gcs-ui-lib 1.0.1

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 (231) hide show
  1. package/.env.development +5 -0
  2. package/.env.production +7 -0
  3. package/.eslintrc.js +5 -0
  4. package/README.md +97 -0
  5. package/_webpack.config.js +135 -0
  6. package/babel.config.js +16 -0
  7. package/lib/demo.html +10 -0
  8. package/lib/fonts/SIMSUN.5e0c362c.5e0c362c.ttf +0 -0
  9. package/lib/fonts/element-icons.535877f5.535877f5.woff +0 -0
  10. package/lib/fonts/element-icons.732389de.732389de.ttf +0 -0
  11. package/lib/fonts/iconfont.09d221ee.09d221ee.woff +0 -0
  12. package/lib/fonts/iconfont.1c4bfacc.1c4bfacc.ttf +0 -0
  13. package/lib/fonts/iconfont.a6f34dc7.a6f34dc7.woff2 +0 -0
  14. package/lib/fonts/iconfont.f4c32765.f4c32765.ttf +0 -0
  15. package/lib/gcs-ui-lib.common.js +106776 -0
  16. package/lib/gcs-ui-lib.css +3 -0
  17. package/lib/gcs-ui-lib.umd.js +106786 -0
  18. package/lib/gcs-ui-lib.umd.min.js +330 -0
  19. package/lib/img/bankbackground(1).e1f6e40f.jpg +0 -0
  20. package/lib/img/busibackground(2).7e09bf1f.jpg +0 -0
  21. package/lib/img/document.193a282d.svg +8 -0
  22. package/lib/img/folder.8e019792.svg +9 -0
  23. package/lib/img/icon.fc86764f.gif +0 -0
  24. package/npm +1 -0
  25. package/package.json +101 -0
  26. package/packages/AutoFillDetail/index.js +7 -0
  27. package/packages/AutoFillDetail/src/components/fillDetail.vue +188 -0
  28. package/packages/AutoFillDetail/src/demo/index.vue +18 -0
  29. package/packages/AutoFillDetail/src/main.vue +283 -0
  30. package/packages/AutoFillDetection/index.js +7 -0
  31. package/packages/AutoFillDetection/src/components/FillInfo.vue +36 -0
  32. package/packages/AutoFillDetection/src/components/HandEntred.vue +226 -0
  33. package/packages/AutoFillDetection/src/components/RuleHit.vue +105 -0
  34. package/packages/AutoFillDetection/src/components/SelectEntries.vue +192 -0
  35. package/packages/AutoFillDetection/src/components/config.js +359 -0
  36. package/packages/AutoFillDetection/src/demo/index.vue +18 -0
  37. package/packages/AutoFillDetection/src/main.vue +130 -0
  38. package/packages/AutoFillList/index.js +7 -0
  39. package/packages/AutoFillList/src/components/ImportRules.vue +407 -0
  40. package/packages/AutoFillList/src/components/ImportRulesDialog.vue +40 -0
  41. package/packages/AutoFillList/src/components/config.js +616 -0
  42. package/packages/AutoFillList/src/demo/index.vue +28 -0
  43. package/packages/AutoFillList/src/main.vue +559 -0
  44. package/packages/AutoFillRuleHistory/index.js +7 -0
  45. package/packages/AutoFillRuleHistory/src/demo/index.vue +23 -0
  46. package/packages/AutoFillRuleHistory/src/main.vue +422 -0
  47. package/packages/AutoFillService/index.js +7 -0
  48. package/packages/AutoFillService/src/components/BudgetAccountDialogForSetting.vue +588 -0
  49. package/packages/AutoFillService/src/components/BudgetAccountSettingDialog.vue +377 -0
  50. package/packages/AutoFillService/src/components/ConditionGroup.vue +413 -0
  51. package/packages/AutoFillService/src/components/CustomInput.vue +191 -0
  52. package/packages/AutoFillService/src/components/FillComponent.vue +371 -0
  53. package/packages/AutoFillService/src/components/SelectBudgetAccountDialog.vue +161 -0
  54. package/packages/AutoFillService/src/components/SelectDialog.vue +211 -0
  55. package/packages/AutoFillService/src/components/basic.vue +308 -0
  56. package/packages/AutoFillService/src/components/config.js +549 -0
  57. package/packages/AutoFillService/src/components/fillDetail.vue +145 -0
  58. package/packages/AutoFillService/src/components/fillRules.vue +787 -0
  59. package/packages/AutoFillService/src/components/paymentCategory.vue +297 -0
  60. package/packages/AutoFillService/src/components/paymentCategoryT.vue +292 -0
  61. package/packages/AutoFillService/src/customTemplate/FillBigDecimal.vue +50 -0
  62. package/packages/AutoFillService/src/customTemplate/FillDate.vue +54 -0
  63. package/packages/AutoFillService/src/customTemplate/FillInput.vue +33 -0
  64. package/packages/AutoFillService/src/customTemplate/FillMultiSelect.vue +70 -0
  65. package/packages/AutoFillService/src/customTemplate/FillSelect.vue +72 -0
  66. package/packages/AutoFillService/src/demo/index.vue +30 -0
  67. package/packages/AutoFillService/src/main.vue +432 -0
  68. package/packages/Bank/index.js +7 -0
  69. package/packages/Bank/src/demo/index.vue +18 -0
  70. package/packages/Bank/src/main.vue +70 -0
  71. package/packages/BranchBank/index.js +7 -0
  72. package/packages/BranchBank/src/demo/index.vue +18 -0
  73. package/packages/BranchBank/src/main.vue +97 -0
  74. package/packages/ConfigurableForm/index.js +7 -0
  75. package/packages/ConfigurableForm/src/components/config.js +63 -0
  76. package/packages/ConfigurableForm/src/components/detail.vue +158 -0
  77. package/packages/ConfigurableForm/src/demo/index.vue +279 -0
  78. package/packages/ConfigurableForm/src/main.vue +529 -0
  79. package/packages/DynamicForm/index.js +7 -0
  80. package/packages/DynamicForm/src/components/Amount.vue +51 -0
  81. package/packages/DynamicForm/src/components/AmountRange.vue +76 -0
  82. package/packages/DynamicForm/src/components/CheckboxGroup.vue +63 -0
  83. package/packages/DynamicForm/src/components/DMY.vue +126 -0
  84. package/packages/DynamicForm/src/components/Date.vue +51 -0
  85. package/packages/DynamicForm/src/components/DateRange.vue +51 -0
  86. package/packages/DynamicForm/src/components/Dialog.vue +247 -0
  87. package/packages/DynamicForm/src/components/Input.vue +48 -0
  88. package/packages/DynamicForm/src/components/InputNumber.vue +69 -0
  89. package/packages/DynamicForm/src/components/InputNumberRange.vue +47 -0
  90. package/packages/DynamicForm/src/components/LazySelect.vue +311 -0
  91. package/packages/DynamicForm/src/components/RadioGroup.vue +43 -0
  92. package/packages/DynamicForm/src/components/Rate.vue +57 -0
  93. package/packages/DynamicForm/src/components/Select.vue +307 -0
  94. package/packages/DynamicForm/src/components/Switch.vue +32 -0
  95. package/packages/DynamicForm/src/components/Textarea.vue +58 -0
  96. package/packages/DynamicForm/src/components/TimeSelect.vue +61 -0
  97. package/packages/DynamicForm/src/components/unitTreeSelect.vue +141 -0
  98. package/packages/DynamicForm/src/components/urlLinkInput.vue +100 -0
  99. package/packages/DynamicForm/src/demo/index.vue +486 -0
  100. package/packages/DynamicForm/src/fileUpload.js +232 -0
  101. package/packages/DynamicForm/src/formConfig.js +2910 -0
  102. package/packages/DynamicForm/src/helpers.js +18 -0
  103. package/packages/DynamicForm/src/main.vue +1095 -0
  104. package/packages/FileImport/index.js +7 -0
  105. package/packages/FileImport/src/demo/index.vue +29 -0
  106. package/packages/FileImport/src/main.vue +306 -0
  107. package/packages/MultiCurrencyStatistics/index.js +7 -0
  108. package/packages/MultiCurrencyStatistics/src/demo/index.vue +320 -0
  109. package/packages/MultiCurrencyStatistics/src/main.vue +200 -0
  110. package/packages/SelectTicket/index.js +7 -0
  111. package/packages/SelectTicket/src/Tree/index.vue +13 -0
  112. package/packages/SelectTicket/src/demo/index.vue +139 -0
  113. package/packages/SelectTicket/src/header.js +276 -0
  114. package/packages/SelectTicket/src/main.vue +581 -0
  115. package/packages/SelectTicket/src/printDialog/dialogO.vue +116 -0
  116. package/packages/SelectTicket/src/printDialog/index.vue +69 -0
  117. package/packages/SelectTicket/src/ticketDetail/billInformation/README.MD +6 -0
  118. package/packages/SelectTicket/src/ticketDetail/billInformation/mixins/index.js +35 -0
  119. package/packages/SelectTicket/src/ticketDetail/billInformation/obverse.vue +768 -0
  120. package/packages/SelectTicket/src/ticketDetail/billInformation/overview.vue +115 -0
  121. package/packages/SelectTicket/src/ticketDetail/billInformation/printList.vue +127 -0
  122. package/packages/SelectTicket/src/ticketDetail/billInformation/reverse.vue +205 -0
  123. package/packages/SelectTicket/src/ticketDetail/billInformation//351/231/204/345/212/240/344/277/235/350/257/201/344/277/241/346/201/257/345/255/227/346/256/265/345/257/271/347/205/247.md +246 -0
  124. package/packages/SelectTicket/src/ticketDetail/dialog.vue +73 -0
  125. package/packages/SelectTicket/src/ticketDetail/img/bankbackground(1).jpg +0 -0
  126. package/packages/SelectTicket/src/ticketDetail/img/busibackground(2).jpg +0 -0
  127. package/packages/SelectTicket/src/ticketDetail/img/icon.gif +0 -0
  128. package/packages/SelectTicket/src/ticketDetail/img/icon2.png +0 -0
  129. package/packages/SelectTicket/src/ticketDetail/img/noData.png +0 -0
  130. package/packages/SelectTicket/src/ticketDetail/index.vue +188 -0
  131. package/packages/SelectTreeUnit/index.js +7 -0
  132. package/packages/SelectTreeUnit/src/Tree/document.svg +8 -0
  133. package/packages/SelectTreeUnit/src/Tree/folder.svg +9 -0
  134. package/packages/SelectTreeUnit/src/Tree/index.vue +239 -0
  135. package/packages/SelectTreeUnit/src/demo/index.vue +219 -0
  136. package/packages/SelectTreeUnit/src/forEachs.js +16 -0
  137. package/packages/SelectTreeUnit/src/main.vue +1136 -0
  138. package/packages/SelectTreeUnitForm/index.js +7 -0
  139. package/packages/SelectTreeUnitForm/src/Tree/document.svg +8 -0
  140. package/packages/SelectTreeUnitForm/src/Tree/folder.svg +9 -0
  141. package/packages/SelectTreeUnitForm/src/Tree/index.vue +254 -0
  142. package/packages/SelectTreeUnitForm/src/demo/index.vue +230 -0
  143. package/packages/SelectTreeUnitForm/src/forEachs.js +16 -0
  144. package/packages/SelectTreeUnitForm/src/main.vue +1068 -0
  145. package/packages/StreamRefill/index.js +7 -0
  146. package/packages/StreamRefill/src/components/FillBigDecimal.vue +50 -0
  147. package/packages/StreamRefill/src/components/FillDate.vue +56 -0
  148. package/packages/StreamRefill/src/components/FillInput.vue +36 -0
  149. package/packages/StreamRefill/src/components/FillMultiSelect.vue +54 -0
  150. package/packages/StreamRefill/src/components/FillSelect.vue +51 -0
  151. package/packages/StreamRefill/src/demo/index.vue +254 -0
  152. package/packages/StreamRefill/src/main.vue +335 -0
  153. package/packages/Trade/index.js +7 -0
  154. package/packages/Trade/src/components/all/index.vue +913 -0
  155. package/packages/Trade/src/components/dynamicColumnMixin.js +69 -0
  156. package/packages/Trade/src/components/getDCloumn.js +15 -0
  157. package/packages/Trade/src/components/i18n.json +3337 -0
  158. package/packages/Trade/src/components/pendingEvent/index.vue +934 -0
  159. package/packages/Trade/src/components/server-config.js +60 -0
  160. package/packages/Trade/src/components/setUnitName.js +10 -0
  161. package/packages/Trade/src/components/specialHandle.js +171 -0
  162. package/packages/Trade/src/components/topendingTabs.js +21 -0
  163. package/packages/Trade/src/demo/index.vue +43 -0
  164. package/packages/Trade/src/main.vue +86 -0
  165. package/packages/ValidateQuota/index.js +58 -0
  166. package/packages/ValidateQuota/src/demo/index.vue +190 -0
  167. package/packages/ValidateQuota/src/main.vue +71 -0
  168. package/packages/ZipImport/index.js +7 -0
  169. package/packages/ZipImport/src/demo/index.vue +139 -0
  170. package/packages/ZipImport/src/main.vue +330 -0
  171. package/packages/approvel/index.js +8 -0
  172. package/packages/approvel/src/demo/index.vue +28 -0
  173. package/packages/approvel/src/main.vue +26 -0
  174. package/packages/approvel/src/progress.vue +167 -0
  175. package/packages/approvel/src/url.json +29 -0
  176. package/packages/extends/ElSelect.vue +180 -0
  177. package/packages/imgs/list-select.png +0 -0
  178. package/packages/imgs/list-unselect.png +0 -0
  179. package/packages/imgs/list.png +0 -0
  180. package/packages/imgs/tree-select.png +0 -0
  181. package/packages/imgs/tree-unselect.png +0 -0
  182. package/packages/imgs/tree.png +0 -0
  183. package/packages/inputTag/index.js +7 -0
  184. package/packages/inputTag/src/demo/index.vue +355 -0
  185. package/packages/inputTag/src/main.vue +502 -0
  186. package/public/favicon.ico +0 -0
  187. package/public/index.html +19 -0
  188. package/src/App.vue +61 -0
  189. package/src/api/aims.js +8 -0
  190. package/src/api/common.js +254 -0
  191. package/src/api/fileApi.js +33 -0
  192. package/src/api/setting.js +249 -0
  193. package/src/config/appSettings.js +12 -0
  194. package/src/config/favicon.ico +0 -0
  195. package/src/css/autoFill.scss +252 -0
  196. package/src/css/selectTreeUnit.scss +254 -0
  197. package/src/filter/filter.js +1 -0
  198. package/src/filter/index.js +274 -0
  199. package/src/fonts/demo.css +539 -0
  200. package/src/fonts/iconfont.css +21 -0
  201. package/src/fonts/iconfont.js +1 -0
  202. package/src/fonts/iconfont.json +23 -0
  203. package/src/fonts/iconfont.ttf +0 -0
  204. package/src/index.js +161 -0
  205. package/src/locale/format.js +47 -0
  206. package/src/locale/index.js +48 -0
  207. package/src/locale/lang/cn2hk.json +1270 -0
  208. package/src/locale/lang/en.js +73 -0
  209. package/src/locale/lang/es.js +7 -0
  210. package/src/locale/lang/index.js +66 -0
  211. package/src/locale/lang/ja.js +7 -0
  212. package/src/locale/lang/zh.js +74 -0
  213. package/src/locale/lang/zht.js +27 -0
  214. package/src/main.js +49 -0
  215. package/src/preview/page/Aside/index.vue +60 -0
  216. package/src/preview/router.js +107 -0
  217. package/src/utils/auth.js +12 -0
  218. package/src/utils/directive/asciiWidth.js +107 -0
  219. package/src/utils/directive/clickOutside.js +21 -0
  220. package/src/utils/directive/vtitle.js +140 -0
  221. package/src/utils/excel.js +538 -0
  222. package/src/utils/index.js +581 -0
  223. package/src/utils/request.js +157 -0
  224. package/src/utils/requestCache.js +68 -0
  225. package/src/utils/session.js +36 -0
  226. package/src/utils/thems.js +62 -0
  227. package/src/utils/token.js +26 -0
  228. package/src/utils/tools.js +317 -0
  229. package/src/utils/utils.js +513 -0
  230. package/types/favicon.ico +0 -0
  231. package/vue.config.js +49 -0
@@ -0,0 +1,7 @@
1
+ import SelectTreeUnitForm from './src/main'
2
+
3
+ SelectTreeUnitForm.install = function(Vue) {
4
+ Vue.component(SelectTreeUnitForm.name, SelectTreeUnitForm)
5
+ }
6
+
7
+ export default SelectTreeUnitForm
@@ -0,0 +1,8 @@
1
+ <?xml version="1.0" encoding="UTF-8"?>
2
+ <svg width="20px" height="20px" viewBox="0 0 20 20" version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink">
3
+ <title>页面</title>
4
+ <g id="页面" stroke="none" stroke-width="1" fill="none" fill-rule="evenodd">
5
+ <rect id="矩形" fill="#000000" fill-rule="nonzero" opacity="0" x="0" y="0" width="20" height="20"></rect>
6
+ <path d="M16.6914062,5.63867188 C16.8085938,5.75585938 16.875,5.9140625 16.875,6.08007812 L16.875,18.125 C16.875,18.4707031 16.5957031,18.75 16.25,18.75 L3.75,18.75 C3.40429688,18.75 3.125,18.4707031 3.125,18.125 L3.125,1.875 C3.125,1.52929688 3.40429688,1.25 3.75,1.25 L12.0449219,1.25 C12.2109375,1.25 12.3710938,1.31640625 12.4882813,1.43359375 L16.6914062,5.63867188 Z M15.4335938,6.3671875 L11.7578125,2.69140625 L11.7578125,6.3671875 L15.4335938,6.3671875 Z M6.25,9.4140625 C6.16370551,9.4140625 6.09375,9.48401801 6.09375,9.5703125 L6.09375,10.5078125 C6.09375,10.594107 6.16370551,10.6640625 6.25,10.6640625 L13.75,10.6640625 C13.8362945,10.6640625 13.90625,10.594107 13.90625,10.5078125 L13.90625,9.5703125 C13.90625,9.48401801 13.8362945,9.4140625 13.75,9.4140625 L6.25,9.4140625 Z M6.25,12.0703125 C6.16370551,12.0703125 6.09375,12.140268 6.09375,12.2265625 L6.09375,13.1640625 C6.09375,13.250357 6.16370551,13.3203125 6.25,13.3203125 L9.84375,13.3203125 C9.93004449,13.3203125 10,13.250357 10,13.1640625 L10,12.2265625 C10,12.140268 9.93004449,12.0703125 9.84375,12.0703125 L6.25,12.0703125 Z" id="形状" fill="#1677FF" fill-rule="nonzero"></path>
7
+ </g>
8
+ </svg>
@@ -0,0 +1,9 @@
1
+ <?xml version="1.0" encoding="UTF-8"?>
2
+ <svg width="20px" height="20px" viewBox="0 0 20 20" version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink">
3
+ <title>文件</title>
4
+ <g id="文件" stroke="none" stroke-width="1" fill="none" fill-rule="evenodd">
5
+ <rect id="矩形" fill="#000000" fill-rule="nonzero" opacity="0" x="0" y="0" width="20" height="20"></rect>
6
+ <rect id="矩形" fill="#FFBF00" opacity="0.300000012" x="3" y="4" width="14" height="11"></rect>
7
+ <path d="M17.1875,5.828125 L10.1757812,5.828125 L7.88476562,3.63671875 C7.85546875,3.609375 7.81640625,3.59375 7.77734375,3.59375 L2.8125,3.59375 C2.46679688,3.59375 2.1875,3.87304688 2.1875,4.21875 L2.1875,15.78125 C2.1875,16.1269531 2.46679688,16.40625 2.8125,16.40625 L17.1875,16.40625 C17.5332031,16.40625 17.8125,16.1269531 17.8125,15.78125 L17.8125,6.453125 C17.8125,6.10742188 17.5332031,5.828125 17.1875,5.828125 Z" id="路径" fill="#FFBF00" fill-rule="nonzero"></path>
8
+ </g>
9
+ </svg>
@@ -0,0 +1,254 @@
1
+ <template>
2
+ <el-tree
3
+ ref="tree"
4
+ class="cl-tree cl-tree-nstc"
5
+ :node-key="nodeKey"
6
+ :expand-on-click-node="multiple?true:false"
7
+ :default-expanded-keys="defaultExpandedKeys"
8
+ :data="data"
9
+ check-strictly
10
+ :show-checkbox="multiple"
11
+ :props="props"
12
+ v-bind="$attrs"
13
+ v-on="$listeners"
14
+ >
15
+ <div
16
+ slot-scope="{ node, data }"
17
+ :class="data.disabled ? 'nstc-tree-disabled' : ''"
18
+ class="flex-box flex-lr flex-v cl-tree-item"
19
+ @mouseenter="mouseenterTree(node, data)"
20
+ @mouseleave="checkFlag = false"
21
+ >
22
+ <div
23
+ class=" w-500px"
24
+ :title="
25
+ (data[props.value] ? '(' + data[props.value] + ') ' : '') +
26
+ data[props.label]
27
+ "
28
+ >
29
+ <!-- <img :src="node.level == 1 ? folder : desc" class="m-r-ss" alt="" /> -->
30
+ {{
31
+ (data[props.value] ? "(" + data[props.value] + ") " : "") +
32
+ data[props.label]
33
+ }}
34
+ </div>
35
+ <!-- {{ node.data[nodeKey] }} -->
36
+ <div class="row-point" v-show="multiple && !isList">
37
+ <el-dropdown @click.stop="() => null">
38
+ <span class="el-dropdown-link"> ... </span>
39
+ <el-dropdown-menu slot="dropdown" class="nstc-unit-tree-drop">
40
+ <el-dropdown-item
41
+ @click.native.stop="handleCheckedBro(node, data)"
42
+ >{{ $t("common_a_0006") }}</el-dropdown-item
43
+ >
44
+ <el-dropdown-item
45
+ @click.native.stop="handleCheckedChild(node, data, 'direct')"
46
+ >
47
+ {{ $t("common_a_0008") }}</el-dropdown-item
48
+ >
49
+ <el-dropdown-item
50
+ @click.native.stop="handleCheckedChild(node, data, 'all')"
51
+ >{{ $t("common_a_0007") }}</el-dropdown-item
52
+ >
53
+ <el-dropdown-item
54
+ @click.native.stop="handleCheckedChild(node, data, 'cancel')"
55
+ >{{ $t("common_a_0007_1") }}</el-dropdown-item
56
+ >
57
+ </el-dropdown-menu>
58
+ </el-dropdown>
59
+ <!-- <span-->
60
+ <!-- @click="-->
61
+ <!-- showDropMenu == node.data.id-->
62
+ <!-- ? (showDropMenu = null)-->
63
+ <!-- : (showDropMenu = node.data.id)-->
64
+ <!-- "-->
65
+ <!-- >-->
66
+ <!-- . . .-->
67
+ <!-- </span>-->
68
+ <!-- <div class="drop-box" v-if="showDropMenu == node.data.id">-->
69
+ <!-- &lt;!&ndash; <div v-if="!node.data.disabled" @click="handleChecked(node, data)">只勾选本单位</div> &ndash;&gt;-->
70
+ <!-- &lt;!&ndash; 勾选本单位及平级单位&ndash;&gt;-->
71
+ <!-- <div v-if="!node.data.disabled" @click="handleCheckedBro(node, data)">-->
72
+ <!-- {{ $t("common_a_0006") }}-->
73
+ <!-- </div>-->
74
+ <!-- &lt;!&ndash;勾选直接下级单位&ndash;&gt;-->
75
+ <!-- <div @click="handleCheckedChild(node, data, 'direct')">-->
76
+ <!-- {{ $t("common_a_0008") }}-->
77
+ <!-- </div>-->
78
+ <!-- &lt;!&ndash;勾选所有下级单位&ndash;&gt;-->
79
+ <!-- <div @click="handleCheckedChild(node, data, 'all')">-->
80
+ <!-- {{ $t("common_a_0007") }}-->
81
+ <!-- </div>-->
82
+ <!-- </div>-->
83
+ <!-- </div>-->
84
+ <!-- <el-button
85
+ v-if="
86
+ showCheckbox &&
87
+ node.checked &&
88
+ node.data[nodeKey] === (checkFlag && checkFlag.data && checkFlag.data[nodeKey])
89
+ "
90
+ type="text"
91
+ class="m-r-s"
92
+ @click="handleClose(node, data)"
93
+ >{{ $lc('取消勾选') }}</el-button
94
+ >
95
+ <el-button
96
+ v-else-if="
97
+ !node.data.disabled &&
98
+ showCheckbox &&
99
+ !node.checked &&
100
+ node.data[nodeKey] === (checkFlag && checkFlag.data && checkFlag.data[nodeKey])
101
+ "
102
+ type="text"
103
+ class="m-r-s"
104
+ @click="handleChecked(node, data)"
105
+ >{{ $lc('只勾选本层级') }}</el-button
106
+ > -->
107
+ </div>
108
+ </div>
109
+ </el-tree>
110
+ </template>
111
+ <script>
112
+ export default {
113
+ name: "Tree",
114
+ props: {
115
+ isList: {
116
+ type: Boolean,
117
+ default: false,
118
+ },
119
+ data: {
120
+ type: Array,
121
+ default: () => [],
122
+ },
123
+ defaultExpandedKeys: {
124
+ type: Array,
125
+ default: () => [],
126
+ },
127
+ props: {
128
+ type: Object,
129
+ default: () => ({}),
130
+ },
131
+ multiple: {
132
+ type: Boolean,
133
+ default: false,
134
+ },
135
+ // showCheckbox: {
136
+ // type: Boolean,
137
+ // default: false
138
+ // },
139
+ checkStrictly: {
140
+ type: Boolean,
141
+ default: false,
142
+ },
143
+ nodeKey: {
144
+ type: String,
145
+ default: "",
146
+ },
147
+ },
148
+ data() {
149
+ return {
150
+ folder: require("./folder.svg"),
151
+ desc: require("./document.svg"),
152
+ checkFlag: {},
153
+ showDropMenu: null,
154
+ list: [],
155
+ };
156
+ },
157
+ computed: {
158
+ checkStrictlyC: {
159
+ get() {
160
+ return this.checkStrictly;
161
+ },
162
+ set(v) {
163
+ // console.log(v, 123);
164
+ return this.$emit("update:checkStrictly", v);
165
+ },
166
+ },
167
+ },
168
+ mounted() {
169
+ this.setRefData();
170
+ },
171
+ methods: {
172
+ setRefData() {
173
+ const {
174
+ store,
175
+ filter,
176
+ updateKeyChildren,
177
+ getCheckedNodes,
178
+ setCheckedNodes,
179
+ getCheckedKeys,
180
+ setCheckedKeys,
181
+ setChecked,
182
+ getHalfCheckedNodes,
183
+ getHalfCheckedKeys,
184
+ getCurrentKey,
185
+ getCurrentNode,
186
+ setCurrentKey,
187
+ setCurrentNode,
188
+ getNode,
189
+ remove,
190
+ append,
191
+ insertBefore,
192
+ insertAfter,
193
+ } = this.$refs["tree"];
194
+
195
+ this.filter = filter;
196
+ this.updateKeyChildren = updateKeyChildren;
197
+ this.getCheckedNodes = getCheckedNodes;
198
+ this.setCheckedNodes = setCheckedNodes;
199
+ this.getCheckedKeys = getCheckedKeys;
200
+ this.setCheckedKeys = setCheckedKeys;
201
+ this.setChecked = setChecked;
202
+ this.getHalfCheckedNodes = getHalfCheckedNodes;
203
+ this.getHalfCheckedKeys = getHalfCheckedKeys;
204
+ this.getCurrentKey = getCurrentKey;
205
+ this.getCurrentNode = getCurrentNode;
206
+ this.setCurrentKey = setCurrentKey;
207
+ this.setCurrentNode = setCurrentNode;
208
+ this.getNode = getNode;
209
+ this.remove = remove;
210
+ this.append = append;
211
+ this.insertBefore = insertBefore;
212
+ this.insertAfter = insertAfter;
213
+ this.store = store;
214
+ },
215
+ handleChecked(node, data) {
216
+ // this.store.checkStrictly = true
217
+ this.setChecked(node.data, true);
218
+ this.$emit("check", data, {
219
+ checkedKeys: this.getCheckedKeys(),
220
+ checkedNodes: this.getCheckedNodes(),
221
+ halfCheckedNodes: this.getHalfCheckedNodes(),
222
+ halfCheckedKeys: this.getHalfCheckedKeys(),
223
+ });
224
+ // this.store.checkStrictly = false
225
+ },
226
+ handleCheckedBro(node, data) {
227
+ //勾选平级单位
228
+ this.$emit("checkedBro", data);
229
+ },
230
+ handleCheckedChild(node, data, type) {
231
+ //勾选平级单位
232
+ this.$emit("checkedChild", { node, data, type: type });
233
+ },
234
+ mouseenterTree(node, data) {
235
+ this.checkFlag = node;
236
+ },
237
+ handleClose(node, data) {
238
+ // this.store.checkStrictly = true
239
+ this.setChecked(node.data, false);
240
+ this.$emit("check", data, {
241
+ checkedKeys: this.getCheckedKeys(),
242
+ checkedNodes: this.getCheckedNodes(),
243
+ halfCheckedNodes: this.getHalfCheckedNodes(),
244
+ halfCheckedKeys: this.getHalfCheckedKeys(),
245
+ });
246
+ // this.store.checkStrictly = false
247
+ },
248
+ },
249
+ };
250
+ </script>
251
+
252
+ <style scoped>
253
+
254
+ </style>
@@ -0,0 +1,230 @@
1
+ <template>
2
+ <div>
3
+ <!-- {{ unitData }} -->
4
+ <!-- 一般使用 -->
5
+ <!-- 说明:
6
+ 1、不支持默认选择全部
7
+ -->
8
+ <!-- 参数:
9
+ url:数据请求路径
10
+ isUnitDataScope:0不过滤权限,1过滤权限,默认值0
11
+ moduleNo:资金体系树的moduleNo,比如票据:bill-group relaNo:权限码
12
+ node-key:唯一标识,固定为id
13
+ defaultSelect:默认选择单位,可传多个
14
+ upDateValue:用于更新回显值,区别于defaultSelect,不做监听,手动通过upDateShowValue方法更新,更新的数据必须有id
15
+ multiple:是否多选,默认单选
16
+ disabled:禁用状态
17
+ clearable:快速清除,默认为true
18
+ showAllCheck:展示全部单位复选框
19
+ selectFirst:初始化时选取第一家有权限单位
20
+ searchUnitNo:指定查询某一个单位下的所有下级,此模式暂不支持默认单位
21
+ defineProps:映射,目前不支持,接口返回数据和代码逻辑强绑定 -->
22
+ <!-- 事件
23
+ @dataChange 值改变事件 返回数组嵌套单位对象
24
+ -->
25
+ <!-- 方法
26
+ upDateShowValue:刷新表单回显值showValue,传true时,会根据选择值更新树的选择状态,如无需要不要传值,在值upDateValue改变后,在this.$nextTick里面调用方法。
27
+ -->
28
+ <!-- 多选 -->
29
+ <h2>多选</h2>
30
+ {{ unitData1 }}
31
+ <SelectTree
32
+ v-model="unitData1"
33
+ multiple
34
+ :url="'/api/nstc-gtcp/1.0/fundTree'"
35
+ :isUnitDataScope="'1'"
36
+ :defaultSelect="[{ unitName: '山子动力有限公司', unitNo: '1061001' }]"
37
+ :moduleNo="'bill-group'"
38
+ :relaNo="'dft_bill_toBePaid01'"
39
+ node-key="id"
40
+ />
41
+ <!-- 单选 -->
42
+ <h2>单选</h2>
43
+ {{ unitData2 }}
44
+ <SelectTree
45
+ v-model="unitData2"
46
+ :url="'/api/nstc-gtcp/1.0/fundTree'"
47
+ :isUnitDataScope="'0'"
48
+ :moduleNo="'bill-group'"
49
+ select-first
50
+ :relaNo="'dft_bill_toBePaid01'"
51
+ node-key="id"
52
+ />
53
+ <!-- 更新选择值使用方法 -->
54
+ <h2>更新选择值使用方法</h2>
55
+ {{ unitData3 }}
56
+ <el-button @click="refresh()">更新</el-button>
57
+ <SelectTree
58
+ ref="selectTreeUnitForm"
59
+ clearable
60
+ v-model="unitData3"
61
+ :upDateValue="upDateValue"
62
+ :defaultSelect="[{ unitName: '山子动力有限公司', unitNo: '1061001' }]"
63
+ :url="'/api/nstc-gtcp/1.0/fundTree'"
64
+ :isUnitDataScope="'0'"
65
+ :multiple="true"
66
+ :moduleNo="'bill-group'"
67
+ :relaNo="'dft_bill_toBePaid01'"
68
+ node-key="id"
69
+ />
70
+ <h2>在表单中</h2>
71
+ {{ postForm.unitNo }}
72
+ <el-form label-width="80px" :model="postForm" :rules="rules">
73
+ <el-form-item prop="unitNo" :label="$l('单位名称')">
74
+ <SelectTree
75
+ ref="unitRef"
76
+ defaultSelectAll
77
+ v-model="postForm.cltNo"
78
+ :url="'/api/nstc-gtcp/1.0/fundTree'"
79
+ :isUnitDataScope="'1'"
80
+ moduleNo="PTMS"
81
+ node-key="id"
82
+ relaNo="payment001"
83
+ multiple
84
+ v-bind="$attrs"
85
+ @dataChange="(data, isClick) => getUnitName(data, isClick, 'clt')"
86
+ />
87
+ </el-form-item>
88
+ </el-form>
89
+ <!-- <SelectTree
90
+ ref="selectTreeUnitForm"
91
+ clearable
92
+ showAllCheck
93
+ selectFirst
94
+ multiple
95
+ v-model="unitData4"
96
+ :defaultSelect="[mapData]"
97
+ :upDateValue="upDateValue"
98
+ :url="'/api/nstc-gtcp/1.0/fundTree'"
99
+ :isUnitDataScope="'0'"
100
+ :moduleNo="'bill-group'"
101
+ :relaNo="'aimsk011'"
102
+ node-key="id"
103
+ /> -->
104
+ </div>
105
+ </template>
106
+
107
+ <script>
108
+ import emitter from "element-ui/src/mixins/emitter";
109
+ import SelectTree from "./../main.vue";
110
+ export default {
111
+ name: "SelectTreeUnitDemo",
112
+ mixins: [emitter],
113
+ components: {
114
+ SelectTree,
115
+ },
116
+
117
+ data() {
118
+ return {
119
+ mapData: {
120
+ unitName: "深圳思凯",
121
+ unitNo: "3003",
122
+ id: 2824,
123
+ pid: 2820,
124
+ hasChild: 0,
125
+ children: null,
126
+ disabled: false,
127
+ },
128
+ postForm: {
129
+ unitNo: "",
130
+ },
131
+ rules: {
132
+ unitNo: [
133
+ {
134
+ required: true,
135
+ message: "请选择单位名称",
136
+ trigger: ["change"],
137
+ },
138
+ ],
139
+ },
140
+ upDateValue: [],
141
+ unitData1: "",
142
+ unitData2: "",
143
+ unitData3: "",
144
+ unitData4: "",
145
+ unitData5: "",
146
+ unitData6: "",
147
+ treeList: [
148
+ {
149
+ label: "1",
150
+ value: "1",
151
+ id: "1",
152
+ pid: "0",
153
+ children: [
154
+ {
155
+ label: "1-1",
156
+ id: "1-1",
157
+ pid: "1",
158
+ value: "1-1",
159
+ children: [
160
+ { label: "1-1-1", id: "1-1-1", pid: "1-1", value: "1-1-1" },
161
+ ],
162
+ },
163
+ {
164
+ label: "1-2",
165
+ id: "1-2",
166
+ pid: "1",
167
+ value: "1-2",
168
+ children: [
169
+ { label: "1-2-1", id: "1-2-1", pid: "1-2", value: "1-2-1" },
170
+ ],
171
+ },
172
+ ],
173
+ },
174
+ {
175
+ label: "2",
176
+ value: "2",
177
+ id: "2",
178
+ pid: "0",
179
+ children: [
180
+ {
181
+ label: "2-1",
182
+ id: "2-1",
183
+ pid: "2",
184
+ value: "2-1",
185
+ disabled: true,
186
+ children: [
187
+ { label: "2-1-1", id: "2-1-1", pid: "2-1", value: "2-1-1" },
188
+ ],
189
+ },
190
+ {
191
+ label: "2-2",
192
+ id: "2-2",
193
+ pid: "2",
194
+ value: "2-2",
195
+ children: [
196
+ { label: "2-2-1", id: "2-2-1", pid: "2-2", value: "2-2-1" },
197
+ ],
198
+ },
199
+ ],
200
+ },
201
+ ],
202
+ };
203
+ },
204
+ watch: {
205
+ unitData1(val) {
206
+ console.log("unitData1===>", val);
207
+ if (!val) {
208
+ debugger;
209
+ }
210
+ },
211
+ },
212
+ mounted() {},
213
+ methods: {
214
+ dataChange(res, type) {
215
+ this.postForm.unitNo = res.map((item) => item.unitNo);
216
+ console.log(res, type, 888);
217
+ },
218
+ refresh() {
219
+ this.upDateValue = [{ unitNo: "001", unitName: "北京九恒星", id: "1" }];
220
+ // console.log(11111, this.upDateValue);
221
+ this.$nextTick(() => {
222
+ this.$refs.selectTreeUnitForm.upDateShowValue();
223
+ });
224
+ },
225
+ },
226
+ };
227
+ </script>
228
+
229
+ <style lang="scss" scoped>
230
+ </style>
@@ -0,0 +1,16 @@
1
+ function forEachs(arr, callback, branch = 'children', arrp = {}) {
2
+ if (typeof callback === 'function') {
3
+ _forEachs(arr, callback, branch, arrp)
4
+ }
5
+ }
6
+
7
+ function _forEachs(arr, callback, branch, arrp) {
8
+ arr.forEach(function (item, _i, _arr) {
9
+ callback(item, _i, _arr, arrp)
10
+ if (item[branch] && Array.isArray(item[branch])) {
11
+ _forEachs(item[branch], callback, branch, item)
12
+ }
13
+ })
14
+ }
15
+
16
+ export default forEachs