@hestia-earth/ui-components 0.27.62 → 0.27.64
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/common/drawer-container/sidenav.store.d.ts +15 -0
- package/cycles/cycles-completeness/cycles-completeness.component.d.ts +27 -27
- package/cycles/cycles-nodes/cycles-nodes.component.d.ts +47 -46
- package/engine/engine-models-stage-deep/engine-models-stage-deep.component.d.ts +2 -2
- package/esm2022/common/drawer-container/drawer-container.component.mjs +8 -8
- package/esm2022/common/drawer-container/sidenav.store.mjs +2 -2
- package/esm2022/cycles/cycles-completeness/cycles-completeness.component.mjs +14 -8
- package/esm2022/cycles/cycles-nodes/cycles-nodes.component.mjs +13 -6
- package/esm2022/engine/engine-models-stage-deep/engine-models-stage-deep.component.mjs +16 -5
- package/esm2022/files/files-error.model.mjs +6 -1
- package/esm2022/files/files-form/files-form.component.mjs +3 -3
- package/esm2022/impact-assessments/impact-assessments-products/impact-assessments-products.component.mjs +13 -6
- package/esm2022/node/node-logs-models/node-logs-models.component.mjs +3 -3
- package/esm2022/node/node-value-details/node-value-details.component.mjs +3 -3
- package/esm2022/sites/sites-management-chart/sites-management-chart.component.mjs +4 -3
- package/esm2022/sites/sites-nodes/sites-nodes.component.mjs +17 -9
- package/fesm2022/hestia-earth-ui-components.mjs +80 -39
- package/fesm2022/hestia-earth-ui-components.mjs.map +1 -1
- package/impact-assessments/impact-assessments-products/impact-assessments-products.component.d.ts +38 -37
- package/package.json +1 -1
- package/sites/sites-nodes/sites-nodes.component.d.ts +39 -38
|
@@ -1,3 +1,18 @@
|
|
|
1
|
+
export declare const initialState: {
|
|
2
|
+
minWidth: number;
|
|
3
|
+
maxWidth: number;
|
|
4
|
+
width: number;
|
|
5
|
+
expanded: boolean;
|
|
6
|
+
side: "left" | "right";
|
|
7
|
+
resizeEvent: {
|
|
8
|
+
isResizing: boolean;
|
|
9
|
+
startingCursorX: number;
|
|
10
|
+
startingWidth: number;
|
|
11
|
+
newWidth: number;
|
|
12
|
+
};
|
|
13
|
+
contentContainerSpacing: number;
|
|
14
|
+
minMenuDistance: number;
|
|
15
|
+
};
|
|
1
16
|
export declare const sidenavStore: import("@angular/core").Type<{
|
|
2
17
|
expanded: import("@angular/core").Signal<boolean>;
|
|
3
18
|
maxWidth: import("@angular/core").Signal<number>;
|
|
@@ -7,34 +7,33 @@ declare enum View {
|
|
|
7
7
|
logs = "Recalculations logs"
|
|
8
8
|
}
|
|
9
9
|
export declare class CyclesCompletenessComponent {
|
|
10
|
-
private
|
|
10
|
+
private readonly modalService;
|
|
11
|
+
private readonly nodeStoreService;
|
|
11
12
|
protected readonly faDownload: IconDefinition;
|
|
12
|
-
protected dataState: import("@angular/core").InputSignal<DataState>;
|
|
13
|
-
protected schemaBaseUrl: string;
|
|
14
|
-
protected defaultLabel: (node?: any) => any;
|
|
15
|
-
protected keyToLabel: (key: string) => string;
|
|
16
|
-
protected getCompleteness: (cycle: any) => any;
|
|
17
|
-
protected
|
|
18
|
-
protected
|
|
19
|
-
protected
|
|
20
|
-
protected View: typeof View;
|
|
21
|
-
protected viewIcon: {
|
|
13
|
+
protected readonly dataState: import("@angular/core").InputSignal<DataState>;
|
|
14
|
+
protected readonly schemaBaseUrl: string;
|
|
15
|
+
protected readonly defaultLabel: (node?: any) => any;
|
|
16
|
+
protected readonly keyToLabel: (key: string) => string;
|
|
17
|
+
protected readonly getCompleteness: (cycle: any) => any;
|
|
18
|
+
protected readonly nodeKey = NonBlankNodesKey.completeness;
|
|
19
|
+
protected readonly View: typeof View;
|
|
20
|
+
protected readonly viewIcon: {
|
|
22
21
|
"Table view": IconDefinition;
|
|
23
22
|
"Recalculations logs": IconDefinition;
|
|
24
23
|
};
|
|
25
|
-
private showView;
|
|
26
|
-
protected views: import("@angular/core").Signal<View[]>;
|
|
27
|
-
protected selectedView: import("@angular/core").WritableSignal<View>;
|
|
28
|
-
private originalCycles;
|
|
29
|
-
private _allCycles;
|
|
30
|
-
protected cycles: import("@angular/core").Signal<ICycleJSONLD[]>;
|
|
31
|
-
private selectedIndex;
|
|
32
|
-
private ogirinalSelectedCycle;
|
|
33
|
-
private selectedCycle;
|
|
34
|
-
protected selectedLogsKey: import("@angular/core").Signal<any>;
|
|
35
|
-
protected selectedOriginalValues: import("@angular/core").Signal<any>;
|
|
36
|
-
protected selectedRecalculatedValues: import("@angular/core").Signal<any>;
|
|
37
|
-
protected selectedNode: import("@angular/core").Signal<{
|
|
24
|
+
private readonly showView;
|
|
25
|
+
protected readonly views: import("@angular/core").Signal<View[]>;
|
|
26
|
+
protected readonly selectedView: import("@angular/core").WritableSignal<View>;
|
|
27
|
+
private readonly originalCycles;
|
|
28
|
+
private readonly _allCycles;
|
|
29
|
+
protected readonly cycles: import("@angular/core").Signal<ICycleJSONLD[]>;
|
|
30
|
+
private readonly selectedIndex;
|
|
31
|
+
private readonly ogirinalSelectedCycle;
|
|
32
|
+
private readonly selectedCycle;
|
|
33
|
+
protected readonly selectedLogsKey: import("@angular/core").Signal<any>;
|
|
34
|
+
protected readonly selectedOriginalValues: import("@angular/core").Signal<any>;
|
|
35
|
+
protected readonly selectedRecalculatedValues: import("@angular/core").Signal<any>;
|
|
36
|
+
protected readonly selectedNode: import("@angular/core").Signal<{
|
|
38
37
|
'@type': NodeType;
|
|
39
38
|
type: NodeType;
|
|
40
39
|
dataState: DataState;
|
|
@@ -89,9 +88,9 @@ export declare class CyclesCompletenessComponent {
|
|
|
89
88
|
'@id': string;
|
|
90
89
|
name: string;
|
|
91
90
|
}>;
|
|
92
|
-
protected hasData: import("@angular/core").Signal<number>;
|
|
93
|
-
protected isOriginal: import("@angular/core").Signal<boolean>;
|
|
94
|
-
protected completenessKeys: import("@angular/core").Signal<string[]>;
|
|
91
|
+
protected readonly hasData: import("@angular/core").Signal<number>;
|
|
92
|
+
protected readonly isOriginal: import("@angular/core").Signal<boolean>;
|
|
93
|
+
protected readonly completenessKeys: import("@angular/core").Signal<string[]>;
|
|
95
94
|
constructor();
|
|
96
95
|
protected trackById(_index: number, item: ICycleJSONLD): string;
|
|
97
96
|
protected selectIndex({ target: { value } }: {
|
|
@@ -99,6 +98,7 @@ export declare class CyclesCompletenessComponent {
|
|
|
99
98
|
value: any;
|
|
100
99
|
};
|
|
101
100
|
}): void;
|
|
101
|
+
protected showDownload(): void;
|
|
102
102
|
static ɵfac: i0.ɵɵFactoryDeclaration<CyclesCompletenessComponent, never>;
|
|
103
103
|
static ɵcmp: i0.ɵɵComponentDeclaration<CyclesCompletenessComponent, "he-cycles-completeness", never, { "dataState": { "alias": "dataState"; "required": false; "isSignal": true; }; }, {}, never, never, true, never>;
|
|
104
104
|
}
|
|
@@ -18,42 +18,42 @@ export declare enum CycleNodesKeyGroup {
|
|
|
18
18
|
}
|
|
19
19
|
type groupedNode = Animal | Transformation;
|
|
20
20
|
export declare class CyclesNodesComponent {
|
|
21
|
+
private readonly modalService;
|
|
21
22
|
private nodeStoreService;
|
|
22
23
|
protected readonly faDownload: IconDefinition;
|
|
23
|
-
protected dataState: import("@angular/core").InputSignal<DataState>;
|
|
24
|
-
protected nodeKeys: import("@angular/core").InputSignal<BlankNodesKey[]>;
|
|
25
|
-
protected nodeKeyGroup: import("@angular/core").InputSignal<CycleNodesKeyGroup>;
|
|
26
|
-
protected BlankNodesKey: typeof BlankNodesKey;
|
|
27
|
-
protected firstNodeKey: import("@angular/core").Signal<BlankNodesKey>;
|
|
28
|
-
protected selectedNodeKey: import("@angular/core").WritableSignal<BlankNodesKey>;
|
|
29
|
-
protected selectedGroupTerm: import("@angular/core").WritableSignal<Term>;
|
|
30
|
-
protected schemaBaseUrl: string;
|
|
31
|
-
protected propertyValue: (value: import("@hestia-earth/utils/dist/term").propertyValueType | import("@hestia-earth/utils/dist/term").propertyValueType[], termId?: string) => import("@hestia-earth/utils/dist/term").propertyValueType;
|
|
32
|
-
protected defaultLabel: (node?: any) => any;
|
|
33
|
-
protected
|
|
34
|
-
protected
|
|
35
|
-
protected
|
|
36
|
-
protected viewIcon: {
|
|
24
|
+
protected readonly dataState: import("@angular/core").InputSignal<DataState>;
|
|
25
|
+
protected readonly nodeKeys: import("@angular/core").InputSignal<BlankNodesKey[]>;
|
|
26
|
+
protected readonly nodeKeyGroup: import("@angular/core").InputSignal<CycleNodesKeyGroup>;
|
|
27
|
+
protected readonly BlankNodesKey: typeof BlankNodesKey;
|
|
28
|
+
protected readonly firstNodeKey: import("@angular/core").Signal<BlankNodesKey>;
|
|
29
|
+
protected readonly selectedNodeKey: import("@angular/core").WritableSignal<BlankNodesKey>;
|
|
30
|
+
protected readonly selectedGroupTerm: import("@angular/core").WritableSignal<Term>;
|
|
31
|
+
protected readonly schemaBaseUrl: string;
|
|
32
|
+
protected readonly propertyValue: (value: import("@hestia-earth/utils/dist/term").propertyValueType | import("@hestia-earth/utils/dist/term").propertyValueType[], termId?: string) => import("@hestia-earth/utils/dist/term").propertyValueType;
|
|
33
|
+
protected readonly defaultLabel: (node?: any) => any;
|
|
34
|
+
protected readonly headerKeys: import("@angular/core").Signal<string[]>;
|
|
35
|
+
protected readonly View: typeof View;
|
|
36
|
+
protected readonly viewIcon: {
|
|
37
37
|
"Table view": IconDefinition;
|
|
38
38
|
"Chart view": IconDefinition;
|
|
39
39
|
"Operations Timeline": IconDefinition;
|
|
40
40
|
"Recalculations logs": IconDefinition;
|
|
41
41
|
};
|
|
42
|
-
private showView;
|
|
43
|
-
protected views: import("@angular/core").Signal<View[]>;
|
|
44
|
-
protected selectedView: import("@angular/core").WritableSignal<View>;
|
|
45
|
-
private _allNodes;
|
|
46
|
-
private originalNodes;
|
|
47
|
-
private currentNodes;
|
|
48
|
-
protected originalCycles: import("@angular/core").Signal<ICycleJSONLD[] | groupedNode[]>;
|
|
49
|
-
protected cycles: import("@angular/core").Signal<ICycleJSONLD[] | groupedNode[]>;
|
|
50
|
-
private selectedIndex;
|
|
51
|
-
private ogirinalSelectedCycle;
|
|
52
|
-
private selectedCycle;
|
|
53
|
-
protected selectedLogsKey: import("@angular/core").Signal<any>;
|
|
54
|
-
protected selectedOriginalValues: import("@angular/core").Signal<any>;
|
|
55
|
-
protected selectedRecalculatedValues: import("@angular/core").Signal<any>;
|
|
56
|
-
protected selectedNode: import("@angular/core").Signal<{
|
|
42
|
+
private readonly showView;
|
|
43
|
+
protected readonly views: import("@angular/core").Signal<View[]>;
|
|
44
|
+
protected readonly selectedView: import("@angular/core").WritableSignal<View>;
|
|
45
|
+
private readonly _allNodes;
|
|
46
|
+
private readonly originalNodes;
|
|
47
|
+
private readonly currentNodes;
|
|
48
|
+
protected readonly originalCycles: import("@angular/core").Signal<ICycleJSONLD[] | groupedNode[]>;
|
|
49
|
+
protected readonly cycles: import("@angular/core").Signal<ICycleJSONLD[] | groupedNode[]>;
|
|
50
|
+
private readonly selectedIndex;
|
|
51
|
+
private readonly ogirinalSelectedCycle;
|
|
52
|
+
private readonly selectedCycle;
|
|
53
|
+
protected readonly selectedLogsKey: import("@angular/core").Signal<any>;
|
|
54
|
+
protected readonly selectedOriginalValues: import("@angular/core").Signal<any>;
|
|
55
|
+
protected readonly selectedRecalculatedValues: import("@angular/core").Signal<any>;
|
|
56
|
+
protected readonly selectedNode: import("@angular/core").Signal<{
|
|
57
57
|
'@type': NodeType;
|
|
58
58
|
type: NodeType;
|
|
59
59
|
dataState: DataState;
|
|
@@ -161,25 +161,25 @@ export declare class CyclesNodesComponent {
|
|
|
161
161
|
updatedVersion?: string[];
|
|
162
162
|
id?: string;
|
|
163
163
|
}>;
|
|
164
|
-
private isOriginal;
|
|
165
|
-
private originalValues;
|
|
166
|
-
private hasRecalculatedNodes;
|
|
167
|
-
protected showSwitchToRecalculated: import("@angular/core").Signal<boolean>;
|
|
168
|
-
protected timelineValues: import("@angular/core").Signal<blankNodesType[]>;
|
|
169
|
-
private enableTimeline;
|
|
170
|
-
protected isNodeKeyAllowed: import("@angular/core").Signal<boolean>;
|
|
171
|
-
private groupedNodes;
|
|
172
|
-
protected groupNodeTerms: import("@angular/core").Signal<Term[]>;
|
|
173
|
-
protected isGroupNode: import("@angular/core").Signal<boolean>;
|
|
174
|
-
protected isEmission: import("@angular/core").Signal<boolean>;
|
|
175
|
-
protected data: import("@angular/core").Signal<groupedEmissions | {
|
|
164
|
+
private readonly isOriginal;
|
|
165
|
+
private readonly originalValues;
|
|
166
|
+
private readonly hasRecalculatedNodes;
|
|
167
|
+
protected readonly showSwitchToRecalculated: import("@angular/core").Signal<boolean>;
|
|
168
|
+
protected readonly timelineValues: import("@angular/core").Signal<blankNodesType[]>;
|
|
169
|
+
private readonly enableTimeline;
|
|
170
|
+
protected readonly isNodeKeyAllowed: import("@angular/core").Signal<boolean>;
|
|
171
|
+
private readonly groupedNodes;
|
|
172
|
+
protected readonly groupNodeTerms: import("@angular/core").Signal<Term[]>;
|
|
173
|
+
protected readonly isGroupNode: import("@angular/core").Signal<boolean>;
|
|
174
|
+
protected readonly isEmission: import("@angular/core").Signal<boolean>;
|
|
175
|
+
protected readonly data: import("@angular/core").Signal<groupedEmissions | {
|
|
176
176
|
[k: string]: IGroupedKeys<Product>[];
|
|
177
177
|
}>;
|
|
178
|
-
protected dataKeys: import("@angular/core").Signal<string[]>;
|
|
179
|
-
protected hasData: import("@angular/core").Signal<boolean>;
|
|
180
|
-
protected filterTermTypes: import("@angular/core").Signal<TermTermType[]>;
|
|
181
|
-
protected filterTerm: import("@angular/core").WritableSignal<string>;
|
|
182
|
-
protected csvFilename: import("@angular/core").Signal<string>;
|
|
178
|
+
protected readonly dataKeys: import("@angular/core").Signal<string[]>;
|
|
179
|
+
protected readonly hasData: import("@angular/core").Signal<boolean>;
|
|
180
|
+
protected readonly filterTermTypes: import("@angular/core").Signal<TermTermType[]>;
|
|
181
|
+
protected readonly filterTerm: import("@angular/core").WritableSignal<string>;
|
|
182
|
+
protected readonly csvFilename: import("@angular/core").Signal<string>;
|
|
183
183
|
constructor();
|
|
184
184
|
private groupNodesByKey;
|
|
185
185
|
private groupEmissions;
|
|
@@ -190,6 +190,7 @@ export declare class CyclesNodesComponent {
|
|
|
190
190
|
};
|
|
191
191
|
}): void;
|
|
192
192
|
protected cycleNode(cycle: ICycleJSONLD | groupedNode): Term | ICycleJSONLD | groupedNode;
|
|
193
|
+
protected showDownload(): void;
|
|
193
194
|
static ɵfac: i0.ɵɵFactoryDeclaration<CyclesNodesComponent, never>;
|
|
194
195
|
static ɵcmp: i0.ɵɵComponentDeclaration<CyclesNodesComponent, "he-cycles-nodes", never, { "dataState": { "alias": "dataState"; "required": false; "isSignal": true; }; "nodeKeys": { "alias": "nodeKeys"; "required": true; "isSignal": true; }; "nodeKeyGroup": { "alias": "nodeKeyGroup"; "required": false; "isSignal": true; }; }, {}, never, never, true, never>;
|
|
195
196
|
}
|
|
@@ -11,7 +11,6 @@ export declare class EngineModelsStageDeepComponent<T extends NodeType> {
|
|
|
11
11
|
protected readonly faAngleDown: import("@fortawesome/fontawesome-common-types").IconDefinition;
|
|
12
12
|
protected readonly node: import("@angular/core").InputSignal<IJSONLDExtended>;
|
|
13
13
|
protected readonly expanded: import("@angular/core").ModelSignal<boolean>;
|
|
14
|
-
protected readonly showVersion: import("@angular/core").ModelSignal<boolean>;
|
|
15
14
|
/**
|
|
16
15
|
* When nesting the components, avoid allowing expansion on the top-level node.
|
|
17
16
|
*/
|
|
@@ -19,6 +18,7 @@ export declare class EngineModelsStageDeepComponent<T extends NodeType> {
|
|
|
19
18
|
protected readonly id: import("@angular/core").Signal<string>;
|
|
20
19
|
protected readonly type: import("@angular/core").Signal<NodeType>;
|
|
21
20
|
protected readonly nodeColour: import("@angular/core").Signal<any>;
|
|
21
|
+
protected readonly recalculatedAt: import("@angular/core").Signal<any>;
|
|
22
22
|
protected readonly loading: import("@angular/core").WritableSignal<boolean>;
|
|
23
23
|
private readonly relatedNodes;
|
|
24
24
|
private readonly relatedNodes$;
|
|
@@ -35,6 +35,6 @@ export declare class EngineModelsStageDeepComponent<T extends NodeType> {
|
|
|
35
35
|
private findNode;
|
|
36
36
|
protected trackNode(node: IJSONLDExtended): string;
|
|
37
37
|
static ɵfac: i0.ɵɵFactoryDeclaration<EngineModelsStageDeepComponent<any>, never>;
|
|
38
|
-
static ɵcmp: i0.ɵɵComponentDeclaration<EngineModelsStageDeepComponent<any>, "he-engine-models-stage-deep", never, { "node": { "alias": "node"; "required": true; "isSignal": true; }; "expanded": { "alias": "expanded"; "required": false; "isSignal": true; }; "
|
|
38
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<EngineModelsStageDeepComponent<any>, "he-engine-models-stage-deep", never, { "node": { "alias": "node"; "required": true; "isSignal": true; }; "expanded": { "alias": "expanded"; "required": false; "isSignal": true; }; "expandedNode": { "alias": "expandedNode"; "required": false; "isSignal": true; }; }, { "expanded": "expandedChange"; }, never, never, true, never>;
|
|
39
39
|
}
|
|
40
40
|
export {};
|
|
@@ -9,7 +9,7 @@ import { NgbDropdown, NgbDropdownMenu, NgbDropdownToggle } from '@ng-bootstrap/n
|
|
|
9
9
|
import { animationFrameScheduler, combineLatest, EMPTY, fromEvent } from 'rxjs';
|
|
10
10
|
import { LocalStorageService } from 'ngx-webstorage';
|
|
11
11
|
import { HE_REDUCE_WIDTH_ANIMATION, HE_SIDE_MENU_ANIMATION } from './drawer-container.animations';
|
|
12
|
-
import { sidenavStore } from './sidenav.store';
|
|
12
|
+
import { sidenavStore, initialState } from './sidenav.store';
|
|
13
13
|
import { NavigationMenuComponent } from '../navigation-menu/navigation-menu.component';
|
|
14
14
|
import { ResponsiveService } from '../responsive.service';
|
|
15
15
|
import * as i0 from "@angular/core";
|
|
@@ -22,7 +22,7 @@ export class DrawerContainerComponent {
|
|
|
22
22
|
this.localStorage = inject(LocalStorageService);
|
|
23
23
|
this.contentContainer = viewChild('contentContainer', { read: ElementRef });
|
|
24
24
|
this.menuState = signal('close');
|
|
25
|
-
this.expanded = signal(
|
|
25
|
+
this.expanded = signal(initialState.expanded);
|
|
26
26
|
/**
|
|
27
27
|
* The breakpoint at which the drawer will no longer be compact.
|
|
28
28
|
* If a number is provided, it will be used as the width in pixels.
|
|
@@ -31,10 +31,10 @@ export class DrawerContainerComponent {
|
|
|
31
31
|
* @default 'tablet' - the drawer will be compact until the tablet breakpoint.
|
|
32
32
|
*/
|
|
33
33
|
this.compactBreakpoint = input('tablet');
|
|
34
|
-
this.position = input(
|
|
35
|
-
this.min = input(
|
|
36
|
-
this.width = model(
|
|
37
|
-
this.max = input(
|
|
34
|
+
this.position = input(initialState.side);
|
|
35
|
+
this.min = input(initialState.minWidth);
|
|
36
|
+
this.width = model(initialState.width);
|
|
37
|
+
this.max = input(initialState.maxWidth);
|
|
38
38
|
this.resizable = input(true);
|
|
39
39
|
this.contentPaddingStyles = input();
|
|
40
40
|
this.menuOverlap = input(true);
|
|
@@ -45,7 +45,7 @@ export class DrawerContainerComponent {
|
|
|
45
45
|
/**
|
|
46
46
|
* The minimum distance between the menu and the edge of the content container.
|
|
47
47
|
*/
|
|
48
|
-
this.minMenuDistance = input(
|
|
48
|
+
this.minMenuDistance = input(initialState.minMenuDistance);
|
|
49
49
|
/**
|
|
50
50
|
* Giving an id to the menu so that it can store the resized position.
|
|
51
51
|
*/
|
|
@@ -152,4 +152,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImpo
|
|
|
152
152
|
type: HostListener,
|
|
153
153
|
args: ['window:mouseup']
|
|
154
154
|
}] } });
|
|
155
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"drawer-container.component.js","sourceRoot":"","sources":["../../../../src/common/drawer-container/drawer-container.component.ts","../../../../src/common/drawer-container/drawer-container.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  Component,\n  computed,\n  effect,\n  ElementRef,\n  HostListener,\n  inject,\n  input,\n  model,\n  signal,\n  TemplateRef,\n  viewChild\n} from '@angular/core';\nimport { NgClass, NgTemplateOutlet } from '@angular/common';\nimport { FaIconComponent } from '@fortawesome/angular-fontawesome';\nimport { faChevronDown, faChevronLeft, faChevronRight, faChevronUp } from '@fortawesome/free-solid-svg-icons';\nimport type { AnimationEvent } from '@angular/animations';\nimport { outputFromObservable, toObservable, toSignal } from '@angular/core/rxjs-interop';\nimport { delay, filter, map, skip, startWith, switchMap, throttleTime } from 'rxjs/operators';\nimport { FormsModule } from '@angular/forms';\nimport { NgbDropdown, NgbDropdownMenu, NgbDropdownToggle } from '@ng-bootstrap/ng-bootstrap';\nimport { animationFrameScheduler, combineLatest, EMPTY, fromEvent, Observable } from 'rxjs';\nimport { LocalStorageService } from 'ngx-webstorage';\n\nimport { HE_REDUCE_WIDTH_ANIMATION, HE_SIDE_MENU_ANIMATION } from './drawer-container.animations';\nimport { sidenavStore } from './sidenav.store';\nimport { INavigationMenuLink, NavigationMenuComponent } from '../navigation-menu/navigation-menu.component';\nimport { ResponsiveBreakpoint, ResponsiveService } from '../responsive.service';\n\nconst storageKey = 'he-drawer-container';\n\n@Component({\n  selector: 'he-drawer-container',\n  standalone: true,\n  imports: [\n    NgTemplateOutlet,\n    FaIconComponent,\n    NgClass,\n    FormsModule,\n    NgbDropdown,\n    NgbDropdownMenu,\n    NgbDropdownToggle,\n    NavigationMenuComponent\n  ],\n  templateUrl: './drawer-container.component.html',\n  styleUrl: './drawer-container.component.scss',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  animations: [...HE_SIDE_MENU_ANIMATION, ...HE_REDUCE_WIDTH_ANIMATION],\n  // eslint-disable-next-line @angular-eslint/no-host-metadata-property\n  host: {\n    '[class]': 'hostClass()',\n    '[attr.drawer-position]': 'position()',\n    '[attr.drawer-state]': 'menuState()'\n  },\n  providers: [sidenavStore]\n})\nexport class DrawerContainerComponent {\n  private readonly elementRef = inject(ElementRef);\n  private readonly sidenavStore = inject(sidenavStore);\n  private readonly responsiveService = inject(ResponsiveService);\n  private readonly localStorage = inject(LocalStorageService);\n\n  private readonly contentContainer = viewChild('contentContainer', { read: ElementRef });\n\n  protected readonly menuState = signal<'open' | 'close'>('close');\n  protected readonly expanded = signal(true);\n\n  /**\n   * The breakpoint at which the drawer will no longer be compact.\n   * If a number is provided, it will be used as the width in pixels.\n   * If 'none' is provided, the drawer will never be compact.\n   * If a breakpoint name is provided, the drawer will be compact until that breakpoint.\n   * @default 'tablet' - the drawer will be compact until the tablet breakpoint.\n   */\n  protected readonly compactBreakpoint = input<ResponsiveBreakpoint>('tablet');\n  protected readonly position = input<'left' | 'right'>('left');\n  protected readonly min = input<number>(250);\n  protected readonly width = model<number>(256);\n  protected readonly max = input<number>(600);\n  protected readonly resizable = input(true);\n  protected readonly contentPaddingStyles = input<string>();\n  protected readonly menuOverlap = input(true);\n  protected readonly links = input<INavigationMenuLink[]>([]);\n  protected readonly drawerHeaderTemplate = input<TemplateRef<any>>();\n  protected readonly drawerMenuHeaderTemplate = input<TemplateRef<any>>();\n  protected readonly compactHeaderClass = input<NgClass['ngClass']>(null);\n  /**\n   * The minimum distance between the menu and the edge of the content container.\n   */\n  protected readonly minMenuDistance = input<number>(20);\n  /**\n   * Giving an id to the menu so that it can store the resized position.\n   */\n  protected readonly id = input('');\n\n  protected readonly opened = outputFromObservable(\n    toObservable(this.menuState).pipe(\n      skip(1),\n      filter(state => state === 'open'),\n      map(() => true)\n    )\n  );\n  protected readonly closed = outputFromObservable(\n    toObservable(this.menuState).pipe(\n      skip(1),\n      filter(state => state === 'close'),\n      map(() => true)\n    )\n  );\n\n  protected readonly faChevronUp = faChevronUp;\n  protected readonly faChevronDown = faChevronDown;\n\n  protected readonly visible = computed(() =>\n    [this.links()?.length > 0, !!this.drawerHeaderTemplate(), !!this.drawerMenuHeaderTemplate()].some(Boolean)\n  );\n\n  /**\n   * Detect showing modal within the content of the drawer container, which breaks the layout.\n   */\n  protected readonly hasModal = toSignal(\n    fromEvent(this.elementRef.nativeElement, 'click').pipe(\n      map(() => this.elementRef.nativeElement.getElementsByClassName('modal').length > 0)\n    )\n  );\n  protected readonly disableAnimation = toSignal(toObservable(this.hasModal).pipe(delay(1000)));\n\n  protected readonly isCompact = toSignal(\n    toObservable(this.compactBreakpoint).pipe(\n      switchMap(breakpoint =>\n        this.responsiveService.isAboveBreakpoint$(breakpoint).pipe(map(isAboveBreakpoint => !isAboveBreakpoint))\n      )\n    )\n  );\n  protected readonly hostClass = computed(() =>\n    ['is-flex', this.isCompact() ? 'is-flex-direction-column' : '', this.resizable() ? 'is-resizable' : ''].join(' ')\n  );\n  protected readonly isHoldingToggle = this.sidenavStore.isResizing;\n\n  private readonly _updateSidenavEvent$ = toObservable(this.sidenavStore.isResizing).pipe(\n    switchMap(listen => (listen ? (fromEvent(window, 'mousemove') as Observable<MouseEvent>) : EMPTY)),\n    throttleTime(0, animationFrameScheduler)\n  );\n  private readonly _contentContainer$ = toObservable(this.contentContainer).pipe(filter(x => !!x));\n  private readonly _hostComponentWidth$ = fromEvent(window, 'resize').pipe(startWith(window.innerWidth));\n  private readonly _isOverlapping$ = toObservable(this.sidenavStore.isMenuOverlapping);\n\n  /**\n   * we use combineLatest instead of computed to avoid the animation flickering (wait for all sources to emit)\n   */\n  protected readonly reduceAnimation = toSignal(\n    combineLatest([\n      toObservable(this.expanded),\n      this._isOverlapping$,\n      toObservable(this.isCompact),\n      toObservable(this.visible)\n    ]).pipe(\n      map(([expanded, isOverlapping, isCompact, visible]) =>\n        [expanded, !isOverlapping, !isCompact, visible].every(Boolean) ? 'reduced' : 'full'\n      )\n    )\n  );\n  private readonly _contentContainerPadding$ = this._hostComponentWidth$.pipe(\n    switchMap(() => this._contentContainer$.pipe(map(this._getContentLeftSideSpace)))\n  );\n\n  private storageKey = computed(() => [storageKey, this.id()].filter(Boolean).join('-'));\n\n  constructor() {\n    this.sidenavStore.setSide(this.position);\n    this.sidenavStore.setMinWidth(this.min);\n    this.sidenavStore.setMaxWidth(this.max);\n    this.sidenavStore.setWidth(this.width);\n    this.sidenavStore.updateResizing(this._updateSidenavEvent$);\n    this.sidenavStore.setContentContainerSpacing(this._contentContainerPadding$);\n    this.sidenavStore.setExpanded(this.expanded);\n    this.sidenavStore.setMinMenuDistance(this.minMenuDistance);\n\n    effect(\n      () => {\n        if (this.resizable()) {\n          const { width } = JSON.parse(this.localStorage.retrieve(this.storageKey()) || '{}');\n          if (width) {\n            setTimeout(() => this.width.set(width));\n          }\n        }\n      },\n      { allowSignalWrites: true }\n    );\n  }\n\n  startResizing(event: MouseEvent): void {\n    if (!this.resizable()) return;\n    this.sidenavStore.startResizing(event);\n  }\n\n  @HostListener('window:mouseup')\n  stopResizing() {\n    this.sidenavStore.stopResizing();\n    this.localStorage.store(this.storageKey(), JSON.stringify({ width: this.sidenavStore.width() }));\n  }\n\n  protected toggleIcon() {\n    return (this.expanded() && this.position() === 'left') || (!this.expanded() && this.position() === 'right')\n      ? faChevronLeft\n      : faChevronRight;\n  }\n\n  public toggleMenu() {\n    if (this.sidenavStore.hasMenuWidthChanged() && this.expanded()) return;\n\n    this.expanded() ? this.hideMenu() : this.showMenu();\n  }\n\n  public hideMenu() {\n    this.expanded.set(false);\n  }\n\n  public showMenu() {\n    this.expanded.set(true);\n  }\n\n  protected animationDone(event: AnimationEvent) {\n    const didOpen = event.toState !== 'hidden';\n    this.menuState.set(didOpen ? 'open' : 'close');\n  }\n\n  private _getContentLeftSideSpace(element: ElementRef<HTMLElement>) {\n    const padding = window.getComputedStyle(element.nativeElement, null).getPropertyValue('padding-left');\n    const margin = window.getComputedStyle(element.nativeElement, null).getPropertyValue('margin-left');\n    return parseInt(padding, 10) + parseInt(margin, 10);\n  }\n}\n","@if (visible()) {\n  @if (isCompact()) {\n    <div class=\"compact-header\">\n      <div [ngClass]=\"compactHeaderClass()\">\n        <div class=\"is-flex is-align-items-flex-start is-justify-content-space-between w-100\">\n          <div class=\"is-flex is-flex-grow-1 is-justify-content-space-between is-flex-direction-column\">\n            @if (drawerHeaderTemplate()) {\n              <ng-container [ngTemplateOutlet]=\"drawerHeaderTemplate()\" />\n            }\n\n            @if (drawerMenuHeaderTemplate()) {\n              <ng-container [ngTemplateOutlet]=\"drawerMenuHeaderTemplate()\" />\n            }\n          </div>\n\n          @if (links()?.length > 0) {\n            <div ngbDropdown #optionDd=\"ngbDropdown\" container=\"body\" placement=\"bottom-end\">\n              <button\n                ngbDropdownToggle\n                class=\"compact-header--btn button is-small is-no-shadow\"\n                aria-controls=\"drawer-menu\"\n                type=\"button\">\n                Menu\n\n                <fa-icon\n                  class=\"compact-header--btn__icon\"\n                  [icon]=\"optionDd.isOpen() ? faChevronUp : faChevronDown\"\n                  aria-hidden=\"true\"></fa-icon>\n              </button>\n\n              <div ngbDropdownMenu id=\"drawer-menu\">\n                <div class=\"dropdown-content navigation-menu-dropdown\">\n                  <he-navigation-menu (closed)=\"optionDd.close()\" [links]=\"links()\" />\n                </div>\n              </div>\n            </div>\n          }\n        </div>\n      </div>\n    </div>\n  } @else {\n    <aside>\n      <div\n        class=\"shell__menuContent | h-100\"\n        (@sideMenu.done)=\"animationDone($event)\"\n        [@sideMenu]=\"expanded() ? 'full' : 'hidden'\">\n        <div class=\"h-100 shell__menuContent--container\">\n          @if (drawerHeaderTemplate()) {\n            <ng-container [ngTemplateOutlet]=\"drawerHeaderTemplate()\" />\n          }\n\n          @if (links()?.length > 0) {\n            <he-navigation-menu [links]=\"links()\">\n              @if (drawerMenuHeaderTemplate()) {\n                <ng-container outer-content [ngTemplateOutlet]=\"drawerMenuHeaderTemplate()\" />\n              }\n            </he-navigation-menu>\n          }\n        </div>\n        <button (click)=\"toggleMenu()\" (mousedown)=\"startResizing($event)\" class=\"shell__menuContent--toggle\">\n          <fa-icon [icon]=\"toggleIcon()\" />\n        </button>\n      </div>\n    </aside>\n  }\n}\n\n<div\n  [class.is-resizing]=\"isHoldingToggle()\"\n  [@reduceWidth]=\"reduceAnimation()\"\n  class=\"shell__content | h-100 w-100 is-flex is-justify-content-flex-end\">\n  <div\n    [class.disable-animation]=\"disableAnimation()\"\n    [class.disable-transform-x]=\"hasModal()\"\n    class=\"shell__content--body | w-100\">\n    <div #contentContainer [className]=\"contentPaddingStyles()\">\n      <ng-content select=\"[drawer-content]\"></ng-content>\n    </div>\n  </div>\n</div>\n"]}
|
|
155
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"drawer-container.component.js","sourceRoot":"","sources":["../../../../src/common/drawer-container/drawer-container.component.ts","../../../../src/common/drawer-container/drawer-container.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  Component,\n  computed,\n  effect,\n  ElementRef,\n  HostListener,\n  inject,\n  input,\n  model,\n  signal,\n  TemplateRef,\n  viewChild\n} from '@angular/core';\nimport { NgClass, NgTemplateOutlet } from '@angular/common';\nimport { FaIconComponent } from '@fortawesome/angular-fontawesome';\nimport { faChevronDown, faChevronLeft, faChevronRight, faChevronUp } from '@fortawesome/free-solid-svg-icons';\nimport type { AnimationEvent } from '@angular/animations';\nimport { outputFromObservable, toObservable, toSignal } from '@angular/core/rxjs-interop';\nimport { delay, filter, map, skip, startWith, switchMap, throttleTime } from 'rxjs/operators';\nimport { FormsModule } from '@angular/forms';\nimport { NgbDropdown, NgbDropdownMenu, NgbDropdownToggle } from '@ng-bootstrap/ng-bootstrap';\nimport { animationFrameScheduler, combineLatest, EMPTY, fromEvent, Observable } from 'rxjs';\nimport { LocalStorageService } from 'ngx-webstorage';\n\nimport { HE_REDUCE_WIDTH_ANIMATION, HE_SIDE_MENU_ANIMATION } from './drawer-container.animations';\nimport { sidenavStore, initialState } from './sidenav.store';\nimport { INavigationMenuLink, NavigationMenuComponent } from '../navigation-menu/navigation-menu.component';\nimport { ResponsiveBreakpoint, ResponsiveService } from '../responsive.service';\n\nconst storageKey = 'he-drawer-container';\n\n@Component({\n  selector: 'he-drawer-container',\n  standalone: true,\n  imports: [\n    NgTemplateOutlet,\n    FaIconComponent,\n    NgClass,\n    FormsModule,\n    NgbDropdown,\n    NgbDropdownMenu,\n    NgbDropdownToggle,\n    NavigationMenuComponent\n  ],\n  templateUrl: './drawer-container.component.html',\n  styleUrl: './drawer-container.component.scss',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  animations: [...HE_SIDE_MENU_ANIMATION, ...HE_REDUCE_WIDTH_ANIMATION],\n  // eslint-disable-next-line @angular-eslint/no-host-metadata-property\n  host: {\n    '[class]': 'hostClass()',\n    '[attr.drawer-position]': 'position()',\n    '[attr.drawer-state]': 'menuState()'\n  },\n  providers: [sidenavStore]\n})\nexport class DrawerContainerComponent {\n  private readonly elementRef = inject(ElementRef);\n  private readonly sidenavStore = inject(sidenavStore);\n  private readonly responsiveService = inject(ResponsiveService);\n  private readonly localStorage = inject(LocalStorageService);\n\n  private readonly contentContainer = viewChild('contentContainer', { read: ElementRef });\n\n  protected readonly menuState = signal<'open' | 'close'>('close');\n  protected readonly expanded = signal(initialState.expanded);\n\n  /**\n   * The breakpoint at which the drawer will no longer be compact.\n   * If a number is provided, it will be used as the width in pixels.\n   * If 'none' is provided, the drawer will never be compact.\n   * If a breakpoint name is provided, the drawer will be compact until that breakpoint.\n   * @default 'tablet' - the drawer will be compact until the tablet breakpoint.\n   */\n  protected readonly compactBreakpoint = input<ResponsiveBreakpoint>('tablet');\n  protected readonly position = input<'left' | 'right'>(initialState.side);\n  protected readonly min = input<number>(initialState.minWidth);\n  protected readonly width = model<number>(initialState.width);\n  protected readonly max = input<number>(initialState.maxWidth);\n  protected readonly resizable = input(true);\n  protected readonly contentPaddingStyles = input<string>();\n  protected readonly menuOverlap = input(true);\n  protected readonly links = input<INavigationMenuLink[]>([]);\n  protected readonly drawerHeaderTemplate = input<TemplateRef<any>>();\n  protected readonly drawerMenuHeaderTemplate = input<TemplateRef<any>>();\n  protected readonly compactHeaderClass = input<NgClass['ngClass']>(null);\n  /**\n   * The minimum distance between the menu and the edge of the content container.\n   */\n  protected readonly minMenuDistance = input<number>(initialState.minMenuDistance);\n  /**\n   * Giving an id to the menu so that it can store the resized position.\n   */\n  protected readonly id = input('');\n\n  protected readonly opened = outputFromObservable(\n    toObservable(this.menuState).pipe(\n      skip(1),\n      filter(state => state === 'open'),\n      map(() => true)\n    )\n  );\n  protected readonly closed = outputFromObservable(\n    toObservable(this.menuState).pipe(\n      skip(1),\n      filter(state => state === 'close'),\n      map(() => true)\n    )\n  );\n\n  protected readonly faChevronUp = faChevronUp;\n  protected readonly faChevronDown = faChevronDown;\n\n  protected readonly visible = computed(() =>\n    [this.links()?.length > 0, !!this.drawerHeaderTemplate(), !!this.drawerMenuHeaderTemplate()].some(Boolean)\n  );\n\n  /**\n   * Detect showing modal within the content of the drawer container, which breaks the layout.\n   */\n  protected readonly hasModal = toSignal(\n    fromEvent(this.elementRef.nativeElement, 'click').pipe(\n      map(() => this.elementRef.nativeElement.getElementsByClassName('modal').length > 0)\n    )\n  );\n  protected readonly disableAnimation = toSignal(toObservable(this.hasModal).pipe(delay(1000)));\n\n  protected readonly isCompact = toSignal(\n    toObservable(this.compactBreakpoint).pipe(\n      switchMap(breakpoint =>\n        this.responsiveService.isAboveBreakpoint$(breakpoint).pipe(map(isAboveBreakpoint => !isAboveBreakpoint))\n      )\n    )\n  );\n  protected readonly hostClass = computed(() =>\n    ['is-flex', this.isCompact() ? 'is-flex-direction-column' : '', this.resizable() ? 'is-resizable' : ''].join(' ')\n  );\n  protected readonly isHoldingToggle = this.sidenavStore.isResizing;\n\n  private readonly _updateSidenavEvent$ = toObservable(this.sidenavStore.isResizing).pipe(\n    switchMap(listen => (listen ? (fromEvent(window, 'mousemove') as Observable<MouseEvent>) : EMPTY)),\n    throttleTime(0, animationFrameScheduler)\n  );\n  private readonly _contentContainer$ = toObservable(this.contentContainer).pipe(filter(x => !!x));\n  private readonly _hostComponentWidth$ = fromEvent(window, 'resize').pipe(startWith(window.innerWidth));\n  private readonly _isOverlapping$ = toObservable(this.sidenavStore.isMenuOverlapping);\n\n  /**\n   * we use combineLatest instead of computed to avoid the animation flickering (wait for all sources to emit)\n   */\n  protected readonly reduceAnimation = toSignal(\n    combineLatest([\n      toObservable(this.expanded),\n      this._isOverlapping$,\n      toObservable(this.isCompact),\n      toObservable(this.visible)\n    ]).pipe(\n      map(([expanded, isOverlapping, isCompact, visible]) =>\n        [expanded, !isOverlapping, !isCompact, visible].every(Boolean) ? 'reduced' : 'full'\n      )\n    )\n  );\n  private readonly _contentContainerPadding$ = this._hostComponentWidth$.pipe(\n    switchMap(() => this._contentContainer$.pipe(map(this._getContentLeftSideSpace)))\n  );\n\n  private storageKey = computed(() => [storageKey, this.id()].filter(Boolean).join('-'));\n\n  constructor() {\n    this.sidenavStore.setSide(this.position);\n    this.sidenavStore.setMinWidth(this.min);\n    this.sidenavStore.setMaxWidth(this.max);\n    this.sidenavStore.setWidth(this.width);\n    this.sidenavStore.updateResizing(this._updateSidenavEvent$);\n    this.sidenavStore.setContentContainerSpacing(this._contentContainerPadding$);\n    this.sidenavStore.setExpanded(this.expanded);\n    this.sidenavStore.setMinMenuDistance(this.minMenuDistance);\n\n    effect(\n      () => {\n        if (this.resizable()) {\n          const { width } = JSON.parse(this.localStorage.retrieve(this.storageKey()) || '{}');\n          if (width) {\n            setTimeout(() => this.width.set(width));\n          }\n        }\n      },\n      { allowSignalWrites: true }\n    );\n  }\n\n  startResizing(event: MouseEvent): void {\n    if (!this.resizable()) return;\n    this.sidenavStore.startResizing(event);\n  }\n\n  @HostListener('window:mouseup')\n  stopResizing() {\n    this.sidenavStore.stopResizing();\n    this.localStorage.store(this.storageKey(), JSON.stringify({ width: this.sidenavStore.width() }));\n  }\n\n  protected toggleIcon() {\n    return (this.expanded() && this.position() === 'left') || (!this.expanded() && this.position() === 'right')\n      ? faChevronLeft\n      : faChevronRight;\n  }\n\n  public toggleMenu() {\n    if (this.sidenavStore.hasMenuWidthChanged() && this.expanded()) return;\n\n    this.expanded() ? this.hideMenu() : this.showMenu();\n  }\n\n  public hideMenu() {\n    this.expanded.set(false);\n  }\n\n  public showMenu() {\n    this.expanded.set(true);\n  }\n\n  protected animationDone(event: AnimationEvent) {\n    const didOpen = event.toState !== 'hidden';\n    this.menuState.set(didOpen ? 'open' : 'close');\n  }\n\n  private _getContentLeftSideSpace(element: ElementRef<HTMLElement>) {\n    const padding = window.getComputedStyle(element.nativeElement, null).getPropertyValue('padding-left');\n    const margin = window.getComputedStyle(element.nativeElement, null).getPropertyValue('margin-left');\n    return parseInt(padding, 10) + parseInt(margin, 10);\n  }\n}\n","@if (visible()) {\n  @if (isCompact()) {\n    <div class=\"compact-header\">\n      <div [ngClass]=\"compactHeaderClass()\">\n        <div class=\"is-flex is-align-items-flex-start is-justify-content-space-between w-100\">\n          <div class=\"is-flex is-flex-grow-1 is-justify-content-space-between is-flex-direction-column\">\n            @if (drawerHeaderTemplate()) {\n              <ng-container [ngTemplateOutlet]=\"drawerHeaderTemplate()\" />\n            }\n\n            @if (drawerMenuHeaderTemplate()) {\n              <ng-container [ngTemplateOutlet]=\"drawerMenuHeaderTemplate()\" />\n            }\n          </div>\n\n          @if (links()?.length > 0) {\n            <div ngbDropdown #optionDd=\"ngbDropdown\" container=\"body\" placement=\"bottom-end\">\n              <button\n                ngbDropdownToggle\n                class=\"compact-header--btn button is-small is-no-shadow\"\n                aria-controls=\"drawer-menu\"\n                type=\"button\">\n                Menu\n\n                <fa-icon\n                  class=\"compact-header--btn__icon\"\n                  [icon]=\"optionDd.isOpen() ? faChevronUp : faChevronDown\"\n                  aria-hidden=\"true\"></fa-icon>\n              </button>\n\n              <div ngbDropdownMenu id=\"drawer-menu\">\n                <div class=\"dropdown-content navigation-menu-dropdown\">\n                  <he-navigation-menu (closed)=\"optionDd.close()\" [links]=\"links()\" />\n                </div>\n              </div>\n            </div>\n          }\n        </div>\n      </div>\n    </div>\n  } @else {\n    <aside>\n      <div\n        class=\"shell__menuContent | h-100\"\n        (@sideMenu.done)=\"animationDone($event)\"\n        [@sideMenu]=\"expanded() ? 'full' : 'hidden'\">\n        <div class=\"h-100 shell__menuContent--container\">\n          @if (drawerHeaderTemplate()) {\n            <ng-container [ngTemplateOutlet]=\"drawerHeaderTemplate()\" />\n          }\n\n          @if (links()?.length > 0) {\n            <he-navigation-menu [links]=\"links()\">\n              @if (drawerMenuHeaderTemplate()) {\n                <ng-container outer-content [ngTemplateOutlet]=\"drawerMenuHeaderTemplate()\" />\n              }\n            </he-navigation-menu>\n          }\n        </div>\n        <button (click)=\"toggleMenu()\" (mousedown)=\"startResizing($event)\" class=\"shell__menuContent--toggle\">\n          <fa-icon [icon]=\"toggleIcon()\" />\n        </button>\n      </div>\n    </aside>\n  }\n}\n\n<div\n  [class.is-resizing]=\"isHoldingToggle()\"\n  [@reduceWidth]=\"reduceAnimation()\"\n  class=\"shell__content | h-100 w-100 is-flex is-justify-content-flex-end\">\n  <div\n    [class.disable-animation]=\"disableAnimation()\"\n    [class.disable-transform-x]=\"hasModal()\"\n    class=\"shell__content--body | w-100\">\n    <div #contentContainer [className]=\"contentPaddingStyles()\">\n      <ng-content select=\"[drawer-content]\"></ng-content>\n    </div>\n  </div>\n</div>\n"]}
|
|
@@ -9,7 +9,7 @@ const initialResizeEvent = {
|
|
|
9
9
|
startingWidth: 0,
|
|
10
10
|
newWidth: 0
|
|
11
11
|
};
|
|
12
|
-
const initialState = {
|
|
12
|
+
export const initialState = {
|
|
13
13
|
minWidth: 250,
|
|
14
14
|
maxWidth: 600,
|
|
15
15
|
width: 256,
|
|
@@ -86,4 +86,4 @@ export const sidenavStore = signalStore(withState(initialState), withComputed(({
|
|
|
86
86
|
setSidenavWidthCss(sidenavWidth);
|
|
87
87
|
}
|
|
88
88
|
})));
|
|
89
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"sidenav.store.js","sourceRoot":"","sources":["../../../../src/common/drawer-container/sidenav.store.ts"],"names":[],"mappings":"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","sourcesContent":["import { patchState, signalStore, withComputed, withHooks, withMethods, withState } from '@ngrx/signals';\nimport { rxMethod } from '@ngrx/signals/rxjs-interop';\nimport { animationFrameScheduler, pipe } from 'rxjs';\nimport { tap, throttleTime } from 'rxjs/operators';\nimport { computed } from '@angular/core';\n\nconst initialResizeEvent = {\n  isResizing: false,\n  startingCursorX: 0,\n  startingWidth: 0,\n  newWidth: 0\n};\n\nconst initialState = {\n  minWidth: 250,\n  maxWidth: 600,\n  width: 256,\n  expanded: true,\n  side: 'left' as 'left' | 'right',\n  resizeEvent: initialResizeEvent,\n  contentContainerSpacing: 0,\n  minMenuDistance: 20\n};\n\nexport const sidenavStore = signalStore(\n  withState(initialState),\n  withComputed(({ minWidth, width, maxWidth }) => ({\n    sidenavWidth: computed(() => Math.min(Math.max(width(), minWidth()), maxWidth()))\n  })),\n  withMethods(store => ({\n    setExpanded: rxMethod<boolean>(pipe(tap((expanded: boolean) => patchState(store, { expanded })))),\n    setSide: rxMethod<'left' | 'right'>(pipe(tap((side: 'left' | 'right') => patchState(store, { side })))),\n    setMinMenuDistance: rxMethod<number>(\n      pipe(tap((minMenuDistance: number) => patchState(store, { minMenuDistance: minMenuDistance })))\n    ),\n    setMinWidth: rxMethod<number>(pipe(tap((min: number) => patchState(store, { minWidth: min })))),\n    setMaxWidth: rxMethod<number>(pipe(tap((max: number) => patchState(store, { maxWidth: max })))),\n    setWidth: rxMethod<number>(pipe(tap((width: number) => patchState(store, { width })))),\n    setSidenavWidthCss: rxMethod<number>(\n      pipe(\n        throttleTime(0, animationFrameScheduler),\n        tap((width: number) => document.body.style.setProperty('--sidenav-width', `${width}px`))\n      )\n    ),\n    setContentTransformCss: rxMethod<{\n      expanded: boolean;\n      position: 'left' | 'right';\n      value: number;\n    }>(\n      pipe(\n        tap(({ expanded, position, value }) =>\n          document.body.style.setProperty(\n            '--contentTransitionX',\n            `${expanded ? (position == 'left' ? 1 : -1) * value : 0}px`\n          )\n        )\n      )\n    ),\n    setContentContainerSpacing: rxMethod<number>(\n      pipe(tap((contentContainerSpacing: number) => patchState(store, { contentContainerSpacing })))\n    ),\n    startResizing: (event: MouseEvent) =>\n      patchState(store, {\n        resizeEvent: {\n          isResizing: true,\n          startingCursorX: event.clientX,\n          startingWidth: store.sidenavWidth(),\n          newWidth: store.sidenavWidth()\n        }\n      }),\n    updateResizing: rxMethod<MouseEvent>(\n      tap((event: MouseEvent) => {\n        const resizeEvent = store.resizeEvent();\n        // No need to even continue if we're not resizing\n        if (!resizeEvent.isResizing) {\n          return;\n        }\n\n        // 1. Calculate how much mouse has moved on the x-axis\n        const cursorDeltaX = event.clientX - resizeEvent.startingCursorX;\n\n        // 2. Calculate the new width according to initial width and mouse movement\n        const newWidth = resizeEvent.startingWidth - (store.side() === 'left' ? -1 : 1) * cursorDeltaX;\n\n        patchState(store, state => ({\n          ...state,\n          resizeEvent: {\n            ...state.resizeEvent,\n            newWidth\n          },\n          width: newWidth\n        }));\n      })\n    ),\n    stopResizing: () =>\n      patchState(store, {\n        resizeEvent: {\n          ...store.resizeEvent(),\n          isResizing: false\n        }\n      })\n  })),\n  withComputed(({ sidenavWidth, minMenuDistance, resizeEvent, contentContainerSpacing }) => {\n    const isMenuOverlapping = computed(() => sidenavWidth() < contentContainerSpacing() * 2);\n\n    return {\n      sidenavWidth: sidenavWidth,\n      hasMenuWidthChanged: computed(() => resizeEvent().startingWidth !== resizeEvent().newWidth),\n      isResizing: computed(() => resizeEvent().isResizing),\n      isMenuOverlapping: isMenuOverlapping,\n      contentContainerTransform: computed(() =>\n        sidenavWidth() + minMenuDistance() > contentContainerSpacing() && isMenuOverlapping()\n          ? sidenavWidth() + minMenuDistance() - contentContainerSpacing()\n          : 0\n      )\n    };\n  }),\n  withHooks(\n    ({ sidenavWidth, setSidenavWidthCss, setContentTransformCss, side, expanded, contentContainerTransform }) => ({\n      onInit: () => {\n        const contentTransform = computed(() => ({\n          expanded: expanded(),\n          position: side(),\n          value: contentContainerTransform()\n        }));\n\n        setContentTransformCss(contentTransform);\n        setSidenavWidthCss(sidenavWidth);\n      }\n    })\n  )\n);\n"]}
|
|
89
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"sidenav.store.js","sourceRoot":"","sources":["../../../../src/common/drawer-container/sidenav.store.ts"],"names":[],"mappings":"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","sourcesContent":["import { patchState, signalStore, withComputed, withHooks, withMethods, withState } from '@ngrx/signals';\nimport { rxMethod } from '@ngrx/signals/rxjs-interop';\nimport { animationFrameScheduler, pipe } from 'rxjs';\nimport { tap, throttleTime } from 'rxjs/operators';\nimport { computed } from '@angular/core';\n\nconst initialResizeEvent = {\n  isResizing: false,\n  startingCursorX: 0,\n  startingWidth: 0,\n  newWidth: 0\n};\n\nexport const initialState = {\n  minWidth: 250,\n  maxWidth: 600,\n  width: 256,\n  expanded: true,\n  side: 'left' as 'left' | 'right',\n  resizeEvent: initialResizeEvent,\n  contentContainerSpacing: 0,\n  minMenuDistance: 20\n};\n\nexport const sidenavStore = signalStore(\n  withState(initialState),\n  withComputed(({ minWidth, width, maxWidth }) => ({\n    sidenavWidth: computed(() => Math.min(Math.max(width(), minWidth()), maxWidth()))\n  })),\n  withMethods(store => ({\n    setExpanded: rxMethod<boolean>(pipe(tap((expanded: boolean) => patchState(store, { expanded })))),\n    setSide: rxMethod<'left' | 'right'>(pipe(tap((side: 'left' | 'right') => patchState(store, { side })))),\n    setMinMenuDistance: rxMethod<number>(\n      pipe(tap((minMenuDistance: number) => patchState(store, { minMenuDistance: minMenuDistance })))\n    ),\n    setMinWidth: rxMethod<number>(pipe(tap((min: number) => patchState(store, { minWidth: min })))),\n    setMaxWidth: rxMethod<number>(pipe(tap((max: number) => patchState(store, { maxWidth: max })))),\n    setWidth: rxMethod<number>(pipe(tap((width: number) => patchState(store, { width })))),\n    setSidenavWidthCss: rxMethod<number>(\n      pipe(\n        throttleTime(0, animationFrameScheduler),\n        tap((width: number) => document.body.style.setProperty('--sidenav-width', `${width}px`))\n      )\n    ),\n    setContentTransformCss: rxMethod<{\n      expanded: boolean;\n      position: 'left' | 'right';\n      value: number;\n    }>(\n      pipe(\n        tap(({ expanded, position, value }) =>\n          document.body.style.setProperty(\n            '--contentTransitionX',\n            `${expanded ? (position == 'left' ? 1 : -1) * value : 0}px`\n          )\n        )\n      )\n    ),\n    setContentContainerSpacing: rxMethod<number>(\n      pipe(tap((contentContainerSpacing: number) => patchState(store, { contentContainerSpacing })))\n    ),\n    startResizing: (event: MouseEvent) =>\n      patchState(store, {\n        resizeEvent: {\n          isResizing: true,\n          startingCursorX: event.clientX,\n          startingWidth: store.sidenavWidth(),\n          newWidth: store.sidenavWidth()\n        }\n      }),\n    updateResizing: rxMethod<MouseEvent>(\n      tap((event: MouseEvent) => {\n        const resizeEvent = store.resizeEvent();\n        // No need to even continue if we're not resizing\n        if (!resizeEvent.isResizing) {\n          return;\n        }\n\n        // 1. Calculate how much mouse has moved on the x-axis\n        const cursorDeltaX = event.clientX - resizeEvent.startingCursorX;\n\n        // 2. Calculate the new width according to initial width and mouse movement\n        const newWidth = resizeEvent.startingWidth - (store.side() === 'left' ? -1 : 1) * cursorDeltaX;\n\n        patchState(store, state => ({\n          ...state,\n          resizeEvent: {\n            ...state.resizeEvent,\n            newWidth\n          },\n          width: newWidth\n        }));\n      })\n    ),\n    stopResizing: () =>\n      patchState(store, {\n        resizeEvent: {\n          ...store.resizeEvent(),\n          isResizing: false\n        }\n      })\n  })),\n  withComputed(({ sidenavWidth, minMenuDistance, resizeEvent, contentContainerSpacing }) => {\n    const isMenuOverlapping = computed(() => sidenavWidth() < contentContainerSpacing() * 2);\n\n    return {\n      sidenavWidth: sidenavWidth,\n      hasMenuWidthChanged: computed(() => resizeEvent().startingWidth !== resizeEvent().newWidth),\n      isResizing: computed(() => resizeEvent().isResizing),\n      isMenuOverlapping: isMenuOverlapping,\n      contentContainerTransform: computed(() =>\n        sidenavWidth() + minMenuDistance() > contentContainerSpacing() && isMenuOverlapping()\n          ? sidenavWidth() + minMenuDistance() - contentContainerSpacing()\n          : 0\n      )\n    };\n  }),\n  withHooks(\n    ({ sidenavWidth, setSidenavWidthCss, setContentTransformCss, side, expanded, contentContainerTransform }) => ({\n      onInit: () => {\n        const contentTransform = computed(() => ({\n          expanded: expanded(),\n          position: side(),\n          value: contentContainerTransform()\n        }));\n\n        setContentTransformCss(contentTransform);\n        setSidenavWidthCss(sidenavWidth);\n      }\n    })\n  )\n);\n"]}
|