n20-common-lib 1.3.8 → 1.3.11

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 (263) hide show
  1. package/nstc-g6/assets/svg/404.svg +1 -0
  2. package/nstc-g6/assets/svg/addFile.svg +32 -0
  3. package/nstc-g6/assets/svg/bug.svg +1 -0
  4. package/nstc-g6/assets/svg/chart.svg +1 -0
  5. package/nstc-g6/assets/svg/clipboard.svg +1 -0
  6. package/nstc-g6/assets/svg/component.svg +1 -0
  7. package/nstc-g6/assets/svg/dashboard.svg +1 -0
  8. package/nstc-g6/assets/svg/deleteFile.svg +28 -0
  9. package/nstc-g6/assets/svg/documentation.svg +1 -0
  10. package/nstc-g6/assets/svg/drag.svg +1 -0
  11. package/nstc-g6/assets/svg/edit.svg +1 -0
  12. package/nstc-g6/assets/svg/education.svg +1 -0
  13. package/nstc-g6/assets/svg/email.svg +1 -0
  14. package/nstc-g6/assets/svg/example.svg +1 -0
  15. package/nstc-g6/assets/svg/excel.svg +1 -0
  16. package/nstc-g6/assets/svg/exit-fullscreen.svg +1 -0
  17. package/nstc-g6/assets/svg/eye-open.svg +1 -0
  18. package/nstc-g6/assets/svg/eye.svg +1 -0
  19. package/nstc-g6/assets/svg/favorite.svg +1 -0
  20. package/nstc-g6/assets/svg/favorite_active.svg +1 -0
  21. package/nstc-g6/assets/svg/favorite_x400.svg +1 -0
  22. package/nstc-g6/assets/svg/favorite_x400_active.svg +1 -0
  23. package/nstc-g6/assets/svg/favorite_x400_blank.svg +1 -0
  24. package/nstc-g6/assets/svg/filter.svg +16 -0
  25. package/nstc-g6/assets/svg/filter@2x.png +0 -0
  26. package/nstc-g6/assets/svg/filterActive.svg +16 -0
  27. package/nstc-g6/assets/svg/filterClose@2x.png +0 -0
  28. package/nstc-g6/assets/svg/form.svg +1 -0
  29. package/nstc-g6/assets/svg/fullscreen.svg +1 -0
  30. package/nstc-g6/assets/svg/guide.svg +1 -0
  31. package/nstc-g6/assets/svg/hourglass.svg +19 -0
  32. package/nstc-g6/assets/svg/icon.svg +1 -0
  33. package/nstc-g6/assets/svg/international.svg +1 -0
  34. package/nstc-g6/assets/svg/language.svg +1 -0
  35. package/nstc-g6/assets/svg/left-dis.svg +1 -0
  36. package/nstc-g6/assets/svg/left.svg +1 -0
  37. package/nstc-g6/assets/svg/link.svg +1 -0
  38. package/nstc-g6/assets/svg/list.svg +1 -0
  39. package/nstc-g6/assets/svg/lock.svg +1 -0
  40. package/nstc-g6/assets/svg/message-t.svg +1 -0
  41. package/nstc-g6/assets/svg/money.svg +1 -0
  42. package/nstc-g6/assets/svg/money3.svg +1 -0
  43. package/nstc-g6/assets/svg/money4.svg +1 -0
  44. package/nstc-g6/assets/svg/moneyTwo.svg +1 -0
  45. package/nstc-g6/assets/svg/msg_white.svg +1 -0
  46. package/nstc-g6/assets/svg/nested.svg +1 -0
  47. package/nstc-g6/assets/svg/newsearch.svg +19 -0
  48. package/nstc-g6/assets/svg/password.svg +1 -0
  49. package/nstc-g6/assets/svg/pdf.svg +1 -0
  50. package/nstc-g6/assets/svg/people.svg +1 -0
  51. package/nstc-g6/assets/svg/peoples.svg +1 -0
  52. package/nstc-g6/assets/svg/phone.svg +1 -0
  53. package/nstc-g6/assets/svg/phone_msg.svg +1 -0
  54. package/nstc-g6/assets/svg/qq.svg +1 -0
  55. package/nstc-g6/assets/svg/right-dis.svg +1 -0
  56. package/nstc-g6/assets/svg/right.svg +1 -0
  57. package/nstc-g6/assets/svg/search.svg +1 -0
  58. package/nstc-g6/assets/svg/searchActive.svg +19 -0
  59. package/nstc-g6/assets/svg/shopping.svg +1 -0
  60. package/nstc-g6/assets/svg/size.svg +1 -0
  61. package/nstc-g6/assets/svg/skill.svg +1 -0
  62. package/nstc-g6/assets/svg/star.svg +1 -0
  63. package/nstc-g6/assets/svg/steam.svg +1 -0
  64. package/nstc-g6/assets/svg/tab.svg +1 -0
  65. package/nstc-g6/assets/svg/table.svg +1 -0
  66. package/nstc-g6/assets/svg/theme.svg +1 -0
  67. package/nstc-g6/assets/svg/tree-table.svg +1 -0
  68. package/nstc-g6/assets/svg/tree.svg +1 -0
  69. package/nstc-g6/assets/svg/user.svg +1 -0
  70. package/nstc-g6/assets/svg/wechat.svg +1 -0
  71. package/nstc-g6/assets/svg/z-left-2-dis.svg +1 -0
  72. package/nstc-g6/assets/svg/z-left-2.svg +1 -0
  73. package/nstc-g6/assets/svg/z-right-2-dis.svg +1 -0
  74. package/nstc-g6/assets/svg/z-right-2.svg +1 -0
  75. package/nstc-g6/assets/svg/z-right.svg +1 -0
  76. package/nstc-g6/assets/svg/zip.svg +1 -0
  77. package/nstc-g6/components/Calendar/index.js +8 -0
  78. package/nstc-g6/components/Calendar/src/basic/month-table.vue +129 -0
  79. package/nstc-g6/components/Calendar/src/basic/year-table.vue +126 -0
  80. package/nstc-g6/components/Calendar/src/main.vue +442 -0
  81. package/nstc-g6/components/DialogForm/index.js +8 -0
  82. package/nstc-g6/components/DialogForm/src/demo/index.vue +56 -0
  83. package/nstc-g6/components/DialogForm/src/main.vue +189 -0
  84. package/nstc-g6/components/Form/A_DEMO/component/originalForm.vue +281 -0
  85. package/nstc-g6/components/Form/A_DEMO/config/config_3.js +1222 -0
  86. package/nstc-g6/components/Form/A_DEMO/index.vue +803 -0
  87. package/nstc-g6/components/Form/AutocompleteCustom/index.vue +72 -0
  88. package/nstc-g6/components/Form/BusinessSpecific/InputMultiple.vue +191 -0
  89. package/nstc-g6/components/Form/BusinessSpecific/InputWithUnit.vue +128 -0
  90. package/nstc-g6/components/Form/BusinessSpecific/SelectTreeDialog.vue +233 -0
  91. package/nstc-g6/components/Form/BusinessSpecific/readme.md +7 -0
  92. package/nstc-g6/components/Form/CascaderCustom/index.vue +101 -0
  93. package/nstc-g6/components/Form/CheckboxCustom/index.vue +84 -0
  94. package/nstc-g6/components/Form/Component.vue +661 -0
  95. package/nstc-g6/components/Form/ComponentSecond.vue +650 -0
  96. package/nstc-g6/components/Form/DatepickerCustom/index.vue +130 -0
  97. package/nstc-g6/components/Form/InputAndDialog/index.js +15 -0
  98. package/nstc-g6/components/Form/InputAndDialog/src/main.vue +395 -0
  99. package/nstc-g6/components/Form/InputCustom/demo/index.vue +65 -0
  100. package/nstc-g6/components/Form/InputCustom/index.vue +307 -0
  101. package/nstc-g6/components/Form/IntervalinputCustom/demo/index.vue +31 -0
  102. package/nstc-g6/components/Form/IntervalinputCustom/index.vue +118 -0
  103. package/nstc-g6/components/Form/Item.vue +330 -0
  104. package/nstc-g6/components/Form/ItemSecond.vue +269 -0
  105. package/nstc-g6/components/Form/List.vue +146 -0
  106. package/nstc-g6/components/Form/ListSecond.vue +130 -0
  107. package/nstc-g6/components/Form/RadioCustom/index.vue +73 -0
  108. package/nstc-g6/components/Form/SelectAccount/index.js +15 -0
  109. package/nstc-g6/components/Form/SelectAccount/src/demo/index.vue +58 -0
  110. package/nstc-g6/components/Form/SelectAccount/src/main.vue +283 -0
  111. package/nstc-g6/components/Form/SelectAndDialog/index.js +15 -0
  112. package/nstc-g6/components/Form/SelectAndDialog/src/main.vue +384 -0
  113. package/nstc-g6/components/Form/SelectCashFlow/index.js +15 -0
  114. package/nstc-g6/components/Form/SelectCashFlow/src/demo/index.vue +42 -0
  115. package/nstc-g6/components/Form/SelectCashFlow/src/main.vue +126 -0
  116. package/nstc-g6/components/Form/SelectCustom/demo/index.vue +82 -0
  117. package/nstc-g6/components/Form/SelectCustom/index.vue +488 -0
  118. package/nstc-g6/components/Form/SelectSubject/index.js +15 -0
  119. package/nstc-g6/components/Form/SelectSubject/src/demo/index.vue +85 -0
  120. package/nstc-g6/components/Form/SelectSubject/src/main.vue +182 -0
  121. package/nstc-g6/components/Form/SelectindialogCustom/demo/index.vue +188 -0
  122. package/nstc-g6/components/Form/SelectindialogCustom/index.vue +650 -0
  123. package/nstc-g6/components/Form/SelectindialogCustom/install.js +7 -0
  124. package/nstc-g6/components/Form/TableRadioCustom/demo/index.vue +53 -0
  125. package/nstc-g6/components/Form/TableRadioCustom/index.vue +183 -0
  126. package/nstc-g6/components/Form/TextCustom/index.vue +38 -0
  127. package/nstc-g6/components/Form/UploadCustom/demo/index.vue +31 -0
  128. package/nstc-g6/components/Form/UploadCustom/iconxitongshezhi-yichu.png +0 -0
  129. package/nstc-g6/components/Form/UploadCustom/index.vue +506 -0
  130. package/nstc-g6/components/Form/configs.js +191 -0
  131. package/nstc-g6/components/Form/configsSecond.js +161 -0
  132. package/nstc-g6/components/Form/index.js +8 -0
  133. package/nstc-g6/components/Form/index.scss +29 -0
  134. package/nstc-g6/components/Form/payeePersonSelect/index.js +15 -0
  135. package/nstc-g6/components/Form/payeePersonSelect/src/demo/index.vue +164 -0
  136. package/nstc-g6/components/Form/payeePersonSelect/src/main.vue +185 -0
  137. package/nstc-g6/components/Form/readme.txt +4 -0
  138. package/nstc-g6/components/FormGroup/index.js +8 -0
  139. package/nstc-g6/components/FormGroup/src/demo/config.js +23 -0
  140. package/nstc-g6/components/FormGroup/src/demo/index.vue +85 -0
  141. package/nstc-g6/components/FormGroup/src/main.vue +639 -0
  142. package/nstc-g6/components/FormGroup/src/validate.js +23 -0
  143. package/nstc-g6/components/InputTag/InputTag.vue +270 -0
  144. package/nstc-g6/components/NstcApprovel/NstcApprovel.vue +24 -0
  145. package/nstc-g6/components/NstcBackToTop/NstcBackToTop.vue +150 -0
  146. package/nstc-g6/components/NstcBranchLazyLoad/NstcBranchLazyLoad.vue +123 -0
  147. package/nstc-g6/components/NstcCharts/NstcCharts.vue +162 -0
  148. package/nstc-g6/components/NstcCharts/define.js +74 -0
  149. package/nstc-g6/components/NstcCharts/mixins/resize.js +56 -0
  150. package/nstc-g6/components/NstcConfirm/NstcConfirm.vue +152 -0
  151. package/nstc-g6/components/NstcConfirm/index.js +25 -0
  152. package/nstc-g6/components/NstcDialog/NstcDialog.vue +185 -0
  153. package/nstc-g6/components/NstcDialogForm/NstcDialogForm.vue +176 -0
  154. package/nstc-g6/components/NstcDialogTable/NstcDialogTable.vue +280 -0
  155. package/nstc-g6/components/NstcDropdown/NstcDropdown.vue +52 -0
  156. package/nstc-g6/components/NstcDropdownTree/NstcDropdownTree.vue +396 -0
  157. package/nstc-g6/components/NstcElectronicFile/NstcElectronicFile.vue +591 -0
  158. package/nstc-g6/components/NstcExcelCustomImport/NstcExcelCustomImport.vue +475 -0
  159. package/nstc-g6/components/NstcExcelCustomImport/img/upload@2x.png +0 -0
  160. package/nstc-g6/components/NstcExcelExport/NstcExcelExport.vue +145 -0
  161. package/nstc-g6/components/NstcExcelImport/NstcExcelImport.vue +1074 -0
  162. package/nstc-g6/components/NstcExcelImport/img/upload@2x.png +0 -0
  163. package/nstc-g6/components/NstcExcelImportN/NstcExcelImportN.vue +1166 -0
  164. package/nstc-g6/components/NstcExpandCollapse/NstcExpandCollapse.vue +130 -0
  165. package/nstc-g6/components/NstcExpandCollapse/index.scss +77 -0
  166. package/nstc-g6/components/NstcFileUpload/NstcFileUpload.vue +989 -0
  167. package/nstc-g6/components/NstcFileUpload/img/addFile.svg +32 -0
  168. package/nstc-g6/components/NstcFileUpload/img/delete.svg +24 -0
  169. package/nstc-g6/components/NstcFileUpload/img/deleteFile.svg +28 -0
  170. package/nstc-g6/components/NstcFileUpload/img/download.svg +24 -0
  171. package/nstc-g6/components/NstcFileUpload/img/inputUpload.svg +30 -0
  172. package/nstc-g6/components/NstcFileUpload/img/look-diabled.svg +24 -0
  173. package/nstc-g6/components/NstcFileUpload/img/look.svg +24 -0
  174. package/nstc-g6/components/NstcForm/A_DEMO/component/originalForm.vue +281 -0
  175. package/nstc-g6/components/NstcForm/A_DEMO/config/config_3.js +1222 -0
  176. package/nstc-g6/components/NstcForm/A_DEMO/index.vue +796 -0
  177. package/nstc-g6/components/NstcForm/AutocompleteCustom/index.vue +68 -0
  178. package/nstc-g6/components/NstcForm/BusinessSpecific/InputMultiple.vue +189 -0
  179. package/nstc-g6/components/NstcForm/BusinessSpecific/InputWithUnit.vue +128 -0
  180. package/nstc-g6/components/NstcForm/BusinessSpecific/SelectTreeDialog.vue +233 -0
  181. package/nstc-g6/components/NstcForm/BusinessSpecific/readme.md +7 -0
  182. package/nstc-g6/components/NstcForm/CascaderCustom/index.vue +101 -0
  183. package/nstc-g6/components/NstcForm/CheckboxCustom/index.vue +84 -0
  184. package/nstc-g6/components/NstcForm/Component.vue +684 -0
  185. package/nstc-g6/components/NstcForm/ComponentSecond.vue +650 -0
  186. package/nstc-g6/components/NstcForm/DatepickerCustom/index.vue +130 -0
  187. package/nstc-g6/components/NstcForm/InputAndDialog/NstcInputAndDialog.vue +389 -0
  188. package/nstc-g6/components/NstcForm/InputCustom/index.vue +314 -0
  189. package/nstc-g6/components/NstcForm/IntervalInputCustom/index.vue +116 -0
  190. package/nstc-g6/components/NstcForm/Item.vue +327 -0
  191. package/nstc-g6/components/NstcForm/ItemSecond.vue +269 -0
  192. package/nstc-g6/components/NstcForm/List.vue +146 -0
  193. package/nstc-g6/components/NstcForm/ListSecond.vue +130 -0
  194. package/nstc-g6/components/NstcForm/RadioCustom/index.vue +73 -0
  195. package/nstc-g6/components/NstcForm/SelectAccount/NstcSelectAccount.vue +334 -0
  196. package/nstc-g6/components/NstcForm/SelectAndDialog/NstcSelectAndDialog.vue +377 -0
  197. package/nstc-g6/components/NstcForm/SelectCashFlow/NstcSelectCashFlow.vue +123 -0
  198. package/nstc-g6/components/NstcForm/SelectCustom/index.vue +460 -0
  199. package/nstc-g6/components/NstcForm/SelectSubject/NstcSelectSubject.vue +185 -0
  200. package/nstc-g6/components/NstcForm/SelectindialogCustom/index.vue +648 -0
  201. package/nstc-g6/components/NstcForm/TableRadioCustom/index.vue +183 -0
  202. package/nstc-g6/components/NstcForm/TextCustom/index.vue +38 -0
  203. package/nstc-g6/components/NstcForm/UploadCustom/iconxitongshezhi-yichu.png +0 -0
  204. package/nstc-g6/components/NstcForm/UploadCustom/index.vue +500 -0
  205. package/nstc-g6/components/NstcForm/configs.js +191 -0
  206. package/nstc-g6/components/NstcForm/configsSecond.js +161 -0
  207. package/nstc-g6/components/NstcForm/index.js +8 -0
  208. package/nstc-g6/components/NstcForm/index.scss +29 -0
  209. package/nstc-g6/components/NstcForm/payeePersonSelect/NstcPayeePerson.vue +188 -0
  210. package/nstc-g6/components/NstcForm/readme.txt +4 -0
  211. package/nstc-g6/components/NstcPagination/NstcPagination.vue +428 -0
  212. package/nstc-g6/components/NstcPagination/setPageNum.png +0 -0
  213. package/nstc-g6/components/NstcPagination/setpagedefault.png +0 -0
  214. package/nstc-g6/components/NstcScreenFull/NstcScreenFull.vue +70 -0
  215. package/nstc-g6/components/NstcSelectTree/NstcSelectTree.vue +729 -0
  216. package/nstc-g6/components/NstcSelectTreeList/NstcSelectTreeList.vue +676 -0
  217. package/nstc-g6/components/NstcSticky/NstcSticky.vue +97 -0
  218. package/nstc-g6/components/NstcSvgIcon/NstcSvgIcon.vue +72 -0
  219. package/nstc-g6/components/NstcTab/NstcTab.vue +80 -0
  220. package/nstc-g6/components/NstcTabWithBadge/NstcTabWithBadge.vue +45 -0
  221. package/nstc-g6/components/NstcTabWithBadge/index.scss +31 -0
  222. package/nstc-g6/components/NstcTable/ElTableColumnCustom/index.vue +292 -0
  223. package/nstc-g6/components/NstcTable/NstcTable.vue +460 -0
  224. package/nstc-g6/components/NstcTableSet/NstcTableSet.vue +801 -0
  225. package/nstc-g6/components/NstcThemePicker/NstcThemePicker.vue +186 -0
  226. package/nstc-g6/components/NstcUploadCustomExcel/NstcUploadCustomExcel.vue +330 -0
  227. package/nstc-g6/components/NstcUploadExcel/NstcUploadExcel.vue +145 -0
  228. package/nstc-g6/components/NstcWorkBench/NstcWorkBench.vue +176 -0
  229. package/nstc-g6/components/Search/NstcSearch.vue +583 -0
  230. package/nstc-g6/components/Search/src/demo/index copy.vue +101 -0
  231. package/nstc-g6/components/Search/src/demo/index.vue +103 -0
  232. package/nstc-g6/components/Search/src/main copy.vue +607 -0
  233. package/nstc-g6/components/approvelTwo/main.vue +220 -0
  234. package/nstc-g6/components/approvelTwo/progress.vue +154 -0
  235. package/nstc-g6/directives/VCopy/index.js +60 -0
  236. package/nstc-g6/directives/VNstcNumber/index.js +14 -0
  237. package/nstc-g6/directives/VNstcNumber/temp.js +446 -0
  238. package/nstc-g6/index.js +193 -0
  239. package/nstc-g6/utils/auth.js +2 -0
  240. package/nstc-g6/utils/axios.js +2 -0
  241. package/nstc-g6/utils/dateAndValidator.js +649 -0
  242. package/nstc-g6/utils/debounce.js +40 -0
  243. package/nstc-g6/utils/parseTime.js +48 -0
  244. package/nstc-g6/utils/validate/index.js +7 -0
  245. package/nstc-g6/utils/vendor/Export2Excel.js +229 -0
  246. package/nstc-g6/utils/vendor/Export2Zip.js +24 -0
  247. package/nstc-g6/utils/vue-bus.js +5 -0
  248. package/package.json +8 -2
  249. package/src/assets/css/_coreLib.scss +9 -1
  250. package/src/components/ChildRange/index.vue +28 -64
  251. package/src/components/ChildRange/style.scss +34 -0
  252. package/src/components/FileImport/index.vue +3 -1
  253. package/src/components/PageHeader/index.vue +3 -47
  254. package/src/components/PageHeader/style.scss +39 -0
  255. package/src/components/Search/index.vue +1 -97
  256. package/src/components/Search/style.scss +93 -0
  257. package/src/components/Table/ThSelectHeader.vue +28 -33
  258. package/src/components/Table/index.vue +4 -2
  259. package/src/directives/VTitle/index.js +14 -17
  260. package/style/css/normalize.scss +6 -6
  261. package/style/index.css +3 -3
  262. package/style/index.css.map +1 -1
  263. package/style/server-config.jsonc +527 -410
@@ -0,0 +1,330 @@
1
+ <template>
2
+ <div>
3
+ <template v-if="SUPPORT_TYPE.includes(item.mold)">
4
+ <el-form-item
5
+ :label="item.name"
6
+ :prop="item.prop"
7
+ :ref="item.required ? item.prop : null"
8
+ >
9
+ <el-tooltip
10
+ v-if="item.tooltip"
11
+ class="item-tooltip"
12
+ effect="dark"
13
+ :content="item.tooltip"
14
+ placement="top-start"
15
+ :style="{left: -tipLength + 'px'}"
16
+ >
17
+ <i class="el-icon-question" />
18
+ </el-tooltip>
19
+ <!-- 多个link -->
20
+
21
+ <template v-if="Array.isArray(item.link)">
22
+ <component
23
+ ref="item"
24
+ icon-type="drop"
25
+ :showCheckbox="item.showCheckbox"
26
+ :onlyClickLeaf="item.onlyClickLeaf"
27
+ :is="getComponentModel(item.mold)"
28
+ :key="item.prop"
29
+ v-model="value[item.prop]"
30
+ v-bind="item"
31
+ :reset.sync="resets[item.prop]"
32
+ :disabled="disableds[item.prop]"
33
+ :popper-class="popperClass"
34
+ :checkStrictly="item.checkStrictly"
35
+ :disableUnclickLeaf="item.disableUnclickLeaf"
36
+ :label="formData[item.queryKey]"
37
+ v-on="item.listeners"
38
+ @after-leave="$emit('after-leave', item.prop)"
39
+ @enter-click="$emit('enter-click')"
40
+ @treeNodeClick="treeNodeClick"
41
+ />
42
+ <template v-for="link in item.link">
43
+ <template v-if="link.mold && link.renderable !== false">
44
+ <!-- <span-->
45
+ <!-- v-show="link.name"-->
46
+ <!-- :key="`${link.prop}-${link.name}`"-->
47
+ <!-- class="form-item-name form-item-name-link"-->
48
+ <!-- v-html="link.name"-->
49
+ <!-- />-->
50
+ <el-form-item
51
+ :key="link.prop"
52
+ :label="link.name"
53
+ :prop="link.prop"
54
+ :label-width="link.labelWidth"
55
+ class="form-item-link-child"
56
+ :dev-use="link.mold"
57
+ >
58
+ <component
59
+ icon-type="drop"
60
+ :showCheckbox="item.showCheckbox"
61
+ :onlyClickLeaf="item.onlyClickLeaf"
62
+ :disableUnclickLeaf="item.disableUnclickLeaf"
63
+ :is="getComponentModel(item.mold)"
64
+ v-if="link.renderable !== false"
65
+ v-model="value[link.prop]"
66
+ v-bind="link"
67
+ :reset.sync="resets[link.prop]"
68
+ :disabled="disableds[item.prop]"
69
+ :checkStrictly="item.checkStrictly"
70
+ :popper-class="popperClass"
71
+ :label="formData[item.queryKey]"
72
+ v-on="link.listeners"
73
+ @after-leave="$emit('after-leave', link.prop)"
74
+ @enter-click="$emit('enter-click')"
75
+ @treeNodeClick="treeNodeClick"
76
+ />
77
+ </el-form-item>
78
+
79
+ </template>
80
+ </template>
81
+ </template>
82
+ <!-- 单个link -->
83
+ <template v-else-if="item.link &&item.link.mold">
84
+ <template v-if="item.link.position === 'after'">
85
+ <component
86
+ ref="item"
87
+ icon-type="drop"
88
+ :showCheckbox="item.showCheckbox"
89
+ :onlyClickLeaf="item.onlyClickLeaf"
90
+ :disableUnclickLeaf="item.disableUnclickLeaf"
91
+ :is="getComponentModel(item.link.mold)"
92
+ v-if="item.link.renderable !== false"
93
+ :key="item.link.prop"
94
+ v-model="value[item.link.prop]"
95
+ v-bind="item.link"
96
+ :reset.sync="resets[item.link.prop]"
97
+ :disabled="disableds[item.link.prop]"
98
+ :popper-class="popperClass"
99
+ :checkStrictly="item.checkStrictly"
100
+ :label="formData[item.queryKey]"
101
+ v-on="item.link.listeners"
102
+ @after-leave="$emit('after-leave', item.link.prop)"
103
+ @enter-click="$emit('enter-click')"
104
+ @treeNodeClick="treeNodeClick"
105
+ />
106
+ <span
107
+ v-show="item.link.name"
108
+ class="form-item-name form-item-name-link"
109
+ v-html="item.link.name"
110
+ />
111
+ <component
112
+ icon-type="drop"
113
+ :showCheckbox="item.showCheckbox"
114
+ :onlyClickLeaf="item.onlyClickLeaf"
115
+ :disableUnclickLeaf="item.disableUnclickLeaf"
116
+ :is="getComponentModel(item.mold)"
117
+ :key="item.prop"
118
+ v-model="value[item.prop]"
119
+ v-bind="item"
120
+ :reset.sync="resets[item.prop]"
121
+ :disabled="disableds[item.prop]"
122
+ :checkStrictly="item.checkStrictly"
123
+ :popper-class="popperClass"
124
+ :label="formData[item.queryKey]"
125
+ v-on="item.listeners"
126
+ @after-leave="$emit('after-leave', item.prop)"
127
+ @enter-click="$emit('enter-click')"
128
+ @treeNodeClick="treeNodeClick"
129
+ />
130
+ </template>
131
+ <template v-else>
132
+ <component
133
+ icon-type="drop"
134
+ :showCheckbox="item.showCheckbox"
135
+ :onlyClickLeaf="item.onlyClickLeaf"
136
+ :disableUnclickLeaf="item.disableUnclickLeaf"
137
+ :is="getComponentModel(item.mold)"
138
+ :key="item.prop"
139
+ v-model="value[item.prop]"
140
+ v-bind="item"
141
+ :reset.sync="resets[item.prop]"
142
+ :checkStrictly="item.checkStrictly"
143
+ :disabled="disableds[item.prop]"
144
+ :popper-class="popperClass"
145
+ :label="formData[item.queryKey]"
146
+ v-on="item.listeners"
147
+ @after-leave="$emit('after-leave', item.prop)"
148
+ @enter-click="$emit('enter-click')"
149
+ @treeNodeClick="treeNodeClick"
150
+ />
151
+ <span
152
+
153
+ v-show="item.link.name"
154
+ class="form-item-name form-item-name-link"
155
+ v-html="item.link.name"
156
+ />
157
+ <component
158
+ icon-type="drop"
159
+ :showCheckbox="item.showCheckbox"
160
+ :onlyClickLeaf="item.onlyClickLeaf"
161
+ :disableUnclickLeaf="item.disableUnclickLeaf"
162
+ :is="getComponentModel(item.link.mold)"
163
+ v-if="item.link.renderable !== false"
164
+ :key="item.link.prop"
165
+ v-model="value[item.link.prop]"
166
+ v-bind="item.link"
167
+ :reset.sync="resets[item.link.prop]"
168
+ :checkStrictly="item.checkStrictly"
169
+ :disabled="disableds[item.link.prop]"
170
+ :popper-class="popperClass"
171
+ :label="formData[item.queryKey]"
172
+ v-on="item.link.listeners"
173
+ @after-leave="$emit('after-leave', item.link.prop)"
174
+ @enter-click="$emit('enter-click')"
175
+ @treeNodeClick="treeNodeClick"
176
+ />
177
+ </template>
178
+ </template>
179
+
180
+ <template v-else>
181
+ <component
182
+ ref="item"
183
+ icon-type="drop"
184
+ :showCheckbox="item.showCheckbox"
185
+ :onlyClickLeaf="item.onlyClickLeaf"
186
+ :disableUnclickLeaf="item.disableUnclickLeaf"
187
+ :is="getComponentModel(item.mold)"
188
+ :key="item.prop"
189
+ :lazyLoad='item.lazyLoad'
190
+ :labelKey='item.labelKey'
191
+ :valueKey='item.valueKey'
192
+ :checkStrictly="item.checkStrictly"
193
+ :httpMethod="item.httpMethod"
194
+ :params="item.params"
195
+ v-model="value[item.prop]"
196
+ v-bind="item"
197
+ :multiple="item.multiple"
198
+ :reset.sync="resets[item.prop]"
199
+ :disabled="disableds[item.prop]"
200
+ :popper-class="popperClass"
201
+ :query="item.query"
202
+ :label="formData[item.queryKey]"
203
+ :placeholder="item.placeholder"
204
+ v-on="item.listeners"
205
+ :remote="item.remote"
206
+ :filterable="item.filterable"
207
+ :options="item.options"
208
+ :numberRule="item.defaultProps||{}"
209
+ :clearable="item.clearable"
210
+ :isCache="item.isCache"
211
+ :dateType="item.dateType"
212
+ @after-leave="$emit('after-leave', item.prop)"
213
+ @enter-click="$emit('enter-click')"
214
+ @treeNodeClick="treeNodeClick"
215
+ />
216
+ </template>
217
+ </el-form-item>
218
+ </template>
219
+ </div>
220
+ </template>
221
+
222
+ <script>
223
+ import { SUPPORT_TYPE, components } from './configs'
224
+
225
+ export default {
226
+ name: 'FormCustomBaseItem',
227
+
228
+ components,
229
+
230
+ inheritAttrs: false,
231
+
232
+ props: {
233
+ formData: {
234
+ type: Object,
235
+ default: () => ({})
236
+ },
237
+ from: {
238
+ type: String,
239
+ default: ''
240
+ },
241
+ item: {
242
+ default: () => ({}),
243
+ type: Object
244
+ },
245
+
246
+ loading: {
247
+ default: false,
248
+ type: Boolean
249
+ },
250
+
251
+ resets: {
252
+ default: () => ({}),
253
+ type: Object
254
+ },
255
+
256
+ disableds: {
257
+ default: () => ({}),
258
+ type: Object
259
+ },
260
+
261
+ popperClass: {
262
+ type: String,
263
+ default: ''
264
+ },
265
+
266
+ value: {
267
+ default: () => ({}),
268
+ type: Object
269
+ },
270
+
271
+ // 显示模式
272
+ showMode: {
273
+ type: String,
274
+ default: ''
275
+ }
276
+ },
277
+
278
+ // created() {
279
+ // console.log('item:', this.item)
280
+ // },
281
+
282
+ data() {
283
+ return {
284
+ SUPPORT_TYPE
285
+ }
286
+ },
287
+ computed: {
288
+ tipLength() {
289
+ // if (this.item.name.length === 2) {
290
+ // return 68
291
+ // }
292
+ return this.item.name.length * 16 + 30
293
+ }
294
+ // tipLength
295
+ },
296
+
297
+ methods: {
298
+ getComponentModel(model) {
299
+ if (!this.showMode) {
300
+ return `${model}-custom`
301
+ } else {
302
+ return `text-custom`
303
+ }
304
+ },
305
+ treeNodeClick(data, node) {
306
+ this.$emit("tree-node-click", data, node);
307
+ setTimeout(() => {
308
+ const key = this.item.queryKey;
309
+ this.$refs["item"].filterText = this.formData[key];
310
+ }, 0);
311
+ }
312
+ }
313
+ }
314
+ </script>
315
+ <style lang="scss">
316
+ .el-form-item {
317
+ .el-tooltip {
318
+ position: absolute;
319
+ top: 9px;
320
+ }
321
+ .query-button {
322
+ width: 72px;
323
+ height: 26px;
324
+ padding: 0px;
325
+ border: 1px solid #007AFF;
326
+ border-radius: 5px;
327
+ }
328
+ }
329
+
330
+ </style>
@@ -0,0 +1,269 @@
1
+ <template>
2
+ <div :class="{ 'form-item-button':['querybutton', 'addbutton', 'otherbutton'].includes(item.mold) }">
3
+ <el-form-item v-if="item.mold === 'querybutton'">
4
+ <el-button
5
+ type="primary"
6
+ v-bind="item"
7
+ :loading="loading"
8
+ :disabled="disableds[item.prop || item.mold]"
9
+ :icon="item.icon || 'el-icon-search'"
10
+ class="query-button nstc-g6-common-btn-1 nstc-g6-common-btn-size-b"
11
+ @click="$emit('query-click')"
12
+ >
13
+ {{ item.name || '查询' }}
14
+ </el-button>
15
+ </el-form-item>
16
+
17
+ <el-form-item v-if="item.mold === 'addbutton'">
18
+ <el-button
19
+ v-bind="item"
20
+ :disabled="disableds[item.prop || item.mold]"
21
+ :icon="item.icon || 'el-icon-plus'"
22
+ @click="$emit('add-click')"
23
+ >
24
+ {{ item.name || '新增' }}
25
+ </el-button>
26
+ </el-form-item>
27
+
28
+ <el-form-item v-if="item.mold === 'otherbutton'">
29
+ <el-button
30
+ v-bind="item"
31
+ :disabled="disableds[item.prop || item.mold]"
32
+ :icon="item.type === 'icon' ? item.icon : undefined"
33
+ class="other-button"
34
+ @click="$emit('other-click')"
35
+ >
36
+ {{ item.name || '' }}
37
+ </el-button>
38
+ </el-form-item>
39
+
40
+ <template v-else-if="SUPPORT_TYPE.includes(item.mold)">
41
+ <el-form-item
42
+ :label="item.name"
43
+ :prop="item.prop"
44
+ >
45
+ <el-tooltip
46
+ v-if="item.tooltip"
47
+ class="item-tooltip"
48
+ effect="dark"
49
+ :content="item.tooltip"
50
+ placement="top-start"
51
+ :style="{left: -tipLength + 'px'}"
52
+ >
53
+ <i class="el-icon-question" />
54
+ </el-tooltip>
55
+ <!-- 多个 -->
56
+ <template v-if="Array.isArray(item.link)">
57
+ <component
58
+ :is="`${item.mold}-custom`"
59
+ :key="item.prop"
60
+ v-model="value[item.prop]"
61
+ v-bind="item"
62
+ :reset.sync="resets[item.prop]"
63
+ :disabled="disableds[item.prop]"
64
+ :popper-class="popperClass"
65
+ v-on="item.listeners"
66
+ @after-leave="$emit('after-leave', item.prop)"
67
+ @enter-click="$emit('enter-click')"
68
+ />
69
+ <template v-for="link in item.link">
70
+ <template v-if="link.mold && link.renderable !== false">
71
+ <!-- <span-->
72
+ <!-- v-show="link.name"-->
73
+ <!-- :key="`${link.prop}-${link.name}`"-->
74
+ <!-- class="form-item-name form-item-name-link"-->
75
+ <!-- v-html="link.name"-->
76
+ <!-- />-->
77
+ <el-form-item
78
+ :key="link.prop"
79
+ :label="link.name"
80
+ :prop="link.prop"
81
+ :label-width="link.labelWidth"
82
+ class="form-item-link-child"
83
+ :dev-use="link.mold"
84
+ >
85
+ <component
86
+ :is="`${link.mold}-custom`"
87
+ v-if="link.renderable !== false"
88
+ v-model="value[link.prop]"
89
+ v-bind="link"
90
+ :reset.sync="resets[link.prop]"
91
+ :disabled="disableds[item.prop]"
92
+ :popper-class="popperClass"
93
+ v-on="link.listeners"
94
+ @after-leave="$emit('after-leave', link.prop)"
95
+ @enter-click="$emit('enter-click')"
96
+ />
97
+ </el-form-item>
98
+
99
+ </template>
100
+ </template>
101
+ </template>
102
+ <!-- 单个 -->
103
+ <template v-else-if="item.link &&item.link.mold">
104
+ <template v-if="item.link.position === 'after'">
105
+ <component
106
+ :is="`${item.link.mold}-custom`"
107
+ v-if="item.link.renderable !== false"
108
+ :key="item.link.prop"
109
+ v-model="value[item.link.prop]"
110
+ v-bind="item.link"
111
+ :reset.sync="resets[item.link.prop]"
112
+ :disabled="disableds[item.link.prop]"
113
+ :popper-class="popperClass"
114
+ v-on="item.link.listeners"
115
+ @after-leave="$emit('after-leave', item.link.prop)"
116
+ @enter-click="$emit('enter-click')"
117
+ />
118
+ <span
119
+
120
+ v-show="item.link.name"
121
+ class="form-item-name form-item-name-link"
122
+ v-html="item.link.name"
123
+ />
124
+ <component
125
+ :is="`${item.mold}-custom`"
126
+ :key="item.prop"
127
+ v-model="value[item.prop]"
128
+ v-bind="item"
129
+ :reset.sync="resets[item.prop]"
130
+ :disabled="disableds[item.prop]"
131
+ :popper-class="popperClass"
132
+ v-on="item.listeners"
133
+ @after-leave="$emit('after-leave', item.prop)"
134
+ @enter-click="$emit('enter-click')"
135
+ />
136
+ </template>
137
+ <template v-else>
138
+ <component
139
+ :is="`${item.mold}-custom`"
140
+ :key="item.prop"
141
+ v-model="value[item.prop]"
142
+ v-bind="item"
143
+ :reset.sync="resets[item.prop]"
144
+ :disabled="disableds[item.prop]"
145
+ :popper-class="popperClass"
146
+ v-on="item.listeners"
147
+ @after-leave="$emit('after-leave', item.prop)"
148
+ @enter-click="$emit('enter-click')"
149
+ />
150
+ <span
151
+
152
+ v-show="item.link.name"
153
+ class="form-item-name form-item-name-link"
154
+ v-html="item.link.name"
155
+ />
156
+ <component
157
+ :is="`${item.link.mold}-custom`"
158
+ v-if="item.link.renderable !== false"
159
+ :key="item.link.prop"
160
+ v-model="value[item.link.prop]"
161
+ v-bind="item.link"
162
+ :reset.sync="resets[item.link.prop]"
163
+ :disabled="disableds[item.link.prop]"
164
+ :popper-class="popperClass"
165
+ v-on="item.link.listeners"
166
+ @after-leave="$emit('after-leave', item.link.prop)"
167
+ @enter-click="$emit('enter-click')"
168
+ />
169
+ </template>
170
+ </template>
171
+
172
+ <template v-else>
173
+ <component
174
+ :is="`${item.mold}-custom`"
175
+ :key="item.prop"
176
+ v-model="value[item.prop]"
177
+ v-bind="item"
178
+ :reset.sync="resets[item.prop]"
179
+ :disabled="disableds[item.prop]"
180
+ :popper-class="popperClass"
181
+ v-on="item.listeners"
182
+ @after-leave="$emit('after-leave', item.prop)"
183
+ @enter-click="$emit('enter-click')"
184
+ />
185
+ </template>
186
+ </el-form-item>
187
+ </template>
188
+ </div>
189
+ </template>
190
+
191
+ <script>
192
+ import { SUPPORT_TYPE, components } from './configsSecond'
193
+
194
+ export default {
195
+ name: 'FormCustomBaseItem',
196
+
197
+ components,
198
+
199
+ inheritAttrs: false,
200
+
201
+ props: {
202
+ from: {
203
+ type: String,
204
+ default: ''
205
+ },
206
+ item: {
207
+ default: () => ({}),
208
+ type: Object
209
+ },
210
+
211
+ loading: {
212
+ default: false,
213
+ type: Boolean
214
+ },
215
+
216
+ resets: {
217
+ default: () => ({}),
218
+ type: Object
219
+ },
220
+
221
+ disableds: {
222
+ default: () => ({}),
223
+ type: Object
224
+ },
225
+
226
+ popperClass: {
227
+ type: String,
228
+ default: ''
229
+ },
230
+
231
+ value: {
232
+ default: () => ({}),
233
+ type: Object
234
+ }
235
+ },
236
+
237
+ data() {
238
+ return {
239
+ SUPPORT_TYPE
240
+ }
241
+ },
242
+ computed: {
243
+ tipLength() {
244
+ console.log('this.item.name', this.item.name.length)
245
+ // if (this.item.name.length === 2) {
246
+ // return 68
247
+ // }
248
+ return this.item.name.length * 16 + 30
249
+ }
250
+ // tipLength
251
+ }
252
+ }
253
+ </script>
254
+ <style lang="scss">
255
+ .el-form-item {
256
+ .el-tooltip {
257
+ position: absolute;
258
+ top: 9px;
259
+ }
260
+ .query-button {
261
+ width: 72px;
262
+ height: 26px;
263
+ padding: 0px;
264
+ border: 1px solid #007AFF;
265
+ border-radius: 5px;
266
+ }
267
+ }
268
+
269
+ </style>