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
|
@@ -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==
|