@dignite-ng/expand.cms 3.0.0-rc.35 → 3.0.0-rc.37
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/lib/components/admin/entries/create-or-edit-entries.component.mjs +1 -3
- package/esm2022/lib/components/admin/entries/create.component.mjs +3 -3
- package/esm2022/lib/components/dynamic-form/matrix/matrix-config.component.mjs +2 -4
- package/esm2022/lib/components/dynamic-form/matrix/matrix-control.component.mjs +3 -3
- package/esm2022/lib/components/dynamic-form/table/table-config.component.mjs +1 -2
- package/fesm2022/dignite-ng-expand.cms.mjs +5 -10
- package/fesm2022/dignite-ng-expand.cms.mjs.map +1 -1
- package/package.json +1 -1
|
@@ -79,8 +79,6 @@ export class CreateOrEditEntriesComponent {
|
|
|
79
79
|
this.cultureInput.setErrors(repetition);
|
|
80
80
|
this.slugInput.addAsyncValidators(this.SlugAsyncValidator());
|
|
81
81
|
if (this.entryInfo) {
|
|
82
|
-
// this.slugInput.reset(this.entryInfo.slug);
|
|
83
|
-
// this.slugInput.updateValueAndValidity();
|
|
84
82
|
await this.getAllVersionsList();
|
|
85
83
|
this.formEntity.patchValue({
|
|
86
84
|
entryTypeId: this.entryInfo.entryTypeId,
|
|
@@ -278,4 +276,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.5", ngImpor
|
|
|
278
276
|
type: ViewChild,
|
|
279
277
|
args: ['submitclick', { static: true }]
|
|
280
278
|
}] } });
|
|
281
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"create-or-edit-entries.component.js","sourceRoot":"","sources":["../../../../../../../../packages/cms/src/lib/components/admin/entries/create-or-edit-entries.component.ts","../../../../../../../../packages/cms/src/lib/components/admin/entries/create-or-edit-entries.component.html"],"names":[],"mappings":"AAAA,uDAAuD;AACvD,OAAO,EAAE,kBAAkB,EAAE,mBAAmB,EAAE,MAAM,cAAc,CAAC;AACvE,OAAO,EAAE,cAAc,EAAE,MAAM,sBAAsB,CAAC;AACtD,OAAO,EAAE,iBAAiB,EAAE,SAAS,EAAE,UAAU,EAAE,MAAM,EAAE,KAAK,EAAE,SAAS,EAAE,MAAM,eAAe,CAAC;AACnG,OAAO,EAAgC,SAAS,EAAoB,MAAM,gBAAgB,CAAC;AAC3F,OAAO,EAAE,MAAM,EAAE,MAAM,iBAAiB,CAAC;AACzC,OAAO,EAAE,QAAQ,EAAE,QAAQ,EAAE,MAAM,iBAAiB,CAAC;AACrD,OAAO,EAAE,aAAa,EAAE,MAAM,mBAAmB,CAAC;AAClD,OAAO,EAAE,mBAAmB,EAAE,MAAM,2CAA2C,CAAC;AAChF,OAAO,EAAE,iBAAiB,EAAE,MAAM,0CAA0C,CAAC;;;;;;;;;AAU7E,MAAM,OAAO,4BAA4B;IALzC;QAOU,YAAO,GAAG,MAAM,CAAC,cAAc,CAAC,CAAC;QAClC,cAAS,GAAG,MAAM,CAAC,QAAQ,CAAC,CAAC;QAC5B,gBAAW,GAAG,MAAM,CAAC,kBAAkB,CAAC,CAAC;QACzC,yBAAoB,GAAG,MAAM,CAAC,mBAAmB,CAAC,CAAC;QACnD,uBAAkB,GAAG,MAAM,CAAC,iBAAiB,CAAC,CAAC;QAC/C,aAAQ,GAAG,MAAM,CAAC,QAAQ,CAAC,CAAC;QAC5B,yBAAoB,GAAG,MAAM,CAAC,mBAAmB,CAAC,CAAC;QACnD,WAAM,GAAG,MAAM,CAAC,MAAM,CAAC,CAAC;QACxB,mBAAc,GAAG,MAAM,CAAC,aAAa,CAAC,CAAC;QACvC,UAAK,GAAG,MAAM,CAAC,iBAAiB,CAAC,CAAC;QAE1C,UAAU;QACV,kBAAa,GAAU,EAAE,CAAC;QAC1B,iBAAiB;QACjB,cAAS,GAAU,EAAE,CAAC;QACtB,UAAU;QACV,cAAS,GAAQ,EAAE,CAAC;QACpB,UAAU;QACV,gBAAW,GAAQ,EAAE,CAAC;QACtB,mBAAmB;QACnB,kBAAa,GAAQ,EAAE,CAAC;QACxB,YAAY;QACZ,mBAAc,GAAQ,EAAE,CAAC;QACzB,UAAU;QACV,oBAAe,GAAU,EAAE,CAAC;QAEnB,WAAM,GAAgB,KAAK,CAAC;QAE5B,cAAS,GAAe,EAAE,CAAC;QAC3B,gBAAW,GAAe,EAAE,CAAC;QAetC,YAAY;QACZ,WAAM,GAAgB,KAAK,CAAC;KA0N7B;IAzOC,IAAoB,MAAM,CAAC,CAAM;QAC/B,IAAI,CAAC,cAAc,GAAG,CAAC,CAAC,EAAE,CAAC;QAC3B,IAAI,CAAC,SAAS,GAAG,CAAC,CAAC;IACrB,CAAC;IAGD,IAAa,MAAM,CAAC,KAA4B;QAC9C,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC;QACxB,IAAI,KAAK,EAAE,CAAC;YACV,MAAM,SAAS,GAAG,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,wBAAwB,CAAC,CAAC;YACrE,IAAI,CAAC,aAAa,GAAG,SAAS,CAAC;YAC/B,IAAI,CAAC,QAAQ,EAAE,CAAC;QAClB,CAAC;IACH,CAAC;IAID,UAAU;IACV,IAAI,YAAY;QACd,OAAO,IAAI,CAAC,UAAU,EAAE,GAAG,CAAC,SAAS,CAAgB,CAAC;IACxD,CAAC;IACD,IAAI,SAAS;QACX,OAAO,IAAI,CAAC,UAAU,EAAE,GAAG,CAAC,MAAM,CAAgB,CAAC;IACrD,CAAC;IAKD,UAAU;IACV,KAAK,CAAC,QAAQ;QACZ,IAAI,IAAI,CAAC,SAAS,EAAE,CAAC;YACnB,MAAM,IAAI,CAAC,cAAc,EAAE,CAAC;YAC5B,MAAM,IAAI,CAAC,YAAY,EAAE,CAAC;QAC5B,CAAC;QACD,IAAI,CAAC,YAAY,CAAC,OAAO,EAAE,CAAC;QAC5B,MAAM,UAAU,GAAG,MAAM,IAAI,CAAC,qBAAqB,EAAE,CAAC;QACtD,IAAI,UAAU;YAAE,IAAI,CAAC,YAAY,CAAC,SAAS,CAAC,UAAU,CAAC,CAAC;QACxD,IAAI,CAAC,SAAS,CAAC,kBAAkB,CAAC,IAAI,CAAC,kBAAkB,EAAE,CAAC,CAAC;QAG7D,IAAI,IAAI,CAAC,SAAS,EAAE,CAAC;YACnB,6CAA6C;YAC7C,2CAA2C;YAC3C,MAAM,IAAI,CAAC,kBAAkB,EAAE,CAAC;YAChC,IAAI,CAAC,UAAU,CAAC,UAAU,CAAC;gBACzB,WAAW,EAAE,IAAI,CAAC,SAAS,CAAC,WAAW;gBACvC,WAAW,EAAE,IAAI,CAAC,QAAQ,CAAC,SAAS,CAAC,IAAI,CAAC,SAAS,CAAC,WAAW,EAAE,qBAAqB,CAAC;gBACvF,KAAK,EAAE,IAAI,CAAC,SAAS,CAAC,KAAK;gBAC3B,IAAI,EAAE,IAAI,CAAC,SAAS,CAAC,IAAI;gBACzB,QAAQ,EAAE,IAAI,CAAC,SAAS,CAAC,QAAQ;gBACjC,YAAY,EAAE,IAAI,CAAC,SAAS,CAAC,YAAY;gBACzC,gBAAgB,EAAE,IAAI,CAAC,SAAS,CAAC,EAAE;aACpC,CAAC,CAAC;YACH,IAAI,CAAC,SAAS,CAAC,SAAS,CAAC,EAAE,CAAC,CAAA;YAC5B,IAAI,CAAC,SAAS,CAAC,SAAS,CAAC,IAAI,CAAC,CAAA;QAChC,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,UAAU,CAAC,UAAU,CAAC;gBACzB,WAAW,EAAE,IAAI,CAAC,WAAW;gBAC7B,WAAW,EAAE,IAAI,CAAC,QAAQ,CAAC,SAAS,CAAC,IAAI,IAAI,EAAE,EAAE,qBAAqB,CAAC;aACxE,CAAC,CAAC;QACL,CAAC;QAED,IAAI,CAAC,KAAK,CAAC,aAAa,EAAE,CAAC;QAC3B,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC;QACnB,UAAU,CAAC,GAAG,EAAE;YACd,2CAA2C;QAC7C,CAAC,EAAE,CAAC,CAAC,CAAC;IACR,CAAC;IACD,aAAa;IACb,kBAAkB;QAChB,OAAO,CACL,OAAwB,EACgD,EAAE;YAC1E,OAAO,IAAI,OAAO,CAAE,OAAO,CAAC,EAAE;gBAC5B,IAAK,OAAO,CAAC,KAAK,EAAE,CAAC;oBACnB,IAAI,OAAO,CAAC,KAAK,IAAI,IAAI,CAAC,SAAS,EAAE,IAAI,EAAE,CAAC;wBAC1C,OAAO,CAAC,IAAI,CAAC,CAAC;wBACd,OAAO;oBACT,CAAC;oBACD,IAAI,CAAC,kBAAkB;yBACpB,UAAU,CAAC;wBACV,OAAO,EAAE,IAAI,CAAC,YAAY,CAAC,KAAK;wBAChC,SAAS,EAAE,IAAI,CAAC,SAAS;wBACzB,IAAI,EAAE,OAAO,CAAC,KAAK;qBACpB,CAAC;yBACD,SAAS,CAAC,GAAG,CAAC,EAAE;wBACf,IAAI,GAAG,EAAE,CAAC;4BACR,OAAO,CAAC;gCACN,UAAU,EAAE,IAAI,CAAC,oBAAoB,CAAC,OAAO,CAC3C,+BAA+B,EAC/B,OAAO,CAAC,KAAK,CACd;6BACF,CAAC,CAAC;wBACL,CAAC;6BAAM,CAAC;4BACN,OAAO,CAAC,IAAI,CAAC,CAAC;wBAChB,CAAC;oBACH,CAAC,CAAC,CAAC;gBACP,CAAC;YACH,CAAC,CAAC,CAAC;QACL,CAAC,CAAC;IACJ,CAAC;IAED,eAAe;IACf,qBAAqB;QACnB,OAAO,IAAI,OAAO,CAAC,OAAO,CAAC,EAAE;YAC3B,MAAM,OAAO,GAAG,IAAI,CAAC,YAAY,CAAC,KAAK,CAAC;YACxC,IAAI,OAAO,IAAI,IAAI,CAAC,SAAS,EAAE,OAAO,IAAI,IAAI,CAAC,WAAW,CAAC,IAAI,KAAK,CAAC;gBAAE,OAAO,OAAO,CAAC,IAAI,CAAC,CAAC;YAC5F,IAAI,CAAC,kBAAkB;iBACpB,6BAA6B,CAAC;gBAC7B,OAAO,EAAE,OAAO;gBAChB,SAAS,EAAE,IAAI,CAAC,SAAS;gBACzB,WAAW,EAAE,IAAI,CAAC,WAAW;aAC9B,CAAC;iBACD,SAAS,CAAC,GAAG,CAAC,EAAE;gBACf,IAAI,GAAG,EAAE,CAAC;oBACR,OAAO,CAAC;wBACN,UAAU,EAAE,IAAI,CAAC,oBAAoB,CAAC,OAAO,CAC3C,mCAAmC,EACnC,EAAE,EACF,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,WAAW,IAAI,OAAO,CAAC,CAAC,WAAW,CACrE;qBACF,CAAC,CAAC;gBACL,CAAC;qBAAM,CAAC;oBACN,OAAO,CAAC,IAAI,CAAC,CAAC;gBAChB,CAAC;YACH,CAAC,CAAC,CAAC;QACP,CAAC,CAAC,CAAC;IACL,CAAC;IAED,YAAY;IACZ,cAAc;QACZ,OAAO,IAAI,OAAO,CAAC,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;YACrC,IAAI,CAAC,oBAAoB,CAAC,GAAG,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,SAAS,CAAC,GAAG,CAAC,EAAE;gBAC5D,IAAI,CAAC,aAAa,GAAG,GAAG,CAAC,UAAU,CAAC,IAAI,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,IAAI,IAAI,CAAC,WAAW,CAAC,CAAC;gBAC1E,IAAI,CAAC,WAAW,GAAG,GAAG,CAAC;gBACvB,OAAO,CAAC,GAAG,CAAC,CAAC;YACf,CAAC,CAAC,CAAC;QACL,CAAC,CAAC,CAAC;IACL,CAAC;IACD,eAAe;IACf,YAAY;QACV,OAAO,IAAI,OAAO,CAAC,CAAC,OAAO,EAAE,OAAO,EAAE,EAAE;YACtC,IAAI,CAAC,kBAAkB;iBACpB,OAAO,CAAC;gBACP,SAAS,EAAE,IAAI,CAAC,SAAS;gBACzB,cAAc,EAAE,IAAI;gBACpB,OAAO,EAAE,IAAI,CAAC,YAAY,CAAC,KAAK;aACjC,CAAC;iBACD,SAAS,CAAC,CAAC,GAAQ,EAAE,EAAE;gBACtB,MAAM,SAAS,GAAG,GAAG,CAAC,KAAK,CAAC,MAAM,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,KAAK,IAAI,CAAC,SAAS,EAAE,EAAE,CAAC,CAAC;gBACvE,MAAM,UAAU,GAAG,SAAS,CAAC,MAAM,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,QAAQ,CAAC,CAAC;gBACxD,UAAU,CAAC,OAAO,CAAC,EAAE,CAAC,EAAE;oBACtB,MAAM,KAAK,GAAe,CAAC,CAAC;oBAC5B,EAAE,CAAC,KAAK,GAAG,IAAI,KAAK,CAAC,KAAK,CAAC,CAAC;oBAC5B,EAAE,CAAC,QAAQ,GAAG,IAAI,CAAC,eAAe,CAAC,SAAS,EAAE,EAAE,CAAC,EAAE,EAAE,KAAK,GAAG,CAAC,CAAC,CAAC;gBAClE,CAAC,CAAC,CAAC;gBACH,IAAI,CAAC,SAAS,GAAG,UAAU,CAAC;gBAC5B,OAAO,CAAC,GAAG,CAAC,CAAC;YACf,CAAC,CAAC,CAAC;QACP,CAAC,CAAC,CAAC;IACL,CAAC;IACD,mBAAmB;IACnB,eAAe,CAAC,GAAG,EAAE,EAAE,GAAG,EAAE,EAAE,KAAK;QACjC,IAAI,MAAM,GAAG,EAAE,CAAC;QAChB,MAAM,GAAG,GAAG,CAAC,MAAM,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,QAAQ,IAAI,EAAE,CAAC,CAAC;QAC7C,MAAM,CAAC,OAAO,CAAC,EAAE,CAAC,EAAE;YAClB,EAAE,CAAC,KAAK,GAAG,IAAI,KAAK,CAAC,KAAK,CAAC,CAAC;YAC5B,EAAE,CAAC,QAAQ,GAAG,IAAI,CAAC,eAAe,CAAC,GAAG,EAAE,EAAE,CAAC,EAAE,EAAE,KAAK,GAAG,CAAC,CAAC,CAAC;QAC5D,CAAC,CAAC,CAAC;QACH,OAAO,MAAM,CAAC;IAChB,CAAC;IACD,YAAY;IACZ,kBAAkB,CAAC,KAAK;QACtB,MAAM,GAAG,GAAG,KAAK,CAAC,MAAM,CAAC,KAAK,CAAC;QAC/B,MAAM,IAAI,GAAG,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC;QACzC,IAAI,SAAS,GAAG,EAAE,CAAC;QACnB,IAAI,IAAI,CAAC,KAAK;YAAE,OAAO;QACvB,SAAS,GAAG,IAAI,CAAC,cAAc,CAAC,eAAe,CAAC,GAAG,CAAC,CAAC;QACrD,IAAI,CAAC,SAAS,CAAC,UAAU,CAAC,SAAS,IAAI,GAAG,CAAC,CAAC;QAC5C,IAAI,CAAC,kBAAkB;aACpB,UAAU,CAAC;YACV,OAAO,EAAE,IAAI,CAAC,YAAY,CAAC,KAAK;YAChC,SAAS,EAAE,IAAI,CAAC,SAAS;YACzB,IAAI,EAAE,IAAI,CAAC,SAAS,CAAC,KAAK;SAC3B,CAAC;aACD,SAAS,CAAC,GAAG,CAAC,EAAE;YACf,IAAI,GAAG,EAAE,CAAC;gBACR,IAAI,CAAC,SAAS,CAAC,SAAS,CACtB;oBACE,UAAU,EAAE,IAAI,CAAC,oBAAoB,CAAC,OAAO,CAC3C,+BAA+B,EAC/B,IAAI,CAAC,SAAS,CAAC,KAAK,CACrB;iBACF,CACF,CAAA;YACH,CAAC;iBAAM,CAAC;gBACN,IAAI,CAAC,SAAS,CAAC,SAAS,CAAC,IAAI,CAAC,CAAA;YAChC,CAAC;QACH,CAAC,CAAC,CAAC;IACP,CAAC;IAED,cAAc;IACd,kBAAkB;QAChB,OAAO,IAAI,OAAO,CAAC,CAAC,OAAO,EAAE,OAAO,EAAE,EAAE;YACtC,IAAI,CAAC,kBAAkB,CAAC,cAAc,CAAC,IAAI,CAAC,SAAS,CAAC,EAAE,CAAC,CAAC,SAAS,CAAC,GAAG,CAAC,EAAE;gBACxE,IAAI,CAAC,eAAe,GAAG,GAAG,CAAC,KAAK,CAAC;gBACjC,OAAO,CAAC,GAAG,CAAC,CAAC;YACf,CAAC,CAAC,CAAC;QACL,CAAC,CAAC,CAAC;IACL,CAAC;IAED,QAAQ;IACR,gBAAgB,CAAC,SAAS;QACxB,IAAI,CAAC,kBAAkB,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC,SAAS,CAAC,GAAG,CAAC,EAAE;YAC1D,IAAI,CAAC,eAAe,CAAC,OAAO,CAAC,EAAE,CAAC,EAAE;gBAChC,EAAE,CAAC,kBAAkB,GAAG,EAAE,CAAC,EAAE,KAAK,SAAS,CAAC;YAC9C,CAAC,CAAC,CAAC;YACH,OAAO;QACT,CAAC,CAAC,CAAC;IACL,CAAC;IACD,UAAU;IACV,SAAS,CAAC,EAAE;QACV,IAAI,CAAC,MAAM,CAAC,aAAa,CAAC,EAAE,EAAE,EAAE,kBAAkB,EAAE,IAAI,EAAE,CAAC,CAAC,IAAI,CAAC,GAAG,EAAE;YACpE,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,sBAAsB,EAAE,OAAO,CAAC,CAAC,CAAC;QAC1D,CAAC,CAAC,CAAC;IACL,CAAC;IACD,UAAU;IACV,aAAa,CAAC,GAAG;QACf,IAAI,CAAC,kBAAkB,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,SAAS,CAAC,GAAG,CAAC,EAAE;YAClD,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,IAAI,CAAC,oBAAoB,CAAC,OAAO,CAAC,4BAA4B,CAAC,CAAC,CAAC;YACtF,IAAI,CAAC,kBAAkB,EAAE,CAAC;QAC5B,CAAC,CAAC,CAAC;IACL,CAAC;8GAxQU,4BAA4B;kGAA5B,4BAA4B,kTCnBzC,27SA2IM;;2FDxHO,4BAA4B;kBALxC,SAAS;+BACE,4BAA4B;8BAgC7B,MAAM;sBAAd,KAAK;gBAEG,SAAS;sBAAjB,KAAK;gBACG,WAAW;sBAAnB,KAAK;gBACc,MAAM;sBAAzB,KAAK;gBAMO,MAAM;sBAAlB,KAAK;gBAoBsC,WAAW;sBAAtD,SAAS;uBAAC,aAAa,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE","sourcesContent":["/* eslint-disable @angular-eslint/component-selector */\nimport { ConfigStateService, LocalizationService } from '@abp/ng.core';\nimport { ToasterService } from '@abp/ng.theme.shared';\nimport { ChangeDetectorRef, Component, ElementRef, inject, Input, ViewChild } from '@angular/core';\nimport { AbstractControl, FormControl, FormGroup, ValidationErrors } from '@angular/forms';\nimport { Router } from '@angular/router';\nimport { DatePipe, Location } from '@angular/common';\nimport { CmsApiService } from '../../../services';\nimport { SectionAdminService } from '../../../proxy/dignite/cms/admin/sections';\nimport { EntryAdminService } from '../../../proxy/dignite/cms/admin/entries';\nimport { Observable } from 'rxjs';\n\n\n\n@Component({\n  selector: 'cms-create-or-edit-entries',\n  templateUrl: './create-or-edit-entries.component.html',\n  styleUrls: ['./create-or-edit-entries.component.scss'],\n})\nexport class CreateOrEditEntriesComponent {\n\n  private toaster = inject(ToasterService);\n  public _location = inject(Location);\n  private configState = inject(ConfigStateService);\n  private _SectionAdminService = inject(SectionAdminService);\n  private _EntryAdminService = inject(EntryAdminService);\n  private datePipe = inject(DatePipe);\n  private _LocalizationService = inject(LocalizationService);\n  private router = inject(Router);\n  private _CmsApiService = inject(CmsApiService);\n  private cdRef = inject(ChangeDetectorRef);\n\n  /**语言列表 */\n  languagesList: any[] = [];\n  /**条目列表-选择上级条目 */\n  entryList: any[] = [];\n  /**条目信息 */\n  entryInfo: any = '';\n  /**版本信息 */\n  sectionInfo: any = '';\n  /**需要展示的b板块下条目类型 */\n  showEntryType: any = '';\n  /**版本条目id */\n  entryVersionId: any = '';\n  /**版本列表 */\n  AllVersionsList: any[] = [];\n\n  @Input() isEdit: boolean|any = false;\n\n  @Input() sectionId: string|any = '';\n  @Input() entryTypeId: string|any = '';\n  @Input() public set select(v: any) {\n    this.entryVersionId = v.id;\n    this.entryInfo = v;\n  }\n\n  formEntity: FormGroup | undefined;\n  @Input() set entity(value: FormGroup | undefined) {\n    this.formEntity = value;\n    if (value) {\n      const languages = this.configState.getDeep('localization.languages');\n      this.languagesList = languages;\n      this.loadData();\n    }\n  }\n  /**是否加载完成 */\n  isLoad: boolean|any = false;\n\n  /**语言控件 */\n  get cultureInput(): FormControl {\n    return this.formEntity?.get('culture') as FormControl;\n  }\n  get slugInput(): FormControl {\n    return this.formEntity?.get('slug') as FormControl;\n  }\n\n  /**获取提交按钮替身，用于真实触发表单提交 */\n  @ViewChild('submitclick', { static: true }) submitclick: ElementRef;\n\n  /**加载数据 */\n  async loadData() {\n    if (this.sectionId) {\n      await this.getSectionInfo();\n      await this.getEntryList();\n    }\n    this.cultureInput.disable();\n    const repetition = await this.cultureAsyncValidator();\n    if (repetition) this.cultureInput.setErrors(repetition);\n    this.slugInput.addAsyncValidators(this.SlugAsyncValidator());\n    \n\n    if (this.entryInfo) {\n      // this.slugInput.reset(this.entryInfo.slug);\n      // this.slugInput.updateValueAndValidity();\n      await this.getAllVersionsList();\n      this.formEntity.patchValue({\n        entryTypeId: this.entryInfo.entryTypeId,\n        publishTime: this.datePipe.transform(this.entryInfo.publishTime, 'yyyy-MM-dd HH:mm:ss'),\n        title: this.entryInfo.title,\n        slug: this.entryInfo.slug,\n        parentId: this.entryInfo.parentId,\n        versionNotes: this.entryInfo.versionNotes,\n        initialVersionId: this.entryInfo.id,\n      });\n      this.slugInput.setErrors({})\n      this.slugInput.setErrors(null)\n    } else {\n      this.formEntity.patchValue({\n        entryTypeId: this.entryTypeId,\n        publishTime: this.datePipe.transform(new Date(), 'yyyy-MM-dd HH:mm:ss'),\n      });\n    }\n    \n    this.cdRef.detectChanges();\n    this.isLoad = true;\n    setTimeout(() => {\n      // this.submitclick?.nativeElement.click();\n    }, 0);\n  }\n  // /**别名查重 */\n  SlugAsyncValidator() {\n    return (\n      control: AbstractControl\n    ): Promise<ValidationErrors | null> | Observable<ValidationErrors | null> => {\n      return new Promise( resolve => {\n        if ( control.value) {\n          if (control.value == this.entryInfo?.slug) {\n            resolve(null);\n            return;\n          }\n          this._EntryAdminService\n            .slugExists({\n              culture: this.cultureInput.value,\n              sectionId: this.sectionId,\n              slug: control.value,\n            })\n            .subscribe(res => {\n              if (res) {\n                resolve({\n                  repetition: this._LocalizationService.instant(\n                    `Cms::EntrySlug{0}AlreadyExist`,\n                    control.value\n                  ),\n                });\n              } else {\n                resolve(null);\n              }\n            });\n        }\n      });\n    };\n  }\n\n  /**定义自定义异步验证 */\n  cultureAsyncValidator() {\n    return new Promise(resolve => {\n      const culture = this.cultureInput.value;\n      if (culture == this.entryInfo?.culture || this.sectionInfo.type !== 0) return resolve(null);\n      this._EntryAdminService\n        .cultureExistWithSingleSection({\n          culture: culture,\n          sectionId: this.sectionId,\n          entryTypeId: this.entryTypeId,\n        })\n        .subscribe(res => {\n          if (res) {\n            resolve({\n              repetition: this._LocalizationService.instant(\n                `Cms::EntriesAlreadyExistEntryType`,\n                '',\n                this.languagesList.find(el => el.cultureName == culture).displayName\n              ),\n            });\n          } else {\n            resolve(null);\n          }\n        });\n    });\n  }\n\n  /**获取板块信息 */\n  getSectionInfo() {\n    return new Promise((resolve, reject) => {\n      this._SectionAdminService.get(this.sectionId).subscribe(res => {\n        this.showEntryType = res.entryTypes.find(el => el.id == this.entryTypeId);\n        this.sectionInfo = res;\n        resolve(res);\n      });\n    });\n  }\n  /**获取板块下所有条目 */\n  getEntryList() {\n    return new Promise((resolve, rejects) => {\n      this._EntryAdminService\n        .getList({\n          sectionId: this.sectionId,\n          maxResultCount: 1000,\n          culture: this.cultureInput.value,\n        })\n        .subscribe((res: any) => {\n          const entryList = res.items.filter(el => el.id !== this.entryInfo?.id);\n          const parentList = entryList.filter(el => !el.parentId);\n          parentList.forEach(el => {\n            const layer: number|any = 0;\n            el.layer = new Array(layer);\n            el.children = this.groupByParentId(entryList, el.id, layer + 1);\n          });\n          this.entryList = parentList;\n          resolve(res);\n        });\n    });\n  }\n  /**对数组按照父子关系进行分组 */\n  groupByParentId(arr, id = '', layer) {\n    let result = [];\n    result = arr.filter(el => el.parentId == id);\n    result.forEach(el => {\n      el.layer = new Array(layer);\n      el.children = this.groupByParentId(arr, el.id, layer + 1);\n    });\n    return result;\n  }\n  /**标题转化别名 */\n  setTitleToSlugBlur(event) {\n    const val = event.target.value;\n    const slug = this.formEntity.get('slug');\n    let pinyinstr = '';\n    if (slug.value) return;\n    pinyinstr = this._CmsApiService.chineseToPinyin(val);\n    this.slugInput.patchValue(pinyinstr || val);\n    this._EntryAdminService\n      .slugExists({\n        culture: this.cultureInput.value,\n        sectionId: this.sectionId,\n        slug: this.slugInput.value,\n      })\n      .subscribe(res => {\n        if (res) {\n          this.slugInput.setErrors(\n            {\n              repetition: this._LocalizationService.instant(\n                `Cms::EntrySlug{0}AlreadyExist`,\n                this.slugInput.value\n              ),\n            }\n          )\n        } else {\n          this.slugInput.setErrors(null)\n        }\n      });\n  }\n\n  /**获取条目版本列表 */\n  getAllVersionsList() {\n    return new Promise((resolve, rejects) => {\n      this._EntryAdminService.getAllVersions(this.entryInfo.id).subscribe(res => {\n        this.AllVersionsList = res.items;\n        resolve(res);\n      });\n    });\n  }\n\n  /**激活 */\n  ActivatedVersion(VersionId) {\n    this._EntryAdminService.activate(VersionId).subscribe(res => {\n      this.AllVersionsList.forEach(el => {\n        el.isActivatedVersion = el.id === VersionId;\n      });\n      return;\n    });\n  }\n  /**编辑版本 */\n  toEditUrl(id) {\n    this.router.navigateByUrl('', { skipLocationChange: true }).then(() => {\n      this.router.navigate([`/cms/admin/entries/${id}/edit`]);\n    });\n  }\n  /**删除版本 */\n  delectVersion(vid) {\n    this._EntryAdminService.delete(vid).subscribe(res => {\n      this.toaster.success(this._LocalizationService.instant(`AbpUi::DeletedSuccessfully`));\n      this.getAllVersionsList();\n    });\n  }\n}\n","<div [formGroup]=\"formEntity\">\r\n    <div class=\"row\">\r\n        <div class=\"col-md-8\">\r\n            <div class=\"card\">\r\n                <div class=\"card-body\">\r\n                    <div class=\"mb-3\">\r\n                        <div class=\"form-label\">{{'Cms::Title' | abpLocalization}}</div>\r\n                        <input type=\"text\" class=\"form-control\" formControlName=\"title\"\r\n                            (blur)=\"setTitleToSlugBlur($event)\">\r\n                    </div>\r\n                    <ng-container *ngIf=\"isLoad\">\r\n                        <ng-container *ngFor=\"let item of showEntryType?.fieldTabs;let i =index\">\r\n                            <ng-container *ngFor=\"let el of item.fields;let i1 =index\">\r\n                                <ng-container *ngIf=\"el&&formEntity\">\r\n                                    <df-dynamic [fields]=\"el\"\r\n                                        [selected]=\"entryInfo ? entryInfo.extraProperties[el.field.name] : ''\"\r\n                                        [parentFiledName]=\"'extraProperties'\" [culture]=\"cultureInput.value\"\r\n                                        [entity]=\"formEntity\"></df-dynamic>\r\n                                </ng-container>\r\n                            </ng-container>\r\n                        </ng-container>\r\n                    </ng-container>\r\n                </div>\r\n            </div>\r\n        </div>\r\n        <div class=\"col-md-4\">\r\n            <div class=\"card\">\r\n                <div class=\"card-body\">\r\n                    <div class=\"mb-3\">\r\n                        <div class=\"form-label\">{{'Cms::Slug' | abpLocalization}}</div>\r\n                        <input type=\"text\" class=\"form-control\" formControlName=\"slug\">\r\n                        <div class=\"text-danger\" *ngIf=\"slugInput.dirty\">\r\n                            {{slugInput?.errors?.repetition}}\r\n                        </div>\r\n                    </div>\r\n                    <div class=\"mb-3\">\r\n                        <div class=\"form-label\">{{'AbpUi::Languages' | abpLocalization}}</div>\r\n                        <select class=\"form-select form-select-multiple\" formControlName=\"culture\">\r\n                            <ng-container *ngFor=\"let item of languagesList;let i =index\">\r\n                                <option [value]=\"item.cultureName\">{{item.displayName}}</option>\r\n                            </ng-container>\r\n                        </select>\r\n                        <div class=\"text-danger\" *ngIf=\"cultureInput.dirty\">\r\n                            {{cultureInput?.errors?.repetition}}\r\n                        </div>\r\n                    </div>\r\n                    <div class=\"mb-3\" *ngIf=\"sectionInfo.type===1\">\r\n                        <label class=\"form-label\" for=\"parentId\">{{'Cms::ParentEntry' | abpLocalization}}</label>\r\n                        <select class=\"form-select \" formControlName=\"parentId\">\r\n                            <option value=\"\"></option>\r\n                            <ng-container *ngFor=\"let item of entryList;let i =index\">\r\n                                <option [value]=\"item.id\">{{item.title}}</option>\r\n                                <ng-container *ngFor=\"let el of item.children\">\r\n                                    <ng-container *ngTemplateOutlet=\"childTemplate; context: {\r\n                                        $implicit: {\r\n                                        value: el,\r\n                                        }\r\n                                    }\"></ng-container>\r\n                                    <ng-template #childTemplate let-data>\r\n                                        <option [value]=\"data.value.id\">\r\n                                            <ng-container *ngFor=\"let item of data.value.layer\">--</ng-container>\r\n                                            {{data.value.title}}\r\n                                        </option>\r\n                                        <ng-container *ngFor=\"let el of data.value.children\">\r\n                                            <ng-container *ngTemplateOutlet=\"childTemplate; context: {\r\n                                                $implicit: {\r\n                                                value: el,\r\n                                                }\r\n                                            }\"></ng-container>\r\n                                        </ng-container>\r\n                                    </ng-template>\r\n                                </ng-container>\r\n                            </ng-container>\r\n                        </select>\r\n                    </div>\r\n                    <div class=\"mb-3\">\r\n                        <label class=\"form-label\" for=\"publishTime\">{{'Cms::PublishTime' | abpLocalization}}</label>\r\n                        <input type=\"datetime-local\" class=\"form-control\" step=\"1\" formControlName=\"publishTime\">\r\n                    </div>\r\n                    <div class=\"mb-3\" *ngIf=\"isEdit\">\r\n                        <label class=\"form-label\" for=\"Version\">{{'Cms::Version' | abpLocalization}}</label>\r\n                        <ul class=\"list-group\">\r\n                            <ng-container *ngFor=\"let item of AllVersionsList\">\r\n                                <li\r\n                                    class=\"list-group-item flex-between d-flex align-items-center justify-content-between\">\r\n                                    <div>\r\n                                        {{item.initialVersionId?(item.creationTime| date: 'YYYY/MM/dd HH:mm:s'):('Cms::InitialVersion' | abpLocalization)}}\r\n                                        <span class=\"badge text-bg-success ms-1\"\r\n                                            *ngIf=\"item.isActivatedVersion\">{{'Cms::IsActive' | abpLocalization}}</span>\r\n                                        <span class=\"badge text-bg-primary ms-1\"\r\n                                            *ngIf=\"item.id === entryVersionId\">{{'Cms::Editing' |\r\n                                            abpLocalization}}</span>\r\n                                    </div>\r\n                                    <div>\r\n                                        <div ngbDropdown class=\"d-inline-block\">\r\n                                            <button type=\"button\" class=\"btn btn-link-primary p-2 \"\r\n                                                style=\"line-height: 0;\" id=\"dropdownBasic1\" ngbDropdownToggle>\r\n                                            </button>\r\n                                            <div ngbDropdownMenu aria-labelledby=\"dropdownBasic1\">\r\n                                                <button ngbDropdownItem type=\"button\" *ngIf=\"!item.isActivatedVersion\"\r\n                                                    (click)=\"ActivatedVersion(item.id)\">\r\n                                                    <i class=\"fas fa-check me-1\"></i>{{'Cms::IsActive' |\r\n                                                    abpLocalization}}\r\n                                                </button>\r\n                                                <button ngbDropdownItem type=\"button\"\r\n                                                    routerLink=\"/cms/admin/entries/create\"\r\n                                                    [queryParams]=\"{entryVersionId:item.id}\">\r\n                                                    <i class=\"fas fa-plus me-1\"></i>{{'Cms::NewVersion' |\r\n                                                    abpLocalization}}\r\n                                                </button>\r\n                                                <button ngbDropdownItem type=\"button\" (click.stop)=\"toEditUrl(item.id)\"\r\n                                                    *ngIf=\"item.id !== entryVersionId\">\r\n                                                    <i class=\"fas fa-edit me-1\"></i>{{'AbpUi::Edit' | abpLocalization}}\r\n                                                </button>\r\n                                                <button ngbDropdownItem type=\"button\"\r\n                                                    (click.stop)=\"delectVersion(item.id)\"\r\n                                                    *ngIf=\"item.initialVersionId&&!item.isActivatedVersion&&item.id !== entryVersionId\">\r\n                                                    <i class=\"fas fa-trash me-1\"></i>{{'AbpUi::Delete' |\r\n                                                    abpLocalization}}\r\n                                                </button>\r\n                                            </div>\r\n                                        </div>\r\n                                    </div>\r\n                                </li>\r\n                            </ng-container>\r\n                        </ul>\r\n                    </div>\r\n                    <div class=\"mb-3\" *ngIf=\"entryInfo\">\r\n                        <label class=\"form-label\" for=\"versionNotes\">{{'Cms::RevisionNotes' | abpLocalization}}</label>\r\n                        <textarea class=\"form-control\" formControlName=\"versionNotes\" rows=\"3\"></textarea>\r\n                    </div>\r\n\r\n\r\n\r\n                </div>\r\n            </div>\r\n        </div>\r\n    </div>\r\n    <button type=\"submit\" style=\"display: none;\" #submitclick></button>\r\n</div>"]}
|
|
279
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"create-or-edit-entries.component.js","sourceRoot":"","sources":["../../../../../../../../packages/cms/src/lib/components/admin/entries/create-or-edit-entries.component.ts","../../../../../../../../packages/cms/src/lib/components/admin/entries/create-or-edit-entries.component.html"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable @angular-eslint/component-selector */\nimport { ConfigStateService, LocalizationService } from '@abp/ng.core';\nimport { ToasterService } from '@abp/ng.theme.shared';\nimport { ChangeDetectorRef, Component, ElementRef, inject, Input, ViewChild } from '@angular/core';\nimport { AbstractControl, FormControl, FormGroup, ValidationErrors } from '@angular/forms';\nimport { Router } from '@angular/router';\nimport { DatePipe, Location } from '@angular/common';\nimport { CmsApiService } from '../../../services';\nimport { SectionAdminService } from '../../../proxy/dignite/cms/admin/sections';\nimport { EntryAdminService } from '../../../proxy/dignite/cms/admin/entries';\nimport { Observable } from 'rxjs';\n\n\n\n@Component({\n  selector: 'cms-create-or-edit-entries',\n  templateUrl: './create-or-edit-entries.component.html',\n  styleUrls: ['./create-or-edit-entries.component.scss'],\n})\nexport class CreateOrEditEntriesComponent {\n\n  private toaster = inject(ToasterService);\n  public _location = inject(Location);\n  private configState = inject(ConfigStateService);\n  private _SectionAdminService = inject(SectionAdminService);\n  private _EntryAdminService = inject(EntryAdminService);\n  private datePipe = inject(DatePipe);\n  private _LocalizationService = inject(LocalizationService);\n  private router = inject(Router);\n  private _CmsApiService = inject(CmsApiService);\n  private cdRef = inject(ChangeDetectorRef);\n\n  /**语言列表 */\n  languagesList: any[] = [];\n  /**条目列表-选择上级条目 */\n  entryList: any[] = [];\n  /**条目信息 */\n  entryInfo: any = '';\n  /**版本信息 */\n  sectionInfo: any = '';\n  /**需要展示的b板块下条目类型 */\n  showEntryType: any = '';\n  /**版本条目id */\n  entryVersionId: any = '';\n  /**版本列表 */\n  AllVersionsList: any[] = [];\n\n  @Input() isEdit: boolean|any = false;\n\n  @Input() sectionId: string|any = '';\n  @Input() entryTypeId: string|any = '';\n  @Input() public set select(v: any) {\n    this.entryVersionId = v.id;\n    this.entryInfo = v;\n  }\n\n  formEntity: FormGroup | undefined;\n  @Input() set entity(value: FormGroup | undefined) {\n    this.formEntity = value;\n    if (value) {\n      const languages = this.configState.getDeep('localization.languages');\n      this.languagesList = languages;\n      this.loadData();\n    }\n  }\n  /**是否加载完成 */\n  isLoad: boolean|any = false;\n\n  /**语言控件 */\n  get cultureInput(): FormControl {\n    return this.formEntity?.get('culture') as FormControl;\n  }\n  get slugInput(): FormControl {\n    return this.formEntity?.get('slug') as FormControl;\n  }\n\n  /**获取提交按钮替身，用于真实触发表单提交 */\n  @ViewChild('submitclick', { static: true }) submitclick: ElementRef;\n\n  /**加载数据 */\n  async loadData() {\n    if (this.sectionId) {\n      await this.getSectionInfo();\n      await this.getEntryList();\n    }\n    this.cultureInput.disable();\n    const repetition = await this.cultureAsyncValidator();\n    if (repetition) this.cultureInput.setErrors(repetition);\n    this.slugInput.addAsyncValidators(this.SlugAsyncValidator());\n    if (this.entryInfo) {\n      await this.getAllVersionsList();\n      this.formEntity.patchValue({\n        entryTypeId: this.entryInfo.entryTypeId,\n        publishTime: this.datePipe.transform(this.entryInfo.publishTime, 'yyyy-MM-dd HH:mm:ss'),\n        title: this.entryInfo.title,\n        slug: this.entryInfo.slug,\n        parentId: this.entryInfo.parentId,\n        versionNotes: this.entryInfo.versionNotes,\n        initialVersionId: this.entryInfo.id,\n      });\n      this.slugInput.setErrors({})\n      this.slugInput.setErrors(null)\n    } else {\n      this.formEntity.patchValue({\n        entryTypeId: this.entryTypeId,\n        publishTime: this.datePipe.transform(new Date(), 'yyyy-MM-dd HH:mm:ss'),\n      });\n    }\n    \n    this.cdRef.detectChanges();\n    this.isLoad = true;\n    setTimeout(() => {\n      // this.submitclick?.nativeElement.click();\n    }, 0);\n  }\n  // /**别名查重 */\n  SlugAsyncValidator() {\n    return (\n      control: AbstractControl\n    ): Promise<ValidationErrors | null> | Observable<ValidationErrors | null> => {\n      return new Promise( resolve => {\n        if ( control.value) {\n          if (control.value == this.entryInfo?.slug) {\n            resolve(null);\n            return;\n          }\n          this._EntryAdminService\n            .slugExists({\n              culture: this.cultureInput.value,\n              sectionId: this.sectionId,\n              slug: control.value,\n            })\n            .subscribe(res => {\n              if (res) {\n                resolve({\n                  repetition: this._LocalizationService.instant(\n                    `Cms::EntrySlug{0}AlreadyExist`,\n                    control.value\n                  ),\n                });\n              } else {\n                resolve(null);\n              }\n            });\n        }\n      });\n    };\n  }\n\n  /**定义自定义异步验证 */\n  cultureAsyncValidator() {\n    return new Promise(resolve => {\n      const culture = this.cultureInput.value;\n      if (culture == this.entryInfo?.culture || this.sectionInfo.type !== 0) return resolve(null);\n      this._EntryAdminService\n        .cultureExistWithSingleSection({\n          culture: culture,\n          sectionId: this.sectionId,\n          entryTypeId: this.entryTypeId,\n        })\n        .subscribe(res => {\n          if (res) {\n            resolve({\n              repetition: this._LocalizationService.instant(\n                `Cms::EntriesAlreadyExistEntryType`,\n                '',\n                this.languagesList.find(el => el.cultureName == culture).displayName\n              ),\n            });\n          } else {\n            resolve(null);\n          }\n        });\n    });\n  }\n\n  /**获取板块信息 */\n  getSectionInfo() {\n    return new Promise((resolve, reject) => {\n      this._SectionAdminService.get(this.sectionId).subscribe(res => {\n        this.showEntryType = res.entryTypes.find(el => el.id == this.entryTypeId);\n        this.sectionInfo = res;\n        resolve(res);\n      });\n    });\n  }\n  /**获取板块下所有条目 */\n  getEntryList() {\n    return new Promise((resolve, rejects) => {\n      this._EntryAdminService\n        .getList({\n          sectionId: this.sectionId,\n          maxResultCount: 1000,\n          culture: this.cultureInput.value,\n        })\n        .subscribe((res: any) => {\n          const entryList = res.items.filter(el => el.id !== this.entryInfo?.id);\n          const parentList = entryList.filter(el => !el.parentId);\n          parentList.forEach(el => {\n            const layer: number|any = 0;\n            el.layer = new Array(layer);\n            el.children = this.groupByParentId(entryList, el.id, layer + 1);\n          });\n          this.entryList = parentList;\n          resolve(res);\n        });\n    });\n  }\n  /**对数组按照父子关系进行分组 */\n  groupByParentId(arr, id = '', layer) {\n    let result = [];\n    result = arr.filter(el => el.parentId == id);\n    result.forEach(el => {\n      el.layer = new Array(layer);\n      el.children = this.groupByParentId(arr, el.id, layer + 1);\n    });\n    return result;\n  }\n  /**标题转化别名 */\n  setTitleToSlugBlur(event) {\n    const val = event.target.value;\n    const slug = this.formEntity.get('slug');\n    let pinyinstr = '';\n    if (slug.value) return;\n    pinyinstr = this._CmsApiService.chineseToPinyin(val);\n    this.slugInput.patchValue(pinyinstr || val);\n    this._EntryAdminService\n      .slugExists({\n        culture: this.cultureInput.value,\n        sectionId: this.sectionId,\n        slug: this.slugInput.value,\n      })\n      .subscribe(res => {\n        if (res) {\n          this.slugInput.setErrors(\n            {\n              repetition: this._LocalizationService.instant(\n                `Cms::EntrySlug{0}AlreadyExist`,\n                this.slugInput.value\n              ),\n            }\n          )\n        } else {\n          this.slugInput.setErrors(null)\n        }\n      });\n  }\n\n  /**获取条目版本列表 */\n  getAllVersionsList() {\n    return new Promise((resolve, rejects) => {\n      this._EntryAdminService.getAllVersions(this.entryInfo.id).subscribe(res => {\n        this.AllVersionsList = res.items;\n        resolve(res);\n      });\n    });\n  }\n\n  /**激活 */\n  ActivatedVersion(VersionId) {\n    this._EntryAdminService.activate(VersionId).subscribe(res => {\n      this.AllVersionsList.forEach(el => {\n        el.isActivatedVersion = el.id === VersionId;\n      });\n      return;\n    });\n  }\n  /**编辑版本 */\n  toEditUrl(id) {\n    this.router.navigateByUrl('', { skipLocationChange: true }).then(() => {\n      this.router.navigate([`/cms/admin/entries/${id}/edit`]);\n    });\n  }\n  /**删除版本 */\n  delectVersion(vid) {\n    this._EntryAdminService.delete(vid).subscribe(res => {\n      this.toaster.success(this._LocalizationService.instant(`AbpUi::DeletedSuccessfully`));\n      this.getAllVersionsList();\n    });\n  }\n}\n","<div [formGroup]=\"formEntity\">\r\n    <div class=\"row\">\r\n        <div class=\"col-md-8\">\r\n            <div class=\"card\">\r\n                <div class=\"card-body\">\r\n                    <div class=\"mb-3\">\r\n                        <div class=\"form-label\">{{'Cms::Title' | abpLocalization}}</div>\r\n                        <input type=\"text\" class=\"form-control\" formControlName=\"title\"\r\n                            (blur)=\"setTitleToSlugBlur($event)\">\r\n                    </div>\r\n                    <ng-container *ngIf=\"isLoad\">\r\n                        <ng-container *ngFor=\"let item of showEntryType?.fieldTabs;let i =index\">\r\n                            <ng-container *ngFor=\"let el of item.fields;let i1 =index\">\r\n                                <ng-container *ngIf=\"el&&formEntity\">\r\n                                    <df-dynamic [fields]=\"el\"\r\n                                        [selected]=\"entryInfo ? entryInfo.extraProperties[el.field.name] : ''\"\r\n                                        [parentFiledName]=\"'extraProperties'\" [culture]=\"cultureInput.value\"\r\n                                        [entity]=\"formEntity\"></df-dynamic>\r\n                                </ng-container>\r\n                            </ng-container>\r\n                        </ng-container>\r\n                    </ng-container>\r\n                </div>\r\n            </div>\r\n        </div>\r\n        <div class=\"col-md-4\">\r\n            <div class=\"card\">\r\n                <div class=\"card-body\">\r\n                    <div class=\"mb-3\">\r\n                        <div class=\"form-label\">{{'Cms::Slug' | abpLocalization}}</div>\r\n                        <input type=\"text\" class=\"form-control\" formControlName=\"slug\">\r\n                        <div class=\"text-danger\" *ngIf=\"slugInput.dirty\">\r\n                            {{slugInput?.errors?.repetition}}\r\n                        </div>\r\n                    </div>\r\n                    <div class=\"mb-3\">\r\n                        <div class=\"form-label\">{{'AbpUi::Languages' | abpLocalization}}</div>\r\n                        <select class=\"form-select form-select-multiple\" formControlName=\"culture\">\r\n                            <ng-container *ngFor=\"let item of languagesList;let i =index\">\r\n                                <option [value]=\"item.cultureName\">{{item.displayName}}</option>\r\n                            </ng-container>\r\n                        </select>\r\n                        <div class=\"text-danger\" *ngIf=\"cultureInput.dirty\">\r\n                            {{cultureInput?.errors?.repetition}}\r\n                        </div>\r\n                    </div>\r\n                    <div class=\"mb-3\" *ngIf=\"sectionInfo.type===1\">\r\n                        <label class=\"form-label\" for=\"parentId\">{{'Cms::ParentEntry' | abpLocalization}}</label>\r\n                        <select class=\"form-select \" formControlName=\"parentId\">\r\n                            <option value=\"\"></option>\r\n                            <ng-container *ngFor=\"let item of entryList;let i =index\">\r\n                                <option [value]=\"item.id\">{{item.title}}</option>\r\n                                <ng-container *ngFor=\"let el of item.children\">\r\n                                    <ng-container *ngTemplateOutlet=\"childTemplate; context: {\r\n                                        $implicit: {\r\n                                        value: el,\r\n                                        }\r\n                                    }\"></ng-container>\r\n                                    <ng-template #childTemplate let-data>\r\n                                        <option [value]=\"data.value.id\">\r\n                                            <ng-container *ngFor=\"let item of data.value.layer\">--</ng-container>\r\n                                            {{data.value.title}}\r\n                                        </option>\r\n                                        <ng-container *ngFor=\"let el of data.value.children\">\r\n                                            <ng-container *ngTemplateOutlet=\"childTemplate; context: {\r\n                                                $implicit: {\r\n                                                value: el,\r\n                                                }\r\n                                            }\"></ng-container>\r\n                                        </ng-container>\r\n                                    </ng-template>\r\n                                </ng-container>\r\n                            </ng-container>\r\n                        </select>\r\n                    </div>\r\n                    <div class=\"mb-3\">\r\n                        <label class=\"form-label\" for=\"publishTime\">{{'Cms::PublishTime' | abpLocalization}}</label>\r\n                        <input type=\"datetime-local\" class=\"form-control\" step=\"1\" formControlName=\"publishTime\">\r\n                    </div>\r\n                    <div class=\"mb-3\" *ngIf=\"isEdit\">\r\n                        <label class=\"form-label\" for=\"Version\">{{'Cms::Version' | abpLocalization}}</label>\r\n                        <ul class=\"list-group\">\r\n                            <ng-container *ngFor=\"let item of AllVersionsList\">\r\n                                <li\r\n                                    class=\"list-group-item flex-between d-flex align-items-center justify-content-between\">\r\n                                    <div>\r\n                                        {{item.initialVersionId?(item.creationTime| date: 'YYYY/MM/dd HH:mm:s'):('Cms::InitialVersion' | abpLocalization)}}\r\n                                        <span class=\"badge text-bg-success ms-1\"\r\n                                            *ngIf=\"item.isActivatedVersion\">{{'Cms::IsActive' | abpLocalization}}</span>\r\n                                        <span class=\"badge text-bg-primary ms-1\"\r\n                                            *ngIf=\"item.id === entryVersionId\">{{'Cms::Editing' |\r\n                                            abpLocalization}}</span>\r\n                                    </div>\r\n                                    <div>\r\n                                        <div ngbDropdown class=\"d-inline-block\">\r\n                                            <button type=\"button\" class=\"btn btn-link-primary p-2 \"\r\n                                                style=\"line-height: 0;\" id=\"dropdownBasic1\" ngbDropdownToggle>\r\n                                            </button>\r\n                                            <div ngbDropdownMenu aria-labelledby=\"dropdownBasic1\">\r\n                                                <button ngbDropdownItem type=\"button\" *ngIf=\"!item.isActivatedVersion\"\r\n                                                    (click)=\"ActivatedVersion(item.id)\">\r\n                                                    <i class=\"fas fa-check me-1\"></i>{{'Cms::IsActive' |\r\n                                                    abpLocalization}}\r\n                                                </button>\r\n                                                <button ngbDropdownItem type=\"button\"\r\n                                                    routerLink=\"/cms/admin/entries/create\"\r\n                                                    [queryParams]=\"{entryVersionId:item.id}\">\r\n                                                    <i class=\"fas fa-plus me-1\"></i>{{'Cms::NewVersion' |\r\n                                                    abpLocalization}}\r\n                                                </button>\r\n                                                <button ngbDropdownItem type=\"button\" (click.stop)=\"toEditUrl(item.id)\"\r\n                                                    *ngIf=\"item.id !== entryVersionId\">\r\n                                                    <i class=\"fas fa-edit me-1\"></i>{{'AbpUi::Edit' | abpLocalization}}\r\n                                                </button>\r\n                                                <button ngbDropdownItem type=\"button\"\r\n                                                    (click.stop)=\"delectVersion(item.id)\"\r\n                                                    *ngIf=\"item.initialVersionId&&!item.isActivatedVersion&&item.id !== entryVersionId\">\r\n                                                    <i class=\"fas fa-trash me-1\"></i>{{'AbpUi::Delete' |\r\n                                                    abpLocalization}}\r\n                                                </button>\r\n                                            </div>\r\n                                        </div>\r\n                                    </div>\r\n                                </li>\r\n                            </ng-container>\r\n                        </ul>\r\n                    </div>\r\n                    <div class=\"mb-3\" *ngIf=\"entryInfo\">\r\n                        <label class=\"form-label\" for=\"versionNotes\">{{'Cms::RevisionNotes' | abpLocalization}}</label>\r\n                        <textarea class=\"form-control\" formControlName=\"versionNotes\" rows=\"3\"></textarea>\r\n                    </div>\r\n\r\n\r\n\r\n                </div>\r\n            </div>\r\n        </div>\r\n    </div>\r\n    <button type=\"submit\" style=\"display: none;\" #submitclick></button>\r\n</div>"]}
|
|
@@ -120,7 +120,7 @@ export class CreateComponent {
|
|
|
120
120
|
provide: EXTENSIONS_IDENTIFIER,
|
|
121
121
|
useValue: ECmsComponent.Entries_Create,
|
|
122
122
|
},
|
|
123
|
-
], viewQueries: [{ propertyName: "submitclick", first: true, predicate: ["submitclick"], descendants: true, static: true }], ngImport: i0, template: "<abp-page [title]=\"'Cms::New'| abpLocalization\" [toolbar]=\"true\">\r\n <form class=\"row g-3 needs-validation\" [formGroup]=\"formEntity\" [class]=\"{'was-validated':formValidation}\"\r\n (submit)=\"save()\">\r\n <button type=\"submit\" style=\"display: none;\" #submitclick></button>\r\n <ng-container *ngIf=\"formEntity\">\r\n <ng-container *ngIf=\"entryVersionId; else elseTemplate\">\r\n <cms-create-or-edit-entries [sectionId]=\"sectionId\" [entryTypeId]=\"entryTypeId\" [
|
|
123
|
+
], viewQueries: [{ propertyName: "submitclick", first: true, predicate: ["submitclick"], descendants: true, static: true }], ngImport: i0, template: "<abp-page [title]=\"'Cms::New'| abpLocalization\" [toolbar]=\"true\">\r\n <form class=\"row g-3 needs-validation\" [formGroup]=\"formEntity\" [class]=\"{'was-validated':formValidation}\"\r\n (submit)=\"save()\">\r\n <button type=\"submit\" style=\"display: none;\" #submitclick></button>\r\n <ng-container *ngIf=\"formEntity&§ionId\">\r\n <ng-container *ngIf=\"entryVersionId; else elseTemplate\">\r\n <cms-create-or-edit-entries [sectionId]=\"sectionId\" [entryTypeId]=\"entryTypeId\" [isEdit]=\"false\"\r\n [select]=\"entryInfo\" [entity]=\"formEntity\"></cms-create-or-edit-entries>\r\n </ng-container>\r\n <ng-template #elseTemplate>\r\n <cms-create-or-edit-entries [sectionId]=\"sectionId\" [entryTypeId]=\"entryTypeId\"\r\n [entity]=\"formEntity\"></cms-create-or-edit-entries>\r\n </ng-template>\r\n </ng-container>\r\n </form>\r\n</abp-page>", styles: [""], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i2.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: i3.ValidationGroupDirective, selector: "[formGroup],[formGroupName]", exportAs: ["validationGroup"] }, { kind: "component", type: i4.PageComponent, selector: "abp-page", inputs: ["title", "toolbar", "breadcrumb"] }, { kind: "component", type: i5.CreateOrEditEntriesComponent, selector: "cms-create-or-edit-entries", inputs: ["isEdit", "sectionId", "entryTypeId", "select", "entity"] }, { kind: "pipe", type: i6.LocalizationPipe, name: "abpLocalization" }] }); }
|
|
124
124
|
}
|
|
125
125
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.5", ngImport: i0, type: CreateComponent, decorators: [{
|
|
126
126
|
type: Component,
|
|
@@ -129,9 +129,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.5", ngImpor
|
|
|
129
129
|
provide: EXTENSIONS_IDENTIFIER,
|
|
130
130
|
useValue: ECmsComponent.Entries_Create,
|
|
131
131
|
},
|
|
132
|
-
], template: "<abp-page [title]=\"'Cms::New'| abpLocalization\" [toolbar]=\"true\">\r\n <form class=\"row g-3 needs-validation\" [formGroup]=\"formEntity\" [class]=\"{'was-validated':formValidation}\"\r\n (submit)=\"save()\">\r\n <button type=\"submit\" style=\"display: none;\" #submitclick></button>\r\n <ng-container *ngIf=\"formEntity\">\r\n <ng-container *ngIf=\"entryVersionId; else elseTemplate\">\r\n <cms-create-or-edit-entries [sectionId]=\"sectionId\" [entryTypeId]=\"entryTypeId\" [
|
|
132
|
+
], template: "<abp-page [title]=\"'Cms::New'| abpLocalization\" [toolbar]=\"true\">\r\n <form class=\"row g-3 needs-validation\" [formGroup]=\"formEntity\" [class]=\"{'was-validated':formValidation}\"\r\n (submit)=\"save()\">\r\n <button type=\"submit\" style=\"display: none;\" #submitclick></button>\r\n <ng-container *ngIf=\"formEntity&§ionId\">\r\n <ng-container *ngIf=\"entryVersionId; else elseTemplate\">\r\n <cms-create-or-edit-entries [sectionId]=\"sectionId\" [entryTypeId]=\"entryTypeId\" [isEdit]=\"false\"\r\n [select]=\"entryInfo\" [entity]=\"formEntity\"></cms-create-or-edit-entries>\r\n </ng-container>\r\n <ng-template #elseTemplate>\r\n <cms-create-or-edit-entries [sectionId]=\"sectionId\" [entryTypeId]=\"entryTypeId\"\r\n [entity]=\"formEntity\"></cms-create-or-edit-entries>\r\n </ng-template>\r\n </ng-container>\r\n </form>\r\n</abp-page>" }]
|
|
133
133
|
}], propDecorators: { submitclick: [{
|
|
134
134
|
type: ViewChild,
|
|
135
135
|
args: ['submitclick', { static: true }]
|
|
136
136
|
}] } });
|
|
137
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"create.component.js","sourceRoot":"","sources":["../../../../../../../../packages/cms/src/lib/components/admin/entries/create.component.ts","../../../../../../../../packages/cms/src/lib/components/admin/entries/create.component.html"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable @angular-eslint/component-selector */\nimport { EXTENSIONS_IDENTIFIER } from '@abp/ng.components/extensible';\nimport { LocalizationService } from '@abp/ng.core';\nimport { ToasterService } from '@abp/ng.theme.shared';\nimport { DatePipe, Location } from '@angular/common';\nimport { Component, OnInit, inject, ViewChild, ElementRef } from '@angular/core';\nimport { FormBuilder, FormControl, FormGroup } from '@angular/forms';\nimport { ActivatedRoute } from '@angular/router';\n// import { EntryAdminService } from '../../../proxy/admin/entries';\nimport { ECmsComponent } from '../../../enums';\nimport { CreateOrUpdateEntryInputBase } from './create-or-update-entry-input-base';\nimport { ValidatorsService, UpdateListService } from '@dignite-ng/expand.core';\nimport { finalize } from 'rxjs';\nimport { EntryAdminService } from '../../../proxy/dignite/cms/admin/entries';\n\n@Component({\n  selector: 'cms-create',\n  templateUrl: './create.component.html',\n  styleUrls: ['./create.component.scss'],\n  providers: [\n    {\n      provide: EXTENSIONS_IDENTIFIER,\n      useValue: ECmsComponent.Entries_Create,\n    },\n  ],\n})\nexport class CreateComponent implements OnInit {\n  private fb = inject(FormBuilder);\n  private _updateListService = inject(UpdateListService);\n  private toaster = inject(ToasterService);\n  public _location = inject(Location);\n  private route = inject(ActivatedRoute);\n  private _EntryAdminService = inject(EntryAdminService);\n  private _LocalizationService = inject(LocalizationService);\n  private _ValidatorsService = inject(ValidatorsService);\n\n  /**获取提交按钮替身，用于真实触发表单提交 */\n  @ViewChild('submitclick', { static: true }) submitclick: ElementRef;\n\n  /**表单验证状态\n   * {\n   *  title:true,\n   * }\n   */\n  formValidation: any = '';\n  /**表单实体 */\n  formEntity: FormGroup | undefined;\n  /**语言 */\n  cultureName: string|any = '';\n  /**条目类型id */\n  entryTypeId: string|any = '';\n  /**版块id */\n  sectionId: string|any = '';\n  /**条目版本id */\n  entryVersionId: string|any = '';\n  /**条目信息 */\n  entryInfo: any = '';\n\n  /**是否草稿控件*/\n  get draftInput() {\n    return this.formEntity?.get('draft') as FormControl;\n  }\n  /**语言控件 */\n  get cultureInput(): FormControl {\n    return this.formEntity?.get('culture') as FormControl;\n  }\n\n  async ngOnInit(): Promise<void> {\n    const queryParams = this.route.snapshot.queryParams;\n\n    this.cultureName = queryParams.cultureName;\n    this.entryTypeId = queryParams.entryTypeId;\n    this.sectionId = queryParams.sectionId;\n    this.entryVersionId = queryParams.entryVersionId;\n    this.formEntity = this.fb.group(new CreateOrUpdateEntryInputBase());\n    if (this.entryVersionId) await this.getEntryInfo();\n    this.cultureInput.patchValue(this.cultureName);\n  }\n\n  /**获取条目信息 */\n  getEntryInfo() {\n    return new Promise((resolve, rejects) => {\n      this._EntryAdminService.get(this.entryVersionId).subscribe(res => {\n        this.cultureName = res.culture;\n        this.entryTypeId = res.entryTypeId;\n        this.sectionId = res.sectionId;\n        this.entryInfo = res;\n        resolve(res);\n      });\n    });\n  }\n  /**提交 */\n  save() {\n    this.formValidation = this._ValidatorsService.getFormValidationStatus(this.formEntity);\n    if (this._ValidatorsService.isCheckForm(this.formValidation, 'Cms')){\n      this.isSubmit = false;\n      return this.cultureInput.disable();\n    }\n    const input = this.formEntity?.value;\n    input.culture = this.cultureName;\n    input.publishTime = new Date(\n      new Date(input.publishTime).getTime() + 8 * 60 * 60 * 1000\n    ).toISOString();\n    if (!this.formEntity.valid) return;\n    this._EntryAdminService\n      .create(input)\n      .pipe(finalize(() => {\n        this.isSubmit = false;\n      }))\n      .subscribe(res => {\n        this.toaster.success(this._LocalizationService.instant(`AbpUi::SavedSuccessfully`));\n        this._location.back();\n        this._updateListService.updateList();\n      });\n  }\n  isSubmit: boolean|any = false;\n  /**点击提交 */\n  clickSubmit(type) {\n    if (this.isSubmit) return;\n    this.isSubmit = true;\n    this.draftInput.patchValue(type);\n    this.cultureInput.enable();\n    this.submitclick?.nativeElement?.click();\n  }\n\n  /**返回上一页 */\n  backTo() {\n    this._location.back();\n  }\n}\n","<abp-page [title]=\"'Cms::New'| abpLocalization\" [toolbar]=\"true\">\r\n    <form class=\"row g-3 needs-validation\" [formGroup]=\"formEntity\" [class]=\"{'was-validated':formValidation}\"\r\n        (submit)=\"save()\">\r\n        <button type=\"submit\" style=\"display: none;\" #submitclick></button>\r\n        <ng-container *ngIf=\"formEntity\">\r\n            <ng-container *ngIf=\"entryVersionId; else elseTemplate\">\r\n                <cms-create-or-edit-entries [sectionId]=\"sectionId\" [entryTypeId]=\"entryTypeId\" [select]=\"entryInfo\"\r\n                    [entity]=\"formEntity\"></cms-create-or-edit-entries>\r\n            </ng-container>\r\n            <ng-template #elseTemplate>\r\n                <cms-create-or-edit-entries [sectionId]=\"sectionId\" [entryTypeId]=\"entryTypeId\"\r\n                    [entity]=\"formEntity\"></cms-create-or-edit-entries>\r\n            </ng-template>\r\n        </ng-container>\r\n    </form>\r\n</abp-page>"]}
|
|
137
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"create.component.js","sourceRoot":"","sources":["../../../../../../../../packages/cms/src/lib/components/admin/entries/create.component.ts","../../../../../../../../packages/cms/src/lib/components/admin/entries/create.component.html"],"names":[],"mappings":"AAAA,uDAAuD;AACvD,OAAO,EAAE,qBAAqB,EAAE,MAAM,+BAA+B,CAAC;AACtE,OAAO,EAAE,mBAAmB,EAAE,MAAM,cAAc,CAAC;AACnD,OAAO,EAAE,cAAc,EAAE,MAAM,sBAAsB,CAAC;AACtD,OAAO,EAAY,QAAQ,EAAE,MAAM,iBAAiB,CAAC;AACrD,OAAO,EAAE,SAAS,EAAU,MAAM,EAAE,SAAS,EAAE,UAAU,EAAE,MAAM,eAAe,CAAC;AACjF,OAAO,EAAE,WAAW,EAA0B,MAAM,gBAAgB,CAAC;AACrE,OAAO,EAAE,cAAc,EAAE,MAAM,iBAAiB,CAAC;AACjD,oEAAoE;AACpE,OAAO,EAAE,aAAa,EAAE,MAAM,gBAAgB,CAAC;AAC/C,OAAO,EAAE,4BAA4B,EAAE,MAAM,qCAAqC,CAAC;AACnF,OAAO,EAAE,iBAAiB,EAAE,iBAAiB,EAAE,MAAM,yBAAyB,CAAC;AAC/E,OAAO,EAAE,QAAQ,EAAE,MAAM,MAAM,CAAC;AAChC,OAAO,EAAE,iBAAiB,EAAE,MAAM,0CAA0C,CAAC;;;;;;;;AAa7E,MAAM,OAAO,eAAe;IAX5B;QAYU,OAAE,GAAG,MAAM,CAAC,WAAW,CAAC,CAAC;QACzB,uBAAkB,GAAG,MAAM,CAAC,iBAAiB,CAAC,CAAC;QAC/C,YAAO,GAAG,MAAM,CAAC,cAAc,CAAC,CAAC;QAClC,cAAS,GAAG,MAAM,CAAC,QAAQ,CAAC,CAAC;QAC5B,UAAK,GAAG,MAAM,CAAC,cAAc,CAAC,CAAC;QAC/B,uBAAkB,GAAG,MAAM,CAAC,iBAAiB,CAAC,CAAC;QAC/C,yBAAoB,GAAG,MAAM,CAAC,mBAAmB,CAAC,CAAC;QACnD,uBAAkB,GAAG,MAAM,CAAC,iBAAiB,CAAC,CAAC;QAKvD;;;;WAIG;QACH,mBAAc,GAAQ,EAAE,CAAC;QAGzB,QAAQ;QACR,gBAAW,GAAiB,EAAE,CAAC;QAC/B,YAAY;QACZ,gBAAW,GAAiB,EAAE,CAAC;QAC/B,UAAU;QACV,cAAS,GAAiB,EAAE,CAAC;QAC7B,YAAY;QACZ,mBAAc,GAAiB,EAAE,CAAC;QAClC,UAAU;QACV,cAAS,GAAQ,EAAE,CAAC;QA6DpB,aAAQ,GAAkB,KAAK,CAAC;KAcjC;IAzEC,WAAW;IACX,IAAI,UAAU;QACZ,OAAO,IAAI,CAAC,UAAU,EAAE,GAAG,CAAC,OAAO,CAAgB,CAAC;IACtD,CAAC;IACD,UAAU;IACV,IAAI,YAAY;QACd,OAAO,IAAI,CAAC,UAAU,EAAE,GAAG,CAAC,SAAS,CAAgB,CAAC;IACxD,CAAC;IAED,KAAK,CAAC,QAAQ;QACZ,MAAM,WAAW,GAAG,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,WAAW,CAAC;QAEpD,IAAI,CAAC,WAAW,GAAG,WAAW,CAAC,WAAW,CAAC;QAC3C,IAAI,CAAC,WAAW,GAAG,WAAW,CAAC,WAAW,CAAC;QAC3C,IAAI,CAAC,SAAS,GAAG,WAAW,CAAC,SAAS,CAAC;QACvC,IAAI,CAAC,cAAc,GAAG,WAAW,CAAC,cAAc,CAAC;QACjD,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,EAAE,CAAC,KAAK,CAAC,IAAI,4BAA4B,EAAE,CAAC,CAAC;QACpE,IAAI,IAAI,CAAC,cAAc;YAAE,MAAM,IAAI,CAAC,YAAY,EAAE,CAAC;QACnD,IAAI,CAAC,YAAY,CAAC,UAAU,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;IACjD,CAAC;IACD,YAAY;IACZ,YAAY;QACV,OAAO,IAAI,OAAO,CAAC,CAAC,OAAO,EAAE,OAAO,EAAE,EAAE;YACtC,IAAI,CAAC,kBAAkB,CAAC,GAAG,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC,SAAS,CAAC,GAAG,CAAC,EAAE;gBAC/D,IAAI,CAAC,WAAW,GAAG,GAAG,CAAC,OAAO,CAAC;gBAC/B,IAAI,CAAC,WAAW,GAAG,GAAG,CAAC,WAAW,CAAC;gBACnC,IAAI,CAAC,SAAS,GAAG,GAAG,CAAC,SAAS,CAAC;gBAC/B,IAAI,CAAC,SAAS,GAAG,GAAG,CAAC;gBAErB,OAAO,CAAC,GAAG,CAAC,CAAC;YACf,CAAC,CAAC,CAAC;QACL,CAAC,CAAC,CAAC;IACL,CAAC;IACD,QAAQ;IACR,IAAI;QACF,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC,kBAAkB,CAAC,uBAAuB,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;QACvF,IAAI,IAAI,CAAC,kBAAkB,CAAC,WAAW,CAAC,IAAI,CAAC,cAAc,EAAE,KAAK,CAAC,EAAE,CAAC;YACpE,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC;YACtB,OAAO,IAAI,CAAC,YAAY,CAAC,OAAO,EAAE,CAAC;QACrC,CAAC;QACD,MAAM,KAAK,GAAG,IAAI,CAAC,UAAU,EAAE,KAAK,CAAC;QACrC,KAAK,CAAC,OAAO,GAAG,IAAI,CAAC,WAAW,CAAC;QACjC,KAAK,CAAC,WAAW,GAAG,IAAI,IAAI,CAC1B,IAAI,IAAI,CAAC,KAAK,CAAC,WAAW,CAAC,CAAC,OAAO,EAAE,GAAG,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,IAAI,CAC3D,CAAC,WAAW,EAAE,CAAC;QAChB,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,KAAK;YAAE,OAAO;QACnC,IAAI,CAAC,kBAAkB;aACpB,MAAM,CAAC,KAAK,CAAC;aACb,IAAI,CACH,QAAQ,CAAC,GAAG,EAAE;YACZ,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC;QACxB,CAAC,CAAC,CACH;aACA,SAAS,CAAC,GAAG,CAAC,EAAE;YACf,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,IAAI,CAAC,oBAAoB,CAAC,OAAO,CAAC,0BAA0B,CAAC,CAAC,CAAC;YACpF,IAAI,CAAC,SAAS,CAAC,IAAI,EAAE,CAAC;YACtB,IAAI,CAAC,kBAAkB,CAAC,UAAU,EAAE,CAAC;QACvC,CAAC,CAAC,CAAC;IACP,CAAC;IAED,UAAU;IACV,WAAW,CAAC,IAAI;QACd,IAAI,IAAI,CAAC,QAAQ;YAAE,OAAO;QAC1B,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC;QACrB,IAAI,CAAC,UAAU,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC;QACjC,IAAI,CAAC,YAAY,CAAC,MAAM,EAAE,CAAC;QAC3B,IAAI,CAAC,WAAW,EAAE,aAAa,EAAE,KAAK,EAAE,CAAC;IAC3C,CAAC;IAED,WAAW;IACX,MAAM;QACJ,IAAI,CAAC,SAAS,CAAC,IAAI,EAAE,CAAC;IACxB,CAAC;8GAxGU,eAAe;kGAAf,eAAe,qCAPf;YACT;gBACE,OAAO,EAAE,qBAAqB;gBAC9B,QAAQ,EAAE,aAAa,CAAC,cAAc;aACvC;SACF,oJCxBH,y+BAeW;;2FDWE,eAAe;kBAX3B,SAAS;+BACE,YAAY,aAGX;wBACT;4BACE,OAAO,EAAE,qBAAqB;4BAC9B,QAAQ,EAAE,aAAa,CAAC,cAAc;yBACvC;qBACF;8BAa2C,WAAW;sBAAtD,SAAS;uBAAC,aAAa,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE","sourcesContent":["/* eslint-disable @angular-eslint/component-selector */\nimport { EXTENSIONS_IDENTIFIER } from '@abp/ng.components/extensible';\nimport { LocalizationService } from '@abp/ng.core';\nimport { ToasterService } from '@abp/ng.theme.shared';\nimport { DatePipe, Location } from '@angular/common';\nimport { Component, OnInit, inject, ViewChild, ElementRef } from '@angular/core';\nimport { FormBuilder, FormControl, FormGroup } from '@angular/forms';\nimport { ActivatedRoute } from '@angular/router';\n// import { EntryAdminService } from '../../../proxy/admin/entries';\nimport { ECmsComponent } from '../../../enums';\nimport { CreateOrUpdateEntryInputBase } from './create-or-update-entry-input-base';\nimport { ValidatorsService, UpdateListService } from '@dignite-ng/expand.core';\nimport { finalize } from 'rxjs';\nimport { EntryAdminService } from '../../../proxy/dignite/cms/admin/entries';\n\n@Component({\n  selector: 'cms-create',\n  templateUrl: './create.component.html',\n  styleUrls: ['./create.component.scss'],\n  providers: [\n    {\n      provide: EXTENSIONS_IDENTIFIER,\n      useValue: ECmsComponent.Entries_Create,\n    },\n  ],\n})\nexport class CreateComponent implements OnInit {\n  private fb = inject(FormBuilder);\n  private _updateListService = inject(UpdateListService);\n  private toaster = inject(ToasterService);\n  public _location = inject(Location);\n  private route = inject(ActivatedRoute);\n  private _EntryAdminService = inject(EntryAdminService);\n  private _LocalizationService = inject(LocalizationService);\n  private _ValidatorsService = inject(ValidatorsService);\n\n  /**获取提交按钮替身，用于真实触发表单提交 */\n  @ViewChild('submitclick', { static: true }) submitclick: ElementRef;\n\n  /**表单验证状态\n   * {\n   *  title:true,\n   * }\n   */\n  formValidation: any = '';\n  /**表单实体 */\n  formEntity: FormGroup | undefined;\n  /**语言 */\n  cultureName: string | any = '';\n  /**条目类型id */\n  entryTypeId: string | any = '';\n  /**版块id */\n  sectionId: string | any = '';\n  /**条目版本id */\n  entryVersionId: string | any = '';\n  /**条目信息 */\n  entryInfo: any = '';\n\n  /**是否草稿控件*/\n  get draftInput() {\n    return this.formEntity?.get('draft') as FormControl;\n  }\n  /**语言控件 */\n  get cultureInput(): FormControl {\n    return this.formEntity?.get('culture') as FormControl;\n  }\n\n  async ngOnInit(): Promise<void> {\n    const queryParams = this.route.snapshot.queryParams;\n\n    this.cultureName = queryParams.cultureName;\n    this.entryTypeId = queryParams.entryTypeId;\n    this.sectionId = queryParams.sectionId;\n    this.entryVersionId = queryParams.entryVersionId;\n    this.formEntity = this.fb.group(new CreateOrUpdateEntryInputBase());\n    if (this.entryVersionId) await this.getEntryInfo();\n    this.cultureInput.patchValue(this.cultureName);\n  }\n  /**获取条目信息 */\n  getEntryInfo() {\n    return new Promise((resolve, rejects) => {\n      this._EntryAdminService.get(this.entryVersionId).subscribe(res => {\n        this.cultureName = res.culture;\n        this.entryTypeId = res.entryTypeId;\n        this.sectionId = res.sectionId;\n        this.entryInfo = res;\n\n        resolve(res);\n      });\n    });\n  }\n  /**提交 */\n  save() {\n    this.formValidation = this._ValidatorsService.getFormValidationStatus(this.formEntity);\n    if (this._ValidatorsService.isCheckForm(this.formValidation, 'Cms')) {\n      this.isSubmit = false;\n      return this.cultureInput.disable();\n    }\n    const input = this.formEntity?.value;\n    input.culture = this.cultureName;\n    input.publishTime = new Date(\n      new Date(input.publishTime).getTime() + 8 * 60 * 60 * 1000,\n    ).toISOString();\n    if (!this.formEntity.valid) return;\n    this._EntryAdminService\n      .create(input)\n      .pipe(\n        finalize(() => {\n          this.isSubmit = false;\n        }),\n      )\n      .subscribe(res => {\n        this.toaster.success(this._LocalizationService.instant(`AbpUi::SavedSuccessfully`));\n        this._location.back();\n        this._updateListService.updateList();\n      });\n  }\n  isSubmit: boolean | any = false;\n  /**点击提交 */\n  clickSubmit(type) {\n    if (this.isSubmit) return;\n    this.isSubmit = true;\n    this.draftInput.patchValue(type);\n    this.cultureInput.enable();\n    this.submitclick?.nativeElement?.click();\n  }\n\n  /**返回上一页 */\n  backTo() {\n    this._location.back();\n  }\n}\n","<abp-page [title]=\"'Cms::New'| abpLocalization\" [toolbar]=\"true\">\r\n    <form class=\"row g-3 needs-validation\" [formGroup]=\"formEntity\" [class]=\"{'was-validated':formValidation}\"\r\n        (submit)=\"save()\">\r\n        <button type=\"submit\" style=\"display: none;\" #submitclick></button>\r\n        <ng-container *ngIf=\"formEntity&&sectionId\">\r\n            <ng-container *ngIf=\"entryVersionId; else elseTemplate\">\r\n                <cms-create-or-edit-entries [sectionId]=\"sectionId\" [entryTypeId]=\"entryTypeId\" [isEdit]=\"false\"\r\n                    [select]=\"entryInfo\" [entity]=\"formEntity\"></cms-create-or-edit-entries>\r\n            </ng-container>\r\n            <ng-template #elseTemplate>\r\n                <cms-create-or-edit-entries [sectionId]=\"sectionId\" [entryTypeId]=\"entryTypeId\"\r\n                    [entity]=\"formEntity\"></cms-create-or-edit-entries>\r\n            </ng-template>\r\n        </ng-container>\r\n    </form>\r\n</abp-page>"]}
|
|
@@ -210,7 +210,6 @@ export class MatrixConfigComponent {
|
|
|
210
210
|
FieldnameInput.patchValue(pinyin);
|
|
211
211
|
}
|
|
212
212
|
dropMatrix(event) {
|
|
213
|
-
console.log(event.container.data === event.previousContainer.data, 'dropMatrix');
|
|
214
213
|
if (event.container.data === event.previousContainer.data) {
|
|
215
214
|
moveItemInArray(this.MatrixBlockTypes.controls, event.previousIndex, event.currentIndex);
|
|
216
215
|
this.MatrixBlockTypes.updateValueAndValidity();
|
|
@@ -218,10 +217,9 @@ export class MatrixConfigComponent {
|
|
|
218
217
|
}
|
|
219
218
|
else {
|
|
220
219
|
const object1 = this.MatrixBlockTypes.controls[this.selectMatrixBlockIndex].get('fields');
|
|
221
|
-
|
|
220
|
+
const controlsItem = object1.at(event.previousIndex);
|
|
222
221
|
object1.removeAt(event.previousIndex);
|
|
223
222
|
event.container.data[event.currentIndex - 1].controls['fields'].push(controlsItem);
|
|
224
|
-
console.log(object1.controls[event.previousIndex], 'object1.controls[event.previousIndex]');
|
|
225
223
|
}
|
|
226
224
|
this.fieldStartDrag = false;
|
|
227
225
|
}
|
|
@@ -260,4 +258,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.5", ngImpor
|
|
|
260
258
|
type: ViewChild,
|
|
261
259
|
args: ['matrixModalModalSubmit', { static: false }]
|
|
262
260
|
}] } });
|
|
263
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"matrix-config.component.js","sourceRoot":"","sources":["../../../../../../../../packages/cms/src/lib/components/dynamic-form/matrix/matrix-config.component.ts","../../../../../../../../packages/cms/src/lib/components/dynamic-form/matrix/matrix-config.component.html"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable no-async-promise-executor */\n/* eslint-disable @angular-eslint/component-selector */\nimport {\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  inject,\n  Input,\n  viewChild,\n  ViewChild,\n} from '@angular/core';\nimport { FormArray, FormBuilder, FormControl, FormGroup, Validators } from '@angular/forms';\nimport { MatrixConfig, MatrixItemConfig } from './matrix-config';\nimport { CmsApiService, FieldAbstractsService } from '../../../services';\nimport { CdkDrag, CdkDragDrop, moveItemInArray, transferArrayItem } from '@angular/cdk/drag-drop';\nimport { ValidatorsService } from '@dignite-ng/expand.core';\n\n@Component({\n  selector: 'df-matrix-config',\n  templateUrl: './matrix-config.component.html',\n  styleUrls: ['./matrix-config.component.scss'],\n})\nexport class MatrixConfigComponent {\n  constructor(\n    private fb: FormBuilder,\n    private _CmsApiService: CmsApiService,\n    private _FieldAbstractsService: FieldAbstractsService\n  ) {}\n\n  /**表单控件组 */\n  _FieldControlGroup: any[];\n  /**表单控件类型 */\n  _type: any;\n  @Input()\n  public set type(v: any) {\n    this._type = v;\n  }\n\n  /**选择的表单信息 */\n  _selected: any;\n  @Input()\n  public set selected(v: any) {\n    if (v) {\n      for (const key in v.formConfiguration) {\n        if (Array.isArray(v.formConfiguration[key])) {\n          v.formConfiguration[key] = this._CmsApiService.convertKeysToCamelCase(\n            v.formConfiguration[key]\n          );\n        }\n      }\n      this._selected = v;\n    }\n  }\n  /**表单实体 */\n  _Entity: FormGroup | undefined;\n  @Input()\n  public set Entity(v: FormGroup) {\n    this._Entity = v;\n    this.dataLoaded();\n  }\n\n  @ViewChild('submitclick', { static: true }) submitclick: ElementRef;\n\n  private cdr = inject(ChangeDetectorRef);\n  async dataLoaded() {\n    if (this._Entity && this._type) {\n      await this.AfterInit();\n      this.cdr.detectChanges(); // 手动触发变更检测\n      // this.submitclick?.nativeElement?.click();\n    }\n  }\n\n  AfterInit() {\n    return new Promise(async (resolve, rejects) => {\n      this._FieldControlGroup = this._FieldAbstractsService.getExcludeAssignControl(this._type);\n      this._Entity.setControl('formConfiguration', this.fb.group(new MatrixConfig()));\n      await this.setSelectValue();\n      this.formConfiguration.patchValue(this._selected.formConfiguration);\n      resolve(true);\n    });\n  }\n\n  setSelectValue() {\n    return new Promise((resolve, rejects) => {\n      if (this._selected && this._selected.formControlName == this._type) {\n        this._selected.formConfiguration['MatrixBlockTypes'].forEach((el, index) => {\n          this.addMatrixBlockTypeItem(el);\n          el.fields.forEach((elf, indexf) => {\n            this.addMatrixFieldItem(elf, index);\n          });\n        });\n        resolve(true);\n      }\n    });\n  }\n\n  /**获取表单配置 */\n  get formConfiguration() {\n    return this._Entity.get('formConfiguration') as FormGroup;\n  }\n\n  /**获取表单配置下的矩阵块表单数组 */\n  get MatrixBlockTypes() {\n    return this.formConfiguration.controls['MatrixBlockTypes'] as FormArray;\n  }\n\n  /**模态框-状态 */\n  matrixModalOpen: boolean | any = false;\n  /**模态框-是否正在编辑 */\n  isMatrixModalEdit: any = false;\n\n  /**模态框-用于确定模态的繁忙状态是否为真 */\n  modalBusy: boolean | any = false;\n\n  /**模态框-表单 */\n  matrixModalForm: FormGroup | undefined;\n\n  /**表单控件模板-用于在form外提交submit */\n  @ViewChild('matrixModalModalSubmit', { static: false }) matrixModalModalSubmit: ElementRef;\n\n  /**矩阵块-选择的下标 */\n  selectMatrixBlockIndex: any = 0;\n\n  /**矩阵块-选择的矩阵下字段的下标 */\n  selectMatrixFieldIndex: any = 0;\n\n  /**模态框-状态改变 */\n  matrixModalVisibleChange(event) {\n    if (!event) {\n      this.isMatrixModalEdit = false;\n      this.matrixModalForm = undefined;\n      return;\n    }\n  }\n\n  /**矩阵块--新增-打开模态框 */\n  addMatrixBlockType() {\n    this.matrixModalForm = this.fb.group(new MatrixItemConfig());\n    this.matrixModalOpen = true;\n  }\n  formValidation: any;\n  private _ValidatorsService = inject(ValidatorsService);\n  /**模态框--矩阵表单保存提交 */\n  createOrEditSave() {\n    const input = this.matrixModalForm.value;\n    this.formValidation = this._ValidatorsService.getFormValidationStatus(this.matrixModalForm);\n    if (this._ValidatorsService.isCheckForm(this.formValidation, 'Cms')) return;\n    if (!this.matrixModalForm.valid) return;\n    if (this.isMatrixModalEdit) {\n      const MatrixBlockTypesItem = this.MatrixBlockTypes.at(\n        this.selectMatrixBlockIndex\n      ) as FormGroup;\n      MatrixBlockTypesItem.patchValue({\n        ...input,\n      });\n    } else {\n      this.addMatrixBlockTypeItem(input);\n    }\n    this.matrixModalOpen = false;\n    this.matrixModalVisibleChange(false);\n  }\n  /**新增矩阵块-向数组表单中增加项 */\n  addMatrixBlockTypeItem(input) {\n    this.MatrixBlockTypes.push(\n      new FormGroup({\n        displayName: new FormControl(input.displayName, Validators.required),\n        name: new FormControl(input.name, Validators.required),\n        fields: new FormArray([]),\n      })\n    );\n  }\n  /**编辑矩阵块 */\n  EditMatrixBlock(input) {\n    this.matrixModalForm = this.fb.group(new MatrixItemConfig());\n    this.matrixModalForm.patchValue({\n      ...input,\n    });\n    this.matrixModalOpen = true;\n    this.isMatrixModalEdit = true;\n   \n  }\n\n  /**删除矩阵块 */\n  DeleteMatrixBlock(index) {\n    this.MatrixBlockTypes.removeAt(index);\n  }\n\n  /**矩阵块-选择 */\n  selectMatrixBlockChange(index) {\n    this.selectMatrixBlockIndex = index;\n  }\n\n  /**矩阵字段-新增 */\n  addMatrixField() {\n    this.addMatrixFieldItem('', this.selectMatrixBlockIndex);\n    const MatrixBlockTypesItemForm = this.MatrixBlockTypes.at(\n      this.selectMatrixBlockIndex\n    ) as FormGroup;\n    const MatrixFieldItemForm = MatrixBlockTypesItemForm.get('fields') as FormArray;\n    this.selectMatrixFieldChange(0, MatrixFieldItemForm.length - 1);\n  }\n  /**矩阵字段-新增矩阵字段项 */\n  addMatrixFieldItem(input: any = '', selectMatrixBlockIndex) {\n    /**矩阵下标的矩阵项Form */\n    const MatrixBlockTypesItemForm = this.MatrixBlockTypes.at(selectMatrixBlockIndex) as FormGroup;\n    const MatrixFieldItemForm = MatrixBlockTypesItemForm.get('fields') as FormArray;\n    MatrixFieldItemForm.push(\n      this.fb.group({\n        /**字段名称 Display name of this field */\n        displayName: [input.displayName, [Validators.required]],\n        /**字段唯一名称 Unique Name*/\n        name: [input.name, [Validators.required]],\n        /**描述 说明 */\n        description: [input.description, []],\n        /**FieldType字段类型 表单控件名称 */\n        formControlName: [input.formControlName || 'TextEdit', [Validators.required]],\n        //动态表单配置\n        formConfiguration: new FormGroup({}),\n      })\n    );\n    //\n  }\n\n  /**删除矩阵字段项 */\n  deleteMatrixField(MatrixFieldForm, index) {\n    MatrixFieldForm.removeAt(index);\n    this.selectMatrixFieldIndex = 0;\n  }\n\n  /**矩阵字段-选择 */\n  selectMatrixFieldChange(MatrixBlockIndex, MatrixFieldIndex) {\n    this.selectMatrixFieldIndex = MatrixFieldIndex;\n  }\n\n  get nameInput() {\n    return this.matrixModalForm?.get('name');\n  }\n  get FieldnameInput() {\n    const MatrixBlockTypesItemForm = this.MatrixBlockTypes.at(\n      this.selectMatrixBlockIndex\n    ) as FormGroup;\n    const MatrixFieldItemForm = MatrixBlockTypesItemForm.get('fields') as FormArray;\n    return MatrixFieldItemForm.at(this.selectMatrixFieldIndex).get('name');\n  }\n\n  /**矩阵displayNameInput字段失去焦点 */\n  displayNameInputBlur(event) {\n    const value = event.target.value;\n    const pinyin = this._CmsApiService.chineseToPinyin(value);\n    const nameInput = this.nameInput;\n    if (nameInput.value) return;\n    nameInput.patchValue(pinyin);\n  }\n  /**矩阵displayNameInput字段失去焦点 */\n  MatrixFieldDisplayNameInputBlur(event) {\n    const value = event.target.value;\n    const pinyin = this._CmsApiService.chineseToPinyin(value);\n    const FieldnameInput = this.FieldnameInput;\n    if (FieldnameInput.value) return;\n    FieldnameInput.patchValue(pinyin);\n  }\n\n  dropMatrix(event) {\n    console.log(event.container.data === event.previousContainer.data, 'dropMatrix');\n\n    if (event.container.data === event.previousContainer.data) {\n      moveItemInArray(this.MatrixBlockTypes.controls, event.previousIndex, event.currentIndex);\n      this.MatrixBlockTypes.updateValueAndValidity();\n      this.selectMatrixBlockIndex = event.currentIndex;\n    } else {\n      const object1 = this.MatrixBlockTypes.controls[this.selectMatrixBlockIndex].get(\n        'fields'\n      ) as FormArray;\n      let controlsItem = object1.at(event.previousIndex);\n      object1.removeAt(event.previousIndex);\n      event.container.data[event.currentIndex-1].controls['fields'].push(controlsItem);\n      console.log(object1.controls[event.previousIndex],'object1.controls[event.previousIndex]')\n    }\n    this.fieldStartDrag=false;\n  }\n  dropFields(event) {\n    const object1 = this.MatrixBlockTypes.controls[this.selectMatrixBlockIndex].get(\n      'fields'\n    ) as FormArray;\n    moveItemInArray(object1.controls, event.previousIndex, event.currentIndex);\n    this.MatrixBlockTypes.updateValueAndValidity();\n    this.selectMatrixFieldIndex = event.currentIndex;\n    this.fieldStartDrag=false;\n  }\n  sortPredicate(index: number, item: CdkDrag<number>) {\n    return index!==0;\n  }\n  sortPredicateTrue(){\n    return true;\n  }\n  /**字段开始拖拽 */\n  fieldStartDrag:any=false;\n  CdkDragStart(event) {\n    this.fieldStartDrag=true;\n  }\n}\n","<div [formGroup]=\"_Entity\">\n    <div formGroupName=\"formConfiguration\">\n        <div class=\"mb-3\">\n            <label class=\"form-label\">{{'Cms::::FormControl:Matrix' | abpLocalization}}</label>\n            <div class=\"row\" >\n                <div class=\"col-md-3\">\n                    <div class=\"list-group\" [class.fieldStartDragClass]=\"fieldStartDrag\" cdkDropList (cdkDropListDropped)=\"dropMatrix($event)\"     #todoList=\"cdkDropList\"\n                    [cdkDropListData]=\"MatrixBlockTypes.controls\" [cdkDropListSortPredicate]=\"fieldStartDrag?sortPredicate:sortPredicateTrue\"> \n                        <li class=\"list-group-item d-flex align-items-center justify-content-between\"\n                            aria-current=\"true\">\n                            {{'Cms::MatrixBlockType' | abpLocalization}}\n                            <button class=\"btn btn-light btn-sm p-0\" type=\"button\" (click.stop)=\"addMatrixBlockType()\">\n                                <i class=\"fas fa-plus-circle p-1\"></i>\n                            </button>\n                        </li>\n                        <ng-container *ngFor=\"let item of MatrixBlockTypes.controls;let i =index\">\n                            <button type=\"button\" (click.stop)=\"selectMatrixBlockChange(i)\"\n                                class=\"list-group-item d-flex align-items-center justify-content-between list-group-item-action pe-2\"\n                                [class.active]=\"i===selectMatrixBlockIndex\" cdkDrag>\n                                <div style=\"line-break: anywhere;\">\n                                    <div>{{item.value.displayName}}</div>\n                                    <div>{{item.value.name}}</div>\n                                </div>\n                                <div class=\"d-flex align-items-center justify-content-between\">\n                                    <div ngbDropdown class=\"d-inline-block\">\n                                        <button type=\"button\" class=\"btn btn-light btn-sm me-2\" id=\"dropdownBasic1\"\n                                            style=\"z-index: 8;\" ngbDropdownToggle></button>\n                                        <div ngbDropdownMenu aria-labelledby=\"dropdownBasic1\" style=\"z-index: 9;\">\n                                            <button ngbDropdownItem type=\"button\"\n                                                (click.stop)=\"EditMatrixBlock(item.value)\">{{'AbpUi::Edit' |\n                                                abpLocalization}}</button>\n                                            <button ngbDropdownItem type=\"button\"\n                                                (click.stop)=\"DeleteMatrixBlock(i)\">{{'AbpUi::Delete' |\n                                                abpLocalization}}</button>\n                                        </div>\n                                    </div>\n                                    <span class=\"bi bi-arrows-move fs-5 drag-handle\" cdkDragHandle></span>\n                                </div>\n                            </button>\n                        </ng-container>\n                    </div>\n                </div>\n                <div class=\"col-md-3\">\n                    <div class=\"list-group\" *ngIf=\"MatrixBlockTypes?.controls.length>0\" cdkDropList\n                        (cdkDropListDropped)=\"dropFields($event)\"  [cdkDropListData]=\"MatrixBlockTypes.controls[selectMatrixBlockIndex].get('fields').controls\" [cdkDropListConnectedTo]=\"[todoList]\">\n                        <li class=\"list-group-item d-flex align-items-center justify-content-between\"\n                            aria-current=\"true\">\n                            {{'Cms::Fields' | abpLocalization}}\n                            <button class=\"btn btn-light btn-sm p-0\" type=\"button\" (click.stop)=\"addMatrixField()\">\n                                <i class=\"fas fa-plus-circle p-1\"></i>\n                            </button>\n                        </li>\n                        <ng-container *ngFor=\"let item of MatrixBlockTypes.controls;let i =index\">\n                            <ng-container *ngIf=\"i === selectMatrixBlockIndex\">\n                                <ng-container *ngFor=\"let el of item.controls['fields'].controls;let fi =index\">\n                                    <button type=\"button\" (click.stop)=\"selectMatrixFieldChange(i,fi)\"\n                                        class=\"list-group-item d-flex align-items-center justify-content-between list-group-item-action pe-2\"\n                                        [class.active]=\"fi===selectMatrixFieldIndex\" cdkDrag (cdkDragStarted)=\"CdkDragStart($event)\">\n                                        <div style=\"line-break: anywhere;\">\n                                            <div>{{el.value.displayName}}</div>\n                                            <div>{{el.value.name}}</div>\n                                        </div>\n                                        <div class=\"d-flex align-items-center justify-content-between\">\n                                            <button type=\"button\"\n                                                (click.stop)=\"deleteMatrixField(item.controls['fields'],fi)\"\n                                                class=\"btn btn-sm btn-li\">{{'AbpUi::Delete' | abpLocalization}}</button>\n                                            <span class=\"bi bi-arrows-move fs-5 drag-handle\" cdkDragHandle></span>\n                                        </div>\n                                    </button>\n                                </ng-container>\n                            </ng-container>\n                        </ng-container>\n                    </div>\n                </div>\n                <div class=\"col-md-6\" formArrayName=\"MatrixBlockTypes\">\n                    <ng-container *ngFor=\"let item of MatrixBlockTypes.controls;let i =index\">\n                        <div [formGroupName]=\"i\" [hidden]=\"i !== selectMatrixBlockIndex\">\n                            <div formArrayName=\"fields\">\n                                <ng-container *ngFor=\"let itemf of item.controls['fields'].controls;let fi =index\">\n                                    <div [formGroupName]=\"fi\" [hidden]=\"fi !== selectMatrixFieldIndex\">\n                                        <div class=\"mb-3\">\n                                            <label class=\"form-label\" for=\"displayName\">{{'Cms::DisplayName' |\n                                                abpLocalization}}</label>\n                                            <input type=\"text\" class=\"form-control\" formControlName=\"displayName\"\n                                                (blur)=\"MatrixFieldDisplayNameInputBlur($event)\">\n                                        </div>\n                                        <div class=\"mb-3\">\n                                            <label class=\"form-label\" for=\"name\">{{'AbpDynamicForm::FieldName' |\n                                                abpLocalization}}</label>\n                                            <input type=\"text\" class=\"form-control\" formControlName=\"name\">\n                                            <small class=\"form-text text-muted d-block\">\n                                                {{'AbpDynamicForm::FieldNameHelpText' | abpLocalization}}</small>\n                                        </div>\n                                        <div class=\"mb-3\">\n                                            <label class=\"form-label\" for=\"description\">{{'Cms::Description' |\n                                                abpLocalization}}</label>\n                                            <input type=\"text\" class=\"form-control\" formControlName=\"description\">\n                                        </div>\n                                        <div class=\"mb-3\">\n                                            <label class=\"form-label\" for=\"formControlName\">{{'Cms::FieldType' |\n                                                abpLocalization}}</label>\n                                            <select class=\"form-select\" formControlName=\"formControlName\">\n                                                <ng-container *ngFor=\"let itemC of _FieldControlGroup;let i =index\">\n                                                    <option [value]=\"itemC.name\">{{itemC.displayName}}</option>\n                                                </ng-container>\n                                            </select>\n                                        </div>\n                                        <ng-container *ngIf=\"itemf.value.formControlName&&itemf\">\n                                            <df-dynamic [type]=\"itemf.value.formControlName\"\n                                                [selected]=\"_selected?_selected.formConfiguration?.MatrixBlockTypes[i]?.fields[fi]:''\"\n                                                [entity]=\"itemf\"></df-dynamic>\n\n                                        </ng-container>\n                                    </div>\n                                </ng-container>\n                            </div>\n                        </div>\n                    </ng-container>\n                </div>\n\n            </div>\n        </div>\n        <button type=\"submit\" (abpInit)=\"submitclick?.nativeElement?.click()\" style=\"display: none;\"\n            #submitclick></button>\n    </div>\n</div>\n\n\n\n<abp-modal [(visible)]=\"matrixModalOpen\" [busy]=\"modalBusy\" (visibleChange)=\"matrixModalVisibleChange($event)\">\n    <ng-template #abpHeader>\n        <h3>{{isMatrixEdit?('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=\"matrixModalForm; else loaderRef\">\n            <form [formGroup]=\"matrixModalForm\" (submit)=\"createOrEditSave()\">\n                <button type=\"submit\" #matrixModalModalSubmit style=\"display: none\"></button>\n                <div class=\"mb-3\">\n                    <label class=\"form-label\" for=\"displayName\">{{'Cms::DisplayName' | abpLocalization}}</label>\n                    <input type=\"text\" class=\"form-control\" formControlName=\"displayName\"\n                        (blur)=\"displayNameInputBlur($event)\">\n                </div>\n                <div class=\"mb-3\">\n                    <label class=\"form-label\" for=\"name\">{{'Cms::Name' | abpLocalization}}</label>\n                    <input type=\"text\" class=\"form-control\" formControlName=\"name\">\n                </div>\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        <abp-button iconClass=\"fa fa-check\" (click)=\"matrixModalModalSubmit.nativeElement.click()\">{{'AbpUi::Save' |\n            abpLocalization}}</abp-button>\n    </ng-template>\n</abp-modal>\n\n"]}
|
|
261
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"matrix-config.component.js","sourceRoot":"","sources":["../../../../../../../../packages/cms/src/lib/components/dynamic-form/matrix/matrix-config.component.ts","../../../../../../../../packages/cms/src/lib/components/dynamic-form/matrix/matrix-config.component.html"],"names":[],"mappings":"AAAA,8CAA8C;AAC9C,uDAAuD;AACvD,OAAO,EACL,iBAAiB,EACjB,SAAS,EACT,UAAU,EACV,MAAM,EACN,KAAK,EAEL,SAAS,GACV,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,SAAS,EAAE,WAAW,EAAE,WAAW,EAAE,SAAS,EAAE,UAAU,EAAE,MAAM,gBAAgB,CAAC;AAC5F,OAAO,EAAE,YAAY,EAAE,gBAAgB,EAAE,MAAM,iBAAiB,CAAC;AACjE,OAAO,EAAE,aAAa,EAAE,qBAAqB,EAAE,MAAM,mBAAmB,CAAC;AACzE,OAAO,EAAwB,eAAe,EAAqB,MAAM,wBAAwB,CAAC;AAClG,OAAO,EAAE,iBAAiB,EAAE,MAAM,yBAAyB,CAAC;;;;;;;;;;;AAO5D,MAAM,OAAO,qBAAqB;IAChC,YACU,EAAe,EACf,cAA6B,EAC7B,sBAA6C;QAF7C,OAAE,GAAF,EAAE,CAAa;QACf,mBAAc,GAAd,cAAc,CAAe;QAC7B,2BAAsB,GAAtB,sBAAsB,CAAuB;QAqC/C,QAAG,GAAG,MAAM,CAAC,iBAAiB,CAAC,CAAC;QA2CxC,YAAY;QACZ,oBAAe,GAAkB,KAAK,CAAC;QACvC,gBAAgB;QAChB,sBAAiB,GAAQ,KAAK,CAAC;QAE/B,yBAAyB;QACzB,cAAS,GAAkB,KAAK,CAAC;QAQjC,eAAe;QACf,2BAAsB,GAAQ,CAAC,CAAC;QAEhC,qBAAqB;QACrB,2BAAsB,GAAQ,CAAC,CAAC;QAiBxB,uBAAkB,GAAG,MAAM,CAAC,iBAAiB,CAAC,CAAC;QAuJvD,YAAY;QACZ,mBAAc,GAAK,KAAK,CAAC;IA1QtB,CAAC;IAMJ,IACW,IAAI,CAAC,CAAM;QACpB,IAAI,CAAC,KAAK,GAAG,CAAC,CAAC;IACjB,CAAC;IAID,IACW,QAAQ,CAAC,CAAM;QACxB,IAAI,CAAC,EAAE,CAAC;YACN,KAAK,MAAM,GAAG,IAAI,CAAC,CAAC,iBAAiB,EAAE,CAAC;gBACtC,IAAI,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,iBAAiB,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC;oBAC5C,CAAC,CAAC,iBAAiB,CAAC,GAAG,CAAC,GAAG,IAAI,CAAC,cAAc,CAAC,sBAAsB,CACnE,CAAC,CAAC,iBAAiB,CAAC,GAAG,CAAC,CACzB,CAAC;gBACJ,CAAC;YACH,CAAC;YACD,IAAI,CAAC,SAAS,GAAG,CAAC,CAAC;QACrB,CAAC;IACH,CAAC;IAGD,IACW,MAAM,CAAC,CAAY;QAC5B,IAAI,CAAC,OAAO,GAAG,CAAC,CAAC;QACjB,IAAI,CAAC,UAAU,EAAE,CAAC;IACpB,CAAC;IAKD,KAAK,CAAC,UAAU;QACd,IAAI,IAAI,CAAC,OAAO,IAAI,IAAI,CAAC,KAAK,EAAE,CAAC;YAC/B,MAAM,IAAI,CAAC,SAAS,EAAE,CAAC;YACvB,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC,CAAC,WAAW;YACrC,4CAA4C;QAC9C,CAAC;IACH,CAAC;IAED,SAAS;QACP,OAAO,IAAI,OAAO,CAAC,KAAK,EAAE,OAAO,EAAE,OAAO,EAAE,EAAE;YAC5C,IAAI,CAAC,kBAAkB,GAAG,IAAI,CAAC,sBAAsB,CAAC,uBAAuB,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;YAC1F,IAAI,CAAC,OAAO,CAAC,UAAU,CAAC,mBAAmB,EAAE,IAAI,CAAC,EAAE,CAAC,KAAK,CAAC,IAAI,YAAY,EAAE,CAAC,CAAC,CAAC;YAChF,MAAM,IAAI,CAAC,cAAc,EAAE,CAAC;YAC5B,IAAI,CAAC,iBAAiB,CAAC,UAAU,CAAC,IAAI,CAAC,SAAS,CAAC,iBAAiB,CAAC,CAAC;YACpE,OAAO,CAAC,IAAI,CAAC,CAAC;QAChB,CAAC,CAAC,CAAC;IACL,CAAC;IAED,cAAc;QACZ,OAAO,IAAI,OAAO,CAAC,CAAC,OAAO,EAAE,OAAO,EAAE,EAAE;YACtC,IAAI,IAAI,CAAC,SAAS,IAAI,IAAI,CAAC,SAAS,CAAC,eAAe,IAAI,IAAI,CAAC,KAAK,EAAE,CAAC;gBACnE,IAAI,CAAC,SAAS,CAAC,iBAAiB,CAAC,kBAAkB,CAAC,CAAC,OAAO,CAAC,CAAC,EAAE,EAAE,KAAK,EAAE,EAAE;oBACzE,IAAI,CAAC,sBAAsB,CAAC,EAAE,CAAC,CAAC;oBAChC,EAAE,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,GAAG,EAAE,MAAM,EAAE,EAAE;wBAChC,IAAI,CAAC,kBAAkB,CAAC,GAAG,EAAE,KAAK,CAAC,CAAC;oBACtC,CAAC,CAAC,CAAC;gBACL,CAAC,CAAC,CAAC;gBACH,OAAO,CAAC,IAAI,CAAC,CAAC;YAChB,CAAC;QACH,CAAC,CAAC,CAAC;IACL,CAAC;IAED,YAAY;IACZ,IAAI,iBAAiB;QACnB,OAAO,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,mBAAmB,CAAc,CAAC;IAC5D,CAAC;IAED,qBAAqB;IACrB,IAAI,gBAAgB;QAClB,OAAO,IAAI,CAAC,iBAAiB,CAAC,QAAQ,CAAC,kBAAkB,CAAc,CAAC;IAC1E,CAAC;IAsBD,cAAc;IACd,wBAAwB,CAAC,KAAK;QAC5B,IAAI,CAAC,KAAK,EAAE,CAAC;YACX,IAAI,CAAC,iBAAiB,GAAG,KAAK,CAAC;YAC/B,IAAI,CAAC,eAAe,GAAG,SAAS,CAAC;YACjC,OAAO;QACT,CAAC;IACH,CAAC;IAED,mBAAmB;IACnB,kBAAkB;QAChB,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,EAAE,CAAC,KAAK,CAAC,IAAI,gBAAgB,EAAE,CAAC,CAAC;QAC7D,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC;IAC9B,CAAC;IAGD,mBAAmB;IACnB,gBAAgB;QACd,MAAM,KAAK,GAAG,IAAI,CAAC,eAAe,CAAC,KAAK,CAAC;QACzC,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC,kBAAkB,CAAC,uBAAuB,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC;QAC5F,IAAI,IAAI,CAAC,kBAAkB,CAAC,WAAW,CAAC,IAAI,CAAC,cAAc,EAAE,KAAK,CAAC;YAAE,OAAO;QAC5E,IAAI,CAAC,IAAI,CAAC,eAAe,CAAC,KAAK;YAAE,OAAO;QACxC,IAAI,IAAI,CAAC,iBAAiB,EAAE,CAAC;YAC3B,MAAM,oBAAoB,GAAG,IAAI,CAAC,gBAAgB,CAAC,EAAE,CACnD,IAAI,CAAC,sBAAsB,CACf,CAAC;YACf,oBAAoB,CAAC,UAAU,CAAC;gBAC9B,GAAG,KAAK;aACT,CAAC,CAAC;QACL,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,sBAAsB,CAAC,KAAK,CAAC,CAAC;QACrC,CAAC;QACD,IAAI,CAAC,eAAe,GAAG,KAAK,CAAC;QAC7B,IAAI,CAAC,wBAAwB,CAAC,KAAK,CAAC,CAAC;IACvC,CAAC;IACD,qBAAqB;IACrB,sBAAsB,CAAC,KAAK;QAC1B,IAAI,CAAC,gBAAgB,CAAC,IAAI,CACxB,IAAI,SAAS,CAAC;YACZ,WAAW,EAAE,IAAI,WAAW,CAAC,KAAK,CAAC,WAAW,EAAE,UAAU,CAAC,QAAQ,CAAC;YACpE,IAAI,EAAE,IAAI,WAAW,CAAC,KAAK,CAAC,IAAI,EAAE,UAAU,CAAC,QAAQ,CAAC;YACtD,MAAM,EAAE,IAAI,SAAS,CAAC,EAAE,CAAC;SAC1B,CAAC,CACH,CAAC;IACJ,CAAC;IACD,WAAW;IACX,eAAe,CAAC,KAAK;QACnB,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,EAAE,CAAC,KAAK,CAAC,IAAI,gBAAgB,EAAE,CAAC,CAAC;QAC7D,IAAI,CAAC,eAAe,CAAC,UAAU,CAAC;YAC9B,GAAG,KAAK;SACT,CAAC,CAAC;QACH,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC;QAC5B,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC;IAEhC,CAAC;IAED,WAAW;IACX,iBAAiB,CAAC,KAAK;QACrB,IAAI,CAAC,gBAAgB,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;IACxC,CAAC;IAED,YAAY;IACZ,uBAAuB,CAAC,KAAK;QAC3B,IAAI,CAAC,sBAAsB,GAAG,KAAK,CAAC;IACtC,CAAC;IAED,aAAa;IACb,cAAc;QACZ,IAAI,CAAC,kBAAkB,CAAC,EAAE,EAAE,IAAI,CAAC,sBAAsB,CAAC,CAAC;QACzD,MAAM,wBAAwB,GAAG,IAAI,CAAC,gBAAgB,CAAC,EAAE,CACvD,IAAI,CAAC,sBAAsB,CACf,CAAC;QACf,MAAM,mBAAmB,GAAG,wBAAwB,CAAC,GAAG,CAAC,QAAQ,CAAc,CAAC;QAChF,IAAI,CAAC,uBAAuB,CAAC,CAAC,EAAE,mBAAmB,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC;IAClE,CAAC;IACD,kBAAkB;IAClB,kBAAkB,CAAC,QAAa,EAAE,EAAE,sBAAsB;QACxD,kBAAkB;QAClB,MAAM,wBAAwB,GAAG,IAAI,CAAC,gBAAgB,CAAC,EAAE,CAAC,sBAAsB,CAAc,CAAC;QAC/F,MAAM,mBAAmB,GAAG,wBAAwB,CAAC,GAAG,CAAC,QAAQ,CAAc,CAAC;QAChF,mBAAmB,CAAC,IAAI,CACtB,IAAI,CAAC,EAAE,CAAC,KAAK,CAAC;YACZ,qCAAqC;YACrC,WAAW,EAAE,CAAC,KAAK,CAAC,WAAW,EAAE,CAAC,UAAU,CAAC,QAAQ,CAAC,CAAC;YACvD,uBAAuB;YACvB,IAAI,EAAE,CAAC,KAAK,CAAC,IAAI,EAAE,CAAC,UAAU,CAAC,QAAQ,CAAC,CAAC;YACzC,WAAW;YACX,WAAW,EAAE,CAAC,KAAK,CAAC,WAAW,EAAE,EAAE,CAAC;YACpC,0BAA0B;YAC1B,eAAe,EAAE,CAAC,KAAK,CAAC,eAAe,IAAI,UAAU,EAAE,CAAC,UAAU,CAAC,QAAQ,CAAC,CAAC;YAC7E,QAAQ;YACR,iBAAiB,EAAE,IAAI,SAAS,CAAC,EAAE,CAAC;SACrC,CAAC,CACH,CAAC;QACF,EAAE;IACJ,CAAC;IAED,aAAa;IACb,iBAAiB,CAAC,eAAe,EAAE,KAAK;QACtC,eAAe,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;QAChC,IAAI,CAAC,sBAAsB,GAAG,CAAC,CAAC;IAClC,CAAC;IAED,aAAa;IACb,uBAAuB,CAAC,gBAAgB,EAAE,gBAAgB;QACxD,IAAI,CAAC,sBAAsB,GAAG,gBAAgB,CAAC;IACjD,CAAC;IAED,IAAI,SAAS;QACX,OAAO,IAAI,CAAC,eAAe,EAAE,GAAG,CAAC,MAAM,CAAC,CAAC;IAC3C,CAAC;IACD,IAAI,cAAc;QAChB,MAAM,wBAAwB,GAAG,IAAI,CAAC,gBAAgB,CAAC,EAAE,CACvD,IAAI,CAAC,sBAAsB,CACf,CAAC;QACf,MAAM,mBAAmB,GAAG,wBAAwB,CAAC,GAAG,CAAC,QAAQ,CAAc,CAAC;QAChF,OAAO,mBAAmB,CAAC,EAAE,CAAC,IAAI,CAAC,sBAAsB,CAAC,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC;IACzE,CAAC;IAED,8BAA8B;IAC9B,oBAAoB,CAAC,KAAK;QACxB,MAAM,KAAK,GAAG,KAAK,CAAC,MAAM,CAAC,KAAK,CAAC;QACjC,MAAM,MAAM,GAAG,IAAI,CAAC,cAAc,CAAC,eAAe,CAAC,KAAK,CAAC,CAAC;QAC1D,MAAM,SAAS,GAAG,IAAI,CAAC,SAAS,CAAC;QACjC,IAAI,SAAS,CAAC,KAAK;YAAE,OAAO;QAC5B,SAAS,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC;IAC/B,CAAC;IACD,8BAA8B;IAC9B,+BAA+B,CAAC,KAAK;QACnC,MAAM,KAAK,GAAG,KAAK,CAAC,MAAM,CAAC,KAAK,CAAC;QACjC,MAAM,MAAM,GAAG,IAAI,CAAC,cAAc,CAAC,eAAe,CAAC,KAAK,CAAC,CAAC;QAC1D,MAAM,cAAc,GAAG,IAAI,CAAC,cAAc,CAAC;QAC3C,IAAI,cAAc,CAAC,KAAK;YAAE,OAAO;QACjC,cAAc,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC;IACpC,CAAC;IAED,UAAU,CAAC,KAAK;QACd,IAAI,KAAK,CAAC,SAAS,CAAC,IAAI,KAAK,KAAK,CAAC,iBAAiB,CAAC,IAAI,EAAE,CAAC;YAC1D,eAAe,CAAC,IAAI,CAAC,gBAAgB,CAAC,QAAQ,EAAE,KAAK,CAAC,aAAa,EAAE,KAAK,CAAC,YAAY,CAAC,CAAC;YACzF,IAAI,CAAC,gBAAgB,CAAC,sBAAsB,EAAE,CAAC;YAC/C,IAAI,CAAC,sBAAsB,GAAG,KAAK,CAAC,YAAY,CAAC;QACnD,CAAC;aAAM,CAAC;YACN,MAAM,OAAO,GAAG,IAAI,CAAC,gBAAgB,CAAC,QAAQ,CAAC,IAAI,CAAC,sBAAsB,CAAC,CAAC,GAAG,CAC7E,QAAQ,CACI,CAAC;YACf,MAAM,YAAY,GAAG,OAAO,CAAC,EAAE,CAAC,KAAK,CAAC,aAAa,CAAC,CAAC;YACrD,OAAO,CAAC,QAAQ,CAAC,KAAK,CAAC,aAAa,CAAC,CAAC;YACtC,KAAK,CAAC,SAAS,CAAC,IAAI,CAAC,KAAK,CAAC,YAAY,GAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;QACnF,CAAC;QACD,IAAI,CAAC,cAAc,GAAC,KAAK,CAAC;IAC5B,CAAC;IACD,UAAU,CAAC,KAAK;QACd,MAAM,OAAO,GAAG,IAAI,CAAC,gBAAgB,CAAC,QAAQ,CAAC,IAAI,CAAC,sBAAsB,CAAC,CAAC,GAAG,CAC7E,QAAQ,CACI,CAAC;QACf,eAAe,CAAC,OAAO,CAAC,QAAQ,EAAE,KAAK,CAAC,aAAa,EAAE,KAAK,CAAC,YAAY,CAAC,CAAC;QAC3E,IAAI,CAAC,gBAAgB,CAAC,sBAAsB,EAAE,CAAC;QAC/C,IAAI,CAAC,sBAAsB,GAAG,KAAK,CAAC,YAAY,CAAC;QACjD,IAAI,CAAC,cAAc,GAAC,KAAK,CAAC;IAC5B,CAAC;IACD,aAAa,CAAC,KAAa,EAAE,IAAqB;QAChD,OAAO,KAAK,KAAG,CAAC,CAAC;IACnB,CAAC;IACD,iBAAiB;QACf,OAAO,IAAI,CAAC;IACd,CAAC;IAGD,YAAY,CAAC,KAAK;QAChB,IAAI,CAAC,cAAc,GAAC,IAAI,CAAC;IAC3B,CAAC;8GAlRU,qBAAqB;kGAArB,qBAAqB,uWCtBlC,0nWA+JA;;2FDzIa,qBAAqB;kBALjC,SAAS;+BACE,kBAAkB;gJAgBjB,IAAI;sBADd,KAAK;gBAQK,QAAQ;sBADlB,KAAK;gBAgBK,MAAM;sBADhB,KAAK;gBAMsC,WAAW;sBAAtD,SAAS;uBAAC,aAAa,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE;gBAyDc,sBAAsB;sBAA7E,SAAS;uBAAC,wBAAwB,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE","sourcesContent":["/* eslint-disable no-async-promise-executor */\n/* eslint-disable @angular-eslint/component-selector */\nimport {\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  inject,\n  Input,\n  viewChild,\n  ViewChild,\n} from '@angular/core';\nimport { FormArray, FormBuilder, FormControl, FormGroup, Validators } from '@angular/forms';\nimport { MatrixConfig, MatrixItemConfig } from './matrix-config';\nimport { CmsApiService, FieldAbstractsService } from '../../../services';\nimport { CdkDrag, CdkDragDrop, moveItemInArray, transferArrayItem } from '@angular/cdk/drag-drop';\nimport { ValidatorsService } from '@dignite-ng/expand.core';\n\n@Component({\n  selector: 'df-matrix-config',\n  templateUrl: './matrix-config.component.html',\n  styleUrls: ['./matrix-config.component.scss'],\n})\nexport class MatrixConfigComponent {\n  constructor(\n    private fb: FormBuilder,\n    private _CmsApiService: CmsApiService,\n    private _FieldAbstractsService: FieldAbstractsService\n  ) {}\n\n  /**表单控件组 */\n  _FieldControlGroup: any[];\n  /**表单控件类型 */\n  _type: any;\n  @Input()\n  public set type(v: any) {\n    this._type = v;\n  }\n\n  /**选择的表单信息 */\n  _selected: any;\n  @Input()\n  public set selected(v: any) {\n    if (v) {\n      for (const key in v.formConfiguration) {\n        if (Array.isArray(v.formConfiguration[key])) {\n          v.formConfiguration[key] = this._CmsApiService.convertKeysToCamelCase(\n            v.formConfiguration[key]\n          );\n        }\n      }\n      this._selected = v;\n    }\n  }\n  /**表单实体 */\n  _Entity: FormGroup | undefined;\n  @Input()\n  public set Entity(v: FormGroup) {\n    this._Entity = v;\n    this.dataLoaded();\n  }\n\n  @ViewChild('submitclick', { static: true }) submitclick: ElementRef;\n\n  private cdr = inject(ChangeDetectorRef);\n  async dataLoaded() {\n    if (this._Entity && this._type) {\n      await this.AfterInit();\n      this.cdr.detectChanges(); // 手动触发变更检测\n      // this.submitclick?.nativeElement?.click();\n    }\n  }\n\n  AfterInit() {\n    return new Promise(async (resolve, rejects) => {\n      this._FieldControlGroup = this._FieldAbstractsService.getExcludeAssignControl(this._type);\n      this._Entity.setControl('formConfiguration', this.fb.group(new MatrixConfig()));\n      await this.setSelectValue();\n      this.formConfiguration.patchValue(this._selected.formConfiguration);\n      resolve(true);\n    });\n  }\n\n  setSelectValue() {\n    return new Promise((resolve, rejects) => {\n      if (this._selected && this._selected.formControlName == this._type) {\n        this._selected.formConfiguration['MatrixBlockTypes'].forEach((el, index) => {\n          this.addMatrixBlockTypeItem(el);\n          el.fields.forEach((elf, indexf) => {\n            this.addMatrixFieldItem(elf, index);\n          });\n        });\n        resolve(true);\n      }\n    });\n  }\n\n  /**获取表单配置 */\n  get formConfiguration() {\n    return this._Entity.get('formConfiguration') as FormGroup;\n  }\n\n  /**获取表单配置下的矩阵块表单数组 */\n  get MatrixBlockTypes() {\n    return this.formConfiguration.controls['MatrixBlockTypes'] as FormArray;\n  }\n\n  /**模态框-状态 */\n  matrixModalOpen: boolean | any = false;\n  /**模态框-是否正在编辑 */\n  isMatrixModalEdit: any = false;\n\n  /**模态框-用于确定模态的繁忙状态是否为真 */\n  modalBusy: boolean | any = false;\n\n  /**模态框-表单 */\n  matrixModalForm: FormGroup | undefined;\n\n  /**表单控件模板-用于在form外提交submit */\n  @ViewChild('matrixModalModalSubmit', { static: false }) matrixModalModalSubmit: ElementRef;\n\n  /**矩阵块-选择的下标 */\n  selectMatrixBlockIndex: any = 0;\n\n  /**矩阵块-选择的矩阵下字段的下标 */\n  selectMatrixFieldIndex: any = 0;\n\n  /**模态框-状态改变 */\n  matrixModalVisibleChange(event) {\n    if (!event) {\n      this.isMatrixModalEdit = false;\n      this.matrixModalForm = undefined;\n      return;\n    }\n  }\n\n  /**矩阵块--新增-打开模态框 */\n  addMatrixBlockType() {\n    this.matrixModalForm = this.fb.group(new MatrixItemConfig());\n    this.matrixModalOpen = true;\n  }\n  formValidation: any;\n  private _ValidatorsService = inject(ValidatorsService);\n  /**模态框--矩阵表单保存提交 */\n  createOrEditSave() {\n    const input = this.matrixModalForm.value;\n    this.formValidation = this._ValidatorsService.getFormValidationStatus(this.matrixModalForm);\n    if (this._ValidatorsService.isCheckForm(this.formValidation, 'Cms')) return;\n    if (!this.matrixModalForm.valid) return;\n    if (this.isMatrixModalEdit) {\n      const MatrixBlockTypesItem = this.MatrixBlockTypes.at(\n        this.selectMatrixBlockIndex\n      ) as FormGroup;\n      MatrixBlockTypesItem.patchValue({\n        ...input,\n      });\n    } else {\n      this.addMatrixBlockTypeItem(input);\n    }\n    this.matrixModalOpen = false;\n    this.matrixModalVisibleChange(false);\n  }\n  /**新增矩阵块-向数组表单中增加项 */\n  addMatrixBlockTypeItem(input) {\n    this.MatrixBlockTypes.push(\n      new FormGroup({\n        displayName: new FormControl(input.displayName, Validators.required),\n        name: new FormControl(input.name, Validators.required),\n        fields: new FormArray([]),\n      })\n    );\n  }\n  /**编辑矩阵块 */\n  EditMatrixBlock(input) {\n    this.matrixModalForm = this.fb.group(new MatrixItemConfig());\n    this.matrixModalForm.patchValue({\n      ...input,\n    });\n    this.matrixModalOpen = true;\n    this.isMatrixModalEdit = true;\n   \n  }\n\n  /**删除矩阵块 */\n  DeleteMatrixBlock(index) {\n    this.MatrixBlockTypes.removeAt(index);\n  }\n\n  /**矩阵块-选择 */\n  selectMatrixBlockChange(index) {\n    this.selectMatrixBlockIndex = index;\n  }\n\n  /**矩阵字段-新增 */\n  addMatrixField() {\n    this.addMatrixFieldItem('', this.selectMatrixBlockIndex);\n    const MatrixBlockTypesItemForm = this.MatrixBlockTypes.at(\n      this.selectMatrixBlockIndex\n    ) as FormGroup;\n    const MatrixFieldItemForm = MatrixBlockTypesItemForm.get('fields') as FormArray;\n    this.selectMatrixFieldChange(0, MatrixFieldItemForm.length - 1);\n  }\n  /**矩阵字段-新增矩阵字段项 */\n  addMatrixFieldItem(input: any = '', selectMatrixBlockIndex) {\n    /**矩阵下标的矩阵项Form */\n    const MatrixBlockTypesItemForm = this.MatrixBlockTypes.at(selectMatrixBlockIndex) as FormGroup;\n    const MatrixFieldItemForm = MatrixBlockTypesItemForm.get('fields') as FormArray;\n    MatrixFieldItemForm.push(\n      this.fb.group({\n        /**字段名称 Display name of this field */\n        displayName: [input.displayName, [Validators.required]],\n        /**字段唯一名称 Unique Name*/\n        name: [input.name, [Validators.required]],\n        /**描述 说明 */\n        description: [input.description, []],\n        /**FieldType字段类型 表单控件名称 */\n        formControlName: [input.formControlName || 'TextEdit', [Validators.required]],\n        //动态表单配置\n        formConfiguration: new FormGroup({}),\n      })\n    );\n    //\n  }\n\n  /**删除矩阵字段项 */\n  deleteMatrixField(MatrixFieldForm, index) {\n    MatrixFieldForm.removeAt(index);\n    this.selectMatrixFieldIndex = 0;\n  }\n\n  /**矩阵字段-选择 */\n  selectMatrixFieldChange(MatrixBlockIndex, MatrixFieldIndex) {\n    this.selectMatrixFieldIndex = MatrixFieldIndex;\n  }\n\n  get nameInput() {\n    return this.matrixModalForm?.get('name');\n  }\n  get FieldnameInput() {\n    const MatrixBlockTypesItemForm = this.MatrixBlockTypes.at(\n      this.selectMatrixBlockIndex\n    ) as FormGroup;\n    const MatrixFieldItemForm = MatrixBlockTypesItemForm.get('fields') as FormArray;\n    return MatrixFieldItemForm.at(this.selectMatrixFieldIndex).get('name');\n  }\n\n  /**矩阵displayNameInput字段失去焦点 */\n  displayNameInputBlur(event) {\n    const value = event.target.value;\n    const pinyin = this._CmsApiService.chineseToPinyin(value);\n    const nameInput = this.nameInput;\n    if (nameInput.value) return;\n    nameInput.patchValue(pinyin);\n  }\n  /**矩阵displayNameInput字段失去焦点 */\n  MatrixFieldDisplayNameInputBlur(event) {\n    const value = event.target.value;\n    const pinyin = this._CmsApiService.chineseToPinyin(value);\n    const FieldnameInput = this.FieldnameInput;\n    if (FieldnameInput.value) return;\n    FieldnameInput.patchValue(pinyin);\n  }\n\n  dropMatrix(event) {\n    if (event.container.data === event.previousContainer.data) {\n      moveItemInArray(this.MatrixBlockTypes.controls, event.previousIndex, event.currentIndex);\n      this.MatrixBlockTypes.updateValueAndValidity();\n      this.selectMatrixBlockIndex = event.currentIndex;\n    } else {\n      const object1 = this.MatrixBlockTypes.controls[this.selectMatrixBlockIndex].get(\n        'fields'\n      ) as FormArray;\n      const controlsItem = object1.at(event.previousIndex);\n      object1.removeAt(event.previousIndex);\n      event.container.data[event.currentIndex-1].controls['fields'].push(controlsItem);\n    }\n    this.fieldStartDrag=false;\n  }\n  dropFields(event) {\n    const object1 = this.MatrixBlockTypes.controls[this.selectMatrixBlockIndex].get(\n      'fields'\n    ) as FormArray;\n    moveItemInArray(object1.controls, event.previousIndex, event.currentIndex);\n    this.MatrixBlockTypes.updateValueAndValidity();\n    this.selectMatrixFieldIndex = event.currentIndex;\n    this.fieldStartDrag=false;\n  }\n  sortPredicate(index: number, item: CdkDrag<number>) {\n    return index!==0;\n  }\n  sortPredicateTrue(){\n    return true;\n  }\n  /**字段开始拖拽 */\n  fieldStartDrag:any=false;\n  CdkDragStart(event) {\n    this.fieldStartDrag=true;\n  }\n}\n","<div [formGroup]=\"_Entity\">\n    <div formGroupName=\"formConfiguration\">\n        <div class=\"mb-3\">\n            <label class=\"form-label\">{{'Cms::::FormControl:Matrix' | abpLocalization}}</label>\n            <div class=\"row\" >\n                <div class=\"col-md-3\">\n                    <div class=\"list-group\" [class.fieldStartDragClass]=\"fieldStartDrag\" cdkDropList (cdkDropListDropped)=\"dropMatrix($event)\"     #todoList=\"cdkDropList\"\n                    [cdkDropListData]=\"MatrixBlockTypes.controls\" [cdkDropListSortPredicate]=\"fieldStartDrag?sortPredicate:sortPredicateTrue\"> \n                        <li class=\"list-group-item d-flex align-items-center justify-content-between\"\n                            aria-current=\"true\">\n                            {{'Cms::MatrixBlockType' | abpLocalization}}\n                            <button class=\"btn btn-light btn-sm p-0\" type=\"button\" (click.stop)=\"addMatrixBlockType()\">\n                                <i class=\"fas fa-plus-circle p-1\"></i>\n                            </button>\n                        </li>\n                        <ng-container *ngFor=\"let item of MatrixBlockTypes.controls;let i =index\">\n                            <button type=\"button\" (click.stop)=\"selectMatrixBlockChange(i)\"\n                                class=\"list-group-item d-flex align-items-center justify-content-between list-group-item-action pe-2\"\n                                [class.active]=\"i===selectMatrixBlockIndex\" cdkDrag>\n                                <div style=\"line-break: anywhere;\">\n                                    <div>{{item.value.displayName}}</div>\n                                    <div>{{item.value.name}}</div>\n                                </div>\n                                <div class=\"d-flex align-items-center justify-content-between\">\n                                    <div ngbDropdown class=\"d-inline-block\">\n                                        <button type=\"button\" class=\"btn btn-light btn-sm me-2\" id=\"dropdownBasic1\"\n                                            style=\"z-index: 8;\" ngbDropdownToggle></button>\n                                        <div ngbDropdownMenu aria-labelledby=\"dropdownBasic1\" style=\"z-index: 9;\">\n                                            <button ngbDropdownItem type=\"button\"\n                                                (click.stop)=\"EditMatrixBlock(item.value)\">{{'AbpUi::Edit' |\n                                                abpLocalization}}</button>\n                                            <button ngbDropdownItem type=\"button\"\n                                                (click.stop)=\"DeleteMatrixBlock(i)\">{{'AbpUi::Delete' |\n                                                abpLocalization}}</button>\n                                        </div>\n                                    </div>\n                                    <span class=\"bi bi-arrows-move fs-5 drag-handle\" cdkDragHandle></span>\n                                </div>\n                            </button>\n                        </ng-container>\n                    </div>\n                </div>\n                <div class=\"col-md-3\">\n                    <div class=\"list-group\" *ngIf=\"MatrixBlockTypes?.controls.length>0\" cdkDropList\n                        (cdkDropListDropped)=\"dropFields($event)\"  [cdkDropListData]=\"MatrixBlockTypes.controls[selectMatrixBlockIndex].get('fields').controls\" [cdkDropListConnectedTo]=\"[todoList]\">\n                        <li class=\"list-group-item d-flex align-items-center justify-content-between\"\n                            aria-current=\"true\">\n                            {{'Cms::Fields' | abpLocalization}}\n                            <button class=\"btn btn-light btn-sm p-0\" type=\"button\" (click.stop)=\"addMatrixField()\">\n                                <i class=\"fas fa-plus-circle p-1\"></i>\n                            </button>\n                        </li>\n                        <ng-container *ngFor=\"let item of MatrixBlockTypes.controls;let i =index\">\n                            <ng-container *ngIf=\"i === selectMatrixBlockIndex\">\n                                <ng-container *ngFor=\"let el of item.controls['fields'].controls;let fi =index\">\n                                    <button type=\"button\" (click.stop)=\"selectMatrixFieldChange(i,fi)\"\n                                        class=\"list-group-item d-flex align-items-center justify-content-between list-group-item-action pe-2\"\n                                        [class.active]=\"fi===selectMatrixFieldIndex\" cdkDrag (cdkDragStarted)=\"CdkDragStart($event)\">\n                                        <div style=\"line-break: anywhere;\">\n                                            <div>{{el.value.displayName}}</div>\n                                            <div>{{el.value.name}}</div>\n                                        </div>\n                                        <div class=\"d-flex align-items-center justify-content-between\">\n                                            <button type=\"button\"\n                                                (click.stop)=\"deleteMatrixField(item.controls['fields'],fi)\"\n                                                class=\"btn btn-sm btn-li\">{{'AbpUi::Delete' | abpLocalization}}</button>\n                                            <span class=\"bi bi-arrows-move fs-5 drag-handle\" cdkDragHandle></span>\n                                        </div>\n                                    </button>\n                                </ng-container>\n                            </ng-container>\n                        </ng-container>\n                    </div>\n                </div>\n                <div class=\"col-md-6\" formArrayName=\"MatrixBlockTypes\">\n                    <ng-container *ngFor=\"let item of MatrixBlockTypes.controls;let i =index\">\n                        <div [formGroupName]=\"i\" [hidden]=\"i !== selectMatrixBlockIndex\">\n                            <div formArrayName=\"fields\">\n                                <ng-container *ngFor=\"let itemf of item.controls['fields'].controls;let fi =index\">\n                                    <div [formGroupName]=\"fi\" [hidden]=\"fi !== selectMatrixFieldIndex\">\n                                        <div class=\"mb-3\">\n                                            <label class=\"form-label\" for=\"displayName\">{{'Cms::DisplayName' |\n                                                abpLocalization}}</label>\n                                            <input type=\"text\" class=\"form-control\" formControlName=\"displayName\"\n                                                (blur)=\"MatrixFieldDisplayNameInputBlur($event)\">\n                                        </div>\n                                        <div class=\"mb-3\">\n                                            <label class=\"form-label\" for=\"name\">{{'AbpDynamicForm::FieldName' |\n                                                abpLocalization}}</label>\n                                            <input type=\"text\" class=\"form-control\" formControlName=\"name\">\n                                            <small class=\"form-text text-muted d-block\">\n                                                {{'AbpDynamicForm::FieldNameHelpText' | abpLocalization}}</small>\n                                        </div>\n                                        <div class=\"mb-3\">\n                                            <label class=\"form-label\" for=\"description\">{{'Cms::Description' |\n                                                abpLocalization}}</label>\n                                            <input type=\"text\" class=\"form-control\" formControlName=\"description\">\n                                        </div>\n                                        <div class=\"mb-3\">\n                                            <label class=\"form-label\" for=\"formControlName\">{{'Cms::FieldType' |\n                                                abpLocalization}}</label>\n                                            <select class=\"form-select\" formControlName=\"formControlName\">\n                                                <ng-container *ngFor=\"let itemC of _FieldControlGroup;let i =index\">\n                                                    <option [value]=\"itemC.name\">{{itemC.displayName}}</option>\n                                                </ng-container>\n                                            </select>\n                                        </div>\n                                        <ng-container *ngIf=\"itemf.value.formControlName&&itemf\">\n                                            <df-dynamic [type]=\"itemf.value.formControlName\"\n                                                [selected]=\"_selected?_selected.formConfiguration?.MatrixBlockTypes[i]?.fields[fi]:''\"\n                                                [entity]=\"itemf\"></df-dynamic>\n\n                                        </ng-container>\n                                    </div>\n                                </ng-container>\n                            </div>\n                        </div>\n                    </ng-container>\n                </div>\n\n            </div>\n        </div>\n        <button type=\"submit\" (abpInit)=\"submitclick?.nativeElement?.click()\" style=\"display: none;\"\n            #submitclick></button>\n    </div>\n</div>\n\n\n\n<abp-modal [(visible)]=\"matrixModalOpen\" [busy]=\"modalBusy\" (visibleChange)=\"matrixModalVisibleChange($event)\">\n    <ng-template #abpHeader>\n        <h3>{{isMatrixEdit?('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=\"matrixModalForm; else loaderRef\">\n            <form [formGroup]=\"matrixModalForm\" (submit)=\"createOrEditSave()\">\n                <button type=\"submit\" #matrixModalModalSubmit style=\"display: none\"></button>\n                <div class=\"mb-3\">\n                    <label class=\"form-label\" for=\"displayName\">{{'Cms::DisplayName' | abpLocalization}}</label>\n                    <input type=\"text\" class=\"form-control\" formControlName=\"displayName\"\n                        (blur)=\"displayNameInputBlur($event)\">\n                </div>\n                <div class=\"mb-3\">\n                    <label class=\"form-label\" for=\"name\">{{'Cms::Name' | abpLocalization}}</label>\n                    <input type=\"text\" class=\"form-control\" formControlName=\"name\">\n                </div>\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        <abp-button iconClass=\"fa fa-check\" (click)=\"matrixModalModalSubmit.nativeElement.click()\">{{'AbpUi::Save' |\n            abpLocalization}}</abp-button>\n    </ng-template>\n</abp-modal>\n\n"]}
|