swordpass-ui 1.0.0

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 (330) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +37 -0
  3. package/lib/demo.html +10 -0
  4. package/lib/img/icon_found_img.c785c1b7.png +0 -0
  5. package/lib/sword-vue-ui.common.js +61402 -0
  6. package/lib/sword-vue-ui.css +1 -0
  7. package/lib/sword-vue-ui.umd.js +61412 -0
  8. package/lib/sword-vue-ui.umd.min.js +6 -0
  9. package/package.json +109 -0
  10. package/packages/AddQueryStrategy/index.js +7 -0
  11. package/packages/AddQueryStrategy/src/main.vue +236 -0
  12. package/packages/Autocomplete/index.js +7 -0
  13. package/packages/Autocomplete/src/main.vue +192 -0
  14. package/packages/Button/index.js +7 -0
  15. package/packages/Button/src/main.vue +90 -0
  16. package/packages/Cascader/index.js +7 -0
  17. package/packages/Cascader/src/main.vue +210 -0
  18. package/packages/Chart/index.js +7 -0
  19. package/packages/Chart/src/Chart.vue +831 -0
  20. package/packages/Checkbox/index.js +7 -0
  21. package/packages/Checkbox/src/main.vue +200 -0
  22. package/packages/Collapse/index.js +7 -0
  23. package/packages/Collapse/src/ClCollapse.vue +67 -0
  24. package/packages/Collapse/src/ClCollapseItem.vue +21 -0
  25. package/packages/CollapseItem/index.js +7 -0
  26. package/packages/CustomDialog/index.js +7 -0
  27. package/packages/CustomDialog/src/customDialog.js +99 -0
  28. package/packages/CustomDialog/src/main.vue +1944 -0
  29. package/packages/DataView/index.js +7 -0
  30. package/packages/DataView/src/DataView.vue +45 -0
  31. package/packages/Date/index.js +7 -0
  32. package/packages/Date/src/main.vue +180 -0
  33. package/packages/DatePicker/index.js +7 -0
  34. package/packages/DatePicker/src/main.vue +155 -0
  35. package/packages/Demension/index.js +7 -0
  36. package/packages/Demension/src/main.vue +379 -0
  37. package/packages/Dialog/index.js +7 -0
  38. package/packages/Dialog/src/main.vue +160 -0
  39. package/packages/Dictionary/index.js +7 -0
  40. package/packages/Dictionary/src/main.vue +204 -0
  41. package/packages/DimensionSelector/index.js +7 -0
  42. package/packages/DimensionSelector/src/main.vue +359 -0
  43. package/packages/DimensionSelectorInput/index.js +7 -0
  44. package/packages/DimensionSelectorInput/src/main.vue +79 -0
  45. package/packages/Divider/index.js +7 -0
  46. package/packages/Divider/src/main.vue +38 -0
  47. package/packages/Duration/index.js +7 -0
  48. package/packages/Duration/src/main.vue +172 -0
  49. package/packages/Editor/index.js +7 -0
  50. package/packages/Editor/src/main.vue +280 -0
  51. package/packages/Explain/index.js +7 -0
  52. package/packages/Explain/src/main.vue +55 -0
  53. package/packages/FieldTail/index.js +7 -0
  54. package/packages/FieldTail/src/main.vue +163 -0
  55. package/packages/File/index.js +7 -0
  56. package/packages/File/src/FileCard.vue +169 -0
  57. package/packages/File/src/FileList.vue +180 -0
  58. package/packages/File/src/FileTable.vue +223 -0
  59. package/packages/File/src/main.vue +467 -0
  60. package/packages/FileUpload/index.js +7 -0
  61. package/packages/FileUpload/src/main.vue +222 -0
  62. package/packages/FlowChart/index.js +7 -0
  63. package/packages/FlowChart/src/main.vue +386 -0
  64. package/packages/FormItem/index.js +7 -0
  65. package/packages/FormItem/src/main.vue +167 -0
  66. package/packages/Global/index.js +12 -0
  67. package/packages/Global/src/GlobalQuery.vue +200 -0
  68. package/packages/Global/src/GlobalValidate.vue +69 -0
  69. package/packages/Icon/index.js +7 -0
  70. package/packages/Icon/src/icons/ad.js +14 -0
  71. package/packages/Icon/src/icons/address-book.js +14 -0
  72. package/packages/Icon/src/icons/arrow.js +14 -0
  73. package/packages/Icon/src/icons/attachment.js +18 -0
  74. package/packages/Icon/src/icons/balance.js +14 -0
  75. package/packages/Icon/src/icons/ban.js +14 -0
  76. package/packages/Icon/src/icons/bell.js +14 -0
  77. package/packages/Icon/src/icons/block.js +26 -0
  78. package/packages/Icon/src/icons/book.js +14 -0
  79. package/packages/Icon/src/icons/bookmark.js +14 -0
  80. package/packages/Icon/src/icons/bug.js +22 -0
  81. package/packages/Icon/src/icons/bullhorn.js +14 -0
  82. package/packages/Icon/src/icons/calc.js +14 -0
  83. package/packages/Icon/src/icons/checkbox.js +14 -0
  84. package/packages/Icon/src/icons/circle.js +14 -0
  85. package/packages/Icon/src/icons/close.js +14 -0
  86. package/packages/Icon/src/icons/cloud-sun.js +14 -0
  87. package/packages/Icon/src/icons/coffee.js +14 -0
  88. package/packages/Icon/src/icons/component.js +14 -0
  89. package/packages/Icon/src/icons/compress.js +14 -0
  90. package/packages/Icon/src/icons/copyright.js +14 -0
  91. package/packages/Icon/src/icons/dialog.js +14 -0
  92. package/packages/Icon/src/icons/download.js +14 -0
  93. package/packages/Icon/src/icons/duration.js +14 -0
  94. package/packages/Icon/src/icons/excel.js +18 -0
  95. package/packages/Icon/src/icons/expand.js +14 -0
  96. package/packages/Icon/src/icons/export.js +21 -0
  97. package/packages/Icon/src/icons/eye-slash.js +14 -0
  98. package/packages/Icon/src/icons/eye.js +14 -0
  99. package/packages/Icon/src/icons/file.js +18 -0
  100. package/packages/Icon/src/icons/form.js +14 -0
  101. package/packages/Icon/src/icons/ganged.js +14 -0
  102. package/packages/Icon/src/icons/gaode.js +27 -0
  103. package/packages/Icon/src/icons/gift.js +14 -0
  104. package/packages/Icon/src/icons/home.js +14 -0
  105. package/packages/Icon/src/icons/image.js +14 -0
  106. package/packages/Icon/src/icons/import.js +18 -0
  107. package/packages/Icon/src/icons/index.js +67 -0
  108. package/packages/Icon/src/icons/info.js +21 -0
  109. package/packages/Icon/src/icons/laptop.js +14 -0
  110. package/packages/Icon/src/icons/line.js +34 -0
  111. package/packages/Icon/src/icons/lock.js +14 -0
  112. package/packages/Icon/src/icons/map.js +18 -0
  113. package/packages/Icon/src/icons/more.js +19 -0
  114. package/packages/Icon/src/icons/move.js +14 -0
  115. package/packages/Icon/src/icons/org.js +18 -0
  116. package/packages/Icon/src/icons/palette.js +14 -0
  117. package/packages/Icon/src/icons/plan.js +17 -0
  118. package/packages/Icon/src/icons/ppt.js +18 -0
  119. package/packages/Icon/src/icons/question.js +18 -0
  120. package/packages/Icon/src/icons/radio.js +14 -0
  121. package/packages/Icon/src/icons/refresh.js +14 -0
  122. package/packages/Icon/src/icons/search.js +14 -0
  123. package/packages/Icon/src/icons/select.js +14 -0
  124. package/packages/Icon/src/icons/setting.js +18 -0
  125. package/packages/Icon/src/icons/simple-collapse.js +18 -0
  126. package/packages/Icon/src/icons/simple-expand.js +14 -0
  127. package/packages/Icon/src/icons/sort.js +22 -0
  128. package/packages/Icon/src/icons/sword.js +26 -0
  129. package/packages/Icon/src/icons/table.js +14 -0
  130. package/packages/Icon/src/icons/time.js +14 -0
  131. package/packages/Icon/src/icons/tree.js +14 -0
  132. package/packages/Icon/src/icons/typography.js +18 -0
  133. package/packages/Icon/src/icons/upload.js +18 -0
  134. package/packages/Icon/src/icons/user.js +14 -0
  135. package/packages/Icon/src/icons/users.js +30 -0
  136. package/packages/Icon/src/icons/video.js +14 -0
  137. package/packages/Icon/src/icons/word.js +18 -0
  138. package/packages/Icon/src/main.vue +432 -0
  139. package/packages/Image/index.js +7 -0
  140. package/packages/Image/src/main.vue +66 -0
  141. package/packages/Input/index.js +7 -0
  142. package/packages/Input/src/main.vue +552 -0
  143. package/packages/JobSelector/index.js +7 -0
  144. package/packages/JobSelector/src/main.vue +339 -0
  145. package/packages/JobSelectorInput/index.js +7 -0
  146. package/packages/JobSelectorInput/src/main.vue +87 -0
  147. package/packages/Map/index.js +7 -0
  148. package/packages/Map/src/Map.vue +427 -0
  149. package/packages/Milepost/index.js +7 -0
  150. package/packages/Milepost/src/main.vue +45 -0
  151. package/packages/OnlineForm/index.js +7 -0
  152. package/packages/OnlineForm/src/Form.vue +359 -0
  153. package/packages/OrgPostDialog/index.js +7 -0
  154. package/packages/OrgPostDialog/src/main.vue +244 -0
  155. package/packages/OrgSelector/index.js +7 -0
  156. package/packages/OrgSelector/src/main.vue +493 -0
  157. package/packages/OrgSelectorInput/index.js +7 -0
  158. package/packages/OrgSelectorInput/src/OrgSelectorInput.vue +216 -0
  159. package/packages/PostSelector/index.js +7 -0
  160. package/packages/PostSelector/src/main.vue +463 -0
  161. package/packages/PostSelectorInput/index.js +7 -0
  162. package/packages/PostSelectorInput/src/PostSelectorInput.vue +200 -0
  163. package/packages/Preview/index.js +7 -0
  164. package/packages/Preview/src/FillPage.vue +311 -0
  165. package/packages/Preview/src/FrameViewer.vue +135 -0
  166. package/packages/Preview/src/Loading.vue +126 -0
  167. package/packages/Preview/src/PdfViewer.vue +125 -0
  168. package/packages/Preview/src/TextViewer.vue +99 -0
  169. package/packages/Preview/src/main.vue +242 -0
  170. package/packages/Preview/src/watermark.js +124 -0
  171. package/packages/ProcessRecord/index.js +7 -0
  172. package/packages/ProcessRecord/src/main.vue +392 -0
  173. package/packages/Qrcode/index.js +7 -0
  174. package/packages/Qrcode/src/Qrcode.vue +105 -0
  175. package/packages/QuerySqlPreview/index.js +7 -0
  176. package/packages/QuerySqlPreview/src/QuerySqlPreview.vue +163 -0
  177. package/packages/Radio/index.js +7 -0
  178. package/packages/Radio/src/main.vue +172 -0
  179. package/packages/Rate/index.js +7 -0
  180. package/packages/Rate/src/main.vue +89 -0
  181. package/packages/ReadonlyInput/index.js +7 -0
  182. package/packages/ReadonlyInput/src/main.vue +92 -0
  183. package/packages/RelevantFlow/index.js +7 -0
  184. package/packages/RelevantFlow/src/main.vue +547 -0
  185. package/packages/RelevantFlow/src/relevantFlow.js +28 -0
  186. package/packages/RoleSelector/index.js +7 -0
  187. package/packages/RoleSelector/src/main.vue +358 -0
  188. package/packages/RoleSelectorInput/index.js +7 -0
  189. package/packages/RoleSelectorInput/src/main.vue +84 -0
  190. package/packages/SaveButton/index.js +7 -0
  191. package/packages/SaveButton/src/main.vue +73 -0
  192. package/packages/Select/index.js +7 -0
  193. package/packages/Select/src/main.vue +330 -0
  194. package/packages/SelectTree/index.js +7 -0
  195. package/packages/SelectTree/src/SelectTree.vue +352 -0
  196. package/packages/Selector/index.js +7 -0
  197. package/packages/Selector/src/main.vue +617 -0
  198. package/packages/SidebarDialog/index.js +7 -0
  199. package/packages/SidebarDialog/src/main.vue +156 -0
  200. package/packages/Slider/index.js +7 -0
  201. package/packages/Slider/src/main.vue +84 -0
  202. package/packages/Step/index.js +7 -0
  203. package/packages/StepLayout/index.js +7 -0
  204. package/packages/Steps/index.js +7 -0
  205. package/packages/Steps/src/Step.vue +122 -0
  206. package/packages/Steps/src/StepLayout.vue +35 -0
  207. package/packages/Steps/src/Steps.vue +65 -0
  208. package/packages/Subtable/index.js +33 -0
  209. package/packages/Subtable/src/SubDialog.vue +1926 -0
  210. package/packages/Subtable/src/SubExportDialog.vue +115 -0
  211. package/packages/Subtable/src/SubImportDialog.vue +316 -0
  212. package/packages/Subtable/src/SubPagination.vue +112 -0
  213. package/packages/Subtable/src/SubtableBackfill.vue +83 -0
  214. package/packages/Subtable/src/dialog.js +42 -0
  215. package/packages/Switch/index.js +7 -0
  216. package/packages/Switch/src/main.vue +83 -0
  217. package/packages/Table/index.js +7 -0
  218. package/packages/Table/src/CustomColumn.vue +351 -0
  219. package/packages/Table/src/Table.vue +979 -0
  220. package/packages/TableColumn/index.js +7 -0
  221. package/packages/TableColumn/src/main.vue +177 -0
  222. package/packages/TableSearchField/index.js +7 -0
  223. package/packages/TableSearchField/src/main.vue +334 -0
  224. package/packages/TableSearchPanel/index.js +7 -0
  225. package/packages/TableSearchPanel/src/main.vue +149 -0
  226. package/packages/Tabs/index.js +7 -0
  227. package/packages/Tabs/src/Tabs.vue +140 -0
  228. package/packages/Tag/index.js +7 -0
  229. package/packages/Tag/src/main.vue +264 -0
  230. package/packages/TemplateBatchUpdate/index.js +7 -0
  231. package/packages/TemplateBatchUpdate/src/TemplateBatchUpdateDialog.vue +174 -0
  232. package/packages/TemplateForm/index.js +7 -0
  233. package/packages/TemplateForm/src/main.vue +645 -0
  234. package/packages/TemplateFormDialog/index.js +7 -0
  235. package/packages/TemplateFormDialog/src/main.vue +61 -0
  236. package/packages/TemplateImportResult/index.js +7 -0
  237. package/packages/TemplateImportResult/src/main.vue +158 -0
  238. package/packages/TemplatePreview/index.js +19 -0
  239. package/packages/TemplatePreview/src/TemplatePreview.vue +169 -0
  240. package/packages/TemplatePreview/src/TemplatePreviewFile.vue +171 -0
  241. package/packages/TemplatePreview/src/TemplatePreviewImage.vue +83 -0
  242. package/packages/TemplateTaskCirculate/index.js +7 -0
  243. package/packages/TemplateTaskCirculate/src/main.vue +238 -0
  244. package/packages/Text/index.js +7 -0
  245. package/packages/Text/src/main.vue +57 -0
  246. package/packages/TimePicker/index.js +7 -0
  247. package/packages/TimePicker/src/main.vue +139 -0
  248. package/packages/TimeSelect/index.js +7 -0
  249. package/packages/TimeSelect/src/main.vue +96 -0
  250. package/packages/Tree/index.js +7 -0
  251. package/packages/Tree/src/main.vue +439 -0
  252. package/packages/TreeDialog/index.js +7 -0
  253. package/packages/TreeDialog/src/main.vue +293 -0
  254. package/packages/TreeListDialog/index.js +7 -0
  255. package/packages/TreeListDialog/src/main.vue +219 -0
  256. package/packages/Typography/index.js +8 -0
  257. package/packages/Typography/src/create-header.js +72 -0
  258. package/packages/UserDialog/index.js +7 -0
  259. package/packages/UserDialog/src/main.vue +250 -0
  260. package/packages/UserSelector/index.js +7 -0
  261. package/packages/UserSelector/src/main.vue +746 -0
  262. package/packages/UserSelectorInput/index.js +7 -0
  263. package/packages/UserSelectorInput/src/main.vue +319 -0
  264. package/packages/picture/index.js +7 -0
  265. package/packages/picture/src/main.vue +530 -0
  266. package/packages/plugins/Echarts.js +30 -0
  267. package/packages/plugins/Map.js +29 -0
  268. package/packages/plugins/Preview.js +49 -0
  269. package/packages/plugins/Qrcode.js +7 -0
  270. package/packages/plugins/XLSX.js +7 -0
  271. package/packages/plugins/wangeditor.js +19 -0
  272. package/src/assets/icon_found_img.png +0 -0
  273. package/src/assets/table-no-data.png +0 -0
  274. package/src/directive/badge.js +53 -0
  275. package/src/directive/copy.js +47 -0
  276. package/src/directive/ellipsis.js +6 -0
  277. package/src/directive/expandClick.js +23 -0
  278. package/src/directive/express.js +86 -0
  279. package/src/directive/form.js +122 -0
  280. package/src/directive/format.js +24 -0
  281. package/src/directive/formulas.js +708 -0
  282. package/src/directive/index.js +42 -0
  283. package/src/directive/permissionLine.js +59 -0
  284. package/src/directive/permissionLineLable.js +56 -0
  285. package/src/directive/permit.js +23 -0
  286. package/src/directive/popconfirm.js +86 -0
  287. package/src/directive/relatedQuery.js +61 -0
  288. package/src/directive/resize.js +18 -0
  289. package/src/directive/subSort.js +18 -0
  290. package/src/directive/tableDrag.js +25 -0
  291. package/src/directive/tooltip.js +37 -0
  292. package/src/filter/computerSize.js +23 -0
  293. package/src/filter/dateFormat.js +10 -0
  294. package/src/filter/index.js +10 -0
  295. package/src/index.js +267 -0
  296. package/src/locale/format.js +44 -0
  297. package/src/locale/index.js +48 -0
  298. package/src/locale/lang/en.js +59 -0
  299. package/src/locale/lang/zh-CN.js +58 -0
  300. package/src/locale/lang/zh-TW.js +57 -0
  301. package/src/locale/validate/dict.js +223 -0
  302. package/src/math.js +270 -0
  303. package/src/mixins/emitter.js +33 -0
  304. package/src/mixins/form.js +25 -0
  305. package/src/mixins/formDataUpdate.js +32 -0
  306. package/src/mixins/ganged.js +126 -0
  307. package/src/mixins/inputName.js +30 -0
  308. package/src/mixins/linkage.js +403 -0
  309. package/src/mixins/locale.js +9 -0
  310. package/src/mixins/mobileMode.js +27 -0
  311. package/src/mixins/onlineHottable.js +105 -0
  312. package/src/mixins/onlineSubtable.js +468 -0
  313. package/src/mixins/permission.js +84 -0
  314. package/src/mixins/querySqlPreview.js +747 -0
  315. package/src/mixins/regionValidator.js +70 -0
  316. package/src/mixins/script.js +35 -0
  317. package/src/mixins/templatePreview.js +3673 -0
  318. package/src/service.js +336 -0
  319. package/src/services/CustomQuery.js +199 -0
  320. package/src/services/SubPagination.js +132 -0
  321. package/src/styles/index.scss +7 -0
  322. package/src/styles/selector.scss +127 -0
  323. package/src/styles/variables.scss +71 -0
  324. package/src/util/base64.js +21 -0
  325. package/src/util/brower.js +15 -0
  326. package/src/util/clone.js +61 -0
  327. package/src/util/path.js +4 -0
  328. package/src/util/request.js +14 -0
  329. package/src/utils.js +1205 -0
  330. package/src/validate.js +184 -0
@@ -0,0 +1,746 @@
1
+ <template>
2
+ <div
3
+ v-if="permission !== 'n'"
4
+ :class="[
5
+ 'inputs',
6
+ formInputsDisplay == 'block'
7
+ ? 'cl-form-inputs__block'
8
+ : 'cl-form-inputs__inline',
9
+ ]"
10
+ >
11
+ <div
12
+ class="el-select"
13
+ style="width: 100%; min-width: 180px"
14
+ @click="showDialog"
15
+ >
16
+ <div
17
+ ref="tagSpans"
18
+ style="width: calc(100% - 25px)"
19
+ :class="{
20
+ 'el-select__tags_readonly': !inputWriteable,
21
+ 'el-select__tags': inputWriteable,
22
+ }"
23
+ >
24
+ <span>
25
+ <span
26
+ v-for="(item, index) in selectors"
27
+ :key="index"
28
+ class="el-tag el-tag--info el-tag--small"
29
+ @click.stop
30
+ >
31
+ <span class="el-select__tags-text">{{ item.fullname }}</span>
32
+ <i
33
+ v-if="inputWriteable"
34
+ class="el-tag__close el-icon-close"
35
+ @click="handleRemove(item)"
36
+ ></i>
37
+ </span>
38
+ </span>
39
+ </div>
40
+ <div v-if="inputWriteable" class="el-input el-input--suffix">
41
+ <input
42
+ ref="inputEl"
43
+ v-model="value"
44
+ v-validate="inputValidate"
45
+ type="text"
46
+ readonly="readonly"
47
+ :name="inputName"
48
+ autocomplete="off"
49
+ class="el-input__inner"
50
+ :placeholder="placeholder"
51
+ :style="{
52
+ height: inputSuffixHeight + 'px',
53
+ lineHeight: inputSuffixHeight + 'px',
54
+ }"
55
+ />
56
+ <span class="el-input__suffix">
57
+ <span class="el-input__suffix-inner">
58
+ <cl-icon name="user" />
59
+ </span>
60
+ </span>
61
+ </div>
62
+ </div>
63
+ <cl-field-tail :field-name="inputName" :input-value="value" />
64
+
65
+ <el-dialog
66
+ width="80%"
67
+ :title="title"
68
+ :visible.sync="dialogVisible"
69
+ class="dialog-selector__wrapper"
70
+ :class="{ 'mobile-dialog': isMobile }"
71
+ :top="isMobile ? '0px' : '8vh'"
72
+ :before-close="handleClose"
73
+ :close-on-click-modal="false"
74
+ :append-to-body="appendToBody"
75
+ >
76
+ <el-tabs
77
+ v-model="activeGroupVal"
78
+ class="dialog-selector__tabs"
79
+ @tab-click="handleTabClick"
80
+ >
81
+ <el-tab-pane label="常用联系人" name="contact">
82
+ <el-container v-if="activeGroupVal == 'contact'">
83
+ <el-aside v-if="!isMobile" :width="el_aside_w" class="left-aside">
84
+ <el-card class="box-card org-find-card" shadow="never">
85
+ <div slot="header" class="clearfix">
86
+ <span>按群组查找</span>
87
+ </div>
88
+ <cl-radio
89
+ v-model="defaultContactGroupVal"
90
+ display-style="block"
91
+ option-layout="vertical"
92
+ :props="{ key: 'id', value: 'name' }"
93
+ :options="contactGroups"
94
+ ></cl-radio>
95
+ </el-card>
96
+ </el-aside>
97
+ <el-container>
98
+ <el-main>
99
+ <cl-selector
100
+ ref="selector"
101
+ v-model="selectors"
102
+ :data="data"
103
+ :pagination="pagination"
104
+ :table-columns="tableColumns"
105
+ :select-label="selectLabel"
106
+ :quick-search-props="quickSearchProps"
107
+ :single="single"
108
+ :search-placeholder="searchPlaceholder"
109
+ :primary-field="primaryField"
110
+ @load="load"
111
+ @select="select"
112
+ @row-click="rowClick"
113
+ />
114
+ </el-main>
115
+ </el-container>
116
+ </el-container>
117
+ </el-tab-pane>
118
+ <el-tab-pane label="所有用户" name="all">
119
+ <el-container v-if="activeGroupVal == 'all'">
120
+ <el-aside v-if="!isMobile" :width="el_aside_w" class="left-aside">
121
+ <el-card class="box-card org-find-card" shadow="never">
122
+ <div slot="header" class="clearfix">
123
+ <span>按组织查找</span>
124
+ </div>
125
+ <cl-select
126
+ v-model="currentDemension"
127
+ size="small"
128
+ :options="demensions"
129
+ display-style="block"
130
+ :props="{ key: 'id', value: 'demName' }"
131
+ :remote-method="loadDemensions"
132
+ @change="changeDemension"
133
+ />
134
+ <cl-tree
135
+ ref="tree"
136
+ lazy
137
+ display-style="block"
138
+ :load="loadOrgTree"
139
+ :data="orgs"
140
+ :default-expand-all="false"
141
+ :highlight-current="true"
142
+ :props="{
143
+ children: 'children',
144
+ label: 'name',
145
+ isLeaf: 'leaf',
146
+ }"
147
+ :node-key="nodeKey"
148
+ :default-expanded-keys="defaultExpandedKeys"
149
+ class="org-tree"
150
+ accordion
151
+ @node-click="handleNodeClick"
152
+ />
153
+ </el-card>
154
+ </el-aside>
155
+ <el-container>
156
+ <el-main>
157
+ <cl-selector
158
+ class="user-selector"
159
+ ref="selector"
160
+ v-model="selectors"
161
+ :data="data"
162
+ :pagination="pagination"
163
+ :table-columns="tableColumns"
164
+ :select-label="selectLabel"
165
+ :quick-search-props="quickSearchProps"
166
+ :single="single"
167
+ :search-placeholder="searchPlaceholder"
168
+ :primary-field="primaryField"
169
+ @load="load"
170
+ @select="select"
171
+ @row-click="rowClick"
172
+ />
173
+ </el-main>
174
+ </el-container>
175
+ </el-container>
176
+ </el-tab-pane>
177
+ </el-tabs>
178
+
179
+ <div slot="footer" class="dialog-footer">
180
+ <el-button type="primary" size="small" @click="handleDialogSure">
181
+ 确 定
182
+ </el-button>
183
+ <el-button size="small" @click="handleDialogCancel">取 消</el-button>
184
+ </div>
185
+ </el-dialog>
186
+ </div>
187
+ </template>
188
+ <script>
189
+ import utils from '@/utils.js'
190
+ import inputName from '@/mixins/inputName.js'
191
+ import permission from '@/mixins/permission.js'
192
+ import mobileMode from '@/mixins/mobileMode.js'
193
+ import ClFieldTail from '../../FieldTail/index'
194
+ import ClSelector from '../../Selector/index'
195
+ import { setTimeout } from 'timers'
196
+
197
+ export default {
198
+ name: 'ClUserSelector',
199
+ components: {
200
+ ClFieldTail,
201
+ ClSelector,
202
+ },
203
+ mixins: [inputName, permission, mobileMode],
204
+ props: {
205
+ searchPlaceholder: {
206
+ type: String,
207
+ default: '用户名称、账号',
208
+ },
209
+ demensions: {
210
+ type: Array,
211
+ default: () => {
212
+ return []
213
+ },
214
+ },
215
+ contactGroups: {
216
+ type: Array,
217
+ default: () => {
218
+ return []
219
+ },
220
+ },
221
+ orgs: {
222
+ type: Array,
223
+ default: () => {
224
+ return []
225
+ },
226
+ },
227
+ loadOrgTree: {
228
+ type: Function,
229
+ },
230
+ roles: {
231
+ type: Array,
232
+ default: () => {
233
+ return []
234
+ },
235
+ },
236
+ loadRoleTree: {
237
+ type: Function,
238
+ },
239
+ value: String,
240
+ single: {
241
+ type: Boolean,
242
+ default: false,
243
+ },
244
+ roleTreeSupportFilter: {
245
+ type: Boolean,
246
+ default: false,
247
+ },
248
+ config: Object,
249
+ data: {
250
+ type: Array,
251
+ default: () => {
252
+ return []
253
+ },
254
+ },
255
+ tableColumns: {
256
+ type: Array,
257
+ default: () => {
258
+ return []
259
+ },
260
+ },
261
+ pagination: {
262
+ type: Object,
263
+ default: () => {
264
+ return {
265
+ page: 1,
266
+ pageSize: 50,
267
+ total: 0,
268
+ }
269
+ },
270
+ },
271
+ selectLabel: {
272
+ type: String,
273
+ default: 'fullname',
274
+ },
275
+ defaultDemension: {
276
+ type: [String, Number],
277
+ default: '',
278
+ },
279
+ defaultContactGroup: {
280
+ type: [String, Number],
281
+ default: '',
282
+ },
283
+ quickSearchProps: {
284
+ type: String,
285
+ required: true,
286
+ },
287
+ nodeKey: {
288
+ type: String,
289
+ default: 'id',
290
+ },
291
+ defaultExpandedKeys: {
292
+ type: Array,
293
+ default() {
294
+ return []
295
+ },
296
+ },
297
+ appendToBody: {
298
+ type: Boolean,
299
+ default: false,
300
+ },
301
+ activeGroup: {
302
+ type: String,
303
+ default: 'contact',
304
+ },
305
+ formInputsDisplay: {
306
+ type: String,
307
+ default: 'inline',
308
+ },
309
+ title: {
310
+ type: String,
311
+ default: '选择用户',
312
+ },
313
+ },
314
+ data() {
315
+ return {
316
+ el_aside_w: '210px',
317
+ inputSuffixHeight: 30,
318
+ selectors: [],
319
+ dialogVisible: false,
320
+ currentDemension: null,
321
+ primaryField: this.selectLabel,
322
+ }
323
+ },
324
+ computed: {
325
+ activeGroupVal: {
326
+ get: function () {
327
+ return this.activeGroup
328
+ },
329
+ set: function (val) {
330
+ this.$emit('update:activeGroup', val)
331
+ },
332
+ },
333
+ defaultContactGroupVal: {
334
+ get: function () {
335
+ return this.defaultContactGroup
336
+ },
337
+ set: function (val) {
338
+ this.$emit('update:defaultContactGroup', val)
339
+ },
340
+ },
341
+ },
342
+ watch: {
343
+ // 当所选择的数据发生变化时,同步到v-model中
344
+ selectors: function (newVal) {
345
+ let ary = [],
346
+ idAry = [],
347
+ fullnameAry = [],
348
+ mobileAry = [],
349
+ emailAry = [],
350
+ postNameAry = [],
351
+ orgNameAry = [],
352
+ accountAry = []
353
+
354
+ if (newVal && newVal.constructor === Array && newVal.length > 0) {
355
+ newVal.forEach((m) => {
356
+ ary.push(m.fullname)
357
+ if (m.hasOwnProperty('id')) {
358
+ idAry.push(m.id)
359
+ }
360
+ if (m.hasOwnProperty('fullname')) {
361
+ fullnameAry.push(m.fullname)``
362
+ }
363
+ if (m.hasOwnProperty('account')) {
364
+ accountAry.push(m.account)
365
+ }
366
+ if (m.hasOwnProperty('mobile')) {
367
+ mobileAry.push(m.mobile)
368
+ }
369
+ if (m.hasOwnProperty('email')) {
370
+ emailAry.push(m.email)
371
+ }
372
+ if (m.hasOwnProperty('postName')) {
373
+ postNameAry.push(m.postName)
374
+ }
375
+ if (m.hasOwnProperty('orgName')) {
376
+ orgNameAry.push(m.orgName)
377
+ }
378
+ })
379
+ }
380
+ if (this.config) {
381
+ // 配置了id的绑定关系,则回填到指定属性上
382
+ if (this.config.hasOwnProperty('id')) {
383
+ utils.setValueByConfigKey(this, this.config, 'id', idAry.join(','))
384
+ this.primaryField = 'id'
385
+ }
386
+ // 配置了fullname的绑定关系,则回填到指定的属性上
387
+ if (this.config.hasOwnProperty('fullname')) {
388
+ utils.setValueByConfigKey(
389
+ this,
390
+ this.config,
391
+ 'fullname',
392
+ fullnameAry.join(',')
393
+ )
394
+ }
395
+ // 配置了account的绑定关系,则回填到指定的属性上
396
+ if (this.config.hasOwnProperty('account')) {
397
+ utils.setValueByConfigKey(
398
+ this,
399
+ this.config,
400
+ 'account',
401
+ accountAry.join(',')
402
+ )
403
+ this.primaryField = this.primaryField == 'id' ? 'id' : 'account'
404
+ }
405
+ // 配置了mobile的绑定关系,则回填到指定的属性上
406
+ if (this.config.hasOwnProperty('mobile')) {
407
+ utils.setValueByConfigKey(
408
+ this,
409
+ this.config,
410
+ 'mobile',
411
+ mobileAry.join(',')
412
+ )
413
+ }
414
+ // 配置了email的绑定关系,则回填到指定的属性上
415
+ if (this.config.hasOwnProperty('email')) {
416
+ utils.setValueByConfigKey(
417
+ this,
418
+ this.config,
419
+ 'email',
420
+ emailAry.join(',')
421
+ )
422
+ }
423
+
424
+ // 配置了post绑定关系,则回填到指定的属性上
425
+ if (this.config.hasOwnProperty('postName')) {
426
+ utils.setValueByConfigKey(
427
+ this,
428
+ this.config,
429
+ 'postName',
430
+ postNameAry.join(',')
431
+ )
432
+ }
433
+
434
+ // 配置了org绑定关系,则回填到指定的属性上
435
+ if (this.config.hasOwnProperty('orgName')) {
436
+ utils.setValueByConfigKey(
437
+ this,
438
+ this.config,
439
+ 'orgName',
440
+ orgNameAry.join(',')
441
+ )
442
+ }
443
+ }
444
+ // 通过valueChange事件发布值变更消息
445
+ setTimeout(() => {
446
+ this.$emit('valueChange', ary.join(','), newVal)
447
+ this.calacInputSuffixHeight()
448
+ if (this.$refs.inputEl) {
449
+ this.$refs.inputEl.focus()
450
+ this.$refs.inputEl.blur()
451
+ }
452
+ }, 10)
453
+ },
454
+ value: function () {
455
+ // 父级传递进来的value发生变更时,需要同步到当前所选数据中
456
+ this.valueInit()
457
+ },
458
+ defaultDemension: function (newVal, oldVal) {
459
+ if (newVal && newVal != oldVal) {
460
+ this.currentDemension = newVal
461
+ this.changeDemension()
462
+ }
463
+ },
464
+ defaultContactGroupVal: function (newVal, oldVal) {
465
+ if (newVal !== oldVal) {
466
+ // 没有常用联系人分组时,显示全部用户
467
+ if (newVal === null) {
468
+ this.activeGroupVal = 'all'
469
+ }
470
+ }
471
+ },
472
+ },
473
+ mounted() {
474
+ // 组件第一次挂载时,同步value到当前所选数据中
475
+ this.valueInit()
476
+ },
477
+ created() {
478
+ if (this.$smallScreenDialog) {
479
+ this.el_aside_w = '180px'
480
+ }
481
+ this.loadFilterGroup('all')
482
+ },
483
+ methods: {
484
+ handleTabClick(tab) {
485
+ this.loadFilterGroup(tab.name)
486
+ },
487
+ // 同步value到当前所选数据中
488
+ valueInit() {
489
+ let tmpAry = []
490
+ if (this.value) {
491
+ let idAry = [],
492
+ accountAry = [],
493
+ fullnameAry = [],
494
+ mobileAry = [],
495
+ postNameAry = [],
496
+ orgNameAry = [],
497
+ emailAry = []
498
+ if (this.config) {
499
+ // 配置了id绑定关系,则获取id的值
500
+ if (this.config.hasOwnProperty('id')) {
501
+ let idVal = utils.getValueByConfigKey(this, this.config, 'id')
502
+ if (idVal) {
503
+ idAry = idVal.split(',').trim()
504
+ }
505
+ }
506
+ // 配置了fullname绑定关系,则获取fullname的值
507
+ if (this.config.hasOwnProperty('fullname')) {
508
+ let fullnameVal = utils.getValueByConfigKey(
509
+ this,
510
+ this.config,
511
+ 'fullname'
512
+ )
513
+ if (fullnameVal) {
514
+ fullnameAry = fullnameVal.split(',').trim()
515
+ }
516
+ }
517
+
518
+ // 配置了account绑定关系,则获取account的值
519
+ if (this.config.hasOwnProperty('account')) {
520
+ let accountVal = utils.getValueByConfigKey(
521
+ this,
522
+ this.config,
523
+ 'account'
524
+ )
525
+ if (accountVal) {
526
+ accountAry = accountVal.split(',').trim()
527
+ }
528
+ }
529
+
530
+ // 配置了mobile绑定关系,则获取mobile的值
531
+ if (this.config.hasOwnProperty('mobile')) {
532
+ let mobileVal = utils.getValueByConfigKey(
533
+ this,
534
+ this.config,
535
+ 'mobile'
536
+ )
537
+ if (mobileVal) {
538
+ mobileAry = mobileVal.split(',').trim()
539
+ }
540
+ }
541
+
542
+ // 配置了post绑定关系,则获取post的值
543
+ if (this.config.hasOwnProperty('postName')) {
544
+ let postVal = utils.getValueByConfigKey(
545
+ this,
546
+ this.config,
547
+ 'postName'
548
+ )
549
+ if (postVal) {
550
+ postNameAry = postVal.split(',').trim()
551
+ }
552
+ }
553
+
554
+ // 配置了org绑定关系,则获取org的值
555
+ if (this.config.hasOwnProperty('orgName')) {
556
+ let orgVal = utils.getValueByConfigKey(
557
+ this,
558
+ this.config,
559
+ 'orgName'
560
+ )
561
+ if (orgVal) {
562
+ orgNameAry = orgVal.split(',').trim()
563
+ }
564
+ }
565
+
566
+ // 配置了email绑定关系,则获取email的值
567
+ if (this.config.hasOwnProperty('email')) {
568
+ let emailVal = utils.getValueByConfigKey(
569
+ this,
570
+ this.config,
571
+ 'email'
572
+ )
573
+ if (emailVal) {
574
+ emailAry = emailVal.split(',').trim()
575
+ }
576
+ }
577
+ }
578
+ // 将fullname、id、code从逗号分割的字符串解析为json对象格式的数组
579
+ let valAry = this.value.split(',').trim()
580
+ valAry.forEach((m, index) => {
581
+ let item = { fullname: m }
582
+ if (idAry.length > index) {
583
+ item['id'] = idAry[index]
584
+ }
585
+ if (accountAry.length > index) {
586
+ item['account'] = accountAry[index]
587
+ }
588
+ if (fullnameAry.length > index) {
589
+ item['fullname'] = fullnameAry[index]
590
+ }
591
+ if (mobileAry.length > index) {
592
+ item['mobile'] = mobileAry[index]
593
+ }
594
+ if (emailAry.length > index) {
595
+ item['email'] = emailAry[index]
596
+ }
597
+ if (postNameAry.length > index) {
598
+ item['postName'] = postNameAry[index]
599
+ }
600
+ if (orgNameAry.length > index) {
601
+ item['orgName'] = orgNameAry[index]
602
+ }
603
+ tmpAry.push(item)
604
+ })
605
+ }
606
+ // 对数组做深度对比,如果值不完全相等,则进行赋值操作
607
+ if (!utils.arrayEquals(tmpAry, this.selectors)) {
608
+ this.selectors = tmpAry
609
+ }
610
+ },
611
+ showDialog() {
612
+ if (!this.inputWriteable) {
613
+ return
614
+ }
615
+ this.loadFilterGroup()
616
+ this.dialogVisible = true
617
+ setTimeout(() => {
618
+ this.$refs.selector.onShow()
619
+ })
620
+ },
621
+ loadFilterGroup(tabName) {
622
+ const selectTabName = tabName || this.activeGroupVal
623
+ if (selectTabName == 'all') {
624
+ this.loadDemensions()
625
+ // 处理切换Tab时,组织树不加载问题
626
+ this.currentDemension && this.changeDemension()
627
+ } else {
628
+ // 处理不加载树的问题
629
+ this.changeDemension()
630
+ this.loadContactGroup()
631
+ }
632
+ },
633
+ handleClose(done) {
634
+ this.$refs.selector.onHide()
635
+ done && done()
636
+ },
637
+ handleDialogSure() {
638
+ this.$emit('select-data', this.$refs.selector.getSelectedData())
639
+ this.dialogVisible = false
640
+ this.$refs.selector.onHide(true)
641
+ },
642
+ handleDialogCancel() {
643
+ this.dialogVisible = false
644
+ this.$refs.selector.onHide()
645
+ },
646
+ handleRemove(item) {
647
+ this.selectors.remove(item)
648
+ },
649
+ clear() {
650
+ this.selectors = []
651
+ },
652
+ // 更新当前输入框的高度来适配已选数据的高度
653
+ calacInputSuffixHeight() {
654
+ if (!this.$refs.tagSpans) return
655
+ if (this.$refs.tagSpans.offsetHeight) {
656
+ this.inputSuffixHeight = this.$refs.tagSpans.offsetHeight + 5
657
+ } else {
658
+ this.inputSuffixHeight = 30
659
+ }
660
+ },
661
+ load(param, cb) {
662
+ this.$emit('load', param, cb)
663
+ },
664
+ changeDemension() {
665
+ this.$emit('changeDemension', this.currentDemension)
666
+ },
667
+ handleNodeClick(data) {
668
+ this.$emit('loadOrgUser', data)
669
+ },
670
+ handleRoleNodeClick(data) {
671
+ this.$emit('loadRoleUser', data)
672
+ },
673
+ loadDemensions() {
674
+ this.$emit('loadDemensions')
675
+ },
676
+ loadContactGroup() {
677
+ this.$emit('loadContactGroup')
678
+ },
679
+ select(selection, row) {
680
+ this.$emit('select', selection, row)
681
+ },
682
+ rowClick(row, column, event) {
683
+ this.$emit('row-click', row, column, event)
684
+ },
685
+ },
686
+ }
687
+ </script>
688
+ <style lang="scss" scoped>
689
+ @import '~@/styles/selector.scss';
690
+ .el-select__tags {
691
+ background: #fff;
692
+ margin-left: 1px;
693
+ }
694
+
695
+ .el-select__tags_readonly {
696
+ position: relative;
697
+ top: 50%;
698
+ }
699
+
700
+ .el-input__inner[aria-invalid='true'] {
701
+ border-color: #f56c6c;
702
+ }
703
+ ::v-deep .el-main {
704
+ padding-top: 0;
705
+ padding-bottom: 0;
706
+ }
707
+
708
+ ::v-deep .el-scrollbar__wrap {
709
+ overflow-x: hidden;
710
+ }
711
+
712
+ ::v-deep .el-collapse-item__wrap {
713
+ height: calc(100% -500px);
714
+ }
715
+
716
+ div.org-find-card ::v-deep .el-card__body {
717
+ padding: 10px;
718
+ max-height: 520px;
719
+ overflow: auto;
720
+ }
721
+ .el-input__suffix {
722
+ display: flex;
723
+ flex-direction: column;
724
+ justify-content: center;
725
+ }
726
+ .dialog-selector__tabs {
727
+ height: calc(100% - 2px);
728
+
729
+ ::v-deep {
730
+ .el-tabs__content {
731
+ height: calc(100% - 45px);
732
+ padding: 0;
733
+ }
734
+ .el-tab-pane {
735
+ height: 100%;
736
+ }
737
+ }
738
+ }
739
+ .user-selector {
740
+ ::v-deep {
741
+ .el-table::before {
742
+ background-color: transparent;
743
+ }
744
+ }
745
+ }
746
+ </style>