@dignite-ng/expand.file-explorer 3.0.0-rc.49 → 3.0.0-rc.50
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/esm2022/lib/components/dome/file-dome.component.mjs +2 -4
- package/esm2022/lib/components/file-edit/file-edit.component.mjs +33 -24
- package/esm2022/lib/components/file-modal/file-modal.component.mjs +16 -20
- package/esm2022/lib/components/file-modal-tree/file-modal-tree.component.mjs +15 -17
- package/esm2022/lib/components/file-picker/file-picker.component.mjs +14 -16
- package/esm2022/lib/file-explorer.module.mjs +24 -10
- package/esm2022/lib/pipe/format-file-size.pipe.mjs +35 -0
- package/esm2022/public-api.mjs +1 -3
- package/fesm2022/dignite-ng-expand.file-explorer.mjs +97 -114
- package/fesm2022/dignite-ng-expand.file-explorer.mjs.map +1 -1
- package/lib/components/dome/file-dome.component.d.ts +0 -1
- package/lib/components/file-edit/file-edit.component.d.ts +6 -4
- package/lib/components/file-modal/file-modal.component.d.ts +1 -4
- package/lib/components/file-modal-tree/file-modal-tree.component.d.ts +1 -3
- package/lib/components/file-picker/file-picker.component.d.ts +0 -3
- package/lib/file-explorer.module.d.ts +2 -1
- package/lib/pipe/format-file-size.pipe.d.ts +14 -0
- package/package.json +1 -1
- package/esm2022/lib/services/file-api.service.mjs +0 -68
- package/lib/services/file-api.service.d.ts +0 -14
|
@@ -1,5 +1,4 @@
|
|
|
1
|
-
import { Component
|
|
2
|
-
import { FileApiService } from '../../services/file-api.service';
|
|
1
|
+
import { Component } from '@angular/core';
|
|
3
2
|
import * as i0 from "@angular/core";
|
|
4
3
|
import * as i1 from "../file-edit/file-edit.component";
|
|
5
4
|
import * as i2 from "../file-picker/file-picker.component";
|
|
@@ -7,7 +6,6 @@ export class FileDomeComponent {
|
|
|
7
6
|
constructor() {
|
|
8
7
|
/**跟随表单提交--已提交的数据,或选择的数据源 */
|
|
9
8
|
this.fileSubmittedData = [];
|
|
10
|
-
this.FileApiService = inject(FileApiService);
|
|
11
9
|
/**选择文件-弹窗的-已选定的文件 */
|
|
12
10
|
this.selectedFileGroup = [];
|
|
13
11
|
}
|
|
@@ -26,4 +24,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.5", ngImpor
|
|
|
26
24
|
type: Component,
|
|
27
25
|
args: [{ selector: 'fe-file-dome', template: "<div class=\"row\">\r\n <div class=\"col\">\r\n <div class=\"card\">\r\n <div class=\"card-header py-2 border-bottom\">Send file stream with form</div>\r\n <div class=\"card-body\">\r\n <fe-file-edit [(fileData)]=\"fileSubmittedData\" (fileDataChange)=\"fileDataChange($event)\"></fe-file-edit>\r\n </div>\r\n </div>\r\n </div>\r\n <div class=\"col\">\r\n <div class=\"card\">\r\n <div class=\"card-header py-2 border-bottom\">Send file stream with form</div>\r\n <div class=\"card-body\">\r\n <fe-file-picker [selectFormFile]=\"selectedFileGroup\" fileContainerName=\"SampleContainer\" (selectedFileChange)=\"_selectedFileChange($event)\" ></fe-file-picker>\r\n </div>\r\n </div>\r\n </div>\r\n</div>" }]
|
|
28
26
|
}] });
|
|
29
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
27
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmlsZS1kb21lLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2ZpbGUtZXhwbG9yZXIvc3JjL2xpYi9jb21wb25lbnRzL2RvbWUvZmlsZS1kb21lLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2ZpbGUtZXhwbG9yZXIvc3JjL2xpYi9jb21wb25lbnRzL2RvbWUvZmlsZS1kb21lLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxlQUFlLENBQUM7Ozs7QUFRMUMsTUFBTSxPQUFPLGlCQUFpQjtJQU45QjtRQVFFLDRCQUE0QjtRQUM1QixzQkFBaUIsR0FBVSxFQUFFLENBQUE7UUFjN0IscUJBQXFCO1FBQ3JCLHNCQUFpQixHQUFPLEVBQUUsQ0FBQTtLQU0zQjtJQVpDLHNCQUFzQjtJQUN0QixjQUFjLENBQUMsS0FBSztRQUNsQixJQUFJLENBQUMscUJBQXFCLEdBQUcsS0FBSyxDQUFBO0lBQ3BDLENBQUM7SUFLRCx1QkFBdUI7SUFDdkIsbUJBQW1CLENBQUMsS0FBSztRQUN2QixJQUFJLENBQUMsaUJBQWlCLEdBQUcsS0FBSyxDQUFBO0lBQ2hDLENBQUM7OEdBdkJVLGlCQUFpQjtrR0FBakIsaUJBQWlCLG9EQ1I5QiwyMEJBaUJNOzsyRkRUTyxpQkFBaUI7a0JBTjdCLFNBQVM7K0JBRUUsY0FBYyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5AQ29tcG9uZW50KHtcbiAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIEBhbmd1bGFyLWVzbGludC9jb21wb25lbnQtc2VsZWN0b3JcbiAgc2VsZWN0b3I6ICdmZS1maWxlLWRvbWUnLFxuICB0ZW1wbGF0ZVVybDogJy4vZmlsZS1kb21lLmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmxzOiBbJy4vZmlsZS1kb21lLmNvbXBvbmVudC5zY3NzJ11cbn0pXG5leHBvcnQgY2xhc3MgRmlsZURvbWVDb21wb25lbnQge1xuXG4gIC8qKui3n+maj+ihqOWNleaPkOS6pC0t5bey5o+Q5Lqk55qE5pWw5o2u77yM5oiW6YCJ5oup55qE5pWw5o2u5rqQICovXG4gIGZpbGVTdWJtaXR0ZWREYXRhOiBhbnlbXSA9IFtdXG5cbiAgLyoq6Lef6ZqP6KGo5Y2V5o+Q5LqkLS3lvoXmj5DkuqTnmoTmlbDmja5cbiAgICogXG4gICAqIEBwYXJhbSDlvoXkuIrkvKDnmoTmlofku7bku6xcbiAgICogQHBhcmFtIOW+heWIoOmZpOW3suS4iuS8oOeahOaWh+S7tuS7rFxuICAgKi9cbiAgZmlsZURhdGFUb0JlU3VibWl0dGVkOiBhbnlcblxuICAvKirot5/pmo/ooajljZXmj5DkuqQtLeaVsOaNruWPkeeUn+aUueWPmOWbnuiwgyAqL1xuICBmaWxlRGF0YUNoYW5nZShldmVudCkge1xuICAgIHRoaXMuZmlsZURhdGFUb0JlU3VibWl0dGVkID0gZXZlbnRcbiAgfVxuXG4gIC8qKumAieaLqeaWh+S7ti3lvLnnqpfnmoQt5bey6YCJ5a6a55qE5paH5Lu2ICovXG4gIHNlbGVjdGVkRmlsZUdyb3VwOmFueVtdPVtdXG5cbiAgLyoqX3NlbGVjdGVkRmlsZeaUueWPmOWbnuiwgyAqL1xuICBfc2VsZWN0ZWRGaWxlQ2hhbmdlKGV2ZW50KSB7XG4gICAgdGhpcy5zZWxlY3RlZEZpbGVHcm91cCA9IGV2ZW50XG4gIH1cbn1cbiIsIjxkaXYgY2xhc3M9XCJyb3dcIj5cclxuICAgIDxkaXYgY2xhc3M9XCJjb2xcIj5cclxuICAgICAgICA8ZGl2IGNsYXNzPVwiY2FyZFwiPlxyXG4gICAgICAgICAgICA8ZGl2IGNsYXNzPVwiY2FyZC1oZWFkZXIgcHktMiBib3JkZXItYm90dG9tXCI+U2VuZCBmaWxlIHN0cmVhbSB3aXRoIGZvcm08L2Rpdj5cclxuICAgICAgICAgICAgPGRpdiBjbGFzcz1cImNhcmQtYm9keVwiPlxyXG4gICAgICAgICAgICAgICAgPGZlLWZpbGUtZWRpdCAgWyhmaWxlRGF0YSldPVwiZmlsZVN1Ym1pdHRlZERhdGFcIiAgIChmaWxlRGF0YUNoYW5nZSk9XCJmaWxlRGF0YUNoYW5nZSgkZXZlbnQpXCI+PC9mZS1maWxlLWVkaXQ+XHJcbiAgICAgICAgICAgIDwvZGl2PlxyXG4gICAgICAgIDwvZGl2PlxyXG4gICAgPC9kaXY+XHJcbiAgICA8ZGl2IGNsYXNzPVwiY29sXCI+XHJcbiAgICAgICAgPGRpdiBjbGFzcz1cImNhcmRcIj5cclxuICAgICAgICAgICAgPGRpdiBjbGFzcz1cImNhcmQtaGVhZGVyIHB5LTIgYm9yZGVyLWJvdHRvbVwiPlNlbmQgZmlsZSBzdHJlYW0gd2l0aCBmb3JtPC9kaXY+XHJcbiAgICAgICAgICAgIDxkaXYgY2xhc3M9XCJjYXJkLWJvZHlcIj5cclxuICAgICAgICAgICAgICAgIDxmZS1maWxlLXBpY2tlciAgW3NlbGVjdEZvcm1GaWxlXT1cInNlbGVjdGVkRmlsZUdyb3VwXCIgZmlsZUNvbnRhaW5lck5hbWU9XCJTYW1wbGVDb250YWluZXJcIiAoc2VsZWN0ZWRGaWxlQ2hhbmdlKT1cIl9zZWxlY3RlZEZpbGVDaGFuZ2UoJGV2ZW50KVwiID48L2ZlLWZpbGUtcGlja2VyPlxyXG4gICAgICAgICAgICA8L2Rpdj5cclxuICAgICAgICA8L2Rpdj5cclxuICAgIDwvZGl2PlxyXG48L2Rpdj4iXX0=
|
|
@@ -1,13 +1,17 @@
|
|
|
1
|
+
/* eslint-disable @angular-eslint/component-selector */
|
|
1
2
|
import { Component, ElementRef, EventEmitter, Input, Output, ViewChild } from '@angular/core';
|
|
2
|
-
import {
|
|
3
|
+
import { GetImageLacolBase64urlService } from '@dignite-ng/expand.core';
|
|
4
|
+
import { FormatFileSizePipe } from '../../pipe/format-file-size.pipe';
|
|
3
5
|
import * as i0 from "@angular/core";
|
|
4
|
-
import * as i1 from "../../
|
|
5
|
-
import * as i2 from "@
|
|
6
|
-
import * as i3 from "@
|
|
7
|
-
import * as i4 from "
|
|
6
|
+
import * as i1 from "../../pipe/format-file-size.pipe";
|
|
7
|
+
import * as i2 from "@dignite-ng/expand.core";
|
|
8
|
+
import * as i3 from "@angular/common";
|
|
9
|
+
import * as i4 from "@abp/ng.core";
|
|
10
|
+
import * as i5 from "../../previews/file-preview.component";
|
|
8
11
|
export class FileEditComponent {
|
|
9
|
-
constructor(
|
|
10
|
-
this.
|
|
12
|
+
constructor(_FormatFileSizePipe, _GetImageLacolBase64urlService) {
|
|
13
|
+
this._FormatFileSizePipe = _FormatFileSizePipe;
|
|
14
|
+
this._GetImageLacolBase64urlService = _GetImageLacolBase64urlService;
|
|
11
15
|
/**是否多选 */
|
|
12
16
|
this._multiple = true;
|
|
13
17
|
/**文件数据--已上传的数据 */
|
|
@@ -16,7 +20,7 @@ export class FileEditComponent {
|
|
|
16
20
|
this.fileDataChange = new EventEmitter();
|
|
17
21
|
/**文件大小限制
|
|
18
22
|
* @param 1mb
|
|
19
|
-
|
|
23
|
+
*/
|
|
20
24
|
this.sizeLimit = 1048576;
|
|
21
25
|
/**文件表格数据 */
|
|
22
26
|
this.filesTableData = [];
|
|
@@ -25,7 +29,7 @@ export class FileEditComponent {
|
|
|
25
29
|
}
|
|
26
30
|
set multiple(v) {
|
|
27
31
|
this._multiple = v;
|
|
28
|
-
if (v) { }
|
|
32
|
+
// if (v) { }
|
|
29
33
|
}
|
|
30
34
|
set fileData(v) {
|
|
31
35
|
this._fileData = v;
|
|
@@ -38,15 +42,16 @@ export class FileEditComponent {
|
|
|
38
42
|
}
|
|
39
43
|
/**获取文件信息改变 */
|
|
40
44
|
async getFileChange(event) {
|
|
41
|
-
|
|
45
|
+
const files = new Array(...event.target.files);
|
|
42
46
|
/**需要等待setfileSizeUnits执行完后在执行其他方法--需要完善 */
|
|
43
47
|
await this.waitFileToAddTable(files);
|
|
44
48
|
this.fileHandling();
|
|
45
49
|
}
|
|
46
50
|
/**等待将文件数据加入到文件表格数据中 */
|
|
47
51
|
waitFileToAddTable(files) {
|
|
48
|
-
|
|
49
|
-
|
|
52
|
+
// eslint-disable-next-line no-async-promise-executor
|
|
53
|
+
return new Promise(async (resolve) => {
|
|
54
|
+
this.filesTableData.push(...(await this.setfileSizeUnits(files)));
|
|
50
55
|
resolve(true);
|
|
51
56
|
});
|
|
52
57
|
}
|
|
@@ -60,32 +65,36 @@ export class FileEditComponent {
|
|
|
60
65
|
}
|
|
61
66
|
/**文件处理-调用回调函数 */
|
|
62
67
|
fileHandling() {
|
|
63
|
-
|
|
68
|
+
const theFilesToBeUploaded = this.filesTableData.filter(el => !el.id);
|
|
64
69
|
//判断图片大小是否超过限制-用于判断表单是否允许提交
|
|
65
|
-
|
|
66
|
-
this.fileDataChange.emit({
|
|
70
|
+
const isSubmit = !this.filesTableData.some(el => el.size > this.sizeLimit);
|
|
71
|
+
this.fileDataChange.emit({
|
|
72
|
+
theFilesToBeUploaded,
|
|
73
|
+
deleteTheUploadedFiles: this.deleteTheUploadedFiles,
|
|
74
|
+
isSubmit,
|
|
75
|
+
});
|
|
67
76
|
}
|
|
68
77
|
/**设置值文件大小单位/ */
|
|
69
78
|
async setfileSizeUnits(files) {
|
|
70
|
-
return new Promise((resolve
|
|
71
|
-
|
|
79
|
+
return new Promise((resolve) => {
|
|
80
|
+
const formattedFiles = [];
|
|
72
81
|
files.forEach(async (file) => {
|
|
73
|
-
file.fileSize = this.
|
|
82
|
+
file.fileSize = this._FormatFileSizePipe.transform(file.size);
|
|
74
83
|
formattedFiles.push(file);
|
|
75
84
|
//设置选择图片的本地url
|
|
76
85
|
if (!file.src)
|
|
77
|
-
file.src = await this.
|
|
86
|
+
file.src = await this._GetImageLacolBase64urlService.get(file);
|
|
78
87
|
});
|
|
79
88
|
resolve(files);
|
|
80
89
|
});
|
|
81
90
|
}
|
|
82
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.5", ngImport: i0, type: FileEditComponent, deps: [{ token: i1.
|
|
83
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.1.5", type: FileEditComponent, selector: "fe-file-edit", inputs: { multiple: "multiple", fileData: "fileData", limit: "limit" }, outputs: { fileDataChange: "fileDataChange" }, viewQueries: [{ propertyName: "fileEdit", first: true, predicate: ["fileEdit"], descendants: true, static: true }], ngImport: i0, template: "<div class=\"input-group mb-3\">\n <input type=\"file\" class=\"form-control\" #fileEdit [multiple]=\"_multiple\" (change)=\"getFileChange($event)\">\n</div>\n\n<table class=\"table\" *ngIf=\"filesTableData.length>0\">\n <thead>\n <tr>\n <th scope=\"col\"></th>\n <th scope=\"col\">{{'FileExplorer::FileName' | abpLocalization}}</th>\n <th scope=\"col\">{{'FileExplorer::FileSize' | abpLocalization}}</th>\n <th scope=\"col\"></th>\n </tr>\n </thead>\n <tbody>\n <ng-container *ngFor=\"let item of filesTableData;let i =index\">\n <tr>\n <td>\n <fe-file-preview [width]=\"'80px'\" [src]=\"item.src\" [name]=\"item.name\" [type]=\"item.type\" [preview]=\"true\"></fe-file-preview>\n </td>\n <th scope=\"row\">\n <div>{{item.name}}</div>\n <div class=\"form-text text-danger\" *ngIf=\"item.size > sizeLimit\">\n {{'FileExplorer::ExceedsMaximumSize' |\n abpLocalization:
|
|
91
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.5", ngImport: i0, type: FileEditComponent, deps: [{ token: i1.FormatFileSizePipe }, { token: i2.GetImageLacolBase64urlService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
92
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.1.5", type: FileEditComponent, selector: "fe-file-edit", inputs: { multiple: "multiple", fileData: "fileData", limit: "limit" }, outputs: { fileDataChange: "fileDataChange" }, viewQueries: [{ propertyName: "fileEdit", first: true, predicate: ["fileEdit"], descendants: true, static: true }], ngImport: i0, template: "<div class=\"input-group mb-3\">\n <input type=\"file\" class=\"form-control\" #fileEdit [multiple]=\"_multiple\" (change)=\"getFileChange($event)\">\n</div>\n\n<table class=\"table\" *ngIf=\"filesTableData.length>0\">\n <thead>\n <tr>\n <th scope=\"col\"></th>\n <th scope=\"col\">{{'FileExplorer::FileName' | abpLocalization}}</th>\n <th scope=\"col\">{{'FileExplorer::FileSize' | abpLocalization}}</th>\n <th scope=\"col\"></th>\n </tr>\n </thead>\n <tbody>\n <ng-container *ngFor=\"let item of filesTableData;let i =index\">\n <tr>\n <td>\n <fe-file-preview [width]=\"'80px'\" [src]=\"item.src\" [name]=\"item.name\" [type]=\"item.type\" [preview]=\"true\"></fe-file-preview>\n </td>\n <th scope=\"row\">\n <div>{{item.name}}</div>\n <div class=\"form-text text-danger\" *ngIf=\"item.size > sizeLimit\">\n {{'FileExplorer::ExceedsMaximumSize' |\n abpLocalization:(sizeLimit|formatFileSize)}}</div>\n </th>\n <td>{{item.fileSize}}</td>\n <td>\n <button class=\"btn btn-sm p-0 btn-light \" (click.stop)=\"deleteFileTableItem(i,item)\">\n <i class=\"fas fa-trash p-2\"></i>\n </button>\n </td>\n </tr>\n </ng-container>\n </tbody>\n</table>", styles: [""], dependencies: [{ kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i4.StopPropagationDirective, selector: "[click.stop]", outputs: ["click.stop"] }, { kind: "component", type: i5.FilePreviewComponent, selector: "fe-file-preview", inputs: ["width", "src", "preview", "type", "name", "className"] }, { kind: "pipe", type: i4.LocalizationPipe, name: "abpLocalization" }, { kind: "pipe", type: i1.FormatFileSizePipe, name: "formatFileSize" }] }); }
|
|
84
93
|
}
|
|
85
94
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.5", ngImport: i0, type: FileEditComponent, decorators: [{
|
|
86
95
|
type: Component,
|
|
87
|
-
args: [{ selector: 'fe-file-edit', template: "<div class=\"input-group mb-3\">\n <input type=\"file\" class=\"form-control\" #fileEdit [multiple]=\"_multiple\" (change)=\"getFileChange($event)\">\n</div>\n\n<table class=\"table\" *ngIf=\"filesTableData.length>0\">\n <thead>\n <tr>\n <th scope=\"col\"></th>\n <th scope=\"col\">{{'FileExplorer::FileName' | abpLocalization}}</th>\n <th scope=\"col\">{{'FileExplorer::FileSize' | abpLocalization}}</th>\n <th scope=\"col\"></th>\n </tr>\n </thead>\n <tbody>\n <ng-container *ngFor=\"let item of filesTableData;let i =index\">\n <tr>\n <td>\n <fe-file-preview [width]=\"'80px'\" [src]=\"item.src\" [name]=\"item.name\" [type]=\"item.type\" [preview]=\"true\"></fe-file-preview>\n </td>\n <th scope=\"row\">\n <div>{{item.name}}</div>\n <div class=\"form-text text-danger\" *ngIf=\"item.size > sizeLimit\">\n {{'FileExplorer::ExceedsMaximumSize' |\n abpLocalization:
|
|
88
|
-
}], ctorParameters: () => [{ type: i1.
|
|
96
|
+
args: [{ selector: 'fe-file-edit', template: "<div class=\"input-group mb-3\">\n <input type=\"file\" class=\"form-control\" #fileEdit [multiple]=\"_multiple\" (change)=\"getFileChange($event)\">\n</div>\n\n<table class=\"table\" *ngIf=\"filesTableData.length>0\">\n <thead>\n <tr>\n <th scope=\"col\"></th>\n <th scope=\"col\">{{'FileExplorer::FileName' | abpLocalization}}</th>\n <th scope=\"col\">{{'FileExplorer::FileSize' | abpLocalization}}</th>\n <th scope=\"col\"></th>\n </tr>\n </thead>\n <tbody>\n <ng-container *ngFor=\"let item of filesTableData;let i =index\">\n <tr>\n <td>\n <fe-file-preview [width]=\"'80px'\" [src]=\"item.src\" [name]=\"item.name\" [type]=\"item.type\" [preview]=\"true\"></fe-file-preview>\n </td>\n <th scope=\"row\">\n <div>{{item.name}}</div>\n <div class=\"form-text text-danger\" *ngIf=\"item.size > sizeLimit\">\n {{'FileExplorer::ExceedsMaximumSize' |\n abpLocalization:(sizeLimit|formatFileSize)}}</div>\n </th>\n <td>{{item.fileSize}}</td>\n <td>\n <button class=\"btn btn-sm p-0 btn-light \" (click.stop)=\"deleteFileTableItem(i,item)\">\n <i class=\"fas fa-trash p-2\"></i>\n </button>\n </td>\n </tr>\n </ng-container>\n </tbody>\n</table>" }]
|
|
97
|
+
}], ctorParameters: () => [{ type: i1.FormatFileSizePipe }, { type: i2.GetImageLacolBase64urlService }], propDecorators: { multiple: [{
|
|
89
98
|
type: Input
|
|
90
99
|
}], fileData: [{
|
|
91
100
|
type: Input
|
|
@@ -97,4 +106,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.5", ngImpor
|
|
|
97
106
|
type: ViewChild,
|
|
98
107
|
args: ['fileEdit', { static: true }]
|
|
99
108
|
}] } });
|
|
100
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"file-edit.component.js","sourceRoot":"","sources":["../../../../../../../packages/file-explorer/src/lib/components/file-edit/file-edit.component.ts","../../../../../../../packages/file-explorer/src/lib/components/file-edit/file-edit.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, EventEmitter, Input, Output, ViewChild } from '@angular/core';\nimport { FileApiService } from '../../services/file-api.service';\n\n@Component({\n  selector: 'fe-file-edit',\n  templateUrl: './file-edit.component.html',\n  styleUrls: ['./file-edit.component.scss']\n})\nexport class FileEditComponent {\n  constructor(\n    public _FileApiService: FileApiService,\n  ) { }\n\n  /**是否多选 */\n  _multiple: boolean = true\n  @Input()\n  public set multiple(v: boolean) {\n    this._multiple = v;\n    if (v) { }\n  }\n  /**文件数据--已上传的数据 */\n  _fileData: any[] = []\n  @Input()\n  public set fileData(v: any[]) {\n    this._fileData = v;\n    if (v.length > 0) {\n      this.getFileChange({ target: { files: v } })\n    }\n  }\n  /** 跟随表单提交--已提交的数据，或选择的数据源--回调*/\n  @Output() fileDataChange = new EventEmitter()\n\n  /**文件大小限制 \n   * @param 1mb\n  */\n  sizeLimit: number = 1048576\n  @Input()\n  public set limit(v: number) {\n    this.sizeLimit = v;\n  }\n\n  /**文件表格数据 */\n  filesTableData: any[] = []\n  /** 待删除已上传的文件们*/\n  deleteTheUploadedFiles: any[] = []\n\n  /**获取文件选择框的元素 */\n  @ViewChild('fileEdit', { static: true }) fileEdit: ElementRef;\n\n\n  /**获取文件信息改变 */\n  async getFileChange(event) {\n    let files = new Array(...event.target.files)\n    /**需要等待setfileSizeUnits执行完后在执行其他方法--需要完善 */\n    await this.waitFileToAddTable(files)\n    this.fileHandling()\n  }\n\n  /**等待将文件数据加入到文件表格数据中 */\n  waitFileToAddTable(files) {\n    return new Promise(async (resolve, rejects) => {\n      this.filesTableData.push(...await this.setfileSizeUnits(files))\n      resolve(true)\n    })\n  }\n\n  /**删除文件表格的项 */\n  deleteFileTableItem(index, item) {\n    this.filesTableData.splice(index, 1)\n    if (item.id) {\n      this.deleteTheUploadedFiles.push(item)\n    }\n    this.fileHandling()\n  }\n\n  /**文件处理-调用回调函数 */\n  fileHandling() {\n    let theFilesToBeUploaded = this.filesTableData.filter(el => !el.id)\n    //判断图片大小是否超过限制-用于判断表单是否允许提交\n    let isSubmit = !this.filesTableData.some(el => el.size > this.sizeLimit);\n    this.fileDataChange.emit({ theFilesToBeUploaded, deleteTheUploadedFiles: this.deleteTheUploadedFiles, isSubmit })\n  }\n\n  /**设置值文件大小单位/ */\n  async setfileSizeUnits(files: File[] | any[]): Promise<any> {\n    return new Promise((resolve, rejects) => {\n      let formattedFiles = []\n      files.forEach(async (file) => {\n        file.fileSize = this._FileApiService.formatFileSize(file.size)\n        formattedFiles.push(file)\n        //设置选择图片的本地url\n        if (!file.src) file.src = await this._FileApiService.getImageLacolBase64Url(file);\n      });\n      resolve(files)\n    })\n  }\n\n}\n","<div class=\"input-group mb-3\">\n    <input type=\"file\" class=\"form-control\" #fileEdit [multiple]=\"_multiple\" (change)=\"getFileChange($event)\">\n</div>\n\n<table class=\"table\" *ngIf=\"filesTableData.length>0\">\n    <thead>\n        <tr>\n            <th scope=\"col\"></th>\n            <th scope=\"col\">{{'FileExplorer::FileName' | abpLocalization}}</th>\n            <th scope=\"col\">{{'FileExplorer::FileSize' | abpLocalization}}</th>\n            <th scope=\"col\"></th>\n        </tr>\n    </thead>\n    <tbody>\n        <ng-container *ngFor=\"let item of filesTableData;let i =index\">\n            <tr>\n                <td>\n                    <fe-file-preview [width]=\"'80px'\" [src]=\"item.src\" [name]=\"item.name\" [type]=\"item.type\" [preview]=\"true\"></fe-file-preview>\n                </td>\n                <th scope=\"row\">\n                    <div>{{item.name}}</div>\n                    <div class=\"form-text text-danger\" *ngIf=\"item.size > sizeLimit\">\n                        {{'FileExplorer::ExceedsMaximumSize' |\n                        abpLocalization:_FileApiService.formatFileSize(sizeLimit)}}</div>\n                </th>\n                <td>{{item.fileSize}}</td>\n                <td>\n                    <button class=\"btn btn-sm p-0 btn-light \" (click.stop)=\"deleteFileTableItem(i,item)\">\n                        <i class=\"fas fa-trash p-2\"></i>\n                    </button>\n                </td>\n            </tr>\n        </ng-container>\n    </tbody>\n</table>"]}
|
|
109
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"file-edit.component.js","sourceRoot":"","sources":["../../../../../../../packages/file-explorer/src/lib/components/file-edit/file-edit.component.ts","../../../../../../../packages/file-explorer/src/lib/components/file-edit/file-edit.component.html"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable @angular-eslint/component-selector */\nimport { Component, ElementRef, EventEmitter, Input, Output, ViewChild } from '@angular/core';\nimport { GetImageLacolBase64urlService } from '@dignite-ng/expand.core';\nimport { FormatFileSizePipe } from '../../pipe/format-file-size.pipe';\n\n@Component({\n  selector: 'fe-file-edit',\n  templateUrl: './file-edit.component.html',\n  styleUrls: ['./file-edit.component.scss'],\n})\nexport class FileEditComponent {\n  constructor(\n    public _FormatFileSizePipe: FormatFileSizePipe,\n    private _GetImageLacolBase64urlService: GetImageLacolBase64urlService,\n  ) {}\n\n  /**是否多选 */\n  _multiple = true;\n  @Input()\n  public set multiple(v: boolean) {\n    this._multiple = v;\n    // if (v) { }\n  }\n  /**文件数据--已上传的数据 */\n  _fileData: any[] = [];\n  @Input()\n  public set fileData(v: any[]) {\n    this._fileData = v;\n    if (v.length > 0) {\n      this.getFileChange({ target: { files: v } });\n    }\n  }\n  /** 跟随表单提交--已提交的数据，或选择的数据源--回调*/\n  @Output() fileDataChange = new EventEmitter();\n\n  /**文件大小限制\n   * @param 1mb\n   */\n  sizeLimit = 1048576;\n  @Input()\n  public set limit(v: number) {\n    this.sizeLimit = v;\n  }\n\n  /**文件表格数据 */\n  filesTableData: any[] = [];\n  /** 待删除已上传的文件们*/\n  deleteTheUploadedFiles: any[] = [];\n\n  /**获取文件选择框的元素 */\n  @ViewChild('fileEdit', { static: true }) fileEdit: ElementRef;\n\n  /**获取文件信息改变 */\n  async getFileChange(event) {\n    const files = new Array(...event.target.files);\n    /**需要等待setfileSizeUnits执行完后在执行其他方法--需要完善 */\n    await this.waitFileToAddTable(files);\n    this.fileHandling();\n  }\n\n  /**等待将文件数据加入到文件表格数据中 */\n  waitFileToAddTable(files) {\n    // eslint-disable-next-line no-async-promise-executor\n    return new Promise(async (resolve) => {\n      this.filesTableData.push(...(await this.setfileSizeUnits(files)));\n      resolve(true);\n    });\n  }\n\n  /**删除文件表格的项 */\n  deleteFileTableItem(index, item) {\n    this.filesTableData.splice(index, 1);\n    if (item.id) {\n      this.deleteTheUploadedFiles.push(item);\n    }\n    this.fileHandling();\n  }\n\n  /**文件处理-调用回调函数 */\n  fileHandling() {\n    const theFilesToBeUploaded = this.filesTableData.filter(el => !el.id);\n    //判断图片大小是否超过限制-用于判断表单是否允许提交\n    const isSubmit = !this.filesTableData.some(el => el.size > this.sizeLimit);\n    this.fileDataChange.emit({\n      theFilesToBeUploaded,\n      deleteTheUploadedFiles: this.deleteTheUploadedFiles,\n      isSubmit,\n    });\n  }\n\n  /**设置值文件大小单位/ */\n  async setfileSizeUnits(files: File[] | any[]): Promise<any> {\n    return new Promise((resolve) => {\n      const formattedFiles = [];\n      files.forEach(async file => {\n        file.fileSize = this._FormatFileSizePipe.transform(file.size);\n        formattedFiles.push(file);\n        //设置选择图片的本地url\n        if (!file.src) file.src = await this._GetImageLacolBase64urlService.get(file);\n      });\n      resolve(files);\n    });\n  }\n}\n","<div class=\"input-group mb-3\">\n    <input type=\"file\" class=\"form-control\" #fileEdit [multiple]=\"_multiple\" (change)=\"getFileChange($event)\">\n</div>\n\n<table class=\"table\" *ngIf=\"filesTableData.length>0\">\n    <thead>\n        <tr>\n            <th scope=\"col\"></th>\n            <th scope=\"col\">{{'FileExplorer::FileName' | abpLocalization}}</th>\n            <th scope=\"col\">{{'FileExplorer::FileSize' | abpLocalization}}</th>\n            <th scope=\"col\"></th>\n        </tr>\n    </thead>\n    <tbody>\n        <ng-container *ngFor=\"let item of filesTableData;let i =index\">\n            <tr>\n                <td>\n                    <fe-file-preview [width]=\"'80px'\" [src]=\"item.src\" [name]=\"item.name\" [type]=\"item.type\" [preview]=\"true\"></fe-file-preview>\n                </td>\n                <th scope=\"row\">\n                    <div>{{item.name}}</div>\n                    <div class=\"form-text text-danger\" *ngIf=\"item.size > sizeLimit\">\n                        {{'FileExplorer::ExceedsMaximumSize' |\n                        abpLocalization:(sizeLimit|formatFileSize)}}</div>\n                </th>\n                <td>{{item.fileSize}}</td>\n                <td>\n                    <button class=\"btn btn-sm p-0 btn-light \" (click.stop)=\"deleteFileTableItem(i,item)\">\n                        <i class=\"fas fa-trash p-2\"></i>\n                    </button>\n                </td>\n            </tr>\n        </ng-container>\n    </tbody>\n</table>"]}
|