@pepperi-addons/ngx-composite-lib 0.4.2-beta.101 → 0.4.2-beta.103

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.
Files changed (21) hide show
  1. package/esm2020/generic-fields-builder/generic-fields-builder.component.mjs +107 -0
  2. package/esm2020/generic-fields-builder/generic-fields-builder.module.mjs +79 -0
  3. package/esm2020/generic-fields-builder/generic-fields-builder.service.mjs +39 -0
  4. package/esm2020/generic-fields-builder/pepperi-addons-ngx-composite-lib-generic-fields-builder.mjs +5 -0
  5. package/esm2020/generic-fields-builder/public-api.mjs +6 -0
  6. package/esm2020/padding-settings/padding-settings.component.mjs +4 -6
  7. package/fesm2015/pepperi-addons-ngx-composite-lib-generic-fields-builder.mjs +227 -0
  8. package/fesm2015/pepperi-addons-ngx-composite-lib-generic-fields-builder.mjs.map +1 -0
  9. package/fesm2015/pepperi-addons-ngx-composite-lib-padding-settings.mjs +3 -5
  10. package/fesm2015/pepperi-addons-ngx-composite-lib-padding-settings.mjs.map +1 -1
  11. package/fesm2020/pepperi-addons-ngx-composite-lib-generic-fields-builder.mjs +227 -0
  12. package/fesm2020/pepperi-addons-ngx-composite-lib-generic-fields-builder.mjs.map +1 -0
  13. package/fesm2020/pepperi-addons-ngx-composite-lib-padding-settings.mjs +3 -5
  14. package/fesm2020/pepperi-addons-ngx-composite-lib-padding-settings.mjs.map +1 -1
  15. package/generic-fields-builder/generic-fields-builder.component.d.ts +34 -0
  16. package/generic-fields-builder/generic-fields-builder.module.d.ts +22 -0
  17. package/generic-fields-builder/generic-fields-builder.service.d.ts +14 -0
  18. package/generic-fields-builder/index.d.ts +5 -0
  19. package/generic-fields-builder/public-api.d.ts +2 -0
  20. package/package.json +9 -1
  21. package/src/assets/i18n/en.ngx-composite-lib.json +10 -0
@@ -0,0 +1,107 @@
1
+ import { moveItemInArray } from '@angular/cdk/drag-drop';
2
+ import { Component, EventEmitter, Input, Output } from '@angular/core';
3
+ import * as i0 from "@angular/core";
4
+ import * as i1 from "./generic-fields-builder.service";
5
+ import * as i2 from "@angular/common";
6
+ import * as i3 from "@angular/cdk/drag-drop";
7
+ import * as i4 from "@angular/material/icon";
8
+ import * as i5 from "@pepperi-addons/ngx-lib/icon";
9
+ import * as i6 from "@pepperi-addons/ngx-lib/page-layout";
10
+ import * as i7 from "@pepperi-addons/ngx-lib/draggable-items";
11
+ import * as i8 from "@ngx-translate/core";
12
+ export class GenericFieldsBuilderComponent {
13
+ constructor(genericFieldsBuilderService) {
14
+ this.genericFieldsBuilderService = genericFieldsBuilderService;
15
+ // @Input() title: string = '';
16
+ this.builderTitle = '';
17
+ this.builderTitleHint = '';
18
+ this.showAddSeparator = true;
19
+ this.itemKeyLabel = '';
20
+ this.itemTitleLabel = '';
21
+ this._availableFields = [];
22
+ this.fieldTemplate = undefined;
23
+ this._fields = [];
24
+ this.fieldsChange = new EventEmitter();
25
+ this.emptyDropAreaId = 'emptyDropArea';
26
+ this.mappedFieldsId = 'mappedFields';
27
+ this.isGrabbing = false;
28
+ this.genericFieldsBuilderService.isGrabbingChange$.subscribe((value) => {
29
+ this.isGrabbing = value;
30
+ });
31
+ }
32
+ set availableFields(value) {
33
+ this._availableFields = value;
34
+ }
35
+ get availableFields() {
36
+ return this._availableFields;
37
+ }
38
+ set fields(value) {
39
+ this._fields = value;
40
+ }
41
+ get fields() {
42
+ return this._fields;
43
+ }
44
+ notifyFieldsChange() {
45
+ this.fieldsChange.emit(this._fields);
46
+ }
47
+ addNewField(draggableItem, index) {
48
+ // Add new menuField to the mappedFields.
49
+ const field = { key: draggableItem.data.key, title: draggableItem.title };
50
+ this.spliceMappedFields(index, 0, field);
51
+ }
52
+ spliceMappedFields(start, deleteCount, field) {
53
+ if (field) {
54
+ this._fields.splice(start, deleteCount, field);
55
+ }
56
+ else {
57
+ this._fields.splice(start, deleteCount);
58
+ }
59
+ this.notifyFieldsChange();
60
+ }
61
+ ngOnInit() {
62
+ //
63
+ }
64
+ onDragStart(event) {
65
+ this.genericFieldsBuilderService.onDragStart(event);
66
+ }
67
+ onDragEnd(event) {
68
+ this.genericFieldsBuilderService.onDragEnd(event);
69
+ }
70
+ onDropField(event) {
71
+ if (event.previousContainer === event.container) {
72
+ moveItemInArray(event.container.data, event.previousIndex, event.currentIndex);
73
+ this.notifyFieldsChange();
74
+ }
75
+ else if (event.container.id === 'emptyDropArea') {
76
+ this.addNewField(event.previousContainer.data[event.previousIndex], this.fields.length);
77
+ }
78
+ else {
79
+ this.addNewField(event.previousContainer.data[event.previousIndex], event.currentIndex);
80
+ }
81
+ }
82
+ }
83
+ GenericFieldsBuilderComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.2", ngImport: i0, type: GenericFieldsBuilderComponent, deps: [{ token: i1.GenericFieldsBuilderService }], target: i0.ɵɵFactoryTarget.Component });
84
+ GenericFieldsBuilderComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.0.2", type: GenericFieldsBuilderComponent, selector: "pep-generic-fields-builder", inputs: { builderTitle: "builderTitle", builderTitleHint: "builderTitleHint", showAddSeparator: "showAddSeparator", itemKeyLabel: "itemKeyLabel", itemTitleLabel: "itemTitleLabel", availableFields: "availableFields", fieldTemplate: "fieldTemplate", fields: "fields" }, outputs: { fieldsChange: "fieldsChange" }, 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 }}&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 <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 }\"></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\">\n {{ 'GENERIC_FIELDS_BUILDER.TEMPLATE_NOT_SUPPLIED' | translate: { fieldTitle: field.title || field.key } }}\n</ng-template>\n", styles: [".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 .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-area .mapped-field-container.cdk-drag-placeholder{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 .mapped-field-container.cdk-drag-placeholder .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: "pipe", type: i8.TranslatePipe, name: "translate" }] });
85
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.2", ngImport: i0, type: GenericFieldsBuilderComponent, decorators: [{
86
+ type: Component,
87
+ 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 }}&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 <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 }\"></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\">\n {{ 'GENERIC_FIELDS_BUILDER.TEMPLATE_NOT_SUPPLIED' | translate: { fieldTitle: field.title || field.key } }}\n</ng-template>\n", styles: [".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 .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-area .mapped-field-container.cdk-drag-placeholder{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 .mapped-field-container.cdk-drag-placeholder .field-wrapper{opacity:0}\n"] }]
88
+ }], ctorParameters: function () { return [{ type: i1.GenericFieldsBuilderService }]; }, propDecorators: { builderTitle: [{
89
+ type: Input
90
+ }], builderTitleHint: [{
91
+ type: Input
92
+ }], showAddSeparator: [{
93
+ type: Input
94
+ }], itemKeyLabel: [{
95
+ type: Input
96
+ }], itemTitleLabel: [{
97
+ type: Input
98
+ }], availableFields: [{
99
+ type: Input
100
+ }], fieldTemplate: [{
101
+ type: Input
102
+ }], fields: [{
103
+ type: Input
104
+ }], fieldsChange: [{
105
+ type: Output
106
+ }] } });
107
+ //# 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 } from '@pepperi-addons/ngx-lib/draggable-items';\nimport { GenericFieldsBuilderService } from './generic-fields-builder.service';\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    \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: any[] = [];\n    @Input()\n    set fields(value: any[]) {\n        this._fields = value;\n    }\n    get fields() : any[] {\n        return this._fields;\n    }\n\n    @Output()\n    fieldsChange: EventEmitter<any[]> = new EventEmitter<any[]>();\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: any = { key: draggableItem.data.key, title: draggableItem.title };\n        this.spliceMappedFields(index, 0, field);\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                                <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 }\"></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\">\n    {{ 'GENERIC_FIELDS_BUILDER.TEMPLATE_NOT_SUPPLIED' | translate: { fieldTitle: field.title || field.key } }}\n</ng-template>\n"]}
@@ -0,0 +1,79 @@
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 * as i0 from "@angular/core";
17
+ import * as i1 from "@pepperi-addons/ngx-lib/icon";
18
+ const pepIcons = [
19
+ pepIconSystemClose,
20
+ pepIconArrowDownAlt,
21
+ pepIconSystemBin,
22
+ pepIconNumberPlus
23
+ ];
24
+ export class PepGenericFieldsBuilderModule {
25
+ constructor(pepIconRegistry) {
26
+ this.pepIconRegistry = pepIconRegistry;
27
+ this.pepIconRegistry.registerIcons(pepIcons);
28
+ }
29
+ }
30
+ PepGenericFieldsBuilderModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.2", ngImport: i0, type: PepGenericFieldsBuilderModule, deps: [{ token: i1.PepIconRegistry }], target: i0.ɵɵFactoryTarget.NgModule });
31
+ PepGenericFieldsBuilderModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "14.0.2", ngImport: i0, type: PepGenericFieldsBuilderModule, declarations: [GenericFieldsBuilderComponent], imports: [CommonModule,
32
+ DragDropModule,
33
+ MatIconModule,
34
+ PepNgxLibModule,
35
+ PepButtonModule,
36
+ PepDialogModule,
37
+ PepIconModule,
38
+ PepMenuModule,
39
+ PepPageLayoutModule,
40
+ PepTextboxModule,
41
+ PepTopBarModule,
42
+ PepDraggableItemsModule], exports: [GenericFieldsBuilderComponent] });
43
+ PepGenericFieldsBuilderModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "14.0.2", ngImport: i0, type: PepGenericFieldsBuilderModule, providers: [GenericFieldsBuilderService], imports: [CommonModule,
44
+ DragDropModule,
45
+ MatIconModule,
46
+ PepNgxLibModule,
47
+ PepButtonModule,
48
+ PepDialogModule,
49
+ PepIconModule,
50
+ PepMenuModule,
51
+ PepPageLayoutModule,
52
+ PepTextboxModule,
53
+ PepTopBarModule,
54
+ PepDraggableItemsModule] });
55
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.2", ngImport: i0, type: PepGenericFieldsBuilderModule, decorators: [{
56
+ type: NgModule,
57
+ args: [{
58
+ declarations: [
59
+ GenericFieldsBuilderComponent
60
+ ],
61
+ imports: [
62
+ CommonModule,
63
+ DragDropModule,
64
+ MatIconModule,
65
+ PepNgxLibModule,
66
+ PepButtonModule,
67
+ PepDialogModule,
68
+ PepIconModule,
69
+ PepMenuModule,
70
+ PepPageLayoutModule,
71
+ PepTextboxModule,
72
+ PepTopBarModule,
73
+ PepDraggableItemsModule,
74
+ ],
75
+ exports: [GenericFieldsBuilderComponent],
76
+ providers: [GenericFieldsBuilderService]
77
+ }]
78
+ }], ctorParameters: function () { return [{ type: i1.PepIconRegistry }]; } });
79
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ2VuZXJpYy1maWVsZHMtYnVpbGRlci5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtY29tcG9zaXRlLWxpYi9nZW5lcmljLWZpZWxkcy1idWlsZGVyL2dlbmVyaWMtZmllbGRzLWJ1aWxkZXIubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBRS9DLE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQztBQUV4RCxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFFdkQsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLHlCQUF5QixDQUFDO0FBQzFELE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSxnQ0FBZ0MsQ0FBQztBQUNqRSxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sZ0NBQWdDLENBQUM7QUFDakUsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLDhCQUE4QixDQUFDO0FBQzdELE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLHFDQUFxQyxDQUFDO0FBQzFFLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLGlDQUFpQyxDQUFDO0FBQ25FLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSxpQ0FBaUMsQ0FBQztBQUNsRSxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsTUFBTSx5Q0FBeUMsQ0FBQztBQUNsRixPQUFPLEVBQW1CLGFBQWEsRUFBRSxrQkFBa0IsRUFBRSxtQkFBbUIsRUFBRSxnQkFBZ0IsRUFBRSxpQkFBaUIsRUFBRSxNQUFNLDhCQUE4QixDQUFDO0FBRTVKLE9BQU8sRUFBRSwyQkFBMkIsRUFBRSxNQUFNLGtDQUFrQyxDQUFDO0FBRS9FLE9BQU8sRUFBRSw2QkFBNkIsRUFBRSxNQUFNLG9DQUFvQyxDQUFDOzs7QUFFbkYsTUFBTSxRQUFRLEdBQUc7SUFDYixrQkFBa0I7SUFDbEIsbUJBQW1CO0lBQ25CLGdCQUFnQjtJQUNoQixpQkFBaUI7Q0FDcEIsQ0FBQztBQXVCRixNQUFNLE9BQU8sNkJBQTZCO0lBQ3RDLFlBQ1ksZUFBZ0M7UUFBaEMsb0JBQWUsR0FBZixlQUFlLENBQWlCO1FBRXhDLElBQUksQ0FBQyxlQUFlLENBQUMsYUFBYSxDQUFDLFFBQVEsQ0FBQyxDQUFDO0lBQ2pELENBQUM7OzBIQUxRLDZCQUE2QjsySEFBN0IsNkJBQTZCLGlCQW5CbEMsNkJBQTZCLGFBRzdCLFlBQVk7UUFDWixjQUFjO1FBQ2QsYUFBYTtRQUNiLGVBQWU7UUFDZixlQUFlO1FBQ2YsZUFBZTtRQUNmLGFBQWE7UUFDYixhQUFhO1FBQ2IsbUJBQW1CO1FBQ25CLGdCQUFnQjtRQUNoQixlQUFlO1FBQ2YsdUJBQXVCLGFBRWpCLDZCQUE2QjsySEFHOUIsNkJBQTZCLGFBRjNCLENBQUMsMkJBQTJCLENBQUMsWUFkcEMsWUFBWTtRQUNaLGNBQWM7UUFDZCxhQUFhO1FBQ2IsZUFBZTtRQUNmLGVBQWU7UUFDZixlQUFlO1FBQ2YsYUFBYTtRQUNiLGFBQWE7UUFDYixtQkFBbUI7UUFDbkIsZ0JBQWdCO1FBQ2hCLGVBQWU7UUFDZix1QkFBdUI7MkZBS2xCLDZCQUE2QjtrQkFyQnpDLFFBQVE7bUJBQUM7b0JBQ04sWUFBWSxFQUFFO3dCQUNWLDZCQUE2QjtxQkFDaEM7b0JBQ0QsT0FBTyxFQUFFO3dCQUNMLFlBQVk7d0JBQ1osY0FBYzt3QkFDZCxhQUFhO3dCQUNiLGVBQWU7d0JBQ2YsZUFBZTt3QkFDZixlQUFlO3dCQUNmLGFBQWE7d0JBQ2IsYUFBYTt3QkFDYixtQkFBbUI7d0JBQ25CLGdCQUFnQjt3QkFDaEIsZUFBZTt3QkFDZix1QkFBdUI7cUJBQzFCO29CQUNELE9BQU8sRUFBRSxDQUFDLDZCQUE2QixDQUFDO29CQUN4QyxTQUFTLEVBQUUsQ0FBQywyQkFBMkIsQ0FBQztpQkFDM0MiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcblxuaW1wb3J0IHsgRHJhZ0Ryb3BNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jZGsvZHJhZy1kcm9wJztcblxuaW1wb3J0IHsgTWF0SWNvbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2ljb24nO1xuXG5pbXBvcnQgeyBQZXBOZ3hMaWJNb2R1bGUgfSBmcm9tICdAcGVwcGVyaS1hZGRvbnMvbmd4LWxpYic7XG5pbXBvcnQgeyBQZXBCdXR0b25Nb2R1bGUgfSBmcm9tICdAcGVwcGVyaS1hZGRvbnMvbmd4LWxpYi9idXR0b24nO1xuaW1wb3J0IHsgUGVwRGlhbG9nTW9kdWxlIH0gZnJvbSAnQHBlcHBlcmktYWRkb25zL25neC1saWIvZGlhbG9nJztcbmltcG9ydCB7IFBlcE1lbnVNb2R1bGUgfSBmcm9tICdAcGVwcGVyaS1hZGRvbnMvbmd4LWxpYi9tZW51JztcbmltcG9ydCB7IFBlcFBhZ2VMYXlvdXRNb2R1bGUgfSBmcm9tICdAcGVwcGVyaS1hZGRvbnMvbmd4LWxpYi9wYWdlLWxheW91dCc7XG5pbXBvcnQgeyBQZXBUZXh0Ym94TW9kdWxlIH0gZnJvbSAnQHBlcHBlcmktYWRkb25zL25neC1saWIvdGV4dGJveCc7XG5pbXBvcnQgeyBQZXBUb3BCYXJNb2R1bGUgfSBmcm9tICdAcGVwcGVyaS1hZGRvbnMvbmd4LWxpYi90b3AtYmFyJztcbmltcG9ydCB7IFBlcERyYWdnYWJsZUl0ZW1zTW9kdWxlIH0gZnJvbSAnQHBlcHBlcmktYWRkb25zL25neC1saWIvZHJhZ2dhYmxlLWl0ZW1zJztcbmltcG9ydCB7IFBlcEljb25SZWdpc3RyeSwgUGVwSWNvbk1vZHVsZSwgcGVwSWNvblN5c3RlbUNsb3NlLCBwZXBJY29uQXJyb3dEb3duQWx0LCBwZXBJY29uU3lzdGVtQmluLCBwZXBJY29uTnVtYmVyUGx1cyB9IGZyb20gJ0BwZXBwZXJpLWFkZG9ucy9uZ3gtbGliL2ljb24nO1xuXG5pbXBvcnQgeyBHZW5lcmljRmllbGRzQnVpbGRlclNlcnZpY2UgfSBmcm9tICcuL2dlbmVyaWMtZmllbGRzLWJ1aWxkZXIuc2VydmljZSc7XG5cbmltcG9ydCB7IEdlbmVyaWNGaWVsZHNCdWlsZGVyQ29tcG9uZW50IH0gZnJvbSAnLi9nZW5lcmljLWZpZWxkcy1idWlsZGVyLmNvbXBvbmVudCc7XG5cbmNvbnN0IHBlcEljb25zID0gW1xuICAgIHBlcEljb25TeXN0ZW1DbG9zZSxcbiAgICBwZXBJY29uQXJyb3dEb3duQWx0LFxuICAgIHBlcEljb25TeXN0ZW1CaW4sXG4gICAgcGVwSWNvbk51bWJlclBsdXNcbl07XG5cbkBOZ01vZHVsZSh7XG4gICAgZGVjbGFyYXRpb25zOiBbXG4gICAgICAgIEdlbmVyaWNGaWVsZHNCdWlsZGVyQ29tcG9uZW50XG4gICAgXSxcbiAgICBpbXBvcnRzOiBbXG4gICAgICAgIENvbW1vbk1vZHVsZSxcbiAgICAgICAgRHJhZ0Ryb3BNb2R1bGUsXG4gICAgICAgIE1hdEljb25Nb2R1bGUsXG4gICAgICAgIFBlcE5neExpYk1vZHVsZSxcbiAgICAgICAgUGVwQnV0dG9uTW9kdWxlLFxuICAgICAgICBQZXBEaWFsb2dNb2R1bGUsXG4gICAgICAgIFBlcEljb25Nb2R1bGUsXG4gICAgICAgIFBlcE1lbnVNb2R1bGUsXG4gICAgICAgIFBlcFBhZ2VMYXlvdXRNb2R1bGUsXG4gICAgICAgIFBlcFRleHRib3hNb2R1bGUsXG4gICAgICAgIFBlcFRvcEJhck1vZHVsZSxcbiAgICAgICAgUGVwRHJhZ2dhYmxlSXRlbXNNb2R1bGUsXG4gICAgXSxcbiAgICBleHBvcnRzOiBbR2VuZXJpY0ZpZWxkc0J1aWxkZXJDb21wb25lbnRdLFxuICAgIHByb3ZpZGVyczogW0dlbmVyaWNGaWVsZHNCdWlsZGVyU2VydmljZV1cbn0pXG5leHBvcnQgY2xhc3MgUGVwR2VuZXJpY0ZpZWxkc0J1aWxkZXJNb2R1bGUge1xuICAgIGNvbnN0cnVjdG9yKFxuICAgICAgICBwcml2YXRlIHBlcEljb25SZWdpc3RyeTogUGVwSWNvblJlZ2lzdHJ5LFxuICAgICkge1xuICAgICAgICB0aGlzLnBlcEljb25SZWdpc3RyeS5yZWdpc3Rlckljb25zKHBlcEljb25zKTtcbiAgICB9XG59XG4iXX0=
@@ -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
+ constructor() {
7
+ // This subject is for is grabbing mode.
8
+ this._isGrabbingSubject = new BehaviorSubject(false);
9
+ //
10
+ }
11
+ get isGrabbingChange$() {
12
+ return this._isGrabbingSubject.asObservable().pipe(distinctUntilChanged());
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: "14.0.2", ngImport: i0, type: GenericFieldsBuilderService, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
32
+ GenericFieldsBuilderService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "14.0.2", ngImport: i0, type: GenericFieldsBuilderService, providedIn: 'root' });
33
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.2", ngImport: i0, type: GenericFieldsBuilderService, decorators: [{
34
+ type: Injectable,
35
+ args: [{
36
+ providedIn: 'root'
37
+ }]
38
+ }], ctorParameters: function () { return []; } });
39
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ2VuZXJpYy1maWVsZHMtYnVpbGRlci5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vcHJvamVjdHMvbmd4LWNvbXBvc2l0ZS1saWIvZ2VuZXJpYy1maWVsZHMtYnVpbGRlci9nZW5lcmljLWZpZWxkcy1idWlsZGVyLnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQ0EsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUMzQyxPQUFPLEVBQUUsZUFBZSxFQUFjLE1BQU0sTUFBTSxDQUFDO0FBQ25ELE9BQU8sRUFBRSxvQkFBb0IsRUFBVSxNQUFNLGdCQUFnQixDQUFDOztBQUs5RCxNQUFNLE9BQU8sMkJBQTJCO0lBUXBDO1FBTkEsd0NBQXdDO1FBQ2hDLHVCQUFrQixHQUE2QixJQUFJLGVBQWUsQ0FBVSxLQUFLLENBQUMsQ0FBQztRQU12RixFQUFFO0lBQ04sQ0FBQztJQU5ELElBQUksaUJBQWlCO1FBQ2pCLE9BQU8sSUFBSSxDQUFDLGtCQUFrQixDQUFDLFlBQVksRUFBRSxDQUFDLElBQUksQ0FBQyxvQkFBb0IsRUFBRSxDQUFDLENBQUM7SUFDL0UsQ0FBQztJQU1PLHVCQUF1QjtRQUMzQixRQUFRLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxHQUFHLENBQUMsZ0JBQWdCLENBQUMsQ0FBQztRQUM5QyxRQUFRLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxNQUFNLEdBQUcsVUFBVSxDQUFDO1FBQ3hDLElBQUksQ0FBQyxrQkFBa0IsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUM7SUFDdkMsQ0FBQztJQUVPLHFCQUFxQjtRQUN6QixRQUFRLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxNQUFNLENBQUMsZ0JBQWdCLENBQUMsQ0FBQztRQUNqRCxRQUFRLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxNQUFNLEdBQUcsT0FBTyxDQUFDO1FBQ3JDLElBQUksQ0FBQyxrQkFBa0IsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDeEMsQ0FBQztJQUVELFdBQVcsQ0FBQyxLQUFtQjtRQUMzQixJQUFJLENBQUMsdUJBQXVCLEVBQUUsQ0FBQztJQUNuQyxDQUFDO0lBRUQsU0FBUyxDQUFDLEtBQWlCO1FBQ3ZCLElBQUksQ0FBQyxxQkFBcUIsRUFBRSxDQUFDO0lBQ2pDLENBQUM7O3dIQTlCUSwyQkFBMkI7NEhBQTNCLDJCQUEyQixjQUZ4QixNQUFNOzJGQUVULDJCQUEyQjtrQkFIdkMsVUFBVTttQkFBQztvQkFDUixVQUFVLEVBQUUsTUFBTTtpQkFDckIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDZGtEcmFnRW5kLCBDZGtEcmFnU3RhcnQgfSBmcm9tICdAYW5ndWxhci9jZGsvZHJhZy1kcm9wJztcbmltcG9ydCB7IEluamVjdGFibGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEJlaGF2aW9yU3ViamVjdCwgT2JzZXJ2YWJsZSB9IGZyb20gJ3J4anMnO1xuaW1wb3J0IHsgZGlzdGluY3RVbnRpbENoYW5nZWQsIGZpbHRlciB9IGZyb20gJ3J4anMvb3BlcmF0b3JzJztcblxuQEluamVjdGFibGUoe1xuICAgIHByb3ZpZGVkSW46ICdyb290J1xufSlcbmV4cG9ydCBjbGFzcyBHZW5lcmljRmllbGRzQnVpbGRlclNlcnZpY2Uge1xuICAgIFxuICAgIC8vIFRoaXMgc3ViamVjdCBpcyBmb3IgaXMgZ3JhYmJpbmcgbW9kZS5cbiAgICBwcml2YXRlIF9pc0dyYWJiaW5nU3ViamVjdDogQmVoYXZpb3JTdWJqZWN0PGJvb2xlYW4+ID0gbmV3IEJlaGF2aW9yU3ViamVjdDxib29sZWFuPihmYWxzZSk7XG4gICAgZ2V0IGlzR3JhYmJpbmdDaGFuZ2UkKCk6IE9ic2VydmFibGU8Ym9vbGVhbj4ge1xuICAgICAgICByZXR1cm4gdGhpcy5faXNHcmFiYmluZ1N1YmplY3QuYXNPYnNlcnZhYmxlKCkucGlwZShkaXN0aW5jdFVudGlsQ2hhbmdlZCgpKTtcbiAgICB9XG5cbiAgICBjb25zdHJ1Y3RvcigpIHsgXG4gICAgICAgIC8vXG4gICAgfVxuXG4gICAgcHJpdmF0ZSBjaGFuZ2VDdXJzb3JPbkRyYWdTdGFydCgpIHtcbiAgICAgICAgZG9jdW1lbnQuYm9keS5jbGFzc0xpc3QuYWRkKCdpbmhlcml0Q3Vyc29ycycpO1xuICAgICAgICBkb2N1bWVudC5ib2R5LnN0eWxlLmN1cnNvciA9ICdncmFiYmluZyc7XG4gICAgICAgIHRoaXMuX2lzR3JhYmJpbmdTdWJqZWN0Lm5leHQodHJ1ZSk7XG4gICAgfVxuXG4gICAgcHJpdmF0ZSBjaGFuZ2VDdXJzb3JPbkRyYWdFbmQoKSB7XG4gICAgICAgIGRvY3VtZW50LmJvZHkuY2xhc3NMaXN0LnJlbW92ZSgnaW5oZXJpdEN1cnNvcnMnKTtcbiAgICAgICAgZG9jdW1lbnQuYm9keS5zdHlsZS5jdXJzb3IgPSAndW5zZXQnO1xuICAgICAgICB0aGlzLl9pc0dyYWJiaW5nU3ViamVjdC5uZXh0KGZhbHNlKTtcbiAgICB9XG4gICAgXG4gICAgb25EcmFnU3RhcnQoZXZlbnQ6IENka0RyYWdTdGFydCkge1xuICAgICAgICB0aGlzLmNoYW5nZUN1cnNvck9uRHJhZ1N0YXJ0KCk7XG4gICAgfVxuXG4gICAgb25EcmFnRW5kKGV2ZW50OiBDZGtEcmFnRW5kKSB7XG4gICAgICAgIHRoaXMuY2hhbmdlQ3Vyc29yT25EcmFnRW5kKCk7XG4gICAgfVxufVxuIl19
@@ -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==
@@ -14,9 +14,6 @@ export class PaddingSettingsComponent {
14
14
  this.bottomPaddingValue = '0';
15
15
  this._padding = new PepPaddingSettings();
16
16
  this.paddingChange = new EventEmitter();
17
- if (!this.padding.isUniform) {
18
- this.formatPaddingValue();
19
- }
20
17
  }
21
18
  set padding(value) {
22
19
  if (!value) {
@@ -25,6 +22,7 @@ export class PaddingSettingsComponent {
25
22
  else {
26
23
  this._padding = value;
27
24
  }
25
+ this.formatPaddingValue();
28
26
  }
29
27
  get padding() {
30
28
  return this._padding;
@@ -80,13 +78,13 @@ export class PaddingSettingsComponent {
80
78
  }
81
79
  }
82
80
  PaddingSettingsComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.2", ngImport: i0, type: PaddingSettingsComponent, deps: [{ token: i1.TranslateService }], target: i0.ɵɵFactoryTarget.Component });
83
- PaddingSettingsComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.0.2", type: PaddingSettingsComponent, selector: "pep-padding-settings", inputs: { padding: "padding" }, outputs: { paddingChange: "paddingChange" }, ngImport: i0, template: "<div>\n <label class=\"body-xl bold ellipsis title\">{{'PADDING_SETTINGS.TITLE' | translate}}</label>\n <pep-checkbox \n class=\"checkbox-as-sub-title\"\n [label]=\"'PADDING_SETTINGS.UNIFORM' | translate\" \n [renderTitle]=\"false\" \n [value]=\"padding?.isUniform || false\" \n (valueChange)=\"onUniformChanged($event)\">\n </pep-checkbox>\n <div class=\"paddingValueCont\">\n <pep-textbox *ngIf=\"padding?.isUniform\"\n type=\"real\"\n [label]=\"'PADDING_SETTINGS.DESCRIPTION' | translate\" \n [value]=\"padding?.paddingValue || '0'\" \n (valueChange)=\"onPaddingChanged($event, 'uniform')\">\n </pep-textbox>\n <pep-textbox *ngIf=\"!padding?.isUniform\" \n type=\"real\"\n [renderSymbol]=\"false\"\n [label]=\"'PADDING_SETTINGS.TOP' | translate\" \n [value]=\"topPaddingValue || '0'\" \n (valueChange)=\"onPaddingChanged($event, 'top')\">\n </pep-textbox>\n <pep-textbox *ngIf=\"!padding?.isUniform\"\n type=\"real\"\n [renderSymbol]=\"false\"\n [label]=\"'PADDING_SETTINGS.END' | translate\" \n [value]=\"endPaddingValue || '0'\" \n (valueChange)=\"onPaddingChanged($event, 'end')\">\n </pep-textbox>\n <pep-textbox *ngIf=\"!padding?.isUniform\"\n type=\"real\"\n [renderSymbol]=\"false\"\n [label]=\"'PADDING_SETTINGS.BOTTOM' | translate\" \n [value]=\"bottomPaddingValue || '0'\" \n (valueChange)=\"onPaddingChanged($event, 'bottom')\">\n </pep-textbox>\n <pep-textbox *ngIf=\"!padding?.isUniform\"\n type=\"real\"\n [renderSymbol]=\"false\"\n [label]=\"'PADDING_SETTINGS.START' | translate\" \n [value]=\"startPaddingValue || '0'\"\n (valueChange)=\"onPaddingChanged($event, 'start')\">\n </pep-textbox>\n </div>\n</div>", styles: [":host{width:100%;display:grid;gap:var(--pep-spacing-lg, 1rem)}:host label{margin-bottom:0}pep-checkbox ::ng-deep .mat-checkbox-inner-container{width:1.25rem;height:1.25rem}.paddingValueCont{display:grid;column-gap:var(--pep-spacing-sm, .5rem);grid-auto-flow:column}\n"], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i3.PepCheckboxComponent, selector: "pep-checkbox", inputs: ["key", "value", "label", "type", "mandatory", "disabled", "readonly", "xAlignment", "rowSpan", "additionalValue", "form", "isActive", "showTitle", "renderTitle", "layoutType", "visible"], outputs: ["valueChange"] }, { kind: "component", type: i4.PepTextboxComponent, selector: "pep-textbox", inputs: ["key", "value", "minFractionDigits", "maxFractionDigits", "accessory", "label", "placeholder", "type", "mandatory", "disabled", "readonly", "maxFieldCharacters", "hint", "textColor", "xAlignment", "rowSpan", "minValue", "maxValue", "visible", "form", "isActive", "showTitle", "renderTitle", "renderError", "renderSymbol", "layoutType", "parentFieldKey", "regex", "regexError", "isInFocus"], outputs: ["valueChange", "keyup"] }, { kind: "pipe", type: i1.TranslatePipe, name: "translate" }] });
81
+ PaddingSettingsComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.0.2", type: PaddingSettingsComponent, selector: "pep-padding-settings", inputs: { padding: "padding" }, outputs: { paddingChange: "paddingChange" }, ngImport: i0, template: "<div>\n <label class=\"body-xl bold ellipsis title\">{{'PADDING_SETTINGS.TITLE' | translate}}</label>\n <pep-checkbox \n class=\"checkbox-as-sub-title\"\n [label]=\"'PADDING_SETTINGS.UNIFORM' | translate\" \n [renderTitle]=\"false\" \n [value]=\"padding?.isUniform || false\" \n (valueChange)=\"onUniformChanged($event)\">\n </pep-checkbox>\n <div class=\"paddingValueCont\">\n <pep-textbox *ngIf=\"padding?.isUniform\"\n type=\"real\"\n [label]=\"'PADDING_SETTINGS.DESCRIPTION' | translate\" \n [value]=\"padding?.paddingValue || '0'\" \n (valueChange)=\"onPaddingChanged($event, 'uniform')\">\n </pep-textbox>\n <pep-textbox *ngIf=\"!padding?.isUniform\" \n type=\"real\"\n [renderSymbol]=\"false\"\n [label]=\"'PADDING_SETTINGS.TOP' | translate\" \n [value]=\"topPaddingValue || '0'\" \n (valueChange)=\"onPaddingChanged($event, 'top')\">\n </pep-textbox>\n <pep-textbox *ngIf=\"!padding?.isUniform\"\n type=\"real\"\n [renderSymbol]=\"false\"\n [label]=\"'PADDING_SETTINGS.END' | translate\" \n [value]=\"endPaddingValue || '0'\" \n (valueChange)=\"onPaddingChanged($event, 'end')\">\n </pep-textbox>\n <pep-textbox *ngIf=\"!padding?.isUniform\"\n type=\"real\"\n [renderSymbol]=\"false\"\n [label]=\"'PADDING_SETTINGS.BOTTOM' | translate\" \n [value]=\"bottomPaddingValue || '0'\" \n (valueChange)=\"onPaddingChanged($event, 'bottom')\">\n </pep-textbox>\n <pep-textbox *ngIf=\"!padding?.isUniform\"\n type=\"real\"\n [renderSymbol]=\"false\"\n [label]=\"'PADDING_SETTINGS.START' | translate\" \n [value]=\"startPaddingValue || '0'\"\n (valueChange)=\"onPaddingChanged($event, 'start')\">\n </pep-textbox>\n </div>\n</div>", styles: [":host{width:100%;display:grid}:host label{margin-bottom:0}pep-checkbox ::ng-deep .mat-checkbox-inner-container{width:1.25rem;height:1.25rem}.paddingValueCont{display:grid;column-gap:var(--pep-spacing-sm, .5rem);grid-auto-flow:column}.paddingValueCont ::ng-deep .mat-form-field-flex{padding-inline:.5rem}\n"], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i3.PepCheckboxComponent, selector: "pep-checkbox", inputs: ["key", "value", "label", "type", "mandatory", "disabled", "readonly", "xAlignment", "rowSpan", "additionalValue", "form", "isActive", "showTitle", "renderTitle", "layoutType", "visible"], outputs: ["valueChange"] }, { kind: "component", type: i4.PepTextboxComponent, selector: "pep-textbox", inputs: ["key", "value", "minFractionDigits", "maxFractionDigits", "accessory", "label", "placeholder", "type", "mandatory", "disabled", "readonly", "maxFieldCharacters", "hint", "textColor", "xAlignment", "rowSpan", "minValue", "maxValue", "visible", "form", "isActive", "showTitle", "renderTitle", "renderError", "renderSymbol", "layoutType", "parentFieldKey", "regex", "regexError", "isInFocus"], outputs: ["valueChange", "keyup"] }, { kind: "pipe", type: i1.TranslatePipe, name: "translate" }] });
84
82
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.2", ngImport: i0, type: PaddingSettingsComponent, decorators: [{
85
83
  type: Component,
86
- args: [{ selector: 'pep-padding-settings', template: "<div>\n <label class=\"body-xl bold ellipsis title\">{{'PADDING_SETTINGS.TITLE' | translate}}</label>\n <pep-checkbox \n class=\"checkbox-as-sub-title\"\n [label]=\"'PADDING_SETTINGS.UNIFORM' | translate\" \n [renderTitle]=\"false\" \n [value]=\"padding?.isUniform || false\" \n (valueChange)=\"onUniformChanged($event)\">\n </pep-checkbox>\n <div class=\"paddingValueCont\">\n <pep-textbox *ngIf=\"padding?.isUniform\"\n type=\"real\"\n [label]=\"'PADDING_SETTINGS.DESCRIPTION' | translate\" \n [value]=\"padding?.paddingValue || '0'\" \n (valueChange)=\"onPaddingChanged($event, 'uniform')\">\n </pep-textbox>\n <pep-textbox *ngIf=\"!padding?.isUniform\" \n type=\"real\"\n [renderSymbol]=\"false\"\n [label]=\"'PADDING_SETTINGS.TOP' | translate\" \n [value]=\"topPaddingValue || '0'\" \n (valueChange)=\"onPaddingChanged($event, 'top')\">\n </pep-textbox>\n <pep-textbox *ngIf=\"!padding?.isUniform\"\n type=\"real\"\n [renderSymbol]=\"false\"\n [label]=\"'PADDING_SETTINGS.END' | translate\" \n [value]=\"endPaddingValue || '0'\" \n (valueChange)=\"onPaddingChanged($event, 'end')\">\n </pep-textbox>\n <pep-textbox *ngIf=\"!padding?.isUniform\"\n type=\"real\"\n [renderSymbol]=\"false\"\n [label]=\"'PADDING_SETTINGS.BOTTOM' | translate\" \n [value]=\"bottomPaddingValue || '0'\" \n (valueChange)=\"onPaddingChanged($event, 'bottom')\">\n </pep-textbox>\n <pep-textbox *ngIf=\"!padding?.isUniform\"\n type=\"real\"\n [renderSymbol]=\"false\"\n [label]=\"'PADDING_SETTINGS.START' | translate\" \n [value]=\"startPaddingValue || '0'\"\n (valueChange)=\"onPaddingChanged($event, 'start')\">\n </pep-textbox>\n </div>\n</div>", styles: [":host{width:100%;display:grid;gap:var(--pep-spacing-lg, 1rem)}:host label{margin-bottom:0}pep-checkbox ::ng-deep .mat-checkbox-inner-container{width:1.25rem;height:1.25rem}.paddingValueCont{display:grid;column-gap:var(--pep-spacing-sm, .5rem);grid-auto-flow:column}\n"] }]
84
+ args: [{ selector: 'pep-padding-settings', template: "<div>\n <label class=\"body-xl bold ellipsis title\">{{'PADDING_SETTINGS.TITLE' | translate}}</label>\n <pep-checkbox \n class=\"checkbox-as-sub-title\"\n [label]=\"'PADDING_SETTINGS.UNIFORM' | translate\" \n [renderTitle]=\"false\" \n [value]=\"padding?.isUniform || false\" \n (valueChange)=\"onUniformChanged($event)\">\n </pep-checkbox>\n <div class=\"paddingValueCont\">\n <pep-textbox *ngIf=\"padding?.isUniform\"\n type=\"real\"\n [label]=\"'PADDING_SETTINGS.DESCRIPTION' | translate\" \n [value]=\"padding?.paddingValue || '0'\" \n (valueChange)=\"onPaddingChanged($event, 'uniform')\">\n </pep-textbox>\n <pep-textbox *ngIf=\"!padding?.isUniform\" \n type=\"real\"\n [renderSymbol]=\"false\"\n [label]=\"'PADDING_SETTINGS.TOP' | translate\" \n [value]=\"topPaddingValue || '0'\" \n (valueChange)=\"onPaddingChanged($event, 'top')\">\n </pep-textbox>\n <pep-textbox *ngIf=\"!padding?.isUniform\"\n type=\"real\"\n [renderSymbol]=\"false\"\n [label]=\"'PADDING_SETTINGS.END' | translate\" \n [value]=\"endPaddingValue || '0'\" \n (valueChange)=\"onPaddingChanged($event, 'end')\">\n </pep-textbox>\n <pep-textbox *ngIf=\"!padding?.isUniform\"\n type=\"real\"\n [renderSymbol]=\"false\"\n [label]=\"'PADDING_SETTINGS.BOTTOM' | translate\" \n [value]=\"bottomPaddingValue || '0'\" \n (valueChange)=\"onPaddingChanged($event, 'bottom')\">\n </pep-textbox>\n <pep-textbox *ngIf=\"!padding?.isUniform\"\n type=\"real\"\n [renderSymbol]=\"false\"\n [label]=\"'PADDING_SETTINGS.START' | translate\" \n [value]=\"startPaddingValue || '0'\"\n (valueChange)=\"onPaddingChanged($event, 'start')\">\n </pep-textbox>\n </div>\n</div>", styles: [":host{width:100%;display:grid}:host label{margin-bottom:0}pep-checkbox ::ng-deep .mat-checkbox-inner-container{width:1.25rem;height:1.25rem}.paddingValueCont{display:grid;column-gap:var(--pep-spacing-sm, .5rem);grid-auto-flow:column}.paddingValueCont ::ng-deep .mat-form-field-flex{padding-inline:.5rem}\n"] }]
87
85
  }], ctorParameters: function () { return [{ type: i1.TranslateService }]; }, propDecorators: { padding: [{
88
86
  type: Input
89
87
  }], paddingChange: [{
90
88
  type: Output
91
89
  }] } });
92
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"padding-settings.component.js","sourceRoot":"","sources":["../../../../projects/ngx-composite-lib/padding-settings/padding-settings.component.ts","../../../../projects/ngx-composite-lib/padding-settings/padding-settings.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, Output } from '@angular/core';\nimport { TranslateService } from '@ngx-translate/core';\nimport { PepPaddingSettings } from './padding-settings.model';\n\n@Component({\n    selector: 'pep-padding-settings',\n    templateUrl: './padding-settings.component.html',\n    styleUrls: ['./padding-settings.component.scss']\n})\n\nexport class PaddingSettingsComponent  {\n\n    public startPaddingValue = '0';\n    public endPaddingValue = '0';\n    public topPaddingValue = '0';\n    public bottomPaddingValue = '0';\n\n    private _padding: PepPaddingSettings = new PepPaddingSettings();\n    @Input()\n    set padding(value: PepPaddingSettings) {\n        if (!value) {\n            this._padding = new PepPaddingSettings();\n        } else {\n            this._padding = value;\n        }\n    }\n    get padding(): PepPaddingSettings {\n        return this._padding;\n    }\n\n    @Output()\n    paddingChange: EventEmitter<PepPaddingSettings> = new EventEmitter<PepPaddingSettings>();\n\n    constructor(\n        private translate: TranslateService,\n    ) {\n        if(!this.padding.isUniform){\n            this.formatPaddingValue();\n        }\n    }\n\n    private raisePaddingChange() {\n        this.paddingChange.emit(this.padding);\n    }\n\n    onUniformChanged(value: boolean) {\n        this.padding.isUniform = value;\n        this.formatPaddingValue();\n        this.raisePaddingChange();\n    }\n\n    formatPaddingValue() {\n        if(this.padding.isUniform){ \n            this.padding.paddingValue = this.padding.paddingValue.split(',')[0];\n         } \n         else{\n            if(isNaN(Number(this.padding.paddingValue))){\n                const num = this.padding.paddingValue.split(',') || ['0','0','0','0'];\n                this.topPaddingValue = num[0];\n                this.endPaddingValue = num[1];\n                this.bottomPaddingValue = num[2];\n                this.startPaddingValue = num[3];\n            }\n            else{\n                this.topPaddingValue = this.endPaddingValue = this.bottomPaddingValue = this.startPaddingValue = this.padding.paddingValue;\n            }\n            \n            this.padding.paddingValue = `${this.topPaddingValue},${this.endPaddingValue},${this.bottomPaddingValue},${this.startPaddingValue}`;\n         } \n    }\n\n    onPaddingChanged(value: any, uniformPos: string) {\n        if(!this.padding.isUniform){\n            switch(uniformPos){\n                case 'top':\n                    this.topPaddingValue = value;\n                    break;\n                case 'end':\n                    this.endPaddingValue = value;\n                    break;\n                case 'bottom':\n                    this.bottomPaddingValue = value;\n                    break;\n                case 'start':\n                    this.startPaddingValue = value;\n                    break;\n            }\n           this.padding.paddingValue = `${this.topPaddingValue},${this.endPaddingValue},${this.bottomPaddingValue},${this.startPaddingValue}`;\n        }\n        else{\n            this.padding.paddingValue = `${value}`;\n        }\n        this.raisePaddingChange();\n    }\n}\n","<div>\n    <label class=\"body-xl bold ellipsis title\">{{'PADDING_SETTINGS.TITLE' | translate}}</label>\n    <pep-checkbox \n        class=\"checkbox-as-sub-title\"\n        [label]=\"'PADDING_SETTINGS.UNIFORM' | translate\" \n        [renderTitle]=\"false\" \n        [value]=\"padding?.isUniform || false\" \n        (valueChange)=\"onUniformChanged($event)\">\n    </pep-checkbox>\n    <div class=\"paddingValueCont\">\n        <pep-textbox *ngIf=\"padding?.isUniform\"\n            type=\"real\"\n            [label]=\"'PADDING_SETTINGS.DESCRIPTION' | translate\" \n            [value]=\"padding?.paddingValue || '0'\" \n            (valueChange)=\"onPaddingChanged($event, 'uniform')\">\n        </pep-textbox>\n        <pep-textbox *ngIf=\"!padding?.isUniform\" \n            type=\"real\"\n            [renderSymbol]=\"false\"\n            [label]=\"'PADDING_SETTINGS.TOP' | translate\" \n            [value]=\"topPaddingValue || '0'\" \n            (valueChange)=\"onPaddingChanged($event, 'top')\">\n        </pep-textbox>\n        <pep-textbox *ngIf=\"!padding?.isUniform\"\n            type=\"real\"\n            [renderSymbol]=\"false\"\n            [label]=\"'PADDING_SETTINGS.END' | translate\" \n            [value]=\"endPaddingValue || '0'\" \n            (valueChange)=\"onPaddingChanged($event, 'end')\">\n        </pep-textbox>\n        <pep-textbox *ngIf=\"!padding?.isUniform\"\n            type=\"real\"\n            [renderSymbol]=\"false\"\n            [label]=\"'PADDING_SETTINGS.BOTTOM' | translate\" \n            [value]=\"bottomPaddingValue || '0'\" \n            (valueChange)=\"onPaddingChanged($event, 'bottom')\">\n        </pep-textbox>\n        <pep-textbox *ngIf=\"!padding?.isUniform\"\n            type=\"real\"\n            [renderSymbol]=\"false\"\n            [label]=\"'PADDING_SETTINGS.START' | translate\" \n            [value]=\"startPaddingValue || '0'\"\n            (valueChange)=\"onPaddingChanged($event, 'start')\">\n        </pep-textbox>\n    </div>\n</div>"]}
90
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"padding-settings.component.js","sourceRoot":"","sources":["../../../../projects/ngx-composite-lib/padding-settings/padding-settings.component.ts","../../../../projects/ngx-composite-lib/padding-settings/padding-settings.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, Output } from '@angular/core';\nimport { TranslateService } from '@ngx-translate/core';\nimport { PepPaddingSettings } from './padding-settings.model';\n\n@Component({\n    selector: 'pep-padding-settings',\n    templateUrl: './padding-settings.component.html',\n    styleUrls: ['./padding-settings.component.scss']\n})\n\nexport class PaddingSettingsComponent  {\n\n    public startPaddingValue = '0';\n    public endPaddingValue = '0';\n    public topPaddingValue = '0';\n    public bottomPaddingValue = '0';\n\n    private _padding: PepPaddingSettings = new PepPaddingSettings();\n    @Input()\n    set padding(value: PepPaddingSettings) {\n        if (!value) {\n            this._padding = new PepPaddingSettings();\n        } else {\n            this._padding = value;\n        }\n        this.formatPaddingValue();\n    }\n    get padding(): PepPaddingSettings {\n        return this._padding;\n    }\n\n    @Output()\n    paddingChange: EventEmitter<PepPaddingSettings> = new EventEmitter<PepPaddingSettings>();\n\n    constructor(\n        private translate: TranslateService,\n    ) {\n       \n    }\n\n    private raisePaddingChange() {\n        this.paddingChange.emit(this.padding);\n    }\n\n    onUniformChanged(value: boolean) {\n        this.padding.isUniform = value;\n        this.formatPaddingValue();\n        this.raisePaddingChange();\n    }\n\n    formatPaddingValue() {\n        if(this.padding.isUniform){ \n            this.padding.paddingValue = this.padding.paddingValue.split(',')[0];\n         } \n         else{\n            if(isNaN(Number(this.padding.paddingValue))){\n                const num = this.padding.paddingValue.split(',') || ['0','0','0','0'];\n                this.topPaddingValue = num[0];\n                this.endPaddingValue = num[1];\n                this.bottomPaddingValue = num[2];\n                this.startPaddingValue = num[3];\n            }\n            else{\n                this.topPaddingValue = this.endPaddingValue = this.bottomPaddingValue = this.startPaddingValue = this.padding.paddingValue;\n            }\n            \n            this.padding.paddingValue = `${this.topPaddingValue},${this.endPaddingValue},${this.bottomPaddingValue},${this.startPaddingValue}`;\n         } \n    }\n\n    onPaddingChanged(value: any, uniformPos: string) {\n        if(!this.padding.isUniform){\n            switch(uniformPos){\n                case 'top':\n                    this.topPaddingValue = value;\n                    break;\n                case 'end':\n                    this.endPaddingValue = value;\n                    break;\n                case 'bottom':\n                    this.bottomPaddingValue = value;\n                    break;\n                case 'start':\n                    this.startPaddingValue = value;\n                    break;\n            }\n           this.padding.paddingValue = `${this.topPaddingValue},${this.endPaddingValue},${this.bottomPaddingValue},${this.startPaddingValue}`;\n        }\n        else{\n            this.padding.paddingValue = `${value}`;\n        }\n        this.raisePaddingChange();\n    }\n}\n","<div>\n    <label class=\"body-xl bold ellipsis title\">{{'PADDING_SETTINGS.TITLE' | translate}}</label>\n    <pep-checkbox \n        class=\"checkbox-as-sub-title\"\n        [label]=\"'PADDING_SETTINGS.UNIFORM' | translate\" \n        [renderTitle]=\"false\" \n        [value]=\"padding?.isUniform || false\" \n        (valueChange)=\"onUniformChanged($event)\">\n    </pep-checkbox>\n    <div class=\"paddingValueCont\">\n        <pep-textbox *ngIf=\"padding?.isUniform\"\n            type=\"real\"\n            [label]=\"'PADDING_SETTINGS.DESCRIPTION' | translate\" \n            [value]=\"padding?.paddingValue || '0'\" \n            (valueChange)=\"onPaddingChanged($event, 'uniform')\">\n        </pep-textbox>\n        <pep-textbox *ngIf=\"!padding?.isUniform\" \n            type=\"real\"\n            [renderSymbol]=\"false\"\n            [label]=\"'PADDING_SETTINGS.TOP' | translate\" \n            [value]=\"topPaddingValue || '0'\" \n            (valueChange)=\"onPaddingChanged($event, 'top')\">\n        </pep-textbox>\n        <pep-textbox *ngIf=\"!padding?.isUniform\"\n            type=\"real\"\n            [renderSymbol]=\"false\"\n            [label]=\"'PADDING_SETTINGS.END' | translate\" \n            [value]=\"endPaddingValue || '0'\" \n            (valueChange)=\"onPaddingChanged($event, 'end')\">\n        </pep-textbox>\n        <pep-textbox *ngIf=\"!padding?.isUniform\"\n            type=\"real\"\n            [renderSymbol]=\"false\"\n            [label]=\"'PADDING_SETTINGS.BOTTOM' | translate\" \n            [value]=\"bottomPaddingValue || '0'\" \n            (valueChange)=\"onPaddingChanged($event, 'bottom')\">\n        </pep-textbox>\n        <pep-textbox *ngIf=\"!padding?.isUniform\"\n            type=\"real\"\n            [renderSymbol]=\"false\"\n            [label]=\"'PADDING_SETTINGS.START' | translate\" \n            [value]=\"startPaddingValue || '0'\"\n            (valueChange)=\"onPaddingChanged($event, 'start')\">\n        </pep-textbox>\n    </div>\n</div>"]}