worktimeCtrl.js 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265
  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",function ($rootScope, $scope, $state, $timeout, $interval, $modal, SweetAlert, i18nService, uiGridConstants, uiGridGroupingConstants, Restangular, api_bpm_schedule,api_bpm_data) {
  6. $scope.langs=i18nService.getAllLangs();
  7. $scope.lang = 'zh-cn';
  8. i18nService.setCurrentLang($scope.lang);
  9. var loginUser=$rootScope.user;
  10. $scope.gridOptions = {};
  11. $scope.gridOptions.data = 'myData';
  12. $scope.gridOptions.enableColumnResizing = true;
  13. $scope.gridOptions.enableFiltering = true;
  14. $scope.gridOptions.enableGridMenu = false;
  15. $scope.gridOptions.enableRowSelection = true;
  16. $scope.gridOptions.showGridFooter = true;
  17. $scope.gridOptions.showColumnFooter = false;
  18. $scope.gridOptions.fastWatch = true;
  19. $scope.gridOptions.useExternalFiltering=true;
  20. $scope.gridOptions.useExternalPagination = true;
  21. $scope.gridOptions.paginationPageSizes = [10];
  22. $scope.gridOptions.paginationPageSize = 10;
  23. $scope.gridOptions.multiSelect = false;
  24. //$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>";
  25. $scope.gridOptions.rowIdentity = function(row) {
  26. return row.id;
  27. };
  28. $scope.gridOptions.getRowIdentity = function(row) {
  29. return row.id;
  30. };
  31. $scope.transfer= function(deleteFlag){
  32. if(deleteFlag==true){return "是"}
  33. else {return "否"}
  34. }
  35. $scope.gridOptions.columnDefs = [
  36. { name:'code', displayName:'班次代码', width:100, enableFiltering:false},
  37. { name:'title', displayName:'班次', width:100, enableFiltering:false},
  38. { name:'startTime', displayName:'开始时间', width:200, enableFiltering:false},
  39. { name:'endTime', displayName:'结束时间', width:200, enableFiltering:false},
  40. { name:'person', displayName:'本班次人数', width:100, enableFiltering:false},
  41. { name:'description', displayName:'班次描述', width:100, enableFiltering:false},
  42. { name:'deleteFlag', displayName:'是否被删除', width:100, enableFiltering:false,cellTemplate:'<div class="ui-grid-cell-contents">{{grid.appScope.transfer(row.entity.deleteFlag)}}</div>'},
  43. { name:'isTemplate', displayName:'是否为模版', width:100, enableFiltering:false,cellTemplate:'<div class="ui-grid-cell-contents">{{grid.appScope.transfer(row.entity.isTemplate)}}</div>'},
  44. { name:'修改', cellTemplate:'<a class="btn btn-sm btn-info" ng-click="grid.appScope.saveData(row.entity)" tooltip="编辑">' +
  45. '<i class="fa fa-pencil-square-o"/></a>' , width:100,enableFiltering:false}
  46. ];
  47. $scope.saveData = function(selectdata){
  48. var modalInstance = $modal.open({
  49. templateUrl: 'assets/views/system/tpl/systemworktime.html',
  50. controller: function($scope, $modalInstance, api_bpm_data){
  51. $scope.worktimedata={};
  52. $scope.worktimedata=selectdata;
  53. $scope.cancel = function() {
  54. $modalInstance.dismiss('cancel');
  55. };
  56. $scope.savercode = function(worktimedata){
  57. var fildata={
  58. "scheduleclass": {
  59. "id":selectdata.id,
  60. "code": worktimedata.code,
  61. "name": worktimedata.title,
  62. "person": worktimedata.person,
  63. "description": worktimedata.description,
  64. "startTime": worktimedata.startTime,
  65. "endTime": worktimedata.endTime,
  66. "shiftTime": selectdata.shiftTime,
  67. "succeedTime": selectdata.succeedTime,
  68. "isTemplate": worktimedata.isTemplate
  69. }
  70. }
  71. api_bpm_data.updData('scheduleclass',fildata).then(function(response){
  72. if(response){
  73. if(response.status==200){
  74. SweetAlert.swal({
  75. title:"修改成功!",
  76. type:"success"
  77. },function(){
  78. // $scope.refreshData('expand-right', defaultFilterData);
  79. })
  80. }else{
  81. SweetAlert.swal({
  82. title:"修改失败!",
  83. type:"error"
  84. })
  85. }
  86. }
  87. })
  88. $modalInstance.close();
  89. }
  90. }
  91. });
  92. }
  93. $scope.addData = function(){
  94. var modalInstance = $modal.open({
  95. templateUrl: 'assets/views/system/tpl/systemworktime.html',
  96. controller: function($scope, $modalInstance,api_bpm_data){
  97. $scope.cancel = function() {
  98. $modalInstance.dismiss('cancel');
  99. };
  100. $scope.savercode = function(worktimedata) {
  101. $modalInstance.close(worktimedata);
  102. };
  103. }
  104. });
  105. modalInstance.result.then(function(selectedItem) {
  106. if(selectedItem){
  107. var fildata={
  108. "scheduleclass": {
  109. "code": selectedItem.code,
  110. "name": selectedItem.title,
  111. "person": selectedItem.person,
  112. "description": selectedItem.description,
  113. "startTime": selectedItem.startTime,
  114. "endTime": selectedItem.endTime,
  115. "shiftTime": selectedItem.shiftTime,
  116. "succeedTime": selectedItem.succeedTime,
  117. "isTemplate": selectedItem.isTemplate
  118. }
  119. }
  120. api_bpm_data.addData('scheduleclass',fildata).then(function(response){
  121. if(response.status==200){
  122. SweetAlert.swal({
  123. title:"新增成功!",
  124. type:"success"
  125. },function(){
  126. $scope.refreshData('expand-right', defaultFilterData);
  127. })
  128. }else{
  129. SweetAlert.swal({
  130. title:"新增失败!",
  131. type:"error"
  132. })
  133. }
  134. })
  135. }
  136. });
  137. }
  138. $scope.removeData = function(){
  139. var rmvList = [$scope.selected.items.id]
  140. if(rmvList.length>0){
  141. api_bpm_data.rmvData('scheduleclass',rmvList).then(function(response){
  142. if(response.status==200){
  143. SweetAlert.swal({
  144. title: "删除成功!",
  145. type: "success",
  146. confirmButtonColor: "#007AFF"
  147. },function(){
  148. });
  149. }else{
  150. SweetAlert.swal({
  151. title: "操作异常!",
  152. text: "系统异常,请稍后重试,或者联系管理员!",
  153. type: "error"
  154. });
  155. }
  156. })
  157. }
  158. }
  159. $scope.selected = {
  160. items:[]
  161. }
  162. $scope.editted = {
  163. items:[]
  164. }
  165. $scope.gridOptions.onRegisterApi = function(gridApi){
  166. $scope.gridApi = gridApi;
  167. gridApi.edit.on.afterCellEdit($scope,function(rowEntity, colDef, newValue, oldValue){
  168. console.log(rowEntity);
  169. });
  170. gridApi.pagination.on.paginationChanged($scope, function (newPage, pageSize) {
  171. var filtersData = $scope.memoryfilterData;
  172. filtersData.idx=newPage-1;
  173. filtersData.sum=pageSize;
  174. $scope.refreshData('expand-right',filtersData);
  175. });
  176. gridApi.selection.on.rowSelectionChanged($scope, function(scope){
  177. scope.grid.appScope.selected.items=scope.entity
  178. });
  179. };
  180. var defaultFilterData = {
  181. "idx":0,
  182. "sum":10
  183. };
  184. $scope.memoryfilterData = {
  185. "idx":0,
  186. "sum":10
  187. }
  188. $scope.ldloading = {};
  189. $scope.refreshData = function(style,filterData){
  190. $scope.ldloading[style.replace('-', '_')] = true;
  191. if(angular.isUndefined(filterData)){
  192. filterData = defaultFilterData;
  193. }
  194. $scope.myData = [];
  195. api_bpm_schedule.getScheduleClass().then(function(response){
  196. if(response.status == 200){
  197. $scope.ldloading[style.replace('-', '_')] = false;
  198. var scheduleClassList = response.list;
  199. $scope.gridOptions.totalItems = response.totalNum;
  200. angular.forEach(scheduleClassList,function(item){
  201. var templateEvent = {
  202. id:item.id,
  203. title:item['description'],
  204. code:item['code'],
  205. startTime:item.startTime,
  206. person:item.person,
  207. //starts_at:
  208. endTime:item.endTime,
  209. //ends_at:
  210. succeedTime:item.succeedTime,
  211. shiftTime:item.shiftTime,
  212. description:item.description,
  213. deleteFlag:item.deleteFlag,
  214. isTemplate:item.isTemplate,
  215. draggable: true
  216. };
  217. $scope.myData.push(templateEvent);
  218. })
  219. }
  220. })
  221. // $scope.myData = [];
  222. // api_bpm_data.fetchDataList('closecode',filterData).then(function(data){
  223. // var myData = Restangular.stripRestangular(data);
  224. // $scope.gridOptions.totalItems = myData.totalNum;
  225. // $scope.myData = myData.list;
  226. // $scope.ldloading[style.replace('-', '_')] = false;
  227. // },function(){
  228. // $scope.ldloading[style.replace('-', '_')] = false;
  229. // });
  230. };
  231. $scope.refreshData('expand-right', defaultFilterData);
  232. }]);