@pepperi-addons/ngx-composite-lib 0.0.16-loader.8 → 0.4.0-angular14.3
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 +25 -25
- package/color-settings/color-settings.model.d.ts +5 -5
- package/color-settings/color-settings.module.d.ts +12 -12
- package/color-settings/{pepperi-addons-ngx-composite-lib-color-settings.d.ts → index.d.ts} +5 -5
- package/color-settings/public-api.d.ts +3 -3
- package/core/common/directives/index.d.ts +1 -1
- package/core/common/directives/public-api.d.ts +1 -1
- package/core/common/directives/reset-configuration-field.directive.d.ts +39 -39
- package/core/common/index.d.ts +1 -1
- package/core/common/public-api.d.ts +2 -2
- package/core/common/services/dimx.service.d.ts +32 -32
- package/core/common/services/index.d.ts +1 -1
- package/core/common/services/public-api.d.ts +2 -2
- package/core/common/services/utilities.service.d.ts +6 -6
- package/core/index.d.ts +1 -1
- package/core/public-api.d.ts +1 -1
- package/data-view-builder/data-view-builder.component.d.ts +35 -35
- package/data-view-builder/data-view-builder.model.d.ts +1 -1
- package/data-view-builder/data-view-builder.module.d.ts +23 -23
- package/data-view-builder/data-view-builder.service.d.ts +14 -14
- package/data-view-builder/{pepperi-addons-ngx-composite-lib-data-view-builder.d.ts → index.d.ts} +5 -5
- package/data-view-builder/menu-data-view/menu-data-view.component.d.ts +36 -36
- package/data-view-builder/public-api.d.ts +3 -3
- package/{esm2015/color-settings/color-settings.component.js → esm2020/color-settings/color-settings.component.mjs} +87 -91
- package/{esm2015/color-settings/color-settings.model.js → esm2020/color-settings/color-settings.model.mjs} +8 -8
- package/{esm2015/color-settings/color-settings.module.js → esm2020/color-settings/color-settings.module.mjs} +38 -40
- package/{esm2015/color-settings/pepperi-addons-ngx-composite-lib-color-settings.js → esm2020/color-settings/pepperi-addons-ngx-composite-lib-color-settings.mjs} +4 -4
- package/{esm2015/color-settings/public-api.js → esm2020/color-settings/public-api.mjs} +6 -6
- package/{esm2015/core/common/directives/index.js → esm2020/core/common/directives/index.mjs} +4 -4
- package/{esm2015/core/common/directives/public-api.js → esm2020/core/common/directives/public-api.mjs} +4 -4
- package/esm2020/core/common/directives/reset-configuration-field.directive.mjs +153 -0
- package/{esm2015/core/common/index.js → esm2020/core/common/index.mjs} +4 -4
- package/{esm2015/core/common/public-api.js → esm2020/core/common/public-api.mjs} +5 -5
- package/esm2020/core/common/services/dimx.service.mjs +48 -0
- package/{esm2015/core/common/services/index.js → esm2020/core/common/services/index.mjs} +4 -4
- package/{esm2015/core/common/services/public-api.js → esm2020/core/common/services/public-api.mjs} +5 -5
- package/{esm2015/core/common/services/utilities.service.js → esm2020/core/common/services/utilities.service.mjs} +18 -18
- package/{esm2015/core/index.js → esm2020/core/index.mjs} +4 -4
- package/{esm2015/core/public-api.js → esm2020/core/public-api.mjs} +4 -4
- package/esm2020/data-view-builder/data-view-builder.component.mjs +117 -0
- package/{esm2015/data-view-builder/data-view-builder.model.js → esm2020/data-view-builder/data-view-builder.model.mjs} +1 -1
- package/{esm2015/data-view-builder/data-view-builder.module.js → esm2020/data-view-builder/data-view-builder.module.mjs} +80 -82
- package/{esm2015/data-view-builder/data-view-builder.service.js → esm2020/data-view-builder/data-view-builder.service.mjs} +38 -38
- package/esm2020/data-view-builder/menu-data-view/menu-data-view.component.mjs +117 -0
- package/{esm2015/data-view-builder/pepperi-addons-ngx-composite-lib-data-view-builder.js → esm2020/data-view-builder/pepperi-addons-ngx-composite-lib-data-view-builder.mjs} +4 -4
- package/{esm2015/data-view-builder/public-api.js → esm2020/data-view-builder/public-api.mjs} +6 -6
- package/esm2020/file-status-panel/file-status-panel.component.mjs +35 -0
- package/{esm2015/file-status-panel/file-status-panel.model.js → esm2020/file-status-panel/file-status-panel.model.mjs} +8 -8
- package/{esm2015/file-status-panel/file-status-panel.module.js → esm2020/file-status-panel/file-status-panel.module.mjs} +54 -56
- package/{esm2015/file-status-panel/pepperi-addons-ngx-composite-lib-file-status-panel.js → esm2020/file-status-panel/pepperi-addons-ngx-composite-lib-file-status-panel.mjs} +4 -4
- package/{esm2015/file-status-panel/public-api.js → esm2020/file-status-panel/public-api.mjs} +6 -6
- package/esm2020/generic-form/generic-form.component.mjs +184 -0
- package/{esm2015/generic-form/generic-form.model.js → esm2020/generic-form/generic-form.model.mjs} +1 -1
- package/{esm2015/generic-form/generic-form.module.js → esm2020/generic-form/generic-form.module.mjs} +68 -74
- package/{esm2015/generic-form/generic-form.service.js → esm2020/generic-form/generic-form.service.mjs} +67 -67
- package/{esm2015/generic-form/pepperi-addons-ngx-composite-lib-generic-form.js → esm2020/generic-form/pepperi-addons-ngx-composite-lib-generic-form.mjs} +4 -4
- package/{esm2015/generic-form/public-api.js → esm2020/generic-form/public-api.mjs} +7 -7
- package/esm2020/generic-list/generic-list.component.mjs +425 -0
- package/{esm2015/generic-list/generic-list.model.js → esm2020/generic-list/generic-list.model.mjs} +1 -1
- package/{esm2015/generic-list/generic-list.module.js → esm2020/generic-list/generic-list.module.mjs} +70 -72
- package/esm2020/generic-list/generic-list.service.mjs +125 -0
- package/{esm2015/generic-list/pepperi-addons-ngx-composite-lib-generic-list.js → esm2020/generic-list/pepperi-addons-ngx-composite-lib-generic-list.mjs} +4 -4
- package/{esm2015/generic-list/public-api.js → esm2020/generic-list/public-api.mjs} +7 -7
- package/esm2020/group-buttons-settings/group-buttons-settings.component.mjs +130 -0
- package/{esm2015/group-buttons-settings/group-buttons-settings.model.js → esm2020/group-buttons-settings/group-buttons-settings.model.mjs} +1 -1
- package/{esm2015/group-buttons-settings/group-buttons-settings.module.js → esm2020/group-buttons-settings/group-buttons-settings.module.mjs} +48 -50
- package/{esm2015/group-buttons-settings/pepperi-addons-ngx-composite-lib-group-buttons-settings.js → esm2020/group-buttons-settings/pepperi-addons-ngx-composite-lib-group-buttons-settings.mjs} +4 -4
- package/{esm2015/group-buttons-settings/public-api.js → esm2020/group-buttons-settings/public-api.mjs} +6 -6
- package/{esm2015/ngx-composite-lib.module.js → esm2020/ngx-composite-lib.module.mjs} +54 -56
- package/{esm2015/pepperi-addons-ngx-composite-lib.js → esm2020/pepperi-addons-ngx-composite-lib.mjs} +4 -4
- package/{esm2015/public-api.js → esm2020/public-api.mjs} +5 -5
- package/{esm2015/shadow-settings/pepperi-addons-ngx-composite-lib-shadow-settings.js → esm2020/shadow-settings/pepperi-addons-ngx-composite-lib-shadow-settings.mjs} +4 -4
- package/{esm2015/shadow-settings/public-api.js → esm2020/shadow-settings/public-api.mjs} +6 -6
- package/{esm2015/shadow-settings/shadow-settings.component.js → esm2020/shadow-settings/shadow-settings.component.mjs} +69 -73
- package/{esm2015/shadow-settings/shadow-settings.model.js → esm2020/shadow-settings/shadow-settings.model.mjs} +7 -7
- package/{esm2015/shadow-settings/shadow-settings.module.js → esm2020/shadow-settings/shadow-settings.module.mjs} +42 -44
- package/fesm2015/{pepperi-addons-ngx-composite-lib-color-settings.js → pepperi-addons-ngx-composite-lib-color-settings.mjs} +117 -123
- package/fesm2015/pepperi-addons-ngx-composite-lib-color-settings.mjs.map +1 -0
- package/fesm2015/pepperi-addons-ngx-composite-lib-data-view-builder.mjs +350 -0
- package/fesm2015/pepperi-addons-ngx-composite-lib-data-view-builder.mjs.map +1 -0
- package/fesm2015/pepperi-addons-ngx-composite-lib-file-status-panel.mjs +107 -0
- package/fesm2015/pepperi-addons-ngx-composite-lib-file-status-panel.mjs.map +1 -0
- package/fesm2015/{pepperi-addons-ngx-composite-lib-generic-form.js → pepperi-addons-ngx-composite-lib-generic-form.mjs} +295 -305
- package/fesm2015/pepperi-addons-ngx-composite-lib-generic-form.mjs.map +1 -0
- package/fesm2015/{pepperi-addons-ngx-composite-lib-generic-list.js → pepperi-addons-ngx-composite-lib-generic-list.mjs} +605 -609
- package/fesm2015/pepperi-addons-ngx-composite-lib-generic-list.mjs.map +1 -0
- package/fesm2015/{pepperi-addons-ngx-composite-lib-group-buttons-settings.js → pepperi-addons-ngx-composite-lib-group-buttons-settings.mjs} +168 -174
- package/fesm2015/pepperi-addons-ngx-composite-lib-group-buttons-settings.mjs.map +1 -0
- package/fesm2015/{pepperi-addons-ngx-composite-lib-shadow-settings.js → pepperi-addons-ngx-composite-lib-shadow-settings.mjs} +102 -108
- package/fesm2015/pepperi-addons-ngx-composite-lib-shadow-settings.mjs.map +1 -0
- package/fesm2015/{pepperi-addons-ngx-composite-lib.js → pepperi-addons-ngx-composite-lib.mjs} +254 -256
- package/fesm2015/pepperi-addons-ngx-composite-lib.mjs.map +1 -0
- package/fesm2020/pepperi-addons-ngx-composite-lib-color-settings.mjs +141 -0
- package/fesm2020/pepperi-addons-ngx-composite-lib-color-settings.mjs.map +1 -0
- package/fesm2020/pepperi-addons-ngx-composite-lib-data-view-builder.mjs +348 -0
- package/fesm2020/pepperi-addons-ngx-composite-lib-data-view-builder.mjs.map +1 -0
- package/{fesm2015/pepperi-addons-ngx-composite-lib-file-status-panel.js → fesm2020/pepperi-addons-ngx-composite-lib-file-status-panel.mjs} +82 -88
- package/fesm2020/pepperi-addons-ngx-composite-lib-file-status-panel.mjs.map +1 -0
- package/fesm2020/pepperi-addons-ngx-composite-lib-generic-form.mjs +315 -0
- package/fesm2020/pepperi-addons-ngx-composite-lib-generic-form.mjs.map +1 -0
- package/fesm2020/pepperi-addons-ngx-composite-lib-generic-list.mjs +619 -0
- package/fesm2020/pepperi-addons-ngx-composite-lib-generic-list.mjs.map +1 -0
- package/fesm2020/pepperi-addons-ngx-composite-lib-group-buttons-settings.mjs +186 -0
- package/fesm2020/pepperi-addons-ngx-composite-lib-group-buttons-settings.mjs.map +1 -0
- package/fesm2020/pepperi-addons-ngx-composite-lib-shadow-settings.mjs +126 -0
- package/fesm2020/pepperi-addons-ngx-composite-lib-shadow-settings.mjs.map +1 -0
- package/fesm2020/pepperi-addons-ngx-composite-lib.mjs +304 -0
- package/fesm2020/pepperi-addons-ngx-composite-lib.mjs.map +1 -0
- package/file-status-panel/file-status-panel.component.d.ts +14 -14
- package/file-status-panel/file-status-panel.model.d.ts +7 -7
- package/file-status-panel/file-status-panel.module.d.ts +17 -17
- package/file-status-panel/{pepperi-addons-ngx-composite-lib-file-status-panel.d.ts → index.d.ts} +5 -5
- package/file-status-panel/public-api.d.ts +3 -3
- package/generic-form/generic-form.component.d.ts +46 -46
- package/generic-form/generic-form.model.d.ts +34 -34
- package/generic-form/generic-form.module.d.ts +13 -13
- package/generic-form/generic-form.service.d.ts +16 -16
- package/generic-form/index.d.ts +5 -1
- package/generic-form/public-api.d.ts +4 -4
- package/generic-list/generic-list.component.d.ts +101 -101
- package/generic-list/generic-list.model.d.ts +54 -54
- package/generic-list/generic-list.module.d.ts +18 -18
- package/generic-list/generic-list.service.d.ts +43 -43
- package/generic-list/{pepperi-addons-ngx-composite-lib-generic-list.d.ts → index.d.ts} +5 -5
- package/generic-list/public-api.d.ts +4 -4
- package/group-buttons-settings/group-buttons-settings.component.d.ts +33 -33
- package/group-buttons-settings/group-buttons-settings.model.d.ts +1 -1
- package/group-buttons-settings/group-buttons-settings.module.d.ts +15 -15
- package/group-buttons-settings/{pepperi-addons-ngx-composite-lib-group-buttons-settings.d.ts → index.d.ts} +5 -5
- package/group-buttons-settings/public-api.d.ts +3 -3
- package/{pepperi-addons-ngx-composite-lib.d.ts → index.d.ts} +5 -5
- package/ngx-composite-lib.module.d.ts +13 -13
- package/package.json +89 -19
- package/public-api.d.ts +2 -2
- package/shadow-settings/{pepperi-addons-ngx-composite-lib-shadow-settings.d.ts → index.d.ts} +5 -5
- package/shadow-settings/public-api.d.ts +3 -3
- package/shadow-settings/shadow-settings.component.d.ts +23 -23
- package/shadow-settings/shadow-settings.model.d.ts +7 -7
- package/shadow-settings/shadow-settings.module.d.ts +13 -13
- package/src/core/style/components/data-view-builder.scss +3 -3
- package/styling.scss +1 -1
- package/bundles/pepperi-addons-ngx-composite-lib-color-settings.umd.js +0 -181
- package/bundles/pepperi-addons-ngx-composite-lib-color-settings.umd.js.map +0 -1
- package/bundles/pepperi-addons-ngx-composite-lib-data-view-builder.umd.js +0 -393
- package/bundles/pepperi-addons-ngx-composite-lib-data-view-builder.umd.js.map +0 -1
- package/bundles/pepperi-addons-ngx-composite-lib-file-status-panel.umd.js +0 -137
- package/bundles/pepperi-addons-ngx-composite-lib-file-status-panel.umd.js.map +0 -1
- package/bundles/pepperi-addons-ngx-composite-lib-generic-form.umd.js +0 -697
- package/bundles/pepperi-addons-ngx-composite-lib-generic-form.umd.js.map +0 -1
- package/bundles/pepperi-addons-ngx-composite-lib-generic-list.umd.js +0 -1060
- package/bundles/pepperi-addons-ngx-composite-lib-generic-list.umd.js.map +0 -1
- package/bundles/pepperi-addons-ngx-composite-lib-group-buttons-settings.umd.js +0 -225
- package/bundles/pepperi-addons-ngx-composite-lib-group-buttons-settings.umd.js.map +0 -1
- package/bundles/pepperi-addons-ngx-composite-lib-shadow-settings.umd.js +0 -165
- package/bundles/pepperi-addons-ngx-composite-lib-shadow-settings.umd.js.map +0 -1
- package/bundles/pepperi-addons-ngx-composite-lib.umd.js +0 -666
- package/bundles/pepperi-addons-ngx-composite-lib.umd.js.map +0 -1
- package/color-settings/package.json +0 -10
- package/data-view-builder/package.json +0 -10
- package/esm2015/core/common/directives/reset-configuration-field.directive.js +0 -157
- package/esm2015/core/common/services/dimx.service.js +0 -50
- package/esm2015/data-view-builder/data-view-builder.component.js +0 -122
- package/esm2015/data-view-builder/menu-data-view/menu-data-view.component.js +0 -122
- package/esm2015/file-status-panel/file-status-panel.component.js +0 -39
- package/esm2015/generic-form/generic-form.component.js +0 -190
- package/esm2015/generic-form/index.js +0 -5
- package/esm2015/generic-list/generic-list.component.js +0 -443
- package/esm2015/generic-list/generic-list.service.js +0 -127
- package/esm2015/group-buttons-settings/group-buttons-settings.component.js +0 -135
- package/fesm2015/pepperi-addons-ngx-composite-lib-color-settings.js.map +0 -1
- package/fesm2015/pepperi-addons-ngx-composite-lib-data-view-builder.js +0 -360
- package/fesm2015/pepperi-addons-ngx-composite-lib-data-view-builder.js.map +0 -1
- package/fesm2015/pepperi-addons-ngx-composite-lib-file-status-panel.js.map +0 -1
- package/fesm2015/pepperi-addons-ngx-composite-lib-generic-form.js.map +0 -1
- package/fesm2015/pepperi-addons-ngx-composite-lib-generic-list.js.map +0 -1
- package/fesm2015/pepperi-addons-ngx-composite-lib-group-buttons-settings.js.map +0 -1
- package/fesm2015/pepperi-addons-ngx-composite-lib-shadow-settings.js.map +0 -1
- package/fesm2015/pepperi-addons-ngx-composite-lib.js.map +0 -1
- package/file-status-panel/package.json +0 -10
- package/generic-form/package.json +0 -10
- package/generic-form/pepperi-addons-ngx-composite-lib-generic-form.d.ts +0 -5
- package/generic-list/package.json +0 -13
- package/group-buttons-settings/package.json +0 -10
- package/shadow-settings/package.json +0 -10
|
@@ -1,122 +0,0 @@
|
|
|
1
|
-
import { moveItemInArray } from '@angular/cdk/drag-drop';
|
|
2
|
-
import { Component, EventEmitter, Input, Output, TemplateRef, ViewChild } from '@angular/core';
|
|
3
|
-
import * as i0 from "@angular/core";
|
|
4
|
-
import * as i1 from "@pepperi-addons/ngx-lib/dialog";
|
|
5
|
-
import * as i2 from "../data-view-builder.service";
|
|
6
|
-
import * as i3 from "@angular/material/icon";
|
|
7
|
-
import * as i4 from "@pepperi-addons/ngx-lib/icon";
|
|
8
|
-
import * as i5 from "@pepperi-addons/ngx-lib/button";
|
|
9
|
-
import * as i6 from "@pepperi-addons/ngx-lib/textbox";
|
|
10
|
-
import * as i7 from "@angular/common";
|
|
11
|
-
import * as i8 from "@angular/cdk/drag-drop";
|
|
12
|
-
import * as i9 from "@ngx-translate/core";
|
|
13
|
-
export class MenuDataViewComponent {
|
|
14
|
-
constructor(dialogService, dataViewBuilderService) {
|
|
15
|
-
this.dialogService = dialogService;
|
|
16
|
-
this.dataViewBuilderService = dataViewBuilderService;
|
|
17
|
-
this.fields = []; // The data view fields.
|
|
18
|
-
this.availableFieldsTitles = new Map(); // <FieldID, Original Title> from the available fields.
|
|
19
|
-
this.emptyDropAreaId = '';
|
|
20
|
-
this.mappedFieldsId = '';
|
|
21
|
-
this.fieldsChange = new EventEmitter();
|
|
22
|
-
this.isGrabbing = false;
|
|
23
|
-
this.dialogRef = null;
|
|
24
|
-
this.dataViewBuilderService.isGrabbingChange$.subscribe((value) => {
|
|
25
|
-
this.isGrabbing = value;
|
|
26
|
-
});
|
|
27
|
-
}
|
|
28
|
-
addNewField(draggableItem, index) {
|
|
29
|
-
// Add new menuField to the mappedFields.
|
|
30
|
-
const menuField = { FieldID: draggableItem.data.key, Title: draggableItem.title };
|
|
31
|
-
this.spliceMappedFields(index, 0, menuField);
|
|
32
|
-
}
|
|
33
|
-
spliceMappedFields(start, deleteCount, item) {
|
|
34
|
-
if (item) {
|
|
35
|
-
this.fields.splice(start, deleteCount, item);
|
|
36
|
-
}
|
|
37
|
-
else {
|
|
38
|
-
this.fields.splice(start, deleteCount);
|
|
39
|
-
}
|
|
40
|
-
this.notifyFieldsChange();
|
|
41
|
-
}
|
|
42
|
-
changeTitle(menuField, title) {
|
|
43
|
-
menuField.Title = title;
|
|
44
|
-
this.notifyFieldsChange();
|
|
45
|
-
}
|
|
46
|
-
notifyFieldsChange() {
|
|
47
|
-
this.fieldsChange.emit(this.fields);
|
|
48
|
-
}
|
|
49
|
-
ngOnInit() {
|
|
50
|
-
//
|
|
51
|
-
}
|
|
52
|
-
addSeparator(index) {
|
|
53
|
-
const menuField = { FieldID: '', Title: '' };
|
|
54
|
-
this.spliceMappedFields(index, 0, menuField);
|
|
55
|
-
}
|
|
56
|
-
onDragStart(event) {
|
|
57
|
-
this.dataViewBuilderService.onDragStart(event);
|
|
58
|
-
}
|
|
59
|
-
onDragEnd(event) {
|
|
60
|
-
this.dataViewBuilderService.onDragEnd(event);
|
|
61
|
-
}
|
|
62
|
-
onDropField(event) {
|
|
63
|
-
if (event.previousContainer === event.container) {
|
|
64
|
-
moveItemInArray(event.container.data, event.previousIndex, event.currentIndex);
|
|
65
|
-
this.notifyFieldsChange();
|
|
66
|
-
}
|
|
67
|
-
else if (event.container.id === 'emptyDropArea') {
|
|
68
|
-
this.addNewField(event.previousContainer.data[event.previousIndex], this.fields.length);
|
|
69
|
-
}
|
|
70
|
-
else {
|
|
71
|
-
this.addNewField(event.previousContainer.data[event.previousIndex], event.currentIndex);
|
|
72
|
-
}
|
|
73
|
-
}
|
|
74
|
-
onTitleChanged(event, menuField) {
|
|
75
|
-
this.changeTitle(menuField, event);
|
|
76
|
-
}
|
|
77
|
-
onDeleteMappedField(event, menuField) {
|
|
78
|
-
const index = this.fields.findIndex(ms => ms === menuField);
|
|
79
|
-
if (index > -1) {
|
|
80
|
-
this.spliceMappedFields(index, 1);
|
|
81
|
-
}
|
|
82
|
-
}
|
|
83
|
-
onEditSeparatorField(event, menuField) {
|
|
84
|
-
this.dialogRef = this.dialogService.openDialog(this.separatorTitleModalTemplate, { value: menuField.Title });
|
|
85
|
-
this.dialogRef.afterClosed().subscribe((titleValue) => {
|
|
86
|
-
if (titleValue !== undefined) {
|
|
87
|
-
this.changeTitle(menuField, titleValue);
|
|
88
|
-
}
|
|
89
|
-
});
|
|
90
|
-
}
|
|
91
|
-
setDialogValue(value) {
|
|
92
|
-
this.closeDialog(value);
|
|
93
|
-
}
|
|
94
|
-
closeDialog(value = undefined) {
|
|
95
|
-
var _a;
|
|
96
|
-
(_a = this.dialogRef) === null || _a === void 0 ? void 0 : _a.close(value);
|
|
97
|
-
}
|
|
98
|
-
}
|
|
99
|
-
MenuDataViewComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.0.5", ngImport: i0, type: MenuDataViewComponent, deps: [{ token: i1.PepDialogService }, { token: i2.DataViewBuilderService }], target: i0.ɵɵFactoryTarget.Component });
|
|
100
|
-
MenuDataViewComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.0.5", type: MenuDataViewComponent, selector: "menu-data-view", inputs: { fields: "fields", availableFieldsTitles: "availableFieldsTitles", emptyDropAreaId: "emptyDropAreaId", mappedFieldsId: "mappedFieldsId" }, outputs: { fieldsChange: "fieldsChange" }, viewQueries: [{ propertyName: "separatorTitleModalTemplate", first: true, predicate: ["separatorTitleModalTemplate"], descendants: true, read: TemplateRef }], ngImport: i0, template: "<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 {{ 'DATA_VIEW_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 menuField of fields; let i = index\" >\n <div class=\"mapped-field-container\" [ngClass]=\"{ 'separator-container': menuField.FieldID === '' }\" \n cdkDrag (cdkDragStarted)=\"onDragStart($event)\" (cdkDragEnded)=\"onDragEnd($event)\">\n <ng-container *ngTemplateOutlet=\"mappedFieldTemplate; context: { menuField: menuField }\"></ng-container>\n </div>\n <div *ngIf=\"!isGrabbing\" class=\"add-separator-container\">\n <pep-button class=\"add-separator\" styleType=\"regular\" sizeType=\"sm\" iconName=\"number_plus\" \n [value]=\"'DATA_VIEW_BUILDER.ADD_SEPARATOR' | translate\" (buttonClick)=\"addSeparator(i+1)\"></pep-button>\n </div>\n </ng-container>\n </div>\n</ng-template>\n\n<ng-template #mappedFieldTemplate let-menuField=\"menuField\">\n <ng-container *ngIf=\"menuField.FieldID !== ''; then menuItemTemplate; else separatorTemplate\"></ng-container>\n\n <ng-template #menuItemTemplate>\n <div class=\"fields-wrapper\">\n <pep-textbox [label]=\"'DATA_VIEW_BUILDER.MENU_ITEM_KEY_TITLE' | translate\" [value]=\"menuField.FieldID\" [disabled]=\"true\">\n </pep-textbox>\n \n <pep-textbox [label]=\"'DATA_VIEW_BUILDER.MENU_ITEM_VALUE_TITLE' | translate\" [hint]=\"'(' + (availableFieldsTitles.get(menuField.FieldID) || '') + ')'\"\n [value]=\"menuField.Title\" (valueChange)=\"onTitleChanged($event, menuField)\">\n </pep-textbox>\n \n <pep-button class=\"center-button\" iconName=\"system_bin\" [title]=\"'ACTIONS.DELETE' | translate\" (buttonClick)=\"onDeleteMappedField($event, menuField)\"></pep-button>\n </div>\n </ng-template>\n <ng-template #separatorTemplate>\n <div class=\"separator-wrapper \">\n <div class=\"pep-spacing-element title title-md color-dimmed\">\n <span [title]=\"menuField.Title\">{{ menuField.Title }}</span>\n </div>\n <div class=\"list-actions\">\n <pep-button iconName=\"system_edit\" [title]=\"'ACTIONS.EDIT' | translate\" sizeType=\"xs\" styleType=\"regular\" (buttonClick)=\"onEditSeparatorField($event, menuField)\"></pep-button>\n <pep-button iconName=\"system_bin\" [title]=\"'ACTIONS.DELETE' | translate\" sizeType=\"xs\" styleType=\"regular\" (buttonClick)=\"onDeleteMappedField($event, menuField)\"></pep-button>\n </div>\n </div>\n </ng-template>\n</ng-template>\n\n<ng-template #separatorTitleModalTemplate let-data>\n <pep-dialog [title]=\"'DATA_VIEW_BUILDER.SEPARATOR_TITLE' | translate\">\n <ng-container pep-dialog-content>\n <pep-textbox #txt [label]=\"'DATA_VIEW_BUILDER.ADD_A_TITLE' | translate\" [(value)]=\"data.value\">\n </pep-textbox>\n </ng-container>\n <ng-container pep-dialog-actions>\n <div class=\"pep-spacing-element-negative\">\n <button mat-button class=\"pep-spacing-element pep-button md weak\"\n (click)=\"closeDialog()\">\n {{'Cancel' | translate}}\n </button>\n <button mat-button class=\"pep-spacing-element pep-button md strong\"\n (click)=\"setDialogValue(txt.value)\">\n {{ 'Save' | translate}}\n </button>\n </div>\n </ng-container>\n </pep-dialog>\n</ng-template>", styles: ["html body.inheritCursors *{cursor:inherit!important}.cdk-drag-preview.mapped-field-container{max-width:600px;display:flex;justify-content:center;align-items:center;border-radius:var(--pep-border-radius-md, .25rem)}.cdk-drag-preview.mapped-field-container:not(.separator-container){padding-inline:var(--pep-spacing-lg, 1rem)}.cdk-drag-preview.mapped-field-container:not(.separator-container){grid-gap:calc(var(--pep-spacing-lg, 1rem) * 2);gap:calc(var(--pep-spacing-lg, 1rem) * 2);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%))}.cdk-drag-preview.mapped-field-container .fields-wrapper{display:grid;width:100%;grid-template-columns:1fr 1fr auto;grid-gap:.5rem;gap:.5rem;padding-top:.5rem}.cdk-drag-preview.mapped-field-container .fields-wrapper .center-button{margin-top:var(--pep-form-field-title-height, 1.5rem)}.cdk-drag-preview.mapped-field-container .separator-wrapper{display:grid;width:100%;grid-template-columns:1fr auto;padding-bottom:var(--pep-spacing-xs, .25rem);border-bottom:1px solid hsl(var(--pep-color-regular-h, 0),var(--pep-color-regular-s, 0%),calc(var(--pep-color-regular-l, 10%) + 30%))}.cdk-drag-preview.mapped-field-container .separator-wrapper .list-actions{display:flex;grid-gap:var(--pep-spacing-xs, .25rem);gap: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%),.12);position:relative}.drop-field-here-area:not(.separator-container){padding-inline:var(--pep-spacing-lg, 1rem)}.drop-field-here-area:after{z-index:0;content:\"\";transition:all .25s;display:block;position:absolute;top:0;bottom:0;left:0;right: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;grid-column-gap:var(--pep-spacing-lg, 1rem);column-gap:var(--pep-spacing-lg, 1rem)}.mapped-fields-area:not(.no-row-gap){grid-row-gap:var(--pep-spacing-lg, 1rem);row-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:2.5rem}.mapped-fields-area.cdk-drop-list-dragging ::ng-deep .placeholder-item:not(.separator-container){padding-inline:var(--pep-spacing-lg, 1rem)}.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)}.mapped-fields-area .mapped-field-container:not(.separator-container){padding-inline:var(--pep-spacing-lg, 1rem)}.mapped-fields-area .mapped-field-container:not(.separator-container){grid-gap:calc(var(--pep-spacing-lg, 1rem) * 2);gap:calc(var(--pep-spacing-lg, 1rem) * 2);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%))}.mapped-fields-area .mapped-field-container .fields-wrapper{display:grid;width:100%;grid-template-columns:1fr 1fr auto;grid-gap:.5rem;gap:.5rem;padding-top:.5rem}.mapped-fields-area .mapped-field-container .fields-wrapper .center-button{margin-top:var(--pep-form-field-title-height, 1.5rem)}.mapped-fields-area .mapped-field-container .separator-wrapper{display:grid;width:100%;grid-template-columns:1fr auto;padding-bottom:var(--pep-spacing-xs, .25rem);border-bottom:1px solid hsl(var(--pep-color-regular-h, 0),var(--pep-color-regular-s, 0%),calc(var(--pep-color-regular-l, 10%) + 30%))}.mapped-fields-area .mapped-field-container .separator-wrapper .list-actions{display:flex;grid-gap:var(--pep-spacing-xs, .25rem);gap:var(--pep-spacing-xs, .25rem)}.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 .fields-wrapper,.mapped-fields-area .mapped-field-container.cdk-drag-placeholder .separator-wrapper{opacity:0}.mapped-fields-area .add-separator-container{max-width:600px;display:flex;justify-content:center;align-items:center;border-radius:var(--pep-border-radius-md, .25rem);height:var(--pep-spacing-lg, 1rem)}.mapped-fields-area .add-separator-container:not(.separator-container){padding-inline:var(--pep-spacing-lg, 1rem)}.mapped-fields-area .add-separator-container .add-separator{position:relative;display:none}.mapped-fields-area .add-separator-container:hover .add-separator{display:block}\n"], components: [{ type: i3.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { type: i4.PepIconComponent, selector: "pep-icon", inputs: ["spin", "name", "fill"] }, { type: i5.PepButtonComponent, selector: "pep-button", inputs: ["styleType", "styleStateType", "sizeType", "classNames", "disabled", "iconPosition", "visible", "key", "value", "iconName"], outputs: ["buttonClick"] }, { type: i6.PepTextboxComponent, selector: "pep-textbox", inputs: ["accessory", "label", "placeholder", "mandatory", "disabled", "readonly", "textColor", "xAlignment", "rowSpan", "minValue", "maxValue", "form", "isActive", "showTitle", "renderTitle", "renderError", "renderSymbol", "layoutType", "parentFieldKey", "key", "value", "formattedValue", "type", "visible", "maxFieldCharacters", "hint"], outputs: ["valueChange", "formValidationChange"] }, { type: i1.PepDialogComponent, selector: "pep-dialog", inputs: ["showClose", "showHeader", "showFooter", "title"], outputs: ["close"] }], directives: [{ type: i7.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i8.CdkDropList, selector: "[cdkDropList], cdk-drop-list", inputs: ["cdkDropListConnectedTo", "id", "cdkDropListEnterPredicate", "cdkDropListSortPredicate", "cdkDropListDisabled", "cdkDropListSortingDisabled", "cdkDropListAutoScrollDisabled", "cdkDropListOrientation", "cdkDropListLockAxis", "cdkDropListData", "cdkDropListAutoScrollStep"], outputs: ["cdkDropListDropped", "cdkDropListEntered", "cdkDropListExited", "cdkDropListSorted"], exportAs: ["cdkDropList"] }, { type: i7.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { type: i7.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i8.CdkDrag, selector: "[cdkDrag]", inputs: ["cdkDragDisabled", "cdkDragStartDelay", "cdkDragLockAxis", "cdkDragConstrainPosition", "cdkDragPreviewClass", "cdkDragBoundary", "cdkDragRootElement", "cdkDragPreviewContainer", "cdkDragData", "cdkDragFreeDragPosition"], outputs: ["cdkDragStarted", "cdkDragReleased", "cdkDragEnded", "cdkDragEntered", "cdkDragExited", "cdkDragDropped", "cdkDragMoved"], exportAs: ["cdkDrag"] }, { type: i7.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }], pipes: { "translate": i9.TranslatePipe } });
|
|
101
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.0.5", ngImport: i0, type: MenuDataViewComponent, decorators: [{
|
|
102
|
-
type: Component,
|
|
103
|
-
args: [{
|
|
104
|
-
selector: 'menu-data-view',
|
|
105
|
-
templateUrl: './menu-data-view.component.html',
|
|
106
|
-
styleUrls: ['./menu-data-view.component.scss']
|
|
107
|
-
}]
|
|
108
|
-
}], ctorParameters: function () { return [{ type: i1.PepDialogService }, { type: i2.DataViewBuilderService }]; }, propDecorators: { separatorTitleModalTemplate: [{
|
|
109
|
-
type: ViewChild,
|
|
110
|
-
args: ['separatorTitleModalTemplate', { read: TemplateRef }]
|
|
111
|
-
}], fields: [{
|
|
112
|
-
type: Input
|
|
113
|
-
}], availableFieldsTitles: [{
|
|
114
|
-
type: Input
|
|
115
|
-
}], emptyDropAreaId: [{
|
|
116
|
-
type: Input
|
|
117
|
-
}], mappedFieldsId: [{
|
|
118
|
-
type: Input
|
|
119
|
-
}], fieldsChange: [{
|
|
120
|
-
type: Output
|
|
121
|
-
}] } });
|
|
122
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"menu-data-view.component.js","sourceRoot":"","sources":["../../../../../projects/ngx-composite-lib/data-view-builder/menu-data-view/menu-data-view.component.ts","../../../../../projects/ngx-composite-lib/data-view-builder/menu-data-view/menu-data-view.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 { MatDialogRef } from '@angular/material/dialog';\nimport { TranslateService } from '@ngx-translate/core';\nimport { IPepButtonClickEvent } from '@pepperi-addons/ngx-lib/button';\nimport { PepDialogService } from '@pepperi-addons/ngx-lib/dialog';\nimport { IPepDraggableItem } from '@pepperi-addons/ngx-lib/draggable-items';\nimport { DataViewField, MenuDataViewField } from '@pepperi-addons/papi-sdk';\nimport { DataViewBuilderService } from '../data-view-builder.service';\n\n@Component({\n    selector: 'menu-data-view',\n    templateUrl: './menu-data-view.component.html',\n    styleUrls: ['./menu-data-view.component.scss']\n})\nexport class MenuDataViewComponent implements OnInit {\n    @ViewChild('separatorTitleModalTemplate', { read: TemplateRef }) separatorTitleModalTemplate!: TemplateRef<any>;\n\n    @Input() \n    fields: Array<DataViewField> = []; // The data view fields.\n\n    @Input()\n    availableFieldsTitles: Map<string, string> = new Map<string, string>(); // <FieldID, Original Title> from the available fields.\n\n    @Input() \n    emptyDropAreaId = '';\n\n    @Input() \n    mappedFieldsId = '';\n\n    @Output()\n    fieldsChange: EventEmitter<DataViewField[]> = new EventEmitter<DataViewField[]>();\n    \n    isGrabbing = false;\n    private dialogRef: MatDialogRef<any> | null = null;\n    \n    constructor(\n        private dialogService: PepDialogService,\n        private dataViewBuilderService: DataViewBuilderService\n    ) { \n        this.dataViewBuilderService.isGrabbingChange$.subscribe((value) => {\n            this.isGrabbing = value;\n        });\n    }\n    \n    private addNewField(draggableItem: IPepDraggableItem, index: number) {\n        // Add new menuField to the mappedFields.\n        const menuField: MenuDataViewField = { FieldID: draggableItem.data.key, Title: draggableItem.title };\n        this.spliceMappedFields(index, 0, menuField);\n    }\n    \n    private spliceMappedFields(start: number, deleteCount: number, item?: MenuDataViewField) {\n        if (item) {\n            this.fields.splice(start, deleteCount, item);\n        } else {\n            this.fields.splice(start, deleteCount);\n        }\n\n        this.notifyFieldsChange();\n    }\n\n    private changeTitle(menuField: MenuDataViewField, title: string) {\n        menuField.Title = title;\n        this.notifyFieldsChange();\n    }\n\n    private notifyFieldsChange() {\n        this.fieldsChange.emit(this.fields);\n    }\n\n    ngOnInit() {\n        //\n    }\n\n    addSeparator(index: number) {\n        const menuField: MenuDataViewField = { FieldID: '', Title: '' };\n        this.spliceMappedFields(index, 0, menuField);\n    }\n\n    onDragStart(event: CdkDragStart) {\n        this.dataViewBuilderService.onDragStart(event);\n    }\n\n    onDragEnd(event: CdkDragEnd) {\n        this.dataViewBuilderService.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    onTitleChanged(event: string, menuField: MenuDataViewField) {\n        this.changeTitle(menuField, event);\n    }\n\n    onDeleteMappedField(event: IPepButtonClickEvent, menuField: MenuDataViewField) {\n        const index = this.fields.findIndex(ms => ms === menuField);\n        if (index > -1) {\n            this.spliceMappedFields(index, 1);\n        }\n    }\n\n    onEditSeparatorField(event: IPepButtonClickEvent, menuField: MenuDataViewField) {\n        this.dialogRef = this.dialogService.openDialog(this.separatorTitleModalTemplate, { value: menuField.Title });\n        this.dialogRef.afterClosed().subscribe((titleValue) => {\n            if (titleValue !== undefined) {\n                this.changeTitle(menuField, titleValue);\n            }\n        });\n    }\n\n    setDialogValue(value: string) {\n        this.closeDialog(value);\n    }\n\n    closeDialog(value: string | undefined = undefined) {\n        this.dialogRef?.close(value);\n    }\n}\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            {{ 'DATA_VIEW_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 menuField of fields; let i = index\" >\n            <div class=\"mapped-field-container\" [ngClass]=\"{ 'separator-container': menuField.FieldID === '' }\" \n                cdkDrag (cdkDragStarted)=\"onDragStart($event)\" (cdkDragEnded)=\"onDragEnd($event)\">\n                <ng-container *ngTemplateOutlet=\"mappedFieldTemplate; context: { menuField: menuField }\"></ng-container>\n            </div>\n            <div *ngIf=\"!isGrabbing\" class=\"add-separator-container\">\n                <pep-button class=\"add-separator\" styleType=\"regular\" sizeType=\"sm\" iconName=\"number_plus\" \n                    [value]=\"'DATA_VIEW_BUILDER.ADD_SEPARATOR' | translate\" (buttonClick)=\"addSeparator(i+1)\"></pep-button>\n            </div>\n        </ng-container>\n    </div>\n</ng-template>\n\n<ng-template #mappedFieldTemplate let-menuField=\"menuField\">\n    <ng-container *ngIf=\"menuField.FieldID !== ''; then menuItemTemplate; else separatorTemplate\"></ng-container>\n\n    <ng-template #menuItemTemplate>\n        <div class=\"fields-wrapper\">\n            <pep-textbox [label]=\"'DATA_VIEW_BUILDER.MENU_ITEM_KEY_TITLE' | translate\" [value]=\"menuField.FieldID\" [disabled]=\"true\">\n            </pep-textbox>\n            \n            <pep-textbox [label]=\"'DATA_VIEW_BUILDER.MENU_ITEM_VALUE_TITLE' | translate\" [hint]=\"'(' + (availableFieldsTitles.get(menuField.FieldID) || '') + ')'\"\n                [value]=\"menuField.Title\" (valueChange)=\"onTitleChanged($event, menuField)\">\n            </pep-textbox>\n    \n            <pep-button class=\"center-button\" iconName=\"system_bin\" [title]=\"'ACTIONS.DELETE' | translate\" (buttonClick)=\"onDeleteMappedField($event, menuField)\"></pep-button>\n        </div>\n    </ng-template>\n    <ng-template #separatorTemplate>\n        <div class=\"separator-wrapper \">\n            <div class=\"pep-spacing-element title title-md color-dimmed\">\n                <span [title]=\"menuField.Title\">{{ menuField.Title }}</span>\n            </div>\n            <div class=\"list-actions\">\n                <pep-button iconName=\"system_edit\" [title]=\"'ACTIONS.EDIT' | translate\" sizeType=\"xs\" styleType=\"regular\" (buttonClick)=\"onEditSeparatorField($event, menuField)\"></pep-button>\n                <pep-button iconName=\"system_bin\" [title]=\"'ACTIONS.DELETE' | translate\" sizeType=\"xs\" styleType=\"regular\" (buttonClick)=\"onDeleteMappedField($event, menuField)\"></pep-button>\n            </div>\n        </div>\n    </ng-template>\n</ng-template>\n\n<ng-template #separatorTitleModalTemplate let-data>\n    <pep-dialog [title]=\"'DATA_VIEW_BUILDER.SEPARATOR_TITLE' | translate\">\n        <ng-container pep-dialog-content>\n            <pep-textbox #txt [label]=\"'DATA_VIEW_BUILDER.ADD_A_TITLE' | translate\" [(value)]=\"data.value\">\n            </pep-textbox>\n        </ng-container>\n        <ng-container pep-dialog-actions>\n            <div class=\"pep-spacing-element-negative\">\n                <button mat-button class=\"pep-spacing-element pep-button md weak\"\n                    (click)=\"closeDialog()\">\n                    {{'Cancel' | translate}}\n                </button>\n                <button mat-button class=\"pep-spacing-element pep-button md strong\"\n                    (click)=\"setDialogValue(txt.value)\">\n                    {{ 'Save' | translate}}\n                </button>\n            </div>\n        </ng-container>\n    </pep-dialog>\n</ng-template>"]}
|
|
@@ -1,39 +0,0 @@
|
|
|
1
|
-
import { Component, Output, EventEmitter, Inject } from '@angular/core';
|
|
2
|
-
import { MAT_SNACK_BAR_DATA } from '@angular/material/snack-bar';
|
|
3
|
-
import * as i0 from "@angular/core";
|
|
4
|
-
import * as i1 from "@angular/material/snack-bar";
|
|
5
|
-
import * as i2 from "@pepperi-addons/ngx-lib/snack-bar";
|
|
6
|
-
import * as i3 from "@pepperi-addons/ngx-lib/icon";
|
|
7
|
-
import * as i4 from "@angular/common";
|
|
8
|
-
export class FileStatusPanelComponent {
|
|
9
|
-
constructor(data, snackBarRef) {
|
|
10
|
-
this.data = data;
|
|
11
|
-
this.snackBarRef = snackBarRef;
|
|
12
|
-
// @Input() title = '';
|
|
13
|
-
// @Input() filesList: Array<FileStatus> = [];
|
|
14
|
-
this.closeClick = new EventEmitter();
|
|
15
|
-
//
|
|
16
|
-
}
|
|
17
|
-
ngOnInit() {
|
|
18
|
-
//
|
|
19
|
-
}
|
|
20
|
-
onCloseClicked(event) {
|
|
21
|
-
this.closeClick.emit();
|
|
22
|
-
}
|
|
23
|
-
}
|
|
24
|
-
FileStatusPanelComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.0.5", ngImport: i0, type: FileStatusPanelComponent, deps: [{ token: MAT_SNACK_BAR_DATA }, { token: i1.MatSnackBarRef }], target: i0.ɵɵFactoryTarget.Component });
|
|
25
|
-
FileStatusPanelComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.0.5", type: FileStatusPanelComponent, selector: "pep-file-status-panel", outputs: { closeClick: "closeClick" }, ngImport: i0, template: "<pep-snack-bar class=\"upload-panel-contnainer\" [snackBarRef]=\"snackBarRef\" [title]=\"data.title\" (closeClick)=\"onCloseClicked($event)\" >\n <div pep-snack-bar-content class=\"panel-content\">\n <ul *ngIf=\"data.content.length\">\n <li *ngFor=\"let file of data.content\">\n <ng-container *ngIf=\"file?.status !== 'hidden'\">\n <span class=\"color-dimmed body-sm ellipsis\">{{file.name}}</span>\n <pep-icon class=\"pep-spacing-element\" name=\"arrow_right_alt\"></pep-icon>\n <span class=\"body-sm\" title=\"{{file.statusMessage}}\">{{file.status}}</span>\n </ng-container>\n </li>\n </ul>\n </div>\n</pep-snack-bar>", styles: [".upload-panel-contnainer .panel-content{max-height:50vh;overflow:auto}.upload-panel-contnainer .panel-content ul{list-style-type:none;padding:0}.upload-panel-contnainer .panel-content ul li{height:1.25rem;margin-top:.5rem;display:flex;flex-direction:row;align-items:center}.upload-panel-contnainer .panel-content ul li pep-icon{height:1rem}\n"], components: [{ type: i2.PepSnackBarComponent, selector: "pep-snack-bar", inputs: ["snackBarRef", "title"], outputs: ["closeClick"] }, { type: i3.PepIconComponent, selector: "pep-icon", inputs: ["spin", "name", "fill"] }], directives: [{ type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i4.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }] });
|
|
26
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.0.5", ngImport: i0, type: FileStatusPanelComponent, decorators: [{
|
|
27
|
-
type: Component,
|
|
28
|
-
args: [{
|
|
29
|
-
selector: 'pep-file-status-panel',
|
|
30
|
-
templateUrl: './file-status-panel.component.html',
|
|
31
|
-
styleUrls: ['./file-status-panel.component.scss']
|
|
32
|
-
}]
|
|
33
|
-
}], ctorParameters: function () { return [{ type: i2.PepSnackBarData, decorators: [{
|
|
34
|
-
type: Inject,
|
|
35
|
-
args: [MAT_SNACK_BAR_DATA]
|
|
36
|
-
}] }, { type: i1.MatSnackBarRef }]; }, propDecorators: { closeClick: [{
|
|
37
|
-
type: Output
|
|
38
|
-
}] } });
|
|
39
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmlsZS1zdGF0dXMtcGFuZWwuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vcHJvamVjdHMvbmd4LWNvbXBvc2l0ZS1saWIvZmlsZS1zdGF0dXMtcGFuZWwvZmlsZS1zdGF0dXMtcGFuZWwuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vcHJvamVjdHMvbmd4LWNvbXBvc2l0ZS1saWIvZmlsZS1zdGF0dXMtcGFuZWwvZmlsZS1zdGF0dXMtcGFuZWwuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBNkIsTUFBTSxFQUFFLFlBQVksRUFBWSxNQUFNLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDN0csT0FBTyxFQUFrQixrQkFBa0IsRUFBRSxNQUFNLDZCQUE2QixDQUFDOzs7Ozs7QUFVakYsTUFBTSxPQUFPLHdCQUF3QjtJQU9qQyxZQUN1QyxJQUFxQixFQUNqRCxXQUFxRDtRQUR6QixTQUFJLEdBQUosSUFBSSxDQUFpQjtRQUNqRCxnQkFBVyxHQUFYLFdBQVcsQ0FBMEM7UUFSaEUsdUJBQXVCO1FBQ3ZCLDhDQUE4QztRQUc5QyxlQUFVLEdBQXVCLElBQUksWUFBWSxFQUFRLENBQUM7UUFNdkQsRUFBRTtJQUNMLENBQUM7SUFFRCxRQUFRO1FBQ0osRUFBRTtJQUNOLENBQUM7SUFFRCxjQUFjLENBQUMsS0FBVTtRQUNyQixJQUFJLENBQUMsVUFBVSxDQUFDLElBQUksRUFBRSxDQUFDO0lBQzNCLENBQUM7O3FIQXBCUSx3QkFBd0Isa0JBUXJCLGtCQUFrQjt5R0FSckIsd0JBQXdCLG9HQ1hyQyxndkJBWWdCOzJGRERILHdCQUF3QjtrQkFMcEMsU0FBUzttQkFBQztvQkFDUCxRQUFRLEVBQUUsdUJBQXVCO29CQUNqQyxXQUFXLEVBQUUsb0NBQW9DO29CQUNqRCxTQUFTLEVBQUUsQ0FBQyxvQ0FBb0MsQ0FBQztpQkFDcEQ7OzBCQVNRLE1BQU07MkJBQUMsa0JBQWtCO3lFQUg5QixVQUFVO3NCQURULE1BQU0iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIE9uSW5pdCwgSW5qZWN0YWJsZSwgSW5wdXQsIE91dHB1dCwgRXZlbnRFbWl0dGVyLCBPcHRpb25hbCwgSW5qZWN0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBNYXRTbmFja0JhclJlZiwgTUFUX1NOQUNLX0JBUl9EQVRBIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvc25hY2stYmFyJztcbmltcG9ydCB7IFRyYW5zbGF0ZVNlcnZpY2UgfSBmcm9tICdAbmd4LXRyYW5zbGF0ZS9jb3JlJztcbmltcG9ydCB7IFBlcFNuYWNrQmFyRGF0YSB9IGZyb20gJ0BwZXBwZXJpLWFkZG9ucy9uZ3gtbGliL3NuYWNrLWJhcic7XG5pbXBvcnQgeyBGaWxlU3RhdHVzIH0gZnJvbSAnLi9maWxlLXN0YXR1cy1wYW5lbC5tb2RlbCc7XG5cbkBDb21wb25lbnQoe1xuICAgIHNlbGVjdG9yOiAncGVwLWZpbGUtc3RhdHVzLXBhbmVsJyxcbiAgICB0ZW1wbGF0ZVVybDogJy4vZmlsZS1zdGF0dXMtcGFuZWwuY29tcG9uZW50Lmh0bWwnLFxuICAgIHN0eWxlVXJsczogWycuL2ZpbGUtc3RhdHVzLXBhbmVsLmNvbXBvbmVudC5zY3NzJ11cbn0pXG5leHBvcnQgY2xhc3MgRmlsZVN0YXR1c1BhbmVsQ29tcG9uZW50IGltcGxlbWVudHMgT25Jbml0IHtcbiAgICAvLyBASW5wdXQoKSB0aXRsZSA9ICcnO1xuICAgIC8vIEBJbnB1dCgpIGZpbGVzTGlzdDogQXJyYXk8RmlsZVN0YXR1cz4gPSBbXTtcbiAgICBcbiAgICBAT3V0cHV0KClcbiAgICBjbG9zZUNsaWNrOiBFdmVudEVtaXR0ZXI8dm9pZD4gPSBuZXcgRXZlbnRFbWl0dGVyPHZvaWQ+KCk7XG4gICAgXG4gICAgY29uc3RydWN0b3IoXG4gICAgICAgIEBJbmplY3QoTUFUX1NOQUNLX0JBUl9EQVRBKSBwdWJsaWMgZGF0YTogUGVwU25hY2tCYXJEYXRhLFxuICAgICAgICBwdWJsaWMgc25hY2tCYXJSZWY6IE1hdFNuYWNrQmFyUmVmPEZpbGVTdGF0dXNQYW5lbENvbXBvbmVudD5cbiAgICApIHtcbiAgICAgICAvL1xuICAgIH1cblxuICAgIG5nT25Jbml0KCkge1xuICAgICAgICAvL1xuICAgIH1cblxuICAgIG9uQ2xvc2VDbGlja2VkKGV2ZW50OiBhbnkpOiB2b2lkIHtcbiAgICAgICAgdGhpcy5jbG9zZUNsaWNrLmVtaXQoKTtcbiAgICB9XG5cblxufSIsIjxwZXAtc25hY2stYmFyIGNsYXNzPVwidXBsb2FkLXBhbmVsLWNvbnRuYWluZXJcIiBbc25hY2tCYXJSZWZdPVwic25hY2tCYXJSZWZcIiBbdGl0bGVdPVwiZGF0YS50aXRsZVwiIChjbG9zZUNsaWNrKT1cIm9uQ2xvc2VDbGlja2VkKCRldmVudClcIiA+XG4gICAgPGRpdiBwZXAtc25hY2stYmFyLWNvbnRlbnQgY2xhc3M9XCJwYW5lbC1jb250ZW50XCI+XG4gICAgICAgIDx1bCAqbmdJZj1cImRhdGEuY29udGVudC5sZW5ndGhcIj5cbiAgICAgICAgICAgIDxsaSAqbmdGb3I9XCJsZXQgZmlsZSBvZiBkYXRhLmNvbnRlbnRcIj5cbiAgICAgICAgICAgICAgICA8bmctY29udGFpbmVyICpuZ0lmPVwiZmlsZT8uc3RhdHVzICE9PSAnaGlkZGVuJ1wiPlxuICAgICAgICAgICAgICAgICAgICA8c3BhbiBjbGFzcz1cImNvbG9yLWRpbW1lZCBib2R5LXNtIGVsbGlwc2lzXCI+e3tmaWxlLm5hbWV9fTwvc3Bhbj5cbiAgICAgICAgICAgICAgICAgICAgPHBlcC1pY29uIGNsYXNzPVwicGVwLXNwYWNpbmctZWxlbWVudFwiIG5hbWU9XCJhcnJvd19yaWdodF9hbHRcIj48L3BlcC1pY29uPlxuICAgICAgICAgICAgICAgICAgICA8c3BhbiBjbGFzcz1cImJvZHktc21cIiB0aXRsZT1cInt7ZmlsZS5zdGF0dXNNZXNzYWdlfX1cIj57e2ZpbGUuc3RhdHVzfX08L3NwYW4+XG4gICAgICAgICAgICAgICAgPC9uZy1jb250YWluZXI+XG4gICAgICAgICAgICA8L2xpPlxuICAgICAgICA8L3VsPlxuICAgIDwvZGl2PlxuPC9wZXAtc25hY2stYmFyPiJdfQ==
|
|
@@ -1,190 +0,0 @@
|
|
|
1
|
-
import { Component, Input, Output, ViewChild, ViewContainerRef, EventEmitter, } from '@angular/core';
|
|
2
|
-
import { PepFormComponent } from '@pepperi-addons/ngx-lib/form';
|
|
3
|
-
import { UIControl, ObjectsDataRow, PepGuid } from '@pepperi-addons/ngx-lib';
|
|
4
|
-
import { DataViewConverter } from '@pepperi-addons/data-views';
|
|
5
|
-
import { PepGenericFormService } from './generic-form.service';
|
|
6
|
-
import * as i0 from "@angular/core";
|
|
7
|
-
import * as i1 from "@pepperi-addons/ngx-lib";
|
|
8
|
-
import * as i2 from "./generic-form.service";
|
|
9
|
-
import * as i3 from "@pepperi-addons/ngx-lib/page-layout";
|
|
10
|
-
import * as i4 from "@pepperi-addons/ngx-lib/top-bar";
|
|
11
|
-
import * as i5 from "@angular/common";
|
|
12
|
-
export class GenericFormComponent {
|
|
13
|
-
constructor(_resolver, layoutService, _genericFormService) {
|
|
14
|
-
this._resolver = _resolver;
|
|
15
|
-
this.layoutService = layoutService;
|
|
16
|
-
this._genericFormService = _genericFormService;
|
|
17
|
-
this._optionalValues = [];
|
|
18
|
-
this.isLocked = false;
|
|
19
|
-
this.inline = false;
|
|
20
|
-
this.showTopBar = false;
|
|
21
|
-
this.addPadding = false;
|
|
22
|
-
this.valueChange = new EventEmitter();
|
|
23
|
-
this.fieldClick = new EventEmitter();
|
|
24
|
-
this.formValidationChange = new EventEmitter();
|
|
25
|
-
this.layoutService.onResize$.pipe().subscribe((size) => {
|
|
26
|
-
//
|
|
27
|
-
});
|
|
28
|
-
this._formData = new ObjectsDataRow();
|
|
29
|
-
this._uiControl = new UIControl();
|
|
30
|
-
}
|
|
31
|
-
set pepListContainer(val) {
|
|
32
|
-
this._pepFormContainer = val;
|
|
33
|
-
}
|
|
34
|
-
set dataSource(val) {
|
|
35
|
-
this._data = val;
|
|
36
|
-
}
|
|
37
|
-
set dataView(val) {
|
|
38
|
-
this.initForm(val);
|
|
39
|
-
}
|
|
40
|
-
ngOnInit() {
|
|
41
|
-
//
|
|
42
|
-
}
|
|
43
|
-
initForm(dataView) {
|
|
44
|
-
setTimeout(() => {
|
|
45
|
-
var _a, _b;
|
|
46
|
-
if (this._pepFormContainer) {
|
|
47
|
-
if (this._pepFormContainer.length) {
|
|
48
|
-
this._pepFormContainer.remove();
|
|
49
|
-
this._formData = new ObjectsDataRow();
|
|
50
|
-
this._uiControl = new UIControl();
|
|
51
|
-
}
|
|
52
|
-
const factory = this._resolver.resolveComponentFactory(PepFormComponent);
|
|
53
|
-
const componentRef = this._pepFormContainer.createComponent(factory);
|
|
54
|
-
this._pepForm = componentRef.instance;
|
|
55
|
-
this._formData.IsEditable = !this.isLocked;
|
|
56
|
-
this._formData.UID = dataView.UID || PepGuid.newGuid();
|
|
57
|
-
const uiControlData = DataViewConverter.toUIControlData(dataView);
|
|
58
|
-
if (uiControlData) {
|
|
59
|
-
if (uiControlData === null || uiControlData === void 0 ? void 0 : uiControlData.ControlFields) {
|
|
60
|
-
(_a = dataView.Fields) === null || _a === void 0 ? void 0 : _a.forEach((field) => {
|
|
61
|
-
var _a;
|
|
62
|
-
if ((_a = field.OptionalValues) === null || _a === void 0 ? void 0 : _a.length) {
|
|
63
|
-
this._optionalValues.push({
|
|
64
|
-
fieldId: field.FieldID,
|
|
65
|
-
optionalValues: field.OptionalValues
|
|
66
|
-
});
|
|
67
|
-
}
|
|
68
|
-
});
|
|
69
|
-
this._uiControl.ControlFields = uiControlData.ControlFields.map((field) => this._genericFormService.convertToUiControlField(field));
|
|
70
|
-
}
|
|
71
|
-
this._uiControl.Columns = uiControlData.Columns;
|
|
72
|
-
if ((_b = this._uiControl.ControlFields) === null || _b === void 0 ? void 0 : _b.length) {
|
|
73
|
-
this._formData.Fields = [];
|
|
74
|
-
this._uiControl.ControlFields.forEach((item) => {
|
|
75
|
-
let value = '';
|
|
76
|
-
if (this._genericFormService.hasProperty(this._data, item.ApiName)) {
|
|
77
|
-
value = this._data[item.ApiName];
|
|
78
|
-
}
|
|
79
|
-
this._formData.Fields.push(this._genericFormService.createFormField(item, value, this.getOptionalValues(item.ApiName)));
|
|
80
|
-
});
|
|
81
|
-
componentRef.instance.layoutType = 'form';
|
|
82
|
-
componentRef.instance.layout = this._uiControl;
|
|
83
|
-
componentRef.instance.data = this._formData;
|
|
84
|
-
componentRef.instance.isInternal = false;
|
|
85
|
-
componentRef.instance.lockFields = this.isLocked;
|
|
86
|
-
componentRef.instance.valueChange.subscribe(($event) => {
|
|
87
|
-
this.onValueChanged($event);
|
|
88
|
-
});
|
|
89
|
-
componentRef.instance.fieldClick.subscribe(($event) => {
|
|
90
|
-
this.onfieldClicked($event);
|
|
91
|
-
});
|
|
92
|
-
componentRef.instance.formValidationChange.subscribe(($event) => {
|
|
93
|
-
this.onFormValidationChanged($event);
|
|
94
|
-
});
|
|
95
|
-
}
|
|
96
|
-
}
|
|
97
|
-
}
|
|
98
|
-
}, 0);
|
|
99
|
-
}
|
|
100
|
-
/**
|
|
101
|
-
* updates form field's value
|
|
102
|
-
* @param field object containing the data of the required update
|
|
103
|
-
*/
|
|
104
|
-
updateFieldValue(fieldChanged) {
|
|
105
|
-
this._data[fieldChanged.ApiName] = fieldChanged.Value;
|
|
106
|
-
}
|
|
107
|
-
getOptionalValues(fieldId) {
|
|
108
|
-
const item = this._optionalValues.find((item) => item.fieldId === fieldId);
|
|
109
|
-
return (item === null || item === void 0 ? void 0 : item.optionalValues) || [];
|
|
110
|
-
}
|
|
111
|
-
getData() {
|
|
112
|
-
return {
|
|
113
|
-
UID: this._formData.UID,
|
|
114
|
-
Values: this._data
|
|
115
|
-
};
|
|
116
|
-
}
|
|
117
|
-
/**
|
|
118
|
-
* updates form field(s) params
|
|
119
|
-
* @param fields
|
|
120
|
-
*/
|
|
121
|
-
updateFields(fields) {
|
|
122
|
-
fields.forEach((field) => {
|
|
123
|
-
const index = this._formData.Fields.findIndex((item) => item.ApiName === field.FieldId);
|
|
124
|
-
if (index >= 0) {
|
|
125
|
-
for (const [key, value] of Object.entries(field.Params)) {
|
|
126
|
-
if (this._genericFormService.hasProperty(this._formData.Fields[index], key)) {
|
|
127
|
-
const item = this._formData.Fields[index];
|
|
128
|
-
item[key] = value;
|
|
129
|
-
}
|
|
130
|
-
}
|
|
131
|
-
}
|
|
132
|
-
});
|
|
133
|
-
this._pepForm.ReloadForm();
|
|
134
|
-
this._pepForm.data = this._formData;
|
|
135
|
-
}
|
|
136
|
-
onValueChanged(event) {
|
|
137
|
-
const field = {
|
|
138
|
-
UID: event.id,
|
|
139
|
-
ApiName: event.key,
|
|
140
|
-
Value: event.value
|
|
141
|
-
};
|
|
142
|
-
this.updateFieldValue(field);
|
|
143
|
-
this.valueChange.emit(field);
|
|
144
|
-
}
|
|
145
|
-
onfieldClicked(event) {
|
|
146
|
-
const field = {
|
|
147
|
-
UID: event.id,
|
|
148
|
-
ApiName: event.key,
|
|
149
|
-
Value: event.value
|
|
150
|
-
};
|
|
151
|
-
this.updateFieldValue(field);
|
|
152
|
-
this.fieldClick.emit(field);
|
|
153
|
-
}
|
|
154
|
-
onFormValidationChanged(event) {
|
|
155
|
-
this.formValidationChange.emit(event);
|
|
156
|
-
}
|
|
157
|
-
}
|
|
158
|
-
GenericFormComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.0.5", ngImport: i0, type: GenericFormComponent, deps: [{ token: i0.ComponentFactoryResolver }, { token: i1.PepLayoutService }, { token: i2.PepGenericFormService }], target: i0.ɵɵFactoryTarget.Component });
|
|
159
|
-
GenericFormComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.0.5", 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 <div class=\"form-view\">\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)}\n"], components: [{ type: i3.PepPageLayoutComponent, selector: "pep-page-layout", inputs: ["addPadding", "showShadow"] }, { type: i4.PepTopBarComponent, selector: "pep-top-bar", inputs: ["inline", "title"], outputs: ["footerStateChange"] }], directives: [{ type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i5.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { type: i5.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }] });
|
|
160
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.0.5", ngImport: i0, type: GenericFormComponent, decorators: [{
|
|
161
|
-
type: Component,
|
|
162
|
-
args: [{
|
|
163
|
-
selector: 'pep-generic-form',
|
|
164
|
-
templateUrl: './generic-form.component.html',
|
|
165
|
-
styleUrls: ['./generic-form.component.scss'],
|
|
166
|
-
providers: [PepGenericFormService]
|
|
167
|
-
}]
|
|
168
|
-
}], ctorParameters: function () { return [{ type: i0.ComponentFactoryResolver }, { type: i1.PepLayoutService }, { type: i2.PepGenericFormService }]; }, propDecorators: { pepListContainer: [{
|
|
169
|
-
type: ViewChild,
|
|
170
|
-
args: ['pepFormContainer', { read: ViewContainerRef }]
|
|
171
|
-
}], dataSource: [{
|
|
172
|
-
type: Input
|
|
173
|
-
}], dataView: [{
|
|
174
|
-
type: Input
|
|
175
|
-
}], isLocked: [{
|
|
176
|
-
type: Input
|
|
177
|
-
}], inline: [{
|
|
178
|
-
type: Input
|
|
179
|
-
}], showTopBar: [{
|
|
180
|
-
type: Input
|
|
181
|
-
}], addPadding: [{
|
|
182
|
-
type: Input
|
|
183
|
-
}], valueChange: [{
|
|
184
|
-
type: Output
|
|
185
|
-
}], fieldClick: [{
|
|
186
|
-
type: Output
|
|
187
|
-
}], formValidationChange: [{
|
|
188
|
-
type: Output
|
|
189
|
-
}] } });
|
|
190
|
-
//# 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    ComponentFactoryResolver,\n} from '@angular/core';\nimport { 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';\nimport { } from './'\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 _optionalValues: any[] = [];\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 _resolver: ComponentFactoryResolver,\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(() => {\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\n                const factory = this._resolver.resolveComponentFactory(PepFormComponent);\n                const componentRef = this._pepFormContainer.createComponent(factory);\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                        dataView.Fields?.forEach((field: any) => {\n                            if (field.OptionalValues?.length) {\n                                this._optionalValues.push({\n                                    fieldId: field.FieldID,\n                                    optionalValues: field.OptionalValues\n                                });\n                            }\n                        });\n                        this._uiControl.ControlFields = uiControlData.ControlFields.map((field: any) => this._genericFormService.convertToUiControlField(field));\n\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                            this._formData.Fields.push(this._genericFormService.createFormField(item, value, this.getOptionalValues(item.ApiName)) as ObjectsDataRowCell);\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    private getOptionalValues(fieldId: string) {\n        const item = this._optionalValues.find((item: any) => item.fieldId === fieldId);\n        return item?.optionalValues || [];\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        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                    }\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    <div class=\"form-view\">\n        <ng-container #pepFormContainer></ng-container>\n    </div>\n</ng-template>\n"]}
|
|
@@ -1,5 +0,0 @@
|
|
|
1
|
-
/*
|
|
2
|
-
* export from ngx-composite-lib/generic-form
|
|
3
|
-
*/
|
|
4
|
-
export * from './public-api';
|
|
5
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtY29tcG9zaXRlLWxpYi9nZW5lcmljLWZvcm0vaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFDSCxjQUFjLGNBQWMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qXG4gKiBleHBvcnQgZnJvbSBuZ3gtY29tcG9zaXRlLWxpYi9nZW5lcmljLWZvcm1cbiAqL1xuZXhwb3J0ICogZnJvbSAnLi9wdWJsaWMtYXBpJzsiXX0=
|