@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.
@@ -1,5 +1,4 @@
1
- import { Component, inject } from '@angular/core';
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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmlsZS1kb21lLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2ZpbGUtZXhwbG9yZXIvc3JjL2xpYi9jb21wb25lbnRzL2RvbWUvZmlsZS1kb21lLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2ZpbGUtZXhwbG9yZXIvc3JjL2xpYi9jb21wb25lbnRzL2RvbWUvZmlsZS1kb21lLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ2xELE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSxpQ0FBaUMsQ0FBQzs7OztBQVFqRSxNQUFNLE9BQU8saUJBQWlCO0lBTjlCO1FBUUUsNEJBQTRCO1FBQzVCLHNCQUFpQixHQUFVLEVBQUUsQ0FBQTtRQVN2QixtQkFBYyxHQUFDLE1BQU0sQ0FBQyxjQUFjLENBQUMsQ0FBQTtRQU0zQyxxQkFBcUI7UUFDckIsc0JBQWlCLEdBQU8sRUFBRSxDQUFBO0tBTTNCO0lBWkMsc0JBQXNCO0lBQ3RCLGNBQWMsQ0FBQyxLQUFLO1FBQ2xCLElBQUksQ0FBQyxxQkFBcUIsR0FBRyxLQUFLLENBQUE7SUFDcEMsQ0FBQztJQUtELHVCQUF1QjtJQUN2QixtQkFBbUIsQ0FBQyxLQUFLO1FBQ3ZCLElBQUksQ0FBQyxpQkFBaUIsR0FBRyxLQUFLLENBQUE7SUFDaEMsQ0FBQzs4R0F4QlUsaUJBQWlCO2tHQUFqQixpQkFBaUIsb0RDVDlCLDIwQkFpQk07OzJGRFJPLGlCQUFpQjtrQkFON0IsU0FBUzsrQkFFRSxjQUFjIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBpbmplY3QgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEZpbGVBcGlTZXJ2aWNlIH0gZnJvbSAnLi4vLi4vc2VydmljZXMvZmlsZS1hcGkuc2VydmljZSc7XG5cbkBDb21wb25lbnQoe1xuICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgQGFuZ3VsYXItZXNsaW50L2NvbXBvbmVudC1zZWxlY3RvclxuICBzZWxlY3RvcjogJ2ZlLWZpbGUtZG9tZScsXG4gIHRlbXBsYXRlVXJsOiAnLi9maWxlLWRvbWUuY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybHM6IFsnLi9maWxlLWRvbWUuY29tcG9uZW50LnNjc3MnXVxufSlcbmV4cG9ydCBjbGFzcyBGaWxlRG9tZUNvbXBvbmVudCB7XG5cbiAgLyoq6Lef6ZqP6KGo5Y2V5o+Q5LqkLS3lt7Lmj5DkuqTnmoTmlbDmja7vvIzmiJbpgInmi6nnmoTmlbDmja7mupAgKi9cbiAgZmlsZVN1Ym1pdHRlZERhdGE6IGFueVtdID0gW11cblxuICAvKirot5/pmo/ooajljZXmj5DkuqQtLeW+heaPkOS6pOeahOaVsOaNrlxuICAgKiBcbiAgICogQHBhcmFtIOW+heS4iuS8oOeahOaWh+S7tuS7rFxuICAgKiBAcGFyYW0g5b6F5Yig6Zmk5bey5LiK5Lyg55qE5paH5Lu25LusXG4gICAqL1xuICBmaWxlRGF0YVRvQmVTdWJtaXR0ZWQ6IGFueVxuXG5wcml2YXRlIEZpbGVBcGlTZXJ2aWNlPWluamVjdChGaWxlQXBpU2VydmljZSlcbiAgLyoq6Lef6ZqP6KGo5Y2V5o+Q5LqkLS3mlbDmja7lj5HnlJ/mlLnlj5jlm57osIMgKi9cbiAgZmlsZURhdGFDaGFuZ2UoZXZlbnQpIHtcbiAgICB0aGlzLmZpbGVEYXRhVG9CZVN1Ym1pdHRlZCA9IGV2ZW50XG4gIH1cblxuICAvKirpgInmi6nmlofku7Yt5by556qX55qELeW3sumAieWumueahOaWh+S7tiAqL1xuICBzZWxlY3RlZEZpbGVHcm91cDphbnlbXT1bXVxuXG4gIC8qKl9zZWxlY3RlZEZpbGXmlLnlj5jlm57osIMgKi9cbiAgX3NlbGVjdGVkRmlsZUNoYW5nZShldmVudCkge1xuICAgIHRoaXMuc2VsZWN0ZWRGaWxlR3JvdXAgPSBldmVudFxuICB9XG59XG4iLCI8ZGl2IGNsYXNzPVwicm93XCI+XHJcbiAgICA8ZGl2IGNsYXNzPVwiY29sXCI+XHJcbiAgICAgICAgPGRpdiBjbGFzcz1cImNhcmRcIj5cclxuICAgICAgICAgICAgPGRpdiBjbGFzcz1cImNhcmQtaGVhZGVyIHB5LTIgYm9yZGVyLWJvdHRvbVwiPlNlbmQgZmlsZSBzdHJlYW0gd2l0aCBmb3JtPC9kaXY+XHJcbiAgICAgICAgICAgIDxkaXYgY2xhc3M9XCJjYXJkLWJvZHlcIj5cclxuICAgICAgICAgICAgICAgIDxmZS1maWxlLWVkaXQgIFsoZmlsZURhdGEpXT1cImZpbGVTdWJtaXR0ZWREYXRhXCIgICAoZmlsZURhdGFDaGFuZ2UpPVwiZmlsZURhdGFDaGFuZ2UoJGV2ZW50KVwiPjwvZmUtZmlsZS1lZGl0PlxyXG4gICAgICAgICAgICA8L2Rpdj5cclxuICAgICAgICA8L2Rpdj5cclxuICAgIDwvZGl2PlxyXG4gICAgPGRpdiBjbGFzcz1cImNvbFwiPlxyXG4gICAgICAgIDxkaXYgY2xhc3M9XCJjYXJkXCI+XHJcbiAgICAgICAgICAgIDxkaXYgY2xhc3M9XCJjYXJkLWhlYWRlciBweS0yIGJvcmRlci1ib3R0b21cIj5TZW5kIGZpbGUgc3RyZWFtIHdpdGggZm9ybTwvZGl2PlxyXG4gICAgICAgICAgICA8ZGl2IGNsYXNzPVwiY2FyZC1ib2R5XCI+XHJcbiAgICAgICAgICAgICAgICA8ZmUtZmlsZS1waWNrZXIgIFtzZWxlY3RGb3JtRmlsZV09XCJzZWxlY3RlZEZpbGVHcm91cFwiIGZpbGVDb250YWluZXJOYW1lPVwiU2FtcGxlQ29udGFpbmVyXCIgKHNlbGVjdGVkRmlsZUNoYW5nZSk9XCJfc2VsZWN0ZWRGaWxlQ2hhbmdlKCRldmVudClcIiA+PC9mZS1maWxlLXBpY2tlcj5cclxuICAgICAgICAgICAgPC9kaXY+XHJcbiAgICAgICAgPC9kaXY+XHJcbiAgICA8L2Rpdj5cclxuPC9kaXY+Il19
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 { FileApiService } from '../../services/file-api.service';
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 "../../services/file-api.service";
5
- import * as i2 from "@angular/common";
6
- import * as i3 from "@abp/ng.core";
7
- import * as i4 from "../../previews/file-preview.component";
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(_FileApiService) {
10
- this._FileApiService = _FileApiService;
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
- let files = new Array(...event.target.files);
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
- return new Promise(async (resolve, rejects) => {
49
- this.filesTableData.push(...await this.setfileSizeUnits(files));
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
- let theFilesToBeUploaded = this.filesTableData.filter(el => !el.id);
68
+ const theFilesToBeUploaded = this.filesTableData.filter(el => !el.id);
64
69
  //判断图片大小是否超过限制-用于判断表单是否允许提交
65
- let isSubmit = !this.filesTableData.some(el => el.size > this.sizeLimit);
66
- this.fileDataChange.emit({ theFilesToBeUploaded, deleteTheUploadedFiles: this.deleteTheUploadedFiles, isSubmit });
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, rejects) => {
71
- let formattedFiles = [];
79
+ return new Promise((resolve) => {
80
+ const formattedFiles = [];
72
81
  files.forEach(async (file) => {
73
- file.fileSize = this._FileApiService.formatFileSize(file.size);
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._FileApiService.getImageLacolBase64Url(file);
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.FileApiService }], target: i0.ɵɵFactoryTarget.Component }); }
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:_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>", styles: [""], dependencies: [{ kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.StopPropagationDirective, selector: "[click.stop]", outputs: ["click.stop"] }, { kind: "component", type: i4.FilePreviewComponent, selector: "fe-file-preview", inputs: ["width", "src", "preview", "type", "name", "className"] }, { kind: "pipe", type: i3.LocalizationPipe, name: "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:_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>" }]
88
- }], ctorParameters: () => [{ type: i1.FileApiService }], propDecorators: { multiple: [{
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>"]}