schedulingCtrl.js 102 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650165116521653165416551656165716581659166016611662166316641665166616671668166916701671167216731674167516761677167816791680168116821683168416851686168716881689169016911692169316941695169616971698169917001701170217031704170517061707170817091710171117121713171417151716171717181719172017211722172317241725172617271728172917301731173217331734173517361737173817391740174117421743174417451746174717481749175017511752175317541755175617571758175917601761176217631764176517661767176817691770177117721773177417751776177717781779178017811782178317841785178617871788178917901791179217931794179517961797179817991800180118021803180418051806180718081809181018111812181318141815181618171818181918201821182218231824182518261827182818291830183118321833183418351836183718381839184018411842184318441845184618471848184918501851185218531854185518561857185818591860186118621863186418651866186718681869187018711872187318741875187618771878187918801881188218831884188518861887188818891890189118921893189418951896189718981899190019011902190319041905190619071908190919101911191219131914191519161917191819191920192119221923192419251926192719281929193019311932193319341935193619371938193919401941194219431944194519461947194819491950195119521953195419551956195719581959196019611962196319641965196619671968196919701971197219731974197519761977197819791980198119821983198419851986198719881989199019911992199319941995199619971998199920002001200220032004200520062007200820092010201120122013201420152016201720182019202020212022202320242025202620272028202920302031203220332034203520362037203820392040204120422043204420452046204720482049205020512052205320542055205620572058205920602061206220632064206520662067206820692070207120722073207420752076207720782079208020812082208320842085208620872088208920902091209220932094209520962097209820992100210121022103210421052106210721082109211021112112211321142115211621172118211921202121212221232124212521262127212821292130213121322133213421352136213721382139214021412142214321442145214621472148214921502151215221532154215521562157215821592160216121622163216421652166216721682169217021712172217321742175217621772178217921802181218221832184218521862187218821892190219121922193219421952196219721982199220022012202220322042205220622072208220922102211221222132214221522162217221822192220222122222223222422252226222722282229223022312232223322342235223622372238223922402241224222432244224522462247224822492250225122522253225422552256225722582259226022612262226322642265226622672268226922702271227222732274227522762277227822792280228122822283228422852286228722882289229022912292229322942295229622972298229923002301230223032304230523062307230823092310231123122313231423152316231723182319232023212322232323242325232623272328232923302331233223332334233523362337233823392340234123422343234423452346234723482349235023512352235323542355235623572358235923602361236223632364236523662367
  1. 'use strict';
  2. app.config(['calendarConfigProvider', function(calendarConfigProvider) {
  3. calendarConfigProvider.setDateFormatter('moment'); // use moment to format dates
  4. calendarConfigProvider.setTitleFormats({
  5. day: 'dddd MMMM DD, YYYY',
  6. week: '{year}年{week}周',
  7. month: 'MMMM YYYY',
  8. year: 'YYYY'
  9. //day: 'ddd D MMM' //this will configure the day view title to be shorter
  10. });
  11. calendarConfigProvider.setI18nStrings({
  12. eventsLabel: '描述', //This will set the events label on the day view
  13. timeLabel: '时间', //This will set the time label on the time view
  14. weekNumber: '{week}周'
  15. });
  16. }]);
  17. /**
  18. * Controller of the angularBootstrapCalendarApp
  19. */
  20. app.controller('schedulingCtrl', ["$scope", "i18nService", "$rootScope", "$log", "$state", "$timeout", "$interval", "SweetAlert", 'FileUploader', "uiGridConstants", "uiGridGroupingConstants", "Restangular", "api_bpm_domain", "api_bpm_data", "$aside", "moment", function($scope, i18nService, $rootScope, $log, $state, $timeout, $interval, SweetAlert, FileUploader, uiGridConstants, uiGridGroupingConstants, Restangular, api_bpm_domain, api_bpm_data, $aside, moment) {
  21. var loginUser = $rootScope.user;
  22. $scope.langs = i18nService.getAllLangs();
  23. $scope.lang = 'zh-cn';
  24. i18nService.setCurrentLang($scope.lang);
  25. $scope.allright = false;
  26. $scope.someright = true;
  27. for (var obj in $rootScope.user.role) {
  28. if ($rootScope.user.role[obj].rolecode == 'schedule manager') {
  29. $scope.allright = true;
  30. $scope.someright = false;
  31. }
  32. }
  33. var pdKey = $state.current.pdKey;
  34. $scope.gridOptions = {};
  35. $scope.gridOptions.data = 'myData';
  36. $scope.gridOptions.enableColumnResizing = true;
  37. $scope.gridOptions.enableFiltering = false;
  38. $scope.gridOptions.enableGridMenu = true;
  39. $scope.gridOptions.enableRowSelection = true;
  40. $scope.gridOptions.showGridFooter = true;
  41. $scope.gridOptions.showColumnFooter = false;
  42. $scope.gridOptions.fastWatch = true;
  43. // $scope.gridOptions.useExternalFiltering=true;
  44. $scope.gridOptions.useExternalPagination = true;
  45. $scope.gridOptions.paginationPageSizes = [10];
  46. $scope.gridOptions.paginationPageSize = 10;
  47. $scope.gridOptions.multiSelect = false;
  48. $scope.gridOptions.rowTemplate = "<div ng-dblclick=\"grid.appScope.pdList.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>";
  49. $scope.gridOptions.rowIdentity = function(row) {
  50. return row.id;
  51. };
  52. $scope.gridOptions.getRowIdentity = function(row) {
  53. return row.id;
  54. };
  55. $scope.gridOptions.columnDefs = [{
  56. name: 'item',
  57. displayName: '序号',
  58. width: 50,
  59. enableFiltering: false
  60. }, {
  61. name: 'sourceWatch.watchTime',
  62. displayName: '换班时间',
  63. width: '15%',
  64. enableFiltering: false
  65. }, {
  66. name: 'initUser.name',
  67. displayName: '申请人',
  68. width: '10%',
  69. enableFiltering: false
  70. }, {
  71. name: 'sourceWatch.scheduleClass.name',
  72. displayName: '换班班次',
  73. width: '10%',
  74. enableFiltering: false
  75. }, {
  76. name: 'endWatch.watchTime',
  77. displayName: '对换时间',
  78. width: '15%',
  79. enableFiltering: false
  80. }, {
  81. name: 'endWatch.user.name',
  82. displayName: '对换人员',
  83. width: '10%',
  84. enableFiltering: false
  85. }, {
  86. name: 'endWatch.scheduleClass.name',
  87. displayName: '对换班次',
  88. width: '10%',
  89. enableFiltering: false
  90. }, {
  91. name: 'stage.name',
  92. displayName: '状态',
  93. width: '10%',
  94. enableFiltering: false
  95. }, {
  96. name: '操作',
  97. cellTemplate: '<schedulingoperator item="row.entity" colobject="col">',
  98. enableFiltering: false
  99. }];
  100. // $scope.gridOptions.importerDataAddCallback = function( grid, newObjects ) {
  101. // $scope.myData = $scope.myData.concat( newObjects );
  102. // console.log($scope);
  103. // };
  104. $scope.refresh = function(style, filterData) {
  105. var filtersData = {
  106. "assignee": $rootScope.user.id,
  107. "candidateGroups": $rootScope.user.group[0].id,
  108. idx: 0,
  109. sum: 10
  110. };
  111. $scope.gridOptions.refresh();
  112. $scope.refreshData('expand-right', $scope.fileData);
  113. };
  114. $scope.searchstate = "all";
  115. $scope.onChange = function(searchType) {
  116. if (searchType && searchType != "") {
  117. $scope.searchstate = searchType;
  118. } else {
  119. $scope.searchstate = "all";
  120. }
  121. $scope.fileData.searchType = searchType;
  122. $scope.refreshData('expand-right', $scope.fileData);
  123. };
  124. $scope.gridOptions.onRegisterApi = function(gridApi) {
  125. $scope.gridApi = gridApi;
  126. gridApi.pagination.on.paginationChanged($scope, function(newPage, pageSize) {
  127. // console.log(newPage);
  128. // console.log(pageSize);
  129. $rootScope['idx'] = newPage;
  130. $scope.fileData.idx=newPage - 1;
  131. $scope.fileData.sum=pageSize;
  132. $scope.refreshData('expand-right', $scope.fileData);
  133. });
  134. // gridApi.core.on.filterChanged($scope, function() {
  135. // var grid = this.grid;
  136. // var filtersData = {
  137. // "assignee":$rootScope.user.id,
  138. // "candidateGroups":$rootScope.user.group[0].id,
  139. // "idx":0,
  140. // "sum":10
  141. // };
  142. // angular.forEach(grid.columns,function(item){
  143. // if(item.enableFiltering){
  144. // if(angular.isDefined(item.filters[0].term)&&item.filters[0].term!=''){
  145. // // console.log('item.filters[0]='+JSON.stringify(item.filters[0]));
  146. // if(angular.isUndefined(filtersData['scheduling'])){
  147. // filtersData['scheduling']={};
  148. // }
  149. // filtersData['scheduling'][item.field]=item.filters[0].term;
  150. // }
  151. // }
  152. // });
  153. // $scope.refreshData('expand-right', filtersData);
  154. // });
  155. // gridApi.selection.on.rowSelectionChanged($scope, function(data) {
  156. // //$scope.selected.item = data.entity;
  157. // console.log(data);
  158. // });
  159. };
  160. // $scope.gridOptions.appScopeProvider = {
  161. // onDblClick : function(row) {
  162. // $state.go('app.form.detail',{data:row, formKey:'changeDetail', pdKey:'change'});
  163. // //var url = '//google.com';
  164. // //$window.open(url, "_blank", "height=600,width=800,toolbar=no,location=no,menubar=no,titlebar=no");
  165. // }
  166. // };
  167. $scope.selectRowFunction = function(data) {
  168. // console.log(data);
  169. // $state.go('app.process.modeler',{modelId:data.id});
  170. $state.go('app.scheduling.editor', {
  171. taskId: data.taskId,
  172. processInstanceId: data.processInstanceId,
  173. id:data.id
  174. });
  175. };
  176. $scope.onDblClick = function(data) {
  177. //console.log(row.entity);
  178. $state.go('app.detail', { formKey: 'schedulingDetail', pdKey: 'schedule', dataId: data.entity.id, taskId: data.entity.taskId, processInstanceId: data.entity.processInstanceId });
  179. };
  180. // this.onDblClick = function(row) {
  181. // //console.log(row.entity);
  182. // $state.go('app.detail', {
  183. // formKey: 'schedulingDetail',
  184. // pdKey: 'scheduling',
  185. // dataId: row.entity.id
  186. // });
  187. // };
  188. this.removeRowFunction = function(data) {
  189. //TODO $translate('key')
  190. SweetAlert.swal({
  191. title: "确认删除?",
  192. text: "删除以后,你将不能恢复该数据!",
  193. type: "warning",
  194. cancelButtonText: "取消",
  195. showCancelButton: true,
  196. confirmButtonColor: "#DD6B55",
  197. confirmButtonText: "确认删除!"
  198. }, function(isConfirm) {
  199. if (isConfirm) {
  200. // api_bpm_domain.removemodel(data.id).then(function(response){
  201. // if(response){
  202. // $scope.refreshData();
  203. // SweetAlert.swal({
  204. // title: "删除成功!",
  205. // confirmButtonColor: "#007AFF"
  206. // });
  207. // }
  208. // });
  209. } else {
  210. }
  211. });
  212. }
  213. //$scope.callsPending = 0;
  214. //var i = 0;
  215. var defaultFilterData = {
  216. "assignee": $rootScope.user.id,
  217. // "candidateGroups":$rootScope.user.group[0].id,
  218. "searchType":"all",
  219. "idx": 0,
  220. "sum": 10
  221. };
  222. // if (angular.isDefined($rootScope.search) && angular.isDefined($rootScope.search.scheduling)) {
  223. // defaultFilterData['searchType'] = $rootScope.search.scheduling;
  224. // $scope.searchTypes = $rootScope.search.scheduling;
  225. // }
  226. // if ($rootScope['cmdbs'] != 'scheduling') { $rootScope.idx = 1 }
  227. // if (angular.isDefined($rootScope.idx) && $rootScope.cmdbs != "false") {
  228. // $rootScope['cmdbs'] = 'scheduling';
  229. // defaultFilterData.idx = $rootScope.idx - 1;
  230. // } else { $rootScope.cmdbs = ""; }
  231. $scope.fileData={
  232. "assignee": $rootScope.user.id,
  233. "searchType":"all",
  234. "idx": 0,
  235. "sum": 10
  236. }
  237. $scope.ldloading = {};
  238. $scope.refreshData = function(style, filterData) {
  239. $scope.ldloading[style.replace('-', '_')] = true;
  240. if (angular.isUndefined(filterData)) {
  241. // defaultFilterData.idx = $rootScope.idx - 1;
  242. filterData = defaultFilterData;
  243. }
  244. // if (angular.isDefined($scope.searchTypes)) {
  245. // $rootScope['search'] = {};
  246. // filterData['searchType'] = $scope.searchTypes;
  247. // $rootScope['search']['scheduling'] = $scope.searchTypes;
  248. // }
  249. $scope.myData = [];
  250. //var start = new Date();
  251. //var sec = $interval(function () {
  252. //$scope.callsPending++;
  253. api_bpm_domain.fetchtask(pdKey, filterData).then(function(data) {
  254. $scope.callsPending--;
  255. // console.log('filterData='+JSON.stringify(filterData));
  256. var myData = Restangular.stripRestangular(data);
  257. $scope.gridOptions.totalItems = myData.resultCount;
  258. $scope.myData = myData.data;
  259. for (var i = 0; i < $scope.myData.length; i++) {
  260. $scope.myData[i]['item'] = i + 1 + filterData.idx * filterData.sum
  261. }
  262. $scope.ldloading[style.replace('-', '_')] = false;
  263. }, function() {
  264. $scope.ldloading[style.replace('-', '_')] = false;
  265. });
  266. };
  267. $scope.refreshData2 = function(style, filterData) {
  268. $scope.ldloading[style.replace('-', '_')] = true;
  269. if (angular.isUndefined(filterData)) {
  270. // defaultFilterData.idx = $rootScope.idx - 1;
  271. filterData = defaultFilterData;
  272. }
  273. // if (angular.isDefined($scope.searchTypes)) {
  274. // $rootScope['search'] = {};
  275. // filterData['searchType'] = $scope.searchTypes;
  276. // $rootScope['search']['scheduling'] = $scope.searchTypes;
  277. // }
  278. $scope.myData = [];
  279. //var start = new Date();
  280. //var sec = $interval(function () {
  281. //$scope.callsPending++;
  282. api_bpm_domain.fetchtask(pdKey, filterData).then(function(data) {
  283. $scope.callsPending--;
  284. // console.log('filterData='+JSON.stringify(filterData));
  285. var myData = Restangular.stripRestangular(data);
  286. $scope.gridOptions.totalItems = myData.resultCount;
  287. $scope.myData = myData.data;
  288. for (var i = 0; i < $scope.myData.length; i++) {
  289. $scope.myData[i]['item'] = i + 1 + filterData.idx * filterData.sum
  290. }
  291. $scope.ldloading[style.replace('-', '_')] = false;
  292. }, function() {
  293. $scope.ldloading[style.replace('-', '_')] = false;
  294. });
  295. };
  296. $scope.refreshData('expand-right', $scope.fileData);
  297. $scope.timer = $interval(function () {
  298. $scope.refreshData2('expand-right', $scope.fileData);
  299. }, $rootScope.refreshTime);
  300. $scope.$on('$destroy', function () {
  301. $interval.cancel($scope.timer)
  302. });
  303. }]);
  304. app.controller('SchedulingOperCtrl', ['$rootScope', '$http', '$scope', function($rootScope, $http, $scope, $event) {
  305. if ($scope.item.handlerUser != null) {
  306. if ($rootScope.user.id == $scope.item.handlerUser.id) {
  307. $scope.item.chaozuoPower = true;
  308. }
  309. }
  310. $scope.look = function() {
  311. $scope.colobject.grid.appScope.onDblClick($scope.item);
  312. }
  313. $scope.edit = function() {
  314. $scope.colobject.grid.appScope.selectRowFunction($scope.item);
  315. // console.log('$scope.item='+JSON.stringify($scope.item));
  316. $scope.doEdit($scope.item.id);
  317. }
  318. }]);
  319. app.directive('schedulingoperator', function() {
  320. return {
  321. restrict: 'E',
  322. scope: {
  323. item: '=',
  324. colobject: '='
  325. },
  326. controller: 'SchedulingOperCtrl',
  327. template: '<div class="cl-effect-1 ui-grid-cell-contents pull-left">' +
  328. // '<a ng-click="look()" tooltip="查看" tooltip-placement="left"><i class="ti-eye"></i></a>' +
  329. // '<a ng-click="edit()" ng-show="{{item.chaozuoPower}}" tooltip="编辑" tooltip-placement="left"><i class="fa fa-pencil-square-o"></i></a>' +
  330. '<a ng-click="edit()" ng-show="{{item.chaozuoPower}}" class="bianjifont">编辑</a>' +
  331. '</div>'
  332. };
  333. });
  334. /* 我的排班 */
  335. app.controller('myCalendarCtrl', ["$rootScope", "$scope", "$aside", "calendarConfig", "moment", "SweetAlert", "Restangular", "api_bpm_schedule", "api_user_data", function($rootScope, $scope, $aside, calendarConfig, moment, SweetAlert, Restangular, api_bpm_schedule, api_user_data) {
  336. var loginUser = $rootScope.user;
  337. //console.log(loginUser);
  338. calendarConfig.dateFormatter = 'moment';
  339. calendarConfig.i18nStrings.eventsLabel = '排班描述';
  340. calendarConfig.i18nStrings.timeLabel = '时间';
  341. calendarConfig.i18nStrings.weekNumber = '{week}周';
  342. calendarConfig.allDateFormats = {
  343. angular: {
  344. date: {
  345. hour: 'ha',
  346. day: 'd MMM',
  347. month: 'MMMM',
  348. weekDay: 'EEEE',
  349. time: 'HH:mm',
  350. datetime: 'MMM d, h:mm a'
  351. },
  352. title: {
  353. day: 'yyyy MMMM EEEE d',
  354. week: '{year}年第{week}周',
  355. month: 'yyyy MMMM',
  356. year: 'yyyy'
  357. }
  358. },
  359. moment: {
  360. date: {
  361. hour: 'ha',
  362. day: 'MMMDD日',
  363. month: 'MMMM',
  364. weekDay: 'dddd',
  365. time: 'HH:mm',
  366. datetime: 'MMM D, h:mm a'
  367. },
  368. title: {
  369. day: 'YYYY年MMMMDD日, dddd ',
  370. week: '{year}年第{week}周',
  371. month: 'YYYY年MMMM',
  372. year: 'YYYY'
  373. }
  374. }
  375. };
  376. moment.locale('zh_cn', {
  377. months: '一月_二月_三月_四月_五月_六月_七月_八月_九月_十月_十一月_十二月'.split('_'),
  378. monthsShort: '1月_2月_3月_4月_5月_6月_7月_8月_9月_10月_11月_12月'.split('_'),
  379. weekdays: '星期日_星期一_星期二_星期三_星期四_星期五_星期六'.split('_'),
  380. weekdaysShort: '周日_周一_周二_周三_周四_周五_周六'.split('_'),
  381. weekdaysMin: '日_一_二_三_四_五_六'.split('_'),
  382. longDateFormat: {
  383. LT: 'Ah点mm分',
  384. LTS: 'Ah点m分s秒',
  385. L: 'YYYY-MM-DD',
  386. LL: 'YYYY年MMMD日',
  387. LLL: 'YYYY年MMMD日Ah点mm分',
  388. LLLL: 'YYYY年MMMD日ddddAh点mm分',
  389. l: 'YYYY-MM-DD',
  390. ll: 'YYYY年MMMD日',
  391. lll: 'YYYY年MMMD日Ah点mm分',
  392. llll: 'YYYY年MMMD日ddddAh点mm分'
  393. },
  394. meridiemParse: /凌晨|早上|上午|中午|下午|晚上/,
  395. meridiemHour: function(hour, meridiem) {
  396. if (hour === 12) {
  397. hour = 0;
  398. }
  399. if (meridiem === '凌晨' || meridiem === '早上' ||
  400. meridiem === '上午') {
  401. return hour;
  402. } else if (meridiem === '下午' || meridiem === '晚上') {
  403. return hour + 12;
  404. } else {
  405. // '中午'
  406. return hour >= 11 ? hour : hour + 12;
  407. }
  408. },
  409. meridiem: function(hour, minute, isLower) {
  410. var hm = hour * 100 + minute;
  411. if (hm < 600) {
  412. return '凌晨';
  413. } else if (hm < 900) {
  414. return '早上';
  415. } else if (hm < 1130) {
  416. return '上午';
  417. } else if (hm < 1230) {
  418. return '中午';
  419. } else if (hm < 1800) {
  420. return '下午';
  421. } else {
  422. return '晚上';
  423. }
  424. },
  425. calendar: {
  426. sameDay: function() {
  427. return this.minutes() === 0 ? '[今天]Ah[点整]' : '[今天]LT';
  428. },
  429. nextDay: function() {
  430. return this.minutes() === 0 ? '[明天]Ah[点整]' : '[明天]LT';
  431. },
  432. lastDay: function() {
  433. return this.minutes() === 0 ? '[昨天]Ah[点整]' : '[昨天]LT';
  434. },
  435. nextWeek: function() {
  436. var startOfWeek, prefix;
  437. startOfWeek = moment().startOf('week');
  438. prefix = this.unix() - startOfWeek.unix() >= 7 * 24 * 3600 ? '[下]' : '[本]';
  439. return this.minutes() === 0 ? prefix + 'dddAh点整' : prefix + 'dddAh点mm';
  440. },
  441. lastWeek: function() {
  442. var startOfWeek, prefix;
  443. startOfWeek = moment().startOf('week');
  444. prefix = this.unix() < startOfWeek.unix() ? '[上]' : '[本]';
  445. return this.minutes() === 0 ? prefix + 'dddAh点整' : prefix + 'dddAh点mm';
  446. },
  447. sameElse: 'LL'
  448. },
  449. ordinalParse: /\d{1,2}(日|月|周)/,
  450. ordinal: function(number, period) {
  451. switch (period) {
  452. case 'd':
  453. case 'D':
  454. case 'DDD':
  455. return number + '日';
  456. case 'M':
  457. return number + '月';
  458. case 'w':
  459. case 'W':
  460. return number + '周';
  461. default:
  462. return number;
  463. }
  464. },
  465. relativeTime: {
  466. future: '%s内',
  467. past: '%s前',
  468. s: '几秒',
  469. m: '1 分钟',
  470. mm: '%d 分钟',
  471. h: '1 小时',
  472. hh: '%d 小时',
  473. d: '1 天',
  474. dd: '%d 天',
  475. M: '1 个月',
  476. MM: '%d 个月',
  477. y: '1 年',
  478. yy: '%d 年'
  479. },
  480. week: {
  481. // GB/T 7408-1994《数据元和交换格式·信息交换·日期和时间表示法》与ISO 8601:1988等效
  482. dow: 1, // Monday is the first day of the week.
  483. doy: 4 // The week that contains Jan 4th is the first week of the year.
  484. }
  485. });
  486. //console.log(window.moment().weekdays);
  487. var date = new Date();
  488. var d = date.getDate();
  489. var m = date.getMonth();
  490. var y = date.getFullYear();
  491. // console.log(loginUser);
  492. var filterData = {
  493. "userId": loginUser.id,
  494. "startTime": moment(new Date(y, m, 1, 0, 0)).format('YYYY-MM-DD HH:mm:ss'),
  495. "endTime": moment(new Date(y, m + 1, 1, 0, 0)).format('YYYY-MM-DD HH:mm:ss')
  496. };
  497. var load = $scope.load = function(filterData) {
  498. api_bpm_schedule.fetchSchedule(filterData.userId, filterData.startTime, filterData.endTime).then(function(response) {
  499. if (response.status == 200) {
  500. $scope.events = [];
  501. // console.log(response.list);
  502. var myData = response.list;
  503. angular.forEach(myData, function(item) {
  504. var eventTemp = {};
  505. eventTemp.title = item.description;
  506. // eventTemp.title = item.name;
  507. eventTemp.type = item.scheduleClass.code;
  508. eventTemp.startsAt = moment(item['scheduleOrder'].startTime).toDate();
  509. eventTemp.endsAtTime = moment(item['scheduleOrder'].endTime).toDate();
  510. eventTemp.startTime = item['scheduleOrder'].startTime;
  511. eventTemp.endTime = item['scheduleOrder'].endTime;
  512. //eventTemp.ends_at = moment(item.endTime).toDate();
  513. eventTemp.id = item.id;
  514. eventTemp.deletable = false;
  515. eventTemp.user = item.user;
  516. $scope.events.push(eventTemp);
  517. })
  518. }
  519. });
  520. }
  521. // var load = $scope.load = function(filterData){
  522. // api_bpm_schedule.fetchSchedule(filterData.userId, filterData.startTime, filterData.endTime).then(function(response){
  523. // console.log("response="+JSON.stringify(response));
  524. // if(response.status==200){
  525. // $scope.events = [];
  526. // console.log(response.list);
  527. // var myData = response.list;
  528. // angular.forEach(myData,function(item){
  529. // var eventTemp = {};
  530. // eventTemp.title = item.description;
  531. // eventTemp.type = item.scheduleClass.code;
  532. // eventTemp.startsAt = moment(item.startTime).toDate();
  533. // eventTemp.endsAtTime = moment(item.endTime).toDate();
  534. // eventTemp.startTime = item.startTime;
  535. // eventTemp.endTime = item.endTime;
  536. // //eventTemp.ends_at = moment(item.endTime).toDate();
  537. // eventTemp.id = item.id;
  538. // eventTemp.deletable = false;
  539. // eventTemp.users = item.users;
  540. // $scope.events.push(eventTemp);
  541. // // console.log("eventTemp="+JSON.stringify(eventTemp));
  542. // })
  543. // }
  544. // });
  545. // }
  546. $scope.scheduleClass = {};
  547. var convertEvent = function(scheduleorder) {
  548. var eventTemp = {};
  549. eventTemp.title = scheduleorder.name;
  550. eventTemp.type = scheduleorder.scheduleClass.code;
  551. eventTemp.startsAt = moment(scheduleorder.startTime).toDate();
  552. //eventTemp.ends_at = moment(scheduleorder.endTime).toDate();
  553. eventTemp.id = scheduleorder.id;
  554. eventTemp.user = scheduleorder.user;
  555. eventTemp.deletable = false;
  556. return eventTemp;
  557. }
  558. // var convertEvent = function(scheduleorder){
  559. // var eventTemp = {};
  560. // eventTemp.title = scheduleorder.description;
  561. // eventTemp.type = scheduleorder.scheduleClass.code;
  562. // eventTemp.starts_at = moment(scheduleorder.scheduleClass.startTime).toDate();
  563. // eventTemp.ends_at = moment(scheduleorder.scheduleClass.endTime).toDate();
  564. // eventTemp.id = scheduleorder.id;
  565. // eventTemp.users = scheduleorder.users;
  566. // eventTemp.deletable = false;
  567. // return eventTemp;
  568. // }
  569. // function getdatas() {
  570. api_bpm_schedule.getScheduleClass().then(function(response) {
  571. if (response.status == 200) {
  572. var scheduleClassList = response.list;
  573. angular.forEach(scheduleClassList, function(item) {
  574. item.startsAt = moment(item.startTime).format('HH:mm:ss');
  575. item.endsAt = moment(item.endTime).format('HH:mm:ss');
  576. // console.log("item.startsAt="+JSON.stringify(item.startsAt))
  577. // console.log("item.endsAt="+JSON.stringify(item.endsAt))
  578. $scope.scheduleClass[item['code']] = item;
  579. })
  580. }
  581. })
  582. // }
  583. function getalldata() {
  584. api_bpm_schedule.fetchList(filterData.startTime, filterData.endTime).then(function(response) {
  585. if (response.status == 200) {
  586. $scope.events = [];
  587. // console.log(response.list);
  588. var myData = response.list;
  589. angular.forEach(myData, function(item) {
  590. var eventTemp = {};
  591. // eventTemp.title = item.name;
  592. eventTemp.title = item.description;
  593. eventTemp.type = item.scheduleClass.code;
  594. eventTemp.startsAt = moment(item.startTime).toDate();
  595. eventTemp.endsAtTime = moment(item.endTime).toDate();
  596. eventTemp.startTime = item.startTime;
  597. eventTemp.endTime = item.endTime;
  598. //eventTemp.ends_at = moment(item.endTime).toDate();
  599. eventTemp.id = item.id;
  600. eventTemp.users = item.users;
  601. // {
  602. // title: '白班',
  603. // type: 'job',
  604. // starts_at: new Date(y, m, 5, 19, 0),
  605. // ends_at: new Date(y, m, 5, 22, 30)
  606. // },
  607. $scope.events.push(eventTemp);
  608. })
  609. }
  610. });
  611. }
  612. getalldata();
  613. $scope.odr = 2;
  614. $scope.searchstate = 2;
  615. $scope.order = function(odr) {
  616. if (odr == 1) {
  617. $scope.odr = 1;
  618. $scope.searchstate = 1;
  619. $scope.load(filterData);
  620. } else if (odr == 2) {
  621. $scope.odr = 2;
  622. $scope.searchstate = 2;
  623. getalldata();
  624. }
  625. }
  626. $scope.events = [];
  627. $scope.calendarView = 'month';
  628. //$scope.calendarDay = new Date();
  629. $scope.calendarDate = moment().startOf('month').toDate();
  630. $scope.timeLabel = "时间";
  631. $scope.eventLabel = "描述";
  632. //日历编辑
  633. function showModal(action, event) {
  634. // console.log("action="+JSON.stringify(action))
  635. var modalInstance = $aside.open({
  636. templateUrl: 'scheduleEvent.html',
  637. placement: 'right',
  638. size: 'sm',
  639. backdrop: true,
  640. controller: function($scope, $modalInstance, scheduleClass, APIService, MementFormat) {
  641. $scope.$modalInstance = $modalInstance;
  642. $scope.action = action;
  643. $scope.event = event;
  644. $scope.scheduleClassic = event;
  645. $scope.$watch('event.type', function(newvalue, oldvalue) {
  646. // if(oldvalue == newvalue) return;
  647. // if(scheduleClass[newvalue]){
  648. var sm = MementFormat(scheduleClass[newvalue].startTime);
  649. var em = MementFormat(scheduleClass[newvalue].endTime);
  650. // console.log("sm=" + JSON.stringify(sm))
  651. event.starts_at = MementFormat(event.startTime).startOf('day').add(sm.hour(), 'hour').add(sm.minute(), 'minute').add(sm.second(), 'second').toDate();
  652. // console.log("event.starts_at=" + JSON.stringify(event.starts_at))
  653. if (sm.hour() > em.hour()) {
  654. event.ends_at = MementFormat(event.startTime).startOf('day').add(1, 'day').add(em.hour(), 'hour').add(em.minute(), 'minute').add(em.second(), 'second').toDate();
  655. // console.log("event.ends_at=" + JSON.stringify(event.starts_at))
  656. } else {
  657. event.ends_at = MementFormat(event.startTime).startOf('day').add(em.hour(), 'hour').add(em.minute(), 'minute').add(em.second(), 'second').toDate();
  658. // console.log("event.ends_at=" + JSON.stringify(event.ends_at))
  659. }
  660. // }
  661. });
  662. // $scope.ok = function (event) {
  663. // console.log("event="+JSON.stringify(event))
  664. // event.action = action;
  665. // $modalInstance.close(event);
  666. // };
  667. $scope.cancel = function(event) {
  668. $modalInstance.dismiss();
  669. };
  670. var acUserSelect = $scope.refreshUser = function(key) {
  671. //for test
  672. // $scope.users=[{"id":1,"phone":"13971293737","orgId":1,"name":"李静","role":[{"id":1,"rolecode":"admin","role":"主行管理员","flag":0}],"gender":"女","dept":{"id":3,"dept":"运行监控科"},"flag":0,"email":"","account":"005292","nickname":"lijing","group":[{"id":3,"groupName":"运行监控科"}]},{"id":2,"phone":"15807199490","orgId":1,"name":"李进","role":[{"id":1,"rolecode":"admin","role":"主行管理员","flag":0},{"id":7,"rolecode":"change manager","role":"变更流程经理","flag":1},{"id":8,"rolecode":"change coordinator","role":"协调员","flag":0},{"id":9,"rolecode":"configure manager","role":"配置管理员","flag":0},{"id":10,"rolecode":"release manager","role":"发布经理","flag":0}],"gender":"男","dept":{"id":3,"dept":"运行监控科"},"flag":0,"email":"","account":"005298","nickname":"lijin","group":[{"id":3,"groupName":"运行监控科"}]},{"id":3,"phone":"13507195958","orgId":1,"name":"杨代华","role":[{"id":2,"rolecode":"user","role":"主行员工","flag":1}],"gender":"男","dept":{"id":9,"dept":"管理层"},"flag":0,"email":"","account":"005241","group":[{"id":9,"groupName":"管理层"}]},{"id":4,"phone":"18717107255","orgId":1,"name":"朱红艳","role":[{"id":2,"rolecode":"user","role":"主行员工","flag":1}],"gender":"女","dept":{"id":9,"dept":"管理层"},"flag":0,"email":"","account":"005242","group":[{"id":9,"groupName":"管理层"}]},{"id":5,"phone":"13667282828","orgId":1,"name":"李喆","role":[{"id":2,"rolecode":"user","role":"主行员工","flag":1}],"gender":"男","dept":{"id":9,"dept":"管理层"},"flag":0,"email":"","account":"005243","group":[{"id":9,"groupName":"管理层"}]}];
  673. // return;
  674. var data = { "idx": "0", "sum": "5" };
  675. if (key) {
  676. data['user'] = {
  677. 'name': key
  678. };
  679. }
  680. APIService.fetchDataList('user', data).then(function(response) {
  681. if (response) {
  682. if (response.status = 200) {
  683. $scope.users = response.list;
  684. // console.log($scope.users);
  685. }
  686. }
  687. })
  688. };
  689. if (angular.isDefined(event.users) && event.users.length > 0) {
  690. }
  691. $scope.users = [event.user];
  692. acUserSelect();
  693. },
  694. resolve: {
  695. scheduleClass: function() {
  696. return $scope.scheduleClass;
  697. },
  698. APIService: function() {
  699. return api_user_data;
  700. },
  701. MementFormat: function() {
  702. return moment;
  703. }
  704. }
  705. });
  706. modalInstance.result.then(function(selectedEvent) {
  707. if (selectedEvent.action == 'Clicked') {
  708. // var data = {
  709. // "scheduleorder":{
  710. // "id":selectedEvent.id,
  711. // "description":selectedEvent.title,
  712. // "startTime":moment(selectedEvent.starts_at).format('YYYY-MM-DD HH:mm:ss'),
  713. // "endTime":moment(selectedEvent.ends_at).format('YYYY-MM-DD HH:mm:ss'),
  714. // "users":selectedEvent.users,
  715. // "scheduleClass":{"id":$scope.scheduleClass[selectedEvent.type].id}
  716. // }
  717. // };
  718. // api_bpm_schedule.update(data).then(function(response){
  719. // if(response.status==200){
  720. // SweetAlert.swal({
  721. // title: "操作成功!",
  722. // text: "排班更新成功!",
  723. // type: "succes"
  724. // });
  725. // angular.forEach($scope.events,function(item){
  726. // if(item.id==selectedEvent.id){
  727. // item = selectedEvent;
  728. // }
  729. // })
  730. // }else{
  731. // SweetAlert.swal({
  732. // title: "操作失败",
  733. // text: "排班更新失败,请稍后重试!",
  734. // type: "error"
  735. // })
  736. // }
  737. // })
  738. } else {
  739. //
  740. }
  741. });
  742. }
  743. $scope.moment = function(string) {
  744. return moment(string);
  745. }
  746. $scope.eventClicked = function(event) {
  747. // console.log("event="+JSON.stringify(event))
  748. showModal('Clicked', event);
  749. };
  750. $scope.eventEdited = function(event) {
  751. showModal('Edited', event);
  752. };
  753. //
  754. var updateViews = function(newvalue, oldvalue) {
  755. if (oldvalue == newvalue) return;
  756. var timeStart, timeEnd, timeStartSpan, timeEndSpan;
  757. if ($scope.calendarView == "year") {
  758. } else if ($scope.calendarView == "month") {
  759. // $scope.getmonth=
  760. timeStart = moment(newvalue).startOf('month');
  761. timeEnd = moment(newvalue).endOf('month');
  762. } else if ($scope.calendarView == "week") {
  763. timeStart = moment(newvalue).startOf('week');
  764. timeEnd = moment(newvalue).endOf('week');
  765. } else if ($scope.calendarView == "Day") {
  766. timeStart = moment(newvalue).startOf('day');
  767. timeEnd = moment(newvalue).endOf('day');
  768. }
  769. timeStartSpan = timeStart.format('YYYY-MM-DD HH:mm:ss');
  770. timeEndSpan = timeEnd.format('YYYY-MM-DD HH:mm:ss');
  771. filterData["startTime"] = timeStartSpan;
  772. filterData["endTime"] = timeEndSpan;
  773. $scope.order($scope.odr);
  774. }
  775. $scope.$watch('calendarDate', updateViews)
  776. $scope.next = function() {
  777. $scope.getmonth = 'nextmonth';
  778. $scope.calendarControl.next();
  779. }
  780. $scope.prev = function() {
  781. $scope.calendarControl.prev();
  782. }
  783. $scope.setCalendarToToday = function() {
  784. $scope.calendarDay = new Date();
  785. };
  786. $scope.toggle = function($event, field, event) {
  787. $event.preventDefault();
  788. $event.stopPropagation();
  789. event[field] = !event[field];
  790. };
  791. // $scope.load(filterData);
  792. }]);
  793. /* 排班日历 */
  794. app.controller('adminCalendarCtrl', ["$rootScope", "$scope", "$http", "$aside", "$modal", "calendarConfig", "moment", "SweetAlert", 'FileUploader', "Restangular", "api_bpm_schedule", "api_user_data", "api_bpm_data", function($rootScope, $scope, $http, $aside, $modal, calendarConfig, moment, SweetAlert, FileUploader, Restangular, api_bpm_schedule, api_user_data, api_bpm_data) {
  795. var loginUser = $rootScope.user;
  796. $scope.xinzeng=false;
  797. for(var i=0;i<loginUser.menu.length;i++){
  798. if(loginUser.menu[i].link=="paibanrili_xinzeng"){
  799. $scope.xinzeng=true
  800. }
  801. };
  802. console.log($scope.bianji);
  803. var date = new Date();
  804. var d = date.getDate();
  805. var m = date.getMonth();
  806. var y = date.getFullYear();
  807. // console.log(week);
  808. calendarConfig.dateFormatter = 'moment';
  809. calendarConfig.i18nStrings.eventsLabel = '排班描述';
  810. calendarConfig.i18nStrings.timeLabel = '时间';
  811. calendarConfig.i18nStrings.weekNumber = '{week}周';
  812. calendarConfig.allDateFormats = {
  813. angular: {
  814. date: {
  815. hour: 'ha',
  816. day: 'd MMM',
  817. month: 'MMMM',
  818. weekDay: 'EEEE',
  819. time: 'HH:mm',
  820. datetime: 'MMM d, h:mm a'
  821. },
  822. title: {
  823. day: 'yyyy MMMM EEEE d',
  824. week: '{year}年第{week}周',
  825. month: 'yyyy MMMM',
  826. year: 'yyyy'
  827. }
  828. },
  829. moment: {
  830. date: {
  831. hour: 'ha',
  832. day: 'MMMDD日',
  833. month: 'MMMM',
  834. weekDay: 'dddd',
  835. time: 'HH:mm',
  836. datetime: 'MMM D, h:mm a'
  837. },
  838. title: {
  839. day: 'YYYY年MMMMDD日, dddd ',
  840. week: '{year}年第{week}周',
  841. month: 'YYYY年MMMM',
  842. year: 'YYYY'
  843. }
  844. }
  845. };
  846. moment.locale('zh_cn', {
  847. months: '一月_二月_三月_四月_五月_六月_七月_八月_九月_十月_十一月_十二月'.split('_'),
  848. monthsShort: '1月_2月_3月_4月_5月_6月_7月_8月_9月_10月_11月_12月'.split('_'),
  849. weekdays: '星期日_星期一_星期二_星期三_星期四_星期五_星期六'.split('_'),
  850. weekdaysShort: '周日_周一_周二_周三_周四_周五_周六'.split('_'),
  851. weekdaysMin: '日_一_二_三_四_五_六'.split('_'),
  852. longDateFormat: {
  853. LT: 'Ah点mm分',
  854. LTS: 'Ah点m分s秒',
  855. L: 'YYYY-MM-DD',
  856. LL: 'YYYY年MMMD日',
  857. LLL: 'YYYY年MMMD日Ah点mm分',
  858. LLLL: 'YYYY年MMMD日ddddAh点mm分',
  859. l: 'YYYY-MM-DD',
  860. ll: 'YYYY年MMMD日',
  861. lll: 'YYYY年MMMD日Ah点mm分',
  862. llll: 'YYYY年MMMD日ddddAh点mm分'
  863. },
  864. meridiemParse: /凌晨|早上|上午|中午|下午|晚上/,
  865. meridiemHour: function(hour, meridiem) {
  866. if (hour === 12) {
  867. hour = 0;
  868. }
  869. if (meridiem === '凌晨' || meridiem === '早上' ||
  870. meridiem === '上午') {
  871. return hour;
  872. } else if (meridiem === '下午' || meridiem === '晚上') {
  873. return hour + 12;
  874. } else {
  875. // '中午'
  876. return hour >= 11 ? hour : hour + 12;
  877. }
  878. },
  879. meridiem: function(hour, minute, isLower) {
  880. var hm = hour * 100 + minute;
  881. if (hm < 600) {
  882. return '凌晨';
  883. } else if (hm < 900) {
  884. return '早上';
  885. } else if (hm < 1130) {
  886. return '上午';
  887. } else if (hm < 1230) {
  888. return '中午';
  889. } else if (hm < 1800) {
  890. return '下午';
  891. } else {
  892. return '晚上';
  893. }
  894. },
  895. calendar: {
  896. sameDay: function() {
  897. return this.minutes() === 0 ? '[今天]Ah[点整]' : '[今天]LT';
  898. },
  899. nextDay: function() {
  900. return this.minutes() === 0 ? '[明天]Ah[点整]' : '[明天]LT';
  901. },
  902. lastDay: function() {
  903. return this.minutes() === 0 ? '[昨天]Ah[点整]' : '[昨天]LT';
  904. },
  905. nextWeek: function() {
  906. var startOfWeek, prefix;
  907. startOfWeek = moment().startOf('week');
  908. prefix = this.unix() - startOfWeek.unix() >= 7 * 24 * 3600 ? '[下]' : '[本]';
  909. return this.minutes() === 0 ? prefix + 'dddAh点整' : prefix + 'dddAh点mm';
  910. },
  911. lastWeek: function() {
  912. var startOfWeek, prefix;
  913. startOfWeek = moment().startOf('week');
  914. prefix = this.unix() < startOfWeek.unix() ? '[上]' : '[本]';
  915. return this.minutes() === 0 ? prefix + 'dddAh点整' : prefix + 'dddAh点mm';
  916. },
  917. sameElse: 'LL'
  918. },
  919. ordinalParse: /\d{1,2}(日|月|周)/,
  920. ordinal: function(number, period) {
  921. switch (period) {
  922. case 'd':
  923. case 'D':
  924. case 'DDD':
  925. return number + '日';
  926. case 'M':
  927. return number + '月';
  928. case 'w':
  929. case 'W':
  930. return number + '周';
  931. default:
  932. return number;
  933. }
  934. },
  935. relativeTime: {
  936. future: '%s内',
  937. past: '%s前',
  938. s: '几秒',
  939. m: '1 分钟',
  940. mm: '%d 分钟',
  941. h: '1 小时',
  942. hh: '%d 小时',
  943. d: '1 天',
  944. dd: '%d 天',
  945. M: '1 个月',
  946. MM: '%d 个月',
  947. y: '1 年',
  948. yy: '%d 年'
  949. },
  950. week: {
  951. // GB/T 7408-1994《数据元和交换格式·信息交换·日期和时间表示法》与ISO 8601:1988等效
  952. dow: 1, // Monday is the first day of the week.
  953. doy: 4 // The week that contains Jan 4th is the first week of the year.
  954. }
  955. });
  956. var importUploader = $scope.importUploader = new FileUploader({
  957. url: api_bpm_data.impFileData().getRequestedUrl()
  958. });
  959. // importUploader.filters.push({
  960. // name: 'customFilter',
  961. // fn: function(item /*{File|FileLikeObject}*/ , options) {
  962. // var type = item.name.slice(item.name.lastIndexOf('.') + 1);
  963. // //var type = '|' + item.type.slice(item.type.lastIndexOf('/') + 1) + '|';
  964. // return (type == 'xlsx');
  965. // }
  966. // });
  967. importUploader.onWhenAddingFileFailed = function(item /*{File|FileLikeObject}*/ , filter, options) {
  968. console.info('onWhenAddingFileFailed', item, filter, options);
  969. };
  970. importUploader.onAfterAddingFile = function(fileItem) {
  971. console.info('onAfterAddingFile', fileItem);
  972. };
  973. importUploader.onAfterAddingAll = function(addedFileItems) {
  974. console.info('onAfterAddingAll', addedFileItems);
  975. };
  976. importUploader.onProgressItem = function(fileItem, progress) {
  977. console.info('onProgressItem', fileItem, progress);
  978. };
  979. importUploader.onProgressAll = function(progress) {
  980. console.info('onProgressAll', progress);
  981. };
  982. importUploader.onSuccessItem = function(fileItem, response, status, headers) {
  983. $scope.ldloading.expand_right = false;
  984. SweetAlert.swal({
  985. title: "导入成功!",
  986. confirmButtonColor: "#007AFF",
  987. type: "success"
  988. }, function() {
  989. $scope.scheduleClass = {};
  990. $scope.calendarView = 'month';
  991. $scope.calendarDate = moment().startOf('month').toDate();
  992. $scope.calendarTitle;
  993. $scope.externalEvents = [];
  994. api_bpm_schedule.getScheduleClass().then(function(response) {
  995. if (response.status == 200) {
  996. var scheduleClassList = response.list;
  997. angular.forEach(scheduleClassList, function(item) {
  998. item.startsAt = moment(item.startTime).format('HH:mm:ss');
  999. item.endsAt = moment(item.endTime).format('HH:mm:ss');
  1000. $scope.scheduleClass[item['code']] = item;
  1001. var templateEvent = {
  1002. title: item['name'],
  1003. type: item['code'],
  1004. startTime: item.startsAt,
  1005. //starts_at:
  1006. endTime: item.endsAt,
  1007. //ends_at:
  1008. draggable: true,
  1009. deleteFlag: item.deleteFlag
  1010. };
  1011. if (!templateEvent.deleteFlag) {
  1012. $scope.externalEvents.push(templateEvent);
  1013. }
  1014. })
  1015. }
  1016. })
  1017. });
  1018. console.info('onSuccessItem', fileItem, response, status, headers);
  1019. };
  1020. importUploader.onErrorItem = function(fileItem, response, status, headers) {
  1021. console.info('onErrorItem', fileItem, response, status, headers);
  1022. SweetAlert.swal({
  1023. title: "系统错误!",
  1024. text: "系统错误,请稍候重试!",
  1025. type: "error"
  1026. });
  1027. };
  1028. importUploader.onCancelItem = function(fileItem, response, status, headers) {
  1029. console.info('onCancelItem', fileItem, response, status, headers);
  1030. };
  1031. importUploader.onCompleteItem = function(fileItem, response, status, headers) {
  1032. console.info('onCompleteItem', fileItem, response, status, headers);
  1033. };
  1034. importUploader.onCompleteAll = function() {
  1035. console.info('onCompleteAll');
  1036. };
  1037. $scope.ldloading = {};
  1038. $scope.import = function() {
  1039. $scope.ldloading.expand_right = true;
  1040. importUploader.onBeforeUploadItem = function(item) {
  1041. console.info('onBeforeUploadItem', item);
  1042. };
  1043. importUploader.uploadAll();
  1044. }
  1045. //导入
  1046. $scope.importopen = function() { //导入触发事件
  1047. var modalInstance = $modal.open({
  1048. templateUrl: 'assets/views/import.html',
  1049. controller: function($scope, $modalInstance, FileUploader) {
  1050. var importUploader = $scope.importUploader = new FileUploader({
  1051. url: api_bpm_data.impFileData().getRequestedUrl()
  1052. });
  1053. // importUploader.filters.push({
  1054. // name: 'customFilter',
  1055. // fn: function(item /*{File|FileLikeObject}*/ , options) {
  1056. // var type = item.name.slice(item.name.lastIndexOf('.') + 1);
  1057. // //var type = '|' + item.type.slice(item.type.lastIndexOf('/') + 1) + '|';
  1058. // return (type == 'xlsx');
  1059. // }
  1060. // });
  1061. importUploader.onWhenAddingFileFailed = function(item /*{File|FileLikeObject}*/ , filter, options) {
  1062. console.info('onWhenAddingFileFailed', item, filter, options);
  1063. };
  1064. importUploader.onAfterAddingFile = function(fileItem) {
  1065. console.info('onAfterAddingFile', fileItem);
  1066. };
  1067. importUploader.onAfterAddingAll = function(addedFileItems) {
  1068. console.info('onAfterAddingAll', addedFileItems);
  1069. };
  1070. importUploader.onProgressItem = function(fileItem, progress) {
  1071. console.info('onProgressItem', fileItem, progress);
  1072. };
  1073. importUploader.onProgressAll = function(progress) {
  1074. console.info('onProgressAll', progress);
  1075. };
  1076. $rootScope.isMask = false;
  1077. importUploader.onSuccessItem = function(fileItem, response, status, headers) {
  1078. if (response.status == 200) {
  1079. $rootScope.isMask = false;
  1080. SweetAlert.swal({
  1081. title: "导入成功!",
  1082. confirmButtonColor: "#007AFF",
  1083. type: "success"
  1084. }, function() {
  1085. $scope.scheduleClass = {};
  1086. $scope.calendarView = 'month';
  1087. $scope.calendarDate = moment().startOf('month').toDate();
  1088. $scope.calendarTitle;
  1089. $scope.externalEvents = [];
  1090. api_bpm_schedule.getScheduleClass().then(function(response) {
  1091. if (response.status == 200) {
  1092. var scheduleClassList = response.list;
  1093. angular.forEach(scheduleClassList, function(item) {
  1094. item.startsAt = moment(item.startTime).format('HH:mm:ss');
  1095. item.endsAt = moment(item.endTime).format('HH:mm:ss');
  1096. $scope.scheduleClass[item['code']] = item;
  1097. var templateEvent = {
  1098. title: item['name'],
  1099. type: item['code'],
  1100. startTime: item.startsAt,
  1101. //starts_at:
  1102. endTime: item.endsAt,
  1103. //ends_at:
  1104. draggable: true,
  1105. deleteFlag: item.deleteFlag
  1106. };
  1107. if (!templateEvent.deleteFlag) {
  1108. $scope.externalEvents.push(templateEvent);
  1109. }
  1110. })
  1111. }
  1112. })
  1113. });
  1114. } else {
  1115. $rootScope.isMask = false;
  1116. SweetAlert.swal({
  1117. title: "导入失败!",
  1118. text: response.error,
  1119. type: "error"
  1120. })
  1121. }
  1122. // console.info('onSuccessItem', fileItem, response, status, headers);
  1123. };
  1124. importUploader.onErrorItem = function(fileItem, response, status, headers) {
  1125. console.info('onErrorItem', fileItem, response, status, headers);
  1126. SweetAlert.swal({
  1127. title: "系统错误!",
  1128. text: "系统错误,请稍候重试!",
  1129. type: "error"
  1130. });
  1131. };
  1132. importUploader.onCancelItem = function(fileItem, response, status, headers) {
  1133. console.info('onCancelItem', fileItem, response, status, headers);
  1134. };
  1135. importUploader.onCompleteItem = function(fileItem, response, status, headers) {
  1136. console.info('onCompleteItem', fileItem, response, status, headers);
  1137. };
  1138. importUploader.onCompleteAll = function() {
  1139. console.info('onCompleteAll');
  1140. };
  1141. $scope.ldloading = {};
  1142. $scope.import = function() {
  1143. $modalInstance.dismiss('cancel');
  1144. $rootScope.isMask = true;
  1145. importUploader.onBeforeUploadItem = function(item) {
  1146. angular.extend(item.headers, $rootScope.getSession());
  1147. item.formData.push({ 'filename': item.file.name });
  1148. item.formData.push({ 'type': "scheduleOrder" });
  1149. };
  1150. importUploader.uploadAll();
  1151. }
  1152. $scope.cancel = function() {
  1153. $modalInstance.dismiss('cancel');
  1154. };
  1155. },
  1156. size: 'sm',
  1157. resolve: {
  1158. importUploader: function() {
  1159. return $scope.importUploader;
  1160. }
  1161. }
  1162. });
  1163. modalInstance.result.then(function(selectedItem) {
  1164. if (selectedItem) {}
  1165. })
  1166. }
  1167. //导出
  1168. $scope.export = function(eventtime) {
  1169. var filadata = { 'sum': 1000, 'idx': 0 };
  1170. $http({
  1171. url: api_bpm_data.downDataModel("scheduleOrder", eventtime.getMonth() + 1).getRequestedUrl(),
  1172. method: 'POST',
  1173. data: JSON.stringify(filadata),
  1174. headers: {
  1175. // 'Content-type': 'application/xls',
  1176. 'Accept': '*/*'
  1177. },
  1178. responseType: 'arraybuffer'
  1179. }).success(function(data, status, headers, config) {
  1180. // $scope.ldloading.zoom_in = false;
  1181. var file = new Blob([data], {
  1182. type: 'application/vnd.ms-excel'
  1183. });
  1184. //trick to download store a file having its URL
  1185. var fileURL = URL.createObjectURL(file);
  1186. var a = document.createElement('a');
  1187. a.href = fileURL;
  1188. a.target = '_blank';
  1189. a.download = $scope.calendarTitle + '排班.xls';
  1190. document.body.appendChild(a);
  1191. a.click();
  1192. }).error(function(data, status, headers, config) {
  1193. // $scope.ldloading.zoom_in = false;
  1194. console.log(data);
  1195. });
  1196. }
  1197. var filterData = {
  1198. //"userId": loginUser.id,
  1199. "startTime": moment(new Date(y, m, 1, 0, 0)).format('YYYY-MM-DD HH:mm:ss'),
  1200. "endTime": moment(new Date(y, m + 1, 1, 0, 0)).format('YYYY-MM-DD HH:mm:ss')
  1201. };
  1202. var load = $scope.load = function(filterData) {
  1203. api_bpm_schedule.fetchList(filterData.startTime, filterData.endTime, filterData.userId).then(function(response) {
  1204. if (response.status == 200) {
  1205. $scope.events = [];
  1206. // console.log(response.list);
  1207. var myData = response.list;
  1208. angular.forEach(myData, function(item) {
  1209. var eventTemp = {};
  1210. eventTemp.title = item.description;
  1211. eventTemp.type = item.scheduleClass.code;
  1212. eventTemp.startsAt = moment(item.startTime).toDate();
  1213. eventTemp.endsAtTime = moment(item.endTime).toDate();
  1214. eventTemp.startTime = item.startTime;
  1215. eventTemp.endTime = item.endTime;
  1216. //eventTemp.ends_at = moment(item.endTime).toDate();
  1217. eventTemp.id = item.id;
  1218. eventTemp.users = item.users;
  1219. // {
  1220. // title: '白班',
  1221. // type: 'job',
  1222. // starts_at: new Date(y, m, 5, 19, 0),
  1223. // ends_at: new Date(y, m, 5, 22, 30)
  1224. // },
  1225. $scope.events.push(eventTemp);
  1226. })
  1227. }
  1228. });
  1229. }
  1230. $scope.scheduleClass = {};
  1231. $scope.calendarView = 'month';
  1232. $scope.calendarDate = moment().startOf('month').toDate();
  1233. $scope.calendarTitle;
  1234. $scope.externalEvents = [];
  1235. api_bpm_schedule.getScheduleClass().then(function(response) {
  1236. if (response.status == 200) {
  1237. var scheduleClassList = response.list;
  1238. // console.log(scheduleClassList)
  1239. angular.forEach(scheduleClassList, function(item) {
  1240. item.startsAt = moment(item.startTime).format('HH:mm:ss');
  1241. item.endsAt = moment(item.endTime).format('HH:mm:ss');
  1242. $scope.scheduleClass[item['code']] = item;
  1243. var templateEvent = {
  1244. title: item['name'],
  1245. type: item['code'],
  1246. startTime: item.startsAt,
  1247. //starts_at:
  1248. endTime: item.endsAt,
  1249. person: item.person,
  1250. //ends_at:
  1251. deleteFlag: item.deleteFlag
  1252. };
  1253. if (!templateEvent.deleteFlag) {
  1254. $scope.externalEvents.push(templateEvent);
  1255. }
  1256. })
  1257. }
  1258. })
  1259. $scope.typeTransfer = function(type) {
  1260. return $scope.scheduleClass[type].name;
  1261. }
  1262. $scope.events = [];
  1263. var acUserSelect = $scope.refreshUser = function(key) {
  1264. //for test
  1265. // $scope.users=[{"id":1,"phone":"13971293737","orgId":1,"name":"李静","role":[{"id":1,"rolecode":"admin","role":"主行管理员","flag":0}],"gender":"女","dept":{"id":3,"dept":"运行监控科"},"flag":0,"email":"","account":"005292","nickname":"lijing","group":[{"id":3,"groupName":"运行监控科"}]},{"id":2,"phone":"15807199490","orgId":1,"name":"李进","role":[{"id":1,"rolecode":"admin","role":"主行管理员","flag":0},{"id":7,"rolecode":"change manager","role":"变更流程经理","flag":1},{"id":8,"rolecode":"change coordinator","role":"协调员","flag":0},{"id":9,"rolecode":"configure manager","role":"配置管理员","flag":0},{"id":10,"rolecode":"release manager","role":"发布经理","flag":0}],"gender":"男","dept":{"id":3,"dept":"运行监控科"},"flag":0,"email":"","account":"005298","nickname":"lijin","group":[{"id":3,"groupName":"运行监控科"}]},{"id":3,"phone":"13507195958","orgId":1,"name":"杨代华","role":[{"id":2,"rolecode":"user","role":"主行员工","flag":1}],"gender":"男","dept":{"id":9,"dept":"管理层"},"flag":0,"email":"","account":"005241","group":[{"id":9,"groupName":"管理层"}]},{"id":4,"phone":"18717107255","orgId":1,"name":"朱红艳","role":[{"id":2,"rolecode":"user","role":"主行员工","flag":1}],"gender":"女","dept":{"id":9,"dept":"管理层"},"flag":0,"email":"","account":"005242","group":[{"id":9,"groupName":"管理层"}]},{"id":5,"phone":"13667282828","orgId":1,"name":"李喆","role":[{"id":2,"rolecode":"user","role":"主行员工","flag":1}],"gender":"男","dept":{"id":9,"dept":"管理层"},"flag":0,"email":"","account":"005243","group":[{"id":9,"groupName":"管理层"}]}];
  1266. // return;
  1267. var data = { "idx": "0", "sum": "999", "user": { "roledata": { "rolecode": "watch" } } };
  1268. // console.log(data);
  1269. if (key) {
  1270. data.user['name'] = key
  1271. }
  1272. // console.log(data);
  1273. api_user_data.fetchDataList('user', data).then(function(response) {
  1274. if (response) {
  1275. if (response.status = 200) {
  1276. $scope.users = response.list;
  1277. // console.log($scope.users);
  1278. }
  1279. }
  1280. })
  1281. };
  1282. $scope.users = [];
  1283. acUserSelect();
  1284. $scope.calendarView = 'month';
  1285. $scope.calendarDay = new Date();
  1286. $scope.timeLabel = "时间";
  1287. $scope.eventLabel = "描述";
  1288. var judegeEventByLimit = function(event, compareDay) {
  1289. var ret = true;
  1290. angular.forEach($scope.events, function(item) {
  1291. var day = moment(item.startsAt).startOf('day').format('YYYY-MM-DD');
  1292. if (day == compareDay) {
  1293. if (item.type == event.type) {
  1294. ret = false;
  1295. }
  1296. }
  1297. });
  1298. return ret;
  1299. }
  1300. $scope.eventDropped = function(event, start, end) {
  1301. console.log($scope.xinzeng);
  1302. if(!$scope.xinzeng){
  1303. SweetAlert.swal({
  1304. title: "操作失败",
  1305. text: "对不起,你没有权限新增!",
  1306. type: "error"
  1307. });
  1308. }else{
  1309. var externalIndex = $scope.externalEvents.indexOf(event);
  1310. if (externalIndex > -1) {
  1311. if (angular.isDefined(event.users) && event.users != null && event.users.length <= event.person) {
  1312. var compareDay = moment(start).startOf('day').format('YYYY-MM-DD');
  1313. if (!judegeEventByLimit(event, compareDay)) {
  1314. SweetAlert.swal({
  1315. title: "操作失败",
  1316. text: "当天" + event.title + "已存在, 请纠正后重试!",
  1317. type: "error"
  1318. });
  1319. return;
  1320. }
  1321. //$scope.externalEvents.splice(externalIndex, 1);
  1322. var bm = moment(moment(start).startOf('day').format('YYYY-MM-DD') + ' ' + event.startTime);
  1323. var em = moment(moment(start).startOf('day').format('YYYY-MM-DD') + ' ' + event.endTime);
  1324. event.startsAt = bm.toDate();
  1325. //console.log(JSON.stringify(event) + "start" + start + " end" + end);
  1326. var endTime = '';
  1327. var startTime = '';
  1328. if (bm.hour() > em.hour()) {
  1329. endTime = (moment(start).startOf('day').add('day', 1).format('YYYY-MM-DD') + ' ' + event.endTime);
  1330. } else {
  1331. endTime = (moment(start).startOf('day').format('YYYY-MM-DD') + ' ' + event.endTime);
  1332. }
  1333. startTime = (moment(start).startOf('day').format('YYYY-MM-DD') + ' ' + event.startTime);
  1334. var data = {
  1335. "scheduleorder": {
  1336. "description": event.title,
  1337. "startTime": startTime,
  1338. "endTime": endTime,
  1339. "users": event.users,
  1340. "scheduleClass": { "id": $scope.scheduleClass[event.type].id }
  1341. }
  1342. };
  1343. //event.endTime = "";
  1344. // event.startTime = "";
  1345. api_bpm_schedule.add(data).then(function(response) {
  1346. if (response.status == 200) {
  1347. SweetAlert.swal({
  1348. title: "操作成功!",
  1349. text: "新建排班成功!",
  1350. type: "succes"
  1351. });
  1352. var myData = response.data;
  1353. event.id = myData.id;
  1354. $scope.events.push({ 'id': event.id, 'title': event.title, 'startTime': startTime, 'endTime': endTime, 'users': event.users, 'type': event.type, 'startsAt': event.startsAt, 'draggable': event.draggable });
  1355. } else {
  1356. SweetAlert.swal({
  1357. title: "操作失败",
  1358. text: "新建排班失败,请稍后重试!",
  1359. type: "error"
  1360. })
  1361. }
  1362. })
  1363. } else {
  1364. SweetAlert.swal({
  1365. title: "操作失败",
  1366. text: "请选择" + event.person + "位值班人",
  1367. type: "error"
  1368. });
  1369. }
  1370. }
  1371. }
  1372. //console.log("new eventDropped")
  1373. };
  1374. function showModal(action, event) {
  1375. var modalInstance = $aside.open({
  1376. templateUrl: 'calendarEvent.html',
  1377. placement: 'right',
  1378. size: 'sm',
  1379. backdrop: true,
  1380. controller: function($scope, $modalInstance, scheduleClass, APIService, MementFormat, Alert, EventsData,moment) {
  1381. var loginUser = $rootScope.user;
  1382. $scope.shanchu=false;
  1383. $scope.bianji=false;
  1384. for(var i=0;i<loginUser.menu.length;i++){
  1385. if(loginUser.menu[i].link=="paibanrili_shanchu"){
  1386. $scope.shanchu=true
  1387. }
  1388. if(loginUser.menu[i].link=="paibanrili_bianji"){
  1389. $scope.bianji=true
  1390. }
  1391. };
  1392. $scope.$modalInstance = $modalInstance;
  1393. $scope.action = action;
  1394. event.startsAt = moment(event.startsAt).format('YYYY-MM-DD HH:mm:ss');
  1395. event.endsAtTime = moment(event.startsAt).format('YYYY-MM-DD HH:mm:ss');
  1396. $scope.event = event;
  1397. console.log(event);
  1398. $scope.scheduleClassic = event.tilte;
  1399. $scope.currentDate = MementFormat().toDate();
  1400. $scope.$watch('event.type', function(newvalue, oldvalue) {
  1401. if (oldvalue == newvalue) return;
  1402. if (scheduleClass[newvalue]) {
  1403. var sm = MementFormat(scheduleClass[newvalue].startTime);
  1404. var em = MementFormat(scheduleClass[newvalue].endTime);
  1405. event.startsAt = MementFormat(event.startTime).startOf('day').add(sm.hour(), 'hour').add(sm.minute(), 'minute').add(sm.second(), 'second').toDate();
  1406. event.startTime = MementFormat(event.startTime).startOf('day').add(sm.hour(), 'hour').add(sm.minute(), 'minute').add(sm.second(), 'second').format('YYYY-MM-DD HH:mm:ss');
  1407. event.title = scheduleClass[newvalue].name;
  1408. if (sm.hour() > em.hour()) {
  1409. event.endTime = MementFormat(event.startTime).startOf('day').add(1, 'day').add(em.hour(), 'hour').add(em.minute(), 'minute').add(em.second(), 'second').format('YYYY-MM-DD HH:mm:ss');
  1410. event.endsAtTime = MementFormat(event.startTime).startOf('day').add(1, 'day').add(em.hour(), 'hour').add(em.minute(), 'minute').add(em.second(), 'second').toDate();
  1411. } else {
  1412. event.endTime = MementFormat(event.startTime).startOf('day').add(em.hour(), 'hour').add(em.minute(), 'minute').add(em.second(), 'second').format('YYYY-MM-DD HH:mm:ss');
  1413. event.endsAtTime = MementFormat(event.startTime).startOf('day').add(em.hour(), 'hour').add(em.minute(), 'minute').add(em.second(), 'second').toDate();
  1414. }
  1415. }
  1416. });
  1417. $scope.$watch('event.startsAt', function(newvalue, oldvalue) {
  1418. if (oldvalue == newvalue) return;
  1419. if (MementFormat(oldvalue).format('YYYY-MM-DD HH:mm:ss') == MementFormat(newvalue).format('YYYY-MM-DD HH:mm:ss')) return;
  1420. if (scheduleClass[event.type]) {
  1421. var sm = MementFormat(scheduleClass[event.type].startTime);
  1422. var em = MementFormat(scheduleClass[event.type].endTime);
  1423. //event.starts_at = MementFormat(event.starts_at).startOf('day').add(sm.hour(),'hour').add(sm.minute(),'minute').add(sm.second(),'second').toDate();
  1424. if (sm.hour() > em.hour()) {
  1425. event.endTime = MementFormat(event.startsAt).startOf('day').add(1, 'day').add(em.hour(), 'hour').add(em.minute(), 'minute').add(em.second(), 'second').format('YYYY-MM-DD HH:mm:ss');
  1426. event.endsAtTime = MementFormat(event.startsAt).startOf('day').add(1, 'day').add(em.hour(), 'hour').add(em.minute(), 'minute').add(em.second(), 'second').toDate();
  1427. } else {
  1428. event.endTime = MementFormat(event.startsAt).startOf('day').add(em.hour(), 'hour').add(em.minute(), 'minute').add(em.second(), 'second').format('YYYY-MM-DD HH:mm:ss');
  1429. event.endsAtTime = MementFormat(event.startsAt).startOf('day').add(em.hour(), 'hour').add(em.minute(), 'minute').add(em.second(), 'second').toDate();
  1430. }
  1431. }
  1432. });
  1433. $scope.setEndOpen = function() {
  1434. if (scheduleClass[event.type]) {
  1435. var sm = MementFormat(scheduleClass[event.type].startTime);
  1436. var em = MementFormat(scheduleClass[event.type].endTime);
  1437. event.startsAt = MementFormat(event.startTime).startOf('day').add(sm.hour(), 'hour').add(sm.minute(), 'minute').add(sm.second(), 'second').toDate();
  1438. if (sm.hour() > em.hour()) {
  1439. event.endTime = MementFormat(event.startTime).startOf('day').add(1, 'day').add(em.hour(), 'hour').add(em.minute(), 'minute').add(em.second(), 'second').format('YYYY-MM-DD HH:mm:ss');
  1440. event.endsAtTime = MementFormat(event.startTime).startOf('day').add(1, 'day').add(em.hour(), 'hour').add(em.minute(), 'minute').add(em.second(), 'second').toDate();
  1441. } else {
  1442. event.endTime = MementFormat(event.startTime).startOf('day').add(em.hour(), 'hour').add(em.minute(), 'minute').add(em.second(), 'second').format('YYYY-MM-DD HH:mm:ss');
  1443. event.endsAtTime = MementFormat(event.startTime).startOf('day').add(em.hour(), 'hour').add(em.minute(), 'minute').add(em.second(), 'second').toDate();
  1444. }
  1445. }
  1446. }
  1447. //同一天只能排出一个白班一个夜班
  1448. function judegeEventByLimit(event) {
  1449. var ret = true;
  1450. var compareDay = moment(event.startsAt).startOf('day').format('YYYY-MM-DD');
  1451. angular.forEach(EventsData, function(item) {
  1452. var day = moment(item.startsAt).startOf('day').format('YYYY-MM-DD');
  1453. if (day == compareDay) {
  1454. if (angular.isDefined(event.id)) {
  1455. if (item.type == event.type && event.id != item.id) ret = false;
  1456. } else {
  1457. if (item.type == event.type) ret = false;
  1458. }
  1459. }
  1460. });
  1461. return ret;
  1462. }
  1463. $scope.ok = function(event) {
  1464. // console.log("event="+JSON.stringify(event));
  1465. if (angular.isDefined(event.users) && event.users != null) {
  1466. if (judegeEventByLimit(event)) {
  1467. event.action = action;
  1468. $modalInstance.close(event);
  1469. } else {
  1470. Alert.swal({
  1471. title: "操作失败",
  1472. text: "同一天只能排出一个白班一个夜班, 请纠正后重试!",
  1473. type: "error"
  1474. })
  1475. }
  1476. } else {
  1477. Alert.swal({
  1478. title: "操作失败",
  1479. text: "请填写值班人",
  1480. type: "error"
  1481. })
  1482. }
  1483. };
  1484. $scope.deleteEvent = function(event) {
  1485. event.action = "Deleted";
  1486. $modalInstance.close(event);
  1487. };
  1488. $scope.refreshModalUser = function(key) {
  1489. //for test
  1490. // $scope.users=[{"id":1,"phone":"13971293737","orgId":1,"name":"李静","role":[{"id":1,"rolecode":"admin","role":"主行管理员","flag":0}],"gender":"女","dept":{"id":3,"dept":"运行监控科"},"flag":0,"email":"","account":"005292","nickname":"lijing","group":[{"id":3,"groupName":"运行监控科"}]},{"id":2,"phone":"15807199490","orgId":1,"name":"李进","role":[{"id":1,"rolecode":"admin","role":"主行管理员","flag":0},{"id":7,"rolecode":"change manager","role":"变更流程经理","flag":1},{"id":8,"rolecode":"change coordinator","role":"协调员","flag":0},{"id":9,"rolecode":"configure manager","role":"配置管理员","flag":0},{"id":10,"rolecode":"release manager","role":"发布经理","flag":0}],"gender":"男","dept":{"id":3,"dept":"运行监控科"},"flag":0,"email":"","account":"005298","nickname":"lijin","group":[{"id":3,"groupName":"运行监控科"}]},{"id":3,"phone":"13507195958","orgId":1,"name":"杨代华","role":[{"id":2,"rolecode":"user","role":"主行员工","flag":1}],"gender":"男","dept":{"id":9,"dept":"管理层"},"flag":0,"email":"","account":"005241","group":[{"id":9,"groupName":"管理层"}]},{"id":4,"phone":"18717107255","orgId":1,"name":"朱红艳","role":[{"id":2,"rolecode":"user","role":"主行员工","flag":1}],"gender":"女","dept":{"id":9,"dept":"管理层"},"flag":0,"email":"","account":"005242","group":[{"id":9,"groupName":"管理层"}]},{"id":5,"phone":"13667282828","orgId":1,"name":"李喆","role":[{"id":2,"rolecode":"user","role":"主行员工","flag":1}],"gender":"男","dept":{"id":9,"dept":"管理层"},"flag":0,"email":"","account":"005243","group":[{"id":9,"groupName":"管理层"}]}];
  1491. // return;
  1492. var data = { "idx": "0", "sum": "999", "user": { "roledata": { "rolecode": "watch" } } };
  1493. if (key) {
  1494. data.user['name'] = key
  1495. }
  1496. console.log(data);
  1497. APIService.fetchDataList('user', data).then(function(response) {
  1498. if (response) {
  1499. // console.log("response=" + JSON.stringify(response))
  1500. if (response.status = 200) {
  1501. $scope.modalusers = response.list;
  1502. console.log($scope.users);
  1503. }
  1504. }
  1505. })
  1506. };
  1507. $scope.users = [];
  1508. $scope.refreshModalUser();
  1509. },
  1510. resolve: {
  1511. scheduleClass: function() {
  1512. return $scope.scheduleClass;
  1513. },
  1514. APIService: function() {
  1515. return api_user_data;
  1516. },
  1517. MementFormat: function() {
  1518. return moment;
  1519. },
  1520. Alert: function() {
  1521. return SweetAlert;
  1522. },
  1523. EventsData: function() {
  1524. return $scope.events;
  1525. }
  1526. }
  1527. });
  1528. modalInstance.result.then(function(selectedEvent) {
  1529. if (selectedEvent.action == 'Edited') {
  1530. //new
  1531. var data = {
  1532. "scheduleorder": {
  1533. "description": selectedEvent.title,
  1534. "startTime": selectedEvent.startTime,
  1535. "endTime": selectedEvent.endTime,
  1536. "users": selectedEvent.users,
  1537. "scheduleClass": { "id": $scope.scheduleClass[selectedEvent.type].id }
  1538. }
  1539. };
  1540. api_bpm_schedule.add(data).then(function(response) {
  1541. if (response.status == 200) {
  1542. SweetAlert.swal({
  1543. title: "操作成功!",
  1544. text: "新建排班成功!",
  1545. type: "succes"
  1546. });
  1547. $scope.events.push(convertEvent(response.data));
  1548. // angular.forEach($scope.events,function(item){
  1549. // if(item.id==selectedEvent.id){
  1550. // item = selectedEvent;
  1551. // }
  1552. // })
  1553. } else {
  1554. SweetAlert.swal({
  1555. title: "操作失败",
  1556. text: "新建排班失败,请稍后重试!",
  1557. type: "error"
  1558. })
  1559. }
  1560. })
  1561. } else if (selectedEvent.action == 'Clicked') {
  1562. if(typeof(selectedEvent.startTime)!="string"){
  1563. selectedEvent.startTime=moment(selectedEvent.startTime.getTime()).format('YYYY-MM-DD HH:mm:ss')
  1564. }
  1565. if(typeof(selectedEvent.endTime)!="string"){
  1566. selectedEvent.endTime=moment(selectedEvent.endTime.getTime()).format('YYYY-MM-DD HH:mm:ss')
  1567. }
  1568. var data = {
  1569. "scheduleorder": {
  1570. "id": selectedEvent.id,
  1571. "description": selectedEvent.title,
  1572. "startTime":selectedEvent.startTime,
  1573. "endTime": selectedEvent.endTime,
  1574. "users": selectedEvent.users,
  1575. "scheduleClass": { "id": $scope.scheduleClass[selectedEvent.type].id }
  1576. }
  1577. };
  1578. api_bpm_schedule.update(data).then(function(response) {
  1579. if (response.status == 200) {
  1580. SweetAlert.swal({
  1581. title: "操作成功!",
  1582. text: "排班更新成功!",
  1583. type: "succes"
  1584. });
  1585. angular.forEach($scope.events, function(item) {
  1586. if (item.id == selectedEvent.id) {
  1587. item = selectedEvent;
  1588. }
  1589. })
  1590. } else {
  1591. SweetAlert.swal({
  1592. title: "操作失败",
  1593. text: "排班更新失败,请稍后重试!",
  1594. type: "error"
  1595. })
  1596. }
  1597. })
  1598. } else {
  1599. $scope.eventDeleted(selectedEvent);
  1600. }
  1601. });
  1602. }
  1603. $scope.moment = function(string) {
  1604. return moment(string);
  1605. }
  1606. $scope.eventClicked = function(event) {
  1607. showModal('Clicked', event);
  1608. };
  1609. $scope.addEvent = function() {
  1610. var sm = moment($scope.scheduleClass['job'].startTime);
  1611. var em = moment($scope.scheduleClass['job'].endTime);
  1612. var newevent = {
  1613. title: $scope.scheduleClass['job'].name,
  1614. type: $scope.scheduleClass['job'].code,
  1615. user: loginUser
  1616. };
  1617. newevent.startsAt = moment($scope.calendarDay).startOf('day').add(sm.hour(), 'hour').add(sm.minute(), 'minute').add(sm.second(), 'second').toDate();
  1618. newevent.startTime = moment($scope.calendarDay).startOf('day').add(sm.hour(), 'hour').add(sm.minute(), 'minute').add(sm.second(), 'second').format('YYYY-MM-DD HH:mm:ss');
  1619. if (sm.hour() > em.hour()) {
  1620. newevent.endTime = moment($scope.calendarDay).startOf('day').add(1, 'day').add(em.hour(), 'hour').add(em.minute(), 'minute').add(em.second(), 'second').format('YYYY-MM-DD HH:mm:ss');
  1621. newevent.endsAtTime = moment($scope.calendarDay).startOf('day').add(1, 'day').add(em.hour(), 'hour').add(em.minute(), 'minute').add(em.second(), 'second').toDate();
  1622. //newevent.ends_at = moment($scope.calendarDay).startOf('day').add(1, 'day').add(em.hour(),'hour').add(em.minute(),'minute').add(em.second(),'second').toDate();
  1623. } else {
  1624. newevent.endTime = moment($scope.calendarDay).startOf('day').add(em.hour(), 'hour').add(em.minute(), 'minute').add(em.second(), 'second').format('YYYY-MM-DD HH:mm:ss');
  1625. newevent.endsAtTime = moment($scope.calendarDay).startOf('day').add(em.hour(), 'hour').add(em.minute(), 'minute').add(em.second(), 'second').toDate();
  1626. //newevent.ends_at = moment($scope.calendarDay).startOf('day').add(em.hour(),'hour').add(em.minute(),'minute').add(em.second(),'second').toDate();
  1627. }
  1628. $scope.eventEdited(newevent);
  1629. };
  1630. $scope.eventEdited = function(event) {
  1631. showModal('Edited', event);
  1632. };
  1633. $scope.eventDeleted = function(event) {
  1634. SweetAlert.swal({
  1635. title: "确认删除?",
  1636. text: "删除的数据不可恢复,请确认继续操作!",
  1637. type: "warning",
  1638. showCancelButton: true,
  1639. confirmButtonColor: "#DD6B55",
  1640. confirmButtonText: "继续删除",
  1641. cancelButtonText: "取消操作",
  1642. closeOnConfirm: false,
  1643. closeOnCancel: false
  1644. }, function(isConfirm) {
  1645. if (isConfirm) {
  1646. api_bpm_schedule.remove([event.id]).then(function(response) {
  1647. if (response.status == 200) {
  1648. $scope.events.splice(event.$id, 1);
  1649. SweetAlert.swal("操作成功!", "数据已经被删除.", "success");
  1650. } else {
  1651. SweetAlert.swal("操作失败!", "数据暂时无法被删除,请稍候重试", "error");
  1652. }
  1653. });
  1654. } else {
  1655. SweetAlert.swal("操作取消", "数据安全", "error");
  1656. }
  1657. });
  1658. };
  1659. //$scope.timeStart;
  1660. //$scope.timeEnd;
  1661. var updateView = function(newvalue, oldvalue) {
  1662. if (oldvalue == newvalue) return;
  1663. if (moment(oldvalue).format('YYYY-MM-DD HH:mm:ss') == moment(newvalue).format('YYYY-MM-DD HH:mm:ss')) return;
  1664. var timeStart, timeEnd, timeStartSpan, timeEndSpan;
  1665. if ($scope.calendarView == "year") {
  1666. } else if ($scope.calendarView == "month") {
  1667. timeStart = moment(newvalue).startOf('month');
  1668. timeEnd = moment(newvalue).endOf('month');
  1669. } else if ($scope.calendarView == "week") {
  1670. timeStart = moment(newvalue).startOf('week');
  1671. timeEnd = moment(newvalue).endOf('week');
  1672. } else if ($scope.calendarView == "Day") {
  1673. timeStart = moment(newvalue).startOf('day');
  1674. timeEnd = moment(newvalue).endOf('day');
  1675. }
  1676. timeStartSpan = timeStart.format('YYYY-MM-DD HH:mm:ss');
  1677. timeEndSpan = timeEnd.format('YYYY-MM-DD HH:mm:ss');
  1678. filterData["startTime"] = timeStartSpan;
  1679. filterData["endTime"] = timeEndSpan;
  1680. load(filterData);
  1681. }
  1682. $scope.$watch('calendarDate', updateView)
  1683. $scope.next = function() {
  1684. $scope.calendarControl.next();
  1685. }
  1686. $scope.prev = function() {
  1687. $scope.calendarControl.prev();
  1688. }
  1689. $scope.setCalendarToToday = function() {
  1690. $scope.calendarDay = new Date();
  1691. };
  1692. $scope.toggle = function($event, field, event) {
  1693. $event.preventDefault();
  1694. $event.stopPropagation();
  1695. event[field] = !event[field];
  1696. };
  1697. $scope.load(filterData);
  1698. }]);
  1699. /* 换班记录 */
  1700. app.controller('shiftScheduleCtrl', ["$rootScope", "$scope", "$state", "$timeout", "$interval", "moment", "SweetAlert", "Restangular", "api_bpm_schedule", "api_user_data", function($rootScope, $scope, $state, $timeout, $interval, moment, SweetAlert, Restangular, api_bpm_schedule, api_user_data) {
  1701. var loginUser = $rootScope.user;
  1702. $scope.shiftes = [];
  1703. var load = function() {
  1704. $scope.shiftes = [];
  1705. api_bpm_schedule.queryHandleoutSwitch(loginUser.id).then(function(response) {
  1706. if (response) {
  1707. var myData = Restangular.stripRestangular(response);
  1708. angular.forEach(myData.list, function(item) {
  1709. $scope.shiftes.push(item);
  1710. })
  1711. }
  1712. })
  1713. }
  1714. $scope.getShiftType = function(shift) {
  1715. var ret = "error";
  1716. if (shift.scheduleOrderDTO.status.id == 2) {
  1717. ret = "import";
  1718. }
  1719. if (shift.scheduleOrderDTO.status.id == 4) {
  1720. ret = "upload";
  1721. }
  1722. return ret;
  1723. }
  1724. // var getShift = function(){
  1725. // angular.forEach($scope.shiftes, function(item){
  1726. // if(item.user.id==loginUser.id){
  1727. // return item;
  1728. // }
  1729. // })
  1730. // }
  1731. var getShift = function() {
  1732. var ret = null;
  1733. angular.forEach($scope.shiftes, function(item) {
  1734. if (item.user.id == loginUser.id && (item.status.id == 1 || item.status.id == 2) && ret == null) {
  1735. ret = item;
  1736. }
  1737. })
  1738. return ret;
  1739. }
  1740. $scope.getHandle = function() {
  1741. var ret = "error";
  1742. var shift;
  1743. var index = 0;
  1744. //angular.forEach($scope.shiftes, function(item){
  1745. for (var index1 in $scope.shiftes) {
  1746. //shift = item;
  1747. var item = $scope.shiftes[index1];
  1748. //console.log(item.user.id +"==" +loginUser.id + "shift.status.id"+shift.status.id + " " + shift.scheduleOrderDTO.status.id );
  1749. if (item.user.id == loginUser.id) {
  1750. shift = item;
  1751. //console.log(shift.status.id);
  1752. if (shift.status.id == 1) {
  1753. //console.log("shift.scheduleOrderDTO.status.id="+shift.scheduleOrderDTO.status.id);
  1754. if (shift.scheduleOrderDTO.status.id == 2) {
  1755. ret = "import";
  1756. }
  1757. } else if (shift.status.id == 2) {
  1758. if (shift.scheduleOrderDTO.status.id == 4) {
  1759. ret = "upload";
  1760. break;
  1761. //return;
  1762. }
  1763. }
  1764. //return ret;
  1765. }
  1766. if (item.status.id == 5) {
  1767. index++;
  1768. }
  1769. //});
  1770. }
  1771. //console.log(index)
  1772. if (ret == 'import' && index != 2) {
  1773. ret = 'uploadDes';
  1774. }
  1775. console.log(ret);
  1776. return ret;
  1777. }
  1778. $scope.importShift = function() {
  1779. var shift = getShift();
  1780. var data = {};
  1781. if (shift.status.id == 1) {
  1782. data.status = {};
  1783. data.status.id = 4;
  1784. }
  1785. data.id = shift.id;
  1786. api_bpm_schedule.handleSchedule(data).then(function(response) {
  1787. if (response) {
  1788. var myData = Restangular.stripRestangular(response);
  1789. if (response.status == 200) {
  1790. SweetAlert.swal("接班成功!", "接班成功!", "success");
  1791. load();
  1792. } else {
  1793. SweetAlert.swal("接班失败!", "接班失败,请稍候重试", "error");
  1794. }
  1795. }
  1796. })
  1797. }
  1798. $scope.uploadShift = function() {
  1799. var shift = getShift();
  1800. var data = {};
  1801. if (shift.status.id == 2) {
  1802. data.status = {};
  1803. data.status.id = 5;
  1804. }
  1805. data.id = shift.id;
  1806. api_bpm_schedule.handleSchedule(data).then(function(response) {
  1807. if (response) {
  1808. var myData = Restangular.stripRestangular(response);
  1809. if (response.status == 200) {
  1810. SweetAlert.swal("交班成功!", "交班成功!", "success");
  1811. load();
  1812. } else {
  1813. SweetAlert.swal("交班失败!", "交班失败,请稍候重试", "error");
  1814. }
  1815. }
  1816. })
  1817. }
  1818. load();
  1819. // api_bpm_schedule.queryRecieveSwitch(loginUser.id).then(function(response){
  1820. // if(response){
  1821. // var myData = Restangular.stripRestangular(response);
  1822. // angular.forEach(myData.list, function(item){
  1823. // $scope.shiftes.push(item);
  1824. // })
  1825. // }
  1826. // })
  1827. }]);
  1828. /* 换班申请 */
  1829. app.controller('shiftRecordCtrl', ["$rootScope", "$scope", "$state", "$timeout", "$interval", "SweetAlert", "i18nService", "uiGridConstants", "uiGridGroupingConstants", "Restangular", "api_bpm_schedule", "$aside", "moment", function($rootScope, $scope, $state, $timeout, $interval, SweetAlert, i18nService, uiGridConstants, uiGridGroupingConstants, Restangular, api_bpm_schedule, $aside, moment) {
  1830. $scope.langs = i18nService.getAllLangs();
  1831. $scope.lang = 'zh-cn';
  1832. i18nService.setCurrentLang($scope.lang);
  1833. $scope.gridOptions = {};
  1834. $scope.gridOptions.data = 'myData';
  1835. $scope.gridOptions.enableColumnResizing = true;
  1836. $scope.gridOptions.enableFiltering = false;
  1837. $scope.gridOptions.enableGridMenu = true;
  1838. $scope.gridOptions.enableRowSelection = true;
  1839. $scope.gridOptions.showGridFooter = true;
  1840. $scope.gridOptions.showColumnFooter = false;
  1841. $scope.gridOptions.fastWatch = true;
  1842. $scope.gridOptions.useExternalFiltering = true;
  1843. $scope.gridOptions.useExternalPagination = true;
  1844. $scope.gridOptions.paginationPageSizes = [10];
  1845. $scope.gridOptions.paginationPageSize = 10;
  1846. $scope.gridOptions.multiSelect = false;
  1847. //$scope.gridOptions.rowTemplate = "<div ng-dblclick=\"grid.appScope.pdList.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>";
  1848. //
  1849. $scope.gridOptions.rowIdentity = function(row) {
  1850. return row.id;
  1851. };
  1852. $scope.gridOptions.getRowIdentity = function(row) {
  1853. return row.id;
  1854. };
  1855. $scope.gridOptions.columnDefs = [{
  1856. name: 'orderTime',
  1857. displayName: '日期',
  1858. width: 100
  1859. }, {
  1860. name: 'scheduleClass.name',
  1861. displayName: '班次',
  1862. width: 80,
  1863. enableFiltering: false
  1864. },
  1865. {
  1866. name: 'scheduleWatchList[2].user.name',
  1867. displayName: '第一交班人',
  1868. width: 100,
  1869. enableFiltering: false
  1870. },
  1871. {
  1872. name: 'scheduleWatchList[2].shiftTime',
  1873. displayName: '交班时间',
  1874. width: 180,
  1875. enableFiltering: false
  1876. },
  1877. {
  1878. name: 'scheduleWatchList[3].user.name',
  1879. displayName: '第二交班人',
  1880. width: 100,
  1881. enableFiltering: false
  1882. },
  1883. {
  1884. name: 'scheduleWatchList[3].shiftTime',
  1885. displayName: '交班时间',
  1886. width: 180,
  1887. enableFiltering: false
  1888. },
  1889. {
  1890. name: 'scheduleWatchList[0].user.name',
  1891. displayName: '第一接班人',
  1892. width: 100,
  1893. enableFiltering: false
  1894. },
  1895. {
  1896. name: 'scheduleWatchList[0].succeedTime',
  1897. displayName: '接班时间',
  1898. width: 180,
  1899. enableFiltering: false
  1900. },
  1901. {
  1902. name: 'scheduleWatchList[1].user.name',
  1903. displayName: '第二接班人',
  1904. width: 100,
  1905. enableFiltering: false
  1906. },
  1907. {
  1908. name: 'scheduleWatchList[1].succeedTime',
  1909. displayName: '接班时间',
  1910. width: 180,
  1911. enableFiltering: false
  1912. },
  1913. {
  1914. name: 'status.name',
  1915. displayName: '状态',
  1916. width: 100,
  1917. enableFiltering: false
  1918. }
  1919. ];
  1920. $scope.gridOptions.onRegisterApi = function(gridApi) {
  1921. $scope.gridApi = gridApi;
  1922. gridApi.pagination.on.paginationChanged($scope, function(newPage, pageSize) {
  1923. console.log(newPage);
  1924. console.log(pageSize);
  1925. $scope.refreshData('expand-right', {
  1926. "idx": newPage - 1,
  1927. "sum": pageSize
  1928. });
  1929. });
  1930. gridApi.selection.on.rowSelectionChanged($scope, function(data) {
  1931. //$scope.selected.item = data.entity;
  1932. console.log(data);
  1933. });
  1934. // gridApi.core.on.filterChanged($scope, function() {
  1935. // var grid = this.grid;
  1936. // var filtersData = {
  1937. // idx:0,
  1938. // sum:10
  1939. // };
  1940. // angular.forEach(grid.columns,function(item){
  1941. // if(item.enableFiltering){
  1942. // if(angular.isDefined(item.filters[0].term)&&item.filters[0].term!=''){
  1943. // // console.log('item.filters[0]='+JSON.stringify(item.filters[0]));
  1944. // if(angular.isUndefined(filtersData['scheduling'])){
  1945. // filtersData['scheduling']={};
  1946. // }
  1947. // filtersData['scheduling'][item.field]=item.filters[0].term;
  1948. // }
  1949. // }
  1950. // });
  1951. // $scope.memoryfilterData = filtersData;
  1952. // $scope.refreshData('expand-right', filtersData);
  1953. // });
  1954. };
  1955. this.selectRowFunction = function(data) {
  1956. console.log(data);
  1957. // $state.go('app.process.modeler',{modelId:data.id});
  1958. $state.go('app.scheduling.editor', {
  1959. taskId: data.taskId,
  1960. processInstanceId: data.processInstanceId
  1961. });
  1962. };
  1963. $scope.search = function(start, end) {
  1964. var filtersData = {
  1965. "scheduleorder": { "type": "4" },
  1966. idx: 0,
  1967. sum: 10
  1968. };
  1969. if (angular.isDefined(start) || angular.isDefined(end)) {
  1970. filtersData.scheduleorder['startTime'] = moment(start).format('YYYY-MM-DD HH:mm:ss');
  1971. // filtersData.scheduleorder['endTime']=moment(end).format('YYYY-MM-DD HH:mm:ss');
  1972. var timedata = new Date(end).getTime() + 86400000;
  1973. var d = new Date(timedata)
  1974. filtersData.scheduleorder['endTime'] = moment(d).format('YYYY-MM-DD HH:mm:ss');
  1975. console.log(timedata)
  1976. }
  1977. $scope.memoryfilterData = filtersData;
  1978. $scope.refresh('expand-right', filtersData);
  1979. }
  1980. $scope.ldloading = false;
  1981. $scope.export = function(start, end) {
  1982. $scope.ldloading.expand_right = true;
  1983. var filtersData = {
  1984. scheduleorder: { "type": "4" },
  1985. idx: 0,
  1986. sum: 1000
  1987. };
  1988. if (angular.isDefined(start) || angular.isDefined(end)) {
  1989. filtersData.scheduleorder['startTime'] = moment(start).format('YYYY-MM-DD HH:mm:ss');
  1990. var timedata = new Date(end).getTime() + 86400000;
  1991. var d = new Date(timedata)
  1992. filtersData.scheduleorder['endTime'] = moment(d).format('YYYY-MM-DD HH:mm:ss');
  1993. }
  1994. // if(angular.isDefined($scope.ciclassify)&&$scope.ciclassify!=null){
  1995. // if(angular.isUndefined($scope.ciclassify.children)||$scope.ciclassify.children.length==0){
  1996. api_bpm_schedule.query(filtersData).then(function(data) {
  1997. var dataList = Restangular.stripRestangular(data).list;
  1998. // if(dataList&&(dataList.list.length>=1)){
  1999. var headers = [];
  2000. var fieldHeaders = [];
  2001. var exportdata = [];
  2002. var fields = [];
  2003. var rowData = [];
  2004. var rowdata = [];
  2005. if ($scope.gridOptions.columnDefs.length > 0) {
  2006. angular.forEach($scope.gridOptions.columnDefs, function(prop) {
  2007. headers.push(prop.displayName);
  2008. // angular.forEach(prop.form.fields, function(field, index){
  2009. // fieldHeaders.push(field.templateOptions.label);
  2010. // fields.push(field.key);
  2011. // if(index!=0){
  2012. // headers.push("");
  2013. // }
  2014. // });
  2015. })
  2016. }
  2017. var rowLine = [];
  2018. var dataline = [];
  2019. for (var i = 0; i < dataList.length; i++) {
  2020. if (angular.isUndefined(dataList[i].scheduleWatchList[0])) { dataList[i].scheduleWatchList[0] = {} }
  2021. if (angular.isUndefined(dataList[i].scheduleWatchList[1])) { dataList[i].scheduleWatchList[1] = {} }
  2022. if (angular.isUndefined(dataList[i].scheduleWatchList[2])) { dataList[i].scheduleWatchList[2] = {} }
  2023. if (angular.isUndefined(dataList[i].scheduleWatchList[3])) { dataList[i].scheduleWatchList[3] = {} }
  2024. if (angular.isUndefined(dataList[i].scheduleWatchList[2].user)) { dataList[i].scheduleWatchList[2].user = "" }
  2025. if (angular.isUndefined(dataList[i].scheduleWatchList[2].shiftTime)) { dataList[i].scheduleWatchList[2].shiftTime = "" }
  2026. if (angular.isUndefined(dataList[i].scheduleWatchList[1].user)) { dataList[i].scheduleWatchList[1].user = "" }
  2027. if (angular.isUndefined(dataList[i].scheduleWatchList[1].succeedTime)) { dataList[i].scheduleWatchList[1].succeedTime = "" }
  2028. if (angular.isUndefined(dataList[i].scheduleWatchList[0].user)) { dataList[i].scheduleWatchList[0].user = "" }
  2029. if (angular.isUndefined(dataList[i].scheduleWatchList[0].succeedTime)) { dataList[i].scheduleWatchList[0].succeedTime = "" }
  2030. if (angular.isUndefined(dataList[i].scheduleWatchList[3].user)) { dataList[i].scheduleWatchList[3].user = "" }
  2031. if (angular.isUndefined(dataList[i].scheduleWatchList[3].shiftTime)) { dataList[i].scheduleWatchList[3].shiftTime = "" }
  2032. exportdata = {
  2033. orderTime: dataList[i].orderTime,
  2034. scheduleClass: dataList[i].scheduleClass.name,
  2035. username2: dataList[i].scheduleWatchList[2].user.name,
  2036. shiftTime2: dataList[i].scheduleWatchList[2].shiftTime,
  2037. username3: dataList[i].scheduleWatchList[3].user.name,
  2038. succeedTime3: dataList[i].scheduleWatchList[3].succeedTime,
  2039. username0: dataList[i].scheduleWatchList[0].user.name,
  2040. succeedTime0: dataList[i].scheduleWatchList[0].succeedTime,
  2041. username1: dataList[i].scheduleWatchList[1].user.name,
  2042. shiftTime1: dataList[i].scheduleWatchList[1].shiftTime,
  2043. status: dataList[i].status.name
  2044. }
  2045. // dataline.push([exportdata]);
  2046. var rowLine = [];
  2047. angular.forEach(exportdata, function(keyfield) {
  2048. // angular.forEach(data,function(keyfield){
  2049. // if(data[keyfield]){
  2050. rowLine.push(keyfield);
  2051. // }else{
  2052. // rowLine.push("");
  2053. // }
  2054. // })
  2055. // rowData.push(rowLine);
  2056. })
  2057. rowData.push(rowLine);
  2058. rowdata = rowData;
  2059. }
  2060. var csvdata = headers.join(',') + '\r\n';
  2061. // csvdata = csvdata + fieldHeaders.join(',') + '\r\n';
  2062. // csvdata = csvdata + fields.join(',') + '\r\n';
  2063. angular.forEach(rowData, function(line) {
  2064. csvdata = csvdata + line.join(',') + '\r\n';
  2065. })
  2066. csvdata = "\ufeff" + csvdata;
  2067. var file = new Blob([csvdata], {
  2068. type: 'application/csv;charset=utf-8'
  2069. });
  2070. // var filename = $scope.ciclassify.label;
  2071. var fileURL = URL.createObjectURL(file);
  2072. var a = document.createElement('a');
  2073. a.href = fileURL;
  2074. a.target = '_blank';
  2075. a.download = "交接班记录" + '.csv';
  2076. document.body.appendChild(a);
  2077. a.click();
  2078. // }
  2079. $scope.ldloading.expand_right = false;
  2080. // },function(){
  2081. // $scope.ldloading.expand_right = false;
  2082. })
  2083. // }else{
  2084. // SweetAlert.swal({
  2085. // title: "参数不合法!",
  2086. // text: "参数不合法,请选择没有子类的配置项导出!",
  2087. // type: "error"
  2088. // });
  2089. // }
  2090. // }else{
  2091. // SweetAlert.swal({
  2092. // title: "参数不合法!",
  2093. // text: "参数不合法,请选择需要导出的配置项分类!",
  2094. // type: "error"
  2095. // });
  2096. // }
  2097. }
  2098. $scope.today = function() {
  2099. $scope.dt = new Date();
  2100. };
  2101. $scope.today();
  2102. $scope.clear = function() {
  2103. $scope.dt = null;
  2104. };
  2105. // Disable weekend selection
  2106. $scope.disabled = function(date, mode) {
  2107. return (mode === 'day' && (date.getDay() === 0 || date.getDay() === 6));
  2108. };
  2109. // $scope.toggleMin = function () {
  2110. // $scope.minDate = $scope.minDate ? null : new Date();
  2111. // };
  2112. // $scope.toggleMin();
  2113. $scope.open = function($event) {
  2114. $event.preventDefault();
  2115. $event.stopPropagation();
  2116. $scope.opened = !$scope.opened;
  2117. };
  2118. $scope.endOpen = function($event) {
  2119. $event.preventDefault();
  2120. $event.stopPropagation();
  2121. $scope.startOpened = false;
  2122. $scope.endOpened = !$scope.endOpened;
  2123. };
  2124. $scope.startOpen = function($event) {
  2125. $event.preventDefault();
  2126. $event.stopPropagation();
  2127. $scope.endOpened = false;
  2128. $scope.startOpened = !$scope.startOpened;
  2129. };
  2130. $scope.dateOptions = {
  2131. formatYear: 'yy',
  2132. startingDay: 1
  2133. };
  2134. $scope.formats = ['dd-MMMM-yyyy', 'yyyy/MM/dd', 'dd.MM.yyyy', 'shortDate'];
  2135. $scope.format = $scope.formats[1];
  2136. $scope.hstep = 1;
  2137. $scope.mstep = 15;
  2138. // Time Picker
  2139. $scope.options = {
  2140. hstep: [1, 2, 3],
  2141. mstep: [1, 5, 10, 15, 25, 30]
  2142. };
  2143. $scope.ismeridian = true;
  2144. $scope.toggleMode = function() {
  2145. $scope.ismeridian = !$scope.ismeridian;
  2146. };
  2147. $scope.update = function() {
  2148. var d = new Date();
  2149. d.setHours(14);
  2150. d.setMinutes(0);
  2151. $scope.dt = d;
  2152. };
  2153. $scope.changed = function() {
  2154. $log.log('Time changed to: ' + $scope.dt);
  2155. };
  2156. $scope.clear = function() {
  2157. $scope.dt = null;
  2158. };
  2159. var defaultFilterData = {
  2160. "idx": 0,
  2161. "sum": 10
  2162. };
  2163. $scope.ldloading = {};
  2164. $scope.refreshData = function(style, filterData) {
  2165. // $scope.ldloading[style.replace('-', '_')] = true;
  2166. if (angular.isUndefined(filterData)) {
  2167. filterData = defaultFilterData;
  2168. }
  2169. if (angular.isDefined($scope.searchTypes)) {
  2170. filterData['searchType'] = $scope.searchTypes;
  2171. }
  2172. $scope.myData = [];
  2173. api_bpm_schedule.querySwitch(filterData).then(function(data) {
  2174. var myData = Restangular.stripRestangular(data);
  2175. $scope.gridOptions.totalItems = myData.totalNum;
  2176. $scope.myData = myData.list;
  2177. // $scope.ldloading[style.replace('-', '_')] = false;
  2178. }, function() {
  2179. // $scope.ldloading[style.replace('-', '_')] = false;
  2180. });
  2181. };
  2182. $scope.refreshData('expand-right', defaultFilterData);
  2183. $scope.refresh = function(style, filterData) {
  2184. // $scope.ldloading[style.replace('-', '_')] = true;
  2185. if (angular.isUndefined(filterData)) {
  2186. filterData = defaultFilterData;
  2187. }
  2188. if (angular.isDefined($scope.searchTypes)) {
  2189. filterData['searchType'] = $scope.searchTypes;
  2190. }
  2191. $scope.myData = [];
  2192. api_bpm_schedule.query(filterData).then(function(data) {
  2193. var myData = Restangular.stripRestangular(data);
  2194. $scope.gridOptions.totalItems = myData.totalNum;
  2195. $scope.myData = myData.list;
  2196. // $scope.ldloading[style.replace('-', '_')] = false;
  2197. }, function() {
  2198. // $scope.ldloading[style.replace('-', '_')] = false;
  2199. });
  2200. };
  2201. }]);
  2202. // delete-event-html="'<i class=\'glyphicon glyphicon-remove\'></i>'"
  2203. // edit-event-html="'<i class=\'glyphicon glyphicon-pencil\'></i>'"