af-mobile-client-vue3 1.3.16 → 1.3.18

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 (274) hide show
  1. package/.cursorrules +60 -60
  2. package/.editorconfig +9 -9
  3. package/.env +10 -10
  4. package/.env.development +1 -1
  5. package/.env.production +1 -1
  6. package/.node-version +1 -1
  7. package/.vscode/extensions.json +12 -12
  8. package/.vscode/settings.json +66 -66
  9. package/CLAUDE.md +189 -189
  10. package/README.md +182 -182
  11. package/af-example-mobile-vue-web.iml +9 -9
  12. package/build/vite/index.ts +98 -98
  13. package/build/vite/optimize.ts +34 -34
  14. package/build/vite/vconsole.ts +47 -47
  15. package/commitlint.config.ts +32 -32
  16. package/compress.js +36 -36
  17. package/eslint.config.ts +30 -30
  18. package/index.html +23 -23
  19. package/mock/data.ts +20 -20
  20. package/mock/index.ts +7 -7
  21. package/mock/modules/prose.mock.ts +13 -13
  22. package/mock/modules/user.mock.ts +152 -152
  23. package/mock/util.ts +19 -19
  24. package/netlify.toml +12 -12
  25. package/package.json +114 -114
  26. package/postcss.config.ts +27 -27
  27. package/public/favicon.svg +4 -4
  28. package/public/safari-pinned-tab.svg +4 -4
  29. package/scripts/verifyCommit.js +19 -19
  30. package/src/App.vue +79 -79
  31. package/src/api/mock/index.ts +30 -30
  32. package/src/api/user/index.ts +40 -40
  33. package/src/assets/img/user/login/background-shadow-1.svg +20 -20
  34. package/src/assets/img/user/login/logo-background.svg +20 -20
  35. package/src/bootstrap.ts +26 -26
  36. package/src/components/core/BeautifulLoading/index.vue +52 -52
  37. package/src/components/core/ImageUploader/index.vue +244 -244
  38. package/src/components/core/NavBar/index.vue +53 -53
  39. package/src/components/core/Tabbar/index.vue +32 -32
  40. package/src/components/core/Uploader/index.vue +124 -124
  41. package/src/components/core/XGridDropOption/index.vue +154 -154
  42. package/src/components/core/XMultiSelect/index.vue +183 -183
  43. package/src/components/core/XSelect/index.vue +149 -149
  44. package/src/components/data/CardContainer/CardContainer.vue +118 -118
  45. package/src/components/data/CardContainer/CardHeader.vue +99 -99
  46. package/src/components/data/InfoDisplay/index.vue +132 -132
  47. package/src/components/data/UserDetail/api.ts +24 -24
  48. package/src/components/data/UserDetail/index.vue +620 -620
  49. package/src/components/data/UserDetail/recordEntries.ts +159 -159
  50. package/src/components/data/UserDetail/types.ts +26 -26
  51. package/src/components/data/XBadge/index.vue +82 -82
  52. package/src/components/data/XCellDetail/index.vue +105 -105
  53. package/src/components/data/XCellList/XCellList.md +313 -313
  54. package/src/components/data/XCellList/index.vue +1110 -1075
  55. package/src/components/data/XCellListFilter/QrScanner/index.vue +207 -207
  56. package/src/components/data/XCellListFilter/QrScanner/startScanAnimation.ts +53 -53
  57. package/src/components/data/XCellListFilter/VpnRecognition/index.vue +119 -119
  58. package/src/components/data/XCellListFilter/index.vue +705 -705
  59. package/src/components/data/XForm/index.vue +659 -659
  60. package/src/components/data/XFormGroup/doc/DeviceForm.vue +122 -122
  61. package/src/components/data/XFormGroup/doc/FormGroupDemo.vue +56 -56
  62. package/src/components/data/XFormGroup/doc/README.md +286 -286
  63. package/src/components/data/XFormGroup/doc/UserForm.vue +102 -102
  64. package/src/components/data/XFormGroup/index.vue +240 -240
  65. package/src/components/data/XFormItem/index.vue +1310 -1310
  66. package/src/components/data/XOlMap/README.md +227 -227
  67. package/src/components/data/XOlMap/XLocationPicker/index.vue +226 -226
  68. package/src/components/data/XOlMap/index.vue +1490 -1490
  69. package/src/components/data/XOlMap/types.ts +149 -149
  70. package/src/components/data/XOlMap/utils/wgs84ToGcj02.js +154 -154
  71. package/src/components/data/XReportForm/DateTimeSecondsPicker.vue +208 -208
  72. package/src/components/data/XReportForm/XReportFormJsonRender.vue +220 -220
  73. package/src/components/data/XReportForm/index.vue +1393 -1393
  74. package/src/components/data/XReportGrid/XAddReport/XAddReport.vue +198 -198
  75. package/src/components/data/XReportGrid/XAddReport/index.js +3 -3
  76. package/src/components/data/XReportGrid/XAddReport/index.md +53 -53
  77. package/src/components/data/XReportGrid/XAddReport/index.ts +10 -10
  78. package/src/components/data/XReportGrid/XReport.vue +960 -960
  79. package/src/components/data/XReportGrid/XReportDemo.vue +33 -33
  80. package/src/components/data/XReportGrid/XReportDesign.vue +597 -597
  81. package/src/components/data/XReportGrid/XReportDrawer/XReportDrawer.vue +148 -148
  82. package/src/components/data/XReportGrid/XReportDrawer/index.js +3 -3
  83. package/src/components/data/XReportGrid/XReportDrawer/index.ts +10 -10
  84. package/src/components/data/XReportGrid/XReportJsonRender.vue +399 -399
  85. package/src/components/data/XReportGrid/XReportTrGroup.vue +592 -592
  86. package/src/components/data/XReportGrid/index.md +46 -46
  87. package/src/components/data/XReportGrid/print.js +184 -184
  88. package/src/components/data/XSignature/index.vue +284 -284
  89. package/src/components/data/XTag/index.vue +10 -10
  90. package/src/components/layout/NormalDataLayout/index.vue +69 -69
  91. package/src/components/layout/TabBarLayout/index.vue +40 -40
  92. package/src/composables/dark.ts +5 -5
  93. package/src/config/routes.ts +9 -9
  94. package/src/constants/index.ts +2 -2
  95. package/src/enums/requestEnum.ts +25 -25
  96. package/src/expression/ExpressionRunner.ts +28 -28
  97. package/src/expression/TestExpression.ts +510 -510
  98. package/src/expression/core/Delegate.ts +116 -116
  99. package/src/expression/core/Expression.ts +1359 -1359
  100. package/src/expression/core/Program.ts +985 -985
  101. package/src/expression/core/Token.ts +29 -29
  102. package/src/expression/enums/ExpressionType.ts +81 -81
  103. package/src/expression/enums/TokenType.ts +11 -11
  104. package/src/expression/exception/BreakWayException.ts +2 -2
  105. package/src/expression/exception/ContinueWayException.ts +2 -2
  106. package/src/expression/exception/ExpressionException.ts +29 -29
  107. package/src/expression/exception/ReturnWayException.ts +14 -14
  108. package/src/expression/exception/ServiceException.ts +22 -22
  109. package/src/expression/instances/JSONArray.ts +52 -52
  110. package/src/expression/instances/JSONObject.ts +118 -118
  111. package/src/expression/instances/LogicConsole.ts +31 -31
  112. package/src/font-style/font.css +4 -4
  113. package/src/hooks/useBoolean.ts +26 -26
  114. package/src/hooks/useCommon.ts +9 -9
  115. package/src/hooks/useLoading.ts +16 -16
  116. package/src/hooks/useLogin.ts +97 -97
  117. package/src/icons/svg/check-in.svg +32 -32
  118. package/src/icons/svg/dark.svg +4 -4
  119. package/src/icons/svg/github.svg +4 -4
  120. package/src/icons/svg/light.svg +4 -4
  121. package/src/icons/svg/link.svg +4 -4
  122. package/src/icons/svgo.yml +22 -22
  123. package/src/layout/GridView/index.vue +16 -16
  124. package/src/layout/PageLayout.vue +9 -9
  125. package/src/layout/SingleLayout.vue +9 -9
  126. package/src/locales/en-US.json +128 -128
  127. package/src/locales/zh-CN.json +128 -128
  128. package/src/logic/LogicRunner.ts +67 -67
  129. package/src/logic/TestLogic.ts +13 -13
  130. package/src/logic/plugins/common/DateTools.ts +35 -35
  131. package/src/logic/plugins/common/VueTools.ts +30 -30
  132. package/src/logic/plugins/index.ts +7 -7
  133. package/src/main.ts +44 -44
  134. package/src/plugins/AppData.ts +38 -38
  135. package/src/plugins/GetLoginInfoService.ts +10 -10
  136. package/src/plugins/collectIcons.ts +10 -10
  137. package/src/plugins/index.ts +11 -11
  138. package/src/router/README.md +8 -8
  139. package/src/router/guards.ts +59 -59
  140. package/src/router/index.ts +35 -35
  141. package/src/router/invoiceRoutes.ts +33 -33
  142. package/src/router/routes.ts +353 -341
  143. package/src/router/types.ts +7 -7
  144. package/src/services/api/Login.ts +6 -6
  145. package/src/services/api/common.ts +109 -109
  146. package/src/services/api/index.ts +7 -7
  147. package/src/services/api/manage.ts +8 -8
  148. package/src/services/api/search.ts +16 -16
  149. package/src/services/api/user.ts +17 -17
  150. package/src/services/restTools.ts +56 -56
  151. package/src/services/v3Api.ts +147 -147
  152. package/src/stores/index.ts +11 -11
  153. package/src/stores/modules/counter.ts +19 -19
  154. package/src/stores/modules/routeCache.ts +23 -23
  155. package/src/stores/modules/setting.ts +77 -76
  156. package/src/stores/modules/user.ts +235 -235
  157. package/src/stores/mutation-type.ts +7 -7
  158. package/src/styles/app.less +36 -36
  159. package/src/styles/login.less +109 -109
  160. package/src/styles/var.less +25 -16
  161. package/src/types/env.d.ts +16 -16
  162. package/src/types/settings.ts +1 -1
  163. package/src/types/vue-router.d.ts +9 -9
  164. package/src/utils/Storage.ts +124 -124
  165. package/src/utils/authority-utils.ts +84 -84
  166. package/src/utils/common.ts +41 -41
  167. package/src/utils/crypto.ts +39 -39
  168. package/src/utils/dataUtil.ts +42 -42
  169. package/src/utils/dictUtil.ts +52 -52
  170. package/src/utils/http/index.ts +199 -199
  171. package/src/utils/i18n.ts +72 -72
  172. package/src/utils/indexedDB.ts +195 -195
  173. package/src/utils/inline-px-to-vw.ts +28 -28
  174. package/src/utils/mobileUtil.ts +34 -34
  175. package/src/utils/progress.ts +19 -19
  176. package/src/utils/routerUtil.ts +271 -271
  177. package/src/utils/runEvalFunction.ts +13 -13
  178. package/src/utils/secureStorage.ts +71 -71
  179. package/src/utils/set-page-title.ts +5 -5
  180. package/src/utils/validate.ts +6 -6
  181. package/src/utils/wechatUtil.ts +9 -9
  182. package/src/views/chat/index.vue +153 -153
  183. package/src/views/common/LoadError.vue +63 -63
  184. package/src/views/common/NotFound.vue +67 -67
  185. package/src/views/component/EvaluateRecordView/index.vue +40 -40
  186. package/src/views/component/IconifyView/index.vue +504 -504
  187. package/src/views/component/UserDetailView/UserDetailPage.vue +77 -77
  188. package/src/views/component/UserDetailView/index.vue +234 -234
  189. package/src/views/component/XCellDetailView/index.vue +217 -217
  190. package/src/views/component/XCellListView/index.vue +157 -108
  191. package/src/views/component/XFormAppraiseView/index.vue +174 -174
  192. package/src/views/component/XFormGroupView/index.vue +82 -78
  193. package/src/views/component/XFormGroupView/xformgroup222.vue +97 -0
  194. package/src/views/component/XFormView/index.vue +27 -27
  195. package/src/views/component/XOlMapView/XLocationPicker/index.vue +118 -118
  196. package/src/views/component/XOlMapView/index.vue +434 -434
  197. package/src/views/component/XOlMapView/testData.ts +64 -64
  198. package/src/views/component/XReportFormIframeView/index.vue +47 -47
  199. package/src/views/component/XReportFormView/index.vue +13 -13
  200. package/src/views/component/XReportGridView/index.vue +17 -17
  201. package/src/views/component/XRequestView/index.vue +234 -234
  202. package/src/views/component/XSignatureView/index.vue +50 -50
  203. package/src/views/component/index.vue +181 -181
  204. package/src/views/component/menu.vue +117 -117
  205. package/src/views/component/notice.vue +46 -46
  206. package/src/views/component/topNav.vue +36 -36
  207. package/src/views/invoiceShow/index.vue +61 -61
  208. package/src/views/user/login/ForgetPasswordForm.vue +94 -94
  209. package/src/views/user/login/LoginForm.vue +346 -346
  210. package/src/views/user/login/LoginTitle.vue +76 -76
  211. package/src/views/user/login/LoginWave.vue +109 -109
  212. package/src/views/user/login/index.vue +22 -22
  213. package/src/views/user/my/comm/ModifyPassword.vue +346 -346
  214. package/src/views/user/my/index.vue +340 -340
  215. package/src/views/user/register/index.vue +910 -0
  216. package/src/views/userRecords/AbnormalAlarmRecords.vue +21 -21
  217. package/src/views/userRecords/CardReplacementRecords.vue +21 -21
  218. package/src/views/userRecords/ChangeRecords.vue +19 -19
  219. package/src/views/userRecords/CommandViewRecords.vue +20 -20
  220. package/src/views/userRecords/GasCompensationRecords.vue +20 -20
  221. package/src/views/userRecords/InstrumentCollectionRecords.vue +21 -21
  222. package/src/views/userRecords/MeterRecords.vue +20 -20
  223. package/src/views/userRecords/OperateRecords.vue +51 -51
  224. package/src/views/userRecords/OtherChargeRecords.vue +19 -19
  225. package/src/views/userRecords/PaymentRecords.vue +28 -28
  226. package/src/views/userRecords/PriceAdjustmentRecords.vue +19 -19
  227. package/src/views/userRecords/ReplacementRecords.vue +19 -19
  228. package/src/views/userRecords/SafetyRecords.vue +19 -19
  229. package/src/views/userRecords/TransactionRecords.vue +21 -21
  230. package/src/views/userRecords/TransferRecords.vue +19 -19
  231. package/src/views/userRecords/operateRecordDetail/index.vue +316 -316
  232. package/src/views/userRecords/operateRecordDetail/operateRecordDetails/AddUserDetail.vue +124 -124
  233. package/src/views/userRecords/operateRecordDetail/operateRecordDetails/AdvanceDeliveryDetail.vue +88 -88
  234. package/src/views/userRecords/operateRecordDetail/operateRecordDetails/AutoAccountsCancelDetail.vue +205 -205
  235. package/src/views/userRecords/operateRecordDetail/operateRecordDetails/AutoAccountsDetail.vue +192 -192
  236. package/src/views/userRecords/operateRecordDetail/operateRecordDetails/BankDkDetail.vue +192 -192
  237. package/src/views/userRecords/operateRecordDetail/operateRecordDetails/BankPayDetail.vue +192 -192
  238. package/src/views/userRecords/operateRecordDetail/operateRecordDetails/BlacklistDetail.vue +153 -153
  239. package/src/views/userRecords/operateRecordDetail/operateRecordDetails/CancellationDetail.vue +101 -101
  240. package/src/views/userRecords/operateRecordDetail/operateRecordDetails/CardMeterCenterCancelDetail.vue +127 -127
  241. package/src/views/userRecords/operateRecordDetail/operateRecordDetails/CardMeterCenterDetail.vue +153 -153
  242. package/src/views/userRecords/operateRecordDetail/operateRecordDetails/CardOverUserDetail.vue +153 -153
  243. package/src/views/userRecords/operateRecordDetail/operateRecordDetails/ChangeMeterCancelDetail.vue +166 -166
  244. package/src/views/userRecords/operateRecordDetail/operateRecordDetails/ChangeMeterDetail.vue +205 -205
  245. package/src/views/userRecords/operateRecordDetail/operateRecordDetails/DisableManageDetail.vue +127 -127
  246. package/src/views/userRecords/operateRecordDetail/operateRecordDetails/EnableManageDetail.vue +114 -114
  247. package/src/views/userRecords/operateRecordDetail/operateRecordDetails/FaZheChangeDetail.vue +124 -124
  248. package/src/views/userRecords/operateRecordDetail/operateRecordDetails/FeeDeductionDetail.vue +153 -153
  249. package/src/views/userRecords/operateRecordDetail/operateRecordDetails/GasPriceChangeDetail.vue +126 -126
  250. package/src/views/userRecords/operateRecordDetail/operateRecordDetails/InputtorChangeDetail.vue +126 -126
  251. package/src/views/userRecords/operateRecordDetail/operateRecordDetails/IotMeterCenterCancelDetail.vue +114 -114
  252. package/src/views/userRecords/operateRecordDetail/operateRecordDetails/IotMeterCenterDetail.vue +127 -127
  253. package/src/views/userRecords/operateRecordDetail/operateRecordDetails/IotOpenDetail.vue +88 -88
  254. package/src/views/userRecords/operateRecordDetail/operateRecordDetails/MachineCardDetail.vue +101 -101
  255. package/src/views/userRecords/operateRecordDetail/operateRecordDetails/MachineMeterCenterCancelDetail.vue +218 -218
  256. package/src/views/userRecords/operateRecordDetail/operateRecordDetails/MachineMeterCenterDetail.vue +153 -153
  257. package/src/views/userRecords/operateRecordDetail/operateRecordDetails/OffGasAddGasDetail.vue +140 -140
  258. package/src/views/userRecords/operateRecordDetail/operateRecordDetails/OtherChargeCancelDetail.vue +127 -127
  259. package/src/views/userRecords/operateRecordDetail/operateRecordDetails/OtherChargeDetail.vue +114 -114
  260. package/src/views/userRecords/operateRecordDetail/operateRecordDetails/OverUserChangeDetail.vue +127 -127
  261. package/src/views/userRecords/operateRecordDetail/operateRecordDetails/ReBillDetail.vue +127 -127
  262. package/src/views/userRecords/operateRecordDetail/operateRecordDetails/RefundDetail.vue +114 -114
  263. package/src/views/userRecords/operateRecordDetail/operateRecordDetails/ReplaceCardManageCancelDetail.vue +127 -127
  264. package/src/views/userRecords/operateRecordDetail/operateRecordDetails/ReplaceCardManageDetail.vue +114 -114
  265. package/src/views/userRecords/operateRecordDetail/operateRecordDetails/SaleCardGasDetail.vue +140 -140
  266. package/src/views/userRecords/operateRecordDetail/operateRecordDetails/TransferManageCancelDetail.vue +152 -152
  267. package/src/views/userRecords/operateRecordDetail/operateRecordDetails/TransferManageDetail.vue +178 -178
  268. package/src/views/userRecords/operateRecordDetail/operateRecordDetails/UserChangeDetail.vue +123 -123
  269. package/src/views/userRecords/operateRecordDetail/operateRecordDetails/WechatPayDetail.vue +192 -192
  270. package/src/views/userRecords/types.ts +66 -66
  271. package/tsconfig.json +39 -39
  272. package/uno.config.ts +82 -82
  273. package/vite.config.ts +118 -118
  274. package/.claude/settings.local.json +0 -8
@@ -1,183 +1,183 @@
1
- <script setup lang="ts">
2
- import {
3
- Cell as VanCell,
4
- CellGroup as VanCellGroup,
5
- Checkbox as VanCheckbox,
6
- CheckboxGroup as VanCheckboxGroup,
7
- Field as VanField,
8
- Popup as VanPopup,
9
- Search as VanSearch,
10
- } from 'vant'
11
- import { computed, defineEmits, defineModel, defineProps, ref, watch } from 'vue'
12
-
13
- const props = defineProps({
14
- columns: {
15
- type: Array,
16
- default() {
17
- return []
18
- },
19
- },
20
- selectValue: {
21
- type: Array,
22
- default() {
23
- return []
24
- },
25
- },
26
- option: {
27
- type: Object,
28
- default() {
29
- return { text: 'label', value: 'value' }
30
- },
31
- },
32
- // 是否支持搜索
33
- isSearch: {
34
- type: Boolean,
35
- default: true,
36
- },
37
- })
38
- const emits = defineEmits(['input', 'confirm', 'change', 'cancel'])
39
- const show = ref(false)
40
- const searchVal = ref('')
41
- const columnsData = ref([])
42
- const checkboxValue = ref(JSON.parse(JSON.stringify(props.selectValue)))
43
- const checkedAll = ref(false)
44
- const resultValue = defineModel()
45
- const checkboxGroup = ref()
46
- const checkboxes = ref()
47
- function search(val) {
48
- if (val) {
49
- columnsData.value = props.columns.filter((item) => {
50
- return item[props.option.text].includes(val)
51
- })
52
- }
53
- else {
54
- columnsData.value = JSON.parse(JSON.stringify(props.columns))
55
- }
56
- }
57
- function getData(val) {
58
- const res = props.columns.filter((item) => {
59
- return val.includes(item[props.option.value])
60
- })
61
- return res
62
- }
63
- function onConfirm() {
64
- resultValue.value = checkboxValue.value
65
- show.value = !show.value
66
- emits('confirm', resultValue.value, getData(resultValue.value))
67
- }
68
- function change(val) {
69
- emits('change', val, getData(resultValue.value))
70
- }
71
- function cancel() {
72
- show.value = !show.value
73
- emits('cancel', resultValue.value)
74
- }
75
- function toggle(item, _index) {
76
- // 假设 checkboxValue 是一个对象,我们通过 index 来切换对应 checkbox 的值
77
- const idx = checkboxValue.value.indexOf(item[props.option.value])
78
- if (idx !== -1)
79
- checkboxValue.value.splice(idx, 1)
80
- else
81
- checkboxValue.value.push(item[props.option.value])
82
- }
83
- function toggleAll() {
84
- // 遍历 checkboxValue 并设置所有 checkbox 的值为 checkedAll 的值
85
- if (checkedAll.value)
86
- checkboxValue.value = columnsData.value.map(item => item[props.option.value])
87
-
88
- else
89
- checkboxValue.value = []
90
- }
91
- function showPopu(disabled) {
92
- columnsData.value = JSON.parse(JSON.stringify(props.columns))
93
- if (disabled !== undefined && disabled !== false)
94
- return false
95
- else
96
- show.value = !show.value
97
- }
98
- watch(() => columnsData.value, (newVal, _oldVal) => {
99
- checkedAll.value = newVal.length && newVal.length === checkboxValue.value.length
100
- })
101
- watch(() => checkboxValue.value.length, (newVal, _oldVal) => {
102
- checkedAll.value = newVal && newVal === columnsData.value.length
103
- })
104
- const resultLabel = computed(() => {
105
- const res = props.columns.filter((item) => {
106
- return (resultValue.value as unknown as string[]).includes(item[props.option.value])
107
- }).map(item => item[props.option.text])
108
- return res.join(',')
109
- })
110
- </script>
111
-
112
- <template>
113
- <div class="dh-field">
114
- <VanField
115
- v-model="resultLabel"
116
- v-bind="$attrs"
117
- readonly
118
- :border="false"
119
- :is-link="$attrs.disabled === undefined"
120
- error-message-align="right"
121
- @click="showPopu($attrs.readonly)"
122
- />
123
- <VanPopup v-model:show="show" position="bottom">
124
- <div class="van-picker__toolbar">
125
- <button type="button" class="van-picker__cancel" @click="cancel">
126
- 取消
127
- </button>
128
- <div class="van-ellipsis van-picker__title">
129
- {{ $attrs.label }}
130
- </div>
131
- <button type="button" class="van-picker__confirm" @click="onConfirm">
132
- 确认
133
- </button>
134
- </div>
135
- <div style="max-height:264px; overflow-y:auto;">
136
- <VanSearch
137
- v-if="props.isSearch"
138
- v-model="searchVal"
139
- placeholder="搜索"
140
- @update:model-value="search"
141
- @cancel="search"
142
- />
143
- <VanCell title="全选">
144
- <template #right-icon>
145
- <VanCheckbox v-model="checkedAll" name="all" @click="toggleAll" />
146
- </template>
147
- </VanCell>
148
- <VanCheckboxGroup ref="checkboxGroup" v-model="checkboxValue" @change="change">
149
- <VanCellGroup>
150
- <VanCell
151
- v-for="(item, index) in columnsData"
152
- :key="item[props.option.value]"
153
- :title="item[props.option.text]"
154
- clickable
155
- @click="toggle(item, index)"
156
- >
157
- <template #right-icon>
158
- <VanCheckbox ref="checkboxes" :name="item[props.option.value]" @click.stop />
159
- </template>
160
- </VanCell>
161
- </VanCellGroup>
162
- </VanCheckboxGroup>
163
- </div>
164
- </VanPopup>
165
- </div>
166
- </template>
167
-
168
- <style lang="less" scoped>
169
- .dh-field {
170
- width: 100%;
171
- padding: 0;
172
- background: #fff;
173
- .dh-cell.van-cell {
174
- padding: 10px 0;
175
- }
176
- .dh-cell.van-cell--required::before {
177
- left: -8px;
178
- }
179
- .van-popup {
180
- border-radius: 20px 20px 0 0;
181
- }
182
- }
183
- </style>
1
+ <script setup lang="ts">
2
+ import {
3
+ Cell as VanCell,
4
+ CellGroup as VanCellGroup,
5
+ Checkbox as VanCheckbox,
6
+ CheckboxGroup as VanCheckboxGroup,
7
+ Field as VanField,
8
+ Popup as VanPopup,
9
+ Search as VanSearch,
10
+ } from 'vant'
11
+ import { computed, defineEmits, defineModel, defineProps, ref, watch } from 'vue'
12
+
13
+ const props = defineProps({
14
+ columns: {
15
+ type: Array,
16
+ default() {
17
+ return []
18
+ },
19
+ },
20
+ selectValue: {
21
+ type: Array,
22
+ default() {
23
+ return []
24
+ },
25
+ },
26
+ option: {
27
+ type: Object,
28
+ default() {
29
+ return { text: 'label', value: 'value' }
30
+ },
31
+ },
32
+ // 是否支持搜索
33
+ isSearch: {
34
+ type: Boolean,
35
+ default: true,
36
+ },
37
+ })
38
+ const emits = defineEmits(['input', 'confirm', 'change', 'cancel'])
39
+ const show = ref(false)
40
+ const searchVal = ref('')
41
+ const columnsData = ref([])
42
+ const checkboxValue = ref(JSON.parse(JSON.stringify(props.selectValue)))
43
+ const checkedAll = ref(false)
44
+ const resultValue = defineModel()
45
+ const checkboxGroup = ref()
46
+ const checkboxes = ref()
47
+ function search(val) {
48
+ if (val) {
49
+ columnsData.value = props.columns.filter((item) => {
50
+ return item[props.option.text].includes(val)
51
+ })
52
+ }
53
+ else {
54
+ columnsData.value = JSON.parse(JSON.stringify(props.columns))
55
+ }
56
+ }
57
+ function getData(val) {
58
+ const res = props.columns.filter((item) => {
59
+ return val.includes(item[props.option.value])
60
+ })
61
+ return res
62
+ }
63
+ function onConfirm() {
64
+ resultValue.value = checkboxValue.value
65
+ show.value = !show.value
66
+ emits('confirm', resultValue.value, getData(resultValue.value))
67
+ }
68
+ function change(val) {
69
+ emits('change', val, getData(resultValue.value))
70
+ }
71
+ function cancel() {
72
+ show.value = !show.value
73
+ emits('cancel', resultValue.value)
74
+ }
75
+ function toggle(item, _index) {
76
+ // 假设 checkboxValue 是一个对象,我们通过 index 来切换对应 checkbox 的值
77
+ const idx = checkboxValue.value.indexOf(item[props.option.value])
78
+ if (idx !== -1)
79
+ checkboxValue.value.splice(idx, 1)
80
+ else
81
+ checkboxValue.value.push(item[props.option.value])
82
+ }
83
+ function toggleAll() {
84
+ // 遍历 checkboxValue 并设置所有 checkbox 的值为 checkedAll 的值
85
+ if (checkedAll.value)
86
+ checkboxValue.value = columnsData.value.map(item => item[props.option.value])
87
+
88
+ else
89
+ checkboxValue.value = []
90
+ }
91
+ function showPopu(disabled) {
92
+ columnsData.value = JSON.parse(JSON.stringify(props.columns))
93
+ if (disabled !== undefined && disabled !== false)
94
+ return false
95
+ else
96
+ show.value = !show.value
97
+ }
98
+ watch(() => columnsData.value, (newVal, _oldVal) => {
99
+ checkedAll.value = newVal.length && newVal.length === checkboxValue.value.length
100
+ })
101
+ watch(() => checkboxValue.value.length, (newVal, _oldVal) => {
102
+ checkedAll.value = newVal && newVal === columnsData.value.length
103
+ })
104
+ const resultLabel = computed(() => {
105
+ const res = props.columns.filter((item) => {
106
+ return (resultValue.value as unknown as string[]).includes(item[props.option.value])
107
+ }).map(item => item[props.option.text])
108
+ return res.join(',')
109
+ })
110
+ </script>
111
+
112
+ <template>
113
+ <div class="dh-field">
114
+ <VanField
115
+ v-model="resultLabel"
116
+ v-bind="$attrs"
117
+ readonly
118
+ :border="false"
119
+ :is-link="$attrs.disabled === undefined"
120
+ error-message-align="right"
121
+ @click="showPopu($attrs.readonly)"
122
+ />
123
+ <VanPopup v-model:show="show" position="bottom">
124
+ <div class="van-picker__toolbar">
125
+ <button type="button" class="van-picker__cancel" @click="cancel">
126
+ 取消
127
+ </button>
128
+ <div class="van-ellipsis van-picker__title">
129
+ {{ $attrs.label }}
130
+ </div>
131
+ <button type="button" class="van-picker__confirm" @click="onConfirm">
132
+ 确认
133
+ </button>
134
+ </div>
135
+ <div style="max-height:264px; overflow-y:auto;">
136
+ <VanSearch
137
+ v-if="props.isSearch"
138
+ v-model="searchVal"
139
+ placeholder="搜索"
140
+ @update:model-value="search"
141
+ @cancel="search"
142
+ />
143
+ <VanCell title="全选">
144
+ <template #right-icon>
145
+ <VanCheckbox v-model="checkedAll" name="all" @click="toggleAll" />
146
+ </template>
147
+ </VanCell>
148
+ <VanCheckboxGroup ref="checkboxGroup" v-model="checkboxValue" @change="change">
149
+ <VanCellGroup>
150
+ <VanCell
151
+ v-for="(item, index) in columnsData"
152
+ :key="item[props.option.value]"
153
+ :title="item[props.option.text]"
154
+ clickable
155
+ @click="toggle(item, index)"
156
+ >
157
+ <template #right-icon>
158
+ <VanCheckbox ref="checkboxes" :name="item[props.option.value]" @click.stop />
159
+ </template>
160
+ </VanCell>
161
+ </VanCellGroup>
162
+ </VanCheckboxGroup>
163
+ </div>
164
+ </VanPopup>
165
+ </div>
166
+ </template>
167
+
168
+ <style lang="less" scoped>
169
+ .dh-field {
170
+ width: 100%;
171
+ padding: 0;
172
+ background: #fff;
173
+ .dh-cell.van-cell {
174
+ padding: 10px 0;
175
+ }
176
+ .dh-cell.van-cell--required::before {
177
+ left: -8px;
178
+ }
179
+ .van-popup {
180
+ border-radius: 20px 20px 0 0;
181
+ }
182
+ }
183
+ </style>
@@ -1,149 +1,149 @@
1
- <script setup lang="ts">
2
- import {
3
- Field as VanField,
4
- Picker as VanPicker,
5
- Popup as VanPopup,
6
- } from 'vant'
7
- import { computed, defineEmits, defineModel, defineProps, onBeforeMount, ref, watch } from 'vue'
8
-
9
- const props = defineProps({
10
- columns: {
11
- type: Array,
12
- default() {
13
- return []
14
- },
15
- },
16
- option: {
17
- type: Object,
18
- default() {
19
- return { text: 'label', value: 'value', children: 'children' }
20
- },
21
- },
22
- isSearch: {
23
- type: Boolean,
24
- default: false,
25
- },
26
- offOption: { // 关闭option配置key-value;当数据是非集合的数组的时候,开启
27
- type: Boolean,
28
- default: false,
29
- },
30
- border: { // 是否展示边框
31
- type: Boolean,
32
- default: false,
33
- },
34
- })
35
- const emits = defineEmits(['confirm', 'change', 'cancel', 'input'])
36
- const show = ref(false)
37
- const searchVal = ref('')
38
- const resultValue = defineModel()
39
- const columnsData = ref([])
40
- const selectedOption = ref([])
41
-
42
- // 转换空children为空字符串
43
- function transformColumns(data) {
44
- return data.map((item) => {
45
- if (item.children && item.children.length === 0) {
46
- return {
47
- ...item,
48
- children: '',
49
- }
50
- }
51
- else if (item.children && item.children.length !== 0) {
52
- return { ...item, children: transformColumns(item.children) }
53
- }
54
- else {
55
- return { ...item }
56
- }
57
- })
58
- }
59
-
60
- onBeforeMount(() => {
61
- columnsData.value = transformColumns(props.columns)
62
- })
63
-
64
- const resultLabel = computed({
65
- get() {
66
- if (!resultValue.value)
67
- return ''
68
- const res = props.columns.filter((item) => {
69
- const data = props.offOption ? item : item[props.option.value]
70
- return data === resultValue.value
71
- })
72
- return res.length ? (props.offOption ? res[0] : res[0][props.option.text]) : ''
73
- },
74
- set() {
75
-
76
- },
77
- })
78
-
79
- function search(val) {
80
- if (val) {
81
- columnsData.value = transformColumns(columnsData.value).filter((item) => {
82
- const data = props.offOption ? item : item[props.option.text]
83
- return data.includes(val)
84
- })
85
- }
86
- else {
87
- columnsData.value = transformColumns(props.columns)
88
- }
89
- }
90
-
91
- function onConfirm(value, _index) {
92
- resultValue.value = props.offOption ? value.selectedValues : value.selectedValues[0]
93
- // resultValue.value = value.selectedValues
94
- selectedOption.value = value.selectedOptions
95
- show.value = !show.value
96
- emits('confirm', value.selectedValues[0], value.selectedOptions)
97
- }
98
-
99
- function change(val, index) {
100
- emits('change', val, index, resultValue.value)
101
- }
102
-
103
- function cancel(val, index) {
104
- show.value = !show.value
105
- emits('cancel', val, index, resultValue.value)
106
- }
107
-
108
- function showPopu(disabled) {
109
- if (disabled !== undefined && disabled !== false)
110
- return false
111
- columnsData.value = transformColumns(props.columns)
112
- show.value = !show.value
113
- }
114
-
115
- watch(() => resultValue, (newVal, _oldVal) => {
116
- searchVal.value = ''
117
- columnsData.value = transformColumns(props.columns)
118
- emits('input', newVal)
119
- })
120
- </script>
121
-
122
- <template>
123
- <VanField
124
- v-model="resultLabel"
125
- v-bind="$attrs"
126
- readonly
127
- :is-link="true"
128
- :border="props.border"
129
- error-message-align="right"
130
- @click="showPopu($attrs.readonly)"
131
- />
132
- <VanPopup v-model:show="show" position="bottom">
133
- <VanField v-if="props.isSearch" v-model="searchVal" input-align="left" placeholder="搜索" @input="search" />
134
- <VanPicker
135
- v-bind="$attrs"
136
- :columns="columnsData"
137
- :columns-field-names="props.option"
138
- show-toolbar
139
- :value-key="props.option.text"
140
- @cancel="cancel"
141
- @confirm="onConfirm"
142
- @change="change"
143
- />
144
- </VanPopup>
145
- </template>
146
-
147
- <style scoped>
148
- /* 样式定义 */
149
- </style>
1
+ <script setup lang="ts">
2
+ import {
3
+ Field as VanField,
4
+ Picker as VanPicker,
5
+ Popup as VanPopup,
6
+ } from 'vant'
7
+ import { computed, defineEmits, defineModel, defineProps, onBeforeMount, ref, watch } from 'vue'
8
+
9
+ const props = defineProps({
10
+ columns: {
11
+ type: Array,
12
+ default() {
13
+ return []
14
+ },
15
+ },
16
+ option: {
17
+ type: Object,
18
+ default() {
19
+ return { text: 'label', value: 'value', children: 'children' }
20
+ },
21
+ },
22
+ isSearch: {
23
+ type: Boolean,
24
+ default: false,
25
+ },
26
+ offOption: { // 关闭option配置key-value;当数据是非集合的数组的时候,开启
27
+ type: Boolean,
28
+ default: false,
29
+ },
30
+ border: { // 是否展示边框
31
+ type: Boolean,
32
+ default: false,
33
+ },
34
+ })
35
+ const emits = defineEmits(['confirm', 'change', 'cancel', 'input'])
36
+ const show = ref(false)
37
+ const searchVal = ref('')
38
+ const resultValue = defineModel()
39
+ const columnsData = ref([])
40
+ const selectedOption = ref([])
41
+
42
+ // 转换空children为空字符串
43
+ function transformColumns(data) {
44
+ return data.map((item) => {
45
+ if (item.children && item.children.length === 0) {
46
+ return {
47
+ ...item,
48
+ children: '',
49
+ }
50
+ }
51
+ else if (item.children && item.children.length !== 0) {
52
+ return { ...item, children: transformColumns(item.children) }
53
+ }
54
+ else {
55
+ return { ...item }
56
+ }
57
+ })
58
+ }
59
+
60
+ onBeforeMount(() => {
61
+ columnsData.value = transformColumns(props.columns)
62
+ })
63
+
64
+ const resultLabel = computed({
65
+ get() {
66
+ if (!resultValue.value)
67
+ return ''
68
+ const res = props.columns.filter((item) => {
69
+ const data = props.offOption ? item : item[props.option.value]
70
+ return data === resultValue.value
71
+ })
72
+ return res.length ? (props.offOption ? res[0] : res[0][props.option.text]) : ''
73
+ },
74
+ set() {
75
+
76
+ },
77
+ })
78
+
79
+ function search(val) {
80
+ if (val) {
81
+ columnsData.value = transformColumns(columnsData.value).filter((item) => {
82
+ const data = props.offOption ? item : item[props.option.text]
83
+ return data.includes(val)
84
+ })
85
+ }
86
+ else {
87
+ columnsData.value = transformColumns(props.columns)
88
+ }
89
+ }
90
+
91
+ function onConfirm(value, _index) {
92
+ resultValue.value = props.offOption ? value.selectedValues : value.selectedValues[0]
93
+ // resultValue.value = value.selectedValues
94
+ selectedOption.value = value.selectedOptions
95
+ show.value = !show.value
96
+ emits('confirm', value.selectedValues[0], value.selectedOptions)
97
+ }
98
+
99
+ function change(val, index) {
100
+ emits('change', val, index, resultValue.value)
101
+ }
102
+
103
+ function cancel(val, index) {
104
+ show.value = !show.value
105
+ emits('cancel', val, index, resultValue.value)
106
+ }
107
+
108
+ function showPopu(disabled) {
109
+ if (disabled !== undefined && disabled !== false)
110
+ return false
111
+ columnsData.value = transformColumns(props.columns)
112
+ show.value = !show.value
113
+ }
114
+
115
+ watch(() => resultValue, (newVal, _oldVal) => {
116
+ searchVal.value = ''
117
+ columnsData.value = transformColumns(props.columns)
118
+ emits('input', newVal)
119
+ })
120
+ </script>
121
+
122
+ <template>
123
+ <VanField
124
+ v-model="resultLabel"
125
+ v-bind="$attrs"
126
+ readonly
127
+ :is-link="true"
128
+ :border="props.border"
129
+ error-message-align="right"
130
+ @click="showPopu($attrs.readonly)"
131
+ />
132
+ <VanPopup v-model:show="show" position="bottom">
133
+ <VanField v-if="props.isSearch" v-model="searchVal" input-align="left" placeholder="搜索" @input="search" />
134
+ <VanPicker
135
+ v-bind="$attrs"
136
+ :columns="columnsData"
137
+ :columns-field-names="props.option"
138
+ show-toolbar
139
+ :value-key="props.option.text"
140
+ @cancel="cancel"
141
+ @confirm="onConfirm"
142
+ @change="change"
143
+ />
144
+ </VanPopup>
145
+ </template>
146
+
147
+ <style scoped>
148
+ /* 样式定义 */
149
+ </style>