cilog-lib 1.10.21 → 1.11.0

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.
@@ -1,57 +1,69 @@
1
1
  import * as i0 from '@angular/core';
2
- import { Injectable, Component, NgModule, EventEmitter, forwardRef, HostListener, ViewChild, Output, Input, Pipe, LOCALE_ID } from '@angular/core';
3
- import { BehaviorSubject } from 'rxjs';
2
+ import { Component, Injectable, Pipe, EventEmitter, HostListener, ViewChild, Output, Input } from '@angular/core';
4
3
  import * as i2 from 'primeng/dialog';
5
4
  import { DialogModule } from 'primeng/dialog';
5
+ import { BehaviorSubject } from 'rxjs';
6
6
  import * as i1 from 'primeng/api';
7
- import { ConfirmationService } from 'primeng/api';
8
- import * as i4 from 'primeng/button';
9
- import { ButtonModule } from 'primeng/button';
10
- import * as i3 from '@angular/common';
11
- import { CommonModule, registerLocaleData } from '@angular/common';
12
- import * as i5 from 'primeng/table';
7
+ import * as i6 from 'primeng/table';
13
8
  import { TableModule } from 'primeng/table';
14
- import * as i2$1 from 'primeng/inputtext';
15
- import { InputTextModule } from 'primeng/inputtext';
16
- import * as i7 from 'primeng/selectbutton';
17
- import { SelectButtonModule } from 'primeng/selectbutton';
18
- import * as i8 from 'primeng/select';
19
- import { SelectModule } from 'primeng/select';
20
- import * as i9 from 'primeng/inputnumber';
9
+ import * as i7 from 'primeng/contextmenu';
10
+ import { ContextMenuModule } from 'primeng/contextmenu';
11
+ import * as i15 from 'primeng/inputnumber';
21
12
  import { InputNumberModule } from 'primeng/inputnumber';
22
- import { ConfirmDialogModule } from 'primeng/confirmdialog';
23
- import * as i10 from 'primeng/multiselect';
24
- import { MultiSelectModule } from 'primeng/multiselect';
25
- import * as i13 from 'primeng/tag';
13
+ import * as i3 from '@angular/common';
14
+ import { CommonModule } from '@angular/common';
15
+ import * as i5 from 'primeng/tag';
26
16
  import { TagModule } from 'primeng/tag';
27
- import * as i14 from 'primeng/tooltip';
17
+ import * as i8 from 'primeng/tooltip';
28
18
  import { TooltipModule } from 'primeng/tooltip';
29
- import * as i15 from 'primeng/toggleswitch';
30
- import { ToggleSwitchModule } from 'primeng/toggleswitch';
31
- import { SkeletonModule } from 'primeng/skeleton';
32
- import * as i1$1 from 'primeng/editor';
33
- import { EditorModule } from 'primeng/editor';
34
- import * as i12 from 'primeng/contextmenu';
35
- import { ContextMenuModule } from 'primeng/contextmenu';
36
- import * as i6 from 'primeng/tabs';
37
- import { TabsModule } from 'primeng/tabs';
38
- import * as i11 from 'primeng/datepicker';
19
+ import * as i4 from '@angular/forms';
20
+ import { FormsModule } from '@angular/forms';
21
+ import * as i9 from 'primeng/multiselect';
22
+ import { MultiSelectModule } from 'primeng/multiselect';
23
+ import * as i10 from 'primeng/datepicker';
39
24
  import { DatePickerModule } from 'primeng/datepicker';
40
- import { BrowserModule } from '@angular/platform-browser';
25
+ import * as i11 from 'primeng/select';
26
+ import { SelectModule } from 'primeng/select';
27
+ import * as i12 from 'primeng/selectbutton';
28
+ import { SelectButtonModule } from 'primeng/selectbutton';
29
+ import * as i13 from 'primeng/button';
30
+ import { ButtonModule } from 'primeng/button';
31
+ import * as i14 from 'primeng/inputtext';
32
+ import { InputTextModule } from 'primeng/inputtext';
41
33
  import * as Excel from 'exceljs';
42
34
  import * as FileSaver from 'file-saver';
43
- import * as i16 from '@angular/forms';
44
- import { NG_VALUE_ACCESSOR, FormsModule, ReactiveFormsModule } from '@angular/forms';
45
- import localeFr from '@angular/common/locales/fr';
46
- import * as i1$2 from '@angular/common/http';
47
- import { HttpClient, provideHttpClient, withInterceptorsFromDi } from '@angular/common/http';
48
- import * as i2$2 from '@angular/router';
49
- import * as i8$1 from 'ngx-markdown';
50
- import { MarkdownModule } from 'ngx-markdown';
51
- import * as i9$1 from 'primeng/progressspinner';
35
+ import * as i5$1 from 'primeng/progressspinner';
52
36
  import { ProgressSpinnerModule } from 'primeng/progressspinner';
37
+ import * as i6$1 from 'primeng/tabs';
38
+ import { TabsModule } from 'primeng/tabs';
39
+ import { EditorModule } from 'primeng/editor';
40
+ import { MarkdownComponent } from 'ngx-markdown';
41
+ import * as i1$1 from '@angular/common/http';
42
+ import * as i2$1 from '@angular/router';
43
+
44
+ class CilogLibComponent {
45
+ constructor() { }
46
+ ngOnInit() {
47
+ }
48
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "21.0.6", ngImport: i0, type: CilogLibComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
49
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "21.0.6", type: CilogLibComponent, isStandalone: false, selector: "lib-cilog-lib", ngImport: i0, template: `
50
+ <p>
51
+ cilog-lib works!
52
+ </p>
53
+ `, isInline: true });
54
+ }
55
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "21.0.6", ngImport: i0, type: CilogLibComponent, decorators: [{
56
+ type: Component,
57
+ args: [{ selector: 'lib-cilog-lib', template: `
58
+ <p>
59
+ cilog-lib works!
60
+ </p>
61
+ `, standalone: false }]
62
+ }], ctorParameters: () => [] });
53
63
 
54
64
  class CilogMessageService {
65
+ display;
66
+ message;
55
67
  constructor() {
56
68
  this.message = new BehaviorSubject(null);
57
69
  this.display = new BehaviorSubject(null);
@@ -68,8 +80,8 @@ class CilogMessageService {
68
80
  closeDialog() {
69
81
  this.display.next(false);
70
82
  }
71
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "21.0.6", ngImport: i0, type: CilogMessageService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
72
- static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "21.0.6", ngImport: i0, type: CilogMessageService, providedIn: 'root' }); }
83
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "21.0.6", ngImport: i0, type: CilogMessageService, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
84
+ static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "21.0.6", ngImport: i0, type: CilogMessageService, providedIn: 'root' });
73
85
  }
74
86
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "21.0.6", ngImport: i0, type: CilogMessageService, decorators: [{
75
87
  type: Injectable,
@@ -79,6 +91,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "21.0.6", ngImpor
79
91
  }], ctorParameters: () => [] });
80
92
 
81
93
  class CilogMessageComponent {
94
+ messageService;
95
+ display;
96
+ message;
82
97
  constructor(messageService) {
83
98
  this.messageService = messageService;
84
99
  }
@@ -140,100 +155,16 @@ class CilogMessageComponent {
140
155
  refreshPage() {
141
156
  window.location.reload();
142
157
  }
143
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "21.0.6", ngImport: i0, type: CilogMessageComponent, deps: [{ token: CilogMessageService }], target: i0.ɵɵFactoryTarget.Component }); }
144
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "21.0.6", type: CilogMessageComponent, isStandalone: false, selector: "cilog-message", ngImport: i0, template: "<p-dialog [styleClass]=\"classBySeverity()\"\n [(visible)]=\"display\"\n [modal]=\"true\"\n [baseZIndex]=\"10000\"\n [closable]=\"false\"\n [resizable]=\"false\"\n [draggable]=\"false\">\n\n <!-- Header -->\n <ng-template pTemplate=\"header\">\n <i class=\"pi {{ iconBySeverity() }} header_icon\"></i>\n <span class=\"header_text\">{{ headerBySeverity() }}</span>\n </ng-template>\n\n <!-- Content -->\n <p class=\"content mb-3\"\n [innerHTML]=\"message?.content\">\n </p>\n\n <!-- Boutons -->\n @if (message?.closable == true && message?.refresh == false) {\n <button pButton\n icon=\"pi pi-check\"\n (click)=\"display=false\"\n label=\"Ok\"\n style=\"float:right;\"\n class=\"p-button-text\">\n </button>\n }\n @if (message?.refresh == true) {\n <button pButton\n icon=\"pi pi-refresh\"\n (click)=\"refreshPage()\"\n label=\"Rafra\u00EEchir\"\n style=\"float:right;\"\n class=\"p-button-text\">\n </button>\n }\n\n</p-dialog>\n", styles: [":host ::ng-deep .message_success>div{background-color:#b7fdc0}:host ::ng-deep .message_error>div{background-color:#fdb8b7}:host ::ng-deep .message_warn>div{background-color:#fff5ba}:host ::ng-deep .message_info>div{background-color:#b7eefd}:host ::ng-deep .p-dialog-content,:host ::ng-deep .p-dialog-footer,:host ::ng-deep .p-dialog-header{padding:10px}:host ::ng-deep .content{margin:4px;white-space:pre}:host ::ng-deep .p-button-text{padding-top:0;padding-bottom:3px}:host ::ng-deep .header_text{font-weight:500;font-size:1.25rem;margin-left:10px}:host ::ng-deep .header_icon{font-size:1.5rem}:host ::ng-deep .p-dialog-header{justify-content:inherit}\n"], dependencies: [{ kind: "component", type: i2.Dialog, selector: "p-dialog", inputs: ["hostName", "header", "draggable", "resizable", "contentStyle", "contentStyleClass", "modal", "closeOnEscape", "dismissableMask", "rtl", "closable", "breakpoints", "styleClass", "maskStyleClass", "maskStyle", "showHeader", "blockScroll", "autoZIndex", "baseZIndex", "minX", "minY", "focusOnShow", "maximizable", "keepInViewport", "focusTrap", "transitionOptions", "maskMotionOptions", "motionOptions", "closeIcon", "closeAriaLabel", "closeTabindex", "minimizeIcon", "maximizeIcon", "closeButtonProps", "maximizeButtonProps", "visible", "style", "position", "role", "appendTo", "content", "contentTemplate", "footerTemplate", "closeIconTemplate", "maximizeIconTemplate", "minimizeIconTemplate", "headlessTemplate"], outputs: ["onShow", "onHide", "visibleChange", "onResizeInit", "onResizeEnd", "onDragEnd", "onMaximize"] }, { kind: "directive", type: i1.PrimeTemplate, selector: "[pTemplate]", inputs: ["type", "pTemplate"] }, { kind: "directive", type: i4.ButtonDirective, selector: "[pButton]", inputs: ["ptButtonDirective", "pButtonPT", "pButtonUnstyled", "hostName", "text", "plain", "raised", "size", "outlined", "rounded", "iconPos", "loadingIcon", "fluid", "label", "icon", "loading", "buttonProps", "severity"] }] }); }
158
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "21.0.6", ngImport: i0, type: CilogMessageComponent, deps: [{ token: CilogMessageService }], target: i0.ɵɵFactoryTarget.Component });
159
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "21.0.6", type: CilogMessageComponent, isStandalone: true, selector: "cilog-message", ngImport: i0, template: "<p-dialog [styleClass]=\"classBySeverity()\"\n [(visible)]=\"display\"\n [modal]=\"true\"\n [baseZIndex]=\"10000\"\n [closable]=\"false\"\n [resizable]=\"false\"\n [draggable]=\"false\">\n\n <!-- Header -->\n <ng-template pTemplate=\"header\">\n <i class=\"pi {{ iconBySeverity() }} header_icon\"></i>\n <span class=\"header_text\">{{ headerBySeverity() }}</span>\n </ng-template>\n\n <!-- Content -->\n <p class=\"content mb-3\"\n [innerHTML]=\"message?.content\">\n </p>\n\n <!-- Boutons -->\n @if (message?.closable == true && message?.refresh == false) {\n <button pButton\n icon=\"pi pi-check\"\n (click)=\"display=false\"\n label=\"Ok\"\n style=\"float:right;\"\n class=\"p-button-text\">\n </button>\n }\n @if (message?.refresh == true) {\n <button pButton\n icon=\"pi pi-refresh\"\n (click)=\"refreshPage()\"\n label=\"Rafra\u00EEchir\"\n style=\"float:right;\"\n class=\"p-button-text\">\n </button>\n }\n\n</p-dialog>\n", styles: [":host ::ng-deep .message_success>div{background-color:#b7fdc0}:host ::ng-deep .message_error>div{background-color:#fdb8b7}:host ::ng-deep .message_warn>div{background-color:#fff5ba}:host ::ng-deep .message_info>div{background-color:#b7eefd}:host ::ng-deep .p-dialog-content,:host ::ng-deep .p-dialog-footer,:host ::ng-deep .p-dialog-header{padding:10px}:host ::ng-deep .content{margin:4px;white-space:pre}:host ::ng-deep .p-button-text{padding-top:0;padding-bottom:3px}:host ::ng-deep .header_text{font-weight:500;font-size:1.25rem;margin-left:10px}:host ::ng-deep .header_icon{font-size:1.5rem}:host ::ng-deep .p-dialog-header{justify-content:inherit}\n"], dependencies: [{ kind: "ngmodule", type: DialogModule }, { kind: "component", type: i2.Dialog, selector: "p-dialog", inputs: ["hostName", "header", "draggable", "resizable", "contentStyle", "contentStyleClass", "modal", "closeOnEscape", "dismissableMask", "rtl", "closable", "breakpoints", "styleClass", "maskStyleClass", "maskStyle", "showHeader", "blockScroll", "autoZIndex", "baseZIndex", "minX", "minY", "focusOnShow", "maximizable", "keepInViewport", "focusTrap", "transitionOptions", "maskMotionOptions", "motionOptions", "closeIcon", "closeAriaLabel", "closeTabindex", "minimizeIcon", "maximizeIcon", "closeButtonProps", "maximizeButtonProps", "visible", "style", "position", "role", "appendTo", "content", "contentTemplate", "footerTemplate", "closeIconTemplate", "maximizeIconTemplate", "minimizeIconTemplate", "headlessTemplate"], outputs: ["onShow", "onHide", "visibleChange", "onResizeInit", "onResizeEnd", "onDragEnd", "onMaximize"] }, { kind: "directive", type: i1.PrimeTemplate, selector: "[pTemplate]", inputs: ["type", "pTemplate"] }] });
145
160
  }
146
161
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "21.0.6", ngImport: i0, type: CilogMessageComponent, decorators: [{
147
162
  type: Component,
148
- args: [{ selector: 'cilog-message', standalone: false, template: "<p-dialog [styleClass]=\"classBySeverity()\"\n [(visible)]=\"display\"\n [modal]=\"true\"\n [baseZIndex]=\"10000\"\n [closable]=\"false\"\n [resizable]=\"false\"\n [draggable]=\"false\">\n\n <!-- Header -->\n <ng-template pTemplate=\"header\">\n <i class=\"pi {{ iconBySeverity() }} header_icon\"></i>\n <span class=\"header_text\">{{ headerBySeverity() }}</span>\n </ng-template>\n\n <!-- Content -->\n <p class=\"content mb-3\"\n [innerHTML]=\"message?.content\">\n </p>\n\n <!-- Boutons -->\n @if (message?.closable == true && message?.refresh == false) {\n <button pButton\n icon=\"pi pi-check\"\n (click)=\"display=false\"\n label=\"Ok\"\n style=\"float:right;\"\n class=\"p-button-text\">\n </button>\n }\n @if (message?.refresh == true) {\n <button pButton\n icon=\"pi pi-refresh\"\n (click)=\"refreshPage()\"\n label=\"Rafra\u00EEchir\"\n style=\"float:right;\"\n class=\"p-button-text\">\n </button>\n }\n\n</p-dialog>\n", styles: [":host ::ng-deep .message_success>div{background-color:#b7fdc0}:host ::ng-deep .message_error>div{background-color:#fdb8b7}:host ::ng-deep .message_warn>div{background-color:#fff5ba}:host ::ng-deep .message_info>div{background-color:#b7eefd}:host ::ng-deep .p-dialog-content,:host ::ng-deep .p-dialog-footer,:host ::ng-deep .p-dialog-header{padding:10px}:host ::ng-deep .content{margin:4px;white-space:pre}:host ::ng-deep .p-button-text{padding-top:0;padding-bottom:3px}:host ::ng-deep .header_text{font-weight:500;font-size:1.25rem;margin-left:10px}:host ::ng-deep .header_icon{font-size:1.5rem}:host ::ng-deep .p-dialog-header{justify-content:inherit}\n"] }]
163
+ args: [{ selector: 'cilog-message', imports: [
164
+ DialogModule
165
+ ], template: "<p-dialog [styleClass]=\"classBySeverity()\"\n [(visible)]=\"display\"\n [modal]=\"true\"\n [baseZIndex]=\"10000\"\n [closable]=\"false\"\n [resizable]=\"false\"\n [draggable]=\"false\">\n\n <!-- Header -->\n <ng-template pTemplate=\"header\">\n <i class=\"pi {{ iconBySeverity() }} header_icon\"></i>\n <span class=\"header_text\">{{ headerBySeverity() }}</span>\n </ng-template>\n\n <!-- Content -->\n <p class=\"content mb-3\"\n [innerHTML]=\"message?.content\">\n </p>\n\n <!-- Boutons -->\n @if (message?.closable == true && message?.refresh == false) {\n <button pButton\n icon=\"pi pi-check\"\n (click)=\"display=false\"\n label=\"Ok\"\n style=\"float:right;\"\n class=\"p-button-text\">\n </button>\n }\n @if (message?.refresh == true) {\n <button pButton\n icon=\"pi pi-refresh\"\n (click)=\"refreshPage()\"\n label=\"Rafra\u00EEchir\"\n style=\"float:right;\"\n class=\"p-button-text\">\n </button>\n }\n\n</p-dialog>\n", styles: [":host ::ng-deep .message_success>div{background-color:#b7fdc0}:host ::ng-deep .message_error>div{background-color:#fdb8b7}:host ::ng-deep .message_warn>div{background-color:#fff5ba}:host ::ng-deep .message_info>div{background-color:#b7eefd}:host ::ng-deep .p-dialog-content,:host ::ng-deep .p-dialog-footer,:host ::ng-deep .p-dialog-header{padding:10px}:host ::ng-deep .content{margin:4px;white-space:pre}:host ::ng-deep .p-button-text{padding-top:0;padding-bottom:3px}:host ::ng-deep .header_text{font-weight:500;font-size:1.25rem;margin-left:10px}:host ::ng-deep .header_icon{font-size:1.5rem}:host ::ng-deep .p-dialog-header{justify-content:inherit}\n"] }]
149
166
  }], ctorParameters: () => [{ type: CilogMessageService }] });
150
167
 
151
- class CilogLibComponent {
152
- constructor() { }
153
- ngOnInit() {
154
- }
155
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "21.0.6", ngImport: i0, type: CilogLibComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
156
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "21.0.6", type: CilogLibComponent, isStandalone: false, selector: "lib-cilog-lib", ngImport: i0, template: `
157
- <p>
158
- cilog-lib works!
159
- </p>
160
- `, isInline: true }); }
161
- }
162
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "21.0.6", ngImport: i0, type: CilogLibComponent, decorators: [{
163
- type: Component,
164
- args: [{ selector: 'lib-cilog-lib', template: `
165
- <p>
166
- cilog-lib works!
167
- </p>
168
- `, standalone: false }]
169
- }], ctorParameters: () => [] });
170
-
171
- class PrimengModule {
172
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "21.0.6", ngImport: i0, type: PrimengModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
173
- static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "21.0.6", ngImport: i0, type: PrimengModule, imports: [CommonModule], exports: [DialogModule,
174
- ButtonModule,
175
- TableModule,
176
- InputTextModule,
177
- SelectButtonModule,
178
- SelectModule,
179
- InputNumberModule,
180
- ConfirmDialogModule,
181
- MultiSelectModule,
182
- DatePickerModule,
183
- ContextMenuModule,
184
- TagModule,
185
- TooltipModule,
186
- ToggleSwitchModule,
187
- SkeletonModule,
188
- EditorModule,
189
- TabsModule] }); }
190
- static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "21.0.6", ngImport: i0, type: PrimengModule, imports: [CommonModule, DialogModule,
191
- ButtonModule,
192
- TableModule,
193
- InputTextModule,
194
- SelectButtonModule,
195
- SelectModule,
196
- InputNumberModule,
197
- ConfirmDialogModule,
198
- MultiSelectModule,
199
- DatePickerModule,
200
- ContextMenuModule,
201
- TagModule,
202
- TooltipModule,
203
- ToggleSwitchModule,
204
- SkeletonModule,
205
- EditorModule,
206
- TabsModule] }); }
207
- }
208
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "21.0.6", ngImport: i0, type: PrimengModule, decorators: [{
209
- type: NgModule,
210
- args: [{
211
- declarations: [],
212
- exports: [
213
- DialogModule,
214
- ButtonModule,
215
- TableModule,
216
- InputTextModule,
217
- SelectButtonModule,
218
- SelectModule,
219
- InputNumberModule,
220
- ConfirmDialogModule,
221
- MultiSelectModule,
222
- DatePickerModule,
223
- ContextMenuModule,
224
- TagModule,
225
- TooltipModule,
226
- ToggleSwitchModule,
227
- SkeletonModule,
228
- EditorModule,
229
- TabsModule
230
- ],
231
- imports: [
232
- CommonModule
233
- ]
234
- }]
235
- }] });
236
-
237
168
  var Position;
238
169
  (function (Position) {
239
170
  Position["Right"] = "right";
@@ -285,194 +216,54 @@ var ModeCalendar;
285
216
  ModeCalendar["DateHour"] = "datehour";
286
217
  })(ModeCalendar || (ModeCalendar = {}));
287
218
 
288
- class ExportService {
289
- constructor() { }
290
- exportExcel(values, columns, byFiltre, withColors) {
291
- // Workbook
292
- let wb = new Excel.Workbook();
293
- // Worksheet
294
- let ws = wb.addWorksheet('Export', {
295
- properties: { defaultColWidth: 20 },
296
- });
297
- // Colonnes
298
- let cols = [];
299
- columns = columns.filter(col => !col.invisible);
300
- columns.forEach(col => {
301
- if (!byFiltre || col.exportable == true) {
302
- let colExcel = {
303
- header: col.libelle,
304
- key: col.id,
305
- style: this.getStyleByType(col.type)
306
- };
307
- if (col.width != null && col.width.includes('px')) {
308
- const px = parseInt(col.width.replace('px', '').trim(), 10);
309
- const excelWidth = px / 7;
310
- colExcel.width = parseFloat(excelWidth.toFixed(2));
311
- }
312
- cols.push(colExcel);
313
- }
314
- });
315
- ws.columns = cols;
316
- // Lignes
317
- values.forEach(row => {
318
- if (!byFiltre || row.exportable == true) {
319
- let rowExcel = {};
320
- columns.filter(obj => !byFiltre || obj.exportable == true).forEach(col => {
321
- if (row[col.id].excelSubstitution != null) {
322
- rowExcel[col.id] = row[col.id].excelSubstitution;
323
- }
324
- else {
325
- rowExcel[col.id] = this.getValueByType(row[col.id], col);
326
- }
327
- });
328
- // Application du style de chaque cellule
329
- let result = ws.addRow(rowExcel);
330
- columns.filter(obj => !byFiltre || obj.exportable == true).forEach((col, index) => {
331
- const cell = result.getCell(index + 1);
332
- if (row[col.id].bold) {
333
- cell.font = { bold: true };
334
- }
335
- if (withColors) {
336
- if ((row.color != null && row.color != '') || (row[col.id].color != null && row[col.id].color != '')) {
337
- cell.style.fill = {
338
- type: "pattern",
339
- pattern: "solid",
340
- fgColor: {
341
- argb: row[col.id].color != null ? this.getHexaColor(row[col.id].color) : this.getHexaColor(row.color)
342
- },
343
- bgColor: {
344
- argb: row[col.id].color != null ? this.getHexaColor(row[col.id].color) : this.getHexaColor(row.color)
345
- }
346
- };
347
- }
348
- }
349
- });
350
- }
351
- });
352
- // Style
353
- this.setStyleGlobalGrille(ws);
354
- // Sauvegarde
355
- wb.xlsx.writeBuffer().then(function (buffer) {
356
- const data = new Blob([buffer], {
357
- type: 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet',
358
- });
359
- FileSaver.saveAs(data, "Export Excel.xlsx");
360
- });
361
- }
362
- getHexaColor(color) {
363
- var ctx = document.createElement('canvas').getContext('2d');
364
- ctx.fillStyle = color;
365
- return ctx.fillStyle.replace('#', '');
366
- }
367
- setStyleGlobalGrille(ws) {
368
- ws.views = [
369
- { state: 'frozen', ySplit: 1 }
370
- ];
371
- ws.eachRow((row, rowNumber) => {
372
- row.eachCell({ includeEmpty: true }, (cell, number) => {
373
- if (rowNumber == 1) {
374
- cell.fill = {
375
- pattern: 'solid',
376
- type: 'pattern',
377
- fgColor: {
378
- argb: '2fab49',
379
- },
380
- };
381
- cell.alignment = { horizontal: 'center' };
382
- cell.alignment.vertical = 'middle';
383
- cell.font = {
384
- name: 'Arial',
385
- size: 10,
386
- bold: true
387
- };
388
- cell.border = {
389
- bottom: { style: 'thin' },
390
- top: { style: 'thin' },
391
- left: { style: 'thin' },
392
- right: { style: 'thin' },
393
- };
394
- }
395
- else {
396
- cell.border = {
397
- bottom: { style: 'thin' },
398
- top: { style: 'thin' },
399
- left: { style: 'thin' },
400
- right: { style: 'thin' },
401
- };
402
- }
403
- });
404
- });
405
- ws.autoFilter = {
406
- from: 'A1',
407
- to: this.columnIndexToColumnLetter(ws.columnCount).toString() + '1',
408
- };
409
- }
410
- columnIndexToColumnLetter(column) {
411
- var temp, letter = '';
412
- while (column > 0) {
413
- temp = (column - 1) % 26;
414
- letter = String.fromCharCode(temp + 65) + letter;
415
- column = (column - temp - 1) / 26;
416
- }
417
- return letter;
418
- }
419
- getValueByType(cell, col) {
420
- switch (col.type) {
421
- case ColType.MultiSelect:
422
- let optionLabelMulti = cell.options != null && cell.options.optionLabel != null ? cell.options.optionLabel : col.options.optionLabel;
423
- return cell.value.map(val => val[optionLabelMulti]).join(', ');
424
- case ColType.SelectButton:
425
- case ColType.Dropdown:
426
- case ColType.State:
427
- let optionLabel = cell.options != null && cell.options.optionLabel != null ? cell.options.optionLabel : col.options.optionLabel;
428
- return cell.value != null ? cell.value[optionLabel] : null;
429
- case ColType.Image:
430
- case ColType.Button:
431
- return null;
432
- case ColType.Switch:
433
- return cell.value == true ? 'Oui' : 'Non';
434
- case ColType.Date:
435
- if (cell.value != null) {
436
- let dateStr = cell.value.getFullYear() + '-' + ((cell.value.getMonth() + 1 < 10) ? '0' + (cell.value.getMonth() + 1) : (cell.value.getMonth() + 1)) + '-' + (cell.value.getDate() < 10 ? '0' + cell.value.getDate() : cell.value.getDate()) + 'T00:00:00.000Z';
437
- return new Date(dateStr);
438
- }
439
- else {
440
- return null;
441
- }
442
- default:
443
- return cell.value;
219
+ class ValuePipe {
220
+ transform(obj, ...args) {
221
+ if (typeof obj === 'number') {
222
+ if (isNaN(obj))
223
+ return '0';
224
+ if (!isFinite(obj))
225
+ return '0';
226
+ if (obj != null)
227
+ return obj.toLocaleString('fr-FR', { maximumFractionDigits: 2 });
228
+ return "";
444
229
  }
445
- }
446
- getStyleByType(type) {
447
- switch (type) {
448
- case ColType.Date:
449
- return { numFmt: 'dd/mm/yyyy' };
450
- case ColType.CilogNumber:
451
- case ColType.Number:
452
- return { numFmt: '#,##0.00' };
453
- default:
454
- return null;
230
+ else {
231
+ return obj;
455
232
  }
456
233
  }
457
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "21.0.6", ngImport: i0, type: ExportService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
458
- static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "21.0.6", ngImport: i0, type: ExportService, providedIn: 'root' }); }
234
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "21.0.6", ngImport: i0, type: ValuePipe, deps: [], target: i0.ɵɵFactoryTarget.Pipe });
235
+ static ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "14.0.0", version: "21.0.6", ngImport: i0, type: ValuePipe, isStandalone: true, name: "value" });
459
236
  }
460
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "21.0.6", ngImport: i0, type: ExportService, decorators: [{
461
- type: Injectable,
237
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "21.0.6", ngImport: i0, type: ValuePipe, decorators: [{
238
+ type: Pipe,
462
239
  args: [{
463
- providedIn: 'root'
240
+ name: 'value'
464
241
  }]
465
- }], ctorParameters: () => [] });
242
+ }] });
466
243
 
467
244
  class CilogInputNumberComponent {
468
- constructor() {
469
- this.onInput = new EventEmitter();
470
- this.onChange = new EventEmitter();
471
- this.onFocus = new EventEmitter();
472
- this.onBlur = new EventEmitter();
473
- this.valueStr = '';
474
- this.specialKeys = ['Tab', 'End', 'Home', 'ArrowLeft', 'ArrowRight'];
475
- }
245
+ value;
246
+ min;
247
+ max;
248
+ maxDecimals;
249
+ prefixe;
250
+ suffixe;
251
+ inputStyleClass;
252
+ disabled;
253
+ readonly;
254
+ textColor;
255
+ bold;
256
+ italic;
257
+ floatLabel;
258
+ onInput = new EventEmitter();
259
+ onChange = new EventEmitter();
260
+ onFocus = new EventEmitter();
261
+ onBlur = new EventEmitter();
262
+ valueStr = '';
263
+ cilogInputNumber;
264
+ regex;
265
+ specialKeys = ['Tab', 'End', 'Home', 'ArrowLeft', 'ArrowRight'];
266
+ constructor() { }
476
267
  ngOnInit() {
477
268
  this.regex = new RegExp(`^-?\\d{1,3}(?:\\d{3})*(?:[\\.,]\\d{0,${this.maxDecimals || Number.MAX_SAFE_INTEGER}})?$`);
478
269
  }
@@ -652,24 +443,14 @@ class CilogInputNumberComponent {
652
443
  registerOnTouched(fn) {
653
444
  this.onTouchedInput = fn;
654
445
  }
655
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "21.0.6", ngImport: i0, type: CilogInputNumberComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
656
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "21.0.6", type: CilogInputNumberComponent, isStandalone: false, selector: "cilog-input-number", inputs: { min: "min", max: "max", maxDecimals: "maxDecimals", prefixe: "prefixe", suffixe: "suffixe", inputStyleClass: "inputStyleClass", disabled: "disabled", readonly: "readonly", textColor: "textColor", bold: "bold", italic: "italic", floatLabel: "floatLabel" }, outputs: { onInput: "onInput", onChange: "onChange", onFocus: "onFocus", onBlur: "onBlur" }, host: { listeners: { "keydown": "onKeyDownEvent($event)" } }, providers: [
657
- {
658
- provide: NG_VALUE_ACCESSOR,
659
- useExisting: forwardRef(() => CilogInputNumberComponent),
660
- multi: true
661
- }
662
- ], viewQueries: [{ propertyName: "cilogInputNumber", first: true, predicate: ["cilogInputNumber"], descendants: true }], ngImport: i0, template: "<div class=\"input-group w-full\">\n\n @if (prefixe != null) {\n <span class=\"input-group-addon prefixe\"\n >\n {{ prefixe }}\n </span>\n }\n\n <div [ngClass]=\"{ 'p-float-label' : floatLabel != null }\">\n <input #cilogInputNumber\n pInputText\n type=\"text\"\n [disabled]=\"disabled\"\n [readonly]=\"readonly\"\n [value]=\"valueStr\"\n (focus)=\"onFocusEvent($event)\"\n (blur)=\"onBlurEvent($event)\"\n [class]=\"'w-full z-1' + (inputStyleClass == null ? '' : ' ' + inputStyleClass)\"\n [ngClass]=\"suffixe != null && prefixe != null ? 'border-noround' : prefixe != null ? 'border-noround-left' : suffixe != null ? 'border-noround-right' : null\"\n [ngStyle]=\"{ 'color' : textColor ? textColor : null }\" />\n\n @if (floatLabel != null) {\n <label>{{ floatLabel }}</label>\n }\n </div>\n\n @if (suffixe != null) {\n <span class=\"input-group-addon suffixe\"\n >\n {{ suffixe }}\n </span>\n }\n\n </div>\n", styles: [":host ::ng-deep .input-group{display:flex!important}:host ::ng-deep .input-group-addon{background-color:#fff!important;border:1px solid #ccc!important;padding:0 12px!important;max-width:5rem!important;overflow:hidden!important;font-weight:700!important}:host ::ng-deep .prefixe{border-radius:4px 0 0 4px!important;border-right:none!important;display:flex;align-items:center}:host ::ng-deep .suffixe{border-radius:0 4px 4px 0!important;border-left:none!important;display:flex;align-items:center}\n"], dependencies: [{ kind: "directive", type: i3.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i3.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "directive", type: i2$1.InputText, selector: "[pInputText]", inputs: ["hostName", "ptInputText", "pInputTextPT", "pInputTextUnstyled", "pSize", "variant", "fluid", "invalid"] }] }); }
446
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "21.0.6", ngImport: i0, type: CilogInputNumberComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
447
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "21.0.6", type: CilogInputNumberComponent, isStandalone: true, selector: "cilog-input-number", inputs: { min: "min", max: "max", maxDecimals: "maxDecimals", prefixe: "prefixe", suffixe: "suffixe", inputStyleClass: "inputStyleClass", disabled: "disabled", readonly: "readonly", textColor: "textColor", bold: "bold", italic: "italic", floatLabel: "floatLabel" }, outputs: { onInput: "onInput", onChange: "onChange", onFocus: "onFocus", onBlur: "onBlur" }, host: { listeners: { "keydown": "onKeyDownEvent($event)" } }, viewQueries: [{ propertyName: "cilogInputNumber", first: true, predicate: ["cilogInputNumber"], descendants: true }], ngImport: i0, template: "<div class=\"input-group w-full\">\n\n @if (prefixe != null) {\n <span class=\"input-group-addon prefixe\">\n {{ prefixe }}\n </span>\n }\n\n <div [ngClass]=\"{ 'p-float-label' : floatLabel != null }\">\n <input #cilogInputNumber\n pInputText\n type=\"text\"\n [disabled]=\"disabled\"\n [readonly]=\"readonly\"\n [value]=\"valueStr\"\n (focus)=\"onFocusEvent($event)\"\n (blur)=\"onBlurEvent($event)\"\n [class]=\"'w-full z-1' + (inputStyleClass == null ? '' : ' ' + inputStyleClass)\"\n [ngClass]=\"suffixe != null && prefixe != null ? 'border-noround' : prefixe != null ? 'border-noround-left' : suffixe != null ? 'border-noround-right' : null\"\n [ngStyle]=\"{ 'color' : textColor ? textColor : null }\" />\n\n @if (floatLabel != null) {\n <label>{{ floatLabel }}</label>\n }\n </div>\n\n @if (suffixe != null) {\n <span class=\"input-group-addon suffixe\">\n {{ suffixe }}\n </span>\n }\n\n</div>\n", styles: [":host ::ng-deep .input-group{display:flex!important}:host ::ng-deep .input-group-addon{background-color:#fff!important;border:1px solid #ccc!important;padding:0 12px!important;max-width:5rem!important;overflow:hidden!important;font-weight:700!important}:host ::ng-deep .prefixe{border-radius:4px 0 0 4px!important;border-right:none!important;display:flex;align-items:center}:host ::ng-deep .suffixe{border-radius:0 4px 4px 0!important;border-left:none!important;display:flex;align-items:center}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i3.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i3.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }] });
663
448
  }
664
449
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "21.0.6", ngImport: i0, type: CilogInputNumberComponent, decorators: [{
665
450
  type: Component,
666
- args: [{ selector: 'cilog-input-number', providers: [
667
- {
668
- provide: NG_VALUE_ACCESSOR,
669
- useExisting: forwardRef(() => CilogInputNumberComponent),
670
- multi: true
671
- }
672
- ], standalone: false, template: "<div class=\"input-group w-full\">\n\n @if (prefixe != null) {\n <span class=\"input-group-addon prefixe\"\n >\n {{ prefixe }}\n </span>\n }\n\n <div [ngClass]=\"{ 'p-float-label' : floatLabel != null }\">\n <input #cilogInputNumber\n pInputText\n type=\"text\"\n [disabled]=\"disabled\"\n [readonly]=\"readonly\"\n [value]=\"valueStr\"\n (focus)=\"onFocusEvent($event)\"\n (blur)=\"onBlurEvent($event)\"\n [class]=\"'w-full z-1' + (inputStyleClass == null ? '' : ' ' + inputStyleClass)\"\n [ngClass]=\"suffixe != null && prefixe != null ? 'border-noround' : prefixe != null ? 'border-noround-left' : suffixe != null ? 'border-noround-right' : null\"\n [ngStyle]=\"{ 'color' : textColor ? textColor : null }\" />\n\n @if (floatLabel != null) {\n <label>{{ floatLabel }}</label>\n }\n </div>\n\n @if (suffixe != null) {\n <span class=\"input-group-addon suffixe\"\n >\n {{ suffixe }}\n </span>\n }\n\n </div>\n", styles: [":host ::ng-deep .input-group{display:flex!important}:host ::ng-deep .input-group-addon{background-color:#fff!important;border:1px solid #ccc!important;padding:0 12px!important;max-width:5rem!important;overflow:hidden!important;font-weight:700!important}:host ::ng-deep .prefixe{border-radius:4px 0 0 4px!important;border-right:none!important;display:flex;align-items:center}:host ::ng-deep .suffixe{border-radius:0 4px 4px 0!important;border-left:none!important;display:flex;align-items:center}\n"] }]
451
+ args: [{ selector: 'cilog-input-number', imports: [
452
+ CommonModule
453
+ ], template: "<div class=\"input-group w-full\">\n\n @if (prefixe != null) {\n <span class=\"input-group-addon prefixe\">\n {{ prefixe }}\n </span>\n }\n\n <div [ngClass]=\"{ 'p-float-label' : floatLabel != null }\">\n <input #cilogInputNumber\n pInputText\n type=\"text\"\n [disabled]=\"disabled\"\n [readonly]=\"readonly\"\n [value]=\"valueStr\"\n (focus)=\"onFocusEvent($event)\"\n (blur)=\"onBlurEvent($event)\"\n [class]=\"'w-full z-1' + (inputStyleClass == null ? '' : ' ' + inputStyleClass)\"\n [ngClass]=\"suffixe != null && prefixe != null ? 'border-noround' : prefixe != null ? 'border-noround-left' : suffixe != null ? 'border-noround-right' : null\"\n [ngStyle]=\"{ 'color' : textColor ? textColor : null }\" />\n\n @if (floatLabel != null) {\n <label>{{ floatLabel }}</label>\n }\n </div>\n\n @if (suffixe != null) {\n <span class=\"input-group-addon suffixe\">\n {{ suffixe }}\n </span>\n }\n\n</div>\n", styles: [":host ::ng-deep .input-group{display:flex!important}:host ::ng-deep .input-group-addon{background-color:#fff!important;border:1px solid #ccc!important;padding:0 12px!important;max-width:5rem!important;overflow:hidden!important;font-weight:700!important}:host ::ng-deep .prefixe{border-radius:4px 0 0 4px!important;border-right:none!important;display:flex;align-items:center}:host ::ng-deep .suffixe{border-radius:0 4px 4px 0!important;border-left:none!important;display:flex;align-items:center}\n"] }]
673
454
  }], ctorParameters: () => [], propDecorators: { min: [{
674
455
  type: Input
675
456
  }], max: [{
@@ -710,51 +491,219 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "21.0.6", ngImpor
710
491
  args: ['keydown', ['$event']]
711
492
  }] } });
712
493
 
713
- class ValuePipe {
714
- transform(obj, ...args) {
715
- if (typeof obj === 'number') {
716
- if (isNaN(obj))
717
- return '0';
718
- if (!isFinite(obj))
719
- return '0';
720
- if (obj != null)
721
- return obj.toLocaleString('fr-FR', { maximumFractionDigits: 2 });
722
- return "";
494
+ class ExportService {
495
+ constructor() { }
496
+ exportExcel(values, columns, byFiltre, withColors) {
497
+ // Workbook
498
+ let wb = new Excel.Workbook();
499
+ // Worksheet
500
+ let ws = wb.addWorksheet('Export', {
501
+ properties: { defaultColWidth: 20 },
502
+ });
503
+ // Colonnes
504
+ let cols = [];
505
+ columns = columns.filter(col => !col.invisible);
506
+ columns.forEach(col => {
507
+ if (!byFiltre || col.exportable == true) {
508
+ let colExcel = {
509
+ header: col.libelle,
510
+ key: col.id,
511
+ style: this.getStyleByType(col.type)
512
+ };
513
+ if (col.width != null && col.width.includes('px')) {
514
+ const px = parseInt(col.width.replace('px', '').trim(), 10);
515
+ const excelWidth = px / 7;
516
+ colExcel.width = parseFloat(excelWidth.toFixed(2));
517
+ }
518
+ cols.push(colExcel);
519
+ }
520
+ });
521
+ ws.columns = cols;
522
+ // Lignes
523
+ values.forEach(row => {
524
+ if (!byFiltre || row.exportable == true) {
525
+ let rowExcel = {};
526
+ columns.filter(obj => !byFiltre || obj.exportable == true).forEach(col => {
527
+ if (row[col.id].excelSubstitution != null) {
528
+ rowExcel[col.id] = row[col.id].excelSubstitution;
529
+ }
530
+ else {
531
+ rowExcel[col.id] = this.getValueByType(row[col.id], col);
532
+ }
533
+ });
534
+ // Application du style de chaque cellule
535
+ let result = ws.addRow(rowExcel);
536
+ columns.filter(obj => !byFiltre || obj.exportable == true).forEach((col, index) => {
537
+ const cell = result.getCell(index + 1);
538
+ if (row[col.id].bold) {
539
+ cell.font = { bold: true };
540
+ }
541
+ if (withColors) {
542
+ if ((row.color != null && row.color != '') || (row[col.id].color != null && row[col.id].color != '')) {
543
+ cell.style.fill = {
544
+ type: "pattern",
545
+ pattern: "solid",
546
+ fgColor: {
547
+ argb: row[col.id].color != null ? this.getHexaColor(row[col.id].color) : this.getHexaColor(row.color)
548
+ },
549
+ bgColor: {
550
+ argb: row[col.id].color != null ? this.getHexaColor(row[col.id].color) : this.getHexaColor(row.color)
551
+ }
552
+ };
553
+ }
554
+ }
555
+ });
556
+ }
557
+ });
558
+ // Style
559
+ this.setStyleGlobalGrille(ws);
560
+ // Sauvegarde
561
+ wb.xlsx.writeBuffer().then(function (buffer) {
562
+ const data = new Blob([buffer], {
563
+ type: 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet',
564
+ });
565
+ FileSaver.saveAs(data, "Export Excel.xlsx");
566
+ });
567
+ }
568
+ getHexaColor(color) {
569
+ var ctx = document.createElement('canvas').getContext('2d');
570
+ ctx.fillStyle = color;
571
+ return ctx.fillStyle.replace('#', '');
572
+ }
573
+ setStyleGlobalGrille(ws) {
574
+ ws.views = [
575
+ { state: 'frozen', ySplit: 1 }
576
+ ];
577
+ ws.eachRow((row, rowNumber) => {
578
+ row.eachCell({ includeEmpty: true }, (cell, number) => {
579
+ if (rowNumber == 1) {
580
+ cell.fill = {
581
+ pattern: 'solid',
582
+ type: 'pattern',
583
+ fgColor: {
584
+ argb: '2fab49',
585
+ },
586
+ };
587
+ cell.alignment = { horizontal: 'center' };
588
+ cell.alignment.vertical = 'middle';
589
+ cell.font = {
590
+ name: 'Arial',
591
+ size: 10,
592
+ bold: true
593
+ };
594
+ cell.border = {
595
+ bottom: { style: 'thin' },
596
+ top: { style: 'thin' },
597
+ left: { style: 'thin' },
598
+ right: { style: 'thin' },
599
+ };
600
+ }
601
+ else {
602
+ cell.border = {
603
+ bottom: { style: 'thin' },
604
+ top: { style: 'thin' },
605
+ left: { style: 'thin' },
606
+ right: { style: 'thin' },
607
+ };
608
+ }
609
+ });
610
+ });
611
+ ws.autoFilter = {
612
+ from: 'A1',
613
+ to: this.columnIndexToColumnLetter(ws.columnCount).toString() + '1',
614
+ };
615
+ }
616
+ columnIndexToColumnLetter(column) {
617
+ var temp, letter = '';
618
+ while (column > 0) {
619
+ temp = (column - 1) % 26;
620
+ letter = String.fromCharCode(temp + 65) + letter;
621
+ column = (column - temp - 1) / 26;
723
622
  }
724
- else {
725
- return obj;
623
+ return letter;
624
+ }
625
+ getValueByType(cell, col) {
626
+ switch (col.type) {
627
+ case ColType.MultiSelect:
628
+ let optionLabelMulti = cell.options != null && cell.options.optionLabel != null ? cell.options.optionLabel : col.options.optionLabel;
629
+ return cell.value.map(val => val[optionLabelMulti]).join(', ');
630
+ case ColType.SelectButton:
631
+ case ColType.Dropdown:
632
+ case ColType.State:
633
+ let optionLabel = cell.options != null && cell.options.optionLabel != null ? cell.options.optionLabel : col.options.optionLabel;
634
+ return cell.value != null ? cell.value[optionLabel] : null;
635
+ case ColType.Image:
636
+ case ColType.Button:
637
+ return null;
638
+ case ColType.Switch:
639
+ return cell.value == true ? 'Oui' : 'Non';
640
+ case ColType.Date:
641
+ if (cell.value != null) {
642
+ let dateStr = cell.value.getFullYear() + '-' + ((cell.value.getMonth() + 1 < 10) ? '0' + (cell.value.getMonth() + 1) : (cell.value.getMonth() + 1)) + '-' + (cell.value.getDate() < 10 ? '0' + cell.value.getDate() : cell.value.getDate()) + 'T00:00:00.000Z';
643
+ return new Date(dateStr);
644
+ }
645
+ else {
646
+ return null;
647
+ }
648
+ default:
649
+ return cell.value;
650
+ }
651
+ }
652
+ getStyleByType(type) {
653
+ switch (type) {
654
+ case ColType.Date:
655
+ return { numFmt: 'dd/mm/yyyy' };
656
+ case ColType.CilogNumber:
657
+ case ColType.Number:
658
+ return { numFmt: '#,##0.00' };
659
+ default:
660
+ return null;
726
661
  }
727
662
  }
728
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "21.0.6", ngImport: i0, type: ValuePipe, deps: [], target: i0.ɵɵFactoryTarget.Pipe }); }
729
- static { this.ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "14.0.0", version: "21.0.6", ngImport: i0, type: ValuePipe, isStandalone: false, name: "value" }); }
663
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "21.0.6", ngImport: i0, type: ExportService, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
664
+ static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "21.0.6", ngImport: i0, type: ExportService, providedIn: 'root' });
730
665
  }
731
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "21.0.6", ngImport: i0, type: ValuePipe, decorators: [{
732
- type: Pipe,
666
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "21.0.6", ngImport: i0, type: ExportService, decorators: [{
667
+ type: Injectable,
733
668
  args: [{
734
- name: 'value',
735
- standalone: false
669
+ providedIn: 'root'
736
670
  }]
737
- }] });
671
+ }], ctorParameters: () => [] });
738
672
 
739
673
  class CilogTableComponent {
674
+ confirmationService;
675
+ filterService;
676
+ cdRef;
677
+ exportService;
678
+ initFilter = true;
679
+ columns;
680
+ columnsChange = new EventEmitter();
681
+ values;
682
+ valuesChange = new EventEmitter();
683
+ options;
684
+ loading;
685
+ onEdit = new EventEmitter();
686
+ onEditInit = new EventEmitter();
687
+ onDelete = new EventEmitter();
688
+ onSelect = new EventEmitter();
689
+ onUnselect = new EventEmitter();
690
+ onFilter = new EventEmitter();
691
+ onFilterInit = new EventEmitter();
692
+ onSort = new EventEmitter();
693
+ onPage = new EventEmitter();
694
+ onRowDoubleClick = new EventEmitter();
695
+ selectedRows;
696
+ filterDatesRange;
697
+ optionsSwitch;
698
+ contextMenuSelectedItem;
699
+ table;
700
+ cm;
701
+ inputNumber;
740
702
  constructor(confirmationService, filterService, cdRef, exportService) {
741
703
  this.confirmationService = confirmationService;
742
704
  this.filterService = filterService;
743
705
  this.cdRef = cdRef;
744
706
  this.exportService = exportService;
745
- this.initFilter = true;
746
- this.columnsChange = new EventEmitter();
747
- this.valuesChange = new EventEmitter();
748
- this.onEdit = new EventEmitter();
749
- this.onEditInit = new EventEmitter();
750
- this.onDelete = new EventEmitter();
751
- this.onSelect = new EventEmitter();
752
- this.onUnselect = new EventEmitter();
753
- this.onFilter = new EventEmitter();
754
- this.onFilterInit = new EventEmitter();
755
- this.onSort = new EventEmitter();
756
- this.onPage = new EventEmitter();
757
- this.onRowDoubleClick = new EventEmitter();
758
707
  }
759
708
  ngOnInit() {
760
709
  this.optionsSwitch = [
@@ -1340,12 +1289,28 @@ class CilogTableComponent {
1340
1289
  this.inputNumber.input.nativeElement.focus();
1341
1290
  });
1342
1291
  }
1343
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "21.0.6", ngImport: i0, type: CilogTableComponent, deps: [{ token: i1.ConfirmationService }, { token: i1.FilterService }, { token: i0.ChangeDetectorRef }, { token: ExportService }], target: i0.ɵɵFactoryTarget.Component }); }
1344
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "21.0.6", type: CilogTableComponent, isStandalone: false, selector: "cilog-table", inputs: { columns: "columns", values: "values", options: "options", loading: "loading" }, outputs: { columnsChange: "columnsChange", valuesChange: "valuesChange", onEdit: "onEdit", onEditInit: "onEditInit", onDelete: "onDelete", onSelect: "onSelect", onUnselect: "onUnselect", onFilter: "onFilter", onFilterInit: "onFilterInit", onSort: "onSort", onPage: "onPage", onRowDoubleClick: "onRowDoubleClick" }, viewQueries: [{ propertyName: "table", first: true, predicate: ["table"], descendants: true, static: true }, { propertyName: "cm", first: true, predicate: ["cm"], descendants: true }, { propertyName: "inputNumber", first: true, predicate: ["inputNumber"], descendants: true }], ngImport: i0, template: "<div [ngStyle]=\"{ 'height': options.scrollHeight != null ? options.scrollHeight : '100%' }\">\n\n @if (options.exportExcel) {\n <button pButton\n icon=\"pi pi-file-excel\"\n class=\"p-button-success absolute z-5 w-2rem h-2rem border-round-right border-noround-top\"\n pTooltip=\"Exporter le contenu de la grille au format Excel\"\n (click)=\"exportExcel(options.exportExcelByFiltre, !options.exportExcelNoColors)\">\n </button>\n }\n\n <p-contextMenu #cm [model]=\"options.contextMenuItems\" />\n\n <p-table #table\n [columns]=\"columns\"\n [value]=\"values\"\n dataKey=\"id\"\n [selectionMode]=\"getModeSelection()\"\n [metaKeySelection]=\"isModeMetakeySelection()\"\n [(selection)]=\"selectedRows\"\n (onRowSelect)=\"onSelectRow($event)\"\n (onRowUnselect)=\"onUnselectRow($event)\"\n (onHeaderCheckboxToggle)=\"onSelectAll($event)\"\n (sortFunction)=\"sortGrille($event)\"\n [customSort]=\"options.grouping == null ? true : false\"\n [scrollable]=\"true\"\n [loading]=\"loading\"\n [scrollHeight]=\"'flex'\"\n [rowGroupMode]=\"options.grouping != null ? 'subheader' : null\"\n [groupRowsBy]=\"options.grouping != null ? options.grouping.obj + '.' + options.grouping.id : null\"\n [groupRowsByOrder]=\"0\"\n [virtualScroll]=\"options.virtualScroll == true && options.scrollHeight != null ? true : false\"\n [virtualScrollItemSize]=\"options.virtualScrollItemSize != null ? options.virtualScrollItemSize : 35\"\n [paginator]=\"options.paginator == null ? false : true\"\n [rows]=\"options.paginatorRows\"\n (onPage)=\"onPageTable($event)\"\n [tableStyleClass]=\"!options.themeGrille ? 'grid_grey' : options.themeGrille\"\n [lazy]=\"options.lazy == true ? true : false\"\n (onFilter)=\"onFilterTable($event)\"\n [rowTrackBy]=\"trackByFunction\"\n [(contextMenuSelection)]=\"contextMenuSelectedItem\"\n [contextMenu]=\"cm\">\n\n <!-- HEADER -->\n <ng-template pTemplate=\"header\" let-columns>\n\n <!-- HEADERS -->\n <tr class=\"rowHeader\">\n @if (isModeCheckboxSelection()) {\n <th class=\"cellDelete\"\n pFrozenColumn>\n @if (!options.filterable && options.toggleAll) {\n <p-tableHeaderCheckbox></p-tableHeaderCheckbox>\n }\n </th>\n }\n @for (col of columns; track col) {\n @if (!col.invisible) {\n <th\n [ngStyle]=\"{ 'width' : col.width ? col.width : null, 'background-color': col.backgroundColor ? col.backgroundColor : null }\"\n [ngClass]=\"{ 'text-center' : options.centerHeaders, 'headerAffichageSimple': !options.headersAffichageEntier, 'headerAffichageEntier': options.headersAffichageEntier }\"\n [pSortableColumn]=\"col.id\"\n [pSortableColumnDisabled]=\"!options.sortable || options.grouping != null || col.libelle == null || col.libelle == ''\"\n id=\"{{ col.id }}\"\n (click)=\"refreshData()\"\n pFrozenColumn\n [frozen]=\"col.frozen\"\n [pTooltip]=\"col.libelle\"\n [tooltipDisabled]=\"!col.tooltipHeader\"\n tooltipPosition=\"bottom\">\n <div [ngStyle]=\"{ 'color': col.textColor ? col.textColor : null }\">\n {{ col.libelle }}\n </div>\n @if (options.sortable && options.grouping == null && col.libelle != null && col.libelle != '') {\n <p-sortIcon\n [field]=\"col.id\">\n </p-sortIcon>\n }\n </th>\n }\n }\n @if (options.rowsDeletable) {\n <th class=\"cellDelete\"></th>\n }\n </tr>\n\n <!-- FILTRES -->\n @if (options.filterable) {\n <tr class=\"rowFilter\">\n @if (isModeCheckboxSelection()) {\n <th class=\"cellDelete\"\n pFrozenColumn>\n @if (options.toggleAll) {\n <p-tableHeaderCheckbox></p-tableHeaderCheckbox>\n }\n </th>\n }\n @for (col of columns; track col) {\n <!-- Text -->\n @if (!col.invisible && ((checkType('Dropdown', col) && col.options.filterText)\n || (checkType('MultiSelect', col) && col.options.filterText)\n || checkType('Text', col)\n || checkType('File', col)\n || (checkType('Button', col) && col.options.filterCol))\n || checkType('Number', col)\n || checkType('CilogNumber', col)) {\n <th\n [ngStyle]=\"{ 'width' : col.width ? col.width : null }\"\n pFrozenColumn\n [frozen]=\"col.frozen\">\n @if (!col.disableFilter) {\n <input\n pInputText\n type=\"text\"\n (input)=\"onFilterCol($event, col)\"\n [(ngModel)]=\"col.options.defaultFilters\">\n }\n </th>\n }\n <!-- Date -->\n @if (!col.invisible && checkType('Date', col)) {\n <th\n [ngStyle]=\"{ 'width' : col.width ? col.width : null }\"\n pFrozenColumn\n [frozen]=\"col.frozen\">\n @if (!col.disableFilter) {\n <p-datepicker\n [view]=\"getOption(col, rowData, 'mode') == null ? 'date' : getOption(col, rowData, 'mode')\"\n [dateFormat]=\"getOption(col, rowData, 'mode') == 'year' ? 'yy' : getOption(col, rowData, 'mode') == 'month' ? 'mm/yy' : 'dd/mm/yy'\"\n [inputId]=\"col.id + '_filter'\"\n firstDayOfWeek=\"1\"\n [readonlyInput]=\"true\"\n appendTo=\"body\"\n selectionMode=\"range\"\n (onSelect)=\"onFilterCol($event, col)\"\n showButtonBar=\"true\"\n (onClearClick)=\"onFilterCol($event, col)\"\n [(ngModel)]=\"col.options.defaultFilters\">\n </p-datepicker>\n }\n </th>\n }\n <!-- Liste -->\n @if (!col.invisible && ((checkType('Dropdown', col) && !col.options.filterText) || (checkType('MultiSelect', col) && !col.options.filterText) || checkType('SelectButton', col) || checkType('State', col))) {\n <th\n [ngStyle]=\"{ 'width' : col.width ? col.width : null }\"\n pFrozenColumn\n [frozen]=\"col.frozen\">\n @if (!col.disableFilter) {\n <p-multiSelect\n [options]=\"col.options?.options\"\n [filter]=\"true\"\n dataKey=\"ID\"\n [optionLabel]=\"col.options?.optionLabel\"\n appendTo=\"body\"\n emptyFilterMessage=\"Aucun r\u00E9sultat\"\n emptyMessage=\"Aucun r\u00E9sultat\"\n [virtualScroll]=\"true\"\n [virtualScrollItemSize]=\"35\"\n selectedItemsLabel=\"{0} selectionn\u00E9s\"\n (onChange)=\"onFilterCol($event, col)\"\n [(ngModel)]=\"col.options.defaultFilters\"\n [group]=\"col.options.optionGroupChildren != null ? true : false\"\n [optionGroupLabel]=\"col.options.optionGroupLabel\"\n [optionGroupChildren]=\"col.options.optionGroupChildren\"\n [showToggleAll]=\"false\"\n [showClear]=\"true\"\n (onClear)=\"onFilterCol(null, col)\">\n <ng-template let-group pTemplate=\"group\">\n <div>{{group[col.options.optionGroupLabel]}}</div>\n </ng-template>\n </p-multiSelect>\n }\n </th>\n }\n <!-- Switch -->\n @if (!col.invisible && checkType('Switch', col)) {\n <th\n [ngStyle]=\"{ 'width' : col.width ? col.width : null }\"\n pFrozenColumn\n [frozen]=\"col.frozen\">\n @if (!col.disableFilter) {\n <p-multiSelect\n [options]=\"optionsSwitch\"\n [showHeader]=\"false\"\n optionLabel=\"label\"\n optionValue=\"value\"\n appendTo=\"body\"\n emptyFilterMessage=\"Aucun r\u00E9sultat\"\n emptyMessage=\"Aucun r\u00E9sultat\"\n [virtualScrollItemSize]=\"30\"\n selectedItemsLabel=\"{0} selectionn\u00E9s\"\n (onChange)=\"onFilterCol($event, col)\"\n [(ngModel)]=\"col.options.defaultFilters\">\n </p-multiSelect>\n }\n </th>\n }\n <!-- Non filtrable -->\n @if (!col.invisible && (checkType('Image', col) || (checkType('Button', col) && !col.options.filterCol))) {\n <th\n [ngStyle]=\"{ 'width' : col.width ? col.width : null }\"\n pFrozenColumn\n [frozen]=\"col.frozen\">\n </th>\n }\n }\n @if (options.rowsDeletable) {\n <th class=\"cellDelete\"></th>\n }\n </tr>\n }\n\n <!-- TOTAL -->\n @if (options.rowTotal) {\n <tr\n class=\"rowTotal\">\n @if (isModeCheckboxSelection()) {\n <th class=\"cellDelete\"\n pFrozenColumn>\n </th>\n }\n @for (col of columns; track col) {\n @if (!col.invisible) {\n <th\n [ngStyle]=\"{ 'width' : col.width ? col.width : null }\"\n [ngClass]=\"{ 'text-center' : true }\"\n pFrozenColumn\n [frozen]=\"col.frozen\">\n <div>{{ getTotalStr(col) }}</div>\n </th>\n }\n }\n @if (options.rowsDeletable) {\n <th class=\"cellDelete\"></th>\n }\n </tr>\n }\n </ng-template>\n\n <!--Groupheader-->\n <ng-template pTemplate=\"groupheader\" let-rowData>\n <tr pRowGroupHeader class=\"rowGrouping\">\n <td [attr.colspan]=\"columns.length\">\n <div class=\"text_bold\">{{ rowData[options.grouping.obj][options.grouping.libelle] }}</div>\n </td>\n </tr>\n </ng-template>\n\n <!-- Body -->\n <ng-template pTemplate=\"body\" let-rowData let-columns=\"columns\">\n <tr id=\"{{ rowData.id }}\"\n [ngStyle]=\"{ 'background-color': rowData.color ? rowData.color : null }\"\n [pSelectableRow]=\"rowData\"\n [pSelectableRowDisabled]=\"!options.selectable || isModeCheckboxSelection() || isModeCellSelection()\"\n (dblclick)=\"onRowDoubleClickEvent(rowData)\"\n [pContextMenuRow]=\"rowData\"\n [pContextMenuRowDisabled]=\"options.contextMenuItems == null\">\n\n @if (isModeCheckboxSelection()) {\n <td\n class=\"cellDelete\"\n pFrozenColumn>\n <p-tableCheckbox [value]=\"rowData\" [disabled]=\"rowData.readonly\"></p-tableCheckbox>\n </td>\n }\n\n @for (col of columns; track col) {\n <!-- Text -->\n @if (!col.invisible && checkType('Text', col) && isModeEdition() && !rowData.readonly && !rowData[col.id]?.readonly) {\n <td\n [ngStyle]=\"{ 'width' : col.width ? col.width : null, 'background-color': rowData[col.id].color ? rowData[col.id].color : null }\"\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\n [pEditableColumn]=\"rowData\"\n [pEditableColumnField]=\"col.id\"\n [pTooltip]=\"rowData[col.id].tooltip != null ? rowData[col.id].tooltip : rowData[col.id].value\"\n [tooltipDisabled]=\"!col.tooltip\"\n tooltipPosition=\"bottom\"\n pFrozenColumn\n (click)=\"options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection && !rowData[col.id].disableSelection && onSelectCell(rowData[col.id])\"\n [frozen]=\"col.frozen\"\n [ngClass]=\"{\r\n 'text-left': col.position == 'left' || col.position == null,\r\n 'text-right': col.position == 'right',\r\n 'text-center': col.position == 'center',\r\n 'font-bold': rowData.bold == true || rowData[col.id].bold == true,\r\n 'font-italic': rowData.italic == true || rowData[col.id].italic == true,\r\n 'selectable_cell' : options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection\r\n }\">\r\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\n <p-cellEditor>\n <ng-template pTemplate=\"input\">\n <input pInputText\n type=\"text\"\n [(ngModel)]=\"rowData[col.id].value\"\n (blur)=\"onEditCell(rowData, col, rowData[col.id].value)\"\n (keydown.enter)=\"onEditCell(rowData, col, rowData[col.id].value)\"\n (keydown.tab)=\"onEditCell(rowData, col, rowData[col.id].value)\"\n (click)=\"onEditInitCell(rowData, col, rowData[col.id].value)\"\n [ngClass]=\"{\r\n 'text-left': col.position == 'left' || col.position == null,\r\n 'text-right': col.position == 'right',\r\n 'text-center': col.position == 'center',\r\n 'font-bold': rowData.bold == true || rowData[col.id].bold == true,\r\n 'font-italic': rowData.italic == true || rowData[col.id].italic == true\r\n }\" />\r\n </ng-template>\n <ng-template pTemplate=\"output\">\n @if (rowData[col.id]) {\n <div\n style=\"white-space: pre;\">\n {{ getFormattedText(col, rowData) }}\n </div>\n }\n </ng-template>\n </p-cellEditor>\n </td>\n }\n @if (!col.invisible && checkType('Text', col) && (!isModeEdition() || rowData.readonly || rowData[col.id]?.readonly)) {\n <td\n [ngStyle]=\"{\r\n 'width' : col.width ? col.width : null,\r\n 'background-color' : rowData[col.id].color ? rowData[col.id].color : null,\r\n 'color' : rowData[col.id].textColor ? rowData[col.id].textColor : null\r\n }\"\r\n (click)=\"options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection && !rowData[col.id].disableSelection && onSelectCell(rowData[col.id])\"\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\n [pTooltip]=\"rowData[col.id].tooltip != null ? rowData[col.id].tooltip : rowData[col.id].value\"\n [tooltipDisabled]=\"!col.tooltip\"\n tooltipPosition=\"bottom\"\n [ngClass]=\"{\r\n 'paddingCell': rowData[col.id] != null,\r\n 'text-left': col.position == 'left' || col.position == null,\r\n 'text-right': col.position == 'right',\r\n 'text-center': col.position == 'center',\r\n 'font-bold': rowData.bold == true || rowData[col.id].bold == true,\r\n 'font-italic': rowData.italic == true || rowData[col.id].italic == true,\r\n 'selectable_cell' : options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection\r\n }\"\r\n pFrozenColumn\n [frozen]=\"col.frozen\">\n <div class=\"p-column-title\">\n {{ col.libelle }} :\n </div>\n @if (rowData[col.id]) {\n <div\n style=\"white-space: pre;\">\n {{ getFormattedText(col, rowData) }}\n </div>\n }\n </td>\n }\n <!-- Dropdown -->\n @if (!col.invisible && checkType('Dropdown', col) && isModeEdition() && !rowData.readonly && !rowData[col.id]?.readonly) {\n <td\n [ngStyle]=\"{ 'width' : col.width ? col.width : null, 'background-color': rowData[col.id].color ? rowData[col.id].color : null }\"\n [ngClass]=\"{\r\n 'text-left': col.position == 'left' || col.position == null,\r\n 'text-right': col.position == 'right',\r\n 'text-center': col.position == 'center',\r\n 'selectable_cell' : options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection\r\n }\"\r\n (click)=\"options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection && onSelectCell(rowData[col.id])\"\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\n [pTooltip]=\"rowData[col.id].tooltip != null ? rowData[col.id].tooltip : rowData[col.id].value != null ? rowData[col.id].value[getOption(col, rowData, 'optionLabel')] : ''\"\n [tooltipDisabled]=\"!col.tooltip\"\n tooltipPosition=\"bottom\"\n pFrozenColumn\n [frozen]=\"col.frozen\"\n class=\"paddingCell\">\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\n @if (rowData[col.id] != null) {\n <p-select\n dataKey=\"ID\"\n [options]=\"getOption(col, rowData, 'options')\"\n [filter]=\"getOption(col, rowData, 'filter')\"\n [optionLabel]=\"getOption(col, rowData, 'optionLabel')\"\n [(ngModel)]=\"rowData[col.id].value\"\n [autoDisplayFirst]=\"false\"\n appendTo=\"body\"\n [showClear]=\"getOption(col, rowData, 'deletable')\"\n emptyFilterMessage=\"Aucun r\u00E9sultat\"\n emptyMessage=\"Aucun r\u00E9sultat\"\n [baseZIndex]=\"getOption(col, rowData, 'baseZIndex')\"\n [virtualScroll]=\"getOption(col, rowData, 'virtualScroll')\"\n [readonly]=\"rowData.readonly || rowData[col.id]?.readonly\"\n [virtualScrollItemSize]=\"30\"\n (onChange)=\"onEditCell(rowData, col, rowData[col.id].value)\"\n (onClear)=\"onEditCell(rowData, col, rowData[col.id].value)\">\n <ng-template let-data pTemplate=\"selectedItem\">\n @if (data != null) {\n <span\n [ngClass]=\"{\r\n 'font-bold': rowData.bold == true || rowData[col.id].bold == true,\r\n 'font-italic': rowData.italic == true || rowData[col.id].italic == true\r\n }\">\r\n {{ data[getOption(col, rowData, 'optionLabel')] }}\n </span>\n }\n @if (data == null) {\n <span></span>\n }\n </ng-template>\n </p-select>\n }\n </td>\n }\n @if (!col.invisible && checkType('Dropdown', col) && (rowData.readonly || rowData[col.id]?.readonly || !isModeEdition())) {\n <td\n [ngStyle]=\"{\r\n 'width' : col.width ? col.width : null,\r\n 'background-color': rowData[col.id].color ? rowData[col.id].color : null,\r\n 'color' : rowData[col.id].textColor ? rowData[col.id].textColor : null\r\n }\"\r\n (click)=\"options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection && onSelectCell(rowData[col.id])\"\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\n [pTooltip]=\"rowData[col.id].tooltip != null ? rowData[col.id].tooltip : rowData[col.id].value != null ? rowData[col.id].value[getOption(col, rowData, 'optionLabel')] : ''\"\n [tooltipDisabled]=\"!col.tooltip\"\n tooltipPosition=\"bottom\"\n [ngClass]=\"{\r\n 'paddingCell': rowData[col.id] != null,\r\n 'text-left': col.position == 'left' || col.position == null,\r\n 'text-right': col.position == 'right',\r\n 'text-center': col.position == 'center',\r\n 'font-bold': rowData.bold == true || rowData[col.id].bold == true,\r\n 'font-italic': rowData.italic == true || rowData[col.id].italic == true,\r\n 'selectable_cell' : options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection\r\n }\"\r\n pFrozenColumn\n [frozen]=\"col.frozen\">\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\n @if (rowData[col.id]) {\n <div>{{ rowData[col.id].value != null ? rowData[col.id].value[getOption(col, rowData, 'optionLabel')] : '' }}</div>\n }\n </td>\n }\n <!-- Cilog Number -->\n @if (!col.invisible && checkType('CilogNumber', col) && isModeEdition() && !rowData.readonly && !rowData[col.id]?.readonly) {\n <td\n [ngStyle]=\"{ 'width' : col.width ? col.width : null, 'background-color': rowData[col.id].color ? rowData[col.id].color : null }\"\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\n [ngClass]=\"{\r\n 'paddingCell': rowData[col.id] != null,\r\n 'selectable_cell' : options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection\r\n }\"\r\n (click)=\"options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection && onSelectCell(rowData[col.id])\"\n [pTooltip]=\"rowData[col.id].tooltip != null ? rowData[col.id].tooltip : rowData[col.id].value | value\"\n [tooltipDisabled]=\"!col.tooltip\"\n tooltipPosition=\"bottom\"\n pFrozenColumn\n [frozen]=\"col.frozen\">\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\n @if (rowData[col.id] && !rowData.readonly && !rowData[col.id]?.readonly) {\n <cilog-input-number\n (onInput)=\"onInputNumber($event)\"\n [(ngModel)]=\"rowData[col.id].value\"\n [inputStyleClass]=\"col.position == null || col.position == 'right' ? 'text-right' : col.position == 'left' ? 'text-left' : 'text-center'\"\n [textColor]=\"rowData[col.id].textColor\"\n [bold]=\"rowData.bold == true || rowData[col.id].bold == true\"\n [italic]=\"rowData.italic == true || rowData[col.id].italic == true\"\n [suffixe]=\"getOption(col, rowData, 'suffix')\"\n [prefixe]=\"getOption(col, rowData, 'prefix') != null ? getOption(col, rowData, 'prefix') + ' ' : null\"\n [min]=\"getOption(col, rowData, 'min')\"\n [max]=\"getOption(col, rowData, 'max')\"\n [disabled]=\"rowData.readonly || rowData[col.id]?.readonly\"\n [maxDecimals]=\"getOption(col, rowData, 'modeInteger') != null && getOption(col, rowData, 'modeInteger') == true ? 0 : getOption(col, rowData, 'maxDecimales') != null ? getOption(col, rowData, 'maxDecimales') : 2 \"\n (onChange)=\"onEditCell(rowData, col, rowData[col.id].value)\"\n (onFocus)=\"onEditInitCell(rowData, col, rowData[col.id].value)\">\n </cilog-input-number>\n }\n </td>\n }\n @if (!col.invisible && checkType('CilogNumber', col) && (rowData.readonly || rowData[col.id]?.readonly || !isModeEdition())) {\n <td\n [ngStyle]=\"{\r\n 'width' : col.width ? col.width : null,\r\n 'background-color': rowData[col.id].color ? rowData[col.id].color : null,\r\n 'color' : rowData[col.id].textColor ? rowData[col.id].textColor : null\r\n }\"\r\n (click)=\"options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection && onSelectCell(rowData[col.id])\"\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\n [pTooltip]=\"rowData[col.id].tooltip != null ? rowData[col.id].tooltip : rowData[col.id].value | value\"\n [tooltipDisabled]=\"!col.tooltip\"\n tooltipPosition=\"bottom\"\n [ngClass]=\"{\r\n 'paddingCell': rowData[col.id] != null,\r\n 'text-left': col.position == 'left' || col.position == null,\r\n 'text-right': col.position == 'right',\r\n 'text-center': col.position == 'center',\r\n 'font-bold': rowData.bold == true || rowData[col.id].bold == true,\r\n 'font-italic': rowData.italic == true || rowData[col.id].italic == true,\r\n 'selectable_cell' : options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection\r\n }\"\r\n pFrozenColumn\n [frozen]=\"col.frozen\">\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\n @if (rowData[col.id]) {\n <div>{{ getFormattedNumber(col, rowData, rowData[col.id].value) }}</div>\n }\n </td>\n }\n <!-- Number -->\n @if (!col.invisible && checkType('Number', col) && isModeEdition() && !rowData.readonly && !rowData[col.id]?.readonly) {\n <td\n [ngStyle]=\"{ 'width' : col.width ? col.width : null, 'background-color': rowData[col.id].color ? rowData[col.id].color : null }\"\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\n [pTooltip]=\"rowData[col.id].tooltip != null ? rowData[col.id].tooltip : rowData[col.id].value | value\"\n [tooltipDisabled]=\"!col.tooltip\"\n [ngClass]=\"{\r\n 'paddingCell': rowData[col.id] != null,\r\n 'text-left': col.position == 'left',\r\n 'text-right': col.position == 'right' || col.position == null,\r\n 'text-center': col.position == 'center',\r\n 'font-bold': rowData.bold == true || rowData[col.id].bold == true,\r\n 'font-italic': rowData.italic == true || rowData[col.id].italic == true,\r\n 'selectable_cell' : options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection\r\n }\"\r\n tooltipPosition=\"bottom\"\n pFrozenColumn\n [frozen]=\"col.frozen\"\n (click)=\"onClickCellNumber(rowData, col)\">\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\n @if (rowData[col.id] && !rowData[col.id].focus) {\n <div>\n {{ getFormattedNumber(col, rowData, rowData[col.id].value) }}\n </div>\n }\n @if (rowData[col.id] && !rowData.readonly && !rowData[col.id]?.readonly && rowData[col.id].focus == true) {\n <p-inputNumber #inputNumber\n locale=\"fr-FR\"\n (onInput)=\"onInputNumber($event)\"\n [(ngModel)]=\"rowData[col.id].value\"\n [showButtons]=\"getOption(col, rowData, 'showButtons')\"\n [inputStyleClass]=\"col.position == null || col.position == 'right' ? 'text-right' : col.position == 'left' ? 'text-left' : 'text-center'\"\n [inputStyle]=\"{ 'font-weight': rowData.bold == true || rowData[col.id].bold == true ? 'bold' : null, 'font-style': rowData.italic == true || rowData[col.id].italic == true ? 'italic' : null }\"\n [suffix]=\"getOption(col, rowData, 'suffix')\"\n [prefix]=\"getOption(col, rowData, 'prefix') != null ? getOption(col, rowData, 'prefix') + ' ' : null\"\n [min]=\"getOption(col, rowData, 'min')\"\n [max]=\"getOption(col, rowData, 'max')\"\n [minFractionDigits]=\"getOption(col, rowData, 'modeInteger') != null && getOption(col, rowData, 'modeInteger') == true ? 0 : getOption(col, rowData, 'minDecimales') != null ? getOption(col, rowData, 'minDecimales') : 0\"\n [maxFractionDigits]=\"getOption(col, rowData, 'modeInteger') != null && getOption(col, rowData, 'modeInteger') == true ? 0 : getOption(col, rowData, 'maxDecimales') != null ? getOption(col, rowData, 'maxDecimales') : 2 \"\n (onBlur)=\"onEditCell(rowData, col, rowData[col.id].value)\"\n (onKeyDown)=\"onKeyDown($event, rowData, col, rowData[col.id].value)\"\n (onFocus)=\"onEditInitCell(rowData, col, rowData[col.id].value)\">\n </p-inputNumber>\n }\n </td>\n }\n @if (!col.invisible && checkType('Number', col) && (rowData.readonly || rowData[col.id]?.readonly || !isModeEdition())) {\n <td\n [ngStyle]=\"{\r\n 'width' : col.width ? col.width : null,\r\n 'background-color': rowData[col.id].color ? rowData[col.id].color : null,\r\n 'color' : rowData[col.id].textColor ? rowData[col.id].textColor : null\r\n }\"\r\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\n [pTooltip]=\"rowData[col.id].tooltip != null ? rowData[col.id].tooltip : rowData[col.id].value | value\"\n [tooltipDisabled]=\"!col.tooltip\"\n tooltipPosition=\"bottom\"\n (click)=\"options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection && onSelectCell(rowData[col.id])\"\n [ngClass]=\"{\r\n 'paddingCell': rowData[col.id] != null,\r\n 'text-left': col.position == 'left',\r\n 'text-right': col.position == 'right' || col.position == null,\r\n 'text-center': col.position == 'center',\r\n 'font-bold': rowData.bold == true || rowData[col.id].bold == true,\r\n 'font-italic': rowData.italic == true || rowData[col.id].italic == true,\r\n 'selectable_cell' : options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection\r\n }\"\r\n pFrozenColumn\n [frozen]=\"col.frozen\">\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\n @if (rowData[col.id]) {\n <div>{{ getFormattedNumber(col, rowData, rowData[col.id].value) }}</div>\n }\n </td>\n }\n <!-- Date -->\n @if (!col.invisible && checkType('Date', col) && isModeEdition() && !rowData.readonly && !rowData[col.id]?.readonly) {\n <td\n [ngStyle]=\"{ 'width' : col.width ? col.width : null, 'background-color': rowData[col.id].color ? rowData[col.id].color : null }\"\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\n [ngClass]=\"{\r\n 'paddingCell': rowData[col.id] != null,\r\n 'selectable_cell' : options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection\r\n }\"\r\n (click)=\"options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection && onSelectCell(rowData[col.id])\"\n [pTooltip]=\"rowData[col.id].tooltip != null ? rowData[col.id].tooltip : getOption(col, rowData, 'mode') == 'year' ? (rowData[col.id].value | date: 'yyyy') : getOption(col, rowData, 'mode') == 'month' ? (rowData[col.id].value | date: 'MM/yy') : getOption(col, rowData, 'mode') == 'hour' ? (rowData[col.id].value | date: 'HH:mm') : getOption(col, rowData, 'mode') == 'datehour' ? (rowData[col.id].value | date: 'dd/MM/yy HH:mm') : (rowData[col.id].value | date: 'dd/MM/yyyy')\"\n [tooltipDisabled]=\"!col.tooltip\"\n tooltipPosition=\"bottom\"\n pFrozenColumn\n [frozen]=\"col.frozen\">\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\n <p-datepicker [(ngModel)]=\"rowData[col.id].value\"\n [view]=\"getOption(col, rowData, 'mode') == null || getOption(col, rowData, 'mode') == 'date' || getOption(col, rowData, 'mode') == 'hour' ? 'date' : getOption(col, rowData, 'mode') == 'datehour' ? 'date' : getOption(col, rowData, 'mode')\"\n [dateFormat]=\"getOption(col, rowData, 'mode') == 'year' ? 'yy' : getOption(col, rowData, 'mode') == 'month' ? 'mm/yy' : getOption(col, rowData, 'mode') == 'hour' || getOption(col, rowData, 'mode') == 'datehour' ? 'dd/mm/yy' : 'dd/mm/yy'\"\n [showTime]=\"getOption(col, rowData, 'mode') == 'datehour'\"\n [timeOnly]=\"getOption(col, rowData, 'mode') == 'hour'\"\n [hourFormat]=\"24\"\n firstDayOfWeek=\"1\"\n (onSelect)=\"onEditCell(rowData, col, rowData[col.id].value)\"\n (onBlur)=\"onEditCell(rowData, col, rowData[col.id].value)\"\n (onClear)=\"onEditCell(rowData, col, rowData[col.id].value)\"\n [inputStyleClass]=\"col.position == null || col.position == 'right' ? 'text-right' : col.position == 'left' ? 'text-left' : 'text-center'\"\n [inputStyle]=\"{ 'font-weight': rowData.bold == true || rowData[col.id].bold == true ? 'bold' : null, 'font-style': rowData.italic == true || rowData[col.id].italic == true ? 'italic' : null }\"\n [showClear]=\"getOption(col, rowData, 'clear')\"\n [minDate]=\"getOption(col, rowData, 'minDate')\"\n [maxDate]=\"getOption(col, rowData, 'maxDate')\"\n [defaultDate]=\"getOption(col, rowData, 'defaultDate')\"\n appendTo=\"body\">\n </p-datepicker>\n </td>\n }\n @if (!col.invisible && checkType('Date', col) && (rowData.readonly || rowData[col.id]?.readonly || !isModeEdition())) {\n <td\n [ngStyle]=\"{\r\n 'min-width' : col.width ? col.width : null,\r\n 'background-color': rowData[col.id].color ? rowData[col.id].color : null,\r\n 'color' : rowData[col.id].textColor ? rowData[col.id].textColor : null\r\n }\"\r\n (click)=\"options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection && onSelectCell(rowData[col.id])\"\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\n [pTooltip]=\"rowData[col.id].tooltip != null ? rowData[col.id].tooltip : rowData[col.id].value | date: 'dd/MM/yyyy'\"\n [tooltipDisabled]=\"!col.tooltip\"\n tooltipPosition=\"bottom\"\n [ngClass]=\"{\r\n 'paddingCell': rowData[col.id] != null,\r\n 'text-left': col.position == 'left' || col.position == null,\r\n 'text-right': col.position == 'right',\r\n 'text-center': col.position == 'center',\r\n 'font-bold': rowData.bold == true || rowData[col.id].bold == true,\r\n 'font-italic': rowData.italic == true || rowData[col.id].italic == true,\r\n 'selectable_cell' : options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection\r\n }\"\r\n pFrozenColumn\n [frozen]=\"col.frozen\">\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\n @if (rowData[col.id]) {\n <div>{{ rowData[col.id].value | date: (getOption(col, rowData, 'mode') == 'year' ? 'yyyy' : getOption(col, rowData, 'mode') == 'month' ? 'MM/yyyy' : 'dd/MM/yyyy') }}</div>\n }\n </td>\n }\n <!-- MultiSelect -->\n @if (!col.invisible && checkType('MultiSelect', col) && isModeEdition() && !rowData.readonly && !rowData[col.id]?.readonly) {\n <td\n [ngStyle]=\"{ 'width' : col.width ? col.width : null, 'background-color': rowData[col.id].color ? rowData[col.id].color : null }\"\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\n [ngClass]=\"{\r\n 'text-left': col.position == 'left' || col.position == null,\r\n 'text-right': col.position == 'right',\r\n 'text-center': col.position == 'center',\r\n 'selectable_cell' : options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection\r\n }\"\r\n (click)=\"options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection && onSelectCell(rowData[col.id])\"\n [pTooltip]=\"rowData[col.id].tooltip != null ? rowData[col.id].tooltip : getMultiSelectConcat(rowData[col.id].value, getOption(col, rowData, 'optionLabel'))\"\n [tooltipDisabled]=\"!col.tooltip\"\n tooltipPosition=\"bottom\"\n pFrozenColumn\n [frozen]=\"col.frozen\"\n class=\"paddingCell\">\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\n @if (rowData[col.id] != null) {\n <p-multiSelect\n [options]=\"getOption(col, rowData, 'options')\"\n [filter]=\"getOption(col, rowData, 'filter')\"\n [optionLabel]=\"getOption(col, rowData, 'optionLabel')\"\n [(ngModel)]=\"rowData[col.id].value\"\n appendTo=\"body\"\n dataKey=\"ID\"\n emptyFilterMessage=\"Aucun r\u00E9sultat\"\n emptyMessage=\"Aucun r\u00E9sultat\"\n [baseZIndex]=\"getOption(col, rowData, 'baseZIndex')\"\n [virtualScroll]=\"getOption(col, rowData, 'virtualScroll')\"\n [readonly]=\"rowData.readonly || rowData[col.id]?.readonly || !isModeEdition()\"\n [virtualScrollItemSize]=\"30\"\n selectedItemsLabel=\"{0} selectionn\u00E9s\"\n (onChange)=\"editMultiselect(rowData, col, $event)\"\n [showToggleAll]=\"false\"\n [showHeader]=\"getOption(col, rowData, 'filter')\"\n [group]=\"getOption(col, rowData, 'optionGroupChildren') != null ? true : false\"\n [optionGroupLabel]=\"getOption(col, rowData, 'optionGroupLabel')\"\n [optionGroupChildren]=\"getOption(col, rowData, 'optionGroupChildren')\"\n ngDefaultControl>\n <ng-template let-data pTemplate=\"selectedItems\">\n @for (option of data; track option; let i = $index) {\n <span\n [ngClass]=\"{\r\n 'font-bold': rowData.bold == true || rowData[col.id].bold == true,\r\n 'font-italic': rowData.italic == true || rowData[col.id].italic == true\r\n }\">\r\n {{ option[getOption(col, rowData, 'optionLabel')] + (i != data.length - 1 ? ',' : '') }}\n </span>\n }\n </ng-template>\n <ng-template let-group pTemplate=\"group\">\n <div>{{group[col.options.optionGroupLabel]}}</div>\n </ng-template>\n </p-multiSelect>\n }\n </td>\n }\n @if (!col.invisible && checkType('MultiSelect', col) && (rowData.readonly || rowData[col.id]?.readonly || !isModeEdition())) {\n <td\n [ngStyle]=\"{\r\n 'width' : col.width ? col.width : null,\r\n 'background-color': rowData[col.id].color ? rowData[col.id].color : null,\r\n 'color' : rowData[col.id].textColor ? rowData[col.id].textColor : null\r\n }\"\r\n (click)=\"options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection && onSelectCell(rowData[col.id])\"\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\n [pTooltip]=\"rowData[col.id].tooltip != null ? rowData[col.id].tooltip : getMultiSelectConcat(rowData[col.id].value, getOption(col, rowData, 'optionLabel'))\"\n [tooltipDisabled]=\"!col.tooltip\"\n tooltipPosition=\"bottom\"\n [ngClass]=\"{\r\n 'paddingCell': rowData[col.id] != null,\r\n 'text-left': col.position == 'left' || col.position == null,\r\n 'text-right': col.position == 'right',\r\n 'text-center': col.position == 'center',\r\n 'font-bold': rowData.bold == true || rowData[col.id].bold == true,\r\n 'font-italic': rowData.italic == true || rowData[col.id].italic == true,\r\n 'selectable_cell' : options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection\r\n }\"\r\n pFrozenColumn\n [frozen]=\"col.frozen\">\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\n @if (rowData[col.id]) {\n <div>{{ getMultiSelectConcat(rowData[col.id].value, getOption(col, rowData, 'optionLabel')) }}</div>\n }\n </td>\n }\n <!-- Image -->\n @if (!col.invisible && checkType('Image', col)) {\n <td\n [ngStyle]=\"{ 'width' : col.width ? col.width : null, 'background-color': rowData[col.id].color ? rowData[col.id].color : null }\"\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\n [ngClass]=\"{\r\n 'paddingCell': rowData[col.id] != null,\r\n 'selectable_cell' : options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection\r\n }\"\r\n (click)=\"options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection && onSelectCell(rowData[col.id])\"\n class=\"text-center\"\n pFrozenColumn\n [frozen]=\"col.frozen\">\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\n @if (rowData[col.id]) {\n <img style=\"vertical-align: middle; width: 40px;\" src=\"{{ rowData[col.id].value }}\" />\n }\n </td>\n }\n <!-- Button -->\n @if (!col.invisible && checkType('Button', col)) {\n <td\n class=\"paddingCell text-center\"\n [ngClass]=\"{\r\n 'selectable_cell' : options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection\r\n }\"\r\n (click)=\"options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection && onSelectCell(rowData[col.id])\"\n [ngStyle]=\"{ 'width' : col.width ? col.width : null, 'background-color': rowData[col.id].color ? rowData[col.id].color : null }\">\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\n @if (rowData[col.id].value != null && isValueButtonByType(rowData[col.id].value, 'function')) {\n <button pButton\n [disabled]=\"rowData.readonly || rowData[col.id]?.readonly\"\n [label]=\"getOption(col, rowData, 'label')\"\n [icon]=\"getOption(col, rowData, 'icon')\"\n (click)=\"rowData[col.id].value()\"\n [pTooltip]=\"rowData[col.id].tooltip != null ? rowData[col.id].tooltip : getOption(col, rowData, 'label')\"\n [tooltipDisabled]=\"!col.tooltip\"\n [class]=\"'p-button-' + getOption(col, rowData, 'severity')\"\n [ngClass]=\"{\r\n 'font-bold': rowData.bold == true || rowData[col.id].bold == true,\r\n 'font-italic': rowData.italic == true || rowData[col.id].italic == true\r\n }\">\r\n </button>\n }\n @if (isValueButtonByType(rowData[col.id].value, 'string')) {\n <div\n [ngClass]=\"{\r\n 'paddingCell': rowData[col.id] != null,\r\n 'text-left': col.position == 'left' || col.position == null,\r\n 'text-right': col.position == 'right',\r\n 'text-center': col.position == 'center',\r\n 'font-bold': rowData.bold == true || rowData[col.id].bold == true,\r\n 'font-italic': rowData.italic == true || rowData[col.id].italic == true\r\n }\"\r\n [pTooltip]=\"rowData[col.id].tooltip != null ? rowData[col.id].tooltip : rowData[col.id].value\"\n [tooltipDisabled]=\"!col.tooltip\">\n {{ rowData[col.id].value }}\n </div>\n }\n </td>\n }\n <!-- SelectButton -->\n @if (!col.invisible && checkType('SelectButton', col) && isModeEdition() && !rowData.readonly && !rowData[col.id]?.readonly) {\n <td\n [ngStyle]=\"{ 'width' : col.width ? col.width : null, 'background-color': rowData[col.id].color ? rowData[col.id].color : null }\"\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\n [ngClass]=\"{\r\n 'paddingCell': rowData[col.id] != null,\r\n 'selectable_cell' : options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection\r\n }\"\r\n (click)=\"options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection && onSelectCell(rowData[col.id])\"\n pFrozenColumn\n [frozen]=\"col.frozen\">\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\n @if (rowData[col.id] != null) {\n <p-selectButton\n [options]=\"getOption(col, rowData, 'options')\"\n [optionLabel]=\"getOption(col, rowData, 'optionLabel')\"\n [optionValue]=\"getOption(col, rowData, 'optionValue') != null ? getOption(col, rowData, 'optionValue') : 'value'\"\n [(ngModel)]=\"rowData[col.id].value\"\n [disabled]=\"rowData.readonly || rowData[col.id]?.readonly || !isModeEdition()\"\n (onChange)=\"onEditCell(rowData, col, rowData[col.id].value)\">\n <ng-template let-item pTemplate=\"item\">\n <span class=\"text-center w-full\"\n [ngClass]=\"{\r\n 'font-bold': rowData.bold == true || rowData[col.id].bold == true,\r\n 'font-italic': rowData.italic == true || rowData[col.id].italic == true\r\n }\">\r\n {{ item.label }}\n </span>\n </ng-template>\n </p-selectButton>\n }\n </td>\n }\n @if (!col.invisible && checkType('SelectButton', col) && (rowData.readonly || rowData[col.id]?.readonly || !isModeEdition())) {\n <td\n [ngStyle]=\"{\r\n 'width' : col.width ? col.width : null,\r\n 'background-color': rowData[col.id].color ? rowData[col.id].color : null,\r\n 'color' : rowData[col.id].textColor ? rowData[col.id].textColor : null\r\n }\"\r\n (click)=\"options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection && onSelectCell(rowData[col.id])\"\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\n pFrozenColumn\n [frozen]=\"col.frozen\"\n class=\"text-center\"\n [ngClass]=\"{\r\n 'paddingCell': rowData[col.id] != null,\r\n 'font-bold': rowData.bold == true || rowData[col.id].bold == true,\r\n 'font-italic': rowData.italic == true || rowData[col.id].italic == true,\r\n 'selectable_cell' : options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection\r\n }\">\r\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\n @if (rowData[col.id]) {\n <div>{{ getSelectLibelleByValue(rowData, col) }}</div>\n }\n </td>\n }\n <!-- Switch -->\n @if (!col.invisible && checkType('Switch', col)) {\n <td\n [ngStyle]=\"{ 'width' : col.width ? col.width : null, 'background-color': rowData[col.id].color ? rowData[col.id].color : null }\"\n class=\"text-center\"\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\n [ngClass]=\"{\r\n 'paddingCell': rowData[col.id] != null,\r\n 'selectable_cell' : options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection\r\n }\"\r\n (click)=\"options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection && onSelectCell(rowData[col.id])\"\n pFrozenColumn\n [frozen]=\"col.frozen\">\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\n @if (rowData[col.id] != null) {\n <p-toggleswitch\n [(ngModel)]=\"rowData[col.id].value\"\n [disabled]=\"rowData.readonly || rowData[col.id]?.readonly || (getOption(col, rowData, 'action') == null && !isModeEdition())\"\n (onChange)=\"onEditCell(rowData, col, rowData[col.id].value)\"\n ngDefaultControl>\n </p-toggleswitch>\n }\n </td>\n }\n <!-- File -->\n @if (!col.invisible && checkType('File', col) && isModeEdition() && !rowData.readonly && !rowData[col.id]?.readonly) {\n <td\n [ngStyle]=\"{ 'width' : col.width ? col.width : null, 'background-color': rowData[col.id].color ? rowData[col.id].color : null }\"\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\n [ngClass]=\"{\r\n 'paddingCell': rowData[col.id] != null,\r\n 'selectable_cell' : options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection\r\n }\"\r\n (click)=\"options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection && onSelectCell(rowData[col.id])\"\n pFrozenColumn\n [frozen]=\"col.frozen\">\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\n @if (rowData[col.id] != null) {\n <div class=\"p-inputgroup\">\n <button type=\"button\"\n pButton\n pRipple\n icon=\"pi pi-upload\"\n (click)=\"clickById('input_' + rowData[col.id].id)\"\n [disabled]=\"rowData.readonly || rowData[col.id]?.readonly || !isModeEdition()\">\n </button>\n <input id=\"{{'output_' + rowData[col.id].id}}\"\n pInputText\n type=\"text\"\n [ngClass]=\"{\r\n 'text-left': col.position == 'left' || col.position == null,\r\n 'text-right': col.position == 'right',\r\n 'text-center': col.position == 'center',\r\n 'font-bold': rowData.bold == true || rowData[col.id].bold == true,\r\n 'font-italic': rowData.italic == true || rowData[col.id].italic == true\r\n }\"\r\n value=\"{{ rowData[col.id].value != null ? rowData[col.id].value : '' }}\"\n readonly\n [pTooltip]=\"rowData[col.id].tooltip != null ? rowData[col.id].tooltip : rowData[col.id].value ? rowData[col.id].value : ''\"\n [tooltipDisabled]=\"!col.tooltip\">\n @if (getOption(col, rowData, 'downloadPath') && rowData[col.id].value != null) {\n <button\n type=\"button\"\n pButton\n pRipple\n icon=\"pi pi-download\"\n (click)=\"downloadFile(rowData[col.id])\"\n [disabled]=\"rowData.readonly || rowData[col.id]?.readonly || !isModeEdition()\">\n </button>\n }\n </div>\n }\n @if (rowData[col.id]) {\n <input id=\"{{'input_' + rowData[col.id].id}}\" #inputFile pInputText type=\"file\" hidden (change)=\"rowData[col.id].value = inputFile.files[0].name; onEditCell(rowData, col, inputFile.files[0])\">\n }\n </td>\n }\n @if (!col.invisible && checkType('File', col) && (rowData.readonly || rowData[col.id]?.readonly || !isModeEdition())) {\n <td\n [ngStyle]=\"{\r\n 'width' : col.width ? col.width : null,\r\n 'background-color': rowData[col.id].color ? rowData[col.id].color : null,\r\n 'color' : rowData[col.id].textColor ? rowData[col.id].textColor : null\r\n }\"\r\n (click)=\"options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection && onSelectCell(rowData[col.id])\"\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\n [pTooltip]=\"rowData[col.id].tooltip != null ? rowData[col.id].tooltip : rowData[col.id].value ? rowData[col.id].value : ''\"\n [ngClass]=\"{\r\n 'paddingCell': rowData[col.id] != null,\r\n 'text-left': col.position == 'left' || col.position == null,\r\n 'text-right': col.position == 'right',\r\n 'text-center': col.position == 'center',\r\n 'font-bold': rowData.bold == true || rowData[col.id].bold == true,\r\n 'font-italic': rowData.italic == true || rowData[col.id].italic == true,\r\n 'selectable_cell' : options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection\r\n }\"\r\n [tooltipDisabled]=\"!col.tooltip\"\n tooltipPosition=\"bottom\"\n pFrozenColumn\n [frozen]=\"col.frozen\">\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\n @if (rowData[col.id]) {\n <div>{{ rowData[col.id].value ? rowData[col.id].value : '' }}</div>\n }\n </td>\n }\n <!-- State -->\n @if (!col.invisible && checkType('State', col)) {\n <td\n [ngStyle]=\"{ 'width' : col.width ? col.width : null, 'background-color': rowData[col.id].color ? rowData[col.id].color : null }\"\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\n [ngClass]=\"{\r\n 'paddingCell': rowData[col.id] != null,\r\n 'selectable_cell' : options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection\r\n }\"\r\n (click)=\"options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection && onSelectCell(rowData[col.id])\"\n class=\"text-center\"\n pFrozenColumn\n [frozen]=\"col.frozen\">\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\n @if (rowData[col.id].value != null) {\n <p-tag\n [value]=\"rowData[col.id].value[getOption(col, rowData, 'optionLabel')]\"\n [severity]=\"rowData[col.id].value.severity\"\n [icon]=\"rowData[col.id].value.icon\"\n [style]=\"{\r\n 'background-color': rowData[col.id].value.backgroundColor,\r\n 'color': rowData[col.id].value.textColor,\r\n 'font-weight': rowData.bold == true || rowData[col.id].bold == true ? 'bold' : null,\r\n 'font-style': rowData.italic == true || rowData[col.id].italic == true ? 'italic' : null\r\n }\">\r\n </p-tag>\n }\n </td>\n }\n }\n\n <!-- Deletion -->\n @if (options.rowsDeletable) {\n <td\n class=\"cellDelete\"\n [ngClass]=\"rowData.deletable ? 'paddingCell' : null\">\n @if (rowData.deletable) {\n <button\n pButton\n type=\"button\"\n icon=\"pi pi-times\"\n class=\"p-button-danger buttonDelete p-button-text\"\n [disabled]=\"rowData.readonly\"\n (click)=\"onDeleteLine(rowData)\">\n </button>\n }\n </td>\n }\n\n </tr>\n </ng-template>\n </p-table>\n </div>\n", styles: ["::ng-deep .p-tooltip .p-tooltip-text{overflow-wrap:break-word!important}:host ::ng-deep .grid_brown .rowHeader>th{background-color:#795548}:host ::ng-deep .grid_brown .rowHeader>th div{color:#fff}:host ::ng-deep .grid_brown .rowHeader>th i{color:#fff}:host ::ng-deep .grid_brown .rowHeader .p-sortable-column:hover{background-color:#a47767}:host ::ng-deep .grid_brown .rowHeader .p-sortable-column:hover i{color:#fff}:host ::ng-deep .grid_brown .rowHeader .p-sortable-column.p-highlight div{color:#76c7ff}:host ::ng-deep .grid_brown .rowHeader .p-sortable-column.p-highlight .p-sortable-column-icon{color:#76c7ff}:host ::ng-deep .grid_brown .rowFilter th{background-color:#795548}:host ::ng-deep .grid_grey .rowHeader>th{background-color:#dedddd}:host ::ng-deep .grid_grey .rowHeader>th div{color:#495057}:host ::ng-deep .grid_grey .rowHeader>th i{color:#495057}:host ::ng-deep .grid_grey .rowHeader .p-sortable-column:hover{background-color:#e7e7e7}:host ::ng-deep .grid_grey .rowHeader .p-sortable-column:hover i{color:#495057}:host ::ng-deep .grid_grey .rowHeader .p-sortable-column.p-highlight div{color:#008bff}:host ::ng-deep .grid_grey .rowHeader .p-sortable-column.p-highlight .p-sortable-column-icon{color:#008bff}:host ::ng-deep .grid_grey .rowFilter th{background-color:#dedddd}:host ::ng-deep .selectable_cell:hover{background:#dcdcdc!important;cursor:pointer!important}:host ::ng-deep .p-frozen-column{z-index:2!important}:host ::ng-deep .p-datatable-thead{z-index:3!important}:host ::ng-deep .p-checkbox{border-radius:inherit!important}:host ::ng-deep p-inputnumber{width:100%}:host ::ng-deep .p-calendar,:host ::ng-deep .p-inputtext,:host ::ng-deep .p-inputnumber,:host ::ng-deep .p-inputnumber-input,:host ::ng-deep .p-dropdown,:host ::ng-deep .p-multiselect{width:100%}:host ::ng-deep .suffixe,:host ::ng-deep .prefixe{height:25px;padding-top:1px!important}:host ::ng-deep .p-multiselect-label-container,:host ::ng-deep .p-dropdown-label{width:1px!important}:host ::ng-deep .p-scroller-content{min-height:50%}:host ::ng-deep .rowTotal>th{background-color:#edcbaa!important}:host ::ng-deep .rowGrouping{background:#faeada!important}:host ::ng-deep .p-inputswitch.p-inputswitch-checked .p-inputswitch-slider{background:#30e130}:host ::ng-deep .p-inputswitch.p-inputswitch-checked:not(.p-disabled):hover .p-inputswitch-slider{background:#2bd12b}:host ::ng-deep .p-datatable-table{table-layout:fixed}:host ::ng-deep .p-datatable-thead>tr>th{border:1px solid rgba(0,0,0,.12)!important;padding:8px;font-weight:600;height:40px}:host ::ng-deep .headerAffichageSimple div{overflow:hidden;white-space:nowrap;text-overflow:ellipsis}:host ::ng-deep .headerAffichageEntier{word-wrap:break-word}:host ::ng-deep .p-datatable-tbody>tr>td{border:1px solid rgba(0,0,0,.12)!important;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}:host ::ng-deep .p-datatable-tbody>tr>td div{overflow:hidden;white-space:nowrap;text-overflow:ellipsis}:host ::ng-deep .p-tag{max-width:100%}:host ::ng-deep .p-tag .p-tag-value{overflow:hidden;white-space:nowrap;text-overflow:ellipsis}:host ::ng-deep .p-button{padding:5px;max-width:100%}:host ::ng-deep .p-button .p-button-label{overflow:hidden!important;white-space:nowrap!important;text-overflow:ellipsis!important}:host ::ng-deep .text_bold{font-weight:700!important}:host ::ng-deep .cellDelete{flex:0 0 50px!important;width:50px;text-align:center!important;padding:0!important}:host ::ng-deep .p-tooltip .p-tooltip-text{background-color:red!important}:host ::ng-deep .p-skeleton{background-color:#dee2e6;border-radius:6px;padding:0}:host ::ng-deep .p-datatable-tbody>tr{height:35px}:host ::ng-deep .p-inputtext{height:25px!important;padding:4px 5px!important}:host ::ng-deep .p-inputnumber{height:25px;padding:0!important}:host ::ng-deep .p-inputnumber-input{padding:0 5px!important}:host ::ng-deep .p-inputgroup .p-inputtext{height:25px;padding:4px 5px!important}:host ::ng-deep .p-dropdown,:host ::ng-deep .p-multiselect{vertical-align:middle}:host ::ng-deep .p-dropdown-label{padding-top:2px;padding-bottom:2px}:host ::ng-deep .p-multiselect-label{padding-top:2px;padding-bottom:2px}:host ::ng-deep .p-editable-column{padding:3px 10px!important}:host ::ng-deep .paddingCell{padding:3px 10px!important}:host ::ng-deep .p-selectbutton>.p-button{width:50%;height:25px}:host ::ng-deep .p-inputgroup>.p-button{height:25px}:host ::ng-deep .buttonDelete{width:100%;height:20px}:host ::ng-deep .p-column-title{display:none}:host ::ng-deep .p-datatable-loading-icon{color:#fff}\n"], dependencies: [{ kind: "directive", type: i3.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i3.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "directive", type: i1.PrimeTemplate, selector: "[pTemplate]", inputs: ["type", "pTemplate"] }, { kind: "directive", type: i4.ButtonDirective, selector: "[pButton]", inputs: ["ptButtonDirective", "pButtonPT", "pButtonUnstyled", "hostName", "text", "plain", "raised", "size", "outlined", "rounded", "iconPos", "loadingIcon", "fluid", "label", "icon", "loading", "buttonProps", "severity"] }, { kind: "component", type: i5.Table, selector: "p-table", inputs: ["frozenColumns", "frozenValue", "styleClass", "tableStyle", "tableStyleClass", "paginator", "pageLinks", "rowsPerPageOptions", "alwaysShowPaginator", "paginatorPosition", "paginatorStyleClass", "paginatorDropdownAppendTo", "paginatorDropdownScrollHeight", "currentPageReportTemplate", "showCurrentPageReport", "showJumpToPageDropdown", "showJumpToPageInput", "showFirstLastIcon", "showPageLinks", "defaultSortOrder", "sortMode", "resetPageOnSort", "selectionMode", "selectionPageOnly", "contextMenuSelection", "contextMenuSelectionMode", "dataKey", "metaKeySelection", "rowSelectable", "rowTrackBy", "lazy", "lazyLoadOnInit", "compareSelectionBy", "csvSeparator", "exportFilename", "filters", "globalFilterFields", "filterDelay", "filterLocale", "expandedRowKeys", "editingRowKeys", "rowExpandMode", "scrollable", "rowGroupMode", "scrollHeight", "virtualScroll", "virtualScrollItemSize", "virtualScrollOptions", "virtualScrollDelay", "frozenWidth", "contextMenu", "resizableColumns", "columnResizeMode", "reorderableColumns", "loading", "loadingIcon", "showLoader", "rowHover", "customSort", "showInitialSortBadge", "exportFunction", "exportHeader", "stateKey", "stateStorage", "editMode", "groupRowsBy", "size", "showGridlines", "stripedRows", "groupRowsByOrder", "responsiveLayout", "breakpoint", "paginatorLocale", "value", "columns", "first", "rows", "totalRecords", "sortField", "sortOrder", "multiSortMeta", "selection", "selectAll"], outputs: ["contextMenuSelectionChange", "selectAllChange", "selectionChange", "onRowSelect", "onRowUnselect", "onPage", "onSort", "onFilter", "onLazyLoad", "onRowExpand", "onRowCollapse", "onContextMenuSelect", "onColResize", "onColReorder", "onRowReorder", "onEditInit", "onEditComplete", "onEditCancel", "onHeaderCheckboxToggle", "sortFunction", "firstChange", "rowsChange", "onStateSave", "onStateRestore"] }, { kind: "directive", type: i5.SortableColumn, selector: "[pSortableColumn]", inputs: ["pSortableColumn", "pSortableColumnDisabled"] }, { kind: "directive", type: i5.FrozenColumn, selector: "[pFrozenColumn]", inputs: ["frozen", "alignFrozen"] }, { kind: "directive", type: i5.RowGroupHeader, selector: "[pRowGroupHeader]" }, { kind: "directive", type: i5.SelectableRow, selector: "[pSelectableRow]", inputs: ["pSelectableRow", "pSelectableRowIndex", "pSelectableRowDisabled"] }, { kind: "directive", type: i5.ContextMenuRow, selector: "[pContextMenuRow]", inputs: ["pContextMenuRow", "pContextMenuRowIndex", "pContextMenuRowDisabled"] }, { kind: "directive", type: i5.EditableColumn, selector: "[pEditableColumn]", inputs: ["pEditableColumn", "pEditableColumnField", "pEditableColumnRowIndex", "pEditableColumnDisabled", "pFocusCellSelector"] }, { kind: "component", type: i5.CellEditor, selector: "p-cellEditor" }, { kind: "component", type: i5.SortIcon, selector: "p-sortIcon", inputs: ["field"] }, { kind: "component", type: i5.TableCheckbox, selector: "p-tableCheckbox", inputs: ["value", "disabled", "required", "index", "inputId", "name", "ariaLabel"] }, { kind: "component", type: i5.TableHeaderCheckbox, selector: "p-tableHeaderCheckbox", inputs: ["disabled", "inputId", "name", "ariaLabel"] }, { kind: "directive", type: i2$1.InputText, selector: "[pInputText]", inputs: ["hostName", "ptInputText", "pInputTextPT", "pInputTextUnstyled", "pSize", "variant", "fluid", "invalid"] }, { kind: "component", type: i7.SelectButton, selector: "p-selectButton, p-selectbutton, p-select-button", inputs: ["options", "optionLabel", "optionValue", "optionDisabled", "unselectable", "tabindex", "multiple", "allowEmpty", "styleClass", "ariaLabelledBy", "dataKey", "autofocus", "size", "fluid"], outputs: ["onOptionClick", "onChange"] }, { kind: "component", type: i8.Select, selector: "p-select", inputs: ["id", "scrollHeight", "filter", "panelStyle", "styleClass", "panelStyleClass", "readonly", "editable", "tabindex", "placeholder", "loadingIcon", "filterPlaceholder", "filterLocale", "inputId", "dataKey", "filterBy", "filterFields", "autofocus", "resetFilterOnHide", "checkmark", "dropdownIcon", "loading", "optionLabel", "optionValue", "optionDisabled", "optionGroupLabel", "optionGroupChildren", "group", "showClear", "emptyFilterMessage", "emptyMessage", "lazy", "virtualScroll", "virtualScrollItemSize", "virtualScrollOptions", "overlayOptions", "ariaFilterLabel", "ariaLabel", "ariaLabelledBy", "filterMatchMode", "tooltip", "tooltipPosition", "tooltipPositionStyle", "tooltipStyleClass", "focusOnHover", "selectOnFocus", "autoOptionFocus", "autofocusFilter", "filterValue", "options", "appendTo", "motionOptions"], outputs: ["onChange", "onFilter", "onFocus", "onBlur", "onClick", "onShow", "onHide", "onClear", "onLazyLoad"] }, { kind: "component", type: i9.InputNumber, selector: "p-inputNumber, p-inputnumber, p-input-number", inputs: ["showButtons", "format", "buttonLayout", "inputId", "styleClass", "placeholder", "tabindex", "title", "ariaLabelledBy", "ariaDescribedBy", "ariaLabel", "ariaRequired", "autocomplete", "incrementButtonClass", "decrementButtonClass", "incrementButtonIcon", "decrementButtonIcon", "readonly", "allowEmpty", "locale", "localeMatcher", "mode", "currency", "currencyDisplay", "useGrouping", "minFractionDigits", "maxFractionDigits", "prefix", "suffix", "inputStyle", "inputStyleClass", "showClear", "autofocus"], outputs: ["onInput", "onFocus", "onBlur", "onKeyDown", "onClear"] }, { kind: "component", type: i10.MultiSelect, selector: "p-multiSelect, p-multiselect, p-multi-select", inputs: ["id", "ariaLabel", "styleClass", "panelStyle", "panelStyleClass", "inputId", "readonly", "group", "filter", "filterPlaceHolder", "filterLocale", "overlayVisible", "tabindex", "dataKey", "ariaLabelledBy", "displaySelectedLabel", "maxSelectedLabels", "selectionLimit", "selectedItemsLabel", "showToggleAll", "emptyFilterMessage", "emptyMessage", "resetFilterOnHide", "dropdownIcon", "chipIcon", "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", "placeholder", "options", "filterValue", "selectAll", "focusOnHover", "filterFields", "selectOnFocus", "autoOptionFocus", "highlightOnSelect", "size", "variant", "fluid", "appendTo", "motionOptions"], outputs: ["onChange", "onFilter", "onFocus", "onBlur", "onClick", "onClear", "onPanelShow", "onPanelHide", "onLazyLoad", "onRemove", "onSelectAllChange"] }, { kind: "component", type: i11.DatePicker, selector: "p-datePicker, p-datepicker, p-date-picker", inputs: ["iconDisplay", "styleClass", "inputStyle", "inputId", "inputStyleClass", "placeholder", "ariaLabelledBy", "ariaLabel", "iconAriaLabel", "dateFormat", "multipleSeparator", "rangeSeparator", "inline", "showOtherMonths", "selectOtherMonths", "showIcon", "icon", "readonlyInput", "shortYearCutoff", "hourFormat", "timeOnly", "stepHour", "stepMinute", "stepSecond", "showSeconds", "showOnFocus", "showWeek", "startWeekFromFirstDayOfYear", "showClear", "dataType", "selectionMode", "maxDateCount", "showButtonBar", "todayButtonStyleClass", "clearButtonStyleClass", "autofocus", "autoZIndex", "baseZIndex", "panelStyleClass", "panelStyle", "keepInvalid", "hideOnDateTimeSelect", "touchUI", "timeSeparator", "focusTrap", "showTransitionOptions", "hideTransitionOptions", "tabindex", "minDate", "maxDate", "disabledDates", "disabledDays", "showTime", "responsiveOptions", "numberOfMonths", "firstDayOfWeek", "view", "defaultDate", "appendTo", "motionOptions"], outputs: ["onFocus", "onBlur", "onClose", "onSelect", "onClear", "onInput", "onTodayClick", "onClearClick", "onMonthChange", "onYearChange", "onClickOutside", "onShow"] }, { kind: "component", type: i12.ContextMenu, selector: "p-contextMenu, p-contextmenu, p-context-menu", inputs: ["model", "triggerEvent", "target", "global", "style", "styleClass", "autoZIndex", "baseZIndex", "id", "breakpoint", "ariaLabel", "ariaLabelledBy", "pressDelay", "appendTo", "motionOptions"], outputs: ["onShow", "onHide"] }, { kind: "component", type: i13.Tag, selector: "p-tag", inputs: ["styleClass", "severity", "value", "icon", "rounded"] }, { kind: "directive", type: i14.Tooltip, selector: "[pTooltip]", inputs: ["tooltipPosition", "tooltipEvent", "positionStyle", "tooltipStyleClass", "tooltipZIndex", "escape", "showDelay", "hideDelay", "life", "positionTop", "positionLeft", "autoHide", "fitContent", "hideOnEscape", "pTooltip", "tooltipDisabled", "tooltipOptions", "appendTo", "ptTooltip", "pTooltipPT", "pTooltipUnstyled"] }, { kind: "component", type: i15.ToggleSwitch, selector: "p-toggleswitch, p-toggleSwitch, p-toggle-switch", inputs: ["styleClass", "tabindex", "inputId", "readonly", "trueValue", "falseValue", "ariaLabel", "size", "ariaLabelledBy", "autofocus"], outputs: ["onChange"] }, { kind: "directive", type: i16.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i16.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i16.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: CilogInputNumberComponent, selector: "cilog-input-number", inputs: ["min", "max", "maxDecimals", "prefixe", "suffixe", "inputStyleClass", "disabled", "readonly", "textColor", "bold", "italic", "floatLabel"], outputs: ["onInput", "onChange", "onFocus", "onBlur"] }, { kind: "pipe", type: i3.DatePipe, name: "date" }, { kind: "pipe", type: ValuePipe, name: "value" }] }); }
1292
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "21.0.6", ngImport: i0, type: CilogTableComponent, deps: [{ token: i1.ConfirmationService }, { token: i1.FilterService }, { token: i0.ChangeDetectorRef }, { token: ExportService }], target: i0.ɵɵFactoryTarget.Component });
1293
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "21.0.6", type: CilogTableComponent, isStandalone: true, selector: "cilog-table", inputs: { columns: "columns", values: "values", options: "options", loading: "loading" }, outputs: { columnsChange: "columnsChange", valuesChange: "valuesChange", onEdit: "onEdit", onEditInit: "onEditInit", onDelete: "onDelete", onSelect: "onSelect", onUnselect: "onUnselect", onFilter: "onFilter", onFilterInit: "onFilterInit", onSort: "onSort", onPage: "onPage", onRowDoubleClick: "onRowDoubleClick" }, viewQueries: [{ propertyName: "table", first: true, predicate: ["table"], descendants: true, static: true }, { propertyName: "cm", first: true, predicate: ["cm"], descendants: true }, { propertyName: "inputNumber", first: true, predicate: ["inputNumber"], descendants: true }], ngImport: i0, template: "<div [ngStyle]=\"{ 'height': options.scrollHeight != null ? options.scrollHeight : '100%' }\">\n\n @if (options.exportExcel) {\n <button pButton\n icon=\"pi pi-file-excel\"\n class=\"p-button-success absolute z-5 w-2rem h-2rem border-round-right border-noround-top\"\n pTooltip=\"Exporter le contenu de la grille au format Excel\"\n tooltipPosition=\"right\"\n (click)=\"exportExcel(options.exportExcelByFiltre, !options.exportExcelNoColors)\">\n </button>\n }\n\n <p-contextMenu #cm [model]=\"options.contextMenuItems\" />\n\n <p-table #table\n [columns]=\"columns\"\n [value]=\"values\"\n dataKey=\"id\"\n [selectionMode]=\"getModeSelection()\"\n [metaKeySelection]=\"isModeMetakeySelection()\"\n [(selection)]=\"selectedRows\"\n (onRowSelect)=\"onSelectRow($event)\"\n (onRowUnselect)=\"onUnselectRow($event)\"\n (onHeaderCheckboxToggle)=\"onSelectAll($event)\"\n (sortFunction)=\"sortGrille($event)\"\n [customSort]=\"options.grouping == null ? true : false\"\n [scrollable]=\"true\"\n [loading]=\"loading\"\n [scrollHeight]=\"'flex'\"\n [rowGroupMode]=\"options.grouping != null ? 'subheader' : null\"\n [groupRowsBy]=\"options.grouping != null ? options.grouping.obj + '.' + options.grouping.id : null\"\n [groupRowsByOrder]=\"0\"\n [virtualScroll]=\"options.virtualScroll == true && options.scrollHeight != null ? true : false\"\n [virtualScrollItemSize]=\"options.virtualScrollItemSize != null ? options.virtualScrollItemSize : 35\"\n [paginator]=\"options.paginator == null ? false : true\"\n [rows]=\"options.paginatorRows\"\n (onPage)=\"onPageTable($event)\"\n [tableStyleClass]=\"!options.themeGrille ? 'grid_grey' : options.themeGrille\"\n [lazy]=\"options.lazy == true ? true : false\"\n (onFilter)=\"onFilterTable($event)\"\n [rowTrackBy]=\"trackByFunction\"\n [(contextMenuSelection)]=\"contextMenuSelectedItem\"\n [contextMenu]=\"cm\">\n\n <!-- HEADER -->\n <ng-template pTemplate=\"header\" let-columns>\n\n <!-- HEADERS -->\n <tr class=\"rowHeader\">\n @if (isModeCheckboxSelection()) {\n <th class=\"cellDelete\"\n pFrozenColumn>\n @if (!options.filterable && options.toggleAll) {\n <p-tableHeaderCheckbox></p-tableHeaderCheckbox>\n }\n </th>\n }\n @for (col of columns; track col) {\n @if (!col.invisible) {\n <th [ngStyle]=\"{ 'width' : col.width ? col.width : null, 'background-color': col.backgroundColor ? col.backgroundColor : null }\"\n [ngClass]=\"{ 'text-center' : options.centerHeaders, 'headerAffichageSimple': !options.headersAffichageEntier, 'headerAffichageEntier': options.headersAffichageEntier }\"\n [pSortableColumn]=\"col.id\"\n [pSortableColumnDisabled]=\"!options.sortable || options.grouping != null || col.libelle == null || col.libelle == ''\"\n id=\"{{ col.id }}\"\n (click)=\"refreshData()\"\n pFrozenColumn\n [frozen]=\"col.frozen\"\n [pTooltip]=\"col.libelle\"\n [tooltipDisabled]=\"!col.tooltipHeader\"\n tooltipPosition=\"bottom\">\n <div [ngStyle]=\"{ 'color': col.textColor ? col.textColor : null }\">\n {{ col.libelle }}\n </div>\n @if (options.sortable && options.grouping == null && col.libelle != null && col.libelle != '') {\n <p-sortIcon [field]=\"col.id\">\n </p-sortIcon>\n }\n </th>\n }\n }\n @if (options.rowsDeletable) {\n <th class=\"cellDelete\"></th>\n }\n </tr>\n\n <!-- FILTRES -->\n @if (options.filterable) {\n <tr class=\"rowFilter\">\n @if (isModeCheckboxSelection()) {\n <th class=\"cellDelete\"\n pFrozenColumn>\n @if (options.toggleAll) {\n <p-tableHeaderCheckbox></p-tableHeaderCheckbox>\n }\n </th>\n }\n @for (col of columns; track col) {\n <!-- Text -->\n @if (!col.invisible && ((checkType('Dropdown', col) && col.options.filterText)\n || (checkType('MultiSelect', col) && col.options.filterText)\n || checkType('Text', col)\n || checkType('File', col)\n || (checkType('Button', col) && col.options.filterCol))\n || checkType('Number', col)\n || checkType('CilogNumber', col)) {\n <th [ngStyle]=\"{ 'width' : col.width ? col.width : null }\"\n pFrozenColumn\n [frozen]=\"col.frozen\">\n @if (!col.disableFilter) {\n <input pInputText\n type=\"text\"\n (input)=\"onFilterCol($event, col)\"\n name=\"filterText\"\n [(ngModel)]=\"col.options.defaultFilters\">\n }\n </th>\n }\n <!-- Date -->\n @if (!col.invisible && checkType('Date', col)) {\n <th [ngStyle]=\"{ 'width' : col.width ? col.width : null }\"\n pFrozenColumn\n [frozen]=\"col.frozen\">\n @if (!col.disableFilter) {\n <p-datepicker [view]=\"col.options.mode == null ? 'date' : col.options.mode\"\n [dateFormat]=\"col.options.mode == 'year' ? 'yy' : col.options.mode == 'month' ? 'mm/yy' : 'dd/mm/yy'\"\n [inputId]=\"col.id + '_filter'\"\n [firstDayOfWeek]=\"1\"\n [readonlyInput]=\"true\"\n appendTo=\"body\"\n selectionMode=\"range\"\n (onSelect)=\"onFilterCol($event, col)\"\n showButtonBar=\"true\"\n (onClearClick)=\"onFilterCol($event, col)\"\n name=\"filterDate\"\n [(ngModel)]=\"col.options.defaultFilters\">\n </p-datepicker>\n }\n </th>\n }\n <!-- Liste -->\n @if (!col.invisible && ((checkType('Dropdown', col) && !col.options.filterText) || (checkType('MultiSelect', col) && !col.options.filterText) || checkType('SelectButton', col) || checkType('State', col))) {\n <th [ngStyle]=\"{ 'width' : col.width ? col.width : null }\"\n pFrozenColumn\n [frozen]=\"col.frozen\">\n @if (!col.disableFilter) {\n <p-multiSelect [options]=\"col.options?.options\"\n [filter]=\"true\"\n dataKey=\"ID\"\n [optionLabel]=\"col.options?.optionLabel\"\n appendTo=\"body\"\n emptyFilterMessage=\"Aucun r\u00E9sultat\"\n emptyMessage=\"Aucun r\u00E9sultat\"\n [virtualScroll]=\"true\"\n [virtualScrollItemSize]=\"35\"\n selectedItemsLabel=\"{0} selectionn\u00E9s\"\n (onChange)=\"onFilterCol($event, col)\"\n name=\"filterChoix\"\n [(ngModel)]=\"col.options.defaultFilters\"\n [group]=\"col.options.optionGroupChildren != null ? true : false\"\n [optionGroupLabel]=\"col.options.optionGroupLabel\"\n [optionGroupChildren]=\"col.options.optionGroupChildren\"\n [showToggleAll]=\"false\"\n [showClear]=\"true\"\n (onClear)=\"onFilterCol(null, col)\">\n <ng-template let-group pTemplate=\"group\">\n <div>{{group[col.options.optionGroupLabel]}}</div>\n </ng-template>\n </p-multiSelect>\n }\n </th>\n }\n <!-- Switch -->\n @if (!col.invisible && checkType('Switch', col)) {\n <th [ngStyle]=\"{ 'width' : col.width ? col.width : null }\"\n pFrozenColumn\n [frozen]=\"col.frozen\">\n @if (!col.disableFilter) {\n <p-multiSelect [options]=\"optionsSwitch\"\n [showHeader]=\"false\"\n optionLabel=\"label\"\n optionValue=\"value\"\n appendTo=\"body\"\n emptyFilterMessage=\"Aucun r\u00E9sultat\"\n emptyMessage=\"Aucun r\u00E9sultat\"\n [virtualScrollItemSize]=\"30\"\n selectedItemsLabel=\"{0} selectionn\u00E9s\"\n (onChange)=\"onFilterCol($event, col)\"\n name=\"filterChoix2\"\n [(ngModel)]=\"col.options.defaultFilters\">\n </p-multiSelect>\n }\n </th>\n }\n <!-- Non filtrable -->\n @if (!col.invisible && (checkType('Image', col) || (checkType('Button', col) && !col.options.filterCol))) {\n <th [ngStyle]=\"{ 'width' : col.width ? col.width : null }\"\n pFrozenColumn\n [frozen]=\"col.frozen\">\n </th>\n }\n }\n @if (options.rowsDeletable) {\n <th class=\"cellDelete\"></th>\n }\n </tr>\n }\n\n <!-- TOTAL -->\n @if (options.rowTotal) {\n <tr class=\"rowTotal\">\n @if (isModeCheckboxSelection()) {\n <th class=\"cellDelete\"\n pFrozenColumn>\n </th>\n }\n @for (col of columns; track col) {\n @if (!col.invisible) {\n <th [ngStyle]=\"{ 'width' : col.width ? col.width : null }\"\n [ngClass]=\"{ 'text-center' : true }\"\n pFrozenColumn\n [frozen]=\"col.frozen\">\n <div>{{ getTotalStr(col) }}</div>\n </th>\n }\n }\n @if (options.rowsDeletable) {\n <th class=\"cellDelete\"></th>\n }\n </tr>\n }\n </ng-template>\n\n <!--Groupheader-->\n <ng-template pTemplate=\"groupheader\" let-rowData>\n <tr pRowGroupHeader class=\"rowGrouping\">\n <td [attr.colspan]=\"columns.length\">\n <div class=\"text_bold\">{{ rowData[options.grouping.obj][options.grouping.libelle] }}</div>\n </td>\n </tr>\n </ng-template>\n\n <!-- Body -->\n <ng-template pTemplate=\"body\" let-rowData let-columns=\"columns\">\n <tr id=\"{{ rowData.id }}\"\n [ngStyle]=\"{ 'background-color': rowData.color ? rowData.color : null }\"\n [pSelectableRow]=\"rowData\"\n [pSelectableRowDisabled]=\"!options.selectable || isModeCheckboxSelection() || isModeCellSelection()\"\n (dblclick)=\"onRowDoubleClickEvent(rowData)\"\n [pContextMenuRow]=\"rowData\"\n [pContextMenuRowDisabled]=\"options.contextMenuItems == null\">\n\n @if (isModeCheckboxSelection()) {\n <td class=\"cellDelete\"\n pFrozenColumn>\n <p-tableCheckbox [value]=\"rowData\" [disabled]=\"rowData.readonly\"></p-tableCheckbox>\n </td>\n }\n\n @for (col of columns; track col) {\n <!-- Text -->\n @if (!col.invisible && checkType('Text', col) && isModeEdition() && !rowData.readonly && !rowData[col.id]?.readonly) {\n <td [ngStyle]=\"{ 'width' : col.width ? col.width : null, 'background-color': rowData[col.id].color ? rowData[col.id].color : null }\"\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\n [pEditableColumn]=\"rowData\"\n [pEditableColumnField]=\"col.id\"\n [pTooltip]=\"rowData[col.id].tooltip != null ? rowData[col.id].tooltip : rowData[col.id].value\"\n [tooltipDisabled]=\"!col.tooltip\"\n tooltipPosition=\"bottom\"\n pFrozenColumn\n (click)=\"options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection && !rowData[col.id].disableSelection && onSelectCell(rowData[col.id])\"\n [frozen]=\"col.frozen\"\n [ngClass]=\"{\n 'text-left': col.position == 'left' || col.position == null,\n 'text-right': col.position == 'right',\n 'text-center': col.position == 'center',\n 'font-bold': rowData.bold == true || rowData[col.id].bold == true,\n 'font-italic': rowData.italic == true || rowData[col.id].italic == true,\n 'selectable_cell' : options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection\n }\">\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\n <p-cellEditor>\n <ng-template pTemplate=\"input\">\n <input pInputText\n type=\"text\"\n [(ngModel)]=\"rowData[col.id].value\"\n name=\"text\"\n (blur)=\"onEditCell(rowData, col, rowData[col.id].value)\"\n (keydown.enter)=\"onEditCell(rowData, col, rowData[col.id].value)\"\n (keydown.tab)=\"onEditCell(rowData, col, rowData[col.id].value)\"\n (click)=\"onEditInitCell(rowData, col, rowData[col.id].value)\"\n [ngClass]=\"{\n 'text-left': col.position == 'left' || col.position == null,\n 'text-right': col.position == 'right',\n 'text-center': col.position == 'center',\n 'font-bold': rowData.bold == true || rowData[col.id].bold == true,\n 'font-italic': rowData.italic == true || rowData[col.id].italic == true\n }\" />\n </ng-template>\n <ng-template pTemplate=\"output\">\n @if (rowData[col.id]) {\n <div style=\"white-space: pre;\">\n {{ getFormattedText(col, rowData) }}\n </div>\n }\n </ng-template>\n </p-cellEditor>\n </td>\n }\n @if (!col.invisible && checkType('Text', col) && (!isModeEdition() || rowData.readonly || rowData[col.id]?.readonly)) {\n <td [ngStyle]=\"{\n 'width' : col.width ? col.width : null,\n 'background-color' : rowData[col.id].color ? rowData[col.id].color : null,\n 'color' : rowData[col.id].textColor ? rowData[col.id].textColor : null\n }\"\n (click)=\"options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection && !rowData[col.id].disableSelection && onSelectCell(rowData[col.id])\"\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\n [pTooltip]=\"rowData[col.id].tooltip != null ? rowData[col.id].tooltip : rowData[col.id].value\"\n [tooltipDisabled]=\"!col.tooltip\"\n tooltipPosition=\"bottom\"\n [ngClass]=\"{\n 'paddingCell': rowData[col.id] != null,\n 'text-left': col.position == 'left' || col.position == null,\n 'text-right': col.position == 'right',\n 'text-center': col.position == 'center',\n 'font-bold': rowData.bold == true || rowData[col.id].bold == true,\n 'font-italic': rowData.italic == true || rowData[col.id].italic == true,\n 'selectable_cell' : options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection\n }\"\n pFrozenColumn\n [frozen]=\"col.frozen\">\n <div class=\"p-column-title\">\n {{ col.libelle }} :\n </div>\n @if (rowData[col.id]) {\n <div style=\"white-space: pre;\">\n {{ getFormattedText(col, rowData) }}\n </div>\n }\n </td>\n }\n <!-- Dropdown -->\n @if (!col.invisible && checkType('Dropdown', col) && isModeEdition() && !rowData.readonly && !rowData[col.id]?.readonly) {\n <td [ngStyle]=\"{ 'width' : col.width ? col.width : null, 'background-color': rowData[col.id].color ? rowData[col.id].color : null }\"\n [ngClass]=\"{\n 'text-left': col.position == 'left' || col.position == null,\n 'text-right': col.position == 'right',\n 'text-center': col.position == 'center',\n 'selectable_cell' : options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection\n }\"\n (click)=\"options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection && onSelectCell(rowData[col.id])\"\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\n [pTooltip]=\"rowData[col.id].tooltip != null ? rowData[col.id].tooltip : rowData[col.id].value != null ? rowData[col.id].value[getOption(col, rowData, 'optionLabel')] : ''\"\n [tooltipDisabled]=\"!col.tooltip\"\n tooltipPosition=\"bottom\"\n pFrozenColumn\n [frozen]=\"col.frozen\"\n class=\"paddingCell\">\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\n @if (rowData[col.id] != null) {\n <p-select dataKey=\"ID\"\n [options]=\"getOption(col, rowData, 'options')\"\n [filter]=\"getOption(col, rowData, 'filter')\"\n [optionLabel]=\"getOption(col, rowData, 'optionLabel')\"\n [(ngModel)]=\"rowData[col.id].value\"\n name=\"select\"\n appendTo=\"body\"\n [showClear]=\"getOption(col, rowData, 'deletable')\"\n emptyFilterMessage=\"Aucun r\u00E9sultat\"\n emptyMessage=\"Aucun r\u00E9sultat\"\n [virtualScroll]=\"getOption(col, rowData, 'virtualScroll')\"\n [readonly]=\"rowData.readonly || rowData[col.id]?.readonly\"\n [virtualScrollItemSize]=\"30\"\n (onChange)=\"onEditCell(rowData, col, rowData[col.id].value)\"\n (onClear)=\"onEditCell(rowData, col, rowData[col.id].value)\">\n <ng-template let-data pTemplate=\"selectedItem\">\n @if (data != null) {\n <span [ngClass]=\"{\n 'font-bold': rowData.bold == true || rowData[col.id].bold == true,\n 'font-italic': rowData.italic == true || rowData[col.id].italic == true\n }\">\n {{ data[getOption(col, rowData, 'optionLabel')] }}\n </span>\n }\n @if (data == null) {\n <span></span>\n }\n </ng-template>\n </p-select>\n }\n </td>\n }\n @if (!col.invisible && checkType('Dropdown', col) && (rowData.readonly || rowData[col.id]?.readonly || !isModeEdition())) {\n <td [ngStyle]=\"{\n 'width' : col.width ? col.width : null,\n 'background-color': rowData[col.id].color ? rowData[col.id].color : null,\n 'color' : rowData[col.id].textColor ? rowData[col.id].textColor : null\n }\"\n (click)=\"options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection && onSelectCell(rowData[col.id])\"\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\n [pTooltip]=\"rowData[col.id].tooltip != null ? rowData[col.id].tooltip : rowData[col.id].value != null ? rowData[col.id].value[getOption(col, rowData, 'optionLabel')] : ''\"\n [tooltipDisabled]=\"!col.tooltip\"\n tooltipPosition=\"bottom\"\n [ngClass]=\"{\n 'paddingCell': rowData[col.id] != null,\n 'text-left': col.position == 'left' || col.position == null,\n 'text-right': col.position == 'right',\n 'text-center': col.position == 'center',\n 'font-bold': rowData.bold == true || rowData[col.id].bold == true,\n 'font-italic': rowData.italic == true || rowData[col.id].italic == true,\n 'selectable_cell' : options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection\n }\"\n pFrozenColumn\n [frozen]=\"col.frozen\">\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\n @if (rowData[col.id]) {\n <div>{{ rowData[col.id].value != null ? rowData[col.id].value[getOption(col, rowData, 'optionLabel')] : '' }}</div>\n }\n </td>\n }\n <!-- Cilog Number -->\n @if (!col.invisible && checkType('CilogNumber', col) && isModeEdition() && !rowData.readonly && !rowData[col.id]?.readonly) {\n <td [ngStyle]=\"{ 'width' : col.width ? col.width : null, 'background-color': rowData[col.id].color ? rowData[col.id].color : null }\"\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\n [ngClass]=\"{\n 'paddingCell': rowData[col.id] != null,\n 'selectable_cell' : options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection\n }\"\n (click)=\"options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection && onSelectCell(rowData[col.id])\"\n [pTooltip]=\"rowData[col.id].tooltip != null ? rowData[col.id].tooltip : rowData[col.id].value | value\"\n [tooltipDisabled]=\"!col.tooltip\"\n tooltipPosition=\"bottom\"\n pFrozenColumn\n [frozen]=\"col.frozen\">\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\n @if (rowData[col.id] && !rowData.readonly && !rowData[col.id]?.readonly) {\n <cilog-input-number (onInput)=\"onInputNumber($event)\"\n [(ngModel)]=\"rowData[col.id].value\"\n name=\"cilog-number\"\n ngDefaultControl\n [inputStyleClass]=\"col.position == null || col.position == 'right' ? 'text-right' : col.position == 'left' ? 'text-left' : 'text-center'\"\n [textColor]=\"rowData[col.id].textColor\"\n [bold]=\"rowData.bold == true || rowData[col.id].bold == true\"\n [italic]=\"rowData.italic == true || rowData[col.id].italic == true\"\n [suffixe]=\"getOption(col, rowData, 'suffix')\"\n [prefixe]=\"getOption(col, rowData, 'prefix') != null ? getOption(col, rowData, 'prefix') + ' ' : null\"\n [min]=\"getOption(col, rowData, 'min')\"\n [max]=\"getOption(col, rowData, 'max')\"\n [disabled]=\"rowData.readonly || rowData[col.id]?.readonly\"\n [maxDecimals]=\"getOption(col, rowData, 'modeInteger') != null && getOption(col, rowData, 'modeInteger') == true ? 0 : getOption(col, rowData, 'maxDecimales') != null ? getOption(col, rowData, 'maxDecimales') : 2 \"\n (onChange)=\"onEditCell(rowData, col, rowData[col.id].value)\"\n (onFocus)=\"onEditInitCell(rowData, col, rowData[col.id].value)\">\n </cilog-input-number>\n }\n </td>\n }\n @if (!col.invisible && checkType('CilogNumber', col) && (rowData.readonly || rowData[col.id]?.readonly || !isModeEdition())) {\n <td [ngStyle]=\"{\n 'width' : col.width ? col.width : null,\n 'background-color': rowData[col.id].color ? rowData[col.id].color : null,\n 'color' : rowData[col.id].textColor ? rowData[col.id].textColor : null\n }\"\n (click)=\"options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection && onSelectCell(rowData[col.id])\"\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\n [pTooltip]=\"rowData[col.id].tooltip != null ? rowData[col.id].tooltip : rowData[col.id].value | value\"\n [tooltipDisabled]=\"!col.tooltip\"\n tooltipPosition=\"bottom\"\n [ngClass]=\"{\n 'paddingCell': rowData[col.id] != null,\n 'text-left': col.position == 'left' || col.position == null,\n 'text-right': col.position == 'right',\n 'text-center': col.position == 'center',\n 'font-bold': rowData.bold == true || rowData[col.id].bold == true,\n 'font-italic': rowData.italic == true || rowData[col.id].italic == true,\n 'selectable_cell' : options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection\n }\"\n pFrozenColumn\n [frozen]=\"col.frozen\">\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\n @if (rowData[col.id]) {\n <div>{{ getFormattedNumber(col, rowData, rowData[col.id].value) }}</div>\n }\n </td>\n }\n <!-- Number -->\n @if (!col.invisible && checkType('Number', col) && isModeEdition() && !rowData.readonly && !rowData[col.id]?.readonly) {\n <td [ngStyle]=\"{ 'width' : col.width ? col.width : null, 'background-color': rowData[col.id].color ? rowData[col.id].color : null }\"\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\n [pTooltip]=\"rowData[col.id].tooltip != null ? rowData[col.id].tooltip : rowData[col.id].value | value\"\n [tooltipDisabled]=\"!col.tooltip\"\n [ngClass]=\"{\n 'paddingCell': rowData[col.id] != null,\n 'text-left': col.position == 'left',\n 'text-right': col.position == 'right' || col.position == null,\n 'text-center': col.position == 'center',\n 'font-bold': rowData.bold == true || rowData[col.id].bold == true,\n 'font-italic': rowData.italic == true || rowData[col.id].italic == true,\n 'selectable_cell' : options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection\n }\"\n tooltipPosition=\"bottom\"\n pFrozenColumn\n [frozen]=\"col.frozen\"\n (click)=\"onClickCellNumber(rowData, col)\">\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\n @if (rowData[col.id] && !rowData[col.id].focus) {\n <div>\n {{ getFormattedNumber(col, rowData, rowData[col.id].value) }}\n </div>\n }\n @if (rowData[col.id] && !rowData.readonly && !rowData[col.id]?.readonly && rowData[col.id].focus == true) {\n <p-inputNumber #inputNumber\n locale=\"fr-FR\"\n (onInput)=\"onInputNumber($event)\"\n [(ngModel)]=\"rowData[col.id].value\"\n name=\"input-number\"\n [showButtons]=\"getOption(col, rowData, 'showButtons')\"\n [inputStyleClass]=\"col.position == null || col.position == 'right' ? 'text-right' : col.position == 'left' ? 'text-left' : 'text-center'\"\n [inputStyle]=\"{ 'font-weight': rowData.bold == true || rowData[col.id].bold == true ? 'bold' : null, 'font-style': rowData.italic == true || rowData[col.id].italic == true ? 'italic' : null }\"\n [suffix]=\"getOption(col, rowData, 'suffix')\"\n [prefix]=\"getOption(col, rowData, 'prefix') != null ? getOption(col, rowData, 'prefix') + ' ' : null\"\n [min]=\"getOption(col, rowData, 'min')\"\n [max]=\"getOption(col, rowData, 'max')\"\n [minFractionDigits]=\"getOption(col, rowData, 'modeInteger') != null && getOption(col, rowData, 'modeInteger') == true ? 0 : getOption(col, rowData, 'minDecimales') != null ? getOption(col, rowData, 'minDecimales') : 0\"\n [maxFractionDigits]=\"getOption(col, rowData, 'modeInteger') != null && getOption(col, rowData, 'modeInteger') == true ? 0 : getOption(col, rowData, 'maxDecimales') != null ? getOption(col, rowData, 'maxDecimales') : 2 \"\n (onBlur)=\"onEditCell(rowData, col, rowData[col.id].value)\"\n (onKeyDown)=\"onKeyDown($event, rowData, col, rowData[col.id].value)\"\n (onFocus)=\"onEditInitCell(rowData, col, rowData[col.id].value)\">\n </p-inputNumber>\n }\n </td>\n }\n @if (!col.invisible && checkType('Number', col) && (rowData.readonly || rowData[col.id]?.readonly || !isModeEdition())) {\n <td [ngStyle]=\"{\n 'width' : col.width ? col.width : null,\n 'background-color': rowData[col.id].color ? rowData[col.id].color : null,\n 'color' : rowData[col.id].textColor ? rowData[col.id].textColor : null\n }\"\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\n [pTooltip]=\"rowData[col.id].tooltip != null ? rowData[col.id].tooltip : rowData[col.id].value | value\"\n [tooltipDisabled]=\"!col.tooltip\"\n tooltipPosition=\"bottom\"\n (click)=\"options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection && onSelectCell(rowData[col.id])\"\n [ngClass]=\"{\n 'paddingCell': rowData[col.id] != null,\n 'text-left': col.position == 'left',\n 'text-right': col.position == 'right' || col.position == null,\n 'text-center': col.position == 'center',\n 'font-bold': rowData.bold == true || rowData[col.id].bold == true,\n 'font-italic': rowData.italic == true || rowData[col.id].italic == true,\n 'selectable_cell' : options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection\n }\"\n pFrozenColumn\n [frozen]=\"col.frozen\">\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\n @if (rowData[col.id]) {\n <div>{{ getFormattedNumber(col, rowData, rowData[col.id].value) }}</div>\n }\n </td>\n }\n <!-- Date -->\n @if (!col.invisible && checkType('Date', col) && isModeEdition() && !rowData.readonly && !rowData[col.id]?.readonly) {\n <td [ngStyle]=\"{ 'width' : col.width ? col.width : null, 'background-color': rowData[col.id].color ? rowData[col.id].color : null }\"\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\n [ngClass]=\"{\n 'paddingCell': rowData[col.id] != null,\n 'selectable_cell' : options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection\n }\"\n (click)=\"options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection && onSelectCell(rowData[col.id])\"\n [pTooltip]=\"rowData[col.id].tooltip != null ? rowData[col.id].tooltip : getOption(col, rowData, 'mode') == 'year' ? (rowData[col.id].value | date: 'yyyy') : getOption(col, rowData, 'mode') == 'month' ? (rowData[col.id].value | date: 'MM/yy') : getOption(col, rowData, 'mode') == 'hour' ? (rowData[col.id].value | date: 'HH:mm') : getOption(col, rowData, 'mode') == 'datehour' ? (rowData[col.id].value | date: 'dd/MM/yy HH:mm') : (rowData[col.id].value | date: 'dd/MM/yyyy')\"\n [tooltipDisabled]=\"!col.tooltip\"\n tooltipPosition=\"bottom\"\n pFrozenColumn\n [frozen]=\"col.frozen\">\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\n <p-datepicker [(ngModel)]=\"rowData[col.id].value\"\n name=\"date-picker\"\n [view]=\"getOption(col, rowData, 'mode') == null || getOption(col, rowData, 'mode') == 'date' || getOption(col, rowData, 'mode') == 'hour' ? 'date' : getOption(col, rowData, 'mode') == 'datehour' ? 'date' : getOption(col, rowData, 'mode')\"\n [dateFormat]=\"getOption(col, rowData, 'mode') == 'year' ? 'yy' : getOption(col, rowData, 'mode') == 'month' ? 'mm/yy' : getOption(col, rowData, 'mode') == 'hour' || getOption(col, rowData, 'mode') == 'datehour' ? 'dd/mm/yy' : 'dd/mm/yy'\"\n [showTime]=\"getOption(col, rowData, 'mode') == 'datehour'\"\n [timeOnly]=\"getOption(col, rowData, 'mode') == 'hour'\"\n [hourFormat]=\"'24'\"\n [firstDayOfWeek]=\"1\"\n (onSelect)=\"onEditCell(rowData, col, rowData[col.id].value)\"\n (onBlur)=\"onEditCell(rowData, col, rowData[col.id].value)\"\n (onClear)=\"onEditCell(rowData, col, rowData[col.id].value)\"\n [inputStyleClass]=\"col.position == null || col.position == 'right' ? 'text-right' : col.position == 'left' ? 'text-left' : 'text-center'\"\n [inputStyle]=\"{ 'font-weight': rowData.bold == true || rowData[col.id].bold == true ? 'bold' : null, 'font-style': rowData.italic == true || rowData[col.id].italic == true ? 'italic' : null }\"\n [showClear]=\"getOption(col, rowData, 'clear')\"\n [minDate]=\"getOption(col, rowData, 'minDate')\"\n [maxDate]=\"getOption(col, rowData, 'maxDate')\"\n [defaultDate]=\"getOption(col, rowData, 'defaultDate')\"\n appendTo=\"body\">\n </p-datepicker>\n </td>\n }\n @if (!col.invisible && checkType('Date', col) && (rowData.readonly || rowData[col.id]?.readonly || !isModeEdition())) {\n <td [ngStyle]=\"{\n 'min-width' : col.width ? col.width : null,\n 'background-color': rowData[col.id].color ? rowData[col.id].color : null,\n 'color' : rowData[col.id].textColor ? rowData[col.id].textColor : null\n }\"\n (click)=\"options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection && onSelectCell(rowData[col.id])\"\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\n [pTooltip]=\"rowData[col.id].tooltip != null ? rowData[col.id].tooltip : rowData[col.id].value | date: 'dd/MM/yyyy'\"\n [tooltipDisabled]=\"!col.tooltip\"\n tooltipPosition=\"bottom\"\n [ngClass]=\"{\n 'paddingCell': rowData[col.id] != null,\n 'text-left': col.position == 'left' || col.position == null,\n 'text-right': col.position == 'right',\n 'text-center': col.position == 'center',\n 'font-bold': rowData.bold == true || rowData[col.id].bold == true,\n 'font-italic': rowData.italic == true || rowData[col.id].italic == true,\n 'selectable_cell' : options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection\n }\"\n pFrozenColumn\n [frozen]=\"col.frozen\">\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\n @if (rowData[col.id]) {\n <div>{{ rowData[col.id].value | date: (getOption(col, rowData, 'mode') == 'year' ? 'yyyy' : getOption(col, rowData, 'mode') == 'month' ? 'MM/yyyy' : 'dd/MM/yyyy') }}</div>\n }\n </td>\n }\n <!-- MultiSelect -->\n @if (!col.invisible && checkType('MultiSelect', col) && isModeEdition() && !rowData.readonly && !rowData[col.id]?.readonly) {\n <td [ngStyle]=\"{ 'width' : col.width ? col.width : null, 'background-color': rowData[col.id].color ? rowData[col.id].color : null }\"\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\n [ngClass]=\"{\n 'text-left': col.position == 'left' || col.position == null,\n 'text-right': col.position == 'right',\n 'text-center': col.position == 'center',\n 'selectable_cell' : options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection\n }\"\n (click)=\"options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection && onSelectCell(rowData[col.id])\"\n [pTooltip]=\"rowData[col.id].tooltip != null ? rowData[col.id].tooltip : getMultiSelectConcat(rowData[col.id].value, getOption(col, rowData, 'optionLabel'))\"\n [tooltipDisabled]=\"!col.tooltip\"\n tooltipPosition=\"bottom\"\n pFrozenColumn\n [frozen]=\"col.frozen\"\n class=\"paddingCell\">\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\n @if (rowData[col.id] != null) {\n <p-multiSelect [options]=\"getOption(col, rowData, 'options')\"\n [filter]=\"getOption(col, rowData, 'filter')\"\n [optionLabel]=\"getOption(col, rowData, 'optionLabel')\"\n [(ngModel)]=\"rowData[col.id].value\"\n name=\"multiselect\"\n appendTo=\"body\"\n dataKey=\"ID\"\n emptyFilterMessage=\"Aucun r\u00E9sultat\"\n emptyMessage=\"Aucun r\u00E9sultat\"\n [virtualScroll]=\"getOption(col, rowData, 'virtualScroll')\"\n [readonly]=\"rowData.readonly || rowData[col.id]?.readonly || !isModeEdition()\"\n [virtualScrollItemSize]=\"30\"\n selectedItemsLabel=\"{0} selectionn\u00E9s\"\n (onChange)=\"editMultiselect(rowData, col, $event)\"\n [showToggleAll]=\"false\"\n [showHeader]=\"getOption(col, rowData, 'filter')\"\n [group]=\"getOption(col, rowData, 'optionGroupChildren') != null ? true : false\"\n [optionGroupLabel]=\"getOption(col, rowData, 'optionGroupLabel')\"\n [optionGroupChildren]=\"getOption(col, rowData, 'optionGroupChildren')\"\n ngDefaultControl>\n <ng-template let-data pTemplate=\"selectedItems\">\n @for (option of data; track option; let i = $index) {\n <span [ngClass]=\"{\n 'font-bold': rowData.bold == true || rowData[col.id].bold == true,\n 'font-italic': rowData.italic == true || rowData[col.id].italic == true\n }\">\n {{ option[getOption(col, rowData, 'optionLabel')] + (i != data.length - 1 ? ',' : '') }}\n </span>\n }\n </ng-template>\n <ng-template let-group pTemplate=\"group\">\n <div>{{group[col.options.optionGroupLabel]}}</div>\n </ng-template>\n </p-multiSelect>\n }\n </td>\n }\n @if (!col.invisible && checkType('MultiSelect', col) && (rowData.readonly || rowData[col.id]?.readonly || !isModeEdition())) {\n <td [ngStyle]=\"{\n 'width' : col.width ? col.width : null,\n 'background-color': rowData[col.id].color ? rowData[col.id].color : null,\n 'color' : rowData[col.id].textColor ? rowData[col.id].textColor : null\n }\"\n (click)=\"options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection && onSelectCell(rowData[col.id])\"\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\n [pTooltip]=\"rowData[col.id].tooltip != null ? rowData[col.id].tooltip : getMultiSelectConcat(rowData[col.id].value, getOption(col, rowData, 'optionLabel'))\"\n [tooltipDisabled]=\"!col.tooltip\"\n tooltipPosition=\"bottom\"\n [ngClass]=\"{\n 'paddingCell': rowData[col.id] != null,\n 'text-left': col.position == 'left' || col.position == null,\n 'text-right': col.position == 'right',\n 'text-center': col.position == 'center',\n 'font-bold': rowData.bold == true || rowData[col.id].bold == true,\n 'font-italic': rowData.italic == true || rowData[col.id].italic == true,\n 'selectable_cell' : options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection\n }\"\n pFrozenColumn\n [frozen]=\"col.frozen\">\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\n @if (rowData[col.id]) {\n <div>{{ getMultiSelectConcat(rowData[col.id].value, getOption(col, rowData, 'optionLabel')) }}</div>\n }\n </td>\n }\n <!-- Image -->\n @if (!col.invisible && checkType('Image', col)) {\n <td [ngStyle]=\"{ 'width' : col.width ? col.width : null, 'background-color': rowData[col.id].color ? rowData[col.id].color : null }\"\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\n [ngClass]=\"{\n 'paddingCell': rowData[col.id] != null,\n 'selectable_cell' : options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection\n }\"\n (click)=\"options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection && onSelectCell(rowData[col.id])\"\n class=\"text-center\"\n pFrozenColumn\n [frozen]=\"col.frozen\">\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\n @if (rowData[col.id]) {\n <img style=\"vertical-align: middle; width: 40px;\" src=\"{{ rowData[col.id].value }}\" />\n }\n </td>\n }\n <!-- Button -->\n @if (!col.invisible && checkType('Button', col)) {\n <td class=\"paddingCell text-center\"\n [ngClass]=\"{\n 'selectable_cell' : options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection\n }\"\n (click)=\"options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection && onSelectCell(rowData[col.id])\"\n [ngStyle]=\"{ 'width' : col.width ? col.width : null, 'background-color': rowData[col.id].color ? rowData[col.id].color : null }\">\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\n @if (rowData[col.id].value != null && isValueButtonByType(rowData[col.id].value, 'function')) {\n <button pButton\n [disabled]=\"rowData.readonly || rowData[col.id]?.readonly\"\n [label]=\"getOption(col, rowData, 'label')\"\n [icon]=\"getOption(col, rowData, 'icon')\"\n (click)=\"rowData[col.id].value()\"\n [pTooltip]=\"rowData[col.id].tooltip != null ? rowData[col.id].tooltip : getOption(col, rowData, 'label')\"\n [tooltipDisabled]=\"!col.tooltip\"\n [class]=\"'p-button-' + getOption(col, rowData, 'severity')\"\n [ngClass]=\"{\n 'font-bold': rowData.bold == true || rowData[col.id].bold == true,\n 'font-italic': rowData.italic == true || rowData[col.id].italic == true\n }\">\n </button>\n }\n @if (isValueButtonByType(rowData[col.id].value, 'string')) {\n <div [ngClass]=\"{\n 'paddingCell': rowData[col.id] != null,\n 'text-left': col.position == 'left' || col.position == null,\n 'text-right': col.position == 'right',\n 'text-center': col.position == 'center',\n 'font-bold': rowData.bold == true || rowData[col.id].bold == true,\n 'font-italic': rowData.italic == true || rowData[col.id].italic == true\n }\"\n [pTooltip]=\"rowData[col.id].tooltip != null ? rowData[col.id].tooltip : rowData[col.id].value\"\n [tooltipDisabled]=\"!col.tooltip\">\n {{ rowData[col.id].value }}\n </div>\n }\n </td>\n }\n <!-- SelectButton -->\n @if (!col.invisible && checkType('SelectButton', col) && isModeEdition() && !rowData.readonly && !rowData[col.id]?.readonly) {\n <td [ngStyle]=\"{ 'width' : col.width ? col.width : null, 'background-color': rowData[col.id].color ? rowData[col.id].color : null }\"\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\n [ngClass]=\"{\n 'paddingCell': rowData[col.id] != null,\n 'selectable_cell' : options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection\n }\"\n (click)=\"options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection && onSelectCell(rowData[col.id])\"\n pFrozenColumn\n [frozen]=\"col.frozen\">\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\n @if (rowData[col.id] != null) {\n <p-selectButton [options]=\"getOption(col, rowData, 'options')\"\n [optionLabel]=\"getOption(col, rowData, 'optionLabel')\"\n [optionValue]=\"getOption(col, rowData, 'optionValue') != null ? getOption(col, rowData, 'optionValue') : 'value'\"\n [(ngModel)]=\"rowData[col.id].value\"\n name=\"select-button\"\n [disabled]=\"rowData.readonly || rowData[col.id]?.readonly || !isModeEdition()\"\n (onChange)=\"onEditCell(rowData, col, rowData[col.id].value)\">\n <ng-template let-item pTemplate=\"item\">\n <span class=\"text-center w-full\"\n [ngClass]=\"{\n 'font-bold': rowData.bold == true || rowData[col.id].bold == true,\n 'font-italic': rowData.italic == true || rowData[col.id].italic == true\n }\">\n {{ item.label }}\n </span>\n </ng-template>\n </p-selectButton>\n }\n </td>\n }\n @if (!col.invisible && checkType('SelectButton', col) && (rowData.readonly || rowData[col.id]?.readonly || !isModeEdition())) {\n <td [ngStyle]=\"{\n 'width' : col.width ? col.width : null,\n 'background-color': rowData[col.id].color ? rowData[col.id].color : null,\n 'color' : rowData[col.id].textColor ? rowData[col.id].textColor : null\n }\"\n (click)=\"options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection && onSelectCell(rowData[col.id])\"\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\n pFrozenColumn\n [frozen]=\"col.frozen\"\n class=\"text-center\"\n [ngClass]=\"{\n 'paddingCell': rowData[col.id] != null,\n 'font-bold': rowData.bold == true || rowData[col.id].bold == true,\n 'font-italic': rowData.italic == true || rowData[col.id].italic == true,\n 'selectable_cell' : options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection\n }\">\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\n @if (rowData[col.id]) {\n <div>{{ getSelectLibelleByValue(rowData, col) }}</div>\n }\n </td>\n }\n <!-- Switch -->\n @if (!col.invisible && checkType('Switch', col)) {\n <td [ngStyle]=\"{ 'width' : col.width ? col.width : null, 'background-color': rowData[col.id].color ? rowData[col.id].color : null }\"\n class=\"text-center\"\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\n [ngClass]=\"{\n 'paddingCell': rowData[col.id] != null,\n 'selectable_cell' : options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection\n }\"\n (click)=\"options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection && onSelectCell(rowData[col.id])\"\n pFrozenColumn\n [frozen]=\"col.frozen\">\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\n @if (rowData[col.id] != null) {\n <p-toggleswitch [(ngModel)]=\"rowData[col.id].value\"\n name=\"toggle-switch\"\n [disabled]=\"rowData.readonly || rowData[col.id]?.readonly || (getOption(col, rowData, 'action') == null && !isModeEdition())\"\n (onChange)=\"onEditCell(rowData, col, rowData[col.id].value)\"\n ngDefaultControl>\n </p-toggleswitch>\n }\n </td>\n }\n <!-- File -->\n @if (!col.invisible && checkType('File', col) && isModeEdition() && !rowData.readonly && !rowData[col.id]?.readonly) {\n <td [ngStyle]=\"{ 'width' : col.width ? col.width : null, 'background-color': rowData[col.id].color ? rowData[col.id].color : null }\"\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\n [ngClass]=\"{\n 'paddingCell': rowData[col.id] != null,\n 'selectable_cell' : options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection\n }\"\n (click)=\"options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection && onSelectCell(rowData[col.id])\"\n pFrozenColumn\n [frozen]=\"col.frozen\">\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\n @if (rowData[col.id] != null) {\n <div class=\"p-inputgroup\">\n <button type=\"button\"\n pButton\n pRipple\n icon=\"pi pi-upload\"\n (click)=\"clickById('input_' + rowData[col.id].id)\"\n [disabled]=\"rowData.readonly || rowData[col.id]?.readonly || !isModeEdition()\">\n </button>\n <input id=\"{{'output_' + rowData[col.id].id}}\"\n pInputText\n type=\"text\"\n [ngClass]=\"{\n 'text-left': col.position == 'left' || col.position == null,\n 'text-right': col.position == 'right',\n 'text-center': col.position == 'center',\n 'font-bold': rowData.bold == true || rowData[col.id].bold == true,\n 'font-italic': rowData.italic == true || rowData[col.id].italic == true\n }\"\n value=\"{{ rowData[col.id].value != null ? rowData[col.id].value : '' }}\"\n readonly\n [pTooltip]=\"rowData[col.id].tooltip != null ? rowData[col.id].tooltip : rowData[col.id].value ? rowData[col.id].value : ''\"\n [tooltipDisabled]=\"!col.tooltip\">\n @if (getOption(col, rowData, 'downloadPath') && rowData[col.id].value != null) {\n <button type=\"button\"\n pButton\n pRipple\n icon=\"pi pi-download\"\n (click)=\"downloadFile(rowData[col.id])\"\n [disabled]=\"rowData.readonly || rowData[col.id]?.readonly || !isModeEdition()\">\n </button>\n }\n </div>\n }\n @if (rowData[col.id]) {\n <input id=\"{{'input_' + rowData[col.id].id}}\" #inputFile pInputText type=\"file\" hidden (change)=\"rowData[col.id].value = inputFile.files[0].name; onEditCell(rowData, col, inputFile.files[0])\">\n }\n </td>\n }\n @if (!col.invisible && checkType('File', col) && (rowData.readonly || rowData[col.id]?.readonly || !isModeEdition())) {\n <td [ngStyle]=\"{\n 'width' : col.width ? col.width : null,\n 'background-color': rowData[col.id].color ? rowData[col.id].color : null,\n 'color' : rowData[col.id].textColor ? rowData[col.id].textColor : null\n }\"\n (click)=\"options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection && onSelectCell(rowData[col.id])\"\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\n [pTooltip]=\"rowData[col.id].tooltip != null ? rowData[col.id].tooltip : rowData[col.id].value ? rowData[col.id].value : ''\"\n [ngClass]=\"{\n 'paddingCell': rowData[col.id] != null,\n 'text-left': col.position == 'left' || col.position == null,\n 'text-right': col.position == 'right',\n 'text-center': col.position == 'center',\n 'font-bold': rowData.bold == true || rowData[col.id].bold == true,\n 'font-italic': rowData.italic == true || rowData[col.id].italic == true,\n 'selectable_cell' : options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection\n }\"\n [tooltipDisabled]=\"!col.tooltip\"\n tooltipPosition=\"bottom\"\n pFrozenColumn\n [frozen]=\"col.frozen\">\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\n @if (rowData[col.id]) {\n <div>{{ rowData[col.id].value ? rowData[col.id].value : '' }}</div>\n }\n </td>\n }\n <!-- State -->\n @if (!col.invisible && checkType('State', col)) {\n <td [ngStyle]=\"{ 'width' : col.width ? col.width : null, 'background-color': rowData[col.id].color ? rowData[col.id].color : null }\"\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\n [ngClass]=\"{\n 'paddingCell': rowData[col.id] != null,\n 'selectable_cell' : options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection\n }\"\n (click)=\"options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection && onSelectCell(rowData[col.id])\"\n class=\"text-center\"\n pFrozenColumn\n [frozen]=\"col.frozen\">\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\n @if (rowData[col.id].value != null) {\n <p-tag [value]=\"rowData[col.id].value[getOption(col, rowData, 'optionLabel')]\"\n [severity]=\"rowData[col.id].value.severity\"\n [icon]=\"rowData[col.id].value.icon\"\n [style]=\"{\n 'background-color': rowData[col.id].value.backgroundColor,\n 'color': rowData[col.id].value.textColor,\n 'font-weight': rowData.bold == true || rowData[col.id].bold == true ? 'bold' : null,\n 'font-style': rowData.italic == true || rowData[col.id].italic == true ? 'italic' : null\n }\">\n </p-tag>\n }\n </td>\n }\n }\n\n <!-- Deletion -->\n @if (options.rowsDeletable) {\n <td class=\"cellDelete\"\n [ngClass]=\"rowData.deletable ? 'paddingCell' : null\">\n @if (rowData.deletable) {\n <button pButton\n type=\"button\"\n icon=\"pi pi-times\"\n class=\"p-button-danger buttonDelete p-button-text\"\n [disabled]=\"rowData.readonly\"\n (click)=\"onDeleteLine(rowData)\">\n </button>\n }\n </td>\n }\n\n </tr>\n </ng-template>\n </p-table>\n</div>\n", styles: ["::ng-deep .p-tooltip .p-tooltip-text{overflow-wrap:break-word!important}:host ::ng-deep .grid_brown .rowHeader>th{background-color:#795548}:host ::ng-deep .grid_brown .rowHeader>th div{color:#fff}:host ::ng-deep .grid_brown .rowHeader>th i{color:#fff}:host ::ng-deep .grid_brown .rowHeader .p-sortable-column:hover{background-color:#a47767}:host ::ng-deep .grid_brown .rowHeader .p-sortable-column:hover i{color:#fff}:host ::ng-deep .grid_brown .rowHeader .p-sortable-column.p-highlight div{color:#76c7ff}:host ::ng-deep .grid_brown .rowHeader .p-sortable-column.p-highlight .p-sortable-column-icon{color:#76c7ff}:host ::ng-deep .grid_brown .rowFilter th{background-color:#795548}:host ::ng-deep .grid_grey .rowHeader>th{background-color:#dedddd}:host ::ng-deep .grid_grey .rowHeader>th div{color:#495057}:host ::ng-deep .grid_grey .rowHeader>th i{color:#495057}:host ::ng-deep .grid_grey .rowHeader .p-sortable-column:hover{background-color:#e7e7e7}:host ::ng-deep .grid_grey .rowHeader .p-sortable-column:hover i{color:#495057}:host ::ng-deep .grid_grey .rowHeader .p-sortable-column.p-highlight div{color:#008bff}:host ::ng-deep .grid_grey .rowHeader .p-sortable-column.p-highlight .p-sortable-column-icon{color:#008bff}:host ::ng-deep .grid_grey .rowFilter th{background-color:#dedddd}:host ::ng-deep .selectable_cell:hover{background:#dcdcdc!important;cursor:pointer!important}:host ::ng-deep .p-frozen-column{z-index:2!important}:host ::ng-deep .p-datatable-thead{z-index:3!important}:host ::ng-deep .p-checkbox{border-radius:inherit!important}:host ::ng-deep p-inputnumber{width:100%}:host ::ng-deep .p-calendar,:host ::ng-deep .p-inputtext,:host ::ng-deep .p-inputnumber,:host ::ng-deep .p-inputnumber-input,:host ::ng-deep .p-dropdown,:host ::ng-deep .p-multiselect{width:100%}:host ::ng-deep .suffixe,:host ::ng-deep .prefixe{height:25px;padding-top:1px!important}:host ::ng-deep .p-multiselect-label-container,:host ::ng-deep .p-dropdown-label{width:1px!important}:host ::ng-deep .p-scroller-content{min-height:50%}:host ::ng-deep .rowTotal>th{background-color:#edcbaa!important}:host ::ng-deep .rowGrouping{background:#faeada!important}:host ::ng-deep .p-inputswitch.p-inputswitch-checked .p-inputswitch-slider{background:#30e130}:host ::ng-deep .p-inputswitch.p-inputswitch-checked:not(.p-disabled):hover .p-inputswitch-slider{background:#2bd12b}:host ::ng-deep .p-datatable-table{table-layout:fixed}:host ::ng-deep .p-datatable-thead>tr>th{border:1px solid rgba(0,0,0,.12)!important;padding:8px;font-weight:600;height:40px}:host ::ng-deep .headerAffichageSimple div{overflow:hidden;white-space:nowrap;text-overflow:ellipsis}:host ::ng-deep .headerAffichageEntier{word-wrap:break-word}:host ::ng-deep .p-datatable-tbody>tr>td{border:1px solid rgba(0,0,0,.12)!important;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}:host ::ng-deep .p-datatable-tbody>tr>td div{overflow:hidden;white-space:nowrap;text-overflow:ellipsis}:host ::ng-deep .p-tag{max-width:100%}:host ::ng-deep .p-tag .p-tag-value{overflow:hidden;white-space:nowrap;text-overflow:ellipsis}:host ::ng-deep .p-button{padding:5px;max-width:100%}:host ::ng-deep .p-button .p-button-label{overflow:hidden!important;white-space:nowrap!important;text-overflow:ellipsis!important}:host ::ng-deep .text_bold{font-weight:700!important}:host ::ng-deep .cellDelete{flex:0 0 50px!important;width:50px;text-align:center!important;padding:0!important}:host ::ng-deep .p-tooltip .p-tooltip-text{background-color:red!important}:host ::ng-deep .p-skeleton{background-color:#dee2e6;border-radius:6px;padding:0}:host ::ng-deep .p-datatable-tbody>tr{height:35px}:host ::ng-deep .p-inputtext{height:25px!important;padding:4px 5px!important}:host ::ng-deep .p-inputnumber{height:25px;padding:0!important}:host ::ng-deep .p-inputnumber-input{padding:0 5px!important}:host ::ng-deep .p-inputgroup .p-inputtext{height:25px;padding:4px 5px!important}:host ::ng-deep .p-dropdown,:host ::ng-deep .p-multiselect{vertical-align:middle}:host ::ng-deep .p-dropdown-label{padding-top:2px;padding-bottom:2px}:host ::ng-deep .p-multiselect-label{padding-top:2px;padding-bottom:2px}:host ::ng-deep .p-editable-column{padding:3px 10px!important}:host ::ng-deep .paddingCell{padding:3px 10px!important}:host ::ng-deep .p-selectbutton>.p-button{width:50%;height:25px}:host ::ng-deep .p-inputgroup>.p-button{height:25px}:host ::ng-deep .buttonDelete{width:100%;height:20px}:host ::ng-deep .p-column-title{display:none}:host ::ng-deep .p-datatable-loading-icon{color:#fff}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i3.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i3.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i4.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i4.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i4.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "ngmodule", type: TagModule }, { kind: "component", type: i5.Tag, selector: "p-tag", inputs: ["styleClass", "severity", "value", "icon", "rounded"] }, { kind: "directive", type: i1.PrimeTemplate, selector: "[pTemplate]", inputs: ["type", "pTemplate"] }, { kind: "ngmodule", type: TableModule }, { kind: "component", type: i6.Table, selector: "p-table", inputs: ["frozenColumns", "frozenValue", "styleClass", "tableStyle", "tableStyleClass", "paginator", "pageLinks", "rowsPerPageOptions", "alwaysShowPaginator", "paginatorPosition", "paginatorStyleClass", "paginatorDropdownAppendTo", "paginatorDropdownScrollHeight", "currentPageReportTemplate", "showCurrentPageReport", "showJumpToPageDropdown", "showJumpToPageInput", "showFirstLastIcon", "showPageLinks", "defaultSortOrder", "sortMode", "resetPageOnSort", "selectionMode", "selectionPageOnly", "contextMenuSelection", "contextMenuSelectionMode", "dataKey", "metaKeySelection", "rowSelectable", "rowTrackBy", "lazy", "lazyLoadOnInit", "compareSelectionBy", "csvSeparator", "exportFilename", "filters", "globalFilterFields", "filterDelay", "filterLocale", "expandedRowKeys", "editingRowKeys", "rowExpandMode", "scrollable", "rowGroupMode", "scrollHeight", "virtualScroll", "virtualScrollItemSize", "virtualScrollOptions", "virtualScrollDelay", "frozenWidth", "contextMenu", "resizableColumns", "columnResizeMode", "reorderableColumns", "loading", "loadingIcon", "showLoader", "rowHover", "customSort", "showInitialSortBadge", "exportFunction", "exportHeader", "stateKey", "stateStorage", "editMode", "groupRowsBy", "size", "showGridlines", "stripedRows", "groupRowsByOrder", "responsiveLayout", "breakpoint", "paginatorLocale", "value", "columns", "first", "rows", "totalRecords", "sortField", "sortOrder", "multiSortMeta", "selection", "selectAll"], outputs: ["contextMenuSelectionChange", "selectAllChange", "selectionChange", "onRowSelect", "onRowUnselect", "onPage", "onSort", "onFilter", "onLazyLoad", "onRowExpand", "onRowCollapse", "onContextMenuSelect", "onColResize", "onColReorder", "onRowReorder", "onEditInit", "onEditComplete", "onEditCancel", "onHeaderCheckboxToggle", "sortFunction", "firstChange", "rowsChange", "onStateSave", "onStateRestore"] }, { kind: "directive", type: i6.SortableColumn, selector: "[pSortableColumn]", inputs: ["pSortableColumn", "pSortableColumnDisabled"] }, { kind: "directive", type: i6.FrozenColumn, selector: "[pFrozenColumn]", inputs: ["frozen", "alignFrozen"] }, { kind: "directive", type: i6.RowGroupHeader, selector: "[pRowGroupHeader]" }, { kind: "directive", type: i6.SelectableRow, selector: "[pSelectableRow]", inputs: ["pSelectableRow", "pSelectableRowIndex", "pSelectableRowDisabled"] }, { kind: "directive", type: i6.ContextMenuRow, selector: "[pContextMenuRow]", inputs: ["pContextMenuRow", "pContextMenuRowIndex", "pContextMenuRowDisabled"] }, { kind: "directive", type: i6.EditableColumn, selector: "[pEditableColumn]", inputs: ["pEditableColumn", "pEditableColumnField", "pEditableColumnRowIndex", "pEditableColumnDisabled", "pFocusCellSelector"] }, { kind: "component", type: i6.CellEditor, selector: "p-cellEditor" }, { kind: "component", type: i6.SortIcon, selector: "p-sortIcon", inputs: ["field"] }, { kind: "component", type: i6.TableCheckbox, selector: "p-tableCheckbox", inputs: ["value", "disabled", "required", "index", "inputId", "name", "ariaLabel"] }, { kind: "component", type: i6.TableHeaderCheckbox, selector: "p-tableHeaderCheckbox", inputs: ["disabled", "inputId", "name", "ariaLabel"] }, { kind: "ngmodule", type: ContextMenuModule }, { kind: "component", type: i7.ContextMenu, selector: "p-contextMenu, p-contextmenu, p-context-menu", inputs: ["model", "triggerEvent", "target", "global", "style", "styleClass", "autoZIndex", "baseZIndex", "id", "breakpoint", "ariaLabel", "ariaLabelledBy", "pressDelay", "appendTo", "motionOptions"], outputs: ["onShow", "onHide"] }, { kind: "ngmodule", type: TooltipModule }, { kind: "directive", type: i8.Tooltip, selector: "[pTooltip]", inputs: ["tooltipPosition", "tooltipEvent", "positionStyle", "tooltipStyleClass", "tooltipZIndex", "escape", "showDelay", "hideDelay", "life", "positionTop", "positionLeft", "autoHide", "fitContent", "hideOnEscape", "pTooltip", "tooltipDisabled", "tooltipOptions", "appendTo", "ptTooltip", "pTooltipPT", "pTooltipUnstyled"] }, { kind: "ngmodule", type: MultiSelectModule }, { kind: "component", type: i9.MultiSelect, selector: "p-multiSelect, p-multiselect, p-multi-select", inputs: ["id", "ariaLabel", "styleClass", "panelStyle", "panelStyleClass", "inputId", "readonly", "group", "filter", "filterPlaceHolder", "filterLocale", "overlayVisible", "tabindex", "dataKey", "ariaLabelledBy", "displaySelectedLabel", "maxSelectedLabels", "selectionLimit", "selectedItemsLabel", "showToggleAll", "emptyFilterMessage", "emptyMessage", "resetFilterOnHide", "dropdownIcon", "chipIcon", "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", "placeholder", "options", "filterValue", "selectAll", "focusOnHover", "filterFields", "selectOnFocus", "autoOptionFocus", "highlightOnSelect", "size", "variant", "fluid", "appendTo", "motionOptions"], outputs: ["onChange", "onFilter", "onFocus", "onBlur", "onClick", "onClear", "onPanelShow", "onPanelHide", "onLazyLoad", "onRemove", "onSelectAllChange"] }, { kind: "ngmodule", type: DatePickerModule }, { kind: "component", type: i10.DatePicker, selector: "p-datePicker, p-datepicker, p-date-picker", inputs: ["iconDisplay", "styleClass", "inputStyle", "inputId", "inputStyleClass", "placeholder", "ariaLabelledBy", "ariaLabel", "iconAriaLabel", "dateFormat", "multipleSeparator", "rangeSeparator", "inline", "showOtherMonths", "selectOtherMonths", "showIcon", "icon", "readonlyInput", "shortYearCutoff", "hourFormat", "timeOnly", "stepHour", "stepMinute", "stepSecond", "showSeconds", "showOnFocus", "showWeek", "startWeekFromFirstDayOfYear", "showClear", "dataType", "selectionMode", "maxDateCount", "showButtonBar", "todayButtonStyleClass", "clearButtonStyleClass", "autofocus", "autoZIndex", "baseZIndex", "panelStyleClass", "panelStyle", "keepInvalid", "hideOnDateTimeSelect", "touchUI", "timeSeparator", "focusTrap", "showTransitionOptions", "hideTransitionOptions", "tabindex", "minDate", "maxDate", "disabledDates", "disabledDays", "showTime", "responsiveOptions", "numberOfMonths", "firstDayOfWeek", "view", "defaultDate", "appendTo", "motionOptions"], outputs: ["onFocus", "onBlur", "onClose", "onSelect", "onClear", "onInput", "onTodayClick", "onClearClick", "onMonthChange", "onYearChange", "onClickOutside", "onShow"] }, { kind: "ngmodule", type: SelectModule }, { kind: "component", type: i11.Select, selector: "p-select", inputs: ["id", "scrollHeight", "filter", "panelStyle", "styleClass", "panelStyleClass", "readonly", "editable", "tabindex", "placeholder", "loadingIcon", "filterPlaceholder", "filterLocale", "inputId", "dataKey", "filterBy", "filterFields", "autofocus", "resetFilterOnHide", "checkmark", "dropdownIcon", "loading", "optionLabel", "optionValue", "optionDisabled", "optionGroupLabel", "optionGroupChildren", "group", "showClear", "emptyFilterMessage", "emptyMessage", "lazy", "virtualScroll", "virtualScrollItemSize", "virtualScrollOptions", "overlayOptions", "ariaFilterLabel", "ariaLabel", "ariaLabelledBy", "filterMatchMode", "tooltip", "tooltipPosition", "tooltipPositionStyle", "tooltipStyleClass", "focusOnHover", "selectOnFocus", "autoOptionFocus", "autofocusFilter", "filterValue", "options", "appendTo", "motionOptions"], outputs: ["onChange", "onFilter", "onFocus", "onBlur", "onClick", "onShow", "onHide", "onClear", "onLazyLoad"] }, { kind: "component", type: CilogInputNumberComponent, selector: "cilog-input-number", inputs: ["min", "max", "maxDecimals", "prefixe", "suffixe", "inputStyleClass", "disabled", "readonly", "textColor", "bold", "italic", "floatLabel"], outputs: ["onInput", "onChange", "onFocus", "onBlur"] }, { kind: "ngmodule", type: SelectButtonModule }, { kind: "component", type: i12.SelectButton, selector: "p-selectButton, p-selectbutton, p-select-button", inputs: ["options", "optionLabel", "optionValue", "optionDisabled", "unselectable", "tabindex", "multiple", "allowEmpty", "styleClass", "ariaLabelledBy", "dataKey", "autofocus", "size", "fluid"], outputs: ["onOptionClick", "onChange"] }, { kind: "ngmodule", type: ButtonModule }, { kind: "directive", type: i13.ButtonDirective, selector: "[pButton]", inputs: ["ptButtonDirective", "pButtonPT", "pButtonUnstyled", "hostName", "text", "plain", "raised", "size", "outlined", "rounded", "iconPos", "loadingIcon", "fluid", "label", "icon", "loading", "buttonProps", "severity"] }, { kind: "ngmodule", type: InputTextModule }, { kind: "directive", type: i14.InputText, selector: "[pInputText]", inputs: ["hostName", "ptInputText", "pInputTextPT", "pInputTextUnstyled", "pSize", "variant", "fluid", "invalid"] }, { kind: "ngmodule", type: InputNumberModule }, { kind: "component", type: i15.InputNumber, selector: "p-inputNumber, p-inputnumber, p-input-number", inputs: ["showButtons", "format", "buttonLayout", "inputId", "styleClass", "placeholder", "tabindex", "title", "ariaLabelledBy", "ariaDescribedBy", "ariaLabel", "ariaRequired", "autocomplete", "incrementButtonClass", "decrementButtonClass", "incrementButtonIcon", "decrementButtonIcon", "readonly", "allowEmpty", "locale", "localeMatcher", "mode", "currency", "currencyDisplay", "useGrouping", "minFractionDigits", "maxFractionDigits", "prefix", "suffix", "inputStyle", "inputStyleClass", "showClear", "autofocus"], outputs: ["onInput", "onFocus", "onBlur", "onKeyDown", "onClear"] }, { kind: "pipe", type: i3.DatePipe, name: "date" }, { kind: "pipe", type: ValuePipe, name: "value" }] });
1345
1294
  }
1346
1295
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "21.0.6", ngImport: i0, type: CilogTableComponent, decorators: [{
1347
1296
  type: Component,
1348
- args: [{ selector: 'cilog-table', standalone: false, template: "<div [ngStyle]=\"{ 'height': options.scrollHeight != null ? options.scrollHeight : '100%' }\">\n\n @if (options.exportExcel) {\n <button pButton\n icon=\"pi pi-file-excel\"\n class=\"p-button-success absolute z-5 w-2rem h-2rem border-round-right border-noround-top\"\n pTooltip=\"Exporter le contenu de la grille au format Excel\"\n (click)=\"exportExcel(options.exportExcelByFiltre, !options.exportExcelNoColors)\">\n </button>\n }\n\n <p-contextMenu #cm [model]=\"options.contextMenuItems\" />\n\n <p-table #table\n [columns]=\"columns\"\n [value]=\"values\"\n dataKey=\"id\"\n [selectionMode]=\"getModeSelection()\"\n [metaKeySelection]=\"isModeMetakeySelection()\"\n [(selection)]=\"selectedRows\"\n (onRowSelect)=\"onSelectRow($event)\"\n (onRowUnselect)=\"onUnselectRow($event)\"\n (onHeaderCheckboxToggle)=\"onSelectAll($event)\"\n (sortFunction)=\"sortGrille($event)\"\n [customSort]=\"options.grouping == null ? true : false\"\n [scrollable]=\"true\"\n [loading]=\"loading\"\n [scrollHeight]=\"'flex'\"\n [rowGroupMode]=\"options.grouping != null ? 'subheader' : null\"\n [groupRowsBy]=\"options.grouping != null ? options.grouping.obj + '.' + options.grouping.id : null\"\n [groupRowsByOrder]=\"0\"\n [virtualScroll]=\"options.virtualScroll == true && options.scrollHeight != null ? true : false\"\n [virtualScrollItemSize]=\"options.virtualScrollItemSize != null ? options.virtualScrollItemSize : 35\"\n [paginator]=\"options.paginator == null ? false : true\"\n [rows]=\"options.paginatorRows\"\n (onPage)=\"onPageTable($event)\"\n [tableStyleClass]=\"!options.themeGrille ? 'grid_grey' : options.themeGrille\"\n [lazy]=\"options.lazy == true ? true : false\"\n (onFilter)=\"onFilterTable($event)\"\n [rowTrackBy]=\"trackByFunction\"\n [(contextMenuSelection)]=\"contextMenuSelectedItem\"\n [contextMenu]=\"cm\">\n\n <!-- HEADER -->\n <ng-template pTemplate=\"header\" let-columns>\n\n <!-- HEADERS -->\n <tr class=\"rowHeader\">\n @if (isModeCheckboxSelection()) {\n <th class=\"cellDelete\"\n pFrozenColumn>\n @if (!options.filterable && options.toggleAll) {\n <p-tableHeaderCheckbox></p-tableHeaderCheckbox>\n }\n </th>\n }\n @for (col of columns; track col) {\n @if (!col.invisible) {\n <th\n [ngStyle]=\"{ 'width' : col.width ? col.width : null, 'background-color': col.backgroundColor ? col.backgroundColor : null }\"\n [ngClass]=\"{ 'text-center' : options.centerHeaders, 'headerAffichageSimple': !options.headersAffichageEntier, 'headerAffichageEntier': options.headersAffichageEntier }\"\n [pSortableColumn]=\"col.id\"\n [pSortableColumnDisabled]=\"!options.sortable || options.grouping != null || col.libelle == null || col.libelle == ''\"\n id=\"{{ col.id }}\"\n (click)=\"refreshData()\"\n pFrozenColumn\n [frozen]=\"col.frozen\"\n [pTooltip]=\"col.libelle\"\n [tooltipDisabled]=\"!col.tooltipHeader\"\n tooltipPosition=\"bottom\">\n <div [ngStyle]=\"{ 'color': col.textColor ? col.textColor : null }\">\n {{ col.libelle }}\n </div>\n @if (options.sortable && options.grouping == null && col.libelle != null && col.libelle != '') {\n <p-sortIcon\n [field]=\"col.id\">\n </p-sortIcon>\n }\n </th>\n }\n }\n @if (options.rowsDeletable) {\n <th class=\"cellDelete\"></th>\n }\n </tr>\n\n <!-- FILTRES -->\n @if (options.filterable) {\n <tr class=\"rowFilter\">\n @if (isModeCheckboxSelection()) {\n <th class=\"cellDelete\"\n pFrozenColumn>\n @if (options.toggleAll) {\n <p-tableHeaderCheckbox></p-tableHeaderCheckbox>\n }\n </th>\n }\n @for (col of columns; track col) {\n <!-- Text -->\n @if (!col.invisible && ((checkType('Dropdown', col) && col.options.filterText)\n || (checkType('MultiSelect', col) && col.options.filterText)\n || checkType('Text', col)\n || checkType('File', col)\n || (checkType('Button', col) && col.options.filterCol))\n || checkType('Number', col)\n || checkType('CilogNumber', col)) {\n <th\n [ngStyle]=\"{ 'width' : col.width ? col.width : null }\"\n pFrozenColumn\n [frozen]=\"col.frozen\">\n @if (!col.disableFilter) {\n <input\n pInputText\n type=\"text\"\n (input)=\"onFilterCol($event, col)\"\n [(ngModel)]=\"col.options.defaultFilters\">\n }\n </th>\n }\n <!-- Date -->\n @if (!col.invisible && checkType('Date', col)) {\n <th\n [ngStyle]=\"{ 'width' : col.width ? col.width : null }\"\n pFrozenColumn\n [frozen]=\"col.frozen\">\n @if (!col.disableFilter) {\n <p-datepicker\n [view]=\"getOption(col, rowData, 'mode') == null ? 'date' : getOption(col, rowData, 'mode')\"\n [dateFormat]=\"getOption(col, rowData, 'mode') == 'year' ? 'yy' : getOption(col, rowData, 'mode') == 'month' ? 'mm/yy' : 'dd/mm/yy'\"\n [inputId]=\"col.id + '_filter'\"\n firstDayOfWeek=\"1\"\n [readonlyInput]=\"true\"\n appendTo=\"body\"\n selectionMode=\"range\"\n (onSelect)=\"onFilterCol($event, col)\"\n showButtonBar=\"true\"\n (onClearClick)=\"onFilterCol($event, col)\"\n [(ngModel)]=\"col.options.defaultFilters\">\n </p-datepicker>\n }\n </th>\n }\n <!-- Liste -->\n @if (!col.invisible && ((checkType('Dropdown', col) && !col.options.filterText) || (checkType('MultiSelect', col) && !col.options.filterText) || checkType('SelectButton', col) || checkType('State', col))) {\n <th\n [ngStyle]=\"{ 'width' : col.width ? col.width : null }\"\n pFrozenColumn\n [frozen]=\"col.frozen\">\n @if (!col.disableFilter) {\n <p-multiSelect\n [options]=\"col.options?.options\"\n [filter]=\"true\"\n dataKey=\"ID\"\n [optionLabel]=\"col.options?.optionLabel\"\n appendTo=\"body\"\n emptyFilterMessage=\"Aucun r\u00E9sultat\"\n emptyMessage=\"Aucun r\u00E9sultat\"\n [virtualScroll]=\"true\"\n [virtualScrollItemSize]=\"35\"\n selectedItemsLabel=\"{0} selectionn\u00E9s\"\n (onChange)=\"onFilterCol($event, col)\"\n [(ngModel)]=\"col.options.defaultFilters\"\n [group]=\"col.options.optionGroupChildren != null ? true : false\"\n [optionGroupLabel]=\"col.options.optionGroupLabel\"\n [optionGroupChildren]=\"col.options.optionGroupChildren\"\n [showToggleAll]=\"false\"\n [showClear]=\"true\"\n (onClear)=\"onFilterCol(null, col)\">\n <ng-template let-group pTemplate=\"group\">\n <div>{{group[col.options.optionGroupLabel]}}</div>\n </ng-template>\n </p-multiSelect>\n }\n </th>\n }\n <!-- Switch -->\n @if (!col.invisible && checkType('Switch', col)) {\n <th\n [ngStyle]=\"{ 'width' : col.width ? col.width : null }\"\n pFrozenColumn\n [frozen]=\"col.frozen\">\n @if (!col.disableFilter) {\n <p-multiSelect\n [options]=\"optionsSwitch\"\n [showHeader]=\"false\"\n optionLabel=\"label\"\n optionValue=\"value\"\n appendTo=\"body\"\n emptyFilterMessage=\"Aucun r\u00E9sultat\"\n emptyMessage=\"Aucun r\u00E9sultat\"\n [virtualScrollItemSize]=\"30\"\n selectedItemsLabel=\"{0} selectionn\u00E9s\"\n (onChange)=\"onFilterCol($event, col)\"\n [(ngModel)]=\"col.options.defaultFilters\">\n </p-multiSelect>\n }\n </th>\n }\n <!-- Non filtrable -->\n @if (!col.invisible && (checkType('Image', col) || (checkType('Button', col) && !col.options.filterCol))) {\n <th\n [ngStyle]=\"{ 'width' : col.width ? col.width : null }\"\n pFrozenColumn\n [frozen]=\"col.frozen\">\n </th>\n }\n }\n @if (options.rowsDeletable) {\n <th class=\"cellDelete\"></th>\n }\n </tr>\n }\n\n <!-- TOTAL -->\n @if (options.rowTotal) {\n <tr\n class=\"rowTotal\">\n @if (isModeCheckboxSelection()) {\n <th class=\"cellDelete\"\n pFrozenColumn>\n </th>\n }\n @for (col of columns; track col) {\n @if (!col.invisible) {\n <th\n [ngStyle]=\"{ 'width' : col.width ? col.width : null }\"\n [ngClass]=\"{ 'text-center' : true }\"\n pFrozenColumn\n [frozen]=\"col.frozen\">\n <div>{{ getTotalStr(col) }}</div>\n </th>\n }\n }\n @if (options.rowsDeletable) {\n <th class=\"cellDelete\"></th>\n }\n </tr>\n }\n </ng-template>\n\n <!--Groupheader-->\n <ng-template pTemplate=\"groupheader\" let-rowData>\n <tr pRowGroupHeader class=\"rowGrouping\">\n <td [attr.colspan]=\"columns.length\">\n <div class=\"text_bold\">{{ rowData[options.grouping.obj][options.grouping.libelle] }}</div>\n </td>\n </tr>\n </ng-template>\n\n <!-- Body -->\n <ng-template pTemplate=\"body\" let-rowData let-columns=\"columns\">\n <tr id=\"{{ rowData.id }}\"\n [ngStyle]=\"{ 'background-color': rowData.color ? rowData.color : null }\"\n [pSelectableRow]=\"rowData\"\n [pSelectableRowDisabled]=\"!options.selectable || isModeCheckboxSelection() || isModeCellSelection()\"\n (dblclick)=\"onRowDoubleClickEvent(rowData)\"\n [pContextMenuRow]=\"rowData\"\n [pContextMenuRowDisabled]=\"options.contextMenuItems == null\">\n\n @if (isModeCheckboxSelection()) {\n <td\n class=\"cellDelete\"\n pFrozenColumn>\n <p-tableCheckbox [value]=\"rowData\" [disabled]=\"rowData.readonly\"></p-tableCheckbox>\n </td>\n }\n\n @for (col of columns; track col) {\n <!-- Text -->\n @if (!col.invisible && checkType('Text', col) && isModeEdition() && !rowData.readonly && !rowData[col.id]?.readonly) {\n <td\n [ngStyle]=\"{ 'width' : col.width ? col.width : null, 'background-color': rowData[col.id].color ? rowData[col.id].color : null }\"\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\n [pEditableColumn]=\"rowData\"\n [pEditableColumnField]=\"col.id\"\n [pTooltip]=\"rowData[col.id].tooltip != null ? rowData[col.id].tooltip : rowData[col.id].value\"\n [tooltipDisabled]=\"!col.tooltip\"\n tooltipPosition=\"bottom\"\n pFrozenColumn\n (click)=\"options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection && !rowData[col.id].disableSelection && onSelectCell(rowData[col.id])\"\n [frozen]=\"col.frozen\"\n [ngClass]=\"{\r\n 'text-left': col.position == 'left' || col.position == null,\r\n 'text-right': col.position == 'right',\r\n 'text-center': col.position == 'center',\r\n 'font-bold': rowData.bold == true || rowData[col.id].bold == true,\r\n 'font-italic': rowData.italic == true || rowData[col.id].italic == true,\r\n 'selectable_cell' : options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection\r\n }\">\r\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\n <p-cellEditor>\n <ng-template pTemplate=\"input\">\n <input pInputText\n type=\"text\"\n [(ngModel)]=\"rowData[col.id].value\"\n (blur)=\"onEditCell(rowData, col, rowData[col.id].value)\"\n (keydown.enter)=\"onEditCell(rowData, col, rowData[col.id].value)\"\n (keydown.tab)=\"onEditCell(rowData, col, rowData[col.id].value)\"\n (click)=\"onEditInitCell(rowData, col, rowData[col.id].value)\"\n [ngClass]=\"{\r\n 'text-left': col.position == 'left' || col.position == null,\r\n 'text-right': col.position == 'right',\r\n 'text-center': col.position == 'center',\r\n 'font-bold': rowData.bold == true || rowData[col.id].bold == true,\r\n 'font-italic': rowData.italic == true || rowData[col.id].italic == true\r\n }\" />\r\n </ng-template>\n <ng-template pTemplate=\"output\">\n @if (rowData[col.id]) {\n <div\n style=\"white-space: pre;\">\n {{ getFormattedText(col, rowData) }}\n </div>\n }\n </ng-template>\n </p-cellEditor>\n </td>\n }\n @if (!col.invisible && checkType('Text', col) && (!isModeEdition() || rowData.readonly || rowData[col.id]?.readonly)) {\n <td\n [ngStyle]=\"{\r\n 'width' : col.width ? col.width : null,\r\n 'background-color' : rowData[col.id].color ? rowData[col.id].color : null,\r\n 'color' : rowData[col.id].textColor ? rowData[col.id].textColor : null\r\n }\"\r\n (click)=\"options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection && !rowData[col.id].disableSelection && onSelectCell(rowData[col.id])\"\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\n [pTooltip]=\"rowData[col.id].tooltip != null ? rowData[col.id].tooltip : rowData[col.id].value\"\n [tooltipDisabled]=\"!col.tooltip\"\n tooltipPosition=\"bottom\"\n [ngClass]=\"{\r\n 'paddingCell': rowData[col.id] != null,\r\n 'text-left': col.position == 'left' || col.position == null,\r\n 'text-right': col.position == 'right',\r\n 'text-center': col.position == 'center',\r\n 'font-bold': rowData.bold == true || rowData[col.id].bold == true,\r\n 'font-italic': rowData.italic == true || rowData[col.id].italic == true,\r\n 'selectable_cell' : options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection\r\n }\"\r\n pFrozenColumn\n [frozen]=\"col.frozen\">\n <div class=\"p-column-title\">\n {{ col.libelle }} :\n </div>\n @if (rowData[col.id]) {\n <div\n style=\"white-space: pre;\">\n {{ getFormattedText(col, rowData) }}\n </div>\n }\n </td>\n }\n <!-- Dropdown -->\n @if (!col.invisible && checkType('Dropdown', col) && isModeEdition() && !rowData.readonly && !rowData[col.id]?.readonly) {\n <td\n [ngStyle]=\"{ 'width' : col.width ? col.width : null, 'background-color': rowData[col.id].color ? rowData[col.id].color : null }\"\n [ngClass]=\"{\r\n 'text-left': col.position == 'left' || col.position == null,\r\n 'text-right': col.position == 'right',\r\n 'text-center': col.position == 'center',\r\n 'selectable_cell' : options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection\r\n }\"\r\n (click)=\"options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection && onSelectCell(rowData[col.id])\"\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\n [pTooltip]=\"rowData[col.id].tooltip != null ? rowData[col.id].tooltip : rowData[col.id].value != null ? rowData[col.id].value[getOption(col, rowData, 'optionLabel')] : ''\"\n [tooltipDisabled]=\"!col.tooltip\"\n tooltipPosition=\"bottom\"\n pFrozenColumn\n [frozen]=\"col.frozen\"\n class=\"paddingCell\">\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\n @if (rowData[col.id] != null) {\n <p-select\n dataKey=\"ID\"\n [options]=\"getOption(col, rowData, 'options')\"\n [filter]=\"getOption(col, rowData, 'filter')\"\n [optionLabel]=\"getOption(col, rowData, 'optionLabel')\"\n [(ngModel)]=\"rowData[col.id].value\"\n [autoDisplayFirst]=\"false\"\n appendTo=\"body\"\n [showClear]=\"getOption(col, rowData, 'deletable')\"\n emptyFilterMessage=\"Aucun r\u00E9sultat\"\n emptyMessage=\"Aucun r\u00E9sultat\"\n [baseZIndex]=\"getOption(col, rowData, 'baseZIndex')\"\n [virtualScroll]=\"getOption(col, rowData, 'virtualScroll')\"\n [readonly]=\"rowData.readonly || rowData[col.id]?.readonly\"\n [virtualScrollItemSize]=\"30\"\n (onChange)=\"onEditCell(rowData, col, rowData[col.id].value)\"\n (onClear)=\"onEditCell(rowData, col, rowData[col.id].value)\">\n <ng-template let-data pTemplate=\"selectedItem\">\n @if (data != null) {\n <span\n [ngClass]=\"{\r\n 'font-bold': rowData.bold == true || rowData[col.id].bold == true,\r\n 'font-italic': rowData.italic == true || rowData[col.id].italic == true\r\n }\">\r\n {{ data[getOption(col, rowData, 'optionLabel')] }}\n </span>\n }\n @if (data == null) {\n <span></span>\n }\n </ng-template>\n </p-select>\n }\n </td>\n }\n @if (!col.invisible && checkType('Dropdown', col) && (rowData.readonly || rowData[col.id]?.readonly || !isModeEdition())) {\n <td\n [ngStyle]=\"{\r\n 'width' : col.width ? col.width : null,\r\n 'background-color': rowData[col.id].color ? rowData[col.id].color : null,\r\n 'color' : rowData[col.id].textColor ? rowData[col.id].textColor : null\r\n }\"\r\n (click)=\"options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection && onSelectCell(rowData[col.id])\"\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\n [pTooltip]=\"rowData[col.id].tooltip != null ? rowData[col.id].tooltip : rowData[col.id].value != null ? rowData[col.id].value[getOption(col, rowData, 'optionLabel')] : ''\"\n [tooltipDisabled]=\"!col.tooltip\"\n tooltipPosition=\"bottom\"\n [ngClass]=\"{\r\n 'paddingCell': rowData[col.id] != null,\r\n 'text-left': col.position == 'left' || col.position == null,\r\n 'text-right': col.position == 'right',\r\n 'text-center': col.position == 'center',\r\n 'font-bold': rowData.bold == true || rowData[col.id].bold == true,\r\n 'font-italic': rowData.italic == true || rowData[col.id].italic == true,\r\n 'selectable_cell' : options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection\r\n }\"\r\n pFrozenColumn\n [frozen]=\"col.frozen\">\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\n @if (rowData[col.id]) {\n <div>{{ rowData[col.id].value != null ? rowData[col.id].value[getOption(col, rowData, 'optionLabel')] : '' }}</div>\n }\n </td>\n }\n <!-- Cilog Number -->\n @if (!col.invisible && checkType('CilogNumber', col) && isModeEdition() && !rowData.readonly && !rowData[col.id]?.readonly) {\n <td\n [ngStyle]=\"{ 'width' : col.width ? col.width : null, 'background-color': rowData[col.id].color ? rowData[col.id].color : null }\"\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\n [ngClass]=\"{\r\n 'paddingCell': rowData[col.id] != null,\r\n 'selectable_cell' : options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection\r\n }\"\r\n (click)=\"options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection && onSelectCell(rowData[col.id])\"\n [pTooltip]=\"rowData[col.id].tooltip != null ? rowData[col.id].tooltip : rowData[col.id].value | value\"\n [tooltipDisabled]=\"!col.tooltip\"\n tooltipPosition=\"bottom\"\n pFrozenColumn\n [frozen]=\"col.frozen\">\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\n @if (rowData[col.id] && !rowData.readonly && !rowData[col.id]?.readonly) {\n <cilog-input-number\n (onInput)=\"onInputNumber($event)\"\n [(ngModel)]=\"rowData[col.id].value\"\n [inputStyleClass]=\"col.position == null || col.position == 'right' ? 'text-right' : col.position == 'left' ? 'text-left' : 'text-center'\"\n [textColor]=\"rowData[col.id].textColor\"\n [bold]=\"rowData.bold == true || rowData[col.id].bold == true\"\n [italic]=\"rowData.italic == true || rowData[col.id].italic == true\"\n [suffixe]=\"getOption(col, rowData, 'suffix')\"\n [prefixe]=\"getOption(col, rowData, 'prefix') != null ? getOption(col, rowData, 'prefix') + ' ' : null\"\n [min]=\"getOption(col, rowData, 'min')\"\n [max]=\"getOption(col, rowData, 'max')\"\n [disabled]=\"rowData.readonly || rowData[col.id]?.readonly\"\n [maxDecimals]=\"getOption(col, rowData, 'modeInteger') != null && getOption(col, rowData, 'modeInteger') == true ? 0 : getOption(col, rowData, 'maxDecimales') != null ? getOption(col, rowData, 'maxDecimales') : 2 \"\n (onChange)=\"onEditCell(rowData, col, rowData[col.id].value)\"\n (onFocus)=\"onEditInitCell(rowData, col, rowData[col.id].value)\">\n </cilog-input-number>\n }\n </td>\n }\n @if (!col.invisible && checkType('CilogNumber', col) && (rowData.readonly || rowData[col.id]?.readonly || !isModeEdition())) {\n <td\n [ngStyle]=\"{\r\n 'width' : col.width ? col.width : null,\r\n 'background-color': rowData[col.id].color ? rowData[col.id].color : null,\r\n 'color' : rowData[col.id].textColor ? rowData[col.id].textColor : null\r\n }\"\r\n (click)=\"options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection && onSelectCell(rowData[col.id])\"\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\n [pTooltip]=\"rowData[col.id].tooltip != null ? rowData[col.id].tooltip : rowData[col.id].value | value\"\n [tooltipDisabled]=\"!col.tooltip\"\n tooltipPosition=\"bottom\"\n [ngClass]=\"{\r\n 'paddingCell': rowData[col.id] != null,\r\n 'text-left': col.position == 'left' || col.position == null,\r\n 'text-right': col.position == 'right',\r\n 'text-center': col.position == 'center',\r\n 'font-bold': rowData.bold == true || rowData[col.id].bold == true,\r\n 'font-italic': rowData.italic == true || rowData[col.id].italic == true,\r\n 'selectable_cell' : options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection\r\n }\"\r\n pFrozenColumn\n [frozen]=\"col.frozen\">\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\n @if (rowData[col.id]) {\n <div>{{ getFormattedNumber(col, rowData, rowData[col.id].value) }}</div>\n }\n </td>\n }\n <!-- Number -->\n @if (!col.invisible && checkType('Number', col) && isModeEdition() && !rowData.readonly && !rowData[col.id]?.readonly) {\n <td\n [ngStyle]=\"{ 'width' : col.width ? col.width : null, 'background-color': rowData[col.id].color ? rowData[col.id].color : null }\"\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\n [pTooltip]=\"rowData[col.id].tooltip != null ? rowData[col.id].tooltip : rowData[col.id].value | value\"\n [tooltipDisabled]=\"!col.tooltip\"\n [ngClass]=\"{\r\n 'paddingCell': rowData[col.id] != null,\r\n 'text-left': col.position == 'left',\r\n 'text-right': col.position == 'right' || col.position == null,\r\n 'text-center': col.position == 'center',\r\n 'font-bold': rowData.bold == true || rowData[col.id].bold == true,\r\n 'font-italic': rowData.italic == true || rowData[col.id].italic == true,\r\n 'selectable_cell' : options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection\r\n }\"\r\n tooltipPosition=\"bottom\"\n pFrozenColumn\n [frozen]=\"col.frozen\"\n (click)=\"onClickCellNumber(rowData, col)\">\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\n @if (rowData[col.id] && !rowData[col.id].focus) {\n <div>\n {{ getFormattedNumber(col, rowData, rowData[col.id].value) }}\n </div>\n }\n @if (rowData[col.id] && !rowData.readonly && !rowData[col.id]?.readonly && rowData[col.id].focus == true) {\n <p-inputNumber #inputNumber\n locale=\"fr-FR\"\n (onInput)=\"onInputNumber($event)\"\n [(ngModel)]=\"rowData[col.id].value\"\n [showButtons]=\"getOption(col, rowData, 'showButtons')\"\n [inputStyleClass]=\"col.position == null || col.position == 'right' ? 'text-right' : col.position == 'left' ? 'text-left' : 'text-center'\"\n [inputStyle]=\"{ 'font-weight': rowData.bold == true || rowData[col.id].bold == true ? 'bold' : null, 'font-style': rowData.italic == true || rowData[col.id].italic == true ? 'italic' : null }\"\n [suffix]=\"getOption(col, rowData, 'suffix')\"\n [prefix]=\"getOption(col, rowData, 'prefix') != null ? getOption(col, rowData, 'prefix') + ' ' : null\"\n [min]=\"getOption(col, rowData, 'min')\"\n [max]=\"getOption(col, rowData, 'max')\"\n [minFractionDigits]=\"getOption(col, rowData, 'modeInteger') != null && getOption(col, rowData, 'modeInteger') == true ? 0 : getOption(col, rowData, 'minDecimales') != null ? getOption(col, rowData, 'minDecimales') : 0\"\n [maxFractionDigits]=\"getOption(col, rowData, 'modeInteger') != null && getOption(col, rowData, 'modeInteger') == true ? 0 : getOption(col, rowData, 'maxDecimales') != null ? getOption(col, rowData, 'maxDecimales') : 2 \"\n (onBlur)=\"onEditCell(rowData, col, rowData[col.id].value)\"\n (onKeyDown)=\"onKeyDown($event, rowData, col, rowData[col.id].value)\"\n (onFocus)=\"onEditInitCell(rowData, col, rowData[col.id].value)\">\n </p-inputNumber>\n }\n </td>\n }\n @if (!col.invisible && checkType('Number', col) && (rowData.readonly || rowData[col.id]?.readonly || !isModeEdition())) {\n <td\n [ngStyle]=\"{\r\n 'width' : col.width ? col.width : null,\r\n 'background-color': rowData[col.id].color ? rowData[col.id].color : null,\r\n 'color' : rowData[col.id].textColor ? rowData[col.id].textColor : null\r\n }\"\r\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\n [pTooltip]=\"rowData[col.id].tooltip != null ? rowData[col.id].tooltip : rowData[col.id].value | value\"\n [tooltipDisabled]=\"!col.tooltip\"\n tooltipPosition=\"bottom\"\n (click)=\"options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection && onSelectCell(rowData[col.id])\"\n [ngClass]=\"{\r\n 'paddingCell': rowData[col.id] != null,\r\n 'text-left': col.position == 'left',\r\n 'text-right': col.position == 'right' || col.position == null,\r\n 'text-center': col.position == 'center',\r\n 'font-bold': rowData.bold == true || rowData[col.id].bold == true,\r\n 'font-italic': rowData.italic == true || rowData[col.id].italic == true,\r\n 'selectable_cell' : options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection\r\n }\"\r\n pFrozenColumn\n [frozen]=\"col.frozen\">\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\n @if (rowData[col.id]) {\n <div>{{ getFormattedNumber(col, rowData, rowData[col.id].value) }}</div>\n }\n </td>\n }\n <!-- Date -->\n @if (!col.invisible && checkType('Date', col) && isModeEdition() && !rowData.readonly && !rowData[col.id]?.readonly) {\n <td\n [ngStyle]=\"{ 'width' : col.width ? col.width : null, 'background-color': rowData[col.id].color ? rowData[col.id].color : null }\"\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\n [ngClass]=\"{\r\n 'paddingCell': rowData[col.id] != null,\r\n 'selectable_cell' : options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection\r\n }\"\r\n (click)=\"options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection && onSelectCell(rowData[col.id])\"\n [pTooltip]=\"rowData[col.id].tooltip != null ? rowData[col.id].tooltip : getOption(col, rowData, 'mode') == 'year' ? (rowData[col.id].value | date: 'yyyy') : getOption(col, rowData, 'mode') == 'month' ? (rowData[col.id].value | date: 'MM/yy') : getOption(col, rowData, 'mode') == 'hour' ? (rowData[col.id].value | date: 'HH:mm') : getOption(col, rowData, 'mode') == 'datehour' ? (rowData[col.id].value | date: 'dd/MM/yy HH:mm') : (rowData[col.id].value | date: 'dd/MM/yyyy')\"\n [tooltipDisabled]=\"!col.tooltip\"\n tooltipPosition=\"bottom\"\n pFrozenColumn\n [frozen]=\"col.frozen\">\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\n <p-datepicker [(ngModel)]=\"rowData[col.id].value\"\n [view]=\"getOption(col, rowData, 'mode') == null || getOption(col, rowData, 'mode') == 'date' || getOption(col, rowData, 'mode') == 'hour' ? 'date' : getOption(col, rowData, 'mode') == 'datehour' ? 'date' : getOption(col, rowData, 'mode')\"\n [dateFormat]=\"getOption(col, rowData, 'mode') == 'year' ? 'yy' : getOption(col, rowData, 'mode') == 'month' ? 'mm/yy' : getOption(col, rowData, 'mode') == 'hour' || getOption(col, rowData, 'mode') == 'datehour' ? 'dd/mm/yy' : 'dd/mm/yy'\"\n [showTime]=\"getOption(col, rowData, 'mode') == 'datehour'\"\n [timeOnly]=\"getOption(col, rowData, 'mode') == 'hour'\"\n [hourFormat]=\"24\"\n firstDayOfWeek=\"1\"\n (onSelect)=\"onEditCell(rowData, col, rowData[col.id].value)\"\n (onBlur)=\"onEditCell(rowData, col, rowData[col.id].value)\"\n (onClear)=\"onEditCell(rowData, col, rowData[col.id].value)\"\n [inputStyleClass]=\"col.position == null || col.position == 'right' ? 'text-right' : col.position == 'left' ? 'text-left' : 'text-center'\"\n [inputStyle]=\"{ 'font-weight': rowData.bold == true || rowData[col.id].bold == true ? 'bold' : null, 'font-style': rowData.italic == true || rowData[col.id].italic == true ? 'italic' : null }\"\n [showClear]=\"getOption(col, rowData, 'clear')\"\n [minDate]=\"getOption(col, rowData, 'minDate')\"\n [maxDate]=\"getOption(col, rowData, 'maxDate')\"\n [defaultDate]=\"getOption(col, rowData, 'defaultDate')\"\n appendTo=\"body\">\n </p-datepicker>\n </td>\n }\n @if (!col.invisible && checkType('Date', col) && (rowData.readonly || rowData[col.id]?.readonly || !isModeEdition())) {\n <td\n [ngStyle]=\"{\r\n 'min-width' : col.width ? col.width : null,\r\n 'background-color': rowData[col.id].color ? rowData[col.id].color : null,\r\n 'color' : rowData[col.id].textColor ? rowData[col.id].textColor : null\r\n }\"\r\n (click)=\"options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection && onSelectCell(rowData[col.id])\"\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\n [pTooltip]=\"rowData[col.id].tooltip != null ? rowData[col.id].tooltip : rowData[col.id].value | date: 'dd/MM/yyyy'\"\n [tooltipDisabled]=\"!col.tooltip\"\n tooltipPosition=\"bottom\"\n [ngClass]=\"{\r\n 'paddingCell': rowData[col.id] != null,\r\n 'text-left': col.position == 'left' || col.position == null,\r\n 'text-right': col.position == 'right',\r\n 'text-center': col.position == 'center',\r\n 'font-bold': rowData.bold == true || rowData[col.id].bold == true,\r\n 'font-italic': rowData.italic == true || rowData[col.id].italic == true,\r\n 'selectable_cell' : options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection\r\n }\"\r\n pFrozenColumn\n [frozen]=\"col.frozen\">\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\n @if (rowData[col.id]) {\n <div>{{ rowData[col.id].value | date: (getOption(col, rowData, 'mode') == 'year' ? 'yyyy' : getOption(col, rowData, 'mode') == 'month' ? 'MM/yyyy' : 'dd/MM/yyyy') }}</div>\n }\n </td>\n }\n <!-- MultiSelect -->\n @if (!col.invisible && checkType('MultiSelect', col) && isModeEdition() && !rowData.readonly && !rowData[col.id]?.readonly) {\n <td\n [ngStyle]=\"{ 'width' : col.width ? col.width : null, 'background-color': rowData[col.id].color ? rowData[col.id].color : null }\"\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\n [ngClass]=\"{\r\n 'text-left': col.position == 'left' || col.position == null,\r\n 'text-right': col.position == 'right',\r\n 'text-center': col.position == 'center',\r\n 'selectable_cell' : options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection\r\n }\"\r\n (click)=\"options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection && onSelectCell(rowData[col.id])\"\n [pTooltip]=\"rowData[col.id].tooltip != null ? rowData[col.id].tooltip : getMultiSelectConcat(rowData[col.id].value, getOption(col, rowData, 'optionLabel'))\"\n [tooltipDisabled]=\"!col.tooltip\"\n tooltipPosition=\"bottom\"\n pFrozenColumn\n [frozen]=\"col.frozen\"\n class=\"paddingCell\">\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\n @if (rowData[col.id] != null) {\n <p-multiSelect\n [options]=\"getOption(col, rowData, 'options')\"\n [filter]=\"getOption(col, rowData, 'filter')\"\n [optionLabel]=\"getOption(col, rowData, 'optionLabel')\"\n [(ngModel)]=\"rowData[col.id].value\"\n appendTo=\"body\"\n dataKey=\"ID\"\n emptyFilterMessage=\"Aucun r\u00E9sultat\"\n emptyMessage=\"Aucun r\u00E9sultat\"\n [baseZIndex]=\"getOption(col, rowData, 'baseZIndex')\"\n [virtualScroll]=\"getOption(col, rowData, 'virtualScroll')\"\n [readonly]=\"rowData.readonly || rowData[col.id]?.readonly || !isModeEdition()\"\n [virtualScrollItemSize]=\"30\"\n selectedItemsLabel=\"{0} selectionn\u00E9s\"\n (onChange)=\"editMultiselect(rowData, col, $event)\"\n [showToggleAll]=\"false\"\n [showHeader]=\"getOption(col, rowData, 'filter')\"\n [group]=\"getOption(col, rowData, 'optionGroupChildren') != null ? true : false\"\n [optionGroupLabel]=\"getOption(col, rowData, 'optionGroupLabel')\"\n [optionGroupChildren]=\"getOption(col, rowData, 'optionGroupChildren')\"\n ngDefaultControl>\n <ng-template let-data pTemplate=\"selectedItems\">\n @for (option of data; track option; let i = $index) {\n <span\n [ngClass]=\"{\r\n 'font-bold': rowData.bold == true || rowData[col.id].bold == true,\r\n 'font-italic': rowData.italic == true || rowData[col.id].italic == true\r\n }\">\r\n {{ option[getOption(col, rowData, 'optionLabel')] + (i != data.length - 1 ? ',' : '') }}\n </span>\n }\n </ng-template>\n <ng-template let-group pTemplate=\"group\">\n <div>{{group[col.options.optionGroupLabel]}}</div>\n </ng-template>\n </p-multiSelect>\n }\n </td>\n }\n @if (!col.invisible && checkType('MultiSelect', col) && (rowData.readonly || rowData[col.id]?.readonly || !isModeEdition())) {\n <td\n [ngStyle]=\"{\r\n 'width' : col.width ? col.width : null,\r\n 'background-color': rowData[col.id].color ? rowData[col.id].color : null,\r\n 'color' : rowData[col.id].textColor ? rowData[col.id].textColor : null\r\n }\"\r\n (click)=\"options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection && onSelectCell(rowData[col.id])\"\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\n [pTooltip]=\"rowData[col.id].tooltip != null ? rowData[col.id].tooltip : getMultiSelectConcat(rowData[col.id].value, getOption(col, rowData, 'optionLabel'))\"\n [tooltipDisabled]=\"!col.tooltip\"\n tooltipPosition=\"bottom\"\n [ngClass]=\"{\r\n 'paddingCell': rowData[col.id] != null,\r\n 'text-left': col.position == 'left' || col.position == null,\r\n 'text-right': col.position == 'right',\r\n 'text-center': col.position == 'center',\r\n 'font-bold': rowData.bold == true || rowData[col.id].bold == true,\r\n 'font-italic': rowData.italic == true || rowData[col.id].italic == true,\r\n 'selectable_cell' : options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection\r\n }\"\r\n pFrozenColumn\n [frozen]=\"col.frozen\">\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\n @if (rowData[col.id]) {\n <div>{{ getMultiSelectConcat(rowData[col.id].value, getOption(col, rowData, 'optionLabel')) }}</div>\n }\n </td>\n }\n <!-- Image -->\n @if (!col.invisible && checkType('Image', col)) {\n <td\n [ngStyle]=\"{ 'width' : col.width ? col.width : null, 'background-color': rowData[col.id].color ? rowData[col.id].color : null }\"\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\n [ngClass]=\"{\r\n 'paddingCell': rowData[col.id] != null,\r\n 'selectable_cell' : options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection\r\n }\"\r\n (click)=\"options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection && onSelectCell(rowData[col.id])\"\n class=\"text-center\"\n pFrozenColumn\n [frozen]=\"col.frozen\">\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\n @if (rowData[col.id]) {\n <img style=\"vertical-align: middle; width: 40px;\" src=\"{{ rowData[col.id].value }}\" />\n }\n </td>\n }\n <!-- Button -->\n @if (!col.invisible && checkType('Button', col)) {\n <td\n class=\"paddingCell text-center\"\n [ngClass]=\"{\r\n 'selectable_cell' : options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection\r\n }\"\r\n (click)=\"options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection && onSelectCell(rowData[col.id])\"\n [ngStyle]=\"{ 'width' : col.width ? col.width : null, 'background-color': rowData[col.id].color ? rowData[col.id].color : null }\">\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\n @if (rowData[col.id].value != null && isValueButtonByType(rowData[col.id].value, 'function')) {\n <button pButton\n [disabled]=\"rowData.readonly || rowData[col.id]?.readonly\"\n [label]=\"getOption(col, rowData, 'label')\"\n [icon]=\"getOption(col, rowData, 'icon')\"\n (click)=\"rowData[col.id].value()\"\n [pTooltip]=\"rowData[col.id].tooltip != null ? rowData[col.id].tooltip : getOption(col, rowData, 'label')\"\n [tooltipDisabled]=\"!col.tooltip\"\n [class]=\"'p-button-' + getOption(col, rowData, 'severity')\"\n [ngClass]=\"{\r\n 'font-bold': rowData.bold == true || rowData[col.id].bold == true,\r\n 'font-italic': rowData.italic == true || rowData[col.id].italic == true\r\n }\">\r\n </button>\n }\n @if (isValueButtonByType(rowData[col.id].value, 'string')) {\n <div\n [ngClass]=\"{\r\n 'paddingCell': rowData[col.id] != null,\r\n 'text-left': col.position == 'left' || col.position == null,\r\n 'text-right': col.position == 'right',\r\n 'text-center': col.position == 'center',\r\n 'font-bold': rowData.bold == true || rowData[col.id].bold == true,\r\n 'font-italic': rowData.italic == true || rowData[col.id].italic == true\r\n }\"\r\n [pTooltip]=\"rowData[col.id].tooltip != null ? rowData[col.id].tooltip : rowData[col.id].value\"\n [tooltipDisabled]=\"!col.tooltip\">\n {{ rowData[col.id].value }}\n </div>\n }\n </td>\n }\n <!-- SelectButton -->\n @if (!col.invisible && checkType('SelectButton', col) && isModeEdition() && !rowData.readonly && !rowData[col.id]?.readonly) {\n <td\n [ngStyle]=\"{ 'width' : col.width ? col.width : null, 'background-color': rowData[col.id].color ? rowData[col.id].color : null }\"\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\n [ngClass]=\"{\r\n 'paddingCell': rowData[col.id] != null,\r\n 'selectable_cell' : options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection\r\n }\"\r\n (click)=\"options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection && onSelectCell(rowData[col.id])\"\n pFrozenColumn\n [frozen]=\"col.frozen\">\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\n @if (rowData[col.id] != null) {\n <p-selectButton\n [options]=\"getOption(col, rowData, 'options')\"\n [optionLabel]=\"getOption(col, rowData, 'optionLabel')\"\n [optionValue]=\"getOption(col, rowData, 'optionValue') != null ? getOption(col, rowData, 'optionValue') : 'value'\"\n [(ngModel)]=\"rowData[col.id].value\"\n [disabled]=\"rowData.readonly || rowData[col.id]?.readonly || !isModeEdition()\"\n (onChange)=\"onEditCell(rowData, col, rowData[col.id].value)\">\n <ng-template let-item pTemplate=\"item\">\n <span class=\"text-center w-full\"\n [ngClass]=\"{\r\n 'font-bold': rowData.bold == true || rowData[col.id].bold == true,\r\n 'font-italic': rowData.italic == true || rowData[col.id].italic == true\r\n }\">\r\n {{ item.label }}\n </span>\n </ng-template>\n </p-selectButton>\n }\n </td>\n }\n @if (!col.invisible && checkType('SelectButton', col) && (rowData.readonly || rowData[col.id]?.readonly || !isModeEdition())) {\n <td\n [ngStyle]=\"{\r\n 'width' : col.width ? col.width : null,\r\n 'background-color': rowData[col.id].color ? rowData[col.id].color : null,\r\n 'color' : rowData[col.id].textColor ? rowData[col.id].textColor : null\r\n }\"\r\n (click)=\"options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection && onSelectCell(rowData[col.id])\"\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\n pFrozenColumn\n [frozen]=\"col.frozen\"\n class=\"text-center\"\n [ngClass]=\"{\r\n 'paddingCell': rowData[col.id] != null,\r\n 'font-bold': rowData.bold == true || rowData[col.id].bold == true,\r\n 'font-italic': rowData.italic == true || rowData[col.id].italic == true,\r\n 'selectable_cell' : options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection\r\n }\">\r\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\n @if (rowData[col.id]) {\n <div>{{ getSelectLibelleByValue(rowData, col) }}</div>\n }\n </td>\n }\n <!-- Switch -->\n @if (!col.invisible && checkType('Switch', col)) {\n <td\n [ngStyle]=\"{ 'width' : col.width ? col.width : null, 'background-color': rowData[col.id].color ? rowData[col.id].color : null }\"\n class=\"text-center\"\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\n [ngClass]=\"{\r\n 'paddingCell': rowData[col.id] != null,\r\n 'selectable_cell' : options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection\r\n }\"\r\n (click)=\"options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection && onSelectCell(rowData[col.id])\"\n pFrozenColumn\n [frozen]=\"col.frozen\">\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\n @if (rowData[col.id] != null) {\n <p-toggleswitch\n [(ngModel)]=\"rowData[col.id].value\"\n [disabled]=\"rowData.readonly || rowData[col.id]?.readonly || (getOption(col, rowData, 'action') == null && !isModeEdition())\"\n (onChange)=\"onEditCell(rowData, col, rowData[col.id].value)\"\n ngDefaultControl>\n </p-toggleswitch>\n }\n </td>\n }\n <!-- File -->\n @if (!col.invisible && checkType('File', col) && isModeEdition() && !rowData.readonly && !rowData[col.id]?.readonly) {\n <td\n [ngStyle]=\"{ 'width' : col.width ? col.width : null, 'background-color': rowData[col.id].color ? rowData[col.id].color : null }\"\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\n [ngClass]=\"{\r\n 'paddingCell': rowData[col.id] != null,\r\n 'selectable_cell' : options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection\r\n }\"\r\n (click)=\"options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection && onSelectCell(rowData[col.id])\"\n pFrozenColumn\n [frozen]=\"col.frozen\">\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\n @if (rowData[col.id] != null) {\n <div class=\"p-inputgroup\">\n <button type=\"button\"\n pButton\n pRipple\n icon=\"pi pi-upload\"\n (click)=\"clickById('input_' + rowData[col.id].id)\"\n [disabled]=\"rowData.readonly || rowData[col.id]?.readonly || !isModeEdition()\">\n </button>\n <input id=\"{{'output_' + rowData[col.id].id}}\"\n pInputText\n type=\"text\"\n [ngClass]=\"{\r\n 'text-left': col.position == 'left' || col.position == null,\r\n 'text-right': col.position == 'right',\r\n 'text-center': col.position == 'center',\r\n 'font-bold': rowData.bold == true || rowData[col.id].bold == true,\r\n 'font-italic': rowData.italic == true || rowData[col.id].italic == true\r\n }\"\r\n value=\"{{ rowData[col.id].value != null ? rowData[col.id].value : '' }}\"\n readonly\n [pTooltip]=\"rowData[col.id].tooltip != null ? rowData[col.id].tooltip : rowData[col.id].value ? rowData[col.id].value : ''\"\n [tooltipDisabled]=\"!col.tooltip\">\n @if (getOption(col, rowData, 'downloadPath') && rowData[col.id].value != null) {\n <button\n type=\"button\"\n pButton\n pRipple\n icon=\"pi pi-download\"\n (click)=\"downloadFile(rowData[col.id])\"\n [disabled]=\"rowData.readonly || rowData[col.id]?.readonly || !isModeEdition()\">\n </button>\n }\n </div>\n }\n @if (rowData[col.id]) {\n <input id=\"{{'input_' + rowData[col.id].id}}\" #inputFile pInputText type=\"file\" hidden (change)=\"rowData[col.id].value = inputFile.files[0].name; onEditCell(rowData, col, inputFile.files[0])\">\n }\n </td>\n }\n @if (!col.invisible && checkType('File', col) && (rowData.readonly || rowData[col.id]?.readonly || !isModeEdition())) {\n <td\n [ngStyle]=\"{\r\n 'width' : col.width ? col.width : null,\r\n 'background-color': rowData[col.id].color ? rowData[col.id].color : null,\r\n 'color' : rowData[col.id].textColor ? rowData[col.id].textColor : null\r\n }\"\r\n (click)=\"options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection && onSelectCell(rowData[col.id])\"\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\n [pTooltip]=\"rowData[col.id].tooltip != null ? rowData[col.id].tooltip : rowData[col.id].value ? rowData[col.id].value : ''\"\n [ngClass]=\"{\r\n 'paddingCell': rowData[col.id] != null,\r\n 'text-left': col.position == 'left' || col.position == null,\r\n 'text-right': col.position == 'right',\r\n 'text-center': col.position == 'center',\r\n 'font-bold': rowData.bold == true || rowData[col.id].bold == true,\r\n 'font-italic': rowData.italic == true || rowData[col.id].italic == true,\r\n 'selectable_cell' : options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection\r\n }\"\r\n [tooltipDisabled]=\"!col.tooltip\"\n tooltipPosition=\"bottom\"\n pFrozenColumn\n [frozen]=\"col.frozen\">\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\n @if (rowData[col.id]) {\n <div>{{ rowData[col.id].value ? rowData[col.id].value : '' }}</div>\n }\n </td>\n }\n <!-- State -->\n @if (!col.invisible && checkType('State', col)) {\n <td\n [ngStyle]=\"{ 'width' : col.width ? col.width : null, 'background-color': rowData[col.id].color ? rowData[col.id].color : null }\"\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\n [ngClass]=\"{\r\n 'paddingCell': rowData[col.id] != null,\r\n 'selectable_cell' : options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection\r\n }\"\r\n (click)=\"options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection && onSelectCell(rowData[col.id])\"\n class=\"text-center\"\n pFrozenColumn\n [frozen]=\"col.frozen\">\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\n @if (rowData[col.id].value != null) {\n <p-tag\n [value]=\"rowData[col.id].value[getOption(col, rowData, 'optionLabel')]\"\n [severity]=\"rowData[col.id].value.severity\"\n [icon]=\"rowData[col.id].value.icon\"\n [style]=\"{\r\n 'background-color': rowData[col.id].value.backgroundColor,\r\n 'color': rowData[col.id].value.textColor,\r\n 'font-weight': rowData.bold == true || rowData[col.id].bold == true ? 'bold' : null,\r\n 'font-style': rowData.italic == true || rowData[col.id].italic == true ? 'italic' : null\r\n }\">\r\n </p-tag>\n }\n </td>\n }\n }\n\n <!-- Deletion -->\n @if (options.rowsDeletable) {\n <td\n class=\"cellDelete\"\n [ngClass]=\"rowData.deletable ? 'paddingCell' : null\">\n @if (rowData.deletable) {\n <button\n pButton\n type=\"button\"\n icon=\"pi pi-times\"\n class=\"p-button-danger buttonDelete p-button-text\"\n [disabled]=\"rowData.readonly\"\n (click)=\"onDeleteLine(rowData)\">\n </button>\n }\n </td>\n }\n\n </tr>\n </ng-template>\n </p-table>\n </div>\n", styles: ["::ng-deep .p-tooltip .p-tooltip-text{overflow-wrap:break-word!important}:host ::ng-deep .grid_brown .rowHeader>th{background-color:#795548}:host ::ng-deep .grid_brown .rowHeader>th div{color:#fff}:host ::ng-deep .grid_brown .rowHeader>th i{color:#fff}:host ::ng-deep .grid_brown .rowHeader .p-sortable-column:hover{background-color:#a47767}:host ::ng-deep .grid_brown .rowHeader .p-sortable-column:hover i{color:#fff}:host ::ng-deep .grid_brown .rowHeader .p-sortable-column.p-highlight div{color:#76c7ff}:host ::ng-deep .grid_brown .rowHeader .p-sortable-column.p-highlight .p-sortable-column-icon{color:#76c7ff}:host ::ng-deep .grid_brown .rowFilter th{background-color:#795548}:host ::ng-deep .grid_grey .rowHeader>th{background-color:#dedddd}:host ::ng-deep .grid_grey .rowHeader>th div{color:#495057}:host ::ng-deep .grid_grey .rowHeader>th i{color:#495057}:host ::ng-deep .grid_grey .rowHeader .p-sortable-column:hover{background-color:#e7e7e7}:host ::ng-deep .grid_grey .rowHeader .p-sortable-column:hover i{color:#495057}:host ::ng-deep .grid_grey .rowHeader .p-sortable-column.p-highlight div{color:#008bff}:host ::ng-deep .grid_grey .rowHeader .p-sortable-column.p-highlight .p-sortable-column-icon{color:#008bff}:host ::ng-deep .grid_grey .rowFilter th{background-color:#dedddd}:host ::ng-deep .selectable_cell:hover{background:#dcdcdc!important;cursor:pointer!important}:host ::ng-deep .p-frozen-column{z-index:2!important}:host ::ng-deep .p-datatable-thead{z-index:3!important}:host ::ng-deep .p-checkbox{border-radius:inherit!important}:host ::ng-deep p-inputnumber{width:100%}:host ::ng-deep .p-calendar,:host ::ng-deep .p-inputtext,:host ::ng-deep .p-inputnumber,:host ::ng-deep .p-inputnumber-input,:host ::ng-deep .p-dropdown,:host ::ng-deep .p-multiselect{width:100%}:host ::ng-deep .suffixe,:host ::ng-deep .prefixe{height:25px;padding-top:1px!important}:host ::ng-deep .p-multiselect-label-container,:host ::ng-deep .p-dropdown-label{width:1px!important}:host ::ng-deep .p-scroller-content{min-height:50%}:host ::ng-deep .rowTotal>th{background-color:#edcbaa!important}:host ::ng-deep .rowGrouping{background:#faeada!important}:host ::ng-deep .p-inputswitch.p-inputswitch-checked .p-inputswitch-slider{background:#30e130}:host ::ng-deep .p-inputswitch.p-inputswitch-checked:not(.p-disabled):hover .p-inputswitch-slider{background:#2bd12b}:host ::ng-deep .p-datatable-table{table-layout:fixed}:host ::ng-deep .p-datatable-thead>tr>th{border:1px solid rgba(0,0,0,.12)!important;padding:8px;font-weight:600;height:40px}:host ::ng-deep .headerAffichageSimple div{overflow:hidden;white-space:nowrap;text-overflow:ellipsis}:host ::ng-deep .headerAffichageEntier{word-wrap:break-word}:host ::ng-deep .p-datatable-tbody>tr>td{border:1px solid rgba(0,0,0,.12)!important;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}:host ::ng-deep .p-datatable-tbody>tr>td div{overflow:hidden;white-space:nowrap;text-overflow:ellipsis}:host ::ng-deep .p-tag{max-width:100%}:host ::ng-deep .p-tag .p-tag-value{overflow:hidden;white-space:nowrap;text-overflow:ellipsis}:host ::ng-deep .p-button{padding:5px;max-width:100%}:host ::ng-deep .p-button .p-button-label{overflow:hidden!important;white-space:nowrap!important;text-overflow:ellipsis!important}:host ::ng-deep .text_bold{font-weight:700!important}:host ::ng-deep .cellDelete{flex:0 0 50px!important;width:50px;text-align:center!important;padding:0!important}:host ::ng-deep .p-tooltip .p-tooltip-text{background-color:red!important}:host ::ng-deep .p-skeleton{background-color:#dee2e6;border-radius:6px;padding:0}:host ::ng-deep .p-datatable-tbody>tr{height:35px}:host ::ng-deep .p-inputtext{height:25px!important;padding:4px 5px!important}:host ::ng-deep .p-inputnumber{height:25px;padding:0!important}:host ::ng-deep .p-inputnumber-input{padding:0 5px!important}:host ::ng-deep .p-inputgroup .p-inputtext{height:25px;padding:4px 5px!important}:host ::ng-deep .p-dropdown,:host ::ng-deep .p-multiselect{vertical-align:middle}:host ::ng-deep .p-dropdown-label{padding-top:2px;padding-bottom:2px}:host ::ng-deep .p-multiselect-label{padding-top:2px;padding-bottom:2px}:host ::ng-deep .p-editable-column{padding:3px 10px!important}:host ::ng-deep .paddingCell{padding:3px 10px!important}:host ::ng-deep .p-selectbutton>.p-button{width:50%;height:25px}:host ::ng-deep .p-inputgroup>.p-button{height:25px}:host ::ng-deep .buttonDelete{width:100%;height:20px}:host ::ng-deep .p-column-title{display:none}:host ::ng-deep .p-datatable-loading-icon{color:#fff}\n"] }]
1297
+ args: [{ selector: 'cilog-table', imports: [
1298
+ CommonModule,
1299
+ FormsModule,
1300
+ ValuePipe,
1301
+ TagModule,
1302
+ TableModule,
1303
+ ContextMenuModule,
1304
+ TooltipModule,
1305
+ MultiSelectModule,
1306
+ DatePickerModule,
1307
+ SelectModule,
1308
+ CilogInputNumberComponent,
1309
+ SelectButtonModule,
1310
+ ButtonModule,
1311
+ InputTextModule,
1312
+ InputNumberModule
1313
+ ], template: "<div [ngStyle]=\"{ 'height': options.scrollHeight != null ? options.scrollHeight : '100%' }\">\n\n @if (options.exportExcel) {\n <button pButton\n icon=\"pi pi-file-excel\"\n class=\"p-button-success absolute z-5 w-2rem h-2rem border-round-right border-noround-top\"\n pTooltip=\"Exporter le contenu de la grille au format Excel\"\n tooltipPosition=\"right\"\n (click)=\"exportExcel(options.exportExcelByFiltre, !options.exportExcelNoColors)\">\n </button>\n }\n\n <p-contextMenu #cm [model]=\"options.contextMenuItems\" />\n\n <p-table #table\n [columns]=\"columns\"\n [value]=\"values\"\n dataKey=\"id\"\n [selectionMode]=\"getModeSelection()\"\n [metaKeySelection]=\"isModeMetakeySelection()\"\n [(selection)]=\"selectedRows\"\n (onRowSelect)=\"onSelectRow($event)\"\n (onRowUnselect)=\"onUnselectRow($event)\"\n (onHeaderCheckboxToggle)=\"onSelectAll($event)\"\n (sortFunction)=\"sortGrille($event)\"\n [customSort]=\"options.grouping == null ? true : false\"\n [scrollable]=\"true\"\n [loading]=\"loading\"\n [scrollHeight]=\"'flex'\"\n [rowGroupMode]=\"options.grouping != null ? 'subheader' : null\"\n [groupRowsBy]=\"options.grouping != null ? options.grouping.obj + '.' + options.grouping.id : null\"\n [groupRowsByOrder]=\"0\"\n [virtualScroll]=\"options.virtualScroll == true && options.scrollHeight != null ? true : false\"\n [virtualScrollItemSize]=\"options.virtualScrollItemSize != null ? options.virtualScrollItemSize : 35\"\n [paginator]=\"options.paginator == null ? false : true\"\n [rows]=\"options.paginatorRows\"\n (onPage)=\"onPageTable($event)\"\n [tableStyleClass]=\"!options.themeGrille ? 'grid_grey' : options.themeGrille\"\n [lazy]=\"options.lazy == true ? true : false\"\n (onFilter)=\"onFilterTable($event)\"\n [rowTrackBy]=\"trackByFunction\"\n [(contextMenuSelection)]=\"contextMenuSelectedItem\"\n [contextMenu]=\"cm\">\n\n <!-- HEADER -->\n <ng-template pTemplate=\"header\" let-columns>\n\n <!-- HEADERS -->\n <tr class=\"rowHeader\">\n @if (isModeCheckboxSelection()) {\n <th class=\"cellDelete\"\n pFrozenColumn>\n @if (!options.filterable && options.toggleAll) {\n <p-tableHeaderCheckbox></p-tableHeaderCheckbox>\n }\n </th>\n }\n @for (col of columns; track col) {\n @if (!col.invisible) {\n <th [ngStyle]=\"{ 'width' : col.width ? col.width : null, 'background-color': col.backgroundColor ? col.backgroundColor : null }\"\n [ngClass]=\"{ 'text-center' : options.centerHeaders, 'headerAffichageSimple': !options.headersAffichageEntier, 'headerAffichageEntier': options.headersAffichageEntier }\"\n [pSortableColumn]=\"col.id\"\n [pSortableColumnDisabled]=\"!options.sortable || options.grouping != null || col.libelle == null || col.libelle == ''\"\n id=\"{{ col.id }}\"\n (click)=\"refreshData()\"\n pFrozenColumn\n [frozen]=\"col.frozen\"\n [pTooltip]=\"col.libelle\"\n [tooltipDisabled]=\"!col.tooltipHeader\"\n tooltipPosition=\"bottom\">\n <div [ngStyle]=\"{ 'color': col.textColor ? col.textColor : null }\">\n {{ col.libelle }}\n </div>\n @if (options.sortable && options.grouping == null && col.libelle != null && col.libelle != '') {\n <p-sortIcon [field]=\"col.id\">\n </p-sortIcon>\n }\n </th>\n }\n }\n @if (options.rowsDeletable) {\n <th class=\"cellDelete\"></th>\n }\n </tr>\n\n <!-- FILTRES -->\n @if (options.filterable) {\n <tr class=\"rowFilter\">\n @if (isModeCheckboxSelection()) {\n <th class=\"cellDelete\"\n pFrozenColumn>\n @if (options.toggleAll) {\n <p-tableHeaderCheckbox></p-tableHeaderCheckbox>\n }\n </th>\n }\n @for (col of columns; track col) {\n <!-- Text -->\n @if (!col.invisible && ((checkType('Dropdown', col) && col.options.filterText)\n || (checkType('MultiSelect', col) && col.options.filterText)\n || checkType('Text', col)\n || checkType('File', col)\n || (checkType('Button', col) && col.options.filterCol))\n || checkType('Number', col)\n || checkType('CilogNumber', col)) {\n <th [ngStyle]=\"{ 'width' : col.width ? col.width : null }\"\n pFrozenColumn\n [frozen]=\"col.frozen\">\n @if (!col.disableFilter) {\n <input pInputText\n type=\"text\"\n (input)=\"onFilterCol($event, col)\"\n name=\"filterText\"\n [(ngModel)]=\"col.options.defaultFilters\">\n }\n </th>\n }\n <!-- Date -->\n @if (!col.invisible && checkType('Date', col)) {\n <th [ngStyle]=\"{ 'width' : col.width ? col.width : null }\"\n pFrozenColumn\n [frozen]=\"col.frozen\">\n @if (!col.disableFilter) {\n <p-datepicker [view]=\"col.options.mode == null ? 'date' : col.options.mode\"\n [dateFormat]=\"col.options.mode == 'year' ? 'yy' : col.options.mode == 'month' ? 'mm/yy' : 'dd/mm/yy'\"\n [inputId]=\"col.id + '_filter'\"\n [firstDayOfWeek]=\"1\"\n [readonlyInput]=\"true\"\n appendTo=\"body\"\n selectionMode=\"range\"\n (onSelect)=\"onFilterCol($event, col)\"\n showButtonBar=\"true\"\n (onClearClick)=\"onFilterCol($event, col)\"\n name=\"filterDate\"\n [(ngModel)]=\"col.options.defaultFilters\">\n </p-datepicker>\n }\n </th>\n }\n <!-- Liste -->\n @if (!col.invisible && ((checkType('Dropdown', col) && !col.options.filterText) || (checkType('MultiSelect', col) && !col.options.filterText) || checkType('SelectButton', col) || checkType('State', col))) {\n <th [ngStyle]=\"{ 'width' : col.width ? col.width : null }\"\n pFrozenColumn\n [frozen]=\"col.frozen\">\n @if (!col.disableFilter) {\n <p-multiSelect [options]=\"col.options?.options\"\n [filter]=\"true\"\n dataKey=\"ID\"\n [optionLabel]=\"col.options?.optionLabel\"\n appendTo=\"body\"\n emptyFilterMessage=\"Aucun r\u00E9sultat\"\n emptyMessage=\"Aucun r\u00E9sultat\"\n [virtualScroll]=\"true\"\n [virtualScrollItemSize]=\"35\"\n selectedItemsLabel=\"{0} selectionn\u00E9s\"\n (onChange)=\"onFilterCol($event, col)\"\n name=\"filterChoix\"\n [(ngModel)]=\"col.options.defaultFilters\"\n [group]=\"col.options.optionGroupChildren != null ? true : false\"\n [optionGroupLabel]=\"col.options.optionGroupLabel\"\n [optionGroupChildren]=\"col.options.optionGroupChildren\"\n [showToggleAll]=\"false\"\n [showClear]=\"true\"\n (onClear)=\"onFilterCol(null, col)\">\n <ng-template let-group pTemplate=\"group\">\n <div>{{group[col.options.optionGroupLabel]}}</div>\n </ng-template>\n </p-multiSelect>\n }\n </th>\n }\n <!-- Switch -->\n @if (!col.invisible && checkType('Switch', col)) {\n <th [ngStyle]=\"{ 'width' : col.width ? col.width : null }\"\n pFrozenColumn\n [frozen]=\"col.frozen\">\n @if (!col.disableFilter) {\n <p-multiSelect [options]=\"optionsSwitch\"\n [showHeader]=\"false\"\n optionLabel=\"label\"\n optionValue=\"value\"\n appendTo=\"body\"\n emptyFilterMessage=\"Aucun r\u00E9sultat\"\n emptyMessage=\"Aucun r\u00E9sultat\"\n [virtualScrollItemSize]=\"30\"\n selectedItemsLabel=\"{0} selectionn\u00E9s\"\n (onChange)=\"onFilterCol($event, col)\"\n name=\"filterChoix2\"\n [(ngModel)]=\"col.options.defaultFilters\">\n </p-multiSelect>\n }\n </th>\n }\n <!-- Non filtrable -->\n @if (!col.invisible && (checkType('Image', col) || (checkType('Button', col) && !col.options.filterCol))) {\n <th [ngStyle]=\"{ 'width' : col.width ? col.width : null }\"\n pFrozenColumn\n [frozen]=\"col.frozen\">\n </th>\n }\n }\n @if (options.rowsDeletable) {\n <th class=\"cellDelete\"></th>\n }\n </tr>\n }\n\n <!-- TOTAL -->\n @if (options.rowTotal) {\n <tr class=\"rowTotal\">\n @if (isModeCheckboxSelection()) {\n <th class=\"cellDelete\"\n pFrozenColumn>\n </th>\n }\n @for (col of columns; track col) {\n @if (!col.invisible) {\n <th [ngStyle]=\"{ 'width' : col.width ? col.width : null }\"\n [ngClass]=\"{ 'text-center' : true }\"\n pFrozenColumn\n [frozen]=\"col.frozen\">\n <div>{{ getTotalStr(col) }}</div>\n </th>\n }\n }\n @if (options.rowsDeletable) {\n <th class=\"cellDelete\"></th>\n }\n </tr>\n }\n </ng-template>\n\n <!--Groupheader-->\n <ng-template pTemplate=\"groupheader\" let-rowData>\n <tr pRowGroupHeader class=\"rowGrouping\">\n <td [attr.colspan]=\"columns.length\">\n <div class=\"text_bold\">{{ rowData[options.grouping.obj][options.grouping.libelle] }}</div>\n </td>\n </tr>\n </ng-template>\n\n <!-- Body -->\n <ng-template pTemplate=\"body\" let-rowData let-columns=\"columns\">\n <tr id=\"{{ rowData.id }}\"\n [ngStyle]=\"{ 'background-color': rowData.color ? rowData.color : null }\"\n [pSelectableRow]=\"rowData\"\n [pSelectableRowDisabled]=\"!options.selectable || isModeCheckboxSelection() || isModeCellSelection()\"\n (dblclick)=\"onRowDoubleClickEvent(rowData)\"\n [pContextMenuRow]=\"rowData\"\n [pContextMenuRowDisabled]=\"options.contextMenuItems == null\">\n\n @if (isModeCheckboxSelection()) {\n <td class=\"cellDelete\"\n pFrozenColumn>\n <p-tableCheckbox [value]=\"rowData\" [disabled]=\"rowData.readonly\"></p-tableCheckbox>\n </td>\n }\n\n @for (col of columns; track col) {\n <!-- Text -->\n @if (!col.invisible && checkType('Text', col) && isModeEdition() && !rowData.readonly && !rowData[col.id]?.readonly) {\n <td [ngStyle]=\"{ 'width' : col.width ? col.width : null, 'background-color': rowData[col.id].color ? rowData[col.id].color : null }\"\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\n [pEditableColumn]=\"rowData\"\n [pEditableColumnField]=\"col.id\"\n [pTooltip]=\"rowData[col.id].tooltip != null ? rowData[col.id].tooltip : rowData[col.id].value\"\n [tooltipDisabled]=\"!col.tooltip\"\n tooltipPosition=\"bottom\"\n pFrozenColumn\n (click)=\"options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection && !rowData[col.id].disableSelection && onSelectCell(rowData[col.id])\"\n [frozen]=\"col.frozen\"\n [ngClass]=\"{\n 'text-left': col.position == 'left' || col.position == null,\n 'text-right': col.position == 'right',\n 'text-center': col.position == 'center',\n 'font-bold': rowData.bold == true || rowData[col.id].bold == true,\n 'font-italic': rowData.italic == true || rowData[col.id].italic == true,\n 'selectable_cell' : options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection\n }\">\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\n <p-cellEditor>\n <ng-template pTemplate=\"input\">\n <input pInputText\n type=\"text\"\n [(ngModel)]=\"rowData[col.id].value\"\n name=\"text\"\n (blur)=\"onEditCell(rowData, col, rowData[col.id].value)\"\n (keydown.enter)=\"onEditCell(rowData, col, rowData[col.id].value)\"\n (keydown.tab)=\"onEditCell(rowData, col, rowData[col.id].value)\"\n (click)=\"onEditInitCell(rowData, col, rowData[col.id].value)\"\n [ngClass]=\"{\n 'text-left': col.position == 'left' || col.position == null,\n 'text-right': col.position == 'right',\n 'text-center': col.position == 'center',\n 'font-bold': rowData.bold == true || rowData[col.id].bold == true,\n 'font-italic': rowData.italic == true || rowData[col.id].italic == true\n }\" />\n </ng-template>\n <ng-template pTemplate=\"output\">\n @if (rowData[col.id]) {\n <div style=\"white-space: pre;\">\n {{ getFormattedText(col, rowData) }}\n </div>\n }\n </ng-template>\n </p-cellEditor>\n </td>\n }\n @if (!col.invisible && checkType('Text', col) && (!isModeEdition() || rowData.readonly || rowData[col.id]?.readonly)) {\n <td [ngStyle]=\"{\n 'width' : col.width ? col.width : null,\n 'background-color' : rowData[col.id].color ? rowData[col.id].color : null,\n 'color' : rowData[col.id].textColor ? rowData[col.id].textColor : null\n }\"\n (click)=\"options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection && !rowData[col.id].disableSelection && onSelectCell(rowData[col.id])\"\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\n [pTooltip]=\"rowData[col.id].tooltip != null ? rowData[col.id].tooltip : rowData[col.id].value\"\n [tooltipDisabled]=\"!col.tooltip\"\n tooltipPosition=\"bottom\"\n [ngClass]=\"{\n 'paddingCell': rowData[col.id] != null,\n 'text-left': col.position == 'left' || col.position == null,\n 'text-right': col.position == 'right',\n 'text-center': col.position == 'center',\n 'font-bold': rowData.bold == true || rowData[col.id].bold == true,\n 'font-italic': rowData.italic == true || rowData[col.id].italic == true,\n 'selectable_cell' : options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection\n }\"\n pFrozenColumn\n [frozen]=\"col.frozen\">\n <div class=\"p-column-title\">\n {{ col.libelle }} :\n </div>\n @if (rowData[col.id]) {\n <div style=\"white-space: pre;\">\n {{ getFormattedText(col, rowData) }}\n </div>\n }\n </td>\n }\n <!-- Dropdown -->\n @if (!col.invisible && checkType('Dropdown', col) && isModeEdition() && !rowData.readonly && !rowData[col.id]?.readonly) {\n <td [ngStyle]=\"{ 'width' : col.width ? col.width : null, 'background-color': rowData[col.id].color ? rowData[col.id].color : null }\"\n [ngClass]=\"{\n 'text-left': col.position == 'left' || col.position == null,\n 'text-right': col.position == 'right',\n 'text-center': col.position == 'center',\n 'selectable_cell' : options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection\n }\"\n (click)=\"options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection && onSelectCell(rowData[col.id])\"\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\n [pTooltip]=\"rowData[col.id].tooltip != null ? rowData[col.id].tooltip : rowData[col.id].value != null ? rowData[col.id].value[getOption(col, rowData, 'optionLabel')] : ''\"\n [tooltipDisabled]=\"!col.tooltip\"\n tooltipPosition=\"bottom\"\n pFrozenColumn\n [frozen]=\"col.frozen\"\n class=\"paddingCell\">\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\n @if (rowData[col.id] != null) {\n <p-select dataKey=\"ID\"\n [options]=\"getOption(col, rowData, 'options')\"\n [filter]=\"getOption(col, rowData, 'filter')\"\n [optionLabel]=\"getOption(col, rowData, 'optionLabel')\"\n [(ngModel)]=\"rowData[col.id].value\"\n name=\"select\"\n appendTo=\"body\"\n [showClear]=\"getOption(col, rowData, 'deletable')\"\n emptyFilterMessage=\"Aucun r\u00E9sultat\"\n emptyMessage=\"Aucun r\u00E9sultat\"\n [virtualScroll]=\"getOption(col, rowData, 'virtualScroll')\"\n [readonly]=\"rowData.readonly || rowData[col.id]?.readonly\"\n [virtualScrollItemSize]=\"30\"\n (onChange)=\"onEditCell(rowData, col, rowData[col.id].value)\"\n (onClear)=\"onEditCell(rowData, col, rowData[col.id].value)\">\n <ng-template let-data pTemplate=\"selectedItem\">\n @if (data != null) {\n <span [ngClass]=\"{\n 'font-bold': rowData.bold == true || rowData[col.id].bold == true,\n 'font-italic': rowData.italic == true || rowData[col.id].italic == true\n }\">\n {{ data[getOption(col, rowData, 'optionLabel')] }}\n </span>\n }\n @if (data == null) {\n <span></span>\n }\n </ng-template>\n </p-select>\n }\n </td>\n }\n @if (!col.invisible && checkType('Dropdown', col) && (rowData.readonly || rowData[col.id]?.readonly || !isModeEdition())) {\n <td [ngStyle]=\"{\n 'width' : col.width ? col.width : null,\n 'background-color': rowData[col.id].color ? rowData[col.id].color : null,\n 'color' : rowData[col.id].textColor ? rowData[col.id].textColor : null\n }\"\n (click)=\"options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection && onSelectCell(rowData[col.id])\"\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\n [pTooltip]=\"rowData[col.id].tooltip != null ? rowData[col.id].tooltip : rowData[col.id].value != null ? rowData[col.id].value[getOption(col, rowData, 'optionLabel')] : ''\"\n [tooltipDisabled]=\"!col.tooltip\"\n tooltipPosition=\"bottom\"\n [ngClass]=\"{\n 'paddingCell': rowData[col.id] != null,\n 'text-left': col.position == 'left' || col.position == null,\n 'text-right': col.position == 'right',\n 'text-center': col.position == 'center',\n 'font-bold': rowData.bold == true || rowData[col.id].bold == true,\n 'font-italic': rowData.italic == true || rowData[col.id].italic == true,\n 'selectable_cell' : options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection\n }\"\n pFrozenColumn\n [frozen]=\"col.frozen\">\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\n @if (rowData[col.id]) {\n <div>{{ rowData[col.id].value != null ? rowData[col.id].value[getOption(col, rowData, 'optionLabel')] : '' }}</div>\n }\n </td>\n }\n <!-- Cilog Number -->\n @if (!col.invisible && checkType('CilogNumber', col) && isModeEdition() && !rowData.readonly && !rowData[col.id]?.readonly) {\n <td [ngStyle]=\"{ 'width' : col.width ? col.width : null, 'background-color': rowData[col.id].color ? rowData[col.id].color : null }\"\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\n [ngClass]=\"{\n 'paddingCell': rowData[col.id] != null,\n 'selectable_cell' : options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection\n }\"\n (click)=\"options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection && onSelectCell(rowData[col.id])\"\n [pTooltip]=\"rowData[col.id].tooltip != null ? rowData[col.id].tooltip : rowData[col.id].value | value\"\n [tooltipDisabled]=\"!col.tooltip\"\n tooltipPosition=\"bottom\"\n pFrozenColumn\n [frozen]=\"col.frozen\">\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\n @if (rowData[col.id] && !rowData.readonly && !rowData[col.id]?.readonly) {\n <cilog-input-number (onInput)=\"onInputNumber($event)\"\n [(ngModel)]=\"rowData[col.id].value\"\n name=\"cilog-number\"\n ngDefaultControl\n [inputStyleClass]=\"col.position == null || col.position == 'right' ? 'text-right' : col.position == 'left' ? 'text-left' : 'text-center'\"\n [textColor]=\"rowData[col.id].textColor\"\n [bold]=\"rowData.bold == true || rowData[col.id].bold == true\"\n [italic]=\"rowData.italic == true || rowData[col.id].italic == true\"\n [suffixe]=\"getOption(col, rowData, 'suffix')\"\n [prefixe]=\"getOption(col, rowData, 'prefix') != null ? getOption(col, rowData, 'prefix') + ' ' : null\"\n [min]=\"getOption(col, rowData, 'min')\"\n [max]=\"getOption(col, rowData, 'max')\"\n [disabled]=\"rowData.readonly || rowData[col.id]?.readonly\"\n [maxDecimals]=\"getOption(col, rowData, 'modeInteger') != null && getOption(col, rowData, 'modeInteger') == true ? 0 : getOption(col, rowData, 'maxDecimales') != null ? getOption(col, rowData, 'maxDecimales') : 2 \"\n (onChange)=\"onEditCell(rowData, col, rowData[col.id].value)\"\n (onFocus)=\"onEditInitCell(rowData, col, rowData[col.id].value)\">\n </cilog-input-number>\n }\n </td>\n }\n @if (!col.invisible && checkType('CilogNumber', col) && (rowData.readonly || rowData[col.id]?.readonly || !isModeEdition())) {\n <td [ngStyle]=\"{\n 'width' : col.width ? col.width : null,\n 'background-color': rowData[col.id].color ? rowData[col.id].color : null,\n 'color' : rowData[col.id].textColor ? rowData[col.id].textColor : null\n }\"\n (click)=\"options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection && onSelectCell(rowData[col.id])\"\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\n [pTooltip]=\"rowData[col.id].tooltip != null ? rowData[col.id].tooltip : rowData[col.id].value | value\"\n [tooltipDisabled]=\"!col.tooltip\"\n tooltipPosition=\"bottom\"\n [ngClass]=\"{\n 'paddingCell': rowData[col.id] != null,\n 'text-left': col.position == 'left' || col.position == null,\n 'text-right': col.position == 'right',\n 'text-center': col.position == 'center',\n 'font-bold': rowData.bold == true || rowData[col.id].bold == true,\n 'font-italic': rowData.italic == true || rowData[col.id].italic == true,\n 'selectable_cell' : options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection\n }\"\n pFrozenColumn\n [frozen]=\"col.frozen\">\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\n @if (rowData[col.id]) {\n <div>{{ getFormattedNumber(col, rowData, rowData[col.id].value) }}</div>\n }\n </td>\n }\n <!-- Number -->\n @if (!col.invisible && checkType('Number', col) && isModeEdition() && !rowData.readonly && !rowData[col.id]?.readonly) {\n <td [ngStyle]=\"{ 'width' : col.width ? col.width : null, 'background-color': rowData[col.id].color ? rowData[col.id].color : null }\"\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\n [pTooltip]=\"rowData[col.id].tooltip != null ? rowData[col.id].tooltip : rowData[col.id].value | value\"\n [tooltipDisabled]=\"!col.tooltip\"\n [ngClass]=\"{\n 'paddingCell': rowData[col.id] != null,\n 'text-left': col.position == 'left',\n 'text-right': col.position == 'right' || col.position == null,\n 'text-center': col.position == 'center',\n 'font-bold': rowData.bold == true || rowData[col.id].bold == true,\n 'font-italic': rowData.italic == true || rowData[col.id].italic == true,\n 'selectable_cell' : options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection\n }\"\n tooltipPosition=\"bottom\"\n pFrozenColumn\n [frozen]=\"col.frozen\"\n (click)=\"onClickCellNumber(rowData, col)\">\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\n @if (rowData[col.id] && !rowData[col.id].focus) {\n <div>\n {{ getFormattedNumber(col, rowData, rowData[col.id].value) }}\n </div>\n }\n @if (rowData[col.id] && !rowData.readonly && !rowData[col.id]?.readonly && rowData[col.id].focus == true) {\n <p-inputNumber #inputNumber\n locale=\"fr-FR\"\n (onInput)=\"onInputNumber($event)\"\n [(ngModel)]=\"rowData[col.id].value\"\n name=\"input-number\"\n [showButtons]=\"getOption(col, rowData, 'showButtons')\"\n [inputStyleClass]=\"col.position == null || col.position == 'right' ? 'text-right' : col.position == 'left' ? 'text-left' : 'text-center'\"\n [inputStyle]=\"{ 'font-weight': rowData.bold == true || rowData[col.id].bold == true ? 'bold' : null, 'font-style': rowData.italic == true || rowData[col.id].italic == true ? 'italic' : null }\"\n [suffix]=\"getOption(col, rowData, 'suffix')\"\n [prefix]=\"getOption(col, rowData, 'prefix') != null ? getOption(col, rowData, 'prefix') + ' ' : null\"\n [min]=\"getOption(col, rowData, 'min')\"\n [max]=\"getOption(col, rowData, 'max')\"\n [minFractionDigits]=\"getOption(col, rowData, 'modeInteger') != null && getOption(col, rowData, 'modeInteger') == true ? 0 : getOption(col, rowData, 'minDecimales') != null ? getOption(col, rowData, 'minDecimales') : 0\"\n [maxFractionDigits]=\"getOption(col, rowData, 'modeInteger') != null && getOption(col, rowData, 'modeInteger') == true ? 0 : getOption(col, rowData, 'maxDecimales') != null ? getOption(col, rowData, 'maxDecimales') : 2 \"\n (onBlur)=\"onEditCell(rowData, col, rowData[col.id].value)\"\n (onKeyDown)=\"onKeyDown($event, rowData, col, rowData[col.id].value)\"\n (onFocus)=\"onEditInitCell(rowData, col, rowData[col.id].value)\">\n </p-inputNumber>\n }\n </td>\n }\n @if (!col.invisible && checkType('Number', col) && (rowData.readonly || rowData[col.id]?.readonly || !isModeEdition())) {\n <td [ngStyle]=\"{\n 'width' : col.width ? col.width : null,\n 'background-color': rowData[col.id].color ? rowData[col.id].color : null,\n 'color' : rowData[col.id].textColor ? rowData[col.id].textColor : null\n }\"\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\n [pTooltip]=\"rowData[col.id].tooltip != null ? rowData[col.id].tooltip : rowData[col.id].value | value\"\n [tooltipDisabled]=\"!col.tooltip\"\n tooltipPosition=\"bottom\"\n (click)=\"options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection && onSelectCell(rowData[col.id])\"\n [ngClass]=\"{\n 'paddingCell': rowData[col.id] != null,\n 'text-left': col.position == 'left',\n 'text-right': col.position == 'right' || col.position == null,\n 'text-center': col.position == 'center',\n 'font-bold': rowData.bold == true || rowData[col.id].bold == true,\n 'font-italic': rowData.italic == true || rowData[col.id].italic == true,\n 'selectable_cell' : options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection\n }\"\n pFrozenColumn\n [frozen]=\"col.frozen\">\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\n @if (rowData[col.id]) {\n <div>{{ getFormattedNumber(col, rowData, rowData[col.id].value) }}</div>\n }\n </td>\n }\n <!-- Date -->\n @if (!col.invisible && checkType('Date', col) && isModeEdition() && !rowData.readonly && !rowData[col.id]?.readonly) {\n <td [ngStyle]=\"{ 'width' : col.width ? col.width : null, 'background-color': rowData[col.id].color ? rowData[col.id].color : null }\"\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\n [ngClass]=\"{\n 'paddingCell': rowData[col.id] != null,\n 'selectable_cell' : options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection\n }\"\n (click)=\"options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection && onSelectCell(rowData[col.id])\"\n [pTooltip]=\"rowData[col.id].tooltip != null ? rowData[col.id].tooltip : getOption(col, rowData, 'mode') == 'year' ? (rowData[col.id].value | date: 'yyyy') : getOption(col, rowData, 'mode') == 'month' ? (rowData[col.id].value | date: 'MM/yy') : getOption(col, rowData, 'mode') == 'hour' ? (rowData[col.id].value | date: 'HH:mm') : getOption(col, rowData, 'mode') == 'datehour' ? (rowData[col.id].value | date: 'dd/MM/yy HH:mm') : (rowData[col.id].value | date: 'dd/MM/yyyy')\"\n [tooltipDisabled]=\"!col.tooltip\"\n tooltipPosition=\"bottom\"\n pFrozenColumn\n [frozen]=\"col.frozen\">\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\n <p-datepicker [(ngModel)]=\"rowData[col.id].value\"\n name=\"date-picker\"\n [view]=\"getOption(col, rowData, 'mode') == null || getOption(col, rowData, 'mode') == 'date' || getOption(col, rowData, 'mode') == 'hour' ? 'date' : getOption(col, rowData, 'mode') == 'datehour' ? 'date' : getOption(col, rowData, 'mode')\"\n [dateFormat]=\"getOption(col, rowData, 'mode') == 'year' ? 'yy' : getOption(col, rowData, 'mode') == 'month' ? 'mm/yy' : getOption(col, rowData, 'mode') == 'hour' || getOption(col, rowData, 'mode') == 'datehour' ? 'dd/mm/yy' : 'dd/mm/yy'\"\n [showTime]=\"getOption(col, rowData, 'mode') == 'datehour'\"\n [timeOnly]=\"getOption(col, rowData, 'mode') == 'hour'\"\n [hourFormat]=\"'24'\"\n [firstDayOfWeek]=\"1\"\n (onSelect)=\"onEditCell(rowData, col, rowData[col.id].value)\"\n (onBlur)=\"onEditCell(rowData, col, rowData[col.id].value)\"\n (onClear)=\"onEditCell(rowData, col, rowData[col.id].value)\"\n [inputStyleClass]=\"col.position == null || col.position == 'right' ? 'text-right' : col.position == 'left' ? 'text-left' : 'text-center'\"\n [inputStyle]=\"{ 'font-weight': rowData.bold == true || rowData[col.id].bold == true ? 'bold' : null, 'font-style': rowData.italic == true || rowData[col.id].italic == true ? 'italic' : null }\"\n [showClear]=\"getOption(col, rowData, 'clear')\"\n [minDate]=\"getOption(col, rowData, 'minDate')\"\n [maxDate]=\"getOption(col, rowData, 'maxDate')\"\n [defaultDate]=\"getOption(col, rowData, 'defaultDate')\"\n appendTo=\"body\">\n </p-datepicker>\n </td>\n }\n @if (!col.invisible && checkType('Date', col) && (rowData.readonly || rowData[col.id]?.readonly || !isModeEdition())) {\n <td [ngStyle]=\"{\n 'min-width' : col.width ? col.width : null,\n 'background-color': rowData[col.id].color ? rowData[col.id].color : null,\n 'color' : rowData[col.id].textColor ? rowData[col.id].textColor : null\n }\"\n (click)=\"options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection && onSelectCell(rowData[col.id])\"\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\n [pTooltip]=\"rowData[col.id].tooltip != null ? rowData[col.id].tooltip : rowData[col.id].value | date: 'dd/MM/yyyy'\"\n [tooltipDisabled]=\"!col.tooltip\"\n tooltipPosition=\"bottom\"\n [ngClass]=\"{\n 'paddingCell': rowData[col.id] != null,\n 'text-left': col.position == 'left' || col.position == null,\n 'text-right': col.position == 'right',\n 'text-center': col.position == 'center',\n 'font-bold': rowData.bold == true || rowData[col.id].bold == true,\n 'font-italic': rowData.italic == true || rowData[col.id].italic == true,\n 'selectable_cell' : options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection\n }\"\n pFrozenColumn\n [frozen]=\"col.frozen\">\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\n @if (rowData[col.id]) {\n <div>{{ rowData[col.id].value | date: (getOption(col, rowData, 'mode') == 'year' ? 'yyyy' : getOption(col, rowData, 'mode') == 'month' ? 'MM/yyyy' : 'dd/MM/yyyy') }}</div>\n }\n </td>\n }\n <!-- MultiSelect -->\n @if (!col.invisible && checkType('MultiSelect', col) && isModeEdition() && !rowData.readonly && !rowData[col.id]?.readonly) {\n <td [ngStyle]=\"{ 'width' : col.width ? col.width : null, 'background-color': rowData[col.id].color ? rowData[col.id].color : null }\"\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\n [ngClass]=\"{\n 'text-left': col.position == 'left' || col.position == null,\n 'text-right': col.position == 'right',\n 'text-center': col.position == 'center',\n 'selectable_cell' : options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection\n }\"\n (click)=\"options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection && onSelectCell(rowData[col.id])\"\n [pTooltip]=\"rowData[col.id].tooltip != null ? rowData[col.id].tooltip : getMultiSelectConcat(rowData[col.id].value, getOption(col, rowData, 'optionLabel'))\"\n [tooltipDisabled]=\"!col.tooltip\"\n tooltipPosition=\"bottom\"\n pFrozenColumn\n [frozen]=\"col.frozen\"\n class=\"paddingCell\">\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\n @if (rowData[col.id] != null) {\n <p-multiSelect [options]=\"getOption(col, rowData, 'options')\"\n [filter]=\"getOption(col, rowData, 'filter')\"\n [optionLabel]=\"getOption(col, rowData, 'optionLabel')\"\n [(ngModel)]=\"rowData[col.id].value\"\n name=\"multiselect\"\n appendTo=\"body\"\n dataKey=\"ID\"\n emptyFilterMessage=\"Aucun r\u00E9sultat\"\n emptyMessage=\"Aucun r\u00E9sultat\"\n [virtualScroll]=\"getOption(col, rowData, 'virtualScroll')\"\n [readonly]=\"rowData.readonly || rowData[col.id]?.readonly || !isModeEdition()\"\n [virtualScrollItemSize]=\"30\"\n selectedItemsLabel=\"{0} selectionn\u00E9s\"\n (onChange)=\"editMultiselect(rowData, col, $event)\"\n [showToggleAll]=\"false\"\n [showHeader]=\"getOption(col, rowData, 'filter')\"\n [group]=\"getOption(col, rowData, 'optionGroupChildren') != null ? true : false\"\n [optionGroupLabel]=\"getOption(col, rowData, 'optionGroupLabel')\"\n [optionGroupChildren]=\"getOption(col, rowData, 'optionGroupChildren')\"\n ngDefaultControl>\n <ng-template let-data pTemplate=\"selectedItems\">\n @for (option of data; track option; let i = $index) {\n <span [ngClass]=\"{\n 'font-bold': rowData.bold == true || rowData[col.id].bold == true,\n 'font-italic': rowData.italic == true || rowData[col.id].italic == true\n }\">\n {{ option[getOption(col, rowData, 'optionLabel')] + (i != data.length - 1 ? ',' : '') }}\n </span>\n }\n </ng-template>\n <ng-template let-group pTemplate=\"group\">\n <div>{{group[col.options.optionGroupLabel]}}</div>\n </ng-template>\n </p-multiSelect>\n }\n </td>\n }\n @if (!col.invisible && checkType('MultiSelect', col) && (rowData.readonly || rowData[col.id]?.readonly || !isModeEdition())) {\n <td [ngStyle]=\"{\n 'width' : col.width ? col.width : null,\n 'background-color': rowData[col.id].color ? rowData[col.id].color : null,\n 'color' : rowData[col.id].textColor ? rowData[col.id].textColor : null\n }\"\n (click)=\"options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection && onSelectCell(rowData[col.id])\"\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\n [pTooltip]=\"rowData[col.id].tooltip != null ? rowData[col.id].tooltip : getMultiSelectConcat(rowData[col.id].value, getOption(col, rowData, 'optionLabel'))\"\n [tooltipDisabled]=\"!col.tooltip\"\n tooltipPosition=\"bottom\"\n [ngClass]=\"{\n 'paddingCell': rowData[col.id] != null,\n 'text-left': col.position == 'left' || col.position == null,\n 'text-right': col.position == 'right',\n 'text-center': col.position == 'center',\n 'font-bold': rowData.bold == true || rowData[col.id].bold == true,\n 'font-italic': rowData.italic == true || rowData[col.id].italic == true,\n 'selectable_cell' : options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection\n }\"\n pFrozenColumn\n [frozen]=\"col.frozen\">\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\n @if (rowData[col.id]) {\n <div>{{ getMultiSelectConcat(rowData[col.id].value, getOption(col, rowData, 'optionLabel')) }}</div>\n }\n </td>\n }\n <!-- Image -->\n @if (!col.invisible && checkType('Image', col)) {\n <td [ngStyle]=\"{ 'width' : col.width ? col.width : null, 'background-color': rowData[col.id].color ? rowData[col.id].color : null }\"\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\n [ngClass]=\"{\n 'paddingCell': rowData[col.id] != null,\n 'selectable_cell' : options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection\n }\"\n (click)=\"options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection && onSelectCell(rowData[col.id])\"\n class=\"text-center\"\n pFrozenColumn\n [frozen]=\"col.frozen\">\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\n @if (rowData[col.id]) {\n <img style=\"vertical-align: middle; width: 40px;\" src=\"{{ rowData[col.id].value }}\" />\n }\n </td>\n }\n <!-- Button -->\n @if (!col.invisible && checkType('Button', col)) {\n <td class=\"paddingCell text-center\"\n [ngClass]=\"{\n 'selectable_cell' : options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection\n }\"\n (click)=\"options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection && onSelectCell(rowData[col.id])\"\n [ngStyle]=\"{ 'width' : col.width ? col.width : null, 'background-color': rowData[col.id].color ? rowData[col.id].color : null }\">\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\n @if (rowData[col.id].value != null && isValueButtonByType(rowData[col.id].value, 'function')) {\n <button pButton\n [disabled]=\"rowData.readonly || rowData[col.id]?.readonly\"\n [label]=\"getOption(col, rowData, 'label')\"\n [icon]=\"getOption(col, rowData, 'icon')\"\n (click)=\"rowData[col.id].value()\"\n [pTooltip]=\"rowData[col.id].tooltip != null ? rowData[col.id].tooltip : getOption(col, rowData, 'label')\"\n [tooltipDisabled]=\"!col.tooltip\"\n [class]=\"'p-button-' + getOption(col, rowData, 'severity')\"\n [ngClass]=\"{\n 'font-bold': rowData.bold == true || rowData[col.id].bold == true,\n 'font-italic': rowData.italic == true || rowData[col.id].italic == true\n }\">\n </button>\n }\n @if (isValueButtonByType(rowData[col.id].value, 'string')) {\n <div [ngClass]=\"{\n 'paddingCell': rowData[col.id] != null,\n 'text-left': col.position == 'left' || col.position == null,\n 'text-right': col.position == 'right',\n 'text-center': col.position == 'center',\n 'font-bold': rowData.bold == true || rowData[col.id].bold == true,\n 'font-italic': rowData.italic == true || rowData[col.id].italic == true\n }\"\n [pTooltip]=\"rowData[col.id].tooltip != null ? rowData[col.id].tooltip : rowData[col.id].value\"\n [tooltipDisabled]=\"!col.tooltip\">\n {{ rowData[col.id].value }}\n </div>\n }\n </td>\n }\n <!-- SelectButton -->\n @if (!col.invisible && checkType('SelectButton', col) && isModeEdition() && !rowData.readonly && !rowData[col.id]?.readonly) {\n <td [ngStyle]=\"{ 'width' : col.width ? col.width : null, 'background-color': rowData[col.id].color ? rowData[col.id].color : null }\"\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\n [ngClass]=\"{\n 'paddingCell': rowData[col.id] != null,\n 'selectable_cell' : options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection\n }\"\n (click)=\"options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection && onSelectCell(rowData[col.id])\"\n pFrozenColumn\n [frozen]=\"col.frozen\">\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\n @if (rowData[col.id] != null) {\n <p-selectButton [options]=\"getOption(col, rowData, 'options')\"\n [optionLabel]=\"getOption(col, rowData, 'optionLabel')\"\n [optionValue]=\"getOption(col, rowData, 'optionValue') != null ? getOption(col, rowData, 'optionValue') : 'value'\"\n [(ngModel)]=\"rowData[col.id].value\"\n name=\"select-button\"\n [disabled]=\"rowData.readonly || rowData[col.id]?.readonly || !isModeEdition()\"\n (onChange)=\"onEditCell(rowData, col, rowData[col.id].value)\">\n <ng-template let-item pTemplate=\"item\">\n <span class=\"text-center w-full\"\n [ngClass]=\"{\n 'font-bold': rowData.bold == true || rowData[col.id].bold == true,\n 'font-italic': rowData.italic == true || rowData[col.id].italic == true\n }\">\n {{ item.label }}\n </span>\n </ng-template>\n </p-selectButton>\n }\n </td>\n }\n @if (!col.invisible && checkType('SelectButton', col) && (rowData.readonly || rowData[col.id]?.readonly || !isModeEdition())) {\n <td [ngStyle]=\"{\n 'width' : col.width ? col.width : null,\n 'background-color': rowData[col.id].color ? rowData[col.id].color : null,\n 'color' : rowData[col.id].textColor ? rowData[col.id].textColor : null\n }\"\n (click)=\"options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection && onSelectCell(rowData[col.id])\"\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\n pFrozenColumn\n [frozen]=\"col.frozen\"\n class=\"text-center\"\n [ngClass]=\"{\n 'paddingCell': rowData[col.id] != null,\n 'font-bold': rowData.bold == true || rowData[col.id].bold == true,\n 'font-italic': rowData.italic == true || rowData[col.id].italic == true,\n 'selectable_cell' : options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection\n }\">\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\n @if (rowData[col.id]) {\n <div>{{ getSelectLibelleByValue(rowData, col) }}</div>\n }\n </td>\n }\n <!-- Switch -->\n @if (!col.invisible && checkType('Switch', col)) {\n <td [ngStyle]=\"{ 'width' : col.width ? col.width : null, 'background-color': rowData[col.id].color ? rowData[col.id].color : null }\"\n class=\"text-center\"\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\n [ngClass]=\"{\n 'paddingCell': rowData[col.id] != null,\n 'selectable_cell' : options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection\n }\"\n (click)=\"options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection && onSelectCell(rowData[col.id])\"\n pFrozenColumn\n [frozen]=\"col.frozen\">\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\n @if (rowData[col.id] != null) {\n <p-toggleswitch [(ngModel)]=\"rowData[col.id].value\"\n name=\"toggle-switch\"\n [disabled]=\"rowData.readonly || rowData[col.id]?.readonly || (getOption(col, rowData, 'action') == null && !isModeEdition())\"\n (onChange)=\"onEditCell(rowData, col, rowData[col.id].value)\"\n ngDefaultControl>\n </p-toggleswitch>\n }\n </td>\n }\n <!-- File -->\n @if (!col.invisible && checkType('File', col) && isModeEdition() && !rowData.readonly && !rowData[col.id]?.readonly) {\n <td [ngStyle]=\"{ 'width' : col.width ? col.width : null, 'background-color': rowData[col.id].color ? rowData[col.id].color : null }\"\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\n [ngClass]=\"{\n 'paddingCell': rowData[col.id] != null,\n 'selectable_cell' : options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection\n }\"\n (click)=\"options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection && onSelectCell(rowData[col.id])\"\n pFrozenColumn\n [frozen]=\"col.frozen\">\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\n @if (rowData[col.id] != null) {\n <div class=\"p-inputgroup\">\n <button type=\"button\"\n pButton\n pRipple\n icon=\"pi pi-upload\"\n (click)=\"clickById('input_' + rowData[col.id].id)\"\n [disabled]=\"rowData.readonly || rowData[col.id]?.readonly || !isModeEdition()\">\n </button>\n <input id=\"{{'output_' + rowData[col.id].id}}\"\n pInputText\n type=\"text\"\n [ngClass]=\"{\n 'text-left': col.position == 'left' || col.position == null,\n 'text-right': col.position == 'right',\n 'text-center': col.position == 'center',\n 'font-bold': rowData.bold == true || rowData[col.id].bold == true,\n 'font-italic': rowData.italic == true || rowData[col.id].italic == true\n }\"\n value=\"{{ rowData[col.id].value != null ? rowData[col.id].value : '' }}\"\n readonly\n [pTooltip]=\"rowData[col.id].tooltip != null ? rowData[col.id].tooltip : rowData[col.id].value ? rowData[col.id].value : ''\"\n [tooltipDisabled]=\"!col.tooltip\">\n @if (getOption(col, rowData, 'downloadPath') && rowData[col.id].value != null) {\n <button type=\"button\"\n pButton\n pRipple\n icon=\"pi pi-download\"\n (click)=\"downloadFile(rowData[col.id])\"\n [disabled]=\"rowData.readonly || rowData[col.id]?.readonly || !isModeEdition()\">\n </button>\n }\n </div>\n }\n @if (rowData[col.id]) {\n <input id=\"{{'input_' + rowData[col.id].id}}\" #inputFile pInputText type=\"file\" hidden (change)=\"rowData[col.id].value = inputFile.files[0].name; onEditCell(rowData, col, inputFile.files[0])\">\n }\n </td>\n }\n @if (!col.invisible && checkType('File', col) && (rowData.readonly || rowData[col.id]?.readonly || !isModeEdition())) {\n <td [ngStyle]=\"{\n 'width' : col.width ? col.width : null,\n 'background-color': rowData[col.id].color ? rowData[col.id].color : null,\n 'color' : rowData[col.id].textColor ? rowData[col.id].textColor : null\n }\"\n (click)=\"options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection && onSelectCell(rowData[col.id])\"\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\n [pTooltip]=\"rowData[col.id].tooltip != null ? rowData[col.id].tooltip : rowData[col.id].value ? rowData[col.id].value : ''\"\n [ngClass]=\"{\n 'paddingCell': rowData[col.id] != null,\n 'text-left': col.position == 'left' || col.position == null,\n 'text-right': col.position == 'right',\n 'text-center': col.position == 'center',\n 'font-bold': rowData.bold == true || rowData[col.id].bold == true,\n 'font-italic': rowData.italic == true || rowData[col.id].italic == true,\n 'selectable_cell' : options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection\n }\"\n [tooltipDisabled]=\"!col.tooltip\"\n tooltipPosition=\"bottom\"\n pFrozenColumn\n [frozen]=\"col.frozen\">\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\n @if (rowData[col.id]) {\n <div>{{ rowData[col.id].value ? rowData[col.id].value : '' }}</div>\n }\n </td>\n }\n <!-- State -->\n @if (!col.invisible && checkType('State', col)) {\n <td [ngStyle]=\"{ 'width' : col.width ? col.width : null, 'background-color': rowData[col.id].color ? rowData[col.id].color : null }\"\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\n [ngClass]=\"{\n 'paddingCell': rowData[col.id] != null,\n 'selectable_cell' : options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection\n }\"\n (click)=\"options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection && onSelectCell(rowData[col.id])\"\n class=\"text-center\"\n pFrozenColumn\n [frozen]=\"col.frozen\">\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\n @if (rowData[col.id].value != null) {\n <p-tag [value]=\"rowData[col.id].value[getOption(col, rowData, 'optionLabel')]\"\n [severity]=\"rowData[col.id].value.severity\"\n [icon]=\"rowData[col.id].value.icon\"\n [style]=\"{\n 'background-color': rowData[col.id].value.backgroundColor,\n 'color': rowData[col.id].value.textColor,\n 'font-weight': rowData.bold == true || rowData[col.id].bold == true ? 'bold' : null,\n 'font-style': rowData.italic == true || rowData[col.id].italic == true ? 'italic' : null\n }\">\n </p-tag>\n }\n </td>\n }\n }\n\n <!-- Deletion -->\n @if (options.rowsDeletable) {\n <td class=\"cellDelete\"\n [ngClass]=\"rowData.deletable ? 'paddingCell' : null\">\n @if (rowData.deletable) {\n <button pButton\n type=\"button\"\n icon=\"pi pi-times\"\n class=\"p-button-danger buttonDelete p-button-text\"\n [disabled]=\"rowData.readonly\"\n (click)=\"onDeleteLine(rowData)\">\n </button>\n }\n </td>\n }\n\n </tr>\n </ng-template>\n </p-table>\n</div>\n", styles: ["::ng-deep .p-tooltip .p-tooltip-text{overflow-wrap:break-word!important}:host ::ng-deep .grid_brown .rowHeader>th{background-color:#795548}:host ::ng-deep .grid_brown .rowHeader>th div{color:#fff}:host ::ng-deep .grid_brown .rowHeader>th i{color:#fff}:host ::ng-deep .grid_brown .rowHeader .p-sortable-column:hover{background-color:#a47767}:host ::ng-deep .grid_brown .rowHeader .p-sortable-column:hover i{color:#fff}:host ::ng-deep .grid_brown .rowHeader .p-sortable-column.p-highlight div{color:#76c7ff}:host ::ng-deep .grid_brown .rowHeader .p-sortable-column.p-highlight .p-sortable-column-icon{color:#76c7ff}:host ::ng-deep .grid_brown .rowFilter th{background-color:#795548}:host ::ng-deep .grid_grey .rowHeader>th{background-color:#dedddd}:host ::ng-deep .grid_grey .rowHeader>th div{color:#495057}:host ::ng-deep .grid_grey .rowHeader>th i{color:#495057}:host ::ng-deep .grid_grey .rowHeader .p-sortable-column:hover{background-color:#e7e7e7}:host ::ng-deep .grid_grey .rowHeader .p-sortable-column:hover i{color:#495057}:host ::ng-deep .grid_grey .rowHeader .p-sortable-column.p-highlight div{color:#008bff}:host ::ng-deep .grid_grey .rowHeader .p-sortable-column.p-highlight .p-sortable-column-icon{color:#008bff}:host ::ng-deep .grid_grey .rowFilter th{background-color:#dedddd}:host ::ng-deep .selectable_cell:hover{background:#dcdcdc!important;cursor:pointer!important}:host ::ng-deep .p-frozen-column{z-index:2!important}:host ::ng-deep .p-datatable-thead{z-index:3!important}:host ::ng-deep .p-checkbox{border-radius:inherit!important}:host ::ng-deep p-inputnumber{width:100%}:host ::ng-deep .p-calendar,:host ::ng-deep .p-inputtext,:host ::ng-deep .p-inputnumber,:host ::ng-deep .p-inputnumber-input,:host ::ng-deep .p-dropdown,:host ::ng-deep .p-multiselect{width:100%}:host ::ng-deep .suffixe,:host ::ng-deep .prefixe{height:25px;padding-top:1px!important}:host ::ng-deep .p-multiselect-label-container,:host ::ng-deep .p-dropdown-label{width:1px!important}:host ::ng-deep .p-scroller-content{min-height:50%}:host ::ng-deep .rowTotal>th{background-color:#edcbaa!important}:host ::ng-deep .rowGrouping{background:#faeada!important}:host ::ng-deep .p-inputswitch.p-inputswitch-checked .p-inputswitch-slider{background:#30e130}:host ::ng-deep .p-inputswitch.p-inputswitch-checked:not(.p-disabled):hover .p-inputswitch-slider{background:#2bd12b}:host ::ng-deep .p-datatable-table{table-layout:fixed}:host ::ng-deep .p-datatable-thead>tr>th{border:1px solid rgba(0,0,0,.12)!important;padding:8px;font-weight:600;height:40px}:host ::ng-deep .headerAffichageSimple div{overflow:hidden;white-space:nowrap;text-overflow:ellipsis}:host ::ng-deep .headerAffichageEntier{word-wrap:break-word}:host ::ng-deep .p-datatable-tbody>tr>td{border:1px solid rgba(0,0,0,.12)!important;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}:host ::ng-deep .p-datatable-tbody>tr>td div{overflow:hidden;white-space:nowrap;text-overflow:ellipsis}:host ::ng-deep .p-tag{max-width:100%}:host ::ng-deep .p-tag .p-tag-value{overflow:hidden;white-space:nowrap;text-overflow:ellipsis}:host ::ng-deep .p-button{padding:5px;max-width:100%}:host ::ng-deep .p-button .p-button-label{overflow:hidden!important;white-space:nowrap!important;text-overflow:ellipsis!important}:host ::ng-deep .text_bold{font-weight:700!important}:host ::ng-deep .cellDelete{flex:0 0 50px!important;width:50px;text-align:center!important;padding:0!important}:host ::ng-deep .p-tooltip .p-tooltip-text{background-color:red!important}:host ::ng-deep .p-skeleton{background-color:#dee2e6;border-radius:6px;padding:0}:host ::ng-deep .p-datatable-tbody>tr{height:35px}:host ::ng-deep .p-inputtext{height:25px!important;padding:4px 5px!important}:host ::ng-deep .p-inputnumber{height:25px;padding:0!important}:host ::ng-deep .p-inputnumber-input{padding:0 5px!important}:host ::ng-deep .p-inputgroup .p-inputtext{height:25px;padding:4px 5px!important}:host ::ng-deep .p-dropdown,:host ::ng-deep .p-multiselect{vertical-align:middle}:host ::ng-deep .p-dropdown-label{padding-top:2px;padding-bottom:2px}:host ::ng-deep .p-multiselect-label{padding-top:2px;padding-bottom:2px}:host ::ng-deep .p-editable-column{padding:3px 10px!important}:host ::ng-deep .paddingCell{padding:3px 10px!important}:host ::ng-deep .p-selectbutton>.p-button{width:50%;height:25px}:host ::ng-deep .p-inputgroup>.p-button{height:25px}:host ::ng-deep .buttonDelete{width:100%;height:20px}:host ::ng-deep .p-column-title{display:none}:host ::ng-deep .p-datatable-loading-icon{color:#fff}\n"] }]
1349
1314
  }], ctorParameters: () => [{ type: i1.ConfirmationService }, { type: i1.FilterService }, { type: i0.ChangeDetectorRef }, { type: ExportService }], propDecorators: { columns: [{
1350
1315
  type: Input
1351
1316
  }], columnsChange: [{
@@ -1389,23 +1354,12 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "21.0.6", ngImpor
1389
1354
  args: ['inputNumber']
1390
1355
  }] } });
1391
1356
 
1392
- class CilogTableService {
1393
- constructor() { }
1394
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "21.0.6", ngImport: i0, type: CilogTableService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
1395
- static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "21.0.6", ngImport: i0, type: CilogTableService, providedIn: 'root' }); }
1396
- }
1397
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "21.0.6", ngImport: i0, type: CilogTableService, decorators: [{
1398
- type: Injectable,
1399
- args: [{
1400
- providedIn: 'root'
1401
- }]
1402
- }], ctorParameters: () => [] });
1403
-
1404
1357
  class CilogEditorComponent {
1405
- constructor() {
1406
- this.textChange = new EventEmitter();
1407
- this.onTextChange = new EventEmitter();
1408
- }
1358
+ text;
1359
+ textChange = new EventEmitter();
1360
+ onTextChange = new EventEmitter();
1361
+ editor;
1362
+ constructor() { }
1409
1363
  ngOnInit() {
1410
1364
  }
1411
1365
  change(event) {
@@ -1415,12 +1369,14 @@ class CilogEditorComponent {
1415
1369
  onSelectionChange(event) {
1416
1370
  // NOTHING
1417
1371
  }
1418
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "21.0.6", ngImport: i0, type: CilogEditorComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
1419
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "21.0.6", type: CilogEditorComponent, isStandalone: false, selector: "cilog-editor", inputs: { text: "text" }, outputs: { textChange: "textChange", onTextChange: "onTextChange" }, viewQueries: [{ propertyName: "editor", first: true, predicate: ["editor"], descendants: true }], ngImport: i0, template: "<p-editor #editor\r\n [(ngModel)]=\"text\"\r\n (onTextChange)=\"change($event)\">\r\n</p-editor>\r\n", styles: [""], dependencies: [{ kind: "component", type: i1$1.Editor, selector: "p-editor", inputs: ["style", "styleClass", "placeholder", "formats", "modules", "bounds", "scrollingContainer", "debug", "readonly"], outputs: ["onInit", "onTextChange", "onSelectionChange", "onEditorChange", "onFocus", "onBlur"] }, { kind: "directive", type: i16.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i16.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }] }); }
1372
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "21.0.6", ngImport: i0, type: CilogEditorComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
1373
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "21.0.6", type: CilogEditorComponent, isStandalone: true, selector: "cilog-editor", inputs: { text: "text" }, outputs: { textChange: "textChange", onTextChange: "onTextChange" }, viewQueries: [{ propertyName: "editor", first: true, predicate: ["editor"], descendants: true }], ngImport: i0, template: "<p-editor #editor\r\n [(ngModel)]=\"text\"\r\n (onTextChange)=\"change($event)\">\r\n</p-editor>\r\n", styles: [""], dependencies: [{ kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i4.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i4.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }] });
1420
1374
  }
1421
1375
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "21.0.6", ngImport: i0, type: CilogEditorComponent, decorators: [{
1422
1376
  type: Component,
1423
- args: [{ selector: 'cilog-editor', standalone: false, template: "<p-editor #editor\r\n [(ngModel)]=\"text\"\r\n (onTextChange)=\"change($event)\">\r\n</p-editor>\r\n" }]
1377
+ args: [{ selector: 'cilog-editor', imports: [
1378
+ FormsModule
1379
+ ], template: "<p-editor #editor\r\n [(ngModel)]=\"text\"\r\n (onTextChange)=\"change($event)\">\r\n</p-editor>\r\n" }]
1424
1380
  }], ctorParameters: () => [], propDecorators: { text: [{
1425
1381
  type: Input
1426
1382
  }], textChange: [{
@@ -1433,14 +1389,17 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "21.0.6", ngImpor
1433
1389
  }] } });
1434
1390
 
1435
1391
  class DocumentationContextuelleComponent {
1392
+ http;
1393
+ router;
1394
+ config;
1395
+ categories = [];
1396
+ filteredCategories = [];
1397
+ tabs = [];
1398
+ searchQuery = '';
1399
+ activeTabIndex = 0;
1436
1400
  constructor(http, router) {
1437
1401
  this.http = http;
1438
1402
  this.router = router;
1439
- this.categories = [];
1440
- this.filteredCategories = [];
1441
- this.tabs = [];
1442
- this.searchQuery = '';
1443
- this.activeTabIndex = 0;
1444
1403
  }
1445
1404
  ngOnInit() {
1446
1405
  this.http.get('assets/docs/doc-config/config.json').subscribe((config) => {
@@ -1569,82 +1528,25 @@ class DocumentationContextuelleComponent {
1569
1528
  .reduce((acc, cat) => acc.concat(cat.docs), [])
1570
1529
  .find(doc => normalizedUrl.toLowerCase().includes(doc.fileName.toLowerCase().replace('.md', '')));
1571
1530
  }
1572
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "21.0.6", ngImport: i0, type: DocumentationContextuelleComponent, deps: [{ token: i1$2.HttpClient }, { token: i2$2.Router }], target: i0.ɵɵFactoryTarget.Component }); }
1573
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "21.0.6", type: DocumentationContextuelleComponent, isStandalone: false, selector: "cilog-documentation-contextuelle", ngImport: i0, template: "<div class=\"documentation-container\">\n <!-- Menu sup\u00E9rieur -->\n <div class=\"documentation-menu\">\n <button pButton\n type=\"button\"\n icon=\"pi pi-list\"\n label=\"Sommaire des documentations\"\n class=\"p-button-sm p-button-outlined\"\n (click)=\"openDocumentationList()\"\n title=\"Voir toutes les documentations disponibles\">\n </button>\n <button pButton\n type=\"button\"\n icon=\"pi pi-home\"\n label=\"Documentation courante\"\n class=\"p-button-sm p-button-outlined\"\n (click)=\"openCurrentPageDoc()\"\n title=\"Documentation de la page actuelle\">\n </button>\n </div>\n\n <!-- Syst\u00E8me d'onglets -->\n <p-tabs [(tabindex)]=\"activeTabIndex\"\n (onClose)=\"closeTab($event)\"\n styleClass=\"documentation-tabs\">\n <p-tablist>\n @for (tab of tabs; track tab.value) {\n <p-tab [value]=\"tab.value\" [closable]=\"tabs.length > 1\">{{ tab.title }}</p-tab>\n }\n </p-tablist>\n <p-tabpanels>\n @for (tab of tabs; track tab; let i = $index) {\n <p-tabpanel [value]=\"tab.value\">\n <!-- Contenu pour onglet de liste - Version am\u00E9lior\u00E9e -->\n @if (tab.type === 'list') {\n <div class=\"docs-list-container\">\n <div class=\"docs-header\">\n <h2>\uD83D\uDCDA Sommaire de la Documentation</h2>\n <p class=\"docs-subtitle\">Explorez toutes les fonctionnalit\u00E9s disponibles dans LogeProj</p>\n </div>\n <!-- Barre de recherche -->\n <div class=\"search-bar\">\n <span class=\"p-input-icon-left\" style=\"width: 100%; max-width: 800px;\">\n <i class=\"pi pi-search\"></i>\n <input type=\"text\"\n pInputText\n placeholder=\"Rechercher dans les documentations...\"\n [(ngModel)]=\"searchQuery\"\n (input)=\"filterDocumentation()\"\n style=\"width: 100% !important; padding: 12px 20px 12px 40px !important; border-radius: 25px !important;\">\n </span>\n </div>\n <!-- Liste des cat\u00E9gories -->\n <div class=\"categories-container\">\n @for (category of filteredCategories; track category) {\n <div class=\"category-section\">\n <div class=\"category-header\" (click)=\"toggleCategory(category.key)\">\n <i class=\"pi\" [ngClass]=\"category.expanded ? 'pi-chevron-down' : 'pi-chevron-right'\"></i>\n <span class=\"category-icon\">{{ category.icon }}</span>\n <h3 class=\"category-title\">{{ category.name }}</h3>\n <span class=\"category-count\">({{ category.docs.length }})</span>\n </div>\n <div class=\"category-content\" [ngClass]=\"{ 'expanded': category.expanded }\">\n <div class=\"docs-grid\">\n @for (doc of category.docs; track doc) {\n <div class=\"doc-card\"\n (click)=\"openDocumentationAndSwitch(doc)\"\n [title]=\"doc.description\">\n <div class=\"doc-card-content\">\n <h4 class=\"doc-name\">{{ doc.displayName }}</h4>\n <p class=\"doc-description\">{{ doc.description }}</p>\n </div>\n </div>\n }\n </div>\n </div>\n </div>\n }\n </div>\n <!-- Stats en bas -->\n <div class=\"docs-stats\">\n <div class=\"stat-item\">\n <strong>{{ getTotalDocsCount() }}</strong> documentations disponibles\n </div>\n <div class=\"stat-item\">\n <strong>{{ getOpenTabsCount() }}</strong> onglets ouverts\n </div>\n </div>\n </div>\n }\n <!-- Contenu pour onglet de documentation -->\n @if (tab.type === 'doc') {\n <div class=\"markdown-container\">\n <!-- Breadcrumb pour navigation -->\n @if (tab.category) {\n <div class=\"doc-breadcrumb\">\n <span class=\"breadcrumb-item\">{{ tab.category }}</span>\n <i class=\"pi pi-angle-right\"></i>\n <span class=\"breadcrumb-current\">{{ tab.title }}</span>\n </div>\n }\n @if (tab.loading) {\n <div class=\"loading-container\">\n <p-progressSpinner strokeWidth=\"4\"></p-progressSpinner>\n <span>Chargement de la documentation...</span>\n </div>\n }\n @if (!tab.loading) {\n <markdown [data]=\"tab.content || 'Aucun contenu disponible'\">\n </markdown>\n }\n </div>\n }\n </p-tabpanel>\n }\n </p-tabpanels>\n </p-tabs>\n</div>\n", styles: [".documentation-container{display:flex;flex-direction:column;height:100%;width:100%}.documentation-menu{padding:15px;background:linear-gradient(135deg,#667eea,#764ba2);border-bottom:1px solid #e9ecef;display:flex;gap:10px;flex-shrink:0}.documentation-menu .p-button{background:#fff3;border:1px solid rgba(255,255,255,.3);color:#fff}.documentation-menu .p-button:hover{background:#ffffff4d}.docs-list-container{padding:20px;flex:1;overflow-y:auto;background:#f8f9fa}.docs-header{text-align:center;margin-bottom:30px}.docs-header h2{margin:0 0 10px;color:#2c3e50;font-size:2rem}.docs-header .docs-subtitle{color:#7f8c8d;font-size:1.1rem;margin:0}.search-bar{margin-bottom:30px;display:flex;justify-content:center}.search-bar .search-input{width:100%;padding:12px 20px 12px 40px;border-radius:25px;border:2px solid #e9ecef;font-size:1rem}.search-bar .search-input:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.categories-container{max-width:1200px;margin:0 auto}.category-section{margin-bottom:25px;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;overflow:hidden}.category-section .category-header{padding:20px;background:linear-gradient(135deg,#f5f7fa,#c3cfe2);cursor:pointer;display:flex;align-items:center;gap:15px;transition:all .3s ease}.category-section .category-header:hover{background:linear-gradient(135deg,#e8eaf6,#b39ddb)}.category-section .category-header .pi{color:#667eea;font-size:1rem;transition:transform .3s ease}.category-section .category-header .category-icon{font-size:1.5rem}.category-section .category-header .category-title{margin:0;color:#2c3e50;font-size:1.3rem;flex:1}.category-section .category-header .category-count{color:#7f8c8d;font-size:.9rem;background:#677eea1a;padding:4px 12px;border-radius:15px}.category-section .category-content{max-height:0;overflow:hidden;transition:max-height .4s ease-out}.category-section .category-content.expanded{max-height:2000px;transition:max-height .6s ease-in}.docs-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:20px;padding:25px}.doc-card{border:1px solid #e9ecef;border-radius:12px;padding:20px;cursor:pointer;transition:all .3s ease;background:#fff;position:relative;overflow:hidden}.doc-card:before{content:\"\";position:absolute;top:0;left:0;width:100%;height:4px;background:linear-gradient(90deg,#667eea,#764ba2);transform:scaleX(0);transition:transform .3s ease}.doc-card:hover{border-color:#667eea;box-shadow:0 8px 25px #667eea26;transform:translateY(-4px)}.doc-card:hover:before{transform:scaleX(1)}.doc-card .doc-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px}.doc-card .doc-card-header .doc-icon{font-size:2rem}.doc-card .doc-card-header .doc-badge{padding:4px 8px;border-radius:12px;font-size:.75rem;font-weight:600;text-transform:uppercase}.doc-card .doc-card-header .doc-badge.doc-badge-high{background:#e8f5e8;color:#2e7d2e}.doc-card .doc-card-header .doc-badge.doc-badge-medium{background:#fff3cd;color:#856404}.doc-card .doc-card-header .doc-badge.doc-badge-low{background:#f8f9fa;color:#6c757d}.doc-card .doc-card-content .doc-name{margin:0 0 10px;color:#2c3e50;font-size:1.1rem;font-weight:600;line-height:1.3}.doc-card .doc-card-content .doc-description{color:#6c757d;font-size:.9rem;line-height:1.4;margin:0 0 10px}.doc-card .doc-card-content .doc-filename{color:#adb5bd;font-size:.8rem;font-family:Courier New,monospace}.docs-stats{display:flex;justify-content:center;gap:40px;margin-top:40px;padding:20px;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a}.docs-stats .stat-item{text-align:center;color:#6c757d}.docs-stats .stat-item strong{color:#667eea;font-size:1.2rem}.markdown-container{flex:1;overflow-y:auto;padding:20px;background:#fff}.markdown-container .doc-breadcrumb{display:flex;align-items:center;gap:8px;margin-bottom:20px;padding:10px 0;border-bottom:1px solid #e9ecef;color:#6c757d;font-size:.9rem}.markdown-container .doc-breadcrumb .breadcrumb-current{color:#2c3e50;font-weight:600}.markdown-container markdown{display:block;line-height:1.6}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px;color:#6c757d;gap:20px}.loading-container span{font-size:1.1rem}.documentation-tabs{flex:1;display:flex;flex-direction:column}.documentation-tabs ::ng-deep .p-tabview-panels{flex:1;display:flex}.documentation-tabs ::ng-deep .p-tabview-panels .p-tabview-panel{flex:1;display:flex;flex-direction:column}.documentation-tabs ::ng-deep .p-tabview-nav{background:#f8f9fa;border-bottom:2px solid #e9ecef}.documentation-tabs ::ng-deep .p-tabview-nav .p-tabview-nav-link{background:transparent;border:none;color:#6c757d;font-weight:500}.documentation-tabs ::ng-deep .p-tabview-nav .p-tabview-nav-link:not(.p-disabled):focus{box-shadow:0 0 0 2px #667eea33}.documentation-tabs ::ng-deep .p-tabview-nav .p-highlight .p-tabview-nav-link{background:#fff;color:#667eea;border-bottom:2px solid #667eea}\n"], dependencies: [{ kind: "directive", type: i3.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i4.ButtonDirective, selector: "[pButton]", inputs: ["ptButtonDirective", "pButtonPT", "pButtonUnstyled", "hostName", "text", "plain", "raised", "size", "outlined", "rounded", "iconPos", "loadingIcon", "fluid", "label", "icon", "loading", "buttonProps", "severity"] }, { kind: "directive", type: i2$1.InputText, selector: "[pInputText]", inputs: ["hostName", "ptInputText", "pInputTextPT", "pInputTextUnstyled", "pSize", "variant", "fluid", "invalid"] }, { kind: "component", type: i6.Tabs, selector: "p-tabs", inputs: ["value", "scrollable", "lazy", "selectOnFocus", "showNavigators", "tabindex"], outputs: ["valueChange"] }, { kind: "component", type: i6.TabPanels, selector: "p-tabpanels" }, { kind: "component", type: i6.TabPanel, selector: "p-tabpanel", inputs: ["lazy", "value"], outputs: ["valueChange"] }, { kind: "component", type: i6.TabList, selector: "p-tablist" }, { kind: "component", type: i6.Tab, selector: "p-tab", inputs: ["value", "disabled"], outputs: ["valueChange"] }, { kind: "directive", type: i16.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i16.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i16.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i8$1.MarkdownComponent, selector: "markdown, [markdown]", inputs: ["data", "src", "disableSanitizer", "inline", "clipboard", "clipboardButtonComponent", "clipboardButtonTemplate", "emoji", "katex", "katexOptions", "mermaid", "mermaidOptions", "lineHighlight", "line", "lineOffset", "lineNumbers", "start", "commandLine", "filterOutput", "host", "prompt", "output", "user"], outputs: ["error", "load", "ready"] }, { kind: "component", type: i9$1.ProgressSpinner, selector: "p-progressSpinner, p-progress-spinner, p-progressspinner", inputs: ["styleClass", "strokeWidth", "fill", "animationDuration", "ariaLabel"] }] }); }
1531
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "21.0.6", ngImport: i0, type: DocumentationContextuelleComponent, deps: [{ token: i1$1.HttpClient }, { token: i2$1.Router }], target: i0.ɵɵFactoryTarget.Component });
1532
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "21.0.6", type: DocumentationContextuelleComponent, isStandalone: true, selector: "cilog-documentation-contextuelle", ngImport: i0, template: "<div class=\"documentation-container\">\n <!-- Menu sup\u00E9rieur -->\n <div class=\"documentation-menu\">\n <button pButton\n type=\"button\"\n icon=\"pi pi-list\"\n label=\"Sommaire des documentations\"\n class=\"p-button-sm p-button-outlined\"\n (click)=\"openDocumentationList()\"\n title=\"Voir toutes les documentations disponibles\">\n </button>\n <button pButton\n type=\"button\"\n icon=\"pi pi-home\"\n label=\"Documentation courante\"\n class=\"p-button-sm p-button-outlined\"\n (click)=\"openCurrentPageDoc()\"\n title=\"Documentation de la page actuelle\">\n </button>\n </div>\n\n <!-- Syst\u00E8me d'onglets -->\n <p-tabs (onClose)=\"closeTab($event)\"\n styleClass=\"documentation-tabs\">\n <p-tablist>\n @for (tab of tabs; track tab.value) {\n <p-tab [value]=\"tab.value\">{{ tab.title }}</p-tab>\n }\n </p-tablist>\n <p-tabpanels>\n @for (tab of tabs; track tab; let i = $index) {\n <p-tabpanel [value]=\"tab.value\">\n <!-- Contenu pour onglet de liste - Version am\u00E9lior\u00E9e -->\n @if (tab.type === 'list') {\n <div class=\"docs-list-container\">\n <div class=\"docs-header\">\n <h2>\uD83D\uDCDA Sommaire de la Documentation</h2>\n <p class=\"docs-subtitle\">Explorez toutes les fonctionnalit\u00E9s disponibles dans LogeProj</p>\n </div>\n <!-- Barre de recherche -->\n <div class=\"search-bar\">\n <span class=\"p-input-icon-left\" style=\"width: 100%; max-width: 800px;\">\n <i class=\"pi pi-search\"></i>\n <input type=\"text\"\n pInputText\n placeholder=\"Rechercher dans les documentations...\"\n name=\"recherche\"\n [(ngModel)]=\"searchQuery\"\n ngDefaultControl\n (input)=\"filterDocumentation()\"\n style=\"width: 100% !important; padding: 12px 20px 12px 40px !important; border-radius: 25px !important;\">\n </span>\n </div>\n <!-- Liste des cat\u00E9gories -->\n <div class=\"categories-container\">\n @for (category of filteredCategories; track category) {\n <div class=\"category-section\">\n <div class=\"category-header\" (click)=\"toggleCategory(category.key)\">\n <i class=\"pi\" [ngClass]=\"category.expanded ? 'pi-chevron-down' : 'pi-chevron-right'\"></i>\n <span class=\"category-icon\">{{ category.icon }}</span>\n <h3 class=\"category-title\">{{ category.name }}</h3>\n <span class=\"category-count\">({{ category.docs.length }})</span>\n </div>\n <div class=\"category-content\" [ngClass]=\"{ 'expanded': category.expanded }\">\n <div class=\"docs-grid\">\n @for (doc of category.docs; track doc) {\n <div class=\"doc-card\"\n (click)=\"openDocumentationAndSwitch(doc)\"\n [title]=\"doc.description\">\n <div class=\"doc-card-content\">\n <h4 class=\"doc-name\">{{ doc.displayName }}</h4>\n <p class=\"doc-description\">{{ doc.description }}</p>\n </div>\n </div>\n }\n </div>\n </div>\n </div>\n }\n </div>\n <!-- Stats en bas -->\n <div class=\"docs-stats\">\n <div class=\"stat-item\">\n <strong>{{ getTotalDocsCount() }}</strong> documentations disponibles\n </div>\n <div class=\"stat-item\">\n <strong>{{ getOpenTabsCount() }}</strong> onglets ouverts\n </div>\n </div>\n </div>\n }\n <!-- Contenu pour onglet de documentation -->\n @if (tab.type === 'doc') {\n <div class=\"markdown-container\">\n <!-- Breadcrumb pour navigation -->\n @if (tab.category) {\n <div class=\"doc-breadcrumb\">\n <span class=\"breadcrumb-item\">{{ tab.category }}</span>\n <i class=\"pi pi-angle-right\"></i>\n <span class=\"breadcrumb-current\">{{ tab.title }}</span>\n </div>\n }\n @if (tab.loading) {\n <div class=\"loading-container\">\n <p-progressSpinner strokeWidth=\"4\"></p-progressSpinner>\n <span>Chargement de la documentation...</span>\n </div>\n }\n @if (!tab.loading) {\n <markdown [data]=\"tab.content || 'Aucun contenu disponible'\">\n </markdown>\n }\n </div>\n }\n </p-tabpanel>\n }\n </p-tabpanels>\n </p-tabs>\n</div>\n", styles: [".documentation-container{display:flex;flex-direction:column;height:100%;width:100%}.documentation-menu{padding:15px;background:linear-gradient(135deg,#667eea,#764ba2);border-bottom:1px solid #e9ecef;display:flex;gap:10px;flex-shrink:0}.documentation-menu .p-button{background:#fff3;border:1px solid rgba(255,255,255,.3);color:#fff}.documentation-menu .p-button:hover{background:#ffffff4d}.docs-list-container{padding:20px;flex:1;overflow-y:auto;background:#f8f9fa}.docs-header{text-align:center;margin-bottom:30px}.docs-header h2{margin:0 0 10px;color:#2c3e50;font-size:2rem}.docs-header .docs-subtitle{color:#7f8c8d;font-size:1.1rem;margin:0}.search-bar{margin-bottom:30px;display:flex;justify-content:center}.search-bar .search-input{width:100%;padding:12px 20px 12px 40px;border-radius:25px;border:2px solid #e9ecef;font-size:1rem}.search-bar .search-input:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.categories-container{max-width:1200px;margin:0 auto}.category-section{margin-bottom:25px;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;overflow:hidden}.category-section .category-header{padding:20px;background:linear-gradient(135deg,#f5f7fa,#c3cfe2);cursor:pointer;display:flex;align-items:center;gap:15px;transition:all .3s ease}.category-section .category-header:hover{background:linear-gradient(135deg,#e8eaf6,#b39ddb)}.category-section .category-header .pi{color:#667eea;font-size:1rem;transition:transform .3s ease}.category-section .category-header .category-icon{font-size:1.5rem}.category-section .category-header .category-title{margin:0;color:#2c3e50;font-size:1.3rem;flex:1}.category-section .category-header .category-count{color:#7f8c8d;font-size:.9rem;background:#677eea1a;padding:4px 12px;border-radius:15px}.category-section .category-content{max-height:0;overflow:hidden;transition:max-height .4s ease-out}.category-section .category-content.expanded{max-height:2000px;transition:max-height .6s ease-in}.docs-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:20px;padding:25px}.doc-card{border:1px solid #e9ecef;border-radius:12px;padding:20px;cursor:pointer;transition:all .3s ease;background:#fff;position:relative;overflow:hidden}.doc-card:before{content:\"\";position:absolute;top:0;left:0;width:100%;height:4px;background:linear-gradient(90deg,#667eea,#764ba2);transform:scaleX(0);transition:transform .3s ease}.doc-card:hover{border-color:#667eea;box-shadow:0 8px 25px #667eea26;transform:translateY(-4px)}.doc-card:hover:before{transform:scaleX(1)}.doc-card .doc-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px}.doc-card .doc-card-header .doc-icon{font-size:2rem}.doc-card .doc-card-header .doc-badge{padding:4px 8px;border-radius:12px;font-size:.75rem;font-weight:600;text-transform:uppercase}.doc-card .doc-card-header .doc-badge.doc-badge-high{background:#e8f5e8;color:#2e7d2e}.doc-card .doc-card-header .doc-badge.doc-badge-medium{background:#fff3cd;color:#856404}.doc-card .doc-card-header .doc-badge.doc-badge-low{background:#f8f9fa;color:#6c757d}.doc-card .doc-card-content .doc-name{margin:0 0 10px;color:#2c3e50;font-size:1.1rem;font-weight:600;line-height:1.3}.doc-card .doc-card-content .doc-description{color:#6c757d;font-size:.9rem;line-height:1.4;margin:0 0 10px}.doc-card .doc-card-content .doc-filename{color:#adb5bd;font-size:.8rem;font-family:Courier New,monospace}.docs-stats{display:flex;justify-content:center;gap:40px;margin-top:40px;padding:20px;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a}.docs-stats .stat-item{text-align:center;color:#6c757d}.docs-stats .stat-item strong{color:#667eea;font-size:1.2rem}.markdown-container{flex:1;overflow-y:auto;padding:20px;background:#fff}.markdown-container .doc-breadcrumb{display:flex;align-items:center;gap:8px;margin-bottom:20px;padding:10px 0;border-bottom:1px solid #e9ecef;color:#6c757d;font-size:.9rem}.markdown-container .doc-breadcrumb .breadcrumb-current{color:#2c3e50;font-weight:600}.markdown-container markdown{display:block;line-height:1.6}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px;color:#6c757d;gap:20px}.loading-container span{font-size:1.1rem}.documentation-tabs{flex:1;display:flex;flex-direction:column}.documentation-tabs ::ng-deep .p-tabview-panels{flex:1;display:flex}.documentation-tabs ::ng-deep .p-tabview-panels .p-tabview-panel{flex:1;display:flex;flex-direction:column}.documentation-tabs ::ng-deep .p-tabview-nav{background:#f8f9fa;border-bottom:2px solid #e9ecef}.documentation-tabs ::ng-deep .p-tabview-nav .p-tabview-nav-link{background:transparent;border:none;color:#6c757d;font-weight:500}.documentation-tabs ::ng-deep .p-tabview-nav .p-tabview-nav-link:not(.p-disabled):focus{box-shadow:0 0 0 2px #667eea33}.documentation-tabs ::ng-deep .p-tabview-nav .p-highlight .p-tabview-nav-link{background:#fff;color:#667eea;border-bottom:2px solid #667eea}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i3.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i4.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i4.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i4.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "ngmodule", type: ProgressSpinnerModule }, { kind: "component", type: i5$1.ProgressSpinner, selector: "p-progressSpinner, p-progress-spinner, p-progressspinner", inputs: ["styleClass", "strokeWidth", "fill", "animationDuration", "ariaLabel"] }, { kind: "ngmodule", type: TabsModule }, { kind: "component", type: i6$1.Tabs, selector: "p-tabs", inputs: ["value", "scrollable", "lazy", "selectOnFocus", "showNavigators", "tabindex"], outputs: ["valueChange"] }, { kind: "component", type: i6$1.TabPanels, selector: "p-tabpanels" }, { kind: "component", type: i6$1.TabPanel, selector: "p-tabpanel", inputs: ["lazy", "value"], outputs: ["valueChange"] }, { kind: "component", type: i6$1.TabList, selector: "p-tablist" }, { kind: "component", type: i6$1.Tab, selector: "p-tab", inputs: ["value", "disabled"], outputs: ["valueChange"] }, { kind: "ngmodule", type: EditorModule }, { kind: "component", type: MarkdownComponent, selector: "markdown, [markdown]", inputs: ["data", "src", "disableSanitizer", "inline", "clipboard", "clipboardButtonComponent", "clipboardButtonTemplate", "emoji", "katex", "katexOptions", "mermaid", "mermaidOptions", "lineHighlight", "line", "lineOffset", "lineNumbers", "start", "commandLine", "filterOutput", "host", "prompt", "output", "user"], outputs: ["error", "load", "ready"] }] });
1574
1533
  }
1575
1534
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "21.0.6", ngImport: i0, type: DocumentationContextuelleComponent, decorators: [{
1576
1535
  type: Component,
1577
- args: [{ selector: 'cilog-documentation-contextuelle', standalone: false, template: "<div class=\"documentation-container\">\n <!-- Menu sup\u00E9rieur -->\n <div class=\"documentation-menu\">\n <button pButton\n type=\"button\"\n icon=\"pi pi-list\"\n label=\"Sommaire des documentations\"\n class=\"p-button-sm p-button-outlined\"\n (click)=\"openDocumentationList()\"\n title=\"Voir toutes les documentations disponibles\">\n </button>\n <button pButton\n type=\"button\"\n icon=\"pi pi-home\"\n label=\"Documentation courante\"\n class=\"p-button-sm p-button-outlined\"\n (click)=\"openCurrentPageDoc()\"\n title=\"Documentation de la page actuelle\">\n </button>\n </div>\n\n <!-- Syst\u00E8me d'onglets -->\n <p-tabs [(tabindex)]=\"activeTabIndex\"\n (onClose)=\"closeTab($event)\"\n styleClass=\"documentation-tabs\">\n <p-tablist>\n @for (tab of tabs; track tab.value) {\n <p-tab [value]=\"tab.value\" [closable]=\"tabs.length > 1\">{{ tab.title }}</p-tab>\n }\n </p-tablist>\n <p-tabpanels>\n @for (tab of tabs; track tab; let i = $index) {\n <p-tabpanel [value]=\"tab.value\">\n <!-- Contenu pour onglet de liste - Version am\u00E9lior\u00E9e -->\n @if (tab.type === 'list') {\n <div class=\"docs-list-container\">\n <div class=\"docs-header\">\n <h2>\uD83D\uDCDA Sommaire de la Documentation</h2>\n <p class=\"docs-subtitle\">Explorez toutes les fonctionnalit\u00E9s disponibles dans LogeProj</p>\n </div>\n <!-- Barre de recherche -->\n <div class=\"search-bar\">\n <span class=\"p-input-icon-left\" style=\"width: 100%; max-width: 800px;\">\n <i class=\"pi pi-search\"></i>\n <input type=\"text\"\n pInputText\n placeholder=\"Rechercher dans les documentations...\"\n [(ngModel)]=\"searchQuery\"\n (input)=\"filterDocumentation()\"\n style=\"width: 100% !important; padding: 12px 20px 12px 40px !important; border-radius: 25px !important;\">\n </span>\n </div>\n <!-- Liste des cat\u00E9gories -->\n <div class=\"categories-container\">\n @for (category of filteredCategories; track category) {\n <div class=\"category-section\">\n <div class=\"category-header\" (click)=\"toggleCategory(category.key)\">\n <i class=\"pi\" [ngClass]=\"category.expanded ? 'pi-chevron-down' : 'pi-chevron-right'\"></i>\n <span class=\"category-icon\">{{ category.icon }}</span>\n <h3 class=\"category-title\">{{ category.name }}</h3>\n <span class=\"category-count\">({{ category.docs.length }})</span>\n </div>\n <div class=\"category-content\" [ngClass]=\"{ 'expanded': category.expanded }\">\n <div class=\"docs-grid\">\n @for (doc of category.docs; track doc) {\n <div class=\"doc-card\"\n (click)=\"openDocumentationAndSwitch(doc)\"\n [title]=\"doc.description\">\n <div class=\"doc-card-content\">\n <h4 class=\"doc-name\">{{ doc.displayName }}</h4>\n <p class=\"doc-description\">{{ doc.description }}</p>\n </div>\n </div>\n }\n </div>\n </div>\n </div>\n }\n </div>\n <!-- Stats en bas -->\n <div class=\"docs-stats\">\n <div class=\"stat-item\">\n <strong>{{ getTotalDocsCount() }}</strong> documentations disponibles\n </div>\n <div class=\"stat-item\">\n <strong>{{ getOpenTabsCount() }}</strong> onglets ouverts\n </div>\n </div>\n </div>\n }\n <!-- Contenu pour onglet de documentation -->\n @if (tab.type === 'doc') {\n <div class=\"markdown-container\">\n <!-- Breadcrumb pour navigation -->\n @if (tab.category) {\n <div class=\"doc-breadcrumb\">\n <span class=\"breadcrumb-item\">{{ tab.category }}</span>\n <i class=\"pi pi-angle-right\"></i>\n <span class=\"breadcrumb-current\">{{ tab.title }}</span>\n </div>\n }\n @if (tab.loading) {\n <div class=\"loading-container\">\n <p-progressSpinner strokeWidth=\"4\"></p-progressSpinner>\n <span>Chargement de la documentation...</span>\n </div>\n }\n @if (!tab.loading) {\n <markdown [data]=\"tab.content || 'Aucun contenu disponible'\">\n </markdown>\n }\n </div>\n }\n </p-tabpanel>\n }\n </p-tabpanels>\n </p-tabs>\n</div>\n", styles: [".documentation-container{display:flex;flex-direction:column;height:100%;width:100%}.documentation-menu{padding:15px;background:linear-gradient(135deg,#667eea,#764ba2);border-bottom:1px solid #e9ecef;display:flex;gap:10px;flex-shrink:0}.documentation-menu .p-button{background:#fff3;border:1px solid rgba(255,255,255,.3);color:#fff}.documentation-menu .p-button:hover{background:#ffffff4d}.docs-list-container{padding:20px;flex:1;overflow-y:auto;background:#f8f9fa}.docs-header{text-align:center;margin-bottom:30px}.docs-header h2{margin:0 0 10px;color:#2c3e50;font-size:2rem}.docs-header .docs-subtitle{color:#7f8c8d;font-size:1.1rem;margin:0}.search-bar{margin-bottom:30px;display:flex;justify-content:center}.search-bar .search-input{width:100%;padding:12px 20px 12px 40px;border-radius:25px;border:2px solid #e9ecef;font-size:1rem}.search-bar .search-input:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.categories-container{max-width:1200px;margin:0 auto}.category-section{margin-bottom:25px;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;overflow:hidden}.category-section .category-header{padding:20px;background:linear-gradient(135deg,#f5f7fa,#c3cfe2);cursor:pointer;display:flex;align-items:center;gap:15px;transition:all .3s ease}.category-section .category-header:hover{background:linear-gradient(135deg,#e8eaf6,#b39ddb)}.category-section .category-header .pi{color:#667eea;font-size:1rem;transition:transform .3s ease}.category-section .category-header .category-icon{font-size:1.5rem}.category-section .category-header .category-title{margin:0;color:#2c3e50;font-size:1.3rem;flex:1}.category-section .category-header .category-count{color:#7f8c8d;font-size:.9rem;background:#677eea1a;padding:4px 12px;border-radius:15px}.category-section .category-content{max-height:0;overflow:hidden;transition:max-height .4s ease-out}.category-section .category-content.expanded{max-height:2000px;transition:max-height .6s ease-in}.docs-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:20px;padding:25px}.doc-card{border:1px solid #e9ecef;border-radius:12px;padding:20px;cursor:pointer;transition:all .3s ease;background:#fff;position:relative;overflow:hidden}.doc-card:before{content:\"\";position:absolute;top:0;left:0;width:100%;height:4px;background:linear-gradient(90deg,#667eea,#764ba2);transform:scaleX(0);transition:transform .3s ease}.doc-card:hover{border-color:#667eea;box-shadow:0 8px 25px #667eea26;transform:translateY(-4px)}.doc-card:hover:before{transform:scaleX(1)}.doc-card .doc-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px}.doc-card .doc-card-header .doc-icon{font-size:2rem}.doc-card .doc-card-header .doc-badge{padding:4px 8px;border-radius:12px;font-size:.75rem;font-weight:600;text-transform:uppercase}.doc-card .doc-card-header .doc-badge.doc-badge-high{background:#e8f5e8;color:#2e7d2e}.doc-card .doc-card-header .doc-badge.doc-badge-medium{background:#fff3cd;color:#856404}.doc-card .doc-card-header .doc-badge.doc-badge-low{background:#f8f9fa;color:#6c757d}.doc-card .doc-card-content .doc-name{margin:0 0 10px;color:#2c3e50;font-size:1.1rem;font-weight:600;line-height:1.3}.doc-card .doc-card-content .doc-description{color:#6c757d;font-size:.9rem;line-height:1.4;margin:0 0 10px}.doc-card .doc-card-content .doc-filename{color:#adb5bd;font-size:.8rem;font-family:Courier New,monospace}.docs-stats{display:flex;justify-content:center;gap:40px;margin-top:40px;padding:20px;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a}.docs-stats .stat-item{text-align:center;color:#6c757d}.docs-stats .stat-item strong{color:#667eea;font-size:1.2rem}.markdown-container{flex:1;overflow-y:auto;padding:20px;background:#fff}.markdown-container .doc-breadcrumb{display:flex;align-items:center;gap:8px;margin-bottom:20px;padding:10px 0;border-bottom:1px solid #e9ecef;color:#6c757d;font-size:.9rem}.markdown-container .doc-breadcrumb .breadcrumb-current{color:#2c3e50;font-weight:600}.markdown-container markdown{display:block;line-height:1.6}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px;color:#6c757d;gap:20px}.loading-container span{font-size:1.1rem}.documentation-tabs{flex:1;display:flex;flex-direction:column}.documentation-tabs ::ng-deep .p-tabview-panels{flex:1;display:flex}.documentation-tabs ::ng-deep .p-tabview-panels .p-tabview-panel{flex:1;display:flex;flex-direction:column}.documentation-tabs ::ng-deep .p-tabview-nav{background:#f8f9fa;border-bottom:2px solid #e9ecef}.documentation-tabs ::ng-deep .p-tabview-nav .p-tabview-nav-link{background:transparent;border:none;color:#6c757d;font-weight:500}.documentation-tabs ::ng-deep .p-tabview-nav .p-tabview-nav-link:not(.p-disabled):focus{box-shadow:0 0 0 2px #667eea33}.documentation-tabs ::ng-deep .p-tabview-nav .p-highlight .p-tabview-nav-link{background:#fff;color:#667eea;border-bottom:2px solid #667eea}\n"] }]
1578
- }], ctorParameters: () => [{ type: i1$2.HttpClient }, { type: i2$2.Router }] });
1579
-
1580
- registerLocaleData(localeFr);
1581
- class CilogLibModule {
1582
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "21.0.6", ngImport: i0, type: CilogLibModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
1583
- static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "21.0.6", ngImport: i0, type: CilogLibModule, declarations: [CilogLibComponent,
1584
- CilogMessageComponent,
1585
- CilogTableComponent,
1586
- CilogEditorComponent,
1587
- CilogInputNumberComponent,
1588
- DocumentationContextuelleComponent,
1589
- ValuePipe], imports: [CommonModule,
1590
- PrimengModule,
1591
- BrowserModule,
1592
- FormsModule,
1593
- ReactiveFormsModule, i8$1.MarkdownModule, ProgressSpinnerModule], exports: [CilogMessageComponent,
1594
- CilogTableComponent,
1595
- CilogEditorComponent,
1596
- CilogInputNumberComponent,
1597
- DocumentationContextuelleComponent] }); }
1598
- static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "21.0.6", ngImport: i0, type: CilogLibModule, providers: [
1599
- CilogMessageService,
1600
- CilogTableService,
1601
- ConfirmationService,
1602
- { provide: LOCALE_ID, useValue: 'fr-FR' },
1603
- provideHttpClient(withInterceptorsFromDi()),
1604
- ], imports: [CommonModule,
1605
- PrimengModule,
1606
- BrowserModule,
1607
- FormsModule,
1608
- ReactiveFormsModule,
1609
- MarkdownModule.forRoot({ loader: HttpClient }),
1610
- ProgressSpinnerModule] }); }
1611
- }
1612
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "21.0.6", ngImport: i0, type: CilogLibModule, decorators: [{
1613
- type: NgModule,
1614
- args: [{ declarations: [
1615
- CilogLibComponent,
1616
- CilogMessageComponent,
1617
- CilogTableComponent,
1618
- CilogEditorComponent,
1619
- CilogInputNumberComponent,
1620
- DocumentationContextuelleComponent,
1621
- ValuePipe
1622
- ],
1623
- exports: [
1624
- CilogMessageComponent,
1625
- CilogTableComponent,
1626
- CilogEditorComponent,
1627
- CilogInputNumberComponent,
1628
- DocumentationContextuelleComponent,
1629
- ], imports: [CommonModule,
1630
- PrimengModule,
1631
- BrowserModule,
1536
+ args: [{ selector: 'cilog-documentation-contextuelle', imports: [
1537
+ CommonModule,
1632
1538
  FormsModule,
1633
- ReactiveFormsModule,
1634
- MarkdownModule.forRoot({ loader: HttpClient }),
1635
- ProgressSpinnerModule], providers: [
1636
- CilogMessageService,
1637
- CilogTableService,
1638
- ConfirmationService,
1639
- { provide: LOCALE_ID, useValue: 'fr-FR' },
1640
- provideHttpClient(withInterceptorsFromDi()),
1641
- ] }]
1642
- }] });
1539
+ ProgressSpinnerModule,
1540
+ TabsModule,
1541
+ EditorModule,
1542
+ MarkdownComponent
1543
+ ], template: "<div class=\"documentation-container\">\n <!-- Menu sup\u00E9rieur -->\n <div class=\"documentation-menu\">\n <button pButton\n type=\"button\"\n icon=\"pi pi-list\"\n label=\"Sommaire des documentations\"\n class=\"p-button-sm p-button-outlined\"\n (click)=\"openDocumentationList()\"\n title=\"Voir toutes les documentations disponibles\">\n </button>\n <button pButton\n type=\"button\"\n icon=\"pi pi-home\"\n label=\"Documentation courante\"\n class=\"p-button-sm p-button-outlined\"\n (click)=\"openCurrentPageDoc()\"\n title=\"Documentation de la page actuelle\">\n </button>\n </div>\n\n <!-- Syst\u00E8me d'onglets -->\n <p-tabs (onClose)=\"closeTab($event)\"\n styleClass=\"documentation-tabs\">\n <p-tablist>\n @for (tab of tabs; track tab.value) {\n <p-tab [value]=\"tab.value\">{{ tab.title }}</p-tab>\n }\n </p-tablist>\n <p-tabpanels>\n @for (tab of tabs; track tab; let i = $index) {\n <p-tabpanel [value]=\"tab.value\">\n <!-- Contenu pour onglet de liste - Version am\u00E9lior\u00E9e -->\n @if (tab.type === 'list') {\n <div class=\"docs-list-container\">\n <div class=\"docs-header\">\n <h2>\uD83D\uDCDA Sommaire de la Documentation</h2>\n <p class=\"docs-subtitle\">Explorez toutes les fonctionnalit\u00E9s disponibles dans LogeProj</p>\n </div>\n <!-- Barre de recherche -->\n <div class=\"search-bar\">\n <span class=\"p-input-icon-left\" style=\"width: 100%; max-width: 800px;\">\n <i class=\"pi pi-search\"></i>\n <input type=\"text\"\n pInputText\n placeholder=\"Rechercher dans les documentations...\"\n name=\"recherche\"\n [(ngModel)]=\"searchQuery\"\n ngDefaultControl\n (input)=\"filterDocumentation()\"\n style=\"width: 100% !important; padding: 12px 20px 12px 40px !important; border-radius: 25px !important;\">\n </span>\n </div>\n <!-- Liste des cat\u00E9gories -->\n <div class=\"categories-container\">\n @for (category of filteredCategories; track category) {\n <div class=\"category-section\">\n <div class=\"category-header\" (click)=\"toggleCategory(category.key)\">\n <i class=\"pi\" [ngClass]=\"category.expanded ? 'pi-chevron-down' : 'pi-chevron-right'\"></i>\n <span class=\"category-icon\">{{ category.icon }}</span>\n <h3 class=\"category-title\">{{ category.name }}</h3>\n <span class=\"category-count\">({{ category.docs.length }})</span>\n </div>\n <div class=\"category-content\" [ngClass]=\"{ 'expanded': category.expanded }\">\n <div class=\"docs-grid\">\n @for (doc of category.docs; track doc) {\n <div class=\"doc-card\"\n (click)=\"openDocumentationAndSwitch(doc)\"\n [title]=\"doc.description\">\n <div class=\"doc-card-content\">\n <h4 class=\"doc-name\">{{ doc.displayName }}</h4>\n <p class=\"doc-description\">{{ doc.description }}</p>\n </div>\n </div>\n }\n </div>\n </div>\n </div>\n }\n </div>\n <!-- Stats en bas -->\n <div class=\"docs-stats\">\n <div class=\"stat-item\">\n <strong>{{ getTotalDocsCount() }}</strong> documentations disponibles\n </div>\n <div class=\"stat-item\">\n <strong>{{ getOpenTabsCount() }}</strong> onglets ouverts\n </div>\n </div>\n </div>\n }\n <!-- Contenu pour onglet de documentation -->\n @if (tab.type === 'doc') {\n <div class=\"markdown-container\">\n <!-- Breadcrumb pour navigation -->\n @if (tab.category) {\n <div class=\"doc-breadcrumb\">\n <span class=\"breadcrumb-item\">{{ tab.category }}</span>\n <i class=\"pi pi-angle-right\"></i>\n <span class=\"breadcrumb-current\">{{ tab.title }}</span>\n </div>\n }\n @if (tab.loading) {\n <div class=\"loading-container\">\n <p-progressSpinner strokeWidth=\"4\"></p-progressSpinner>\n <span>Chargement de la documentation...</span>\n </div>\n }\n @if (!tab.loading) {\n <markdown [data]=\"tab.content || 'Aucun contenu disponible'\">\n </markdown>\n }\n </div>\n }\n </p-tabpanel>\n }\n </p-tabpanels>\n </p-tabs>\n</div>\n", styles: [".documentation-container{display:flex;flex-direction:column;height:100%;width:100%}.documentation-menu{padding:15px;background:linear-gradient(135deg,#667eea,#764ba2);border-bottom:1px solid #e9ecef;display:flex;gap:10px;flex-shrink:0}.documentation-menu .p-button{background:#fff3;border:1px solid rgba(255,255,255,.3);color:#fff}.documentation-menu .p-button:hover{background:#ffffff4d}.docs-list-container{padding:20px;flex:1;overflow-y:auto;background:#f8f9fa}.docs-header{text-align:center;margin-bottom:30px}.docs-header h2{margin:0 0 10px;color:#2c3e50;font-size:2rem}.docs-header .docs-subtitle{color:#7f8c8d;font-size:1.1rem;margin:0}.search-bar{margin-bottom:30px;display:flex;justify-content:center}.search-bar .search-input{width:100%;padding:12px 20px 12px 40px;border-radius:25px;border:2px solid #e9ecef;font-size:1rem}.search-bar .search-input:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.categories-container{max-width:1200px;margin:0 auto}.category-section{margin-bottom:25px;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;overflow:hidden}.category-section .category-header{padding:20px;background:linear-gradient(135deg,#f5f7fa,#c3cfe2);cursor:pointer;display:flex;align-items:center;gap:15px;transition:all .3s ease}.category-section .category-header:hover{background:linear-gradient(135deg,#e8eaf6,#b39ddb)}.category-section .category-header .pi{color:#667eea;font-size:1rem;transition:transform .3s ease}.category-section .category-header .category-icon{font-size:1.5rem}.category-section .category-header .category-title{margin:0;color:#2c3e50;font-size:1.3rem;flex:1}.category-section .category-header .category-count{color:#7f8c8d;font-size:.9rem;background:#677eea1a;padding:4px 12px;border-radius:15px}.category-section .category-content{max-height:0;overflow:hidden;transition:max-height .4s ease-out}.category-section .category-content.expanded{max-height:2000px;transition:max-height .6s ease-in}.docs-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:20px;padding:25px}.doc-card{border:1px solid #e9ecef;border-radius:12px;padding:20px;cursor:pointer;transition:all .3s ease;background:#fff;position:relative;overflow:hidden}.doc-card:before{content:\"\";position:absolute;top:0;left:0;width:100%;height:4px;background:linear-gradient(90deg,#667eea,#764ba2);transform:scaleX(0);transition:transform .3s ease}.doc-card:hover{border-color:#667eea;box-shadow:0 8px 25px #667eea26;transform:translateY(-4px)}.doc-card:hover:before{transform:scaleX(1)}.doc-card .doc-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px}.doc-card .doc-card-header .doc-icon{font-size:2rem}.doc-card .doc-card-header .doc-badge{padding:4px 8px;border-radius:12px;font-size:.75rem;font-weight:600;text-transform:uppercase}.doc-card .doc-card-header .doc-badge.doc-badge-high{background:#e8f5e8;color:#2e7d2e}.doc-card .doc-card-header .doc-badge.doc-badge-medium{background:#fff3cd;color:#856404}.doc-card .doc-card-header .doc-badge.doc-badge-low{background:#f8f9fa;color:#6c757d}.doc-card .doc-card-content .doc-name{margin:0 0 10px;color:#2c3e50;font-size:1.1rem;font-weight:600;line-height:1.3}.doc-card .doc-card-content .doc-description{color:#6c757d;font-size:.9rem;line-height:1.4;margin:0 0 10px}.doc-card .doc-card-content .doc-filename{color:#adb5bd;font-size:.8rem;font-family:Courier New,monospace}.docs-stats{display:flex;justify-content:center;gap:40px;margin-top:40px;padding:20px;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a}.docs-stats .stat-item{text-align:center;color:#6c757d}.docs-stats .stat-item strong{color:#667eea;font-size:1.2rem}.markdown-container{flex:1;overflow-y:auto;padding:20px;background:#fff}.markdown-container .doc-breadcrumb{display:flex;align-items:center;gap:8px;margin-bottom:20px;padding:10px 0;border-bottom:1px solid #e9ecef;color:#6c757d;font-size:.9rem}.markdown-container .doc-breadcrumb .breadcrumb-current{color:#2c3e50;font-weight:600}.markdown-container markdown{display:block;line-height:1.6}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px;color:#6c757d;gap:20px}.loading-container span{font-size:1.1rem}.documentation-tabs{flex:1;display:flex;flex-direction:column}.documentation-tabs ::ng-deep .p-tabview-panels{flex:1;display:flex}.documentation-tabs ::ng-deep .p-tabview-panels .p-tabview-panel{flex:1;display:flex;flex-direction:column}.documentation-tabs ::ng-deep .p-tabview-nav{background:#f8f9fa;border-bottom:2px solid #e9ecef}.documentation-tabs ::ng-deep .p-tabview-nav .p-tabview-nav-link{background:transparent;border:none;color:#6c757d;font-weight:500}.documentation-tabs ::ng-deep .p-tabview-nav .p-tabview-nav-link:not(.p-disabled):focus{box-shadow:0 0 0 2px #667eea33}.documentation-tabs ::ng-deep .p-tabview-nav .p-highlight .p-tabview-nav-link{background:#fff;color:#667eea;border-bottom:2px solid #667eea}\n"] }]
1544
+ }], ctorParameters: () => [{ type: i1$1.HttpClient }, { type: i2$1.Router }] });
1643
1545
 
1644
1546
  class CilogLibService {
1645
1547
  constructor() { }
1646
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "21.0.6", ngImport: i0, type: CilogLibService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
1647
- static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "21.0.6", ngImport: i0, type: CilogLibService, providedIn: 'root' }); }
1548
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "21.0.6", ngImport: i0, type: CilogLibService, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
1549
+ static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "21.0.6", ngImport: i0, type: CilogLibService, providedIn: 'root' });
1648
1550
  }
1649
1551
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "21.0.6", ngImport: i0, type: CilogLibService, decorators: [{
1650
1552
  type: Injectable,
@@ -1653,14 +1555,26 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "21.0.6", ngImpor
1653
1555
  }]
1654
1556
  }], ctorParameters: () => [] });
1655
1557
 
1558
+ class CilogTableService {
1559
+ constructor() { }
1560
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "21.0.6", ngImport: i0, type: CilogTableService, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
1561
+ static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "21.0.6", ngImport: i0, type: CilogTableService, providedIn: 'root' });
1562
+ }
1563
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "21.0.6", ngImport: i0, type: CilogTableService, decorators: [{
1564
+ type: Injectable,
1565
+ args: [{
1566
+ providedIn: 'root'
1567
+ }]
1568
+ }], ctorParameters: () => [] });
1569
+
1656
1570
  /*
1657
1571
  * Public API Surface of cilog-lib
1658
1572
  */
1659
- // Modules
1573
+ // Components
1660
1574
 
1661
1575
  /**
1662
1576
  * Generated bundle index. Do not edit.
1663
1577
  */
1664
1578
 
1665
- export { CilogEditorComponent, CilogInputNumberComponent, CilogLibComponent, CilogLibModule, CilogLibService, CilogMessageComponent, CilogMessageService, CilogTableComponent, CilogTableService, ColType, DocumentationContextuelleComponent, ExportService, ModeCalendar, ModeSelection, Position, Severity, ThemeGrille };
1579
+ export { CilogEditorComponent, CilogInputNumberComponent, CilogLibComponent, CilogLibService, CilogMessageComponent, CilogMessageService, CilogTableComponent, CilogTableService, ColType, DocumentationContextuelleComponent, ExportService, ModeCalendar, ModeSelection, Position, Severity, ThemeGrille };
1666
1580
  //# sourceMappingURL=cilog-lib.mjs.map