@sl-material/sl-import 1.1.0-beta4 → 1.1.0-beta5
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 +229 -39
- package/index.d.ts +2 -2
- package/package.json +1 -1
- package/sl-import.cjs.js +1 -1
- package/sl-import.es.js +38 -47
- package/sl-import.umd.umd.js +17 -16
package/README.md
CHANGED
|
@@ -5,15 +5,17 @@
|
|
|
5
5
|
## 特性
|
|
6
6
|
|
|
7
7
|
- **多种模板类型** - 内置 5 种预设模板,支持自定义配置
|
|
8
|
-
- **文件分片上传** -
|
|
8
|
+
- **文件分片上传** - 支持大文件分片上传,自动合并,支持延迟上传
|
|
9
9
|
- **多文件上传** - 支持批量文件上传,横向滚动列表展示
|
|
10
10
|
- **上传时机控制** - 支持立即上传和延迟上传两种模式
|
|
11
|
+
- **灵活文件校验** - 可选的文件数量和大小校验,不传则不校验
|
|
11
12
|
- **品牌选择** - 支持静态数据或异步加载品牌列表
|
|
12
13
|
- **图片比例选择** - 支持配置图片裁剪比例选项
|
|
13
14
|
- **日期范围选择** - 支持月份和日期范围选择
|
|
15
|
+
- **统一 Loading 样式** - 文件卡片和全局遮罩使用相同的渐变圆环动画
|
|
14
16
|
- **纯原生实现** - 不依赖 Vue/React 等框架,可在任何环境使用
|
|
15
17
|
- **TypeScript 支持** - 完整的类型定义
|
|
16
|
-
-
|
|
18
|
+
- **标准化国际化** - 支持 zh_CN、en_US、ja_JP、zh_HK、zh_TW、id 等语言
|
|
17
19
|
|
|
18
20
|
## 安装
|
|
19
21
|
|
|
@@ -108,22 +110,69 @@ ImportDialog.open({
|
|
|
108
110
|
|
|
109
111
|
```typescript
|
|
110
112
|
ImportDialog.open({
|
|
111
|
-
|
|
113
|
+
locale: "zh_CN" as I18nLocaleEnum,
|
|
114
|
+
type: ExportTypeEnum.excel,
|
|
112
115
|
templateType: TemplateTypeEnum.BASE,
|
|
116
|
+
templateUrl: "/template/base_template.xlsx",
|
|
117
|
+
tips: ["提示信息 1", "提示信息 2"],
|
|
118
|
+
onConfirm: async (data) => {
|
|
119
|
+
return submitImportMock(data);
|
|
120
|
+
// 可以在这里进行额外的后处理
|
|
121
|
+
},
|
|
113
122
|
uploadConfig: {
|
|
114
123
|
multiple: true,
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
124
|
+
confirmLoading: false,
|
|
125
|
+
maxFileSize: 1000,
|
|
126
|
+
// maxFiles: 2,
|
|
127
|
+
maxFileSizeUnit: "KB",
|
|
128
|
+
// 文件预处理函数:选择文件后立即调用
|
|
129
|
+
customUpload: async (file: File, context) => {
|
|
130
|
+
if (file.name.includes(",")) {
|
|
131
|
+
context?.removeFile(
|
|
132
|
+
context?.fileList.findIndex((f) => f.name === file.name),
|
|
133
|
+
);
|
|
121
134
|
}
|
|
135
|
+
// 返回值会存储在 fileItem.response 中
|
|
136
|
+
return { file };
|
|
137
|
+
},
|
|
138
|
+
},
|
|
139
|
+
});
|
|
140
|
+
```
|
|
141
|
+
|
|
142
|
+
### 文件校验配置
|
|
143
|
+
|
|
144
|
+
```typescript
|
|
145
|
+
ImportDialog.open({
|
|
146
|
+
title: "导入数据",
|
|
147
|
+
templateType: TemplateTypeEnum.BASE,
|
|
148
|
+
uploadConfig: {
|
|
149
|
+
multiple: true,
|
|
150
|
+
// 不配置 maxFiles 和 maxFileSize,则不进行任何校验
|
|
151
|
+
customUpload: async (file, context, onProgress) => {
|
|
152
|
+
return { file };
|
|
153
|
+
},
|
|
154
|
+
},
|
|
155
|
+
onConfirm: async (data) => {
|
|
156
|
+
console.log("上传结果:", data);
|
|
157
|
+
return { success: true };
|
|
158
|
+
},
|
|
159
|
+
});
|
|
160
|
+
```
|
|
161
|
+
|
|
162
|
+
```typescript
|
|
163
|
+
ImportDialog.open({
|
|
164
|
+
title: "导入数据",
|
|
165
|
+
templateType: TemplateTypeEnum.BASE,
|
|
166
|
+
uploadConfig: {
|
|
167
|
+
multiple: true,
|
|
168
|
+
maxFiles: 10, // 限制最多 10 个文件
|
|
169
|
+
maxFileSize: 50, // 限制单个文件最大 50MB
|
|
170
|
+
maxFileSizeUnit: "MB",
|
|
171
|
+
customUpload: async (file, context, onProgress) => {
|
|
122
172
|
return { file };
|
|
123
173
|
},
|
|
124
174
|
},
|
|
125
175
|
onConfirm: async (data) => {
|
|
126
|
-
// 此时文件已上传完成,data.files 包含上传结果
|
|
127
176
|
console.log("上传结果:", data);
|
|
128
177
|
return { success: true };
|
|
129
178
|
},
|
|
@@ -150,7 +199,7 @@ ImportDialog.open({
|
|
|
150
199
|
});
|
|
151
200
|
```
|
|
152
201
|
|
|
153
|
-
### 分片上传(立即上传)
|
|
202
|
+
### 分片上传(立即上传) 注意分片上传目前只支持单个文件上传
|
|
154
203
|
|
|
155
204
|
```typescript
|
|
156
205
|
ImportDialog.open({
|
|
@@ -158,7 +207,7 @@ ImportDialog.open({
|
|
|
158
207
|
templateType: TemplateTypeEnum.BASE,
|
|
159
208
|
uploadConfig: {
|
|
160
209
|
autoUpload: true, // 选择文件后立即开始上传
|
|
161
|
-
maxFileSize: 500,
|
|
210
|
+
maxFileSize: 500, // 可选:限制文件大小为 500MB
|
|
162
211
|
maxFileSizeUnit: "MB",
|
|
163
212
|
chunkedUpload: {
|
|
164
213
|
initUpload: async (fileName, fileSize) => {
|
|
@@ -187,6 +236,58 @@ ImportDialog.open({
|
|
|
187
236
|
});
|
|
188
237
|
```
|
|
189
238
|
|
|
239
|
+
### 分片上传 点击确定上传
|
|
240
|
+
|
|
241
|
+
````typescript
|
|
242
|
+
ImportDialog.open({
|
|
243
|
+
type: ExportTypeEnum.excel,
|
|
244
|
+
title: "分片上传(延迟)",
|
|
245
|
+
templateType: TemplateTypeEnum.BASE,
|
|
246
|
+
tabs: [{ label: "分片延迟上传", key: "chunked-delayed" }],
|
|
247
|
+
tips: [
|
|
248
|
+
"1. 选择文件后不会立即上传",
|
|
249
|
+
"2. 点击确定按钮时才开始分片上传",
|
|
250
|
+
"3. autoUpload: false(默认值)",
|
|
251
|
+
],
|
|
252
|
+
uploadTitle: "选择大文件",
|
|
253
|
+
uploadHint: "选择文件后点击确定开始分片上传",
|
|
254
|
+
acceptTypes: ".xlsx,.xls,.csv,.zip",
|
|
255
|
+
uploadConfig: {
|
|
256
|
+
maxFileSize: 500,
|
|
257
|
+
maxFileSizeUnit: "MB",
|
|
258
|
+
autoUpload: false, // 选择文件后不立即上传,等待点击确定
|
|
259
|
+
chunkedUpload: {
|
|
260
|
+
initUpload: async (fileName: string, fileSize: number) => {
|
|
261
|
+
const response = await initImportTask({ fileName, fileSize });
|
|
262
|
+
console.info("initResult>>>", response);
|
|
263
|
+
return {
|
|
264
|
+
uploadSessionId: response?.uploadSessionId,
|
|
265
|
+
partSize: response?.partSize,
|
|
266
|
+
totalParts: response?.totalParts,
|
|
267
|
+
};
|
|
268
|
+
},
|
|
269
|
+
getResumableConfig: (initResult) => ({
|
|
270
|
+
target: `/newProxy/basic-data-io/api/file/upload/part?uploadSessionId=${initResult.uploadSessionId}`,
|
|
271
|
+
headers: {
|
|
272
|
+
"TCSL-BP-TOKEN":
|
|
273
|
+
window.sessionStorage.getItem("token") || slyToken,
|
|
274
|
+
},
|
|
275
|
+
// query: { uploadSessionId: initResult.uploadSessionId },
|
|
276
|
+
}),
|
|
277
|
+
mergeChunks: async (uploadSessionId: string) => {
|
|
278
|
+
const response = await uploadFileMerge(uploadSessionId);
|
|
279
|
+
|
|
280
|
+
return response;
|
|
281
|
+
},
|
|
282
|
+
},
|
|
283
|
+
},
|
|
284
|
+
onConfirm: async (data) => {
|
|
285
|
+
console.info("openChunkedUploadDelayed>>>", data);
|
|
286
|
+
return { success: true, message: "导入成功" };
|
|
287
|
+
},
|
|
288
|
+
});
|
|
289
|
+
```
|
|
290
|
+
|
|
190
291
|
### 带品牌选择的导入
|
|
191
292
|
|
|
192
293
|
```typescript
|
|
@@ -214,7 +315,7 @@ ImportDialog.open({
|
|
|
214
315
|
return { success: true };
|
|
215
316
|
},
|
|
216
317
|
});
|
|
217
|
-
|
|
318
|
+
````
|
|
218
319
|
|
|
219
320
|
### 自定义日期范围
|
|
220
321
|
|
|
@@ -297,27 +398,28 @@ ImportDialog.open({
|
|
|
297
398
|
|
|
298
399
|
所有上传相关配置统一放在 `uploadConfig` 对象中:
|
|
299
400
|
|
|
300
|
-
| 参数 | 类型 | 默认值 | 说明
|
|
301
|
-
| ----------------- | ----------------------------------------------- | ------- |
|
|
302
|
-
| `autoUpload` | `boolean` | `false` | 是否立即上传文件
|
|
303
|
-
| `multiple` | `boolean` | `false` | 是否支持多文件上传
|
|
304
|
-
| `maxFiles` | `number` |
|
|
305
|
-
| `maxFileSize` | `number` |
|
|
306
|
-
| `maxFileSizeUnit` | `'KB' \| 'MB' \| 'GB'` | `'MB'` | 文件大小单位
|
|
307
|
-
| `customUpload` | `(file, context?, onProgress?) => Promise<any>` | - | 自定义上传函数
|
|
308
|
-
| `chunkedUpload` | `ChunkUploadStrategy` | - | 分片上传策略配置
|
|
309
|
-
| `confirmLoading` | `boolean` | `true` | 确定按钮 loading 控制
|
|
310
|
-
| `onFileChange` | `(files: FileUploadItem[]) => void` | - | 文件列表变化回调
|
|
311
|
-
| `onProgress` | `(file, progress) => void` | - | 上传进度回调
|
|
312
|
-
| `onSuccess` | `(file, response) => void` | - | 上传成功回调
|
|
313
|
-
| `onError` | `(file, error) => void` | - | 上传失败回调
|
|
314
|
-
|
|
315
|
-
|
|
316
|
-
|
|
317
|
-
- `
|
|
401
|
+
| 参数 | 类型 | 默认值 | 说明 |
|
|
402
|
+
| ----------------- | ----------------------------------------------- | ------- | ---------------------------- |
|
|
403
|
+
| `autoUpload` | `boolean` | `false` | 是否立即上传文件 |
|
|
404
|
+
| `multiple` | `boolean` | `false` | 是否支持多文件上传 |
|
|
405
|
+
| `maxFiles` | `number` | - | 最大文件数量,不传则不校验 |
|
|
406
|
+
| `maxFileSize` | `number` | - | 单文件最大大小,不传则不校验 |
|
|
407
|
+
| `maxFileSizeUnit` | `'KB' \| 'MB' \| 'GB'` | `'MB'` | 文件大小单位 |
|
|
408
|
+
| `customUpload` | `(file, context?, onProgress?) => Promise<any>` | - | 自定义上传函数 |
|
|
409
|
+
| `chunkedUpload` | `ChunkUploadStrategy` | - | 分片上传策略配置 |
|
|
410
|
+
| `confirmLoading` | `boolean` | `true` | 确定按钮 loading 控制 |
|
|
411
|
+
| `onFileChange` | `(files: FileUploadItem[]) => void` | - | 文件列表变化回调 |
|
|
412
|
+
| `onProgress` | `(file, progress) => void` | - | 上传进度回调 |
|
|
413
|
+
| `onSuccess` | `(file, response) => void` | - | 上传成功回调 |
|
|
414
|
+
| `onError` | `(file, error) => void` | - | 上传失败回调 |
|
|
415
|
+
|
|
416
|
+
**文件校验配置说明**:
|
|
417
|
+
|
|
418
|
+
- `maxFiles`:限制最大文件数量,不传递则不进行数量校验
|
|
419
|
+
- `maxFileSize` 和 `maxFileSizeUnit` 组合使用来限制文件大小,不传递则不进行大小校验
|
|
318
420
|
- 例如:`maxFileSize: 10, maxFileSizeUnit: 'KB'` 表示最大 10KB
|
|
319
421
|
- 例如:`maxFileSize: 500, maxFileSizeUnit: 'MB'` 表示最大 500MB
|
|
320
|
-
-
|
|
422
|
+
- 校验参数完全可选,可根据需要灵活配置
|
|
321
423
|
|
|
322
424
|
##### 分片上传策略 (ChunkUploadStrategy)
|
|
323
425
|
|
|
@@ -369,13 +471,30 @@ interface Context {
|
|
|
369
471
|
|
|
370
472
|
### 国际化 (I18nLocaleEnum)
|
|
371
473
|
|
|
372
|
-
| 语言
|
|
373
|
-
|
|
|
374
|
-
| 简体中文
|
|
375
|
-
|
|
|
376
|
-
|
|
|
377
|
-
|
|
|
378
|
-
|
|
|
474
|
+
| 语言 | 枚举值 |
|
|
475
|
+
| ---------------- | ------- |
|
|
476
|
+
| 简体中文 | `zh_CN` |
|
|
477
|
+
| 繁體中文(香港) | `zh_HK` |
|
|
478
|
+
| 繁體中文(臺灣) | `zh_TW` |
|
|
479
|
+
| 英语(美国) | `en_US` |
|
|
480
|
+
| 日本语 | `ja_JP` |
|
|
481
|
+
| 印尼语 | `id` |
|
|
482
|
+
|
|
483
|
+
**使用方式**:
|
|
484
|
+
|
|
485
|
+
```typescript
|
|
486
|
+
import { ImportDialog, I18nLocaleEnum } from "@sl-material/sl-import";
|
|
487
|
+
|
|
488
|
+
ImportDialog.open({
|
|
489
|
+
locale: I18nLocaleEnum.ZH_CN, // 简体中文
|
|
490
|
+
// locale: I18nLocaleEnum.ZH_HK, // 繁體中文(香港)
|
|
491
|
+
// locale: I18nLocaleEnum.ZH_TW, // 繁體中文(臺灣)
|
|
492
|
+
// locale: I18nLocaleEnum.EN_US, // 英语(美国)
|
|
493
|
+
// locale: I18nLocaleEnum.JA_JP, // 日本语
|
|
494
|
+
// locale: I18nLocaleEnum.ID, // 印尼语
|
|
495
|
+
// ... 其他配置
|
|
496
|
+
});
|
|
497
|
+
```
|
|
379
498
|
|
|
380
499
|
### 类型定义
|
|
381
500
|
|
|
@@ -422,6 +541,53 @@ interface FileUploadItem {
|
|
|
422
541
|
}
|
|
423
542
|
```
|
|
424
543
|
|
|
544
|
+
## 最新特性
|
|
545
|
+
|
|
546
|
+
### 🎯 灵活的文件校验
|
|
547
|
+
|
|
548
|
+
文件校验参数完全可选,可根据需要灵活配置:
|
|
549
|
+
|
|
550
|
+
```typescript
|
|
551
|
+
// 不进行任何校验
|
|
552
|
+
uploadConfig: {
|
|
553
|
+
multiple: true,
|
|
554
|
+
customUpload: myUploadFunction
|
|
555
|
+
}
|
|
556
|
+
|
|
557
|
+
// 完整校验配置
|
|
558
|
+
uploadConfig: {
|
|
559
|
+
multiple: true,
|
|
560
|
+
maxFiles: 10, // 限制最多 10 个文件
|
|
561
|
+
maxFileSize: 50, // 限制单个文件最大 50MB
|
|
562
|
+
maxFileSizeUnit: "MB",
|
|
563
|
+
customUpload: myUploadFunction
|
|
564
|
+
}
|
|
565
|
+
```
|
|
566
|
+
|
|
567
|
+
### 🌍 标准化国际化
|
|
568
|
+
|
|
569
|
+
支持 6 种语言,使用标准的语言代码格式:
|
|
570
|
+
|
|
571
|
+
- `zh_CN` - 简体中文
|
|
572
|
+
- `zh_HK` - 繁體中文(香港)
|
|
573
|
+
- `zh_TW` - 繁體中文(臺灣)
|
|
574
|
+
- `en_US` - 英语(美国)
|
|
575
|
+
- `ja_JP` - 日本语
|
|
576
|
+
- `id` - 印尼语
|
|
577
|
+
|
|
578
|
+
### ⚡ 统一 Loading 动画
|
|
579
|
+
|
|
580
|
+
文件卡片和全局遮罩使用相同的渐变圆环动画,视觉效果统一且流畅。
|
|
581
|
+
|
|
582
|
+
### 🔄 分片上传延迟模式
|
|
583
|
+
|
|
584
|
+
支持分片上传的延迟模式,文件选择后不会立即上传,用户可以:
|
|
585
|
+
|
|
586
|
+
1. 选择多个文件
|
|
587
|
+
2. 预览文件列表
|
|
588
|
+
3. 手动触发上传或删除文件
|
|
589
|
+
4. 点击确认按钮开始上传
|
|
590
|
+
|
|
425
591
|
## UMD 使用方式
|
|
426
592
|
|
|
427
593
|
```html
|
|
@@ -438,6 +604,30 @@ interface FileUploadItem {
|
|
|
438
604
|
|
|
439
605
|
> **注意**:UMD 版本同样已内联 CSS,无需额外引入样式文件。
|
|
440
606
|
|
|
607
|
+
## 更新日志
|
|
608
|
+
|
|
609
|
+
### v1.1.0-beta4
|
|
610
|
+
|
|
611
|
+
#### 🚀 新增特性
|
|
612
|
+
|
|
613
|
+
- **灵活文件校验**:`maxFiles` 和 `maxFileSize` 参数改为可选,不传则不校验
|
|
614
|
+
- **标准化国际化**:统一语言代码格式为 `zh_CN`、`en_US`、`ja_JP` 等
|
|
615
|
+
- **新增语言支持**:添加 `zh_HK`(繁體中文-香港)支持
|
|
616
|
+
- **统一 Loading 样式**:文件卡片和全局遮罩使用相同的渐变圆环动画
|
|
617
|
+
- **分片上传延迟模式**:支持文件选择后延迟上传,用户可手动控制上传时机
|
|
618
|
+
|
|
619
|
+
#### 🐛 修复问题
|
|
620
|
+
|
|
621
|
+
- 修复 loading 动画跳动问题
|
|
622
|
+
- 修复分片上传延迟模式下的配置问题
|
|
623
|
+
- 优化文件校验逻辑的时机和顺序
|
|
624
|
+
|
|
625
|
+
#### 💎 优化改进
|
|
626
|
+
|
|
627
|
+
- 所有硬编码中文提示改为国际化调用
|
|
628
|
+
- 优化文件大小单位配置,支持 KB、MB、GB
|
|
629
|
+
- 改进错误提示信息的准确性和友好性
|
|
630
|
+
|
|
441
631
|
## License
|
|
442
632
|
|
|
443
633
|
MIT
|
package/index.d.ts
CHANGED
|
@@ -447,11 +447,11 @@ declare namespace types {
|
|
|
447
447
|
export { types }
|
|
448
448
|
|
|
449
449
|
export declare interface UploadConfig {
|
|
450
|
-
/**
|
|
450
|
+
/** 最大文件数量,不传则不校验 */
|
|
451
451
|
maxFiles?: number;
|
|
452
452
|
/** 是否支持多文件上传,默认 false */
|
|
453
453
|
multiple?: boolean;
|
|
454
|
-
/**
|
|
454
|
+
/** 单文件最大大小,不传则不校验 */
|
|
455
455
|
maxFileSize?: number;
|
|
456
456
|
/** 文件大小单位,默认 'MB' */
|
|
457
457
|
maxFileSizeUnit?: FileSizeUnit;
|