atr-components 0.0.22 → 0.1.0

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.
@@ -2,4 +2,4 @@
2
2
  * Generated bundle index. Do not edit.
3
3
  */
4
4
  /// <amd-module name="atr-components" />
5
- export * from './public-api';
5
+ export * from './atr-public-api';
@@ -38,3 +38,4 @@ export * from "./lib/shared/validators/atr-validtors";
38
38
  export * from "./lib/shared/upload/upload.component";
39
39
  export * from "./lib/shared/table/table.component";
40
40
  export * from "./lib/shared/table/table-form-item/table-form-item.component";
41
+ export * from "./lib/shared/quill-editor/quill-editor.component";
@@ -1,5 +1,5 @@
1
1
  /**
2
2
  * Generated bundle index. Do not edit.
3
3
  */
4
- export * from './public-api';
5
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXRyLWNvbXBvbmVudHMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9wcm9qZWN0cy9jb21wb25lbnRzL3NyYy9hdHItY29tcG9uZW50cy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUVILGNBQWMsY0FBYyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBHZW5lcmF0ZWQgYnVuZGxlIGluZGV4LiBEbyBub3QgZWRpdC5cbiAqL1xuXG5leHBvcnQgKiBmcm9tICcuL3B1YmxpYy1hcGknO1xuIl19
4
+ export * from './atr-public-api';
5
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXRyLWNvbXBvbmVudHMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9wcm9qZWN0cy9jb21wb25lbnRzL3NyYy9hdHItY29tcG9uZW50cy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUVILGNBQWMsa0JBQWtCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEdlbmVyYXRlZCBidW5kbGUgaW5kZXguIERvIG5vdCBlZGl0LlxuICovXG5cbmV4cG9ydCAqIGZyb20gJy4vYXRyLXB1YmxpYy1hcGknO1xuIl19
@@ -0,0 +1,45 @@
1
+ /*
2
+ * Public API Surface of components
3
+ */
4
+ export * from "./core/animations/animations";
5
+ export * from "./core/interceptor/base.interceptor";
6
+ export * from "./core/ngz-module/cus-zorro-antd.module";
7
+ export * from "./core/animations/fly-in";
8
+ export * from "./core/animations/scroll-screen";
9
+ export * from './atr-components.module';
10
+ export * from './lib/hello/hello.module';
11
+ export * from './core/auth/auth.guard';
12
+ export * from './core/base/atr-common';
13
+ export * from './core/routereuse/atr-reuse-strategy';
14
+ export * from "./core/utils/ToolsUtil";
15
+ export * from "./core/utils/localstorage.util";
16
+ export * from "./core/utils/sessionstorage.util";
17
+ export * from "./core/services/dict/dict.service";
18
+ export * from "./core/services/http.service";
19
+ export * from "./core/services/menu.service";
20
+ export * from "./core/services/upload-oss.service";
21
+ export * from "./core/directive/role.directive";
22
+ export * from "./core/directive/error-img.directive";
23
+ export * from "./core/directive/hq-spin.directive";
24
+ export { HelloComponent } from './lib/hello/hello.component';
25
+ export * from "./core/pipe/pipe-module.module";
26
+ export * from "./core/pipe/is-empty.pipe";
27
+ export * from "./core/pipe/dicts.pipe";
28
+ export * from "./core/pipe/defaultVal.pipe";
29
+ export * from "./core/pipe/day.pipe";
30
+ export * from "./core/pipe/safe-compute.pipe";
31
+ export * from "./core/pipe/is-not-empty.pipe";
32
+ export * from "./lib/shared/atr-shared.module";
33
+ export * from "./lib/shared/form/form.component";
34
+ export * from "./lib/shared/local-upload/local-upload.component";
35
+ export * from "./lib/shared/select-tree/select-tree.component";
36
+ export * from "./lib/shared/service/busi.service";
37
+ export * from "./lib/shared/table/table-td/table-td.component";
38
+ export * from "./lib/shared/share.service";
39
+ export * from "./lib/shared/video/video.component";
40
+ export * from "./lib/shared/validators/atr-validtors";
41
+ export * from "./lib/shared/upload/upload.component";
42
+ export * from "./lib/shared/table/table.component";
43
+ export * from "./lib/shared/table/table-form-item/table-form-item.component";
44
+ export * from "./lib/shared/quill-editor/quill-editor.component";
45
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXRyLXB1YmxpYy1hcGkuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9wcm9qZWN0cy9jb21wb25lbnRzL3NyYy9hdHItcHVibGljLWFwaS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUNILGNBQWMsOEJBQThCLENBQUE7QUFDNUMsY0FBYyxxQ0FBcUMsQ0FBQTtBQUNuRCxjQUFjLHlDQUF5QyxDQUFBO0FBQ3ZELGNBQWMsMEJBQTBCLENBQUE7QUFDeEMsY0FBYyxpQ0FBaUMsQ0FBQTtBQUMvQyxjQUFjLHlCQUF5QixDQUFDO0FBQ3hDLGNBQWMsMEJBQTBCLENBQUM7QUFDekMsY0FBYyx3QkFBd0IsQ0FBQztBQUN2QyxjQUFjLHdCQUF3QixDQUFDO0FBQ3ZDLGNBQWMsc0NBQXNDLENBQUM7QUFDckQsY0FBYyx3QkFBd0IsQ0FBQTtBQUN0QyxjQUFjLGdDQUFnQyxDQUFBO0FBQzlDLGNBQWMsa0NBQWtDLENBQUE7QUFDaEQsY0FBYyxtQ0FBbUMsQ0FBQTtBQUNqRCxjQUFjLDhCQUE4QixDQUFBO0FBQzVDLGNBQWMsOEJBQThCLENBQUE7QUFDNUMsY0FBYyxvQ0FBb0MsQ0FBQTtBQUNsRCxjQUFjLGlDQUFpQyxDQUFDO0FBQ2hELGNBQWMsc0NBQXNDLENBQUM7QUFDckQsY0FBYyxvQ0FBb0MsQ0FBQztBQUNuRCxPQUFPLEVBQUMsY0FBYyxFQUFDLE1BQU0sNkJBQTZCLENBQUM7QUFFM0QsY0FBYyxnQ0FBZ0MsQ0FBQTtBQUM5QyxjQUFjLDJCQUEyQixDQUFDO0FBQzFDLGNBQWMsd0JBQXdCLENBQUM7QUFDdkMsY0FBYyw2QkFBNkIsQ0FBQztBQUM1QyxjQUFjLHNCQUFzQixDQUFDO0FBQ3JDLGNBQWMsK0JBQStCLENBQUM7QUFDOUMsY0FBYywrQkFBK0IsQ0FBQztBQUU5QyxjQUFjLGdDQUFnQyxDQUFBO0FBQzlDLGNBQWMsa0NBQWtDLENBQUE7QUFDaEQsY0FBYyxrREFBa0QsQ0FBQTtBQUNoRSxjQUFjLGdEQUFnRCxDQUFBO0FBQzlELGNBQWMsbUNBQW1DLENBQUE7QUFDakQsY0FBYyxnREFBZ0QsQ0FBQTtBQUM5RCxjQUFjLDRCQUE0QixDQUFBO0FBQzFDLGNBQWMsb0NBQW9DLENBQUE7QUFDbEQsY0FBYyx1Q0FBdUMsQ0FBQTtBQUNyRCxjQUFjLHNDQUFzQyxDQUFBO0FBQ3BELGNBQWMsb0NBQW9DLENBQUE7QUFDbEQsY0FBYyw4REFBOEQsQ0FBQTtBQUM1RSxjQUFjLGtEQUFrRCxDQUFBIiwic291cmNlc0NvbnRlbnQiOlsiLypcbiAqIFB1YmxpYyBBUEkgU3VyZmFjZSBvZiBjb21wb25lbnRzXG4gKi9cbmV4cG9ydCAqIGZyb20gXCIuL2NvcmUvYW5pbWF0aW9ucy9hbmltYXRpb25zXCJcbmV4cG9ydCAqIGZyb20gXCIuL2NvcmUvaW50ZXJjZXB0b3IvYmFzZS5pbnRlcmNlcHRvclwiXG5leHBvcnQgKiBmcm9tIFwiLi9jb3JlL25nei1tb2R1bGUvY3VzLXpvcnJvLWFudGQubW9kdWxlXCJcbmV4cG9ydCAqIGZyb20gXCIuL2NvcmUvYW5pbWF0aW9ucy9mbHktaW5cIlxuZXhwb3J0ICogZnJvbSBcIi4vY29yZS9hbmltYXRpb25zL3Njcm9sbC1zY3JlZW5cIlxuZXhwb3J0ICogZnJvbSAnLi9hdHItY29tcG9uZW50cy5tb2R1bGUnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvaGVsbG8vaGVsbG8ubW9kdWxlJztcbmV4cG9ydCAqIGZyb20gJy4vY29yZS9hdXRoL2F1dGguZ3VhcmQnO1xuZXhwb3J0ICogZnJvbSAnLi9jb3JlL2Jhc2UvYXRyLWNvbW1vbic7XG5leHBvcnQgKiBmcm9tICcuL2NvcmUvcm91dGVyZXVzZS9hdHItcmV1c2Utc3RyYXRlZ3knO1xuZXhwb3J0ICogZnJvbSBcIi4vY29yZS91dGlscy9Ub29sc1V0aWxcIlxuZXhwb3J0ICogZnJvbSBcIi4vY29yZS91dGlscy9sb2NhbHN0b3JhZ2UudXRpbFwiXG5leHBvcnQgKiBmcm9tIFwiLi9jb3JlL3V0aWxzL3Nlc3Npb25zdG9yYWdlLnV0aWxcIlxuZXhwb3J0ICogZnJvbSBcIi4vY29yZS9zZXJ2aWNlcy9kaWN0L2RpY3Quc2VydmljZVwiXG5leHBvcnQgKiBmcm9tIFwiLi9jb3JlL3NlcnZpY2VzL2h0dHAuc2VydmljZVwiXG5leHBvcnQgKiBmcm9tIFwiLi9jb3JlL3NlcnZpY2VzL21lbnUuc2VydmljZVwiXG5leHBvcnQgKiBmcm9tIFwiLi9jb3JlL3NlcnZpY2VzL3VwbG9hZC1vc3Muc2VydmljZVwiXG5leHBvcnQgKiBmcm9tIFwiLi9jb3JlL2RpcmVjdGl2ZS9yb2xlLmRpcmVjdGl2ZVwiO1xuZXhwb3J0ICogZnJvbSBcIi4vY29yZS9kaXJlY3RpdmUvZXJyb3ItaW1nLmRpcmVjdGl2ZVwiO1xuZXhwb3J0ICogZnJvbSBcIi4vY29yZS9kaXJlY3RpdmUvaHEtc3Bpbi5kaXJlY3RpdmVcIjtcbmV4cG9ydCB7SGVsbG9Db21wb25lbnR9IGZyb20gJy4vbGliL2hlbGxvL2hlbGxvLmNvbXBvbmVudCc7XG5cbmV4cG9ydCAqIGZyb20gXCIuL2NvcmUvcGlwZS9waXBlLW1vZHVsZS5tb2R1bGVcIlxuZXhwb3J0ICogZnJvbSBcIi4vY29yZS9waXBlL2lzLWVtcHR5LnBpcGVcIjtcbmV4cG9ydCAqIGZyb20gXCIuL2NvcmUvcGlwZS9kaWN0cy5waXBlXCI7XG5leHBvcnQgKiBmcm9tIFwiLi9jb3JlL3BpcGUvZGVmYXVsdFZhbC5waXBlXCI7XG5leHBvcnQgKiBmcm9tIFwiLi9jb3JlL3BpcGUvZGF5LnBpcGVcIjtcbmV4cG9ydCAqIGZyb20gXCIuL2NvcmUvcGlwZS9zYWZlLWNvbXB1dGUucGlwZVwiO1xuZXhwb3J0ICogZnJvbSBcIi4vY29yZS9waXBlL2lzLW5vdC1lbXB0eS5waXBlXCI7XG5cbmV4cG9ydCAqIGZyb20gXCIuL2xpYi9zaGFyZWQvYXRyLXNoYXJlZC5tb2R1bGVcIlxuZXhwb3J0ICogZnJvbSBcIi4vbGliL3NoYXJlZC9mb3JtL2Zvcm0uY29tcG9uZW50XCJcbmV4cG9ydCAqIGZyb20gXCIuL2xpYi9zaGFyZWQvbG9jYWwtdXBsb2FkL2xvY2FsLXVwbG9hZC5jb21wb25lbnRcIlxuZXhwb3J0ICogZnJvbSBcIi4vbGliL3NoYXJlZC9zZWxlY3QtdHJlZS9zZWxlY3QtdHJlZS5jb21wb25lbnRcIlxuZXhwb3J0ICogZnJvbSBcIi4vbGliL3NoYXJlZC9zZXJ2aWNlL2J1c2kuc2VydmljZVwiXG5leHBvcnQgKiBmcm9tIFwiLi9saWIvc2hhcmVkL3RhYmxlL3RhYmxlLXRkL3RhYmxlLXRkLmNvbXBvbmVudFwiXG5leHBvcnQgKiBmcm9tIFwiLi9saWIvc2hhcmVkL3NoYXJlLnNlcnZpY2VcIlxuZXhwb3J0ICogZnJvbSBcIi4vbGliL3NoYXJlZC92aWRlby92aWRlby5jb21wb25lbnRcIlxuZXhwb3J0ICogZnJvbSBcIi4vbGliL3NoYXJlZC92YWxpZGF0b3JzL2F0ci12YWxpZHRvcnNcIlxuZXhwb3J0ICogZnJvbSBcIi4vbGliL3NoYXJlZC91cGxvYWQvdXBsb2FkLmNvbXBvbmVudFwiXG5leHBvcnQgKiBmcm9tIFwiLi9saWIvc2hhcmVkL3RhYmxlL3RhYmxlLmNvbXBvbmVudFwiXG5leHBvcnQgKiBmcm9tIFwiLi9saWIvc2hhcmVkL3RhYmxlL3RhYmxlLWZvcm0taXRlbS90YWJsZS1mb3JtLWl0ZW0uY29tcG9uZW50XCJcbmV4cG9ydCAqIGZyb20gXCIuL2xpYi9zaGFyZWQvcXVpbGwtZWRpdG9yL3F1aWxsLWVkaXRvci5jb21wb25lbnRcIlxuXG4iXX0=
@@ -18,7 +18,10 @@ import { TableFormItemComponent } from "./table/table-form-item/table-form-item.
18
18
  import { PipeModuleModule } from "../../core/pipe/pipe-module.module";
19
19
  import { AtrComponentsModule } from "../../atr-components.module";
20
20
  import { CusNgZorroAntdModule } from "../../core/ngz-module/cus-zorro-antd.module";
21
+ import { QuillModule } from "ngx-quill";
22
+ import { QuillEditorComponent } from "./quill-editor/quill-editor.component";
21
23
  import * as i0 from "@angular/core";
24
+ import * as i1 from "ngx-quill";
22
25
  const THIRDMODULES = [
23
26
  CusNgZorroAntdModule,
24
27
  NzResizableModule
@@ -27,7 +30,7 @@ const SERVICE_PROVIDES = [];
27
30
  registerLocaleData(zh);
28
31
  // #endregion
29
32
  // #region your componets & directives
30
- const COMPONENTS = [TableFormItemComponent, TableTdComponent, AtrTableComponent, UploadComponent, AtrFormComponent, LocalUploadComponent,
33
+ const COMPONENTS = [QuillEditorComponent, TableFormItemComponent, TableTdComponent, AtrTableComponent, UploadComponent, AtrFormComponent, LocalUploadComponent,
31
34
  SelectTreeComponent, VideoComponent];
32
35
  //SharedModule
33
36
  // 应 包含定义:
@@ -37,7 +40,7 @@ const COMPONENTS = [TableFormItemComponent, TableTdComponent, AtrTableComponent,
37
40
  export class AtrSharedModule {
38
41
  }
39
42
  AtrSharedModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: AtrSharedModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
40
- AtrSharedModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: AtrSharedModule, declarations: [TableFormItemComponent, TableTdComponent, AtrTableComponent, UploadComponent, AtrFormComponent, LocalUploadComponent,
43
+ AtrSharedModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: AtrSharedModule, declarations: [QuillEditorComponent, TableFormItemComponent, TableTdComponent, AtrTableComponent, UploadComponent, AtrFormComponent, LocalUploadComponent,
41
44
  SelectTreeComponent, VideoComponent], imports: [PipeModuleModule,
42
45
  CommonModule,
43
46
  FormsModule,
@@ -48,12 +51,12 @@ AtrSharedModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version
48
51
  VgOverlayPlayModule,
49
52
  VgBufferingModule,
50
53
  DragDropModule,
51
- AtrComponentsModule], exports: [DragDropModule,
54
+ AtrComponentsModule, i1.QuillModule], exports: [DragDropModule,
52
55
  CommonModule,
53
56
  FormsModule,
54
57
  ReactiveFormsModule,
55
58
  RouterModule, CusNgZorroAntdModule,
56
- NzResizableModule, TableFormItemComponent, TableTdComponent, AtrTableComponent, UploadComponent, AtrFormComponent, LocalUploadComponent,
59
+ NzResizableModule, QuillEditorComponent, TableFormItemComponent, TableTdComponent, AtrTableComponent, UploadComponent, AtrFormComponent, LocalUploadComponent,
57
60
  SelectTreeComponent, VideoComponent, PipeModuleModule] });
58
61
  AtrSharedModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: AtrSharedModule, providers: SERVICE_PROVIDES, imports: [[
59
62
  PipeModuleModule,
@@ -68,7 +71,40 @@ AtrSharedModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version
68
71
  VgOverlayPlayModule,
69
72
  VgBufferingModule,
70
73
  DragDropModule,
71
- AtrComponentsModule
74
+ AtrComponentsModule,
75
+ QuillModule.forRoot({
76
+ modules: {
77
+ syntax: false,
78
+ imageResize: {},
79
+ toolbar: {
80
+ container: [
81
+ ['undo', 'redo'],
82
+ ['bold', 'italic', 'underline'],
83
+ // ['code-block'], // blockquote
84
+ // [{ header: 1 }, { header: 2 }], // custom button values
85
+ [{ list: 'ordered' }, { list: 'bullet' }],
86
+ // [{ script: 'sub' }, { script: 'super' }], // superscript/subscript
87
+ [{ indent: '-1' }, { indent: '+1' }],
88
+ // [{ direction: 'rtl' }], // text direction
89
+ // [{ size: ['small', false, 'large', 'huge'] }], // custom dropdown
90
+ [{ header: [1, 2, 3, 4, 5, 6, false] }],
91
+ [{ color: [] }, { background: [] }],
92
+ // [{ font: [] }],
93
+ [{ align: [] }],
94
+ ['clean'],
95
+ ['image'], // link and image, video
96
+ ],
97
+ handlers: {
98
+ redo() {
99
+ this['quill'].history.redo();
100
+ },
101
+ undo() {
102
+ this['quill'].history.undo();
103
+ }
104
+ }
105
+ }
106
+ }
107
+ }),
72
108
  ], DragDropModule,
73
109
  CommonModule,
74
110
  FormsModule,
@@ -91,7 +127,40 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.11", ngImpo
91
127
  VgOverlayPlayModule,
92
128
  VgBufferingModule,
93
129
  DragDropModule,
94
- AtrComponentsModule
130
+ AtrComponentsModule,
131
+ QuillModule.forRoot({
132
+ modules: {
133
+ syntax: false,
134
+ imageResize: {},
135
+ toolbar: {
136
+ container: [
137
+ ['undo', 'redo'],
138
+ ['bold', 'italic', 'underline'],
139
+ // ['code-block'], // blockquote
140
+ // [{ header: 1 }, { header: 2 }], // custom button values
141
+ [{ list: 'ordered' }, { list: 'bullet' }],
142
+ // [{ script: 'sub' }, { script: 'super' }], // superscript/subscript
143
+ [{ indent: '-1' }, { indent: '+1' }],
144
+ // [{ direction: 'rtl' }], // text direction
145
+ // [{ size: ['small', false, 'large', 'huge'] }], // custom dropdown
146
+ [{ header: [1, 2, 3, 4, 5, 6, false] }],
147
+ [{ color: [] }, { background: [] }],
148
+ // [{ font: [] }],
149
+ [{ align: [] }],
150
+ ['clean'],
151
+ ['image'], // link and image, video
152
+ ],
153
+ handlers: {
154
+ redo() {
155
+ this['quill'].history.redo();
156
+ },
157
+ undo() {
158
+ this['quill'].history.undo();
159
+ }
160
+ }
161
+ }
162
+ }
163
+ }),
95
164
  ],
96
165
  declarations: [
97
166
  // your components
@@ -112,4 +181,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.11", ngImpo
112
181
  providers: SERVICE_PROVIDES
113
182
  }]
114
183
  }] });
115
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXRyLXNoYXJlZC5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jb21wb25lbnRzL3NyYy9saWIvc2hhcmVkL2F0ci1zaGFyZWQubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsV0FBVyxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFDbEUsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLHlCQUF5QixDQUFDO0FBQzVELE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSwyQkFBMkIsQ0FBQztBQUM1RCxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSx1QkFBdUIsQ0FBQztBQUN6RCxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQztBQUM1RCxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUNyRCxPQUFPLEVBQUUsTUFBTSw0QkFBNEIsQ0FBQztBQUM1QyxPQUFPLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSx1Q0FBdUMsQ0FBQztBQUM3RSxPQUFPLEVBQUMsUUFBUSxFQUFDLE1BQU0sZUFBZSxDQUFDO0FBQ3ZDLE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLHFDQUFxQyxDQUFDO0FBQzFFLE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQztBQUN6RCxPQUFPLEVBQUMsZ0JBQWdCLEVBQUUsWUFBWSxFQUFFLG1CQUFtQixFQUFFLGlCQUFpQixFQUFDLE1BQU0sZ0JBQWdCLENBQUM7QUFDdEcsT0FBTyxFQUFDLGNBQWMsRUFBQyxNQUFNLHdCQUF3QixDQUFDO0FBQ3RELE9BQU8sRUFBQyxnQkFBZ0IsRUFBQyxNQUFNLHFDQUFxQyxDQUFDO0FBQ3JFLE9BQU8sRUFBQyxzQkFBc0IsRUFBQyxNQUFNLG1EQUFtRCxDQUFDO0FBQ3pGLE9BQU8sRUFBQyxnQkFBZ0IsRUFBQyxNQUFNLG9DQUFvQyxDQUFDO0FBQ3BFLE9BQU8sRUFBQyxtQkFBbUIsRUFBQyxNQUFNLDZCQUE2QixDQUFDO0FBQ2hFLE9BQU8sRUFBQyxvQkFBb0IsRUFBQyxNQUFNLDZDQUE2QyxDQUFDOztBQUNqRixNQUFNLFlBQVksR0FBRztJQUNuQixvQkFBb0I7SUFDcEIsaUJBQWlCO0NBQ2xCLENBQUM7QUFFRixNQUFNLGdCQUFnQixHQUFPLEVBQUUsQ0FBQztBQUNoQyxrQkFBa0IsQ0FBQyxFQUFFLENBQUMsQ0FBQztBQUN2QixhQUFhO0FBRWIsc0NBQXNDO0FBQ3RDLE1BQU0sVUFBVSxHQUFHLENBQUMsc0JBQXNCLEVBQUMsZ0JBQWdCLEVBQUMsaUJBQWlCLEVBQUMsZUFBZSxFQUFDLGdCQUFnQixFQUFDLG9CQUFvQjtJQUNqSSxtQkFBbUIsRUFBQyxjQUFjLENBQUMsQ0FBQztBQW1DdEMsY0FBYztBQUNkLFVBQVU7QUFDVixjQUFjO0FBQ2QsZUFBZTtBQUNmLHFCQUFxQjtBQUNyQixNQUFNLE9BQU8sZUFBZTs7NkdBQWYsZUFBZTs4R0FBZixlQUFlLGlCQXpDUixzQkFBc0IsRUFBQyxnQkFBZ0IsRUFBQyxpQkFBaUIsRUFBQyxlQUFlLEVBQUMsZ0JBQWdCLEVBQUMsb0JBQW9CO1FBQ2pJLG1CQUFtQixFQUFDLGNBQWMsYUFHaEMsZ0JBQWdCO1FBQ2hCLFlBQVk7UUFDWixXQUFXO1FBQ1gsbUJBQW1CO1FBQ25CLFlBQVksRUFqQmQsb0JBQW9CO1FBQ3BCLGlCQUFpQixFQW1CZixZQUFZO1FBQ1osZ0JBQWdCO1FBQ2hCLG1CQUFtQjtRQUNuQixpQkFBaUI7UUFDakIsY0FBYztRQUNkLG1CQUFtQixhQU9uQixjQUFjO1FBQ2QsWUFBWTtRQUNaLFdBQVc7UUFDWCxtQkFBbUI7UUFDbkIsWUFBWSxFQXBDZCxvQkFBb0I7UUFDcEIsaUJBQWlCLEVBUUMsc0JBQXNCLEVBQUMsZ0JBQWdCLEVBQUMsaUJBQWlCLEVBQUMsZUFBZSxFQUFDLGdCQUFnQixFQUFDLG9CQUFvQjtRQUNqSSxtQkFBbUIsRUFBQyxjQUFjLEVBK0JoQyxnQkFBZ0I7OEdBU1AsZUFBZSxhQVBoQixnQkFBZ0IsWUEvQmpCO1lBQ1AsZ0JBQWdCO1lBQ2hCLFlBQVk7WUFDWixXQUFXO1lBQ1gsbUJBQW1CO1lBQ25CLFlBQVk7WUFDWixhQUFhO1lBQ2IsR0FBRyxZQUFZO1lBQ2YsWUFBWTtZQUNaLGdCQUFnQjtZQUNoQixtQkFBbUI7WUFDbkIsaUJBQWlCO1lBQ2pCLGNBQWM7WUFDZCxtQkFBbUI7U0FDcEIsRUFNQyxjQUFjO1FBQ2QsWUFBWTtRQUNaLFdBQVc7UUFDWCxtQkFBbUI7UUFDbkIsWUFBWSxFQXBDZCxvQkFBb0I7UUFDcEIsaUJBQWlCLEVBd0NmLGdCQUFnQjs0RkFTUCxlQUFlO2tCQXZDM0IsUUFBUTttQkFBQztvQkFDUixPQUFPLEVBQUU7d0JBQ1AsZ0JBQWdCO3dCQUNoQixZQUFZO3dCQUNaLFdBQVc7d0JBQ1gsbUJBQW1CO3dCQUNuQixZQUFZO3dCQUNaLGFBQWE7d0JBQ2IsR0FBRyxZQUFZO3dCQUNmLFlBQVk7d0JBQ1osZ0JBQWdCO3dCQUNoQixtQkFBbUI7d0JBQ25CLGlCQUFpQjt3QkFDakIsY0FBYzt3QkFDZCxtQkFBbUI7cUJBQ3BCO29CQUNELFlBQVksRUFBRTt3QkFDWixrQkFBa0I7d0JBQ2xCLEdBQUcsVUFBVTtxQkFDZDtvQkFDRCxPQUFPLEVBQUU7d0JBQ1AsY0FBYzt3QkFDZCxZQUFZO3dCQUNaLFdBQVc7d0JBQ1gsbUJBQW1CO3dCQUNuQixZQUFZO3dCQUNaLGFBQWE7d0JBQ2IsR0FBRyxZQUFZO3dCQUNmLGtCQUFrQjt3QkFDbEIsR0FBRyxVQUFVO3dCQUNiLGdCQUFnQjtxQkFDakI7b0JBQ0QsU0FBUyxFQUFDLGdCQUFnQjtpQkFDM0IiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xyXG5pbXBvcnQgeyBSZWFjdGl2ZUZvcm1zTW9kdWxlLCBGb3Jtc01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcclxuaW1wb3J0IHsgUm91dGVyTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvcm91dGVyJztcclxuaW1wb3J0IHsgQXRyVGFibGVDb21wb25lbnQgfSBmcm9tICcuL3RhYmxlL3RhYmxlLmNvbXBvbmVudCc7XHJcbmltcG9ydCB7IFVwbG9hZENvbXBvbmVudCB9IGZyb20gJy4vdXBsb2FkL3VwbG9hZC5jb21wb25lbnQnO1xyXG5pbXBvcnQgeyBBdHJGb3JtQ29tcG9uZW50IH0gZnJvbSAnLi9mb3JtL2Zvcm0uY29tcG9uZW50JztcclxuaW1wb3J0IHsgTnpSZXNpemFibGVNb2R1bGUgfSBmcm9tICduZy16b3Jyby1hbnRkL3Jlc2l6YWJsZSc7XHJcbmltcG9ydCB7IHJlZ2lzdGVyTG9jYWxlRGF0YSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XHJcbmltcG9ydCB6aCBmcm9tICdAYW5ndWxhci9jb21tb24vbG9jYWxlcy96aCc7XHJcbmltcG9ydCB7IExvY2FsVXBsb2FkQ29tcG9uZW50IH0gZnJvbSAnLi9sb2NhbC11cGxvYWQvbG9jYWwtdXBsb2FkLmNvbXBvbmVudCc7XHJcbmltcG9ydCB7TmdNb2R1bGV9IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XHJcbmltcG9ydCB7IFNlbGVjdFRyZWVDb21wb25lbnQgfSBmcm9tICcuL3NlbGVjdC10cmVlL3NlbGVjdC10cmVlLmNvbXBvbmVudCc7XHJcbmltcG9ydCB7IFZpZGVvQ29tcG9uZW50IH0gZnJvbSAnLi92aWRlby92aWRlby5jb21wb25lbnQnO1xyXG5pbXBvcnQge1ZnQ29udHJvbHNNb2R1bGUsIFZnQ29yZU1vZHVsZSwgVmdPdmVybGF5UGxheU1vZHVsZSwgVmdCdWZmZXJpbmdNb2R1bGV9IGZyb20gXCJuZ3gtdmlkZW9ndWxhclwiO1xyXG5pbXBvcnQge0RyYWdEcm9wTW9kdWxlfSBmcm9tIFwiQGFuZ3VsYXIvY2RrL2RyYWctZHJvcFwiO1xyXG5pbXBvcnQge1RhYmxlVGRDb21wb25lbnR9IGZyb20gXCIuL3RhYmxlL3RhYmxlLXRkL3RhYmxlLXRkLmNvbXBvbmVudFwiO1xyXG5pbXBvcnQge1RhYmxlRm9ybUl0ZW1Db21wb25lbnR9IGZyb20gXCIuL3RhYmxlL3RhYmxlLWZvcm0taXRlbS90YWJsZS1mb3JtLWl0ZW0uY29tcG9uZW50XCI7XHJcbmltcG9ydCB7UGlwZU1vZHVsZU1vZHVsZX0gZnJvbSBcIi4uLy4uL2NvcmUvcGlwZS9waXBlLW1vZHVsZS5tb2R1bGVcIjtcclxuaW1wb3J0IHtBdHJDb21wb25lbnRzTW9kdWxlfSBmcm9tIFwiLi4vLi4vYXRyLWNvbXBvbmVudHMubW9kdWxlXCI7XHJcbmltcG9ydCB7Q3VzTmdab3Jyb0FudGRNb2R1bGV9IGZyb20gXCIuLi8uLi9jb3JlL25nei1tb2R1bGUvY3VzLXpvcnJvLWFudGQubW9kdWxlXCI7XHJcbmNvbnN0IFRISVJETU9EVUxFUyA9IFtcclxuICBDdXNOZ1pvcnJvQW50ZE1vZHVsZSxcclxuICBOelJlc2l6YWJsZU1vZHVsZVxyXG5dO1xyXG5cclxuY29uc3QgU0VSVklDRV9QUk9WSURFUzphbnkgPSBbXTtcclxucmVnaXN0ZXJMb2NhbGVEYXRhKHpoKTtcclxuLy8gI2VuZHJlZ2lvblxyXG5cclxuLy8gI3JlZ2lvbiB5b3VyIGNvbXBvbmV0cyAmIGRpcmVjdGl2ZXNcclxuY29uc3QgQ09NUE9ORU5UUyA9IFtUYWJsZUZvcm1JdGVtQ29tcG9uZW50LFRhYmxlVGRDb21wb25lbnQsQXRyVGFibGVDb21wb25lbnQsVXBsb2FkQ29tcG9uZW50LEF0ckZvcm1Db21wb25lbnQsTG9jYWxVcGxvYWRDb21wb25lbnQsXHJcbiAgU2VsZWN0VHJlZUNvbXBvbmVudCxWaWRlb0NvbXBvbmVudF07XHJcbkBOZ01vZHVsZSh7XHJcbiAgaW1wb3J0czogW1xyXG4gICAgUGlwZU1vZHVsZU1vZHVsZSxcclxuICAgIENvbW1vbk1vZHVsZSxcclxuICAgIEZvcm1zTW9kdWxlLFxyXG4gICAgUmVhY3RpdmVGb3Jtc01vZHVsZSxcclxuICAgIFJvdXRlck1vZHVsZSxcclxuICAgIC8vIHRoaXJkIGxpYnNcclxuICAgIC4uLlRISVJETU9EVUxFUyxcclxuICAgIFZnQ29yZU1vZHVsZSxcclxuICAgIFZnQ29udHJvbHNNb2R1bGUsXHJcbiAgICBWZ092ZXJsYXlQbGF5TW9kdWxlLFxyXG4gICAgVmdCdWZmZXJpbmdNb2R1bGUsXHJcbiAgICBEcmFnRHJvcE1vZHVsZSxcclxuICAgIEF0ckNvbXBvbmVudHNNb2R1bGVcclxuICBdLFxyXG4gIGRlY2xhcmF0aW9uczogW1xyXG4gICAgLy8geW91ciBjb21wb25lbnRzXHJcbiAgICAuLi5DT01QT05FTlRTLFxyXG4gIF0sXHJcbiAgZXhwb3J0czogW1xyXG4gICAgRHJhZ0Ryb3BNb2R1bGUsXHJcbiAgICBDb21tb25Nb2R1bGUsXHJcbiAgICBGb3Jtc01vZHVsZSxcclxuICAgIFJlYWN0aXZlRm9ybXNNb2R1bGUsXHJcbiAgICBSb3V0ZXJNb2R1bGUsXHJcbiAgICAvLyB0aGlyZCBsaWJzXHJcbiAgICAuLi5USElSRE1PRFVMRVMsXHJcbiAgICAvLyB5b3VyIGNvbXBvbmVudHNcclxuICAgIC4uLkNPTVBPTkVOVFMsXHJcbiAgICBQaXBlTW9kdWxlTW9kdWxlXHJcbiAgXSxcclxuICBwcm92aWRlcnM6U0VSVklDRV9QUk9WSURFU1xyXG59KVxyXG4vL1NoYXJlZE1vZHVsZVxyXG4vLyDlupQg5YyF5ZCr5a6a5LmJ77yaXHJcbi8vIOW6lOeUqOmAmueUqOiHquWumuS5ieS4muWKoee7hOS7tlxyXG4vLyDlupQg5a+85Ye65omA5pyJ5YyF5ZCr55qE5qih5Z2X44CCXHJcbi8vIOS4jeW6lCDmnIkgcHJvdmlkZXJzIOWxnuaAp+OAglxyXG5leHBvcnQgY2xhc3MgQXRyU2hhcmVkTW9kdWxlIHsgfVxyXG4iXX0=
184
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"atr-shared.module.js","sourceRoot":"","sources":["../../../../../projects/components/src/lib/shared/atr-shared.module.ts"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\r\nimport { ReactiveFormsModule, FormsModule } from '@angular/forms';\r\nimport { RouterModule } from '@angular/router';\r\nimport { AtrTableComponent } from './table/table.component';\r\nimport { UploadComponent } from './upload/upload.component';\r\nimport { AtrFormComponent } from './form/form.component';\r\nimport { NzResizableModule } from 'ng-zorro-antd/resizable';\r\nimport { registerLocaleData } from '@angular/common';\r\nimport zh from '@angular/common/locales/zh';\r\nimport { LocalUploadComponent } from './local-upload/local-upload.component';\r\nimport {NgModule} from \"@angular/core\";\r\nimport { SelectTreeComponent } from './select-tree/select-tree.component';\r\nimport { VideoComponent } from './video/video.component';\r\nimport {VgControlsModule, VgCoreModule, VgOverlayPlayModule, VgBufferingModule} from \"ngx-videogular\";\r\nimport {DragDropModule} from \"@angular/cdk/drag-drop\";\r\nimport {TableTdComponent} from \"./table/table-td/table-td.component\";\r\nimport {TableFormItemComponent} from \"./table/table-form-item/table-form-item.component\";\r\nimport {PipeModuleModule} from \"../../core/pipe/pipe-module.module\";\r\nimport {AtrComponentsModule} from \"../../atr-components.module\";\r\nimport {CusNgZorroAntdModule} from \"../../core/ngz-module/cus-zorro-antd.module\";\r\nimport {QuillModule} from \"ngx-quill\";\r\nimport {QuillEditorComponent} from \"./quill-editor/quill-editor.component\";\r\nconst THIRDMODULES = [\r\n  CusNgZorroAntdModule,\r\n  NzResizableModule\r\n];\r\n\r\nconst SERVICE_PROVIDES:any = [];\r\nregisterLocaleData(zh);\r\n// #endregion\r\n\r\n// #region your componets & directives\r\nconst COMPONENTS = [QuillEditorComponent,TableFormItemComponent,TableTdComponent,AtrTableComponent,UploadComponent,AtrFormComponent,LocalUploadComponent,\r\n  SelectTreeComponent,VideoComponent];\r\n@NgModule({\r\n  imports: [\r\n    PipeModuleModule,\r\n    CommonModule,\r\n    FormsModule,\r\n    ReactiveFormsModule,\r\n    RouterModule,\r\n    // third libs\r\n    ...THIRDMODULES,\r\n    VgCoreModule,\r\n    VgControlsModule,\r\n    VgOverlayPlayModule,\r\n    VgBufferingModule,\r\n    DragDropModule,\r\n    AtrComponentsModule,\r\n    QuillModule.forRoot({\r\n      modules: {\r\n        syntax: false,\r\n        imageResize: {},\r\n        toolbar: {\r\n          container: [\r\n            ['undo', 'redo'],\r\n            ['bold', 'italic', 'underline'],        // toggled buttons\r\n            // ['code-block'], // blockquote\r\n            // [{ header: 1 }, { header: 2 }],               // custom button values\r\n            [{list: 'ordered'}, {list: 'bullet'}],\r\n            // [{ script: 'sub' }, { script: 'super' }],      // superscript/subscript\r\n            [{indent: '-1'}, {indent: '+1'}],          // outdent/indent\r\n            // [{ direction: 'rtl' }],                         // text direction\r\n            // [{ size: ['small', false, 'large', 'huge'] }],  // custom dropdown\r\n            [{header: [1, 2, 3, 4, 5, 6, false]}],\r\n            [{color: []}, {background: []}],          // dropdown with defaults from theme\r\n            // [{ font: [] }],\r\n            [{align: []}],\r\n            ['clean'],                                         // remove formatting button\r\n            ['image'],                      // link and image, video\r\n          ],\r\n          handlers: {\r\n            redo() {\r\n              this['quill'].history.redo();\r\n            },\r\n            undo() {\r\n              this['quill'].history.undo();\r\n            }\r\n          }\r\n        }\r\n      }\r\n    }),\r\n  ],\r\n  declarations: [\r\n    // your components\r\n    ...COMPONENTS,\r\n  ],\r\n  exports: [\r\n    DragDropModule,\r\n    CommonModule,\r\n    FormsModule,\r\n    ReactiveFormsModule,\r\n    RouterModule,\r\n    // third libs\r\n    ...THIRDMODULES,\r\n    // your components\r\n    ...COMPONENTS,\r\n    PipeModuleModule\r\n  ],\r\n  providers:SERVICE_PROVIDES\r\n})\r\n//SharedModule\r\n// 应 包含定义：\r\n// 应用通用自定义业务组件\r\n// 应 导出所有包含的模块。\r\n// 不应 有 providers 属性。\r\nexport class AtrSharedModule { }\r\n"]}
@@ -0,0 +1,166 @@
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
+ // @ts-ignore
6
+ import ImageResize from 'quill-image-resize-module';
7
+ import { NG_VALUE_ACCESSOR } from '@angular/forms';
8
+ import { UploadOssService } from "../../../core/services/upload-oss.service";
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/imageResize', ImageResize);
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
+ }
67
+ imageHandler() {
68
+ const Imageinput = document.createElement('input');
69
+ Imageinput.setAttribute('type', 'file');
70
+ Imageinput.setAttribute('multiple', 'multiple');
71
+ Imageinput.setAttribute('accept', 'image/png, image/gif, image/jpeg, image/bmp');
72
+ Imageinput.classList.add('ql-image');
73
+ Imageinput.addEventListener('change', () => {
74
+ if (this.needImgSeq) {
75
+ this.imgVis = true;
76
+ }
77
+ console.log(Imageinput);
78
+ let files = Imageinput.files;
79
+ if (files === null || files.length == 0) {
80
+ return;
81
+ }
82
+ this.imgUrls = [];
83
+ for (let i = 0; i < files.length; i++) {
84
+ const file = files[i];
85
+ if (file === null) {
86
+ continue;
87
+ }
88
+ const error = (res) => {
89
+ this.message.warning('上传失败');
90
+ };
91
+ this.uploadOssService.uploadOss(file).subscribe((url) => {
92
+ console.log(file);
93
+ if (url) {
94
+ this.imgUrls.push({ url: url, file: file, index: i });
95
+ if (!this.needImgSeq) {
96
+ this.editor.insertEmbed(this.editor.getSelection(true).index, 'image', url);
97
+ }
98
+ }
99
+ else {
100
+ this.message.warning('上传失败');
101
+ }
102
+ if (this.needImgSeq && this.imgUrls.length == files.length) {
103
+ this.imgVis = true;
104
+ this.imgUrls.sort((a, b) => a.index - b.index);
105
+ document.getElementById("te")?.click();
106
+ }
107
+ }, error);
108
+ }
109
+ });
110
+ Imageinput.click();
111
+ }
112
+ saveSeq() {
113
+ console.log(123);
114
+ for (let i = this.imgUrls.length - 1; i >= 0; i--) {
115
+ this.editor.insertEmbed(this.editor.getSelection(true).index, 'image', this.imgUrls[i].url);
116
+ }
117
+ this.imgVis = false;
118
+ }
119
+ arrowUp(index) {
120
+ let img = this.imgUrls[index];
121
+ this.imgUrls[index] = this.imgUrls[index - 1];
122
+ this.imgUrls[index - 1] = img;
123
+ }
124
+ arrowDown(index) {
125
+ let img = this.imgUrls[index];
126
+ this.imgUrls[index] = this.imgUrls[index + 1];
127
+ this.imgUrls[index + 1] = img;
128
+ }
129
+ cancle() {
130
+ this.imgVis = false;
131
+ }
132
+ te() {
133
+ console.log('上传完毕');
134
+ }
135
+ }
136
+ 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 });
137
+ 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: [
138
+ UploadOssService,
139
+ {
140
+ provide: NG_VALUE_ACCESSOR,
141
+ useExisting: forwardRef(() => QuillEditorComponent),
142
+ multi: true
143
+ }
144
+ ], 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"] }] });
145
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: QuillEditorComponent, decorators: [{
146
+ type: Component,
147
+ args: [{ selector: 'app-quill-editor', providers: [
148
+ UploadOssService,
149
+ {
150
+ provide: NG_VALUE_ACCESSOR,
151
+ useExisting: forwardRef(() => QuillEditorComponent),
152
+ multi: true
153
+ }
154
+ ], 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"] }]
155
+ }], ctorParameters: function () { return [{ type: i1.UploadOssService }, { type: i2.NzMessageService }]; }, propDecorators: { placeholder: [{
156
+ type: Input
157
+ }], styles: [{
158
+ type: Input
159
+ }], value: [{
160
+ type: Input
161
+ }], readOnly: [{
162
+ type: Input
163
+ }], needImgSeq: [{
164
+ type: Input
165
+ }] } });
166
+ //# 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// @ts-ignore\r\nimport 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\nQuill.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"]}