@tsi-developpement/tsi-shared-ui 1.0.11 → 1.0.13
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/lib/end-points/endpoints.mjs +2 -4
- package/esm2022/lib/functions/modal-open.function.mjs +1 -8
- package/esm2022/lib/shared.module.mjs +5 -13
- package/esm2022/lib/tsi-components/index.mjs +1 -3
- package/esm2022/lib/tsi-components/manage-reporting/add-report-popup/add-report-popup.component.mjs +73 -16
- package/esm2022/lib/tsi-components/tsi-generic-crud/tsi-generic-crud.component.mjs +18 -60
- package/esm2022/lib/tsi-components/tsi-notes-grid/tsi-notes-grid.component.mjs +1 -1
- package/esm2022/lib/tsi-components/tsi-upload-grid/tsi-upload-grid.component.mjs +1 -1
- package/fesm2022/tsi-developpement-tsi-shared-ui.mjs +132 -362
- package/fesm2022/tsi-developpement-tsi-shared-ui.mjs.map +1 -1
- package/lib/consts/app-providers.d.ts +1 -1
- package/lib/end-points/endpoints.d.ts +1 -3
- package/lib/functions/modal-open.function.d.ts +0 -1
- package/lib/shared.module.d.ts +53 -55
- package/lib/tsi-components/index.d.ts +0 -2
- package/lib/tsi-components/manage-reporting/add-report-popup/add-report-popup.component.d.ts +11 -1
- package/lib/tsi-components/tsi-generic-crud/tsi-generic-crud.component.d.ts +3 -8
- package/package.json +1 -1
- package/esm2022/lib/consts/form-type.mjs +0 -8
- package/esm2022/lib/end-points/formulaire-endpoints.mjs +0 -11
- package/esm2022/lib/models/dynamic-form/formulaire.mjs +0 -5
- package/esm2022/lib/services/dynamic-form/form-data.service.mjs +0 -31
- package/esm2022/lib/tsi-components/tsi-dynamic-form/create-or-edit-dynamic-form/create-or-edit-dynamic-form.component.mjs +0 -150
- package/esm2022/lib/tsi-components/tsi-dynamic-form/dynamic-form-list/dynamic-form-list.component.mjs +0 -59
- package/lib/consts/form-type.d.ts +0 -7
- package/lib/end-points/formulaire-endpoints.d.ts +0 -9
- package/lib/models/dynamic-form/formulaire.d.ts +0 -56
- package/lib/services/dynamic-form/form-data.service.d.ts +0 -16
- package/lib/tsi-components/tsi-dynamic-form/create-or-edit-dynamic-form/create-or-edit-dynamic-form.component.d.ts +0 -43
- package/lib/tsi-components/tsi-dynamic-form/dynamic-form-list/dynamic-form-list.component.d.ts +0 -12
package/esm2022/lib/tsi-components/manage-reporting/add-report-popup/add-report-popup.component.mjs
CHANGED
|
@@ -3,27 +3,35 @@ import { AdministrationEndpoints } from '../../../end-points';
|
|
|
3
3
|
import { TsiReportType, Modes } from '../../../enums';
|
|
4
4
|
import { TsiFormComponentBaseComponent } from '../../../tsi-base/components/tsi-form-base/tsi-form-base.component';
|
|
5
5
|
import { appProviders } from '../../../consts/app-providers';
|
|
6
|
+
import { firstValueFrom } from 'rxjs';
|
|
7
|
+
import { HttpParams } from '@angular/common/http';
|
|
6
8
|
import * as i0 from "@angular/core";
|
|
7
9
|
import * as i1 from "primeng/dynamicdialog";
|
|
8
10
|
import * as i2 from "../../../services/reporting/reporting.service";
|
|
9
11
|
import * as i3 from "../../../services/notification/tsi-notification.service";
|
|
10
12
|
import * as i4 from "../../../services/reporting/dashboard-module.service";
|
|
11
13
|
import * as i5 from "../../../services/notification/tsi-confirmation.service";
|
|
12
|
-
import * as i6 from "@angular/common";
|
|
13
|
-
import * as i7 from "@angular/
|
|
14
|
-
import * as i8 from "
|
|
15
|
-
import * as i9 from "
|
|
16
|
-
import * as i10 from "
|
|
17
|
-
import * as i11 from "
|
|
18
|
-
import * as i12 from "
|
|
19
|
-
import * as i13 from "../../input-components/tsi-
|
|
20
|
-
import * as i14 from "../../
|
|
21
|
-
import * as i15 from "../../tsi-
|
|
14
|
+
import * as i6 from "@angular/common/http";
|
|
15
|
+
import * as i7 from "@angular/router";
|
|
16
|
+
import * as i8 from "@angular/common";
|
|
17
|
+
import * as i9 from "@angular/forms";
|
|
18
|
+
import * as i10 from "primeng/api";
|
|
19
|
+
import * as i11 from "primeng/multiselect";
|
|
20
|
+
import * as i12 from "primeng/panel";
|
|
21
|
+
import * as i13 from "../../input-components/tsi-search-combo/tsi-search-combo.component";
|
|
22
|
+
import * as i14 from "../../input-components/tsi-checkbox/tsi-checkbox.component";
|
|
23
|
+
import * as i15 from "../../input-components/tsi-integer/tsi-integer.component";
|
|
24
|
+
import * as i16 from "../../input-components/tsi-text-area/tsi-text-area.component";
|
|
25
|
+
import * as i17 from "../../input-components/tsi-text-box/tsi-text-box.component";
|
|
26
|
+
import * as i18 from "../../output-components/tsi-label/tsi-label.component";
|
|
27
|
+
import * as i19 from "../../tsi-modal-footer/tsi-modal-footer.component";
|
|
28
|
+
import * as i20 from "../../tsi-form/tsi-form.component";
|
|
29
|
+
import * as i21 from "../../../pipes/localize.pipe";
|
|
22
30
|
export class AddReportPopupComponent extends TsiFormComponentBaseComponent {
|
|
23
31
|
get isReportForFiche() {
|
|
24
32
|
return !this.config.data?.fromEndpoint?.includes("getallpaged") && this.config.data?.fromEndpoint != undefined;
|
|
25
33
|
}
|
|
26
|
-
constructor(ref, reportingService, config, notificationService, dashboardModuleService, _confirm) {
|
|
34
|
+
constructor(ref, reportingService, config, notificationService, dashboardModuleService, _confirm, _httpClient, _router) {
|
|
27
35
|
super(ref, config);
|
|
28
36
|
this.ref = ref;
|
|
29
37
|
this.reportingService = reportingService;
|
|
@@ -31,6 +39,8 @@ export class AddReportPopupComponent extends TsiFormComponentBaseComponent {
|
|
|
31
39
|
this.notificationService = notificationService;
|
|
32
40
|
this.dashboardModuleService = dashboardModuleService;
|
|
33
41
|
this._confirm = _confirm;
|
|
42
|
+
this._httpClient = _httpClient;
|
|
43
|
+
this._router = _router;
|
|
34
44
|
this.dataSource = [
|
|
35
45
|
{ key: TsiReportType.List, value: "End user report" },
|
|
36
46
|
{ key: TsiReportType.Dashboard, value: "Dashboard" },
|
|
@@ -40,6 +50,9 @@ export class AddReportPopupComponent extends TsiFormComponentBaseComponent {
|
|
|
40
50
|
this.modes = Modes;
|
|
41
51
|
this.isEditionPersonnalise = false;
|
|
42
52
|
this.administrationEndpoints = AdministrationEndpoints;
|
|
53
|
+
this.selectedEndpoints = [];
|
|
54
|
+
this.endpointsOptions = [];
|
|
55
|
+
this.enableMultiSelectEndpoints = false;
|
|
43
56
|
this._isReportForFiche = false;
|
|
44
57
|
this.report = {
|
|
45
58
|
reportType: '',
|
|
@@ -58,6 +71,7 @@ export class AddReportPopupComponent extends TsiFormComponentBaseComponent {
|
|
|
58
71
|
this.modules = [];
|
|
59
72
|
}
|
|
60
73
|
ngOnInit() {
|
|
74
|
+
this.enableMultiSelectEndpoints = this._router.url.includes('edition-personalisee');
|
|
61
75
|
if (this.config.data.value) {
|
|
62
76
|
console.log(">>> this.config.data: ", this.config.data);
|
|
63
77
|
this.report.reportType = this.config.data.value.reportType;
|
|
@@ -69,6 +83,14 @@ export class AddReportPopupComponent extends TsiFormComponentBaseComponent {
|
|
|
69
83
|
this.report.formName = this.config.data.value.formName;
|
|
70
84
|
this.report.reportNameAbrege = this.config.data.value.shortName;
|
|
71
85
|
this.report.display = this.config.data.value.display;
|
|
86
|
+
if (this.enableMultiSelectEndpoints) {
|
|
87
|
+
this.endpointsOptions = this.report.endPointKey
|
|
88
|
+
? this.report.endPointKey.split(';').map(x => ({ label: x, value: x }))
|
|
89
|
+
: [];
|
|
90
|
+
this.selectedEndpoints = this.report.endPointKey
|
|
91
|
+
? this.report.endPointKey.split(';')
|
|
92
|
+
: [];
|
|
93
|
+
}
|
|
72
94
|
}
|
|
73
95
|
this.reportBusinessClass = this.config.data?.businessClass;
|
|
74
96
|
this.customReportingMode = this.config.data?.customReportingMode;
|
|
@@ -96,7 +118,42 @@ export class AddReportPopupComponent extends TsiFormComponentBaseComponent {
|
|
|
96
118
|
reportTypeChange(evt) {
|
|
97
119
|
console.log(evt);
|
|
98
120
|
}
|
|
121
|
+
async handleOpen() {
|
|
122
|
+
try {
|
|
123
|
+
const data = await firstValueFrom(this._httpClient.get(encodeURI(this.administrationEndpoints.getAllApiAsKeyValuePair())));
|
|
124
|
+
this.endpointsOptions = data || [];
|
|
125
|
+
this.endpointsOptions = [...this.selectedEndpoints.map(x => ({ label: x, value: x })),
|
|
126
|
+
...this.endpointsOptions];
|
|
127
|
+
}
|
|
128
|
+
catch (error) {
|
|
129
|
+
console.error('Error loading endpoints:', error);
|
|
130
|
+
this.endpointsOptions = [];
|
|
131
|
+
}
|
|
132
|
+
}
|
|
133
|
+
async onFilter(event) {
|
|
134
|
+
try {
|
|
135
|
+
const params = this._generateHttpParams(event?.filter);
|
|
136
|
+
const data = await firstValueFrom(this._httpClient.get(encodeURI(this.administrationEndpoints.getAllApiAsKeyValuePair()), { params }));
|
|
137
|
+
this.endpointsOptions = data || [];
|
|
138
|
+
this.endpointsOptions = [...this.selectedEndpoints.map(x => ({ label: x, value: x })), ...this.endpointsOptions];
|
|
139
|
+
}
|
|
140
|
+
catch (error) {
|
|
141
|
+
console.error('Error loading endpoints:', error);
|
|
142
|
+
this.endpointsOptions = [];
|
|
143
|
+
}
|
|
144
|
+
}
|
|
145
|
+
_generateHttpParams(filter) {
|
|
146
|
+
let params = new HttpParams();
|
|
147
|
+
if (filter) {
|
|
148
|
+
params = params.set('value', filter);
|
|
149
|
+
}
|
|
150
|
+
return params;
|
|
151
|
+
}
|
|
99
152
|
save() {
|
|
153
|
+
if (this.enableMultiSelectEndpoints) {
|
|
154
|
+
this.report.endPointKey = this.selectedEndpoints.join(';');
|
|
155
|
+
this.report.endPointValue = this.selectedEndpoints.join(';');
|
|
156
|
+
}
|
|
100
157
|
super.save();
|
|
101
158
|
if (this.report.reportType === '') {
|
|
102
159
|
this.notificationService.warn("shared_reporting_report_type_required");
|
|
@@ -138,11 +195,11 @@ export class AddReportPopupComponent extends TsiFormComponentBaseComponent {
|
|
|
138
195
|
}
|
|
139
196
|
});
|
|
140
197
|
}
|
|
141
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: AddReportPopupComponent, deps: [{ token: i1.DynamicDialogRef }, { token: i2.ReportingService }, { token: i1.DynamicDialogConfig }, { token: i3.TsiNotificationService }, { token: i4.DashboardModuleService }, { token: i5.TsiConfirmationService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
142
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: AddReportPopupComponent, selector: "app-add-report-popup", providers: [...appProviders], usesInheritance: true, ngImport: i0, template: "<form class=\"form-horizontal\" autocomplete=\"off\" #reportForm=\"ngForm\">\r\n <h4>\r\n <Tsi-Label [labelValue]=\"'Nouveau Rapport'\"></Tsi-Label>\r\n </h4>\r\n <p-panel header=\"Informations\">\r\n <div class=\"grid \">\r\n <!-- Type -->\r\n <div class=\"col-3 col-form-label\">\r\n <Tsi-Label labelValue=\"administration_edition_personnalise_type\"></Tsi-Label>\r\n </div>\r\n <div class=\"col-9\">\r\n <Tsi-Search-Combo [disabled]=\"this.mode !== modes.create\" id-field=\"key\" label-field=\"value\"\r\n [(bind)]=\"report.reportType\" [datasource]=\"dataSource\">\r\n </Tsi-Search-Combo>\r\n </div>\r\n <!-- Nom du rapport -->\r\n <div class=\"col-3 col-form-label\">\r\n <Tsi-Label labelValue=\"administration_edition_personnalise_reportName\"></Tsi-Label>\r\n </div>\r\n <div class=\"col-9\">\r\n <Tsi-Text-Box [inputName]=\"'reportName'\" [(inputField)]=\"report.reportName\"></Tsi-Text-Box>\r\n </div>\r\n <!-- Nom abr\u00E9g\u00E9 -->\r\n <div class=\"col-3 col-form-label\">\r\n <Tsi-Label labelValue=\"administration_edition_personnalise_reportNameAbrege\"></Tsi-Label>\r\n </div>\r\n <div class=\"col-3\">\r\n <Tsi-Text-Box [inputName]=\"'reportNameAbrege'\" [(inputField)]=\"report.reportNameAbrege\"></Tsi-Text-Box>\r\n </div>\r\n <div class=\"flex col-6\">\r\n <!-- Ordre de tri -->\r\n <div class=\"flex gap-4 w-6\">\r\n <Tsi-Label labelValue=\"administration_edition_personnalise_triOrdre\"></Tsi-Label>\r\n <Tsi-Integer [inputName]=\"'triOrdre'\" [(inputField)]=\"report.triOrdre\"></Tsi-Integer>\r\n </div>\r\n <!-- Afficher dashboard -->\r\n <div class=\"flex gap-4 w-6\">\r\n <Tsi-Label labelValue=\"administration_edition_personnalise_display\"></Tsi-Label>\r\n <Tsi-CheckBox [inputName]=\"'display'\" [(inputField)]=\"report.display\"></Tsi-CheckBox>\r\n </div>\r\n </div>\r\n <!-- Module -->\r\n <div class=\"col-3 col-form-label\">\r\n <Tsi-Label labelValue=\"administration_edition_personnalise_Module\"></Tsi-Label>\r\n </div>\r\n <div class=\"col-9\">\r\n <Tsi-Search-Combo id-field=\"code\" label-field=\"libelle\" [multiple]=\"false\" [(bind)]=\"report.module\"\r\n [datasource]=\"modules\" [isFiltered]=\"false\">\r\n </Tsi-Search-Combo>\r\n </div>\r\n <!-- Deuxi\u00E9me Impress -->\r\n <div class=\"col-3 col-form-label\">\r\n <Tsi-Label labelValue=\"administration_edition_personnalise_imppress\"></Tsi-Label>\r\n </div>\r\n <div class=\"col-5\">\r\n <Tsi-Text-Box [disabled]=\"true\" [inputName]=\"'imppress'\" [(inputField)]=\"report.impress\"></Tsi-Text-Box>\r\n </div>\r\n <!-- Edition unique -->\r\n <div class=\"col-4 col-form-label flx\">\r\n <Tsi-CheckBox [inputName]=\"'EditionUnique'\" [(inputField)]=\"report.editionUnique\"></Tsi-CheckBox> \r\n <Tsi-Label labelValue=\"administration_edition_personnalise_EditionUnique\"></Tsi-Label>\r\n </div>\r\n <!-- Endpoint -->\r\n <div class=\"col-3 col-form-label\">\r\n <Tsi-Label labelValue=\"administration_edition_personnalise_endpoint\"></Tsi-Label>\r\n </div>\r\n <div class=\"col-9\">\r\n <Tsi-Search-Combo *ngIf=\"!isReportForFiche\" id-field=\"key\" label-field=\"value\"\r\n [disabled]=\"modes.edit === mode || isEditionPersonnalise === false\"\r\n (selectedLabelChange)=\"selectedEndpointChange($event)\" [(bind)]=\"report.endPointKey\"\r\n [elementSourceUrl]=\"administrationEndpoints.getApiAsKeyValuePair()\"\r\n [listSourceUrl]=\"administrationEndpoints.getAllApiAsKeyValuePair()\" [isFiltered]=\"true\">\r\n </Tsi-Search-Combo>\r\n\r\n <Tsi-Search-Combo *ngIf=\"isReportForFiche || customReportingMode\" id-field=\"value\" label-field=\"value\"\r\n (selectedLabelChange)=\"selectedEndpointChange($event)\" [(bind)]=\"report.endPointKey\"\r\n [listSourceUrl]=\"administrationEndpoints.getAllApiAsKeyValuePairByBusinessClassName(this.reportBusinessClass)\"\r\n [isFiltered]=\"false\">\r\n </Tsi-Search-Combo>\r\n </div>\r\n\r\n <div class=\"col-3 col-form-label\">\r\n <Tsi-Label labelValue=\"administration_edition_personnalise_formName\"></Tsi-Label>\r\n </div>\r\n <div class=\"col-6\">\r\n <Tsi-Text-Box [disabled]=\"true\" [inputName]=\"'formName'\"\r\n [(inputField)]=\"report.formName\"></Tsi-Text-Box>\r\n </div>\r\n <!-- Param -->\r\n <div *ngIf=\"isGetByIdRequest\" class=\"col-3 col-form-label\">\r\n <Tsi-Label labelValue=\"administration_edition_personnalise_param\"></Tsi-Label>\r\n </div>\r\n <div *ngIf=\"isGetByIdRequest\" class=\"col-9\">\r\n <Tsi-Text-Box [inputName]=\"'param'\" [(inputField)]=\"report.param\"></Tsi-Text-Box>\r\n </div>\r\n </div>\r\n </p-panel>\r\n <br />\r\n <p-panel header=\"Configuration Pivot Grid\">\r\n <div class=\"grid \">\r\n <!-- Class or view -->\r\n <div class=\"col-3 col-form-label\">\r\n <Tsi-Label [labelValue]=\"'Class or view'\"></Tsi-Label>\r\n </div>\r\n <div class=\"col-9\">\r\n <Tsi-Text-Box [inputName]=\"'dddd'\"></Tsi-Text-Box>\r\n </div>\r\n <!-- Query -->\r\n <div class=\"col-3 col-form-label\">\r\n <Tsi-Label [labelValue]=\"'Query'\"></Tsi-Label>\r\n </div>\r\n <div class=\"col-9 col-form-label\">\r\n <Tsi-Text-Area [rows]=\"2\"></Tsi-Text-Area>\r\n </div>\r\n </div>\r\n </p-panel>\r\n\r\n <Tsi-Modal-Footer [cancelDisabled]=\"saving\" [saveDisabled]=\"saving\" (onSaveClick)=\"save()\" (onCancelClick)=\"hide()\"></Tsi-Modal-Footer>\r\n</form>", styles: [".flx{display:flex;justify-content:center;align-items:center}\n"], dependencies: [{ kind: "directive", type: i6.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i7.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i7.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i7.NgForm, selector: "form:not([ngNoForm]):not([formGroup]),ng-form,[ngForm]", inputs: ["ngFormOptions"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "component", type: i8.Panel, selector: "p-panel", inputs: ["toggleable", "header", "collapsed", "style", "styleClass", "iconPos", "expandIcon", "collapseIcon", "showHeader", "toggler", "transitionOptions"], outputs: ["collapsedChange", "onBeforeToggle", "onAfterToggle"] }, { kind: "component", type: i9.TsiSearchComboComponent, selector: "Tsi-Search-Combo", inputs: ["elementSourceUrl", "listSourceUrl", "id-field", "label-field", "multiple", "sort", "showClear", "reloadDataSource", "isFiltered", "selectedLabel", "maxWidth", "businessClass", "comboType", "statusMetadata", "currentRowItem", "datasource", "bind", "showSearchButton", "showAddButton", "showConsultButton", "showUpdateButton"], outputs: ["bindChange", "datasource-loaded", "init", "isLoaded", "selectedLabelChange", "onClick", "onSearchButtonClick"] }, { kind: "component", type: i10.TsiCheckboxComponent, selector: "Tsi-CheckBox", inputs: ["class", "isBinary", "checked", "tooltipText", "tooltipPosition"], outputs: ["inputFieldChange", "checkedChange"] }, { kind: "component", type: i11.TsiIntegerComponent, selector: "Tsi-Integer", inputs: ["class", "minValue", "maxValue", "delayChangeTime"], outputs: ["newItemEvent", "inputFieldChange"] }, { kind: "component", type: i12.TsiTextAreaComponent, selector: "Tsi-Text-Area", inputs: ["rows", "cols"], outputs: ["newItemEvent", "inputFieldChange"] }, { kind: "component", type: i13.TsiTextBoxComponent, selector: "Tsi-Text-Box", inputs: ["textBoxType", "autocomplete"], outputs: ["newItemEvent", "inputFieldChange"] }, { kind: "component", type: i14.TsiLabelComponent, selector: "Tsi-Label", inputs: ["labelValue", "styleClass", "infoText"] }, { kind: "component", type: i15.TsiModalFooterComponent, selector: "Tsi-Modal-Footer", inputs: ["cancelDisabled", "saveDisabled", "cancelLabel", "saveLabel", "isConsult", "isDuplicate", "isOnlyCreate"], outputs: ["onCancelClick", "onSaveClick"] }] }); }
|
|
198
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: AddReportPopupComponent, deps: [{ token: i1.DynamicDialogRef }, { token: i2.ReportingService }, { token: i1.DynamicDialogConfig }, { token: i3.TsiNotificationService }, { token: i4.DashboardModuleService }, { token: i5.TsiConfirmationService }, { token: i6.HttpClient }, { token: i7.Router }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
199
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: AddReportPopupComponent, selector: "app-add-report-popup", providers: [...appProviders], usesInheritance: true, ngImport: i0, template: "<tsi-form class=\"form-horizontal\" autocomplete=\"off\">\r\n <h4>\r\n <Tsi-Label [labelValue]=\"'Nouveau Rapport'\"></Tsi-Label>\r\n </h4>\r\n <p-panel header=\"Informations\">\r\n <div class=\"grid \">\r\n <!-- Type -->\r\n <div class=\"col-3 col-form-label\">\r\n <Tsi-Label labelValue=\"administration_edition_personnalise_type\"></Tsi-Label>\r\n </div>\r\n <div class=\"col-9\">\r\n <Tsi-Search-Combo [disabled]=\"this.mode !== modes.create\" id-field=\"key\" label-field=\"value\"\r\n [(bind)]=\"report.reportType\" [datasource]=\"dataSource\">\r\n </Tsi-Search-Combo>\r\n </div>\r\n <!-- Nom du rapport -->\r\n <div class=\"col-3 col-form-label\">\r\n <Tsi-Label labelValue=\"administration_edition_personnalise_reportName\"></Tsi-Label>\r\n </div>\r\n <div class=\"col-9\">\r\n <Tsi-Text-Box [inputName]=\"'reportName'\" [(inputField)]=\"report.reportName\"></Tsi-Text-Box>\r\n </div>\r\n <!-- Nom abr\u00E9g\u00E9 -->\r\n <div class=\"col-3 col-form-label\">\r\n <Tsi-Label labelValue=\"administration_edition_personnalise_reportNameAbrege\"></Tsi-Label>\r\n </div>\r\n <div class=\"col-3\">\r\n <Tsi-Text-Box [inputName]=\"'reportNameAbrege'\" [(inputField)]=\"report.reportNameAbrege\"></Tsi-Text-Box>\r\n </div>\r\n <div class=\"flex col-6\">\r\n <!-- Ordre de tri -->\r\n <div class=\"flex gap-4 w-6\">\r\n <Tsi-Label labelValue=\"administration_edition_personnalise_triOrdre\"></Tsi-Label>\r\n <Tsi-Integer [inputName]=\"'triOrdre'\" [(inputField)]=\"report.triOrdre\"></Tsi-Integer>\r\n </div>\r\n <!-- Afficher dashboard -->\r\n <div class=\"flex gap-4 w-6\">\r\n <Tsi-Label labelValue=\"administration_edition_personnalise_display\"></Tsi-Label>\r\n <Tsi-CheckBox [inputName]=\"'display'\" [(inputField)]=\"report.display\"></Tsi-CheckBox>\r\n </div>\r\n </div>\r\n <!-- Module -->\r\n <div class=\"col-3 col-form-label\">\r\n <Tsi-Label labelValue=\"administration_edition_personnalise_Module\"></Tsi-Label>\r\n </div>\r\n <div class=\"col-9\">\r\n <Tsi-Search-Combo id-field=\"code\" label-field=\"libelle\" [multiple]=\"false\" [(bind)]=\"report.module\"\r\n [datasource]=\"modules\" [isFiltered]=\"false\">\r\n </Tsi-Search-Combo>\r\n </div>\r\n <!-- Deuxi\u00E9me Impress -->\r\n <div class=\"col-3 col-form-label\">\r\n <Tsi-Label labelValue=\"administration_edition_personnalise_imppress\"></Tsi-Label>\r\n </div>\r\n <div class=\"col-5\">\r\n <Tsi-Text-Box [disabled]=\"true\" [inputName]=\"'imppress'\" [(inputField)]=\"report.impress\"></Tsi-Text-Box>\r\n </div>\r\n <!-- Edition unique -->\r\n <div class=\"col-4 col-form-label flx\">\r\n <Tsi-CheckBox [inputName]=\"'EditionUnique'\" [(inputField)]=\"report.editionUnique\"></Tsi-CheckBox> \r\n <Tsi-Label labelValue=\"administration_edition_personnalise_EditionUnique\"></Tsi-Label>\r\n </div>\r\n <!-- Endpoint -->\r\n <div class=\"col-3 col-form-label\">\r\n <Tsi-Label labelValue=\"administration_edition_personnalise_endpoint\"></Tsi-Label>\r\n </div>\r\n <div class=\"col-9\">\r\n <Tsi-Search-Combo *ngIf=\"!isReportForFiche && !enableMultiSelectEndpoints\" id-field=\"key\" label-field=\"value\"\r\n [disabled]=\"modes.edit === mode || isEditionPersonnalise === false\"\r\n (selectedLabelChange)=\"selectedEndpointChange($event)\" [(bind)]=\"report.endPointKey\"\r\n [elementSourceUrl]=\"administrationEndpoints.getApiAsKeyValuePair()\"\r\n [listSourceUrl]=\"administrationEndpoints.getAllApiAsKeyValuePair()\" [isFiltered]=\"true\">\r\n </Tsi-Search-Combo>\r\n\r\n <Tsi-Search-Combo *ngIf=\"(isReportForFiche || customReportingMode) && !enableMultiSelectEndpoints \" id-field=\"value\" label-field=\"value\"\r\n (selectedLabelChange)=\"selectedEndpointChange($event)\" [(bind)]=\"report.endPointKey\"\r\n [listSourceUrl]=\"administrationEndpoints.getAllApiAsKeyValuePairByBusinessClassName(this.reportBusinessClass)\"\r\n [isFiltered]=\"false\">\r\n </Tsi-Search-Combo>\r\n\r\n <p-multiSelect *ngIf=\"enableMultiSelectEndpoints\" [options]=\"endpointsOptions\" [(ngModel)]=\"selectedEndpoints\"\r\n selectedItemsLabel=\"{0} {{ 'endpoint_selected' | localize }}\" optionLabel=\"value\"\r\n optionValue=\"value\"\r\n [style]=\"{'min-width': '180px'}\" placeholder=\"{{ 'shared_reporting_choose_endpoints' | localize }}\"\r\n (onPanelShow)=\"handleOpen()\"\r\n [filter]=\"true\"\r\n (onFilter)=\"onFilter($event)\"\r\n display=\"chip\"\r\n class=\"rounded-multiselect\">\r\n <ng-template let-option pTemplate=\"item\">\r\n <div class=\"flex items-center gap-2\">\r\n <span>{{ option.value}}</span>\r\n </div>\r\n </ng-template>\r\n </p-multiSelect>\r\n </div>\r\n\r\n\r\n <div class=\"col-3 col-form-label\">\r\n <Tsi-Label labelValue=\"administration_edition_personnalise_formName\"></Tsi-Label>\r\n </div>\r\n <div class=\"col-6\">\r\n <Tsi-Text-Box [disabled]=\"true\" [inputName]=\"'formName'\"\r\n [(inputField)]=\"report.formName\"></Tsi-Text-Box>\r\n </div>\r\n <!-- Param -->\r\n <div *ngIf=\"isGetByIdRequest\" class=\"col-3 col-form-label\">\r\n <Tsi-Label labelValue=\"administration_edition_personnalise_param\"></Tsi-Label>\r\n </div>\r\n <div *ngIf=\"isGetByIdRequest\" class=\"col-9\">\r\n <Tsi-Text-Box [inputName]=\"'param'\" [(inputField)]=\"report.param\"></Tsi-Text-Box>\r\n </div>\r\n </div>\r\n </p-panel>\r\n <br />\r\n <p-panel header=\"Configuration Pivot Grid\">\r\n <div class=\"grid \">\r\n <!-- Class or view -->\r\n <div class=\"col-3 col-form-label\">\r\n <Tsi-Label [labelValue]=\"'Class or view'\"></Tsi-Label>\r\n </div>\r\n <div class=\"col-9\">\r\n <Tsi-Text-Box [inputName]=\"'dddd'\"></Tsi-Text-Box>\r\n </div>\r\n <!-- Query -->\r\n <div class=\"col-3 col-form-label\">\r\n <Tsi-Label [labelValue]=\"'Query'\"></Tsi-Label>\r\n </div>\r\n <div class=\"col-9 col-form-label\">\r\n <Tsi-Text-Area [rows]=\"2\"></Tsi-Text-Area>\r\n </div>\r\n </div>\r\n </p-panel>\r\n\r\n <Tsi-Modal-Footer [cancelDisabled]=\"saving\" [saveDisabled]=\"saving\" (onSaveClick)=\"save()\"\r\n (onCancelClick)=\"hide()\"></Tsi-Modal-Footer>\r\n</tsi-form>", styles: [".flx{display:flex;justify-content:center;align-items:center}::ng-deep .rounded-multiselect .p-multiselect{border-radius:12px!important}::ng-deep .rounded-multiselect .p-multiselect-label{border-radius:12px!important}\n"], dependencies: [{ kind: "directive", type: i8.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i9.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i9.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: i10.PrimeTemplate, selector: "[pTemplate]", inputs: ["type", "pTemplate"] }, { kind: "component", type: i11.MultiSelect, selector: "p-multiSelect", inputs: ["id", "ariaLabel", "style", "styleClass", "panelStyle", "panelStyleClass", "inputId", "disabled", "readonly", "group", "filter", "filterPlaceHolder", "filterLocale", "overlayVisible", "tabindex", "variant", "appendTo", "dataKey", "name", "ariaLabelledBy", "displaySelectedLabel", "maxSelectedLabels", "selectionLimit", "selectedItemsLabel", "showToggleAll", "emptyFilterMessage", "emptyMessage", "resetFilterOnHide", "dropdownIcon", "optionLabel", "optionValue", "optionDisabled", "optionGroupLabel", "optionGroupChildren", "showHeader", "filterBy", "scrollHeight", "lazy", "virtualScroll", "loading", "virtualScrollItemSize", "loadingIcon", "virtualScrollOptions", "overlayOptions", "ariaFilterLabel", "filterMatchMode", "tooltip", "tooltipPosition", "tooltipPositionStyle", "tooltipStyleClass", "autofocusFilter", "display", "autocomplete", "showClear", "autofocus", "autoZIndex", "baseZIndex", "showTransitionOptions", "hideTransitionOptions", "defaultLabel", "placeholder", "options", "filterValue", "itemSize", "selectAll", "focusOnHover", "filterFields", "selectOnFocus", "autoOptionFocus"], outputs: ["onChange", "onFilter", "onFocus", "onBlur", "onClick", "onClear", "onPanelShow", "onPanelHide", "onLazyLoad", "onRemove", "onSelectAllChange"] }, { kind: "component", type: i12.Panel, selector: "p-panel", inputs: ["toggleable", "header", "collapsed", "style", "styleClass", "iconPos", "expandIcon", "collapseIcon", "showHeader", "toggler", "transitionOptions"], outputs: ["collapsedChange", "onBeforeToggle", "onAfterToggle"] }, { kind: "component", type: i13.TsiSearchComboComponent, selector: "Tsi-Search-Combo", inputs: ["elementSourceUrl", "listSourceUrl", "id-field", "label-field", "multiple", "sort", "showClear", "reloadDataSource", "isFiltered", "selectedLabel", "maxWidth", "businessClass", "comboType", "statusMetadata", "currentRowItem", "datasource", "bind", "showSearchButton", "showAddButton", "showConsultButton", "showUpdateButton"], outputs: ["bindChange", "datasource-loaded", "init", "isLoaded", "selectedLabelChange", "onClick", "onSearchButtonClick"] }, { kind: "component", type: i14.TsiCheckboxComponent, selector: "Tsi-CheckBox", inputs: ["class", "isBinary", "checked", "tooltipText", "tooltipPosition"], outputs: ["inputFieldChange", "checkedChange"] }, { kind: "component", type: i15.TsiIntegerComponent, selector: "Tsi-Integer", inputs: ["class", "minValue", "maxValue", "delayChangeTime"], outputs: ["newItemEvent", "inputFieldChange"] }, { kind: "component", type: i16.TsiTextAreaComponent, selector: "Tsi-Text-Area", inputs: ["rows", "cols"], outputs: ["newItemEvent", "inputFieldChange"] }, { kind: "component", type: i17.TsiTextBoxComponent, selector: "Tsi-Text-Box", inputs: ["textBoxType", "autocomplete"], outputs: ["newItemEvent", "inputFieldChange"] }, { kind: "component", type: i18.TsiLabelComponent, selector: "Tsi-Label", inputs: ["labelValue", "styleClass", "infoText"] }, { kind: "component", type: i19.TsiModalFooterComponent, selector: "Tsi-Modal-Footer", inputs: ["cancelDisabled", "saveDisabled", "cancelLabel", "saveLabel", "isConsult", "isDuplicate", "isOnlyCreate"], outputs: ["onCancelClick", "onSaveClick"] }, { kind: "component", type: i20.TsiFormComponent, selector: "tsi-form", inputs: ["class", "autocomplete", "optionalEndpoints", "disabled", "isLoading", "modalSize", "formEndpoint", "formName", "isReportingToolbarDisabled", "isCreateOnly"], outputs: ["onSave", "onSubmit", "onSubmitFormWorkflowConfiguration", "formRefChange", "onStatusChange"] }, { kind: "pipe", type: i21.LocalizePipe, name: "localize" }] }); }
|
|
143
200
|
}
|
|
144
201
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: AddReportPopupComponent, decorators: [{
|
|
145
202
|
type: Component,
|
|
146
|
-
args: [{ selector: 'app-add-report-popup', providers: [...appProviders], template: "<form class=\"form-horizontal\" autocomplete=\"off\"
|
|
147
|
-
}], ctorParameters: () => [{ type: i1.DynamicDialogRef }, { type: i2.ReportingService }, { type: i1.DynamicDialogConfig }, { type: i3.TsiNotificationService }, { type: i4.DashboardModuleService }, { type: i5.TsiConfirmationService }] });
|
|
148
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"add-report-popup.component.js","sourceRoot":"","sources":["../../../../../../../projects/tsi-shared-ui/src/lib/tsi-components/manage-reporting/add-report-popup/add-report-popup.component.ts","../../../../../../../projects/tsi-shared-ui/src/lib/tsi-components/manage-reporting/add-report-popup/add-report-popup.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit } from '@angular/core';\r\nimport { DynamicDialogConfig, DynamicDialogRef } from 'primeng/dynamicdialog';\r\nimport { AdministrationEndpoints } from '../../../end-points';\r\nimport { TsiReportType, Modes } from '../../../enums';\r\nimport { TsiFormComponentBaseComponent } from '../../../tsi-base/components/tsi-form-base/tsi-form-base.component';\r\nimport { DashboardModuleService } from '../../../services/reporting/dashboard-module.service';\r\nimport { appProviders } from '../../../consts/app-providers';\r\nimport { ReportingService } from '../../../services/reporting/reporting.service';\r\nimport { TsiNotificationService } from '../../../services/notification/tsi-notification.service';\r\nimport { TsiConfirmationService } from '../../../services/notification/tsi-confirmation.service';\r\n\r\n@Component({\r\n  selector: 'app-add-report-popup',\r\n  templateUrl: './add-report-popup.component.html',\r\n  styleUrls: ['./add-report-popup.component.scss'],\r\n  providers: [...appProviders]\r\n})\r\nexport class AddReportPopupComponent extends TsiFormComponentBaseComponent implements OnInit {\r\n\r\n  dataSource: { key: TsiReportType, value: string }[] = [\r\n    { key: TsiReportType.List, value: \"End user report\" },\r\n    { key: TsiReportType.Dashboard, value: \"Dashboard\" },\r\n    { key: TsiReportType.RTF, value: \"RTF\" }\r\n  ];\r\n\r\n  isGetByIdRequest: boolean = false;\r\n  modes = Modes;\r\n  isEditionPersonnalise: boolean = false;\r\n  administrationEndpoints = AdministrationEndpoints;\r\n  reportBusinessClass?: string\r\n  customReportingMode?: boolean\r\n\r\n  private _isReportForFiche: boolean = false;\r\n\r\n  get isReportForFiche(): boolean {\r\n    return !this.config.data?.fromEndpoint?.includes(\"getallpaged\") && this.config.data?.fromEndpoint != undefined\r\n  }\r\n\r\n  report = {\r\n    reportType: '',\r\n    reportName: '',\r\n    reportNameAbrege: '',\r\n    triOrdre: 0,\r\n    module: '',\r\n    impress: '',\r\n    editionUnique: false,\r\n    endPointKey: '',\r\n    endPointValue: '',\r\n    param: '',\r\n    formName: '',\r\n    display: false,\r\n  }\r\n\r\n  modules: any[] = [];\r\n\r\n  constructor(\r\n    public override ref: DynamicDialogRef,\r\n    public reportingService: ReportingService,\r\n    public override config: DynamicDialogConfig,\r\n    private notificationService: TsiNotificationService,\r\n    private dashboardModuleService: DashboardModuleService,\r\n    private _confirm: TsiConfirmationService,\r\n  ) {\r\n    super(ref, config);\r\n  }\r\n\r\n  override ngOnInit(): void {\r\n\r\n    if (this.config.data.value) {\r\n      console.log(\">>> this.config.data: \", this.config.data);\r\n      this.report.reportType = this.config.data.value.reportType;\r\n      this.report.reportName = this.config.data.value.name;\r\n      this.report.endPointKey = this.config.data.value?.restEndpoint;\r\n      this.report.endPointValue = this.config.data.value?.restEndpoint;\r\n      this.report.module = this.config.data.value.module;\r\n      this.report.triOrdre = this.config.data.value.order;\r\n      this.report.formName = this.config.data.value.formName;\r\n      this.report.reportNameAbrege = this.config.data.value.shortName;\r\n      this.report.display = this.config.data.value.display;\r\n    }\r\n\r\n    this.reportBusinessClass = this.config.data?.businessClass\r\n    this.customReportingMode = this.config.data?.customReportingMode\r\n\r\n    if (this.customReportingMode) {\r\n      this.report.endPointKey = this.config.data?.fromEndpoint\r\n      this.report.endPointValue = this.config.data?.fromEndpoint\r\n    }\r\n\r\n\r\n    if (this.config.data?.fromEndpoint && !this.isReportForFiche && !this.customReportingMode) {\r\n      this.reportingService.getApiAsKeyValueByValue(encodeURIComponent(this.config.data.fromEndpoint)).subscribe({\r\n        next: (res: any) => {\r\n          console.log(res)\r\n          this.report.endPointKey = res[0]?.key;\r\n          this.report.endPointValue = res[0]?.value;\r\n        },\r\n        error: (err) => {\r\n          console.log(err)\r\n        }\r\n      })\r\n    }\r\n\r\n    this.mode = this.config.data.mode\r\n    this.isEditionPersonnalise = this.config.data.isEditionPersonnalise\r\n    console.log(this.mode)\r\n\r\n    this.getAllModules();\r\n  }\r\n\r\n  reportTypeChange(evt: any) {\r\n    console.log(evt)\r\n  }\r\n\r\n  override save(): void {\r\n    super.save()\r\n    if (this.report.reportType === '') {\r\n      this.notificationService.warn(\"shared_reporting_report_type_required\");\r\n      return;\r\n    }\r\n    else if (this.report.reportName === '') {\r\n      this.notificationService.warn(\"shared_reporting_report_name_required\");\r\n      return;\r\n    }\r\n    else if (this.isEditionPersonnalise && this.report.endPointKey === '') {\r\n      this.notificationService.warn(\"shared_reporting_report_endpoint_required\");\r\n      return;\r\n    }\r\n\r\n    this._confirm\r\n      .confirm(this.l('shared_reporting_report_confirmRedirection'), undefined, (result: boolean) => {\r\n\r\n\r\n        if (result) {\r\n          localStorage.setItem('canRedirect', JSON.stringify(true));\r\n          this.hide(this.report);\r\n        } else {\r\n          localStorage.setItem('canRedirect', JSON.stringify(false));\r\n          this.hide(this.report)\r\n        }\r\n      }\r\n      );\r\n\r\n  }\r\n\r\n  selectedEndpointChange(endpointValue: any) {\r\n    console.log(this.report)\r\n    this.report.endPointValue = endpointValue;\r\n    this.isGetByIdRequest = endpointValue.includes(\"{id}\");\r\n  }\r\n\r\n  private getAllModules(): void {\r\n    this.dashboardModuleService\r\n      .getAllModules()\r\n      .subscribe(\r\n        {\r\n          next: (values: any[]) => {\r\n            if (values && Array.isArray(values) && values.length > 0) {\r\n              this.modules = values;\r\n            }\r\n          }\r\n        }\r\n      )\r\n  }\r\n}\r\n","<form class=\"form-horizontal\" autocomplete=\"off\" #reportForm=\"ngForm\">\r\n    <h4>\r\n        <Tsi-Label [labelValue]=\"'Nouveau Rapport'\"></Tsi-Label>\r\n    </h4>\r\n    <p-panel header=\"Informations\">\r\n        <div class=\"grid \">\r\n            <!-- Type -->\r\n            <div class=\"col-3 col-form-label\">\r\n                <Tsi-Label labelValue=\"administration_edition_personnalise_type\"></Tsi-Label>\r\n            </div>\r\n            <div class=\"col-9\">\r\n                <Tsi-Search-Combo [disabled]=\"this.mode !== modes.create\" id-field=\"key\" label-field=\"value\"\r\n                    [(bind)]=\"report.reportType\" [datasource]=\"dataSource\">\r\n                </Tsi-Search-Combo>\r\n            </div>\r\n            <!-- Nom du rapport -->\r\n            <div class=\"col-3 col-form-label\">\r\n                <Tsi-Label labelValue=\"administration_edition_personnalise_reportName\"></Tsi-Label>\r\n            </div>\r\n            <div class=\"col-9\">\r\n                <Tsi-Text-Box [inputName]=\"'reportName'\" [(inputField)]=\"report.reportName\"></Tsi-Text-Box>\r\n            </div>\r\n            <!-- Nom abrégé -->\r\n            <div class=\"col-3 col-form-label\">\r\n                <Tsi-Label labelValue=\"administration_edition_personnalise_reportNameAbrege\"></Tsi-Label>\r\n            </div>\r\n            <div class=\"col-3\">\r\n                <Tsi-Text-Box [inputName]=\"'reportNameAbrege'\" [(inputField)]=\"report.reportNameAbrege\"></Tsi-Text-Box>\r\n            </div>\r\n            <div class=\"flex col-6\">\r\n                <!-- Ordre de tri -->\r\n                <div class=\"flex gap-4 w-6\">\r\n                    <Tsi-Label labelValue=\"administration_edition_personnalise_triOrdre\"></Tsi-Label>\r\n                    <Tsi-Integer [inputName]=\"'triOrdre'\" [(inputField)]=\"report.triOrdre\"></Tsi-Integer>\r\n                </div>\r\n                <!-- Afficher dashboard -->\r\n                <div class=\"flex gap-4 w-6\">\r\n                    <Tsi-Label labelValue=\"administration_edition_personnalise_display\"></Tsi-Label>\r\n                    <Tsi-CheckBox [inputName]=\"'display'\" [(inputField)]=\"report.display\"></Tsi-CheckBox>\r\n                </div>\r\n            </div>\r\n            <!-- Module -->\r\n            <div class=\"col-3 col-form-label\">\r\n                <Tsi-Label labelValue=\"administration_edition_personnalise_Module\"></Tsi-Label>\r\n            </div>\r\n            <div class=\"col-9\">\r\n                <Tsi-Search-Combo id-field=\"code\" label-field=\"libelle\" [multiple]=\"false\" [(bind)]=\"report.module\"\r\n                    [datasource]=\"modules\" [isFiltered]=\"false\">\r\n                </Tsi-Search-Combo>\r\n            </div>\r\n            <!-- Deuxiéme Impress -->\r\n            <div class=\"col-3 col-form-label\">\r\n                <Tsi-Label labelValue=\"administration_edition_personnalise_imppress\"></Tsi-Label>\r\n            </div>\r\n            <div class=\"col-5\">\r\n                <Tsi-Text-Box [disabled]=\"true\" [inputName]=\"'imppress'\" [(inputField)]=\"report.impress\"></Tsi-Text-Box>\r\n            </div>\r\n            <!-- Edition unique -->\r\n            <div class=\"col-4 col-form-label flx\">\r\n                <Tsi-CheckBox [inputName]=\"'EditionUnique'\" [(inputField)]=\"report.editionUnique\"></Tsi-CheckBox>&nbsp;\r\n                <Tsi-Label labelValue=\"administration_edition_personnalise_EditionUnique\"></Tsi-Label>\r\n            </div>\r\n            <!-- Endpoint -->\r\n            <div class=\"col-3 col-form-label\">\r\n                <Tsi-Label labelValue=\"administration_edition_personnalise_endpoint\"></Tsi-Label>\r\n            </div>\r\n            <div class=\"col-9\">\r\n                <Tsi-Search-Combo *ngIf=\"!isReportForFiche\" id-field=\"key\" label-field=\"value\"\r\n                    [disabled]=\"modes.edit === mode || isEditionPersonnalise === false\"\r\n                    (selectedLabelChange)=\"selectedEndpointChange($event)\" [(bind)]=\"report.endPointKey\"\r\n                    [elementSourceUrl]=\"administrationEndpoints.getApiAsKeyValuePair()\"\r\n                    [listSourceUrl]=\"administrationEndpoints.getAllApiAsKeyValuePair()\" [isFiltered]=\"true\">\r\n                </Tsi-Search-Combo>\r\n\r\n                <Tsi-Search-Combo *ngIf=\"isReportForFiche || customReportingMode\" id-field=\"value\" label-field=\"value\"\r\n                    (selectedLabelChange)=\"selectedEndpointChange($event)\" [(bind)]=\"report.endPointKey\"\r\n                    [listSourceUrl]=\"administrationEndpoints.getAllApiAsKeyValuePairByBusinessClassName(this.reportBusinessClass)\"\r\n                    [isFiltered]=\"false\">\r\n                </Tsi-Search-Combo>\r\n            </div>\r\n\r\n            <div class=\"col-3 col-form-label\">\r\n                <Tsi-Label labelValue=\"administration_edition_personnalise_formName\"></Tsi-Label>\r\n            </div>\r\n            <div class=\"col-6\">\r\n                <Tsi-Text-Box [disabled]=\"true\" [inputName]=\"'formName'\"\r\n                    [(inputField)]=\"report.formName\"></Tsi-Text-Box>\r\n            </div>\r\n            <!-- Param -->\r\n            <div *ngIf=\"isGetByIdRequest\" class=\"col-3 col-form-label\">\r\n                <Tsi-Label labelValue=\"administration_edition_personnalise_param\"></Tsi-Label>\r\n            </div>\r\n            <div *ngIf=\"isGetByIdRequest\" class=\"col-9\">\r\n                <Tsi-Text-Box [inputName]=\"'param'\" [(inputField)]=\"report.param\"></Tsi-Text-Box>\r\n            </div>\r\n        </div>\r\n    </p-panel>\r\n    <br />\r\n    <p-panel header=\"Configuration Pivot Grid\">\r\n        <div class=\"grid \">\r\n            <!-- Class or view -->\r\n            <div class=\"col-3 col-form-label\">\r\n                <Tsi-Label [labelValue]=\"'Class or view'\"></Tsi-Label>\r\n            </div>\r\n            <div class=\"col-9\">\r\n                <Tsi-Text-Box [inputName]=\"'dddd'\"></Tsi-Text-Box>\r\n            </div>\r\n            <!-- Query -->\r\n            <div class=\"col-3 col-form-label\">\r\n                <Tsi-Label [labelValue]=\"'Query'\"></Tsi-Label>\r\n            </div>\r\n            <div class=\"col-9 col-form-label\">\r\n                <Tsi-Text-Area [rows]=\"2\"></Tsi-Text-Area>\r\n            </div>\r\n        </div>\r\n    </p-panel>\r\n\r\n    <Tsi-Modal-Footer [cancelDisabled]=\"saving\" [saveDisabled]=\"saving\" (onSaveClick)=\"save()\" (onCancelClick)=\"hide()\"></Tsi-Modal-Footer>\r\n</form>"]}
|
|
203
|
+
args: [{ selector: 'app-add-report-popup', providers: [...appProviders], template: "<tsi-form class=\"form-horizontal\" autocomplete=\"off\">\r\n <h4>\r\n <Tsi-Label [labelValue]=\"'Nouveau Rapport'\"></Tsi-Label>\r\n </h4>\r\n <p-panel header=\"Informations\">\r\n <div class=\"grid \">\r\n <!-- Type -->\r\n <div class=\"col-3 col-form-label\">\r\n <Tsi-Label labelValue=\"administration_edition_personnalise_type\"></Tsi-Label>\r\n </div>\r\n <div class=\"col-9\">\r\n <Tsi-Search-Combo [disabled]=\"this.mode !== modes.create\" id-field=\"key\" label-field=\"value\"\r\n [(bind)]=\"report.reportType\" [datasource]=\"dataSource\">\r\n </Tsi-Search-Combo>\r\n </div>\r\n <!-- Nom du rapport -->\r\n <div class=\"col-3 col-form-label\">\r\n <Tsi-Label labelValue=\"administration_edition_personnalise_reportName\"></Tsi-Label>\r\n </div>\r\n <div class=\"col-9\">\r\n <Tsi-Text-Box [inputName]=\"'reportName'\" [(inputField)]=\"report.reportName\"></Tsi-Text-Box>\r\n </div>\r\n <!-- Nom abr\u00E9g\u00E9 -->\r\n <div class=\"col-3 col-form-label\">\r\n <Tsi-Label labelValue=\"administration_edition_personnalise_reportNameAbrege\"></Tsi-Label>\r\n </div>\r\n <div class=\"col-3\">\r\n <Tsi-Text-Box [inputName]=\"'reportNameAbrege'\" [(inputField)]=\"report.reportNameAbrege\"></Tsi-Text-Box>\r\n </div>\r\n <div class=\"flex col-6\">\r\n <!-- Ordre de tri -->\r\n <div class=\"flex gap-4 w-6\">\r\n <Tsi-Label labelValue=\"administration_edition_personnalise_triOrdre\"></Tsi-Label>\r\n <Tsi-Integer [inputName]=\"'triOrdre'\" [(inputField)]=\"report.triOrdre\"></Tsi-Integer>\r\n </div>\r\n <!-- Afficher dashboard -->\r\n <div class=\"flex gap-4 w-6\">\r\n <Tsi-Label labelValue=\"administration_edition_personnalise_display\"></Tsi-Label>\r\n <Tsi-CheckBox [inputName]=\"'display'\" [(inputField)]=\"report.display\"></Tsi-CheckBox>\r\n </div>\r\n </div>\r\n <!-- Module -->\r\n <div class=\"col-3 col-form-label\">\r\n <Tsi-Label labelValue=\"administration_edition_personnalise_Module\"></Tsi-Label>\r\n </div>\r\n <div class=\"col-9\">\r\n <Tsi-Search-Combo id-field=\"code\" label-field=\"libelle\" [multiple]=\"false\" [(bind)]=\"report.module\"\r\n [datasource]=\"modules\" [isFiltered]=\"false\">\r\n </Tsi-Search-Combo>\r\n </div>\r\n <!-- Deuxi\u00E9me Impress -->\r\n <div class=\"col-3 col-form-label\">\r\n <Tsi-Label labelValue=\"administration_edition_personnalise_imppress\"></Tsi-Label>\r\n </div>\r\n <div class=\"col-5\">\r\n <Tsi-Text-Box [disabled]=\"true\" [inputName]=\"'imppress'\" [(inputField)]=\"report.impress\"></Tsi-Text-Box>\r\n </div>\r\n <!-- Edition unique -->\r\n <div class=\"col-4 col-form-label flx\">\r\n <Tsi-CheckBox [inputName]=\"'EditionUnique'\" [(inputField)]=\"report.editionUnique\"></Tsi-CheckBox> \r\n <Tsi-Label labelValue=\"administration_edition_personnalise_EditionUnique\"></Tsi-Label>\r\n </div>\r\n <!-- Endpoint -->\r\n <div class=\"col-3 col-form-label\">\r\n <Tsi-Label labelValue=\"administration_edition_personnalise_endpoint\"></Tsi-Label>\r\n </div>\r\n <div class=\"col-9\">\r\n <Tsi-Search-Combo *ngIf=\"!isReportForFiche && !enableMultiSelectEndpoints\" id-field=\"key\" label-field=\"value\"\r\n [disabled]=\"modes.edit === mode || isEditionPersonnalise === false\"\r\n (selectedLabelChange)=\"selectedEndpointChange($event)\" [(bind)]=\"report.endPointKey\"\r\n [elementSourceUrl]=\"administrationEndpoints.getApiAsKeyValuePair()\"\r\n [listSourceUrl]=\"administrationEndpoints.getAllApiAsKeyValuePair()\" [isFiltered]=\"true\">\r\n </Tsi-Search-Combo>\r\n\r\n <Tsi-Search-Combo *ngIf=\"(isReportForFiche || customReportingMode) && !enableMultiSelectEndpoints \" id-field=\"value\" label-field=\"value\"\r\n (selectedLabelChange)=\"selectedEndpointChange($event)\" [(bind)]=\"report.endPointKey\"\r\n [listSourceUrl]=\"administrationEndpoints.getAllApiAsKeyValuePairByBusinessClassName(this.reportBusinessClass)\"\r\n [isFiltered]=\"false\">\r\n </Tsi-Search-Combo>\r\n\r\n <p-multiSelect *ngIf=\"enableMultiSelectEndpoints\" [options]=\"endpointsOptions\" [(ngModel)]=\"selectedEndpoints\"\r\n selectedItemsLabel=\"{0} {{ 'endpoint_selected' | localize }}\" optionLabel=\"value\"\r\n optionValue=\"value\"\r\n [style]=\"{'min-width': '180px'}\" placeholder=\"{{ 'shared_reporting_choose_endpoints' | localize }}\"\r\n (onPanelShow)=\"handleOpen()\"\r\n [filter]=\"true\"\r\n (onFilter)=\"onFilter($event)\"\r\n display=\"chip\"\r\n class=\"rounded-multiselect\">\r\n <ng-template let-option pTemplate=\"item\">\r\n <div class=\"flex items-center gap-2\">\r\n <span>{{ option.value}}</span>\r\n </div>\r\n </ng-template>\r\n </p-multiSelect>\r\n </div>\r\n\r\n\r\n <div class=\"col-3 col-form-label\">\r\n <Tsi-Label labelValue=\"administration_edition_personnalise_formName\"></Tsi-Label>\r\n </div>\r\n <div class=\"col-6\">\r\n <Tsi-Text-Box [disabled]=\"true\" [inputName]=\"'formName'\"\r\n [(inputField)]=\"report.formName\"></Tsi-Text-Box>\r\n </div>\r\n <!-- Param -->\r\n <div *ngIf=\"isGetByIdRequest\" class=\"col-3 col-form-label\">\r\n <Tsi-Label labelValue=\"administration_edition_personnalise_param\"></Tsi-Label>\r\n </div>\r\n <div *ngIf=\"isGetByIdRequest\" class=\"col-9\">\r\n <Tsi-Text-Box [inputName]=\"'param'\" [(inputField)]=\"report.param\"></Tsi-Text-Box>\r\n </div>\r\n </div>\r\n </p-panel>\r\n <br />\r\n <p-panel header=\"Configuration Pivot Grid\">\r\n <div class=\"grid \">\r\n <!-- Class or view -->\r\n <div class=\"col-3 col-form-label\">\r\n <Tsi-Label [labelValue]=\"'Class or view'\"></Tsi-Label>\r\n </div>\r\n <div class=\"col-9\">\r\n <Tsi-Text-Box [inputName]=\"'dddd'\"></Tsi-Text-Box>\r\n </div>\r\n <!-- Query -->\r\n <div class=\"col-3 col-form-label\">\r\n <Tsi-Label [labelValue]=\"'Query'\"></Tsi-Label>\r\n </div>\r\n <div class=\"col-9 col-form-label\">\r\n <Tsi-Text-Area [rows]=\"2\"></Tsi-Text-Area>\r\n </div>\r\n </div>\r\n </p-panel>\r\n\r\n <Tsi-Modal-Footer [cancelDisabled]=\"saving\" [saveDisabled]=\"saving\" (onSaveClick)=\"save()\"\r\n (onCancelClick)=\"hide()\"></Tsi-Modal-Footer>\r\n</tsi-form>", styles: [".flx{display:flex;justify-content:center;align-items:center}::ng-deep .rounded-multiselect .p-multiselect{border-radius:12px!important}::ng-deep .rounded-multiselect .p-multiselect-label{border-radius:12px!important}\n"] }]
|
|
204
|
+
}], ctorParameters: () => [{ type: i1.DynamicDialogRef }, { type: i2.ReportingService }, { type: i1.DynamicDialogConfig }, { type: i3.TsiNotificationService }, { type: i4.DashboardModuleService }, { type: i5.TsiConfirmationService }, { type: i6.HttpClient }, { type: i7.Router }] });
|
|
205
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"add-report-popup.component.js","sourceRoot":"","sources":["../../../../../../../projects/tsi-shared-ui/src/lib/tsi-components/manage-reporting/add-report-popup/add-report-popup.component.ts","../../../../../../../projects/tsi-shared-ui/src/lib/tsi-components/manage-reporting/add-report-popup/add-report-popup.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit } from '@angular/core';\r\nimport { DynamicDialogConfig, DynamicDialogRef } from 'primeng/dynamicdialog';\r\nimport { AdministrationEndpoints } from '../../../end-points';\r\nimport { TsiReportType, Modes } from '../../../enums';\r\nimport { TsiFormComponentBaseComponent } from '../../../tsi-base/components/tsi-form-base/tsi-form-base.component';\r\nimport { DashboardModuleService } from '../../../services/reporting/dashboard-module.service';\r\nimport { appProviders } from '../../../consts/app-providers';\r\nimport { ReportingService } from '../../../services/reporting/reporting.service';\r\nimport { TsiNotificationService } from '../../../services/notification/tsi-notification.service';\r\nimport { TsiConfirmationService } from '../../../services/notification/tsi-confirmation.service';\r\nimport { firstValueFrom } from 'rxjs';\r\nimport { HttpClient, HttpParams } from '@angular/common/http';\r\nimport { Router } from '@angular/router';\r\n\r\n@Component({\r\n  selector: 'app-add-report-popup',\r\n  templateUrl: './add-report-popup.component.html',\r\n  styleUrls: ['./add-report-popup.component.scss'],\r\n  providers: [...appProviders]\r\n})\r\nexport class AddReportPopupComponent extends TsiFormComponentBaseComponent implements OnInit {\r\n\r\n  dataSource: { key: TsiReportType, value: string }[] = [\r\n    { key: TsiReportType.List, value: \"End user report\" },\r\n    { key: TsiReportType.Dashboard, value: \"Dashboard\" },\r\n    { key: TsiReportType.RTF, value: \"RTF\" }\r\n  ];\r\n\r\n  isGetByIdRequest: boolean = false;\r\n  modes = Modes;\r\n  isEditionPersonnalise: boolean = false;\r\n  administrationEndpoints = AdministrationEndpoints;\r\n  reportBusinessClass?: string\r\n  customReportingMode?: boolean\r\n\r\n  selectedEndpoints: any[] = []\r\n  endpointsOptions: any[] = []\r\n  enableMultiSelectEndpoints: boolean = false\r\n\r\n  private _isReportForFiche: boolean = false;\r\n\r\n  get isReportForFiche(): boolean {\r\n    return !this.config.data?.fromEndpoint?.includes(\"getallpaged\") && this.config.data?.fromEndpoint != undefined\r\n  }\r\n\r\n  report = {\r\n    reportType: '',\r\n    reportName: '',\r\n    reportNameAbrege: '',\r\n    triOrdre: 0,\r\n    module: '',\r\n    impress: '',\r\n    editionUnique: false,\r\n    endPointKey: '',\r\n    endPointValue: '',\r\n    param: '',\r\n    formName: '',\r\n    display: false,\r\n  }\r\n\r\n  modules: any[] = [];\r\n\r\n  constructor(\r\n    public override ref: DynamicDialogRef,\r\n    public reportingService: ReportingService,\r\n    public override config: DynamicDialogConfig,\r\n    private notificationService: TsiNotificationService,\r\n    private dashboardModuleService: DashboardModuleService,\r\n    private _confirm: TsiConfirmationService,\r\n    private _httpClient: HttpClient,\r\n    private _router: Router\r\n  ) {\r\n    super(ref, config);\r\n  }\r\n\r\n  override ngOnInit(): void {\r\n\r\n    this.enableMultiSelectEndpoints = this._router.url.includes('edition-personalisee');\r\n\r\n    if (this.config.data.value) {\r\n      console.log(\">>> this.config.data: \", this.config.data);\r\n      this.report.reportType = this.config.data.value.reportType;\r\n      this.report.reportName = this.config.data.value.name;\r\n      this.report.endPointKey = this.config.data.value?.restEndpoint;\r\n      this.report.endPointValue = this.config.data.value?.restEndpoint;\r\n      this.report.module = this.config.data.value.module;\r\n      this.report.triOrdre = this.config.data.value.order;\r\n      this.report.formName = this.config.data.value.formName;\r\n      this.report.reportNameAbrege = this.config.data.value.shortName;\r\n      this.report.display = this.config.data.value.display;\r\n\r\n      if (this.enableMultiSelectEndpoints) {\r\n        this.endpointsOptions = this.report.endPointKey\r\n          ? this.report.endPointKey.split(';').map(x => ({ label: x, value: x }))\r\n          : [];\r\n        this.selectedEndpoints = this.report.endPointKey\r\n          ? this.report.endPointKey.split(';')\r\n          : [];\r\n      }\r\n    }\r\n\r\n    this.reportBusinessClass = this.config.data?.businessClass\r\n    this.customReportingMode = this.config.data?.customReportingMode\r\n\r\n    if (this.customReportingMode) {\r\n      this.report.endPointKey = this.config.data?.fromEndpoint\r\n      this.report.endPointValue = this.config.data?.fromEndpoint\r\n    }\r\n\r\n\r\n    if (this.config.data?.fromEndpoint && !this.isReportForFiche && !this.customReportingMode) {\r\n      this.reportingService.getApiAsKeyValueByValue(encodeURIComponent(this.config.data.fromEndpoint)).subscribe({\r\n        next: (res: any) => {\r\n          console.log(res)\r\n          this.report.endPointKey = res[0]?.key;\r\n          this.report.endPointValue = res[0]?.value;\r\n        },\r\n        error: (err) => {\r\n          console.log(err)\r\n        }\r\n      })\r\n    }\r\n\r\n    this.mode = this.config.data.mode\r\n    this.isEditionPersonnalise = this.config.data.isEditionPersonnalise\r\n    console.log(this.mode)\r\n\r\n    this.getAllModules();\r\n  }\r\n\r\n  reportTypeChange(evt: any) {\r\n    console.log(evt)\r\n  }\r\n\r\n  async handleOpen() {\r\n    try {\r\n      const data = await firstValueFrom(\r\n        this._httpClient.get<any[]>(\r\n          encodeURI(this.administrationEndpoints.getAllApiAsKeyValuePair())\r\n        )\r\n      );\r\n\r\n      this.endpointsOptions = data || [];\r\n      this.endpointsOptions = [... this.selectedEndpoints.map(x => ({ label: x, value: x })),\r\n      ...this.endpointsOptions]\r\n    } catch (error) {\r\n      console.error('Error loading endpoints:', error);\r\n      this.endpointsOptions = [];\r\n    }\r\n  }\r\n\r\n  async onFilter(event: any) {\r\n    try {\r\n      const params = this._generateHttpParams(event?.filter);\r\n\r\n      const data = await firstValueFrom(\r\n        this._httpClient.get<any[]>(\r\n          encodeURI(this.administrationEndpoints.getAllApiAsKeyValuePair()),\r\n          { params }\r\n        )\r\n      );\r\n\r\n      this.endpointsOptions = data || [];\r\n      this.endpointsOptions = [...this.selectedEndpoints.map(x => ({ label: x, value: x })), ...this.endpointsOptions]\r\n    } catch (error) {\r\n      console.error('Error loading endpoints:', error);\r\n      this.endpointsOptions = [];\r\n    }\r\n  }\r\n\r\n  _generateHttpParams(filter?: string): HttpParams {\r\n    let params = new HttpParams();\r\n    if (filter) {\r\n      params = params.set('value', filter);\r\n    }\r\n    return params;\r\n  }\r\n\r\n  override save(): void {\r\n\r\n    if (this.enableMultiSelectEndpoints) {\r\n      this.report.endPointKey = this.selectedEndpoints.join(';');\r\n      this.report.endPointValue = this.selectedEndpoints.join(';');\r\n    }\r\n\r\n    super.save()\r\n    \r\n    if (this.report.reportType === '') {\r\n      this.notificationService.warn(\"shared_reporting_report_type_required\");\r\n      return;\r\n    }\r\n    else if (this.report.reportName === '') {\r\n      this.notificationService.warn(\"shared_reporting_report_name_required\");\r\n      return;\r\n    }\r\n    else if (this.isEditionPersonnalise && this.report.endPointKey === '') {\r\n      this.notificationService.warn(\"shared_reporting_report_endpoint_required\");\r\n      return;\r\n    }\r\n\r\n    this._confirm\r\n      .confirm(this.l('shared_reporting_report_confirmRedirection'), undefined, (result: boolean) => {\r\n        if (result) {\r\n          localStorage.setItem('canRedirect', JSON.stringify(true));\r\n          this.hide(this.report);\r\n        } else {\r\n          localStorage.setItem('canRedirect', JSON.stringify(false));\r\n          this.hide(this.report)\r\n        }\r\n      }\r\n      );\r\n\r\n  }\r\n\r\n  selectedEndpointChange(endpointValue: any) {\r\n    console.log(this.report)\r\n    this.report.endPointValue = endpointValue;\r\n    this.isGetByIdRequest = endpointValue.includes(\"{id}\");\r\n  }\r\n\r\n  private getAllModules(): void {\r\n    this.dashboardModuleService\r\n      .getAllModules()\r\n      .subscribe(\r\n        {\r\n          next: (values: any[]) => {\r\n            if (values && Array.isArray(values) && values.length > 0) {\r\n              this.modules = values;\r\n            }\r\n          }\r\n        }\r\n      )\r\n  }\r\n}\r\n","<tsi-form class=\"form-horizontal\" autocomplete=\"off\">\r\n    <h4>\r\n        <Tsi-Label [labelValue]=\"'Nouveau Rapport'\"></Tsi-Label>\r\n    </h4>\r\n    <p-panel header=\"Informations\">\r\n        <div class=\"grid \">\r\n            <!-- Type -->\r\n            <div class=\"col-3 col-form-label\">\r\n                <Tsi-Label labelValue=\"administration_edition_personnalise_type\"></Tsi-Label>\r\n            </div>\r\n            <div class=\"col-9\">\r\n                <Tsi-Search-Combo [disabled]=\"this.mode !== modes.create\" id-field=\"key\" label-field=\"value\"\r\n                    [(bind)]=\"report.reportType\" [datasource]=\"dataSource\">\r\n                </Tsi-Search-Combo>\r\n            </div>\r\n            <!-- Nom du rapport -->\r\n            <div class=\"col-3 col-form-label\">\r\n                <Tsi-Label labelValue=\"administration_edition_personnalise_reportName\"></Tsi-Label>\r\n            </div>\r\n            <div class=\"col-9\">\r\n                <Tsi-Text-Box [inputName]=\"'reportName'\" [(inputField)]=\"report.reportName\"></Tsi-Text-Box>\r\n            </div>\r\n            <!-- Nom abrégé -->\r\n            <div class=\"col-3 col-form-label\">\r\n                <Tsi-Label labelValue=\"administration_edition_personnalise_reportNameAbrege\"></Tsi-Label>\r\n            </div>\r\n            <div class=\"col-3\">\r\n                <Tsi-Text-Box [inputName]=\"'reportNameAbrege'\" [(inputField)]=\"report.reportNameAbrege\"></Tsi-Text-Box>\r\n            </div>\r\n            <div class=\"flex col-6\">\r\n                <!-- Ordre de tri -->\r\n                <div class=\"flex gap-4 w-6\">\r\n                    <Tsi-Label labelValue=\"administration_edition_personnalise_triOrdre\"></Tsi-Label>\r\n                    <Tsi-Integer [inputName]=\"'triOrdre'\" [(inputField)]=\"report.triOrdre\"></Tsi-Integer>\r\n                </div>\r\n                <!-- Afficher dashboard -->\r\n                <div class=\"flex gap-4 w-6\">\r\n                    <Tsi-Label labelValue=\"administration_edition_personnalise_display\"></Tsi-Label>\r\n                    <Tsi-CheckBox [inputName]=\"'display'\" [(inputField)]=\"report.display\"></Tsi-CheckBox>\r\n                </div>\r\n            </div>\r\n            <!-- Module -->\r\n            <div class=\"col-3 col-form-label\">\r\n                <Tsi-Label labelValue=\"administration_edition_personnalise_Module\"></Tsi-Label>\r\n            </div>\r\n            <div class=\"col-9\">\r\n                <Tsi-Search-Combo id-field=\"code\" label-field=\"libelle\" [multiple]=\"false\" [(bind)]=\"report.module\"\r\n                    [datasource]=\"modules\" [isFiltered]=\"false\">\r\n                </Tsi-Search-Combo>\r\n            </div>\r\n            <!-- Deuxiéme Impress -->\r\n            <div class=\"col-3 col-form-label\">\r\n                <Tsi-Label labelValue=\"administration_edition_personnalise_imppress\"></Tsi-Label>\r\n            </div>\r\n            <div class=\"col-5\">\r\n                <Tsi-Text-Box [disabled]=\"true\" [inputName]=\"'imppress'\" [(inputField)]=\"report.impress\"></Tsi-Text-Box>\r\n            </div>\r\n            <!-- Edition unique -->\r\n            <div class=\"col-4 col-form-label flx\">\r\n                <Tsi-CheckBox [inputName]=\"'EditionUnique'\" [(inputField)]=\"report.editionUnique\"></Tsi-CheckBox>&nbsp;\r\n                <Tsi-Label labelValue=\"administration_edition_personnalise_EditionUnique\"></Tsi-Label>\r\n            </div>\r\n            <!-- Endpoint -->\r\n            <div class=\"col-3 col-form-label\">\r\n                <Tsi-Label labelValue=\"administration_edition_personnalise_endpoint\"></Tsi-Label>\r\n            </div>\r\n            <div class=\"col-9\">\r\n                <Tsi-Search-Combo *ngIf=\"!isReportForFiche && !enableMultiSelectEndpoints\" id-field=\"key\" label-field=\"value\"\r\n                    [disabled]=\"modes.edit === mode || isEditionPersonnalise === false\"\r\n                    (selectedLabelChange)=\"selectedEndpointChange($event)\" [(bind)]=\"report.endPointKey\"\r\n                    [elementSourceUrl]=\"administrationEndpoints.getApiAsKeyValuePair()\"\r\n                    [listSourceUrl]=\"administrationEndpoints.getAllApiAsKeyValuePair()\" [isFiltered]=\"true\">\r\n                </Tsi-Search-Combo>\r\n\r\n                <Tsi-Search-Combo *ngIf=\"(isReportForFiche || customReportingMode) && !enableMultiSelectEndpoints \" id-field=\"value\" label-field=\"value\"\r\n                    (selectedLabelChange)=\"selectedEndpointChange($event)\" [(bind)]=\"report.endPointKey\"\r\n                    [listSourceUrl]=\"administrationEndpoints.getAllApiAsKeyValuePairByBusinessClassName(this.reportBusinessClass)\"\r\n                    [isFiltered]=\"false\">\r\n                </Tsi-Search-Combo>\r\n\r\n                <p-multiSelect *ngIf=\"enableMultiSelectEndpoints\" [options]=\"endpointsOptions\" [(ngModel)]=\"selectedEndpoints\"\r\n                    selectedItemsLabel=\"{0} {{ 'endpoint_selected' | localize }}\" optionLabel=\"value\"\r\n                    optionValue=\"value\"\r\n                    [style]=\"{'min-width': '180px'}\" placeholder=\"{{ 'shared_reporting_choose_endpoints' | localize }}\"\r\n                    (onPanelShow)=\"handleOpen()\"\r\n                    [filter]=\"true\"\r\n                    (onFilter)=\"onFilter($event)\"\r\n                    display=\"chip\"\r\n                    class=\"rounded-multiselect\">\r\n                    <ng-template let-option pTemplate=\"item\">\r\n                        <div class=\"flex items-center gap-2\">\r\n                            <span>{{ option.value}}</span>\r\n                        </div>\r\n                    </ng-template>\r\n                </p-multiSelect>\r\n            </div>\r\n\r\n\r\n            <div class=\"col-3 col-form-label\">\r\n                <Tsi-Label labelValue=\"administration_edition_personnalise_formName\"></Tsi-Label>\r\n            </div>\r\n            <div class=\"col-6\">\r\n                <Tsi-Text-Box [disabled]=\"true\" [inputName]=\"'formName'\"\r\n                    [(inputField)]=\"report.formName\"></Tsi-Text-Box>\r\n            </div>\r\n            <!-- Param -->\r\n            <div *ngIf=\"isGetByIdRequest\" class=\"col-3 col-form-label\">\r\n                <Tsi-Label labelValue=\"administration_edition_personnalise_param\"></Tsi-Label>\r\n            </div>\r\n            <div *ngIf=\"isGetByIdRequest\" class=\"col-9\">\r\n                <Tsi-Text-Box [inputName]=\"'param'\" [(inputField)]=\"report.param\"></Tsi-Text-Box>\r\n            </div>\r\n        </div>\r\n    </p-panel>\r\n    <br />\r\n    <p-panel header=\"Configuration Pivot Grid\">\r\n        <div class=\"grid \">\r\n            <!-- Class or view -->\r\n            <div class=\"col-3 col-form-label\">\r\n                <Tsi-Label [labelValue]=\"'Class or view'\"></Tsi-Label>\r\n            </div>\r\n            <div class=\"col-9\">\r\n                <Tsi-Text-Box [inputName]=\"'dddd'\"></Tsi-Text-Box>\r\n            </div>\r\n            <!-- Query -->\r\n            <div class=\"col-3 col-form-label\">\r\n                <Tsi-Label [labelValue]=\"'Query'\"></Tsi-Label>\r\n            </div>\r\n            <div class=\"col-9 col-form-label\">\r\n                <Tsi-Text-Area [rows]=\"2\"></Tsi-Text-Area>\r\n            </div>\r\n        </div>\r\n    </p-panel>\r\n\r\n    <Tsi-Modal-Footer [cancelDisabled]=\"saving\" [saveDisabled]=\"saving\" (onSaveClick)=\"save()\"\r\n        (onCancelClick)=\"hide()\"></Tsi-Modal-Footer>\r\n</tsi-form>"]}
|