'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);
}]);