@frame-ui-ng/components 0.3.0-beta.0 → 0.4.0-beta.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.
- package/button/src/styles/button.css +5 -1
- package/button-group/src/styles/button-group.css +6 -0
- package/fesm2022/frame-ui-ng-components-combobox.mjs +48 -51
- package/fesm2022/frame-ui-ng-components-combobox.mjs.map +1 -1
- package/fesm2022/frame-ui-ng-components-confirm-modal.mjs +162 -0
- package/fesm2022/frame-ui-ng-components-confirm-modal.mjs.map +1 -0
- package/fesm2022/frame-ui-ng-components-dropdown-menu.mjs +1 -1
- package/fesm2022/frame-ui-ng-components-dropdown-menu.mjs.map +1 -1
- package/fesm2022/frame-ui-ng-components-input-otp.mjs +64 -69
- package/fesm2022/frame-ui-ng-components-input-otp.mjs.map +1 -1
- package/fesm2022/frame-ui-ng-components-modal.mjs +93 -15
- package/fesm2022/frame-ui-ng-components-modal.mjs.map +1 -1
- package/fesm2022/frame-ui-ng-components-pagination.mjs +37 -36
- package/fesm2022/frame-ui-ng-components-pagination.mjs.map +1 -1
- package/fesm2022/frame-ui-ng-components-progress.mjs +2 -1
- package/fesm2022/frame-ui-ng-components-progress.mjs.map +1 -1
- package/fesm2022/frame-ui-ng-components-resizable.mjs +16 -26
- package/fesm2022/frame-ui-ng-components-resizable.mjs.map +1 -1
- package/fesm2022/frame-ui-ng-components-sheet.mjs +19 -16
- package/fesm2022/frame-ui-ng-components-sheet.mjs.map +1 -1
- package/fesm2022/frame-ui-ng-components-sidebar.mjs +19 -13
- package/fesm2022/frame-ui-ng-components-sidebar.mjs.map +1 -1
- package/fesm2022/frame-ui-ng-components-slider.mjs +53 -59
- package/fesm2022/frame-ui-ng-components-slider.mjs.map +1 -1
- package/fesm2022/frame-ui-ng-components-tooltip.mjs +44 -0
- package/fesm2022/frame-ui-ng-components-tooltip.mjs.map +1 -1
- package/fesm2022/frame-ui-ng-components-utils.mjs +20 -0
- package/fesm2022/frame-ui-ng-components-utils.mjs.map +1 -0
- package/fesm2022/frame-ui-ng-components-virtual-scroll.mjs +10 -12
- package/fesm2022/frame-ui-ng-components-virtual-scroll.mjs.map +1 -1
- package/fesm2022/frame-ui-ng-components.mjs +353 -296
- package/fesm2022/frame-ui-ng-components.mjs.map +1 -1
- package/item/src/styles/item.css +188 -187
- package/modal/src/styles/modal.css +10 -1
- package/package.json +10 -2
- package/sidebar/src/styles/sidebar.css +10 -4
- package/src/styles/blueprint.css +98 -0
- package/src/styles/components.css +4 -4
- package/styles/blueprint.css +98 -0
- package/styles/components.css +4 -4
- package/styles.css +4 -4
- package/tooltip/src/styles/tooltip.css +4 -4
- package/types/frame-ui-ng-components-combobox.d.ts +1 -1
- package/types/frame-ui-ng-components-confirm-modal.d.ts +48 -0
- package/types/frame-ui-ng-components-input-otp.d.ts +1 -1
- package/types/frame-ui-ng-components-modal.d.ts +18 -7
- package/types/frame-ui-ng-components-sheet.d.ts +2 -0
- package/types/frame-ui-ng-components-sidebar.d.ts +2 -2
- package/types/frame-ui-ng-components-tooltip.d.ts +5 -0
- package/types/frame-ui-ng-components-utils.d.ts +5 -0
- package/types/frame-ui-ng-components.d.ts +68 -55
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"frame-ui-ng-components-progress.mjs","sources":["../../../projects/components/progress/src/progress.ts","../../../projects/components/progress/progress.module.ts","../../../projects/components/progress/frame-ui-ng-components-progress.ts"],"sourcesContent":["import { Directive, computed, input } from '@angular/core';\n\nfunction coerceProgressValue(value: unknown): number | null {\n if (value === null || value === undefined || value === '') {\n return null;\n }\n\n const parsed = Number(value);\n return Number.isFinite(parsed) ? parsed : null;\n}\n\nfunction coerceProgressMax(value: unknown): number {\n const parsed = Number(value);\n return Number.isFinite(parsed) && parsed > 0 ? parsed : 100;\n}\n\n@Directive({\n selector: '[frProgress], frame-progress',\n exportAs: 'frProgress',\n host: {\n class: 'frame-progress',\n role: 'progressbar',\n '[attr.aria-valuemin]': 'isIndeterminate() ? null : 0',\n '[attr.aria-valuemax]': 'isIndeterminate() ? null : max()',\n '[attr.aria-valuenow]': 'isIndeterminate() ? null : normalizedValue()',\n '[attr.data-state]': 'state()',\n '[attr.data-value]': 'isIndeterminate() ? null : normalizedValue()',\n '[attr.data-max]': 'isIndeterminate() ? null : max()',\n '[style.--frame-progress-value]': 'isIndeterminate() ? null : normalizedValue()',\n '[style.--frame-progress-max]': 'isIndeterminate() ? null : max()',\n '[style.--frame-progress-percent]': 'isIndeterminate() ? null : percentage() + \"%\"',\n },\n})\nexport class FrProgress {\n readonly value = input<number | null, unknown>(0, { transform: coerceProgressValue });\n readonly max = input<number, unknown>(100, { transform: coerceProgressMax });\n\n readonly isIndeterminate = computed(() => this.value() === null);\n\n readonly normalizedValue = computed(() => {\n const value = this.value();\n\n if (value === null) {\n return 0;\n }\n\n return
|
|
1
|
+
{"version":3,"file":"frame-ui-ng-components-progress.mjs","sources":["../../../projects/components/progress/src/progress.ts","../../../projects/components/progress/progress.module.ts","../../../projects/components/progress/frame-ui-ng-components-progress.ts"],"sourcesContent":["import { Directive, computed, input } from '@angular/core';\r\nimport { clampNumber } from '@frame-ui-ng/components/utils';\r\n\r\nfunction coerceProgressValue(value: unknown): number | null {\r\n if (value === null || value === undefined || value === '') {\r\n return null;\r\n }\r\n\r\n const parsed = Number(value);\r\n return Number.isFinite(parsed) ? parsed : null;\r\n}\r\n\r\nfunction coerceProgressMax(value: unknown): number {\r\n const parsed = Number(value);\r\n return Number.isFinite(parsed) && parsed > 0 ? parsed : 100;\r\n}\r\n\r\n@Directive({\r\n selector: '[frProgress], frame-progress',\r\n exportAs: 'frProgress',\r\n host: {\r\n class: 'frame-progress',\r\n role: 'progressbar',\r\n '[attr.aria-valuemin]': 'isIndeterminate() ? null : 0',\r\n '[attr.aria-valuemax]': 'isIndeterminate() ? null : max()',\r\n '[attr.aria-valuenow]': 'isIndeterminate() ? null : normalizedValue()',\r\n '[attr.data-state]': 'state()',\r\n '[attr.data-value]': 'isIndeterminate() ? null : normalizedValue()',\r\n '[attr.data-max]': 'isIndeterminate() ? null : max()',\r\n '[style.--frame-progress-value]': 'isIndeterminate() ? null : normalizedValue()',\r\n '[style.--frame-progress-max]': 'isIndeterminate() ? null : max()',\r\n '[style.--frame-progress-percent]': 'isIndeterminate() ? null : percentage() + \"%\"',\r\n },\r\n})\r\nexport class FrProgress {\r\n readonly value = input<number | null, unknown>(0, { transform: coerceProgressValue });\r\n readonly max = input<number, unknown>(100, { transform: coerceProgressMax });\r\n\r\n readonly isIndeterminate = computed(() => this.value() === null);\r\n\r\n readonly normalizedValue = computed(() => {\r\n const value = this.value();\r\n\r\n if (value === null) {\r\n return 0;\r\n }\r\n\r\n return clampNumber(value, 0, this.max());\r\n });\r\n\r\n readonly percentage = computed(() => (this.normalizedValue() / this.max()) * 100);\r\n\r\n readonly state = computed(() => {\r\n if (this.isIndeterminate()) {\r\n return 'indeterminate';\r\n }\r\n\r\n return this.normalizedValue() >= this.max() ? 'complete' : 'loading';\r\n });\r\n}\r\n\r\n@Directive({\r\n selector: '[frProgressIndicator], frame-progress-indicator',\r\n host: {\r\n class: 'frame-progress__indicator',\r\n },\r\n})\r\nexport class FrProgressIndicator {}\r\n","import { NgModule } from '@angular/core';\nimport {\n FrProgress,\n FrProgressIndicator,\n} from './src/progress';\n\n@NgModule({\n imports: [\n FrProgress,\n FrProgressIndicator,\n ],\n exports: [\n FrProgress,\n FrProgressIndicator,\n ],\n})\nexport class FrProgressModule {}\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './public-api';\n"],"names":[],"mappings":"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"}
|
|
@@ -1,15 +1,9 @@
|
|
|
1
1
|
import * as i0 from '@angular/core';
|
|
2
|
-
import { inject, ElementRef, input, booleanAttribute, output, Directive,
|
|
2
|
+
import { inject, ElementRef, input, booleanAttribute, output, Directive, NgModule } from '@angular/core';
|
|
3
|
+
import { clampNumber, coerceNumber } from '@frame-ui-ng/components/utils';
|
|
3
4
|
|
|
4
5
|
const FR_RESIZABLE_ORIENTATIONS = ['horizontal', 'vertical'];
|
|
5
6
|
let nextResizableId = 0;
|
|
6
|
-
function coerceSize(value, fallback) {
|
|
7
|
-
const parsed = Number(value);
|
|
8
|
-
return Number.isFinite(parsed) ? parsed : fallback;
|
|
9
|
-
}
|
|
10
|
-
function clampSize(value, min, max) {
|
|
11
|
-
return Math.min(Math.max(value, min), max);
|
|
12
|
-
}
|
|
13
7
|
class FrResizablePanelGroup {
|
|
14
8
|
elementRef = inject((ElementRef));
|
|
15
9
|
groupId = `frame-resizable-${++nextResizableId}`;
|
|
@@ -49,7 +43,7 @@ class FrResizablePanelGroup {
|
|
|
49
43
|
panel.style.flexGrow = '0';
|
|
50
44
|
panel.style.flexShrink = '0';
|
|
51
45
|
if (!panel.style.flexBasis) {
|
|
52
|
-
this.applyPanelSize(panel,
|
|
46
|
+
this.applyPanelSize(panel, clampNumber(this.defaultSize(panel) ?? fallbackSize, this.minSize(panel), this.maxSize(panel)));
|
|
53
47
|
}
|
|
54
48
|
else {
|
|
55
49
|
this.applyPanelSize(panel, this.panelSize(panel) ?? 0);
|
|
@@ -139,8 +133,8 @@ class FrResizablePanelGroup {
|
|
|
139
133
|
resizePair(previousPanel, nextPanel, pairTotal, requestedPreviousSize) {
|
|
140
134
|
const previousMin = this.minSize(previousPanel);
|
|
141
135
|
const previousMax = Math.min(this.maxSize(previousPanel), pairTotal - this.minSize(nextPanel));
|
|
142
|
-
const previousSize =
|
|
143
|
-
const nextSize =
|
|
136
|
+
const previousSize = clampNumber(requestedPreviousSize, previousMin, previousMax);
|
|
137
|
+
const nextSize = clampNumber(pairTotal - previousSize, this.minSize(nextPanel), this.maxSize(nextPanel));
|
|
144
138
|
this.applyPanelSize(previousPanel, previousSize);
|
|
145
139
|
this.applyPanelSize(nextPanel, nextSize);
|
|
146
140
|
this.updateHandleMetadata();
|
|
@@ -199,16 +193,16 @@ class FrResizablePanelGroup {
|
|
|
199
193
|
}
|
|
200
194
|
defaultSize(panel) {
|
|
201
195
|
const value = panel.getAttribute('data-default-size');
|
|
202
|
-
return value === null ? null :
|
|
196
|
+
return value === null ? null : coerceNumber(value, 0);
|
|
203
197
|
}
|
|
204
198
|
minSize(panel) {
|
|
205
|
-
return
|
|
199
|
+
return coerceNumber(panel.getAttribute('data-min-size'), 0);
|
|
206
200
|
}
|
|
207
201
|
maxSize(panel) {
|
|
208
|
-
return
|
|
202
|
+
return coerceNumber(panel.getAttribute('data-max-size'), 100);
|
|
209
203
|
}
|
|
210
204
|
collapsedSize(panel) {
|
|
211
|
-
return
|
|
205
|
+
return coerceNumber(panel.getAttribute('data-collapsed-size'), 0);
|
|
212
206
|
}
|
|
213
207
|
collapsible(panel) {
|
|
214
208
|
return panel.hasAttribute('data-collapsible');
|
|
@@ -229,11 +223,11 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "21.2.16", ngImpo
|
|
|
229
223
|
}]
|
|
230
224
|
}], propDecorators: { orientation: [{ type: i0.Input, args: [{ isSignal: true, alias: "orientation", required: false }] }], disabled: [{ type: i0.Input, args: [{ isSignal: true, alias: "disabled", required: false }] }], layoutChange: [{ type: i0.Output, args: ["layoutChange"] }] } });
|
|
231
225
|
class FrResizablePanel {
|
|
232
|
-
defaultSize = input(0, { ...(ngDevMode ? { debugName: "defaultSize" } : /* istanbul ignore next */ {}), transform: (value) =>
|
|
233
|
-
minSize = input(0, { ...(ngDevMode ? { debugName: "minSize" } : /* istanbul ignore next */ {}), transform: (value) =>
|
|
234
|
-
maxSize = input(100, { ...(ngDevMode ? { debugName: "maxSize" } : /* istanbul ignore next */ {}), transform: (value) =>
|
|
226
|
+
defaultSize = input(0, { ...(ngDevMode ? { debugName: "defaultSize" } : /* istanbul ignore next */ {}), transform: (value) => coerceNumber(value, 0) });
|
|
227
|
+
minSize = input(0, { ...(ngDevMode ? { debugName: "minSize" } : /* istanbul ignore next */ {}), transform: (value) => coerceNumber(value, 0) });
|
|
228
|
+
maxSize = input(100, { ...(ngDevMode ? { debugName: "maxSize" } : /* istanbul ignore next */ {}), transform: (value) => coerceNumber(value, 100) });
|
|
235
229
|
collapsible = input(false, { ...(ngDevMode ? { debugName: "collapsible" } : /* istanbul ignore next */ {}), transform: booleanAttribute });
|
|
236
|
-
collapsedSize = input(0, { ...(ngDevMode ? { debugName: "collapsedSize" } : /* istanbul ignore next */ {}), transform: (value) =>
|
|
230
|
+
collapsedSize = input(0, { ...(ngDevMode ? { debugName: "collapsedSize" } : /* istanbul ignore next */ {}), transform: (value) => coerceNumber(value, 0) });
|
|
237
231
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "21.2.16", ngImport: i0, type: FrResizablePanel, deps: [], target: i0.ɵɵFactoryTarget.Directive });
|
|
238
232
|
static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "17.1.0", version: "21.2.16", type: FrResizablePanel, isStandalone: true, selector: "[frResizablePanel], frame-resizable-panel", inputs: { defaultSize: { classPropertyName: "defaultSize", publicName: "defaultSize", isSignal: true, isRequired: false, transformFunction: null }, minSize: { classPropertyName: "minSize", publicName: "minSize", isSignal: true, isRequired: false, transformFunction: null }, maxSize: { classPropertyName: "maxSize", publicName: "maxSize", isSignal: true, isRequired: false, transformFunction: null }, collapsible: { classPropertyName: "collapsible", publicName: "collapsible", isSignal: true, isRequired: false, transformFunction: null }, collapsedSize: { classPropertyName: "collapsedSize", publicName: "collapsedSize", isSignal: true, isRequired: false, transformFunction: null } }, host: { properties: { "attr.data-default-size": "defaultSize()", "attr.data-min-size": "minSize()", "attr.data-max-size": "maxSize()", "attr.data-collapsible": "collapsible() ? \"\" : null", "attr.data-collapsed-size": "collapsedSize()" }, classAttribute: "frame-resizable__panel" }, ngImport: i0 });
|
|
239
233
|
}
|
|
@@ -282,15 +276,11 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "21.2.16", ngImpo
|
|
|
282
276
|
'[attr.data-orientation]': 'group.orientation()',
|
|
283
277
|
'[attr.data-handle]': 'withHandle() ? "" : null',
|
|
284
278
|
'[attr.data-disabled]': 'group.disabled() ? "" : null',
|
|
279
|
+
'(pointerdown)': 'onPointerDown($event)',
|
|
280
|
+
'(keydown)': 'onKeydown($event)',
|
|
285
281
|
},
|
|
286
282
|
}]
|
|
287
|
-
}], propDecorators: { withHandle: [{ type: i0.Input, args: [{ isSignal: true, alias: "withHandle", required: false }] }]
|
|
288
|
-
type: HostListener,
|
|
289
|
-
args: ['pointerdown', ['$event']]
|
|
290
|
-
}], onKeydown: [{
|
|
291
|
-
type: HostListener,
|
|
292
|
-
args: ['keydown', ['$event']]
|
|
293
|
-
}] } });
|
|
283
|
+
}], propDecorators: { withHandle: [{ type: i0.Input, args: [{ isSignal: true, alias: "withHandle", required: false }] }] } });
|
|
294
284
|
|
|
295
285
|
class FrResizableModule {
|
|
296
286
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "21.2.16", ngImport: i0, type: FrResizableModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"frame-ui-ng-components-resizable.mjs","sources":["../../../projects/components/resizable/src/resizable.ts","../../../projects/components/resizable/resizable.module.ts","../../../projects/components/resizable/frame-ui-ng-components-resizable.ts"],"sourcesContent":["import {\n AfterViewInit,\n Directive,\n ElementRef,\n HostListener,\n OnDestroy,\n booleanAttribute,\n inject,\n input,\n output,\n} from '@angular/core';\n\nexport const FR_RESIZABLE_ORIENTATIONS = ['horizontal', 'vertical'] as const;\nexport type FrResizableOrientation = (typeof FR_RESIZABLE_ORIENTATIONS)[number];\n\nlet nextResizableId = 0;\n\nfunction coerceSize(value: unknown, fallback: number): number {\n const parsed = Number(value);\n return Number.isFinite(parsed) ? parsed : fallback;\n}\n\nfunction clampSize(value: number, min: number, max: number): number {\n return Math.min(Math.max(value, min), max);\n}\n\n@Directive({\n selector: '[frResizablePanelGroup], frame-resizable-panel-group',\n exportAs: 'frResizablePanelGroup',\n host: {\n class: 'frame-resizable',\n '[attr.data-orientation]': 'orientation()',\n '[attr.data-disabled]': 'disabled() ? \"\" : null',\n },\n})\nexport class FrResizablePanelGroup implements AfterViewInit, OnDestroy {\n private readonly elementRef = inject(ElementRef<HTMLElement>);\n private readonly groupId = `frame-resizable-${++nextResizableId}`;\n private readonly cleanupFns: Array<() => void> = [];\n\n readonly orientation = input<FrResizableOrientation>('horizontal');\n readonly disabled = input(false, { transform: booleanAttribute });\n readonly layoutChange = output<number[]>();\n\n ngAfterViewInit(): void {\n queueMicrotask(() => this.initializeLayout());\n }\n\n ngOnDestroy(): void {\n for (const cleanup of this.cleanupFns) {\n cleanup();\n }\n }\n\n panelId(index: number): string {\n return `${this.groupId}-panel-${index}`;\n }\n\n panels(): HTMLElement[] {\n return Array.from(\n this.elementRef.nativeElement.children,\n ).filter((child): child is HTMLElement => child instanceof HTMLElement && child.hasAttribute('FrResizablePanel'));\n }\n\n handles(): HTMLElement[] {\n return Array.from(\n this.elementRef.nativeElement.children,\n ).filter((child): child is HTMLElement => child instanceof HTMLElement && child.hasAttribute('FrResizableHandle'));\n }\n\n initializeLayout(): void {\n const panels = this.panels();\n\n if (!panels.length) {\n return;\n }\n\n const remainingPanels = panels.filter((panel) => !panel.style.flexBasis);\n const assignedTotal = panels.reduce((total, panel) => total + (this.panelSize(panel) ?? 0), 0);\n const fallbackSize = remainingPanels.length\n ? Math.max((100 - assignedTotal) / remainingPanels.length, 0)\n : 0;\n\n panels.forEach((panel, index) => {\n panel.id ||= this.panelId(index);\n panel.style.flexGrow = '0';\n panel.style.flexShrink = '0';\n\n if (!panel.style.flexBasis) {\n this.applyPanelSize(\n panel,\n clampSize(this.defaultSize(panel) ?? fallbackSize, this.minSize(panel), this.maxSize(panel)),\n );\n } else {\n this.applyPanelSize(panel, this.panelSize(panel) ?? 0);\n }\n });\n\n this.updateHandleMetadata();\n this.emitLayout();\n }\n\n startResize(handle: HTMLElement, pointerId: number, startClientX: number, startClientY: number): void {\n if (this.disabled()) {\n return;\n }\n\n const pair = this.panelPairForHandle(handle);\n\n if (!pair) {\n return;\n }\n\n const groupRect = this.elementRef.nativeElement.getBoundingClientRect();\n const dimension = this.orientation() === 'horizontal' ? groupRect.width : groupRect.height;\n\n if (dimension <= 0) {\n return;\n }\n\n const [previousPanel, nextPanel] = pair;\n const startPrevious = this.panelSize(previousPanel) ?? 0;\n const startNext = this.panelSize(nextPanel) ?? 0;\n const pairTotal = startPrevious + startNext;\n const rtlMultiplier =\n this.orientation() === 'horizontal' && getComputedStyle(this.elementRef.nativeElement).direction === 'rtl'\n ? -1\n : 1;\n\n handle.setPointerCapture?.(pointerId);\n handle.setAttribute('data-dragging', '');\n this.elementRef.nativeElement.setAttribute('data-resizing', '');\n\n const move = (event: PointerEvent) => {\n const deltaPx =\n this.orientation() === 'horizontal'\n ? (event.clientX - startClientX) * rtlMultiplier\n : event.clientY - startClientY;\n this.resizePair(previousPanel, nextPanel, pairTotal, startPrevious + (deltaPx / dimension) * 100);\n };\n\n const end = () => {\n handle.removeAttribute('data-dragging');\n this.elementRef.nativeElement.removeAttribute('data-resizing');\n window.removeEventListener('pointermove', move);\n window.removeEventListener('pointerup', end);\n window.removeEventListener('pointercancel', end);\n };\n\n window.addEventListener('pointermove', move);\n window.addEventListener('pointerup', end, { once: true });\n window.addEventListener('pointercancel', end, { once: true });\n }\n\n resizeFromKeyboard(handle: HTMLElement, key: string): boolean {\n if (this.disabled()) {\n return false;\n }\n\n const pair = this.panelPairForHandle(handle);\n\n if (!pair) {\n return false;\n }\n\n const [previousPanel, nextPanel] = pair;\n const startPrevious = this.panelSize(previousPanel) ?? 0;\n const startNext = this.panelSize(nextPanel) ?? 0;\n const pairTotal = startPrevious + startNext;\n const isRtl =\n this.orientation() === 'horizontal' &&\n getComputedStyle(this.elementRef.nativeElement).direction === 'rtl';\n const step = 10;\n\n switch (key) {\n case 'ArrowLeft':\n this.resizePair(previousPanel, nextPanel, pairTotal, startPrevious + (isRtl ? step : -step));\n return true;\n case 'ArrowRight':\n this.resizePair(previousPanel, nextPanel, pairTotal, startPrevious + (isRtl ? -step : step));\n return true;\n case 'ArrowUp':\n this.resizePair(previousPanel, nextPanel, pairTotal, startPrevious - step);\n return true;\n case 'ArrowDown':\n this.resizePair(previousPanel, nextPanel, pairTotal, startPrevious + step);\n return true;\n case 'Home':\n this.resizePair(previousPanel, nextPanel, pairTotal, this.minSize(previousPanel));\n return true;\n case 'End':\n this.resizePair(previousPanel, nextPanel, pairTotal, pairTotal - this.minSize(nextPanel));\n return true;\n default:\n return false;\n }\n }\n\n private resizePair(\n previousPanel: HTMLElement,\n nextPanel: HTMLElement,\n pairTotal: number,\n requestedPreviousSize: number,\n ): void {\n const previousMin = this.minSize(previousPanel);\n const previousMax = Math.min(this.maxSize(previousPanel), pairTotal - this.minSize(nextPanel));\n const previousSize = clampSize(requestedPreviousSize, previousMin, previousMax);\n const nextSize = clampSize(pairTotal - previousSize, this.minSize(nextPanel), this.maxSize(nextPanel));\n\n this.applyPanelSize(previousPanel, previousSize);\n this.applyPanelSize(nextPanel, nextSize);\n this.updateHandleMetadata();\n this.emitLayout();\n }\n\n private applyPanelSize(panel: HTMLElement, size: number): void {\n const normalizedSize = Math.max(size, 0);\n const collapsedThreshold = this.collapsible(panel) ? this.collapsedSize(panel) : 0;\n const collapsed = normalizedSize <= collapsedThreshold;\n const appliedSize = collapsed ? collapsedThreshold : normalizedSize;\n\n panel.style.flexBasis = `${appliedSize}%`;\n panel.setAttribute('data-size', String(appliedSize));\n panel.toggleAttribute('data-collapsed', collapsed);\n }\n\n private panelPairForHandle(handle: HTMLElement): [HTMLElement, HTMLElement] | null {\n let previous = handle.previousElementSibling;\n let next = handle.nextElementSibling;\n\n while (previous && !(previous instanceof HTMLElement && previous.hasAttribute('FrResizablePanel'))) {\n previous = previous.previousElementSibling;\n }\n\n while (next && !(next instanceof HTMLElement && next.hasAttribute('FrResizablePanel'))) {\n next = next.nextElementSibling;\n }\n\n if (!(previous instanceof HTMLElement) || !(next instanceof HTMLElement)) {\n return null;\n }\n\n return [previous, next];\n }\n\n private updateHandleMetadata(): void {\n const panels = this.panels();\n\n this.handles().forEach((handle) => {\n const pair = this.panelPairForHandle(handle);\n\n if (!pair) {\n return;\n }\n\n const [previousPanel, nextPanel] = pair;\n const previousIndex = panels.indexOf(previousPanel);\n const nextIndex = panels.indexOf(nextPanel);\n\n handle.setAttribute('aria-controls', [previousPanel.id, nextPanel.id].filter(Boolean).join(' '));\n handle.setAttribute('aria-valuemin', String(this.minSize(previousPanel)));\n handle.setAttribute('aria-valuemax', String(this.maxSize(previousPanel)));\n handle.setAttribute('aria-valuenow', String(Math.round(this.panelSize(previousPanel) ?? 0)));\n handle.setAttribute('data-panels', `${previousIndex}:${nextIndex}`);\n });\n }\n\n private emitLayout(): void {\n this.layoutChange.emit(this.panels().map((panel) => this.panelSize(panel) ?? 0));\n }\n\n private panelSize(panel: HTMLElement): number | null {\n const styleSize = Number.parseFloat(panel.style.flexBasis);\n\n if (Number.isFinite(styleSize)) {\n return styleSize;\n }\n\n const dataSize = Number(panel.getAttribute('data-size'));\n return Number.isFinite(dataSize) ? dataSize : null;\n }\n\n private defaultSize(panel: HTMLElement): number | null {\n const value = panel.getAttribute('data-default-size');\n return value === null ? null : coerceSize(value, 0);\n }\n\n private minSize(panel: HTMLElement): number {\n return coerceSize(panel.getAttribute('data-min-size'), 0);\n }\n\n private maxSize(panel: HTMLElement): number {\n return coerceSize(panel.getAttribute('data-max-size'), 100);\n }\n\n private collapsedSize(panel: HTMLElement): number {\n return coerceSize(panel.getAttribute('data-collapsed-size'), 0);\n }\n\n private collapsible(panel: HTMLElement): boolean {\n return panel.hasAttribute('data-collapsible');\n }\n}\n\n@Directive({\n selector: '[frResizablePanel], frame-resizable-panel',\n host: {\n class: 'frame-resizable__panel',\n '[attr.data-default-size]': 'defaultSize()',\n '[attr.data-min-size]': 'minSize()',\n '[attr.data-max-size]': 'maxSize()',\n '[attr.data-collapsible]': 'collapsible() ? \"\" : null',\n '[attr.data-collapsed-size]': 'collapsedSize()',\n },\n})\nexport class FrResizablePanel {\n readonly defaultSize = input<number, unknown>(0, { transform: (value) => coerceSize(value, 0) });\n readonly minSize = input<number, unknown>(0, { transform: (value) => coerceSize(value, 0) });\n readonly maxSize = input<number, unknown>(100, { transform: (value) => coerceSize(value, 100) });\n readonly collapsible = input(false, { transform: booleanAttribute });\n readonly collapsedSize = input<number, unknown>(0, { transform: (value) => coerceSize(value, 0) });\n}\n\n@Directive({\n selector: '[frResizableHandle], frame-resizable-handle',\n host: {\n class: 'frame-resizable__handle',\n role: 'separator',\n tabindex: '0',\n '[attr.aria-orientation]': 'group.orientation()',\n '[attr.data-orientation]': 'group.orientation()',\n '[attr.data-handle]': 'withHandle() ? \"\" : null',\n '[attr.data-disabled]': 'group.disabled() ? \"\" : null',\n },\n})\nexport class FrResizableHandle {\n protected readonly group = inject(FrResizablePanelGroup);\n private readonly elementRef = inject(ElementRef<HTMLElement>);\n\n readonly withHandle = input(false, { transform: booleanAttribute });\n\n @HostListener('pointerdown', ['$event'])\n protected onPointerDown(event: PointerEvent): void {\n if (event.button !== 0) {\n return;\n }\n\n event.preventDefault();\n this.group.startResize(this.elementRef.nativeElement, event.pointerId, event.clientX, event.clientY);\n }\n\n @HostListener('keydown', ['$event'])\n protected onKeydown(event: KeyboardEvent): void {\n if (this.group.resizeFromKeyboard(this.elementRef.nativeElement, event.key)) {\n event.preventDefault();\n }\n }\n}\n","import { NgModule } from '@angular/core';\nimport {\n FrResizableHandle,\n FrResizablePanel,\n FrResizablePanelGroup,\n} from './src/resizable';\n\n@NgModule({\n imports: [\n FrResizableHandle,\n FrResizablePanel,\n FrResizablePanelGroup,\n ],\n exports: [\n FrResizableHandle,\n FrResizablePanel,\n FrResizablePanelGroup,\n ],\n})\nexport class FrResizableModule {}\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './public-api';\n"],"names":[],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"frame-ui-ng-components-resizable.mjs","sources":["../../../projects/components/resizable/src/resizable.ts","../../../projects/components/resizable/resizable.module.ts","../../../projects/components/resizable/frame-ui-ng-components-resizable.ts"],"sourcesContent":["import {\r\n AfterViewInit,\r\n Directive,\r\n ElementRef,\r\n OnDestroy,\r\n booleanAttribute,\r\n inject,\r\n input,\r\n output,\r\n} from '@angular/core';\r\nimport { clampNumber, coerceNumber } from '@frame-ui-ng/components/utils';\r\n\r\nexport const FR_RESIZABLE_ORIENTATIONS = ['horizontal', 'vertical'] as const;\r\nexport type FrResizableOrientation = (typeof FR_RESIZABLE_ORIENTATIONS)[number];\r\n\r\nlet nextResizableId = 0;\r\n\r\n@Directive({\r\n selector: '[frResizablePanelGroup], frame-resizable-panel-group',\r\n exportAs: 'frResizablePanelGroup',\r\n host: {\r\n class: 'frame-resizable',\r\n '[attr.data-orientation]': 'orientation()',\r\n '[attr.data-disabled]': 'disabled() ? \"\" : null',\r\n },\r\n})\r\nexport class FrResizablePanelGroup implements AfterViewInit, OnDestroy {\r\n private readonly elementRef = inject(ElementRef<HTMLElement>);\r\n private readonly groupId = `frame-resizable-${++nextResizableId}`;\r\n private readonly cleanupFns: Array<() => void> = [];\r\n\r\n readonly orientation = input<FrResizableOrientation>('horizontal');\r\n readonly disabled = input(false, { transform: booleanAttribute });\r\n readonly layoutChange = output<number[]>();\r\n\r\n ngAfterViewInit(): void {\r\n queueMicrotask(() => this.initializeLayout());\r\n }\r\n\r\n ngOnDestroy(): void {\r\n for (const cleanup of this.cleanupFns) {\r\n cleanup();\r\n }\r\n }\r\n\r\n panelId(index: number): string {\r\n return `${this.groupId}-panel-${index}`;\r\n }\r\n\r\n panels(): HTMLElement[] {\r\n return Array.from(\r\n this.elementRef.nativeElement.children,\r\n ).filter((child): child is HTMLElement => child instanceof HTMLElement && child.hasAttribute('FrResizablePanel'));\r\n }\r\n\r\n handles(): HTMLElement[] {\r\n return Array.from(\r\n this.elementRef.nativeElement.children,\r\n ).filter((child): child is HTMLElement => child instanceof HTMLElement && child.hasAttribute('FrResizableHandle'));\r\n }\r\n\r\n initializeLayout(): void {\r\n const panels = this.panels();\r\n\r\n if (!panels.length) {\r\n return;\r\n }\r\n\r\n const remainingPanels = panels.filter((panel) => !panel.style.flexBasis);\r\n const assignedTotal = panels.reduce((total, panel) => total + (this.panelSize(panel) ?? 0), 0);\r\n const fallbackSize = remainingPanels.length\r\n ? Math.max((100 - assignedTotal) / remainingPanels.length, 0)\r\n : 0;\r\n\r\n panels.forEach((panel, index) => {\r\n panel.id ||= this.panelId(index);\r\n panel.style.flexGrow = '0';\r\n panel.style.flexShrink = '0';\r\n\r\n if (!panel.style.flexBasis) {\r\n this.applyPanelSize(\r\n panel,\r\n clampNumber(this.defaultSize(panel) ?? fallbackSize, this.minSize(panel), this.maxSize(panel)),\r\n );\r\n } else {\r\n this.applyPanelSize(panel, this.panelSize(panel) ?? 0);\r\n }\r\n });\r\n\r\n this.updateHandleMetadata();\r\n this.emitLayout();\r\n }\r\n\r\n startResize(handle: HTMLElement, pointerId: number, startClientX: number, startClientY: number): void {\r\n if (this.disabled()) {\r\n return;\r\n }\r\n\r\n const pair = this.panelPairForHandle(handle);\r\n\r\n if (!pair) {\r\n return;\r\n }\r\n\r\n const groupRect = this.elementRef.nativeElement.getBoundingClientRect();\r\n const dimension = this.orientation() === 'horizontal' ? groupRect.width : groupRect.height;\r\n\r\n if (dimension <= 0) {\r\n return;\r\n }\r\n\r\n const [previousPanel, nextPanel] = pair;\r\n const startPrevious = this.panelSize(previousPanel) ?? 0;\r\n const startNext = this.panelSize(nextPanel) ?? 0;\r\n const pairTotal = startPrevious + startNext;\r\n const rtlMultiplier =\r\n this.orientation() === 'horizontal' && getComputedStyle(this.elementRef.nativeElement).direction === 'rtl'\r\n ? -1\r\n : 1;\r\n\r\n handle.setPointerCapture?.(pointerId);\r\n handle.setAttribute('data-dragging', '');\r\n this.elementRef.nativeElement.setAttribute('data-resizing', '');\r\n\r\n const move = (event: PointerEvent) => {\r\n const deltaPx =\r\n this.orientation() === 'horizontal'\r\n ? (event.clientX - startClientX) * rtlMultiplier\r\n : event.clientY - startClientY;\r\n this.resizePair(previousPanel, nextPanel, pairTotal, startPrevious + (deltaPx / dimension) * 100);\r\n };\r\n\r\n const end = () => {\r\n handle.removeAttribute('data-dragging');\r\n this.elementRef.nativeElement.removeAttribute('data-resizing');\r\n window.removeEventListener('pointermove', move);\r\n window.removeEventListener('pointerup', end);\r\n window.removeEventListener('pointercancel', end);\r\n };\r\n\r\n window.addEventListener('pointermove', move);\r\n window.addEventListener('pointerup', end, { once: true });\r\n window.addEventListener('pointercancel', end, { once: true });\r\n }\r\n\r\n resizeFromKeyboard(handle: HTMLElement, key: string): boolean {\r\n if (this.disabled()) {\r\n return false;\r\n }\r\n\r\n const pair = this.panelPairForHandle(handle);\r\n\r\n if (!pair) {\r\n return false;\r\n }\r\n\r\n const [previousPanel, nextPanel] = pair;\r\n const startPrevious = this.panelSize(previousPanel) ?? 0;\r\n const startNext = this.panelSize(nextPanel) ?? 0;\r\n const pairTotal = startPrevious + startNext;\r\n const isRtl =\r\n this.orientation() === 'horizontal' &&\r\n getComputedStyle(this.elementRef.nativeElement).direction === 'rtl';\r\n const step = 10;\r\n\r\n switch (key) {\r\n case 'ArrowLeft':\r\n this.resizePair(previousPanel, nextPanel, pairTotal, startPrevious + (isRtl ? step : -step));\r\n return true;\r\n case 'ArrowRight':\r\n this.resizePair(previousPanel, nextPanel, pairTotal, startPrevious + (isRtl ? -step : step));\r\n return true;\r\n case 'ArrowUp':\r\n this.resizePair(previousPanel, nextPanel, pairTotal, startPrevious - step);\r\n return true;\r\n case 'ArrowDown':\r\n this.resizePair(previousPanel, nextPanel, pairTotal, startPrevious + step);\r\n return true;\r\n case 'Home':\r\n this.resizePair(previousPanel, nextPanel, pairTotal, this.minSize(previousPanel));\r\n return true;\r\n case 'End':\r\n this.resizePair(previousPanel, nextPanel, pairTotal, pairTotal - this.minSize(nextPanel));\r\n return true;\r\n default:\r\n return false;\r\n }\r\n }\r\n\r\n private resizePair(\r\n previousPanel: HTMLElement,\r\n nextPanel: HTMLElement,\r\n pairTotal: number,\r\n requestedPreviousSize: number,\r\n ): void {\r\n const previousMin = this.minSize(previousPanel);\r\n const previousMax = Math.min(this.maxSize(previousPanel), pairTotal - this.minSize(nextPanel));\r\n const previousSize = clampNumber(requestedPreviousSize, previousMin, previousMax);\r\n const nextSize = clampNumber(pairTotal - previousSize, this.minSize(nextPanel), this.maxSize(nextPanel));\r\n\r\n this.applyPanelSize(previousPanel, previousSize);\r\n this.applyPanelSize(nextPanel, nextSize);\r\n this.updateHandleMetadata();\r\n this.emitLayout();\r\n }\r\n\r\n private applyPanelSize(panel: HTMLElement, size: number): void {\r\n const normalizedSize = Math.max(size, 0);\r\n const collapsedThreshold = this.collapsible(panel) ? this.collapsedSize(panel) : 0;\r\n const collapsed = normalizedSize <= collapsedThreshold;\r\n const appliedSize = collapsed ? collapsedThreshold : normalizedSize;\r\n\r\n panel.style.flexBasis = `${appliedSize}%`;\r\n panel.setAttribute('data-size', String(appliedSize));\r\n panel.toggleAttribute('data-collapsed', collapsed);\r\n }\r\n\r\n private panelPairForHandle(handle: HTMLElement): [HTMLElement, HTMLElement] | null {\r\n let previous = handle.previousElementSibling;\r\n let next = handle.nextElementSibling;\r\n\r\n while (previous && !(previous instanceof HTMLElement && previous.hasAttribute('FrResizablePanel'))) {\r\n previous = previous.previousElementSibling;\r\n }\r\n\r\n while (next && !(next instanceof HTMLElement && next.hasAttribute('FrResizablePanel'))) {\r\n next = next.nextElementSibling;\r\n }\r\n\r\n if (!(previous instanceof HTMLElement) || !(next instanceof HTMLElement)) {\r\n return null;\r\n }\r\n\r\n return [previous, next];\r\n }\r\n\r\n private updateHandleMetadata(): void {\r\n const panels = this.panels();\r\n\r\n this.handles().forEach((handle) => {\r\n const pair = this.panelPairForHandle(handle);\r\n\r\n if (!pair) {\r\n return;\r\n }\r\n\r\n const [previousPanel, nextPanel] = pair;\r\n const previousIndex = panels.indexOf(previousPanel);\r\n const nextIndex = panels.indexOf(nextPanel);\r\n\r\n handle.setAttribute('aria-controls', [previousPanel.id, nextPanel.id].filter(Boolean).join(' '));\r\n handle.setAttribute('aria-valuemin', String(this.minSize(previousPanel)));\r\n handle.setAttribute('aria-valuemax', String(this.maxSize(previousPanel)));\r\n handle.setAttribute('aria-valuenow', String(Math.round(this.panelSize(previousPanel) ?? 0)));\r\n handle.setAttribute('data-panels', `${previousIndex}:${nextIndex}`);\r\n });\r\n }\r\n\r\n private emitLayout(): void {\r\n this.layoutChange.emit(this.panels().map((panel) => this.panelSize(panel) ?? 0));\r\n }\r\n\r\n private panelSize(panel: HTMLElement): number | null {\r\n const styleSize = Number.parseFloat(panel.style.flexBasis);\r\n\r\n if (Number.isFinite(styleSize)) {\r\n return styleSize;\r\n }\r\n\r\n const dataSize = Number(panel.getAttribute('data-size'));\r\n return Number.isFinite(dataSize) ? dataSize : null;\r\n }\r\n\r\n private defaultSize(panel: HTMLElement): number | null {\r\n const value = panel.getAttribute('data-default-size');\r\n return value === null ? null : coerceNumber(value, 0);\r\n }\r\n\r\n private minSize(panel: HTMLElement): number {\r\n return coerceNumber(panel.getAttribute('data-min-size'), 0);\r\n }\r\n\r\n private maxSize(panel: HTMLElement): number {\r\n return coerceNumber(panel.getAttribute('data-max-size'), 100);\r\n }\r\n\r\n private collapsedSize(panel: HTMLElement): number {\r\n return coerceNumber(panel.getAttribute('data-collapsed-size'), 0);\r\n }\r\n\r\n private collapsible(panel: HTMLElement): boolean {\r\n return panel.hasAttribute('data-collapsible');\r\n }\r\n}\r\n\r\n@Directive({\r\n selector: '[frResizablePanel], frame-resizable-panel',\r\n host: {\r\n class: 'frame-resizable__panel',\r\n '[attr.data-default-size]': 'defaultSize()',\r\n '[attr.data-min-size]': 'minSize()',\r\n '[attr.data-max-size]': 'maxSize()',\r\n '[attr.data-collapsible]': 'collapsible() ? \"\" : null',\r\n '[attr.data-collapsed-size]': 'collapsedSize()',\r\n },\r\n})\r\nexport class FrResizablePanel {\r\n readonly defaultSize = input<number, unknown>(0, { transform: (value) => coerceNumber(value, 0) });\r\n readonly minSize = input<number, unknown>(0, { transform: (value) => coerceNumber(value, 0) });\r\n readonly maxSize = input<number, unknown>(100, { transform: (value) => coerceNumber(value, 100) });\r\n readonly collapsible = input(false, { transform: booleanAttribute });\r\n readonly collapsedSize = input<number, unknown>(0, { transform: (value) => coerceNumber(value, 0) });\r\n}\r\n\r\n@Directive({\r\n selector: '[frResizableHandle], frame-resizable-handle',\r\n host: {\r\n class: 'frame-resizable__handle',\r\n role: 'separator',\r\n tabindex: '0',\r\n '[attr.aria-orientation]': 'group.orientation()',\r\n '[attr.data-orientation]': 'group.orientation()',\r\n '[attr.data-handle]': 'withHandle() ? \"\" : null',\r\n '[attr.data-disabled]': 'group.disabled() ? \"\" : null',\r\n '(pointerdown)': 'onPointerDown($event)',\r\n '(keydown)': 'onKeydown($event)',\r\n },\r\n})\r\nexport class FrResizableHandle {\r\n protected readonly group = inject(FrResizablePanelGroup);\r\n private readonly elementRef = inject(ElementRef<HTMLElement>);\r\n\r\n readonly withHandle = input(false, { transform: booleanAttribute });\r\n\r\n protected onPointerDown(event: PointerEvent): void {\r\n if (event.button !== 0) {\r\n return;\r\n }\r\n\r\n event.preventDefault();\r\n this.group.startResize(this.elementRef.nativeElement, event.pointerId, event.clientX, event.clientY);\r\n }\r\n\r\n protected onKeydown(event: KeyboardEvent): void {\r\n if (this.group.resizeFromKeyboard(this.elementRef.nativeElement, event.key)) {\r\n event.preventDefault();\r\n }\r\n }\r\n}\r\n","import { NgModule } from '@angular/core';\nimport {\n FrResizableHandle,\n FrResizablePanel,\n FrResizablePanelGroup,\n} from './src/resizable';\n\n@NgModule({\n imports: [\n FrResizableHandle,\n FrResizablePanel,\n FrResizablePanelGroup,\n ],\n exports: [\n FrResizableHandle,\n FrResizablePanel,\n FrResizablePanelGroup,\n ],\n})\nexport class FrResizableModule {}\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './public-api';\n"],"names":[],"mappings":";;;;MAYa,yBAAyB,GAAG,CAAC,YAAY,EAAE,UAAU;AAGlE,IAAI,eAAe,GAAG,CAAC;MAWV,qBAAqB,CAAA;AACf,IAAA,UAAU,GAAG,MAAM,EAAC,UAAuB,EAAC;AAC5C,IAAA,OAAO,GAAG,CAAA,gBAAA,EAAmB,EAAE,eAAe,EAAE;IAChD,UAAU,GAAsB,EAAE;AAE1C,IAAA,WAAW,GAAG,KAAK,CAAyB,YAAY,kFAAC;IACzD,QAAQ,GAAG,KAAK,CAAC,KAAK,gFAAI,SAAS,EAAE,gBAAgB,EAAA,CAAG;IACxD,YAAY,GAAG,MAAM,EAAY;IAE1C,eAAe,GAAA;QACb,cAAc,CAAC,MAAM,IAAI,CAAC,gBAAgB,EAAE,CAAC;IAC/C;IAEA,WAAW,GAAA;AACT,QAAA,KAAK,MAAM,OAAO,IAAI,IAAI,CAAC,UAAU,EAAE;AACrC,YAAA,OAAO,EAAE;QACX;IACF;AAEA,IAAA,OAAO,CAAC,KAAa,EAAA;AACnB,QAAA,OAAO,GAAG,IAAI,CAAC,OAAO,CAAA,OAAA,EAAU,KAAK,EAAE;IACzC;IAEA,MAAM,GAAA;AACJ,QAAA,OAAO,KAAK,CAAC,IAAI,CACf,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,QAAQ,CACvC,CAAC,MAAM,CAAC,CAAC,KAAK,KAA2B,KAAK,YAAY,WAAW,IAAI,KAAK,CAAC,YAAY,CAAC,kBAAkB,CAAC,CAAC;IACnH;IAEA,OAAO,GAAA;AACL,QAAA,OAAO,KAAK,CAAC,IAAI,CACf,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,QAAQ,CACvC,CAAC,MAAM,CAAC,CAAC,KAAK,KAA2B,KAAK,YAAY,WAAW,IAAI,KAAK,CAAC,YAAY,CAAC,mBAAmB,CAAC,CAAC;IACpH;IAEA,gBAAgB,GAAA;AACd,QAAA,MAAM,MAAM,GAAG,IAAI,CAAC,MAAM,EAAE;AAE5B,QAAA,IAAI,CAAC,MAAM,CAAC,MAAM,EAAE;YAClB;QACF;AAEA,QAAA,MAAM,eAAe,GAAG,MAAM,CAAC,MAAM,CAAC,CAAC,KAAK,KAAK,CAAC,KAAK,CAAC,KAAK,CAAC,SAAS,CAAC;AACxE,QAAA,MAAM,aAAa,GAAG,MAAM,CAAC,MAAM,CAAC,CAAC,KAAK,EAAE,KAAK,KAAK,KAAK,IAAI,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,EAAE,CAAC,CAAC;AAC9F,QAAA,MAAM,YAAY,GAAG,eAAe,CAAC;AACnC,cAAE,IAAI,CAAC,GAAG,CAAC,CAAC,GAAG,GAAG,aAAa,IAAI,eAAe,CAAC,MAAM,EAAE,CAAC;cAC1D,CAAC;QAEL,MAAM,CAAC,OAAO,CAAC,CAAC,KAAK,EAAE,KAAK,KAAI;YAC9B,KAAK,CAAC,EAAE,KAAK,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC;AAChC,YAAA,KAAK,CAAC,KAAK,CAAC,QAAQ,GAAG,GAAG;AAC1B,YAAA,KAAK,CAAC,KAAK,CAAC,UAAU,GAAG,GAAG;AAE5B,YAAA,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,SAAS,EAAE;AAC1B,gBAAA,IAAI,CAAC,cAAc,CACjB,KAAK,EACL,WAAW,CAAC,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC,IAAI,YAAY,EAAE,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,CAC/F;YACH;iBAAO;AACL,gBAAA,IAAI,CAAC,cAAc,CAAC,KAAK,EAAE,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;YACxD;AACF,QAAA,CAAC,CAAC;QAEF,IAAI,CAAC,oBAAoB,EAAE;QAC3B,IAAI,CAAC,UAAU,EAAE;IACnB;AAEA,IAAA,WAAW,CAAC,MAAmB,EAAE,SAAiB,EAAE,YAAoB,EAAE,YAAoB,EAAA;AAC5F,QAAA,IAAI,IAAI,CAAC,QAAQ,EAAE,EAAE;YACnB;QACF;QAEA,MAAM,IAAI,GAAG,IAAI,CAAC,kBAAkB,CAAC,MAAM,CAAC;QAE5C,IAAI,CAAC,IAAI,EAAE;YACT;QACF;QAEA,MAAM,SAAS,GAAG,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,qBAAqB,EAAE;QACvE,MAAM,SAAS,GAAG,IAAI,CAAC,WAAW,EAAE,KAAK,YAAY,GAAG,SAAS,CAAC,KAAK,GAAG,SAAS,CAAC,MAAM;AAE1F,QAAA,IAAI,SAAS,IAAI,CAAC,EAAE;YAClB;QACF;AAEA,QAAA,MAAM,CAAC,aAAa,EAAE,SAAS,CAAC,GAAG,IAAI;QACvC,MAAM,aAAa,GAAG,IAAI,CAAC,SAAS,CAAC,aAAa,CAAC,IAAI,CAAC;QACxD,MAAM,SAAS,GAAG,IAAI,CAAC,SAAS,CAAC,SAAS,CAAC,IAAI,CAAC;AAChD,QAAA,MAAM,SAAS,GAAG,aAAa,GAAG,SAAS;QAC3C,MAAM,aAAa,GACjB,IAAI,CAAC,WAAW,EAAE,KAAK,YAAY,IAAI,gBAAgB,CAAC,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,CAAC,SAAS,KAAK;cACjG,CAAC;cACD,CAAC;AAEP,QAAA,MAAM,CAAC,iBAAiB,GAAG,SAAS,CAAC;AACrC,QAAA,MAAM,CAAC,YAAY,CAAC,eAAe,EAAE,EAAE,CAAC;QACxC,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,YAAY,CAAC,eAAe,EAAE,EAAE,CAAC;AAE/D,QAAA,MAAM,IAAI,GAAG,CAAC,KAAmB,KAAI;AACnC,YAAA,MAAM,OAAO,GACX,IAAI,CAAC,WAAW,EAAE,KAAK;kBACnB,CAAC,KAAK,CAAC,OAAO,GAAG,YAAY,IAAI;AACnC,kBAAE,KAAK,CAAC,OAAO,GAAG,YAAY;AAClC,YAAA,IAAI,CAAC,UAAU,CAAC,aAAa,EAAE,SAAS,EAAE,SAAS,EAAE,aAAa,GAAG,CAAC,OAAO,GAAG,SAAS,IAAI,GAAG,CAAC;AACnG,QAAA,CAAC;QAED,MAAM,GAAG,GAAG,MAAK;AACf,YAAA,MAAM,CAAC,eAAe,CAAC,eAAe,CAAC;YACvC,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,eAAe,CAAC,eAAe,CAAC;AAC9D,YAAA,MAAM,CAAC,mBAAmB,CAAC,aAAa,EAAE,IAAI,CAAC;AAC/C,YAAA,MAAM,CAAC,mBAAmB,CAAC,WAAW,EAAE,GAAG,CAAC;AAC5C,YAAA,MAAM,CAAC,mBAAmB,CAAC,eAAe,EAAE,GAAG,CAAC;AAClD,QAAA,CAAC;AAED,QAAA,MAAM,CAAC,gBAAgB,CAAC,aAAa,EAAE,IAAI,CAAC;AAC5C,QAAA,MAAM,CAAC,gBAAgB,CAAC,WAAW,EAAE,GAAG,EAAE,EAAE,IAAI,EAAE,IAAI,EAAE,CAAC;AACzD,QAAA,MAAM,CAAC,gBAAgB,CAAC,eAAe,EAAE,GAAG,EAAE,EAAE,IAAI,EAAE,IAAI,EAAE,CAAC;IAC/D;IAEA,kBAAkB,CAAC,MAAmB,EAAE,GAAW,EAAA;AACjD,QAAA,IAAI,IAAI,CAAC,QAAQ,EAAE,EAAE;AACnB,YAAA,OAAO,KAAK;QACd;QAEA,MAAM,IAAI,GAAG,IAAI,CAAC,kBAAkB,CAAC,MAAM,CAAC;QAE5C,IAAI,CAAC,IAAI,EAAE;AACT,YAAA,OAAO,KAAK;QACd;AAEA,QAAA,MAAM,CAAC,aAAa,EAAE,SAAS,CAAC,GAAG,IAAI;QACvC,MAAM,aAAa,GAAG,IAAI,CAAC,SAAS,CAAC,aAAa,CAAC,IAAI,CAAC;QACxD,MAAM,SAAS,GAAG,IAAI,CAAC,SAAS,CAAC,SAAS,CAAC,IAAI,CAAC;AAChD,QAAA,MAAM,SAAS,GAAG,aAAa,GAAG,SAAS;AAC3C,QAAA,MAAM,KAAK,GACT,IAAI,CAAC,WAAW,EAAE,KAAK,YAAY;YACnC,gBAAgB,CAAC,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,CAAC,SAAS,KAAK,KAAK;QACrE,MAAM,IAAI,GAAG,EAAE;QAEf,QAAQ,GAAG;AACT,YAAA,KAAK,WAAW;gBACd,IAAI,CAAC,UAAU,CAAC,aAAa,EAAE,SAAS,EAAE,SAAS,EAAE,aAAa,IAAI,KAAK,GAAG,IAAI,GAAG,CAAC,IAAI,CAAC,CAAC;AAC5F,gBAAA,OAAO,IAAI;AACb,YAAA,KAAK,YAAY;gBACf,IAAI,CAAC,UAAU,CAAC,aAAa,EAAE,SAAS,EAAE,SAAS,EAAE,aAAa,IAAI,KAAK,GAAG,CAAC,IAAI,GAAG,IAAI,CAAC,CAAC;AAC5F,gBAAA,OAAO,IAAI;AACb,YAAA,KAAK,SAAS;AACZ,gBAAA,IAAI,CAAC,UAAU,CAAC,aAAa,EAAE,SAAS,EAAE,SAAS,EAAE,aAAa,GAAG,IAAI,CAAC;AAC1E,gBAAA,OAAO,IAAI;AACb,YAAA,KAAK,WAAW;AACd,gBAAA,IAAI,CAAC,UAAU,CAAC,aAAa,EAAE,SAAS,EAAE,SAAS,EAAE,aAAa,GAAG,IAAI,CAAC;AAC1E,gBAAA,OAAO,IAAI;AACb,YAAA,KAAK,MAAM;AACT,gBAAA,IAAI,CAAC,UAAU,CAAC,aAAa,EAAE,SAAS,EAAE,SAAS,EAAE,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC,CAAC;AACjF,gBAAA,OAAO,IAAI;AACb,YAAA,KAAK,KAAK;AACR,gBAAA,IAAI,CAAC,UAAU,CAAC,aAAa,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS,GAAG,IAAI,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC;AACzF,gBAAA,OAAO,IAAI;AACb,YAAA;AACE,gBAAA,OAAO,KAAK;;IAElB;AAEQ,IAAA,UAAU,CAChB,aAA0B,EAC1B,SAAsB,EACtB,SAAiB,EACjB,qBAA6B,EAAA;QAE7B,MAAM,WAAW,GAAG,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC;QAC/C,MAAM,WAAW,GAAG,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC,EAAE,SAAS,GAAG,IAAI,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC;QAC9F,MAAM,YAAY,GAAG,WAAW,CAAC,qBAAqB,EAAE,WAAW,EAAE,WAAW,CAAC;QACjF,MAAM,QAAQ,GAAG,WAAW,CAAC,SAAS,GAAG,YAAY,EAAE,IAAI,CAAC,OAAO,CAAC,SAAS,CAAC,EAAE,IAAI,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC;AAExG,QAAA,IAAI,CAAC,cAAc,CAAC,aAAa,EAAE,YAAY,CAAC;AAChD,QAAA,IAAI,CAAC,cAAc,CAAC,SAAS,EAAE,QAAQ,CAAC;QACxC,IAAI,CAAC,oBAAoB,EAAE;QAC3B,IAAI,CAAC,UAAU,EAAE;IACnB;IAEQ,cAAc,CAAC,KAAkB,EAAE,IAAY,EAAA;QACrD,MAAM,cAAc,GAAG,IAAI,CAAC,GAAG,CAAC,IAAI,EAAE,CAAC,CAAC;QACxC,MAAM,kBAAkB,GAAG,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC,GAAG,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC,GAAG,CAAC;AAClF,QAAA,MAAM,SAAS,GAAG,cAAc,IAAI,kBAAkB;QACtD,MAAM,WAAW,GAAG,SAAS,GAAG,kBAAkB,GAAG,cAAc;QAEnE,KAAK,CAAC,KAAK,CAAC,SAAS,GAAG,CAAA,EAAG,WAAW,GAAG;QACzC,KAAK,CAAC,YAAY,CAAC,WAAW,EAAE,MAAM,CAAC,WAAW,CAAC,CAAC;AACpD,QAAA,KAAK,CAAC,eAAe,CAAC,gBAAgB,EAAE,SAAS,CAAC;IACpD;AAEQ,IAAA,kBAAkB,CAAC,MAAmB,EAAA;AAC5C,QAAA,IAAI,QAAQ,GAAG,MAAM,CAAC,sBAAsB;AAC5C,QAAA,IAAI,IAAI,GAAG,MAAM,CAAC,kBAAkB;AAEpC,QAAA,OAAO,QAAQ,IAAI,EAAE,QAAQ,YAAY,WAAW,IAAI,QAAQ,CAAC,YAAY,CAAC,kBAAkB,CAAC,CAAC,EAAE;AAClG,YAAA,QAAQ,GAAG,QAAQ,CAAC,sBAAsB;QAC5C;AAEA,QAAA,OAAO,IAAI,IAAI,EAAE,IAAI,YAAY,WAAW,IAAI,IAAI,CAAC,YAAY,CAAC,kBAAkB,CAAC,CAAC,EAAE;AACtF,YAAA,IAAI,GAAG,IAAI,CAAC,kBAAkB;QAChC;AAEA,QAAA,IAAI,EAAE,QAAQ,YAAY,WAAW,CAAC,IAAI,EAAE,IAAI,YAAY,WAAW,CAAC,EAAE;AACxE,YAAA,OAAO,IAAI;QACb;AAEA,QAAA,OAAO,CAAC,QAAQ,EAAE,IAAI,CAAC;IACzB;IAEQ,oBAAoB,GAAA;AAC1B,QAAA,MAAM,MAAM,GAAG,IAAI,CAAC,MAAM,EAAE;QAE5B,IAAI,CAAC,OAAO,EAAE,CAAC,OAAO,CAAC,CAAC,MAAM,KAAI;YAChC,MAAM,IAAI,GAAG,IAAI,CAAC,kBAAkB,CAAC,MAAM,CAAC;YAE5C,IAAI,CAAC,IAAI,EAAE;gBACT;YACF;AAEA,YAAA,MAAM,CAAC,aAAa,EAAE,SAAS,CAAC,GAAG,IAAI;YACvC,MAAM,aAAa,GAAG,MAAM,CAAC,OAAO,CAAC,aAAa,CAAC;YACnD,MAAM,SAAS,GAAG,MAAM,CAAC,OAAO,CAAC,SAAS,CAAC;YAE3C,MAAM,CAAC,YAAY,CAAC,eAAe,EAAE,CAAC,aAAa,CAAC,EAAE,EAAE,SAAS,CAAC,EAAE,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;AAChG,YAAA,MAAM,CAAC,YAAY,CAAC,eAAe,EAAE,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC,CAAC,CAAC;AACzE,YAAA,MAAM,CAAC,YAAY,CAAC,eAAe,EAAE,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC,CAAC,CAAC;YACzE,MAAM,CAAC,YAAY,CAAC,eAAe,EAAE,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,SAAS,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;YAC5F,MAAM,CAAC,YAAY,CAAC,aAAa,EAAE,CAAA,EAAG,aAAa,CAAA,CAAA,EAAI,SAAS,CAAA,CAAE,CAAC;AACrE,QAAA,CAAC,CAAC;IACJ;IAEQ,UAAU,GAAA;QAChB,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC,GAAG,CAAC,CAAC,KAAK,KAAK,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC;IAClF;AAEQ,IAAA,SAAS,CAAC,KAAkB,EAAA;AAClC,QAAA,MAAM,SAAS,GAAG,MAAM,CAAC,UAAU,CAAC,KAAK,CAAC,KAAK,CAAC,SAAS,CAAC;AAE1D,QAAA,IAAI,MAAM,CAAC,QAAQ,CAAC,SAAS,CAAC,EAAE;AAC9B,YAAA,OAAO,SAAS;QAClB;QAEA,MAAM,QAAQ,GAAG,MAAM,CAAC,KAAK,CAAC,YAAY,CAAC,WAAW,CAAC,CAAC;AACxD,QAAA,OAAO,MAAM,CAAC,QAAQ,CAAC,QAAQ,CAAC,GAAG,QAAQ,GAAG,IAAI;IACpD;AAEQ,IAAA,WAAW,CAAC,KAAkB,EAAA;QACpC,MAAM,KAAK,GAAG,KAAK,CAAC,YAAY,CAAC,mBAAmB,CAAC;AACrD,QAAA,OAAO,KAAK,KAAK,IAAI,GAAG,IAAI,GAAG,YAAY,CAAC,KAAK,EAAE,CAAC,CAAC;IACvD;AAEQ,IAAA,OAAO,CAAC,KAAkB,EAAA;QAChC,OAAO,YAAY,CAAC,KAAK,CAAC,YAAY,CAAC,eAAe,CAAC,EAAE,CAAC,CAAC;IAC7D;AAEQ,IAAA,OAAO,CAAC,KAAkB,EAAA;QAChC,OAAO,YAAY,CAAC,KAAK,CAAC,YAAY,CAAC,eAAe,CAAC,EAAE,GAAG,CAAC;IAC/D;AAEQ,IAAA,aAAa,CAAC,KAAkB,EAAA;QACtC,OAAO,YAAY,CAAC,KAAK,CAAC,YAAY,CAAC,qBAAqB,CAAC,EAAE,CAAC,CAAC;IACnE;AAEQ,IAAA,WAAW,CAAC,KAAkB,EAAA;AACpC,QAAA,OAAO,KAAK,CAAC,YAAY,CAAC,kBAAkB,CAAC;IAC/C;wGA1QW,qBAAqB,EAAA,IAAA,EAAA,EAAA,EAAA,MAAA,EAAA,EAAA,CAAA,eAAA,CAAA,SAAA,EAAA,CAAA;4FAArB,qBAAqB,EAAA,YAAA,EAAA,IAAA,EAAA,QAAA,EAAA,sDAAA,EAAA,MAAA,EAAA,EAAA,WAAA,EAAA,EAAA,iBAAA,EAAA,aAAA,EAAA,UAAA,EAAA,aAAA,EAAA,QAAA,EAAA,IAAA,EAAA,UAAA,EAAA,KAAA,EAAA,iBAAA,EAAA,IAAA,EAAA,EAAA,QAAA,EAAA,EAAA,iBAAA,EAAA,UAAA,EAAA,UAAA,EAAA,UAAA,EAAA,QAAA,EAAA,IAAA,EAAA,UAAA,EAAA,KAAA,EAAA,iBAAA,EAAA,IAAA,EAAA,EAAA,EAAA,OAAA,EAAA,EAAA,YAAA,EAAA,cAAA,EAAA,EAAA,IAAA,EAAA,EAAA,UAAA,EAAA,EAAA,uBAAA,EAAA,eAAA,EAAA,oBAAA,EAAA,0BAAA,EAAA,EAAA,cAAA,EAAA,iBAAA,EAAA,EAAA,QAAA,EAAA,CAAA,uBAAA,CAAA,EAAA,QAAA,EAAA,EAAA,EAAA,CAAA;;4FAArB,qBAAqB,EAAA,UAAA,EAAA,CAAA;kBATjC,SAAS;AAAC,YAAA,IAAA,EAAA,CAAA;AACT,oBAAA,QAAQ,EAAE,sDAAsD;AAChE,oBAAA,QAAQ,EAAE,uBAAuB;AACjC,oBAAA,IAAI,EAAE;AACJ,wBAAA,KAAK,EAAE,iBAAiB;AACxB,wBAAA,yBAAyB,EAAE,eAAe;AAC1C,wBAAA,sBAAsB,EAAE,wBAAwB;AACjD,qBAAA;AACF,iBAAA;;MAyRY,gBAAgB,CAAA;AAClB,IAAA,WAAW,GAAG,KAAK,CAAkB,CAAC,EAAA,EAAA,IAAA,SAAA,GAAA,EAAA,SAAA,EAAA,aAAA,EAAA,8BAAA,EAAA,CAAA,EAAI,SAAS,EAAE,CAAC,KAAK,KAAK,YAAY,CAAC,KAAK,EAAE,CAAC,CAAC,GAAG;AACzF,IAAA,OAAO,GAAG,KAAK,CAAkB,CAAC,EAAA,EAAA,IAAA,SAAA,GAAA,EAAA,SAAA,EAAA,SAAA,EAAA,8BAAA,EAAA,CAAA,EAAI,SAAS,EAAE,CAAC,KAAK,KAAK,YAAY,CAAC,KAAK,EAAE,CAAC,CAAC,GAAG;AACrF,IAAA,OAAO,GAAG,KAAK,CAAkB,GAAG,EAAA,EAAA,IAAA,SAAA,GAAA,EAAA,SAAA,EAAA,SAAA,EAAA,8BAAA,EAAA,CAAA,EAAI,SAAS,EAAE,CAAC,KAAK,KAAK,YAAY,CAAC,KAAK,EAAE,GAAG,CAAC,GAAG;IACzF,WAAW,GAAG,KAAK,CAAC,KAAK,mFAAI,SAAS,EAAE,gBAAgB,EAAA,CAAG;AAC3D,IAAA,aAAa,GAAG,KAAK,CAAkB,CAAC,EAAA,EAAA,IAAA,SAAA,GAAA,EAAA,SAAA,EAAA,eAAA,EAAA,8BAAA,EAAA,CAAA,EAAI,SAAS,EAAE,CAAC,KAAK,KAAK,YAAY,CAAC,KAAK,EAAE,CAAC,CAAC,GAAG;wGALzF,gBAAgB,EAAA,IAAA,EAAA,EAAA,EAAA,MAAA,EAAA,EAAA,CAAA,eAAA,CAAA,SAAA,EAAA,CAAA;4FAAhB,gBAAgB,EAAA,YAAA,EAAA,IAAA,EAAA,QAAA,EAAA,2CAAA,EAAA,MAAA,EAAA,EAAA,WAAA,EAAA,EAAA,iBAAA,EAAA,aAAA,EAAA,UAAA,EAAA,aAAA,EAAA,QAAA,EAAA,IAAA,EAAA,UAAA,EAAA,KAAA,EAAA,iBAAA,EAAA,IAAA,EAAA,EAAA,OAAA,EAAA,EAAA,iBAAA,EAAA,SAAA,EAAA,UAAA,EAAA,SAAA,EAAA,QAAA,EAAA,IAAA,EAAA,UAAA,EAAA,KAAA,EAAA,iBAAA,EAAA,IAAA,EAAA,EAAA,OAAA,EAAA,EAAA,iBAAA,EAAA,SAAA,EAAA,UAAA,EAAA,SAAA,EAAA,QAAA,EAAA,IAAA,EAAA,UAAA,EAAA,KAAA,EAAA,iBAAA,EAAA,IAAA,EAAA,EAAA,WAAA,EAAA,EAAA,iBAAA,EAAA,aAAA,EAAA,UAAA,EAAA,aAAA,EAAA,QAAA,EAAA,IAAA,EAAA,UAAA,EAAA,KAAA,EAAA,iBAAA,EAAA,IAAA,EAAA,EAAA,aAAA,EAAA,EAAA,iBAAA,EAAA,eAAA,EAAA,UAAA,EAAA,eAAA,EAAA,QAAA,EAAA,IAAA,EAAA,UAAA,EAAA,KAAA,EAAA,iBAAA,EAAA,IAAA,EAAA,EAAA,EAAA,IAAA,EAAA,EAAA,UAAA,EAAA,EAAA,wBAAA,EAAA,eAAA,EAAA,oBAAA,EAAA,WAAA,EAAA,oBAAA,EAAA,WAAA,EAAA,uBAAA,EAAA,6BAAA,EAAA,0BAAA,EAAA,iBAAA,EAAA,EAAA,cAAA,EAAA,wBAAA,EAAA,EAAA,QAAA,EAAA,EAAA,EAAA,CAAA;;4FAAhB,gBAAgB,EAAA,UAAA,EAAA,CAAA;kBAX5B,SAAS;AAAC,YAAA,IAAA,EAAA,CAAA;AACT,oBAAA,QAAQ,EAAE,2CAA2C;AACrD,oBAAA,IAAI,EAAE;AACJ,wBAAA,KAAK,EAAE,wBAAwB;AAC/B,wBAAA,0BAA0B,EAAE,eAAe;AAC3C,wBAAA,sBAAsB,EAAE,WAAW;AACnC,wBAAA,sBAAsB,EAAE,WAAW;AACnC,wBAAA,yBAAyB,EAAE,2BAA2B;AACtD,wBAAA,4BAA4B,EAAE,iBAAiB;AAChD,qBAAA;AACF,iBAAA;;MAuBY,iBAAiB,CAAA;AACT,IAAA,KAAK,GAAG,MAAM,CAAC,qBAAqB,CAAC;AACvC,IAAA,UAAU,GAAG,MAAM,EAAC,UAAuB,EAAC;IAEpD,UAAU,GAAG,KAAK,CAAC,KAAK,kFAAI,SAAS,EAAE,gBAAgB,EAAA,CAAG;AAEzD,IAAA,aAAa,CAAC,KAAmB,EAAA;AACzC,QAAA,IAAI,KAAK,CAAC,MAAM,KAAK,CAAC,EAAE;YACtB;QACF;QAEA,KAAK,CAAC,cAAc,EAAE;QACtB,IAAI,CAAC,KAAK,CAAC,WAAW,CAAC,IAAI,CAAC,UAAU,CAAC,aAAa,EAAE,KAAK,CAAC,SAAS,EAAE,KAAK,CAAC,OAAO,EAAE,KAAK,CAAC,OAAO,CAAC;IACtG;AAEU,IAAA,SAAS,CAAC,KAAoB,EAAA;AACtC,QAAA,IAAI,IAAI,CAAC,KAAK,CAAC,kBAAkB,CAAC,IAAI,CAAC,UAAU,CAAC,aAAa,EAAE,KAAK,CAAC,GAAG,CAAC,EAAE;YAC3E,KAAK,CAAC,cAAc,EAAE;QACxB;IACF;wGAnBW,iBAAiB,EAAA,IAAA,EAAA,EAAA,EAAA,MAAA,EAAA,EAAA,CAAA,eAAA,CAAA,SAAA,EAAA,CAAA;4FAAjB,iBAAiB,EAAA,YAAA,EAAA,IAAA,EAAA,QAAA,EAAA,6CAAA,EAAA,MAAA,EAAA,EAAA,UAAA,EAAA,EAAA,iBAAA,EAAA,YAAA,EAAA,UAAA,EAAA,YAAA,EAAA,QAAA,EAAA,IAAA,EAAA,UAAA,EAAA,KAAA,EAAA,iBAAA,EAAA,IAAA,EAAA,EAAA,EAAA,IAAA,EAAA,EAAA,UAAA,EAAA,EAAA,MAAA,EAAA,WAAA,EAAA,UAAA,EAAA,GAAA,EAAA,EAAA,SAAA,EAAA,EAAA,aAAA,EAAA,uBAAA,EAAA,SAAA,EAAA,mBAAA,EAAA,EAAA,UAAA,EAAA,EAAA,uBAAA,EAAA,qBAAA,EAAA,uBAAA,EAAA,qBAAA,EAAA,kBAAA,EAAA,4BAAA,EAAA,oBAAA,EAAA,gCAAA,EAAA,EAAA,cAAA,EAAA,yBAAA,EAAA,EAAA,QAAA,EAAA,EAAA,EAAA,CAAA;;4FAAjB,iBAAiB,EAAA,UAAA,EAAA,CAAA;kBAd7B,SAAS;AAAC,YAAA,IAAA,EAAA,CAAA;AACT,oBAAA,QAAQ,EAAE,6CAA6C;AACvD,oBAAA,IAAI,EAAE;AACJ,wBAAA,KAAK,EAAE,yBAAyB;AAChC,wBAAA,IAAI,EAAE,WAAW;AACjB,wBAAA,QAAQ,EAAE,GAAG;AACb,wBAAA,yBAAyB,EAAE,qBAAqB;AAChD,wBAAA,yBAAyB,EAAE,qBAAqB;AAChD,wBAAA,oBAAoB,EAAE,0BAA0B;AAChD,wBAAA,sBAAsB,EAAE,8BAA8B;AACtD,wBAAA,eAAe,EAAE,uBAAuB;AACxC,wBAAA,WAAW,EAAE,mBAAmB;AACjC,qBAAA;AACF,iBAAA;;;MCpTY,iBAAiB,CAAA;wGAAjB,iBAAiB,EAAA,IAAA,EAAA,EAAA,EAAA,MAAA,EAAA,EAAA,CAAA,eAAA,CAAA,QAAA,EAAA,CAAA;AAAjB,IAAA,OAAA,IAAA,GAAA,EAAA,CAAA,mBAAA,CAAA,EAAA,UAAA,EAAA,QAAA,EAAA,OAAA,EAAA,SAAA,EAAA,QAAA,EAAA,EAAA,EAAA,IAAA,EAAA,iBAAiB,YAV1B,iBAAiB;YACjB,gBAAgB;AAChB,YAAA,qBAAqB,aAGrB,iBAAiB;YACjB,gBAAgB;YAChB,qBAAqB,CAAA,EAAA,CAAA;yGAGZ,iBAAiB,EAAA,CAAA;;4FAAjB,iBAAiB,EAAA,UAAA,EAAA,CAAA;kBAZ7B,QAAQ;AAAC,YAAA,IAAA,EAAA,CAAA;AACR,oBAAA,OAAO,EAAE;wBACP,iBAAiB;wBACjB,gBAAgB;wBAChB,qBAAqB;AACtB,qBAAA;AACD,oBAAA,OAAO,EAAE;wBACP,iBAAiB;wBACjB,gBAAgB;wBAChB,qBAAqB;AACtB,qBAAA;AACF,iBAAA;;;AClBD;;AAEG;;;;"}
|
|
@@ -81,18 +81,22 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "21.2.16", ngImpo
|
|
|
81
81
|
}]
|
|
82
82
|
}], propDecorators: { result: [{ type: i0.Input, args: [{ isSignal: true, alias: "frSheetClose", required: false }] }] } });
|
|
83
83
|
class FrSheetPanel {
|
|
84
|
+
dialogRef = inject(DialogRef, { optional: true });
|
|
84
85
|
scrollable = input(false, { ...(ngDevMode ? { debugName: "scrollable" } : /* istanbul ignore next */ {}), transform: booleanAttribute });
|
|
85
86
|
showCloseButton = input(true, { ...(ngDevMode ? { debugName: "showCloseButton" } : /* istanbul ignore next */ {}), transform: booleanAttribute });
|
|
86
87
|
side = input('right', { ...(ngDevMode ? { debugName: "side" } : /* istanbul ignore next */ {}), transform: coerceSheetSide });
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
<ng-content />
|
|
90
|
-
@if (showCloseButton()) {
|
|
91
|
-
<button class="frame-sheet__close" frSheetClose type="button" aria-label="Close sheet">
|
|
92
|
-
<span aria-hidden="true">×</span>
|
|
93
|
-
</button>
|
|
88
|
+
close() {
|
|
89
|
+
this.dialogRef?.close();
|
|
94
90
|
}
|
|
95
|
-
|
|
91
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "21.2.16", ngImport: i0, type: FrSheetPanel, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
92
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "21.2.16", type: FrSheetPanel, isStandalone: true, selector: "[frSheetPanel], frame-sheet-panel", inputs: { scrollable: { classPropertyName: "scrollable", publicName: "scrollable", isSignal: true, isRequired: false, transformFunction: null }, showCloseButton: { classPropertyName: "showCloseButton", publicName: "showCloseButton", isSignal: true, isRequired: false, transformFunction: null }, side: { classPropertyName: "side", publicName: "side", isSignal: true, isRequired: false, transformFunction: null } }, host: { properties: { "attr.data-scrollable": "scrollable() ? \"\" : null", "attr.data-side": "side()" }, classAttribute: "frame-sheet__panel" }, ngImport: i0, template: `
|
|
93
|
+
<ng-content />
|
|
94
|
+
@if (showCloseButton()) {
|
|
95
|
+
<button class="frame-sheet__close" type="button" aria-label="Close sheet" (click)="close()">
|
|
96
|
+
<span aria-hidden="true">×</span>
|
|
97
|
+
</button>
|
|
98
|
+
}
|
|
99
|
+
`, isInline: true });
|
|
96
100
|
}
|
|
97
101
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "21.2.16", ngImport: i0, type: FrSheetPanel, decorators: [{
|
|
98
102
|
type: Component,
|
|
@@ -103,15 +107,14 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "21.2.16", ngImpo
|
|
|
103
107
|
'[attr.data-scrollable]': 'scrollable() ? "" : null',
|
|
104
108
|
'[attr.data-side]': 'side()',
|
|
105
109
|
},
|
|
106
|
-
template: `
|
|
107
|
-
<ng-content />
|
|
108
|
-
@if (showCloseButton()) {
|
|
109
|
-
<button class="frame-sheet__close"
|
|
110
|
-
<span aria-hidden="true">×</span>
|
|
111
|
-
</button>
|
|
112
|
-
}
|
|
110
|
+
template: `
|
|
111
|
+
<ng-content />
|
|
112
|
+
@if (showCloseButton()) {
|
|
113
|
+
<button class="frame-sheet__close" type="button" aria-label="Close sheet" (click)="close()">
|
|
114
|
+
<span aria-hidden="true">×</span>
|
|
115
|
+
</button>
|
|
116
|
+
}
|
|
113
117
|
`,
|
|
114
|
-
imports: [FrSheetClose],
|
|
115
118
|
}]
|
|
116
119
|
}], propDecorators: { scrollable: [{ type: i0.Input, args: [{ isSignal: true, alias: "scrollable", required: false }] }], showCloseButton: [{ type: i0.Input, args: [{ isSignal: true, alias: "showCloseButton", required: false }] }], side: [{ type: i0.Input, args: [{ isSignal: true, alias: "side", required: false }] }] } });
|
|
117
120
|
class FrSheetHeader {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"frame-ui-ng-components-sheet.mjs","sources":["../../../projects/components/sheet/src/sheet.content.ts","../../../projects/components/sheet/src/sheet.primitives.ts","../../../projects/components/sheet/src/sheet.tokens.ts","../../../projects/components/sheet/src/sheet-shell.ts","../../../projects/components/sheet/src/sheet.service.ts","../../../projects/components/sheet/src/sheet.trigger.ts","../../../projects/components/sheet/sheet.module.ts","../../../projects/components/sheet/frame-ui-ng-components-sheet.ts"],"sourcesContent":["import { Direction } from '@angular/cdk/bidi';\nimport {\n Directive,\n TemplateRef,\n ViewContainerRef,\n booleanAttribute,\n inject,\n input,\n} from '@angular/core';\n\nimport { FrSheetConfig } from './sheet.service';\n\n@Directive({\n selector: 'ng-template[frSheetContent]',\n exportAs: 'frSheetContent',\n})\nexport class FrSheetContent {\n readonly templateRef = inject(TemplateRef<unknown>);\n\n readonly ariaLabel = input<string | null>(null, { alias: 'aria-label' });\n readonly ariaLabelledBy = input<string | null>(null, { alias: 'aria-labelledby' });\n readonly ariaDescribedBy = input<string | null>(null, { alias: 'aria-describedby' });\n readonly backdropClass = input<string | string[] | null>(null);\n readonly closeOnDestroy = input(true, { transform: booleanAttribute });\n readonly closeOnNavigation = input(true, { transform: booleanAttribute });\n readonly direction = input<Direction | null>(null);\n readonly disableClose = input(false, { transform: booleanAttribute });\n readonly height = input<string | null>(null);\n readonly id = input<string | null>(null);\n readonly maxHeight = input<string | null>(null);\n readonly maxWidth = input<string | null>(null);\n readonly minHeight = input<string | null>(null);\n readonly minWidth = input<string | null>(null);\n readonly panelClass = input<string | string[] | null>(null);\n readonly role = input<'dialog' | 'alertdialog'>('dialog');\n readonly width = input<string | null>(null);\n\n buildConfig(viewContainerRef: ViewContainerRef): FrSheetConfig {\n return {\n ariaLabel: this.ariaLabel() ?? undefined,\n ariaLabelledBy: this.ariaLabelledBy() ?? undefined,\n ariaDescribedBy: this.ariaDescribedBy() ?? undefined,\n backdropClass: this.backdropClass() ?? undefined,\n closeOnDestroy: this.closeOnDestroy(),\n closeOnNavigation: this.closeOnNavigation(),\n direction: this.direction() ?? undefined,\n disableClose: this.disableClose(),\n height: this.height() ?? undefined,\n id: this.id() ?? undefined,\n maxHeight: this.maxHeight() ?? undefined,\n maxWidth: this.maxWidth() ?? undefined,\n minHeight: this.minHeight() ?? undefined,\n minWidth: this.minWidth() ?? undefined,\n panelClass: this.panelClass() ?? undefined,\n role: this.role(),\n viewContainerRef,\n width: this.width() ?? undefined,\n };\n }\n}\n","import { DialogRef } from '@angular/cdk/dialog';\nimport { Component, Directive, booleanAttribute, inject, input } from '@angular/core';\n\nexport const FR_SHEET_SIDES = ['top', 'right', 'bottom', 'left'] as const;\nexport type FrSheetSide = (typeof FR_SHEET_SIDES)[number];\n\nfunction coerceSheetSide(value: unknown): FrSheetSide {\n return value === 'top' || value === 'bottom' || value === 'left' ? value : 'right';\n}\n\n@Directive({\n selector: '[frSheetClose]',\n host: {\n class: 'frame-sheet__close-control',\n '(click)': 'close()',\n },\n})\nexport class FrSheetClose {\n private readonly dialogRef = inject<DialogRef<unknown, unknown>>(DialogRef, { optional: true });\n readonly result = input<unknown>(undefined, { alias: 'frSheetClose' });\n\n close(): void {\n this.dialogRef?.close(this.result());\n }\n}\n\n@Component({\n selector: '[frSheetPanel], frame-sheet-panel',\n host: {\n class: 'frame-sheet__panel',\n '[attr.data-scrollable]': 'scrollable() ? \"\" : null',\n '[attr.data-side]': 'side()',\n },\n template: `\n <ng-content />\n @if (showCloseButton()) {\n <button class=\"frame-sheet__close\" frSheetClose type=\"button\" aria-label=\"Close sheet\">\n <span aria-hidden=\"true\">×</span>\n </button>\n }\n `,\n imports: [FrSheetClose],\n})\nexport class FrSheetPanel {\n readonly scrollable = input(false, { transform: booleanAttribute });\n readonly showCloseButton = input(true, { transform: booleanAttribute });\n readonly side = input<FrSheetSide, unknown>('right', { transform: coerceSheetSide });\n}\n\n@Directive({\n selector: '[frSheetHeader], frame-sheet-header',\n host: {\n class: 'frame-sheet__header',\n },\n})\nexport class FrSheetHeader {}\n\n@Directive({\n selector: '[frSheetBody], frame-sheet-body',\n host: {\n class: 'frame-sheet__body',\n },\n})\nexport class FrSheetBody {}\n\n@Directive({\n selector: '[frSheetFooter], frame-sheet-footer',\n host: {\n class: 'frame-sheet__footer',\n },\n})\nexport class FrSheetFooter {}\n\n@Directive({\n selector: '[frSheetTitle], frame-sheet-title',\n host: {\n class: 'frame-sheet__title',\n },\n})\nexport class FrSheetTitle {}\n\n@Directive({\n selector: '[frSheetDescription], frame-sheet-description',\n host: {\n class: 'frame-sheet__description',\n },\n})\nexport class FrSheetDescription {}\n","import { DIALOG_DATA } from '@angular/cdk/dialog';\n\nexport const FR_SHEET_DATA = DIALOG_DATA;\n","import { DIALOG_DATA, DialogRef } from '@angular/cdk/dialog';\nimport { NgComponentOutlet } from '@angular/common';\nimport { Component, Injector, Type, inject } from '@angular/core';\n\nimport { FrButton, FrButtonAppearance, FrButtonLabel } from '@frame-ui-ng/components/button';\nimport {\n FrSheetBody,\n FrSheetDescription,\n FrSheetFooter,\n FrSheetHeader,\n FrSheetPanel,\n FrSheetSide,\n FrSheetTitle,\n} from './sheet.primitives';\nimport { FR_SHEET_DATA } from './sheet.tokens';\n\nexport type FrSheetFooterAction = {\n appearance?: FrButtonAppearance;\n ariaLabel?: string;\n close?: boolean;\n disabled?: boolean;\n label: string;\n result?: unknown;\n};\n\nexport type FrSheetShellOptions = {\n bodyComponent: Type<unknown>;\n bodyData?: unknown;\n bodyInputs?: Record<string, unknown>;\n description?: string;\n footerActions?: FrSheetFooterAction[];\n scrollable?: boolean;\n showCloseButton?: boolean;\n side?: FrSheetSide;\n title?: string;\n};\n\n@Component({\n selector: 'frame-sheet-shell',\n imports: [\n FrButton,\n FrButtonLabel,\n FrSheetBody,\n FrSheetDescription,\n FrSheetFooter,\n FrSheetHeader,\n FrSheetPanel,\n FrSheetTitle,\n NgComponentOutlet,\n ],\n template: `\n <div\n frSheetPanel\n [side]=\"options.side ?? 'right'\"\n [showCloseButton]=\"options.showCloseButton ?? true\"\n [scrollable]=\"options.scrollable ?? false\"\n >\n @if (options.title || options.description) {\n <div frSheetHeader>\n @if (options.title) {\n <h2 frSheetTitle>{{ options.title }}</h2>\n }\n\n @if (options.description) {\n <p frSheetDescription>{{ options.description }}</p>\n }\n </div>\n }\n\n <div frSheetBody>\n <ng-container\n [ngComponentOutlet]=\"options.bodyComponent\"\n [ngComponentOutletInputs]=\"options.bodyInputs ?? {}\"\n [ngComponentOutletInjector]=\"bodyInjector\"\n />\n </div>\n\n @if (options.footerActions?.length) {\n <div frSheetFooter>\n @for (action of options.footerActions; track action.label) {\n <button\n frButton\n type=\"button\"\n [appearance]=\"action.appearance ?? 'primary'\"\n [disabled]=\"action.disabled ?? false\"\n [attr.aria-label]=\"action.ariaLabel ?? null\"\n (click)=\"handleAction(action)\"\n >\n <span frButtonLabel>{{ action.label }}</span>\n </button>\n }\n </div>\n }\n </div>\n `,\n})\nexport class FrSheetShell {\n private readonly dialogRef = inject(DialogRef<unknown>);\n private readonly injector = inject(Injector);\n readonly options = inject<FrSheetShellOptions>(DIALOG_DATA);\n readonly bodyInjector = Injector.create({\n parent: this.injector,\n providers: [\n {\n provide: FR_SHEET_DATA,\n useValue: this.options.bodyData,\n },\n ],\n });\n\n handleAction(action: FrSheetFooterAction): void {\n if (action.close ?? true) {\n this.dialogRef.close(action.result);\n }\n }\n}\n\r\n","import { Dialog, DialogConfig, DialogRef } from '@angular/cdk/dialog';\nimport { ComponentType } from '@angular/cdk/portal';\nimport { Injectable, TemplateRef, Type, inject } from '@angular/core';\n\nimport { FrSheetSide } from './sheet.primitives';\nimport { FrSheetFooterAction, FrSheetShell, FrSheetShellOptions } from './sheet-shell';\n\nexport type FrSheetRef<Result = unknown, Component = unknown> = DialogRef<Result, Component>;\nexport type FrSheetConfig<Data = unknown, Result = unknown, Component = unknown> = DialogConfig<\n Data,\n DialogRef<Result, Component>\n> & {\n bodyData?: unknown;\n bodyInputs?: Record<string, unknown>;\n description?: string;\n footerActions?: FrSheetFooterAction[];\n scrollable?: boolean;\n showCloseButton?: boolean;\n side?: FrSheetSide;\n title?: string;\n};\n\nconst DEFAULT_PANEL_CLASS = 'frame-sheet__overlay-pane';\nconst DEFAULT_BACKDROP_CLASS = 'frame-sheet__backdrop';\n\n@Injectable({ providedIn: 'root' })\nexport class FrSheetService {\n private readonly dialog = inject(Dialog);\n\n open<Result = unknown, Data = unknown, Component = unknown>(\n content: ComponentType<Component>,\n config?: FrSheetConfig<Data, Result, Component>,\n ): FrSheetRef<Result, Component>;\n open<Result = unknown, Data = unknown, Context = unknown>(\n content: TemplateRef<Context>,\n config?: FrSheetConfig<Data, Result, Context>,\n ): FrSheetRef<Result, Context>;\n open<Result = unknown, Data = unknown, ComponentOrContext = unknown>(\n content: ComponentType<ComponentOrContext> | TemplateRef<ComponentOrContext>,\n config: FrSheetConfig<Data, Result, ComponentOrContext> = {},\n ): FrSheetRef<Result, ComponentOrContext> {\n if (isComponentType(content) && hasShellOptions(config as FrSheetConfig)) {\n const shellConfig: DialogConfig<FrSheetShellOptions, DialogRef<Result, FrSheetShell>> = {\n ...(withoutShellOptions(config) as unknown as DialogConfig<\n FrSheetShellOptions,\n DialogRef<Result, FrSheetShell>\n >),\n data: {\n bodyComponent: content as Type<unknown>,\n bodyData: config.bodyData ?? config.data,\n bodyInputs: config.bodyInputs,\n description: config.description,\n footerActions: config.footerActions,\n scrollable: config.scrollable,\n showCloseButton: config.showCloseButton,\n side: config.side,\n title: config.title,\n },\n };\n\n return this.dialog.open<Result, FrSheetShellOptions, FrSheetShell>(\n FrSheetShell,\n this.withDefaultClasses(shellConfig),\n ) as unknown as FrSheetRef<Result, ComponentOrContext>;\n }\n\n return this.dialog.open<Result, Data, ComponentOrContext>(\n content,\n this.withDefaultClasses(config),\n );\n }\n\n closeAll(): void {\n this.dialog.closeAll();\n }\n\n private withDefaultClasses<Data, Result, Component>(\n config: DialogConfig<Data, DialogRef<Result, Component>>,\n ): DialogConfig<Data, DialogRef<Result, Component>> {\n return {\n ariaModal: true,\n autoFocus: 'first-tabbable',\n restoreFocus: true,\n ...config,\n maxHeight: config.maxHeight ?? '100dvh',\n maxWidth: config.maxWidth ?? '100vw',\n panelClass: mergeClassList(config.panelClass, DEFAULT_PANEL_CLASS),\n backdropClass: mergeClassList(config.backdropClass, DEFAULT_BACKDROP_CLASS),\n };\n }\n}\n\nfunction isComponentType(value: unknown): value is ComponentType<unknown> {\n return typeof value === 'function';\n}\n\nfunction hasShellOptions(config: FrSheetConfig): boolean {\n return [\n config.bodyData,\n config.bodyInputs,\n config.description,\n config.footerActions,\n config.scrollable,\n config.showCloseButton,\n config.side,\n config.title,\n ].some((value) => value !== undefined);\n}\n\nfunction withoutShellOptions<Data, Result, Component>(\n config: FrSheetConfig<Data, Result, Component>,\n): DialogConfig<Data, DialogRef<Result, Component>> {\n const {\n bodyData: _bodyData,\n bodyInputs: _bodyInputs,\n description: _description,\n footerActions: _footerActions,\n scrollable: _scrollable,\n showCloseButton: _showCloseButton,\n side: _side,\n title: _title,\n ...dialogConfig\n } = config;\n\n return dialogConfig;\n}\n\nfunction mergeClassList(\n classList: string | string[] | undefined,\n defaultClass: string,\n): string[] {\n const classes = Array.isArray(classList)\n ? classList\n : classList\n ? classList.split(/\\s+/)\n : [];\n\n return Array.from(new Set([defaultClass, ...classes].filter(Boolean)));\n}\n","import {\n DestroyRef,\n Directive,\n ElementRef,\n TemplateRef,\n ViewContainerRef,\n booleanAttribute,\n inject,\n input,\n output,\n signal,\n} from '@angular/core';\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\n\nimport { FrSheetContent } from './sheet.content';\nimport { FrSheetRef, FrSheetService } from './sheet.service';\n\n@Directive({\n selector: '[frSheetTrigger]',\n host: {\n class: 'frame-sheet__trigger',\n '[attr.aria-haspopup]': '\"dialog\"',\n '[attr.data-state]': 'isOpen() ? \"open\" : \"closed\"',\n '[attr.disabled]': 'disabled() ? \"\" : null',\n '[attr.aria-disabled]': 'disabled() ? \"true\" : null',\n '(click)': 'open()',\n },\n})\nexport class FrSheetTrigger {\n private static readonly CUSTOM_PROPERTY_PREFIX = '--frame-sheet-';\n\n private readonly destroyRef = inject(DestroyRef);\n private readonly elementRef = inject<ElementRef<HTMLElement>>(ElementRef);\n private readonly sheet = inject(FrSheetService);\n private readonly viewContainerRef = inject(ViewContainerRef);\n private sheetRef: FrSheetRef | null = null;\n\n readonly content = input<FrSheetContent | TemplateRef<unknown> | null>(null, {\n alias: 'frSheetTrigger',\n });\n readonly disabled = input(false, { transform: booleanAttribute });\n readonly opened = output<FrSheetRef>();\n readonly closed = output<unknown>();\n readonly isOpen = signal(false);\n\n open(): void {\n if (this.disabled() || this.isOpen()) {\n return;\n }\n\n const content = this.content();\n\n if (!content) {\n return;\n }\n\n const templateRef = content instanceof FrSheetContent ? content.templateRef : content;\n const config =\n content instanceof FrSheetContent\n ? content.buildConfig(this.viewContainerRef)\n : { viewContainerRef: this.viewContainerRef };\n\n this.sheetRef = this.sheet.open(templateRef, config);\n this.isOpen.set(true);\n this.opened.emit(this.sheetRef);\n queueMicrotask(() => this.syncCustomPropertiesToOverlay());\n\n this.sheetRef.closed.pipe(takeUntilDestroyed(this.destroyRef)).subscribe((result) => {\n this.isOpen.set(false);\n this.sheetRef = null;\n this.closed.emit(result);\n });\n }\n\n private syncCustomPropertiesToOverlay(): void {\n const overlayElement = this.sheetRef?.overlayRef.overlayElement ?? null;\n\n if (!overlayElement) {\n return;\n }\n\n const sheetPanel = overlayElement.querySelector<HTMLElement>('.frame-sheet__panel') ?? overlayElement;\n const sourceStyles = getComputedStyle(this.elementRef.nativeElement);\n\n for (let index = 0; index < sourceStyles.length; index += 1) {\n const propertyName = sourceStyles.item(index);\n\n if (!propertyName.startsWith(FrSheetTrigger.CUSTOM_PROPERTY_PREFIX)) {\n continue;\n }\n\n const propertyValue = sourceStyles.getPropertyValue(propertyName);\n\n overlayElement.style.setProperty(propertyName, propertyValue);\n sheetPanel.style.setProperty(propertyName, propertyValue);\n }\n }\n}\n","import { NgModule } from '@angular/core';\nimport {\n FrSheetBody,\n FrSheetClose,\n FrSheetContent,\n FrSheetDescription,\n FrSheetFooter,\n FrSheetHeader,\n FrSheetPanel,\n FrSheetShell,\n FrSheetTitle,\n FrSheetTrigger,\n} from './src/sheet';\n\n@NgModule({\n imports: [\n FrSheetBody,\n FrSheetClose,\n FrSheetContent,\n FrSheetDescription,\n FrSheetFooter,\n FrSheetHeader,\n FrSheetPanel,\n FrSheetShell,\n FrSheetTitle,\n FrSheetTrigger,\n ],\n exports: [\n FrSheetBody,\n FrSheetClose,\n FrSheetContent,\n FrSheetDescription,\n FrSheetFooter,\n FrSheetHeader,\n FrSheetPanel,\n FrSheetShell,\n FrSheetTitle,\n FrSheetTrigger,\n ],\n})\nexport class FrSheetModule {}\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './public-api';\n"],"names":[],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"frame-ui-ng-components-sheet.mjs","sources":["../../../projects/components/sheet/src/sheet.content.ts","../../../projects/components/sheet/src/sheet.primitives.ts","../../../projects/components/sheet/src/sheet.tokens.ts","../../../projects/components/sheet/src/sheet-shell.ts","../../../projects/components/sheet/src/sheet.service.ts","../../../projects/components/sheet/src/sheet.trigger.ts","../../../projects/components/sheet/sheet.module.ts","../../../projects/components/sheet/frame-ui-ng-components-sheet.ts"],"sourcesContent":["import { Direction } from '@angular/cdk/bidi';\nimport {\n Directive,\n TemplateRef,\n ViewContainerRef,\n booleanAttribute,\n inject,\n input,\n} from '@angular/core';\n\nimport { FrSheetConfig } from './sheet.service';\n\n@Directive({\n selector: 'ng-template[frSheetContent]',\n exportAs: 'frSheetContent',\n})\nexport class FrSheetContent {\n readonly templateRef = inject(TemplateRef<unknown>);\n\n readonly ariaLabel = input<string | null>(null, { alias: 'aria-label' });\n readonly ariaLabelledBy = input<string | null>(null, { alias: 'aria-labelledby' });\n readonly ariaDescribedBy = input<string | null>(null, { alias: 'aria-describedby' });\n readonly backdropClass = input<string | string[] | null>(null);\n readonly closeOnDestroy = input(true, { transform: booleanAttribute });\n readonly closeOnNavigation = input(true, { transform: booleanAttribute });\n readonly direction = input<Direction | null>(null);\n readonly disableClose = input(false, { transform: booleanAttribute });\n readonly height = input<string | null>(null);\n readonly id = input<string | null>(null);\n readonly maxHeight = input<string | null>(null);\n readonly maxWidth = input<string | null>(null);\n readonly minHeight = input<string | null>(null);\n readonly minWidth = input<string | null>(null);\n readonly panelClass = input<string | string[] | null>(null);\n readonly role = input<'dialog' | 'alertdialog'>('dialog');\n readonly width = input<string | null>(null);\n\n buildConfig(viewContainerRef: ViewContainerRef): FrSheetConfig {\n return {\n ariaLabel: this.ariaLabel() ?? undefined,\n ariaLabelledBy: this.ariaLabelledBy() ?? undefined,\n ariaDescribedBy: this.ariaDescribedBy() ?? undefined,\n backdropClass: this.backdropClass() ?? undefined,\n closeOnDestroy: this.closeOnDestroy(),\n closeOnNavigation: this.closeOnNavigation(),\n direction: this.direction() ?? undefined,\n disableClose: this.disableClose(),\n height: this.height() ?? undefined,\n id: this.id() ?? undefined,\n maxHeight: this.maxHeight() ?? undefined,\n maxWidth: this.maxWidth() ?? undefined,\n minHeight: this.minHeight() ?? undefined,\n minWidth: this.minWidth() ?? undefined,\n panelClass: this.panelClass() ?? undefined,\n role: this.role(),\n viewContainerRef,\n width: this.width() ?? undefined,\n };\n }\n}\n","import { DialogRef } from '@angular/cdk/dialog';\r\nimport { Component, Directive, booleanAttribute, inject, input } from '@angular/core';\r\n\r\nexport const FR_SHEET_SIDES = ['top', 'right', 'bottom', 'left'] as const;\r\nexport type FrSheetSide = (typeof FR_SHEET_SIDES)[number];\r\n\r\nfunction coerceSheetSide(value: unknown): FrSheetSide {\r\n return value === 'top' || value === 'bottom' || value === 'left' ? value : 'right';\r\n}\r\n\r\n@Directive({\r\n selector: '[frSheetClose]',\r\n host: {\r\n class: 'frame-sheet__close-control',\r\n '(click)': 'close()',\r\n },\r\n})\r\nexport class FrSheetClose {\r\n private readonly dialogRef = inject<DialogRef<unknown, unknown>>(DialogRef, { optional: true });\r\n readonly result = input<unknown>(undefined, { alias: 'frSheetClose' });\r\n\r\n close(): void {\r\n this.dialogRef?.close(this.result());\r\n }\r\n}\r\n\r\n@Component({\r\n selector: '[frSheetPanel], frame-sheet-panel',\r\n host: {\r\n class: 'frame-sheet__panel',\r\n '[attr.data-scrollable]': 'scrollable() ? \"\" : null',\r\n '[attr.data-side]': 'side()',\r\n },\r\n template: `\r\n <ng-content />\r\n @if (showCloseButton()) {\r\n <button class=\"frame-sheet__close\" type=\"button\" aria-label=\"Close sheet\" (click)=\"close()\">\r\n <span aria-hidden=\"true\">×</span>\r\n </button>\r\n }\r\n `,\r\n})\r\nexport class FrSheetPanel {\r\n private readonly dialogRef = inject<DialogRef<unknown, unknown>>(DialogRef, { optional: true });\r\n\r\n readonly scrollable = input(false, { transform: booleanAttribute });\r\n readonly showCloseButton = input(true, { transform: booleanAttribute });\r\n readonly side = input<FrSheetSide, unknown>('right', { transform: coerceSheetSide });\r\n\r\n close(): void {\r\n this.dialogRef?.close();\r\n }\r\n}\r\n\r\n@Directive({\r\n selector: '[frSheetHeader], frame-sheet-header',\r\n host: {\r\n class: 'frame-sheet__header',\r\n },\r\n})\r\nexport class FrSheetHeader {}\r\n\r\n@Directive({\r\n selector: '[frSheetBody], frame-sheet-body',\r\n host: {\r\n class: 'frame-sheet__body',\r\n },\r\n})\r\nexport class FrSheetBody {}\r\n\r\n@Directive({\r\n selector: '[frSheetFooter], frame-sheet-footer',\r\n host: {\r\n class: 'frame-sheet__footer',\r\n },\r\n})\r\nexport class FrSheetFooter {}\r\n\r\n@Directive({\r\n selector: '[frSheetTitle], frame-sheet-title',\r\n host: {\r\n class: 'frame-sheet__title',\r\n },\r\n})\r\nexport class FrSheetTitle {}\r\n\r\n@Directive({\r\n selector: '[frSheetDescription], frame-sheet-description',\r\n host: {\r\n class: 'frame-sheet__description',\r\n },\r\n})\r\nexport class FrSheetDescription {}\r\n","import { DIALOG_DATA } from '@angular/cdk/dialog';\n\nexport const FR_SHEET_DATA = DIALOG_DATA;\n","import { DIALOG_DATA, DialogRef } from '@angular/cdk/dialog';\nimport { NgComponentOutlet } from '@angular/common';\nimport { Component, Injector, Type, inject } from '@angular/core';\n\nimport { FrButton, FrButtonAppearance, FrButtonLabel } from '@frame-ui-ng/components/button';\nimport {\n FrSheetBody,\n FrSheetDescription,\n FrSheetFooter,\n FrSheetHeader,\n FrSheetPanel,\n FrSheetSide,\n FrSheetTitle,\n} from './sheet.primitives';\nimport { FR_SHEET_DATA } from './sheet.tokens';\n\nexport type FrSheetFooterAction = {\n appearance?: FrButtonAppearance;\n ariaLabel?: string;\n close?: boolean;\n disabled?: boolean;\n label: string;\n result?: unknown;\n};\n\nexport type FrSheetShellOptions = {\n bodyComponent: Type<unknown>;\n bodyData?: unknown;\n bodyInputs?: Record<string, unknown>;\n description?: string;\n footerActions?: FrSheetFooterAction[];\n scrollable?: boolean;\n showCloseButton?: boolean;\n side?: FrSheetSide;\n title?: string;\n};\n\n@Component({\n selector: 'frame-sheet-shell',\n imports: [\n FrButton,\n FrButtonLabel,\n FrSheetBody,\n FrSheetDescription,\n FrSheetFooter,\n FrSheetHeader,\n FrSheetPanel,\n FrSheetTitle,\n NgComponentOutlet,\n ],\n template: `\n <div\n frSheetPanel\n [side]=\"options.side ?? 'right'\"\n [showCloseButton]=\"options.showCloseButton ?? true\"\n [scrollable]=\"options.scrollable ?? false\"\n >\n @if (options.title || options.description) {\n <div frSheetHeader>\n @if (options.title) {\n <h2 frSheetTitle>{{ options.title }}</h2>\n }\n\n @if (options.description) {\n <p frSheetDescription>{{ options.description }}</p>\n }\n </div>\n }\n\n <div frSheetBody>\n <ng-container\n [ngComponentOutlet]=\"options.bodyComponent\"\n [ngComponentOutletInputs]=\"options.bodyInputs ?? {}\"\n [ngComponentOutletInjector]=\"bodyInjector\"\n />\n </div>\n\n @if (options.footerActions?.length) {\n <div frSheetFooter>\n @for (action of options.footerActions; track action.label) {\n <button\n frButton\n type=\"button\"\n [appearance]=\"action.appearance ?? 'primary'\"\n [disabled]=\"action.disabled ?? false\"\n [attr.aria-label]=\"action.ariaLabel ?? null\"\n (click)=\"handleAction(action)\"\n >\n <span frButtonLabel>{{ action.label }}</span>\n </button>\n }\n </div>\n }\n </div>\n `,\n})\nexport class FrSheetShell {\n private readonly dialogRef = inject(DialogRef<unknown>);\n private readonly injector = inject(Injector);\n readonly options = inject<FrSheetShellOptions>(DIALOG_DATA);\n readonly bodyInjector = Injector.create({\n parent: this.injector,\n providers: [\n {\n provide: FR_SHEET_DATA,\n useValue: this.options.bodyData,\n },\n ],\n });\n\n handleAction(action: FrSheetFooterAction): void {\n if (action.close ?? true) {\n this.dialogRef.close(action.result);\n }\n }\n}\n\r\n","import { Dialog, DialogConfig, DialogRef } from '@angular/cdk/dialog';\nimport { ComponentType } from '@angular/cdk/portal';\nimport { Injectable, TemplateRef, Type, inject } from '@angular/core';\n\nimport { FrSheetSide } from './sheet.primitives';\nimport { FrSheetFooterAction, FrSheetShell, FrSheetShellOptions } from './sheet-shell';\n\nexport type FrSheetRef<Result = unknown, Component = unknown> = DialogRef<Result, Component>;\nexport type FrSheetConfig<Data = unknown, Result = unknown, Component = unknown> = DialogConfig<\n Data,\n DialogRef<Result, Component>\n> & {\n bodyData?: unknown;\n bodyInputs?: Record<string, unknown>;\n description?: string;\n footerActions?: FrSheetFooterAction[];\n scrollable?: boolean;\n showCloseButton?: boolean;\n side?: FrSheetSide;\n title?: string;\n};\n\nconst DEFAULT_PANEL_CLASS = 'frame-sheet__overlay-pane';\nconst DEFAULT_BACKDROP_CLASS = 'frame-sheet__backdrop';\n\n@Injectable({ providedIn: 'root' })\nexport class FrSheetService {\n private readonly dialog = inject(Dialog);\n\n open<Result = unknown, Data = unknown, Component = unknown>(\n content: ComponentType<Component>,\n config?: FrSheetConfig<Data, Result, Component>,\n ): FrSheetRef<Result, Component>;\n open<Result = unknown, Data = unknown, Context = unknown>(\n content: TemplateRef<Context>,\n config?: FrSheetConfig<Data, Result, Context>,\n ): FrSheetRef<Result, Context>;\n open<Result = unknown, Data = unknown, ComponentOrContext = unknown>(\n content: ComponentType<ComponentOrContext> | TemplateRef<ComponentOrContext>,\n config: FrSheetConfig<Data, Result, ComponentOrContext> = {},\n ): FrSheetRef<Result, ComponentOrContext> {\n if (isComponentType(content) && hasShellOptions(config as FrSheetConfig)) {\n const shellConfig: DialogConfig<FrSheetShellOptions, DialogRef<Result, FrSheetShell>> = {\n ...(withoutShellOptions(config) as unknown as DialogConfig<\n FrSheetShellOptions,\n DialogRef<Result, FrSheetShell>\n >),\n data: {\n bodyComponent: content as Type<unknown>,\n bodyData: config.bodyData ?? config.data,\n bodyInputs: config.bodyInputs,\n description: config.description,\n footerActions: config.footerActions,\n scrollable: config.scrollable,\n showCloseButton: config.showCloseButton,\n side: config.side,\n title: config.title,\n },\n };\n\n return this.dialog.open<Result, FrSheetShellOptions, FrSheetShell>(\n FrSheetShell,\n this.withDefaultClasses(shellConfig),\n ) as unknown as FrSheetRef<Result, ComponentOrContext>;\n }\n\n return this.dialog.open<Result, Data, ComponentOrContext>(\n content,\n this.withDefaultClasses(config),\n );\n }\n\n closeAll(): void {\n this.dialog.closeAll();\n }\n\n private withDefaultClasses<Data, Result, Component>(\n config: DialogConfig<Data, DialogRef<Result, Component>>,\n ): DialogConfig<Data, DialogRef<Result, Component>> {\n return {\n ariaModal: true,\n autoFocus: 'first-tabbable',\n restoreFocus: true,\n ...config,\n maxHeight: config.maxHeight ?? '100dvh',\n maxWidth: config.maxWidth ?? '100vw',\n panelClass: mergeClassList(config.panelClass, DEFAULT_PANEL_CLASS),\n backdropClass: mergeClassList(config.backdropClass, DEFAULT_BACKDROP_CLASS),\n };\n }\n}\n\nfunction isComponentType(value: unknown): value is ComponentType<unknown> {\n return typeof value === 'function';\n}\n\nfunction hasShellOptions(config: FrSheetConfig): boolean {\n return [\n config.bodyData,\n config.bodyInputs,\n config.description,\n config.footerActions,\n config.scrollable,\n config.showCloseButton,\n config.side,\n config.title,\n ].some((value) => value !== undefined);\n}\n\nfunction withoutShellOptions<Data, Result, Component>(\n config: FrSheetConfig<Data, Result, Component>,\n): DialogConfig<Data, DialogRef<Result, Component>> {\n const {\n bodyData: _bodyData,\n bodyInputs: _bodyInputs,\n description: _description,\n footerActions: _footerActions,\n scrollable: _scrollable,\n showCloseButton: _showCloseButton,\n side: _side,\n title: _title,\n ...dialogConfig\n } = config;\n\n return dialogConfig;\n}\n\nfunction mergeClassList(\n classList: string | string[] | undefined,\n defaultClass: string,\n): string[] {\n const classes = Array.isArray(classList)\n ? classList\n : classList\n ? classList.split(/\\s+/)\n : [];\n\n return Array.from(new Set([defaultClass, ...classes].filter(Boolean)));\n}\n","import {\n DestroyRef,\n Directive,\n ElementRef,\n TemplateRef,\n ViewContainerRef,\n booleanAttribute,\n inject,\n input,\n output,\n signal,\n} from '@angular/core';\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\n\nimport { FrSheetContent } from './sheet.content';\nimport { FrSheetRef, FrSheetService } from './sheet.service';\n\n@Directive({\n selector: '[frSheetTrigger]',\n host: {\n class: 'frame-sheet__trigger',\n '[attr.aria-haspopup]': '\"dialog\"',\n '[attr.data-state]': 'isOpen() ? \"open\" : \"closed\"',\n '[attr.disabled]': 'disabled() ? \"\" : null',\n '[attr.aria-disabled]': 'disabled() ? \"true\" : null',\n '(click)': 'open()',\n },\n})\nexport class FrSheetTrigger {\n private static readonly CUSTOM_PROPERTY_PREFIX = '--frame-sheet-';\n\n private readonly destroyRef = inject(DestroyRef);\n private readonly elementRef = inject<ElementRef<HTMLElement>>(ElementRef);\n private readonly sheet = inject(FrSheetService);\n private readonly viewContainerRef = inject(ViewContainerRef);\n private sheetRef: FrSheetRef | null = null;\n\n readonly content = input<FrSheetContent | TemplateRef<unknown> | null>(null, {\n alias: 'frSheetTrigger',\n });\n readonly disabled = input(false, { transform: booleanAttribute });\n readonly opened = output<FrSheetRef>();\n readonly closed = output<unknown>();\n readonly isOpen = signal(false);\n\n open(): void {\n if (this.disabled() || this.isOpen()) {\n return;\n }\n\n const content = this.content();\n\n if (!content) {\n return;\n }\n\n const templateRef = content instanceof FrSheetContent ? content.templateRef : content;\n const config =\n content instanceof FrSheetContent\n ? content.buildConfig(this.viewContainerRef)\n : { viewContainerRef: this.viewContainerRef };\n\n this.sheetRef = this.sheet.open(templateRef, config);\n this.isOpen.set(true);\n this.opened.emit(this.sheetRef);\n queueMicrotask(() => this.syncCustomPropertiesToOverlay());\n\n this.sheetRef.closed.pipe(takeUntilDestroyed(this.destroyRef)).subscribe((result) => {\n this.isOpen.set(false);\n this.sheetRef = null;\n this.closed.emit(result);\n });\n }\n\n private syncCustomPropertiesToOverlay(): void {\n const overlayElement = this.sheetRef?.overlayRef.overlayElement ?? null;\n\n if (!overlayElement) {\n return;\n }\n\n const sheetPanel = overlayElement.querySelector<HTMLElement>('.frame-sheet__panel') ?? overlayElement;\n const sourceStyles = getComputedStyle(this.elementRef.nativeElement);\n\n for (let index = 0; index < sourceStyles.length; index += 1) {\n const propertyName = sourceStyles.item(index);\n\n if (!propertyName.startsWith(FrSheetTrigger.CUSTOM_PROPERTY_PREFIX)) {\n continue;\n }\n\n const propertyValue = sourceStyles.getPropertyValue(propertyName);\n\n overlayElement.style.setProperty(propertyName, propertyValue);\n sheetPanel.style.setProperty(propertyName, propertyValue);\n }\n }\n}\n","import { NgModule } from '@angular/core';\nimport {\n FrSheetBody,\n FrSheetClose,\n FrSheetContent,\n FrSheetDescription,\n FrSheetFooter,\n FrSheetHeader,\n FrSheetPanel,\n FrSheetShell,\n FrSheetTitle,\n FrSheetTrigger,\n} from './src/sheet';\n\n@NgModule({\n imports: [\n FrSheetBody,\n FrSheetClose,\n FrSheetContent,\n FrSheetDescription,\n FrSheetFooter,\n FrSheetHeader,\n FrSheetPanel,\n FrSheetShell,\n FrSheetTitle,\n FrSheetTrigger,\n ],\n exports: [\n FrSheetBody,\n FrSheetClose,\n FrSheetContent,\n FrSheetDescription,\n FrSheetFooter,\n FrSheetHeader,\n FrSheetPanel,\n FrSheetShell,\n FrSheetTitle,\n FrSheetTrigger,\n ],\n})\nexport class FrSheetModule {}\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './public-api';\n"],"names":[],"mappings":"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"}
|
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
import * as i0 from '@angular/core';
|
|
2
|
-
import { InjectionToken, numberAttribute, inject, ElementRef, signal, input, booleanAttribute, output, computed, effect,
|
|
2
|
+
import { InjectionToken, numberAttribute, inject, ElementRef, signal, input, booleanAttribute, output, computed, effect, Directive, NgModule } from '@angular/core';
|
|
3
3
|
import { DOCUMENT } from '@angular/common';
|
|
4
|
+
import { clampNumber } from '@frame-ui-ng/components/utils';
|
|
4
5
|
|
|
5
6
|
const FR_SIDEBAR_SIDES = ['left', 'right'];
|
|
6
7
|
const FR_SIDEBAR_VARIANTS = ['sidebar', 'floating', 'inset'];
|
|
@@ -125,12 +126,10 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "21.2.16", ngImpo
|
|
|
125
126
|
'[attr.data-mobile-open]': 'openMobile()',
|
|
126
127
|
'[attr.data-mobile]': 'isMobile() ? "" : null',
|
|
127
128
|
'[attr.data-resizing]': 'resizing() ? "" : null',
|
|
129
|
+
'(document:keydown)': 'handleKeydown($event)',
|
|
128
130
|
},
|
|
129
131
|
}]
|
|
130
|
-
}], ctorParameters: () => [], propDecorators: { defaultOpen: [{ type: i0.Input, args: [{ isSignal: true, alias: "defaultOpen", required: false }] }], openInput: [{ type: i0.Input, args: [{ isSignal: true, alias: "open", required: false }] }], openChange: [{ type: i0.Output, args: ["openChange"] }], openMobileChange: [{ type: i0.Output, args: ["openMobileChange"] }], shortcut: [{ type: i0.Input, args: [{ isSignal: true, alias: "shortcut", required: false }] }], keyboardShortcut: [{ type: i0.Input, args: [{ isSignal: true, alias: "keyboardShortcut", required: false }] }]
|
|
131
|
-
type: HostListener,
|
|
132
|
-
args: ['document:keydown', ['$event']]
|
|
133
|
-
}] } });
|
|
132
|
+
}], ctorParameters: () => [], propDecorators: { defaultOpen: [{ type: i0.Input, args: [{ isSignal: true, alias: "defaultOpen", required: false }] }], openInput: [{ type: i0.Input, args: [{ isSignal: true, alias: "open", required: false }] }], openChange: [{ type: i0.Output, args: ["openChange"] }], openMobileChange: [{ type: i0.Output, args: ["openMobileChange"] }], shortcut: [{ type: i0.Input, args: [{ isSignal: true, alias: "shortcut", required: false }] }], keyboardShortcut: [{ type: i0.Input, args: [{ isSignal: true, alias: "keyboardShortcut", required: false }] }] } });
|
|
134
133
|
class FrSidebar {
|
|
135
134
|
elementRef = inject(ElementRef);
|
|
136
135
|
provider = inject(FR_SIDEBAR_PROVIDER, { optional: true });
|
|
@@ -139,8 +138,9 @@ class FrSidebar {
|
|
|
139
138
|
collapsible = input('offcanvas', { ...(ngDevMode ? { debugName: "collapsible" } : /* istanbul ignore next */ {}), transform: coerceCollapsible });
|
|
140
139
|
minSize = input(null, { ...(ngDevMode ? { debugName: "minSize" } : /* istanbul ignore next */ {}), transform: coerceOptionalNumber });
|
|
141
140
|
maxSize = input(384, { ...(ngDevMode ? { debugName: "maxSize" } : /* istanbul ignore next */ {}), transform: coerceOptionalNumber });
|
|
141
|
+
resizable = input(true, { ...(ngDevMode ? { debugName: "resizable" } : /* istanbul ignore next */ {}), transform: booleanAttribute });
|
|
142
142
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "21.2.16", ngImport: i0, type: FrSidebar, deps: [], target: i0.ɵɵFactoryTarget.Directive });
|
|
143
|
-
static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "17.1.0", version: "21.2.16", type: FrSidebar, isStandalone: true, selector: "[frSidebar], frame-sidebar", inputs: { side: { classPropertyName: "side", publicName: "side", isSignal: true, isRequired: false, transformFunction: null }, variant: { classPropertyName: "variant", publicName: "variant", isSignal: true, isRequired: false, transformFunction: null }, collapsible: { classPropertyName: "collapsible", publicName: "collapsible", isSignal: true, isRequired: false, transformFunction: null }, minSize: { classPropertyName: "minSize", publicName: "minSize", isSignal: true, isRequired: false, transformFunction: null }, maxSize: { classPropertyName: "maxSize", publicName: "maxSize", isSignal: true, isRequired: false, transformFunction: null } }, host: { properties: { "attr.data-side": "side()", "attr.data-variant": "variant()", "attr.data-collapsible": "collapsible()", "attr.data-state": "provider?.state() ?? \"expanded\"", "attr.data-mobile-open": "provider?.openMobile() ?? false" }, classAttribute: "frame-sidebar" }, ngImport: i0 });
|
|
143
|
+
static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "17.1.0", version: "21.2.16", type: FrSidebar, isStandalone: true, selector: "[frSidebar], frame-sidebar", inputs: { side: { classPropertyName: "side", publicName: "side", isSignal: true, isRequired: false, transformFunction: null }, variant: { classPropertyName: "variant", publicName: "variant", isSignal: true, isRequired: false, transformFunction: null }, collapsible: { classPropertyName: "collapsible", publicName: "collapsible", isSignal: true, isRequired: false, transformFunction: null }, minSize: { classPropertyName: "minSize", publicName: "minSize", isSignal: true, isRequired: false, transformFunction: null }, maxSize: { classPropertyName: "maxSize", publicName: "maxSize", isSignal: true, isRequired: false, transformFunction: null }, resizable: { classPropertyName: "resizable", publicName: "resizable", isSignal: true, isRequired: false, transformFunction: null } }, host: { properties: { "attr.data-side": "side()", "attr.data-variant": "variant()", "attr.data-collapsible": "collapsible()", "attr.data-resizable": "resizable() ? \"\" : null", "attr.data-state": "provider?.state() ?? \"expanded\"", "attr.data-mobile-open": "provider?.openMobile() ?? false" }, classAttribute: "frame-sidebar" }, ngImport: i0 });
|
|
144
144
|
}
|
|
145
145
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "21.2.16", ngImport: i0, type: FrSidebar, decorators: [{
|
|
146
146
|
type: Directive,
|
|
@@ -151,11 +151,12 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "21.2.16", ngImpo
|
|
|
151
151
|
'[attr.data-side]': 'side()',
|
|
152
152
|
'[attr.data-variant]': 'variant()',
|
|
153
153
|
'[attr.data-collapsible]': 'collapsible()',
|
|
154
|
+
'[attr.data-resizable]': 'resizable() ? "" : null',
|
|
154
155
|
'[attr.data-state]': 'provider?.state() ?? "expanded"',
|
|
155
156
|
'[attr.data-mobile-open]': 'provider?.openMobile() ?? false',
|
|
156
157
|
},
|
|
157
158
|
}]
|
|
158
|
-
}], propDecorators: { side: [{ type: i0.Input, args: [{ isSignal: true, alias: "side", required: false }] }], variant: [{ type: i0.Input, args: [{ isSignal: true, alias: "variant", required: false }] }], collapsible: [{ type: i0.Input, args: [{ isSignal: true, alias: "collapsible", required: false }] }], minSize: [{ type: i0.Input, args: [{ isSignal: true, alias: "minSize", required: false }] }], maxSize: [{ type: i0.Input, args: [{ isSignal: true, alias: "maxSize", required: false }] }] } });
|
|
159
|
+
}], propDecorators: { side: [{ type: i0.Input, args: [{ isSignal: true, alias: "side", required: false }] }], variant: [{ type: i0.Input, args: [{ isSignal: true, alias: "variant", required: false }] }], collapsible: [{ type: i0.Input, args: [{ isSignal: true, alias: "collapsible", required: false }] }], minSize: [{ type: i0.Input, args: [{ isSignal: true, alias: "minSize", required: false }] }], maxSize: [{ type: i0.Input, args: [{ isSignal: true, alias: "maxSize", required: false }] }], resizable: [{ type: i0.Input, args: [{ isSignal: true, alias: "resizable", required: false }] }] } });
|
|
159
160
|
class FrSidebarTrigger {
|
|
160
161
|
provider = inject(FR_SIDEBAR_PROVIDER, { optional: true });
|
|
161
162
|
ariaLabel = input('Toggle sidebar', { ...(ngDevMode ? { debugName: "ariaLabel" } : /* istanbul ignore next */ {}), alias: 'aria-label' });
|
|
@@ -194,10 +195,13 @@ class FrSidebarRail {
|
|
|
194
195
|
if (this.suppressClick) {
|
|
195
196
|
return;
|
|
196
197
|
}
|
|
198
|
+
if (this.sidebar?.collapsible() === 'icon') {
|
|
199
|
+
return;
|
|
200
|
+
}
|
|
197
201
|
this.provider?.toggleSidebar();
|
|
198
202
|
}
|
|
199
203
|
startResize(event) {
|
|
200
|
-
if (!this.sidebar || !this.provider || this.provider.isMobile()) {
|
|
204
|
+
if (!this.sidebar || !this.provider || this.provider.isMobile() || !this.sidebar.resizable()) {
|
|
201
205
|
return;
|
|
202
206
|
}
|
|
203
207
|
this.startX = event.clientX;
|
|
@@ -211,7 +215,9 @@ class FrSidebarRail {
|
|
|
211
215
|
const up = () => {
|
|
212
216
|
this.document.removeEventListener('pointermove', move);
|
|
213
217
|
this.document.removeEventListener('pointerup', up);
|
|
214
|
-
this.
|
|
218
|
+
if (this.dragging) {
|
|
219
|
+
this.flushResize();
|
|
220
|
+
}
|
|
215
221
|
this.provider?.setResizing(false);
|
|
216
222
|
this.suppressClick = this.dragging;
|
|
217
223
|
this.dragging = false;
|
|
@@ -231,9 +237,12 @@ class FrSidebarRail {
|
|
|
231
237
|
}
|
|
232
238
|
const delta = event.clientX - this.startX;
|
|
233
239
|
const direction = this.sidebar.side() === 'right' ? -1 : 1;
|
|
234
|
-
const nextWidth =
|
|
240
|
+
const nextWidth = clampNumber(this.startWidth + delta * direction, this.resizeMinSize, this.resizeMaxSize);
|
|
235
241
|
if (Math.abs(delta) > 3) {
|
|
236
242
|
this.dragging = true;
|
|
243
|
+
if (this.sidebar.collapsible() === 'icon' && !this.provider.open()) {
|
|
244
|
+
this.provider.setOpen(true);
|
|
245
|
+
}
|
|
237
246
|
}
|
|
238
247
|
this.pendingWidth = nextWidth;
|
|
239
248
|
if (this.frameId !== -1) {
|
|
@@ -253,9 +262,6 @@ class FrSidebarRail {
|
|
|
253
262
|
this.provider?.setSidebarWidth(this.pendingWidth);
|
|
254
263
|
}
|
|
255
264
|
}
|
|
256
|
-
clampWidth(width) {
|
|
257
|
-
return Math.min(Math.max(width, this.resizeMinSize), this.resizeMaxSize);
|
|
258
|
-
}
|
|
259
265
|
captureResizeBounds() {
|
|
260
266
|
if (!this.sidebar) {
|
|
261
267
|
return;
|