@utogether/udp-core 1.0.1-beta.2 → 1.0.1-beta.4

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 (98) hide show
  1. package/build/plugins.ts +6 -1
  2. package/dist/{403-BBQoJwTM.js → 403-CT4J-t-o.js} +1 -1
  3. package/dist/{404-BbJPSIWM.js → 404-BAudfnaK.js} +1 -1
  4. package/dist/{500-BtFL9R4M.js → 500-BlOGtpEE.js} +1 -1
  5. package/dist/{AuthorityInfo-DhiwCeLN.js → AuthorityInfo-Bl03tEhF.js} +1 -1
  6. package/dist/{AuthorityInfo.vue_vue_type_style_index_0_lang-Duyweh89.js → AuthorityInfo.vue_vue_type_style_index_0_lang-CUwS2F3R.js} +1 -1
  7. package/dist/{Company-CGqmslx-.js → Company-CIj9XgQn.js} +3 -3
  8. package/dist/{CompanyPanel-hlDsxD-6.js → CompanyPanel-CublK5NN.js} +16 -16
  9. package/dist/{Department-BZyJtacc.js → Department-BolPW-W3.js} +3 -3
  10. package/dist/{DepartmentPanel-D-a_EBFt.js → DepartmentPanel-BttxSHfM.js} +1 -1
  11. package/dist/{DesignPanel-Bl4luWDV.js → DesignPanel-BwCbn92O.js} +1 -1
  12. package/dist/{DesignPanel.vue_vue_type_style_index_0_lang-I8C3iGvz.js → DesignPanel.vue_vue_type_style_index_0_lang-y2AnCTg6.js} +2 -2
  13. package/dist/{DictView-B4a7Hs1X.js → DictView-D85ziNV2.js} +13 -12
  14. package/dist/InvOrganization-CaAk_f7F.js +66 -0
  15. package/dist/{Org-BTGTrAVz.js → Org-CreIihFE.js} +1 -1
  16. package/dist/{Preview-pHD84xqI.js → Preview-DMGbhV6q.js} +1 -1
  17. package/dist/{ReportDefine-DnnCNQWS.js → ReportDefine-DogZwa8T.js} +1 -1
  18. package/dist/{ReportDesign-BnI_Q4pg.js → ReportDesign-CdSsJJeA.js} +2 -2
  19. package/dist/{ReportQuery-Dby2MmtM.js → ReportQuery-DPvKqeUm.js} +1 -1
  20. package/dist/{ReportQueryFrom-Blm1N8P1.js → ReportQueryFrom-UokkfBx_.js} +1 -1
  21. package/dist/{ReportQueryFrom.vue_vue_type_style_index_0_lang-CnG_Ybnt.js → ReportQueryFrom.vue_vue_type_style_index_0_lang-BlOoThY7.js} +1 -1
  22. package/dist/{ReportTemplate-D65RXRY_.js → ReportTemplate-DCnmllXW.js} +1 -1
  23. package/dist/{Role-eFZoTpXc.js → Role-sfmwLiNM.js} +3 -3
  24. package/dist/{RoleAssign-D9-Y3UNz.js → RoleAssign-WRk90VO2.js} +3 -3
  25. package/dist/{RolePanel-DlFw6HSf.js → RolePanel-DhP0_5ur.js} +1 -1
  26. package/dist/{RolePanel-CoUOc3sX.js → RolePanel-iWysS02n.js} +1 -1
  27. package/dist/{RolePanel.vue_vue_type_script_setup_true_lang-DKHgNWQP.js → RolePanel.vue_vue_type_script_setup_true_lang-CYXqW-d4.js} +1 -1
  28. package/dist/{RolePanel.vue_vue_type_script_setup_true_lang-Clwk-MHw.js → RolePanel.vue_vue_type_script_setup_true_lang-_hVY31HC.js} +3 -3
  29. package/dist/{ScrollPanel.vue_vue_type_style_index_0_lang-M2FQJwPU.js → ScrollPanel.vue_vue_type_style_index_0_lang-BozDFES-.js} +1 -1
  30. package/dist/{Staff-DFBLCsAd.js → Staff-Bha-Ijax.js} +3 -3
  31. package/dist/{StaffInfo-d2CK0oBA.js → StaffInfo-CbfYI8UW.js} +1 -1
  32. package/dist/{StaffInfo.vue_vue_type_script_setup_true_lang-4m8wK9tq.js → StaffInfo.vue_vue_type_script_setup_true_lang-Ce-MUVYH.js} +1 -1
  33. package/dist/{StaffPanel-D6aWLKN3.js → StaffPanel-B8094e97.js} +1 -1
  34. package/dist/{StaffPanel.vue_vue_type_script_setup_true_lang-C7YT2CVb.js → StaffPanel.vue_vue_type_script_setup_true_lang-_kJIBCtx.js} +2 -2
  35. package/dist/{SysUser-BdZvYxQH.js → SysUser-D1J9vPnb.js} +2 -2
  36. package/dist/{SysUserPanel-BIVa6LLr.js → SysUserPanel-DGDPKKoY.js} +1 -1
  37. package/dist/{SysUserPanel.vue_vue_type_script_setup_true_lang-BsBKpYR7.js → SysUserPanel.vue_vue_type_script_setup_true_lang-D-5-zKn6.js} +1 -1
  38. package/dist/{SystemMenu-C-5VKlHK.js → SystemMenu-Dz8Pllh5.js} +9 -9
  39. package/dist/{UserInfo-DqXCRZts.js → UserInfo-ecAJA2Yg.js} +1 -1
  40. package/dist/{UserInfo.vue_vue_type_style_index_0_lang-N3TwfpPx.js → UserInfo.vue_vue_type_style_index_0_lang-4_-I_sQN.js} +1 -1
  41. package/dist/{childView-B2lSsqS3.js → childView-4uI_RT2m.js} +1 -1
  42. package/dist/{childView-DRUNqgjI.js → childView-OXXoMFg3.js} +1 -1
  43. package/dist/{childView.vue_vue_type_style_index_0_lang-oGriyFTv.js → childView.vue_vue_type_style_index_0_lang-DC-yx4Kv.js} +1 -1
  44. package/dist/{childView.vue_vue_type_style_index_0_lang-B9XBDDU_.js → childView.vue_vue_type_style_index_0_lang-e43PUsUO.js} +1 -1
  45. package/dist/{code-rule-DZC9T6cl.js → code-rule-B667R66s.js} +1 -1
  46. package/dist/core.es.js +14 -11
  47. package/dist/{cron-task-BJwPeA5F.js → cron-task-DcmGSr2D.js} +1 -1
  48. package/dist/{frameView-C6wkvok-.js → frameView-BzgaLYjQ.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-DZc3qRTx.js → index-CLliRySq.js} +516 -560
  53. package/dist/{layoutView-CeJBpZb_.js → layoutView-BBQB8pDc.js} +109 -108
  54. package/dist/{login-BOxwzwdB.js → login-DIG7pRU7.js} +2 -2
  55. package/dist/{lov-view-DRF-99U4.js → lov-view-CSIPKZSY.js} +2 -2
  56. package/dist/{menuInfo-3Sjvs9nM.js → menuInfo-CPHjl7id.js} +1 -1
  57. package/dist/{menuInfo.vue_vue_type_style_index_0_lang-DrQ560nm.js → menuInfo.vue_vue_type_style_index_0_lang-BXNiinTg.js} +31 -29
  58. package/dist/{pda-app-B9tn7jdv.js → pda-app-BLjbMcdt.js} +1 -1
  59. package/dist/{resource-BqnxbQNe.js → resource-MxqaSJqB.js} +1 -1
  60. package/dist/{su-welcome-VwifUK_O.js → su-welcome-C0flTYCx.js} +1 -1
  61. package/dist/{sys-config-C0-gSBFO.js → sys-config-CXzGs3Nl.js} +1 -1
  62. package/dist/udp-core.css +2 -2
  63. package/dist/{utogether-Di1byIum.js → utogether-CFdIDuAT.js} +1 -1
  64. package/index.ts +40 -36
  65. package/package.json +1 -1
  66. package/src/App.vue +70 -70
  67. package/src/components/udp/grid.vue +505 -0
  68. package/src/components/udp/index.ts +7 -4
  69. package/src/components/udp/lov.vue +410 -0
  70. package/src/components/udp/modal-form.vue +2 -2
  71. package/src/components/udp/modal-grid.vue +297 -0
  72. package/src/components/udp/utils.ts +379 -40
  73. package/src/directives/permission/index.ts +1 -1
  74. package/src/layout/components/lay-navbar/index.vue +1 -1
  75. package/src/layout/components/lay-panel/index.vue +150 -150
  76. package/src/layout/components/lay-sidebar/breadCrumb.vue +1 -1
  77. package/src/layout/components/lay-tag/index.vue +625 -625
  78. package/src/layout/layoutView.vue +215 -215
  79. package/src/main.ts +7 -6
  80. package/src/plugins/i18n/en.ts +291 -289
  81. package/src/plugins/i18n/zh.ts +338 -337
  82. package/src/plugins/vxe-table/index.ts +1 -1
  83. package/src/plugins/vxe-table/render.tsx +4 -2
  84. package/src/router/index.ts +187 -183
  85. package/src/router/modules/remaining.ts +58 -83
  86. package/src/style/button.scss +85 -78
  87. package/src/style/tailwind.css +1 -68
  88. package/src/style/vxetable.scss +265 -256
  89. package/src/utils/authority/index.ts +1 -1
  90. package/src/views/organization/company/CompanyPanel.vue +259 -259
  91. package/src/views/organization/inv-org/InvOrganization.vue +2 -3
  92. package/src/views/system/menu/SystemMenu.vue +1 -1
  93. package/src/views/system/menu/menuInfo.vue +376 -373
  94. package/src/views/udev/dict/DictView.vue +106 -106
  95. package/src/views/udev/lov/lov-view.vue +91 -91
  96. package/types/global.d.ts +2 -1
  97. package/vite.config.ts +4 -1
  98. package/dist/InvOrganization-q4T3y8dQ.js +0 -260
@@ -1,259 +1,259 @@
1
- <!--
2
- * @Author: wei.li
3
- * @Date: 2021-11-19 21:14:41
4
- * @LastEditors: levi7754 levi7754@163.com
5
- * @LastEditTime: 2025-04-08 15:48:36
6
- * @Description: 租户管理
7
- -->
8
-
9
- <template>
10
- <div class="page-content">
11
- <!-- 工具栏 -->
12
- <vxe-toolbar perfect class="">
13
- <template #buttons>
14
- <ut-button status="u-cyan" icon="ri-add-line" content="add" @tap="handleAdd()" />
15
- <ut-button status="primary" icon="ri-edit-box-line" content="edit" @tap="handleEdit('update')" />
16
- <ut-button status="danger" icon="ri-close-fill" content="delete" @tap="handleDelete()" />
17
- </template>
18
- </vxe-toolbar>
19
- <el-row
20
- v-if="data.dialogFormVisible"
21
- type="flex"
22
- justify="center"
23
- align="middle"
24
- class="w-departInfo-wrapper"
25
- >
26
- <el-card width="60%" shadow="always" class="box-card w-card-wrapper">
27
- <div class="clearfix">
28
- <span class="w-card-title" />
29
- </div>
30
- <el-row>
31
- <vxe-form ref="xForm" :data="data.record" :rules="rules" label-width="80px">
32
- <vxe-form-item
33
- :title="$t('message.udp.unitName')"
34
- field="unitName"
35
- :item-render="{ name: '$input', props: { disabled: data.dataStatus === 'detail' } }"
36
- :span="24"
37
- />
38
- <vxe-form-item
39
- :title="$t('message.udp.unitCode')"
40
- field="unitCode"
41
- :item-render="{ name: '$input', props: { disabled: data.dataStatus !== 'add' } }"
42
- :span="24"
43
- />
44
- <vxe-form-item
45
- :title="$t('message.udp.unitNote')"
46
- field="unitNote"
47
- :item-render="{ name: '$input', props: { disabled: data.dataStatus === 'detail' } }"
48
- :span="24"
49
- />
50
- </vxe-form>
51
- </el-row>
52
- <el-row type="flex" justify="center">
53
- <vxe-checkbox
54
- v-if="data.dataStatus === 'add'"
55
- v-model="data.isChecked"
56
- style="padding-top: 5px; margin-right: 8px"
57
- >{{ $t('message.udp.continueAdd') }}</vxe-checkbox
58
- >
59
- <vxe-button
60
- v-if="data.dataStatus !== 'detail'"
61
- status="primary"
62
- :content="$t('message.btn.confirm')"
63
- @click="handleComfirm"
64
- />
65
- <vxe-button
66
- v-if="data.dataStatus !== 'detail'"
67
- status="warning"
68
- :content="$t('message.btn.cancel')"
69
- @click="handleCancle"
70
- />
71
- </el-row>
72
- </el-card>
73
- </el-row>
74
- <el-row v-else class="w-noclick-wrapper">
75
- <!-- <span class="w-department-header">{{ $t('setting.deartment.organization') }}</span> -->
76
- <div class="w-content-wrapper">
77
- <ul>
78
- <li class="w-department-line">
79
- <div>● 点击新建,新建租户信息。</div>
80
- <div style="margin: 0; text-indent: 2em">
81
- 已点击树结构上的租户名称,默认创建为当前租户的下属租户
82
- </div>
83
- <div style="margin: 0; text-indent: 2em">未点击树结构上的租户名称,则创建为一级租户</div>
84
- </li>
85
- <li class="w-department-line">● 点击树结构上的租户名称,点击修改按钮,修改租户信息。</li>
86
- <li class="w-department-line">
87
- <div>● 点击树结构上的租户名称,点击删除按钮,删除租户信息。</div>
88
- <div style="text-indent: 2em">当租户下有单位存在时,不允许删除租户信息。</div>
89
- </li>
90
- </ul>
91
- </div>
92
- </el-row>
93
- </div>
94
- </template>
95
-
96
- <script setup lang="ts">
97
- import { useI18n } from 'vue-i18n';
98
- import { reactive, watch, inject } from 'vue';
99
- import { VxeUI, VxeFormPropTypes } from 'vxe-table';
100
- import { templateRef } from '@vueuse/core';
101
- import { clone } from 'xe-utils';
102
- import { successMessage, warnMessage } from '@utogether/utils';
103
- import { getServiceApi } from '../../../api';
104
-
105
- const data = reactive<IRecord>({
106
- record: {},
107
- dataList: [],
108
- submitLoading: false,
109
- dialogFormVisible: false,
110
- isChecked: false,
111
- dataStatus: ''
112
- });
113
- const { t } = useI18n();
114
- const rules: VxeFormPropTypes.Rules = {
115
- unitName: [
116
- {
117
- required: true,
118
- message: `${t('message.required')}${t('message.udp.unitName')}`
119
- }
120
- ],
121
- unitCode: [
122
- {
123
- required: true,
124
- message: `${t('message.required')}${t('message.udp.unitCode')}`
125
- }
126
- ]
127
- };
128
-
129
- const active: IRecord = inject('active');
130
- const scrollPanelChange: IRecord = inject('scrollPanelChange');
131
-
132
- const serviceApi = getServiceApi();
133
- const url = '/uums/unit';
134
-
135
- watch(
136
- () => active.value,
137
- (newVal, oldVal) => {
138
- data.record = active.value;
139
- newVal?.id && oldVal?.id && newVal !== oldVal && handleEdit('detail');
140
- }
141
- );
142
-
143
- // 新增子类型
144
- const handleAdd = () => {
145
- data.dataStatus = 'add';
146
- data.record = {};
147
- data.record.parentId = active.value?.id;
148
- data.isChecked = false;
149
- data.dialogFormVisible = true;
150
- };
151
- // 编辑
152
- const handleEdit = dataStatus => {
153
- data.dataStatus = dataStatus;
154
- data.record = clone(active.value, true);
155
- data.dialogFormVisible = true;
156
- };
157
-
158
- const xForm = templateRef<any>('xForm', null);
159
- const handleComfirm = () => {
160
- xForm.value.validate(async valid => {
161
- if (!valid) {
162
- const { record, dataStatus } = data;
163
- if (dataStatus === 'add') {
164
- await serviceApi.post(url, record);
165
- } else {
166
- await serviceApi.put(url, record);
167
- }
168
- actionComplete();
169
- }
170
- });
171
- };
172
-
173
- const handleDelete = async () => {
174
- const { record } = data;
175
- if (record.children?.length) return warnMessage(t('message.deletePartment'));
176
- const type = await VxeUI.modal.confirm(t('message.tip.del', { msg: 'aaaaa' }));
177
- if (type === 'confirm') {
178
- await serviceApi.delete(url, record);
179
- actionComplete();
180
- }
181
- };
182
-
183
- const actionComplete = () => {
184
- scrollPanelChange.value = true;
185
- successMessage(t('message.operateSuccess'));
186
- handleClose();
187
- };
188
-
189
- const handleCancle = () => {
190
- data.dialogFormVisible = false;
191
- data.dataStatus = '';
192
- };
193
-
194
- const handleClose = () => {
195
- data.dialogFormVisible = false;
196
- };
197
- </script>
198
- <style lang="scss" scoped>
199
- .page-content {
200
- background-color: #fff;
201
-
202
- .w-departInfo-wrapper {
203
- width: 96%;
204
- height: 75vh;
205
-
206
- .w-card-wrapper {
207
- width: 40%;
208
-
209
- .el-card__header {
210
- padding: 10px 20px;
211
-
212
- .w-card-title {
213
- position: relative;
214
- top: 5px;
215
- }
216
- }
217
- }
218
-
219
- .el-form-item {
220
- margin-bottom: 12px;
221
- }
222
- }
223
-
224
- .w-noclick-wrapper {
225
- display: flex;
226
- flex-wrap: wrap;
227
- align-items: center;
228
- justify-content: center;
229
- height: 100%;
230
-
231
- .w-content-wrapper {
232
- display: flex;
233
- align-items: center;
234
- justify-content: center;
235
- height: 75vh;
236
-
237
- ul {
238
- padding: 24px;
239
- border: 1px solid #ccc;
240
- border-radius: 10px;
241
- }
242
- }
243
-
244
- .w-department-header {
245
- padding-right: 20px;
246
- font-size: 26px;
247
- font-weight: bolder;
248
- color: #69c;
249
- }
250
-
251
- .w-department-line {
252
- font-size: 16px;
253
- line-height: 35px;
254
- color: #999;
255
- list-style: none;
256
- }
257
- }
258
- }
259
- </style>
1
+ <!--
2
+ * @Author: wei.li
3
+ * @Date: 2021-11-19 21:14:41
4
+ * @LastEditors: levi7754 levi7754@163.com
5
+ * @LastEditTime: 2025-04-08 15:48:36
6
+ * @Description: 租户管理
7
+ -->
8
+
9
+ <template>
10
+ <div class="page-content">
11
+ <!-- 工具栏 -->
12
+ <vxe-toolbar perfect class="">
13
+ <template #buttons>
14
+ <ut-button status="u-cyan" icon="ri-add-line" content="add" @tap="handleAdd()" />
15
+ <ut-button status="primary" icon="ri-edit-box-line" content="edit" @tap="handleEdit('update')" />
16
+ <ut-button status="danger" icon="ri-close-fill" content="delete" @tap="handleDelete()" />
17
+ </template>
18
+ </vxe-toolbar>
19
+ <el-row
20
+ v-if="data.dialogFormVisible"
21
+ type="flex"
22
+ justify="center"
23
+ align="middle"
24
+ class="w-departInfo-wrapper"
25
+ >
26
+ <el-card width="60%" shadow="always" class="box-card w-card-wrapper">
27
+ <div class="clearfix">
28
+ <span class="w-card-title" />
29
+ </div>
30
+ <el-row>
31
+ <vxe-form ref="xForm" :data="data.record" :rules="rules" label-width="80px">
32
+ <vxe-form-item
33
+ :title="$t('message.udp.unitName')"
34
+ field="unitName"
35
+ :item-render="{ name: '$input', props: { disabled: data.dataStatus === 'detail' } }"
36
+ :span="24"
37
+ />
38
+ <vxe-form-item
39
+ :title="$t('message.udp.unitCode')"
40
+ field="unitCode"
41
+ :item-render="{ name: '$input', props: { disabled: data.dataStatus !== 'add' } }"
42
+ :span="24"
43
+ />
44
+ <vxe-form-item
45
+ :title="$t('message.udp.unitNote')"
46
+ field="unitNote"
47
+ :item-render="{ name: '$input', props: { disabled: data.dataStatus === 'detail' } }"
48
+ :span="24"
49
+ />
50
+ </vxe-form>
51
+ </el-row>
52
+ <el-row type="flex" justify="center">
53
+ <vxe-checkbox
54
+ v-if="data.dataStatus === 'add'"
55
+ v-model="data.isChecked"
56
+ style="padding-top: 5px; margin-right: 8px"
57
+ >{{ $t('message.udp.continueAdd') }}</vxe-checkbox
58
+ >
59
+ <vxe-button
60
+ v-if="data.dataStatus !== 'detail'"
61
+ status="primary"
62
+ :content="$t('message.btn.confirm')"
63
+ @click="handleComfirm"
64
+ />
65
+ <vxe-button
66
+ v-if="data.dataStatus !== 'detail'"
67
+ status="warning"
68
+ :content="$t('message.btn.cancel')"
69
+ @click="handleCancle"
70
+ />
71
+ </el-row>
72
+ </el-card>
73
+ </el-row>
74
+ <el-row v-else class="w-noclick-wrapper">
75
+ <!-- <span class="w-department-header">{{ $t('setting.deartment.organization') }}</span> -->
76
+ <div class="w-content-wrapper">
77
+ <ul>
78
+ <li class="w-department-line">
79
+ <div>● 点击新建,新建租户信息。</div>
80
+ <div style="margin: 0; text-indent: 2em">
81
+ 已点击树结构上的租户名称,默认创建为当前租户的下属租户
82
+ </div>
83
+ <div style="margin: 0; text-indent: 2em">未点击树结构上的租户名称,则创建为一级租户</div>
84
+ </li>
85
+ <li class="w-department-line">● 点击树结构上的租户名称,点击修改按钮,修改租户信息。</li>
86
+ <li class="w-department-line">
87
+ <div>● 点击树结构上的租户名称,点击删除按钮,删除租户信息。</div>
88
+ <div style="text-indent: 2em">当租户下有单位存在时,不允许删除租户信息。</div>
89
+ </li>
90
+ </ul>
91
+ </div>
92
+ </el-row>
93
+ </div>
94
+ </template>
95
+
96
+ <script setup lang="ts">
97
+ import { useI18n } from 'vue-i18n';
98
+ import { reactive, watch, inject } from 'vue';
99
+ import { VxeUI } from 'vxe-table';
100
+ import { templateRef } from '@vueuse/core';
101
+ import { clone } from 'xe-utils';
102
+ import { successMessage, warnMessage } from '@utogether/utils';
103
+ import { getServiceApi } from '../../../api';
104
+
105
+ const data = reactive<IRecord>({
106
+ record: {},
107
+ dataList: [],
108
+ submitLoading: false,
109
+ dialogFormVisible: false,
110
+ isChecked: false,
111
+ dataStatus: ''
112
+ });
113
+ const { t } = useI18n();
114
+ const rules = {
115
+ unitName: [
116
+ {
117
+ required: true,
118
+ message: `${t('message.required')}${t('message.udp.unitName')}`
119
+ }
120
+ ],
121
+ unitCode: [
122
+ {
123
+ required: true,
124
+ message: `${t('message.required')}${t('message.udp.unitCode')}`
125
+ }
126
+ ]
127
+ };
128
+
129
+ const active: IRecord = inject('active');
130
+ const scrollPanelChange: IRecord = inject('scrollPanelChange');
131
+
132
+ const serviceApi = getServiceApi();
133
+ const url = '/uums/unit';
134
+
135
+ watch(
136
+ () => active.value,
137
+ (newVal, oldVal) => {
138
+ data.record = active.value;
139
+ newVal?.id && oldVal?.id && newVal !== oldVal && handleEdit('detail');
140
+ }
141
+ );
142
+
143
+ // 新增子类型
144
+ const handleAdd = () => {
145
+ data.dataStatus = 'add';
146
+ data.record = {};
147
+ data.record.parentId = active.value?.id;
148
+ data.isChecked = false;
149
+ data.dialogFormVisible = true;
150
+ };
151
+ // 编辑
152
+ const handleEdit = dataStatus => {
153
+ data.dataStatus = dataStatus;
154
+ data.record = clone(active.value, true);
155
+ data.dialogFormVisible = true;
156
+ };
157
+
158
+ const xForm = templateRef<any>('xForm', null);
159
+ const handleComfirm = () => {
160
+ xForm.value.validate(async valid => {
161
+ if (!valid) {
162
+ const { record, dataStatus } = data;
163
+ if (dataStatus === 'add') {
164
+ await serviceApi.post(url, record);
165
+ } else {
166
+ await serviceApi.put(url, record);
167
+ }
168
+ actionComplete();
169
+ }
170
+ });
171
+ };
172
+
173
+ const handleDelete = async () => {
174
+ const { record } = data;
175
+ if (record.children?.length) return warnMessage(t('message.deletePartment'));
176
+ const type = await VxeUI.modal.confirm(t('message.tip.del', { msg: 'aaaaa' }));
177
+ if (type === 'confirm') {
178
+ await serviceApi.delete(url, record);
179
+ actionComplete();
180
+ }
181
+ };
182
+
183
+ const actionComplete = () => {
184
+ scrollPanelChange.value = true;
185
+ successMessage(t('message.operateSuccess'));
186
+ handleClose();
187
+ };
188
+
189
+ const handleCancle = () => {
190
+ data.dialogFormVisible = false;
191
+ data.dataStatus = '';
192
+ };
193
+
194
+ const handleClose = () => {
195
+ data.dialogFormVisible = false;
196
+ };
197
+ </script>
198
+ <style lang="scss" scoped>
199
+ .page-content {
200
+ background-color: #fff;
201
+
202
+ .w-departInfo-wrapper {
203
+ width: 96%;
204
+ height: 75vh;
205
+
206
+ .w-card-wrapper {
207
+ width: 40%;
208
+
209
+ .el-card__header {
210
+ padding: 10px 20px;
211
+
212
+ .w-card-title {
213
+ position: relative;
214
+ top: 5px;
215
+ }
216
+ }
217
+ }
218
+
219
+ .el-form-item {
220
+ margin-bottom: 12px;
221
+ }
222
+ }
223
+
224
+ .w-noclick-wrapper {
225
+ display: flex;
226
+ flex-wrap: wrap;
227
+ align-items: center;
228
+ justify-content: center;
229
+ height: 100%;
230
+
231
+ .w-content-wrapper {
232
+ display: flex;
233
+ align-items: center;
234
+ justify-content: center;
235
+ height: 75vh;
236
+
237
+ ul {
238
+ padding: 24px;
239
+ border: 1px solid #ccc;
240
+ border-radius: 10px;
241
+ }
242
+ }
243
+
244
+ .w-department-header {
245
+ padding-right: 20px;
246
+ font-size: 26px;
247
+ font-weight: bolder;
248
+ color: #69c;
249
+ }
250
+
251
+ .w-department-line {
252
+ font-size: 16px;
253
+ line-height: 35px;
254
+ color: #999;
255
+ list-style: none;
256
+ }
257
+ }
258
+ }
259
+ </style>
@@ -2,7 +2,7 @@
2
2
  * @Author: wei.li
3
3
  * @Date: 2021-11-29 11:32:07
4
4
  * @LastEditors: levi7754 levi7754@163.com
5
- * @LastEditTime: 2025-04-29 10:22:16
5
+ * @LastEditTime: 2025-07-25 13:44:34
6
6
  * @Description: 库存组织
7
7
  -->
8
8
  <template>
@@ -21,8 +21,7 @@ export default { name: 'InvOrganization' };
21
21
  <script setup lang="tsx">
22
22
  import { ref, reactive } from 'vue';
23
23
  import to from 'await-to-js';
24
- // import { useRender } from '@utogether/utils';
25
- import { useRender } from '../../../utils/udp/useRender';
24
+ import { useRender } from '@utogether/utils';
26
25
  import { getServiceApi } from '../../../api';
27
26
 
28
27
  const url = '/uums/cusOrganization';
@@ -189,7 +189,7 @@ const handleAuthorityPanel = record => {
189
189
  };
190
190
 
191
191
  const onClose = (type?, record?) => {
192
- type === 'submit' && row && xgrid.value.getInstance().reloadTreeExpand(row || record);
192
+ type === 'submit' && (row || record) && xgrid.value.getInstance().reloadTreeExpand(row || record);
193
193
  data.record = {};
194
194
  data.showDrawer = false;
195
195
  data.showAuthority = false;