export_view.js 7.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219
  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. _failList = _cache.getItem('failList');
  14. let xmlObj = null;
  15. //设置工程编号表格数据设置
  16. const sheetSetting = {
  17. header: [
  18. {headerName: '名称', headerWidth: 200, dataCode: 'name', dataType: 'String'},
  19. {headerName: '工程编号', headerWidth: 200, dataCode: 'code', dataType: 'String'},
  20. ],
  21. view: {
  22. lockColumns: ['name'],
  23. lockRows: [0]
  24. }
  25. };
  26. //操作状态
  27. const STATE = {
  28. checking: false, //自检
  29. exporting: false, //导出
  30. confirming: false //导出确认
  31. };
  32. let spread = null;
  33. //初始化设置工程编号表格
  34. function initSpread(datas) {
  35. if (spread) {
  36. return;
  37. }
  38. spread = SheetDataHelper.createNewSpread($("#exportSpread")[0], 1);
  39. sheetCommonObj.spreadDefaultStyle(spread);
  40. let sheet = spread.getSheet(0);
  41. sheetCommonObj.initSheet(sheet, sheetSetting, 30);
  42. sheet.setRowCount(datas.length);
  43. sheetCommonObj.showTreeData(sheet, sheetSetting, datas);
  44. }
  45. //获取设置的工程编号
  46. function getCodeFromSheet(sheet) {
  47. let codeCol = 1;
  48. let rst = [];
  49. //排除建设项目行
  50. for (let row = 1; row < sheet.getRowCount(); row++) {
  51. rst.push(sheet.getValue(row, codeCol) || '');
  52. }
  53. return rst;
  54. }
  55. // 回到初始状态
  56. function resetState() {
  57. xmlObj = null;
  58. _cache.clear();
  59. }
  60. //事件监听
  61. function exportListener() {
  62. //导出接口-项目自检
  63. $('#export-check').click(async function () {
  64. let checkedDatas = $('#export input[type="checkbox"]:checked');
  65. if (!checkedDatas.length) {
  66. return;
  67. }
  68. if (STATE.checking) {
  69. return;
  70. }
  71. STATE.checking = true;
  72. let pr = new SCComponent.InitProgressBar();
  73. try {
  74. if (!xmlObj || !xmlObj.originalDatas.length) {
  75. pr.start('导出数据接口', '正在自检,请稍候……');
  76. xmlObj = new XMLStandard(userID, 1);
  77. for (let checkedData of checkedDatas) {
  78. let fileKind = $(checkedData).val();
  79. await xmlObj.transformData(projectObj.project.ID(), fileKind);
  80. }
  81. }
  82. //设置提示弹窗
  83. if (_failList.length * 20 > 400) {
  84. $('#hintBox_caption').addClass('export-check');
  85. }
  86. if (_failList.length) {
  87. throw _failList.join('<br/>');
  88. }
  89. } catch (err) {
  90. alert(err);
  91. }
  92. pr.end();
  93. setTimeout(() => {
  94. STATE.checking = false;
  95. }, 300);
  96. });
  97. //导出接口,如果没有错误,弹出工程编号设置窗口
  98. $('#export-confirm').click(async function () {
  99. let checkedDatas = $('#export input[type="checkbox"]:checked');
  100. if (!checkedDatas.length) {
  101. return;
  102. }
  103. if (STATE.exporting) {
  104. return;
  105. }
  106. STATE.exporting = true;
  107. let pr = new SCComponent.InitProgressBar();
  108. try {
  109. let isPring = false; //是否调用了进度条(控制工程窗口什么时候显示,优化交互)
  110. if (!xmlObj || !xmlObj.originalDatas.length) {
  111. isPring = true;
  112. pr.start('导出数据接口', '正在导出文件,请稍候……');
  113. xmlObj = new XMLStandard(userID, 1);
  114. for (let checkedData of checkedDatas) {
  115. let fileKind = $(checkedData).val();
  116. await xmlObj.transformData(projectObj.project.ID(), fileKind);
  117. }
  118. pr.end();
  119. }
  120. //错误-设置提示弹窗
  121. //不弹出
  122. /*if (_failList.length * 20 > 400) {
  123. $('#hintBox_caption').addClass('export-check');
  124. }
  125. if (_failList.length) {
  126. throw _failList.join('<br/>');
  127. }*/
  128. //弹出工程编号设置窗口
  129. if (isPring) {
  130. setTimeout(() => {
  131. $('#exportCode').modal('show');
  132. }, 300);
  133. } else {
  134. $('#exportCode').modal('show');
  135. }
  136. } catch (err) {
  137. pr.end();
  138. alert(err);
  139. }
  140. setTimeout(() => {
  141. STATE.exporting = false;
  142. }, 300);
  143. });
  144. //工程编号设置窗口-----
  145. //设置工程编号
  146. $('#exportCode').on('shown.bs.modal', function () {
  147. if (!xmlObj) {
  148. alert('数据错误!');
  149. $(this).modal('hide');
  150. return false;
  151. }
  152. initSpread(XML_EXPORT_BASE.UTIL.getCodeSheetData(xmlObj.PMData));
  153. });
  154. //设置完工程编号后,导出数据。如果选中多个文件,导出压缩包
  155. $('#exportCode-confirm').click(async function () {
  156. if (!spread || !xmlObj) {
  157. return false;
  158. }
  159. if (STATE.confirming) {
  160. return;
  161. }
  162. STATE.confirming = true;
  163. let pr = new SCComponent.InitProgressBar();
  164. try {
  165. let codeDatas = getCodeFromSheet(spread.getSheet(0));
  166. if (codeDatas.includes('')) {
  167. alert('单项、单位工程工程编号不可为空。');
  168. STATE.confirming = false;
  169. return false;
  170. }
  171. if ([...new Set(codeDatas)].length !== codeDatas.length) {
  172. alert('单项、单位工程工程编号必须唯一。');
  173. STATE.confirming = false;
  174. return false;
  175. }
  176. XML_EXPORT_BASE.UTIL.setupCode(xmlObj.originalDatas, codeDatas, xmlObj.instance);
  177. pr.start('导出数据接口', '正在导出文件,请稍候……');
  178. // 导出文件
  179. await XML_EXPORT_BASE.exportFile(xmlObj.originalDatas);
  180. } catch (err) {
  181. console.log(err);
  182. alert(err);
  183. }
  184. console.log(xmlObj);
  185. pr.end();
  186. $('#exportCode').modal('hide');
  187. $('#export').modal('hide');
  188. setTimeout(() => {
  189. STATE.confirming = false;
  190. }, 300);
  191. });
  192. //导出窗口--------
  193. $('#export').on('show.bs.modal', function () {
  194. xmlObj = null;
  195. });
  196. $('#export').on('hide.bs.modal', function() {
  197. resetState();
  198. //xmlObj = null;
  199. STATE.checking = false;
  200. STATE.exporting = false;
  201. STATE.confirming = false;
  202. //恢复设置提示弹窗 因为是共用的alert
  203. $('#hintBox_caption').removeClass('export-check');
  204. $('#export input[type="checkbox"]:eq(0)').prop('checked', true);
  205. if (spread) {
  206. spread.destroy();
  207. spread = null;
  208. }
  209. });
  210. $('#export input[type="checkbox"]').click(function () {
  211. resetState();
  212. //xmlObj = null;
  213. });
  214. }
  215. return {exportListener}
  216. })();