list.js 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409
  1. 'use strict';
  2. var app = angular.module('app', [
  3. 'angularUtils.directives.dirPagination'
  4. ]);
  5. app.controller("taizhangCtrl", ["$scope", "$http", "$timeout", function ($scope, $http, $timeout) {
  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.get_lastReturnPageno = sp.getUrlName("lastReturnPageno");
  12. var postCfg = {
  13. headers: {
  14. 'Content-Type': 'application/json',
  15. 'Authorization': "Bearer " + self.get_AccessToken
  16. }
  17. }
  18. self.loading = false;
  19. self.search = JSON.parse($.cookie("GlWorkPlatform-yzaptz")) || { DATE1: sp.getWeekNumber(new Date()).begin, DATE2: sp.getWeekNumber(new Date()).end };
  20. self.getData = function () {
  21. self.list = [];
  22. self.loading = false;
  23. var data = {
  24. tablename: "SX_YZAPTZ",
  25. colums: "*,TO_CHAR(YZAPDATE,'yyyy-mm-dd')as YZAPDATE1,TO_CHAR(CTIME,'hh24:mi')as CTIME1",
  26. order: "CTIME",
  27. sqlwhere: " and YZAPDATE BETWEEN '" + self.search.DATE1 + " 00:00:00' AND '" + self.search.DATE2 + " 23:59:59' and USERID='" + self.userId + "'"
  28. }
  29. $http.post(apiurljs.login + "g2app/dataabase/queryDataByColStr", { data: s4.encryptData_CBC(JSON.stringify(data)) }, postCfg)
  30. .success(function (obj) {
  31. var res = strToJson(s4.decryptData_CBC(obj.data));
  32. self.loading = false;
  33. self.addFlag = false;
  34. self.editFlag = false;
  35. self.addList = [];
  36. self.list = res.data;
  37. self.list.forEach(function (item) {
  38. item.CNAME == "null" ? "" : item.CNAME
  39. item.ATTENDANCESCOPE == "null" ? "" : item.ATTENDANCESCOPE
  40. item.ADDR == "null" ? "" : item.ADDR
  41. item.TIMEPERIOD1 = item.TIMEPERIOD;
  42. item.CTIME2 = item.CTIME1;
  43. item.CNAME1 = item.CNAME;
  44. item.ATTENDANCESCOPE1 = item.ATTENDANCESCOPE;
  45. item.ADDR1 = item.ADDR;
  46. })
  47. console.log(self.list)
  48. })
  49. }
  50. self.getData();
  51. self.openLayer = function () {
  52. sp.layer("#Search")
  53. }
  54. self.doSearch = function () {
  55. sp.layerhide()
  56. if (self.search.DATE1 == "" || self.search.DATE2 == "") {
  57. sp.dialog("时间为可为空!");
  58. return
  59. }
  60. $.cookie("GlWorkPlatform-yzaptz", JSON.stringify(self.search), { path: '/', expires: 1 });
  61. self.getData();
  62. }
  63. self.cancal = function () {
  64. self.search = {
  65. DATE1: sp.getWeekNumber(new Date()).begin,
  66. DATE2: sp.getWeekNumber(new Date()).end
  67. }
  68. $.cookie("GlWorkPlatform-yzaptz", null, { path: '/', expires: 1 });
  69. self.getData();
  70. sp.layerhide()
  71. }
  72. self.refresh = function () {
  73. self.getData();
  74. }
  75. self.openInit = function () {
  76. self.init = {
  77. DATE1: sp.getWeekNumber(new Date()).begin, DATE2: sp.getWeekNumber(new Date()).end
  78. }
  79. sp.layer("#Init")
  80. }
  81. self.doInit = function () {
  82. var data = {
  83. userid: self.userId,
  84. routeinfoid: 0,
  85. startdate: self.init.DATE1 + " 00:00:00",
  86. enddate: self.init.DATE2 + " 23:59:59"
  87. }
  88. $http.post(apiurljs.login + "g2app/richang/initYZAPTZList", { data: s4.encryptData_CBC(JSON.stringify(data)) }, postCfg)
  89. .success(function (obj) {
  90. var res = strToJson(s4.decryptData_CBC(obj.data));
  91. sp.layerhide();
  92. if (res.success) {
  93. self.getData();
  94. } else {
  95. sp.dialog(res.message)
  96. }
  97. })
  98. }
  99. self.addItem = function () {
  100. self.addFlag = true;
  101. self.addList.push({
  102. YZAPDATE: sp.format(sp.getLocalDate()),
  103. CWEEK: weeks[new Date().getDay()],
  104. TIMEPERIOD: "上午",
  105. CTIME: "09:00",
  106. CNAME: "",
  107. ATTENDANCESCOPE: "",
  108. ADDR: ""
  109. })
  110. $timeout(function () {
  111. $(".table-scroll").scrollTop($(".table-scroll").find("table").height())
  112. }, 1)
  113. }
  114. self.delItem = function (item) {
  115. var dialogHead = "<span class=\"sp-dialog-head\"><span class=\"sp-dialog-tip\">温馨提示</span><span class=\"sp-dialog-close sp-closeDialog\" title=\"关闭\">×</span></span>";
  116. var dialogBody = "<div class=\"sp-dialog-body\">删除后不可恢复,您确认要删除吗?</div>";
  117. 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>";
  118. $('.sp-dialog').html(dialogHead + dialogBody + dialogFoot);
  119. sp.openCenter(".sp-dialog");
  120. ///取消按钮
  121. $('.sp-closeDialog').click(function (event) {
  122. sp.closeCenter(".sp-dialog");
  123. event.preventDefault();
  124. event.stopPropagation();
  125. });
  126. //post消息的id
  127. $("#delDataTrue").click(function () {
  128. var data = {
  129. tablename: "SX_YZAPTZ",
  130. id: item.ID
  131. };
  132. $http.post(apiurljs.login + "g2app/dataabase/delDataById", { data: s4.encryptData_CBC(JSON.stringify(data)) }, postCfg)
  133. .success(function (obj) {
  134. var res = strToJson(s4.decryptData_CBC(obj.data));
  135. sp.dialoghide();
  136. if (res.success) {
  137. self.getData();
  138. } else {
  139. sp.dialog("删除失败,请联系管理员!");
  140. }
  141. });
  142. });
  143. }
  144. var weeks = ["星期日", "星期一", "星期二", "星期三", "星期四", "星期五", "星期六"]
  145. self.changeCtime = function (obj, n) {
  146. if (n == 0) {
  147. if (obj.CTIME >= "13:00") {
  148. obj.TIMEPERIOD = "下午"
  149. } else {
  150. obj.TIMEPERIOD = "上午"
  151. }
  152. } else {
  153. if (obj.CTIME2 >= "13:00") {
  154. obj.TIMEPERIOD1 = "下午"
  155. } else {
  156. obj.TIMEPERIOD1 = "上午"
  157. }
  158. }
  159. obj.CWEEK = weeks[new Date(obj.YZAPDATE).getDay()]
  160. }
  161. self.btnCancal = function () {
  162. self.addFlag = false;
  163. self.addList = []
  164. self.editFlag = false;
  165. self.list.forEach(function (item) {
  166. item.TIMEPERIOD1 = item.TIMEPERIOD;
  167. item.CTIME2 = item.CTIME1;
  168. item.CNAME1 = item.CNAME;
  169. item.ATTENDANCESCOPE1 = item.ATTENDANCESCOPE;
  170. item.ADDR1 = item.ADDR;
  171. })
  172. }
  173. self.btnSave = function () {
  174. var n1 = true, n2 = true;
  175. if (self.addList.length > 0) {
  176. n1 = false;
  177. var data1 = {
  178. tablename: "SX_YZAPTZ",
  179. data: []
  180. }
  181. self.addList.forEach(function (item) {
  182. data1.data.push({
  183. YZAPDATE: item.YZAPDATE,
  184. TIMEPERIOD: item.TIMEPERIOD,
  185. CWEEK: item.CWEEK,
  186. CTIME: item.YZAPDATE + " " + item.CTIME + ":00",
  187. CNAME: item.CNAME,
  188. ATTENDANCESCOPE: item.ATTENDANCESCOPE,
  189. ADDR: item.ADDR,
  190. USERID: self.userId,
  191. SECTCODE: self.userDpCode,
  192. CDATE: sp.getLocalDate()
  193. })
  194. })
  195. $http.post(apiurljs.login + "g2app/dataabase/insertDataList", { data: s4.encryptData_CBC(JSON.stringify(data1)) }, postCfg)
  196. .success(function (obj) {
  197. var res = strToJson(s4.decryptData_CBC(obj.data));
  198. if (res.success == true) {
  199. n1 = true;
  200. if (self.list.length > 0) {
  201. n2 = false;
  202. var data2 = {
  203. entity: "SX_YZAPTZ",
  204. data: [],
  205. setwhere: []
  206. }
  207. self.list.forEach(function (item) {
  208. data2.data.push({
  209. TIMEPERIOD: item.TIMEPERIOD1,
  210. CTIME: item.YZAPDATE1 + " " + item.CTIME2 + ":00",
  211. CNAME: item.CNAME1,
  212. ATTENDANCESCOPE: item.ATTENDANCESCOPE1,
  213. ADDR: item.ADDR1
  214. })
  215. data2.setwhere.push({ ID: item.ID })
  216. })
  217. $http.post(apiurljs.login + "g2app/Data/UpdataByWhereList", { data: s4.encryptData_CBC(JSON.stringify(data2)) }, postCfg)
  218. .success(function (obj1) {
  219. var res1 = strToJson(s4.decryptData_CBC(obj1.data));
  220. if (res1.success == true) {
  221. n2 = true;
  222. if (n1 == true && n2 == true) {
  223. self.getData();
  224. sp.dialog("保存成功!");
  225. $timeout(function () {
  226. sp.dialoghide();
  227. }, 1500)
  228. }
  229. } else {
  230. sp.dialog(res1.message)
  231. }
  232. })
  233. } else {
  234. if (n1 == true && n2 == true) {
  235. self.getData();
  236. sp.dialog("保存成功!");
  237. $timeout(function () {
  238. sp.dialoghide();
  239. }, 1500)
  240. }
  241. }
  242. } else {
  243. sp.dialog(res.message)
  244. }
  245. })
  246. } else {
  247. n2 = false;
  248. var data1 = {
  249. entity: "SX_YZAPTZ",
  250. data: [],
  251. setwhere: []
  252. }
  253. self.list.forEach(function (item) {
  254. data1.data.push({
  255. TIMEPERIOD: item.TIMEPERIOD1,
  256. CTIME: item.YZAPDATE1 + " " + item.CTIME2 + ":00",
  257. CNAME: item.CNAME1,
  258. ATTENDANCESCOPE: item.ATTENDANCESCOPE1,
  259. ADDR: item.ADDR1
  260. })
  261. data1.setwhere.push({ ID: item.ID })
  262. })
  263. $http.post(apiurljs.login + "g2app/Data/UpdataByWhereList", { data: s4.encryptData_CBC(JSON.stringify(data1)) }, postCfg)
  264. .success(function (obj) {
  265. var res = strToJson(s4.decryptData_CBC(obj.data));
  266. if (res.success == true) {
  267. n2 = true;
  268. if (n1 == true && n2 == true) {
  269. self.getData();
  270. sp.dialog("保存成功!");
  271. $timeout(function () {
  272. sp.dialoghide();
  273. }, 1500)
  274. }
  275. } else {
  276. sp.dialog(res.message)
  277. }
  278. })
  279. }
  280. }
  281. self.printOut = function () {
  282. if (self.canExportExcel) {
  283. $('#table td').attr('t', 's')
  284. var defaultCellStyle = {
  285. font: {
  286. name: 'Times New Roman',
  287. sz: 12,
  288. color: {
  289. rgb: "000000"
  290. },
  291. bold: false, italic: false,
  292. underline: false
  293. },
  294. alignment: {
  295. vertical: "center",
  296. horizontal: "center", indent: 0, wrapText: true
  297. },
  298. border: {
  299. top: {
  300. style: "thin",
  301. color: {
  302. rgb: "000000"
  303. }
  304. },
  305. right: {
  306. style: "thin",
  307. color: {
  308. rgb: "000000"
  309. }
  310. },
  311. bottom: {
  312. style: "thin",
  313. color: {
  314. rgb: "000000"
  315. }
  316. },
  317. left: {
  318. style: "thin",
  319. color: {
  320. rgb: "000000"
  321. }
  322. }
  323. }
  324. };
  325. var cell = { defaultCellStyle: defaultCellStyle };
  326. var wb = XLSX.utils.table_to_book_addtitle(document.querySelector('#table'), cell, "一周安排台账")
  327. //设置表格的样式
  328. var wbout = XLSX.write(wb, {
  329. bookType: 'xlsx',
  330. bookSST: false,
  331. type: 'binary',
  332. cellStyles: true,
  333. defaultCellStyle: defaultCellStyle,
  334. showGridLines: false
  335. });
  336. var s2ab = function (s) {
  337. var buf = new ArrayBuffer(s.length);
  338. var view = new Uint8Array(buf);
  339. for (var i = 0; i !== s.length; ++i) view[i] = s.charCodeAt(i) & 0xFF;
  340. return buf;
  341. };
  342. try {
  343. saveAs(new Blob([s2ab(wbout)], { type: 'application/octet-stream' }), '一周安排台账.xlsx')
  344. } catch (e) { if (typeof console !== 'undefined') console.log(e, wbout) }
  345. return wbout
  346. } else {
  347. sp.dialog('数据还未加载完成,请稍等...')
  348. }
  349. }
  350. //头部下滚冻结
  351. $(function () {
  352. //页面高度撑满
  353. setTimeout(function () {
  354. if ($(".ibox-content").height() < $(window).height() - 31) {
  355. $(".ibox-content").css("height", $(window).height() - 31)
  356. }
  357. }, 1)
  358. })
  359. }])
  360. app.directive("repeatFinish", function () {
  361. return {
  362. link: function (scope) {
  363. if (scope.$last == true) {
  364. scope.$parent.ctl.canExportExcel = true;
  365. setTimeout(function () {
  366. $("#table").rowspan(1)
  367. $("#table").rowspan(0)
  368. }, 10);
  369. }
  370. }
  371. };
  372. });
  373. jQuery.fn.rowspan = function (colIdx) { //封装的一个JQuery小插件
  374. return this.each(function () {
  375. var that;
  376. $('tr', this).each(function (row) {
  377. $('td:eq(' + colIdx + ')', this).filter(':visible').each(function (col) {
  378. if (that != null && $(this).html() == $(that).html()) {
  379. var rowspan = $(that).attr("rowSpan");
  380. if (rowspan == undefined) {
  381. $(that).attr("rowSpan", 1);
  382. rowspan = $(that).attr("rowSpan");
  383. }
  384. rowspan = Number(rowspan) + 1;
  385. $(that).attr("rowSpan", rowspan);
  386. $(this).remove();
  387. } else {
  388. that = this;
  389. }
  390. });
  391. });
  392. });
  393. }