@dignite-ng/expand.file-explorer 0.0.1
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 +24 -0
- package/config/enums/index.d.ts +1 -0
- package/config/enums/route-names.d.ts +3 -0
- package/config/file-config.module.d.ts +8 -0
- package/config/index.d.ts +5 -0
- package/config/providers/index.d.ts +1 -0
- package/config/providers/route.provider.d.ts +8 -0
- package/config/public-api.d.ts +3 -0
- package/esm2022/config/dignite-ng-expand.file-explorer-config.mjs +5 -0
- package/esm2022/config/enums/index.mjs +2 -0
- package/esm2022/config/enums/route-names.mjs +2 -0
- package/esm2022/config/file-config.module.mjs +19 -0
- package/esm2022/config/providers/index.mjs +2 -0
- package/esm2022/config/providers/route.provider.mjs +24 -0
- package/esm2022/config/public-api.mjs +4 -0
- package/esm2022/dignite-ng-expand.file-explorer.mjs +5 -0
- package/esm2022/lib/components/dome/file-dome.component.mjs +32 -0
- package/esm2022/lib/components/file-edit/file-edit.component.mjs +102 -0
- package/esm2022/lib/components/file-modal/file-modal.component.mjs +271 -0
- package/esm2022/lib/components/file-modal-tree/file-modal-tree.component.mjs +195 -0
- package/esm2022/lib/components/file-picker/file-picker.component.mjs +57 -0
- package/esm2022/lib/components/index.mjs +6 -0
- package/esm2022/lib/file-explorer-routing.module.mjs +25 -0
- package/esm2022/lib/file-explorer.module.mjs +83 -0
- package/esm2022/lib/proxy/dignite/file-explorer/directories/file-descriptor.service.mjs +48 -0
- package/esm2022/lib/proxy/dignite/file-explorer/directories/index.mjs +3 -0
- package/esm2022/lib/proxy/dignite/file-explorer/directories/models.mjs +2 -0
- package/esm2022/lib/proxy/dignite/file-explorer/files/file-descriptor.service.mjs +60 -0
- package/esm2022/lib/proxy/dignite/file-explorer/files/index.mjs +3 -0
- package/esm2022/lib/proxy/dignite/file-explorer/files/models.mjs +2 -0
- package/esm2022/lib/proxy/dignite/file-explorer/index.mjs +4 -0
- package/esm2022/lib/proxy/dignite/index.mjs +3 -0
- package/esm2022/lib/proxy/index.mjs +5 -0
- package/esm2022/lib/proxy/microsoft/asp-net-core/index.mjs +3 -0
- package/esm2022/lib/proxy/microsoft/asp-net-core/mvc/index.mjs +2 -0
- package/esm2022/lib/proxy/microsoft/asp-net-core/mvc/models.mjs +2 -0
- package/esm2022/lib/proxy/microsoft/extensions/index.mjs +3 -0
- package/esm2022/lib/proxy/microsoft/extensions/primitives/index.mjs +2 -0
- package/esm2022/lib/proxy/microsoft/extensions/primitives/models.mjs +2 -0
- package/esm2022/lib/proxy/microsoft/index.mjs +5 -0
- package/esm2022/lib/proxy/microsoft/net/http/headers/index.mjs +2 -0
- package/esm2022/lib/proxy/microsoft/net/http/headers/models.mjs +2 -0
- package/esm2022/lib/proxy/microsoft/net/http/index.mjs +3 -0
- package/esm2022/lib/proxy/microsoft/net/index.mjs +3 -0
- package/esm2022/lib/proxy/volo/abp/content/index.mjs +2 -0
- package/esm2022/lib/proxy/volo/abp/content/models.mjs +2 -0
- package/esm2022/lib/proxy/volo/abp/index.mjs +3 -0
- package/esm2022/lib/proxy/volo/index.mjs +3 -0
- package/esm2022/lib/services/file-api.service.mjs +66 -0
- package/esm2022/lib/services/index.mjs +2 -0
- package/esm2022/public-api.mjs +8 -0
- package/fesm2022/dignite-ng-expand.file-explorer-config.mjs +47 -0
- package/fesm2022/dignite-ng-expand.file-explorer-config.mjs.map +1 -0
- package/fesm2022/dignite-ng-expand.file-explorer.mjs +972 -0
- package/fesm2022/dignite-ng-expand.file-explorer.mjs.map +1 -0
- package/index.d.ts +5 -0
- package/lib/components/dome/file-dome.component.d.ts +19 -0
- package/lib/components/file-edit/file-edit.component.d.ts +38 -0
- package/lib/components/file-modal/file-modal.component.d.ts +93 -0
- package/lib/components/file-modal-tree/file-modal-tree.component.d.ts +66 -0
- package/lib/components/file-picker/file-picker.component.d.ts +23 -0
- package/lib/components/index.d.ts +5 -0
- package/lib/file-explorer-routing.module.d.ts +7 -0
- package/lib/file-explorer.module.d.ts +18 -0
- package/lib/proxy/dignite/file-explorer/directories/file-descriptor.service.d.ts +17 -0
- package/lib/proxy/dignite/file-explorer/directories/index.d.ts +2 -0
- package/lib/proxy/dignite/file-explorer/directories/models.d.ts +29 -0
- package/lib/proxy/dignite/file-explorer/files/file-descriptor.service.d.ts +20 -0
- package/lib/proxy/dignite/file-explorer/files/index.d.ts +2 -0
- package/lib/proxy/dignite/file-explorer/files/models.d.ts +50 -0
- package/lib/proxy/dignite/file-explorer/index.d.ts +3 -0
- package/lib/proxy/dignite/index.d.ts +2 -0
- package/lib/proxy/index.d.ts +4 -0
- package/lib/proxy/microsoft/asp-net-core/index.d.ts +2 -0
- package/lib/proxy/microsoft/asp-net-core/mvc/index.d.ts +1 -0
- package/lib/proxy/microsoft/asp-net-core/mvc/models.d.ts +10 -0
- package/lib/proxy/microsoft/extensions/index.d.ts +2 -0
- package/lib/proxy/microsoft/extensions/primitives/index.d.ts +1 -0
- package/lib/proxy/microsoft/extensions/primitives/models.d.ts +8 -0
- package/lib/proxy/microsoft/index.d.ts +4 -0
- package/lib/proxy/microsoft/net/http/headers/index.d.ts +1 -0
- package/lib/proxy/microsoft/net/http/headers/models.d.ts +6 -0
- package/lib/proxy/microsoft/net/http/index.d.ts +2 -0
- package/lib/proxy/microsoft/net/index.d.ts +2 -0
- package/lib/proxy/volo/abp/content/index.d.ts +1 -0
- package/lib/proxy/volo/abp/content/models.d.ts +5 -0
- package/lib/proxy/volo/abp/index.d.ts +2 -0
- package/lib/proxy/volo/index.d.ts +2 -0
- package/lib/services/file-api.service.d.ts +14 -0
- package/lib/services/index.d.ts +1 -0
- package/package.json +40 -0
- package/public-api.d.ts +4 -0
|
@@ -0,0 +1,271 @@
|
|
|
1
|
+
import { Component, EventEmitter, Input, Output } from '@angular/core';
|
|
2
|
+
import { ListService, LIST_QUERY_DEBOUNCE_TIME } from '@abp/ng.core';
|
|
3
|
+
import { SelectionType } from '@swimlane/ngx-datatable';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
import * as i1 from "../../proxy/dignite/file-explorer/files";
|
|
6
|
+
import * as i2 from "@abp/ng.theme.shared";
|
|
7
|
+
import * as i3 from "@abp/ng.core";
|
|
8
|
+
import * as i4 from "../../services/file-api.service";
|
|
9
|
+
import * as i5 from "@angular/common";
|
|
10
|
+
import * as i6 from "@swimlane/ngx-datatable";
|
|
11
|
+
import * as i7 from "../file-modal-tree/file-modal-tree.component";
|
|
12
|
+
var that;
|
|
13
|
+
class FileModalComponent {
|
|
14
|
+
_FileService;
|
|
15
|
+
toaster;
|
|
16
|
+
list;
|
|
17
|
+
_FileApiService;
|
|
18
|
+
restService;
|
|
19
|
+
confirmation;
|
|
20
|
+
_LocalizationService;
|
|
21
|
+
constructor(_FileService, toaster, list, _FileApiService, restService, confirmation, _LocalizationService) {
|
|
22
|
+
this._FileService = _FileService;
|
|
23
|
+
this.toaster = toaster;
|
|
24
|
+
this.list = list;
|
|
25
|
+
this._FileApiService = _FileApiService;
|
|
26
|
+
this.restService = restService;
|
|
27
|
+
this.confirmation = confirmation;
|
|
28
|
+
this._LocalizationService = _LocalizationService;
|
|
29
|
+
that = this;
|
|
30
|
+
}
|
|
31
|
+
/**图片容器 */
|
|
32
|
+
_fileContainerName;
|
|
33
|
+
set fileContainerName(v) {
|
|
34
|
+
if (v) {
|
|
35
|
+
this._fileContainerName = v;
|
|
36
|
+
this.loadData();
|
|
37
|
+
}
|
|
38
|
+
}
|
|
39
|
+
/**是否多选 */
|
|
40
|
+
_multiple = true;
|
|
41
|
+
set multiple(v) {
|
|
42
|
+
this._multiple = v;
|
|
43
|
+
if (v) { }
|
|
44
|
+
}
|
|
45
|
+
/**文件大小限制
|
|
46
|
+
* @param 1mb
|
|
47
|
+
*/
|
|
48
|
+
sizeLimit = 1048576;
|
|
49
|
+
set limit(v) {
|
|
50
|
+
this.sizeLimit = v;
|
|
51
|
+
}
|
|
52
|
+
/**父组件传递的模态框状态 */
|
|
53
|
+
set visible(v) {
|
|
54
|
+
this.ModalOpen = v;
|
|
55
|
+
if (v) {
|
|
56
|
+
this.loadData();
|
|
57
|
+
}
|
|
58
|
+
}
|
|
59
|
+
/**模态框状态回调 */
|
|
60
|
+
visibleChange = new EventEmitter();
|
|
61
|
+
/**模态框-状态-是否打开 */
|
|
62
|
+
ModalOpen = false;
|
|
63
|
+
/**模态框-繁忙状态-用于确定模态的繁忙状态是否为真 */
|
|
64
|
+
ModalBusy = false;
|
|
65
|
+
/**模态框-状态改变回调 */
|
|
66
|
+
ModalVisibleChange(event) {
|
|
67
|
+
if (!event) {
|
|
68
|
+
this.visibleChange.emit(event);
|
|
69
|
+
return;
|
|
70
|
+
}
|
|
71
|
+
}
|
|
72
|
+
/**模态框保存 */
|
|
73
|
+
modalSave() {
|
|
74
|
+
let selectedTablearr = this._FileApiService.deepClone(this.selectedTable);
|
|
75
|
+
this.selectFilefn.emit(selectedTablearr);
|
|
76
|
+
this.ModalVisibleChange(false);
|
|
77
|
+
}
|
|
78
|
+
/**dignite-file-modal-tree */
|
|
79
|
+
/**选择的tree节点 */
|
|
80
|
+
_theSelectedTreeNode = '';
|
|
81
|
+
/**初始化数据 */
|
|
82
|
+
loadData() {
|
|
83
|
+
if (this.ModalOpen && this._fileContainerName) {
|
|
84
|
+
this.hookToQuery();
|
|
85
|
+
}
|
|
86
|
+
}
|
|
87
|
+
/**tree-节点选择 */
|
|
88
|
+
_nodeClick(event) {
|
|
89
|
+
this._theSelectedTreeNode = event;
|
|
90
|
+
this.list.get();
|
|
91
|
+
}
|
|
92
|
+
/**图片上传-要上传图片的状态文件列表 */
|
|
93
|
+
uploadPictureStatusList = [];
|
|
94
|
+
/**图片上传-获取文件信息改变 */
|
|
95
|
+
async getFileChange(event) {
|
|
96
|
+
let files = new Array(...event.target.files);
|
|
97
|
+
this.uploadPictureStatusList = files;
|
|
98
|
+
for (const file of files) {
|
|
99
|
+
if (file.size > this.sizeLimit) {
|
|
100
|
+
this.setuploadPictureStatus(file, 2);
|
|
101
|
+
continue;
|
|
102
|
+
}
|
|
103
|
+
await this.uploadingFile(file).then(() => {
|
|
104
|
+
this.setuploadPictureStatus(file, 1);
|
|
105
|
+
this.list.get();
|
|
106
|
+
}).catch(() => {
|
|
107
|
+
this.setuploadPictureStatus(file, 2);
|
|
108
|
+
}); // 等待每个文件上传完成
|
|
109
|
+
}
|
|
110
|
+
this.list.get();
|
|
111
|
+
let isSubmit = !this.uploadPictureStatusList.some(el => el.status == 2);
|
|
112
|
+
if (isSubmit) {
|
|
113
|
+
// this.toaster.success("上传完成");
|
|
114
|
+
setTimeout(() => {
|
|
115
|
+
this.uploadPictureStatusList = [];
|
|
116
|
+
}, 6000);
|
|
117
|
+
}
|
|
118
|
+
}
|
|
119
|
+
/**图片上传-设置uploadPictureStatusList的状态 */
|
|
120
|
+
setuploadPictureStatus(file, type) {
|
|
121
|
+
this.uploadPictureStatusList.map(el => {
|
|
122
|
+
if (el == file)
|
|
123
|
+
el.status = type;
|
|
124
|
+
});
|
|
125
|
+
}
|
|
126
|
+
/**图片上传-递归按顺序上传 */
|
|
127
|
+
uploadingFile(file) {
|
|
128
|
+
return new Promise((resolve, rejects) => {
|
|
129
|
+
let formData = new FormData();
|
|
130
|
+
formData.append('file', file, file.name);
|
|
131
|
+
this.createFile({
|
|
132
|
+
file: formData,
|
|
133
|
+
containerName: this._fileContainerName,
|
|
134
|
+
directoryId: this._theSelectedTreeNode?.key || '',
|
|
135
|
+
entityId: ''
|
|
136
|
+
}).subscribe(res => {
|
|
137
|
+
resolve(true);
|
|
138
|
+
}, (err) => {
|
|
139
|
+
rejects(false);
|
|
140
|
+
});
|
|
141
|
+
});
|
|
142
|
+
}
|
|
143
|
+
/**文件表格-数据*/
|
|
144
|
+
data = {
|
|
145
|
+
items: [],
|
|
146
|
+
totalCount: 0,
|
|
147
|
+
};
|
|
148
|
+
/**文件表格-条件*/
|
|
149
|
+
filters = {};
|
|
150
|
+
/**文件表格-表格自带选择类型 */
|
|
151
|
+
SelectionType = SelectionType;
|
|
152
|
+
/**文件表格-选择的表格数据项 */
|
|
153
|
+
selectedTable = [];
|
|
154
|
+
/**已选定的文件 */
|
|
155
|
+
selectPickerFile;
|
|
156
|
+
ngOnChanges(changes) {
|
|
157
|
+
//Called before any other lifecycle hook. Use it to inject dependencies, but avoid any serious work here.
|
|
158
|
+
//Add '${implements OnChanges}' to the class.
|
|
159
|
+
this.selectedTable = this._FileApiService.deepClone(this.selectPickerFile);
|
|
160
|
+
}
|
|
161
|
+
/**当前选择的table项 id */
|
|
162
|
+
nowSelectId = '';
|
|
163
|
+
/**选择文件回调 */
|
|
164
|
+
// @Output() selectedFileChange = new EventEmitter<any[]>()
|
|
165
|
+
selectFilefn = new EventEmitter();
|
|
166
|
+
/**文件表格-获取表格数据 */
|
|
167
|
+
hookToQuery() {
|
|
168
|
+
const getData = (query) => this._FileService.getList({
|
|
169
|
+
...query,
|
|
170
|
+
...this.filters,
|
|
171
|
+
containerName: this._fileContainerName,
|
|
172
|
+
directoryId: this._theSelectedTreeNode.key
|
|
173
|
+
});
|
|
174
|
+
const setData = (list) => (this.data = list);
|
|
175
|
+
this.list.hookToQuery(getData).subscribe(setData);
|
|
176
|
+
}
|
|
177
|
+
/**文件表格-查看所有分组的文件数据 */
|
|
178
|
+
lookAllFile() {
|
|
179
|
+
this._theSelectedTreeNode = '';
|
|
180
|
+
this.list.get();
|
|
181
|
+
}
|
|
182
|
+
/**选择表格项 */
|
|
183
|
+
onSelectTableItem({ selected }) {
|
|
184
|
+
this.selectedTable = this._FileApiService.deepClone(selected);
|
|
185
|
+
let selectedTablearr = this.removeDuplicatesById(this.selectedTable);
|
|
186
|
+
if (selected.length > selectedTablearr.length) {
|
|
187
|
+
selectedTablearr = selectedTablearr.filter(el => el.id !== this.nowSelectId);
|
|
188
|
+
}
|
|
189
|
+
this.selectedTable = selectedTablearr;
|
|
190
|
+
}
|
|
191
|
+
/**删除数组中重复的项 */
|
|
192
|
+
removeDuplicatesById(array) {
|
|
193
|
+
const seenIds = {};
|
|
194
|
+
return array.filter(item => {
|
|
195
|
+
if (!seenIds[item.id]) {
|
|
196
|
+
seenIds[item.id] = true;
|
|
197
|
+
return true;
|
|
198
|
+
}
|
|
199
|
+
return false;
|
|
200
|
+
});
|
|
201
|
+
}
|
|
202
|
+
/**一个布尔or函数,可用于检查是否要根据条件选择特定行。 */
|
|
203
|
+
selectCheck = (row, column, value) => {
|
|
204
|
+
this.nowSelectId = row.id;
|
|
205
|
+
return true;
|
|
206
|
+
};
|
|
207
|
+
/**判断row是否选中 */
|
|
208
|
+
selectedcheckbox = (id) => {
|
|
209
|
+
return this.selectedTable.some(el => el.id == id);
|
|
210
|
+
};
|
|
211
|
+
/**删除图片 */
|
|
212
|
+
deleteFile(file) {
|
|
213
|
+
this.confirmation
|
|
214
|
+
.warn('', { key: '', defaultValue: this._LocalizationService.instant(`AbpUi::ItemWillBeDeletedMessage`) })
|
|
215
|
+
.subscribe((status) => {
|
|
216
|
+
if (status == 'confirm') {
|
|
217
|
+
this._FileService.delete(file.id).subscribe(res => {
|
|
218
|
+
this.toaster.success(this._LocalizationService.instant(`AbpUi::SuccessfullyDeleted`));
|
|
219
|
+
this.list.get();
|
|
220
|
+
});
|
|
221
|
+
}
|
|
222
|
+
});
|
|
223
|
+
}
|
|
224
|
+
/**关闭文件状态弹窗 */
|
|
225
|
+
closeFileStatusModal() {
|
|
226
|
+
this.uploadPictureStatusList = [];
|
|
227
|
+
}
|
|
228
|
+
/**创建图片的接口,代理中的file类型不匹配,切换为any类型 */
|
|
229
|
+
createFile = (input, config) => this.restService.request({
|
|
230
|
+
method: 'POST',
|
|
231
|
+
url: '/api/file-explorer/files',
|
|
232
|
+
params: { containerName: input.containerName, cellName: input.cellName, directoryId: input.directoryId, entityId: input.entityId },
|
|
233
|
+
body: input.file,
|
|
234
|
+
}, { apiName: 'FileExplorer', ...config });
|
|
235
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", 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 ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: FileModalComponent, selector: "fe-file-modal", inputs: { fileContainerName: "fileContainerName", multiple: "multiple", limit: "limit", visible: "visible", selectPickerFile: "selectPickerFile" }, outputs: { visibleChange: "visibleChange", selectFilefn: "selectFilefn" }, providers: [
|
|
237
|
+
// [Required]
|
|
238
|
+
ListService,
|
|
239
|
+
// [Optional]
|
|
240
|
+
// Provide this token if you want a different debounce time.
|
|
241
|
+
// Default is 300. Cannot be 0. Any value below 100 is not recommended.
|
|
242
|
+
{ 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\" 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=\"col-9\" style=\"height: calc(100vh - 240px)\">\n <div class=\"mb-2 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\" accept=\".jpg,.jpeg,.png,.gif,.webp\"\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]=\"SelectionType.multiClick\" (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 [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:m: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 border bg-white p-1 m-5\"\n style=\"border-radius: 10px\">\n <div class=\"card\">\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: "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.NgxDatatableListDirective, selector: "ngx-datatable[list]", inputs: ["list"], exportAs: ["ngxDatatableList"] }, { kind: "directive", type: i2.ModalCloseDirective, selector: "[abpClose]" }, { kind: "component", type: i7.FileModalTreeComponent, selector: "fe-file-modal-tree", inputs: ["theSelectedTreeNode", "fileContainerName"], outputs: ["nodeClick"] }, { kind: "pipe", type: i5.DatePipe, name: "date" }, { kind: "pipe", type: i3.LocalizationPipe, name: "abpLocalization" }] });
|
|
244
|
+
}
|
|
245
|
+
export { FileModalComponent };
|
|
246
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: FileModalComponent, decorators: [{
|
|
247
|
+
type: Component,
|
|
248
|
+
args: [{ selector: 'fe-file-modal', providers: [
|
|
249
|
+
// [Required]
|
|
250
|
+
ListService,
|
|
251
|
+
// [Optional]
|
|
252
|
+
// Provide this token if you want a different debounce time.
|
|
253
|
+
// Default is 300. Cannot be 0. Any value below 100 is not recommended.
|
|
254
|
+
{ provide: LIST_QUERY_DEBOUNCE_TIME, useValue: 500 },
|
|
255
|
+
], 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\" 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=\"col-9\" style=\"height: calc(100vh - 240px)\">\n <div class=\"mb-2 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\" accept=\".jpg,.jpeg,.png,.gif,.webp\"\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]=\"SelectionType.multiClick\" (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 [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:m: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 border bg-white p-1 m-5\"\n style=\"border-radius: 10px\">\n <div class=\"card\">\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"] }]
|
|
256
|
+
}], ctorParameters: function () { return [{ type: i1.FileDescriptorService }, { type: i2.ToasterService }, { type: i3.ListService }, { type: i4.FileApiService }, { type: i3.RestService }, { type: i2.ConfirmationService }, { type: i3.LocalizationService }]; }, propDecorators: { fileContainerName: [{
|
|
257
|
+
type: Input
|
|
258
|
+
}], multiple: [{
|
|
259
|
+
type: Input
|
|
260
|
+
}], limit: [{
|
|
261
|
+
type: Input
|
|
262
|
+
}], visible: [{
|
|
263
|
+
type: Input
|
|
264
|
+
}], visibleChange: [{
|
|
265
|
+
type: Output
|
|
266
|
+
}], selectPickerFile: [{
|
|
267
|
+
type: Input
|
|
268
|
+
}], selectFilefn: [{
|
|
269
|
+
type: Output
|
|
270
|
+
}] } });
|
|
271
|
+
//# 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 } 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, 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  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  _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 = true\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    }\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() selectedFileChange = new EventEmitter<any[]>()\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::SuccessfullyDeleted`));\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\" 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=\"col-9\" style=\"height: calc(100vh - 240px)\">\n        <div class=\"mb-2 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\" accept=\".jpg,.jpeg,.png,.gif,.webp\"\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]=\"SelectionType.multiClick\" (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 [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:m: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 border bg-white p-1 m-5\"\n          style=\"border-radius: 10px\">\n          <div class=\"card\">\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>"]}
|