my-common-zzp 0.0.1 → 0.0.2
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/common.module.mjs +26 -0
- package/esm2022/lib/uc/index.mjs +2 -1
- package/esm2022/lib/uc/uc-file-list/card-list/component.mjs +150 -0
- package/esm2022/lib/uc/uc-file-list/component.mjs +277 -0
- package/esm2022/lib/uc/uc-file-list/cropImageModal/component.mjs +240 -0
- package/esm2022/lib/uc/uc-file-list/data.mjs +73 -0
- package/esm2022/lib/uc/uc-file-list/method.mjs +103 -0
- package/esm2022/lib/uc/uc-file-list/table-list.mjs +84 -0
- package/esm2022/lib/uc/uc-file-list/toolbar.mjs +79 -0
- package/esm2022/lib/uc/uc-file-list/type.mjs +2 -0
- package/esm2022/lib/uc/uc-file-list/upload.mjs +42 -0
- package/esm2022/lib/ucModel.mjs +23 -3
- package/esm2022/public-api.mjs +2 -1
- package/fesm2022/my-common-zzp.mjs +1034 -6
- package/fesm2022/my-common-zzp.mjs.map +1 -1
- package/lib/common.module.d.ts +10 -0
- package/lib/uc/index.d.ts +1 -0
- package/lib/uc/uc-file-list/card-list/component.d.ts +19 -0
- package/lib/uc/uc-file-list/component.d.ts +56 -0
- package/lib/uc/uc-file-list/cropImageModal/component.d.ts +45 -0
- package/lib/uc/uc-file-list/data.d.ts +19 -0
- package/lib/uc/uc-file-list/method.d.ts +23 -0
- package/lib/uc/uc-file-list/table-list.d.ts +15 -0
- package/lib/uc/uc-file-list/toolbar.d.ts +14 -0
- package/lib/uc/uc-file-list/type.d.ts +7 -0
- package/lib/uc/uc-file-list/upload.d.ts +12 -0
- package/lib/ucModel.d.ts +20 -14
- package/package.json +1 -1
- package/public-api.d.ts +1 -0
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* itec 开发环境基础设施
|
|
3
|
+
* - 基础组件声明
|
|
4
|
+
* - 基础服务声明
|
|
5
|
+
*/
|
|
6
|
+
import { NgModule } from '@angular/core';
|
|
7
|
+
import { CommonModule } from '@angular/common';
|
|
8
|
+
import { NgZorroAntdModule } from './ngZorroAntd.module';
|
|
9
|
+
import { MaterialModule } from './material.module';
|
|
10
|
+
// 核心的组件
|
|
11
|
+
import { UcModule } from './ucModel';
|
|
12
|
+
import * as i0 from "@angular/core";
|
|
13
|
+
export class ItecCoreModule {
|
|
14
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.0", ngImport: i0, type: ItecCoreModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
|
|
15
|
+
static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "18.1.0", ngImport: i0, type: ItecCoreModule, imports: [CommonModule, NgZorroAntdModule, MaterialModule], exports: [CommonModule, NgZorroAntdModule, MaterialModule, UcModule] }); }
|
|
16
|
+
static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "18.1.0", ngImport: i0, type: ItecCoreModule, imports: [CommonModule, NgZorroAntdModule, MaterialModule, CommonModule, NgZorroAntdModule, MaterialModule, UcModule] }); }
|
|
17
|
+
}
|
|
18
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.0", ngImport: i0, type: ItecCoreModule, decorators: [{
|
|
19
|
+
type: NgModule,
|
|
20
|
+
args: [{
|
|
21
|
+
imports: [CommonModule, NgZorroAntdModule, MaterialModule],
|
|
22
|
+
exports: [CommonModule, NgZorroAntdModule, MaterialModule, UcModule],
|
|
23
|
+
providers: [],
|
|
24
|
+
}]
|
|
25
|
+
}] });
|
|
26
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29tbW9uLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL215LWNvbW1vbi9zcmMvbGliL2NvbW1vbi5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7Ozs7R0FJRztBQUNILE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBRS9DLE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLHNCQUFzQixDQUFDO0FBQ3pELE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSxtQkFBbUIsQ0FBQztBQUNuRCxRQUFRO0FBQ1IsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLFdBQVcsQ0FBQzs7QUFPckMsTUFBTSxPQUFPLGNBQWM7OEdBQWQsY0FBYzsrR0FBZCxjQUFjLFlBSmhCLFlBQVksRUFBRSxpQkFBaUIsRUFBRSxjQUFjLGFBQy9DLFlBQVksRUFBRSxpQkFBaUIsRUFBRSxjQUFjLEVBQUUsUUFBUTsrR0FHdkQsY0FBYyxZQUpoQixZQUFZLEVBQUUsaUJBQWlCLEVBQUUsY0FBYyxFQUMvQyxZQUFZLEVBQUUsaUJBQWlCLEVBQUUsY0FBYyxFQUFFLFFBQVE7OzJGQUd2RCxjQUFjO2tCQUwxQixRQUFRO21CQUFDO29CQUNULE9BQU8sRUFBRSxDQUFDLFlBQVksRUFBRSxpQkFBaUIsRUFBRSxjQUFjLENBQUM7b0JBQzFELE9BQU8sRUFBRSxDQUFDLFlBQVksRUFBRSxpQkFBaUIsRUFBRSxjQUFjLEVBQUUsUUFBUSxDQUFDO29CQUNwRSxTQUFTLEVBQUUsRUFBRTtpQkFDYiIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxyXG4gKiAgaXRlYyDlvIDlj5Hnjq/looPln7rnoYDorr7mlr1cclxuICogIC0g5Z+656GA57uE5Lu25aOw5piOXHJcbiAqICAtIOWfuuehgOacjeWKoeWjsOaYjlxyXG4gKi9cclxuaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcclxuXHJcbmltcG9ydCB7IE5nWm9ycm9BbnRkTW9kdWxlIH0gZnJvbSAnLi9uZ1pvcnJvQW50ZC5tb2R1bGUnO1xyXG5pbXBvcnQgeyBNYXRlcmlhbE1vZHVsZSB9IGZyb20gJy4vbWF0ZXJpYWwubW9kdWxlJztcclxuLy8g5qC45b+D55qE57uE5Lu2XHJcbmltcG9ydCB7IFVjTW9kdWxlIH0gZnJvbSAnLi91Y01vZGVsJztcclxuXHJcbkBOZ01vZHVsZSh7XHJcblx0aW1wb3J0czogW0NvbW1vbk1vZHVsZSwgTmdab3Jyb0FudGRNb2R1bGUsIE1hdGVyaWFsTW9kdWxlXSxcclxuXHRleHBvcnRzOiBbQ29tbW9uTW9kdWxlLCBOZ1pvcnJvQW50ZE1vZHVsZSwgTWF0ZXJpYWxNb2R1bGUsIFVjTW9kdWxlXSxcclxuXHRwcm92aWRlcnM6IFtdLFxyXG59KVxyXG5leHBvcnQgY2xhc3MgSXRlY0NvcmVNb2R1bGUge31cclxuIl19
|
package/esm2022/lib/uc/index.mjs
CHANGED
|
@@ -19,4 +19,5 @@ export { UcPickupWindowHeaderComponent } from "./uc-pickup-window/header.compone
|
|
|
19
19
|
export { UcFormComponent } from "./uc-fields/uc-form.component";
|
|
20
20
|
export { UcFieldsReadonlyComponent } from "./uc-fields/fieldsReadonly.component";
|
|
21
21
|
export { UcFieldsEditComponent } from "./uc-fields/fieldsEdit.component";
|
|
22
|
-
|
|
22
|
+
export { UcFileListComponent } from "./uc-file-list/component";
|
|
23
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9teS1jb21tb24vc3JjL2xpYi91Yy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLFVBQVUsQ0FBQztBQUN6QixPQUFPLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSwyQkFBMkIsQ0FBQztBQUNqRSxPQUFPLEVBQUUseUJBQXlCLEVBQUUsTUFBTSx3Q0FBd0MsQ0FBQztBQUNuRixPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSx1QkFBdUIsQ0FBQztBQUMxRCxPQUFPLEVBQUUsMkJBQTJCLEVBQUUsTUFBTSx1Q0FBdUMsQ0FBQztBQUNwRixPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQztBQUM3RCxPQUFPLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSwyQkFBMkIsQ0FBQztBQUNqRSxPQUFPLEVBQUUsd0JBQXdCLEVBQUUsTUFBTSxpQ0FBaUMsQ0FBQztBQUMzRSxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQztBQUMvRCxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsTUFBTSxnQ0FBZ0MsQ0FBQztBQUN6RSxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQztBQUM3RCxPQUFPLEVBQUUsZUFBZSxFQUFFLFdBQVcsRUFBRSxNQUFNLDZCQUE2QixDQUFDO0FBQzNFLE9BQU8sRUFBRSwyQkFBMkIsRUFBRSxNQUFNLGtDQUFrQyxDQUFDO0FBQy9FLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxNQUFNLDhCQUE4QixDQUFDO0FBQ3ZFLE9BQU8sRUFBRSxvQkFBb0IsRUFBRSxNQUFNLDBCQUEwQixDQUFDO0FBQ2hFLE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLDBCQUEwQixDQUFDO0FBQy9ELE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLHdCQUF3QixDQUFDO0FBQzVELE9BQU8sRUFBRSw2QkFBNkIsRUFBRSxNQUFNLHFDQUFxQyxDQUFDO0FBQ3BGLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSwrQkFBK0IsQ0FBQztBQUNoRSxPQUFPLEVBQUUseUJBQXlCLEVBQUUsTUFBTSxzQ0FBc0MsQ0FBQztBQUNqRixPQUFPLEVBQUUscUJBQXFCLEVBQUUsTUFBTSxrQ0FBa0MsQ0FBQztBQUN6RSxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gXCIuL2NvbW1vblwiO1xyXG5leHBvcnQgeyBVY0RhdGVSYW5nZUNvbXBvbmVudCB9IGZyb20gXCIuL3VjLWRhdGUtcmFuZ2UvY29tcG9uZW50XCI7XHJcbmV4cG9ydCB7IFVjTnpNb2RhbENvbnRlbnRDb21wb25lbnQgfSBmcm9tIFwiLi91Yy1kaWFsb2cvdWNOek1vZGFsQ29udGVudC5Db21wb25lbnRcIjtcclxuZXhwb3J0IHsgVWNGaWVsZHNDb21wb25lbnQgfSBmcm9tIFwiLi91Yy1maWVsZHMvY29tcG9uZW50XCI7XHJcbmV4cG9ydCB7IFVjTGlzdEZpbHRlck9wdGlvbkNvbXBvbmVudCB9IGZyb20gXCIuL3VjLWxpc3QtZmlsdGVyL3VjLWxpc3QtZmlsdGVyT3B0aW9uXCI7XHJcbmV4cG9ydCB7IFVjTGlzdE5hdkNvbXBvbmVudCB9IGZyb20gXCIuL3VjLWxpc3QtbmF2L2NvbXBvbmVudFwiO1xyXG5leHBvcnQgeyBVY0xpc3RUYWJsZUNvbXBvbmVudCB9IGZyb20gXCIuL3VjLWxpc3QtdGFibGUvY29tcG9uZW50XCI7XHJcbmV4cG9ydCB7IFVjTGlzdFRhYmxlQ29yZUNvbXBvbmVudCB9IGZyb20gXCIuL3VjLWxpc3QtdGFibGUvdGFibGUuY29tcG9uZW50XCI7XHJcbmV4cG9ydCB7IFVjTGlzdFRyZWVDb21wb25lbnQgfSBmcm9tIFwiLi91Yy1saXN0LXRyZWUvY29tcG9uZW50XCI7XHJcbmV4cG9ydCB7IFVjTGlzdFRyZWVDb3JlQ29tcG9uZW50IH0gZnJvbSBcIi4vdWMtbGlzdC10cmVlL3RhYmxlLmNvbXBvbmVudFwiO1xyXG5leHBvcnQgeyBVY05hdkxpc3RDb21wb25lbnQgfSBmcm9tIFwiLi91Yy1uYXYtbGlzdC9jb21wb25lbnRcIjtcclxuZXhwb3J0IHsgVWNOYXYxQ29tcG9uZW50LCBkZWZhdWx0TGlzdCB9IGZyb20gXCIuL3VjLW5hdjEvdWMtbmF2MS5jb21wb25lbnRcIjtcclxuZXhwb3J0IHsgVWNQZXJmZWN0U2Nyb2xsYmFyQ29tcG9uZW50IH0gZnJvbSBcIi4vdWMtcGVyZmVjdC1zY3JvbGxiYXIvY29tcG9uZW50XCI7XHJcbmV4cG9ydCB7IFVjUGlja3VwV2luZG93Q29tcG9uZW50IH0gZnJvbSBcIi4vdWMtcGlja3VwLXdpbmRvdy9jb21wb25lbnRcIjtcclxuZXhwb3J0IHsgVWNTdWJIZWFkZXJDb21wb25lbnQgfSBmcm9tIFwiLi91Yy1zdWJoZWFkZXIvY29tcG9uZW50XCI7XHJcbmV4cG9ydCB7IFVjVGl0bGVOYXZDb21wb25lbnQgfSBmcm9tIFwiLi91Yy10aXRsZS1uYXYvY29tcG9uZW50XCI7XHJcbmV4cG9ydCB7IFVjVG9vbGJhckNvbXBvbmVudCB9IGZyb20gXCIuL3VjLXRvb2xiYXIvY29tcG9uZW50XCI7XHJcbmV4cG9ydCB7IFVjUGlja3VwV2luZG93SGVhZGVyQ29tcG9uZW50IH0gZnJvbSBcIi4vdWMtcGlja3VwLXdpbmRvdy9oZWFkZXIuY29tcG9uZW50XCI7XHJcbmV4cG9ydCB7IFVjRm9ybUNvbXBvbmVudCB9IGZyb20gXCIuL3VjLWZpZWxkcy91Yy1mb3JtLmNvbXBvbmVudFwiO1xyXG5leHBvcnQgeyBVY0ZpZWxkc1JlYWRvbmx5Q29tcG9uZW50IH0gZnJvbSBcIi4vdWMtZmllbGRzL2ZpZWxkc1JlYWRvbmx5LmNvbXBvbmVudFwiO1xyXG5leHBvcnQgeyBVY0ZpZWxkc0VkaXRDb21wb25lbnQgfSBmcm9tIFwiLi91Yy1maWVsZHMvZmllbGRzRWRpdC5jb21wb25lbnRcIjtcclxuZXhwb3J0IHsgVWNGaWxlTGlzdENvbXBvbmVudCB9IGZyb20gXCIuL3VjLWZpbGUtbGlzdC9jb21wb25lbnRcIjtcclxuIl19
|
|
@@ -0,0 +1,150 @@
|
|
|
1
|
+
import { moveItemInArray } from "@angular/cdk/drag-drop";
|
|
2
|
+
import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output } from "@angular/core";
|
|
3
|
+
import { actions } from "../data";
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
import * as i1 from "@angular/common";
|
|
6
|
+
import * as i2 from "@angular/cdk/drag-drop";
|
|
7
|
+
import * as i3 from "ng-inline-svg-2";
|
|
8
|
+
import * as i4 from "../upload";
|
|
9
|
+
export class UcFileCardListComponent {
|
|
10
|
+
constructor() {
|
|
11
|
+
this.multiple = false; //多选文件
|
|
12
|
+
this.allowUpload = true; //允许上传
|
|
13
|
+
this.onUploadCancelClick = new EventEmitter();
|
|
14
|
+
this.onCradClick = new EventEmitter();
|
|
15
|
+
this.actions = actions;
|
|
16
|
+
}
|
|
17
|
+
ngOnInit() {
|
|
18
|
+
this.cardSize = this.cardSize ? this.cardSize + "px" : "150px";
|
|
19
|
+
}
|
|
20
|
+
drop(event) {
|
|
21
|
+
if (event.previousIndex !== event.currentIndex) {
|
|
22
|
+
moveItemInArray(this.dataList, event.previousIndex, event.currentIndex);
|
|
23
|
+
this.onCradClick.emit({
|
|
24
|
+
code: "DROPPED",
|
|
25
|
+
data: event.currentIndex,
|
|
26
|
+
});
|
|
27
|
+
}
|
|
28
|
+
}
|
|
29
|
+
doSth(event, code, item) {
|
|
30
|
+
event.stopPropagation();
|
|
31
|
+
this.onCradClick.emit({
|
|
32
|
+
code: code,
|
|
33
|
+
data: item,
|
|
34
|
+
});
|
|
35
|
+
}
|
|
36
|
+
onUploadCancelCallback() {
|
|
37
|
+
this.onUploadCancelClick.emit();
|
|
38
|
+
}
|
|
39
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.0", ngImport: i0, type: UcFileCardListComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
40
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.1.0", type: UcFileCardListComponent, selector: "uc-file-card-list", inputs: { cardSize: "cardSize", multiple: "multiple", allowUpload: "allowUpload", beforeUpload: "beforeUpload", dataList: "dataList" }, outputs: { onUploadCancelClick: "onUploadCancelClick", onCradClick: "onCradClick" }, ngImport: i0, template: `<div class="main">
|
|
41
|
+
<div class="dropContent" cdkDropList cdkDropListOrientation="mixed" (cdkDropListDropped)="drop($event)">
|
|
42
|
+
@for (item of dataList ; let idx = $index; track idx) {
|
|
43
|
+
<div
|
|
44
|
+
cdkDrag
|
|
45
|
+
class="fileContent"
|
|
46
|
+
[ngStyle]="{
|
|
47
|
+
width:cardSize,
|
|
48
|
+
height:cardSize,
|
|
49
|
+
}"
|
|
50
|
+
>
|
|
51
|
+
@if(item.type==="image"){
|
|
52
|
+
<span class="image-content vc">
|
|
53
|
+
<img [src]="item.fileSrc" />
|
|
54
|
+
</span>
|
|
55
|
+
}@else {
|
|
56
|
+
<span [inlineSVG]="item.imageSrc" cacheSVG="true" class="svg-icon svg-icon-7x vc"></span>
|
|
57
|
+
}
|
|
58
|
+
<div class="mask">
|
|
59
|
+
<div class="maskContent" (click)="doSth($event, 'DOWNLOAD', item)">
|
|
60
|
+
<span class="operating">
|
|
61
|
+
@for (c of actions ; track c) { @if(c.type===item.type||c.type==='any'){
|
|
62
|
+
<a [class]="c.type === 'image' ? 'mr-5' : ''" (click)="doSth($event, c.code, item)">
|
|
63
|
+
<i class="icon-xl" [ngClass]="c.icon"></i>
|
|
64
|
+
</a>
|
|
65
|
+
} }
|
|
66
|
+
</span>
|
|
67
|
+
</div>
|
|
68
|
+
</div>
|
|
69
|
+
</div>
|
|
70
|
+
} @if(allowUpload){
|
|
71
|
+
|
|
72
|
+
<uc-file-upload [multiple]="multiple" [beforeUpload]="beforeUpload" (onCancel)="onUploadCancelCallback()">
|
|
73
|
+
<div
|
|
74
|
+
class="fileContent text-muted"
|
|
75
|
+
[ngStyle]="{
|
|
76
|
+
width:cardSize,
|
|
77
|
+
height:cardSize,
|
|
78
|
+
}"
|
|
79
|
+
>
|
|
80
|
+
<i class="flaticon2-plus icon-xl icon-plus vc"></i>
|
|
81
|
+
</div>
|
|
82
|
+
</uc-file-upload>
|
|
83
|
+
}
|
|
84
|
+
</div>
|
|
85
|
+
</div> `, isInline: true, styles: ["@charset \"UTF-8\";.main .dropContent{display:flex;flex-wrap:wrap}.main .dropContent .fileContent{margin-right:8px;margin-bottom:5px;padding:6px;border:1px solid #cccccc;position:relative}.main .dropContent .fileContent .image-content{width:100%;height:100%}.main .dropContent .fileContent .image-content img{width:100%;height:100%;object-fit:cover}.main .dropContent .fileContent .icon-plus{color:unset}.main .dropContent .fileContent .icon-plus:hover{cursor:pointer}.main .dropContent .fileContent .mask{position:absolute;top:0;left:0;height:100%;width:100%}.main .dropContent .fileContent .mask .maskContent{opacity:0;transition:opacity .2s ease,visibility .2s ease;background:#65656599;height:100%;width:100%;position:relative}.main .dropContent .fileContent .mask .maskContent .operating{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.main .dropContent .fileContent .mask .maskContent .operating a{color:#fff}.main .dropContent .fileContent .mask .maskContent .operating a i{color:unset}.main .dropContent .fileContent .mask:hover .maskContent{opacity:1;visibility:visible}.cdk-drag-preview{border-radius:4px;box-shadow:0 5px 5px -3px #0003,0 8px 10px 1px #00000024,0 3px 14px 2px #0000001f}.cdk-drag-preview .image-content{width:100%;height:100%}.cdk-drag-preview .image-content img{width:100%;height:100%;object-fit:cover}.cdk-drag-preview .maskContent,.cdk-drag-placeholder{opacity:0}.cdk-drag-animating{transition:transform .25s cubic-bezier(0,0,.2,1)}.vc{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "directive", type: i2.CdkDropList, selector: "[cdkDropList], cdk-drop-list", inputs: ["cdkDropListConnectedTo", "cdkDropListData", "cdkDropListOrientation", "id", "cdkDropListLockAxis", "cdkDropListDisabled", "cdkDropListSortingDisabled", "cdkDropListEnterPredicate", "cdkDropListSortPredicate", "cdkDropListAutoScrollDisabled", "cdkDropListAutoScrollStep", "cdkDropListElementContainer"], outputs: ["cdkDropListDropped", "cdkDropListEntered", "cdkDropListExited", "cdkDropListSorted"], exportAs: ["cdkDropList"] }, { kind: "directive", type: i2.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: i3.InlineSVGDirective, selector: "[inlineSVG]", inputs: ["inlineSVG", "resolveSVGUrl", "replaceContents", "prepend", "injectComponent", "cacheSVG", "setSVGAttributes", "removeSVGAttributes", "forceEvalStyles", "evalScripts", "fallbackImgUrl", "fallbackSVG", "onSVGLoaded"], outputs: ["onSVGInserted", "onSVGFailed"] }, { kind: "component", type: i4.UcFileUploadComponent, selector: "uc-file-upload", inputs: ["multiple", "beforeUpload"], outputs: ["onCancel"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
86
|
+
}
|
|
87
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.0", ngImport: i0, type: UcFileCardListComponent, decorators: [{
|
|
88
|
+
type: Component,
|
|
89
|
+
args: [{ changeDetection: ChangeDetectionStrategy.OnPush, selector: "uc-file-card-list", template: `<div class="main">
|
|
90
|
+
<div class="dropContent" cdkDropList cdkDropListOrientation="mixed" (cdkDropListDropped)="drop($event)">
|
|
91
|
+
@for (item of dataList ; let idx = $index; track idx) {
|
|
92
|
+
<div
|
|
93
|
+
cdkDrag
|
|
94
|
+
class="fileContent"
|
|
95
|
+
[ngStyle]="{
|
|
96
|
+
width:cardSize,
|
|
97
|
+
height:cardSize,
|
|
98
|
+
}"
|
|
99
|
+
>
|
|
100
|
+
@if(item.type==="image"){
|
|
101
|
+
<span class="image-content vc">
|
|
102
|
+
<img [src]="item.fileSrc" />
|
|
103
|
+
</span>
|
|
104
|
+
}@else {
|
|
105
|
+
<span [inlineSVG]="item.imageSrc" cacheSVG="true" class="svg-icon svg-icon-7x vc"></span>
|
|
106
|
+
}
|
|
107
|
+
<div class="mask">
|
|
108
|
+
<div class="maskContent" (click)="doSth($event, 'DOWNLOAD', item)">
|
|
109
|
+
<span class="operating">
|
|
110
|
+
@for (c of actions ; track c) { @if(c.type===item.type||c.type==='any'){
|
|
111
|
+
<a [class]="c.type === 'image' ? 'mr-5' : ''" (click)="doSth($event, c.code, item)">
|
|
112
|
+
<i class="icon-xl" [ngClass]="c.icon"></i>
|
|
113
|
+
</a>
|
|
114
|
+
} }
|
|
115
|
+
</span>
|
|
116
|
+
</div>
|
|
117
|
+
</div>
|
|
118
|
+
</div>
|
|
119
|
+
} @if(allowUpload){
|
|
120
|
+
|
|
121
|
+
<uc-file-upload [multiple]="multiple" [beforeUpload]="beforeUpload" (onCancel)="onUploadCancelCallback()">
|
|
122
|
+
<div
|
|
123
|
+
class="fileContent text-muted"
|
|
124
|
+
[ngStyle]="{
|
|
125
|
+
width:cardSize,
|
|
126
|
+
height:cardSize,
|
|
127
|
+
}"
|
|
128
|
+
>
|
|
129
|
+
<i class="flaticon2-plus icon-xl icon-plus vc"></i>
|
|
130
|
+
</div>
|
|
131
|
+
</uc-file-upload>
|
|
132
|
+
}
|
|
133
|
+
</div>
|
|
134
|
+
</div> `, styles: ["@charset \"UTF-8\";.main .dropContent{display:flex;flex-wrap:wrap}.main .dropContent .fileContent{margin-right:8px;margin-bottom:5px;padding:6px;border:1px solid #cccccc;position:relative}.main .dropContent .fileContent .image-content{width:100%;height:100%}.main .dropContent .fileContent .image-content img{width:100%;height:100%;object-fit:cover}.main .dropContent .fileContent .icon-plus{color:unset}.main .dropContent .fileContent .icon-plus:hover{cursor:pointer}.main .dropContent .fileContent .mask{position:absolute;top:0;left:0;height:100%;width:100%}.main .dropContent .fileContent .mask .maskContent{opacity:0;transition:opacity .2s ease,visibility .2s ease;background:#65656599;height:100%;width:100%;position:relative}.main .dropContent .fileContent .mask .maskContent .operating{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.main .dropContent .fileContent .mask .maskContent .operating a{color:#fff}.main .dropContent .fileContent .mask .maskContent .operating a i{color:unset}.main .dropContent .fileContent .mask:hover .maskContent{opacity:1;visibility:visible}.cdk-drag-preview{border-radius:4px;box-shadow:0 5px 5px -3px #0003,0 8px 10px 1px #00000024,0 3px 14px 2px #0000001f}.cdk-drag-preview .image-content{width:100%;height:100%}.cdk-drag-preview .image-content img{width:100%;height:100%;object-fit:cover}.cdk-drag-preview .maskContent,.cdk-drag-placeholder{opacity:0}.cdk-drag-animating{transition:transform .25s cubic-bezier(0,0,.2,1)}.vc{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}\n"] }]
|
|
135
|
+
}], propDecorators: { cardSize: [{
|
|
136
|
+
type: Input
|
|
137
|
+
}], multiple: [{
|
|
138
|
+
type: Input
|
|
139
|
+
}], allowUpload: [{
|
|
140
|
+
type: Input
|
|
141
|
+
}], beforeUpload: [{
|
|
142
|
+
type: Input
|
|
143
|
+
}], dataList: [{
|
|
144
|
+
type: Input
|
|
145
|
+
}], onUploadCancelClick: [{
|
|
146
|
+
type: Output
|
|
147
|
+
}], onCradClick: [{
|
|
148
|
+
type: Output
|
|
149
|
+
}] } });
|
|
150
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbXktY29tbW9uL3NyYy9saWIvdWMvdWMtZmlsZS1saXN0L2NhcmQtbGlzdC9jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFlLGVBQWUsRUFBRSxNQUFNLHdCQUF3QixDQUFDO0FBQ3RFLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxTQUFTLEVBQUUsWUFBWSxFQUFFLEtBQUssRUFBVSxNQUFNLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFFeEcsT0FBTyxFQUFFLE9BQU8sRUFBRSxNQUFNLFNBQVMsQ0FBQzs7Ozs7O0FBcURsQyxNQUFNLE9BQU8sdUJBQXVCO0lBbkRwQztRQXFEYSxhQUFRLEdBQVksS0FBSyxDQUFDLENBQUMsTUFBTTtRQUNqQyxnQkFBVyxHQUFZLElBQUksQ0FBQyxDQUFDLE1BQU07UUFHbEMsd0JBQW1CLEdBQUcsSUFBSSxZQUFZLEVBQU8sQ0FBQztRQUM5QyxnQkFBVyxHQUFHLElBQUksWUFBWSxFQUFPLENBQUM7UUFFaEQsWUFBTyxHQUFlLE9BQU8sQ0FBQztLQTBCakM7SUF4QkcsUUFBUTtRQUNKLElBQUksQ0FBQyxRQUFRLEdBQUcsSUFBSSxDQUFDLFFBQVEsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLFFBQVEsR0FBRyxJQUFJLENBQUMsQ0FBQyxDQUFDLE9BQU8sQ0FBQztJQUNuRSxDQUFDO0lBRUQsSUFBSSxDQUFDLEtBQTRCO1FBQzdCLElBQUksS0FBSyxDQUFDLGFBQWEsS0FBSyxLQUFLLENBQUMsWUFBWSxFQUFFLENBQUM7WUFDN0MsZUFBZSxDQUFDLElBQUksQ0FBQyxRQUFRLEVBQUUsS0FBSyxDQUFDLGFBQWEsRUFBRSxLQUFLLENBQUMsWUFBWSxDQUFDLENBQUM7WUFDeEUsSUFBSSxDQUFDLFdBQVcsQ0FBQyxJQUFJLENBQUM7Z0JBQ2xCLElBQUksRUFBRSxTQUFTO2dCQUNmLElBQUksRUFBRSxLQUFLLENBQUMsWUFBWTthQUMzQixDQUFDLENBQUM7UUFDUCxDQUFDO0lBQ0wsQ0FBQztJQUNELEtBQUssQ0FBQyxLQUFLLEVBQUUsSUFBSSxFQUFFLElBQUk7UUFDbkIsS0FBSyxDQUFDLGVBQWUsRUFBRSxDQUFDO1FBQ3hCLElBQUksQ0FBQyxXQUFXLENBQUMsSUFBSSxDQUFDO1lBQ2xCLElBQUksRUFBRSxJQUFJO1lBQ1YsSUFBSSxFQUFFLElBQUk7U0FDYixDQUFDLENBQUM7SUFDUCxDQUFDO0lBRUQsc0JBQXNCO1FBQ2xCLElBQUksQ0FBQyxtQkFBbUIsQ0FBQyxJQUFJLEVBQUUsQ0FBQztJQUNwQyxDQUFDOzhHQWxDUSx1QkFBdUI7a0dBQXZCLHVCQUF1QixzUkFoRHRCOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7WUE2Q0Y7OzJGQUdDLHVCQUF1QjtrQkFuRG5DLFNBQVM7c0NBQ1csdUJBQXVCLENBQUMsTUFBTSxZQUNyQyxtQkFBbUIsWUFDbkI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztZQTZDRjs4QkFJQyxRQUFRO3NCQUFoQixLQUFLO2dCQUNHLFFBQVE7c0JBQWhCLEtBQUs7Z0JBQ0csV0FBVztzQkFBbkIsS0FBSztnQkFDRyxZQUFZO3NCQUFwQixLQUFLO2dCQUNHLFFBQVE7c0JBQWhCLEtBQUs7Z0JBQ0ksbUJBQW1CO3NCQUE1QixNQUFNO2dCQUNHLFdBQVc7c0JBQXBCLE1BQU0iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDZGtEcmFnRHJvcCwgbW92ZUl0ZW1JbkFycmF5IH0gZnJvbSBcIkBhbmd1bGFyL2Nkay9kcmFnLWRyb3BcIjtcclxuaW1wb3J0IHsgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIENvbXBvbmVudCwgRXZlbnRFbWl0dGVyLCBJbnB1dCwgT25Jbml0LCBPdXRwdXQgfSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiO1xyXG5pbXBvcnQgXyBmcm9tIFwibG9kYXNoXCI7XHJcbmltcG9ydCB7IGFjdGlvbnMgfSBmcm9tIFwiLi4vZGF0YVwiO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcclxuICAgIHNlbGVjdG9yOiBcInVjLWZpbGUtY2FyZC1saXN0XCIsXHJcbiAgICB0ZW1wbGF0ZTogYDxkaXYgY2xhc3M9XCJtYWluXCI+XHJcbiAgICAgICAgPGRpdiBjbGFzcz1cImRyb3BDb250ZW50XCIgY2RrRHJvcExpc3QgY2RrRHJvcExpc3RPcmllbnRhdGlvbj1cIm1peGVkXCIgKGNka0Ryb3BMaXN0RHJvcHBlZCk9XCJkcm9wKCRldmVudClcIj5cclxuICAgICAgICAgICAgQGZvciAoaXRlbSBvZiBkYXRhTGlzdCA7IGxldCBpZHggPSAkaW5kZXg7IHRyYWNrIGlkeCkge1xyXG4gICAgICAgICAgICA8ZGl2XHJcbiAgICAgICAgICAgICAgICBjZGtEcmFnXHJcbiAgICAgICAgICAgICAgICBjbGFzcz1cImZpbGVDb250ZW50XCJcclxuICAgICAgICAgICAgICAgIFtuZ1N0eWxlXT1cIntcclxuICAgICAgICAgICAgICAgIHdpZHRoOmNhcmRTaXplLFxyXG4gICAgICAgICAgICAgICAgaGVpZ2h0OmNhcmRTaXplLFxyXG4gICAgICAgICAgICAgIH1cIlxyXG4gICAgICAgICAgICA+XHJcbiAgICAgICAgICAgICAgICBAaWYoaXRlbS50eXBlPT09XCJpbWFnZVwiKXtcclxuICAgICAgICAgICAgICAgIDxzcGFuIGNsYXNzPVwiaW1hZ2UtY29udGVudCB2Y1wiPlxyXG4gICAgICAgICAgICAgICAgICAgIDxpbWcgW3NyY109XCJpdGVtLmZpbGVTcmNcIiAvPlxyXG4gICAgICAgICAgICAgICAgPC9zcGFuPlxyXG4gICAgICAgICAgICAgICAgfUBlbHNlIHtcclxuICAgICAgICAgICAgICAgIDxzcGFuIFtpbmxpbmVTVkddPVwiaXRlbS5pbWFnZVNyY1wiIGNhY2hlU1ZHPVwidHJ1ZVwiIGNsYXNzPVwic3ZnLWljb24gc3ZnLWljb24tN3ggdmNcIj48L3NwYW4+XHJcbiAgICAgICAgICAgICAgICB9XHJcbiAgICAgICAgICAgICAgICA8ZGl2IGNsYXNzPVwibWFza1wiPlxyXG4gICAgICAgICAgICAgICAgICAgIDxkaXYgY2xhc3M9XCJtYXNrQ29udGVudFwiIChjbGljayk9XCJkb1N0aCgkZXZlbnQsICdET1dOTE9BRCcsIGl0ZW0pXCI+XHJcbiAgICAgICAgICAgICAgICAgICAgICAgIDxzcGFuIGNsYXNzPVwib3BlcmF0aW5nXCI+XHJcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICBAZm9yIChjIG9mIGFjdGlvbnMgOyB0cmFjayBjKSB7IEBpZihjLnR5cGU9PT1pdGVtLnR5cGV8fGMudHlwZT09PSdhbnknKXtcclxuICAgICAgICAgICAgICAgICAgICAgICAgICAgIDxhIFtjbGFzc109XCJjLnR5cGUgPT09ICdpbWFnZScgPyAnbXItNScgOiAnJ1wiIChjbGljayk9XCJkb1N0aCgkZXZlbnQsIGMuY29kZSwgaXRlbSlcIj5cclxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICA8aSBjbGFzcz1cImljb24teGxcIiBbbmdDbGFzc109XCJjLmljb25cIj48L2k+XHJcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICA8L2E+XHJcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICB9IH1cclxuICAgICAgICAgICAgICAgICAgICAgICAgPC9zcGFuPlxyXG4gICAgICAgICAgICAgICAgICAgIDwvZGl2PlxyXG4gICAgICAgICAgICAgICAgPC9kaXY+XHJcbiAgICAgICAgICAgIDwvZGl2PlxyXG4gICAgICAgICAgICB9IEBpZihhbGxvd1VwbG9hZCl7XHJcblxyXG4gICAgICAgICAgICA8dWMtZmlsZS11cGxvYWQgW211bHRpcGxlXT1cIm11bHRpcGxlXCIgW2JlZm9yZVVwbG9hZF09XCJiZWZvcmVVcGxvYWRcIiAob25DYW5jZWwpPVwib25VcGxvYWRDYW5jZWxDYWxsYmFjaygpXCI+XHJcbiAgICAgICAgICAgICAgICA8ZGl2XHJcbiAgICAgICAgICAgICAgICAgICAgY2xhc3M9XCJmaWxlQ29udGVudCB0ZXh0LW11dGVkXCJcclxuICAgICAgICAgICAgICAgICAgICBbbmdTdHlsZV09XCJ7XHJcbiAgICAgICAgICAgICAgICB3aWR0aDpjYXJkU2l6ZSxcclxuICAgICAgICAgICAgICAgIGhlaWdodDpjYXJkU2l6ZSxcclxuICAgICAgICAgICAgICAgfVwiXHJcbiAgICAgICAgICAgICAgICA+XHJcbiAgICAgICAgICAgICAgICAgICAgPGkgY2xhc3M9XCJmbGF0aWNvbjItcGx1cyBpY29uLXhsIGljb24tcGx1cyB2Y1wiPjwvaT5cclxuICAgICAgICAgICAgICAgIDwvZGl2PlxyXG4gICAgICAgICAgICA8L3VjLWZpbGUtdXBsb2FkPlxyXG4gICAgICAgICAgICB9XHJcbiAgICAgICAgPC9kaXY+XHJcbiAgICA8L2Rpdj4gYCxcclxuICAgIHN0eWxlVXJsczogW1wiY29tcG9uZW50LnNjc3NcIl0sXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBVY0ZpbGVDYXJkTGlzdENvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCB7XHJcbiAgICBASW5wdXQoKSBjYXJkU2l6ZTogc3RyaW5nIHwgbnVtYmVyOyAvL2NhcmTlpKflsI8g6buY6K6kMjAwcHhcclxuICAgIEBJbnB1dCgpIG11bHRpcGxlOiBib29sZWFuID0gZmFsc2U7IC8v5aSa6YCJ5paH5Lu2XHJcbiAgICBASW5wdXQoKSBhbGxvd1VwbG9hZDogYm9vbGVhbiA9IHRydWU7IC8v5YWB6K645LiK5LygXHJcbiAgICBASW5wdXQoKSBiZWZvcmVVcGxvYWQ7XHJcbiAgICBASW5wdXQoKSBkYXRhTGlzdDtcclxuICAgIEBPdXRwdXQoKSBvblVwbG9hZENhbmNlbENsaWNrID0gbmV3IEV2ZW50RW1pdHRlcjxhbnk+KCk7XHJcbiAgICBAT3V0cHV0KCkgb25DcmFkQ2xpY2sgPSBuZXcgRXZlbnRFbWl0dGVyPGFueT4oKTtcclxuXHJcbiAgICBhY3Rpb25zOiBBcnJheTxhbnk+ID0gYWN0aW9ucztcclxuXHJcbiAgICBuZ09uSW5pdCgpOiB2b2lkIHtcclxuICAgICAgICB0aGlzLmNhcmRTaXplID0gdGhpcy5jYXJkU2l6ZSA/IHRoaXMuY2FyZFNpemUgKyBcInB4XCIgOiBcIjE1MHB4XCI7XHJcbiAgICB9XHJcblxyXG4gICAgZHJvcChldmVudDogQ2RrRHJhZ0Ryb3A8c3RyaW5nW10+KSB7XHJcbiAgICAgICAgaWYgKGV2ZW50LnByZXZpb3VzSW5kZXggIT09IGV2ZW50LmN1cnJlbnRJbmRleCkge1xyXG4gICAgICAgICAgICBtb3ZlSXRlbUluQXJyYXkodGhpcy5kYXRhTGlzdCwgZXZlbnQucHJldmlvdXNJbmRleCwgZXZlbnQuY3VycmVudEluZGV4KTtcclxuICAgICAgICAgICAgdGhpcy5vbkNyYWRDbGljay5lbWl0KHtcclxuICAgICAgICAgICAgICAgIGNvZGU6IFwiRFJPUFBFRFwiLFxyXG4gICAgICAgICAgICAgICAgZGF0YTogZXZlbnQuY3VycmVudEluZGV4LFxyXG4gICAgICAgICAgICB9KTtcclxuICAgICAgICB9XHJcbiAgICB9XHJcbiAgICBkb1N0aChldmVudCwgY29kZSwgaXRlbSkge1xyXG4gICAgICAgIGV2ZW50LnN0b3BQcm9wYWdhdGlvbigpO1xyXG4gICAgICAgIHRoaXMub25DcmFkQ2xpY2suZW1pdCh7XHJcbiAgICAgICAgICAgIGNvZGU6IGNvZGUsXHJcbiAgICAgICAgICAgIGRhdGE6IGl0ZW0sXHJcbiAgICAgICAgfSk7XHJcbiAgICB9XHJcblxyXG4gICAgb25VcGxvYWRDYW5jZWxDYWxsYmFjaygpIHtcclxuICAgICAgICB0aGlzLm9uVXBsb2FkQ2FuY2VsQ2xpY2suZW1pdCgpO1xyXG4gICAgfVxyXG59XHJcbiJdfQ==
|
|
@@ -0,0 +1,277 @@
|
|
|
1
|
+
import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output, ViewChildren, } from "@angular/core";
|
|
2
|
+
import _ from "lodash";
|
|
3
|
+
import { forkJoin, tap } from "rxjs";
|
|
4
|
+
import { UcFileCardsCropImageModalComponent } from "./cropImageModal/component";
|
|
5
|
+
import { compressImage } from "../../formly-config/types/avatar/cropImageModal/method";
|
|
6
|
+
import { findFileTypeOption } from "./method";
|
|
7
|
+
import { fileSvgSrc, FLIETYPE } from "./data";
|
|
8
|
+
import { calcNewSeqValue } from "./method";
|
|
9
|
+
import { saveAs } from "file-saver";
|
|
10
|
+
import { AppInjector } from "../../service";
|
|
11
|
+
import { FILE_URL } from "../../service/inject.token";
|
|
12
|
+
import * as i0 from "@angular/core";
|
|
13
|
+
import * as i1 from "../../service";
|
|
14
|
+
import * as i2 from "@angular/common/http";
|
|
15
|
+
import * as i3 from "ng-zorro-antd/image";
|
|
16
|
+
import * as i4 from "./table-list";
|
|
17
|
+
import * as i5 from "./toolbar";
|
|
18
|
+
import * as i6 from "./card-list/component";
|
|
19
|
+
export class UcFileListComponent {
|
|
20
|
+
//传入的数据
|
|
21
|
+
set dataList(list) {
|
|
22
|
+
if (list) {
|
|
23
|
+
this.fileList = list.map(m => {
|
|
24
|
+
return {
|
|
25
|
+
id: m.id,
|
|
26
|
+
fileSrc: this.apiUrl + m.name,
|
|
27
|
+
imageSrc: fileSvgSrc[m.type],
|
|
28
|
+
lineCode: m.lineCode,
|
|
29
|
+
name: m.name,
|
|
30
|
+
type: m.type,
|
|
31
|
+
};
|
|
32
|
+
});
|
|
33
|
+
this.fileList = _.orderBy(this.fileList, "lineCode");
|
|
34
|
+
}
|
|
35
|
+
}
|
|
36
|
+
constructor(cdr, App, http, modalUtils) {
|
|
37
|
+
this.cdr = cdr;
|
|
38
|
+
this.App = App;
|
|
39
|
+
this.http = http;
|
|
40
|
+
this.modalUtils = modalUtils;
|
|
41
|
+
this.apiUrl = AppInjector.get(FILE_URL, ""); // root FILE_URL 文件上传地址
|
|
42
|
+
this.uploadFileTypes = []; //设定允许上传文件类型
|
|
43
|
+
this.mode = "card";
|
|
44
|
+
this.multiple = false; //多选文件
|
|
45
|
+
this.allowUpload = true; //允许上传
|
|
46
|
+
this.toolbarVisible = true; //表头操作可见
|
|
47
|
+
this.fileList = [];
|
|
48
|
+
this.imageGroups = [];
|
|
49
|
+
this.onOk = new EventEmitter();
|
|
50
|
+
this.beforeUpload = async (file, uploadFileList) => {
|
|
51
|
+
// 两种状态 上传文件数量
|
|
52
|
+
// 一个 判断当前文件类型与允许上传的文件类型是否一致 后单笔上传 图片类型 打开编辑框
|
|
53
|
+
// 多个 过滤掉文件类型与允许上传的文件类型不一致的文件 多笔文件上传
|
|
54
|
+
if (uploadFileList.length > 1) {
|
|
55
|
+
if (file === uploadFileList.at(-1)) {
|
|
56
|
+
//最后一个文件时执行所有的文件上传 图片自动压缩200kb以内
|
|
57
|
+
const observableArayy = [];
|
|
58
|
+
for (let index = 0; index < uploadFileList.length; index++) {
|
|
59
|
+
let e = uploadFileList[index];
|
|
60
|
+
const fileTypeOption = findFileTypeOption(e);
|
|
61
|
+
const valid = this.uploadFileTypes.length
|
|
62
|
+
? this.uploadFileTypes.some(item => item == fileTypeOption.type)
|
|
63
|
+
: true;
|
|
64
|
+
if (valid) {
|
|
65
|
+
if (fileTypeOption.type === "image") {
|
|
66
|
+
e = await compressImage(e);
|
|
67
|
+
}
|
|
68
|
+
const o = this.uploadFiles(e, fileTypeOption);
|
|
69
|
+
observableArayy.push(o);
|
|
70
|
+
}
|
|
71
|
+
}
|
|
72
|
+
forkJoin(observableArayy).subscribe();
|
|
73
|
+
}
|
|
74
|
+
}
|
|
75
|
+
else {
|
|
76
|
+
// 获取文件对象
|
|
77
|
+
const _file = (file.originFileObj || file);
|
|
78
|
+
// //找到上传文件是哪个类型的
|
|
79
|
+
const fileTypeOption = findFileTypeOption(file);
|
|
80
|
+
const valid = this.uploadFileTypes.length
|
|
81
|
+
? this.uploadFileTypes.some(item => item == fileTypeOption.type)
|
|
82
|
+
: true;
|
|
83
|
+
if (valid) {
|
|
84
|
+
if (fileTypeOption.type === "image") {
|
|
85
|
+
const reader = new FileReader();
|
|
86
|
+
// 定义文件读取完成后的回调函数
|
|
87
|
+
reader.onload = (e) => {
|
|
88
|
+
this.openEditImageModal({ fileSrc: e.target.result }, "DEFAULT");
|
|
89
|
+
this.cdr.markForCheck();
|
|
90
|
+
};
|
|
91
|
+
// 启动文件读取过程
|
|
92
|
+
reader.readAsDataURL(_file);
|
|
93
|
+
}
|
|
94
|
+
else {
|
|
95
|
+
this.uploadFiles(file, fileTypeOption).subscribe();
|
|
96
|
+
}
|
|
97
|
+
}
|
|
98
|
+
}
|
|
99
|
+
return false;
|
|
100
|
+
};
|
|
101
|
+
}
|
|
102
|
+
onUploadCancelClick() {
|
|
103
|
+
this.openEditImageModal(null, "DEFAULT");
|
|
104
|
+
this.cdr.markForCheck();
|
|
105
|
+
}
|
|
106
|
+
doSth(event) {
|
|
107
|
+
switch (event.code) {
|
|
108
|
+
case "EDIT":
|
|
109
|
+
this.openEditImageModal(event.data);
|
|
110
|
+
break;
|
|
111
|
+
case "DELETE":
|
|
112
|
+
this.deleteFile(event.data);
|
|
113
|
+
break;
|
|
114
|
+
case "DOWNLOAD":
|
|
115
|
+
this.viewFile(event.data);
|
|
116
|
+
break;
|
|
117
|
+
case "DROPPED":
|
|
118
|
+
this.dropFile(event.data);
|
|
119
|
+
break;
|
|
120
|
+
}
|
|
121
|
+
}
|
|
122
|
+
deleteFile(item) {
|
|
123
|
+
this.App.httpClient.delete(item.fileSrc).subscribe();
|
|
124
|
+
this.onOk.emit({
|
|
125
|
+
code: "DELETE",
|
|
126
|
+
id: item.id,
|
|
127
|
+
});
|
|
128
|
+
}
|
|
129
|
+
viewFile(item) {
|
|
130
|
+
switch (item.type) {
|
|
131
|
+
case "image":
|
|
132
|
+
this.openImageBoard(item.fileSrc);
|
|
133
|
+
break;
|
|
134
|
+
case "pdf":
|
|
135
|
+
this.http.get(item.fileSrc, { responseType: "blob" }).subscribe(blob => {
|
|
136
|
+
const pdf = new Blob([blob], { type: "application/pdf;chartset=uTF-8" });
|
|
137
|
+
const url = window.URL.createObjectURL(pdf);
|
|
138
|
+
window.open(url, "_blank");
|
|
139
|
+
//释放内存(确保窗口已打开后执行)
|
|
140
|
+
setTimeout(() => window.URL.revokeObjectURL(url), 1000);
|
|
141
|
+
});
|
|
142
|
+
break;
|
|
143
|
+
default:
|
|
144
|
+
this.downloadFile(item.fileSrc, item.name);
|
|
145
|
+
break;
|
|
146
|
+
}
|
|
147
|
+
}
|
|
148
|
+
/**
|
|
149
|
+
*
|
|
150
|
+
* @param item
|
|
151
|
+
* @param modalType DEFAULT 普通类型 不带有删除 用于上传文件后 打开编辑模式 , IMAGE 带有删除功能 用于图片编辑
|
|
152
|
+
*/
|
|
153
|
+
openEditImageModal(item, modalType) {
|
|
154
|
+
let flieSrc = item?.fileSrc || null;
|
|
155
|
+
if (flieSrc) {
|
|
156
|
+
if (!modalType)
|
|
157
|
+
flieSrc = `${item.fileSrc}?timestamp=${new Date().getTime()}`;
|
|
158
|
+
}
|
|
159
|
+
this.modalUtils.openModal({
|
|
160
|
+
content: UcFileCardsCropImageModalComponent,
|
|
161
|
+
props: {
|
|
162
|
+
imageSrc: flieSrc,
|
|
163
|
+
modalType: modalType,
|
|
164
|
+
onOk: event => this.cropImageModalOnOk(event, item),
|
|
165
|
+
},
|
|
166
|
+
});
|
|
167
|
+
}
|
|
168
|
+
//打开nzimage看板
|
|
169
|
+
openImageBoard(src) {
|
|
170
|
+
this.imageGroups = this.fileList.filter(f => f.type === "image");
|
|
171
|
+
setTimeout(t => {
|
|
172
|
+
const images = this.nzImages.toArray();
|
|
173
|
+
for (let index = 0; index < images.length; index++) {
|
|
174
|
+
const x = images[index];
|
|
175
|
+
if (x.nativeElement.src == src) {
|
|
176
|
+
x.nativeElement.click();
|
|
177
|
+
this.cdr.markForCheck();
|
|
178
|
+
break;
|
|
179
|
+
}
|
|
180
|
+
}
|
|
181
|
+
});
|
|
182
|
+
}
|
|
183
|
+
/**
|
|
184
|
+
* 裁剪对话框 图片编辑 上传 删除功能
|
|
185
|
+
* @param event 对话框返回参数
|
|
186
|
+
* @param item 当前选项的原型
|
|
187
|
+
*/
|
|
188
|
+
async cropImageModalOnOk(event, item) {
|
|
189
|
+
if (event.code === "DELETE") {
|
|
190
|
+
this.App.httpClient.delete(item.fileSrc).subscribe();
|
|
191
|
+
this.onOk.emit({
|
|
192
|
+
code: "DELETE",
|
|
193
|
+
id: item.id,
|
|
194
|
+
});
|
|
195
|
+
}
|
|
196
|
+
else {
|
|
197
|
+
const fileTypeOption = FLIETYPE.find(f => f.type === "image");
|
|
198
|
+
let fileName = item?.name || null;
|
|
199
|
+
this.uploadFiles(event.file, fileTypeOption, fileName).subscribe(r => {
|
|
200
|
+
item.fileSrc = `${item.fileSrc}?timestamp=${new Date().getTime()}`;
|
|
201
|
+
this.cdr.markForCheck();
|
|
202
|
+
});
|
|
203
|
+
}
|
|
204
|
+
}
|
|
205
|
+
/**
|
|
206
|
+
*上传方法
|
|
207
|
+
* @param file 上传所需要的文件
|
|
208
|
+
* @param fileName 文件名
|
|
209
|
+
*/
|
|
210
|
+
uploadFiles(file, fileTypeOption, fileName) {
|
|
211
|
+
let isNew = false;
|
|
212
|
+
if (!fileName) {
|
|
213
|
+
fileName = this.masterId + fileTypeOption.type + Date.now() + fileTypeOption.suffix;
|
|
214
|
+
isNew = true;
|
|
215
|
+
}
|
|
216
|
+
const newFile = file;
|
|
217
|
+
const formData = new FormData();
|
|
218
|
+
formData.append("file", newFile, fileName);
|
|
219
|
+
return this.App.httpClient.post(this.apiUrl, formData).pipe(tap(x => {
|
|
220
|
+
if (isNew) {
|
|
221
|
+
this.onOk.emit({
|
|
222
|
+
code: "UPLOAD",
|
|
223
|
+
fileName: fileName,
|
|
224
|
+
lineCode: this.fileList.length + 1,
|
|
225
|
+
type: fileTypeOption.type,
|
|
226
|
+
});
|
|
227
|
+
}
|
|
228
|
+
}));
|
|
229
|
+
}
|
|
230
|
+
downloadFile(url, name) {
|
|
231
|
+
this.http.get(url, { responseType: "blob" }).subscribe(blob => {
|
|
232
|
+
saveAs(blob, name); // 你可以指定任何你想要的文件名
|
|
233
|
+
});
|
|
234
|
+
}
|
|
235
|
+
dropFile(currentIndex) {
|
|
236
|
+
let lineCode = calcNewSeqValue(currentIndex, this.fileList, "lineCode");
|
|
237
|
+
this.fileList[currentIndex].lineCode = lineCode;
|
|
238
|
+
this.onOk.emit({
|
|
239
|
+
code: "UPDATE",
|
|
240
|
+
id: this.fileList[currentIndex].id,
|
|
241
|
+
updateData: [
|
|
242
|
+
{
|
|
243
|
+
key: "lineCode",
|
|
244
|
+
value: lineCode,
|
|
245
|
+
},
|
|
246
|
+
],
|
|
247
|
+
});
|
|
248
|
+
}
|
|
249
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.0", ngImport: i0, type: UcFileListComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i1.Application }, { token: i2.HttpClient }, { token: i1.ModalUtils }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
250
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.1.0", type: UcFileListComponent, selector: "uc-file-list", inputs: { uploadFileTypes: "uploadFileTypes", mode: "mode", cardSize: "cardSize", masterId: "masterId", multiple: "multiple", allowUpload: "allowUpload", toolbarVisible: "toolbarVisible", dataList: "dataList" }, outputs: { onOk: "onOk" }, viewQueries: [{ propertyName: "nzImages", predicate: ["nzImage"], descendants: true }], ngImport: i0, template: "@if(toolbarVisible){\r\n<uc-file-toolbar\r\n [(mode)]=\"mode\"\r\n [beforeUpload]=\"beforeUpload\"\r\n [allowUpload]=\"allowUpload\"\r\n [multiple]=\"multiple\"\r\n (onUploadCancelClick)=\"onUploadCancelClick()\"\r\n/>\r\n\r\n} @if(mode === 'card'){\r\n<uc-file-card-list\r\n [dataList]=\"fileList\"\r\n [beforeUpload]=\"beforeUpload\"\r\n [allowUpload]=\"allowUpload\"\r\n [multiple]=\"multiple\"\r\n (onUploadCancelClick)=\"onUploadCancelClick()\"\r\n (onCradClick)=\"doSth($event)\"\r\n/>\r\n}@else{\r\n<uc-file-table-list\r\n [dataList]=\"fileList\"\r\n [beforeUpload]=\"beforeUpload\"\r\n [allowUpload]=\"toolbarVisible?false: allowUpload \"\r\n [multiple]=\"multiple\"\r\n (onTableRowClick)=\"doSth($event)\"\r\n (onUploadCancelClick)=\"onUploadCancelClick()\"\r\n/>\r\n\r\n} @if(imageGroups.length){\r\n<nz-image-group style=\"display: none\" class=\"nzImage\">\r\n @for (item of imageGroups; track item) {\r\n <img nz-image #nzImage [nzSrc]=\"item.fileSrc\" (close)=\"imageGroups=[]\" />\r\n }\r\n</nz-image-group>\r\n}\r\n", dependencies: [{ kind: "directive", type: i3.NzImageDirective, selector: "img[nz-image]", inputs: ["nzSrc", "nzSrcset", "nzDisablePreview", "nzFallback", "nzPlaceholder", "nzScaleStep"], exportAs: ["nzImage"] }, { kind: "component", type: i3.NzImageGroupComponent, selector: "nz-image-group", inputs: ["nzScaleStep"], exportAs: ["nzImageGroup"] }, { kind: "component", type: i4.UcFileTableListComponent, selector: "uc-file-table-list", inputs: ["dataList", "multiple", "beforeUpload", "allowUpload"], outputs: ["onTableRowClick", "onUploadCancelClick"] }, { kind: "component", type: i5.UcFileToolbarComponent, selector: "uc-file-toolbar", inputs: ["mode", "beforeUpload", "multiple", "allowUpload"], outputs: ["modeChange", "onUploadCancelClick"] }, { kind: "component", type: i6.UcFileCardListComponent, selector: "uc-file-card-list", inputs: ["cardSize", "multiple", "allowUpload", "beforeUpload", "dataList"], outputs: ["onUploadCancelClick", "onCradClick"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
251
|
+
}
|
|
252
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.0", ngImport: i0, type: UcFileListComponent, decorators: [{
|
|
253
|
+
type: Component,
|
|
254
|
+
args: [{ selector: "uc-file-list", changeDetection: ChangeDetectionStrategy.OnPush, template: "@if(toolbarVisible){\r\n<uc-file-toolbar\r\n [(mode)]=\"mode\"\r\n [beforeUpload]=\"beforeUpload\"\r\n [allowUpload]=\"allowUpload\"\r\n [multiple]=\"multiple\"\r\n (onUploadCancelClick)=\"onUploadCancelClick()\"\r\n/>\r\n\r\n} @if(mode === 'card'){\r\n<uc-file-card-list\r\n [dataList]=\"fileList\"\r\n [beforeUpload]=\"beforeUpload\"\r\n [allowUpload]=\"allowUpload\"\r\n [multiple]=\"multiple\"\r\n (onUploadCancelClick)=\"onUploadCancelClick()\"\r\n (onCradClick)=\"doSth($event)\"\r\n/>\r\n}@else{\r\n<uc-file-table-list\r\n [dataList]=\"fileList\"\r\n [beforeUpload]=\"beforeUpload\"\r\n [allowUpload]=\"toolbarVisible?false: allowUpload \"\r\n [multiple]=\"multiple\"\r\n (onTableRowClick)=\"doSth($event)\"\r\n (onUploadCancelClick)=\"onUploadCancelClick()\"\r\n/>\r\n\r\n} @if(imageGroups.length){\r\n<nz-image-group style=\"display: none\" class=\"nzImage\">\r\n @for (item of imageGroups; track item) {\r\n <img nz-image #nzImage [nzSrc]=\"item.fileSrc\" (close)=\"imageGroups=[]\" />\r\n }\r\n</nz-image-group>\r\n}\r\n" }]
|
|
255
|
+
}], ctorParameters: () => [{ type: i0.ChangeDetectorRef }, { type: i1.Application }, { type: i2.HttpClient }, { type: i1.ModalUtils }], propDecorators: { uploadFileTypes: [{
|
|
256
|
+
type: Input
|
|
257
|
+
}], mode: [{
|
|
258
|
+
type: Input
|
|
259
|
+
}], cardSize: [{
|
|
260
|
+
type: Input
|
|
261
|
+
}], masterId: [{
|
|
262
|
+
type: Input
|
|
263
|
+
}], multiple: [{
|
|
264
|
+
type: Input
|
|
265
|
+
}], allowUpload: [{
|
|
266
|
+
type: Input
|
|
267
|
+
}], toolbarVisible: [{
|
|
268
|
+
type: Input
|
|
269
|
+
}], dataList: [{
|
|
270
|
+
type: Input
|
|
271
|
+
}], nzImages: [{
|
|
272
|
+
type: ViewChildren,
|
|
273
|
+
args: ["nzImage"]
|
|
274
|
+
}], onOk: [{
|
|
275
|
+
type: Output
|
|
276
|
+
}] } });
|
|
277
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"component.js","sourceRoot":"","sources":["../../../../../../projects/my-common/src/lib/uc/uc-file-list/component.ts","../../../../../../projects/my-common/src/lib/uc/uc-file-list/component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n    ChangeDetectionStrategy,\r\n    ChangeDetectorRef,\r\n    Component,\r\n    ElementRef,\r\n    EventEmitter,\r\n    Input,\r\n    Output,\r\n    QueryList,\r\n    ViewChildren,\r\n} from \"@angular/core\";\r\nimport _ from \"lodash\";\r\nimport { NzUploadFile } from \"ng-zorro-antd/upload\";\r\nimport { forkJoin, Observable, tap } from \"rxjs\";\r\n\r\nimport { UcFileCardsCropImageModalComponent } from \"./cropImageModal/component\";\r\nimport { compressImage } from \"../../formly-config/types/avatar/cropImageModal/method\";\r\nimport { findFileTypeOption } from \"./method\";\r\nimport { fileSvgSrc, FLIETYPE } from \"./data\";\r\nimport { model, uploadFileType } from \"./type\";\r\nimport { calcNewSeqValue } from \"./method\";\r\nimport { saveAs } from \"file-saver\";\r\nimport { HttpClient } from \"@angular/common/http\";\r\nimport { AppInjector, Application, ModalUtils } from \"../../service\";\r\nimport { FILE_URL } from \"../../service/inject.token\";\r\n\r\n@Component({\r\n    selector: \"uc-file-list\",\r\n    templateUrl: \"./component.html\",\r\n    changeDetection: ChangeDetectionStrategy.OnPush,\r\n})\r\nexport class UcFileListComponent {\r\n    apiUrl: string = AppInjector.get(FILE_URL, \"\"); // root FILE_URL 文件上传地址\r\n    @Input() uploadFileTypes: Array<uploadFileType> = []; //设定允许上传文件类型\r\n    @Input() mode: \"card\" | \"list\" = \"card\";\r\n    @Input() cardSize: string | number; //card大小 默认200px\r\n    @Input() masterId: string | number; //文件识别id\r\n    @Input() multiple: boolean = false; //多选文件\r\n    @Input() allowUpload: boolean = true; //允许上传\r\n    @Input() toolbarVisible: boolean = true; //表头操作可见\r\n    //传入的数据\r\n    @Input() set dataList(list: Array<model>) {\r\n        if (list) {\r\n            this.fileList = list.map(m => {\r\n                return {\r\n                    id: m.id,\r\n                    fileSrc: this.apiUrl + m.name,\r\n                    imageSrc: fileSvgSrc[m.type],\r\n                    lineCode: m.lineCode,\r\n                    name: m.name,\r\n                    type: m.type,\r\n                };\r\n            });\r\n            this.fileList = _.orderBy(this.fileList, \"lineCode\");\r\n        }\r\n    }\r\n\r\n    fileTypeOption; //文件类型 选项 包含 后缀 类型等\r\n    fileList: Array<any> = [];\r\n    imageGroups: Array<any> = [];\r\n\r\n    @ViewChildren(\"nzImage\") nzImages!: QueryList<ElementRef>;\r\n\r\n    @Output() onOk = new EventEmitter<any>();\r\n    beforeUpload = async (file: NzUploadFile, uploadFileList: NzUploadFile[]) => {\r\n        // 两种状态 上传文件数量\r\n        // 一个 判断当前文件类型与允许上传的文件类型是否一致 后单笔上传 图片类型 打开编辑框\r\n        // 多个 过滤掉文件类型与允许上传的文件类型不一致的文件 多笔文件上传\r\n\r\n        if (uploadFileList.length > 1) {\r\n            if (file === uploadFileList.at(-1)) {\r\n                //最后一个文件时执行所有的文件上传 图片自动压缩200kb以内\r\n                const observableArayy: Observable<any>[] = [];\r\n                for (let index = 0; index < uploadFileList.length; index++) {\r\n                    let e = uploadFileList[index];\r\n                    const fileTypeOption = findFileTypeOption(e);\r\n                    const valid = this.uploadFileTypes.length\r\n                        ? this.uploadFileTypes.some(item => item == fileTypeOption.type)\r\n                        : true;\r\n                    if (valid) {\r\n                        if (fileTypeOption.type === \"image\") {\r\n                            e = await compressImage(e);\r\n                        }\r\n                        const o = this.uploadFiles(e, fileTypeOption);\r\n                        observableArayy.push(o);\r\n                    }\r\n                }\r\n                forkJoin(observableArayy).subscribe();\r\n            }\r\n        } else {\r\n            // 获取文件对象\r\n            const _file = (file.originFileObj || file) as File;\r\n            // //找到上传文件是哪个类型的\r\n            const fileTypeOption = findFileTypeOption(file);\r\n\r\n            const valid = this.uploadFileTypes.length\r\n                ? this.uploadFileTypes.some(item => item == fileTypeOption.type)\r\n                : true;\r\n            if (valid) {\r\n                if (fileTypeOption.type === \"image\") {\r\n                    const reader = new FileReader();\r\n                    // 定义文件读取完成后的回调函数\r\n                    reader.onload = (e: any) => {\r\n                        this.openEditImageModal({ fileSrc: e.target.result }, \"DEFAULT\");\r\n                        this.cdr.markForCheck();\r\n                    };\r\n                    // 启动文件读取过程\r\n                    reader.readAsDataURL(_file);\r\n                } else {\r\n                    this.uploadFiles(file, fileTypeOption).subscribe();\r\n                }\r\n            }\r\n        }\r\n        return false;\r\n    };\r\n\r\n    constructor(\r\n        private cdr: ChangeDetectorRef,\r\n        private App: Application,\r\n        private http: HttpClient,\r\n        private modalUtils: ModalUtils\r\n    ) {}\r\n\r\n    onUploadCancelClick() {\r\n        this.openEditImageModal(null, \"DEFAULT\");\r\n        this.cdr.markForCheck();\r\n    }\r\n\r\n    doSth(event) {\r\n        switch (event.code) {\r\n            case \"EDIT\":\r\n                this.openEditImageModal(event.data);\r\n                break;\r\n            case \"DELETE\":\r\n                this.deleteFile(event.data);\r\n                break;\r\n            case \"DOWNLOAD\":\r\n                this.viewFile(event.data);\r\n                break;\r\n            case \"DROPPED\":\r\n                this.dropFile(event.data);\r\n                break;\r\n        }\r\n    }\r\n\r\n    deleteFile(item) {\r\n        this.App.httpClient.delete(item.fileSrc).subscribe();\r\n        this.onOk.emit({\r\n            code: \"DELETE\",\r\n            id: item.id,\r\n        });\r\n    }\r\n\r\n    viewFile(item) {\r\n        switch (item.type) {\r\n            case \"image\":\r\n                this.openImageBoard(item.fileSrc);\r\n                break;\r\n            case \"pdf\":\r\n                this.http.get(item.fileSrc, { responseType: \"blob\" }).subscribe(blob => {\r\n                    const pdf = new Blob([blob], { type: \"application/pdf;chartset=uTF-8\" });\r\n                    const url = window.URL.createObjectURL(pdf);\r\n                    window.open(url, \"_blank\");\r\n                    //释放内存（确保窗口已打开后执行）\r\n                    setTimeout(() => window.URL.revokeObjectURL(url), 1000);\r\n                });\r\n                break;\r\n            default:\r\n                this.downloadFile(item.fileSrc, item.name);\r\n                break;\r\n        }\r\n    }\r\n\r\n    /**\r\n     *\r\n     * @param item\r\n     * @param modalType  DEFAULT 普通类型 不带有删除 用于上传文件后 打开编辑模式 , IMAGE 带有删除功能 用于图片编辑\r\n     */\r\n    openEditImageModal(item, modalType?) {\r\n        let flieSrc = item?.fileSrc || null;\r\n        if (flieSrc) {\r\n            if (!modalType) flieSrc = `${item.fileSrc}?timestamp=${new Date().getTime()}`;\r\n        }\r\n\r\n        this.modalUtils.openModal({\r\n            content: UcFileCardsCropImageModalComponent,\r\n            props: {\r\n                imageSrc: flieSrc,\r\n                modalType: modalType,\r\n                onOk: event => this.cropImageModalOnOk(event, item),\r\n            },\r\n        });\r\n    }\r\n\r\n    //打开nzimage看板\r\n    openImageBoard(src) {\r\n        this.imageGroups = this.fileList.filter(f => f.type === \"image\");\r\n        setTimeout(t => {\r\n            const images = this.nzImages.toArray();\r\n            for (let index = 0; index < images.length; index++) {\r\n                const x = images[index];\r\n                if (x.nativeElement.src == src) {\r\n                    x.nativeElement.click();\r\n                    this.cdr.markForCheck();\r\n                    break;\r\n                }\r\n            }\r\n        });\r\n    }\r\n\r\n    /**\r\n     * 裁剪对话框 图片编辑 上传 删除功能\r\n     * @param event 对话框返回参数\r\n     * @param item 当前选项的原型\r\n     */\r\n    async cropImageModalOnOk(event, item?) {\r\n        if (event.code === \"DELETE\") {\r\n            this.App.httpClient.delete(item.fileSrc).subscribe();\r\n            this.onOk.emit({\r\n                code: \"DELETE\",\r\n                id: item.id,\r\n            });\r\n        } else {\r\n            const fileTypeOption = FLIETYPE.find(f => f.type === \"image\");\r\n            let fileName = item?.name || null;\r\n            this.uploadFiles(event.file, fileTypeOption, fileName).subscribe(r => {\r\n                item.fileSrc = `${item.fileSrc}?timestamp=${new Date().getTime()}`;\r\n                this.cdr.markForCheck();\r\n            });\r\n        }\r\n    }\r\n    /**\r\n     *上传方法\r\n     * @param file 上传所需要的文件\r\n     * @param fileName 文件名\r\n     */\r\n    uploadFiles(file, fileTypeOption, fileName?) {\r\n        let isNew = false;\r\n        if (!fileName) {\r\n            fileName = this.masterId + fileTypeOption.type + Date.now() + fileTypeOption.suffix;\r\n            isNew = true;\r\n        }\r\n        const newFile = file;\r\n        const formData = new FormData();\r\n        formData.append(\"file\", newFile, fileName);\r\n        return this.App.httpClient.post(this.apiUrl, formData).pipe(\r\n            tap(x => {\r\n                if (isNew) {\r\n                    this.onOk.emit({\r\n                        code: \"UPLOAD\",\r\n                        fileName: fileName,\r\n                        lineCode: this.fileList.length + 1,\r\n                        type: fileTypeOption.type,\r\n                    });\r\n                }\r\n            })\r\n        );\r\n    }\r\n\r\n    downloadFile(url: string, name) {\r\n        this.http.get(url, { responseType: \"blob\" }).subscribe(blob => {\r\n            saveAs(blob, name); // 你可以指定任何你想要的文件名\r\n        });\r\n    }\r\n\r\n    dropFile(currentIndex) {\r\n        let lineCode = calcNewSeqValue(currentIndex, this.fileList, \"lineCode\");\r\n        this.fileList[currentIndex].lineCode = lineCode;\r\n        this.onOk.emit({\r\n            code: \"UPDATE\",\r\n            id: this.fileList[currentIndex].id,\r\n            updateData: [\r\n                {\r\n                    key: \"lineCode\",\r\n                    value: lineCode,\r\n                },\r\n            ],\r\n        });\r\n    }\r\n}\r\n","@if(toolbarVisible){\r\n<uc-file-toolbar\r\n    [(mode)]=\"mode\"\r\n    [beforeUpload]=\"beforeUpload\"\r\n    [allowUpload]=\"allowUpload\"\r\n    [multiple]=\"multiple\"\r\n    (onUploadCancelClick)=\"onUploadCancelClick()\"\r\n/>\r\n\r\n} @if(mode === 'card'){\r\n<uc-file-card-list\r\n    [dataList]=\"fileList\"\r\n    [beforeUpload]=\"beforeUpload\"\r\n    [allowUpload]=\"allowUpload\"\r\n    [multiple]=\"multiple\"\r\n    (onUploadCancelClick)=\"onUploadCancelClick()\"\r\n    (onCradClick)=\"doSth($event)\"\r\n/>\r\n}@else{\r\n<uc-file-table-list\r\n    [dataList]=\"fileList\"\r\n    [beforeUpload]=\"beforeUpload\"\r\n    [allowUpload]=\"toolbarVisible?false: allowUpload \"\r\n    [multiple]=\"multiple\"\r\n    (onTableRowClick)=\"doSth($event)\"\r\n    (onUploadCancelClick)=\"onUploadCancelClick()\"\r\n/>\r\n\r\n} @if(imageGroups.length){\r\n<nz-image-group style=\"display: none\" class=\"nzImage\">\r\n    @for (item of imageGroups; track item) {\r\n    <img nz-image #nzImage [nzSrc]=\"item.fileSrc\" (close)=\"imageGroups=[]\" />\r\n    }\r\n</nz-image-group>\r\n}\r\n"]}
|