@dignite-ng/expand.ck-editor 3.0.0-rc.1 → 3.0.0-rc.3
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/lib/ck-editor-routing.module.mjs +2 -6
- package/esm2022/lib/ck-editor.module.mjs +3 -14
- package/esm2022/lib/dynamic-form/ck-editor/ck-editor-config.component.mjs +5 -4
- package/esm2022/lib/dynamic-form/ck-editor/ck-editor-control.component.mjs +27 -20
- package/esm2022/lib/enums/languages-map.mjs +2 -2
- package/esm2022/lib/object/ck-editor-object.mjs +5 -277
- package/esm2022/lib/services/index.mjs +2 -0
- package/esm2022/lib/services/set-ck-editor-configs.service.mjs +27 -0
- package/esm2022/public-api.mjs +2 -5
- package/fesm2022/dignite-ng-expand.ck-editor.mjs +195 -521
- package/fesm2022/dignite-ng-expand.ck-editor.mjs.map +1 -1
- package/lib/ck-editor.module.d.ts +5 -7
- package/lib/dynamic-form/ck-editor/ck-editor-config.component.d.ts +1 -0
- package/lib/dynamic-form/ck-editor/ck-editor-control.component.d.ts +4 -5
- package/lib/enums/languages-map.d.ts +1 -1
- package/lib/object/ck-editor-object.d.ts +8 -27
- package/lib/services/index.d.ts +1 -0
- package/lib/services/set-ck-editor-configs.service.d.ts +7 -0
- package/package.json +1 -1
- package/public-api.d.ts +1 -4
- package/esm2022/lib/components/dome/ck-editor-dome.component.mjs +0 -84
- package/esm2022/lib/pipes/index.mjs +0 -2
- package/esm2022/lib/pipes/set-ckeditor-content.pipe.mjs +0 -25
- package/lib/components/dome/ck-editor-dome.component.d.ts +0 -26
- package/lib/pipes/index.d.ts +0 -1
- package/lib/pipes/set-ckeditor-content.pipe.d.ts +0 -8
|
@@ -1,12 +1,8 @@
|
|
|
1
1
|
import { NgModule } from '@angular/core';
|
|
2
2
|
import { RouterModule } from '@angular/router';
|
|
3
|
-
import { CkEditorDomeComponent } from './components/dome/ck-editor-dome.component';
|
|
4
3
|
import * as i0 from "@angular/core";
|
|
5
4
|
import * as i1 from "@angular/router";
|
|
6
|
-
const routes = [
|
|
7
|
-
path: 'dome',
|
|
8
|
-
component: CkEditorDomeComponent,
|
|
9
|
-
}];
|
|
5
|
+
const routes = [];
|
|
10
6
|
export class CkEditorRoutingModule {
|
|
11
7
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.5", ngImport: i0, type: CkEditorRoutingModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
|
|
12
8
|
static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "18.1.5", ngImport: i0, type: CkEditorRoutingModule, imports: [i1.RouterModule], exports: [RouterModule] }); }
|
|
@@ -19,4 +15,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.5", ngImpor
|
|
|
19
15
|
exports: [RouterModule],
|
|
20
16
|
}]
|
|
21
17
|
}] });
|
|
22
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
18
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2stZWRpdG9yLXJvdXRpbmcubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vcHJvamVjdHMvY2stZWRpdG9yL3NyYy9saWIvY2stZWRpdG9yLXJvdXRpbmcubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLFlBQVksRUFBVSxNQUFNLGlCQUFpQixDQUFDOzs7QUFFdkQsTUFBTSxNQUFNLEdBQVcsRUFBRSxDQUFBO0FBTXpCLE1BQU0sT0FBTyxxQkFBcUI7OEdBQXJCLHFCQUFxQjsrR0FBckIscUJBQXFCLHdDQUZ0QixZQUFZOytHQUVYLHFCQUFxQixZQUh0QixZQUFZLENBQUMsUUFBUSxDQUFDLE1BQU0sQ0FBQyxFQUM3QixZQUFZOzsyRkFFWCxxQkFBcUI7a0JBSmpDLFFBQVE7bUJBQUM7b0JBQ1IsT0FBTyxFQUFFLENBQUMsWUFBWSxDQUFDLFFBQVEsQ0FBQyxNQUFNLENBQUMsQ0FBQztvQkFDeEMsT0FBTyxFQUFFLENBQUMsWUFBWSxDQUFDO2lCQUN4QiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBSb3V0ZXJNb2R1bGUsIFJvdXRlcyB9IGZyb20gJ0Bhbmd1bGFyL3JvdXRlcic7XG5cbmNvbnN0IHJvdXRlczogUm91dGVzID0gW11cblxuQE5nTW9kdWxlKHtcbiAgaW1wb3J0czogW1JvdXRlck1vZHVsZS5mb3JDaGlsZChyb3V0ZXMpXSxcbiAgZXhwb3J0czogW1JvdXRlck1vZHVsZV0sXG59KVxuZXhwb3J0IGNsYXNzIENrRWRpdG9yUm91dGluZ01vZHVsZSB7IH1cbiJdfQ==
|
|
@@ -1,26 +1,19 @@
|
|
|
1
1
|
import { NgModule } from '@angular/core';
|
|
2
2
|
import { CkEditorRoutingModule } from './ck-editor-routing.module';
|
|
3
3
|
import { CoreModule } from '@abp/ng.core';
|
|
4
|
-
import { FormsModule, ReactiveFormsModule } from '@angular/forms';
|
|
5
4
|
import { ThemeSharedModule } from '@abp/ng.theme.shared';
|
|
6
5
|
import { CkEditorConfigComponent, CkEditorControlComponent } from './dynamic-form';
|
|
7
6
|
import { CKEditorModule } from '@ckeditor/ckeditor5-angular';
|
|
8
|
-
import { CkEditorDomeComponent } from './components/dome/ck-editor-dome.component';
|
|
9
7
|
import * as i0 from "@angular/core";
|
|
10
8
|
export class CkEditorModule {
|
|
11
9
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.5", ngImport: i0, type: CkEditorModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
|
|
12
10
|
static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "18.1.5", ngImport: i0, type: CkEditorModule, declarations: [CkEditorControlComponent,
|
|
13
|
-
CkEditorConfigComponent,
|
|
14
|
-
CkEditorDomeComponent], imports: [FormsModule,
|
|
15
|
-
CoreModule,
|
|
11
|
+
CkEditorConfigComponent], imports: [CoreModule,
|
|
16
12
|
ThemeSharedModule,
|
|
17
|
-
ReactiveFormsModule,
|
|
18
13
|
CkEditorRoutingModule,
|
|
19
14
|
CKEditorModule] }); }
|
|
20
|
-
static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "18.1.5", ngImport: i0, type: CkEditorModule, imports: [
|
|
21
|
-
CoreModule,
|
|
15
|
+
static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "18.1.5", ngImport: i0, type: CkEditorModule, imports: [CoreModule,
|
|
22
16
|
ThemeSharedModule,
|
|
23
|
-
ReactiveFormsModule,
|
|
24
17
|
CkEditorRoutingModule,
|
|
25
18
|
CKEditorModule] }); }
|
|
26
19
|
}
|
|
@@ -30,17 +23,13 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.5", ngImpor
|
|
|
30
23
|
declarations: [
|
|
31
24
|
CkEditorControlComponent,
|
|
32
25
|
CkEditorConfigComponent,
|
|
33
|
-
CkEditorDomeComponent,
|
|
34
26
|
],
|
|
35
27
|
imports: [
|
|
36
|
-
FormsModule,
|
|
37
28
|
CoreModule,
|
|
38
29
|
ThemeSharedModule,
|
|
39
|
-
ReactiveFormsModule,
|
|
40
30
|
CkEditorRoutingModule,
|
|
41
31
|
CKEditorModule,
|
|
42
32
|
],
|
|
43
|
-
exports: []
|
|
44
33
|
}]
|
|
45
34
|
}] });
|
|
46
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
35
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2stZWRpdG9yLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL2NrLWVkaXRvci9zcmMvbGliL2NrLWVkaXRvci5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUV6QyxPQUFPLEVBQUUscUJBQXFCLEVBQUUsTUFBTSw0QkFBNEIsQ0FBQztBQUNuRSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sY0FBYyxDQUFDO0FBQzFDLE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLHNCQUFzQixDQUFDO0FBQ3pELE9BQU8sRUFBRSx1QkFBdUIsRUFBRSx3QkFBd0IsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBQ25GLE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSw2QkFBNkIsQ0FBQzs7QUFlN0QsTUFBTSxPQUFPLGNBQWM7OEdBQWQsY0FBYzsrR0FBZCxjQUFjLGlCQVh2Qix3QkFBd0I7WUFDeEIsdUJBQXVCLGFBR3ZCLFVBQVU7WUFDVixpQkFBaUI7WUFDakIscUJBQXFCO1lBQ3JCLGNBQWM7K0dBSUwsY0FBYyxZQVB2QixVQUFVO1lBQ1YsaUJBQWlCO1lBQ2pCLHFCQUFxQjtZQUNyQixjQUFjOzsyRkFJTCxjQUFjO2tCQWIxQixRQUFRO21CQUFDO29CQUNSLFlBQVksRUFBRTt3QkFDWix3QkFBd0I7d0JBQ3hCLHVCQUF1QjtxQkFDeEI7b0JBQ0QsT0FBTyxFQUFFO3dCQUNQLFVBQVU7d0JBQ1YsaUJBQWlCO3dCQUNqQixxQkFBcUI7d0JBQ3JCLGNBQWM7cUJBQ2Y7aUJBRUYiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5pbXBvcnQgeyBDa0VkaXRvclJvdXRpbmdNb2R1bGUgfSBmcm9tICcuL2NrLWVkaXRvci1yb3V0aW5nLm1vZHVsZSc7XG5pbXBvcnQgeyBDb3JlTW9kdWxlIH0gZnJvbSAnQGFicC9uZy5jb3JlJztcbmltcG9ydCB7IFRoZW1lU2hhcmVkTW9kdWxlIH0gZnJvbSAnQGFicC9uZy50aGVtZS5zaGFyZWQnO1xuaW1wb3J0IHsgQ2tFZGl0b3JDb25maWdDb21wb25lbnQsIENrRWRpdG9yQ29udHJvbENvbXBvbmVudCB9IGZyb20gJy4vZHluYW1pYy1mb3JtJztcbmltcG9ydCB7IENLRWRpdG9yTW9kdWxlIH0gZnJvbSAnQGNrZWRpdG9yL2NrZWRpdG9yNS1hbmd1bGFyJztcblxuQE5nTW9kdWxlKHtcbiAgZGVjbGFyYXRpb25zOiBbXG4gICAgQ2tFZGl0b3JDb250cm9sQ29tcG9uZW50LFxuICAgIENrRWRpdG9yQ29uZmlnQ29tcG9uZW50LFxuICBdLFxuICBpbXBvcnRzOiBbXG4gICAgQ29yZU1vZHVsZSxcbiAgICBUaGVtZVNoYXJlZE1vZHVsZSxcbiAgICBDa0VkaXRvclJvdXRpbmdNb2R1bGUsXG4gICAgQ0tFZGl0b3JNb2R1bGUsXG4gIF0sXG5cbn0pXG5leHBvcnQgY2xhc3MgQ2tFZGl0b3JNb2R1bGUgeyB9XG4iXX0=
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { Component, Input, ViewChild } from '@angular/core';
|
|
1
|
+
import { ChangeDetectorRef, Component, inject, Input, ViewChild } from '@angular/core';
|
|
2
2
|
import { CkEditorConfig } from './ck-editor-config';
|
|
3
3
|
import * as i0 from "@angular/core";
|
|
4
4
|
import * as i1 from "@angular/forms";
|
|
@@ -7,6 +7,7 @@ import * as i3 from "@ngx-validate/core";
|
|
|
7
7
|
export class CkEditorConfigComponent {
|
|
8
8
|
constructor(fb) {
|
|
9
9
|
this.fb = fb;
|
|
10
|
+
this.cdr = inject(ChangeDetectorRef);
|
|
10
11
|
}
|
|
11
12
|
set Entity(v) {
|
|
12
13
|
this._Entity = v;
|
|
@@ -25,10 +26,10 @@ export class CkEditorConfigComponent {
|
|
|
25
26
|
return this._Entity.get('formConfiguration');
|
|
26
27
|
}
|
|
27
28
|
async dataLoaded() {
|
|
28
|
-
// if (this.Entity && (this._selected || this._selected === '')) {
|
|
29
29
|
if (this._Entity && this._type) {
|
|
30
30
|
await this.AfterInit();
|
|
31
|
-
this.
|
|
31
|
+
this.cdr.detectChanges(); // 手动触发变更检测
|
|
32
|
+
this.submitclick?.nativeElement?.click();
|
|
32
33
|
}
|
|
33
34
|
}
|
|
34
35
|
AfterInit() {
|
|
@@ -58,4 +59,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.5", ngImpor
|
|
|
58
59
|
type: ViewChild,
|
|
59
60
|
args: ['submitclick', { static: true }]
|
|
60
61
|
}] } });
|
|
61
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
62
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2stZWRpdG9yLWNvbmZpZy5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jay1lZGl0b3Ivc3JjL2xpYi9keW5hbWljLWZvcm0vY2stZWRpdG9yL2NrLWVkaXRvci1jb25maWcuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY2stZWRpdG9yL3NyYy9saWIvZHluYW1pYy1mb3JtL2NrLWVkaXRvci9jay1lZGl0b3ItY29uZmlnLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxTQUFTLEVBQWMsTUFBTSxFQUFFLEtBQUssRUFBRSxTQUFTLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFFbkcsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLG9CQUFvQixDQUFDOzs7OztBQU9wRCxNQUFNLE9BQU8sdUJBQXVCO0lBQ2xDLFlBQW9CLEVBQWU7UUFBZixPQUFFLEdBQUYsRUFBRSxDQUFhO1FBOEIzQixRQUFHLEdBQUcsTUFBTSxDQUFDLGlCQUFpQixDQUFDLENBQUM7SUE5QkYsQ0FBQztJQUd2QyxJQUNXLE1BQU0sQ0FBQyxDQUF3QjtRQUN4QyxJQUFJLENBQUMsT0FBTyxHQUFHLENBQUMsQ0FBQztRQUNqQixJQUFJLENBQUMsVUFBVSxFQUFFLENBQUE7SUFDbkIsQ0FBQztJQUlELElBQ1csUUFBUSxDQUFDLENBQU07UUFDeEIsSUFBSSxDQUFDLFNBQVMsR0FBRyxDQUFDLElBQUksRUFBRSxDQUFDO1FBRXpCLG9CQUFvQjtJQUN0QixDQUFDO0lBR0QsSUFDVyxJQUFJLENBQUMsQ0FBTTtRQUNwQixJQUFJLENBQUMsS0FBSyxHQUFHLENBQUMsQ0FBQztRQUNmLG9CQUFvQjtJQUN0QixDQUFDO0lBQ0QsR0FBRztJQUNILElBQUksaUJBQWlCO1FBQ25CLE9BQU8sSUFBSSxDQUFDLE9BQU8sQ0FBQyxHQUFHLENBQUMsbUJBQW1CLENBQWMsQ0FBQztJQUM1RCxDQUFDO0lBSUQsS0FBSyxDQUFDLFVBQVU7UUFDZCxJQUFJLElBQUksQ0FBQyxPQUFPLElBQUksSUFBSSxDQUFDLEtBQUssRUFBRSxDQUFDO1lBQy9CLE1BQU0sSUFBSSxDQUFDLFNBQVMsRUFBRSxDQUFDO1lBQ3ZCLElBQUksQ0FBQyxHQUFHLENBQUMsYUFBYSxFQUFFLENBQUMsQ0FBQyxXQUFXO1lBQ3JDLElBQUksQ0FBQyxXQUFXLEVBQUUsYUFBYSxFQUFFLEtBQUssRUFBRSxDQUFDO1FBQzNDLENBQUM7SUFDSCxDQUFDO0lBRUQsU0FBUztRQUNQLE9BQU8sSUFBSSxPQUFPLENBQUMsQ0FBQyxPQUFPLEVBQUUsT0FBTyxFQUFFLEVBQUU7WUFDdEMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxVQUFVLENBQUMsbUJBQW1CLEVBQUUsSUFBSSxDQUFDLEVBQUUsQ0FBQyxLQUFLLENBQUMsSUFBSSxjQUFjLEVBQUUsQ0FBQyxDQUFDLENBQUM7WUFDbEYsSUFBSSxJQUFJLENBQUMsU0FBUyxJQUFJLElBQUksQ0FBQyxTQUFTLENBQUMsZUFBZSxJQUFJLElBQUksQ0FBQyxLQUFLLEVBQUUsQ0FBQztnQkFDbkUsSUFBSSxDQUFDLGlCQUFpQixDQUFDLFVBQVUsQ0FBQztvQkFDaEMsR0FBRyxJQUFJLENBQUMsU0FBUyxDQUFDLGlCQUFpQjtpQkFDcEMsQ0FBQyxDQUFDO1lBQ0wsQ0FBQztZQUNELE9BQU8sQ0FBQyxJQUFJLENBQUMsQ0FBQztRQUNoQixDQUFDLENBQUMsQ0FBQztJQUNMLENBQUM7OEdBbERVLHVCQUF1QjtrR0FBdkIsdUJBQXVCLG9QQ1RwQyxzeEJBYU87OzJGREpNLHVCQUF1QjtrQkFMbkMsU0FBUzsrQkFDRSxrQkFBa0I7Z0ZBU2pCLE1BQU07c0JBRGhCLEtBQUs7Z0JBU0ssUUFBUTtzQkFEbEIsS0FBSztnQkFTSyxJQUFJO3NCQURkLEtBQUs7Z0JBU3NDLFdBQVc7c0JBQXRELFNBQVM7dUJBQUMsYUFBYSxFQUFFLEVBQUUsTUFBTSxFQUFFLElBQUksRUFBRSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENoYW5nZURldGVjdG9yUmVmLCBDb21wb25lbnQsIEVsZW1lbnRSZWYsIGluamVjdCwgSW5wdXQsIFZpZXdDaGlsZCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgRm9ybUJ1aWxkZXIsIEZvcm1Hcm91cCB9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcbmltcG9ydCB7IENrRWRpdG9yQ29uZmlnIH0gZnJvbSAnLi9jay1lZGl0b3ItY29uZmlnJztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnY2stZWRpdG9yLWNvbmZpZycsXG4gIHRlbXBsYXRlVXJsOiAnLi9jay1lZGl0b3ItY29uZmlnLmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmxzOiBbJy4vY2stZWRpdG9yLWNvbmZpZy5jb21wb25lbnQuc2NzcyddLFxufSlcbmV4cG9ydCBjbGFzcyBDa0VkaXRvckNvbmZpZ0NvbXBvbmVudCB7XG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgZmI6IEZvcm1CdWlsZGVyKSB7fVxuICAvKirooajljZXlrp7kvZMgKi9cbiAgX0VudGl0eTogRm9ybUdyb3VwIHwgdW5kZWZpbmVkO1xuICBASW5wdXQoKVxuICBwdWJsaWMgc2V0IEVudGl0eSh2OiBGb3JtR3JvdXAgfCB1bmRlZmluZWQpIHtcbiAgICB0aGlzLl9FbnRpdHkgPSB2O1xuICAgIHRoaXMuZGF0YUxvYWRlZCgpXG4gIH1cblxuICAvKirpgInmi6nnmoTooajljZXkv6Hmga8gKi9cbiAgX3NlbGVjdGVkOiBhbnk7XG4gIEBJbnB1dCgpXG4gIHB1YmxpYyBzZXQgc2VsZWN0ZWQodjogYW55KSB7XG4gICAgdGhpcy5fc2VsZWN0ZWQgPSB2IHx8ICcnO1xuXG4gICAgLy8gdGhpcy5kYXRhTG9hZGVkKClcbiAgfVxuICAvKirooajljZXmjqfku7bnsbvlnosgKi9cbiAgX3R5cGU6IGFueTtcbiAgQElucHV0KClcbiAgcHVibGljIHNldCB0eXBlKHY6IGFueSkge1xuICAgIHRoaXMuX3R5cGUgPSB2O1xuICAgIC8vIHRoaXMuZGF0YUxvYWRlZCgpXG4gIH1cbiAgLy8gXG4gIGdldCBmb3JtQ29uZmlndXJhdGlvbigpIHtcbiAgICByZXR1cm4gdGhpcy5fRW50aXR5LmdldCgnZm9ybUNvbmZpZ3VyYXRpb24nKSBhcyBGb3JtR3JvdXA7XG4gIH1cbiAgQFZpZXdDaGlsZCgnc3VibWl0Y2xpY2snLCB7IHN0YXRpYzogdHJ1ZSB9KSBzdWJtaXRjbGljazogRWxlbWVudFJlZjtcblxuICBwcml2YXRlIGNkciA9IGluamVjdChDaGFuZ2VEZXRlY3RvclJlZik7XG4gIGFzeW5jIGRhdGFMb2FkZWQoKSB7XG4gICAgaWYgKHRoaXMuX0VudGl0eSAmJiB0aGlzLl90eXBlKSB7XG4gICAgICBhd2FpdCB0aGlzLkFmdGVySW5pdCgpO1xuICAgICAgdGhpcy5jZHIuZGV0ZWN0Q2hhbmdlcygpOyAvLyDmiYvliqjop6blj5Hlj5jmm7Tmo4DmtYtcbiAgICAgIHRoaXMuc3VibWl0Y2xpY2s/Lm5hdGl2ZUVsZW1lbnQ/LmNsaWNrKCk7XG4gICAgfVxuICB9XG5cbiAgQWZ0ZXJJbml0KCkge1xuICAgIHJldHVybiBuZXcgUHJvbWlzZSgocmVzb2x2ZSwgcmVqZWN0cykgPT4ge1xuICAgICAgdGhpcy5fRW50aXR5LnNldENvbnRyb2woJ2Zvcm1Db25maWd1cmF0aW9uJywgdGhpcy5mYi5ncm91cChuZXcgQ2tFZGl0b3JDb25maWcoKSkpO1xuICAgICAgaWYgKHRoaXMuX3NlbGVjdGVkICYmIHRoaXMuX3NlbGVjdGVkLmZvcm1Db250cm9sTmFtZSA9PSB0aGlzLl90eXBlKSB7XG4gICAgICAgIHRoaXMuZm9ybUNvbmZpZ3VyYXRpb24ucGF0Y2hWYWx1ZSh7XG4gICAgICAgICAgLi4udGhpcy5fc2VsZWN0ZWQuZm9ybUNvbmZpZ3VyYXRpb24sXG4gICAgICAgIH0pO1xuICAgICAgfVxuICAgICAgcmVzb2x2ZSh0cnVlKTtcbiAgICB9KTtcbiAgfVxufVxuIiwiPGZvcm0gW2Zvcm1Hcm91cF09XCJfRW50aXR5XCI+XG4gICAgPGRpdiBmb3JtR3JvdXBOYW1lPVwiZm9ybUNvbmZpZ3VyYXRpb25cIj5cbiAgICAgICAgPGRpdiBjbGFzcz1cIm1iLTNcIj5cbiAgICAgICAgICAgIDxsYWJlbCBjbGFzcz1cImZvcm0tbGFiZWxcIj57eydEaWduaXRlQWJwRHluYW1pY0Zvcm1zQ2tFZGl0b3I6OkltYWdlc0NvbnRhaW5lck5hbWUnIHwgYWJwTG9jYWxpemF0aW9ufX08L2xhYmVsPlxuICAgICAgICAgICAgPGlucHV0IHR5cGU9XCJ0ZXh0XCIgY2xhc3M9XCJmb3JtLWNvbnRyb2xcIiBmb3JtQ29udHJvbE5hbWU9XCJDa2VkaXRvci5JbWFnZXNDb250YWluZXJOYW1lXCI+XG4gICAgICAgIDwvZGl2PlxuICAgICAgICA8ZGl2IGNsYXNzPVwibWItM1wiPlxuICAgICAgICAgICAgPGxhYmVsIGNsYXNzPVwiZm9ybS1sYWJlbFwiPnt7J0RpZ25pdGVBYnBEeW5hbWljRm9ybXNDa0VkaXRvcjo6SW5pdGlhbENvbnRlbnQnIHwgYWJwTG9jYWxpemF0aW9ufX08L2xhYmVsPlxuICAgICAgICAgICAgPGlucHV0IHR5cGU9XCJ0ZXh0XCIgY2xhc3M9XCJmb3JtLWNvbnRyb2xcIiBmb3JtQ29udHJvbE5hbWU9XCJDa2VkaXRvci5Jbml0aWFsQ29udGVudFwiPlxuICAgICAgICA8L2Rpdj5cbiAgICAgICAgPGJ1dHRvbiB0eXBlPVwic3VibWl0XCIgKGFicEluaXQpPVwic3VibWl0Y2xpY2s/Lm5hdGl2ZUVsZW1lbnQ/LmNsaWNrKClcIiBzdHlsZT1cImRpc3BsYXk6IG5vbmU7XCJcbiAgICAgICAgICAgICNzdWJtaXRjbGljaz48L2J1dHRvbj5cbiAgICA8L2Rpdj5cbjwvZm9ybT4iXX0=
|
|
@@ -1,13 +1,11 @@
|
|
|
1
|
-
import { ConfigStateService, LazyLoadService, LOADING_STRATEGY, RestService, SubscriptionService } from '@abp/ng.core';
|
|
2
|
-
import { Component, Input, ViewChild, inject } from '@angular/core';
|
|
1
|
+
import { ConfigStateService, LazyLoadService, LOADING_STRATEGY, RestService, SubscriptionService, } from '@abp/ng.core';
|
|
2
|
+
import { ChangeDetectorRef, Component, Input, ViewChild, inject } from '@angular/core';
|
|
3
3
|
import { FormBuilder, Validators } from '@angular/forms';
|
|
4
|
-
import { LanguagesMap } from '../../enums/languages-map';
|
|
5
4
|
import { isBase64UploadAdapter } from './ckEditorUpload';
|
|
6
|
-
import {
|
|
7
|
-
import { CkEditorTypesObject } from '../../object/ck-editor-object';
|
|
5
|
+
import { SetCkEditorConfigsService } from '../../services';
|
|
8
6
|
import * as i0 from "@angular/core";
|
|
9
|
-
import * as i1 from "@angular/
|
|
10
|
-
import * as i2 from "@angular/
|
|
7
|
+
import * as i1 from "@angular/common";
|
|
8
|
+
import * as i2 from "@angular/forms";
|
|
11
9
|
import * as i3 from "@ngx-validate/core";
|
|
12
10
|
import * as i4 from "@ckeditor/ckeditor5-angular";
|
|
13
11
|
export class CkEditorControlComponent {
|
|
@@ -18,12 +16,11 @@ export class CkEditorControlComponent {
|
|
|
18
16
|
this.ckEditorValue = '';
|
|
19
17
|
/**系统语言 */
|
|
20
18
|
this.currentCulture = this.config.getOne('localization')?.currentCulture?.name;
|
|
21
|
-
/** 语言目录,匹配系统语言,设置ckeditor的语言 */
|
|
22
|
-
this.languagesMap = LanguagesMap;
|
|
23
|
-
this.Editor = ClassicEditor;
|
|
24
19
|
this.fb = inject(FormBuilder);
|
|
25
20
|
/**字段配置列表 */
|
|
26
21
|
this._fields = '';
|
|
22
|
+
this.cdr = inject(ChangeDetectorRef);
|
|
23
|
+
this._SetCkEditorConfigsService = inject(SetCkEditorConfigsService);
|
|
27
24
|
this.lazyLoadService = inject(LazyLoadService);
|
|
28
25
|
this.subscriptionService = inject(SubscriptionService);
|
|
29
26
|
this.invalidfeedback = false;
|
|
@@ -64,16 +61,26 @@ export class CkEditorControlComponent {
|
|
|
64
61
|
async dataLoaded() {
|
|
65
62
|
if (this._fields && this._entity) {
|
|
66
63
|
await this.AfterInit();
|
|
67
|
-
this.ckEditorValue =
|
|
64
|
+
this.ckEditorValue =
|
|
65
|
+
this._selected || this._fields.field.formConfiguration['Ckeditor.InitialContent'];
|
|
68
66
|
this.setckeditorInput(this.ckEditorValue);
|
|
69
|
-
this.
|
|
67
|
+
this.cdr.detectChanges(); // 手动触发变更检测
|
|
68
|
+
this.submitclick?.nativeElement?.click();
|
|
70
69
|
}
|
|
71
70
|
}
|
|
72
71
|
loadckeditor() {
|
|
73
|
-
this
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
72
|
+
let _that = this;
|
|
73
|
+
return new Promise(async (resolve) => {
|
|
74
|
+
await import('ckeditor5').then(async (res) => {
|
|
75
|
+
this.loadStyle();
|
|
76
|
+
_that.Editor = res.ClassicEditor;
|
|
77
|
+
let configs = await _that._SetCkEditorConfigsService.get({
|
|
78
|
+
language: _that.currentCulture,
|
|
79
|
+
});
|
|
80
|
+
_that.ckOptions = configs;
|
|
81
|
+
});
|
|
82
|
+
resolve(true);
|
|
83
|
+
});
|
|
77
84
|
}
|
|
78
85
|
loadStyle() {
|
|
79
86
|
const loaded$ = this.lazyLoadService.load(LOADING_STRATEGY.AppendAnonymousStyleToHead('ckeditor5.css'));
|
|
@@ -97,17 +104,17 @@ export class CkEditorControlComponent {
|
|
|
97
104
|
this.imagesContainerName =
|
|
98
105
|
this._fields.field.formConfiguration['Ckeditor.ImagesContainerName'];
|
|
99
106
|
if (!this.imagesContainerName) {
|
|
100
|
-
this.ckOptions
|
|
107
|
+
this.ckOptions?.toolbar?.items?.splice(this.ckOptions?.toolbar?.items?.indexOf('insertImage'), 1);
|
|
101
108
|
}
|
|
102
109
|
resolve(true);
|
|
103
110
|
});
|
|
104
111
|
}
|
|
105
112
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.5", ngImport: i0, type: CkEditorControlComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
106
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.1.5", type: CkEditorControlComponent, selector: "ck-editor-control", inputs: { fields: "fields", parentFiledName: "parentFiledName", selected: "selected", entity: "entity" }, viewQueries: [{ propertyName: "submitclick", first: true, predicate: ["submitclick"], descendants: true, static: true }], ngImport: i0, template: "<form [formGroup]=\"_entity\">\n <div formGroupName=\"extraProperties\">\n <div class=\"mb-3\">\n <label class=\"form-label\" *ngIf=\"_fields.displayName\">{{ _fields.displayName }}</label>\n <ckeditor [editor]=\"Editor\" *ngIf=\"Editor\" [config]=\"ckOptions\" (ready)=\"onReady($event)\"
|
|
113
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.1.5", type: CkEditorControlComponent, selector: "ck-editor-control", inputs: { fields: "fields", parentFiledName: "parentFiledName", selected: "selected", entity: "entity" }, viewQueries: [{ propertyName: "submitclick", first: true, predicate: ["submitclick"], descendants: true, static: true }], ngImport: i0, template: "<form [formGroup]=\"_entity\">\n <div formGroupName=\"extraProperties\">\n <div class=\"mb-3\">\n <label class=\"form-label\" *ngIf=\"_fields.displayName\">{{ _fields.displayName }}</label>\n <ng-container *ngIf=\"ckOptions\">\n\n <ckeditor [editor]=\"Editor\" *ngIf=\"Editor\" [config]=\"ckOptions\" (ready)=\"onReady($event)\"\n [formControlName]=\"_fields.field.name\">\n </ckeditor>\n </ng-container>\n <small class=\"form-text text-muted d-block\"\n *ngIf=\"_fields.field.description\">{{_fields.field.description}}</small>\n </div>\n </div>\n <button type=\"submit\" style=\"display: none;\" #submitclick></button>\n</form>", styles: [""], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i2.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i2.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "directive", type: i2.FormGroupName, selector: "[formGroupName]", inputs: ["formGroupName"] }, { kind: "directive", type: i3.ValidationGroupDirective, selector: "[formGroup],[formGroupName]", exportAs: ["validationGroup"] }, { kind: "directive", type: i3.ValidationDirective, selector: "[formControl],[formControlName]", exportAs: ["validationDirective"] }, { kind: "component", type: i4.CKEditorComponent, selector: "ckeditor", inputs: ["editor", "config", "data", "tagName", "watchdog", "editorWatchdogConfig", "disableTwoWayDataBinding", "disabled"], outputs: ["ready", "change", "blur", "focus", "error"] }] }); }
|
|
107
114
|
}
|
|
108
115
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.5", ngImport: i0, type: CkEditorControlComponent, decorators: [{
|
|
109
116
|
type: Component,
|
|
110
|
-
args: [{ selector: 'ck-editor-control', template: "<form [formGroup]=\"_entity\">\n <div formGroupName=\"extraProperties\">\n <div class=\"mb-3\">\n <label class=\"form-label\" *ngIf=\"_fields.displayName\">{{ _fields.displayName }}</label>\n <ckeditor [editor]=\"Editor\" *ngIf=\"Editor\" [config]=\"ckOptions\" (ready)=\"onReady($event)\"
|
|
117
|
+
args: [{ selector: 'ck-editor-control', template: "<form [formGroup]=\"_entity\">\n <div formGroupName=\"extraProperties\">\n <div class=\"mb-3\">\n <label class=\"form-label\" *ngIf=\"_fields.displayName\">{{ _fields.displayName }}</label>\n <ng-container *ngIf=\"ckOptions\">\n\n <ckeditor [editor]=\"Editor\" *ngIf=\"Editor\" [config]=\"ckOptions\" (ready)=\"onReady($event)\"\n [formControlName]=\"_fields.field.name\">\n </ckeditor>\n </ng-container>\n <small class=\"form-text text-muted d-block\"\n *ngIf=\"_fields.field.description\">{{_fields.field.description}}</small>\n </div>\n </div>\n <button type=\"submit\" style=\"display: none;\" #submitclick></button>\n</form>" }]
|
|
111
118
|
}], ctorParameters: () => [], propDecorators: { fields: [{
|
|
112
119
|
type: Input
|
|
113
120
|
}], parentFiledName: [{
|
|
@@ -120,4 +127,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.5", ngImpor
|
|
|
120
127
|
type: ViewChild,
|
|
121
128
|
args: ['submitclick', { static: true }]
|
|
122
129
|
}] } });
|
|
123
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ck-editor-control.component.js","sourceRoot":"","sources":["../../../../../../projects/ck-editor/src/lib/dynamic-form/ck-editor/ck-editor-control.component.ts","../../../../../../projects/ck-editor/src/lib/dynamic-form/ck-editor/ck-editor-control.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ConfigStateService, LazyLoadService, LOADING_STRATEGY, RestService, SubscriptionService } from '@abp/ng.core';\nimport { Component, ElementRef, Input, ViewChild, inject } from '@angular/core';\nimport { FormBuilder, FormGroup, Validators } from '@angular/forms';\n\nimport { LanguagesMap } from '../../enums/languages-map';\nimport { isBase64UploadAdapter } from './ckEditorUpload';\nimport { ClassicEditor } from 'ckeditor5';\nimport { CkEditorTypesObject } from '../../object/ck-editor-object';\n\n@Component({\n  selector: 'ck-editor-control',\n  templateUrl: './ck-editor-control.component.html',\n  styleUrls: ['./ck-editor-control.component.scss'],\n})\nexport class CkEditorControlComponent {\n  private config: ConfigStateService = inject(ConfigStateService);\n  private _restService: RestService = inject(RestService);\n  /**ck-Editor的值 */\n  ckEditorValue: any = '';\n  /**系统语言 */\n  currentCulture = this.config.getOne('localization')?.currentCulture?.name;\n  /** 语言目录，匹配系统语言，设置ckeditor的语言 */\n  languagesMap = LanguagesMap;\n\n  public Editor: any = ClassicEditor;\n  constructor() {\n    this.loadckeditor();\n  }\n  public onReady(editor) {\n    let _this = this;\n    editor.plugins.get('FileRepository').createUploadAdapter = function (loader: any) {\n      return new isBase64UploadAdapter(loader, _this.imagesContainerName, _this._restService);\n    };\n  }\n\n  /**ck-editor配置 */\n  ckOptions: any;\n  /**富文本内容改变 */\n  ckEditorChange(event) {\n    this.setckeditorInput(event);\n  }\n\n  private fb = inject(FormBuilder);\n\n  /**字段配置列表 */\n  _fields: any = '';\n  @Input()\n  public set fields(v: any) {\n    this._fields = v;\n  }\n\n  /**父级字段名称，用于为表单设置控件赋值 */\n  _parentFiledName: any;\n  @Input()\n  public set parentFiledName(v: any) {\n    this._parentFiledName = v;\n  }\n  /**父级字段名称，用于为表单设置控件赋值 */\n  _selected: any;\n  @Input()\n  public set selected(v: any) {\n    this._selected = v;\n  }\n  /**表单实体 */\n  _entity: FormGroup | undefined;\n  @Input()\n  public set entity(v: any) {\n    this._entity = v;\n    this.dataLoaded();\n  }\n  @ViewChild('submitclick', { static: true }) submitclick: ElementRef;\n\n  get extraProperties() {\n    return this._entity.get('extraProperties') as FormGroup;\n  }\n  get ckeditorInput() {\n    return this.extraProperties.get(this._fields.field.name) as FormGroup;\n  }\n  /**数据加载完成 */\n  async dataLoaded() {\n    if (this._fields && this._entity) {\n      await this.AfterInit();\n      this.ckEditorValue = this._selected || this._fields.field.formConfiguration['Ckeditor.InitialContent'];\n      this.setckeditorInput(this.ckEditorValue);\n      this.submitclick.nativeElement.click();\n    }\n  }\n\n  loadckeditor() {\n    this.loadStyle();\n    let configs = CkEditorTypesObject['default'];\n    configs.language = this.languagesMap[this.currentCulture];\n    this.ckOptions = configs;\n  }\n  private lazyLoadService = inject(LazyLoadService);\n  private subscriptionService = inject(SubscriptionService);\n  private loadStyle() {\n    const loaded$ = this.lazyLoadService.load(\n      LOADING_STRATEGY.AppendAnonymousStyleToHead('ckeditor5.css')\n    );\n    this.subscriptionService.addOne(loaded$);\n  }\n\n  invalidfeedback = false;\n  //设置值\n  setckeditorInput(val) {\n    this.invalidfeedback = true;\n    this.ckeditorInput.patchValue(val);\n  }\n\n  /**图片容器名称 */\n  imagesContainerName: any = '';\n  AfterInit() {\n    return new Promise(resolve => {\n      let ValidatorsArray = [];\n      if (this._fields.required) {\n        ValidatorsArray.push(Validators.required);\n      }\n      let newControl = this.fb.control(\n        this._selected\n          ? this._selected\n          : this._fields.field.formConfiguration['Ckeditor.InitialContent'],\n        ValidatorsArray\n      );\n      this.extraProperties.setControl(this._fields.field.name, newControl);\n      this.imagesContainerName =\n        this._fields.field.formConfiguration['Ckeditor.ImagesContainerName'];\n      if (!this.imagesContainerName) {\n        this.ckOptions.toolbar.items.splice(this.ckOptions.toolbar.items.indexOf('insertImage'), 1);\n      }\n      resolve(true);\n    });\n  }\n}\n","<form [formGroup]=\"_entity\">\n    <div formGroupName=\"extraProperties\">\n        <div class=\"mb-3\">\n            <label class=\"form-label\" *ngIf=\"_fields.displayName\">{{ _fields.displayName }}</label>\n            <ckeditor [editor]=\"Editor\" *ngIf=\"Editor\" [config]=\"ckOptions\" (ready)=\"onReady($event)\" [formControlName]=\"_fields.field.name\">\n            </ckeditor>\n            <!-- <ng-container *ngIf=\"ckeditorInput?.errors?.required&&invalidfeedback\">\n                <div class=\"text-danger \">\n                    {{'DigniteAbpForms::Validate:Required' | abpLocalization:' '}}\n                </div>\n            </ng-container> -->\n            <small class=\"form-text text-muted d-block\" *ngIf=\"_fields.field.description\">{{_fields.field.description}}</small>\n        </div>\n    </div>\n    <button type=\"submit\" style=\"display: none;\" #submitclick></button>\n</form>"]}
|
|
130
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ck-editor-control.component.js","sourceRoot":"","sources":["../../../../../../projects/ck-editor/src/lib/dynamic-form/ck-editor/ck-editor-control.component.ts","../../../../../../projects/ck-editor/src/lib/dynamic-form/ck-editor/ck-editor-control.component.html"],"names":[],"mappings":"AAAA,OAAO,EACL,kBAAkB,EAClB,eAAe,EACf,gBAAgB,EAChB,WAAW,EACX,mBAAmB,GACpB,MAAM,cAAc,CAAC;AACtB,OAAO,EAAE,iBAAiB,EAAE,SAAS,EAAc,KAAK,EAAE,SAAS,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AACnG,OAAO,EAAE,WAAW,EAAa,UAAU,EAAE,MAAM,gBAAgB,CAAC;AACpE,OAAO,EAAE,qBAAqB,EAAE,MAAM,kBAAkB,CAAC;AACzD,OAAO,EAAE,yBAAyB,EAAE,MAAM,gBAAgB,CAAC;;;;;;AAO3D,MAAM,OAAO,wBAAwB;IAQnC;QAPQ,WAAM,GAAuB,MAAM,CAAC,kBAAkB,CAAC,CAAC;QACxD,iBAAY,GAAgB,MAAM,CAAC,WAAW,CAAC,CAAC;QACxD,iBAAiB;QACjB,kBAAa,GAAQ,EAAE,CAAC;QACxB,UAAU;QACV,mBAAc,GAAG,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,cAAc,CAAC,EAAE,cAAc,EAAE,IAAI,CAAC;QAmBlE,OAAE,GAAG,MAAM,CAAC,WAAW,CAAC,CAAC;QAEjC,YAAY;QACZ,YAAO,GAAQ,EAAE,CAAC;QAiCV,QAAG,GAAG,MAAM,CAAC,iBAAiB,CAAC,CAAC;QAahC,+BAA0B,GAAG,MAAM,CAAC,yBAAyB,CAAC,CAAC;QAgB/D,oBAAe,GAAG,MAAM,CAAC,eAAe,CAAC,CAAC;QAC1C,wBAAmB,GAAG,MAAM,CAAC,mBAAmB,CAAC,CAAC;QAQ1D,oBAAe,GAAG,KAAK,CAAC;QAOxB,YAAY;QACZ,wBAAmB,GAAQ,EAAE,CAAC;QAlG5B,IAAI,CAAC,YAAY,EAAE,CAAC;IACtB,CAAC;IACM,OAAO,CAAC,MAAM;QACnB,IAAI,KAAK,GAAG,IAAI,CAAC;QACjB,MAAM,CAAC,OAAO,CAAC,GAAG,CAAC,gBAAgB,CAAC,CAAC,mBAAmB,GAAG,UAAU,MAAW;YAC9E,OAAO,IAAI,qBAAqB,CAAC,MAAM,EAAE,KAAK,CAAC,mBAAmB,EAAE,KAAK,CAAC,YAAY,CAAC,CAAC;QAC1F,CAAC,CAAC;IACJ,CAAC;IAID,aAAa;IACb,cAAc,CAAC,KAAK;QAClB,IAAI,CAAC,gBAAgB,CAAC,KAAK,CAAC,CAAC;IAC/B,CAAC;IAMD,IACW,MAAM,CAAC,CAAM;QACtB,IAAI,CAAC,OAAO,GAAG,CAAC,CAAC;IACnB,CAAC;IAID,IACW,eAAe,CAAC,CAAM;QAC/B,IAAI,CAAC,gBAAgB,GAAG,CAAC,CAAC;IAC5B,CAAC;IAGD,IACW,QAAQ,CAAC,CAAM;QACxB,IAAI,CAAC,SAAS,GAAG,CAAC,CAAC;IACrB,CAAC;IAGD,IACW,MAAM,CAAC,CAAM;QACtB,IAAI,CAAC,OAAO,GAAG,CAAC,CAAC;QACjB,IAAI,CAAC,UAAU,EAAE,CAAC;IACpB,CAAC;IAGD,IAAI,eAAe;QACjB,OAAO,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,iBAAiB,CAAc,CAAC;IAC1D,CAAC;IACD,IAAI,aAAa;QACf,OAAO,IAAI,CAAC,eAAe,CAAC,GAAG,CAAC,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,IAAI,CAAc,CAAC;IACxE,CAAC;IAED,YAAY;IACZ,KAAK,CAAC,UAAU;QACd,IAAI,IAAI,CAAC,OAAO,IAAI,IAAI,CAAC,OAAO,EAAE,CAAC;YACjC,MAAM,IAAI,CAAC,SAAS,EAAE,CAAC;YACvB,IAAI,CAAC,aAAa;gBAChB,IAAI,CAAC,SAAS,IAAI,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,iBAAiB,CAAC,yBAAyB,CAAC,CAAC;YACpF,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;YAC1C,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC,CAAC,WAAW;YACrC,IAAI,CAAC,WAAW,EAAE,aAAa,EAAE,KAAK,EAAE,CAAC;QAC3C,CAAC;IACH,CAAC;IAID,YAAY;QACV,IAAI,KAAK,GAAG,IAAI,CAAC;QACjB,OAAO,IAAI,OAAO,CAAC,KAAK,EAAC,OAAO,EAAC,EAAE;YACjC,MAAM,MAAM,CAAC,WAAW,CAAC,CAAC,IAAI,CAAC,KAAK,EAAC,GAAG,EAAC,EAAE;gBACzC,IAAI,CAAC,SAAS,EAAE,CAAC;gBACjB,KAAK,CAAC,MAAM,GAAG,GAAG,CAAC,aAAa,CAAC;gBACjC,IAAI,OAAO,GAAG,MAAM,KAAK,CAAC,0BAA0B,CAAC,GAAG,CAAC;oBACvD,QAAQ,EAAE,KAAK,CAAC,cAAc;iBAC/B,CAAC,CAAC;gBACH,KAAK,CAAC,SAAS,GAAG,OAAO,CAAC;YAC5B,CAAC,CAAC,CAAC;YACH,OAAO,CAAC,IAAI,CAAC,CAAC;QAChB,CAAC,CAAC,CAAC;IACL,CAAC;IAGO,SAAS;QACf,MAAM,OAAO,GAAG,IAAI,CAAC,eAAe,CAAC,IAAI,CACvC,gBAAgB,CAAC,0BAA0B,CAAC,eAAe,CAAC,CAC7D,CAAC;QACF,IAAI,CAAC,mBAAmB,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC;IAC3C,CAAC;IAGD,KAAK;IACL,gBAAgB,CAAC,GAAG;QAClB,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC;QAC5B,IAAI,CAAC,aAAa,CAAC,UAAU,CAAC,GAAG,CAAC,CAAC;IACrC,CAAC;IAID,SAAS;QACP,OAAO,IAAI,OAAO,CAAC,OAAO,CAAC,EAAE;YAC3B,IAAI,eAAe,GAAG,EAAE,CAAC;YACzB,IAAI,IAAI,CAAC,OAAO,CAAC,QAAQ,EAAE,CAAC;gBAC1B,eAAe,CAAC,IAAI,CAAC,UAAU,CAAC,QAAQ,CAAC,CAAC;YAC5C,CAAC;YACD,IAAI,UAAU,GAAG,IAAI,CAAC,EAAE,CAAC,OAAO,CAC9B,IAAI,CAAC,SAAS;gBACZ,CAAC,CAAC,IAAI,CAAC,SAAS;gBAChB,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,iBAAiB,CAAC,yBAAyB,CAAC,EACnE,eAAe,CAChB,CAAC;YACF,IAAI,CAAC,eAAe,CAAC,UAAU,CAAC,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,IAAI,EAAE,UAAU,CAAC,CAAC;YACrE,IAAI,CAAC,mBAAmB;gBACtB,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,iBAAiB,CAAC,8BAA8B,CAAC,CAAC;YAEvE,IAAI,CAAC,IAAI,CAAC,mBAAmB,EAAE,CAAC;gBAC9B,IAAI,CAAC,SAAS,EAAE,OAAO,EAAE,KAAK,EAAE,MAAM,CACpC,IAAI,CAAC,SAAS,EAAE,OAAO,EAAE,KAAK,EAAE,OAAO,CAAC,aAAa,CAAC,EACtD,CAAC,CACF,CAAC;YACJ,CAAC;YACD,OAAO,CAAC,IAAI,CAAC,CAAC;QAChB,CAAC,CAAC,CAAC;IACL,CAAC;8GApIU,wBAAwB;kGAAxB,wBAAwB,6RCjBrC,0vBAeO;;2FDEM,wBAAwB;kBALpC,SAAS;+BACE,mBAAmB;wDAkClB,MAAM;sBADhB,KAAK;gBAQK,eAAe;sBADzB,KAAK;gBAOK,QAAQ;sBADlB,KAAK;gBAOK,MAAM;sBADhB,KAAK;gBAKsC,WAAW;sBAAtD,SAAS;uBAAC,aAAa,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE","sourcesContent":["import {\n  ConfigStateService,\n  LazyLoadService,\n  LOADING_STRATEGY,\n  RestService,\n  SubscriptionService,\n} from '@abp/ng.core';\nimport { ChangeDetectorRef, Component, ElementRef, Input, ViewChild, inject } from '@angular/core';\nimport { FormBuilder, FormGroup, Validators } from '@angular/forms';\nimport { isBase64UploadAdapter } from './ckEditorUpload';\nimport { SetCkEditorConfigsService } from '../../services';\n\n@Component({\n  selector: 'ck-editor-control',\n  templateUrl: './ck-editor-control.component.html',\n  styleUrls: ['./ck-editor-control.component.scss'],\n})\nexport class CkEditorControlComponent {\n  private config: ConfigStateService = inject(ConfigStateService);\n  private _restService: RestService = inject(RestService);\n  /**ck-Editor的值 */\n  ckEditorValue: any = '';\n  /**系统语言 */\n  currentCulture = this.config.getOne('localization')?.currentCulture?.name;\n\n  constructor() {\n    this.loadckeditor();\n  }\n  public onReady(editor) {\n    let _this = this;\n    editor.plugins.get('FileRepository').createUploadAdapter = function (loader: any) {\n      return new isBase64UploadAdapter(loader, _this.imagesContainerName, _this._restService);\n    };\n  }\n\n  /**ck-editor配置 */\n  ckOptions: any;\n  /**富文本内容改变 */\n  ckEditorChange(event) {\n    this.setckeditorInput(event);\n  }\n\n  private fb = inject(FormBuilder);\n\n  /**字段配置列表 */\n  _fields: any = '';\n  @Input()\n  public set fields(v: any) {\n    this._fields = v;\n  }\n\n  /**父级字段名称，用于为表单设置控件赋值 */\n  _parentFiledName: any;\n  @Input()\n  public set parentFiledName(v: any) {\n    this._parentFiledName = v;\n  }\n  /**父级字段名称，用于为表单设置控件赋值 */\n  _selected: any;\n  @Input()\n  public set selected(v: any) {\n    this._selected = v;\n  }\n  /**表单实体 */\n  _entity: FormGroup | undefined;\n  @Input()\n  public set entity(v: any) {\n    this._entity = v;\n    this.dataLoaded();\n  }\n  @ViewChild('submitclick', { static: true }) submitclick: ElementRef;\n\n  get extraProperties() {\n    return this._entity.get('extraProperties') as FormGroup;\n  }\n  get ckeditorInput() {\n    return this.extraProperties.get(this._fields.field.name) as FormGroup;\n  }\n  private cdr = inject(ChangeDetectorRef);\n  /**数据加载完成 */\n  async dataLoaded() {\n    if (this._fields && this._entity) {\n      await this.AfterInit();\n      this.ckEditorValue =\n        this._selected || this._fields.field.formConfiguration['Ckeditor.InitialContent'];\n      this.setckeditorInput(this.ckEditorValue);\n      this.cdr.detectChanges(); // 手动触发变更检测\n      this.submitclick?.nativeElement?.click();\n    }\n  }\n\n  private _SetCkEditorConfigsService = inject(SetCkEditorConfigsService);\n  public Editor: any;\n  loadckeditor() {\n    let _that = this;\n    return new Promise(async resolve => {\n      await import('ckeditor5').then(async res => {\n        this.loadStyle();\n        _that.Editor = res.ClassicEditor;\n        let configs = await _that._SetCkEditorConfigsService.get({\n          language: _that.currentCulture,\n        });\n        _that.ckOptions = configs;\n      });\n      resolve(true);\n    });\n  }\n  private lazyLoadService = inject(LazyLoadService);\n  private subscriptionService = inject(SubscriptionService);\n  private loadStyle() {\n    const loaded$ = this.lazyLoadService.load(\n      LOADING_STRATEGY.AppendAnonymousStyleToHead('ckeditor5.css')\n    );\n    this.subscriptionService.addOne(loaded$);\n  }\n\n  invalidfeedback = false;\n  //设置值\n  setckeditorInput(val) {\n    this.invalidfeedback = true;\n    this.ckeditorInput.patchValue(val);\n  }\n\n  /**图片容器名称 */\n  imagesContainerName: any = '';\n  AfterInit() {\n    return new Promise(resolve => {\n      let ValidatorsArray = [];\n      if (this._fields.required) {\n        ValidatorsArray.push(Validators.required);\n      }\n      let newControl = this.fb.control(\n        this._selected\n          ? this._selected\n          : this._fields.field.formConfiguration['Ckeditor.InitialContent'],\n        ValidatorsArray\n      );\n      this.extraProperties.setControl(this._fields.field.name, newControl);\n      this.imagesContainerName =\n        this._fields.field.formConfiguration['Ckeditor.ImagesContainerName'];\n\n      if (!this.imagesContainerName) {\n        this.ckOptions?.toolbar?.items?.splice(\n          this.ckOptions?.toolbar?.items?.indexOf('insertImage'),\n          1\n        );\n      }\n      resolve(true);\n    });\n  }\n}\n","<form [formGroup]=\"_entity\">\n    <div formGroupName=\"extraProperties\">\n        <div class=\"mb-3\">\n            <label class=\"form-label\" *ngIf=\"_fields.displayName\">{{ _fields.displayName }}</label>\n            <ng-container *ngIf=\"ckOptions\">\n\n                <ckeditor [editor]=\"Editor\" *ngIf=\"Editor\" [config]=\"ckOptions\" (ready)=\"onReady($event)\"\n                    [formControlName]=\"_fields.field.name\">\n                </ckeditor>\n            </ng-container>\n            <small class=\"form-text text-muted d-block\"\n                *ngIf=\"_fields.field.description\">{{_fields.field.description}}</small>\n        </div>\n    </div>\n    <button type=\"submit\" style=\"display: none;\" #submitclick></button>\n</form>"]}
|
|
@@ -2,7 +2,7 @@ export var LanguagesMap;
|
|
|
2
2
|
(function (LanguagesMap) {
|
|
3
3
|
LanguagesMap["ar"] = "ar";
|
|
4
4
|
LanguagesMap["cs"] = "cs";
|
|
5
|
-
LanguagesMap["en"] = "en";
|
|
5
|
+
LanguagesMap["en"] = "en-gb";
|
|
6
6
|
LanguagesMap["hi"] = "hi";
|
|
7
7
|
LanguagesMap["fi"] = "fi";
|
|
8
8
|
LanguagesMap["hu"] = "hu";
|
|
@@ -19,4 +19,4 @@ export var LanguagesMap;
|
|
|
19
19
|
LanguagesMap["ja"] = "ja";
|
|
20
20
|
LanguagesMap["vi"] = "vi";
|
|
21
21
|
})(LanguagesMap || (LanguagesMap = {}));
|
|
22
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
22
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGFuZ3VhZ2VzLW1hcC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2NrLWVkaXRvci9zcmMvbGliL2VudW1zL2xhbmd1YWdlcy1tYXAudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsTUFBTSxDQUFOLElBQVksWUFtQlg7QUFuQkQsV0FBWSxZQUFZO0lBQ3BCLHlCQUFRLENBQUE7SUFDUix5QkFBUSxDQUFBO0lBQ1IsNEJBQVcsQ0FBQTtJQUNYLHlCQUFRLENBQUE7SUFDUix5QkFBUSxDQUFBO0lBQ1IseUJBQVEsQ0FBQTtJQUNSLHlCQUFRLENBQUE7SUFDUix5QkFBUSxDQUFBO0lBQ1IsK0JBQWdCLENBQUE7SUFDaEIsK0JBQWdCLENBQUE7SUFDaEIsOEJBQWUsQ0FBQTtJQUNmLGlDQUFrQixDQUFBO0lBQ2xCLHlCQUFRLENBQUE7SUFDUix5QkFBUSxDQUFBO0lBQ1IsNEJBQWEsQ0FBQTtJQUNiLHlCQUFRLENBQUE7SUFDUix5QkFBUSxDQUFBO0lBQ1IseUJBQVEsQ0FBQTtBQUNaLENBQUMsRUFuQlcsWUFBWSxLQUFaLFlBQVksUUFtQnZCIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGVudW0gTGFuZ3VhZ2VzTWFwIHtcclxuICAgIGFyPSAnYXInLFxyXG4gICAgY3M9ICdjcycsXHJcbiAgICBlbj0gJ2VuLWdiJyxcclxuICAgIGhpPSAnaGknLFxyXG4gICAgZmk9ICdmaScsXHJcbiAgICBodT0gJ2h1JyxcclxuICAgIGZyPSAnZnInLFxyXG4gICAgaXQ9ICdpdCcsXHJcbiAgICAnZW4tR0InPSAnZW4tZ2InLFxyXG4gICAgJ3B0LUJSJz0gJ3B0LWJyJyxcclxuICAgICd6aC1IYW50Jz0gJ3poJyxcclxuICAgICd6aC1IYW5zJz0gJ3poLWNuJyxcclxuICAgIHRyPSAndHInLFxyXG4gICAgc2s9ICdzaycsXHJcbiAgICAnZGUtREUnPSAnZGUnLFxyXG4gICAgZXM9ICdlcycsXHJcbiAgICBqYT0gJ2phJyxcclxuICAgIHZpPSAndmknLFxyXG59XHJcbiJdfQ==
|