pdm-ui-kit 0.1.50 → 0.2.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (46) hide show
  1. package/README.md +189 -2
  2. package/esm2020/lib/components/alert-dialog/alert-dialog.component.mjs +3 -3
  3. package/esm2020/lib/components/breadcrumb/breadcrumb.component.mjs +37 -4
  4. package/esm2020/lib/components/calendar/calendar.component.mjs +3 -3
  5. package/esm2020/lib/components/card/card.component.mjs +36 -53
  6. package/esm2020/lib/components/command/command.component.mjs +3 -3
  7. package/esm2020/lib/components/context-menu/context-menu.component.mjs +3 -3
  8. package/esm2020/lib/components/data-table/data-table.component.mjs +214 -16
  9. package/esm2020/lib/components/dialog/dialog.component.mjs +133 -17
  10. package/esm2020/lib/components/draggable-table/draggable-table.component.mjs +300 -0
  11. package/esm2020/lib/components/drawer/drawer.component.mjs +123 -16
  12. package/esm2020/lib/components/dropdown-menu/dropdown-menu.component.mjs +3 -2
  13. package/esm2020/lib/components/hover-card/hover-card.component.mjs +3 -3
  14. package/esm2020/lib/components/menubar/menubar.component.mjs +3 -3
  15. package/esm2020/lib/components/navigation-menu/navigation-menu.component.mjs +25 -3
  16. package/esm2020/lib/components/pagination/pagination.component.mjs +3 -3
  17. package/esm2020/lib/components/popover/popover.component.mjs +5 -3
  18. package/esm2020/lib/components/select/select.component.mjs +5 -3
  19. package/esm2020/lib/components/sheet/sheet.component.mjs +68 -12
  20. package/esm2020/lib/components/sidebar/sidebar.component.mjs +52 -5
  21. package/esm2020/lib/components/table/table.component.mjs +152 -188
  22. package/esm2020/lib/components/tabs/tabs.component.mjs +3 -3
  23. package/esm2020/lib/components/tooltip/tooltip.component.mjs +3 -3
  24. package/esm2020/lib/pdm-ui-kit.module.mjs +5 -1
  25. package/esm2020/lib/utils/responsive.mjs +143 -0
  26. package/esm2020/lib/utils/z-index.mjs +93 -0
  27. package/esm2020/public-api.mjs +4 -1
  28. package/fesm2015/pdm-ui-kit.mjs +1430 -371
  29. package/fesm2015/pdm-ui-kit.mjs.map +1 -1
  30. package/fesm2020/pdm-ui-kit.mjs +1428 -369
  31. package/fesm2020/pdm-ui-kit.mjs.map +1 -1
  32. package/lib/components/breadcrumb/breadcrumb.component.d.ts +23 -1
  33. package/lib/components/card/card.component.d.ts +32 -19
  34. package/lib/components/data-table/data-table.component.d.ts +172 -14
  35. package/lib/components/dialog/dialog.component.d.ts +35 -1
  36. package/lib/components/draggable-table/draggable-table.component.d.ts +74 -0
  37. package/lib/components/drawer/drawer.component.d.ts +65 -7
  38. package/lib/components/navigation-menu/navigation-menu.component.d.ts +22 -1
  39. package/lib/components/sheet/sheet.component.d.ts +30 -3
  40. package/lib/components/sidebar/sidebar.component.d.ts +39 -1
  41. package/lib/components/table/table.component.d.ts +46 -25
  42. package/lib/pdm-ui-kit.module.d.ts +42 -41
  43. package/lib/utils/responsive.d.ts +107 -0
  44. package/lib/utils/z-index.d.ts +73 -0
  45. package/package.json +5 -3
  46. package/public-api.d.ts +3 -0
@@ -1,209 +1,173 @@
1
- import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output, ViewChild } from '@angular/core';
1
+ import { ChangeDetectionStrategy, Component, Input } from '@angular/core';
2
+ import { TABLE_RESPONSIVE } from '../../utils/responsive';
2
3
  import * as i0 from "@angular/core";
3
4
  import * as i1 from "@angular/common";
5
+ /**
6
+ * Componente base de tabla con soporte responsive
7
+ *
8
+ * SIMPLIFICADO: Ya no incluye drag & drop (usar pdm-draggable-table para eso)
9
+ *
10
+ * @example
11
+ * // Tabla simple con scroll horizontal
12
+ * <pdm-table variant="default">
13
+ * <thead><tr><th>Name</th><th>Email</th></tr></thead>
14
+ * <tbody><tr><td>John</td><td>john@example.com</td></tr></tbody>
15
+ * </pdm-table>
16
+ *
17
+ * @example
18
+ * // Tabla interactiva con wrap en mobile
19
+ * <pdm-table variant="interactive" responsiveStrategy="wrap">
20
+ * ...
21
+ * </pdm-table>
22
+ */
4
23
  export class PdmTableComponent {
5
- constructor(renderer) {
6
- this.renderer = renderer;
24
+ constructor() {
25
+ /**
26
+ * Variante visual de la tabla
27
+ * - default: tabla básica sin estilos extra
28
+ * - data: tabla con bordes y espaciado para data
29
+ * - interactive: tabla con hover, sticky header y estilos interactivos
30
+ */
7
31
  this.variant = 'default';
8
- this.reorderRows = false;
9
- this.dragHandleSelector = '[data-drag-handle],[data-slot=row-drag-handle],.row-drag-handle,[data-auto-drag-handle]';
32
+ /**
33
+ * Estrategia responsive para la tabla
34
+ * - scroll: scroll horizontal en mobile (default, más simple)
35
+ * - wrap: permite que el contenido haga wrap
36
+ * - stack: convierte filas en cards en mobile (requiere data-label en celdas)
37
+ * - collapse: oculta columnas menos importantes en mobile
38
+ */
39
+ this.responsiveStrategy = 'scroll';
40
+ /**
41
+ * Clases CSS adicionales para el wrapper
42
+ */
10
43
  this.className = '';
11
- this.rowOrderChange = new EventEmitter();
12
- this.cleanupListeners = [];
13
- this.draggedRow = null;
14
- }
15
- ngAfterViewInit() {
16
- this.syncReorderBehavior();
17
- }
18
- ngOnChanges(changes) {
19
- if (changes['reorderRows'] || changes['variant']) {
20
- this.syncReorderBehavior();
21
- }
22
- }
23
- ngOnDestroy() {
24
- this.cleanupReorderBehavior();
44
+ /**
45
+ * Si es true, aplica padding negativo en mobile para scroll edge-to-edge
46
+ * Útil cuando la tabla está dentro de un container con padding
47
+ */
48
+ this.fullBleed = false;
25
49
  }
26
50
  get wrapperClasses() {
51
+ const baseClasses = ['relative', 'w-full'];
52
+ const strategyClasses = this.getResponsiveStrategyClasses();
53
+ const variantClasses = this.getVariantWrapperClasses();
54
+ // Full bleed: scroll edge-to-edge en mobile
55
+ if (this.fullBleed && this.responsiveStrategy === 'scroll') {
56
+ baseClasses.push('-mx-4', 'px-4', 'sm:mx-0', 'sm:px-0');
57
+ }
27
58
  return [
28
- 'relative w-full overflow-auto',
29
- this.variant === 'interactive' ? 'overflow-x-auto overflow-y-hidden rounded-xl border border-border bg-background' : '',
30
- this.variant === 'data' ? 'overflow-hidden rounded-md border border-border bg-background' : '',
59
+ ...baseClasses,
60
+ ...strategyClasses,
61
+ ...variantClasses,
31
62
  this.className
32
- ];
63
+ ].filter(Boolean);
33
64
  }
34
65
  get tableClasses() {
35
- return [
36
- 'w-full caption-bottom text-sm',
37
- this.variant === 'data'
38
- ? 'border-collapse text-foreground [&_thead_tr]:border-b [&_thead_tr]:border-border [&_tbody_tr]:border-b [&_tbody_tr]:border-border [&_tbody_tr:last-child]:border-b-0 [&_th]:h-10 [&_th]:px-2 [&_th]:text-left [&_th]:align-middle [&_th]:font-medium [&_td]:p-2 [&_td]:align-middle'
39
- : '',
40
- this.variant === 'interactive'
41
- ? 'text-foreground [&_thead]:sticky [&_thead]:top-0 [&_thead]:z-10 [&_thead]:bg-muted/70 [&_thead_tr]:border-b [&_thead_tr]:border-border [&_th]:h-12 [&_th]:px-4 [&_th]:text-left [&_th]:align-middle [&_th]:text-sm [&_th]:font-medium [&_th]:whitespace-nowrap [&_tbody_tr]:border-b [&_tbody_tr]:border-border [&_tbody_tr]:transition-colors [&_tbody_tr:hover]:bg-muted/50 [&_tbody_tr:last-child]:border-b-0 [&_td]:h-14 [&_td]:px-4 [&_td]:align-middle [&_td]:text-sm [&_td]:whitespace-nowrap [&_td:first-child]:w-10 [&_td:last-child]:w-10 [&_svg]:text-muted-foreground'
42
- : ''
43
- ];
44
- }
45
- syncReorderBehavior() {
46
- this.cleanupReorderBehavior();
47
- if (!this.isReorderEnabled) {
48
- return;
49
- }
50
- const tbody = this.getTbody();
51
- if (!tbody) {
52
- return;
53
- }
54
- this.setRowsDraggable(tbody, true);
55
- this.cleanupListeners.push(this.renderer.listen(tbody, 'mousedown', (event) => this.armDragFromHandle(event)), this.renderer.listen(tbody, 'dragstart', (event) => this.onDragStart(event)), this.renderer.listen(tbody, 'dragover', (event) => this.onDragOver(event, tbody)), this.renderer.listen(tbody, 'drop', (event) => this.onDrop(event)), this.renderer.listen(tbody, 'dragend', () => this.onDragEnd()));
56
- this.observer = new MutationObserver(() => this.setRowsDraggable(tbody, true));
57
- this.observer.observe(tbody, { childList: true });
58
- }
59
- cleanupReorderBehavior() {
60
- this.cleanupListeners.forEach((dispose) => dispose());
61
- this.cleanupListeners = [];
62
- if (this.observer) {
63
- this.observer.disconnect();
64
- this.observer = undefined;
65
- }
66
- const tbody = this.getTbody();
67
- if (tbody) {
68
- this.setRowsDraggable(tbody, false);
69
- }
70
- this.draggedRow = null;
71
- }
72
- get isReorderEnabled() {
73
- return this.reorderRows;
74
- }
75
- getTbody() {
76
- return this.tableElement?.nativeElement.tBodies.item(0) ?? null;
77
- }
78
- setRowsDraggable(tbody, enabled) {
79
- const rows = Array.from(tbody.rows);
80
- rows.forEach((row) => {
81
- this.syncAutoDragHandle(row, enabled);
82
- row.draggable = false;
83
- if (!enabled) {
84
- delete row.dataset['dragging'];
85
- delete row.dataset['dragArmed'];
86
- }
87
- });
88
- }
89
- syncAutoDragHandle(row, enabled) {
90
- const firstCell = row.cells.item(0);
91
- if (!firstCell) {
92
- return;
93
- }
94
- const existingAutoHandle = firstCell.querySelector('[data-auto-drag-handle]');
95
- if (!enabled) {
96
- existingAutoHandle?.remove();
97
- return;
98
- }
99
- const hasCustomHandle = !!firstCell.querySelector('[data-drag-handle],[data-slot=row-drag-handle],.row-drag-handle');
100
- if (hasCustomHandle || existingAutoHandle) {
101
- return;
102
- }
103
- const button = this.renderer.createElement('button');
104
- this.renderer.setAttribute(button, 'type', 'button');
105
- this.renderer.setAttribute(button, 'aria-label', 'Drag row');
106
- this.renderer.setAttribute(button, 'data-auto-drag-handle', 'true');
107
- this.renderer.addClass(button, 'inline-flex');
108
- this.renderer.addClass(button, 'h-7');
109
- this.renderer.addClass(button, 'w-7');
110
- this.renderer.addClass(button, 'items-center');
111
- this.renderer.addClass(button, 'justify-center');
112
- this.renderer.addClass(button, 'cursor-grab');
113
- this.renderer.addClass(button, 'active:cursor-grabbing');
114
- this.renderer.addClass(button, 'text-muted-foreground');
115
- const dots = this.renderer.createElement('span');
116
- this.renderer.addClass(dots, 'text-sm');
117
- this.renderer.addClass(dots, 'leading-none');
118
- this.renderer.setProperty(dots, 'textContent', '⋮⋮');
119
- this.renderer.appendChild(button, dots);
120
- this.renderer.insertBefore(firstCell, button, firstCell.firstChild);
121
- }
122
- onDragStart(event) {
123
- const target = event.target;
124
- const row = target?.closest('tr');
125
- if (!row) {
126
- return;
127
- }
128
- const handle = target?.closest(this.dragHandleSelector);
129
- const isArmed = row.dataset['dragArmed'] === 'true';
130
- if ((!handle || !row.contains(handle)) && !isArmed) {
131
- event.preventDefault();
132
- return;
133
- }
134
- this.draggedRow = row;
135
- this.draggedRow.dataset['dragging'] = 'true';
136
- if (event.dataTransfer) {
137
- event.dataTransfer.effectAllowed = 'move';
138
- event.dataTransfer.setData('text/plain', '');
139
- }
140
- }
141
- onDragOver(event, tbody) {
142
- if (!this.draggedRow) {
143
- return;
144
- }
145
- event.preventDefault();
146
- const target = event.target;
147
- const targetRow = target?.closest('tr');
148
- if (!targetRow || targetRow === this.draggedRow) {
149
- return;
150
- }
151
- const rect = targetRow.getBoundingClientRect();
152
- const shouldInsertBefore = event.clientY < rect.top + rect.height / 2;
153
- tbody.insertBefore(this.draggedRow, shouldInsertBefore ? targetRow : targetRow.nextSibling);
154
- }
155
- onDrop(event) {
156
- event.preventDefault();
157
- }
158
- onDragEnd() {
159
- const tbody = this.getTbody();
160
- if (tbody) {
161
- Array.from(tbody.rows).forEach((row) => {
162
- row.draggable = false;
163
- delete row.dataset['dragArmed'];
164
- });
165
- }
166
- if (this.draggedRow) {
167
- delete this.draggedRow.dataset['dragging'];
168
- this.draggedRow = null;
169
- }
170
- if (!tbody) {
171
- return;
172
- }
173
- const order = Array.from(tbody.rows).map((row, index) => row.getAttribute('data-row-id') || String(index));
174
- this.rowOrderChange.emit(order);
175
- }
176
- armDragFromHandle(event) {
177
- const target = event.target;
178
- const handle = target?.closest(this.dragHandleSelector);
179
- if (!handle) {
180
- return;
181
- }
182
- const row = handle.closest('tr');
183
- if (!row) {
184
- return;
185
- }
186
- row.draggable = true;
187
- row.dataset['dragArmed'] = 'true';
66
+ const baseClasses = ['w-full', 'caption-bottom', 'text-sm'];
67
+ const variantClasses = this.getVariantTableClasses();
68
+ const cellClasses = this.getCellClasses();
69
+ return [...baseClasses, ...variantClasses, ...cellClasses].filter(Boolean);
70
+ }
71
+ getResponsiveStrategyClasses() {
72
+ const strategy = TABLE_RESPONSIVE[this.responsiveStrategy];
73
+ if (this.responsiveStrategy === 'scroll') {
74
+ return ['overflow-x-auto'];
75
+ }
76
+ if (this.responsiveStrategy === 'wrap') {
77
+ return ['overflow-x-auto'];
78
+ }
79
+ if (this.responsiveStrategy === 'stack') {
80
+ // Stack requiere lógica en el template, aquí solo el wrapper
81
+ return [];
82
+ }
83
+ if (this.responsiveStrategy === 'collapse') {
84
+ return ['overflow-x-auto'];
85
+ }
86
+ return ['overflow-auto'];
87
+ }
88
+ getVariantWrapperClasses() {
89
+ if (this.variant === 'interactive') {
90
+ return ['rounded-xl', 'border', 'border-border', 'bg-background'];
91
+ }
92
+ if (this.variant === 'data') {
93
+ return ['rounded-md', 'border', 'border-border', 'bg-background'];
94
+ }
95
+ return [];
96
+ }
97
+ getVariantTableClasses() {
98
+ if (this.variant === 'data') {
99
+ return [
100
+ 'border-collapse',
101
+ 'text-foreground',
102
+ '[&_thead_tr]:border-b',
103
+ '[&_thead_tr]:border-border',
104
+ '[&_tbody_tr]:border-b',
105
+ '[&_tbody_tr]:border-border',
106
+ '[&_tbody_tr:last-child]:border-b-0',
107
+ '[&_th]:h-10',
108
+ '[&_th]:px-2',
109
+ '[&_th]:text-left',
110
+ '[&_th]:align-middle',
111
+ '[&_th]:font-medium',
112
+ '[&_td]:p-2',
113
+ '[&_td]:align-middle'
114
+ ];
115
+ }
116
+ if (this.variant === 'interactive') {
117
+ return [
118
+ 'text-foreground',
119
+ '[&_thead]:sticky',
120
+ '[&_thead]:top-0',
121
+ '[&_thead]:z-10',
122
+ '[&_thead]:bg-muted/70',
123
+ '[&_thead_tr]:border-b',
124
+ '[&_thead_tr]:border-border',
125
+ '[&_th]:h-12',
126
+ '[&_th]:px-4',
127
+ '[&_th]:text-left',
128
+ '[&_th]:align-middle',
129
+ '[&_th]:text-sm',
130
+ '[&_th]:font-medium',
131
+ '[&_tbody_tr]:border-b',
132
+ '[&_tbody_tr]:border-border',
133
+ '[&_tbody_tr]:transition-colors',
134
+ '[&_tbody_tr:hover]:bg-muted/50',
135
+ '[&_tbody_tr:last-child]:border-b-0',
136
+ '[&_td]:h-14',
137
+ '[&_td]:px-4',
138
+ '[&_td]:align-middle',
139
+ '[&_td]:text-sm',
140
+ '[&_svg]:text-muted-foreground'
141
+ ];
142
+ }
143
+ return [];
144
+ }
145
+ getCellClasses() {
146
+ // Manejo responsive de whitespace
147
+ if (this.responsiveStrategy === 'scroll') {
148
+ // En scroll, permitir wrap en mobile, nowrap en desktop
149
+ return ['[&_td]:whitespace-normal', '[&_th]:whitespace-normal', 'sm:[&_td]:whitespace-nowrap', 'sm:[&_th]:whitespace-nowrap'];
150
+ }
151
+ if (this.responsiveStrategy === 'wrap') {
152
+ // En wrap, siempre permitir wrap
153
+ return ['[&_td]:whitespace-normal', '[&_td]:break-words', '[&_th]:whitespace-normal'];
154
+ }
155
+ // Default: nowrap (comportamiento anterior para backward compatibility)
156
+ return [];
188
157
  }
189
158
  }
190
- PdmTableComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: PdmTableComponent, deps: [{ token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Component });
191
- PdmTableComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: PdmTableComponent, selector: "pdm-table", inputs: { variant: "variant", reorderRows: "reorderRows", dragHandleSelector: "dragHandleSelector", className: "className" }, outputs: { rowOrderChange: "rowOrderChange" }, viewQueries: [{ propertyName: "tableElement", first: true, predicate: ["tableElement"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "<div [ngClass]=\"wrapperClasses\" [attr.data-slot]=\"variant === 'interactive' ? 'table-container' : null\">\n <table #tableElement [ngClass]=\"tableClasses\" [attr.data-slot]=\"variant === 'interactive' ? 'table' : null\">\n <ng-content></ng-content>\n </table>\n</div>\n", dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
159
+ PdmTableComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: PdmTableComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
160
+ PdmTableComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: PdmTableComponent, selector: "pdm-table", inputs: { variant: "variant", responsiveStrategy: "responsiveStrategy", className: "className", fullBleed: "fullBleed" }, ngImport: i0, template: "<div [ngClass]=\"wrapperClasses\" [attr.data-slot]=\"variant === 'interactive' ? 'table-container' : null\">\n <table #tableElement [ngClass]=\"tableClasses\" [attr.data-slot]=\"variant === 'interactive' ? 'table' : null\">\n <ng-content></ng-content>\n </table>\n</div>\n", dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
192
161
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: PdmTableComponent, decorators: [{
193
162
  type: Component,
194
163
  args: [{ selector: 'pdm-table', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div [ngClass]=\"wrapperClasses\" [attr.data-slot]=\"variant === 'interactive' ? 'table-container' : null\">\n <table #tableElement [ngClass]=\"tableClasses\" [attr.data-slot]=\"variant === 'interactive' ? 'table' : null\">\n <ng-content></ng-content>\n </table>\n</div>\n" }]
195
- }], ctorParameters: function () { return [{ type: i0.Renderer2 }]; }, propDecorators: { variant: [{
164
+ }], propDecorators: { variant: [{
196
165
  type: Input
197
- }], reorderRows: [{
198
- type: Input
199
- }], dragHandleSelector: [{
166
+ }], responsiveStrategy: [{
200
167
  type: Input
201
168
  }], className: [{
202
169
  type: Input
203
- }], rowOrderChange: [{
204
- type: Output
205
- }], tableElement: [{
206
- type: ViewChild,
207
- args: ['tableElement']
170
+ }], fullBleed: [{
171
+ type: Input
208
172
  }] } });
209
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table.component.js","sourceRoot":"","sources":["../../../../../../src/lib/components/table/table.component.ts","../../../../../../src/lib/components/table/table.component.html"],"names":[],"mappings":"AAAA,OAAO,EAEL,uBAAuB,EACvB,SAAS,EAET,YAAY,EACZ,KAAK,EAGL,MAAM,EAGN,SAAS,EACV,MAAM,eAAe,CAAC;;;AASvB,MAAM,OAAO,iBAAiB;IAa5B,YAA6B,QAAmB;QAAnB,aAAQ,GAAR,QAAQ,CAAW;QAZvC,YAAO,GAAoB,SAAS,CAAC;QACrC,gBAAW,GAAG,KAAK,CAAC;QACpB,uBAAkB,GAAG,yFAAyF,CAAC;QAC/G,cAAS,GAAG,EAAE,CAAC;QACd,mBAAc,GAAG,IAAI,YAAY,EAAY,CAAC;QAIhD,qBAAgB,GAAsB,EAAE,CAAC;QAEzC,eAAU,GAA+B,IAAI,CAAC;IAEH,CAAC;IAEpD,eAAe;QACb,IAAI,CAAC,mBAAmB,EAAE,CAAC;IAC7B,CAAC;IAED,WAAW,CAAC,OAAsB;QAChC,IAAI,OAAO,CAAC,aAAa,CAAC,IAAI,OAAO,CAAC,SAAS,CAAC,EAAE;YAChD,IAAI,CAAC,mBAAmB,EAAE,CAAC;SAC5B;IACH,CAAC;IAED,WAAW;QACT,IAAI,CAAC,sBAAsB,EAAE,CAAC;IAChC,CAAC;IAED,IAAI,cAAc;QAChB,OAAO;YACL,+BAA+B;YAC/B,IAAI,CAAC,OAAO,KAAK,aAAa,CAAC,CAAC,CAAC,iFAAiF,CAAC,CAAC,CAAC,EAAE;YACvH,IAAI,CAAC,OAAO,KAAK,MAAM,CAAC,CAAC,CAAC,+DAA+D,CAAC,CAAC,CAAC,EAAE;YAC9F,IAAI,CAAC,SAAS;SACf,CAAC;IACJ,CAAC;IAED,IAAI,YAAY;QACd,OAAO;YACL,+BAA+B;YAC/B,IAAI,CAAC,OAAO,KAAK,MAAM;gBACrB,CAAC,CAAC,qRAAqR;gBACvR,CAAC,CAAC,EAAE;YACN,IAAI,CAAC,OAAO,KAAK,aAAa;gBAC5B,CAAC,CAAC,mjBAAmjB;gBACrjB,CAAC,CAAC,EAAE;SACP,CAAC;IACJ,CAAC;IAEO,mBAAmB;QACzB,IAAI,CAAC,sBAAsB,EAAE,CAAC;QAE9B,IAAI,CAAC,IAAI,CAAC,gBAAgB,EAAE;YAC1B,OAAO;SACR;QAED,MAAM,KAAK,GAAG,IAAI,CAAC,QAAQ,EAAE,CAAC;QAC9B,IAAI,CAAC,KAAK,EAAE;YACV,OAAO;SACR;QAED,IAAI,CAAC,gBAAgB,CAAC,KAAK,EAAE,IAAI,CAAC,CAAC;QAEnC,IAAI,CAAC,gBAAgB,CAAC,IAAI,CACxB,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,KAAK,EAAE,WAAW,EAAE,CAAC,KAAiB,EAAE,EAAE,CAAC,IAAI,CAAC,iBAAiB,CAAC,KAAK,CAAC,CAAC,EAC9F,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,KAAK,EAAE,WAAW,EAAE,CAAC,KAAgB,EAAE,EAAE,CAAC,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC,CAAC,EACvF,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,KAAK,EAAE,UAAU,EAAE,CAAC,KAAgB,EAAE,EAAE,CAAC,IAAI,CAAC,UAAU,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC,EAC5F,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,KAAK,EAAE,MAAM,EAAE,CAAC,KAAgB,EAAE,EAAE,CAAC,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,EAC7E,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,KAAK,EAAE,SAAS,EAAE,GAAG,EAAE,CAAC,IAAI,CAAC,SAAS,EAAE,CAAC,CAC/D,CAAC;QAEF,IAAI,CAAC,QAAQ,GAAG,IAAI,gBAAgB,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,gBAAgB,CAAC,KAAK,EAAE,IAAI,CAAC,CAAC,CAAC;QAC/E,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC,KAAK,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC,CAAC;IACpD,CAAC;IAEO,sBAAsB;QAC5B,IAAI,CAAC,gBAAgB,CAAC,OAAO,CAAC,CAAC,OAAO,EAAE,EAAE,CAAC,OAAO,EAAE,CAAC,CAAC;QACtD,IAAI,CAAC,gBAAgB,GAAG,EAAE,CAAC;QAE3B,IAAI,IAAI,CAAC,QAAQ,EAAE;YACjB,IAAI,CAAC,QAAQ,CAAC,UAAU,EAAE,CAAC;YAC3B,IAAI,CAAC,QAAQ,GAAG,SAAS,CAAC;SAC3B;QAED,MAAM,KAAK,GAAG,IAAI,CAAC,QAAQ,EAAE,CAAC;QAC9B,IAAI,KAAK,EAAE;YACT,IAAI,CAAC,gBAAgB,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;SACrC;QAED,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC;IACzB,CAAC;IAED,IAAY,gBAAgB;QAC1B,OAAO,IAAI,CAAC,WAAW,CAAC;IAC1B,CAAC;IAEO,QAAQ;QACd,OAAO,IAAI,CAAC,YAAY,EAAE,aAAa,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,IAAI,CAAC;IAClE,CAAC;IAEO,gBAAgB,CAAC,KAA8B,EAAE,OAAgB;QACvE,MAAM,IAAI,GAAG,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;QACpC,IAAI,CAAC,OAAO,CAAC,CAAC,GAAG,EAAE,EAAE;YACnB,IAAI,CAAC,kBAAkB,CAAC,GAAG,EAAE,OAAO,CAAC,CAAC;YACtC,GAAG,CAAC,SAAS,GAAG,KAAK,CAAC;YACtB,IAAI,CAAC,OAAO,EAAE;gBACZ,OAAO,GAAG,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC;gBAC/B,OAAO,GAAG,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC;aACjC;QACH,CAAC,CAAC,CAAC;IACL,CAAC;IAEO,kBAAkB,CAAC,GAAwB,EAAE,OAAgB;QACnE,MAAM,SAAS,GAAG,GAAG,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QACpC,IAAI,CAAC,SAAS,EAAE;YACd,OAAO;SACR;QAED,MAAM,kBAAkB,GAAG,SAAS,CAAC,aAAa,CAAC,yBAAyB,CAAC,CAAC;QAC9E,IAAI,CAAC,OAAO,EAAE;YACZ,kBAAkB,EAAE,MAAM,EAAE,CAAC;YAC7B,OAAO;SACR;QAED,MAAM,eAAe,GAAG,CAAC,CAAC,SAAS,CAAC,aAAa,CAAC,iEAAiE,CAAC,CAAC;QACrH,IAAI,eAAe,IAAI,kBAAkB,EAAE;YACzC,OAAO;SACR;QAED,MAAM,MAAM,GAAG,IAAI,CAAC,QAAQ,CAAC,aAAa,CAAC,QAAQ,CAAsB,CAAC;QAC1E,IAAI,CAAC,QAAQ,CAAC,YAAY,CAAC,MAAM,EAAE,MAAM,EAAE,QAAQ,CAAC,CAAC;QACrD,IAAI,CAAC,QAAQ,CAAC,YAAY,CAAC,MAAM,EAAE,YAAY,EAAE,UAAU,CAAC,CAAC;QAC7D,IAAI,CAAC,QAAQ,CAAC,YAAY,CAAC,MAAM,EAAE,uBAAuB,EAAE,MAAM,CAAC,CAAC;QACpE,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,MAAM,EAAE,aAAa,CAAC,CAAC;QAC9C,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,MAAM,EAAE,KAAK,CAAC,CAAC;QACtC,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,MAAM,EAAE,KAAK,CAAC,CAAC;QACtC,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,MAAM,EAAE,cAAc,CAAC,CAAC;QAC/C,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,MAAM,EAAE,gBAAgB,CAAC,CAAC;QACjD,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,MAAM,EAAE,aAAa,CAAC,CAAC;QAC9C,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,MAAM,EAAE,wBAAwB,CAAC,CAAC;QACzD,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,MAAM,EAAE,uBAAuB,CAAC,CAAC;QAExD,MAAM,IAAI,GAAG,IAAI,CAAC,QAAQ,CAAC,aAAa,CAAC,MAAM,CAAC,CAAC;QACjD,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,EAAE,SAAS,CAAC,CAAC;QACxC,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,EAAE,cAAc,CAAC,CAAC;QAC7C,IAAI,CAAC,QAAQ,CAAC,WAAW,CAAC,IAAI,EAAE,aAAa,EAAE,IAAI,CAAC,CAAC;QACrD,IAAI,CAAC,QAAQ,CAAC,WAAW,CAAC,MAAM,EAAE,IAAI,CAAC,CAAC;QAExC,IAAI,CAAC,QAAQ,CAAC,YAAY,CAAC,SAAS,EAAE,MAAM,EAAE,SAAS,CAAC,UAAU,CAAC,CAAC;IACtE,CAAC;IAEO,WAAW,CAAC,KAAgB;QAClC,MAAM,MAAM,GAAG,KAAK,CAAC,MAA4B,CAAC;QAClD,MAAM,GAAG,GAAG,MAAM,EAAE,OAAO,CAAC,IAAI,CAAC,CAAC;QAClC,IAAI,CAAC,GAAG,EAAE;YACR,OAAO;SACR;QAED,MAAM,MAAM,GAAG,MAAM,EAAE,OAAO,CAAC,IAAI,CAAC,kBAAkB,CAAC,CAAC;QACxD,MAAM,OAAO,GAAG,GAAG,CAAC,OAAO,CAAC,WAAW,CAAC,KAAK,MAAM,CAAC;QACpD,IAAI,CAAC,CAAC,MAAM,IAAI,CAAC,GAAG,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,OAAO,EAAE;YAClD,KAAK,CAAC,cAAc,EAAE,CAAC;YACvB,OAAO;SACR;QAED,IAAI,CAAC,UAAU,GAAG,GAA0B,CAAC;QAC7C,IAAI,CAAC,UAAU,CAAC,OAAO,CAAC,UAAU,CAAC,GAAG,MAAM,CAAC;QAE7C,IAAI,KAAK,CAAC,YAAY,EAAE;YACtB,KAAK,CAAC,YAAY,CAAC,aAAa,GAAG,MAAM,CAAC;YAC1C,KAAK,CAAC,YAAY,CAAC,OAAO,CAAC,YAAY,EAAE,EAAE,CAAC,CAAC;SAC9C;IACH,CAAC;IAEO,UAAU,CAAC,KAAgB,EAAE,KAA8B;QACjE,IAAI,CAAC,IAAI,CAAC,UAAU,EAAE;YACpB,OAAO;SACR;QAED,KAAK,CAAC,cAAc,EAAE,CAAC;QACvB,MAAM,MAAM,GAAG,KAAK,CAAC,MAA4B,CAAC;QAClD,MAAM,SAAS,GAAG,MAAM,EAAE,OAAO,CAAC,IAAI,CAA+B,CAAC;QAEtE,IAAI,CAAC,SAAS,IAAI,SAAS,KAAK,IAAI,CAAC,UAAU,EAAE;YAC/C,OAAO;SACR;QAED,MAAM,IAAI,GAAG,SAAS,CAAC,qBAAqB,EAAE,CAAC;QAC/C,MAAM,kBAAkB,GAAG,KAAK,CAAC,OAAO,GAAG,IAAI,CAAC,GAAG,GAAG,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC;QACtE,KAAK,CAAC,YAAY,CAAC,IAAI,CAAC,UAAU,EAAE,kBAAkB,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC,WAAW,CAAC,CAAC;IAC9F,CAAC;IAEO,MAAM,CAAC,KAAgB;QAC7B,KAAK,CAAC,cAAc,EAAE,CAAC;IACzB,CAAC;IAEO,SAAS;QACf,MAAM,KAAK,GAAG,IAAI,CAAC,QAAQ,EAAE,CAAC;QAC9B,IAAI,KAAK,EAAE;YACT,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,OAAO,CAAC,CAAC,GAAG,EAAE,EAAE;gBACrC,GAAG,CAAC,SAAS,GAAG,KAAK,CAAC;gBACtB,OAAO,GAAG,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC;YAClC,CAAC,CAAC,CAAC;SACJ;QAED,IAAI,IAAI,CAAC,UAAU,EAAE;YACnB,OAAO,IAAI,CAAC,UAAU,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC;YAC3C,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC;SACxB;QAED,IAAI,CAAC,KAAK,EAAE;YACV,OAAO;SACR;QAED,MAAM,KAAK,GAAG,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,KAAK,EAAE,EAAE,CAAC,GAAG,CAAC,YAAY,CAAC,aAAa,CAAC,IAAI,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC;QAC3G,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAClC,CAAC;IAEO,iBAAiB,CAAC,KAAiB;QACzC,MAAM,MAAM,GAAG,KAAK,CAAC,MAA4B,CAAC;QAClD,MAAM,MAAM,GAAG,MAAM,EAAE,OAAO,CAAC,IAAI,CAAC,kBAAkB,CAAC,CAAC;QACxD,IAAI,CAAC,MAAM,EAAE;YACX,OAAO;SACR;QAED,MAAM,GAAG,GAAG,MAAM,CAAC,OAAO,CAAC,IAAI,CAA+B,CAAC;QAC/D,IAAI,CAAC,GAAG,EAAE;YACR,OAAO;SACR;QAED,GAAG,CAAC,SAAS,GAAG,IAAI,CAAC;QACrB,GAAG,CAAC,OAAO,CAAC,WAAW,CAAC,GAAG,MAAM,CAAC;IACpC,CAAC;;8GAzOU,iBAAiB;kGAAjB,iBAAiB,iWCtB9B,uRAKA;2FDiBa,iBAAiB;kBAL7B,SAAS;+BACE,WAAW,mBAEJ,uBAAuB,CAAC,MAAM;gGAGtC,OAAO;sBAAf,KAAK;gBACG,WAAW;sBAAnB,KAAK;gBACG,kBAAkB;sBAA1B,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBACI,cAAc;sBAAvB,MAAM;gBAEoB,YAAY;sBAAtC,SAAS;uBAAC,cAAc","sourcesContent":["import {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  Component,\n  ElementRef,\n  EventEmitter,\n  Input,\n  OnChanges,\n  OnDestroy,\n  Output,\n  Renderer2,\n  SimpleChanges,\n  ViewChild\n} from '@angular/core';\n\nexport type PdmTableVariant = 'default' | 'data' | 'interactive';\n\n@Component({\n  selector: 'pdm-table',\n  templateUrl: './table.component.html',\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class PdmTableComponent {\n  @Input() variant: PdmTableVariant = 'default';\n  @Input() reorderRows = false;\n  @Input() dragHandleSelector = '[data-drag-handle],[data-slot=row-drag-handle],.row-drag-handle,[data-auto-drag-handle]';\n  @Input() className = '';\n  @Output() rowOrderChange = new EventEmitter<string[]>();\n\n  @ViewChild('tableElement') tableElement?: ElementRef<HTMLTableElement>;\n\n  private cleanupListeners: Array<() => void> = [];\n  private observer?: MutationObserver;\n  private draggedRow: HTMLTableRowElement | null = null;\n\n  constructor(private readonly renderer: Renderer2) {}\n\n  ngAfterViewInit(): void {\n    this.syncReorderBehavior();\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes['reorderRows'] || changes['variant']) {\n      this.syncReorderBehavior();\n    }\n  }\n\n  ngOnDestroy(): void {\n    this.cleanupReorderBehavior();\n  }\n\n  get wrapperClasses(): string[] {\n    return [\n      'relative w-full overflow-auto',\n      this.variant === 'interactive' ? 'overflow-x-auto overflow-y-hidden rounded-xl border border-border bg-background' : '',\n      this.variant === 'data' ? 'overflow-hidden rounded-md border border-border bg-background' : '',\n      this.className\n    ];\n  }\n\n  get tableClasses(): string[] {\n    return [\n      'w-full caption-bottom text-sm',\n      this.variant === 'data'\n        ? 'border-collapse text-foreground [&_thead_tr]:border-b [&_thead_tr]:border-border [&_tbody_tr]:border-b [&_tbody_tr]:border-border [&_tbody_tr:last-child]:border-b-0 [&_th]:h-10 [&_th]:px-2 [&_th]:text-left [&_th]:align-middle [&_th]:font-medium [&_td]:p-2 [&_td]:align-middle'\n        : '',\n      this.variant === 'interactive'\n        ? 'text-foreground [&_thead]:sticky [&_thead]:top-0 [&_thead]:z-10 [&_thead]:bg-muted/70 [&_thead_tr]:border-b [&_thead_tr]:border-border [&_th]:h-12 [&_th]:px-4 [&_th]:text-left [&_th]:align-middle [&_th]:text-sm [&_th]:font-medium [&_th]:whitespace-nowrap [&_tbody_tr]:border-b [&_tbody_tr]:border-border [&_tbody_tr]:transition-colors [&_tbody_tr:hover]:bg-muted/50 [&_tbody_tr:last-child]:border-b-0 [&_td]:h-14 [&_td]:px-4 [&_td]:align-middle [&_td]:text-sm [&_td]:whitespace-nowrap [&_td:first-child]:w-10 [&_td:last-child]:w-10 [&_svg]:text-muted-foreground'\n        : ''\n    ];\n  }\n\n  private syncReorderBehavior(): void {\n    this.cleanupReorderBehavior();\n\n    if (!this.isReorderEnabled) {\n      return;\n    }\n\n    const tbody = this.getTbody();\n    if (!tbody) {\n      return;\n    }\n\n    this.setRowsDraggable(tbody, true);\n\n    this.cleanupListeners.push(\n      this.renderer.listen(tbody, 'mousedown', (event: MouseEvent) => this.armDragFromHandle(event)),\n      this.renderer.listen(tbody, 'dragstart', (event: DragEvent) => this.onDragStart(event)),\n      this.renderer.listen(tbody, 'dragover', (event: DragEvent) => this.onDragOver(event, tbody)),\n      this.renderer.listen(tbody, 'drop', (event: DragEvent) => this.onDrop(event)),\n      this.renderer.listen(tbody, 'dragend', () => this.onDragEnd())\n    );\n\n    this.observer = new MutationObserver(() => this.setRowsDraggable(tbody, true));\n    this.observer.observe(tbody, { childList: true });\n  }\n\n  private cleanupReorderBehavior(): void {\n    this.cleanupListeners.forEach((dispose) => dispose());\n    this.cleanupListeners = [];\n\n    if (this.observer) {\n      this.observer.disconnect();\n      this.observer = undefined;\n    }\n\n    const tbody = this.getTbody();\n    if (tbody) {\n      this.setRowsDraggable(tbody, false);\n    }\n\n    this.draggedRow = null;\n  }\n\n  private get isReorderEnabled(): boolean {\n    return this.reorderRows;\n  }\n\n  private getTbody(): HTMLTableSectionElement | null {\n    return this.tableElement?.nativeElement.tBodies.item(0) ?? null;\n  }\n\n  private setRowsDraggable(tbody: HTMLTableSectionElement, enabled: boolean): void {\n    const rows = Array.from(tbody.rows);\n    rows.forEach((row) => {\n      this.syncAutoDragHandle(row, enabled);\n      row.draggable = false;\n      if (!enabled) {\n        delete row.dataset['dragging'];\n        delete row.dataset['dragArmed'];\n      }\n    });\n  }\n\n  private syncAutoDragHandle(row: HTMLTableRowElement, enabled: boolean): void {\n    const firstCell = row.cells.item(0);\n    if (!firstCell) {\n      return;\n    }\n\n    const existingAutoHandle = firstCell.querySelector('[data-auto-drag-handle]');\n    if (!enabled) {\n      existingAutoHandle?.remove();\n      return;\n    }\n\n    const hasCustomHandle = !!firstCell.querySelector('[data-drag-handle],[data-slot=row-drag-handle],.row-drag-handle');\n    if (hasCustomHandle || existingAutoHandle) {\n      return;\n    }\n\n    const button = this.renderer.createElement('button') as HTMLButtonElement;\n    this.renderer.setAttribute(button, 'type', 'button');\n    this.renderer.setAttribute(button, 'aria-label', 'Drag row');\n    this.renderer.setAttribute(button, 'data-auto-drag-handle', 'true');\n    this.renderer.addClass(button, 'inline-flex');\n    this.renderer.addClass(button, 'h-7');\n    this.renderer.addClass(button, 'w-7');\n    this.renderer.addClass(button, 'items-center');\n    this.renderer.addClass(button, 'justify-center');\n    this.renderer.addClass(button, 'cursor-grab');\n    this.renderer.addClass(button, 'active:cursor-grabbing');\n    this.renderer.addClass(button, 'text-muted-foreground');\n\n    const dots = this.renderer.createElement('span');\n    this.renderer.addClass(dots, 'text-sm');\n    this.renderer.addClass(dots, 'leading-none');\n    this.renderer.setProperty(dots, 'textContent', '⋮⋮');\n    this.renderer.appendChild(button, dots);\n\n    this.renderer.insertBefore(firstCell, button, firstCell.firstChild);\n  }\n\n  private onDragStart(event: DragEvent): void {\n    const target = event.target as HTMLElement | null;\n    const row = target?.closest('tr');\n    if (!row) {\n      return;\n    }\n\n    const handle = target?.closest(this.dragHandleSelector);\n    const isArmed = row.dataset['dragArmed'] === 'true';\n    if ((!handle || !row.contains(handle)) && !isArmed) {\n      event.preventDefault();\n      return;\n    }\n\n    this.draggedRow = row as HTMLTableRowElement;\n    this.draggedRow.dataset['dragging'] = 'true';\n\n    if (event.dataTransfer) {\n      event.dataTransfer.effectAllowed = 'move';\n      event.dataTransfer.setData('text/plain', '');\n    }\n  }\n\n  private onDragOver(event: DragEvent, tbody: HTMLTableSectionElement): void {\n    if (!this.draggedRow) {\n      return;\n    }\n\n    event.preventDefault();\n    const target = event.target as HTMLElement | null;\n    const targetRow = target?.closest('tr') as HTMLTableRowElement | null;\n\n    if (!targetRow || targetRow === this.draggedRow) {\n      return;\n    }\n\n    const rect = targetRow.getBoundingClientRect();\n    const shouldInsertBefore = event.clientY < rect.top + rect.height / 2;\n    tbody.insertBefore(this.draggedRow, shouldInsertBefore ? targetRow : targetRow.nextSibling);\n  }\n\n  private onDrop(event: DragEvent): void {\n    event.preventDefault();\n  }\n\n  private onDragEnd(): void {\n    const tbody = this.getTbody();\n    if (tbody) {\n      Array.from(tbody.rows).forEach((row) => {\n        row.draggable = false;\n        delete row.dataset['dragArmed'];\n      });\n    }\n\n    if (this.draggedRow) {\n      delete this.draggedRow.dataset['dragging'];\n      this.draggedRow = null;\n    }\n\n    if (!tbody) {\n      return;\n    }\n\n    const order = Array.from(tbody.rows).map((row, index) => row.getAttribute('data-row-id') || String(index));\n    this.rowOrderChange.emit(order);\n  }\n\n  private armDragFromHandle(event: MouseEvent): void {\n    const target = event.target as HTMLElement | null;\n    const handle = target?.closest(this.dragHandleSelector);\n    if (!handle) {\n      return;\n    }\n\n    const row = handle.closest('tr') as HTMLTableRowElement | null;\n    if (!row) {\n      return;\n    }\n\n    row.draggable = true;\n    row.dataset['dragArmed'] = 'true';\n  }\n}\n","<div [ngClass]=\"wrapperClasses\" [attr.data-slot]=\"variant === 'interactive' ? 'table-container' : null\">\n  <table #tableElement [ngClass]=\"tableClasses\" [attr.data-slot]=\"variant === 'interactive' ? 'table' : null\">\n    <ng-content></ng-content>\n  </table>\n</div>\n"]}
173
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table.component.js","sourceRoot":"","sources":["../../../../../../src/lib/components/table/table.component.ts","../../../../../../src/lib/components/table/table.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,uBAAuB,EAAE,SAAS,EAAE,KAAK,EAAE,MAAM,eAAe,CAAC;AAC1E,OAAO,EAA2B,gBAAgB,EAAE,MAAM,wBAAwB,CAAC;;;AAInF;;;;;;;;;;;;;;;;;GAiBG;AAMH,MAAM,OAAO,iBAAiB;IAL9B;QAME;;;;;WAKG;QACM,YAAO,GAAoB,SAAS,CAAC;QAE9C;;;;;;WAMG;QACM,uBAAkB,GAA4B,QAAQ,CAAC;QAEhE;;WAEG;QACM,cAAS,GAAG,EAAE,CAAC;QAExB;;;WAGG;QACM,cAAS,GAAG,KAAK,CAAC;KAiI5B;IA/HC,IAAI,cAAc;QAChB,MAAM,WAAW,GAAG,CAAC,UAAU,EAAE,QAAQ,CAAC,CAAC;QAC3C,MAAM,eAAe,GAAG,IAAI,CAAC,4BAA4B,EAAE,CAAC;QAC5D,MAAM,cAAc,GAAG,IAAI,CAAC,wBAAwB,EAAE,CAAC;QAEvD,4CAA4C;QAC5C,IAAI,IAAI,CAAC,SAAS,IAAI,IAAI,CAAC,kBAAkB,KAAK,QAAQ,EAAE;YAC1D,WAAW,CAAC,IAAI,CAAC,OAAO,EAAE,MAAM,EAAE,SAAS,EAAE,SAAS,CAAC,CAAC;SACzD;QAED,OAAO;YACL,GAAG,WAAW;YACd,GAAG,eAAe;YAClB,GAAG,cAAc;YACjB,IAAI,CAAC,SAAS;SACf,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC;IACpB,CAAC;IAED,IAAI,YAAY;QACd,MAAM,WAAW,GAAG,CAAC,QAAQ,EAAE,gBAAgB,EAAE,SAAS,CAAC,CAAC;QAC5D,MAAM,cAAc,GAAG,IAAI,CAAC,sBAAsB,EAAE,CAAC;QACrD,MAAM,WAAW,GAAG,IAAI,CAAC,cAAc,EAAE,CAAC;QAE1C,OAAO,CAAC,GAAG,WAAW,EAAE,GAAG,cAAc,EAAE,GAAG,WAAW,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC;IAC7E,CAAC;IAEO,4BAA4B;QAClC,MAAM,QAAQ,GAAG,gBAAgB,CAAC,IAAI,CAAC,kBAAkB,CAAC,CAAC;QAE3D,IAAI,IAAI,CAAC,kBAAkB,KAAK,QAAQ,EAAE;YACxC,OAAO,CAAC,iBAAiB,CAAC,CAAC;SAC5B;QAED,IAAI,IAAI,CAAC,kBAAkB,KAAK,MAAM,EAAE;YACtC,OAAO,CAAC,iBAAiB,CAAC,CAAC;SAC5B;QAED,IAAI,IAAI,CAAC,kBAAkB,KAAK,OAAO,EAAE;YACvC,6DAA6D;YAC7D,OAAO,EAAE,CAAC;SACX;QAED,IAAI,IAAI,CAAC,kBAAkB,KAAK,UAAU,EAAE;YAC1C,OAAO,CAAC,iBAAiB,CAAC,CAAC;SAC5B;QAED,OAAO,CAAC,eAAe,CAAC,CAAC;IAC3B,CAAC;IAEO,wBAAwB;QAC9B,IAAI,IAAI,CAAC,OAAO,KAAK,aAAa,EAAE;YAClC,OAAO,CAAC,YAAY,EAAE,QAAQ,EAAE,eAAe,EAAE,eAAe,CAAC,CAAC;SACnE;QAED,IAAI,IAAI,CAAC,OAAO,KAAK,MAAM,EAAE;YAC3B,OAAO,CAAC,YAAY,EAAE,QAAQ,EAAE,eAAe,EAAE,eAAe,CAAC,CAAC;SACnE;QAED,OAAO,EAAE,CAAC;IACZ,CAAC;IAEO,sBAAsB;QAC5B,IAAI,IAAI,CAAC,OAAO,KAAK,MAAM,EAAE;YAC3B,OAAO;gBACL,iBAAiB;gBACjB,iBAAiB;gBACjB,uBAAuB;gBACvB,4BAA4B;gBAC5B,uBAAuB;gBACvB,4BAA4B;gBAC5B,oCAAoC;gBACpC,aAAa;gBACb,aAAa;gBACb,kBAAkB;gBAClB,qBAAqB;gBACrB,oBAAoB;gBACpB,YAAY;gBACZ,qBAAqB;aACtB,CAAC;SACH;QAED,IAAI,IAAI,CAAC,OAAO,KAAK,aAAa,EAAE;YAClC,OAAO;gBACL,iBAAiB;gBACjB,kBAAkB;gBAClB,iBAAiB;gBACjB,gBAAgB;gBAChB,uBAAuB;gBACvB,uBAAuB;gBACvB,4BAA4B;gBAC5B,aAAa;gBACb,aAAa;gBACb,kBAAkB;gBAClB,qBAAqB;gBACrB,gBAAgB;gBAChB,oBAAoB;gBACpB,uBAAuB;gBACvB,4BAA4B;gBAC5B,gCAAgC;gBAChC,gCAAgC;gBAChC,oCAAoC;gBACpC,aAAa;gBACb,aAAa;gBACb,qBAAqB;gBACrB,gBAAgB;gBAChB,+BAA+B;aAChC,CAAC;SACH;QAED,OAAO,EAAE,CAAC;IACZ,CAAC;IAEO,cAAc;QACpB,kCAAkC;QAClC,IAAI,IAAI,CAAC,kBAAkB,KAAK,QAAQ,EAAE;YACxC,wDAAwD;YACxD,OAAO,CAAC,0BAA0B,EAAE,0BAA0B,EAAE,6BAA6B,EAAE,6BAA6B,CAAC,CAAC;SAC/H;QAED,IAAI,IAAI,CAAC,kBAAkB,KAAK,MAAM,EAAE;YACtC,iCAAiC;YACjC,OAAO,CAAC,0BAA0B,EAAE,oBAAoB,EAAE,0BAA0B,CAAC,CAAC;SACvF;QAED,wEAAwE;QACxE,OAAO,EAAE,CAAC;IACZ,CAAC;;8GA3JU,iBAAiB;kGAAjB,iBAAiB,2KC5B9B,uRAKA;2FDuBa,iBAAiB;kBAL7B,SAAS;+BACE,WAAW,mBAEJ,uBAAuB,CAAC,MAAM;8BAStC,OAAO;sBAAf,KAAK;gBASG,kBAAkB;sBAA1B,KAAK;gBAKG,SAAS;sBAAjB,KAAK;gBAMG,SAAS;sBAAjB,KAAK","sourcesContent":["import { ChangeDetectionStrategy, Component, Input } from '@angular/core';\nimport { TableResponsiveStrategy, TABLE_RESPONSIVE } from '../../utils/responsive';\n\nexport type PdmTableVariant = 'default' | 'data' | 'interactive';\n\n/**\n * Componente base de tabla con soporte responsive\n * \n * SIMPLIFICADO: Ya no incluye drag & drop (usar pdm-draggable-table para eso)\n * \n * @example\n * // Tabla simple con scroll horizontal\n * <pdm-table variant=\"default\">\n *   <thead><tr><th>Name</th><th>Email</th></tr></thead>\n *   <tbody><tr><td>John</td><td>john@example.com</td></tr></tbody>\n * </pdm-table>\n * \n * @example\n * // Tabla interactiva con wrap en mobile\n * <pdm-table variant=\"interactive\" responsiveStrategy=\"wrap\">\n *   ...\n * </pdm-table>\n */\n@Component({\n  selector: 'pdm-table',\n  templateUrl: './table.component.html',\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class PdmTableComponent {\n  /**\n   * Variante visual de la tabla\n   * - default: tabla básica sin estilos extra\n   * - data: tabla con bordes y espaciado para data\n   * - interactive: tabla con hover, sticky header y estilos interactivos\n   */\n  @Input() variant: PdmTableVariant = 'default';\n  \n  /**\n   * Estrategia responsive para la tabla\n   * - scroll: scroll horizontal en mobile (default, más simple)\n   * - wrap: permite que el contenido haga wrap\n   * - stack: convierte filas en cards en mobile (requiere data-label en celdas)\n   * - collapse: oculta columnas menos importantes en mobile\n   */\n  @Input() responsiveStrategy: TableResponsiveStrategy = 'scroll';\n  \n  /**\n   * Clases CSS adicionales para el wrapper\n   */\n  @Input() className = '';\n  \n  /**\n   * Si es true, aplica padding negativo en mobile para scroll edge-to-edge\n   * Útil cuando la tabla está dentro de un container con padding\n   */\n  @Input() fullBleed = false;\n\n  get wrapperClasses(): string[] {\n    const baseClasses = ['relative', 'w-full'];\n    const strategyClasses = this.getResponsiveStrategyClasses();\n    const variantClasses = this.getVariantWrapperClasses();\n    \n    // Full bleed: scroll edge-to-edge en mobile\n    if (this.fullBleed && this.responsiveStrategy === 'scroll') {\n      baseClasses.push('-mx-4', 'px-4', 'sm:mx-0', 'sm:px-0');\n    }\n    \n    return [\n      ...baseClasses,\n      ...strategyClasses,\n      ...variantClasses,\n      this.className\n    ].filter(Boolean);\n  }\n\n  get tableClasses(): string[] {\n    const baseClasses = ['w-full', 'caption-bottom', 'text-sm'];\n    const variantClasses = this.getVariantTableClasses();\n    const cellClasses = this.getCellClasses();\n    \n    return [...baseClasses, ...variantClasses, ...cellClasses].filter(Boolean);\n  }\n\n  private getResponsiveStrategyClasses(): string[] {\n    const strategy = TABLE_RESPONSIVE[this.responsiveStrategy];\n    \n    if (this.responsiveStrategy === 'scroll') {\n      return ['overflow-x-auto'];\n    }\n    \n    if (this.responsiveStrategy === 'wrap') {\n      return ['overflow-x-auto'];\n    }\n    \n    if (this.responsiveStrategy === 'stack') {\n      // Stack requiere lógica en el template, aquí solo el wrapper\n      return [];\n    }\n    \n    if (this.responsiveStrategy === 'collapse') {\n      return ['overflow-x-auto'];\n    }\n    \n    return ['overflow-auto'];\n  }\n\n  private getVariantWrapperClasses(): string[] {\n    if (this.variant === 'interactive') {\n      return ['rounded-xl', 'border', 'border-border', 'bg-background'];\n    }\n    \n    if (this.variant === 'data') {\n      return ['rounded-md', 'border', 'border-border', 'bg-background'];\n    }\n    \n    return [];\n  }\n\n  private getVariantTableClasses(): string[] {\n    if (this.variant === 'data') {\n      return [\n        'border-collapse',\n        'text-foreground',\n        '[&_thead_tr]:border-b',\n        '[&_thead_tr]:border-border',\n        '[&_tbody_tr]:border-b',\n        '[&_tbody_tr]:border-border',\n        '[&_tbody_tr:last-child]:border-b-0',\n        '[&_th]:h-10',\n        '[&_th]:px-2',\n        '[&_th]:text-left',\n        '[&_th]:align-middle',\n        '[&_th]:font-medium',\n        '[&_td]:p-2',\n        '[&_td]:align-middle'\n      ];\n    }\n    \n    if (this.variant === 'interactive') {\n      return [\n        'text-foreground',\n        '[&_thead]:sticky',\n        '[&_thead]:top-0',\n        '[&_thead]:z-10',\n        '[&_thead]:bg-muted/70',\n        '[&_thead_tr]:border-b',\n        '[&_thead_tr]:border-border',\n        '[&_th]:h-12',\n        '[&_th]:px-4',\n        '[&_th]:text-left',\n        '[&_th]:align-middle',\n        '[&_th]:text-sm',\n        '[&_th]:font-medium',\n        '[&_tbody_tr]:border-b',\n        '[&_tbody_tr]:border-border',\n        '[&_tbody_tr]:transition-colors',\n        '[&_tbody_tr:hover]:bg-muted/50',\n        '[&_tbody_tr:last-child]:border-b-0',\n        '[&_td]:h-14',\n        '[&_td]:px-4',\n        '[&_td]:align-middle',\n        '[&_td]:text-sm',\n        '[&_svg]:text-muted-foreground'\n      ];\n    }\n    \n    return [];\n  }\n\n  private getCellClasses(): string[] {\n    // Manejo responsive de whitespace\n    if (this.responsiveStrategy === 'scroll') {\n      // En scroll, permitir wrap en mobile, nowrap en desktop\n      return ['[&_td]:whitespace-normal', '[&_th]:whitespace-normal', 'sm:[&_td]:whitespace-nowrap', 'sm:[&_th]:whitespace-nowrap'];\n    }\n    \n    if (this.responsiveStrategy === 'wrap') {\n      // En wrap, siempre permitir wrap\n      return ['[&_td]:whitespace-normal', '[&_td]:break-words', '[&_th]:whitespace-normal'];\n    }\n    \n    // Default: nowrap (comportamiento anterior para backward compatibility)\n    return [];\n  }\n}\n","<div [ngClass]=\"wrapperClasses\" [attr.data-slot]=\"variant === 'interactive' ? 'table-container' : null\">\n  <table #tableElement [ngClass]=\"tableClasses\" [attr.data-slot]=\"variant === 'interactive' ? 'table' : null\">\n    <ng-content></ng-content>\n  </table>\n</div>\n"]}
@@ -18,10 +18,10 @@ export class PdmTabsComponent {
18
18
  }
19
19
  }
20
20
  PdmTabsComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: PdmTabsComponent, deps: [{ token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
21
- PdmTabsComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: PdmTabsComponent, selector: "pdm-tabs", inputs: { items: "items", value: "value", className: "className" }, outputs: { valueChange: "valueChange" }, ngImport: i0, template: "<div [ngClass]=\"['w-full', className]\">\n <div role=\"tablist\" class=\"inline-flex h-8 w-fit items-center justify-center rounded-lg bg-muted p-[3px] text-muted-foreground\">\n <button\n *ngFor=\"let item of items\"\n role=\"tab\"\n [attr.aria-selected]=\"value === item.value\"\n [disabled]=\"item.disabled\"\n [ngClass]=\"[\n 'relative inline-flex h-[calc(100%-1px)] appearance-none flex-1 items-center justify-center gap-1.5 whitespace-nowrap rounded-md border border-transparent px-1.5 py-0.5 text-sm font-medium transition-all focus-visible:border-ring focus-visible:outline-none focus-visible:outline-ring focus-visible:ring-[3px] focus-visible:ring-ring/50 disabled:pointer-events-none disabled:opacity-50',\n value === item.value ? 'bg-background text-foreground shadow-sm' : 'bg-transparent text-muted-foreground'\n ]\"\n (click)=\"select(item)\"\n type=\"button\"\n >\n {{ item.label }}\n </button>\n </div>\n <div class=\"mt-4\">\n <ng-content></ng-content>\n </div>\n</div>\n", dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
21
+ PdmTabsComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: PdmTabsComponent, selector: "pdm-tabs", inputs: { items: "items", value: "value", className: "className" }, outputs: { valueChange: "valueChange" }, ngImport: i0, template: "<div [ngClass]=\"['w-full', className]\">\n <div\n role=\"tablist\"\n class=\"inline-flex h-8 w-full items-center overflow-x-auto scrollbar-thin rounded-lg bg-muted p-[3px] text-muted-foreground md:w-fit\"\n >\n <button\n *ngFor=\"let item of items\"\n role=\"tab\"\n [attr.aria-selected]=\"value === item.value\"\n [disabled]=\"item.disabled\"\n [ngClass]=\"[\n 'relative inline-flex h-[calc(100%-1px)] appearance-none flex-1 items-center justify-center gap-1.5 whitespace-nowrap rounded-md border border-transparent px-3 py-0.5 text-sm font-medium transition-all focus-visible:border-ring focus-visible:outline-none focus-visible:outline-ring focus-visible:ring-[3px] focus-visible:ring-ring/50 disabled:pointer-events-none disabled:opacity-50 md:flex-initial md:px-4',\n value === item.value ? 'bg-background text-foreground shadow-sm' : 'bg-transparent text-muted-foreground'\n ]\"\n (click)=\"select(item)\"\n type=\"button\"\n >\n {{ item.label }}\n </button>\n </div>\n <div class=\"mt-4\">\n <ng-content></ng-content>\n </div>\n</div>\n", dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
22
22
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: PdmTabsComponent, decorators: [{
23
23
  type: Component,
24
- args: [{ selector: 'pdm-tabs', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div [ngClass]=\"['w-full', className]\">\n <div role=\"tablist\" class=\"inline-flex h-8 w-fit items-center justify-center rounded-lg bg-muted p-[3px] text-muted-foreground\">\n <button\n *ngFor=\"let item of items\"\n role=\"tab\"\n [attr.aria-selected]=\"value === item.value\"\n [disabled]=\"item.disabled\"\n [ngClass]=\"[\n 'relative inline-flex h-[calc(100%-1px)] appearance-none flex-1 items-center justify-center gap-1.5 whitespace-nowrap rounded-md border border-transparent px-1.5 py-0.5 text-sm font-medium transition-all focus-visible:border-ring focus-visible:outline-none focus-visible:outline-ring focus-visible:ring-[3px] focus-visible:ring-ring/50 disabled:pointer-events-none disabled:opacity-50',\n value === item.value ? 'bg-background text-foreground shadow-sm' : 'bg-transparent text-muted-foreground'\n ]\"\n (click)=\"select(item)\"\n type=\"button\"\n >\n {{ item.label }}\n </button>\n </div>\n <div class=\"mt-4\">\n <ng-content></ng-content>\n </div>\n</div>\n" }]
24
+ args: [{ selector: 'pdm-tabs', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div [ngClass]=\"['w-full', className]\">\n <div\n role=\"tablist\"\n class=\"inline-flex h-8 w-full items-center overflow-x-auto scrollbar-thin rounded-lg bg-muted p-[3px] text-muted-foreground md:w-fit\"\n >\n <button\n *ngFor=\"let item of items\"\n role=\"tab\"\n [attr.aria-selected]=\"value === item.value\"\n [disabled]=\"item.disabled\"\n [ngClass]=\"[\n 'relative inline-flex h-[calc(100%-1px)] appearance-none flex-1 items-center justify-center gap-1.5 whitespace-nowrap rounded-md border border-transparent px-3 py-0.5 text-sm font-medium transition-all focus-visible:border-ring focus-visible:outline-none focus-visible:outline-ring focus-visible:ring-[3px] focus-visible:ring-ring/50 disabled:pointer-events-none disabled:opacity-50 md:flex-initial md:px-4',\n value === item.value ? 'bg-background text-foreground shadow-sm' : 'bg-transparent text-muted-foreground'\n ]\"\n (click)=\"select(item)\"\n type=\"button\"\n >\n {{ item.label }}\n </button>\n </div>\n <div class=\"mt-4\">\n <ng-content></ng-content>\n </div>\n</div>\n" }]
25
25
  }], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }]; }, propDecorators: { items: [{
26
26
  type: Input
27
27
  }], value: [{
@@ -31,4 +31,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
31
31
  }], valueChange: [{
32
32
  type: Output
33
33
  }] } });
34
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFicy5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9zcmMvbGliL2NvbXBvbmVudHMvdGFicy90YWJzLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uL3NyYy9saWIvY29tcG9uZW50cy90YWJzL3RhYnMuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLHVCQUF1QixFQUFxQixTQUFTLEVBQUUsWUFBWSxFQUFFLEtBQUssRUFBRSxNQUFNLEVBQUUsTUFBTSxlQUFlLENBQUM7OztBQWFuSCxNQUFNLE9BQU8sZ0JBQWdCO0lBQzNCLFlBQTZCLEdBQXNCO1FBQXRCLFFBQUcsR0FBSCxHQUFHLENBQW1CO1FBRTFDLFVBQUssR0FBaUIsRUFBRSxDQUFDO1FBQ3pCLFVBQUssR0FBRyxFQUFFLENBQUM7UUFDWCxjQUFTLEdBQUcsRUFBRSxDQUFDO1FBRWQsZ0JBQVcsR0FBRyxJQUFJLFlBQVksRUFBVSxDQUFDO0lBTkcsQ0FBQztJQVF2RCxNQUFNLENBQUMsSUFBZ0I7UUFDckIsSUFBSSxDQUFDLElBQUksQ0FBQyxRQUFRLEVBQUU7WUFDbEIsSUFBSSxDQUFDLEtBQUssR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDO1lBQ3hCLElBQUksQ0FBQyxXQUFXLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQztZQUNsQyxJQUFJLENBQUMsR0FBRyxDQUFDLFlBQVksRUFBRSxDQUFDO1NBQ3pCO0lBQ0gsQ0FBQzs7NkdBZlUsZ0JBQWdCO2lHQUFoQixnQkFBZ0IsNkpDYjdCLDBpQ0FxQkE7MkZEUmEsZ0JBQWdCO2tCQUw1QixTQUFTOytCQUNFLFVBQVUsbUJBRUgsdUJBQXVCLENBQUMsTUFBTTt3R0FLdEMsS0FBSztzQkFBYixLQUFLO2dCQUNHLEtBQUs7c0JBQWIsS0FBSztnQkFDRyxTQUFTO3NCQUFqQixLQUFLO2dCQUVJLFdBQVc7c0JBQXBCLE1BQU0iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSwgQ2hhbmdlRGV0ZWN0b3JSZWYsIENvbXBvbmVudCwgRXZlbnRFbWl0dGVyLCBJbnB1dCwgT3V0cHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgUGRtVGFiSXRlbSB7XG4gIGxhYmVsOiBzdHJpbmc7XG4gIHZhbHVlOiBzdHJpbmc7XG4gIGRpc2FibGVkPzogYm9vbGVhbjtcbn1cblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAncGRtLXRhYnMnLFxuICB0ZW1wbGF0ZVVybDogJy4vdGFicy5jb21wb25lbnQuaHRtbCcsXG4gIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoXG59KVxuZXhwb3J0IGNsYXNzIFBkbVRhYnNDb21wb25lbnQge1xuICBjb25zdHJ1Y3Rvcihwcml2YXRlIHJlYWRvbmx5IGNkcjogQ2hhbmdlRGV0ZWN0b3JSZWYpIHt9XG5cbiAgQElucHV0KCkgaXRlbXM6IFBkbVRhYkl0ZW1bXSA9IFtdO1xuICBASW5wdXQoKSB2YWx1ZSA9ICcnO1xuICBASW5wdXQoKSBjbGFzc05hbWUgPSAnJztcblxuICBAT3V0cHV0KCkgdmFsdWVDaGFuZ2UgPSBuZXcgRXZlbnRFbWl0dGVyPHN0cmluZz4oKTtcblxuICBzZWxlY3QoaXRlbTogUGRtVGFiSXRlbSk6IHZvaWQge1xuICAgIGlmICghaXRlbS5kaXNhYmxlZCkge1xuICAgICAgdGhpcy52YWx1ZSA9IGl0ZW0udmFsdWU7XG4gICAgICB0aGlzLnZhbHVlQ2hhbmdlLmVtaXQoaXRlbS52YWx1ZSk7XG4gICAgICB0aGlzLmNkci5tYXJrRm9yQ2hlY2soKTtcbiAgICB9XG4gIH1cbn1cbiIsIjxkaXYgW25nQ2xhc3NdPVwiWyd3LWZ1bGwnLCBjbGFzc05hbWVdXCI+XG4gIDxkaXYgcm9sZT1cInRhYmxpc3RcIiBjbGFzcz1cImlubGluZS1mbGV4IGgtOCB3LWZpdCBpdGVtcy1jZW50ZXIganVzdGlmeS1jZW50ZXIgcm91bmRlZC1sZyBiZy1tdXRlZCBwLVszcHhdIHRleHQtbXV0ZWQtZm9yZWdyb3VuZFwiPlxuICAgIDxidXR0b25cbiAgICAgICpuZ0Zvcj1cImxldCBpdGVtIG9mIGl0ZW1zXCJcbiAgICAgIHJvbGU9XCJ0YWJcIlxuICAgICAgW2F0dHIuYXJpYS1zZWxlY3RlZF09XCJ2YWx1ZSA9PT0gaXRlbS52YWx1ZVwiXG4gICAgICBbZGlzYWJsZWRdPVwiaXRlbS5kaXNhYmxlZFwiXG4gICAgICBbbmdDbGFzc109XCJbXG4gICAgICAgICdyZWxhdGl2ZSBpbmxpbmUtZmxleCBoLVtjYWxjKDEwMCUtMXB4KV0gYXBwZWFyYW5jZS1ub25lIGZsZXgtMSBpdGVtcy1jZW50ZXIganVzdGlmeS1jZW50ZXIgZ2FwLTEuNSB3aGl0ZXNwYWNlLW5vd3JhcCByb3VuZGVkLW1kIGJvcmRlciBib3JkZXItdHJhbnNwYXJlbnQgcHgtMS41IHB5LTAuNSB0ZXh0LXNtIGZvbnQtbWVkaXVtIHRyYW5zaXRpb24tYWxsIGZvY3VzLXZpc2libGU6Ym9yZGVyLXJpbmcgZm9jdXMtdmlzaWJsZTpvdXRsaW5lLW5vbmUgZm9jdXMtdmlzaWJsZTpvdXRsaW5lLXJpbmcgZm9jdXMtdmlzaWJsZTpyaW5nLVszcHhdIGZvY3VzLXZpc2libGU6cmluZy1yaW5nLzUwIGRpc2FibGVkOnBvaW50ZXItZXZlbnRzLW5vbmUgZGlzYWJsZWQ6b3BhY2l0eS01MCcsXG4gICAgICAgIHZhbHVlID09PSBpdGVtLnZhbHVlID8gJ2JnLWJhY2tncm91bmQgdGV4dC1mb3JlZ3JvdW5kIHNoYWRvdy1zbScgOiAnYmctdHJhbnNwYXJlbnQgdGV4dC1tdXRlZC1mb3JlZ3JvdW5kJ1xuICAgICAgXVwiXG4gICAgICAoY2xpY2spPVwic2VsZWN0KGl0ZW0pXCJcbiAgICAgIHR5cGU9XCJidXR0b25cIlxuICAgID5cbiAgICAgIHt7IGl0ZW0ubGFiZWwgfX1cbiAgICA8L2J1dHRvbj5cbiAgPC9kaXY+XG4gIDxkaXYgY2xhc3M9XCJtdC00XCI+XG4gICAgPG5nLWNvbnRlbnQ+PC9uZy1jb250ZW50PlxuICA8L2Rpdj5cbjwvZGl2PlxuIl19
34
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFicy5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9zcmMvbGliL2NvbXBvbmVudHMvdGFicy90YWJzLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uL3NyYy9saWIvY29tcG9uZW50cy90YWJzL3RhYnMuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLHVCQUF1QixFQUFxQixTQUFTLEVBQUUsWUFBWSxFQUFFLEtBQUssRUFBRSxNQUFNLEVBQUUsTUFBTSxlQUFlLENBQUM7OztBQWFuSCxNQUFNLE9BQU8sZ0JBQWdCO0lBQzNCLFlBQTZCLEdBQXNCO1FBQXRCLFFBQUcsR0FBSCxHQUFHLENBQW1CO1FBRTFDLFVBQUssR0FBaUIsRUFBRSxDQUFDO1FBQ3pCLFVBQUssR0FBRyxFQUFFLENBQUM7UUFDWCxjQUFTLEdBQUcsRUFBRSxDQUFDO1FBRWQsZ0JBQVcsR0FBRyxJQUFJLFlBQVksRUFBVSxDQUFDO0lBTkcsQ0FBQztJQVF2RCxNQUFNLENBQUMsSUFBZ0I7UUFDckIsSUFBSSxDQUFDLElBQUksQ0FBQyxRQUFRLEVBQUU7WUFDbEIsSUFBSSxDQUFDLEtBQUssR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDO1lBQ3hCLElBQUksQ0FBQyxXQUFXLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQztZQUNsQyxJQUFJLENBQUMsR0FBRyxDQUFDLFlBQVksRUFBRSxDQUFDO1NBQ3pCO0lBQ0gsQ0FBQzs7NkdBZlUsZ0JBQWdCO2lHQUFoQixnQkFBZ0IsNkpDYjdCLHdtQ0F3QkE7MkZEWGEsZ0JBQWdCO2tCQUw1QixTQUFTOytCQUNFLFVBQVUsbUJBRUgsdUJBQXVCLENBQUMsTUFBTTt3R0FLdEMsS0FBSztzQkFBYixLQUFLO2dCQUNHLEtBQUs7c0JBQWIsS0FBSztnQkFDRyxTQUFTO3NCQUFqQixLQUFLO2dCQUVJLFdBQVc7c0JBQXBCLE1BQU0iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSwgQ2hhbmdlRGV0ZWN0b3JSZWYsIENvbXBvbmVudCwgRXZlbnRFbWl0dGVyLCBJbnB1dCwgT3V0cHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgUGRtVGFiSXRlbSB7XG4gIGxhYmVsOiBzdHJpbmc7XG4gIHZhbHVlOiBzdHJpbmc7XG4gIGRpc2FibGVkPzogYm9vbGVhbjtcbn1cblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAncGRtLXRhYnMnLFxuICB0ZW1wbGF0ZVVybDogJy4vdGFicy5jb21wb25lbnQuaHRtbCcsXG4gIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoXG59KVxuZXhwb3J0IGNsYXNzIFBkbVRhYnNDb21wb25lbnQge1xuICBjb25zdHJ1Y3Rvcihwcml2YXRlIHJlYWRvbmx5IGNkcjogQ2hhbmdlRGV0ZWN0b3JSZWYpIHt9XG5cbiAgQElucHV0KCkgaXRlbXM6IFBkbVRhYkl0ZW1bXSA9IFtdO1xuICBASW5wdXQoKSB2YWx1ZSA9ICcnO1xuICBASW5wdXQoKSBjbGFzc05hbWUgPSAnJztcblxuICBAT3V0cHV0KCkgdmFsdWVDaGFuZ2UgPSBuZXcgRXZlbnRFbWl0dGVyPHN0cmluZz4oKTtcblxuICBzZWxlY3QoaXRlbTogUGRtVGFiSXRlbSk6IHZvaWQge1xuICAgIGlmICghaXRlbS5kaXNhYmxlZCkge1xuICAgICAgdGhpcy52YWx1ZSA9IGl0ZW0udmFsdWU7XG4gICAgICB0aGlzLnZhbHVlQ2hhbmdlLmVtaXQoaXRlbS52YWx1ZSk7XG4gICAgICB0aGlzLmNkci5tYXJrRm9yQ2hlY2soKTtcbiAgICB9XG4gIH1cbn1cbiIsIjxkaXYgW25nQ2xhc3NdPVwiWyd3LWZ1bGwnLCBjbGFzc05hbWVdXCI+XG4gIDxkaXZcbiAgICByb2xlPVwidGFibGlzdFwiXG4gICAgY2xhc3M9XCJpbmxpbmUtZmxleCBoLTggdy1mdWxsIGl0ZW1zLWNlbnRlciBvdmVyZmxvdy14LWF1dG8gc2Nyb2xsYmFyLXRoaW4gcm91bmRlZC1sZyBiZy1tdXRlZCBwLVszcHhdIHRleHQtbXV0ZWQtZm9yZWdyb3VuZCBtZDp3LWZpdFwiXG4gID5cbiAgICA8YnV0dG9uXG4gICAgICAqbmdGb3I9XCJsZXQgaXRlbSBvZiBpdGVtc1wiXG4gICAgICByb2xlPVwidGFiXCJcbiAgICAgIFthdHRyLmFyaWEtc2VsZWN0ZWRdPVwidmFsdWUgPT09IGl0ZW0udmFsdWVcIlxuICAgICAgW2Rpc2FibGVkXT1cIml0ZW0uZGlzYWJsZWRcIlxuICAgICAgW25nQ2xhc3NdPVwiW1xuICAgICAgICAncmVsYXRpdmUgaW5saW5lLWZsZXggaC1bY2FsYygxMDAlLTFweCldIGFwcGVhcmFuY2Utbm9uZSBmbGV4LTEgaXRlbXMtY2VudGVyIGp1c3RpZnktY2VudGVyIGdhcC0xLjUgd2hpdGVzcGFjZS1ub3dyYXAgcm91bmRlZC1tZCBib3JkZXIgYm9yZGVyLXRyYW5zcGFyZW50IHB4LTMgcHktMC41IHRleHQtc20gZm9udC1tZWRpdW0gdHJhbnNpdGlvbi1hbGwgZm9jdXMtdmlzaWJsZTpib3JkZXItcmluZyBmb2N1cy12aXNpYmxlOm91dGxpbmUtbm9uZSBmb2N1cy12aXNpYmxlOm91dGxpbmUtcmluZyBmb2N1cy12aXNpYmxlOnJpbmctWzNweF0gZm9jdXMtdmlzaWJsZTpyaW5nLXJpbmcvNTAgZGlzYWJsZWQ6cG9pbnRlci1ldmVudHMtbm9uZSBkaXNhYmxlZDpvcGFjaXR5LTUwIG1kOmZsZXgtaW5pdGlhbCBtZDpweC00JyxcbiAgICAgICAgdmFsdWUgPT09IGl0ZW0udmFsdWUgPyAnYmctYmFja2dyb3VuZCB0ZXh0LWZvcmVncm91bmQgc2hhZG93LXNtJyA6ICdiZy10cmFuc3BhcmVudCB0ZXh0LW11dGVkLWZvcmVncm91bmQnXG4gICAgICBdXCJcbiAgICAgIChjbGljayk9XCJzZWxlY3QoaXRlbSlcIlxuICAgICAgdHlwZT1cImJ1dHRvblwiXG4gICAgPlxuICAgICAge3sgaXRlbS5sYWJlbCB9fVxuICAgIDwvYnV0dG9uPlxuICA8L2Rpdj5cbiAgPGRpdiBjbGFzcz1cIm10LTRcIj5cbiAgICA8bmctY29udGVudD48L25nLWNvbnRlbnQ+XG4gIDwvZGl2PlxuPC9kaXY+XG4iXX0=
@@ -19,10 +19,10 @@ export class PdmTooltipComponent {
19
19
  }
20
20
  }
21
21
  PdmTooltipComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: PdmTooltipComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
22
- PdmTooltipComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: PdmTooltipComponent, selector: "pdm-tooltip", inputs: { text: "text", side: "side", className: "className" }, ngImport: i0, template: "<span class=\"relative inline-flex\" [ngClass]=\"className\" (mouseenter)=\"open = true\" (mouseleave)=\"open = false\" (focusin)=\"open = true\" (focusout)=\"open = false\">\n <ng-content></ng-content>\n <span *ngIf=\"open\" [ngClass]=\"['pointer-events-none absolute z-50 overflow-hidden rounded-md bg-foreground px-3 py-1.5 text-xs text-background animate-in fade-in-0 zoom-in-95', positionClass]\">\n {{ text }}\n </span>\n</span>\n", dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
22
+ PdmTooltipComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: PdmTooltipComponent, selector: "pdm-tooltip", inputs: { text: "text", side: "side", className: "className" }, ngImport: i0, template: "<span class=\"relative inline-flex\" [ngClass]=\"className\" (mouseenter)=\"open = true\" (mouseleave)=\"open = false\" (focusin)=\"open = true\" (focusout)=\"open = false\">\n <ng-content></ng-content>\n <span *ngIf=\"open\" [ngClass]=\"['pointer-events-none absolute z-[70] overflow-hidden rounded-md bg-foreground px-3 py-1.5 text-xs text-background animate-in fade-in-0 zoom-in-95', positionClass]\">\n {{ text }}\n </span>\n</span>\n", dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
23
23
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: PdmTooltipComponent, decorators: [{
24
24
  type: Component,
25
- args: [{ selector: 'pdm-tooltip', changeDetection: ChangeDetectionStrategy.OnPush, template: "<span class=\"relative inline-flex\" [ngClass]=\"className\" (mouseenter)=\"open = true\" (mouseleave)=\"open = false\" (focusin)=\"open = true\" (focusout)=\"open = false\">\n <ng-content></ng-content>\n <span *ngIf=\"open\" [ngClass]=\"['pointer-events-none absolute z-50 overflow-hidden rounded-md bg-foreground px-3 py-1.5 text-xs text-background animate-in fade-in-0 zoom-in-95', positionClass]\">\n {{ text }}\n </span>\n</span>\n" }]
25
+ args: [{ selector: 'pdm-tooltip', changeDetection: ChangeDetectionStrategy.OnPush, template: "<span class=\"relative inline-flex\" [ngClass]=\"className\" (mouseenter)=\"open = true\" (mouseleave)=\"open = false\" (focusin)=\"open = true\" (focusout)=\"open = false\">\n <ng-content></ng-content>\n <span *ngIf=\"open\" [ngClass]=\"['pointer-events-none absolute z-[70] overflow-hidden rounded-md bg-foreground px-3 py-1.5 text-xs text-background animate-in fade-in-0 zoom-in-95', positionClass]\">\n {{ text }}\n </span>\n</span>\n" }]
26
26
  }], propDecorators: { text: [{
27
27
  type: Input
28
28
  }], side: [{
@@ -30,4 +30,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
30
30
  }], className: [{
31
31
  type: Input
32
32
  }] } });
33
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidG9vbHRpcC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9zcmMvbGliL2NvbXBvbmVudHMvdG9vbHRpcC90b29sdGlwLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uL3NyYy9saWIvY29tcG9uZW50cy90b29sdGlwL3Rvb2x0aXAuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLHVCQUF1QixFQUFFLFNBQVMsRUFBRSxLQUFLLEVBQUUsTUFBTSxlQUFlLENBQUM7OztBQU8xRSxNQUFNLE9BQU8sbUJBQW1CO0lBTGhDO1FBTVcsU0FBSSxHQUFHLEVBQUUsQ0FBQztRQUNWLFNBQUksR0FBd0MsS0FBSyxDQUFDO1FBQ2xELGNBQVMsR0FBRyxFQUFFLENBQUM7UUFDeEIsU0FBSSxHQUFHLEtBQUssQ0FBQztLQVFkO0lBTkMsSUFBSSxhQUFhO1FBQ2YsSUFBSSxJQUFJLENBQUMsSUFBSSxLQUFLLFFBQVE7WUFBRSxPQUFPLHlDQUF5QyxDQUFDO1FBQzdFLElBQUksSUFBSSxDQUFDLElBQUksS0FBSyxNQUFNO1lBQUUsT0FBTywwQ0FBMEMsQ0FBQztRQUM1RSxJQUFJLElBQUksQ0FBQyxJQUFJLEtBQUssT0FBTztZQUFFLE9BQU8seUNBQXlDLENBQUM7UUFDNUUsT0FBTyw0Q0FBNEMsQ0FBQztJQUN0RCxDQUFDOztnSEFYVSxtQkFBbUI7b0dBQW5CLG1CQUFtQixtSENQaEMsNGJBTUE7MkZEQ2EsbUJBQW1CO2tCQUwvQixTQUFTOytCQUNFLGFBQWEsbUJBRU4sdUJBQXVCLENBQUMsTUFBTTs4QkFHdEMsSUFBSTtzQkFBWixLQUFLO2dCQUNHLElBQUk7c0JBQVosS0FBSztnQkFDRyxTQUFTO3NCQUFqQixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIENvbXBvbmVudCwgSW5wdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAncGRtLXRvb2x0aXAnLFxuICB0ZW1wbGF0ZVVybDogJy4vdG9vbHRpcC5jb21wb25lbnQuaHRtbCcsXG4gIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoXG59KVxuZXhwb3J0IGNsYXNzIFBkbVRvb2x0aXBDb21wb25lbnQge1xuICBASW5wdXQoKSB0ZXh0ID0gJyc7XG4gIEBJbnB1dCgpIHNpZGU6ICd0b3AnIHwgJ3JpZ2h0JyB8ICdib3R0b20nIHwgJ2xlZnQnID0gJ3RvcCc7XG4gIEBJbnB1dCgpIGNsYXNzTmFtZSA9ICcnO1xuICBvcGVuID0gZmFsc2U7XG5cbiAgZ2V0IHBvc2l0aW9uQ2xhc3MoKTogc3RyaW5nIHtcbiAgICBpZiAodGhpcy5zaWRlID09PSAnYm90dG9tJykgcmV0dXJuICd0b3AtZnVsbCBsZWZ0LTEvMiAtdHJhbnNsYXRlLXgtMS8yIG10LTInO1xuICAgIGlmICh0aGlzLnNpZGUgPT09ICdsZWZ0JykgcmV0dXJuICdyaWdodC1mdWxsIHRvcC0xLzIgLXRyYW5zbGF0ZS15LTEvMiBtci0yJztcbiAgICBpZiAodGhpcy5zaWRlID09PSAncmlnaHQnKSByZXR1cm4gJ2xlZnQtZnVsbCB0b3AtMS8yIC10cmFuc2xhdGUteS0xLzIgbWwtMic7XG4gICAgcmV0dXJuICdib3R0b20tZnVsbCBsZWZ0LTEvMiAtdHJhbnNsYXRlLXgtMS8yIG1iLTInO1xuICB9XG59XG4iLCI8c3BhbiBjbGFzcz1cInJlbGF0aXZlIGlubGluZS1mbGV4XCIgW25nQ2xhc3NdPVwiY2xhc3NOYW1lXCIgKG1vdXNlZW50ZXIpPVwib3BlbiA9IHRydWVcIiAobW91c2VsZWF2ZSk9XCJvcGVuID0gZmFsc2VcIiAoZm9jdXNpbik9XCJvcGVuID0gdHJ1ZVwiIChmb2N1c291dCk9XCJvcGVuID0gZmFsc2VcIj5cbiAgPG5nLWNvbnRlbnQ+PC9uZy1jb250ZW50PlxuICA8c3BhbiAqbmdJZj1cIm9wZW5cIiBbbmdDbGFzc109XCJbJ3BvaW50ZXItZXZlbnRzLW5vbmUgYWJzb2x1dGUgei01MCBvdmVyZmxvdy1oaWRkZW4gcm91bmRlZC1tZCBiZy1mb3JlZ3JvdW5kIHB4LTMgcHktMS41IHRleHQteHMgdGV4dC1iYWNrZ3JvdW5kIGFuaW1hdGUtaW4gZmFkZS1pbi0wIHpvb20taW4tOTUnLCBwb3NpdGlvbkNsYXNzXVwiPlxuICAgIHt7IHRleHQgfX1cbiAgPC9zcGFuPlxuPC9zcGFuPlxuIl19
33
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidG9vbHRpcC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9zcmMvbGliL2NvbXBvbmVudHMvdG9vbHRpcC90b29sdGlwLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uL3NyYy9saWIvY29tcG9uZW50cy90b29sdGlwL3Rvb2x0aXAuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLHVCQUF1QixFQUFFLFNBQVMsRUFBRSxLQUFLLEVBQUUsTUFBTSxlQUFlLENBQUM7OztBQU8xRSxNQUFNLE9BQU8sbUJBQW1CO0lBTGhDO1FBTVcsU0FBSSxHQUFHLEVBQUUsQ0FBQztRQUNWLFNBQUksR0FBd0MsS0FBSyxDQUFDO1FBQ2xELGNBQVMsR0FBRyxFQUFFLENBQUM7UUFDeEIsU0FBSSxHQUFHLEtBQUssQ0FBQztLQVFkO0lBTkMsSUFBSSxhQUFhO1FBQ2YsSUFBSSxJQUFJLENBQUMsSUFBSSxLQUFLLFFBQVE7WUFBRSxPQUFPLHlDQUF5QyxDQUFDO1FBQzdFLElBQUksSUFBSSxDQUFDLElBQUksS0FBSyxNQUFNO1lBQUUsT0FBTywwQ0FBMEMsQ0FBQztRQUM1RSxJQUFJLElBQUksQ0FBQyxJQUFJLEtBQUssT0FBTztZQUFFLE9BQU8seUNBQXlDLENBQUM7UUFDNUUsT0FBTyw0Q0FBNEMsQ0FBQztJQUN0RCxDQUFDOztnSEFYVSxtQkFBbUI7b0dBQW5CLG1CQUFtQixtSENQaEMsOGJBTUE7MkZEQ2EsbUJBQW1CO2tCQUwvQixTQUFTOytCQUNFLGFBQWEsbUJBRU4sdUJBQXVCLENBQUMsTUFBTTs4QkFHdEMsSUFBSTtzQkFBWixLQUFLO2dCQUNHLElBQUk7c0JBQVosS0FBSztnQkFDRyxTQUFTO3NCQUFqQixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIENvbXBvbmVudCwgSW5wdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAncGRtLXRvb2x0aXAnLFxuICB0ZW1wbGF0ZVVybDogJy4vdG9vbHRpcC5jb21wb25lbnQuaHRtbCcsXG4gIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoXG59KVxuZXhwb3J0IGNsYXNzIFBkbVRvb2x0aXBDb21wb25lbnQge1xuICBASW5wdXQoKSB0ZXh0ID0gJyc7XG4gIEBJbnB1dCgpIHNpZGU6ICd0b3AnIHwgJ3JpZ2h0JyB8ICdib3R0b20nIHwgJ2xlZnQnID0gJ3RvcCc7XG4gIEBJbnB1dCgpIGNsYXNzTmFtZSA9ICcnO1xuICBvcGVuID0gZmFsc2U7XG5cbiAgZ2V0IHBvc2l0aW9uQ2xhc3MoKTogc3RyaW5nIHtcbiAgICBpZiAodGhpcy5zaWRlID09PSAnYm90dG9tJykgcmV0dXJuICd0b3AtZnVsbCBsZWZ0LTEvMiAtdHJhbnNsYXRlLXgtMS8yIG10LTInO1xuICAgIGlmICh0aGlzLnNpZGUgPT09ICdsZWZ0JykgcmV0dXJuICdyaWdodC1mdWxsIHRvcC0xLzIgLXRyYW5zbGF0ZS15LTEvMiBtci0yJztcbiAgICBpZiAodGhpcy5zaWRlID09PSAncmlnaHQnKSByZXR1cm4gJ2xlZnQtZnVsbCB0b3AtMS8yIC10cmFuc2xhdGUteS0xLzIgbWwtMic7XG4gICAgcmV0dXJuICdib3R0b20tZnVsbCBsZWZ0LTEvMiAtdHJhbnNsYXRlLXgtMS8yIG1iLTInO1xuICB9XG59XG4iLCI8c3BhbiBjbGFzcz1cInJlbGF0aXZlIGlubGluZS1mbGV4XCIgW25nQ2xhc3NdPVwiY2xhc3NOYW1lXCIgKG1vdXNlZW50ZXIpPVwib3BlbiA9IHRydWVcIiAobW91c2VsZWF2ZSk9XCJvcGVuID0gZmFsc2VcIiAoZm9jdXNpbik9XCJvcGVuID0gdHJ1ZVwiIChmb2N1c291dCk9XCJvcGVuID0gZmFsc2VcIj5cbiAgPG5nLWNvbnRlbnQ+PC9uZy1jb250ZW50PlxuICA8c3BhbiAqbmdJZj1cIm9wZW5cIiBbbmdDbGFzc109XCJbJ3BvaW50ZXItZXZlbnRzLW5vbmUgYWJzb2x1dGUgei1bNzBdIG92ZXJmbG93LWhpZGRlbiByb3VuZGVkLW1kIGJnLWZvcmVncm91bmQgcHgtMyBweS0xLjUgdGV4dC14cyB0ZXh0LWJhY2tncm91bmQgYW5pbWF0ZS1pbiBmYWRlLWluLTAgem9vbS1pbi05NScsIHBvc2l0aW9uQ2xhc3NdXCI+XG4gICAge3sgdGV4dCB9fVxuICA8L3NwYW4+XG48L3NwYW4+XG4iXX0=