@utogether/udp-core 1.0.1-beta.1 → 1.0.1-beta.11

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 (147) hide show
  1. package/build/plugins.ts +39 -32
  2. package/dist/{403-Dp617CWX.js → 403-Dsgsr2M-.js} +1 -1
  3. package/dist/{404-Cz_Axb6Y.js → 404-DmPHEfqM.js} +1 -1
  4. package/dist/{500-BGCtRNse.js → 500-OYEgHR2a.js} +1 -1
  5. package/dist/{AuthorityInfo-DGGfm7IS.js → AuthorityInfo-B1H1txG-.js} +1 -1
  6. package/dist/AuthorityInfo.vue_vue_type_style_index_0_lang-BUlmQtjQ.js +100 -0
  7. package/dist/{Company-IV3GTnzY.js → Company-C8ojgx93.js} +3 -3
  8. package/dist/{CompanyPanel-qV-_VtoL.js → CompanyPanel-Dageer1t.js} +16 -16
  9. package/dist/{Department-B3W-OxW8.js → Department-Dr94_85I.js} +3 -3
  10. package/dist/{DepartmentPanel-Cw3OWxE7.js → DepartmentPanel-Bc5r1HpT.js} +1 -1
  11. package/dist/{DesignPanel-BFxR2fHJ.js → DesignPanel-CcWt1Myp.js} +1 -1
  12. package/dist/{DesignPanel.vue_vue_type_style_index_0_lang-DljbeFba.js → DesignPanel.vue_vue_type_style_index_0_lang-CKA6nx1l.js} +24 -26
  13. package/dist/DictView-BHj6wexC.js +110 -0
  14. package/dist/InvOrganization-DP3Le9g-.js +72 -0
  15. package/dist/Org-BRGHTwsw.js +39 -0
  16. package/dist/{Preview-BlDMmpdR.js → Preview-CqMaUD_3.js} +1 -1
  17. package/dist/{ReportDefine-Cub_85LA.js → ReportDefine-PEQdTCOY.js} +1 -1
  18. package/dist/{ReportDesign-hFhq5UVE.js → ReportDesign-CB4bv8ba.js} +43 -43
  19. package/dist/{ReportQuery-ChkWEyxT.js → ReportQuery-B7t4lMK0.js} +1 -1
  20. package/dist/{ReportQueryFrom-KVyD_8Dj.js → ReportQueryFrom-VBxUIMRJ.js} +1 -1
  21. package/dist/{ReportQueryFrom.vue_vue_type_style_index_0_lang-CLNODquq.js → ReportQueryFrom.vue_vue_type_style_index_0_lang-HeLA4Qs5.js} +1 -1
  22. package/dist/{ReportTemplate-ag9NDvh2.js → ReportTemplate-DNkv7F5p.js} +28 -28
  23. package/dist/{Role-_q3lQ8CZ.js → Role-BGfTpZK4.js} +6 -6
  24. package/dist/{RoleAssign-DZb9IRsm.js → RoleAssign-DrKFWZzA.js} +8 -8
  25. package/dist/{RolePanel-CsLsz-Ds.js → RolePanel-3lvRh7aS.js} +1 -1
  26. package/dist/{RolePanel-BQb1LlhD.js → RolePanel-BRI5QYe4.js} +1 -1
  27. package/dist/RolePanel.vue_vue_type_script_setup_true_lang-BXKZb7yt.js +132 -0
  28. package/dist/{RolePanel.vue_vue_type_script_setup_true_lang-BrnRgHEk.js → RolePanel.vue_vue_type_script_setup_true_lang-Cci_Ysty.js} +44 -38
  29. package/dist/{ScrollPanel.vue_vue_type_style_index_0_lang-CaFKRwXu.js → ScrollPanel.vue_vue_type_style_index_0_lang-BmId6zzA.js} +21 -21
  30. package/dist/{Staff-BSf9Ypbk.js → Staff-Dr0dq3fW.js} +3 -3
  31. package/dist/{StaffInfo-BNKasyMF.js → StaffInfo-_N9g2hPa.js} +1 -1
  32. package/dist/{StaffInfo.vue_vue_type_script_setup_true_lang-DDZ7ukd0.js → StaffInfo.vue_vue_type_script_setup_true_lang-DiTJY2ug.js} +11 -11
  33. package/dist/{StaffPanel-Bpq0WVlH.js → StaffPanel-mxJQiW3G.js} +1 -1
  34. package/dist/{StaffPanel.vue_vue_type_script_setup_true_lang-BhiJ0Q-Q.js → StaffPanel.vue_vue_type_script_setup_true_lang-GRGn-5t6.js} +2 -2
  35. package/dist/{SysUser-FAABuNti.js → SysUser-DgA19hZE.js} +2 -2
  36. package/dist/{SysUserPanel-PxJeOgHm.js → SysUserPanel-Bc85z5_K.js} +1 -1
  37. package/dist/SysUserPanel.vue_vue_type_script_setup_true_lang-BHDrP1Pk.js +294 -0
  38. package/dist/{SystemMenu-C-7NAGon.js → SystemMenu-Be-gFIie.js} +26 -26
  39. package/dist/{UserInfo-ClXKtyGo.js → UserInfo-BCYuwFmr.js} +1 -1
  40. package/dist/{UserInfo.vue_vue_type_style_index_0_lang-8N7P4Hl7.js → UserInfo.vue_vue_type_style_index_0_lang-B1lgokO6.js} +39 -37
  41. package/dist/{childView-C_HmDQNd.js → childView-DhcBr1UA.js} +1 -1
  42. package/dist/{childView-uUlBcTza.js → childView-Dk4zZoXd.js} +1 -1
  43. package/dist/{childView.vue_vue_type_style_index_0_lang-Ckjmw6wJ.js → childView.vue_vue_type_style_index_0_lang-CVnLnl03.js} +40 -40
  44. package/dist/{childView.vue_vue_type_style_index_0_lang-y0sDvYx5.js → childView.vue_vue_type_style_index_0_lang-D4GYVhOc.js} +1 -1
  45. package/dist/{code-rule-AgCVDKFy.js → code-rule-BSwPwuAL.js} +9 -10
  46. package/dist/core.es.js +14 -11
  47. package/dist/{cron-task-C6FgQxTi.js → cron-task-T1ztyra7.js} +1 -1
  48. package/dist/{frameView-BDgISK7N.js → frameView-BDgngiBq.js} +1 -1
  49. package/dist/img/l_img.svg +1 -1
  50. package/dist/img/minicolors.png +0 -0
  51. package/dist/img/v_img.svg +1 -1
  52. package/dist/index-BSj2AtVL.js +4468 -0
  53. package/dist/{layoutView-yb3DV2DQ.js → layoutView-i7dLLBzJ.js} +1181 -1176
  54. package/dist/{login-RRpljbkm.js → login-K5Ludp8x.js} +105 -113
  55. package/dist/{login-log-CvVnyGi3.js → login-log-kqKzKTto.js} +1 -1
  56. package/dist/{lov-view-C9-rjzZR.js → lov-view-lAexiucu.js} +2 -2
  57. package/dist/{menuInfo-CzPQyFhp.js → menuInfo-BaN5YZPp.js} +1 -1
  58. package/dist/{menuInfo.vue_vue_type_style_index_0_lang-BumXunCg.js → menuInfo.vue_vue_type_style_index_0_lang-yI4QOYxG.js} +100 -97
  59. package/dist/{pda-app-Dvy3U-b6.js → pda-app-DEtDXFvM.js} +211 -197
  60. package/dist/{resource-Fy0lFkSV.js → resource-Bztmz7pn.js} +15 -15
  61. package/dist/{su-welcome-DYvSCUST.js → su-welcome-Bx8nBPi9.js} +109 -110
  62. package/dist/sys-config-nvrtYGgi.js +290 -0
  63. package/dist/udp-core.css +2 -2
  64. package/dist/{utogether-CjmJiHoE.js → utogether-yPnwDAIH.js} +1 -1
  65. package/index.ts +40 -36
  66. package/package.json +18 -18
  67. package/src/App.vue +65 -70
  68. package/src/api/index.ts +31 -31
  69. package/src/components/SuCharts/src/UserInfo.vue +78 -78
  70. package/src/components/SuScrollTree/ScrollPanel.vue +3 -3
  71. package/src/components/udp/count-down.vue +536 -0
  72. package/src/components/udp/flip-down/FlipCard/flip-card.vue +251 -0
  73. package/src/components/udp/flip-down/FlipCard/interfaces.ts +4 -0
  74. package/src/components/udp/flip-down/FlipClock/flip-clock.vue +113 -0
  75. package/src/components/udp/form-upload.vue +414 -64
  76. package/src/components/udp/form.vue +112 -0
  77. package/src/components/udp/grid.vue +495 -0
  78. package/src/components/udp/index.ts +10 -4
  79. package/src/components/udp/lov.vue +388 -0
  80. package/src/components/udp/modal-form.vue +13 -3
  81. package/src/components/udp/modal-grid.vue +298 -0
  82. package/src/components/udp/upload.vue +423 -0
  83. package/src/components/udp/utils.ts +447 -40
  84. package/src/directives/permission/index.ts +1 -1
  85. package/src/layout/components/lay-navbar/index.vue +239 -237
  86. package/src/layout/components/lay-panel/index.vue +150 -150
  87. package/src/layout/components/lay-search/index.vue +25 -25
  88. package/src/layout/components/lay-select-org/index.vue +64 -69
  89. package/src/layout/components/lay-sidebar/breadCrumb.vue +1 -1
  90. package/src/layout/components/lay-sidebar/horizontal.vue +190 -191
  91. package/src/layout/components/lay-sidebar/mixNav.vue +260 -258
  92. package/src/layout/components/lay-sidebar/sidebar-logo.vue +92 -98
  93. package/src/layout/components/lay-tag/index.vue +625 -625
  94. package/src/layout/hooks/useNav.ts +173 -173
  95. package/src/layout/layoutView.vue +215 -215
  96. package/src/main.ts +119 -109
  97. package/src/plugins/i18n/en.ts +302 -289
  98. package/src/plugins/i18n/zh.ts +349 -337
  99. package/src/plugins/vxe-table/index.ts +53 -46
  100. package/src/plugins/vxe-table/render.tsx +956 -817
  101. package/src/router/index.ts +177 -183
  102. package/src/router/modules/remaining.ts +58 -83
  103. package/src/store/modules/permission.ts +1 -4
  104. package/src/style/button.scss +85 -78
  105. package/src/style/tailwind.css +1 -68
  106. package/src/style/vxetable.scss +44 -11
  107. package/src/utils/authority/index.ts +1 -1
  108. package/src/utils/{http → udp/http}/index.ts +283 -297
  109. package/src/utils/{http → udp/http}/types.d.ts +8 -5
  110. package/src/utils/udp/useRender.ts +17 -6
  111. package/src/views/login/login-view.vue +300 -314
  112. package/src/views/organization/company/CompanyPanel.vue +259 -259
  113. package/src/views/organization/inv-org/InvOrganization.vue +68 -54
  114. package/src/views/organization/org/Org.vue +9 -5
  115. package/src/views/system/menu/SystemMenu.vue +183 -197
  116. package/src/views/system/menu/menuInfo.vue +363 -371
  117. package/src/views/system/role/AuthorityInfo.vue +19 -15
  118. package/src/views/system/role/Role.vue +1 -5
  119. package/src/views/system/role/RolePanel.vue +11 -2
  120. package/src/views/system/role/UserInfo.vue +195 -193
  121. package/src/views/system/role-assign/RoleAssign.vue +57 -57
  122. package/src/views/system/role-assign/RolePanel.vue +139 -136
  123. package/src/views/system/sys/sys-config.vue +287 -291
  124. package/src/views/system/sysUser/SysUserPanel.vue +278 -278
  125. package/src/views/uapp/pda/pda-app.vue +208 -176
  126. package/src/views/udev/dict/DictView.vue +118 -106
  127. package/src/views/udev/dict/childView.vue +7 -7
  128. package/src/views/udev/lov/lov-view.vue +91 -91
  129. package/src/views/ufile/aggregation/File.vue +5 -5
  130. package/src/views/ufile/file/water-mark.vue +14 -14
  131. package/src/views/uhome/su-welcome.vue +3 -3
  132. package/src/views/ulogin/login.vue +12 -8
  133. package/src/views/upms/user/login-log.vue +1 -1
  134. package/src/views/urpt/design/DesignPanel.vue +507 -526
  135. package/src/views/urpt/design/ReportDesign.vue +15 -19
  136. package/src/views/urpt/static-resource/resource.vue +3 -3
  137. package/src/views/urpt/template/ReportTemplate.vue +7 -7
  138. package/types/global.d.ts +2 -1
  139. package/vite.config.ts +6 -2
  140. package/dist/AuthorityInfo.vue_vue_type_style_index_0_lang-BqccGW7v.js +0 -102
  141. package/dist/DictView-C-i7e4hZ.js +0 -95
  142. package/dist/InvOrganization-cfT6riGU.js +0 -260
  143. package/dist/Org-CA7vTDIF.js +0 -35
  144. package/dist/RolePanel.vue_vue_type_script_setup_true_lang-cmW7zBLu.js +0 -126
  145. package/dist/SysUserPanel.vue_vue_type_script_setup_true_lang-njefUln5.js +0 -288
  146. package/dist/index-DzOzUkf6.js +0 -3388
  147. package/dist/sys-config-DJ1vNQTy.js +0 -277
@@ -1,176 +1,208 @@
1
- <!--
2
- * @Author: wei.li
3
- * @Date: 2021-12-23 11:22:51
4
- * @LastEditors: levi7754 levi7754@163.com
5
- * @LastEditTime: 2025-04-29 17:11:13
6
- * @Description: 托盘管理
7
- -->
8
-
9
- <template>
10
- <div>
11
- <ut-grid ref="xgrid" :columns="columns" :url="url" mode="form" @buttonClick="onButtonClick" />
12
- <ut-modal-form
13
- v-if="showModalForm"
14
- :record="record"
15
- :items="items"
16
- :width="360"
17
- :height="340"
18
- :title="$t('message.title.appAdd')"
19
- :url="url"
20
- data-status="add"
21
- @close="showModalForm = false"
22
- @confirm="onConfirm"
23
- />
24
- </div>
25
- </template>
26
- <script lang="tsx">
27
- export default { name: 'PdaApp' };
28
- </script>
29
- <script setup lang="tsx">
30
- import { ref } from 'vue';
31
- import { useI18n } from 'vue-i18n';
32
- import to from 'await-to-js';
33
- import { getBaseURL, getServiceApi } from '../../../api';
34
- import { useRender } from '@utogether/utils';
35
- import { clone } from 'xe-utils';
36
- import SuQrcode from '../../../components/SuQrcode';
37
-
38
- const baseURL = getBaseURL();
39
-
40
- const renderHook = useRender();
41
-
42
- const { t } = useI18n();
43
- const url = '/upms/v1/app-manage';
44
- const xgrid = ref(null);
45
- const record = ref({});
46
-
47
- // const formItems = [
48
- // { field: 'organizationName', itemRender: renderHook.renderInvOrg() },
49
- // { field: 'trayTypeCode', itemRender: renderHook.renderDict('SU.TRAY.TYPE') },
50
- // { field: 'trayCode' },
51
- // { field: 'materialCode' },
52
- // { field: 'materialName' },
53
- // { field: 'packCode', title: 'message.boxSignCode' }
54
- // ];
55
-
56
- // 列字段
57
- const columns = [
58
- { type: 'checkbox', width: 45, align: 'center' },
59
- // { field: 'trayTypeCode', width: 110, formatter: ['formatDict', 'SU.TRAY.TYPE'] },
60
- { field: 'appVersion', width: 110 },
61
- { field: 'buildNo', width: 130 },
62
- { field: 'versionInfo', miWidth: 200 },
63
- {
64
- field: 'enabled',
65
- title: 'message.status',
66
- width: 90,
67
- formatter: ({ row }) => (row.enabled === '1' ? t('message.appupper') : t('message.applower'))
68
- },
69
- { field: 'creationDate', width: 140 },
70
- {
71
- field: 'operate',
72
- width: 260,
73
- fixed: 'right',
74
- slots: {
75
- default: ({ row }) => {
76
- const content = row.enabled === '1' ? 'applower' : 'appupper';
77
- const status = row.enabled === '1' ? 'warning' : 'primary';
78
- const icon = row.enabled === '1' ? 'ri-inbox-archive-line' : 'ri-inbox-unarchive-line';
79
- if (row.enabled !== '1') {
80
- return [
81
- <ut-button content={content} icon={icon} status={status} onTap={() => handleChild(row)} />
82
- ];
83
- }
84
- return [
85
- <>
86
- <div style="display: flex; justify-content: space-between;">
87
- <ut-button content={content} icon={icon} status={status} onTap={() => handleChild(row)} />
88
- <el-popover
89
- placement="left"
90
- v-slots={{
91
- reference: () => <el-button type="success">{t('message.btn.scan')}</el-button>
92
- }}
93
- >
94
- <>
95
- <SuQrcode text={baseURL + '/ufil/' + row.downloadUrl} />
96
- </>
97
- </el-popover>
98
- </div>
99
- </>
100
- // <el-popover
101
- // placement="left"
102
- // v-slots={{
103
- // reference: () => <el-button type="primary">外网下载</el-button>
104
- // }}
105
- // >
106
- // <>
107
- // <SuQrcode text={'http://jemes.uzuo.cn/gateway/ufil/' + row.downloadUrl} />
108
- // </>
109
- // </el-popover>
110
- ];
111
- }
112
- }
113
- }
114
- ];
115
-
116
- // 启用/禁用
117
- // async function handleClick({ row }) {
118
- // await to(getServiceApi().put(url, row));
119
- // xgrid.value.refreshData();
120
- // }
121
-
122
- /**
123
- * @param {*} row 数据源
124
- */
125
- const handleChild = async row => {
126
- const body = clone(row, true);
127
- body.enabled = row.enabled === '1' ? '0' : '1';
128
- await to(getServiceApi().put(url, body));
129
- xgrid.value.refreshData();
130
- };
131
-
132
- /**
133
- * @description:监听grid事件
134
- * @return {*}
135
- */
136
- const onButtonClick = code => {
137
- code === 'add' && handleAdd();
138
- code === 'del' && handleDel();
139
- };
140
-
141
- const items = [
142
- { field: 'appVersion', required: true },
143
- { field: 'buildNo', required: true },
144
- { field: 'versionInfo', required: true, itemRender: renderHook.renderTextarea() },
145
- {
146
- field: 'downloadUrl',
147
- required: false,
148
- itemRender: { name: '#upload', props: { baseUrl: baseURL } }
149
- }
150
- ];
151
-
152
- const showModalForm = ref(false);
153
-
154
- /**
155
- * @description: 添加
156
- */
157
- const handleAdd = () => {
158
- record.value = {};
159
- showModalForm.value = true;
160
- };
161
-
162
- const handleDel = () => {
163
- xgrid.value.getInstance().commitProxy('delete');
164
- };
165
-
166
- // const handleDownFile = row => {
167
- // clipboardRef.value = baseURL + '/ufil/' + row.downloadUrl;
168
- // successMessage('复制成功,快试试右键粘贴吧');
169
- // };
170
-
171
- // const buttons = [{ code: 'del', status: 'danger', icon: 'ri-delete-bin-line', auth: 'del' }];
172
-
173
- const onConfirm = () => {
174
- xgrid.value.refreshData();
175
- };
176
- </script>
1
+ <!--
2
+ * @Author: wei.li
3
+ * @Date: 2021-12-23 11:22:51
4
+ * @LastEditors: levi7754 levi7754@163.com
5
+ * @LastEditTime: 2025-08-16 18:01:55
6
+ * @Description: 托盘管理
7
+ -->
8
+
9
+ <template>
10
+ <div>
11
+ <ut-grid ref="xgrid" :columns="columns" :url="url" mode="form" @buttonClick="onButtonClick" />
12
+ <ut-modal-form
13
+ v-if="showModalForm"
14
+ :record="record"
15
+ :items="items"
16
+ :width="420"
17
+ :height="450"
18
+ :title="$t('message.title.appAdd')"
19
+ :url="url"
20
+ class="ut-app-form"
21
+ data-status="add"
22
+ @close="showModalForm = false"
23
+ @confirm="onConfirm"
24
+ />
25
+ </div>
26
+ </template>
27
+ <script lang="tsx">
28
+ export default { name: 'PdaApp' };
29
+ </script>
30
+ <script setup lang="tsx">
31
+ import { ref } from 'vue';
32
+ import { useI18n } from 'vue-i18n';
33
+ import to from 'await-to-js';
34
+ import { getBaseURL, getServiceApi } from '../../../api';
35
+ // import { useRender } from '../../../utils/udp/useRender';
36
+ import { useRender } from '@utogether/utils';
37
+ import { clone } from 'xe-utils';
38
+ import SuQrcode from '../../../components/SuQrcode';
39
+
40
+ const baseURL = getBaseURL();
41
+
42
+ const renderHook = useRender();
43
+
44
+ const { t } = useI18n();
45
+ const url = '/upms/v1/app-manage';
46
+ const xgrid = ref(null);
47
+ const record = ref({});
48
+
49
+ // const formItems = [
50
+ // { field: 'organizationName', itemRender: renderHook.renderInvOrg() },
51
+ // { field: 'trayTypeCode', itemRender: renderHook.renderDict('SU.TRAY.TYPE') },
52
+ // { field: 'trayCode' },
53
+ // { field: 'materialCode' },
54
+ // { field: 'materialName' },
55
+ // { field: 'packCode', title: 'message.boxSignCode' }
56
+ // ];
57
+
58
+ // 列字段
59
+ const columns = [
60
+ { type: 'checkbox', width: 45, align: 'center' },
61
+ { field: 'appVersion', title: 'message.udp.appVersion', width: 110 },
62
+ { field: 'buildNo', title: 'message.udp.buildNo', width: 130 },
63
+ {
64
+ field: 'isForceUpdate',
65
+ title: 'message.udp.isForceUpdate',
66
+ width: 130,
67
+ formatter: ({ row }) => (row.isForceUpdate === 'Y' ? t('message.udp.forceUpdate') : t('message.udp.freeUpdate'))
68
+ },
69
+ { field: 'versionInfo', title: 'message.udp.versionInfo', miWidth: 200 },
70
+ {
71
+ field: 'enabled',
72
+ title: 'message.status',
73
+ width: 90,
74
+ formatter: ({ row }) => (row.enabled === '1' ? t('message.appupper') : t('message.applower'))
75
+ },
76
+ { field: 'creationDate', width: 140 },
77
+ {
78
+ field: 'operate',
79
+ width: 260,
80
+ fixed: 'right',
81
+ slots: {
82
+ default: ({ row }) => {
83
+ const content = row.enabled === '1' ? 'applower' : 'appupper';
84
+ const status = row.enabled === '1' ? 'warning' : 'primary';
85
+ const icon = row.enabled === '1' ? 'ri-inbox-archive-line' : 'ri-inbox-unarchive-line';
86
+ if (row.enabled !== '1') {
87
+ return [<ut-button content={content} icon={icon} status={status} onTap={() => handleChild(row)} />];
88
+ }
89
+ return [
90
+ <>
91
+ <div style="display: flex; justify-content: space-between;">
92
+ <ut-button content={content} icon={icon} status={status} onTap={() => handleChild(row)} />
93
+ <el-popover
94
+ placement="left"
95
+ v-slots={{
96
+ reference: () => <el-button type="success">{t('message.btn.scan')}</el-button>
97
+ }}
98
+ >
99
+ <>
100
+ <SuQrcode text={baseURL + '/ufil/' + row.downloadUrl} />
101
+ </>
102
+ </el-popover>
103
+ </div>
104
+ </>
105
+ // <el-popover
106
+ // placement="left"
107
+ // v-slots={{
108
+ // reference: () => <el-button type="primary">外网下载</el-button>
109
+ // }}
110
+ // >
111
+ // <>
112
+ // <SuQrcode text={'http://jemes.uzuo.cn/gateway/ufil/' + row.downloadUrl} />
113
+ // </>
114
+ // </el-popover>
115
+ ];
116
+ }
117
+ }
118
+ }
119
+ ];
120
+
121
+ // 启用/禁用
122
+ // async function handleClick({ row }) {
123
+ // await to(getServiceApi().put(url, row));
124
+ // xgrid.value.refreshData();
125
+ // }
126
+
127
+ /**
128
+ * @param {*} row 数据源
129
+ */
130
+ const handleChild = async row => {
131
+ const body = clone(row, true);
132
+ body.enabled = row.enabled === '1' ? '0' : '1';
133
+ await to(getServiceApi().put(url, body));
134
+ xgrid.value.refreshData();
135
+ };
136
+
137
+ /**
138
+ * @description:监听grid事件
139
+ * @return {*}
140
+ */
141
+ const onButtonClick = code => {
142
+ code === 'add' && handleAdd();
143
+ code === 'del' && handleDel();
144
+ };
145
+
146
+ const items = [
147
+ { field: 'appVersion', title: 'message.udp.appVersion', required: true },
148
+ { field: 'buildNo', title: 'message.udp.buildNo', required: true },
149
+ {
150
+ field: 'isForceUpdate',
151
+ title: 'message.udp.isForceUpdate',
152
+ required: true,
153
+ itemRender: renderHook.renderSwitch({
154
+ openLabel: t('message.udp.forceUpdate'),
155
+ closeLabel: t('message.udp.freeUpdate'),
156
+ openValue: 'Y',
157
+ closeValue: 'N'
158
+ })
159
+ },
160
+ {
161
+ field: 'versionInfo',
162
+ title: 'message.udp.versionInfo',
163
+ required: true,
164
+ itemRender: renderHook.renderTextarea()
165
+ },
166
+ {
167
+ field: 'downloadUrl',
168
+ required: false,
169
+ title: 'message.udp.downloadUrl',
170
+ itemRender: renderHook.renderUpload()
171
+ }
172
+ ];
173
+
174
+ const showModalForm = ref(false);
175
+
176
+ /**
177
+ * @description: 添加
178
+ */
179
+ const handleAdd = () => {
180
+ record.value = {
181
+ // downloadUrl: 'https://vxeui.com/resource/img/fj577.jpg'
182
+ // downloadUrl: '/resource/image/20250817/15806d21e3f445dcae0e2e0825c76a79.jpg'
183
+ };
184
+ showModalForm.value = true;
185
+ };
186
+
187
+ const handleDel = () => {
188
+ xgrid.value.getInstance().commitProxy('delete');
189
+ };
190
+
191
+ // const handleDownFile = row => {
192
+ // clipboardRef.value = baseURL + '/ufil/' + row.downloadUrl;
193
+ // successMessage('复制成功,快试试右键粘贴吧');
194
+ // };
195
+
196
+ // const buttons = [{ code: 'del', status: 'danger', icon: 'ri-delete-bin-line', auth: 'del' }];
197
+
198
+ const onConfirm = () => {
199
+ xgrid.value.refreshData();
200
+ };
201
+ </script>
202
+ <style lang="scss" scoped>
203
+ .ut-app-form {
204
+ ::v-deep(.vxe-switch--label) {
205
+ width: 100%;
206
+ }
207
+ }
208
+ </style>
@@ -1,106 +1,118 @@
1
- <!--
2
- * @Author: wei.li
3
- * @Date: 2021-12-23 17:33:21
4
- * @LastEditors: levi7754 levi7754@163.com
5
- * @LastEditTime: 2025-07-16 15:26:43
6
- * @Description: 数据字典
7
- -->
8
- <template>
9
- <div>
10
- <ut-grid
11
- ref="xgrid"
12
- :items="formItems"
13
- :columns="columns"
14
- url="/upfm/v1/lov"
15
- :events="onGridEvents"
16
- />
17
- <child-view v-if="shouDrawer" :show="shouDrawer" :record="record" @onClose="handleClose" />
18
- </div>
19
- </template>
20
-
21
- <script lang="tsx">
22
- export default { name: 'DictView' };
23
- </script>
24
- <script setup lang="tsx">
25
- import { ref, nextTick } from 'vue';
26
- import childView from './childView.vue';
27
- import { useRender } from '@utogether/utils';
28
-
29
- const xgrid = ref(null);
30
- // const renderOption = useRenderOption();
31
-
32
- const formItems = [
33
- { field: 'dictCode', title: 'message.udp.dictCode' },
34
- { field: 'dictName', title: 'message.udp.dictName' },
35
- { field: 'dictType', title: 'message.udp.dictType' }
36
- ];
37
-
38
- const renderHook = useRender();
39
- // 列字段
40
- const columns = [
41
- { type: 'checkbox', width: 40, align: 'center' },
42
- {
43
- field: 'dictCode',
44
- title: 'message.udp.dictCode',
45
- required: true,
46
- editRender: renderHook.renderInput()
47
- },
48
- {
49
- field: 'dictName',
50
- title: 'message.udp.dictName',
51
- required: true,
52
- editRender: renderHook.renderInput()
53
- },
54
- {
55
- field: 'dictType',
56
- title: 'message.udp.dictType',
57
- required: true,
58
- editRender: renderHook.renderDict('SU.DICT.TYPE'),
59
- formatter: ['formatDict', 'SU.DICT.TYPE']
60
- },
61
- { field: 'dictDesc', title: 'message.remark', editRender: renderHook.renderInput() },
62
- {
63
- field: 'enabled',
64
- width: 90,
65
- editRender: renderHook.renderDict({ code: 'SU.ENABLE', defaultValue: '1' }),
66
- formatter: ['formatDict', 'SU.ENABLE']
67
- },
68
- {
69
- field: 'operate',
70
- width: 80,
71
- slots: {
72
- default: ({ row }) => {
73
- if (!row.id) return null;
74
- return [<ut-button content="lov" onClick={() => hanldeDipose(row)} />];
75
- }
76
- }
77
- }
78
- ];
79
-
80
- const shouDrawer = ref(false);
81
- const record = ref(null);
82
- const hanldeDipose = row => {
83
- nextTick(() => {
84
- shouDrawer.value = true;
85
- record.value = row;
86
- record.value.total = row.children?.length;
87
- });
88
- };
89
- const handleClose = () => {
90
- xgrid.value.refreshData();
91
- shouDrawer.value = false;
92
- };
93
-
94
- const onGridEvents = {
95
- editActived({ row }) {
96
- columns[1].editRender.props.disabled = !!row.id;
97
- }
98
- };
99
-
100
- // function onChange(e) {
101
- // console.log('onChange', e);
102
- // }
103
- // function onFocus(e) {
104
- // console.log('onFocus', e);
105
- // }
106
- </script>
1
+ <!--
2
+ * @Author: wei.li
3
+ * @Date: 2021-12-23 17:33:21
4
+ * @LastEditors: levi7754 levi7754@163.com
5
+ * @LastEditTime: 2025-07-24 10:16:17
6
+ * @Description: 数据字典
7
+ -->
8
+ <template>
9
+ <div>
10
+ <ut-grid
11
+ ref="xgrid"
12
+ :items="formItems"
13
+ :columns="columns"
14
+ :check-method="checkMethod"
15
+ :events="onGridEvents"
16
+ url="/upfm/v1/lov"
17
+ />
18
+ <child-view v-if="shouDrawer" :show="shouDrawer" :record="record" @onClose="handleClose" />
19
+ </div>
20
+ </template>
21
+
22
+ <script lang="tsx">
23
+ export default { name: 'DictView' };
24
+ </script>
25
+ <script setup lang="tsx">
26
+ import { ref, nextTick } from 'vue';
27
+ import childView from './childView.vue';
28
+ import { useRender } from '@utogether/utils';
29
+ // import { useRender } from '../../../utils/udp/useRender';
30
+
31
+ const xgrid = ref(null);
32
+ // const renderOption = useRenderOption();
33
+
34
+ const formItems = [
35
+ { field: 'dictCode', title: 'message.udp.dictCode' },
36
+ { field: 'dictName', title: 'message.udp.dictName' },
37
+ { field: 'dictType', title: 'message.udp.dictType', code: 'SU.DICT.TYPE' }
38
+ ];
39
+
40
+ const renderHook = useRender();
41
+ // 列字段
42
+ const columns = [
43
+ { type: 'checkbox', width: 40, align: 'center' },
44
+
45
+ {
46
+ field: 'dictCode',
47
+ title: 'message.udp.dictCode',
48
+ required: true,
49
+ editRender: renderHook.renderInput()
50
+ },
51
+ {
52
+ field: 'dictName',
53
+ title: 'message.udp.dictName',
54
+ required: true,
55
+ editRender: renderHook.renderInput()
56
+ },
57
+ // {
58
+ // field: 'userName',
59
+ // width: 300,
60
+ // editRender: renderHook.renderUpload()
61
+ // },
62
+ {
63
+ field: 'dictType',
64
+ title: 'message.udp.dictType',
65
+ required: true,
66
+ editRender: renderHook.renderDict('SU.DICT.TYPE'),
67
+ formatter: ['formatDict', 'SU.DICT.TYPE']
68
+ },
69
+ { field: 'dictDesc', title: 'message.remark', editRender: renderHook.renderInput() },
70
+ {
71
+ field: 'enabled',
72
+ width: 90,
73
+ editRender: renderHook.renderDict({ code: 'SU.ENABLE', defaultValue: '1' }),
74
+ formatter: ['formatDict', 'SU.ENABLE']
75
+ },
76
+ {
77
+ field: 'operate',
78
+ width: 80,
79
+ slots: {
80
+ default: ({ row }) => {
81
+ if (!row.id) return null;
82
+ return [<ut-button content="lov" onClick={() => hanldeDipose(row)} />];
83
+ }
84
+ }
85
+ }
86
+ ];
87
+
88
+ const shouDrawer = ref(false);
89
+ const record = ref(null);
90
+ const hanldeDipose = row => {
91
+ nextTick(() => {
92
+ shouDrawer.value = true;
93
+ record.value = row;
94
+ record.value.total = row.children?.length;
95
+ });
96
+ };
97
+ const handleClose = () => {
98
+ xgrid.value.refreshData();
99
+ shouDrawer.value = false;
100
+ };
101
+
102
+ const onGridEvents = {
103
+ editActived({ row }) {
104
+ columns[1].editRender.props.disabled = !!row.id;
105
+ }
106
+ };
107
+
108
+ // function onChange(e) {
109
+ // console.log('onChange', e);
110
+ // }
111
+ // function onFocus(e) {
112
+ // console.log('onFocus', e);
113
+ // }
114
+
115
+ const checkMethod = row => {
116
+ return row.dictType !== '0';
117
+ };
118
+ </script>
@@ -46,12 +46,7 @@
46
46
  <template #default="{ row }">
47
47
  <ut-button status="primary" content="edit" @tap="onEdit(row)" />
48
48
  <ut-button status="warning" content="delete" @tap="onDel(row)" />
49
- <ut-button
50
- status="success"
51
- content="add"
52
- :disabled="row.enabled !== '1'"
53
- @tap="onChildren(row)"
54
- />
49
+ <ut-button status="success" content="add" :disabled="row.enabled !== '1'" @tap="onChildren(row)" />
55
50
  </template>
56
51
  </vxe-table-column>
57
52
  </vxe-table>
@@ -110,6 +105,7 @@ const showModal = ref(false);
110
105
  const subRecord = ref<IRecord>({});
111
106
  const temp = ref<IRecord>({});
112
107
  const modalType = ref('add');
108
+
113
109
  const subItems = [
114
110
  { field: 'dictCode', title: 'message.udp.dictCode', required: true },
115
111
  { field: 'dictName', title: 'message.udp.dictName', required: true },
@@ -179,7 +175,11 @@ const onConfirm = async () => {
179
175
  loading.value = false;
180
176
  if (!err) {
181
177
  console.log({ res });
182
- showModal.value = false;
178
+ if (modalType.value === 'edit') {
179
+ showModal.value = false;
180
+ } else {
181
+ subRecord.value = { enabled: '1' };
182
+ }
183
183
  successMessage();
184
184
  getDict();
185
185
  }