cilog-lib 1.10.19 → 1.10.21
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/fesm2022/cilog-lib.mjs +97 -102
- package/fesm2022/cilog-lib.mjs.map +1 -1
- package/package.json +3 -5
- package/types/cilog-lib.d.ts +538 -0
- package/esm2022/cilog-lib.mjs +0 -5
- package/esm2022/lib/cilog-lib.component.mjs +0 -22
- package/esm2022/lib/cilog-lib.module.mjs +0 -96
- package/esm2022/lib/cilog-lib.service.mjs +0 -14
- package/esm2022/lib/helpers/enums/grille.enum.mjs +0 -51
- package/esm2022/lib/helpers/interfaces/edition.interface.mjs +0 -2
- package/esm2022/lib/helpers/interfaces/editor.interface.mjs +0 -2
- package/esm2022/lib/helpers/interfaces/grille.interface.mjs +0 -2
- package/esm2022/lib/helpers/interfaces/message.interface.mjs +0 -2
- package/esm2022/lib/helpers/pipes/value.pipe.mjs +0 -27
- package/esm2022/lib/modules/primeng.module.mjs +0 -86
- package/esm2022/lib/services/excel.service.mjs +0 -179
- package/esm2022/lib/services/message.service.mjs +0 -30
- package/esm2022/lib/services/table.service.mjs +0 -14
- package/esm2022/lib/views/cilog-input-number/cilog-input-number.component.mjs +0 -251
- package/esm2022/lib/views/documentation/documentation-contextuelle.component.mjs +0 -156
- package/esm2022/lib/views/editor/editor.component.mjs +0 -38
- package/esm2022/lib/views/message/message.component.mjs +0 -77
- package/esm2022/lib/views/table/table.component.mjs +0 -674
- package/esm2022/public-api.mjs +0 -24
- package/index.d.ts +0 -5
- package/lib/cilog-lib.component.d.ts +0 -8
- package/lib/cilog-lib.module.d.ts +0 -21
- package/lib/cilog-lib.service.d.ts +0 -6
- package/lib/helpers/enums/grille.enum.d.ts +0 -44
- package/lib/helpers/interfaces/edition.interface.d.ts +0 -34
- package/lib/helpers/interfaces/editor.interface.d.ts +0 -4
- package/lib/helpers/interfaces/grille.interface.d.ts +0 -166
- package/lib/helpers/interfaces/message.interface.d.ts +0 -6
- package/lib/helpers/pipes/value.pipe.d.ts +0 -7
- package/lib/modules/primeng.module.d.ts +0 -24
- package/lib/services/excel.service.d.ts +0 -15
- package/lib/services/message.service.d.ts +0 -12
- package/lib/services/table.service.d.ts +0 -6
- package/lib/views/cilog-input-number/cilog-input-number.component.d.ts +0 -40
- package/lib/views/documentation/documentation-contextuelle.component.d.ts +0 -49
- package/lib/views/editor/editor.component.d.ts +0 -17
- package/lib/views/message/message.component.d.ts +0 -17
- package/lib/views/table/table.component.d.ts +0 -83
- package/public-api.d.ts +0 -15
package/fesm2022/cilog-lib.mjs
CHANGED
|
@@ -1,52 +1,51 @@
|
|
|
1
1
|
import * as i0 from '@angular/core';
|
|
2
2
|
import { Injectable, Component, NgModule, EventEmitter, forwardRef, HostListener, ViewChild, Output, Input, Pipe, LOCALE_ID } from '@angular/core';
|
|
3
3
|
import { BehaviorSubject } from 'rxjs';
|
|
4
|
-
import * as
|
|
5
|
-
import { CommonModule, registerLocaleData } from '@angular/common';
|
|
6
|
-
import * as i3$1 from 'primeng/dialog';
|
|
4
|
+
import * as i2 from 'primeng/dialog';
|
|
7
5
|
import { DialogModule } from 'primeng/dialog';
|
|
8
6
|
import * as i1 from 'primeng/api';
|
|
9
7
|
import { ConfirmationService } from 'primeng/api';
|
|
10
8
|
import * as i4 from 'primeng/button';
|
|
11
9
|
import { ButtonModule } from 'primeng/button';
|
|
10
|
+
import * as i3 from '@angular/common';
|
|
11
|
+
import { CommonModule, registerLocaleData } from '@angular/common';
|
|
12
12
|
import * as i5 from 'primeng/table';
|
|
13
13
|
import { TableModule } from 'primeng/table';
|
|
14
|
-
import * as i2 from 'primeng/inputtext';
|
|
14
|
+
import * as i2$1 from 'primeng/inputtext';
|
|
15
15
|
import { InputTextModule } from 'primeng/inputtext';
|
|
16
16
|
import * as i7 from 'primeng/selectbutton';
|
|
17
17
|
import { SelectButtonModule } from 'primeng/selectbutton';
|
|
18
|
-
import * as i8 from 'primeng/
|
|
19
|
-
import {
|
|
18
|
+
import * as i8 from 'primeng/select';
|
|
19
|
+
import { SelectModule } from 'primeng/select';
|
|
20
20
|
import * as i9 from 'primeng/inputnumber';
|
|
21
21
|
import { InputNumberModule } from 'primeng/inputnumber';
|
|
22
22
|
import { ConfirmDialogModule } from 'primeng/confirmdialog';
|
|
23
23
|
import * as i10 from 'primeng/multiselect';
|
|
24
24
|
import { MultiSelectModule } from 'primeng/multiselect';
|
|
25
|
-
import * as
|
|
26
|
-
import { CalendarModule } from 'primeng/calendar';
|
|
27
|
-
import * as i14 from 'primeng/tag';
|
|
25
|
+
import * as i13 from 'primeng/tag';
|
|
28
26
|
import { TagModule } from 'primeng/tag';
|
|
29
|
-
import * as
|
|
27
|
+
import * as i14 from 'primeng/tooltip';
|
|
30
28
|
import { TooltipModule } from 'primeng/tooltip';
|
|
31
|
-
import * as i15 from 'primeng/
|
|
32
|
-
import {
|
|
29
|
+
import * as i15 from 'primeng/toggleswitch';
|
|
30
|
+
import { ToggleSwitchModule } from 'primeng/toggleswitch';
|
|
33
31
|
import { SkeletonModule } from 'primeng/skeleton';
|
|
34
32
|
import * as i1$1 from 'primeng/editor';
|
|
35
33
|
import { EditorModule } from 'primeng/editor';
|
|
36
34
|
import * as i12 from 'primeng/contextmenu';
|
|
37
35
|
import { ContextMenuModule } from 'primeng/contextmenu';
|
|
38
|
-
import * as i6 from 'primeng/
|
|
39
|
-
import {
|
|
36
|
+
import * as i6 from 'primeng/tabs';
|
|
37
|
+
import { TabsModule } from 'primeng/tabs';
|
|
38
|
+
import * as i11 from 'primeng/datepicker';
|
|
39
|
+
import { DatePickerModule } from 'primeng/datepicker';
|
|
40
40
|
import { BrowserModule } from '@angular/platform-browser';
|
|
41
|
-
import { BrowserAnimationsModule } from '@angular/platform-browser/animations';
|
|
42
41
|
import * as Excel from 'exceljs';
|
|
43
42
|
import * as FileSaver from 'file-saver';
|
|
44
43
|
import * as i16 from '@angular/forms';
|
|
45
44
|
import { NG_VALUE_ACCESSOR, FormsModule, ReactiveFormsModule } from '@angular/forms';
|
|
46
45
|
import localeFr from '@angular/common/locales/fr';
|
|
47
46
|
import * as i1$2 from '@angular/common/http';
|
|
48
|
-
import {
|
|
49
|
-
import * as i2$
|
|
47
|
+
import { HttpClient, provideHttpClient, withInterceptorsFromDi } from '@angular/common/http';
|
|
48
|
+
import * as i2$2 from '@angular/router';
|
|
50
49
|
import * as i8$1 from 'ngx-markdown';
|
|
51
50
|
import { MarkdownModule } from 'ngx-markdown';
|
|
52
51
|
import * as i9$1 from 'primeng/progressspinner';
|
|
@@ -69,10 +68,10 @@ class CilogMessageService {
|
|
|
69
68
|
closeDialog() {
|
|
70
69
|
this.display.next(false);
|
|
71
70
|
}
|
|
72
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "
|
|
73
|
-
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "
|
|
71
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "21.0.6", ngImport: i0, type: CilogMessageService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
72
|
+
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "21.0.6", ngImport: i0, type: CilogMessageService, providedIn: 'root' }); }
|
|
74
73
|
}
|
|
75
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
74
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "21.0.6", ngImport: i0, type: CilogMessageService, decorators: [{
|
|
76
75
|
type: Injectable,
|
|
77
76
|
args: [{
|
|
78
77
|
providedIn: 'root'
|
|
@@ -141,72 +140,72 @@ class CilogMessageComponent {
|
|
|
141
140
|
refreshPage() {
|
|
142
141
|
window.location.reload();
|
|
143
142
|
}
|
|
144
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "
|
|
145
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "
|
|
143
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "21.0.6", ngImport: i0, type: CilogMessageComponent, deps: [{ token: CilogMessageService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
144
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "21.0.6", type: CilogMessageComponent, isStandalone: false, selector: "cilog-message", ngImport: i0, template: "<p-dialog [styleClass]=\"classBySeverity()\"\n [(visible)]=\"display\"\n [modal]=\"true\"\n [baseZIndex]=\"10000\"\n [closable]=\"false\"\n [resizable]=\"false\"\n [draggable]=\"false\">\n\n <!-- Header -->\n <ng-template pTemplate=\"header\">\n <i class=\"pi {{ iconBySeverity() }} header_icon\"></i>\n <span class=\"header_text\">{{ headerBySeverity() }}</span>\n </ng-template>\n\n <!-- Content -->\n <p class=\"content mb-3\"\n [innerHTML]=\"message?.content\">\n </p>\n\n <!-- Boutons -->\n @if (message?.closable == true && message?.refresh == false) {\n <button pButton\n icon=\"pi pi-check\"\n (click)=\"display=false\"\n label=\"Ok\"\n style=\"float:right;\"\n class=\"p-button-text\">\n </button>\n }\n @if (message?.refresh == true) {\n <button pButton\n icon=\"pi pi-refresh\"\n (click)=\"refreshPage()\"\n label=\"Rafra\u00EEchir\"\n style=\"float:right;\"\n class=\"p-button-text\">\n </button>\n }\n\n</p-dialog>\n", styles: [":host ::ng-deep .message_success>div{background-color:#b7fdc0}:host ::ng-deep .message_error>div{background-color:#fdb8b7}:host ::ng-deep .message_warn>div{background-color:#fff5ba}:host ::ng-deep .message_info>div{background-color:#b7eefd}:host ::ng-deep .p-dialog-content,:host ::ng-deep .p-dialog-footer,:host ::ng-deep .p-dialog-header{padding:10px}:host ::ng-deep .content{margin:4px;white-space:pre}:host ::ng-deep .p-button-text{padding-top:0;padding-bottom:3px}:host ::ng-deep .header_text{font-weight:500;font-size:1.25rem;margin-left:10px}:host ::ng-deep .header_icon{font-size:1.5rem}:host ::ng-deep .p-dialog-header{justify-content:inherit}\n"], dependencies: [{ kind: "component", type: i2.Dialog, selector: "p-dialog", inputs: ["hostName", "header", "draggable", "resizable", "contentStyle", "contentStyleClass", "modal", "closeOnEscape", "dismissableMask", "rtl", "closable", "breakpoints", "styleClass", "maskStyleClass", "maskStyle", "showHeader", "blockScroll", "autoZIndex", "baseZIndex", "minX", "minY", "focusOnShow", "maximizable", "keepInViewport", "focusTrap", "transitionOptions", "maskMotionOptions", "motionOptions", "closeIcon", "closeAriaLabel", "closeTabindex", "minimizeIcon", "maximizeIcon", "closeButtonProps", "maximizeButtonProps", "visible", "style", "position", "role", "appendTo", "content", "contentTemplate", "footerTemplate", "closeIconTemplate", "maximizeIconTemplate", "minimizeIconTemplate", "headlessTemplate"], outputs: ["onShow", "onHide", "visibleChange", "onResizeInit", "onResizeEnd", "onDragEnd", "onMaximize"] }, { kind: "directive", type: i1.PrimeTemplate, selector: "[pTemplate]", inputs: ["type", "pTemplate"] }, { kind: "directive", type: i4.ButtonDirective, selector: "[pButton]", inputs: ["ptButtonDirective", "pButtonPT", "pButtonUnstyled", "hostName", "text", "plain", "raised", "size", "outlined", "rounded", "iconPos", "loadingIcon", "fluid", "label", "icon", "loading", "buttonProps", "severity"] }] }); }
|
|
146
145
|
}
|
|
147
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
146
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "21.0.6", ngImport: i0, type: CilogMessageComponent, decorators: [{
|
|
148
147
|
type: Component,
|
|
149
|
-
args: [{ selector: 'cilog-message', template: "<p-dialog [styleClass]=\"classBySeverity()\"\
|
|
148
|
+
args: [{ selector: 'cilog-message', standalone: false, template: "<p-dialog [styleClass]=\"classBySeverity()\"\n [(visible)]=\"display\"\n [modal]=\"true\"\n [baseZIndex]=\"10000\"\n [closable]=\"false\"\n [resizable]=\"false\"\n [draggable]=\"false\">\n\n <!-- Header -->\n <ng-template pTemplate=\"header\">\n <i class=\"pi {{ iconBySeverity() }} header_icon\"></i>\n <span class=\"header_text\">{{ headerBySeverity() }}</span>\n </ng-template>\n\n <!-- Content -->\n <p class=\"content mb-3\"\n [innerHTML]=\"message?.content\">\n </p>\n\n <!-- Boutons -->\n @if (message?.closable == true && message?.refresh == false) {\n <button pButton\n icon=\"pi pi-check\"\n (click)=\"display=false\"\n label=\"Ok\"\n style=\"float:right;\"\n class=\"p-button-text\">\n </button>\n }\n @if (message?.refresh == true) {\n <button pButton\n icon=\"pi pi-refresh\"\n (click)=\"refreshPage()\"\n label=\"Rafra\u00EEchir\"\n style=\"float:right;\"\n class=\"p-button-text\">\n </button>\n }\n\n</p-dialog>\n", styles: [":host ::ng-deep .message_success>div{background-color:#b7fdc0}:host ::ng-deep .message_error>div{background-color:#fdb8b7}:host ::ng-deep .message_warn>div{background-color:#fff5ba}:host ::ng-deep .message_info>div{background-color:#b7eefd}:host ::ng-deep .p-dialog-content,:host ::ng-deep .p-dialog-footer,:host ::ng-deep .p-dialog-header{padding:10px}:host ::ng-deep .content{margin:4px;white-space:pre}:host ::ng-deep .p-button-text{padding-top:0;padding-bottom:3px}:host ::ng-deep .header_text{font-weight:500;font-size:1.25rem;margin-left:10px}:host ::ng-deep .header_icon{font-size:1.5rem}:host ::ng-deep .p-dialog-header{justify-content:inherit}\n"] }]
|
|
150
149
|
}], ctorParameters: () => [{ type: CilogMessageService }] });
|
|
151
150
|
|
|
152
151
|
class CilogLibComponent {
|
|
153
152
|
constructor() { }
|
|
154
153
|
ngOnInit() {
|
|
155
154
|
}
|
|
156
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "
|
|
157
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "
|
|
155
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "21.0.6", ngImport: i0, type: CilogLibComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
156
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "21.0.6", type: CilogLibComponent, isStandalone: false, selector: "lib-cilog-lib", ngImport: i0, template: `
|
|
158
157
|
<p>
|
|
159
158
|
cilog-lib works!
|
|
160
159
|
</p>
|
|
161
160
|
`, isInline: true }); }
|
|
162
161
|
}
|
|
163
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
162
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "21.0.6", ngImport: i0, type: CilogLibComponent, decorators: [{
|
|
164
163
|
type: Component,
|
|
165
164
|
args: [{ selector: 'lib-cilog-lib', template: `
|
|
166
165
|
<p>
|
|
167
166
|
cilog-lib works!
|
|
168
167
|
</p>
|
|
169
|
-
|
|
168
|
+
`, standalone: false }]
|
|
170
169
|
}], ctorParameters: () => [] });
|
|
171
170
|
|
|
172
171
|
class PrimengModule {
|
|
173
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "
|
|
174
|
-
static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "
|
|
172
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "21.0.6", ngImport: i0, type: PrimengModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
|
|
173
|
+
static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "21.0.6", ngImport: i0, type: PrimengModule, imports: [CommonModule], exports: [DialogModule,
|
|
175
174
|
ButtonModule,
|
|
176
175
|
TableModule,
|
|
177
176
|
InputTextModule,
|
|
178
177
|
SelectButtonModule,
|
|
179
|
-
|
|
178
|
+
SelectModule,
|
|
180
179
|
InputNumberModule,
|
|
181
180
|
ConfirmDialogModule,
|
|
182
181
|
MultiSelectModule,
|
|
183
|
-
|
|
182
|
+
DatePickerModule,
|
|
184
183
|
ContextMenuModule,
|
|
185
184
|
TagModule,
|
|
186
185
|
TooltipModule,
|
|
187
|
-
|
|
186
|
+
ToggleSwitchModule,
|
|
188
187
|
SkeletonModule,
|
|
189
188
|
EditorModule,
|
|
190
|
-
|
|
191
|
-
static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "
|
|
189
|
+
TabsModule] }); }
|
|
190
|
+
static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "21.0.6", ngImport: i0, type: PrimengModule, imports: [CommonModule, DialogModule,
|
|
192
191
|
ButtonModule,
|
|
193
192
|
TableModule,
|
|
194
193
|
InputTextModule,
|
|
195
194
|
SelectButtonModule,
|
|
196
|
-
|
|
195
|
+
SelectModule,
|
|
197
196
|
InputNumberModule,
|
|
198
197
|
ConfirmDialogModule,
|
|
199
198
|
MultiSelectModule,
|
|
200
|
-
|
|
199
|
+
DatePickerModule,
|
|
201
200
|
ContextMenuModule,
|
|
202
201
|
TagModule,
|
|
203
202
|
TooltipModule,
|
|
204
|
-
|
|
203
|
+
ToggleSwitchModule,
|
|
205
204
|
SkeletonModule,
|
|
206
205
|
EditorModule,
|
|
207
|
-
|
|
206
|
+
TabsModule] }); }
|
|
208
207
|
}
|
|
209
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
208
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "21.0.6", ngImport: i0, type: PrimengModule, decorators: [{
|
|
210
209
|
type: NgModule,
|
|
211
210
|
args: [{
|
|
212
211
|
declarations: [],
|
|
@@ -216,18 +215,18 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
216
215
|
TableModule,
|
|
217
216
|
InputTextModule,
|
|
218
217
|
SelectButtonModule,
|
|
219
|
-
|
|
218
|
+
SelectModule,
|
|
220
219
|
InputNumberModule,
|
|
221
220
|
ConfirmDialogModule,
|
|
222
221
|
MultiSelectModule,
|
|
223
|
-
|
|
222
|
+
DatePickerModule,
|
|
224
223
|
ContextMenuModule,
|
|
225
224
|
TagModule,
|
|
226
225
|
TooltipModule,
|
|
227
|
-
|
|
226
|
+
ToggleSwitchModule,
|
|
228
227
|
SkeletonModule,
|
|
229
228
|
EditorModule,
|
|
230
|
-
|
|
229
|
+
TabsModule
|
|
231
230
|
],
|
|
232
231
|
imports: [
|
|
233
232
|
CommonModule
|
|
@@ -319,7 +318,12 @@ class ExportService {
|
|
|
319
318
|
if (!byFiltre || row.exportable == true) {
|
|
320
319
|
let rowExcel = {};
|
|
321
320
|
columns.filter(obj => !byFiltre || obj.exportable == true).forEach(col => {
|
|
322
|
-
|
|
321
|
+
if (row[col.id].excelSubstitution != null) {
|
|
322
|
+
rowExcel[col.id] = row[col.id].excelSubstitution;
|
|
323
|
+
}
|
|
324
|
+
else {
|
|
325
|
+
rowExcel[col.id] = this.getValueByType(row[col.id], col);
|
|
326
|
+
}
|
|
323
327
|
});
|
|
324
328
|
// Application du style de chaque cellule
|
|
325
329
|
let result = ws.addRow(rowExcel);
|
|
@@ -450,10 +454,10 @@ class ExportService {
|
|
|
450
454
|
return null;
|
|
451
455
|
}
|
|
452
456
|
}
|
|
453
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "
|
|
454
|
-
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "
|
|
457
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "21.0.6", ngImport: i0, type: ExportService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
458
|
+
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "21.0.6", ngImport: i0, type: ExportService, providedIn: 'root' }); }
|
|
455
459
|
}
|
|
456
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
460
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "21.0.6", ngImport: i0, type: ExportService, decorators: [{
|
|
457
461
|
type: Injectable,
|
|
458
462
|
args: [{
|
|
459
463
|
providedIn: 'root'
|
|
@@ -648,16 +652,16 @@ class CilogInputNumberComponent {
|
|
|
648
652
|
registerOnTouched(fn) {
|
|
649
653
|
this.onTouchedInput = fn;
|
|
650
654
|
}
|
|
651
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "
|
|
652
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "
|
|
655
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "21.0.6", ngImport: i0, type: CilogInputNumberComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
656
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "21.0.6", type: CilogInputNumberComponent, isStandalone: false, selector: "cilog-input-number", inputs: { min: "min", max: "max", maxDecimals: "maxDecimals", prefixe: "prefixe", suffixe: "suffixe", inputStyleClass: "inputStyleClass", disabled: "disabled", readonly: "readonly", textColor: "textColor", bold: "bold", italic: "italic", floatLabel: "floatLabel" }, outputs: { onInput: "onInput", onChange: "onChange", onFocus: "onFocus", onBlur: "onBlur" }, host: { listeners: { "keydown": "onKeyDownEvent($event)" } }, providers: [
|
|
653
657
|
{
|
|
654
658
|
provide: NG_VALUE_ACCESSOR,
|
|
655
659
|
useExisting: forwardRef(() => CilogInputNumberComponent),
|
|
656
660
|
multi: true
|
|
657
661
|
}
|
|
658
|
-
], viewQueries: [{ propertyName: "cilogInputNumber", first: true, predicate: ["cilogInputNumber"], descendants: true }], ngImport: i0, template: "<div class=\"input-group w-full\">\
|
|
662
|
+
], viewQueries: [{ propertyName: "cilogInputNumber", first: true, predicate: ["cilogInputNumber"], descendants: true }], ngImport: i0, template: "<div class=\"input-group w-full\">\n\n @if (prefixe != null) {\n <span class=\"input-group-addon prefixe\"\n >\n {{ prefixe }}\n </span>\n }\n\n <div [ngClass]=\"{ 'p-float-label' : floatLabel != null }\">\n <input #cilogInputNumber\n pInputText\n type=\"text\"\n [disabled]=\"disabled\"\n [readonly]=\"readonly\"\n [value]=\"valueStr\"\n (focus)=\"onFocusEvent($event)\"\n (blur)=\"onBlurEvent($event)\"\n [class]=\"'w-full z-1' + (inputStyleClass == null ? '' : ' ' + inputStyleClass)\"\n [ngClass]=\"suffixe != null && prefixe != null ? 'border-noround' : prefixe != null ? 'border-noround-left' : suffixe != null ? 'border-noround-right' : null\"\n [ngStyle]=\"{ 'color' : textColor ? textColor : null }\" />\n\n @if (floatLabel != null) {\n <label>{{ floatLabel }}</label>\n }\n </div>\n\n @if (suffixe != null) {\n <span class=\"input-group-addon suffixe\"\n >\n {{ suffixe }}\n </span>\n }\n\n </div>\n", styles: [":host ::ng-deep .input-group{display:flex!important}:host ::ng-deep .input-group-addon{background-color:#fff!important;border:1px solid #ccc!important;padding:0 12px!important;max-width:5rem!important;overflow:hidden!important;font-weight:700!important}:host ::ng-deep .prefixe{border-radius:4px 0 0 4px!important;border-right:none!important;display:flex;align-items:center}:host ::ng-deep .suffixe{border-radius:0 4px 4px 0!important;border-left:none!important;display:flex;align-items:center}\n"], dependencies: [{ kind: "directive", type: i3.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i3.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "directive", type: i2$1.InputText, selector: "[pInputText]", inputs: ["hostName", "ptInputText", "pInputTextPT", "pInputTextUnstyled", "pSize", "variant", "fluid", "invalid"] }] }); }
|
|
659
663
|
}
|
|
660
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
664
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "21.0.6", ngImport: i0, type: CilogInputNumberComponent, decorators: [{
|
|
661
665
|
type: Component,
|
|
662
666
|
args: [{ selector: 'cilog-input-number', providers: [
|
|
663
667
|
{
|
|
@@ -665,7 +669,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
665
669
|
useExisting: forwardRef(() => CilogInputNumberComponent),
|
|
666
670
|
multi: true
|
|
667
671
|
}
|
|
668
|
-
], template: "<div class=\"input-group w-full\">\
|
|
672
|
+
], standalone: false, template: "<div class=\"input-group w-full\">\n\n @if (prefixe != null) {\n <span class=\"input-group-addon prefixe\"\n >\n {{ prefixe }}\n </span>\n }\n\n <div [ngClass]=\"{ 'p-float-label' : floatLabel != null }\">\n <input #cilogInputNumber\n pInputText\n type=\"text\"\n [disabled]=\"disabled\"\n [readonly]=\"readonly\"\n [value]=\"valueStr\"\n (focus)=\"onFocusEvent($event)\"\n (blur)=\"onBlurEvent($event)\"\n [class]=\"'w-full z-1' + (inputStyleClass == null ? '' : ' ' + inputStyleClass)\"\n [ngClass]=\"suffixe != null && prefixe != null ? 'border-noround' : prefixe != null ? 'border-noround-left' : suffixe != null ? 'border-noround-right' : null\"\n [ngStyle]=\"{ 'color' : textColor ? textColor : null }\" />\n\n @if (floatLabel != null) {\n <label>{{ floatLabel }}</label>\n }\n </div>\n\n @if (suffixe != null) {\n <span class=\"input-group-addon suffixe\"\n >\n {{ suffixe }}\n </span>\n }\n\n </div>\n", styles: [":host ::ng-deep .input-group{display:flex!important}:host ::ng-deep .input-group-addon{background-color:#fff!important;border:1px solid #ccc!important;padding:0 12px!important;max-width:5rem!important;overflow:hidden!important;font-weight:700!important}:host ::ng-deep .prefixe{border-radius:4px 0 0 4px!important;border-right:none!important;display:flex;align-items:center}:host ::ng-deep .suffixe{border-radius:0 4px 4px 0!important;border-left:none!important;display:flex;align-items:center}\n"] }]
|
|
669
673
|
}], ctorParameters: () => [], propDecorators: { min: [{
|
|
670
674
|
type: Input
|
|
671
675
|
}], max: [{
|
|
@@ -721,13 +725,14 @@ class ValuePipe {
|
|
|
721
725
|
return obj;
|
|
722
726
|
}
|
|
723
727
|
}
|
|
724
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "
|
|
725
|
-
static { this.ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "14.0.0", version: "
|
|
728
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "21.0.6", ngImport: i0, type: ValuePipe, deps: [], target: i0.ɵɵFactoryTarget.Pipe }); }
|
|
729
|
+
static { this.ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "14.0.0", version: "21.0.6", ngImport: i0, type: ValuePipe, isStandalone: false, name: "value" }); }
|
|
726
730
|
}
|
|
727
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
731
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "21.0.6", ngImport: i0, type: ValuePipe, decorators: [{
|
|
728
732
|
type: Pipe,
|
|
729
733
|
args: [{
|
|
730
|
-
name: 'value'
|
|
734
|
+
name: 'value',
|
|
735
|
+
standalone: false
|
|
731
736
|
}]
|
|
732
737
|
}] });
|
|
733
738
|
|
|
@@ -1335,12 +1340,12 @@ class CilogTableComponent {
|
|
|
1335
1340
|
this.inputNumber.input.nativeElement.focus();
|
|
1336
1341
|
});
|
|
1337
1342
|
}
|
|
1338
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "
|
|
1339
|
-
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" }] }); }
|
|
1343
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "21.0.6", ngImport: i0, type: CilogTableComponent, deps: [{ token: i1.ConfirmationService }, { token: i1.FilterService }, { token: i0.ChangeDetectorRef }, { token: ExportService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
1344
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "21.0.6", type: CilogTableComponent, isStandalone: false, selector: "cilog-table", inputs: { columns: "columns", values: "values", options: "options", loading: "loading" }, outputs: { columnsChange: "columnsChange", valuesChange: "valuesChange", onEdit: "onEdit", onEditInit: "onEditInit", onDelete: "onDelete", onSelect: "onSelect", onUnselect: "onUnselect", onFilter: "onFilter", onFilterInit: "onFilterInit", onSort: "onSort", onPage: "onPage", onRowDoubleClick: "onRowDoubleClick" }, viewQueries: [{ propertyName: "table", first: true, predicate: ["table"], descendants: true, static: true }, { propertyName: "cm", first: true, predicate: ["cm"], descendants: true }, { propertyName: "inputNumber", first: true, predicate: ["inputNumber"], descendants: true }], ngImport: i0, template: "<div [ngStyle]=\"{ 'height': options.scrollHeight != null ? options.scrollHeight : '100%' }\">\n\n @if (options.exportExcel) {\n <button pButton\n icon=\"pi pi-file-excel\"\n class=\"p-button-success absolute z-5 w-2rem h-2rem border-round-right border-noround-top\"\n pTooltip=\"Exporter le contenu de la grille au format Excel\"\n (click)=\"exportExcel(options.exportExcelByFiltre, !options.exportExcelNoColors)\">\n </button>\n }\n\n <p-contextMenu #cm [model]=\"options.contextMenuItems\" />\n\n <p-table #table\n [columns]=\"columns\"\n [value]=\"values\"\n dataKey=\"id\"\n [selectionMode]=\"getModeSelection()\"\n [metaKeySelection]=\"isModeMetakeySelection()\"\n [(selection)]=\"selectedRows\"\n (onRowSelect)=\"onSelectRow($event)\"\n (onRowUnselect)=\"onUnselectRow($event)\"\n (onHeaderCheckboxToggle)=\"onSelectAll($event)\"\n (sortFunction)=\"sortGrille($event)\"\n [customSort]=\"options.grouping == null ? true : false\"\n [scrollable]=\"true\"\n [loading]=\"loading\"\n [scrollHeight]=\"'flex'\"\n [rowGroupMode]=\"options.grouping != null ? 'subheader' : null\"\n [groupRowsBy]=\"options.grouping != null ? options.grouping.obj + '.' + options.grouping.id : null\"\n [groupRowsByOrder]=\"0\"\n [virtualScroll]=\"options.virtualScroll == true && options.scrollHeight != null ? true : false\"\n [virtualScrollItemSize]=\"options.virtualScrollItemSize != null ? options.virtualScrollItemSize : 35\"\n [paginator]=\"options.paginator == null ? false : true\"\n [rows]=\"options.paginatorRows\"\n (onPage)=\"onPageTable($event)\"\n [tableStyleClass]=\"!options.themeGrille ? 'grid_grey' : options.themeGrille\"\n [lazy]=\"options.lazy == true ? true : false\"\n (onFilter)=\"onFilterTable($event)\"\n [rowTrackBy]=\"trackByFunction\"\n [(contextMenuSelection)]=\"contextMenuSelectedItem\"\n [contextMenu]=\"cm\">\n\n <!-- HEADER -->\n <ng-template pTemplate=\"header\" let-columns>\n\n <!-- HEADERS -->\n <tr class=\"rowHeader\">\n @if (isModeCheckboxSelection()) {\n <th class=\"cellDelete\"\n pFrozenColumn>\n @if (!options.filterable && options.toggleAll) {\n <p-tableHeaderCheckbox></p-tableHeaderCheckbox>\n }\n </th>\n }\n @for (col of columns; track col) {\n @if (!col.invisible) {\n <th\n [ngStyle]=\"{ 'width' : col.width ? col.width : null, 'background-color': col.backgroundColor ? col.backgroundColor : null }\"\n [ngClass]=\"{ 'text-center' : options.centerHeaders, 'headerAffichageSimple': !options.headersAffichageEntier, 'headerAffichageEntier': options.headersAffichageEntier }\"\n [pSortableColumn]=\"col.id\"\n [pSortableColumnDisabled]=\"!options.sortable || options.grouping != null || col.libelle == null || col.libelle == ''\"\n id=\"{{ col.id }}\"\n (click)=\"refreshData()\"\n pFrozenColumn\n [frozen]=\"col.frozen\"\n [pTooltip]=\"col.libelle\"\n [tooltipDisabled]=\"!col.tooltipHeader\"\n tooltipPosition=\"bottom\">\n <div [ngStyle]=\"{ 'color': col.textColor ? col.textColor : null }\">\n {{ col.libelle }}\n </div>\n @if (options.sortable && options.grouping == null && col.libelle != null && col.libelle != '') {\n <p-sortIcon\n [field]=\"col.id\">\n </p-sortIcon>\n }\n </th>\n }\n }\n @if (options.rowsDeletable) {\n <th class=\"cellDelete\"></th>\n }\n </tr>\n\n <!-- FILTRES -->\n @if (options.filterable) {\n <tr class=\"rowFilter\">\n @if (isModeCheckboxSelection()) {\n <th class=\"cellDelete\"\n pFrozenColumn>\n @if (options.toggleAll) {\n <p-tableHeaderCheckbox></p-tableHeaderCheckbox>\n }\n </th>\n }\n @for (col of columns; track col) {\n <!-- Text -->\n @if (!col.invisible && ((checkType('Dropdown', col) && col.options.filterText)\n || (checkType('MultiSelect', col) && col.options.filterText)\n || checkType('Text', col)\n || checkType('File', col)\n || (checkType('Button', col) && col.options.filterCol))\n || checkType('Number', col)\n || checkType('CilogNumber', col)) {\n <th\n [ngStyle]=\"{ 'width' : col.width ? col.width : null }\"\n pFrozenColumn\n [frozen]=\"col.frozen\">\n @if (!col.disableFilter) {\n <input\n pInputText\n type=\"text\"\n (input)=\"onFilterCol($event, col)\"\n [(ngModel)]=\"col.options.defaultFilters\">\n }\n </th>\n }\n <!-- Date -->\n @if (!col.invisible && checkType('Date', col)) {\n <th\n [ngStyle]=\"{ 'width' : col.width ? col.width : null }\"\n pFrozenColumn\n [frozen]=\"col.frozen\">\n @if (!col.disableFilter) {\n <p-datepicker\n [view]=\"getOption(col, rowData, 'mode') == null ? 'date' : getOption(col, rowData, 'mode')\"\n [dateFormat]=\"getOption(col, rowData, 'mode') == 'year' ? 'yy' : getOption(col, rowData, 'mode') == 'month' ? 'mm/yy' : 'dd/mm/yy'\"\n [inputId]=\"col.id + '_filter'\"\n firstDayOfWeek=\"1\"\n [readonlyInput]=\"true\"\n appendTo=\"body\"\n selectionMode=\"range\"\n (onSelect)=\"onFilterCol($event, col)\"\n showButtonBar=\"true\"\n (onClearClick)=\"onFilterCol($event, col)\"\n [(ngModel)]=\"col.options.defaultFilters\">\n </p-datepicker>\n }\n </th>\n }\n <!-- Liste -->\n @if (!col.invisible && ((checkType('Dropdown', col) && !col.options.filterText) || (checkType('MultiSelect', col) && !col.options.filterText) || checkType('SelectButton', col) || checkType('State', col))) {\n <th\n [ngStyle]=\"{ 'width' : col.width ? col.width : null }\"\n pFrozenColumn\n [frozen]=\"col.frozen\">\n @if (!col.disableFilter) {\n <p-multiSelect\n [options]=\"col.options?.options\"\n [filter]=\"true\"\n dataKey=\"ID\"\n [optionLabel]=\"col.options?.optionLabel\"\n appendTo=\"body\"\n emptyFilterMessage=\"Aucun r\u00E9sultat\"\n emptyMessage=\"Aucun r\u00E9sultat\"\n [virtualScroll]=\"true\"\n [virtualScrollItemSize]=\"35\"\n selectedItemsLabel=\"{0} selectionn\u00E9s\"\n (onChange)=\"onFilterCol($event, col)\"\n [(ngModel)]=\"col.options.defaultFilters\"\n [group]=\"col.options.optionGroupChildren != null ? true : false\"\n [optionGroupLabel]=\"col.options.optionGroupLabel\"\n [optionGroupChildren]=\"col.options.optionGroupChildren\"\n [showToggleAll]=\"false\"\n [showClear]=\"true\"\n (onClear)=\"onFilterCol(null, col)\">\n <ng-template let-group pTemplate=\"group\">\n <div>{{group[col.options.optionGroupLabel]}}</div>\n </ng-template>\n </p-multiSelect>\n }\n </th>\n }\n <!-- Switch -->\n @if (!col.invisible && checkType('Switch', col)) {\n <th\n [ngStyle]=\"{ 'width' : col.width ? col.width : null }\"\n pFrozenColumn\n [frozen]=\"col.frozen\">\n @if (!col.disableFilter) {\n <p-multiSelect\n [options]=\"optionsSwitch\"\n [showHeader]=\"false\"\n optionLabel=\"label\"\n optionValue=\"value\"\n appendTo=\"body\"\n emptyFilterMessage=\"Aucun r\u00E9sultat\"\n emptyMessage=\"Aucun r\u00E9sultat\"\n [virtualScrollItemSize]=\"30\"\n selectedItemsLabel=\"{0} selectionn\u00E9s\"\n (onChange)=\"onFilterCol($event, col)\"\n [(ngModel)]=\"col.options.defaultFilters\">\n </p-multiSelect>\n }\n </th>\n }\n <!-- Non filtrable -->\n @if (!col.invisible && (checkType('Image', col) || (checkType('Button', col) && !col.options.filterCol))) {\n <th\n [ngStyle]=\"{ 'width' : col.width ? col.width : null }\"\n pFrozenColumn\n [frozen]=\"col.frozen\">\n </th>\n }\n }\n @if (options.rowsDeletable) {\n <th class=\"cellDelete\"></th>\n }\n </tr>\n }\n\n <!-- TOTAL -->\n @if (options.rowTotal) {\n <tr\n class=\"rowTotal\">\n @if (isModeCheckboxSelection()) {\n <th class=\"cellDelete\"\n pFrozenColumn>\n </th>\n }\n @for (col of columns; track col) {\n @if (!col.invisible) {\n <th\n [ngStyle]=\"{ 'width' : col.width ? col.width : null }\"\n [ngClass]=\"{ 'text-center' : true }\"\n pFrozenColumn\n [frozen]=\"col.frozen\">\n <div>{{ getTotalStr(col) }}</div>\n </th>\n }\n }\n @if (options.rowsDeletable) {\n <th class=\"cellDelete\"></th>\n }\n </tr>\n }\n </ng-template>\n\n <!--Groupheader-->\n <ng-template pTemplate=\"groupheader\" let-rowData>\n <tr pRowGroupHeader class=\"rowGrouping\">\n <td [attr.colspan]=\"columns.length\">\n <div class=\"text_bold\">{{ rowData[options.grouping.obj][options.grouping.libelle] }}</div>\n </td>\n </tr>\n </ng-template>\n\n <!-- Body -->\n <ng-template pTemplate=\"body\" let-rowData let-columns=\"columns\">\n <tr id=\"{{ rowData.id }}\"\n [ngStyle]=\"{ 'background-color': rowData.color ? rowData.color : null }\"\n [pSelectableRow]=\"rowData\"\n [pSelectableRowDisabled]=\"!options.selectable || isModeCheckboxSelection() || isModeCellSelection()\"\n (dblclick)=\"onRowDoubleClickEvent(rowData)\"\n [pContextMenuRow]=\"rowData\"\n [pContextMenuRowDisabled]=\"options.contextMenuItems == null\">\n\n @if (isModeCheckboxSelection()) {\n <td\n class=\"cellDelete\"\n pFrozenColumn>\n <p-tableCheckbox [value]=\"rowData\" [disabled]=\"rowData.readonly\"></p-tableCheckbox>\n </td>\n }\n\n @for (col of columns; track col) {\n <!-- Text -->\n @if (!col.invisible && checkType('Text', col) && isModeEdition() && !rowData.readonly && !rowData[col.id]?.readonly) {\n <td\n [ngStyle]=\"{ 'width' : col.width ? col.width : null, 'background-color': rowData[col.id].color ? rowData[col.id].color : null }\"\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\n [pEditableColumn]=\"rowData\"\n [pEditableColumnField]=\"col.id\"\n [pTooltip]=\"rowData[col.id].tooltip != null ? rowData[col.id].tooltip : rowData[col.id].value\"\n [tooltipDisabled]=\"!col.tooltip\"\n tooltipPosition=\"bottom\"\n pFrozenColumn\n (click)=\"options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection && !rowData[col.id].disableSelection && onSelectCell(rowData[col.id])\"\n [frozen]=\"col.frozen\"\n [ngClass]=\"{\r\n 'text-left': col.position == 'left' || col.position == null,\r\n 'text-right': col.position == 'right',\r\n 'text-center': col.position == 'center',\r\n 'font-bold': rowData.bold == true || rowData[col.id].bold == true,\r\n 'font-italic': rowData.italic == true || rowData[col.id].italic == true,\r\n 'selectable_cell' : options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection\r\n }\">\r\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\n <p-cellEditor>\n <ng-template pTemplate=\"input\">\n <input pInputText\n type=\"text\"\n [(ngModel)]=\"rowData[col.id].value\"\n (blur)=\"onEditCell(rowData, col, rowData[col.id].value)\"\n (keydown.enter)=\"onEditCell(rowData, col, rowData[col.id].value)\"\n (keydown.tab)=\"onEditCell(rowData, col, rowData[col.id].value)\"\n (click)=\"onEditInitCell(rowData, col, rowData[col.id].value)\"\n [ngClass]=\"{\r\n 'text-left': col.position == 'left' || col.position == null,\r\n 'text-right': col.position == 'right',\r\n 'text-center': col.position == 'center',\r\n 'font-bold': rowData.bold == true || rowData[col.id].bold == true,\r\n 'font-italic': rowData.italic == true || rowData[col.id].italic == true\r\n }\" />\r\n </ng-template>\n <ng-template pTemplate=\"output\">\n @if (rowData[col.id]) {\n <div\n style=\"white-space: pre;\">\n {{ getFormattedText(col, rowData) }}\n </div>\n }\n </ng-template>\n </p-cellEditor>\n </td>\n }\n @if (!col.invisible && checkType('Text', col) && (!isModeEdition() || rowData.readonly || rowData[col.id]?.readonly)) {\n <td\n [ngStyle]=\"{\r\n 'width' : col.width ? col.width : null,\r\n 'background-color' : rowData[col.id].color ? rowData[col.id].color : null,\r\n 'color' : rowData[col.id].textColor ? rowData[col.id].textColor : null\r\n }\"\r\n (click)=\"options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection && !rowData[col.id].disableSelection && onSelectCell(rowData[col.id])\"\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\n [pTooltip]=\"rowData[col.id].tooltip != null ? rowData[col.id].tooltip : rowData[col.id].value\"\n [tooltipDisabled]=\"!col.tooltip\"\n tooltipPosition=\"bottom\"\n [ngClass]=\"{\r\n 'paddingCell': rowData[col.id] != null,\r\n 'text-left': col.position == 'left' || col.position == null,\r\n 'text-right': col.position == 'right',\r\n 'text-center': col.position == 'center',\r\n 'font-bold': rowData.bold == true || rowData[col.id].bold == true,\r\n 'font-italic': rowData.italic == true || rowData[col.id].italic == true,\r\n 'selectable_cell' : options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection\r\n }\"\r\n pFrozenColumn\n [frozen]=\"col.frozen\">\n <div class=\"p-column-title\">\n {{ col.libelle }} :\n </div>\n @if (rowData[col.id]) {\n <div\n style=\"white-space: pre;\">\n {{ getFormattedText(col, rowData) }}\n </div>\n }\n </td>\n }\n <!-- Dropdown -->\n @if (!col.invisible && checkType('Dropdown', col) && isModeEdition() && !rowData.readonly && !rowData[col.id]?.readonly) {\n <td\n [ngStyle]=\"{ 'width' : col.width ? col.width : null, 'background-color': rowData[col.id].color ? rowData[col.id].color : null }\"\n [ngClass]=\"{\r\n 'text-left': col.position == 'left' || col.position == null,\r\n 'text-right': col.position == 'right',\r\n 'text-center': col.position == 'center',\r\n 'selectable_cell' : options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection\r\n }\"\r\n (click)=\"options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection && onSelectCell(rowData[col.id])\"\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\n [pTooltip]=\"rowData[col.id].tooltip != null ? rowData[col.id].tooltip : rowData[col.id].value != null ? rowData[col.id].value[getOption(col, rowData, 'optionLabel')] : ''\"\n [tooltipDisabled]=\"!col.tooltip\"\n tooltipPosition=\"bottom\"\n pFrozenColumn\n [frozen]=\"col.frozen\"\n class=\"paddingCell\">\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\n @if (rowData[col.id] != null) {\n <p-select\n dataKey=\"ID\"\n [options]=\"getOption(col, rowData, 'options')\"\n [filter]=\"getOption(col, rowData, 'filter')\"\n [optionLabel]=\"getOption(col, rowData, 'optionLabel')\"\n [(ngModel)]=\"rowData[col.id].value\"\n [autoDisplayFirst]=\"false\"\n appendTo=\"body\"\n [showClear]=\"getOption(col, rowData, 'deletable')\"\n emptyFilterMessage=\"Aucun r\u00E9sultat\"\n emptyMessage=\"Aucun r\u00E9sultat\"\n [baseZIndex]=\"getOption(col, rowData, 'baseZIndex')\"\n [virtualScroll]=\"getOption(col, rowData, 'virtualScroll')\"\n [readonly]=\"rowData.readonly || rowData[col.id]?.readonly\"\n [virtualScrollItemSize]=\"30\"\n (onChange)=\"onEditCell(rowData, col, rowData[col.id].value)\"\n (onClear)=\"onEditCell(rowData, col, rowData[col.id].value)\">\n <ng-template let-data pTemplate=\"selectedItem\">\n @if (data != null) {\n <span\n [ngClass]=\"{\r\n 'font-bold': rowData.bold == true || rowData[col.id].bold == true,\r\n 'font-italic': rowData.italic == true || rowData[col.id].italic == true\r\n }\">\r\n {{ data[getOption(col, rowData, 'optionLabel')] }}\n </span>\n }\n @if (data == null) {\n <span></span>\n }\n </ng-template>\n </p-select>\n }\n </td>\n }\n @if (!col.invisible && checkType('Dropdown', col) && (rowData.readonly || rowData[col.id]?.readonly || !isModeEdition())) {\n <td\n [ngStyle]=\"{\r\n 'width' : col.width ? col.width : null,\r\n 'background-color': rowData[col.id].color ? rowData[col.id].color : null,\r\n 'color' : rowData[col.id].textColor ? rowData[col.id].textColor : null\r\n }\"\r\n (click)=\"options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection && onSelectCell(rowData[col.id])\"\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\n [pTooltip]=\"rowData[col.id].tooltip != null ? rowData[col.id].tooltip : rowData[col.id].value != null ? rowData[col.id].value[getOption(col, rowData, 'optionLabel')] : ''\"\n [tooltipDisabled]=\"!col.tooltip\"\n tooltipPosition=\"bottom\"\n [ngClass]=\"{\r\n 'paddingCell': rowData[col.id] != null,\r\n 'text-left': col.position == 'left' || col.position == null,\r\n 'text-right': col.position == 'right',\r\n 'text-center': col.position == 'center',\r\n 'font-bold': rowData.bold == true || rowData[col.id].bold == true,\r\n 'font-italic': rowData.italic == true || rowData[col.id].italic == true,\r\n 'selectable_cell' : options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection\r\n }\"\r\n pFrozenColumn\n [frozen]=\"col.frozen\">\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\n @if (rowData[col.id]) {\n <div>{{ rowData[col.id].value != null ? rowData[col.id].value[getOption(col, rowData, 'optionLabel')] : '' }}</div>\n }\n </td>\n }\n <!-- Cilog Number -->\n @if (!col.invisible && checkType('CilogNumber', col) && isModeEdition() && !rowData.readonly && !rowData[col.id]?.readonly) {\n <td\n [ngStyle]=\"{ 'width' : col.width ? col.width : null, 'background-color': rowData[col.id].color ? rowData[col.id].color : null }\"\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\n [ngClass]=\"{\r\n 'paddingCell': rowData[col.id] != null,\r\n 'selectable_cell' : options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection\r\n }\"\r\n (click)=\"options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection && onSelectCell(rowData[col.id])\"\n [pTooltip]=\"rowData[col.id].tooltip != null ? rowData[col.id].tooltip : rowData[col.id].value | value\"\n [tooltipDisabled]=\"!col.tooltip\"\n tooltipPosition=\"bottom\"\n pFrozenColumn\n [frozen]=\"col.frozen\">\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\n @if (rowData[col.id] && !rowData.readonly && !rowData[col.id]?.readonly) {\n <cilog-input-number\n (onInput)=\"onInputNumber($event)\"\n [(ngModel)]=\"rowData[col.id].value\"\n [inputStyleClass]=\"col.position == null || col.position == 'right' ? 'text-right' : col.position == 'left' ? 'text-left' : 'text-center'\"\n [textColor]=\"rowData[col.id].textColor\"\n [bold]=\"rowData.bold == true || rowData[col.id].bold == true\"\n [italic]=\"rowData.italic == true || rowData[col.id].italic == true\"\n [suffixe]=\"getOption(col, rowData, 'suffix')\"\n [prefixe]=\"getOption(col, rowData, 'prefix') != null ? getOption(col, rowData, 'prefix') + ' ' : null\"\n [min]=\"getOption(col, rowData, 'min')\"\n [max]=\"getOption(col, rowData, 'max')\"\n [disabled]=\"rowData.readonly || rowData[col.id]?.readonly\"\n [maxDecimals]=\"getOption(col, rowData, 'modeInteger') != null && getOption(col, rowData, 'modeInteger') == true ? 0 : getOption(col, rowData, 'maxDecimales') != null ? getOption(col, rowData, 'maxDecimales') : 2 \"\n (onChange)=\"onEditCell(rowData, col, rowData[col.id].value)\"\n (onFocus)=\"onEditInitCell(rowData, col, rowData[col.id].value)\">\n </cilog-input-number>\n }\n </td>\n }\n @if (!col.invisible && checkType('CilogNumber', col) && (rowData.readonly || rowData[col.id]?.readonly || !isModeEdition())) {\n <td\n [ngStyle]=\"{\r\n 'width' : col.width ? col.width : null,\r\n 'background-color': rowData[col.id].color ? rowData[col.id].color : null,\r\n 'color' : rowData[col.id].textColor ? rowData[col.id].textColor : null\r\n }\"\r\n (click)=\"options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection && onSelectCell(rowData[col.id])\"\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\n [pTooltip]=\"rowData[col.id].tooltip != null ? rowData[col.id].tooltip : rowData[col.id].value | value\"\n [tooltipDisabled]=\"!col.tooltip\"\n tooltipPosition=\"bottom\"\n [ngClass]=\"{\r\n 'paddingCell': rowData[col.id] != null,\r\n 'text-left': col.position == 'left' || col.position == null,\r\n 'text-right': col.position == 'right',\r\n 'text-center': col.position == 'center',\r\n 'font-bold': rowData.bold == true || rowData[col.id].bold == true,\r\n 'font-italic': rowData.italic == true || rowData[col.id].italic == true,\r\n 'selectable_cell' : options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection\r\n }\"\r\n pFrozenColumn\n [frozen]=\"col.frozen\">\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\n @if (rowData[col.id]) {\n <div>{{ getFormattedNumber(col, rowData, rowData[col.id].value) }}</div>\n }\n </td>\n }\n <!-- Number -->\n @if (!col.invisible && checkType('Number', col) && isModeEdition() && !rowData.readonly && !rowData[col.id]?.readonly) {\n <td\n [ngStyle]=\"{ 'width' : col.width ? col.width : null, 'background-color': rowData[col.id].color ? rowData[col.id].color : null }\"\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\n [pTooltip]=\"rowData[col.id].tooltip != null ? rowData[col.id].tooltip : rowData[col.id].value | value\"\n [tooltipDisabled]=\"!col.tooltip\"\n [ngClass]=\"{\r\n 'paddingCell': rowData[col.id] != null,\r\n 'text-left': col.position == 'left',\r\n 'text-right': col.position == 'right' || col.position == null,\r\n 'text-center': col.position == 'center',\r\n 'font-bold': rowData.bold == true || rowData[col.id].bold == true,\r\n 'font-italic': rowData.italic == true || rowData[col.id].italic == true,\r\n 'selectable_cell' : options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection\r\n }\"\r\n tooltipPosition=\"bottom\"\n pFrozenColumn\n [frozen]=\"col.frozen\"\n (click)=\"onClickCellNumber(rowData, col)\">\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\n @if (rowData[col.id] && !rowData[col.id].focus) {\n <div>\n {{ getFormattedNumber(col, rowData, rowData[col.id].value) }}\n </div>\n }\n @if (rowData[col.id] && !rowData.readonly && !rowData[col.id]?.readonly && rowData[col.id].focus == true) {\n <p-inputNumber #inputNumber\n locale=\"fr-FR\"\n (onInput)=\"onInputNumber($event)\"\n [(ngModel)]=\"rowData[col.id].value\"\n [showButtons]=\"getOption(col, rowData, 'showButtons')\"\n [inputStyleClass]=\"col.position == null || col.position == 'right' ? 'text-right' : col.position == 'left' ? 'text-left' : 'text-center'\"\n [inputStyle]=\"{ 'font-weight': rowData.bold == true || rowData[col.id].bold == true ? 'bold' : null, 'font-style': rowData.italic == true || rowData[col.id].italic == true ? 'italic' : null }\"\n [suffix]=\"getOption(col, rowData, 'suffix')\"\n [prefix]=\"getOption(col, rowData, 'prefix') != null ? getOption(col, rowData, 'prefix') + ' ' : null\"\n [min]=\"getOption(col, rowData, 'min')\"\n [max]=\"getOption(col, rowData, 'max')\"\n [minFractionDigits]=\"getOption(col, rowData, 'modeInteger') != null && getOption(col, rowData, 'modeInteger') == true ? 0 : getOption(col, rowData, 'minDecimales') != null ? getOption(col, rowData, 'minDecimales') : 0\"\n [maxFractionDigits]=\"getOption(col, rowData, 'modeInteger') != null && getOption(col, rowData, 'modeInteger') == true ? 0 : getOption(col, rowData, 'maxDecimales') != null ? getOption(col, rowData, 'maxDecimales') : 2 \"\n (onBlur)=\"onEditCell(rowData, col, rowData[col.id].value)\"\n (onKeyDown)=\"onKeyDown($event, rowData, col, rowData[col.id].value)\"\n (onFocus)=\"onEditInitCell(rowData, col, rowData[col.id].value)\">\n </p-inputNumber>\n }\n </td>\n }\n @if (!col.invisible && checkType('Number', col) && (rowData.readonly || rowData[col.id]?.readonly || !isModeEdition())) {\n <td\n [ngStyle]=\"{\r\n 'width' : col.width ? col.width : null,\r\n 'background-color': rowData[col.id].color ? rowData[col.id].color : null,\r\n 'color' : rowData[col.id].textColor ? rowData[col.id].textColor : null\r\n }\"\r\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\n [pTooltip]=\"rowData[col.id].tooltip != null ? rowData[col.id].tooltip : rowData[col.id].value | value\"\n [tooltipDisabled]=\"!col.tooltip\"\n tooltipPosition=\"bottom\"\n (click)=\"options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection && onSelectCell(rowData[col.id])\"\n [ngClass]=\"{\r\n 'paddingCell': rowData[col.id] != null,\r\n 'text-left': col.position == 'left',\r\n 'text-right': col.position == 'right' || col.position == null,\r\n 'text-center': col.position == 'center',\r\n 'font-bold': rowData.bold == true || rowData[col.id].bold == true,\r\n 'font-italic': rowData.italic == true || rowData[col.id].italic == true,\r\n 'selectable_cell' : options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection\r\n }\"\r\n pFrozenColumn\n [frozen]=\"col.frozen\">\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\n @if (rowData[col.id]) {\n <div>{{ getFormattedNumber(col, rowData, rowData[col.id].value) }}</div>\n }\n </td>\n }\n <!-- Date -->\n @if (!col.invisible && checkType('Date', col) && isModeEdition() && !rowData.readonly && !rowData[col.id]?.readonly) {\n <td\n [ngStyle]=\"{ 'width' : col.width ? col.width : null, 'background-color': rowData[col.id].color ? rowData[col.id].color : null }\"\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\n [ngClass]=\"{\r\n 'paddingCell': rowData[col.id] != null,\r\n 'selectable_cell' : options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection\r\n }\"\r\n (click)=\"options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection && onSelectCell(rowData[col.id])\"\n [pTooltip]=\"rowData[col.id].tooltip != null ? rowData[col.id].tooltip : getOption(col, rowData, 'mode') == 'year' ? (rowData[col.id].value | date: 'yyyy') : getOption(col, rowData, 'mode') == 'month' ? (rowData[col.id].value | date: 'MM/yy') : getOption(col, rowData, 'mode') == 'hour' ? (rowData[col.id].value | date: 'HH:mm') : getOption(col, rowData, 'mode') == 'datehour' ? (rowData[col.id].value | date: 'dd/MM/yy HH:mm') : (rowData[col.id].value | date: 'dd/MM/yyyy')\"\n [tooltipDisabled]=\"!col.tooltip\"\n tooltipPosition=\"bottom\"\n pFrozenColumn\n [frozen]=\"col.frozen\">\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\n <p-datepicker [(ngModel)]=\"rowData[col.id].value\"\n [view]=\"getOption(col, rowData, 'mode') == null || getOption(col, rowData, 'mode') == 'date' || getOption(col, rowData, 'mode') == 'hour' ? 'date' : getOption(col, rowData, 'mode') == 'datehour' ? 'date' : getOption(col, rowData, 'mode')\"\n [dateFormat]=\"getOption(col, rowData, 'mode') == 'year' ? 'yy' : getOption(col, rowData, 'mode') == 'month' ? 'mm/yy' : getOption(col, rowData, 'mode') == 'hour' || getOption(col, rowData, 'mode') == 'datehour' ? 'dd/mm/yy' : 'dd/mm/yy'\"\n [showTime]=\"getOption(col, rowData, 'mode') == 'datehour'\"\n [timeOnly]=\"getOption(col, rowData, 'mode') == 'hour'\"\n [hourFormat]=\"24\"\n firstDayOfWeek=\"1\"\n (onSelect)=\"onEditCell(rowData, col, rowData[col.id].value)\"\n (onBlur)=\"onEditCell(rowData, col, rowData[col.id].value)\"\n (onClear)=\"onEditCell(rowData, col, rowData[col.id].value)\"\n [inputStyleClass]=\"col.position == null || col.position == 'right' ? 'text-right' : col.position == 'left' ? 'text-left' : 'text-center'\"\n [inputStyle]=\"{ 'font-weight': rowData.bold == true || rowData[col.id].bold == true ? 'bold' : null, 'font-style': rowData.italic == true || rowData[col.id].italic == true ? 'italic' : null }\"\n [showClear]=\"getOption(col, rowData, 'clear')\"\n [minDate]=\"getOption(col, rowData, 'minDate')\"\n [maxDate]=\"getOption(col, rowData, 'maxDate')\"\n [defaultDate]=\"getOption(col, rowData, 'defaultDate')\"\n appendTo=\"body\">\n </p-datepicker>\n </td>\n }\n @if (!col.invisible && checkType('Date', col) && (rowData.readonly || rowData[col.id]?.readonly || !isModeEdition())) {\n <td\n [ngStyle]=\"{\r\n 'min-width' : col.width ? col.width : null,\r\n 'background-color': rowData[col.id].color ? rowData[col.id].color : null,\r\n 'color' : rowData[col.id].textColor ? rowData[col.id].textColor : null\r\n }\"\r\n (click)=\"options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection && onSelectCell(rowData[col.id])\"\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\n [pTooltip]=\"rowData[col.id].tooltip != null ? rowData[col.id].tooltip : rowData[col.id].value | date: 'dd/MM/yyyy'\"\n [tooltipDisabled]=\"!col.tooltip\"\n tooltipPosition=\"bottom\"\n [ngClass]=\"{\r\n 'paddingCell': rowData[col.id] != null,\r\n 'text-left': col.position == 'left' || col.position == null,\r\n 'text-right': col.position == 'right',\r\n 'text-center': col.position == 'center',\r\n 'font-bold': rowData.bold == true || rowData[col.id].bold == true,\r\n 'font-italic': rowData.italic == true || rowData[col.id].italic == true,\r\n 'selectable_cell' : options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection\r\n }\"\r\n pFrozenColumn\n [frozen]=\"col.frozen\">\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\n @if (rowData[col.id]) {\n <div>{{ rowData[col.id].value | date: (getOption(col, rowData, 'mode') == 'year' ? 'yyyy' : getOption(col, rowData, 'mode') == 'month' ? 'MM/yyyy' : 'dd/MM/yyyy') }}</div>\n }\n </td>\n }\n <!-- MultiSelect -->\n @if (!col.invisible && checkType('MultiSelect', col) && isModeEdition() && !rowData.readonly && !rowData[col.id]?.readonly) {\n <td\n [ngStyle]=\"{ 'width' : col.width ? col.width : null, 'background-color': rowData[col.id].color ? rowData[col.id].color : null }\"\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\n [ngClass]=\"{\r\n 'text-left': col.position == 'left' || col.position == null,\r\n 'text-right': col.position == 'right',\r\n 'text-center': col.position == 'center',\r\n 'selectable_cell' : options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection\r\n }\"\r\n (click)=\"options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection && onSelectCell(rowData[col.id])\"\n [pTooltip]=\"rowData[col.id].tooltip != null ? rowData[col.id].tooltip : getMultiSelectConcat(rowData[col.id].value, getOption(col, rowData, 'optionLabel'))\"\n [tooltipDisabled]=\"!col.tooltip\"\n tooltipPosition=\"bottom\"\n pFrozenColumn\n [frozen]=\"col.frozen\"\n class=\"paddingCell\">\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\n @if (rowData[col.id] != null) {\n <p-multiSelect\n [options]=\"getOption(col, rowData, 'options')\"\n [filter]=\"getOption(col, rowData, 'filter')\"\n [optionLabel]=\"getOption(col, rowData, 'optionLabel')\"\n [(ngModel)]=\"rowData[col.id].value\"\n appendTo=\"body\"\n dataKey=\"ID\"\n emptyFilterMessage=\"Aucun r\u00E9sultat\"\n emptyMessage=\"Aucun r\u00E9sultat\"\n [baseZIndex]=\"getOption(col, rowData, 'baseZIndex')\"\n [virtualScroll]=\"getOption(col, rowData, 'virtualScroll')\"\n [readonly]=\"rowData.readonly || rowData[col.id]?.readonly || !isModeEdition()\"\n [virtualScrollItemSize]=\"30\"\n selectedItemsLabel=\"{0} selectionn\u00E9s\"\n (onChange)=\"editMultiselect(rowData, col, $event)\"\n [showToggleAll]=\"false\"\n [showHeader]=\"getOption(col, rowData, 'filter')\"\n [group]=\"getOption(col, rowData, 'optionGroupChildren') != null ? true : false\"\n [optionGroupLabel]=\"getOption(col, rowData, 'optionGroupLabel')\"\n [optionGroupChildren]=\"getOption(col, rowData, 'optionGroupChildren')\"\n ngDefaultControl>\n <ng-template let-data pTemplate=\"selectedItems\">\n @for (option of data; track option; let i = $index) {\n <span\n [ngClass]=\"{\r\n 'font-bold': rowData.bold == true || rowData[col.id].bold == true,\r\n 'font-italic': rowData.italic == true || rowData[col.id].italic == true\r\n }\">\r\n {{ option[getOption(col, rowData, 'optionLabel')] + (i != data.length - 1 ? ',' : '') }}\n </span>\n }\n </ng-template>\n <ng-template let-group pTemplate=\"group\">\n <div>{{group[col.options.optionGroupLabel]}}</div>\n </ng-template>\n </p-multiSelect>\n }\n </td>\n }\n @if (!col.invisible && checkType('MultiSelect', col) && (rowData.readonly || rowData[col.id]?.readonly || !isModeEdition())) {\n <td\n [ngStyle]=\"{\r\n 'width' : col.width ? col.width : null,\r\n 'background-color': rowData[col.id].color ? rowData[col.id].color : null,\r\n 'color' : rowData[col.id].textColor ? rowData[col.id].textColor : null\r\n }\"\r\n (click)=\"options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection && onSelectCell(rowData[col.id])\"\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\n [pTooltip]=\"rowData[col.id].tooltip != null ? rowData[col.id].tooltip : getMultiSelectConcat(rowData[col.id].value, getOption(col, rowData, 'optionLabel'))\"\n [tooltipDisabled]=\"!col.tooltip\"\n tooltipPosition=\"bottom\"\n [ngClass]=\"{\r\n 'paddingCell': rowData[col.id] != null,\r\n 'text-left': col.position == 'left' || col.position == null,\r\n 'text-right': col.position == 'right',\r\n 'text-center': col.position == 'center',\r\n 'font-bold': rowData.bold == true || rowData[col.id].bold == true,\r\n 'font-italic': rowData.italic == true || rowData[col.id].italic == true,\r\n 'selectable_cell' : options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection\r\n }\"\r\n pFrozenColumn\n [frozen]=\"col.frozen\">\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\n @if (rowData[col.id]) {\n <div>{{ getMultiSelectConcat(rowData[col.id].value, getOption(col, rowData, 'optionLabel')) }}</div>\n }\n </td>\n }\n <!-- Image -->\n @if (!col.invisible && checkType('Image', col)) {\n <td\n [ngStyle]=\"{ 'width' : col.width ? col.width : null, 'background-color': rowData[col.id].color ? rowData[col.id].color : null }\"\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\n [ngClass]=\"{\r\n 'paddingCell': rowData[col.id] != null,\r\n 'selectable_cell' : options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection\r\n }\"\r\n (click)=\"options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection && onSelectCell(rowData[col.id])\"\n class=\"text-center\"\n pFrozenColumn\n [frozen]=\"col.frozen\">\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\n @if (rowData[col.id]) {\n <img style=\"vertical-align: middle; width: 40px;\" src=\"{{ rowData[col.id].value }}\" />\n }\n </td>\n }\n <!-- Button -->\n @if (!col.invisible && checkType('Button', col)) {\n <td\n class=\"paddingCell text-center\"\n [ngClass]=\"{\r\n 'selectable_cell' : options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection\r\n }\"\r\n (click)=\"options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection && onSelectCell(rowData[col.id])\"\n [ngStyle]=\"{ 'width' : col.width ? col.width : null, 'background-color': rowData[col.id].color ? rowData[col.id].color : null }\">\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\n @if (rowData[col.id].value != null && isValueButtonByType(rowData[col.id].value, 'function')) {\n <button pButton\n [disabled]=\"rowData.readonly || rowData[col.id]?.readonly\"\n [label]=\"getOption(col, rowData, 'label')\"\n [icon]=\"getOption(col, rowData, 'icon')\"\n (click)=\"rowData[col.id].value()\"\n [pTooltip]=\"rowData[col.id].tooltip != null ? rowData[col.id].tooltip : getOption(col, rowData, 'label')\"\n [tooltipDisabled]=\"!col.tooltip\"\n [class]=\"'p-button-' + getOption(col, rowData, 'severity')\"\n [ngClass]=\"{\r\n 'font-bold': rowData.bold == true || rowData[col.id].bold == true,\r\n 'font-italic': rowData.italic == true || rowData[col.id].italic == true\r\n }\">\r\n </button>\n }\n @if (isValueButtonByType(rowData[col.id].value, 'string')) {\n <div\n [ngClass]=\"{\r\n 'paddingCell': rowData[col.id] != null,\r\n 'text-left': col.position == 'left' || col.position == null,\r\n 'text-right': col.position == 'right',\r\n 'text-center': col.position == 'center',\r\n 'font-bold': rowData.bold == true || rowData[col.id].bold == true,\r\n 'font-italic': rowData.italic == true || rowData[col.id].italic == true\r\n }\"\r\n [pTooltip]=\"rowData[col.id].tooltip != null ? rowData[col.id].tooltip : rowData[col.id].value\"\n [tooltipDisabled]=\"!col.tooltip\">\n {{ rowData[col.id].value }}\n </div>\n }\n </td>\n }\n <!-- SelectButton -->\n @if (!col.invisible && checkType('SelectButton', col) && isModeEdition() && !rowData.readonly && !rowData[col.id]?.readonly) {\n <td\n [ngStyle]=\"{ 'width' : col.width ? col.width : null, 'background-color': rowData[col.id].color ? rowData[col.id].color : null }\"\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\n [ngClass]=\"{\r\n 'paddingCell': rowData[col.id] != null,\r\n 'selectable_cell' : options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection\r\n }\"\r\n (click)=\"options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection && onSelectCell(rowData[col.id])\"\n pFrozenColumn\n [frozen]=\"col.frozen\">\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\n @if (rowData[col.id] != null) {\n <p-selectButton\n [options]=\"getOption(col, rowData, 'options')\"\n [optionLabel]=\"getOption(col, rowData, 'optionLabel')\"\n [optionValue]=\"getOption(col, rowData, 'optionValue') != null ? getOption(col, rowData, 'optionValue') : 'value'\"\n [(ngModel)]=\"rowData[col.id].value\"\n [disabled]=\"rowData.readonly || rowData[col.id]?.readonly || !isModeEdition()\"\n (onChange)=\"onEditCell(rowData, col, rowData[col.id].value)\">\n <ng-template let-item pTemplate=\"item\">\n <span class=\"text-center w-full\"\n [ngClass]=\"{\r\n 'font-bold': rowData.bold == true || rowData[col.id].bold == true,\r\n 'font-italic': rowData.italic == true || rowData[col.id].italic == true\r\n }\">\r\n {{ item.label }}\n </span>\n </ng-template>\n </p-selectButton>\n }\n </td>\n }\n @if (!col.invisible && checkType('SelectButton', col) && (rowData.readonly || rowData[col.id]?.readonly || !isModeEdition())) {\n <td\n [ngStyle]=\"{\r\n 'width' : col.width ? col.width : null,\r\n 'background-color': rowData[col.id].color ? rowData[col.id].color : null,\r\n 'color' : rowData[col.id].textColor ? rowData[col.id].textColor : null\r\n }\"\r\n (click)=\"options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection && onSelectCell(rowData[col.id])\"\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\n pFrozenColumn\n [frozen]=\"col.frozen\"\n class=\"text-center\"\n [ngClass]=\"{\r\n 'paddingCell': rowData[col.id] != null,\r\n 'font-bold': rowData.bold == true || rowData[col.id].bold == true,\r\n 'font-italic': rowData.italic == true || rowData[col.id].italic == true,\r\n 'selectable_cell' : options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection\r\n }\">\r\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\n @if (rowData[col.id]) {\n <div>{{ getSelectLibelleByValue(rowData, col) }}</div>\n }\n </td>\n }\n <!-- Switch -->\n @if (!col.invisible && checkType('Switch', col)) {\n <td\n [ngStyle]=\"{ 'width' : col.width ? col.width : null, 'background-color': rowData[col.id].color ? rowData[col.id].color : null }\"\n class=\"text-center\"\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\n [ngClass]=\"{\r\n 'paddingCell': rowData[col.id] != null,\r\n 'selectable_cell' : options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection\r\n }\"\r\n (click)=\"options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection && onSelectCell(rowData[col.id])\"\n pFrozenColumn\n [frozen]=\"col.frozen\">\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\n @if (rowData[col.id] != null) {\n <p-toggleswitch\n [(ngModel)]=\"rowData[col.id].value\"\n [disabled]=\"rowData.readonly || rowData[col.id]?.readonly || (getOption(col, rowData, 'action') == null && !isModeEdition())\"\n (onChange)=\"onEditCell(rowData, col, rowData[col.id].value)\"\n ngDefaultControl>\n </p-toggleswitch>\n }\n </td>\n }\n <!-- File -->\n @if (!col.invisible && checkType('File', col) && isModeEdition() && !rowData.readonly && !rowData[col.id]?.readonly) {\n <td\n [ngStyle]=\"{ 'width' : col.width ? col.width : null, 'background-color': rowData[col.id].color ? rowData[col.id].color : null }\"\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\n [ngClass]=\"{\r\n 'paddingCell': rowData[col.id] != null,\r\n 'selectable_cell' : options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection\r\n }\"\r\n (click)=\"options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection && onSelectCell(rowData[col.id])\"\n pFrozenColumn\n [frozen]=\"col.frozen\">\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\n @if (rowData[col.id] != null) {\n <div class=\"p-inputgroup\">\n <button type=\"button\"\n pButton\n pRipple\n icon=\"pi pi-upload\"\n (click)=\"clickById('input_' + rowData[col.id].id)\"\n [disabled]=\"rowData.readonly || rowData[col.id]?.readonly || !isModeEdition()\">\n </button>\n <input id=\"{{'output_' + rowData[col.id].id}}\"\n pInputText\n type=\"text\"\n [ngClass]=\"{\r\n 'text-left': col.position == 'left' || col.position == null,\r\n 'text-right': col.position == 'right',\r\n 'text-center': col.position == 'center',\r\n 'font-bold': rowData.bold == true || rowData[col.id].bold == true,\r\n 'font-italic': rowData.italic == true || rowData[col.id].italic == true\r\n }\"\r\n value=\"{{ rowData[col.id].value != null ? rowData[col.id].value : '' }}\"\n readonly\n [pTooltip]=\"rowData[col.id].tooltip != null ? rowData[col.id].tooltip : rowData[col.id].value ? rowData[col.id].value : ''\"\n [tooltipDisabled]=\"!col.tooltip\">\n @if (getOption(col, rowData, 'downloadPath') && rowData[col.id].value != null) {\n <button\n type=\"button\"\n pButton\n pRipple\n icon=\"pi pi-download\"\n (click)=\"downloadFile(rowData[col.id])\"\n [disabled]=\"rowData.readonly || rowData[col.id]?.readonly || !isModeEdition()\">\n </button>\n }\n </div>\n }\n @if (rowData[col.id]) {\n <input id=\"{{'input_' + rowData[col.id].id}}\" #inputFile pInputText type=\"file\" hidden (change)=\"rowData[col.id].value = inputFile.files[0].name; onEditCell(rowData, col, inputFile.files[0])\">\n }\n </td>\n }\n @if (!col.invisible && checkType('File', col) && (rowData.readonly || rowData[col.id]?.readonly || !isModeEdition())) {\n <td\n [ngStyle]=\"{\r\n 'width' : col.width ? col.width : null,\r\n 'background-color': rowData[col.id].color ? rowData[col.id].color : null,\r\n 'color' : rowData[col.id].textColor ? rowData[col.id].textColor : null\r\n }\"\r\n (click)=\"options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection && onSelectCell(rowData[col.id])\"\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\n [pTooltip]=\"rowData[col.id].tooltip != null ? rowData[col.id].tooltip : rowData[col.id].value ? rowData[col.id].value : ''\"\n [ngClass]=\"{\r\n 'paddingCell': rowData[col.id] != null,\r\n 'text-left': col.position == 'left' || col.position == null,\r\n 'text-right': col.position == 'right',\r\n 'text-center': col.position == 'center',\r\n 'font-bold': rowData.bold == true || rowData[col.id].bold == true,\r\n 'font-italic': rowData.italic == true || rowData[col.id].italic == true,\r\n 'selectable_cell' : options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection\r\n }\"\r\n [tooltipDisabled]=\"!col.tooltip\"\n tooltipPosition=\"bottom\"\n pFrozenColumn\n [frozen]=\"col.frozen\">\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\n @if (rowData[col.id]) {\n <div>{{ rowData[col.id].value ? rowData[col.id].value : '' }}</div>\n }\n </td>\n }\n <!-- State -->\n @if (!col.invisible && checkType('State', col)) {\n <td\n [ngStyle]=\"{ 'width' : col.width ? col.width : null, 'background-color': rowData[col.id].color ? rowData[col.id].color : null }\"\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\n [ngClass]=\"{\r\n 'paddingCell': rowData[col.id] != null,\r\n 'selectable_cell' : options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection\r\n }\"\r\n (click)=\"options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection && onSelectCell(rowData[col.id])\"\n class=\"text-center\"\n pFrozenColumn\n [frozen]=\"col.frozen\">\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\n @if (rowData[col.id].value != null) {\n <p-tag\n [value]=\"rowData[col.id].value[getOption(col, rowData, 'optionLabel')]\"\n [severity]=\"rowData[col.id].value.severity\"\n [icon]=\"rowData[col.id].value.icon\"\n [style]=\"{\r\n 'background-color': rowData[col.id].value.backgroundColor,\r\n 'color': rowData[col.id].value.textColor,\r\n 'font-weight': rowData.bold == true || rowData[col.id].bold == true ? 'bold' : null,\r\n 'font-style': rowData.italic == true || rowData[col.id].italic == true ? 'italic' : null\r\n }\">\r\n </p-tag>\n }\n </td>\n }\n }\n\n <!-- Deletion -->\n @if (options.rowsDeletable) {\n <td\n class=\"cellDelete\"\n [ngClass]=\"rowData.deletable ? 'paddingCell' : null\">\n @if (rowData.deletable) {\n <button\n pButton\n type=\"button\"\n icon=\"pi pi-times\"\n class=\"p-button-danger buttonDelete p-button-text\"\n [disabled]=\"rowData.readonly\"\n (click)=\"onDeleteLine(rowData)\">\n </button>\n }\n </td>\n }\n\n </tr>\n </ng-template>\n </p-table>\n </div>\n", styles: ["::ng-deep .p-tooltip .p-tooltip-text{overflow-wrap:break-word!important}:host ::ng-deep .grid_brown .rowHeader>th{background-color:#795548}:host ::ng-deep .grid_brown .rowHeader>th div{color:#fff}:host ::ng-deep .grid_brown .rowHeader>th i{color:#fff}:host ::ng-deep .grid_brown .rowHeader .p-sortable-column:hover{background-color:#a47767}:host ::ng-deep .grid_brown .rowHeader .p-sortable-column:hover i{color:#fff}:host ::ng-deep .grid_brown .rowHeader .p-sortable-column.p-highlight div{color:#76c7ff}:host ::ng-deep .grid_brown .rowHeader .p-sortable-column.p-highlight .p-sortable-column-icon{color:#76c7ff}:host ::ng-deep .grid_brown .rowFilter th{background-color:#795548}:host ::ng-deep .grid_grey .rowHeader>th{background-color:#dedddd}:host ::ng-deep .grid_grey .rowHeader>th div{color:#495057}:host ::ng-deep .grid_grey .rowHeader>th i{color:#495057}:host ::ng-deep .grid_grey .rowHeader .p-sortable-column:hover{background-color:#e7e7e7}:host ::ng-deep .grid_grey .rowHeader .p-sortable-column:hover i{color:#495057}:host ::ng-deep .grid_grey .rowHeader .p-sortable-column.p-highlight div{color:#008bff}:host ::ng-deep .grid_grey .rowHeader .p-sortable-column.p-highlight .p-sortable-column-icon{color:#008bff}:host ::ng-deep .grid_grey .rowFilter th{background-color:#dedddd}:host ::ng-deep .selectable_cell:hover{background:#dcdcdc!important;cursor:pointer!important}:host ::ng-deep .p-frozen-column{z-index:2!important}:host ::ng-deep .p-datatable-thead{z-index:3!important}:host ::ng-deep .p-checkbox{border-radius:inherit!important}:host ::ng-deep p-inputnumber{width:100%}:host ::ng-deep .p-calendar,:host ::ng-deep .p-inputtext,:host ::ng-deep .p-inputnumber,:host ::ng-deep .p-inputnumber-input,:host ::ng-deep .p-dropdown,:host ::ng-deep .p-multiselect{width:100%}:host ::ng-deep .suffixe,:host ::ng-deep .prefixe{height:25px;padding-top:1px!important}:host ::ng-deep .p-multiselect-label-container,:host ::ng-deep .p-dropdown-label{width:1px!important}:host ::ng-deep .p-scroller-content{min-height:50%}:host ::ng-deep .rowTotal>th{background-color:#edcbaa!important}:host ::ng-deep .rowGrouping{background:#faeada!important}:host ::ng-deep .p-inputswitch.p-inputswitch-checked .p-inputswitch-slider{background:#30e130}:host ::ng-deep .p-inputswitch.p-inputswitch-checked:not(.p-disabled):hover .p-inputswitch-slider{background:#2bd12b}:host ::ng-deep .p-datatable-table{table-layout:fixed}:host ::ng-deep .p-datatable-thead>tr>th{border:1px solid rgba(0,0,0,.12)!important;padding:8px;font-weight:600;height:40px}:host ::ng-deep .headerAffichageSimple div{overflow:hidden;white-space:nowrap;text-overflow:ellipsis}:host ::ng-deep .headerAffichageEntier{word-wrap:break-word}:host ::ng-deep .p-datatable-tbody>tr>td{border:1px solid rgba(0,0,0,.12)!important;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}:host ::ng-deep .p-datatable-tbody>tr>td div{overflow:hidden;white-space:nowrap;text-overflow:ellipsis}:host ::ng-deep .p-tag{max-width:100%}:host ::ng-deep .p-tag .p-tag-value{overflow:hidden;white-space:nowrap;text-overflow:ellipsis}:host ::ng-deep .p-button{padding:5px;max-width:100%}:host ::ng-deep .p-button .p-button-label{overflow:hidden!important;white-space:nowrap!important;text-overflow:ellipsis!important}:host ::ng-deep .text_bold{font-weight:700!important}:host ::ng-deep .cellDelete{flex:0 0 50px!important;width:50px;text-align:center!important;padding:0!important}:host ::ng-deep .p-tooltip .p-tooltip-text{background-color:red!important}:host ::ng-deep .p-skeleton{background-color:#dee2e6;border-radius:6px;padding:0}:host ::ng-deep .p-datatable-tbody>tr{height:35px}:host ::ng-deep .p-inputtext{height:25px!important;padding:4px 5px!important}:host ::ng-deep .p-inputnumber{height:25px;padding:0!important}:host ::ng-deep .p-inputnumber-input{padding:0 5px!important}:host ::ng-deep .p-inputgroup .p-inputtext{height:25px;padding:4px 5px!important}:host ::ng-deep .p-dropdown,:host ::ng-deep .p-multiselect{vertical-align:middle}:host ::ng-deep .p-dropdown-label{padding-top:2px;padding-bottom:2px}:host ::ng-deep .p-multiselect-label{padding-top:2px;padding-bottom:2px}:host ::ng-deep .p-editable-column{padding:3px 10px!important}:host ::ng-deep .paddingCell{padding:3px 10px!important}:host ::ng-deep .p-selectbutton>.p-button{width:50%;height:25px}:host ::ng-deep .p-inputgroup>.p-button{height:25px}:host ::ng-deep .buttonDelete{width:100%;height:20px}:host ::ng-deep .p-column-title{display:none}:host ::ng-deep .p-datatable-loading-icon{color:#fff}\n"], dependencies: [{ kind: "directive", type: i3.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i3.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "directive", type: i1.PrimeTemplate, selector: "[pTemplate]", inputs: ["type", "pTemplate"] }, { kind: "directive", type: i4.ButtonDirective, selector: "[pButton]", inputs: ["ptButtonDirective", "pButtonPT", "pButtonUnstyled", "hostName", "text", "plain", "raised", "size", "outlined", "rounded", "iconPos", "loadingIcon", "fluid", "label", "icon", "loading", "buttonProps", "severity"] }, { kind: "component", type: i5.Table, selector: "p-table", inputs: ["frozenColumns", "frozenValue", "styleClass", "tableStyle", "tableStyleClass", "paginator", "pageLinks", "rowsPerPageOptions", "alwaysShowPaginator", "paginatorPosition", "paginatorStyleClass", "paginatorDropdownAppendTo", "paginatorDropdownScrollHeight", "currentPageReportTemplate", "showCurrentPageReport", "showJumpToPageDropdown", "showJumpToPageInput", "showFirstLastIcon", "showPageLinks", "defaultSortOrder", "sortMode", "resetPageOnSort", "selectionMode", "selectionPageOnly", "contextMenuSelection", "contextMenuSelectionMode", "dataKey", "metaKeySelection", "rowSelectable", "rowTrackBy", "lazy", "lazyLoadOnInit", "compareSelectionBy", "csvSeparator", "exportFilename", "filters", "globalFilterFields", "filterDelay", "filterLocale", "expandedRowKeys", "editingRowKeys", "rowExpandMode", "scrollable", "rowGroupMode", "scrollHeight", "virtualScroll", "virtualScrollItemSize", "virtualScrollOptions", "virtualScrollDelay", "frozenWidth", "contextMenu", "resizableColumns", "columnResizeMode", "reorderableColumns", "loading", "loadingIcon", "showLoader", "rowHover", "customSort", "showInitialSortBadge", "exportFunction", "exportHeader", "stateKey", "stateStorage", "editMode", "groupRowsBy", "size", "showGridlines", "stripedRows", "groupRowsByOrder", "responsiveLayout", "breakpoint", "paginatorLocale", "value", "columns", "first", "rows", "totalRecords", "sortField", "sortOrder", "multiSortMeta", "selection", "selectAll"], outputs: ["contextMenuSelectionChange", "selectAllChange", "selectionChange", "onRowSelect", "onRowUnselect", "onPage", "onSort", "onFilter", "onLazyLoad", "onRowExpand", "onRowCollapse", "onContextMenuSelect", "onColResize", "onColReorder", "onRowReorder", "onEditInit", "onEditComplete", "onEditCancel", "onHeaderCheckboxToggle", "sortFunction", "firstChange", "rowsChange", "onStateSave", "onStateRestore"] }, { kind: "directive", type: i5.SortableColumn, selector: "[pSortableColumn]", inputs: ["pSortableColumn", "pSortableColumnDisabled"] }, { kind: "directive", type: i5.FrozenColumn, selector: "[pFrozenColumn]", inputs: ["frozen", "alignFrozen"] }, { kind: "directive", type: i5.RowGroupHeader, selector: "[pRowGroupHeader]" }, { kind: "directive", type: i5.SelectableRow, selector: "[pSelectableRow]", inputs: ["pSelectableRow", "pSelectableRowIndex", "pSelectableRowDisabled"] }, { kind: "directive", type: i5.ContextMenuRow, selector: "[pContextMenuRow]", inputs: ["pContextMenuRow", "pContextMenuRowIndex", "pContextMenuRowDisabled"] }, { kind: "directive", type: i5.EditableColumn, selector: "[pEditableColumn]", inputs: ["pEditableColumn", "pEditableColumnField", "pEditableColumnRowIndex", "pEditableColumnDisabled", "pFocusCellSelector"] }, { kind: "component", type: i5.CellEditor, selector: "p-cellEditor" }, { kind: "component", type: i5.SortIcon, selector: "p-sortIcon", inputs: ["field"] }, { kind: "component", type: i5.TableCheckbox, selector: "p-tableCheckbox", inputs: ["value", "disabled", "required", "index", "inputId", "name", "ariaLabel"] }, { kind: "component", type: i5.TableHeaderCheckbox, selector: "p-tableHeaderCheckbox", inputs: ["disabled", "inputId", "name", "ariaLabel"] }, { kind: "directive", type: i2$1.InputText, selector: "[pInputText]", inputs: ["hostName", "ptInputText", "pInputTextPT", "pInputTextUnstyled", "pSize", "variant", "fluid", "invalid"] }, { kind: "component", type: i7.SelectButton, selector: "p-selectButton, p-selectbutton, p-select-button", inputs: ["options", "optionLabel", "optionValue", "optionDisabled", "unselectable", "tabindex", "multiple", "allowEmpty", "styleClass", "ariaLabelledBy", "dataKey", "autofocus", "size", "fluid"], outputs: ["onOptionClick", "onChange"] }, { kind: "component", type: i8.Select, selector: "p-select", inputs: ["id", "scrollHeight", "filter", "panelStyle", "styleClass", "panelStyleClass", "readonly", "editable", "tabindex", "placeholder", "loadingIcon", "filterPlaceholder", "filterLocale", "inputId", "dataKey", "filterBy", "filterFields", "autofocus", "resetFilterOnHide", "checkmark", "dropdownIcon", "loading", "optionLabel", "optionValue", "optionDisabled", "optionGroupLabel", "optionGroupChildren", "group", "showClear", "emptyFilterMessage", "emptyMessage", "lazy", "virtualScroll", "virtualScrollItemSize", "virtualScrollOptions", "overlayOptions", "ariaFilterLabel", "ariaLabel", "ariaLabelledBy", "filterMatchMode", "tooltip", "tooltipPosition", "tooltipPositionStyle", "tooltipStyleClass", "focusOnHover", "selectOnFocus", "autoOptionFocus", "autofocusFilter", "filterValue", "options", "appendTo", "motionOptions"], outputs: ["onChange", "onFilter", "onFocus", "onBlur", "onClick", "onShow", "onHide", "onClear", "onLazyLoad"] }, { kind: "component", type: i9.InputNumber, selector: "p-inputNumber, p-inputnumber, p-input-number", inputs: ["showButtons", "format", "buttonLayout", "inputId", "styleClass", "placeholder", "tabindex", "title", "ariaLabelledBy", "ariaDescribedBy", "ariaLabel", "ariaRequired", "autocomplete", "incrementButtonClass", "decrementButtonClass", "incrementButtonIcon", "decrementButtonIcon", "readonly", "allowEmpty", "locale", "localeMatcher", "mode", "currency", "currencyDisplay", "useGrouping", "minFractionDigits", "maxFractionDigits", "prefix", "suffix", "inputStyle", "inputStyleClass", "showClear", "autofocus"], outputs: ["onInput", "onFocus", "onBlur", "onKeyDown", "onClear"] }, { kind: "component", type: i10.MultiSelect, selector: "p-multiSelect, p-multiselect, p-multi-select", inputs: ["id", "ariaLabel", "styleClass", "panelStyle", "panelStyleClass", "inputId", "readonly", "group", "filter", "filterPlaceHolder", "filterLocale", "overlayVisible", "tabindex", "dataKey", "ariaLabelledBy", "displaySelectedLabel", "maxSelectedLabels", "selectionLimit", "selectedItemsLabel", "showToggleAll", "emptyFilterMessage", "emptyMessage", "resetFilterOnHide", "dropdownIcon", "chipIcon", "optionLabel", "optionValue", "optionDisabled", "optionGroupLabel", "optionGroupChildren", "showHeader", "filterBy", "scrollHeight", "lazy", "virtualScroll", "loading", "virtualScrollItemSize", "loadingIcon", "virtualScrollOptions", "overlayOptions", "ariaFilterLabel", "filterMatchMode", "tooltip", "tooltipPosition", "tooltipPositionStyle", "tooltipStyleClass", "autofocusFilter", "display", "autocomplete", "showClear", "autofocus", "placeholder", "options", "filterValue", "selectAll", "focusOnHover", "filterFields", "selectOnFocus", "autoOptionFocus", "highlightOnSelect", "size", "variant", "fluid", "appendTo", "motionOptions"], outputs: ["onChange", "onFilter", "onFocus", "onBlur", "onClick", "onClear", "onPanelShow", "onPanelHide", "onLazyLoad", "onRemove", "onSelectAllChange"] }, { kind: "component", type: i11.DatePicker, selector: "p-datePicker, p-datepicker, p-date-picker", inputs: ["iconDisplay", "styleClass", "inputStyle", "inputId", "inputStyleClass", "placeholder", "ariaLabelledBy", "ariaLabel", "iconAriaLabel", "dateFormat", "multipleSeparator", "rangeSeparator", "inline", "showOtherMonths", "selectOtherMonths", "showIcon", "icon", "readonlyInput", "shortYearCutoff", "hourFormat", "timeOnly", "stepHour", "stepMinute", "stepSecond", "showSeconds", "showOnFocus", "showWeek", "startWeekFromFirstDayOfYear", "showClear", "dataType", "selectionMode", "maxDateCount", "showButtonBar", "todayButtonStyleClass", "clearButtonStyleClass", "autofocus", "autoZIndex", "baseZIndex", "panelStyleClass", "panelStyle", "keepInvalid", "hideOnDateTimeSelect", "touchUI", "timeSeparator", "focusTrap", "showTransitionOptions", "hideTransitionOptions", "tabindex", "minDate", "maxDate", "disabledDates", "disabledDays", "showTime", "responsiveOptions", "numberOfMonths", "firstDayOfWeek", "view", "defaultDate", "appendTo", "motionOptions"], outputs: ["onFocus", "onBlur", "onClose", "onSelect", "onClear", "onInput", "onTodayClick", "onClearClick", "onMonthChange", "onYearChange", "onClickOutside", "onShow"] }, { kind: "component", type: i12.ContextMenu, selector: "p-contextMenu, p-contextmenu, p-context-menu", inputs: ["model", "triggerEvent", "target", "global", "style", "styleClass", "autoZIndex", "baseZIndex", "id", "breakpoint", "ariaLabel", "ariaLabelledBy", "pressDelay", "appendTo", "motionOptions"], outputs: ["onShow", "onHide"] }, { kind: "component", type: i13.Tag, selector: "p-tag", inputs: ["styleClass", "severity", "value", "icon", "rounded"] }, { kind: "directive", type: i14.Tooltip, selector: "[pTooltip]", inputs: ["tooltipPosition", "tooltipEvent", "positionStyle", "tooltipStyleClass", "tooltipZIndex", "escape", "showDelay", "hideDelay", "life", "positionTop", "positionLeft", "autoHide", "fitContent", "hideOnEscape", "pTooltip", "tooltipDisabled", "tooltipOptions", "appendTo", "ptTooltip", "pTooltipPT", "pTooltipUnstyled"] }, { kind: "component", type: i15.ToggleSwitch, selector: "p-toggleswitch, p-toggleSwitch, p-toggle-switch", inputs: ["styleClass", "tabindex", "inputId", "readonly", "trueValue", "falseValue", "ariaLabel", "size", "ariaLabelledBy", "autofocus"], outputs: ["onChange"] }, { kind: "directive", type: i16.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i16.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i16.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: CilogInputNumberComponent, selector: "cilog-input-number", inputs: ["min", "max", "maxDecimals", "prefixe", "suffixe", "inputStyleClass", "disabled", "readonly", "textColor", "bold", "italic", "floatLabel"], outputs: ["onInput", "onChange", "onFocus", "onBlur"] }, { kind: "pipe", type: i3.DatePipe, name: "date" }, { kind: "pipe", type: ValuePipe, name: "value" }] }); }
|
|
1340
1345
|
}
|
|
1341
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
1346
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "21.0.6", ngImport: i0, type: CilogTableComponent, decorators: [{
|
|
1342
1347
|
type: Component,
|
|
1343
|
-
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"] }]
|
|
1348
|
+
args: [{ selector: 'cilog-table', standalone: false, template: "<div [ngStyle]=\"{ 'height': options.scrollHeight != null ? options.scrollHeight : '100%' }\">\n\n @if (options.exportExcel) {\n <button pButton\n icon=\"pi pi-file-excel\"\n class=\"p-button-success absolute z-5 w-2rem h-2rem border-round-right border-noround-top\"\n pTooltip=\"Exporter le contenu de la grille au format Excel\"\n (click)=\"exportExcel(options.exportExcelByFiltre, !options.exportExcelNoColors)\">\n </button>\n }\n\n <p-contextMenu #cm [model]=\"options.contextMenuItems\" />\n\n <p-table #table\n [columns]=\"columns\"\n [value]=\"values\"\n dataKey=\"id\"\n [selectionMode]=\"getModeSelection()\"\n [metaKeySelection]=\"isModeMetakeySelection()\"\n [(selection)]=\"selectedRows\"\n (onRowSelect)=\"onSelectRow($event)\"\n (onRowUnselect)=\"onUnselectRow($event)\"\n (onHeaderCheckboxToggle)=\"onSelectAll($event)\"\n (sortFunction)=\"sortGrille($event)\"\n [customSort]=\"options.grouping == null ? true : false\"\n [scrollable]=\"true\"\n [loading]=\"loading\"\n [scrollHeight]=\"'flex'\"\n [rowGroupMode]=\"options.grouping != null ? 'subheader' : null\"\n [groupRowsBy]=\"options.grouping != null ? options.grouping.obj + '.' + options.grouping.id : null\"\n [groupRowsByOrder]=\"0\"\n [virtualScroll]=\"options.virtualScroll == true && options.scrollHeight != null ? true : false\"\n [virtualScrollItemSize]=\"options.virtualScrollItemSize != null ? options.virtualScrollItemSize : 35\"\n [paginator]=\"options.paginator == null ? false : true\"\n [rows]=\"options.paginatorRows\"\n (onPage)=\"onPageTable($event)\"\n [tableStyleClass]=\"!options.themeGrille ? 'grid_grey' : options.themeGrille\"\n [lazy]=\"options.lazy == true ? true : false\"\n (onFilter)=\"onFilterTable($event)\"\n [rowTrackBy]=\"trackByFunction\"\n [(contextMenuSelection)]=\"contextMenuSelectedItem\"\n [contextMenu]=\"cm\">\n\n <!-- HEADER -->\n <ng-template pTemplate=\"header\" let-columns>\n\n <!-- HEADERS -->\n <tr class=\"rowHeader\">\n @if (isModeCheckboxSelection()) {\n <th class=\"cellDelete\"\n pFrozenColumn>\n @if (!options.filterable && options.toggleAll) {\n <p-tableHeaderCheckbox></p-tableHeaderCheckbox>\n }\n </th>\n }\n @for (col of columns; track col) {\n @if (!col.invisible) {\n <th\n [ngStyle]=\"{ 'width' : col.width ? col.width : null, 'background-color': col.backgroundColor ? col.backgroundColor : null }\"\n [ngClass]=\"{ 'text-center' : options.centerHeaders, 'headerAffichageSimple': !options.headersAffichageEntier, 'headerAffichageEntier': options.headersAffichageEntier }\"\n [pSortableColumn]=\"col.id\"\n [pSortableColumnDisabled]=\"!options.sortable || options.grouping != null || col.libelle == null || col.libelle == ''\"\n id=\"{{ col.id }}\"\n (click)=\"refreshData()\"\n pFrozenColumn\n [frozen]=\"col.frozen\"\n [pTooltip]=\"col.libelle\"\n [tooltipDisabled]=\"!col.tooltipHeader\"\n tooltipPosition=\"bottom\">\n <div [ngStyle]=\"{ 'color': col.textColor ? col.textColor : null }\">\n {{ col.libelle }}\n </div>\n @if (options.sortable && options.grouping == null && col.libelle != null && col.libelle != '') {\n <p-sortIcon\n [field]=\"col.id\">\n </p-sortIcon>\n }\n </th>\n }\n }\n @if (options.rowsDeletable) {\n <th class=\"cellDelete\"></th>\n }\n </tr>\n\n <!-- FILTRES -->\n @if (options.filterable) {\n <tr class=\"rowFilter\">\n @if (isModeCheckboxSelection()) {\n <th class=\"cellDelete\"\n pFrozenColumn>\n @if (options.toggleAll) {\n <p-tableHeaderCheckbox></p-tableHeaderCheckbox>\n }\n </th>\n }\n @for (col of columns; track col) {\n <!-- Text -->\n @if (!col.invisible && ((checkType('Dropdown', col) && col.options.filterText)\n || (checkType('MultiSelect', col) && col.options.filterText)\n || checkType('Text', col)\n || checkType('File', col)\n || (checkType('Button', col) && col.options.filterCol))\n || checkType('Number', col)\n || checkType('CilogNumber', col)) {\n <th\n [ngStyle]=\"{ 'width' : col.width ? col.width : null }\"\n pFrozenColumn\n [frozen]=\"col.frozen\">\n @if (!col.disableFilter) {\n <input\n pInputText\n type=\"text\"\n (input)=\"onFilterCol($event, col)\"\n [(ngModel)]=\"col.options.defaultFilters\">\n }\n </th>\n }\n <!-- Date -->\n @if (!col.invisible && checkType('Date', col)) {\n <th\n [ngStyle]=\"{ 'width' : col.width ? col.width : null }\"\n pFrozenColumn\n [frozen]=\"col.frozen\">\n @if (!col.disableFilter) {\n <p-datepicker\n [view]=\"getOption(col, rowData, 'mode') == null ? 'date' : getOption(col, rowData, 'mode')\"\n [dateFormat]=\"getOption(col, rowData, 'mode') == 'year' ? 'yy' : getOption(col, rowData, 'mode') == 'month' ? 'mm/yy' : 'dd/mm/yy'\"\n [inputId]=\"col.id + '_filter'\"\n firstDayOfWeek=\"1\"\n [readonlyInput]=\"true\"\n appendTo=\"body\"\n selectionMode=\"range\"\n (onSelect)=\"onFilterCol($event, col)\"\n showButtonBar=\"true\"\n (onClearClick)=\"onFilterCol($event, col)\"\n [(ngModel)]=\"col.options.defaultFilters\">\n </p-datepicker>\n }\n </th>\n }\n <!-- Liste -->\n @if (!col.invisible && ((checkType('Dropdown', col) && !col.options.filterText) || (checkType('MultiSelect', col) && !col.options.filterText) || checkType('SelectButton', col) || checkType('State', col))) {\n <th\n [ngStyle]=\"{ 'width' : col.width ? col.width : null }\"\n pFrozenColumn\n [frozen]=\"col.frozen\">\n @if (!col.disableFilter) {\n <p-multiSelect\n [options]=\"col.options?.options\"\n [filter]=\"true\"\n dataKey=\"ID\"\n [optionLabel]=\"col.options?.optionLabel\"\n appendTo=\"body\"\n emptyFilterMessage=\"Aucun r\u00E9sultat\"\n emptyMessage=\"Aucun r\u00E9sultat\"\n [virtualScroll]=\"true\"\n [virtualScrollItemSize]=\"35\"\n selectedItemsLabel=\"{0} selectionn\u00E9s\"\n (onChange)=\"onFilterCol($event, col)\"\n [(ngModel)]=\"col.options.defaultFilters\"\n [group]=\"col.options.optionGroupChildren != null ? true : false\"\n [optionGroupLabel]=\"col.options.optionGroupLabel\"\n [optionGroupChildren]=\"col.options.optionGroupChildren\"\n [showToggleAll]=\"false\"\n [showClear]=\"true\"\n (onClear)=\"onFilterCol(null, col)\">\n <ng-template let-group pTemplate=\"group\">\n <div>{{group[col.options.optionGroupLabel]}}</div>\n </ng-template>\n </p-multiSelect>\n }\n </th>\n }\n <!-- Switch -->\n @if (!col.invisible && checkType('Switch', col)) {\n <th\n [ngStyle]=\"{ 'width' : col.width ? col.width : null }\"\n pFrozenColumn\n [frozen]=\"col.frozen\">\n @if (!col.disableFilter) {\n <p-multiSelect\n [options]=\"optionsSwitch\"\n [showHeader]=\"false\"\n optionLabel=\"label\"\n optionValue=\"value\"\n appendTo=\"body\"\n emptyFilterMessage=\"Aucun r\u00E9sultat\"\n emptyMessage=\"Aucun r\u00E9sultat\"\n [virtualScrollItemSize]=\"30\"\n selectedItemsLabel=\"{0} selectionn\u00E9s\"\n (onChange)=\"onFilterCol($event, col)\"\n [(ngModel)]=\"col.options.defaultFilters\">\n </p-multiSelect>\n }\n </th>\n }\n <!-- Non filtrable -->\n @if (!col.invisible && (checkType('Image', col) || (checkType('Button', col) && !col.options.filterCol))) {\n <th\n [ngStyle]=\"{ 'width' : col.width ? col.width : null }\"\n pFrozenColumn\n [frozen]=\"col.frozen\">\n </th>\n }\n }\n @if (options.rowsDeletable) {\n <th class=\"cellDelete\"></th>\n }\n </tr>\n }\n\n <!-- TOTAL -->\n @if (options.rowTotal) {\n <tr\n class=\"rowTotal\">\n @if (isModeCheckboxSelection()) {\n <th class=\"cellDelete\"\n pFrozenColumn>\n </th>\n }\n @for (col of columns; track col) {\n @if (!col.invisible) {\n <th\n [ngStyle]=\"{ 'width' : col.width ? col.width : null }\"\n [ngClass]=\"{ 'text-center' : true }\"\n pFrozenColumn\n [frozen]=\"col.frozen\">\n <div>{{ getTotalStr(col) }}</div>\n </th>\n }\n }\n @if (options.rowsDeletable) {\n <th class=\"cellDelete\"></th>\n }\n </tr>\n }\n </ng-template>\n\n <!--Groupheader-->\n <ng-template pTemplate=\"groupheader\" let-rowData>\n <tr pRowGroupHeader class=\"rowGrouping\">\n <td [attr.colspan]=\"columns.length\">\n <div class=\"text_bold\">{{ rowData[options.grouping.obj][options.grouping.libelle] }}</div>\n </td>\n </tr>\n </ng-template>\n\n <!-- Body -->\n <ng-template pTemplate=\"body\" let-rowData let-columns=\"columns\">\n <tr id=\"{{ rowData.id }}\"\n [ngStyle]=\"{ 'background-color': rowData.color ? rowData.color : null }\"\n [pSelectableRow]=\"rowData\"\n [pSelectableRowDisabled]=\"!options.selectable || isModeCheckboxSelection() || isModeCellSelection()\"\n (dblclick)=\"onRowDoubleClickEvent(rowData)\"\n [pContextMenuRow]=\"rowData\"\n [pContextMenuRowDisabled]=\"options.contextMenuItems == null\">\n\n @if (isModeCheckboxSelection()) {\n <td\n class=\"cellDelete\"\n pFrozenColumn>\n <p-tableCheckbox [value]=\"rowData\" [disabled]=\"rowData.readonly\"></p-tableCheckbox>\n </td>\n }\n\n @for (col of columns; track col) {\n <!-- Text -->\n @if (!col.invisible && checkType('Text', col) && isModeEdition() && !rowData.readonly && !rowData[col.id]?.readonly) {\n <td\n [ngStyle]=\"{ 'width' : col.width ? col.width : null, 'background-color': rowData[col.id].color ? rowData[col.id].color : null }\"\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\n [pEditableColumn]=\"rowData\"\n [pEditableColumnField]=\"col.id\"\n [pTooltip]=\"rowData[col.id].tooltip != null ? rowData[col.id].tooltip : rowData[col.id].value\"\n [tooltipDisabled]=\"!col.tooltip\"\n tooltipPosition=\"bottom\"\n pFrozenColumn\n (click)=\"options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection && !rowData[col.id].disableSelection && onSelectCell(rowData[col.id])\"\n [frozen]=\"col.frozen\"\n [ngClass]=\"{\r\n 'text-left': col.position == 'left' || col.position == null,\r\n 'text-right': col.position == 'right',\r\n 'text-center': col.position == 'center',\r\n 'font-bold': rowData.bold == true || rowData[col.id].bold == true,\r\n 'font-italic': rowData.italic == true || rowData[col.id].italic == true,\r\n 'selectable_cell' : options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection\r\n }\">\r\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\n <p-cellEditor>\n <ng-template pTemplate=\"input\">\n <input pInputText\n type=\"text\"\n [(ngModel)]=\"rowData[col.id].value\"\n (blur)=\"onEditCell(rowData, col, rowData[col.id].value)\"\n (keydown.enter)=\"onEditCell(rowData, col, rowData[col.id].value)\"\n (keydown.tab)=\"onEditCell(rowData, col, rowData[col.id].value)\"\n (click)=\"onEditInitCell(rowData, col, rowData[col.id].value)\"\n [ngClass]=\"{\r\n 'text-left': col.position == 'left' || col.position == null,\r\n 'text-right': col.position == 'right',\r\n 'text-center': col.position == 'center',\r\n 'font-bold': rowData.bold == true || rowData[col.id].bold == true,\r\n 'font-italic': rowData.italic == true || rowData[col.id].italic == true\r\n }\" />\r\n </ng-template>\n <ng-template pTemplate=\"output\">\n @if (rowData[col.id]) {\n <div\n style=\"white-space: pre;\">\n {{ getFormattedText(col, rowData) }}\n </div>\n }\n </ng-template>\n </p-cellEditor>\n </td>\n }\n @if (!col.invisible && checkType('Text', col) && (!isModeEdition() || rowData.readonly || rowData[col.id]?.readonly)) {\n <td\n [ngStyle]=\"{\r\n 'width' : col.width ? col.width : null,\r\n 'background-color' : rowData[col.id].color ? rowData[col.id].color : null,\r\n 'color' : rowData[col.id].textColor ? rowData[col.id].textColor : null\r\n }\"\r\n (click)=\"options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection && !rowData[col.id].disableSelection && onSelectCell(rowData[col.id])\"\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\n [pTooltip]=\"rowData[col.id].tooltip != null ? rowData[col.id].tooltip : rowData[col.id].value\"\n [tooltipDisabled]=\"!col.tooltip\"\n tooltipPosition=\"bottom\"\n [ngClass]=\"{\r\n 'paddingCell': rowData[col.id] != null,\r\n 'text-left': col.position == 'left' || col.position == null,\r\n 'text-right': col.position == 'right',\r\n 'text-center': col.position == 'center',\r\n 'font-bold': rowData.bold == true || rowData[col.id].bold == true,\r\n 'font-italic': rowData.italic == true || rowData[col.id].italic == true,\r\n 'selectable_cell' : options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection\r\n }\"\r\n pFrozenColumn\n [frozen]=\"col.frozen\">\n <div class=\"p-column-title\">\n {{ col.libelle }} :\n </div>\n @if (rowData[col.id]) {\n <div\n style=\"white-space: pre;\">\n {{ getFormattedText(col, rowData) }}\n </div>\n }\n </td>\n }\n <!-- Dropdown -->\n @if (!col.invisible && checkType('Dropdown', col) && isModeEdition() && !rowData.readonly && !rowData[col.id]?.readonly) {\n <td\n [ngStyle]=\"{ 'width' : col.width ? col.width : null, 'background-color': rowData[col.id].color ? rowData[col.id].color : null }\"\n [ngClass]=\"{\r\n 'text-left': col.position == 'left' || col.position == null,\r\n 'text-right': col.position == 'right',\r\n 'text-center': col.position == 'center',\r\n 'selectable_cell' : options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection\r\n }\"\r\n (click)=\"options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection && onSelectCell(rowData[col.id])\"\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\n [pTooltip]=\"rowData[col.id].tooltip != null ? rowData[col.id].tooltip : rowData[col.id].value != null ? rowData[col.id].value[getOption(col, rowData, 'optionLabel')] : ''\"\n [tooltipDisabled]=\"!col.tooltip\"\n tooltipPosition=\"bottom\"\n pFrozenColumn\n [frozen]=\"col.frozen\"\n class=\"paddingCell\">\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\n @if (rowData[col.id] != null) {\n <p-select\n dataKey=\"ID\"\n [options]=\"getOption(col, rowData, 'options')\"\n [filter]=\"getOption(col, rowData, 'filter')\"\n [optionLabel]=\"getOption(col, rowData, 'optionLabel')\"\n [(ngModel)]=\"rowData[col.id].value\"\n [autoDisplayFirst]=\"false\"\n appendTo=\"body\"\n [showClear]=\"getOption(col, rowData, 'deletable')\"\n emptyFilterMessage=\"Aucun r\u00E9sultat\"\n emptyMessage=\"Aucun r\u00E9sultat\"\n [baseZIndex]=\"getOption(col, rowData, 'baseZIndex')\"\n [virtualScroll]=\"getOption(col, rowData, 'virtualScroll')\"\n [readonly]=\"rowData.readonly || rowData[col.id]?.readonly\"\n [virtualScrollItemSize]=\"30\"\n (onChange)=\"onEditCell(rowData, col, rowData[col.id].value)\"\n (onClear)=\"onEditCell(rowData, col, rowData[col.id].value)\">\n <ng-template let-data pTemplate=\"selectedItem\">\n @if (data != null) {\n <span\n [ngClass]=\"{\r\n 'font-bold': rowData.bold == true || rowData[col.id].bold == true,\r\n 'font-italic': rowData.italic == true || rowData[col.id].italic == true\r\n }\">\r\n {{ data[getOption(col, rowData, 'optionLabel')] }}\n </span>\n }\n @if (data == null) {\n <span></span>\n }\n </ng-template>\n </p-select>\n }\n </td>\n }\n @if (!col.invisible && checkType('Dropdown', col) && (rowData.readonly || rowData[col.id]?.readonly || !isModeEdition())) {\n <td\n [ngStyle]=\"{\r\n 'width' : col.width ? col.width : null,\r\n 'background-color': rowData[col.id].color ? rowData[col.id].color : null,\r\n 'color' : rowData[col.id].textColor ? rowData[col.id].textColor : null\r\n }\"\r\n (click)=\"options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection && onSelectCell(rowData[col.id])\"\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\n [pTooltip]=\"rowData[col.id].tooltip != null ? rowData[col.id].tooltip : rowData[col.id].value != null ? rowData[col.id].value[getOption(col, rowData, 'optionLabel')] : ''\"\n [tooltipDisabled]=\"!col.tooltip\"\n tooltipPosition=\"bottom\"\n [ngClass]=\"{\r\n 'paddingCell': rowData[col.id] != null,\r\n 'text-left': col.position == 'left' || col.position == null,\r\n 'text-right': col.position == 'right',\r\n 'text-center': col.position == 'center',\r\n 'font-bold': rowData.bold == true || rowData[col.id].bold == true,\r\n 'font-italic': rowData.italic == true || rowData[col.id].italic == true,\r\n 'selectable_cell' : options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection\r\n }\"\r\n pFrozenColumn\n [frozen]=\"col.frozen\">\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\n @if (rowData[col.id]) {\n <div>{{ rowData[col.id].value != null ? rowData[col.id].value[getOption(col, rowData, 'optionLabel')] : '' }}</div>\n }\n </td>\n }\n <!-- Cilog Number -->\n @if (!col.invisible && checkType('CilogNumber', col) && isModeEdition() && !rowData.readonly && !rowData[col.id]?.readonly) {\n <td\n [ngStyle]=\"{ 'width' : col.width ? col.width : null, 'background-color': rowData[col.id].color ? rowData[col.id].color : null }\"\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\n [ngClass]=\"{\r\n 'paddingCell': rowData[col.id] != null,\r\n 'selectable_cell' : options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection\r\n }\"\r\n (click)=\"options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection && onSelectCell(rowData[col.id])\"\n [pTooltip]=\"rowData[col.id].tooltip != null ? rowData[col.id].tooltip : rowData[col.id].value | value\"\n [tooltipDisabled]=\"!col.tooltip\"\n tooltipPosition=\"bottom\"\n pFrozenColumn\n [frozen]=\"col.frozen\">\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\n @if (rowData[col.id] && !rowData.readonly && !rowData[col.id]?.readonly) {\n <cilog-input-number\n (onInput)=\"onInputNumber($event)\"\n [(ngModel)]=\"rowData[col.id].value\"\n [inputStyleClass]=\"col.position == null || col.position == 'right' ? 'text-right' : col.position == 'left' ? 'text-left' : 'text-center'\"\n [textColor]=\"rowData[col.id].textColor\"\n [bold]=\"rowData.bold == true || rowData[col.id].bold == true\"\n [italic]=\"rowData.italic == true || rowData[col.id].italic == true\"\n [suffixe]=\"getOption(col, rowData, 'suffix')\"\n [prefixe]=\"getOption(col, rowData, 'prefix') != null ? getOption(col, rowData, 'prefix') + ' ' : null\"\n [min]=\"getOption(col, rowData, 'min')\"\n [max]=\"getOption(col, rowData, 'max')\"\n [disabled]=\"rowData.readonly || rowData[col.id]?.readonly\"\n [maxDecimals]=\"getOption(col, rowData, 'modeInteger') != null && getOption(col, rowData, 'modeInteger') == true ? 0 : getOption(col, rowData, 'maxDecimales') != null ? getOption(col, rowData, 'maxDecimales') : 2 \"\n (onChange)=\"onEditCell(rowData, col, rowData[col.id].value)\"\n (onFocus)=\"onEditInitCell(rowData, col, rowData[col.id].value)\">\n </cilog-input-number>\n }\n </td>\n }\n @if (!col.invisible && checkType('CilogNumber', col) && (rowData.readonly || rowData[col.id]?.readonly || !isModeEdition())) {\n <td\n [ngStyle]=\"{\r\n 'width' : col.width ? col.width : null,\r\n 'background-color': rowData[col.id].color ? rowData[col.id].color : null,\r\n 'color' : rowData[col.id].textColor ? rowData[col.id].textColor : null\r\n }\"\r\n (click)=\"options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection && onSelectCell(rowData[col.id])\"\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\n [pTooltip]=\"rowData[col.id].tooltip != null ? rowData[col.id].tooltip : rowData[col.id].value | value\"\n [tooltipDisabled]=\"!col.tooltip\"\n tooltipPosition=\"bottom\"\n [ngClass]=\"{\r\n 'paddingCell': rowData[col.id] != null,\r\n 'text-left': col.position == 'left' || col.position == null,\r\n 'text-right': col.position == 'right',\r\n 'text-center': col.position == 'center',\r\n 'font-bold': rowData.bold == true || rowData[col.id].bold == true,\r\n 'font-italic': rowData.italic == true || rowData[col.id].italic == true,\r\n 'selectable_cell' : options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection\r\n }\"\r\n pFrozenColumn\n [frozen]=\"col.frozen\">\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\n @if (rowData[col.id]) {\n <div>{{ getFormattedNumber(col, rowData, rowData[col.id].value) }}</div>\n }\n </td>\n }\n <!-- Number -->\n @if (!col.invisible && checkType('Number', col) && isModeEdition() && !rowData.readonly && !rowData[col.id]?.readonly) {\n <td\n [ngStyle]=\"{ 'width' : col.width ? col.width : null, 'background-color': rowData[col.id].color ? rowData[col.id].color : null }\"\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\n [pTooltip]=\"rowData[col.id].tooltip != null ? rowData[col.id].tooltip : rowData[col.id].value | value\"\n [tooltipDisabled]=\"!col.tooltip\"\n [ngClass]=\"{\r\n 'paddingCell': rowData[col.id] != null,\r\n 'text-left': col.position == 'left',\r\n 'text-right': col.position == 'right' || col.position == null,\r\n 'text-center': col.position == 'center',\r\n 'font-bold': rowData.bold == true || rowData[col.id].bold == true,\r\n 'font-italic': rowData.italic == true || rowData[col.id].italic == true,\r\n 'selectable_cell' : options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection\r\n }\"\r\n tooltipPosition=\"bottom\"\n pFrozenColumn\n [frozen]=\"col.frozen\"\n (click)=\"onClickCellNumber(rowData, col)\">\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\n @if (rowData[col.id] && !rowData[col.id].focus) {\n <div>\n {{ getFormattedNumber(col, rowData, rowData[col.id].value) }}\n </div>\n }\n @if (rowData[col.id] && !rowData.readonly && !rowData[col.id]?.readonly && rowData[col.id].focus == true) {\n <p-inputNumber #inputNumber\n locale=\"fr-FR\"\n (onInput)=\"onInputNumber($event)\"\n [(ngModel)]=\"rowData[col.id].value\"\n [showButtons]=\"getOption(col, rowData, 'showButtons')\"\n [inputStyleClass]=\"col.position == null || col.position == 'right' ? 'text-right' : col.position == 'left' ? 'text-left' : 'text-center'\"\n [inputStyle]=\"{ 'font-weight': rowData.bold == true || rowData[col.id].bold == true ? 'bold' : null, 'font-style': rowData.italic == true || rowData[col.id].italic == true ? 'italic' : null }\"\n [suffix]=\"getOption(col, rowData, 'suffix')\"\n [prefix]=\"getOption(col, rowData, 'prefix') != null ? getOption(col, rowData, 'prefix') + ' ' : null\"\n [min]=\"getOption(col, rowData, 'min')\"\n [max]=\"getOption(col, rowData, 'max')\"\n [minFractionDigits]=\"getOption(col, rowData, 'modeInteger') != null && getOption(col, rowData, 'modeInteger') == true ? 0 : getOption(col, rowData, 'minDecimales') != null ? getOption(col, rowData, 'minDecimales') : 0\"\n [maxFractionDigits]=\"getOption(col, rowData, 'modeInteger') != null && getOption(col, rowData, 'modeInteger') == true ? 0 : getOption(col, rowData, 'maxDecimales') != null ? getOption(col, rowData, 'maxDecimales') : 2 \"\n (onBlur)=\"onEditCell(rowData, col, rowData[col.id].value)\"\n (onKeyDown)=\"onKeyDown($event, rowData, col, rowData[col.id].value)\"\n (onFocus)=\"onEditInitCell(rowData, col, rowData[col.id].value)\">\n </p-inputNumber>\n }\n </td>\n }\n @if (!col.invisible && checkType('Number', col) && (rowData.readonly || rowData[col.id]?.readonly || !isModeEdition())) {\n <td\n [ngStyle]=\"{\r\n 'width' : col.width ? col.width : null,\r\n 'background-color': rowData[col.id].color ? rowData[col.id].color : null,\r\n 'color' : rowData[col.id].textColor ? rowData[col.id].textColor : null\r\n }\"\r\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\n [pTooltip]=\"rowData[col.id].tooltip != null ? rowData[col.id].tooltip : rowData[col.id].value | value\"\n [tooltipDisabled]=\"!col.tooltip\"\n tooltipPosition=\"bottom\"\n (click)=\"options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection && onSelectCell(rowData[col.id])\"\n [ngClass]=\"{\r\n 'paddingCell': rowData[col.id] != null,\r\n 'text-left': col.position == 'left',\r\n 'text-right': col.position == 'right' || col.position == null,\r\n 'text-center': col.position == 'center',\r\n 'font-bold': rowData.bold == true || rowData[col.id].bold == true,\r\n 'font-italic': rowData.italic == true || rowData[col.id].italic == true,\r\n 'selectable_cell' : options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection\r\n }\"\r\n pFrozenColumn\n [frozen]=\"col.frozen\">\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\n @if (rowData[col.id]) {\n <div>{{ getFormattedNumber(col, rowData, rowData[col.id].value) }}</div>\n }\n </td>\n }\n <!-- Date -->\n @if (!col.invisible && checkType('Date', col) && isModeEdition() && !rowData.readonly && !rowData[col.id]?.readonly) {\n <td\n [ngStyle]=\"{ 'width' : col.width ? col.width : null, 'background-color': rowData[col.id].color ? rowData[col.id].color : null }\"\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\n [ngClass]=\"{\r\n 'paddingCell': rowData[col.id] != null,\r\n 'selectable_cell' : options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection\r\n }\"\r\n (click)=\"options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection && onSelectCell(rowData[col.id])\"\n [pTooltip]=\"rowData[col.id].tooltip != null ? rowData[col.id].tooltip : getOption(col, rowData, 'mode') == 'year' ? (rowData[col.id].value | date: 'yyyy') : getOption(col, rowData, 'mode') == 'month' ? (rowData[col.id].value | date: 'MM/yy') : getOption(col, rowData, 'mode') == 'hour' ? (rowData[col.id].value | date: 'HH:mm') : getOption(col, rowData, 'mode') == 'datehour' ? (rowData[col.id].value | date: 'dd/MM/yy HH:mm') : (rowData[col.id].value | date: 'dd/MM/yyyy')\"\n [tooltipDisabled]=\"!col.tooltip\"\n tooltipPosition=\"bottom\"\n pFrozenColumn\n [frozen]=\"col.frozen\">\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\n <p-datepicker [(ngModel)]=\"rowData[col.id].value\"\n [view]=\"getOption(col, rowData, 'mode') == null || getOption(col, rowData, 'mode') == 'date' || getOption(col, rowData, 'mode') == 'hour' ? 'date' : getOption(col, rowData, 'mode') == 'datehour' ? 'date' : getOption(col, rowData, 'mode')\"\n [dateFormat]=\"getOption(col, rowData, 'mode') == 'year' ? 'yy' : getOption(col, rowData, 'mode') == 'month' ? 'mm/yy' : getOption(col, rowData, 'mode') == 'hour' || getOption(col, rowData, 'mode') == 'datehour' ? 'dd/mm/yy' : 'dd/mm/yy'\"\n [showTime]=\"getOption(col, rowData, 'mode') == 'datehour'\"\n [timeOnly]=\"getOption(col, rowData, 'mode') == 'hour'\"\n [hourFormat]=\"24\"\n firstDayOfWeek=\"1\"\n (onSelect)=\"onEditCell(rowData, col, rowData[col.id].value)\"\n (onBlur)=\"onEditCell(rowData, col, rowData[col.id].value)\"\n (onClear)=\"onEditCell(rowData, col, rowData[col.id].value)\"\n [inputStyleClass]=\"col.position == null || col.position == 'right' ? 'text-right' : col.position == 'left' ? 'text-left' : 'text-center'\"\n [inputStyle]=\"{ 'font-weight': rowData.bold == true || rowData[col.id].bold == true ? 'bold' : null, 'font-style': rowData.italic == true || rowData[col.id].italic == true ? 'italic' : null }\"\n [showClear]=\"getOption(col, rowData, 'clear')\"\n [minDate]=\"getOption(col, rowData, 'minDate')\"\n [maxDate]=\"getOption(col, rowData, 'maxDate')\"\n [defaultDate]=\"getOption(col, rowData, 'defaultDate')\"\n appendTo=\"body\">\n </p-datepicker>\n </td>\n }\n @if (!col.invisible && checkType('Date', col) && (rowData.readonly || rowData[col.id]?.readonly || !isModeEdition())) {\n <td\n [ngStyle]=\"{\r\n 'min-width' : col.width ? col.width : null,\r\n 'background-color': rowData[col.id].color ? rowData[col.id].color : null,\r\n 'color' : rowData[col.id].textColor ? rowData[col.id].textColor : null\r\n }\"\r\n (click)=\"options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection && onSelectCell(rowData[col.id])\"\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\n [pTooltip]=\"rowData[col.id].tooltip != null ? rowData[col.id].tooltip : rowData[col.id].value | date: 'dd/MM/yyyy'\"\n [tooltipDisabled]=\"!col.tooltip\"\n tooltipPosition=\"bottom\"\n [ngClass]=\"{\r\n 'paddingCell': rowData[col.id] != null,\r\n 'text-left': col.position == 'left' || col.position == null,\r\n 'text-right': col.position == 'right',\r\n 'text-center': col.position == 'center',\r\n 'font-bold': rowData.bold == true || rowData[col.id].bold == true,\r\n 'font-italic': rowData.italic == true || rowData[col.id].italic == true,\r\n 'selectable_cell' : options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection\r\n }\"\r\n pFrozenColumn\n [frozen]=\"col.frozen\">\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\n @if (rowData[col.id]) {\n <div>{{ rowData[col.id].value | date: (getOption(col, rowData, 'mode') == 'year' ? 'yyyy' : getOption(col, rowData, 'mode') == 'month' ? 'MM/yyyy' : 'dd/MM/yyyy') }}</div>\n }\n </td>\n }\n <!-- MultiSelect -->\n @if (!col.invisible && checkType('MultiSelect', col) && isModeEdition() && !rowData.readonly && !rowData[col.id]?.readonly) {\n <td\n [ngStyle]=\"{ 'width' : col.width ? col.width : null, 'background-color': rowData[col.id].color ? rowData[col.id].color : null }\"\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\n [ngClass]=\"{\r\n 'text-left': col.position == 'left' || col.position == null,\r\n 'text-right': col.position == 'right',\r\n 'text-center': col.position == 'center',\r\n 'selectable_cell' : options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection\r\n }\"\r\n (click)=\"options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection && onSelectCell(rowData[col.id])\"\n [pTooltip]=\"rowData[col.id].tooltip != null ? rowData[col.id].tooltip : getMultiSelectConcat(rowData[col.id].value, getOption(col, rowData, 'optionLabel'))\"\n [tooltipDisabled]=\"!col.tooltip\"\n tooltipPosition=\"bottom\"\n pFrozenColumn\n [frozen]=\"col.frozen\"\n class=\"paddingCell\">\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\n @if (rowData[col.id] != null) {\n <p-multiSelect\n [options]=\"getOption(col, rowData, 'options')\"\n [filter]=\"getOption(col, rowData, 'filter')\"\n [optionLabel]=\"getOption(col, rowData, 'optionLabel')\"\n [(ngModel)]=\"rowData[col.id].value\"\n appendTo=\"body\"\n dataKey=\"ID\"\n emptyFilterMessage=\"Aucun r\u00E9sultat\"\n emptyMessage=\"Aucun r\u00E9sultat\"\n [baseZIndex]=\"getOption(col, rowData, 'baseZIndex')\"\n [virtualScroll]=\"getOption(col, rowData, 'virtualScroll')\"\n [readonly]=\"rowData.readonly || rowData[col.id]?.readonly || !isModeEdition()\"\n [virtualScrollItemSize]=\"30\"\n selectedItemsLabel=\"{0} selectionn\u00E9s\"\n (onChange)=\"editMultiselect(rowData, col, $event)\"\n [showToggleAll]=\"false\"\n [showHeader]=\"getOption(col, rowData, 'filter')\"\n [group]=\"getOption(col, rowData, 'optionGroupChildren') != null ? true : false\"\n [optionGroupLabel]=\"getOption(col, rowData, 'optionGroupLabel')\"\n [optionGroupChildren]=\"getOption(col, rowData, 'optionGroupChildren')\"\n ngDefaultControl>\n <ng-template let-data pTemplate=\"selectedItems\">\n @for (option of data; track option; let i = $index) {\n <span\n [ngClass]=\"{\r\n 'font-bold': rowData.bold == true || rowData[col.id].bold == true,\r\n 'font-italic': rowData.italic == true || rowData[col.id].italic == true\r\n }\">\r\n {{ option[getOption(col, rowData, 'optionLabel')] + (i != data.length - 1 ? ',' : '') }}\n </span>\n }\n </ng-template>\n <ng-template let-group pTemplate=\"group\">\n <div>{{group[col.options.optionGroupLabel]}}</div>\n </ng-template>\n </p-multiSelect>\n }\n </td>\n }\n @if (!col.invisible && checkType('MultiSelect', col) && (rowData.readonly || rowData[col.id]?.readonly || !isModeEdition())) {\n <td\n [ngStyle]=\"{\r\n 'width' : col.width ? col.width : null,\r\n 'background-color': rowData[col.id].color ? rowData[col.id].color : null,\r\n 'color' : rowData[col.id].textColor ? rowData[col.id].textColor : null\r\n }\"\r\n (click)=\"options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection && onSelectCell(rowData[col.id])\"\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\n [pTooltip]=\"rowData[col.id].tooltip != null ? rowData[col.id].tooltip : getMultiSelectConcat(rowData[col.id].value, getOption(col, rowData, 'optionLabel'))\"\n [tooltipDisabled]=\"!col.tooltip\"\n tooltipPosition=\"bottom\"\n [ngClass]=\"{\r\n 'paddingCell': rowData[col.id] != null,\r\n 'text-left': col.position == 'left' || col.position == null,\r\n 'text-right': col.position == 'right',\r\n 'text-center': col.position == 'center',\r\n 'font-bold': rowData.bold == true || rowData[col.id].bold == true,\r\n 'font-italic': rowData.italic == true || rowData[col.id].italic == true,\r\n 'selectable_cell' : options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection\r\n }\"\r\n pFrozenColumn\n [frozen]=\"col.frozen\">\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\n @if (rowData[col.id]) {\n <div>{{ getMultiSelectConcat(rowData[col.id].value, getOption(col, rowData, 'optionLabel')) }}</div>\n }\n </td>\n }\n <!-- Image -->\n @if (!col.invisible && checkType('Image', col)) {\n <td\n [ngStyle]=\"{ 'width' : col.width ? col.width : null, 'background-color': rowData[col.id].color ? rowData[col.id].color : null }\"\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\n [ngClass]=\"{\r\n 'paddingCell': rowData[col.id] != null,\r\n 'selectable_cell' : options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection\r\n }\"\r\n (click)=\"options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection && onSelectCell(rowData[col.id])\"\n class=\"text-center\"\n pFrozenColumn\n [frozen]=\"col.frozen\">\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\n @if (rowData[col.id]) {\n <img style=\"vertical-align: middle; width: 40px;\" src=\"{{ rowData[col.id].value }}\" />\n }\n </td>\n }\n <!-- Button -->\n @if (!col.invisible && checkType('Button', col)) {\n <td\n class=\"paddingCell text-center\"\n [ngClass]=\"{\r\n 'selectable_cell' : options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection\r\n }\"\r\n (click)=\"options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection && onSelectCell(rowData[col.id])\"\n [ngStyle]=\"{ 'width' : col.width ? col.width : null, 'background-color': rowData[col.id].color ? rowData[col.id].color : null }\">\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\n @if (rowData[col.id].value != null && isValueButtonByType(rowData[col.id].value, 'function')) {\n <button pButton\n [disabled]=\"rowData.readonly || rowData[col.id]?.readonly\"\n [label]=\"getOption(col, rowData, 'label')\"\n [icon]=\"getOption(col, rowData, 'icon')\"\n (click)=\"rowData[col.id].value()\"\n [pTooltip]=\"rowData[col.id].tooltip != null ? rowData[col.id].tooltip : getOption(col, rowData, 'label')\"\n [tooltipDisabled]=\"!col.tooltip\"\n [class]=\"'p-button-' + getOption(col, rowData, 'severity')\"\n [ngClass]=\"{\r\n 'font-bold': rowData.bold == true || rowData[col.id].bold == true,\r\n 'font-italic': rowData.italic == true || rowData[col.id].italic == true\r\n }\">\r\n </button>\n }\n @if (isValueButtonByType(rowData[col.id].value, 'string')) {\n <div\n [ngClass]=\"{\r\n 'paddingCell': rowData[col.id] != null,\r\n 'text-left': col.position == 'left' || col.position == null,\r\n 'text-right': col.position == 'right',\r\n 'text-center': col.position == 'center',\r\n 'font-bold': rowData.bold == true || rowData[col.id].bold == true,\r\n 'font-italic': rowData.italic == true || rowData[col.id].italic == true\r\n }\"\r\n [pTooltip]=\"rowData[col.id].tooltip != null ? rowData[col.id].tooltip : rowData[col.id].value\"\n [tooltipDisabled]=\"!col.tooltip\">\n {{ rowData[col.id].value }}\n </div>\n }\n </td>\n }\n <!-- SelectButton -->\n @if (!col.invisible && checkType('SelectButton', col) && isModeEdition() && !rowData.readonly && !rowData[col.id]?.readonly) {\n <td\n [ngStyle]=\"{ 'width' : col.width ? col.width : null, 'background-color': rowData[col.id].color ? rowData[col.id].color : null }\"\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\n [ngClass]=\"{\r\n 'paddingCell': rowData[col.id] != null,\r\n 'selectable_cell' : options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection\r\n }\"\r\n (click)=\"options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection && onSelectCell(rowData[col.id])\"\n pFrozenColumn\n [frozen]=\"col.frozen\">\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\n @if (rowData[col.id] != null) {\n <p-selectButton\n [options]=\"getOption(col, rowData, 'options')\"\n [optionLabel]=\"getOption(col, rowData, 'optionLabel')\"\n [optionValue]=\"getOption(col, rowData, 'optionValue') != null ? getOption(col, rowData, 'optionValue') : 'value'\"\n [(ngModel)]=\"rowData[col.id].value\"\n [disabled]=\"rowData.readonly || rowData[col.id]?.readonly || !isModeEdition()\"\n (onChange)=\"onEditCell(rowData, col, rowData[col.id].value)\">\n <ng-template let-item pTemplate=\"item\">\n <span class=\"text-center w-full\"\n [ngClass]=\"{\r\n 'font-bold': rowData.bold == true || rowData[col.id].bold == true,\r\n 'font-italic': rowData.italic == true || rowData[col.id].italic == true\r\n }\">\r\n {{ item.label }}\n </span>\n </ng-template>\n </p-selectButton>\n }\n </td>\n }\n @if (!col.invisible && checkType('SelectButton', col) && (rowData.readonly || rowData[col.id]?.readonly || !isModeEdition())) {\n <td\n [ngStyle]=\"{\r\n 'width' : col.width ? col.width : null,\r\n 'background-color': rowData[col.id].color ? rowData[col.id].color : null,\r\n 'color' : rowData[col.id].textColor ? rowData[col.id].textColor : null\r\n }\"\r\n (click)=\"options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection && onSelectCell(rowData[col.id])\"\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\n pFrozenColumn\n [frozen]=\"col.frozen\"\n class=\"text-center\"\n [ngClass]=\"{\r\n 'paddingCell': rowData[col.id] != null,\r\n 'font-bold': rowData.bold == true || rowData[col.id].bold == true,\r\n 'font-italic': rowData.italic == true || rowData[col.id].italic == true,\r\n 'selectable_cell' : options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection\r\n }\">\r\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\n @if (rowData[col.id]) {\n <div>{{ getSelectLibelleByValue(rowData, col) }}</div>\n }\n </td>\n }\n <!-- Switch -->\n @if (!col.invisible && checkType('Switch', col)) {\n <td\n [ngStyle]=\"{ 'width' : col.width ? col.width : null, 'background-color': rowData[col.id].color ? rowData[col.id].color : null }\"\n class=\"text-center\"\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\n [ngClass]=\"{\r\n 'paddingCell': rowData[col.id] != null,\r\n 'selectable_cell' : options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection\r\n }\"\r\n (click)=\"options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection && onSelectCell(rowData[col.id])\"\n pFrozenColumn\n [frozen]=\"col.frozen\">\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\n @if (rowData[col.id] != null) {\n <p-toggleswitch\n [(ngModel)]=\"rowData[col.id].value\"\n [disabled]=\"rowData.readonly || rowData[col.id]?.readonly || (getOption(col, rowData, 'action') == null && !isModeEdition())\"\n (onChange)=\"onEditCell(rowData, col, rowData[col.id].value)\"\n ngDefaultControl>\n </p-toggleswitch>\n }\n </td>\n }\n <!-- File -->\n @if (!col.invisible && checkType('File', col) && isModeEdition() && !rowData.readonly && !rowData[col.id]?.readonly) {\n <td\n [ngStyle]=\"{ 'width' : col.width ? col.width : null, 'background-color': rowData[col.id].color ? rowData[col.id].color : null }\"\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\n [ngClass]=\"{\r\n 'paddingCell': rowData[col.id] != null,\r\n 'selectable_cell' : options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection\r\n }\"\r\n (click)=\"options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection && onSelectCell(rowData[col.id])\"\n pFrozenColumn\n [frozen]=\"col.frozen\">\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\n @if (rowData[col.id] != null) {\n <div class=\"p-inputgroup\">\n <button type=\"button\"\n pButton\n pRipple\n icon=\"pi pi-upload\"\n (click)=\"clickById('input_' + rowData[col.id].id)\"\n [disabled]=\"rowData.readonly || rowData[col.id]?.readonly || !isModeEdition()\">\n </button>\n <input id=\"{{'output_' + rowData[col.id].id}}\"\n pInputText\n type=\"text\"\n [ngClass]=\"{\r\n 'text-left': col.position == 'left' || col.position == null,\r\n 'text-right': col.position == 'right',\r\n 'text-center': col.position == 'center',\r\n 'font-bold': rowData.bold == true || rowData[col.id].bold == true,\r\n 'font-italic': rowData.italic == true || rowData[col.id].italic == true\r\n }\"\r\n value=\"{{ rowData[col.id].value != null ? rowData[col.id].value : '' }}\"\n readonly\n [pTooltip]=\"rowData[col.id].tooltip != null ? rowData[col.id].tooltip : rowData[col.id].value ? rowData[col.id].value : ''\"\n [tooltipDisabled]=\"!col.tooltip\">\n @if (getOption(col, rowData, 'downloadPath') && rowData[col.id].value != null) {\n <button\n type=\"button\"\n pButton\n pRipple\n icon=\"pi pi-download\"\n (click)=\"downloadFile(rowData[col.id])\"\n [disabled]=\"rowData.readonly || rowData[col.id]?.readonly || !isModeEdition()\">\n </button>\n }\n </div>\n }\n @if (rowData[col.id]) {\n <input id=\"{{'input_' + rowData[col.id].id}}\" #inputFile pInputText type=\"file\" hidden (change)=\"rowData[col.id].value = inputFile.files[0].name; onEditCell(rowData, col, inputFile.files[0])\">\n }\n </td>\n }\n @if (!col.invisible && checkType('File', col) && (rowData.readonly || rowData[col.id]?.readonly || !isModeEdition())) {\n <td\n [ngStyle]=\"{\r\n 'width' : col.width ? col.width : null,\r\n 'background-color': rowData[col.id].color ? rowData[col.id].color : null,\r\n 'color' : rowData[col.id].textColor ? rowData[col.id].textColor : null\r\n }\"\r\n (click)=\"options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection && onSelectCell(rowData[col.id])\"\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\n [pTooltip]=\"rowData[col.id].tooltip != null ? rowData[col.id].tooltip : rowData[col.id].value ? rowData[col.id].value : ''\"\n [ngClass]=\"{\r\n 'paddingCell': rowData[col.id] != null,\r\n 'text-left': col.position == 'left' || col.position == null,\r\n 'text-right': col.position == 'right',\r\n 'text-center': col.position == 'center',\r\n 'font-bold': rowData.bold == true || rowData[col.id].bold == true,\r\n 'font-italic': rowData.italic == true || rowData[col.id].italic == true,\r\n 'selectable_cell' : options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection\r\n }\"\r\n [tooltipDisabled]=\"!col.tooltip\"\n tooltipPosition=\"bottom\"\n pFrozenColumn\n [frozen]=\"col.frozen\">\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\n @if (rowData[col.id]) {\n <div>{{ rowData[col.id].value ? rowData[col.id].value : '' }}</div>\n }\n </td>\n }\n <!-- State -->\n @if (!col.invisible && checkType('State', col)) {\n <td\n [ngStyle]=\"{ 'width' : col.width ? col.width : null, 'background-color': rowData[col.id].color ? rowData[col.id].color : null }\"\n id=\"{{ rowData[col.id] != null ? rowData[col.id].id : '' }}\"\n [ngClass]=\"{\r\n 'paddingCell': rowData[col.id] != null,\r\n 'selectable_cell' : options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection\r\n }\"\r\n (click)=\"options.selectable && isModeCellSelection() && !rowData[col.id].disableSelection && onSelectCell(rowData[col.id])\"\n class=\"text-center\"\n pFrozenColumn\n [frozen]=\"col.frozen\">\n <div class=\"p-column-title\">{{ col.libelle }} : </div>\n @if (rowData[col.id].value != null) {\n <p-tag\n [value]=\"rowData[col.id].value[getOption(col, rowData, 'optionLabel')]\"\n [severity]=\"rowData[col.id].value.severity\"\n [icon]=\"rowData[col.id].value.icon\"\n [style]=\"{\r\n 'background-color': rowData[col.id].value.backgroundColor,\r\n 'color': rowData[col.id].value.textColor,\r\n 'font-weight': rowData.bold == true || rowData[col.id].bold == true ? 'bold' : null,\r\n 'font-style': rowData.italic == true || rowData[col.id].italic == true ? 'italic' : null\r\n }\">\r\n </p-tag>\n }\n </td>\n }\n }\n\n <!-- Deletion -->\n @if (options.rowsDeletable) {\n <td\n class=\"cellDelete\"\n [ngClass]=\"rowData.deletable ? 'paddingCell' : null\">\n @if (rowData.deletable) {\n <button\n pButton\n type=\"button\"\n icon=\"pi pi-times\"\n class=\"p-button-danger buttonDelete p-button-text\"\n [disabled]=\"rowData.readonly\"\n (click)=\"onDeleteLine(rowData)\">\n </button>\n }\n </td>\n }\n\n </tr>\n </ng-template>\n </p-table>\n </div>\n", styles: ["::ng-deep .p-tooltip .p-tooltip-text{overflow-wrap:break-word!important}:host ::ng-deep .grid_brown .rowHeader>th{background-color:#795548}:host ::ng-deep .grid_brown .rowHeader>th div{color:#fff}:host ::ng-deep .grid_brown .rowHeader>th i{color:#fff}:host ::ng-deep .grid_brown .rowHeader .p-sortable-column:hover{background-color:#a47767}:host ::ng-deep .grid_brown .rowHeader .p-sortable-column:hover i{color:#fff}:host ::ng-deep .grid_brown .rowHeader .p-sortable-column.p-highlight div{color:#76c7ff}:host ::ng-deep .grid_brown .rowHeader .p-sortable-column.p-highlight .p-sortable-column-icon{color:#76c7ff}:host ::ng-deep .grid_brown .rowFilter th{background-color:#795548}:host ::ng-deep .grid_grey .rowHeader>th{background-color:#dedddd}:host ::ng-deep .grid_grey .rowHeader>th div{color:#495057}:host ::ng-deep .grid_grey .rowHeader>th i{color:#495057}:host ::ng-deep .grid_grey .rowHeader .p-sortable-column:hover{background-color:#e7e7e7}:host ::ng-deep .grid_grey .rowHeader .p-sortable-column:hover i{color:#495057}:host ::ng-deep .grid_grey .rowHeader .p-sortable-column.p-highlight div{color:#008bff}:host ::ng-deep .grid_grey .rowHeader .p-sortable-column.p-highlight .p-sortable-column-icon{color:#008bff}:host ::ng-deep .grid_grey .rowFilter th{background-color:#dedddd}:host ::ng-deep .selectable_cell:hover{background:#dcdcdc!important;cursor:pointer!important}:host ::ng-deep .p-frozen-column{z-index:2!important}:host ::ng-deep .p-datatable-thead{z-index:3!important}:host ::ng-deep .p-checkbox{border-radius:inherit!important}:host ::ng-deep p-inputnumber{width:100%}:host ::ng-deep .p-calendar,:host ::ng-deep .p-inputtext,:host ::ng-deep .p-inputnumber,:host ::ng-deep .p-inputnumber-input,:host ::ng-deep .p-dropdown,:host ::ng-deep .p-multiselect{width:100%}:host ::ng-deep .suffixe,:host ::ng-deep .prefixe{height:25px;padding-top:1px!important}:host ::ng-deep .p-multiselect-label-container,:host ::ng-deep .p-dropdown-label{width:1px!important}:host ::ng-deep .p-scroller-content{min-height:50%}:host ::ng-deep .rowTotal>th{background-color:#edcbaa!important}:host ::ng-deep .rowGrouping{background:#faeada!important}:host ::ng-deep .p-inputswitch.p-inputswitch-checked .p-inputswitch-slider{background:#30e130}:host ::ng-deep .p-inputswitch.p-inputswitch-checked:not(.p-disabled):hover .p-inputswitch-slider{background:#2bd12b}:host ::ng-deep .p-datatable-table{table-layout:fixed}:host ::ng-deep .p-datatable-thead>tr>th{border:1px solid rgba(0,0,0,.12)!important;padding:8px;font-weight:600;height:40px}:host ::ng-deep .headerAffichageSimple div{overflow:hidden;white-space:nowrap;text-overflow:ellipsis}:host ::ng-deep .headerAffichageEntier{word-wrap:break-word}:host ::ng-deep .p-datatable-tbody>tr>td{border:1px solid rgba(0,0,0,.12)!important;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}:host ::ng-deep .p-datatable-tbody>tr>td div{overflow:hidden;white-space:nowrap;text-overflow:ellipsis}:host ::ng-deep .p-tag{max-width:100%}:host ::ng-deep .p-tag .p-tag-value{overflow:hidden;white-space:nowrap;text-overflow:ellipsis}:host ::ng-deep .p-button{padding:5px;max-width:100%}:host ::ng-deep .p-button .p-button-label{overflow:hidden!important;white-space:nowrap!important;text-overflow:ellipsis!important}:host ::ng-deep .text_bold{font-weight:700!important}:host ::ng-deep .cellDelete{flex:0 0 50px!important;width:50px;text-align:center!important;padding:0!important}:host ::ng-deep .p-tooltip .p-tooltip-text{background-color:red!important}:host ::ng-deep .p-skeleton{background-color:#dee2e6;border-radius:6px;padding:0}:host ::ng-deep .p-datatable-tbody>tr{height:35px}:host ::ng-deep .p-inputtext{height:25px!important;padding:4px 5px!important}:host ::ng-deep .p-inputnumber{height:25px;padding:0!important}:host ::ng-deep .p-inputnumber-input{padding:0 5px!important}:host ::ng-deep .p-inputgroup .p-inputtext{height:25px;padding:4px 5px!important}:host ::ng-deep .p-dropdown,:host ::ng-deep .p-multiselect{vertical-align:middle}:host ::ng-deep .p-dropdown-label{padding-top:2px;padding-bottom:2px}:host ::ng-deep .p-multiselect-label{padding-top:2px;padding-bottom:2px}:host ::ng-deep .p-editable-column{padding:3px 10px!important}:host ::ng-deep .paddingCell{padding:3px 10px!important}:host ::ng-deep .p-selectbutton>.p-button{width:50%;height:25px}:host ::ng-deep .p-inputgroup>.p-button{height:25px}:host ::ng-deep .buttonDelete{width:100%;height:20px}:host ::ng-deep .p-column-title{display:none}:host ::ng-deep .p-datatable-loading-icon{color:#fff}\n"] }]
|
|
1344
1349
|
}], ctorParameters: () => [{ type: i1.ConfirmationService }, { type: i1.FilterService }, { type: i0.ChangeDetectorRef }, { type: ExportService }], propDecorators: { columns: [{
|
|
1345
1350
|
type: Input
|
|
1346
1351
|
}], columnsChange: [{
|
|
@@ -1386,10 +1391,10 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
1386
1391
|
|
|
1387
1392
|
class CilogTableService {
|
|
1388
1393
|
constructor() { }
|
|
1389
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "
|
|
1390
|
-
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "
|
|
1394
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "21.0.6", ngImport: i0, type: CilogTableService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
1395
|
+
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "21.0.6", ngImport: i0, type: CilogTableService, providedIn: 'root' }); }
|
|
1391
1396
|
}
|
|
1392
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
1397
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "21.0.6", ngImport: i0, type: CilogTableService, decorators: [{
|
|
1393
1398
|
type: Injectable,
|
|
1394
1399
|
args: [{
|
|
1395
1400
|
providedIn: 'root'
|
|
@@ -1410,12 +1415,12 @@ class CilogEditorComponent {
|
|
|
1410
1415
|
onSelectionChange(event) {
|
|
1411
1416
|
// NOTHING
|
|
1412
1417
|
}
|
|
1413
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "
|
|
1414
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "
|
|
1418
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "21.0.6", ngImport: i0, type: CilogEditorComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
1419
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "21.0.6", type: CilogEditorComponent, isStandalone: false, selector: "cilog-editor", inputs: { text: "text" }, outputs: { textChange: "textChange", onTextChange: "onTextChange" }, viewQueries: [{ propertyName: "editor", first: true, predicate: ["editor"], descendants: true }], ngImport: i0, template: "<p-editor #editor\r\n [(ngModel)]=\"text\"\r\n (onTextChange)=\"change($event)\">\r\n</p-editor>\r\n", styles: [""], dependencies: [{ kind: "component", type: i1$1.Editor, selector: "p-editor", inputs: ["style", "styleClass", "placeholder", "formats", "modules", "bounds", "scrollingContainer", "debug", "readonly"], outputs: ["onInit", "onTextChange", "onSelectionChange", "onEditorChange", "onFocus", "onBlur"] }, { kind: "directive", type: i16.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i16.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }] }); }
|
|
1415
1420
|
}
|
|
1416
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
1421
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "21.0.6", ngImport: i0, type: CilogEditorComponent, decorators: [{
|
|
1417
1422
|
type: Component,
|
|
1418
|
-
args: [{ selector: 'cilog-editor', template: "<p-editor #editor\r\n [(ngModel)]=\"text\"\r\n (onTextChange)=\"change($event)\">\r\n</p-editor>\r\n" }]
|
|
1423
|
+
args: [{ selector: 'cilog-editor', standalone: false, template: "<p-editor #editor\r\n [(ngModel)]=\"text\"\r\n (onTextChange)=\"change($event)\">\r\n</p-editor>\r\n" }]
|
|
1419
1424
|
}], ctorParameters: () => [], propDecorators: { text: [{
|
|
1420
1425
|
type: Input
|
|
1421
1426
|
}], textChange: [{
|
|
@@ -1564,18 +1569,18 @@ class DocumentationContextuelleComponent {
|
|
|
1564
1569
|
.reduce((acc, cat) => acc.concat(cat.docs), [])
|
|
1565
1570
|
.find(doc => normalizedUrl.toLowerCase().includes(doc.fileName.toLowerCase().replace('.md', '')));
|
|
1566
1571
|
}
|
|
1567
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "
|
|
1568
|
-
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"] }] }); }
|
|
1572
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "21.0.6", ngImport: i0, type: DocumentationContextuelleComponent, deps: [{ token: i1$2.HttpClient }, { token: i2$2.Router }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
1573
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "21.0.6", type: DocumentationContextuelleComponent, isStandalone: false, selector: "cilog-documentation-contextuelle", ngImport: i0, template: "<div class=\"documentation-container\">\n <!-- Menu sup\u00E9rieur -->\n <div class=\"documentation-menu\">\n <button pButton\n type=\"button\"\n icon=\"pi pi-list\"\n label=\"Sommaire des documentations\"\n class=\"p-button-sm p-button-outlined\"\n (click)=\"openDocumentationList()\"\n title=\"Voir toutes les documentations disponibles\">\n </button>\n <button pButton\n type=\"button\"\n icon=\"pi pi-home\"\n label=\"Documentation courante\"\n class=\"p-button-sm p-button-outlined\"\n (click)=\"openCurrentPageDoc()\"\n title=\"Documentation de la page actuelle\">\n </button>\n </div>\n\n <!-- Syst\u00E8me d'onglets -->\n <p-tabs [(tabindex)]=\"activeTabIndex\"\n (onClose)=\"closeTab($event)\"\n styleClass=\"documentation-tabs\">\n <p-tablist>\n @for (tab of tabs; track tab.value) {\n <p-tab [value]=\"tab.value\" [closable]=\"tabs.length > 1\">{{ tab.title }}</p-tab>\n }\n </p-tablist>\n <p-tabpanels>\n @for (tab of tabs; track tab; let i = $index) {\n <p-tabpanel [value]=\"tab.value\">\n <!-- Contenu pour onglet de liste - Version am\u00E9lior\u00E9e -->\n @if (tab.type === 'list') {\n <div class=\"docs-list-container\">\n <div class=\"docs-header\">\n <h2>\uD83D\uDCDA Sommaire de la Documentation</h2>\n <p class=\"docs-subtitle\">Explorez toutes les fonctionnalit\u00E9s disponibles dans LogeProj</p>\n </div>\n <!-- Barre de recherche -->\n <div class=\"search-bar\">\n <span class=\"p-input-icon-left\" style=\"width: 100%; max-width: 800px;\">\n <i class=\"pi pi-search\"></i>\n <input type=\"text\"\n pInputText\n placeholder=\"Rechercher dans les documentations...\"\n [(ngModel)]=\"searchQuery\"\n (input)=\"filterDocumentation()\"\n style=\"width: 100% !important; padding: 12px 20px 12px 40px !important; border-radius: 25px !important;\">\n </span>\n </div>\n <!-- Liste des cat\u00E9gories -->\n <div class=\"categories-container\">\n @for (category of filteredCategories; track category) {\n <div class=\"category-section\">\n <div class=\"category-header\" (click)=\"toggleCategory(category.key)\">\n <i class=\"pi\" [ngClass]=\"category.expanded ? 'pi-chevron-down' : 'pi-chevron-right'\"></i>\n <span class=\"category-icon\">{{ category.icon }}</span>\n <h3 class=\"category-title\">{{ category.name }}</h3>\n <span class=\"category-count\">({{ category.docs.length }})</span>\n </div>\n <div class=\"category-content\" [ngClass]=\"{ 'expanded': category.expanded }\">\n <div class=\"docs-grid\">\n @for (doc of category.docs; track doc) {\n <div class=\"doc-card\"\n (click)=\"openDocumentationAndSwitch(doc)\"\n [title]=\"doc.description\">\n <div class=\"doc-card-content\">\n <h4 class=\"doc-name\">{{ doc.displayName }}</h4>\n <p class=\"doc-description\">{{ doc.description }}</p>\n </div>\n </div>\n }\n </div>\n </div>\n </div>\n }\n </div>\n <!-- Stats en bas -->\n <div class=\"docs-stats\">\n <div class=\"stat-item\">\n <strong>{{ getTotalDocsCount() }}</strong> documentations disponibles\n </div>\n <div class=\"stat-item\">\n <strong>{{ getOpenTabsCount() }}</strong> onglets ouverts\n </div>\n </div>\n </div>\n }\n <!-- Contenu pour onglet de documentation -->\n @if (tab.type === 'doc') {\n <div class=\"markdown-container\">\n <!-- Breadcrumb pour navigation -->\n @if (tab.category) {\n <div class=\"doc-breadcrumb\">\n <span class=\"breadcrumb-item\">{{ tab.category }}</span>\n <i class=\"pi pi-angle-right\"></i>\n <span class=\"breadcrumb-current\">{{ tab.title }}</span>\n </div>\n }\n @if (tab.loading) {\n <div class=\"loading-container\">\n <p-progressSpinner strokeWidth=\"4\"></p-progressSpinner>\n <span>Chargement de la documentation...</span>\n </div>\n }\n @if (!tab.loading) {\n <markdown [data]=\"tab.content || 'Aucun contenu disponible'\">\n </markdown>\n }\n </div>\n }\n </p-tabpanel>\n }\n </p-tabpanels>\n </p-tabs>\n</div>\n", styles: [".documentation-container{display:flex;flex-direction:column;height:100%;width:100%}.documentation-menu{padding:15px;background:linear-gradient(135deg,#667eea,#764ba2);border-bottom:1px solid #e9ecef;display:flex;gap:10px;flex-shrink:0}.documentation-menu .p-button{background:#fff3;border:1px solid rgba(255,255,255,.3);color:#fff}.documentation-menu .p-button:hover{background:#ffffff4d}.docs-list-container{padding:20px;flex:1;overflow-y:auto;background:#f8f9fa}.docs-header{text-align:center;margin-bottom:30px}.docs-header h2{margin:0 0 10px;color:#2c3e50;font-size:2rem}.docs-header .docs-subtitle{color:#7f8c8d;font-size:1.1rem;margin:0}.search-bar{margin-bottom:30px;display:flex;justify-content:center}.search-bar .search-input{width:100%;padding:12px 20px 12px 40px;border-radius:25px;border:2px solid #e9ecef;font-size:1rem}.search-bar .search-input:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.categories-container{max-width:1200px;margin:0 auto}.category-section{margin-bottom:25px;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;overflow:hidden}.category-section .category-header{padding:20px;background:linear-gradient(135deg,#f5f7fa,#c3cfe2);cursor:pointer;display:flex;align-items:center;gap:15px;transition:all .3s ease}.category-section .category-header:hover{background:linear-gradient(135deg,#e8eaf6,#b39ddb)}.category-section .category-header .pi{color:#667eea;font-size:1rem;transition:transform .3s ease}.category-section .category-header .category-icon{font-size:1.5rem}.category-section .category-header .category-title{margin:0;color:#2c3e50;font-size:1.3rem;flex:1}.category-section .category-header .category-count{color:#7f8c8d;font-size:.9rem;background:#677eea1a;padding:4px 12px;border-radius:15px}.category-section .category-content{max-height:0;overflow:hidden;transition:max-height .4s ease-out}.category-section .category-content.expanded{max-height:2000px;transition:max-height .6s ease-in}.docs-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:20px;padding:25px}.doc-card{border:1px solid #e9ecef;border-radius:12px;padding:20px;cursor:pointer;transition:all .3s ease;background:#fff;position:relative;overflow:hidden}.doc-card:before{content:\"\";position:absolute;top:0;left:0;width:100%;height:4px;background:linear-gradient(90deg,#667eea,#764ba2);transform:scaleX(0);transition:transform .3s ease}.doc-card:hover{border-color:#667eea;box-shadow:0 8px 25px #667eea26;transform:translateY(-4px)}.doc-card:hover:before{transform:scaleX(1)}.doc-card .doc-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px}.doc-card .doc-card-header .doc-icon{font-size:2rem}.doc-card .doc-card-header .doc-badge{padding:4px 8px;border-radius:12px;font-size:.75rem;font-weight:600;text-transform:uppercase}.doc-card .doc-card-header .doc-badge.doc-badge-high{background:#e8f5e8;color:#2e7d2e}.doc-card .doc-card-header .doc-badge.doc-badge-medium{background:#fff3cd;color:#856404}.doc-card .doc-card-header .doc-badge.doc-badge-low{background:#f8f9fa;color:#6c757d}.doc-card .doc-card-content .doc-name{margin:0 0 10px;color:#2c3e50;font-size:1.1rem;font-weight:600;line-height:1.3}.doc-card .doc-card-content .doc-description{color:#6c757d;font-size:.9rem;line-height:1.4;margin:0 0 10px}.doc-card .doc-card-content .doc-filename{color:#adb5bd;font-size:.8rem;font-family:Courier New,monospace}.docs-stats{display:flex;justify-content:center;gap:40px;margin-top:40px;padding:20px;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a}.docs-stats .stat-item{text-align:center;color:#6c757d}.docs-stats .stat-item strong{color:#667eea;font-size:1.2rem}.markdown-container{flex:1;overflow-y:auto;padding:20px;background:#fff}.markdown-container .doc-breadcrumb{display:flex;align-items:center;gap:8px;margin-bottom:20px;padding:10px 0;border-bottom:1px solid #e9ecef;color:#6c757d;font-size:.9rem}.markdown-container .doc-breadcrumb .breadcrumb-current{color:#2c3e50;font-weight:600}.markdown-container markdown{display:block;line-height:1.6}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px;color:#6c757d;gap:20px}.loading-container span{font-size:1.1rem}.documentation-tabs{flex:1;display:flex;flex-direction:column}.documentation-tabs ::ng-deep .p-tabview-panels{flex:1;display:flex}.documentation-tabs ::ng-deep .p-tabview-panels .p-tabview-panel{flex:1;display:flex;flex-direction:column}.documentation-tabs ::ng-deep .p-tabview-nav{background:#f8f9fa;border-bottom:2px solid #e9ecef}.documentation-tabs ::ng-deep .p-tabview-nav .p-tabview-nav-link{background:transparent;border:none;color:#6c757d;font-weight:500}.documentation-tabs ::ng-deep .p-tabview-nav .p-tabview-nav-link:not(.p-disabled):focus{box-shadow:0 0 0 2px #667eea33}.documentation-tabs ::ng-deep .p-tabview-nav .p-highlight .p-tabview-nav-link{background:#fff;color:#667eea;border-bottom:2px solid #667eea}\n"], dependencies: [{ kind: "directive", type: i3.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i4.ButtonDirective, selector: "[pButton]", inputs: ["ptButtonDirective", "pButtonPT", "pButtonUnstyled", "hostName", "text", "plain", "raised", "size", "outlined", "rounded", "iconPos", "loadingIcon", "fluid", "label", "icon", "loading", "buttonProps", "severity"] }, { kind: "directive", type: i2$1.InputText, selector: "[pInputText]", inputs: ["hostName", "ptInputText", "pInputTextPT", "pInputTextUnstyled", "pSize", "variant", "fluid", "invalid"] }, { kind: "component", type: i6.Tabs, selector: "p-tabs", inputs: ["value", "scrollable", "lazy", "selectOnFocus", "showNavigators", "tabindex"], outputs: ["valueChange"] }, { kind: "component", type: i6.TabPanels, selector: "p-tabpanels" }, { kind: "component", type: i6.TabPanel, selector: "p-tabpanel", inputs: ["lazy", "value"], outputs: ["valueChange"] }, { kind: "component", type: i6.TabList, selector: "p-tablist" }, { kind: "component", type: i6.Tab, selector: "p-tab", inputs: ["value", "disabled"], outputs: ["valueChange"] }, { kind: "directive", type: i16.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i16.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i16.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i8$1.MarkdownComponent, selector: "markdown, [markdown]", inputs: ["data", "src", "disableSanitizer", "inline", "clipboard", "clipboardButtonComponent", "clipboardButtonTemplate", "emoji", "katex", "katexOptions", "mermaid", "mermaidOptions", "lineHighlight", "line", "lineOffset", "lineNumbers", "start", "commandLine", "filterOutput", "host", "prompt", "output", "user"], outputs: ["error", "load", "ready"] }, { kind: "component", type: i9$1.ProgressSpinner, selector: "p-progressSpinner, p-progress-spinner, p-progressspinner", inputs: ["styleClass", "strokeWidth", "fill", "animationDuration", "ariaLabel"] }] }); }
|
|
1569
1574
|
}
|
|
1570
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
1575
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "21.0.6", ngImport: i0, type: DocumentationContextuelleComponent, decorators: [{
|
|
1571
1576
|
type: Component,
|
|
1572
|
-
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"] }]
|
|
1573
|
-
}], ctorParameters: () => [{ type: i1$2.HttpClient }, { type: i2$
|
|
1577
|
+
args: [{ selector: 'cilog-documentation-contextuelle', standalone: false, template: "<div class=\"documentation-container\">\n <!-- Menu sup\u00E9rieur -->\n <div class=\"documentation-menu\">\n <button pButton\n type=\"button\"\n icon=\"pi pi-list\"\n label=\"Sommaire des documentations\"\n class=\"p-button-sm p-button-outlined\"\n (click)=\"openDocumentationList()\"\n title=\"Voir toutes les documentations disponibles\">\n </button>\n <button pButton\n type=\"button\"\n icon=\"pi pi-home\"\n label=\"Documentation courante\"\n class=\"p-button-sm p-button-outlined\"\n (click)=\"openCurrentPageDoc()\"\n title=\"Documentation de la page actuelle\">\n </button>\n </div>\n\n <!-- Syst\u00E8me d'onglets -->\n <p-tabs [(tabindex)]=\"activeTabIndex\"\n (onClose)=\"closeTab($event)\"\n styleClass=\"documentation-tabs\">\n <p-tablist>\n @for (tab of tabs; track tab.value) {\n <p-tab [value]=\"tab.value\" [closable]=\"tabs.length > 1\">{{ tab.title }}</p-tab>\n }\n </p-tablist>\n <p-tabpanels>\n @for (tab of tabs; track tab; let i = $index) {\n <p-tabpanel [value]=\"tab.value\">\n <!-- Contenu pour onglet de liste - Version am\u00E9lior\u00E9e -->\n @if (tab.type === 'list') {\n <div class=\"docs-list-container\">\n <div class=\"docs-header\">\n <h2>\uD83D\uDCDA Sommaire de la Documentation</h2>\n <p class=\"docs-subtitle\">Explorez toutes les fonctionnalit\u00E9s disponibles dans LogeProj</p>\n </div>\n <!-- Barre de recherche -->\n <div class=\"search-bar\">\n <span class=\"p-input-icon-left\" style=\"width: 100%; max-width: 800px;\">\n <i class=\"pi pi-search\"></i>\n <input type=\"text\"\n pInputText\n placeholder=\"Rechercher dans les documentations...\"\n [(ngModel)]=\"searchQuery\"\n (input)=\"filterDocumentation()\"\n style=\"width: 100% !important; padding: 12px 20px 12px 40px !important; border-radius: 25px !important;\">\n </span>\n </div>\n <!-- Liste des cat\u00E9gories -->\n <div class=\"categories-container\">\n @for (category of filteredCategories; track category) {\n <div class=\"category-section\">\n <div class=\"category-header\" (click)=\"toggleCategory(category.key)\">\n <i class=\"pi\" [ngClass]=\"category.expanded ? 'pi-chevron-down' : 'pi-chevron-right'\"></i>\n <span class=\"category-icon\">{{ category.icon }}</span>\n <h3 class=\"category-title\">{{ category.name }}</h3>\n <span class=\"category-count\">({{ category.docs.length }})</span>\n </div>\n <div class=\"category-content\" [ngClass]=\"{ 'expanded': category.expanded }\">\n <div class=\"docs-grid\">\n @for (doc of category.docs; track doc) {\n <div class=\"doc-card\"\n (click)=\"openDocumentationAndSwitch(doc)\"\n [title]=\"doc.description\">\n <div class=\"doc-card-content\">\n <h4 class=\"doc-name\">{{ doc.displayName }}</h4>\n <p class=\"doc-description\">{{ doc.description }}</p>\n </div>\n </div>\n }\n </div>\n </div>\n </div>\n }\n </div>\n <!-- Stats en bas -->\n <div class=\"docs-stats\">\n <div class=\"stat-item\">\n <strong>{{ getTotalDocsCount() }}</strong> documentations disponibles\n </div>\n <div class=\"stat-item\">\n <strong>{{ getOpenTabsCount() }}</strong> onglets ouverts\n </div>\n </div>\n </div>\n }\n <!-- Contenu pour onglet de documentation -->\n @if (tab.type === 'doc') {\n <div class=\"markdown-container\">\n <!-- Breadcrumb pour navigation -->\n @if (tab.category) {\n <div class=\"doc-breadcrumb\">\n <span class=\"breadcrumb-item\">{{ tab.category }}</span>\n <i class=\"pi pi-angle-right\"></i>\n <span class=\"breadcrumb-current\">{{ tab.title }}</span>\n </div>\n }\n @if (tab.loading) {\n <div class=\"loading-container\">\n <p-progressSpinner strokeWidth=\"4\"></p-progressSpinner>\n <span>Chargement de la documentation...</span>\n </div>\n }\n @if (!tab.loading) {\n <markdown [data]=\"tab.content || 'Aucun contenu disponible'\">\n </markdown>\n }\n </div>\n }\n </p-tabpanel>\n }\n </p-tabpanels>\n </p-tabs>\n</div>\n", styles: [".documentation-container{display:flex;flex-direction:column;height:100%;width:100%}.documentation-menu{padding:15px;background:linear-gradient(135deg,#667eea,#764ba2);border-bottom:1px solid #e9ecef;display:flex;gap:10px;flex-shrink:0}.documentation-menu .p-button{background:#fff3;border:1px solid rgba(255,255,255,.3);color:#fff}.documentation-menu .p-button:hover{background:#ffffff4d}.docs-list-container{padding:20px;flex:1;overflow-y:auto;background:#f8f9fa}.docs-header{text-align:center;margin-bottom:30px}.docs-header h2{margin:0 0 10px;color:#2c3e50;font-size:2rem}.docs-header .docs-subtitle{color:#7f8c8d;font-size:1.1rem;margin:0}.search-bar{margin-bottom:30px;display:flex;justify-content:center}.search-bar .search-input{width:100%;padding:12px 20px 12px 40px;border-radius:25px;border:2px solid #e9ecef;font-size:1rem}.search-bar .search-input:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.categories-container{max-width:1200px;margin:0 auto}.category-section{margin-bottom:25px;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;overflow:hidden}.category-section .category-header{padding:20px;background:linear-gradient(135deg,#f5f7fa,#c3cfe2);cursor:pointer;display:flex;align-items:center;gap:15px;transition:all .3s ease}.category-section .category-header:hover{background:linear-gradient(135deg,#e8eaf6,#b39ddb)}.category-section .category-header .pi{color:#667eea;font-size:1rem;transition:transform .3s ease}.category-section .category-header .category-icon{font-size:1.5rem}.category-section .category-header .category-title{margin:0;color:#2c3e50;font-size:1.3rem;flex:1}.category-section .category-header .category-count{color:#7f8c8d;font-size:.9rem;background:#677eea1a;padding:4px 12px;border-radius:15px}.category-section .category-content{max-height:0;overflow:hidden;transition:max-height .4s ease-out}.category-section .category-content.expanded{max-height:2000px;transition:max-height .6s ease-in}.docs-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:20px;padding:25px}.doc-card{border:1px solid #e9ecef;border-radius:12px;padding:20px;cursor:pointer;transition:all .3s ease;background:#fff;position:relative;overflow:hidden}.doc-card:before{content:\"\";position:absolute;top:0;left:0;width:100%;height:4px;background:linear-gradient(90deg,#667eea,#764ba2);transform:scaleX(0);transition:transform .3s ease}.doc-card:hover{border-color:#667eea;box-shadow:0 8px 25px #667eea26;transform:translateY(-4px)}.doc-card:hover:before{transform:scaleX(1)}.doc-card .doc-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px}.doc-card .doc-card-header .doc-icon{font-size:2rem}.doc-card .doc-card-header .doc-badge{padding:4px 8px;border-radius:12px;font-size:.75rem;font-weight:600;text-transform:uppercase}.doc-card .doc-card-header .doc-badge.doc-badge-high{background:#e8f5e8;color:#2e7d2e}.doc-card .doc-card-header .doc-badge.doc-badge-medium{background:#fff3cd;color:#856404}.doc-card .doc-card-header .doc-badge.doc-badge-low{background:#f8f9fa;color:#6c757d}.doc-card .doc-card-content .doc-name{margin:0 0 10px;color:#2c3e50;font-size:1.1rem;font-weight:600;line-height:1.3}.doc-card .doc-card-content .doc-description{color:#6c757d;font-size:.9rem;line-height:1.4;margin:0 0 10px}.doc-card .doc-card-content .doc-filename{color:#adb5bd;font-size:.8rem;font-family:Courier New,monospace}.docs-stats{display:flex;justify-content:center;gap:40px;margin-top:40px;padding:20px;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a}.docs-stats .stat-item{text-align:center;color:#6c757d}.docs-stats .stat-item strong{color:#667eea;font-size:1.2rem}.markdown-container{flex:1;overflow-y:auto;padding:20px;background:#fff}.markdown-container .doc-breadcrumb{display:flex;align-items:center;gap:8px;margin-bottom:20px;padding:10px 0;border-bottom:1px solid #e9ecef;color:#6c757d;font-size:.9rem}.markdown-container .doc-breadcrumb .breadcrumb-current{color:#2c3e50;font-weight:600}.markdown-container markdown{display:block;line-height:1.6}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px;color:#6c757d;gap:20px}.loading-container span{font-size:1.1rem}.documentation-tabs{flex:1;display:flex;flex-direction:column}.documentation-tabs ::ng-deep .p-tabview-panels{flex:1;display:flex}.documentation-tabs ::ng-deep .p-tabview-panels .p-tabview-panel{flex:1;display:flex;flex-direction:column}.documentation-tabs ::ng-deep .p-tabview-nav{background:#f8f9fa;border-bottom:2px solid #e9ecef}.documentation-tabs ::ng-deep .p-tabview-nav .p-tabview-nav-link{background:transparent;border:none;color:#6c757d;font-weight:500}.documentation-tabs ::ng-deep .p-tabview-nav .p-tabview-nav-link:not(.p-disabled):focus{box-shadow:0 0 0 2px #667eea33}.documentation-tabs ::ng-deep .p-tabview-nav .p-highlight .p-tabview-nav-link{background:#fff;color:#667eea;border-bottom:2px solid #667eea}\n"] }]
|
|
1578
|
+
}], ctorParameters: () => [{ type: i1$2.HttpClient }, { type: i2$2.Router }] });
|
|
1574
1579
|
|
|
1575
1580
|
registerLocaleData(localeFr);
|
|
1576
1581
|
class CilogLibModule {
|
|
1577
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "
|
|
1578
|
-
static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "
|
|
1582
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "21.0.6", ngImport: i0, type: CilogLibModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
|
|
1583
|
+
static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "21.0.6", ngImport: i0, type: CilogLibModule, declarations: [CilogLibComponent,
|
|
1579
1584
|
CilogMessageComponent,
|
|
1580
1585
|
CilogTableComponent,
|
|
1581
1586
|
CilogEditorComponent,
|
|
@@ -1584,44 +1589,29 @@ class CilogLibModule {
|
|
|
1584
1589
|
ValuePipe], imports: [CommonModule,
|
|
1585
1590
|
PrimengModule,
|
|
1586
1591
|
BrowserModule,
|
|
1587
|
-
BrowserAnimationsModule,
|
|
1588
1592
|
FormsModule,
|
|
1589
|
-
ReactiveFormsModule,
|
|
1590
|
-
HttpClientModule, i8$1.MarkdownModule, ProgressSpinnerModule], exports: [CilogMessageComponent,
|
|
1593
|
+
ReactiveFormsModule, i8$1.MarkdownModule, ProgressSpinnerModule], exports: [CilogMessageComponent,
|
|
1591
1594
|
CilogTableComponent,
|
|
1592
1595
|
CilogEditorComponent,
|
|
1593
1596
|
CilogInputNumberComponent,
|
|
1594
1597
|
DocumentationContextuelleComponent] }); }
|
|
1595
|
-
static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "
|
|
1598
|
+
static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "21.0.6", ngImport: i0, type: CilogLibModule, providers: [
|
|
1596
1599
|
CilogMessageService,
|
|
1597
1600
|
CilogTableService,
|
|
1598
1601
|
ConfirmationService,
|
|
1599
1602
|
{ provide: LOCALE_ID, useValue: 'fr-FR' },
|
|
1603
|
+
provideHttpClient(withInterceptorsFromDi()),
|
|
1600
1604
|
], imports: [CommonModule,
|
|
1601
1605
|
PrimengModule,
|
|
1602
1606
|
BrowserModule,
|
|
1603
|
-
BrowserAnimationsModule,
|
|
1604
1607
|
FormsModule,
|
|
1605
1608
|
ReactiveFormsModule,
|
|
1606
|
-
HttpClientModule,
|
|
1607
1609
|
MarkdownModule.forRoot({ loader: HttpClient }),
|
|
1608
1610
|
ProgressSpinnerModule] }); }
|
|
1609
1611
|
}
|
|
1610
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
1612
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "21.0.6", ngImport: i0, type: CilogLibModule, decorators: [{
|
|
1611
1613
|
type: NgModule,
|
|
1612
|
-
args: [{
|
|
1613
|
-
imports: [
|
|
1614
|
-
CommonModule,
|
|
1615
|
-
PrimengModule,
|
|
1616
|
-
BrowserModule,
|
|
1617
|
-
BrowserAnimationsModule,
|
|
1618
|
-
FormsModule,
|
|
1619
|
-
ReactiveFormsModule,
|
|
1620
|
-
HttpClientModule,
|
|
1621
|
-
MarkdownModule.forRoot({ loader: HttpClient }),
|
|
1622
|
-
ProgressSpinnerModule
|
|
1623
|
-
],
|
|
1624
|
-
declarations: [
|
|
1614
|
+
args: [{ declarations: [
|
|
1625
1615
|
CilogLibComponent,
|
|
1626
1616
|
CilogMessageComponent,
|
|
1627
1617
|
CilogTableComponent,
|
|
@@ -1636,22 +1626,27 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
1636
1626
|
CilogEditorComponent,
|
|
1637
1627
|
CilogInputNumberComponent,
|
|
1638
1628
|
DocumentationContextuelleComponent,
|
|
1639
|
-
],
|
|
1640
|
-
|
|
1629
|
+
], imports: [CommonModule,
|
|
1630
|
+
PrimengModule,
|
|
1631
|
+
BrowserModule,
|
|
1632
|
+
FormsModule,
|
|
1633
|
+
ReactiveFormsModule,
|
|
1634
|
+
MarkdownModule.forRoot({ loader: HttpClient }),
|
|
1635
|
+
ProgressSpinnerModule], providers: [
|
|
1641
1636
|
CilogMessageService,
|
|
1642
1637
|
CilogTableService,
|
|
1643
1638
|
ConfirmationService,
|
|
1644
1639
|
{ provide: LOCALE_ID, useValue: 'fr-FR' },
|
|
1645
|
-
|
|
1646
|
-
|
|
1640
|
+
provideHttpClient(withInterceptorsFromDi()),
|
|
1641
|
+
] }]
|
|
1647
1642
|
}] });
|
|
1648
1643
|
|
|
1649
1644
|
class CilogLibService {
|
|
1650
1645
|
constructor() { }
|
|
1651
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "
|
|
1652
|
-
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "
|
|
1646
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "21.0.6", ngImport: i0, type: CilogLibService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
1647
|
+
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "21.0.6", ngImport: i0, type: CilogLibService, providedIn: 'root' }); }
|
|
1653
1648
|
}
|
|
1654
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
1649
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "21.0.6", ngImport: i0, type: CilogLibService, decorators: [{
|
|
1655
1650
|
type: Injectable,
|
|
1656
1651
|
args: [{
|
|
1657
1652
|
providedIn: 'root'
|