cilog-lib 1.10.20 → 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.
Files changed (44) hide show
  1. package/fesm2022/cilog-lib.mjs +377 -473
  2. package/fesm2022/cilog-lib.mjs.map +1 -1
  3. package/package.json +3 -5
  4. package/types/cilog-lib.d.ts +496 -0
  5. package/esm2022/cilog-lib.mjs +0 -5
  6. package/esm2022/lib/cilog-lib.component.mjs +0 -22
  7. package/esm2022/lib/cilog-lib.module.mjs +0 -96
  8. package/esm2022/lib/cilog-lib.service.mjs +0 -14
  9. package/esm2022/lib/helpers/enums/grille.enum.mjs +0 -51
  10. package/esm2022/lib/helpers/interfaces/edition.interface.mjs +0 -2
  11. package/esm2022/lib/helpers/interfaces/editor.interface.mjs +0 -2
  12. package/esm2022/lib/helpers/interfaces/grille.interface.mjs +0 -2
  13. package/esm2022/lib/helpers/interfaces/message.interface.mjs +0 -2
  14. package/esm2022/lib/helpers/pipes/value.pipe.mjs +0 -27
  15. package/esm2022/lib/modules/primeng.module.mjs +0 -86
  16. package/esm2022/lib/services/excel.service.mjs +0 -184
  17. package/esm2022/lib/services/message.service.mjs +0 -30
  18. package/esm2022/lib/services/table.service.mjs +0 -14
  19. package/esm2022/lib/views/cilog-input-number/cilog-input-number.component.mjs +0 -251
  20. package/esm2022/lib/views/documentation/documentation-contextuelle.component.mjs +0 -156
  21. package/esm2022/lib/views/editor/editor.component.mjs +0 -38
  22. package/esm2022/lib/views/message/message.component.mjs +0 -77
  23. package/esm2022/lib/views/table/table.component.mjs +0 -674
  24. package/esm2022/public-api.mjs +0 -24
  25. package/index.d.ts +0 -5
  26. package/lib/cilog-lib.component.d.ts +0 -8
  27. package/lib/cilog-lib.module.d.ts +0 -21
  28. package/lib/cilog-lib.service.d.ts +0 -6
  29. package/lib/helpers/enums/grille.enum.d.ts +0 -44
  30. package/lib/helpers/interfaces/edition.interface.d.ts +0 -34
  31. package/lib/helpers/interfaces/editor.interface.d.ts +0 -4
  32. package/lib/helpers/interfaces/grille.interface.d.ts +0 -167
  33. package/lib/helpers/interfaces/message.interface.d.ts +0 -6
  34. package/lib/helpers/pipes/value.pipe.d.ts +0 -7
  35. package/lib/modules/primeng.module.d.ts +0 -24
  36. package/lib/services/excel.service.d.ts +0 -15
  37. package/lib/services/message.service.d.ts +0 -12
  38. package/lib/services/table.service.d.ts +0 -6
  39. package/lib/views/cilog-input-number/cilog-input-number.component.d.ts +0 -40
  40. package/lib/views/documentation/documentation-contextuelle.component.d.ts +0 -49
  41. package/lib/views/editor/editor.component.d.ts +0 -17
  42. package/lib/views/message/message.component.d.ts +0 -17
  43. package/lib/views/table/table.component.d.ts +0 -83
  44. package/public-api.d.ts +0 -15
@@ -1,58 +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';
4
- import * as i3 from '@angular/common';
5
- import { CommonModule, registerLocaleData } from '@angular/common';
6
- import * as i3$1 from 'primeng/dialog';
2
+ import { Component, Injectable, Pipe, EventEmitter, HostListener, ViewChild, Output, Input } from '@angular/core';
3
+ import * as i2 from 'primeng/dialog';
7
4
  import { DialogModule } from 'primeng/dialog';
5
+ import { BehaviorSubject } from 'rxjs';
8
6
  import * as i1 from 'primeng/api';
9
- import { ConfirmationService } from 'primeng/api';
10
- import * as i4 from 'primeng/button';
11
- import { ButtonModule } from 'primeng/button';
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 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/dropdown';
19
- import { DropdownModule } from 'primeng/dropdown';
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 i11 from 'primeng/calendar';
26
- import { CalendarModule } from 'primeng/calendar';
27
- import * as i14 from 'primeng/tag';
13
+ import * as i3 from '@angular/common';
14
+ import { CommonModule } from '@angular/common';
15
+ import * as i5 from 'primeng/tag';
28
16
  import { TagModule } from 'primeng/tag';
29
- import * as i13 from 'primeng/tooltip';
17
+ import * as i8 from 'primeng/tooltip';
30
18
  import { TooltipModule } from 'primeng/tooltip';
31
- import * as i15 from 'primeng/inputswitch';
32
- import { InputSwitchModule } from 'primeng/inputswitch';
33
- import { SkeletonModule } from 'primeng/skeleton';
34
- import * as i1$1 from 'primeng/editor';
35
- import { EditorModule } from 'primeng/editor';
36
- import * as i12 from 'primeng/contextmenu';
37
- import { ContextMenuModule } from 'primeng/contextmenu';
38
- import * as i6 from 'primeng/tabview';
39
- import { TabViewModule } from 'primeng/tabview';
40
- import { BrowserModule } from '@angular/platform-browser';
41
- import { BrowserAnimationsModule } from '@angular/platform-browser/animations';
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';
24
+ import { DatePickerModule } from 'primeng/datepicker';
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';
42
33
  import * as Excel from 'exceljs';
43
34
  import * as FileSaver from 'file-saver';
44
- import * as i16 from '@angular/forms';
45
- import { NG_VALUE_ACCESSOR, FormsModule, ReactiveFormsModule } from '@angular/forms';
46
- import localeFr from '@angular/common/locales/fr';
47
- import * as i1$2 from '@angular/common/http';
48
- import { HttpClientModule, HttpClient } from '@angular/common/http';
49
- import * as i2$1 from '@angular/router';
50
- import * as i8$1 from 'ngx-markdown';
51
- import { MarkdownModule } from 'ngx-markdown';
52
- import * as i9$1 from 'primeng/progressspinner';
35
+ import * as i5$1 from 'primeng/progressspinner';
53
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: () => [] });
54
63
 
55
64
  class CilogMessageService {
65
+ display;
66
+ message;
56
67
  constructor() {
57
68
  this.message = new BehaviorSubject(null);
58
69
  this.display = new BehaviorSubject(null);
@@ -69,10 +80,10 @@ class CilogMessageService {
69
80
  closeDialog() {
70
81
  this.display.next(false);
71
82
  }
72
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: CilogMessageService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
73
- static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.3.12", 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' });
74
85
  }
75
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: CilogMessageService, decorators: [{
86
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "21.0.6", ngImport: i0, type: CilogMessageService, decorators: [{
76
87
  type: Injectable,
77
88
  args: [{
78
89
  providedIn: 'root'
@@ -80,6 +91,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
80
91
  }], ctorParameters: () => [] });
81
92
 
82
93
  class CilogMessageComponent {
94
+ messageService;
95
+ display;
96
+ message;
83
97
  constructor(messageService) {
84
98
  this.messageService = messageService;
85
99
  }
@@ -141,100 +155,16 @@ class CilogMessageComponent {
141
155
  refreshPage() {
142
156
  window.location.reload();
143
157
  }
144
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: CilogMessageComponent, deps: [{ token: CilogMessageService }], target: i0.ɵɵFactoryTarget.Component }); }
145
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: CilogMessageComponent, selector: "cilog-message", ngImport: i0, template: "<p-dialog [styleClass]=\"classBySeverity()\"\r\n [(visible)]=\"display\"\r\n [modal]=\"true\"\r\n [baseZIndex]=\"10000\"\r\n [closable]=\"false\"\r\n [resizable]=\"false\"\r\n [draggable]=\"false\">\r\n\r\n <!-- Header -->\r\n <ng-template pTemplate=\"header\">\r\n <i class=\"pi {{ iconBySeverity() }} header_icon\"></i>\r\n <span class=\"header_text\">{{ headerBySeverity() }}</span>\r\n </ng-template>\r\n\r\n <!-- Content -->\r\n <p class=\"content mb-3\"\r\n [innerHTML]=\"message?.content\">\r\n </p>\r\n\r\n <!-- Boutons -->\r\n <button pButton\r\n *ngIf=\"message?.closable == true && message?.refresh == false\"\r\n icon=\"pi pi-check\"\r\n (click)=\"display=false\"\r\n label=\"Ok\"\r\n style=\"float:right;\"\r\n class=\"p-button-text\">\r\n </button>\r\n <button pButton\r\n *ngIf=\"message?.refresh == true\"\r\n icon=\"pi pi-refresh\"\r\n (click)=\"refreshPage()\"\r\n label=\"Rafra\u00EEchir\"\r\n style=\"float:right;\"\r\n class=\"p-button-text\">\r\n </button>\r\n\r\n</p-dialog>\r\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: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i3$1.Dialog, selector: "p-dialog", inputs: ["header", "draggable", "resizable", "positionLeft", "positionTop", "contentStyle", "contentStyleClass", "modal", "closeOnEscape", "dismissableMask", "rtl", "closable", "responsive", "appendTo", "breakpoints", "styleClass", "maskStyleClass", "maskStyle", "showHeader", "breakpoint", "blockScroll", "autoZIndex", "baseZIndex", "minX", "minY", "focusOnShow", "maximizable", "keepInViewport", "focusTrap", "transitionOptions", "closeIcon", "closeAriaLabel", "closeTabindex", "minimizeIcon", "maximizeIcon", "visible", "style", "position"], 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: ["iconPos", "loadingIcon", "label", "icon", "loading", "severity", "raised", "rounded", "text", "outlined", "size", "plain"] }] }); }
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"] }] });
146
160
  }
147
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: CilogMessageComponent, decorators: [{
161
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "21.0.6", ngImport: i0, type: CilogMessageComponent, decorators: [{
148
162
  type: Component,
149
- args: [{ selector: 'cilog-message', template: "<p-dialog [styleClass]=\"classBySeverity()\"\r\n [(visible)]=\"display\"\r\n [modal]=\"true\"\r\n [baseZIndex]=\"10000\"\r\n [closable]=\"false\"\r\n [resizable]=\"false\"\r\n [draggable]=\"false\">\r\n\r\n <!-- Header -->\r\n <ng-template pTemplate=\"header\">\r\n <i class=\"pi {{ iconBySeverity() }} header_icon\"></i>\r\n <span class=\"header_text\">{{ headerBySeverity() }}</span>\r\n </ng-template>\r\n\r\n <!-- Content -->\r\n <p class=\"content mb-3\"\r\n [innerHTML]=\"message?.content\">\r\n </p>\r\n\r\n <!-- Boutons -->\r\n <button pButton\r\n *ngIf=\"message?.closable == true && message?.refresh == false\"\r\n icon=\"pi pi-check\"\r\n (click)=\"display=false\"\r\n label=\"Ok\"\r\n style=\"float:right;\"\r\n class=\"p-button-text\">\r\n </button>\r\n <button pButton\r\n *ngIf=\"message?.refresh == true\"\r\n icon=\"pi pi-refresh\"\r\n (click)=\"refreshPage()\"\r\n label=\"Rafra\u00EEchir\"\r\n style=\"float:right;\"\r\n class=\"p-button-text\">\r\n </button>\r\n\r\n</p-dialog>\r\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"] }]
150
166
  }], ctorParameters: () => [{ type: CilogMessageService }] });
151
167
 
152
- class CilogLibComponent {
153
- constructor() { }
154
- ngOnInit() {
155
- }
156
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: CilogLibComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
157
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: CilogLibComponent, selector: "lib-cilog-lib", ngImport: i0, template: `
158
- <p>
159
- cilog-lib works!
160
- </p>
161
- `, isInline: true }); }
162
- }
163
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: CilogLibComponent, decorators: [{
164
- type: Component,
165
- args: [{ selector: 'lib-cilog-lib', template: `
166
- <p>
167
- cilog-lib works!
168
- </p>
169
- ` }]
170
- }], ctorParameters: () => [] });
171
-
172
- class PrimengModule {
173
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: PrimengModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
174
- static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "17.3.12", ngImport: i0, type: PrimengModule, imports: [CommonModule], exports: [DialogModule,
175
- ButtonModule,
176
- TableModule,
177
- InputTextModule,
178
- SelectButtonModule,
179
- DropdownModule,
180
- InputNumberModule,
181
- ConfirmDialogModule,
182
- MultiSelectModule,
183
- CalendarModule,
184
- ContextMenuModule,
185
- TagModule,
186
- TooltipModule,
187
- InputSwitchModule,
188
- SkeletonModule,
189
- EditorModule,
190
- TabViewModule] }); }
191
- static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: PrimengModule, imports: [CommonModule, DialogModule,
192
- ButtonModule,
193
- TableModule,
194
- InputTextModule,
195
- SelectButtonModule,
196
- DropdownModule,
197
- InputNumberModule,
198
- ConfirmDialogModule,
199
- MultiSelectModule,
200
- CalendarModule,
201
- ContextMenuModule,
202
- TagModule,
203
- TooltipModule,
204
- InputSwitchModule,
205
- SkeletonModule,
206
- EditorModule,
207
- TabViewModule] }); }
208
- }
209
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: PrimengModule, decorators: [{
210
- type: NgModule,
211
- args: [{
212
- declarations: [],
213
- exports: [
214
- DialogModule,
215
- ButtonModule,
216
- TableModule,
217
- InputTextModule,
218
- SelectButtonModule,
219
- DropdownModule,
220
- InputNumberModule,
221
- ConfirmDialogModule,
222
- MultiSelectModule,
223
- CalendarModule,
224
- ContextMenuModule,
225
- TagModule,
226
- TooltipModule,
227
- InputSwitchModule,
228
- SkeletonModule,
229
- EditorModule,
230
- TabViewModule
231
- ],
232
- imports: [
233
- CommonModule
234
- ]
235
- }]
236
- }] });
237
-
238
168
  var Position;
239
169
  (function (Position) {
240
170
  Position["Right"] = "right";
@@ -286,194 +216,54 @@ var ModeCalendar;
286
216
  ModeCalendar["DateHour"] = "datehour";
287
217
  })(ModeCalendar || (ModeCalendar = {}));
288
218
 
289
- class ExportService {
290
- constructor() { }
291
- exportExcel(values, columns, byFiltre, withColors) {
292
- // Workbook
293
- let wb = new Excel.Workbook();
294
- // Worksheet
295
- let ws = wb.addWorksheet('Export', {
296
- properties: { defaultColWidth: 20 },
297
- });
298
- // Colonnes
299
- let cols = [];
300
- columns = columns.filter(col => !col.invisible);
301
- columns.forEach(col => {
302
- if (!byFiltre || col.exportable == true) {
303
- let colExcel = {
304
- header: col.libelle,
305
- key: col.id,
306
- style: this.getStyleByType(col.type)
307
- };
308
- if (col.width != null && col.width.includes('px')) {
309
- const px = parseInt(col.width.replace('px', '').trim(), 10);
310
- const excelWidth = px / 7;
311
- colExcel.width = parseFloat(excelWidth.toFixed(2));
312
- }
313
- cols.push(colExcel);
314
- }
315
- });
316
- ws.columns = cols;
317
- // Lignes
318
- values.forEach(row => {
319
- if (!byFiltre || row.exportable == true) {
320
- let rowExcel = {};
321
- columns.filter(obj => !byFiltre || obj.exportable == true).forEach(col => {
322
- if (row[col.id].excelSubstitution != null) {
323
- rowExcel[col.id] = row[col.id].excelSubstitution;
324
- }
325
- else {
326
- rowExcel[col.id] = this.getValueByType(row[col.id], col);
327
- }
328
- });
329
- // Application du style de chaque cellule
330
- let result = ws.addRow(rowExcel);
331
- columns.filter(obj => !byFiltre || obj.exportable == true).forEach((col, index) => {
332
- const cell = result.getCell(index + 1);
333
- if (row[col.id].bold) {
334
- cell.font = { bold: true };
335
- }
336
- if (withColors) {
337
- if ((row.color != null && row.color != '') || (row[col.id].color != null && row[col.id].color != '')) {
338
- cell.style.fill = {
339
- type: "pattern",
340
- pattern: "solid",
341
- fgColor: {
342
- argb: row[col.id].color != null ? this.getHexaColor(row[col.id].color) : this.getHexaColor(row.color)
343
- },
344
- bgColor: {
345
- argb: row[col.id].color != null ? this.getHexaColor(row[col.id].color) : this.getHexaColor(row.color)
346
- }
347
- };
348
- }
349
- }
350
- });
351
- }
352
- });
353
- // Style
354
- this.setStyleGlobalGrille(ws);
355
- // Sauvegarde
356
- wb.xlsx.writeBuffer().then(function (buffer) {
357
- const data = new Blob([buffer], {
358
- type: 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet',
359
- });
360
- FileSaver.saveAs(data, "Export Excel.xlsx");
361
- });
362
- }
363
- getHexaColor(color) {
364
- var ctx = document.createElement('canvas').getContext('2d');
365
- ctx.fillStyle = color;
366
- return ctx.fillStyle.replace('#', '');
367
- }
368
- setStyleGlobalGrille(ws) {
369
- ws.views = [
370
- { state: 'frozen', ySplit: 1 }
371
- ];
372
- ws.eachRow((row, rowNumber) => {
373
- row.eachCell({ includeEmpty: true }, (cell, number) => {
374
- if (rowNumber == 1) {
375
- cell.fill = {
376
- pattern: 'solid',
377
- type: 'pattern',
378
- fgColor: {
379
- argb: '2fab49',
380
- },
381
- };
382
- cell.alignment = { horizontal: 'center' };
383
- cell.alignment.vertical = 'middle';
384
- cell.font = {
385
- name: 'Arial',
386
- size: 10,
387
- bold: true
388
- };
389
- cell.border = {
390
- bottom: { style: 'thin' },
391
- top: { style: 'thin' },
392
- left: { style: 'thin' },
393
- right: { style: 'thin' },
394
- };
395
- }
396
- else {
397
- cell.border = {
398
- bottom: { style: 'thin' },
399
- top: { style: 'thin' },
400
- left: { style: 'thin' },
401
- right: { style: 'thin' },
402
- };
403
- }
404
- });
405
- });
406
- ws.autoFilter = {
407
- from: 'A1',
408
- to: this.columnIndexToColumnLetter(ws.columnCount).toString() + '1',
409
- };
410
- }
411
- columnIndexToColumnLetter(column) {
412
- var temp, letter = '';
413
- while (column > 0) {
414
- temp = (column - 1) % 26;
415
- letter = String.fromCharCode(temp + 65) + letter;
416
- column = (column - temp - 1) / 26;
417
- }
418
- return letter;
419
- }
420
- getValueByType(cell, col) {
421
- switch (col.type) {
422
- case ColType.MultiSelect:
423
- let optionLabelMulti = cell.options != null && cell.options.optionLabel != null ? cell.options.optionLabel : col.options.optionLabel;
424
- return cell.value.map(val => val[optionLabelMulti]).join(', ');
425
- case ColType.SelectButton:
426
- case ColType.Dropdown:
427
- case ColType.State:
428
- let optionLabel = cell.options != null && cell.options.optionLabel != null ? cell.options.optionLabel : col.options.optionLabel;
429
- return cell.value != null ? cell.value[optionLabel] : null;
430
- case ColType.Image:
431
- case ColType.Button:
432
- return null;
433
- case ColType.Switch:
434
- return cell.value == true ? 'Oui' : 'Non';
435
- case ColType.Date:
436
- if (cell.value != null) {
437
- 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';
438
- return new Date(dateStr);
439
- }
440
- else {
441
- return null;
442
- }
443
- default:
444
- 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 "";
445
229
  }
446
- }
447
- getStyleByType(type) {
448
- switch (type) {
449
- case ColType.Date:
450
- return { numFmt: 'dd/mm/yyyy' };
451
- case ColType.CilogNumber:
452
- case ColType.Number:
453
- return { numFmt: '#,##0.00' };
454
- default:
455
- return null;
230
+ else {
231
+ return obj;
456
232
  }
457
233
  }
458
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: ExportService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
459
- static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.3.12", 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" });
460
236
  }
461
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: ExportService, decorators: [{
462
- type: Injectable,
237
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "21.0.6", ngImport: i0, type: ValuePipe, decorators: [{
238
+ type: Pipe,
463
239
  args: [{
464
- providedIn: 'root'
240
+ name: 'value'
465
241
  }]
466
- }], ctorParameters: () => [] });
242
+ }] });
467
243
 
468
244
  class CilogInputNumberComponent {
469
- constructor() {
470
- this.onInput = new EventEmitter();
471
- this.onChange = new EventEmitter();
472
- this.onFocus = new EventEmitter();
473
- this.onBlur = new EventEmitter();
474
- this.valueStr = '';
475
- this.specialKeys = ['Tab', 'End', 'Home', 'ArrowLeft', 'ArrowRight'];
476
- }
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() { }
477
267
  ngOnInit() {
478
268
  this.regex = new RegExp(`^-?\\d{1,3}(?:\\d{3})*(?:[\\.,]\\d{0,${this.maxDecimals || Number.MAX_SAFE_INTEGER}})?$`);
479
269
  }
@@ -653,24 +443,14 @@ class CilogInputNumberComponent {
653
443
  registerOnTouched(fn) {
654
444
  this.onTouchedInput = fn;
655
445
  }
656
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: CilogInputNumberComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
657
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: CilogInputNumberComponent, 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: [
658
- {
659
- provide: NG_VALUE_ACCESSOR,
660
- useExisting: forwardRef(() => CilogInputNumberComponent),
661
- multi: true
662
- }
663
- ], viewQueries: [{ propertyName: "cilogInputNumber", first: true, predicate: ["cilogInputNumber"], descendants: true }], ngImport: i0, template: "<div class=\"input-group w-full\">\r\n\r\n <span class=\"input-group-addon prefixe\"\r\n *ngIf=\"prefixe != null\">\r\n {{ prefixe }}\r\n </span>\r\n\r\n <div [ngClass]=\"{ 'p-float-label' : floatLabel != null }\">\r\n <input #cilogInputNumber\r\n pInputText\r\n type=\"text\"\r\n [disabled]=\"disabled\"\r\n [readonly]=\"readonly\"\r\n [value]=\"valueStr\"\r\n (focus)=\"onFocusEvent($event)\"\r\n (blur)=\"onBlurEvent($event)\"\r\n [class]=\"'w-full z-1' + (inputStyleClass == null ? '' : ' ' + inputStyleClass)\"\r\n [ngClass]=\"suffixe != null && prefixe != null ? 'border-noround' : prefixe != null ? 'border-noround-left' : suffixe != null ? 'border-noround-right' : null\"\r\n [ngStyle]=\"{ 'color' : textColor ? textColor : null }\" />\r\n\r\n <label *ngIf=\"floatLabel != null\">{{ floatLabel }}</label>\r\n </div>\r\n\r\n <span class=\"input-group-addon suffixe\"\r\n *ngIf=\"suffixe != null\">\r\n {{ suffixe }}\r\n </span>\r\n\r\n</div>\r\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.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "directive", type: i2.InputText, selector: "[pInputText]", inputs: ["variant"] }] }); }
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"] }] });
664
448
  }
665
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: CilogInputNumberComponent, decorators: [{
449
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "21.0.6", ngImport: i0, type: CilogInputNumberComponent, decorators: [{
666
450
  type: Component,
667
- args: [{ selector: 'cilog-input-number', providers: [
668
- {
669
- provide: NG_VALUE_ACCESSOR,
670
- useExisting: forwardRef(() => CilogInputNumberComponent),
671
- multi: true
672
- }
673
- ], template: "<div class=\"input-group w-full\">\r\n\r\n <span class=\"input-group-addon prefixe\"\r\n *ngIf=\"prefixe != null\">\r\n {{ prefixe }}\r\n </span>\r\n\r\n <div [ngClass]=\"{ 'p-float-label' : floatLabel != null }\">\r\n <input #cilogInputNumber\r\n pInputText\r\n type=\"text\"\r\n [disabled]=\"disabled\"\r\n [readonly]=\"readonly\"\r\n [value]=\"valueStr\"\r\n (focus)=\"onFocusEvent($event)\"\r\n (blur)=\"onBlurEvent($event)\"\r\n [class]=\"'w-full z-1' + (inputStyleClass == null ? '' : ' ' + inputStyleClass)\"\r\n [ngClass]=\"suffixe != null && prefixe != null ? 'border-noround' : prefixe != null ? 'border-noround-left' : suffixe != null ? 'border-noround-right' : null\"\r\n [ngStyle]=\"{ 'color' : textColor ? textColor : null }\" />\r\n\r\n <label *ngIf=\"floatLabel != null\">{{ floatLabel }}</label>\r\n </div>\r\n\r\n <span class=\"input-group-addon suffixe\"\r\n *ngIf=\"suffixe != null\">\r\n {{ suffixe }}\r\n </span>\r\n\r\n</div>\r\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"] }]
674
454
  }], ctorParameters: () => [], propDecorators: { min: [{
675
455
  type: Input
676
456
  }], max: [{
@@ -711,50 +491,219 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
711
491
  args: ['keydown', ['$event']]
712
492
  }] } });
713
493
 
714
- class ValuePipe {
715
- transform(obj, ...args) {
716
- if (typeof obj === 'number') {
717
- if (isNaN(obj))
718
- return '0';
719
- if (!isFinite(obj))
720
- return '0';
721
- if (obj != null)
722
- return obj.toLocaleString('fr-FR', { maximumFractionDigits: 2 });
723
- 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;
724
622
  }
725
- else {
726
- 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;
727
661
  }
728
662
  }
729
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: ValuePipe, deps: [], target: i0.ɵɵFactoryTarget.Pipe }); }
730
- static { this.ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "14.0.0", version: "17.3.12", ngImport: i0, type: ValuePipe, 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' });
731
665
  }
732
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: ValuePipe, decorators: [{
733
- type: Pipe,
666
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "21.0.6", ngImport: i0, type: ExportService, decorators: [{
667
+ type: Injectable,
734
668
  args: [{
735
- name: 'value'
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: "17.3.12", 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: "14.0.0", version: "17.3.12", type: CilogTableComponent, 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%' }\">\r\n\r\n <button pButton\r\n *ngIf=\"options.exportExcel\"\r\n icon=\"pi pi-file-excel\"\r\n class=\"p-button-success absolute z-5 w-2rem h-2rem border-round-right border-noround-top\"\r\n pTooltip=\"Exporter le contenu de la grille au format Excel\"\r\n (click)=\"exportExcel(options.exportExcelByFiltre, !options.exportExcelNoColors)\">\r\n </button>\r\n\r\n <p-contextMenu #cm [model]=\"options.contextMenuItems\" />\r\n\r\n <p-table #table\r\n [columns]=\"columns\"\r\n [value]=\"values\"\r\n dataKey=\"id\"\r\n [selectionMode]=\"getModeSelection()\"\r\n [metaKeySelection]=\"isModeMetakeySelection()\"\r\n [(selection)]=\"selectedRows\"\r\n (onRowSelect)=\"onSelectRow($event)\"\r\n (onRowUnselect)=\"onUnselectRow($event)\"\r\n (onHeaderCheckboxToggle)=\"onSelectAll($event)\"\r\n (sortFunction)=\"sortGrille($event)\"\r\n [customSort]=\"options.grouping == null ? true : false\"\r\n [scrollable]=\"true\"\r\n [loading]=\"loading\"\r\n [scrollHeight]=\"'flex'\"\r\n [rowGroupMode]=\"options.grouping != null ? 'subheader' : null\"\r\n [groupRowsBy]=\"options.grouping != null ? options.grouping.obj + '.' + options.grouping.id : null\"\r\n [groupRowsByOrder]=\"0\"\r\n [virtualScroll]=\"options.virtualScroll == true && options.scrollHeight != null ? true : false\"\r\n [virtualScrollItemSize]=\"options.virtualScrollItemSize != null ? options.virtualScrollItemSize : 35\"\r\n [paginator]=\"options.paginator == null ? false : true\"\r\n [rows]=\"options.paginatorRows\"\r\n (onPage)=\"onPageTable($event)\"\r\n [tableStyleClass]=\"!options.themeGrille ? 'grid_grey' : options.themeGrille\"\r\n [lazy]=\"options.lazy == true ? true : false\"\r\n (onFilter)=\"onFilterTable($event)\"\r\n [rowTrackBy]=\"trackByFunction\"\r\n [(contextMenuSelection)]=\"contextMenuSelectedItem\"\r\n [contextMenu]=\"cm\">\r\n\r\n <!-- HEADER -->\r\n <ng-template pTemplate=\"header\" let-columns>\r\n\r\n <!-- HEADERS -->\r\n <tr class=\"rowHeader\">\r\n <th class=\"cellDelete\"\r\n *ngIf=\"isModeCheckboxSelection()\"\r\n pFrozenColumn>\r\n <p-tableHeaderCheckbox *ngIf=\"!options.filterable && options.toggleAll\"></p-tableHeaderCheckbox>\r\n </th>\r\n <ng-container *ngFor=\"let col of columns\">\r\n <th *ngIf=\"!col.invisible\"\r\n [ngStyle]=\"{ 'width' : col.width ? col.width : null, 'background-color': col.backgroundColor ? col.backgroundColor : null }\"\r\n [ngClass]=\"{ 'text-center' : options.centerHeaders, 'headerAffichageSimple': !options.headersAffichageEntier, 'headerAffichageEntier': options.headersAffichageEntier }\"\r\n [pSortableColumn]=\"col.id\"\r\n [pSortableColumnDisabled]=\"!options.sortable || options.grouping != null || col.libelle == null || col.libelle == ''\"\r\n id=\"{{ col.id }}\"\r\n (click)=\"refreshData()\"\r\n pFrozenColumn\r\n [frozen]=\"col.frozen\"\r\n [pTooltip]=\"col.libelle\"\r\n [tooltipDisabled]=\"!col.tooltipHeader\"\r\n tooltipPosition=\"bottom\">\r\n <div [ngStyle]=\"{ 'color': col.textColor ? col.textColor : null }\">\r\n {{ col.libelle }}\r\n </div>\r\n <p-sortIcon *ngIf=\"options.sortable && options.grouping == null && col.libelle != null && col.libelle != ''\"\r\n [field]=\"col.id\">\r\n </p-sortIcon>\r\n </th>\r\n </ng-container>\r\n <th class=\"cellDelete\" *ngIf=\"options.rowsDeletable\"></th>\r\n </tr>\r\n\r\n <!-- FILTRES -->\r\n <tr *ngIf=\"options.filterable\" class=\"rowFilter\">\r\n\r\n <th class=\"cellDelete\"\r\n *ngIf=\"isModeCheckboxSelection()\"\r\n pFrozenColumn>\r\n <p-tableHeaderCheckbox *ngIf=\"options.toggleAll\"></p-tableHeaderCheckbox>\r\n </th>\r\n\r\n <ng-container *ngFor=\"let col of columns\">\r\n <!-- Text -->\r\n <th *ngIf=\"!col.invisible && ((checkType('Dropdown', col) && col.options.filterText)\r\n || (checkType('MultiSelect', col) && col.options.filterText)\r\n || checkType('Text', col)\r\n || checkType('File', col)\r\n || (checkType('Button', col) && col.options.filterCol))\r\n || checkType('Number', col)\r\n || checkType('CilogNumber', col)\"\r\n [ngStyle]=\"{ 'width' : col.width ? col.width : null }\"\r\n pFrozenColumn\r\n [frozen]=\"col.frozen\">\r\n <input *ngIf=\"!col.disableFilter\"\r\n pInputText\r\n type=\"text\"\r\n (input)=\"onFilterCol($event, col)\"\r\n [(ngModel)]=\"col.options.defaultFilters\">\r\n </th>\r\n\r\n <!-- Date -->\r\n <th *ngIf=\"!col.invisible && checkType('Date', col)\"\r\n [ngStyle]=\"{ 'width' : col.width ? col.width : null }\"\r\n pFrozenColumn\r\n [frozen]=\"col.frozen\">\r\n <p-calendar *ngIf=\"!col.disableFilter\"\r\n [view]=\"getOption(col, rowData, 'mode') == null ? 'date' : getOption(col, rowData, 'mode')\"\r\n [dateFormat]=\"getOption(col, rowData, 'mode') == 'year' ? 'yy' : getOption(col, rowData, 'mode') == 'month' ? 'mm/yy' : 'dd/mm/yy'\"\r\n [inputId]=\"col.id + '_filter'\"\r\n firstDayOfWeek=\"1\"\r\n [readonlyInput]=\"true\"\r\n appendTo=\"body\"\r\n selectionMode=\"range\"\r\n (onSelect)=\"onFilterCol($event, col)\"\r\n showButtonBar=\"true\"\r\n (onClearClick)=\"onFilterCol($event, col)\"\r\n [(ngModel)]=\"col.options.defaultFilters\">\r\n </p-calendar>\r\n </th>\r\n\r\n <!-- Liste -->\r\n <th *ngIf=\"!col.invisible && ((checkType('Dropdown', col) && !col.options.filterText) || (checkType('MultiSelect', col) && !col.options.filterText) || checkType('SelectButton', col) || checkType('State', col))\"\r\n [ngStyle]=\"{ 'width' : col.width ? col.width : null }\"\r\n pFrozenColumn\r\n [frozen]=\"col.frozen\">\r\n <p-multiSelect *ngIf=\"!col.disableFilter\"\r\n [options]=\"col.options?.options\"\r\n [filter]=\"true\"\r\n dataKey=\"ID\"\r\n [optionLabel]=\"col.options?.optionLabel\"\r\n appendTo=\"body\"\r\n emptyFilterMessage=\"Aucun r\u00E9sultat\"\r\n emptyMessage=\"Aucun r\u00E9sultat\"\r\n [virtualScroll]=\"true\"\r\n [virtualScrollItemSize]=\"35\"\r\n selectedItemsLabel=\"{0} selectionn\u00E9s\"\r\n (onChange)=\"onFilterCol($event, col)\"\r\n [(ngModel)]=\"col.options.defaultFilters\"\r\n [group]=\"col.options.optionGroupChildren != null ? true : false\"\r\n [optionGroupLabel]=\"col.options.optionGroupLabel\"\r\n [optionGroupChildren]=\"col.options.optionGroupChildren\"\r\n [showToggleAll]=\"false\"\r\n [showClear]=\"true\"\r\n (onClear)=\"onFilterCol(null, col)\">\r\n <ng-template let-group pTemplate=\"group\">\r\n <div>{{group[col.options.optionGroupLabel]}}</div>\r\n </ng-template>\r\n </p-multiSelect>\r\n </th>\r\n\r\n <!-- Switch -->\r\n <th *ngIf=\"!col.invisible && checkType('Switch', col)\"\r\n [ngStyle]=\"{ 'width' : col.width ? col.width : null }\"\r\n pFrozenColumn\r\n [frozen]=\"col.frozen\">\r\n <p-multiSelect *ngIf=\"!col.disableFilter\"\r\n [options]=\"optionsSwitch\"\r\n [showHeader]=\"false\"\r\n optionLabel=\"label\"\r\n optionValue=\"value\"\r\n appendTo=\"body\"\r\n emptyFilterMessage=\"Aucun r\u00E9sultat\"\r\n emptyMessage=\"Aucun r\u00E9sultat\"\r\n [virtualScrollItemSize]=\"30\"\r\n selectedItemsLabel=\"{0} selectionn\u00E9s\"\r\n (onChange)=\"onFilterCol($event, col)\"\r\n [(ngModel)]=\"col.options.defaultFilters\">\r\n </p-multiSelect>\r\n </th>\r\n\r\n <!-- Non filtrable -->\r\n <th *ngIf=\"!col.invisible && (checkType('Image', col) || (checkType('Button', col) && !col.options.filterCol))\"\r\n [ngStyle]=\"{ 'width' : col.width ? col.width : null }\"\r\n pFrozenColumn\r\n [frozen]=\"col.frozen\">\r\n </th>\r\n </ng-container>\r\n <th class=\"cellDelete\" *ngIf=\"options.rowsDeletable\"></th>\r\n </tr>\r\n\r\n <!-- TOTAL -->\r\n <tr *ngIf=\"options.rowTotal\"\r\n class=\"rowTotal\">\r\n <th class=\"cellDelete\"\r\n *ngIf=\"isModeCheckboxSelection()\"\r\n pFrozenColumn>\r\n </th>\r\n <ng-container *ngFor=\"let col of columns\">\r\n <th *ngIf=\"!col.invisible\"\r\n [ngStyle]=\"{ 'width' : col.width ? col.width : null }\"\r\n [ngClass]=\"{ 'text-center' : true }\"\r\n pFrozenColumn\r\n [frozen]=\"col.frozen\">\r\n <div>{{ getTotalStr(col) }}</div>\r\n </th>\r\n </ng-container>\r\n <th class=\"cellDelete\" *ngIf=\"options.rowsDeletable\"></th>\r\n </tr>\r\n </ng-template>\r\n\r\n <!--Groupheader-->\r\n <ng-template pTemplate=\"groupheader\" let-rowData>\r\n <tr pRowGroupHeader class=\"rowGrouping\">\r\n <td [attr.colspan]=\"columns.length\">\r\n <div class=\"text_bold\">{{ rowData[options.grouping.obj][options.grouping.libelle] }}</div>\r\n </td>\r\n </tr>\r\n </ng-template>\r\n\r\n <!-- Body -->\r\n <ng-template pTemplate=\"body\" let-rowData let-columns=\"columns\">\r\n <tr id=\"{{ rowData.id }}\"\r\n [ngStyle]=\"{ 'background-color': rowData.color ? rowData.color : null }\"\r\n [pSelectableRow]=\"rowData\"\r\n [pSelectableRowDisabled]=\"!options.selectable || isModeCheckboxSelection() || isModeCellSelection()\"\r\n (dblclick)=\"onRowDoubleClickEvent(rowData)\"\r\n [pContextMenuRow]=\"rowData\"\r\n [pContextMenuRowDisabled]=\"options.contextMenuItems == null\">\r\n\r\n <td *ngIf=\"isModeCheckboxSelection()\"\r\n class=\"cellDelete\"\r\n pFrozenColumn>\r\n <p-tableCheckbox [value]=\"rowData\" [disabled]=\"rowData.readonly\"></p-tableCheckbox>\r\n </td>\r\n\r\n <ng-container *ngFor=\"let col of columns\">\r\n\r\n <!-- Text -->\r\n <td *ngIf=\"!col.invisible && checkType('Text', col) && isModeEdition() && !rowData.readonly && !rowData[col.id]?.readonly\"\r\n [ngStyle]=\"{ 'width' : col.width ? col.width : null, 'background-color': rowData[col.id].color ? rowData[col.id].color : null }\"\r\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\r\n [pEditableColumn]=\"rowData\"\r\n [pEditableColumnField]=\"col.id\"\r\n [pTooltip]=\"rowData[col.id].tooltip != null ? rowData[col.id].tooltip : rowData[col.id].value\"\r\n [tooltipDisabled]=\"!col.tooltip\"\r\n tooltipPosition=\"bottom\"\r\n pFrozenColumn\r\n (click)=\"options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection && !rowData[col.id].disableSelection && onSelectCell(rowData[col.id])\"\r\n [frozen]=\"col.frozen\"\r\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>\r\n <p-cellEditor>\r\n <ng-template pTemplate=\"input\">\r\n <input pInputText\r\n type=\"text\"\r\n [(ngModel)]=\"rowData[col.id].value\"\r\n (blur)=\"onEditCell(rowData, col, rowData[col.id].value)\"\r\n (keydown.enter)=\"onEditCell(rowData, col, rowData[col.id].value)\"\r\n (keydown.tab)=\"onEditCell(rowData, col, rowData[col.id].value)\"\r\n (click)=\"onEditInitCell(rowData, col, rowData[col.id].value)\"\r\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>\r\n <ng-template pTemplate=\"output\">\r\n <div *ngIf=\"rowData[col.id]\"\r\n style=\"white-space: pre;\">\r\n {{ getFormattedText(col, rowData) }}\r\n </div>\r\n </ng-template>\r\n </p-cellEditor>\r\n </td>\r\n <td *ngIf=\"!col.invisible && checkType('Text', col) && (!isModeEdition() || rowData.readonly || rowData[col.id]?.readonly)\"\r\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])\"\r\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\r\n [pTooltip]=\"rowData[col.id].tooltip != null ? rowData[col.id].tooltip : rowData[col.id].value\"\r\n [tooltipDisabled]=\"!col.tooltip\"\r\n tooltipPosition=\"bottom\"\r\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\r\n [frozen]=\"col.frozen\">\r\n <div class=\"p-column-title\">\r\n {{ col.libelle }} :\r\n </div>\r\n <div *ngIf=\"rowData[col.id]\"\r\n style=\"white-space: pre;\">\r\n {{ getFormattedText(col, rowData) }}\r\n </div>\r\n </td>\r\n\r\n <!-- Dropdown -->\r\n <td *ngIf=\"!col.invisible && checkType('Dropdown', col) && isModeEdition() && !rowData.readonly && !rowData[col.id]?.readonly\"\r\n [ngStyle]=\"{ 'width' : col.width ? col.width : null, 'background-color': rowData[col.id].color ? rowData[col.id].color : null }\"\r\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])\"\r\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\r\n [pTooltip]=\"rowData[col.id].tooltip != null ? rowData[col.id].tooltip : rowData[col.id].value != null ? rowData[col.id].value[getOption(col, rowData, 'optionLabel')] : ''\"\r\n [tooltipDisabled]=\"!col.tooltip\"\r\n tooltipPosition=\"bottom\"\r\n pFrozenColumn\r\n [frozen]=\"col.frozen\"\r\n class=\"paddingCell\">\r\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\r\n <p-dropdown *ngIf=\"rowData[col.id] != null\"\r\n dataKey=\"ID\"\r\n [options]=\"getOption(col, rowData, 'options')\"\r\n [filter]=\"getOption(col, rowData, 'filter')\"\r\n [optionLabel]=\"getOption(col, rowData, 'optionLabel')\"\r\n [(ngModel)]=\"rowData[col.id].value\"\r\n [autoDisplayFirst]=\"false\"\r\n appendTo=\"body\"\r\n [showClear]=\"getOption(col, rowData, 'deletable')\"\r\n emptyFilterMessage=\"Aucun r\u00E9sultat\"\r\n emptyMessage=\"Aucun r\u00E9sultat\"\r\n [baseZIndex]=\"getOption(col, rowData, 'baseZIndex')\"\r\n [virtualScroll]=\"getOption(col, rowData, 'virtualScroll')\"\r\n [readonly]=\"rowData.readonly || rowData[col.id]?.readonly\"\r\n [virtualScrollItemSize]=\"30\"\r\n (onChange)=\"onEditCell(rowData, col, rowData[col.id].value)\"\r\n (onClear)=\"onEditCell(rowData, col, rowData[col.id].value)\">\r\n <ng-template let-data pTemplate=\"selectedItem\">\r\n <span *ngIf=\"data != null\"\r\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')] }}\r\n </span>\r\n <span *ngIf=\"data == null\"></span>\r\n </ng-template>\r\n </p-dropdown>\r\n </td>\r\n <td *ngIf=\"!col.invisible && checkType('Dropdown', col) && (rowData.readonly || rowData[col.id]?.readonly || !isModeEdition())\"\r\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])\"\r\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\r\n [pTooltip]=\"rowData[col.id].tooltip != null ? rowData[col.id].tooltip : rowData[col.id].value != null ? rowData[col.id].value[getOption(col, rowData, 'optionLabel')] : ''\"\r\n [tooltipDisabled]=\"!col.tooltip\"\r\n tooltipPosition=\"bottom\"\r\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\r\n [frozen]=\"col.frozen\">\r\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\r\n <div *ngIf=\"rowData[col.id]\">{{ rowData[col.id].value != null ? rowData[col.id].value[getOption(col, rowData, 'optionLabel')] : '' }}</div>\r\n </td>\r\n\r\n <!-- Cilog Number -->\r\n <td *ngIf=\"!col.invisible && checkType('CilogNumber', col) && isModeEdition() && !rowData.readonly && !rowData[col.id]?.readonly\"\r\n [ngStyle]=\"{ 'width' : col.width ? col.width : null, 'background-color': rowData[col.id].color ? rowData[col.id].color : null }\"\r\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\r\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])\"\r\n [pTooltip]=\"rowData[col.id].tooltip != null ? rowData[col.id].tooltip : rowData[col.id].value | value\"\r\n [tooltipDisabled]=\"!col.tooltip\"\r\n tooltipPosition=\"bottom\"\r\n pFrozenColumn\r\n [frozen]=\"col.frozen\">\r\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\r\n <cilog-input-number *ngIf=\"rowData[col.id] && !rowData.readonly && !rowData[col.id]?.readonly\"\r\n (onInput)=\"onInputNumber($event)\"\r\n [(ngModel)]=\"rowData[col.id].value\"\r\n [inputStyleClass]=\"col.position == null || col.position == 'right' ? 'text-right' : col.position == 'left' ? 'text-left' : 'text-center'\"\r\n [textColor]=\"rowData[col.id].textColor\"\r\n [bold]=\"rowData.bold == true || rowData[col.id].bold == true\"\r\n [italic]=\"rowData.italic == true || rowData[col.id].italic == true\"\r\n [suffixe]=\"getOption(col, rowData, 'suffix')\"\r\n [prefixe]=\"getOption(col, rowData, 'prefix') != null ? getOption(col, rowData, 'prefix') + ' ' : null\"\r\n [min]=\"getOption(col, rowData, 'min')\"\r\n [max]=\"getOption(col, rowData, 'max')\"\r\n [disabled]=\"rowData.readonly || rowData[col.id]?.readonly\"\r\n [maxDecimals]=\"getOption(col, rowData, 'modeInteger') != null && getOption(col, rowData, 'modeInteger') == true ? 0 : getOption(col, rowData, 'maxDecimales') != null ? getOption(col, rowData, 'maxDecimales') : 2 \"\r\n (onChange)=\"onEditCell(rowData, col, rowData[col.id].value)\"\r\n (onFocus)=\"onEditInitCell(rowData, col, rowData[col.id].value)\">\r\n </cilog-input-number>\r\n </td>\r\n <td *ngIf=\"!col.invisible && checkType('CilogNumber', col) && (rowData.readonly || rowData[col.id]?.readonly || !isModeEdition())\"\r\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])\"\r\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\r\n [pTooltip]=\"rowData[col.id].tooltip != null ? rowData[col.id].tooltip : rowData[col.id].value | value\"\r\n [tooltipDisabled]=\"!col.tooltip\"\r\n tooltipPosition=\"bottom\"\r\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\r\n [frozen]=\"col.frozen\">\r\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\r\n <div *ngIf=\"rowData[col.id]\">{{ getFormattedNumber(col, rowData, rowData[col.id].value) }}</div>\r\n </td>\r\n\r\n <!-- Number -->\r\n <td *ngIf=\"!col.invisible && checkType('Number', col) && isModeEdition() && !rowData.readonly && !rowData[col.id]?.readonly\"\r\n [ngStyle]=\"{ 'width' : col.width ? col.width : null, 'background-color': rowData[col.id].color ? rowData[col.id].color : null }\"\r\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\r\n [pTooltip]=\"rowData[col.id].tooltip != null ? rowData[col.id].tooltip : rowData[col.id].value | value\"\r\n [tooltipDisabled]=\"!col.tooltip\"\r\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\"\r\n pFrozenColumn\r\n [frozen]=\"col.frozen\"\r\n (click)=\"onClickCellNumber(rowData, col)\">\r\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\r\n <div *ngIf=\"rowData[col.id] && !rowData[col.id].focus\">\r\n {{ getFormattedNumber(col, rowData, rowData[col.id].value) }}\r\n </div>\r\n <p-inputNumber #inputNumber\r\n *ngIf=\"rowData[col.id] && !rowData.readonly && !rowData[col.id]?.readonly && rowData[col.id].focus == true\"\r\n locale=\"fr-FR\"\r\n (onInput)=\"onInputNumber($event)\"\r\n [(ngModel)]=\"rowData[col.id].value\"\r\n [showButtons]=\"getOption(col, rowData, 'showButtons')\"\r\n [inputStyleClass]=\"col.position == null || col.position == 'right' ? 'text-right' : col.position == 'left' ? 'text-left' : 'text-center'\"\r\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 }\"\r\n [suffix]=\"getOption(col, rowData, 'suffix')\"\r\n [prefix]=\"getOption(col, rowData, 'prefix') != null ? getOption(col, rowData, 'prefix') + ' ' : null\"\r\n [min]=\"getOption(col, rowData, 'min')\"\r\n [max]=\"getOption(col, rowData, 'max')\"\r\n [minFractionDigits]=\"getOption(col, rowData, 'modeInteger') != null && getOption(col, rowData, 'modeInteger') == true ? 0 : getOption(col, rowData, 'minDecimales') != null ? getOption(col, rowData, 'minDecimales') : 0\"\r\n [maxFractionDigits]=\"getOption(col, rowData, 'modeInteger') != null && getOption(col, rowData, 'modeInteger') == true ? 0 : getOption(col, rowData, 'maxDecimales') != null ? getOption(col, rowData, 'maxDecimales') : 2 \"\r\n (onBlur)=\"onEditCell(rowData, col, rowData[col.id].value)\"\r\n (onKeyDown)=\"onKeyDown($event, rowData, col, rowData[col.id].value)\"\r\n (onFocus)=\"onEditInitCell(rowData, col, rowData[col.id].value)\">\r\n </p-inputNumber>\r\n </td>\r\n <td *ngIf=\"!col.invisible && checkType('Number', col) && (rowData.readonly || rowData[col.id]?.readonly || !isModeEdition())\"\r\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 : '' }}\"\r\n [pTooltip]=\"rowData[col.id].tooltip != null ? rowData[col.id].tooltip : rowData[col.id].value | value\"\r\n [tooltipDisabled]=\"!col.tooltip\"\r\n tooltipPosition=\"bottom\"\r\n (click)=\"options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection && onSelectCell(rowData[col.id])\"\r\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\r\n [frozen]=\"col.frozen\">\r\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\r\n <div *ngIf=\"rowData[col.id]\">{{ getFormattedNumber(col, rowData, rowData[col.id].value) }}</div>\r\n </td>\r\n\r\n <!-- Date -->\r\n <td *ngIf=\"!col.invisible && checkType('Date', col) && isModeEdition() && !rowData.readonly && !rowData[col.id]?.readonly\"\r\n [ngStyle]=\"{ 'width' : col.width ? col.width : null, 'background-color': rowData[col.id].color ? rowData[col.id].color : null }\"\r\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\r\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])\"\r\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')\"\r\n [tooltipDisabled]=\"!col.tooltip\"\r\n tooltipPosition=\"bottom\"\r\n pFrozenColumn\r\n [frozen]=\"col.frozen\">\r\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\r\n <p-calendar [(ngModel)]=\"rowData[col.id].value\"\r\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')\"\r\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'\"\r\n [showTime]=\"getOption(col, rowData, 'mode') == 'datehour'\"\r\n [timeOnly]=\"getOption(col, rowData, 'mode') == 'hour'\"\r\n [hourFormat]=\"24\"\r\n firstDayOfWeek=\"1\"\r\n (onSelect)=\"onEditCell(rowData, col, rowData[col.id].value)\"\r\n (onBlur)=\"onEditCell(rowData, col, rowData[col.id].value)\"\r\n (onClear)=\"onEditCell(rowData, col, rowData[col.id].value)\"\r\n [inputStyleClass]=\"col.position == null || col.position == 'right' ? 'text-right' : col.position == 'left' ? 'text-left' : 'text-center'\"\r\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 }\"\r\n [showClear]=\"getOption(col, rowData, 'clear')\"\r\n [minDate]=\"getOption(col, rowData, 'minDate')\"\r\n [maxDate]=\"getOption(col, rowData, 'maxDate')\"\r\n [defaultDate]=\"getOption(col, rowData, 'defaultDate')\"\r\n appendTo=\"body\">\r\n </p-calendar>\r\n </td>\r\n <td *ngIf=\"!col.invisible && checkType('Date', col) && (rowData.readonly || rowData[col.id]?.readonly || !isModeEdition())\"\r\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])\"\r\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\r\n [pTooltip]=\"rowData[col.id].tooltip != null ? rowData[col.id].tooltip : rowData[col.id].value | date: 'dd/MM/yyyy'\"\r\n [tooltipDisabled]=\"!col.tooltip\"\r\n tooltipPosition=\"bottom\"\r\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\r\n [frozen]=\"col.frozen\">\r\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\r\n <div *ngIf=\"rowData[col.id]\">{{ rowData[col.id].value | date: (getOption(col, rowData, 'mode') == 'year' ? 'yyyy' : getOption(col, rowData, 'mode') == 'month' ? 'MM/yyyy' : 'dd/MM/yyyy') }}</div>\r\n </td>\r\n\r\n <!-- MultiSelect -->\r\n <td *ngIf=\"!col.invisible && checkType('MultiSelect', col) && isModeEdition() && !rowData.readonly && !rowData[col.id]?.readonly\"\r\n [ngStyle]=\"{ 'width' : col.width ? col.width : null, 'background-color': rowData[col.id].color ? rowData[col.id].color : null }\"\r\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\r\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])\"\r\n [pTooltip]=\"rowData[col.id].tooltip != null ? rowData[col.id].tooltip : getMultiSelectConcat(rowData[col.id].value, getOption(col, rowData, 'optionLabel'))\"\r\n [tooltipDisabled]=\"!col.tooltip\"\r\n tooltipPosition=\"bottom\"\r\n pFrozenColumn\r\n [frozen]=\"col.frozen\"\r\n class=\"paddingCell\">\r\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\r\n <p-multiSelect *ngIf=\"rowData[col.id] != null\"\r\n [options]=\"getOption(col, rowData, 'options')\"\r\n [filter]=\"getOption(col, rowData, 'filter')\"\r\n [optionLabel]=\"getOption(col, rowData, 'optionLabel')\"\r\n [(ngModel)]=\"rowData[col.id].value\"\r\n appendTo=\"body\"\r\n dataKey=\"ID\"\r\n emptyFilterMessage=\"Aucun r\u00E9sultat\"\r\n emptyMessage=\"Aucun r\u00E9sultat\"\r\n [baseZIndex]=\"getOption(col, rowData, 'baseZIndex')\"\r\n [virtualScroll]=\"getOption(col, rowData, 'virtualScroll')\"\r\n [readonly]=\"rowData.readonly || rowData[col.id]?.readonly || !isModeEdition()\"\r\n [virtualScrollItemSize]=\"30\"\r\n selectedItemsLabel=\"{0} selectionn\u00E9s\"\r\n (onChange)=\"editMultiselect(rowData, col, $event)\"\r\n [showToggleAll]=\"false\"\r\n [showHeader]=\"getOption(col, rowData, 'filter')\"\r\n [group]=\"getOption(col, rowData, 'optionGroupChildren') != null ? true : false\"\r\n [optionGroupLabel]=\"getOption(col, rowData, 'optionGroupLabel')\"\r\n [optionGroupChildren]=\"getOption(col, rowData, 'optionGroupChildren')\"\r\n ngDefaultControl>\r\n <ng-template let-data pTemplate=\"selectedItems\">\r\n <span *ngFor=\"let option of data, let i = index\"\r\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 ? ',' : '') }}\r\n </span>\r\n </ng-template>\r\n <ng-template let-group pTemplate=\"group\">\r\n <div>{{group[col.options.optionGroupLabel]}}</div>\r\n </ng-template>\r\n </p-multiSelect>\r\n </td>\r\n <td *ngIf=\"!col.invisible && checkType('MultiSelect', col) && (rowData.readonly || rowData[col.id]?.readonly || !isModeEdition())\"\r\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])\"\r\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\r\n [pTooltip]=\"rowData[col.id].tooltip != null ? rowData[col.id].tooltip : getMultiSelectConcat(rowData[col.id].value, getOption(col, rowData, 'optionLabel'))\"\r\n [tooltipDisabled]=\"!col.tooltip\"\r\n tooltipPosition=\"bottom\"\r\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\r\n [frozen]=\"col.frozen\">\r\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\r\n <div *ngIf=\"rowData[col.id]\">{{ getMultiSelectConcat(rowData[col.id].value, getOption(col, rowData, 'optionLabel')) }}</div>\r\n </td>\r\n\r\n <!-- Image -->\r\n <td *ngIf=\"!col.invisible && checkType('Image', col)\"\r\n [ngStyle]=\"{ 'width' : col.width ? col.width : null, 'background-color': rowData[col.id].color ? rowData[col.id].color : null }\"\r\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\r\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])\"\r\n class=\"text-center\"\r\n pFrozenColumn\r\n [frozen]=\"col.frozen\">\r\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\r\n <img *ngIf=\"rowData[col.id]\" style=\"vertical-align: middle; width: 40px;\" src=\"{{ rowData[col.id].value }}\" />\r\n </td>\r\n\r\n <!-- Button -->\r\n <td *ngIf=\"!col.invisible && checkType('Button', col)\"\r\n class=\"paddingCell text-center\"\r\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])\"\r\n [ngStyle]=\"{ 'width' : col.width ? col.width : null, 'background-color': rowData[col.id].color ? rowData[col.id].color : null }\">\r\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\r\n <button pButton\r\n *ngIf=\"rowData[col.id].value != null && isValueButtonByType(rowData[col.id].value, 'function')\"\r\n [disabled]=\"rowData.readonly || rowData[col.id]?.readonly\"\r\n [label]=\"getOption(col, rowData, 'label')\"\r\n [icon]=\"getOption(col, rowData, 'icon')\"\r\n (click)=\"rowData[col.id].value()\"\r\n [pTooltip]=\"rowData[col.id].tooltip != null ? rowData[col.id].tooltip : getOption(col, rowData, 'label')\"\r\n [tooltipDisabled]=\"!col.tooltip\"\r\n [class]=\"'p-button-' + getOption(col, rowData, 'severity')\"\r\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>\r\n <div *ngIf=\"isValueButtonByType(rowData[col.id].value, 'string')\"\r\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\"\r\n [tooltipDisabled]=\"!col.tooltip\">\r\n {{ rowData[col.id].value }}\r\n </div>\r\n </td>\r\n\r\n <!-- SelectButton -->\r\n <td *ngIf=\"!col.invisible && checkType('SelectButton', col) && isModeEdition() && !rowData.readonly && !rowData[col.id]?.readonly\"\r\n [ngStyle]=\"{ 'width' : col.width ? col.width : null, 'background-color': rowData[col.id].color ? rowData[col.id].color : null }\"\r\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\r\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])\"\r\n pFrozenColumn\r\n [frozen]=\"col.frozen\">\r\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\r\n <p-selectButton *ngIf=\"rowData[col.id] != null\"\r\n [options]=\"getOption(col, rowData, 'options')\"\r\n [optionLabel]=\"getOption(col, rowData, 'optionLabel')\"\r\n [optionValue]=\"getOption(col, rowData, 'optionValue') != null ? getOption(col, rowData, 'optionValue') : 'value'\"\r\n [(ngModel)]=\"rowData[col.id].value\"\r\n [disabled]=\"rowData.readonly || rowData[col.id]?.readonly || !isModeEdition()\"\r\n (onChange)=\"onEditCell(rowData, col, rowData[col.id].value)\">\r\n <ng-template let-item pTemplate=\"item\">\r\n <span class=\"text-center w-full\"\r\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 }}\r\n </span>\r\n </ng-template>\r\n </p-selectButton>\r\n </td>\r\n <td *ngIf=\"!col.invisible && checkType('SelectButton', col) && (rowData.readonly || rowData[col.id]?.readonly || !isModeEdition())\"\r\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])\"\r\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\r\n pFrozenColumn\r\n [frozen]=\"col.frozen\"\r\n class=\"text-center\"\r\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>\r\n <div *ngIf=\"rowData[col.id]\">{{ getSelectLibelleByValue(rowData, col) }}</div>\r\n </td>\r\n\r\n <!-- Switch -->\r\n <td *ngIf=\"!col.invisible && checkType('Switch', col)\"\r\n [ngStyle]=\"{ 'width' : col.width ? col.width : null, 'background-color': rowData[col.id].color ? rowData[col.id].color : null }\"\r\n class=\"text-center\"\r\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\r\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])\"\r\n pFrozenColumn\r\n [frozen]=\"col.frozen\">\r\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\r\n <p-inputSwitch *ngIf=\"rowData[col.id] != null\"\r\n [(ngModel)]=\"rowData[col.id].value\"\r\n [disabled]=\"rowData.readonly || rowData[col.id]?.readonly || (getOption(col, rowData, 'action') == null && !isModeEdition())\"\r\n (onChange)=\"onEditCell(rowData, col, rowData[col.id].value)\"\r\n ngDefaultControl>\r\n </p-inputSwitch>\r\n </td>\r\n\r\n <!-- File -->\r\n <td *ngIf=\"!col.invisible && checkType('File', col) && isModeEdition() && !rowData.readonly && !rowData[col.id]?.readonly\"\r\n [ngStyle]=\"{ 'width' : col.width ? col.width : null, 'background-color': rowData[col.id].color ? rowData[col.id].color : null }\"\r\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\r\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])\"\r\n pFrozenColumn\r\n [frozen]=\"col.frozen\">\r\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\r\n <div class=\"p-inputgroup\" *ngIf=\"rowData[col.id] != null\">\r\n <button type=\"button\"\r\n pButton\r\n pRipple\r\n icon=\"pi pi-upload\"\r\n (click)=\"clickById('input_' + rowData[col.id].id)\"\r\n [disabled]=\"rowData.readonly || rowData[col.id]?.readonly || !isModeEdition()\">\r\n </button>\r\n <input id=\"{{'output_' + rowData[col.id].id}}\"\r\n pInputText\r\n type=\"text\"\r\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 : '' }}\"\r\n readonly\r\n [pTooltip]=\"rowData[col.id].tooltip != null ? rowData[col.id].tooltip : rowData[col.id].value ? rowData[col.id].value : ''\"\r\n [tooltipDisabled]=\"!col.tooltip\">\r\n <button *ngIf=\"getOption(col, rowData, 'downloadPath') && rowData[col.id].value != null\"\r\n type=\"button\"\r\n pButton\r\n pRipple\r\n icon=\"pi pi-download\"\r\n (click)=\"downloadFile(rowData[col.id])\"\r\n [disabled]=\"rowData.readonly || rowData[col.id]?.readonly || !isModeEdition()\">\r\n </button>\r\n </div>\r\n <input *ngIf=\"rowData[col.id]\" 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])\">\r\n </td>\r\n <td *ngIf=\"!col.invisible && checkType('File', col) && (rowData.readonly || rowData[col.id]?.readonly || !isModeEdition())\"\r\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])\"\r\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\r\n [pTooltip]=\"rowData[col.id].tooltip != null ? rowData[col.id].tooltip : rowData[col.id].value ? rowData[col.id].value : ''\"\r\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\"\r\n tooltipPosition=\"bottom\"\r\n pFrozenColumn\r\n [frozen]=\"col.frozen\">\r\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\r\n <div *ngIf=\"rowData[col.id]\">{{ rowData[col.id].value ? rowData[col.id].value : '' }}</div>\r\n </td>\r\n\r\n <!-- State -->\r\n <td *ngIf=\"!col.invisible && checkType('State', col)\"\r\n [ngStyle]=\"{ 'width' : col.width ? col.width : null, 'background-color': rowData[col.id].color ? rowData[col.id].color : null }\"\r\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\r\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])\"\r\n class=\"text-center\"\r\n pFrozenColumn\r\n [frozen]=\"col.frozen\">\r\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\r\n <p-tag *ngIf=\"rowData[col.id].value != null\"\r\n [value]=\"rowData[col.id].value[getOption(col, rowData, 'optionLabel')]\"\r\n [severity]=\"rowData[col.id].value.severity\"\r\n [icon]=\"rowData[col.id].value.icon\"\r\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>\r\n </td>\r\n\r\n </ng-container>\r\n\r\n <!-- Deletion -->\r\n <td *ngIf=\"options.rowsDeletable\"\r\n class=\"cellDelete\"\r\n [ngClass]=\"rowData.deletable ? 'paddingCell' : null\">\r\n <button *ngIf=\"rowData.deletable\"\r\n pButton\r\n type=\"button\"\r\n icon=\"pi pi-times\"\r\n class=\"p-button-danger buttonDelete p-button-text\"\r\n [disabled]=\"rowData.readonly\"\r\n (click)=\"onDeleteLine(rowData)\">\r\n </button>\r\n </td>\r\n\r\n </tr>\r\n </ng-template>\r\n </p-table>\r\n</div>\r\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.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { 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: ["iconPos", "loadingIcon", "label", "icon", "loading", "severity", "raised", "rounded", "text", "outlined", "size", "plain"] }, { kind: "component", type: i5.Table, selector: "p-table", inputs: ["frozenColumns", "frozenValue", "style", "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", "scrollDirection", "rowGroupMode", "scrollHeight", "virtualScroll", "virtualScrollItemSize", "virtualScrollOptions", "virtualScrollDelay", "frozenWidth", "responsive", "contextMenu", "resizableColumns", "columnResizeMode", "reorderableColumns", "loading", "loadingIcon", "showLoader", "rowHover", "customSort", "showInitialSortBadge", "autoLayout", "exportFunction", "exportHeader", "stateKey", "stateStorage", "editMode", "groupRowsBy", "groupRowsByOrder", "responsiveLayout", "breakpoint", "paginatorLocale", "value", "columns", "first", "rows", "totalRecords", "sortField", "sortOrder", "multiSortMeta", "selection", "selectAll", "virtualRowHeight"], 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: ["disabled", "value", "index", "inputId", "name", "required", "ariaLabel"] }, { kind: "component", type: i5.TableHeaderCheckbox, selector: "p-tableHeaderCheckbox", inputs: ["disabled", "inputId", "name", "ariaLabel"] }, { kind: "directive", type: i2.InputText, selector: "[pInputText]", inputs: ["variant"] }, { kind: "component", type: i7.SelectButton, selector: "p-selectButton", inputs: ["options", "optionLabel", "optionValue", "optionDisabled", "unselectable", "tabindex", "multiple", "allowEmpty", "style", "styleClass", "ariaLabelledBy", "disabled", "dataKey", "autofocus"], outputs: ["onOptionClick", "onChange"] }, { kind: "component", type: i8.Dropdown, selector: "p-dropdown", inputs: ["id", "scrollHeight", "filter", "name", "style", "panelStyle", "styleClass", "panelStyleClass", "readonly", "required", "editable", "appendTo", "tabindex", "placeholder", "loadingIcon", "filterPlaceholder", "filterLocale", "variant", "inputId", "dataKey", "filterBy", "filterFields", "autofocus", "resetFilterOnHide", "checkmark", "dropdownIcon", "loading", "optionLabel", "optionValue", "optionDisabled", "optionGroupLabel", "optionGroupChildren", "autoDisplayFirst", "group", "showClear", "emptyFilterMessage", "emptyMessage", "lazy", "virtualScroll", "virtualScrollItemSize", "virtualScrollOptions", "overlayOptions", "ariaFilterLabel", "ariaLabel", "ariaLabelledBy", "filterMatchMode", "maxlength", "tooltip", "tooltipPosition", "tooltipPositionStyle", "tooltipStyleClass", "focusOnHover", "selectOnFocus", "autoOptionFocus", "autofocusFilter", "autoShowPanelOnPrintableCharacterKeyDown", "disabled", "itemSize", "autoZIndex", "baseZIndex", "showTransitionOptions", "hideTransitionOptions", "filterValue", "options"], outputs: ["onChange", "onFilter", "onFocus", "onBlur", "onClick", "onShow", "onHide", "onClear", "onLazyLoad"] }, { kind: "component", type: i9.InputNumber, selector: "p-inputNumber", inputs: ["showButtons", "format", "buttonLayout", "inputId", "styleClass", "style", "placeholder", "size", "maxlength", "tabindex", "title", "ariaLabelledBy", "ariaLabel", "ariaRequired", "name", "required", "autocomplete", "min", "max", "incrementButtonClass", "decrementButtonClass", "incrementButtonIcon", "decrementButtonIcon", "readonly", "step", "allowEmpty", "locale", "localeMatcher", "mode", "currency", "currencyDisplay", "useGrouping", "variant", "minFractionDigits", "maxFractionDigits", "prefix", "suffix", "inputStyle", "inputStyleClass", "showClear", "autofocus", "disabled"], outputs: ["onInput", "onFocus", "onBlur", "onKeyDown", "onClear"] }, { kind: "component", type: i10.MultiSelect, selector: "p-multiSelect", inputs: ["id", "ariaLabel", "style", "styleClass", "panelStyle", "panelStyleClass", "inputId", "disabled", "readonly", "group", "filter", "filterPlaceHolder", "filterLocale", "overlayVisible", "tabindex", "variant", "appendTo", "dataKey", "name", "ariaLabelledBy", "displaySelectedLabel", "maxSelectedLabels", "selectionLimit", "selectedItemsLabel", "showToggleAll", "emptyFilterMessage", "emptyMessage", "resetFilterOnHide", "dropdownIcon", "optionLabel", "optionValue", "optionDisabled", "optionGroupLabel", "optionGroupChildren", "showHeader", "filterBy", "scrollHeight", "lazy", "virtualScroll", "loading", "virtualScrollItemSize", "loadingIcon", "virtualScrollOptions", "overlayOptions", "ariaFilterLabel", "filterMatchMode", "tooltip", "tooltipPosition", "tooltipPositionStyle", "tooltipStyleClass", "autofocusFilter", "display", "autocomplete", "showClear", "autofocus", "autoZIndex", "baseZIndex", "showTransitionOptions", "hideTransitionOptions", "defaultLabel", "placeholder", "options", "filterValue", "itemSize", "selectAll", "focusOnHover", "filterFields", "selectOnFocus", "autoOptionFocus"], outputs: ["onChange", "onFilter", "onFocus", "onBlur", "onClick", "onClear", "onPanelShow", "onPanelHide", "onLazyLoad", "onRemove", "onSelectAllChange"] }, { kind: "component", type: i11.Calendar, selector: "p-calendar", inputs: ["iconDisplay", "style", "styleClass", "inputStyle", "inputId", "name", "inputStyleClass", "placeholder", "ariaLabelledBy", "ariaLabel", "iconAriaLabel", "disabled", "dateFormat", "multipleSeparator", "rangeSeparator", "inline", "showOtherMonths", "selectOtherMonths", "showIcon", "icon", "appendTo", "readonlyInput", "shortYearCutoff", "monthNavigator", "yearNavigator", "hourFormat", "timeOnly", "stepYearPicker", "stepHour", "stepMinute", "stepSecond", "showSeconds", "required", "showOnFocus", "showWeek", "startWeekFromFirstDayOfYear", "showClear", "dataType", "selectionMode", "maxDateCount", "showButtonBar", "todayButtonStyleClass", "clearButtonStyleClass", "autofocus", "autoZIndex", "baseZIndex", "panelStyleClass", "panelStyle", "keepInvalid", "hideOnDateTimeSelect", "touchUI", "timeSeparator", "focusTrap", "showTransitionOptions", "hideTransitionOptions", "tabindex", "variant", "minDate", "maxDate", "disabledDates", "disabledDays", "yearRange", "showTime", "responsiveOptions", "numberOfMonths", "firstDayOfWeek", "locale", "view", "defaultDate"], outputs: ["onFocus", "onBlur", "onClose", "onSelect", "onClear", "onInput", "onTodayClick", "onClearClick", "onMonthChange", "onYearChange", "onClickOutside", "onShow"] }, { kind: "component", type: i12.ContextMenu, selector: "p-contextMenu", inputs: ["model", "triggerEvent", "target", "global", "style", "styleClass", "appendTo", "autoZIndex", "baseZIndex", "id", "ariaLabel", "ariaLabelledBy", "pressDelay"], outputs: ["onShow", "onHide"] }, { kind: "directive", type: i13.Tooltip, selector: "[pTooltip]", inputs: ["tooltipPosition", "tooltipEvent", "appendTo", "positionStyle", "tooltipStyleClass", "tooltipZIndex", "escape", "showDelay", "hideDelay", "life", "positionTop", "positionLeft", "autoHide", "fitContent", "hideOnEscape", "pTooltip", "tooltipDisabled", "tooltipOptions"] }, { kind: "component", type: i14.Tag, selector: "p-tag", inputs: ["style", "styleClass", "severity", "value", "icon", "rounded"] }, { kind: "component", type: i15.InputSwitch, selector: "p-inputSwitch", inputs: ["style", "styleClass", "tabindex", "inputId", "name", "disabled", "readonly", "trueValue", "falseValue", "ariaLabel", "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
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: CilogTableComponent, decorators: [{
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', template: "<div [ngStyle]=\"{ 'height': options.scrollHeight != null ? options.scrollHeight : '100%' }\">\r\n\r\n <button pButton\r\n *ngIf=\"options.exportExcel\"\r\n icon=\"pi pi-file-excel\"\r\n class=\"p-button-success absolute z-5 w-2rem h-2rem border-round-right border-noround-top\"\r\n pTooltip=\"Exporter le contenu de la grille au format Excel\"\r\n (click)=\"exportExcel(options.exportExcelByFiltre, !options.exportExcelNoColors)\">\r\n </button>\r\n\r\n <p-contextMenu #cm [model]=\"options.contextMenuItems\" />\r\n\r\n <p-table #table\r\n [columns]=\"columns\"\r\n [value]=\"values\"\r\n dataKey=\"id\"\r\n [selectionMode]=\"getModeSelection()\"\r\n [metaKeySelection]=\"isModeMetakeySelection()\"\r\n [(selection)]=\"selectedRows\"\r\n (onRowSelect)=\"onSelectRow($event)\"\r\n (onRowUnselect)=\"onUnselectRow($event)\"\r\n (onHeaderCheckboxToggle)=\"onSelectAll($event)\"\r\n (sortFunction)=\"sortGrille($event)\"\r\n [customSort]=\"options.grouping == null ? true : false\"\r\n [scrollable]=\"true\"\r\n [loading]=\"loading\"\r\n [scrollHeight]=\"'flex'\"\r\n [rowGroupMode]=\"options.grouping != null ? 'subheader' : null\"\r\n [groupRowsBy]=\"options.grouping != null ? options.grouping.obj + '.' + options.grouping.id : null\"\r\n [groupRowsByOrder]=\"0\"\r\n [virtualScroll]=\"options.virtualScroll == true && options.scrollHeight != null ? true : false\"\r\n [virtualScrollItemSize]=\"options.virtualScrollItemSize != null ? options.virtualScrollItemSize : 35\"\r\n [paginator]=\"options.paginator == null ? false : true\"\r\n [rows]=\"options.paginatorRows\"\r\n (onPage)=\"onPageTable($event)\"\r\n [tableStyleClass]=\"!options.themeGrille ? 'grid_grey' : options.themeGrille\"\r\n [lazy]=\"options.lazy == true ? true : false\"\r\n (onFilter)=\"onFilterTable($event)\"\r\n [rowTrackBy]=\"trackByFunction\"\r\n [(contextMenuSelection)]=\"contextMenuSelectedItem\"\r\n [contextMenu]=\"cm\">\r\n\r\n <!-- HEADER -->\r\n <ng-template pTemplate=\"header\" let-columns>\r\n\r\n <!-- HEADERS -->\r\n <tr class=\"rowHeader\">\r\n <th class=\"cellDelete\"\r\n *ngIf=\"isModeCheckboxSelection()\"\r\n pFrozenColumn>\r\n <p-tableHeaderCheckbox *ngIf=\"!options.filterable && options.toggleAll\"></p-tableHeaderCheckbox>\r\n </th>\r\n <ng-container *ngFor=\"let col of columns\">\r\n <th *ngIf=\"!col.invisible\"\r\n [ngStyle]=\"{ 'width' : col.width ? col.width : null, 'background-color': col.backgroundColor ? col.backgroundColor : null }\"\r\n [ngClass]=\"{ 'text-center' : options.centerHeaders, 'headerAffichageSimple': !options.headersAffichageEntier, 'headerAffichageEntier': options.headersAffichageEntier }\"\r\n [pSortableColumn]=\"col.id\"\r\n [pSortableColumnDisabled]=\"!options.sortable || options.grouping != null || col.libelle == null || col.libelle == ''\"\r\n id=\"{{ col.id }}\"\r\n (click)=\"refreshData()\"\r\n pFrozenColumn\r\n [frozen]=\"col.frozen\"\r\n [pTooltip]=\"col.libelle\"\r\n [tooltipDisabled]=\"!col.tooltipHeader\"\r\n tooltipPosition=\"bottom\">\r\n <div [ngStyle]=\"{ 'color': col.textColor ? col.textColor : null }\">\r\n {{ col.libelle }}\r\n </div>\r\n <p-sortIcon *ngIf=\"options.sortable && options.grouping == null && col.libelle != null && col.libelle != ''\"\r\n [field]=\"col.id\">\r\n </p-sortIcon>\r\n </th>\r\n </ng-container>\r\n <th class=\"cellDelete\" *ngIf=\"options.rowsDeletable\"></th>\r\n </tr>\r\n\r\n <!-- FILTRES -->\r\n <tr *ngIf=\"options.filterable\" class=\"rowFilter\">\r\n\r\n <th class=\"cellDelete\"\r\n *ngIf=\"isModeCheckboxSelection()\"\r\n pFrozenColumn>\r\n <p-tableHeaderCheckbox *ngIf=\"options.toggleAll\"></p-tableHeaderCheckbox>\r\n </th>\r\n\r\n <ng-container *ngFor=\"let col of columns\">\r\n <!-- Text -->\r\n <th *ngIf=\"!col.invisible && ((checkType('Dropdown', col) && col.options.filterText)\r\n || (checkType('MultiSelect', col) && col.options.filterText)\r\n || checkType('Text', col)\r\n || checkType('File', col)\r\n || (checkType('Button', col) && col.options.filterCol))\r\n || checkType('Number', col)\r\n || checkType('CilogNumber', col)\"\r\n [ngStyle]=\"{ 'width' : col.width ? col.width : null }\"\r\n pFrozenColumn\r\n [frozen]=\"col.frozen\">\r\n <input *ngIf=\"!col.disableFilter\"\r\n pInputText\r\n type=\"text\"\r\n (input)=\"onFilterCol($event, col)\"\r\n [(ngModel)]=\"col.options.defaultFilters\">\r\n </th>\r\n\r\n <!-- Date -->\r\n <th *ngIf=\"!col.invisible && checkType('Date', col)\"\r\n [ngStyle]=\"{ 'width' : col.width ? col.width : null }\"\r\n pFrozenColumn\r\n [frozen]=\"col.frozen\">\r\n <p-calendar *ngIf=\"!col.disableFilter\"\r\n [view]=\"getOption(col, rowData, 'mode') == null ? 'date' : getOption(col, rowData, 'mode')\"\r\n [dateFormat]=\"getOption(col, rowData, 'mode') == 'year' ? 'yy' : getOption(col, rowData, 'mode') == 'month' ? 'mm/yy' : 'dd/mm/yy'\"\r\n [inputId]=\"col.id + '_filter'\"\r\n firstDayOfWeek=\"1\"\r\n [readonlyInput]=\"true\"\r\n appendTo=\"body\"\r\n selectionMode=\"range\"\r\n (onSelect)=\"onFilterCol($event, col)\"\r\n showButtonBar=\"true\"\r\n (onClearClick)=\"onFilterCol($event, col)\"\r\n [(ngModel)]=\"col.options.defaultFilters\">\r\n </p-calendar>\r\n </th>\r\n\r\n <!-- Liste -->\r\n <th *ngIf=\"!col.invisible && ((checkType('Dropdown', col) && !col.options.filterText) || (checkType('MultiSelect', col) && !col.options.filterText) || checkType('SelectButton', col) || checkType('State', col))\"\r\n [ngStyle]=\"{ 'width' : col.width ? col.width : null }\"\r\n pFrozenColumn\r\n [frozen]=\"col.frozen\">\r\n <p-multiSelect *ngIf=\"!col.disableFilter\"\r\n [options]=\"col.options?.options\"\r\n [filter]=\"true\"\r\n dataKey=\"ID\"\r\n [optionLabel]=\"col.options?.optionLabel\"\r\n appendTo=\"body\"\r\n emptyFilterMessage=\"Aucun r\u00E9sultat\"\r\n emptyMessage=\"Aucun r\u00E9sultat\"\r\n [virtualScroll]=\"true\"\r\n [virtualScrollItemSize]=\"35\"\r\n selectedItemsLabel=\"{0} selectionn\u00E9s\"\r\n (onChange)=\"onFilterCol($event, col)\"\r\n [(ngModel)]=\"col.options.defaultFilters\"\r\n [group]=\"col.options.optionGroupChildren != null ? true : false\"\r\n [optionGroupLabel]=\"col.options.optionGroupLabel\"\r\n [optionGroupChildren]=\"col.options.optionGroupChildren\"\r\n [showToggleAll]=\"false\"\r\n [showClear]=\"true\"\r\n (onClear)=\"onFilterCol(null, col)\">\r\n <ng-template let-group pTemplate=\"group\">\r\n <div>{{group[col.options.optionGroupLabel]}}</div>\r\n </ng-template>\r\n </p-multiSelect>\r\n </th>\r\n\r\n <!-- Switch -->\r\n <th *ngIf=\"!col.invisible && checkType('Switch', col)\"\r\n [ngStyle]=\"{ 'width' : col.width ? col.width : null }\"\r\n pFrozenColumn\r\n [frozen]=\"col.frozen\">\r\n <p-multiSelect *ngIf=\"!col.disableFilter\"\r\n [options]=\"optionsSwitch\"\r\n [showHeader]=\"false\"\r\n optionLabel=\"label\"\r\n optionValue=\"value\"\r\n appendTo=\"body\"\r\n emptyFilterMessage=\"Aucun r\u00E9sultat\"\r\n emptyMessage=\"Aucun r\u00E9sultat\"\r\n [virtualScrollItemSize]=\"30\"\r\n selectedItemsLabel=\"{0} selectionn\u00E9s\"\r\n (onChange)=\"onFilterCol($event, col)\"\r\n [(ngModel)]=\"col.options.defaultFilters\">\r\n </p-multiSelect>\r\n </th>\r\n\r\n <!-- Non filtrable -->\r\n <th *ngIf=\"!col.invisible && (checkType('Image', col) || (checkType('Button', col) && !col.options.filterCol))\"\r\n [ngStyle]=\"{ 'width' : col.width ? col.width : null }\"\r\n pFrozenColumn\r\n [frozen]=\"col.frozen\">\r\n </th>\r\n </ng-container>\r\n <th class=\"cellDelete\" *ngIf=\"options.rowsDeletable\"></th>\r\n </tr>\r\n\r\n <!-- TOTAL -->\r\n <tr *ngIf=\"options.rowTotal\"\r\n class=\"rowTotal\">\r\n <th class=\"cellDelete\"\r\n *ngIf=\"isModeCheckboxSelection()\"\r\n pFrozenColumn>\r\n </th>\r\n <ng-container *ngFor=\"let col of columns\">\r\n <th *ngIf=\"!col.invisible\"\r\n [ngStyle]=\"{ 'width' : col.width ? col.width : null }\"\r\n [ngClass]=\"{ 'text-center' : true }\"\r\n pFrozenColumn\r\n [frozen]=\"col.frozen\">\r\n <div>{{ getTotalStr(col) }}</div>\r\n </th>\r\n </ng-container>\r\n <th class=\"cellDelete\" *ngIf=\"options.rowsDeletable\"></th>\r\n </tr>\r\n </ng-template>\r\n\r\n <!--Groupheader-->\r\n <ng-template pTemplate=\"groupheader\" let-rowData>\r\n <tr pRowGroupHeader class=\"rowGrouping\">\r\n <td [attr.colspan]=\"columns.length\">\r\n <div class=\"text_bold\">{{ rowData[options.grouping.obj][options.grouping.libelle] }}</div>\r\n </td>\r\n </tr>\r\n </ng-template>\r\n\r\n <!-- Body -->\r\n <ng-template pTemplate=\"body\" let-rowData let-columns=\"columns\">\r\n <tr id=\"{{ rowData.id }}\"\r\n [ngStyle]=\"{ 'background-color': rowData.color ? rowData.color : null }\"\r\n [pSelectableRow]=\"rowData\"\r\n [pSelectableRowDisabled]=\"!options.selectable || isModeCheckboxSelection() || isModeCellSelection()\"\r\n (dblclick)=\"onRowDoubleClickEvent(rowData)\"\r\n [pContextMenuRow]=\"rowData\"\r\n [pContextMenuRowDisabled]=\"options.contextMenuItems == null\">\r\n\r\n <td *ngIf=\"isModeCheckboxSelection()\"\r\n class=\"cellDelete\"\r\n pFrozenColumn>\r\n <p-tableCheckbox [value]=\"rowData\" [disabled]=\"rowData.readonly\"></p-tableCheckbox>\r\n </td>\r\n\r\n <ng-container *ngFor=\"let col of columns\">\r\n\r\n <!-- Text -->\r\n <td *ngIf=\"!col.invisible && checkType('Text', col) && isModeEdition() && !rowData.readonly && !rowData[col.id]?.readonly\"\r\n [ngStyle]=\"{ 'width' : col.width ? col.width : null, 'background-color': rowData[col.id].color ? rowData[col.id].color : null }\"\r\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\r\n [pEditableColumn]=\"rowData\"\r\n [pEditableColumnField]=\"col.id\"\r\n [pTooltip]=\"rowData[col.id].tooltip != null ? rowData[col.id].tooltip : rowData[col.id].value\"\r\n [tooltipDisabled]=\"!col.tooltip\"\r\n tooltipPosition=\"bottom\"\r\n pFrozenColumn\r\n (click)=\"options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection && !rowData[col.id].disableSelection && onSelectCell(rowData[col.id])\"\r\n [frozen]=\"col.frozen\"\r\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>\r\n <p-cellEditor>\r\n <ng-template pTemplate=\"input\">\r\n <input pInputText\r\n type=\"text\"\r\n [(ngModel)]=\"rowData[col.id].value\"\r\n (blur)=\"onEditCell(rowData, col, rowData[col.id].value)\"\r\n (keydown.enter)=\"onEditCell(rowData, col, rowData[col.id].value)\"\r\n (keydown.tab)=\"onEditCell(rowData, col, rowData[col.id].value)\"\r\n (click)=\"onEditInitCell(rowData, col, rowData[col.id].value)\"\r\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>\r\n <ng-template pTemplate=\"output\">\r\n <div *ngIf=\"rowData[col.id]\"\r\n style=\"white-space: pre;\">\r\n {{ getFormattedText(col, rowData) }}\r\n </div>\r\n </ng-template>\r\n </p-cellEditor>\r\n </td>\r\n <td *ngIf=\"!col.invisible && checkType('Text', col) && (!isModeEdition() || rowData.readonly || rowData[col.id]?.readonly)\"\r\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])\"\r\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\r\n [pTooltip]=\"rowData[col.id].tooltip != null ? rowData[col.id].tooltip : rowData[col.id].value\"\r\n [tooltipDisabled]=\"!col.tooltip\"\r\n tooltipPosition=\"bottom\"\r\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\r\n [frozen]=\"col.frozen\">\r\n <div class=\"p-column-title\">\r\n {{ col.libelle }} :\r\n </div>\r\n <div *ngIf=\"rowData[col.id]\"\r\n style=\"white-space: pre;\">\r\n {{ getFormattedText(col, rowData) }}\r\n </div>\r\n </td>\r\n\r\n <!-- Dropdown -->\r\n <td *ngIf=\"!col.invisible && checkType('Dropdown', col) && isModeEdition() && !rowData.readonly && !rowData[col.id]?.readonly\"\r\n [ngStyle]=\"{ 'width' : col.width ? col.width : null, 'background-color': rowData[col.id].color ? rowData[col.id].color : null }\"\r\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])\"\r\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\r\n [pTooltip]=\"rowData[col.id].tooltip != null ? rowData[col.id].tooltip : rowData[col.id].value != null ? rowData[col.id].value[getOption(col, rowData, 'optionLabel')] : ''\"\r\n [tooltipDisabled]=\"!col.tooltip\"\r\n tooltipPosition=\"bottom\"\r\n pFrozenColumn\r\n [frozen]=\"col.frozen\"\r\n class=\"paddingCell\">\r\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\r\n <p-dropdown *ngIf=\"rowData[col.id] != null\"\r\n dataKey=\"ID\"\r\n [options]=\"getOption(col, rowData, 'options')\"\r\n [filter]=\"getOption(col, rowData, 'filter')\"\r\n [optionLabel]=\"getOption(col, rowData, 'optionLabel')\"\r\n [(ngModel)]=\"rowData[col.id].value\"\r\n [autoDisplayFirst]=\"false\"\r\n appendTo=\"body\"\r\n [showClear]=\"getOption(col, rowData, 'deletable')\"\r\n emptyFilterMessage=\"Aucun r\u00E9sultat\"\r\n emptyMessage=\"Aucun r\u00E9sultat\"\r\n [baseZIndex]=\"getOption(col, rowData, 'baseZIndex')\"\r\n [virtualScroll]=\"getOption(col, rowData, 'virtualScroll')\"\r\n [readonly]=\"rowData.readonly || rowData[col.id]?.readonly\"\r\n [virtualScrollItemSize]=\"30\"\r\n (onChange)=\"onEditCell(rowData, col, rowData[col.id].value)\"\r\n (onClear)=\"onEditCell(rowData, col, rowData[col.id].value)\">\r\n <ng-template let-data pTemplate=\"selectedItem\">\r\n <span *ngIf=\"data != null\"\r\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')] }}\r\n </span>\r\n <span *ngIf=\"data == null\"></span>\r\n </ng-template>\r\n </p-dropdown>\r\n </td>\r\n <td *ngIf=\"!col.invisible && checkType('Dropdown', col) && (rowData.readonly || rowData[col.id]?.readonly || !isModeEdition())\"\r\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])\"\r\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\r\n [pTooltip]=\"rowData[col.id].tooltip != null ? rowData[col.id].tooltip : rowData[col.id].value != null ? rowData[col.id].value[getOption(col, rowData, 'optionLabel')] : ''\"\r\n [tooltipDisabled]=\"!col.tooltip\"\r\n tooltipPosition=\"bottom\"\r\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\r\n [frozen]=\"col.frozen\">\r\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\r\n <div *ngIf=\"rowData[col.id]\">{{ rowData[col.id].value != null ? rowData[col.id].value[getOption(col, rowData, 'optionLabel')] : '' }}</div>\r\n </td>\r\n\r\n <!-- Cilog Number -->\r\n <td *ngIf=\"!col.invisible && checkType('CilogNumber', col) && isModeEdition() && !rowData.readonly && !rowData[col.id]?.readonly\"\r\n [ngStyle]=\"{ 'width' : col.width ? col.width : null, 'background-color': rowData[col.id].color ? rowData[col.id].color : null }\"\r\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\r\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])\"\r\n [pTooltip]=\"rowData[col.id].tooltip != null ? rowData[col.id].tooltip : rowData[col.id].value | value\"\r\n [tooltipDisabled]=\"!col.tooltip\"\r\n tooltipPosition=\"bottom\"\r\n pFrozenColumn\r\n [frozen]=\"col.frozen\">\r\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\r\n <cilog-input-number *ngIf=\"rowData[col.id] && !rowData.readonly && !rowData[col.id]?.readonly\"\r\n (onInput)=\"onInputNumber($event)\"\r\n [(ngModel)]=\"rowData[col.id].value\"\r\n [inputStyleClass]=\"col.position == null || col.position == 'right' ? 'text-right' : col.position == 'left' ? 'text-left' : 'text-center'\"\r\n [textColor]=\"rowData[col.id].textColor\"\r\n [bold]=\"rowData.bold == true || rowData[col.id].bold == true\"\r\n [italic]=\"rowData.italic == true || rowData[col.id].italic == true\"\r\n [suffixe]=\"getOption(col, rowData, 'suffix')\"\r\n [prefixe]=\"getOption(col, rowData, 'prefix') != null ? getOption(col, rowData, 'prefix') + ' ' : null\"\r\n [min]=\"getOption(col, rowData, 'min')\"\r\n [max]=\"getOption(col, rowData, 'max')\"\r\n [disabled]=\"rowData.readonly || rowData[col.id]?.readonly\"\r\n [maxDecimals]=\"getOption(col, rowData, 'modeInteger') != null && getOption(col, rowData, 'modeInteger') == true ? 0 : getOption(col, rowData, 'maxDecimales') != null ? getOption(col, rowData, 'maxDecimales') : 2 \"\r\n (onChange)=\"onEditCell(rowData, col, rowData[col.id].value)\"\r\n (onFocus)=\"onEditInitCell(rowData, col, rowData[col.id].value)\">\r\n </cilog-input-number>\r\n </td>\r\n <td *ngIf=\"!col.invisible && checkType('CilogNumber', col) && (rowData.readonly || rowData[col.id]?.readonly || !isModeEdition())\"\r\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])\"\r\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\r\n [pTooltip]=\"rowData[col.id].tooltip != null ? rowData[col.id].tooltip : rowData[col.id].value | value\"\r\n [tooltipDisabled]=\"!col.tooltip\"\r\n tooltipPosition=\"bottom\"\r\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\r\n [frozen]=\"col.frozen\">\r\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\r\n <div *ngIf=\"rowData[col.id]\">{{ getFormattedNumber(col, rowData, rowData[col.id].value) }}</div>\r\n </td>\r\n\r\n <!-- Number -->\r\n <td *ngIf=\"!col.invisible && checkType('Number', col) && isModeEdition() && !rowData.readonly && !rowData[col.id]?.readonly\"\r\n [ngStyle]=\"{ 'width' : col.width ? col.width : null, 'background-color': rowData[col.id].color ? rowData[col.id].color : null }\"\r\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\r\n [pTooltip]=\"rowData[col.id].tooltip != null ? rowData[col.id].tooltip : rowData[col.id].value | value\"\r\n [tooltipDisabled]=\"!col.tooltip\"\r\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\"\r\n pFrozenColumn\r\n [frozen]=\"col.frozen\"\r\n (click)=\"onClickCellNumber(rowData, col)\">\r\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\r\n <div *ngIf=\"rowData[col.id] && !rowData[col.id].focus\">\r\n {{ getFormattedNumber(col, rowData, rowData[col.id].value) }}\r\n </div>\r\n <p-inputNumber #inputNumber\r\n *ngIf=\"rowData[col.id] && !rowData.readonly && !rowData[col.id]?.readonly && rowData[col.id].focus == true\"\r\n locale=\"fr-FR\"\r\n (onInput)=\"onInputNumber($event)\"\r\n [(ngModel)]=\"rowData[col.id].value\"\r\n [showButtons]=\"getOption(col, rowData, 'showButtons')\"\r\n [inputStyleClass]=\"col.position == null || col.position == 'right' ? 'text-right' : col.position == 'left' ? 'text-left' : 'text-center'\"\r\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 }\"\r\n [suffix]=\"getOption(col, rowData, 'suffix')\"\r\n [prefix]=\"getOption(col, rowData, 'prefix') != null ? getOption(col, rowData, 'prefix') + ' ' : null\"\r\n [min]=\"getOption(col, rowData, 'min')\"\r\n [max]=\"getOption(col, rowData, 'max')\"\r\n [minFractionDigits]=\"getOption(col, rowData, 'modeInteger') != null && getOption(col, rowData, 'modeInteger') == true ? 0 : getOption(col, rowData, 'minDecimales') != null ? getOption(col, rowData, 'minDecimales') : 0\"\r\n [maxFractionDigits]=\"getOption(col, rowData, 'modeInteger') != null && getOption(col, rowData, 'modeInteger') == true ? 0 : getOption(col, rowData, 'maxDecimales') != null ? getOption(col, rowData, 'maxDecimales') : 2 \"\r\n (onBlur)=\"onEditCell(rowData, col, rowData[col.id].value)\"\r\n (onKeyDown)=\"onKeyDown($event, rowData, col, rowData[col.id].value)\"\r\n (onFocus)=\"onEditInitCell(rowData, col, rowData[col.id].value)\">\r\n </p-inputNumber>\r\n </td>\r\n <td *ngIf=\"!col.invisible && checkType('Number', col) && (rowData.readonly || rowData[col.id]?.readonly || !isModeEdition())\"\r\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 : '' }}\"\r\n [pTooltip]=\"rowData[col.id].tooltip != null ? rowData[col.id].tooltip : rowData[col.id].value | value\"\r\n [tooltipDisabled]=\"!col.tooltip\"\r\n tooltipPosition=\"bottom\"\r\n (click)=\"options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection && onSelectCell(rowData[col.id])\"\r\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\r\n [frozen]=\"col.frozen\">\r\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\r\n <div *ngIf=\"rowData[col.id]\">{{ getFormattedNumber(col, rowData, rowData[col.id].value) }}</div>\r\n </td>\r\n\r\n <!-- Date -->\r\n <td *ngIf=\"!col.invisible && checkType('Date', col) && isModeEdition() && !rowData.readonly && !rowData[col.id]?.readonly\"\r\n [ngStyle]=\"{ 'width' : col.width ? col.width : null, 'background-color': rowData[col.id].color ? rowData[col.id].color : null }\"\r\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\r\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])\"\r\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')\"\r\n [tooltipDisabled]=\"!col.tooltip\"\r\n tooltipPosition=\"bottom\"\r\n pFrozenColumn\r\n [frozen]=\"col.frozen\">\r\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\r\n <p-calendar [(ngModel)]=\"rowData[col.id].value\"\r\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')\"\r\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'\"\r\n [showTime]=\"getOption(col, rowData, 'mode') == 'datehour'\"\r\n [timeOnly]=\"getOption(col, rowData, 'mode') == 'hour'\"\r\n [hourFormat]=\"24\"\r\n firstDayOfWeek=\"1\"\r\n (onSelect)=\"onEditCell(rowData, col, rowData[col.id].value)\"\r\n (onBlur)=\"onEditCell(rowData, col, rowData[col.id].value)\"\r\n (onClear)=\"onEditCell(rowData, col, rowData[col.id].value)\"\r\n [inputStyleClass]=\"col.position == null || col.position == 'right' ? 'text-right' : col.position == 'left' ? 'text-left' : 'text-center'\"\r\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 }\"\r\n [showClear]=\"getOption(col, rowData, 'clear')\"\r\n [minDate]=\"getOption(col, rowData, 'minDate')\"\r\n [maxDate]=\"getOption(col, rowData, 'maxDate')\"\r\n [defaultDate]=\"getOption(col, rowData, 'defaultDate')\"\r\n appendTo=\"body\">\r\n </p-calendar>\r\n </td>\r\n <td *ngIf=\"!col.invisible && checkType('Date', col) && (rowData.readonly || rowData[col.id]?.readonly || !isModeEdition())\"\r\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])\"\r\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\r\n [pTooltip]=\"rowData[col.id].tooltip != null ? rowData[col.id].tooltip : rowData[col.id].value | date: 'dd/MM/yyyy'\"\r\n [tooltipDisabled]=\"!col.tooltip\"\r\n tooltipPosition=\"bottom\"\r\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\r\n [frozen]=\"col.frozen\">\r\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\r\n <div *ngIf=\"rowData[col.id]\">{{ rowData[col.id].value | date: (getOption(col, rowData, 'mode') == 'year' ? 'yyyy' : getOption(col, rowData, 'mode') == 'month' ? 'MM/yyyy' : 'dd/MM/yyyy') }}</div>\r\n </td>\r\n\r\n <!-- MultiSelect -->\r\n <td *ngIf=\"!col.invisible && checkType('MultiSelect', col) && isModeEdition() && !rowData.readonly && !rowData[col.id]?.readonly\"\r\n [ngStyle]=\"{ 'width' : col.width ? col.width : null, 'background-color': rowData[col.id].color ? rowData[col.id].color : null }\"\r\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\r\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])\"\r\n [pTooltip]=\"rowData[col.id].tooltip != null ? rowData[col.id].tooltip : getMultiSelectConcat(rowData[col.id].value, getOption(col, rowData, 'optionLabel'))\"\r\n [tooltipDisabled]=\"!col.tooltip\"\r\n tooltipPosition=\"bottom\"\r\n pFrozenColumn\r\n [frozen]=\"col.frozen\"\r\n class=\"paddingCell\">\r\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\r\n <p-multiSelect *ngIf=\"rowData[col.id] != null\"\r\n [options]=\"getOption(col, rowData, 'options')\"\r\n [filter]=\"getOption(col, rowData, 'filter')\"\r\n [optionLabel]=\"getOption(col, rowData, 'optionLabel')\"\r\n [(ngModel)]=\"rowData[col.id].value\"\r\n appendTo=\"body\"\r\n dataKey=\"ID\"\r\n emptyFilterMessage=\"Aucun r\u00E9sultat\"\r\n emptyMessage=\"Aucun r\u00E9sultat\"\r\n [baseZIndex]=\"getOption(col, rowData, 'baseZIndex')\"\r\n [virtualScroll]=\"getOption(col, rowData, 'virtualScroll')\"\r\n [readonly]=\"rowData.readonly || rowData[col.id]?.readonly || !isModeEdition()\"\r\n [virtualScrollItemSize]=\"30\"\r\n selectedItemsLabel=\"{0} selectionn\u00E9s\"\r\n (onChange)=\"editMultiselect(rowData, col, $event)\"\r\n [showToggleAll]=\"false\"\r\n [showHeader]=\"getOption(col, rowData, 'filter')\"\r\n [group]=\"getOption(col, rowData, 'optionGroupChildren') != null ? true : false\"\r\n [optionGroupLabel]=\"getOption(col, rowData, 'optionGroupLabel')\"\r\n [optionGroupChildren]=\"getOption(col, rowData, 'optionGroupChildren')\"\r\n ngDefaultControl>\r\n <ng-template let-data pTemplate=\"selectedItems\">\r\n <span *ngFor=\"let option of data, let i = index\"\r\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 ? ',' : '') }}\r\n </span>\r\n </ng-template>\r\n <ng-template let-group pTemplate=\"group\">\r\n <div>{{group[col.options.optionGroupLabel]}}</div>\r\n </ng-template>\r\n </p-multiSelect>\r\n </td>\r\n <td *ngIf=\"!col.invisible && checkType('MultiSelect', col) && (rowData.readonly || rowData[col.id]?.readonly || !isModeEdition())\"\r\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])\"\r\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\r\n [pTooltip]=\"rowData[col.id].tooltip != null ? rowData[col.id].tooltip : getMultiSelectConcat(rowData[col.id].value, getOption(col, rowData, 'optionLabel'))\"\r\n [tooltipDisabled]=\"!col.tooltip\"\r\n tooltipPosition=\"bottom\"\r\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\r\n [frozen]=\"col.frozen\">\r\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\r\n <div *ngIf=\"rowData[col.id]\">{{ getMultiSelectConcat(rowData[col.id].value, getOption(col, rowData, 'optionLabel')) }}</div>\r\n </td>\r\n\r\n <!-- Image -->\r\n <td *ngIf=\"!col.invisible && checkType('Image', col)\"\r\n [ngStyle]=\"{ 'width' : col.width ? col.width : null, 'background-color': rowData[col.id].color ? rowData[col.id].color : null }\"\r\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\r\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])\"\r\n class=\"text-center\"\r\n pFrozenColumn\r\n [frozen]=\"col.frozen\">\r\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\r\n <img *ngIf=\"rowData[col.id]\" style=\"vertical-align: middle; width: 40px;\" src=\"{{ rowData[col.id].value }}\" />\r\n </td>\r\n\r\n <!-- Button -->\r\n <td *ngIf=\"!col.invisible && checkType('Button', col)\"\r\n class=\"paddingCell text-center\"\r\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])\"\r\n [ngStyle]=\"{ 'width' : col.width ? col.width : null, 'background-color': rowData[col.id].color ? rowData[col.id].color : null }\">\r\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\r\n <button pButton\r\n *ngIf=\"rowData[col.id].value != null && isValueButtonByType(rowData[col.id].value, 'function')\"\r\n [disabled]=\"rowData.readonly || rowData[col.id]?.readonly\"\r\n [label]=\"getOption(col, rowData, 'label')\"\r\n [icon]=\"getOption(col, rowData, 'icon')\"\r\n (click)=\"rowData[col.id].value()\"\r\n [pTooltip]=\"rowData[col.id].tooltip != null ? rowData[col.id].tooltip : getOption(col, rowData, 'label')\"\r\n [tooltipDisabled]=\"!col.tooltip\"\r\n [class]=\"'p-button-' + getOption(col, rowData, 'severity')\"\r\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>\r\n <div *ngIf=\"isValueButtonByType(rowData[col.id].value, 'string')\"\r\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\"\r\n [tooltipDisabled]=\"!col.tooltip\">\r\n {{ rowData[col.id].value }}\r\n </div>\r\n </td>\r\n\r\n <!-- SelectButton -->\r\n <td *ngIf=\"!col.invisible && checkType('SelectButton', col) && isModeEdition() && !rowData.readonly && !rowData[col.id]?.readonly\"\r\n [ngStyle]=\"{ 'width' : col.width ? col.width : null, 'background-color': rowData[col.id].color ? rowData[col.id].color : null }\"\r\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\r\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])\"\r\n pFrozenColumn\r\n [frozen]=\"col.frozen\">\r\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\r\n <p-selectButton *ngIf=\"rowData[col.id] != null\"\r\n [options]=\"getOption(col, rowData, 'options')\"\r\n [optionLabel]=\"getOption(col, rowData, 'optionLabel')\"\r\n [optionValue]=\"getOption(col, rowData, 'optionValue') != null ? getOption(col, rowData, 'optionValue') : 'value'\"\r\n [(ngModel)]=\"rowData[col.id].value\"\r\n [disabled]=\"rowData.readonly || rowData[col.id]?.readonly || !isModeEdition()\"\r\n (onChange)=\"onEditCell(rowData, col, rowData[col.id].value)\">\r\n <ng-template let-item pTemplate=\"item\">\r\n <span class=\"text-center w-full\"\r\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 }}\r\n </span>\r\n </ng-template>\r\n </p-selectButton>\r\n </td>\r\n <td *ngIf=\"!col.invisible && checkType('SelectButton', col) && (rowData.readonly || rowData[col.id]?.readonly || !isModeEdition())\"\r\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])\"\r\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\r\n pFrozenColumn\r\n [frozen]=\"col.frozen\"\r\n class=\"text-center\"\r\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>\r\n <div *ngIf=\"rowData[col.id]\">{{ getSelectLibelleByValue(rowData, col) }}</div>\r\n </td>\r\n\r\n <!-- Switch -->\r\n <td *ngIf=\"!col.invisible && checkType('Switch', col)\"\r\n [ngStyle]=\"{ 'width' : col.width ? col.width : null, 'background-color': rowData[col.id].color ? rowData[col.id].color : null }\"\r\n class=\"text-center\"\r\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\r\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])\"\r\n pFrozenColumn\r\n [frozen]=\"col.frozen\">\r\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\r\n <p-inputSwitch *ngIf=\"rowData[col.id] != null\"\r\n [(ngModel)]=\"rowData[col.id].value\"\r\n [disabled]=\"rowData.readonly || rowData[col.id]?.readonly || (getOption(col, rowData, 'action') == null && !isModeEdition())\"\r\n (onChange)=\"onEditCell(rowData, col, rowData[col.id].value)\"\r\n ngDefaultControl>\r\n </p-inputSwitch>\r\n </td>\r\n\r\n <!-- File -->\r\n <td *ngIf=\"!col.invisible && checkType('File', col) && isModeEdition() && !rowData.readonly && !rowData[col.id]?.readonly\"\r\n [ngStyle]=\"{ 'width' : col.width ? col.width : null, 'background-color': rowData[col.id].color ? rowData[col.id].color : null }\"\r\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\r\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])\"\r\n pFrozenColumn\r\n [frozen]=\"col.frozen\">\r\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\r\n <div class=\"p-inputgroup\" *ngIf=\"rowData[col.id] != null\">\r\n <button type=\"button\"\r\n pButton\r\n pRipple\r\n icon=\"pi pi-upload\"\r\n (click)=\"clickById('input_' + rowData[col.id].id)\"\r\n [disabled]=\"rowData.readonly || rowData[col.id]?.readonly || !isModeEdition()\">\r\n </button>\r\n <input id=\"{{'output_' + rowData[col.id].id}}\"\r\n pInputText\r\n type=\"text\"\r\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 : '' }}\"\r\n readonly\r\n [pTooltip]=\"rowData[col.id].tooltip != null ? rowData[col.id].tooltip : rowData[col.id].value ? rowData[col.id].value : ''\"\r\n [tooltipDisabled]=\"!col.tooltip\">\r\n <button *ngIf=\"getOption(col, rowData, 'downloadPath') && rowData[col.id].value != null\"\r\n type=\"button\"\r\n pButton\r\n pRipple\r\n icon=\"pi pi-download\"\r\n (click)=\"downloadFile(rowData[col.id])\"\r\n [disabled]=\"rowData.readonly || rowData[col.id]?.readonly || !isModeEdition()\">\r\n </button>\r\n </div>\r\n <input *ngIf=\"rowData[col.id]\" 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])\">\r\n </td>\r\n <td *ngIf=\"!col.invisible && checkType('File', col) && (rowData.readonly || rowData[col.id]?.readonly || !isModeEdition())\"\r\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])\"\r\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\r\n [pTooltip]=\"rowData[col.id].tooltip != null ? rowData[col.id].tooltip : rowData[col.id].value ? rowData[col.id].value : ''\"\r\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\"\r\n tooltipPosition=\"bottom\"\r\n pFrozenColumn\r\n [frozen]=\"col.frozen\">\r\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\r\n <div *ngIf=\"rowData[col.id]\">{{ rowData[col.id].value ? rowData[col.id].value : '' }}</div>\r\n </td>\r\n\r\n <!-- State -->\r\n <td *ngIf=\"!col.invisible && checkType('State', col)\"\r\n [ngStyle]=\"{ 'width' : col.width ? col.width : null, 'background-color': rowData[col.id].color ? rowData[col.id].color : null }\"\r\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\r\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])\"\r\n class=\"text-center\"\r\n pFrozenColumn\r\n [frozen]=\"col.frozen\">\r\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\r\n <p-tag *ngIf=\"rowData[col.id].value != null\"\r\n [value]=\"rowData[col.id].value[getOption(col, rowData, 'optionLabel')]\"\r\n [severity]=\"rowData[col.id].value.severity\"\r\n [icon]=\"rowData[col.id].value.icon\"\r\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>\r\n </td>\r\n\r\n </ng-container>\r\n\r\n <!-- Deletion -->\r\n <td *ngIf=\"options.rowsDeletable\"\r\n class=\"cellDelete\"\r\n [ngClass]=\"rowData.deletable ? 'paddingCell' : null\">\r\n <button *ngIf=\"rowData.deletable\"\r\n pButton\r\n type=\"button\"\r\n icon=\"pi pi-times\"\r\n class=\"p-button-danger buttonDelete p-button-text\"\r\n [disabled]=\"rowData.readonly\"\r\n (click)=\"onDeleteLine(rowData)\">\r\n </button>\r\n </td>\r\n\r\n </tr>\r\n </ng-template>\r\n </p-table>\r\n</div>\r\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: "17.3.12", ngImpo
1389
1354
  args: ['inputNumber']
1390
1355
  }] } });
1391
1356
 
1392
- class CilogTableService {
1393
- constructor() { }
1394
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: CilogTableService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
1395
- static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: CilogTableService, providedIn: 'root' }); }
1396
- }
1397
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", 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: "17.3.12", ngImport: i0, type: CilogEditorComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
1419
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: CilogEditorComponent, 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"] }, { 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
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: CilogEditorComponent, decorators: [{
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', 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: "17.3.12", ngImpo
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,94 +1528,39 @@ 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: "17.3.12", ngImport: i0, type: DocumentationContextuelleComponent, deps: [{ token: i1$2.HttpClient }, { token: i2$1.Router }], target: i0.ɵɵFactoryTarget.Component }); }
1573
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: DocumentationContextuelleComponent, selector: "cilog-documentation-contextuelle", ngImport: i0, template: "<div class=\"documentation-container\">\r\n <!-- Menu sup\u00E9rieur -->\r\n <div class=\"documentation-menu\">\r\n <button \r\n pButton \r\n type=\"button\" \r\n icon=\"pi pi-list\" \r\n label=\"Sommaire des documentations\"\r\n class=\"p-button-sm p-button-outlined\"\r\n (click)=\"openDocumentationList()\"\r\n title=\"Voir toutes les documentations disponibles\">\r\n </button>\r\n <button \r\n pButton \r\n type=\"button\" \r\n icon=\"pi pi-home\" \r\n label=\"Documentation courante\"\r\n class=\"p-button-sm p-button-outlined\"\r\n (click)=\"openCurrentPageDoc()\"\r\n title=\"Documentation de la page actuelle\">\r\n </button>\r\n </div>\r\n\r\n <!-- Syst\u00E8me d'onglets -->\r\n <p-tabView \r\n [(activeIndex)]=\"activeTabIndex\"\r\n (onClose)=\"closeTab($event)\"\r\n styleClass=\"documentation-tabs\">\r\n \r\n <p-tabPanel \r\n *ngFor=\"let tab of tabs; let i = index\" \r\n [header]=\"tab.title\"\r\n [closable]=\"tabs.length > 1\">\r\n \r\n <!-- Contenu pour onglet de liste - Version am\u00E9lior\u00E9e -->\r\n <div *ngIf=\"tab.type === 'list'\" class=\"docs-list-container\">\r\n <div class=\"docs-header\">\r\n <h2>\uD83D\uDCDA Sommaire de la Documentation</h2>\r\n <p class=\"docs-subtitle\">Explorez toutes les fonctionnalit\u00E9s disponibles dans LogeProj</p>\r\n </div>\r\n\r\n <!-- Barre de recherche -->\r\n <div class=\"search-bar\">\r\n <span class=\"p-input-icon-left\" style=\"width: 100%; max-width: 800px;\">\r\n <i class=\"pi pi-search\"></i>\r\n <input \r\n type=\"text\" \r\n pInputText \r\n placeholder=\"Rechercher dans les documentations...\" \r\n [(ngModel)]=\"searchQuery\"\r\n (input)=\"filterDocumentation()\"\r\n style=\"width: 100% !important; padding: 12px 20px 12px 40px !important; border-radius: 25px !important;\">\r\n </span>\r\n </div>\r\n\r\n <!-- Liste des cat\u00E9gories -->\r\n <div class=\"categories-container\">\r\n <div *ngFor=\"let category of filteredCategories\" class=\"category-section\">\r\n <div class=\"category-header\" (click)=\"toggleCategory(category.key)\">\r\n <i class=\"pi\" [ngClass]=\"category.expanded ? 'pi-chevron-down' : 'pi-chevron-right'\"></i>\r\n <span class=\"category-icon\">{{ category.icon }}</span>\r\n <h3 class=\"category-title\">{{ category.name }}</h3>\r\n <span class=\"category-count\">({{ category.docs.length }})</span>\r\n </div>\r\n \r\n <div class=\"category-content\" [ngClass]=\"{ 'expanded': category.expanded }\">\r\n <div class=\"docs-grid\">\r\n <div \r\n *ngFor=\"let doc of category.docs\" \r\n class=\"doc-card\"\r\n (click)=\"openDocumentationAndSwitch(doc)\"\r\n [title]=\"doc.description\"> \r\n <div class=\"doc-card-content\">\r\n <h4 class=\"doc-name\">{{ doc.displayName }}</h4>\r\n <p class=\"doc-description\">{{ doc.description }}</p>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n \r\n <!-- Stats en bas -->\r\n <div class=\"docs-stats\">\r\n <div class=\"stat-item\">\r\n <strong>{{ getTotalDocsCount() }}</strong> documentations disponibles\r\n </div>\r\n <div class=\"stat-item\">\r\n <strong>{{ getOpenTabsCount() }}</strong> onglets ouverts\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <!-- Contenu pour onglet de documentation -->\r\n <div *ngIf=\"tab.type === 'doc'\" class=\"markdown-container\">\r\n <!-- Breadcrumb pour navigation -->\r\n <div class=\"doc-breadcrumb\" *ngIf=\"tab.category\">\r\n <span class=\"breadcrumb-item\">{{ tab.category }}</span>\r\n <i class=\"pi pi-angle-right\"></i>\r\n <span class=\"breadcrumb-current\">{{ tab.title }}</span>\r\n </div>\r\n\r\n <div *ngIf=\"tab.loading\" class=\"loading-container\">\r\n <p-progressSpinner strokeWidth=\"4\"></p-progressSpinner>\r\n <span>Chargement de la documentation...</span>\r\n </div>\r\n <markdown \r\n *ngIf=\"!tab.loading\" \r\n [data]=\"tab.content || 'Aucun contenu disponible'\">\r\n </markdown>\r\n </div>\r\n </p-tabPanel>\r\n </p-tabView>\r\n</div>", 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: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i4.ButtonDirective, selector: "[pButton]", inputs: ["iconPos", "loadingIcon", "label", "icon", "loading", "severity", "raised", "rounded", "text", "outlined", "size", "plain"] }, { kind: "directive", type: i2.InputText, selector: "[pInputText]", inputs: ["variant"] }, { kind: "component", type: i6.TabView, selector: "p-tabView", inputs: ["style", "styleClass", "controlClose", "scrollable", "activeIndex", "selectOnFocus", "nextButtonAriaLabel", "prevButtonAriaLabel", "autoHideButtons", "tabindex"], outputs: ["onChange", "onClose", "activeIndexChange"] }, { kind: "component", type: i6.TabPanel, selector: "p-tabPanel", inputs: ["closable", "headerStyle", "headerStyleClass", "cache", "tooltip", "tooltipPosition", "tooltipPositionStyle", "tooltipStyleClass", "selected", "disabled", "header", "leftIcon", "rightIcon"] }, { 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", inputs: ["styleClass", "style", "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
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: DocumentationContextuelleComponent, decorators: [{
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', template: "<div class=\"documentation-container\">\r\n <!-- Menu sup\u00E9rieur -->\r\n <div class=\"documentation-menu\">\r\n <button \r\n pButton \r\n type=\"button\" \r\n icon=\"pi pi-list\" \r\n label=\"Sommaire des documentations\"\r\n class=\"p-button-sm p-button-outlined\"\r\n (click)=\"openDocumentationList()\"\r\n title=\"Voir toutes les documentations disponibles\">\r\n </button>\r\n <button \r\n pButton \r\n type=\"button\" \r\n icon=\"pi pi-home\" \r\n label=\"Documentation courante\"\r\n class=\"p-button-sm p-button-outlined\"\r\n (click)=\"openCurrentPageDoc()\"\r\n title=\"Documentation de la page actuelle\">\r\n </button>\r\n </div>\r\n\r\n <!-- Syst\u00E8me d'onglets -->\r\n <p-tabView \r\n [(activeIndex)]=\"activeTabIndex\"\r\n (onClose)=\"closeTab($event)\"\r\n styleClass=\"documentation-tabs\">\r\n \r\n <p-tabPanel \r\n *ngFor=\"let tab of tabs; let i = index\" \r\n [header]=\"tab.title\"\r\n [closable]=\"tabs.length > 1\">\r\n \r\n <!-- Contenu pour onglet de liste - Version am\u00E9lior\u00E9e -->\r\n <div *ngIf=\"tab.type === 'list'\" class=\"docs-list-container\">\r\n <div class=\"docs-header\">\r\n <h2>\uD83D\uDCDA Sommaire de la Documentation</h2>\r\n <p class=\"docs-subtitle\">Explorez toutes les fonctionnalit\u00E9s disponibles dans LogeProj</p>\r\n </div>\r\n\r\n <!-- Barre de recherche -->\r\n <div class=\"search-bar\">\r\n <span class=\"p-input-icon-left\" style=\"width: 100%; max-width: 800px;\">\r\n <i class=\"pi pi-search\"></i>\r\n <input \r\n type=\"text\" \r\n pInputText \r\n placeholder=\"Rechercher dans les documentations...\" \r\n [(ngModel)]=\"searchQuery\"\r\n (input)=\"filterDocumentation()\"\r\n style=\"width: 100% !important; padding: 12px 20px 12px 40px !important; border-radius: 25px !important;\">\r\n </span>\r\n </div>\r\n\r\n <!-- Liste des cat\u00E9gories -->\r\n <div class=\"categories-container\">\r\n <div *ngFor=\"let category of filteredCategories\" class=\"category-section\">\r\n <div class=\"category-header\" (click)=\"toggleCategory(category.key)\">\r\n <i class=\"pi\" [ngClass]=\"category.expanded ? 'pi-chevron-down' : 'pi-chevron-right'\"></i>\r\n <span class=\"category-icon\">{{ category.icon }}</span>\r\n <h3 class=\"category-title\">{{ category.name }}</h3>\r\n <span class=\"category-count\">({{ category.docs.length }})</span>\r\n </div>\r\n \r\n <div class=\"category-content\" [ngClass]=\"{ 'expanded': category.expanded }\">\r\n <div class=\"docs-grid\">\r\n <div \r\n *ngFor=\"let doc of category.docs\" \r\n class=\"doc-card\"\r\n (click)=\"openDocumentationAndSwitch(doc)\"\r\n [title]=\"doc.description\"> \r\n <div class=\"doc-card-content\">\r\n <h4 class=\"doc-name\">{{ doc.displayName }}</h4>\r\n <p class=\"doc-description\">{{ doc.description }}</p>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n \r\n <!-- Stats en bas -->\r\n <div class=\"docs-stats\">\r\n <div class=\"stat-item\">\r\n <strong>{{ getTotalDocsCount() }}</strong> documentations disponibles\r\n </div>\r\n <div class=\"stat-item\">\r\n <strong>{{ getOpenTabsCount() }}</strong> onglets ouverts\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <!-- Contenu pour onglet de documentation -->\r\n <div *ngIf=\"tab.type === 'doc'\" class=\"markdown-container\">\r\n <!-- Breadcrumb pour navigation -->\r\n <div class=\"doc-breadcrumb\" *ngIf=\"tab.category\">\r\n <span class=\"breadcrumb-item\">{{ tab.category }}</span>\r\n <i class=\"pi pi-angle-right\"></i>\r\n <span class=\"breadcrumb-current\">{{ tab.title }}</span>\r\n </div>\r\n\r\n <div *ngIf=\"tab.loading\" class=\"loading-container\">\r\n <p-progressSpinner strokeWidth=\"4\"></p-progressSpinner>\r\n <span>Chargement de la documentation...</span>\r\n </div>\r\n <markdown \r\n *ngIf=\"!tab.loading\" \r\n [data]=\"tab.content || 'Aucun contenu disponible'\">\r\n </markdown>\r\n </div>\r\n </p-tabPanel>\r\n </p-tabView>\r\n</div>", 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$1.Router }] });
1536
+ args: [{ selector: 'cilog-documentation-contextuelle', imports: [
1537
+ CommonModule,
1538
+ FormsModule,
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 }] });
1579
1545
 
1580
- registerLocaleData(localeFr);
1581
- class CilogLibModule {
1582
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: CilogLibModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
1583
- static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "17.3.12", 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
- BrowserAnimationsModule,
1593
- FormsModule,
1594
- ReactiveFormsModule,
1595
- HttpClientModule, i8$1.MarkdownModule, ProgressSpinnerModule], exports: [CilogMessageComponent,
1596
- CilogTableComponent,
1597
- CilogEditorComponent,
1598
- CilogInputNumberComponent,
1599
- DocumentationContextuelleComponent] }); }
1600
- static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: CilogLibModule, providers: [
1601
- CilogMessageService,
1602
- CilogTableService,
1603
- ConfirmationService,
1604
- { provide: LOCALE_ID, useValue: 'fr-FR' },
1605
- ], imports: [CommonModule,
1606
- PrimengModule,
1607
- BrowserModule,
1608
- BrowserAnimationsModule,
1609
- FormsModule,
1610
- ReactiveFormsModule,
1611
- HttpClientModule,
1612
- MarkdownModule.forRoot({ loader: HttpClient }),
1613
- ProgressSpinnerModule] }); }
1546
+ class CilogLibService {
1547
+ constructor() { }
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' });
1614
1550
  }
1615
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: CilogLibModule, decorators: [{
1616
- type: NgModule,
1551
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "21.0.6", ngImport: i0, type: CilogLibService, decorators: [{
1552
+ type: Injectable,
1617
1553
  args: [{
1618
- imports: [
1619
- CommonModule,
1620
- PrimengModule,
1621
- BrowserModule,
1622
- BrowserAnimationsModule,
1623
- FormsModule,
1624
- ReactiveFormsModule,
1625
- HttpClientModule,
1626
- MarkdownModule.forRoot({ loader: HttpClient }),
1627
- ProgressSpinnerModule
1628
- ],
1629
- declarations: [
1630
- CilogLibComponent,
1631
- CilogMessageComponent,
1632
- CilogTableComponent,
1633
- CilogEditorComponent,
1634
- CilogInputNumberComponent,
1635
- DocumentationContextuelleComponent,
1636
- ValuePipe
1637
- ],
1638
- exports: [
1639
- CilogMessageComponent,
1640
- CilogTableComponent,
1641
- CilogEditorComponent,
1642
- CilogInputNumberComponent,
1643
- DocumentationContextuelleComponent,
1644
- ],
1645
- providers: [
1646
- CilogMessageService,
1647
- CilogTableService,
1648
- ConfirmationService,
1649
- { provide: LOCALE_ID, useValue: 'fr-FR' },
1650
- ]
1554
+ providedIn: 'root'
1651
1555
  }]
1652
- }] });
1556
+ }], ctorParameters: () => [] });
1653
1557
 
1654
- class CilogLibService {
1558
+ class CilogTableService {
1655
1559
  constructor() { }
1656
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: CilogLibService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
1657
- static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: CilogLibService, providedIn: 'root' }); }
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' });
1658
1562
  }
1659
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: CilogLibService, decorators: [{
1563
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "21.0.6", ngImport: i0, type: CilogTableService, decorators: [{
1660
1564
  type: Injectable,
1661
1565
  args: [{
1662
1566
  providedIn: 'root'
@@ -1666,11 +1570,11 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
1666
1570
  /*
1667
1571
  * Public API Surface of cilog-lib
1668
1572
  */
1669
- // Modules
1573
+ // Components
1670
1574
 
1671
1575
  /**
1672
1576
  * Generated bundle index. Do not edit.
1673
1577
  */
1674
1578
 
1675
- 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 };
1676
1580
  //# sourceMappingURL=cilog-lib.mjs.map