@pepperi-addons/ngx-composite-lib 0.4.2-beta.99 → 0.5.0-ng15.1
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/color-settings/color-settings.component.d.ts +1 -1
- package/core/common/directives/reset-configuration-field.directive.d.ts +1 -1
- package/data-view-builder/data-view-builder.component.d.ts +1 -1
- package/data-view-builder/data-view-builder.model.d.ts +1 -1
- package/data-view-builder/menu-data-view/menu-data-view.component.d.ts +1 -1
- package/esm2020/color-settings/color-settings.component.mjs +13 -13
- package/esm2020/color-settings/color-settings.module.mjs +5 -5
- package/esm2020/core/common/directives/reset-configuration-field.directive.mjs +24 -24
- package/esm2020/core/common/services/dimx.service.mjs +4 -4
- package/esm2020/core/common/services/utilities.service.mjs +4 -4
- package/esm2020/data-view-builder/data-view-builder.component.mjs +19 -19
- package/esm2020/data-view-builder/data-view-builder.module.mjs +5 -5
- package/esm2020/data-view-builder/data-view-builder.service.mjs +7 -7
- package/esm2020/data-view-builder/menu-data-view/menu-data-view.component.mjs +4 -4
- package/esm2020/file-status-panel/file-status-panel.component.mjs +4 -4
- package/esm2020/file-status-panel/file-status-panel.module.mjs +5 -5
- package/esm2020/flow-picker-button/flow-picker-button.component.mjs +16 -16
- package/esm2020/flow-picker-button/flow-picker-button.module.mjs +5 -5
- package/esm2020/flow-picker-button/flow-picker-button.service.mjs +4 -4
- package/esm2020/generic-fields-builder/field-container/field-container.component.mjs +18 -0
- package/esm2020/generic-fields-builder/generic-fields-builder.component.mjs +119 -0
- package/esm2020/generic-fields-builder/generic-fields-builder.module.mjs +82 -0
- package/esm2020/generic-fields-builder/generic-fields-builder.service.mjs +39 -0
- package/esm2020/generic-fields-builder/pepperi-addons-ngx-composite-lib-generic-fields-builder.mjs +5 -0
- package/esm2020/generic-fields-builder/public-api.mjs +6 -0
- package/esm2020/generic-form/generic-form.component.mjs +13 -13
- package/esm2020/generic-form/generic-form.module.mjs +5 -5
- package/esm2020/generic-form/generic-form.service.mjs +4 -4
- package/esm2020/generic-list/generic-list.component.mjs +102 -49
- package/esm2020/generic-list/generic-list.module.mjs +18 -10
- package/esm2020/generic-list/generic-list.service.mjs +30 -5
- package/esm2020/group-buttons-settings/group-buttons-settings.component.mjs +15 -15
- package/esm2020/group-buttons-settings/group-buttons-settings.module.mjs +5 -5
- package/esm2020/icon-picker/icon-picker.component.mjs +4 -4
- package/esm2020/icon-picker/icon-picker.module.mjs +5 -5
- package/esm2020/icon-picker/icon-picker.service.mjs +4 -4
- package/esm2020/layout-builder/hide-in/hide-in.component.mjs +5 -5
- package/esm2020/layout-builder/hide-in/hide-in.module.mjs +5 -5
- package/esm2020/layout-builder/layout/layout.component.mjs +67 -42
- package/esm2020/layout-builder/layout/layout.module.mjs +7 -5
- package/esm2020/layout-builder/layout-builder-editor/layout-builder-editor.component.mjs +4 -4
- package/esm2020/layout-builder/layout-builder-editor/layout-builder-editor.module.mjs +5 -5
- package/esm2020/layout-builder/layout-builder-internal.service.mjs +77 -77
- package/esm2020/layout-builder/layout-builder.component.mjs +134 -103
- package/esm2020/layout-builder/layout-builder.model.mjs +1 -1
- package/esm2020/layout-builder/layout-builder.module.mjs +5 -5
- package/esm2020/layout-builder/layout-builder.service.mjs +31 -18
- package/esm2020/layout-builder/main-editor/main-editor.component.mjs +47 -36
- package/esm2020/layout-builder/main-editor/main-editor.module.mjs +5 -5
- package/esm2020/layout-builder/section/section.component.mjs +59 -34
- package/esm2020/layout-builder/section/section.module.mjs +5 -5
- package/esm2020/layout-builder/section-block/section-block.component.mjs +19 -19
- package/esm2020/layout-builder/section-block/section-block.module.mjs +5 -5
- package/esm2020/layout-builder/section-editor/section-editor.component.mjs +31 -22
- package/esm2020/layout-builder/section-editor/section-editor.module.mjs +10 -6
- package/esm2020/manage-parameters/manage-parameter/manage-parameter.component.mjs +10 -6
- package/esm2020/manage-parameters/manage-parameters.component.mjs +55 -19
- package/esm2020/manage-parameters/manage-parameters.model.mjs +1 -1
- package/esm2020/manage-parameters/manage-parameters.module.mjs +5 -5
- package/esm2020/manage-parameters/manage-parameters.service.mjs +14 -7
- package/esm2020/mapping-parameters/mapping-parameters.component.mjs +44 -0
- package/esm2020/mapping-parameters/mapping-parameters.model.mjs +6 -0
- package/esm2020/mapping-parameters/mapping-parameters.module.mjs +59 -0
- package/esm2020/mapping-parameters/mapping-parameters.service.mjs +37 -0
- package/esm2020/mapping-parameters/param-map/param-map.component.mjs +73 -0
- package/esm2020/mapping-parameters/pepperi-addons-ngx-composite-lib-mapping-parameters.mjs +5 -0
- package/esm2020/mapping-parameters/public-api.mjs +4 -0
- package/esm2020/ngx-composite-lib.module.mjs +5 -5
- package/esm2020/padding-settings/padding-settings.component.mjs +32 -22
- package/esm2020/padding-settings/padding-settings.model.mjs +3 -3
- package/esm2020/padding-settings/padding-settings.module.mjs +5 -5
- package/esm2020/rich-text/rich-text.component.mjs +12 -12
- package/esm2020/rich-text/rich-text.module.mjs +5 -5
- package/esm2020/rich-text/rich-text.service.mjs +4 -4
- package/esm2020/shadow-settings/shadow-settings.component.mjs +12 -12
- package/esm2020/shadow-settings/shadow-settings.module.mjs +5 -5
- package/esm2020/show-if-badge/show-if-badge.component.mjs +5 -5
- package/esm2020/show-if-badge/show-if-badge.module.mjs +5 -5
- package/fesm2015/pepperi-addons-ngx-composite-lib-color-settings.mjs +16 -16
- package/fesm2015/pepperi-addons-ngx-composite-lib-color-settings.mjs.map +1 -1
- package/fesm2015/pepperi-addons-ngx-composite-lib-data-view-builder.mjs +31 -31
- package/fesm2015/pepperi-addons-ngx-composite-lib-data-view-builder.mjs.map +1 -1
- package/fesm2015/pepperi-addons-ngx-composite-lib-file-status-panel.mjs +7 -7
- package/fesm2015/pepperi-addons-ngx-composite-lib-file-status-panel.mjs.map +1 -1
- package/fesm2015/pepperi-addons-ngx-composite-lib-flow-picker-button.mjs +22 -22
- package/fesm2015/pepperi-addons-ngx-composite-lib-flow-picker-button.mjs.map +1 -1
- package/fesm2015/pepperi-addons-ngx-composite-lib-generic-fields-builder.mjs +254 -0
- package/fesm2015/pepperi-addons-ngx-composite-lib-generic-fields-builder.mjs.map +1 -0
- package/fesm2015/pepperi-addons-ngx-composite-lib-generic-form.mjs +19 -19
- package/fesm2015/pepperi-addons-ngx-composite-lib-generic-form.mjs.map +1 -1
- package/fesm2015/pepperi-addons-ngx-composite-lib-generic-list.mjs +148 -60
- package/fesm2015/pepperi-addons-ngx-composite-lib-generic-list.mjs.map +1 -1
- package/fesm2015/pepperi-addons-ngx-composite-lib-group-buttons-settings.mjs +18 -18
- package/fesm2015/pepperi-addons-ngx-composite-lib-group-buttons-settings.mjs.map +1 -1
- package/fesm2015/pepperi-addons-ngx-composite-lib-icon-picker.mjs +10 -10
- package/fesm2015/pepperi-addons-ngx-composite-lib-icon-picker.mjs.map +1 -1
- package/fesm2015/pepperi-addons-ngx-composite-lib-layout-builder.mjs +853 -725
- package/fesm2015/pepperi-addons-ngx-composite-lib-layout-builder.mjs.map +1 -1
- package/fesm2015/pepperi-addons-ngx-composite-lib-manage-parameters.mjs +83 -35
- package/fesm2015/pepperi-addons-ngx-composite-lib-manage-parameters.mjs.map +1 -1
- package/fesm2015/pepperi-addons-ngx-composite-lib-mapping-parameters.mjs +207 -0
- package/fesm2015/pepperi-addons-ngx-composite-lib-mapping-parameters.mjs.map +1 -0
- package/fesm2015/pepperi-addons-ngx-composite-lib-padding-settings.mjs +37 -27
- package/fesm2015/pepperi-addons-ngx-composite-lib-padding-settings.mjs.map +1 -1
- package/fesm2015/pepperi-addons-ngx-composite-lib-rich-text.mjs +18 -18
- package/fesm2015/pepperi-addons-ngx-composite-lib-rich-text.mjs.map +1 -1
- package/fesm2015/pepperi-addons-ngx-composite-lib-shadow-settings.mjs +15 -15
- package/fesm2015/pepperi-addons-ngx-composite-lib-shadow-settings.mjs.map +1 -1
- package/fesm2015/pepperi-addons-ngx-composite-lib-show-if-badge.mjs +8 -8
- package/fesm2015/pepperi-addons-ngx-composite-lib-show-if-badge.mjs.map +1 -1
- package/fesm2015/pepperi-addons-ngx-composite-lib.mjs +33 -33
- package/fesm2015/pepperi-addons-ngx-composite-lib.mjs.map +1 -1
- package/fesm2020/pepperi-addons-ngx-composite-lib-color-settings.mjs +16 -16
- package/fesm2020/pepperi-addons-ngx-composite-lib-color-settings.mjs.map +1 -1
- package/fesm2020/pepperi-addons-ngx-composite-lib-data-view-builder.mjs +31 -31
- package/fesm2020/pepperi-addons-ngx-composite-lib-data-view-builder.mjs.map +1 -1
- package/fesm2020/pepperi-addons-ngx-composite-lib-file-status-panel.mjs +7 -7
- package/fesm2020/pepperi-addons-ngx-composite-lib-file-status-panel.mjs.map +1 -1
- package/fesm2020/pepperi-addons-ngx-composite-lib-flow-picker-button.mjs +22 -22
- package/fesm2020/pepperi-addons-ngx-composite-lib-flow-picker-button.mjs.map +1 -1
- package/fesm2020/pepperi-addons-ngx-composite-lib-generic-fields-builder.mjs +254 -0
- package/fesm2020/pepperi-addons-ngx-composite-lib-generic-fields-builder.mjs.map +1 -0
- package/fesm2020/pepperi-addons-ngx-composite-lib-generic-form.mjs +19 -19
- package/fesm2020/pepperi-addons-ngx-composite-lib-generic-form.mjs.map +1 -1
- package/fesm2020/pepperi-addons-ngx-composite-lib-generic-list.mjs +146 -60
- package/fesm2020/pepperi-addons-ngx-composite-lib-generic-list.mjs.map +1 -1
- package/fesm2020/pepperi-addons-ngx-composite-lib-group-buttons-settings.mjs +18 -18
- package/fesm2020/pepperi-addons-ngx-composite-lib-group-buttons-settings.mjs.map +1 -1
- package/fesm2020/pepperi-addons-ngx-composite-lib-icon-picker.mjs +10 -10
- package/fesm2020/pepperi-addons-ngx-composite-lib-icon-picker.mjs.map +1 -1
- package/fesm2020/pepperi-addons-ngx-composite-lib-layout-builder.mjs +844 -727
- package/fesm2020/pepperi-addons-ngx-composite-lib-layout-builder.mjs.map +1 -1
- package/fesm2020/pepperi-addons-ngx-composite-lib-manage-parameters.mjs +81 -33
- package/fesm2020/pepperi-addons-ngx-composite-lib-manage-parameters.mjs.map +1 -1
- package/fesm2020/pepperi-addons-ngx-composite-lib-mapping-parameters.mjs +209 -0
- package/fesm2020/pepperi-addons-ngx-composite-lib-mapping-parameters.mjs.map +1 -0
- package/fesm2020/pepperi-addons-ngx-composite-lib-padding-settings.mjs +37 -27
- package/fesm2020/pepperi-addons-ngx-composite-lib-padding-settings.mjs.map +1 -1
- package/fesm2020/pepperi-addons-ngx-composite-lib-rich-text.mjs +18 -18
- package/fesm2020/pepperi-addons-ngx-composite-lib-rich-text.mjs.map +1 -1
- package/fesm2020/pepperi-addons-ngx-composite-lib-shadow-settings.mjs +15 -15
- package/fesm2020/pepperi-addons-ngx-composite-lib-shadow-settings.mjs.map +1 -1
- package/fesm2020/pepperi-addons-ngx-composite-lib-show-if-badge.mjs +8 -8
- package/fesm2020/pepperi-addons-ngx-composite-lib-show-if-badge.mjs.map +1 -1
- package/fesm2020/pepperi-addons-ngx-composite-lib.mjs +33 -33
- package/fesm2020/pepperi-addons-ngx-composite-lib.mjs.map +1 -1
- package/file-status-panel/file-status-panel.component.d.ts +1 -1
- package/file-status-panel/file-status-panel.model.d.ts +1 -1
- package/flow-picker-button/flow-picker-button.component.d.ts +1 -1
- package/generic-fields-builder/field-container/field-container.component.d.ts +10 -0
- package/generic-fields-builder/generic-fields-builder.component.d.ts +46 -0
- package/generic-fields-builder/generic-fields-builder.module.d.ts +23 -0
- package/generic-fields-builder/generic-fields-builder.service.d.ts +14 -0
- package/generic-fields-builder/index.d.ts +5 -0
- package/generic-fields-builder/public-api.d.ts +2 -0
- package/generic-form/generic-form.component.d.ts +1 -1
- package/generic-list/generic-list.component.d.ts +25 -9
- package/generic-list/generic-list.module.d.ts +13 -11
- package/generic-list/generic-list.service.d.ts +3 -1
- package/group-buttons-settings/group-buttons-settings.component.d.ts +1 -1
- package/group-buttons-settings/group-buttons-settings.model.d.ts +1 -1
- package/icon-picker/icon-picker.component.d.ts +1 -1
- package/layout-builder/hide-in/hide-in.component.d.ts +1 -1
- package/layout-builder/hide-in/hide-in.component.theme.scss +1 -1
- package/layout-builder/layout/layout.component.d.ts +12 -8
- package/layout-builder/layout-builder-editor/layout-builder-editor.component.d.ts +1 -1
- package/layout-builder/layout-builder-internal.service.d.ts +5 -10
- package/layout-builder/layout-builder.component.d.ts +11 -4
- package/layout-builder/layout-builder.component.theme.scss +1 -1
- package/layout-builder/layout-builder.model.d.ts +3 -3
- package/layout-builder/layout-builder.service.d.ts +15 -6
- package/layout-builder/main-editor/main-editor.component.d.ts +7 -5
- package/layout-builder/section/section.component.d.ts +8 -1
- package/layout-builder/section-block/section-block.component.d.ts +1 -1
- package/layout-builder/section-editor/section-editor.component.d.ts +4 -1
- package/layout-builder/section-editor/section-editor.module.d.ts +3 -2
- package/manage-parameters/manage-parameter/manage-parameter.component.d.ts +3 -1
- package/manage-parameters/manage-parameters.component.d.ts +10 -3
- package/manage-parameters/manage-parameters.model.d.ts +4 -1
- package/manage-parameters/manage-parameters.service.d.ts +2 -2
- package/mapping-parameters/index.d.ts +5 -0
- package/mapping-parameters/mapping-parameters.component.d.ts +19 -0
- package/mapping-parameters/mapping-parameters.model.d.ts +8 -0
- package/mapping-parameters/mapping-parameters.module.d.ts +18 -0
- package/mapping-parameters/mapping-parameters.service.d.ts +12 -0
- package/mapping-parameters/param-map/param-map.component.d.ts +27 -0
- package/mapping-parameters/public-api.d.ts +3 -0
- package/package.json +19 -2
- package/padding-settings/padding-settings.component.d.ts +1 -1
- package/padding-settings/padding-settings.model.d.ts +2 -2
- package/rich-text/rich-text.component.d.ts +1 -1
- package/shadow-settings/shadow-settings.component.d.ts +1 -1
- package/shadow-settings/shadow-settings.model.d.ts +1 -1
- package/show-if-badge/show-if-badge.component.d.ts +1 -1
- package/src/assets/i18n/en.ngx-composite-lib.json +22 -2
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import { Component } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
import * as i1 from "../generic-fields-builder.service";
|
|
4
|
+
export class FieldContainerComponent {
|
|
5
|
+
constructor(genericFieldsBuilderService) {
|
|
6
|
+
this.genericFieldsBuilderService = genericFieldsBuilderService;
|
|
7
|
+
}
|
|
8
|
+
ngOnInit() {
|
|
9
|
+
//
|
|
10
|
+
}
|
|
11
|
+
}
|
|
12
|
+
FieldContainerComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: FieldContainerComponent, deps: [{ token: i1.GenericFieldsBuilderService }], target: i0.ɵɵFactoryTarget.Component });
|
|
13
|
+
FieldContainerComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: FieldContainerComponent, selector: "pep-field-container", ngImport: i0, template: "<div class=\"mapped-field-container\" >\n <div class=\"field-wrapper\">\n <ng-content></ng-content>\n </div>\n</div>", styles: [".mapped-field-container{cursor:grab;max-width:600px;display:flex;justify-content:center;align-items:center;border-radius:var(--pep-border-radius-md, .25rem);background:hsl(var(--pep-color-regular-h, 0),var(--pep-color-regular-s, 0%),98%);box-shadow:var(--pep-shadow-xs-offset, 0 .125rem .25rem 0) hsla(var(--pep-color-system-primary-h, 0),var(--pep-color-system-primary-s, 0%),var(--pep-color-system-primary-l, 10%),.08);border:1px solid hsl(var(--pep-color-regular-h, 0),var(--pep-color-regular-s, 0%),calc(var(--pep-color-regular-l, 10%) + 30%));min-height:2.5rem}\n"] });
|
|
14
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: FieldContainerComponent, decorators: [{
|
|
15
|
+
type: Component,
|
|
16
|
+
args: [{ selector: 'pep-field-container', template: "<div class=\"mapped-field-container\" >\n <div class=\"field-wrapper\">\n <ng-content></ng-content>\n </div>\n</div>", styles: [".mapped-field-container{cursor:grab;max-width:600px;display:flex;justify-content:center;align-items:center;border-radius:var(--pep-border-radius-md, .25rem);background:hsl(var(--pep-color-regular-h, 0),var(--pep-color-regular-s, 0%),98%);box-shadow:var(--pep-shadow-xs-offset, 0 .125rem .25rem 0) hsla(var(--pep-color-system-primary-h, 0),var(--pep-color-system-primary-s, 0%),var(--pep-color-system-primary-l, 10%),.08);border:1px solid hsl(var(--pep-color-regular-h, 0),var(--pep-color-regular-s, 0%),calc(var(--pep-color-regular-l, 10%) + 30%));min-height:2.5rem}\n"] }]
|
|
17
|
+
}], ctorParameters: function () { return [{ type: i1.GenericFieldsBuilderService }]; } });
|
|
18
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmllbGQtY29udGFpbmVyLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25neC1jb21wb3NpdGUtbGliL2dlbmVyaWMtZmllbGRzLWJ1aWxkZXIvZmllbGQtY29udGFpbmVyL2ZpZWxkLWNvbnRhaW5lci5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtY29tcG9zaXRlLWxpYi9nZW5lcmljLWZpZWxkcy1idWlsZGVyL2ZpZWxkLWNvbnRhaW5lci9maWVsZC1jb250YWluZXIuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQ0EsT0FBTyxFQUFFLFNBQVMsRUFBK0QsTUFBTSxlQUFlLENBQUM7OztBQVF2RyxNQUFNLE9BQU8sdUJBQXVCO0lBRWhDLFlBQ1ksMkJBQXdEO1FBQXhELGdDQUEyQixHQUEzQiwyQkFBMkIsQ0FBNkI7SUFFcEUsQ0FBQztJQUVELFFBQVE7UUFDSixFQUFFO0lBQ04sQ0FBQzs7cUhBVFEsdUJBQXVCO3lHQUF2Qix1QkFBdUIsMkRDVHBDLG1JQUlNOzRGREtPLHVCQUF1QjtrQkFMbkMsU0FBUzsrQkFDSSxxQkFBcUIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDZGtEcmFnRHJvcCwgQ2RrRHJhZ0VuZCwgQ2RrRHJhZ1N0YXJ0LCBtb3ZlSXRlbUluQXJyYXkgfSBmcm9tICdAYW5ndWxhci9jZGsvZHJhZy1kcm9wJztcbmltcG9ydCB7IENvbXBvbmVudCwgRXZlbnRFbWl0dGVyLCBJbnB1dCwgT25Jbml0LCBPdXRwdXQsIFRlbXBsYXRlUmVmLCBWaWV3Q2hpbGQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEdlbmVyaWNGaWVsZHNCdWlsZGVyU2VydmljZSB9IGZyb20gJy4uL2dlbmVyaWMtZmllbGRzLWJ1aWxkZXIuc2VydmljZSc7XG5cbkBDb21wb25lbnQoe1xuICAgIHNlbGVjdG9yOiAncGVwLWZpZWxkLWNvbnRhaW5lcicsXG4gICAgdGVtcGxhdGVVcmw6ICcuL2ZpZWxkLWNvbnRhaW5lci5jb21wb25lbnQuaHRtbCcsXG4gICAgc3R5bGVVcmxzOiBbJy4vZmllbGQtY29udGFpbmVyLmNvbXBvbmVudC5zY3NzJ11cbn0pXG5leHBvcnQgY2xhc3MgRmllbGRDb250YWluZXJDb21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQge1xuICAgIFxuICAgIGNvbnN0cnVjdG9yKFxuICAgICAgICBwcml2YXRlIGdlbmVyaWNGaWVsZHNCdWlsZGVyU2VydmljZTogR2VuZXJpY0ZpZWxkc0J1aWxkZXJTZXJ2aWNlXG4gICAgKSB7XG4gICAgfVxuXG4gICAgbmdPbkluaXQoKSB7XG4gICAgICAgIC8vXG4gICAgfVxufVxuIiwiPGRpdiBjbGFzcz1cIm1hcHBlZC1maWVsZC1jb250YWluZXJcIiA+XG4gICAgPGRpdiBjbGFzcz1cImZpZWxkLXdyYXBwZXJcIj5cbiAgICAgICAgPG5nLWNvbnRlbnQ+PC9uZy1jb250ZW50PlxuICAgIDwvZGl2PlxuPC9kaXY+Il19
|
|
@@ -0,0 +1,119 @@
|
|
|
1
|
+
import { moveItemInArray } from '@angular/cdk/drag-drop';
|
|
2
|
+
import { Component, EventEmitter, Input, Output } from '@angular/core';
|
|
3
|
+
import { PepGuid } from '@pepperi-addons/ngx-lib';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
import * as i1 from "./generic-fields-builder.service";
|
|
6
|
+
import * as i2 from "@angular/common";
|
|
7
|
+
import * as i3 from "@angular/cdk/drag-drop";
|
|
8
|
+
import * as i4 from "@angular/material/icon";
|
|
9
|
+
import * as i5 from "@pepperi-addons/ngx-lib/icon";
|
|
10
|
+
import * as i6 from "@pepperi-addons/ngx-lib/page-layout";
|
|
11
|
+
import * as i7 from "@pepperi-addons/ngx-lib/draggable-items";
|
|
12
|
+
import * as i8 from "./field-container/field-container.component";
|
|
13
|
+
import * as i9 from "@ngx-translate/core";
|
|
14
|
+
export class GenericFieldsBuilderComponent {
|
|
15
|
+
set availableFields(value) {
|
|
16
|
+
this._availableFields = value;
|
|
17
|
+
}
|
|
18
|
+
get availableFields() {
|
|
19
|
+
return this._availableFields;
|
|
20
|
+
}
|
|
21
|
+
set fields(value) {
|
|
22
|
+
this._fields = value;
|
|
23
|
+
}
|
|
24
|
+
get fields() {
|
|
25
|
+
return this._fields;
|
|
26
|
+
}
|
|
27
|
+
constructor(genericFieldsBuilderService) {
|
|
28
|
+
this.genericFieldsBuilderService = genericFieldsBuilderService;
|
|
29
|
+
// @Input() title: string = '';
|
|
30
|
+
this.builderTitle = '';
|
|
31
|
+
this.builderTitleHint = '';
|
|
32
|
+
this.showAddSeparator = true;
|
|
33
|
+
this.itemKeyLabel = '';
|
|
34
|
+
this.itemTitleLabel = '';
|
|
35
|
+
this._availableFields = [];
|
|
36
|
+
this.fieldTemplate = undefined;
|
|
37
|
+
this._fields = [];
|
|
38
|
+
this.fieldsChange = new EventEmitter();
|
|
39
|
+
this.fieldAdd = new EventEmitter();
|
|
40
|
+
this.emptyDropAreaId = 'emptyDropArea';
|
|
41
|
+
this.mappedFieldsId = 'mappedFields';
|
|
42
|
+
this.isGrabbing = false;
|
|
43
|
+
this.genericFieldsBuilderService.isGrabbingChange$.subscribe((value) => {
|
|
44
|
+
this.isGrabbing = value;
|
|
45
|
+
});
|
|
46
|
+
}
|
|
47
|
+
notifyFieldsChange() {
|
|
48
|
+
this.fieldsChange.emit(this._fields);
|
|
49
|
+
}
|
|
50
|
+
addNewField(draggableItem, index) {
|
|
51
|
+
// Add new menuField to the mappedFields.
|
|
52
|
+
const field = {
|
|
53
|
+
key: PepGuid.newGuid(),
|
|
54
|
+
draggableItemData: draggableItem.data,
|
|
55
|
+
title: draggableItem.title
|
|
56
|
+
};
|
|
57
|
+
this.spliceMappedFields(index, 0, field);
|
|
58
|
+
this.fieldAdd.emit({ field, index });
|
|
59
|
+
}
|
|
60
|
+
spliceMappedFields(start, deleteCount, field) {
|
|
61
|
+
if (field) {
|
|
62
|
+
this._fields.splice(start, deleteCount, field);
|
|
63
|
+
}
|
|
64
|
+
else {
|
|
65
|
+
this._fields.splice(start, deleteCount);
|
|
66
|
+
}
|
|
67
|
+
this.notifyFieldsChange();
|
|
68
|
+
}
|
|
69
|
+
ngOnInit() {
|
|
70
|
+
//
|
|
71
|
+
}
|
|
72
|
+
onDragStart(event) {
|
|
73
|
+
this.genericFieldsBuilderService.onDragStart(event);
|
|
74
|
+
}
|
|
75
|
+
onDragEnd(event) {
|
|
76
|
+
this.genericFieldsBuilderService.onDragEnd(event);
|
|
77
|
+
}
|
|
78
|
+
onDropField(event) {
|
|
79
|
+
if (event.previousContainer === event.container) {
|
|
80
|
+
moveItemInArray(event.container.data, event.previousIndex, event.currentIndex);
|
|
81
|
+
this.notifyFieldsChange();
|
|
82
|
+
}
|
|
83
|
+
else if (event.container.id === 'emptyDropArea') {
|
|
84
|
+
this.addNewField(event.previousContainer.data[event.previousIndex], this.fields.length);
|
|
85
|
+
}
|
|
86
|
+
else {
|
|
87
|
+
this.addNewField(event.previousContainer.data[event.previousIndex], event.currentIndex);
|
|
88
|
+
}
|
|
89
|
+
}
|
|
90
|
+
}
|
|
91
|
+
GenericFieldsBuilderComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: GenericFieldsBuilderComponent, deps: [{ token: i1.GenericFieldsBuilderService }], target: i0.ɵɵFactoryTarget.Component });
|
|
92
|
+
GenericFieldsBuilderComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: GenericFieldsBuilderComponent, selector: "pep-generic-fields-builder", inputs: { builderTitle: "builderTitle", builderTitleHint: "builderTitleHint", showAddSeparator: "showAddSeparator", itemKeyLabel: "itemKeyLabel", itemTitleLabel: "itemTitleLabel", setAddedFieldDataCallback: "setAddedFieldDataCallback", availableFields: "availableFields", fieldTemplate: "fieldTemplate", fields: "fields" }, outputs: { fieldsChange: "fieldsChange", fieldAdd: "fieldAdd" }, ngImport: i0, template: "<pep-page-layout >\n <ng-container pep-main-area>\n <div *ngIf=\"availableFields\" class=\"mapped-fields-container\">\n <div class=\"available-fields-side-area\">\n <pep-draggable-items [items]=\"availableFields\" [title]=\"'GENERIC_FIELDS_BUILDER.AVAILABLE_FIELDS' | translate\" titleType=\"with-bottom-border\" titleSizeType=\"md\"\n itemPlaceholderType=\"weak\" [showSearch]=\"true\" [dropAreaIds]=\"['emptyDropArea', 'mappedFields']\" (itemDragStarted)=\"onDragStart($event)\" (itemDragEnded)=\"onDragEnd($event)\">\n </pep-draggable-items>\n </div>\n <div pep-main-area class=\"mapped-fields-main-area\">\n <div class=\"mapped-fields-top-area pep-border-bottom\"\n [title]=\"builderTitle + ' ' + (builderTitleHint ? ('(' + builderTitleHint + ')') : '')\">\n <span class=\"title-md\">{{ builderTitle }} </span>\n <span *ngIf=\"builderTitleHint\" class=\"color-dimmed\">({{ builderTitleHint }})</span>\n </div>\n \n <div class=\"fields-area\">\n <ng-container *ngIf=\"fields === null || fields.length === 0; then emptyTemplate; else notEmptyTemplate\"></ng-container>\n <ng-template #emptyTemplate>\n <div [id]=\"emptyDropAreaId\" class=\"drop-field-here-area\" cdkDropList (cdkDropListDropped)=\"onDropField($event)\">\n <mat-icon class=\"pep-spacing-element\">\n <pep-icon name=\"arrow_down_alt\"></pep-icon>\n </mat-icon>\n <span class=\"body-sm ellipsis\">\n {{ 'GENERIC_FIELDS_BUILDER.EMPTY_DROP_AREA_TEXT' | translate }}\n </span> \n </div>\n </ng-template>\n <ng-template #notEmptyTemplate>\n <div [id]=\"mappedFieldsId\" class=\"mapped-fields-area\" [ngClass]=\"{ 'no-row-gap': !isGrabbing }\"\n cdkDropList [cdkDropListData]=\"fields\" (cdkDropListDropped)=\"onDropField($event)\">\n <ng-container *ngFor=\"let field of fields; let i = index\" >\n <pep-field-container cdkDrag (cdkDragStarted)=\"onDragStart($event)\" (cdkDragEnded)=\"onDragEnd($event)\">\n <ng-container *ngTemplateOutlet=\"fieldTemplate || defaultTemplate; context: { field: field, index: i }\"></ng-container>\n </pep-field-container>\n <!-- <div class=\"mapped-field-container\" \n cdkDrag (cdkDragStarted)=\"onDragStart($event)\" (cdkDragEnded)=\"onDragEnd($event)\">\n \n <div class=\"field-wrapper\">\n <ng-container *ngTemplateOutlet=\"fieldTemplate || defaultTemplate; context: { field: field, index: i }\"></ng-container>\n </div>\n </div> -->\n </ng-container>\n </div>\n </ng-template>\n </div>\n </div>\n </div>\n </ng-container>\n</pep-page-layout>\n\n<ng-template #defaultTemplate let-field=\"field\" let-index=\"index\">\n {{ 'GENERIC_FIELDS_BUILDER.TEMPLATE_NOT_SUPPLIED' | translate: { fieldTitle: field.title || field.key } }}\n</ng-template>\n", styles: [".mapped-field-container{cursor:grab;max-width:600px;display:flex;justify-content:center;align-items:center;border-radius:var(--pep-border-radius-md, .25rem);background:hsl(var(--pep-color-regular-h, 0),var(--pep-color-regular-s, 0%),98%);box-shadow:var(--pep-shadow-xs-offset, 0 .125rem .25rem 0) hsla(var(--pep-color-system-primary-h, 0),var(--pep-color-system-primary-s, 0%),var(--pep-color-system-primary-l, 10%),.08);border:1px solid hsl(var(--pep-color-regular-h, 0),var(--pep-color-regular-s, 0%),calc(var(--pep-color-regular-l, 10%) + 30%));min-height:2.5rem}.mapped-fields-container{display:grid;height:100%;grid-template-columns:auto 1fr;grid-template-areas:\"side-area main-area\"}.mapped-fields-container .available-fields-side-area{grid-area:side-area;width:240px;max-width:240px;overflow:auto;height:inherit;padding-top:var(--pep-spacing-2xl, 2rem);margin-inline-end:calc(var(--pep-spacing-lg, 1rem) * 2)}.mapped-fields-container .mapped-fields-main-area{display:grid;grid-template-rows:auto 1fr;grid-area:main-area;padding-top:var(--pep-spacing-2xl, 2rem);overflow:auto;height:inherit}.mapped-fields-container .mapped-fields-main-area .mapped-fields-top-area{height:var(--pep-top-bar-field-height, 2.5rem);display:flex;align-items:center}.mapped-fields-container .mapped-fields-main-area .fields-area{overflow:auto;height:inherit;padding-top:var(--pep-spacing-lg, 1rem);padding-bottom:var(--pep-spacing-lg, 1rem);padding-inline:var(--pep-spacing-xs, .25rem)}.drop-field-here-area{min-height:5rem;max-width:600px;display:flex;justify-content:center;align-items:center;border-radius:var(--pep-border-radius-md, .25rem);background:hsla(var(--pep-color-weak-h, 0),var(--pep-color-weak-s, 0%),var(--pep-color-weak-l, 10%),.08);position:relative}.drop-field-here-area:after{z-index:0;content:\"\";transition:all .25s;display:block;position:absolute;inset:0;border-radius:inherit;border:1px dashed hsl(var(--pep-color-system-primary-h, 0),var(--pep-color-system-primary-s, 0%),calc(var(--pep-color-system-primary-l, 10%) + 30%))}.drop-field-here-area.cdk-drop-list-dragging{box-shadow:0 0 0 var(--pep-spacing-xs, .25rem) hsla(var(--pep-color-text-link-h, 207),var(--pep-color-text-link-s, 76%),var(--pep-color-text-link-l, 37%),.5)}.drop-field-here-area.cdk-drop-list-dragging:hover{background:hsl(var(--pep-color-regular-h, 0),var(--pep-color-regular-s, 0%),98%);box-shadow:var(--pep-shadow-xs-offset, 0 .125rem .25rem 0) hsla(var(--pep-color-system-primary-h, 0),var(--pep-color-system-primary-s, 0%),var(--pep-color-system-primary-l, 10%),.16);border:1px solid hsl(var(--pep-color-regular-h, 0),var(--pep-color-regular-s, 0%),calc(var(--pep-color-regular-l, 10%) + 20%));box-shadow:0 0 0 var(--pep-spacing-xs, .25rem) hsla(var(--pep-color-text-link-h, 207),var(--pep-color-text-link-s, 76%),var(--pep-color-text-link-l, 37%),.5)}.drop-field-here-area.cdk-drop-list-dragging ::ng-deep .placeholder-item{display:none}.mapped-fields-area{display:flex;flex-direction:column;gap:var(--pep-spacing-lg, 1rem)}.mapped-fields-area.cdk-drop-list-dragging ::ng-deep .placeholder-item{max-width:600px;display:flex;justify-content:center;align-items:center;border-radius:var(--pep-border-radius-md, .25rem);background:hsl(var(--pep-color-regular-h, 0),var(--pep-color-regular-s, 0%),98%);box-shadow:var(--pep-shadow-xs-offset, 0 .125rem .25rem 0) hsla(var(--pep-color-system-primary-h, 0),var(--pep-color-system-primary-s, 0%),var(--pep-color-system-primary-l, 10%),.08);border:1px solid hsl(var(--pep-color-regular-h, 0),var(--pep-color-regular-s, 0%),calc(var(--pep-color-regular-l, 10%) + 30%));box-shadow:0 0 0 var(--pep-spacing-xs, .25rem) hsla(var(--pep-color-text-link-h, 207),var(--pep-color-text-link-s, 76%),var(--pep-color-text-link-l, 37%),.5);height:0!important}.mapped-fields-area .cdk-drag-placeholder ::ng-deep .mapped-field-container{box-shadow:0 0 0 var(--pep-spacing-xs, .25rem) hsla(var(--pep-color-text-link-h, 207),var(--pep-color-text-link-s, 76%),var(--pep-color-text-link-l, 37%),.5)}.mapped-fields-area .cdk-drag-placeholder ::ng-deep .mapped-field-container .field-wrapper{opacity:0}\n"], dependencies: [{ kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i3.CdkDropList, selector: "[cdkDropList], cdk-drop-list", inputs: ["cdkDropListConnectedTo", "cdkDropListData", "cdkDropListOrientation", "id", "cdkDropListLockAxis", "cdkDropListDisabled", "cdkDropListSortingDisabled", "cdkDropListEnterPredicate", "cdkDropListSortPredicate", "cdkDropListAutoScrollDisabled", "cdkDropListAutoScrollStep"], outputs: ["cdkDropListDropped", "cdkDropListEntered", "cdkDropListExited", "cdkDropListSorted"], exportAs: ["cdkDropList"] }, { kind: "directive", type: i3.CdkDrag, selector: "[cdkDrag]", inputs: ["cdkDragData", "cdkDragLockAxis", "cdkDragRootElement", "cdkDragBoundary", "cdkDragStartDelay", "cdkDragFreeDragPosition", "cdkDragDisabled", "cdkDragConstrainPosition", "cdkDragPreviewClass", "cdkDragPreviewContainer"], outputs: ["cdkDragStarted", "cdkDragReleased", "cdkDragEnded", "cdkDragEntered", "cdkDragExited", "cdkDragDropped", "cdkDragMoved"], exportAs: ["cdkDrag"] }, { kind: "component", type: i4.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: i5.PepIconComponent, selector: "pep-icon", inputs: ["spin", "name", "fill"] }, { kind: "component", type: i6.PepPageLayoutComponent, selector: "pep-page-layout", inputs: ["addPadding", "showShadow"] }, { kind: "component", type: i7.PepDraggableItemsComponent, selector: "pep-draggable-items", inputs: ["containerId", "showSearch", "title", "titleType", "titleSizeType", "itemPlaceholderType", "dropAreaIds", "items"], outputs: ["itemDragStarted", "itemDragEnded"] }, { kind: "component", type: i8.FieldContainerComponent, selector: "pep-field-container" }, { kind: "pipe", type: i9.TranslatePipe, name: "translate" }] });
|
|
93
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: GenericFieldsBuilderComponent, decorators: [{
|
|
94
|
+
type: Component,
|
|
95
|
+
args: [{ selector: 'pep-generic-fields-builder', template: "<pep-page-layout >\n <ng-container pep-main-area>\n <div *ngIf=\"availableFields\" class=\"mapped-fields-container\">\n <div class=\"available-fields-side-area\">\n <pep-draggable-items [items]=\"availableFields\" [title]=\"'GENERIC_FIELDS_BUILDER.AVAILABLE_FIELDS' | translate\" titleType=\"with-bottom-border\" titleSizeType=\"md\"\n itemPlaceholderType=\"weak\" [showSearch]=\"true\" [dropAreaIds]=\"['emptyDropArea', 'mappedFields']\" (itemDragStarted)=\"onDragStart($event)\" (itemDragEnded)=\"onDragEnd($event)\">\n </pep-draggable-items>\n </div>\n <div pep-main-area class=\"mapped-fields-main-area\">\n <div class=\"mapped-fields-top-area pep-border-bottom\"\n [title]=\"builderTitle + ' ' + (builderTitleHint ? ('(' + builderTitleHint + ')') : '')\">\n <span class=\"title-md\">{{ builderTitle }} </span>\n <span *ngIf=\"builderTitleHint\" class=\"color-dimmed\">({{ builderTitleHint }})</span>\n </div>\n \n <div class=\"fields-area\">\n <ng-container *ngIf=\"fields === null || fields.length === 0; then emptyTemplate; else notEmptyTemplate\"></ng-container>\n <ng-template #emptyTemplate>\n <div [id]=\"emptyDropAreaId\" class=\"drop-field-here-area\" cdkDropList (cdkDropListDropped)=\"onDropField($event)\">\n <mat-icon class=\"pep-spacing-element\">\n <pep-icon name=\"arrow_down_alt\"></pep-icon>\n </mat-icon>\n <span class=\"body-sm ellipsis\">\n {{ 'GENERIC_FIELDS_BUILDER.EMPTY_DROP_AREA_TEXT' | translate }}\n </span> \n </div>\n </ng-template>\n <ng-template #notEmptyTemplate>\n <div [id]=\"mappedFieldsId\" class=\"mapped-fields-area\" [ngClass]=\"{ 'no-row-gap': !isGrabbing }\"\n cdkDropList [cdkDropListData]=\"fields\" (cdkDropListDropped)=\"onDropField($event)\">\n <ng-container *ngFor=\"let field of fields; let i = index\" >\n <pep-field-container cdkDrag (cdkDragStarted)=\"onDragStart($event)\" (cdkDragEnded)=\"onDragEnd($event)\">\n <ng-container *ngTemplateOutlet=\"fieldTemplate || defaultTemplate; context: { field: field, index: i }\"></ng-container>\n </pep-field-container>\n <!-- <div class=\"mapped-field-container\" \n cdkDrag (cdkDragStarted)=\"onDragStart($event)\" (cdkDragEnded)=\"onDragEnd($event)\">\n \n <div class=\"field-wrapper\">\n <ng-container *ngTemplateOutlet=\"fieldTemplate || defaultTemplate; context: { field: field, index: i }\"></ng-container>\n </div>\n </div> -->\n </ng-container>\n </div>\n </ng-template>\n </div>\n </div>\n </div>\n </ng-container>\n</pep-page-layout>\n\n<ng-template #defaultTemplate let-field=\"field\" let-index=\"index\">\n {{ 'GENERIC_FIELDS_BUILDER.TEMPLATE_NOT_SUPPLIED' | translate: { fieldTitle: field.title || field.key } }}\n</ng-template>\n", styles: [".mapped-field-container{cursor:grab;max-width:600px;display:flex;justify-content:center;align-items:center;border-radius:var(--pep-border-radius-md, .25rem);background:hsl(var(--pep-color-regular-h, 0),var(--pep-color-regular-s, 0%),98%);box-shadow:var(--pep-shadow-xs-offset, 0 .125rem .25rem 0) hsla(var(--pep-color-system-primary-h, 0),var(--pep-color-system-primary-s, 0%),var(--pep-color-system-primary-l, 10%),.08);border:1px solid hsl(var(--pep-color-regular-h, 0),var(--pep-color-regular-s, 0%),calc(var(--pep-color-regular-l, 10%) + 30%));min-height:2.5rem}.mapped-fields-container{display:grid;height:100%;grid-template-columns:auto 1fr;grid-template-areas:\"side-area main-area\"}.mapped-fields-container .available-fields-side-area{grid-area:side-area;width:240px;max-width:240px;overflow:auto;height:inherit;padding-top:var(--pep-spacing-2xl, 2rem);margin-inline-end:calc(var(--pep-spacing-lg, 1rem) * 2)}.mapped-fields-container .mapped-fields-main-area{display:grid;grid-template-rows:auto 1fr;grid-area:main-area;padding-top:var(--pep-spacing-2xl, 2rem);overflow:auto;height:inherit}.mapped-fields-container .mapped-fields-main-area .mapped-fields-top-area{height:var(--pep-top-bar-field-height, 2.5rem);display:flex;align-items:center}.mapped-fields-container .mapped-fields-main-area .fields-area{overflow:auto;height:inherit;padding-top:var(--pep-spacing-lg, 1rem);padding-bottom:var(--pep-spacing-lg, 1rem);padding-inline:var(--pep-spacing-xs, .25rem)}.drop-field-here-area{min-height:5rem;max-width:600px;display:flex;justify-content:center;align-items:center;border-radius:var(--pep-border-radius-md, .25rem);background:hsla(var(--pep-color-weak-h, 0),var(--pep-color-weak-s, 0%),var(--pep-color-weak-l, 10%),.08);position:relative}.drop-field-here-area:after{z-index:0;content:\"\";transition:all .25s;display:block;position:absolute;inset:0;border-radius:inherit;border:1px dashed hsl(var(--pep-color-system-primary-h, 0),var(--pep-color-system-primary-s, 0%),calc(var(--pep-color-system-primary-l, 10%) + 30%))}.drop-field-here-area.cdk-drop-list-dragging{box-shadow:0 0 0 var(--pep-spacing-xs, .25rem) hsla(var(--pep-color-text-link-h, 207),var(--pep-color-text-link-s, 76%),var(--pep-color-text-link-l, 37%),.5)}.drop-field-here-area.cdk-drop-list-dragging:hover{background:hsl(var(--pep-color-regular-h, 0),var(--pep-color-regular-s, 0%),98%);box-shadow:var(--pep-shadow-xs-offset, 0 .125rem .25rem 0) hsla(var(--pep-color-system-primary-h, 0),var(--pep-color-system-primary-s, 0%),var(--pep-color-system-primary-l, 10%),.16);border:1px solid hsl(var(--pep-color-regular-h, 0),var(--pep-color-regular-s, 0%),calc(var(--pep-color-regular-l, 10%) + 20%));box-shadow:0 0 0 var(--pep-spacing-xs, .25rem) hsla(var(--pep-color-text-link-h, 207),var(--pep-color-text-link-s, 76%),var(--pep-color-text-link-l, 37%),.5)}.drop-field-here-area.cdk-drop-list-dragging ::ng-deep .placeholder-item{display:none}.mapped-fields-area{display:flex;flex-direction:column;gap:var(--pep-spacing-lg, 1rem)}.mapped-fields-area.cdk-drop-list-dragging ::ng-deep .placeholder-item{max-width:600px;display:flex;justify-content:center;align-items:center;border-radius:var(--pep-border-radius-md, .25rem);background:hsl(var(--pep-color-regular-h, 0),var(--pep-color-regular-s, 0%),98%);box-shadow:var(--pep-shadow-xs-offset, 0 .125rem .25rem 0) hsla(var(--pep-color-system-primary-h, 0),var(--pep-color-system-primary-s, 0%),var(--pep-color-system-primary-l, 10%),.08);border:1px solid hsl(var(--pep-color-regular-h, 0),var(--pep-color-regular-s, 0%),calc(var(--pep-color-regular-l, 10%) + 30%));box-shadow:0 0 0 var(--pep-spacing-xs, .25rem) hsla(var(--pep-color-text-link-h, 207),var(--pep-color-text-link-s, 76%),var(--pep-color-text-link-l, 37%),.5);height:0!important}.mapped-fields-area .cdk-drag-placeholder ::ng-deep .mapped-field-container{box-shadow:0 0 0 var(--pep-spacing-xs, .25rem) hsla(var(--pep-color-text-link-h, 207),var(--pep-color-text-link-s, 76%),var(--pep-color-text-link-l, 37%),.5)}.mapped-fields-area .cdk-drag-placeholder ::ng-deep .mapped-field-container .field-wrapper{opacity:0}\n"] }]
|
|
96
|
+
}], ctorParameters: function () { return [{ type: i1.GenericFieldsBuilderService }]; }, propDecorators: { builderTitle: [{
|
|
97
|
+
type: Input
|
|
98
|
+
}], builderTitleHint: [{
|
|
99
|
+
type: Input
|
|
100
|
+
}], showAddSeparator: [{
|
|
101
|
+
type: Input
|
|
102
|
+
}], itemKeyLabel: [{
|
|
103
|
+
type: Input
|
|
104
|
+
}], itemTitleLabel: [{
|
|
105
|
+
type: Input
|
|
106
|
+
}], setAddedFieldDataCallback: [{
|
|
107
|
+
type: Input
|
|
108
|
+
}], availableFields: [{
|
|
109
|
+
type: Input
|
|
110
|
+
}], fieldTemplate: [{
|
|
111
|
+
type: Input
|
|
112
|
+
}], fields: [{
|
|
113
|
+
type: Input
|
|
114
|
+
}], fieldsChange: [{
|
|
115
|
+
type: Output
|
|
116
|
+
}], fieldAdd: [{
|
|
117
|
+
type: Output
|
|
118
|
+
}] } });
|
|
119
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"generic-fields-builder.component.js","sourceRoot":"","sources":["../../../../projects/ngx-composite-lib/generic-fields-builder/generic-fields-builder.component.ts","../../../../projects/ngx-composite-lib/generic-fields-builder/generic-fields-builder.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CdkDragDrop, CdkDragEnd, CdkDragStart, moveItemInArray } from '@angular/cdk/drag-drop';\nimport { Component, EventEmitter, Input, OnInit, Output, TemplateRef, ViewChild } from '@angular/core';\nimport { IPepDraggableItem, IPepDraggableItemData } from '@pepperi-addons/ngx-lib/draggable-items';\nimport { GenericFieldsBuilderService } from './generic-fields-builder.service';\nimport { PepGuid } from '@pepperi-addons/ngx-lib';\n\nexport interface IPepGenericField {\n    key: string,\n    title: string,\n    draggableItemData: IPepDraggableItemData\n    [key: string]: any;\n}\n\nexport interface IPepGenericFieldAddedEvent {\n    field: IPepGenericField,\n    index: number,\n}\n\n@Component({\n    selector: 'pep-generic-fields-builder',\n    templateUrl: './generic-fields-builder.component.html',\n    styleUrls: ['./generic-fields-builder.component.scss']\n})\nexport class GenericFieldsBuilderComponent implements OnInit {\n    // @Input() title: string = '';\n    @Input() builderTitle = '';\n    @Input() builderTitleHint = '';\n    @Input() showAddSeparator = true;\n    @Input() itemKeyLabel = '';\n    @Input() itemTitleLabel = '';\n    @Input() setAddedFieldDataCallback: (() => void) | undefined;// Function | undefined = undefined;\n\n    private _availableFields: Array<IPepDraggableItem> = [];\n    @Input()\n    set availableFields(value: Array<IPepDraggableItem>) {\n        this._availableFields = value;\n    }\n    get availableFields(): Array<IPepDraggableItem> {\n        return this._availableFields;\n    }\n    \n    @Input() fieldTemplate: TemplateRef<any> | undefined = undefined;\n    \n    private _fields: IPepGenericField[] = [];\n    @Input()\n    set fields(value: IPepGenericField[]) {\n        this._fields = value;\n    }\n    get fields() : IPepGenericField[] {\n        return this._fields;\n    }\n\n    @Output()\n    fieldsChange: EventEmitter<IPepGenericField[]> = new EventEmitter<IPepGenericField[]>();\n    \n    @Output()\n    fieldAdd: EventEmitter<IPepGenericFieldAddedEvent> = new EventEmitter<IPepGenericFieldAddedEvent>();\n    \n    emptyDropAreaId = 'emptyDropArea';\n    mappedFieldsId = 'mappedFields';\n    isGrabbing = false;\n\n    constructor(\n        private genericFieldsBuilderService: GenericFieldsBuilderService\n    ) {\n        this.genericFieldsBuilderService.isGrabbingChange$.subscribe((value) => {\n            this.isGrabbing = value;\n        });\n    }\n\n    private notifyFieldsChange() {\n        this.fieldsChange.emit(this._fields);\n    }\n\n    private addNewField(draggableItem: IPepDraggableItem, index: number) {\n        // Add new menuField to the mappedFields.\n        const field: IPepGenericField = { \n            key: PepGuid.newGuid(), \n            draggableItemData: draggableItem.data,\n            title: draggableItem.title \n        };\n\n        this.spliceMappedFields(index, 0, field);\n        this.fieldAdd.emit({field, index});\n    }\n    \n    private spliceMappedFields(start: number, deleteCount: number, field?: any) {\n        if (field) {\n            this._fields.splice(start, deleteCount, field);\n        } else {\n            this._fields.splice(start, deleteCount);\n        }\n\n        this.notifyFieldsChange();\n    }\n\n    ngOnInit() {\n        //\n    }\n\n    onDragStart(event: CdkDragStart) {\n        this.genericFieldsBuilderService.onDragStart(event);\n    }\n    \n    onDragEnd(event: CdkDragEnd) {\n        this.genericFieldsBuilderService.onDragEnd(event);\n    }\n\n    onDropField(event: CdkDragDrop<any[]>) {\n        if (event.previousContainer === event.container) {\n            moveItemInArray(event.container.data, event.previousIndex, event.currentIndex);\n            this.notifyFieldsChange();\n        } else if (event.container.id === 'emptyDropArea') {\n            this.addNewField(event.previousContainer.data[event.previousIndex], this.fields.length);\n        } else {\n            this.addNewField(event.previousContainer.data[event.previousIndex], event.currentIndex);\n        }\n    }\n}\n","<pep-page-layout >\n    <ng-container pep-main-area>\n        <div *ngIf=\"availableFields\" class=\"mapped-fields-container\">\n            <div class=\"available-fields-side-area\">\n                <pep-draggable-items [items]=\"availableFields\" [title]=\"'GENERIC_FIELDS_BUILDER.AVAILABLE_FIELDS' | translate\" titleType=\"with-bottom-border\" titleSizeType=\"md\"\n                    itemPlaceholderType=\"weak\" [showSearch]=\"true\" [dropAreaIds]=\"['emptyDropArea', 'mappedFields']\" (itemDragStarted)=\"onDragStart($event)\" (itemDragEnded)=\"onDragEnd($event)\">\n                </pep-draggable-items>\n            </div>\n            <div pep-main-area class=\"mapped-fields-main-area\">\n                <div class=\"mapped-fields-top-area pep-border-bottom\"\n                    [title]=\"builderTitle + ' ' + (builderTitleHint ? ('(' + builderTitleHint + ')') : '')\">\n                    <span class=\"title-md\">{{ builderTitle }}&nbsp;</span>\n                    <span *ngIf=\"builderTitleHint\" class=\"color-dimmed\">({{ builderTitleHint }})</span>\n                </div>\n                \n                <div class=\"fields-area\">\n                    <ng-container *ngIf=\"fields === null || fields.length === 0; then emptyTemplate; else notEmptyTemplate\"></ng-container>\n                    <ng-template #emptyTemplate>\n                        <div [id]=\"emptyDropAreaId\" class=\"drop-field-here-area\" cdkDropList (cdkDropListDropped)=\"onDropField($event)\">\n                            <mat-icon class=\"pep-spacing-element\">\n                                <pep-icon name=\"arrow_down_alt\"></pep-icon>\n                            </mat-icon>\n                            <span class=\"body-sm ellipsis\">\n                                {{ 'GENERIC_FIELDS_BUILDER.EMPTY_DROP_AREA_TEXT' | translate }}\n                            </span> \n                        </div>\n                    </ng-template>\n                    <ng-template #notEmptyTemplate>\n                        <div [id]=\"mappedFieldsId\" class=\"mapped-fields-area\" [ngClass]=\"{ 'no-row-gap': !isGrabbing }\"\n                            cdkDropList [cdkDropListData]=\"fields\" (cdkDropListDropped)=\"onDropField($event)\">\n                            <ng-container *ngFor=\"let field of fields; let i = index\" >\n                                <pep-field-container cdkDrag (cdkDragStarted)=\"onDragStart($event)\" (cdkDragEnded)=\"onDragEnd($event)\">\n                                    <ng-container *ngTemplateOutlet=\"fieldTemplate || defaultTemplate; context: { field: field, index: i }\"></ng-container>\n                                </pep-field-container>\n                                <!-- <div class=\"mapped-field-container\" \n                                    cdkDrag (cdkDragStarted)=\"onDragStart($event)\" (cdkDragEnded)=\"onDragEnd($event)\">\n                                    \n                                    <div class=\"field-wrapper\">\n                                        <ng-container *ngTemplateOutlet=\"fieldTemplate || defaultTemplate; context: { field: field, index: i }\"></ng-container>\n                                    </div>\n                                </div> -->\n                            </ng-container>\n                        </div>\n                    </ng-template>\n                </div>\n            </div>\n        </div>\n    </ng-container>\n</pep-page-layout>\n\n<ng-template #defaultTemplate let-field=\"field\" let-index=\"index\">\n    {{ 'GENERIC_FIELDS_BUILDER.TEMPLATE_NOT_SUPPLIED' | translate: { fieldTitle: field.title || field.key } }}\n</ng-template>\n"]}
|
|
@@ -0,0 +1,82 @@
|
|
|
1
|
+
import { NgModule } from '@angular/core';
|
|
2
|
+
import { CommonModule } from '@angular/common';
|
|
3
|
+
import { DragDropModule } from '@angular/cdk/drag-drop';
|
|
4
|
+
import { MatIconModule } from '@angular/material/icon';
|
|
5
|
+
import { PepNgxLibModule } from '@pepperi-addons/ngx-lib';
|
|
6
|
+
import { PepButtonModule } from '@pepperi-addons/ngx-lib/button';
|
|
7
|
+
import { PepDialogModule } from '@pepperi-addons/ngx-lib/dialog';
|
|
8
|
+
import { PepMenuModule } from '@pepperi-addons/ngx-lib/menu';
|
|
9
|
+
import { PepPageLayoutModule } from '@pepperi-addons/ngx-lib/page-layout';
|
|
10
|
+
import { PepTextboxModule } from '@pepperi-addons/ngx-lib/textbox';
|
|
11
|
+
import { PepTopBarModule } from '@pepperi-addons/ngx-lib/top-bar';
|
|
12
|
+
import { PepDraggableItemsModule } from '@pepperi-addons/ngx-lib/draggable-items';
|
|
13
|
+
import { PepIconModule, pepIconSystemClose, pepIconArrowDownAlt, pepIconSystemBin, pepIconNumberPlus } from '@pepperi-addons/ngx-lib/icon';
|
|
14
|
+
import { GenericFieldsBuilderService } from './generic-fields-builder.service';
|
|
15
|
+
import { GenericFieldsBuilderComponent } from './generic-fields-builder.component';
|
|
16
|
+
import { FieldContainerComponent } from './field-container/field-container.component';
|
|
17
|
+
import * as i0 from "@angular/core";
|
|
18
|
+
import * as i1 from "@pepperi-addons/ngx-lib/icon";
|
|
19
|
+
const pepIcons = [
|
|
20
|
+
pepIconSystemClose,
|
|
21
|
+
pepIconArrowDownAlt,
|
|
22
|
+
pepIconSystemBin,
|
|
23
|
+
pepIconNumberPlus
|
|
24
|
+
];
|
|
25
|
+
export class PepGenericFieldsBuilderModule {
|
|
26
|
+
constructor(pepIconRegistry) {
|
|
27
|
+
this.pepIconRegistry = pepIconRegistry;
|
|
28
|
+
this.pepIconRegistry.registerIcons(pepIcons);
|
|
29
|
+
}
|
|
30
|
+
}
|
|
31
|
+
PepGenericFieldsBuilderModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: PepGenericFieldsBuilderModule, deps: [{ token: i1.PepIconRegistry }], target: i0.ɵɵFactoryTarget.NgModule });
|
|
32
|
+
PepGenericFieldsBuilderModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "15.2.10", ngImport: i0, type: PepGenericFieldsBuilderModule, declarations: [GenericFieldsBuilderComponent,
|
|
33
|
+
FieldContainerComponent], imports: [CommonModule,
|
|
34
|
+
DragDropModule,
|
|
35
|
+
MatIconModule,
|
|
36
|
+
PepNgxLibModule,
|
|
37
|
+
PepButtonModule,
|
|
38
|
+
PepDialogModule,
|
|
39
|
+
PepIconModule,
|
|
40
|
+
PepMenuModule,
|
|
41
|
+
PepPageLayoutModule,
|
|
42
|
+
PepTextboxModule,
|
|
43
|
+
PepTopBarModule,
|
|
44
|
+
PepDraggableItemsModule], exports: [GenericFieldsBuilderComponent] });
|
|
45
|
+
PepGenericFieldsBuilderModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: PepGenericFieldsBuilderModule, providers: [GenericFieldsBuilderService], imports: [CommonModule,
|
|
46
|
+
DragDropModule,
|
|
47
|
+
MatIconModule,
|
|
48
|
+
PepNgxLibModule,
|
|
49
|
+
PepButtonModule,
|
|
50
|
+
PepDialogModule,
|
|
51
|
+
PepIconModule,
|
|
52
|
+
PepMenuModule,
|
|
53
|
+
PepPageLayoutModule,
|
|
54
|
+
PepTextboxModule,
|
|
55
|
+
PepTopBarModule,
|
|
56
|
+
PepDraggableItemsModule] });
|
|
57
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: PepGenericFieldsBuilderModule, decorators: [{
|
|
58
|
+
type: NgModule,
|
|
59
|
+
args: [{
|
|
60
|
+
declarations: [
|
|
61
|
+
GenericFieldsBuilderComponent,
|
|
62
|
+
FieldContainerComponent
|
|
63
|
+
],
|
|
64
|
+
imports: [
|
|
65
|
+
CommonModule,
|
|
66
|
+
DragDropModule,
|
|
67
|
+
MatIconModule,
|
|
68
|
+
PepNgxLibModule,
|
|
69
|
+
PepButtonModule,
|
|
70
|
+
PepDialogModule,
|
|
71
|
+
PepIconModule,
|
|
72
|
+
PepMenuModule,
|
|
73
|
+
PepPageLayoutModule,
|
|
74
|
+
PepTextboxModule,
|
|
75
|
+
PepTopBarModule,
|
|
76
|
+
PepDraggableItemsModule,
|
|
77
|
+
],
|
|
78
|
+
exports: [GenericFieldsBuilderComponent],
|
|
79
|
+
providers: [GenericFieldsBuilderService]
|
|
80
|
+
}]
|
|
81
|
+
}], ctorParameters: function () { return [{ type: i1.PepIconRegistry }]; } });
|
|
82
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ2VuZXJpYy1maWVsZHMtYnVpbGRlci5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtY29tcG9zaXRlLWxpYi9nZW5lcmljLWZpZWxkcy1idWlsZGVyL2dlbmVyaWMtZmllbGRzLWJ1aWxkZXIubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBRS9DLE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQztBQUV4RCxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFFdkQsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLHlCQUF5QixDQUFDO0FBQzFELE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSxnQ0FBZ0MsQ0FBQztBQUNqRSxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sZ0NBQWdDLENBQUM7QUFDakUsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLDhCQUE4QixDQUFDO0FBQzdELE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLHFDQUFxQyxDQUFDO0FBQzFFLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLGlDQUFpQyxDQUFDO0FBQ25FLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSxpQ0FBaUMsQ0FBQztBQUNsRSxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsTUFBTSx5Q0FBeUMsQ0FBQztBQUNsRixPQUFPLEVBQW1CLGFBQWEsRUFBRSxrQkFBa0IsRUFBRSxtQkFBbUIsRUFBRSxnQkFBZ0IsRUFBRSxpQkFBaUIsRUFBRSxNQUFNLDhCQUE4QixDQUFDO0FBRTVKLE9BQU8sRUFBRSwyQkFBMkIsRUFBRSxNQUFNLGtDQUFrQyxDQUFDO0FBRS9FLE9BQU8sRUFBRSw2QkFBNkIsRUFBRSxNQUFNLG9DQUFvQyxDQUFDO0FBQ25GLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxNQUFNLDZDQUE2QyxDQUFDOzs7QUFFdEYsTUFBTSxRQUFRLEdBQUc7SUFDYixrQkFBa0I7SUFDbEIsbUJBQW1CO0lBQ25CLGdCQUFnQjtJQUNoQixpQkFBaUI7Q0FDcEIsQ0FBQztBQXdCRixNQUFNLE9BQU8sNkJBQTZCO0lBQ3RDLFlBQ1ksZUFBZ0M7UUFBaEMsb0JBQWUsR0FBZixlQUFlLENBQWlCO1FBRXhDLElBQUksQ0FBQyxlQUFlLENBQUMsYUFBYSxDQUFDLFFBQVEsQ0FBQyxDQUFDO0lBQ2pELENBQUM7OzJIQUxRLDZCQUE2Qjs0SEFBN0IsNkJBQTZCLGlCQXBCbEMsNkJBQTZCO1FBQzdCLHVCQUF1QixhQUd2QixZQUFZO1FBQ1osY0FBYztRQUNkLGFBQWE7UUFDYixlQUFlO1FBQ2YsZUFBZTtRQUNmLGVBQWU7UUFDZixhQUFhO1FBQ2IsYUFBYTtRQUNiLG1CQUFtQjtRQUNuQixnQkFBZ0I7UUFDaEIsZUFBZTtRQUNmLHVCQUF1QixhQUVqQiw2QkFBNkI7NEhBRzlCLDZCQUE2QixhQUYzQixDQUFDLDJCQUEyQixDQUFDLFlBZHBDLFlBQVk7UUFDWixjQUFjO1FBQ2QsYUFBYTtRQUNiLGVBQWU7UUFDZixlQUFlO1FBQ2YsZUFBZTtRQUNmLGFBQWE7UUFDYixhQUFhO1FBQ2IsbUJBQW1CO1FBQ25CLGdCQUFnQjtRQUNoQixlQUFlO1FBQ2YsdUJBQXVCOzRGQUtsQiw2QkFBNkI7a0JBdEJ6QyxRQUFRO21CQUFDO29CQUNOLFlBQVksRUFBRTt3QkFDViw2QkFBNkI7d0JBQzdCLHVCQUF1QjtxQkFDMUI7b0JBQ0QsT0FBTyxFQUFFO3dCQUNMLFlBQVk7d0JBQ1osY0FBYzt3QkFDZCxhQUFhO3dCQUNiLGVBQWU7d0JBQ2YsZUFBZTt3QkFDZixlQUFlO3dCQUNmLGFBQWE7d0JBQ2IsYUFBYTt3QkFDYixtQkFBbUI7d0JBQ25CLGdCQUFnQjt3QkFDaEIsZUFBZTt3QkFDZix1QkFBdUI7cUJBQzFCO29CQUNELE9BQU8sRUFBRSxDQUFDLDZCQUE2QixDQUFDO29CQUN4QyxTQUFTLEVBQUUsQ0FBQywyQkFBMkIsQ0FBQztpQkFDM0MiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcblxuaW1wb3J0IHsgRHJhZ0Ryb3BNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jZGsvZHJhZy1kcm9wJztcblxuaW1wb3J0IHsgTWF0SWNvbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2ljb24nO1xuXG5pbXBvcnQgeyBQZXBOZ3hMaWJNb2R1bGUgfSBmcm9tICdAcGVwcGVyaS1hZGRvbnMvbmd4LWxpYic7XG5pbXBvcnQgeyBQZXBCdXR0b25Nb2R1bGUgfSBmcm9tICdAcGVwcGVyaS1hZGRvbnMvbmd4LWxpYi9idXR0b24nO1xuaW1wb3J0IHsgUGVwRGlhbG9nTW9kdWxlIH0gZnJvbSAnQHBlcHBlcmktYWRkb25zL25neC1saWIvZGlhbG9nJztcbmltcG9ydCB7IFBlcE1lbnVNb2R1bGUgfSBmcm9tICdAcGVwcGVyaS1hZGRvbnMvbmd4LWxpYi9tZW51JztcbmltcG9ydCB7IFBlcFBhZ2VMYXlvdXRNb2R1bGUgfSBmcm9tICdAcGVwcGVyaS1hZGRvbnMvbmd4LWxpYi9wYWdlLWxheW91dCc7XG5pbXBvcnQgeyBQZXBUZXh0Ym94TW9kdWxlIH0gZnJvbSAnQHBlcHBlcmktYWRkb25zL25neC1saWIvdGV4dGJveCc7XG5pbXBvcnQgeyBQZXBUb3BCYXJNb2R1bGUgfSBmcm9tICdAcGVwcGVyaS1hZGRvbnMvbmd4LWxpYi90b3AtYmFyJztcbmltcG9ydCB7IFBlcERyYWdnYWJsZUl0ZW1zTW9kdWxlIH0gZnJvbSAnQHBlcHBlcmktYWRkb25zL25neC1saWIvZHJhZ2dhYmxlLWl0ZW1zJztcbmltcG9ydCB7IFBlcEljb25SZWdpc3RyeSwgUGVwSWNvbk1vZHVsZSwgcGVwSWNvblN5c3RlbUNsb3NlLCBwZXBJY29uQXJyb3dEb3duQWx0LCBwZXBJY29uU3lzdGVtQmluLCBwZXBJY29uTnVtYmVyUGx1cyB9IGZyb20gJ0BwZXBwZXJpLWFkZG9ucy9uZ3gtbGliL2ljb24nO1xuXG5pbXBvcnQgeyBHZW5lcmljRmllbGRzQnVpbGRlclNlcnZpY2UgfSBmcm9tICcuL2dlbmVyaWMtZmllbGRzLWJ1aWxkZXIuc2VydmljZSc7XG5cbmltcG9ydCB7IEdlbmVyaWNGaWVsZHNCdWlsZGVyQ29tcG9uZW50IH0gZnJvbSAnLi9nZW5lcmljLWZpZWxkcy1idWlsZGVyLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBGaWVsZENvbnRhaW5lckNvbXBvbmVudCB9IGZyb20gJy4vZmllbGQtY29udGFpbmVyL2ZpZWxkLWNvbnRhaW5lci5jb21wb25lbnQnO1xuXG5jb25zdCBwZXBJY29ucyA9IFtcbiAgICBwZXBJY29uU3lzdGVtQ2xvc2UsXG4gICAgcGVwSWNvbkFycm93RG93bkFsdCxcbiAgICBwZXBJY29uU3lzdGVtQmluLFxuICAgIHBlcEljb25OdW1iZXJQbHVzXG5dO1xuXG5ATmdNb2R1bGUoe1xuICAgIGRlY2xhcmF0aW9uczogW1xuICAgICAgICBHZW5lcmljRmllbGRzQnVpbGRlckNvbXBvbmVudCxcbiAgICAgICAgRmllbGRDb250YWluZXJDb21wb25lbnRcbiAgICBdLFxuICAgIGltcG9ydHM6IFtcbiAgICAgICAgQ29tbW9uTW9kdWxlLFxuICAgICAgICBEcmFnRHJvcE1vZHVsZSxcbiAgICAgICAgTWF0SWNvbk1vZHVsZSxcbiAgICAgICAgUGVwTmd4TGliTW9kdWxlLFxuICAgICAgICBQZXBCdXR0b25Nb2R1bGUsXG4gICAgICAgIFBlcERpYWxvZ01vZHVsZSxcbiAgICAgICAgUGVwSWNvbk1vZHVsZSxcbiAgICAgICAgUGVwTWVudU1vZHVsZSxcbiAgICAgICAgUGVwUGFnZUxheW91dE1vZHVsZSxcbiAgICAgICAgUGVwVGV4dGJveE1vZHVsZSxcbiAgICAgICAgUGVwVG9wQmFyTW9kdWxlLFxuICAgICAgICBQZXBEcmFnZ2FibGVJdGVtc01vZHVsZSxcbiAgICBdLFxuICAgIGV4cG9ydHM6IFtHZW5lcmljRmllbGRzQnVpbGRlckNvbXBvbmVudF0sXG4gICAgcHJvdmlkZXJzOiBbR2VuZXJpY0ZpZWxkc0J1aWxkZXJTZXJ2aWNlXVxufSlcbmV4cG9ydCBjbGFzcyBQZXBHZW5lcmljRmllbGRzQnVpbGRlck1vZHVsZSB7XG4gICAgY29uc3RydWN0b3IoXG4gICAgICAgIHByaXZhdGUgcGVwSWNvblJlZ2lzdHJ5OiBQZXBJY29uUmVnaXN0cnksXG4gICAgKSB7XG4gICAgICAgIHRoaXMucGVwSWNvblJlZ2lzdHJ5LnJlZ2lzdGVySWNvbnMocGVwSWNvbnMpO1xuICAgIH1cbn1cbiJdfQ==
|
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
import { Injectable } from '@angular/core';
|
|
2
|
+
import { BehaviorSubject } from 'rxjs';
|
|
3
|
+
import { distinctUntilChanged } from 'rxjs/operators';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
export class GenericFieldsBuilderService {
|
|
6
|
+
get isGrabbingChange$() {
|
|
7
|
+
return this._isGrabbingSubject.asObservable().pipe(distinctUntilChanged());
|
|
8
|
+
}
|
|
9
|
+
constructor() {
|
|
10
|
+
// This subject is for is grabbing mode.
|
|
11
|
+
this._isGrabbingSubject = new BehaviorSubject(false);
|
|
12
|
+
//
|
|
13
|
+
}
|
|
14
|
+
changeCursorOnDragStart() {
|
|
15
|
+
document.body.classList.add('inheritCursors');
|
|
16
|
+
document.body.style.cursor = 'grabbing';
|
|
17
|
+
this._isGrabbingSubject.next(true);
|
|
18
|
+
}
|
|
19
|
+
changeCursorOnDragEnd() {
|
|
20
|
+
document.body.classList.remove('inheritCursors');
|
|
21
|
+
document.body.style.cursor = 'unset';
|
|
22
|
+
this._isGrabbingSubject.next(false);
|
|
23
|
+
}
|
|
24
|
+
onDragStart(event) {
|
|
25
|
+
this.changeCursorOnDragStart();
|
|
26
|
+
}
|
|
27
|
+
onDragEnd(event) {
|
|
28
|
+
this.changeCursorOnDragEnd();
|
|
29
|
+
}
|
|
30
|
+
}
|
|
31
|
+
GenericFieldsBuilderService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: GenericFieldsBuilderService, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
|
|
32
|
+
GenericFieldsBuilderService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: GenericFieldsBuilderService, providedIn: 'root' });
|
|
33
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: GenericFieldsBuilderService, decorators: [{
|
|
34
|
+
type: Injectable,
|
|
35
|
+
args: [{
|
|
36
|
+
providedIn: 'root'
|
|
37
|
+
}]
|
|
38
|
+
}], ctorParameters: function () { return []; } });
|
|
39
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ2VuZXJpYy1maWVsZHMtYnVpbGRlci5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vcHJvamVjdHMvbmd4LWNvbXBvc2l0ZS1saWIvZ2VuZXJpYy1maWVsZHMtYnVpbGRlci9nZW5lcmljLWZpZWxkcy1idWlsZGVyLnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQ0EsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUMzQyxPQUFPLEVBQUUsZUFBZSxFQUFjLE1BQU0sTUFBTSxDQUFDO0FBQ25ELE9BQU8sRUFBRSxvQkFBb0IsRUFBVSxNQUFNLGdCQUFnQixDQUFDOztBQUs5RCxNQUFNLE9BQU8sMkJBQTJCO0lBSXBDLElBQUksaUJBQWlCO1FBQ2pCLE9BQU8sSUFBSSxDQUFDLGtCQUFrQixDQUFDLFlBQVksRUFBRSxDQUFDLElBQUksQ0FBQyxvQkFBb0IsRUFBRSxDQUFDLENBQUM7SUFDL0UsQ0FBQztJQUVEO1FBTkEsd0NBQXdDO1FBQ2hDLHVCQUFrQixHQUE2QixJQUFJLGVBQWUsQ0FBVSxLQUFLLENBQUMsQ0FBQztRQU12RixFQUFFO0lBQ04sQ0FBQztJQUVPLHVCQUF1QjtRQUMzQixRQUFRLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxHQUFHLENBQUMsZ0JBQWdCLENBQUMsQ0FBQztRQUM5QyxRQUFRLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxNQUFNLEdBQUcsVUFBVSxDQUFDO1FBQ3hDLElBQUksQ0FBQyxrQkFBa0IsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUM7SUFDdkMsQ0FBQztJQUVPLHFCQUFxQjtRQUN6QixRQUFRLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxNQUFNLENBQUMsZ0JBQWdCLENBQUMsQ0FBQztRQUNqRCxRQUFRLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxNQUFNLEdBQUcsT0FBTyxDQUFDO1FBQ3JDLElBQUksQ0FBQyxrQkFBa0IsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDeEMsQ0FBQztJQUVELFdBQVcsQ0FBQyxLQUFtQjtRQUMzQixJQUFJLENBQUMsdUJBQXVCLEVBQUUsQ0FBQztJQUNuQyxDQUFDO0lBRUQsU0FBUyxDQUFDLEtBQWlCO1FBQ3ZCLElBQUksQ0FBQyxxQkFBcUIsRUFBRSxDQUFDO0lBQ2pDLENBQUM7O3lIQTlCUSwyQkFBMkI7NkhBQTNCLDJCQUEyQixjQUZ4QixNQUFNOzRGQUVULDJCQUEyQjtrQkFIdkMsVUFBVTttQkFBQztvQkFDUixVQUFVLEVBQUUsTUFBTTtpQkFDckIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDZGtEcmFnRW5kLCBDZGtEcmFnU3RhcnQgfSBmcm9tICdAYW5ndWxhci9jZGsvZHJhZy1kcm9wJztcbmltcG9ydCB7IEluamVjdGFibGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEJlaGF2aW9yU3ViamVjdCwgT2JzZXJ2YWJsZSB9IGZyb20gJ3J4anMnO1xuaW1wb3J0IHsgZGlzdGluY3RVbnRpbENoYW5nZWQsIGZpbHRlciB9IGZyb20gJ3J4anMvb3BlcmF0b3JzJztcblxuQEluamVjdGFibGUoe1xuICAgIHByb3ZpZGVkSW46ICdyb290J1xufSlcbmV4cG9ydCBjbGFzcyBHZW5lcmljRmllbGRzQnVpbGRlclNlcnZpY2Uge1xuICAgIFxuICAgIC8vIFRoaXMgc3ViamVjdCBpcyBmb3IgaXMgZ3JhYmJpbmcgbW9kZS5cbiAgICBwcml2YXRlIF9pc0dyYWJiaW5nU3ViamVjdDogQmVoYXZpb3JTdWJqZWN0PGJvb2xlYW4+ID0gbmV3IEJlaGF2aW9yU3ViamVjdDxib29sZWFuPihmYWxzZSk7XG4gICAgZ2V0IGlzR3JhYmJpbmdDaGFuZ2UkKCk6IE9ic2VydmFibGU8Ym9vbGVhbj4ge1xuICAgICAgICByZXR1cm4gdGhpcy5faXNHcmFiYmluZ1N1YmplY3QuYXNPYnNlcnZhYmxlKCkucGlwZShkaXN0aW5jdFVudGlsQ2hhbmdlZCgpKTtcbiAgICB9XG5cbiAgICBjb25zdHJ1Y3RvcigpIHsgXG4gICAgICAgIC8vXG4gICAgfVxuXG4gICAgcHJpdmF0ZSBjaGFuZ2VDdXJzb3JPbkRyYWdTdGFydCgpIHtcbiAgICAgICAgZG9jdW1lbnQuYm9keS5jbGFzc0xpc3QuYWRkKCdpbmhlcml0Q3Vyc29ycycpO1xuICAgICAgICBkb2N1bWVudC5ib2R5LnN0eWxlLmN1cnNvciA9ICdncmFiYmluZyc7XG4gICAgICAgIHRoaXMuX2lzR3JhYmJpbmdTdWJqZWN0Lm5leHQodHJ1ZSk7XG4gICAgfVxuXG4gICAgcHJpdmF0ZSBjaGFuZ2VDdXJzb3JPbkRyYWdFbmQoKSB7XG4gICAgICAgIGRvY3VtZW50LmJvZHkuY2xhc3NMaXN0LnJlbW92ZSgnaW5oZXJpdEN1cnNvcnMnKTtcbiAgICAgICAgZG9jdW1lbnQuYm9keS5zdHlsZS5jdXJzb3IgPSAndW5zZXQnO1xuICAgICAgICB0aGlzLl9pc0dyYWJiaW5nU3ViamVjdC5uZXh0KGZhbHNlKTtcbiAgICB9XG4gICAgXG4gICAgb25EcmFnU3RhcnQoZXZlbnQ6IENka0RyYWdTdGFydCkge1xuICAgICAgICB0aGlzLmNoYW5nZUN1cnNvck9uRHJhZ1N0YXJ0KCk7XG4gICAgfVxuXG4gICAgb25EcmFnRW5kKGV2ZW50OiBDZGtEcmFnRW5kKSB7XG4gICAgICAgIHRoaXMuY2hhbmdlQ3Vyc29yT25EcmFnRW5kKCk7XG4gICAgfVxufVxuIl19
|
package/esm2020/generic-fields-builder/pepperi-addons-ngx-composite-lib-generic-fields-builder.mjs
ADDED
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Generated bundle index. Do not edit.
|
|
3
|
+
*/
|
|
4
|
+
export * from './public-api';
|
|
5
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGVwcGVyaS1hZGRvbnMtbmd4LWNvbXBvc2l0ZS1saWItZ2VuZXJpYy1maWVsZHMtYnVpbGRlci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL25neC1jb21wb3NpdGUtbGliL2dlbmVyaWMtZmllbGRzLWJ1aWxkZXIvcGVwcGVyaS1hZGRvbnMtbmd4LWNvbXBvc2l0ZS1saWItZ2VuZXJpYy1maWVsZHMtYnVpbGRlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUVILGNBQWMsY0FBYyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBHZW5lcmF0ZWQgYnVuZGxlIGluZGV4LiBEbyBub3QgZWRpdC5cbiAqL1xuXG5leHBvcnQgKiBmcm9tICcuL3B1YmxpYy1hcGknO1xuIl19
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
/*
|
|
2
|
+
* Public API Surface of ngx-composite-lib/generic-fields-builder
|
|
3
|
+
*/
|
|
4
|
+
export * from './generic-fields-builder.module';
|
|
5
|
+
export * from './generic-fields-builder.component';
|
|
6
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL25neC1jb21wb3NpdGUtbGliL2dlbmVyaWMtZmllbGRzLWJ1aWxkZXIvcHVibGljLWFwaS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUNILGNBQWMsaUNBQWlDLENBQUM7QUFDaEQsY0FBYyxvQ0FBb0MsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qXG4gKiBQdWJsaWMgQVBJIFN1cmZhY2Ugb2Ygbmd4LWNvbXBvc2l0ZS1saWIvZ2VuZXJpYy1maWVsZHMtYnVpbGRlclxuICovXG5leHBvcnQgKiBmcm9tICcuL2dlbmVyaWMtZmllbGRzLWJ1aWxkZXIubW9kdWxlJztcbmV4cG9ydCAqIGZyb20gJy4vZ2VuZXJpYy1maWVsZHMtYnVpbGRlci5jb21wb25lbnQnOyJdfQ==
|
|
@@ -9,6 +9,15 @@ import * as i3 from "@angular/common";
|
|
|
9
9
|
import * as i4 from "@pepperi-addons/ngx-lib/page-layout";
|
|
10
10
|
import * as i5 from "@pepperi-addons/ngx-lib/top-bar";
|
|
11
11
|
export class GenericFormComponent {
|
|
12
|
+
set pepListContainer(val) {
|
|
13
|
+
this._pepFormContainer = val;
|
|
14
|
+
}
|
|
15
|
+
set dataSource(val) {
|
|
16
|
+
this._data = val;
|
|
17
|
+
}
|
|
18
|
+
set dataView(val) {
|
|
19
|
+
this.initForm(val);
|
|
20
|
+
}
|
|
12
21
|
constructor(layoutService, _genericFormService) {
|
|
13
22
|
this.layoutService = layoutService;
|
|
14
23
|
this._genericFormService = _genericFormService;
|
|
@@ -25,15 +34,6 @@ export class GenericFormComponent {
|
|
|
25
34
|
this._formData = new ObjectsDataRow();
|
|
26
35
|
this._uiControl = new UIControl();
|
|
27
36
|
}
|
|
28
|
-
set pepListContainer(val) {
|
|
29
|
-
this._pepFormContainer = val;
|
|
30
|
-
}
|
|
31
|
-
set dataSource(val) {
|
|
32
|
-
this._data = val;
|
|
33
|
-
}
|
|
34
|
-
set dataView(val) {
|
|
35
|
-
this.initForm(val);
|
|
36
|
-
}
|
|
37
37
|
ngOnInit() {
|
|
38
38
|
//
|
|
39
39
|
}
|
|
@@ -164,9 +164,9 @@ export class GenericFormComponent {
|
|
|
164
164
|
this.formValidationChange.emit(event);
|
|
165
165
|
}
|
|
166
166
|
}
|
|
167
|
-
GenericFormComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "
|
|
168
|
-
GenericFormComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "
|
|
169
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
167
|
+
GenericFormComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: GenericFormComponent, deps: [{ token: i1.PepLayoutService }, { token: i2.PepGenericFormService }], target: i0.ɵɵFactoryTarget.Component });
|
|
168
|
+
GenericFormComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: GenericFormComponent, selector: "pep-generic-form", inputs: { dataSource: "dataSource", dataView: "dataView", isLocked: "isLocked", inline: "inline", showTopBar: "showTopBar", addPadding: "addPadding" }, outputs: { valueChange: "valueChange", fieldClick: "fieldClick", formValidationChange: "formValidationChange" }, providers: [PepGenericFormService], viewQueries: [{ propertyName: "pepListContainer", first: true, predicate: ["pepFormContainer"], descendants: true, read: ViewContainerRef }], ngImport: i0, template: "<div *ngIf=\"inline\" class=\"inline-container\" [ngClass]=\"{ 'add-padding': addPadding }\">\n <div *ngIf=\"showTopBar\" class=\"inline-top-bar-container\">\n <ng-container *ngTemplateOutlet=\"topBarTemplate\"></ng-container>\n </div>\n <ng-container *ngTemplateOutlet=\"formTemplate\"></ng-container>\n</div>\n\n<pep-page-layout *ngIf=\"!inline\" [addPadding]=\"addPadding\">\n <ng-container *ngIf=\"showTopBar\" pep-top-area>\n <ng-container *ngTemplateOutlet=\"topBarTemplate\"></ng-container>\n </ng-container>\n <div pep-main-area class=\"main-area-container\">\n <ng-container *ngTemplateOutlet=\"formTemplate\"></ng-container>\n </div>\n</pep-page-layout>\n\n<ng-template #topBarTemplate>\n <pep-top-bar [inline]=\"inline\"> \n <div header-start-content>\n <ng-content select=\"[left-buttons]\"></ng-content>\n </div>\n <div header-end-content>\n <ng-content select=\"[right-buttons]\"></ng-content>\n </div>\n\n <!-- <div footer-start-content>\n <ng-content select=\"[bottom-left-buttons]\"></ng-content>\n </div>\n <div footer-end-content>\n <ng-content select=\"[bottom-right-buttons]\"></ng-content>\n </div> -->\n </pep-top-bar>\n</ng-template>\n\n<ng-template #formTemplate>\n <!-- class=\"form-view\" -->\n <div [ngClass]=\"{'form-view': showTopBar, 'padding-bottom': !showTopBar}\">\n <ng-container #pepFormContainer></ng-container>\n </div>\n</ng-template>\n", styles: [":host{height:inherit;display:block}.main-area-container{display:grid;height:inherit}.inline-container{height:inherit;display:grid;grid-template-rows:auto 1fr}.inline-container.add-padding{padding-inline:var(--pep-spacing-lg, 1rem)}.padding-bottom{padding-bottom:var(--pep-spacing-lg, 1rem)}\n"], dependencies: [{ kind: "directive", type: i3.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i4.PepPageLayoutComponent, selector: "pep-page-layout", inputs: ["addPadding", "showShadow"] }, { kind: "component", type: i5.PepTopBarComponent, selector: "pep-top-bar", inputs: ["inline", "title"], outputs: ["footerStateChange"] }] });
|
|
169
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: GenericFormComponent, decorators: [{
|
|
170
170
|
type: Component,
|
|
171
171
|
args: [{ selector: 'pep-generic-form', providers: [PepGenericFormService], template: "<div *ngIf=\"inline\" class=\"inline-container\" [ngClass]=\"{ 'add-padding': addPadding }\">\n <div *ngIf=\"showTopBar\" class=\"inline-top-bar-container\">\n <ng-container *ngTemplateOutlet=\"topBarTemplate\"></ng-container>\n </div>\n <ng-container *ngTemplateOutlet=\"formTemplate\"></ng-container>\n</div>\n\n<pep-page-layout *ngIf=\"!inline\" [addPadding]=\"addPadding\">\n <ng-container *ngIf=\"showTopBar\" pep-top-area>\n <ng-container *ngTemplateOutlet=\"topBarTemplate\"></ng-container>\n </ng-container>\n <div pep-main-area class=\"main-area-container\">\n <ng-container *ngTemplateOutlet=\"formTemplate\"></ng-container>\n </div>\n</pep-page-layout>\n\n<ng-template #topBarTemplate>\n <pep-top-bar [inline]=\"inline\"> \n <div header-start-content>\n <ng-content select=\"[left-buttons]\"></ng-content>\n </div>\n <div header-end-content>\n <ng-content select=\"[right-buttons]\"></ng-content>\n </div>\n\n <!-- <div footer-start-content>\n <ng-content select=\"[bottom-left-buttons]\"></ng-content>\n </div>\n <div footer-end-content>\n <ng-content select=\"[bottom-right-buttons]\"></ng-content>\n </div> -->\n </pep-top-bar>\n</ng-template>\n\n<ng-template #formTemplate>\n <!-- class=\"form-view\" -->\n <div [ngClass]=\"{'form-view': showTopBar, 'padding-bottom': !showTopBar}\">\n <ng-container #pepFormContainer></ng-container>\n </div>\n</ng-template>\n", styles: [":host{height:inherit;display:block}.main-area-container{display:grid;height:inherit}.inline-container{height:inherit;display:grid;grid-template-rows:auto 1fr}.inline-container.add-padding{padding-inline:var(--pep-spacing-lg, 1rem)}.padding-bottom{padding-bottom:var(--pep-spacing-lg, 1rem)}\n"] }]
|
|
172
172
|
}], ctorParameters: function () { return [{ type: i1.PepLayoutService }, { type: i2.PepGenericFormService }]; }, propDecorators: { pepListContainer: [{
|
|
@@ -191,4 +191,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.2", ngImpor
|
|
|
191
191
|
}], formValidationChange: [{
|
|
192
192
|
type: Output
|
|
193
193
|
}] } });
|
|
194
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"generic-form.component.js","sourceRoot":"","sources":["../../../../projects/ngx-composite-lib/generic-form/generic-form.component.ts","../../../../projects/ngx-composite-lib/generic-form/generic-form.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    Component,\n    OnInit,\n    Input,\n    Output,\n    ViewChild,\n    ViewContainerRef,\n    EventEmitter,   \n    Type,\n} from '@angular/core';\n//import { PepFormComponent } from '@pepperi-addons/ngx-lib/form';\nimport {\n    IPepGenericFormDataView,\n    IPepGenericFormValueChange,\n    IPepGenericFormFieldUpdate,\n    IPepGenericFormData\n} from './generic-form.model';\nimport {\n    UIControl,\n    ObjectsDataRow,\n    ObjectsDataRowCell,\n    PepGuid,\n    PepLayoutService\n} from '@pepperi-addons/ngx-lib';\nimport { DataViewConverter } from '@pepperi-addons/data-views';\nimport { PepGenericFormService } from './generic-form.service';\n\n\n@Component({\n    selector: 'pep-generic-form',\n    templateUrl: './generic-form.component.html',\n    styleUrls: ['./generic-form.component.scss'],\n    providers: [PepGenericFormService]\n})\nexport class GenericFormComponent implements OnInit {\n    private _pepFormContainer: ViewContainerRef | undefined;\n    @ViewChild('pepFormContainer', { read: ViewContainerRef })\n    set pepListContainer(val: ViewContainerRef) {\n        this._pepFormContainer = val;\n    }\n\n    private _data: any;\n    @Input()\n    set dataSource(val: any) {\n        this._data = val;\n    }\n\n    private _formData: ObjectsDataRow;\n    private _uiControl: UIControl;\n    @Input()\n    set dataView(val: IPepGenericFormDataView) {\n        this.initForm(val);\n    }\n\n    @Input()\n    isLocked = false;\n\n    @Input()\n    inline = false;\n\n    @Input()\n    showTopBar = false;\n\n    @Input()\n    addPadding = false;\n\n    @Output()\n    valueChange: EventEmitter<IPepGenericFormValueChange> = new EventEmitter<IPepGenericFormValueChange>();\n\n    @Output()\n    fieldClick: EventEmitter<IPepGenericFormValueChange> = new EventEmitter<IPepGenericFormValueChange>();\n\n    @Output()\n    formValidationChange: EventEmitter<boolean> = new EventEmitter<boolean>();\n\n    private _pepForm: any;\n\n    constructor(        \n        private layoutService: PepLayoutService,\n        public _genericFormService: PepGenericFormService\n    ) {\n        this.layoutService.onResize$.pipe().subscribe((size) => {\n            //            \n        });\n        this._formData = new ObjectsDataRow();\n        this._uiControl = new UIControl();\n    }\n\n    ngOnInit() {\n        //        \n    }\n\n    private initForm(dataView: IPepGenericFormDataView) {\n        setTimeout(async () => {\n            if (this._pepFormContainer) {\n                if (this._pepFormContainer.length) {\n                    this._pepFormContainer.remove();\n                    this._formData = new ObjectsDataRow();\n                    this._uiControl = new UIControl();\n                }               \n                const { PepFormComponent } = await import('@pepperi-addons/ngx-lib/form');                  \n                const componentRef = this._pepFormContainer.createComponent(PepFormComponent);    \n\n                this._pepForm = componentRef.instance;\n\n                this._formData.IsEditable = !this.isLocked;\n                this._formData.UID = dataView.UID || PepGuid.newGuid();\n                const uiControlData = DataViewConverter.toUIControlData(dataView);\n                if (uiControlData) {\n                    if (uiControlData?.ControlFields) {\n                        this._uiControl.ControlFields = uiControlData.ControlFields.map((field: any) => this._genericFormService.convertToUiControlField(field));\n                    }\n                    this._uiControl.Columns = uiControlData.Columns;\n\n                    if (this._uiControl.ControlFields?.length) {\n                        this._formData.Fields = [];\n                        this._uiControl.ControlFields.forEach((item) => {\n                            let value = '';\n                            if (this._genericFormService.hasProperty(this._data, item.ApiName)) {\n                                value = this._data[item.ApiName];\n                            }\n                            let dataViewField: any;\n                            if (dataView.Fields) {\n                                dataViewField = dataView.Fields.find(field => field.FieldID === item.ApiName);\n                            }\n                            const controlFieldData = {\n                                ...item,\n                                ...{\n                                    controlFieldValue: value\n                                },\n                                ...{\n                                    OptionalValues: dataViewField?.OptionalValues?.length ? dataViewField.OptionalValues : [],\n                                    AdditionalProps: dataViewField?.AdditionalProps || null\n                                }\n                            }\n                            this._formData.Fields.push(this._genericFormService.createFormField(controlFieldData));\n                        });\n\n                        componentRef.instance.layoutType = 'form';\n                        componentRef.instance.layout = this._uiControl;\n                        componentRef.instance.data = this._formData;\n                        componentRef.instance.isInternal = false;\n                        componentRef.instance.lockFields = this.isLocked;\n                        componentRef.instance.valueChange.subscribe(($event) => {\n                            this.onValueChanged($event);\n                        });\n                        componentRef.instance.fieldClick.subscribe(($event) => {\n                            this.onfieldClicked($event);\n                        });\n                        componentRef.instance.formValidationChange.subscribe(($event) => {\n                            this.onFormValidationChanged($event);\n                        });\n                    }\n                }\n\n            }\n\n        }, 0);\n    }\n\n    /**\n     * updates form field's value\n     * @param field object containing the data of the required update\n     */\n    private updateFieldValue(fieldChanged: IPepGenericFormValueChange) {\n        this._data[fieldChanged.ApiName] = fieldChanged.Value;\n    }\n\n    getData(): IPepGenericFormData {\n        return {\n            UID: this._formData.UID,\n            Values: this._data\n        };\n    }\n\n    /**\n    * updates form field(s) params\n    * @param fields\n    */\n    updateFields(fields: IPepGenericFormFieldUpdate[]) {\n        // update data view with current data\n        for (const [key, value] of Object.entries(this._data)) {\n            const index = this._formData.Fields.findIndex((item) => item.ApiName === key);\n            if (index >= 0) {\n                const item = this._formData.Fields[index] as { [k: string]: any };\n                item.Value = value;\n            }\n        }\n\n        fields.forEach((field) => {\n            const index = this._formData.Fields.findIndex((item) => item.ApiName === field.FieldId);\n            if (index >= 0) {\n                for (const [key, value] of Object.entries(field.Params)) {\n                    if (this._genericFormService.hasProperty(this._formData.Fields[index], key)) {\n                        const item = this._formData.Fields[index] as { [k: string]: any };\n                        item[key] = value;\n                        if (key === 'Value') {\n                            //manually updating formattedValue because FormattedValue is legacy used by webapp\n                            item.FormattedValue = value;\n                        }\n                    }\n                }\n            }\n        });\n        this._pepForm.ReloadForm()\n        this._pepForm.data = this._formData;\n    }\n\n    onValueChanged(event: any) {\n        const field: IPepGenericFormValueChange = {\n            UID: event.id,\n            ApiName: event.key,\n            Value: event.value\n        };\n        this.updateFieldValue(field);\n        this.valueChange.emit(field);\n    }\n\n    onfieldClicked(event: any) {\n        const field: IPepGenericFormValueChange = {\n            UID: event.id,\n            ApiName: event.key,\n            Value: event.value\n        };\n        this.updateFieldValue(field);\n        this.fieldClick.emit(field);\n    }\n\n    onFormValidationChanged(event: any) {\n        this.formValidationChange.emit(event);\n    }\n\n\n}\n","<div *ngIf=\"inline\" class=\"inline-container\" [ngClass]=\"{ 'add-padding': addPadding }\">\n    <div *ngIf=\"showTopBar\" class=\"inline-top-bar-container\">\n        <ng-container *ngTemplateOutlet=\"topBarTemplate\"></ng-container>\n    </div>\n    <ng-container *ngTemplateOutlet=\"formTemplate\"></ng-container>\n</div>\n\n<pep-page-layout *ngIf=\"!inline\" [addPadding]=\"addPadding\">\n    <ng-container *ngIf=\"showTopBar\" pep-top-area>\n        <ng-container *ngTemplateOutlet=\"topBarTemplate\"></ng-container>\n    </ng-container>\n    <div pep-main-area class=\"main-area-container\">\n        <ng-container *ngTemplateOutlet=\"formTemplate\"></ng-container>\n    </div>\n</pep-page-layout>\n\n<ng-template #topBarTemplate>\n    <pep-top-bar [inline]=\"inline\"> \n        <div header-start-content>\n            <ng-content select=\"[left-buttons]\"></ng-content>\n        </div>\n        <div header-end-content>\n            <ng-content select=\"[right-buttons]\"></ng-content>\n        </div>\n\n        <!-- <div footer-start-content>\n            <ng-content select=\"[bottom-left-buttons]\"></ng-content>\n        </div>\n        <div footer-end-content>\n            <ng-content select=\"[bottom-right-buttons]\"></ng-content>\n        </div> -->\n    </pep-top-bar>\n</ng-template>\n\n<ng-template #formTemplate>\n    <!-- class=\"form-view\"  -->\n    <div [ngClass]=\"{'form-view': showTopBar, 'padding-bottom': !showTopBar}\">\n        <ng-container #pepFormContainer></ng-container>\n    </div>\n</ng-template>\n"]}
|
|
194
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"generic-form.component.js","sourceRoot":"","sources":["../../../../projects/ngx-composite-lib/generic-form/generic-form.component.ts","../../../../projects/ngx-composite-lib/generic-form/generic-form.component.html"],"names":[],"mappings":"AAAA,OAAO,EACH,SAAS,EAET,KAAK,EACL,MAAM,EACN,SAAS,EACT,gBAAgB,EAChB,YAAY,GAEf,MAAM,eAAe,CAAC;AAQvB,OAAO,EACH,SAAS,EACT,cAAc,EAEd,OAAO,EAEV,MAAM,yBAAyB,CAAC;AACjC,OAAO,EAAE,iBAAiB,EAAE,MAAM,4BAA4B,CAAC;AAC/D,OAAO,EAAE,qBAAqB,EAAE,MAAM,wBAAwB,CAAC;;;;;;;AAS/D,MAAM,OAAO,oBAAoB;IAE7B,IACI,gBAAgB,CAAC,GAAqB;QACtC,IAAI,CAAC,iBAAiB,GAAG,GAAG,CAAC;IACjC,CAAC;IAGD,IACI,UAAU,CAAC,GAAQ;QACnB,IAAI,CAAC,KAAK,GAAG,GAAG,CAAC;IACrB,CAAC;IAID,IACI,QAAQ,CAAC,GAA4B;QACrC,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC;IACvB,CAAC;IAyBD,YACY,aAA+B,EAChC,mBAA0C;QADzC,kBAAa,GAAb,aAAa,CAAkB;QAChC,wBAAmB,GAAnB,mBAAmB,CAAuB;QAxBrD,aAAQ,GAAG,KAAK,CAAC;QAGjB,WAAM,GAAG,KAAK,CAAC;QAGf,eAAU,GAAG,KAAK,CAAC;QAGnB,eAAU,GAAG,KAAK,CAAC;QAGnB,gBAAW,GAA6C,IAAI,YAAY,EAA8B,CAAC;QAGvG,eAAU,GAA6C,IAAI,YAAY,EAA8B,CAAC;QAGtG,yBAAoB,GAA0B,IAAI,YAAY,EAAW,CAAC;QAQtE,IAAI,CAAC,aAAa,CAAC,SAAS,CAAC,IAAI,EAAE,CAAC,SAAS,CAAC,CAAC,IAAI,EAAE,EAAE;YACnD,cAAc;QAClB,CAAC,CAAC,CAAC;QACH,IAAI,CAAC,SAAS,GAAG,IAAI,cAAc,EAAE,CAAC;QACtC,IAAI,CAAC,UAAU,GAAG,IAAI,SAAS,EAAE,CAAC;IACtC,CAAC;IAED,QAAQ;QACJ,UAAU;IACd,CAAC;IAEO,QAAQ,CAAC,QAAiC;QAC9C,UAAU,CAAC,KAAK,IAAI,EAAE;YAClB,IAAI,IAAI,CAAC,iBAAiB,EAAE;gBACxB,IAAI,IAAI,CAAC,iBAAiB,CAAC,MAAM,EAAE;oBAC/B,IAAI,CAAC,iBAAiB,CAAC,MAAM,EAAE,CAAC;oBAChC,IAAI,CAAC,SAAS,GAAG,IAAI,cAAc,EAAE,CAAC;oBACtC,IAAI,CAAC,UAAU,GAAG,IAAI,SAAS,EAAE,CAAC;iBACrC;gBACD,MAAM,EAAE,gBAAgB,EAAE,GAAG,MAAM,MAAM,CAAC,8BAA8B,CAAC,CAAC;gBAC1E,MAAM,YAAY,GAAG,IAAI,CAAC,iBAAiB,CAAC,eAAe,CAAC,gBAAgB,CAAC,CAAC;gBAE9E,IAAI,CAAC,QAAQ,GAAG,YAAY,CAAC,QAAQ,CAAC;gBAEtC,IAAI,CAAC,SAAS,CAAC,UAAU,GAAG,CAAC,IAAI,CAAC,QAAQ,CAAC;gBAC3C,IAAI,CAAC,SAAS,CAAC,GAAG,GAAG,QAAQ,CAAC,GAAG,IAAI,OAAO,CAAC,OAAO,EAAE,CAAC;gBACvD,MAAM,aAAa,GAAG,iBAAiB,CAAC,eAAe,CAAC,QAAQ,CAAC,CAAC;gBAClE,IAAI,aAAa,EAAE;oBACf,IAAI,aAAa,EAAE,aAAa,EAAE;wBAC9B,IAAI,CAAC,UAAU,CAAC,aAAa,GAAG,aAAa,CAAC,aAAa,CAAC,GAAG,CAAC,CAAC,KAAU,EAAE,EAAE,CAAC,IAAI,CAAC,mBAAmB,CAAC,uBAAuB,CAAC,KAAK,CAAC,CAAC,CAAC;qBAC5I;oBACD,IAAI,CAAC,UAAU,CAAC,OAAO,GAAG,aAAa,CAAC,OAAO,CAAC;oBAEhD,IAAI,IAAI,CAAC,UAAU,CAAC,aAAa,EAAE,MAAM,EAAE;wBACvC,IAAI,CAAC,SAAS,CAAC,MAAM,GAAG,EAAE,CAAC;wBAC3B,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,OAAO,CAAC,CAAC,IAAI,EAAE,EAAE;4BAC3C,IAAI,KAAK,GAAG,EAAE,CAAC;4BACf,IAAI,IAAI,CAAC,mBAAmB,CAAC,WAAW,CAAC,IAAI,CAAC,KAAK,EAAE,IAAI,CAAC,OAAO,CAAC,EAAE;gCAChE,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;6BACpC;4BACD,IAAI,aAAkB,CAAC;4BACvB,IAAI,QAAQ,CAAC,MAAM,EAAE;gCACjB,aAAa,GAAG,QAAQ,CAAC,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC,KAAK,CAAC,OAAO,KAAK,IAAI,CAAC,OAAO,CAAC,CAAC;6BACjF;4BACD,MAAM,gBAAgB,GAAG;gCACrB,GAAG,IAAI;gCACP,GAAG;oCACC,iBAAiB,EAAE,KAAK;iCAC3B;gCACD,GAAG;oCACC,cAAc,EAAE,aAAa,EAAE,cAAc,EAAE,MAAM,CAAC,CAAC,CAAC,aAAa,CAAC,cAAc,CAAC,CAAC,CAAC,EAAE;oCACzF,eAAe,EAAE,aAAa,EAAE,eAAe,IAAI,IAAI;iCAC1D;6BACJ,CAAA;4BACD,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,mBAAmB,CAAC,eAAe,CAAC,gBAAgB,CAAC,CAAC,CAAC;wBAC3F,CAAC,CAAC,CAAC;wBAEH,YAAY,CAAC,QAAQ,CAAC,UAAU,GAAG,MAAM,CAAC;wBAC1C,YAAY,CAAC,QAAQ,CAAC,MAAM,GAAG,IAAI,CAAC,UAAU,CAAC;wBAC/C,YAAY,CAAC,QAAQ,CAAC,IAAI,GAAG,IAAI,CAAC,SAAS,CAAC;wBAC5C,YAAY,CAAC,QAAQ,CAAC,UAAU,GAAG,KAAK,CAAC;wBACzC,YAAY,CAAC,QAAQ,CAAC,UAAU,GAAG,IAAI,CAAC,QAAQ,CAAC;wBACjD,YAAY,CAAC,QAAQ,CAAC,WAAW,CAAC,SAAS,CAAC,CAAC,MAAM,EAAE,EAAE;4BACnD,IAAI,CAAC,cAAc,CAAC,MAAM,CAAC,CAAC;wBAChC,CAAC,CAAC,CAAC;wBACH,YAAY,CAAC,QAAQ,CAAC,UAAU,CAAC,SAAS,CAAC,CAAC,MAAM,EAAE,EAAE;4BAClD,IAAI,CAAC,cAAc,CAAC,MAAM,CAAC,CAAC;wBAChC,CAAC,CAAC,CAAC;wBACH,YAAY,CAAC,QAAQ,CAAC,oBAAoB,CAAC,SAAS,CAAC,CAAC,MAAM,EAAE,EAAE;4BAC5D,IAAI,CAAC,uBAAuB,CAAC,MAAM,CAAC,CAAC;wBACzC,CAAC,CAAC,CAAC;qBACN;iBACJ;aAEJ;QAEL,CAAC,EAAE,CAAC,CAAC,CAAC;IACV,CAAC;IAED;;;OAGG;IACK,gBAAgB,CAAC,YAAwC;QAC7D,IAAI,CAAC,KAAK,CAAC,YAAY,CAAC,OAAO,CAAC,GAAG,YAAY,CAAC,KAAK,CAAC;IAC1D,CAAC;IAED,OAAO;QACH,OAAO;YACH,GAAG,EAAE,IAAI,CAAC,SAAS,CAAC,GAAG;YACvB,MAAM,EAAE,IAAI,CAAC,KAAK;SACrB,CAAC;IACN,CAAC;IAED;;;MAGE;IACF,YAAY,CAAC,MAAoC;QAC7C,qCAAqC;QACrC,KAAK,MAAM,CAAC,GAAG,EAAE,KAAK,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE;YACnD,MAAM,KAAK,GAAG,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,OAAO,KAAK,GAAG,CAAC,CAAC;YAC9E,IAAI,KAAK,IAAI,CAAC,EAAE;gBACZ,MAAM,IAAI,GAAG,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,KAAK,CAAyB,CAAC;gBAClE,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;aACtB;SACJ;QAED,MAAM,CAAC,OAAO,CAAC,CAAC,KAAK,EAAE,EAAE;YACrB,MAAM,KAAK,GAAG,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,OAAO,KAAK,KAAK,CAAC,OAAO,CAAC,CAAC;YACxF,IAAI,KAAK,IAAI,CAAC,EAAE;gBACZ,KAAK,MAAM,CAAC,GAAG,EAAE,KAAK,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,KAAK,CAAC,MAAM,CAAC,EAAE;oBACrD,IAAI,IAAI,CAAC,mBAAmB,CAAC,WAAW,CAAC,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,KAAK,CAAC,EAAE,GAAG,CAAC,EAAE;wBACzE,MAAM,IAAI,GAAG,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,KAAK,CAAyB,CAAC;wBAClE,IAAI,CAAC,GAAG,CAAC,GAAG,KAAK,CAAC;wBAClB,IAAI,GAAG,KAAK,OAAO,EAAE;4BACjB,kFAAkF;4BAClF,IAAI,CAAC,cAAc,GAAG,KAAK,CAAC;yBAC/B;qBACJ;iBACJ;aACJ;QACL,CAAC,CAAC,CAAC;QACH,IAAI,CAAC,QAAQ,CAAC,UAAU,EAAE,CAAA;QAC1B,IAAI,CAAC,QAAQ,CAAC,IAAI,GAAG,IAAI,CAAC,SAAS,CAAC;IACxC,CAAC;IAED,cAAc,CAAC,KAAU;QACrB,MAAM,KAAK,GAA+B;YACtC,GAAG,EAAE,KAAK,CAAC,EAAE;YACb,OAAO,EAAE,KAAK,CAAC,GAAG;YAClB,KAAK,EAAE,KAAK,CAAC,KAAK;SACrB,CAAC;QACF,IAAI,CAAC,gBAAgB,CAAC,KAAK,CAAC,CAAC;QAC7B,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IACjC,CAAC;IAED,cAAc,CAAC,KAAU;QACrB,MAAM,KAAK,GAA+B;YACtC,GAAG,EAAE,KAAK,CAAC,EAAE;YACb,OAAO,EAAE,KAAK,CAAC,GAAG;YAClB,KAAK,EAAE,KAAK,CAAC,KAAK;SACrB,CAAC;QACF,IAAI,CAAC,gBAAgB,CAAC,KAAK,CAAC,CAAC;QAC7B,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAChC,CAAC;IAED,uBAAuB,CAAC,KAAU;QAC9B,IAAI,CAAC,oBAAoB,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAC1C,CAAC;;kHApMQ,oBAAoB;sGAApB,oBAAoB,oTAFlB,CAAC,qBAAqB,CAAC,2HAIK,gBAAgB,6BCpC3D,sgDAwCA;4FDNa,oBAAoB;kBANhC,SAAS;+BACI,kBAAkB,aAGjB,CAAC,qBAAqB,CAAC;2IAK9B,gBAAgB;sBADnB,SAAS;uBAAC,kBAAkB,EAAE,EAAE,IAAI,EAAE,gBAAgB,EAAE;gBAOrD,UAAU;sBADb,KAAK;gBAQF,QAAQ;sBADX,KAAK;gBAMN,QAAQ;sBADP,KAAK;gBAIN,MAAM;sBADL,KAAK;gBAIN,UAAU;sBADT,KAAK;gBAIN,UAAU;sBADT,KAAK;gBAIN,WAAW;sBADV,MAAM;gBAIP,UAAU;sBADT,MAAM;gBAIP,oBAAoB;sBADnB,MAAM","sourcesContent":["import {\n    Component,\n    OnInit,\n    Input,\n    Output,\n    ViewChild,\n    ViewContainerRef,\n    EventEmitter,   \n    Type,\n} from '@angular/core';\n//import { PepFormComponent } from '@pepperi-addons/ngx-lib/form';\nimport {\n    IPepGenericFormDataView,\n    IPepGenericFormValueChange,\n    IPepGenericFormFieldUpdate,\n    IPepGenericFormData\n} from './generic-form.model';\nimport {\n    UIControl,\n    ObjectsDataRow,\n    ObjectsDataRowCell,\n    PepGuid,\n    PepLayoutService\n} from '@pepperi-addons/ngx-lib';\nimport { DataViewConverter } from '@pepperi-addons/data-views';\nimport { PepGenericFormService } from './generic-form.service';\n\n\n@Component({\n    selector: 'pep-generic-form',\n    templateUrl: './generic-form.component.html',\n    styleUrls: ['./generic-form.component.scss'],\n    providers: [PepGenericFormService]\n})\nexport class GenericFormComponent implements OnInit {\n    private _pepFormContainer: ViewContainerRef | undefined;\n    @ViewChild('pepFormContainer', { read: ViewContainerRef })\n    set pepListContainer(val: ViewContainerRef) {\n        this._pepFormContainer = val;\n    }\n\n    private _data: any;\n    @Input()\n    set dataSource(val: any) {\n        this._data = val;\n    }\n\n    private _formData: ObjectsDataRow;\n    private _uiControl: UIControl;\n    @Input()\n    set dataView(val: IPepGenericFormDataView) {\n        this.initForm(val);\n    }\n\n    @Input()\n    isLocked = false;\n\n    @Input()\n    inline = false;\n\n    @Input()\n    showTopBar = false;\n\n    @Input()\n    addPadding = false;\n\n    @Output()\n    valueChange: EventEmitter<IPepGenericFormValueChange> = new EventEmitter<IPepGenericFormValueChange>();\n\n    @Output()\n    fieldClick: EventEmitter<IPepGenericFormValueChange> = new EventEmitter<IPepGenericFormValueChange>();\n\n    @Output()\n    formValidationChange: EventEmitter<boolean> = new EventEmitter<boolean>();\n\n    private _pepForm: any;\n\n    constructor(        \n        private layoutService: PepLayoutService,\n        public _genericFormService: PepGenericFormService\n    ) {\n        this.layoutService.onResize$.pipe().subscribe((size) => {\n            //            \n        });\n        this._formData = new ObjectsDataRow();\n        this._uiControl = new UIControl();\n    }\n\n    ngOnInit() {\n        //        \n    }\n\n    private initForm(dataView: IPepGenericFormDataView) {\n        setTimeout(async () => {\n            if (this._pepFormContainer) {\n                if (this._pepFormContainer.length) {\n                    this._pepFormContainer.remove();\n                    this._formData = new ObjectsDataRow();\n                    this._uiControl = new UIControl();\n                }               \n                const { PepFormComponent } = await import('@pepperi-addons/ngx-lib/form');                  \n                const componentRef = this._pepFormContainer.createComponent(PepFormComponent);    \n\n                this._pepForm = componentRef.instance;\n\n                this._formData.IsEditable = !this.isLocked;\n                this._formData.UID = dataView.UID || PepGuid.newGuid();\n                const uiControlData = DataViewConverter.toUIControlData(dataView);\n                if (uiControlData) {\n                    if (uiControlData?.ControlFields) {\n                        this._uiControl.ControlFields = uiControlData.ControlFields.map((field: any) => this._genericFormService.convertToUiControlField(field));\n                    }\n                    this._uiControl.Columns = uiControlData.Columns;\n\n                    if (this._uiControl.ControlFields?.length) {\n                        this._formData.Fields = [];\n                        this._uiControl.ControlFields.forEach((item) => {\n                            let value = '';\n                            if (this._genericFormService.hasProperty(this._data, item.ApiName)) {\n                                value = this._data[item.ApiName];\n                            }\n                            let dataViewField: any;\n                            if (dataView.Fields) {\n                                dataViewField = dataView.Fields.find(field => field.FieldID === item.ApiName);\n                            }\n                            const controlFieldData = {\n                                ...item,\n                                ...{\n                                    controlFieldValue: value\n                                },\n                                ...{\n                                    OptionalValues: dataViewField?.OptionalValues?.length ? dataViewField.OptionalValues : [],\n                                    AdditionalProps: dataViewField?.AdditionalProps || null\n                                }\n                            }\n                            this._formData.Fields.push(this._genericFormService.createFormField(controlFieldData));\n                        });\n\n                        componentRef.instance.layoutType = 'form';\n                        componentRef.instance.layout = this._uiControl;\n                        componentRef.instance.data = this._formData;\n                        componentRef.instance.isInternal = false;\n                        componentRef.instance.lockFields = this.isLocked;\n                        componentRef.instance.valueChange.subscribe(($event) => {\n                            this.onValueChanged($event);\n                        });\n                        componentRef.instance.fieldClick.subscribe(($event) => {\n                            this.onfieldClicked($event);\n                        });\n                        componentRef.instance.formValidationChange.subscribe(($event) => {\n                            this.onFormValidationChanged($event);\n                        });\n                    }\n                }\n\n            }\n\n        }, 0);\n    }\n\n    /**\n     * updates form field's value\n     * @param field object containing the data of the required update\n     */\n    private updateFieldValue(fieldChanged: IPepGenericFormValueChange) {\n        this._data[fieldChanged.ApiName] = fieldChanged.Value;\n    }\n\n    getData(): IPepGenericFormData {\n        return {\n            UID: this._formData.UID,\n            Values: this._data\n        };\n    }\n\n    /**\n    * updates form field(s) params\n    * @param fields\n    */\n    updateFields(fields: IPepGenericFormFieldUpdate[]) {\n        // update data view with current data\n        for (const [key, value] of Object.entries(this._data)) {\n            const index = this._formData.Fields.findIndex((item) => item.ApiName === key);\n            if (index >= 0) {\n                const item = this._formData.Fields[index] as { [k: string]: any };\n                item.Value = value;\n            }\n        }\n\n        fields.forEach((field) => {\n            const index = this._formData.Fields.findIndex((item) => item.ApiName === field.FieldId);\n            if (index >= 0) {\n                for (const [key, value] of Object.entries(field.Params)) {\n                    if (this._genericFormService.hasProperty(this._formData.Fields[index], key)) {\n                        const item = this._formData.Fields[index] as { [k: string]: any };\n                        item[key] = value;\n                        if (key === 'Value') {\n                            //manually updating formattedValue because FormattedValue is legacy used by webapp\n                            item.FormattedValue = value;\n                        }\n                    }\n                }\n            }\n        });\n        this._pepForm.ReloadForm()\n        this._pepForm.data = this._formData;\n    }\n\n    onValueChanged(event: any) {\n        const field: IPepGenericFormValueChange = {\n            UID: event.id,\n            ApiName: event.key,\n            Value: event.value\n        };\n        this.updateFieldValue(field);\n        this.valueChange.emit(field);\n    }\n\n    onfieldClicked(event: any) {\n        const field: IPepGenericFormValueChange = {\n            UID: event.id,\n            ApiName: event.key,\n            Value: event.value\n        };\n        this.updateFieldValue(field);\n        this.fieldClick.emit(field);\n    }\n\n    onFormValidationChanged(event: any) {\n        this.formValidationChange.emit(event);\n    }\n\n\n}\n","<div *ngIf=\"inline\" class=\"inline-container\" [ngClass]=\"{ 'add-padding': addPadding }\">\n    <div *ngIf=\"showTopBar\" class=\"inline-top-bar-container\">\n        <ng-container *ngTemplateOutlet=\"topBarTemplate\"></ng-container>\n    </div>\n    <ng-container *ngTemplateOutlet=\"formTemplate\"></ng-container>\n</div>\n\n<pep-page-layout *ngIf=\"!inline\" [addPadding]=\"addPadding\">\n    <ng-container *ngIf=\"showTopBar\" pep-top-area>\n        <ng-container *ngTemplateOutlet=\"topBarTemplate\"></ng-container>\n    </ng-container>\n    <div pep-main-area class=\"main-area-container\">\n        <ng-container *ngTemplateOutlet=\"formTemplate\"></ng-container>\n    </div>\n</pep-page-layout>\n\n<ng-template #topBarTemplate>\n    <pep-top-bar [inline]=\"inline\"> \n        <div header-start-content>\n            <ng-content select=\"[left-buttons]\"></ng-content>\n        </div>\n        <div header-end-content>\n            <ng-content select=\"[right-buttons]\"></ng-content>\n        </div>\n\n        <!-- <div footer-start-content>\n            <ng-content select=\"[bottom-left-buttons]\"></ng-content>\n        </div>\n        <div footer-end-content>\n            <ng-content select=\"[bottom-right-buttons]\"></ng-content>\n        </div> -->\n    </pep-top-bar>\n</ng-template>\n\n<ng-template #formTemplate>\n    <!-- class=\"form-view\"  -->\n    <div [ngClass]=\"{'form-view': showTopBar, 'padding-bottom': !showTopBar}\">\n        <ng-container #pepFormContainer></ng-container>\n    </div>\n</ng-template>\n"]}
|
|
@@ -15,8 +15,8 @@ import { GenericFormComponent } from './generic-form.component';
|
|
|
15
15
|
import * as i0 from "@angular/core";
|
|
16
16
|
export class PepGenericFormModule {
|
|
17
17
|
}
|
|
18
|
-
PepGenericFormModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "
|
|
19
|
-
PepGenericFormModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "
|
|
18
|
+
PepGenericFormModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: PepGenericFormModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
19
|
+
PepGenericFormModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "15.2.10", ngImport: i0, type: PepGenericFormModule, declarations: [GenericFormComponent], imports: [CommonModule,
|
|
20
20
|
// MatFormFieldModule,
|
|
21
21
|
// ReactiveFormsModule,
|
|
22
22
|
PepNgxLibModule,
|
|
@@ -25,7 +25,7 @@ PepGenericFormModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", ve
|
|
|
25
25
|
PepMenuModule,
|
|
26
26
|
PepPageLayoutModule,
|
|
27
27
|
PepTopBarModule], exports: [GenericFormComponent] });
|
|
28
|
-
PepGenericFormModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "
|
|
28
|
+
PepGenericFormModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: PepGenericFormModule, providers: [
|
|
29
29
|
PepGenericFormService
|
|
30
30
|
], imports: [CommonModule,
|
|
31
31
|
// MatFormFieldModule,
|
|
@@ -36,7 +36,7 @@ PepGenericFormModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", ve
|
|
|
36
36
|
PepMenuModule,
|
|
37
37
|
PepPageLayoutModule,
|
|
38
38
|
PepTopBarModule] });
|
|
39
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
39
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: PepGenericFormModule, decorators: [{
|
|
40
40
|
type: NgModule,
|
|
41
41
|
args: [{
|
|
42
42
|
declarations: [
|
|
@@ -65,4 +65,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.2", ngImpor
|
|
|
65
65
|
]
|
|
66
66
|
}]
|
|
67
67
|
}] });
|
|
68
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
68
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ2VuZXJpYy1mb3JtLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL25neC1jb21wb3NpdGUtbGliL2dlbmVyaWMtZm9ybS9nZW5lcmljLWZvcm0ubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLG9FQUFvRTtBQUNwRSw0REFBNEQ7QUFDNUQsdURBQXVEO0FBQ3ZELE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQztBQUMxRCxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sOEJBQThCLENBQUM7QUFDN0QsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLDhCQUE4QixDQUFDO0FBQzdELE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLHFDQUFxQyxDQUFDO0FBQzFFLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSxpQ0FBaUMsQ0FBQztBQUNsRSxxRUFBcUU7QUFDckUsK0RBQStEO0FBRS9ELE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxNQUFNLHdCQUF3QixDQUFDO0FBRS9ELE9BQU8sRUFBRSxvQkFBb0IsRUFBRSxNQUFNLDBCQUEwQixDQUFDOztBQThCaEUsTUFBTSxPQUFPLG9CQUFvQjs7a0hBQXBCLG9CQUFvQjttSEFBcEIsb0JBQW9CLGlCQTFCekIsb0JBQW9CLGFBR3BCLFlBQVk7UUFFYixzQkFBc0I7UUFDeEIseUJBQXlCO1FBRXRCLGVBQWU7UUFDaEIsaUJBQWlCO1FBQ2hCLGFBQWE7UUFDYixhQUFhO1FBQ2IsbUJBQW1CO1FBQ25CLGVBQWUsYUFPZixvQkFBb0I7bUhBTWYsb0JBQW9CLGFBSmxCO1FBQ1AscUJBQXFCO0tBQ3hCLFlBckJHLFlBQVk7UUFFYixzQkFBc0I7UUFDeEIseUJBQXlCO1FBRXRCLGVBQWU7UUFDaEIsaUJBQWlCO1FBQ2hCLGFBQWE7UUFDYixhQUFhO1FBQ2IsbUJBQW1CO1FBQ25CLGVBQWU7NEZBYVYsb0JBQW9CO2tCQTVCaEMsUUFBUTttQkFBQztvQkFDTixZQUFZLEVBQUU7d0JBQ1Ysb0JBQW9CO3FCQUN2QjtvQkFDRCxPQUFPLEVBQUU7d0JBQ0wsWUFBWTt3QkFFYixzQkFBc0I7d0JBQ3hCLHlCQUF5Qjt3QkFFdEIsZUFBZTt3QkFDaEIsaUJBQWlCO3dCQUNoQixhQUFhO3dCQUNiLGFBQWE7d0JBQ2IsbUJBQW1CO3dCQUNuQixlQUFlO3dCQUNsQixzQkFBc0I7d0JBQ3JCLGlCQUFpQjt3QkFDbEIscUJBQXFCO3dCQUNwQix3QkFBd0I7cUJBQ3pCO29CQUNELE9BQU8sRUFBRTt3QkFDTCxvQkFBb0I7cUJBQ3ZCO29CQUNELFNBQVMsRUFBRTt3QkFDUCxxQkFBcUI7cUJBQ3hCO2lCQUNKIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG4vL2ltcG9ydCB7IE1hdEZvcm1GaWVsZE1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2Zvcm0tZmllbGQnO1xuLy9pbXBvcnQgeyBNYXRlcmlhbE1vZHVsZSB9IGZyb20gJ0BwZXBwZXJpLWFkZG9ucy9uZ3gtbGliLyc7XG4vL2ltcG9ydCB7IFJlYWN0aXZlRm9ybXNNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XG5pbXBvcnQgeyBQZXBOZ3hMaWJNb2R1bGUgfSBmcm9tICdAcGVwcGVyaS1hZGRvbnMvbmd4LWxpYic7XG5pbXBvcnQgeyBQZXBGb3JtTW9kdWxlIH0gZnJvbSAnQHBlcHBlcmktYWRkb25zL25neC1saWIvZm9ybSc7XG5pbXBvcnQgeyBQZXBNZW51TW9kdWxlIH0gZnJvbSAnQHBlcHBlcmktYWRkb25zL25neC1saWIvbWVudSc7XG5pbXBvcnQgeyBQZXBQYWdlTGF5b3V0TW9kdWxlIH0gZnJvbSAnQHBlcHBlcmktYWRkb25zL25neC1saWIvcGFnZS1sYXlvdXQnO1xuaW1wb3J0IHsgUGVwVG9wQmFyTW9kdWxlIH0gZnJvbSAnQHBlcHBlcmktYWRkb25zL25neC1saWIvdG9wLWJhcic7XG4vL2ltcG9ydCB7IFBlcFRleHRib3hNb2R1bGUgfSBmcm9tICdAcGVwcGVyaS1hZGRvbnMvbmd4LWxpYi90ZXh0Ym94Jztcbi8vaW1wb3J0IHsgUGVwRGF0ZU1vZHVsZSB9IGZyb20gJ0BwZXBwZXJpLWFkZG9ucy9uZ3gtbGliL2RhdGUnO1xuXG5pbXBvcnQgeyBQZXBHZW5lcmljRm9ybVNlcnZpY2UgfSBmcm9tICcuL2dlbmVyaWMtZm9ybS5zZXJ2aWNlJztcblxuaW1wb3J0IHsgR2VuZXJpY0Zvcm1Db21wb25lbnQgfSBmcm9tICcuL2dlbmVyaWMtZm9ybS5jb21wb25lbnQnO1xuXG5ATmdNb2R1bGUoe1xuICAgIGRlY2xhcmF0aW9uczogW1xuICAgICAgICBHZW5lcmljRm9ybUNvbXBvbmVudFxuICAgIF0sXG4gICAgaW1wb3J0czogW1xuICAgICAgICBDb21tb25Nb2R1bGUsIFxuXG4gICAgICAgLy8gTWF0Rm9ybUZpZWxkTW9kdWxlLFxuICAgICAvLyAgIFJlYWN0aXZlRm9ybXNNb2R1bGUsXG5cbiAgICAgICAgUGVwTmd4TGliTW9kdWxlLFxuICAgICAgIC8vIFBlcExpc3RNb2R1bGUsXG4gICAgICAgIFBlcEZvcm1Nb2R1bGUsXG4gICAgICAgIFBlcE1lbnVNb2R1bGUsXG4gICAgICAgIFBlcFBhZ2VMYXlvdXRNb2R1bGUsXG4gICAgICAgIFBlcFRvcEJhck1vZHVsZSxcbiAgICAgLy8gICBQZXBUZXh0Ym94TW9kdWxlLFxuICAgICAgLy8gIFBlcERhdGVNb2R1bGVcbiAgICAgLy8gICBQZXBTZWFyY2hNb2R1bGUsXG4gICAgICAvLyAgUGVwQnJlYWRDcnVtYnNNb2R1bGVcbiAgICBdLFxuICAgIGV4cG9ydHM6IFtcbiAgICAgICAgR2VuZXJpY0Zvcm1Db21wb25lbnRcbiAgICBdLFxuICAgIHByb3ZpZGVyczogW1xuICAgICAgICBQZXBHZW5lcmljRm9ybVNlcnZpY2VcbiAgICBdXG59KVxuZXhwb3J0IGNsYXNzIFBlcEdlbmVyaWNGb3JtTW9kdWxlIHsgfVxuIl19
|