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,552 @@
1
+ <template>
2
+ <div
3
+ v-if="permission !== 'n'"
4
+ v-express
5
+ :class="[
6
+ 'inputs',
7
+ formInputsDisplay == 'block'
8
+ ? 'cl-form-inputs__block'
9
+ : 'cl-form-inputs__inline',
10
+ ]"
11
+ >
12
+ <el-input
13
+ v-if="inputWriteable && type != 'number'"
14
+ ref="inputEle"
15
+ v-model="inputVal"
16
+ v-validate="inputValidate"
17
+ :type="type"
18
+ :size="inputSize"
19
+ :style="inputWidth"
20
+ :name="inputName"
21
+ :placeholder="placeholder"
22
+ :clearable="clearable"
23
+ :show-password="showPassword"
24
+ :disabled="disabled"
25
+ :readonly="readonly"
26
+ :rows="rowsVal"
27
+ :cols="colsVal"
28
+ :min="min"
29
+ :max="max"
30
+ :autosize="autosize"
31
+ :tabindex="tabindex"
32
+ :prefix-icon="prefixIcon"
33
+ :suffix-icon="suffixIcon"
34
+ :minlength="minlength"
35
+ :maxlength="maxlength"
36
+ :show-word-limit="showWordLimit"
37
+ @blur="handleBlur"
38
+ @focus="handleFocus"
39
+ @change="handleChange"
40
+ @input="handleInput"
41
+ @clear="handleClear"
42
+ >
43
+ <slot slot="prefix" name="prefix"></slot>
44
+ <slot slot="suffix" name="suffix"></slot>
45
+ <slot slot="prepend" name="prepend"></slot>
46
+ <slot slot="append" name="append"></slot>
47
+ </el-input>
48
+ <template v-if="inputWriteable && type == 'number'">
49
+ <el-input-number
50
+ v-show="isNumber"
51
+ ref="inputEle"
52
+ v-model="inputVal"
53
+ v-validate="inputValidate"
54
+ :type="type"
55
+ :controls-position="controlsPosition"
56
+ :size="inputSize"
57
+ :style="inputWidth"
58
+ :name="inputName"
59
+ :placeholder="placeholder"
60
+ :clearable="clearable"
61
+ :disabled="disabled"
62
+ :readonly="readonly"
63
+ :min="min"
64
+ :max="max"
65
+ :step="step"
66
+ :step-strictly="stepStrictly"
67
+ :precision="precision"
68
+ @blur="handleBlur"
69
+ @focus="handleFocus"
70
+ @change="handleChange"
71
+ ></el-input-number>
72
+ <el-input
73
+ v-show="!isNumber"
74
+ ref="exhibit"
75
+ v-model="exhibitText"
76
+ class="exhibit"
77
+ type="text"
78
+ :controls-position="controlsPosition"
79
+ :size="inputSize"
80
+ :style="inputWidth"
81
+ :name="inputName"
82
+ :placeholder="placeholder"
83
+ :clearable="clearable"
84
+ :disabled="disabled"
85
+ :readonly="readonly"
86
+ :min="min"
87
+ :max="max"
88
+ :step="step"
89
+ :step-strictly="stepStrictly"
90
+ :precision="precision"
91
+ @focus="isNumber = true"
92
+ ></el-input>
93
+ <span v-if="company">{{ company }}</span>
94
+ </template>
95
+ <cl-field-tail
96
+ v-if="permission_sub !== 'n'"
97
+ :field-name="inputName"
98
+ :readonly="!inputWriteable"
99
+ :input-value="inputVal"
100
+ :company="company"
101
+ >
102
+ <slot slot="prefix" name="prefix"></slot>
103
+ <slot slot="suffix" name="suffix"></slot>
104
+ <slot slot="prepend" name="prepend"></slot>
105
+ <slot slot="append" name="append"></slot>
106
+ </cl-field-tail>
107
+ </div>
108
+ </template>
109
+ <script>
110
+ import utils from '@/utils.js'
111
+ import FormMath from '@/math.js'
112
+ import ClFieldTail from '../../FieldTail/index'
113
+ import permission from '@/mixins/permission.js'
114
+ import inputName from '@/mixins/inputName.js'
115
+ import form from '@/mixins/form.js'
116
+
117
+ export default {
118
+ name: 'ClInput',
119
+ components: {
120
+ ClFieldTail,
121
+ },
122
+ mixins: [permission, inputName, form],
123
+ props: {
124
+ value: [String, Number],
125
+ controlsPosition: {
126
+ type: String,
127
+ default: 'right',
128
+ },
129
+ width: [String, Number],
130
+ clearable: {
131
+ type: Boolean,
132
+ default: true,
133
+ },
134
+ showPassword: {
135
+ type: Boolean,
136
+ default: false,
137
+ },
138
+ mathExp: String,
139
+ type: {
140
+ type: String,
141
+ default: 'text',
142
+ },
143
+ ctrlType: {
144
+ type: String,
145
+ default: '',
146
+ },
147
+ dateCalcExp: Object,
148
+ readonly: {
149
+ type: Boolean,
150
+ default: false,
151
+ },
152
+ disabled: {
153
+ type: Boolean,
154
+ default: false,
155
+ },
156
+ min: Number,
157
+ max: Number,
158
+ step: {
159
+ type: Number,
160
+ default: 1,
161
+ },
162
+ stepStrictly: {
163
+ type: Boolean,
164
+ default: false,
165
+ },
166
+ precision: Number,
167
+ cols: {
168
+ type: Number,
169
+ default: 60,
170
+ },
171
+ rows: {
172
+ type: Number,
173
+ default: 2,
174
+ },
175
+ autosize: {
176
+ type: [Boolean, Object],
177
+ default: false,
178
+ },
179
+ prefixIcon: String,
180
+ suffixIcon: String,
181
+ tabindex: String,
182
+ minlength: {
183
+ type: Number,
184
+ },
185
+ maxlength: {
186
+ type: Number,
187
+ },
188
+ showWordLimit: {
189
+ type: Boolean,
190
+ default: false,
191
+ },
192
+ format: {
193
+ type: Function,
194
+ },
195
+ formatWhenReadonly: {
196
+ type: Boolean,
197
+ default: true,
198
+ },
199
+ filterthousandBit: {
200
+ type: Boolean,
201
+ default: false,
202
+ },
203
+ filtercurrency: {
204
+ type: Boolean,
205
+ default: false,
206
+ },
207
+ configAttributes: Object,
208
+ company: String,
209
+ },
210
+ data() {
211
+ return {
212
+ unwatchAry: [],
213
+ morphing: false,
214
+ tempInputVal: null,
215
+ isFocus: false,
216
+ exhibitText: '',
217
+ isNumber: true,
218
+ }
219
+ },
220
+ computed: {
221
+ inputVal: {
222
+ get() {
223
+ // input为number时 输入框获取焦点时 自动清空输入框默认内容 简化用户操作
224
+ if (this.isFocus && this.type === 'number' && this.value === 0) {
225
+ return undefined
226
+ }
227
+ if (this.morphing && this.tempInputVal !== null) {
228
+ return this.tempInputVal
229
+ }
230
+ if (utils.isEmpty(this.value)) {
231
+ return ''
232
+ }
233
+ return this.value
234
+ },
235
+ set(val) {
236
+ if (this.isFocus && this.type === 'number' && val === undefined) {
237
+ this.$emit('input', 0)
238
+ return
239
+ }
240
+ // 格式化显示时不更新到value属性上
241
+ !this.morphing && this.$emit('input', val)
242
+ },
243
+ },
244
+ colsVal: function() {
245
+ return this.type == 'textarea' ? this.cols : null
246
+ },
247
+ rowsVal: function() {
248
+ return this.type == 'textarea' ? this.rows : null
249
+ },
250
+ inputWidth: function() {
251
+ return this.width
252
+ ? typeof this.width == 'string'
253
+ ? { width: this.width }
254
+ : { width: `${this.width}px` }
255
+ : null
256
+ },
257
+ },
258
+ watch: {
259
+ value: function() {
260
+ if (this.morphing && this.tempInputVal !== null) {
261
+ this.enterMorph()
262
+ }
263
+ },
264
+ inputWriteable: function(newVal, oldVal) {
265
+ if (newVal != oldVal) {
266
+ if (!newVal) {
267
+ // 只读时是否保持格式化显示
268
+ this.formatWhenReadonly ? this.enterMorph() : this.exitMorph()
269
+ } else {
270
+ this.enterMorph()
271
+ }
272
+ }
273
+ },
274
+ },
275
+ mounted() {
276
+ const _me = this
277
+ const exp = this.mathExp
278
+ const formVm = utils.getOnlineFormInstance(_me)
279
+ //初始化流水号配置
280
+ this.initIdentity(_me, formVm)
281
+
282
+ // 数学运算表达式
283
+ if (exp) {
284
+ let elAttr = this.$vnode.data.model.expression
285
+ if (this.modelExpression) {
286
+ elAttr = this.modelExpression
287
+ }
288
+ const fields = FormMath.parseFuncexpField(exp)
289
+ formVm.$on(elAttr, function(args) {
290
+ if (args.hasOwnProperty('index')) {
291
+ const { subScopeEl, index } = utils.getSubScopeElAndIndex(_me.$el)
292
+ if (subScopeEl != null && index === null) {
293
+ throw '要计算子表行数据的输入框不在包含data-subname属性的元素中.'
294
+ }
295
+ if (index == args.index) {
296
+ _me.$emit('input', args.result)
297
+ }
298
+ } else {
299
+ _me.$emit('input', args.result)
300
+ }
301
+ })
302
+ fields.forEach((ele) => {
303
+ if (formVm.watchMap.has(ele)) {
304
+ let ary = formVm.watchMap.get(ele)
305
+ ary.push({ target: elAttr, exp })
306
+ formVm.watchMap.set(ele, ary.unique('target'))
307
+ } else {
308
+ formVm.watchMap.set(ele, [{ target: elAttr, exp }])
309
+ }
310
+ })
311
+ }
312
+ // 日期计算表达式
313
+ if (this.dateCalcExp) {
314
+ // 计算日期间隔
315
+ let handleDateCalc = function(startVal, endVal) {
316
+ _me.$emit(
317
+ 'input',
318
+ utils.dateCalc(startVal, endVal, _me.dateCalcExp.diffType)
319
+ )
320
+ }
321
+ // 获取是否在子表中每一行进行日期计算
322
+ const { subScopeEl, index } = utils.getSubScopeElAndIndex(_me.$el)
323
+ if (subScopeEl) {
324
+ const startScope = utils.getSubInputScopeByModelExpression(
325
+ subScopeEl,
326
+ this.dateCalcExp.start
327
+ )
328
+ const endScope = utils.getSubInputScopeByModelExpression(
329
+ subScopeEl,
330
+ this.dateCalcExp.end
331
+ )
332
+ // 对于子表中某行的日期计算,需要找到日期控件对应的vm实例
333
+ startScope.$watch(
334
+ 'inputVal',
335
+ function(newVal, oldVal) {
336
+ if (newVal !== oldVal) {
337
+ handleDateCalc(startScope.value, endScope.value)
338
+ }
339
+ },
340
+ { immediate: false }
341
+ )
342
+ endScope.$watch(
343
+ 'inputVal',
344
+ function(newVal, oldVal) {
345
+ if (newVal !== oldVal) {
346
+ handleDateCalc(startScope.value, endScope.value)
347
+ }
348
+ },
349
+ { immediate: false }
350
+ )
351
+ } else {
352
+ let cb = function(newVal, oldVal) {
353
+ if (newVal !== oldVal) {
354
+ let startVal = utils.getValueByPath(
355
+ formVm,
356
+ _me.dateCalcExp.start,
357
+ index
358
+ )
359
+ let endVal = utils.getValueByPath(
360
+ formVm,
361
+ _me.dateCalcExp.end,
362
+ index
363
+ )
364
+ handleDateCalc(startVal, endVal)
365
+ }
366
+ }
367
+ // 主表中的日期计算,在表单上通过v-model的表达式来监控值变更
368
+ formVm.$watch(this.dateCalcExp.start, cb, { immediate: true })
369
+ formVm.$watch(this.dateCalcExp.end, cb, { immediate: true })
370
+ }
371
+ }
372
+ this.enterMorph()
373
+ },
374
+ beforeDestroy() {
375
+ let that = this
376
+ let watcher = that._watchers.find((m) => m.expression == 'inputVal')
377
+ if (watcher && watcher.cb) {
378
+ // 单行文本销毁时,触发一次change事件,更新计算公式
379
+ watcher.cb('0', that.inputVal, true)
380
+ }
381
+ },
382
+ destroyed() {
383
+ this.unwatchAry &&
384
+ this.unwatchAry.forEach((unwatch) => {
385
+ unwatch.call()
386
+ })
387
+ },
388
+ methods: {
389
+ handleBlur(event) {
390
+ this.isFocus = false
391
+ this.enterMorph()
392
+ this.$emit('blur', event)
393
+ },
394
+ handleFocus(event) {
395
+ this.isFocus = true
396
+ this.exitMorph()
397
+ this.$emit('focus', event)
398
+ },
399
+ handleChange(val) {
400
+ this.$emit('change', val)
401
+ },
402
+ handleInput(val) {
403
+ this.$emit('input', val)
404
+ },
405
+ handleClear() {
406
+ this.$emit('clear')
407
+ },
408
+ // 进入格式显示模式
409
+ enterMorph() {
410
+ // 只在text类型时格式化
411
+ // 货币和数字时也格式化
412
+ if (
413
+ this.morphing ||
414
+ (this.type != 'text' &&
415
+ this.ctrlType !== 'currency' &&
416
+ this.ctrlType !== 'number')
417
+ ) {
418
+ return
419
+ }
420
+ // 优先处理设定了format方法的情况
421
+ if (this.format) {
422
+ const result = this.format(this.value)
423
+ if (result && result.constructor == Promise) {
424
+ result.then((resp) => {
425
+ this.morphing = true
426
+ this.tempInputVal = resp
427
+ })
428
+ } else if (result != null && result != undefined) {
429
+ this.morphing = true
430
+ this.tempInputVal = result
431
+ }
432
+ }
433
+ // 其次人民币大写
434
+ else if (this.filtercurrency) {
435
+ this.morphing = true
436
+ if (this.ctrlType === 'currency' || this.ctrlType === 'number') {
437
+ this.exhibitText = FormMath.convertCurrency(this.value)
438
+ this.isNumber = false
439
+ } else {
440
+ this.tempInputVal = FormMath.convertCurrency(this.value)
441
+ }
442
+ }
443
+ // 最后千分位
444
+ else if (this.filterthousandBit) {
445
+ this.morphing = true
446
+ if (this.ctrlType === 'currency' || this.ctrlType === 'number') {
447
+ this.exhibitText = utils.thousandBit(this.value)
448
+ this.isNumber = false
449
+ } else {
450
+ this.tempInputVal = utils.thousandBit(this.value)
451
+ }
452
+ }
453
+ },
454
+ // 退出格式化显示模式
455
+ exitMorph() {
456
+ this.morphing = false
457
+ this.tempInputVal = null
458
+ },
459
+ initIdentity(_me, pInst) {
460
+ //检查流水号
461
+ if (this.configAttributes) {
462
+ this.isEdit = !this.configAttributes.isInputEdit
463
+ //判断是否绑定流水号
464
+ if (this.configAttributes.bindIdentityAlias) {
465
+ this.isEdit = false
466
+ if (this.value) return
467
+ var alias = this.configAttributes.bindIdentityAlias
468
+ this.$requestConfig.getNextIdByAlias(alias).then((res) => {
469
+ if (res.state) {
470
+ this.$emit('input', res.value)
471
+ if (res.value) {
472
+ var match = /(\{(.*)\}).*$/.exec(res.value)
473
+ //判断流水号中是否表达式如{kjbt.csfjsc}
474
+ if (match) {
475
+ this.$emit('input', res.value.replace(match[1], ''))
476
+ // data 数据所在的 VueComponent
477
+ const runtimePInst = utils.getRuntimeTemplateOnlineForm(
478
+ this
479
+ )
480
+ if (runtimePInst && match[2]) {
481
+ runtimePInst.$watch(
482
+ `data.${match[2]}`,
483
+ (newVal, oldVal) => {
484
+ if (newVal != oldVal) {
485
+ if (this.modelName === `data.${match[2]}`) {
486
+ this.$message.error(
487
+ '流水号生成规则字段不能绑定流水号显示字段'
488
+ )
489
+ } else {
490
+ this.$emit(
491
+ 'input',
492
+ res.value.replace(match[1], newVal)
493
+ )
494
+ }
495
+ }
496
+ },
497
+ { immediate: true }
498
+ )
499
+ }
500
+ }
501
+ }
502
+ } else {
503
+ this.$message.error(res.message)
504
+ }
505
+ })
506
+ }
507
+ _me.$watch('inputVal', function() {
508
+ pInst.$watch(
509
+ 'identityMap',
510
+ function(newVal, oldVal) {
511
+ if (newVal && newVal !== oldVal) {
512
+ for (const key in newVal) {
513
+ if (_me.modelName == key) {
514
+ let item = newVal[key]
515
+ utils.setValueByPath(
516
+ pInst,
517
+ item.key,
518
+ item.value.replace(item.expression, _me.value)
519
+ )
520
+ }
521
+ }
522
+ }
523
+ },
524
+ { immediate: true }
525
+ )
526
+ })
527
+ }
528
+ },
529
+ },
530
+ }
531
+ </script>
532
+ <style lang="scss" scoped>
533
+ div[aria-invalid='true'] ::v-deep .el-input__inner,
534
+ div[aria-invalid='true'] ::v-deep .el-input__inner:focus {
535
+ border-color: #f56c6c;
536
+ }
537
+
538
+ div[aria-invalid='true'] ::v-deep .el-textarea__inner,
539
+ div[aria-invalid='true'] ::v-deep .el-textarea__inner:focus {
540
+ border-color: #f56c6c;
541
+ }
542
+ .inputs {
543
+ ::v-deep {
544
+ .el-input-number {
545
+ width: calc(100% - 30px);
546
+ }
547
+ }
548
+ }
549
+ .exhibit {
550
+ width: calc(100% - 30px);
551
+ }
552
+ </style>
@@ -0,0 +1,7 @@
1
+ import JobSelector from './src/main.vue'
2
+
3
+ JobSelector.install = function(Vue) {
4
+ Vue.component(JobSelector.name, JobSelector)
5
+ }
6
+
7
+ export default JobSelector