lw-cdp-ui 1.2.48 → 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 -469
  63. package/dist/components/lwLogin/index.vue +0 -511
  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 -346
  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 -19906
  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,391 +0,0 @@
1
- <template>
2
- <!-- 间隔标题 -->
3
- <div v-if="item.component == 'divider'"
4
- class="title-name title-name-divider"
5
- :id="'divider-' + index"
6
- :data-index="index">
7
- <span>
8
- {{ item.label }}
9
- <el-tooltip v-if="item.tips">
10
- <template #content>
11
- <span style="max-width: 300px; display: inline-block;">
12
- {{ item.tips }}
13
- </span>
14
- </template>
15
- <el-icon><el-icon-question-filled /></el-icon>
16
- </el-tooltip>
17
- </span>
18
- <slot :name="item?.options?.component"></slot>
19
-
20
- </div>
21
-
22
- <!-- 表单内容 -->
23
- <el-form-item v-else
24
- :class="{ 'form-item-name-null': !item?.label }"
25
- :prop="getPropName(item)"
26
- :rules="rulesHandle(item)">
27
- <template #label>
28
- {{ item.label }}
29
- <el-tooltip v-if="item.tips"
30
- :raw-content="item?.rawContent"
31
- :content="item.tips">
32
- <el-icon><el-icon-question-filled /></el-icon>
33
- </el-tooltip>
34
- </template>
35
-
36
- <!-- input -->
37
- <template v-if="item.component == 'input'">
38
- <template
39
- v-if="item?.options?.prepend">{{ item?.options.prepend }}</template>
40
- <textToPassword v-model="objItem.value"
41
- :password="item?.options?.password" />
42
- <template
43
- v-if="item?.options?.append">{{ item?.options.append }}</template>
44
-
45
- </template>
46
- <!-- upload -->
47
- <template v-else-if="item.component == 'upload'">
48
- <template v-for="(_item, _index) in objItem?.options.items"
49
- :key="_index">
50
- <lw-upload v-model="_item.value"
51
- :height="item.height"
52
- :width="item.width"
53
- :maxSize="_item.maxSize"
54
- :accept="_item.accept"
55
- :title="_item.label"
56
- :parseData="item.parseData"
57
- :disabled="true"
58
- :multiple="_item?.multiple"
59
- :limit="_item?.limit"
60
- :returnFile="_item?.returnFile"
61
- :tip="_item?.tip"
62
- :apiObj="item.apiObj"></lw-upload>
63
-
64
- </template>
65
- </template>
66
- <!-- checkbox -->
67
- <template v-else-if="item.component == 'checkbox'">
68
- <template v-for="(_item, _index) in objItem?.options.items"
69
- :key="_index">{{ getKeyToLabel(_item.value, objItem?.options.items) }}</template>
70
- </template>
71
- <!-- checkboxGroup 、select、radio -->
72
- <template
73
- v-else-if="item.component == 'checkboxGroup' || item.component == 'select' || item.component == 'radio'">
74
- {{ getKeyToLabel(objItem.value, item?.options.items) }}
75
- </template>
76
-
77
- <!-- switch -->
78
- <template v-else-if="item.component == 'switch'">
79
- {{ objItem.value ? item?.options?.true || '是' : item?.options?.false || '否' }}
80
- </template>
81
- <!-- treeSelect -->
82
- <template v-else-if="item.component == 'treeSelect'">
83
- <el-tree-select v-model="objItem.value"
84
- :props="item?.options?.props"
85
- disabled
86
- :node-Key="item?.options?.nodeKey"
87
- :multiple="item?.options?.multiple"
88
- :check-Strictly="item?.options?.checkStrictly"
89
- :data="item?.options?.items"></el-tree-select>
90
-
91
- </template>
92
- <!-- cascader -->
93
- <template v-else-if="item.component == 'cascader'">
94
- <el-cascader v-model="objItem.value"
95
- style="width: 100%;"
96
- :props="item?.options?.props"
97
- :separator="item?.options?.separator"
98
- disabled
99
- :options="item?.options.items"
100
- clearable></el-cascader>
101
- </template>
102
- <!-- date -->
103
- <template v-else-if="item.component == 'date'">
104
- <template v-if="typeof objItem.value == 'string'">
105
- {{ dayjs(objItem.value).format(item?.options?.valueFormat || 'YYYY-MM-DD HH:mm:ss') }}
106
- </template>
107
- <template v-if="typeof objItem.value == 'object'">
108
- {{ objItem.value.length > 0 ? dayjs(objItem.value[0]).format(item?.options?.valueFormat || 'YYYY-MM-DD HH:mm:ss') + ' - ' + dayjs(objItem.value[1]).format(item?.options?.valueFormat || 'YYYY-MM-DD HH:mm:ss') : '--' }}
109
- </template>
110
- </template>
111
- <!-- number -->
112
- <template v-else-if="item.component == 'number'">
113
- {{ objItem.value }}
114
- <template v-if="item?.options?.suffix">
115
- <span>{{ item?.options.suffix }}</span>
116
- </template>
117
- </template>
118
- <!-- color -->
119
- <template v-else-if="item.component == 'color'">
120
- <el-color-picker v-model="objItem.value"
121
- disabled />
122
- </template>
123
- <!-- rate -->
124
- <template v-else-if="item.component == 'rate'">
125
- <el-rate style="margin-top: 6px;"
126
- v-model="objItem.value"
127
- disabled></el-rate>
128
- </template>
129
- <!-- slider -->
130
- <template v-else-if="item.component == 'slider'">
131
- <el-slider v-model="objItem.value"
132
- :marks="item?.options.marks"
133
- disabled></el-slider>
134
- </template>
135
-
136
- <!-- tags -->
137
- <template v-else-if="item.component == 'tags'">
138
- <div class="tags-list">
139
- <el-tag v-for="tag in objItem.value"
140
- :key="tag">
141
- {{ tag }}
142
- </el-tag>
143
- </div>
144
- </template>
145
-
146
- <!-- 没有组件是component值 就是插槽名称 -->
147
- <template v-else>
148
- <slot :name="item.component"
149
- :itemCur="item"
150
- :formCur="form">
151
- <el-tag type="danger">[{{ item.component }}]
152
- 没有这个默认组件也未自定义插槽内容</el-tag>
153
- </slot>
154
- </template>
155
- <div v-if="item.message"
156
- class="el-form-item-msg">{{ item.message }}</div>
157
- </el-form-item>
158
- </template>
159
-
160
- <script>
161
- import lwUpload from '../lwUpload'
162
- import dayjs from 'dayjs'
163
- import textToPassword from './textToPassword'
164
- export default {
165
- name: 'ViewItem',
166
- data() {
167
- return {
168
- tagVisible: {},
169
- dataForm: {},
170
- objItem: {},
171
- tagValue: ''
172
- }
173
- },
174
- components: {
175
- lwUpload,
176
- textToPassword
177
- },
178
- props: {
179
- item: {
180
- type: Object,
181
- default: () => { }
182
- },
183
- index: {
184
- type: Number,
185
- default: 0
186
- },
187
- form: {
188
- type: Object,
189
- default: () => { }
190
- }
191
- },
192
- watch: {
193
- item: {
194
- handler(val) {
195
- this.objItem = val
196
- },
197
- immediate: true,
198
- deep: true
199
- },
200
- form: {
201
- handler(val) {
202
- if (this.item.component === 'checkbox' || this.item.component === 'upload') {
203
- this.objItem.options?.items?.forEach((option) => {
204
- option.value = this.flattenObject(this.form, option.name, option.value)
205
- });
206
- } else {
207
- this.objItem.value = this.flattenObject(this.form, this.item.name, this.objItem.value)
208
- }
209
-
210
- },
211
- immediate: true,
212
- deep: true
213
- },
214
- objItem: {
215
- handler(val) {
216
- if (val.component === 'checkbox' || val.component === 'upload') {
217
- val.options?.items?.forEach((option) => {
218
- this.unflattenObject(this.form, option.name, option.value)
219
- });
220
- } else {
221
- this.unflattenObject(this.form, val.name, val.value)
222
- }
223
- },
224
- deep: true
225
- },
226
- },
227
- methods: {
228
- flattenObject(obj, key, defaultValue = '') {
229
- if (!key || !obj) { return false }
230
- const keys = key.split('.'); // 将路径拆分成数组
231
-
232
- let current = obj;
233
- // 遍历路径并逐层查找
234
- for (let i = 0; i < keys.length; i++) {
235
- // 如果当前层级不存在,则创建该层级对象
236
- if (current[keys[i]] === undefined) {
237
- current[keys[i]] = (i === keys.length - 1) ? defaultValue : {}; // 如果是最后一个层级,设为默认值,否则创建空对象
238
- }
239
- // 否则,继续向下查找
240
- current = current[keys[i]];
241
- }
242
- return current;
243
- },
244
- unflattenObject(obj, path, value) {
245
- if (!path || !obj) { return false }
246
- const keys = path.split('.'); // 按点分隔路径
247
-
248
- keys.forEach((key, index) => {
249
- if (index === keys.length - 1) {
250
- // 最后一级,直接赋值
251
- obj[key] = value;
252
- } else {
253
- // 如果不存在该层级,创建空对象
254
- if (!obj[key] || typeof obj[key] !== 'object') {
255
- obj[key] = {};
256
- }
257
- obj = obj[key]; // 进入下一层
258
- }
259
- });
260
-
261
- },
262
- // prop NAME
263
- getPropName(item) {
264
- if (item.component == 'checkbox' || item.component == 'upload') {
265
- return item?.options.items[0].name
266
- } else {
267
- return item.name
268
- }
269
- },
270
- // 处理动态必填
271
- rulesHandle(item) {
272
- if (item.requiredHandle) {
273
- try {
274
- const requiredHandleFunc = new Function("form", `return ${item.requiredHandle.replace(/\$/g, "form")}`);
275
- const exp = requiredHandleFunc(this.form);
276
-
277
- const requiredRule = item.rules.find(t => 'required' in t);
278
- if (requiredRule) {
279
- requiredRule.required = exp;
280
- }
281
- } catch (error) {
282
- console.error("Error requiredHandle function:", error);
283
- }
284
- }
285
- return item.rules;
286
- },
287
- // key to label
288
- getKeyToLabel(val, items = []) {
289
- let item = items.find(item => { return item.value == val })
290
- return item?.label || val || '--'
291
- },
292
- dayjs: dayjs
293
- }
294
- }
295
- </script>
296
-
297
-
298
- <style lang="scss" scoped>
299
- :deep(.el-col) {
300
- &:first-child {
301
- .title-name {
302
- border: 0;
303
- padding-top: 25px;
304
- margin-top: 0;
305
- }
306
- }
307
- }
308
-
309
- .title-name {
310
- font-size: 18px;
311
- font-weight: bold;
312
- margin-bottom: 10px;
313
- margin-top: 25px;
314
- border-top: 10px solid #f5f7fa;
315
- padding-top: 20px;
316
- display: flex;
317
- align-items: center;
318
- justify-content: space-between;
319
- }
320
-
321
- .form-mini {
322
- display: flex;
323
- width: 100%;
324
- box-sizing: border-box;
325
- }
326
- .form-affix {
327
- min-width: 130px;
328
- padding-left: 20px;
329
- }
330
-
331
- .w-20 {
332
- width: 100px;
333
- }
334
-
335
- :deep(.form-item-name-null) {
336
- > .el-form-item__label {
337
- display: none !important;
338
- }
339
- }
340
- .affix-body {
341
- background-color: var(--el-fill-color-light);
342
- border: 1px solid var(--el-border-color-light);
343
- margin: 0;
344
- position: relative;
345
- &::after {
346
- content: "";
347
- position: absolute;
348
- left: -2px;
349
- right: 0;
350
- height: 16px;
351
- background-color: #ffffff;
352
- top: -17px;
353
- }
354
- .anchor-link {
355
- padding: 0 20px;
356
- height: var(--el-tabs-header-height);
357
- box-sizing: border-box;
358
- list-style: none;
359
- font-size: var(--el-font-size-base);
360
- font-weight: bold;
361
- color: var(--el-text-color-secondary);
362
- position: relative;
363
- height: 40px;
364
- display: inline-block;
365
- line-height: 40px;
366
- cursor: pointer;
367
- border-left: 1px solid transparent;
368
- border-right: 1px solid transparent;
369
- }
370
- .active {
371
- color: var(--el-color-primary);
372
- background-color: var(--el-bg-color-overlay);
373
- border-bottom: 1px solid var(--el-bg-color-overlay);
374
- border-right-color: var(--el-border-color);
375
- border-left: 1px solid var(--el-border-color-light);
376
- border-right: 1px solid var(--el-border-color-light);
377
- &:first-child {
378
- border-left: 1px solid var(--el-fill-color-light);
379
- }
380
- }
381
- }
382
-
383
- :deep(.el-tag) {
384
- & + .button-new-tag {
385
- margin-left: 10px;
386
- }
387
- & + .w-20 {
388
- margin-left: 10px;
389
- }
390
- }
391
- </style>