lw-cdp-ui 1.2.47 → 1.2.49

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 (88) hide show
  1. package/package.json +1 -1
  2. package/dist/assets/images/empty.jpg +0 -0
  3. package/dist/assets/images/login.svg +0 -558
  4. package/dist/assets/images/logo.jpg +0 -0
  5. package/dist/assets/images/logo.svg +0 -78
  6. package/dist/assets/images/logo1.svg +0 -86
  7. package/dist/assets/images/register.svg +0 -351
  8. package/dist/components/lwCronSelect/index.vue +0 -218
  9. package/dist/components/lwFlow/components/lfControl.vue +0 -126
  10. package/dist/components/lwFlow/components/lfNodePanel.vue +0 -98
  11. package/dist/components/lwFlow/config/dagre.js +0 -279
  12. package/dist/components/lwFlow/config/nodesList.js +0 -243
  13. package/dist/components/lwFlow/index.vue +0 -781
  14. package/dist/components/lwFlow/nodeEdit/audienceReceive.vue +0 -262
  15. package/dist/components/lwFlow/nodeEdit/basicSettings.vue +0 -88
  16. package/dist/components/lwFlow/nodeEdit/eventReceive.vue +0 -145
  17. package/dist/components/lwFlow/nodeEdit/index.vue +0 -306
  18. package/dist/components/lwFlow/nodeEdit/sms.vue +0 -107
  19. package/dist/components/lwFlow/nodeEdit/styleSettings.vue +0 -236
  20. package/dist/components/lwFlow/nodes/basisEnd.js +0 -56
  21. package/dist/components/lwFlow/nodes/basisStart.js +0 -56
  22. package/dist/components/lwFlow/nodes/custom.js +0 -129
  23. package/dist/components/lwFlow/nodes/et2lTable.js +0 -132
  24. package/dist/components/lwFlow/nodesData/datas/audienceReceive.js +0 -137
  25. package/dist/components/lwFlow/nodesData/datas/base.js +0 -190
  26. package/dist/components/lwFlow/nodesData/datas/collap.js +0 -95
  27. package/dist/components/lwFlow/nodesData/datas/eventReceive.js +0 -106
  28. package/dist/components/lwFlow/nodesData/datas/expand.js +0 -85
  29. package/dist/components/lwFlow/nodesData/datas/filter.js +0 -85
  30. package/dist/components/lwFlow/nodesData/datas/joiner.js +0 -96
  31. package/dist/components/lwFlow/nodesData/datas/mapper.js +0 -111
  32. package/dist/components/lwFlow/nodesData/datas/reduce.js +0 -69
  33. package/dist/components/lwFlow/nodesData/datas/sms.js +0 -69
  34. package/dist/components/lwFlow/nodesData/datas/source.js +0 -142
  35. package/dist/components/lwFlow/nodesData/datas/target.js +0 -95
  36. package/dist/components/lwFlow/nodesData/datas/timer.js +0 -180
  37. package/dist/components/lwFlow/nodesData/index.js +0 -41
  38. package/dist/components/lwForm/index.vue +0 -631
  39. package/dist/components/lwFormJson/JsonItem.vue +0 -302
  40. package/dist/components/lwFormJson/StatsConfig.vue +0 -544
  41. package/dist/components/lwFormJson/TreeItem.vue +0 -149
  42. package/dist/components/lwFormJson/index.vue +0 -362
  43. package/dist/components/lwFormJson/menuList.js +0 -324
  44. package/dist/components/lwFormMini/FormItem.vue +0 -466
  45. package/dist/components/lwFormMini/ViewItem.vue +0 -391
  46. package/dist/components/lwFormMini/index.vue +0 -421
  47. package/dist/components/lwFormMini/textToPassword.vue +0 -61
  48. package/dist/components/lwFormView/index.vue +0 -390
  49. package/dist/components/lwFormView/textToPassword.vue +0 -59
  50. package/dist/components/lwIconSelect/iconSelect.js +0 -289
  51. package/dist/components/lwIconSelect/index.vue +0 -142
  52. package/dist/components/lwLayout/components/NavMenu.vue +0 -36
  53. package/dist/components/lwLayout/components/aside.vue +0 -295
  54. package/dist/components/lwLayout/components/bu.vue +0 -88
  55. package/dist/components/lwLayout/components/iframeView.vue +0 -57
  56. package/dist/components/lwLayout/components/lang.vue +0 -77
  57. package/dist/components/lwLayout/components/setting.vue +0 -102
  58. package/dist/components/lwLayout/components/sideM.vue +0 -135
  59. package/dist/components/lwLayout/components/tags.vue +0 -388
  60. package/dist/components/lwLayout/components/topbar.vue +0 -69
  61. package/dist/components/lwLayout/components/userbar.vue +0 -214
  62. package/dist/components/lwLayout/index.vue +0 -460
  63. package/dist/components/lwLogin/index.vue +0 -506
  64. package/dist/components/lwLogin/locale/en-us.js +0 -37
  65. package/dist/components/lwLogin/locale/zh-cn.js +0 -37
  66. package/dist/components/lwSearch/date/date.vue +0 -113
  67. package/dist/components/lwSearch/dateRange/dateRange.vue +0 -118
  68. package/dist/components/lwSearch/dates/dates.vue +0 -366
  69. package/dist/components/lwSearch/index.vue +0 -628
  70. package/dist/components/lwSearch/input/input.vue +0 -55
  71. package/dist/components/lwSearch/locale/en-us.js +0 -15
  72. package/dist/components/lwSearch/locale/zh-cn.js +0 -15
  73. package/dist/components/lwSearch/select/select.vue +0 -58
  74. package/dist/components/lwSvgIcon/index.vue +0 -29
  75. package/dist/components/lwTable/index.js +0 -286
  76. package/dist/components/lwTable/index.scss +0 -238
  77. package/dist/components/lwTable/index.vue +0 -344
  78. package/dist/components/lwTable/locale/en-US.js +0 -26
  79. package/dist/components/lwTable/locale/zh-CN.js +0 -26
  80. package/dist/components/lwTable/useFullscreen.js +0 -73
  81. package/dist/components/lwTableForm/index.vue +0 -662
  82. package/dist/components/lwTableSelect/index.vue +0 -266
  83. package/dist/components/lwTableSelect/tableSelect.js +0 -23
  84. package/dist/components/lwUpload/index.vue +0 -564
  85. package/dist/lw-cdp-ui.esm.js +0 -19893
  86. package/dist/lw-cdp-ui.umd.js +0 -22
  87. package/dist/style.css +0 -1
  88. package/dist/vite.svg +0 -1
@@ -1,344 +0,0 @@
1
- <template>
2
- <div class="baseTablePage-wrap">
3
- <!-- 表格主体 -->
4
- <el-table v-if="!isCard"
5
- ref="multipleTable"
6
- v-loading="loading"
7
- :columns="tableHeaders"
8
- :data="tableData"
9
- :row-key="rowKey"
10
- :max-height="maxHeight"
11
- :size="tableSize"
12
- :stripe="stripe"
13
- :hoverable="hoverable"
14
- highlight-current-row
15
- scrollbar-always-on
16
- :virtual-list-props="virtualListProps"
17
- @current-change="handleCurrentChange"
18
- @selection-change="handleSelectionChange">
19
- <!-- 选择列 -->
20
- <el-table-column v-if="rowSelection"
21
- fixed="left"
22
- type="selection"
23
- width="55" />
24
-
25
- <!-- 数据列 -->
26
- <el-table-column v-for="col in tableHeaders"
27
- :key="col"
28
- :prop="col.dataIndex"
29
- :label="col.title"
30
- :width="col.width"
31
- :min-width="col.minWidth"
32
- :align="col.align ?? 'center'"
33
- :fixed="col.fixed"
34
- :sortable="col.sortable"
35
- :show-overflow-tooltip="col.tooltip">
36
- <!-- 表头插槽 -->
37
- <template #header="{ column, $index }">
38
- <slot v-if="col?.header"
39
- :name="col.header"
40
- :scope="{ column, $index, col }">
41
- <el-tag type="danger">
42
- [{{ col.header }}]没有这个自定义表头
43
- </el-tag>
44
- </slot>
45
- <template v-else>
46
- {{ col.title }}
47
- <el-tooltip v-if="col.tips">
48
- <template #content>
49
- <span style="max-width: 300px; display: inline-block;">
50
- {{ col.tips }}
51
- </span>
52
- </template>
53
- <el-icon>
54
- <component :is="col.icon || 'el-icon-question-filled'" />
55
- </el-icon>
56
- </el-tooltip>
57
- </template>
58
- </template>
59
-
60
- <!-- 单元格内容插槽 -->
61
- <template #default="scope">
62
- <!-- 操作列 -->
63
- <template v-if="col?.operation">
64
- <div v-if="filterOperations(col.operation, scope.row).length <= 3">
65
- <span v-for="op in filterOperations(col.operation, scope.row)"
66
- :key="op">
67
- <!-- 图标按钮 -->
68
- <el-tooltip v-if="op.icon"
69
- :content="op.label"
70
- placement="top">
71
- <el-button type="primary"
72
- size="small"
73
- :icon="op.icon"
74
- :disabled="op.disabled?.(scope.row)"
75
- circle
76
- @click="op.clickFun(scope.row, scope.$index, tableData)" />
77
- </el-tooltip>
78
-
79
- <!-- 文字按钮 -->
80
- <el-button v-else
81
- type="primary"
82
- text
83
- size="small"
84
- :disabled="op.disabled?.(scope.row)"
85
- @click="op.clickFun(scope.row, scope.$index, tableData)">
86
- {{ op.label }}
87
- </el-button>
88
- </span>
89
- </div>
90
-
91
- <!-- 更多操作下拉菜单 -->
92
- <div v-else>
93
- <!-- 显示前2个按钮 -->
94
- <span v-for="op in filterOperations(col.operation, scope.row).slice(0, 2)"
95
- :key="op">
96
- <el-tooltip v-if="op.icon"
97
- :content="op.label"
98
- placement="top">
99
- <el-button type="primary"
100
- size="small"
101
- :icon="op.icon"
102
- :disabled="op.disabled?.(scope.row)"
103
- circle
104
- @click="op.clickFun(scope.row, scope.$index, tableData)" />
105
- </el-tooltip>
106
-
107
- <el-button v-else
108
- type="primary"
109
- text
110
- size="small"
111
- :disabled="op.disabled?.(scope.row)"
112
- @click="op.clickFun(scope.row, scope.$index, tableData)">
113
- {{ op.label }}
114
- </el-button>
115
- </span>
116
-
117
- <el-dropdown>
118
- <el-button size="small"
119
- type="primary"
120
- link>
121
- <el-icon class="more-btn"
122
- size="16">
123
- <el-icon-more-filled />
124
- </el-icon>
125
- </el-button>
126
- <template #dropdown>
127
- <el-dropdown-menu>
128
- <el-dropdown-item v-for="op in filterOperations(col.operation, scope.row).slice(2)"
129
- :key="op"
130
- @click="op.clickFun(scope.row, scope.$index, tableData)">
131
- {{ op.label }}
132
- </el-dropdown-item>
133
- </el-dropdown-menu>
134
- </template>
135
- </el-dropdown>
136
- </div>
137
- </template>
138
-
139
- <!-- 其他渲染类型 -->
140
- <template v-else>
141
- <!-- 自定义渲染 -->
142
- <div v-if="col.eleRender">
143
- <span v-html="col.eleRender(scope.row, scope.$index)"
144
- @click="col.clickFun?.(scope.row, scope.$index, tableData)" />
145
- </div>
146
-
147
- <!-- 图片列 -->
148
- <div v-else-if="col.type === 'img'">
149
- <el-image style="height: 28px"
150
- :src="scope.row[col.dataIndex] || '/static/images/empty.jpg'"
151
- :preview-src-list="[scope.row[col.dataIndex]]"
152
- fit="cover"
153
- :z-index="99"
154
- :preview-teleported="true" />
155
- </div>
156
-
157
- <!-- 选项列 -->
158
- <div v-else-if="!col.switch && col.options?.length">
159
- <template v-if="scope.row.isEdit && col.canEdit">
160
- <el-select v-model="scope.row[col.editSource]"
161
- :value-key="col.editValue || 'code'"
162
- class="select-select number"
163
- placeholder=""
164
- allow-clear
165
- allow-search
166
- filter-option
167
- @change="val => col.callback(val, scope.row)">
168
- <el-option v-for="item in col.options"
169
- :key="item"
170
- :value="item">
171
- {{ col.editValue ? item[col.editValue] : item.name }}
172
- </el-option>
173
- </el-select>
174
- </template>
175
- <template v-else>
176
- <span v-for="(item, index) in col.options"
177
- :key="item + index">
178
- <span
179
- v-if="scope.row[col.dataIndex] == item[col.editValue || 'code']">
180
- <span v-if="item.statusColor"
181
- :style="`background-color: ${item.statusColor}; border-radius: 100%; padding: 4px; display: inline-block; margin-right: 5px;`" />
182
- {{ col.editValue ? item[col.editValue] : item.name }}
183
- </span>
184
- </span>
185
- </template>
186
- </div>
187
-
188
- <!-- 其他简单渲染 -->
189
- <template v-else>
190
- {{ scope.row[col.dataIndex] ?? (scope.row[col.dataIndex] === 0 ? '0' : '') }}
191
- </template>
192
- </template>
193
- </template>
194
- </el-table-column>
195
- </el-table>
196
-
197
- <!-- 卡片主题 -->
198
- <div v-else
199
- class="table-card-list"
200
- :style="{ minHeight: maxHeight }">
201
- <el-row :gutter="20">
202
- <VueSelecto dragContainer=".table-card-list"
203
- boundContainer=".table-card-list"
204
- :selectableTargets="['.table-card-item']"
205
- :selectByClick="true"
206
- :selectFromInside="true"
207
- :continueSelect="false"
208
- :toggleContinueSelect='"shift"'
209
- :keyContainer="window"
210
- :hitRate="50"
211
- @select="onSelect" />
212
- <el-col :span="6"
213
- v-for="item in tableData">
214
- <div class="table-card-item"
215
- :data-item="JSON.stringify(item)">
216
- <slot name="cardItem"
217
- :item="item"></slot>
218
- </div>
219
- </el-col>
220
- <el-col :span="24"
221
- v-if="tableData.length == 0">
222
- <el-empty description="暂无数据" />
223
- </el-col>
224
- </el-row>
225
- </div>
226
-
227
- <!-- 分页工具栏 -->
228
- <div v-if="isShowPagination"
229
- class="pagination-block">
230
- <!-- 表格工具栏 -->
231
- <div class="tool-block">
232
- <template v-if="!hideTool">
233
- <!-- 刷新按钮 -->
234
- <el-tooltip :content="$t('btn.refresh')">
235
- <el-icon size="20"
236
- @click="refresh">
237
- <el-icon-refresh />
238
- </el-icon>
239
- </el-tooltip>
240
-
241
- <!-- 显示方式 -->
242
- <el-tooltip v-if="!hideCard"
243
- :content="isCard ? '表格显示': '卡片显示'">
244
- <el-icon size="20"
245
- @click="isCard = !isCard">
246
- <el-icon-postcard v-if="!isCard" />
247
- <el-icon-document v-else />
248
- </el-icon>
249
- </el-tooltip>
250
-
251
- <!-- 表格大小设置 -->
252
- <el-dropdown @command="handleSelect">
253
- <span class="dropdown-trigger">
254
- <el-tooltip :content="$t('lwTable.tools.lineHeightName')">
255
- <el-icon size="20">
256
- <el-icon-set-up />
257
- </el-icon>
258
- </el-tooltip>
259
- </span>
260
- <template #dropdown>
261
- <el-dropdown-menu>
262
- <el-dropdown-item command="small">
263
- {{ $t('lwTable.tools.lineHeight.mini') }}
264
- </el-dropdown-item>
265
- <el-dropdown-item command="medium">
266
- {{ $t('lwTable.tools.lineHeight.small') }}
267
- </el-dropdown-item>
268
- <el-dropdown-item command="large">
269
- {{ $t('lwTable.tools.lineHeight.medium') }}
270
- </el-dropdown-item>
271
- </el-dropdown-menu>
272
- </template>
273
- </el-dropdown>
274
-
275
- <!-- 列设置 -->
276
- <el-popover placement="top-start"
277
- :title="$t('lwTable.tools.columnsSetting')"
278
- :width="400"
279
- trigger="hover">
280
- <template #reference>
281
- <el-icon size="20">
282
- <el-icon-setting />
283
- </el-icon>
284
- </template>
285
-
286
- <el-checkbox v-model="allCheck"
287
- @change="checkAll">
288
- {{ $t('lwTable.tools.allCheck') }},{{ $t('lwTable.tools.hasChecked') }}{{ checkedKeys.length }}/{{ treeData.length }}
289
- </el-checkbox>
290
-
291
- <el-checkbox-group v-model="checkedKeys"
292
- @change="treeCheck">
293
- <el-checkbox v-for="item in treeData"
294
- :key="item.key"
295
- :label="item.title"
296
- :value="item.key">
297
- {{ item.title }}
298
- </el-checkbox>
299
- </el-checkbox-group>
300
-
301
- <div class="fix-num">
302
- {{ $t('lwTable.tools.table_before') }}
303
- <el-input-number v-model="fixNum"
304
- :min="0"
305
- :max="10"
306
- size="small" />
307
- {{ $t('lwTable.tools.column_fixed') }}
308
- </div>
309
- </el-popover>
310
-
311
- <!-- 全屏按钮 -->
312
- <el-tooltip
313
- :content="isFullscreen ? $t('lwTable.tools.cancel') : $t('lwTable.tools.fullScreen')">
314
- <el-icon v-if="!isFullscreen"
315
- class="icon-fullscreen"
316
- @click="tableToggleFullScreen">
317
- <el-icon-full-screen />
318
- </el-icon>
319
- <el-icon v-if="isFullscreen"
320
- class="icon-fullscreen-exit"
321
- @click="tableToggleFullScreen">
322
- <el-icon-full-screen />
323
- </el-icon>
324
- </el-tooltip>
325
- </template>
326
- </div>
327
-
328
- <!-- 分页器 -->
329
- <el-pagination background
330
- size="small"
331
- :current-page.sync="parseFloat(searchParams.page).toString() == 'NaN' ? 1 : searchParams.page"
332
- :page-size="searchParams.size || 10"
333
- :total="totalCount"
334
- :page-sizes="pageSizes"
335
- layout="total, prev, pager, next, sizes, jumper"
336
- @size-change="sizeChange"
337
- @current-change="currentChange" />
338
- </div>
339
- </div>
340
- </template>
341
- <script src="./index.js"></script>
342
- <style lang="scss" scoped>
343
- @import "./index.scss";
344
- </style>
@@ -1,26 +0,0 @@
1
- export default {
2
- lwTable: {
3
- tools: {
4
- lineHeightName: 'row height',
5
- lineHeight: {
6
- mini: 'Compact',
7
- small: 'Medium',
8
- medium: 'High',
9
- large: 'Extra High'
10
- },
11
- border: 'Border',
12
- columnsSetting: 'Column Settings',
13
- allCheck: 'Select All',
14
- hasChecked: 'Selected',
15
- cancel: 'Cancel',
16
- fullScreen: 'Full Screen',
17
- table_before: 'Before the table',
18
- column_fixed: 'Column fixed',
19
- last_column_fixed: 'Last column fixed',
20
- please_select: 'Please select...',
21
- total: 'total',
22
- recordsPage: 'records Page',
23
- pages: 'pages'
24
- }
25
- }
26
- }
@@ -1,26 +0,0 @@
1
- export default {
2
- lwTable: {
3
- tools: {
4
- lineHeightName: '行高',
5
- lineHeight: {
6
- mini: '紧凑',
7
- small: '中等',
8
- medium: '高',
9
- large: '较高'
10
- },
11
- border: '边框',
12
- columnsSetting: '列设置',
13
- allCheck: '全选',
14
- hasChecked: '已选',
15
- cancel: '取消',
16
- fullScreen: '全屏',
17
- table_before: '表格前',
18
- column_fixed: '列固定',
19
- last_column_fixed: '最后一列固定',
20
- please_select: '请选择...',
21
- total: '共',
22
- recordsPage: '条记录 第',
23
- pages: '页'
24
- }
25
- }
26
- }
@@ -1,73 +0,0 @@
1
- // useFullscreen.js - 全屏功能实现
2
- import { ref, onMounted, onUnmounted } from 'vue'
3
-
4
- export function useFullscreen() {
5
- const isFullscreen = ref(false)
6
-
7
- // 进入全屏
8
- const enterFullscreen = (element) => {
9
- if (element.requestFullscreen) {
10
- element.requestFullscreen()
11
- } else if (element.mozRequestFullScreen) {
12
- // Firefox
13
- element.mozRequestFullScreen()
14
- } else if (element.webkitRequestFullscreen) {
15
- // Chrome, Safari and Opera
16
- element.webkitRequestFullscreen()
17
- } else if (element.msRequestFullscreen) {
18
- // IE/Edge
19
- element.msRequestFullscreen()
20
- }
21
- }
22
-
23
- // 退出全屏
24
- const exitFullscreen = () => {
25
- if (document.exitFullscreen) {
26
- document.exitFullscreen()
27
- } else if (document.mozCancelFullScreen) {
28
- // Firefox
29
- document.mozCancelFullScreen()
30
- } else if (document.webkitExitFullscreen) {
31
- // Chrome, Safari and Opera
32
- document.webkitExitFullscreen()
33
- } else if (document.msExitFullscreen) {
34
- // IE/Edge
35
- document.msExitFullscreen()
36
- }
37
- }
38
-
39
- // 全屏切换
40
- const toggleFullScreen = () => {
41
- if (isFullscreen.value) {
42
- exitFullscreen()
43
- } else {
44
- enterFullscreen(document.documentElement)
45
- }
46
- }
47
-
48
- // 检查全屏状态
49
- const handleFullscreenChange = () => {
50
- isFullscreen.value = Boolean(document.fullscreenElement || document.mozFullScreenElement || document.webkitFullscreenElement || document.msFullscreenElement)
51
- }
52
-
53
- // 监听全屏状态变化
54
- onMounted(() => {
55
- document.addEventListener('fullscreenchange', handleFullscreenChange)
56
- document.addEventListener('webkitfullscreenchange', handleFullscreenChange)
57
- document.addEventListener('mozfullscreenchange', handleFullscreenChange)
58
- document.addEventListener('MSFullscreenChange', handleFullscreenChange)
59
- })
60
-
61
- // 清理监听器
62
- onUnmounted(() => {
63
- document.removeEventListener('fullscreenchange', handleFullscreenChange)
64
- document.removeEventListener('webkitfullscreenchange', handleFullscreenChange)
65
- document.removeEventListener('mozfullscreenchange', handleFullscreenChange)
66
- document.removeEventListener('MSFullscreenChange', handleFullscreenChange)
67
- })
68
-
69
- return {
70
- isFullscreen,
71
- toggle: toggleFullScreen
72
- }
73
- }