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,377 @@
1
+ <!--
2
+ * @Author: your name
3
+ * @Date: 2022-01-13 11:06:47
4
+ * @LastEditTime: 2022-02-15 14:01:35
5
+ * @LastEditors: Please set LastEditors
6
+ * @Description: 下拉+弹框
7
+ * @FilePath: SelectAndDialog.vue
8
+ -->
9
+ <template>
10
+ <div class="dialog-select">
11
+ <div
12
+ style="position: relative"
13
+ @mouseenter="hovering = true"
14
+ @mouseleave="hovering = false"
15
+ >
16
+ <el-select
17
+ v-model="selectValue"
18
+ v-nstc-lazy-load="lazyLoadAction"
19
+ filterable
20
+ remote
21
+ :loading="loading"
22
+ :remote-method="filterOptions"
23
+ :placeholder="chMapper.plcSelect"
24
+ :disabled="disabled"
25
+ v-bind="$attrs"
26
+ @change="selectOpt"
27
+ @blur="selectBlur"
28
+ @focus="selectFocus"
29
+ v-on="$listeners"
30
+ >
31
+ <el-option
32
+ v-for="item in options"
33
+ :key="item[valueKey]"
34
+ :label="item[labelKey]"
35
+ :value="item[valueKey]"
36
+ />
37
+ </el-select>
38
+ <i
39
+ v-if="!showClose"
40
+ class="search-btn el-input__icon el-icon-search"
41
+ @click="onSearchIconClick"
42
+ >
43
+ </i>
44
+ <i
45
+ v-if="showClose"
46
+ class="search-btn el-select__caret el-input__icon el-icon-circle-close"
47
+ @click="onClearIconClick"
48
+ ></i>
49
+ </div>
50
+
51
+ <DialogTable
52
+ ref="dialog"
53
+ v-model="showDialog"
54
+ v-bind="dialogProps"
55
+ @comfirm="onComfirm"
56
+ >
57
+ <template slot="form">
58
+ <slot></slot>
59
+ </template>
60
+ </DialogTable>
61
+ </div>
62
+ </template>
63
+
64
+ <script>
65
+ import axios from '../../../../src/utils/axios'
66
+ import DialogTable from '../../NstcDialogTable/NstcDialogTable'
67
+ export default {
68
+ name: 'NstcSelectAndDialog',
69
+ components: { DialogTable },
70
+ directives: {
71
+ 'nstc-lazy-load': {
72
+ bind(el, binding) {
73
+ const SELECTWRAP_DOM = el.querySelector(
74
+ '.el-select-dropdown .el-select-dropdown__wrap'
75
+ )
76
+ SELECTWRAP_DOM.addEventListener('scroll', function () {
77
+ const condition =
78
+ this.scrollHeight - this.scrollTop - 2 <= this.clientHeight
79
+ console.log('condition', condition)
80
+ if (condition) {
81
+ binding.value()
82
+ }
83
+ })
84
+ }
85
+ }
86
+ },
87
+ props: {
88
+ value: String,
89
+ columns: Array,
90
+ url: String,
91
+ httpMethod: {
92
+ type: String,
93
+ default: 'GET'
94
+ },
95
+ query: {
96
+ type: String,
97
+ default: 'label'
98
+ },
99
+ params: {
100
+ type: Object,
101
+ default: () => ({
102
+ isEnable: 1
103
+ })
104
+ },
105
+ rowKey: {
106
+ type: String,
107
+ default: 'id'
108
+ },
109
+ formatData: {
110
+ type: Function,
111
+ default: (d) => d
112
+ },
113
+ formatParams: {
114
+ type: Function,
115
+ default: (d) => d
116
+ },
117
+ tableForm: {
118
+ type: Object,
119
+ default: () => {}
120
+ },
121
+ valueKey: {
122
+ type: String,
123
+ default: 'value'
124
+ },
125
+ labelKey: {
126
+ type: String,
127
+ default: 'label'
128
+ },
129
+ appendToBody: {
130
+ type: Boolean,
131
+ default: true
132
+ },
133
+ disabled: {
134
+ type: Boolean,
135
+ default: false
136
+ },
137
+ chMapper: {
138
+ type: Object,
139
+ default: () => ({
140
+ title: '选择xx',
141
+ noselectmsg: '请选择xx',
142
+ plcInput: '请输入',
143
+ plcSelect: '请选择'
144
+ })
145
+ },
146
+ // 是否添加懒加载
147
+ lazyLoad: {
148
+ type: Boolean,
149
+ default: false
150
+ }
151
+ },
152
+ data() {
153
+ return {
154
+ showDialog: false,
155
+ options: [],
156
+ allData: [],
157
+ hovering: false,
158
+ loading: false,
159
+ remoteQuery: '',
160
+ dialogProps: {},
161
+ paginationObj: {
162
+ current: 1,
163
+ size: 20
164
+ },
165
+ lazyLoadLocal: false
166
+ }
167
+ },
168
+ computed: {
169
+ showClose() {
170
+ let hasValue =
171
+ this.value !== undefined && this.value !== null && this.value !== ''
172
+ return this.hovering && hasValue
173
+ },
174
+ selectValue: {
175
+ set(val) {
176
+ this.$emit('input', val)
177
+ },
178
+ get() {
179
+ console.log(this.value)
180
+ return this.value
181
+ }
182
+ }
183
+ },
184
+ beforeDestroy() {
185
+ this.$bus.$off('nstc_custom_form_config_update')
186
+ },
187
+ created() {
188
+ let props = {
189
+ title: this.chMapper.title,
190
+ warning: this.chMapper.noselectmsg,
191
+ single: true,
192
+ columns: this.columns,
193
+ rowKey: this.rowKey,
194
+ queryApi: this.queryApi,
195
+ formatParams: this.beforeFormatParams,
196
+ formatData: this.formatData,
197
+ appendToBody: this.appendToBody
198
+ }
199
+ this.dialogProps = props
200
+ this.$bus.$on('nstc_custom_form_config_update', (formData) => {
201
+ console.log('监听到的全局事件', formData)
202
+ })
203
+ },
204
+ mounted() {
205
+ this.editSetOptions()
206
+ this.lazyLoadLocal = this.lazyLoad
207
+ },
208
+ methods: {
209
+ /**
210
+ * 懒加载
211
+ */
212
+ lazyLoadAction() {
213
+ if (this.lazyLoadLocal) {
214
+ this.paginationObj.current++
215
+ this.queryAllData()
216
+ }
217
+ },
218
+ async queryAllData() {
219
+ let param = this.lazyLoadLocal
220
+ ? this.beforeFormatParams(this.paginationObj, 'init')
221
+ : this.beforeFormatParams({ size: 100, current: 1 }, 'init')
222
+ this.lazyLoadLocal ? (param.quickSearch = this.remoteQuery) : ''
223
+ let res = await this.queryApi(param)
224
+
225
+ if (!this.lazyLoadLocal && res && res.total && res.total > 100) {
226
+ param = this.beforeFormatParams({ size: res.total, current: 1 }, 'init')
227
+ let resAll = await this.queryApi(param)
228
+ res = resAll
229
+ }
230
+ console.log('数据====', res)
231
+ let { data } = this.formatData(res || [])
232
+ this.allData = this.lazyLoadLocal ? this.allData.concat(data) : data
233
+ // this.allData = data;
234
+ console.log(this.allData)
235
+ this.lazyLoadLocal ? this.setOptions(this.allData) : this.setOptions(data)
236
+ },
237
+
238
+ beforeFormatParams(pageParam, mode) {
239
+ const { size, current } = pageParam
240
+ let defaultParam = this.params
241
+ let page = this.formatPageParam(size, current)
242
+ let params
243
+ if (mode != 'init') {
244
+ let param = this.queryFormData || {}
245
+ params = { ...defaultParam, ...param, ...page }
246
+ } else {
247
+ params = { ...defaultParam, ...page }
248
+ }
249
+ return this.formatParams(params)
250
+ },
251
+
252
+ formatPageParam(size, current) {
253
+ let page = { 'page.size': size, 'page.current': current }
254
+ let method = this.httpMethod.toUpperCase()
255
+ if (method == 'POST') {
256
+ page = { page: { size, current } }
257
+ }
258
+ return page
259
+ },
260
+
261
+ queryApi(param) {
262
+ const { url, httpMethod } = this
263
+ let body = httpMethod.toUpperCase() === 'POST' ? 'data' : 'params'
264
+ let reqConf = { url, method: httpMethod }
265
+ reqConf[body] = param
266
+ return axios(reqConf)
267
+ },
268
+
269
+ setOptions(data) {
270
+ // let opts = [];
271
+ // let value = this.value;
272
+ // let valueKey = this.valueKey;
273
+ // if (value) {
274
+ // let row = data.find((item) => item[valueKey] == value);
275
+ // if (row) {
276
+ // let filters = data.filter((item) => item[valueKey] != value);
277
+ // opts = [row].concat(filters.slice(0, 9));
278
+ // } else {
279
+ // opts = data.slice(0, 10);
280
+ // }
281
+ // } else {
282
+ // opts = data.slice(0, 10);
283
+ // }
284
+ this.options = data
285
+ },
286
+
287
+ filterOptions(query) {
288
+ this.remoteQuery = query
289
+ if (this.lazyLoad) {
290
+ this.allData = []
291
+ this.queryAllData()
292
+ return
293
+ }
294
+ if (query) {
295
+ let opts = this.allData.filter((item) => {
296
+ return item[this.labelKey].indexOf(query) > -1
297
+ })
298
+ this.options = opts.slice(0, 10)
299
+ } else {
300
+ this.options = this.allData.slice(0, 10)
301
+ }
302
+ },
303
+
304
+ updateOptions(value) {
305
+ let allData = this.allData || []
306
+ let options = this.options || []
307
+ let row = allData.find((item) => item[this.valueKey] == value)
308
+ let hasRow = options.find((item) => item[this.valueKey] == value)
309
+ if (row && !hasRow) {
310
+ let opts = [row].concat(options)
311
+ this.options = opts
312
+ }
313
+ console.log(this.options)
314
+ },
315
+
316
+ // 编辑回显
317
+ editSetOptions() {
318
+ if (this.value) {
319
+ this.queryAllData()
320
+ }
321
+ },
322
+
323
+ // 显示弹窗
324
+ onSearchIconClick(event) {
325
+ this.$emit('show-dialog')
326
+ this.queryAllData()
327
+ this.showDialog = true
328
+ this.$nextTick(() => {
329
+ this.queryTableData()
330
+ })
331
+ },
332
+
333
+ onClearIconClick() {
334
+ this.options = this.allData.slice(0, 10)
335
+ this.$emit('input', '')
336
+ },
337
+
338
+ queryTableData() {
339
+ this.queryFormData = Object.assign({}, this.tableForm)
340
+ this.$refs.dialog.queryData('searchbtn')
341
+ },
342
+
343
+ selectOpt(val) {
344
+ let row = this.allData.find((item) => item[this.valueKey] == val)
345
+ console.log(val, row, this.valueKey, this.allData)
346
+ this.$emit('comfirm', [val], row)
347
+ },
348
+
349
+ selectFocus() {
350
+ this.allData = []
351
+ this.queryAllData()
352
+ },
353
+ selectBlur() {
354
+ if (this.lazyLoadLocal) {
355
+ this.paginationObj = { size: 20, current: 1 }
356
+ }
357
+ return
358
+ },
359
+
360
+ onComfirm(values, row) {
361
+ let value = row[this.valueKey]
362
+ this.updateOptions(value)
363
+ this.$emit('input', value)
364
+ this.$emit('comfirm', values, row)
365
+ }
366
+ }
367
+ }
368
+ </script>
369
+
370
+ <style scoped>
371
+ .search-btn {
372
+ color: #c0c4cc;
373
+ position: absolute;
374
+ right: 7px;
375
+ top: -1px;
376
+ }
377
+ </style>
@@ -0,0 +1,123 @@
1
+ <!--
2
+ * @Author: your name
3
+ * @Date: 2022-01-13 11:06:47
4
+ * @LastEditTime: 2022-02-14 09:47:37
5
+ * @LastEditors: Please set LastEditors
6
+ * @Description: 现金流选择
7
+ * @FilePath: NstcSelectCashFlow.vue
8
+ -->
9
+ <template>
10
+ <SelectAndDialog v-model="_value" ref="select" v-bind="bindProps" :table-form="formSearch" :format-data="formatData" @show-dialog="onShowDialog">
11
+ <div class="form-wrap">
12
+ <el-form inline :model="formSearch">
13
+ <el-form-item :label="chMapper.flowNoLabel">
14
+ <el-input :placeholder="chMapper.plcInput" v-model="formSearch.flowNoLike" maxlength="60" clearable></el-input>
15
+ </el-form-item>
16
+ <el-form-item :label="chMapper.flowNameLabel">
17
+ <el-input :placeholder="chMapper.plcInput" v-model="formSearch.flowName" maxlength="60" clearable></el-input>
18
+ </el-form-item>
19
+ <el-form-item>
20
+ <el-button type="primary" @click="searchClick">查询</el-button>
21
+ <el-button class="nstc-g6-common-btn-3" @click="queryReset">重置</el-button>
22
+ </el-form-item>
23
+ </el-form>
24
+ </div>
25
+ </SelectAndDialog>
26
+ </template>
27
+
28
+ <script>
29
+ import SelectAndDialog from "../SelectAndDialog/NstcSelectAndDialog.vue";
30
+ export default {
31
+ name: "NstcSelectCashFlow",
32
+ components: { SelectAndDialog },
33
+ props: {
34
+ value: String,
35
+ queryConf: {
36
+ type: Object,
37
+ default: () => {}
38
+ },
39
+ chMapper: {
40
+ type: Object,
41
+ default: () => ({
42
+ title: "选择现金流",
43
+ plcInput: "请输入",
44
+ plcSelect: "请选择",
45
+ noselectmsg: "请选择现金流",
46
+ flowNoLabel: "现金流编号",
47
+ flowNameLabel: "现金流名称"
48
+ })
49
+ }
50
+ },
51
+ data() {
52
+ return {
53
+ formSearch: {
54
+ flowNoLike: "",
55
+ flowName: ""
56
+ },
57
+ bindProps: {}
58
+ };
59
+ },
60
+ computed: {
61
+ _value: {
62
+ set(val) {
63
+ this.$emit("input", val);
64
+ },
65
+ get() {
66
+ return this.value;
67
+ }
68
+ }
69
+ },
70
+ created() {
71
+ let url = "/api/nstc-mdm/1.0/cashflow"
72
+ let props = {
73
+ columns: [
74
+ { prop: "flowNo", label: this.chMapper.flowNoLabel },
75
+ { prop: "flowName", label: this.chMapper.flowNameLabel }
76
+ ],
77
+ url: this.queryConf.url || url,
78
+ params: this.queryConf.defaultParam || { resultType: 0, lastNode: 1 },
79
+ rowKey: "flowNo",
80
+ valueKey: "flowNo",
81
+ labelKey: "flowName",
82
+ chMapper: this.chMapper
83
+ };
84
+ this.bindProps = props;
85
+ },
86
+ mounted() {},
87
+ methods: {
88
+ formatData(res) {
89
+ let data = [],
90
+ total = 0;
91
+ if (res && !res.total && Array.isArray(res)) {
92
+ data = res;
93
+ total = res.length;
94
+ } else if (res && res.total && res.list) {
95
+ data = res.list || [];
96
+ total = res.total;
97
+ }
98
+ data = data.map((item) => {
99
+ return {
100
+ flowNo: item.flowNo,
101
+ flowName: item.flowName
102
+ };
103
+ });
104
+ return { data, total };
105
+ },
106
+
107
+ onShowDialog() {
108
+ this.queryReset();
109
+ },
110
+
111
+ searchClick() {
112
+ this.$refs.select.queryTableData();
113
+ },
114
+
115
+ queryReset() {
116
+ this.formSearch = {
117
+ flowNoLike: "",
118
+ flowName: ""
119
+ };
120
+ }
121
+ }
122
+ };
123
+ </script>