export_view.js 9.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246
  1. 'use strict';
  2. /**
  3. *
  4. *
  5. * @author Zhong
  6. * @date 2019/6/5
  7. * @version
  8. */
  9. //导出接口相关
  10. const ExportView = (() => {
  11. let _base = XML_EXPORT_BASE,
  12. _cache = _base.CACHE,
  13. _util = _base.UTIL;
  14. // 导出数据缓存
  15. let _exportCache = [];
  16. //设置工程编号表格数据设置
  17. const sheetSetting = {
  18. header: [
  19. {headerName: '名称', headerWidth: 200, dataCode: 'name', dataType: 'String'},
  20. {headerName: '工程编号', headerWidth: 200, dataCode: 'code', dataType: 'String'},
  21. ],
  22. view: {
  23. lockColumns: ['name'],
  24. lockRows: [0]
  25. }
  26. };
  27. //操作状态
  28. const STATE = {
  29. checking: false, //自检
  30. exporting: false, //导出
  31. confirming: false //导出确认
  32. };
  33. let spread = null;
  34. //初始化设置工程编号表格
  35. function initSpread(datas) {
  36. if (spread) {
  37. return;
  38. }
  39. spread = SheetDataHelper.createNewSpread($("#exportSpread")[0], 1);
  40. sheetCommonObj.spreadDefaultStyle(spread);
  41. let sheet = spread.getSheet(0);
  42. sheetCommonObj.initSheet(sheet, sheetSetting, 30);
  43. sheet.setRowCount(datas.length);
  44. sheetCommonObj.showTreeData(sheet, sheetSetting, datas);
  45. }
  46. //获取设置的工程编号
  47. function getCodeFromSheet(sheet) {
  48. let codeCol = 1;
  49. let rst = [];
  50. //排除建设项目行
  51. for (let row = 1; row < sheet.getRowCount(); row++) {
  52. rst.push(sheet.getText(row, codeCol) || '');
  53. }
  54. return rst;
  55. }
  56. // 回到初始状态,需要清空cache中的数据
  57. function resetState() {
  58. _exportCache = [];
  59. _cache.clear();
  60. }
  61. // 设置提示高度样式
  62. function setHeightByInfo(infos) {
  63. if (infos.length * 20 > 400) {
  64. $('#hintBox_caption').addClass('export-check');
  65. }
  66. }
  67. // 显示工程编码设置窗口
  68. function showSetCodeModal(isPring) {
  69. if (isPring) {
  70. setTimeout(() => {
  71. $('#exportCode').modal('show');
  72. }, 300);
  73. } else {
  74. $('#exportCode').modal('show');
  75. }
  76. }
  77. //事件监听
  78. function exportListener() {
  79. //导出接口-项目自检
  80. $('#export-check').click(async function () {
  81. let failList = _cache.getItem('failList');
  82. let checkedDatas = $('#export input[type="checkbox"]:checked');
  83. if (!checkedDatas.length) {
  84. return;
  85. }
  86. if (STATE.checking) {
  87. return;
  88. }
  89. STATE.checking = true;
  90. let pr = new SCComponent.InitProgressBar();
  91. try {
  92. if (!_exportCache || !_exportCache.length) {
  93. pr.start('导出数据接口', '正在自检,请稍候……');
  94. for (let checkedData of checkedDatas) {
  95. let fileKind = parseInt($(checkedData).val());
  96. let exportData = await _base.extractExportData(XMLStandard.entry, _base.CONFIG.GRANULARITY.PROJECT,
  97. fileKind, projectObj.project.ID(), userID);
  98. _exportCache.push(...exportData);
  99. }
  100. }
  101. failList = _util.deWeightHints(failList);
  102. if (failList.length) {
  103. //设置提示弹窗
  104. setHeightByInfo(failList);
  105. throw failList.join('<br/>');
  106. }
  107. // 弱自检
  108. const infos = _util.softCheck();
  109. if (infos.length) {
  110. setHeightByInfo(infos);
  111. throw infos.join('<br/>');
  112. }
  113. throw '自检完成,未检测到错误数据。'
  114. } catch (err) {
  115. alert(err);
  116. }
  117. pr.end();
  118. setTimeout(() => {
  119. STATE.checking = false;
  120. }, 300);
  121. });
  122. //导出接口,如果没有错误,弹出工程编号设置窗口
  123. $('#export-confirm').click(async function () {
  124. let failList = _cache.getItem('failList');
  125. let checkedDatas = $('#export input[type="checkbox"]:checked');
  126. if (!checkedDatas.length) {
  127. return;
  128. }
  129. if (STATE.exporting) {
  130. return;
  131. }
  132. STATE.exporting = true;
  133. let pr = new SCComponent.InitProgressBar();
  134. try {
  135. let isPring = false; //是否调用了进度条(控制工程窗口什么时候显示,优化交互)
  136. if (!_exportCache || !_exportCache.length) {
  137. isPring = true;
  138. pr.start('导出数据接口', '正在导出文件,请稍候……');
  139. for (let checkedData of checkedDatas) {
  140. let fileKind = parseInt($(checkedData).val());
  141. let exportData = await _base.extractExportData(XMLStandard.entry, _base.CONFIG.GRANULARITY.PROJECT,
  142. fileKind, projectObj.project.ID(), userID);
  143. _exportCache.push(...exportData);
  144. }
  145. pr.end();
  146. }
  147. failList = _util.deWeightHints(failList);
  148. if (failList.length) {
  149. //错误-设置提示弹窗
  150. setHeightByInfo(failList);
  151. throw failList.join('<br/>');
  152. }
  153. // 如果没有自检过,需要进行弱自检,并且弹出的窗口包含“继续、取消”按钮
  154. const infos = _util.softCheck();
  155. if (infos.length) {
  156. const doYes = () => {
  157. showSetCodeModal(isPring);
  158. };
  159. hintBox.infoBox('系统提示', infos.join('<br/>'), hintBox.btnType.yesNo, doYes, null, ['继续', '取消']);
  160. setTimeout(() => {
  161. STATE.exporting = false;
  162. }, 300);
  163. return;
  164. }
  165. //弹出工程编号设置窗口
  166. showSetCodeModal(isPring);
  167. } catch (err) {
  168. console.log(err);
  169. pr.end();
  170. alert(err);
  171. }
  172. setTimeout(() => {
  173. STATE.exporting = false;
  174. }, 300);
  175. });
  176. //工程编号设置窗口-----
  177. //设置工程编号
  178. $('#exportCode').on('shown.bs.modal', function () {
  179. if (!_exportCache || !_exportCache.length) {
  180. alert('数据错误!');
  181. $(this).modal('hide');
  182. return false;
  183. }
  184. let projectData = _cache.getItem('projectData');
  185. initSpread(XML_EXPORT_BASE.UTIL.getCodeSheetData(projectData));
  186. });
  187. //设置完工程编号后,导出数据。如果选中多个文件,导出压缩包
  188. $('#exportCode-confirm').click(async function () {
  189. if (!spread || !_exportCache || !_exportCache.length) {
  190. return false;
  191. }
  192. if (STATE.confirming) {
  193. return;
  194. }
  195. STATE.confirming = true;
  196. let pr = new SCComponent.InitProgressBar();
  197. try {
  198. // 工程编号
  199. let codes = getCodeFromSheet(spread.getSheet(0));
  200. if (codes.includes('')) {
  201. alert('单项、单位工程工程编号不可为空。');
  202. STATE.confirming = false;
  203. return false;
  204. }
  205. if ([...new Set(codes)].length !== codes.length) {
  206. alert('单项、单位工程工程编号必须唯一。');
  207. STATE.confirming = false;
  208. return false;
  209. }
  210. pr.start('导出数据接口', '正在导出文件,请稍候……');
  211. // 导出文件
  212. await _base.exportFile(codes, _exportCache, XMLStandard.resetContentCode, XMLStandard.saveAsFile);
  213. } catch (err) {
  214. console.log(err);
  215. alert(err);
  216. }
  217. pr.end();
  218. $('#exportCode').modal('hide');
  219. $('#export').modal('hide');
  220. setTimeout(() => {
  221. STATE.confirming = false;
  222. }, 300);
  223. });
  224. //导出窗口--------
  225. $('#export').on('hide.bs.modal', function() {
  226. resetState();
  227. STATE.checking = false;
  228. STATE.exporting = false;
  229. STATE.confirming = false;
  230. //恢复设置提示弹窗 因为是共用的alert
  231. $('#hintBox_caption').removeClass('export-check');
  232. $('#export input[type="checkbox"]:eq(0)').prop('checked', true);
  233. if (spread) {
  234. spread.destroy();
  235. spread = null;
  236. }
  237. });
  238. $('#export input[type="checkbox"]').click(function () {
  239. resetState();
  240. });
  241. }
  242. return {exportListener}
  243. })();