123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465 |
- 'use strict';
- /**
- * controller for User Profile Example
- */
- app.controller('adminUserListCtrl', ["$rootScope", "$scope", "$state", "$timeout", "$interval", "$modal", "SweetAlert", "i18nService", "uiGridConstants", "uiGridGroupingConstants", "Restangular", "api_user_data", "api_login", function($rootScope, $scope, $state, $timeout, $interval, $modal, SweetAlert, i18nService, uiGridConstants, uiGridGroupingConstants, Restangular, api_user_data, api_login) {
- $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 = false;
- //$scope.gridOptions.rowTemplate= "<div ng-dblclick=\"grid.appScope.onDblClick(row)\" ng-repeat=\"(colRenderIndex, col) in colContainer.renderedColumns track by col.uid\" ui-grid-one-bind-id-grid=\"rowRenderIndex + '-' + col.uid + '-cell'\" class=\"ui-grid-cell\" ng-class=\"{ 'ui-grid-row-header-cell': col.isRowHeader }\" role=\"{{col.isRowHeader ? 'rowheader' : 'gridcell'}}\" ui-grid-cell></div>";
- $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;
- }
- $scope.transferStatus = function(flag) {
- return (flag == 0) ? "有效" : "无效";
- }
- $scope.transfergroup = function(group) {
- var groupData = '';
- angular.forEach(group, function(item) {
- if (groupData == '') {
- groupData = item.groupName;
- } else {
- groupData = groupData + "/" + item.groupName;
- }
- })
- return groupData;
- }
- //remote data
- $scope.gridOptions.columnDefs = [{
- name: 'item',
- displayName: '序号',
- width: 50,
- enableFiltering: false,
- cellTemplate: '<div>' +
- '<div class="ui-grid-cell-contents">{{row.entity.item}}</div>' +
- '</div>'
- },
- { name: 'account', displayName: '工号', width: '10%', enableFiltering: false },
- { name: 'name', displayName: '姓名', width: '8%', enableFiltering: false },
- { name: 'gender.name', displayName: '性别', width: '6%', enableFiltering: false },
- { name: 'phone', displayName: '联系电话', width: '10%', enableFiltering: false },
- { name: 'email', displayName: '邮箱', width: '10%', enableFiltering: false },
- { name: 'dept.dept', displayName: '科室', width: '10%', enableFiltering: false },
- { name: 'group', displayName: '所属组', width: '10%', cellTemplate: '<div class="ui-grid-cell-contents">{{grid.appScope.transfergroup(row.entity.group)}}</div>', enableFiltering: false },
- { name: 'flag', displayName: '状态', cellTemplate: '<div class="ui-grid-cell-contents">{{grid.appScope.transferStatus(row.entity.flag)}}</div>', width: '6%', enableFiltering: false },
- {
- name: '编辑',
- cellTemplate: '<div><div class="cl-effect-1 ui-grid-cell-contents pull-left">' +
- // '<a ng-click="grid.appScope.saveData(row.entity)" tooltip="编辑" tooltip-placement="right">' +
- // '<i class="fa fa-pencil-square-o"/></a>' +
- '<a ng-click="grid.appScope.saveData(row.entity)" class="bianjifont">编辑</a>' +
- // '<a ng-click="grid.appScope.resetpassword(row.entity.id)" tooltip="重置密码" tooltip-placement="right">' +
- // '<i class="ti-back-right"/></a>' +
- // '<a ng-click="grid.appScope.resetpassword(row.entity.id)" class="printfont" >重置密码</a>' +
- // '<a ng-show="row.entity.isRegis&&row.entity.isRegis==1" ng-click="grid.appScope.registerfunction(row.entity.id)" tooltip="消息中心注册" tooltip-placement="right">' +
- // '<i class="ti-write"/></a>' +
- // '<a ng-show="row.entity.isRegis&&row.entity.isRegis==1" ng-click="grid.appScope.registerfunction(row.entity.id)" class="handlefont" tooltip="消息中心注册" tooltip-placement="left">注册</a>' +
- '</div></div>',
- enableFiltering: false
- }
- ];
- $scope.groupdata = {};
- var apple_selected, tree, treedata_avm, treedata_geography;
- $scope.onFilterCallback = function(branch) {
- var filedata = $scope.memoryfilterData;
- if (filedata.user) {
- filedata.user.groupdata = { id: branch.id };
- } else {
- filedata.user = { groupdata: { id: branch.id } };
- }
- // filedata.user.group = branch.groupName;
- $scope.refreshData('expand-right', filedata);
- };
- $scope.my_data = [];
- $scope.deselectItem = function(item) {
- console.log(item)
- console.log($scope)
- }
- function convertListToTree(data, treeMap) {
- var idToNodeMap = {}; //Keeps track of nodes using id as key, for fast lookup
- var root = null; //Initially set our loop to null
- var parentNode = null;
- //loop over data
- for (var i = 0; i < data.length; i++) {
- var datum = data[i];
- //each node will have children, so let's give it a "children" poperty
- datum.children = [];
- //add an entry for this node to the map so that any future children can
- //lookup the parent
- idToNodeMap[datum.id] = datum;
- //Does this node have a parent?
- if (typeof datum.parent === "undefined" || datum.parent == null) {
- //Doesn't look like it, so this node is the root of the tree
- root = datum;
- treeMap[datum.id] = root;
- } else {
- //This node has a parent, so let's look it up using the id
- parentNode = idToNodeMap[datum.parent.id];
- //We don't need this property, so let's delete it.
- delete datum.parent;
- //Let's add the current node as a child of the parent node.
- parentNode.children.push(datum);
- }
- }
- return root;
- }
- function convertParentToChildList(data) {
- var treeMap = {};
- var list = [];
- convertListToTree(data, treeMap);
- angular.forEach(treeMap, function(item) {
- list.push(item);
- });
- return list;
- }
- $scope.my_tree = tree = {};
- $scope.try_async_load = function() {
- $scope.my_data = [];
- $scope.select_treedata = [];
- $scope.doing_async = true;
- api_user_data.fetchDataList('group', { "idx": 0, "sum": 1000 }).then(function(data) {
- $scope.select_treedata = $scope.my_data = convertParentToChildList(data['list']);
- $scope.doing_async = false;
- // tree.expand_all();
- //console.log(treelist);
- });
- };
- $scope.select_treedata = [];
- $scope.propTypeOptions = [];
- $scope.try_async_load();
- //注册
- $scope.registerfunction = function(id) {
- var modalInstance = $modal.open({
- templateUrl: 'assets/views/system/tpl/register.html',
- controller: function($scope, scope, $modalInstance) {
- $scope.ok = function(key) {
- var filedata = { 'id': id, 'email': key };
- $modalInstance.dismiss('cancel');
- api_user_data.register(filedata).then(function(response) {
- var myData = Restangular.stripRestangular(response);
- if (response.status == 200) {
- SweetAlert.swal({
- title: "注册成功!",
- type: "success",
- confirmButtonColor: "#007AFF"
- }, function() {
- scope.refreshData('expand-right', scope.memoryfilterData);
- });
- } else {
- SweetAlert.swal({
- title: "注册失败!",
- text: response.msg,
- type: "error"
- });
- }
- })
- };
- $scope.cancel = function() {
- $modalInstance.dismiss('cancel');
- };
- },
- resolve: {
- scope: function() {
- return $scope;
- }
- }
- })
- }
- $scope.resetpassword = function(id) {
- var modalInstance = $modal.open({
- templateUrl: 'assets/views/delete.html',
- controller: function($scope, $modalInstance) {
- var data;
- $scope.title = '重置密码';
- $scope.connect = '确定要重置密码?';
- $scope.ok = function() {
- $modalInstance.dismiss('cancel');
- api_login.resetpwd(id).then(function(response) {
- var myData = Restangular.stripRestangular(response);
- // console.log("myData=" + JSON.stringify(myData));
- if (response.status == 200) {
- SweetAlert.swal({
- title: "重置成功!",
- type: "success",
- confirmButtonColor: "#007AFF"
- });
- } else {
- SweetAlert.swal({
- title: "操作异常!",
- text: "系统异常,请稍后重试,或者联系管理员!",
- type: "error"
- });
- }
- })
- };
- $scope.cancel = function() {
- $modalInstance.dismiss('cancel');
- };
- },
- size: 'sm'
- })
- }
- $scope.saveData = function(data) {
- var modelData = { model: { user: data } };
- if (modelData.model.user && modelData.model.user.item) {
- delete modelData.model.user.item;
- }
- $state.go('app.system.form', { formKey: 'system_edit', service: 'api_user_data', model: JSON.stringify(modelData) });
- };
- $scope.addData = function() {
- var modelData={model:{user:{flag:"0"}}};
- $state.go('app.system.form', { formKey: 'system_edit', service: 'api_user_data',model: JSON.stringify(modelData) });
- }
- $scope.removeData = function() {
- var modalInstance = $modal.open({
- templateUrl: 'assets/views/delete.html',
- controller: function($scope, scope, $modalInstance, api_bpm_data) {
- var rmvList = [];
- $scope.title = '人员删除';
- $scope.connect = '确定要删除此人员?';
- angular.forEach(scope.selected.items, function(item) {
- rmvList.push(item.id);
- });
- $scope.ok = function() {
- $modalInstance.close(rmvList);
- };
- $scope.cancel = function() {
- $modalInstance.dismiss('cancel');
- };
- },
- size: 'sm',
- resolve: {
- scope: function() {
- return $scope;
- }
- }
- });
- modalInstance.result.then(function(selectedItem) {
- if (selectedItem) {
- if (selectedItem.length > 0) {
- api_user_data.rmvData('user', selectedItem).then(function(response) {
- if (response.data) {
- SweetAlert.swal({
- title: "删除成功!",
- type: "success",
- confirmButtonColor: "#007AFF"
- }, function() {
- $scope.myData = _.reject($scope.myData, function(o) { return _.includes(selectedItem, o.id); });
- $scope.selected = {
- items: []
- };
- $scope.gridOptions.totalItems = $scope.gridOptions.totalItems - selectedItem.length;
- $scope.gridApi.grid.selection.selectedCount = 0;
- });
- } 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;
- defaultFilterData = filtersData;
- $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)
- }
- });
- // 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['requester'])) {
- // filtersData['requester'] = {};
- // }
- // filtersData['requester'][item.field] = item.filters[0].term;
- // }
- // }
- // });
- // $scope.memoryfilterData = filtersData;
- // $scope.refreshData('expand-right', filtersData);
- // });
- gridApi.core.on.filterChanged($scope, function() {
- var grid = this.grid;
- // var filtersData = {
- // idx: 0,
- // sum: 10
- // };
- var filtersData = $scope.memoryfilterData;
- angular.forEach(grid.columns, function(item) {
- if (item.enableFiltering) {
- if (angular.isDefined(item.filters[0].term) && item.filters[0].term != '') {
- if (angular.isUndefined(filtersData['user'])) {
- filtersData['user'] = {};
- filtersData['user']['flag'] = -1;
- filtersData['user'][item.field] = item.filters[0].term;
- } else {
- filtersData.user.flag = -1;
- filtersData.user[item.field] = item.filters[0].term;
- }
- // filtersData['user']['flag'] = -1;
- // filtersData['user'][item.field] = item.filters[0].term;
- }
- }
- });
- $scope.memoryfilterData = filtersData;
- $scope.refreshData('expand-right', filtersData);
- });
- };
- var defaultFilterData = {
- "idx": 0,
- "sum": 10
- };
- $scope.memoryfilterData = {
- "idx": 0,
- "sum": 10
- }
- $scope.ldloading = {};
- //刷新
- $scope.refresh = function(style, filterData) {
- $scope.selected = { items: [] };
- if ($scope.gridApi) {
- // $scope.gridApi.grid.options.paginationCurrentPage = 0;
- $scope.gridApi.grid.selection.selectedCount = 0;
- }
- $scope.refreshData('expand-right', defaultFilterData);
- }
- //获取列表数据
- $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 = [];
- filterData['flag'] = -1;
- // if ($scope.gridApi) {
- // $scope.gridApi.grid.selection.selectedCount = 0;
- // $scope.selected = { items: [] };
- // }
- console.log("filterData=" + JSON.stringify(filterData))
- api_user_data.fetchDataList('user', filterData).then(function(data) {
- var myData = Restangular.stripRestangular(data);
- $scope.gridOptions.totalItems = myData.totalNum;
- $scope.myData = myData.list;
- for (var i = 0; i < $scope.myData.length; i++) {
- $scope.myData[i]['item'] = i + 1 + filterData.idx * filterData.sum
- }
- $scope.ldloading[style.replace('-', '_')] = false;
- // console.log("$scope.myData="+JSON.stringify($scope.myData))
- }, function() {
- $scope.ldloading[style.replace('-', '_')] = false;
- });
- };
- $scope.refreshData('expand-right', defaultFilterData);
- }]);
|