@dignite-ng/expand.file-explorer 3.0.0-rc.33 → 3.0.0-rc.35

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,19 +1,24 @@
1
1
  import { Component, EventEmitter, Input, Output, inject } from '@angular/core';
2
2
  import * as FileService from '../../proxy/dignite/file-explorer/files';
3
3
  import { ConfirmationService, ToasterService } from '@abp/ng.theme.shared';
4
- import { ListService, RestService, LocalizationService, LIST_QUERY_DEBOUNCE_TIME } from '@abp/ng.core';
5
- import { FileDescriptorService } from '../../proxy/dignite/file-explorer/files';
4
+ import { ListService, RestService, LocalizationService, LIST_QUERY_DEBOUNCE_TIME, } from '@abp/ng.core';
5
+ import { FileDescriptorService, } from '../../proxy/dignite/file-explorer/files';
6
6
  import { FileApiService } from '../../services/file-api.service';
7
7
  import { SelectionType } from '@swimlane/ngx-datatable';
8
+ import { FormControl, FormGroup, Validators } from '@angular/forms';
9
+ import { finalize } from 'rxjs';
8
10
  import * as i0 from "@angular/core";
9
11
  import * as i1 from "../../proxy/dignite/file-explorer/files";
10
12
  import * as i2 from "@abp/ng.theme.shared";
11
13
  import * as i3 from "@abp/ng.core";
12
14
  import * as i4 from "../../services/file-api.service";
13
- import * as i5 from "@angular/common";
14
- import * as i6 from "@swimlane/ngx-datatable";
15
- import * as i7 from "../file-modal-tree/file-modal-tree.component";
16
- import * as i8 from "../../previews/file-preview.component";
15
+ import * as i5 from "@angular/forms";
16
+ import * as i6 from "@angular/common";
17
+ import * as i7 from "@swimlane/ngx-datatable";
18
+ import * as i8 from "@ngx-validate/core";
19
+ import * as i9 from "../file-modal-tree/file-modal-tree.component";
20
+ import * as i10 from "../../previews/file-preview.component";
21
+ import * as i11 from "../../pipe/get-directory-name.pipe";
17
22
  var that;
18
23
  export class FileModalComponent {
19
24
  constructor(_FileService, toaster, list, _FileApiService, restService, confirmation, _LocalizationService) {
@@ -30,8 +35,8 @@ export class FileModalComponent {
30
35
  /**是否多选 */
31
36
  this._multiple = false;
32
37
  /**文件大小限制
33
- * @param 1mb
34
- */
38
+ * @param 1mb
39
+ */
35
40
  this.sizeLimit = 1048576;
36
41
  /**模态框状态回调 */
37
42
  this.visibleChange = new EventEmitter();
@@ -42,6 +47,9 @@ export class FileModalComponent {
42
47
  /**dignite-file-modal-tree */
43
48
  /**选择的tree节点 */
44
49
  this._theSelectedTreeNode = '';
50
+ this.isCreateList = false;
51
+ /** 从tree获取来的数据 */
52
+ this.fileGroupList = [];
45
53
  /**图片上传-要上传图片的状态文件列表 */
46
54
  this.uploadPictureStatusList = [];
47
55
  /**文件表格-数据*/
@@ -53,45 +61,57 @@ export class FileModalComponent {
53
61
  this.filters = {};
54
62
  /**文件表格-表格自带选择类型 */
55
63
  this.SelectionType = SelectionType;
56
- /**文件表格-选择的表格数据项 */
57
- this.selectedTable = [];
58
- /**当前选择的table项 id */
59
- this.nowSelectId = '';
60
64
  /**选择文件回调 */
61
65
  this.selectFilefn = new EventEmitter();
62
- /**一个布尔or函数,可用于检查是否要根据条件选择特定行。 */
63
- this.selectCheck = (row, column, value) => {
64
- this.nowSelectId = row.id;
65
- return true;
66
- };
67
- /**判断row是否选中 */
68
- this.selectedcheckbox = (id) => {
69
- return this.selectedTable.some(el => el.id == id);
70
- };
71
66
  /**创建图片的接口,代理中的file类型不匹配,切换为any类型 */
72
67
  this.createFile = (input, config) => this.restService.request({
73
68
  method: 'POST',
74
69
  url: '/api/file-explorer/files',
75
- params: { containerName: input.containerName, cellName: input.cellName, directoryId: input.directoryId, entityId: input.entityId },
70
+ params: {
71
+ containerName: input.containerName,
72
+ cellName: input.cellName,
73
+ directoryId: input.directoryId,
74
+ entityId: input.entityId,
75
+ },
76
76
  body: input.file,
77
77
  }, { apiName: 'FileExplorer', ...config });
78
+ /**文件表格-选择的表格数据项 */
79
+ this.selectedTable = [];
80
+ /**当前选择的table项 id */
81
+ this.nowSelectId = '';
82
+ /**是否全选 */
83
+ this.isAllSelected = false;
84
+ /**判断row是否选中 */
85
+ this.selectedcheckbox = id => {
86
+ return this.selectedTable.some(el => el.id === id);
87
+ };
88
+ /**当前编辑的row */
89
+ this.newEditRow = '';
90
+ /**是否正在加载 */
91
+ this.isloading = false;
78
92
  that = this;
79
93
  }
80
94
  /**获取目录配置 */
81
95
  getFilesConfiguration() {
82
- this._FileDescriptorService.getFileContainerConfiguration(this._fileContainerName).subscribe(res => {
83
- this.createDirectoryPermissionName = res?.createDirectoryPermissionName;
96
+ return new Promise((resolve, reject) => {
97
+ this._FileDescriptorService
98
+ .getFileContainerConfiguration(this._fileContainerName)
99
+ .subscribe(res => {
100
+ this.createDirectoryPermissionName = res?.createDirectoryPermissionName;
101
+ resolve(res);
102
+ });
84
103
  });
85
104
  }
86
105
  set fileContainerName(v) {
87
106
  if (v) {
88
107
  this._fileContainerName = v;
89
- this.loadData();
108
+ // this.loadData()
90
109
  }
91
110
  }
92
111
  set multiple(v) {
93
112
  this._multiple = v;
94
- if (v) { }
113
+ if (v) {
114
+ }
95
115
  }
96
116
  set limit(v) {
97
117
  this.sizeLimit = v;
@@ -106,7 +126,13 @@ export class FileModalComponent {
106
126
  /**模态框-状态改变回调 */
107
127
  ModalVisibleChange(event) {
108
128
  if (!event) {
129
+ this.ModalOpen = false;
130
+ this.ModalBusy = false;
109
131
  this.visibleChange.emit(event);
132
+ this.createDirectoryPermissionName = '';
133
+ this._theSelectedTreeNode = '';
134
+ this.selectedTable = [];
135
+ this.uploadPictureStatusList = [];
110
136
  return;
111
137
  }
112
138
  }
@@ -119,12 +145,47 @@ export class FileModalComponent {
119
145
  /**初始化数据 */
120
146
  loadData() {
121
147
  if (this.ModalOpen && this._fileContainerName) {
122
- this.hookToQuery();
148
+ this.list.maxResultCount = 100;
149
+ // this.filters.skipCount = 0;
123
150
  this.getFilesConfiguration();
151
+ if (!this.isCreateList) {
152
+ this.hookToQuery();
153
+ this.isCreateList = true;
154
+ }
155
+ else {
156
+ this.list.get();
157
+ }
124
158
  }
125
159
  }
160
+ /** 从tree获取数据 */
161
+ treeNodeData(event) {
162
+ this.fileGroupList = this.flattenNestedArray(event);
163
+ }
164
+ /**
165
+ * 将嵌套数组扁平化
166
+ * @param {Array} nestedArray - 包含嵌套children的数组
167
+ * @returns {Array} - 扁平化后的数组
168
+ */
169
+ flattenNestedArray(nestedArray) {
170
+ let result = [];
171
+ function flatten(items) {
172
+ if (!items)
173
+ return;
174
+ for (const item of items) {
175
+ // 将当前项添加到结果数组
176
+ result.push({ ...item });
177
+ // 如果有children属性且是数组,递归处理
178
+ if (item.children && Array.isArray(item.children)) {
179
+ flatten(item.children);
180
+ }
181
+ }
182
+ }
183
+ flatten(nestedArray);
184
+ return result;
185
+ }
126
186
  /**tree-节点选择 */
127
187
  _nodeClick(event) {
188
+ this.filters.skipCount = 0;
128
189
  this._theSelectedTreeNode = event;
129
190
  this.list.get();
130
191
  }
@@ -137,12 +198,15 @@ export class FileModalComponent {
137
198
  this.setuploadPictureStatus(file, 2);
138
199
  continue;
139
200
  }
140
- await this.uploadingFile(file).then(() => {
201
+ await this.uploadingFile(file)
202
+ .then(res => {
203
+ this.selectedTable.push(res);
141
204
  this.setuploadPictureStatus(file, 1);
142
- this.list.get();
143
- }).catch(() => {
205
+ // this.list.get()
206
+ })
207
+ .catch(() => {
144
208
  this.setuploadPictureStatus(file, 2);
145
- }); // 等待每个文件上传完成
209
+ }); // 等待每个文件上传完成
146
210
  }
147
211
  this.list.get();
148
212
  let isSubmit = !this.uploadPictureStatusList.some(el => el.status == 2);
@@ -150,7 +214,7 @@ export class FileModalComponent {
150
214
  // this.toaster.success("上传完成");
151
215
  setTimeout(() => {
152
216
  this.uploadPictureStatusList = [];
153
- }, 6000);
217
+ }, 4000);
154
218
  }
155
219
  }
156
220
  /**图片上传-设置uploadPictureStatusList的状态 */
@@ -169,43 +233,156 @@ export class FileModalComponent {
169
233
  file: formData,
170
234
  containerName: this._fileContainerName,
171
235
  directoryId: this._theSelectedTreeNode?.key || '',
172
- entityId: ''
236
+ entityId: '',
173
237
  }).subscribe(res => {
174
- resolve(true);
175
- }, (err) => {
238
+ resolve(res);
239
+ }, err => {
176
240
  rejects(false);
177
241
  });
178
242
  });
179
243
  }
180
- ngOnChanges(changes) {
181
- //Called before any other lifecycle hook. Use it to inject dependencies, but avoid any serious work here.
182
- //Add '${implements OnChanges}' to the class.
183
- this.selectedTable = this._FileApiService.deepClone(this.selectPickerFile);
184
- }
185
244
  /**文件表格-获取表格数据 */
186
245
  hookToQuery() {
187
246
  const getData = (query) => this._FileService.getList({
188
247
  ...query,
189
248
  ...this.filters,
190
249
  containerName: this._fileContainerName,
191
- directoryId: this._theSelectedTreeNode.key
250
+ directoryId: this._theSelectedTreeNode.key,
192
251
  });
193
- const setData = (list) => (this.data = list);
252
+ const setData = (list) => {
253
+ this.data = list;
254
+ this.onPageChange(list.items);
255
+ };
194
256
  this.list.hookToQuery(getData).subscribe(setData);
195
257
  }
196
258
  /**文件表格-查看所有分组的文件数据 */
197
259
  lookAllFile() {
260
+ this.filters.skipCount = 0;
198
261
  this._theSelectedTreeNode = '';
199
262
  this.list.get();
200
263
  }
201
- /**选择表格项 */
202
- onSelectTableItem({ selected }) {
203
- this.selectedTable = this._FileApiService.deepClone(selected);
204
- let selectedTablearr = this.removeDuplicatesById(this.selectedTable);
205
- if (selected.length > selectedTablearr.length) {
206
- selectedTablearr = selectedTablearr.filter(el => el.id !== this.nowSelectId);
264
+ /**删除图片 */
265
+ deleteFile(file) {
266
+ this._FileService.delete(file.id).subscribe(res => {
267
+ this.toaster.success(this._LocalizationService.instant(`FileExplorer::DeletedSuccessfully`));
268
+ this.list.get();
269
+ });
270
+ }
271
+ /**删除所有选中图片 */
272
+ onDeleteAllSelectFile() {
273
+ this.confirmation
274
+ .warn('', {
275
+ key: '',
276
+ defaultValue: this._LocalizationService.instant(`FileExplorer::AreYouSure`),
277
+ })
278
+ .subscribe(async (status) => {
279
+ if (status == 'confirm') {
280
+ let selectedTable = this.selectedTable;
281
+ try {
282
+ const result = await this.batchDeleteItems(selectedTable);
283
+ if (result.success) {
284
+ this.toaster.success(result.message);
285
+ this.list.get();
286
+ // 可能需要刷新表格或更新UI
287
+ }
288
+ else {
289
+ //删除失败的项
290
+ this.list.get();
291
+ // console.warn(result.message);
292
+ // 可以选择展示失败项或重试
293
+ }
294
+ }
295
+ catch (error) {
296
+ //批量删除过程中发生错误
297
+ }
298
+ }
299
+ });
300
+ }
301
+ /**
302
+ * 批量删除表格项
303
+ * @param selectedTable 需要删除的表格项数组
304
+ * @returns 包含成功状态和失败项的结果对象
305
+ */
306
+ async batchDeleteItems(selectedTable) {
307
+ // 存储所有删除请求的Promise
308
+ const deletePromises = selectedTable.map(item => {
309
+ return new Promise((resolve, reject) => {
310
+ this._FileService.delete(item.id).subscribe(() => {
311
+ resolve(null);
312
+ }, () => {
313
+ reject(item);
314
+ });
315
+ });
316
+ });
317
+ // 等待所有请求完成
318
+ const results = await Promise.allSettled(deletePromises);
319
+ console.log(results, 'resultsresultsresults');
320
+ // 收集失败的项
321
+ const failedItems = [];
322
+ results.forEach(result => {
323
+ if (result.status === 'rejected') {
324
+ failedItems.push(result.reason);
325
+ }
326
+ });
327
+ return {
328
+ success: failedItems.length === 0,
329
+ failedItems,
330
+ message: failedItems.length === 0
331
+ ? this._LocalizationService.instant(`FileExplorer::DeletedSuccessfully`)
332
+ : `${failedItems.length}个项删除失败`,
333
+ };
334
+ }
335
+ // 使用示例
336
+ async handleBatchDelete() { }
337
+ /**关闭文件状态弹窗 */
338
+ closeFileStatusModal() {
339
+ this.uploadPictureStatusList = [];
340
+ }
341
+ ngOnChanges(changes) {
342
+ //Called before any other lifecycle hook. Use it to inject dependencies, but avoid any serious work here.
343
+ //Add '${implements OnChanges}' to the class.
344
+ this.selectedTable = this._FileApiService.deepClone(this.selectPickerFile);
345
+ }
346
+ /**表格分页切换 */
347
+ onPageChange(newArray) {
348
+ this.isAllSelected = this.isAllSelectedFn(newArray, this.selectedTable);
349
+ }
350
+ /**行选择框改变 */
351
+ onCheckboxChangeFn(event, row, array) {
352
+ const { checked } = event.target;
353
+ let selectedTableArray = [...this.selectedTable];
354
+ if (this._multiple) {
355
+ if (checked) {
356
+ selectedTableArray.push(row);
357
+ }
358
+ else {
359
+ selectedTableArray = selectedTableArray.filter(el => el.id != row.id);
360
+ }
361
+ this.isAllSelected = this.isAllSelectedFn(array, selectedTableArray);
362
+ }
363
+ else {
364
+ selectedTableArray.length = 0;
365
+ selectedTableArray = checked ? [row] : [];
207
366
  }
208
- this.selectedTable = selectedTablearr;
367
+ this.selectedTable = this.removeDuplicatesById(selectedTableArray);
368
+ }
369
+ /**如果selectedTableArray不含array中的所有项,则将isAllSelected设为true,否则设为false */
370
+ isAllSelectedFn(tolalArray, selectedArray = []) {
371
+ if (tolalArray.length == 0)
372
+ return false;
373
+ return tolalArray.every(item => selectedArray.some(el => el.id === item.id));
374
+ }
375
+ /**选择当前页全部 */
376
+ onSelectAllFn(event, array) {
377
+ let selectedTableArray = this.selectedTable;
378
+ if (event.target.checked) {
379
+ selectedTableArray = this.removeDuplicatesById([...selectedTableArray, ...array]);
380
+ }
381
+ else {
382
+ selectedTableArray = selectedTableArray.filter(el => !array.some(item => item.id === el.id));
383
+ }
384
+ this.isAllSelected = event.target.checked;
385
+ this.selectedTable = selectedTableArray;
209
386
  }
210
387
  /**删除数组中重复的项 */
211
388
  removeDuplicatesById(array) {
@@ -218,32 +395,61 @@ export class FileModalComponent {
218
395
  return false;
219
396
  });
220
397
  }
221
- /**删除图片 */
222
- deleteFile(file) {
223
- this.confirmation
224
- .warn('', { key: '', defaultValue: this._LocalizationService.instant(`AbpUi::ItemWillBeDeletedMessage`) })
225
- .subscribe((status) => {
226
- if (status == 'confirm') {
227
- this._FileService.delete(file.id).subscribe(res => {
228
- this.toaster.success(this._LocalizationService.instant(`AbpUi::DeletedSuccessfully`));
229
- this.list.get();
230
- });
398
+ /**提交FileName编辑 */
399
+ onSubmitFileName(event) {
400
+ let input = this.FileNameForm.value;
401
+ if (!this.FileNameForm.valid)
402
+ return;
403
+ if (this.isloading)
404
+ return;
405
+ this.isloading = true;
406
+ this._FileService
407
+ .update(input.id, {
408
+ name: input.fileName
409
+ })
410
+ .pipe(finalize(() => {
411
+ this.isloading = false;
412
+ }))
413
+ .subscribe(res => {
414
+ //通过当前newEditRow的id,修改data.items中对应项的name
415
+ for (const element of this.data.items) {
416
+ if (element.id == this.newEditRow.id) {
417
+ element.name = input.fileName;
418
+ break;
419
+ }
231
420
  }
421
+ this.FileNameForm = undefined;
422
+ this.newEditRow = '';
423
+ this.toaster.success(this._LocalizationService.instant(`FileExplorer::SavedSuccessfully`));
424
+ // this.list.get();
232
425
  });
233
426
  }
234
- /**关闭文件状态弹窗 */
235
- closeFileStatusModal() {
236
- this.uploadPictureStatusList = [];
427
+ /**打开编辑 */
428
+ onEditFileName(row) {
429
+ this.FileNameForm = new FormGroup({
430
+ fileName: new FormControl('', [Validators.required]),
431
+ id: new FormControl('', [Validators.required]),
432
+ });
433
+ this.FileNameForm.patchValue({
434
+ fileName: row.name,
435
+ id: row.id,
436
+ });
437
+ this.newEditRow = row;
438
+ }
439
+ /**关闭编辑 */
440
+ onCancelFileName(row) {
441
+ this.newEditRow = '';
442
+ this.FileNameForm = undefined;
237
443
  }
238
444
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.5", ngImport: i0, type: FileModalComponent, deps: [{ token: i1.FileDescriptorService }, { token: i2.ToasterService }, { token: i3.ListService }, { token: i4.FileApiService }, { token: i3.RestService }, { token: i2.ConfirmationService }, { token: i3.LocalizationService }], target: i0.ɵɵFactoryTarget.Component }); }
239
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.1.5", type: FileModalComponent, selector: "fe-file-modal", inputs: { fileContainerName: "fileContainerName", multiple: "multiple", limit: "limit", visible: "visible", selectPickerFile: "selectPickerFile" }, outputs: { visibleChange: "visibleChange", selectFilefn: "selectFilefn" }, providers: [
445
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.1.5", type: FileModalComponent, selector: "fe-file-modal", inputs: { fileContainerName: "fileContainerName", multiple: "multiple", limit: "limit", visible: "visible", selectPickerFile: "selectPickerFile" }, outputs: { visibleChange: "visibleChange", selectFilefn: "selectFilefn" }, providers: [
240
446
  // [Required]
241
447
  ListService,
242
448
  // [Optional]
243
449
  // Provide this token if you want a different debounce time.
244
450
  // Default is 300. Cannot be 0. Any value below 100 is not recommended.
245
451
  { provide: LIST_QUERY_DEBOUNCE_TIME, useValue: 500 },
246
- ], usesOnChanges: true, ngImport: i0, template: "<abp-modal [(visible)]=\"ModalOpen\" (visibleChange)=\"ModalVisibleChange($event)\"\n [options]=\"{ size: 'xl', scrollable: false }\">\n <ng-template #abpHeader>\n <h3>{{'FileExplorer::FileExplorer' | abpLocalization}}</h3>\n </ng-template>\n <ng-template #abpBody>\n <div class=\"row file-explorer-modal-body file-modal\">\n <div class=\"col-3\" *ngIf=\"createDirectoryPermissionName\" style=\"overflow: auto; height: calc(100vh - 240px)\">\n <fe-file-modal-tree [theSelectedTreeNode]=\"_theSelectedTreeNode\" (nodeClick)=\"_nodeClick($event)\"\n [fileContainerName]=\"_fileContainerName\"></fe-file-modal-tree>\n </div>\n <div [class]=\"createDirectoryPermissionName?'col-9':'col-12'\" style=\"height: calc(100vh - 240px)\">\n <div class=\"mb-3 d-flex justify-content-between align-items-center\">\n <div class=\"btn-link\" role=button style=\"flex: 2\" (click)=\"lookAllFile()\">{{'FileExplorer::AllFiles' | abpLocalization}}</div>\n <div class=\"input-group form-file\" style=\"flex: 2\">\n <input type=\"file\" class=\"form-control\" #fileEdit [multiple]=\"_multiple\" \n (change)=\"getFileChange($event)\" />\n </div>\n </div>\n <div>\n <ngx-datatable class=\"material container-height\" [rows]=\"data.items\" [list]=\"list\" columnMode=\"flex\"\n [columns]=\"columns\" [headerHeight]=\"50\" [footerHeight]=\"50\" rowHeight=\"auto\" [scrollbarV]=\"true\"\n [virtualization]=\"false\" [externalPaging]=\"true\" [count]=\"data.totalCount\" [selected]=\"selectedTable\"\n [selectCheck]=\"selectCheck\" [selectionType]=\"_multiple?SelectionType.multiClick:SelectionType.single\" (select)=\"onSelectTableItem($event)\">\n <ngx-datatable-column [width]=\"50\" prop=\"id\" [sortable]=\"false\" [canAutoResize]=\"false\" [draggable]=\"false\"\n [resizeable]=\"false\">\n <ng-template ngx-datatable-header-template let-value=\"value\" let-allRowsSelected=\"allRowsSelected\"\n let-selectFn=\"selectFn\">\n <input type=\"checkbox\" class=\"form-check-input\" [checked]=\"allRowsSelected\"\n (change)=\"selectFn(!allRowsSelected)\" />\n </ng-template>\n <ng-template ngx-datatable-cell-template let-row=\"row\" let-value=\"value\" let-isSelected=\"isSelected\"\n let-onCheckboxChangeFn=\"onCheckboxChangeFn\">\n <input type=\"checkbox\" class=\"form-check-input\" [checked]=\"selectedcheckbox(value)\"\n (change)=\"onCheckboxChangeFn($event)\" />\n </ng-template>\n </ngx-datatable-column>\n <ngx-datatable-column [flexGrow]=\"2\">\n <ng-template let-row=\"row\" let-value=\"value\" ngx-datatable-cell-template>\n <fe-file-preview [width]=\"'80px'\" [src]=\"row.url\" [name]=\"row.name\" [type]=\"row.mimeType\" [preview]=\"true\"></fe-file-preview>\n </ng-template>\n </ngx-datatable-column>\n <ngx-datatable-column [name]=\"'FileExplorer::FileName' | abpLocalization\" prop=\"name\" [flexGrow]=\"4\">\n <ng-template let-row=\"row\" let-value=\"value\" ngx-datatable-cell-template>\n {{ value }}\n </ng-template>\n </ngx-datatable-column>\n <ngx-datatable-column [name]=\"'FileExplorer::FileSize' | abpLocalization\" prop=\"size\" [flexGrow]=\"1.5\">\n <ng-template let-row=\"row\" let-value=\"value\" ngx-datatable-cell-template>\n {{ _FileApiService.formatFileSize(value) }}\n </ng-template>\n </ngx-datatable-column>\n <ngx-datatable-column [name]=\"'FileExplorer::Directory' | abpLocalization\" prop=\"cellName\" [flexGrow]=\"1\">\n <ng-template let-row=\"row\" let-value=\"value\" ngx-datatable-cell-template>\n {{ value }}\n </ng-template>\n </ngx-datatable-column>\n <ngx-datatable-column [name]=\"'FileExplorer::CreationTime' | abpLocalization\" prop=\"creationTime\" [flexGrow]=\"2\">\n <ng-template let-row=\"row\" let-value=\"value\" ngx-datatable-cell-template>\n {{ value | date : 'YYYY/MM/dd HH:mm:s' }}\n </ng-template>\n </ngx-datatable-column>\n <ngx-datatable-column [flexGrow]=\"1\">\n <ng-template let-row=\"row\" let-value=\"value\" ngx-datatable-cell-template>\n <button class=\"btn btn-sm btn-light p-0\" (click.stop)=\"deleteFile(row)\">\n <i class=\"fas fa-trash text-primary p-2\"></i>\n </button>\n </ng-template>\n </ngx-datatable-column>\n </ngx-datatable>\n </div>\n <div *ngIf=\"uploadPictureStatusList.length > 0\"\n class=\"position-fixed bottom-0 end-0 shadow-lg file-status-modal m-5\"\n style=\"border-radius: 10px\">\n <div class=\"card p-1\">\n <div class=\"card-header d-flex align-items-center justify-content-between p-0 py-1 border-bottom\">\n <div>{{'FileExplorer::UploadFiles' | abpLocalization}}</div>\n <button type=\"button\" class=\"btn-close\" aria-label=\"Close\" (click.stop)=\"closeFileStatusModal()\"></button>\n </div>\n <div class=\"card-body\">\n <table class=\"table\">\n <thead>\n <tr>\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 uploadPictureStatusList; let i = index\">\n <tr>\n <th scope=\"row\">\n <div>{{ item.name }}</div>\n <div class=\"form-text text-danger\" *ngIf=\"item.size > sizeLimit\">\n {{'FileExplorer::ExceedsMaximumSize' | abpLocalization:_FileApiService.formatFileSize(sizeLimit)}}\n </div>\n </th>\n <td>{{ item.fileSize }}</td>\n <td>\n <i *ngIf=\"item.status === 1\" class=\"fas fa-check text-primary\"></i>\n <i *ngIf=\"item.status === 2\" class=\"fas fa-times-circle text-danger\"></i>\n </td>\n </tr>\n </ng-container>\n </tbody>\n </table>\n </div>\n </div>\n </div>\n </div>\n </div>\n </ng-template>\n <ng-template #abpFooter>\n <button type=\"button\" class=\"btn btn-secondary\" abpClose>{{'AbpUi::Close' | abpLocalization}}</button>\n <abp-button iconClass=\"fa fa-check\" (click)=\"modalSave()\">{{'AbpUi::Save' | abpLocalization}}</abp-button>\n </ng-template>\n</abp-modal>", styles: ["::ng-deep .file-modal .container-height{height:calc(100vh - 284px)}::ng-deep .file-modal .file-status-modal{background:#fff}::ng-deep .file-modal .file-status-modal .card-body{max-height:300px;overflow-y:auto}::ng-deep .file-modal .ngx-datatable.material.single-selection .datatable-body-row.active,::ng-deep .file-modal .ngx-datatable.material.single-selection .datatable-body-row.active .datatable-row-group,::ng-deep .file-modal .ngx-datatable.material.multi-selection .datatable-body-row.active,::ng-deep .file-modal .ngx-datatable.material.multi-selection .datatable-body-row.active .datatable-row-group,::ng-deep .file-modal .ngx-datatable.material.multi-click-selection .datatable-body-row.active,::ng-deep .file-modal .ngx-datatable.material.multi-click-selection .datatable-body-row.active .datatable-row-group{background-color:transparent!important}::ng-deep .file-modal .ant-tree .ant-tree-node-content-wrapper{padding:0}::ng-deep .file-modal .ant-tree .ant-tree-node-content-wrapper .custom-node{width:100%}::ng-deep .file-modal .ant-tree .ant-tree-node-content-wrapper .selected{background-color:var(--lpx-brand)!important}::ng-deep .file-modal .ant-tree .ant-tree-node-content-wrapper .selected .btn{color:var(--lpx-navbar-color)}::ng-deep .file-modal .ant-tree .ant-tree-node-content-wrapper.ant-tree-node-selected{background-color:transparent}::ng-deep .file-modal .ngx-datatable.fixed-header .datatable-header .datatable-header-inner .datatable-header-cell,::ng-deep .file-modal .ngx-datatable.material .datatable-body .datatable-body-row .datatable-body-cell{overflow:initial;line-break:anywhere}\n"], dependencies: [{ kind: "directive", type: i5.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.StopPropagationDirective, selector: "[click.stop]", outputs: ["click.stop"] }, { kind: "component", type: i6.DatatableComponent, selector: "ngx-datatable", inputs: ["targetMarkerTemplate", "rows", "groupRowsBy", "groupedRows", "columns", "selected", "scrollbarV", "scrollbarH", "rowHeight", "columnMode", "headerHeight", "footerHeight", "externalPaging", "externalSorting", "limit", "count", "offset", "loadingIndicator", "selectionType", "reorderable", "swapColumns", "sortType", "sorts", "cssClasses", "messages", "rowClass", "selectCheck", "displayCheck", "groupExpansionDefault", "trackByProp", "selectAllRowsOnPage", "virtualization", "treeFromRelation", "treeToRelation", "summaryRow", "summaryHeight", "summaryPosition", "rowIdentity"], outputs: ["scroll", "activate", "select", "sort", "page", "reorder", "resize", "tableContextmenu", "treeAction"] }, { kind: "directive", type: i6.DataTableColumnDirective, selector: "ngx-datatable-column", inputs: ["name", "prop", "frozenLeft", "frozenRight", "flexGrow", "resizeable", "comparator", "pipe", "sortable", "draggable", "canAutoResize", "minWidth", "width", "maxWidth", "checkboxable", "headerCheckboxable", "headerClass", "cellClass", "isTreeColumn", "treeLevelIndent", "summaryFunc", "summaryTemplate", "cellTemplate", "headerTemplate", "treeToggleTemplate"] }, { kind: "directive", type: i6.DataTableColumnHeaderDirective, selector: "[ngx-datatable-header-template]" }, { kind: "directive", type: i6.DataTableColumnCellDirective, selector: "[ngx-datatable-cell-template]" }, { kind: "directive", type: i2.NgxDatatableListDirective, selector: "ngx-datatable[list]", inputs: ["list"], exportAs: ["ngxDatatableList"] }, { kind: "component", type: i2.ButtonComponent, selector: "abp-button", inputs: ["buttonId", "buttonClass", "buttonType", "formName", "iconClass", "loading", "disabled", "attributes"], outputs: ["click", "focus", "blur", "abpClick", "abpFocus", "abpBlur"] }, { kind: "component", type: i2.ModalComponent, selector: "abp-modal", inputs: ["visible", "busy", "options", "suppressUnsavedChangesWarning"], outputs: ["visibleChange", "init", "appear", "disappear"] }, { kind: "directive", type: i2.ModalCloseDirective, selector: "[abpClose]" }, { kind: "component", type: i7.FileModalTreeComponent, selector: "fe-file-modal-tree", inputs: ["theSelectedTreeNode", "fileContainerName"], outputs: ["nodeClick"] }, { kind: "component", type: i8.FilePreviewComponent, selector: "fe-file-preview", inputs: ["width", "src", "preview", "type", "name", "className"] }, { kind: "pipe", type: i5.DatePipe, name: "date" }, { kind: "pipe", type: i3.LocalizationPipe, name: "abpLocalization" }] }); }
452
+ ], usesOnChanges: true, ngImport: i0, template: "<abp-modal [(visible)]=\"ModalOpen\" (visibleChange)=\"ModalVisibleChange($event)\"\n [options]=\"{ size: 'xl', scrollable: false }\">\n <ng-template #abpHeader>\n <h3>{{'FileExplorer::FileExplorer' | abpLocalization}}</h3>\n </ng-template>\n <ng-template #abpBody>\n <div class=\"row file-explorer-modal-body file-modal\" *ngIf=\"ModalOpen\">\n <div class=\"col-3\" *ngIf=\"createDirectoryPermissionName\" style=\"overflow: auto; height: calc(100vh - 240px)\">\n <fe-file-modal-tree [theSelectedTreeNode]=\"_theSelectedTreeNode\" (nodeClick)=\"_nodeClick($event)\"\n (lookAllBtn)=\"lookAllFile()\" (treeNodeData)=\"treeNodeData($event)\"\n [fileContainerName]=\"_fileContainerName\"></fe-file-modal-tree>\n </div>\n <div [class]=\"createDirectoryPermissionName?'col-9':'col-12'\" style=\"height: calc(100vh - 240px)\">\n <div class=\"mb-3 d-flex justify-content-between align-items-center\">\n <div style=\"flex: 2\"><span *ngIf=\"selectedTable.length>1\" class=\"btn-link\"\n (click.stop)=\"onDeleteAllSelectFile()\" role=\"button\">{{'FileExplorer::Delete' | abpLocalization}}</span>\n </div>\n <div class=\"input-group form-file\" style=\"flex: 2\">\n <input type=\"file\" class=\"form-control\" #fileEdit [multiple]=\"_multiple\" (change)=\"getFileChange($event)\" />\n </div>\n </div>\n <div>\n <!-- [selectionType]=\"_multiple?SelectionType.checkbox:SelectionType.single\" -->\n <!-- [selectCheck]=\"selectCheck\" -->\n <ngx-datatable class=\"material container-height\" [rows]=\"data.items\" [list]=\"list\" columnMode=\"flex\"\n [headerHeight]=\"50\" [footerHeight]=\"50\" rowHeight=\"auto\" [scrollbarV]=\"true\" [virtualization]=\"false\"\n [externalPaging]=\"true\" [count]=\"data.totalCount\">\n <ngx-datatable-column [width]=\"50\" prop=\"id\" [sortable]=\"false\" [canAutoResize]=\"false\" [draggable]=\"false\"\n [resizeable]=\"false\">\n <ng-template ngx-datatable-header-template let-value=\"value\" let-allRowsSelected=\"allRowsSelected\"\n let-selectFn=\"selectFn\">\n <input type=\"checkbox\" class=\"form-check-input\" *ngIf=\"_multiple\" [checked]=\"isAllSelected\"\n (change)=\"onSelectAllFn($event,data.items)\" />\n </ng-template>\n <ng-template ngx-datatable-cell-template let-row=\"row\" let-value=\"value\">\n <input type=\"checkbox\" class=\"form-check-input\" [checked]=\"selectedcheckbox(value)\"\n (change)=\"onCheckboxChangeFn($event,row,data.items)\" />\n </ng-template>\n </ngx-datatable-column>\n <ngx-datatable-column [sortable]=\"false\" [flexGrow]=\"2\">\n <ng-template let-row=\"row\" let-value=\"value\" ngx-datatable-cell-template>\n <fe-file-preview [width]=\"'80px'\" [src]=\"row.url\" [name]=\"row.name\" [type]=\"row.mimeType\"\n [preview]=\"true\"></fe-file-preview>\n </ng-template>\n </ngx-datatable-column>\n <ngx-datatable-column [name]=\"'FileExplorer::FileName' | abpLocalization\" prop=\"name\" [sortable]=\"false\"\n [flexGrow]=\"4\">\n <ng-template let-row=\"row\" let-value=\"value\" ngx-datatable-cell-template>\n <div class=\"d-flex align-items-start titlehover\" *ngIf=\"newEditRow.id!==row.id\">\n <span class=\"me-2\">{{ value }}</span>\n <i class=\"fa fa-pencil-square-o\" role=\"button\" (click.stop)=\"onEditFileName(row)\" style=\"line-height:2;\" aria-hidden=\"true\"></i>\n </div>\n <div *ngIf=\"FileNameForm&&newEditRow.id===row.id\">\n <form [formGroup]=\"FileNameForm\" (ngSubmit)=\"onSubmitFileName($event)\">\n <div class=\"d-flex align-items-start\">\n <div class=\"me-2\">\n <input class=\"form-control \" type=\"text\" formControlName=\"fileName\">\n </div>\n <button class=\" btn btn-sm\" type=\"submit\">\n <i class=\"fa-spin fa fa-spinner\" *ngIf=\"isloading\"></i>\n <i class=\"fa fa-check\" aria-hidden=\"true\" *ngIf=\"!isloading\"></i></button>\n <button class=\" btn btn-sm\" (click.stop)=\"onCancelFileName(row)\"><i class=\"fa fa-times\" type=\"reset\" aria-hidden=\"true\"></i></button>\n \n </div>\n </form>\n </div>\n </ng-template>\n </ngx-datatable-column>\n <ngx-datatable-column [name]=\"'FileExplorer::FileSize' | abpLocalization\" prop=\"size\" [flexGrow]=\"1.5\">\n <ng-template let-row=\"row\" let-value=\"value\" ngx-datatable-cell-template>\n {{ _FileApiService.formatFileSize(value) }}\n </ng-template>\n </ngx-datatable-column>\n <ngx-datatable-column [name]=\"'FileExplorer::Directory' | abpLocalization\" prop=\"directoryId\"\n [sortable]=\"false\" [flexGrow]=\"1\">\n <ng-template let-row=\"row\" let-value=\"value\" ngx-datatable-cell-template>\n {{ value|getDirectoryName:fileGroupList }}\n </ng-template>\n </ngx-datatable-column>\n <ngx-datatable-column [name]=\"'FileExplorer::CreationTime' | abpLocalization\" prop=\"creationTime\"\n [flexGrow]=\"2\">\n <ng-template let-row=\"row\" let-value=\"value\" ngx-datatable-cell-template>\n {{ value | date : 'YYYY/MM/dd HH:mm:s' }}\n </ng-template>\n </ngx-datatable-column>\n <ngx-datatable-column [flexGrow]=\"1\" [sortable]=\"false\">\n <ng-template let-row=\"row\" let-value=\"value\" ngx-datatable-cell-template>\n <button class=\"btn btn-sm btn-light p-0\" (click.stop)=\"deleteFile(row)\">\n <i class=\"fas fa-trash text-primary p-2\"></i>\n </button>\n </ng-template>\n </ngx-datatable-column>\n </ngx-datatable>\n </div>\n <div *ngIf=\"uploadPictureStatusList.length > 0\"\n class=\"position-fixed bottom-0 end-0 shadow-lg file-status-modal m-5\" style=\"border-radius: 10px\">\n <div class=\"card p-1\">\n <div class=\"card-header d-flex align-items-center justify-content-between p-0 py-1 border-bottom\">\n <div>{{'FileExplorer::UploadFiles' | abpLocalization}}</div>\n <button type=\"button\" class=\"btn-close\" aria-label=\"Close\" (click.stop)=\"closeFileStatusModal()\"></button>\n </div>\n <div class=\"card-body\">\n <table class=\"table\">\n <thead>\n <tr>\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 uploadPictureStatusList; let i = index\">\n <tr>\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)}}\n </div>\n </th>\n <td>{{ item.fileSize }}</td>\n <td>\n <i *ngIf=\"item.status === 1\" class=\"fas fa-check text-primary\"></i>\n <i *ngIf=\"item.status === 2\" class=\"fas fa-times-circle text-danger\"></i>\n </td>\n </tr>\n </ng-container>\n </tbody>\n </table>\n </div>\n </div>\n </div>\n </div>\n </div>\n </ng-template>\n <ng-template #abpFooter>\n <button type=\"button\" class=\"btn btn-secondary\" abpClose>{{'AbpUi::Close' | abpLocalization}}</button>\n <abp-button iconClass=\"fa fa-check\" (click)=\"modalSave()\">{{'FileExplorer::Confirm' | abpLocalization}}\n @if(selectedTable.length>0){\n ({{selectedTable.length}})\n }\n </abp-button>\n </ng-template>\n</abp-modal>", styles: ["::ng-deep .file-modal .container-height{height:calc(100vh - 284px)}::ng-deep .file-modal .file-status-modal{background:#fff}::ng-deep .file-modal .file-status-modal .card-body{max-height:300px;overflow-y:auto}::ng-deep .file-modal .ngx-datatable.material.single-selection .datatable-body-row.active,::ng-deep .file-modal .ngx-datatable.material.single-selection .datatable-body-row.active .datatable-row-group,::ng-deep .file-modal .ngx-datatable.material.multi-selection .datatable-body-row.active,::ng-deep .file-modal .ngx-datatable.material.multi-selection .datatable-body-row.active .datatable-row-group,::ng-deep .file-modal .ngx-datatable.material.multi-click-selection .datatable-body-row.active,::ng-deep .file-modal .ngx-datatable.material.multi-click-selection .datatable-body-row.active .datatable-row-group{background-color:transparent!important}::ng-deep .file-modal .ant-tree .ant-tree-node-content-wrapper{padding:0}::ng-deep .file-modal .ant-tree .ant-tree-node-content-wrapper .ng-star-inserted[title]{padding:0 10px}::ng-deep .file-modal .ant-tree .ant-tree-node-content-wrapper .custom-node{width:100%}::ng-deep .file-modal .ant-tree .ant-tree-node-content-wrapper .selected{background-color:var(--lpx-brand)!important;color:var(--lpx-brand-text)}::ng-deep .file-modal .ant-tree .ant-tree-node-content-wrapper.ant-tree-node-selected{background-color:transparent}::ng-deep .file-modal .ngx-datatable.fixed-header .datatable-header .datatable-header-inner .datatable-header-cell,::ng-deep .file-modal .ngx-datatable.material .datatable-body .datatable-body-row .datatable-body-cell{overflow:initial;line-break:anywhere}::ng-deep .file-modal input[type=checkbox]{cursor:pointer}::ng-deep .file-modal .titlehover i{display:none}::ng-deep .file-modal .titlehover:hover i{display:block}\n"], dependencies: [{ kind: "directive", type: i5.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i5.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i5.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i5.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i6.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i6.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i5.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i5.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "directive", type: i3.FormSubmitDirective, selector: "form[ngSubmit][formGroup]", inputs: ["debounce", "notValidateOnSubmit", "markAsDirtyWhenSubmit"], outputs: ["ngSubmit"] }, { kind: "directive", type: i3.StopPropagationDirective, selector: "[click.stop]", outputs: ["click.stop"] }, { kind: "component", type: i7.DatatableComponent, selector: "ngx-datatable", inputs: ["targetMarkerTemplate", "rows", "groupRowsBy", "groupedRows", "columns", "selected", "scrollbarV", "scrollbarH", "rowHeight", "columnMode", "headerHeight", "footerHeight", "externalPaging", "externalSorting", "limit", "count", "offset", "loadingIndicator", "selectionType", "reorderable", "swapColumns", "sortType", "sorts", "cssClasses", "messages", "rowClass", "selectCheck", "displayCheck", "groupExpansionDefault", "trackByProp", "selectAllRowsOnPage", "virtualization", "treeFromRelation", "treeToRelation", "summaryRow", "summaryHeight", "summaryPosition", "rowIdentity"], outputs: ["scroll", "activate", "select", "sort", "page", "reorder", "resize", "tableContextmenu", "treeAction"] }, { kind: "directive", type: i7.DataTableColumnDirective, selector: "ngx-datatable-column", inputs: ["name", "prop", "frozenLeft", "frozenRight", "flexGrow", "resizeable", "comparator", "pipe", "sortable", "draggable", "canAutoResize", "minWidth", "width", "maxWidth", "checkboxable", "headerCheckboxable", "headerClass", "cellClass", "isTreeColumn", "treeLevelIndent", "summaryFunc", "summaryTemplate", "cellTemplate", "headerTemplate", "treeToggleTemplate"] }, { kind: "directive", type: i7.DataTableColumnHeaderDirective, selector: "[ngx-datatable-header-template]" }, { kind: "directive", type: i7.DataTableColumnCellDirective, selector: "[ngx-datatable-cell-template]" }, { kind: "directive", type: i8.ValidationGroupDirective, selector: "[formGroup],[formGroupName]", exportAs: ["validationGroup"] }, { kind: "directive", type: i8.ValidationDirective, selector: "[formControl],[formControlName]", exportAs: ["validationDirective"] }, { kind: "directive", type: i2.NgxDatatableListDirective, selector: "ngx-datatable[list]", inputs: ["list"], exportAs: ["ngxDatatableList"] }, { kind: "component", type: i2.ButtonComponent, selector: "abp-button", inputs: ["buttonId", "buttonClass", "buttonType", "formName", "iconClass", "loading", "disabled", "attributes"], outputs: ["click", "focus", "blur", "abpClick", "abpFocus", "abpBlur"] }, { kind: "component", type: i2.ModalComponent, selector: "abp-modal", inputs: ["visible", "busy", "options", "suppressUnsavedChangesWarning"], outputs: ["visibleChange", "init", "appear", "disappear"] }, { kind: "directive", type: i2.ModalCloseDirective, selector: "[abpClose]" }, { kind: "component", type: i9.FileModalTreeComponent, selector: "fe-file-modal-tree", inputs: ["theSelectedTreeNode", "fileContainerName"], outputs: ["nodeClick", "treeNodeData", "lookAllBtn"] }, { kind: "component", type: i10.FilePreviewComponent, selector: "fe-file-preview", inputs: ["width", "src", "preview", "type", "name", "className"] }, { kind: "pipe", type: i6.DatePipe, name: "date" }, { kind: "pipe", type: i3.LocalizationPipe, name: "abpLocalization" }, { kind: "pipe", type: i11.GetDirectoryNamePipe, name: "getDirectoryName" }] }); }
247
453
  }
248
454
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.5", ngImport: i0, type: FileModalComponent, decorators: [{
249
455
  type: Component,
@@ -254,7 +460,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.5", ngImpor
254
460
  // Provide this token if you want a different debounce time.
255
461
  // Default is 300. Cannot be 0. Any value below 100 is not recommended.
256
462
  { provide: LIST_QUERY_DEBOUNCE_TIME, useValue: 500 },
257
- ], template: "<abp-modal [(visible)]=\"ModalOpen\" (visibleChange)=\"ModalVisibleChange($event)\"\n [options]=\"{ size: 'xl', scrollable: false }\">\n <ng-template #abpHeader>\n <h3>{{'FileExplorer::FileExplorer' | abpLocalization}}</h3>\n </ng-template>\n <ng-template #abpBody>\n <div class=\"row file-explorer-modal-body file-modal\">\n <div class=\"col-3\" *ngIf=\"createDirectoryPermissionName\" style=\"overflow: auto; height: calc(100vh - 240px)\">\n <fe-file-modal-tree [theSelectedTreeNode]=\"_theSelectedTreeNode\" (nodeClick)=\"_nodeClick($event)\"\n [fileContainerName]=\"_fileContainerName\"></fe-file-modal-tree>\n </div>\n <div [class]=\"createDirectoryPermissionName?'col-9':'col-12'\" style=\"height: calc(100vh - 240px)\">\n <div class=\"mb-3 d-flex justify-content-between align-items-center\">\n <div class=\"btn-link\" role=button style=\"flex: 2\" (click)=\"lookAllFile()\">{{'FileExplorer::AllFiles' | abpLocalization}}</div>\n <div class=\"input-group form-file\" style=\"flex: 2\">\n <input type=\"file\" class=\"form-control\" #fileEdit [multiple]=\"_multiple\" \n (change)=\"getFileChange($event)\" />\n </div>\n </div>\n <div>\n <ngx-datatable class=\"material container-height\" [rows]=\"data.items\" [list]=\"list\" columnMode=\"flex\"\n [columns]=\"columns\" [headerHeight]=\"50\" [footerHeight]=\"50\" rowHeight=\"auto\" [scrollbarV]=\"true\"\n [virtualization]=\"false\" [externalPaging]=\"true\" [count]=\"data.totalCount\" [selected]=\"selectedTable\"\n [selectCheck]=\"selectCheck\" [selectionType]=\"_multiple?SelectionType.multiClick:SelectionType.single\" (select)=\"onSelectTableItem($event)\">\n <ngx-datatable-column [width]=\"50\" prop=\"id\" [sortable]=\"false\" [canAutoResize]=\"false\" [draggable]=\"false\"\n [resizeable]=\"false\">\n <ng-template ngx-datatable-header-template let-value=\"value\" let-allRowsSelected=\"allRowsSelected\"\n let-selectFn=\"selectFn\">\n <input type=\"checkbox\" class=\"form-check-input\" [checked]=\"allRowsSelected\"\n (change)=\"selectFn(!allRowsSelected)\" />\n </ng-template>\n <ng-template ngx-datatable-cell-template let-row=\"row\" let-value=\"value\" let-isSelected=\"isSelected\"\n let-onCheckboxChangeFn=\"onCheckboxChangeFn\">\n <input type=\"checkbox\" class=\"form-check-input\" [checked]=\"selectedcheckbox(value)\"\n (change)=\"onCheckboxChangeFn($event)\" />\n </ng-template>\n </ngx-datatable-column>\n <ngx-datatable-column [flexGrow]=\"2\">\n <ng-template let-row=\"row\" let-value=\"value\" ngx-datatable-cell-template>\n <fe-file-preview [width]=\"'80px'\" [src]=\"row.url\" [name]=\"row.name\" [type]=\"row.mimeType\" [preview]=\"true\"></fe-file-preview>\n </ng-template>\n </ngx-datatable-column>\n <ngx-datatable-column [name]=\"'FileExplorer::FileName' | abpLocalization\" prop=\"name\" [flexGrow]=\"4\">\n <ng-template let-row=\"row\" let-value=\"value\" ngx-datatable-cell-template>\n {{ value }}\n </ng-template>\n </ngx-datatable-column>\n <ngx-datatable-column [name]=\"'FileExplorer::FileSize' | abpLocalization\" prop=\"size\" [flexGrow]=\"1.5\">\n <ng-template let-row=\"row\" let-value=\"value\" ngx-datatable-cell-template>\n {{ _FileApiService.formatFileSize(value) }}\n </ng-template>\n </ngx-datatable-column>\n <ngx-datatable-column [name]=\"'FileExplorer::Directory' | abpLocalization\" prop=\"cellName\" [flexGrow]=\"1\">\n <ng-template let-row=\"row\" let-value=\"value\" ngx-datatable-cell-template>\n {{ value }}\n </ng-template>\n </ngx-datatable-column>\n <ngx-datatable-column [name]=\"'FileExplorer::CreationTime' | abpLocalization\" prop=\"creationTime\" [flexGrow]=\"2\">\n <ng-template let-row=\"row\" let-value=\"value\" ngx-datatable-cell-template>\n {{ value | date : 'YYYY/MM/dd HH:mm:s' }}\n </ng-template>\n </ngx-datatable-column>\n <ngx-datatable-column [flexGrow]=\"1\">\n <ng-template let-row=\"row\" let-value=\"value\" ngx-datatable-cell-template>\n <button class=\"btn btn-sm btn-light p-0\" (click.stop)=\"deleteFile(row)\">\n <i class=\"fas fa-trash text-primary p-2\"></i>\n </button>\n </ng-template>\n </ngx-datatable-column>\n </ngx-datatable>\n </div>\n <div *ngIf=\"uploadPictureStatusList.length > 0\"\n class=\"position-fixed bottom-0 end-0 shadow-lg file-status-modal m-5\"\n style=\"border-radius: 10px\">\n <div class=\"card p-1\">\n <div class=\"card-header d-flex align-items-center justify-content-between p-0 py-1 border-bottom\">\n <div>{{'FileExplorer::UploadFiles' | abpLocalization}}</div>\n <button type=\"button\" class=\"btn-close\" aria-label=\"Close\" (click.stop)=\"closeFileStatusModal()\"></button>\n </div>\n <div class=\"card-body\">\n <table class=\"table\">\n <thead>\n <tr>\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 uploadPictureStatusList; let i = index\">\n <tr>\n <th scope=\"row\">\n <div>{{ item.name }}</div>\n <div class=\"form-text text-danger\" *ngIf=\"item.size > sizeLimit\">\n {{'FileExplorer::ExceedsMaximumSize' | abpLocalization:_FileApiService.formatFileSize(sizeLimit)}}\n </div>\n </th>\n <td>{{ item.fileSize }}</td>\n <td>\n <i *ngIf=\"item.status === 1\" class=\"fas fa-check text-primary\"></i>\n <i *ngIf=\"item.status === 2\" class=\"fas fa-times-circle text-danger\"></i>\n </td>\n </tr>\n </ng-container>\n </tbody>\n </table>\n </div>\n </div>\n </div>\n </div>\n </div>\n </ng-template>\n <ng-template #abpFooter>\n <button type=\"button\" class=\"btn btn-secondary\" abpClose>{{'AbpUi::Close' | abpLocalization}}</button>\n <abp-button iconClass=\"fa fa-check\" (click)=\"modalSave()\">{{'AbpUi::Save' | abpLocalization}}</abp-button>\n </ng-template>\n</abp-modal>", styles: ["::ng-deep .file-modal .container-height{height:calc(100vh - 284px)}::ng-deep .file-modal .file-status-modal{background:#fff}::ng-deep .file-modal .file-status-modal .card-body{max-height:300px;overflow-y:auto}::ng-deep .file-modal .ngx-datatable.material.single-selection .datatable-body-row.active,::ng-deep .file-modal .ngx-datatable.material.single-selection .datatable-body-row.active .datatable-row-group,::ng-deep .file-modal .ngx-datatable.material.multi-selection .datatable-body-row.active,::ng-deep .file-modal .ngx-datatable.material.multi-selection .datatable-body-row.active .datatable-row-group,::ng-deep .file-modal .ngx-datatable.material.multi-click-selection .datatable-body-row.active,::ng-deep .file-modal .ngx-datatable.material.multi-click-selection .datatable-body-row.active .datatable-row-group{background-color:transparent!important}::ng-deep .file-modal .ant-tree .ant-tree-node-content-wrapper{padding:0}::ng-deep .file-modal .ant-tree .ant-tree-node-content-wrapper .custom-node{width:100%}::ng-deep .file-modal .ant-tree .ant-tree-node-content-wrapper .selected{background-color:var(--lpx-brand)!important}::ng-deep .file-modal .ant-tree .ant-tree-node-content-wrapper .selected .btn{color:var(--lpx-navbar-color)}::ng-deep .file-modal .ant-tree .ant-tree-node-content-wrapper.ant-tree-node-selected{background-color:transparent}::ng-deep .file-modal .ngx-datatable.fixed-header .datatable-header .datatable-header-inner .datatable-header-cell,::ng-deep .file-modal .ngx-datatable.material .datatable-body .datatable-body-row .datatable-body-cell{overflow:initial;line-break:anywhere}\n"] }]
463
+ ], template: "<abp-modal [(visible)]=\"ModalOpen\" (visibleChange)=\"ModalVisibleChange($event)\"\n [options]=\"{ size: 'xl', scrollable: false }\">\n <ng-template #abpHeader>\n <h3>{{'FileExplorer::FileExplorer' | abpLocalization}}</h3>\n </ng-template>\n <ng-template #abpBody>\n <div class=\"row file-explorer-modal-body file-modal\" *ngIf=\"ModalOpen\">\n <div class=\"col-3\" *ngIf=\"createDirectoryPermissionName\" style=\"overflow: auto; height: calc(100vh - 240px)\">\n <fe-file-modal-tree [theSelectedTreeNode]=\"_theSelectedTreeNode\" (nodeClick)=\"_nodeClick($event)\"\n (lookAllBtn)=\"lookAllFile()\" (treeNodeData)=\"treeNodeData($event)\"\n [fileContainerName]=\"_fileContainerName\"></fe-file-modal-tree>\n </div>\n <div [class]=\"createDirectoryPermissionName?'col-9':'col-12'\" style=\"height: calc(100vh - 240px)\">\n <div class=\"mb-3 d-flex justify-content-between align-items-center\">\n <div style=\"flex: 2\"><span *ngIf=\"selectedTable.length>1\" class=\"btn-link\"\n (click.stop)=\"onDeleteAllSelectFile()\" role=\"button\">{{'FileExplorer::Delete' | abpLocalization}}</span>\n </div>\n <div class=\"input-group form-file\" style=\"flex: 2\">\n <input type=\"file\" class=\"form-control\" #fileEdit [multiple]=\"_multiple\" (change)=\"getFileChange($event)\" />\n </div>\n </div>\n <div>\n <!-- [selectionType]=\"_multiple?SelectionType.checkbox:SelectionType.single\" -->\n <!-- [selectCheck]=\"selectCheck\" -->\n <ngx-datatable class=\"material container-height\" [rows]=\"data.items\" [list]=\"list\" columnMode=\"flex\"\n [headerHeight]=\"50\" [footerHeight]=\"50\" rowHeight=\"auto\" [scrollbarV]=\"true\" [virtualization]=\"false\"\n [externalPaging]=\"true\" [count]=\"data.totalCount\">\n <ngx-datatable-column [width]=\"50\" prop=\"id\" [sortable]=\"false\" [canAutoResize]=\"false\" [draggable]=\"false\"\n [resizeable]=\"false\">\n <ng-template ngx-datatable-header-template let-value=\"value\" let-allRowsSelected=\"allRowsSelected\"\n let-selectFn=\"selectFn\">\n <input type=\"checkbox\" class=\"form-check-input\" *ngIf=\"_multiple\" [checked]=\"isAllSelected\"\n (change)=\"onSelectAllFn($event,data.items)\" />\n </ng-template>\n <ng-template ngx-datatable-cell-template let-row=\"row\" let-value=\"value\">\n <input type=\"checkbox\" class=\"form-check-input\" [checked]=\"selectedcheckbox(value)\"\n (change)=\"onCheckboxChangeFn($event,row,data.items)\" />\n </ng-template>\n </ngx-datatable-column>\n <ngx-datatable-column [sortable]=\"false\" [flexGrow]=\"2\">\n <ng-template let-row=\"row\" let-value=\"value\" ngx-datatable-cell-template>\n <fe-file-preview [width]=\"'80px'\" [src]=\"row.url\" [name]=\"row.name\" [type]=\"row.mimeType\"\n [preview]=\"true\"></fe-file-preview>\n </ng-template>\n </ngx-datatable-column>\n <ngx-datatable-column [name]=\"'FileExplorer::FileName' | abpLocalization\" prop=\"name\" [sortable]=\"false\"\n [flexGrow]=\"4\">\n <ng-template let-row=\"row\" let-value=\"value\" ngx-datatable-cell-template>\n <div class=\"d-flex align-items-start titlehover\" *ngIf=\"newEditRow.id!==row.id\">\n <span class=\"me-2\">{{ value }}</span>\n <i class=\"fa fa-pencil-square-o\" role=\"button\" (click.stop)=\"onEditFileName(row)\" style=\"line-height:2;\" aria-hidden=\"true\"></i>\n </div>\n <div *ngIf=\"FileNameForm&&newEditRow.id===row.id\">\n <form [formGroup]=\"FileNameForm\" (ngSubmit)=\"onSubmitFileName($event)\">\n <div class=\"d-flex align-items-start\">\n <div class=\"me-2\">\n <input class=\"form-control \" type=\"text\" formControlName=\"fileName\">\n </div>\n <button class=\" btn btn-sm\" type=\"submit\">\n <i class=\"fa-spin fa fa-spinner\" *ngIf=\"isloading\"></i>\n <i class=\"fa fa-check\" aria-hidden=\"true\" *ngIf=\"!isloading\"></i></button>\n <button class=\" btn btn-sm\" (click.stop)=\"onCancelFileName(row)\"><i class=\"fa fa-times\" type=\"reset\" aria-hidden=\"true\"></i></button>\n \n </div>\n </form>\n </div>\n </ng-template>\n </ngx-datatable-column>\n <ngx-datatable-column [name]=\"'FileExplorer::FileSize' | abpLocalization\" prop=\"size\" [flexGrow]=\"1.5\">\n <ng-template let-row=\"row\" let-value=\"value\" ngx-datatable-cell-template>\n {{ _FileApiService.formatFileSize(value) }}\n </ng-template>\n </ngx-datatable-column>\n <ngx-datatable-column [name]=\"'FileExplorer::Directory' | abpLocalization\" prop=\"directoryId\"\n [sortable]=\"false\" [flexGrow]=\"1\">\n <ng-template let-row=\"row\" let-value=\"value\" ngx-datatable-cell-template>\n {{ value|getDirectoryName:fileGroupList }}\n </ng-template>\n </ngx-datatable-column>\n <ngx-datatable-column [name]=\"'FileExplorer::CreationTime' | abpLocalization\" prop=\"creationTime\"\n [flexGrow]=\"2\">\n <ng-template let-row=\"row\" let-value=\"value\" ngx-datatable-cell-template>\n {{ value | date : 'YYYY/MM/dd HH:mm:s' }}\n </ng-template>\n </ngx-datatable-column>\n <ngx-datatable-column [flexGrow]=\"1\" [sortable]=\"false\">\n <ng-template let-row=\"row\" let-value=\"value\" ngx-datatable-cell-template>\n <button class=\"btn btn-sm btn-light p-0\" (click.stop)=\"deleteFile(row)\">\n <i class=\"fas fa-trash text-primary p-2\"></i>\n </button>\n </ng-template>\n </ngx-datatable-column>\n </ngx-datatable>\n </div>\n <div *ngIf=\"uploadPictureStatusList.length > 0\"\n class=\"position-fixed bottom-0 end-0 shadow-lg file-status-modal m-5\" style=\"border-radius: 10px\">\n <div class=\"card p-1\">\n <div class=\"card-header d-flex align-items-center justify-content-between p-0 py-1 border-bottom\">\n <div>{{'FileExplorer::UploadFiles' | abpLocalization}}</div>\n <button type=\"button\" class=\"btn-close\" aria-label=\"Close\" (click.stop)=\"closeFileStatusModal()\"></button>\n </div>\n <div class=\"card-body\">\n <table class=\"table\">\n <thead>\n <tr>\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 uploadPictureStatusList; let i = index\">\n <tr>\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)}}\n </div>\n </th>\n <td>{{ item.fileSize }}</td>\n <td>\n <i *ngIf=\"item.status === 1\" class=\"fas fa-check text-primary\"></i>\n <i *ngIf=\"item.status === 2\" class=\"fas fa-times-circle text-danger\"></i>\n </td>\n </tr>\n </ng-container>\n </tbody>\n </table>\n </div>\n </div>\n </div>\n </div>\n </div>\n </ng-template>\n <ng-template #abpFooter>\n <button type=\"button\" class=\"btn btn-secondary\" abpClose>{{'AbpUi::Close' | abpLocalization}}</button>\n <abp-button iconClass=\"fa fa-check\" (click)=\"modalSave()\">{{'FileExplorer::Confirm' | abpLocalization}}\n @if(selectedTable.length>0){\n ({{selectedTable.length}})\n }\n </abp-button>\n </ng-template>\n</abp-modal>", styles: ["::ng-deep .file-modal .container-height{height:calc(100vh - 284px)}::ng-deep .file-modal .file-status-modal{background:#fff}::ng-deep .file-modal .file-status-modal .card-body{max-height:300px;overflow-y:auto}::ng-deep .file-modal .ngx-datatable.material.single-selection .datatable-body-row.active,::ng-deep .file-modal .ngx-datatable.material.single-selection .datatable-body-row.active .datatable-row-group,::ng-deep .file-modal .ngx-datatable.material.multi-selection .datatable-body-row.active,::ng-deep .file-modal .ngx-datatable.material.multi-selection .datatable-body-row.active .datatable-row-group,::ng-deep .file-modal .ngx-datatable.material.multi-click-selection .datatable-body-row.active,::ng-deep .file-modal .ngx-datatable.material.multi-click-selection .datatable-body-row.active .datatable-row-group{background-color:transparent!important}::ng-deep .file-modal .ant-tree .ant-tree-node-content-wrapper{padding:0}::ng-deep .file-modal .ant-tree .ant-tree-node-content-wrapper .ng-star-inserted[title]{padding:0 10px}::ng-deep .file-modal .ant-tree .ant-tree-node-content-wrapper .custom-node{width:100%}::ng-deep .file-modal .ant-tree .ant-tree-node-content-wrapper .selected{background-color:var(--lpx-brand)!important;color:var(--lpx-brand-text)}::ng-deep .file-modal .ant-tree .ant-tree-node-content-wrapper.ant-tree-node-selected{background-color:transparent}::ng-deep .file-modal .ngx-datatable.fixed-header .datatable-header .datatable-header-inner .datatable-header-cell,::ng-deep .file-modal .ngx-datatable.material .datatable-body .datatable-body-row .datatable-body-cell{overflow:initial;line-break:anywhere}::ng-deep .file-modal input[type=checkbox]{cursor:pointer}::ng-deep .file-modal .titlehover i{display:none}::ng-deep .file-modal .titlehover:hover i{display:block}\n"] }]
258
464
  }], ctorParameters: () => [{ type: i1.FileDescriptorService }, { type: i2.ToasterService }, { type: i3.ListService }, { type: i4.FileApiService }, { type: i3.RestService }, { type: i2.ConfirmationService }, { type: i3.LocalizationService }], propDecorators: { fileContainerName: [{
259
465
  type: Input
260
466
  }], multiple: [{
@@ -265,9 +471,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.5", ngImpor
265
471
  type: Input
266
472
  }], visibleChange: [{
267
473
  type: Output
268
- }], selectPickerFile: [{
269
- type: Input
270
474
  }], selectFilefn: [{
271
475
  type: Output
476
+ }], selectPickerFile: [{
477
+ type: Input
272
478
  }] } });
273
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"file-modal.component.js","sourceRoot":"","sources":["../../../../../../../packages/file-explorer/src/lib/components/file-modal/file-modal.component.ts","../../../../../../../packages/file-explorer/src/lib/components/file-modal/file-modal.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, Output, SimpleChanges, inject } from '@angular/core';\nimport * as FileService from '../../proxy/dignite/file-explorer/files';\nimport { Confirmation, ConfirmationService, ToasterService } from '@abp/ng.theme.shared';\nimport { PagedResultDto, ABP, ListService, Rest, RestService, LocalizationService, LIST_QUERY_DEBOUNCE_TIME } from '@abp/ng.core';\nimport { FileDescriptorDto, FileDescriptorService, GetFilesInput } from '../../proxy/dignite/file-explorer/files';\nimport { FileApiService } from '../../services/file-api.service';\nimport { SelectionType } from '@swimlane/ngx-datatable';\nvar that\n@Component({\n  // eslint-disable-next-line @angular-eslint/component-selector\n  selector: 'fe-file-modal',\n  templateUrl: './file-modal.component.html',\n  styleUrls: ['./file-modal.component.scss'],\n  providers: [\n    // [Required]\n    ListService,\n    // [Optional]\n    // Provide this token if you want a different debounce time.\n    // Default is 300. Cannot be 0. Any value below 100 is not recommended.\n    { provide: LIST_QUERY_DEBOUNCE_TIME, useValue: 500 },\n  ]\n})\nexport class FileModalComponent {\n\n  constructor(\n    private _FileService: FileService.FileDescriptorService,\n    private toaster: ToasterService,\n    public readonly list: ListService,\n    public _FileApiService: FileApiService,\n    private restService: RestService,\n    private confirmation: ConfirmationService,\n    private _LocalizationService: LocalizationService,\n  ) {\n    that = this\n    \n  }\n\n  private _FileDescriptorService=inject(FileDescriptorService)\n  /**获取目录配置 */\n  getFilesConfiguration(){\n    this._FileDescriptorService.getFileContainerConfiguration(this._fileContainerName).subscribe(res=>{\n      this.createDirectoryPermissionName=res?.createDirectoryPermissionName\n    })\n  }\n  /**目录的权限名称 */\n  createDirectoryPermissionName:string=null\n\n  /**图片容器 */\n  _fileContainerName: string\n  @Input()\n  public set fileContainerName(v: string) {\n    if (v) {\n      this._fileContainerName = v;\n      this.loadData()\n    }\n  }\n\n  /**是否多选 */\n  _multiple: boolean = false\n  @Input()\n  public set multiple(v: boolean) {\n    this._multiple = v;\n    if (v) { }\n  }\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  @Input()\n  public set visible(v: boolean) {\n    this.ModalOpen = v;\n    if (v) {\n      this.loadData()\n    }\n  }\n\n  /**模态框状态回调 */\n  @Output() visibleChange = new EventEmitter()\n\n\n\n  /**模态框-状态-是否打开 */\n  ModalOpen: boolean = false\n\n  /**模态框-繁忙状态-用于确定模态的繁忙状态是否为真 */\n  ModalBusy: boolean = false\n\n\n\n  /**模态框-状态改变回调 */\n  ModalVisibleChange(event) {\n    if (!event) {\n      this.visibleChange.emit(event)\n      return\n    }\n  }\n\n  /**模态框保存 */\n  modalSave() {\n    let selectedTablearr = this._FileApiService.deepClone(this.selectedTable)\n    this.selectFilefn.emit(selectedTablearr)\n\n    this.ModalVisibleChange(false)\n  }\n  /**dignite-file-modal-tree */\n  /**选择的tree节点 */\n  _theSelectedTreeNode: any = ''\n\n  /**初始化数据 */\n  loadData() {\n    if (this.ModalOpen && this._fileContainerName) {\n      this.hookToQuery()\n      this.getFilesConfiguration()\n    }\n  }\n\n  /**tree-节点选择 */\n  _nodeClick(event) {\n    this._theSelectedTreeNode = event\n    this.list.get()\n  }\n\n  /**图片上传-要上传图片的状态文件列表 */\n  uploadPictureStatusList: any[] = []\n\n  /**图片上传-获取文件信息改变 */\n  async getFileChange(event) {\n    let files = new Array(...event.target.files)\n    this.uploadPictureStatusList = files\n    for (const file of files) {\n      if (file.size > this.sizeLimit) {\n        this.setuploadPictureStatus(file, 2)\n        continue;\n      }\n      await this.uploadingFile(file).then(() => {\n        this.setuploadPictureStatus(file, 1)\n        this.list.get()\n      }).catch(() => {\n        this.setuploadPictureStatus(file, 2)\n      }); // 等待每个文件上传完成  \n    }\n    this.list.get()\n    let isSubmit = !this.uploadPictureStatusList.some(el => el.status == 2);\n    if (isSubmit) {\n      // this.toaster.success(\"上传完成\");\n      setTimeout(() => {\n        this.uploadPictureStatusList = []\n      }, 6000)\n    }\n  }\n\n  /**图片上传-设置uploadPictureStatusList的状态 */\n  setuploadPictureStatus(file, type) {\n    this.uploadPictureStatusList.map(el => {\n      if (el == file) el.status = type\n    })\n  }\n\n\n  /**图片上传-递归按顺序上传 */\n  uploadingFile(file) {\n    return new Promise((resolve, rejects) => {\n      let formData = new FormData();\n      formData.append('file', file, file.name);\n      this.createFile({\n        file: formData,\n        containerName: this._fileContainerName,\n        directoryId: this._theSelectedTreeNode?.key || '',\n        entityId: ''\n      }).subscribe(res => {\n        resolve(true)\n      }, (err) => {\n        rejects(false)\n      })\n    })\n  }\n\n\n  /**文件表格-数据*/\n  data: PagedResultDto<FileDescriptorDto> = {\n    items: [],\n    totalCount: 0,\n  };\n\n  /**文件表格-条件*/\n  filters = {} as GetFilesInput;\n\n  /**文件表格-表格自带选择类型 */\n  SelectionType = SelectionType;\n\n  /**文件表格-选择的表格数据项 */\n  selectedTable = []\n\n  /**已选定的文件 */\n  @Input() selectPickerFile: any[]\n\n  ngOnChanges(changes: SimpleChanges): void {\n    //Called before any other lifecycle hook. Use it to inject dependencies, but avoid any serious work here.\n    //Add '${implements OnChanges}' to the class.\n    this.selectedTable = this._FileApiService.deepClone(this.selectPickerFile)\n  }\n  /**当前选择的table项 id */\n  nowSelectId: any = ''\n\n  /**选择文件回调 */\n  @Output() selectFilefn = new EventEmitter<any[]>()\n\n  /**文件表格-获取表格数据 */\n  hookToQuery() {\n    const getData = (query: ABP.PageQueryParams) => this._FileService.getList({\n      ...query,\n      ...this.filters,\n      containerName: this._fileContainerName,\n      directoryId: this._theSelectedTreeNode.key\n    });\n    const setData = (list: PagedResultDto<FileDescriptorDto>) => (this.data = list);\n    this.list.hookToQuery(getData).subscribe(setData);\n  }\n\n  /**文件表格-查看所有分组的文件数据 */\n  lookAllFile() {\n    this._theSelectedTreeNode = ''\n    this.list.get()\n  }\n\n  /**选择表格项 */\n  onSelectTableItem({ selected }) {\n    this.selectedTable = this._FileApiService.deepClone(selected)\n    let selectedTablearr = this.removeDuplicatesById(this.selectedTable)\n    if (selected.length > selectedTablearr.length) {\n      selectedTablearr = selectedTablearr.filter(el => el.id !== this.nowSelectId)\n    }\n    this.selectedTable = selectedTablearr\n  }\n\n  /**删除数组中重复的项 */\n  removeDuplicatesById(array) {\n    const seenIds = {};\n    return array.filter(item => {\n      if (!seenIds[item.id]) {\n        seenIds[item.id] = true;\n        return true;\n      }\n      return false;\n    });\n  }\n\n  /**一个布尔or函数，可用于检查是否要根据条件选择特定行。 */\n  selectCheck = (row, column, value) => {\n    this.nowSelectId = row.id\n    return true;\n  }\n\n  /**判断row是否选中 */\n  selectedcheckbox = (id) => {\n    return this.selectedTable.some(el => el.id == id)\n  }\n\n\n\n  /**删除图片 */\n  deleteFile(file) {\n\n    this.confirmation\n      .warn('', { key: '', defaultValue: this._LocalizationService.instant(`AbpUi::ItemWillBeDeletedMessage`) })\n      .subscribe((status: Confirmation.Status) => {\n        if (status == 'confirm') {\n          this._FileService.delete(file.id).subscribe(res => {\n            this.toaster.success(this._LocalizationService.instant(`AbpUi::DeletedSuccessfully`));\n            this.list.get()\n          })\n        }\n      });\n  }\n\n  /**关闭文件状态弹窗 */\n  closeFileStatusModal() {\n    this.uploadPictureStatusList = []\n  }\n\n  /**创建图片的接口，代理中的file类型不匹配，切换为any类型 */\n  createFile = (input: any, config?: Partial<Rest.Config>) =>\n    this.restService.request<any, FileDescriptorDto>({\n      method: 'POST',\n      url: '/api/file-explorer/files',\n      params: { containerName: input.containerName, cellName: input.cellName, directoryId: input.directoryId, entityId: input.entityId },\n      body: input.file,\n    },\n      { apiName: 'FileExplorer', ...config });\n}\n","<abp-modal [(visible)]=\"ModalOpen\" (visibleChange)=\"ModalVisibleChange($event)\"\n  [options]=\"{ size: 'xl', scrollable: false }\">\n  <ng-template #abpHeader>\n    <h3>{{'FileExplorer::FileExplorer' | abpLocalization}}</h3>\n  </ng-template>\n  <ng-template #abpBody>\n    <div class=\"row file-explorer-modal-body file-modal\">\n      <div class=\"col-3\" *ngIf=\"createDirectoryPermissionName\"  style=\"overflow: auto; height: calc(100vh - 240px)\">\n        <fe-file-modal-tree [theSelectedTreeNode]=\"_theSelectedTreeNode\" (nodeClick)=\"_nodeClick($event)\"\n          [fileContainerName]=\"_fileContainerName\"></fe-file-modal-tree>\n      </div>\n      <div [class]=\"createDirectoryPermissionName?'col-9':'col-12'\" style=\"height: calc(100vh - 240px)\">\n        <div class=\"mb-3 d-flex justify-content-between align-items-center\">\n          <div class=\"btn-link\" role=button style=\"flex: 2\" (click)=\"lookAllFile()\">{{'FileExplorer::AllFiles' | abpLocalization}}</div>\n          <div class=\"input-group form-file\" style=\"flex: 2\">\n            <input type=\"file\" class=\"form-control\" #fileEdit [multiple]=\"_multiple\" \n              (change)=\"getFileChange($event)\" />\n          </div>\n        </div>\n        <div>\n          <ngx-datatable class=\"material container-height\" [rows]=\"data.items\" [list]=\"list\" columnMode=\"flex\"\n            [columns]=\"columns\" [headerHeight]=\"50\" [footerHeight]=\"50\" rowHeight=\"auto\" [scrollbarV]=\"true\"\n            [virtualization]=\"false\" [externalPaging]=\"true\" [count]=\"data.totalCount\" [selected]=\"selectedTable\"\n            [selectCheck]=\"selectCheck\" [selectionType]=\"_multiple?SelectionType.multiClick:SelectionType.single\" (select)=\"onSelectTableItem($event)\">\n            <ngx-datatable-column [width]=\"50\" prop=\"id\" [sortable]=\"false\" [canAutoResize]=\"false\" [draggable]=\"false\"\n              [resizeable]=\"false\">\n              <ng-template ngx-datatable-header-template let-value=\"value\" let-allRowsSelected=\"allRowsSelected\"\n                let-selectFn=\"selectFn\">\n                <input type=\"checkbox\" class=\"form-check-input\" [checked]=\"allRowsSelected\"\n                  (change)=\"selectFn(!allRowsSelected)\" />\n              </ng-template>\n              <ng-template ngx-datatable-cell-template let-row=\"row\" let-value=\"value\" let-isSelected=\"isSelected\"\n                let-onCheckboxChangeFn=\"onCheckboxChangeFn\">\n                <input type=\"checkbox\" class=\"form-check-input\" [checked]=\"selectedcheckbox(value)\"\n                  (change)=\"onCheckboxChangeFn($event)\" />\n              </ng-template>\n            </ngx-datatable-column>\n            <ngx-datatable-column   [flexGrow]=\"2\">\n              <ng-template let-row=\"row\" let-value=\"value\" ngx-datatable-cell-template>\n                <fe-file-preview [width]=\"'80px'\" [src]=\"row.url\" [name]=\"row.name\" [type]=\"row.mimeType\" [preview]=\"true\"></fe-file-preview>\n              </ng-template>\n            </ngx-datatable-column>\n            <ngx-datatable-column [name]=\"'FileExplorer::FileName' | abpLocalization\" prop=\"name\" [flexGrow]=\"4\">\n              <ng-template let-row=\"row\" let-value=\"value\" ngx-datatable-cell-template>\n                {{ value }}\n              </ng-template>\n            </ngx-datatable-column>\n            <ngx-datatable-column  [name]=\"'FileExplorer::FileSize' | abpLocalization\" prop=\"size\" [flexGrow]=\"1.5\">\n              <ng-template let-row=\"row\" let-value=\"value\" ngx-datatable-cell-template>\n                {{ _FileApiService.formatFileSize(value) }}\n              </ng-template>\n            </ngx-datatable-column>\n            <ngx-datatable-column  [name]=\"'FileExplorer::Directory' | abpLocalization\" prop=\"cellName\" [flexGrow]=\"1\">\n              <ng-template let-row=\"row\" let-value=\"value\" ngx-datatable-cell-template>\n                {{ value }}\n              </ng-template>\n            </ngx-datatable-column>\n            <ngx-datatable-column [name]=\"'FileExplorer::CreationTime' | abpLocalization\" prop=\"creationTime\" [flexGrow]=\"2\">\n              <ng-template let-row=\"row\" let-value=\"value\" ngx-datatable-cell-template>\n                {{ value | date : 'YYYY/MM/dd HH:mm:s' }}\n              </ng-template>\n            </ngx-datatable-column>\n            <ngx-datatable-column [flexGrow]=\"1\">\n              <ng-template let-row=\"row\" let-value=\"value\" ngx-datatable-cell-template>\n                <button class=\"btn btn-sm btn-light p-0\" (click.stop)=\"deleteFile(row)\">\n                  <i class=\"fas fa-trash text-primary p-2\"></i>\n                </button>\n              </ng-template>\n            </ngx-datatable-column>\n          </ngx-datatable>\n        </div>\n        <div *ngIf=\"uploadPictureStatusList.length > 0\"\n          class=\"position-fixed bottom-0 end-0 shadow-lg file-status-modal   m-5\"\n          style=\"border-radius: 10px\">\n          <div class=\"card p-1\">\n            <div class=\"card-header d-flex align-items-center justify-content-between p-0 py-1 border-bottom\">\n              <div>{{'FileExplorer::UploadFiles' | abpLocalization}}</div>\n              <button type=\"button\" class=\"btn-close\" aria-label=\"Close\" (click.stop)=\"closeFileStatusModal()\"></button>\n            </div>\n            <div class=\"card-body\">\n              <table class=\"table\">\n                <thead>\n                  <tr>\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 uploadPictureStatusList; let i = index\">\n                    <tr>\n                      <th scope=\"row\">\n                        <div>{{ item.name }}</div>\n                        <div class=\"form-text text-danger\" *ngIf=\"item.size > sizeLimit\">\n                          {{'FileExplorer::ExceedsMaximumSize' | abpLocalization:_FileApiService.formatFileSize(sizeLimit)}}\n                        </div>\n                      </th>\n                      <td>{{ item.fileSize }}</td>\n                      <td>\n                        <i *ngIf=\"item.status === 1\" class=\"fas fa-check text-primary\"></i>\n                        <i *ngIf=\"item.status === 2\" class=\"fas fa-times-circle text-danger\"></i>\n                      </td>\n                    </tr>\n                  </ng-container>\n                </tbody>\n              </table>\n            </div>\n          </div>\n        </div>\n      </div>\n    </div>\n  </ng-template>\n  <ng-template #abpFooter>\n    <button type=\"button\" class=\"btn btn-secondary\" abpClose>{{'AbpUi::Close' | abpLocalization}}</button>\n    <abp-button iconClass=\"fa fa-check\" (click)=\"modalSave()\">{{'AbpUi::Save' | abpLocalization}}</abp-button>\n  </ng-template>\n</abp-modal>"]}
479
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"file-modal.component.js","sourceRoot":"","sources":["../../../../../../../packages/file-explorer/src/lib/components/file-modal/file-modal.component.ts","../../../../../../../packages/file-explorer/src/lib/components/file-modal/file-modal.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, Output, SimpleChanges, inject } from '@angular/core';\nimport * as FileService from '../../proxy/dignite/file-explorer/files';\nimport { Confirmation, ConfirmationService, ToasterService } from '@abp/ng.theme.shared';\nimport {\n  PagedResultDto,\n  ABP,\n  ListService,\n  Rest,\n  RestService,\n  LocalizationService,\n  LIST_QUERY_DEBOUNCE_TIME,\n} from '@abp/ng.core';\nimport {\n  FileDescriptorDto,\n  FileDescriptorService,\n  GetFilesInput,\n} from '../../proxy/dignite/file-explorer/files';\nimport { FileApiService } from '../../services/file-api.service';\nimport { SelectionType } from '@swimlane/ngx-datatable';\nimport { FormControl, FormGroup, Validators } from '@angular/forms';\nimport { finalize } from 'rxjs';\nvar that;\n@Component({\n  // eslint-disable-next-line @angular-eslint/component-selector\n  selector: 'fe-file-modal',\n  templateUrl: './file-modal.component.html',\n  styleUrls: ['./file-modal.component.scss'],\n  providers: [\n    // [Required]\n    ListService,\n    // [Optional]\n    // Provide this token if you want a different debounce time.\n    // Default is 300. Cannot be 0. Any value below 100 is not recommended.\n    { provide: LIST_QUERY_DEBOUNCE_TIME, useValue: 500 },\n  ],\n})\nexport class FileModalComponent {\n  constructor(\n    private _FileService: FileService.FileDescriptorService,\n    private toaster: ToasterService,\n    public readonly list: ListService,\n    public _FileApiService: FileApiService,\n    private restService: RestService,\n    private confirmation: ConfirmationService,\n    private _LocalizationService: LocalizationService\n  ) {\n    that = this;\n  }\n\n  private _FileDescriptorService = inject(FileDescriptorService);\n  /**获取目录配置 */\n  getFilesConfiguration() {\n    return new Promise((resolve, reject) => {\n      this._FileDescriptorService\n        .getFileContainerConfiguration(this._fileContainerName)\n        .subscribe(res => {\n          this.createDirectoryPermissionName = res?.createDirectoryPermissionName;\n          resolve(res);\n        });\n    });\n  }\n  /**目录的权限名称 */\n  createDirectoryPermissionName: string = null;\n\n  /**图片容器 */\n  _fileContainerName: string;\n  @Input()\n  public set fileContainerName(v: string) {\n    if (v) {\n      this._fileContainerName = v;\n      // this.loadData()\n    }\n  }\n\n  /**是否多选 */\n  _multiple: boolean = false;\n  @Input()\n  public set multiple(v: boolean) {\n    this._multiple = v;\n    if (v) {\n    }\n  }\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  @Input()\n  public set visible(v: boolean) {\n    this.ModalOpen = v;\n    if (v) {\n      this.loadData();\n    }\n  }\n\n  /**模态框状态回调 */\n  @Output() visibleChange = new EventEmitter();\n\n  /**模态框-状态-是否打开 */\n  ModalOpen: boolean = false;\n\n  /**模态框-繁忙状态-用于确定模态的繁忙状态是否为真 */\n  ModalBusy: boolean = false;\n\n  /**模态框-状态改变回调 */\n  ModalVisibleChange(event) {\n    if (!event) {\n      this.ModalOpen = false;\n      this.ModalBusy = false;\n      this.visibleChange.emit(event);\n      this.createDirectoryPermissionName = '';\n      this._theSelectedTreeNode = '';\n      this.selectedTable = [];\n      this.uploadPictureStatusList = [];\n      return;\n    }\n  }\n\n  /**模态框保存 */\n  modalSave() {\n    let selectedTablearr = this._FileApiService.deepClone(this.selectedTable);\n    this.selectFilefn.emit(selectedTablearr);\n    this.ModalVisibleChange(false);\n  }\n  /**dignite-file-modal-tree */\n  /**选择的tree节点 */\n  _theSelectedTreeNode: any = '';\n  isCreateList: boolean = false;\n  /**初始化数据 */\n  loadData() {\n    if (this.ModalOpen && this._fileContainerName) {\n      this.list.maxResultCount = 100;\n      // this.filters.skipCount = 0;\n      this.getFilesConfiguration();\n      if (!this.isCreateList) {\n        this.hookToQuery();\n        this.isCreateList = true;\n      } else {\n        this.list.get();\n      }\n    }\n  }\n  /** 从tree获取来的数据 */\n  fileGroupList: any[] = [];\n  /** 从tree获取数据 */\n  treeNodeData(event) {\n    this.fileGroupList = this.flattenNestedArray(event);\n  }\n  /**\n   * 将嵌套数组扁平化\n   * @param {Array} nestedArray - 包含嵌套children的数组\n   * @returns {Array} - 扁平化后的数组\n   */\n  flattenNestedArray(nestedArray) {\n    let result = [];\n\n    function flatten(items) {\n      if (!items) return;\n\n      for (const item of items) {\n        // 将当前项添加到结果数组\n        result.push({ ...item });\n\n        // 如果有children属性且是数组，递归处理\n        if (item.children && Array.isArray(item.children)) {\n          flatten(item.children);\n        }\n      }\n    }\n\n    flatten(nestedArray);\n    return result;\n  }\n\n  /**tree-节点选择 */\n  _nodeClick(event) {\n    this.filters.skipCount = 0;\n    this._theSelectedTreeNode = event;\n    this.list.get();\n  }\n\n  /**图片上传-要上传图片的状态文件列表 */\n  uploadPictureStatusList: any[] = [];\n\n  /**图片上传-获取文件信息改变 */\n  async getFileChange(event) {\n    let files = new Array(...event.target.files);\n    this.uploadPictureStatusList = files;\n    for (const file of files) {\n      if (file.size > this.sizeLimit) {\n        this.setuploadPictureStatus(file, 2);\n        continue;\n      }\n      await this.uploadingFile(file)\n        .then(res => {\n          this.selectedTable.push(res);\n          this.setuploadPictureStatus(file, 1);\n          // this.list.get()\n        })\n        .catch(() => {\n          this.setuploadPictureStatus(file, 2);\n        }); // 等待每个文件上传完成\n    }\n    this.list.get();\n    let isSubmit = !this.uploadPictureStatusList.some(el => el.status == 2);\n    if (isSubmit) {\n      // this.toaster.success(\"上传完成\");\n      setTimeout(() => {\n        this.uploadPictureStatusList = [];\n      }, 4000);\n    }\n  }\n\n  /**图片上传-设置uploadPictureStatusList的状态 */\n  setuploadPictureStatus(file, type) {\n    this.uploadPictureStatusList.map(el => {\n      if (el == file) el.status = type;\n    });\n  }\n\n  /**图片上传-递归按顺序上传 */\n  uploadingFile(file) {\n    return new Promise((resolve, rejects) => {\n      let formData = new FormData();\n      formData.append('file', file, file.name);\n      this.createFile({\n        file: formData,\n        containerName: this._fileContainerName,\n        directoryId: this._theSelectedTreeNode?.key || '',\n        entityId: '',\n      }).subscribe(\n        res => {\n          resolve(res);\n        },\n        err => {\n          rejects(false);\n        }\n      );\n    });\n  }\n\n  /**文件表格-数据*/\n  data: PagedResultDto<FileDescriptorDto> = {\n    items: [],\n    totalCount: 0,\n  };\n\n  /**文件表格-条件*/\n  filters = {} as GetFilesInput;\n\n  /**文件表格-表格自带选择类型 */\n  SelectionType = SelectionType;\n\n  /**选择文件回调 */\n  @Output() selectFilefn = new EventEmitter<any[]>();\n\n  /**文件表格-获取表格数据 */\n  hookToQuery() {\n    const getData = (query: ABP.PageQueryParams) =>\n      this._FileService.getList({\n        ...query,\n        ...this.filters,\n        containerName: this._fileContainerName,\n        directoryId: this._theSelectedTreeNode.key,\n      });\n    const setData = (list: PagedResultDto<FileDescriptorDto>) => {\n      this.data = list;\n      this.onPageChange(list.items);\n    };\n    this.list.hookToQuery(getData).subscribe(setData);\n  }\n\n  /**文件表格-查看所有分组的文件数据 */\n  lookAllFile() {\n    this.filters.skipCount = 0;\n    this._theSelectedTreeNode = '';\n    this.list.get();\n  }\n\n  /**删除图片 */\n  deleteFile(file) {\n    this._FileService.delete(file.id).subscribe(res => {\n      this.toaster.success(this._LocalizationService.instant(`FileExplorer::DeletedSuccessfully`));\n      this.list.get();\n    });\n  }\n\n  /**删除所有选中图片 */\n  onDeleteAllSelectFile() {\n    this.confirmation\n      .warn('', {\n        key: '',\n        defaultValue: this._LocalizationService.instant(`FileExplorer::AreYouSure`),\n      })\n      .subscribe(async (status: Confirmation.Status) => {\n        if (status == 'confirm') {\n          let selectedTable = this.selectedTable;\n          try {\n            const result = await this.batchDeleteItems(selectedTable);\n            if (result.success) {\n              this.toaster.success(result.message);\n              this.list.get();\n              // 可能需要刷新表格或更新UI\n            } else {\n              //删除失败的项\n              this.list.get();\n              // console.warn(result.message);\n              // 可以选择展示失败项或重试\n            }\n          } catch (error) {\n            //批量删除过程中发生错误\n          }\n        }\n      });\n  }\n\n  /**\n   * 批量删除表格项\n   * @param selectedTable 需要删除的表格项数组\n   * @returns 包含成功状态和失败项的结果对象\n   */\n  async batchDeleteItems(selectedTable: any[]) {\n    // 存储所有删除请求的Promise\n    const deletePromises = selectedTable.map(item => {\n      return new Promise((resolve, reject) => {\n        this._FileService.delete(item.id).subscribe(\n          () => {\n            resolve(null);\n          },\n          () => {\n            reject(item);\n          }\n        );\n      });\n    });\n\n    // 等待所有请求完成\n    const results = await Promise.allSettled(deletePromises);\n    console.log(results, 'resultsresultsresults');\n    // 收集失败的项\n    const failedItems: any[] = [];\n    results.forEach(result => {\n      if (result.status === 'rejected') {\n        failedItems.push(result.reason);\n      }\n    });\n\n    return {\n      success: failedItems.length === 0,\n      failedItems,\n      message:\n        failedItems.length === 0\n          ? this._LocalizationService.instant(`FileExplorer::DeletedSuccessfully`)\n          : `${failedItems.length}个项删除失败`,\n    };\n  }\n\n  // 使用示例\n  async handleBatchDelete() {}\n\n  /**关闭文件状态弹窗 */\n  closeFileStatusModal() {\n    this.uploadPictureStatusList = [];\n  }\n\n  /**创建图片的接口，代理中的file类型不匹配，切换为any类型 */\n  createFile = (input: any, config?: Partial<Rest.Config>) =>\n    this.restService.request<any, FileDescriptorDto>(\n      {\n        method: 'POST',\n        url: '/api/file-explorer/files',\n        params: {\n          containerName: input.containerName,\n          cellName: input.cellName,\n          directoryId: input.directoryId,\n          entityId: input.entityId,\n        },\n        body: input.file,\n      },\n      { apiName: 'FileExplorer', ...config }\n    );\n\n  /**文件表格-选择的表格数据项 */\n  selectedTable = [];\n  /**当前选择的table项 id */\n  nowSelectId: any = '';\n  /**是否全选 */\n  isAllSelected = false;\n\n  /**已选定的文件 */\n  @Input() selectPickerFile: any[];\n\n  ngOnChanges(changes: SimpleChanges): void {\n    //Called before any other lifecycle hook. Use it to inject dependencies, but avoid any serious work here.\n    //Add '${implements OnChanges}' to the class.\n    this.selectedTable = this._FileApiService.deepClone(this.selectPickerFile);\n  }\n  /**表格分页切换 */\n  onPageChange(newArray) {\n    this.isAllSelected = this.isAllSelectedFn(newArray, this.selectedTable);\n  }\n  /**行选择框改变 */\n  onCheckboxChangeFn(event, row, array: any[]) {\n    const { checked } = event.target;\n    let selectedTableArray = [...this.selectedTable];\n    if (this._multiple) {\n      if (checked) {\n        selectedTableArray.push(row);\n      } else {\n        selectedTableArray = selectedTableArray.filter(el => el.id != row.id);\n      }\n      this.isAllSelected = this.isAllSelectedFn(array, selectedTableArray);\n    } else {\n      selectedTableArray.length = 0;\n      selectedTableArray = checked ? [row] : [];\n    }\n    this.selectedTable = this.removeDuplicatesById(selectedTableArray);\n  }\n  /**如果selectedTableArray不含array中的所有项，则将isAllSelected设为true,否则设为false */\n  isAllSelectedFn(tolalArray: any[], selectedArray: any[] = []) {\n    if(tolalArray.length == 0) return false;\n    return tolalArray.every(item => selectedArray.some(el => el.id === item.id));\n  }\n  /**选择当前页全部 */\n  onSelectAllFn(event: any, array: any[]) {\n    let selectedTableArray = this.selectedTable;\n    if (event.target.checked) {\n      selectedTableArray = this.removeDuplicatesById([...selectedTableArray, ...array]);\n    } else {\n      selectedTableArray = selectedTableArray.filter(el => !array.some(item => item.id === el.id));\n    }\n    this.isAllSelected = event.target.checked;\n    this.selectedTable = selectedTableArray;\n  }\n\n  /**判断row是否选中 */\n  selectedcheckbox = id => {\n    return this.selectedTable.some(el => el.id === id);\n  };\n  /**删除数组中重复的项 */\n  removeDuplicatesById(array) {\n    const seenIds = {};\n    return array.filter(item => {\n      if (!seenIds[item.id]) {\n        seenIds[item.id] = true;\n        return true;\n      }\n      return false;\n    });\n  }\n  /**用于编辑的表单，同时只能显示编辑一个 */\n  FileNameForm: FormGroup | any;\n  /**当前编辑的row */\n  newEditRow: any = '';\n  /**是否正在加载 */\n  isloading: boolean = false;\n  /**提交FileName编辑 */\n  onSubmitFileName(event) {\n    let input = this.FileNameForm.value;\n    if (!this.FileNameForm.valid) return;\n    if (this.isloading) return;\n    this.isloading = true;\n    this._FileService\n      .update(input.id, {\n        name:input.fileName\n      })\n      .pipe(\n        finalize(() => {\n          this.isloading = false;\n        })\n      )\n      .subscribe(res => {\n        //通过当前newEditRow的id,修改data.items中对应项的name\n        for (const element of this.data.items) {\n          if (element.id == this.newEditRow.id) {\n            element.name = input.fileName;\n            break;\n          }\n        }\n\n        this.FileNameForm = undefined;\n        this.newEditRow = '';\n        this.toaster.success(this._LocalizationService.instant(`FileExplorer::SavedSuccessfully`));\n        // this.list.get();\n      });\n  }\n  /**打开编辑 */\n  onEditFileName(row) {\n    this.FileNameForm = new FormGroup({\n      fileName: new FormControl('', [Validators.required]),\n      id: new FormControl('', [Validators.required]),\n    });\n    this.FileNameForm.patchValue({\n      fileName: row.name,\n      id: row.id,\n    });\n    this.newEditRow = row;\n  }\n  /**关闭编辑 */\n  onCancelFileName(row) {\n    this.newEditRow = '';\n    this.FileNameForm = undefined;\n  }\n}\n","<abp-modal [(visible)]=\"ModalOpen\" (visibleChange)=\"ModalVisibleChange($event)\"\n  [options]=\"{ size: 'xl', scrollable: false }\">\n  <ng-template #abpHeader>\n    <h3>{{'FileExplorer::FileExplorer' | abpLocalization}}</h3>\n  </ng-template>\n  <ng-template #abpBody>\n    <div class=\"row file-explorer-modal-body file-modal\" *ngIf=\"ModalOpen\">\n      <div class=\"col-3\" *ngIf=\"createDirectoryPermissionName\" style=\"overflow: auto; height: calc(100vh - 240px)\">\n        <fe-file-modal-tree [theSelectedTreeNode]=\"_theSelectedTreeNode\" (nodeClick)=\"_nodeClick($event)\"\n          (lookAllBtn)=\"lookAllFile()\" (treeNodeData)=\"treeNodeData($event)\"\n          [fileContainerName]=\"_fileContainerName\"></fe-file-modal-tree>\n      </div>\n      <div [class]=\"createDirectoryPermissionName?'col-9':'col-12'\" style=\"height: calc(100vh - 240px)\">\n        <div class=\"mb-3 d-flex justify-content-between align-items-center\">\n          <div style=\"flex: 2\"><span *ngIf=\"selectedTable.length>1\" class=\"btn-link\"\n              (click.stop)=\"onDeleteAllSelectFile()\" role=\"button\">{{'FileExplorer::Delete' | abpLocalization}}</span>\n          </div>\n          <div class=\"input-group form-file\" style=\"flex: 2\">\n            <input type=\"file\" class=\"form-control\" #fileEdit [multiple]=\"_multiple\" (change)=\"getFileChange($event)\" />\n          </div>\n        </div>\n        <div>\n          <!-- [selectionType]=\"_multiple?SelectionType.checkbox:SelectionType.single\" -->\n          <!-- [selectCheck]=\"selectCheck\" -->\n          <ngx-datatable class=\"material container-height\" [rows]=\"data.items\" [list]=\"list\" columnMode=\"flex\"\n            [headerHeight]=\"50\" [footerHeight]=\"50\" rowHeight=\"auto\" [scrollbarV]=\"true\" [virtualization]=\"false\"\n            [externalPaging]=\"true\" [count]=\"data.totalCount\">\n            <ngx-datatable-column [width]=\"50\" prop=\"id\" [sortable]=\"false\" [canAutoResize]=\"false\" [draggable]=\"false\"\n              [resizeable]=\"false\">\n              <ng-template ngx-datatable-header-template let-value=\"value\" let-allRowsSelected=\"allRowsSelected\"\n                let-selectFn=\"selectFn\">\n                <input type=\"checkbox\" class=\"form-check-input\" *ngIf=\"_multiple\" [checked]=\"isAllSelected\"\n                  (change)=\"onSelectAllFn($event,data.items)\" />\n              </ng-template>\n              <ng-template ngx-datatable-cell-template let-row=\"row\" let-value=\"value\">\n                <input type=\"checkbox\" class=\"form-check-input\" [checked]=\"selectedcheckbox(value)\"\n                  (change)=\"onCheckboxChangeFn($event,row,data.items)\" />\n              </ng-template>\n            </ngx-datatable-column>\n            <ngx-datatable-column [sortable]=\"false\" [flexGrow]=\"2\">\n              <ng-template let-row=\"row\" let-value=\"value\" ngx-datatable-cell-template>\n                <fe-file-preview [width]=\"'80px'\" [src]=\"row.url\" [name]=\"row.name\" [type]=\"row.mimeType\"\n                  [preview]=\"true\"></fe-file-preview>\n              </ng-template>\n            </ngx-datatable-column>\n            <ngx-datatable-column [name]=\"'FileExplorer::FileName' | abpLocalization\" prop=\"name\" [sortable]=\"false\"\n              [flexGrow]=\"4\">\n              <ng-template let-row=\"row\" let-value=\"value\" ngx-datatable-cell-template>\n                <div class=\"d-flex align-items-start titlehover\" *ngIf=\"newEditRow.id!==row.id\">\n                  <span class=\"me-2\">{{ value }}</span>\n                  <i class=\"fa fa-pencil-square-o\" role=\"button\" (click.stop)=\"onEditFileName(row)\" style=\"line-height:2;\" aria-hidden=\"true\"></i>\n                </div>\n                <div *ngIf=\"FileNameForm&&newEditRow.id===row.id\">\n                  <form [formGroup]=\"FileNameForm\" (ngSubmit)=\"onSubmitFileName($event)\">\n                    <div class=\"d-flex align-items-start\">\n                      <div class=\"me-2\">\n                        <input class=\"form-control \" type=\"text\"  formControlName=\"fileName\">\n                      </div>\n                      <button class=\" btn btn-sm\" type=\"submit\">\n                        <i class=\"fa-spin fa fa-spinner\" *ngIf=\"isloading\"></i>\n                        <i class=\"fa fa-check\" aria-hidden=\"true\" *ngIf=\"!isloading\"></i></button>\n                      <button class=\" btn btn-sm\" (click.stop)=\"onCancelFileName(row)\"><i class=\"fa fa-times\" type=\"reset\" aria-hidden=\"true\"></i></button>\n                      \n                    </div>\n                  </form>\n                </div>\n              </ng-template>\n            </ngx-datatable-column>\n            <ngx-datatable-column [name]=\"'FileExplorer::FileSize' | abpLocalization\" prop=\"size\" [flexGrow]=\"1.5\">\n              <ng-template let-row=\"row\" let-value=\"value\" ngx-datatable-cell-template>\n                {{ _FileApiService.formatFileSize(value) }}\n              </ng-template>\n            </ngx-datatable-column>\n            <ngx-datatable-column [name]=\"'FileExplorer::Directory' | abpLocalization\" prop=\"directoryId\"\n              [sortable]=\"false\" [flexGrow]=\"1\">\n              <ng-template let-row=\"row\" let-value=\"value\" ngx-datatable-cell-template>\n                {{ value|getDirectoryName:fileGroupList }}\n              </ng-template>\n            </ngx-datatable-column>\n            <ngx-datatable-column [name]=\"'FileExplorer::CreationTime' | abpLocalization\" prop=\"creationTime\"\n              [flexGrow]=\"2\">\n              <ng-template let-row=\"row\" let-value=\"value\" ngx-datatable-cell-template>\n                {{ value | date : 'YYYY/MM/dd HH:mm:s' }}\n              </ng-template>\n            </ngx-datatable-column>\n            <ngx-datatable-column [flexGrow]=\"1\" [sortable]=\"false\">\n              <ng-template let-row=\"row\" let-value=\"value\" ngx-datatable-cell-template>\n                <button class=\"btn btn-sm btn-light p-0\" (click.stop)=\"deleteFile(row)\">\n                  <i class=\"fas fa-trash text-primary p-2\"></i>\n                </button>\n              </ng-template>\n            </ngx-datatable-column>\n          </ngx-datatable>\n        </div>\n        <div *ngIf=\"uploadPictureStatusList.length > 0\"\n          class=\"position-fixed bottom-0 end-0 shadow-lg file-status-modal   m-5\" style=\"border-radius: 10px\">\n          <div class=\"card p-1\">\n            <div class=\"card-header d-flex align-items-center justify-content-between p-0 py-1 border-bottom\">\n              <div>{{'FileExplorer::UploadFiles' | abpLocalization}}</div>\n              <button type=\"button\" class=\"btn-close\" aria-label=\"Close\" (click.stop)=\"closeFileStatusModal()\"></button>\n            </div>\n            <div class=\"card-body\">\n              <table class=\"table\">\n                <thead>\n                  <tr>\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 uploadPictureStatusList; let i = index\">\n                    <tr>\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)}}\n                        </div>\n                      </th>\n                      <td>{{ item.fileSize }}</td>\n                      <td>\n                        <i *ngIf=\"item.status === 1\" class=\"fas fa-check text-primary\"></i>\n                        <i *ngIf=\"item.status === 2\" class=\"fas fa-times-circle text-danger\"></i>\n                      </td>\n                    </tr>\n                  </ng-container>\n                </tbody>\n              </table>\n            </div>\n          </div>\n        </div>\n      </div>\n    </div>\n  </ng-template>\n  <ng-template #abpFooter>\n    <button type=\"button\" class=\"btn btn-secondary\" abpClose>{{'AbpUi::Close' | abpLocalization}}</button>\n    <abp-button iconClass=\"fa fa-check\" (click)=\"modalSave()\">{{'FileExplorer::Confirm' | abpLocalization}}\n      @if(selectedTable.length>0){\n      ({{selectedTable.length}})\n      }\n    </abp-button>\n  </ng-template>\n</abp-modal>"]}