@utogether/udp-core 1.0.0 → 1.0.1-beta.10

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 (201) hide show
  1. package/build/plugins.ts +39 -26
  2. package/dist/{403-B1R-4vXw.js → 403-Ctxjn4q8.js} +9 -8
  3. package/dist/{404-fXPl8csw.js → 404-W5yzyiZ9.js} +15 -14
  4. package/dist/{500-eI5842YB.js → 500-DXuGEOm4.js} +11 -10
  5. package/dist/{AuthorityInfo-CfVH6PaB.js → AuthorityInfo-C2tflCt8.js} +1 -1
  6. package/dist/AuthorityInfo.vue_vue_type_style_index_0_lang-SVgy3HX7.js +100 -0
  7. package/dist/{AuthorityPanel-BaLMwMgW.js → AuthorityPanel-BeBNiwqc.js} +1 -1
  8. package/dist/{AuthorityPanel.vue_vue_type_style_index_0_lang-C_bkqLD9.js → AuthorityPanel.vue_vue_type_style_index_0_lang-CIYmnP9-.js} +6 -6
  9. package/dist/{Company-CYC9Avfz.js → Company-PLez5GoH.js} +3 -3
  10. package/dist/{CompanyPanel-B4MzoqN_.js → CompanyPanel-CIGaQooL.js} +20 -20
  11. package/dist/{Department-B4BNSiYx.js → Department-B9wLsXFm.js} +3 -3
  12. package/dist/{DepartmentPanel-zJO89L2O.js → DepartmentPanel-DSM4lTaz.js} +23 -23
  13. package/dist/{DesignPanel-S8P0J97f.js → DesignPanel-B6a9wW_A.js} +1 -1
  14. package/dist/{DesignPanel.vue_vue_type_style_index_0_lang-DW-_Vqrr.js → DesignPanel.vue_vue_type_style_index_0_lang-DtHfoDQk.js} +28 -30
  15. package/dist/DictView-DhFbQxdJ.js +110 -0
  16. package/dist/{InvOrganization-MuM2jtsG.js → InvOrganization-D90AbR3b.js} +2 -2
  17. package/dist/Org-DxBkYabD.js +39 -0
  18. package/dist/{Preview-CRyiwUIR.js → Preview-BFtRpBxw.js} +1 -1
  19. package/dist/{ReportDefine-WZYIx8Sm.js → ReportDefine-BIa2QryC.js} +1 -1
  20. package/dist/{ReportDesign-D-7GKgpb.js → ReportDesign-CnyjI-WD.js} +44 -44
  21. package/dist/{ReportQuery-BIIJny6w.js → ReportQuery-BiK7yEhV.js} +5 -5
  22. package/dist/{ReportQueryFrom-OoUl7N2O.js → ReportQueryFrom-C2rqdFTm.js} +1 -1
  23. package/dist/{ReportQueryFrom.vue_vue_type_style_index_0_lang-B878fgj8.js → ReportQueryFrom.vue_vue_type_style_index_0_lang-Ba9HLnXQ.js} +6 -5
  24. package/dist/{ReportTemplate-Cfeq9US-.js → ReportTemplate-DdkLscP3.js} +30 -30
  25. package/dist/{Role-BwTV2QMH.js → Role-BrsxgK8D.js} +6 -6
  26. package/dist/{RoleAssign-De1JjOun.js → RoleAssign-DiqwJqDa.js} +8 -8
  27. package/dist/{RolePanel-pUBXsqCM.js → RolePanel-BDusGyo7.js} +1 -1
  28. package/dist/{RolePanel-E3RcdByM.js → RolePanel-Dqx5dI3f.js} +1 -1
  29. package/dist/RolePanel.vue_vue_type_script_setup_true_lang-2Z1q_5uW.js +132 -0
  30. package/dist/{RolePanel.vue_vue_type_script_setup_true_lang-B2pQwHb0.js → RolePanel.vue_vue_type_script_setup_true_lang-B5lUnaMI.js} +40 -34
  31. package/dist/{ScrollPanel.vue_vue_type_style_index_0_lang-vMR1fBi0.js → ScrollPanel.vue_vue_type_style_index_0_lang-vSP23fEq.js} +23 -23
  32. package/dist/{Staff-Czm7A8vI.js → Staff-Cwi9LQiZ.js} +3 -3
  33. package/dist/StaffInfo-XjVtyaMv.js +4 -0
  34. package/dist/{StaffInfo.vue_vue_type_style_index_0_lang-DMTL7KCh.js → StaffInfo.vue_vue_type_script_setup_true_lang-wSrAuyet.js} +16 -16
  35. package/dist/{StaffPanel-CHk60LEz.js → StaffPanel-C-wYcFdv.js} +1 -1
  36. package/dist/{StaffPanel.vue_vue_type_script_setup_true_lang-iPKLb5wG.js → StaffPanel.vue_vue_type_script_setup_true_lang-DZNArmnC.js} +46 -49
  37. package/dist/{SysUser-BGwbttRn.js → SysUser-O4tvr-Ur.js} +2 -2
  38. package/dist/{SysUserPanel-BCbKoLKt.js → SysUserPanel-B853docZ.js} +1 -1
  39. package/dist/SysUserPanel.vue_vue_type_script_setup_true_lang-DhiYYC97.js +294 -0
  40. package/dist/{SystemMenu-BkqZSDKl.js → SystemMenu-CXR6mrXr.js} +52 -50
  41. package/dist/{UserInfo-BsyAcT2d.js → UserInfo-BkP8pE2a.js} +1 -1
  42. package/dist/{UserInfo.vue_vue_type_style_index_0_lang-D0-KDxAh.js → UserInfo.vue_vue_type_style_index_0_lang-D4r_umjV.js} +38 -36
  43. package/dist/{childView-CyuLTUqC.js → childView-D0HwbgDT.js} +1 -1
  44. package/dist/{childView-CF83nhxb.js → childView-TRqUkSDC.js} +1 -1
  45. package/dist/{childView.vue_vue_type_style_index_0_lang-CNSgGda3.js → childView.vue_vue_type_style_index_0_lang-BzISq0Jf.js} +43 -43
  46. package/dist/{childView.vue_vue_type_style_index_0_lang-Cch4lE-i.js → childView.vue_vue_type_style_index_0_lang-DQRgNsJY.js} +1 -1
  47. package/dist/{code-rule-Bz-gnktN.js → code-rule-BV7PQWhK.js} +13 -14
  48. package/dist/core.es.js +13 -10
  49. package/dist/{cron-task-CIifSUdW.js → cron-task-9ZS9bi7K.js} +11 -11
  50. package/dist/{frameView-_d2mqjjQ.js → frameView-DE83AN50.js} +15 -14
  51. package/dist/img/l_img.svg +1 -1
  52. package/dist/img/minicolors.png +0 -0
  53. package/dist/img/v_img.svg +1 -1
  54. package/dist/index-DVARtten.js +2623 -0
  55. package/dist/{layoutView-DLKVepB8.js → layoutView-D1U-c4By.js} +730 -724
  56. package/dist/{login-log-CvVnyGi3.js → login-log-kqKzKTto.js} +1 -1
  57. package/dist/{login-LREiDfFU.js → login-sPCEiTGT.js} +107 -113
  58. package/dist/{lov-view-DDrIVILB.js → lov-view-76NcYTYl.js} +5 -5
  59. package/dist/{menuInfo-B1FUV-Sk.js → menuInfo-CxjfjFpm.js} +1 -1
  60. package/dist/{menuInfo.vue_vue_type_style_index_0_lang-Cnk3vdtD.js → menuInfo.vue_vue_type_style_index_0_lang-C2qahH3r.js} +98 -95
  61. package/dist/pda-app-BUH16bLj.js +710 -0
  62. package/dist/redirect-BqegffKC.js +15 -0
  63. package/dist/{resource-BCwx9fEv.js → resource-CCuHzoA6.js} +18 -18
  64. package/dist/{su-welcome-189A7N4r.js → su-welcome-mRArONsd.js} +133 -133
  65. package/dist/{sys-config-BZ3sejow.js → sys-config-Cvt05yF6.js} +21 -21
  66. package/dist/udp-core.css +2 -2
  67. package/dist/{utogether-r08LNiIZ.js → utogether-Dm_VBQHR.js} +6 -6
  68. package/index.ts +40 -36
  69. package/package.json +4 -2
  70. package/src/App.vue +65 -70
  71. package/src/api/index.ts +1 -1
  72. package/src/components/SuCharts/src/UserInfo.vue +78 -78
  73. package/src/components/SuScrollTree/ScrollPanel.vue +3 -3
  74. package/src/components/udp/count-down.vue +536 -0
  75. package/src/components/udp/flip-down/FlipCard/flip-card.vue +251 -0
  76. package/src/components/udp/flip-down/FlipCard/interfaces.ts +4 -0
  77. package/src/components/udp/flip-down/FlipClock/flip-clock.vue +113 -0
  78. package/src/components/udp/form-upload.vue +482 -0
  79. package/src/components/udp/form.vue +112 -0
  80. package/src/components/udp/grid.vue +495 -0
  81. package/src/components/udp/index.ts +10 -0
  82. package/src/components/udp/lov.vue +388 -0
  83. package/src/components/udp/modal-form.vue +189 -0
  84. package/src/components/udp/modal-grid.vue +288 -0
  85. package/src/components/udp/upload.vue +423 -0
  86. package/src/components/udp/utils.ts +447 -0
  87. package/src/directives/permission/index.ts +1 -1
  88. package/src/layout/components/lay-navbar/index.vue +1 -1
  89. package/src/layout/components/lay-panel/index.vue +150 -150
  90. package/src/layout/components/lay-search/index.vue +25 -25
  91. package/src/layout/components/lay-sidebar/breadCrumb.vue +1 -1
  92. package/src/layout/components/lay-tag/index.vue +625 -625
  93. package/src/layout/layoutView.vue +215 -215
  94. package/src/main.ts +25 -14
  95. package/src/plugins/i18n/en.ts +302 -289
  96. package/src/plugins/i18n/zh.ts +348 -337
  97. package/src/plugins/vxe-table/index.ts +53 -46
  98. package/src/plugins/vxe-table/render.tsx +956 -397
  99. package/src/router/index.ts +187 -183
  100. package/src/router/modules/remaining.ts +58 -83
  101. package/src/style/button.scss +85 -78
  102. package/src/style/tailwind.css +1 -68
  103. package/src/style/vxetable.scss +44 -11
  104. package/src/utils/authority/index.ts +1 -1
  105. package/src/utils/{http → udp/http}/index.ts +8 -24
  106. package/src/utils/{http → udp/http}/types.d.ts +8 -5
  107. package/src/utils/udp/useRender.ts +431 -0
  108. package/src/views/login/login-view.vue +2 -2
  109. package/src/views/organization/company/CompanyPanel.vue +259 -259
  110. package/src/views/organization/inv-org/InvOrganization.vue +1 -1
  111. package/src/views/organization/org/Org.vue +9 -5
  112. package/src/views/organization/staff/StaffInfo.vue +0 -30
  113. package/src/views/organization/staff/StaffPanel.vue +4 -3
  114. package/src/views/system/menu/AuthorityPanel.vue +2 -2
  115. package/src/views/system/menu/SystemMenu.vue +183 -191
  116. package/src/views/system/menu/menuInfo.vue +363 -368
  117. package/src/views/system/role/AuthorityInfo.vue +19 -33
  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 +1 -1
  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/components/menu-favorite.vue +1 -1
  132. package/src/views/uhome/su-welcome.vue +4 -4
  133. package/src/views/ulogin/login.vue +15 -10
  134. package/src/views/upms/user/login-log.vue +1 -1
  135. package/src/views/urpt/design/DesignPanel.vue +507 -526
  136. package/src/views/urpt/design/ReportDesign.vue +15 -19
  137. package/src/views/urpt/static-resource/resource.vue +3 -3
  138. package/src/views/urpt/template/ReportTemplate.vue +7 -7
  139. package/types/global.d.ts +2 -2
  140. package/vite.config.ts +13 -2
  141. package/dist/AuthorityInfo.vue_vue_type_style_index_0_lang-DbK-f8jH.js +0 -102
  142. package/dist/DictView-bIS5-rK-.js +0 -95
  143. package/dist/Org-kXHSjsgJ.js +0 -35
  144. package/dist/RolePanel.vue_vue_type_script_setup_true_lang-CTIad9_Q.js +0 -126
  145. package/dist/StaffInfo-DJzvBuxy.js +0 -4
  146. package/dist/SysUserPanel.vue_vue_type_script_setup_true_lang-0QUjnhjF.js +0 -289
  147. package/dist/core.umd.js +0 -173
  148. package/dist/index-BKIw8tSn.js +0 -9195
  149. package/dist/pda-app-CRhVGijN.js +0 -2209
  150. package/dist/redirect-DiaNDu8F.js +0 -15
  151. package/src/assets/images/empty.png +0 -0
  152. package/src/assets/images/logo.png +0 -0
  153. package/src/components/ReCountTo/README.md +0 -2
  154. package/src/components/ReCountTo/index.ts +0 -18
  155. package/src/components/ReCountTo/src/normal/index.tsx +0 -165
  156. package/src/components/ReCountTo/src/normal/props.ts +0 -37
  157. package/src/components/ReCountTo/src/rebound/index.tsx +0 -67
  158. package/src/components/ReCountTo/src/rebound/props.ts +0 -14
  159. package/src/components/ReCountTo/src/rebound/rebound.css +0 -77
  160. package/src/components/ReCropper/index.ts +0 -14
  161. package/src/components/ReCropper/src/index.tsx +0 -141
  162. package/src/components/ReFlicker/index.css +0 -39
  163. package/src/components/ReFlicker/index.ts +0 -50
  164. package/src/components/ReFlop/index.ts +0 -14
  165. package/src/components/ReFlop/src/Filpper.tsx +0 -99
  166. package/src/components/ReFlop/src/filpper.css +0 -184
  167. package/src/components/ReFlop/src/index.vue +0 -126
  168. package/src/components/ReFlowChart/index.ts +0 -24
  169. package/src/components/ReFlowChart/src/Control.vue +0 -139
  170. package/src/components/ReFlowChart/src/DataDialog.vue +0 -12
  171. package/src/components/ReFlowChart/src/NodePanel.vue +0 -151
  172. package/src/components/ReFlowChart/src/adpterForTurbo.ts +0 -160
  173. package/src/components/ReFlowChart/src/assets/iconfont/iconfont.css +0 -49
  174. package/src/components/ReFlowChart/src/assets/iconfont/iconfont.eot +0 -0
  175. package/src/components/ReFlowChart/src/assets/iconfont/iconfont.js +0 -61
  176. package/src/components/ReFlowChart/src/assets/iconfont/iconfont.json +0 -58
  177. package/src/components/ReFlowChart/src/assets/iconfont/iconfont.svg +0 -47
  178. package/src/components/ReFlowChart/src/assets/iconfont/iconfont.ttf +0 -0
  179. package/src/components/ReFlowChart/src/assets/iconfont/iconfont.woff +0 -0
  180. package/src/components/ReFlowChart/src/assets/iconfont/iconfont.woff2 +0 -0
  181. package/src/components/ReFlowChart/src/config.ts +0 -62
  182. package/src/components/ReSplitPane/index.css +0 -49
  183. package/src/components/ReSplitPane/index.tsx +0 -119
  184. package/src/components/ReSplitPane/resizer.css +0 -45
  185. package/src/components/ReSplitPane/resizer.tsx +0 -30
  186. package/src/components/SuCommon/card/components/Card.vue +0 -148
  187. package/src/components/SuCommon/card/components/DialogForm.vue +0 -127
  188. package/src/components/SuCommon/card/index.vue +0 -142
  189. package/src/components/SuCommon/icon-select/index.vue +0 -241
  190. package/src/components/SuCommon/table/index.vue +0 -208
  191. package/src/components/SuCommon/utils/index.ts +0 -103
  192. package/src/components/SuCommon/utils/slot.tsx +0 -50
  193. package/src/views/components/contextmenu/basic.vue +0 -74
  194. package/src/views/components/contextmenu/context-menu.vue +0 -40
  195. package/src/views/components/contextmenu/menuDynamic.vue +0 -99
  196. package/src/views/components/contextmenu/menuGroup.vue +0 -71
  197. package/src/views/components/count-to/index.vue +0 -43
  198. package/src/views/components/cropping/index.vue +0 -59
  199. package/src/views/components/cropping/picture.jpeg +0 -0
  200. package/src/views/components/split-pane/index.vue +0 -82
  201. package/src/views/components/video/index.vue +0 -57
@@ -1,127 +0,0 @@
1
- <script setup lang="ts">
2
- import { ref, watch } from 'vue';
3
- import { message } from '@/utils/message';
4
- import { FormInstance } from 'element-plus';
5
-
6
- const SELECT_OPTIONS = [
7
- { label: '网关', value: 1 },
8
- { label: '人工智能', value: 2 },
9
- { label: 'CVM', value: 3 },
10
- { label: '防火墙', value: 4 },
11
- { label: '未知', value: 5 }
12
- ];
13
-
14
- const props = defineProps({
15
- visible: {
16
- type: Boolean,
17
- default: false
18
- },
19
- data: {
20
- type: Object,
21
- default: () => {
22
- return {};
23
- }
24
- }
25
- });
26
-
27
- const ruleFormRef = ref<FormInstance>();
28
-
29
- const formVisible = ref(false);
30
- const formData = ref(props.data);
31
- const textareaValue = ref('');
32
-
33
- const submitForm = async (formEl: FormInstance | undefined) => {
34
- if (!formEl) return;
35
- await formEl.validate(valid => {
36
- if (valid) {
37
- message('提交成功', { type: 'success' });
38
- formVisible.value = false;
39
- resetForm(formEl);
40
- }
41
- });
42
- };
43
-
44
- const resetForm = (formEl: FormInstance | undefined) => {
45
- if (!formEl) return;
46
- formEl.resetFields();
47
- };
48
-
49
- const closeDialog = () => {
50
- formVisible.value = false;
51
- resetForm(ruleFormRef.value);
52
- };
53
-
54
- const emit = defineEmits(['update:visible']);
55
- watch(
56
- () => formVisible.value,
57
- val => {
58
- emit('update:visible', val);
59
- }
60
- );
61
-
62
- watch(
63
- () => props.visible,
64
- val => {
65
- formVisible.value = val;
66
- }
67
- );
68
-
69
- watch(
70
- () => props.data,
71
- val => {
72
- formData.value = val;
73
- }
74
- );
75
-
76
- const rules = {
77
- name: [{ required: true, message: '请输入产品名称', trigger: 'blur' }]
78
- };
79
- </script>
80
-
81
- <template>
82
- <el-dialog v-model="formVisible" title="新建产品" :width="680" draggable :before-close="closeDialog">
83
- <!-- 表单内容 -->
84
- <el-form ref="ruleFormRef" :model="formData" :rules="rules" label-width="100px">
85
- <el-form-item label="产品名称" prop="name">
86
- <el-input v-model="formData.name" :style="{ width: '480px' }" placeholder="请输入产品名称" />
87
- </el-form-item>
88
- <el-form-item label="产品状态" prop="status">
89
- <el-radio-group v-model="formData.status">
90
- <el-radio label="0">已停用</el-radio>
91
- <el-radio label="1">已启用</el-radio>
92
- </el-radio-group>
93
- </el-form-item>
94
- <el-form-item label="产品描述" prop="description">
95
- <el-input
96
- v-model="formData.description"
97
- :style="{ width: '480px' }"
98
- placeholder="请输入产品描述"
99
- />
100
- </el-form-item>
101
- <el-form-item label="产品类型" prop="type">
102
- <el-select v-model="formData.type" clearable :style="{ width: '480px' }">
103
- <el-option
104
- v-for="(item, index) in SELECT_OPTIONS"
105
- :key="index"
106
- :value="item.value"
107
- :label="item.label"
108
- >
109
- {{ item.label }}
110
- </el-option>
111
- </el-select>
112
- </el-form-item>
113
- <el-form-item label="备注" prop="mark">
114
- <el-input
115
- v-model="textareaValue"
116
- type="textarea"
117
- :style="{ width: '480px' }"
118
- placeholder="请输入内容"
119
- />
120
- </el-form-item>
121
- </el-form>
122
- <template #footer>
123
- <el-button @click="closeDialog">取消</el-button>
124
- <el-button type="primary" @click="submitForm(ruleFormRef)"> 确定 </el-button>
125
- </template>
126
- </el-dialog>
127
- </template>
@@ -1,142 +0,0 @@
1
- <template>
2
- <div class="main">
3
- <div class="w-full flex justify-between mb-4">
4
- <vxe-button icon="" @click="formDialogVisible = true"> 新建产品 </vxe-button>
5
- <!-- <el-button :icon="useRenderIcon(AddFill)" @click="formDialogVisible = true"> 新建产品 </el-button> -->
6
- <vxe-input
7
- v-model="searchValue"
8
- style="width: 300px"
9
- placeholder="请输入关键字查询"
10
- clearable
11
- type="search"
12
- />
13
- </div>
14
- <div v-loading="dataLoading">
15
- <el-empty
16
- v-show="
17
- productList
18
- .slice(
19
- pagination.pageSize * (pagination.current - 1),
20
- pagination.pageSize * pagination.current
21
- )
22
- .filter(v => v.name.toLowerCase().includes(searchValue.toLowerCase())).length === 0
23
- "
24
- description="暂无数据"
25
- />
26
- <template v-if="pagination.total > 0">
27
- <el-row :gutter="16">
28
- <el-col
29
- v-for="(product, index) in productList
30
- .slice(
31
- pagination.pageSize * (pagination.current - 1),
32
- pagination.pageSize * pagination.current
33
- )
34
- .filter(v => v.name.toLowerCase().includes(searchValue.toLowerCase()))"
35
- :key="index"
36
- :xs="24"
37
- :sm="12"
38
- :md="8"
39
- :lg="6"
40
- :xl="4"
41
- >
42
- <Card
43
- :product="product"
44
- @delete-item="handleDeleteItem"
45
- @manage-product="handleManageProduct"
46
- />
47
- </el-col>
48
- </el-row>
49
- <el-pagination
50
- v-model:currentPage="pagination.current"
51
- class="float-right"
52
- :page-size="pagination.pageSize"
53
- :total="pagination.total"
54
- :page-sizes="[12, 24, 36]"
55
- :background="true"
56
- layout="total, sizes, prev, pager, next, jumper"
57
- @size-change="onPageSizeChange"
58
- @current-change="onCurrentChange"
59
- />
60
- </template>
61
- </div>
62
- <dialogForm v-model:visible="formDialogVisible" :data="formData" />
63
- </div>
64
- </template>
65
-
66
- <script setup lang="ts">
67
- import Card from './components/Card.vue';
68
- import { successMessage } from '@utogether/utils';
69
- import { ElMessageBox } from 'element-plus';
70
- import { ref, onMounted, nextTick } from 'vue';
71
- import dialogForm from './components/DialogForm.vue';
72
- // import { useRenderIcon } from '@/components/ReIcon/src/hooks';
73
- // import AddFill from '@iconify-icons/ri/add-circle-line';
74
-
75
- defineOptions({
76
- name: 'ListCard'
77
- });
78
-
79
- const INITIAL_DATA = {
80
- name: '',
81
- status: '',
82
- description: '',
83
- type: '',
84
- mark: ''
85
- };
86
-
87
- const pagination = ref({ current: 1, pageSize: 12, total: 0 });
88
-
89
- const productList = ref([{ name: '1' }]);
90
- const dataLoading = ref(true);
91
-
92
- const getCardListData = async () => {
93
- try {
94
- productList.value = [];
95
- pagination.value = {
96
- ...pagination.value,
97
- total: 0
98
- };
99
- } catch (e) {
100
- console.log(e);
101
- } finally {
102
- setTimeout(() => {
103
- dataLoading.value = false;
104
- }, 500);
105
- }
106
- };
107
-
108
- onMounted(() => {
109
- getCardListData();
110
- });
111
-
112
- const formDialogVisible = ref(false);
113
- const formData = ref({ ...INITIAL_DATA });
114
- const searchValue = ref('');
115
-
116
- const onPageSizeChange = (size: number) => {
117
- pagination.value.pageSize = size;
118
- pagination.value.current = 1;
119
- };
120
- const onCurrentChange = (current: number) => {
121
- pagination.value.current = current;
122
- };
123
- const handleDeleteItem = product => {
124
- ElMessageBox.confirm(
125
- product ? `确认删除后${product.name}的所有产品信息将被清空, 且无法恢复` : '',
126
- '提示',
127
- {
128
- type: 'warning'
129
- }
130
- )
131
- .then(() => {
132
- successMessage('删除成功');
133
- })
134
- .catch(() => {});
135
- };
136
- const handleManageProduct = product => {
137
- formDialogVisible.value = true;
138
- nextTick(() => {
139
- formData.value = { ...product, status: product?.isSetup ? '1' : '0' };
140
- });
141
- };
142
- </script>
@@ -1,241 +0,0 @@
1
- <template>
2
- <div class="selector w-full">
3
- <el-input v-model="inputValue" readonly size="small" class="u-icon-input relative">
4
- <template #append>
5
- <span
6
- v-if="inputValue"
7
- class="u-icon-close item-center justify-center text-sm hidden absolute"
8
- @click="onDel"
9
- >
10
- <IconifyIconOffline icon="ri:close-circle-line" />
11
- </span>
12
- <el-popover
13
- :visible="visible"
14
- :width="350"
15
- :popper-options="{ placement: 'auto' }"
16
- :teleported="props.teleported"
17
- trigger="click"
18
- popper-class="udp-popper"
19
- @hide="onHiden"
20
- >
21
- <template #reference>
22
- <div
23
- class="w-7 h-full cursor-pointer flex justify-center items-center"
24
- @click="visible = !visible"
25
- >
26
- <i :class="currentActiveType + icon" style="font-size: 16px" />
27
- </div>
28
- </template>
29
-
30
- <div class="flex items-center pr-2">
31
- <el-input v-model="filterValue" class="p-2" placeholder="搜索图标" clearable />
32
- </div>
33
- <el-divider border-style="dashed" />
34
- <el-scrollbar height="220px">
35
- <template #default>
36
- <ul class="flex flex-wrap px-2 ml-2">
37
- <li
38
- v-for="(item, key) in pageList"
39
- :key="key"
40
- :title="item"
41
- class="icon-item p-2 cursor-pointer mr-2 mt-1 flex justify-center items-center border border-[#e5e7eb]"
42
- :style="iconItemStyle(item)"
43
- @click="onChangeIcon(item)"
44
- >
45
- <i :class="currentActiveType + item" class="w-5 h-5 text-xl" />
46
- </li>
47
- </ul>
48
- </template>
49
- </el-scrollbar>
50
- <el-divider border-style="dashed" />
51
-
52
- <div class="w-full h-9 flex items-center overflow-auto border-t border-[#e5e7eb]">
53
- <el-pagination
54
- class="flex-auto ml-2"
55
- :total="total"
56
- :current-page="currentPage"
57
- :page-size="pageSize"
58
- :pager-count="5"
59
- layout="pager"
60
- background
61
- small
62
- @current-change="onCurrentChange"
63
- />
64
- <vxe-button
65
- class="justify-end mr-2 ml-2"
66
- status="danger"
67
- size="small"
68
- type="text"
69
- content="取消"
70
- @click="onHiden"
71
- />
72
- </div>
73
- </el-popover>
74
- </template>
75
- </el-input>
76
- </div>
77
- </template>
78
-
79
- <script lang="ts">
80
- export default {
81
- name: 'SuIconSelect'
82
- };
83
- </script>
84
-
85
- <script setup lang="ts">
86
- import { ref, computed, CSSProperties, toRef, watch, onMounted } from 'vue';
87
- import { clone } from 'xe-utils';
88
- import { iconSet } from '@utogether/utils';
89
-
90
- type ParameterCSSProperties = (item?: string) => CSSProperties | undefined;
91
-
92
- const props = defineProps({
93
- modelValue: {
94
- require: false,
95
- type: String
96
- },
97
- teleported: {
98
- require: false,
99
- type: Boolean
100
- }
101
- });
102
- const emit = defineEmits<{ (e: 'update:modelValue', v: string) }>();
103
-
104
- const visible = ref(false);
105
- const inputValue = toRef(props, 'modelValue');
106
-
107
- const iconList = ref(Object.keys(iconSet.icons));
108
- const currentActiveType = ref('ri-');
109
- const icon = ref();
110
-
111
- // 深拷贝图标数据,前端做搜索
112
- const copyIconList = clone(iconList.value, true);
113
-
114
- const pageSize = ref(35);
115
- const currentPage = ref(1);
116
-
117
- const total = ref(0);
118
-
119
- // 搜索条件
120
- const filterValue = ref('');
121
-
122
- const setInitIcon = () => {
123
- icon.value = 'corner-down-right-fill';
124
- if (inputValue.value) {
125
- icon.value = inputValue.value.split(':')[1];
126
- }
127
- };
128
-
129
- const pageList = computed(() => {
130
- if (currentPage.value === 1) {
131
- return copyIconList
132
- .filter(v => v.includes(filterValue.value))
133
- .slice(currentPage.value - 1, pageSize.value);
134
- } else {
135
- return copyIconList
136
- .filter(v => v.includes(filterValue.value))
137
- .slice(
138
- pageSize.value * (currentPage.value - 1),
139
- pageSize.value * (currentPage.value - 1) + pageSize.value
140
- );
141
- }
142
- });
143
-
144
- const iconItemStyle = computed((): ParameterCSSProperties => {
145
- return item => {
146
- if (inputValue.value === currentActiveType.value + item) {
147
- return {
148
- borderColor: 'var(--el-color-primary)',
149
- color: 'var(--el-color-primary)'
150
- };
151
- }
152
- };
153
- });
154
-
155
- function onChangeIcon(item) {
156
- icon.value = item;
157
- emit('update:modelValue', transformIcon());
158
- onHiden();
159
- }
160
-
161
- function onCurrentChange(page) {
162
- currentPage.value = page;
163
- }
164
-
165
- const transformIcon = () => {
166
- if (currentActiveType.value === 'ri-') {
167
- return 'ri:' + icon.value;
168
- }
169
- return currentActiveType.value + icon.value;
170
- };
171
-
172
- const onDel = () => {
173
- icon.value = 'corner-down-right-fill';
174
- emit('update:modelValue', '');
175
- };
176
-
177
- const setTotal = () => {
178
- if (currentPage.value === 1) {
179
- total.value = copyIconList.filter(v => v.includes(filterValue.value)).length;
180
- } else {
181
- total.value = copyIconList.length;
182
- }
183
- };
184
-
185
- const onHiden = () => {
186
- visible.value = false;
187
- filterValue.value = '';
188
- };
189
-
190
- watch(
191
- () => {
192
- return props.modelValue;
193
- },
194
- () => {
195
- if (props.modelValue) {
196
- icon.value = props.modelValue.substring(props.modelValue.indexOf(':') + 1);
197
- }
198
- }
199
- );
200
- watch(
201
- () => {
202
- return filterValue.value;
203
- },
204
- () => {
205
- currentPage.value = 1;
206
- setTotal();
207
- }
208
- );
209
-
210
- onMounted(() => {
211
- setTotal();
212
- setInitIcon();
213
- });
214
- </script>
215
-
216
- <style lang="scss" scoped>
217
- .el-divider--horizontal {
218
- margin: 1px auto !important;
219
- }
220
-
221
- .icon-item {
222
- &:hover {
223
- color: var(--el-color-primary);
224
- border-color: var(--el-color-primary);
225
- transform: scaleX(1.05);
226
- transition: all 0.4s;
227
- }
228
- }
229
-
230
- :deep(.el-input-group__append) {
231
- padding: 0;
232
- }
233
-
234
- .u-icon-input:hover {
235
- .u-icon-close {
236
- left: -22px;
237
- display: flex;
238
- background-color: #fff;
239
- }
240
- }
241
- </style>