'use strict'; /** * controller for User Profile Example */ app.controller('userListCtrl', ["$rootScope","$scope", "$state", "$timeout", "$interval", "$modal", "SweetAlert", "i18nService", "uiGridConstants", "uiGridGroupingConstants", "Restangular", "api_configure_data", function ($rootScope, $scope, $state, $timeout, $interval, $modal, SweetAlert, i18nService, uiGridConstants, uiGridGroupingConstants, Restangular, api_configure_data) { $scope.langs=i18nService.getAllLangs(); $scope.lang = 'zh-cn'; i18nService.setCurrentLang($scope.lang); var loginUser=$rootScope.user; //$scope.allright=false; //$scope.allrightnot=true; $scope.gridOptions = {}; $scope.gridOptions.data = 'myData'; $scope.gridOptions.enableColumnResizing = true; $scope.gridOptions.enableFiltering = true; $scope.gridOptions.enableGridMenu = false; $scope.gridOptions.enableRowSelection = true; $scope.gridOptions.showGridFooter = true; $scope.gridOptions.showColumnFooter = false; $scope.gridOptions.fastWatch = true; $scope.gridOptions.useExternalFiltering=true; $scope.gridOptions.useExternalPagination = true; $scope.gridOptions.paginationPageSizes = [10]; $scope.gridOptions.paginationPageSize = 10; $scope.gridOptions.multiSelect = true; //$scope.gridOptions.rowTemplate= "
"; $scope.gridOptions.rowIdentity = function(row) { return row.id; }; $scope.gridOptions.getRowIdentity = function(row) { return row.id; }; $scope.transferRole = function(roles){ var tempValue=""; angular.forEach(roles,function(item){ if(tempValue!=""){ tempValue = tempValue + "/" ; } tempValue = tempValue + item.role; }) return tempValue; } //remote data $scope.gridOptions.columnDefs = [ { name:'requester', displayName:'请求人', width:100,enableFiltering:false}, { name:'candidateGroup', displayName:'技术人员', width:100,enableFiltering:false}, { name:'right', displayName:'权限', width:140, enableFiltering:false}, { name:'group', displayName:'工作组', width:100, enableFiltering:false}, { name:'role', displayName:'角色', width:100, enableFiltering:false}, { name:'scheduling', displayName:'排班', width:100,enableFiltering:false}, { name:'plan', displayName:'计划任务', width:100,enableFiltering:false}, // { name:'role', cellTemplate:'
{{grid.appScope.transferRole(row.entity.role)}}
', displayName:'角色', width:140}, { name:'编辑', cellTemplate:'' + '' , width:100,enableFiltering:false} //'' , width:100, enableFiltering:false} ]; $scope.saveData = function(data){ var modelData = { model : { menu : data } }; // console.log("modelData="+JSON.stringify(modelData)); $state.go('app.system.form_editor',{formKey:'system_edit_navmanager', service:'api_configure_data',model : JSON.stringify(modelData)} ); }; // $scope.addData = function(){ // $state.go('app.system.form',{formKey:'system_edit_navmanager', service:'api_configure_data',} // ); // } $scope.removeData = function(){ var rmvList = []; angular.forEach($scope.selected.items,function(item){ rmvList.push(item.id); }); if(rmvList.length>0){ api_configure_data.rmvData('menu',rmvList).then(function(response){ if(response.data){ SweetAlert.swal({ title: "删除成功!", type: "success", confirmButtonColor: "#007AFF" },function(){ $scope.myData = _.reject($scope.myData, function(o) { return _.includes(rmvList,o.id); }); $scope.selected = { items:[] }; }); }else{ SweetAlert.swal({ title: "操作异常!", text: "系统异常,请稍后重试,或者联系管理员!", type: "error" }); } }) } } $scope.selected = { items:[] } $scope.editted = { items:[] } $scope.gridOptions.onRegisterApi = function(gridApi){ $scope.gridApi = gridApi; gridApi.edit.on.afterCellEdit($scope,function(rowEntity, colDef, newValue, oldValue){ console.log(rowEntity); }); gridApi.pagination.on.paginationChanged($scope, function (newPage, pageSize) { var filtersData = $scope.memoryfilterData; filtersData.idx=newPage-1; filtersData.sum=pageSize; $scope.refreshData('expand-right',filtersData); }); gridApi.selection.on.rowSelectionChanged($scope, function(scope){ var j=0; for(var i=0;i<=scope.grid.appScope.selected.items.length;i++){ if(scope.grid.appScope.selected.items[i]==scope.entity){ j++; break; } } // console.log("j="+j) if(j==1){ scope.grid.appScope.selected.items.splice(i,1); }else{ scope.grid.appScope.selected.items.push(scope.entity) } //console.log("scope.grid.appScope.selected.items="+JSON.stringify(scope.grid.appScope.selected.items)); //console.log("scope.entity="+JSON.stringify(scope.entity)); }); gridApi.core.on.filterChanged( $scope, function() { var grid = this.grid; var filtersData = { idx:0, sum:10 }; angular.forEach(grid.columns,function(item){ if(item.enableFiltering){ if(angular.isDefined(item.filters[0].term)&&item.filters[0].term!=''){ if(angular.isUndefined(filtersData['menu'])){ filtersData['menu']={}; } filtersData['menu'][item.field]=item.filters[0].term; } } }); // $scope.memoryfilterData = filterData $scope.refreshData('expand-right', filtersData); }); }; var defaultFilterData = { "idx":0, "sum":10 }; $scope.memoryfilterData = { "idx":0, "sum":10 } $scope.ldloading = {}; $scope.refreshData = function(style,filterData){ // $scope.ldloading[style.replace('-', '_')] = true; // if(angular.isUndefined(filterData)){ // filterData = defaultFilterData; // } // if(angular.isDefined($scope.searchTypes)){ // filterData['searchType'] = $scope.searchTypes; // } // $scope.myData = []; // api_configure_data.fetchDataList('menu',filterData).then(function(data){ // var myData = Restangular.stripRestangular(data); // $scope.gridOptions.totalItems = myData.totalNum; // $scope.myData = myData.list; // $scope.ldloading[style.replace('-', '_')] = false; // },function(){ // $scope.ldloading[style.replace('-', '_')] = false; // }); }; // $scope.refreshData('expand-right', defaultFilterData); }]);