atr-components 0.2.417 → 2.0.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/atr-components.module.d.ts +9 -9
- package/atr-public-api.d.ts +53 -53
- package/core/animations/animations.d.ts +1 -1
- package/core/animations/fly-in.d.ts +1 -1
- package/core/animations/scroll-screen.d.ts +1 -1
- package/core/auth/auth.guard.d.ts +11 -11
- package/core/base/atr-common.d.ts +347 -347
- package/core/directive/error-img.directive.d.ts +10 -10
- package/core/directive/hq-spin.directive.d.ts +13 -13
- package/core/directive/role.directive.d.ts +16 -16
- package/core/interceptor/base.interceptor.d.ts +17 -17
- package/core/ngz-module/cus-zorro-antd.module.d.ts +75 -75
- package/core/pipe/china-num.pipe.d.ts +7 -7
- package/core/pipe/count.pipe.d.ts +7 -7
- package/core/pipe/day.pipe.d.ts +8 -8
- package/core/pipe/defaultVal.pipe.d.ts +7 -7
- package/core/pipe/dicts.pipe.d.ts +10 -10
- package/core/pipe/image-pipe.pipe.d.ts +8 -8
- package/core/pipe/is-empty.pipe.d.ts +7 -7
- package/core/pipe/is-not-empty.pipe.d.ts +7 -7
- package/core/pipe/oss.pipe.d.ts +7 -7
- package/core/pipe/ossStatic.pipe.d.ts +7 -7
- package/core/pipe/pipe-module.module.d.ts +21 -21
- package/core/pipe/remove-html.pipe.d.ts +10 -10
- package/core/pipe/safe-compute.pipe.d.ts +7 -7
- package/core/pipe/safe-html.pipe.d.ts +10 -10
- package/core/pipe/safe-url.pipe.d.ts +10 -10
- package/core/routereuse/atr-reuse-strategy.d.ts +19 -19
- package/core/services/dict/dict.service.d.ts +20 -20
- package/core/services/http.service.d.ts +31 -31
- package/core/services/menu.service.d.ts +29 -29
- package/core/services/upload-oss.service.d.ts +14 -14
- package/core/utils/ToolsUtil.d.ts +180 -180
- package/core/utils/localstorage.util.d.ts +15 -15
- package/core/utils/sessionstorage.util.d.ts +15 -15
- package/{esm2020 → esm2022}/atr-components.mjs +4 -4
- package/esm2022/atr-components.module.mjs +36 -0
- package/{esm2020 → esm2022}/atr-public-api.mjs +54 -54
- package/{esm2020 → esm2022}/core/animations/animations.mjs +9 -9
- package/{esm2020 → esm2022}/core/animations/fly-in.mjs +18 -18
- package/{esm2020 → esm2022}/core/animations/scroll-screen.mjs +22 -22
- package/{esm2020 → esm2022}/core/auth/auth.guard.mjs +37 -37
- package/esm2022/core/base/atr-common.mjs +47 -0
- package/{esm2020 → esm2022}/core/directive/error-img.directive.mjs +31 -31
- package/{esm2020 → esm2022}/core/directive/hq-spin.directive.mjs +48 -48
- package/esm2022/core/directive/role.directive.mjs +69 -0
- package/{esm2020 → esm2022}/core/interceptor/base.interceptor.mjs +165 -165
- package/{esm2020 → esm2022}/core/ngz-module/cus-zorro-antd.module.mjs +292 -292
- package/{esm2020 → esm2022}/core/pipe/china-num.pipe.mjs +36 -36
- package/{esm2020 → esm2022}/core/pipe/count.pipe.mjs +34 -34
- package/{esm2020 → esm2022}/core/pipe/day.pipe.mjs +24 -24
- package/{esm2020 → esm2022}/core/pipe/defaultVal.pipe.mjs +23 -23
- package/{esm2020 → esm2022}/core/pipe/dicts.pipe.mjs +28 -28
- package/{esm2020 → esm2022}/core/pipe/image-pipe.pipe.mjs +17 -17
- package/{esm2020 → esm2022}/core/pipe/is-empty.pipe.mjs +20 -20
- package/{esm2020 → esm2022}/core/pipe/is-not-empty.pipe.mjs +17 -17
- package/{esm2020 → esm2022}/core/pipe/oss.pipe.mjs +17 -17
- package/{esm2020 → esm2022}/core/pipe/ossStatic.pipe.mjs +17 -17
- package/esm2022/core/pipe/pipe-module.module.mjs +38 -0
- package/{esm2020 → esm2022}/core/pipe/remove-html.pipe.mjs +21 -21
- package/{esm2020 → esm2022}/core/pipe/safe-compute.pipe.mjs +23 -23
- package/{esm2020 → esm2022}/core/pipe/safe-html.pipe.mjs +20 -20
- package/{esm2020 → esm2022}/core/pipe/safe-url.pipe.mjs +20 -20
- package/esm2022/core/routereuse/atr-reuse-strategy.mjs +79 -0
- package/esm2022/core/services/dict/dict.service.mjs +152 -0
- package/{esm2020 → esm2022}/core/services/http.service.mjs +306 -306
- package/{esm2020 → esm2022}/core/services/menu.service.mjs +130 -130
- package/{esm2020 → esm2022}/core/services/upload-oss.service.mjs +74 -74
- package/esm2022/core/utils/ToolsUtil.mjs +622 -0
- package/{esm2020 → esm2022}/core/utils/localstorage.util.mjs +94 -94
- package/{esm2020 → esm2022}/core/utils/sessionstorage.util.mjs +72 -72
- package/{esm2020 → esm2022}/lib/hello/hello.component.mjs +15 -15
- package/esm2022/lib/hello/hello.module.mjs +20 -0
- package/esm2022/lib/shared/atr-shared.module.mjs +204 -0
- package/esm2022/lib/shared/echarts/echarts.component.mjs +77 -0
- package/esm2022/lib/shared/form/form.component.mjs +574 -0
- package/esm2022/lib/shared/img-canvas/img-canvas.component.mjs +132 -0
- package/esm2022/lib/shared/local-upload/local-upload.component.mjs +68 -0
- package/esm2022/lib/shared/quill-editor/quill-editor.component.mjs +248 -0
- package/esm2022/lib/shared/select-icons/select-icons.component.mjs +90 -0
- package/{esm2020 → esm2022}/lib/shared/select-tree/select-tree.component.mjs +55 -55
- package/{esm2020 → esm2022}/lib/shared/service/busi.service.mjs +69 -69
- package/{esm2020 → esm2022}/lib/shared/share.service.mjs +107 -107
- package/esm2022/lib/shared/table/table-form-item/table-form-item.component.mjs +96 -0
- package/esm2022/lib/shared/table/table-td/table-td.component.mjs +165 -0
- package/esm2022/lib/shared/table/table.component.mjs +749 -0
- package/{esm2020 → esm2022}/lib/shared/upload/upload.component.mjs +274 -274
- package/{esm2020 → esm2022}/lib/shared/validators/atr-validtors.mjs +8 -8
- package/esm2022/lib/shared/video/video.component.mjs +16 -0
- package/esm2022/lib/shared/view-form/view-form.component.mjs +181 -0
- package/{fesm2020 → fesm2022}/atr-components.mjs +5311 -5312
- package/fesm2022/atr-components.mjs.map +1 -0
- package/{atr-components.d.ts → index.d.ts} +5 -5
- package/lib/hello/hello.component.d.ts +8 -8
- package/lib/hello/hello.module.d.ts +8 -8
- package/lib/shared/atr-shared.module.d.ts +36 -33
- package/lib/shared/echarts/echarts.component.d.ts +34 -34
- package/lib/shared/form/form.component.d.ts +45 -45
- package/lib/shared/img-canvas/img-canvas.component.d.ts +28 -28
- package/lib/shared/local-upload/local-upload.component.d.ts +22 -22
- package/lib/shared/quill-editor/quill-editor.component.d.ts +45 -45
- package/lib/shared/select-icons/select-icons.component.d.ts +24 -24
- package/lib/shared/select-tree/select-tree.component.d.ts +23 -23
- package/lib/shared/service/busi.service.d.ts +20 -20
- package/lib/shared/share.service.d.ts +14 -14
- package/lib/shared/table/table-form-item/table-form-item.component.d.ts +25 -25
- package/lib/shared/table/table-td/table-td.component.d.ts +26 -26
- package/lib/shared/table/table.component.d.ts +94 -94
- package/lib/shared/upload/upload.component.d.ts +53 -53
- package/lib/shared/validators/atr-validtors.d.ts +2 -2
- package/lib/shared/video/video.component.d.ts +7 -7
- package/lib/shared/view-form/view-form.component.d.ts +28 -28
- package/package.json +14 -22
- package/esm2020/atr-components.module.mjs +0 -38
- package/esm2020/core/base/atr-common.mjs +0 -47
- package/esm2020/core/directive/role.directive.mjs +0 -69
- package/esm2020/core/pipe/pipe-module.module.mjs +0 -40
- package/esm2020/core/routereuse/atr-reuse-strategy.mjs +0 -79
- package/esm2020/core/services/dict/dict.service.mjs +0 -152
- package/esm2020/core/utils/ToolsUtil.mjs +0 -622
- package/esm2020/lib/hello/hello.module.mjs +0 -22
- package/esm2020/lib/shared/atr-shared.module.mjs +0 -199
- package/esm2020/lib/shared/echarts/echarts.component.mjs +0 -77
- package/esm2020/lib/shared/form/form.component.mjs +0 -574
- package/esm2020/lib/shared/img-canvas/img-canvas.component.mjs +0 -132
- package/esm2020/lib/shared/local-upload/local-upload.component.mjs +0 -68
- package/esm2020/lib/shared/quill-editor/quill-editor.component.mjs +0 -248
- package/esm2020/lib/shared/select-icons/select-icons.component.mjs +0 -90
- package/esm2020/lib/shared/table/table-form-item/table-form-item.component.mjs +0 -96
- package/esm2020/lib/shared/table/table-td/table-td.component.mjs +0 -165
- package/esm2020/lib/shared/table/table.component.mjs +0 -749
- package/esm2020/lib/shared/video/video.component.mjs +0 -15
- package/esm2020/lib/shared/view-form/view-form.component.mjs +0 -181
- package/fesm2015/atr-components.mjs +0 -5522
- package/fesm2015/atr-components.mjs.map +0 -1
- package/fesm2020/atr-components.mjs.map +0 -1
|
@@ -1,132 +0,0 @@
|
|
|
1
|
-
import { Component, EventEmitter, Input, Output, ViewChild } from '@angular/core';
|
|
2
|
-
import * as i0 from "@angular/core";
|
|
3
|
-
export class ImgCanvasComponent {
|
|
4
|
-
constructor(elementRef) {
|
|
5
|
-
this.elementRef = elementRef;
|
|
6
|
-
this.needTime = false;
|
|
7
|
-
this.width = 800;
|
|
8
|
-
this.height = 800;
|
|
9
|
-
this.clipArr = [];
|
|
10
|
-
this.rotateNum = 0;
|
|
11
|
-
this.loadOver = new EventEmitter();
|
|
12
|
-
this.needContextmenu = false;
|
|
13
|
-
}
|
|
14
|
-
set url(url) {
|
|
15
|
-
// if (url && url.indexOf('?v=') < 0) {
|
|
16
|
-
// if (url.indexOf("?") < 0) {
|
|
17
|
-
// url += "?";
|
|
18
|
-
//
|
|
19
|
-
// }
|
|
20
|
-
// url += "v=" + new Date().getTime()
|
|
21
|
-
// }
|
|
22
|
-
this.imgUrl = url;
|
|
23
|
-
}
|
|
24
|
-
ngOnInit() {
|
|
25
|
-
}
|
|
26
|
-
getCanvasFull() {
|
|
27
|
-
let imgW = this.img.width; //图片的宽
|
|
28
|
-
let imgH = this.img.height; //图片的高
|
|
29
|
-
let cW = this.width;
|
|
30
|
-
let cH = this.height;
|
|
31
|
-
let rateW = imgH / imgW; //比例
|
|
32
|
-
let rateH = imgW / imgH; //比例
|
|
33
|
-
if (imgW > imgH) {
|
|
34
|
-
imgW = this.width;
|
|
35
|
-
imgH = imgW * rateW;
|
|
36
|
-
if (imgH > cH) {
|
|
37
|
-
imgH = cH;
|
|
38
|
-
imgW = imgH * rateH;
|
|
39
|
-
}
|
|
40
|
-
}
|
|
41
|
-
else {
|
|
42
|
-
imgH = this.height;
|
|
43
|
-
imgW = imgH * rateH;
|
|
44
|
-
if (imgW > cW) {
|
|
45
|
-
imgW = cW;
|
|
46
|
-
imgH = imgW * rateW;
|
|
47
|
-
}
|
|
48
|
-
}
|
|
49
|
-
// imgH = this.canvasDom.offsetHeight
|
|
50
|
-
// imgW = this.canvasDom.offsetWidth
|
|
51
|
-
// let canvasH = imgH * rate
|
|
52
|
-
// if (canvasH > this.height) {
|
|
53
|
-
// canvasH = this.height
|
|
54
|
-
// rate = canvasH / imgH
|
|
55
|
-
// canvasW = imgW * rate
|
|
56
|
-
// }
|
|
57
|
-
console.log("图片宽高", imgW + ";" + imgH);
|
|
58
|
-
return {
|
|
59
|
-
imgW: imgW,
|
|
60
|
-
imgH: imgH
|
|
61
|
-
};
|
|
62
|
-
}
|
|
63
|
-
initImg(needSession = true) {
|
|
64
|
-
this.canvasDom = this.canvas1.nativeElement;
|
|
65
|
-
// this.canvasDom = document.getElementById(this.canvasId);
|
|
66
|
-
//检测支持性
|
|
67
|
-
if (!this.canvasDom.getContext('2d'))
|
|
68
|
-
return;
|
|
69
|
-
//获得 2d 上下文对象
|
|
70
|
-
let context1 = this.canvasDom.getContext('2d');
|
|
71
|
-
let img = new Image();
|
|
72
|
-
img.setAttribute('crossOrigin', 'anonymous');
|
|
73
|
-
if (this.needTime) {
|
|
74
|
-
if (this.imgUrl.indexOf("?") < 0) {
|
|
75
|
-
this.imgUrl += "?";
|
|
76
|
-
}
|
|
77
|
-
this.imgUrl += "v=" + new Date().getTime();
|
|
78
|
-
}
|
|
79
|
-
img.src = this.imgUrl;
|
|
80
|
-
img.onload = () => {
|
|
81
|
-
this.img = img;
|
|
82
|
-
const { imgW, imgH } = this.getCanvasFull();
|
|
83
|
-
this.canvasDom.width = this.width;
|
|
84
|
-
this.canvasDom.height = this.height;
|
|
85
|
-
if (this.clipArr && this.clipArr.length > 0) {
|
|
86
|
-
this.goClip(context1);
|
|
87
|
-
}
|
|
88
|
-
// 参数 1:要绘制的 img 参数 2、3:绘制的 img 在 canvas 中的坐标 参数4,5是width,height
|
|
89
|
-
context1.drawImage(this.img, 0, 0, this.width, this.height);
|
|
90
|
-
this.loadOver.emit({ code: 'loadOver' });
|
|
91
|
-
};
|
|
92
|
-
}
|
|
93
|
-
goClip(context) {
|
|
94
|
-
context.beginPath();
|
|
95
|
-
context.moveTo(this.clipArr[0].x1, this.clipArr[0].y1);
|
|
96
|
-
this.clipArr.forEach((item, index) => {
|
|
97
|
-
if (index > 0) {
|
|
98
|
-
context.lineTo(item.x1, item.y1);
|
|
99
|
-
}
|
|
100
|
-
});
|
|
101
|
-
context.lineTo(this.clipArr[0].x1, this.clipArr[0].y1);
|
|
102
|
-
context.clip();
|
|
103
|
-
}
|
|
104
|
-
ngAfterViewInit() {
|
|
105
|
-
setTimeout(() => {
|
|
106
|
-
console.log('当前组件宽高', this.elementRef.nativeElement.offsetHeight);
|
|
107
|
-
this.initImg();
|
|
108
|
-
}, 300);
|
|
109
|
-
}
|
|
110
|
-
}
|
|
111
|
-
ImgCanvasComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: ImgCanvasComponent, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component });
|
|
112
|
-
ImgCanvasComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.11", type: ImgCanvasComponent, selector: "app-img", inputs: { needTime: "needTime", url: "url", clipArr: "clipArr", rotateNum: "rotateNum", needContextmenu: "needContextmenu" }, outputs: { loadOver: "loadOver" }, viewQueries: [{ propertyName: "canvas1", first: true, predicate: ["canvas1"], descendants: true }], ngImport: i0, template: "<canvas #canvas1 style=\"width: 100%;height: 100%;\" oncontextmenu=\"return needContextmenu\">\r\n \u60A8\u7684\u6D4F\u89C8\u5668\u4E0D\u652F\u6301\u753B\u5E03\uFF01\r\n</canvas>\r\n<ng-content></ng-content>\r\n", styles: [""] });
|
|
113
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: ImgCanvasComponent, decorators: [{
|
|
114
|
-
type: Component,
|
|
115
|
-
args: [{ selector: 'app-img', template: "<canvas #canvas1 style=\"width: 100%;height: 100%;\" oncontextmenu=\"return needContextmenu\">\r\n \u60A8\u7684\u6D4F\u89C8\u5668\u4E0D\u652F\u6301\u753B\u5E03\uFF01\r\n</canvas>\r\n<ng-content></ng-content>\r\n", styles: [""] }]
|
|
116
|
-
}], ctorParameters: function () { return [{ type: i0.ElementRef }]; }, propDecorators: { needTime: [{
|
|
117
|
-
type: Input
|
|
118
|
-
}], url: [{
|
|
119
|
-
type: Input
|
|
120
|
-
}], canvas1: [{
|
|
121
|
-
type: ViewChild,
|
|
122
|
-
args: ['canvas1', { static: false }]
|
|
123
|
-
}], clipArr: [{
|
|
124
|
-
type: Input
|
|
125
|
-
}], rotateNum: [{
|
|
126
|
-
type: Input
|
|
127
|
-
}], loadOver: [{
|
|
128
|
-
type: Output
|
|
129
|
-
}], needContextmenu: [{
|
|
130
|
-
type: Input
|
|
131
|
-
}] } });
|
|
132
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"img-canvas.component.js","sourceRoot":"","sources":["../../../../../../projects/components/src/lib/shared/img-canvas/img-canvas.component.ts","../../../../../../projects/components/src/lib/shared/img-canvas/img-canvas.component.html"],"names":[],"mappings":"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","sourcesContent":["import {AfterViewInit, Component, ElementRef, EventEmitter, Input, OnInit, Output, ViewChild} from '@angular/core';\r\nimport {SessionStorageUtil} from \"../../../core/utils/sessionstorage.util\";\r\nimport {ToolsUtil} from \"../../../core/utils/ToolsUtil\";\r\n\r\n@Component({\r\n  selector: 'app-img',\r\n  templateUrl: './img-canvas.component.html',\r\n  styleUrls: ['./img-canvas.component.less']\r\n})\r\nexport class ImgCanvasComponent implements OnInit, AfterViewInit {\r\n\r\n  @Input() needTime = false;\r\n\r\n  @Input() set url(url: string) {\r\n    // if (url && url.indexOf('?v=') < 0) {\r\n    //   if (url.indexOf(\"?\") < 0) {\r\n    //     url += \"?\";\r\n    //\r\n    //   }\r\n    //   url += \"v=\" + new Date().getTime()\r\n    // }\r\n    this.imgUrl = url;\r\n  }\r\n\r\n  @ViewChild('canvas1', {static: false}) canvas1: any;\r\n  canvasDom: any\r\n  width = 800;\r\n  height = 800;\r\n  imgUrl: any;\r\n  img: any;\r\n  @Input() clipArr: any[] = [];\r\n  @Input() rotateNum: any = 0;\r\n  @Output() loadOver: EventEmitter<any> = new EventEmitter();\r\n  @Input() needContextmenu = false\r\n\r\n  constructor(private elementRef: ElementRef) {\r\n  }\r\n\r\n  ngOnInit(): void {\r\n\r\n  }\r\n\r\n  getCanvasFull() {\r\n    let imgW = this.img.width//图片的宽\r\n    let imgH = this.img.height//图片的高\r\n    let cW = this.width;\r\n    let cH = this.height;\r\n    let rateW = imgH / imgW//比例\r\n    let rateH = imgW / imgH//比例\r\n    if (imgW > imgH) {\r\n      imgW = this.width\r\n      imgH = imgW * rateW;\r\n      if (imgH > cH) {\r\n        imgH = cH\r\n        imgW = imgH * rateH\r\n      }\r\n    } else {\r\n      imgH = this.height\r\n      imgW = imgH * rateH;\r\n      if (imgW > cW) {\r\n        imgW = cW\r\n        imgH = imgW * rateW\r\n      }\r\n    }\r\n\r\n    // imgH = this.canvasDom.offsetHeight\r\n    // imgW = this.canvasDom.offsetWidth\r\n    // let canvasH = imgH * rate\r\n    // if (canvasH > this.height) {\r\n    //   canvasH = this.height\r\n    //   rate = canvasH / imgH\r\n    //   canvasW = imgW * rate\r\n    // }\r\n    console.log(\"图片宽高\", imgW + \";\" + imgH)\r\n    return {\r\n      imgW: imgW,\r\n      imgH: imgH\r\n    }\r\n  }\r\n\r\n  initImg(needSession = true) {\r\n    this.canvasDom = this.canvas1.nativeElement;\r\n    // this.canvasDom = document.getElementById(this.canvasId);\r\n    //检测支持性\r\n    if (!this.canvasDom.getContext('2d')) return;\r\n    //获得 2d 上下文对象\r\n    let context1 = this.canvasDom.getContext('2d');\r\n    let img = new Image()\r\n    img.setAttribute('crossOrigin', 'anonymous')\r\n    if (this.needTime) {\r\n      if (this.imgUrl.indexOf(\"?\") < 0) {\r\n        this.imgUrl += \"?\";\r\n      }\r\n      this.imgUrl += \"v=\" + new Date().getTime()\r\n    }\r\n    img.src = this.imgUrl\r\n    img.onload = () => {\r\n      this.img = img\r\n      const {imgW, imgH} = this.getCanvasFull();\r\n      this.canvasDom.width = this.width;\r\n      this.canvasDom.height = this.height;\r\n      if (this.clipArr && this.clipArr.length > 0) {\r\n        this.goClip(context1)\r\n      }\r\n      // 参数 1：要绘制的 img   参数 2、3：绘制的 img 在 canvas 中的坐标 参数4,5是width，height\r\n      context1.drawImage(this.img, 0, 0, this.width, this.height,);\r\n      this.loadOver.emit({code: 'loadOver'})\r\n    }\r\n  }\r\n\r\n\r\n  goClip(context: any) {\r\n    context.beginPath()\r\n    context.moveTo(this.clipArr[0].x1, this.clipArr[0].y1);\r\n    this.clipArr.forEach((item, index) => {\r\n      if (index > 0) {\r\n        context.lineTo(item.x1, item.y1)\r\n      }\r\n    })\r\n    context.lineTo(this.clipArr[0].x1, this.clipArr[0].y1);\r\n    context.clip();\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    setTimeout(() => {\r\n      console.log('当前组件宽高', this.elementRef.nativeElement.offsetHeight)\r\n      this.initImg()\r\n    }, 300)\r\n  }\r\n\r\n}\r\n","<canvas #canvas1 style=\"width: 100%;height: 100%;\" oncontextmenu=\"return needContextmenu\">\r\n  您的浏览器不支持画布！\r\n</canvas>\r\n<ng-content></ng-content>\r\n"]}
|
|
@@ -1,68 +0,0 @@
|
|
|
1
|
-
import { Component, Input, Output, EventEmitter } from '@angular/core';
|
|
2
|
-
import { LocalStorageUtil } from "../../../core/utils/localstorage.util";
|
|
3
|
-
import * as i0 from "@angular/core";
|
|
4
|
-
import * as i1 from "ng-zorro-antd/upload";
|
|
5
|
-
import * as i2 from "ng-zorro-antd/button";
|
|
6
|
-
import * as i3 from "@angular/common";
|
|
7
|
-
import * as i4 from "../../../core/directive/role.directive";
|
|
8
|
-
import * as i5 from "ng-zorro-antd/core/wave";
|
|
9
|
-
import * as i6 from "ng-zorro-antd/core/transition-patch";
|
|
10
|
-
import * as i7 from "ng-zorro-antd/icon";
|
|
11
|
-
export class LocalUploadComponent {
|
|
12
|
-
constructor() {
|
|
13
|
-
this.nzAccept = 'application/vnd.ms-excel';
|
|
14
|
-
this.afterChange = new EventEmitter();
|
|
15
|
-
this.showList = false;
|
|
16
|
-
this.header = (file) => {
|
|
17
|
-
let obj = {
|
|
18
|
-
"x-header-atr": "web",
|
|
19
|
-
"token": LocalStorageUtil.getUserToken(),
|
|
20
|
-
// "orgCode" : ToolsUtil.getOrgCode()
|
|
21
|
-
};
|
|
22
|
-
return obj;
|
|
23
|
-
};
|
|
24
|
-
}
|
|
25
|
-
ngOnInit() {
|
|
26
|
-
// this.header = this.getDefaultHeader(new HttpHeaders());
|
|
27
|
-
}
|
|
28
|
-
onChange(params) {
|
|
29
|
-
console.log(params);
|
|
30
|
-
if (params.type == "success" || params.type == "removed") {
|
|
31
|
-
let fileUrls = [];
|
|
32
|
-
for (let file of params.fileList) {
|
|
33
|
-
if (file["key"] != undefined) {
|
|
34
|
-
fileUrls.push(file["key"]);
|
|
35
|
-
continue;
|
|
36
|
-
}
|
|
37
|
-
if (file.originFileObj) {
|
|
38
|
-
let originFileObj = file.originFileObj;
|
|
39
|
-
if (originFileObj["key"] != undefined) {
|
|
40
|
-
fileUrls.push(originFileObj["key"]);
|
|
41
|
-
}
|
|
42
|
-
}
|
|
43
|
-
}
|
|
44
|
-
this.afterChange.emit(params);
|
|
45
|
-
}
|
|
46
|
-
}
|
|
47
|
-
}
|
|
48
|
-
LocalUploadComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: LocalUploadComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
49
|
-
LocalUploadComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.11", type: LocalUploadComponent, selector: "atr-local-upload", inputs: { beforeUpload: "beforeUpload", url: "url", nzAccept: "nzAccept", name: "name", code: "code", withoutRole: "withoutRole" }, outputs: { afterChange: "afterChange" }, ngImport: i0, template: "<ng-container *ngIf=\"!withoutRole\">\r\n <nz-upload [nzAction]=\"url\" [nzAccept]=\"nzAccept\" [nzHeaders]=\"header\" [nzShowUploadList]=\"showList\"\r\n [nzBeforeUpload]=\"beforeUpload\"\r\n (nzChange)=\"onChange($event)\"\r\n *atrRole=\"code\" [nzLimit]='1'>\r\n <button nz-button nzSize=\"small\"><i nz-icon nzType=\"upload\"></i><span> {{name}}</span></button>\r\n </nz-upload>\r\n</ng-container>\r\n<ng-container *ngIf=\"withoutRole\">\r\n <nz-upload [nzAction]=\"url\" [nzAccept]=\"nzAccept\" [nzHeaders]=\"header\" [nzShowUploadList]=\"showList\"\r\n [nzBeforeUpload]=\"beforeUpload\"\r\n (nzChange)=\"onChange($event)\"\r\n [nzLimit]='1'>\r\n <button nz-button nzSize=\"small\"><i nz-icon nzType=\"upload\"></i><span> {{name}}</span></button>\r\n </nz-upload>\r\n</ng-container>\r\n", styles: [""], components: [{ type: i1.NzUploadComponent, selector: "nz-upload", inputs: ["nzType", "nzLimit", "nzSize", "nzFileType", "nzAccept", "nzAction", "nzDirectory", "nzOpenFileDialogOnClick", "nzBeforeUpload", "nzCustomRequest", "nzData", "nzFilter", "nzFileList", "nzDisabled", "nzHeaders", "nzListType", "nzMultiple", "nzName", "nzShowUploadList", "nzShowButton", "nzWithCredentials", "nzRemove", "nzPreview", "nzPreviewFile", "nzPreviewIsImage", "nzTransformFile", "nzDownload", "nzIconRender", "nzFileListRender"], outputs: ["nzChange", "nzFileListChange"], exportAs: ["nzUpload"] }, { type: i2.NzButtonComponent, selector: "button[nz-button], a[nz-button]", inputs: ["nzBlock", "nzGhost", "nzSearch", "nzLoading", "nzDanger", "disabled", "tabIndex", "nzType", "nzShape", "nzSize"], exportAs: ["nzButton"] }], directives: [{ type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i4.AtrRoleDirective, selector: "[atrRole]", inputs: ["atrRole"] }, { type: i5.NzWaveDirective, selector: "[nz-wave],button[nz-button]:not([nzType=\"link\"]):not([nzType=\"text\"])", inputs: ["nzWaveExtraNode"], exportAs: ["nzWave"] }, { type: i6.ɵNzTransitionPatchDirective, selector: "[nz-button], nz-button-group, [nz-icon], [nz-menu-item], [nz-submenu], nz-select-top-control, nz-select-placeholder, nz-input-group", inputs: ["hidden"] }, { type: i7.NzIconDirective, selector: "[nz-icon]", inputs: ["nzSpin", "nzRotate", "nzType", "nzTheme", "nzTwotoneColor", "nzIconfont"], exportAs: ["nzIcon"] }] });
|
|
50
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: LocalUploadComponent, decorators: [{
|
|
51
|
-
type: Component,
|
|
52
|
-
args: [{ selector: 'atr-local-upload', template: "<ng-container *ngIf=\"!withoutRole\">\r\n <nz-upload [nzAction]=\"url\" [nzAccept]=\"nzAccept\" [nzHeaders]=\"header\" [nzShowUploadList]=\"showList\"\r\n [nzBeforeUpload]=\"beforeUpload\"\r\n (nzChange)=\"onChange($event)\"\r\n *atrRole=\"code\" [nzLimit]='1'>\r\n <button nz-button nzSize=\"small\"><i nz-icon nzType=\"upload\"></i><span> {{name}}</span></button>\r\n </nz-upload>\r\n</ng-container>\r\n<ng-container *ngIf=\"withoutRole\">\r\n <nz-upload [nzAction]=\"url\" [nzAccept]=\"nzAccept\" [nzHeaders]=\"header\" [nzShowUploadList]=\"showList\"\r\n [nzBeforeUpload]=\"beforeUpload\"\r\n (nzChange)=\"onChange($event)\"\r\n [nzLimit]='1'>\r\n <button nz-button nzSize=\"small\"><i nz-icon nzType=\"upload\"></i><span> {{name}}</span></button>\r\n </nz-upload>\r\n</ng-container>\r\n", styles: [""] }]
|
|
53
|
-
}], ctorParameters: function () { return []; }, propDecorators: { beforeUpload: [{
|
|
54
|
-
type: Input
|
|
55
|
-
}], url: [{
|
|
56
|
-
type: Input
|
|
57
|
-
}], nzAccept: [{
|
|
58
|
-
type: Input
|
|
59
|
-
}], name: [{
|
|
60
|
-
type: Input
|
|
61
|
-
}], code: [{
|
|
62
|
-
type: Input
|
|
63
|
-
}], withoutRole: [{
|
|
64
|
-
type: Input
|
|
65
|
-
}], afterChange: [{
|
|
66
|
-
type: Output
|
|
67
|
-
}] } });
|
|
68
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibG9jYWwtdXBsb2FkLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2NvbXBvbmVudHMvc3JjL2xpYi9zaGFyZWQvbG9jYWwtdXBsb2FkL2xvY2FsLXVwbG9hZC5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jb21wb25lbnRzL3NyYy9saWIvc2hhcmVkL2xvY2FsLXVwbG9hZC9sb2NhbC11cGxvYWQuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFDLFNBQVMsRUFBVSxLQUFLLEVBQUUsTUFBTSxFQUFFLFlBQVksRUFBQyxNQUFNLGVBQWUsQ0FBQztBQUU3RSxPQUFPLEVBQUMsZ0JBQWdCLEVBQUMsTUFBTSx1Q0FBdUMsQ0FBQzs7Ozs7Ozs7O0FBVXZFLE1BQU0sT0FBTyxvQkFBb0I7SUFXL0I7UUFSUyxhQUFRLEdBQUcsMEJBQTBCLENBQUM7UUFLL0MsZ0JBQVcsR0FBc0IsSUFBSSxZQUFZLEVBQUUsQ0FBQztRQUVwRCxhQUFRLEdBQVEsS0FBSyxDQUFDO1FBTXRCLFdBQU0sR0FBSSxDQUFDLElBQWtCLEVBQUUsRUFBRTtZQUMvQixJQUFJLEdBQUcsR0FBRztnQkFDUixjQUFjLEVBQUMsS0FBSztnQkFDcEIsT0FBTyxFQUFHLGdCQUFnQixDQUFDLFlBQVksRUFBRTtnQkFDekMscUNBQXFDO2FBQ3RDLENBQUE7WUFFRCxPQUFPLEdBQUcsQ0FBQztRQUNiLENBQUMsQ0FBQztJQWJjLENBQUM7SUFFakIsUUFBUTtRQUNOLDBEQUEwRDtJQUM1RCxDQUFDO0lBVUQsUUFBUSxDQUFDLE1BQTJCO1FBQ2xDLE9BQU8sQ0FBQyxHQUFHLENBQUMsTUFBTSxDQUFDLENBQUM7UUFDcEIsSUFBSSxNQUFNLENBQUMsSUFBSSxJQUFJLFNBQVMsSUFBSSxNQUFNLENBQUMsSUFBSSxJQUFJLFNBQVMsRUFBRTtZQUN4RCxJQUFJLFFBQVEsR0FBVSxFQUFFLENBQUM7WUFDekIsS0FBSyxJQUFJLElBQUksSUFBSSxNQUFNLENBQUMsUUFBUSxFQUFFO2dCQUNoQyxJQUFJLElBQUksQ0FBQyxLQUFLLENBQUMsSUFBSSxTQUFTLEVBQUU7b0JBQzVCLFFBQVEsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUM7b0JBQzNCLFNBQVM7aUJBQ1Y7Z0JBQ0QsSUFBSSxJQUFJLENBQUMsYUFBYSxFQUFFO29CQUN0QixJQUFJLGFBQWEsR0FBUSxJQUFJLENBQUMsYUFBYSxDQUFBO29CQUMzQyxJQUFJLGFBQWEsQ0FBQyxLQUFLLENBQUMsSUFBSSxTQUFTLEVBQUU7d0JBQ3JDLFFBQVEsQ0FBQyxJQUFJLENBQUMsYUFBYSxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUE7cUJBQ3BDO2lCQUNGO2FBQ0Y7WUFFRCxJQUFJLENBQUMsV0FBVyxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsQ0FBQztTQUMvQjtJQUNILENBQUM7O2tIQTVDVSxvQkFBb0I7c0dBQXBCLG9CQUFvQixxT0NaakMsMjJCQWdCQTs0RkRKYSxvQkFBb0I7a0JBTGhDLFNBQVM7K0JBQ0Usa0JBQWtCOzBFQUtuQixZQUFZO3NCQUFwQixLQUFLO2dCQUNHLEdBQUc7c0JBQVgsS0FBSztnQkFDRyxRQUFRO3NCQUFoQixLQUFLO2dCQUNHLElBQUk7c0JBQVosS0FBSztnQkFDRyxJQUFJO3NCQUFaLEtBQUs7Z0JBQ0csV0FBVztzQkFBbkIsS0FBSztnQkFFTixXQUFXO3NCQURWLE1BQU0iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0NvbXBvbmVudCwgT25Jbml0LCBJbnB1dCwgT3V0cHV0LCBFdmVudEVtaXR0ZXJ9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQge056VXBsb2FkQ2hhbmdlUGFyYW0sIE56VXBsb2FkRmlsZX0gZnJvbSAnbmctem9ycm8tYW50ZC91cGxvYWQvbmctem9ycm8tYW50ZC11cGxvYWQnO1xyXG5pbXBvcnQge0xvY2FsU3RvcmFnZVV0aWx9IGZyb20gXCIuLi8uLi8uLi9jb3JlL3V0aWxzL2xvY2Fsc3RvcmFnZS51dGlsXCI7XHJcbmltcG9ydCB7VG9vbHNVdGlsfSBmcm9tIFwiLi4vLi4vLi4vY29yZS91dGlscy9Ub29sc1V0aWxcIjtcclxuaW1wb3J0IHthdHJfc3RhdGljX2RhdGFzfSBmcm9tIFwiLi4vLi4vLi4vY29yZS9iYXNlL2F0ci1jb21tb25cIjtcclxuaW1wb3J0IHtPYnNlcnZhYmxlfSBmcm9tIFwicnhqc1wiO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgc2VsZWN0b3I6ICdhdHItbG9jYWwtdXBsb2FkJyxcclxuICB0ZW1wbGF0ZVVybDogJy4vbG9jYWwtdXBsb2FkLmNvbXBvbmVudC5odG1sJyxcclxuICBzdHlsZVVybHM6IFsnLi9sb2NhbC11cGxvYWQuY29tcG9uZW50Lmxlc3MnXVxyXG59KVxyXG5leHBvcnQgY2xhc3MgTG9jYWxVcGxvYWRDb21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQge1xyXG4gIEBJbnB1dCgpIGJlZm9yZVVwbG9hZDogYW55O1xyXG4gIEBJbnB1dCgpIHVybDphbnk7XHJcbiAgQElucHV0KCkgbnpBY2NlcHQgPSAnYXBwbGljYXRpb24vdm5kLm1zLWV4Y2VsJztcclxuICBASW5wdXQoKSBuYW1lOmFueTtcclxuICBASW5wdXQoKSBjb2RlOmFueTtcclxuICBASW5wdXQoKSB3aXRob3V0Um9sZTphbnk7XHJcbiAgQE91dHB1dCgpXHJcbiAgYWZ0ZXJDaGFuZ2U6IEV2ZW50RW1pdHRlcjxhbnk+ID0gbmV3IEV2ZW50RW1pdHRlcigpO1xyXG5cclxuICBzaG93TGlzdCA6YW55ID0gZmFsc2U7XHJcbiAgY29uc3RydWN0b3IoKSB7IH1cclxuXHJcbiAgbmdPbkluaXQoKSB7XHJcbiAgICAvLyB0aGlzLmhlYWRlciA9IHRoaXMuZ2V0RGVmYXVsdEhlYWRlcihuZXcgSHR0cEhlYWRlcnMoKSk7XHJcbiAgfVxyXG4gIGhlYWRlciAgPSAoZmlsZTogTnpVcGxvYWRGaWxlKSA9PiB7XHJcbiAgICBsZXQgb2JqID0ge1xyXG4gICAgICBcIngtaGVhZGVyLWF0clwiOlwid2ViXCIsXHJcbiAgICAgIFwidG9rZW5cIiA6IExvY2FsU3RvcmFnZVV0aWwuZ2V0VXNlclRva2VuKCksXHJcbiAgICAgIC8vIFwib3JnQ29kZVwiIDogVG9vbHNVdGlsLmdldE9yZ0NvZGUoKVxyXG4gICAgfVxyXG5cclxuICAgIHJldHVybiBvYmo7XHJcbiAgfTtcclxuICBvbkNoYW5nZShwYXJhbXM6IE56VXBsb2FkQ2hhbmdlUGFyYW0pIHtcclxuICAgIGNvbnNvbGUubG9nKHBhcmFtcyk7XHJcbiAgICBpZiAocGFyYW1zLnR5cGUgPT0gXCJzdWNjZXNzXCIgfHwgcGFyYW1zLnR5cGUgPT0gXCJyZW1vdmVkXCIpIHtcclxuICAgICAgbGV0IGZpbGVVcmxzOiBhbnlbXSA9IFtdO1xyXG4gICAgICBmb3IgKGxldCBmaWxlIG9mIHBhcmFtcy5maWxlTGlzdCkge1xyXG4gICAgICAgIGlmIChmaWxlW1wia2V5XCJdICE9IHVuZGVmaW5lZCkge1xyXG4gICAgICAgICAgZmlsZVVybHMucHVzaChmaWxlW1wia2V5XCJdKTtcclxuICAgICAgICAgIGNvbnRpbnVlO1xyXG4gICAgICAgIH1cclxuICAgICAgICBpZiAoZmlsZS5vcmlnaW5GaWxlT2JqKSB7XHJcbiAgICAgICAgICBsZXQgb3JpZ2luRmlsZU9iajogYW55ID0gZmlsZS5vcmlnaW5GaWxlT2JqXHJcbiAgICAgICAgICBpZiAob3JpZ2luRmlsZU9ialtcImtleVwiXSAhPSB1bmRlZmluZWQpIHtcclxuICAgICAgICAgICAgZmlsZVVybHMucHVzaChvcmlnaW5GaWxlT2JqW1wia2V5XCJdKVxyXG4gICAgICAgICAgfVxyXG4gICAgICAgIH1cclxuICAgICAgfVxyXG5cclxuICAgICAgdGhpcy5hZnRlckNoYW5nZS5lbWl0KHBhcmFtcyk7XHJcbiAgICB9XHJcbiAgfVxyXG4gIC8vIGdldERlZmF1bHRIZWFkZXIoX2hlYWRlcnM6SHR0cEhlYWRlcnMpOkh0dHBIZWFkZXJze1xyXG4gIC8vICAgX2hlYWRlcnMgPSBfaGVhZGVycy5zZXQoXCJ4LWhlYWRlci1hdHJcIixcIm1hbmFnZVwiKTtcclxuICAvLyAgIF9oZWFkZXJzID0gX2hlYWRlcnMuc2V0KFwidG9rZW5cIixMb2NhbFN0b3JhZ2VVdGlsLmdldFVzZXJUb2tlbigpKTtcclxuICAvLyAgIF9oZWFkZXJzID0gX2hlYWRlcnMuc2V0KFwidXNlcklkXCIsTG9jYWxTdG9yYWdlVXRpbC5nZXRVc2VySWQoKSk7XHJcbiAgLy8gICBfaGVhZGVycyA9IF9oZWFkZXJzLnNldChcIm9yZ0NvZGVcIixUb29sc1V0aWwuZ2V0T3JnQ29kZSgpKTtcclxuICAvLyAgIHJldHVybiBfaGVhZGVycztcclxuICAvLyB9XHJcbn1cclxuIiwiPG5nLWNvbnRhaW5lciAqbmdJZj1cIiF3aXRob3V0Um9sZVwiPlxyXG4gIDxuei11cGxvYWQgW256QWN0aW9uXT1cInVybFwiIFtuekFjY2VwdF09XCJuekFjY2VwdFwiIFtuekhlYWRlcnNdPVwiaGVhZGVyXCIgW256U2hvd1VwbG9hZExpc3RdPVwic2hvd0xpc3RcIlxyXG4gICAgICAgICAgICAgW256QmVmb3JlVXBsb2FkXT1cImJlZm9yZVVwbG9hZFwiXHJcbiAgICAgICAgICAgICAobnpDaGFuZ2UpPVwib25DaGFuZ2UoJGV2ZW50KVwiXHJcbiAgICAgICAgICAgICAqYXRyUm9sZT1cImNvZGVcIiBbbnpMaW1pdF09JzEnPlxyXG4gICAgPGJ1dHRvbiBuei1idXR0b24gbnpTaXplPVwic21hbGxcIj48aSBuei1pY29uIG56VHlwZT1cInVwbG9hZFwiPjwvaT48c3Bhbj4ge3tuYW1lfX08L3NwYW4+PC9idXR0b24+XHJcbiAgPC9uei11cGxvYWQ+XHJcbjwvbmctY29udGFpbmVyPlxyXG48bmctY29udGFpbmVyICpuZ0lmPVwid2l0aG91dFJvbGVcIj5cclxuICA8bnotdXBsb2FkIFtuekFjdGlvbl09XCJ1cmxcIiBbbnpBY2NlcHRdPVwibnpBY2NlcHRcIiBbbnpIZWFkZXJzXT1cImhlYWRlclwiIFtuelNob3dVcGxvYWRMaXN0XT1cInNob3dMaXN0XCJcclxuICAgICAgICAgICAgIFtuekJlZm9yZVVwbG9hZF09XCJiZWZvcmVVcGxvYWRcIlxyXG4gICAgICAgICAgICAgKG56Q2hhbmdlKT1cIm9uQ2hhbmdlKCRldmVudClcIlxyXG4gICAgICAgICAgICAgW256TGltaXRdPScxJz5cclxuICAgIDxidXR0b24gbnotYnV0dG9uIG56U2l6ZT1cInNtYWxsXCI+PGkgbnotaWNvbiBuelR5cGU9XCJ1cGxvYWRcIj48L2k+PHNwYW4+IHt7bmFtZX19PC9zcGFuPjwvYnV0dG9uPlxyXG4gIDwvbnotdXBsb2FkPlxyXG48L25nLWNvbnRhaW5lcj5cclxuIl19
|
|
@@ -1,248 +0,0 @@
|
|
|
1
|
-
import { Component, Input, forwardRef } from '@angular/core';
|
|
2
|
-
import { Subject } from 'rxjs';
|
|
3
|
-
import { debounceTime } from 'rxjs/operators';
|
|
4
|
-
import Quill from 'quill';
|
|
5
|
-
import ResizeModule from "@ssumo/quill-resize-module";
|
|
6
|
-
import { NG_VALUE_ACCESSOR } from '@angular/forms';
|
|
7
|
-
import { UploadOssService } from "../../../core/services/upload-oss.service";
|
|
8
|
-
import { ToolsUtil } from "../../../core/utils/ToolsUtil";
|
|
9
|
-
import * as i0 from "@angular/core";
|
|
10
|
-
import * as i1 from "../../../core/services/upload-oss.service";
|
|
11
|
-
import * as i2 from "ng-zorro-antd/message";
|
|
12
|
-
import * as i3 from "ngx-quill";
|
|
13
|
-
import * as i4 from "ng-zorro-antd/modal";
|
|
14
|
-
import * as i5 from "@angular/forms";
|
|
15
|
-
import * as i6 from "@angular/common";
|
|
16
|
-
import * as i7 from "ng-zorro-antd/core/transition-patch";
|
|
17
|
-
import * as i8 from "ng-zorro-antd/icon";
|
|
18
|
-
Quill.register("modules/resize", ResizeModule);
|
|
19
|
-
const icons = Quill.import('ui/icons');
|
|
20
|
-
icons.undo = `<svg viewbox="0 0 18 18">
|
|
21
|
-
<polygon class="ql-fill ql-stroke" points="6 10 4 12 2 10 6 10"></polygon>
|
|
22
|
-
<path class="ql-stroke" d="M8.09,13.91A4.6,4.6,0,0,0,9,14,5,5,0,1,0,4,9"></path>
|
|
23
|
-
</svg>`;
|
|
24
|
-
icons.redo = `<svg viewbox="0 0 18 18">
|
|
25
|
-
<polygon class="ql-fill ql-stroke" points="12 10 14 12 16 10 12 10"></polygon>
|
|
26
|
-
<path class="ql-stroke" d="M9.91,13.91A4.6,4.6,0,0,1,9,14a5,5,0,1,1,5-5"></path>
|
|
27
|
-
</svg>`;
|
|
28
|
-
export class QuillEditorComponent {
|
|
29
|
-
constructor(uploadOssService, message) {
|
|
30
|
-
this.uploadOssService = uploadOssService;
|
|
31
|
-
this.message = message;
|
|
32
|
-
this.placeholder = '请输入';
|
|
33
|
-
this.styles = { height: '350px' };
|
|
34
|
-
this.readOnly = false;
|
|
35
|
-
this.needImgSeq = false;
|
|
36
|
-
this.imgUrls = [];
|
|
37
|
-
this.editor$ = new Subject();
|
|
38
|
-
this.imgVis = false;
|
|
39
|
-
}
|
|
40
|
-
ngOnInit() {
|
|
41
|
-
this.editor$.pipe(debounceTime(700)).subscribe((editorContent) => {
|
|
42
|
-
if (typeof (this.onChangeListener) === 'function' && typeof (this.onTouchedListener)) {
|
|
43
|
-
this.onChangeListener(editorContent); // 告诉form,你的表单值改变成了payload
|
|
44
|
-
this.onTouchedListener(); // 告诉form,你的表单有交互发生
|
|
45
|
-
}
|
|
46
|
-
});
|
|
47
|
-
}
|
|
48
|
-
writeValue(value) {
|
|
49
|
-
this.value = value;
|
|
50
|
-
}
|
|
51
|
-
registerOnChange(fn) {
|
|
52
|
-
this.onChangeListener = fn;
|
|
53
|
-
}
|
|
54
|
-
registerOnTouched(fn) {
|
|
55
|
-
this.onTouchedListener = fn;
|
|
56
|
-
}
|
|
57
|
-
setDisabledState(isDisabled) {
|
|
58
|
-
}
|
|
59
|
-
onChange(quill) {
|
|
60
|
-
this.editor$.next(quill.html);
|
|
61
|
-
}
|
|
62
|
-
EditorCreated(quill) {
|
|
63
|
-
const toolbar = quill.getModule('toolbar');
|
|
64
|
-
toolbar.addHandler('image', this.imageHandler.bind(this));
|
|
65
|
-
this.editor = quill;
|
|
66
|
-
let that = this;
|
|
67
|
-
quill.on('text-change', function (delta, oldDelta, source) {
|
|
68
|
-
if (source == 'api') {
|
|
69
|
-
}
|
|
70
|
-
else if (source == 'user') {
|
|
71
|
-
console.log('user');
|
|
72
|
-
that.uploadImgs([], 0);
|
|
73
|
-
}
|
|
74
|
-
});
|
|
75
|
-
}
|
|
76
|
-
getBlobByBase64(url, oldUrl) {
|
|
77
|
-
const c = document.createElement('canvas');
|
|
78
|
-
console.log(c);
|
|
79
|
-
const ctx = c.getContext('2d');
|
|
80
|
-
ctx.stroke();
|
|
81
|
-
let blob = ToolsUtil.dataURItoBlob(url);
|
|
82
|
-
blob.name = '.png';
|
|
83
|
-
let delta = this.editor.getContents();
|
|
84
|
-
console.log('delta', delta);
|
|
85
|
-
for (let i = 0; i < delta.ops.length; i++) {
|
|
86
|
-
if (delta.ops[i].insert.image == oldUrl) {
|
|
87
|
-
return {
|
|
88
|
-
index: i,
|
|
89
|
-
blob: blob,
|
|
90
|
-
oldUrl: oldUrl
|
|
91
|
-
};
|
|
92
|
-
}
|
|
93
|
-
}
|
|
94
|
-
return;
|
|
95
|
-
}
|
|
96
|
-
uploadImgs(blods, index) {
|
|
97
|
-
let details = this.editor.getContents();
|
|
98
|
-
let opt = details.ops[index];
|
|
99
|
-
if (opt && opt.insert && opt.insert.image) {
|
|
100
|
-
if (ToolsUtil.isBase64(opt.insert.image)) {
|
|
101
|
-
blods.push(this.getBlobByBase64(opt.insert.image, opt.insert.image));
|
|
102
|
-
this.isEndContents(blods, index);
|
|
103
|
-
}
|
|
104
|
-
else {
|
|
105
|
-
let c = document.createElement('canvas');
|
|
106
|
-
let ctx = c.getContext('2d');
|
|
107
|
-
let img = new Image();
|
|
108
|
-
img.src = opt.insert.image;
|
|
109
|
-
img.setAttribute('crossOrigin', '*');
|
|
110
|
-
let that = this;
|
|
111
|
-
img.onload = function () {
|
|
112
|
-
c.width = img.width;
|
|
113
|
-
c.height = img.height;
|
|
114
|
-
ctx.drawImage(img, 0, 0, img.width, img.height);
|
|
115
|
-
let url = c.toDataURL();
|
|
116
|
-
blods.push(that.getBlobByBase64(url, img.src));
|
|
117
|
-
that.isEndContents(blods, index);
|
|
118
|
-
};
|
|
119
|
-
}
|
|
120
|
-
}
|
|
121
|
-
else {
|
|
122
|
-
this.isEndContents(blods, index);
|
|
123
|
-
}
|
|
124
|
-
}
|
|
125
|
-
uploadImg(blods) {
|
|
126
|
-
if (!blods || blods.length <= 0) {
|
|
127
|
-
return;
|
|
128
|
-
}
|
|
129
|
-
for (let i = 0; i < blods.length; i++) {
|
|
130
|
-
let blob = blods[i];
|
|
131
|
-
this.uploadOssService.uploadOss(blob).subscribe((url) => {
|
|
132
|
-
let delta = this.editor.getContents();
|
|
133
|
-
delta.filter((opt) => opt && opt.insert && opt.insert.image == blods[i].oldUrl).forEach((opt, index) => {
|
|
134
|
-
opt.insert.image = url;
|
|
135
|
-
});
|
|
136
|
-
this.editor.setContents(delta, 'api');
|
|
137
|
-
});
|
|
138
|
-
}
|
|
139
|
-
}
|
|
140
|
-
isEndContents(blods, index) {
|
|
141
|
-
let details = this.editor.getContents();
|
|
142
|
-
if (++index != details.ops.length) {
|
|
143
|
-
this.uploadImgs(blods, index);
|
|
144
|
-
}
|
|
145
|
-
else {
|
|
146
|
-
this.uploadImg(blods);
|
|
147
|
-
}
|
|
148
|
-
}
|
|
149
|
-
imageHandler() {
|
|
150
|
-
const Imageinput = document.createElement('input');
|
|
151
|
-
Imageinput.setAttribute('type', 'file');
|
|
152
|
-
Imageinput.setAttribute('multiple', 'multiple');
|
|
153
|
-
Imageinput.setAttribute('accept', 'image/png, image/gif, image/jpeg, image/bmp');
|
|
154
|
-
Imageinput.classList.add('ql-image');
|
|
155
|
-
Imageinput.addEventListener('change', () => {
|
|
156
|
-
if (this.needImgSeq) {
|
|
157
|
-
this.imgVis = true;
|
|
158
|
-
}
|
|
159
|
-
console.log(Imageinput);
|
|
160
|
-
let files = Imageinput.files;
|
|
161
|
-
if (files === null || files.length == 0) {
|
|
162
|
-
return;
|
|
163
|
-
}
|
|
164
|
-
this.imgUrls = [];
|
|
165
|
-
for (let i = 0; i < files.length; i++) {
|
|
166
|
-
const file = files[i];
|
|
167
|
-
if (file === null) {
|
|
168
|
-
continue;
|
|
169
|
-
}
|
|
170
|
-
const error = (res) => {
|
|
171
|
-
this.message.warning('上传失败');
|
|
172
|
-
};
|
|
173
|
-
this.uploadOssService.uploadOss(file).subscribe((url) => {
|
|
174
|
-
console.log(file);
|
|
175
|
-
if (url) {
|
|
176
|
-
this.imgUrls.push({ url: url, file: file, index: i });
|
|
177
|
-
if (!this.needImgSeq) {
|
|
178
|
-
this.editor.insertEmbed(this.editor.getSelection(true).index, 'image', url);
|
|
179
|
-
}
|
|
180
|
-
}
|
|
181
|
-
else {
|
|
182
|
-
this.message.warning('上传失败');
|
|
183
|
-
}
|
|
184
|
-
if (this.needImgSeq && this.imgUrls.length == files.length) {
|
|
185
|
-
this.imgVis = true;
|
|
186
|
-
this.imgUrls.sort((a, b) => a.index - b.index);
|
|
187
|
-
document.getElementById("te")?.click();
|
|
188
|
-
}
|
|
189
|
-
}, error);
|
|
190
|
-
}
|
|
191
|
-
});
|
|
192
|
-
Imageinput.click();
|
|
193
|
-
}
|
|
194
|
-
saveSeq() {
|
|
195
|
-
console.log(123);
|
|
196
|
-
for (let i = this.imgUrls.length - 1; i >= 0; i--) {
|
|
197
|
-
this.editor.insertEmbed(this.editor.getSelection(true).index, 'image', this.imgUrls[i].url);
|
|
198
|
-
}
|
|
199
|
-
this.imgVis = false;
|
|
200
|
-
}
|
|
201
|
-
arrowUp(index) {
|
|
202
|
-
let img = this.imgUrls[index];
|
|
203
|
-
this.imgUrls[index] = this.imgUrls[index - 1];
|
|
204
|
-
this.imgUrls[index - 1] = img;
|
|
205
|
-
}
|
|
206
|
-
arrowDown(index) {
|
|
207
|
-
let img = this.imgUrls[index];
|
|
208
|
-
this.imgUrls[index] = this.imgUrls[index + 1];
|
|
209
|
-
this.imgUrls[index + 1] = img;
|
|
210
|
-
}
|
|
211
|
-
cancle() {
|
|
212
|
-
this.imgVis = false;
|
|
213
|
-
}
|
|
214
|
-
te() {
|
|
215
|
-
console.log('上传完毕');
|
|
216
|
-
}
|
|
217
|
-
}
|
|
218
|
-
QuillEditorComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: QuillEditorComponent, deps: [{ token: i1.UploadOssService }, { token: i2.NzMessageService }], target: i0.ɵɵFactoryTarget.Component });
|
|
219
|
-
QuillEditorComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.11", type: QuillEditorComponent, selector: "app-quill-editor", inputs: { placeholder: "placeholder", styles: "styles", value: "value", readOnly: "readOnly", needImgSeq: "needImgSeq" }, providers: [
|
|
220
|
-
UploadOssService,
|
|
221
|
-
{
|
|
222
|
-
provide: NG_VALUE_ACCESSOR,
|
|
223
|
-
useExisting: forwardRef(() => QuillEditorComponent),
|
|
224
|
-
multi: true
|
|
225
|
-
}
|
|
226
|
-
], ngImport: i0, template: "<quill-editor\r\n [styles]=\"styles\"\r\n [placeholder]=\"placeholder\"\r\n (onEditorCreated)=\"EditorCreated($event)\"\r\n [(ngModel)]=\"value\"\r\n (onContentChanged)=\"onChange($event)\"\r\n [readOnly]=\"readOnly\"\r\n></quill-editor>\r\n<!--\u8FD9\u4E2Adiv,\u662F\u56E0\u4E3A\u4E0A\u4F20\u5B8C\u6BD5\u7126\u70B9\u8FD8\u5728\u5BCC\u6587\u672C\u91CC,\u5F39\u51FA\u65E0\u6CD5\u663E\u793A.....-->\r\n<div id=\"te\" (click)=\"te()\"></div>\r\n<nz-modal [(nzVisible)]=\"imgVis\" (nzOnOk)=\"saveSeq()\" (nzOnCancel)=\"cancle()\" nzMaskClosable=\"false\"\r\n [nzStyle]=\"{padding:0}\">\r\n <ng-container *nzModalContent>\r\n <div style=\"max-height:600px;overflow:auto;margin-top: 10px;\">\r\n <ng-container *ngTemplateOutlet=\"imgsContent\"></ng-container>\r\n </div>\r\n </ng-container>\r\n</nz-modal>\r\n<ng-template #imgsContent>\r\n <ng-container *ngFor=\"let imgOpt of imgUrls;let i = index\">\r\n <div class=\"img-div\">\r\n <img [src]=\"imgOpt.url\" [ngStyle]=\"{ width: '100px',display: 'inline-block', margin:'5px' }\"/>\r\n <div style=\"margin-left: 20px; color: grey;\">{{imgOpt.file.name}}</div>\r\n <div style=\"margin-right: 20px; flex: 1;text-align: right;\">\r\n <a title=\"\u4E0A\u79FB\" *ngIf=\" i > 0\" style=\"display: block;\" (click)=\"arrowUp(i)\">\r\n <i nz-icon nzType=\"arrow-up\" nzTheme=\"outline\" style=\"color: #1890ff; font-size: 15px;\"></i>\r\n \u4E0A\u79FB</a>\r\n <a title=\"\u4E0B\u79FB\" *ngIf=\" i < imgUrls.length - 1\" (click)=\"arrowDown(i)\">\r\n <i nz-icon nzType=\"arrow-down\" nzTheme=\"outline\" style=\"color: #1890ff; font-size: 15px\"></i>\r\n \u4E0B\u79FB</a>\r\n </div>\r\n </div>\r\n </ng-container>\r\n</ng-template>\r\n\r\n", styles: [".img-div{border:1px solid #d9d9d9;border-radius:4px;margin-top:5px;display:flex;align-items:center;padding:0 5px}\n"], components: [{ type: i3.QuillEditorComponent, selector: "quill-editor" }, { type: i4.NzModalComponent, selector: "nz-modal", inputs: ["nzMask", "nzMaskClosable", "nzCloseOnNavigation", "nzVisible", "nzClosable", "nzOkLoading", "nzOkDisabled", "nzCancelDisabled", "nzCancelLoading", "nzKeyboard", "nzNoAnimation", "nzCentered", "nzContent", "nzComponentParams", "nzFooter", "nzZIndex", "nzWidth", "nzWrapClassName", "nzClassName", "nzStyle", "nzTitle", "nzCloseIcon", "nzMaskStyle", "nzBodyStyle", "nzOkText", "nzCancelText", "nzOkType", "nzOkDanger", "nzIconType", "nzModalType", "nzAutofocus", "nzOnOk", "nzOnCancel"], outputs: ["nzOnOk", "nzOnCancel", "nzAfterOpen", "nzAfterClose", "nzVisibleChange"], exportAs: ["nzModal"] }], directives: [{ type: i5.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i5.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { type: i4.NzModalContentDirective, selector: "[nzModalContent]", exportAs: ["nzModalContent"] }, { type: i6.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }, { type: i6.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i6.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { type: i6.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i7.ɵNzTransitionPatchDirective, selector: "[nz-button], nz-button-group, [nz-icon], [nz-menu-item], [nz-submenu], nz-select-top-control, nz-select-placeholder, nz-input-group", inputs: ["hidden"] }, { type: i8.NzIconDirective, selector: "[nz-icon]", inputs: ["nzSpin", "nzRotate", "nzType", "nzTheme", "nzTwotoneColor", "nzIconfont"], exportAs: ["nzIcon"] }] });
|
|
227
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: QuillEditorComponent, decorators: [{
|
|
228
|
-
type: Component,
|
|
229
|
-
args: [{ selector: 'app-quill-editor', providers: [
|
|
230
|
-
UploadOssService,
|
|
231
|
-
{
|
|
232
|
-
provide: NG_VALUE_ACCESSOR,
|
|
233
|
-
useExisting: forwardRef(() => QuillEditorComponent),
|
|
234
|
-
multi: true
|
|
235
|
-
}
|
|
236
|
-
], template: "<quill-editor\r\n [styles]=\"styles\"\r\n [placeholder]=\"placeholder\"\r\n (onEditorCreated)=\"EditorCreated($event)\"\r\n [(ngModel)]=\"value\"\r\n (onContentChanged)=\"onChange($event)\"\r\n [readOnly]=\"readOnly\"\r\n></quill-editor>\r\n<!--\u8FD9\u4E2Adiv,\u662F\u56E0\u4E3A\u4E0A\u4F20\u5B8C\u6BD5\u7126\u70B9\u8FD8\u5728\u5BCC\u6587\u672C\u91CC,\u5F39\u51FA\u65E0\u6CD5\u663E\u793A.....-->\r\n<div id=\"te\" (click)=\"te()\"></div>\r\n<nz-modal [(nzVisible)]=\"imgVis\" (nzOnOk)=\"saveSeq()\" (nzOnCancel)=\"cancle()\" nzMaskClosable=\"false\"\r\n [nzStyle]=\"{padding:0}\">\r\n <ng-container *nzModalContent>\r\n <div style=\"max-height:600px;overflow:auto;margin-top: 10px;\">\r\n <ng-container *ngTemplateOutlet=\"imgsContent\"></ng-container>\r\n </div>\r\n </ng-container>\r\n</nz-modal>\r\n<ng-template #imgsContent>\r\n <ng-container *ngFor=\"let imgOpt of imgUrls;let i = index\">\r\n <div class=\"img-div\">\r\n <img [src]=\"imgOpt.url\" [ngStyle]=\"{ width: '100px',display: 'inline-block', margin:'5px' }\"/>\r\n <div style=\"margin-left: 20px; color: grey;\">{{imgOpt.file.name}}</div>\r\n <div style=\"margin-right: 20px; flex: 1;text-align: right;\">\r\n <a title=\"\u4E0A\u79FB\" *ngIf=\" i > 0\" style=\"display: block;\" (click)=\"arrowUp(i)\">\r\n <i nz-icon nzType=\"arrow-up\" nzTheme=\"outline\" style=\"color: #1890ff; font-size: 15px;\"></i>\r\n \u4E0A\u79FB</a>\r\n <a title=\"\u4E0B\u79FB\" *ngIf=\" i < imgUrls.length - 1\" (click)=\"arrowDown(i)\">\r\n <i nz-icon nzType=\"arrow-down\" nzTheme=\"outline\" style=\"color: #1890ff; font-size: 15px\"></i>\r\n \u4E0B\u79FB</a>\r\n </div>\r\n </div>\r\n </ng-container>\r\n</ng-template>\r\n\r\n", styles: [".img-div{border:1px solid #d9d9d9;border-radius:4px;margin-top:5px;display:flex;align-items:center;padding:0 5px}\n"] }]
|
|
237
|
-
}], ctorParameters: function () { return [{ type: i1.UploadOssService }, { type: i2.NzMessageService }]; }, propDecorators: { placeholder: [{
|
|
238
|
-
type: Input
|
|
239
|
-
}], styles: [{
|
|
240
|
-
type: Input
|
|
241
|
-
}], value: [{
|
|
242
|
-
type: Input
|
|
243
|
-
}], readOnly: [{
|
|
244
|
-
type: Input
|
|
245
|
-
}], needImgSeq: [{
|
|
246
|
-
type: Input
|
|
247
|
-
}] } });
|
|
248
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"quill-editor.component.js","sourceRoot":"","sources":["../../../../../../projects/components/src/lib/shared/quill-editor/quill-editor.component.ts","../../../../../../projects/components/src/lib/shared/quill-editor/quill-editor.component.html"],"names":[],"mappings":"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","sourcesContent":["import {Component, OnInit, Input, forwardRef, ViewChild} from '@angular/core';\r\nimport {Subject} from 'rxjs';\r\nimport {debounceTime} from 'rxjs/operators';\r\nimport Quill from 'quill';\r\nimport ResizeModule from \"@ssumo/quill-resize-module\";\r\nimport {ControlValueAccessor, NG_VALUE_ACCESSOR} from '@angular/forms';\r\nimport {NzMessageService} from 'ng-zorro-antd/message';\r\nimport {UploadOssService} from \"../../../core/services/upload-oss.service\";\r\nimport {ToolsUtil} from \"../../../core/utils/ToolsUtil\";\r\n\r\nQuill.register(\"modules/resize\", ResizeModule);\r\nconst icons = Quill.import('ui/icons');\r\nicons.undo = `<svg viewbox=\"0 0 18 18\">\r\n  <polygon class=\"ql-fill ql-stroke\" points=\"6 10 4 12 2 10 6 10\"></polygon>\r\n  <path class=\"ql-stroke\" d=\"M8.09,13.91A4.6,4.6,0,0,0,9,14,5,5,0,1,0,4,9\"></path>\r\n</svg>`;\r\nicons.redo = `<svg viewbox=\"0 0 18 18\">\r\n  <polygon class=\"ql-fill ql-stroke\" points=\"12 10 14 12 16 10 12 10\"></polygon>\r\n  <path class=\"ql-stroke\" d=\"M9.91,13.91A4.6,4.6,0,0,1,9,14a5,5,0,1,1,5-5\"></path>\r\n</svg>`;\r\n\r\n@Component({\r\n  selector: 'app-quill-editor',\r\n  templateUrl: './quill-editor.component.html',\r\n  styleUrls: ['./quill-editor.component.less'],\r\n  providers: [\r\n    UploadOssService,\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      useExisting: forwardRef(() => QuillEditorComponent),\r\n      multi: true\r\n    }\r\n  ]\r\n})\r\nexport class QuillEditorComponent implements OnInit, ControlValueAccessor {\r\n\r\n  @Input() placeholder = '请输入';\r\n  @Input() styles: any = {height: '350px'};\r\n  @Input() value: string | any; // 组件对应的 “ ngModel ”\r\n  @Input() readOnly: boolean = false;\r\n  @Input() needImgSeq: boolean = false;\r\n  editor: any;\r\n  onChangeListener: any; // 改变值回调\r\n  onTouchedListener: any; // 交互回调\r\n  imgUrls: any = [];\r\n  editor$ = new Subject<string>();\r\n  imgVis = false;\r\n\r\n  constructor(private uploadOssService: UploadOssService, private message: NzMessageService) {\r\n  }\r\n\r\n  ngOnInit() {\r\n    this.editor$.pipe(\r\n      debounceTime(700)\r\n    ).subscribe((editorContent: string) => {\r\n      if (typeof (this.onChangeListener) === 'function' && typeof (this.onTouchedListener)) {\r\n        this.onChangeListener(editorContent); // 告诉form，你的表单值改变成了payload\r\n        this.onTouchedListener(); // 告诉form，你的表单有交互发生\r\n      }\r\n    });\r\n  }\r\n\r\n  writeValue(value: string | any[]): void {\r\n    this.value = value;\r\n  }\r\n\r\n  registerOnChange(fn: any): void {\r\n    this.onChangeListener = fn;\r\n  }\r\n\r\n  registerOnTouched(fn: any): void {\r\n    this.onTouchedListener = fn;\r\n  }\r\n\r\n  setDisabledState?(isDisabled: boolean): void {\r\n\r\n  }\r\n\r\n  onChange(quill: any) {\r\n    this.editor$.next(quill.html);\r\n  }\r\n\r\n  EditorCreated(quill: any) {\r\n    const toolbar = quill.getModule('toolbar');\r\n    toolbar.addHandler('image', this.imageHandler.bind(this));\r\n    this.editor = quill;\r\n    let that = this;\r\n    quill.on('text-change', function (delta: any, oldDelta: any, source: any) {\r\n      if (source == 'api') {\r\n      } else if (source == 'user') {\r\n        console.log('user');\r\n        that.uploadImgs([], 0);\r\n      }\r\n    });\r\n  }\r\n\r\n  getBlobByBase64(url: any, oldUrl: any) {\r\n    const c: any = document.createElement('canvas');\r\n    console.log(c);\r\n    const ctx = c.getContext('2d');\r\n    ctx.stroke();\r\n    let blob: any = ToolsUtil.dataURItoBlob(url);\r\n    blob.name = '.png';\r\n    let delta = this.editor.getContents();\r\n    console.log('delta', delta)\r\n    for (let i = 0; i < delta.ops.length; i++) {\r\n      if (delta.ops[i].insert.image == oldUrl) {\r\n        return {\r\n          index: i,\r\n          blob: blob,\r\n          oldUrl: oldUrl\r\n        }\r\n      }\r\n    }\r\n    return;\r\n  }\r\n\r\n  uploadImgs(blods: any, index: any) {\r\n    let details = this.editor.getContents();\r\n    let opt = details.ops[index];\r\n    if (opt && opt.insert && opt.insert.image) {\r\n      if (ToolsUtil.isBase64(opt.insert.image)) {\r\n        blods.push(this.getBlobByBase64(opt.insert.image, opt.insert.image));\r\n        this.isEndContents(blods, index)\r\n      } else {\r\n        let c = document.createElement('canvas');\r\n        let ctx: any = c.getContext('2d');\r\n        let img = new Image();\r\n        img.src = opt.insert.image;\r\n        img.setAttribute('crossOrigin', '*');\r\n        let that = this;\r\n        img.onload = function () {\r\n          c.width = img.width;\r\n          c.height = img.height;\r\n          ctx.drawImage(img, 0, 0, img.width, img.height);\r\n          let url = c.toDataURL();\r\n          blods.push(that.getBlobByBase64(url, img.src))\r\n          that.isEndContents(blods, index)\r\n        }\r\n      }\r\n    } else {\r\n      this.isEndContents(blods, index)\r\n    }\r\n\r\n  }\r\n  uploadImg(blods:any) {\r\n    if (!blods || blods.length <= 0) {\r\n      return\r\n    }\r\n\r\n    for(let i = 0;i< blods.length;i++){\r\n      let blob = blods[i];\r\n      this.uploadOssService.uploadOss(blob).subscribe((url) => {\r\n        let delta = this.editor.getContents();\r\n        delta.filter((opt:any) => opt && opt.insert && opt.insert.image == blods[i].oldUrl).forEach((opt:any, index:any) => {\r\n          opt.insert.image = url\r\n        });\r\n        this.editor.setContents(delta, 'api');\r\n      })\r\n    }\r\n  }\r\n  isEndContents(blods:any, index:any) {\r\n    let details = this.editor.getContents();\r\n    if (++index != details.ops.length) {\r\n      this.uploadImgs(blods, index);\r\n    } else {\r\n      this.uploadImg(blods);\r\n    }\r\n  }\r\n\r\n  imageHandler() {\r\n    const Imageinput = document.createElement('input');\r\n    Imageinput.setAttribute('type', 'file');\r\n    Imageinput.setAttribute('multiple', 'multiple');\r\n    Imageinput.setAttribute('accept', 'image/png, image/gif, image/jpeg, image/bmp');\r\n    Imageinput.classList.add('ql-image');\r\n    Imageinput.addEventListener('change', () => {\r\n      if (this.needImgSeq) {\r\n        this.imgVis = true;\r\n      }\r\n      console.log(Imageinput);\r\n      let files: any = Imageinput.files;\r\n      if (files === null || files.length == 0) {\r\n        return;\r\n      }\r\n      this.imgUrls = [];\r\n      for (let i = 0; i < files.length; i++) {\r\n        const file = files[i];\r\n        if (file === null) {\r\n          continue;\r\n        }\r\n\r\n\r\n        const error = (res: any) => {\r\n          this.message.warning('上传失败');\r\n        };\r\n\r\n        this.uploadOssService.uploadOss(file).subscribe((url) => {\r\n          console.log(file);\r\n          if (url) {\r\n            this.imgUrls.push({url: url, file: file, index: i});\r\n            if (!this.needImgSeq) {\r\n              this.editor.insertEmbed(this.editor.getSelection(true).index, 'image', url);\r\n            }\r\n          } else {\r\n            this.message.warning('上传失败');\r\n          }\r\n          if (this.needImgSeq && this.imgUrls.length == files.length) {\r\n            this.imgVis = true;\r\n            this.imgUrls.sort((a: any, b: any) => a.index - b.index);\r\n            document.getElementById(\"te\")?.click();\r\n          }\r\n        }, error);\r\n      }\r\n\r\n    });\r\n\r\n    Imageinput.click();\r\n  }\r\n\r\n  saveSeq() {\r\n    console.log(123);\r\n    for (let i = this.imgUrls.length - 1; i >= 0; i--) {\r\n      this.editor.insertEmbed(this.editor.getSelection(true).index, 'image', this.imgUrls[i].url);\r\n    }\r\n    this.imgVis = false;\r\n  }\r\n\r\n  arrowUp(index: any) {\r\n    let img = this.imgUrls[index];\r\n    this.imgUrls[index] = this.imgUrls[index - 1];\r\n    this.imgUrls[index - 1] = img;\r\n  }\r\n\r\n  arrowDown(index: any) {\r\n    let img = this.imgUrls[index];\r\n    this.imgUrls[index] = this.imgUrls[index + 1];\r\n    this.imgUrls[index + 1] = img;\r\n  }\r\n\r\n  cancle() {\r\n    this.imgVis = false;\r\n  }\r\n\r\n  te() {\r\n    console.log('上传完毕')\r\n  }\r\n}\r\n","<quill-editor\r\n  [styles]=\"styles\"\r\n  [placeholder]=\"placeholder\"\r\n  (onEditorCreated)=\"EditorCreated($event)\"\r\n  [(ngModel)]=\"value\"\r\n  (onContentChanged)=\"onChange($event)\"\r\n  [readOnly]=\"readOnly\"\r\n></quill-editor>\r\n<!--这个div,是因为上传完毕焦点还在富文本里,弹出无法显示.....-->\r\n<div id=\"te\" (click)=\"te()\"></div>\r\n<nz-modal [(nzVisible)]=\"imgVis\" (nzOnOk)=\"saveSeq()\" (nzOnCancel)=\"cancle()\" nzMaskClosable=\"false\"\r\n          [nzStyle]=\"{padding:0}\">\r\n  <ng-container *nzModalContent>\r\n  <div style=\"max-height:600px;overflow:auto;margin-top: 10px;\">\r\n    <ng-container *ngTemplateOutlet=\"imgsContent\"></ng-container>\r\n  </div>\r\n  </ng-container>\r\n</nz-modal>\r\n<ng-template #imgsContent>\r\n  <ng-container *ngFor=\"let imgOpt of imgUrls;let i = index\">\r\n    <div class=\"img-div\">\r\n      <img [src]=\"imgOpt.url\" [ngStyle]=\"{ width: '100px',display: 'inline-block', margin:'5px' }\"/>\r\n      <div style=\"margin-left: 20px; color: grey;\">{{imgOpt.file.name}}</div>\r\n      <div style=\"margin-right: 20px; flex: 1;text-align: right;\">\r\n        <a title=\"上移\" *ngIf=\" i > 0\" style=\"display: block;\" (click)=\"arrowUp(i)\">\r\n          <i nz-icon nzType=\"arrow-up\" nzTheme=\"outline\" style=\"color: #1890ff; font-size: 15px;\"></i>\r\n          上移</a>\r\n        <a title=\"下移\" *ngIf=\" i < imgUrls.length - 1\" (click)=\"arrowDown(i)\">\r\n          <i nz-icon nzType=\"arrow-down\" nzTheme=\"outline\" style=\"color: #1890ff; font-size: 15px\"></i>\r\n          下移</a>\r\n      </div>\r\n    </div>\r\n  </ng-container>\r\n</ng-template>\r\n\r\n"]}
|