@utogether/udp-core 1.0.1-beta.15 → 1.0.1-beta.17

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 (126) hide show
  1. package/build/plugins.ts +39 -39
  2. package/dist/{403-DpJevH-h.js → 403-C3cfjZIT.js} +1 -1
  3. package/dist/{404-BpqJK3YD.js → 404-Bg3j7QIo.js} +1 -1
  4. package/dist/{500-DyvRbMD_.js → 500-CMT7Zyy7.js} +1 -1
  5. package/dist/{AuthorityInfo-Cyu4XHXx.js → AuthorityInfo-B1mvqs4x.js} +1 -1
  6. package/dist/{AuthorityInfo.vue_vue_type_style_index_0_lang-BxmnEEFq.js → AuthorityInfo.vue_vue_type_style_index_0_lang-DwoW7QWO.js} +3 -3
  7. package/dist/{Company-BLygcYrI.js → Company-qTguidK8.js} +3 -3
  8. package/dist/{CompanyPanel-D5Tgw6LF.js → CompanyPanel-BBC-o-k3.js} +17 -17
  9. package/dist/{Department-qI9OninZ.js → Department-C3mKZOnK.js} +3 -3
  10. package/dist/{DepartmentPanel-P-P8fPZQ.js → DepartmentPanel-CNdpOHBT.js} +25 -25
  11. package/dist/{DesignPanel-BxjD0AZi.js → DesignPanel-D9jrRCoG.js} +1 -1
  12. package/dist/{DesignPanel.vue_vue_type_style_index_0_lang-DN_OKxCu.js → DesignPanel.vue_vue_type_style_index_0_lang-A-Aj1Hl0.js} +6 -6
  13. package/dist/{DictView-PWL_Vf0T.js → DictView-CgdVkSiP.js} +15 -16
  14. package/dist/{InvOrganization-JXBXyn3G.js → InvOrganization-RE7s3vBq.js} +1 -1
  15. package/dist/{Org-DcTJn6YQ.js → Org-wXDGvTrS.js} +3 -3
  16. package/dist/{Preview-IKvbHI8a.js → Preview-Pvt1__BV.js} +1 -1
  17. package/dist/{ReportDefine-_G7ts7Ch.js → ReportDefine-xEQsgFyv.js} +1 -1
  18. package/dist/{ReportDesign-7h5oFklh.js → ReportDesign-jOSuEFH9.js} +9 -9
  19. package/dist/{ReportQuery-dj0BQUyi.js → ReportQuery-DxEmmGiN.js} +1 -1
  20. package/dist/{ReportQueryFrom-6WaZPg9i.js → ReportQueryFrom-CFlxfS5M.js} +1 -1
  21. package/dist/{ReportQueryFrom.vue_vue_type_style_index_0_lang-ChhcBPqa.js → ReportQueryFrom.vue_vue_type_style_index_0_lang-iHpiYz8f.js} +1 -1
  22. package/dist/{ReportTemplate-DIvJ3RrB.js → ReportTemplate-Dtz3aet7.js} +11 -11
  23. package/dist/{Role-ia_3qAZU.js → Role-B_NsHIyE.js} +3 -3
  24. package/dist/{RoleAssign-D0zVl4y3.js → RoleAssign-C9wm4zq4.js} +8 -8
  25. package/dist/{RolePanel-CQxOiAzj.js → RolePanel-BlHidBR0.js} +1 -1
  26. package/dist/{RolePanel-BiGGmP2w.js → RolePanel-DWM9mfNs.js} +1 -1
  27. package/dist/{RolePanel.vue_vue_type_script_setup_true_lang-BYDLRS_x.js → RolePanel.vue_vue_type_script_setup_true_lang-Cn4RRzXm.js} +1 -1
  28. package/dist/{RolePanel.vue_vue_type_script_setup_true_lang-Dwv5LFbf.js → RolePanel.vue_vue_type_script_setup_true_lang-DVQ9aqb1.js} +9 -9
  29. package/dist/{ScrollPanel.vue_vue_type_style_index_0_lang-gPP4duO8.js → ScrollPanel.vue_vue_type_style_index_0_lang-CCm-_i8O.js} +8 -8
  30. package/dist/{Staff-Bf_oUqF6.js → Staff-BfDc61QS.js} +3 -3
  31. package/dist/{StaffInfo-D5aisjx2.js → StaffInfo-BaJFo4mg.js} +1 -1
  32. package/dist/{StaffInfo.vue_vue_type_script_setup_true_lang-6PX7Bx6A.js → StaffInfo.vue_vue_type_script_setup_true_lang-Bwj4x1wu.js} +7 -7
  33. package/dist/{StaffPanel--zKzd4rt.js → StaffPanel-B6I2ZS6A.js} +1 -1
  34. package/dist/{StaffPanel.vue_vue_type_script_setup_true_lang-BWZSIFpq.js → StaffPanel.vue_vue_type_script_setup_true_lang-vbyS4w3V.js} +2 -2
  35. package/dist/{SysUser-BelbESLR.js → SysUser-B_r9LYc5.js} +2 -2
  36. package/dist/{SysUserPanel-BixKqQcA.js → SysUserPanel-C4ajcHPV.js} +1 -1
  37. package/dist/{SysUserPanel.vue_vue_type_script_setup_true_lang-BhaWZEfo.js → SysUserPanel.vue_vue_type_script_setup_true_lang-8Q0VvC9B.js} +41 -37
  38. package/dist/{SystemMenu-D40tzcSj.js → SystemMenu-CyPG23uP.js} +10 -10
  39. package/dist/{UserInfo-DTyk071j.js → UserInfo-BkoGt4ib.js} +1 -1
  40. package/dist/{UserInfo.vue_vue_type_style_index_0_lang-p9MByikC.js → UserInfo.vue_vue_type_style_index_0_lang-DrzF1YYG.js} +10 -10
  41. package/dist/{childView-so5qSxr0.js → childView-9vEO8ymO.js} +1 -1
  42. package/dist/{childView-xL3iE1yN.js → childView-Dh0NyiQe.js} +1 -1
  43. package/dist/{childView.vue_vue_type_style_index_0_lang-CKcXpSqa.js → childView.vue_vue_type_style_index_0_lang-BOeoZuAK.js} +7 -7
  44. package/dist/{childView.vue_vue_type_style_index_0_lang-DK1ei5uM.js → childView.vue_vue_type_style_index_0_lang-CMOjfXBX.js} +1 -1
  45. package/dist/{code-rule-DC35y76w.js → code-rule-C7jI_1gJ.js} +6 -6
  46. package/dist/core.es.js +17 -12
  47. package/dist/{cron-task-BhjQ4S68.js → cron-task-Dg9DJXvv.js} +11 -11
  48. package/dist/{frameView-G_zhG9pf.js → frameView-CeR-_hjB.js} +1 -1
  49. package/dist/{index-C6ehxLLO.js → index-Bb7gIEvu.js} +739 -496
  50. package/dist/{layoutView-CO2U8qCQ.js → layoutView-wsLHrEeX.js} +1347 -1346
  51. package/dist/login-CluzzdqH.js +249 -0
  52. package/dist/{lov-view-Cr929NMD.js → lov-view-BvQCvwbW.js} +5 -5
  53. package/dist/{menuInfo-BWuROp7u.js → menuInfo-B8RLelIC.js} +1 -1
  54. package/dist/{menuInfo.vue_vue_type_style_index_0_lang-9nouHUjO.js → menuInfo.vue_vue_type_style_index_0_lang-DvkapEZr.js} +7 -7
  55. package/dist/{pda-app-CQP1sMAI.js → pda-app-D3LNmD9a.js} +19 -19
  56. package/dist/{resource-BDQLrMpK.js → resource-D8JA_03-.js} +7 -7
  57. package/dist/{su-welcome-CZysrZQ1.js → su-welcome-BjxeEKSo.js} +88 -88
  58. package/dist/{sys-config-BiGNMYSA.js → sys-config-sbeLk9bP.js} +6 -6
  59. package/dist/udp-core.css +1 -9
  60. package/dist/utogether-MlnyYtNS.js +4 -0
  61. package/index.ts +48 -40
  62. package/package.json +1 -1
  63. package/src/App.vue +65 -65
  64. package/src/components/SuCharts/src/UserInfo.vue +78 -78
  65. package/src/components/SuScrollTree/ScrollPanel.vue +170 -175
  66. package/src/components/udp/{grid.vue → grid/index.vue} +27 -24
  67. package/src/components/udp/index.ts +2 -9
  68. package/src/components/udp/utils.ts +60 -107
  69. package/src/layout/components/lay-navbar/index.vue +239 -239
  70. package/src/layout/components/lay-panel/index.vue +150 -150
  71. package/src/layout/components/lay-search/index.vue +25 -25
  72. package/src/layout/components/lay-select-org/index.vue +64 -64
  73. package/src/layout/components/lay-sidebar/horizontal.vue +190 -190
  74. package/src/layout/components/lay-sidebar/mixNav.vue +260 -260
  75. package/src/layout/components/lay-sidebar/sidebar-logo.vue +92 -92
  76. package/src/layout/components/lay-tag/index.vue +20 -48
  77. package/src/layout/hooks/useNav.ts +173 -173
  78. package/src/layout/hooks/useTag.ts +223 -233
  79. package/src/layout/types.ts +3 -2
  80. package/src/main.ts +117 -113
  81. package/src/plugins/i18n/en.ts +302 -302
  82. package/src/plugins/i18n/zh.ts +356 -354
  83. package/src/plugins/vxe-table/index.ts +116 -53
  84. package/src/plugins/vxe-table/render.tsx +956 -956
  85. package/src/router/index.ts +186 -177
  86. package/src/router/modules/remaining.ts +58 -58
  87. package/src/router/utils.ts +393 -377
  88. package/src/store/modules/app.ts +1 -3
  89. package/src/store/modules/multiTags.ts +110 -109
  90. package/src/store/modules/permission.ts +113 -100
  91. package/src/style/button.scss +85 -85
  92. package/src/style/login.css +1 -1
  93. package/src/style/vxetable.scss +25 -2
  94. package/src/utils/index.ts +3 -1
  95. package/src/views/organization/company/CompanyPanel.vue +259 -259
  96. package/src/views/organization/department/DepartmentPanel.vue +269 -283
  97. package/src/views/system/menu/SystemMenu.vue +183 -183
  98. package/src/views/system/menu/menuInfo.vue +363 -363
  99. package/src/views/system/role/UserInfo.vue +195 -195
  100. package/src/views/system/role-assign/RoleAssign.vue +57 -57
  101. package/src/views/system/role-assign/RolePanel.vue +139 -139
  102. package/src/views/system/sys/sys-config.vue +336 -336
  103. package/src/views/system/sysUser/SysUserPanel.vue +279 -278
  104. package/src/views/uapp/pda/pda-app.vue +208 -208
  105. package/src/views/udev/dict/DictView.vue +118 -118
  106. package/src/views/udev/dict/childView.vue +1 -1
  107. package/src/views/udev/lov/lov-view.vue +91 -91
  108. package/src/views/ulogin/login.vue +2 -2
  109. package/src/views/upms/interface/log-out.vue +101 -101
  110. package/src/views/urpt/design/DesignPanel.vue +507 -507
  111. package/types/global.d.ts +2 -8
  112. package/dist/login-DzyK2soP.js +0 -278
  113. package/dist/utogether-BRirriOz.js +0 -182
  114. package/src/components/udp/count-down.vue +0 -536
  115. package/src/components/udp/flip-down/FlipCard/flip-card.vue +0 -251
  116. package/src/components/udp/flip-down/FlipCard/interfaces.ts +0 -4
  117. package/src/components/udp/flip-down/FlipClock/flip-clock.vue +0 -113
  118. package/src/components/udp/form-upload.vue +0 -482
  119. package/src/components/udp/form.vue +0 -112
  120. package/src/components/udp/lov.vue +0 -388
  121. package/src/components/udp/modal-form.vue +0 -190
  122. package/src/components/udp/modal-grid.vue +0 -298
  123. package/src/components/udp/upload.vue +0 -423
  124. package/src/utils/udp/http/index.ts +0 -294
  125. package/src/utils/udp/http/types.d.ts +0 -49
  126. package/src/utils/udp/useRender.ts +0 -431
@@ -46,7 +46,7 @@ html[data-vxe-ui-theme='light'] {
46
46
  }
47
47
 
48
48
  // 输入框必填
49
- .vxe-input--suffix {
49
+ .vxe-input:not(.is--disabled) > .vxe-input--suffix {
50
50
  background-color: #fffbdf;
51
51
  }
52
52
 
@@ -66,7 +66,7 @@ html[data-vxe-ui-theme='light'] {
66
66
  }
67
67
 
68
68
  // 日期必填
69
- .vxe-date-picker {
69
+ .vxe-date-picker:not(.is--disabled) {
70
70
  .vxe-date-picker--inner,
71
71
  .vxe-input--suffix {
72
72
  background-color: #fffbdf;
@@ -77,6 +77,14 @@ html[data-vxe-ui-theme='light'] {
77
77
  background-color: #fffbdf;
78
78
  }
79
79
  }
80
+
81
+ .vxe-number-input:not(.is--disabled) {
82
+ .vxe-number-input--input-inner {
83
+ .vxe-number-input--input {
84
+ background-color: #fffbdf;
85
+ }
86
+ }
87
+ }
80
88
  }
81
89
 
82
90
  /** 分页组件:当前页颜色 */
@@ -306,3 +314,18 @@ html[data-vxe-ui-theme='light'] {
306
314
  background-color: #d8e5f7;
307
315
  background-image: linear-gradient(180deg, #d8e5f7, #bcd3f5);
308
316
  }
317
+
318
+ /*********************************** tabs ****************************/
319
+
320
+ .vxe-tabs-header--item-name {
321
+ font-size: 12px;
322
+ font-weight: 600;
323
+ color: #909399;
324
+ }
325
+
326
+ .vxe-tabs-header--item.is--active {
327
+ .vxe-tabs-header--item-name {
328
+ font-size: 13px;
329
+ color: var(--udp-theme-vxeColor);
330
+ }
331
+ }
@@ -2,11 +2,13 @@
2
2
  * @Author: wei.li
3
3
  * @Date: 2022-07-07 14:43:20
4
4
  * @LastEditors: levi7754 levi7754@163.com
5
- * @LastEditTime: 2025-06-03 09:26:49
5
+ * @LastEditTime: 2025-09-12 14:49:00
6
6
  * @Description: file content
7
7
  */
8
8
 
9
9
  // export * from './udp/useRender';
10
+ export * from './browers';
11
+ export * from './lifecycle';
10
12
 
11
13
  export const getKeyList = (data, key) => {
12
14
  const array = [];
@@ -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 } 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>
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>