cloud-web-corejs 1.0.54-dev.65 → 1.0.54-dev.650

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (491) hide show
  1. package/package.json +22 -14
  2. package/src/App.vue +30 -34
  3. package/src/api/user.js +64 -40
  4. package/src/components/Qrcode/fileParse.vue +0 -1
  5. package/src/components/Tinymce/index.vue +112 -71
  6. package/src/components/VabUpload/image-viewer.vue +2 -2
  7. package/src/components/VabUpload/index.js +49 -1
  8. package/src/components/VabUpload/mixins.js +1822 -2
  9. package/src/components/VabUpload/propertiesDialog.vue +1 -1
  10. package/src/components/VabUpload/view.vue +209 -120
  11. package/src/components/advancedSearchDialog/mixins.js +28 -1
  12. package/src/components/base-textarea/index.vue +104 -0
  13. package/src/components/baseAlert/index.js +44 -1
  14. package/src/components/baseAlert/index.vue +24 -20
  15. package/src/components/baseAlert/mixins.js +61 -1
  16. package/src/components/baseAttachment/index.vue +49 -40
  17. package/src/components/baseAttachment/install.js +21 -5
  18. package/src/components/baseAttachment/mixins.js +310 -1
  19. package/src/components/baseInputBatch/mixins.js +58 -1
  20. package/src/components/baseInputExport/index.vue +21 -14
  21. package/src/components/baseInputExport/mixins.js +391 -1
  22. package/src/components/baseTabs/index.vue +16 -8
  23. package/src/components/baseTabs/mixins.js +166 -1
  24. package/src/components/cnPrint/index.js +44 -1
  25. package/src/components/cnPrint/mixins.js +189 -1
  26. package/src/components/code-editor/index.vue +102 -63
  27. package/src/components/confirmDialog/index.js +41 -1
  28. package/src/components/confirmDialog/index.vue +24 -17
  29. package/src/components/confirmDialog/mixins.js +31 -1
  30. package/src/components/errorMsg/index.js +1 -1
  31. package/src/components/errorMsg/index.vue +78 -70
  32. package/src/components/errorMsg/mixins.js +6 -5
  33. package/src/components/excelExport/button.vue +86 -24
  34. package/src/components/excelExport/exportFieldDialog.vue +215 -81
  35. package/src/components/excelExport/index.js +6 -6
  36. package/src/components/excelExport/index.vue +108 -26
  37. package/src/components/excelExport/mixins.js +2 -2
  38. package/src/components/excelImport/index.js +13 -13
  39. package/src/components/excelImport/mixins.js +2 -1
  40. package/src/components/fileLibrary/fileObjAuthDialog.vue +179 -89
  41. package/src/components/fileLibrary/fileObjAuthEditDialog.vue +6 -0
  42. package/src/components/fileLibrary/filterDialog.vue +454 -0
  43. package/src/components/fileLibrary/index.vue +605 -262
  44. package/src/components/fileLibrary/mixins/categoryMoveDialogMixins.js +1 -1
  45. package/src/components/fileLibrary/mixins/fileCategoryDialogMixins.js +1 -1
  46. package/src/components/fileLibrary/mixins/fileHistoryDialogMixins.js +2 -2
  47. package/src/components/fileLibrary/mixins/fileObjAuthDialogMixin.js +339 -211
  48. package/src/components/fileLibrary/mixins/fileObjAuthEditDialogMixin.js +31 -27
  49. package/src/components/fileLibrary/mixins/fileObjAuthEditMixin.js +4 -4
  50. package/src/components/fileLibrary/mixins/indexMixins.js +220 -101
  51. package/src/components/fileLibrary/mixins/propertiesDialogMixins.js +64 -4
  52. package/src/components/fileLibrary/mixins/recycleBinDialogMixins.js +3 -3
  53. package/src/components/fileLibrary/propertiesDialog.vue +113 -74
  54. package/src/components/fileLibrary/shareDialog.vue +1 -1
  55. package/src/components/formOplog/mixins.js +85 -4
  56. package/src/components/hiprint/css/bootstrap.min.css +6 -0
  57. package/src/components/hiprint/fonts/glyphicons-halflings-regular.eot +0 -0
  58. package/src/components/hiprint/fonts/glyphicons-halflings-regular.svg +288 -0
  59. package/src/components/hiprint/fonts/glyphicons-halflings-regular.ttf +0 -0
  60. package/src/components/hiprint/fonts/glyphicons-halflings-regular.woff +0 -0
  61. package/src/components/hiprint/fonts/glyphicons-halflings-regular.woff2 +0 -0
  62. package/src/components/hiprint/hiprint.bundle.js +15 -3
  63. package/src/components/hiprint/view/design/index.vue +140 -47
  64. package/src/components/hiprint/view/design/mixins.js +611 -1
  65. package/src/components/hiprint/view/design/preview.vue +75 -52
  66. package/src/components/hiprint/view/json-view.vue +31 -31
  67. package/src/components/jdPrint/index.js +44 -1
  68. package/src/components/jdPrint/mixins.js +208 -1
  69. package/src/components/jsonImport/index.js +187 -17
  70. package/src/components/jsonImport/mixins.js +333 -1
  71. package/src/components/langImport/index.js +80 -1
  72. package/src/components/langImport/mixins.js +500 -16
  73. package/src/components/langTag/mixins/addButton.js +51 -5
  74. package/src/components/langTag/mixins/deleteButton.js +55 -5
  75. package/src/components/langTag/mixins/view.js +47 -5
  76. package/src/components/luckysheet/dialog.vue +159 -0
  77. package/src/components/luckysheet/export.js +595 -0
  78. package/src/components/luckysheet/fileUtils.js +147 -0
  79. package/src/components/luckysheet/index.js +72 -0
  80. package/src/components/luckysheet/templateJson.js +12078 -0
  81. package/src/components/luckysheet/view.vue +210 -0
  82. package/src/components/obsUpload/index.js +34 -0
  83. package/src/components/obsUpload/index.vue +231 -0
  84. package/src/components/obsUpload/mixins.js +1476 -0
  85. package/src/components/onlineTalk/index.vue +1 -1
  86. package/src/components/onlineTalk/mixins.js +852 -1
  87. package/src/components/onlineTalk/talkUserDialog.vue +280 -0
  88. package/src/components/oplogTable/mixins.js +83 -4
  89. package/src/components/pddPrint/index.js +44 -1
  90. package/src/components/pddPrint/mixins.js +252 -1
  91. package/src/components/projectTag/mixins/addButton.js +52 -1
  92. package/src/components/projectTag/mixins/deleteButton.js +52 -1
  93. package/src/components/projectTag/mixins/view.js +43 -1
  94. package/src/components/scriptDescription/button.vue +12 -4
  95. package/src/components/scriptDescription/mixins.js +30 -1
  96. package/src/components/scriptTest/mixins.js +90 -1
  97. package/src/components/statusTag/mixins.js +66 -1
  98. package/src/components/table/CellSlot.vue +1 -0
  99. package/src/components/table/config.js +1 -1
  100. package/src/components/table/index.js +12 -11
  101. package/src/components/table/plugins/extend-cell-area/vxe-table-extend-cell-area.es6.min.js +11028 -0
  102. package/src/components/table/plugins/extend-cell-area/vxe-table-extend-cell-area.min.css +200 -0
  103. package/src/components/table/tableForm.vue +99 -63
  104. package/src/components/table/tableFormMixin.js +1 -1
  105. package/src/components/table/util/index.js +339 -0
  106. package/src/components/table/vxeFilter/index.js +2 -1
  107. package/src/components/table/vxeFilter/mixin.js +8 -6
  108. package/src/components/tempStorage/index.vue +76 -55
  109. package/src/components/tempStorage/tempStorageDialog.vue +179 -54
  110. package/src/components/vb-tabs/x-tabs.vue +56 -30
  111. package/src/components/vipPrint/index.js +44 -1
  112. package/src/components/vipPrint/mixins.js +268 -1
  113. package/src/components/wf/addOpinionButton.vue +57 -0
  114. package/src/components/wf/content.vue +834 -362
  115. package/src/components/wf/mixins/addOpinionButton.js +53 -0
  116. package/src/components/wf/mixins/setCandidateButton.js +161 -0
  117. package/src/components/wf/mixins/setCandidateDialog.js +213 -1
  118. package/src/components/wf/mixins/setCandidateDialog2.js +252 -0
  119. package/src/components/wf/mixins/wfFlowEleScriptDialog.js +131 -0
  120. package/src/components/wf/mixins/wfTaskUserRangeDialog.js +69 -0
  121. package/src/components/wf/setCandidateButton.vue +40 -0
  122. package/src/components/wf/setCandidateDialog.vue +10 -0
  123. package/src/components/wf/setCandidateDialog2.vue +105 -0
  124. package/src/components/wf/wf.js +2156 -1
  125. package/src/components/wf/wfFlowEleScriptDialog.vue +89 -0
  126. package/src/components/wf/wfStartDialog.vue +66 -42
  127. package/src/components/wf/wfTaskUserRangeDialog.vue +65 -0
  128. package/src/components/wf/wfUtil.js +279 -1
  129. package/src/components/xform/form-designer/designer.js +1995 -9
  130. package/src/components/xform/form-designer/form-widget/components/gantt/index.vue +434 -0
  131. package/src/components/xform/form-designer/form-widget/container-widget/containerMixin.js +1 -1
  132. package/src/components/xform/form-designer/form-widget/container-widget/data-table-mixin.js +9 -8
  133. package/src/components/xform/form-designer/form-widget/container-widget/data-table-widget.vue +4 -1
  134. package/src/components/xform/form-designer/form-widget/container-widget/detail-pane-widget.vue +3 -2
  135. package/src/components/xform/form-designer/form-widget/container-widget/detail-widget.vue +3 -3
  136. package/src/components/xform/form-designer/form-widget/dialog/baseFormulaDialog copy.vue +971 -0
  137. package/src/components/xform/form-designer/form-widget/dialog/baseFormulaDialog.vue +971 -0
  138. package/src/components/xform/form-designer/form-widget/dialog/exportDialog.vue +13 -0
  139. package/src/components/xform/form-designer/form-widget/dialog/fileReferenceDialog.vue +301 -0
  140. package/src/components/xform/form-designer/form-widget/dialog/formDialog.vue +85 -48
  141. package/src/components/xform/form-designer/form-widget/dialog/formDrawer.vue +5 -1
  142. package/src/components/xform/form-designer/form-widget/dialog/formulaDialog.vue +799 -0
  143. package/src/components/xform/form-designer/form-widget/dialog/importDialog.vue +30 -7
  144. package/src/components/xform/form-designer/form-widget/dialog/importDialogMixin.js +1762 -9
  145. package/src/components/xform/form-designer/form-widget/dialog/searchFormDialog.vue +222 -75
  146. package/src/components/xform/form-designer/form-widget/field-widget/a-link-widget.vue +2 -2
  147. package/src/components/xform/form-designer/form-widget/field-widget/a-text-widget.vue +1 -1
  148. package/src/components/xform/form-designer/form-widget/field-widget/baseAttachment-widget.vue +32 -4
  149. package/src/components/xform/form-designer/form-widget/field-widget/button-widget.vue +1 -1
  150. package/src/components/xform/form-designer/form-widget/field-widget/cascader-widget.vue +19 -1
  151. package/src/components/xform/form-designer/form-widget/field-widget/census-widget.vue +40 -28
  152. package/src/components/xform/form-designer/form-widget/field-widget/checkbox-widget.vue +18 -7
  153. package/src/components/xform/form-designer/form-widget/field-widget/color-widget.vue +4 -1
  154. package/src/components/xform/form-designer/form-widget/field-widget/copy_button-widget.vue +95 -0
  155. package/src/components/xform/form-designer/form-widget/field-widget/date-range-widget.vue +13 -2
  156. package/src/components/xform/form-designer/form-widget/field-widget/date-widget.vue +30 -4
  157. package/src/components/xform/form-designer/form-widget/field-widget/download-button-widget.vue +133 -0
  158. package/src/components/xform/form-designer/form-widget/field-widget/dropdown-item-widget.vue +86 -0
  159. package/src/components/xform/form-designer/form-widget/field-widget/dropdown-widget.vue +170 -0
  160. package/src/components/xform/form-designer/form-widget/field-widget/fieldMixin.js +1654 -16
  161. package/src/components/xform/form-designer/form-widget/field-widget/form-item-wrapper.vue +705 -379
  162. package/src/components/xform/form-designer/form-widget/field-widget/gantt-widget.vue +964 -0
  163. package/src/components/xform/form-designer/form-widget/field-widget/html-text-widget.vue +6 -2
  164. package/src/components/xform/form-designer/form-widget/field-widget/import-button-widget.vue +22 -11
  165. package/src/components/xform/form-designer/form-widget/field-widget/import2-button-widget.vue +90 -0
  166. package/src/components/xform/form-designer/form-widget/field-widget/input-widget.vue +7 -2
  167. package/src/components/xform/form-designer/form-widget/field-widget/mixins/echart-bar-mixin.js +2 -1
  168. package/src/components/xform/form-designer/form-widget/field-widget/mixins/echart-category-mixin.js +3 -2
  169. package/src/components/xform/form-designer/form-widget/field-widget/mixins/echart-pie-mixin.js +1 -1
  170. package/src/components/xform/form-designer/form-widget/field-widget/mixins/vabsearch-mixin.js +179 -0
  171. package/src/components/xform/form-designer/form-widget/field-widget/multiSearch-widget.vue +53 -0
  172. package/src/components/xform/form-designer/form-widget/field-widget/number-widget.vue +114 -81
  173. package/src/components/xform/form-designer/form-widget/field-widget/oplog-widget.vue +186 -0
  174. package/src/components/xform/form-designer/form-widget/field-widget/print-button-widget.vue +55 -28
  175. package/src/components/xform/form-designer/form-widget/field-widget/print-detail-button-widget.vue +119 -0
  176. package/src/components/xform/form-designer/form-widget/field-widget/project-tag-widget.vue +154 -47
  177. package/src/components/xform/form-designer/form-widget/field-widget/radio-widget.vue +26 -6
  178. package/src/components/xform/form-designer/form-widget/field-widget/search_button-widget.vue +2 -2
  179. package/src/components/xform/form-designer/form-widget/field-widget/select-export-button-widget.vue +86 -0
  180. package/src/components/xform/form-designer/form-widget/field-widget/select-export-item-button-widget.vue +92 -0
  181. package/src/components/xform/form-designer/form-widget/field-widget/select-widget.vue +24 -9
  182. package/src/components/xform/form-designer/form-widget/field-widget/singerSearch-widget.vue +53 -0
  183. package/src/components/xform/form-designer/form-widget/field-widget/singleUpload-widget.vue +145 -0
  184. package/src/components/xform/form-designer/form-widget/field-widget/static-content-wrapper.vue +12 -1
  185. package/src/components/xform/form-designer/form-widget/field-widget/static-text-widget.vue +8 -3
  186. package/src/components/xform/form-designer/form-widget/field-widget/status-widget.vue +82 -49
  187. package/src/components/xform/form-designer/form-widget/field-widget/table-export-button-widget.vue +38 -38
  188. package/src/components/xform/form-designer/form-widget/field-widget/tableexportbuttonwidget.vue +99 -0
  189. package/src/components/xform/form-designer/form-widget/field-widget/tempStorage-widget.vue +147 -0
  190. package/src/components/xform/form-designer/form-widget/field-widget/text-widget.vue +106 -33
  191. package/src/components/xform/form-designer/form-widget/field-widget/time-range-widget.vue +2 -2
  192. package/src/components/xform/form-designer/form-widget/field-widget/vabSearch-widget.vue +3 -171
  193. package/src/components/xform/form-designer/form-widget/field-widget/vabUpload-widget.vue +191 -66
  194. package/src/components/xform/form-designer/form-widget/field-widget/vabUpload2-widget.vue +753 -0
  195. package/src/components/xform/form-designer/form-widget/indexMixin.js +1 -1
  196. package/src/components/xform/form-designer/indexMixin.js +3 -2
  197. package/src/components/xform/form-designer/refMixinDesign.js +1 -28
  198. package/src/components/xform/form-designer/setting-panel/form-setting.vue +981 -172
  199. package/src/components/xform/form-designer/setting-panel/index.vue +41 -32
  200. package/src/components/xform/form-designer/setting-panel/indexMixin.js +1 -1
  201. package/src/components/xform/form-designer/setting-panel/option-items-setting.vue +537 -302
  202. package/src/components/xform/form-designer/setting-panel/property-editor/a-link-editor.vue +4 -4
  203. package/src/components/xform/form-designer/setting-panel/property-editor/a-text-editor.vue +3 -3
  204. package/src/components/xform/form-designer/setting-panel/property-editor/autoValueEnabled-editor.vue +38 -0
  205. package/src/components/xform/form-designer/setting-panel/property-editor/censusClass-editor.vue +6 -0
  206. package/src/components/xform/form-designer/setting-panel/property-editor/colorClass-editor.vue +28 -0
  207. package/src/components/xform/form-designer/setting-panel/property-editor/commonAttributeEnabled-editor.vue +41 -0
  208. package/src/components/xform/form-designer/setting-panel/property-editor/container-data-table/columnRenderDialog.vue +125 -0
  209. package/src/components/xform/form-designer/setting-panel/property-editor/container-data-table/data-table-editor.vue +991 -1042
  210. package/src/components/xform/form-designer/setting-panel/property-editor/container-data-table/edit-tree-button-group-config-dialog.vue +281 -0
  211. package/src/components/xform/form-designer/setting-panel/property-editor/container-data-table/exportItemColumns-dialog.vue +432 -0
  212. package/src/components/xform/form-designer/setting-panel/property-editor/container-data-table/onCheckboxChange-editor.vue +1 -1
  213. package/src/components/xform/form-designer/setting-panel/property-editor/container-data-table/table-column-dialog.vue +1222 -529
  214. package/src/components/xform/form-designer/setting-panel/property-editor/container-detail/detail-editor.vue +3 -3
  215. package/src/components/xform/form-designer/setting-panel/property-editor/container-detail-pane/detail-pane-editor.vue +3 -3
  216. package/src/components/xform/form-designer/setting-panel/property-editor/container-grid-col/grid-col-offset-editor.vue +1 -1
  217. package/src/components/xform/form-designer/setting-panel/property-editor/container-grid-col/grid-col-pull-editor.vue +1 -1
  218. package/src/components/xform/form-designer/setting-panel/property-editor/container-grid-col/grid-col-push-editor.vue +1 -1
  219. package/src/components/xform/form-designer/setting-panel/property-editor/container-list-h5/list-h5-editor.vue +0 -8
  220. package/src/components/xform/form-designer/setting-panel/property-editor/container-tree/tree-customClass-editor.vue +31 -2
  221. package/src/components/xform/form-designer/setting-panel/property-editor/copyButton-editor.vue +36 -0
  222. package/src/components/xform/form-designer/setting-panel/property-editor/downloadButtonFlag-editor.vue +32 -0
  223. package/src/components/xform/form-designer/setting-panel/property-editor/dropdownFlag-editor.vue +133 -0
  224. package/src/components/xform/form-designer/setting-panel/property-editor/event-handler/eventMixin.js +2 -2
  225. package/src/components/xform/form-designer/setting-panel/property-editor/event-handler/onAfterConfirmFile-editor.vue +5 -3
  226. package/src/components/xform/form-designer/setting-panel/property-editor/event-handler/onClick-editor.vue +23 -8
  227. package/src/components/xform/form-designer/setting-panel/property-editor/field-button/clickBindEvent-editor.vue +35 -20
  228. package/src/components/xform/form-designer/setting-panel/property-editor/field-button/search-dialog-event-editor.vue +64 -5
  229. package/src/components/xform/form-designer/setting-panel/property-editor/field-dropdown-menu/dropdown-item-editor.vue +21 -0
  230. package/src/components/xform/form-designer/setting-panel/property-editor/field-dropdown-menu/dropdown-menu-editor.vue +59 -0
  231. package/src/components/xform/form-designer/setting-panel/property-editor/field-gantt/gantt-editor.vue +36 -0
  232. package/src/components/xform/form-designer/setting-panel/property-editor/field-import-button/import-button-editor.vue +77 -20
  233. package/src/components/xform/form-designer/setting-panel/property-editor/field-import-button/import2-button-editor.vue +96 -0
  234. package/src/components/xform/form-designer/setting-panel/property-editor/field-print-button/print-button-editor.vue +44 -15
  235. package/src/components/xform/form-designer/setting-panel/property-editor/field-print-button/print-detail-button-editor.vue +115 -0
  236. package/src/components/xform/form-designer/setting-panel/property-editor/field-rate/rate-defaultValue-editor.vue +1 -1
  237. package/src/components/xform/form-designer/setting-panel/property-editor/field-static-text/preWrap-editor.vue +23 -0
  238. package/src/components/xform/form-designer/setting-panel/property-editor/field-static-text/textContent-editor.vue +1 -1
  239. package/src/components/xform/form-designer/setting-panel/property-editor/field-status/field-status-editor.vue +67 -41
  240. package/src/components/xform/form-designer/setting-panel/property-editor/field-table-export-button/select-export-button-editor.vue +56 -0
  241. package/src/components/xform/form-designer/setting-panel/property-editor/field-table-export-button/select-export-item-button-editor.vue +71 -0
  242. package/src/components/xform/form-designer/setting-panel/property-editor/field-vabSearch/vabSearchName-editor.vue +13 -1
  243. package/src/components/xform/form-designer/setting-panel/property-editor/field-vabUpload/field-vabUpload-editor.vue +33 -1
  244. package/src/components/xform/form-designer/setting-panel/property-editor/field-vabUpload2/field-vabUpload2-editor.vue +66 -0
  245. package/src/components/xform/form-designer/setting-panel/property-editor/formScriptEnabled-editor.vue +89 -19
  246. package/src/components/xform/form-designer/setting-panel/property-editor/formatType-editor.vue +137 -0
  247. package/src/components/xform/form-designer/setting-panel/property-editor/formula-editor.vue +721 -466
  248. package/src/components/xform/form-designer/setting-panel/property-editor/labelColor-editor.vue +20 -11
  249. package/src/components/xform/form-designer/setting-panel/property-editor/labelIconClass-editor.vue +1 -1
  250. package/src/components/xform/form-designer/setting-panel/property-editor/labelIconPosition-editor.vue +1 -1
  251. package/src/components/xform/form-designer/setting-panel/property-editor/labelTooltip-editor.vue +1 -1
  252. package/src/components/xform/form-designer/setting-panel/property-editor/limit-editor.vue +1 -1
  253. package/src/components/xform/form-designer/setting-panel/property-editor/multiple-editor.vue +19 -14
  254. package/src/components/xform/form-designer/setting-panel/property-editor/multipleLimit-editor.vue +1 -1
  255. package/src/components/xform/form-designer/setting-panel/property-editor/name-editor.vue +126 -50
  256. package/src/components/xform/form-designer/setting-panel/property-editor/oplog-editor.vue +31 -0
  257. package/src/components/xform/form-designer/setting-panel/property-editor/precision-editor.vue +1 -1
  258. package/src/components/xform/form-designer/setting-panel/property-editor/project-tag-editor.vue +349 -0
  259. package/src/components/xform/form-designer/setting-panel/property-editor/required-editor.vue +10 -6
  260. package/src/components/xform/form-designer/setting-panel/property-editor/requiredHint-editor.vue +3 -3
  261. package/src/components/xform/form-designer/setting-panel/property-editor/tempStorage-editor.vue +42 -0
  262. package/src/components/xform/form-designer/setting-panel/property-editor/textFlag-editor.vue +305 -19
  263. package/src/components/xform/form-designer/setting-panel/property-editor/validation-editor.vue +2 -2
  264. package/src/components/xform/form-designer/setting-panel/property-editor/validationHint-editor.vue +2 -2
  265. package/src/components/xform/form-designer/setting-panel/property-editor/wfFlag-editor.vue +372 -50
  266. package/src/components/xform/form-designer/setting-panel/property-editor/widgetShowRuleFlag-editor.vue +263 -0
  267. package/src/components/xform/form-designer/setting-panel/propertyRegister.js +33 -11
  268. package/src/components/xform/form-designer/setting-panel/widgetPropertyDialogMixin.js +173 -0
  269. package/src/components/xform/form-designer/toolbar-panel/index.vue +267 -103
  270. package/src/components/xform/form-designer/toolbar-panel/indexMixin.js +1 -1
  271. package/src/components/xform/form-designer/widget-panel/index.vue +21 -1
  272. package/src/components/xform/form-designer/widget-panel/indexMixin.js +19 -18
  273. package/src/components/xform/form-designer/widget-panel/widgetsConfig.js +1733 -950
  274. package/src/components/xform/form-render/container-item/containerItemMixin.js +1237 -11
  275. package/src/components/xform/form-render/container-item/data-table-item.vue +209 -196
  276. package/src/components/xform/form-render/container-item/data-table-mixin.js +3404 -18
  277. package/src/components/xform/form-render/container-item/detail-item.vue +72 -48
  278. package/src/components/xform/form-render/container-item/detail-pane-item.vue +17 -3
  279. package/src/components/xform/form-render/container-item/grid-col-item.vue +10 -3
  280. package/src/components/xform/form-render/container-item/grid-item.vue +1 -1
  281. package/src/components/xform/form-render/container-item/list-h5-item.vue +1118 -403
  282. package/src/components/xform/form-render/container-item/tab-item.vue +62 -25
  283. package/src/components/xform/form-render/container-item/table-cell-item.vue +38 -32
  284. package/src/components/xform/form-render/container-item/table-item.vue +4 -2
  285. package/src/components/xform/form-render/container-item/table2-cell-item.vue +53 -34
  286. package/src/components/xform/form-render/container-item/table2-item.vue +182 -91
  287. package/src/components/xform/form-render/container-item/tree-item.vue +32 -11
  288. package/src/components/xform/form-render/dynamicDialogRender.js +1 -1
  289. package/src/components/xform/form-render/index.vue +77 -20
  290. package/src/components/xform/form-render/indexMixin.js +3719 -12
  291. package/src/components/xform/form-render/refMixin.js +3 -3
  292. package/src/components/xform/lang/zh-CN.js +29 -4
  293. package/src/components/xform/mixins/defaultHandle.js +367 -2
  294. package/src/components/xform/mixins/scriptHttp.js +3 -1
  295. package/src/components/xform/utils/emitter.js +4 -4
  296. package/src/components/xform/utils/formHttp.js +162 -0
  297. package/src/components/xform/utils/format.js +41 -34
  298. package/src/components/xform/utils/formula-util.js +969 -0
  299. package/src/components/xform/utils/smart-vue-i18n/index.js +2 -1
  300. package/src/components/xform/utils/util.js +1475 -1
  301. package/src/components/xform/utils/validators.js +2 -5
  302. package/src/components/xform/utils/vue2js-generator.js +2 -2
  303. package/src/components/xhsPrint/index.js +44 -1
  304. package/src/components/xhsPrint/mixins.js +269 -1
  305. package/src/directive/LimitNumber/index.js +125 -1
  306. package/src/directive/el-dialog-center/index.js +34 -1
  307. package/src/directive/el-drag-dialog/drag.js +86 -1
  308. package/src/directive/el-readonly/index.js +15 -1
  309. package/src/directive/permission/hasPermi.js +34 -1
  310. package/src/index.js +215 -190
  311. package/src/lang/index.js +56 -51
  312. package/src/lang/locale/en/login.js +27 -0
  313. package/src/lang/locale/zh/login.js +26 -0
  314. package/src/layout/components/AppMain.vue +8 -1
  315. package/src/layout/components/Sidebar/default.vue +1660 -1222
  316. package/src/layout/components/Sidebar/index.vue +6 -1
  317. package/src/layout/components/TagsView/index.vue +43 -12
  318. package/src/layout/components/createCompany/createCompanyDialog.vue +157 -0
  319. package/src/layout/components/extractedCode/createDialog.vue +92 -0
  320. package/src/layout/components/extractedCode/queryDialog.vue +103 -0
  321. package/src/layout/components/extractedCode/viewDialog.vue +207 -0
  322. package/src/layout/components/langTool.vue +33 -30
  323. package/src/layout/components/watermark/index.vue +83 -0
  324. package/src/layout/defaultLayout.vue +17 -9
  325. package/src/mixins/selectDialog/index.js +266 -1
  326. package/src/mixins/tableTree/index.js +199 -4
  327. package/src/mixins/wf/index.js +33 -1
  328. package/src/permission.js +135 -18
  329. package/src/resources/js/base/common.js +109 -109
  330. package/src/router/index.js +4 -7
  331. package/src/router/modules/customer.js +12 -18
  332. package/src/router/modules/system.js +4 -0
  333. package/src/store/config/index.js +83 -14
  334. package/src/store/getters.js +4 -1
  335. package/src/store/modules/permission.js +46 -41
  336. package/src/store/modules/settings.js +1 -1
  337. package/src/store/modules/tagsView.js +5 -8
  338. package/src/store/modules/user.js +367 -16
  339. package/src/utils/aes.js +2 -1
  340. package/src/utils/auth.js +1 -1
  341. package/src/utils/global.js +1 -1
  342. package/src/utils/index.js +2 -3
  343. package/src/utils/keepAlive.js +1 -1
  344. package/src/utils/pddLog.js +92 -0
  345. package/src/utils/pdfUtil.js +71 -0
  346. package/src/utils/request.js +1 -1
  347. package/src/utils/vab.js +1283 -27
  348. package/src/utils/validate.js +1 -1
  349. package/src/utils/wf.js +4 -4
  350. package/src/views/bd/setting/bd_attach_setting/edit.vue +5 -5
  351. package/src/views/bd/setting/bd_attach_setting/list.vue +28 -55
  352. package/src/views/bd/setting/bd_attach_setting/mixins/dialog.js +84 -1
  353. package/src/views/bd/setting/bd_attach_setting/mixins/edit.js +116 -5
  354. package/src/views/bd/setting/bd_attach_setting/mixins/list.js +239 -1
  355. package/src/views/bd/setting/bd_company_env/dialog.vue +174 -0
  356. package/src/views/bd/setting/bd_company_env/edit.vue +193 -0
  357. package/src/views/bd/setting/bd_company_env/list.vue +175 -0
  358. package/src/views/bd/setting/config_manage/list.vue +83 -0
  359. package/src/views/bd/setting/formVersion/button.vue +55 -0
  360. package/src/views/bd/setting/formVersion/compareDialog.vue +287 -0
  361. package/src/views/bd/setting/formVersion/fieldCompare.vue +54 -0
  362. package/src/views/bd/setting/formVersion/ftHistoryDialog.vue +400 -0
  363. package/src/views/bd/setting/formVersion/link.vue +58 -0
  364. package/src/views/bd/setting/formVersion/preformDialog.vue +86 -0
  365. package/src/views/bd/setting/formVersion/reverButton.vue +82 -0
  366. package/src/views/bd/setting/form_import_log/edit.vue +130 -0
  367. package/src/views/bd/setting/form_import_log/list.vue +211 -0
  368. package/src/views/bd/setting/form_script/edit.vue +196 -74
  369. package/src/views/bd/setting/form_script/edit1.vue +410 -187
  370. package/src/views/bd/setting/form_script/form_list.vue +118 -37
  371. package/src/views/bd/setting/form_script/list.vue +90 -21
  372. package/src/views/bd/setting/form_script/list1.vue +200 -118
  373. package/src/views/bd/setting/form_script/mixins/dialog.js +130 -1
  374. package/src/views/bd/setting/form_script/mixins/edit.js +265 -7
  375. package/src/views/bd/setting/form_script/mixins/edit1.js +259 -9
  376. package/src/views/bd/setting/form_script/mixins/form_list.js +322 -14
  377. package/src/views/bd/setting/form_script/mixins/list.js +278 -4
  378. package/src/views/bd/setting/form_script/mixins/list1.js +480 -14
  379. package/src/views/bd/setting/form_script/mixins/list2.js +10 -1
  380. package/src/views/bd/setting/form_script/mixins/otherAuthDialog.js +194 -0
  381. package/src/views/bd/setting/form_script/mixins/preformDialog.js +34 -1
  382. package/src/views/bd/setting/form_script/otherAuthDialog.vue +83 -0
  383. package/src/views/bd/setting/form_template/batchWfObjConfigDialog.vue +2 -2
  384. package/src/views/bd/setting/form_template/edit.vue +355 -184
  385. package/src/views/bd/setting/form_template/formDesignerDialog.vue +171 -0
  386. package/src/views/bd/setting/form_template/list.vue +296 -214
  387. package/src/views/bd/setting/form_template/mixins/batchWfObjConfigDialog.js +279 -1
  388. package/src/views/bd/setting/form_template/mixins/dialog.js +103 -1
  389. package/src/views/bd/setting/form_template/mixins/edit.js +277 -9
  390. package/src/views/bd/setting/form_template/mixins/editWfObjConfigDialog.js +92 -1
  391. package/src/views/bd/setting/form_template/mixins/ftHistoryDialog.js +91 -1
  392. package/src/views/bd/setting/form_template/mixins/itemEdit.js +104 -1
  393. package/src/views/bd/setting/form_template/mixins/itemList.js +234 -1
  394. package/src/views/bd/setting/form_template/mixins/list.js +672 -22
  395. package/src/views/bd/setting/form_template/mixins/list2.js +411 -0
  396. package/src/views/bd/setting/form_template/mixins/otherAuthDialog.js +193 -0
  397. package/src/views/bd/setting/form_template/mixins/preformDialog.js +28 -3
  398. package/src/views/bd/setting/form_template/mixins/wf_list.js +421 -3
  399. package/src/views/bd/setting/form_template/otherAuthDialog.vue +83 -0
  400. package/src/views/bd/setting/form_template/wfObjConfigDialog.vue +2 -2
  401. package/src/views/bd/setting/form_template/wf_list.vue +161 -127
  402. package/src/views/bd/setting/logic_param/edit.vue +146 -0
  403. package/src/views/bd/setting/logic_param/edit1.vue +106 -0
  404. package/src/views/bd/setting/logic_param/edit2.vue +139 -0
  405. package/src/views/bd/setting/logic_param/list.vue +74 -0
  406. package/src/views/bd/setting/logic_param/list1.vue +12 -0
  407. package/src/views/bd/setting/logic_param/list2.vue +12 -0
  408. package/src/views/bd/setting/logic_param/mixins/edit.js +93 -0
  409. package/src/views/bd/setting/logic_param/mixins/list.js +376 -0
  410. package/src/views/bd/setting/menu_kind/list.vue +172 -83
  411. package/src/views/bd/setting/menu_kind/mixins/authDialog.js +300 -7
  412. package/src/views/bd/setting/menu_kind/mixins/dialog.js +139 -1
  413. package/src/views/bd/setting/menu_kind/mixins/list.js +201 -1
  414. package/src/views/bd/setting/push_data/edit.vue +139 -0
  415. package/src/views/bd/setting/push_data/list.vue +283 -0
  416. package/src/views/bd/setting/push_data_h/edit.vue +153 -0
  417. package/src/views/bd/setting/push_data_h/list.vue +293 -0
  418. package/src/views/bd/setting/request_async_setting/edit.vue +320 -0
  419. package/src/views/bd/setting/request_async_setting/list.vue +372 -0
  420. package/src/views/bd/setting/request_setting/edit.vue +300 -0
  421. package/src/views/bd/setting/request_setting/list.vue +311 -0
  422. package/src/views/bd/setting/table_model/edit.vue +1079 -426
  423. package/src/views/bd/setting/table_model/list.vue +213 -128
  424. package/src/views/bd/setting/table_model/mixins/dialog.js +71 -1
  425. package/src/views/bd/setting/table_model/mixins/edit.js +1309 -13
  426. package/src/views/bd/setting/table_model/mixins/list.js +429 -2
  427. package/src/views/bd/setting/table_model/mixins/otherAuthDialog.js +201 -0
  428. package/src/views/bd/setting/table_model/mixins/zdDialog.js +114 -3
  429. package/src/views/bd/setting/table_model/otherAuthDialog.vue +83 -0
  430. package/src/views/bd/setting/utils/index.js +60 -1
  431. package/src/views/user/access_log/list.vue +418 -349
  432. package/src/views/user/area/dialog.vue +223 -117
  433. package/src/views/user/area/list.vue +318 -0
  434. package/src/views/user/common_attribute/list.vue +4 -1
  435. package/src/views/user/company_info/dialog.vue +195 -163
  436. package/src/views/user/extend_datasource/dialog.vue +3 -0
  437. package/src/views/user/extend_datasource/edit.vue +2 -1
  438. package/src/views/user/extend_datasource/list.vue +3 -0
  439. package/src/views/user/fieldTranslation/editDialog.vue +8 -8
  440. package/src/views/user/fieldTranslation/list.vue +33 -33
  441. package/src/views/user/form/vform/designer.vue +790 -749
  442. package/src/views/user/form/vform/out_render.vue +1 -1
  443. package/src/views/user/form/vform/render.vue +67 -37
  444. package/src/views/user/form/view/edit.vue +38 -37
  445. package/src/views/user/form/view/list.vue +270 -49
  446. package/src/views/user/home/default.vue +1117 -979
  447. package/src/views/user/home/dev.vue +29 -0
  448. package/src/views/user/home/index.vue +18 -7
  449. package/src/views/user/login/default.vue +165 -36
  450. package/src/views/user/login/index.vue +4 -6
  451. package/src/views/user/login/indexMixin.js +329 -118
  452. package/src/views/user/menu/list.vue +27 -1
  453. package/src/views/user/notify_message/dialog.vue +44 -22
  454. package/src/views/user/notify_template/edit.vue +188 -187
  455. package/src/views/user/notify_template/edit2.vue +176 -0
  456. package/src/views/user/notify_template/list.vue +4 -1
  457. package/src/views/user/notify_template/list2.vue +190 -0
  458. package/src/views/user/outLink/form_view.vue +211 -211
  459. package/src/views/user/outLink/index.vue +67 -11
  460. package/src/views/user/position/list.vue +112 -72
  461. package/src/views/user/project_tag/dialog.vue +9 -4
  462. package/src/views/user/project_tag/edit.vue +2 -2
  463. package/src/views/user/project_tag/list.vue +9 -4
  464. package/src/views/user/request_setting/edit.vue +258 -0
  465. package/src/views/user/request_setting/list.vue +248 -0
  466. package/src/views/user/role/authConfig.vue +89 -0
  467. package/src/views/user/role/dialog.vue +70 -48
  468. package/src/views/user/role/edit.vue +609 -429
  469. package/src/views/user/role/list.vue +4 -4
  470. package/src/views/user/sale_org/dialog.vue +1 -1
  471. package/src/views/user/sale_org/list.vue +4 -1
  472. package/src/views/user/system_notice/infoDialog.vue +2 -1
  473. package/src/views/user/user/dialog.vue +46 -23
  474. package/src/views/user/user/edit.vue +1391 -1021
  475. package/src/views/user/user/form_dialog.vue +158 -0
  476. package/src/views/user/user/form_info.vue +210 -0
  477. package/src/views/user/user/info.vue +253 -140
  478. package/src/views/user/user/list.vue +652 -563
  479. package/src/views/user/user/modifyPasswordDialog.vue +64 -53
  480. package/src/views/user/wf/wfReport/index.vue +619 -0
  481. package/src/views/user/wf/wf_auto_submit_data/list.vue +2 -0
  482. package/src/views/user/wf/wf_manage/list.vue +379 -250
  483. package/src/views/user/wf/wf_manage/list2.vue +854 -0
  484. package/src/views/user/wf/wf_manage/wfContentDialog.vue +25 -22
  485. package/src/views/user/wf/wf_obj_config/importItemDialog.vue +109 -0
  486. package/src/views/user/wf/wf_obj_config/itemEdit.vue +25 -1
  487. package/src/views/user/wf/wf_obj_config/list.vue +114 -9
  488. package/src/views/user/wf/wf_transfer_setting/edit.vue +282 -0
  489. package/src/views/user/wf/wf_transfer_setting/list.vue +319 -0
  490. package/src/views/user/workbench_menu/list.vue +555 -0
  491. package/src/components/xform/form-render/container-item/list-h5-item2.vue +0 -1347
@@ -1,1042 +1,991 @@
1
- <template>
2
- <div>
3
- <el-form-item :label="i18nt('designer.setting.tableWidth')">
4
- <el-input v-model="optionModel.tableWidth"></el-input>
5
- </el-form-item>
6
- <el-form-item :label="i18nt('designer.setting.tableHeight')">
7
- <el-input v-model="optionModel.tableHeight"></el-input>
8
- </el-form-item>
9
- <!-- <el-form-item :label="i18nt('designer.setting.customClass')">
10
- <el-select v-model="optionModel.customClass" multiple="" filterable="" allow-create="" default-first-option="">
11
- <el-option v-for="(e, t) in cssClassList" :key="t" :value="e" :label="e"></el-option>
12
- </el-select>
13
- </el-form-item>-->
14
- <!-- <el-form-item :label="i18nt('designer.setting.showIndex')"><el-switch v-model="optionModel.showIndex"></el-switch></el-form-item>
15
- <el-form-item :label="i18nt('designer.setting.showCheckBox')"><el-switch v-model="optionModel.showCheckBox"></el-switch></el-form-item> -->
16
- <el-form-item label="查询列表">
17
- <el-switch v-model="optionModel.isQueryTable"></el-switch>
18
- </el-form-item>
19
- <el-form-item :label="i18nt('designer.setting.showPagination')">
20
- <el-switch v-model="optionModel.showPagination"></el-switch>
21
- </el-form-item>
22
- <!-- <el-form-item :label="i18nt('显示导出')">
23
- <el-switch v-model="optionModel.showExportBtn"></el-switch>
24
- </el-form-item>-->
25
- <!-- <el-form-item :label="i18nt('显示搜索栏')">
26
- <el-switch v-model="optionModel.showSearchArea"></el-switch>
27
- </el-form-item>-->
28
- <!-- <el-form-item :label="i18nt('designer.setting.smallPagination')"><el-switch v-model="optionModel.smallPagination"></el-switch></el-form-item>
29
- <el-form-item :label="i18nt('designer.setting.showSummary')"><el-switch v-model="optionModel.showSummary"></el-switch></el-form-item>
30
- <el-form-item :label="i18nt('designer.setting.stripe')"><el-switch v-model="optionModel.stripe"></el-switch></el-form-item>
31
- <el-form-item :label="i18nt('designer.setting.rowSpacing')">
32
- <el-input-number style="width:100%;" controls-position="right" :min="0" :max="20" v-model="optionModel.rowSpacing"></el-input-number>
33
- </el-form-item>
34
- <el-form-item :label="i18nt('designer.setting.widgetSize')">
35
- <el-select v-model="optionModel.tableSize" @change="refreshTableLayout">
36
- <el-option v-for="e in widgetSizes" :key="e.value" :value="e.value" :label="e.label"></el-option>
37
- </el-select>
38
- </el-form-item> -->
39
- <el-form-item :label="i18nt('designer.setting.tableColEdit')">
40
- <el-button type="primary" plain="" round="" @click="openSetting">{{
41
- i18nt('designer.setting.editAction')
42
- }}
43
- </el-button>
44
- </el-form-item>
45
- <el-form-item label="自定义表格配置" label-width="150px">
46
- <a href="javascript:void(0);" class="a-link link-oneLind"
47
- @click="editEventHandler('tableConfig', tableConfigParams)">
48
- <span>{{ optionModel.tableConfig }}</span>
49
- <i class="el-icon-edit"></i>
50
- </a>
51
- </el-form-item>
52
- <el-form-item label-width="0">
53
- <el-divider class="custom-divider-margin-top">编辑表格设置</el-divider>
54
- </el-form-item>
55
- <el-form-item :label="i18nt('编辑表格')">
56
- <el-switch v-model="optionModel.isEditTable"></el-switch>
57
- </el-form-item>
58
- <el-form-item :label="i18nt('树表格')">
59
- <el-switch v-model="optionModel.isTreeTable"></el-switch>
60
- </el-form-item>
61
- <el-form-item :label="i18nt('启用WBS码')">
62
- <el-switch v-model="optionModel.wbsEnabled"></el-switch>
63
- </el-form-item>
64
- <el-form-item :label="i18nt('排序脚本编码')" v-if="optionModel.isEditTable">
65
- <el-input v-model="optionModel.sortScriptCode"></el-input>
66
- </el-form-item>
67
- <!-- <el-form-item :label="i18nt('上级关联字段')">
68
- <el-input v-model="optionModel.parentField"></el-input>
69
- </el-form-item>
70
- <el-form-item label="编辑表格默认数据" label-width="150px">
71
- <a href="javascript:void(0);" class="a-link link-oneLind"
72
- @click="editEventHandler('editDefaultRow', tableConfigParams)">
73
- <span>{{ optionModel.editDefaultRow }}</span>
74
- <i class="el-icon-edit"></i>
75
- </a>
76
- </el-form-item>-->
77
- <!-- <el-form-item :label="i18nt('designer.setting.tableDataEdit')">
78
- <el-button type="primary" plain="" round="" @click="openTableDataEdit">{{
79
- i18nt('designer.setting.editAction')
80
- }}
81
- </el-button>
82
- </el-form-item>-->
83
- <!-- <el-form-item :label="i18nt('designer.setting.dsEnabled')">
84
- <el-switch v-model="optionModel.dsEnabled"></el-switch>
85
- </el-form-item>-->
86
- <!-- <el-form-item v-if="optionModel.dsEnabled" :label="i18nt('designer.setting.dsName')">
87
- <el-select v-model="optionModel.dsName" filterable="" clearable="">
88
- <el-option v-for="(e, t) in dataSourceList" :key="t" :value="e.uniqueName" :label="e.uniqueName" :title="e.description"></el-option>
89
- </el-select>
90
- </el-form-item> -->
91
- <!-- <el-form-item v-if="!optionModel.dsEnabled" :label="i18nt('designer.setting.showButtonsColumn')">
92
- <el-switch v-model="optionModel.showButtonsColumn" @change="handleShowButtonsColumnChange"></el-switch>
93
- </el-form-item> -->
94
- <!-- <el-form-item v-if="optionModel.dsEnabled" :label="i18nt('请求访问')">
95
- &lt;!&ndash; <el-button type="primary" plain="" round="" @click="openSqlEditDialog">{{ i18nt('designer.setting.editAction') }}</el-button> &ndash;&gt;
96
- <el-input
97
- class="search-input"
98
- max="200"
99
- v-model="optionModel.accessName"
100
- @clear="
101
- optionModel.accessCode = '';
102
- $forceUpdate();
103
- "
104
- v-el-readonly
105
- clearable
106
- >
107
- <i slot="suffix" class="el-input__icon el-icon-search" @click="showRequestaccessDialog=true"></i>
108
- </el-input>
109
- </el-form-item>-->
110
- <!-- <el-form-item v-if="optionModel.showButtonsColumn" :label="i18nt('designer.setting.buttonsColumnEdit')">
111
- <el-button type="primary" plain="" round="" @click="editButtonsColumn">{{ i18nt('designer.setting.editAction') }}</el-button>
112
- </el-form-item> -->
113
- <el-dialog
114
- v-if="dataDialogVisible"
115
- custom-class="dialog-style list-dialog"
116
- :title="i18nt('designer.setting.tableDataEdit')"
117
- :visible.sync="dataDialogVisible"
118
- :show-close="!0"
119
- append-to-body=""
120
- :close-on-click-modal="!1"
121
- :close-on-press-escape="!1"
122
- :destroy-on-close="!0"
123
- width="75%"
124
- v-dialog-drag
125
- >
126
- <template slot="footer">
127
- <div class="dialog-footer">
128
- <el-button type="" @click="dataDialogVisible = !1" class="button-sty" icon="el-icon-close">
129
- {{ i18nt('designer.hint.cancel') }}
130
- </el-button>
131
- <el-button type="primary" @click="saveTableData" class="button-sty" icon="el-icon-check">
132
- {{ i18nt('designer.hint.confirm') }}
133
- </el-button>
134
- </div>
135
- </template>
136
- <code-editor mode="json" :readonly="!1" v-model="tableDataOptions"></code-editor>
137
- </el-dialog>
138
- <!-- <el-dialog
139
- v-if="dialogVisible"
140
- custom-class="dialog-style list-dialog"
141
- :title="i18nt('designer.setting.tableColEdit')"
142
- :visible.sync="dialogVisible"
143
- :show-close="!0"
144
- :append-to-body="false"
145
- :modal="false"
146
- :close-on-click-modal="!1"
147
- :close-on-press-escape="!1"
148
- :destroy-on-close="!0"
149
- width="1220px"
150
- v-dialog-drag
151
- >
152
- <div class="cont">
153
- <template slot="footer">
154
- <div class="dialog-footer">
155
- <el-button type="" @click="dialogVisible = !1" class="button-sty" icon="el-icon-close">
156
- {{ i18nt('designer.hint.cancel') }}
157
- </el-button>
158
- <el-button type="primary" @click="colSubmit" class="button-sty" icon="el-icon-check">
159
- {{ i18nt('designer.hint.confirm') }}
160
- </el-button>
161
-
162
- </div>
163
- </template>
164
- <el-table
165
- ref="singleTable"
166
- width="100%"
167
- :data="optionModel.tableColumns"
168
-
169
- height="500"
170
- border=""
171
- row-key="columnId"
172
- stripe=""
173
- >
174
- <el-table-column type="index" width="35" fixed="left"></el-table-column>
175
- <el-table-column label="" width="35"><i class="el-icon-s-operation drag-option"></i></el-table-column>
176
- <el-table-column :label="i18nt('designer.setting.columnLabel')" width="150" prop="label">
177
- <template slot-scope="scope">
178
- <el-input v-model="scope.row.label"></el-input>
179
- </template>
180
- </el-table-column>
181
- <el-table-column :label="i18nt('designer.setting.columnName')" width="150" prop="prop">
182
- <template slot-scope="scope">
183
- <el-input v-model="scope.row.prop"></el-input>
184
- </template>
185
- </el-table-column>
186
- <el-table-column :label="i18nt('designer.setting.columnWidth')" width="100" prop="width">
187
- <template slot-scope="scope">
188
- <el-input v-model="scope.row.width"></el-input>
189
- </template>
190
- </el-table-column>
191
- <el-table-column :label="i18nt('designer.setting.visibleColumn')" width="70" prop="show">
192
- <template slot-scope="scope">
193
- <el-switch v-model="scope.row.show"></el-switch>
194
- </template>
195
- </el-table-column>
196
- <el-table-column :label="i18nt('必填')" width="70" prop="required">
197
- <template slot-scope="scope">
198
- <el-switch v-model="scope.row.required"></el-switch>
199
- </template>
200
- </el-table-column>
201
- <el-table-column :label="i18nt('designer.setting.sortableColumn')" width="70" prop="sortable">
202
- <template slot-scope="scope">
203
- <el-switch v-model="scope.row.sortable"></el-switch>
204
- </template>
205
- </el-table-column>
206
- <el-table-column :label="i18nt('designer.setting.fixedColumn')" width="100" prop="fixed">
207
- <template slot-scope="scope">
208
- <el-select v-model="scope.row.fixed" clearable>
209
- <el-option value="left">left</el-option>
210
- <el-option value="right">right</el-option>
211
- </el-select>
212
- </template>
213
- </el-table-column>
214
- &lt;!&ndash; <el-table-column :label="i18nt('designer.setting.alignTypeOfColumn')" width="100" prop="align">
215
- <template slot-scope="scope">
216
- <el-select v-model="scope.row.align">
217
- <el-option v-for="(e,index) in alignOptions" :key="index" :value="e.value" :label="e.label"></el-option>
218
- </el-select>
219
- </template>
220
- </el-table-column>&ndash;&gt;
221
- <el-table-column :label="i18nt('designer.setting.formatOfColumn')" width="200" prop="formatS">
222
- <template slot-scope="scope">
223
- <el-select v-model="scope.row.formatS" @change="changeFormatS(scope.row)" clearable>
224
- <el-option-group :label="i18nt('designer.setting.customRenderGroup')">
225
- <el-option value="render" label="render"></el-option>
226
- </el-option-group>
227
- <el-option-group v-for="t in op" :key="t.label" :label="t.label">
228
- <el-option v-for="e in t.options" :key="e.value" :value="e.value" :label="e.label"></el-option>
229
- </el-option-group>
230
- </el-select>
231
- </template>
232
- </el-table-column>
233
- <el-table-column label="格式化配置" width="70" fixed="right" align="center">
234
- <template slot-scope="scope">
235
- <el-button size="mini" plain="" round="" icon="el-icon-edit"
236
- @click="openFormatConfigDialog(scope.row,scope.$index)"
237
- :disabled="!columnFormatMap[scope.row.formatS]"></el-button>
238
- </template>
239
- </el-table-column>
240
- <el-table-column :label="i18nt('designer.setting.renderFunction')" width="70" fixed="right" align="center">
241
- <template slot-scope="scope">
242
- <el-button :disabled="'render' !== scope.row.formatS" size="mini" plain="" round="" icon="el-icon-edit"
243
- @click="showRenderDialog(scope.row)"></el-button>
244
- </template>
245
- </el-table-column>
246
- <el-table-column :label="i18nt('designer.setting.actionColumn')" width="100" fixed="right" align="center">
247
- <template #header>
248
- <span>{{ i18nt('designer.setting.actionColumn') }}</span>
249
- &lt;!&ndash; <el-button :title="i18nt('designer.setting.addTableColumn')" size="mini" type="" circle=""
250
- icon="el-icon-plus" @click="openFieldTreeDialog"></el-button>&ndash;&gt;
251
- </template>
252
- <template slot-scope="scope">
253
- <el-button :title="i18nt('designer.setting.addTableColumn')" size="mini" type="" circle=""
254
- icon="el-icon-plus" @click="addCol"></el-button>
255
- <el-button
256
- :title="i18nt('designer.setting.deleteTableColumn')"
257
- size="mini"
258
- type=""
259
- circle=""
260
- icon="el-icon-minus"
261
- @click="handleDelete(scope.$index, scope.row)"
262
- ></el-button>
263
- </template>
264
- </el-table-column>
265
-
266
- </el-table>
267
- </div>
268
-
269
- </el-dialog>-->
270
- <!-- <el-dialog
271
- v-if="showRenderDialogFlag"
272
- :title="i18nt('designer.setting.renderFunction')"
273
- :visible.sync="showRenderDialogFlag"
274
- append-to-body=""
275
- :show-close="!0"
276
- custom-class="dialog-style list-dialog"
277
- :close-on-click-modal="!1"
278
- :close-on-press-escape="!1"
279
- :destroy-on-close="!0"
280
- v-dialog-drag
281
- >
282
- <el-alert type="info" :closable="!1" title="function customRender(params,h) {"/>
283
- <code-editor ref="dsResultEditor" mode="javascript" :readonly="!1" v-model="renderJson"></code-editor>
284
- <el-alert type="info" :closable="!1" title="}"/>
285
- <div class="dialog-footer" slot="footer">
286
- <el-button @click="showRenderDialogFlag = !1" class="button-sty" icon="el-icon-close">
287
- {{ i18nt('designer.hint.cancel') }}
288
- </el-button>
289
- <el-button type="primary" @click="saveColumnRender" class="button-sty" icon="el-icon-check">
290
- {{ i18nt('designer.hint.confirm') }}
291
- </el-button>
292
- </div>
293
- </el-dialog>-->
294
- <el-dialog
295
- v-if="showSqlEditDialog"
296
- :title="i18nt('数据源SQL编辑')"
297
- :visible.sync="showSqlEditDialog"
298
- append-to-body=""
299
- :show-close="!0"
300
- custom-class="dialog-style list-dialog"
301
- :close-on-click-modal="!1"
302
- :close-on-press-escape="!1"
303
- :destroy-on-close="!0"
304
- v-dialog-drag
305
- >
306
- <el-alert type="info" :closable="!1"/>
307
- <code-editor ref="dsResultEditor" mode="javascript" :readonly="!1" v-model="dataSourceSql"></code-editor>
308
- <el-alert type="info" :closable="!1"/>
309
- <div class="dialog-footer" slot="footer">
310
- <el-button @click="showSqlEditDialog = !1" class="button-sty" icon="el-icon-close">
311
- {{ i18nt('designer.hint.cancel') }}
312
- </el-button>
313
- <el-button type="primary" @click="saveDataSourceSql" class="button-sty" icon="el-icon-check">
314
- {{ i18nt('designer.hint.confirm') }}
315
- </el-button>
316
- </div>
317
- </el-dialog>
318
- <requestaccessDialog v-if="showRequestaccessDialog" :visiable.sync="showRequestaccessDialog"
319
- @confirm="confirmInsertRequestaccess" multi="false"
320
- :param="{reportCode:reportTemplate.reportCode}"/>
321
-
322
- <el-dialog
323
- v-if="showFieldTreeDialog"
324
- custom-class="dialog-style list-dialog"
325
- title="新增列表列"
326
- :visible.sync="showFieldTreeDialog"
327
- :show-close="!0"
328
- :append-to-body="false"
329
- :modal="false"
330
- :close-on-click-modal="!1"
331
- :close-on-press-escape="!1"
332
- :destroy-on-close="!0"
333
- width="500px"
334
- v-dialog-drag
335
- >
336
- <div class="cont" style="height: 500px;">
337
- <el-tree
338
- ref="tree"
339
- :data="treeData"
340
- show-checkbox
341
- node-key="name"
342
- :default-expand-all="true"
343
- :check-on-click-node="true"
344
- :expand-on-click-node="false"
345
- :default-checked-keys="defaultCheckedKeys"
346
- :props="defaultProps">
347
- </el-tree>
348
- </div>
349
- <span slot="footer" class="dialog-footer">
350
- <el-button type="primary" plain class="button-sty" @click="showFieldTreeDialog=false">
351
- <i class="el-icon-close el-icon"></i>
352
- 取 消
353
- </el-button>
354
- <el-button type="primary" @click="confirmFieldTreeDialog" class="button-sty">
355
- <i class="el-icon-check el-icon"></i>
356
- 确 定
357
- </el-button>
358
- </span>
359
- </el-dialog>
360
- <!-- <el-dialog
361
- v-if="showDateConfigDialog"
362
- :title="i18nt('日期配置编辑')"
363
- :visible.sync="showDateConfigDialog"
364
- append-to-body=""
365
- :show-close="!0"
366
- custom-class="dialog-style list-dialog"
367
- :close-on-click-modal="!1"
368
- :close-on-press-escape="!1"
369
- :destroy-on-close="!0"
370
- v-dialog-drag
371
- >
372
- <div class="cont">
373
- <el-form>
374
- <template v-for="(editorName, index) in dateFieldList">
375
- <component
376
- :is="editorName"
377
- :designer="designer"
378
- :selected-widget="selectedWidget"
379
- :option-model="columnOption"
380
- :key="index"
381
- ></component>
382
- </template>
383
- </el-form>
384
- </div>
385
- <div class="dialog-footer" slot="footer">
386
- <el-button @click="showDateConfigDialog = !1" class="button-sty" icon="el-icon-close">
387
- {{ i18nt('designer.hint.cancel') }}
388
- </el-button>
389
- <el-button type="primary" class="button-sty" icon="el-icon-check" @click="confirmDateConfigDialog">
390
- {{ i18nt('designer.hint.confirm') }}
391
- </el-button>
392
- </div>
393
- </el-dialog>-->
394
- <!-- <el-dialog
395
- v-if="showDateConfigDialog"
396
- :title="i18nt('日期配置编辑')"
397
- :visible.sync="showDateConfigDialog"
398
- append-to-body=""
399
- :show-close="!0"
400
- custom-class="dialog-style list-dialog"
401
- :close-on-click-modal="!1"
402
- :close-on-press-escape="!1"
403
- :destroy-on-close="!0"
404
- v-dialog-drag
405
- >
406
- <div class="cont">
407
- <el-scrollbar class="setting-scrollbar">
408
- <el-form :model="columnOption" size="mini" label-position="left" label-width="120px" class="setting-form"
409
- @submit.native.prevent>
410
- <el-collapse v-model="widgetActiveCollapseNames" class="setting-collapse">
411
- <el-collapse-item name="1" v-if="showCollapse(commonProps)"
412
- :title="i18nt('designer.setting.commonSetting')">
413
- <template v-for="(editorName, propName) in commonProps">
414
- <component
415
- v-if="hasPropEditor(propName, editorName)"
416
- :is="getPropEditor(propName, editorName)"
417
- :designer="designer"
418
- :selected-widget="columnSelectedWidget"
419
- :option-model="columnOption"
420
- :key="propName"
421
- ></component>
422
- </template>
423
- </el-collapse-item>
424
-
425
- <el-collapse-item name="2" v-if="showCollapse(advProps)"
426
- :title="i18nt('designer.setting.advancedSetting')">
427
- <template v-for="(editorName, propName) in advProps">
428
- <component
429
- v-if="hasPropEditor(propName, editorName)"
430
- :is="getPropEditor(propName, editorName)"
431
- :designer="designer"
432
- :selected-widget="selectedWidget"
433
- :option-model="columnOption"
434
- :key="propName"
435
- ></component>
436
- </template>
437
- </el-collapse-item>
438
-
439
- <el-collapse-item name="3" v-if="showEventCollapse() && showCollapse(eventProps)"
440
- :title="i18nt('designer.setting.eventSetting')">
441
- <template v-for="(editorName, propName) in eventProps">
442
- <component
443
- v-if="hasPropEditor(propName, editorName)"
444
- :is="getPropEditor(propName, editorName)"
445
- :designer="designer"
446
- :selected-widget="selectedWidget"
447
- :option-model="columnOption"
448
- :key="propName"
449
- ></component>
450
- </template>
451
- </el-collapse-item>
452
- </el-collapse>
453
- </el-form>
454
- </el-scrollbar>
455
- </div>
456
- <div class="dialog-footer" slot="footer">
457
- <el-button @click="showDateConfigDialog = !1" class="button-sty" icon="el-icon-close">
458
- {{ i18nt('designer.hint.cancel') }}
459
- </el-button>
460
- <el-button type="primary" class="button-sty" icon="el-icon-check" @click="confirmDateConfigDialog">
461
- {{ i18nt('designer.hint.confirm') }}
462
- </el-button>
463
- </div>
464
- </el-dialog>-->
465
- <tableColumnDialog v-if="dialogVisible" :visiable.sync="dialogVisible" :designer="designer"
466
- :selectedWidget="selectedWidget"
467
- :optionModel="optionModel"/>
468
-
469
-
470
- </div>
471
- </template>
472
-
473
- <script>
474
- import i18n from '../../../../../../components/xform/utils/i18n';
475
- // import Draggable from 'vuedraggable';
476
- import {deepClone, generateId} from '../../../../../../components/xform/utils/util';
477
- import Sortable from 'sortablejs';
478
- import requestaccessDialog from '../../../../../../views/user/form/report_requestaccess/dialog.vue'
479
- import conditionEditor from './condition-editor.vue'
480
- import tableColumnDialog from "./table-column-dialog.vue";
481
- import eventMixin
482
- from "../../../../../../components/xform/form-designer/setting-panel/property-editor/event-handler/eventMixin";
483
- import setttingConfig from "@/settings";
484
-
485
- export default {
486
- name: 'data-table-editor',
487
- componentName: 'PropertyEditor',
488
- mixins: [i18n, eventMixin],
489
- components: {
490
- requestaccessDialog,
491
- conditionEditor,
492
- tableColumnDialog
493
- },
494
- props: {
495
- designer: Object,
496
- selectedWidget: Object,
497
- optionModel: Object
498
- },
499
- inject: ['getReportTemplate', 'showEventCollapse', 'openWidgetPropertyDialog'],
500
- data: function () {
501
- return {
502
- showTableConfigDialog: false,
503
- tableConfigCode: null,
504
- dialogVisible: !1,
505
- dataDialogVisible: !1,
506
- showButtonsEditDialog: !1,
507
- oldButtonName: '',
508
- cssClassList: [],
509
- tableDataOptions: [],
510
- widgetSizes: [
511
- {
512
- label: 'default',
513
- value: ''
514
- },
515
- {
516
- label: 'large',
517
- value: 'large'
518
- },
519
- {
520
- label: 'medium',
521
- value: 'medium'
522
- },
523
- {
524
- label: 'small',
525
- value: 'small'
526
- },
527
- {
528
- label: 'mini',
529
- value: 'mini'
530
- }
531
- ],
532
- alignOptions: [
533
- {
534
- value: 'left',
535
- label: 'left'
536
- },
537
- {
538
- value: 'center',
539
- label: 'center'
540
- },
541
- {
542
- value: 'right',
543
- label: 'right'
544
- }
545
- ],
546
- fieldTypeOptions: [
547
- {
548
- value: 'text',
549
- label: 'Text'
550
- },
551
- {
552
- value: 'number',
553
- label: 'Number'
554
- },
555
- {
556
- value: 'date',
557
- label: 'Date'
558
- }
559
- ],
560
- op: [
561
- {
562
- label: 'Date Format',
563
- options: [
564
- {
565
- value: 'd1',
566
- label: 'yyyy-MM-dd'
567
- },
568
- {
569
- value: 'd2',
570
- label: 'yyyy/MM/dd'
571
- },
572
- {
573
- value: 'd3',
574
- label: 'yyyy年MM月dd日'
575
- },
576
- {
577
- value: 'd4',
578
- label: 'yyyy-MM-dd HH:mm:ss'
579
- },
580
- {
581
- value: 'd5',
582
- label: 'yyyy-MM-dd hh:mm:ss'
583
- }
584
- ]
585
- },
586
- {
587
- label: 'Number Format',
588
- options: [
589
- {
590
- value: 'n1',
591
- label: '###,###,###,##0.######'
592
- },
593
- {
594
- value: 'n2',
595
- label: '###,###,###,##0.00####'
596
- },
597
- {
598
- value: 'n3',
599
- label: '###,###,###,##0.000000'
600
- },
601
- {
602
- value: 'n4',
603
- label: '###,###,###,##0.000'
604
- },
605
- {
606
- value: 'n5',
607
- label: '###,###,###,##0.00'
608
- },
609
- {
610
- value: 'n6',
611
- label: '###,###,###,##0'
612
- },
613
- {
614
- value: 'n7',
615
- label: '###,##0.00##%'
616
- }
617
- ]
618
- },
619
- {
620
- label: 'edit Format',
621
- options: [
622
- {
623
- value: 'editInput',
624
- label: '文本输入框'
625
- },
626
- {
627
- value: 'editNumber',
628
- label: '数字输入框'
629
- },
630
- {
631
- value: 'editDate',
632
- label: '日期输入框'
633
- },
634
- {
635
- value: 'editSelect',
636
- label: '下拉框'
637
- },
638
- {
639
- value: 'editSearch',
640
- label: '搜索框'
641
- },
642
- {
643
- value: 'editDelete',
644
- label: '删除按钮'
645
- },
646
- {
647
- value: 'editButton',
648
- label: '查看按钮'
649
- }
650
- ]
651
- },
652
- ],
653
- columnFormatMap: {
654
- editInput: 'input',
655
- editNumber: 'number',
656
- editDate: 'date',
657
- editSelect: 'select',
658
- editSearch: 'vabsearch'
659
- },
660
- showRenderDialogFlag: !1,
661
- renderJson: '',
662
- currentTableColumn: null,
663
- nameRules: [
664
- {
665
- required: !0,
666
- trigger: ['blur', 'change'],
667
- message: this.i18nt('designer.setting.fieldValueRequired')
668
- }
669
- ],
670
- showSqlEditDialog: false,
671
- dataSourceSql: "",
672
- showRequestaccessDialog: false,
673
- showDateConfigDialog: false,
674
- columnOption: {},
675
- dateFieldList: [],
676
- columnSelectedWidget: {},
677
- // reportTemplate:{}
678
-
679
- showFieldTreeDialog: false,
680
- treeData: [],
681
- defaultProps: {
682
- children: 'children',
683
- label: 'label'
684
- },
685
- defaultCheckedKeys: [],
686
- tableConfigParams: ["dataId", "formCode"]
687
- };
688
- },
689
- computed: {
690
- dataSourceList: function () {
691
- return this.designer.formConfig && this.designer.formConfig.dataSources ? this.designer.formConfig.dataSources : [];
692
- },
693
- reportTemplate: function () {
694
- return this.getReportTemplate();
695
- }
696
- },
697
- created: function () {
698
- // this.reportTemplate = this.getReportTemplate();
699
- var e = this;
700
- (this.cssClassList = deepClone(this.designer.getCssClassList())),
701
- this.designer.handleEvent('form-css-updated', function (t) {
702
- e.cssClassList = t;
703
- });
704
- if (this.optionModel.showExportBtn == null) this.$set(this.optionModel, 'showExportBtn', true);
705
- if (this.optionModel.tableConfig === void 0) this.$set(this.optionModel, 'tableConfig', "");
706
- },
707
- mounted: function () {
708
- /*let dateFieldList = Object.keys(dateFieldComponents);
709
- this.dateFieldList = dateFieldList;*/
710
- },
711
- methods: {
712
-
713
- dragSort: function () {
714
- var e = this.$refs.singleTable.$el.querySelectorAll('.el-table__body-wrapper > table > tbody')[0],
715
- t = this.optionModel.tableColumns;
716
- this.sortable = Sortable.create(e, {
717
- ghostClass: 'sortable-ghost',
718
- setData: function (e) {
719
- e.setData('Text', '');
720
- },
721
- onEnd: function (e) {
722
- var i = t.splice(e.oldIndex, 1)[0];
723
- t.splice(e.newIndex, 0, i);
724
- t[e.newIndex].id;
725
- t[e.newIndex - 1] && t[e.newIndex - 1].id, t[e.newIndex + 1] && t[e.newIndex + 1].id;
726
- }
727
- });
728
- },
729
- openTableDataEdit: function () {
730
- (this.dataDialogVisible = !0), (this.tableDataOptions = JSON.stringify(this.optionModel.tableData, null, ' '));
731
- },
732
- saveTableData: function () {
733
- try {
734
- (this.optionModel.tableData = JSON.parse(this.tableDataOptions)), (this.dataDialogVisible = !1);
735
- } catch (e) {
736
- this.$message.error(this.i18nt('designer.hint.invalidOptionsData') + e.message);
737
- }
738
- },
739
- openSetting: function () {
740
- var e = this;
741
- (this.dialogVisible = !0)/*,
742
- this.$nextTick(function () {
743
- e.dragSort();
744
- });*/
745
- },
746
- colSubmit: function () {
747
- this.dialogVisible = !1;
748
- },
749
- addCol: function () {
750
- let tmpId = 'column' + generateId();
751
- var e = {
752
- columnId: new Date().getTime(),
753
- required: false,
754
- width: 150,
755
- prop: tmpId,
756
- label: tmpId,
757
- align: "left",
758
- show: true,
759
- sortable: true
760
- };
761
- this.optionModel.tableColumns.push(e), this.designer.emitHistoryChange();
762
- },
763
- handleDelete: function (e, t) {
764
- if (1 === this.optionModel.tableColumns.length) return this.$message.warning(this.i18nt('designer.setting.onlyOneColumnCannotBeDeleted')), !1;
765
- this.optionModel.tableColumns.splice(e, 1);
766
- },
767
- showRenderDialog: function (e) {
768
- (this.currentTableColumn = e), (this.renderJson = e.render || ''), (this.showRenderDialogFlag = !0);
769
- },
770
- saveColumnRender: function () {
771
- this.$set(this.currentTableColumn, 'render', this.renderJson), (this.showRenderDialogFlag = !1);
772
- },
773
- handleShowButtonsColumnChange: function (e) {
774
- if (e) {
775
- var t = this.designer.formWidget.getSelectedWidgetRef();
776
- t &&
777
- t.refreshLayout &&
778
- this.$nextTick(function () {
779
- t.refreshLayout();
780
- });
781
- }
782
- },
783
- onButtonNameFocus: function (e) {
784
- console.log('test', e), (this.oldButtonName = e.target.value);
785
- },
786
- onButtonNameChange: function (e, t) {
787
- var i = !1;
788
- this.optionModel.operationButtons.map(function (n, o) {
789
- n.name === e && o !== t && (i = !0);
790
- }),
791
- i && (this.$message.error(this.i18nt('designer.setting.operationButtonDuplicatedNameError')), (this.optionModel.operationButtons[t].name = this.oldButtonName));
792
- },
793
- editButtonsColumn: function () {
794
- this.showButtonsEditDialog = !0;
795
- },
796
- deleteOperationButton: function (e) {
797
- var t = this;
798
- this.$confirm(this.i18nt('designer.setting.deleteOperationButtonHint'), this.i18nt('render.hint.prompt'), {
799
- confirmButtonText: this.i18nt('render.hint.confirm'),
800
- cancelButtonText: this.i18nt('render.hint.cancel')
801
- })
802
- .then(function () {
803
- t.optionModel.operationButtons.splice(e, 1);
804
- })
805
- .catch(function (e) {
806
- });
807
- },
808
- addOperationButton: function () {
809
- this.$set(this.optionModel, 'operationButtons', this.optionModel.operationButtons || []),
810
- this.optionModel.operationButtons.push({
811
- name: 'btn' + generateId(),
812
- label: 'new btn',
813
- type: 'text',
814
- size: 'small',
815
- round: !1,
816
- hidden: !1,
817
- disabled: !1
818
- });
819
- },
820
- refreshTableLayout: function () {
821
- var e = this.designer.formWidget.getSelectedWidgetRef();
822
- e &&
823
- e.refreshLayout &&
824
- this.$nextTick(function () {
825
- e.refreshLayout();
826
- });
827
- },
828
- saveDataSourceSql() {
829
- this.optionModel.dataSourceSql = this.dataSourceSql;
830
- this.showSqlEditDialog = false;
831
- },
832
- openSqlEditDialog() {
833
- this.dataSourceSql = this.optionModel.dataSourceSql ? deepClone(this.optionModel.dataSourceSql) : "";
834
- this.showSqlEditDialog = true;
835
- },
836
- confirmInsertRequestaccess(rows) {
837
- if (rows.length) {
838
- let row = rows[0];
839
- this.optionModel.accessName = row.accessName;
840
- this.optionModel.accessCode = row.accessCode;
841
- }
842
- },
843
- changeFormatS(row) {
844
- let columnWidgetConfig = this.getColumnWidgetConfig(row, true);
845
- let {columnSelectedWidget, columnEditFields} = columnWidgetConfig;
846
- if (columnSelectedWidget) {
847
- row.columnOption = columnSelectedWidget.options;
848
- } else {
849
- row.columnOption = {}
850
- }
851
- if (row.formatS == 'editDelete' || row.formatS == 'editButton') {
852
- row.width = 47;
853
- row.prop = null;
854
- row.label = null;
855
- row.sortable = false;
856
- } else {
857
- let tmpId = 'column' + generateId();
858
- if (!row.width || row.width == 47) row.width = 150;
859
- if (!row.prop) row.prop = tmpId;
860
- if (!row.label) row.label = tmpId;
861
- row.sortable = true;
862
- }
863
- },
864
- getColumnWidgetConfig(row, isChange) {
865
- let formatS = row.formatS
866
- let columnSelectedWidget = null;
867
- let columnEditFields = null;
868
-
869
- let type = this.columnFormatMap[row.formatS];
870
- /*if (type == 'date') {
871
- columnEditFields = ['type', 'format', 'valueFormat']
872
- } else if (type == 'select') {
873
-
874
- }
875
- if (type == 'vabsearch') {
876
- columnEditFields = ['vabSearchField', 'formCode', 'formVersion', 'required', 'showFormField', 'onSearchConfirm', 'onSearchClear']
877
- }*/
878
-
879
- if (type) {
880
- columnSelectedWidget = this.$baseLodash.cloneDeep(this.designer.getFieldWidgetByType(type));
881
- let tmpId = generateId();
882
- let idVal = row.prop ? row.prop : (type + tmpId);
883
- columnSelectedWidget.id = idVal;
884
- columnSelectedWidget.options.name = idVal;
885
- if (!isChange && row.columnOption && Object.keys(row.columnOption).length) {
886
- row.columnOption.required = row.required || false;
887
- columnSelectedWidget.options = row.columnOption;
888
- } else {
889
- columnSelectedWidget.options.required = row.required || false;
890
- row.columnOption = columnSelectedWidget.options;
891
- }
892
- columnSelectedWidget.options.name = row.prop;
893
- columnSelectedWidget.options.label = row.label;
894
- columnSelectedWidget.options.labelHidden = true;
895
-
896
- }
897
- return {columnSelectedWidget, columnEditFields};
898
- },
899
- openFormatConfigDialog(row, index) {
900
- let option = row.columnOption;
901
- let selectedWidget;
902
- let columnWidgetConfig = this.getColumnWidgetConfig(row);
903
- let {columnSelectedWidget, columnEditFields} = columnWidgetConfig;
904
- if (columnSelectedWidget) {
905
- option = columnSelectedWidget.options;
906
- selectedWidget = columnSelectedWidget;
907
- } else {
908
- option = {}
909
- selectedWidget = {};
910
- }
911
-
912
- let columnOption = this.$baseLodash.cloneDeep(option);
913
- row.columnOption = columnOption;
914
- this.operateIndex = index;
915
-
916
- this.openWidgetPropertyDialog({
917
- row: row,
918
- columnSelectedWidget: selectedWidget,
919
- index: index,
920
- columnEditFields: columnEditFields,
921
- callback: (columnOption) => {
922
- this.confirmFormatConfigDialog(columnOption);
923
- }
924
- })
925
- },
926
- confirmFormatConfigDialog(columnOption) {
927
- let row = this.optionModel.tableColumns[this.operateIndex];
928
- row.columnOption = columnOption;
929
- row.prop = columnOption.name;
930
- row.label = columnOption.label;
931
- row.required = columnOption.required;
932
- },
933
- openFieldTreeDialog() {
934
- this.treeData = [{
935
- "name": "Jinjilianxiren",
936
- "label": "员工-紧急联系人",
937
- children: [
938
- {
939
- "detailEntity": "Jinjilianxiren",
940
- "name": "createdOn",
941
- "label": "员工-紧急联系人.创建时间",
942
- "type": "DateTime",
943
- "required": "1"
944
- }, /*{
945
- "searchDialogWidth": "520px",
946
- "detailEntity": "Jinjilianxiren",
947
- "name": "createdBy",
948
- "label": "员工-紧急联系人.创建用户",
949
- "type": "Reference",
950
- "required": "1"
951
- },*/ {
952
- "detailEntity": "Jinjilianxiren",
953
- "name": "modifiedOn",
954
- "label": "员工-紧急联系人.最近修改时间",
955
- "type": "DateTime",
956
- "required": "0"
957
- }, /*{
958
- "searchDialogWidth": "520px",
959
- "detailEntity": "Jinjilianxiren",
960
- "name": "modifiedBy",
961
- "label": "员工-紧急联系人.修改用户",
962
- "type": "Reference",
963
- "required": "0"
964
- }, {
965
- "searchDialogWidth": "520px",
966
- "detailEntity": "Jinjilianxiren",
967
- "name": "mdYuangongdanganId",
968
- "label": "员工-紧急联系人.主从关联Id",
969
- "type": "Reference",
970
- "required": "1"
971
- },*/ {
972
- "detailEntity": "Jinjilianxiren",
973
- "name": "shouji",
974
- "label": "员工-紧急联系人.手机",
975
- "type": "Text",
976
- "required": "0",
977
- "maxLength": "200"
978
- }, {
979
- "detailEntity": "Jinjilianxiren",
980
- "name": "jinjilianxirenxingming",
981
- "label": "员工-紧急联系人.紧急联系人姓名",
982
- "type": "Text",
983
- "required": "0",
984
- "maxLength": "200"
985
- }]
986
- }];
987
-
988
- let fields = this.optionModel.tableColumns.filter(item => !!item.prop).map(item => item.prop);
989
- let defaultCheckedKeys = [];
990
- this.treeData.forEach(item1 => {
991
- item1.children.forEach(item2 => {
992
- if (fields.includes(item2.name) && !defaultCheckedKeys.includes(item2.name)) {
993
- defaultCheckedKeys.push(item2.name)
994
- }
995
- })
996
- })
997
- this.defaultCheckedKeys = defaultCheckedKeys
998
- this.showFieldTreeDialog = true;
999
- },
1000
- confirmFieldTreeDialog() {
1001
- // defaultCheckedKeys
1002
- let fields = this.optionModel.tableColumns.filter(item => !!item.prop).map(item => item.prop);
1003
- let datas = this.$refs.tree.getCheckedNodes(true, false);
1004
- datas.filter(item => !fields.includes(item.name)).forEach(item => {
1005
- this.addCol2(item);
1006
- });
1007
- this.designer.emitHistoryChange();
1008
- this.showFieldTreeDialog = false;
1009
- },
1010
- addCol2: function (item) {
1011
- let tmpId = 'column' + generateId();
1012
- var e = {
1013
- columnId: new Date().getTime(),
1014
- required: false,
1015
- width: 150,
1016
- prop: item.name,
1017
- label: item.label,
1018
- show: true,
1019
- sortable: true
1020
- };
1021
- this.optionModel.tableColumns.push(e)
1022
- },
1023
- openTableConfigDialog() {
1024
- this.eventHeader = `${this.optionModel.name}.${eventName}(${eventParams.join(', ')}) {`;
1025
- this.eventHandlerCode = selectedWidget.options[eventName] || '';
1026
- this.showTableConfigDialog = true;
1027
- },
1028
- downloadExcel() {
1029
- let defaultUrl = 'http://file.sc.5mall.com/download/repo1/b/mk1/2024/12/13/b2aea548-a9a8-4dca-bba7-8d9c6134ebe3.xlsx';
1030
- let xformImportTemplateFile = setttingConfig.xformImportTemplateFile || defaultUrl;
1031
- if (!xformImportTemplateFile) return;
1032
- this.$commonFileUtil.downloadFile(xformImportTemplateFile, "通用导入模板.xlsx");
1033
- }
1034
- }
1035
- };
1036
- </script>
1037
-
1038
- <style>
1039
- .icon-drag:before {
1040
- content: '\e61d';
1041
- }
1042
- </style>
1
+ <template>
2
+ <div>
3
+ <el-form-item :label="i18nt('designer.setting.tableWidth')">
4
+ <el-input v-model="optionModel.tableWidth"></el-input>
5
+ </el-form-item>
6
+ <el-form-item :label="i18nt('designer.setting.tableHeight')">
7
+ <el-input v-model="optionModel.tableHeight"></el-input>
8
+ </el-form-item>
9
+ <el-form-item label="行高度(px)">
10
+ <el-input v-model="optionModel.tableRowHeight"></el-input>
11
+ </el-form-item>
12
+ <!-- <el-form-item :label="i18nt('designer.setting.customClass')">
13
+ <el-select v-model="optionModel.customClass" multiple="" filterable="" allow-create="" default-first-option="">
14
+ <el-option v-for="(e, t) in cssClassList" :key="t" :value="e" :label="e"></el-option>
15
+ </el-select>
16
+ </el-form-item>-->
17
+ <!-- <el-form-item :label="i18nt('designer.setting.showIndex')"><el-switch v-model="optionModel.showIndex"></el-switch></el-form-item>
18
+ <el-form-item :label="i18nt('designer.setting.showCheckBox')"><el-switch v-model="optionModel.showCheckBox"></el-switch></el-form-item> -->
19
+ <el-form-item label="启用数据行合并">
20
+ <el-switch v-model="optionModel.mergeRowEnabled"></el-switch>
21
+ </el-form-item>
22
+ <el-form-item :label="i18nt('合并行唯一字段')">
23
+ <el-input v-model="optionModel.mergeRowKey"></el-input>
24
+ </el-form-item>
25
+ <el-form-item label="查询列表">
26
+ <el-switch v-model="optionModel.isQueryTable"></el-switch>
27
+ </el-form-item>
28
+ <el-form-item label="切换tab时自动查询">
29
+ <el-switch v-model="optionModel.searchOnSwitchTab"></el-switch>
30
+ </el-form-item>
31
+ <el-form-item label="是否显示查询按钮">
32
+ <el-switch v-model="isShowQueryButton"></el-switch>
33
+ </el-form-item>
34
+ <el-form-item :label="i18nt('designer.setting.showPagination')">
35
+ <el-switch v-model="optionModel.showPagination"></el-switch>
36
+ </el-form-item>
37
+ <el-form-item :label="i18nt('是否显示表尾统计行')">
38
+ <el-switch v-model="optionModel.showGridFooter"></el-switch>
39
+ </el-form-item>
40
+ <el-form-item :label="i18nt('是否隐藏复选框')">
41
+ <el-switch v-model="optionModel.hideGridCheckBox"></el-switch>
42
+ </el-form-item>
43
+ <el-form-item label="是否查询总页数">
44
+ <el-switch v-model="isQueryAllPage"></el-switch>
45
+ </el-form-item>
46
+ <el-form-item label="默认每页查询数">
47
+ <base-input-number
48
+ v-model="optionModel.gridPageSize"
49
+ size="mini"
50
+ :max="10000"
51
+ />
52
+ </el-form-item>
53
+ <el-form-item :label="i18nt('可选择每页查询数')"></el-form-item>
54
+ <el-form-item label-width="0">
55
+ <template v-if="optionModel.gridPageSizeList">
56
+ <draggable
57
+ tag="ul"
58
+ class="draggable-box"
59
+ :list="optionModel.gridPageSizeList"
60
+ v-bind="{
61
+ group: 'optionsGroup',
62
+ ghostClass: 'ghost',
63
+ handle: '.drag-option',
64
+ }"
65
+ >
66
+ <li
67
+ v-for="(item, index) in optionModel.gridPageSizeList"
68
+ :key="index"
69
+ class="col-item"
70
+ >
71
+ <i class="el-icon-s-operation drag-option"></i>
72
+ <base-input-number
73
+ v-model="item.value"
74
+ :min="1"
75
+ :max="10000"
76
+ style="width: 200px"
77
+ ></base-input-number>
78
+ <el-button
79
+ circle
80
+ plain
81
+ size="mini"
82
+ type="danger"
83
+ @click="optionModel.gridPageSizeList.splice(index, 1)"
84
+ icon="el-icon-minus"
85
+ class="col-delete-button"
86
+ style="position: unset"
87
+ ></el-button>
88
+ </li>
89
+ </draggable>
90
+ </template>
91
+ <div>
92
+ <el-button
93
+ type="text"
94
+ @click="addGridPageSizeList"
95
+ icon="el-icon-circle-plus-outline"
96
+ class="add-option"
97
+ >
98
+ {{ i18nt("新增分页数") }}
99
+ </el-button>
100
+ </div>
101
+ </el-form-item>
102
+
103
+ <!-- <el-form-item :label="i18nt('显示导出')">
104
+ <el-switch v-model="optionModel.showExportBtn"></el-switch>
105
+ </el-form-item>-->
106
+ <!-- <el-form-item :label="i18nt('显示搜索栏')">
107
+ <el-switch v-model="optionModel.showSearchArea"></el-switch>
108
+ </el-form-item>-->
109
+ <!-- <el-form-item :label="i18nt('designer.setting.smallPagination')"><el-switch v-model="optionModel.smallPagination"></el-switch></el-form-item>
110
+ <el-form-item :label="i18nt('designer.setting.showSummary')"><el-switch v-model="optionModel.showSummary"></el-switch></el-form-item>
111
+ <el-form-item :label="i18nt('designer.setting.stripe')"><el-switch v-model="optionModel.stripe"></el-switch></el-form-item>
112
+ <el-form-item :label="i18nt('designer.setting.rowSpacing')">
113
+ <el-input-number style="width:100%;" controls-position="right" :min="0" :max="20" v-model="optionModel.rowSpacing"></el-input-number>
114
+ </el-form-item>
115
+ <el-form-item :label="i18nt('designer.setting.widgetSize')">
116
+ <el-select v-model="optionModel.tableSize" @change="refreshTableLayout">
117
+ <el-option v-for="e in widgetSizes" :key="e.value" :value="e.value" :label="e.label"></el-option>
118
+ </el-select>
119
+ </el-form-item> -->
120
+ <el-form-item :label="i18nt('designer.setting.tableColEdit')">
121
+ <el-button type="primary" plain="" round="" @click="openSetting"
122
+ >{{ i18nt("designer.setting.editAction") }}
123
+ </el-button>
124
+ </el-form-item>
125
+ <el-form-item label="自定义表格配置" label-width="150px">
126
+ <a
127
+ href="javascript:void(0);"
128
+ class="a-link link-oneLind"
129
+ @click="editEventHandler('tableConfig', tableConfigParams)"
130
+ >
131
+ <span>{{ optionModel.tableConfig }}</span>
132
+ <i class="el-icon-edit"></i>
133
+ </a>
134
+ </el-form-item>
135
+ <el-form-item label-width="0">
136
+ <el-divider class="custom-divider-margin-top">编辑表格设置</el-divider>
137
+ </el-form-item>
138
+ <el-form-item :label="i18nt('编辑表格')">
139
+ <el-switch v-model="optionModel.isEditTable"></el-switch>
140
+ </el-form-item>
141
+ <el-form-item :label="i18nt('树表格')">
142
+ <el-switch v-model="optionModel.isTreeTable"></el-switch>
143
+ </el-form-item>
144
+ <el-form-item :label="i18nt('启用WBS码')">
145
+ <el-switch v-model="optionModel.wbsEnabled"></el-switch>
146
+ </el-form-item>
147
+ <el-form-item :label="i18nt('排序脚本编码')" v-if="optionModel.isEditTable">
148
+ <el-input v-model="optionModel.sortScriptCode"></el-input>
149
+ </el-form-item>
150
+ <el-form-item label-width="0">
151
+ <el-divider class="custom-divider-margin-top">明细导出设置</el-divider>
152
+ </el-form-item>
153
+ <el-form-item :label="i18nt('明细导出脚本编码')">
154
+ <el-input v-model="optionModel.exportItemScriptCode"></el-input>
155
+ </el-form-item>
156
+ <el-form-item label="自定义明细导出参数" label-width="150px">
157
+ <a
158
+ href="javascript:void(0);"
159
+ class="a-link link-oneLind"
160
+ @click="editEventHandler('exportItemParam', tableConfigParams)"
161
+ >
162
+ <span>{{ optionModel.exportItemParam }}</span>
163
+ <i class="el-icon-edit"></i>
164
+ </a>
165
+ </el-form-item>
166
+ <el-form-item label="明细导出列维护" label-width="150px">
167
+ <a
168
+ href="javascript:void(0);"
169
+ class="a-link link-oneLind"
170
+ @click="openExportItemColumnsDialog"
171
+ >
172
+ <span>{{
173
+ optionModel.exportItemColumns && optionModel.exportItemColumns.length
174
+ ? "已维护"
175
+ : null
176
+ }}</span>
177
+ <i class="el-icon-edit"></i>
178
+ </a>
179
+ </el-form-item>
180
+
181
+ <el-dialog
182
+ v-if="dataDialogVisible"
183
+ custom-class="dialog-style list-dialog"
184
+ :title="i18nt('designer.setting.tableDataEdit')"
185
+ :visible.sync="dataDialogVisible"
186
+ :show-close="!0"
187
+ append-to-body=""
188
+ :close-on-click-modal="!1"
189
+ :close-on-press-escape="!1"
190
+ :destroy-on-close="!0"
191
+ width="75%"
192
+ v-dialog-drag
193
+ >
194
+ <template slot="footer">
195
+ <div class="dialog-footer">
196
+ <el-button
197
+ type=""
198
+ @click="dataDialogVisible = !1"
199
+ class="button-sty"
200
+ icon="el-icon-close"
201
+ >
202
+ {{ i18nt("designer.hint.cancel") }}
203
+ </el-button>
204
+ <el-button
205
+ type="primary"
206
+ @click="saveTableData"
207
+ class="button-sty"
208
+ icon="el-icon-check"
209
+ >
210
+ {{ i18nt("designer.hint.confirm") }}
211
+ </el-button>
212
+ </div>
213
+ </template>
214
+ <code-editor
215
+ mode="json"
216
+ :readonly="!1"
217
+ v-model="tableDataOptions"
218
+ ></code-editor>
219
+ </el-dialog>
220
+ <el-dialog
221
+ v-if="showSqlEditDialog"
222
+ :title="i18nt('数据源SQL编辑')"
223
+ :visible.sync="showSqlEditDialog"
224
+ append-to-body=""
225
+ :show-close="!0"
226
+ custom-class="dialog-style list-dialog"
227
+ :close-on-click-modal="!1"
228
+ :close-on-press-escape="!1"
229
+ :destroy-on-close="!0"
230
+ v-dialog-drag
231
+ >
232
+ <el-alert type="info" :closable="!1" />
233
+ <code-editor
234
+ ref="dsResultEditor"
235
+ mode="javascript"
236
+ :readonly="!1"
237
+ v-model="dataSourceSql"
238
+ ></code-editor>
239
+ <el-alert type="info" :closable="!1" />
240
+ <div class="dialog-footer" slot="footer">
241
+ <el-button
242
+ @click="showSqlEditDialog = !1"
243
+ class="button-sty"
244
+ icon="el-icon-close"
245
+ >
246
+ {{ i18nt("designer.hint.cancel") }}
247
+ </el-button>
248
+ <el-button
249
+ type="primary"
250
+ @click="saveDataSourceSql"
251
+ class="button-sty"
252
+ icon="el-icon-check"
253
+ >
254
+ {{ i18nt("designer.hint.confirm") }}
255
+ </el-button>
256
+ </div>
257
+ </el-dialog>
258
+ <requestaccessDialog
259
+ v-if="showRequestaccessDialog"
260
+ :visiable.sync="showRequestaccessDialog"
261
+ @confirm="confirmInsertRequestaccess"
262
+ multi="false"
263
+ :param="{ reportCode: reportTemplate.reportCode }"
264
+ />
265
+
266
+ <el-dialog
267
+ v-if="showFieldTreeDialog"
268
+ custom-class="dialog-style list-dialog"
269
+ title="新增列表列"
270
+ :visible.sync="showFieldTreeDialog"
271
+ :show-close="!0"
272
+ :append-to-body="false"
273
+ :modal="false"
274
+ :close-on-click-modal="!1"
275
+ :close-on-press-escape="!1"
276
+ :destroy-on-close="!0"
277
+ width="500px"
278
+ v-dialog-drag
279
+ >
280
+ <div class="cont" style="height: 500px">
281
+ <el-tree
282
+ ref="tree"
283
+ :data="treeData"
284
+ show-checkbox
285
+ node-key="name"
286
+ :default-expand-all="true"
287
+ :check-on-click-node="true"
288
+ :expand-on-click-node="false"
289
+ :default-checked-keys="defaultCheckedKeys"
290
+ :props="defaultProps"
291
+ >
292
+ </el-tree>
293
+ </div>
294
+ <span slot="footer" class="dialog-footer">
295
+ <el-button
296
+ type="primary"
297
+ plain
298
+ class="button-sty"
299
+ @click="showFieldTreeDialog = false"
300
+ >
301
+ <i class="el-icon-close el-icon"></i>
302
+ 取 消
303
+ </el-button>
304
+ <el-button
305
+ type="primary"
306
+ @click="confirmFieldTreeDialog"
307
+ class="button-sty"
308
+ >
309
+ <i class="el-icon-check el-icon"></i>
310
+
311
+ </el-button>
312
+ </span>
313
+ </el-dialog>
314
+ <tableColumnDialog
315
+ v-if="dialogVisible"
316
+ :visiable.sync="dialogVisible"
317
+ :designer="designer"
318
+ :selectedWidget="selectedWidget"
319
+ :optionModel="optionModel"
320
+ />
321
+ <exportItemColumnsDialog
322
+ v-if="showExportItemColumnsDialog"
323
+ :visiable.sync="showExportItemColumnsDialog"
324
+ :designer="designer"
325
+ :selectedWidget="selectedWidget"
326
+ :optionModel="optionModel"
327
+ />
328
+ </div>
329
+ </template>
330
+
331
+ <script>
332
+ import i18n from "../../../../../../components/xform/utils/i18n";
333
+ import Draggable from "vuedraggable";
334
+ import {
335
+ deepClone,
336
+ generateId,
337
+ } from "../../../../../../components/xform/utils/util";
338
+ import Sortable from "sortablejs";
339
+ import requestaccessDialog from "../../../../../../views/user/form/report_requestaccess/dialog.vue";
340
+ // import conditionEditor from "./condition-editor.vue";
341
+ import tableColumnDialog from "./table-column-dialog.vue";
342
+ import eventMixin from "../../../../../../components/xform/form-designer/setting-panel/property-editor/event-handler/eventMixin";
343
+ import setttingConfig from "@/settings";
344
+
345
+ import exportItemColumnsDialog from "./exportItemColumns-dialog.vue";
346
+
347
+ export default {
348
+ name: "data-table-editor",
349
+ componentName: "PropertyEditor",
350
+ mixins: [i18n, eventMixin],
351
+ components: {
352
+ Draggable,
353
+ requestaccessDialog,
354
+ // conditionEditor,
355
+ tableColumnDialog,
356
+ exportItemColumnsDialog,
357
+ },
358
+ props: {
359
+ designer: Object,
360
+ selectedWidget: Object,
361
+ optionModel: Object,
362
+ },
363
+ inject: [
364
+ "getReportTemplate",
365
+ "showEventCollapse",
366
+ "openWidgetPropertyDialog",
367
+ ],
368
+ data: function () {
369
+ return {
370
+ showTableConfigDialog: false,
371
+ tableConfigCode: null,
372
+ dialogVisible: !1,
373
+ dataDialogVisible: !1,
374
+ showButtonsEditDialog: !1,
375
+ oldButtonName: "",
376
+ cssClassList: [],
377
+ tableDataOptions: [],
378
+ widgetSizes: [
379
+ {
380
+ label: "default",
381
+ value: "",
382
+ },
383
+ {
384
+ label: "large",
385
+ value: "large",
386
+ },
387
+ {
388
+ label: "medium",
389
+ value: "medium",
390
+ },
391
+ {
392
+ label: "small",
393
+ value: "small",
394
+ },
395
+ {
396
+ label: "mini",
397
+ value: "mini",
398
+ },
399
+ ],
400
+ alignOptions: [
401
+ {
402
+ value: "left",
403
+ label: "left",
404
+ },
405
+ {
406
+ value: "center",
407
+ label: "center",
408
+ },
409
+ {
410
+ value: "right",
411
+ label: "right",
412
+ },
413
+ ],
414
+ fieldTypeOptions: [
415
+ {
416
+ value: "text",
417
+ label: "Text",
418
+ },
419
+ {
420
+ value: "number",
421
+ label: "Number",
422
+ },
423
+ {
424
+ value: "date",
425
+ label: "Date",
426
+ },
427
+ ],
428
+ op: [
429
+ {
430
+ label: "Date Format",
431
+ options: [
432
+ {
433
+ value: "d1",
434
+ label: "yyyy-MM-dd",
435
+ },
436
+ {
437
+ value: "d2",
438
+ label: "yyyy/MM/dd",
439
+ },
440
+ {
441
+ value: "d3",
442
+ label: "yyyy年MM月dd日",
443
+ },
444
+ {
445
+ value: "d4",
446
+ label: "yyyy-MM-dd HH:mm:ss",
447
+ },
448
+ {
449
+ value: "d5",
450
+ label: "yyyy-MM-dd hh:mm:ss",
451
+ },
452
+ ],
453
+ },
454
+ {
455
+ label: "Number Format",
456
+ options: [
457
+ {
458
+ value: "n1",
459
+ label: "###,###,###,##0.######",
460
+ },
461
+ {
462
+ value: "n2",
463
+ label: "###,###,###,##0.00####",
464
+ },
465
+ {
466
+ value: "n3",
467
+ label: "###,###,###,##0.000000",
468
+ },
469
+ {
470
+ value: "n4",
471
+ label: "###,###,###,##0.000",
472
+ },
473
+ {
474
+ value: "n5",
475
+ label: "###,###,###,##0.00",
476
+ },
477
+ {
478
+ value: "n6",
479
+ label: "###,###,###,##0",
480
+ },
481
+ {
482
+ value: "n7",
483
+ label: "###,##0.00##%",
484
+ },
485
+ ],
486
+ },
487
+ {
488
+ label: "edit Format",
489
+ options: [
490
+ {
491
+ value: "editInput",
492
+ label: "文本输入框",
493
+ },
494
+ {
495
+ value: "editNumber",
496
+ label: "数字输入框",
497
+ },
498
+ {
499
+ value: "editDate",
500
+ label: "日期输入框",
501
+ },
502
+ {
503
+ value: "editSelect",
504
+ label: "下拉框",
505
+ },
506
+ {
507
+ value: "editSearch",
508
+ label: "搜索框",
509
+ },
510
+ {
511
+ value: "editDelete",
512
+ label: "删除按钮",
513
+ },
514
+ {
515
+ value: "editButton",
516
+ label: "查看按钮",
517
+ },
518
+ ],
519
+ },
520
+ ],
521
+ columnFormatMap: {
522
+ editInput: "input",
523
+ editNumber: "number",
524
+ editDate: "date",
525
+ editSelect: "select",
526
+ editSearch: "vabsearch",
527
+ },
528
+ showRenderDialogFlag: !1,
529
+ renderJson: "",
530
+ currentTableColumn: null,
531
+ nameRules: [
532
+ {
533
+ required: !0,
534
+ trigger: ["blur", "change"],
535
+ message: this.i18nt("designer.setting.fieldValueRequired"),
536
+ },
537
+ ],
538
+ showSqlEditDialog: false,
539
+ dataSourceSql: "",
540
+ showRequestaccessDialog: false,
541
+ showDateConfigDialog: false,
542
+ columnOption: {},
543
+ dateFieldList: [],
544
+ columnSelectedWidget: {},
545
+ // reportTemplate:{}
546
+
547
+ showFieldTreeDialog: false,
548
+ treeData: [],
549
+ defaultProps: {
550
+ children: "children",
551
+ label: "label",
552
+ },
553
+ defaultCheckedKeys: [],
554
+ tableConfigParams: ["dataId", "formCode"],
555
+ showExportItemColumnsDialog: false,
556
+ };
557
+ },
558
+ computed: {
559
+ dataSourceList: function () {
560
+ return this.designer.formConfig && this.designer.formConfig.dataSources
561
+ ? this.designer.formConfig.dataSources
562
+ : [];
563
+ },
564
+ reportTemplate: function () {
565
+ return this.getReportTemplate();
566
+ },
567
+ isQueryAllPage: {
568
+ get() {
569
+ return !this.optionModel.isNotQueryAllPage;
570
+ },
571
+ set(val) {
572
+ this.optionModel.isNotQueryAllPage = !val;
573
+ },
574
+ },
575
+ isShowQueryButton: {
576
+ get() {
577
+ return !this.optionModel.isNotShowQueryButton;
578
+ },
579
+ set(val) {
580
+ this.optionModel.isNotShowQueryButton = !val;
581
+ },
582
+ },
583
+ },
584
+ created: function () {
585
+ // this.reportTemplate = this.getReportTemplate();
586
+ var e = this;
587
+ (this.cssClassList = deepClone(this.designer.getCssClassList())),
588
+ this.designer.handleEvent("form-css-updated", function (t) {
589
+ e.cssClassList = t;
590
+ });
591
+ if (this.optionModel.showExportBtn == null)
592
+ this.$set(this.optionModel, "showExportBtn", true);
593
+ if (this.optionModel.tableConfig === void 0)
594
+ this.$set(this.optionModel, "tableConfig", "");
595
+ },
596
+ mounted: function () {
597
+ /*let dateFieldList = Object.keys(dateFieldComponents);
598
+ this.dateFieldList = dateFieldList;*/
599
+ },
600
+ methods: {
601
+ dragSort: function () {
602
+ var e = this.$refs.singleTable.$el.querySelectorAll(
603
+ ".el-table__body-wrapper > table > tbody"
604
+ )[0],
605
+ t = this.optionModel.tableColumns;
606
+ this.sortable = Sortable.create(e, {
607
+ ghostClass: "sortable-ghost",
608
+ setData: function (e) {
609
+ e.setData("Text", "");
610
+ },
611
+ onEnd: function (e) {
612
+ var i = t.splice(e.oldIndex, 1)[0];
613
+ t.splice(e.newIndex, 0, i);
614
+ t[e.newIndex].id;
615
+ t[e.newIndex - 1] && t[e.newIndex - 1].id,
616
+ t[e.newIndex + 1] && t[e.newIndex + 1].id;
617
+ },
618
+ });
619
+ },
620
+ openTableDataEdit: function () {
621
+ (this.dataDialogVisible = !0),
622
+ (this.tableDataOptions = JSON.stringify(
623
+ this.optionModel.tableData,
624
+ null,
625
+ " "
626
+ ));
627
+ },
628
+ saveTableData: function () {
629
+ try {
630
+ (this.optionModel.tableData = JSON.parse(this.tableDataOptions)),
631
+ (this.dataDialogVisible = !1);
632
+ } catch (e) {
633
+ this.$message.error(
634
+ this.i18nt("designer.hint.invalidOptionsData") + e.message
635
+ );
636
+ }
637
+ },
638
+ openSetting: function () {
639
+ var e = this;
640
+ this.dialogVisible = !0; /*,
641
+ this.$nextTick(function () {
642
+ e.dragSort();
643
+ });*/
644
+ },
645
+ colSubmit: function () {
646
+ this.dialogVisible = !1;
647
+ },
648
+ addCol: function () {
649
+ let tmpId = "column" + generateId();
650
+ var e = {
651
+ columnId: new Date().getTime(),
652
+ required: false,
653
+ width: 150,
654
+ prop: tmpId,
655
+ label: tmpId,
656
+ align: "left",
657
+ show: true,
658
+ sortable: true,
659
+ };
660
+ this.optionModel.tableColumns.push(e), this.designer.emitHistoryChange();
661
+ },
662
+ handleDelete: function (e, t) {
663
+ if (1 === this.optionModel.tableColumns.length)
664
+ return (
665
+ this.$message.warning(
666
+ this.i18nt("designer.setting.onlyOneColumnCannotBeDeleted")
667
+ ),
668
+ !1
669
+ );
670
+ this.optionModel.tableColumns.splice(e, 1);
671
+ },
672
+ showRenderDialog: function (e) {
673
+ (this.currentTableColumn = e),
674
+ (this.renderJson = e.render || ""),
675
+ (this.showRenderDialogFlag = !0);
676
+ },
677
+ saveColumnRender: function () {
678
+ this.$set(this.currentTableColumn, "render", this.renderJson),
679
+ (this.showRenderDialogFlag = !1);
680
+ },
681
+ handleShowButtonsColumnChange: function (e) {
682
+ if (e) {
683
+ var t = this.designer.formWidget.getSelectedWidgetRef();
684
+ t
685
+ && t.refreshLayout
686
+ && this.$nextTick(function () {
687
+ t.refreshLayout();
688
+ });
689
+ }
690
+ },
691
+ onButtonNameFocus: function (e) {
692
+ console.log("test", e), (this.oldButtonName = e.target.value);
693
+ },
694
+ onButtonNameChange: function (e, t) {
695
+ var i = !1;
696
+ this.optionModel.operationButtons.map(function (n, o) {
697
+ n.name === e && o !== t && (i = !0);
698
+ }),
699
+ i
700
+ && (this.$message.error(
701
+ this.i18nt("designer.setting.operationButtonDuplicatedNameError")
702
+ ),
703
+ (this.optionModel.operationButtons[t].name = this.oldButtonName));
704
+ },
705
+ editButtonsColumn: function () {
706
+ this.showButtonsEditDialog = !0;
707
+ },
708
+ deleteOperationButton: function (e) {
709
+ var t = this;
710
+ this.$confirm(
711
+ this.i18nt("designer.setting.deleteOperationButtonHint"),
712
+ this.i18nt("render.hint.prompt"),
713
+ {
714
+ confirmButtonText: this.i18nt("render.hint.confirm"),
715
+ cancelButtonText: this.i18nt("render.hint.cancel"),
716
+ }
717
+ )
718
+ .then(function () {
719
+ t.optionModel.operationButtons.splice(e, 1);
720
+ })
721
+ .catch(function (e) {});
722
+ },
723
+ addOperationButton: function () {
724
+ this.$set(
725
+ this.optionModel,
726
+ "operationButtons",
727
+ this.optionModel.operationButtons || []
728
+ ),
729
+ this.optionModel.operationButtons.push({
730
+ name: "btn" + generateId(),
731
+ label: "new btn",
732
+ type: "text",
733
+ size: "small",
734
+ round: !1,
735
+ hidden: !1,
736
+ disabled: !1,
737
+ });
738
+ },
739
+ refreshTableLayout: function () {
740
+ var e = this.designer.formWidget.getSelectedWidgetRef();
741
+ e
742
+ && e.refreshLayout
743
+ && this.$nextTick(function () {
744
+ e.refreshLayout();
745
+ });
746
+ },
747
+ saveDataSourceSql() {
748
+ this.optionModel.dataSourceSql = this.dataSourceSql;
749
+ this.showSqlEditDialog = false;
750
+ },
751
+ openSqlEditDialog() {
752
+ this.dataSourceSql = this.optionModel.dataSourceSql
753
+ ? deepClone(this.optionModel.dataSourceSql)
754
+ : "";
755
+ this.showSqlEditDialog = true;
756
+ },
757
+ confirmInsertRequestaccess(rows) {
758
+ if (rows.length) {
759
+ let row = rows[0];
760
+ this.optionModel.accessName = row.accessName;
761
+ this.optionModel.accessCode = row.accessCode;
762
+ }
763
+ },
764
+ changeFormatS(row) {
765
+ let columnWidgetConfig = this.getColumnWidgetConfig(row, true);
766
+ let { columnSelectedWidget, columnEditFields } = columnWidgetConfig;
767
+ if (columnSelectedWidget) {
768
+ row.columnOption = columnSelectedWidget.options;
769
+ } else {
770
+ row.columnOption = {};
771
+ }
772
+ if (row.formatS == "editDelete" || row.formatS == "editButton") {
773
+ row.width = 47;
774
+ row.prop = null;
775
+ row.label = null;
776
+ row.sortable = false;
777
+ } else {
778
+ let tmpId = "column" + generateId();
779
+ if (!row.width || row.width == 47) row.width = 150;
780
+ if (!row.prop) row.prop = tmpId;
781
+ if (!row.label) row.label = tmpId;
782
+ row.sortable = true;
783
+ }
784
+ },
785
+ getColumnWidgetConfig(row, isChange) {
786
+ let formatS = row.formatS;
787
+ let columnSelectedWidget = null;
788
+ let columnEditFields = null;
789
+
790
+ let type = this.columnFormatMap[row.formatS];
791
+
792
+ if (type) {
793
+ columnSelectedWidget = this.$baseLodash.cloneDeep(
794
+ this.designer.getFieldWidgetByType(type)
795
+ );
796
+ let tmpId = generateId();
797
+ let idVal = row.prop ? row.prop : type + tmpId;
798
+ columnSelectedWidget.id = idVal;
799
+ columnSelectedWidget.options.name = idVal;
800
+ if (
801
+ !isChange
802
+ && row.columnOption
803
+ && Object.keys(row.columnOption).length
804
+ ) {
805
+ row.columnOption.required = row.required || false;
806
+ columnSelectedWidget.options = row.columnOption;
807
+ } else {
808
+ columnSelectedWidget.options.required = row.required || false;
809
+ row.columnOption = columnSelectedWidget.options;
810
+ }
811
+ columnSelectedWidget.options.name = row.prop;
812
+ columnSelectedWidget.options.label = row.label;
813
+ columnSelectedWidget.options.labelHidden = true;
814
+ }
815
+ return { columnSelectedWidget, columnEditFields };
816
+ },
817
+ openFormatConfigDialog(row, index) {
818
+ let option = row.columnOption;
819
+ let selectedWidget;
820
+ let columnWidgetConfig = this.getColumnWidgetConfig(row);
821
+ let { columnSelectedWidget, columnEditFields } = columnWidgetConfig;
822
+ if (columnSelectedWidget) {
823
+ option = columnSelectedWidget.options;
824
+ selectedWidget = columnSelectedWidget;
825
+ } else {
826
+ option = {};
827
+ selectedWidget = {};
828
+ }
829
+
830
+ let columnOption = this.$baseLodash.cloneDeep(option);
831
+ row.columnOption = columnOption;
832
+ this.operateIndex = index;
833
+
834
+ this.openWidgetPropertyDialog({
835
+ row: row,
836
+ columnSelectedWidget: selectedWidget,
837
+ index: index,
838
+ columnEditFields: columnEditFields,
839
+ callback: (columnOption) => {
840
+ this.confirmFormatConfigDialog(columnOption);
841
+ },
842
+ });
843
+ },
844
+ confirmFormatConfigDialog(columnOption) {
845
+ let row = this.optionModel.tableColumns[this.operateIndex];
846
+ row.columnOption = columnOption;
847
+ row.prop = columnOption.name;
848
+ row.label = columnOption.label;
849
+ row.required = columnOption.required;
850
+ },
851
+ openFieldTreeDialog() {
852
+ this.treeData = [
853
+ {
854
+ name: "Jinjilianxiren",
855
+ label: "员工-紧急联系人",
856
+ children: [
857
+ {
858
+ detailEntity: "Jinjilianxiren",
859
+ name: "createdOn",
860
+ label: "员工-紧急联系人.创建时间",
861
+ type: "DateTime",
862
+ required: "1",
863
+ },
864
+ /*{
865
+ "searchDialogWidth": "520px",
866
+ "detailEntity": "Jinjilianxiren",
867
+ "name": "createdBy",
868
+ "label": "员工-紧急联系人.创建用户",
869
+ "type": "Reference",
870
+ "required": "1"
871
+ },*/ {
872
+ detailEntity: "Jinjilianxiren",
873
+ name: "modifiedOn",
874
+ label: "员工-紧急联系人.最近修改时间",
875
+ type: "DateTime",
876
+ required: "0",
877
+ },
878
+ /*{
879
+ "searchDialogWidth": "520px",
880
+ "detailEntity": "Jinjilianxiren",
881
+ "name": "modifiedBy",
882
+ "label": "员工-紧急联系人.修改用户",
883
+ "type": "Reference",
884
+ "required": "0"
885
+ }, {
886
+ "searchDialogWidth": "520px",
887
+ "detailEntity": "Jinjilianxiren",
888
+ "name": "mdYuangongdanganId",
889
+ "label": "员工-紧急联系人.主从关联Id",
890
+ "type": "Reference",
891
+ "required": "1"
892
+ },*/ {
893
+ detailEntity: "Jinjilianxiren",
894
+ name: "shouji",
895
+ label: "员工-紧急联系人.手机",
896
+ type: "Text",
897
+ required: "0",
898
+ maxLength: "200",
899
+ },
900
+ {
901
+ detailEntity: "Jinjilianxiren",
902
+ name: "jinjilianxirenxingming",
903
+ label: "员工-紧急联系人.紧急联系人姓名",
904
+ type: "Text",
905
+ required: "0",
906
+ maxLength: "200",
907
+ },
908
+ ],
909
+ },
910
+ ];
911
+
912
+ let fields = this.optionModel.tableColumns
913
+ .filter((item) => !!item.prop)
914
+ .map((item) => item.prop);
915
+ let defaultCheckedKeys = [];
916
+ this.treeData.forEach((item1) => {
917
+ item1.children.forEach((item2) => {
918
+ if (
919
+ fields.includes(item2.name)
920
+ && !defaultCheckedKeys.includes(item2.name)
921
+ ) {
922
+ defaultCheckedKeys.push(item2.name);
923
+ }
924
+ });
925
+ });
926
+ this.defaultCheckedKeys = defaultCheckedKeys;
927
+ this.showFieldTreeDialog = true;
928
+ },
929
+ confirmFieldTreeDialog() {
930
+ // defaultCheckedKeys
931
+ let fields = this.optionModel.tableColumns
932
+ .filter((item) => !!item.prop)
933
+ .map((item) => item.prop);
934
+ let datas = this.$refs.tree.getCheckedNodes(true, false);
935
+ datas
936
+ .filter((item) => !fields.includes(item.name))
937
+ .forEach((item) => {
938
+ this.addCol2(item);
939
+ });
940
+ this.designer.emitHistoryChange();
941
+ this.showFieldTreeDialog = false;
942
+ },
943
+ addCol2: function (item) {
944
+ let tmpId = "column" + generateId();
945
+ var e = {
946
+ columnId: new Date().getTime(),
947
+ required: false,
948
+ width: 150,
949
+ prop: item.name,
950
+ label: item.label,
951
+ show: true,
952
+ sortable: true,
953
+ };
954
+ this.optionModel.tableColumns.push(e);
955
+ },
956
+ openTableConfigDialog() {
957
+ this.eventHeader = `${
958
+ this.optionModel.name
959
+ }.${eventName}(${eventParams.join(", ")}) {`;
960
+ this.eventHandlerCode = selectedWidget.options[eventName] || "";
961
+ this.showTableConfigDialog = true;
962
+ },
963
+ downloadExcel() {
964
+ let defaultUrl
965
+ = "http://file.sc.5mall.com/download/repo1/b/mk1/2024/12/13/b2aea548-a9a8-4dca-bba7-8d9c6134ebe3.xlsx";
966
+ let xformImportTemplateFile
967
+ = setttingConfig.xformImportTemplateFile || defaultUrl;
968
+ if (!xformImportTemplateFile) return;
969
+ this.$commonFileUtil.downloadFile(
970
+ xformImportTemplateFile,
971
+ "通用导入模板.xlsx"
972
+ );
973
+ },
974
+ addGridPageSizeList() {
975
+ if (this.optionModel.gridPageSizeList === undefined) {
976
+ this.$set(this.optionModel, "gridPageSizeList", []);
977
+ }
978
+ this.optionModel.gridPageSizeList.push({ value: 50 });
979
+ },
980
+ openExportItemColumnsDialog() {
981
+ this.showExportItemColumnsDialog = true;
982
+ },
983
+ },
984
+ };
985
+ </script>
986
+
987
+ <style>
988
+ .icon-drag:before {
989
+ content: "\e61d";
990
+ }
991
+ </style>