@dignite-ng/expand.file-explorer 3.0.0-rc.34 → 3.0.0-rc.35
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/lib/components/file-modal/file-modal.component.mjs +274 -68
- package/esm2022/lib/components/file-modal-tree/file-modal-tree.component.mjs +125 -52
- package/esm2022/lib/components/file-picker/file-picker.component.mjs +14 -5
- package/esm2022/lib/file-explorer.module.mjs +14 -3
- package/esm2022/lib/pipe/get-directory-name.pipe.mjs +20 -0
- package/esm2022/lib/proxy/dignite/file-explorer/files/file-descriptor.service.mjs +10 -3
- package/esm2022/lib/proxy/dignite/file-explorer/files/models.mjs +1 -1
- package/fesm2022/dignite-ng-expand.file-explorer.mjs +448 -131
- package/fesm2022/dignite-ng-expand.file-explorer.mjs.map +1 -1
- package/lib/components/file-modal/file-modal.component.d.ts +61 -20
- 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 +4 -1
- package/lib/pipe/get-directory-name.pipe.d.ts +7 -0
- 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 +1 -1
|
@@ -1,11 +1,12 @@
|
|
|
1
1
|
/* eslint-disable @angular-eslint/component-selector */
|
|
2
|
-
import { Component, ElementRef, EventEmitter, Input, Output, ViewChild } from '@angular/core';
|
|
2
|
+
import { Component, ElementRef, EventEmitter, inject, Input, Output, ViewChild, } from '@angular/core';
|
|
3
3
|
import { FormBuilder, Validators } from '@angular/forms';
|
|
4
4
|
import * as DescriptorService from '../../proxy/dignite/file-explorer/directories';
|
|
5
|
-
import { ToasterService } from '@abp/ng.theme.shared';
|
|
6
|
-
import { of } from 'rxjs';
|
|
5
|
+
import { ConfirmationService, ToasterService } from '@abp/ng.theme.shared';
|
|
6
|
+
import { finalize, map, of, tap } from 'rxjs';
|
|
7
7
|
import { FileApiService } from '../../services/file-api.service';
|
|
8
8
|
import { LocalizationService } from '@abp/ng.core';
|
|
9
|
+
import { ValidatorsService } from '@dignite-ng/expand.core';
|
|
9
10
|
import * as i0 from "@angular/core";
|
|
10
11
|
import * as i1 from "../../proxy/dignite/file-explorer/directories";
|
|
11
12
|
import * as i2 from "@angular/forms";
|
|
@@ -15,15 +16,16 @@ import * as i5 from "@abp/ng.core";
|
|
|
15
16
|
import * as i6 from "@angular/common";
|
|
16
17
|
import * as i7 from "@ngx-validate/core";
|
|
17
18
|
import * as i8 from "@ng-bootstrap/ng-bootstrap";
|
|
18
|
-
import * as i9 from "ng
|
|
19
|
+
import * as i9 from "@abp/ng.components/tree";
|
|
19
20
|
var that;
|
|
20
21
|
export class FileModalTreeComponent {
|
|
21
|
-
constructor(_DescriptorService, fb, toaster, _FileApiService, _LocalizationService) {
|
|
22
|
+
constructor(_DescriptorService, fb, toaster, _FileApiService, _LocalizationService, confirmation) {
|
|
22
23
|
this._DescriptorService = _DescriptorService;
|
|
23
24
|
this.fb = fb;
|
|
24
25
|
this.toaster = toaster;
|
|
25
26
|
this._FileApiService = _FileApiService;
|
|
26
27
|
this._LocalizationService = _LocalizationService;
|
|
28
|
+
this.confirmation = confirmation;
|
|
27
29
|
/**文件分组列表 */
|
|
28
30
|
this.fileGroupList = [];
|
|
29
31
|
/**选择的tree节点 */
|
|
@@ -34,25 +36,41 @@ export class FileModalTreeComponent {
|
|
|
34
36
|
this.anExpandedNode = [];
|
|
35
37
|
/**tree节点选择回调 */
|
|
36
38
|
this.nodeClick = new EventEmitter();
|
|
37
|
-
|
|
39
|
+
/**获取数据后回调给file-modal */
|
|
40
|
+
this.treeNodeData = new EventEmitter();
|
|
41
|
+
/**查看所有文件回调函数,在file-modal中处理逻辑 */
|
|
42
|
+
this.lookAllBtn = new EventEmitter();
|
|
43
|
+
this.handleClick = event => event.stopPropagation();
|
|
44
|
+
this.selectedNode = [];
|
|
38
45
|
/**判断节点是否选中 */
|
|
39
|
-
this.isNodeSelected =
|
|
46
|
+
this.isNodeSelected = el => {
|
|
47
|
+
return el.key === this._theSelectedTreeNode?.key;
|
|
48
|
+
};
|
|
40
49
|
/**分组 */
|
|
41
50
|
/**模态框-状态-是否打开 */
|
|
42
51
|
this.ModalDescriptorOpen = false;
|
|
43
52
|
/**模态框-descriptor-繁忙状态-用于确定模态的繁忙状态是否为真 */
|
|
44
53
|
this.ModalDescriptorBusy = false;
|
|
54
|
+
this.formValidation = '';
|
|
55
|
+
this._ValidatorsService = inject(ValidatorsService);
|
|
45
56
|
that = this;
|
|
46
57
|
}
|
|
47
58
|
set theSelectedTreeNode(v) {
|
|
48
59
|
this._theSelectedTreeNode = v;
|
|
49
|
-
if (v
|
|
60
|
+
if (v == '') {
|
|
50
61
|
this.loadData();
|
|
51
62
|
}
|
|
52
63
|
}
|
|
53
64
|
set fileContainerName(v) {
|
|
54
65
|
if (v) {
|
|
55
66
|
this._fileContainerName = v;
|
|
67
|
+
// this.loadData();
|
|
68
|
+
}
|
|
69
|
+
}
|
|
70
|
+
ngAfterContentInit() {
|
|
71
|
+
//Called after ngOnInit when the component's or directive's content has been initialized.
|
|
72
|
+
//Add 'implements AfterContentInit' to the class.
|
|
73
|
+
if (this._fileContainerName) {
|
|
56
74
|
this.loadData();
|
|
57
75
|
}
|
|
58
76
|
}
|
|
@@ -63,48 +81,70 @@ export class FileModalTreeComponent {
|
|
|
63
81
|
}
|
|
64
82
|
/**获取文件分组 */
|
|
65
83
|
getFileGroupList() {
|
|
66
|
-
this._DescriptorService
|
|
84
|
+
this._DescriptorService
|
|
85
|
+
.getList({
|
|
67
86
|
containerName: this._fileContainerName,
|
|
68
|
-
})
|
|
87
|
+
})
|
|
88
|
+
.subscribe(async (res) => {
|
|
69
89
|
this.fileGroupList = await this.setTheValueOfTheNodeRecursively(res.items);
|
|
90
|
+
this.treeNodeData.emit(this.fileGroupList);
|
|
70
91
|
});
|
|
71
92
|
}
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
93
|
+
/**查看所有文件 */
|
|
94
|
+
onLookAllBtn() {
|
|
95
|
+
this.lookAllBtn.emit();
|
|
96
|
+
}
|
|
97
|
+
/**递归-将列表转化为父子级结构 */
|
|
98
|
+
setTheValueOfTheNodeRecursively(array, parentId = null, root) {
|
|
99
|
+
let rootList = root || array;
|
|
100
|
+
let result = array.filter(item => item.parentId === parentId);
|
|
101
|
+
result.sort((a, b) => a.order - b.order);
|
|
102
|
+
result.map((el) => {
|
|
103
|
+
el.title = el.name;
|
|
104
|
+
el.key = el.id;
|
|
105
|
+
el.entity = el.id; /** 节点值 */
|
|
106
|
+
el.expanded = this.anExpandedNode.includes(el.key);
|
|
107
|
+
el.children.sort((a, b) => a.order - b.order);
|
|
108
|
+
if (el.children.length > 0) {
|
|
109
|
+
this.setTheValueOfTheNodeRecursively(el.children, el.id, rootList);
|
|
110
|
+
}
|
|
84
111
|
});
|
|
112
|
+
return result;
|
|
85
113
|
}
|
|
86
114
|
/**tree-拖拽 */
|
|
87
|
-
nzEvent(event) {
|
|
88
|
-
}
|
|
115
|
+
nzEvent(event) { }
|
|
89
116
|
/**tree-拖拽 -验证*/
|
|
90
117
|
beforeDrop(arg) {
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
118
|
+
const { pos, dragNode, node } = arg;
|
|
119
|
+
// 只处理有效的拖拽位置
|
|
120
|
+
if (pos === 0 || pos === 1 || pos === -1) {
|
|
121
|
+
// 根据不同的拖拽位置计算参数
|
|
122
|
+
const parentId = pos === 0 ? node.key : node.parentNode?.key || '';
|
|
123
|
+
let order;
|
|
124
|
+
if (pos === 1) {
|
|
125
|
+
order = node.origin.order + 1;
|
|
126
|
+
}
|
|
127
|
+
else if (pos === 0) {
|
|
128
|
+
order = node.origin.children.length + 1;
|
|
129
|
+
}
|
|
130
|
+
else {
|
|
131
|
+
// pos === -1
|
|
132
|
+
order = Math.max(0, node.origin.order - 1);
|
|
133
|
+
}
|
|
134
|
+
// 统一处理移动逻辑
|
|
135
|
+
return that._DescriptorService.move(dragNode.key, { parentId, order }).pipe(tap(() => that.getFileGroupList()), map(() => true));
|
|
102
136
|
}
|
|
137
|
+
return of(false);
|
|
103
138
|
}
|
|
104
139
|
/**tree--选择节点 */
|
|
105
|
-
activeNode(
|
|
106
|
-
|
|
107
|
-
|
|
140
|
+
activeNode(node) {
|
|
141
|
+
if (event?.target?.localName == 'i')
|
|
142
|
+
return;
|
|
143
|
+
if (this._theSelectedTreeNode?.key == node.key)
|
|
144
|
+
return;
|
|
145
|
+
this.selectedNode = [node];
|
|
146
|
+
this._theSelectedTreeNode = node;
|
|
147
|
+
this.nodeClick.emit(node);
|
|
108
148
|
}
|
|
109
149
|
/**点击展开树节点图标触发 */
|
|
110
150
|
nzExpandChange(event) {
|
|
@@ -123,23 +163,32 @@ export class FileModalTreeComponent {
|
|
|
123
163
|
this.ModalDescriptorForm = this.fb.group({
|
|
124
164
|
containerName: [this._fileContainerName || '', Validators.required],
|
|
125
165
|
name: ['', Validators.required],
|
|
126
|
-
parentId: [items?.key || ''
|
|
166
|
+
parentId: [items?.key || ''],
|
|
127
167
|
});
|
|
128
168
|
/**编辑 */
|
|
129
169
|
if (edit) {
|
|
130
170
|
this.theNodeBeingEdited = items.origin;
|
|
131
171
|
this.ModalDescriptorForm.patchValue({
|
|
132
|
-
name: items.origin.name
|
|
172
|
+
name: items.origin.name,
|
|
133
173
|
});
|
|
134
174
|
}
|
|
135
175
|
}
|
|
136
176
|
/**删除分组 */
|
|
137
177
|
deleteDescriptorBtn(node) {
|
|
138
|
-
this.
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
|
|
178
|
+
this.confirmation
|
|
179
|
+
.warn('', {
|
|
180
|
+
key: '',
|
|
181
|
+
defaultValue: this._LocalizationService.instant(`FileExplorer::DeletionConfirmationMessage`, node.title),
|
|
182
|
+
})
|
|
183
|
+
.subscribe((status) => {
|
|
184
|
+
if (status == 'confirm') {
|
|
185
|
+
this._DescriptorService.delete(node.key).subscribe(res => {
|
|
186
|
+
this.ModalDescriptorOpen = false;
|
|
187
|
+
if (this.theNodeBeingEdited.key == node.key)
|
|
188
|
+
this.theNodeBeingEdited = '';
|
|
189
|
+
this.getFileGroupList();
|
|
190
|
+
});
|
|
191
|
+
}
|
|
143
192
|
});
|
|
144
193
|
}
|
|
145
194
|
/**模态框-descriptor-状态改变回调 */
|
|
@@ -153,32 +202,56 @@ export class FileModalTreeComponent {
|
|
|
153
202
|
/**f分组模态框保存 */
|
|
154
203
|
createOrEditSave() {
|
|
155
204
|
let input = this.ModalDescriptorForm.value;
|
|
205
|
+
this.formValidation = this._ValidatorsService.getFormValidationStatus(this.ModalDescriptorForm);
|
|
206
|
+
if (this._ValidatorsService.isCheckForm(this.formValidation, 'FileExplorer'))
|
|
207
|
+
return;
|
|
208
|
+
if (!this.ModalDescriptorForm.valid)
|
|
209
|
+
return;
|
|
210
|
+
if (this.ModalDescriptorBusy)
|
|
211
|
+
return;
|
|
212
|
+
this.ModalDescriptorBusy = true;
|
|
156
213
|
if (this.theNodeBeingEdited) {
|
|
157
|
-
this._DescriptorService
|
|
214
|
+
this._DescriptorService
|
|
215
|
+
.update(this.theNodeBeingEdited.key, input)
|
|
216
|
+
.pipe(finalize(() => {
|
|
217
|
+
this.ModalDescriptorBusy = false;
|
|
218
|
+
}))
|
|
219
|
+
.subscribe(res => {
|
|
158
220
|
this.ModalDescriptorOpen = false;
|
|
221
|
+
this.ModalDescriptorVisibleChange(false);
|
|
159
222
|
this.getFileGroupList();
|
|
160
223
|
});
|
|
161
224
|
return;
|
|
162
225
|
}
|
|
163
|
-
this._DescriptorService
|
|
226
|
+
this._DescriptorService
|
|
227
|
+
.create(input)
|
|
228
|
+
.pipe(finalize(() => {
|
|
229
|
+
this.ModalDescriptorBusy = false;
|
|
230
|
+
}))
|
|
231
|
+
.subscribe(res => {
|
|
164
232
|
this.ModalDescriptorOpen = false;
|
|
233
|
+
this.ModalDescriptorVisibleChange(false);
|
|
165
234
|
this.getFileGroupList();
|
|
166
235
|
});
|
|
167
236
|
}
|
|
168
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.5", ngImport: i0, type: FileModalTreeComponent, deps: [{ token: i1.FileDescriptorService }, { token: i2.FormBuilder }, { token: i3.ToasterService }, { token: i4.FileApiService }, { token: i5.LocalizationService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
169
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "
|
|
237
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.5", ngImport: i0, type: FileModalTreeComponent, deps: [{ token: i1.FileDescriptorService }, { token: i2.FormBuilder }, { token: i3.ToasterService }, { token: i4.FileApiService }, { token: i5.LocalizationService }, { token: i3.ConfirmationService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
238
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.1.5", type: FileModalTreeComponent, selector: "fe-file-modal-tree", inputs: { theSelectedTreeNode: "theSelectedTreeNode", fileContainerName: "fileContainerName" }, outputs: { nodeClick: "nodeClick", treeNodeData: "treeNodeData", lookAllBtn: "lookAllBtn" }, viewQueries: [{ propertyName: "ModalFormDescriptorSubmit", first: true, predicate: ["ModalFormDescriptorSubmit"], descendants: true }], ngImport: i0, template: "<div class=\"card-header p-0 mb-1 d-flex justify-content-between align-items-center\">\n <h6 class=\"h6 mb-0 btn-link\" role=\"button\" (click.stop)=\"onLookAllBtn()\">{{'FileExplorer::MyDirectories' | abpLocalization}}</h6>\n <button type=\"button\" class=\"btn btn-light btn-sm ms-2\" (click.stop)=\"addDescriptorBtn()\"><i\n class=\"fas fa-plus-circle\" aria-hidden=\"true\"></i></button>\n</div>\n@if(fileGroupList.length>0){\n<abp-tree [nodes]=\"fileGroupList\" (nzExpandChange)=\"nzExpandChange($event)\" [draggable]=\"true\"\n (dropOver)=\"nzEvent($event)\" [beforeDrop]=\"beforeDrop\" (selectedNodeChange)=\"activeNode($event)\" [changeCheckboxWithNode]=\"true\" [isNodeSelected]=\"isNodeSelected\">\n\n <ng-template #menu let-node>\n <button ngbDropdownItem (click.stop)=\"addDescriptorBtn(node)\"><i\n class=\" me-1 fa fa-pencil\"></i>{{'FileExplorer::NewDirectory' | abpLocalization}}</button>\n <button ngbDropdownItem (click.stop)=\"addDescriptorBtn(node,true)\"><i\n class=\" me-1 fa fa-plus\"></i>{{'AbpUi::Edit' | abpLocalization}}</button>\n <button ngbDropdownItem (click.stop)=\"deleteDescriptorBtn(node)\"><i\n class=\" me-1 fa fa-remove\"></i>{{'AbpUi::Delete' | abpLocalization}}</button>\n </ng-template>\n\n <ng-template abpTreeExpandedIconTemplate let-node let-origin=\"origin\">\n <i aria-hidden=\"true\" *ngIf=\"node.children.length>0\">\n <ng-container *ngTemplateOutlet=\"node.isExpanded ? minusIcon : plusIcon\"></ng-container></i>\n </ng-template>\n\n <ng-template #minusIcon>\n <svg width=\"15\" height=\"15\" viewBox=\"0 0 24 24\" xmlns=\"http://www.w3.org/2000/svg\" fill-rule=\"evenodd\"\n clip-rule=\"evenodd\">\n <path\n d=\"M11.5 0c6.347 0 11.5 5.153 11.5 11.5s-5.153 11.5-11.5 11.5-11.5-5.153-11.5-11.5 5.153-11.5 11.5-11.5zm0 1c5.795 0 10.5 4.705 10.5 10.5s-4.705 10.5-10.5 10.5-10.5-4.705-10.5-10.5 4.705-10.5 10.5-10.5zm-6.5 10h13v1h-13v-1z\" />\n </svg>\n </ng-template>\n\n <ng-template #plusIcon>\n <svg width=\"15\" height=\"15\" viewBox=\"0 0 24 24\" xmlns=\"http://www.w3.org/2000/svg\" fill-rule=\"evenodd\"\n clip-rule=\"evenodd\">\n <path\n d=\"M11.5 0c6.347 0 11.5 5.153 11.5 11.5s-5.153 11.5-11.5 11.5-11.5-5.153-11.5-11.5 5.153-11.5 11.5-11.5zm0 1c5.795 0 10.5 4.705 10.5 10.5s-4.705 10.5-10.5 10.5-10.5-4.705-10.5-10.5 4.705-10.5 10.5-10.5zm.5 10h6v1h-6v6h-1v-6h-6v-1h6v-6h1v6z\" />\n </svg>\n </ng-template>\n</abp-tree>\n\n}\n<abp-modal [(visible)]=\"ModalDescriptorOpen\" [busy]=\"ModalDescriptorBusy\"\n (visibleChange)=\"ModalDescriptorVisibleChange($event)\">\n <ng-template #abpHeader>\n <h3>{{theNodeBeingEdited?('AbpUi::Edit' | abpLocalization):('FileExplorer::NewDirectory' | abpLocalization)}}\n </h3>\n </ng-template>\n <ng-template #abpBody>\n <ng-template #loaderRef>\n <div class=\"text-center\"><i class=\"fa fa-pulse fa-spinner\" aria-hidden=\"true\"></i></div>\n </ng-template>\n <ng-container *ngIf=\"ModalDescriptorForm; else loaderRef\">\n <form class=\"sites-modal-form\" #myForm=\"ngForm\" [formGroup]=\"ModalDescriptorForm\"\n (keydown.enter)=\"$event.preventDefault()\" (submit)=\"createOrEditSave()\">\n <button type=\"submit\" #ModalFormDescriptorSubmit style=\"display: none\"></button>\n <div class=\"mb-3\">\n <label class=\"form-label\">{{'FileExplorer::DirectoryName' | abpLocalization}}</label>\n <input type=\"email\" class=\"form-control\" formControlName=\"name\">\n </div>\n </form>\n </ng-container>\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\" [loading]=\"ModalDescriptorBusy\"\n (click)=\"ModalFormDescriptorSubmit.nativeElement.click()\">{{'AbpUi::Save' | abpLocalization}}</abp-button>\n </ng-template>\n</abp-modal>", styles: [""], dependencies: [{ kind: "directive", type: i2.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i2.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: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i6.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i6.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i2.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i2.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "directive", type: i5.StopPropagationDirective, selector: "[click.stop]", outputs: ["click.stop"] }, { kind: "directive", type: i7.ValidationGroupDirective, selector: "[formGroup],[formGroupName]", exportAs: ["validationGroup"] }, { kind: "directive", type: i7.ValidationDirective, selector: "[formControl],[formControlName]", exportAs: ["validationDirective"] }, { kind: "component", type: i3.ButtonComponent, selector: "abp-button", inputs: ["buttonId", "buttonClass", "buttonType", "formName", "iconClass", "loading", "disabled", "attributes"], outputs: ["click", "focus", "blur", "abpClick", "abpFocus", "abpBlur"] }, { kind: "component", type: i3.ModalComponent, selector: "abp-modal", inputs: ["visible", "busy", "options", "suppressUnsavedChangesWarning"], outputs: ["visibleChange", "init", "appear", "disappear"] }, { kind: "directive", type: i3.ModalCloseDirective, selector: "[abpClose]" }, { kind: "directive", type: i8.NgbDropdownItem, selector: "[ngbDropdownItem]", inputs: ["tabindex", "disabled"] }, { kind: "directive", type: i8.NgbDropdownButtonItem, selector: "button[ngbDropdownItem]" }, { kind: "directive", type: i9.ExpandedIconTemplateDirective, selector: "[abpTreeExpandedIconTemplate],[abp-tree-expanded-icon-template]" }, { kind: "component", type: i9.TreeComponent, selector: "abp-tree", inputs: ["noAnimation", "draggable", "checkable", "checkStrictly", "checkedKeys", "nodes", "expandedKeys", "selectedNode", "changeCheckboxWithNode", "isNodeSelected", "beforeDrop"], outputs: ["checkedKeysChange", "expandedKeysChange", "selectedNodeChange", "dropOver", "nzExpandChange"] }, { kind: "pipe", type: i5.LocalizationPipe, name: "abpLocalization" }] }); }
|
|
170
239
|
}
|
|
171
240
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.5", ngImport: i0, type: FileModalTreeComponent, decorators: [{
|
|
172
241
|
type: Component,
|
|
173
|
-
args: [{ selector: 'fe-file-modal-tree', template: "<div class=\"card-header p-0 mb-1 d-flex justify-content-between align-items-center\">\n <h6 class=\"h6 mb-0\">{{'FileExplorer::MyDirectories' | abpLocalization}}</h6>\n <button type=\"button\" class=\"btn btn-light btn-sm ms-2\" (click.stop)=\"addDescriptorBtn()\"><i\n class=\"fas fa-plus-circle\" aria-hidden=\"true\"></i></button>\n</div>\n<
|
|
174
|
-
}], ctorParameters: () => [{ type: i1.FileDescriptorService }, { type: i2.FormBuilder }, { type: i3.ToasterService }, { type: i4.FileApiService }, { type: i5.LocalizationService }], propDecorators: { theSelectedTreeNode: [{
|
|
242
|
+
args: [{ selector: 'fe-file-modal-tree', template: "<div class=\"card-header p-0 mb-1 d-flex justify-content-between align-items-center\">\n <h6 class=\"h6 mb-0 btn-link\" role=\"button\" (click.stop)=\"onLookAllBtn()\">{{'FileExplorer::MyDirectories' | abpLocalization}}</h6>\n <button type=\"button\" class=\"btn btn-light btn-sm ms-2\" (click.stop)=\"addDescriptorBtn()\"><i\n class=\"fas fa-plus-circle\" aria-hidden=\"true\"></i></button>\n</div>\n@if(fileGroupList.length>0){\n<abp-tree [nodes]=\"fileGroupList\" (nzExpandChange)=\"nzExpandChange($event)\" [draggable]=\"true\"\n (dropOver)=\"nzEvent($event)\" [beforeDrop]=\"beforeDrop\" (selectedNodeChange)=\"activeNode($event)\" [changeCheckboxWithNode]=\"true\" [isNodeSelected]=\"isNodeSelected\">\n\n <ng-template #menu let-node>\n <button ngbDropdownItem (click.stop)=\"addDescriptorBtn(node)\"><i\n class=\" me-1 fa fa-pencil\"></i>{{'FileExplorer::NewDirectory' | abpLocalization}}</button>\n <button ngbDropdownItem (click.stop)=\"addDescriptorBtn(node,true)\"><i\n class=\" me-1 fa fa-plus\"></i>{{'AbpUi::Edit' | abpLocalization}}</button>\n <button ngbDropdownItem (click.stop)=\"deleteDescriptorBtn(node)\"><i\n class=\" me-1 fa fa-remove\"></i>{{'AbpUi::Delete' | abpLocalization}}</button>\n </ng-template>\n\n <ng-template abpTreeExpandedIconTemplate let-node let-origin=\"origin\">\n <i aria-hidden=\"true\" *ngIf=\"node.children.length>0\">\n <ng-container *ngTemplateOutlet=\"node.isExpanded ? minusIcon : plusIcon\"></ng-container></i>\n </ng-template>\n\n <ng-template #minusIcon>\n <svg width=\"15\" height=\"15\" viewBox=\"0 0 24 24\" xmlns=\"http://www.w3.org/2000/svg\" fill-rule=\"evenodd\"\n clip-rule=\"evenodd\">\n <path\n d=\"M11.5 0c6.347 0 11.5 5.153 11.5 11.5s-5.153 11.5-11.5 11.5-11.5-5.153-11.5-11.5 5.153-11.5 11.5-11.5zm0 1c5.795 0 10.5 4.705 10.5 10.5s-4.705 10.5-10.5 10.5-10.5-4.705-10.5-10.5 4.705-10.5 10.5-10.5zm-6.5 10h13v1h-13v-1z\" />\n </svg>\n </ng-template>\n\n <ng-template #plusIcon>\n <svg width=\"15\" height=\"15\" viewBox=\"0 0 24 24\" xmlns=\"http://www.w3.org/2000/svg\" fill-rule=\"evenodd\"\n clip-rule=\"evenodd\">\n <path\n d=\"M11.5 0c6.347 0 11.5 5.153 11.5 11.5s-5.153 11.5-11.5 11.5-11.5-5.153-11.5-11.5 5.153-11.5 11.5-11.5zm0 1c5.795 0 10.5 4.705 10.5 10.5s-4.705 10.5-10.5 10.5-10.5-4.705-10.5-10.5 4.705-10.5 10.5-10.5zm.5 10h6v1h-6v6h-1v-6h-6v-1h6v-6h1v6z\" />\n </svg>\n </ng-template>\n</abp-tree>\n\n}\n<abp-modal [(visible)]=\"ModalDescriptorOpen\" [busy]=\"ModalDescriptorBusy\"\n (visibleChange)=\"ModalDescriptorVisibleChange($event)\">\n <ng-template #abpHeader>\n <h3>{{theNodeBeingEdited?('AbpUi::Edit' | abpLocalization):('FileExplorer::NewDirectory' | abpLocalization)}}\n </h3>\n </ng-template>\n <ng-template #abpBody>\n <ng-template #loaderRef>\n <div class=\"text-center\"><i class=\"fa fa-pulse fa-spinner\" aria-hidden=\"true\"></i></div>\n </ng-template>\n <ng-container *ngIf=\"ModalDescriptorForm; else loaderRef\">\n <form class=\"sites-modal-form\" #myForm=\"ngForm\" [formGroup]=\"ModalDescriptorForm\"\n (keydown.enter)=\"$event.preventDefault()\" (submit)=\"createOrEditSave()\">\n <button type=\"submit\" #ModalFormDescriptorSubmit style=\"display: none\"></button>\n <div class=\"mb-3\">\n <label class=\"form-label\">{{'FileExplorer::DirectoryName' | abpLocalization}}</label>\n <input type=\"email\" class=\"form-control\" formControlName=\"name\">\n </div>\n </form>\n </ng-container>\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\" [loading]=\"ModalDescriptorBusy\"\n (click)=\"ModalFormDescriptorSubmit.nativeElement.click()\">{{'AbpUi::Save' | abpLocalization}}</abp-button>\n </ng-template>\n</abp-modal>" }]
|
|
243
|
+
}], ctorParameters: () => [{ type: i1.FileDescriptorService }, { type: i2.FormBuilder }, { type: i3.ToasterService }, { type: i4.FileApiService }, { type: i5.LocalizationService }, { type: i3.ConfirmationService }], propDecorators: { theSelectedTreeNode: [{
|
|
175
244
|
type: Input
|
|
176
245
|
}], nodeClick: [{
|
|
177
246
|
type: Output
|
|
247
|
+
}], treeNodeData: [{
|
|
248
|
+
type: Output
|
|
249
|
+
}], lookAllBtn: [{
|
|
250
|
+
type: Output
|
|
178
251
|
}], fileContainerName: [{
|
|
179
252
|
type: Input
|
|
180
253
|
}], ModalFormDescriptorSubmit: [{
|
|
181
254
|
type: ViewChild,
|
|
182
255
|
args: ['ModalFormDescriptorSubmit', { static: false }]
|
|
183
256
|
}] } });
|
|
184
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"file-modal-tree.component.js","sourceRoot":"","sources":["../../../../../../../packages/file-explorer/src/lib/components/file-modal-tree/file-modal-tree.component.ts","../../../../../../../packages/file-explorer/src/lib/components/file-modal-tree/file-modal-tree.component.html"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable @angular-eslint/component-selector */\nimport { Component, ElementRef, EventEmitter, Input, Output, ViewChild, ViewContainerRef } from '@angular/core';\nimport { FormBuilder, FormGroup, Validators } from '@angular/forms';\nimport { NzFormatEmitEvent } from 'ng-zorro-antd/tree';\nimport * as DescriptorService from '../../proxy/dignite/file-explorer/directories';\nimport {  ToasterService } from '@abp/ng.theme.shared';\nimport { NzFormatBeforeDropEvent } from 'ng-zorro-antd/tree';\nimport {  of } from 'rxjs';\nimport { FileApiService } from '../../services/file-api.service';\nimport { LocalizationService } from '@abp/ng.core';\nvar that;\n@Component({\n  selector: 'fe-file-modal-tree',\n  templateUrl: './file-modal-tree.component.html',\n  styleUrls: ['./file-modal-tree.component.scss']\n})\nexport class FileModalTreeComponent {\n  constructor(\n    private _DescriptorService: DescriptorService.FileDescriptorService,\n    private fb: FormBuilder,\n    private toaster: ToasterService,\n    public _FileApiService: FileApiService,\n    public _LocalizationService: LocalizationService,\n  ) {\n    that = this\n  }\n\n  /**文件分组列表 */\n  fileGroupList: any[] = [];\n\n  /**选择的tree节点 */\n  _theSelectedTreeNode: any = '';\n  @Input()\n  public set theSelectedTreeNode(v: any) {\n    this._theSelectedTreeNode = v;\n    if (v.length > 0) {\n      this.loadData()\n    }\n  }\n\n  /**正在编辑的节点 */\n  theNodeBeingEdited: any = '';\n\n  /**已展开的节点 */\n  anExpandedNode: any[] = [];\n\n  /**图片容器 */\n  _fileContainerName: string;\n\n  /**tree节点选择回调 */\n  @Output() nodeClick = new EventEmitter();\n\n\n  @Input()\n  public set fileContainerName(v: string) {\n    if (v) {\n      this._fileContainerName = v;\n      this.loadData()\n    }\n  }\n\n  handleClick = (event) => event.stopPropagation();\n\n  loadData() {\n    if (this._fileContainerName) {\n      this.getFileGroupList()\n    }\n  }\n\n\n  /**获取文件分组 */\n  getFileGroupList() {\n    this._DescriptorService.getList({\n      containerName: this._fileContainerName,\n    }).subscribe(async (res) => {\n      this.fileGroupList = await this.setTheValueOfTheNodeRecursively(res.items)\n    })\n  }\n  \n  /**递归设置节点的值 */\n  setTheValueOfTheNodeRecursively(array: any[]): any {\n    return new Promise((reslove, rejects) => {\n      array.forEach((el) => {\n        el.title = el.name\n        el.key = el.id\n        el.expanded = this.anExpandedNode.includes(el.key)\n        if (el.children.length > 0) {\n          this.setTheValueOfTheNodeRecursively(el.children)\n        }\n      })\n      reslove(array)\n    })\n  }\n\n  /**tree-拖拽 */\n  nzEvent(event: NzFormatEmitEvent): void {\n  }\n\n  /**tree-拖拽 -验证*/\n  beforeDrop(arg: NzFormatBeforeDropEvent) {\n    if (arg.pos === 0 || arg.pos === 1) {\n      that._DescriptorService.move(arg.dragNode.key, {\n        \"parentId\": arg.pos === 1 ? (arg.node.parentNode?.key||'') : arg.node.key,\n        \"order\": arg.pos === 1 ? arg.node.origin.order + 1 : arg.node.origin.children.length + 1\n      }).subscribe(res => {\n        that.getFileGroupList()\n      })\n      return of(true)\n    } else {\n      return of(false);\n    }\n  }\n\n  /**tree--选择节点 */\n  activeNode(event) {\n    this._theSelectedTreeNode = event.node\n    this.nodeClick.emit(event.node)\n  }\n\n  /**判断节点是否选中 */\n  isNodeSelected = (el) => el.key === this._theSelectedTreeNode?.key\n\n  /**点击展开树节点图标触发 */\n  nzExpandChange(event) {\n    let anExpandedNode = this.anExpandedNode\n    if (anExpandedNode.includes(event.node.key)) {\n      anExpandedNode = anExpandedNode.filter(key => key !== event.node.key)\n    } else {\n      anExpandedNode.push(event.node.key)\n    }\n    this.anExpandedNode = anExpandedNode\n  }\n\n\n  /**增加分组 */\n  addDescriptorBtn(items: any = '', edit = false) {\n    this.ModalDescriptorOpen = true\n    this.ModalDescriptorForm = this.fb.group({\n      containerName: [this._fileContainerName || '', Validators.required],\n      name: ['', Validators.required],\n      parentId: [items?.key || '', Validators.required],\n    })\n    /**编辑 */\n    if (edit) {\n      this.theNodeBeingEdited = items.origin\n      this.ModalDescriptorForm.patchValue({\n        name: items.origin.name\n      })\n    }\n  }\n\n  /**删除分组 */\n  deleteDescriptorBtn(node) {\n    this._DescriptorService.delete(node.key).subscribe(res => {\n      this.ModalDescriptorOpen = false\n      if (this.theNodeBeingEdited.key == node.key) this.theNodeBeingEdited = ''\n      this.getFileGroupList()\n    })\n  }\n\n  \n\n  /**分组 */\n  /**模态框-状态-是否打开 */\n  ModalDescriptorOpen: boolean = false\n\n  /**模态框-descriptor-繁忙状态-用于确定模态的繁忙状态是否为真 */\n  ModalDescriptorBusy: boolean = false\n\n  /**模态框-descriptor-表单 */\n  ModalDescriptorForm: FormGroup | undefined;\n  \n  /**模态框-descriptor-表单--控件模板-动态赋值表单控件 */\n  @ViewChild('ModalFormDescriptorSubmit', { static: false }) ModalFormDescriptorSubmit: ElementRef;\n\n  /**模态框-descriptor-状态改变回调 */\n  ModalDescriptorVisibleChange(event) {\n    if (!event) {\n      this.ModalDescriptorForm = undefined\n      this.theNodeBeingEdited = ''\n      return\n    }\n  }\n\n  /**f分组模态框保存 */\n  createOrEditSave() {\n    let input = this.ModalDescriptorForm.value\n    if (this.theNodeBeingEdited) {\n      this._DescriptorService.update(this.theNodeBeingEdited.key, input).subscribe(res => {\n        this.ModalDescriptorOpen = false\n        this.getFileGroupList()\n      })\n      return\n    }\n    this._DescriptorService.create(input).subscribe(res => {\n      this.ModalDescriptorOpen = false\n      this.getFileGroupList()\n    })\n  }\n\n\n\n\n}\n","<div class=\"card-header  p-0 mb-1 d-flex justify-content-between align-items-center\">\n    <h6 class=\"h6 mb-0\">{{'FileExplorer::MyDirectories' | abpLocalization}}</h6>\n    <button type=\"button\" class=\"btn btn-light btn-sm ms-2\" (click.stop)=\"addDescriptorBtn()\"><i\n            class=\"fas fa-plus-circle\" aria-hidden=\"true\"></i></button>\n</div>\n<nz-tree [nzData]=\"fileGroupList\" class=\"ng-zorro-antd-tree\" nzDraggable nzBlockNode nzShowIcon\n    [nzExpandedIcon]=\"multiExpandedIconTpl\" (nzOnDrop)=\"nzEvent($event)\" [nzBeforeDrop]=\"beforeDrop\"\n    (nzClick)=\"activeNode($event)\" (nzExpandChange)=\"nzExpandChange($event)\" [nzTreeTemplate]=\"nzTreeTemplate\">\n    <ng-template #nzTreeTemplate let-node let-origin=\"origin\">\n        <div class=\"custom-node d-inline-block   ng-star-inserted dropdown\" [title]=\"node.title\">\n            <div #dropdown=\"ngbDropdown\" class=\"d-inline-block\" ngbDropdown placement=\"bottom\" container=\"body\">\n                <div class=\"btn-group\" [class.selected]=\"isNodeSelected(node)\">\n                    <button class=\"btn btn-sm  p-0 px-1\">{{ node.title }}</button>\n                    <button class=\"btn btn-sm  p-0\" (click)=\"handleClick($event)\" ngbDropdownToggle\n                        [class.dropdown-toggle]=\"false\" aria-hidden=\"true\">\n                        <i class=\"fas fa-caret-down text-muted p-1\"></i>\n                    </button>\n                </div>\n                <div ngbDropdownMenu>\n                    <button ngbDropdownItem\n                        (click.stop)=\"addDescriptorBtn(node)\">{{'FileExplorer::NewDirectory' | abpLocalization}}</button>\n                    <button ngbDropdownItem\n                        (click.stop)=\"addDescriptorBtn(node,true)\">{{'AbpUi::Edit' | abpLocalization}}</button>\n                    <button ngbDropdownItem\n                        (click.stop)=\"deleteDescriptorBtn(node)\">{{'AbpUi::Delete' | abpLocalization}}</button>\n                </div>\n            </div>\n        </div>\n    </ng-template>\n    <ng-template #multiExpandedIconTpl let-node let-origin=\"origin\">\n        <ng-container *ngIf=\"node.children.length > 0\">\n            <i [class]=\"node.isExpanded ? 'fas fa-caret-down' : 'fas fa-caret-right'\"></i>\n        </ng-container>\n    </ng-template>\n</nz-tree>\n\n\n<abp-modal [(visible)]=\"ModalDescriptorOpen\" [busy]=\"ModalDescriptorBusy\"\n    (visibleChange)=\"ModalDescriptorVisibleChange($event)\">\n    <ng-template #abpHeader>\n        <h3>{{theNodeBeingEdited?('AbpUi::Edit' | abpLocalization):('FileExplorer::NewDirectory' | abpLocalization)}}</h3>\n    </ng-template>\n    <ng-template #abpBody>\n        <ng-template #loaderRef>\n            <div class=\"text-center\"><i class=\"fa fa-pulse fa-spinner\" aria-hidden=\"true\"></i></div>\n        </ng-template>\n        <ng-container *ngIf=\"ModalDescriptorForm; else loaderRef\">\n            <form class=\"sites-modal-form\" #myForm=\"ngForm\" [formGroup]=\"ModalDescriptorForm\"\n                (keydown.enter)=\"$event.preventDefault()\" (submit)=\"createOrEditSave()\">\n                <button type=\"submit\" #ModalFormDescriptorSubmit style=\"display: none\"></button>\n                <div class=\"mb-3\">\n                    <label class=\"form-label\">{{'FileExplorer::DirectoryName' | abpLocalization}}</label>\n                    <input type=\"email\" class=\"form-control\" formControlName=\"name\">\n                </div>\n            </form>\n        </ng-container>\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\"\n            (click)=\"ModalFormDescriptorSubmit.nativeElement.click()\">{{'AbpUi::Save' | abpLocalization}}</abp-button>\n    </ng-template>\n</abp-modal>"]}
|
|
257
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"file-modal-tree.component.js","sourceRoot":"","sources":["../../../../../../../packages/file-explorer/src/lib/components/file-modal-tree/file-modal-tree.component.ts","../../../../../../../packages/file-explorer/src/lib/components/file-modal-tree/file-modal-tree.component.html"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable @angular-eslint/component-selector */\nimport {\n  AfterContentInit,\n  Component,\n  ElementRef,\n  EventEmitter,\n  inject,\n  Input,\n  Output,\n  ViewChild,\n} from '@angular/core';\nimport { FormBuilder, FormGroup, Validators } from '@angular/forms';\nimport { NzFormatEmitEvent, NzTreeNode } from 'ng-zorro-antd/tree';\nimport * as DescriptorService from '../../proxy/dignite/file-explorer/directories';\nimport { Confirmation, ConfirmationService, ToasterService } from '@abp/ng.theme.shared';\nimport { NzFormatBeforeDropEvent } from 'ng-zorro-antd/tree';\nimport { finalize, map, of, tap } from 'rxjs';\nimport { FileApiService } from '../../services/file-api.service';\nimport { LocalizationService } from '@abp/ng.core';\nimport { ValidatorsService } from '@dignite-ng/expand.core';\nvar that;\n@Component({\n  selector: 'fe-file-modal-tree',\n  templateUrl: './file-modal-tree.component.html',\n  styleUrls: ['./file-modal-tree.component.scss'],\n})\nexport class FileModalTreeComponent implements AfterContentInit {\n  constructor(\n    private _DescriptorService: DescriptorService.FileDescriptorService,\n    private fb: FormBuilder,\n    private toaster: ToasterService,\n    public _FileApiService: FileApiService,\n    public _LocalizationService: LocalizationService,\n    private confirmation: ConfirmationService,\n  ) {\n    that = this;\n  }\n\n  /**文件分组列表 */\n  fileGroupList: any[] = [];\n\n  /**选择的tree节点 */\n  _theSelectedTreeNode: any = '';\n  @Input()\n  public set theSelectedTreeNode(v: any) {\n    this._theSelectedTreeNode = v;\n\n    if (v == '') {\n      this.loadData();\n    }\n  }\n\n  /**正在编辑的节点 */\n  theNodeBeingEdited: any = '';\n\n  /**已展开的节点 */\n  anExpandedNode: any[] = [];\n\n  /**图片容器 */\n  _fileContainerName: string;\n\n  /**tree节点选择回调 */\n  @Output() nodeClick = new EventEmitter();\n  /**获取数据后回调给file-modal */\n  @Output() treeNodeData = new EventEmitter();\n  /**查看所有文件回调函数，在file-modal中处理逻辑 */\n  @Output() lookAllBtn = new EventEmitter();\n\n  @Input()\n  public set fileContainerName(v: string) {\n    if (v) {\n      this._fileContainerName = v;\n      // this.loadData();\n    }\n  }\n  ngAfterContentInit(): void {\n    //Called after ngOnInit when the component's or directive's content has been initialized.\n    //Add 'implements AfterContentInit' to the class.\n    if (this._fileContainerName) {\n      this.loadData();\n    }\n  }\n\n  handleClick = event => event.stopPropagation();\n\n  loadData() {\n    if (this._fileContainerName) {\n      this.getFileGroupList();\n    }\n  }\n\n  /**获取文件分组 */\n  getFileGroupList() {\n    this._DescriptorService\n      .getList({\n        containerName: this._fileContainerName,\n      })\n      .subscribe(async res => {\n        this.fileGroupList = await this.setTheValueOfTheNodeRecursively(res.items);\n        this.treeNodeData.emit(this.fileGroupList);\n      });\n  }\n\n  /**查看所有文件 */\n  onLookAllBtn() {\n    this.lookAllBtn.emit();\n  }\n\n  /**递归-将列表转化为父子级结构 */\n  setTheValueOfTheNodeRecursively(array: any[], parentId: any = null, root?: any[]): any {\n    let rootList = root || array;\n    let result = array.filter(item => item.parentId === parentId);\n    result.sort((a, b) => a.order - b.order);\n    result.map((el: any) => {\n      el.title = el.name;\n      el.key = el.id;\n      el.entity = el.id; /** 节点值 */\n      el.expanded = this.anExpandedNode.includes(el.key);\n      el.children.sort((a, b) => a.order - b.order);\n      if (el.children.length > 0) {\n        this.setTheValueOfTheNodeRecursively(el.children, el.id, rootList);\n      }\n    });\n    return result;\n  }\n\n  /**tree-拖拽 */\n  nzEvent(event: NzFormatEmitEvent): void {}\n\n  /**tree-拖拽 -验证*/\n  beforeDrop(arg: NzFormatBeforeDropEvent) {\n    const { pos, dragNode, node } = arg;\n    // 只处理有效的拖拽位置\n    if (pos === 0 || pos === 1 || pos === -1) {\n      // 根据不同的拖拽位置计算参数\n      const parentId = pos === 0 ? node.key : node.parentNode?.key || '';\n\n      let order;\n      if (pos === 1) {\n        order = node.origin.order + 1;\n      } else if (pos === 0) {\n        order = node.origin.children.length + 1;\n      } else {\n        // pos === -1\n        order = Math.max(0, node.origin.order - 1);\n      }\n      // 统一处理移动逻辑\n      return that._DescriptorService.move(dragNode.key, { parentId, order }).pipe(\n        tap(() => that.getFileGroupList()),\n        map(() => true)\n      );\n    }\n\n    return of(false);\n  }\n\n  selectedNode: NzTreeNode[] = [];\n  /**tree--选择节点 */\n  activeNode(node: NzTreeNode) {\n    if ((event as any)?.target?.localName == 'i') return;\n    if (this._theSelectedTreeNode?.key == node.key) return;\n    this.selectedNode = [node];\n    this._theSelectedTreeNode = node;\n    this.nodeClick.emit(node);\n  }\n\n  /**判断节点是否选中 */\n  isNodeSelected = el => {\n    return el.key === this._theSelectedTreeNode?.key;\n  };\n\n  /**点击展开树节点图标触发 */\n  nzExpandChange(event) {\n    let anExpandedNode = this.anExpandedNode;\n    if (anExpandedNode.includes(event.node.key)) {\n      anExpandedNode = anExpandedNode.filter(key => key !== event.node.key);\n    } else {\n      anExpandedNode.push(event.node.key);\n    }\n    this.anExpandedNode = anExpandedNode;\n  }\n\n  /**增加分组 */\n  addDescriptorBtn(items: any = '', edit = false) {\n    this.ModalDescriptorOpen = true;\n    this.ModalDescriptorForm = this.fb.group({\n      containerName: [this._fileContainerName || '', Validators.required],\n      name: ['', Validators.required],\n      parentId: [items?.key || ''],\n    });\n    /**编辑 */\n    if (edit) {\n      this.theNodeBeingEdited = items.origin;\n      this.ModalDescriptorForm.patchValue({\n        name: items.origin.name,\n      });\n    }\n  }\n\n  /**删除分组 */\n  deleteDescriptorBtn(node) {\n    this.confirmation\n      .warn('', {\n        key: '',\n        defaultValue: this._LocalizationService.instant(`FileExplorer::DeletionConfirmationMessage`,node.title),\n      })\n      .subscribe((status: Confirmation.Status) => {\n        if (status == 'confirm') {\n          this._DescriptorService.delete(node.key).subscribe(res => {\n            this.ModalDescriptorOpen = false;\n            if (this.theNodeBeingEdited.key == node.key) this.theNodeBeingEdited = '';\n            this.getFileGroupList();\n          });\n        }\n      });\n  }\n\n  /**分组 */\n  /**模态框-状态-是否打开 */\n  ModalDescriptorOpen: boolean = false;\n\n  /**模态框-descriptor-繁忙状态-用于确定模态的繁忙状态是否为真 */\n  ModalDescriptorBusy: boolean = false;\n\n  /**模态框-descriptor-表单 */\n  ModalDescriptorForm: FormGroup | undefined;\n\n  /**模态框-descriptor-表单--控件模板-动态赋值表单控件 */\n  @ViewChild('ModalFormDescriptorSubmit', { static: false }) ModalFormDescriptorSubmit: ElementRef;\n\n  /**模态框-descriptor-状态改变回调 */\n  ModalDescriptorVisibleChange(event) {\n    if (!event) {\n      this.ModalDescriptorForm = undefined;\n      this.theNodeBeingEdited = '';\n      return;\n    }\n  }\n  formValidation: any = '';\n  private _ValidatorsService = inject(ValidatorsService);\n  /**f分组模态框保存 */\n  createOrEditSave() {\n    let input = this.ModalDescriptorForm.value;\n    this.formValidation = this._ValidatorsService.getFormValidationStatus(this.ModalDescriptorForm);\n    if (this._ValidatorsService.isCheckForm(this.formValidation, 'FileExplorer')) return;\n    if (!this.ModalDescriptorForm.valid) return;\n    if (this.ModalDescriptorBusy) return;\n    this.ModalDescriptorBusy = true;\n\n    if (this.theNodeBeingEdited) {\n      this._DescriptorService\n        .update(this.theNodeBeingEdited.key, input)\n        .pipe(\n          finalize(() => {\n            this.ModalDescriptorBusy = false;\n          })\n        )\n        .subscribe(res => {\n          this.ModalDescriptorOpen = false;\n          this.ModalDescriptorVisibleChange(false);\n          this.getFileGroupList();\n        });\n      return;\n    }\n    this._DescriptorService\n      .create(input)\n      .pipe(\n        finalize(() => {\n          this.ModalDescriptorBusy = false;\n        })\n      )\n      .subscribe(res => {\n        this.ModalDescriptorOpen = false;\n        this.ModalDescriptorVisibleChange(false);\n        this.getFileGroupList();\n      });\n  }\n}\n","<div class=\"card-header  p-0 mb-1 d-flex justify-content-between align-items-center\">\n    <h6 class=\"h6 mb-0 btn-link\" role=\"button\" (click.stop)=\"onLookAllBtn()\">{{'FileExplorer::MyDirectories' | abpLocalization}}</h6>\n    <button type=\"button\" class=\"btn btn-light btn-sm ms-2\" (click.stop)=\"addDescriptorBtn()\"><i\n            class=\"fas fa-plus-circle\" aria-hidden=\"true\"></i></button>\n</div>\n@if(fileGroupList.length>0){\n<abp-tree [nodes]=\"fileGroupList\" (nzExpandChange)=\"nzExpandChange($event)\" [draggable]=\"true\"\n    (dropOver)=\"nzEvent($event)\" [beforeDrop]=\"beforeDrop\" (selectedNodeChange)=\"activeNode($event)\" [changeCheckboxWithNode]=\"true\"  [isNodeSelected]=\"isNodeSelected\">\n\n    <ng-template #menu let-node>\n        <button ngbDropdownItem (click.stop)=\"addDescriptorBtn(node)\"><i\n                class=\" me-1 fa fa-pencil\"></i>{{'FileExplorer::NewDirectory' | abpLocalization}}</button>\n        <button ngbDropdownItem (click.stop)=\"addDescriptorBtn(node,true)\"><i\n                class=\" me-1 fa fa-plus\"></i>{{'AbpUi::Edit' | abpLocalization}}</button>\n        <button ngbDropdownItem (click.stop)=\"deleteDescriptorBtn(node)\"><i\n                class=\" me-1 fa fa-remove\"></i>{{'AbpUi::Delete' | abpLocalization}}</button>\n    </ng-template>\n\n    <ng-template abpTreeExpandedIconTemplate let-node let-origin=\"origin\">\n        <i aria-hidden=\"true\" *ngIf=\"node.children.length>0\">\n            <ng-container *ngTemplateOutlet=\"node.isExpanded ? minusIcon : plusIcon\"></ng-container></i>\n    </ng-template>\n\n    <ng-template #minusIcon>\n        <svg width=\"15\" height=\"15\" viewBox=\"0 0 24 24\" xmlns=\"http://www.w3.org/2000/svg\" fill-rule=\"evenodd\"\n            clip-rule=\"evenodd\">\n            <path\n                d=\"M11.5 0c6.347 0 11.5 5.153 11.5 11.5s-5.153 11.5-11.5 11.5-11.5-5.153-11.5-11.5 5.153-11.5 11.5-11.5zm0 1c5.795 0 10.5 4.705 10.5 10.5s-4.705 10.5-10.5 10.5-10.5-4.705-10.5-10.5 4.705-10.5 10.5-10.5zm-6.5 10h13v1h-13v-1z\" />\n        </svg>\n    </ng-template>\n\n    <ng-template #plusIcon>\n        <svg width=\"15\" height=\"15\" viewBox=\"0 0 24 24\" xmlns=\"http://www.w3.org/2000/svg\" fill-rule=\"evenodd\"\n            clip-rule=\"evenodd\">\n            <path\n                d=\"M11.5 0c6.347 0 11.5 5.153 11.5 11.5s-5.153 11.5-11.5 11.5-11.5-5.153-11.5-11.5 5.153-11.5 11.5-11.5zm0 1c5.795 0 10.5 4.705 10.5 10.5s-4.705 10.5-10.5 10.5-10.5-4.705-10.5-10.5 4.705-10.5 10.5-10.5zm.5 10h6v1h-6v6h-1v-6h-6v-1h6v-6h1v6z\" />\n        </svg>\n    </ng-template>\n</abp-tree>\n\n}\n<abp-modal [(visible)]=\"ModalDescriptorOpen\" [busy]=\"ModalDescriptorBusy\"\n    (visibleChange)=\"ModalDescriptorVisibleChange($event)\">\n    <ng-template #abpHeader>\n        <h3>{{theNodeBeingEdited?('AbpUi::Edit' | abpLocalization):('FileExplorer::NewDirectory' | abpLocalization)}}\n        </h3>\n    </ng-template>\n    <ng-template #abpBody>\n        <ng-template #loaderRef>\n            <div class=\"text-center\"><i class=\"fa fa-pulse fa-spinner\" aria-hidden=\"true\"></i></div>\n        </ng-template>\n        <ng-container *ngIf=\"ModalDescriptorForm; else loaderRef\">\n            <form class=\"sites-modal-form\" #myForm=\"ngForm\" [formGroup]=\"ModalDescriptorForm\"\n                (keydown.enter)=\"$event.preventDefault()\" (submit)=\"createOrEditSave()\">\n                <button type=\"submit\" #ModalFormDescriptorSubmit style=\"display: none\"></button>\n                <div class=\"mb-3\">\n                    <label class=\"form-label\">{{'FileExplorer::DirectoryName' | abpLocalization}}</label>\n                    <input type=\"email\" class=\"form-control\" formControlName=\"name\">\n                </div>\n            </form>\n        </ng-container>\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\" [loading]=\"ModalDescriptorBusy\"\n            (click)=\"ModalFormDescriptorSubmit.nativeElement.click()\">{{'AbpUi::Save' | abpLocalization}}</abp-button>\n    </ng-template>\n</abp-modal>"]}
|
|
@@ -1,12 +1,14 @@
|
|
|
1
1
|
/* eslint-disable @angular-eslint/component-selector */
|
|
2
2
|
import { Component, EventEmitter, Input, Output } from '@angular/core';
|
|
3
3
|
import { FileApiService } from '../../services/file-api.service';
|
|
4
|
+
import { moveItemInArray } from '@angular/cdk/drag-drop';
|
|
4
5
|
import * as i0 from "@angular/core";
|
|
5
6
|
import * as i1 from "../../services/file-api.service";
|
|
6
7
|
import * as i2 from "@angular/common";
|
|
7
8
|
import * as i3 from "@abp/ng.core";
|
|
8
|
-
import * as i4 from "
|
|
9
|
-
import * as i5 from "
|
|
9
|
+
import * as i4 from "@angular/cdk/drag-drop";
|
|
10
|
+
import * as i5 from "../file-modal/file-modal.component";
|
|
11
|
+
import * as i6 from "../../previews/file-preview.component";
|
|
10
12
|
export class FilePickerComponent {
|
|
11
13
|
constructor(_FileApiService) {
|
|
12
14
|
this._FileApiService = _FileApiService;
|
|
@@ -45,12 +47,19 @@ export class FilePickerComponent {
|
|
|
45
47
|
this.selectedFileChange.emit([]);
|
|
46
48
|
this.selectedFileChange.emit(this.selectFormFile);
|
|
47
49
|
}
|
|
50
|
+
/**调整表格位置 */
|
|
51
|
+
drop(event) {
|
|
52
|
+
moveItemInArray(this._fileShowTable, event.previousIndex, event.currentIndex);
|
|
53
|
+
this.selectFormFile = this._fileShowTable;
|
|
54
|
+
this.selectedFileChange.emit(this.selectFormFile);
|
|
55
|
+
// this._fileShowTable.updateValueAndValidity()
|
|
56
|
+
}
|
|
48
57
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.5", ngImport: i0, type: FilePickerComponent, deps: [{ token: i1.FileApiService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
49
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.1.5", type: FilePickerComponent, selector: "fe-file-picker", inputs: { multiple: "multiple", fileContainerName: "fileContainerName", selectFormFile: "selectFormFile" }, outputs: { selectedFileChange: "selectedFileChange" }, usesOnChanges: true, ngImport: i0, template: "<button class=\"btn btn-sm btn-primary ms-2 float-end\" type=\"button\"
|
|
58
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.1.5", type: FilePickerComponent, selector: "fe-file-picker", inputs: { multiple: "multiple", fileContainerName: "fileContainerName", selectFormFile: "selectFormFile" }, outputs: { selectedFileChange: "selectedFileChange" }, usesOnChanges: true, ngImport: i0, template: "<button class=\"btn btn-sm btn-primary ms-2 float-end\" type=\"button\"\n (click.stop)=\"ModalOpen = true\">{{'FileExplorer::SelectFile' | abpLocalization}}</button>\n\n<fe-file-modal [(visible)]=\"ModalOpen\" [selectPickerFile]=\"selectFormFile\" [multiple]=\"_multiple\"\n (selectFilefn)=\"_selectFilefn($event)\" [fileContainerName]=\"_fileContainerName\"></fe-file-modal>\n<table class=\"table\" *ngIf=\"_fileShowTable.length>0\" cdkDropList (cdkDropListDropped)=\"drop($event)\">\n <thead>\n <tr>\n <th scope=\"col\" style=\"width: 30px;\"></th>\n <th scope=\"col\"></th>\n <th scope=\"col\">{{'FileExplorer::FileName' | abpLocalization}}</th>\n <th scope=\"col\">{{'FileExplorer::FileSize' | abpLocalization}}</th>\n <th scope=\"col\"></th>\n </tr>\n </thead>\n <tbody>\n <ng-container *ngFor=\"let item of _fileShowTable;let i =index\">\n <tr cdkDrag cdkDragLockAxis=\"y\" [cdkDragData]=\"item\">\n <td>\n <div class=\"drag-handle\" cdkDragHandle>\n <span class=\"bi bi-arrows-move fs-5\"></span>\n </div>\n </td>\n <td>\n <fe-file-preview [width]=\"'80px'\" [src]=\"item.url||item.Url\" [name]=\"item.name||item.Name\"\n [type]=\"item.mimeType||item.MimeType\" [preview]=\"true\"></fe-file-preview>\n </td>\n <th scope=\"row\">\n <div>{{item.name||item.Name}}</div>\n </th>\n <td>{{_FileApiService.formatFileSize(item.Size||item.size)}}</td>\n <td>\n <button class=\"btn btn-sm p-0 btn-light \" (click.stop)=\"deleteFileTableItem(i,item)\">\n <i class=\"fas fa-trash p-2\"></i>\n </button>\n </td>\n </tr>\n </ng-container>\n </tbody>\n</table>", styles: [".table{border-collapse:collapse;table-layout:fixed}\n"], dependencies: [{ kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.StopPropagationDirective, selector: "[click.stop]", outputs: ["click.stop"] }, { kind: "directive", type: i4.CdkDropList, selector: "[cdkDropList], cdk-drop-list", inputs: ["cdkDropListConnectedTo", "cdkDropListData", "cdkDropListOrientation", "id", "cdkDropListLockAxis", "cdkDropListDisabled", "cdkDropListSortingDisabled", "cdkDropListEnterPredicate", "cdkDropListSortPredicate", "cdkDropListAutoScrollDisabled", "cdkDropListAutoScrollStep"], outputs: ["cdkDropListDropped", "cdkDropListEntered", "cdkDropListExited", "cdkDropListSorted"], exportAs: ["cdkDropList"] }, { kind: "directive", type: i4.CdkDrag, selector: "[cdkDrag]", inputs: ["cdkDragData", "cdkDragLockAxis", "cdkDragRootElement", "cdkDragBoundary", "cdkDragStartDelay", "cdkDragFreeDragPosition", "cdkDragDisabled", "cdkDragConstrainPosition", "cdkDragPreviewClass", "cdkDragPreviewContainer"], outputs: ["cdkDragStarted", "cdkDragReleased", "cdkDragEnded", "cdkDragEntered", "cdkDragExited", "cdkDragDropped", "cdkDragMoved"], exportAs: ["cdkDrag"] }, { kind: "directive", type: i4.CdkDragHandle, selector: "[cdkDragHandle]", inputs: ["cdkDragHandleDisabled"] }, { kind: "component", type: i5.FileModalComponent, selector: "fe-file-modal", inputs: ["fileContainerName", "multiple", "limit", "visible", "selectPickerFile"], outputs: ["visibleChange", "selectFilefn"] }, { kind: "component", type: i6.FilePreviewComponent, selector: "fe-file-preview", inputs: ["width", "src", "preview", "type", "name", "className"] }, { kind: "pipe", type: i3.LocalizationPipe, name: "abpLocalization" }] }); }
|
|
50
59
|
}
|
|
51
60
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.5", ngImport: i0, type: FilePickerComponent, decorators: [{
|
|
52
61
|
type: Component,
|
|
53
|
-
args: [{ selector: 'fe-file-picker', template: "<button class=\"btn btn-sm btn-primary ms-2 float-end\" type=\"button\"
|
|
62
|
+
args: [{ selector: 'fe-file-picker', template: "<button class=\"btn btn-sm btn-primary ms-2 float-end\" type=\"button\"\n (click.stop)=\"ModalOpen = true\">{{'FileExplorer::SelectFile' | abpLocalization}}</button>\n\n<fe-file-modal [(visible)]=\"ModalOpen\" [selectPickerFile]=\"selectFormFile\" [multiple]=\"_multiple\"\n (selectFilefn)=\"_selectFilefn($event)\" [fileContainerName]=\"_fileContainerName\"></fe-file-modal>\n<table class=\"table\" *ngIf=\"_fileShowTable.length>0\" cdkDropList (cdkDropListDropped)=\"drop($event)\">\n <thead>\n <tr>\n <th scope=\"col\" style=\"width: 30px;\"></th>\n <th scope=\"col\"></th>\n <th scope=\"col\">{{'FileExplorer::FileName' | abpLocalization}}</th>\n <th scope=\"col\">{{'FileExplorer::FileSize' | abpLocalization}}</th>\n <th scope=\"col\"></th>\n </tr>\n </thead>\n <tbody>\n <ng-container *ngFor=\"let item of _fileShowTable;let i =index\">\n <tr cdkDrag cdkDragLockAxis=\"y\" [cdkDragData]=\"item\">\n <td>\n <div class=\"drag-handle\" cdkDragHandle>\n <span class=\"bi bi-arrows-move fs-5\"></span>\n </div>\n </td>\n <td>\n <fe-file-preview [width]=\"'80px'\" [src]=\"item.url||item.Url\" [name]=\"item.name||item.Name\"\n [type]=\"item.mimeType||item.MimeType\" [preview]=\"true\"></fe-file-preview>\n </td>\n <th scope=\"row\">\n <div>{{item.name||item.Name}}</div>\n </th>\n <td>{{_FileApiService.formatFileSize(item.Size||item.size)}}</td>\n <td>\n <button class=\"btn btn-sm p-0 btn-light \" (click.stop)=\"deleteFileTableItem(i,item)\">\n <i class=\"fas fa-trash p-2\"></i>\n </button>\n </td>\n </tr>\n </ng-container>\n </tbody>\n</table>", styles: [".table{border-collapse:collapse;table-layout:fixed}\n"] }]
|
|
54
63
|
}], ctorParameters: () => [{ type: i1.FileApiService }], propDecorators: { multiple: [{
|
|
55
64
|
type: Input
|
|
56
65
|
}], fileContainerName: [{
|
|
@@ -60,4 +69,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.5", ngImpor
|
|
|
60
69
|
}], selectedFileChange: [{
|
|
61
70
|
type: Output
|
|
62
71
|
}] } });
|
|
63
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
72
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"file-picker.component.js","sourceRoot":"","sources":["../../../../../../../packages/file-explorer/src/lib/components/file-picker/file-picker.component.ts","../../../../../../../packages/file-explorer/src/lib/components/file-picker/file-picker.component.html"],"names":[],"mappings":"AAAA,uDAAuD;AACvD,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,KAAK,EAAa,MAAM,EAAiB,MAAM,eAAe,CAAC;AACjG,OAAO,EAAE,cAAc,EAAE,MAAM,iCAAiC,CAAC;AACjE,OAAO,EAAE,eAAe,EAAE,MAAM,wBAAwB,CAAC;;;;;;;;AAOzD,MAAM,OAAO,mBAAmB;IAI9B,YACU,eAA+B;QAA/B,oBAAe,GAAf,eAAe,CAAgB;QAMzC,UAAU;QACV,cAAS,GAAY,KAAK,CAAA;QAM1B,UAAU;QACV,uBAAkB,GAAW,QAAQ,CAAA;QAgB3B,uBAAkB,GAAG,IAAI,YAAY,EAAE,CAAA;QAEjD,mBAAc,GAAU,EAAE,CAAA;QAU1B,iBAAiB;QACjB,cAAS,GAAY,KAAK,CAAA;IAxC1B,CAAC;IAKD,IACW,QAAQ,CAAC,CAAU;QAC5B,IAAI,CAAC,SAAS,GAAG,CAAC,CAAC;IACrB,CAAC;IAID,IACW,iBAAiB,CAAC,CAAS;QACpC,IAAI,CAAC,kBAAkB,GAAG,CAAC,CAAC;IAC9B,CAAC;IAKD,WAAW,CAAC,OAAsB;QAChC,IAAI,yBAAyB,GAAG,OAAO,CAAC,cAAc,CAAC,cAAc,CAAC,CAAA;QACtE,IAAI,yBAAyB,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YACzC,IAAI,CAAC,cAAc,GAAG,yBAAyB,CAAA;QACjD,CAAC;IACH,CAAC;IAMD,eAAe;IACf,aAAa,CAAC,KAAY;QACxB,IAAI,cAAc,GAAG,IAAI,CAAC,eAAe,CAAC,SAAS,CAAC,KAAK,CAAC,CAAA;QAC1D,IAAI,CAAC,cAAc,GAAG,cAAc,CAAA;QACpC,IAAI,CAAC,cAAc,GAAG,cAAc,CAAA;QACpC,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,cAAc,CAAC,CAAA;IAC9C,CAAC;IAKD,aAAa;IACb,mBAAmB,CAAC,CAAC,EAAE,IAAI;QACzB,IAAI,CAAC,cAAc,CAAC,MAAM,CAAC,CAAC,EAAE,CAAC,CAAC,CAAA;QAChC,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC,cAAc,CAAA;QACzC,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,EAAE,CAAC,CAAA;QAChC,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,IAAI,CAAC,cAAc,CAAC,CAAA;IACnD,CAAC;IACD,YAAY;IACV,IAAI,CAAC,KAAU;QACb,eAAe,CACb,IAAI,CAAC,cAAc,EACnB,KAAK,CAAC,aAAa,EACnB,KAAK,CAAC,YAAY,CACnB,CAAC;QACF,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC,cAAc,CAAA;QACzC,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,IAAI,CAAC,cAAc,CAAC,CAAA;QACjD,+CAA+C;IACjD,CAAC;8GAnEQ,mBAAmB;kGAAnB,mBAAmB,8OCVhC,28DAuCQ;;2FD7BK,mBAAmB;kBAL/B,SAAS;+BACE,gBAAgB;mFAkBf,QAAQ;sBADlB,KAAK;gBAQK,iBAAiB;sBAD3B,KAAK;gBAMG,cAAc;sBAAtB,KAAK;gBASI,kBAAkB;sBAA3B,MAAM","sourcesContent":["/* eslint-disable @angular-eslint/component-selector */\nimport { Component, EventEmitter, Input, OnChanges, Output, SimpleChanges } from '@angular/core';\nimport { FileApiService } from '../../services/file-api.service';\nimport { moveItemInArray } from '@angular/cdk/drag-drop';\n\n@Component({\n  selector: 'fe-file-picker',\n  templateUrl: './file-picker.component.html',\n  styleUrls: ['./file-picker.component.scss']\n})\nexport class FilePickerComponent implements OnChanges {\n\n\n\n  constructor(\n    private _FileApiService: FileApiService,\n  ) {\n\n  }\n\n\n  /**是否多选 */\n  _multiple: boolean = false\n  @Input()\n  public set multiple(v: boolean) {\n    this._multiple = v;\n  }\n\n  /**图片容器 */\n  _fileContainerName: string = 'Images'\n  @Input()\n  public set fileContainerName(v: string) {\n    this._fileContainerName = v;\n  }\n\n  /**已选定的文件 */\n  @Input() selectFormFile: any[]\n\n  ngOnChanges(changes: SimpleChanges): void {\n    let selectFormFilengOnChanges = changes.selectFormFile['currentValue']\n    if (selectFormFilengOnChanges.length > 0) {\n      this._fileShowTable = selectFormFilengOnChanges\n    }\n  }\n\n  @Output() selectedFileChange = new EventEmitter()\n\n  _fileShowTable: any[] = []\n\n  /**表格选择的文件回调 */\n  _selectFilefn(event: any[]) {\n    let _fileShowTable = this._FileApiService.deepClone(event)\n    this._fileShowTable = _fileShowTable\n    this.selectFormFile = _fileShowTable\n    this.selectedFileChange.emit(_fileShowTable)\n  }\n\n  /**模态框-状态-是否打开 */\n  ModalOpen: boolean = false\n\n  /**删除文件表格项 */\n  deleteFileTableItem(i, file) {\n    this._fileShowTable.splice(i, 1)\n    this.selectFormFile = this._fileShowTable\n    this.selectedFileChange.emit([])\n    this.selectedFileChange.emit(this.selectFormFile)\n  }\n  /**调整表格位置 */\n    drop(event: any) {\n      moveItemInArray(\n        this._fileShowTable,\n        event.previousIndex,\n        event.currentIndex\n      );\n      this.selectFormFile = this._fileShowTable\n      this.selectedFileChange.emit(this.selectFormFile)\n      // this._fileShowTable.updateValueAndValidity()\n    }\n}\n","<button class=\"btn btn-sm btn-primary ms-2 float-end\" type=\"button\"\n    (click.stop)=\"ModalOpen = true\">{{'FileExplorer::SelectFile' | abpLocalization}}</button>\n\n<fe-file-modal [(visible)]=\"ModalOpen\" [selectPickerFile]=\"selectFormFile\" [multiple]=\"_multiple\"\n    (selectFilefn)=\"_selectFilefn($event)\" [fileContainerName]=\"_fileContainerName\"></fe-file-modal>\n<table class=\"table\" *ngIf=\"_fileShowTable.length>0\" cdkDropList (cdkDropListDropped)=\"drop($event)\">\n    <thead>\n        <tr>\n            <th scope=\"col\" style=\"width: 30px;\"></th>\n            <th scope=\"col\"></th>\n            <th scope=\"col\">{{'FileExplorer::FileName' | abpLocalization}}</th>\n            <th scope=\"col\">{{'FileExplorer::FileSize' | abpLocalization}}</th>\n            <th scope=\"col\"></th>\n        </tr>\n    </thead>\n    <tbody>\n        <ng-container *ngFor=\"let item of _fileShowTable;let i =index\">\n            <tr cdkDrag cdkDragLockAxis=\"y\" [cdkDragData]=\"item\">\n                <td>\n                    <div class=\"drag-handle\" cdkDragHandle>\n                        <span class=\"bi bi-arrows-move fs-5\"></span>\n                    </div>\n                </td>\n                <td>\n                    <fe-file-preview [width]=\"'80px'\" [src]=\"item.url||item.Url\" [name]=\"item.name||item.Name\"\n                        [type]=\"item.mimeType||item.MimeType\" [preview]=\"true\"></fe-file-preview>\n                </td>\n                <th scope=\"row\">\n                    <div>{{item.name||item.Name}}</div>\n                </th>\n                <td>{{_FileApiService.formatFileSize(item.Size||item.size)}}</td>\n                <td>\n                    <button class=\"btn btn-sm p-0 btn-light \" (click.stop)=\"deleteFileTableItem(i,item)\">\n                        <i class=\"fas fa-trash p-2\"></i>\n                    </button>\n                </td>\n            </tr>\n        </ng-container>\n    </tbody>\n</table>"]}
|