mooho-base-admin-plus 0.1.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 (283) hide show
  1. package/.env +5 -0
  2. package/.env.development +0 -0
  3. package/.env.production +0 -0
  4. package/.eslintignore +11 -0
  5. package/.eslintrc.js +47 -0
  6. package/.prettierrc +15 -0
  7. package/README.md +18 -0
  8. package/dist/favicon.ico +0 -0
  9. package/dist/mooho-base-admin-plus.min.esm.js +131746 -0
  10. package/dist/mooho-base-admin-plus.min.js +279 -0
  11. package/dist/setting.js +31 -0
  12. package/dist/static/images/app-barcode.png +0 -0
  13. package/dist/static/images/login/bg.png +0 -0
  14. package/dist/static/images/login/logo.png +0 -0
  15. package/dist/static/images/login/password-active.png +0 -0
  16. package/dist/static/images/login/password-default.png +0 -0
  17. package/dist/static/images/login/signIn-img.png +0 -0
  18. package/dist/static/images/login/user-active.png +0 -0
  19. package/dist/static/images/login/user-default.png +0 -0
  20. package/dist/static/images/logo-dark.png +0 -0
  21. package/dist/static/images/logo-small.png +0 -0
  22. package/dist/static/images/logo.png +0 -0
  23. package/dist/static/images/logo.svg +510 -0
  24. package/dist/static/images/no-image.png +0 -0
  25. package/dist/style.css +4 -0
  26. package/index.html +18 -0
  27. package/other/pda.vue +28 -0
  28. package/package.json +59 -0
  29. package/public/favicon.ico +0 -0
  30. package/public/setting.js +31 -0
  31. package/public/static/images/app-barcode.png +0 -0
  32. package/public/static/images/login/bg.png +0 -0
  33. package/public/static/images/login/logo.png +0 -0
  34. package/public/static/images/login/password-active.png +0 -0
  35. package/public/static/images/login/password-default.png +0 -0
  36. package/public/static/images/login/signIn-img.png +0 -0
  37. package/public/static/images/login/user-active.png +0 -0
  38. package/public/static/images/login/user-default.png +0 -0
  39. package/public/static/images/logo-dark.png +0 -0
  40. package/public/static/images/logo-small.png +0 -0
  41. package/public/static/images/logo.png +0 -0
  42. package/public/static/images/logo.svg +510 -0
  43. package/public/static/images/no-image.png +0 -0
  44. package/src/App.vue +60 -0
  45. package/src/api/application.js +35 -0
  46. package/src/api/customModel.js +187 -0
  47. package/src/api/customPage.js +15 -0
  48. package/src/api/customTable.js +24 -0
  49. package/src/api/dataSource.js +93 -0
  50. package/src/api/dataView.js +199 -0
  51. package/src/api/dictType.js +23 -0
  52. package/src/api/entityView.js +13 -0
  53. package/src/api/enum.js +15 -0
  54. package/src/api/filterColumn.js +16 -0
  55. package/src/api/model.js +244 -0
  56. package/src/api/movePlan.js +29 -0
  57. package/src/api/notification.js +28 -0
  58. package/src/api/openApiPermission.js +25 -0
  59. package/src/api/permission.js +51 -0
  60. package/src/api/planJob.js +15 -0
  61. package/src/api/process.js +23 -0
  62. package/src/api/processDef.js +36 -0
  63. package/src/api/processInst.js +16 -0
  64. package/src/api/rolePermission.js +17 -0
  65. package/src/api/roleProperty.js +36 -0
  66. package/src/api/shortcut.js +20 -0
  67. package/src/api/system.js +23 -0
  68. package/src/api/task.js +56 -0
  69. package/src/api/taskQueue.js +24 -0
  70. package/src/api/user.js +45 -0
  71. package/src/api/viewColumn.js +16 -0
  72. package/src/assets/svg/body.svg +17 -0
  73. package/src/assets/svg/header-theme-dark.svg +40 -0
  74. package/src/assets/svg/header-theme-primary.svg +40 -0
  75. package/src/assets/svg/header-top.svg +40 -0
  76. package/src/assets/svg/icon-happy.svg +1 -0
  77. package/src/assets/svg/icon-sad.svg +1 -0
  78. package/src/assets/svg/icon-social-bilibili.svg +1 -0
  79. package/src/assets/svg/icon-social-dingding.svg +1 -0
  80. package/src/assets/svg/icon-social-facebook.svg +1 -0
  81. package/src/assets/svg/icon-social-juejin.svg +1 -0
  82. package/src/assets/svg/icon-social-qq.svg +1 -0
  83. package/src/assets/svg/icon-social-twitter.svg +1 -0
  84. package/src/assets/svg/icon-social-wechat.svg +1 -0
  85. package/src/assets/svg/icon-social-weibo.svg +1 -0
  86. package/src/assets/svg/icon-social-zhihu.svg +1 -0
  87. package/src/assets/svg/nav-theme-dark.svg +40 -0
  88. package/src/assets/svg/nav-theme-light.svg +40 -0
  89. package/src/components/copyright/index.vue +28 -0
  90. package/src/components/home/notice-list.vue +62 -0
  91. package/src/components/home/shortcut.vue +125 -0
  92. package/src/components/input/dialog-select.vue +301 -0
  93. package/src/components/input/item-select.vue +195 -0
  94. package/src/components/link/index.vue +54 -0
  95. package/src/components/richEditor/index.vue +86 -0
  96. package/src/components/upload/file-upload.vue +84 -0
  97. package/src/components/upload/upload-attachment.vue +119 -0
  98. package/src/components/upload/upload-image.vue +212 -0
  99. package/src/components/view/column-check.vue +223 -0
  100. package/src/components/view/column-edit.vue +850 -0
  101. package/src/components/view/column-select.vue +206 -0
  102. package/src/components/view/condition-edit.vue +164 -0
  103. package/src/components/view/filter-edit.vue +633 -0
  104. package/src/components/view/filter-setting.vue +126 -0
  105. package/src/components/view/form-setting-layout.vue +375 -0
  106. package/src/components/view/form-setting.vue +247 -0
  107. package/src/components/view/group-column.vue +104 -0
  108. package/src/components/view/group-method.vue +104 -0
  109. package/src/components/view/mixin.js +72 -0
  110. package/src/components/view/modal-form-filter.vue +319 -0
  111. package/src/components/view/modal-form-sort.vue +248 -0
  112. package/src/components/view/modal-form.vue +453 -0
  113. package/src/components/view/modal-table.vue +471 -0
  114. package/src/components/view/table-filter.vue +702 -0
  115. package/src/components/view/table-setting.vue +533 -0
  116. package/src/components/view/view-chart.vue +423 -0
  117. package/src/components/view/view-form-draggable.vue +837 -0
  118. package/src/components/view/view-form.vue +1444 -0
  119. package/src/components/view/view-table.vue +2261 -0
  120. package/src/components/workflow/flow-chart.vue +846 -0
  121. package/src/directive/focus.js +10 -0
  122. package/src/directive/tabHide.js +9 -0
  123. package/src/i18n/index.js +15 -0
  124. package/src/i18n/locale/en-US.js +1 -0
  125. package/src/i18n/locale/lang.js +1 -0
  126. package/src/i18n/locale/zh-CN.js +1 -0
  127. package/src/i18n/locale.js +102 -0
  128. package/src/index.js +222 -0
  129. package/src/layouts/basic-layout/header-breadcrumb/index.vue +122 -0
  130. package/src/layouts/basic-layout/header-collapse/index.vue +44 -0
  131. package/src/layouts/basic-layout/header-fullscreen/index.vue +19 -0
  132. package/src/layouts/basic-layout/header-i18n/index.vue +45 -0
  133. package/src/layouts/basic-layout/header-log/index.vue +41 -0
  134. package/src/layouts/basic-layout/header-logo/index.vue +23 -0
  135. package/src/layouts/basic-layout/header-notice/index.vue +218 -0
  136. package/src/layouts/basic-layout/header-reload/index.vue +21 -0
  137. package/src/layouts/basic-layout/header-search/index.vue +37 -0
  138. package/src/layouts/basic-layout/header-setting/index.vue +219 -0
  139. package/src/layouts/basic-layout/header-user/index.vue +175 -0
  140. package/src/layouts/basic-layout/i18n.js +50 -0
  141. package/src/layouts/basic-layout/index.vue +280 -0
  142. package/src/layouts/basic-layout/menu-head/index.vue +120 -0
  143. package/src/layouts/basic-layout/menu-head/title.vue +48 -0
  144. package/src/layouts/basic-layout/menu-side/index.vue +113 -0
  145. package/src/layouts/basic-layout/menu-side/menu-collapse.vue +76 -0
  146. package/src/layouts/basic-layout/menu-side/menu-item.vue +31 -0
  147. package/src/layouts/basic-layout/menu-side/menu-title.vue +56 -0
  148. package/src/layouts/basic-layout/menu-side/submenu.vue +31 -0
  149. package/src/layouts/basic-layout/mixins/click-item.js +21 -0
  150. package/src/layouts/basic-layout/mixins/sider-menu-badge.js +13 -0
  151. package/src/layouts/basic-layout/mixins/translate-title.js +11 -0
  152. package/src/layouts/basic-layout/tabs/index.vue +192 -0
  153. package/src/layouts/basic-layout/water-mark/index.vue +29 -0
  154. package/src/libs/lodop/index.js +145 -0
  155. package/src/libs/random_str.js +10 -0
  156. package/src/libs/request/index.js +158 -0
  157. package/src/libs/system/index.js +234 -0
  158. package/src/libs/util.cookies.js +44 -0
  159. package/src/libs/util.db.js +13 -0
  160. package/src/libs/util.js +55 -0
  161. package/src/libs/util.log.js +88 -0
  162. package/src/libs/water-mark.js +44 -0
  163. package/src/menu/header.js +20 -0
  164. package/src/menu/modules/dashboard.js +23 -0
  165. package/src/menu/sider.js +12 -0
  166. package/src/mixins/app.js +9 -0
  167. package/src/mixins/page.js +643 -0
  168. package/src/pages/account/login.vue +101 -0
  169. package/src/pages/common/home.vue +169 -0
  170. package/src/pages/common/task-form.vue +350 -0
  171. package/src/pages/common/todo.vue +31 -0
  172. package/src/pages/system/apiLog.vue +79 -0
  173. package/src/pages/system/applicationType.vue +182 -0
  174. package/src/pages/system/customPage.vue +62 -0
  175. package/src/pages/system/customTable.vue +98 -0
  176. package/src/pages/system/dict.vue +36 -0
  177. package/src/pages/system/dictType.vue +58 -0
  178. package/src/pages/system/entityView.vue +38 -0
  179. package/src/pages/system/error/404.vue +6 -0
  180. package/src/pages/system/extendColumn.vue +99 -0
  181. package/src/pages/system/formView.vue +136 -0
  182. package/src/pages/system/log.vue +55 -0
  183. package/src/pages/system/notice.vue +26 -0
  184. package/src/pages/system/openApi.vue +26 -0
  185. package/src/pages/system/openUser.vue +66 -0
  186. package/src/pages/system/organization.vue +98 -0
  187. package/src/pages/system/organizationType.vue +26 -0
  188. package/src/pages/system/permission.vue +175 -0
  189. package/src/pages/system/planJob.vue +40 -0
  190. package/src/pages/system/printTemplate.vue +48 -0
  191. package/src/pages/system/process.vue +79 -0
  192. package/src/pages/system/processType.vue +26 -0
  193. package/src/pages/system/role.vue +395 -0
  194. package/src/pages/system/rolePropertyEdit.vue +480 -0
  195. package/src/pages/system/sequenceSetting.vue +26 -0
  196. package/src/pages/system/systemData.vue +52 -0
  197. package/src/pages/system/tableView.vue +386 -0
  198. package/src/pages/system/taskQueue.vue +48 -0
  199. package/src/pages/system/user.vue +250 -0
  200. package/src/pages/template/processPage.vue +243 -0
  201. package/src/pages/template/reportPage.vue +66 -0
  202. package/src/pages/template/viewPage.vue +139 -0
  203. package/src/plugins/auth/index.js +21 -0
  204. package/src/plugins/error/index.js +31 -0
  205. package/src/plugins/index.js +24 -0
  206. package/src/plugins/sweetalert2/index.js +20 -0
  207. package/src/router/dynamic.js +183 -0
  208. package/src/router/index.js +84 -0
  209. package/src/setting.js +202 -0
  210. package/src/store/index.js +9 -0
  211. package/src/store/modules/admin/index.js +16 -0
  212. package/src/store/modules/admin/modules/account.js +103 -0
  213. package/src/store/modules/admin/modules/cache.js +119 -0
  214. package/src/store/modules/admin/modules/dataView.js +112 -0
  215. package/src/store/modules/admin/modules/db.js +231 -0
  216. package/src/store/modules/admin/modules/i18n.js +87 -0
  217. package/src/store/modules/admin/modules/layout.js +115 -0
  218. package/src/store/modules/admin/modules/loader.js +44 -0
  219. package/src/store/modules/admin/modules/log.js +77 -0
  220. package/src/store/modules/admin/modules/menu.js +338 -0
  221. package/src/store/modules/admin/modules/page.js +466 -0
  222. package/src/store/modules/admin/modules/user.js +96 -0
  223. package/src/store/modules/admin/modules/viewPage.js +34 -0
  224. package/src/styles/common.less +47 -0
  225. package/src/styles/css/default.css +510 -0
  226. package/src/styles/css/login.css +1217 -0
  227. package/src/styles/default/index.less +6 -0
  228. package/src/styles/font/demo.css +539 -0
  229. package/src/styles/font/demo_index.html +372 -0
  230. package/src/styles/font/icon-demo/demo.css +539 -0
  231. package/src/styles/font/icon-demo/demo_index.html +423 -0
  232. package/src/styles/font/icon-demo/iconfont.css +61 -0
  233. package/src/styles/font/icon-demo/iconfont.eot +0 -0
  234. package/src/styles/font/icon-demo/iconfont.js +1 -0
  235. package/src/styles/font/icon-demo/iconfont.svg +59 -0
  236. package/src/styles/font/icon-demo/iconfont.ttf +0 -0
  237. package/src/styles/font/icon-demo/iconfont.woff +0 -0
  238. package/src/styles/font/icon-demo/iconfont.woff2 +0 -0
  239. package/src/styles/font/iconfont.css +47 -0
  240. package/src/styles/font/iconfont.js +1 -0
  241. package/src/styles/font/iconfont.json +65 -0
  242. package/src/styles/font/iconfont.ttf +0 -0
  243. package/src/styles/font/iconfont.woff +0 -0
  244. package/src/styles/font/iconfont.woff2 +0 -0
  245. package/src/styles/font/ionicons.svg +870 -0
  246. package/src/styles/font/ionicons.ttf +0 -0
  247. package/src/styles/font/ionicons.woff +0 -0
  248. package/src/styles/font/ionicons.woff2 +0 -0
  249. package/src/styles/index.less +7 -0
  250. package/src/styles/layout/basic-layout/layout.less +527 -0
  251. package/src/styles/layout/basic-layout/menu.less +274 -0
  252. package/src/styles/layout/index.less +2 -0
  253. package/src/styles/setting.less +6 -0
  254. package/styleguide.config.js +22 -0
  255. package/test/api/barcode.js +50 -0
  256. package/test/api/inbound.js +47 -0
  257. package/test/api/interfaceLog.js +15 -0
  258. package/test/api/interfaceQueue.js +15 -0
  259. package/test/api/interfaceServer.js +29 -0
  260. package/test/api/movePlan.js +50 -0
  261. package/test/api/movePlanItem.js +13 -0
  262. package/test/api/moveType.js +22 -0
  263. package/test/api/openApiPermission.js +25 -0
  264. package/test/api/outbound.js +40 -0
  265. package/test/api/permission.js +34 -0
  266. package/test/api/rolePermission.js +17 -0
  267. package/test/api/user.js +40 -0
  268. package/test/api/viewColumn.js +16 -0
  269. package/test/api/warehouse.js +13 -0
  270. package/test/api/warehouseMoveType.js +18 -0
  271. package/test/main.js +55 -0
  272. package/test/package.js +33 -0
  273. package/test/pages/home/index.vue +22 -0
  274. package/test/pages/task/test.vue +28 -0
  275. package/test/pages/test/dataViewTest.vue +28 -0
  276. package/test/pages/test/logReport.vue +25 -0
  277. package/test/pages/test/testPage.vue +38 -0
  278. package/test/router/routes.js +88 -0
  279. package/test/setting.env.js +22 -0
  280. package/test/styles/css/custom.css +0 -0
  281. package/test/styles/css/login.css +1217 -0
  282. package/vite.config.js +72 -0
  283. package/vue.config.js +20 -0
@@ -0,0 +1,702 @@
1
+ <template>
2
+ <div style="display: contents">
3
+ <Col v-for="(column, index) in columns" :key="index" v-bind="getGrid(column.columnWidth)">
4
+ <template v-if="column.isShow">
5
+ <div :key="column.code" v-if="column.controlType === 'Placeholder'"></div>
6
+ <FormItem :label="column.name" :key="column.code" v-if="column.controlType !== 'Placeholder'">
7
+ <template v-if="column.controlType === 'Custom'">
8
+ <!--
9
+ @slot 自定义列
10
+ @binding {object} filter 数据对象
11
+ @binding {object} column 列对象
12
+ @binding {string} code 列代码
13
+ -->
14
+ <slot name="column" :filter="data" :column="column" :code="column.code"></slot>
15
+ </template>
16
+ <template v-else-if="column.controlType === 'Label'">
17
+ <div v-html="showData(data, column)"></div>
18
+ </template>
19
+ <template v-else-if="column.controlType === 'TextInput'">
20
+ <Input
21
+ size="small"
22
+ type="text"
23
+ :model-value="parseFilterData(data, column)"
24
+ @update:model-value="$event => setFilterData(data, column, $event)"
25
+ @on-keyup="$event => onKeyup($event)"
26
+ :style="{ width: column.controlWidth == null ? null : column.controlWidth + 'px' }"
27
+ :placeholder="column.description"
28
+ />
29
+ </template>
30
+ <template v-else-if="column.controlType === 'NumberInput'">
31
+ <Input
32
+ size="small"
33
+ type="number"
34
+ number
35
+ :model-value="parseFilterData(data, column)"
36
+ @update:model-value="$event => setFilterData(data, column, $event)"
37
+ @on-keyup="$event => onKeyup($event)"
38
+ :style="{ width: column.controlWidth == null ? '100px' : column.controlWidth + 'px' }"
39
+ :placeholder="column.description"
40
+ />
41
+ </template>
42
+ <template v-else-if="column.controlType === 'Select'">
43
+ <Select
44
+ size="small"
45
+ :model-value="parseFilterData(data, column)"
46
+ @update:model-value="$event => setFilterData(data, column, $event)"
47
+ clearable
48
+ :style="{ width: column.controlWidth == null ? null : column.controlWidth + 'px' }"
49
+ :placeholder="column.description"
50
+ :transfer="true"
51
+ @on-change="selected => onSelectDataChange(column, selected)"
52
+ >
53
+ <Option v-for="item in getDataSource(data, column)" :key="item.id" :value="item.id">{{ item.name }}</Option>
54
+ </Select>
55
+ </template>
56
+ <template v-else-if="column.controlType === 'MultiSelect'">
57
+ <Select
58
+ size="small"
59
+ :model-value="parseArrayFilterData(data, column)"
60
+ :multiple="true"
61
+ clearable
62
+ @update:model-value="$event => setArrayFilterData(data, column, $event)"
63
+ :style="{ width: column.controlWidth == null ? null : column.controlWidth + 'px' }"
64
+ :placeholder="column.description"
65
+ :transfer="true"
66
+ @on-change="selected => onSelectDataChange(column, selected)"
67
+ >
68
+ <Option v-for="item in getDataSource(data, column)" :key="item.id" :value="item.id">{{ item.name }}</Option>
69
+ </Select>
70
+ </template>
71
+ <template v-else-if="column.controlType === 'TreeSelect'">
72
+ <TreeSelect
73
+ size="small"
74
+ :model-value="parseTreeFilterData(data, column)"
75
+ @update:model-value="$event => setFilterData(data, column, $event)"
76
+ :data="getDataSource(data, column)"
77
+ :clearable="true"
78
+ :style="{ width: column.controlWidth == null ? null : column.controlWidth + 'px' }"
79
+ :placeholder="column.description"
80
+ :transfer="true"
81
+ @on-change="selected => onSelectDataChange(column, selected)"
82
+ ></TreeSelect>
83
+ </template>
84
+ <template v-else-if="column.controlType === 'MultiTreeSelect'">
85
+ <TreeSelect
86
+ size="small"
87
+ :model-value="parseArrayFilterData(data, column)"
88
+ @update:model-value="$event => setArrayFilterData(data, column, $event)"
89
+ :data="getDataSource(data, column)"
90
+ :multiple="true"
91
+ :show-checkbox="true"
92
+ :clearable="true"
93
+ :style="{ width: column.controlWidth == null ? null : column.controlWidth + 'px' }"
94
+ :placeholder="column.description"
95
+ :transfer="true"
96
+ @on-change="selected => onSelectDataChange(column, selected)"
97
+ ></TreeSelect>
98
+ </template>
99
+ <template v-else-if="column.controlType === 'SelectWithOther'">
100
+ <Select
101
+ size="small"
102
+ :model-value="parseFilterDataWithOther(data, column)"
103
+ @update:model-value="$event => setFilterDataWithOther(data, column, $event)"
104
+ clearable
105
+ :style="{ width: column.controlWidth == null ? '40%' : column.controlWidth + 'px' }"
106
+ :placeholder="column.description"
107
+ :transfer="true"
108
+ @on-change="selected => onSelectDataChange(column, selected)"
109
+ >
110
+ <Option v-for="item in getDataSource(data, column)" :key="item.id" :value="item.id">{{ item.name }}</Option>
111
+ <Option key="__Other" value="__Other">其他</Option>
112
+ </Select>
113
+ <Input
114
+ type="text"
115
+ size="small"
116
+ v-show="parseFilterDataWithOther(data, column) == '__Other'"
117
+ :model-value="parseFilterData(data, column)"
118
+ @update:model-value="$event => setFilterData(data, column, $event)"
119
+ :style="{ width: column.controlWidth == null ? '40%' : column.controlWidth + 'px' }"
120
+ style="margin-left: 4px"
121
+ :maxlength="column.maxLength"
122
+ :placeholder="column.description"
123
+ @on-change="onDataChange(column)"
124
+ />
125
+ </template>
126
+ <template v-else-if="column.controlType === 'ComboSelect'">
127
+ <Select
128
+ size="small"
129
+ :model-value="parseFilterData(data, column)"
130
+ @update:model-value="$event => setFilterData(data, column, $event)"
131
+ clearable
132
+ filterable
133
+ :style="{ width: column.controlWidth == null ? null : column.controlWidth + 'px' }"
134
+ :placeholder="column.description"
135
+ :transfer="true"
136
+ @on-change="selected => onSelectDataChange(column, selected)"
137
+ >
138
+ <Option v-for="item in getDataSource(data, column)" :key="item.id" :value="item.id">{{ item.name }}</Option>
139
+ </Select>
140
+ </template>
141
+ <template v-else-if="column.controlType === 'DialogSelect'">
142
+ <dialog-select
143
+ size="small"
144
+ :model-value="parseFilterData(data, column)"
145
+ @update:model-value="$event => setFilterData(data, column, $event)"
146
+ :source="column.source"
147
+ :source-data-code="column.sourceDataCode"
148
+ :source-display-code="column.sourceDisplayCode"
149
+ :param="getParam(data, column)"
150
+ :controlWidth="column.controlWidth"
151
+ @on-change="selected => onSelectDataChange(column, selected)"
152
+ ></dialog-select>
153
+ </template>
154
+ <template
155
+ v-else-if="
156
+ column.controlType === 'Date' ||
157
+ column.controlType === 'DateTime' ||
158
+ column.controlType === 'Year' ||
159
+ column.controlType === 'Month' ||
160
+ column.controlType === 'DateRange'
161
+ "
162
+ >
163
+ <DatePicker
164
+ size="small"
165
+ :type="column.controlType.toLowerCase()"
166
+ :model-value="parseFilterData(data, column)"
167
+ @update:model-value="$event => setFilterData(data, column, $event)"
168
+ :placeholder="column.description"
169
+ :transfer="true"
170
+ :style="{ width: column.controlWidth == null ? null : column.controlWidth + 'px' }"
171
+ @on-change="onDataChange(column)"
172
+ ></DatePicker>
173
+ </template>
174
+ <template v-else-if="column.controlType === 'Time'">
175
+ <TimePicker
176
+ size="small"
177
+ type="time"
178
+ :model-value="parseFilterData(data, column)"
179
+ @update:model-value="$event => setFilterData(data, column, $event)"
180
+ :placeholder="column.description"
181
+ :transfer="true"
182
+ :style="{ width: column.controlWidth == null ? null : column.controlWidth + 'px' }"
183
+ @on-change="onDataChange(column)"
184
+ ></TimePicker>
185
+ </template>
186
+ <template v-else-if="column.controlType === 'Check'">
187
+ <Checkbox
188
+ size="small"
189
+ style="line-height: 26px"
190
+ :model-value="!!parseFilterData(data, column)"
191
+ @update:model-value="$event => setFilterData(data, column, $event)"
192
+ @on-change="onDataChange(column)"
193
+ />
194
+ </template>
195
+ <template v-else-if="column.controlType === 'Switch'">
196
+ <div style="line-height: 24px">
197
+ <Switch
198
+ size="small"
199
+ :model-value="!!parseFilterData(data, column)"
200
+ @update:model-value="$event => setFilterData(data, column, $event)"
201
+ @on-change="onDataChange(column)"
202
+ />
203
+ </div>
204
+ </template>
205
+ <template v-else-if="column.controlType === 'Radio'">
206
+ <RadioGroup
207
+ size="small"
208
+ style="line-height: 22px"
209
+ :model-value="parseFilterData(data, column)"
210
+ @update:model-value="$event => setFilterData(data, column, $event)"
211
+ @on-change="selected => onSelectDataChange(column, selected)"
212
+ >
213
+ <Radio v-for="item in getDataSource(data, column)" :key="item.id" :label="item.id">
214
+ <span>{{ item.name }}</span>
215
+ </Radio>
216
+ </RadioGroup>
217
+ </template>
218
+ <template v-else>暂不支持此控件 {{ column.controlType }}</template>
219
+ </FormItem>
220
+ </template>
221
+ </Col>
222
+ <Col v-if="keywordEnable" v-bind="grid6">
223
+ <FormItem label="关键词">
224
+ <Input v-model="data.keyword" v-focus @on-keyup="$event => onKeyup($event)" size="small" />
225
+ </FormItem>
226
+ </Col>
227
+ </div>
228
+ </template>
229
+ <script>
230
+ import mixinPage from '../../mixins/page';
231
+ import mixin from './mixin';
232
+ import modelApi from '../../api/model';
233
+ import customModelApi from '../../api/customModel';
234
+ import DialogSelect from '../input/dialog-select.vue';
235
+ import dateFormat from 'date-fns/format';
236
+
237
+ export default {
238
+ mixins: [mixin, mixinPage],
239
+ components: { DialogSelect },
240
+ data() {
241
+ return {};
242
+ },
243
+ async created() {
244
+ this.init();
245
+ },
246
+ props: {
247
+ keywordEnable: {
248
+ type: Boolean
249
+ },
250
+ // 是否存储过程
251
+ isDataSource: {
252
+ type: Boolean
253
+ },
254
+ // 筛选项数据
255
+ data: {
256
+ type: Object
257
+ },
258
+ // 字段
259
+ columns: {
260
+ type: Array
261
+ }
262
+ },
263
+ watch: {
264
+ columns() {
265
+ this.init();
266
+ }
267
+ },
268
+ computed: {},
269
+ methods: {
270
+ init() {
271
+ let data = this.data;
272
+ this.columns.forEach(item => {
273
+ if (item.defaultValue) {
274
+ if (item.defaultValue == '{today}') {
275
+ // 当前日期
276
+ let date = new Date();
277
+ let value = date.toISOString().replace(/T.*/, '');
278
+ this.setData(data, item.code, new Date(value));
279
+ } else if (item.defaultValue.startsWith('{today(') && item.defaultValue.endsWith(')}')) {
280
+ // 当前时间转字符串
281
+ let format = item.defaultValue.substr(7, item.defaultValue.length - 9);
282
+ this.setData(data, item.code, dateFormat(new Date(), format));
283
+ } else if (item.defaultValue == '{currentUser}') {
284
+ // 当前用户
285
+ this.setData(data, item.code, this.info.name);
286
+ } else {
287
+ if (item.dataType === 'Integer') {
288
+ this.setData(data, item.code, parseInt(item.defaultValue));
289
+ } else if (item.dataType === 'Decimal') {
290
+ this.setData(data, item.code, parseFloat(item.defaultValue));
291
+ } else if (item.dataType === 'Boolean' && item.defaultValue.toUpperCase == 'TRUE') {
292
+ this.setData(data, item.code, true);
293
+ } else if (item.dataType === 'Boolean' && item.defaultValue.toUpperCase == 'FALSE') {
294
+ this.setData(data, item.code, false);
295
+ } else {
296
+ this.setData(data, item.code, item.defaultValue);
297
+ }
298
+ }
299
+ }
300
+ });
301
+
302
+ // 初始化触发规则
303
+ setTimeout(() => {
304
+ // 初始化静态选项
305
+ this.initStaticItem();
306
+
307
+ // 初始化触发规则
308
+ this.initTrigger();
309
+
310
+ this.onDataChange();
311
+ });
312
+ },
313
+ // 初始化静态选项
314
+ initStaticItem() {
315
+ this.columns.forEach(column => {
316
+ if (column.isStaticItem) {
317
+ column.dataSource = [];
318
+
319
+ if (!!(column.itemData || '').trim()) {
320
+ column.itemData.split(/[\n]/).forEach(item => {
321
+ if (!!(item || '').trim()) {
322
+ if (item.split(':').length > 1) {
323
+ let key = item.split(':')[0];
324
+ let value = item.split(':')[1];
325
+
326
+ column.dataSource.push({
327
+ id: key,
328
+ name: value
329
+ });
330
+ } else {
331
+ column.dataSource.push({
332
+ id: item,
333
+ name: item
334
+ });
335
+ }
336
+ }
337
+ });
338
+ }
339
+ }
340
+ });
341
+
342
+ //this.$forceUpdate();
343
+ },
344
+ // 初始化触发规则
345
+ initTrigger() {
346
+ // 触发规则
347
+ this.columns.forEach(column => {
348
+ column.triggers = [];
349
+ });
350
+
351
+ this.columns
352
+ .filter(column => {
353
+ return !column.isStaticItem && !!(column.source || '').trim() && !!(column.param || '').trim();
354
+ })
355
+ .forEach(column => {
356
+ let param = JSON.parse(column.param);
357
+ for (let key in param) {
358
+ this.columns
359
+ .filter(item => {
360
+ return param[key] === item.code;
361
+ })
362
+ .forEach(item => {
363
+ item.triggers.push(column);
364
+ });
365
+ }
366
+ });
367
+ },
368
+ // 填充数据源
369
+ async fillDataSource(data, column, param) {
370
+ // 参数完整,查询数据
371
+ let res;
372
+ if (column.isSourceCustom) {
373
+ res = await customModelApi.query(column.source, param);
374
+ } else {
375
+ res = await modelApi.query(column.source, param);
376
+ }
377
+
378
+ column.rawData = res.data;
379
+
380
+ if (column.controlType === 'TreeSelect' || column.controlType === 'MultiTreeSelect') {
381
+ let data = res.data.map(item => {
382
+ return {
383
+ id: !(column.sourceDataCode || '').trim() ? item.id : this.parseData(item, column.sourceDataCode),
384
+ name: this.parseData(item, column.sourceDisplayCode),
385
+ parentID: item.parentID
386
+ };
387
+ });
388
+
389
+ column.dataSource = this.getTreeDataSource(data, column, null);
390
+ } else {
391
+ column.dataSource = res.data.map(item => {
392
+ return {
393
+ id: !(column.sourceDataCode || '').trim() ? item.id : this.parseData(item, column.sourceDataCode),
394
+ name: this.parseData(item, column.sourceDisplayCode)
395
+ };
396
+ });
397
+
398
+ // 默认第一项
399
+ if (data) {
400
+ if (this.parseFilterData(data, column) == null && column.isDefaultFirst && res.length > 0) {
401
+ this.setData(data, column.code, this.parseData(res[0], column.sourceDataCode));
402
+ }
403
+ }
404
+ }
405
+
406
+ //this.$forceUpdate();
407
+
408
+ // 更新data触发刷新
409
+ // this.data = { ...this.data };
410
+
411
+ // 触发
412
+ this.onDataChange(column);
413
+ },
414
+ // 获取树结构数据源
415
+ getTreeDataSource(data, column, parentID) {
416
+ let result = data
417
+ .filter(item => {
418
+ return item.parentID == parentID;
419
+ })
420
+ .map(item => {
421
+ return {
422
+ value: !(column.sourceDataCode || '').trim() ? item.id : this.parseData(item, column.sourceDataCode),
423
+ title: this.parseData(item, column.sourceDisplayCode),
424
+ selected: false,
425
+ checked: false
426
+ };
427
+ });
428
+
429
+ if (result.length > 0) {
430
+ for (let item of result) {
431
+ item.expand = true;
432
+ item.children = this.getTreeDataSource(data, column, item.value);
433
+ }
434
+ }
435
+
436
+ return result;
437
+ },
438
+ // 获取数据源
439
+ getDataSource(data, column) {
440
+ if (!column.isStaticItem && column.dataType.indexOf('Enum:') === 0) {
441
+ // 枚举
442
+ return this.getEnumList(column.dataType.split(':')[1]);
443
+ } else {
444
+ return column.dataSource == null ? [] : column.dataSource;
445
+ }
446
+ },
447
+ // // 可筛选下拉框加载数据
448
+ // loadOption(data, column, keyword) {
449
+ // let param = this.getParam(data, column);
450
+
451
+ // if (param != null) {
452
+ // if (!(keyword || '').trim() && this.parseFilterData(data, column) != null) {
453
+ // param.id = this.parseFilterData(data, column);
454
+ // } else {
455
+ // param.keyword = keyword;
456
+ // }
457
+ // param.per = 20;
458
+
459
+ // this.fillDataSource(data, column, param);
460
+ // } else {
461
+ // // 参数不完整,清空数据
462
+ // column.dataSource = [];
463
+ // this.setData(data, column.code, null);
464
+ // // column.displayValue = null;
465
+
466
+ // // 触发
467
+ // column.triggers.forEach(item => {
468
+ // item.needRefresh = true;
469
+ // });
470
+ // }
471
+ // },
472
+ // 选项变化事件
473
+ onSelectDataChange(sender, selected) {
474
+ let code;
475
+ if (sender.code.endsWith('ID')) {
476
+ code = sender.code.substr(0, sender.code.length - 2);
477
+ }
478
+ let model = null;
479
+ if (typeof selected == 'object') {
480
+ if (selected instanceof Array) {
481
+ model = [];
482
+
483
+ for (let item of selected) {
484
+ if (typeof item == 'object') {
485
+ model.push(item);
486
+ } else {
487
+ if (sender.rawData) {
488
+ model.push(
489
+ sender.rawData.find(rawData => {
490
+ return this.parseFilterData(rawData, sender.sourceDataCode) == item;
491
+ })
492
+ );
493
+ } else {
494
+ model.push(item);
495
+ }
496
+ }
497
+ }
498
+ } else {
499
+ model = selected;
500
+ }
501
+ } else {
502
+ if (sender.rawData) {
503
+ model = sender.rawData.find(rawData => {
504
+ return this.parseFilterData(rawData, sender.sourceDataCode) == selected;
505
+ });
506
+ } else {
507
+ model = selected;
508
+ }
509
+ }
510
+
511
+ if (code) {
512
+ this.setData(this.data, code, model);
513
+ }
514
+
515
+ this.onDataChange(sender, model);
516
+ },
517
+ // 数据变化事件
518
+ onDataChange(sender, selected) {
519
+ setTimeout(() => {
520
+ this.$emit('on-change', sender, selected);
521
+ });
522
+
523
+ // 计算需要刷新的字段
524
+ if (sender == null || sender.triggers !== []) {
525
+ this.columns.forEach(function (column) {
526
+ if (
527
+ !column.isStaticItem &&
528
+ !!(column.source || '').trim() &&
529
+ (sender == null ||
530
+ sender.triggers.some(item => {
531
+ return item.id === column.id;
532
+ }))
533
+ ) {
534
+ column.needRefresh = true;
535
+ }
536
+ });
537
+ }
538
+
539
+ // 刷新数据源
540
+ while (true) {
541
+ let column = this.columns.filter(item => {
542
+ return item.needRefresh === true;
543
+ })[0];
544
+
545
+ if (column == null) {
546
+ // 没有需要刷新的字段
547
+ break;
548
+ }
549
+
550
+ let param = this.getParam(this.data, column);
551
+
552
+ if (
553
+ column.controlType === 'Select' ||
554
+ column.controlType === 'MultiSelect' ||
555
+ column.controlType === 'TreeSelect' ||
556
+ column.controlType === 'MultiTreeSelect' ||
557
+ column.controlType === 'SelectWithOther' ||
558
+ column.controlType === 'ComboSelect' ||
559
+ column.controlType === 'Radio'
560
+ ) {
561
+ // 选择框、单选框组
562
+ if (param != null) {
563
+ this.fillDataSource(this.data, column, param);
564
+ } else {
565
+ // 参数不完整,清空数据
566
+ column.dataSource = [];
567
+ this.setData(this.data, column.code, null);
568
+ // column.displayValue = null;
569
+
570
+ // 触发
571
+ column.triggers.forEach(item => {
572
+ item.needRefresh = true;
573
+ });
574
+ }
575
+ }
576
+
577
+ column.needRefresh = false;
578
+ }
579
+
580
+ //this.$forceUpdate();
581
+ },
582
+ // 筛选项取值
583
+ parseFilterData(model, column) {
584
+ return model[this.getFilterKey(column)];
585
+ },
586
+ // 筛选项赋值
587
+ setFilterData(model, column, value) {
588
+ model[this.getFilterKey(column)] = value;
589
+
590
+ if (column.code.indexOf('.') >= 0) {
591
+ this.setData(model, column.code, value);
592
+ }
593
+ },
594
+ // 筛选项取值(数组)
595
+ parseArrayFilterData(model, column) {
596
+ let data = [];
597
+ let value = this.parseFilterData(model, column);
598
+ if (value != null && value != '') {
599
+ data = value.split(',');
600
+ }
601
+
602
+ return data;
603
+ },
604
+ // 筛选项赋值(数组)
605
+ setArrayFilterData(model, column, value) {
606
+ let data = '';
607
+ if (value != null) {
608
+ data = value.join(',');
609
+ }
610
+
611
+ this.setFilterData(model, column, data);
612
+ },
613
+ // 根据表达式取值(带其他)
614
+ parseFilterDataWithOther(model, column) {
615
+ let expression = column.code;
616
+ let selectValue = this.parseData(model, expression + '_o');
617
+
618
+ let value = this.parseFilterData(model, expression);
619
+ let dataSource = this.getDataSource(model, column);
620
+
621
+ if (selectValue != null) {
622
+ return selectValue;
623
+ } else if (value == null) {
624
+ return null;
625
+ } else if (
626
+ dataSource &&
627
+ dataSource.some(item => {
628
+ return item.id == value;
629
+ })
630
+ ) {
631
+ return value;
632
+ } else {
633
+ return '__Other';
634
+ }
635
+ },
636
+ // 根据表达式赋值(带其他)
637
+ setFilterDataWithOther(model, column, value) {
638
+ this.setData(model, column.code + '_o', value);
639
+ if (value != '__Other') {
640
+ this.setFilterData(model, column, value);
641
+ } else {
642
+ this.setFilterData(model, column, null);
643
+ }
644
+ },
645
+ // 获取筛选项Key
646
+ getFilterKey(column) {
647
+ let key = column.code;
648
+
649
+ //if (!this.isDataSource) {
650
+ switch (column.controlType) {
651
+ case 'Date':
652
+ key = 'd_' + key; // 日
653
+ break;
654
+ case 'Month':
655
+ key = 'm_' + key; // 月
656
+ break;
657
+ case 'Year':
658
+ key = 'y_' + key; // 年
659
+ break;
660
+ }
661
+ //}
662
+
663
+ switch (column.operator) {
664
+ case 'GreaterThan':
665
+ key = key + '_g'; // 大于
666
+ break;
667
+ case 'LessThan':
668
+ key = key + '_l'; // 小于
669
+ break;
670
+ case 'GreaterThanOrEqual':
671
+ key = key + '_ge'; // 大于等于
672
+ break;
673
+ case 'LessThanOrEqual':
674
+ key = key + '_le'; // 小于等于
675
+ break;
676
+ case 'NotEqual':
677
+ key = key + '_n'; // 不等于
678
+ break;
679
+ case 'Contains':
680
+ key = key + '_c'; // 模糊匹配
681
+ break;
682
+ }
683
+
684
+ return key;
685
+ },
686
+ // 键盘事件
687
+ onKeyup(e) {
688
+ this.$emit('on-keyup', e);
689
+ },
690
+ // 根据表达式取值(树)
691
+ parseTreeFilterData(data, column) {
692
+ let value = this.parseFilterData(data, column);
693
+
694
+ if (value == null) {
695
+ return '';
696
+ } else {
697
+ return value;
698
+ }
699
+ }
700
+ }
701
+ };
702
+ </script>