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.
Files changed (44) hide show
  1. package/fesm2022/cilog-lib.mjs +97 -102
  2. package/fesm2022/cilog-lib.mjs.map +1 -1
  3. package/package.json +3 -5
  4. package/types/cilog-lib.d.ts +538 -0
  5. package/esm2022/cilog-lib.mjs +0 -5
  6. package/esm2022/lib/cilog-lib.component.mjs +0 -22
  7. package/esm2022/lib/cilog-lib.module.mjs +0 -96
  8. package/esm2022/lib/cilog-lib.service.mjs +0 -14
  9. package/esm2022/lib/helpers/enums/grille.enum.mjs +0 -51
  10. package/esm2022/lib/helpers/interfaces/edition.interface.mjs +0 -2
  11. package/esm2022/lib/helpers/interfaces/editor.interface.mjs +0 -2
  12. package/esm2022/lib/helpers/interfaces/grille.interface.mjs +0 -2
  13. package/esm2022/lib/helpers/interfaces/message.interface.mjs +0 -2
  14. package/esm2022/lib/helpers/pipes/value.pipe.mjs +0 -27
  15. package/esm2022/lib/modules/primeng.module.mjs +0 -86
  16. package/esm2022/lib/services/excel.service.mjs +0 -179
  17. package/esm2022/lib/services/message.service.mjs +0 -30
  18. package/esm2022/lib/services/table.service.mjs +0 -14
  19. package/esm2022/lib/views/cilog-input-number/cilog-input-number.component.mjs +0 -251
  20. package/esm2022/lib/views/documentation/documentation-contextuelle.component.mjs +0 -156
  21. package/esm2022/lib/views/editor/editor.component.mjs +0 -38
  22. package/esm2022/lib/views/message/message.component.mjs +0 -77
  23. package/esm2022/lib/views/table/table.component.mjs +0 -674
  24. package/esm2022/public-api.mjs +0 -24
  25. package/index.d.ts +0 -5
  26. package/lib/cilog-lib.component.d.ts +0 -8
  27. package/lib/cilog-lib.module.d.ts +0 -21
  28. package/lib/cilog-lib.service.d.ts +0 -6
  29. package/lib/helpers/enums/grille.enum.d.ts +0 -44
  30. package/lib/helpers/interfaces/edition.interface.d.ts +0 -34
  31. package/lib/helpers/interfaces/editor.interface.d.ts +0 -4
  32. package/lib/helpers/interfaces/grille.interface.d.ts +0 -166
  33. package/lib/helpers/interfaces/message.interface.d.ts +0 -6
  34. package/lib/helpers/pipes/value.pipe.d.ts +0 -7
  35. package/lib/modules/primeng.module.d.ts +0 -24
  36. package/lib/services/excel.service.d.ts +0 -15
  37. package/lib/services/message.service.d.ts +0 -12
  38. package/lib/services/table.service.d.ts +0 -6
  39. package/lib/views/cilog-input-number/cilog-input-number.component.d.ts +0 -40
  40. package/lib/views/documentation/documentation-contextuelle.component.d.ts +0 -49
  41. package/lib/views/editor/editor.component.d.ts +0 -17
  42. package/lib/views/message/message.component.d.ts +0 -17
  43. package/lib/views/table/table.component.d.ts +0 -83
  44. package/public-api.d.ts +0 -15
@@ -1,251 +0,0 @@
1
- import { Component, EventEmitter, forwardRef, HostListener, Input, Output, ViewChild } from '@angular/core';
2
- import { NG_VALUE_ACCESSOR } from '@angular/forms';
3
- import * as i0 from "@angular/core";
4
- import * as i1 from "@angular/common";
5
- import * as i2 from "primeng/inputtext";
6
- export class CilogInputNumberComponent {
7
- constructor() {
8
- this.onInput = new EventEmitter();
9
- this.onChange = new EventEmitter();
10
- this.onFocus = new EventEmitter();
11
- this.onBlur = new EventEmitter();
12
- this.valueStr = '';
13
- this.specialKeys = ['Tab', 'End', 'Home', 'ArrowLeft', 'ArrowRight'];
14
- }
15
- ngOnInit() {
16
- this.regex = new RegExp(`^-?\\d{1,3}(?:\\d{3})*(?:[\\.,]\\d{0,${this.maxDecimals || Number.MAX_SAFE_INTEGER}})?$`);
17
- }
18
- onKeyDownEvent(event) {
19
- if (this.specialKeys.indexOf(event.key) !== -1) {
20
- return;
21
- }
22
- if (event.key == 'Enter') {
23
- this.onChangeInput(this.value);
24
- this.onChange.emit(this.value);
25
- return;
26
- }
27
- let current = this.cilogInputNumber.nativeElement.value;
28
- const positionStart = this.cilogInputNumber.nativeElement.selectionStart;
29
- const positionEnd = this.cilogInputNumber.nativeElement.selectionEnd;
30
- let debut = current.slice(0, positionStart).replace(/\s/g, '');
31
- let fin = current.slice(positionEnd).replace(/\s/g, '');
32
- let next = current.replace(/\s/g, '');
33
- if (event.key === '.') {
34
- let positionStartPoint = this.cilogInputNumber.nativeElement.selectionStart;
35
- next = [debut, ',', fin].join('');
36
- if (String(next).match(this.regex)) {
37
- this.acceptValue(next, event);
38
- }
39
- else {
40
- if (current.slice(positionStart)[0] == ',') {
41
- this.cilogInputNumber.nativeElement.selectionStart = positionStartPoint + 1;
42
- this.cilogInputNumber.nativeElement.selectionEnd = positionStartPoint + 1;
43
- }
44
- }
45
- }
46
- else if (event.key === 'Backspace') {
47
- if (positionStart == positionEnd && (/\s/g.test(current.slice(positionStart - 1, positionStart)) || current.slice(positionStart - 1, positionStart) == ",")) {
48
- this.cilogInputNumber.nativeElement.selectionStart = positionStart - 1;
49
- this.cilogInputNumber.nativeElement.selectionEnd = positionStart - 1;
50
- if (this.cilogInputNumber.nativeElement.value.at(-1) == ',') {
51
- this.cilogInputNumber.nativeElement.value = this.cilogInputNumber.nativeElement.value.substring(0, this.cilogInputNumber.nativeElement.value.length - 1);
52
- }
53
- }
54
- else {
55
- if (this.cilogInputNumber.nativeElement.selectionStart != this.cilogInputNumber.nativeElement.selectionEnd) {
56
- next = [debut, fin].join('');
57
- }
58
- else {
59
- if (positionStart != 0) {
60
- debut = current.slice(0, positionStart - 1).replace(/\s/g, '');
61
- }
62
- next = [debut, fin].join('');
63
- }
64
- this.checkValue(next, event);
65
- }
66
- }
67
- else {
68
- if (event.key === ',' && current.slice(positionStart)[0] == ',') {
69
- this.cilogInputNumber.nativeElement.selectionStart += 1;
70
- }
71
- else {
72
- if (positionStart != positionEnd) {
73
- this.cilogInputNumber.nativeElement.selectionStart = positionStart + 1;
74
- this.cilogInputNumber.nativeElement.selectionEnd = positionStart + 1;
75
- }
76
- next = [debut, event.key, fin].join('');
77
- this.checkValue(next, event);
78
- }
79
- }
80
- event.preventDefault();
81
- }
82
- checkValue(next, event) {
83
- if (next == '-' && (this.min == null || this.min < 0)) {
84
- this.acceptValue(next, event);
85
- }
86
- else if (next.length > 1 && next[0] == ',') {
87
- this.acceptValue(next.substring(1), event);
88
- }
89
- else {
90
- if (String(next), !String(next).match(this.regex)) {
91
- if (next == '') {
92
- this.acceptValue(next, event);
93
- }
94
- }
95
- else {
96
- let number = +(next.replace(',', '.'));
97
- if (this.min == null || number >= this.min) {
98
- if (this.max == null || number <= this.max) {
99
- this.acceptValue(next, event);
100
- }
101
- }
102
- }
103
- }
104
- }
105
- acceptValue(value, event) {
106
- // Stockage position initiale
107
- const positionStart = this.cilogInputNumber.nativeElement.selectionStart;
108
- const positionEnd = this.cilogInputNumber.nativeElement.selectionEnd;
109
- let valEntier = this.cilogInputNumber.nativeElement.value.replace(/\s/g, '').split(',')[0];
110
- if (valEntier[0] == '-') {
111
- valEntier = valEntier.substring(1);
112
- }
113
- setTimeout(() => {
114
- let positionFinale = positionStart;
115
- if (positionStart == positionEnd) {
116
- let jump = 1;
117
- let valEntierNext = value.split(',')[0];
118
- if (valEntierNext[0] == '-') {
119
- valEntierNext = valEntierNext.substring(1);
120
- }
121
- if (value.split(',')[0] != valEntier &&
122
- ((event.key != 'Backspace' && valEntier.length != 0 && valEntier.length % 3 == 0)
123
- || (event.key == 'Backspace' && (valEntier.length - 1) != 0 && (valEntier.length - 1) % 3 == 0))) {
124
- jump = 2;
125
- }
126
- // Calcul position finale
127
- if (event.key == 'Backspace') {
128
- if (positionStart != 0) {
129
- positionFinale = positionStart - jump;
130
- }
131
- }
132
- else {
133
- positionFinale = positionStart + jump;
134
- }
135
- }
136
- this.cilogInputNumber.nativeElement.selectionStart = positionFinale;
137
- this.cilogInputNumber.nativeElement.selectionEnd = positionFinale;
138
- });
139
- // Mise à jour de la valeur du champ
140
- if (value == '' || value == '-') {
141
- this.writeValue(null, value);
142
- }
143
- else {
144
- this.writeValue(+(value.replace(',', '.')), value, ((event.key == '.' || event.key == ',') && value.slice(-1) == ','), (event.key == '0' && value.split(',')[0] == valEntier && value.split(',').length == 2), (event.key == '0' && +value.split(',')[1] == 0));
145
- }
146
- this.onChangeInput(this.value);
147
- this.onInput.emit(this.value);
148
- }
149
- writeValue(value, valueString = null, sep = false, zero = false, zeroAfter = false) {
150
- this.value = value;
151
- if (this.value == null) {
152
- if (valueString == '-') {
153
- this.valueStr = '-';
154
- }
155
- else {
156
- this.valueStr = '';
157
- }
158
- if (this.cilogInputNumber) {
159
- this.cilogInputNumber.nativeElement.value = this.valueStr;
160
- }
161
- }
162
- else {
163
- if (this.maxDecimals != null && this.value.toString().split('.').length > 1 && this.value.toString().split('.')[1].length > this.maxDecimals) {
164
- this.valueStr = this.value.toLocaleString('fr-FR', { maximumFractionDigits: this.maxDecimals });
165
- }
166
- else {
167
- this.valueStr = this.value.toLocaleString('fr-FR', { maximumFractionDigits: 6 });
168
- }
169
- if (sep || zeroAfter) {
170
- this.valueStr = this.valueStr + ',';
171
- }
172
- if (zero) {
173
- this.valueStr = this.valueStr + '0';
174
- }
175
- this.cilogInputNumber.nativeElement.value = this.valueStr;
176
- }
177
- }
178
- onBlurEvent(event) {
179
- this.onChangeInput(this.value);
180
- this.onChange.emit(this.value);
181
- this.onBlur.emit(this.value);
182
- }
183
- onFocusEvent(event) {
184
- this.onFocus.emit(this.value);
185
- }
186
- onChangeInput(val) { }
187
- onTouchedInput() { }
188
- registerOnChange(fn) {
189
- this.onChangeInput = fn;
190
- }
191
- registerOnTouched(fn) {
192
- this.onTouchedInput = fn;
193
- }
194
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: CilogInputNumberComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
195
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: CilogInputNumberComponent, selector: "cilog-input-number", inputs: { min: "min", max: "max", maxDecimals: "maxDecimals", prefixe: "prefixe", suffixe: "suffixe", inputStyleClass: "inputStyleClass", disabled: "disabled", readonly: "readonly", textColor: "textColor", bold: "bold", italic: "italic", floatLabel: "floatLabel" }, outputs: { onInput: "onInput", onChange: "onChange", onFocus: "onFocus", onBlur: "onBlur" }, host: { listeners: { "keydown": "onKeyDownEvent($event)" } }, providers: [
196
- {
197
- provide: NG_VALUE_ACCESSOR,
198
- useExisting: forwardRef(() => CilogInputNumberComponent),
199
- multi: true
200
- }
201
- ], viewQueries: [{ propertyName: "cilogInputNumber", first: true, predicate: ["cilogInputNumber"], descendants: true }], ngImport: i0, template: "<div class=\"input-group w-full\">\r\n\r\n <span class=\"input-group-addon prefixe\"\r\n *ngIf=\"prefixe != null\">\r\n {{ prefixe }}\r\n </span>\r\n\r\n <div [ngClass]=\"{ 'p-float-label' : floatLabel != null }\">\r\n <input #cilogInputNumber\r\n pInputText\r\n type=\"text\"\r\n [disabled]=\"disabled\"\r\n [readonly]=\"readonly\"\r\n [value]=\"valueStr\"\r\n (focus)=\"onFocusEvent($event)\"\r\n (blur)=\"onBlurEvent($event)\"\r\n [class]=\"'w-full z-1' + (inputStyleClass == null ? '' : ' ' + inputStyleClass)\"\r\n [ngClass]=\"suffixe != null && prefixe != null ? 'border-noround' : prefixe != null ? 'border-noround-left' : suffixe != null ? 'border-noround-right' : null\"\r\n [ngStyle]=\"{ 'color' : textColor ? textColor : null }\" />\r\n\r\n <label *ngIf=\"floatLabel != null\">{{ floatLabel }}</label>\r\n </div>\r\n\r\n <span class=\"input-group-addon suffixe\"\r\n *ngIf=\"suffixe != null\">\r\n {{ suffixe }}\r\n </span>\r\n\r\n</div>\r\n", styles: [":host ::ng-deep .input-group{display:flex!important}:host ::ng-deep .input-group-addon{background-color:#fff!important;border:1px solid #ccc!important;padding:0 12px!important;max-width:5rem!important;overflow:hidden!important;font-weight:700!important}:host ::ng-deep .prefixe{border-radius:4px 0 0 4px!important;border-right:none!important;display:flex;align-items:center}:host ::ng-deep .suffixe{border-radius:0 4px 4px 0!important;border-left:none!important;display:flex;align-items:center}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "directive", type: i2.InputText, selector: "[pInputText]", inputs: ["variant"] }] }); }
202
- }
203
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: CilogInputNumberComponent, decorators: [{
204
- type: Component,
205
- args: [{ selector: 'cilog-input-number', providers: [
206
- {
207
- provide: NG_VALUE_ACCESSOR,
208
- useExisting: forwardRef(() => CilogInputNumberComponent),
209
- multi: true
210
- }
211
- ], template: "<div class=\"input-group w-full\">\r\n\r\n <span class=\"input-group-addon prefixe\"\r\n *ngIf=\"prefixe != null\">\r\n {{ prefixe }}\r\n </span>\r\n\r\n <div [ngClass]=\"{ 'p-float-label' : floatLabel != null }\">\r\n <input #cilogInputNumber\r\n pInputText\r\n type=\"text\"\r\n [disabled]=\"disabled\"\r\n [readonly]=\"readonly\"\r\n [value]=\"valueStr\"\r\n (focus)=\"onFocusEvent($event)\"\r\n (blur)=\"onBlurEvent($event)\"\r\n [class]=\"'w-full z-1' + (inputStyleClass == null ? '' : ' ' + inputStyleClass)\"\r\n [ngClass]=\"suffixe != null && prefixe != null ? 'border-noround' : prefixe != null ? 'border-noround-left' : suffixe != null ? 'border-noround-right' : null\"\r\n [ngStyle]=\"{ 'color' : textColor ? textColor : null }\" />\r\n\r\n <label *ngIf=\"floatLabel != null\">{{ floatLabel }}</label>\r\n </div>\r\n\r\n <span class=\"input-group-addon suffixe\"\r\n *ngIf=\"suffixe != null\">\r\n {{ suffixe }}\r\n </span>\r\n\r\n</div>\r\n", styles: [":host ::ng-deep .input-group{display:flex!important}:host ::ng-deep .input-group-addon{background-color:#fff!important;border:1px solid #ccc!important;padding:0 12px!important;max-width:5rem!important;overflow:hidden!important;font-weight:700!important}:host ::ng-deep .prefixe{border-radius:4px 0 0 4px!important;border-right:none!important;display:flex;align-items:center}:host ::ng-deep .suffixe{border-radius:0 4px 4px 0!important;border-left:none!important;display:flex;align-items:center}\n"] }]
212
- }], ctorParameters: () => [], propDecorators: { min: [{
213
- type: Input
214
- }], max: [{
215
- type: Input
216
- }], maxDecimals: [{
217
- type: Input
218
- }], prefixe: [{
219
- type: Input
220
- }], suffixe: [{
221
- type: Input
222
- }], inputStyleClass: [{
223
- type: Input
224
- }], disabled: [{
225
- type: Input
226
- }], readonly: [{
227
- type: Input
228
- }], textColor: [{
229
- type: Input
230
- }], bold: [{
231
- type: Input
232
- }], italic: [{
233
- type: Input
234
- }], floatLabel: [{
235
- type: Input
236
- }], onInput: [{
237
- type: Output
238
- }], onChange: [{
239
- type: Output
240
- }], onFocus: [{
241
- type: Output
242
- }], onBlur: [{
243
- type: Output
244
- }], cilogInputNumber: [{
245
- type: ViewChild,
246
- args: ['cilogInputNumber']
247
- }], onKeyDownEvent: [{
248
- type: HostListener,
249
- args: ['keydown', ['$event']]
250
- }] } });
251
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cilog-input-number.component.js","sourceRoot":"","sources":["../../../../../../projects/cilog-lib/src/lib/views/cilog-input-number/cilog-input-number.component.ts","../../../../../../projects/cilog-lib/src/lib/views/cilog-input-number/cilog-input-number.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, EventEmitter, forwardRef, HostListener, Input, OnInit, Output, ViewChild } from '@angular/core';\r\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\r\n\r\n@Component({\r\n    selector: 'cilog-input-number',\r\n    templateUrl: './cilog-input-number.component.html',\r\n    styleUrls: ['./cilog-input-number.component.scss'],\r\n    providers: [\r\n        {\r\n            provide: NG_VALUE_ACCESSOR,\r\n            useExisting: forwardRef(() => CilogInputNumberComponent),\r\n            multi: true\r\n        }\r\n    ]\r\n})\r\nexport class CilogInputNumberComponent implements OnInit, ControlValueAccessor {\r\n\r\n    value: number;\r\n\r\n    @Input() min: number;\r\n    @Input() max: number;\r\n    @Input() maxDecimals: number;\r\n    @Input() prefixe: string;\r\n    @Input() suffixe: string;\r\n    @Input() inputStyleClass: string;\r\n    @Input() disabled: boolean;\r\n    @Input() readonly: boolean;\r\n    @Input() textColor: string;\r\n    @Input() bold: boolean;\r\n    @Input() italic: boolean;\r\n    @Input() floatLabel: string;\r\n\r\n    @Output() onInput: EventEmitter<number> = new EventEmitter<number>();\r\n    @Output() onChange: EventEmitter<number> = new EventEmitter<number>();\r\n    @Output() onFocus: EventEmitter<number> = new EventEmitter<number>();\r\n    @Output() onBlur: EventEmitter<number> = new EventEmitter<number>();\r\n\r\n    valueStr: string = '';\r\n\r\n    @ViewChild('cilogInputNumber') cilogInputNumber: ElementRef;\r\n\r\n    private regex: RegExp;\r\n    private specialKeys: Array<string> = ['Tab', 'End', 'Home', 'ArrowLeft', 'ArrowRight'];\r\n    \r\n    constructor() { }\r\n\r\n    ngOnInit() {\r\n        this.regex = new RegExp(`^-?\\\\d{1,3}(?:\\\\d{3})*(?:[\\\\.,]\\\\d{0,${this.maxDecimals || Number.MAX_SAFE_INTEGER}})?$`);\r\n    }\r\n\r\n    @HostListener('keydown', ['$event'])\r\n    onKeyDownEvent(event: KeyboardEvent) {\r\n\r\n        if (this.specialKeys.indexOf(event.key) !== -1) {\r\n            return;\r\n        }\r\n\r\n        if (event.key == 'Enter') {\r\n            this.onChangeInput(this.value);\r\n            this.onChange.emit(this.value);\r\n            return;\r\n        }\r\n\r\n        let current: string = this.cilogInputNumber.nativeElement.value;\r\n\r\n        const positionStart = this.cilogInputNumber.nativeElement.selectionStart;\r\n        const positionEnd = this.cilogInputNumber.nativeElement.selectionEnd;\r\n\r\n        let debut: string = current.slice(0, positionStart).replace(/\\s/g, '');\r\n        let fin: string = current.slice(positionEnd).replace(/\\s/g, '');\r\n\r\n        let next: string = current.replace(/\\s/g, '');\r\n        if (event.key === '.') {\r\n            let positionStartPoint: number = this.cilogInputNumber.nativeElement.selectionStart;\r\n            next = [debut, ',', fin].join('');\r\n            if (String(next).match(this.regex)) {\r\n                this.acceptValue(next, event);\r\n            } else {\r\n                if (current.slice(positionStart)[0] == ',') {\r\n                    this.cilogInputNumber.nativeElement.selectionStart = positionStartPoint + 1;\r\n                    this.cilogInputNumber.nativeElement.selectionEnd = positionStartPoint + 1;\r\n                }\r\n            }\r\n        } else if (event.key === 'Backspace') {\r\n            if (positionStart == positionEnd && (/\\s/g.test(current.slice(positionStart - 1, positionStart)) || current.slice(positionStart - 1, positionStart) == \",\")) {\r\n                this.cilogInputNumber.nativeElement.selectionStart = positionStart - 1;\r\n                this.cilogInputNumber.nativeElement.selectionEnd = positionStart - 1;\r\n                if (this.cilogInputNumber.nativeElement.value.at(-1) == ',') {\r\n                    this.cilogInputNumber.nativeElement.value = this.cilogInputNumber.nativeElement.value.substring(0, this.cilogInputNumber.nativeElement.value.length - 1);\r\n                }\r\n            } else {\r\n                if (this.cilogInputNumber.nativeElement.selectionStart != this.cilogInputNumber.nativeElement.selectionEnd) {\r\n                    next = [debut, fin].join('');\r\n                } else {\r\n                    if (positionStart != 0) {\r\n                        debut = current.slice(0, positionStart - 1).replace(/\\s/g, '');\r\n                    }\r\n                    next = [debut, fin].join('');\r\n                }\r\n                this.checkValue(next, event);\r\n            }\r\n        } else {\r\n            if (event.key === ',' && current.slice(positionStart)[0] == ',') {\r\n                this.cilogInputNumber.nativeElement.selectionStart += 1;\r\n            } else {\r\n                if (positionStart != positionEnd) {\r\n                    this.cilogInputNumber.nativeElement.selectionStart = positionStart + 1;\r\n                    this.cilogInputNumber.nativeElement.selectionEnd = positionStart + 1;\r\n                }\r\n                next = [debut, event.key, fin].join('');\r\n                this.checkValue(next, event);\r\n            }\r\n        }\r\n\r\n        event.preventDefault();\r\n    }\r\n\r\n    checkValue(next: string, event) {\r\n        if (next == '-' && (this.min == null || this.min < 0)) {\r\n            this.acceptValue(next, event);\r\n        } else if (next.length > 1 && next[0] == ',') {\r\n            this.acceptValue(next.substring(1), event);\r\n        } else {\r\n            if (String(next), !String(next).match(this.regex)) {\r\n                if (next == '') {\r\n                    this.acceptValue(next, event);\r\n                }\r\n            } else {\r\n                let number: number = +(next.replace(',', '.'));\r\n                if (this.min == null || number >= this.min) {\r\n                    if (this.max == null || number <= this.max) {\r\n                        this.acceptValue(next, event);\r\n                    }\r\n                }\r\n            }\r\n        }\r\n    }\r\n\r\n    acceptValue(value: string, event) {\r\n        // Stockage position initiale\r\n        const positionStart = this.cilogInputNumber.nativeElement.selectionStart;\r\n        const positionEnd = this.cilogInputNumber.nativeElement.selectionEnd;\r\n        let valEntier: string = this.cilogInputNumber.nativeElement.value.replace(/\\s/g, '').split(',')[0];\r\n        if (valEntier[0] == '-') {\r\n            valEntier = valEntier.substring(1);\r\n        }\r\n\r\n        setTimeout(() => {\r\n            let positionFinale: number = positionStart;\r\n            if (positionStart == positionEnd) {\r\n                let jump: number = 1;\r\n                let valEntierNext: string = value.split(',')[0];\r\n                if (valEntierNext[0] == '-') {\r\n                    valEntierNext = valEntierNext.substring(1);\r\n                }\r\n                if (\r\n                    value.split(',')[0] != valEntier &&\r\n                    (\r\n                        (event.key != 'Backspace' && valEntier.length != 0 && valEntier.length % 3 == 0)\r\n                        || (event.key == 'Backspace' && (valEntier.length - 1) != 0 && (valEntier.length - 1) % 3 == 0)\r\n                    )\r\n                ) {\r\n                    jump = 2;\r\n                }\r\n\r\n                // Calcul position finale\r\n                if (event.key == 'Backspace') {\r\n                    if (positionStart != 0) {\r\n                        positionFinale = positionStart - jump;\r\n                    }\r\n                } else {\r\n                    positionFinale = positionStart + jump;\r\n                }\r\n            }\r\n            this.cilogInputNumber.nativeElement.selectionStart = positionFinale;\r\n            this.cilogInputNumber.nativeElement.selectionEnd = positionFinale;\r\n        });\r\n\r\n        // Mise à jour de la valeur du champ\r\n        if (value == '' || value == '-') {\r\n            this.writeValue(null, value);\r\n        } else {\r\n            this.writeValue(\r\n                +(value.replace(',', '.')),\r\n                value,\r\n                ((event.key == '.' || event.key == ',') && value.slice(-1) == ','),\r\n                (event.key == '0' && value.split(',')[0] == valEntier && value.split(',').length == 2),\r\n                (event.key == '0' && +value.split(',')[1] == 0)\r\n            );\r\n        }\r\n\r\n        this.onChangeInput(this.value);\r\n        this.onInput.emit(this.value);\r\n    }\r\n\r\n    writeValue(value: number, valueString: string = null, sep: boolean = false, zero: boolean = false, zeroAfter: boolean = false): void {\r\n        this.value = value;\r\n\r\n        if (this.value == null) {\r\n            if (valueString == '-') {\r\n                this.valueStr = '-';\r\n            } else {\r\n                this.valueStr = '';\r\n            }\r\n            if (this.cilogInputNumber) {\r\n                this.cilogInputNumber.nativeElement.value = this.valueStr;\r\n            }\r\n        } else {\r\n            if (this.maxDecimals != null && this.value.toString().split('.').length > 1 && this.value.toString().split('.')[1].length > this.maxDecimals) {\r\n                this.valueStr = this.value.toLocaleString('fr-FR', { maximumFractionDigits: this.maxDecimals });\r\n            } else {\r\n                this.valueStr = this.value.toLocaleString('fr-FR', { maximumFractionDigits: 6 });\r\n            }\r\n            if (sep || zeroAfter) {\r\n                this.valueStr = this.valueStr + ',';\r\n            }\r\n            if (zero) {\r\n                this.valueStr = this.valueStr + '0';\r\n            }\r\n            this.cilogInputNumber.nativeElement.value = this.valueStr;\r\n        }\r\n    }\r\n\r\n    onBlurEvent(event) {\r\n        this.onChangeInput(this.value);\r\n        this.onChange.emit(this.value);\r\n        this.onBlur.emit(this.value);\r\n    }\r\n\r\n    onFocusEvent(event) {\r\n        this.onFocus.emit(this.value);\r\n    }\r\n\r\n    onChangeInput(val: number) { }\r\n\r\n    onTouchedInput() { }\r\n\r\n    registerOnChange(fn: () => void): void {\r\n        this.onChangeInput = fn;\r\n    }\r\n\r\n    registerOnTouched(fn: () => void): void {\r\n        this.onTouchedInput = fn;\r\n    }\r\n}\r\n","<div class=\"input-group w-full\">\r\n\r\n    <span class=\"input-group-addon prefixe\"\r\n          *ngIf=\"prefixe != null\">\r\n        {{ prefixe }}\r\n    </span>\r\n\r\n    <div [ngClass]=\"{ 'p-float-label' : floatLabel != null }\">\r\n        <input #cilogInputNumber\r\n               pInputText\r\n               type=\"text\"\r\n               [disabled]=\"disabled\"\r\n               [readonly]=\"readonly\"\r\n               [value]=\"valueStr\"\r\n               (focus)=\"onFocusEvent($event)\"\r\n               (blur)=\"onBlurEvent($event)\"\r\n               [class]=\"'w-full z-1' + (inputStyleClass == null ? '' : ' ' + inputStyleClass)\"\r\n               [ngClass]=\"suffixe != null && prefixe != null ? 'border-noround' : prefixe != null ? 'border-noround-left' : suffixe != null ? 'border-noround-right' : null\"\r\n               [ngStyle]=\"{ 'color' : textColor ? textColor : null }\" />\r\n\r\n        <label *ngIf=\"floatLabel != null\">{{ floatLabel }}</label>\r\n    </div>\r\n\r\n    <span class=\"input-group-addon suffixe\"\r\n          *ngIf=\"suffixe != null\">\r\n        {{ suffixe }}\r\n    </span>\r\n\r\n</div>\r\n"]}
@@ -1,156 +0,0 @@
1
- import { Component } from '@angular/core';
2
- import * as i0 from "@angular/core";
3
- import * as i1 from "@angular/common/http";
4
- import * as i2 from "@angular/router";
5
- import * as i3 from "@angular/common";
6
- import * as i4 from "primeng/button";
7
- import * as i5 from "primeng/inputtext";
8
- import * as i6 from "primeng/tabview";
9
- import * as i7 from "@angular/forms";
10
- import * as i8 from "ngx-markdown";
11
- import * as i9 from "primeng/progressspinner";
12
- export class DocumentationContextuelleComponent {
13
- constructor(http, router) {
14
- this.http = http;
15
- this.router = router;
16
- this.categories = [];
17
- this.filteredCategories = [];
18
- this.tabs = [];
19
- this.searchQuery = '';
20
- this.activeTabIndex = 0;
21
- }
22
- ngOnInit() {
23
- this.http.get('assets/docs/doc-config/config.json').subscribe((config) => {
24
- this.config = config;
25
- this.organizeDocsByCategory(config);
26
- // Tentative d'ouverture automatique en fonction de l'URL
27
- const currentPath = this.router.url;
28
- const foundDoc = this.findDocForUrl(currentPath);
29
- if (foundDoc) {
30
- this.openDocumentationAndSwitch(foundDoc);
31
- }
32
- else {
33
- this.openDocumentationList(); // fallback sur le sommaire
34
- }
35
- });
36
- }
37
- openCurrentPageDoc() {
38
- const currentPath = this.router.url;
39
- const foundDoc = this.findDocForUrl(currentPath);
40
- if (foundDoc) {
41
- this.openDocumentationAndSwitch(foundDoc);
42
- }
43
- else {
44
- this.openDocumentationList();
45
- }
46
- }
47
- organizeDocsByCategory(config) {
48
- const categories = config.categories.map((cat) => ({
49
- ...cat,
50
- docs: []
51
- }));
52
- const iconMappings = config.iconMappings || {};
53
- const docsConfig = config.documentations;
54
- for (const fileName in docsConfig) {
55
- const doc = docsConfig[fileName];
56
- const categoryKey = doc.category;
57
- const matchedCategory = categories.find((cat) => cat.key === categoryKey);
58
- if (matchedCategory) {
59
- const icon = doc.tags?.map(t => iconMappings[t])?.find(i => !!i) || iconMappings.default;
60
- matchedCategory.docs.push({
61
- ...doc,
62
- fileName,
63
- icon
64
- });
65
- }
66
- }
67
- this.categories = categories.sort((a, b) => a.name - b.name);
68
- this.categories.forEach(cat => {
69
- cat.docs = cat.docs.sort((a, b) => a.displayName.localeCompare(b.displayName));
70
- });
71
- this.filteredCategories = JSON.parse(JSON.stringify(this.categories));
72
- }
73
- filterDocumentation() {
74
- const query = this.searchQuery.toLowerCase();
75
- this.filteredCategories = this.categories.map(category => {
76
- const filteredDocs = category.docs.filter(doc => doc.displayName.toLowerCase().includes(query) ||
77
- doc.description.toLowerCase().includes(query) ||
78
- doc.tags?.some(tag => tag.toLowerCase().includes(query)));
79
- return {
80
- ...category,
81
- docs: filteredDocs
82
- };
83
- }).filter(cat => cat.docs.length > 0);
84
- }
85
- toggleCategory(key) {
86
- const cat = this.filteredCategories.find(c => c.key === key);
87
- if (cat)
88
- cat.expanded = !cat.expanded;
89
- }
90
- openTabAndActivate(tab) {
91
- this.tabs.push(tab);
92
- setTimeout(() => {
93
- this.activeTabIndex = this.tabs.length - 1;
94
- });
95
- }
96
- openDocumentationAndSwitch(doc) {
97
- const existingTab = this.tabs.find(tab => tab.fileName === doc.fileName);
98
- if (existingTab) {
99
- this.activeTabIndex = this.tabs.indexOf(existingTab);
100
- return;
101
- }
102
- const newTab = {
103
- type: 'doc',
104
- title: doc.displayName,
105
- fileName: doc.fileName,
106
- content: '',
107
- loading: true,
108
- category: this.categories.find(c => c.key === doc.category)?.name
109
- };
110
- this.openTabAndActivate(newTab);
111
- fetch(`assets/docs/${doc.fileName}`)
112
- .then(res => res.text())
113
- .then(content => {
114
- newTab.content = content;
115
- newTab.loading = false;
116
- })
117
- .catch(() => {
118
- newTab.content = '❌ Erreur lors du chargement du fichier markdown.';
119
- newTab.loading = false;
120
- });
121
- }
122
- openDocumentationList() {
123
- const existing = this.tabs.find(t => t.type === 'list');
124
- if (existing) {
125
- this.activeTabIndex = this.tabs.indexOf(existing);
126
- return;
127
- }
128
- this.openTabAndActivate({ type: 'list', title: '📚 Sommaire des Docs' });
129
- }
130
- getTotalDocsCount() {
131
- return this.categories.reduce((sum, cat) => sum + cat.docs.length, 0);
132
- }
133
- getOpenTabsCount() {
134
- return this.tabs.length;
135
- }
136
- closeTab(event) {
137
- this.tabs.splice(event.index, 1);
138
- if (this.activeTabIndex >= this.tabs.length) {
139
- this.activeTabIndex = this.tabs.length - 1;
140
- }
141
- }
142
- /** Essaie de retrouver un document à partir de l'URL Angular */
143
- findDocForUrl(url) {
144
- const normalizedUrl = url.replace(/^\/+/, '').replace(/\/$/, '');
145
- return this.categories
146
- .reduce((acc, cat) => acc.concat(cat.docs), [])
147
- .find(doc => normalizedUrl.toLowerCase().includes(doc.fileName.toLowerCase().replace('.md', '')));
148
- }
149
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: DocumentationContextuelleComponent, deps: [{ token: i1.HttpClient }, { token: i2.Router }], target: i0.ɵɵFactoryTarget.Component }); }
150
- 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: i5.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: i7.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: i7.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i7.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i8.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.ProgressSpinner, selector: "p-progressSpinner", inputs: ["styleClass", "style", "strokeWidth", "fill", "animationDuration", "ariaLabel"] }] }); }
151
- }
152
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: DocumentationContextuelleComponent, decorators: [{
153
- type: Component,
154
- 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"] }]
155
- }], ctorParameters: () => [{ type: i1.HttpClient }, { type: i2.Router }] });
156
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"documentation-contextuelle.component.js","sourceRoot":"","sources":["../../../../../../projects/cilog-lib/src/lib/views/documentation/documentation-contextuelle.component.ts","../../../../../../projects/cilog-lib/src/lib/views/documentation/documentation-contextuelle.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit } from '@angular/core';\r\nimport { HttpClient } from '@angular/common/http';\r\nimport { Router } from '@angular/router';\r\n\r\ninterface DocumentationEntry {\r\n  displayName: string;\r\n  description: string;\r\n  category: string;\r\n  tags: string[];\r\n}\r\n\r\ninterface Category {\r\n  key: string;\r\n  name: string;\r\n  icon: string;\r\n  expanded: boolean;\r\n  keywords: string[];\r\n  docs: DocFile[];\r\n}\r\n\r\ninterface DocFile extends DocumentationEntry {\r\n  fileName: string;\r\n  icon: string;\r\n}\r\n\r\n@Component({\r\n  selector: 'cilog-documentation-contextuelle',\r\n  templateUrl: './documentation-contextuelle.component.html',\r\n  styleUrls: ['./documentation-contextuelle.component.scss']\r\n})\r\nexport class DocumentationContextuelleComponent implements OnInit {\r\n  config: any;\r\n  categories: Category[] = [];\r\n  filteredCategories: Category[] = [];\r\n  tabs: any[] = [];\r\n  searchQuery = '';\r\n  activeTabIndex = 0;\r\n\r\n  constructor(\r\n    private http: HttpClient,\r\n    private router: Router\r\n  ) {}\r\n\r\n  ngOnInit(): void {\r\n    this.http.get('assets/docs/doc-config/config.json').subscribe((config: any) => {\r\n      this.config = config;\r\n      this.organizeDocsByCategory(config);\r\n\r\n      // Tentative d'ouverture automatique en fonction de l'URL\r\n      const currentPath = this.router.url;\r\n      const foundDoc = this.findDocForUrl(currentPath);\r\n      if (foundDoc) {\r\n        this.openDocumentationAndSwitch(foundDoc);\r\n      } else {\r\n        this.openDocumentationList(); // fallback sur le sommaire\r\n      }\r\n    });\r\n  }\r\n\r\n  openCurrentPageDoc(): void {\r\n    const currentPath = this.router.url;\r\n    const foundDoc = this.findDocForUrl(currentPath);\r\n    if (foundDoc) {\r\n      this.openDocumentationAndSwitch(foundDoc);\r\n    } else {\r\n      this.openDocumentationList();\r\n    }\r\n  }\r\n\r\n  organizeDocsByCategory(config: any): void {\r\n    const categories = config.categories.map((cat: any) => ({\r\n      ...cat,\r\n      docs: []\r\n    }));\r\n\r\n    const iconMappings = config.iconMappings || {};\r\n    const docsConfig = config.documentations;\r\n\r\n    for (const fileName in docsConfig) {\r\n      const doc = docsConfig[fileName];\r\n      const categoryKey = doc.category;\r\n\r\n      const matchedCategory = categories.find((cat: any) => cat.key === categoryKey);\r\n      if (matchedCategory) {\r\n        const icon = doc.tags?.map(t => iconMappings[t])?.find(i => !!i) || iconMappings.default;\r\n        matchedCategory.docs.push({\r\n          ...doc,\r\n          fileName,\r\n          icon\r\n        });\r\n      }\r\n    }\r\n\r\n    this.categories = categories.sort((a, b) => a.name - b.name);\r\n    this.categories.forEach(cat => {\r\n      cat.docs = cat.docs.sort((a, b) => a.displayName.localeCompare(b.displayName));\r\n    });\r\n    this.filteredCategories = JSON.parse(JSON.stringify(this.categories));\r\n  }\r\n\r\n  filterDocumentation(): void {\r\n    const query = this.searchQuery.toLowerCase();\r\n\r\n    this.filteredCategories = this.categories.map(category => {\r\n      const filteredDocs = category.docs.filter(doc =>\r\n        doc.displayName.toLowerCase().includes(query) ||\r\n        doc.description.toLowerCase().includes(query) ||\r\n        doc.tags?.some(tag => tag.toLowerCase().includes(query))\r\n      );\r\n      return {\r\n        ...category,\r\n        docs: filteredDocs\r\n      };\r\n    }).filter(cat => cat.docs.length > 0);\r\n  }\r\n\r\n  toggleCategory(key: string): void {\r\n    const cat = this.filteredCategories.find(c => c.key === key);\r\n    if (cat) cat.expanded = !cat.expanded;\r\n  }\r\n\r\n  openTabAndActivate(tab: any): void {\r\n    this.tabs.push(tab);\r\n    setTimeout(() => {\r\n      this.activeTabIndex = this.tabs.length - 1;\r\n    });\r\n  }\r\n\r\n\r\n  openDocumentationAndSwitch(doc: DocFile): void {\r\n    const existingTab = this.tabs.find(tab => tab.fileName === doc.fileName);\r\n    if (existingTab) {\r\n      this.activeTabIndex = this.tabs.indexOf(existingTab);\r\n      return;\r\n    }\r\n\r\n    const newTab = {\r\n      type: 'doc',\r\n      title: doc.displayName,\r\n      fileName: doc.fileName,\r\n      content: '',\r\n      loading: true,\r\n      category: this.categories.find(c => c.key === doc.category)?.name\r\n    };\r\n\r\n  this.openTabAndActivate(newTab);\r\n\r\n    fetch(`assets/docs/${doc.fileName}`)\r\n      .then(res => res.text())\r\n      .then(content => {\r\n        newTab.content = content;\r\n        newTab.loading = false;\r\n      })\r\n      .catch(() => {\r\n        newTab.content = '❌ Erreur lors du chargement du fichier markdown.';\r\n        newTab.loading = false;\r\n      });\r\n  }\r\n\r\n  openDocumentationList(): void {\r\n    const existing = this.tabs.find(t => t.type === 'list');\r\n    if (existing) {\r\n      this.activeTabIndex = this.tabs.indexOf(existing);\r\n      return;\r\n    }\r\n    this.openTabAndActivate({ type: 'list', title: '📚 Sommaire des Docs' });\r\n  }\r\n\r\n  getTotalDocsCount(): number {\r\n    return this.categories.reduce((sum, cat) => sum + cat.docs.length, 0);\r\n  }\r\n\r\n  getOpenTabsCount(): number {\r\n    return this.tabs.length;\r\n  }\r\n\r\n  closeTab(event: any): void {\r\n    this.tabs.splice(event.index, 1);\r\n    if (this.activeTabIndex >= this.tabs.length) {\r\n      this.activeTabIndex = this.tabs.length - 1;\r\n    }\r\n  }\r\n\r\n  /** Essaie de retrouver un document à partir de l'URL Angular */\r\n  findDocForUrl(url: string): DocFile | undefined {\r\n    const normalizedUrl = url.replace(/^\\/+/, '').replace(/\\/$/, '');\r\n    return this.categories\r\n      .reduce((acc, cat) => acc.concat(cat.docs), [] as DocFile[])\r\n      .find(doc =>\r\n        normalizedUrl.toLowerCase().includes(doc.fileName.toLowerCase().replace('.md', ''))\r\n      );\r\n  }\r\n}\r\n","<div class=\"documentation-container\">\r\n  <!-- Menu supérieur -->\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ème 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éliorée -->\r\n      <div *ngIf=\"tab.type === 'list'\" class=\"docs-list-container\">\r\n        <div class=\"docs-header\">\r\n          <h2>📚 Sommaire de la Documentation</h2>\r\n          <p class=\"docs-subtitle\">Explorez toutes les fonctionnalités 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égories -->\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>"]}
@@ -1,38 +0,0 @@
1
- import { Output, ViewChild } from '@angular/core';
2
- import { EventEmitter } from '@angular/core';
3
- import { Input } from '@angular/core';
4
- import { Component } from '@angular/core';
5
- import * as i0 from "@angular/core";
6
- import * as i1 from "primeng/editor";
7
- import * as i2 from "@angular/forms";
8
- export class CilogEditorComponent {
9
- constructor() {
10
- this.textChange = new EventEmitter();
11
- this.onTextChange = new EventEmitter();
12
- }
13
- ngOnInit() {
14
- }
15
- change(event) {
16
- this.textChange.emit(event.htmlValue);
17
- this.onTextChange.emit({ htmlValue: event.htmlValue, textValue: event.textValue });
18
- }
19
- onSelectionChange(event) {
20
- // NOTHING
21
- }
22
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: CilogEditorComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
23
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: CilogEditorComponent, selector: "cilog-editor", inputs: { text: "text" }, outputs: { textChange: "textChange", onTextChange: "onTextChange" }, viewQueries: [{ propertyName: "editor", first: true, predicate: ["editor"], descendants: true }], ngImport: i0, template: "<p-editor #editor\r\n [(ngModel)]=\"text\"\r\n (onTextChange)=\"change($event)\">\r\n</p-editor>\r\n", styles: [""], dependencies: [{ kind: "component", type: i1.Editor, selector: "p-editor", inputs: ["style", "styleClass", "placeholder", "formats", "modules", "bounds", "scrollingContainer", "debug", "readonly"], outputs: ["onInit", "onTextChange", "onSelectionChange"] }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }] }); }
24
- }
25
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: CilogEditorComponent, decorators: [{
26
- type: Component,
27
- args: [{ selector: 'cilog-editor', template: "<p-editor #editor\r\n [(ngModel)]=\"text\"\r\n (onTextChange)=\"change($event)\">\r\n</p-editor>\r\n" }]
28
- }], ctorParameters: () => [], propDecorators: { text: [{
29
- type: Input
30
- }], textChange: [{
31
- type: Output
32
- }], onTextChange: [{
33
- type: Output
34
- }], editor: [{
35
- type: ViewChild,
36
- args: ['editor']
37
- }] } });
38
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWRpdG9yLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2NpbG9nLWxpYi9zcmMvbGliL3ZpZXdzL2VkaXRvci9lZGl0b3IuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY2lsb2ctbGliL3NyYy9saWIvdmlld3MvZWRpdG9yL2VkaXRvci5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsTUFBTSxFQUFFLFNBQVMsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUNsRCxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQzdDLE9BQU8sRUFBRSxLQUFLLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDdEMsT0FBTyxFQUFFLFNBQVMsRUFBVSxNQUFNLGVBQWUsQ0FBQzs7OztBQVNsRCxNQUFNLE9BQU8sb0JBQW9CO0lBUzdCO1FBTlUsZUFBVSxHQUF5QixJQUFJLFlBQVksRUFBVSxDQUFDO1FBRTlELGlCQUFZLEdBQW9DLElBQUksWUFBWSxFQUFxQixDQUFDO0lBSWhGLENBQUM7SUFFakIsUUFBUTtJQUNSLENBQUM7SUFFRCxNQUFNLENBQUMsS0FBSztRQUNSLElBQUksQ0FBQyxVQUFVLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxTQUFTLENBQUMsQ0FBQztRQUN0QyxJQUFJLENBQUMsWUFBWSxDQUFDLElBQUksQ0FBQyxFQUFFLFNBQVMsRUFBRSxLQUFLLENBQUMsU0FBUyxFQUFFLFNBQVMsRUFBRSxLQUFLLENBQUMsU0FBUyxFQUFFLENBQUMsQ0FBQztJQUN2RixDQUFDO0lBRUQsaUJBQWlCLENBQUMsS0FBSztRQUNuQixVQUFVO0lBQ2QsQ0FBQzsrR0FyQlEsb0JBQW9CO21HQUFwQixvQkFBb0IscVBDWmpDLHdIQUlBOzs0RkRRYSxvQkFBb0I7a0JBTGhDLFNBQVM7K0JBQ0ksY0FBYzt3REFNZixJQUFJO3NCQUFaLEtBQUs7Z0JBQ0ksVUFBVTtzQkFBbkIsTUFBTTtnQkFFRyxZQUFZO3NCQUFyQixNQUFNO2dCQUVjLE1BQU07c0JBQTFCLFNBQVM7dUJBQUMsUUFBUSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE91dHB1dCwgVmlld0NoaWxkIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IEV2ZW50RW1pdHRlciB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBJbnB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBDb21wb25lbnQsIE9uSW5pdCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBJRWRpdG9yVGV4dENoYW5nZSB9IGZyb20gJy4uLy4uL2hlbHBlcnMvaW50ZXJmYWNlcy9lZGl0b3IuaW50ZXJmYWNlJztcclxuaW1wb3J0IHsgRWRpdG9yIH0gZnJvbSAncHJpbWVuZy9lZGl0b3InO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgICBzZWxlY3RvcjogJ2NpbG9nLWVkaXRvcicsXHJcbiAgICB0ZW1wbGF0ZVVybDogJy4vZWRpdG9yLmNvbXBvbmVudC5odG1sJyxcclxuICAgIHN0eWxlVXJsczogWycuL2VkaXRvci5jb21wb25lbnQuc2NzcyddXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBDaWxvZ0VkaXRvckNvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCB7XHJcblxyXG4gICAgQElucHV0KCkgdGV4dDogc3RyaW5nO1xyXG4gICAgQE91dHB1dCgpIHRleHRDaGFuZ2U6IEV2ZW50RW1pdHRlcjxzdHJpbmc+ID0gbmV3IEV2ZW50RW1pdHRlcjxzdHJpbmc+KCk7XHJcblxyXG4gICAgQE91dHB1dCgpIG9uVGV4dENoYW5nZTogRXZlbnRFbWl0dGVyPElFZGl0b3JUZXh0Q2hhbmdlPiA9IG5ldyBFdmVudEVtaXR0ZXI8SUVkaXRvclRleHRDaGFuZ2U+KCk7XHJcblxyXG4gICAgQFZpZXdDaGlsZCgnZWRpdG9yJykgZWRpdG9yOiBFZGl0b3I7XHJcblxyXG4gICAgY29uc3RydWN0b3IoKSB7IH1cclxuXHJcbiAgICBuZ09uSW5pdCgpOiB2b2lkIHtcclxuICAgIH1cclxuXHJcbiAgICBjaGFuZ2UoZXZlbnQpIHtcclxuICAgICAgICB0aGlzLnRleHRDaGFuZ2UuZW1pdChldmVudC5odG1sVmFsdWUpO1xyXG4gICAgICAgIHRoaXMub25UZXh0Q2hhbmdlLmVtaXQoeyBodG1sVmFsdWU6IGV2ZW50Lmh0bWxWYWx1ZSwgdGV4dFZhbHVlOiBldmVudC50ZXh0VmFsdWUgfSk7XHJcbiAgICB9XHJcblxyXG4gICAgb25TZWxlY3Rpb25DaGFuZ2UoZXZlbnQpIHtcclxuICAgICAgICAvLyBOT1RISU5HXHJcbiAgICB9XHJcbn1cclxuIiwiPHAtZWRpdG9yICNlZGl0b3JcclxuICAgICAgICAgIFsobmdNb2RlbCldPVwidGV4dFwiXHJcbiAgICAgICAgICAob25UZXh0Q2hhbmdlKT1cImNoYW5nZSgkZXZlbnQpXCI+XHJcbjwvcC1lZGl0b3I+XHJcbiJdfQ==