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,359 @@
1
+ <template>
2
+ <div name="online-form">
3
+ <el-skeleton v-if="loadStatus == 0" :rows="6" animated />
4
+ <cl-runtime-template
5
+ v-else-if="loadStatus > 0"
6
+ :name="formName"
7
+ :data="data"
8
+ :permission="permission"
9
+ :is-view="isView"
10
+ :is-print="isPrint"
11
+ :mobile-mode="mobileMode"
12
+ :form-key="formKey"
13
+ class="online-form-wrap form-table__wrap"
14
+ :init-fill-data="initFillData"
15
+ :extend-prop="extendProp"
16
+ :is-support-mobile="isSupportMobile"
17
+ :inst-id="instId"
18
+ @load-fail="handleLoadFail"
19
+ @load-success="handleLoadSuccess"
20
+ />
21
+ <div v-else class="loaded-fail__div">
22
+ 表单加载失败,可能是表单配置发生了变化,请联系管理员...
23
+ </div>
24
+ </div>
25
+ </template>
26
+ <script>
27
+ import utils from '@/utils.js'
28
+ import onlineHottable from '@/mixins/onlineHottable.js'
29
+ import onlineSubtable from '@/mixins/onlineSubtable.js'
30
+ import regionValidator from '@/mixins/regionValidator.js'
31
+ import emitter from '@/mixins/emitter.js'
32
+
33
+ import Vue from 'vue'
34
+ export default {
35
+ name: 'ClOnlineForm',
36
+ componentName: 'ClOnlineForm',
37
+ mixins: [regionValidator, emitter],
38
+ props: {
39
+ html: String,
40
+ data: Object,
41
+ permission: Object,
42
+ initFillData: {
43
+ type: Boolean,
44
+ default: false,
45
+ },
46
+ isView: {
47
+ type: Boolean,
48
+ default: false,
49
+ },
50
+ isPrint: {
51
+ type: Boolean,
52
+ default: false,
53
+ },
54
+ isLook: {
55
+ type: Boolean,
56
+ default: false,
57
+ },
58
+ mobileMode: {
59
+ type: Boolean,
60
+ default: false,
61
+ },
62
+ flowKey: String,
63
+ formId: String,
64
+ formKey: String,
65
+ extendProp: {
66
+ type: Object,
67
+ default: () => {
68
+ return {}
69
+ },
70
+ },
71
+ isSupportMobile: {
72
+ type: Boolean,
73
+ default: false,
74
+ },
75
+ instId: [String, Number],
76
+ },
77
+ data() {
78
+ return {
79
+ formName: `onlineForm_${utils.getName()}`,
80
+ loadStatus: 0,
81
+ subBackfill: new Map(),
82
+ hotTableFillback: String,
83
+ scopeName: `form-${utils.getName()}`,
84
+ getDataPromiseResolve: null,
85
+ getDataPromiseReject: null,
86
+ }
87
+ },
88
+ watch: {
89
+ html: {
90
+ handler: function(newVal) {
91
+ if (newVal) {
92
+ this.init()
93
+ }
94
+ },
95
+ immediate: true,
96
+ },
97
+ },
98
+ created() {
99
+ this.$on('global-validate-result', (result) => {
100
+ if (result) {
101
+ this.getDataPromiseResolve(this.data)
102
+ } else {
103
+ this.getDataPromiseReject()
104
+ }
105
+ })
106
+ },
107
+ methods: {
108
+ handleLoadSuccess(res) {
109
+ this.loadStatus = 1
110
+ this.$emit('load-success', res)
111
+ },
112
+ handleLoadFail() {
113
+ this.loadStatus = -1
114
+ },
115
+ getData(validate) {
116
+ return new Promise((resolve, reject) => {
117
+ this.getDataPromiseResolve = resolve
118
+ this.getDataPromiseReject = reject
119
+ if (!validate) {
120
+ resolve(this.data)
121
+ } else {
122
+ // 执行校验逻辑
123
+ this.validateRegion(`[name='${this.formName}']`).then(
124
+ (errorItems) => {
125
+ if (errorItems.length > 0) {
126
+ reject(errorItems)
127
+ } else {
128
+ this.broadcast('ClGlobalValidate', 'global-validate')
129
+ }
130
+ }
131
+ )
132
+ }
133
+ })
134
+ },
135
+ init() {
136
+ this.loadStatus = 1
137
+ Vue.component('cl-runtime-template', {
138
+ componentName: 'ClRuntimeTemplate',
139
+ mixins: [onlineHottable, onlineSubtable],
140
+ props: {
141
+ html: String,
142
+ data: Object,
143
+ permission: Object,
144
+ initFillData: {
145
+ type: Boolean,
146
+ default: false,
147
+ },
148
+ isView: {
149
+ type: Boolean,
150
+ default: false,
151
+ },
152
+ isPrint: {
153
+ type: Boolean,
154
+ default: false,
155
+ },
156
+ formKey: String,
157
+ mobileMode: {
158
+ type: Boolean,
159
+ default: false,
160
+ },
161
+ extendProp: {
162
+ type: Object,
163
+ default: () => {
164
+ return {}
165
+ },
166
+ },
167
+ isSupportMobile: {
168
+ type: Boolean,
169
+ default: false,
170
+ },
171
+ instId: [String, Number],
172
+ },
173
+ template: this.html,
174
+ })
175
+ },
176
+ },
177
+ }
178
+ </script>
179
+ <style lang="scss">
180
+ .transition {
181
+ outline: 1px dotted #85a5ff;
182
+ outline-width: 2px;
183
+ outline-offset: -1px;
184
+ }
185
+ .el-tabs--border-card {
186
+ border: 1px solid #ebeef5;
187
+ -webkit-box-shadow: none;
188
+ box-shadow: none;
189
+ }
190
+
191
+ .tabcheck_btn {
192
+ text-align: right;
193
+ padding-top: 20px;
194
+ }
195
+ .loaded-fail__div {
196
+ text-align: center;
197
+ font-size: 14px;
198
+ font-weight: bold;
199
+ color: #f56c6c;
200
+ }
201
+ .main-table {
202
+ border-collapse: separate;
203
+ margin-bottom: 20px;
204
+ tr > td {
205
+ &:empty {
206
+ border: none !important;
207
+ }
208
+ }
209
+ }
210
+ @media print {
211
+ .printHide {
212
+ display: none;
213
+ }
214
+ .main-field {
215
+ line-height: 1.5 !important;
216
+ }
217
+ .el-main {
218
+ padding: 0px !important;
219
+ }
220
+ .sub-table-header ::v-deep th {
221
+ min-width: 110px !important;
222
+ }
223
+ colgroup {
224
+ display: none !important;
225
+ }
226
+ .el-table__header {
227
+ width: 100% !important;
228
+ }
229
+ .el-table__body {
230
+ width: 100% !important;
231
+ }
232
+ .el-table_1_column_1 {
233
+ width: 60px !important;
234
+ }
235
+ .el-table_1_column_3 {
236
+ width: 100px !important;
237
+ }
238
+ .el-table_1_column_4 {
239
+ width: 100px !important;
240
+ }
241
+ .el-table_1_column_5 {
242
+ display: none !important;
243
+ }
244
+ .gutter {
245
+ display: none !important;
246
+ }
247
+ .form-table {
248
+ border: 1px solid rgb(238, 235, 235) !important;
249
+ }
250
+ .form-table > tbody > tr > th,
251
+ .form-table > tbody > tr > td,
252
+ .form-table > tfoot > tr > td,
253
+ .form-table > thead > tr > th {
254
+ border: 1px solid rgb(238, 235, 235) !important;
255
+ }
256
+ .el-table__header {
257
+ border: 1px solid rgb(238, 235, 235) !important;
258
+ }
259
+ .el-table__header > tbody > tr > th,
260
+ .el-table__header > tbody > tr > td,
261
+ .el-table__header > tfoot > tr > td,
262
+ .el-table__header > thead > tr > th {
263
+ border: 1px solid rgb(238, 235, 235) !important;
264
+ }
265
+ .el-table__body > tbody > tr > th,
266
+ .el-table__body > tbody > tr > td,
267
+ .el-table__body > tfoot > tr > td,
268
+ .el-table__body > thead > tr > th {
269
+ border: 1px solid rgb(238, 235, 235) !important;
270
+ }
271
+ .el-table th.is-leaf,
272
+ .el-table td {
273
+ border-bottom: 1px solid rgb(238, 235, 235) !important;
274
+ }
275
+ }
276
+ .main-title {
277
+ word-break: break-all;
278
+ text-align: right;
279
+ font-weight: 100;
280
+ color: #545252;
281
+ font-size: 12px;
282
+ padding: 0px 10px !important;
283
+ font-weight: bold;
284
+ line-height: 28px;
285
+ }
286
+ .main-field {
287
+ padding: 10px;
288
+ line-height: 0;
289
+ .unit {
290
+ display: inline-block;
291
+ }
292
+ }
293
+ .online-form-wrap {
294
+ [name='online-form'] .el-date-editor.el-input,
295
+ .el-date-editor.el-input__inner {
296
+ width: 100%;
297
+ }
298
+ .el-input {
299
+ width: 100% !important;
300
+ }
301
+ .amap-page-container {
302
+ .amap-toolbar,
303
+ .amap-geolocation-con,
304
+ .amap-scalecontrol,
305
+ .amap-logo,
306
+ .amap-copyright {
307
+ z-index: 1 !important;
308
+ }
309
+ }
310
+ }
311
+ .el-tooltip__popper {
312
+ p {
313
+ width: 300px;
314
+ }
315
+ }
316
+ .xh_table tfoot td:empty {
317
+ padding: 0 !important;
318
+ border: none !important;
319
+ }
320
+ .online-form-wrap {
321
+ .table_layout_wrap,
322
+ .grandson_table_wrap {
323
+ overflow: auto;
324
+ }
325
+ .table_layout_wrap {
326
+ td {
327
+ .inputs {
328
+ position: relative;
329
+ }
330
+ }
331
+ }
332
+ }
333
+ .inputs {
334
+ .file-list__wrap {
335
+ padding-left: 0;
336
+ .file-item {
337
+ .file-icon,
338
+ .file-close__icon {
339
+ padding-top: 11px;
340
+ }
341
+ }
342
+ }
343
+ }
344
+ .form-table__wrap {
345
+ .form-table > thead > tr > th:last-child {
346
+ min-width: 100px !important;
347
+ }
348
+ }
349
+ .inputs {
350
+ .edui-default .edui-editor {
351
+ border: none;
352
+ }
353
+ }
354
+ td.is-required:before {
355
+ content: '*';
356
+ color: #f56c6c;
357
+ margin-right: 4px;
358
+ }
359
+ </style>
@@ -0,0 +1,7 @@
1
+ import OrgPostDialog from './src/main.vue'
2
+
3
+ OrgPostDialog.install = function(Vue) {
4
+ Vue.component(OrgPostDialog.name, OrgPostDialog)
5
+ }
6
+
7
+ export default OrgPostDialog
@@ -0,0 +1,244 @@
1
+ <template>
2
+ <div class="inputs">
3
+ <el-dialog
4
+ :title="dialogTitile"
5
+ :visible.sync="dialogVisible"
6
+ class="dialog-selector__wrapper"
7
+ top="6vh"
8
+ :before-close="handleClose"
9
+ :close-on-click-modal="false"
10
+ :append-to-body="appendToBody"
11
+ :destroy-on-close="destroyOnClose"
12
+ >
13
+ <el-container>
14
+ <el-aside width="210px" class="left-aside">
15
+ <el-card class="box-card org-find-card" shadow="never">
16
+ <div slot="header" class="clearfix">
17
+ <span>按组织查找</span>
18
+ </div>
19
+ <cl-select
20
+ v-model="currentDemension"
21
+ size="small"
22
+ :options="demensions"
23
+ :props="{ key: 'id', value: 'demName' }"
24
+ :remote-method="loadDemensions"
25
+ @change="changeDemension"
26
+ />
27
+ <cl-tree
28
+ ref="tree"
29
+ lazy
30
+ :load="loadOrgTree"
31
+ :data="orgs"
32
+ :default-expand-all="false"
33
+ :highlight-current="true"
34
+ :props="{ children: 'children', label: 'name', isLeaf: 'leaf' }"
35
+ :node-key="nodeKey"
36
+ :default-expanded-keys="defaultExpandedKeys"
37
+ class="org-tree"
38
+ accordion
39
+ @node-click="handleNodeClick"
40
+ ></cl-tree>
41
+ </el-card>
42
+ </el-aside>
43
+ <el-container>
44
+ <el-main>
45
+ <cl-selector
46
+ ref="selector"
47
+ v-model="selectors"
48
+ :data="data"
49
+ :pagination="pagination"
50
+ :table-columns="tableColumns"
51
+ :select-label="selectLabel"
52
+ :quick-search-props="quickSearchProps"
53
+ :single="single"
54
+ :search-placeholder="searchPlaceholder"
55
+ @load="load"
56
+ />
57
+ </el-main>
58
+ </el-container>
59
+ </el-container>
60
+
61
+ <div slot="footer" class="dialog-footer">
62
+ <el-button type="primary" size="small" @click="handleDialogSure">
63
+ 确 定
64
+ </el-button>
65
+ <el-button size="small" @click="handleDialogCancel">取 消</el-button>
66
+ </div>
67
+ </el-dialog>
68
+ </div>
69
+ </template>
70
+ <script>
71
+ import ClSelector from '../../Selector/index'
72
+ import { setTimeout } from 'timers'
73
+
74
+ export default {
75
+ name: 'ClOrgPostDialog',
76
+ components: {
77
+ ClSelector,
78
+ },
79
+ props: {
80
+ dialogTitile: {
81
+ type: String,
82
+ default: '对话框',
83
+ },
84
+ demensions: {
85
+ type: Array,
86
+ default: () => {
87
+ return []
88
+ },
89
+ },
90
+ orgs: {
91
+ type: Array,
92
+ default: () => {
93
+ return []
94
+ },
95
+ },
96
+ loadOrgTree: {
97
+ type: Function,
98
+ },
99
+ value: String,
100
+ single: {
101
+ type: Boolean,
102
+ default: false,
103
+ },
104
+ data: {
105
+ type: Array,
106
+ default: () => {
107
+ return []
108
+ },
109
+ },
110
+ tableColumns: {
111
+ type: Array,
112
+ default: () => {
113
+ return []
114
+ },
115
+ },
116
+ pagination: {
117
+ type: Object,
118
+ default: () => {
119
+ return {
120
+ page: 1,
121
+ pageSize: 50,
122
+ total: 0,
123
+ }
124
+ },
125
+ },
126
+ selectLabel: {
127
+ type: String,
128
+ default: 'name',
129
+ },
130
+ appendToBody: {
131
+ type: Boolean,
132
+ default: false,
133
+ },
134
+ defaultDemension: {
135
+ type: [String, Number],
136
+ default: '',
137
+ },
138
+ quickSearchProps: {
139
+ type: String,
140
+ required: true,
141
+ },
142
+ nodeKey: {
143
+ type: String,
144
+ default: 'id',
145
+ },
146
+ defaultExpandedKeys: {
147
+ type: Array,
148
+ default() {
149
+ return []
150
+ },
151
+ },
152
+ destroyOnClose: {
153
+ type: Boolean,
154
+ default: false,
155
+ },
156
+ searchPlaceholder: {
157
+ type: String,
158
+ default: '名称、编码',
159
+ },
160
+ },
161
+ data() {
162
+ return {
163
+ inputName: null,
164
+ selectors: [],
165
+ dialogVisible: false,
166
+ currentDemension: null,
167
+ }
168
+ },
169
+ watch: {
170
+ defaultDemension: function(newVal, oldVal) {
171
+ if (newVal && newVal != oldVal) {
172
+ this.currentDemension = newVal
173
+ this.changeDemension()
174
+ }
175
+ },
176
+ },
177
+ methods: {
178
+ // 同步value到当前所选数据中
179
+ showDialog(selectors) {
180
+ this.dialogVisible = true
181
+ this.loadDemensions()
182
+ if (!selectors) {
183
+ selectors = []
184
+ }
185
+ setTimeout(() => {
186
+ this.$refs.selector.onShow(selectors)
187
+ })
188
+ },
189
+ handleClose(done) {
190
+ this.$refs.selector.onHide()
191
+ done && done()
192
+ },
193
+ handleDialogSure() {
194
+ this.dialogVisible = false
195
+ this.$refs.selector.onHide(true)
196
+ this.$emit('onConfirm', this.selectors)
197
+ },
198
+ handleDialogCancel() {
199
+ this.dialogVisible = false
200
+ this.$refs.selector.onHide()
201
+ },
202
+ handleRemove(item) {
203
+ this.selectors.remove(item)
204
+ },
205
+ load(param, cb) {
206
+ this.$emit('load', param, cb)
207
+ },
208
+ changeDemension() {
209
+ this.$emit('changeDemension', this.currentDemension)
210
+ },
211
+ handleNodeClick(data) {
212
+ this.$emit('loadListData', data)
213
+ },
214
+ loadDemensions() {
215
+ this.$emit('loadDemensions')
216
+ },
217
+ },
218
+ }
219
+ </script>
220
+ <style lang="scss" scoped>
221
+ @import '~@/styles/selector.scss';
222
+ .inputs {
223
+ display: block;
224
+ }
225
+
226
+ .el-select__tags {
227
+ background: #fff;
228
+ margin-left: 1px;
229
+ }
230
+
231
+ .el-select__tags_readonly {
232
+ position: relative;
233
+ top: 50%;
234
+ }
235
+
236
+ .el-input__inner[aria-invalid='true'] {
237
+ border-color: #f56c6c;
238
+ }
239
+ div.org-find-card ::v-deep .el-card__body {
240
+ padding: 10px;
241
+ max-height: 520px;
242
+ overflow: auto;
243
+ }
244
+ </style>
@@ -0,0 +1,7 @@
1
+ import OrgSelector from './src/main.vue'
2
+
3
+ OrgSelector.install = function(Vue) {
4
+ Vue.component(OrgSelector.name, OrgSelector)
5
+ }
6
+
7
+ export default OrgSelector