atr-components 0.2.103 → 0.2.105
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 +4 -7
- package/atr-public-api.d.ts +6 -0
- package/core/base/atr-common.d.ts +7 -2
- package/core/directive/hq-spin.directive.d.ts +4 -3
- package/core/pipe/china-num.pipe.d.ts +7 -0
- package/core/pipe/count.pipe.d.ts +7 -0
- package/core/pipe/is-empty.pipe.d.ts +1 -1
- package/core/pipe/oss.pipe.d.ts +7 -0
- package/core/pipe/ossStatic.pipe.d.ts +7 -0
- package/core/pipe/pipe-module.module.d.ts +8 -2
- package/core/pipe/remove-html.pipe.d.ts +10 -0
- package/core/pipe/safe-url.pipe.d.ts +10 -0
- package/core/services/upload-oss.service.d.ts +3 -1
- package/core/utils/ToolsUtil.d.ts +4 -0
- package/esm2020/atr-components.module.mjs +5 -10
- package/esm2020/atr-public-api.mjs +7 -4
- package/esm2020/core/base/atr-common.mjs +5 -1
- package/esm2020/core/directive/hq-spin.directive.mjs +16 -4
- package/esm2020/core/pipe/china-num.pipe.mjs +36 -0
- package/esm2020/core/pipe/count.pipe.mjs +34 -0
- package/esm2020/core/pipe/is-empty.pipe.mjs +5 -2
- package/esm2020/core/pipe/oss.pipe.mjs +17 -0
- package/esm2020/core/pipe/ossStatic.pipe.mjs +17 -0
- package/esm2020/core/pipe/pipe-module.module.mjs +12 -3
- package/esm2020/core/pipe/remove-html.pipe.mjs +21 -0
- package/esm2020/core/pipe/safe-url.pipe.mjs +20 -0
- package/esm2020/core/services/upload-oss.service.mjs +47 -1
- package/esm2020/core/utils/ToolsUtil.mjs +31 -1
- package/esm2020/lib/shared/atr-shared.module.mjs +10 -4
- package/esm2020/lib/shared/quill-editor/quill-editor.component.mjs +86 -1
- package/esm2020/lib/shared/table/table-form-item/table-form-item.component.mjs +3 -3
- package/esm2020/lib/shared/table/table.component.mjs +8 -1
- package/fesm2015/atr-components.mjs +461 -146
- package/fesm2015/atr-components.mjs.map +1 -1
- package/fesm2020/atr-components.mjs +461 -146
- package/fesm2020/atr-components.mjs.map +1 -1
- package/lib/shared/atr-shared.module.d.ts +15 -12
- package/lib/shared/quill-editor/quill-editor.component.d.ts +8 -0
- package/package.json +1 -1
|
@@ -5,6 +5,7 @@ import Quill from 'quill';
|
|
|
5
5
|
// import ImageResize from "quill-image-resize-module";
|
|
6
6
|
import { NG_VALUE_ACCESSOR } from '@angular/forms';
|
|
7
7
|
import { UploadOssService } from "../../../core/services/upload-oss.service";
|
|
8
|
+
import { ToolsUtil } from "../../../core/utils/ToolsUtil";
|
|
8
9
|
import * as i0 from "@angular/core";
|
|
9
10
|
import * as i1 from "../../../core/services/upload-oss.service";
|
|
10
11
|
import * as i2 from "ng-zorro-antd/message";
|
|
@@ -62,6 +63,90 @@ export class QuillEditorComponent {
|
|
|
62
63
|
const toolbar = quill.getModule('toolbar');
|
|
63
64
|
toolbar.addHandler('image', this.imageHandler.bind(this));
|
|
64
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
|
+
this.uploadOssService.uploadOssFiles(blods.map((v) => v.blob)).subscribe((res) => {
|
|
130
|
+
if (res && res.length > 0) {
|
|
131
|
+
let delta = this.editor.getContents();
|
|
132
|
+
for (let i = 0; i < res.length; i++) {
|
|
133
|
+
console.log('delta', delta);
|
|
134
|
+
delta.filter((opt) => opt && opt.insert && opt.insert.image == blods[i].oldUrl).forEach((opt, index) => {
|
|
135
|
+
opt.insert.image = res[i].url;
|
|
136
|
+
});
|
|
137
|
+
}
|
|
138
|
+
this.editor.setContents(delta, 'api');
|
|
139
|
+
}
|
|
140
|
+
});
|
|
141
|
+
}
|
|
142
|
+
isEndContents(blods, index) {
|
|
143
|
+
let details = this.editor.getContents();
|
|
144
|
+
if (++index != details.ops.length) {
|
|
145
|
+
this.uploadImgs(blods, index);
|
|
146
|
+
}
|
|
147
|
+
else {
|
|
148
|
+
this.uploadImg(blods);
|
|
149
|
+
}
|
|
65
150
|
}
|
|
66
151
|
imageHandler() {
|
|
67
152
|
const Imageinput = document.createElement('input');
|
|
@@ -162,4 +247,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.11", ngImpo
|
|
|
162
247
|
}], needImgSeq: [{
|
|
163
248
|
type: Input
|
|
164
249
|
}] } });
|
|
165
|
-
//# 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":"AAAA,OAAO,EAAC,SAAS,EAAU,KAAK,EAAE,UAAU,EAAY,MAAM,eAAe,CAAC;AAC9E,OAAO,EAAC,OAAO,EAAC,MAAM,MAAM,CAAC;AAC7B,OAAO,EAAC,YAAY,EAAC,MAAM,gBAAgB,CAAC;AAC5C,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,uDAAuD;AACvD,OAAO,EAAuB,iBAAiB,EAAC,MAAM,gBAAgB,CAAC;AAEvE,OAAO,EAAC,gBAAgB,EAAC,MAAM,2CAA2C,CAAC;;;;;;;;;;AAE3E,sDAAsD;AACtD,MAAM,KAAK,GAAG,KAAK,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC;AACvC,KAAK,CAAC,IAAI,GAAG;;;OAGN,CAAC;AACR,KAAK,CAAC,IAAI,GAAG;;;OAGN,CAAC;AAeR,MAAM,OAAO,oBAAoB;IAc/B,YAAoB,gBAAkC,EAAU,OAAyB;QAArE,qBAAgB,GAAhB,gBAAgB,CAAkB;QAAU,YAAO,GAAP,OAAO,CAAkB;QAZhF,gBAAW,GAAG,KAAK,CAAC;QACpB,WAAM,GAAQ,EAAC,MAAM,EAAE,OAAO,EAAC,CAAC;QAEhC,aAAQ,GAAY,KAAK,CAAC;QAC1B,eAAU,GAAY,KAAK,CAAC;QAIrC,YAAO,GAAQ,EAAE,CAAC;QAClB,YAAO,GAAG,IAAI,OAAO,EAAU,CAAC;QAChC,WAAM,GAAG,KAAK,CAAC;IAGf,CAAC;IAED,QAAQ;QACN,IAAI,CAAC,OAAO,CAAC,IAAI,CACf,YAAY,CAAC,GAAG,CAAC,CAClB,CAAC,SAAS,CAAC,CAAC,aAAqB,EAAE,EAAE;YACpC,IAAI,OAAO,CAAC,IAAI,CAAC,gBAAgB,CAAC,KAAK,UAAU,IAAI,OAAO,CAAC,IAAI,CAAC,iBAAiB,CAAC,EAAE;gBACpF,IAAI,CAAC,gBAAgB,CAAC,aAAa,CAAC,CAAC,CAAC,0BAA0B;gBAChE,IAAI,CAAC,iBAAiB,EAAE,CAAC,CAAC,mBAAmB;aAC9C;QACH,CAAC,CAAC,CAAC;IACL,CAAC;IAED,UAAU,CAAC,KAAqB;QAC9B,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;IACrB,CAAC;IAED,gBAAgB,CAAC,EAAO;QACtB,IAAI,CAAC,gBAAgB,GAAG,EAAE,CAAC;IAC7B,CAAC;IAED,iBAAiB,CAAC,EAAO;QACvB,IAAI,CAAC,iBAAiB,GAAG,EAAE,CAAC;IAC9B,CAAC;IAED,gBAAgB,CAAE,UAAmB;IAErC,CAAC;IAED,QAAQ,CAAC,KAAU;QACjB,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;IAChC,CAAC;IAED,aAAa,CAAC,KAAU;QACtB,MAAM,OAAO,GAAG,KAAK,CAAC,SAAS,CAAC,SAAS,CAAC,CAAC;QAC3C,OAAO,CAAC,UAAU,CAAC,OAAO,EAAE,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC;QAC1D,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;IACtB,CAAC;IAED,YAAY;QACV,MAAM,UAAU,GAAG,QAAQ,CAAC,aAAa,CAAC,OAAO,CAAC,CAAC;QACnD,UAAU,CAAC,YAAY,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;QACxC,UAAU,CAAC,YAAY,CAAC,UAAU,EAAE,UAAU,CAAC,CAAC;QAChD,UAAU,CAAC,YAAY,CAAC,QAAQ,EAAE,6CAA6C,CAAC,CAAC;QACjF,UAAU,CAAC,SAAS,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC;QACrC,UAAU,CAAC,gBAAgB,CAAC,QAAQ,EAAE,GAAG,EAAE;YACzC,IAAI,IAAI,CAAC,UAAU,EAAE;gBACnB,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC;aACpB;YACD,OAAO,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC;YACxB,IAAI,KAAK,GAAQ,UAAU,CAAC,KAAK,CAAC;YAClC,IAAI,KAAK,KAAK,IAAI,IAAI,KAAK,CAAC,MAAM,IAAI,CAAC,EAAE;gBACvC,OAAO;aACR;YACD,IAAI,CAAC,OAAO,GAAG,EAAE,CAAC;YAClB,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,KAAK,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;gBACrC,MAAM,IAAI,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC;gBACtB,IAAI,IAAI,KAAK,IAAI,EAAE;oBACjB,SAAS;iBACV;gBAGD,MAAM,KAAK,GAAG,CAAC,GAAQ,EAAE,EAAE;oBACzB,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC;gBAC/B,CAAC,CAAC;gBAEF,IAAI,CAAC,gBAAgB,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC,SAAS,CAAC,CAAC,GAAG,EAAE,EAAE;oBACtD,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;oBAClB,IAAI,GAAG,EAAE;wBACP,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,EAAC,GAAG,EAAE,GAAG,EAAE,IAAI,EAAE,IAAI,EAAE,KAAK,EAAE,CAAC,EAAC,CAAC,CAAC;wBACpD,IAAI,CAAC,IAAI,CAAC,UAAU,EAAE;4BACpB,IAAI,CAAC,MAAM,CAAC,WAAW,CAAC,IAAI,CAAC,MAAM,CAAC,YAAY,CAAC,IAAI,CAAC,CAAC,KAAK,EAAE,OAAO,EAAE,GAAG,CAAC,CAAC;yBAC7E;qBACF;yBAAM;wBACL,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC;qBAC9B;oBACD,IAAI,IAAI,CAAC,UAAU,IAAI,IAAI,CAAC,OAAO,CAAC,MAAM,IAAI,KAAK,CAAC,MAAM,EAAE;wBAC1D,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC;wBACnB,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAM,EAAE,CAAM,EAAE,EAAE,CAAC,CAAC,CAAC,KAAK,GAAG,CAAC,CAAC,KAAK,CAAC,CAAC;wBACzD,QAAQ,CAAC,cAAc,CAAC,IAAI,CAAC,EAAE,KAAK,EAAE,CAAC;qBACxC;gBACH,CAAC,EAAE,KAAK,CAAC,CAAC;aACX;QAEH,CAAC,CAAC,CAAC;QAEH,UAAU,CAAC,KAAK,EAAE,CAAC;IACrB,CAAC;IAED,OAAO;QACL,OAAO,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;QACjB,KAAK,IAAI,CAAC,GAAG,IAAI,CAAC,OAAO,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC,EAAE,EAAE;YACjD,IAAI,CAAC,MAAM,CAAC,WAAW,CAAC,IAAI,CAAC,MAAM,CAAC,YAAY,CAAC,IAAI,CAAC,CAAC,KAAK,EAAE,OAAO,EAAE,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC;SAC7F;QACD,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;IACtB,CAAC;IAED,OAAO,CAAC,KAAU;QAChB,IAAI,GAAG,GAAG,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;QAC9B,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,GAAG,IAAI,CAAC,OAAO,CAAC,KAAK,GAAG,CAAC,CAAC,CAAC;QAC9C,IAAI,CAAC,OAAO,CAAC,KAAK,GAAG,CAAC,CAAC,GAAG,GAAG,CAAC;IAChC,CAAC;IAED,SAAS,CAAC,KAAU;QAClB,IAAI,GAAG,GAAG,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;QAC9B,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,GAAG,IAAI,CAAC,OAAO,CAAC,KAAK,GAAG,CAAC,CAAC,CAAC;QAC9C,IAAI,CAAC,OAAO,CAAC,KAAK,GAAG,CAAC,CAAC,GAAG,GAAG,CAAC;IAChC,CAAC;IAED,MAAM;QACJ,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;IACtB,CAAC;IAED,EAAE;QACA,OAAO,CAAC,GAAG,CAAC,MAAM,CAAC,CAAA;IACrB,CAAC;;kHAlIU,oBAAoB;sGAApB,oBAAoB,qKATpB;QACT,gBAAgB;QAChB;YACE,OAAO,EAAE,iBAAiB;YAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,oBAAoB,CAAC;YACnD,KAAK,EAAE,IAAI;SACZ;KACF,0BC/BH,ivDAmCA;4FDFa,oBAAoB;kBAbhC,SAAS;+BACE,kBAAkB,aAGjB;wBACT,gBAAgB;wBAChB;4BACE,OAAO,EAAE,iBAAiB;4BAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,qBAAqB,CAAC;4BACnD,KAAK,EAAE,IAAI;yBACZ;qBACF;sIAIQ,WAAW;sBAAnB,KAAK;gBACG,MAAM;sBAAd,KAAK;gBACG,KAAK;sBAAb,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBACG,UAAU;sBAAlB,KAAK","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\n// import ImageResize from \"quill-image-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\n\r\n// Quill.register('modules/imageResize', ImageResize);\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  }\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"]}
|
|
250
|
+
//# 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\n// import ImageResize from \"quill-image-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\n// Quill.register('modules/imageResize', ImageResize);\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    this.uploadOssService.uploadOssFiles(blods.map((v:any) => v.blob)).subscribe((res:any) => {\r\n        if (res && res.length > 0) {\r\n          let delta = this.editor.getContents();\r\n          for (let i = 0; i < res.length; i++) {\r\n            console.log('delta', delta);\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 = res[i].url\r\n            });\r\n          }\r\n          this.editor.setContents(delta, 'api');\r\n        }\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"]}
|
|
@@ -74,7 +74,7 @@ TableFormItemComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0",
|
|
|
74
74
|
useExisting: forwardRef(() => TableFormItemComponent),
|
|
75
75
|
multi: true
|
|
76
76
|
}
|
|
77
|
-
], ngImport: i0, template: "<nz-form-item style=\"position: relative\" title=\"{{header.name}}\" nzFlex>\n <nz-form-control [nzSpan]=\"header.cspan || 24\" [ngSwitch]=\"header.type\">\n <nz-input-group [nzSuffix]=\"inputClearTpl\" *ngSwitchCase=\"'text'\">\n <input\n nz-input\n placeholder=\"{{header.name}}\"\n [attr.id]=\"header.key\"\n [(ngModel)]=\"value\"\n (ngModelChange)=\"onChange($event)\"\n />\n\n </nz-input-group>\n\n <nz-select *ngSwitchCase=\"'select'\"\n [nzAllowClear]=\"!header.disableClear\"\n nzPlaceHolder=\"{{header.name}}\"\n nzAllowClear=\"true\"\n nzServerSearch\n [(ngModel)]=\"value\"\n (ngModelChange)=\"onChange($event)\"\n >\n <nz-option *ngFor=\"let o of dictList\" [nzLabel]=\"o.typeName\"\n [nzValue]=\"o.id\"></nz-option>\n </nz-select>\n <nz-select *ngSwitchCase=\"'selectCus'\"\n [nzAllowClear]=\"!header.disableClear\"\n nzPlaceHolder=\"{{header.name}}\"\n nzAllowClear=\"true\"\n [nzShowSearch]=\"true\"\n [(ngModel)]=\"value\"\n (ngModelChange)=\"onChange($event)\"\n >\n <nz-option *ngFor=\"let o of header.dictList\" nzCustomContent [nzLabel]=\"o.label\"\n [nzValue]=\"o.value\">\n <i class=\"select-icon\" *ngIf=\"header.icon?.isShow\" nz-icon [nzType]=\"header.icon.icon\"\n nzTheme=\"outline\" style=\"margin-right: 1rem;\"\n (click)=\"clickIcon(o.value,header,$event)\"></i>\n {{o.label}}\n </nz-option>\n\n </nz-select>\n <nz-cascader\n *ngSwitchCase=\"'cascader'\"\n (ngModelChange)=\"onChange($event)\"\n style=\"flex: 1\" [nzAllowClear]=\"!header.disableClear\"\n nzPlaceHolder=\"{{header.name}}\"\n [nzShowSearch]=\"true\"\n [nzOptions]=\"header.dictList\"\n [(ngModel)]=\"value\"\n ></nz-cascader>\n <nz-tree-select\n *ngSwitchCase=\"'treeSelect'\"\n (ngModelChange)=\"onChange($event)\"\n [nzAllowClear]=\"!header.disableClear\"\n [nzNodes]=\"header.treeList\"\n nzShowSearch=\"true\"\n nzHideUnMatched=\"true\"\n nzPlaceHolder=\"{{header.name}}\"\n [nzShowSearch]=\"true\"\n [(ngModel)]=\"value\"\n [nzMultiple]=\"header.selectUrl.isMultiple\"\n [nzMaxTagCount]=\"header.maxTagCount || 3\"\n >\n </nz-tree-select>\n <nz-range-picker\n *ngSwitchCase=\"'dateRange'\"\n [nzShowTime]=\"header.nzShowTime ? header.nzShowTime : false\"\n (ngModelChange)=\"onChange($event)\"\n\n [nzFormat]=\"header.nzShowTime && header.nzShowTime.nzFormat ?\n ('yyyy-MM-dd '+ header.nzShowTime.nzFormat) : 'yyyy-MM-dd HH:mm:ss'\"\n\n [nzShowNow]=\"header.nzShowTime && header.nzShowNow \"\n [(ngModel)]=\"value\"\n style=\"width: 100%;\"\n nzAllowClear=\"true\"\n [nzPlaceHolder]=\"[header.name+'\u5F00\u59CB\u65F6\u95F4','\u7ED3\u675F\u65F6\u95F4']\"\n [nzDefaultPickerValue]=\"header.defaultVal\"></nz-range-picker>\n <ng-container *ngSwitchCase=\"'sdate'\">\n <nz-date-picker style=\"width: 100%\" [nzFormat]=\"'yyyy-MM-dd'\"\n (ngModelChange)=\"onChange($event)\"\n [(ngModel)]=\"value\"\n *ngIf=\"!header.dateMode\"\n nzAllowClear=\"true\"></nz-date-picker>\n <nz-date-picker style=\"width: 100%\"\n (ngModelChange)=\"onChange($event)\"\n [(ngModel)]=\"value\"\n *ngIf=\"header.dateMode\"\n [nzMode]=\"header.dateMode\"\n nzAllowClear=\"true\"></nz-date-picker>\n </ng-container>\n <nz-month-picker\n *ngSwitchCase=\"'smonth'\"\n (ngModelChange)=\"onChange($event)\"\n [(ngModel)]=\"value\"\n [nzFormat]=\"'yyyy-MM'\"\n [nzPlaceHolder]=\"[header.name]\"\n nzAllowClear=\"true\"></nz-month-picker>\n <span class=\"label-title\">{{header.name}}</span>\n </nz-form-control>\n</nz-form-item>\n\n<ng-template #inputClearTpl>\n <i nz-icon class=\"ant-input-clear-icon\" nzTheme=\"fill\" nzType=\"close-circle\"\n *ngIf=\"!header.disableClear && value|isNotEmpty\" (click)=\"value = null;onChange()\"></i>\n</ng-template>\n", styles: [":host{margin-bottom:5px}:host .label-title{z-index:80}\n", ":host{width:100%;height:100%;display:flex;flex-direction:column}:host ::ng-deep .ant-modal{top:50px;padding:0}:host .ant-advanced-search-form{padding:10px 6px 6px;background:#fbfbfb;border:1px solid #d9d9d9;border-radius:6px;margin-bottom:5px}:host .select-icon:hover{color:#1890ff}:host ::ng-deep .ant-advanced-search-form .ant-form-item{margin-bottom:5px}:host ::ng-deep .ant-table-column-title{font-size:.65rem}:host ::ng-deep .ant-table-tbody>tr.ant-table-row:hover>td{background:#d0eeea}:host ::ng-deep .ant-modal-header,:host ::ng-deep .ant-modal-content{border-radius:4px}:host ::ng-deep .ant-table-tbody>tr.selected:hover>td{background-color:#cfe1d0!important}:host ::ng-deep .ant-table{height:100%}:host ::ng-deep nz-pagination{position:absolute;bottom:0;right:0}:host .search-result-list{padding:1px;border:1px dashed #e9e9e9;border-radius:6px;background-color:#fff;flex:1;text-align:center;position:relative}:host [nz-form-label]{overflow:visible}:host button{margin:2px 4px}:host .collapse{margin-left:6px;font-size:12px}:host .action-area{text-align:left}:host .search-area{text-align:right}:host ::ng-deep .main-table{position:absolute;top:0;left:0;right:0;bottom:0}:host ::ng-deep .main-table .ant-spin-nested-loading{height:100%}:host ::ng-deep .main-table .ant-spin-container{height:100%}:host ::ng-deep .ant-table-tbody>tr.selected>td{background-color:#cfe1d0}:host ::ng-deep .ant-table-tbody>tr>td>img{display:block;width:40%;margin:0 auto}:host ::ng-deep .ant-table-body{-ms-overflow-style:none;overflow:-moz-scrollbars-none}:host ::ng-deep .ant-table-body::-webkit-scrollbar,:host ::ng-deep .ant-table-header::-webkit-scrollbar{width:6px!important;height:6px!important}:host ::ng-deep .ant-table-body::-webkit-scrollbar-track,:host ::ng-deep .ant-table-header::-webkit-scrollbar-track{width:6px!important;cursor:pointer}:host ::ng-deep .ant-table-body::-webkit-scrollbar-thumb,:host ::ng-deep .ant-table-header::-webkit-scrollbar-thumb{background:#1890ff;border-radius:3px;cursor:pointer}:host ::ng-deep .ant-table-bordered .ant-table-thead>tr>th{border-right:1px solid #ddd}:host ::ng-deep .ant-table-header{-ms-overflow-style:none;overflow:-moz-scrollbars-none;margin-bottom:-5px!important}:host ::ng-deep .ant-table-placeholder{border-bottom:none!important;border-top:none!important}:host .tabel-colunmn{display:block;width:160px;height:300px;background:#fff;border:1px solid #ddd;padding:10px;border-radius:5px;overflow-x:hidden;overflow-y:auto;position:relative}:host .tabel-colunmn-header{position:fixed;top:0;left:0;right:0;height:30px;z-index:999;line-height:30px;border-bottom:1px solid #ddd;text-align:left;font-size:13px;padding-left:10px}:host .t-tr{background:#fff}:host .t-tr:nth-child(odd){background:#f8f9fa}:host ::ng-deep .ant-table-thead>tr>th{background:#e7ebef!important;border-radius:0;word-break:break-all;white-space:pre-wrap}:host ::ng-deep .ant-table-tbody>tr>td{word-break:break-all;white-space:pre-wrap}:host ::ng-deep .ant-table-header{background:#e7ebef!important}:host td{font-size:.65rem}:host .resize-trigger{height:100%}:host .nz-resizable-preview{border-width:0;border-right-width:1px}:host ::ng-deep .ant-table-thead>tr>th .ant-table-header-column .ant-table-column-sorters>:not(.ant-table-column-sorter){position:unset}:host ::ng-deep .ant-table-tbody>tr>td{padding:5px}:host ::ng-deep .ant-table{line-height:15px}:host ::ng-deep .ant-table-middle .ant-table-footer,:host .ant-table-middle .ant-table-tbody>tr>td,:host .ant-table-middle .ant-table-thead>tr>th,:host .ant-table-middle .ant-table-title{padding:5px}:host ::ng-deep .ant-table-tbody>tr>td>img{width:35px}:host ::ng-deep .ant-modal-body{padding:10px}:host ::ng-deep .ant-table.ant-table-bordered tbody>tr>td{font-size:13px}:host ::ng-deep th{z-index:80!important}:host .left-zindex-header{z-index:90!important}:host .left-zindex{z-index:80!important}:host ::ng-deep input,:host ::ng-deep .ant-select-single:not(.ant-select-customize-input) .ant-select-selector,:host ::ng-deep .ant-picker{border-radius:5px}:host .border-text{width:100%;height:36px;line-height:36px;display:flex}:host .border-text .border-text-line{display:inline-block;border-top:1px solid #cccccc;margin-top:18px}:host .border-text .border-text-line-left{width:10px;border-left:1px solid #cccccc}:host .border-text .border-text-line-right{flex:1;border-right:1px solid #cccccc}:host .border-text .border-text-span{margin-left:5px;margin-right:5px}:host .label-title{position:absolute;display:block;top:-7px;left:10px;background-color:#fff;color:#000;font-weight:600;font-size:12px;line-height:12px}:host ::ng-deep .tabel-colunmn-header{position:absolute!important;top:0!important}:host ::ng-deep .ant-table-cell-fix-left,:host .ant-table-cell-fix-right{position:sticky!important}\n"], components: [{ type: i1.NzFormItemComponent, selector: "nz-form-item", exportAs: ["nzFormItem"] }, { type: i1.NzFormControlComponent, selector: "nz-form-control", inputs: ["nzSuccessTip", "nzWarningTip", "nzErrorTip", "nzValidatingTip", "nzExtra", "nzAutoTips", "nzDisableAutoTips", "nzHasFeedback", "nzValidateStatus"], exportAs: ["nzFormControl"] }, { type: i2.NzInputGroupComponent, selector: "nz-input-group", inputs: ["nzAddOnBeforeIcon", "nzAddOnAfterIcon", "nzPrefixIcon", "nzSuffixIcon", "nzAddOnBefore", "nzAddOnAfter", "nzPrefix", "nzStatus", "nzSuffix", "nzSize", "nzSearch", "nzCompact"], exportAs: ["nzInputGroup"] }, { type: i3.NzSelectComponent, selector: "nz-select", inputs: ["nzId", "nzSize", "nzStatus", "nzOptionHeightPx", "nzOptionOverflowSize", "nzDropdownClassName", "nzDropdownMatchSelectWidth", "nzDropdownStyle", "nzNotFoundContent", "nzPlaceHolder", "nzMaxTagCount", "nzDropdownRender", "nzCustomTemplate", "nzSuffixIcon", "nzClearIcon", "nzRemoveIcon", "nzMenuItemSelectedIcon", "nzTokenSeparators", "nzMaxTagPlaceholder", "nzMaxMultipleCount", "nzMode", "nzFilterOption", "compareWith", "nzAllowClear", "nzBorderless", "nzShowSearch", "nzLoading", "nzAutoFocus", "nzAutoClearSearchValue", "nzServerSearch", "nzDisabled", "nzOpen", "nzBackdrop", "nzOptions", "nzShowArrow"], outputs: ["nzOnSearch", "nzScrollToBottom", "nzOpenChange", "nzBlur", "nzFocus"], exportAs: ["nzSelect"] }, { type: i3.NzOptionComponent, selector: "nz-option", inputs: ["nzLabel", "nzValue", "nzDisabled", "nzHide", "nzCustomContent"], exportAs: ["nzOption"] }, { type: i4.NzCascaderComponent, selector: "nz-cascader, [nz-cascader]", inputs: ["nzOptionRender", "nzShowInput", "nzShowArrow", "nzAllowClear", "nzAutoFocus", "nzChangeOnSelect", "nzDisabled", "nzColumnClassName", "nzExpandTrigger", "nzValueProperty", "nzLabelRender", "nzLabelProperty", "nzNotFoundContent", "nzSize", "nzBackdrop", "nzShowSearch", "nzPlaceHolder", "nzMenuClassName", "nzMenuStyle", "nzMouseEnterDelay", "nzMouseLeaveDelay", "nzStatus", "nzTriggerAction", "nzChangeOn", "nzLoadData", "nzSuffixIcon", "nzExpandIcon", "nzOptions"], outputs: ["nzVisibleChange", "nzSelectionChange", "nzSelect", "nzClear"], exportAs: ["nzCascader"] }, { type: i5.NzTreeSelectComponent, selector: "nz-tree-select", inputs: ["nzId", "nzAllowClear", "nzShowExpand", "nzShowLine", "nzDropdownMatchSelectWidth", "nzCheckable", "nzHideUnMatched", "nzShowIcon", "nzShowSearch", "nzDisabled", "nzAsyncData", "nzMultiple", "nzDefaultExpandAll", "nzCheckStrictly", "nzVirtualItemSize", "nzVirtualMaxBufferPx", "nzVirtualMinBufferPx", "nzVirtualHeight", "nzExpandedIcon", "nzNotFoundContent", "nzNodes", "nzOpen", "nzSize", "nzPlaceHolder", "nzDropdownStyle", "nzDropdownClassName", "nzBackdrop", "nzStatus", "nzExpandedKeys", "nzDisplayWith", "nzMaxTagCount", "nzMaxTagPlaceholder", "nzTreeTemplate"], outputs: ["nzOpenChange", "nzCleared", "nzRemoved", "nzExpandChange", "nzTreeClick", "nzTreeCheckBoxChange"], exportAs: ["nzTreeSelect"] }, { type: i6.NzDatePickerComponent, selector: "nz-date-picker,nz-week-picker,nz-month-picker,nz-year-picker,nz-range-picker", inputs: ["nzAllowClear", "nzAutoFocus", "nzDisabled", "nzBorderless", "nzInputReadOnly", "nzInline", "nzOpen", "nzDisabledDate", "nzLocale", "nzPlaceHolder", "nzPopupStyle", "nzDropdownClassName", "nzSize", "nzStatus", "nzFormat", "nzDateRender", "nzDisabledTime", "nzRenderExtraFooter", "nzShowToday", "nzMode", "nzShowNow", "nzRanges", "nzDefaultPickerValue", "nzSeparator", "nzSuffixIcon", "nzBackdrop", "nzId", "nzPlacement", "nzShowTime"], outputs: ["nzOnPanelChange", "nzOnCalendarChange", "nzOnOk", "nzOnOpenChange"], exportAs: ["nzDatePicker"] }], directives: [{ type: i7.NzRowDirective, selector: "[nz-row],nz-row,nz-form-item", inputs: ["nzAlign", "nzJustify", "nzGutter"], exportAs: ["nzRow"] }, { type: i7.NzColDirective, selector: "[nz-col],nz-col,nz-form-control,nz-form-label", inputs: ["nzFlex", "nzSpan", "nzOrder", "nzOffset", "nzPush", "nzPull", "nzXs", "nzSm", "nzMd", "nzLg", "nzXl", "nzXXl"], exportAs: ["nzCol"] }, { type: i8.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { type: i8.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { type: i9.ɵ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: i2.NzInputGroupWhitSuffixOrPrefixDirective, selector: "nz-input-group[nzSuffix], nz-input-group[nzPrefix]" }, { type: i2.NzInputDirective, selector: "input[nz-input],textarea[nz-input]", inputs: ["nzBorderless", "nzSize", "nzStatus", "disabled"], exportAs: ["nzInput"] }, { type: i10.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { type: i10.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i10.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { type: i8.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i8.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i11.NzIconDirective, selector: "[nz-icon]", inputs: ["nzSpin", "nzRotate", "nzType", "nzTheme", "nzTwotoneColor", "nzIconfont"], exportAs: ["nzIcon"] }, { type: i6.NzRangePickerComponent, selector: "nz-range-picker", exportAs: ["nzRangePicker"] }, { type: i6.NzMonthPickerComponent, selector: "nz-month-picker", exportAs: ["nzMonthPicker"] }], pipes: { "isNotEmpty": i12.IsNotEmptyPipe } });
|
|
77
|
+
], ngImport: i0, template: "<nz-form-item style=\"position: relative\" title=\"{{header.name}}\" nzFlex>\n <nz-form-control [nzSpan]=\"header.cspan || 24\" [ngSwitch]=\"header.type\">\n <nz-input-group [nzSuffix]=\"inputClearTpl\" *ngSwitchCase=\"'text'\">\n <input\n nz-input\n placeholder=\"{{header.name}}\"\n [attr.id]=\"header.key\"\n [(ngModel)]=\"value\"\n (ngModelChange)=\"onChange($event)\"\n />\n\n </nz-input-group>\n\n <nz-select *ngSwitchCase=\"'select'\"\n [nzAllowClear]=\"!header.disableClear\"\n nzPlaceHolder=\"{{header.name}}\"\n nzAllowClear=\"true\"\n [nzMode]=\"header.nzMode || 'default'\"\n nzServerSearch\n [(ngModel)]=\"value\"\n (ngModelChange)=\"onChange($event)\"\n >\n <nz-option *ngFor=\"let o of dictList\" [nzLabel]=\"o.typeName\"\n [nzValue]=\"o.id\"></nz-option>\n </nz-select>\n <nz-select *ngSwitchCase=\"'selectCus'\"\n [nzMode]=\"header.nzMode || 'default'\"\n [nzAllowClear]=\"!header.disableClear\"\n nzPlaceHolder=\"{{header.name}}\"\n nzAllowClear=\"true\"\n [nzShowSearch]=\"true\"\n [(ngModel)]=\"value\"\n (ngModelChange)=\"onChange($event)\"\n >\n <nz-option *ngFor=\"let o of header.dictList\" nzCustomContent [nzLabel]=\"o.label\"\n [nzValue]=\"o.value\">\n <i class=\"select-icon\" *ngIf=\"header.icon?.isShow\" nz-icon [nzType]=\"header.icon.icon\"\n nzTheme=\"outline\" style=\"margin-right: 1rem;\"\n (click)=\"clickIcon(o.value,header,$event)\"></i>\n {{o.label}}\n </nz-option>\n\n </nz-select>\n <nz-cascader\n *ngSwitchCase=\"'cascader'\"\n (ngModelChange)=\"onChange($event)\"\n style=\"flex: 1\" [nzAllowClear]=\"!header.disableClear\"\n nzPlaceHolder=\"{{header.name}}\"\n [nzShowSearch]=\"true\"\n [nzOptions]=\"header.dictList\"\n [(ngModel)]=\"value\"\n ></nz-cascader>\n <nz-tree-select\n *ngSwitchCase=\"'treeSelect'\"\n (ngModelChange)=\"onChange($event)\"\n [nzAllowClear]=\"!header.disableClear\"\n [nzNodes]=\"header.treeList\"\n nzShowSearch=\"true\"\n nzHideUnMatched=\"true\"\n nzPlaceHolder=\"{{header.name}}\"\n [nzShowSearch]=\"true\"\n [(ngModel)]=\"value\"\n [nzMultiple]=\"header.selectUrl.isMultiple\"\n [nzMaxTagCount]=\"header.maxTagCount || 3\"\n >\n </nz-tree-select>\n <nz-range-picker *ngSwitchCase=\"'dayRange'\" [(ngModel)]=\"value\" (ngModelChange)=\"onChange($event)\"\n [(ngModel)]=\"value\"\n style=\"width: 100%;\"\n nzAllowClear=\"true\"\n [nzPlaceHolder]=\"[header.name+'\u5F00\u59CB\u65F6\u95F4','\u7ED3\u675F\u65F6\u95F4']\"\n [nzDefaultPickerValue]=\"header.defaultVal\"\n ></nz-range-picker>\n <nz-range-picker\n *ngSwitchCase=\"'dateRange'\"\n [nzShowTime]=\"header.nzShowTime ? header.nzShowTime : false\"\n (ngModelChange)=\"onChange($event)\"\n\n [nzFormat]=\"header.nzShowTime && header.nzShowTime.nzFormat ?\n ('yyyy-MM-dd '+ header.nzShowTime.nzFormat) : 'yyyy-MM-dd HH:mm:ss'\"\n\n [nzShowNow]=\"header.nzShowTime && header.nzShowNow \"\n [(ngModel)]=\"value\"\n style=\"width: 100%;\"\n nzAllowClear=\"true\"\n [nzPlaceHolder]=\"[header.name+'\u5F00\u59CB\u65F6\u95F4','\u7ED3\u675F\u65F6\u95F4']\"\n [nzDefaultPickerValue]=\"header.defaultVal\"></nz-range-picker>\n <ng-container *ngSwitchCase=\"'sdate'\">\n <nz-date-picker style=\"width: 100%\" [nzFormat]=\"'yyyy-MM-dd'\"\n (ngModelChange)=\"onChange($event)\"\n [(ngModel)]=\"value\"\n *ngIf=\"!header.dateMode\"\n nzAllowClear=\"true\"></nz-date-picker>\n <nz-date-picker style=\"width: 100%\"\n (ngModelChange)=\"onChange($event)\"\n [(ngModel)]=\"value\"\n *ngIf=\"header.dateMode\"\n [nzMode]=\"header.dateMode\"\n nzAllowClear=\"true\"></nz-date-picker>\n </ng-container>\n <nz-month-picker\n *ngSwitchCase=\"'smonth'\"\n (ngModelChange)=\"onChange($event)\"\n [(ngModel)]=\"value\"\n [nzFormat]=\"'yyyy-MM'\"\n [nzPlaceHolder]=\"[header.name]\"\n nzAllowClear=\"true\"></nz-month-picker>\n <span class=\"label-title\">{{header.name}}</span>\n </nz-form-control>\n</nz-form-item>\n\n<ng-template #inputClearTpl>\n <i nz-icon class=\"ant-input-clear-icon\" nzTheme=\"fill\" nzType=\"close-circle\"\n *ngIf=\"!header.disableClear && value|isNotEmpty\" (click)=\"value = null;onChange()\"></i>\n</ng-template>\n", styles: [":host{margin-bottom:5px}:host .label-title{z-index:80}\n", ":host{width:100%;height:100%;display:flex;flex-direction:column}:host ::ng-deep .ant-modal{top:50px;padding:0}:host .ant-advanced-search-form{padding:10px 6px 6px;background:#fbfbfb;border:1px solid #d9d9d9;border-radius:6px;margin-bottom:5px}:host .select-icon:hover{color:#1890ff}:host ::ng-deep .ant-advanced-search-form .ant-form-item{margin-bottom:5px}:host ::ng-deep .ant-table-column-title{font-size:.65rem}:host ::ng-deep .ant-table-tbody>tr.ant-table-row:hover>td{background:#d0eeea}:host ::ng-deep .ant-modal-header,:host ::ng-deep .ant-modal-content{border-radius:4px}:host ::ng-deep .ant-table-tbody>tr.selected:hover>td{background-color:#cfe1d0!important}:host ::ng-deep .ant-table{height:100%}:host ::ng-deep nz-pagination{position:absolute;bottom:0;right:0}:host .search-result-list{padding:1px;border:1px dashed #e9e9e9;border-radius:6px;background-color:#fff;flex:1;text-align:center;position:relative}:host [nz-form-label]{overflow:visible}:host button{margin:2px 4px}:host .collapse{margin-left:6px;font-size:12px}:host .action-area{text-align:left}:host .search-area{text-align:right}:host ::ng-deep .main-table{position:absolute;top:0;left:0;right:0;bottom:0}:host ::ng-deep .main-table .ant-spin-nested-loading{height:100%}:host ::ng-deep .main-table .ant-spin-container{height:100%}:host ::ng-deep .ant-table-tbody>tr.selected>td{background-color:#cfe1d0}:host ::ng-deep .ant-table-tbody>tr>td>img{display:block;width:40%;margin:0 auto}:host ::ng-deep .ant-table-body{-ms-overflow-style:none;overflow:-moz-scrollbars-none}:host ::ng-deep .ant-table-body::-webkit-scrollbar,:host ::ng-deep .ant-table-header::-webkit-scrollbar{width:6px!important;height:6px!important}:host ::ng-deep .ant-table-body::-webkit-scrollbar-track,:host ::ng-deep .ant-table-header::-webkit-scrollbar-track{width:6px!important;cursor:pointer}:host ::ng-deep .ant-table-body::-webkit-scrollbar-thumb,:host ::ng-deep .ant-table-header::-webkit-scrollbar-thumb{background:#1890ff;border-radius:3px;cursor:pointer}:host ::ng-deep .ant-table-bordered .ant-table-thead>tr>th{border-right:1px solid #ddd}:host ::ng-deep .ant-table-header{-ms-overflow-style:none;overflow:-moz-scrollbars-none;margin-bottom:-5px!important}:host ::ng-deep .ant-table-placeholder{border-bottom:none!important;border-top:none!important}:host .tabel-colunmn{display:block;width:160px;height:300px;background:#fff;border:1px solid #ddd;padding:10px;border-radius:5px;overflow-x:hidden;overflow-y:auto;position:relative}:host .tabel-colunmn-header{position:fixed;top:0;left:0;right:0;height:30px;z-index:999;line-height:30px;border-bottom:1px solid #ddd;text-align:left;font-size:13px;padding-left:10px}:host .t-tr{background:#fff}:host .t-tr:nth-child(odd){background:#f8f9fa}:host ::ng-deep .ant-table-thead>tr>th{background:#e7ebef!important;border-radius:0;word-break:break-all;white-space:pre-wrap}:host ::ng-deep .ant-table-tbody>tr>td{word-break:break-all;white-space:pre-wrap}:host ::ng-deep .ant-table-header{background:#e7ebef!important}:host td{font-size:.65rem}:host .resize-trigger{height:100%}:host .nz-resizable-preview{border-width:0;border-right-width:1px}:host ::ng-deep .ant-table-thead>tr>th .ant-table-header-column .ant-table-column-sorters>:not(.ant-table-column-sorter){position:unset}:host ::ng-deep .ant-table-tbody>tr>td{padding:5px}:host ::ng-deep .ant-table{line-height:15px}:host ::ng-deep .ant-table-middle .ant-table-footer,:host .ant-table-middle .ant-table-tbody>tr>td,:host .ant-table-middle .ant-table-thead>tr>th,:host .ant-table-middle .ant-table-title{padding:5px}:host ::ng-deep .ant-table-tbody>tr>td>img{width:35px}:host ::ng-deep .ant-modal-body{padding:10px}:host ::ng-deep .ant-table.ant-table-bordered tbody>tr>td{font-size:13px}:host ::ng-deep th{z-index:80!important}:host .left-zindex-header{z-index:90!important}:host .left-zindex{z-index:80!important}:host ::ng-deep input,:host ::ng-deep .ant-select-single:not(.ant-select-customize-input) .ant-select-selector,:host ::ng-deep .ant-picker{border-radius:5px}:host .border-text{width:100%;height:36px;line-height:36px;display:flex}:host .border-text .border-text-line{display:inline-block;border-top:1px solid #cccccc;margin-top:18px}:host .border-text .border-text-line-left{width:10px;border-left:1px solid #cccccc}:host .border-text .border-text-line-right{flex:1;border-right:1px solid #cccccc}:host .border-text .border-text-span{margin-left:5px;margin-right:5px}:host .label-title{position:absolute;display:block;top:-7px;left:10px;background-color:#fff;color:#000;font-weight:600;font-size:12px;line-height:12px}:host ::ng-deep .tabel-colunmn-header{position:absolute!important;top:0!important}:host ::ng-deep .ant-table-cell-fix-left,:host .ant-table-cell-fix-right{position:sticky!important}\n"], components: [{ type: i1.NzFormItemComponent, selector: "nz-form-item", exportAs: ["nzFormItem"] }, { type: i1.NzFormControlComponent, selector: "nz-form-control", inputs: ["nzSuccessTip", "nzWarningTip", "nzErrorTip", "nzValidatingTip", "nzExtra", "nzAutoTips", "nzDisableAutoTips", "nzHasFeedback", "nzValidateStatus"], exportAs: ["nzFormControl"] }, { type: i2.NzInputGroupComponent, selector: "nz-input-group", inputs: ["nzAddOnBeforeIcon", "nzAddOnAfterIcon", "nzPrefixIcon", "nzSuffixIcon", "nzAddOnBefore", "nzAddOnAfter", "nzPrefix", "nzStatus", "nzSuffix", "nzSize", "nzSearch", "nzCompact"], exportAs: ["nzInputGroup"] }, { type: i3.NzSelectComponent, selector: "nz-select", inputs: ["nzId", "nzSize", "nzStatus", "nzOptionHeightPx", "nzOptionOverflowSize", "nzDropdownClassName", "nzDropdownMatchSelectWidth", "nzDropdownStyle", "nzNotFoundContent", "nzPlaceHolder", "nzMaxTagCount", "nzDropdownRender", "nzCustomTemplate", "nzSuffixIcon", "nzClearIcon", "nzRemoveIcon", "nzMenuItemSelectedIcon", "nzTokenSeparators", "nzMaxTagPlaceholder", "nzMaxMultipleCount", "nzMode", "nzFilterOption", "compareWith", "nzAllowClear", "nzBorderless", "nzShowSearch", "nzLoading", "nzAutoFocus", "nzAutoClearSearchValue", "nzServerSearch", "nzDisabled", "nzOpen", "nzBackdrop", "nzOptions", "nzShowArrow"], outputs: ["nzOnSearch", "nzScrollToBottom", "nzOpenChange", "nzBlur", "nzFocus"], exportAs: ["nzSelect"] }, { type: i3.NzOptionComponent, selector: "nz-option", inputs: ["nzLabel", "nzValue", "nzDisabled", "nzHide", "nzCustomContent"], exportAs: ["nzOption"] }, { type: i4.NzCascaderComponent, selector: "nz-cascader, [nz-cascader]", inputs: ["nzOptionRender", "nzShowInput", "nzShowArrow", "nzAllowClear", "nzAutoFocus", "nzChangeOnSelect", "nzDisabled", "nzColumnClassName", "nzExpandTrigger", "nzValueProperty", "nzLabelRender", "nzLabelProperty", "nzNotFoundContent", "nzSize", "nzBackdrop", "nzShowSearch", "nzPlaceHolder", "nzMenuClassName", "nzMenuStyle", "nzMouseEnterDelay", "nzMouseLeaveDelay", "nzStatus", "nzTriggerAction", "nzChangeOn", "nzLoadData", "nzSuffixIcon", "nzExpandIcon", "nzOptions"], outputs: ["nzVisibleChange", "nzSelectionChange", "nzSelect", "nzClear"], exportAs: ["nzCascader"] }, { type: i5.NzTreeSelectComponent, selector: "nz-tree-select", inputs: ["nzId", "nzAllowClear", "nzShowExpand", "nzShowLine", "nzDropdownMatchSelectWidth", "nzCheckable", "nzHideUnMatched", "nzShowIcon", "nzShowSearch", "nzDisabled", "nzAsyncData", "nzMultiple", "nzDefaultExpandAll", "nzCheckStrictly", "nzVirtualItemSize", "nzVirtualMaxBufferPx", "nzVirtualMinBufferPx", "nzVirtualHeight", "nzExpandedIcon", "nzNotFoundContent", "nzNodes", "nzOpen", "nzSize", "nzPlaceHolder", "nzDropdownStyle", "nzDropdownClassName", "nzBackdrop", "nzStatus", "nzExpandedKeys", "nzDisplayWith", "nzMaxTagCount", "nzMaxTagPlaceholder", "nzTreeTemplate"], outputs: ["nzOpenChange", "nzCleared", "nzRemoved", "nzExpandChange", "nzTreeClick", "nzTreeCheckBoxChange"], exportAs: ["nzTreeSelect"] }, { type: i6.NzDatePickerComponent, selector: "nz-date-picker,nz-week-picker,nz-month-picker,nz-year-picker,nz-range-picker", inputs: ["nzAllowClear", "nzAutoFocus", "nzDisabled", "nzBorderless", "nzInputReadOnly", "nzInline", "nzOpen", "nzDisabledDate", "nzLocale", "nzPlaceHolder", "nzPopupStyle", "nzDropdownClassName", "nzSize", "nzStatus", "nzFormat", "nzDateRender", "nzDisabledTime", "nzRenderExtraFooter", "nzShowToday", "nzMode", "nzShowNow", "nzRanges", "nzDefaultPickerValue", "nzSeparator", "nzSuffixIcon", "nzBackdrop", "nzId", "nzPlacement", "nzShowTime"], outputs: ["nzOnPanelChange", "nzOnCalendarChange", "nzOnOk", "nzOnOpenChange"], exportAs: ["nzDatePicker"] }], directives: [{ type: i7.NzRowDirective, selector: "[nz-row],nz-row,nz-form-item", inputs: ["nzAlign", "nzJustify", "nzGutter"], exportAs: ["nzRow"] }, { type: i7.NzColDirective, selector: "[nz-col],nz-col,nz-form-control,nz-form-label", inputs: ["nzFlex", "nzSpan", "nzOrder", "nzOffset", "nzPush", "nzPull", "nzXs", "nzSm", "nzMd", "nzLg", "nzXl", "nzXXl"], exportAs: ["nzCol"] }, { type: i8.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { type: i8.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { type: i9.ɵ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: i2.NzInputGroupWhitSuffixOrPrefixDirective, selector: "nz-input-group[nzSuffix], nz-input-group[nzPrefix]" }, { type: i2.NzInputDirective, selector: "input[nz-input],textarea[nz-input]", inputs: ["nzBorderless", "nzSize", "nzStatus", "disabled"], exportAs: ["nzInput"] }, { type: i10.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { type: i10.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i10.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { type: i8.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i8.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i11.NzIconDirective, selector: "[nz-icon]", inputs: ["nzSpin", "nzRotate", "nzType", "nzTheme", "nzTwotoneColor", "nzIconfont"], exportAs: ["nzIcon"] }, { type: i6.NzRangePickerComponent, selector: "nz-range-picker", exportAs: ["nzRangePicker"] }, { type: i6.NzMonthPickerComponent, selector: "nz-month-picker", exportAs: ["nzMonthPicker"] }], pipes: { "isNotEmpty": i12.IsNotEmptyPipe } });
|
|
78
78
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: TableFormItemComponent, decorators: [{
|
|
79
79
|
type: Component,
|
|
80
80
|
args: [{ selector: 'app-table-form-item', providers: [
|
|
@@ -83,7 +83,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.11", ngImpo
|
|
|
83
83
|
useExisting: forwardRef(() => TableFormItemComponent),
|
|
84
84
|
multi: true
|
|
85
85
|
}
|
|
86
|
-
], template: "<nz-form-item style=\"position: relative\" title=\"{{header.name}}\" nzFlex>\n <nz-form-control [nzSpan]=\"header.cspan || 24\" [ngSwitch]=\"header.type\">\n <nz-input-group [nzSuffix]=\"inputClearTpl\" *ngSwitchCase=\"'text'\">\n <input\n nz-input\n placeholder=\"{{header.name}}\"\n [attr.id]=\"header.key\"\n [(ngModel)]=\"value\"\n (ngModelChange)=\"onChange($event)\"\n />\n\n </nz-input-group>\n\n <nz-select *ngSwitchCase=\"'select'\"\n [nzAllowClear]=\"!header.disableClear\"\n nzPlaceHolder=\"{{header.name}}\"\n nzAllowClear=\"true\"\n nzServerSearch\n [(ngModel)]=\"value\"\n (ngModelChange)=\"onChange($event)\"\n >\n <nz-option *ngFor=\"let o of dictList\" [nzLabel]=\"o.typeName\"\n [nzValue]=\"o.id\"></nz-option>\n </nz-select>\n <nz-select *ngSwitchCase=\"'selectCus'\"\n [nzAllowClear]=\"!header.disableClear\"\n nzPlaceHolder=\"{{header.name}}\"\n nzAllowClear=\"true\"\n [nzShowSearch]=\"true\"\n [(ngModel)]=\"value\"\n (ngModelChange)=\"onChange($event)\"\n >\n <nz-option *ngFor=\"let o of header.dictList\" nzCustomContent [nzLabel]=\"o.label\"\n [nzValue]=\"o.value\">\n <i class=\"select-icon\" *ngIf=\"header.icon?.isShow\" nz-icon [nzType]=\"header.icon.icon\"\n nzTheme=\"outline\" style=\"margin-right: 1rem;\"\n (click)=\"clickIcon(o.value,header,$event)\"></i>\n {{o.label}}\n </nz-option>\n\n </nz-select>\n <nz-cascader\n *ngSwitchCase=\"'cascader'\"\n (ngModelChange)=\"onChange($event)\"\n style=\"flex: 1\" [nzAllowClear]=\"!header.disableClear\"\n nzPlaceHolder=\"{{header.name}}\"\n [nzShowSearch]=\"true\"\n [nzOptions]=\"header.dictList\"\n [(ngModel)]=\"value\"\n ></nz-cascader>\n <nz-tree-select\n *ngSwitchCase=\"'treeSelect'\"\n (ngModelChange)=\"onChange($event)\"\n [nzAllowClear]=\"!header.disableClear\"\n [nzNodes]=\"header.treeList\"\n nzShowSearch=\"true\"\n nzHideUnMatched=\"true\"\n nzPlaceHolder=\"{{header.name}}\"\n [nzShowSearch]=\"true\"\n [(ngModel)]=\"value\"\n [nzMultiple]=\"header.selectUrl.isMultiple\"\n [nzMaxTagCount]=\"header.maxTagCount || 3\"\n >\n </nz-tree-select>\n <nz-range-picker\n *ngSwitchCase=\"'dateRange'\"\n [nzShowTime]=\"header.nzShowTime ? header.nzShowTime : false\"\n (ngModelChange)=\"onChange($event)\"\n\n [nzFormat]=\"header.nzShowTime && header.nzShowTime.nzFormat
|
|
86
|
+
], template: "<nz-form-item style=\"position: relative\" title=\"{{header.name}}\" nzFlex>\n <nz-form-control [nzSpan]=\"header.cspan || 24\" [ngSwitch]=\"header.type\">\n <nz-input-group [nzSuffix]=\"inputClearTpl\" *ngSwitchCase=\"'text'\">\n <input\n nz-input\n placeholder=\"{{header.name}}\"\n [attr.id]=\"header.key\"\n [(ngModel)]=\"value\"\n (ngModelChange)=\"onChange($event)\"\n />\n\n </nz-input-group>\n\n <nz-select *ngSwitchCase=\"'select'\"\n [nzAllowClear]=\"!header.disableClear\"\n nzPlaceHolder=\"{{header.name}}\"\n nzAllowClear=\"true\"\n [nzMode]=\"header.nzMode || 'default'\"\n nzServerSearch\n [(ngModel)]=\"value\"\n (ngModelChange)=\"onChange($event)\"\n >\n <nz-option *ngFor=\"let o of dictList\" [nzLabel]=\"o.typeName\"\n [nzValue]=\"o.id\"></nz-option>\n </nz-select>\n <nz-select *ngSwitchCase=\"'selectCus'\"\n [nzMode]=\"header.nzMode || 'default'\"\n [nzAllowClear]=\"!header.disableClear\"\n nzPlaceHolder=\"{{header.name}}\"\n nzAllowClear=\"true\"\n [nzShowSearch]=\"true\"\n [(ngModel)]=\"value\"\n (ngModelChange)=\"onChange($event)\"\n >\n <nz-option *ngFor=\"let o of header.dictList\" nzCustomContent [nzLabel]=\"o.label\"\n [nzValue]=\"o.value\">\n <i class=\"select-icon\" *ngIf=\"header.icon?.isShow\" nz-icon [nzType]=\"header.icon.icon\"\n nzTheme=\"outline\" style=\"margin-right: 1rem;\"\n (click)=\"clickIcon(o.value,header,$event)\"></i>\n {{o.label}}\n </nz-option>\n\n </nz-select>\n <nz-cascader\n *ngSwitchCase=\"'cascader'\"\n (ngModelChange)=\"onChange($event)\"\n style=\"flex: 1\" [nzAllowClear]=\"!header.disableClear\"\n nzPlaceHolder=\"{{header.name}}\"\n [nzShowSearch]=\"true\"\n [nzOptions]=\"header.dictList\"\n [(ngModel)]=\"value\"\n ></nz-cascader>\n <nz-tree-select\n *ngSwitchCase=\"'treeSelect'\"\n (ngModelChange)=\"onChange($event)\"\n [nzAllowClear]=\"!header.disableClear\"\n [nzNodes]=\"header.treeList\"\n nzShowSearch=\"true\"\n nzHideUnMatched=\"true\"\n nzPlaceHolder=\"{{header.name}}\"\n [nzShowSearch]=\"true\"\n [(ngModel)]=\"value\"\n [nzMultiple]=\"header.selectUrl.isMultiple\"\n [nzMaxTagCount]=\"header.maxTagCount || 3\"\n >\n </nz-tree-select>\n <nz-range-picker *ngSwitchCase=\"'dayRange'\" [(ngModel)]=\"value\" (ngModelChange)=\"onChange($event)\"\n [(ngModel)]=\"value\"\n style=\"width: 100%;\"\n nzAllowClear=\"true\"\n [nzPlaceHolder]=\"[header.name+'\u5F00\u59CB\u65F6\u95F4','\u7ED3\u675F\u65F6\u95F4']\"\n [nzDefaultPickerValue]=\"header.defaultVal\"\n ></nz-range-picker>\n <nz-range-picker\n *ngSwitchCase=\"'dateRange'\"\n [nzShowTime]=\"header.nzShowTime ? header.nzShowTime : false\"\n (ngModelChange)=\"onChange($event)\"\n\n [nzFormat]=\"header.nzShowTime && header.nzShowTime.nzFormat ?\n ('yyyy-MM-dd '+ header.nzShowTime.nzFormat) : 'yyyy-MM-dd HH:mm:ss'\"\n\n [nzShowNow]=\"header.nzShowTime && header.nzShowNow \"\n [(ngModel)]=\"value\"\n style=\"width: 100%;\"\n nzAllowClear=\"true\"\n [nzPlaceHolder]=\"[header.name+'\u5F00\u59CB\u65F6\u95F4','\u7ED3\u675F\u65F6\u95F4']\"\n [nzDefaultPickerValue]=\"header.defaultVal\"></nz-range-picker>\n <ng-container *ngSwitchCase=\"'sdate'\">\n <nz-date-picker style=\"width: 100%\" [nzFormat]=\"'yyyy-MM-dd'\"\n (ngModelChange)=\"onChange($event)\"\n [(ngModel)]=\"value\"\n *ngIf=\"!header.dateMode\"\n nzAllowClear=\"true\"></nz-date-picker>\n <nz-date-picker style=\"width: 100%\"\n (ngModelChange)=\"onChange($event)\"\n [(ngModel)]=\"value\"\n *ngIf=\"header.dateMode\"\n [nzMode]=\"header.dateMode\"\n nzAllowClear=\"true\"></nz-date-picker>\n </ng-container>\n <nz-month-picker\n *ngSwitchCase=\"'smonth'\"\n (ngModelChange)=\"onChange($event)\"\n [(ngModel)]=\"value\"\n [nzFormat]=\"'yyyy-MM'\"\n [nzPlaceHolder]=\"[header.name]\"\n nzAllowClear=\"true\"></nz-month-picker>\n <span class=\"label-title\">{{header.name}}</span>\n </nz-form-control>\n</nz-form-item>\n\n<ng-template #inputClearTpl>\n <i nz-icon class=\"ant-input-clear-icon\" nzTheme=\"fill\" nzType=\"close-circle\"\n *ngIf=\"!header.disableClear && value|isNotEmpty\" (click)=\"value = null;onChange()\"></i>\n</ng-template>\n", styles: [":host{margin-bottom:5px}:host .label-title{z-index:80}\n", ":host{width:100%;height:100%;display:flex;flex-direction:column}:host ::ng-deep .ant-modal{top:50px;padding:0}:host .ant-advanced-search-form{padding:10px 6px 6px;background:#fbfbfb;border:1px solid #d9d9d9;border-radius:6px;margin-bottom:5px}:host .select-icon:hover{color:#1890ff}:host ::ng-deep .ant-advanced-search-form .ant-form-item{margin-bottom:5px}:host ::ng-deep .ant-table-column-title{font-size:.65rem}:host ::ng-deep .ant-table-tbody>tr.ant-table-row:hover>td{background:#d0eeea}:host ::ng-deep .ant-modal-header,:host ::ng-deep .ant-modal-content{border-radius:4px}:host ::ng-deep .ant-table-tbody>tr.selected:hover>td{background-color:#cfe1d0!important}:host ::ng-deep .ant-table{height:100%}:host ::ng-deep nz-pagination{position:absolute;bottom:0;right:0}:host .search-result-list{padding:1px;border:1px dashed #e9e9e9;border-radius:6px;background-color:#fff;flex:1;text-align:center;position:relative}:host [nz-form-label]{overflow:visible}:host button{margin:2px 4px}:host .collapse{margin-left:6px;font-size:12px}:host .action-area{text-align:left}:host .search-area{text-align:right}:host ::ng-deep .main-table{position:absolute;top:0;left:0;right:0;bottom:0}:host ::ng-deep .main-table .ant-spin-nested-loading{height:100%}:host ::ng-deep .main-table .ant-spin-container{height:100%}:host ::ng-deep .ant-table-tbody>tr.selected>td{background-color:#cfe1d0}:host ::ng-deep .ant-table-tbody>tr>td>img{display:block;width:40%;margin:0 auto}:host ::ng-deep .ant-table-body{-ms-overflow-style:none;overflow:-moz-scrollbars-none}:host ::ng-deep .ant-table-body::-webkit-scrollbar,:host ::ng-deep .ant-table-header::-webkit-scrollbar{width:6px!important;height:6px!important}:host ::ng-deep .ant-table-body::-webkit-scrollbar-track,:host ::ng-deep .ant-table-header::-webkit-scrollbar-track{width:6px!important;cursor:pointer}:host ::ng-deep .ant-table-body::-webkit-scrollbar-thumb,:host ::ng-deep .ant-table-header::-webkit-scrollbar-thumb{background:#1890ff;border-radius:3px;cursor:pointer}:host ::ng-deep .ant-table-bordered .ant-table-thead>tr>th{border-right:1px solid #ddd}:host ::ng-deep .ant-table-header{-ms-overflow-style:none;overflow:-moz-scrollbars-none;margin-bottom:-5px!important}:host ::ng-deep .ant-table-placeholder{border-bottom:none!important;border-top:none!important}:host .tabel-colunmn{display:block;width:160px;height:300px;background:#fff;border:1px solid #ddd;padding:10px;border-radius:5px;overflow-x:hidden;overflow-y:auto;position:relative}:host .tabel-colunmn-header{position:fixed;top:0;left:0;right:0;height:30px;z-index:999;line-height:30px;border-bottom:1px solid #ddd;text-align:left;font-size:13px;padding-left:10px}:host .t-tr{background:#fff}:host .t-tr:nth-child(odd){background:#f8f9fa}:host ::ng-deep .ant-table-thead>tr>th{background:#e7ebef!important;border-radius:0;word-break:break-all;white-space:pre-wrap}:host ::ng-deep .ant-table-tbody>tr>td{word-break:break-all;white-space:pre-wrap}:host ::ng-deep .ant-table-header{background:#e7ebef!important}:host td{font-size:.65rem}:host .resize-trigger{height:100%}:host .nz-resizable-preview{border-width:0;border-right-width:1px}:host ::ng-deep .ant-table-thead>tr>th .ant-table-header-column .ant-table-column-sorters>:not(.ant-table-column-sorter){position:unset}:host ::ng-deep .ant-table-tbody>tr>td{padding:5px}:host ::ng-deep .ant-table{line-height:15px}:host ::ng-deep .ant-table-middle .ant-table-footer,:host .ant-table-middle .ant-table-tbody>tr>td,:host .ant-table-middle .ant-table-thead>tr>th,:host .ant-table-middle .ant-table-title{padding:5px}:host ::ng-deep .ant-table-tbody>tr>td>img{width:35px}:host ::ng-deep .ant-modal-body{padding:10px}:host ::ng-deep .ant-table.ant-table-bordered tbody>tr>td{font-size:13px}:host ::ng-deep th{z-index:80!important}:host .left-zindex-header{z-index:90!important}:host .left-zindex{z-index:80!important}:host ::ng-deep input,:host ::ng-deep .ant-select-single:not(.ant-select-customize-input) .ant-select-selector,:host ::ng-deep .ant-picker{border-radius:5px}:host .border-text{width:100%;height:36px;line-height:36px;display:flex}:host .border-text .border-text-line{display:inline-block;border-top:1px solid #cccccc;margin-top:18px}:host .border-text .border-text-line-left{width:10px;border-left:1px solid #cccccc}:host .border-text .border-text-line-right{flex:1;border-right:1px solid #cccccc}:host .border-text .border-text-span{margin-left:5px;margin-right:5px}:host .label-title{position:absolute;display:block;top:-7px;left:10px;background-color:#fff;color:#000;font-weight:600;font-size:12px;line-height:12px}:host ::ng-deep .tabel-colunmn-header{position:absolute!important;top:0!important}:host ::ng-deep .ant-table-cell-fix-left,:host .ant-table-cell-fix-right{position:sticky!important}\n"] }]
|
|
87
87
|
}], ctorParameters: function () { return []; }, propDecorators: { header: [{
|
|
88
88
|
type: Input
|
|
89
89
|
}], value: [{
|
|
@@ -93,4 +93,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.11", ngImpo
|
|
|
93
93
|
}], headerAction: [{
|
|
94
94
|
type: Output
|
|
95
95
|
}] } });
|
|
96
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table-form-item.component.js","sourceRoot":"","sources":["../../../../../../../projects/components/src/lib/shared/table/table-form-item/table-form-item.component.ts","../../../../../../../projects/components/src/lib/shared/table/table-form-item/table-form-item.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAC,SAAS,EAAE,YAAY,EAAE,UAAU,EAAE,KAAK,EAAqB,MAAM,EAAgB,MAAM,eAAe,CAAC;AACnH,OAAO,EAAuB,iBAAiB,EAAC,MAAM,gBAAgB,CAAC;AAGvE,OAAO,EAAC,SAAS,EAAC,MAAM,kCAAkC,CAAC;;;;;;;;;;;;;;AAc3D,MAAM,OAAO,sBAAsB;IAU/B;QAPS,aAAQ,GAAO,EAAE,CAAC;QACjB,iBAAY,GAAG,IAAI,YAAY,EAAe,CAAC;QAI3D,WAAM,GAAG,SAAS,CAAC,MAAM,CAAA;IAGvB,CAAC;IAED,QAAQ;IACR,CAAC;IAED,UAAU,CAAC,KAAqB;QAC5B,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;IACvB,CAAC;IAED,gBAAgB,CAAC,EAAO;QACpB,OAAO,CAAC,GAAG,CAAC,kBAAkB,CAAC,CAAA;QAC/B,IAAI,CAAC,gBAAgB,GAAG,EAAE,CAAC;IAC/B,CAAC;IAED,iBAAiB,CAAC,EAAO;QACrB,OAAO,CAAC,GAAG,CAAC,mBAAmB,CAAC,CAAA;QAChC,IAAI,CAAC,iBAAiB,GAAG,EAAE,CAAC;IAChC,CAAC;IAED,gBAAgB,CAAE,UAAmB;IAErC,CAAC;IAED,QAAQ,CAAC,CAAM;QACX,OAAO,CAAC,GAAG,CAAC,aAAa,EAAC,IAAI,CAAC,KAAK,CAAC,CAAA;QACrC,OAAO,CAAC,GAAG,CAAC,eAAe,EAAC,CAAC,CAAC,CAAA;QAC9B,IAAG,IAAI,CAAC,gBAAgB,EAAE;YACtB,IAAI,CAAC,gBAAgB,CAAC,CAAC,CAAC,CAAC,CAAC,0BAA0B;SACvD;QACD,IAAG,IAAI,CAAC,iBAAiB,EAAE;YACvB,IAAI,CAAC,iBAAiB,EAAE,CAAC,CAAC,mBAAmB;SAChD;IACL,CAAC;IAED,YAAY,CAAC,KAAS,EAAE,IAAQ;QAC5B,qBAAqB;QACrB,IAAI,MAAM,GAAgB;YACtB,IAAI,EAAE,IAAI,CAAC,KAAK;YAChB,IAAI,EAAE,IAAI,CAAC,GAAG;YACd,IAAI,EAAE,IAAI;YACV,KAAK,EAAE,KAAK;SACf,CAAC;QACF,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,MAAM,CAAC,CAAA;IAElC,CAAC;IACD,SAAS,CAAC,KAAS,EAAE,IAAoB,EAAE,MAAU;QACjD,MAAM,CAAC,eAAe,EAAE,CAAC;QACzB,0BAA0B;QAC1B,IAAI,MAAM,GAAgB;YACtB,IAAI,EAAE,IAAI,CAAC,IAAI;YACf,IAAI,EAAE,IAAI,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,EAAE,IAAI,CAAA,CAAC,CAAA,EAAE;YAC1C,IAAI,EAAE,IAAI;YACV,KAAK,EAAE,KAAK;SACf,CAAC;QACF,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,MAAM,CAAC,CAAA;IAClC,CAAC;;oHAlEQ,sBAAsB;wGAAtB,sBAAsB,6JARpB;QACP;YACI,OAAO,EAAE,iBAAiB;YAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,sBAAsB,CAAC;YACrD,KAAK,EAAE,IAAI;SACd;KACJ,0BChBL,owIA0GA;4FDxFa,sBAAsB;kBAZlC,SAAS;+BACI,qBAAqB,aAGpB;wBACP;4BACI,OAAO,EAAE,iBAAiB;4BAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,uBAAuB,CAAC;4BACrD,KAAK,EAAE,IAAI;yBACd;qBACJ;0EAGQ,MAAM;sBAAd,KAAK;gBACG,KAAK;sBAAb,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBACI,YAAY;sBAArB,MAAM","sourcesContent":["import {Component, EventEmitter, forwardRef, Input, OnChanges, OnInit, Output, SimpleChanges} from '@angular/core';\r\nimport {ControlValueAccessor, NG_VALUE_ACCESSOR} from \"@angular/forms\";\r\nimport {NzMessageService} from \"ng-zorro-antd/message\";\r\nimport {AtrQueryHeader, TableAction} from \"../../../../core/base/atr-common\";\r\nimport {ToolsUtil} from \"../../../../core/utils/ToolsUtil\";\r\n\r\n@Component({\r\n    selector: 'app-table-form-item',\r\n    templateUrl: './table-form-item.component.html',\r\n    styleUrls: ['./table-form-item.component.scss', '../table.component.less'],\r\n    providers: [\r\n        {\r\n            provide: NG_VALUE_ACCESSOR,\r\n            useExisting: forwardRef(() => TableFormItemComponent),\r\n            multi: true\r\n        }\r\n    ]\r\n})\r\nexport class TableFormItemComponent implements OnInit, ControlValueAccessor {\r\n    @Input() header:AtrQueryHeader |any;\r\n    @Input() value: string | any; // 组件对应的 “ ngModel ”\r\n    @Input() dictList:any = [];\r\n    @Output() headerAction = new EventEmitter<TableAction>();\r\n\r\n    onChangeListener: any; // 改变值回调\r\n    onTouchedListener: any; // 交互回调\r\n  isNull = ToolsUtil.isNull\r\n\r\n    constructor() {\r\n    }\r\n\r\n    ngOnInit() {\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        console.log('registerOnChange')\r\n        this.onChangeListener = fn;\r\n    }\r\n\r\n    registerOnTouched(fn: any): void {\r\n        console.log('registerOnTouched')\r\n        this.onTouchedListener = fn;\r\n    }\r\n\r\n    setDisabledState?(isDisabled: boolean): void {\r\n\r\n    }\r\n\r\n    onChange(e?:any) {\r\n        console.log('form change',this.value)\r\n        console.log('form change e',e)\r\n        if(this.onChangeListener) {\r\n            this.onChangeListener(e); // 告诉form，你的表单值改变成了payload\r\n        }\r\n        if(this.onTouchedListener) {\r\n            this.onTouchedListener(); // 告诉form，你的表单有交互发生\r\n        }\r\n    }\r\n\r\n    selectChange(value:any, item:any) {\r\n        //console.log(value);\r\n        let action: TableAction = {\r\n            name: item.label,\r\n            code: item.key,\r\n            data: item,\r\n            value: value,\r\n        };\r\n        this.headerAction.emit(action)\r\n\r\n    }\r\n    clickIcon(value:any, item: AtrQueryHeader, $event:any) {\r\n        $event.stopPropagation();\r\n        //console.log(value,item);\r\n        let action: TableAction = {\r\n            name: item.name,\r\n            code: item.icon?.code ? item.icon?.code:\"\",\r\n            data: item,\r\n            value: value,\r\n        };\r\n        this.headerAction.emit(action)\r\n    }\r\n}\r\n","<nz-form-item style=\"position: relative\" title=\"{{header.name}}\" nzFlex>\n  <nz-form-control [nzSpan]=\"header.cspan || 24\" [ngSwitch]=\"header.type\">\n    <nz-input-group [nzSuffix]=\"inputClearTpl\" *ngSwitchCase=\"'text'\">\n      <input\n        nz-input\n        placeholder=\"{{header.name}}\"\n        [attr.id]=\"header.key\"\n        [(ngModel)]=\"value\"\n        (ngModelChange)=\"onChange($event)\"\n      />\n\n    </nz-input-group>\n\n    <nz-select *ngSwitchCase=\"'select'\"\n               [nzAllowClear]=\"!header.disableClear\"\n               nzPlaceHolder=\"{{header.name}}\"\n               nzAllowClear=\"true\"\n               nzServerSearch\n               [(ngModel)]=\"value\"\n               (ngModelChange)=\"onChange($event)\"\n    >\n      <nz-option *ngFor=\"let o of dictList\" [nzLabel]=\"o.typeName\"\n                 [nzValue]=\"o.id\"></nz-option>\n    </nz-select>\n    <nz-select *ngSwitchCase=\"'selectCus'\"\n               [nzAllowClear]=\"!header.disableClear\"\n               nzPlaceHolder=\"{{header.name}}\"\n               nzAllowClear=\"true\"\n               [nzShowSearch]=\"true\"\n               [(ngModel)]=\"value\"\n               (ngModelChange)=\"onChange($event)\"\n    >\n      <nz-option *ngFor=\"let o of header.dictList\" nzCustomContent [nzLabel]=\"o.label\"\n                 [nzValue]=\"o.value\">\n        <i class=\"select-icon\" *ngIf=\"header.icon?.isShow\" nz-icon [nzType]=\"header.icon.icon\"\n           nzTheme=\"outline\" style=\"margin-right: 1rem;\"\n           (click)=\"clickIcon(o.value,header,$event)\"></i>\n        {{o.label}}\n      </nz-option>\n\n    </nz-select>\n    <nz-cascader\n      *ngSwitchCase=\"'cascader'\"\n      (ngModelChange)=\"onChange($event)\"\n      style=\"flex: 1\" [nzAllowClear]=\"!header.disableClear\"\n      nzPlaceHolder=\"{{header.name}}\"\n      [nzShowSearch]=\"true\"\n      [nzOptions]=\"header.dictList\"\n      [(ngModel)]=\"value\"\n    ></nz-cascader>\n    <nz-tree-select\n      *ngSwitchCase=\"'treeSelect'\"\n      (ngModelChange)=\"onChange($event)\"\n      [nzAllowClear]=\"!header.disableClear\"\n      [nzNodes]=\"header.treeList\"\n      nzShowSearch=\"true\"\n      nzHideUnMatched=\"true\"\n      nzPlaceHolder=\"{{header.name}}\"\n      [nzShowSearch]=\"true\"\n      [(ngModel)]=\"value\"\n      [nzMultiple]=\"header.selectUrl.isMultiple\"\n      [nzMaxTagCount]=\"header.maxTagCount || 3\"\n    >\n    </nz-tree-select>\n    <nz-range-picker\n      *ngSwitchCase=\"'dateRange'\"\n      [nzShowTime]=\"header.nzShowTime ? header.nzShowTime : false\"\n      (ngModelChange)=\"onChange($event)\"\n\n      [nzFormat]=\"header.nzShowTime && header.nzShowTime.nzFormat ?\n      ('yyyy-MM-dd '+ header.nzShowTime.nzFormat) : 'yyyy-MM-dd HH:mm:ss'\"\n\n      [nzShowNow]=\"header.nzShowTime && header.nzShowNow \"\n      [(ngModel)]=\"value\"\n      style=\"width: 100%;\"\n      nzAllowClear=\"true\"\n      [nzPlaceHolder]=\"[header.name+'开始时间','结束时间']\"\n      [nzDefaultPickerValue]=\"header.defaultVal\"></nz-range-picker>\n    <ng-container *ngSwitchCase=\"'sdate'\">\n      <nz-date-picker style=\"width: 100%\" [nzFormat]=\"'yyyy-MM-dd'\"\n                      (ngModelChange)=\"onChange($event)\"\n                      [(ngModel)]=\"value\"\n                      *ngIf=\"!header.dateMode\"\n                      nzAllowClear=\"true\"></nz-date-picker>\n      <nz-date-picker style=\"width: 100%\"\n                      (ngModelChange)=\"onChange($event)\"\n                      [(ngModel)]=\"value\"\n                      *ngIf=\"header.dateMode\"\n                      [nzMode]=\"header.dateMode\"\n                      nzAllowClear=\"true\"></nz-date-picker>\n    </ng-container>\n    <nz-month-picker\n      *ngSwitchCase=\"'smonth'\"\n      (ngModelChange)=\"onChange($event)\"\n      [(ngModel)]=\"value\"\n      [nzFormat]=\"'yyyy-MM'\"\n      [nzPlaceHolder]=\"[header.name]\"\n      nzAllowClear=\"true\"></nz-month-picker>\n    <span class=\"label-title\">{{header.name}}</span>\n  </nz-form-control>\n</nz-form-item>\n\n<ng-template #inputClearTpl>\n  <i nz-icon class=\"ant-input-clear-icon\" nzTheme=\"fill\" nzType=\"close-circle\"\n     *ngIf=\"!header.disableClear && value|isNotEmpty\" (click)=\"value = null;onChange()\"></i>\n</ng-template>\n"]}
|
|
96
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table-form-item.component.js","sourceRoot":"","sources":["../../../../../../../projects/components/src/lib/shared/table/table-form-item/table-form-item.component.ts","../../../../../../../projects/components/src/lib/shared/table/table-form-item/table-form-item.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAC,SAAS,EAAE,YAAY,EAAE,UAAU,EAAE,KAAK,EAAqB,MAAM,EAAgB,MAAM,eAAe,CAAC;AACnH,OAAO,EAAuB,iBAAiB,EAAC,MAAM,gBAAgB,CAAC;AAGvE,OAAO,EAAC,SAAS,EAAC,MAAM,kCAAkC,CAAC;;;;;;;;;;;;;;AAc3D,MAAM,OAAO,sBAAsB;IAU/B;QAPS,aAAQ,GAAO,EAAE,CAAC;QACjB,iBAAY,GAAG,IAAI,YAAY,EAAe,CAAC;QAI3D,WAAM,GAAG,SAAS,CAAC,MAAM,CAAA;IAGvB,CAAC;IAED,QAAQ;IACR,CAAC;IAED,UAAU,CAAC,KAAqB;QAC5B,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;IACvB,CAAC;IAED,gBAAgB,CAAC,EAAO;QACpB,OAAO,CAAC,GAAG,CAAC,kBAAkB,CAAC,CAAA;QAC/B,IAAI,CAAC,gBAAgB,GAAG,EAAE,CAAC;IAC/B,CAAC;IAED,iBAAiB,CAAC,EAAO;QACrB,OAAO,CAAC,GAAG,CAAC,mBAAmB,CAAC,CAAA;QAChC,IAAI,CAAC,iBAAiB,GAAG,EAAE,CAAC;IAChC,CAAC;IAED,gBAAgB,CAAE,UAAmB;IAErC,CAAC;IAED,QAAQ,CAAC,CAAM;QACX,OAAO,CAAC,GAAG,CAAC,aAAa,EAAC,IAAI,CAAC,KAAK,CAAC,CAAA;QACrC,OAAO,CAAC,GAAG,CAAC,eAAe,EAAC,CAAC,CAAC,CAAA;QAC9B,IAAG,IAAI,CAAC,gBAAgB,EAAE;YACtB,IAAI,CAAC,gBAAgB,CAAC,CAAC,CAAC,CAAC,CAAC,0BAA0B;SACvD;QACD,IAAG,IAAI,CAAC,iBAAiB,EAAE;YACvB,IAAI,CAAC,iBAAiB,EAAE,CAAC,CAAC,mBAAmB;SAChD;IACL,CAAC;IAED,YAAY,CAAC,KAAS,EAAE,IAAQ;QAC5B,qBAAqB;QACrB,IAAI,MAAM,GAAgB;YACtB,IAAI,EAAE,IAAI,CAAC,KAAK;YAChB,IAAI,EAAE,IAAI,CAAC,GAAG;YACd,IAAI,EAAE,IAAI;YACV,KAAK,EAAE,KAAK;SACf,CAAC;QACF,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,MAAM,CAAC,CAAA;IAElC,CAAC;IACD,SAAS,CAAC,KAAS,EAAE,IAAoB,EAAE,MAAU;QACjD,MAAM,CAAC,eAAe,EAAE,CAAC;QACzB,0BAA0B;QAC1B,IAAI,MAAM,GAAgB;YACtB,IAAI,EAAE,IAAI,CAAC,IAAI;YACf,IAAI,EAAE,IAAI,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,EAAE,IAAI,CAAA,CAAC,CAAA,EAAE;YAC1C,IAAI,EAAE,IAAI;YACV,KAAK,EAAE,KAAK;SACf,CAAC;QACF,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,MAAM,CAAC,CAAA;IAClC,CAAC;;oHAlEQ,sBAAsB;wGAAtB,sBAAsB,6JARpB;QACP;YACI,OAAO,EAAE,iBAAiB;YAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,sBAAsB,CAAC;YACrD,KAAK,EAAE,IAAI;SACd;KACJ,0BChBL,wzJAmHA;4FDjGa,sBAAsB;kBAZlC,SAAS;+BACI,qBAAqB,aAGpB;wBACP;4BACI,OAAO,EAAE,iBAAiB;4BAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,uBAAuB,CAAC;4BACrD,KAAK,EAAE,IAAI;yBACd;qBACJ;0EAGQ,MAAM;sBAAd,KAAK;gBACG,KAAK;sBAAb,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBACI,YAAY;sBAArB,MAAM","sourcesContent":["import {Component, EventEmitter, forwardRef, Input, OnChanges, OnInit, Output, SimpleChanges} from '@angular/core';\r\nimport {ControlValueAccessor, NG_VALUE_ACCESSOR} from \"@angular/forms\";\r\nimport {NzMessageService} from \"ng-zorro-antd/message\";\r\nimport {AtrQueryHeader, TableAction} from \"../../../../core/base/atr-common\";\r\nimport {ToolsUtil} from \"../../../../core/utils/ToolsUtil\";\r\n\r\n@Component({\r\n    selector: 'app-table-form-item',\r\n    templateUrl: './table-form-item.component.html',\r\n    styleUrls: ['./table-form-item.component.scss', '../table.component.less'],\r\n    providers: [\r\n        {\r\n            provide: NG_VALUE_ACCESSOR,\r\n            useExisting: forwardRef(() => TableFormItemComponent),\r\n            multi: true\r\n        }\r\n    ]\r\n})\r\nexport class TableFormItemComponent implements OnInit, ControlValueAccessor {\r\n    @Input() header:AtrQueryHeader |any;\r\n    @Input() value: string | any; // 组件对应的 “ ngModel ”\r\n    @Input() dictList:any = [];\r\n    @Output() headerAction = new EventEmitter<TableAction>();\r\n\r\n    onChangeListener: any; // 改变值回调\r\n    onTouchedListener: any; // 交互回调\r\n  isNull = ToolsUtil.isNull\r\n\r\n    constructor() {\r\n    }\r\n\r\n    ngOnInit() {\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        console.log('registerOnChange')\r\n        this.onChangeListener = fn;\r\n    }\r\n\r\n    registerOnTouched(fn: any): void {\r\n        console.log('registerOnTouched')\r\n        this.onTouchedListener = fn;\r\n    }\r\n\r\n    setDisabledState?(isDisabled: boolean): void {\r\n\r\n    }\r\n\r\n    onChange(e?:any) {\r\n        console.log('form change',this.value)\r\n        console.log('form change e',e)\r\n        if(this.onChangeListener) {\r\n            this.onChangeListener(e); // 告诉form，你的表单值改变成了payload\r\n        }\r\n        if(this.onTouchedListener) {\r\n            this.onTouchedListener(); // 告诉form，你的表单有交互发生\r\n        }\r\n    }\r\n\r\n    selectChange(value:any, item:any) {\r\n        //console.log(value);\r\n        let action: TableAction = {\r\n            name: item.label,\r\n            code: item.key,\r\n            data: item,\r\n            value: value,\r\n        };\r\n        this.headerAction.emit(action)\r\n\r\n    }\r\n    clickIcon(value:any, item: AtrQueryHeader, $event:any) {\r\n        $event.stopPropagation();\r\n        //console.log(value,item);\r\n        let action: TableAction = {\r\n            name: item.name,\r\n            code: item.icon?.code ? item.icon?.code:\"\",\r\n            data: item,\r\n            value: value,\r\n        };\r\n        this.headerAction.emit(action)\r\n    }\r\n}\r\n","<nz-form-item style=\"position: relative\" title=\"{{header.name}}\" nzFlex>\n  <nz-form-control [nzSpan]=\"header.cspan || 24\" [ngSwitch]=\"header.type\">\n    <nz-input-group [nzSuffix]=\"inputClearTpl\" *ngSwitchCase=\"'text'\">\n      <input\n        nz-input\n        placeholder=\"{{header.name}}\"\n        [attr.id]=\"header.key\"\n        [(ngModel)]=\"value\"\n        (ngModelChange)=\"onChange($event)\"\n      />\n\n    </nz-input-group>\n\n    <nz-select *ngSwitchCase=\"'select'\"\n               [nzAllowClear]=\"!header.disableClear\"\n               nzPlaceHolder=\"{{header.name}}\"\n               nzAllowClear=\"true\"\n               [nzMode]=\"header.nzMode || 'default'\"\n               nzServerSearch\n               [(ngModel)]=\"value\"\n               (ngModelChange)=\"onChange($event)\"\n    >\n      <nz-option *ngFor=\"let o of dictList\" [nzLabel]=\"o.typeName\"\n                 [nzValue]=\"o.id\"></nz-option>\n    </nz-select>\n    <nz-select *ngSwitchCase=\"'selectCus'\"\n               [nzMode]=\"header.nzMode || 'default'\"\n               [nzAllowClear]=\"!header.disableClear\"\n               nzPlaceHolder=\"{{header.name}}\"\n               nzAllowClear=\"true\"\n               [nzShowSearch]=\"true\"\n               [(ngModel)]=\"value\"\n               (ngModelChange)=\"onChange($event)\"\n    >\n      <nz-option *ngFor=\"let o of header.dictList\" nzCustomContent [nzLabel]=\"o.label\"\n                 [nzValue]=\"o.value\">\n        <i class=\"select-icon\" *ngIf=\"header.icon?.isShow\" nz-icon [nzType]=\"header.icon.icon\"\n           nzTheme=\"outline\" style=\"margin-right: 1rem;\"\n           (click)=\"clickIcon(o.value,header,$event)\"></i>\n        {{o.label}}\n      </nz-option>\n\n    </nz-select>\n    <nz-cascader\n      *ngSwitchCase=\"'cascader'\"\n      (ngModelChange)=\"onChange($event)\"\n      style=\"flex: 1\" [nzAllowClear]=\"!header.disableClear\"\n      nzPlaceHolder=\"{{header.name}}\"\n      [nzShowSearch]=\"true\"\n      [nzOptions]=\"header.dictList\"\n      [(ngModel)]=\"value\"\n    ></nz-cascader>\n    <nz-tree-select\n      *ngSwitchCase=\"'treeSelect'\"\n      (ngModelChange)=\"onChange($event)\"\n      [nzAllowClear]=\"!header.disableClear\"\n      [nzNodes]=\"header.treeList\"\n      nzShowSearch=\"true\"\n      nzHideUnMatched=\"true\"\n      nzPlaceHolder=\"{{header.name}}\"\n      [nzShowSearch]=\"true\"\n      [(ngModel)]=\"value\"\n      [nzMultiple]=\"header.selectUrl.isMultiple\"\n      [nzMaxTagCount]=\"header.maxTagCount || 3\"\n    >\n    </nz-tree-select>\n    <nz-range-picker  *ngSwitchCase=\"'dayRange'\" [(ngModel)]=\"value\" (ngModelChange)=\"onChange($event)\"\n                      [(ngModel)]=\"value\"\n                      style=\"width: 100%;\"\n                      nzAllowClear=\"true\"\n                      [nzPlaceHolder]=\"[header.name+'开始时间','结束时间']\"\n                      [nzDefaultPickerValue]=\"header.defaultVal\"\n    ></nz-range-picker>\n    <nz-range-picker\n      *ngSwitchCase=\"'dateRange'\"\n      [nzShowTime]=\"header.nzShowTime ? header.nzShowTime : false\"\n      (ngModelChange)=\"onChange($event)\"\n\n      [nzFormat]=\"header.nzShowTime && header.nzShowTime.nzFormat  ?\n      ('yyyy-MM-dd '+ header.nzShowTime.nzFormat) : 'yyyy-MM-dd HH:mm:ss'\"\n\n      [nzShowNow]=\"header.nzShowTime && header.nzShowNow \"\n      [(ngModel)]=\"value\"\n      style=\"width: 100%;\"\n      nzAllowClear=\"true\"\n      [nzPlaceHolder]=\"[header.name+'开始时间','结束时间']\"\n      [nzDefaultPickerValue]=\"header.defaultVal\"></nz-range-picker>\n    <ng-container *ngSwitchCase=\"'sdate'\">\n      <nz-date-picker style=\"width: 100%\" [nzFormat]=\"'yyyy-MM-dd'\"\n                      (ngModelChange)=\"onChange($event)\"\n                      [(ngModel)]=\"value\"\n                      *ngIf=\"!header.dateMode\"\n                      nzAllowClear=\"true\"></nz-date-picker>\n      <nz-date-picker style=\"width: 100%\"\n                      (ngModelChange)=\"onChange($event)\"\n                      [(ngModel)]=\"value\"\n                      *ngIf=\"header.dateMode\"\n                      [nzMode]=\"header.dateMode\"\n                      nzAllowClear=\"true\"></nz-date-picker>\n    </ng-container>\n    <nz-month-picker\n      *ngSwitchCase=\"'smonth'\"\n      (ngModelChange)=\"onChange($event)\"\n      [(ngModel)]=\"value\"\n      [nzFormat]=\"'yyyy-MM'\"\n      [nzPlaceHolder]=\"[header.name]\"\n      nzAllowClear=\"true\"></nz-month-picker>\n    <span class=\"label-title\">{{header.name}}</span>\n  </nz-form-control>\n</nz-form-item>\n\n<ng-template #inputClearTpl>\n  <i nz-icon class=\"ant-input-clear-icon\" nzTheme=\"fill\" nzType=\"close-circle\"\n     *ngIf=\"!header.disableClear && value|isNotEmpty\" (click)=\"value = null;onChange()\"></i>\n</ng-template>\n"]}
|