@pega/angular-sdk-components 0.23.9 → 0.23.10
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/_bridge/angular-pconnect.mjs +14 -2
- package/esm2022/lib/_components/field/auto-complete/auto-complete.component.mjs +4 -2
- package/esm2022/lib/_components/field/check-box/check-box.component.mjs +5 -4
- package/esm2022/lib/_components/field/currency/currency.component.mjs +5 -2
- package/esm2022/lib/_components/field/date/date.component.mjs +5 -2
- package/esm2022/lib/_components/field/date-time/date-time.component.mjs +4 -5
- package/esm2022/lib/_components/field/dropdown/dropdown.component.mjs +1 -5
- package/esm2022/lib/_components/field/email/email.component.mjs +5 -3
- package/esm2022/lib/_components/field/integer/integer.component.mjs +5 -3
- package/esm2022/lib/_components/field/percentage/percentage.component.mjs +5 -3
- package/esm2022/lib/_components/field/phone/phone.component.mjs +4 -3
- package/esm2022/lib/_components/field/radio-buttons/radio-buttons.component.mjs +5 -6
- package/esm2022/lib/_components/field/text-area/text-area.component.mjs +5 -7
- package/esm2022/lib/_components/field/text-input/text-input.component.mjs +5 -3
- package/esm2022/lib/_components/field/time/time.component.mjs +5 -4
- package/esm2022/lib/_components/field/url/url.component.mjs +5 -3
- package/esm2022/lib/_components/field/user-reference/user-reference.component.mjs +5 -6
- package/esm2022/lib/_components/infra/Containers/modal-view-container/modal-view-container.component.mjs +2 -8
- package/esm2022/lib/_components/infra/reference/reference.component.mjs +14 -11
- package/esm2022/lib/_components/infra/root-container/root-container.component.mjs +3 -13
- package/esm2022/lib/_components/template/default-form/default-form.component.mjs +39 -8
- package/esm2022/lib/_components/template/field-group-template/field-group-template.component.mjs +2 -2
- package/fesm2022/pega-angular-sdk-components.mjs +109 -79
- package/fesm2022/pega-angular-sdk-components.mjs.map +1 -1
- package/lib/_bridge/angular-pconnect.d.ts +2 -0
- package/lib/_components/field/dropdown/dropdown.component.d.ts +0 -1
- package/lib/_components/field/radio-buttons/radio-buttons.component.d.ts +0 -1
- package/lib/_components/field/text-area/text-area.component.d.ts +0 -1
- package/lib/_components/infra/Containers/modal-view-container/modal-view-container.component.d.ts +1 -2
- package/lib/_components/infra/root-container/root-container.component.d.ts +0 -1
- package/lib/_components/template/default-form/default-form.component.d.ts +9 -3
- package/package.json +1 -1
|
@@ -3,11 +3,25 @@ import { CommonModule } from '@angular/common';
|
|
|
3
3
|
import { ReferenceComponent } from '../../infra/reference/reference.component';
|
|
4
4
|
import { ComponentMapperComponent } from '../../../_bridge/component-mapper/component-mapper.component';
|
|
5
5
|
import * as i0 from "@angular/core";
|
|
6
|
-
import * as i1 from "../../../
|
|
7
|
-
import * as i2 from "
|
|
6
|
+
import * as i1 from "../../../_bridge/angular-pconnect";
|
|
7
|
+
import * as i2 from "../../../_helpers/template-utils";
|
|
8
|
+
import * as i3 from "@angular/common";
|
|
9
|
+
function areViewsChanged(oldViews, newViews) {
|
|
10
|
+
if (oldViews.length !== newViews.length) {
|
|
11
|
+
return true;
|
|
12
|
+
}
|
|
13
|
+
return !oldViews.every((oldView, index) => {
|
|
14
|
+
const newView = newViews[index];
|
|
15
|
+
return oldView.getPConnect().viewName === newView.getPConnect().viewName;
|
|
16
|
+
});
|
|
17
|
+
}
|
|
8
18
|
export class DefaultFormComponent {
|
|
9
|
-
constructor(templateUtils) {
|
|
19
|
+
constructor(angularPConnect, templateUtils) {
|
|
20
|
+
this.angularPConnect = angularPConnect;
|
|
10
21
|
this.templateUtils = templateUtils;
|
|
22
|
+
// Used with AngularPConnect
|
|
23
|
+
this.angularPConnectData = {};
|
|
24
|
+
this.arChildren$ = [];
|
|
11
25
|
this.NO_HEADER_TEMPLATES = [
|
|
12
26
|
'SubTabs',
|
|
13
27
|
'SimpleTable',
|
|
@@ -20,6 +34,19 @@ export class DefaultFormComponent {
|
|
|
20
34
|
];
|
|
21
35
|
}
|
|
22
36
|
ngOnInit() {
|
|
37
|
+
// First thing in initialization is registering and subscribing to the AngularPConnect service
|
|
38
|
+
this.angularPConnectData = this.angularPConnect.registerAndSubscribeComponent(this, this.onStateChange);
|
|
39
|
+
this.updateSelf();
|
|
40
|
+
}
|
|
41
|
+
ngOnDestroy() {
|
|
42
|
+
if (this.angularPConnectData.unsubscribeFn) {
|
|
43
|
+
this.angularPConnectData.unsubscribeFn();
|
|
44
|
+
}
|
|
45
|
+
}
|
|
46
|
+
onStateChange() {
|
|
47
|
+
this.updateSelf();
|
|
48
|
+
}
|
|
49
|
+
updateSelf() {
|
|
23
50
|
const configProps = this.pConn$.getConfigProps();
|
|
24
51
|
this.template = configProps?.template;
|
|
25
52
|
const propToUse = { ...this.pConn$.getInheritedProps() };
|
|
@@ -45,17 +72,21 @@ export class DefaultFormComponent {
|
|
|
45
72
|
// repoint children before getting templateArray
|
|
46
73
|
// Children may contain 'reference' component, so we need to
|
|
47
74
|
// normalize them
|
|
48
|
-
|
|
75
|
+
const children = ReferenceComponent.normalizePConnArray(kids[0].getPConnect().getChildren());
|
|
76
|
+
const visibleChildren = children.filter(child => child !== undefined);
|
|
77
|
+
if (areViewsChanged(this.arChildren$, visibleChildren)) {
|
|
78
|
+
this.arChildren$ = visibleChildren;
|
|
79
|
+
}
|
|
49
80
|
}
|
|
50
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DefaultFormComponent, deps: [{ token: i1.TemplateUtils }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
51
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: DefaultFormComponent, isStandalone: true, selector: "app-default-form", inputs: { pConn$: "pConn$", formGroup$: "formGroup$" }, ngImport: i0, template: "<!-- When adding a component here, add the same component in 'region' template as well -->\n<div *ngIf=\"!NO_HEADER_TEMPLATES.includes(template) && showLabel\">\n <div class=\"template-title-container\">{{ label }}</div>\n</div>\n<div *ngIf=\"instructions\" class=\"psdk-default-form-instruction-text\">\n <div key=\"instructions\" id=\"instruction-text\" [innerHTML]=\"instructions\"></div>\n</div>\n<div [className]=\"divClass$\">\n <div *ngFor=\"let kid of arChildren$\" [ngClass]=\"{ 'grid-column': kid.getPConnect().getComponentName() === 'View' }\">\n <component-mapper\n [name]=\"kid.getPConnect().getComponentName()\"\n [props]=\"{\n pConn$: kid.getPConnect(),\n formGroup$: formGroup$\n }\"\n errorMsg=\"DefaultForm wants component not yet available: {{ kid.getPConnect().getComponentName() }}\"\n ></component-mapper>\n </div>\n</div>\n", styles: [".psdk-default-form-one-column{display:grid;grid-template-columns:repeat(1,minmax(0,1fr));column-gap:1rem}.psdk-default-form-two-column{display:grid;grid-template-columns:repeat(2,1fr);column-gap:1rem}.psdk-default-form-three-column{display:grid;grid-template-columns:repeat(3,1fr);column-gap:1rem}.psdk-default-form-three-column .grid-column{grid-column:1/span 3}.psdk-default-form-two-column .grid-column{grid-column:1/span 2}.psdk-default-form-one-column .grid-column{grid-column:1}.template-title-container{font-size:.9375rem;font-weight:600;margin:10px 0}.psdk-default-form-instruction-text{padding-top:.625rem;padding-bottom:.625rem}\n"], dependencies: [{ kind: "ngmodule", type: i0.forwardRef(function () { return CommonModule; }) }, { kind: "directive", type: i0.forwardRef(function () { return
|
|
81
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DefaultFormComponent, deps: [{ token: i1.AngularPConnectService }, { token: i2.TemplateUtils }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
82
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: DefaultFormComponent, isStandalone: true, selector: "app-default-form", inputs: { pConn$: "pConn$", formGroup$: "formGroup$" }, ngImport: i0, template: "<!-- When adding a component here, add the same component in 'region' template as well -->\n<div *ngIf=\"!NO_HEADER_TEMPLATES.includes(template) && showLabel\">\n <div class=\"template-title-container\">{{ label }}</div>\n</div>\n<div *ngIf=\"instructions\" class=\"psdk-default-form-instruction-text\">\n <div key=\"instructions\" id=\"instruction-text\" [innerHTML]=\"instructions\"></div>\n</div>\n<div [className]=\"divClass$\">\n <div *ngFor=\"let kid of arChildren$\" [ngClass]=\"{ 'grid-column': kid.getPConnect().getComponentName() === 'View' }\">\n <component-mapper\n [name]=\"kid.getPConnect().getComponentName()\"\n [props]=\"{\n pConn$: kid.getPConnect(),\n formGroup$: formGroup$\n }\"\n errorMsg=\"DefaultForm wants component not yet available: {{ kid.getPConnect().getComponentName() }}\"\n ></component-mapper>\n </div>\n</div>\n", styles: [".psdk-default-form-one-column{display:grid;grid-template-columns:repeat(1,minmax(0,1fr));column-gap:1rem}.psdk-default-form-two-column{display:grid;grid-template-columns:repeat(2,1fr);column-gap:1rem}.psdk-default-form-three-column{display:grid;grid-template-columns:repeat(3,1fr);column-gap:1rem}.psdk-default-form-three-column .grid-column{grid-column:1/span 3}.psdk-default-form-two-column .grid-column{grid-column:1/span 2}.psdk-default-form-one-column .grid-column{grid-column:1}.template-title-container{font-size:.9375rem;font-weight:600;margin:10px 0}.psdk-default-form-instruction-text{padding-top:.625rem;padding-bottom:.625rem}\n"], dependencies: [{ kind: "ngmodule", type: i0.forwardRef(function () { return CommonModule; }) }, { kind: "directive", type: i0.forwardRef(function () { return i3.NgClass; }), selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i0.forwardRef(function () { return i3.NgForOf; }), selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i0.forwardRef(function () { return i3.NgIf; }), selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i0.forwardRef(function () { return ComponentMapperComponent; }), selector: "component-mapper", inputs: ["name", "props", "errorMsg", "outputEvents", "parent"] }] }); }
|
|
52
83
|
}
|
|
53
84
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DefaultFormComponent, decorators: [{
|
|
54
85
|
type: Component,
|
|
55
86
|
args: [{ selector: 'app-default-form', standalone: true, imports: [CommonModule, forwardRef(() => ComponentMapperComponent)], template: "<!-- When adding a component here, add the same component in 'region' template as well -->\n<div *ngIf=\"!NO_HEADER_TEMPLATES.includes(template) && showLabel\">\n <div class=\"template-title-container\">{{ label }}</div>\n</div>\n<div *ngIf=\"instructions\" class=\"psdk-default-form-instruction-text\">\n <div key=\"instructions\" id=\"instruction-text\" [innerHTML]=\"instructions\"></div>\n</div>\n<div [className]=\"divClass$\">\n <div *ngFor=\"let kid of arChildren$\" [ngClass]=\"{ 'grid-column': kid.getPConnect().getComponentName() === 'View' }\">\n <component-mapper\n [name]=\"kid.getPConnect().getComponentName()\"\n [props]=\"{\n pConn$: kid.getPConnect(),\n formGroup$: formGroup$\n }\"\n errorMsg=\"DefaultForm wants component not yet available: {{ kid.getPConnect().getComponentName() }}\"\n ></component-mapper>\n </div>\n</div>\n", styles: [".psdk-default-form-one-column{display:grid;grid-template-columns:repeat(1,minmax(0,1fr));column-gap:1rem}.psdk-default-form-two-column{display:grid;grid-template-columns:repeat(2,1fr);column-gap:1rem}.psdk-default-form-three-column{display:grid;grid-template-columns:repeat(3,1fr);column-gap:1rem}.psdk-default-form-three-column .grid-column{grid-column:1/span 3}.psdk-default-form-two-column .grid-column{grid-column:1/span 2}.psdk-default-form-one-column .grid-column{grid-column:1}.template-title-container{font-size:.9375rem;font-weight:600;margin:10px 0}.psdk-default-form-instruction-text{padding-top:.625rem;padding-bottom:.625rem}\n"] }]
|
|
56
|
-
}], ctorParameters: function () { return [{ type: i1.TemplateUtils }]; }, propDecorators: { pConn$: [{
|
|
87
|
+
}], ctorParameters: function () { return [{ type: i1.AngularPConnectService }, { type: i2.TemplateUtils }]; }, propDecorators: { pConn$: [{
|
|
57
88
|
type: Input
|
|
58
89
|
}], formGroup$: [{
|
|
59
90
|
type: Input
|
|
60
91
|
}] } });
|
|
61
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGVmYXVsdC1mb3JtLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2FuZ3VsYXItc2RrLWNvbXBvbmVudHMvc3JjL2xpYi9fY29tcG9uZW50cy90ZW1wbGF0ZS9kZWZhdWx0LWZvcm0vZGVmYXVsdC1mb3JtLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2FuZ3VsYXItc2RrLWNvbXBvbmVudHMvc3JjL2xpYi9fY29tcG9uZW50cy90ZW1wbGF0ZS9kZWZhdWx0LWZvcm0vZGVmYXVsdC1mb3JtLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQVUsS0FBSyxFQUFFLFVBQVUsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUNyRSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFFL0MsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sMkNBQTJDLENBQUM7QUFDL0UsT0FBTyxFQUFFLHdCQUF3QixFQUFFLE1BQU0sOERBQThELENBQUM7Ozs7QUFpQnhHLE1BQU0sT0FBTyxvQkFBb0I7SUFzQi9CLFlBQW9CLGFBQTRCO1FBQTVCLGtCQUFhLEdBQWIsYUFBYSxDQUFlO1FBWGhELHdCQUFtQixHQUFHO1lBQ3BCLFNBQVM7WUFDVCxhQUFhO1lBQ2IsU0FBUztZQUNULGtCQUFrQjtZQUNsQixvQkFBb0I7WUFDcEIsbUJBQW1CO1lBQ25CLG1CQUFtQjtZQUNuQixjQUFjO1NBQ2YsQ0FBQztJQUVpRCxDQUFDO0lBRXBELFFBQVE7UUFDTixNQUFNLFdBQVcsR0FBRyxJQUFJLENBQUMsTUFBTSxDQUFDLGNBQWMsRUFBc0IsQ0FBQztRQUNyRSxJQUFJLENBQUMsUUFBUSxHQUFHLFdBQVcsRUFBRSxRQUFRLENBQUM7UUFDdEMsTUFBTSxTQUFTLEdBQVEsRUFBRSxHQUFHLElBQUksQ0FBQyxNQUFNLENBQUMsaUJBQWlCLEVBQUUsRUFBRSxDQUFDO1FBQzlELElBQUksQ0FBQyxTQUFTLEdBQUcsU0FBUyxFQUFFLFNBQVMsQ0FBQztRQUN0QyxJQUFJLENBQUMsS0FBSyxHQUFHLFNBQVMsRUFBRSxLQUFLLENBQUM7UUFDOUIsTUFBTSxJQUFJLEdBQUcsSUFBSSxDQUFDLE1BQU0sQ0FBQyxXQUFXLEVBQVcsQ0FBQztRQUNoRCxJQUFJLENBQUMsWUFBWSxHQUFHLElBQUksQ0FBQyxhQUFhLENBQUMsZUFBZSxDQUFDLElBQUksQ0FBQyxNQUFNLEVBQUUsV0FBVyxFQUFFLFlBQVksQ0FBQyxDQUFDO1FBRS9GLE1BQU0sT0FBTyxHQUFHLFdBQVcsQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFDLFdBQVcsQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFDLEdBQUcsQ0FBQztRQUNoRSxRQUFRLE9BQU8sRUFBRTtZQUNmLEtBQUssR0FBRztnQkFDTixJQUFJLENBQUMsU0FBUyxHQUFHLDhCQUE4QixDQUFDO2dCQUNoRCxNQUFNO1lBQ1IsS0FBSyxHQUFHO2dCQUNOLElBQUksQ0FBQyxTQUFTLEdBQUcsOEJBQThCLENBQUM7Z0JBQ2hELE1BQU07WUFDUixLQUFLLEdBQUc7Z0JBQ04sSUFBSSxDQUFDLFNBQVMsR0FBRyxnQ0FBZ0MsQ0FBQztnQkFDbEQsTUFBTTtZQUNSO2dCQUNFLElBQUksQ0FBQyxTQUFTLEdBQUcsOEJBQThCLENBQUM7Z0JBQ2hELE1BQU07U0FDVDtRQUVELGdEQUFnRDtRQUNoRCw0REFBNEQ7UUFDNUQsa0JBQWtCO1FBQ2xCLElBQUksQ0FBQyxXQUFXLEdBQUcsa0JBQWtCLENBQUMsbUJBQW1CLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxDQUFDLFdBQVcsRUFBRSxDQUFDLFdBQVcsRUFBRSxDQUFDLENBQUM7SUFDakcsQ0FBQzsrR0FyRFUsb0JBQW9CO21HQUFwQixvQkFBb0Isb0lDckJqQyw0M0JBbUJBLDR0QkRBWSxZQUFZLDBmQUFtQix3QkFBd0I7OzRGQUV0RCxvQkFBb0I7a0JBUGhDLFNBQVM7K0JBQ0Usa0JBQWtCLGNBR2hCLElBQUksV0FDUCxDQUFDLFlBQVksRUFBRSxVQUFVLENBQUMsR0FBRyxFQUFFLENBQUMsd0JBQXdCLENBQUMsQ0FBQztvR0FHMUQsTUFBTTtzQkFBZCxLQUFLO2dCQUNHLFVBQVU7c0JBQWxCLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIE9uSW5pdCwgSW5wdXQsIGZvcndhcmRSZWYgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQgeyBGb3JtR3JvdXAgfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XG5pbXBvcnQgeyBSZWZlcmVuY2VDb21wb25lbnQgfSBmcm9tICcuLi8uLi9pbmZyYS9yZWZlcmVuY2UvcmVmZXJlbmNlLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBDb21wb25lbnRNYXBwZXJDb21wb25lbnQgfSBmcm9tICcuLi8uLi8uLi9fYnJpZGdlL2NvbXBvbmVudC1tYXBwZXIvY29tcG9uZW50LW1hcHBlci5jb21wb25lbnQnO1xuaW1wb3J0IHsgVGVtcGxhdGVVdGlscyB9IGZyb20gJy4uLy4uLy4uL19oZWxwZXJzL3RlbXBsYXRlLXV0aWxzJztcblxuaW50ZXJmYWNlIERlZmF1bHRGb3JtUHJvcHMge1xuICAvLyBJZiBhbnksIGVudGVyIGFkZGl0aW9uYWwgcHJvcHMgdGhhdCBvbmx5IGV4aXN0IG9uIHRoaXMgY29tcG9uZW50XG4gIE51bUNvbHM6IHN0cmluZztcbiAgdGVtcGxhdGU6IHN0cmluZztcbiAgaW5zdHJ1Y3Rpb25zOiBzdHJpbmc7XG59XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ2FwcC1kZWZhdWx0LWZvcm0nLFxuICB0ZW1wbGF0ZVVybDogJy4vZGVmYXVsdC1mb3JtLmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmxzOiBbJy4vZGVmYXVsdC1mb3JtLmNvbXBvbmVudC5zY3NzJ10sXG4gIHN0YW5kYWxvbmU6IHRydWUsXG4gIGltcG9ydHM6IFtDb21tb25Nb2R1bGUsIGZvcndhcmRSZWYoKCkgPT4gQ29tcG9uZW50TWFwcGVyQ29tcG9uZW50KV1cbn0pXG5leHBvcnQgY2xhc3MgRGVmYXVsdEZvcm1Db21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQge1xuICBASW5wdXQoKSBwQ29ubiQ6IHR5cGVvZiBQQ29ubmVjdDtcbiAgQElucHV0KCkgZm9ybUdyb3VwJDogRm9ybUdyb3VwO1xuXG4gIGFyQ2hpbGRyZW4kOiBhbnlbXTtcbiAgZGl2Q2xhc3MkOiBzdHJpbmc7XG4gIHRlbXBsYXRlOiBhbnk7XG4gIHNob3dMYWJlbDogYW55O1xuICBsYWJlbDogYW55O1xuICBpbnN0cnVjdGlvbnM6IHN0cmluZztcblxuICBOT19IRUFERVJfVEVNUExBVEVTID0gW1xuICAgICdTdWJUYWJzJyxcbiAgICAnU2ltcGxlVGFibGUnLFxuICAgICdEZXRhaWxzJyxcbiAgICAnRGV0YWlsc1R3b0NvbHVtbicsXG4gICAgJ0RldGFpbHNUaHJlZUNvbHVtbicsXG4gICAgJ05hcnJvd1dpZGVEZXRhaWxzJyxcbiAgICAnV2lkZU5hcnJvd0RldGFpbHMnLFxuICAgICdDb25maXJtYXRpb24nXG4gIF07XG5cbiAgY29uc3RydWN0b3IocHJpdmF0ZSB0ZW1wbGF0ZVV0aWxzOiBUZW1wbGF0ZVV0aWxzKSB7fVxuXG4gIG5nT25Jbml0KCk6IHZvaWQge1xuICAgIGNvbnN0IGNvbmZpZ1Byb3BzID0gdGhpcy5wQ29ubiQuZ2V0Q29uZmlnUHJvcHMoKSBhcyBEZWZhdWx0Rm9ybVByb3BzO1xuICAgIHRoaXMudGVtcGxhdGUgPSBjb25maWdQcm9wcz8udGVtcGxhdGU7XG4gICAgY29uc3QgcHJvcFRvVXNlOiBhbnkgPSB7IC4uLnRoaXMucENvbm4kLmdldEluaGVyaXRlZFByb3BzKCkgfTtcbiAgICB0aGlzLnNob3dMYWJlbCA9IHByb3BUb1VzZT8uc2hvd0xhYmVsO1xuICAgIHRoaXMubGFiZWwgPSBwcm9wVG9Vc2U/LmxhYmVsO1xuICAgIGNvbnN0IGtpZHMgPSB0aGlzLnBDb25uJC5nZXRDaGlsZHJlbigpIGFzIGFueVtdO1xuICAgIHRoaXMuaW5zdHJ1Y3Rpb25zID0gdGhpcy50ZW1wbGF0ZVV0aWxzLmdldEluc3RydWN0aW9ucyh0aGlzLnBDb25uJCwgY29uZmlnUHJvcHM/Lmluc3RydWN0aW9ucyk7XG5cbiAgICBjb25zdCBudW1Db2xzID0gY29uZmlnUHJvcHMuTnVtQ29scyA/IGNvbmZpZ1Byb3BzLk51bUNvbHMgOiAnMSc7XG4gICAgc3dpdGNoIChudW1Db2xzKSB7XG4gICAgICBjYXNlICcxJzpcbiAgICAgICAgdGhpcy5kaXZDbGFzcyQgPSAncHNkay1kZWZhdWx0LWZvcm0tb25lLWNvbHVtbic7XG4gICAgICAgIGJyZWFrO1xuICAgICAgY2FzZSAnMic6XG4gICAgICAgIHRoaXMuZGl2Q2xhc3MkID0gJ3BzZGstZGVmYXVsdC1mb3JtLXR3by1jb2x1bW4nO1xuICAgICAgICBicmVhaztcbiAgICAgIGNhc2UgJzMnOlxuICAgICAgICB0aGlzLmRpdkNsYXNzJCA9ICdwc2RrLWRlZmF1bHQtZm9ybS10aHJlZS1jb2x1bW4nO1xuICAgICAgICBicmVhaztcbiAgICAgIGRlZmF1bHQ6XG4gICAgICAgIHRoaXMuZGl2Q2xhc3MkID0gJ3BzZGstZGVmYXVsdC1mb3JtLW9uZS1jb2x1bW4nO1xuICAgICAgICBicmVhaztcbiAgICB9XG5cbiAgICAvLyByZXBvaW50IGNoaWxkcmVuIGJlZm9yZSBnZXR0aW5nIHRlbXBsYXRlQXJyYXlcbiAgICAvLyBDaGlsZHJlbiBtYXkgY29udGFpbiAncmVmZXJlbmNlJyBjb21wb25lbnQsIHNvIHdlIG5lZWQgdG9cbiAgICAvLyAgbm9ybWFsaXplIHRoZW1cbiAgICB0aGlzLmFyQ2hpbGRyZW4kID0gUmVmZXJlbmNlQ29tcG9uZW50Lm5vcm1hbGl6ZVBDb25uQXJyYXkoa2lkc1swXS5nZXRQQ29ubmVjdCgpLmdldENoaWxkcmVuKCkpO1xuICB9XG59XG4iLCI8IS0tIFdoZW4gYWRkaW5nIGEgY29tcG9uZW50IGhlcmUsIGFkZCB0aGUgc2FtZSBjb21wb25lbnQgaW4gJ3JlZ2lvbicgdGVtcGxhdGUgYXMgd2VsbCAtLT5cbjxkaXYgKm5nSWY9XCIhTk9fSEVBREVSX1RFTVBMQVRFUy5pbmNsdWRlcyh0ZW1wbGF0ZSkgJiYgc2hvd0xhYmVsXCI+XG4gIDxkaXYgY2xhc3M9XCJ0ZW1wbGF0ZS10aXRsZS1jb250YWluZXJcIj57eyBsYWJlbCB9fTwvZGl2PlxuPC9kaXY+XG48ZGl2ICpuZ0lmPVwiaW5zdHJ1Y3Rpb25zXCIgY2xhc3M9XCJwc2RrLWRlZmF1bHQtZm9ybS1pbnN0cnVjdGlvbi10ZXh0XCI+XG4gIDxkaXYga2V5PVwiaW5zdHJ1Y3Rpb25zXCIgaWQ9XCJpbnN0cnVjdGlvbi10ZXh0XCIgW2lubmVySFRNTF09XCJpbnN0cnVjdGlvbnNcIj48L2Rpdj5cbjwvZGl2PlxuPGRpdiBbY2xhc3NOYW1lXT1cImRpdkNsYXNzJFwiPlxuICA8ZGl2ICpuZ0Zvcj1cImxldCBraWQgb2YgYXJDaGlsZHJlbiRcIiBbbmdDbGFzc109XCJ7ICdncmlkLWNvbHVtbic6IGtpZC5nZXRQQ29ubmVjdCgpLmdldENvbXBvbmVudE5hbWUoKSA9PT0gJ1ZpZXcnIH1cIj5cbiAgICA8Y29tcG9uZW50LW1hcHBlclxuICAgICAgW25hbWVdPVwia2lkLmdldFBDb25uZWN0KCkuZ2V0Q29tcG9uZW50TmFtZSgpXCJcbiAgICAgIFtwcm9wc109XCJ7XG4gICAgICAgIHBDb25uJDoga2lkLmdldFBDb25uZWN0KCksXG4gICAgICAgIGZvcm1Hcm91cCQ6IGZvcm1Hcm91cCRcbiAgICAgIH1cIlxuICAgICAgZXJyb3JNc2c9XCJEZWZhdWx0Rm9ybSB3YW50cyBjb21wb25lbnQgbm90IHlldCBhdmFpbGFibGU6IHt7IGtpZC5nZXRQQ29ubmVjdCgpLmdldENvbXBvbmVudE5hbWUoKSB9fVwiXG4gICAgPjwvY29tcG9uZW50LW1hcHBlcj5cbiAgPC9kaXY+XG48L2Rpdj5cbiJdfQ==
|
|
92
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"default-form.component.js","sourceRoot":"","sources":["../../../../../../../packages/angular-sdk-components/src/lib/_components/template/default-form/default-form.component.ts","../../../../../../../packages/angular-sdk-components/src/lib/_components/template/default-form/default-form.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, Input, forwardRef, OnDestroy } from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { FormGroup } from '@angular/forms';\nimport { ReferenceComponent } from '../../infra/reference/reference.component';\nimport { AngularPConnectData, AngularPConnectService } from '../../../_bridge/angular-pconnect';\nimport { ComponentMapperComponent } from '../../../_bridge/component-mapper/component-mapper.component';\nimport { TemplateUtils } from '../../../_helpers/template-utils';\n\nfunction areViewsChanged(oldViews: any[], newViews: any[]): boolean {\n  if (oldViews.length !== newViews.length) {\n    return true;\n  }\n\n  return !oldViews.every((oldView, index) => {\n    const newView = newViews[index];\n    return oldView.getPConnect().viewName === newView.getPConnect().viewName;\n  });\n}\n\ninterface DefaultFormProps {\n  // If any, enter additional props that only exist on this component\n  NumCols: string;\n  template: string;\n  instructions: string;\n}\n\n@Component({\n  selector: 'app-default-form',\n  templateUrl: './default-form.component.html',\n  styleUrls: ['./default-form.component.scss'],\n  standalone: true,\n  imports: [CommonModule, forwardRef(() => ComponentMapperComponent)]\n})\nexport class DefaultFormComponent implements OnInit, OnDestroy {\n  @Input() pConn$: typeof PConnect;\n  @Input() formGroup$: FormGroup;\n\n  // Used with AngularPConnect\n  angularPConnectData: AngularPConnectData = {};\n\n  arChildren$: any[] = [];\n  divClass$: string;\n  template: any;\n  showLabel: any;\n  label: any;\n  instructions: string;\n\n  NO_HEADER_TEMPLATES = [\n    'SubTabs',\n    'SimpleTable',\n    'Details',\n    'DetailsTwoColumn',\n    'DetailsThreeColumn',\n    'NarrowWideDetails',\n    'WideNarrowDetails',\n    'Confirmation'\n  ];\n\n  constructor(\n    private angularPConnect: AngularPConnectService,\n    private templateUtils: TemplateUtils\n  ) {}\n\n  ngOnInit(): void {\n    // First thing in initialization is registering and subscribing to the AngularPConnect service\n    this.angularPConnectData = this.angularPConnect.registerAndSubscribeComponent(this, this.onStateChange);\n\n    this.updateSelf();\n  }\n\n  ngOnDestroy() {\n    if (this.angularPConnectData.unsubscribeFn) {\n      this.angularPConnectData.unsubscribeFn();\n    }\n  }\n\n  onStateChange() {\n    this.updateSelf();\n  }\n\n  updateSelf() {\n    const configProps = this.pConn$.getConfigProps() as DefaultFormProps;\n    this.template = configProps?.template;\n    const propToUse: any = { ...this.pConn$.getInheritedProps() };\n    this.showLabel = propToUse?.showLabel;\n    this.label = propToUse?.label;\n    const kids = this.pConn$.getChildren() as any[];\n    this.instructions = this.templateUtils.getInstructions(this.pConn$, configProps?.instructions);\n\n    const numCols = configProps.NumCols ? configProps.NumCols : '1';\n    switch (numCols) {\n      case '1':\n        this.divClass$ = 'psdk-default-form-one-column';\n        break;\n      case '2':\n        this.divClass$ = 'psdk-default-form-two-column';\n        break;\n      case '3':\n        this.divClass$ = 'psdk-default-form-three-column';\n        break;\n      default:\n        this.divClass$ = 'psdk-default-form-one-column';\n        break;\n    }\n\n    // repoint children before getting templateArray\n    // Children may contain 'reference' component, so we need to\n    //  normalize them\n    const children = ReferenceComponent.normalizePConnArray(kids[0].getPConnect().getChildren());\n\n    const visibleChildren = children.filter(child => child !== undefined);\n\n    if (areViewsChanged(this.arChildren$, visibleChildren)) {\n      this.arChildren$ = visibleChildren;\n    }\n  }\n}\n","<!-- When adding a component here, add the same component in 'region' template as well -->\n<div *ngIf=\"!NO_HEADER_TEMPLATES.includes(template) && showLabel\">\n  <div class=\"template-title-container\">{{ label }}</div>\n</div>\n<div *ngIf=\"instructions\" class=\"psdk-default-form-instruction-text\">\n  <div key=\"instructions\" id=\"instruction-text\" [innerHTML]=\"instructions\"></div>\n</div>\n<div [className]=\"divClass$\">\n  <div *ngFor=\"let kid of arChildren$\" [ngClass]=\"{ 'grid-column': kid.getPConnect().getComponentName() === 'View' }\">\n    <component-mapper\n      [name]=\"kid.getPConnect().getComponentName()\"\n      [props]=\"{\n        pConn$: kid.getPConnect(),\n        formGroup$: formGroup$\n      }\"\n      errorMsg=\"DefaultForm wants component not yet available: {{ kid.getPConnect().getComponentName() }}\"\n    ></component-mapper>\n  </div>\n</div>\n"]}
|
package/esm2022/lib/_components/template/field-group-template/field-group-template.component.mjs
CHANGED
|
@@ -81,7 +81,7 @@ export class FieldGroupTemplateComponent {
|
|
|
81
81
|
this.pConn$.setInheritedProp('displayMode', 'LABELS_LEFT');
|
|
82
82
|
}
|
|
83
83
|
this.referenceList = this.configProps$.referenceList;
|
|
84
|
-
if (this.prevRefLength != this.referenceList
|
|
84
|
+
if (this.prevRefLength != this.referenceList?.length) {
|
|
85
85
|
// eslint-disable-next-line sonarjs/no-collapsible-if
|
|
86
86
|
if (!this.readonlyMode) {
|
|
87
87
|
if (this.referenceList?.length === 0 && this.allowAddEdit !== false) {
|
|
@@ -131,4 +131,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
131
131
|
}], formGroup$: [{
|
|
132
132
|
type: Input
|
|
133
133
|
}] } });
|
|
134
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"field-group-template.component.js","sourceRoot":"","sources":["../../../../../../../packages/angular-sdk-components/src/lib/_components/template/field-group-template/field-group-template.component.ts","../../../../../../../packages/angular-sdk-components/src/lib/_components/template/field-group-template/field-group-template.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, Input, forwardRef, OnDestroy, OnChanges } from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { FormGroup } from '@angular/forms';\nimport { MatButtonModule } from '@angular/material/button';\nimport { AngularPConnectData, AngularPConnectService } from '../../../_bridge/angular-pconnect';\nimport { buildView, getReferenceList } from '../../../_helpers/field-group-utils';\nimport { Utils } from '../../../_helpers/utils';\nimport { ComponentMapperComponent } from '../../../_bridge/component-mapper/component-mapper.component';\n\ninterface FieldGroupTemplateProps {\n  // If any, enter additional props that only exist on this component\n  label?: string;\n  showLabel?: boolean;\n  referenceList?: any[];\n  contextClass: string;\n  renderMode?: string;\n  heading?: string;\n  lookForChildInConfig?: boolean;\n  displayMode?: string;\n  fieldHeader?: string;\n  allowTableEdit: boolean;\n}\n\n@Component({\n  selector: 'app-field-group-template',\n  templateUrl: './field-group-template.component.html',\n  styleUrls: ['./field-group-template.component.scss'],\n  standalone: true,\n  imports: [CommonModule, MatButtonModule, forwardRef(() => ComponentMapperComponent)]\n})\nexport class FieldGroupTemplateComponent implements OnInit, OnDestroy, OnChanges {\n  @Input() configProps$: FieldGroupTemplateProps;\n  @Input() pConn$: typeof PConnect;\n  @Input() formGroup$: FormGroup;\n\n  angularPConnectData: AngularPConnectData = {};\n  inheritedProps$: object;\n  showLabel$?: boolean = true;\n  label$?: string;\n  readonlyMode: boolean;\n  contextClass: any;\n  referenceList: any;\n  pageReference: any;\n  heading: any;\n  children: any;\n  menuIconOverride$: any;\n  prevRefLength: number;\n  allowAddEdit: boolean;\n  fieldHeader: any;\n\n  constructor(\n    private angularPConnect: AngularPConnectService,\n    private utils: Utils\n  ) {}\n\n  ngOnInit(): void {\n    // First thing in initialization is registering and subscribing to the AngularPConnect service\n    this.angularPConnectData = this.angularPConnect.registerAndSubscribeComponent(this, this.onStateChange);\n    this.updateSelf();\n\n    const menuIconOverride$ = 'trash';\n    if (menuIconOverride$) {\n      this.menuIconOverride$ = this.utils.getImageSrc(menuIconOverride$, this.utils.getSDKStaticContentUrl());\n    }\n  }\n\n  ngOnDestroy(): void {\n    if (this.angularPConnectData.unsubscribeFn) {\n      this.angularPConnectData.unsubscribeFn();\n    }\n  }\n\n  onStateChange() {\n    // Should always check the bridge to see if the component should\n    // update itself (re-render)\n    const bUpdateSelf = this.angularPConnect.shouldComponentUpdate(this);\n    // ONLY call updateSelf when the component should update\n    if (bUpdateSelf) {\n      this.updateSelf();\n    }\n  }\n\n  ngOnChanges(changes) {\n    if (changes && changes.configProps$) {\n      const props = changes.configProps$;\n      if (props.currentValue !== props.previousValue) {\n        this.configProps$ = props.currentValue;\n        if (changes?.pConn$?.currentValue) {\n          this.pConn$ = changes?.pConn$?.currentValue;\n        }\n        this.updateSelf();\n      }\n    }\n  }\n\n  updateSelf() {\n    this.inheritedProps$ = this.pConn$.getInheritedProps();\n    this.label$ = this.configProps$.label;\n    this.showLabel$ = this.configProps$.showLabel;\n    // label & showLabel within inheritedProps takes precedence over configProps\n    this.label$ = (this.inheritedProps$ as any).label || this.label$;\n    this.showLabel$ = (this.inheritedProps$ as any).showLabel || this.showLabel$;\n\n    this.allowAddEdit = this.configProps$.allowTableEdit;\n\n    const renderMode = this.configProps$.renderMode;\n    const displayMode = this.configProps$.displayMode;\n    this.readonlyMode = renderMode === 'ReadOnly' || displayMode === 'LABELS_LEFT';\n    this.contextClass = this.configProps$.contextClass;\n    const lookForChildInConfig = this.configProps$.lookForChildInConfig;\n    this.heading = this.configProps$.heading ?? 'Row';\n    this.fieldHeader = this.configProps$.fieldHeader;\n    const resolvedList = getReferenceList(this.pConn$);\n    this.pageReference = `${this.pConn$.getPageReference()}${resolvedList}`;\n    this.pConn$.setReferenceList(resolvedList);\n    if (this.readonlyMode) {\n      this.pConn$.setInheritedProp('displayMode', 'LABELS_LEFT');\n    }\n    this.referenceList = this.configProps$.referenceList;\n    if (this.prevRefLength != this.referenceList.length) {\n      // eslint-disable-next-line sonarjs/no-collapsible-if\n      if (!this.readonlyMode) {\n        if (this.referenceList?.length === 0 && this.allowAddEdit !== false) {\n          this.addFieldGroupItem();\n        }\n      }\n      const children: any = [];\n      this.referenceList?.forEach((item, index) => {\n        children.push({\n          id: index,\n          name: this.fieldHeader === 'propertyRef' ? this.getDynamicHeader(item, index) : this.getStaticHeader(this.heading, index),\n          children: buildView(this.pConn$, index, lookForChildInConfig)\n        });\n      });\n      this.children = children;\n    }\n    this.prevRefLength = this.referenceList.length;\n  }\n\n  getStaticHeader = (heading, index) => {\n    return `${heading} ${index + 1}`;\n  };\n\n  getDynamicHeader = (item, index) => {\n    if (this.fieldHeader === 'propertyRef' && this.heading && item[this.heading.substring(1)]) {\n      return item[this.heading.substring(1)];\n    }\n    return `Row ${index + 1}`;\n  };\n\n  addFieldGroupItem() {\n    if (PCore.getPCoreVersion()?.includes('8.7')) {\n      this.pConn$.getListActions().insert({ classID: this.contextClass }, this.referenceList.length, this.pageReference);\n    } else {\n      // @ts-ignore - second parameter \"pageRef\" is optional for insert method\n      this.pConn$.getListActions().insert({ classID: this.contextClass }, this.referenceList.length);\n    }\n  }\n\n  deleteFieldGroupItem(index) {\n    if (PCore.getPCoreVersion()?.includes('8.7')) {\n      this.pConn$.getListActions().deleteEntry(index, this.pageReference);\n    } else {\n      // @ts-ignore - second parameter \"pageRef\" is optional for deleteEntry method\n      this.pConn$.getListActions().deleteEntry(index);\n    }\n  }\n}\n","<div id=\"field-group\">\n  <h3 *ngIf=\"showLabel$\" className=\"label\" style=\"font-weight: bold\">\n    {{ label$ }}\n  </h3>\n  <div *ngIf=\"readonlyMode; else editable\">\n    <div *ngIf=\"children && children.length > 0\">\n      <div *ngFor=\"let item of children; let i = index\">\n        <component-mapper name=\"FieldGroupList\" [props]=\"{ heading: item.name, formGroup$, item }\"></component-mapper>\n      </div>\n    </div>\n  </div>\n  <ng-template #editable>\n    <div *ngIf=\"children && children.length > 0\">\n      <div *ngFor=\"let kid of children; let i = index\">\n        <div class=\"header-div\">\n          <div style=\"width: 80%\">\n            <b>{{ kid.name }}</b>\n          </div>\n          <div *ngIf=\"allowAddEdit !== false\" style=\"width: 20%; text-align: right\">\n            <button id=\"delete-button\" mat-icon-button (click)=\"deleteFieldGroupItem(i)\">\n              <img class=\"psdk-utility-card-action-svg-icon\" src=\"{{ menuIconOverride$ }}\" />\n            </button>\n          </div>\n        </div>\n\n        <div *ngIf=\"kid.children.getPConnect().getRawMetadata().type.toLowerCase() == 'region'\">\n          <component-mapper name=\"Region\" [props]=\"{ pConn$: kid.children.getPConnect(), formGroup$ }\"></component-mapper>\n        </div>\n      </div>\n      <button *ngIf=\"allowAddEdit !== false\" mat-button color=\"primary\" style=\"font-size: 16px\" (click)=\"addFieldGroupItem()\">+ Add</button>\n    </div>\n  </ng-template>\n</div>\n"]}
|
|
134
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"field-group-template.component.js","sourceRoot":"","sources":["../../../../../../../packages/angular-sdk-components/src/lib/_components/template/field-group-template/field-group-template.component.ts","../../../../../../../packages/angular-sdk-components/src/lib/_components/template/field-group-template/field-group-template.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAU,KAAK,EAAE,UAAU,EAAwB,MAAM,eAAe,CAAC;AAC3F,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAE/C,OAAO,EAAE,eAAe,EAAE,MAAM,0BAA0B,CAAC;AAE3D,OAAO,EAAE,SAAS,EAAE,gBAAgB,EAAE,MAAM,qCAAqC,CAAC;AAElF,OAAO,EAAE,wBAAwB,EAAE,MAAM,8DAA8D,CAAC;;;;;;AAuBxG,MAAM,OAAO,2BAA2B;IAoBtC,YACU,eAAuC,EACvC,KAAY;QADZ,oBAAe,GAAf,eAAe,CAAwB;QACvC,UAAK,GAAL,KAAK,CAAO;QAjBtB,wBAAmB,GAAwB,EAAE,CAAC;QAE9C,eAAU,GAAa,IAAI,CAAC;QAsG5B,oBAAe,GAAG,CAAC,OAAO,EAAE,KAAK,EAAE,EAAE;YACnC,OAAO,GAAG,OAAO,IAAI,KAAK,GAAG,CAAC,EAAE,CAAC;QACnC,CAAC,CAAC;QAEF,qBAAgB,GAAG,CAAC,IAAI,EAAE,KAAK,EAAE,EAAE;YACjC,IAAI,IAAI,CAAC,WAAW,KAAK,aAAa,IAAI,IAAI,CAAC,OAAO,IAAI,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,EAAE;gBACzF,OAAO,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC;aACxC;YACD,OAAO,OAAO,KAAK,GAAG,CAAC,EAAE,CAAC;QAC5B,CAAC,CAAC;IA/FC,CAAC;IAEJ,QAAQ;QACN,8FAA8F;QAC9F,IAAI,CAAC,mBAAmB,GAAG,IAAI,CAAC,eAAe,CAAC,6BAA6B,CAAC,IAAI,EAAE,IAAI,CAAC,aAAa,CAAC,CAAC;QACxG,IAAI,CAAC,UAAU,EAAE,CAAC;QAElB,MAAM,iBAAiB,GAAG,OAAO,CAAC;QAClC,IAAI,iBAAiB,EAAE;YACrB,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC,KAAK,CAAC,WAAW,CAAC,iBAAiB,EAAE,IAAI,CAAC,KAAK,CAAC,sBAAsB,EAAE,CAAC,CAAC;SACzG;IACH,CAAC;IAED,WAAW;QACT,IAAI,IAAI,CAAC,mBAAmB,CAAC,aAAa,EAAE;YAC1C,IAAI,CAAC,mBAAmB,CAAC,aAAa,EAAE,CAAC;SAC1C;IACH,CAAC;IAED,aAAa;QACX,gEAAgE;QAChE,4BAA4B;QAC5B,MAAM,WAAW,GAAG,IAAI,CAAC,eAAe,CAAC,qBAAqB,CAAC,IAAI,CAAC,CAAC;QACrE,wDAAwD;QACxD,IAAI,WAAW,EAAE;YACf,IAAI,CAAC,UAAU,EAAE,CAAC;SACnB;IACH,CAAC;IAED,WAAW,CAAC,OAAO;QACjB,IAAI,OAAO,IAAI,OAAO,CAAC,YAAY,EAAE;YACnC,MAAM,KAAK,GAAG,OAAO,CAAC,YAAY,CAAC;YACnC,IAAI,KAAK,CAAC,YAAY,KAAK,KAAK,CAAC,aAAa,EAAE;gBAC9C,IAAI,CAAC,YAAY,GAAG,KAAK,CAAC,YAAY,CAAC;gBACvC,IAAI,OAAO,EAAE,MAAM,EAAE,YAAY,EAAE;oBACjC,IAAI,CAAC,MAAM,GAAG,OAAO,EAAE,MAAM,EAAE,YAAY,CAAC;iBAC7C;gBACD,IAAI,CAAC,UAAU,EAAE,CAAC;aACnB;SACF;IACH,CAAC;IAED,UAAU;QACR,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,MAAM,CAAC,iBAAiB,EAAE,CAAC;QACvD,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,YAAY,CAAC,KAAK,CAAC;QACtC,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,YAAY,CAAC,SAAS,CAAC;QAC9C,4EAA4E;QAC5E,IAAI,CAAC,MAAM,GAAI,IAAI,CAAC,eAAuB,CAAC,KAAK,IAAI,IAAI,CAAC,MAAM,CAAC;QACjE,IAAI,CAAC,UAAU,GAAI,IAAI,CAAC,eAAuB,CAAC,SAAS,IAAI,IAAI,CAAC,UAAU,CAAC;QAE7E,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,YAAY,CAAC,cAAc,CAAC;QAErD,MAAM,UAAU,GAAG,IAAI,CAAC,YAAY,CAAC,UAAU,CAAC;QAChD,MAAM,WAAW,GAAG,IAAI,CAAC,YAAY,CAAC,WAAW,CAAC;QAClD,IAAI,CAAC,YAAY,GAAG,UAAU,KAAK,UAAU,IAAI,WAAW,KAAK,aAAa,CAAC;QAC/E,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,YAAY,CAAC,YAAY,CAAC;QACnD,MAAM,oBAAoB,GAAG,IAAI,CAAC,YAAY,CAAC,oBAAoB,CAAC;QACpE,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,YAAY,CAAC,OAAO,IAAI,KAAK,CAAC;QAClD,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,YAAY,CAAC,WAAW,CAAC;QACjD,MAAM,YAAY,GAAG,gBAAgB,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QACnD,IAAI,CAAC,aAAa,GAAG,GAAG,IAAI,CAAC,MAAM,CAAC,gBAAgB,EAAE,GAAG,YAAY,EAAE,CAAC;QACxE,IAAI,CAAC,MAAM,CAAC,gBAAgB,CAAC,YAAY,CAAC,CAAC;QAC3C,IAAI,IAAI,CAAC,YAAY,EAAE;YACrB,IAAI,CAAC,MAAM,CAAC,gBAAgB,CAAC,aAAa,EAAE,aAAa,CAAC,CAAC;SAC5D;QACD,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,YAAY,CAAC,aAAa,CAAC;QACrD,IAAI,IAAI,CAAC,aAAa,IAAI,IAAI,CAAC,aAAa,EAAE,MAAM,EAAE;YACpD,qDAAqD;YACrD,IAAI,CAAC,IAAI,CAAC,YAAY,EAAE;gBACtB,IAAI,IAAI,CAAC,aAAa,EAAE,MAAM,KAAK,CAAC,IAAI,IAAI,CAAC,YAAY,KAAK,KAAK,EAAE;oBACnE,IAAI,CAAC,iBAAiB,EAAE,CAAC;iBAC1B;aACF;YACD,MAAM,QAAQ,GAAQ,EAAE,CAAC;YACzB,IAAI,CAAC,aAAa,EAAE,OAAO,CAAC,CAAC,IAAI,EAAE,KAAK,EAAE,EAAE;gBAC1C,QAAQ,CAAC,IAAI,CAAC;oBACZ,EAAE,EAAE,KAAK;oBACT,IAAI,EAAE,IAAI,CAAC,WAAW,KAAK,aAAa,CAAC,CAAC,CAAC,IAAI,CAAC,gBAAgB,CAAC,IAAI,EAAE,KAAK,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,OAAO,EAAE,KAAK,CAAC;oBACzH,QAAQ,EAAE,SAAS,CAAC,IAAI,CAAC,MAAM,EAAE,KAAK,EAAE,oBAAoB,CAAC;iBAC9D,CAAC,CAAC;YACL,CAAC,CAAC,CAAC;YACH,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC;SAC1B;QACD,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,aAAa,CAAC,MAAM,CAAC;IACjD,CAAC;IAaD,iBAAiB;QACf,IAAI,KAAK,CAAC,eAAe,EAAE,EAAE,QAAQ,CAAC,KAAK,CAAC,EAAE;YAC5C,IAAI,CAAC,MAAM,CAAC,cAAc,EAAE,CAAC,MAAM,CAAC,EAAE,OAAO,EAAE,IAAI,CAAC,YAAY,EAAE,EAAE,IAAI,CAAC,aAAa,CAAC,MAAM,EAAE,IAAI,CAAC,aAAa,CAAC,CAAC;SACpH;aAAM;YACL,wEAAwE;YACxE,IAAI,CAAC,MAAM,CAAC,cAAc,EAAE,CAAC,MAAM,CAAC,EAAE,OAAO,EAAE,IAAI,CAAC,YAAY,EAAE,EAAE,IAAI,CAAC,aAAa,CAAC,MAAM,CAAC,CAAC;SAChG;IACH,CAAC;IAED,oBAAoB,CAAC,KAAK;QACxB,IAAI,KAAK,CAAC,eAAe,EAAE,EAAE,QAAQ,CAAC,KAAK,CAAC,EAAE;YAC5C,IAAI,CAAC,MAAM,CAAC,cAAc,EAAE,CAAC,WAAW,CAAC,KAAK,EAAE,IAAI,CAAC,aAAa,CAAC,CAAC;SACrE;aAAM;YACL,6EAA6E;YAC7E,IAAI,CAAC,MAAM,CAAC,cAAc,EAAE,CAAC,WAAW,CAAC,KAAK,CAAC,CAAC;SACjD;IACH,CAAC;+GAxIU,2BAA2B;mGAA3B,2BAA2B,+LC9BxC,m+CAiCA,0LDLY,YAAY,oXAAE,eAAe,8hBAAmB,wBAAwB;;4FAEvE,2BAA2B;kBAPvC,SAAS;+BACE,0BAA0B,cAGxB,IAAI,WACP,CAAC,YAAY,EAAE,eAAe,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,wBAAwB,CAAC,CAAC;iIAG3E,YAAY;sBAApB,KAAK;gBACG,MAAM;sBAAd,KAAK;gBACG,UAAU;sBAAlB,KAAK","sourcesContent":["import { Component, OnInit, Input, forwardRef, OnDestroy, OnChanges } from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { FormGroup } from '@angular/forms';\nimport { MatButtonModule } from '@angular/material/button';\nimport { AngularPConnectData, AngularPConnectService } from '../../../_bridge/angular-pconnect';\nimport { buildView, getReferenceList } from '../../../_helpers/field-group-utils';\nimport { Utils } from '../../../_helpers/utils';\nimport { ComponentMapperComponent } from '../../../_bridge/component-mapper/component-mapper.component';\n\ninterface FieldGroupTemplateProps {\n  // If any, enter additional props that only exist on this component\n  label?: string;\n  showLabel?: boolean;\n  referenceList?: any[];\n  contextClass: string;\n  renderMode?: string;\n  heading?: string;\n  lookForChildInConfig?: boolean;\n  displayMode?: string;\n  fieldHeader?: string;\n  allowTableEdit: boolean;\n}\n\n@Component({\n  selector: 'app-field-group-template',\n  templateUrl: './field-group-template.component.html',\n  styleUrls: ['./field-group-template.component.scss'],\n  standalone: true,\n  imports: [CommonModule, MatButtonModule, forwardRef(() => ComponentMapperComponent)]\n})\nexport class FieldGroupTemplateComponent implements OnInit, OnDestroy, OnChanges {\n  @Input() configProps$: FieldGroupTemplateProps;\n  @Input() pConn$: typeof PConnect;\n  @Input() formGroup$: FormGroup;\n\n  angularPConnectData: AngularPConnectData = {};\n  inheritedProps$: object;\n  showLabel$?: boolean = true;\n  label$?: string;\n  readonlyMode: boolean;\n  contextClass: any;\n  referenceList: any;\n  pageReference: any;\n  heading: any;\n  children: any;\n  menuIconOverride$: any;\n  prevRefLength: number;\n  allowAddEdit: boolean;\n  fieldHeader: any;\n\n  constructor(\n    private angularPConnect: AngularPConnectService,\n    private utils: Utils\n  ) {}\n\n  ngOnInit(): void {\n    // First thing in initialization is registering and subscribing to the AngularPConnect service\n    this.angularPConnectData = this.angularPConnect.registerAndSubscribeComponent(this, this.onStateChange);\n    this.updateSelf();\n\n    const menuIconOverride$ = 'trash';\n    if (menuIconOverride$) {\n      this.menuIconOverride$ = this.utils.getImageSrc(menuIconOverride$, this.utils.getSDKStaticContentUrl());\n    }\n  }\n\n  ngOnDestroy(): void {\n    if (this.angularPConnectData.unsubscribeFn) {\n      this.angularPConnectData.unsubscribeFn();\n    }\n  }\n\n  onStateChange() {\n    // Should always check the bridge to see if the component should\n    // update itself (re-render)\n    const bUpdateSelf = this.angularPConnect.shouldComponentUpdate(this);\n    // ONLY call updateSelf when the component should update\n    if (bUpdateSelf) {\n      this.updateSelf();\n    }\n  }\n\n  ngOnChanges(changes) {\n    if (changes && changes.configProps$) {\n      const props = changes.configProps$;\n      if (props.currentValue !== props.previousValue) {\n        this.configProps$ = props.currentValue;\n        if (changes?.pConn$?.currentValue) {\n          this.pConn$ = changes?.pConn$?.currentValue;\n        }\n        this.updateSelf();\n      }\n    }\n  }\n\n  updateSelf() {\n    this.inheritedProps$ = this.pConn$.getInheritedProps();\n    this.label$ = this.configProps$.label;\n    this.showLabel$ = this.configProps$.showLabel;\n    // label & showLabel within inheritedProps takes precedence over configProps\n    this.label$ = (this.inheritedProps$ as any).label || this.label$;\n    this.showLabel$ = (this.inheritedProps$ as any).showLabel || this.showLabel$;\n\n    this.allowAddEdit = this.configProps$.allowTableEdit;\n\n    const renderMode = this.configProps$.renderMode;\n    const displayMode = this.configProps$.displayMode;\n    this.readonlyMode = renderMode === 'ReadOnly' || displayMode === 'LABELS_LEFT';\n    this.contextClass = this.configProps$.contextClass;\n    const lookForChildInConfig = this.configProps$.lookForChildInConfig;\n    this.heading = this.configProps$.heading ?? 'Row';\n    this.fieldHeader = this.configProps$.fieldHeader;\n    const resolvedList = getReferenceList(this.pConn$);\n    this.pageReference = `${this.pConn$.getPageReference()}${resolvedList}`;\n    this.pConn$.setReferenceList(resolvedList);\n    if (this.readonlyMode) {\n      this.pConn$.setInheritedProp('displayMode', 'LABELS_LEFT');\n    }\n    this.referenceList = this.configProps$.referenceList;\n    if (this.prevRefLength != this.referenceList?.length) {\n      // eslint-disable-next-line sonarjs/no-collapsible-if\n      if (!this.readonlyMode) {\n        if (this.referenceList?.length === 0 && this.allowAddEdit !== false) {\n          this.addFieldGroupItem();\n        }\n      }\n      const children: any = [];\n      this.referenceList?.forEach((item, index) => {\n        children.push({\n          id: index,\n          name: this.fieldHeader === 'propertyRef' ? this.getDynamicHeader(item, index) : this.getStaticHeader(this.heading, index),\n          children: buildView(this.pConn$, index, lookForChildInConfig)\n        });\n      });\n      this.children = children;\n    }\n    this.prevRefLength = this.referenceList.length;\n  }\n\n  getStaticHeader = (heading, index) => {\n    return `${heading} ${index + 1}`;\n  };\n\n  getDynamicHeader = (item, index) => {\n    if (this.fieldHeader === 'propertyRef' && this.heading && item[this.heading.substring(1)]) {\n      return item[this.heading.substring(1)];\n    }\n    return `Row ${index + 1}`;\n  };\n\n  addFieldGroupItem() {\n    if (PCore.getPCoreVersion()?.includes('8.7')) {\n      this.pConn$.getListActions().insert({ classID: this.contextClass }, this.referenceList.length, this.pageReference);\n    } else {\n      // @ts-ignore - second parameter \"pageRef\" is optional for insert method\n      this.pConn$.getListActions().insert({ classID: this.contextClass }, this.referenceList.length);\n    }\n  }\n\n  deleteFieldGroupItem(index) {\n    if (PCore.getPCoreVersion()?.includes('8.7')) {\n      this.pConn$.getListActions().deleteEntry(index, this.pageReference);\n    } else {\n      // @ts-ignore - second parameter \"pageRef\" is optional for deleteEntry method\n      this.pConn$.getListActions().deleteEntry(index);\n    }\n  }\n}\n","<div id=\"field-group\">\n  <h3 *ngIf=\"showLabel$\" className=\"label\" style=\"font-weight: bold\">\n    {{ label$ }}\n  </h3>\n  <div *ngIf=\"readonlyMode; else editable\">\n    <div *ngIf=\"children && children.length > 0\">\n      <div *ngFor=\"let item of children; let i = index\">\n        <component-mapper name=\"FieldGroupList\" [props]=\"{ heading: item.name, formGroup$, item }\"></component-mapper>\n      </div>\n    </div>\n  </div>\n  <ng-template #editable>\n    <div *ngIf=\"children && children.length > 0\">\n      <div *ngFor=\"let kid of children; let i = index\">\n        <div class=\"header-div\">\n          <div style=\"width: 80%\">\n            <b>{{ kid.name }}</b>\n          </div>\n          <div *ngIf=\"allowAddEdit !== false\" style=\"width: 20%; text-align: right\">\n            <button id=\"delete-button\" mat-icon-button (click)=\"deleteFieldGroupItem(i)\">\n              <img class=\"psdk-utility-card-action-svg-icon\" src=\"{{ menuIconOverride$ }}\" />\n            </button>\n          </div>\n        </div>\n\n        <div *ngIf=\"kid.children.getPConnect().getRawMetadata().type.toLowerCase() == 'region'\">\n          <component-mapper name=\"Region\" [props]=\"{ pConn$: kid.children.getPConnect(), formGroup$ }\"></component-mapper>\n        </div>\n      </div>\n      <button *ngIf=\"allowAddEdit !== false\" mat-button color=\"primary\" style=\"font-size: 16px\" (click)=\"addFieldGroupItem()\">+ Add</button>\n    </div>\n  </ng-template>\n</div>\n"]}
|