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

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 (144) hide show
  1. package/build/plugins.ts +8 -2
  2. package/dist/{403-B1R-4vXw.js → 403-BBQoJwTM.js} +9 -8
  3. package/dist/{404-fXPl8csw.js → 404-BbJPSIWM.js} +15 -14
  4. package/dist/{500-eI5842YB.js → 500-BtFL9R4M.js} +11 -10
  5. package/dist/{AuthorityInfo-CfVH6PaB.js → AuthorityInfo-DhiwCeLN.js} +1 -1
  6. package/dist/{AuthorityInfo.vue_vue_type_style_index_0_lang-DbK-f8jH.js → AuthorityInfo.vue_vue_type_style_index_0_lang-Duyweh89.js} +3 -3
  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-CGqmslx-.js} +3 -3
  10. package/dist/{CompanyPanel-B4MzoqN_.js → CompanyPanel-hlDsxD-6.js} +10 -10
  11. package/dist/{Department-B4BNSiYx.js → Department-BZyJtacc.js} +3 -3
  12. package/dist/{DepartmentPanel-zJO89L2O.js → DepartmentPanel-D-a_EBFt.js} +23 -23
  13. package/dist/{DesignPanel-S8P0J97f.js → DesignPanel-Bl4luWDV.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-I8C3iGvz.js} +6 -6
  15. package/dist/{DictView-bIS5-rK-.js → DictView-B4a7Hs1X.js} +9 -9
  16. package/dist/InvOrganization-q4T3y8dQ.js +260 -0
  17. package/dist/{Org-kXHSjsgJ.js → Org-BTGTrAVz.js} +3 -3
  18. package/dist/{Preview-CRyiwUIR.js → Preview-pHD84xqI.js} +1 -1
  19. package/dist/{ReportDefine-WZYIx8Sm.js → ReportDefine-DnnCNQWS.js} +1 -1
  20. package/dist/{ReportDesign-D-7GKgpb.js → ReportDesign-BnI_Q4pg.js} +10 -10
  21. package/dist/{ReportQuery-BIIJny6w.js → ReportQuery-Dby2MmtM.js} +5 -5
  22. package/dist/{ReportQueryFrom-OoUl7N2O.js → ReportQueryFrom-Blm1N8P1.js} +1 -1
  23. package/dist/{ReportQueryFrom.vue_vue_type_style_index_0_lang-B878fgj8.js → ReportQueryFrom.vue_vue_type_style_index_0_lang-CnG_Ybnt.js} +6 -5
  24. package/dist/{ReportTemplate-Cfeq9US-.js → ReportTemplate-D65RXRY_.js} +11 -11
  25. package/dist/{Role-BwTV2QMH.js → Role-eFZoTpXc.js} +3 -3
  26. package/dist/{RoleAssign-De1JjOun.js → RoleAssign-D9-Y3UNz.js} +3 -3
  27. package/dist/{RolePanel-pUBXsqCM.js → RolePanel-CoUOc3sX.js} +1 -1
  28. package/dist/{RolePanel-E3RcdByM.js → RolePanel-DlFw6HSf.js} +1 -1
  29. package/dist/{RolePanel.vue_vue_type_script_setup_true_lang-B2pQwHb0.js → RolePanel.vue_vue_type_script_setup_true_lang-Clwk-MHw.js} +12 -12
  30. package/dist/{RolePanel.vue_vue_type_script_setup_true_lang-CTIad9_Q.js → RolePanel.vue_vue_type_script_setup_true_lang-DKHgNWQP.js} +4 -4
  31. package/dist/{ScrollPanel.vue_vue_type_style_index_0_lang-vMR1fBi0.js → ScrollPanel.vue_vue_type_style_index_0_lang-M2FQJwPU.js} +8 -8
  32. package/dist/{Staff-Czm7A8vI.js → Staff-DFBLCsAd.js} +3 -3
  33. package/dist/StaffInfo-d2CK0oBA.js +4 -0
  34. package/dist/{StaffInfo.vue_vue_type_style_index_0_lang-DMTL7KCh.js → StaffInfo.vue_vue_type_script_setup_true_lang-4m8wK9tq.js} +7 -7
  35. package/dist/{StaffPanel-CHk60LEz.js → StaffPanel-D6aWLKN3.js} +1 -1
  36. package/dist/{StaffPanel.vue_vue_type_script_setup_true_lang-iPKLb5wG.js → StaffPanel.vue_vue_type_script_setup_true_lang-C7YT2CVb.js} +46 -49
  37. package/dist/{SysUser-BGwbttRn.js → SysUser-BdZvYxQH.js} +2 -2
  38. package/dist/{SysUserPanel-BCbKoLKt.js → SysUserPanel-BIVa6LLr.js} +1 -1
  39. package/dist/{SysUserPanel.vue_vue_type_script_setup_true_lang-0QUjnhjF.js → SysUserPanel.vue_vue_type_script_setup_true_lang-BsBKpYR7.js} +1 -2
  40. package/dist/{SystemMenu-BkqZSDKl.js → SystemMenu-C-5VKlHK.js} +51 -49
  41. package/dist/{UserInfo-BsyAcT2d.js → UserInfo-DqXCRZts.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-N3TwfpPx.js} +13 -13
  43. package/dist/{childView-CyuLTUqC.js → childView-B2lSsqS3.js} +1 -1
  44. package/dist/{childView-CF83nhxb.js → childView-DRUNqgjI.js} +1 -1
  45. package/dist/{childView.vue_vue_type_style_index_0_lang-Cch4lE-i.js → childView.vue_vue_type_style_index_0_lang-B9XBDDU_.js} +1 -1
  46. package/dist/{childView.vue_vue_type_style_index_0_lang-CNSgGda3.js → childView.vue_vue_type_style_index_0_lang-oGriyFTv.js} +6 -6
  47. package/dist/{code-rule-Bz-gnktN.js → code-rule-DZC9T6cl.js} +6 -6
  48. package/dist/core.es.js +4 -4
  49. package/dist/{cron-task-CIifSUdW.js → cron-task-BJwPeA5F.js} +11 -11
  50. package/dist/{frameView-_d2mqjjQ.js → frameView-C6wkvok-.js} +15 -14
  51. package/dist/index-DZc3qRTx.js +2650 -0
  52. package/dist/{layoutView-DLKVepB8.js → layoutView-CeJBpZb_.js} +658 -653
  53. package/dist/{login-LREiDfFU.js → login-BOxwzwdB.js} +26 -25
  54. package/dist/{lov-view-DDrIVILB.js → lov-view-DRF-99U4.js} +5 -5
  55. package/dist/{menuInfo-B1FUV-Sk.js → menuInfo-3Sjvs9nM.js} +1 -1
  56. package/dist/{menuInfo.vue_vue_type_style_index_0_lang-Cnk3vdtD.js → menuInfo.vue_vue_type_style_index_0_lang-DrQ560nm.js} +95 -94
  57. package/dist/pda-app-B9tn7jdv.js +696 -0
  58. package/dist/redirect-BqegffKC.js +15 -0
  59. package/dist/{resource-BCwx9fEv.js → resource-BqnxbQNe.js} +7 -7
  60. package/dist/{su-welcome-189A7N4r.js → su-welcome-VwifUK_O.js} +41 -40
  61. package/dist/{sys-config-BZ3sejow.js → sys-config-C0-gSBFO.js} +18 -18
  62. package/dist/udp-core.css +2 -2
  63. package/dist/{utogether-r08LNiIZ.js → utogether-Di1byIum.js} +6 -6
  64. package/package.json +18 -16
  65. package/src/App.vue +3 -3
  66. package/src/components/udp/form-upload.vue +183 -0
  67. package/src/components/udp/index.ts +4 -0
  68. package/src/components/udp/modal-form.vue +180 -0
  69. package/src/components/udp/utils.ts +40 -0
  70. package/src/main.ts +109 -108
  71. package/src/plugins/vxe-table/index.ts +53 -46
  72. package/src/plugins/vxe-table/render.tsx +604 -184
  73. package/src/utils/udp/useRender.ts +420 -0
  74. package/src/views/organization/inv-org/InvOrganization.vue +2 -1
  75. package/src/views/organization/staff/StaffInfo.vue +0 -30
  76. package/src/views/organization/staff/StaffPanel.vue +4 -3
  77. package/src/views/system/menu/AuthorityPanel.vue +2 -2
  78. package/src/views/system/menu/SystemMenu.vue +197 -191
  79. package/src/views/system/menu/menuInfo.vue +11 -6
  80. package/src/views/system/role/AuthorityInfo.vue +1 -19
  81. package/src/views/system/sysUser/SysUserPanel.vue +1 -1
  82. package/src/views/udev/dict/DictView.vue +2 -2
  83. package/src/views/uhome/components/menu-favorite.vue +1 -1
  84. package/src/views/uhome/su-welcome.vue +1 -1
  85. package/src/views/ulogin/login.vue +1 -1
  86. package/types/global.d.ts +0 -1
  87. package/vite.config.ts +9 -2
  88. package/dist/InvOrganization-MuM2jtsG.js +0 -66
  89. package/dist/StaffInfo-DJzvBuxy.js +0 -4
  90. package/dist/core.umd.js +0 -173
  91. package/dist/index-BKIw8tSn.js +0 -9195
  92. package/dist/pda-app-CRhVGijN.js +0 -2209
  93. package/dist/redirect-DiaNDu8F.js +0 -15
  94. package/src/assets/images/empty.png +0 -0
  95. package/src/assets/images/logo.png +0 -0
  96. package/src/components/ReCountTo/README.md +0 -2
  97. package/src/components/ReCountTo/index.ts +0 -18
  98. package/src/components/ReCountTo/src/normal/index.tsx +0 -165
  99. package/src/components/ReCountTo/src/normal/props.ts +0 -37
  100. package/src/components/ReCountTo/src/rebound/index.tsx +0 -67
  101. package/src/components/ReCountTo/src/rebound/props.ts +0 -14
  102. package/src/components/ReCountTo/src/rebound/rebound.css +0 -77
  103. package/src/components/ReCropper/index.ts +0 -14
  104. package/src/components/ReCropper/src/index.tsx +0 -141
  105. package/src/components/ReFlicker/index.css +0 -39
  106. package/src/components/ReFlicker/index.ts +0 -50
  107. package/src/components/ReFlop/index.ts +0 -14
  108. package/src/components/ReFlop/src/Filpper.tsx +0 -99
  109. package/src/components/ReFlop/src/filpper.css +0 -184
  110. package/src/components/ReFlop/src/index.vue +0 -126
  111. package/src/components/ReFlowChart/index.ts +0 -24
  112. package/src/components/ReFlowChart/src/Control.vue +0 -139
  113. package/src/components/ReFlowChart/src/DataDialog.vue +0 -12
  114. package/src/components/ReFlowChart/src/NodePanel.vue +0 -151
  115. package/src/components/ReFlowChart/src/adpterForTurbo.ts +0 -160
  116. package/src/components/ReFlowChart/src/assets/iconfont/iconfont.css +0 -49
  117. package/src/components/ReFlowChart/src/assets/iconfont/iconfont.eot +0 -0
  118. package/src/components/ReFlowChart/src/assets/iconfont/iconfont.js +0 -61
  119. package/src/components/ReFlowChart/src/assets/iconfont/iconfont.json +0 -58
  120. package/src/components/ReFlowChart/src/assets/iconfont/iconfont.svg +0 -47
  121. package/src/components/ReFlowChart/src/assets/iconfont/iconfont.ttf +0 -0
  122. package/src/components/ReFlowChart/src/assets/iconfont/iconfont.woff +0 -0
  123. package/src/components/ReFlowChart/src/assets/iconfont/iconfont.woff2 +0 -0
  124. package/src/components/ReFlowChart/src/config.ts +0 -62
  125. package/src/components/ReSplitPane/index.css +0 -49
  126. package/src/components/ReSplitPane/index.tsx +0 -119
  127. package/src/components/ReSplitPane/resizer.css +0 -45
  128. package/src/components/ReSplitPane/resizer.tsx +0 -30
  129. package/src/components/SuCommon/card/components/Card.vue +0 -148
  130. package/src/components/SuCommon/card/components/DialogForm.vue +0 -127
  131. package/src/components/SuCommon/card/index.vue +0 -142
  132. package/src/components/SuCommon/icon-select/index.vue +0 -241
  133. package/src/components/SuCommon/table/index.vue +0 -208
  134. package/src/components/SuCommon/utils/index.ts +0 -103
  135. package/src/components/SuCommon/utils/slot.tsx +0 -50
  136. package/src/views/components/contextmenu/basic.vue +0 -74
  137. package/src/views/components/contextmenu/context-menu.vue +0 -40
  138. package/src/views/components/contextmenu/menuDynamic.vue +0 -99
  139. package/src/views/components/contextmenu/menuGroup.vue +0 -71
  140. package/src/views/components/count-to/index.vue +0 -43
  141. package/src/views/components/cropping/index.vue +0 -59
  142. package/src/views/components/cropping/picture.jpeg +0 -0
  143. package/src/views/components/split-pane/index.vue +0 -82
  144. 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>