@dignite-ng/expand.cms 0.0.14 → 0.0.15
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/config/enums/route-names.mjs +1 -1
- package/esm2022/config/providers/route.provider.mjs +1 -22
- package/esm2022/lib/components/admin/entries/create-or-edit-entries.component.mjs +19 -5
- package/esm2022/lib/components/admin/entries/create-or-update-entry-input-base.mjs +1 -12
- package/esm2022/lib/components/admin/entries/create.component.mjs +5 -5
- package/esm2022/lib/components/admin/entries/edit.component.mjs +18 -15
- package/esm2022/lib/components/admin/entries/entries.component.mjs +17 -21
- package/esm2022/lib/components/admin/fields/create-field.component.mjs +18 -10
- package/esm2022/lib/components/admin/fields/create-or-edit-field.component.mjs +8 -12
- package/esm2022/lib/components/admin/fields/create-or-update-field-input-base.mjs +2 -2
- package/esm2022/lib/components/admin/fields/edit-field.component.mjs +13 -6
- package/esm2022/lib/components/admin/fields/fields.component.mjs +10 -3
- package/esm2022/lib/components/admin/sections/entry-types/create-or-edit.-entry-type-input-base.mjs +2 -2
- package/esm2022/lib/components/admin/sections/entry-types/create-or-edit.component.mjs +20 -8
- package/esm2022/lib/components/admin/sections/sections.component.mjs +10 -10
- package/esm2022/lib/components/dynamic-form/entry/entry-config.component.mjs +9 -7
- package/esm2022/lib/components/dynamic-form/entry/entry-control.component.mjs +26 -23
- package/esm2022/lib/components/dynamic-form/matrix/matrix-config.component.mjs +9 -7
- package/esm2022/lib/components/dynamic-form/matrix/matrix-config.mjs +2 -16
- package/esm2022/lib/components/dynamic-form/matrix/matrix-control.component.mjs +10 -3
- package/esm2022/lib/components/dynamic-form/table/table-config.component.mjs +7 -5
- package/esm2022/lib/components/dynamic-form/table/table-control.component.mjs +18 -6
- package/esm2022/lib/proxy/admin/entries/entry-admin.service.mjs +1 -8
- package/esm2022/lib/services/cms-api.service.mjs +1 -5
- package/esm2022/lib/services/field-abstracts.service.mjs +3 -2
- package/esm2022/lib/services/simple-reuse-strategy.mjs +1 -1
- package/esm2022/lib/services/update-list.service.mjs +19 -0
- package/fesm2022/dignite-ng-expand.cms-config.mjs +0 -21
- package/fesm2022/dignite-ng-expand.cms-config.mjs.map +1 -1
- package/fesm2022/dignite-ng-expand.cms.mjs +190 -148
- package/fesm2022/dignite-ng-expand.cms.mjs.map +1 -1
- package/lib/components/admin/entries/create-or-edit-entries.component.d.ts +3 -0
- package/lib/components/admin/entries/create.component.d.ts +1 -0
- package/lib/components/admin/entries/edit.component.d.ts +4 -3
- package/lib/components/admin/entries/entries.component.d.ts +3 -2
- package/lib/components/admin/fields/create-field.component.d.ts +4 -1
- package/lib/components/admin/fields/create-or-edit-field.component.d.ts +3 -3
- package/lib/components/admin/fields/create-or-update-field-input-base.d.ts +1 -0
- package/lib/components/admin/fields/edit-field.component.d.ts +4 -2
- package/lib/components/admin/fields/fields.component.d.ts +2 -0
- package/lib/components/admin/sections/entry-types/create-or-edit.-entry-type-input-base.d.ts +1 -0
- package/lib/components/admin/sections/entry-types/create-or-edit.component.d.ts +4 -2
- package/lib/components/admin/sections/sections.component.d.ts +3 -0
- package/lib/components/dynamic-form/entry/entry-config.component.d.ts +4 -1
- package/lib/components/dynamic-form/entry/entry-control.component.d.ts +6 -7
- package/lib/components/dynamic-form/matrix/matrix-config.component.d.ts +1 -0
- package/lib/components/dynamic-form/matrix/matrix-config.d.ts +1 -7
- package/lib/components/dynamic-form/matrix/matrix-control.component.d.ts +4 -1
- package/lib/components/dynamic-form/table/table-control.component.d.ts +4 -0
- package/lib/services/update-list.service.d.ts +9 -0
- package/package.json +3 -3
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { LIST_QUERY_DEBOUNCE_TIME, ListService } from '@abp/ng.core';
|
|
2
|
-
import { Component, ViewChild, } from '@angular/core';
|
|
2
|
+
import { Component, ViewChild, inject, } from '@angular/core';
|
|
3
3
|
import { FormControl, Validators, } from '@angular/forms';
|
|
4
4
|
import { ColumnMode } from "@swimlane/ngx-datatable";
|
|
5
5
|
import { finalize } from 'rxjs/operators';
|
|
@@ -7,6 +7,7 @@ import { CreateOrUpdateSectionsInputBase } from './create-or-update-sections-inp
|
|
|
7
7
|
import { SectionType, sectionTypeOptions } from '../../../proxy/sections';
|
|
8
8
|
import { EXTENSIONS_IDENTIFIER } from '@abp/ng.theme.shared/extensions';
|
|
9
9
|
import { ECmsComponent } from '../../../enums';
|
|
10
|
+
import { UpdateListService } from '../../../services/update-list.service';
|
|
10
11
|
import * as i0 from "@angular/core";
|
|
11
12
|
import * as i1 from "@abp/ng.core";
|
|
12
13
|
import * as i2 from "../../../proxy/admin/sections";
|
|
@@ -45,6 +46,7 @@ class SectionsComponent {
|
|
|
45
46
|
this._CmsApiService = _CmsApiService;
|
|
46
47
|
this.router = router;
|
|
47
48
|
}
|
|
49
|
+
_UpdateListService = inject(UpdateListService);
|
|
48
50
|
/**跳转编辑 */
|
|
49
51
|
jumpSectionsEdit(row, item) {
|
|
50
52
|
this.router.navigate([`/cms/admin/sections/${row.id}/entry-types/${item.id}/edit`], {});
|
|
@@ -75,6 +77,9 @@ class SectionsComponent {
|
|
|
75
77
|
async ngOnInit() {
|
|
76
78
|
await this.getSiteList();
|
|
77
79
|
this.hookToQuery();
|
|
80
|
+
this._UpdateListService.updateListEvent.subscribe(() => {
|
|
81
|
+
this.list.get();
|
|
82
|
+
});
|
|
78
83
|
}
|
|
79
84
|
/**站点切换 */
|
|
80
85
|
siteIdChange() {
|
|
@@ -129,9 +134,7 @@ class SectionsComponent {
|
|
|
129
134
|
}
|
|
130
135
|
/**删除某个条目类型 */
|
|
131
136
|
deleteEntryType(row) {
|
|
132
|
-
this.confirmation.warn(row.displayName,
|
|
133
|
-
// "确定要删除这个条目类型吗?",
|
|
134
|
-
this._LocalizationService.instant(`AbpUi::ItemWillBeDeletedMessage`)).subscribe((status) => {
|
|
137
|
+
this.confirmation.warn(row.displayName, this._LocalizationService.instant(`AbpUi::ItemWillBeDeletedMessage`)).subscribe((status) => {
|
|
135
138
|
if (status == 'confirm') {
|
|
136
139
|
this._EntryTypeAdminService.delete(row.id).pipe(finalize(() => {
|
|
137
140
|
})).subscribe(res => {
|
|
@@ -213,7 +216,6 @@ class SectionsComponent {
|
|
|
213
216
|
}
|
|
214
217
|
radiochange() {
|
|
215
218
|
this.routeInput.patchValue(this.routeInput.value);
|
|
216
|
-
// this.createOrEditModalSubmitBtn.nativeElement.click()
|
|
217
219
|
}
|
|
218
220
|
/**字段标签input失去标点生成字段名字 */
|
|
219
221
|
disPlayNameInputBlur(event) {
|
|
@@ -237,12 +239,10 @@ class SectionsComponent {
|
|
|
237
239
|
this.createOrEditForm.setControl('name', new FormControl(this.nameInput.value || '', {
|
|
238
240
|
validators: Validators.required,
|
|
239
241
|
asyncValidators: this.nameRepetitionAsyncValidator(),
|
|
240
|
-
// updateOn: 'blur'
|
|
241
242
|
}));
|
|
242
243
|
this.createOrEditForm.setControl('route', new FormControl(this.routeInput.value || '', {
|
|
243
244
|
validators: [Validators.required, this.forbiddenNameValidator()],
|
|
244
245
|
asyncValidators: [this.routeRepetitionAsyncValidator()],
|
|
245
|
-
// updateOn: 'blur'
|
|
246
246
|
}));
|
|
247
247
|
}
|
|
248
248
|
forbiddenNameValidator() {
|
|
@@ -252,7 +252,7 @@ class SectionsComponent {
|
|
|
252
252
|
return forbidden ? { repetition: this._LocalizationService.instant(`Cms::RouteVerificationTips`, this._LocalizationService.instant(`Cms::Enum:SectionType:` + SectionType[this.typeInput.value]), '{slug}') } : null;
|
|
253
253
|
};
|
|
254
254
|
}
|
|
255
|
-
|
|
255
|
+
/**定义异步验证方法 */
|
|
256
256
|
nameRepetitionAsyncValidator() {
|
|
257
257
|
return (ctrl) => {
|
|
258
258
|
return new Promise(resolve => {
|
|
@@ -275,7 +275,7 @@ class SectionsComponent {
|
|
|
275
275
|
});
|
|
276
276
|
};
|
|
277
277
|
}
|
|
278
|
-
|
|
278
|
+
/**定义异步验证方法 */
|
|
279
279
|
routeRepetitionAsyncValidator() {
|
|
280
280
|
return (ctrl) => {
|
|
281
281
|
return new Promise(resolve => {
|
|
@@ -331,4 +331,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
331
331
|
type: ViewChild,
|
|
332
332
|
args: ['createOrEditModalSubmitBtn', { static: false }]
|
|
333
333
|
}] } });
|
|
334
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"sections.component.js","sourceRoot":"","sources":["../../../../../../../projects/cms/src/lib/components/admin/sections/sections.component.ts","../../../../../../../projects/cms/src/lib/components/admin/sections/sections.component.html"],"names":[],"mappings":"AAAA,OAAO,EAA2B,wBAAwB,EAAE,WAAW,EAAuC,MAAM,cAAc,CAAC;AAEnI,OAAO,EAAE,SAAS,EAAsB,SAAS,GAAG,MAAM,eAAe,CAAC;AAC1E,OAAO,EAAgC,WAAW,EAA4C,UAAU,GAAG,MAAM,gBAAgB,CAAC;AAGlI,OAAO,EAAE,UAAU,EAAE,MAAM,yBAAyB,CAAC;AACrD,OAAO,EAAE,QAAQ,EAAE,MAAM,gBAAgB,CAAC;AAC1C,OAAO,EAAE,+BAA+B,EAAE,MAAM,wCAAwC,CAAC;AACzF,OAAO,EAAE,WAAW,EAAE,kBAAkB,EAAE,MAAM,yBAAyB,CAAC;AAC1E,OAAO,EAAE,qBAAqB,EAAE,MAAM,iCAAiC,CAAC;AACxE,OAAO,EAAE,aAAa,EAAE,MAAM,gBAAgB,CAAC;;;;;;;;;;;;;;AAK/C,MAiBa,iBAAiB;IAEV;IACR;IACA;IACA;IACA;IACA;IACA;IACD;IACA;IACA;IACC;IAXV,YACkB,IAAiB,EACzB,oBAAyC,EACzC,iBAAmC,EACnC,OAAuB,EACvB,YAAiC,EACjC,EAAe,EACf,WAA+B,EAChC,sBAA6C,EAC7C,oBAAyC,EACzC,cAA6B,EAC5B,MAAc;QAVN,SAAI,GAAJ,IAAI,CAAa;QACzB,yBAAoB,GAApB,oBAAoB,CAAqB;QACzC,sBAAiB,GAAjB,iBAAiB,CAAkB;QACnC,YAAO,GAAP,OAAO,CAAgB;QACvB,iBAAY,GAAZ,YAAY,CAAqB;QACjC,OAAE,GAAF,EAAE,CAAa;QACf,gBAAW,GAAX,WAAW,CAAoB;QAChC,2BAAsB,GAAtB,sBAAsB,CAAuB;QAC7C,yBAAoB,GAApB,oBAAoB,CAAqB;QACzC,mBAAc,GAAd,cAAc,CAAe;QAC5B,WAAM,GAAN,MAAM,CAAQ;IAGxB,CAAC;IAED,UAAU;IACV,gBAAgB,CAAC,GAAG,EAAE,IAAI;QACxB,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,uBAAuB,GAAG,CAAC,EAAE,gBAAgB,IAAI,CAAC,EAAE,OAAO,CAAC,EAAE,EACnF,CAAC,CAAA;IACJ,CAAC;IACD,UAAU;IACV,kBAAkB,CAAC,GAAG;QACpB,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,uBAAuB,GAAG,CAAC,EAAE,qBAAqB,CAAC,EAAE,EAC1E,CAAC,CAAA;IACJ,CAAC;IAGD,UAAU;IACV,QAAQ,GAAU,EAAE,CAAA;IACpB,OAAO;IACP,UAAU,GAAG,UAAU,CAAC;IACxB,IAAI,GAA+B;QACjC,KAAK,EAAE,EAAE;QACT,UAAU,EAAE,CAAC;KACd,CAAC;IACF,MAAM;IACN,OAAO,GAAG,EAAsB,CAAC;IACjC,YAAY;IACZ,WAAW;QACT,MAAM,OAAO,GAAG,CAAC,KAA0B,EAAE,EAAE,CAAC,IAAI,CAAC,oBAAoB,CAAC,OAAO,CAAC;YAChF,GAAG,KAAK;YACR,GAAG,IAAI,CAAC,OAAO;SAChB,CAAC,CAAC;QAEH,MAAM,OAAO,GAAG,CAAC,IAAgC,EAAE,EAAE,CAAC,CAAC,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,CAAC;QACzE,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC;IACpD,CAAC;IAED,KAAK,CAAC,QAAQ;QACZ,MAAM,IAAI,CAAC,WAAW,EAAE,CAAA;QACxB,IAAI,CAAC,WAAW,EAAE,CAAA;IACpB,CAAC;IAED,UAAU;IACV,YAAY;QACV,IAAI,CAAC,IAAI,CAAC,IAAI,GAAG,CAAC,CAAA;QAClB,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,CAAA;IACjB,CAAC;IAED,YAAY;IACZ,WAAW;QACT,OAAO,IAAI,OAAO,CAAC,CAAC,OAAO,EAAE,OAAO,EAAE,EAAE;YACtC,IAAI,CAAC,iBAAiB,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC,SAAS,CAAC,GAAG,CAAC,EAAE;gBACjD,IAAI,CAAC,QAAQ,GAAG,GAAG,CAAC,KAAK,CAAA;gBACzB,IAAI,CAAC,OAAO,CAAC,MAAM,GAAG,GAAG,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,EAAE,IAAI,EAAE,CAAA;gBAC5C,OAAO,CAAC,IAAI,CAAC,CAAA;gBACb,OAAO,CAAC,KAAK,CAAC,CAAA;YAEhB,CAAC,CAAC,CAAA;QACJ,CAAC,CAAC,CAAA;IAEJ,CAAC;IAED,eAAe;IACf,WAAW,GAAY,KAAK,CAAA;IAE5B,qBAAqB;IACrB,SAAS,GAAY,KAAK,CAAA;IAC1B,YAAY;IACZ,gBAAgB,CAAwB;IAExC,cAAc;IACd,QAAQ,CAAK;IAEb,YAAY,GAAG,WAAW,CAAA;IAC1B,mBAAmB,GAAG,kBAAkB,CAAA;IAExC,qBAAqB;IACuC,0BAA0B,CAAa;IAEnG,iBAAiB;IACjB,aAAa,CAAC,KAAK;QACjB,IAAI,CAAC,KAAK,EAAE;YACV,IAAI,CAAC,QAAQ,GAAG,EAAE,CAAA;YAClB,OAAM;SACP;IACH,CAAC;IACD,gBAAgB;IAChB,gBAAgB;QACd,IAAI,CAAC,WAAW,GAAG,IAAI,CAAA;QACvB,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC,EAAE,CAAC,KAAK,CAAC,IAAI,+BAA+B,EAAE,CAAC,CAAA;QAC5E,IAAI,CAAC,oBAAoB,EAAE,CAAA;IAC7B,CAAC;IACD,gBAAgB;IAChB,cAAc,CAAC,GAAG;QAChB,IAAI,CAAC,WAAW,GAAG,IAAI,CAAA;QACvB,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC,EAAE,CAAC,KAAK,CAAC,IAAI,+BAA+B,EAAE,CAAC,CAAA;QAC5E,IAAI,CAAC,oBAAoB,EAAE,CAAA;QAC3B,IAAI,CAAC,oBAAoB,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,SAAS,CAAC,GAAG,CAAC,EAAE;YACpD,IAAI,CAAC,gBAAgB,CAAC,UAAU,CAAC,GAAG,CAAC,CAAA;YACrC,IAAI,CAAC,QAAQ,GAAG,GAAG,CAAA;QACrB,CAAC,CAAC,CAAA;IACJ,CAAC;IACD,cAAc;IACd,eAAe,CAAC,GAAG;QACjB,IAAI,CAAC,YAAY,CAAC,IAAI,CACpB,GAAG,CAAC,WAAW;QACf,mBAAmB;QACnB,IAAI,CAAC,oBAAoB,CAAC,OAAO,CAAC,iCAAiC,CAAC,CACrE,CAAC,SAAS,CAAC,CAAC,MAA2B,EAAE,EAAE;YAC1C,IAAI,MAAM,IAAI,SAAS,EAAE;gBACvB,IAAI,CAAC,sBAAsB,CAAC,MAAM,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,GAAG,EAAE;gBAC9D,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,GAAG,CAAC,EAAE;oBAClB,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,IAAI,CAAC,oBAAoB,CAAC,OAAO,CAAC,4BAA4B,CAAC,CAAC,CAAC;oBACtF,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,CAAA;gBACjB,CAAC,CAAC,CAAA;aACH;QACH,CAAC,CAAC,CAAC;IAEL,CAAC;IAED,YAAY;IACZ,gBAAgB;QACd,IAAI,IAAI,CAAC,QAAQ,EAAE;YACjB,OAAO,IAAI,CAAC,QAAQ,EAAE,CAAA;SACvB;QACD,IAAI,CAAC,UAAU,EAAE,CAAA;IACnB,CAAC;IAED,MAAM;IACN,UAAU;QACR,IAAI,KAAK,GAAG,IAAI,CAAC,gBAAgB,CAAC,KAAK,CAAA;QACvC,KAAK,CAAC,MAAM,GAAG,IAAI,CAAC,OAAO,CAAC,MAAM,CAAA;QAClC,IAAI,CAAC,IAAI,CAAC,gBAAgB,CAAC,KAAK;YAAE,OAAM;QACxC,IAAI,CAAC,SAAS,GAAG,IAAI,CAAA;QACrB,IAAI,CAAC,oBAAoB,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,GAAG,EAAE;YACzD,IAAI,CAAC,SAAS,GAAG,KAAK,CAAA;YACtB,IAAI,CAAC,WAAW,GAAG,KAAK,CAAA;QAC1B,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,GAAG,CAAC,EAAE;YAClB,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,IAAI,CAAC,oBAAoB,CAAC,OAAO,CAAC,2BAA2B,CAAC,CAAC,CAAC;YACrF,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,CAAA;QACjB,CAAC,CAAC,CAAA;IACJ,CAAC;IACD,YAAY;IACZ,QAAQ;QACN,IAAI,KAAK,GAAG,IAAI,CAAC,gBAAgB,CAAC,KAAK,CAAA;QACvC,KAAK,CAAC,MAAM,GAAG,IAAI,CAAC,OAAO,CAAC,MAAM,CAAA;QAClC,KAAK,CAAC,gBAAgB,GAAG,IAAI,CAAC,QAAQ,CAAC,gBAAgB,CAAA;QACvD,IAAI,CAAC,IAAI,CAAC,gBAAgB,CAAC,KAAK;YAAE,OAAM;QACxC,IAAI,CAAC,SAAS,GAAG,IAAI,CAAA;QACrB,IAAI,CAAC,oBAAoB,CAAC,MAAM,CAAC,IAAI,CAAC,QAAQ,CAAC,EAAE,EAAE,KAAK,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,GAAG,EAAE;YAC3E,IAAI,CAAC,SAAS,GAAG,KAAK,CAAA;YACtB,IAAI,CAAC,WAAW,GAAG,KAAK,CAAA;QAC1B,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,GAAG,CAAC,EAAE;YAClB,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,IAAI,CAAC,oBAAoB,CAAC,OAAO,CAAC,2BAA2B,CAAC,CAAC,CAAC;YACrF,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,CAAA;QACjB,CAAC,CAAC,CAAA;IACJ,CAAC;IACD,UAAU;IACV,WAAW,CAAC,GAAG;QACb,IAAI,CAAC,YAAY,CAAC,IAAI,CACpB,GAAG,CAAC,WAAW,EACf,IAAI,CAAC,oBAAoB,CAAC,OAAO,CAAC,iCAAiC,CAAC,CACrE,CAAC,SAAS,CAAC,CAAC,MAA2B,EAAE,EAAE;YAC1C,IAAI,MAAM,IAAI,SAAS,EAAE;gBACvB,IAAI,CAAC,oBAAoB,CAAC,MAAM,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,GAAG,EAAE;gBAC5D,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,GAAG,CAAC,EAAE;oBAClB,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,IAAI,CAAC,oBAAoB,CAAC,OAAO,CAAC,4BAA4B,CAAC,CAAC,CAAC;oBACtF,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,CAAA;gBACjB,CAAC,CAAC,CAAA;aACH;QACH,CAAC,CAAC,CAAC;IACL,CAAC;IAID,cAAc;IACd,IAAI,gBAAgB;QAClB,OAAO,IAAI,CAAC,gBAAgB,CAAC,GAAG,CAAC,aAAa,CAAC,CAAA;IACjD,CAAC;IACD,cAAc;IACd,IAAI,SAAS;QACX,OAAO,IAAI,CAAC,gBAAgB,CAAC,GAAG,CAAC,MAAM,CAAC,CAAA;IAC1C,CAAC;IACD,eAAe;IACf,IAAI,UAAU;QACZ,OAAO,IAAI,CAAC,gBAAgB,CAAC,GAAG,CAAC,OAAO,CAAC,CAAA;IAC3C,CAAC;IACD,eAAe;IACf,IAAI,aAAa;QACf,OAAO,IAAI,CAAC,gBAAgB,CAAC,GAAG,CAAC,UAAU,CAAC,CAAA;IAC9C,CAAC;IACD,eAAe;IACf,IAAI,SAAS;QACX,OAAO,IAAI,CAAC,gBAAgB,CAAC,GAAG,CAAC,MAAM,CAAC,CAAA;IAC1C,CAAC;IAED,WAAW;QACT,IAAI,CAAC,UAAU,CAAC,UAAU,CAAC,IAAI,CAAC,UAAU,CAAC,KAAK,CAAC,CAAA;QACjD,wDAAwD;IAC1D,CAAC;IAGD,yBAAyB;IACzB,oBAAoB,CAAC,KAAK;QACxB,IAAI,KAAK,GAAG,KAAK,CAAC,MAAM,CAAC,KAAK,CAAA;QAC9B,IAAI,MAAM,GAAG,IAAI,CAAC,cAAc,CAAC,eAAe,CAAC,KAAK,CAAC,CAAA;QACvD,IAAI,SAAS,GAAG,IAAI,CAAC,SAAS,CAAA;QAC9B,IAAI,UAAU,GAAG,IAAI,CAAC,UAAU,CAAA;QAChC,IAAI,aAAa,GAAG,IAAI,CAAC,aAAa,CAAA;QACtC,IAAI,SAAS,CAAC,KAAK;YAAE,OAAM;QAC3B,SAAS,CAAC,UAAU,CAAC,MAAM,CAAC,CAAA;QAC5B,IAAI,UAAU,CAAC,KAAK;YAAE,OAAM;QAC5B,UAAU,CAAC,UAAU,CAAC,MAAM,GAAG,CAAC,IAAI,CAAC,SAAS,CAAC,KAAK,KAAK,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAA;QAC7E,IAAI,aAAa,CAAC,KAAK;YAAE,OAAM;QAC/B,aAAa,CAAC,UAAU,CAAC,MAAM,GAAG,QAAQ,CAAC,CAAA;IAC7C,CAAC;IAID,gBAAgB;IAChB,oBAAoB;QAClB,IAAI,CAAC,gBAAgB,CAAC,UAAU,CAAC,MAAM,EAAE,IAAI,WAAW,CAAC,IAAI,CAAC,SAAS,CAAC,KAAK,IAAI,EAAE,EAAE;YACnF,UAAU,EAAE,UAAU,CAAC,QAAQ;YAC/B,eAAe,EAAE,IAAI,CAAC,4BAA4B,EAAE;YACpD,mBAAmB;SACpB,CAAC,CAAC,CAAA;QACH,IAAI,CAAC,gBAAgB,CAAC,UAAU,CAAC,OAAO,EAAE,IAAI,WAAW,CAAC,IAAI,CAAC,UAAU,CAAC,KAAK,IAAI,EAAE,EAAE;YACrF,UAAU,EAAE,CAAC,UAAU,CAAC,QAAQ,EAAE,IAAI,CAAC,sBAAsB,EAAE,CAAC;YAChE,eAAe,EAAE,CAAC,IAAI,CAAC,6BAA6B,EAAE,CAAC;YACvD,mBAAmB;SACpB,CAAC,CAAC,CAAA;IACL,CAAC;IACD,sBAAsB;QACpB,OAAO,CAAC,OAAwB,EAA2B,EAAE;YAC3D,IAAI,UAAU,GAAG,OAAO,CAAC,KAAK,CAAC,iBAAiB,EAAE,CAAA;YAClD,IAAI,SAAS,GAAG,IAAI,CAAC,SAAS,CAAC,KAAK,IAAI,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,UAAU,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,CAAA;YAChG,OAAO,SAAS,CAAC,CAAC,CAAC,EAAE,UAAU,EAAE,IAAI,CAAC,oBAAoB,CAAC,OAAO,CAAC,4BAA4B,EAAE,IAAI,CAAC,oBAAoB,CAAC,OAAO,CAAC,wBAAwB,GAAG,WAAW,CAAC,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,EAAE,QAAQ,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC;QACvN,CAAC,CAAC;IACJ,CAAC;IAED,UAAU;IACV,4BAA4B;QAC1B,OAAO,CAAC,IAAqB,EAA0E,EAAE;YACvG,OAAO,IAAI,OAAO,CAAC,OAAO,CAAC,EAAE;gBAC3B,IAAI,OAAO,GAAG,IAAI,CAAC,gBAAgB,EAAE,GAAG,CAAC,MAAM,CAAC,CAAA;gBAChD,IAAI,OAAO,CAAC,KAAK,IAAI,IAAI,CAAC,QAAQ,EAAE,IAAI,EAAE;oBACxC,OAAO,CAAC,IAAI,CAAC,CAAC;oBACd,OAAM;iBACP;gBACD,IAAI,CAAC,oBAAoB,CAAC,UAAU,CAAC;oBACnC,MAAM,EAAE,IAAI,CAAC,OAAO,CAAC,MAAM;oBAC3B,IAAI,EAAE,OAAO,CAAC,KAAK;iBACpB,CAAC,CAAC,SAAS,CAAC,GAAG,CAAC,EAAE;oBACjB,IAAI,GAAG,EAAE;wBACP,OAAO,CAAC,EAAE,UAAU,EAAE,IAAI,CAAC,oBAAoB,CAAC,OAAO,CAAC,iCAAiC,EAAE,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC;qBAC3G;yBAAM;wBACL,OAAO,CAAC,IAAI,CAAC,CAAC;qBACf;gBACH,CAAC,CAAC,CAAA;YACJ,CAAC,CAAC,CAAC;QACL,CAAC,CAAC;IACJ,CAAC;IACD,UAAU;IACV,6BAA6B;QAC3B,OAAO,CAAC,IAAqB,EAA0E,EAAE;YACvG,OAAO,IAAI,OAAO,CAAC,OAAO,CAAC,EAAE;gBAC3B,IAAI,OAAO,GAAG,IAAI,CAAC,gBAAgB,EAAE,GAAG,CAAC,OAAO,CAAC,CAAC,KAAK,CAAA;gBACvD,IAAI,OAAO,IAAI,IAAI,CAAC,QAAQ,EAAE,KAAK,EAAE;oBACnC,OAAO,CAAC,IAAI,CAAC,CAAC;oBACd,OAAM;iBACP;gBACD,IAAI,CAAC,oBAAoB,CAAC,WAAW,CAAC;oBACpC,MAAM,EAAE,IAAI,CAAC,OAAO,CAAC,MAAM;oBAC3B,KAAK,EAAE,OAAO;iBACf,CAAC,CAAC,SAAS,CAAC,GAAG,CAAC,EAAE;oBACjB,IAAI,GAAG,EAAE;wBACP,OAAO,CAAC,EAAE,UAAU,EAAE,IAAI,CAAC,oBAAoB,CAAC,OAAO,CAAC,kCAAkC,EAAE,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC;qBAC5G;yBAAM;wBACL,OAAO,CAAC,IAAI,CAAC,CAAC;qBACf;gBACH,CAAC,CAAC,CAAA;YACJ,CAAC,CAAC,CAAC;QACL,CAAC,CAAC;IACJ,CAAC;wGAxSU,iBAAiB;4FAAjB,iBAAiB,uCAbjB;YACT,aAAa;YACb,WAAW;YACX,aAAa;YACb,4DAA4D;YAC5D,uEAAuE;YACvE,EAAE,OAAO,EAAE,wBAAwB,EAAE,QAAQ,EAAE,GAAG,EAAE;YACpD;gBACE,OAAO,EAAE,qBAAqB;gBAC9B,QAAQ,EAAE,aAAa,CAAC,QAAQ;aACjC;SACF,oKC/BH,m+XA8LY;;SD7JC,iBAAiB;4FAAjB,iBAAiB;kBAjB7B,SAAS;+BACE,cAAc,aAGb;wBACT,aAAa;wBACb,WAAW;wBACX,aAAa;wBACb,4DAA4D;wBAC5D,uEAAuE;wBACvE,EAAE,OAAO,EAAE,wBAAwB,EAAE,QAAQ,EAAE,GAAG,EAAE;wBACpD;4BACE,OAAO,EAAE,qBAAqB;4BAC9B,QAAQ,EAAE,aAAa,CAAC,QAAQ;yBACjC;qBACF;oZA4F2D,0BAA0B;sBAArF,SAAS;uBAAC,4BAA4B,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE","sourcesContent":["import { ABP, ConfigStateService, LIST_QUERY_DEBOUNCE_TIME, ListService, LocalizationService, PagedResultDto } from '@abp/ng.core';\nimport { ToasterService, ConfirmationService, Confirmation, } from '@abp/ng.theme.shared';\nimport { Component, ElementRef, OnInit, ViewChild, } from '@angular/core';\nimport { AbstractControl, FormBuilder, FormControl, FormGroup, ValidationErrors, ValidatorFn, Validators, } from '@angular/forms';\nimport { EntryTypeAdminService, GetSectionsInput, SectionAdminService, SectionDto } from '../../../proxy/admin/sections';\nimport { SiteAdminService } from '../../../proxy/admin/sites';\nimport { ColumnMode } from \"@swimlane/ngx-datatable\";\nimport { finalize } from 'rxjs/operators';\nimport { CreateOrUpdateSectionsInputBase } from './create-or-update-sections-input-base';\nimport { SectionType, sectionTypeOptions } from '../../../proxy/sections';\nimport { EXTENSIONS_IDENTIFIER } from '@abp/ng.theme.shared/extensions';\nimport { ECmsComponent } from '../../../enums';\nimport { CmsApiService } from '../../../services/cms-api.service';\nimport { Observable } from 'rxjs';\nimport { Router } from '@angular/router';\n\n@Component({\n  selector: 'cms-sections',\n  templateUrl: './sections.component.html',\n  styleUrls: ['./sections.component.scss'],\n  providers: [\n    // [Required]\n    ListService,\n    // [Optional]\n    // Provide this token if you want a different debounce time.\n    // Default is 300. Cannot be 0. Any value below 100 is not recommended.\n    { provide: LIST_QUERY_DEBOUNCE_TIME, useValue: 500 },\n    {\n      provide: EXTENSIONS_IDENTIFIER,\n      useValue: ECmsComponent.Sections,\n    },\n  ]\n})\nexport class SectionsComponent implements OnInit {\n  constructor(\n    public readonly list: ListService,\n    private _SectionAdminService: SectionAdminService,\n    private _SiteAdminService: SiteAdminService,\n    private toaster: ToasterService,\n    private confirmation: ConfirmationService,\n    private fb: FormBuilder,\n    private configState: ConfigStateService,\n    public _EntryTypeAdminService: EntryTypeAdminService,\n    public _LocalizationService: LocalizationService,\n    public _CmsApiService: CmsApiService,\n    private router: Router,\n  ) {\n\n  }\n\n  /**跳转编辑 */\n  jumpSectionsEdit(row, item) {\n    this.router.navigate([`/cms/admin/sections/${row.id}/entry-types/${item.id}/edit`], {\n    })\n  }\n  /**跳转新建 */\n  jumpSectionsCreate(row) {\n    this.router.navigate([`/cms/admin/sections/${row.id}/entry-types/create`], {\n    })\n  }\n\n\n  /**版块列表 */\n  siteList: any[] = []\n  /*** */\n  ColumnMode = ColumnMode;\n  data: PagedResultDto<SectionDto> = {\n    items: [],\n    totalCount: 0,\n  };\n  /** */\n  filters = {} as GetSectionsInput;\n  /**获取页面列表 */\n  hookToQuery() {\n    const getData = (query: ABP.PageQueryParams) => this._SectionAdminService.getList({\n      ...query,\n      ...this.filters,\n    });\n\n    const setData = (list: PagedResultDto<SectionDto>) => (this.data = list);\n    this.list.hookToQuery(getData).subscribe(setData);\n  }\n\n  async ngOnInit(): Promise<void> {\n    await this.getSiteList()\n    this.hookToQuery()\n  }\n\n  /**站点切换 */\n  siteIdChange() {\n    this.list.page = 0\n    this.list.get()\n  }\n\n  /**获取版块列表 */\n  getSiteList() {\n    return new Promise((resolve, rejects) => {\n      this._SiteAdminService.getList({}).subscribe(res => {\n        this.siteList = res.items\n        this.filters.siteId = res.items[0]?.id || ''\n        resolve(true)\n        rejects(false)\n\n      })\n    })\n\n  }\n\n  /**创建版块模态框状态 */\n  visibleOpen: boolean = false\n\n  /**用于确定模态的繁忙状态是否为真 */\n  modalBusy: boolean = false\n  /**创建版块表单 */\n  createOrEditForm: FormGroup | undefined;\n\n  /**版块给定的表单值 */\n  selected: any\n\n  _SectionType = SectionType\n  _sectionTypeOptions = sectionTypeOptions\n\n  /**表单控件模板-动态赋值表单控件 */\n  @ViewChild('createOrEditModalSubmitBtn', { static: false }) createOrEditModalSubmitBtn: ElementRef;\n\n  /**创建版块模态框状态改变 */\n  VisibleChange(event) {\n    if (!event) {\n      this.selected = ''\n      return\n    }\n  }\n  /**创建版块，打开模态框 */\n  createSectionBtn() {\n    this.visibleOpen = true\n    this.createOrEditForm = this.fb.group(new CreateOrUpdateSectionsInputBase())\n    this.setAsyncValidatorsFn()\n  }\n  /**编辑版块，打开模态框 */\n  editSectionBtn(row) {\n    this.visibleOpen = true\n    this.createOrEditForm = this.fb.group(new CreateOrUpdateSectionsInputBase())\n    this.setAsyncValidatorsFn()\n    this._SectionAdminService.get(row.id).subscribe(res => {\n      this.createOrEditForm.patchValue(res)\n      this.selected = res\n    })\n  }\n  /**删除某个条目类型 */\n  deleteEntryType(row) {\n    this.confirmation.warn(\n      row.displayName,\n      // \"确定要删除这个条目类型吗?\",\n      this._LocalizationService.instant(`AbpUi::ItemWillBeDeletedMessage`),\n    ).subscribe((status: Confirmation.Status) => {\n      if (status == 'confirm') {\n        this._EntryTypeAdminService.delete(row.id).pipe(finalize(() => {\n        })).subscribe(res => {\n          this.toaster.success(this._LocalizationService.instant(`AbpUi::SuccessfullyDeleted`));\n          this.list.get()\n        })\n      }\n    });\n\n  }\n\n  /**表单保存提交 */\n  createOrEditSave() {\n    if (this.selected) {\n      return this.EditSave()\n    }\n    this.createSave()\n  }\n\n  /** */\n  createSave() {\n    let input = this.createOrEditForm.value\n    input.siteId = this.filters.siteId\n    if (!this.createOrEditForm.valid) return\n    this.modalBusy = true\n    this._SectionAdminService.create(input).pipe(finalize(() => {\n      this.modalBusy = false\n      this.visibleOpen = false\n    })).subscribe(res => {\n      this.toaster.success(this._LocalizationService.instant(`CmsKit::SavedSuccessfully`));\n      this.list.get()\n    })\n  }\n  /**创建版块保存 */\n  EditSave() {\n    let input = this.createOrEditForm.value\n    input.siteId = this.filters.siteId\n    input.concurrencyStamp = this.selected.concurrencyStamp\n    if (!this.createOrEditForm.valid) return\n    this.modalBusy = true\n    this._SectionAdminService.update(this.selected.id, input).pipe(finalize(() => {\n      this.modalBusy = false\n      this.visibleOpen = false\n    })).subscribe(res => {\n      this.toaster.success(this._LocalizationService.instant(`CmsKit::SavedSuccessfully`));\n      this.list.get()\n    })\n  }\n  /**删除版块 */\n  deletefield(row) {\n    this.confirmation.warn(\n      row.displayName,\n      this._LocalizationService.instant(`AbpUi::ItemWillBeDeletedMessage`),\n    ).subscribe((status: Confirmation.Status) => {\n      if (status == 'confirm') {\n        this._SectionAdminService.delete(row.id).pipe(finalize(() => {\n        })).subscribe(res => {\n          this.toaster.success(this._LocalizationService.instant(`AbpUi::SuccessfullyDeleted`));\n          this.list.get()\n        })\n      }\n    });\n  }\n\n\n\n  /**name表单控件 */\n  get displayNameInput() {\n    return this.createOrEditForm.get('displayName')\n  }\n  /**name表单控件 */\n  get nameInput() {\n    return this.createOrEditForm.get('name')\n  }\n  /**route表单控件 */\n  get routeInput() {\n    return this.createOrEditForm.get('route')\n  }\n  /**route表单控件 */\n  get templateInput() {\n    return this.createOrEditForm.get('template')\n  }\n  /**route表单控件 */\n  get typeInput() {\n    return this.createOrEditForm.get('type')\n  }\n\n  radiochange() {\n    this.routeInput.patchValue(this.routeInput.value)\n    // this.createOrEditModalSubmitBtn.nativeElement.click()\n  }\n\n\n  /**字段标签input失去标点生成字段名字 */\n  disPlayNameInputBlur(event) {\n    let value = event.target.value\n    let pinyin = this._CmsApiService.chineseToPinyin(value)\n    let nameInput = this.nameInput\n    let routeInput = this.routeInput\n    let templateInput = this.templateInput\n    if (nameInput.value) return\n    nameInput.patchValue(pinyin)\n    if (routeInput.value) return\n    routeInput.patchValue(pinyin + (this.typeInput.value === 0 ? '' : '/{slug}'))\n    if (templateInput.value) return\n    templateInput.patchValue(pinyin + '/index')\n  }\n\n\n\n  /**设置字段控件异步验证 */\n  setAsyncValidatorsFn() {\n    this.createOrEditForm.setControl('name', new FormControl(this.nameInput.value || '', {\n      validators: Validators.required,\n      asyncValidators: this.nameRepetitionAsyncValidator(),\n      // updateOn: 'blur'\n    }))\n    this.createOrEditForm.setControl('route', new FormControl(this.routeInput.value || '', {\n      validators: [Validators.required, this.forbiddenNameValidator()],\n      asyncValidators: [this.routeRepetitionAsyncValidator()],\n      // updateOn: 'blur'\n    }))\n  }\n  forbiddenNameValidator(): ValidatorFn {\n    return (control: AbstractControl): ValidationErrors | null => {\n      let inputValue = control.value.toLocaleLowerCase()\n      let forbidden = this.typeInput.value == 0 ? false : inputValue.includes('{slug}') ? false : true\n      return forbidden ? { repetition: this._LocalizationService.instant(`Cms::RouteVerificationTips`, this._LocalizationService.instant(`Cms::Enum:SectionType:` + SectionType[this.typeInput.value]), '{slug}') } : null;\n    };\n  }\n\n  //定义异步验证方法\n  nameRepetitionAsyncValidator() {\n    return (ctrl: AbstractControl): Promise<ValidationErrors | null> | Observable<ValidationErrors | null> => {\n      return new Promise(resolve => {\n        let subslug = this.createOrEditForm?.get('name')\n        if (subslug.value == this.selected?.name) {\n          resolve(null);\n          return\n        }\n        this._SectionAdminService.nameExists({\n          siteId: this.filters.siteId,\n          name: subslug.value\n        }).subscribe(res => {\n          if (res) {\n            resolve({ repetition: this._LocalizationService.instant(`Cms::SectionName{0}AlreadyExist`, ctrl.value) });\n          } else {\n            resolve(null);\n          }\n        })\n      });\n    };\n  }\n  //定义异步验证方法\n  routeRepetitionAsyncValidator() {\n    return (ctrl: AbstractControl): Promise<ValidationErrors | null> | Observable<ValidationErrors | null> => {\n      return new Promise(resolve => {\n        let subslug = this.createOrEditForm?.get('route').value\n        if (subslug == this.selected?.route) {\n          resolve(null);\n          return\n        }\n        this._SectionAdminService.routeExists({\n          siteId: this.filters.siteId,\n          route: subslug\n        }).subscribe(res => {\n          if (res) {\n            resolve({ repetition: this._LocalizationService.instant(`Cms::SectionRoute{0}AlreadyExist`, ctrl.value) });\n          } else {\n            resolve(null);\n          }\n        })\n      });\n    };\n  }\n\n\n}\n","<abp-page [title]=\"'Cms::Sections' | abpLocalization\" [toolbar]=\"true\">\n    <div class=\"sections-page\">\n\n        <div class=\"card \">\n            <div class=\"card-body px-2 py-sm-2 border-bottom\">\n                <div class=\"input-group\">\n                    <select class=\"form-select col-auto\" [(ngModel)]=\"filters.siteId\" (change)=\"siteIdChange()\">\n                        <ng-container *ngFor=\"let item of siteList\">\n                            <option [value]=\"item.id\">{{item.displayName}}</option>\n                        </ng-container>\n                    </select>\n                    <input type=\"text\" class=\"form-control\" [(ngModel)]=\"filters.filter\"\n                        [placeholder]=\"'AbpUi::Search' | abpLocalization\" />\n                    <button class=\"btn btn-primary px-3\" type=\"button\" id=\"button-addon2\" (click)=\"list.get()\">\n                        <i class=\"fa fa-search\"></i>\n                    </button>\n                </div>\n            </div>\n        </div>\n        <div class=\"card mb-0\">\n            <div class=\"card-body p-0\">\n                <div class=\"table-responsive table-fixed-header\">\n                    <ngx-datatable class=\"material container-height\" [rows]=\"data.items\" [list]=\"list\"\n                        [columnMode]=\"'force'\" [headerHeight]=\"50\" [footerHeight]=\"50\" rowHeight=\"auto\"\n                        [scrollbarV]=\"true\" [virtualization]=\"false\" [externalPaging]=\"true\" [count]=\"data.totalCount\">\n                        <ngx-datatable-column [name]=\"'Cms::DisplayName' | abpLocalization\" prop=\"displayName\">\n                            <ng-template let-row=\"row\" let-value=\"value\" ngx-datatable-cell-template>\n                                {{ value }}\n                            </ng-template>\n                        </ngx-datatable-column>\n                        <ngx-datatable-column [name]=\"'Cms::Name' | abpLocalization\" prop=\"name\">\n                            <ng-template let-row=\"row\" let-value=\"value\" ngx-datatable-cell-template>\n                                {{ value }}\n                            </ng-template>\n                        </ngx-datatable-column>\n                        <ngx-datatable-column [name]=\"'Cms::SectionType' | abpLocalization\" prop=\"type\">\n                            <ng-template let-row=\"row\" let-value=\"value\" ngx-datatable-cell-template>\n                                {{('Cms::Enum:SectionType:'+_SectionType[value]) | abpLocalization}}\n                            </ng-template>\n                        </ngx-datatable-column>\n                        <ngx-datatable-column [name]=\"'Cms::Default' | abpLocalization\" prop=\"isDefault\">\n                            <ng-template let-row=\"row\" let-value=\"value\" ngx-datatable-cell-template>\n                                <i class=\"fas fa-check text-success\" *ngIf=\"value\"></i>\n                                <i class=\"fas fa-times text-danger\" *ngIf=\"!value\"></i>\n                            </ng-template>\n                        </ngx-datatable-column>\n                        <ngx-datatable-column [name]=\"'Cms::IsActive' | abpLocalization\" prop=\"isActive\">\n                            <ng-template let-row=\"row\" let-value=\"value\" ngx-datatable-cell-template>\n                                <i class=\"fas fa-check text-success\" *ngIf=\"value\"></i>\n                                <i class=\"fas fa-times text-danger\" *ngIf=\"!value\"></i>\n                            </ng-template>\n                        </ngx-datatable-column>\n                        <ngx-datatable-column [name]=\"'Cms::EntryType' | abpLocalization\" prop=\"SiteId\">\n                            <ng-template let-row=\"row\" let-value=\"value\" ngx-datatable-cell-template>\n                                <div ngbDropdown container=\"body\">\n                                    <button type=\"button\" class=\"btn btn-link\" ngbDropdownToggle id=\"dropdownBasic1\">\n                                        {{'Cms::EntryType' | abpLocalization}}\n                                    </button>\n                                    <div ngbDropdownMenu aria-labelledby=\"dropdownBasic1\">\n                                        <ng-container *ngFor=\"let item of row.entryTypes;let i =index\">\n                                            <li ngbDropdownItem\n                                                class=\"d-flex align-items-center justify-content-between\"\n                                                (click.stop)=\"jumpSectionsEdit(row,item)\">{{item.displayName}}\n                                                <button class=\"btn btn-light btn-sm p-0\"\n                                                    (click.stop)=\"deleteEntryType(item)\"><i class=\"fas fa-trash p-sm-1\"\n                                                        style=\"font-size: 12px;\" role=\"button\"></i></button>\n                                            </li>\n                                        </ng-container>\n                                        <li ngbDropdownItem (click.stop)=\"jumpSectionsCreate(row)\"><i\n                                                class=\"fas fa-plus-circle me-2\"></i>{{'Cms::New' |\n                                            abpLocalization}}</li>\n                                    </div>\n                                </div>\n\n                            </ng-template>\n                        </ngx-datatable-column>\n                        <ngx-datatable-column [name]=\"'Cms::CreationTime' | abpLocalization\" prop=\"creationTime\">\n                            <ng-template let-row=\"row\" let-value=\"value\" ngx-datatable-cell-template>\n                                {{ value | date : 'yyyy-MM-dd hh-mm-ss' }}\n                            </ng-template>\n                        </ngx-datatable-column>\n                        <ngx-datatable-column [sortable]=\"false\">\n                            <ng-template let-row=\"row\" let-value=\"value\" ngx-datatable-cell-template>\n                                <div ngbDropdown container=\"body\">\n                                    <button type=\"button\" class=\"btn btn-outline-primary btn-sm\" ngbDropdownToggle>\n                                        {{'AbpUi::Actions' | abpLocalization}}\n                                    </button>\n                                    <div ngbDropdownMenu>\n                                        <button ngbDropdownItem (click)=\"editSectionBtn(row)\">{{'AbpUi::Edit' |\n                                            abpLocalization}}</button>\n                                        <button ngbDropdownItem (click)=\"deletefield(row)\">{{'AbpUi::Delete' |\n                                            abpLocalization}}</button>\n                                    </div>\n                                </div>\n                            </ng-template>\n                        </ngx-datatable-column>\n                    </ngx-datatable>\n                </div>\n            </div>\n        </div>\n\n    </div>\n\n\n</abp-page>\n\n\n\n\n<abp-modal [(visible)]=\"visibleOpen\" [busy]=\"modalBusy\" (visibleChange)=\"VisibleChange($event)\">\n    <ng-template #abpHeader>\n        <h3>{{selected?('AbpUi::Edit' | abpLocalization):('Cms::New' | abpLocalization)}}</h3>\n    </ng-template>\n    <ng-template #abpBody>\n        <ng-template #loaderRef>\n            <div class=\"text-center\"><i class=\"fa fa-pulse fa-spinner\" aria-hidden=\"true\"></i></div>\n        </ng-template>\n        <ng-container *ngIf=\"createOrEditForm; else loaderRef\">\n            <form class=\"sites-modal-form\" [formGroup]=\"createOrEditForm\" (ngSubmit)=\"createOrEditSave()\">\n                <button type=\"submit\" #createOrEditModalSubmitBtn style=\"display: none\"></button>\n                <div class=\"mb-2\">\n                    <label class=\"form-label\">{{'Cms::EntryType' | abpLocalization}}</label>\n                    <div>\n                        <ng-container *ngFor=\"let item of _sectionTypeOptions;let i =index\">\n                            <div class=\"form-check form-check-inline\">\n                                <input class=\"form-check-input\" type=\"radio\" [value]=\"item.value\"\n                                    (change)=\"radiochange()\" formControlName=\"type\" id=\"flexRadioDefault{{i}}\">\n                                <label class=\"form-check-label\" for=\"flexRadioDefault{{i}}\">\n                                    {{ 'Cms::Enum:SectionType:'+item.key | abpLocalization }}\n                                </label>\n                            </div>\n                        </ng-container>\n                    </div>\n                </div>\n                <div class=\"mb-2\">\n                    <label class=\"form-label\">{{'Cms::DisplayName' | abpLocalization}}</label>\n                    <input type=\"text\" class=\"form-control\" formControlName=\"displayName\"\n                        (blur)=\"disPlayNameInputBlur($event)\" placeholder=\"\" />\n                </div>\n                <div class=\"mb-2\">\n                    <label class=\"form-label\">{{'Cms::Name' | abpLocalization}}</label>\n                    <input type=\"text\" class=\"form-control\" formControlName=\"name\" placeholder=\"\" />\n                    <div class=\"text-danger invalid-feedback\" *ngIf=\"nameInput.errors?.repetition\">\n                        {{nameInput.errors?.repetition}}\n                    </div>\n                </div>\n                <div class=\"mb-2\">\n                    <label class=\"form-label\">{{'Cms::Route' | abpLocalization}} </label>\n                    <input type=\"text\" class=\"form-control\" formControlName=\"route\" placeholder=\"\" />\n                    <div class=\"text-danger invalid-feedback\" *ngIf=\"routeInput.errors?.repetition\">\n                        {{routeInput.errors?.repetition}}\n                    </div>\n                    <div class=\"form-text\">\n                        {{'Cms::RouteTips' | abpLocalization}}<br>\n                        &nbsp;&nbsp;blog<br>\n                        &nbsp;&nbsp;{{'blog/{slug}'}}<br>\n                        &nbsp;&nbsp;{{'blog/{publishTime:yyyy}/{publishTime:MM}/{slug}'}}\n                    </div>\n                </div>\n                <div class=\"mb-2\">\n                    <label class=\"form-label\">{{'Cms::Template' | abpLocalization}} </label>\n                    <input type=\"text\" class=\"form-control\" formControlName=\"template\" placeholder=\"\" />\n                    <div class=\"form-text\">\n                        {{\"Cms::TemplateTips\" | abpLocalization}}\n                    </div>\n                </div>\n                <div class=\"mb-2\">\n                    <div class=\"form-check form-check-inline\">\n                        <input class=\"form-check-input\" type=\"checkbox\" value=\"true\" formControlName=\"isDefault\"\n                            id=\"isDefault\" />\n                        <label class=\"form-check-label\" for=\"isDefault\"> {{'Cms::Default' | abpLocalization}} </label>\n                    </div>\n                </div>\n                <div class=\"mb-2\">\n                    <div class=\"form-check form-check-inline\">\n                        <input class=\"form-check-input\" type=\"checkbox\" value=\"true\" formControlName=\"isActive\"\n                            id=\"isActive\" />\n                        <label class=\"form-check-label\" for=\"isActive\"> {{'Cms::IsActive' | abpLocalization}}</label>\n                    </div>\n                </div>\n\n            </form>\n        </ng-container>\n    </ng-template>\n    <ng-template #abpFooter>\n        <button type=\"button\" class=\"btn btn-secondary\" abpClose>{{'AbpUi::Close' | abpLocalization}}</button>\n        <!--  [disabled]=\"!this.createOrEditForm.valid\" -->\n        <abp-button iconClass=\"fa fa-check\" (click)=\"createOrEditModalSubmitBtn.nativeElement.click()\">{{'AbpUi::Save' |\n            abpLocalization}}</abp-button>\n    </ng-template>\n</abp-modal>"]}
|
|
334
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"sections.component.js","sourceRoot":"","sources":["../../../../../../../projects/cms/src/lib/components/admin/sections/sections.component.ts","../../../../../../../projects/cms/src/lib/components/admin/sections/sections.component.html"],"names":[],"mappings":"AAAA,OAAO,EAA2B,wBAAwB,EAAE,WAAW,EAAuC,MAAM,cAAc,CAAC;AAEnI,OAAO,EAAE,SAAS,EAAsB,SAAS,EAAE,MAAM,GAAG,MAAM,eAAe,CAAC;AAClF,OAAO,EAAgC,WAAW,EAA4C,UAAU,GAAG,MAAM,gBAAgB,CAAC;AAGlI,OAAO,EAAE,UAAU,EAAE,MAAM,yBAAyB,CAAC;AACrD,OAAO,EAAE,QAAQ,EAAE,MAAM,gBAAgB,CAAC;AAC1C,OAAO,EAAE,+BAA+B,EAAE,MAAM,wCAAwC,CAAC;AACzF,OAAO,EAAE,WAAW,EAAE,kBAAkB,EAAE,MAAM,yBAAyB,CAAC;AAC1E,OAAO,EAAE,qBAAqB,EAAE,MAAM,iCAAiC,CAAC;AACxE,OAAO,EAAE,aAAa,EAAE,MAAM,gBAAgB,CAAC;AAI/C,OAAO,EAAE,iBAAiB,EAAE,MAAM,uCAAuC,CAAC;;;;;;;;;;;;;;AAE1E,MAiBa,iBAAiB;IAEV;IACR;IACA;IACA;IACA;IACA;IACA;IACD;IACA;IACA;IACC;IAXV,YACkB,IAAiB,EACzB,oBAAyC,EACzC,iBAAmC,EACnC,OAAuB,EACvB,YAAiC,EACjC,EAAe,EACf,WAA+B,EAChC,sBAA6C,EAC7C,oBAAyC,EACzC,cAA6B,EAC5B,MAAc;QAVN,SAAI,GAAJ,IAAI,CAAa;QACzB,yBAAoB,GAApB,oBAAoB,CAAqB;QACzC,sBAAiB,GAAjB,iBAAiB,CAAkB;QACnC,YAAO,GAAP,OAAO,CAAgB;QACvB,iBAAY,GAAZ,YAAY,CAAqB;QACjC,OAAE,GAAF,EAAE,CAAa;QACf,gBAAW,GAAX,WAAW,CAAoB;QAChC,2BAAsB,GAAtB,sBAAsB,CAAuB;QAC7C,yBAAoB,GAApB,oBAAoB,CAAqB;QACzC,mBAAc,GAAd,cAAc,CAAe;QAC5B,WAAM,GAAN,MAAM,CAAQ;IAGxB,CAAC;IACO,kBAAkB,GAAC,MAAM,CAAC,iBAAiB,CAAC,CAAA;IAEpD,UAAU;IACV,gBAAgB,CAAC,GAAG,EAAE,IAAI;QACxB,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,uBAAuB,GAAG,CAAC,EAAE,gBAAgB,IAAI,CAAC,EAAE,OAAO,CAAC,EAAE,EACnF,CAAC,CAAA;IACJ,CAAC;IACD,UAAU;IACV,kBAAkB,CAAC,GAAG;QACpB,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,uBAAuB,GAAG,CAAC,EAAE,qBAAqB,CAAC,EAAE,EAC1E,CAAC,CAAA;IACJ,CAAC;IAGD,UAAU;IACV,QAAQ,GAAU,EAAE,CAAA;IACpB,OAAO;IACP,UAAU,GAAG,UAAU,CAAC;IACxB,IAAI,GAA+B;QACjC,KAAK,EAAE,EAAE;QACT,UAAU,EAAE,CAAC;KACd,CAAC;IACF,MAAM;IACN,OAAO,GAAG,EAAsB,CAAC;IACjC,YAAY;IACZ,WAAW;QACT,MAAM,OAAO,GAAG,CAAC,KAA0B,EAAE,EAAE,CAAC,IAAI,CAAC,oBAAoB,CAAC,OAAO,CAAC;YAChF,GAAG,KAAK;YACR,GAAG,IAAI,CAAC,OAAO;SAChB,CAAC,CAAC;QAEH,MAAM,OAAO,GAAG,CAAC,IAAgC,EAAE,EAAE,CAAC,CAAC,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,CAAC;QACzE,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC;IACpD,CAAC;IAED,KAAK,CAAC,QAAQ;QACZ,MAAM,IAAI,CAAC,WAAW,EAAE,CAAA;QACxB,IAAI,CAAC,WAAW,EAAE,CAAA;QAClB,IAAI,CAAC,kBAAkB,CAAC,eAAe,CAAC,SAAS,CAAC,GAAG,EAAE;YACrD,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,CAAA;QACjB,CAAC,CAAC,CAAC;IACL,CAAC;IAED,UAAU;IACV,YAAY;QACV,IAAI,CAAC,IAAI,CAAC,IAAI,GAAG,CAAC,CAAA;QAClB,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,CAAA;IACjB,CAAC;IAED,YAAY;IACZ,WAAW;QACT,OAAO,IAAI,OAAO,CAAC,CAAC,OAAO,EAAE,OAAO,EAAE,EAAE;YACtC,IAAI,CAAC,iBAAiB,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC,SAAS,CAAC,GAAG,CAAC,EAAE;gBACjD,IAAI,CAAC,QAAQ,GAAG,GAAG,CAAC,KAAK,CAAA;gBACzB,IAAI,CAAC,OAAO,CAAC,MAAM,GAAG,GAAG,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,EAAE,IAAI,EAAE,CAAA;gBAC5C,OAAO,CAAC,IAAI,CAAC,CAAA;gBACb,OAAO,CAAC,KAAK,CAAC,CAAA;YAEhB,CAAC,CAAC,CAAA;QACJ,CAAC,CAAC,CAAA;IAEJ,CAAC;IAED,eAAe;IACf,WAAW,GAAY,KAAK,CAAA;IAE5B,qBAAqB;IACrB,SAAS,GAAY,KAAK,CAAA;IAC1B,YAAY;IACZ,gBAAgB,CAAwB;IAExC,cAAc;IACd,QAAQ,CAAK;IAEb,YAAY,GAAG,WAAW,CAAA;IAC1B,mBAAmB,GAAG,kBAAkB,CAAA;IAExC,qBAAqB;IACuC,0BAA0B,CAAa;IAEnG,iBAAiB;IACjB,aAAa,CAAC,KAAK;QACjB,IAAI,CAAC,KAAK,EAAE;YACV,IAAI,CAAC,QAAQ,GAAG,EAAE,CAAA;YAClB,OAAM;SACP;IACH,CAAC;IACD,gBAAgB;IAChB,gBAAgB;QACd,IAAI,CAAC,WAAW,GAAG,IAAI,CAAA;QACvB,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC,EAAE,CAAC,KAAK,CAAC,IAAI,+BAA+B,EAAE,CAAC,CAAA;QAC5E,IAAI,CAAC,oBAAoB,EAAE,CAAA;IAC7B,CAAC;IACD,gBAAgB;IAChB,cAAc,CAAC,GAAG;QAChB,IAAI,CAAC,WAAW,GAAG,IAAI,CAAA;QACvB,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC,EAAE,CAAC,KAAK,CAAC,IAAI,+BAA+B,EAAE,CAAC,CAAA;QAC5E,IAAI,CAAC,oBAAoB,EAAE,CAAA;QAC3B,IAAI,CAAC,oBAAoB,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,SAAS,CAAC,GAAG,CAAC,EAAE;YACpD,IAAI,CAAC,gBAAgB,CAAC,UAAU,CAAC,GAAG,CAAC,CAAA;YACrC,IAAI,CAAC,QAAQ,GAAG,GAAG,CAAA;QACrB,CAAC,CAAC,CAAA;IACJ,CAAC;IACD,cAAc;IACd,eAAe,CAAC,GAAG;QACjB,IAAI,CAAC,YAAY,CAAC,IAAI,CACpB,GAAG,CAAC,WAAW,EACf,IAAI,CAAC,oBAAoB,CAAC,OAAO,CAAC,iCAAiC,CAAC,CACrE,CAAC,SAAS,CAAC,CAAC,MAA2B,EAAE,EAAE;YAC1C,IAAI,MAAM,IAAI,SAAS,EAAE;gBACvB,IAAI,CAAC,sBAAsB,CAAC,MAAM,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,GAAG,EAAE;gBAC9D,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,GAAG,CAAC,EAAE;oBAClB,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,IAAI,CAAC,oBAAoB,CAAC,OAAO,CAAC,4BAA4B,CAAC,CAAC,CAAC;oBACtF,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,CAAA;gBACjB,CAAC,CAAC,CAAA;aACH;QACH,CAAC,CAAC,CAAC;IAEL,CAAC;IAED,YAAY;IACZ,gBAAgB;QACd,IAAI,IAAI,CAAC,QAAQ,EAAE;YACjB,OAAO,IAAI,CAAC,QAAQ,EAAE,CAAA;SACvB;QACD,IAAI,CAAC,UAAU,EAAE,CAAA;IACnB,CAAC;IAED,MAAM;IACN,UAAU;QACR,IAAI,KAAK,GAAG,IAAI,CAAC,gBAAgB,CAAC,KAAK,CAAA;QACvC,KAAK,CAAC,MAAM,GAAG,IAAI,CAAC,OAAO,CAAC,MAAM,CAAA;QAClC,IAAI,CAAC,IAAI,CAAC,gBAAgB,CAAC,KAAK;YAAE,OAAM;QACxC,IAAI,CAAC,SAAS,GAAG,IAAI,CAAA;QACrB,IAAI,CAAC,oBAAoB,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,GAAG,EAAE;YACzD,IAAI,CAAC,SAAS,GAAG,KAAK,CAAA;YACtB,IAAI,CAAC,WAAW,GAAG,KAAK,CAAA;QAC1B,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,GAAG,CAAC,EAAE;YAClB,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,IAAI,CAAC,oBAAoB,CAAC,OAAO,CAAC,2BAA2B,CAAC,CAAC,CAAC;YACrF,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,CAAA;QACjB,CAAC,CAAC,CAAA;IACJ,CAAC;IACD,YAAY;IACZ,QAAQ;QACN,IAAI,KAAK,GAAG,IAAI,CAAC,gBAAgB,CAAC,KAAK,CAAA;QACvC,KAAK,CAAC,MAAM,GAAG,IAAI,CAAC,OAAO,CAAC,MAAM,CAAA;QAClC,KAAK,CAAC,gBAAgB,GAAG,IAAI,CAAC,QAAQ,CAAC,gBAAgB,CAAA;QACvD,IAAI,CAAC,IAAI,CAAC,gBAAgB,CAAC,KAAK;YAAE,OAAM;QACxC,IAAI,CAAC,SAAS,GAAG,IAAI,CAAA;QACrB,IAAI,CAAC,oBAAoB,CAAC,MAAM,CAAC,IAAI,CAAC,QAAQ,CAAC,EAAE,EAAE,KAAK,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,GAAG,EAAE;YAC3E,IAAI,CAAC,SAAS,GAAG,KAAK,CAAA;YACtB,IAAI,CAAC,WAAW,GAAG,KAAK,CAAA;QAC1B,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,GAAG,CAAC,EAAE;YAClB,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,IAAI,CAAC,oBAAoB,CAAC,OAAO,CAAC,2BAA2B,CAAC,CAAC,CAAC;YACrF,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,CAAA;QACjB,CAAC,CAAC,CAAA;IACJ,CAAC;IACD,UAAU;IACV,WAAW,CAAC,GAAG;QACb,IAAI,CAAC,YAAY,CAAC,IAAI,CACpB,GAAG,CAAC,WAAW,EACf,IAAI,CAAC,oBAAoB,CAAC,OAAO,CAAC,iCAAiC,CAAC,CACrE,CAAC,SAAS,CAAC,CAAC,MAA2B,EAAE,EAAE;YAC1C,IAAI,MAAM,IAAI,SAAS,EAAE;gBACvB,IAAI,CAAC,oBAAoB,CAAC,MAAM,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,GAAG,EAAE;gBAC5D,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,GAAG,CAAC,EAAE;oBAClB,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,IAAI,CAAC,oBAAoB,CAAC,OAAO,CAAC,4BAA4B,CAAC,CAAC,CAAC;oBACtF,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,CAAA;gBACjB,CAAC,CAAC,CAAA;aACH;QACH,CAAC,CAAC,CAAC;IACL,CAAC;IAID,cAAc;IACd,IAAI,gBAAgB;QAClB,OAAO,IAAI,CAAC,gBAAgB,CAAC,GAAG,CAAC,aAAa,CAAC,CAAA;IACjD,CAAC;IACD,cAAc;IACd,IAAI,SAAS;QACX,OAAO,IAAI,CAAC,gBAAgB,CAAC,GAAG,CAAC,MAAM,CAAC,CAAA;IAC1C,CAAC;IACD,eAAe;IACf,IAAI,UAAU;QACZ,OAAO,IAAI,CAAC,gBAAgB,CAAC,GAAG,CAAC,OAAO,CAAC,CAAA;IAC3C,CAAC;IACD,eAAe;IACf,IAAI,aAAa;QACf,OAAO,IAAI,CAAC,gBAAgB,CAAC,GAAG,CAAC,UAAU,CAAC,CAAA;IAC9C,CAAC;IACD,eAAe;IACf,IAAI,SAAS;QACX,OAAO,IAAI,CAAC,gBAAgB,CAAC,GAAG,CAAC,MAAM,CAAC,CAAA;IAC1C,CAAC;IAED,WAAW;QACT,IAAI,CAAC,UAAU,CAAC,UAAU,CAAC,IAAI,CAAC,UAAU,CAAC,KAAK,CAAC,CAAA;IACnD,CAAC;IAGD,yBAAyB;IACzB,oBAAoB,CAAC,KAAK;QACxB,IAAI,KAAK,GAAG,KAAK,CAAC,MAAM,CAAC,KAAK,CAAA;QAC9B,IAAI,MAAM,GAAG,IAAI,CAAC,cAAc,CAAC,eAAe,CAAC,KAAK,CAAC,CAAA;QACvD,IAAI,SAAS,GAAG,IAAI,CAAC,SAAS,CAAA;QAC9B,IAAI,UAAU,GAAG,IAAI,CAAC,UAAU,CAAA;QAChC,IAAI,aAAa,GAAG,IAAI,CAAC,aAAa,CAAA;QACtC,IAAI,SAAS,CAAC,KAAK;YAAE,OAAM;QAC3B,SAAS,CAAC,UAAU,CAAC,MAAM,CAAC,CAAA;QAC5B,IAAI,UAAU,CAAC,KAAK;YAAE,OAAM;QAC5B,UAAU,CAAC,UAAU,CAAC,MAAM,GAAG,CAAC,IAAI,CAAC,SAAS,CAAC,KAAK,KAAK,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAA;QAC7E,IAAI,aAAa,CAAC,KAAK;YAAE,OAAM;QAC/B,aAAa,CAAC,UAAU,CAAC,MAAM,GAAG,QAAQ,CAAC,CAAA;IAC7C,CAAC;IAID,gBAAgB;IAChB,oBAAoB;QAClB,IAAI,CAAC,gBAAgB,CAAC,UAAU,CAAC,MAAM,EAAE,IAAI,WAAW,CAAC,IAAI,CAAC,SAAS,CAAC,KAAK,IAAI,EAAE,EAAE;YACnF,UAAU,EAAE,UAAU,CAAC,QAAQ;YAC/B,eAAe,EAAE,IAAI,CAAC,4BAA4B,EAAE;SACrD,CAAC,CAAC,CAAA;QACH,IAAI,CAAC,gBAAgB,CAAC,UAAU,CAAC,OAAO,EAAE,IAAI,WAAW,CAAC,IAAI,CAAC,UAAU,CAAC,KAAK,IAAI,EAAE,EAAE;YACrF,UAAU,EAAE,CAAC,UAAU,CAAC,QAAQ,EAAE,IAAI,CAAC,sBAAsB,EAAE,CAAC;YAChE,eAAe,EAAE,CAAC,IAAI,CAAC,6BAA6B,EAAE,CAAC;SACxD,CAAC,CAAC,CAAA;IACL,CAAC;IACD,sBAAsB;QACpB,OAAO,CAAC,OAAwB,EAA2B,EAAE;YAC3D,IAAI,UAAU,GAAG,OAAO,CAAC,KAAK,CAAC,iBAAiB,EAAE,CAAA;YAClD,IAAI,SAAS,GAAG,IAAI,CAAC,SAAS,CAAC,KAAK,IAAI,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,UAAU,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,CAAA;YAChG,OAAO,SAAS,CAAC,CAAC,CAAC,EAAE,UAAU,EAAE,IAAI,CAAC,oBAAoB,CAAC,OAAO,CAAC,4BAA4B,EAAE,IAAI,CAAC,oBAAoB,CAAC,OAAO,CAAC,wBAAwB,GAAG,WAAW,CAAC,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,EAAE,QAAQ,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC;QACvN,CAAC,CAAC;IACJ,CAAC;IAED,cAAc;IACd,4BAA4B;QAC1B,OAAO,CAAC,IAAqB,EAA0E,EAAE;YACvG,OAAO,IAAI,OAAO,CAAC,OAAO,CAAC,EAAE;gBAC3B,IAAI,OAAO,GAAG,IAAI,CAAC,gBAAgB,EAAE,GAAG,CAAC,MAAM,CAAC,CAAA;gBAChD,IAAI,OAAO,CAAC,KAAK,IAAI,IAAI,CAAC,QAAQ,EAAE,IAAI,EAAE;oBACxC,OAAO,CAAC,IAAI,CAAC,CAAC;oBACd,OAAM;iBACP;gBACD,IAAI,CAAC,oBAAoB,CAAC,UAAU,CAAC;oBACnC,MAAM,EAAE,IAAI,CAAC,OAAO,CAAC,MAAM;oBAC3B,IAAI,EAAE,OAAO,CAAC,KAAK;iBACpB,CAAC,CAAC,SAAS,CAAC,GAAG,CAAC,EAAE;oBACjB,IAAI,GAAG,EAAE;wBACP,OAAO,CAAC,EAAE,UAAU,EAAE,IAAI,CAAC,oBAAoB,CAAC,OAAO,CAAC,iCAAiC,EAAE,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC;qBAC3G;yBAAM;wBACL,OAAO,CAAC,IAAI,CAAC,CAAC;qBACf;gBACH,CAAC,CAAC,CAAA;YACJ,CAAC,CAAC,CAAC;QACL,CAAC,CAAC;IACJ,CAAC;IACD,cAAc;IACd,6BAA6B;QAC3B,OAAO,CAAC,IAAqB,EAA0E,EAAE;YACvG,OAAO,IAAI,OAAO,CAAC,OAAO,CAAC,EAAE;gBAC3B,IAAI,OAAO,GAAG,IAAI,CAAC,gBAAgB,EAAE,GAAG,CAAC,OAAO,CAAC,CAAC,KAAK,CAAA;gBACvD,IAAI,OAAO,IAAI,IAAI,CAAC,QAAQ,EAAE,KAAK,EAAE;oBACnC,OAAO,CAAC,IAAI,CAAC,CAAC;oBACd,OAAM;iBACP;gBACD,IAAI,CAAC,oBAAoB,CAAC,WAAW,CAAC;oBACpC,MAAM,EAAE,IAAI,CAAC,OAAO,CAAC,MAAM;oBAC3B,KAAK,EAAE,OAAO;iBACf,CAAC,CAAC,SAAS,CAAC,GAAG,CAAC,EAAE;oBACjB,IAAI,GAAG,EAAE;wBACP,OAAO,CAAC,EAAE,UAAU,EAAE,IAAI,CAAC,oBAAoB,CAAC,OAAO,CAAC,kCAAkC,EAAE,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC;qBAC5G;yBAAM;wBACL,OAAO,CAAC,IAAI,CAAC,CAAC;qBACf;gBACH,CAAC,CAAC,CAAA;YACJ,CAAC,CAAC,CAAC;QACL,CAAC,CAAC;IACJ,CAAC;wGAxSU,iBAAiB;4FAAjB,iBAAiB,uCAbjB;YACT,aAAa;YACb,WAAW;YACX,aAAa;YACb,4DAA4D;YAC5D,uEAAuE;YACvE,EAAE,OAAO,EAAE,wBAAwB,EAAE,QAAQ,EAAE,GAAG,EAAE;YACpD;gBACE,OAAO,EAAE,qBAAqB;gBAC9B,QAAQ,EAAE,aAAa,CAAC,QAAQ;aACjC;SACF,oKChCH,m+XA8LY;;SD5JC,iBAAiB;4FAAjB,iBAAiB;kBAjB7B,SAAS;+BACE,cAAc,aAGb;wBACT,aAAa;wBACb,WAAW;wBACX,aAAa;wBACb,4DAA4D;wBAC5D,uEAAuE;wBACvE,EAAE,OAAO,EAAE,wBAAwB,EAAE,QAAQ,EAAE,GAAG,EAAE;wBACpD;4BACE,OAAO,EAAE,qBAAqB;4BAC9B,QAAQ,EAAE,aAAa,CAAC,QAAQ;yBACjC;qBACF;oZAgG2D,0BAA0B;sBAArF,SAAS;uBAAC,4BAA4B,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE","sourcesContent":["import { ABP, ConfigStateService, LIST_QUERY_DEBOUNCE_TIME, ListService, LocalizationService, PagedResultDto } from '@abp/ng.core';\nimport { ToasterService, ConfirmationService, Confirmation, } from '@abp/ng.theme.shared';\nimport { Component, ElementRef, OnInit, ViewChild, inject, } from '@angular/core';\nimport { AbstractControl, FormBuilder, FormControl, FormGroup, ValidationErrors, ValidatorFn, Validators, } from '@angular/forms';\nimport { EntryTypeAdminService, GetSectionsInput, SectionAdminService, SectionDto } from '../../../proxy/admin/sections';\nimport { SiteAdminService } from '../../../proxy/admin/sites';\nimport { ColumnMode } from \"@swimlane/ngx-datatable\";\nimport { finalize } from 'rxjs/operators';\nimport { CreateOrUpdateSectionsInputBase } from './create-or-update-sections-input-base';\nimport { SectionType, sectionTypeOptions } from '../../../proxy/sections';\nimport { EXTENSIONS_IDENTIFIER } from '@abp/ng.theme.shared/extensions';\nimport { ECmsComponent } from '../../../enums';\nimport { CmsApiService } from '../../../services/cms-api.service';\nimport { Observable } from 'rxjs';\nimport { Router } from '@angular/router';\nimport { UpdateListService } from '../../../services/update-list.service';\n\n@Component({\n  selector: 'cms-sections',\n  templateUrl: './sections.component.html',\n  styleUrls: ['./sections.component.scss'],\n  providers: [\n    // [Required]\n    ListService,\n    // [Optional]\n    // Provide this token if you want a different debounce time.\n    // Default is 300. Cannot be 0. Any value below 100 is not recommended.\n    { provide: LIST_QUERY_DEBOUNCE_TIME, useValue: 500 },\n    {\n      provide: EXTENSIONS_IDENTIFIER,\n      useValue: ECmsComponent.Sections,\n    },\n  ]\n})\nexport class SectionsComponent implements OnInit {\n  constructor(\n    public readonly list: ListService,\n    private _SectionAdminService: SectionAdminService,\n    private _SiteAdminService: SiteAdminService,\n    private toaster: ToasterService,\n    private confirmation: ConfirmationService,\n    private fb: FormBuilder,\n    private configState: ConfigStateService,\n    public _EntryTypeAdminService: EntryTypeAdminService,\n    public _LocalizationService: LocalizationService,\n    public _CmsApiService: CmsApiService,\n    private router: Router,\n  ) {\n\n  }\n  private _UpdateListService=inject(UpdateListService)\n\n  /**跳转编辑 */\n  jumpSectionsEdit(row, item) {\n    this.router.navigate([`/cms/admin/sections/${row.id}/entry-types/${item.id}/edit`], {\n    })\n  }\n  /**跳转新建 */\n  jumpSectionsCreate(row) {\n    this.router.navigate([`/cms/admin/sections/${row.id}/entry-types/create`], {\n    })\n  }\n\n\n  /**版块列表 */\n  siteList: any[] = []\n  /*** */\n  ColumnMode = ColumnMode;\n  data: PagedResultDto<SectionDto> = {\n    items: [],\n    totalCount: 0,\n  };\n  /** */\n  filters = {} as GetSectionsInput;\n  /**获取页面列表 */\n  hookToQuery() {\n    const getData = (query: ABP.PageQueryParams) => this._SectionAdminService.getList({\n      ...query,\n      ...this.filters,\n    });\n\n    const setData = (list: PagedResultDto<SectionDto>) => (this.data = list);\n    this.list.hookToQuery(getData).subscribe(setData);\n  }\n\n  async ngOnInit(): Promise<void> {\n    await this.getSiteList()\n    this.hookToQuery()\n    this._UpdateListService.updateListEvent.subscribe(() => {\n      this.list.get()\n    });\n  }\n\n  /**站点切换 */\n  siteIdChange() {\n    this.list.page = 0\n    this.list.get()\n  }\n\n  /**获取版块列表 */\n  getSiteList() {\n    return new Promise((resolve, rejects) => {\n      this._SiteAdminService.getList({}).subscribe(res => {\n        this.siteList = res.items\n        this.filters.siteId = res.items[0]?.id || ''\n        resolve(true)\n        rejects(false)\n\n      })\n    })\n\n  }\n\n  /**创建版块模态框状态 */\n  visibleOpen: boolean = false\n\n  /**用于确定模态的繁忙状态是否为真 */\n  modalBusy: boolean = false\n  /**创建版块表单 */\n  createOrEditForm: FormGroup | undefined;\n\n  /**版块给定的表单值 */\n  selected: any\n\n  _SectionType = SectionType\n  _sectionTypeOptions = sectionTypeOptions\n\n  /**表单控件模板-动态赋值表单控件 */\n  @ViewChild('createOrEditModalSubmitBtn', { static: false }) createOrEditModalSubmitBtn: ElementRef;\n\n  /**创建版块模态框状态改变 */\n  VisibleChange(event) {\n    if (!event) {\n      this.selected = ''\n      return\n    }\n  }\n  /**创建版块，打开模态框 */\n  createSectionBtn() {\n    this.visibleOpen = true\n    this.createOrEditForm = this.fb.group(new CreateOrUpdateSectionsInputBase())\n    this.setAsyncValidatorsFn()\n  }\n  /**编辑版块，打开模态框 */\n  editSectionBtn(row) {\n    this.visibleOpen = true\n    this.createOrEditForm = this.fb.group(new CreateOrUpdateSectionsInputBase())\n    this.setAsyncValidatorsFn()\n    this._SectionAdminService.get(row.id).subscribe(res => {\n      this.createOrEditForm.patchValue(res)\n      this.selected = res\n    })\n  }\n  /**删除某个条目类型 */\n  deleteEntryType(row) {\n    this.confirmation.warn(\n      row.displayName,\n      this._LocalizationService.instant(`AbpUi::ItemWillBeDeletedMessage`),\n    ).subscribe((status: Confirmation.Status) => {\n      if (status == 'confirm') {\n        this._EntryTypeAdminService.delete(row.id).pipe(finalize(() => {\n        })).subscribe(res => {\n          this.toaster.success(this._LocalizationService.instant(`AbpUi::SuccessfullyDeleted`));\n          this.list.get()\n        })\n      }\n    });\n\n  }\n\n  /**表单保存提交 */\n  createOrEditSave() {\n    if (this.selected) {\n      return this.EditSave()\n    }\n    this.createSave()\n  }\n\n  /** */\n  createSave() {\n    let input = this.createOrEditForm.value\n    input.siteId = this.filters.siteId\n    if (!this.createOrEditForm.valid) return\n    this.modalBusy = true\n    this._SectionAdminService.create(input).pipe(finalize(() => {\n      this.modalBusy = false\n      this.visibleOpen = false\n    })).subscribe(res => {\n      this.toaster.success(this._LocalizationService.instant(`CmsKit::SavedSuccessfully`));\n      this.list.get()\n    })\n  }\n  /**创建版块保存 */\n  EditSave() {\n    let input = this.createOrEditForm.value\n    input.siteId = this.filters.siteId\n    input.concurrencyStamp = this.selected.concurrencyStamp\n    if (!this.createOrEditForm.valid) return\n    this.modalBusy = true\n    this._SectionAdminService.update(this.selected.id, input).pipe(finalize(() => {\n      this.modalBusy = false\n      this.visibleOpen = false\n    })).subscribe(res => {\n      this.toaster.success(this._LocalizationService.instant(`CmsKit::SavedSuccessfully`));\n      this.list.get()\n    })\n  }\n  /**删除版块 */\n  deletefield(row) {\n    this.confirmation.warn(\n      row.displayName,\n      this._LocalizationService.instant(`AbpUi::ItemWillBeDeletedMessage`),\n    ).subscribe((status: Confirmation.Status) => {\n      if (status == 'confirm') {\n        this._SectionAdminService.delete(row.id).pipe(finalize(() => {\n        })).subscribe(res => {\n          this.toaster.success(this._LocalizationService.instant(`AbpUi::SuccessfullyDeleted`));\n          this.list.get()\n        })\n      }\n    });\n  }\n\n\n\n  /**name表单控件 */\n  get displayNameInput() {\n    return this.createOrEditForm.get('displayName')\n  }\n  /**name表单控件 */\n  get nameInput() {\n    return this.createOrEditForm.get('name')\n  }\n  /**route表单控件 */\n  get routeInput() {\n    return this.createOrEditForm.get('route')\n  }\n  /**route表单控件 */\n  get templateInput() {\n    return this.createOrEditForm.get('template')\n  }\n  /**route表单控件 */\n  get typeInput() {\n    return this.createOrEditForm.get('type')\n  }\n\n  radiochange() {\n    this.routeInput.patchValue(this.routeInput.value)\n  }\n\n\n  /**字段标签input失去标点生成字段名字 */\n  disPlayNameInputBlur(event) {\n    let value = event.target.value\n    let pinyin = this._CmsApiService.chineseToPinyin(value)\n    let nameInput = this.nameInput\n    let routeInput = this.routeInput\n    let templateInput = this.templateInput\n    if (nameInput.value) return\n    nameInput.patchValue(pinyin)\n    if (routeInput.value) return\n    routeInput.patchValue(pinyin + (this.typeInput.value === 0 ? '' : '/{slug}'))\n    if (templateInput.value) return\n    templateInput.patchValue(pinyin + '/index')\n  }\n\n\n\n  /**设置字段控件异步验证 */\n  setAsyncValidatorsFn() {\n    this.createOrEditForm.setControl('name', new FormControl(this.nameInput.value || '', {\n      validators: Validators.required,\n      asyncValidators: this.nameRepetitionAsyncValidator(),\n    }))\n    this.createOrEditForm.setControl('route', new FormControl(this.routeInput.value || '', {\n      validators: [Validators.required, this.forbiddenNameValidator()],\n      asyncValidators: [this.routeRepetitionAsyncValidator()],\n    }))\n  }\n  forbiddenNameValidator(): ValidatorFn {\n    return (control: AbstractControl): ValidationErrors | null => {\n      let inputValue = control.value.toLocaleLowerCase()\n      let forbidden = this.typeInput.value == 0 ? false : inputValue.includes('{slug}') ? false : true\n      return forbidden ? { repetition: this._LocalizationService.instant(`Cms::RouteVerificationTips`, this._LocalizationService.instant(`Cms::Enum:SectionType:` + SectionType[this.typeInput.value]), '{slug}') } : null;\n    };\n  }\n\n  /**定义异步验证方法 */\n  nameRepetitionAsyncValidator() {\n    return (ctrl: AbstractControl): Promise<ValidationErrors | null> | Observable<ValidationErrors | null> => {\n      return new Promise(resolve => {\n        let subslug = this.createOrEditForm?.get('name')\n        if (subslug.value == this.selected?.name) {\n          resolve(null);\n          return\n        }\n        this._SectionAdminService.nameExists({\n          siteId: this.filters.siteId,\n          name: subslug.value\n        }).subscribe(res => {\n          if (res) {\n            resolve({ repetition: this._LocalizationService.instant(`Cms::SectionName{0}AlreadyExist`, ctrl.value) });\n          } else {\n            resolve(null);\n          }\n        })\n      });\n    };\n  }\n  /**定义异步验证方法 */\n  routeRepetitionAsyncValidator() {\n    return (ctrl: AbstractControl): Promise<ValidationErrors | null> | Observable<ValidationErrors | null> => {\n      return new Promise(resolve => {\n        let subslug = this.createOrEditForm?.get('route').value\n        if (subslug == this.selected?.route) {\n          resolve(null);\n          return\n        }\n        this._SectionAdminService.routeExists({\n          siteId: this.filters.siteId,\n          route: subslug\n        }).subscribe(res => {\n          if (res) {\n            resolve({ repetition: this._LocalizationService.instant(`Cms::SectionRoute{0}AlreadyExist`, ctrl.value) });\n          } else {\n            resolve(null);\n          }\n        })\n      });\n    };\n  }\n\n\n}\n","<abp-page [title]=\"'Cms::Sections' | abpLocalization\" [toolbar]=\"true\">\n    <div class=\"sections-page\">\n\n        <div class=\"card \">\n            <div class=\"card-body px-2 py-sm-2 border-bottom\">\n                <div class=\"input-group\">\n                    <select class=\"form-select col-auto\" [(ngModel)]=\"filters.siteId\" (change)=\"siteIdChange()\">\n                        <ng-container *ngFor=\"let item of siteList\">\n                            <option [value]=\"item.id\">{{item.displayName}}</option>\n                        </ng-container>\n                    </select>\n                    <input type=\"text\" class=\"form-control\" [(ngModel)]=\"filters.filter\"\n                        [placeholder]=\"'AbpUi::Search' | abpLocalization\" />\n                    <button class=\"btn btn-primary px-3\" type=\"button\" id=\"button-addon2\" (click)=\"list.get()\">\n                        <i class=\"fa fa-search\"></i>\n                    </button>\n                </div>\n            </div>\n        </div>\n        <div class=\"card mb-0\">\n            <div class=\"card-body p-0\">\n                <div class=\"table-responsive table-fixed-header\">\n                    <ngx-datatable class=\"material container-height\" [rows]=\"data.items\" [list]=\"list\"\n                        [columnMode]=\"'force'\" [headerHeight]=\"50\" [footerHeight]=\"50\" rowHeight=\"auto\"\n                        [scrollbarV]=\"true\" [virtualization]=\"false\" [externalPaging]=\"true\" [count]=\"data.totalCount\">\n                        <ngx-datatable-column [name]=\"'Cms::DisplayName' | abpLocalization\" prop=\"displayName\">\n                            <ng-template let-row=\"row\" let-value=\"value\" ngx-datatable-cell-template>\n                                {{ value }}\n                            </ng-template>\n                        </ngx-datatable-column>\n                        <ngx-datatable-column [name]=\"'Cms::Name' | abpLocalization\" prop=\"name\">\n                            <ng-template let-row=\"row\" let-value=\"value\" ngx-datatable-cell-template>\n                                {{ value }}\n                            </ng-template>\n                        </ngx-datatable-column>\n                        <ngx-datatable-column [name]=\"'Cms::SectionType' | abpLocalization\" prop=\"type\">\n                            <ng-template let-row=\"row\" let-value=\"value\" ngx-datatable-cell-template>\n                                {{('Cms::Enum:SectionType:'+_SectionType[value]) | abpLocalization}}\n                            </ng-template>\n                        </ngx-datatable-column>\n                        <ngx-datatable-column [name]=\"'Cms::Default' | abpLocalization\" prop=\"isDefault\">\n                            <ng-template let-row=\"row\" let-value=\"value\" ngx-datatable-cell-template>\n                                <i class=\"fas fa-check text-success\" *ngIf=\"value\"></i>\n                                <i class=\"fas fa-times text-danger\" *ngIf=\"!value\"></i>\n                            </ng-template>\n                        </ngx-datatable-column>\n                        <ngx-datatable-column [name]=\"'Cms::IsActive' | abpLocalization\" prop=\"isActive\">\n                            <ng-template let-row=\"row\" let-value=\"value\" ngx-datatable-cell-template>\n                                <i class=\"fas fa-check text-success\" *ngIf=\"value\"></i>\n                                <i class=\"fas fa-times text-danger\" *ngIf=\"!value\"></i>\n                            </ng-template>\n                        </ngx-datatable-column>\n                        <ngx-datatable-column [name]=\"'Cms::EntryType' | abpLocalization\" prop=\"SiteId\">\n                            <ng-template let-row=\"row\" let-value=\"value\" ngx-datatable-cell-template>\n                                <div ngbDropdown container=\"body\">\n                                    <button type=\"button\" class=\"btn btn-link\" ngbDropdownToggle id=\"dropdownBasic1\">\n                                        {{'Cms::EntryType' | abpLocalization}}\n                                    </button>\n                                    <div ngbDropdownMenu aria-labelledby=\"dropdownBasic1\">\n                                        <ng-container *ngFor=\"let item of row.entryTypes;let i =index\">\n                                            <li ngbDropdownItem\n                                                class=\"d-flex align-items-center justify-content-between\"\n                                                (click.stop)=\"jumpSectionsEdit(row,item)\">{{item.displayName}}\n                                                <button class=\"btn btn-light btn-sm p-0\"\n                                                    (click.stop)=\"deleteEntryType(item)\"><i class=\"fas fa-trash p-sm-1\"\n                                                        style=\"font-size: 12px;\" role=\"button\"></i></button>\n                                            </li>\n                                        </ng-container>\n                                        <li ngbDropdownItem (click.stop)=\"jumpSectionsCreate(row)\"><i\n                                                class=\"fas fa-plus-circle me-2\"></i>{{'Cms::New' |\n                                            abpLocalization}}</li>\n                                    </div>\n                                </div>\n\n                            </ng-template>\n                        </ngx-datatable-column>\n                        <ngx-datatable-column [name]=\"'Cms::CreationTime' | abpLocalization\" prop=\"creationTime\">\n                            <ng-template let-row=\"row\" let-value=\"value\" ngx-datatable-cell-template>\n                                {{ value | date : 'yyyy-MM-dd hh-mm-ss' }}\n                            </ng-template>\n                        </ngx-datatable-column>\n                        <ngx-datatable-column [sortable]=\"false\">\n                            <ng-template let-row=\"row\" let-value=\"value\" ngx-datatable-cell-template>\n                                <div ngbDropdown container=\"body\">\n                                    <button type=\"button\" class=\"btn btn-outline-primary btn-sm\" ngbDropdownToggle>\n                                        {{'AbpUi::Actions' | abpLocalization}}\n                                    </button>\n                                    <div ngbDropdownMenu>\n                                        <button ngbDropdownItem (click)=\"editSectionBtn(row)\">{{'AbpUi::Edit' |\n                                            abpLocalization}}</button>\n                                        <button ngbDropdownItem (click)=\"deletefield(row)\">{{'AbpUi::Delete' |\n                                            abpLocalization}}</button>\n                                    </div>\n                                </div>\n                            </ng-template>\n                        </ngx-datatable-column>\n                    </ngx-datatable>\n                </div>\n            </div>\n        </div>\n\n    </div>\n\n\n</abp-page>\n\n\n\n\n<abp-modal [(visible)]=\"visibleOpen\" [busy]=\"modalBusy\" (visibleChange)=\"VisibleChange($event)\">\n    <ng-template #abpHeader>\n        <h3>{{selected?('AbpUi::Edit' | abpLocalization):('Cms::New' | abpLocalization)}}</h3>\n    </ng-template>\n    <ng-template #abpBody>\n        <ng-template #loaderRef>\n            <div class=\"text-center\"><i class=\"fa fa-pulse fa-spinner\" aria-hidden=\"true\"></i></div>\n        </ng-template>\n        <ng-container *ngIf=\"createOrEditForm; else loaderRef\">\n            <form class=\"sites-modal-form\" [formGroup]=\"createOrEditForm\" (ngSubmit)=\"createOrEditSave()\">\n                <button type=\"submit\" #createOrEditModalSubmitBtn style=\"display: none\"></button>\n                <div class=\"mb-2\">\n                    <label class=\"form-label\">{{'Cms::EntryType' | abpLocalization}}</label>\n                    <div>\n                        <ng-container *ngFor=\"let item of _sectionTypeOptions;let i =index\">\n                            <div class=\"form-check form-check-inline\">\n                                <input class=\"form-check-input\" type=\"radio\" [value]=\"item.value\"\n                                    (change)=\"radiochange()\" formControlName=\"type\" id=\"flexRadioDefault{{i}}\">\n                                <label class=\"form-check-label\" for=\"flexRadioDefault{{i}}\">\n                                    {{ 'Cms::Enum:SectionType:'+item.key | abpLocalization }}\n                                </label>\n                            </div>\n                        </ng-container>\n                    </div>\n                </div>\n                <div class=\"mb-2\">\n                    <label class=\"form-label\">{{'Cms::DisplayName' | abpLocalization}}</label>\n                    <input type=\"text\" class=\"form-control\" formControlName=\"displayName\"\n                        (blur)=\"disPlayNameInputBlur($event)\" placeholder=\"\" />\n                </div>\n                <div class=\"mb-2\">\n                    <label class=\"form-label\">{{'Cms::Name' | abpLocalization}}</label>\n                    <input type=\"text\" class=\"form-control\" formControlName=\"name\" placeholder=\"\" />\n                    <div class=\"text-danger invalid-feedback\" *ngIf=\"nameInput.errors?.repetition\">\n                        {{nameInput.errors?.repetition}}\n                    </div>\n                </div>\n                <div class=\"mb-2\">\n                    <label class=\"form-label\">{{'Cms::Route' | abpLocalization}} </label>\n                    <input type=\"text\" class=\"form-control\" formControlName=\"route\" placeholder=\"\" />\n                    <div class=\"text-danger invalid-feedback\" *ngIf=\"routeInput.errors?.repetition\">\n                        {{routeInput.errors?.repetition}}\n                    </div>\n                    <div class=\"form-text\">\n                        {{'Cms::RouteTips' | abpLocalization}}<br>\n                        &nbsp;&nbsp;blog<br>\n                        &nbsp;&nbsp;{{'blog/{slug}'}}<br>\n                        &nbsp;&nbsp;{{'blog/{publishTime:yyyy}/{publishTime:MM}/{slug}'}}\n                    </div>\n                </div>\n                <div class=\"mb-2\">\n                    <label class=\"form-label\">{{'Cms::Template' | abpLocalization}} </label>\n                    <input type=\"text\" class=\"form-control\" formControlName=\"template\" placeholder=\"\" />\n                    <div class=\"form-text\">\n                        {{\"Cms::TemplateTips\" | abpLocalization}}\n                    </div>\n                </div>\n                <div class=\"mb-2\">\n                    <div class=\"form-check form-check-inline\">\n                        <input class=\"form-check-input\" type=\"checkbox\" value=\"true\" formControlName=\"isDefault\"\n                            id=\"isDefault\" />\n                        <label class=\"form-check-label\" for=\"isDefault\"> {{'Cms::Default' | abpLocalization}} </label>\n                    </div>\n                </div>\n                <div class=\"mb-2\">\n                    <div class=\"form-check form-check-inline\">\n                        <input class=\"form-check-input\" type=\"checkbox\" value=\"true\" formControlName=\"isActive\"\n                            id=\"isActive\" />\n                        <label class=\"form-check-label\" for=\"isActive\"> {{'Cms::IsActive' | abpLocalization}}</label>\n                    </div>\n                </div>\n\n            </form>\n        </ng-container>\n    </ng-template>\n    <ng-template #abpFooter>\n        <button type=\"button\" class=\"btn btn-secondary\" abpClose>{{'AbpUi::Close' | abpLocalization}}</button>\n        <!--  [disabled]=\"!this.createOrEditForm.valid\" -->\n        <abp-button iconClass=\"fa fa-check\" (click)=\"createOrEditModalSubmitBtn.nativeElement.click()\">{{'AbpUi::Save' |\n            abpLocalization}}</abp-button>\n    </ng-template>\n</abp-modal>"]}
|
|
@@ -23,19 +23,21 @@ class EntryConfigComponent {
|
|
|
23
23
|
if (v == this._type)
|
|
24
24
|
return;
|
|
25
25
|
this._type = v;
|
|
26
|
-
// if (v) this.dataLoaded(1)
|
|
27
26
|
}
|
|
28
27
|
/**表单实体 */
|
|
29
28
|
_Entity;
|
|
30
29
|
set Entity(v) {
|
|
31
30
|
this._Entity = v;
|
|
32
|
-
// if (v) this.dataLoaded(2)
|
|
33
31
|
}
|
|
34
32
|
/**选择的表单信息 */
|
|
35
33
|
_selected;
|
|
36
34
|
set selected(v) {
|
|
37
35
|
this._selected = v;
|
|
38
|
-
|
|
36
|
+
}
|
|
37
|
+
/**语言 */
|
|
38
|
+
_culture;
|
|
39
|
+
set culture(v) {
|
|
40
|
+
this._culture = v;
|
|
39
41
|
}
|
|
40
42
|
get formConfiguration() {
|
|
41
43
|
return this._Entity.get('formConfiguration');
|
|
@@ -93,8 +95,6 @@ class EntryConfigComponent {
|
|
|
93
95
|
this.formConfiguration.patchValue({
|
|
94
96
|
'Entry.SectionId': res.items[0]?.id || ''
|
|
95
97
|
});
|
|
96
|
-
// this.filters.sectionId = res.items[0]?.id || ''
|
|
97
|
-
// this.getSectionOfEntryType()
|
|
98
98
|
resolve(res.items);
|
|
99
99
|
});
|
|
100
100
|
});
|
|
@@ -104,7 +104,7 @@ class EntryConfigComponent {
|
|
|
104
104
|
await this.getSiteOfSectionList();
|
|
105
105
|
}
|
|
106
106
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: EntryConfigComponent, deps: [{ token: i1.FormBuilder }, { token: i2.SiteAdminService }, { token: i3.SectionAdminService }], target: i0.ɵɵFactoryTarget.Component });
|
|
107
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: EntryConfigComponent, selector: "cms-entry-config", inputs: { type: "type", Entity: "Entity", selected: "selected" }, viewQueries: [{ propertyName: "submitclick", first: true, predicate: ["submitclick"], descendants: true, static: true }], ngImport: i0, template: "<div class=\"mb-2\">\n <label class=\"form-label\">{{'Cms::Sites' | abpLocalization}}</label>\n <select class=\"form-select col-auto\" [(ngModel)]=\"siteId\" (change)=\"siteIdChange()\">\n <ng-container *ngFor=\"let item of siteList\">\n <option [value]=\"item.id\">{{item.displayName}}</option>\n </ng-container>\n </select>\n</div>\n<form [formGroup]=\"_Entity\">\n <div formGroupName=\"formConfiguration\">\n \n <div class=\"mb-2\">\n <label class=\"form-label\">{{'Cms::Sections' | abpLocalization}}</label>\n <select class=\"form-select col-auto\" formControlName=\"Entry.SectionId\">\n <ng-container *ngFor=\"let item of SiteOfSectionList\">\n <option [value]=\"item.id\">{{item.displayName}}</option>\n </ng-container>\n </select>\n </div>\n\n <div class=\"mb-2\">\n <div class=\"form-check form-check-inline\">\n <input class=\"form-check-input\" type=\"checkbox\" formControlName=\"Entry.Multiple\" id=\"Multiple\">\n <label class=\"form-check-label\" for=\"Multiple\">\n {{'Cms::Multiple' | abpLocalization}}\n </label>\n </div>\n </div>\n <div class=\"mb-2\">\n <label class=\"form-label\">{{'Cms::Placeholder' | abpLocalization}}</label>\n <input type=\"text\" class=\"form-control\" formControlName=\"Entry.Placeholder\">\n </div>\n <button type=\"submit\" (abpInit)=\"submitclick?.nativeElement?.click()\" style=\"display: none;\"\n #submitclick></button>\n </div>\n</form>", styles: [""], dependencies: [{ kind: "directive", type: i4.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i1.NgSelectOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i1.ɵNgSelectMultipleOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i1.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i1.CheckboxControlValueAccessor, selector: "input[type=checkbox][formControlName],input[type=checkbox][formControl],input[type=checkbox][ngModel]" }, { kind: "directive", type: i1.SelectControlValueAccessor, selector: "select:not([multiple])[formControlName],select:not([multiple])[formControl],select:not([multiple])[ngModel]", inputs: ["compareWith"] }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i1.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: i1.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i1.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "directive", type: i1.FormGroupName, selector: "[formGroupName]", inputs: ["formGroupName"] }, { kind: "directive", type: i5.InitDirective, selector: "[abpInit]", outputs: ["abpInit"] }, { kind: "directive", type: i6.ValidationGroupDirective, selector: "[formGroup],[formGroupName]", exportAs: ["validationGroup"] }, { kind: "directive", type: i6.ValidationDirective, selector: "[formControl],[formControlName]", exportAs: ["validationDirective"] }, { kind: "pipe", type: i5.LocalizationPipe, name: "abpLocalization" }] });
|
|
107
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: EntryConfigComponent, selector: "cms-entry-config", inputs: { type: "type", Entity: "Entity", selected: "selected", culture: "culture" }, viewQueries: [{ propertyName: "submitclick", first: true, predicate: ["submitclick"], descendants: true, static: true }], ngImport: i0, template: "<div class=\"mb-2\">\n <label class=\"form-label\">{{'Cms::Sites' | abpLocalization}}</label>\n <select class=\"form-select col-auto\" [(ngModel)]=\"siteId\" (change)=\"siteIdChange()\">\n <ng-container *ngFor=\"let item of siteList\">\n <option [value]=\"item.id\">{{item.displayName}}</option>\n </ng-container>\n </select>\n</div>\n<form [formGroup]=\"_Entity\">\n <div formGroupName=\"formConfiguration\">\n \n <div class=\"mb-2\">\n <label class=\"form-label\">{{'Cms::Sections' | abpLocalization}}</label>\n <select class=\"form-select col-auto\" formControlName=\"Entry.SectionId\">\n <ng-container *ngFor=\"let item of SiteOfSectionList\">\n <option [value]=\"item.id\">{{item.displayName}}</option>\n </ng-container>\n </select>\n </div>\n\n <div class=\"mb-2\">\n <div class=\"form-check form-check-inline\">\n <input class=\"form-check-input\" type=\"checkbox\" formControlName=\"Entry.Multiple\" id=\"Multiple\">\n <label class=\"form-check-label\" for=\"Multiple\">\n {{'Cms::Multiple' | abpLocalization}}\n </label>\n </div>\n </div>\n <div class=\"mb-2\">\n <label class=\"form-label\">{{'Cms::Placeholder' | abpLocalization}}</label>\n <input type=\"text\" class=\"form-control\" formControlName=\"Entry.Placeholder\">\n </div>\n <button type=\"submit\" (abpInit)=\"submitclick?.nativeElement?.click()\" style=\"display: none;\"\n #submitclick></button>\n </div>\n</form>", styles: [""], dependencies: [{ kind: "directive", type: i4.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i1.NgSelectOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i1.ɵNgSelectMultipleOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i1.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i1.CheckboxControlValueAccessor, selector: "input[type=checkbox][formControlName],input[type=checkbox][formControl],input[type=checkbox][ngModel]" }, { kind: "directive", type: i1.SelectControlValueAccessor, selector: "select:not([multiple])[formControlName],select:not([multiple])[formControl],select:not([multiple])[ngModel]", inputs: ["compareWith"] }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i1.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: i1.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i1.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "directive", type: i1.FormGroupName, selector: "[formGroupName]", inputs: ["formGroupName"] }, { kind: "directive", type: i5.InitDirective, selector: "[abpInit]", outputs: ["abpInit"] }, { kind: "directive", type: i6.ValidationGroupDirective, selector: "[formGroup],[formGroupName]", exportAs: ["validationGroup"] }, { kind: "directive", type: i6.ValidationDirective, selector: "[formControl],[formControlName]", exportAs: ["validationDirective"] }, { kind: "pipe", type: i5.LocalizationPipe, name: "abpLocalization" }] });
|
|
108
108
|
}
|
|
109
109
|
export { EntryConfigComponent };
|
|
110
110
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: EntryConfigComponent, decorators: [{
|
|
@@ -116,8 +116,10 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
116
116
|
type: Input
|
|
117
117
|
}], selected: [{
|
|
118
118
|
type: Input
|
|
119
|
+
}], culture: [{
|
|
120
|
+
type: Input
|
|
119
121
|
}], submitclick: [{
|
|
120
122
|
type: ViewChild,
|
|
121
123
|
args: ['submitclick', { static: true }]
|
|
122
124
|
}] } });
|
|
123
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"entry-config.component.js","sourceRoot":"","sources":["../../../../../../../projects/cms/src/lib/components/dynamic-form/entry/entry-config.component.ts","../../../../../../../projects/cms/src/lib/components/dynamic-form/entry/entry-config.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AfterContentInit, Component, ElementRef, Input, ViewChild } from '@angular/core';\nimport { FormBuilder, FormControl, FormGroup, Validators } from '@angular/forms';\nimport { EntryConfig } from './entry-config';\nimport { SiteAdminService } from '../../../proxy/admin/sites';\nimport { SectionAdminService } from '../../../proxy/admin/sections';\n@Component({\n  selector: 'cms-entry-config',\n  templateUrl: './entry-config.component.html',\n  styleUrls: ['./entry-config.component.scss']\n})\nexport class EntryConfigComponent implements AfterContentInit{\n  constructor(\n    private fb: FormBuilder,\n    private _SiteAdminService: SiteAdminService,\n    private _SectionAdminService: SectionAdminService,\n  ) {\n  }\n  /**表单控件类型 */\n  _type: any\n  @Input()\n  public set type(v: any) {\n    if (v == this._type) return\n\n    this._type = v\n    // if (v) this.dataLoaded(1)\n  }\n  /**表单实体 */\n  _Entity: FormGroup | undefined\n  @Input()\n  public set Entity(v: FormGroup) {\n    this._Entity = v;\n    // if (v) this.dataLoaded(2)\n  }\n  /**选择的表单信息 */\n  _selected: any\n  @Input()\n  public set selected(v: any) {\n    this._selected = v\n    // if (v) this.dataLoaded(3)\n  }\n  get formConfiguration() {\n    return this._Entity.get('formConfiguration') as FormGroup\n  }\n  @ViewChild('submitclick', { static: true }) submitclick: ElementRef;\n\n  /**站点列表 */\n  siteList: any[any] = []\n\n  /**选择的站点id */\n  // siteId: string = ''\n  siteId: any = new FormControl('')\n  /**站点下的版块 */\n  SiteOfSectionList: any[any] = []\n\n  ngAfterContentInit(): void {\n    //Called after ngOnInit when the component's or directive's content has been initialized.\n    //Add 'implements AfterContentInit' to the class.\n    this.dataLoaded(2)\n  }\n\n  async dataLoaded(val) {\n    if (this._Entity && this._type) {\n      await this.AfterInit()\n      this.submitclick.nativeElement.click();\n    }\n  }\n\n  AfterInit() {\n    return new Promise(async (resolve, rejects) => {\n      this._Entity.setControl('formConfiguration', this.fb.group(new EntryConfig()))\n      await this.getsiteList()\n      await this.getSiteOfSectionList()\n      if (this._selected) {\n        this.formConfiguration.patchValue({\n          ...this._selected.formConfiguration\n        })\n      }\n      resolve(true)\n    })\n  }\n\n  /**获取站点列表 */\n  getsiteList() {\n    return new Promise((resolve, rejects) => {\n      this._SiteAdminService.getList({}).subscribe(res => {\n        this.siteList = res.items\n        this.siteId = res.items[0]?.id || ''\n        resolve(res.items)\n      })\n    })\n  }\n  /**获取站点下的版块 */\n  getSiteOfSectionList() {\n    return new Promise((resolve, rejects) => {\n      this._SectionAdminService.getList({\n        maxResultCount: 1000,\n        siteId: this.siteId\n      }).subscribe(res => {\n        this.SiteOfSectionList = res.items\n        this.formConfiguration.patchValue({\n          'Entry.SectionId': res.items[0]?.id || ''\n        })\n        // this.filters.sectionId = res.items[0]?.id || ''\n        // this.getSectionOfEntryType()\n        resolve(res.items)\n      })\n    })\n  }\n\n  /**切换站点 */\n  async siteIdChange() {\n    await this.getSiteOfSectionList()\n  }\n}\n","<div class=\"mb-2\">\n    <label class=\"form-label\">{{'Cms::Sites' | abpLocalization}}</label>\n    <select class=\"form-select col-auto\"  [(ngModel)]=\"siteId\" (change)=\"siteIdChange()\">\n        <ng-container *ngFor=\"let item of siteList\">\n            <option [value]=\"item.id\">{{item.displayName}}</option>\n        </ng-container>\n    </select>\n</div>\n<form [formGroup]=\"_Entity\">\n    <div formGroupName=\"formConfiguration\">\n        \n        <div class=\"mb-2\">\n            <label class=\"form-label\">{{'Cms::Sections' | abpLocalization}}</label>\n            <select class=\"form-select col-auto\" formControlName=\"Entry.SectionId\">\n                <ng-container *ngFor=\"let item of SiteOfSectionList\">\n                    <option [value]=\"item.id\">{{item.displayName}}</option>\n                </ng-container>\n            </select>\n        </div>\n\n        <div class=\"mb-2\">\n            <div class=\"form-check form-check-inline\">\n                <input class=\"form-check-input\" type=\"checkbox\" formControlName=\"Entry.Multiple\" id=\"Multiple\">\n                <label class=\"form-check-label\" for=\"Multiple\">\n                    {{'Cms::Multiple' | abpLocalization}}\n                </label>\n            </div>\n        </div>\n        <div class=\"mb-2\">\n            <label class=\"form-label\">{{'Cms::Placeholder' | abpLocalization}}</label>\n            <input type=\"text\" class=\"form-control\" formControlName=\"Entry.Placeholder\">\n        </div>\n        <button type=\"submit\" (abpInit)=\"submitclick?.nativeElement?.click()\" style=\"display: none;\"\n            #submitclick></button>\n    </div>\n</form>"]}
|
|
125
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"entry-config.component.js","sourceRoot":"","sources":["../../../../../../../projects/cms/src/lib/components/dynamic-form/entry/entry-config.component.ts","../../../../../../../projects/cms/src/lib/components/dynamic-form/entry/entry-config.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AfterContentInit, Component, ElementRef, Input, ViewChild } from '@angular/core';\nimport { FormBuilder, FormControl, FormGroup, Validators } from '@angular/forms';\nimport { EntryConfig } from './entry-config';\nimport { SiteAdminService } from '../../../proxy/admin/sites';\nimport { SectionAdminService } from '../../../proxy/admin/sections';\n@Component({\n  selector: 'cms-entry-config',\n  templateUrl: './entry-config.component.html',\n  styleUrls: ['./entry-config.component.scss']\n})\nexport class EntryConfigComponent implements AfterContentInit{\n  constructor(\n    private fb: FormBuilder,\n    private _SiteAdminService: SiteAdminService,\n    private _SectionAdminService: SectionAdminService,\n  ) {\n  }\n  /**表单控件类型 */\n  _type: any\n  @Input()\n  public set type(v: any) {\n    if (v == this._type) return\n\n    this._type = v\n  }\n  /**表单实体 */\n  _Entity: FormGroup | undefined\n  @Input()\n  public set Entity(v: FormGroup) {\n    this._Entity = v;\n  }\n  /**选择的表单信息 */\n  _selected: any\n  @Input()\n  public set selected(v: any) {\n    this._selected = v\n  }\n  /**语言 */\n  _culture: any\n  @Input()\n  public set culture(v: any) {\n    this._culture = v\n  }\n  get formConfiguration() {\n    return this._Entity.get('formConfiguration') as FormGroup\n  }\n  @ViewChild('submitclick', { static: true }) submitclick: ElementRef;\n\n  /**站点列表 */\n  siteList: any[any] = []\n\n  /**选择的站点id */\n  // siteId: string = ''\n  siteId: any = new FormControl('')\n  /**站点下的版块 */\n  SiteOfSectionList: any[any] = []\n\n  ngAfterContentInit(): void {\n    //Called after ngOnInit when the component's or directive's content has been initialized.\n    //Add 'implements AfterContentInit' to the class.\n    this.dataLoaded(2)\n  }\n\n  async dataLoaded(val) {\n    if (this._Entity && this._type) {\n      await this.AfterInit()\n      this.submitclick.nativeElement.click();\n    }\n  }\n\n  AfterInit() {\n    return new Promise(async (resolve, rejects) => {\n      this._Entity.setControl('formConfiguration', this.fb.group(new EntryConfig()))\n      await this.getsiteList()\n      await this.getSiteOfSectionList()\n      if (this._selected) {\n        this.formConfiguration.patchValue({\n          ...this._selected.formConfiguration\n        })\n      }\n      resolve(true)\n    })\n  }\n\n  /**获取站点列表 */\n  getsiteList() {\n    return new Promise((resolve, rejects) => {\n      this._SiteAdminService.getList({}).subscribe(res => {\n        this.siteList = res.items\n        this.siteId = res.items[0]?.id || ''\n        resolve(res.items)\n      })\n    })\n  }\n  /**获取站点下的版块 */\n  getSiteOfSectionList() {\n    return new Promise((resolve, rejects) => {\n      this._SectionAdminService.getList({\n        maxResultCount: 1000,\n        siteId: this.siteId\n      }).subscribe(res => {\n        this.SiteOfSectionList = res.items\n        this.formConfiguration.patchValue({\n          'Entry.SectionId': res.items[0]?.id || ''\n        })\n        resolve(res.items)\n      })\n    })\n  }\n\n  /**切换站点 */\n  async siteIdChange() {\n    await this.getSiteOfSectionList()\n  }\n}\n","<div class=\"mb-2\">\n    <label class=\"form-label\">{{'Cms::Sites' | abpLocalization}}</label>\n    <select class=\"form-select col-auto\"  [(ngModel)]=\"siteId\" (change)=\"siteIdChange()\">\n        <ng-container *ngFor=\"let item of siteList\">\n            <option [value]=\"item.id\">{{item.displayName}}</option>\n        </ng-container>\n    </select>\n</div>\n<form [formGroup]=\"_Entity\">\n    <div formGroupName=\"formConfiguration\">\n        \n        <div class=\"mb-2\">\n            <label class=\"form-label\">{{'Cms::Sections' | abpLocalization}}</label>\n            <select class=\"form-select col-auto\" formControlName=\"Entry.SectionId\">\n                <ng-container *ngFor=\"let item of SiteOfSectionList\">\n                    <option [value]=\"item.id\">{{item.displayName}}</option>\n                </ng-container>\n            </select>\n        </div>\n\n        <div class=\"mb-2\">\n            <div class=\"form-check form-check-inline\">\n                <input class=\"form-check-input\" type=\"checkbox\" formControlName=\"Entry.Multiple\" id=\"Multiple\">\n                <label class=\"form-check-label\" for=\"Multiple\">\n                    {{'Cms::Multiple' | abpLocalization}}\n                </label>\n            </div>\n        </div>\n        <div class=\"mb-2\">\n            <label class=\"form-label\">{{'Cms::Placeholder' | abpLocalization}}</label>\n            <input type=\"text\" class=\"form-control\" formControlName=\"Entry.Placeholder\">\n        </div>\n        <button type=\"submit\" (abpInit)=\"submitclick?.nativeElement?.click()\" style=\"display: none;\"\n            #submitclick></button>\n    </div>\n</form>"]}
|
|
@@ -1,24 +1,17 @@
|
|
|
1
|
-
import { Component, Input, ViewChild } from '@angular/core';
|
|
2
|
-
import { Validators } from '@angular/forms';
|
|
1
|
+
import { Component, Input, ViewChild, inject } from '@angular/core';
|
|
2
|
+
import { FormBuilder, Validators } from '@angular/forms';
|
|
3
|
+
import { EntryAdminService } from '../../../proxy/admin/entries';
|
|
3
4
|
import { EntryStatus } from '../../../proxy/entries/entry-status.enum';
|
|
4
5
|
import * as i0 from "@angular/core";
|
|
5
|
-
import * as i1 from "@angular/
|
|
6
|
-
import * as i2 from "
|
|
7
|
-
import * as i3 from "@
|
|
8
|
-
import * as i4 from "
|
|
9
|
-
import * as i5 from "@ngx-validate/core";
|
|
10
|
-
import * as i6 from "ng-zorro-antd/select";
|
|
6
|
+
import * as i1 from "@angular/common";
|
|
7
|
+
import * as i2 from "@angular/forms";
|
|
8
|
+
import * as i3 from "@ngx-validate/core";
|
|
9
|
+
import * as i4 from "ng-zorro-antd/select";
|
|
11
10
|
class EntryControlComponent {
|
|
12
|
-
|
|
13
|
-
_EntryAdminService;
|
|
14
|
-
router;
|
|
15
|
-
route;
|
|
16
|
-
constructor(fb, _EntryAdminService, router, route) {
|
|
17
|
-
this.fb = fb;
|
|
18
|
-
this._EntryAdminService = _EntryAdminService;
|
|
19
|
-
this.router = router;
|
|
20
|
-
this.route = route;
|
|
11
|
+
constructor() {
|
|
21
12
|
}
|
|
13
|
+
fb = inject(FormBuilder);
|
|
14
|
+
_EntryAdminService = inject(EntryAdminService);
|
|
22
15
|
/**表单实体 */
|
|
23
16
|
_entity;
|
|
24
17
|
set entity(v) {
|
|
@@ -47,12 +40,20 @@ class EntryControlComponent {
|
|
|
47
40
|
if (v)
|
|
48
41
|
this.dataLoaded();
|
|
49
42
|
}
|
|
43
|
+
/**语言 */
|
|
44
|
+
_culture;
|
|
45
|
+
set culture(v) {
|
|
46
|
+
if (v) {
|
|
47
|
+
this._culture = v;
|
|
48
|
+
this.dataLoaded();
|
|
49
|
+
}
|
|
50
|
+
}
|
|
50
51
|
submitclick;
|
|
51
52
|
extraProperties;
|
|
52
53
|
/** */
|
|
53
54
|
listOfOption = [];
|
|
54
55
|
async dataLoaded() {
|
|
55
|
-
if (this._fields && this._entity && this._parentFiledName) {
|
|
56
|
+
if (this._fields && this._entity && this._parentFiledName && this._culture) {
|
|
56
57
|
await this.AfterInit();
|
|
57
58
|
await this.getEntryAssignList();
|
|
58
59
|
this.submitclick.nativeElement.click();
|
|
@@ -74,7 +75,7 @@ class EntryControlComponent {
|
|
|
74
75
|
getEntryAssignList(filter = '') {
|
|
75
76
|
return new Promise((resolve, rejects) => {
|
|
76
77
|
this._EntryAdminService.getList({
|
|
77
|
-
culture: this.
|
|
78
|
+
culture: this._culture,
|
|
78
79
|
sectionId: this._fields.field.formConfiguration['Entry.SectionId'],
|
|
79
80
|
skipCount: 0,
|
|
80
81
|
maxResultCount: 30,
|
|
@@ -90,14 +91,14 @@ class EntryControlComponent {
|
|
|
90
91
|
async SelectChange(event) {
|
|
91
92
|
await this.getEntryAssignList(event);
|
|
92
93
|
}
|
|
93
|
-
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: EntryControlComponent, deps: [
|
|
94
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: EntryControlComponent, selector: "cms-entry-control", inputs: { entity: "entity", fields: "fields", parentFiledName: "parentFiledName", selected: "selected" }, viewQueries: [{ propertyName: "submitclick", first: true, predicate: ["submitclick"], descendants: true, static: true }], ngImport: i0, template: "<form [formGroup]=\"_entity\">\r\n <div [formGroupName]=\"_parentFiledName\" class=\"entry-control-page\">\r\n <div class=\"mb-2\">\r\n <label class=\"form-label\" *ngIf=\"_fields.displayName\">{{ _fields.displayName }}</label>\r\n <ng-container *ngIf=\"_fields.field.formConfiguration['Entry.Multiple']; else elseTemplate\">\r\n <div class=\"form-select\">\r\n <nz-select [nzMaxTagCount]=\"5\" (nzOnSearch)=\"SelectChange($event)\" nzShowSearch nzMode=\"multiple\" [nzPlaceHolder]=\"_fields.field.formConfiguration['Entry.Placeholder']\"\r\n formControlName=\"{{_fields.field.name}}\">\r\n <nz-option *ngFor=\"let item of listOfOption\" [nzLabel]=\"item.title\" [nzValue]=\"item.id\"></nz-option>\r\n </nz-select>\r\n </div>\r\n </ng-container>\r\n <ng-template #elseTemplate>\r\n <div class=\"form-select\">\r\n <nz-select nzShowSearch (nzOnSearch)=\"SelectChange($event)\" [nzMaxMultipleCount]=\"1\" nzMode=\"multiple\" [nzPlaceHolder]=\"_fields.field.formConfiguration['Entry.Placeholder']\"\r\n formControlName=\"{{_fields.field.name}}\">\r\n <nz-option *ngFor=\"let item of listOfOption\" [nzLabel]=\"item.title\" [nzValue]=\"item.id\"></nz-option>\r\n </nz-select>\r\n </div>\r\n </ng-template>\r\n\r\n <div class=\"form-text\" *ngIf=\"_fields.field.description\">{{_fields.field.description}}</div>\r\n </div>\r\n </div>\r\n <button type=\"submit\" style=\"display: none;\" #submitclick></button>\r\n</form>\r\n\r\n\r\n <!-- <ng-container *ngIf=\"_fields.field.formConfiguration['TextEdit.Mode'] ===_TextEditMode.SingleLine\">\r\n <input type=\"text\" class=\"form-control\" formControlName=\"{{_fields.field.name}}\"\r\n [placeholder]=\"_fields.field.formConfiguration['TextEdit.Placeholder']\" />\r\n </ng-container>\r\n <ng-container *ngIf=\"_fields.field.formConfiguration['TextEdit.Mode'] === _TextEditMode.MultipleLine\">\r\n <textarea class=\"form-control\" formControlName=\"{{_fields.field.name}}\"\r\n [placeholder]=\"_fields.field.formConfiguration['TextEdit.Placeholder']\" rows=\"3\"></textarea>\r\n </ng-container> -->", styles: ["::ng-deep .entry-control-page .form-select{padding:0}::ng-deep .entry-control-page nz-select{width:100%}::ng-deep .entry-control-page nz-select .ant-select-selector{background:transparent!important;border:none!important;padding:.275rem 1.25rem!important;box-shadow:none!important;height:auto!important}::ng-deep .entry-control-page nz-select .anticon-search,::ng-deep .entry-control-page nz-select .anticon-down{display:none}\n"], dependencies: [{ kind: "directive", type:
|
|
94
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: EntryControlComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
95
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: EntryControlComponent, selector: "cms-entry-control", inputs: { entity: "entity", fields: "fields", parentFiledName: "parentFiledName", selected: "selected", culture: "culture" }, viewQueries: [{ propertyName: "submitclick", first: true, predicate: ["submitclick"], descendants: true, static: true }], ngImport: i0, template: "<form [formGroup]=\"_entity\">\r\n <div [formGroupName]=\"_parentFiledName\" class=\"entry-control-page\">\r\n <div class=\"mb-2\">\r\n <label class=\"form-label\" *ngIf=\"_fields.displayName\">{{ _fields.displayName }}</label>\r\n <ng-container *ngIf=\"_fields.field.formConfiguration['Entry.Multiple']; else elseTemplate\">\r\n <div class=\"form-select\">\r\n <nz-select [nzMaxTagCount]=\"5\" (nzOnSearch)=\"SelectChange($event)\" nzShowSearch nzMode=\"multiple\" [nzPlaceHolder]=\"_fields.field.formConfiguration['Entry.Placeholder']\"\r\n formControlName=\"{{_fields.field.name}}\">\r\n <nz-option *ngFor=\"let item of listOfOption\" [nzLabel]=\"item.title\" [nzValue]=\"item.id\"></nz-option>\r\n </nz-select>\r\n </div>\r\n </ng-container>\r\n <ng-template #elseTemplate>\r\n <div class=\"form-select\">\r\n <nz-select nzShowSearch (nzOnSearch)=\"SelectChange($event)\" [nzMaxMultipleCount]=\"1\" nzMode=\"multiple\" [nzPlaceHolder]=\"_fields.field.formConfiguration['Entry.Placeholder']\"\r\n formControlName=\"{{_fields.field.name}}\">\r\n <nz-option *ngFor=\"let item of listOfOption\" [nzLabel]=\"item.title\" [nzValue]=\"item.id\"></nz-option>\r\n </nz-select>\r\n </div>\r\n </ng-template>\r\n\r\n <div class=\"form-text\" *ngIf=\"_fields.field.description\">{{_fields.field.description}}</div>\r\n </div>\r\n </div>\r\n <button type=\"submit\" style=\"display: none;\" #submitclick></button>\r\n</form>\r\n\r\n\r\n <!-- <ng-container *ngIf=\"_fields.field.formConfiguration['TextEdit.Mode'] ===_TextEditMode.SingleLine\">\r\n <input type=\"text\" class=\"form-control\" formControlName=\"{{_fields.field.name}}\"\r\n [placeholder]=\"_fields.field.formConfiguration['TextEdit.Placeholder']\" />\r\n </ng-container>\r\n <ng-container *ngIf=\"_fields.field.formConfiguration['TextEdit.Mode'] === _TextEditMode.MultipleLine\">\r\n <textarea class=\"form-control\" formControlName=\"{{_fields.field.name}}\"\r\n [placeholder]=\"_fields.field.formConfiguration['TextEdit.Placeholder']\" rows=\"3\"></textarea>\r\n </ng-container> -->", styles: ["::ng-deep .entry-control-page .form-select{padding:0}::ng-deep .entry-control-page nz-select{width:100%}::ng-deep .entry-control-page nz-select .ant-select-selector{background:transparent!important;border:none!important;padding:.275rem 1.25rem!important;box-shadow:none!important;height:auto!important}::ng-deep .entry-control-page nz-select .anticon-search,::ng-deep .entry-control-page nz-select .anticon-down{display:none}\n"], dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { 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.NzOptionComponent, selector: "nz-option", inputs: ["nzLabel", "nzValue", "nzDisabled", "nzHide", "nzCustomContent"], exportAs: ["nzOption"] }, { kind: "component", type: i4.NzSelectComponent, selector: "nz-select", inputs: ["nzId", "nzSize", "nzStatus", "nzOptionHeightPx", "nzOptionOverflowSize", "nzDropdownClassName", "nzDropdownMatchSelectWidth", "nzDropdownStyle", "nzNotFoundContent", "nzPlaceHolder", "nzPlacement", "nzMaxTagCount", "nzDropdownRender", "nzCustomTemplate", "nzSuffixIcon", "nzClearIcon", "nzRemoveIcon", "nzMenuItemSelectedIcon", "nzTokenSeparators", "nzMaxTagPlaceholder", "nzMaxMultipleCount", "nzMode", "nzFilterOption", "compareWith", "nzAllowClear", "nzBorderless", "nzShowSearch", "nzLoading", "nzAutoFocus", "nzAutoClearSearchValue", "nzServerSearch", "nzDisabled", "nzOpen", "nzSelectOnTab", "nzBackdrop", "nzOptions", "nzShowArrow"], outputs: ["nzOnSearch", "nzScrollToBottom", "nzOpenChange", "nzBlur", "nzFocus"], exportAs: ["nzSelect"] }] });
|
|
95
96
|
}
|
|
96
97
|
export { EntryControlComponent };
|
|
97
98
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: EntryControlComponent, decorators: [{
|
|
98
99
|
type: Component,
|
|
99
100
|
args: [{ selector: 'cms-entry-control', template: "<form [formGroup]=\"_entity\">\r\n <div [formGroupName]=\"_parentFiledName\" class=\"entry-control-page\">\r\n <div class=\"mb-2\">\r\n <label class=\"form-label\" *ngIf=\"_fields.displayName\">{{ _fields.displayName }}</label>\r\n <ng-container *ngIf=\"_fields.field.formConfiguration['Entry.Multiple']; else elseTemplate\">\r\n <div class=\"form-select\">\r\n <nz-select [nzMaxTagCount]=\"5\" (nzOnSearch)=\"SelectChange($event)\" nzShowSearch nzMode=\"multiple\" [nzPlaceHolder]=\"_fields.field.formConfiguration['Entry.Placeholder']\"\r\n formControlName=\"{{_fields.field.name}}\">\r\n <nz-option *ngFor=\"let item of listOfOption\" [nzLabel]=\"item.title\" [nzValue]=\"item.id\"></nz-option>\r\n </nz-select>\r\n </div>\r\n </ng-container>\r\n <ng-template #elseTemplate>\r\n <div class=\"form-select\">\r\n <nz-select nzShowSearch (nzOnSearch)=\"SelectChange($event)\" [nzMaxMultipleCount]=\"1\" nzMode=\"multiple\" [nzPlaceHolder]=\"_fields.field.formConfiguration['Entry.Placeholder']\"\r\n formControlName=\"{{_fields.field.name}}\">\r\n <nz-option *ngFor=\"let item of listOfOption\" [nzLabel]=\"item.title\" [nzValue]=\"item.id\"></nz-option>\r\n </nz-select>\r\n </div>\r\n </ng-template>\r\n\r\n <div class=\"form-text\" *ngIf=\"_fields.field.description\">{{_fields.field.description}}</div>\r\n </div>\r\n </div>\r\n <button type=\"submit\" style=\"display: none;\" #submitclick></button>\r\n</form>\r\n\r\n\r\n <!-- <ng-container *ngIf=\"_fields.field.formConfiguration['TextEdit.Mode'] ===_TextEditMode.SingleLine\">\r\n <input type=\"text\" class=\"form-control\" formControlName=\"{{_fields.field.name}}\"\r\n [placeholder]=\"_fields.field.formConfiguration['TextEdit.Placeholder']\" />\r\n </ng-container>\r\n <ng-container *ngIf=\"_fields.field.formConfiguration['TextEdit.Mode'] === _TextEditMode.MultipleLine\">\r\n <textarea class=\"form-control\" formControlName=\"{{_fields.field.name}}\"\r\n [placeholder]=\"_fields.field.formConfiguration['TextEdit.Placeholder']\" rows=\"3\"></textarea>\r\n </ng-container> -->", styles: ["::ng-deep .entry-control-page .form-select{padding:0}::ng-deep .entry-control-page nz-select{width:100%}::ng-deep .entry-control-page nz-select .ant-select-selector{background:transparent!important;border:none!important;padding:.275rem 1.25rem!important;box-shadow:none!important;height:auto!important}::ng-deep .entry-control-page nz-select .anticon-search,::ng-deep .entry-control-page nz-select .anticon-down{display:none}\n"] }]
|
|
100
|
-
}], ctorParameters: function () { return [
|
|
101
|
+
}], ctorParameters: function () { return []; }, propDecorators: { entity: [{
|
|
101
102
|
type: Input
|
|
102
103
|
}], fields: [{
|
|
103
104
|
type: Input
|
|
@@ -105,8 +106,10 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
105
106
|
type: Input
|
|
106
107
|
}], selected: [{
|
|
107
108
|
type: Input
|
|
109
|
+
}], culture: [{
|
|
110
|
+
type: Input
|
|
108
111
|
}], submitclick: [{
|
|
109
112
|
type: ViewChild,
|
|
110
113
|
args: ['submitclick', { static: true }]
|
|
111
114
|
}] } });
|
|
112
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"entry-control.component.js","sourceRoot":"","sources":["../../../../../../../projects/cms/src/lib/components/dynamic-form/entry/entry-control.component.ts","../../../../../../../projects/cms/src/lib/components/dynamic-form/entry/entry-control.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, Input, ViewChild, ViewContainerRef } from '@angular/core';\nimport { FormBuilder, FormGroup, Validators } from '@angular/forms';\nimport { EntryAdminService } from '../../../proxy/admin/entries';\nimport { EntryStatus } from '../../../proxy/entries/entry-status.enum';\nimport { ActivatedRoute, Router } from '@angular/router';\n\n\n@Component({\n  selector: 'cms-entry-control',\n  templateUrl: './entry-control.component.html',\n  styleUrls: ['./entry-control.component.scss']\n})\nexport class EntryControlComponent {\n\n\n  constructor(\n    private fb: FormBuilder,\n    private _EntryAdminService: EntryAdminService,\n    private router: Router,\n    private route: ActivatedRoute,\n  ) {\n  }\n\n  /**表单实体 */\n  _entity: FormGroup | undefined\n  @Input()\n  public set entity(v: any) {\n    this._entity = v;\n    if (v) this.dataLoaded()\n  }\n\n  /**字段配置列表 */\n  _fields: any = ''\n  @Input()\n  public set fields(v: any) {\n    this._fields = v;\n    if (v) this.dataLoaded()\n  }\n\n  /**父级字段名称，用于为表单设置控件赋值 */\n  _parentFiledName: any\n  @Input()\n  public set parentFiledName(v: any) {\n    this._parentFiledName = v;\n    if (v) this.dataLoaded()\n  }\n  /**父级字段名称，用于为表单设置控件赋值 */\n  _selected: any\n  @Input()\n  public set selected(v: any) {\n    this._selected = v || [];\n    if (v) this.dataLoaded()\n  }\n  @ViewChild('submitclick', { static: true }) submitclick: ElementRef;\n\n  extraProperties: FormGroup | undefined\n\n  /** */\n  listOfOption: any[] = [];\n\n  async dataLoaded() {\n    if (this._fields && this._entity && this._parentFiledName) {\n      await this.AfterInit()\n      await this.getEntryAssignList()\n      this.submitclick.nativeElement.click();\n    }\n  }\n\n  AfterInit() {\n    return new Promise((resolve, rejects) => {\n      let ValidatorsArray = []\n      if (this._fields.required) {\n        ValidatorsArray.push(Validators.required)\n      }\n      let newControl = this.fb.control(this._selected, ValidatorsArray)\n      let extraProperties = this._entity.get(this._parentFiledName) as FormGroup\n      extraProperties.setControl(this._fields.field.name, newControl)\n      resolve(true)\n    })\n  }\n\n  /**获取对应的条目 */\n  getEntryAssignList(filter = '') {\n    return new Promise((resolve, rejects) => {\n      this._EntryAdminService.getList({\n        culture: this._entity.get('culture').value,\n        sectionId: this._fields.field.formConfiguration['Entry.SectionId'],\n        skipCount: 0,\n        maxResultCount: 30,\n        status: EntryStatus.Published,\n        filter: filter\n      }).subscribe(res => {\n        this.listOfOption = res.items\n        resolve(true)\n      })\n    })\n  }\n\n  /** */\n  async SelectChange(event) {\n    await this.getEntryAssignList(event)\n  }\n}\n","<form [formGroup]=\"_entity\">\r\n    <div [formGroupName]=\"_parentFiledName\" class=\"entry-control-page\">\r\n        <div class=\"mb-2\">\r\n            <label class=\"form-label\" *ngIf=\"_fields.displayName\">{{ _fields.displayName }}</label>\r\n            <ng-container *ngIf=\"_fields.field.formConfiguration['Entry.Multiple']; else elseTemplate\">\r\n                <div class=\"form-select\">\r\n                    <nz-select [nzMaxTagCount]=\"5\" (nzOnSearch)=\"SelectChange($event)\" nzShowSearch  nzMode=\"multiple\"  [nzPlaceHolder]=\"_fields.field.formConfiguration['Entry.Placeholder']\"\r\n                    formControlName=\"{{_fields.field.name}}\">\r\n                        <nz-option *ngFor=\"let item of listOfOption\" [nzLabel]=\"item.title\" [nzValue]=\"item.id\"></nz-option>\r\n                    </nz-select>\r\n                </div>\r\n            </ng-container>\r\n            <ng-template #elseTemplate>\r\n                <div class=\"form-select\">\r\n                    <nz-select nzShowSearch (nzOnSearch)=\"SelectChange($event)\" [nzMaxMultipleCount]=\"1\"  nzMode=\"multiple\" [nzPlaceHolder]=\"_fields.field.formConfiguration['Entry.Placeholder']\"\r\n                    formControlName=\"{{_fields.field.name}}\">\r\n                        <nz-option *ngFor=\"let item of listOfOption\" [nzLabel]=\"item.title\" [nzValue]=\"item.id\"></nz-option>\r\n                    </nz-select>\r\n                </div>\r\n            </ng-template>\r\n\r\n            <div class=\"form-text\" *ngIf=\"_fields.field.description\">{{_fields.field.description}}</div>\r\n        </div>\r\n    </div>\r\n    <button type=\"submit\" style=\"display: none;\" #submitclick></button>\r\n</form>\r\n\r\n\r\n     <!-- <ng-container *ngIf=\"_fields.field.formConfiguration['TextEdit.Mode'] ===_TextEditMode.SingleLine\">\r\n                <input type=\"text\" class=\"form-control\" formControlName=\"{{_fields.field.name}}\"\r\n                    [placeholder]=\"_fields.field.formConfiguration['TextEdit.Placeholder']\" />\r\n            </ng-container>\r\n            <ng-container *ngIf=\"_fields.field.formConfiguration['TextEdit.Mode'] === _TextEditMode.MultipleLine\">\r\n                <textarea class=\"form-control\" formControlName=\"{{_fields.field.name}}\"\r\n                    [placeholder]=\"_fields.field.formConfiguration['TextEdit.Placeholder']\" rows=\"3\"></textarea>\r\n            </ng-container> -->"]}
|
|
115
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"entry-control.component.js","sourceRoot":"","sources":["../../../../../../../projects/cms/src/lib/components/dynamic-form/entry/entry-control.component.ts","../../../../../../../projects/cms/src/lib/components/dynamic-form/entry/entry-control.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, Input, ViewChild, ViewContainerRef, inject } from '@angular/core';\nimport { FormBuilder, FormGroup, Validators } from '@angular/forms';\nimport { EntryAdminService } from '../../../proxy/admin/entries';\nimport { EntryStatus } from '../../../proxy/entries/entry-status.enum';\nimport { ActivatedRoute, Router } from '@angular/router';\n\n\n@Component({\n  selector: 'cms-entry-control',\n  templateUrl: './entry-control.component.html',\n  styleUrls: ['./entry-control.component.scss']\n})\nexport class EntryControlComponent {\n\n\n  constructor(\n  ) {\n  }\n  private fb=inject(FormBuilder)\n  private _EntryAdminService=inject(EntryAdminService)\n\n  /**表单实体 */\n  _entity: FormGroup | undefined\n  @Input()\n  public set entity(v: any) {\n    this._entity = v;\n    \n    if (v) this.dataLoaded()\n  }\n\n  /**字段配置列表 */\n  _fields: any = ''\n  @Input()\n  public set fields(v: any) {\n    this._fields = v;\n    if (v) this.dataLoaded()\n  }\n\n  /**父级字段名称，用于为表单设置控件赋值 */\n  _parentFiledName: any\n  @Input()\n  public set parentFiledName(v: any) {\n    this._parentFiledName = v;\n    if (v) this.dataLoaded()\n  }\n  /**父级字段名称，用于为表单设置控件赋值 */\n  _selected: any\n  @Input()\n  public set selected(v: any) {\n    this._selected = v || [];\n    if (v) this.dataLoaded()\n  }\n  /**语言 */\n_culture: any\n  @Input()\n  public set culture(v: any) {\n    if (v) {\n      this._culture = v ;\n      this.dataLoaded()\n    }\n  }\n  @ViewChild('submitclick', { static: true }) submitclick: ElementRef;\n\n  extraProperties: FormGroup | undefined\n\n  /** */\n  listOfOption: any[] = [];\n  async dataLoaded() {\n    if (this._fields && this._entity && this._parentFiledName&&this._culture) {\n      await this.AfterInit()\n      await this.getEntryAssignList()\n      this.submitclick.nativeElement.click();\n    }\n  }\n\n  AfterInit() {\n    return new Promise((resolve, rejects) => {\n      let ValidatorsArray = []\n      if (this._fields.required) {\n        ValidatorsArray.push(Validators.required)\n      }\n      let newControl = this.fb.control(this._selected, ValidatorsArray)\n      let extraProperties = this._entity.get(this._parentFiledName) as FormGroup\n      extraProperties.setControl(this._fields.field.name, newControl)\n      resolve(true)\n    })\n  }\n\n  /**获取对应的条目 */\n  getEntryAssignList(filter = '') {\n    return new Promise((resolve, rejects) => {\n      this._EntryAdminService.getList({\n        culture: this._culture,\n        sectionId: this._fields.field.formConfiguration['Entry.SectionId'],\n        skipCount: 0,\n        maxResultCount: 30,\n        status: EntryStatus.Published,\n        filter: filter\n      }).subscribe(res => {\n        this.listOfOption = res.items\n        resolve(true)\n      })\n    })\n  }\n\n  /** */\n  async SelectChange(event) {\n    await this.getEntryAssignList(event)\n  }\n}\n","<form [formGroup]=\"_entity\">\r\n    <div [formGroupName]=\"_parentFiledName\" class=\"entry-control-page\">\r\n        <div class=\"mb-2\">\r\n            <label class=\"form-label\" *ngIf=\"_fields.displayName\">{{ _fields.displayName }}</label>\r\n            <ng-container *ngIf=\"_fields.field.formConfiguration['Entry.Multiple']; else elseTemplate\">\r\n                <div class=\"form-select\">\r\n                    <nz-select [nzMaxTagCount]=\"5\" (nzOnSearch)=\"SelectChange($event)\" nzShowSearch  nzMode=\"multiple\"  [nzPlaceHolder]=\"_fields.field.formConfiguration['Entry.Placeholder']\"\r\n                    formControlName=\"{{_fields.field.name}}\">\r\n                        <nz-option *ngFor=\"let item of listOfOption\" [nzLabel]=\"item.title\" [nzValue]=\"item.id\"></nz-option>\r\n                    </nz-select>\r\n                </div>\r\n            </ng-container>\r\n            <ng-template #elseTemplate>\r\n                <div class=\"form-select\">\r\n                    <nz-select nzShowSearch (nzOnSearch)=\"SelectChange($event)\" [nzMaxMultipleCount]=\"1\"  nzMode=\"multiple\" [nzPlaceHolder]=\"_fields.field.formConfiguration['Entry.Placeholder']\"\r\n                    formControlName=\"{{_fields.field.name}}\">\r\n                        <nz-option *ngFor=\"let item of listOfOption\" [nzLabel]=\"item.title\" [nzValue]=\"item.id\"></nz-option>\r\n                    </nz-select>\r\n                </div>\r\n            </ng-template>\r\n\r\n            <div class=\"form-text\" *ngIf=\"_fields.field.description\">{{_fields.field.description}}</div>\r\n        </div>\r\n    </div>\r\n    <button type=\"submit\" style=\"display: none;\" #submitclick></button>\r\n</form>\r\n\r\n\r\n     <!-- <ng-container *ngIf=\"_fields.field.formConfiguration['TextEdit.Mode'] ===_TextEditMode.SingleLine\">\r\n                <input type=\"text\" class=\"form-control\" formControlName=\"{{_fields.field.name}}\"\r\n                    [placeholder]=\"_fields.field.formConfiguration['TextEdit.Placeholder']\" />\r\n            </ng-container>\r\n            <ng-container *ngIf=\"_fields.field.formConfiguration['TextEdit.Mode'] === _TextEditMode.MultipleLine\">\r\n                <textarea class=\"form-control\" formControlName=\"{{_fields.field.name}}\"\r\n                    [placeholder]=\"_fields.field.formConfiguration['TextEdit.Placeholder']\" rows=\"3\"></textarea>\r\n            </ng-container> -->"]}
|