worktimeCtrl.js 25 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561
  1. 'use strict';
  2. /**
  3. * controller for User Profile Example
  4. */
  5. app.controller('woketimeCtrl', ["$rootScope", "$scope", "$state", "$timeout", "$interval", "$modal", "SweetAlert", "i18nService", "uiGridConstants", "uiGridGroupingConstants", "Restangular", "api_bpm_schedule", "api_bpm_data", "api_wechatfile", function($rootScope, $scope, $state, $timeout, $interval, $modal, SweetAlert, i18nService, uiGridConstants, uiGridGroupingConstants, Restangular, api_bpm_schedule, api_bpm_data, api_wechatfile) {
  6. $scope.langs = i18nService.getAllLangs();
  7. $scope.lang = 'zh-cn';
  8. i18nService.setCurrentLang($scope.lang);
  9. var loginUser = $rootScope.user;
  10. $scope.xinzeng=false;
  11. $scope.shanchu=false;
  12. $scope.bianji=false;
  13. for(var i=0;i<loginUser.menu.length;i++){
  14. if(loginUser.menu[i].link=="gongzuoshijianshezhi_xinzeng"){
  15. $scope.xinzeng=true
  16. }
  17. if(loginUser.menu[i].link=="gongzuoshijianshezhi_shanchu"){
  18. $scope.shanchu=true
  19. }
  20. if(loginUser.menu[i].link=="gongzuoshijianshezhi_bianji"){
  21. $scope.bianji=true
  22. }
  23. }
  24. $scope.gridOptions = {};
  25. $scope.gridOptions.data = 'myData';
  26. $scope.gridOptions.enableColumnResizing = true;
  27. $scope.gridOptions.enableFiltering = true;
  28. $scope.gridOptions.enableGridMenu = true;
  29. $scope.gridOptions.enableRowSelection = true;
  30. $scope.gridOptions.showGridFooter = true;
  31. $scope.gridOptions.showColumnFooter = false;
  32. $scope.gridOptions.fastWatch = true;
  33. $scope.gridOptions.useExternalFiltering = true;
  34. $scope.gridOptions.useExternalPagination = true;
  35. $scope.gridOptions.paginationPageSizes = [10, 20, 50, 100];
  36. $scope.gridOptions.paginationPageSize = 10;
  37. $scope.gridOptions.multiSelect = false;
  38. $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>";
  39. $scope.gridOptions.rowIdentity = function(row) {
  40. return row.id;
  41. };
  42. $scope.gridOptions.getRowIdentity = function(row) {
  43. return row.id;
  44. };
  45. $scope.transferWorkDay = function(deleteFlag) {
  46. if (deleteFlag == true) { return "工作日" } else { return "节假日" }
  47. }
  48. $scope.transfer = function(deleteFlag) {
  49. if (deleteFlag == true) { return "是" } else { return "否" }
  50. }
  51. $scope.transferstatus = function(deleteFlag) {
  52. if (deleteFlag == true) { return "停用" } else { return "使用" }
  53. }
  54. $scope.translate = function(item) {
  55. return item?moment(item).format('HH:mm'):''
  56. }
  57. $scope.gridOptions.columnDefs = [
  58. { name: 'item', displayName: '序号', width: 50, enableFiltering: false },
  59. { name: 'name', displayName: '班次', width: '8%', enableFiltering: false },
  60. {
  61. name: 'startTime',
  62. displayName: '起始时间1',
  63. width: '8%',
  64. enableFiltering: false,
  65. cellTemplate: '<div class="ui-grid-cell-contents">{{grid.appScope.translate(row.entity.startTime)}}~{{grid.appScope.translate(row.entity.endTime)}}</div>'
  66. },
  67. {
  68. name: 'startTime2',
  69. displayName: '起始时间2',
  70. width: '8%',
  71. enableFiltering: false,
  72. cellTemplate: '<div class="ui-grid-cell-contents">{{grid.appScope.translate(row.entity.startTime2)}}~{{grid.appScope.translate(row.entity.endTime2)}}</div>'
  73. },
  74. {
  75. name: 'startTime3',
  76. displayName: '起始时间3',
  77. width: '8%',
  78. enableFiltering: false,
  79. cellTemplate: '<div class="ui-grid-cell-contents">{{grid.appScope.translate(row.entity.startTime3)}}~{{grid.appScope.translate(row.entity.endTime3)}}</div>'
  80. },
  81. { name: 'type.name', displayName: '班次类型', width: '8%', enableFiltering: false },
  82. { name: 'isTemplate', displayName: '呼叫中心关联', width: '8%', enableFiltering: false, cellTemplate: '<div class="ui-grid-cell-contents">{{grid.appScope.transfer(row.entity.isTemplate)}}</div>' },
  83. { name: 'priority.name', displayName: '优先级关联', width: '8%', enableFiltering: false },
  84. { name: 'description', displayName: '班次描述', width: '10%', enableFiltering: false },
  85. { name: 'deleteFlag', displayName: '使用状态', width: '8%', enableFiltering: false, cellTemplate: '<div class="ui-grid-cell-contents">{{grid.appScope.transferstatus(row.entity.deleteFlag)}}</div>' },
  86. { name: 'workDay', displayName: '工作日/节假日', width: '8%', enableFiltering: false, cellTemplate: '<div class="ui-grid-cell-contents">{{grid.appScope.transferWorkDay(row.entity.workDay)}}</div>' },
  87. {
  88. name: '编辑',
  89. cellTemplate: '<div><div class="links cl-effect-1 ui-grid-cell-contents" >' +
  90. '<a ng-click="grid.appScope.saveData(row.entity)" ng-show="grid.appScope.bianji" class="bianjifont">编辑</a>' +
  91. '</div></div>',
  92. enableFiltering: false
  93. },
  94. ];
  95. $scope.saveData = function(selectdata) {
  96. selectdata = angular.copy(selectdata);
  97. var modalInstance = $modal.open({
  98. resolve: {
  99. scope: function () {
  100. return $scope;
  101. }
  102. },
  103. templateUrl: 'assets/views/system/tpl/systemworktime.html',
  104. controller: function($scope, scope, $modalInstance, api_bpm_data) {
  105. $scope.title = "修改班次";
  106. $scope.changeType = function(e){
  107. $scope.worktimedata.isTemplate = false;
  108. $scope.worktimedata.priority = undefined;
  109. }
  110. // 时间start
  111. $scope.times = [];
  112. $scope.timeId = 1;
  113. $scope.isAdd = true;
  114. // 新添加
  115. $scope.add = function() {
  116. $scope.times.push({ id: ++$scope.timeId, startTime: new Date(), endTime: new Date() });
  117. $scope.timeChange();
  118. }
  119. // 删除
  120. $scope.remove = function(index) {
  121. $scope.times.splice(index, 1);
  122. $scope.timeChange();
  123. }
  124. //监听输入事件
  125. $scope.timeChange = function(e, time, i) {
  126. console.log(e, time)
  127. // -------------判断添加按钮是否禁用 start
  128. $scope.isAdd = $scope.times.length >= 3;
  129. // -------------判断添加按钮是否禁用 end
  130. }
  131. $scope.timeChange();
  132. // 时间end
  133. $scope.worktimedata = {"isTemplate": false, name: ''};
  134. selectdata.workDay = selectdata.workDay?selectdata.workDay:0;
  135. var times = [];
  136. if(selectdata.startTime && selectdata.endTime){
  137. times.push({id: $scope.timeId++, startTime: selectdata.startTime, endTime: selectdata.endTime})
  138. }
  139. if(selectdata.startTime2 && selectdata.endTime2){
  140. times.push({id: $scope.timeId++, startTime: selectdata.startTime2, endTime: selectdata.endTime2})
  141. }
  142. if(selectdata.startTime3 && selectdata.endTime3){
  143. times.push({id: $scope.timeId++, startTime: selectdata.startTime3, endTime: selectdata.endTime3})
  144. }
  145. $scope.times = times;
  146. $scope.worktimedata = angular.copy(selectdata);
  147. $scope.dictionary = [];
  148. api_wechatfile.getDictionary({ "type": "list", "key": "schedule_class_type" }).then(function(data) {
  149. if (data) {
  150. $scope.dictionary = data;
  151. }
  152. })
  153. $scope.priorityList = [];
  154. api_wechatfile.getDictionary({ "type": "list", "key": "incident_priority" }).then(function(data) {
  155. if (data) {
  156. $scope.priorityList = data;
  157. }
  158. })
  159. $scope.cancel = function() {
  160. $modalInstance.dismiss('cancel');
  161. };
  162. $scope.savercode = function(worktimedata) {
  163. var fildata = {
  164. "scheduleclass": worktimedata
  165. }
  166. $scope.times.forEach( (v, i) => {
  167. fildata.scheduleclass['startTime' + (i === 0 ? '' : (i + 1))] = v.startTime ? moment(v.startTime).startOf('minute').format('YYYY-MM-DD HH:mm:ss') : undefined;
  168. fildata.scheduleclass['endTime' + (i === 0 ? '' : (i + 1))] = v.endTime ? moment(v.endTime).startOf('minute').format('YYYY-MM-DD HH:mm:ss') : undefined;
  169. })
  170. if (!fildata.scheduleclass.name.trim()) {
  171. SweetAlert.swal({
  172. title: "新增失败!",
  173. text: "班次未填",
  174. type: "error"
  175. })
  176. } else if (!fildata.scheduleclass.startTime) {
  177. SweetAlert.swal({
  178. title: "新增失败!",
  179. text: "班次开始时间未填",
  180. type: "error"
  181. })
  182. } else if (!fildata.scheduleclass.endTime) {
  183. SweetAlert.swal({
  184. title: "新增失败!",
  185. text: "班次结束时间未填",
  186. type: "error"
  187. })
  188. } else if (!fildata.scheduleclass.type) {
  189. SweetAlert.swal({
  190. title: "新增失败!",
  191. text: "班次类型未填",
  192. type: "error"
  193. })
  194. } else if (fildata.scheduleclass.workDay === undefined) {
  195. SweetAlert.swal({
  196. title: "新增失败!",
  197. text: "工作日/节假日未填",
  198. type: "error"
  199. })
  200. }else{
  201. api_bpm_data.updData('scheduleclass', fildata).then(function(response) {
  202. if (response) {
  203. if (response.status == 200) {
  204. if(response.data && !response.data.priority && !response.data.type){
  205. SweetAlert.swal({
  206. title: "操作异常!",
  207. text: "优先级重复!",
  208. type: "error"
  209. });
  210. }else{
  211. SweetAlert.swal({
  212. title: "修改成功!",
  213. type: "success"
  214. }, function() {
  215. scope.refreshData('expand-right');
  216. $modalInstance.close();
  217. })
  218. }
  219. } else {
  220. SweetAlert.swal({
  221. title: "修改失败!",
  222. type: "error"
  223. })
  224. }
  225. }
  226. })
  227. }
  228. }
  229. }
  230. });
  231. }
  232. $scope.addData = function() {
  233. var modalInstance = $modal.open({
  234. templateUrl: 'assets/views/system/tpl/systemworktime.html',
  235. controller: function($scope, $modalInstance, api_bpm_data) {
  236. $scope.title = "新增班次";
  237. $scope.changeType = function(e){
  238. $scope.worktimedata.isTemplate = false;
  239. $scope.worktimedata.priority = undefined;
  240. }
  241. // 时间start
  242. $scope.times = [{id: 1, startTime: new Date(), endTime: new Date()}];
  243. $scope.timeId = 1;
  244. $scope.isAdd = true;
  245. // 新添加
  246. $scope.add = function() {
  247. $scope.times.push({ id: ++$scope.timeId, startTime: new Date(), endTime: new Date() });
  248. $scope.timeChange();
  249. }
  250. // 删除
  251. $scope.remove = function(index) {
  252. $scope.times.splice(index, 1);
  253. $scope.timeChange();
  254. }
  255. //监听输入事件
  256. $scope.timeChange = function(e, time, i) {
  257. console.log(e, time)
  258. // -------------判断添加按钮是否禁用 start
  259. $scope.isAdd = $scope.times.length >= 3;
  260. // -------------判断添加按钮是否禁用 end
  261. }
  262. $scope.timeChange();
  263. // 时间end
  264. $scope.dictionary = [];
  265. api_wechatfile.getDictionary({ "type": "list", "key": "schedule_class_type" }).then(function(data) {
  266. if (data) {
  267. $scope.dictionary = data;
  268. }
  269. })
  270. $scope.priorityList = [];
  271. api_wechatfile.getDictionary({ "type": "list", "key": "incident_priority" }).then(function(data) {
  272. if (data) {
  273. $scope.priorityList = data;
  274. }
  275. })
  276. $scope.worktimedata = { "isTemplate": false, name: '' }
  277. $scope.cancel = function() {
  278. $modalInstance.dismiss('cancel');
  279. };
  280. $scope.savercode = function(worktimedata) {
  281. var selectedItem = worktimedata;
  282. var fildata = {
  283. "scheduleclass": {
  284. // "code": selectedItem.code,
  285. "name": selectedItem.name,
  286. "description": selectedItem.description,
  287. "shiftTime": selectedItem.shiftTime,
  288. "succeedTime": selectedItem.succeedTime,
  289. "type": selectedItem.type,
  290. "priority": selectedItem.priority,
  291. "isTemplate": selectedItem.isTemplate,
  292. "deleteFlag": selectedItem.deleteFlag,
  293. "workDay": selectedItem.workDay,
  294. }
  295. }
  296. $scope.times.forEach( (v, i) => {
  297. fildata.scheduleclass['startTime' + (i === 0 ? '' : (i + 1))] = v.startTime ? moment(v.startTime).startOf('minute').format('YYYY-MM-DD HH:mm:ss') : undefined;
  298. fildata.scheduleclass['endTime' + (i === 0 ? '' : (i + 1))] = v.endTime ? moment(v.endTime).startOf('minute').format('YYYY-MM-DD HH:mm:ss') : undefined;
  299. })
  300. if (!fildata.scheduleclass.name.trim()) {
  301. SweetAlert.swal({
  302. title: "新增失败!",
  303. text: "班次未填",
  304. type: "error"
  305. })
  306. } else if (!fildata.scheduleclass.startTime) {
  307. SweetAlert.swal({
  308. title: "新增失败!",
  309. text: "班次开始时间未填",
  310. type: "error"
  311. })
  312. } else if (!fildata.scheduleclass.endTime) {
  313. SweetAlert.swal({
  314. title: "新增失败!",
  315. text: "班次结束时间未填",
  316. type: "error"
  317. })
  318. } else if (!fildata.scheduleclass.type) {
  319. SweetAlert.swal({
  320. title: "新增失败!",
  321. text: "班次类型未填",
  322. type: "error"
  323. })
  324. } else if (fildata.scheduleclass.workDay === undefined) {
  325. SweetAlert.swal({
  326. title: "新增失败!",
  327. text: "工作日/节假日未填",
  328. type: "error"
  329. })
  330. }else{
  331. $modalInstance.close(fildata);
  332. }
  333. };
  334. }
  335. });
  336. modalInstance.result.then(function(selectedItem) {
  337. if (selectedItem) {
  338. var fildata = selectedItem
  339. api_bpm_data.addData('scheduleclass', fildata).then(function(response) {
  340. if (response.status == 200) {
  341. if(response.data && !response.data.priority && !response.data.type){
  342. SweetAlert.swal({
  343. title: "操作异常!",
  344. text: "优先级重复!",
  345. type: "error"
  346. });
  347. }else{
  348. SweetAlert.swal({
  349. title: "新增成功!",
  350. type: "success"
  351. }, function() {
  352. $scope.refreshData('expand-right', defaultFilterData);
  353. })
  354. }
  355. } else {
  356. SweetAlert.swal({
  357. title: "新增失败!",
  358. type: "error"
  359. })
  360. }
  361. })
  362. }
  363. });
  364. }
  365. $scope.removeData = function() {
  366. var modalInstance = $modal.open({
  367. templateUrl: 'assets/views/incident/tpl/acceptTask.tpl.html',
  368. controller: function($scope, scope, $modalInstance, api_user_data) {
  369. var rmvList = [];
  370. $scope.title = "删除";
  371. $scope.connect = "确定要删除本班次?";
  372. rmvList.push(scope.selected.items[0].id);
  373. $scope.ok = function() {
  374. $modalInstance.close(rmvList);
  375. };
  376. $scope.cancel = function() {
  377. $modalInstance.dismiss('cancel');
  378. };
  379. },
  380. size: 'sm',
  381. resolve: {
  382. scope: function() {
  383. return $scope;
  384. }
  385. }
  386. });
  387. modalInstance.result.then(function(selectedItem) {
  388. if (selectedItem) {
  389. if (selectedItem.length > 0) {
  390. api_bpm_data.rmvData('scheduleclass', selectedItem).then(function(response) {
  391. if (response.status == 200) {
  392. if(response.data && !response.data.priority && !response.data.type){
  393. SweetAlert.swal({
  394. title: "操作异常!",
  395. text: "优先级重复!",
  396. type: "error"
  397. });
  398. }else{
  399. SweetAlert.swal({
  400. title: "删除成功!",
  401. type: "success",
  402. confirmButtonColor: "#007AFF"
  403. }, function() {
  404. $scope.refreshData('expand-right', defaultFilterData);
  405. // $scope.myData = _.reject($scope.myData, function(o) { return _.includes(selectedItem, o.id); });
  406. // $scope.selected = {
  407. // items: []
  408. // };
  409. // $scope.gridOptions.totalItems = $scope.gridOptions.totalItems - selectedItem.length
  410. $scope.gridApi.grid.selection.selectedCount = 0;
  411. });
  412. }
  413. } else {
  414. SweetAlert.swal({
  415. title: "操作异常!",
  416. text: "系统异常,请稍后重试,或者联系管理员!",
  417. type: "error"
  418. });
  419. }
  420. })
  421. }
  422. }
  423. })
  424. }
  425. $scope.selected = {
  426. items: []
  427. }
  428. $scope.editted = {
  429. items: []
  430. }
  431. $scope.gridOptions.onRegisterApi = function(gridApi) {
  432. $scope.gridApi = gridApi;
  433. // gridApi.edit.on.afterCellEdit($scope,function(rowEntity, colDef, newValue, oldValue){
  434. // console.log(rowEntity);
  435. // });
  436. gridApi.pagination.on.paginationChanged($scope, function(newPage, pageSize) {
  437. var filtersData = $scope.memoryfilterData;
  438. filtersData.idx = newPage - 1;
  439. filtersData.sum = pageSize;
  440. defaultFilterData = filtersData;
  441. $scope.refreshData('expand-right', filtersData);
  442. });
  443. // gridApi.selection.on.rowSelectionChanged($scope, function(scope) {
  444. // scope.grid.appScope.selected.items[0] = scope.entity
  445. // });
  446. gridApi.selection.on.rowSelectionChanged($scope, function(data) {
  447. if (data.isSelected) {
  448. data.grid.appScope.selected.items[0] = data.entity;
  449. } else {
  450. if (data.grid.appScope.selected.items[0].id == data.entity.id) {
  451. data.grid.appScope.selected.items = [];
  452. }
  453. }
  454. });
  455. };
  456. var defaultFilterData = {
  457. "idx": 0,
  458. "sum": 10
  459. };
  460. $scope.memoryfilterData = {
  461. "idx": 0,
  462. "sum": 10
  463. }
  464. $scope.ldloading = {};
  465. $scope.refresh = function(style, filterData) {
  466. $scope.selected = { items: [] };
  467. if ($scope.gridApi) {
  468. // $scope.gridApi.grid.options.paginationCurrentPage = 0;
  469. $scope.gridApi.grid.selection.selectedCount = 0;
  470. }
  471. $scope.refreshData('expand-right', defaultFilterData);
  472. }
  473. $scope.refreshData = function(style, filterData) {
  474. $scope.ldloading[style.replace('-', '_')] = true;
  475. if (angular.isUndefined(filterData)) {
  476. filterData = defaultFilterData;
  477. }
  478. $scope.myData = [];
  479. // $scope.selected = { items: [] };
  480. // if ($scope.gridApi) {
  481. // $scope.gridApi.grid.selection.selectedCount = 0;
  482. // }
  483. api_bpm_schedule.getScheduleClass().then(function(response) {
  484. if (response.status == 200) {
  485. $scope.ldloading[style.replace('-', '_')] = false;
  486. var scheduleClassList = response.list;
  487. $scope.gridOptions.totalItems = response.totalNum;
  488. angular.forEach(scheduleClassList, function(item) {
  489. var templateEvent = {
  490. id: item.id,
  491. name: item['name'],
  492. // code: item['code'],
  493. startTime: item.startTime,
  494. startTime2: item.startTime2,
  495. startTime3: item.startTime3,
  496. //starts_at:
  497. endTime: item.endTime,
  498. endTime2: item.endTime2,
  499. endTime3: item.endTime3,
  500. type: item.type,
  501. priority: item.priority,
  502. succeedTime: item.succeedTime,
  503. shiftTime: item.shiftTime,
  504. description: item.description,
  505. deleteFlag: item.deleteFlag,
  506. isTemplate: item.isTemplate,
  507. draggable: true,
  508. workDay: item.workDay,
  509. };
  510. $scope.myData.push(templateEvent);
  511. })
  512. for (var i = 0; i < $scope.myData.length; i++) {
  513. $scope.myData[i]['item'] = i + 1 + filterData.idx * filterData.sum
  514. }
  515. }
  516. })
  517. // $scope.myData = [];
  518. // api_bpm_data.fetchDataList('closecode',filterData).then(function(data){
  519. // var myData = Restangular.stripRestangular(data);
  520. // $scope.gridOptions.totalItems = myData.totalNum;
  521. // $scope.myData = myData.list;
  522. // $scope.ldloading[style.replace('-', '_')] = false;
  523. // },function(){
  524. // $scope.ldloading[style.replace('-', '_')] = false;
  525. // });
  526. };
  527. $scope.refreshData('expand-right', defaultFilterData);
  528. }]);