@moment-design/material-library 0.1.11 → 0.1.13

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.
package/README.md CHANGED
@@ -1,127 +1,127 @@
1
- # 素材库组件
2
-
3
- ## 使用组件
4
-
5
- `安装依赖`
6
-
7
- ```
8
- npm install @moment-design/material-library --save
9
- ```
10
-
11
- `使用组件`
12
-
13
- ```ts
14
- import MaterialLibrary from "@moment-design/material-library"
15
-
16
- <MaterialLibrary
17
- ref="refLMaterialLibrary"
18
- :config="config"
19
- @choose="(v) => (chooseDatas = v)"
20
- ></MaterialLibrary>
21
- ```
22
-
23
- ## API
24
-
25
- Props
26
-
27
- | 参数名 | 描述 | 类型 | 默认值 |
28
- | -------------- | ---------------------------- | ----------------------------- | ------------------------------- |
29
- | fileType | 素材类型限制 | number | 1[图片],2[文档],3[视频],4[音乐] |
30
- | max | 素材最大数量 | number | 10 |
31
- | dialog | 列表、弹窗样式 | DialogConfig | {} |
32
- | scroll | 左侧分组、右侧内容滚动条高度 | ScrollConfig | {} |
33
- | apis | 素材库相关接口 | ApisConfig | {} |
34
- | customValidate | 自定义校验函数 | (datas) => (true 或 报错信息) | - |
35
-
36
- DialogConfig
37
-
38
- | 参数名 | 描述 | 类型 | 默认值 |
39
- | ------- | --------------------------- | ------- | -------- |
40
- | title | 弹窗标题 | string | 选择素材 |
41
- | visible | 列表(false)、弹窗(true)样式 | boolean | false |
42
- | width | 弹出框宽度 | number | 1160 |
43
-
44
- ScrollConfig
45
-
46
- | 参数名 | 描述 | 类型 | 默认值 |
47
- | ------ | ------------------ | ------ | ------- |
48
- | left | 左侧分组滚动条高度 | string | '430px' |
49
- | right | 右侧内容滚动条高度 | string | '430px' |
50
-
51
- ApisConfig
52
-
53
- | 参数名 | 描述 | 类型 | 默认值 |
54
- | ------------ | ------------------ | ---- | ------ |
55
- | getGroupList | 获取分组列表 | api | - |
56
- | postGroup | 新增、编辑分组 | api | - |
57
- | deleteGroup | 删除分组 | api | - |
58
- | getFileList | 获取分组下素材列表 | api | - |
59
- | deleteFile | 删除分组下的素材 | api | - |
60
- | moveFile | 移动分组 | api | - |
61
- | uploadFile | 上传素材 | api | - |
62
-
63
- Events
64
-
65
- | 事件名 | 描述 | 参数 |
66
- | ------ | ---------- | -------------- |
67
- | choose | 选中的素材 | (datas: any[]) |
68
-
69
- Expose
70
-
71
- | 事件名 | 描述 | 参数 |
72
- | ------ | ---------------------- | ---- |
73
- | open | 主动触发打开选择素材库 | - |
74
-
75
- ## 示例数据
76
-
77
- ```js
78
- const config = {
79
- dialog: {
80
- visible: false,
81
- title: '选择素材',
82
- width: 1160,
83
- },
84
- scroll: {
85
- left: '560px',
86
- right: '560px',
87
- },
88
- fileType: 1,
89
- apis: useMaterialApis(),
90
- };
91
-
92
- const useMaterialApis = {
93
- getGroupList,
94
- postGroup,
95
- deleteGroup,
96
- getFileList,
97
- deleteFile,
98
- moveFile,
99
- uploadFile,
100
- };
101
- ```
102
-
103
- ## Interface
104
-
105
- ```js
106
- export interface IMaterialLibrary {
107
- dialog: {
108
- visible: boolean,
109
- title?: string,
110
- width?: number,
111
- };
112
- scroll?: {
113
- left?: string,
114
- right?: string,
115
- };
116
- fileType?: 1 | 2 | 3 | 4;
117
- apis: {
118
- getGroupList: any,
119
- postGroup: any,
120
- deleteGroup: any,
121
- getFileList: any,
122
- deleteFile: any,
123
- moveFile: any,
124
- uploadFile: any,
125
- };
126
- }
127
- ```
1
+ # 素材库组件
2
+
3
+ ## 使用组件
4
+
5
+ `安装依赖`
6
+
7
+ ```
8
+ npm install @moment-design/material-library --save
9
+ ```
10
+
11
+ `使用组件`
12
+
13
+ ```ts
14
+ import MaterialLibrary from "@moment-design/material-library"
15
+
16
+ <MaterialLibrary
17
+ ref="refLMaterialLibrary"
18
+ :config="config"
19
+ @choose="(v) => (chooseDatas = v)"
20
+ ></MaterialLibrary>
21
+ ```
22
+
23
+ ## API
24
+
25
+ Props
26
+
27
+ | 参数名 | 描述 | 类型 | 默认值 |
28
+ | -------------- | ---------------------------- | ----------------------------- | ------------------------------- |
29
+ | fileType | 素材类型限制 | number | 1[图片],2[文档],3[视频],4[音乐] |
30
+ | max | 素材最大数量 | number | 10 |
31
+ | dialog | 列表、弹窗样式 | DialogConfig | {} |
32
+ | scroll | 左侧分组、右侧内容滚动条高度 | ScrollConfig | {} |
33
+ | apis | 素材库相关接口 | ApisConfig | {} |
34
+ | customValidate | 自定义校验函数 | (datas) => (true 或 报错信息) | - |
35
+
36
+ DialogConfig
37
+
38
+ | 参数名 | 描述 | 类型 | 默认值 |
39
+ | ------- | --------------------------- | ------- | -------- |
40
+ | title | 弹窗标题 | string | 选择素材 |
41
+ | visible | 列表(false)、弹窗(true)样式 | boolean | false |
42
+ | width | 弹出框宽度 | number | 1160 |
43
+
44
+ ScrollConfig
45
+
46
+ | 参数名 | 描述 | 类型 | 默认值 |
47
+ | ------ | ------------------ | ------ | ------- |
48
+ | left | 左侧分组滚动条高度 | string | '430px' |
49
+ | right | 右侧内容滚动条高度 | string | '430px' |
50
+
51
+ ApisConfig
52
+
53
+ | 参数名 | 描述 | 类型 | 默认值 |
54
+ | ------------ | ------------------ | ---- | ------ |
55
+ | getGroupList | 获取分组列表 | api | - |
56
+ | postGroup | 新增、编辑分组 | api | - |
57
+ | deleteGroup | 删除分组 | api | - |
58
+ | getFileList | 获取分组下素材列表 | api | - |
59
+ | deleteFile | 删除分组下的素材 | api | - |
60
+ | moveFile | 移动分组 | api | - |
61
+ | uploadFile | 上传素材 | api | - |
62
+
63
+ Events
64
+
65
+ | 事件名 | 描述 | 参数 |
66
+ | ------ | ---------- | -------------- |
67
+ | choose | 选中的素材 | (datas: any[]) |
68
+
69
+ Expose
70
+
71
+ | 事件名 | 描述 | 参数 |
72
+ | ------ | ---------------------- | ---- |
73
+ | open | 主动触发打开选择素材库 | - |
74
+
75
+ ## 示例数据
76
+
77
+ ```js
78
+ const config = {
79
+ dialog: {
80
+ visible: false,
81
+ title: '选择素材',
82
+ width: 1160,
83
+ },
84
+ scroll: {
85
+ left: '560px',
86
+ right: '560px',
87
+ },
88
+ fileType: 1,
89
+ apis: useMaterialApis(),
90
+ };
91
+
92
+ const useMaterialApis = {
93
+ getGroupList,
94
+ postGroup,
95
+ deleteGroup,
96
+ getFileList,
97
+ deleteFile,
98
+ moveFile,
99
+ uploadFile,
100
+ };
101
+ ```
102
+
103
+ ## Interface
104
+
105
+ ```js
106
+ export interface IMaterialLibrary {
107
+ dialog: {
108
+ visible: boolean,
109
+ title?: string,
110
+ width?: number,
111
+ };
112
+ scroll?: {
113
+ left?: string,
114
+ right?: string,
115
+ };
116
+ fileType?: 1 | 2 | 3 | 4;
117
+ apis: {
118
+ getGroupList: any,
119
+ postGroup: any,
120
+ deleteGroup: any,
121
+ getFileList: any,
122
+ deleteFile: any,
123
+ moveFile: any,
124
+ uploadFile: any,
125
+ };
126
+ }
127
+ ```
@@ -18,75 +18,75 @@
18
18
  color: #55585c;
19
19
  margin-bottom: 24px;
20
20
  }
21
- .l-material-library-content[data-v-c6cf1646] {
21
+ .l-material-library-content[data-v-0ecf57ca] {
22
22
  display: flex;
23
23
  align-items: center;
24
24
  justify-content: space-between;
25
25
  }
26
- .l-material-library-content .label span[data-v-c6cf1646] {
26
+ .l-material-library-content .label span[data-v-0ecf57ca] {
27
27
  color: red;
28
28
  position: relative;
29
29
  top: 2px;
30
30
  margin-right: 6px;
31
31
  }
32
- .l-material-library-content .input[data-v-c6cf1646] {
32
+ .l-material-library-content .input[data-v-0ecf57ca] {
33
33
  width: 390px;
34
34
  }
35
- .l-material-library-group[data-v-d0efd9ca] {
35
+ .l-material-library-group[data-v-c01a8f7e] {
36
36
  width: 230px;
37
37
  margin-right: 24px;
38
38
  }
39
- .l-material-library-group .header[data-v-d0efd9ca] {
39
+ .l-material-library-group .header[data-v-c01a8f7e] {
40
40
  margin-bottom: 16px;
41
41
  display: flex;
42
42
  align-items: center;
43
43
  justify-content: space-between;
44
44
  }
45
- .l-material-library-group .header .title[data-v-d0efd9ca] {
45
+ .l-material-library-group .header .title[data-v-c01a8f7e] {
46
46
  font-size: 16px;
47
47
  font-weight: 600;
48
48
  color: #12141a;
49
49
  }
50
- .l-material-library-group .footer .search[data-v-d0efd9ca] {
50
+ .l-material-library-group .footer .search[data-v-c01a8f7e] {
51
51
  margin-bottom: 8px;
52
52
  }
53
- .l-material-library-group .footer .group-items[data-v-d0efd9ca] {
53
+ .l-material-library-group .footer .group-items[data-v-c01a8f7e] {
54
54
  margin-top: 16px;
55
55
  }
56
- .l-material-library-group .footer .group-items .group-item[data-v-d0efd9ca] {
56
+ .l-material-library-group .footer .group-items .group-item[data-v-c01a8f7e] {
57
57
  height: 46px;
58
58
  display: flex;
59
59
  align-items: center;
60
60
  justify-content: space-between;
61
61
  cursor: pointer;
62
62
  }
63
- .l-material-library-group .footer .group-items .group-item[data-v-d0efd9ca]:hover {
63
+ .l-material-library-group .footer .group-items .group-item[data-v-c01a8f7e]:hover {
64
64
  background-color: #f2f3f5;
65
65
  }
66
- .l-material-library-group .footer .group-items .group-item.active[data-v-d0efd9ca] {
66
+ .l-material-library-group .footer .group-items .group-item.active[data-v-c01a8f7e] {
67
67
  background-color: #f4f7ff;
68
68
  }
69
- .l-material-library-group .footer .group-items .group-item .left[data-v-d0efd9ca] {
69
+ .l-material-library-group .footer .group-items .group-item .left[data-v-c01a8f7e] {
70
70
  display: flex;
71
71
  align-items: center;
72
72
  justify-content: space-between;
73
73
  width: 30px;
74
74
  padding-left: 8px;
75
75
  }
76
- .l-material-library-group .footer .group-items .group-item .left .folder[data-v-d0efd9ca] {
76
+ .l-material-library-group .footer .group-items .group-item .left .folder[data-v-c01a8f7e] {
77
77
  margin-right: 6px;
78
78
  width: 15px;
79
79
  height: 15px;
80
80
  position: relative;
81
81
  top: 1px;
82
82
  }
83
- .l-material-library-group .footer .group-items .group-item .center[data-v-d0efd9ca] {
83
+ .l-material-library-group .footer .group-items .group-item .center[data-v-c01a8f7e] {
84
84
  flex: 1;
85
85
  white-space: nowrap;
86
86
  overflow: hidden;
87
87
  text-overflow: ellipsis;
88
88
  }
89
- .l-material-library-group .footer .group-items .group-item .right[data-v-d0efd9ca] {
89
+ .l-material-library-group .footer .group-items .group-item .right[data-v-c01a8f7e] {
90
90
  width: 30px;
91
91
  padding-right: 16px;
92
92
  }
@@ -221,104 +221,104 @@
221
221
  color: #86909c;
222
222
  line-height: 1.75;
223
223
  }
224
- .change-group-items[data-v-6511b8e9] {
224
+ .change-group-items[data-v-3777c371] {
225
225
  min-height: 350px;
226
226
  }
227
- .change-group-items .item[data-v-6511b8e9] {
227
+ .change-group-items .item[data-v-3777c371] {
228
228
  height: 46px;
229
229
  display: flex;
230
230
  align-items: center;
231
231
  justify-content: space-between;
232
232
  cursor: pointer;
233
233
  }
234
- .change-group-items .item[data-v-6511b8e9]:hover {
234
+ .change-group-items .item[data-v-3777c371]:hover {
235
235
  background-color: #f2f3f5;
236
236
  }
237
- .change-group-items .item.active[data-v-6511b8e9] {
237
+ .change-group-items .item.active[data-v-3777c371] {
238
238
  background-color: #f4f7ff;
239
239
  }
240
- .change-group-items .item .img[data-v-6511b8e9] {
240
+ .change-group-items .item .img[data-v-3777c371] {
241
241
  display: flex;
242
242
  align-items: center;
243
243
  justify-content: space-between;
244
244
  width: 30px;
245
245
  padding-left: 8px;
246
246
  }
247
- .change-group-items .item .img .folder[data-v-6511b8e9] {
247
+ .change-group-items .item .img .folder[data-v-3777c371] {
248
248
  margin-right: 6px;
249
249
  width: 15px;
250
250
  height: 15px;
251
251
  position: relative;
252
252
  top: 1px;
253
253
  }
254
- .change-group-items .item .name[data-v-6511b8e9] {
254
+ .change-group-items .item .name[data-v-3777c371] {
255
255
  flex: 1;
256
256
  white-space: nowrap;
257
257
  overflow: hidden;
258
258
  text-overflow: ellipsis;
259
259
  }
260
- .l-material-library-upload .form-item[data-v-4839e6a6] {
260
+ .l-material-library-upload .form-item[data-v-3fcdc336] {
261
261
  display: flex;
262
262
  align-items: center;
263
263
  margin-bottom: 16px;
264
264
  }
265
- .l-material-library-upload .form-item[data-v-4839e6a6]:not(:last-child) {
265
+ .l-material-library-upload .form-item[data-v-3fcdc336]:not(:last-child) {
266
266
  margin-bottom: 16px;
267
267
  }
268
- .l-material-library-upload .form-item .label[data-v-4839e6a6] {
268
+ .l-material-library-upload .form-item .label[data-v-3fcdc336] {
269
269
  width: 70px;
270
270
  margin-right: 16px;
271
271
  }
272
- .l-material-library-upload .form-item .label span[data-v-4839e6a6] {
272
+ .l-material-library-upload .form-item .label span[data-v-3fcdc336] {
273
273
  color: red;
274
274
  margin-right: 4px;
275
275
  position: relative;
276
276
  top: 2px;
277
277
  }
278
- .l-material-library-upload .upload[data-v-4839e6a6] {
278
+ .l-material-library-upload .upload[data-v-3fcdc336] {
279
279
  margin-top: 16px;
280
280
  }
281
- .l-material-library-upload .upload .tips[data-v-4839e6a6] {
281
+ .l-material-library-upload .upload .tips[data-v-3fcdc336] {
282
282
  margin-bottom: 16px;
283
283
  color: #86909c;
284
284
  }
285
- .l-material-library-upload .upload[data-v-4839e6a6] .mo-upload-progress {
285
+ .l-material-library-upload .upload[data-v-3fcdc336] .mo-upload-progress {
286
286
  display: none;
287
287
  }
288
- .l-material-library-right-content[data-v-4085b1b9] {
288
+ .l-material-library-right-content[data-v-1d0a809d] {
289
289
  flex: 1;
290
290
  }
291
- .l-material-library-right-content .header[data-v-4085b1b9] {
291
+ .l-material-library-right-content .header[data-v-1d0a809d] {
292
292
  display: flex;
293
293
  justify-content: space-between;
294
294
  }
295
- .l-material-library-right-content .header .left[data-v-4085b1b9] {
295
+ .l-material-library-right-content .header .left[data-v-1d0a809d] {
296
296
  display: flex;
297
297
  justify-content: space-between;
298
298
  }
299
- .l-material-library-right-content .header .more-icon-down[data-v-4085b1b9] {
299
+ .l-material-library-right-content .header .more-icon-down[data-v-1d0a809d] {
300
300
  position: relative;
301
301
  top: -1px;
302
302
  margin-left: 6px;
303
303
  font-size: 15px;
304
304
  stroke-width: 5;
305
305
  }
306
- .l-material-library-right-content .toolbar[data-v-4085b1b9] {
306
+ .l-material-library-right-content .toolbar[data-v-1d0a809d] {
307
307
  margin: 16px 0;
308
308
  display: flex;
309
309
  align-items: center;
310
310
  justify-content: space-between;
311
311
  }
312
- .l-material-library-right-content .toolbar .apps[data-v-4085b1b9],
313
- .l-material-library-right-content .toolbar .menu[data-v-4085b1b9] {
312
+ .l-material-library-right-content .toolbar .apps[data-v-1d0a809d],
313
+ .l-material-library-right-content .toolbar .menu[data-v-1d0a809d] {
314
314
  margin-left: 8px;
315
315
  font-size: 20px;
316
316
  stroke-width: 5;
317
317
  }
318
- .l-material-library-right-content .toolbar .apps[data-v-4085b1b9]:hover,
319
- .l-material-library-right-content .toolbar .menu[data-v-4085b1b9]:hover,
320
- .l-material-library-right-content .toolbar .apps.active[data-v-4085b1b9],
321
- .l-material-library-right-content .toolbar .menu.active[data-v-4085b1b9] {
318
+ .l-material-library-right-content .toolbar .apps[data-v-1d0a809d]:hover,
319
+ .l-material-library-right-content .toolbar .menu[data-v-1d0a809d]:hover,
320
+ .l-material-library-right-content .toolbar .apps.active[data-v-1d0a809d],
321
+ .l-material-library-right-content .toolbar .menu.active[data-v-1d0a809d] {
322
322
  color: #1966ff;
323
323
  cursor: pointer;
324
324
  }
package/dist/index.cjs.js CHANGED
@@ -765,7 +765,7 @@ var lodash = { exports: {} };
765
765
  }
766
766
  var runInContext = function runInContext2(context) {
767
767
  context = context == null ? root2 : _.defaults(root2.Object(), context, _.pick(root2, contextProps));
768
- var Array2 = context.Array, Date = context.Date, Error = context.Error, Function2 = context.Function, Math = context.Math, Object2 = context.Object, RegExp2 = context.RegExp, String2 = context.String, TypeError = context.TypeError;
768
+ var Array2 = context.Array, Date = context.Date, Error2 = context.Error, Function2 = context.Function, Math = context.Math, Object2 = context.Object, RegExp2 = context.RegExp, String2 = context.String, TypeError = context.TypeError;
769
769
  var arrayProto = Array2.prototype, funcProto = Function2.prototype, objectProto2 = Object2.prototype;
770
770
  var coreJsData = context["__core-js_shared__"];
771
771
  var funcToString = funcProto.toString;
@@ -4168,7 +4168,7 @@ var lodash = { exports: {} };
4168
4168
  }
4169
4169
  function isNative(value) {
4170
4170
  if (isMaskable(value)) {
4171
- throw new Error(CORE_ERROR_TEXT);
4171
+ throw new Error2(CORE_ERROR_TEXT);
4172
4172
  }
4173
4173
  return baseIsNative(value);
4174
4174
  }
@@ -4709,7 +4709,7 @@ var lodash = { exports: {} };
4709
4709
  if (!variable) {
4710
4710
  source = "with (obj) {\n" + source + "\n}\n";
4711
4711
  } else if (reForbiddenIdentifierChars.test(variable)) {
4712
- throw new Error(INVALID_TEMPL_VAR_ERROR_TEXT);
4712
+ throw new Error2(INVALID_TEMPL_VAR_ERROR_TEXT);
4713
4713
  }
4714
4714
  source = (isEvaluating ? source.replace(reEmptyStringLeading, "") : source).replace(reEmptyStringMiddle, "$1").replace(reEmptyStringTrailing, "$1;");
4715
4715
  source = "function(" + (variable || "obj") + ") {\n" + (variable ? "" : "obj || (obj = {});\n") + "var __t, __p = ''" + (isEscaping ? ", __e = _.escape" : "") + (isEvaluating ? ", __j = Array.prototype.join;\nfunction print() { __p += __j.call(arguments, '') }\n" : ";\n") + source + "return __p\n}";
@@ -4828,7 +4828,7 @@ var lodash = { exports: {} };
4828
4828
  try {
4829
4829
  return apply(func, undefined$1, args);
4830
4830
  } catch (e) {
4831
- return isError(e) ? e : new Error(e);
4831
+ return isError(e) ? e : new Error2(e);
4832
4832
  }
4833
4833
  });
4834
4834
  var bindAll = flatRest(function(object, methodNames) {
@@ -5650,7 +5650,7 @@ function _sfc_render$7(_ctx, _cache, $props, $setup, $data, $options) {
5650
5650
  _: 1
5651
5651
  }, 8, ["visible", "title", "others", "onOk"]);
5652
5652
  }
5653
- var CLeftGroup = /* @__PURE__ */ _export_sfc(_sfc_main$8, [["render", _sfc_render$7], ["__scopeId", "data-v-c6cf1646"]]);
5653
+ var CLeftGroup = /* @__PURE__ */ _export_sfc(_sfc_main$8, [["render", _sfc_render$7], ["__scopeId", "data-v-0ecf57ca"]]);
5654
5654
  var _imports_0$1 = "";
5655
5655
  var cLeft_vue_vue_type_style_index_0_scoped_true_lang = "";
5656
5656
  const _sfc_main$7 = vue.defineComponent({
@@ -5936,7 +5936,7 @@ function _sfc_render$6(_ctx, _cache, $props, $setup, $data, $options) {
5936
5936
  }, 8, ["visible", "others", "onHandle:ok"])
5937
5937
  ], 64);
5938
5938
  }
5939
- var CLeft = /* @__PURE__ */ _export_sfc(_sfc_main$7, [["render", _sfc_render$6], ["__scopeId", "data-v-d0efd9ca"]]);
5939
+ var CLeft = /* @__PURE__ */ _export_sfc(_sfc_main$7, [["render", _sfc_render$6], ["__scopeId", "data-v-c01a8f7e"]]);
5940
5940
  var IconOther = "";
5941
5941
  var IconMusic = "";
5942
5942
  var IconRar = "";
@@ -6917,7 +6917,7 @@ function _sfc_render$3(_ctx, _cache, $props, $setup, $data, $options) {
6917
6917
  _: 1
6918
6918
  }, 8, ["visible", "others", "onHandle:ok"]);
6919
6919
  }
6920
- var CChangeGroup = /* @__PURE__ */ _export_sfc(_sfc_main$3, [["render", _sfc_render$3], ["__scopeId", "data-v-6511b8e9"]]);
6920
+ var CChangeGroup = /* @__PURE__ */ _export_sfc(_sfc_main$3, [["render", _sfc_render$3], ["__scopeId", "data-v-3777c371"]]);
6921
6921
  var cUpload_vue_vue_type_style_index_0_scoped_true_lang = "";
6922
6922
  const _sfc_main$2 = vue.defineComponent({
6923
6923
  name: "",
@@ -7021,7 +7021,7 @@ const _sfc_main$2 = vue.defineComponent({
7021
7021
  accept.value = ".jpg,.jpeg,.png,.bmp,.webp,.gif";
7022
7022
  break;
7023
7023
  case 2:
7024
- accept.value = ".rar,.zip,.ttf,.doc,.docx,.xls,.xlsx,.xlsm,.pdf,.ppt,.pptx,.txt'";
7024
+ accept.value = ".rar,.zip,.ttf,.doc,.docx,.xls,.xlsx,.xlsm,.pdf,.ppt,.pptx,.txt";
7025
7025
  break;
7026
7026
  case 3:
7027
7027
  accept.value = ".swf,.mp4";
@@ -7160,7 +7160,7 @@ function _sfc_render$2(_ctx, _cache, $props, $setup, $data, $options) {
7160
7160
  _: 1
7161
7161
  }, 8, ["visible", "others", "onHandle:ok"]);
7162
7162
  }
7163
- var CUpload = /* @__PURE__ */ _export_sfc(_sfc_main$2, [["render", _sfc_render$2], ["__scopeId", "data-v-4839e6a6"]]);
7163
+ var CUpload = /* @__PURE__ */ _export_sfc(_sfc_main$2, [["render", _sfc_render$2], ["__scopeId", "data-v-3fcdc336"]]);
7164
7164
  var cRight_vue_vue_type_style_index_0_scoped_true_lang = "";
7165
7165
  const _sfc_main$1 = vue.defineComponent({
7166
7166
  name: "",
@@ -7224,6 +7224,10 @@ const _sfc_main$1 = vue.defineComponent({
7224
7224
  init(groupId.value);
7225
7225
  };
7226
7226
  const handlePreview = (item) => {
7227
+ if (item.fileFormat === "txt") {
7228
+ downloadTxtFile(item.filePath, item.fileName);
7229
+ return;
7230
+ }
7227
7231
  const a = document.createElement("a");
7228
7232
  a.setAttribute("href", item.filePath);
7229
7233
  a.setAttribute("target", "_blank");
@@ -7231,6 +7235,23 @@ const _sfc_main$1 = vue.defineComponent({
7231
7235
  a.click();
7232
7236
  setTimeout(() => document.body.removeChild(a), 500);
7233
7237
  };
7238
+ const downloadTxtFile = async (fileUrl, fileName2) => {
7239
+ try {
7240
+ const response = await fetch(fileUrl);
7241
+ if (!response.ok) {
7242
+ throw new Error(`HTTP error! status: ${response.status}`);
7243
+ }
7244
+ const blob = await response.blob();
7245
+ const url = URL.createObjectURL(blob);
7246
+ const a = document.createElement("a");
7247
+ a.href = url;
7248
+ a.download = fileName2;
7249
+ a.click();
7250
+ URL.revokeObjectURL(url);
7251
+ } catch (error) {
7252
+ console.error("\u4E0B\u8F7D\u6587\u4EF6\u65F6\u51FA\u9519:", error);
7253
+ }
7254
+ };
7234
7255
  const handleRemove = (item) => {
7235
7256
  current.value = item;
7236
7257
  visible.value = true;
@@ -7338,7 +7359,8 @@ const _sfc_main$1 = vue.defineComponent({
7338
7359
  initCheckbox,
7339
7360
  handleRemoveOk,
7340
7361
  reset,
7341
- init
7362
+ init,
7363
+ downloadTxtFile
7342
7364
  };
7343
7365
  }
7344
7366
  });
@@ -7532,7 +7554,7 @@ function _sfc_render$1(_ctx, _cache, $props, $setup, $data, $options) {
7532
7554
  }, null, 8, ["config", "onUpload:success"])
7533
7555
  ], 64);
7534
7556
  }
7535
- var CRight = /* @__PURE__ */ _export_sfc(_sfc_main$1, [["render", _sfc_render$1], ["__scopeId", "data-v-4085b1b9"]]);
7557
+ var CRight = /* @__PURE__ */ _export_sfc(_sfc_main$1, [["render", _sfc_render$1], ["__scopeId", "data-v-1d0a809d"]]);
7536
7558
  var index_vue_vue_type_style_index_0_scoped_true_lang = "";
7537
7559
  const _sfc_main = vue.defineComponent({
7538
7560
  name: "MaterialLibrary",