@dignite-ng/expand.file-explorer 3.0.0-rc.4 → 3.0.0-rc.40
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +128 -24
- package/esm2022/config/dignite-ng-expand.file-explorer-config.mjs +1 -1
- package/esm2022/config/enums/index.mjs +1 -1
- package/esm2022/config/enums/route-names.mjs +1 -1
- package/esm2022/config/file-config.module.mjs +1 -1
- package/esm2022/config/providers/index.mjs +1 -1
- package/esm2022/config/providers/route.provider.mjs +1 -1
- package/esm2022/config/public-api.mjs +1 -1
- package/esm2022/dignite-ng-expand.file-explorer.mjs +1 -1
- package/esm2022/lib/components/dome/file-dome.component.mjs +1 -1
- package/esm2022/lib/components/dynamic-form/file-explorer/file-explorer-config.component.mjs +3 -2
- package/esm2022/lib/components/dynamic-form/file-explorer/file-explorer-config.mjs +1 -1
- package/esm2022/lib/components/dynamic-form/file-explorer/file-explorer-control.component.mjs +17 -3
- package/esm2022/lib/components/dynamic-form/file-explorer/file-explorer-view.component.mjs +41 -0
- package/esm2022/lib/components/dynamic-form/file-explorer/index.mjs +1 -1
- package/esm2022/lib/components/dynamic-form/form-control-group.mjs +3 -2
- package/esm2022/lib/components/file-edit/file-edit.component.mjs +4 -3
- package/esm2022/lib/components/file-modal/file-modal.component.mjs +277 -74
- package/esm2022/lib/components/file-modal-tree/file-modal-tree.component.mjs +129 -52
- package/esm2022/lib/components/file-picker/file-picker.component.mjs +15 -5
- package/esm2022/lib/components/index.mjs +1 -1
- package/esm2022/lib/file-explorer-routing.module.mjs +1 -1
- package/esm2022/lib/file-explorer.module.mjs +19 -4
- package/esm2022/lib/pipe/get-directory-name.pipe.mjs +20 -0
- package/esm2022/lib/previews/file-preview.component.mjs +7 -3
- package/esm2022/lib/previews/index.mjs +1 -1
- package/esm2022/lib/previews/models.mjs +1 -1
- package/esm2022/lib/proxy/dignite/file-explorer/directories/file-descriptor.service.mjs +2 -1
- package/esm2022/lib/proxy/dignite/file-explorer/directories/index.mjs +1 -1
- package/esm2022/lib/proxy/dignite/file-explorer/directories/models.mjs +1 -1
- package/esm2022/lib/proxy/dignite/file-explorer/files/file-descriptor.service.mjs +11 -3
- package/esm2022/lib/proxy/dignite/file-explorer/files/index.mjs +1 -1
- package/esm2022/lib/proxy/dignite/file-explorer/files/models.mjs +1 -1
- package/esm2022/lib/proxy/microsoft/asp-net-core/mvc/models.mjs +1 -1
- package/esm2022/lib/proxy/microsoft/extensions/primitives/models.mjs +1 -1
- package/esm2022/lib/proxy/microsoft/net/http/headers/models.mjs +1 -1
- package/esm2022/lib/proxy/volo/abp/content/models.mjs +1 -1
- package/esm2022/lib/services/file-api.service.mjs +1 -1
- package/esm2022/public-api.mjs +1 -1
- package/fesm2022/dignite-ng-expand.file-explorer-config.mjs.map +1 -1
- package/fesm2022/dignite-ng-expand.file-explorer.mjs +512 -145
- package/fesm2022/dignite-ng-expand.file-explorer.mjs.map +1 -1
- package/lib/components/dynamic-form/file-explorer/file-explorer-control.component.d.ts +4 -1
- package/lib/components/dynamic-form/file-explorer/file-explorer-view.component.d.ts +17 -0
- package/lib/components/file-modal/file-modal.component.d.ts +63 -22
- package/lib/components/file-modal-tree/file-modal-tree.component.d.ts +21 -10
- package/lib/components/file-picker/file-picker.component.d.ts +2 -0
- package/lib/file-explorer.module.d.ts +12 -8
- package/lib/pipe/get-directory-name.pipe.d.ts +7 -0
- package/lib/previews/file-preview.component.d.ts +2 -1
- package/lib/proxy/dignite/file-explorer/files/file-descriptor.service.d.ts +3 -1
- package/lib/proxy/dignite/file-explorer/files/models.d.ts +5 -2
- package/package.json +25 -7
|
@@ -1,17 +1,24 @@
|
|
|
1
1
|
import { Component, EventEmitter, Input, Output, inject } from '@angular/core';
|
|
2
|
-
import
|
|
3
|
-
import {
|
|
2
|
+
import * as FileService from '../../proxy/dignite/file-explorer/files';
|
|
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';
|
|
6
|
+
import { FileApiService } from '../../services/file-api.service';
|
|
4
7
|
import { SelectionType } from '@swimlane/ngx-datatable';
|
|
8
|
+
import { FormControl, FormGroup, Validators } from '@angular/forms';
|
|
9
|
+
import { finalize } from 'rxjs';
|
|
5
10
|
import * as i0 from "@angular/core";
|
|
6
11
|
import * as i1 from "../../proxy/dignite/file-explorer/files";
|
|
7
12
|
import * as i2 from "@abp/ng.theme.shared";
|
|
8
13
|
import * as i3 from "@abp/ng.core";
|
|
9
14
|
import * as i4 from "../../services/file-api.service";
|
|
10
|
-
import * as i5 from "@angular/
|
|
11
|
-
import * as i6 from "@
|
|
12
|
-
import * as i7 from "
|
|
13
|
-
import * as i8 from "
|
|
14
|
-
|
|
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";
|
|
15
22
|
export class FileModalComponent {
|
|
16
23
|
constructor(_FileService, toaster, list, _FileApiService, restService, confirmation, _LocalizationService) {
|
|
17
24
|
this._FileService = _FileService;
|
|
@@ -27,8 +34,8 @@ export class FileModalComponent {
|
|
|
27
34
|
/**是否多选 */
|
|
28
35
|
this._multiple = false;
|
|
29
36
|
/**文件大小限制
|
|
30
|
-
|
|
31
|
-
|
|
37
|
+
* @param 1mb
|
|
38
|
+
*/
|
|
32
39
|
this.sizeLimit = 1048576;
|
|
33
40
|
/**模态框状态回调 */
|
|
34
41
|
this.visibleChange = new EventEmitter();
|
|
@@ -39,6 +46,9 @@ export class FileModalComponent {
|
|
|
39
46
|
/**dignite-file-modal-tree */
|
|
40
47
|
/**选择的tree节点 */
|
|
41
48
|
this._theSelectedTreeNode = '';
|
|
49
|
+
this.isCreateList = false;
|
|
50
|
+
/** 从tree获取来的数据 */
|
|
51
|
+
this.fileGroupList = [];
|
|
42
52
|
/**图片上传-要上传图片的状态文件列表 */
|
|
43
53
|
this.uploadPictureStatusList = [];
|
|
44
54
|
/**文件表格-数据*/
|
|
@@ -50,45 +60,54 @@ export class FileModalComponent {
|
|
|
50
60
|
this.filters = {};
|
|
51
61
|
/**文件表格-表格自带选择类型 */
|
|
52
62
|
this.SelectionType = SelectionType;
|
|
53
|
-
/**文件表格-选择的表格数据项 */
|
|
54
|
-
this.selectedTable = [];
|
|
55
|
-
/**当前选择的table项 id */
|
|
56
|
-
this.nowSelectId = '';
|
|
57
63
|
/**选择文件回调 */
|
|
58
64
|
this.selectFilefn = new EventEmitter();
|
|
59
|
-
/**一个布尔or函数,可用于检查是否要根据条件选择特定行。 */
|
|
60
|
-
this.selectCheck = (row, column, value) => {
|
|
61
|
-
this.nowSelectId = row.id;
|
|
62
|
-
return true;
|
|
63
|
-
};
|
|
64
|
-
/**判断row是否选中 */
|
|
65
|
-
this.selectedcheckbox = (id) => {
|
|
66
|
-
return this.selectedTable.some(el => el.id == id);
|
|
67
|
-
};
|
|
68
65
|
/**创建图片的接口,代理中的file类型不匹配,切换为any类型 */
|
|
69
66
|
this.createFile = (input, config) => this.restService.request({
|
|
70
67
|
method: 'POST',
|
|
71
68
|
url: '/api/file-explorer/files',
|
|
72
|
-
params: {
|
|
69
|
+
params: {
|
|
70
|
+
containerName: input.containerName,
|
|
71
|
+
cellName: input.cellName,
|
|
72
|
+
directoryId: input.directoryId,
|
|
73
|
+
entityId: input.entityId,
|
|
74
|
+
},
|
|
73
75
|
body: input.file,
|
|
74
76
|
}, { apiName: 'FileExplorer', ...config });
|
|
75
|
-
|
|
77
|
+
/**文件表格-选择的表格数据项 */
|
|
78
|
+
this.selectedTable = [];
|
|
79
|
+
/**当前选择的table项 id */
|
|
80
|
+
this.nowSelectId = '';
|
|
81
|
+
/**是否全选 */
|
|
82
|
+
this.isAllSelected = false;
|
|
83
|
+
/**判断row是否选中 */
|
|
84
|
+
this.selectedcheckbox = id => {
|
|
85
|
+
return this.selectedTable.some(el => el.id === id);
|
|
86
|
+
};
|
|
87
|
+
/**当前编辑的row */
|
|
88
|
+
this.newEditRow = '';
|
|
89
|
+
/**是否正在加载 */
|
|
90
|
+
this.isloading = false;
|
|
76
91
|
}
|
|
77
92
|
/**获取目录配置 */
|
|
78
93
|
getFilesConfiguration() {
|
|
79
|
-
|
|
80
|
-
this.
|
|
94
|
+
return new Promise((resolve, reject) => {
|
|
95
|
+
this._FileDescriptorService
|
|
96
|
+
.getFileContainerConfiguration(this._fileContainerName)
|
|
97
|
+
.subscribe(res => {
|
|
98
|
+
this.createDirectoryPermissionName = res?.createDirectoryPermissionName;
|
|
99
|
+
resolve(res);
|
|
100
|
+
});
|
|
81
101
|
});
|
|
82
102
|
}
|
|
83
103
|
set fileContainerName(v) {
|
|
84
104
|
if (v) {
|
|
85
105
|
this._fileContainerName = v;
|
|
86
|
-
this.loadData()
|
|
106
|
+
// this.loadData()
|
|
87
107
|
}
|
|
88
108
|
}
|
|
89
109
|
set multiple(v) {
|
|
90
110
|
this._multiple = v;
|
|
91
|
-
if (v) { }
|
|
92
111
|
}
|
|
93
112
|
set limit(v) {
|
|
94
113
|
this.sizeLimit = v;
|
|
@@ -103,51 +122,95 @@ export class FileModalComponent {
|
|
|
103
122
|
/**模态框-状态改变回调 */
|
|
104
123
|
ModalVisibleChange(event) {
|
|
105
124
|
if (!event) {
|
|
125
|
+
this.ModalOpen = false;
|
|
126
|
+
this.ModalBusy = false;
|
|
106
127
|
this.visibleChange.emit(event);
|
|
128
|
+
this.createDirectoryPermissionName = '';
|
|
129
|
+
this._theSelectedTreeNode = '';
|
|
130
|
+
this.selectedTable = [];
|
|
131
|
+
this.uploadPictureStatusList = [];
|
|
107
132
|
return;
|
|
108
133
|
}
|
|
109
134
|
}
|
|
110
135
|
/**模态框保存 */
|
|
111
136
|
modalSave() {
|
|
112
|
-
|
|
137
|
+
const selectedTablearr = this._FileApiService.deepClone(this.selectedTable);
|
|
113
138
|
this.selectFilefn.emit(selectedTablearr);
|
|
114
139
|
this.ModalVisibleChange(false);
|
|
115
140
|
}
|
|
116
141
|
/**初始化数据 */
|
|
117
142
|
loadData() {
|
|
118
143
|
if (this.ModalOpen && this._fileContainerName) {
|
|
119
|
-
this.
|
|
144
|
+
this.list.maxResultCount = 100;
|
|
145
|
+
// this.filters.skipCount = 0;
|
|
120
146
|
this.getFilesConfiguration();
|
|
147
|
+
if (!this.isCreateList) {
|
|
148
|
+
this.hookToQuery();
|
|
149
|
+
this.isCreateList = true;
|
|
150
|
+
}
|
|
151
|
+
else {
|
|
152
|
+
this.list.get();
|
|
153
|
+
}
|
|
154
|
+
}
|
|
155
|
+
}
|
|
156
|
+
/** 从tree获取数据 */
|
|
157
|
+
treeNodeData(event) {
|
|
158
|
+
this.fileGroupList = this.flattenNestedArray(event);
|
|
159
|
+
}
|
|
160
|
+
/**
|
|
161
|
+
* 将嵌套数组扁平化
|
|
162
|
+
* @param {Array} nestedArray - 包含嵌套children的数组
|
|
163
|
+
* @returns {Array} - 扁平化后的数组
|
|
164
|
+
*/
|
|
165
|
+
flattenNestedArray(nestedArray) {
|
|
166
|
+
const result = [];
|
|
167
|
+
function flatten(items) {
|
|
168
|
+
if (!items)
|
|
169
|
+
return;
|
|
170
|
+
for (const item of items) {
|
|
171
|
+
// 将当前项添加到结果数组
|
|
172
|
+
result.push({ ...item });
|
|
173
|
+
// 如果有children属性且是数组,递归处理
|
|
174
|
+
if (item.children && Array.isArray(item.children)) {
|
|
175
|
+
flatten(item.children);
|
|
176
|
+
}
|
|
177
|
+
}
|
|
121
178
|
}
|
|
179
|
+
flatten(nestedArray);
|
|
180
|
+
return result;
|
|
122
181
|
}
|
|
123
182
|
/**tree-节点选择 */
|
|
124
183
|
_nodeClick(event) {
|
|
184
|
+
this.filters.skipCount = 0;
|
|
125
185
|
this._theSelectedTreeNode = event;
|
|
126
186
|
this.list.get();
|
|
127
187
|
}
|
|
128
188
|
/**图片上传-获取文件信息改变 */
|
|
129
189
|
async getFileChange(event) {
|
|
130
|
-
|
|
190
|
+
const files = new Array(...event.target.files);
|
|
131
191
|
this.uploadPictureStatusList = files;
|
|
132
192
|
for (const file of files) {
|
|
133
193
|
if (file.size > this.sizeLimit) {
|
|
134
194
|
this.setuploadPictureStatus(file, 2);
|
|
135
195
|
continue;
|
|
136
196
|
}
|
|
137
|
-
await this.uploadingFile(file)
|
|
197
|
+
await this.uploadingFile(file)
|
|
198
|
+
.then(res => {
|
|
199
|
+
this.selectedTable.push(res);
|
|
138
200
|
this.setuploadPictureStatus(file, 1);
|
|
139
|
-
this.list.get()
|
|
140
|
-
})
|
|
201
|
+
// this.list.get()
|
|
202
|
+
})
|
|
203
|
+
.catch(() => {
|
|
141
204
|
this.setuploadPictureStatus(file, 2);
|
|
142
|
-
}); // 等待每个文件上传完成
|
|
205
|
+
}); // 等待每个文件上传完成
|
|
143
206
|
}
|
|
144
207
|
this.list.get();
|
|
145
|
-
|
|
208
|
+
const isSubmit = !this.uploadPictureStatusList.some(el => el.status == 2);
|
|
146
209
|
if (isSubmit) {
|
|
147
210
|
// this.toaster.success("上传完成");
|
|
148
211
|
setTimeout(() => {
|
|
149
212
|
this.uploadPictureStatusList = [];
|
|
150
|
-
},
|
|
213
|
+
}, 4000);
|
|
151
214
|
}
|
|
152
215
|
}
|
|
153
216
|
/**图片上传-设置uploadPictureStatusList的状态 */
|
|
@@ -160,49 +223,160 @@ export class FileModalComponent {
|
|
|
160
223
|
/**图片上传-递归按顺序上传 */
|
|
161
224
|
uploadingFile(file) {
|
|
162
225
|
return new Promise((resolve, rejects) => {
|
|
163
|
-
|
|
226
|
+
const formData = new FormData();
|
|
164
227
|
formData.append('file', file, file.name);
|
|
165
228
|
this.createFile({
|
|
166
229
|
file: formData,
|
|
167
230
|
containerName: this._fileContainerName,
|
|
168
231
|
directoryId: this._theSelectedTreeNode?.key || '',
|
|
169
|
-
entityId: ''
|
|
232
|
+
entityId: '',
|
|
170
233
|
}).subscribe(res => {
|
|
171
|
-
resolve(
|
|
172
|
-
},
|
|
234
|
+
resolve(res);
|
|
235
|
+
}, err => {
|
|
173
236
|
rejects(false);
|
|
174
237
|
});
|
|
175
238
|
});
|
|
176
239
|
}
|
|
177
|
-
ngOnChanges(changes) {
|
|
178
|
-
//Called before any other lifecycle hook. Use it to inject dependencies, but avoid any serious work here.
|
|
179
|
-
//Add '${implements OnChanges}' to the class.
|
|
180
|
-
this.selectedTable = this._FileApiService.deepClone(this.selectPickerFile);
|
|
181
|
-
}
|
|
182
240
|
/**文件表格-获取表格数据 */
|
|
183
241
|
hookToQuery() {
|
|
184
242
|
const getData = (query) => this._FileService.getList({
|
|
185
243
|
...query,
|
|
186
244
|
...this.filters,
|
|
187
245
|
containerName: this._fileContainerName,
|
|
188
|
-
directoryId: this._theSelectedTreeNode.key
|
|
246
|
+
directoryId: this._theSelectedTreeNode.key,
|
|
189
247
|
});
|
|
190
|
-
const setData = (list) =>
|
|
248
|
+
const setData = (list) => {
|
|
249
|
+
this.data = list;
|
|
250
|
+
this.onPageChange(list.items);
|
|
251
|
+
};
|
|
191
252
|
this.list.hookToQuery(getData).subscribe(setData);
|
|
192
253
|
}
|
|
193
254
|
/**文件表格-查看所有分组的文件数据 */
|
|
194
255
|
lookAllFile() {
|
|
256
|
+
this.filters.skipCount = 0;
|
|
195
257
|
this._theSelectedTreeNode = '';
|
|
196
258
|
this.list.get();
|
|
197
259
|
}
|
|
198
|
-
|
|
199
|
-
|
|
200
|
-
this.
|
|
201
|
-
|
|
202
|
-
|
|
203
|
-
|
|
260
|
+
/**删除图片 */
|
|
261
|
+
deleteFile(file) {
|
|
262
|
+
this._FileService.delete(file.id).subscribe(res => {
|
|
263
|
+
this.toaster.success(this._LocalizationService.instant(`FileExplorer::DeletedSuccessfully`));
|
|
264
|
+
this.list.get();
|
|
265
|
+
});
|
|
266
|
+
}
|
|
267
|
+
/**删除所有选中图片 */
|
|
268
|
+
onDeleteAllSelectFile() {
|
|
269
|
+
this.confirmation
|
|
270
|
+
.warn('', {
|
|
271
|
+
key: '',
|
|
272
|
+
defaultValue: this._LocalizationService.instant(`FileExplorer::AreYouSure`),
|
|
273
|
+
})
|
|
274
|
+
.subscribe(async (status) => {
|
|
275
|
+
if (status == 'confirm') {
|
|
276
|
+
const selectedTable = this.selectedTable;
|
|
277
|
+
try {
|
|
278
|
+
const result = await this.batchDeleteItems(selectedTable);
|
|
279
|
+
if (result.success) {
|
|
280
|
+
this.toaster.success(result.message);
|
|
281
|
+
this.list.get();
|
|
282
|
+
// 可能需要刷新表格或更新UI
|
|
283
|
+
}
|
|
284
|
+
else {
|
|
285
|
+
//删除失败的项
|
|
286
|
+
this.list.get();
|
|
287
|
+
// 可以选择展示失败项或重试
|
|
288
|
+
}
|
|
289
|
+
}
|
|
290
|
+
catch (error) {
|
|
291
|
+
//批量删除过程中发生错误
|
|
292
|
+
}
|
|
293
|
+
}
|
|
294
|
+
});
|
|
295
|
+
}
|
|
296
|
+
/**
|
|
297
|
+
* 批量删除表格项
|
|
298
|
+
* @param selectedTable 需要删除的表格项数组
|
|
299
|
+
* @returns 包含成功状态和失败项的结果对象
|
|
300
|
+
*/
|
|
301
|
+
async batchDeleteItems(selectedTable) {
|
|
302
|
+
// 存储所有删除请求的Promise
|
|
303
|
+
const deletePromises = selectedTable.map(item => {
|
|
304
|
+
return new Promise((resolve, reject) => {
|
|
305
|
+
this._FileService.delete(item.id).subscribe(() => {
|
|
306
|
+
resolve(null);
|
|
307
|
+
}, () => {
|
|
308
|
+
reject(item);
|
|
309
|
+
});
|
|
310
|
+
});
|
|
311
|
+
});
|
|
312
|
+
// 等待所有请求完成
|
|
313
|
+
const results = await Promise.allSettled(deletePromises);
|
|
314
|
+
// 收集失败的项
|
|
315
|
+
const failedItems = [];
|
|
316
|
+
results.forEach(result => {
|
|
317
|
+
if (result.status === 'rejected') {
|
|
318
|
+
failedItems.push(result.reason);
|
|
319
|
+
}
|
|
320
|
+
});
|
|
321
|
+
return {
|
|
322
|
+
success: failedItems.length === 0,
|
|
323
|
+
failedItems,
|
|
324
|
+
message: failedItems.length === 0
|
|
325
|
+
? this._LocalizationService.instant(`FileExplorer::DeletedSuccessfully`)
|
|
326
|
+
: `${failedItems.length}个项删除失败`,
|
|
327
|
+
};
|
|
328
|
+
}
|
|
329
|
+
// 使用示例
|
|
330
|
+
async handleBatchDelete() { }
|
|
331
|
+
/**关闭文件状态弹窗 */
|
|
332
|
+
closeFileStatusModal() {
|
|
333
|
+
this.uploadPictureStatusList = [];
|
|
334
|
+
}
|
|
335
|
+
ngOnChanges(changes) {
|
|
336
|
+
//Called before any other lifecycle hook. Use it to inject dependencies, but avoid any serious work here.
|
|
337
|
+
//Add '${implements OnChanges}' to the class.
|
|
338
|
+
this.selectedTable = this._FileApiService.deepClone(this.selectPickerFile);
|
|
339
|
+
}
|
|
340
|
+
/**表格分页切换 */
|
|
341
|
+
onPageChange(newArray) {
|
|
342
|
+
this.isAllSelected = this.isAllSelectedFn(newArray, this.selectedTable);
|
|
343
|
+
}
|
|
344
|
+
/**行选择框改变 */
|
|
345
|
+
onCheckboxChangeFn(event, row, array) {
|
|
346
|
+
const { checked } = event.target;
|
|
347
|
+
let selectedTableArray = [...this.selectedTable];
|
|
348
|
+
if (this._multiple) {
|
|
349
|
+
if (checked) {
|
|
350
|
+
selectedTableArray.push(row);
|
|
351
|
+
}
|
|
352
|
+
else {
|
|
353
|
+
selectedTableArray = selectedTableArray.filter(el => el.id != row.id);
|
|
354
|
+
}
|
|
355
|
+
this.isAllSelected = this.isAllSelectedFn(array, selectedTableArray);
|
|
356
|
+
}
|
|
357
|
+
else {
|
|
358
|
+
selectedTableArray.length = 0;
|
|
359
|
+
selectedTableArray = checked ? [row] : [];
|
|
360
|
+
}
|
|
361
|
+
this.selectedTable = this.removeDuplicatesById(selectedTableArray);
|
|
362
|
+
}
|
|
363
|
+
/**如果selectedTableArray不含array中的所有项,则将isAllSelected设为true,否则设为false */
|
|
364
|
+
isAllSelectedFn(tolalArray, selectedArray = []) {
|
|
365
|
+
if (tolalArray.length == 0)
|
|
366
|
+
return false;
|
|
367
|
+
return tolalArray.every(item => selectedArray.some(el => el.id === item.id));
|
|
368
|
+
}
|
|
369
|
+
/**选择当前页全部 */
|
|
370
|
+
onSelectAllFn(event, array) {
|
|
371
|
+
let selectedTableArray = this.selectedTable;
|
|
372
|
+
if (event.target.checked) {
|
|
373
|
+
selectedTableArray = this.removeDuplicatesById([...selectedTableArray, ...array]);
|
|
374
|
+
}
|
|
375
|
+
else {
|
|
376
|
+
selectedTableArray = selectedTableArray.filter(el => !array.some(item => item.id === el.id));
|
|
204
377
|
}
|
|
205
|
-
this.
|
|
378
|
+
this.isAllSelected = event.target.checked;
|
|
379
|
+
this.selectedTable = selectedTableArray;
|
|
206
380
|
}
|
|
207
381
|
/**删除数组中重复的项 */
|
|
208
382
|
removeDuplicatesById(array) {
|
|
@@ -215,32 +389,61 @@ export class FileModalComponent {
|
|
|
215
389
|
return false;
|
|
216
390
|
});
|
|
217
391
|
}
|
|
218
|
-
|
|
219
|
-
|
|
220
|
-
this.
|
|
221
|
-
|
|
222
|
-
|
|
223
|
-
|
|
224
|
-
|
|
225
|
-
|
|
226
|
-
|
|
227
|
-
|
|
392
|
+
/**提交FileName编辑 */
|
|
393
|
+
onSubmitFileName(event) {
|
|
394
|
+
const input = this.FileNameForm.value;
|
|
395
|
+
if (!this.FileNameForm.valid)
|
|
396
|
+
return;
|
|
397
|
+
if (this.isloading)
|
|
398
|
+
return;
|
|
399
|
+
this.isloading = true;
|
|
400
|
+
this._FileService
|
|
401
|
+
.update(input.id, {
|
|
402
|
+
name: input.fileName
|
|
403
|
+
})
|
|
404
|
+
.pipe(finalize(() => {
|
|
405
|
+
this.isloading = false;
|
|
406
|
+
}))
|
|
407
|
+
.subscribe(res => {
|
|
408
|
+
//通过当前newEditRow的id,修改data.items中对应项的name
|
|
409
|
+
for (const element of this.data.items) {
|
|
410
|
+
if (element.id == this.newEditRow.id) {
|
|
411
|
+
element.name = input.fileName;
|
|
412
|
+
break;
|
|
413
|
+
}
|
|
228
414
|
}
|
|
415
|
+
this.FileNameForm = undefined;
|
|
416
|
+
this.newEditRow = '';
|
|
417
|
+
this.toaster.success(this._LocalizationService.instant(`FileExplorer::SavedSuccessfully`));
|
|
418
|
+
// this.list.get();
|
|
229
419
|
});
|
|
230
420
|
}
|
|
231
|
-
|
|
232
|
-
|
|
233
|
-
this.
|
|
421
|
+
/**打开编辑 */
|
|
422
|
+
onEditFileName(row) {
|
|
423
|
+
this.FileNameForm = new FormGroup({
|
|
424
|
+
fileName: new FormControl('', [Validators.required]),
|
|
425
|
+
id: new FormControl('', [Validators.required]),
|
|
426
|
+
});
|
|
427
|
+
this.FileNameForm.patchValue({
|
|
428
|
+
fileName: row.name,
|
|
429
|
+
id: row.id,
|
|
430
|
+
});
|
|
431
|
+
this.newEditRow = row;
|
|
432
|
+
}
|
|
433
|
+
/**关闭编辑 */
|
|
434
|
+
onCancelFileName(row) {
|
|
435
|
+
this.newEditRow = '';
|
|
436
|
+
this.FileNameForm = undefined;
|
|
234
437
|
}
|
|
235
438
|
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 }); }
|
|
236
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "
|
|
439
|
+
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: [
|
|
237
440
|
// [Required]
|
|
238
441
|
ListService,
|
|
239
442
|
// [Optional]
|
|
240
443
|
// Provide this token if you want a different debounce time.
|
|
241
444
|
// Default is 300. Cannot be 0. Any value below 100 is not recommended.
|
|
242
445
|
{ provide: LIST_QUERY_DEBOUNCE_TIME, useValue: 500 },
|
|
243
|
-
], 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"] }, { kind: "pipe", type: i5.DatePipe, name: "date" }, { kind: "pipe", type: i3.LocalizationPipe, name: "abpLocalization" }] }); }
|
|
446
|
+
], 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" }] }); }
|
|
244
447
|
}
|
|
245
448
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.5", ngImport: i0, type: FileModalComponent, decorators: [{
|
|
246
449
|
type: Component,
|
|
@@ -251,7 +454,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.5", ngImpor
|
|
|
251
454
|
// Provide this token if you want a different debounce time.
|
|
252
455
|
// Default is 300. Cannot be 0. Any value below 100 is not recommended.
|
|
253
456
|
{ provide: LIST_QUERY_DEBOUNCE_TIME, useValue: 500 },
|
|
254
|
-
], 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"] }]
|
|
457
|
+
], 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"] }]
|
|
255
458
|
}], ctorParameters: () => [{ type: i1.FileDescriptorService }, { type: i2.ToasterService }, { type: i3.ListService }, { type: i4.FileApiService }, { type: i3.RestService }, { type: i2.ConfirmationService }, { type: i3.LocalizationService }], propDecorators: { fileContainerName: [{
|
|
256
459
|
type: Input
|
|
257
460
|
}], multiple: [{
|
|
@@ -262,9 +465,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.5", ngImpor
|
|
|
262
465
|
type: Input
|
|
263
466
|
}], visibleChange: [{
|
|
264
467
|
type: Output
|
|
265
|
-
}], selectPickerFile: [{
|
|
266
|
-
type: Input
|
|
267
468
|
}], selectFilefn: [{
|
|
268
469
|
type: Output
|
|
470
|
+
}], selectPickerFile: [{
|
|
471
|
+
type: Input
|
|
269
472
|
}] } });
|
|
270
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"file-modal.component.js","sourceRoot":"","sources":["../../../../../../projects/file-explorer/src/lib/components/file-modal/file-modal.component.ts","../../../../../../projects/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>"]}
|
|
473
|
+
//# 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":"AAAA,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,KAAK,EAAE,MAAM,EAAiB,MAAM,EAAa,MAAM,eAAe,CAAC;AACzG,OAAO,KAAK,WAAW,MAAM,yCAAyC,CAAC;AACvE,OAAO,EAAgB,mBAAmB,EAAE,cAAc,EAAE,MAAM,sBAAsB,CAAC;AACzF,OAAO,EAGL,WAAW,EAEX,WAAW,EACX,mBAAmB,EACnB,wBAAwB,GACzB,MAAM,cAAc,CAAC;AACtB,OAAO,EAEL,qBAAqB,GAEtB,MAAM,yCAAyC,CAAC;AACjD,OAAO,EAAE,cAAc,EAAE,MAAM,iCAAiC,CAAC;AACjE,OAAO,EAAE,aAAa,EAAE,MAAM,yBAAyB,CAAC;AACxD,OAAO,EAAE,WAAW,EAAE,SAAS,EAAE,UAAU,EAAE,MAAM,gBAAgB,CAAC;AACpE,OAAO,EAAE,QAAQ,EAAE,MAAM,MAAM,CAAC;;;;;;;;;;;;;AAehC,MAAM,OAAO,kBAAkB;IAC7B,YACU,YAA+C,EAC/C,OAAuB,EACf,IAAiB,EAC1B,eAA+B,EAC9B,WAAwB,EACxB,YAAiC,EACjC,oBAAyC;QANzC,iBAAY,GAAZ,YAAY,CAAmC;QAC/C,YAAO,GAAP,OAAO,CAAgB;QACf,SAAI,GAAJ,IAAI,CAAa;QAC1B,oBAAe,GAAf,eAAe,CAAgB;QAC9B,gBAAW,GAAX,WAAW,CAAa;QACxB,iBAAY,GAAZ,YAAY,CAAqB;QACjC,yBAAoB,GAApB,oBAAoB,CAAqB;QAI3C,2BAAsB,GAAG,MAAM,CAAC,qBAAqB,CAAC,CAAC;QAY/D,aAAa;QACb,kCAA6B,GAAW,IAAI,CAAC;QAY7C,UAAU;QACV,cAAS,GAAG,KAAK,CAAC;QAMlB;;WAEG;QACH,cAAS,GAAG,OAAO,CAAC;QAcpB,aAAa;QACH,kBAAa,GAAG,IAAI,YAAY,EAAE,CAAC;QAE7C,iBAAiB;QACjB,cAAS,GAAG,KAAK,CAAC;QAElB,8BAA8B;QAC9B,cAAS,GAAG,KAAK,CAAC;QAsBlB,6BAA6B;QAC7B,eAAe;QACf,yBAAoB,GAAQ,EAAE,CAAC;QAC/B,iBAAY,GAAG,KAAK,CAAC;QAerB,kBAAkB;QAClB,kBAAa,GAAU,EAAE,CAAC;QAsC1B,uBAAuB;QACvB,4BAAuB,GAAU,EAAE,CAAC;QA2DpC,YAAY;QACZ,SAAI,GAAsC;YACxC,KAAK,EAAE,EAAE;YACT,UAAU,EAAE,CAAC;SACd,CAAC;QAEF,YAAY;QACZ,YAAO,GAAG,EAAmB,CAAC;QAE9B,mBAAmB;QACnB,kBAAa,GAAG,aAAa,CAAC;QAE9B,YAAY;QACF,iBAAY,GAAG,IAAI,YAAY,EAAS,CAAC;QA6GnD,oCAAoC;QACpC,eAAU,GAAG,CAAC,KAAU,EAAE,MAA6B,EAAE,EAAE,CACzD,IAAI,CAAC,WAAW,CAAC,OAAO,CACtB;YACE,MAAM,EAAE,MAAM;YACd,GAAG,EAAE,0BAA0B;YAC/B,MAAM,EAAE;gBACN,aAAa,EAAE,KAAK,CAAC,aAAa;gBAClC,QAAQ,EAAE,KAAK,CAAC,QAAQ;gBACxB,WAAW,EAAE,KAAK,CAAC,WAAW;gBAC9B,QAAQ,EAAE,KAAK,CAAC,QAAQ;aACzB;YACD,IAAI,EAAE,KAAK,CAAC,IAAI;SACjB,EACD,EAAE,OAAO,EAAE,cAAc,EAAE,GAAG,MAAM,EAAE,CACvC,CAAC;QAEJ,mBAAmB;QACnB,kBAAa,GAAG,EAAE,CAAC;QACnB,oBAAoB;QACpB,gBAAW,GAAQ,EAAE,CAAC;QACtB,UAAU;QACV,kBAAa,GAAG,KAAK,CAAC;QAgDtB,eAAe;QACf,qBAAgB,GAAG,EAAE,CAAC,EAAE;YACtB,OAAO,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,KAAK,EAAE,CAAC,CAAC;QACrD,CAAC,CAAC;QAcF,cAAc;QACd,eAAU,GAAQ,EAAE,CAAC;QACrB,YAAY;QACZ,cAAS,GAAG,KAAK,CAAC;IAzZlB,CAAC;IAGD,YAAY;IACZ,qBAAqB;QACnB,OAAO,IAAI,OAAO,CAAC,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;YACrC,IAAI,CAAC,sBAAsB;iBACxB,6BAA6B,CAAC,IAAI,CAAC,kBAAkB,CAAC;iBACtD,SAAS,CAAC,GAAG,CAAC,EAAE;gBACf,IAAI,CAAC,6BAA6B,GAAG,GAAG,EAAE,6BAA6B,CAAC;gBACxE,OAAO,CAAC,GAAG,CAAC,CAAC;YACf,CAAC,CAAC,CAAC;QACP,CAAC,CAAC,CAAC;IACL,CAAC;IAMD,IACW,iBAAiB,CAAC,CAAS;QACpC,IAAI,CAAC,EAAE,CAAC;YACN,IAAI,CAAC,kBAAkB,GAAG,CAAC,CAAC;YAC5B,kBAAkB;QACpB,CAAC;IACH,CAAC;IAID,IACW,QAAQ,CAAC,CAAU;QAC5B,IAAI,CAAC,SAAS,GAAG,CAAC,CAAC;IACrB,CAAC;IAMD,IACW,KAAK,CAAC,CAAS;QACxB,IAAI,CAAC,SAAS,GAAG,CAAC,CAAC;IACrB,CAAC;IACD,iBAAiB;IACjB,IACW,OAAO,CAAC,CAAU;QAC3B,IAAI,CAAC,SAAS,GAAG,CAAC,CAAC;QACnB,IAAI,CAAC,EAAE,CAAC;YACN,IAAI,CAAC,QAAQ,EAAE,CAAC;QAClB,CAAC;IACH,CAAC;IAWD,gBAAgB;IAChB,kBAAkB,CAAC,KAAK;QACtB,IAAI,CAAC,KAAK,EAAE,CAAC;YACX,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;YACvB,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;YACvB,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;YAC/B,IAAI,CAAC,6BAA6B,GAAG,EAAE,CAAC;YACxC,IAAI,CAAC,oBAAoB,GAAG,EAAE,CAAC;YAC/B,IAAI,CAAC,aAAa,GAAG,EAAE,CAAC;YACxB,IAAI,CAAC,uBAAuB,GAAG,EAAE,CAAC;YAClC,OAAO;QACT,CAAC;IACH,CAAC;IAED,WAAW;IACX,SAAS;QACP,MAAM,gBAAgB,GAAG,IAAI,CAAC,eAAe,CAAC,SAAS,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;QAC5E,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAC;QACzC,IAAI,CAAC,kBAAkB,CAAC,KAAK,CAAC,CAAC;IACjC,CAAC;IAKD,WAAW;IACX,QAAQ;QACN,IAAI,IAAI,CAAC,SAAS,IAAI,IAAI,CAAC,kBAAkB,EAAE,CAAC;YAC9C,IAAI,CAAC,IAAI,CAAC,cAAc,GAAG,GAAG,CAAC;YAC/B,8BAA8B;YAC9B,IAAI,CAAC,qBAAqB,EAAE,CAAC;YAC7B,IAAI,CAAC,IAAI,CAAC,YAAY,EAAE,CAAC;gBACvB,IAAI,CAAC,WAAW,EAAE,CAAC;gBACnB,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC;YAC3B,CAAC;iBAAM,CAAC;gBACN,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,CAAC;YAClB,CAAC;QACH,CAAC;IACH,CAAC;IAGD,gBAAgB;IAChB,YAAY,CAAC,KAAK;QAChB,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,kBAAkB,CAAC,KAAK,CAAC,CAAC;IACtD,CAAC;IACD;;;;OAIG;IACH,kBAAkB,CAAC,WAAW;QAC5B,MAAM,MAAM,GAAG,EAAE,CAAC;QAElB,SAAS,OAAO,CAAC,KAAK;YACpB,IAAI,CAAC,KAAK;gBAAE,OAAO;YAEnB,KAAK,MAAM,IAAI,IAAI,KAAK,EAAE,CAAC;gBACzB,cAAc;gBACd,MAAM,CAAC,IAAI,CAAC,EAAE,GAAG,IAAI,EAAE,CAAC,CAAC;gBAEzB,yBAAyB;gBACzB,IAAI,IAAI,CAAC,QAAQ,IAAI,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,QAAQ,CAAC,EAAE,CAAC;oBAClD,OAAO,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;gBACzB,CAAC;YACH,CAAC;QACH,CAAC;QAED,OAAO,CAAC,WAAW,CAAC,CAAC;QACrB,OAAO,MAAM,CAAC;IAChB,CAAC;IAED,eAAe;IACf,UAAU,CAAC,KAAK;QACd,IAAI,CAAC,OAAO,CAAC,SAAS,GAAG,CAAC,CAAC;QAC3B,IAAI,CAAC,oBAAoB,GAAG,KAAK,CAAC;QAClC,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,CAAC;IAClB,CAAC;IAKD,mBAAmB;IACnB,KAAK,CAAC,aAAa,CAAC,KAAK;QACvB,MAAM,KAAK,GAAG,IAAI,KAAK,CAAC,GAAG,KAAK,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;QAC/C,IAAI,CAAC,uBAAuB,GAAG,KAAK,CAAC;QACrC,KAAK,MAAM,IAAI,IAAI,KAAK,EAAE,CAAC;YACzB,IAAI,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,SAAS,EAAE,CAAC;gBAC/B,IAAI,CAAC,sBAAsB,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC;gBACrC,SAAS;YACX,CAAC;YACD,MAAM,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC;iBAC3B,IAAI,CAAC,GAAG,CAAC,EAAE;gBACV,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;gBAC7B,IAAI,CAAC,sBAAsB,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC;gBACrC,kBAAkB;YACpB,CAAC,CAAC;iBACD,KAAK,CAAC,GAAG,EAAE;gBACV,IAAI,CAAC,sBAAsB,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC;YACvC,CAAC,CAAC,CAAC,CAAC,aAAa;QACrB,CAAC;QACD,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,CAAC;QAChB,MAAM,QAAQ,GAAG,CAAC,IAAI,CAAC,uBAAuB,CAAC,IAAI,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,MAAM,IAAI,CAAC,CAAC,CAAC;QAC1E,IAAI,QAAQ,EAAE,CAAC;YACb,gCAAgC;YAChC,UAAU,CAAC,GAAG,EAAE;gBACd,IAAI,CAAC,uBAAuB,GAAG,EAAE,CAAC;YACpC,CAAC,EAAE,IAAI,CAAC,CAAC;QACX,CAAC;IACH,CAAC;IAED,uCAAuC;IACvC,sBAAsB,CAAC,IAAI,EAAE,IAAI;QAC/B,IAAI,CAAC,uBAAuB,CAAC,GAAG,CAAC,EAAE,CAAC,EAAE;YACpC,IAAI,EAAE,IAAI,IAAI;gBAAE,EAAE,CAAC,MAAM,GAAG,IAAI,CAAC;QACnC,CAAC,CAAC,CAAC;IACL,CAAC;IAED,kBAAkB;IAClB,aAAa,CAAC,IAAI;QAChB,OAAO,IAAI,OAAO,CAAC,CAAC,OAAO,EAAE,OAAO,EAAE,EAAE;YACtC,MAAM,QAAQ,GAAG,IAAI,QAAQ,EAAE,CAAC;YAChC,QAAQ,CAAC,MAAM,CAAC,MAAM,EAAE,IAAI,EAAE,IAAI,CAAC,IAAI,CAAC,CAAC;YACzC,IAAI,CAAC,UAAU,CAAC;gBACd,IAAI,EAAE,QAAQ;gBACd,aAAa,EAAE,IAAI,CAAC,kBAAkB;gBACtC,WAAW,EAAE,IAAI,CAAC,oBAAoB,EAAE,GAAG,IAAI,EAAE;gBACjD,QAAQ,EAAE,EAAE;aACb,CAAC,CAAC,SAAS,CACV,GAAG,CAAC,EAAE;gBACJ,OAAO,CAAC,GAAG,CAAC,CAAC;YACf,CAAC,EACD,GAAG,CAAC,EAAE;gBACJ,OAAO,CAAC,KAAK,CAAC,CAAC;YACjB,CAAC,CACF,CAAC;QACJ,CAAC,CAAC,CAAC;IACL,CAAC;IAiBD,iBAAiB;IACjB,WAAW;QACT,MAAM,OAAO,GAAG,CAAC,KAA0B,EAAE,EAAE,CAC7C,IAAI,CAAC,YAAY,CAAC,OAAO,CAAC;YACxB,GAAG,KAAK;YACR,GAAG,IAAI,CAAC,OAAO;YACf,aAAa,EAAE,IAAI,CAAC,kBAAkB;YACtC,WAAW,EAAE,IAAI,CAAC,oBAAoB,CAAC,GAAG;SAC3C,CAAC,CAAC;QACL,MAAM,OAAO,GAAG,CAAC,IAAuC,EAAE,EAAE;YAC1D,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC;YACjB,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAChC,CAAC,CAAC;QACF,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC;IACpD,CAAC;IAED,sBAAsB;IACtB,WAAW;QACT,IAAI,CAAC,OAAO,CAAC,SAAS,GAAG,CAAC,CAAC;QAC3B,IAAI,CAAC,oBAAoB,GAAG,EAAE,CAAC;QAC/B,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,CAAC;IAClB,CAAC;IAED,UAAU;IACV,UAAU,CAAC,IAAI;QACb,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,SAAS,CAAC,GAAG,CAAC,EAAE;YAChD,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,IAAI,CAAC,oBAAoB,CAAC,OAAO,CAAC,mCAAmC,CAAC,CAAC,CAAC;YAC7F,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,CAAC;QAClB,CAAC,CAAC,CAAC;IACL,CAAC;IAED,cAAc;IACd,qBAAqB;QACnB,IAAI,CAAC,YAAY;aACd,IAAI,CAAC,EAAE,EAAE;YACR,GAAG,EAAE,EAAE;YACP,YAAY,EAAE,IAAI,CAAC,oBAAoB,CAAC,OAAO,CAAC,0BAA0B,CAAC;SAC5E,CAAC;aACD,SAAS,CAAC,KAAK,EAAE,MAA2B,EAAE,EAAE;YAC/C,IAAI,MAAM,IAAI,SAAS,EAAE,CAAC;gBACxB,MAAM,aAAa,GAAG,IAAI,CAAC,aAAa,CAAC;gBACzC,IAAI,CAAC;oBACH,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,gBAAgB,CAAC,aAAa,CAAC,CAAC;oBAC1D,IAAI,MAAM,CAAC,OAAO,EAAE,CAAC;wBACnB,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC;wBACrC,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,CAAC;wBAChB,gBAAgB;oBAClB,CAAC;yBAAM,CAAC;wBACN,QAAQ;wBACR,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,CAAC;wBAChB,eAAe;oBACjB,CAAC;gBACH,CAAC;gBAAC,OAAO,KAAK,EAAE,CAAC;oBACf,aAAa;gBACf,CAAC;YACH,CAAC;QACH,CAAC,CAAC,CAAC;IACP,CAAC;IAED;;;;OAIG;IACH,KAAK,CAAC,gBAAgB,CAAC,aAAoB;QACzC,mBAAmB;QACnB,MAAM,cAAc,GAAG,aAAa,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE;YAC9C,OAAO,IAAI,OAAO,CAAC,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;gBACrC,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,SAAS,CACzC,GAAG,EAAE;oBACH,OAAO,CAAC,IAAI,CAAC,CAAC;gBAChB,CAAC,EACD,GAAG,EAAE;oBACH,MAAM,CAAC,IAAI,CAAC,CAAC;gBACf,CAAC,CACF,CAAC;YACJ,CAAC,CAAC,CAAC;QACL,CAAC,CAAC,CAAC;QAEH,WAAW;QACX,MAAM,OAAO,GAAG,MAAM,OAAO,CAAC,UAAU,CAAC,cAAc,CAAC,CAAC;QACzD,SAAS;QACT,MAAM,WAAW,GAAU,EAAE,CAAC;QAC9B,OAAO,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE;YACvB,IAAI,MAAM,CAAC,MAAM,KAAK,UAAU,EAAE,CAAC;gBACjC,WAAW,CAAC,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC;YAClC,CAAC;QACH,CAAC,CAAC,CAAC;QAEH,OAAO;YACL,OAAO,EAAE,WAAW,CAAC,MAAM,KAAK,CAAC;YACjC,WAAW;YACX,OAAO,EACL,WAAW,CAAC,MAAM,KAAK,CAAC;gBACtB,CAAC,CAAC,IAAI,CAAC,oBAAoB,CAAC,OAAO,CAAC,mCAAmC,CAAC;gBACxE,CAAC,CAAC,GAAG,WAAW,CAAC,MAAM,QAAQ;SACpC,CAAC;IACJ,CAAC;IAED,OAAO;IACP,KAAK,CAAC,iBAAiB,KAAI,CAAC;IAE5B,cAAc;IACd,oBAAoB;QAClB,IAAI,CAAC,uBAAuB,GAAG,EAAE,CAAC;IACpC,CAAC;IA6BD,WAAW,CAAC,OAAsB;QAChC,yGAAyG;QACzG,6CAA6C;QAC7C,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,eAAe,CAAC,SAAS,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAC;IAC7E,CAAC;IACD,YAAY;IACZ,YAAY,CAAC,QAAQ;QACnB,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,eAAe,CAAC,QAAQ,EAAE,IAAI,CAAC,aAAa,CAAC,CAAC;IAC1E,CAAC;IACD,YAAY;IACZ,kBAAkB,CAAC,KAAK,EAAE,GAAG,EAAE,KAAY;QACzC,MAAM,EAAE,OAAO,EAAE,GAAG,KAAK,CAAC,MAAM,CAAC;QACjC,IAAI,kBAAkB,GAAG,CAAC,GAAG,IAAI,CAAC,aAAa,CAAC,CAAC;QACjD,IAAI,IAAI,CAAC,SAAS,EAAE,CAAC;YACnB,IAAI,OAAO,EAAE,CAAC;gBACZ,kBAAkB,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;YAC/B,CAAC;iBAAM,CAAC;gBACN,kBAAkB,GAAG,kBAAkB,CAAC,MAAM,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,IAAI,GAAG,CAAC,EAAE,CAAC,CAAC;YACxE,CAAC;YACD,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,eAAe,CAAC,KAAK,EAAE,kBAAkB,CAAC,CAAC;QACvE,CAAC;aAAM,CAAC;YACN,kBAAkB,CAAC,MAAM,GAAG,CAAC,CAAC;YAC9B,kBAAkB,GAAG,OAAO,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;QAC5C,CAAC;QACD,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,oBAAoB,CAAC,kBAAkB,CAAC,CAAC;IACrE,CAAC;IACD,sEAAsE;IACtE,eAAe,CAAC,UAAiB,EAAE,gBAAuB,EAAE;QAC1D,IAAG,UAAU,CAAC,MAAM,IAAI,CAAC;YAAE,OAAO,KAAK,CAAC;QACxC,OAAO,UAAU,CAAC,KAAK,CAAC,IAAI,CAAC,EAAE,CAAC,aAAa,CAAC,IAAI,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,KAAK,IAAI,CAAC,EAAE,CAAC,CAAC,CAAC;IAC/E,CAAC;IACD,aAAa;IACb,aAAa,CAAC,KAAU,EAAE,KAAY;QACpC,IAAI,kBAAkB,GAAG,IAAI,CAAC,aAAa,CAAC;QAC5C,IAAI,KAAK,CAAC,MAAM,CAAC,OAAO,EAAE,CAAC;YACzB,kBAAkB,GAAG,IAAI,CAAC,oBAAoB,CAAC,CAAC,GAAG,kBAAkB,EAAE,GAAG,KAAK,CAAC,CAAC,CAAC;QACpF,CAAC;aAAM,CAAC;YACN,kBAAkB,GAAG,kBAAkB,CAAC,MAAM,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,EAAE,KAAK,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;QAC/F,CAAC;QACD,IAAI,CAAC,aAAa,GAAG,KAAK,CAAC,MAAM,CAAC,OAAO,CAAC;QAC1C,IAAI,CAAC,aAAa,GAAG,kBAAkB,CAAC;IAC1C,CAAC;IAMD,eAAe;IACf,oBAAoB,CAAC,KAAK;QACxB,MAAM,OAAO,GAAG,EAAE,CAAC;QACnB,OAAO,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE;YACzB,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE,CAAC,EAAE,CAAC;gBACtB,OAAO,CAAC,IAAI,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC;gBACxB,OAAO,IAAI,CAAC;YACd,CAAC;YACD,OAAO,KAAK,CAAC;QACf,CAAC,CAAC,CAAC;IACL,CAAC;IAOD,kBAAkB;IAClB,gBAAgB,CAAC,KAAK;QACpB,MAAM,KAAK,GAAG,IAAI,CAAC,YAAY,CAAC,KAAK,CAAC;QACtC,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,KAAK;YAAE,OAAO;QACrC,IAAI,IAAI,CAAC,SAAS;YAAE,OAAO;QAC3B,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC;QACtB,IAAI,CAAC,YAAY;aACd,MAAM,CAAC,KAAK,CAAC,EAAE,EAAE;YAChB,IAAI,EAAC,KAAK,CAAC,QAAQ;SACpB,CAAC;aACD,IAAI,CACH,QAAQ,CAAC,GAAG,EAAE;YACZ,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;QACzB,CAAC,CAAC,CACH;aACA,SAAS,CAAC,GAAG,CAAC,EAAE;YACf,yCAAyC;YACzC,KAAK,MAAM,OAAO,IAAI,IAAI,CAAC,IAAI,CAAC,KAAK,EAAE,CAAC;gBACtC,IAAI,OAAO,CAAC,EAAE,IAAI,IAAI,CAAC,UAAU,CAAC,EAAE,EAAE,CAAC;oBACrC,OAAO,CAAC,IAAI,GAAG,KAAK,CAAC,QAAQ,CAAC;oBAC9B,MAAM;gBACR,CAAC;YACH,CAAC;YAED,IAAI,CAAC,YAAY,GAAG,SAAS,CAAC;YAC9B,IAAI,CAAC,UAAU,GAAG,EAAE,CAAC;YACrB,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,IAAI,CAAC,oBAAoB,CAAC,OAAO,CAAC,iCAAiC,CAAC,CAAC,CAAC;YAC3F,mBAAmB;QACrB,CAAC,CAAC,CAAC;IACP,CAAC;IACD,UAAU;IACV,cAAc,CAAC,GAAG;QAChB,IAAI,CAAC,YAAY,GAAG,IAAI,SAAS,CAAC;YAChC,QAAQ,EAAE,IAAI,WAAW,CAAC,EAAE,EAAE,CAAC,UAAU,CAAC,QAAQ,CAAC,CAAC;YACpD,EAAE,EAAE,IAAI,WAAW,CAAC,EAAE,EAAE,CAAC,UAAU,CAAC,QAAQ,CAAC,CAAC;SAC/C,CAAC,CAAC;QACH,IAAI,CAAC,YAAY,CAAC,UAAU,CAAC;YAC3B,QAAQ,EAAE,GAAG,CAAC,IAAI;YAClB,EAAE,EAAE,GAAG,CAAC,EAAE;SACX,CAAC,CAAC;QACH,IAAI,CAAC,UAAU,GAAG,GAAG,CAAC;IACxB,CAAC;IACD,UAAU;IACV,gBAAgB,CAAC,GAAG;QAClB,IAAI,CAAC,UAAU,GAAG,EAAE,CAAC;QACrB,IAAI,CAAC,YAAY,GAAG,SAAS,CAAC;IAChC,CAAC;8GAldU,kBAAkB;kGAAlB,kBAAkB,uQATlB;YACT,aAAa;YACb,WAAW;YACX,aAAa;YACb,4DAA4D;YAC5D,uEAAuE;YACvE,EAAE,OAAO,EAAE,wBAAwB,EAAE,QAAQ,EAAE,GAAG,EAAE;SACrD,+CCjCH,4iRA+IY;;2FD5GC,kBAAkB;kBAd9B,SAAS;+BAEE,eAAe,aAGd;wBACT,aAAa;wBACb,WAAW;wBACX,aAAa;wBACb,4DAA4D;wBAC5D,uEAAuE;wBACvE,EAAE,OAAO,EAAE,wBAAwB,EAAE,QAAQ,EAAE,GAAG,EAAE;qBACrD;4QAgCU,iBAAiB;sBAD3B,KAAK;gBAWK,QAAQ;sBADlB,KAAK;gBAUK,KAAK;sBADf,KAAK;gBAMK,OAAO;sBADjB,KAAK;gBASI,aAAa;sBAAtB,MAAM;gBA8JG,YAAY;sBAArB,MAAM;gBAsIE,gBAAgB;sBAAxB,KAAK","sourcesContent":["import { Component, EventEmitter, Input, Output, SimpleChanges, inject, OnChanges } 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';\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 implements OnChanges {\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  }\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 = false;\n  @Input()\n  public set multiple(v: boolean) {\n    this._multiple = v;\n  }\n\n  /**文件大小限制\n   * @param 1mb\n   */\n  sizeLimit = 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 = false;\n\n  /**模态框-繁忙状态-用于确定模态的繁忙状态是否为真 */\n  ModalBusy = 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    const 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 = 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    const 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    const 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    const 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      const 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          const 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              // 可以选择展示失败项或重试\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    // 收集失败的项\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 = false;\n  /**提交FileName编辑 */\n  onSubmitFileName(event) {\n    const 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>"]}
|