list.js 20 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539
  1. 'use strict';
  2. var app = angular.module('app', [
  3. 'angularUtils.directives.dirPagination'
  4. ]);
  5. app.controller("listCtrl", ["$scope", "$http", "$timeout", "$interval", function ($scope, $http, $timeout, $interval) {
  6. var self = this;
  7. var s4 = new SM4Util();
  8. self.userId = $.cookie("GlWorkPlatform-userid");
  9. self.userName = $.cookie("GlWorkPlatform-chineseName");
  10. self.get_AccessToken = localStorage.getItem("GlWorkPlatform-AccessToken");
  11. self.deviceType = localStorage.getItem("tjJxtGoldenlinkWork-deviceType");
  12. self.get_lastReturnPageno = sp.getUrlName("lastReturnPageno");
  13. self.get_type = sp.getUrlName("type");
  14. self.params = sp.getUrlName("params");
  15. var postCfg = {
  16. headers: {
  17. 'Content-Type': 'application/json',
  18. 'Authorization': "Bearer " + self.get_AccessToken
  19. }
  20. }
  21. self.type = self.get_type != "" ? self.get_type : "todo";
  22. self.Url = getUrl(self.type);
  23. self.CrossPage = window.parent.CrossPage;
  24. self.loading = false;
  25. self.search = null//JSON.parse($.cookie("GlWorkPlatform-SJPSDB"));
  26. self.noDataTip = 1;//没有数据时赋变量为0,先默认为1
  27. self.pageno = 1;
  28. self.total_count = 0;
  29. self.itemsPerPage = 20;
  30. self.pageOptions = [10, 20, 30, 40, 50, 100, 300, 500];
  31. self.getBLJD = function () {
  32. var data = {
  33. ckey: "CODE_SJPSBLJD",
  34. routeinfoid: self.routeinfoid
  35. }
  36. $http.post(apiurljs.login + "g2app/abase/queryDataCode", { data: s4.encryptData_CBC(JSON.stringify(data)) }, postCfg)
  37. .success(function (obj) {
  38. var res = strToJson(s4.decryptData_CBC(obj.data));
  39. self.BLJD = res.data.CODE_SJPSBLJD;
  40. self.load()
  41. })
  42. }
  43. self.ordercondition = [];
  44. self.flowids = [{ ID: "AA1A", NAME: "委主要领导批示督办", checked: false }]
  45. self.getData = function (pageno) {
  46. if (self.search == null) {
  47. self.search = {
  48. FLOW: [],
  49. TITLE: "",
  50. CHDATE: "",
  51. DATE1: "",
  52. DATE2: "",
  53. SJPS: '',
  54. QPRQ: '',
  55. QTCS: ''
  56. }
  57. }
  58. var flowids = self.search.FLOW.join("|");
  59. var querycondition = [];
  60. var columnscondition = [
  61. { COLID: "CHDATE", COLUMNS: "SX_SJPSDU.TO_CHAR(CHDATE)" },
  62. { COLID: "SJPS", COLUMNS: "SX_SJPSDU.SJPS" },
  63. { COLID: "QPRQ", COLUMNS: "SX_SJPSDU.TO_CHAR(QPRQ)" },
  64. { COLID: "QTCS", COLUMNS: "SX_SJPSDU.QTCS" },
  65. { COLID: "DBSX", COLUMNS: "SX_SJPSDU.DBSX" },
  66. { COLID: "BLJD", COLUMNS: "SX_SJPSDU.BLJD" }
  67. ]
  68. if (self.search.TITLE != "") {
  69. querycondition.push({ "CKIND": "VARCHAR", "TABLEID": "SYS_ROUTE_VIEW", "COLID": "TITLE", "VALUEA": self.search.TITLE, "VALUEB": "" })
  70. }
  71. if (self.search.CHDATE != "") {
  72. querycondition.push({ "CKIND": "VARCHAR", "TABLEID": "CODETABLE", "COLID": "CHDATE", "VALUEA": self.search.CHDATE, "VALUEB": "" })
  73. }
  74. if (self.search.SJPS != "") {
  75. querycondition.push({ "CKIND": "VARCHAR", "TABLEID": "CODETABLE", "COLID": "SJPS", "VALUEA": self.search.SJPS, "VALUEB": "" })
  76. }
  77. if (self.search.QPRQ != "") {
  78. querycondition.push({ "CKIND": "VARCHAR", "TABLEID": "CODETABLE", "COLID": "QPRQ", "VALUEA": self.search.QPRQ, "VALUEB": "" })
  79. }
  80. if (self.search.QTCS != "") {
  81. querycondition.push({ "CKIND": "VARCHAR", "TABLEID": "CODETABLE", "COLID": "QTCS", "VALUEA": self.search.QTCS, "VALUEB": "" })
  82. }
  83. if (self.params != "") {
  84. querycondition.push({ "CKIND": "VARLIST", "TABLEID": "SYS_ROUTE", "COLID": "ROUTEID", "VALUEA": self.params, "VALUEB": "" })
  85. }
  86. if (self.search.DATE1 != "" && self.search.DATE2 != "") {
  87. querycondition.push({ "CKIND": "DATETIME", "TABLEID": "SYS_ROUTE_VIEW", "COLID": "RECEIVEDATE", "VALUEA": self.search.DATE1, "VALUEB": self.search.DATE2 })
  88. } else if (self.search.DATE1 != "" && self.search.DATE2 == "") {
  89. querycondition.push({ "CKIND": "DATETIME", "TABLEID": "SYS_ROUTE_VIEW", "COLID": "RECEIVEDATE", "VALUEA": self.search.DATE1, "VALUEB": ""})
  90. } else if (self.search.DATE1 == "" && self.search.DATE2 != "") {
  91. querycondition.push({ "CKIND": "DATETIME", "TABLEID": "SYS_ROUTE_VIEW", "COLID": "RECEIVEDATE", "VALUEA": "", "VALUEB": self.search.DATE2 })
  92. }
  93. self.list = [];
  94. self.loading = true;
  95. self.pageno = pageno;
  96. $scope.__default__currentPage = self.pageno; //设置页面样式在第几页
  97. var data = {
  98. flowid: flowids == "" ? "AA1A" : flowids,
  99. userid: self.userId,
  100. pageno: self.pageno,
  101. pagesize: self.itemsPerPage,
  102. columnscondition: JSON.stringify(columnscondition),
  103. querycondition: JSON.stringify(querycondition),
  104. ordercondition: self.ordercondition.length == 0 ? "" : JSON.stringify(self.ordercondition)
  105. }
  106. //$http.post(apiurljs.login + "g2work/routeinfo/" + self.Url, { data: s4.encryptData_CBC(JSON.stringify(data)) }, postCfg)
  107. $http.post(apiurljs.login + "g2work/routeinfo/" + self.Url, data, postCfg)
  108. .success(function (obj) {
  109. var res = obj;
  110. //var res = strToJson(s4.decryptData_CBC(obj.data));
  111. self.loading = false;
  112. if (res.data == null || res.data == undefined || res.data == "") {
  113. self.noDataTip = 0;
  114. if (self.params != "") {
  115. self.params = "";
  116. self.getData(1)
  117. }
  118. } else {
  119. self.noDataTip = 1;
  120. self.list = res.data;
  121. self.total_count = res.totalCount;
  122. $.each(self.list, function (index, item) {
  123. item.CHDATE = sp.format(item.CHDATE);
  124. item.QPRQ = sp.format(item.QPRQ);
  125. item.DBSX = sp.format(item.DBSX);
  126. self.BLJD.forEach(function (item1) {
  127. if (item.BLJD == item1.CODE)
  128. item.BLJD = item1.CNAME
  129. })
  130. if (item.FILEN != "") {
  131. item.FILEN = item.FILEN.indexOf("dotype") > -1 ? item.FILEN.replace("dotype=1", "dotype=" + getDoType(self.type)) + "&type=" + self.type + "&lastReturnPageno=" + self.pageno + "&flowid=" + item.FLOWID : item.FILEN + "&dotype=" + getDoType(self.type) + "&type=" + self.type + "&lastReturnPageno=" + self.pageno + "&flowid=" + item.FLOWID;
  132. } else {
  133. item.FILEN = "#";
  134. }
  135. if (self.type == "finish") {
  136. item.RECEIVEDATE = item.FINISHEDDATE;
  137. }
  138. })
  139. }
  140. })
  141. }
  142. self.load = function () {
  143. if (self.get_lastReturnPageno == undefined || self.get_lastReturnPageno == null || self.get_lastReturnPageno == "") {
  144. self.getData(self.pageno);
  145. } else {
  146. $timeout(function () {
  147. self.getData(self.get_lastReturnPageno);
  148. }, 1)
  149. }
  150. }
  151. self.sortFiled = function (str) {
  152. var n = 0, obj, x = -1;
  153. self.ordercondition.forEach(function (item, index) {
  154. if (item.COLID == str) {
  155. n++
  156. item.SORTTYPE = item.SORTTYPE == "" || item.SORTTYPE == "asc" ? "desc" : "asc"
  157. obj = item; x = index
  158. }
  159. })
  160. if (n == 0) {
  161. self.ordercondition.unshift({ COLID: str, SORTTYPE: "desc" })
  162. }
  163. if (x != -1) {
  164. self.ordercondition.splice(x, 1)
  165. self.ordercondition.unshift(obj)
  166. }
  167. self.getData(1);
  168. }
  169. self.getBLJD();
  170. self.openLayer = function () {
  171. self.params = "";
  172. if (self.search == null) {
  173. self.search = {
  174. FLOW: [],
  175. TITLE: "",
  176. CHDATE: "",
  177. DATE1: "",
  178. DATE2: "",
  179. SJPS: '',
  180. QPRQ: '',
  181. QTCS: ''
  182. }
  183. } else {
  184. self.flowids.forEach(function (item) {
  185. item.checked = false;
  186. if (self.search.FLOW.indexOf(item.ID) > -1) {
  187. item.checked = true;
  188. }
  189. })
  190. }
  191. sp.layer("#Search")
  192. }
  193. self.doSearch = function () {
  194. self.search.FLOW = [];
  195. self.flowids.forEach(function (item) {
  196. if (item.checked == true) {
  197. self.search.FLOW.push(item.ID)
  198. }
  199. })
  200. self.getData(self.pageno)
  201. sp.layerhide()
  202. }
  203. self.cancal = function () {
  204. self.search = {
  205. FLOW: [],
  206. TITLE: "",
  207. CHDATE: "",
  208. DATE1: "",
  209. DATE2: "",
  210. SJPS: '',
  211. QPRQ: '',
  212. QTCS: ''
  213. }
  214. $.cookie("GlWorkPlatform-SJPSDB", null, { path: '/', expires: 1 });
  215. self.getData(1)
  216. sp.layerhide()
  217. }
  218. self.refresh = function () {
  219. self.CrossPage.type = null;
  220. self.getData(self.pageno);
  221. }
  222. self.goUrl = function (item) {
  223. if (item.TODOLIST && item.TODOLIST.length > 1) {
  224. self.todoTitle = item.TITLE;
  225. self.todoList = item.TODOLIST;
  226. sp.layer("#todolist")
  227. } else {
  228. if (self.deviceType == "pad") {
  229. window.location.href = item.FILEN + "&dotype=" + getDoType(self.type)
  230. } else {
  231. sp.openNewWindow(item.FILEN + "&dotype=" + getDoType(self.type), item.TITLE)
  232. }
  233. sp.layerhide();
  234. }
  235. }
  236. self.btnDel = function (item) {
  237. var data = {
  238. routeinfoid: item.ROUTEINFOID,
  239. userid: self.userId
  240. }
  241. $http.post(apiurljs.login + "g2work/routeinfo/deleteDraftByRouteinfoid", { data: s4.encryptData_CBC(JSON.stringify(data)) }, postCfg)
  242. .success(function (obj) {
  243. var res = strToJson(s4.decryptData_CBC(obj.data));
  244. if (res.success == true) {
  245. self.getData(self.pageno)
  246. } else {
  247. sp.dialog(res.message)
  248. }
  249. })
  250. }
  251. self.btnRecall = function (routeid,kind) {
  252. var data = {
  253. routeid: routeid,
  254. kind:kind,
  255. userid: self.userId
  256. }
  257. $http.post(apiurljs.login + "g2work/routeinfo/queryDataRecallDoneByRouteid", { data: s4.encryptData_CBC(JSON.stringify(data)) }, postCfg)
  258. .success(function (obj) {
  259. var res = strToJson(s4.decryptData_CBC(obj.data));
  260. var dialogHead = "<span class=\"sp-dialog-head\"><span class=\"sp-dialog-tip\">温馨提示</span><span class=\"sp-dialog-close sp-closeDialog\" title=\"关闭\">×</span></span>";
  261. var dialogBody = "<div class=\"sp-dialog-body\">" + res.data.REMARK + "</div>";
  262. var dialogFoot = "<div class=\"sp-dialog-foot\"><input id='delDataTrue' type='button' value='撤 回' class='sp-dialog-btnTrue' /><input type='button' value='取 消' class='sp-dialog-btnCancle sp-closeDialog' /></div>";
  263. $('.sp-dialog').html(dialogHead + dialogBody + dialogFoot);
  264. sp.openCenter(".sp-dialog");
  265. ///取消按钮
  266. $('.sp-closeDialog').click(function (event) {
  267. sp.closeCenter(".sp-dialog");
  268. event.preventDefault();
  269. event.stopPropagation();
  270. });
  271. //post消息的id
  272. $("#delDataTrue").click(function () {
  273. $http.post(apiurljs.login + "g2work/routeinfo/recallDoneByRouteid", { data: s4.encryptData_CBC(JSON.stringify(data)) }, postCfg)
  274. .success(function (obj) {
  275. var res = strToJson(s4.decryptData_CBC(obj.data));
  276. sp.dialoghide()
  277. if (res.success == true) {
  278. self.getData(self.pageno)
  279. } else {
  280. sp.dialog(res.message)
  281. }
  282. })
  283. });
  284. })
  285. }
  286. self.changeType = function (str) {
  287. if (self.type == str) {
  288. return;
  289. } else {
  290. var time1 = sp.getLocalDate1();
  291. self.journalRecord(time1, sp.getLocalDate1(), "查询", "查询日志", "/g2work/routeinfo/" + self.Url)
  292. self.type = str;
  293. self.Url = getUrl(self.type);
  294. self.getData(1)
  295. }
  296. }
  297. self.getAddFlag = function () {
  298. var data = {
  299. userid: self.userId,
  300. ntops: 0
  301. }
  302. $http.post(apiurljs.login + "g2work/desktop/queryWorkflowCando", data, postCfg)
  303. .success(function (obj) {
  304. var res = strToJson(s4.decryptData_CBC(obj.data));
  305. self.lcList = [];
  306. self.activeLC = {};
  307. res.data.forEach(function (item) {
  308. if ("AA1A".indexOf(item.FLOWID) > -1) {
  309. self.lcList.push(item);
  310. }
  311. })
  312. })
  313. }
  314. self.getAddFlag()
  315. self.addLC = function () {
  316. if (self.lcList.length == 1) {
  317. sp.openNewWindow(self.lcList[0].FILEN + "&dotype=1&flowid=" + self.lcList[0].FLOWID, self.lcList[0].FLOWNAME)
  318. } else {
  319. sp.layer("#addLC");
  320. }
  321. }
  322. self.seeLCT = function (item,event) {
  323. event.preventDefault();
  324. event.stopPropagation();
  325. }
  326. self.goAddUrl = function (obj) {
  327. sp.openNewWindow(obj.FILEN + "&dotype=1&flowid=" + obj.FLOWID, obj.FLOWNAME)
  328. sp.layerhide()
  329. }
  330. self.printEXCEL = function () {
  331. self.columns = [
  332. { header: "文件/会议名称", key: "TITLE", width: 100 },
  333. { header: "来文/参会日期", key: "CHDATE", width: 20 },
  334. { header: "委主要领导批示", key: "SJPS", width: 20 },
  335. { header: "签批日期", key: "QPRQ", width: 20 },
  336. { header: "牵头处室", key: "QTCS", width: 20 },
  337. { header: "督办时限", key: "DBSX", width: 20 },
  338. { header: "办理进度", key: "BLJD", width: 25 }
  339. ]
  340. self.listExcel = self.list.map(function (item) {
  341. return {
  342. TITLE: item.TITLE,
  343. CHDATE: item.CHDATE,
  344. SJPS: item.SJPS,
  345. QPRQ: item.QPRQ,
  346. QTCS: item.QTCS,
  347. DBSX: item.DBSX,
  348. BLJD: item.BLJD
  349. }
  350. })
  351. // 创建工作簿
  352. var workbook = new ExcelJS.Workbook()
  353. // 添加工作表
  354. var worksheet = workbook.addWorksheet('sheet1')
  355. // 设置表头
  356. worksheet.columns = self.columns
  357. // 添加表体数据
  358. self.listExcel.forEach(function (item) {
  359. worksheet.addRow(item)
  360. })
  361. /**
  362. * 设置样式
  363. */
  364. // 1、设置标题行样式
  365. var headerRow = worksheet.getRow(1)
  366. // 连续遍历所有非空单元格
  367. headerRow.eachCell(function (cell) {
  368. // 边框 https://github.com/exceljs/exceljs/blob/HEAD/README_zh.md#%E8%BE%B9%E6%A1%86
  369. cell.border = {
  370. top: {
  371. style: 'thin'
  372. },
  373. left: {
  374. style: 'thin'
  375. },
  376. bottom: {
  377. style: 'thin'
  378. },
  379. right: {
  380. style: 'thin'
  381. },
  382. }
  383. // 填充 https://github.com/exceljs/exceljs/blob/HEAD/README_zh.md#%E5%A1%AB%E5%85%85
  384. cell.fill = {
  385. type: 'pattern',
  386. pattern: 'solid',
  387. fgColor: {
  388. argb: '4f81bd'
  389. }
  390. }
  391. // 字体 https://github.com/exceljs/exceljs/blob/HEAD/README_zh.md#%E5%AD%97%E4%BD%93
  392. cell.font = {
  393. name: '微软雅黑',
  394. size: 11,
  395. bold: true,
  396. color: { argb: '000000' }
  397. }
  398. // 对齐 https://github.com/exceljs/exceljs/blob/HEAD/README_zh.md#%E5%AF%B9%E9%BD%90
  399. cell.alignment = {
  400. vertical: 'middle',
  401. horizontal: 'center'
  402. }
  403. })
  404. // 2、设置内容行样式
  405. const bodyRow = worksheet.getRows(2, self.listExcel.length + 1)
  406. bodyRow.forEach(function (row) {
  407. //遍历此列中的所有当前单元格,包括空单元格
  408. row.eachCell({ includeEmpty: true }, function (cell) {
  409. // 边框
  410. cell.border = {
  411. top: {
  412. style: 'thin'
  413. },
  414. left: {
  415. style: 'thin'
  416. },
  417. bottom: {
  418. style: 'thin'
  419. },
  420. right: {
  421. style: 'thin'
  422. },
  423. }
  424. // 字体 https://github.com/exceljs/exceljs/blob/HEAD/README_zh.md#%E5%AD%97%E4%BD%93
  425. cell.font = {
  426. name: '微软雅黑',
  427. size: 11,
  428. color: { argb: '000000' }
  429. }
  430. // 对齐 https://github.com/exceljs/exceljs/blob/HEAD/README_zh.md#%E5%AF%B9%E9%BD%90
  431. cell.alignment = {
  432. vertical: 'middle',
  433. horizontal: 'center'
  434. }
  435. })
  436. })
  437. // 导出表格
  438. workbook.xlsx.writeBuffer().then(function (buffer) {
  439. const blob = new Blob([buffer], {
  440. type: 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet'
  441. })
  442. const link = document.createElement('a')
  443. link.href = URL.createObjectURL(blob)
  444. link.download = '书记批示督办' + sp.format(sp.getLocalDate()) + '.xlsx'
  445. link.click()
  446. URL.revokeObjectURL(link.href) // 下载完成释放掉blob对象
  447. })
  448. //})
  449. }
  450. //记录日志
  451. self.journalRecord = function (time1, time2, title, func, url) {
  452. if (!self.CrossPage || !self.CrossPage.cname) { return; }
  453. var data = {
  454. tablename: "SYS_CLICKLOG",
  455. data: {
  456. CTIME: time1 == null ? sp.getLocalDate1() : time1,
  457. TITLE: (title != "" ? self.CrossPage.cname + "/" + title : self.CrossPage.cname),
  458. REQUESTURL: url,
  459. REQUESTHEADERURL: window.location.origin,
  460. LOGTYPE: func,
  461. USERTYPE: $.cookie("GlWorkPlatform-userType"),
  462. ADMIN: $.cookie("GlWorkPlatform-userTypeEng"),
  463. CLIENTIP: sp.myIP(),
  464. PCNAME: sp.detectOS(),
  465. BROWSERNAME: sp.browser(),
  466. RESPONSETIME: time2 == null ? sp.getLocalDate1() : time2,
  467. USERID: self.userId,
  468. USERNAME: self.userName
  469. }
  470. }
  471. $http.post(apiurljs.login + "g2app/dataabase/insertFormData", { data: s4.encryptData_CBC(JSON.stringify(data)) }, postCfg)
  472. .success(function (res) {
  473. self.CrossPage.type = 1;
  474. })
  475. }
  476. var width = 0, height = 0;
  477. $interval(function () {
  478. if (localStorage.getItem("GlWorkPlatform-SJPSDB-refresh") == 1) {
  479. localStorage.removeItem("GlWorkPlatform-SJPSDB-refresh")
  480. self.refresh()
  481. }
  482. }, 1000)
  483. //头部下滚冻结
  484. $(function () {
  485. width = window.outerWidth;
  486. height = window.outerHeight;
  487. //页面高度撑满
  488. setTimeout(function () {
  489. if ($(".ibox-content").height() < $(window).height() - 31) {
  490. $(".ibox-content").css("height", $(window).height() - 31)
  491. }
  492. }, 1)
  493. })
  494. }])
  495. function getUrl(str) {
  496. switch (str) {
  497. case "todo":
  498. return "queryDataTodoWithPage";
  499. break;
  500. case "done":
  501. return "queryDataDoneWithPage";
  502. break;
  503. case "finish":
  504. return "queryDataFinishWithPage";
  505. break;
  506. }
  507. }
  508. function getDoType(str) {
  509. switch (str) {
  510. case "todo":
  511. return 1;
  512. break;
  513. default:
  514. return 0;
  515. break;
  516. }
  517. }