158 lines
4.5 KiB
Python
158 lines
4.5 KiB
Python
'use strict';
|
|
|
|
app.controller('MenuController', function (
|
|
$scope,
|
|
$window,
|
|
$uibModal,
|
|
MenuService,
|
|
toaster,
|
|
$translate) {
|
|
$scope.menus = [];
|
|
$scope.currentMenu = {};
|
|
$scope.currentMenuChildren = [];
|
|
$scope.cur_user = JSON.parse($window.localStorage.getItem("myems_admin_ui_current_user"));
|
|
$scope.getAllMenus = function () {
|
|
MenuService.getAllMenus(function (response) {
|
|
if (angular.isDefined(response.status) && response.status === 200) {
|
|
$scope.menus = response.data;
|
|
} else {
|
|
$scope.menus = [];
|
|
}
|
|
//create menu tree
|
|
var treedata = { 'core': { 'data': [], "multiple": false, }, "plugins": ["wholerow"] };
|
|
for (var i = 0; i < $scope.menus.length; i++) {
|
|
if ($scope.menus[i].parent_menu_id == null) {
|
|
var node = {
|
|
"id": $scope.menus[i].id.toString(),
|
|
"parent": '#',
|
|
"text": $scope.menus[i].name,
|
|
"state": { 'opened': true },
|
|
};
|
|
} else {
|
|
var node = {
|
|
"id": $scope.menus[i].id.toString(),
|
|
"parent": $scope.menus[i].parent_menu_id.toString(),
|
|
"text": $scope.menus[i].name,
|
|
"state": { 'opened': true },
|
|
};
|
|
};
|
|
treedata['core']['data'].push(node);
|
|
}
|
|
|
|
angular.element(menutree).jstree(treedata);
|
|
//menu tree selected changed event handler
|
|
angular.element(menutree).on("changed.jstree", function (e, data) {
|
|
if (data.action === 'ready' || data.action === 'select_node') {
|
|
$scope.getMenuChildren(parseInt(data.selected[0]));
|
|
};
|
|
});
|
|
});
|
|
};
|
|
|
|
$scope.refreshMenuTree = function () {
|
|
MenuService.getAllMenus(function (response) {
|
|
if (angular.isDefined(response.status) && response.status === 200) {
|
|
$scope.menus = response.data;
|
|
} else {
|
|
$scope.menus = [];
|
|
}
|
|
//create menu tree
|
|
var treedata = { 'core': { 'data': [], "multiple": false, }, "plugins": ["wholerow"] };
|
|
for (var i = 0; i < $scope.menus.length; i++) {
|
|
if ($scope.menus[i].parent_menu_id == null) {
|
|
var node = {
|
|
"id": $scope.menus[i].id.toString(),
|
|
"parent": '#',
|
|
"text": $scope.menus[i].name,
|
|
"state": { 'opened': true},
|
|
};
|
|
} else {
|
|
var node = {
|
|
"id": $scope.menus[i].id.toString(),
|
|
"parent": $scope.menus[i].parent_menu_id.toString(),
|
|
"text": $scope.menus[i].name,
|
|
"state": { 'opened': true},
|
|
};
|
|
};
|
|
treedata['core']['data'].push(node);
|
|
}
|
|
var menutree = document.getElementById("menutree");
|
|
angular.element(menutree).jstree(true).settings.core.data = treedata['core']['data'];
|
|
angular.element(menutree).jstree(true).refresh();
|
|
});
|
|
};
|
|
|
|
$scope.getMenuChildren = function (menuid) {
|
|
MenuService.getMenuChildren(menuid, function (response) {
|
|
if (angular.isDefined(response.status) && response.status === 200) {
|
|
$scope.currentMenu = response.data["current"];
|
|
$scope.currentMenuChildren = response.data["children"];
|
|
} else {
|
|
$scope.currentMenu = {};
|
|
$scope.currentMenuChildren = [];
|
|
}
|
|
});
|
|
};
|
|
|
|
$scope.editMenu = function (menu) {
|
|
var modalInstance = $uibModal.open({
|
|
windowClass: "animated fadeIn",
|
|
templateUrl: 'views/settings/menu/menu.model.html',
|
|
controller: 'ModalEditMenuCtrl',
|
|
resolve: {
|
|
params: function () {
|
|
return {
|
|
menu: angular.copy(menu),
|
|
menus: angular.copy($scope.menus),
|
|
};
|
|
}
|
|
}
|
|
});
|
|
|
|
modalInstance.result.then(function (modifiedMenu) {
|
|
let headers = { "User-UUID": $scope.cur_user.uuid, "Token": $scope.cur_user.token };
|
|
MenuService.editMenu(modifiedMenu, headers, function (response) {
|
|
if (angular.isDefined(response.status) && response.status === 200) {
|
|
toaster.pop({
|
|
type: "success",
|
|
title: $translate.instant("TOASTER.SUCCESS_TITLE"),
|
|
body: $translate.instant("TOASTER.SUCCESS_UPDATE_BODY", { template: $translate.instant("COMMON.MENU") }),
|
|
showCloseButton: true,
|
|
});
|
|
$scope.$emit('handleEmitMenuChanged');
|
|
} else {
|
|
toaster.pop({
|
|
type: "error",
|
|
title: $translate.instant("TOASTER.ERROR_UPDATE_BODY", { template: $translate.instant("COMMON.MENU") }),
|
|
body: $translate.instant(response.data.description),
|
|
showCloseButton: true,
|
|
});
|
|
}
|
|
});
|
|
}, function () {
|
|
//do nothing;
|
|
});
|
|
};
|
|
|
|
$scope.getAllMenus();
|
|
|
|
$scope.$on('handleBroadcastMenuChanged', function (event) {
|
|
$scope.refreshMenuTree();
|
|
});
|
|
|
|
});
|
|
|
|
|
|
app.controller('ModalEditMenuCtrl', function ($scope, $uibModalInstance, params) {
|
|
$scope.operation = "SETTING.EDIT_MENU";
|
|
$scope.menu = params.menu;
|
|
|
|
$scope.ok = function () {
|
|
$uibModalInstance.close($scope.menu);
|
|
};
|
|
|
|
$scope.cancel = function () {
|
|
$uibModalInstance.dismiss('cancel');
|
|
};
|
|
});
|