@flywheel-io/vision 2.6.3 → 2.7.0-beta.1
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/components/avatar-list/avatar-list.component.d.ts +1 -1
- package/components/form-heading/form-heading.component.d.ts +1 -3
- package/components/form-heading/form-heading.module.d.ts +1 -2
- package/components/menu/menu-close-triggers.directive.d.ts +1 -1
- package/components/menu/menu-item/menu-item.component.d.ts +5 -0
- package/components/tooltip/tooltip-panel/tooltip-panel.component.d.ts +14 -3
- package/components/tooltip/tooltip.component.d.ts +5 -12
- package/components/tooltip/tooltip.directive.d.ts +30 -0
- package/components/tooltip/tooltip.module.d.ts +3 -1
- package/components/wrapped-input/wrapped-input.component.d.ts +1 -4
- package/esm2022/components/avatar/avatar.component.mjs +3 -7
- package/esm2022/components/avatar-list/avatar-list.component.mjs +15 -23
- package/esm2022/components/chip-list/chip-list.component.mjs +2 -3
- package/esm2022/components/form-heading/form-heading.component.mjs +3 -9
- package/esm2022/components/form-heading/form-heading.module.mjs +3 -7
- package/esm2022/components/menu/menu-close-triggers.directive.mjs +9 -15
- package/esm2022/components/menu/menu-item/menu-item.component.mjs +13 -2
- package/esm2022/components/tooltip/tooltip-panel/tooltip-panel.component.mjs +70 -6
- package/esm2022/components/tooltip/tooltip.component.mjs +15 -69
- package/esm2022/components/tooltip/tooltip.directive.mjs +114 -0
- package/esm2022/components/tooltip/tooltip.module.mjs +11 -3
- package/esm2022/components/typeahead/typeahead.component.mjs +4 -8
- package/esm2022/components/wrapped-input/wrapped-input.component.mjs +3 -10
- package/esm2022/public-api.mjs +2 -1
- package/fesm2022/flywheel-io-vision.mjs +242 -187
- package/fesm2022/flywheel-io-vision.mjs.map +1 -1
- package/flywheel-io-vision-2.7.0-beta.1.tgz +0 -0
- package/package.json +1 -1
- package/public-api.d.ts +1 -0
- package/components/tag/tag.component.d.ts +0 -10
- package/components/tag/tag.module.d.ts +0 -9
- package/esm2022/components/tag/tag.component.mjs +0 -25
- package/esm2022/components/tag/tag.module.mjs +0 -28
|
@@ -16,7 +16,7 @@ export declare class FwAvatarListComponent implements OnInit {
|
|
|
16
16
|
applyBorderToChildAvatars: import("@angular/core").EffectRef;
|
|
17
17
|
childrenChanged: import("@angular/core").EffectRef;
|
|
18
18
|
hiddenAvatars: import("@angular/core").WritableSignal<any[]>;
|
|
19
|
-
|
|
19
|
+
calcOverflow(): void;
|
|
20
20
|
static ɵfac: i0.ɵɵFactoryDeclaration<FwAvatarListComponent, never>;
|
|
21
21
|
static ɵcmp: i0.ɵɵComponentDeclaration<FwAvatarListComponent, "fw-avatar-list", never, { "resizeDebounceMs": { "alias": "resizeDebounceMs"; "required": false; "isSignal": true; }; }, {}, ["avatars", "avatarElementRefs"], ["fw-avatar"], true, never>;
|
|
22
22
|
}
|
|
@@ -3,10 +3,8 @@ export declare class FwFormHeadingComponent {
|
|
|
3
3
|
class: string;
|
|
4
4
|
title: string;
|
|
5
5
|
description?: string;
|
|
6
|
-
required?: boolean;
|
|
7
6
|
status?: string;
|
|
8
|
-
statusColor?: 'slate' | 'primary' | 'secondary' | 'red' | 'green' | 'orange';
|
|
9
7
|
constructor();
|
|
10
8
|
static ɵfac: i0.ɵɵFactoryDeclaration<FwFormHeadingComponent, never>;
|
|
11
|
-
static ɵcmp: i0.ɵɵComponentDeclaration<FwFormHeadingComponent, "fw-form-heading", never, { "title": { "alias": "title"; "required": false; }; "description": { "alias": "description"; "required": false; }; "
|
|
9
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<FwFormHeadingComponent, "fw-form-heading", never, { "title": { "alias": "title"; "required": false; }; "description": { "alias": "description"; "required": false; }; "status": { "alias": "status"; "required": false; }; }, {}, never, ["fw-tooltip", "fw-icon", "fw-chip", "p", "*"], false, never>;
|
|
12
10
|
}
|
|
@@ -3,9 +3,8 @@ import * as i1 from "./form-heading.component";
|
|
|
3
3
|
import * as i2 from "@angular/common";
|
|
4
4
|
import * as i3 from "../button/button.module";
|
|
5
5
|
import * as i4 from "../icon/icon.module";
|
|
6
|
-
import * as i5 from "../tag/tag.module";
|
|
7
6
|
export declare class FwFormHeadingModule {
|
|
8
7
|
static ɵfac: i0.ɵɵFactoryDeclaration<FwFormHeadingModule, never>;
|
|
9
|
-
static ɵmod: i0.ɵɵNgModuleDeclaration<FwFormHeadingModule, [typeof i1.FwFormHeadingComponent], [typeof i2.CommonModule, typeof i3.FwButtonModule, typeof i4.FwIconModule
|
|
8
|
+
static ɵmod: i0.ɵɵNgModuleDeclaration<FwFormHeadingModule, [typeof i1.FwFormHeadingComponent], [typeof i2.CommonModule, typeof i3.FwButtonModule, typeof i4.FwIconModule], [typeof i1.FwFormHeadingComponent]>;
|
|
10
9
|
static ɵinj: i0.ɵɵInjectorDeclaration<FwFormHeadingModule>;
|
|
11
10
|
}
|
|
@@ -2,9 +2,9 @@ import { CdkMenuTrigger } from '@angular/cdk/menu';
|
|
|
2
2
|
import { QueryList } from '@angular/core';
|
|
3
3
|
import * as i0 from "@angular/core";
|
|
4
4
|
export declare class FwMenuCloseTriggersDirective {
|
|
5
|
+
outsideClick(): void;
|
|
5
6
|
triggers?: QueryList<CdkMenuTrigger>;
|
|
6
7
|
private _isOpen;
|
|
7
|
-
outsideClick(event: MouseEvent): void;
|
|
8
8
|
static ɵfac: i0.ɵɵFactoryDeclaration<FwMenuCloseTriggersDirective, never>;
|
|
9
9
|
static ɵdir: i0.ɵɵDirectiveDeclaration<FwMenuCloseTriggersDirective, "[fwMenuCloseTriggers]", never, {}, {}, ["triggers"], never, false, never>;
|
|
10
10
|
}
|
|
@@ -35,6 +35,11 @@ export declare class FwMenuItemComponent implements OnChanges, OnDestroy, AfterC
|
|
|
35
35
|
updateLayout(): void;
|
|
36
36
|
toggleSubItemsView(): void;
|
|
37
37
|
handleClick(evt?: Event): void;
|
|
38
|
+
/**
|
|
39
|
+
* stops the browser built-in tooltip from showing up
|
|
40
|
+
* @see https://developer.mozilla.org/en-US/docs/Web/HTML/Reference/Global_attributes/title
|
|
41
|
+
*/
|
|
42
|
+
get attrTitle(): string;
|
|
38
43
|
static ɵfac: i0.ɵɵFactoryDeclaration<FwMenuItemComponent, never>;
|
|
39
44
|
static ɵcmp: i0.ɵɵComponentDeclaration<FwMenuItemComponent, "fw-menu-item", never, { "value": { "alias": "value"; "required": false; }; "size": { "alias": "size"; "required": false; }; "title": { "alias": "title"; "required": false; }; "description": { "alias": "description"; "required": false; }; "icon": { "alias": "icon"; "required": false; }; "iconColor": { "alias": "iconColor"; "required": false; }; "disabled": { "alias": "disabled"; "required": false; }; "showCheckbox": { "alias": "showCheckbox"; "required": false; }; "checkboxColor": { "alias": "checkboxColor"; "required": false; }; "multiSelect": { "alias": "multiSelect"; "required": false; }; "hidden": { "alias": "hidden"; "required": false; }; "collapsed": { "alias": "collapsed"; "required": false; }; "href": { "alias": "href"; "required": false; }; "target": { "alias": "target"; "required": false; }; "subItemsOpen": { "alias": "subItemsOpen"; "required": false; }; "mouseEnterHandler": { "alias": "mouseEnterHandler"; "required": false; "isSignal": true; }; "focused": { "alias": "focused"; "required": false; }; "selected": { "alias": "selected"; "required": false; }; }, { "mouseEnterHandler": "mouseEnterHandlerChange"; "click": "click"; }, ["subItems"], ["fw-avatar", "p", "fw-badge", "fw-icon", "fw-icon-button", "fw-menu-sub-item"], false, never>;
|
|
40
45
|
}
|
|
@@ -1,12 +1,23 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { CdkOverlayOrigin, ConnectedPosition, Overlay } from '@angular/cdk/overlay';
|
|
2
|
+
import { ElementRef, EventEmitter } from '@angular/core';
|
|
2
3
|
import * as i0 from "@angular/core";
|
|
4
|
+
export type DelayLength = 'none' | 'short' | 'long';
|
|
5
|
+
export type SimplePosition = 'above' | 'below' | 'left' | 'right' | 'none';
|
|
3
6
|
export declare class FwTooltipPanelComponent {
|
|
4
|
-
|
|
7
|
+
trigger: import("@angular/core").InputSignalWithTransform<CdkOverlayOrigin, CdkOverlayOrigin | ElementRef<HTMLElement>>;
|
|
8
|
+
title: string;
|
|
9
|
+
isOpen: import("@angular/core").InputSignal<boolean>;
|
|
10
|
+
position: import("@angular/core").InputSignal<SimplePosition>;
|
|
11
|
+
connectedPosition: import("@angular/core").Signal<ConnectedPosition[]>;
|
|
5
12
|
color?: 'light' | 'dark';
|
|
6
13
|
maxWidth?: number;
|
|
7
14
|
mouseLeave: EventEmitter<MouseEvent>;
|
|
15
|
+
delay: import("@angular/core").InputSignal<DelayLength>;
|
|
16
|
+
delayMs: import("@angular/core").Signal<number>;
|
|
17
|
+
overlayService: Overlay;
|
|
18
|
+
updateOverlayOnChange: import("@angular/core").EffectRef;
|
|
8
19
|
get classes(): string;
|
|
9
20
|
hidePopover(e: MouseEvent): void;
|
|
10
21
|
static ɵfac: i0.ɵɵFactoryDeclaration<FwTooltipPanelComponent, never>;
|
|
11
|
-
static ɵcmp: i0.ɵɵComponentDeclaration<FwTooltipPanelComponent, "fw-tooltip-panel", never, { "position": { "alias": "position"; "required": false; }; "color": { "alias": "color"; "required": false; }; "maxWidth": { "alias": "maxWidth"; "required": false; }; }, { "mouseLeave": "mouseLeave"; }, never, ["*"], false, never>;
|
|
22
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<FwTooltipPanelComponent, "fw-tooltip-panel", never, { "trigger": { "alias": "trigger"; "required": false; "isSignal": true; }; "title": { "alias": "title"; "required": false; }; "isOpen": { "alias": "isOpen"; "required": false; "isSignal": true; }; "position": { "alias": "position"; "required": false; "isSignal": true; }; "color": { "alias": "color"; "required": false; }; "maxWidth": { "alias": "maxWidth"; "required": false; }; "delay": { "alias": "delay"; "required": false; "isSignal": true; }; }, { "mouseLeave": "mouseLeave"; }, never, ["*"], false, never>;
|
|
12
23
|
}
|
|
@@ -1,4 +1,5 @@
|
|
|
1
|
-
import { CdkOverlayOrigin,
|
|
1
|
+
import { CdkOverlayOrigin, FlexibleConnectedPositionStrategyOrigin } from '@angular/cdk/overlay';
|
|
2
|
+
import { SimplePosition } from './tooltip-panel/tooltip-panel.component';
|
|
2
3
|
import * as i0 from "@angular/core";
|
|
3
4
|
type DelayLength = 'none' | 'short' | 'long';
|
|
4
5
|
/**
|
|
@@ -8,26 +9,18 @@ type DelayLength = 'none' | 'short' | 'long';
|
|
|
8
9
|
export declare class FwTooltipComponent {
|
|
9
10
|
title: string;
|
|
10
11
|
color: 'light' | 'dark';
|
|
11
|
-
position:
|
|
12
|
+
position: SimplePosition;
|
|
12
13
|
maxWidth?: number;
|
|
13
14
|
fullWidth?: boolean;
|
|
14
15
|
isOpen: boolean;
|
|
15
16
|
trigger: CdkOverlayOrigin | FlexibleConnectedPositionStrategyOrigin;
|
|
16
|
-
private cdRef;
|
|
17
17
|
delay: import("@angular/core").InputSignal<DelayLength>;
|
|
18
|
-
delayMs: import("@angular/core").Signal<number>;
|
|
19
18
|
get classes(): string;
|
|
20
19
|
/**
|
|
21
20
|
* stops the browser built-in tooltip from showing up
|
|
22
21
|
* @see https://developer.mozilla.org/en-US/docs/Web/HTML/Reference/Global_attributes/title
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
positionMap: {
|
|
26
|
-
[key: string]: ConnectedPosition;
|
|
27
|
-
};
|
|
28
|
-
private openDelayTimer;
|
|
29
|
-
handleMouseEnter(event: MouseEvent): void;
|
|
30
|
-
handleMouseLeave(): void;
|
|
22
|
+
*/
|
|
23
|
+
get attrTitle(): string;
|
|
31
24
|
static ɵfac: i0.ɵɵFactoryDeclaration<FwTooltipComponent, never>;
|
|
32
25
|
static ɵcmp: i0.ɵɵComponentDeclaration<FwTooltipComponent, "fw-tooltip", never, { "title": { "alias": "title"; "required": false; }; "color": { "alias": "color"; "required": false; }; "position": { "alias": "position"; "required": false; }; "maxWidth": { "alias": "maxWidth"; "required": false; }; "fullWidth": { "alias": "fullWidth"; "required": false; }; "isOpen": { "alias": "isOpen"; "required": false; }; "trigger": { "alias": "trigger"; "required": false; }; "delay": { "alias": "delay"; "required": false; "isSignal": true; }; }, {}, never, ["*"], false, never>;
|
|
33
26
|
}
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
import { ConnectedPosition, OverlayConfig } from '@angular/cdk/overlay';
|
|
2
|
+
import { OnInit } from '@angular/core';
|
|
3
|
+
import { SimplePosition } from './tooltip-panel/tooltip-panel.component';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
type DelayLength = 'none' | 'short' | 'long';
|
|
6
|
+
export declare class FwTooltipDirective implements OnInit {
|
|
7
|
+
private elementRef;
|
|
8
|
+
private viewContainerRef;
|
|
9
|
+
private overlayService;
|
|
10
|
+
private overlayRef;
|
|
11
|
+
private tooltipRef;
|
|
12
|
+
private tooltipPortal;
|
|
13
|
+
delayMs: import("@angular/core").InputSignalWithTransform<number, DelayLength>;
|
|
14
|
+
title: import("@angular/core").ModelSignal<string>;
|
|
15
|
+
position: import("@angular/core").ModelSignal<SimplePosition>;
|
|
16
|
+
maxWidth: import("@angular/core").ModelSignal<number>;
|
|
17
|
+
enabled: import("@angular/core").ModelSignal<boolean>;
|
|
18
|
+
connectedPosition: import("@angular/core").Signal<ConnectedPosition[]>;
|
|
19
|
+
positionStrategy: import("@angular/core").Signal<import("@angular/cdk/overlay").FlexibleConnectedPositionStrategy>;
|
|
20
|
+
overlayConfig: import("@angular/core").Signal<OverlayConfig>;
|
|
21
|
+
addMouseEventListeners: import("@angular/core").EffectRef;
|
|
22
|
+
ngOnInit(): void;
|
|
23
|
+
private openDelayTimer;
|
|
24
|
+
private closeDelayTimer;
|
|
25
|
+
showTooltip(): void;
|
|
26
|
+
hideTooltip(): void;
|
|
27
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<FwTooltipDirective, never>;
|
|
28
|
+
static ɵdir: i0.ɵɵDirectiveDeclaration<FwTooltipDirective, "[fwTooltip]", never, { "delayMs": { "alias": "fwTooltipDelay"; "required": false; "isSignal": true; }; "title": { "alias": "fwTooltip"; "required": false; "isSignal": true; }; "position": { "alias": "fwTooltipPosition"; "required": false; "isSignal": true; }; "maxWidth": { "alias": "fwTooltipMaxWidthPx"; "required": false; "isSignal": true; }; "enabled": { "alias": "fwTooltipEnabled"; "required": false; "isSignal": true; }; }, { "title": "fwTooltipChange"; "position": "fwTooltipPositionChange"; "maxWidth": "fwTooltipMaxWidthPxChange"; "enabled": "fwTooltipEnabledChange"; }, never, never, true, never>;
|
|
29
|
+
}
|
|
30
|
+
export {};
|
|
@@ -4,8 +4,10 @@ import * as i2 from "./tooltip-panel/tooltip-panel.component";
|
|
|
4
4
|
import * as i3 from "@angular/common";
|
|
5
5
|
import * as i4 from "../popover/popover.module";
|
|
6
6
|
import * as i5 from "@angular/cdk/overlay";
|
|
7
|
+
import * as i6 from "@angular/cdk/table";
|
|
8
|
+
import * as i7 from "./tooltip.directive";
|
|
7
9
|
export declare class FwTooltipModule {
|
|
8
10
|
static ɵfac: i0.ɵɵFactoryDeclaration<FwTooltipModule, never>;
|
|
9
|
-
static ɵmod: i0.ɵɵNgModuleDeclaration<FwTooltipModule, [typeof i1.FwTooltipComponent, typeof i2.FwTooltipPanelComponent], [typeof i3.CommonModule, typeof i4.FwPopoverModule, typeof i5.OverlayModule], [typeof i1.FwTooltipComponent, typeof i2.FwTooltipPanelComponent]>;
|
|
11
|
+
static ɵmod: i0.ɵɵNgModuleDeclaration<FwTooltipModule, [typeof i1.FwTooltipComponent, typeof i2.FwTooltipPanelComponent], [typeof i3.CommonModule, typeof i4.FwPopoverModule, typeof i5.OverlayModule, typeof i6.CdkNoDataRow, typeof i7.FwTooltipDirective], [typeof i1.FwTooltipComponent, typeof i2.FwTooltipPanelComponent, typeof i7.FwTooltipDirective]>;
|
|
10
12
|
static ɵinj: i0.ɵɵInjectorDeclaration<FwTooltipModule>;
|
|
11
13
|
}
|
|
@@ -1,13 +1,10 @@
|
|
|
1
1
|
import * as i0 from "@angular/core";
|
|
2
2
|
export declare class FwWrappedInputComponent {
|
|
3
3
|
title: string;
|
|
4
|
-
status?: string;
|
|
5
|
-
statusColor?: 'slate' | 'primary' | 'secondary' | 'red' | 'green' | 'orange';
|
|
6
4
|
description?: string;
|
|
7
5
|
helperText?: string;
|
|
8
6
|
errorText?: string;
|
|
9
|
-
required?: boolean;
|
|
10
7
|
class: boolean;
|
|
11
8
|
static ɵfac: i0.ɵɵFactoryDeclaration<FwWrappedInputComponent, never>;
|
|
12
|
-
static ɵcmp: i0.ɵɵComponentDeclaration<FwWrappedInputComponent, "fw-wrapped-input", never, { "title": { "alias": "title"; "required": false; }; "
|
|
9
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<FwWrappedInputComponent, "fw-wrapped-input", never, { "title": { "alias": "title"; "required": false; }; "description": { "alias": "description"; "required": false; }; "helperText": { "alias": "helperText"; "required": false; }; "errorText": { "alias": "errorText"; "required": false; }; }, {}, never, ["fw-form-heading", "fw-button-toggle, fw-date-input, fw-text-input, fw-number-input, fw-phone-input, fw-textarea-input, fw-select, fw-multi-select, fw-checkbox, fw-typeahead"], false, never>;
|
|
13
10
|
}
|
|
@@ -33,12 +33,8 @@ export class FwAvatarComponent {
|
|
|
33
33
|
return [this.size, this.variant, this.content, 'selected'].filter(Boolean).join(' ');
|
|
34
34
|
}
|
|
35
35
|
;
|
|
36
|
-
get borderClass() {
|
|
37
|
-
|
|
38
|
-
}
|
|
39
|
-
get selectedClassApplied() {
|
|
40
|
-
return this.selected();
|
|
41
|
-
}
|
|
36
|
+
get borderClass() { return this.bordered; }
|
|
37
|
+
get selectedClassApplied() { return this.selected(); }
|
|
42
38
|
loadImage() {
|
|
43
39
|
this.isImageBroken = false;
|
|
44
40
|
}
|
|
@@ -79,4 +75,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
79
75
|
type: HostBinding,
|
|
80
76
|
args: ['class.selected']
|
|
81
77
|
}] } });
|
|
82
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
78
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXZhdGFyLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3NyYy9jb21wb25lbnRzL2F2YXRhci9hdmF0YXIuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vc3JjL2NvbXBvbmVudHMvYXZhdGFyL2F2YXRhci5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLFFBQVEsRUFBQyxXQUFXLEVBQUUsS0FBSyxFQUFFLEtBQUssRUFBRSxLQUFLLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFFckYsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sbUJBQW1CLENBQUM7Ozs7QUFLckQsTUFBTSxhQUFhLEdBQXlDO0lBQzFELE9BQU8sRUFBRSxxQkFBcUI7SUFDOUIsU0FBUyxFQUFFLHVCQUF1QjtJQUNsQyxHQUFHLEVBQUUsaUJBQWlCO0lBQ3RCLGFBQWEsRUFBRSxvQkFBb0I7SUFDbkMsS0FBSyxFQUFFLG1CQUFtQjtJQUMxQixPQUFPLEVBQUUsb0JBQW9CO0lBQzdCLE9BQU8sRUFBRSxtQkFBbUI7Q0FDN0IsQ0FBQTtBQU1ELE1BQU0sT0FBTyxpQkFBaUI7SUFMOUI7UUFZVyxVQUFLLEdBQXVCLFNBQVMsQ0FBQztRQUN0QyxZQUFPLEdBQXVDLFVBQVUsQ0FBQztRQUN6RCxZQUFPLEdBQWtDLE1BQU0sQ0FBQztRQUNoRCxTQUFJLEdBQThDLE9BQU8sQ0FBQztRQUMxRCxZQUFPLEdBQVksRUFBRSxDQUFDO1FBQ3RCLGFBQVEsR0FBWSxFQUFFLENBQUM7UUFDdkIsaUJBQVksR0FBWSxFQUFFLENBQUM7UUFDM0IsU0FBSSxHQUFjLE1BQU0sQ0FBQztRQUN6QixhQUFRLEdBQUcsS0FBSyxDQUFDO1FBRTFCLGFBQVEsR0FBRyxLQUFLLENBQUMsS0FBSyxDQUFDLENBQUM7UUFDeEIsY0FBUyxHQUFHLEtBQUssRUFBVSxDQUFDO1FBSTVCLGVBQVUsR0FBRyxRQUFRLENBQUMsR0FBRyxFQUFFLENBQUMsZ0JBQWdCLENBQUMsSUFBSSxDQUFDLFNBQVMsRUFBRSxDQUFDLENBQUMsQ0FBQztRQUVoRSxtQkFBYyxHQUFHLFFBQVEsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxJQUFJLENBQUMsU0FBUyxFQUFFLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxVQUFVLEVBQUUsQ0FBQyxDQUFDLENBQUMsYUFBYSxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDO1FBRWxHLGtCQUFhLEdBQVksS0FBSyxDQUFDO0tBU2hDO0lBbENDLElBQStCLE9BQU87UUFFcEMsT0FBTyxDQUFDLElBQUksQ0FBQyxJQUFJLEVBQUUsSUFBSSxDQUFDLE9BQU8sRUFBRSxJQUFJLENBQUMsT0FBTyxFQUFFLFVBQVUsQ0FBQyxDQUFDLE1BQU0sQ0FBQyxPQUFPLENBQUMsQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLENBQUM7SUFDdkYsQ0FBQztJQUFBLENBQUM7SUFZRixJQUFtQyxXQUFXLEtBQUssT0FBTyxJQUFJLENBQUMsUUFBUSxDQUFDLENBQUMsQ0FBQztJQUkxRSxJQUFtQyxvQkFBb0IsS0FBYyxPQUFPLElBQUksQ0FBQyxRQUFRLEVBQUUsQ0FBQyxDQUFDLENBQUM7SUFROUYsU0FBUztRQUNQLElBQUksQ0FBQyxhQUFhLEdBQUcsS0FBSyxDQUFDO0lBQzdCLENBQUM7SUFFRCxVQUFVO1FBQ1IsSUFBSSxDQUFDLGFBQWEsR0FBRyxJQUFJLENBQUM7SUFDNUIsQ0FBQzsrR0FsQ1UsaUJBQWlCO21HQUFqQixpQkFBaUIsOG1EQ3JCOUIsNjRCQXNCQTs7NEZERGEsaUJBQWlCO2tCQUw3QixTQUFTOytCQUNFLFdBQVc7OEJBS1UsT0FBTztzQkFBckMsV0FBVzt1QkFBQyxZQUFZO2dCQU1oQixLQUFLO3NCQUFiLEtBQUs7Z0JBQ0csT0FBTztzQkFBZixLQUFLO2dCQUNHLE9BQU87c0JBQWYsS0FBSztnQkFDRyxJQUFJO3NCQUFaLEtBQUs7Z0JBQ0csT0FBTztzQkFBZixLQUFLO2dCQUNHLFFBQVE7c0JBQWhCLEtBQUs7Z0JBQ0csWUFBWTtzQkFBcEIsS0FBSztnQkFDRyxJQUFJO3NCQUFaLEtBQUs7Z0JBQ0csUUFBUTtzQkFBaEIsS0FBSztnQkFDNkIsV0FBVztzQkFBN0MsV0FBVzt1QkFBQyxnQkFBZ0I7Z0JBSU0sb0JBQW9CO3NCQUF0RCxXQUFXO3VCQUFDLGdCQUFnQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgY29tcHV0ZWQsSG9zdEJpbmRpbmcsIElucHV0LCBpbnB1dCwgbW9kZWwgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuaW1wb3J0IHsgcGlja0NvbG9yVmlhSGFzaCB9IGZyb20gJy4uLy4uL2NvbG9yLnV0aWxzJztcbmltcG9ydCB7IEljb25UeXBlIH0gZnJvbSAnLi4vaWNvbi9pY29uLnR5cGVzJztcblxudHlwZSBBdmF0YXJDb2xvck9wdGlvbiA9ICdwcmltYXJ5JyB8ICdzZWNvbmRhcnknIHwgJ3JlZCcgfCAnbGlnaHQtc2xhdGUnIHwgJ3NsYXRlJyB8ICd3YXJuaW5nJyB8ICdzdWNjZXNzJztcblxuY29uc3QgbmFtZWRDb2xvck1hcDogeyBbSyBpbiBBdmF0YXJDb2xvck9wdGlvbl06IHN0cmluZyB9ID0ge1xuICBwcmltYXJ5OiAndmFyKC0tcHJpbWFyeS1iYXNlKScsXG4gIHNlY29uZGFyeTogJ3ZhcigtLXNlY29uZGFyeS1iYXNlKScsXG4gIHJlZDogJ3ZhcigtLXJlZC1iYXNlKScsXG4gICdsaWdodC1zbGF0ZSc6ICd2YXIoLS1zbGF0ZS1saWdodCknLFxuICBzbGF0ZTogJ3ZhcigtLXNsYXRlLWJhc2UpJyxcbiAgd2FybmluZzogJ3ZhcigtLW9yYW5nZS1iYXNlKScsXG4gIHN1Y2Nlc3M6ICd2YXIoLS1ncmVlbi1iYXNlKScsXG59XG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdmdy1hdmF0YXInLFxuICBzdHlsZVVybHM6IFsnLi9hdmF0YXIuY29tcG9uZW50LnNjc3MnXSxcbiAgdGVtcGxhdGVVcmw6ICcuL2F2YXRhci5jb21wb25lbnQuaHRtbCcsXG59KVxuZXhwb3J0IGNsYXNzIEZ3QXZhdGFyQ29tcG9uZW50IHtcbiAgQEhvc3RCaW5kaW5nKCdhdHRyLmNsYXNzJykgZ2V0IGNsYXNzZXMoKTogc3RyaW5nIHtcblxuICAgIHJldHVybiBbdGhpcy5zaXplLCB0aGlzLnZhcmlhbnQsIHRoaXMuY29udGVudCwgJ3NlbGVjdGVkJ10uZmlsdGVyKEJvb2xlYW4pLmpvaW4oJyAnKTtcbiAgfTtcblxuXG4gIEBJbnB1dCgpIGNvbG9yPzogQXZhdGFyQ29sb3JPcHRpb24gPSAncHJpbWFyeSc7XG4gIEBJbnB1dCgpIHZhcmlhbnQ/OiAnY2lyY3VsYXInIHwgJ3JvdW5kZWQnIHwgJ3NxdWFyZScgPSAnY2lyY3VsYXInO1xuICBASW5wdXQoKSBjb250ZW50PzogJ2ltYWdlJyB8ICdpY29uJyB8ICdpbml0aWFsJyA9ICdpY29uJztcbiAgQElucHV0KCkgc2l6ZT86ICdzbWFsbCcgfCAnbWVkaXVtJyB8ICdsYXJnZScgfCAneC1sYXJnZScgPSAnc21hbGwnO1xuICBASW5wdXQoKSBpbml0aWFsPzogc3RyaW5nID0gJyc7XG4gIEBJbnB1dCgpIGltYWdlVXJsPzogc3RyaW5nID0gJyc7XG4gIEBJbnB1dCgpIGltYWdlQWx0VGV4dD86IHN0cmluZyA9ICcnO1xuICBASW5wdXQoKSBpY29uPzogSWNvblR5cGUgPSAndXNlcic7XG4gIEBJbnB1dCgpIGJvcmRlcmVkID0gZmFsc2U7XG4gIEBIb3N0QmluZGluZygnY2xhc3MuYm9yZGVyZWQnKSBnZXQgYm9yZGVyQ2xhc3MoKSB7IHJldHVybiB0aGlzLmJvcmRlcmVkOyB9XG4gIHNlbGVjdGVkID0gaW5wdXQoZmFsc2UpO1xuICBjb2xvclNlZWQgPSBtb2RlbDxzdHJpbmc+KCk7XG5cbiAgQEhvc3RCaW5kaW5nKCdjbGFzcy5zZWxlY3RlZCcpIGdldCBzZWxlY3RlZENsYXNzQXBwbGllZCgpOiBib29sZWFuIHsgcmV0dXJuIHRoaXMuc2VsZWN0ZWQoKTsgfVxuXG4gIGhhc2VkQ29sb3IgPSBjb21wdXRlZCgoKSA9PiBwaWNrQ29sb3JWaWFIYXNoKHRoaXMuY29sb3JTZWVkKCkpKTtcblxuICBjb2xvclRvRGlzcGxheSA9IGNvbXB1dGVkKCgpID0+IHRoaXMuY29sb3JTZWVkKCkgPyB0aGlzLmhhc2VkQ29sb3IoKSA6IG5hbWVkQ29sb3JNYXBbdGhpcy5jb2xvcl0pO1xuXG4gIGlzSW1hZ2VCcm9rZW46IGJvb2xlYW4gPSBmYWxzZTtcblxuICBsb2FkSW1hZ2UoKTogdm9pZCB7XG4gICAgdGhpcy5pc0ltYWdlQnJva2VuID0gZmFsc2U7XG4gIH1cblxuICBlcnJvckltYWdlKCk6IHZvaWQge1xuICAgIHRoaXMuaXNJbWFnZUJyb2tlbiA9IHRydWU7XG4gIH1cbn1cbiIsIjxuZy1jb250YWluZXIgW25nU3dpdGNoXT1cImNvbnRlbnRcIj5cbiAgPGRpdiBbc3R5bGUuYmFja2dyb3VuZENvbG9yXT1cImNvbG9yVG9EaXNwbGF5KClcIiAqbmdTd2l0Y2hDYXNlPVwiJ2ltYWdlJ1wiIGNsYXNzPVwiYXZhdGFyXCI+XG4gICAgPGltZ1xuICAgICAgKm5nSWY9XCIhaXNJbWFnZUJyb2tlbiBlbHNlIGRpc3BsYXlJbml0aWFsXCJcbiAgICAgIFtzcmNdPVwiaW1hZ2VVcmxcIlxuICAgICAgW2FsdF09XCJpbWFnZUFsdFRleHRcIlxuICAgICAgKGxvYWQpPVwibG9hZEltYWdlKClcIlxuICAgICAgKGVycm9yKT1cImVycm9ySW1hZ2UoKVwiPlxuICA8L2Rpdj5cbiAgPGRpdiAqbmdTd2l0Y2hDYXNlPVwiJ2ljb24nXCIgW3N0eWxlLmJhY2tncm91bmRDb2xvcl09XCJjb2xvclRvRGlzcGxheSgpXCIgY2xhc3M9XCJhdmF0YXJcIj5cbiAgICA8bmctY29udGFpbmVyICpuZ1RlbXBsYXRlT3V0bGV0PVwiZGlzcGxheUljb25cIj48L25nLWNvbnRhaW5lcj5cbiAgPC9kaXY+XG4gIDxkaXYgKm5nU3dpdGNoQ2FzZT1cIidpbml0aWFsJ1wiIFtzdHlsZS5iYWNrZ3JvdW5kQ29sb3JdPVwiY29sb3JUb0Rpc3BsYXkoKVwiIGNsYXNzPVwiYXZhdGFyXCI+XG4gICAgPG5nLWNvbnRhaW5lciAqbmdUZW1wbGF0ZU91dGxldD1cImRpc3BsYXlJbml0aWFsXCI+PC9uZy1jb250YWluZXI+XG4gIDwvZGl2PlxuPC9uZy1jb250YWluZXI+XG48bmctdGVtcGxhdGUgI2Rpc3BsYXlJbml0aWFsPlxuICA8c3BhbiBjbGFzcz1cImluaXRpYWxcIiAqbmdJZj1cImluaXRpYWwgZWxzZSBkaXNwbGF5SWNvblwiPnt7IGluaXRpYWwgfX08L3NwYW4+XG48L25nLXRlbXBsYXRlPlxuPG5nLXRlbXBsYXRlICNkaXNwbGF5SWNvbj5cbiAgPGZ3LWljb24+e3sgaWNvbiB9fTwvZnctaWNvbj5cbjwvbmctdGVtcGxhdGU+XG4iXX0=
|
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import { ChangeDetectorRef, Component, contentChildren, effect, ElementRef, inject, input, signal, viewChild
|
|
2
|
-
import { BehaviorSubject, debounce, timer } from 'rxjs';
|
|
1
|
+
import { ChangeDetectorRef, Component, contentChildren, effect, ElementRef, inject, input, signal, viewChild } from '@angular/core';
|
|
2
|
+
import { BehaviorSubject, debounce, distinctUntilChanged, timer } from 'rxjs';
|
|
3
3
|
import { FwAvatarComponent } from '../avatar/avatar.component';
|
|
4
4
|
import { FwAvatarModule } from '../avatar/avatar.module';
|
|
5
5
|
import { FwTooltipModule } from '../tooltip/tooltip.module';
|
|
@@ -26,44 +26,37 @@ export class FwAvatarListComponent {
|
|
|
26
26
|
});
|
|
27
27
|
this.childrenChanged = effect(() => {
|
|
28
28
|
this.avatarElementRefs();
|
|
29
|
-
this.
|
|
29
|
+
this.calcOverflow();
|
|
30
30
|
}, { allowSignalWrites: true });
|
|
31
31
|
this.hiddenAvatars = signal([]);
|
|
32
32
|
}
|
|
33
33
|
ngOnInit() {
|
|
34
34
|
// wire up resize observer to rxjs and debouce
|
|
35
35
|
const resize$ = new BehaviorSubject(null);
|
|
36
|
-
const recalcOnResize$ = resize$.pipe(debounce(() => timer(this.resizeDebounceMs())));
|
|
37
|
-
const resizeObserver = new ResizeObserver(() => {
|
|
38
|
-
resize$.next();
|
|
36
|
+
const recalcOnResize$ = resize$.pipe(distinctUntilChanged(), debounce(() => timer(this.resizeDebounceMs())));
|
|
37
|
+
const resizeObserver = new ResizeObserver((resizeEntries) => {
|
|
38
|
+
resize$.next(resizeEntries);
|
|
39
39
|
});
|
|
40
40
|
resizeObserver.observe(this.hostElement.nativeElement, {});
|
|
41
|
-
recalcOnResize$.subscribe(() => this.
|
|
41
|
+
recalcOnResize$.subscribe(() => this.calcOverflow());
|
|
42
42
|
}
|
|
43
|
-
|
|
43
|
+
calcOverflow() {
|
|
44
44
|
const hostRect = this.hostElement.nativeElement.getBoundingClientRect();
|
|
45
45
|
const avatarElements = this.avatarElementRefs().map(ref => ref.nativeElement);
|
|
46
46
|
const moreTextElement = this.moreText().nativeElement;
|
|
47
|
-
avatarElements.forEach(
|
|
47
|
+
avatarElements.forEach(avatar => avatar.classList.remove('hidden'));
|
|
48
48
|
moreTextElement.classList.remove('hidden');
|
|
49
|
-
const
|
|
50
|
-
const
|
|
51
|
-
return !(
|
|
49
|
+
const visibleAvatars = avatarElements.filter(avatar => {
|
|
50
|
+
const avatarRect = avatar.getBoundingClientRect();
|
|
51
|
+
return !(avatarRect.right > hostRect.right || avatarRect.bottom > hostRect.bottom);
|
|
52
52
|
});
|
|
53
|
-
const overflowingAvatars = avatarElements.toSpliced(0,
|
|
53
|
+
const overflowingAvatars = avatarElements.toSpliced(0, visibleAvatars.length);
|
|
54
54
|
if (overflowingAvatars.length > 0) {
|
|
55
|
-
const lastVisibleAvatar =
|
|
55
|
+
const lastVisibleAvatar = visibleAvatars[visibleAvatars.length - 1];
|
|
56
56
|
const enoughRoomForMoreText = (hostRect.right - lastVisibleAvatar.getBoundingClientRect().right) > (moreTextElement.offsetWidth);
|
|
57
57
|
if (!enoughRoomForMoreText) {
|
|
58
58
|
overflowingAvatars.push(lastVisibleAvatar);
|
|
59
59
|
}
|
|
60
|
-
// avatars are less wide than the text so we might need to hide 2 to make room for the text
|
|
61
|
-
// there's probably a fancy recursive solution here but ehhh
|
|
62
|
-
const secondLastVisibleAvatar = visibleChips[visibleChips.length - 2];
|
|
63
|
-
const needEvenMoreSpace = (hostRect.right - secondLastVisibleAvatar.getBoundingClientRect().right) > (moreTextElement.offsetWidth);
|
|
64
|
-
if (!needEvenMoreSpace) {
|
|
65
|
-
overflowingAvatars.push(secondLastVisibleAvatar);
|
|
66
|
-
}
|
|
67
60
|
this.hiddenAvatars.set(overflowingAvatars);
|
|
68
61
|
overflowingAvatars.forEach(hiddenChip => {
|
|
69
62
|
hiddenChip.classList.add('hidden');
|
|
@@ -72,7 +65,6 @@ export class FwAvatarListComponent {
|
|
|
72
65
|
else {
|
|
73
66
|
this.moreText().nativeElement.classList.add('hidden');
|
|
74
67
|
}
|
|
75
|
-
// eslint-disable-next-line @rx-angular/no-explicit-change-detection-apis
|
|
76
68
|
this.changeDetector.detectChanges();
|
|
77
69
|
}
|
|
78
70
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: FwAvatarListComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
@@ -85,4 +77,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
85
77
|
FwTooltipModule,
|
|
86
78
|
], template: "<ng-content select=\"fw-avatar\"></ng-content>\n<fw-tooltip> <!--TODO: figure out how to get a tooltip-->\n <p #moreText> +{{hiddenAvatars().length}} </p>\n</fw-tooltip>\n", styles: [":host{display:flex;align-items:center;flex-basis:max-content;flex-flow:row nowrap;justify-content:flex-start;max-height:36px;overflow:hidden}:host ::ng-deep fw-avatar:not(:first-child){margin-left:-4px}:host p{line-height:100%;cursor:default;margin:0;padding-left:8px;text-wrap:nowrap;color:var(--typography-muted)}:host::ng-deep .hidden{display:none}\n"] }]
|
|
87
79
|
}] });
|
|
88
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"avatar-list.component.js","sourceRoot":"","sources":["../../../../../src/components/avatar-list/avatar-list.component.ts","../../../../../src/components/avatar-list/avatar-list.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectorRef,\n  Component,\n  contentChildren,\n  effect,\n  ElementRef,\n  inject,\n  input,\n  OnInit,\n  signal,\n  viewChild,\n} from '@angular/core';\nimport { BehaviorSubject, debounce, timer } from 'rxjs';\n\nimport { FwAvatarComponent } from '../avatar/avatar.component';\nimport { FwAvatarModule } from '../avatar/avatar.module';\nimport { FwTooltipModule } from '../tooltip/tooltip.module';\n\n// the nature of this component is to handle a complex layout issue so disabling this lint rule\n/* eslint-disable @rx-angular/prefer-no-layout-sensitive-apis */\n\n\n/**\n * Component for displaying and managing the overflow of a list of `fw-avatar`s\n * @see [Vision Docs](https://cdn.flywheel.io/docs/vision/master/?path=/docs/components-avatar-list--docs)\n */\n@Component({\n  selector: 'fw-avatar-list',\n  standalone: true,\n  imports: [\n    FwAvatarModule,\n    FwTooltipModule,\n  ],\n  templateUrl: './avatar-list.component.html',\n  styleUrl: './avatar-list.component.scss',\n})\nexport class FwAvatarListComponent implements OnInit {\n\n  hostElement = inject(ElementRef);\n  avatars = contentChildren<FwAvatarComponent>(FwAvatarComponent);\n  avatarElementRefs = contentChildren<FwAvatarComponent, ElementRef>(FwAvatarComponent, { read: ElementRef });\n  moreText = viewChild.required<ElementRef<HTMLParagraphElement>>('moreText');\n  changeDetector = inject(ChangeDetectorRef);\n  resizeDebounceMs = input(100);\n\n  ngOnInit(): void {\n    // wire up resize observer to rxjs and debouce\n    const resize$ = new BehaviorSubject<void>(null);\n    const recalcOnResize$ = resize$.pipe(\n      debounce(() => timer(this.resizeDebounceMs())), // debounce otherwise it can run EVERY frame\n    );\n\n    const resizeObserver = new ResizeObserver(() => {\n      resize$.next();\n    });\n    resizeObserver.observe(this.hostElement.nativeElement, {});\n    recalcOnResize$.subscribe(() => this.calcChipOverflow());\n  }\n\n  applyBorderToChildAvatars = effect(() => {\n    this.avatars().forEach(avatar => {\n      avatar.bordered = true;\n    });\n  });\n\n  childrenChanged = effect(() => {\n    this.avatarElementRefs();\n    this.calcChipOverflow();\n  }, { allowSignalWrites: true });\n\n\n  hiddenAvatars = signal([]);\n\n  calcChipOverflow(): void {\n\n    const hostRect = (this.hostElement.nativeElement as HTMLElement).getBoundingClientRect();\n    const avatarElements = this.avatarElementRefs().map(ref => ref.nativeElement as HTMLElement);\n    const moreTextElement = this.moreText().nativeElement;\n\n    avatarElements.forEach(chip => chip.classList.remove('hidden'));\n    moreTextElement.classList.remove('hidden');\n\n    const visibleChips = avatarElements.filter(chip => {\n      const chipRect = chip.getBoundingClientRect();\n      return !(chipRect.right > hostRect.right || chipRect.bottom > hostRect.bottom);\n    });\n\n    const overflowingAvatars = avatarElements.toSpliced(0, visibleChips.length);\n\n    if (overflowingAvatars.length > 0) {\n      const lastVisibleAvatar = visibleChips[visibleChips.length - 1];\n      const enoughRoomForMoreText = (hostRect.right - lastVisibleAvatar.getBoundingClientRect().right) > (moreTextElement.offsetWidth);\n\n      if (!enoughRoomForMoreText) {\n        overflowingAvatars.push(lastVisibleAvatar);\n      }\n\n      // avatars are less wide than the text so we might need to hide 2 to make room for the text\n      // there's probably a fancy recursive solution here but ehhh\n      const secondLastVisibleAvatar = visibleChips[visibleChips.length - 2];\n      const needEvenMoreSpace = (hostRect.right - secondLastVisibleAvatar.getBoundingClientRect().right) > (moreTextElement.offsetWidth);\n\n      if (!needEvenMoreSpace) {\n        overflowingAvatars.push(secondLastVisibleAvatar);\n      }\n\n      this.hiddenAvatars.set(overflowingAvatars);\n      overflowingAvatars.forEach(hiddenChip => {\n        hiddenChip.classList.add('hidden');\n      });\n    } else {\n      this.moreText().nativeElement.classList.add('hidden');\n    }\n\n    // eslint-disable-next-line @rx-angular/no-explicit-change-detection-apis\n    this.changeDetector.detectChanges();\n  }\n\n}\n","<ng-content select=\"fw-avatar\"></ng-content>\n<fw-tooltip> <!--TODO: figure out how to get a tooltip-->\n  <p #moreText> +{{hiddenAvatars().length}} </p>\n</fw-tooltip>\n"]}
|
|
80
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"avatar-list.component.js","sourceRoot":"","sources":["../../../../../src/components/avatar-list/avatar-list.component.ts","../../../../../src/components/avatar-list/avatar-list.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,iBAAiB,EAAE,SAAS,EAAE,eAAe,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,EAAE,KAAK,EAAU,MAAM,EAAE,SAAS,EAAE,MAAM,eAAe,CAAC;AAC5I,OAAO,EAAE,eAAe,EAAE,QAAQ,EAAE,oBAAoB,EAAE,KAAK,EAAE,MAAM,MAAM,CAAC;AAE9E,OAAO,EAAE,iBAAiB,EAAE,MAAM,4BAA4B,CAAC;AAC/D,OAAO,EAAE,cAAc,EAAE,MAAM,yBAAyB,CAAC;AACzD,OAAO,EAAE,eAAe,EAAE,MAAM,2BAA2B,CAAC;;;AAE5D,+FAA+F;AAC/F,gEAAgE;AAGhE;;;GAGG;AAWH,MAAM,OAAO,qBAAqB;IAVlC;QAYE,gBAAW,GAAG,MAAM,CAAC,UAAU,CAAC,CAAC;QACjC,YAAO,GAAG,eAAe,CAAoB,iBAAiB,CAAC,CAAC;QAChE,sBAAiB,GAAG,eAAe,CAAgC,iBAAiB,EAAE,EAAE,IAAI,EAAE,UAAU,EAAE,CAAC,CAAC;QAC5G,aAAQ,GAAG,SAAS,CAAC,QAAQ,CAAmC,UAAU,CAAC,CAAC;QAC5E,mBAAc,GAAG,MAAM,CAAC,iBAAiB,CAAC,CAAC;QAC3C,qBAAgB,GAAG,KAAK,CAAC,GAAG,CAAC,CAAC;QAiB9B,8BAAyB,GAAG,MAAM,CAAC,GAAG,EAAE;YACtC,IAAI,CAAC,OAAO,EAAE,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE;gBAC9B,MAAM,CAAC,QAAQ,GAAG,IAAI,CAAA;YACxB,CAAC,CAAC,CAAC;QACL,CAAC,CAAC,CAAA;QAEF,oBAAe,GAAG,MAAM,CAAC,GAAG,EAAE;YAC5B,IAAI,CAAC,iBAAiB,EAAE,CAAC;YACzB,IAAI,CAAC,YAAY,EAAE,CAAC;QACtB,CAAC,EAAE,EAAE,iBAAiB,EAAE,IAAI,EAAE,CAAC,CAAA;QAG/B,kBAAa,GAAG,MAAM,CAAC,EAAE,CAAC,CAAC;KAqC5B;IAhEC,QAAQ;QACN,8CAA8C;QAC9C,MAAM,OAAO,GAAG,IAAI,eAAe,CAAwB,IAAI,CAAC,CAAC;QACjE,MAAM,eAAe,GAAG,OAAO,CAAC,IAAI,CAClC,oBAAoB,EAAE,EACtB,QAAQ,CAAC,GAAG,EAAE,CAAC,KAAK,CAAC,IAAI,CAAC,gBAAgB,EAAE,CAAC,CAAC,CAC/C,CAAC;QAEF,MAAM,cAAc,GAAG,IAAI,cAAc,CAAC,CAAC,aAAa,EAAE,EAAE;YAC1D,OAAO,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;QAC9B,CAAC,CAAC,CAAA;QACF,cAAc,CAAC,OAAO,CAAC,IAAI,CAAC,WAAW,CAAC,aAAa,EAAE,EAAG,CAAC,CAAC;QAC5D,eAAe,CAAC,SAAS,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,YAAY,EAAE,CAAC,CAAC;IACvD,CAAC;IAgBD,YAAY;QAEV,MAAM,QAAQ,GAAI,IAAI,CAAC,WAAW,CAAC,aAA6B,CAAC,qBAAqB,EAAE,CAAC;QACzF,MAAM,cAAc,GAAG,IAAI,CAAC,iBAAiB,EAAE,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,aAA4B,CAAC,CAAC;QAC7F,MAAM,eAAe,GAAG,IAAI,CAAC,QAAQ,EAAE,CAAC,aAAa,CAAC;QAEtD,cAAc,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE,CAAC,MAAM,CAAC,SAAS,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,CAAC;QACpE,eAAe,CAAC,SAAS,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC;QAE3C,MAAM,cAAc,GAAG,cAAc,CAAC,MAAM,CAAC,MAAM,CAAC,EAAE;YACpD,MAAM,UAAU,GAAG,MAAM,CAAC,qBAAqB,EAAE,CAAC;YAClD,OAAO,CAAC,CAAC,UAAU,CAAC,KAAK,GAAG,QAAQ,CAAC,KAAK,IAAI,UAAU,CAAC,MAAM,GAAG,QAAQ,CAAC,MAAM,CAAC,CAAC;QACrF,CAAC,CAAC,CAAA;QAEF,MAAM,kBAAkB,GAAG,cAAc,CAAC,SAAS,CAAC,CAAC,EAAE,cAAc,CAAC,MAAM,CAAC,CAAC;QAE9E,IAAI,kBAAkB,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YAClC,MAAM,iBAAiB,GAAG,cAAc,CAAC,cAAc,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC;YACpE,MAAM,qBAAqB,GAAG,CAAC,QAAQ,CAAC,KAAK,GAAG,iBAAiB,CAAC,qBAAqB,EAAE,CAAC,KAAK,CAAC,GAAG,CAAC,eAAe,CAAC,WAAW,CAAC,CAAC;YAEjI,IAAI,CAAC,qBAAqB,EAAE,CAAC;gBAC3B,kBAAkB,CAAC,IAAI,CAAC,iBAAiB,CAAC,CAAA;YAC5C,CAAC;YAED,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,kBAAkB,CAAC,CAAC;YAC3C,kBAAkB,CAAC,OAAO,CAAC,UAAU,CAAC,EAAE;gBACtC,UAAU,CAAC,SAAS,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;YACrC,CAAC,CAAC,CAAA;QACJ,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,QAAQ,EAAE,CAAC,aAAa,CAAC,SAAS,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;QACxD,CAAC;QAED,IAAI,CAAC,cAAc,CAAC,aAAa,EAAE,CAAC;IACtC,CAAC;+GAvEU,qBAAqB;mGAArB,qBAAqB,uQAGa,iBAAiB,oEACK,iBAAiB,QAAU,UAAU,mKC7B1G,8KAIA,0ZDeI,cAAc,8BACd,eAAe;;4FAKN,qBAAqB;kBAVjC,SAAS;+BACE,gBAAgB,cACd,IAAI,WACP;wBACP,cAAc;wBACd,eAAe;qBAChB","sourcesContent":["import { ChangeDetectorRef, Component, contentChildren, effect, ElementRef, inject, input, OnInit, signal, viewChild } from '@angular/core';\nimport { BehaviorSubject, debounce, distinctUntilChanged, timer } from 'rxjs';\n\nimport { FwAvatarComponent } from '../avatar/avatar.component';\nimport { FwAvatarModule } from '../avatar/avatar.module';\nimport { FwTooltipModule } from '../tooltip/tooltip.module';\n\n// the nature of this component is to handle a complex layout issue so disabling this lint rule\n/* eslint-disable @rx-angular/prefer-no-layout-sensitive-apis */\n\n\n/**\n * Component for displaying and managing the overflow of a list of `fw-avatar`s\n * @see [Vision Docs](https://cdn.flywheel.io/docs/vision/master/?path=/docs/components-avatar-list--docs)\n */\n@Component({\n  selector: 'fw-avatar-list',\n  standalone: true,\n  imports: [\n    FwAvatarModule,\n    FwTooltipModule,\n  ],\n  templateUrl: './avatar-list.component.html',\n  styleUrl: './avatar-list.component.scss',\n})\nexport class FwAvatarListComponent implements OnInit {\n\n  hostElement = inject(ElementRef);\n  avatars = contentChildren<FwAvatarComponent>(FwAvatarComponent);\n  avatarElementRefs = contentChildren<FwAvatarComponent, ElementRef>(FwAvatarComponent, { read: ElementRef });\n  moreText = viewChild.required<ElementRef<HTMLParagraphElement>>('moreText');\n  changeDetector = inject(ChangeDetectorRef);\n  resizeDebounceMs = input(100);\n\n  ngOnInit(): void {\n    // wire up resize observer to rxjs and debouce\n    const resize$ = new BehaviorSubject<ResizeObserverEntry[]>(null);\n    const recalcOnResize$ = resize$.pipe(\n      distinctUntilChanged(),\n      debounce(() => timer(this.resizeDebounceMs())), // debounce otherwise it can run EVERY frame\n    );\n\n    const resizeObserver = new ResizeObserver((resizeEntries) => {\n      resize$.next(resizeEntries);\n    })\n    resizeObserver.observe(this.hostElement.nativeElement, { });\n    recalcOnResize$.subscribe(() => this.calcOverflow());\n  }\n\n  applyBorderToChildAvatars = effect(() => {\n    this.avatars().forEach(avatar => {\n      avatar.bordered = true\n    });\n  })\n\n  childrenChanged = effect(() => {\n    this.avatarElementRefs();\n    this.calcOverflow();\n  }, { allowSignalWrites: true })\n\n\n  hiddenAvatars = signal([]);\n\n  calcOverflow(): void {\n\n    const hostRect = (this.hostElement.nativeElement as HTMLElement).getBoundingClientRect();\n    const avatarElements = this.avatarElementRefs().map(ref => ref.nativeElement as HTMLElement);\n    const moreTextElement = this.moreText().nativeElement;\n\n    avatarElements.forEach(avatar => avatar.classList.remove('hidden'));\n    moreTextElement.classList.remove('hidden');\n\n    const visibleAvatars = avatarElements.filter(avatar => {\n      const avatarRect = avatar.getBoundingClientRect();\n      return !(avatarRect.right > hostRect.right || avatarRect.bottom > hostRect.bottom);\n    })\n\n    const overflowingAvatars = avatarElements.toSpliced(0, visibleAvatars.length);\n\n    if (overflowingAvatars.length > 0) {\n      const lastVisibleAvatar = visibleAvatars[visibleAvatars.length - 1];\n      const enoughRoomForMoreText = (hostRect.right - lastVisibleAvatar.getBoundingClientRect().right) > (moreTextElement.offsetWidth);\n\n      if (!enoughRoomForMoreText) {\n        overflowingAvatars.push(lastVisibleAvatar)\n      }\n\n      this.hiddenAvatars.set(overflowingAvatars);\n      overflowingAvatars.forEach(hiddenChip => {\n        hiddenChip.classList.add('hidden');\n      })\n    } else {\n      this.moreText().nativeElement.classList.add('hidden');\n    }\n\n    this.changeDetector.detectChanges();\n  }\n\n}\n","<ng-content select=\"fw-avatar\"></ng-content>\n<fw-tooltip> <!--TODO: figure out how to get a tooltip-->\n  <p #moreText> +{{hiddenAvatars().length}} </p>\n</fw-tooltip>\n"]}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { ChangeDetectorRef, Component, computed, contentChildren, effect, ElementRef, inject, signal, viewChild
|
|
1
|
+
import { ChangeDetectorRef, Component, computed, contentChildren, effect, ElementRef, inject, signal, viewChild } from '@angular/core';
|
|
2
2
|
import { FwChipComponent } from '../chip/chip.component';
|
|
3
3
|
import { FwChipModule } from '../chip/chip.module';
|
|
4
4
|
import { FwTooltipModule } from '../tooltip/tooltip.module';
|
|
@@ -57,7 +57,6 @@ export class FwChipListComponent {
|
|
|
57
57
|
else {
|
|
58
58
|
this.moreText().nativeElement.classList.add('hidden');
|
|
59
59
|
}
|
|
60
|
-
// eslint-disable-next-line @rx-angular/no-explicit-change-detection-apis
|
|
61
60
|
this.changeDetector.detectChanges();
|
|
62
61
|
}
|
|
63
62
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: FwChipListComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
@@ -70,4 +69,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
70
69
|
FwTooltipModule,
|
|
71
70
|
], template: "<ng-content></ng-content>\n<fw-tooltip [title]=\"hiddenLabels()\">\n <p #moreText> +{{hiddenChips().length}} more </p>\n</fw-tooltip>\n", styles: [":host{flex-basis:max-content;display:flex;flex-flow:row wrap;gap:8px;align-items:flex-start;justify-content:flex-start;max-height:28px;overflow:hidden}:host p{line-height:24px;cursor:default;margin:0 8px 0 0;text-wrap:nowrap;color:var(--typography-muted)}:host::ng-deep .hidden{display:none}\n"] }]
|
|
72
71
|
}] });
|
|
73
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
72
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"chip-list.component.js","sourceRoot":"","sources":["../../../../../src/components/chip-list/chip-list.component.ts","../../../../../src/components/chip-list/chip-list.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectorRef, Component, computed, contentChildren, effect, ElementRef, inject, OnInit, signal, viewChild } from '@angular/core';\n\nimport { FwChipComponent } from '../chip/chip.component';\nimport { FwChipModule } from '../chip/chip.module';\nimport { FwTooltipModule } from '../tooltip/tooltip.module';\n\n// the nature of this component is to handle a complex layout issue so disabling this lint rule\n/* eslint-disable @rx-angular/prefer-no-layout-sensitive-apis */\n\n@Component({\n  selector: 'fw-chip-list',\n  standalone: true,\n  imports: [\n    FwChipModule,\n    FwTooltipModule,\n  ],\n  templateUrl: './chip-list.component.html',\n  styleUrl: './chip-list.component.scss',\n})\nexport class FwChipListComponent implements OnInit {\n  changeDetector = inject(ChangeDetectorRef);\n  hostElement = inject(ElementRef);\n  childChipElementRefs = contentChildren<FwChipComponent, ElementRef>(FwChipComponent, { read: ElementRef });\n  moreText = viewChild.required<ElementRef<HTMLParagraphElement>>('moreText');\n\n  hiddenElementCount = signal(0);\n  hiddenChips = signal<HTMLElement[]>([]);\n  hiddenLabels = computed(() => {\n    return this.hiddenChips().map(chip => {\n      // this relies on the dom shape of the chip, might be fragile\n      const contentSpan = chip.querySelector('span');\n      return contentSpan.innerText;\n    }).join(', ');\n  })\n\n  childrenChanged = effect(() => {\n    this.childChipElementRefs();\n    this.calcChipOverflow();\n  }, { allowSignalWrites: true })\n\n  resizeObserver = new ResizeObserver(() => {\n    this.calcChipOverflow();\n  })\n\n  ngOnInit(): void {\n    this.resizeObserver.observe(this.hostElement.nativeElement);\n  }\n\n  calcChipOverflow(): void {\n\n    const hostRect = (this.hostElement.nativeElement as HTMLElement).getBoundingClientRect();\n    const chipElements = this.childChipElementRefs().map(ref => ref.nativeElement as HTMLElement);\n    const moreTextElement = this.moreText().nativeElement;\n\n    chipElements.forEach(chip => chip.classList.remove('hidden'));\n    moreTextElement.classList.remove('hidden');\n\n    const visibleChips = chipElements.filter(chip => {\n      const chipRect = chip.getBoundingClientRect();\n      return !(chipRect.right > hostRect.right || chipRect.bottom > hostRect.bottom);\n    })\n\n    const overflowChips = chipElements.toSpliced(0, visibleChips.length);\n\n    if (overflowChips.length > 0) {\n      const lastVisibleChip = visibleChips[visibleChips.length - 1];\n      const enoughRoomForMoreText = (hostRect.right - lastVisibleChip.getBoundingClientRect().right) > (moreTextElement.offsetWidth);\n\n      if (!enoughRoomForMoreText) {\n        overflowChips.push(lastVisibleChip)\n      }\n\n      this.hiddenChips.set(overflowChips);\n      overflowChips.forEach(hiddenChip => {\n        hiddenChip.classList.add('hidden');\n      })\n    } else {\n      this.moreText().nativeElement.classList.add('hidden');\n    }\n\n    this.changeDetector.detectChanges();\n  }\n}\n","<ng-content></ng-content>\n<fw-tooltip [title]=\"hiddenLabels()\">\n  <p #moreText> +{{hiddenChips().length}} more </p>\n</fw-tooltip>\n"]}
|
|
@@ -1,18 +1,16 @@
|
|
|
1
1
|
import { Component, HostBinding, Input, ViewEncapsulation } from '@angular/core';
|
|
2
2
|
import * as i0 from "@angular/core";
|
|
3
3
|
import * as i1 from "@angular/common";
|
|
4
|
-
import * as i2 from "../tag/tag.component";
|
|
5
4
|
export class FwFormHeadingComponent {
|
|
6
5
|
constructor() {
|
|
7
6
|
this.class = 'fw-form-heading';
|
|
8
|
-
this.statusColor = 'slate';
|
|
9
7
|
}
|
|
10
8
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: FwFormHeadingComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
11
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: FwFormHeadingComponent, selector: "fw-form-heading", inputs: { title: "title", description: "description",
|
|
9
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: FwFormHeadingComponent, selector: "fw-form-heading", inputs: { title: "title", description: "description", status: "status" }, host: { properties: { "attr.class": "this.class" } }, ngImport: i0, template: "<div class=\"heading-area\">\n <div>\n <h4 class=\"vision-h4 section-heading\">{{ title }}\n <span *ngIf=\"status\" class=\"status\">{{ status.toUpperCase() }}</span>\n <ng-content select=\"fw-tooltip\"></ng-content>\n <ng-content select=\"fw-icon\"></ng-content>\n <ng-content select=\"fw-chip\"></ng-content>\n </h4>\n <p class=\"vision-p3\" *ngIf=\"description\">{{ description }}</p>\n <ng-content select=\"p\"></ng-content>\n </div>\n</div>\n<div class=\"right-content\">\n <ng-content></ng-content>\n</div>\n", styles: [".fw-form-heading{width:100%;display:flex;justify-content:space-between;align-items:center;gap:8px}.fw-form-heading .heading-area{display:flex;align-items:center;padding-left:4px;margin-bottom:8px}.fw-form-heading .heading-area h4{color:var(--typography-base);margin:0;display:flex;align-items:center;gap:5px}.fw-form-heading .heading-area h4 .status{color:var(--primary-base)}.fw-form-heading .heading-area p{color:var(--typography-muted);margin:0;line-height:140%;display:flex;align-items:center;gap:3px}.fw-form-heading .heading-area p a{color:var(--typography-muted)}.fw-form-heading .heading-area fw-icon.heading-icon{box-sizing:border-box;color:var(--primary-base);width:44px;height:44px;font-size:32px;text-align:center;justify-content:center;padding:6px}.fw-form-heading .right-content{display:flex;gap:8px}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], encapsulation: i0.ViewEncapsulation.None }); }
|
|
12
10
|
}
|
|
13
11
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: FwFormHeadingComponent, decorators: [{
|
|
14
12
|
type: Component,
|
|
15
|
-
args: [{ selector: 'fw-form-heading', encapsulation: ViewEncapsulation.None, template: "<div class=\"heading-area\">\n <div>\n <
|
|
13
|
+
args: [{ selector: 'fw-form-heading', encapsulation: ViewEncapsulation.None, template: "<div class=\"heading-area\">\n <div>\n <h4 class=\"vision-h4 section-heading\">{{ title }}\n <span *ngIf=\"status\" class=\"status\">{{ status.toUpperCase() }}</span>\n <ng-content select=\"fw-tooltip\"></ng-content>\n <ng-content select=\"fw-icon\"></ng-content>\n <ng-content select=\"fw-chip\"></ng-content>\n </h4>\n <p class=\"vision-p3\" *ngIf=\"description\">{{ description }}</p>\n <ng-content select=\"p\"></ng-content>\n </div>\n</div>\n<div class=\"right-content\">\n <ng-content></ng-content>\n</div>\n", styles: [".fw-form-heading{width:100%;display:flex;justify-content:space-between;align-items:center;gap:8px}.fw-form-heading .heading-area{display:flex;align-items:center;padding-left:4px;margin-bottom:8px}.fw-form-heading .heading-area h4{color:var(--typography-base);margin:0;display:flex;align-items:center;gap:5px}.fw-form-heading .heading-area h4 .status{color:var(--primary-base)}.fw-form-heading .heading-area p{color:var(--typography-muted);margin:0;line-height:140%;display:flex;align-items:center;gap:3px}.fw-form-heading .heading-area p a{color:var(--typography-muted)}.fw-form-heading .heading-area fw-icon.heading-icon{box-sizing:border-box;color:var(--primary-base);width:44px;height:44px;font-size:32px;text-align:center;justify-content:center;padding:6px}.fw-form-heading .right-content{display:flex;gap:8px}\n"] }]
|
|
16
14
|
}], ctorParameters: () => [], propDecorators: { class: [{
|
|
17
15
|
type: HostBinding,
|
|
18
16
|
args: ['attr.class']
|
|
@@ -20,11 +18,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
20
18
|
type: Input
|
|
21
19
|
}], description: [{
|
|
22
20
|
type: Input
|
|
23
|
-
}], required: [{
|
|
24
|
-
type: Input
|
|
25
21
|
}], status: [{
|
|
26
22
|
type: Input
|
|
27
|
-
}], statusColor: [{
|
|
28
|
-
type: Input
|
|
29
23
|
}] } });
|
|
30
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
24
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZm9ybS1oZWFkaW5nLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3NyYy9jb21wb25lbnRzL2Zvcm0taGVhZGluZy9mb3JtLWhlYWRpbmcuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vc3JjL2NvbXBvbmVudHMvZm9ybS1oZWFkaW5nL2Zvcm0taGVhZGluZy5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLFdBQVcsRUFBRSxLQUFLLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxlQUFlLENBQUM7OztBQVFqRixNQUFNLE9BQU8sc0JBQXNCO0lBTWpDO1FBTDJCLFVBQUssR0FBRyxpQkFBaUIsQ0FBQztJQU1yRCxDQUFDOytHQVBVLHNCQUFzQjttR0FBdEIsc0JBQXNCLHVMQ1JuQyx1aUJBZUE7OzRGRFBhLHNCQUFzQjtrQkFObEMsU0FBUzsrQkFDRSxpQkFBaUIsaUJBR1osaUJBQWlCLENBQUMsSUFBSTt3REFHVixLQUFLO3NCQUEvQixXQUFXO3VCQUFDLFlBQVk7Z0JBQ2hCLEtBQUs7c0JBQWIsS0FBSztnQkFDRyxXQUFXO3NCQUFuQixLQUFLO2dCQUNHLE1BQU07c0JBQWQsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgSG9zdEJpbmRpbmcsIElucHV0LCBWaWV3RW5jYXBzdWxhdGlvbiB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdmdy1mb3JtLWhlYWRpbmcnLFxuICB0ZW1wbGF0ZVVybDogJy4vZm9ybS1oZWFkaW5nLmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmxzOiBbJy4vZm9ybS1oZWFkaW5nLmNvbXBvbmVudC5zY3NzJ10sXG4gIGVuY2Fwc3VsYXRpb246IFZpZXdFbmNhcHN1bGF0aW9uLk5vbmUsXG59KVxuZXhwb3J0IGNsYXNzIEZ3Rm9ybUhlYWRpbmdDb21wb25lbnQge1xuICBASG9zdEJpbmRpbmcoJ2F0dHIuY2xhc3MnKSBjbGFzcyA9ICdmdy1mb3JtLWhlYWRpbmcnO1xuICBASW5wdXQoKSB0aXRsZTogc3RyaW5nO1xuICBASW5wdXQoKSBkZXNjcmlwdGlvbj86IHN0cmluZztcbiAgQElucHV0KCkgc3RhdHVzPzogc3RyaW5nO1xuXG4gIGNvbnN0cnVjdG9yKCkge1xuICB9XG59XG4iLCI8ZGl2IGNsYXNzPVwiaGVhZGluZy1hcmVhXCI+XG4gIDxkaXY+XG4gICAgPGg0IGNsYXNzPVwidmlzaW9uLWg0IHNlY3Rpb24taGVhZGluZ1wiPnt7IHRpdGxlIH19XG4gICAgICA8c3BhbiAqbmdJZj1cInN0YXR1c1wiIGNsYXNzPVwic3RhdHVzXCI+e3sgc3RhdHVzLnRvVXBwZXJDYXNlKCkgfX08L3NwYW4+XG4gICAgICA8bmctY29udGVudCBzZWxlY3Q9XCJmdy10b29sdGlwXCI+PC9uZy1jb250ZW50PlxuICAgICAgPG5nLWNvbnRlbnQgc2VsZWN0PVwiZnctaWNvblwiPjwvbmctY29udGVudD5cbiAgICAgIDxuZy1jb250ZW50IHNlbGVjdD1cImZ3LWNoaXBcIj48L25nLWNvbnRlbnQ+XG4gICAgPC9oND5cbiAgICA8cCBjbGFzcz1cInZpc2lvbi1wM1wiICpuZ0lmPVwiZGVzY3JpcHRpb25cIj57eyBkZXNjcmlwdGlvbiB9fTwvcD5cbiAgICA8bmctY29udGVudCBzZWxlY3Q9XCJwXCI+PC9uZy1jb250ZW50PlxuICA8L2Rpdj5cbjwvZGl2PlxuPGRpdiBjbGFzcz1cInJpZ2h0LWNvbnRlbnRcIj5cbiAgPG5nLWNvbnRlbnQ+PC9uZy1jb250ZW50PlxuPC9kaXY+XG4iXX0=
|
|
@@ -2,19 +2,16 @@ import { CommonModule } from '@angular/common';
|
|
|
2
2
|
import { NgModule } from '@angular/core';
|
|
3
3
|
import { FwButtonModule } from '../button/button.module';
|
|
4
4
|
import { FwIconModule } from '../icon/icon.module';
|
|
5
|
-
import { FwTagModule } from '../tag/tag.module';
|
|
6
5
|
import { FwFormHeadingComponent } from './form-heading.component';
|
|
7
6
|
import * as i0 from "@angular/core";
|
|
8
7
|
export class FwFormHeadingModule {
|
|
9
8
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: FwFormHeadingModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
|
|
10
9
|
static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "17.3.12", ngImport: i0, type: FwFormHeadingModule, declarations: [FwFormHeadingComponent], imports: [CommonModule,
|
|
11
10
|
FwButtonModule,
|
|
12
|
-
FwIconModule,
|
|
13
|
-
FwTagModule], exports: [FwFormHeadingComponent] }); }
|
|
11
|
+
FwIconModule], exports: [FwFormHeadingComponent] }); }
|
|
14
12
|
static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: FwFormHeadingModule, imports: [CommonModule,
|
|
15
13
|
FwButtonModule,
|
|
16
|
-
FwIconModule
|
|
17
|
-
FwTagModule] }); }
|
|
14
|
+
FwIconModule] }); }
|
|
18
15
|
}
|
|
19
16
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: FwFormHeadingModule, decorators: [{
|
|
20
17
|
type: NgModule,
|
|
@@ -23,7 +20,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
23
20
|
CommonModule,
|
|
24
21
|
FwButtonModule,
|
|
25
22
|
FwIconModule,
|
|
26
|
-
FwTagModule,
|
|
27
23
|
],
|
|
28
24
|
exports: [
|
|
29
25
|
FwFormHeadingComponent,
|
|
@@ -33,4 +29,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
33
29
|
],
|
|
34
30
|
}]
|
|
35
31
|
}] });
|
|
36
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
32
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZm9ybS1oZWFkaW5nLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3NyYy9jb21wb25lbnRzL2Zvcm0taGVhZGluZy9mb3JtLWhlYWRpbmcubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRXpDLE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQztBQUN6RCxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0scUJBQXFCLENBQUM7QUFDbkQsT0FBTyxFQUFFLHNCQUFzQixFQUFFLE1BQU0sMEJBQTBCLENBQUM7O0FBZWxFLE1BQU0sT0FBTyxtQkFBbUI7K0dBQW5CLG1CQUFtQjtnSEFBbkIsbUJBQW1CLGlCQUg1QixzQkFBc0IsYUFSdEIsWUFBWTtZQUNaLGNBQWM7WUFDZCxZQUFZLGFBR1osc0JBQXNCO2dIQU1iLG1CQUFtQixZQVg1QixZQUFZO1lBQ1osY0FBYztZQUNkLFlBQVk7OzRGQVNILG1CQUFtQjtrQkFiL0IsUUFBUTttQkFBQztvQkFDUixPQUFPLEVBQUU7d0JBQ1AsWUFBWTt3QkFDWixjQUFjO3dCQUNkLFlBQVk7cUJBQ2I7b0JBQ0QsT0FBTyxFQUFFO3dCQUNQLHNCQUFzQjtxQkFDdkI7b0JBQ0QsWUFBWSxFQUFFO3dCQUNaLHNCQUFzQjtxQkFDdkI7aUJBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuaW1wb3J0IHsgRndCdXR0b25Nb2R1bGUgfSBmcm9tICcuLi9idXR0b24vYnV0dG9uLm1vZHVsZSc7XG5pbXBvcnQgeyBGd0ljb25Nb2R1bGUgfSBmcm9tICcuLi9pY29uL2ljb24ubW9kdWxlJztcbmltcG9ydCB7IEZ3Rm9ybUhlYWRpbmdDb21wb25lbnQgfSBmcm9tICcuL2Zvcm0taGVhZGluZy5jb21wb25lbnQnO1xuXG5ATmdNb2R1bGUoe1xuICBpbXBvcnRzOiBbXG4gICAgQ29tbW9uTW9kdWxlLFxuICAgIEZ3QnV0dG9uTW9kdWxlLFxuICAgIEZ3SWNvbk1vZHVsZSxcbiAgXSxcbiAgZXhwb3J0czogW1xuICAgIEZ3Rm9ybUhlYWRpbmdDb21wb25lbnQsXG4gIF0sXG4gIGRlY2xhcmF0aW9uczogW1xuICAgIEZ3Rm9ybUhlYWRpbmdDb21wb25lbnQsXG4gIF0sXG59KVxuZXhwb3J0IGNsYXNzIEZ3Rm9ybUhlYWRpbmdNb2R1bGUge1xufVxuIl19
|
|
@@ -5,20 +5,14 @@ export class FwMenuCloseTriggersDirective {
|
|
|
5
5
|
constructor() {
|
|
6
6
|
this._isOpen = false;
|
|
7
7
|
}
|
|
8
|
-
outsideClick(
|
|
9
|
-
|
|
10
|
-
// Check is close under fw-menu-container (overlay)
|
|
11
|
-
const clickedInsideMenu = target.closest('fw-menu-container') !== null;
|
|
12
|
-
// Check is clicked on trigger
|
|
13
|
-
const clickedOnTrigger = target.closest('[cdkMenuTriggerFor]') !== null;
|
|
14
|
-
if (!clickedInsideMenu && !clickedOnTrigger && this._isOpen && this.triggers?.length > 0) {
|
|
15
|
-
// Close menu if click outside menu and trigger
|
|
8
|
+
outsideClick() {
|
|
9
|
+
if (this._isOpen && this.triggers && this.triggers.length > 0) {
|
|
16
10
|
this.triggers.forEach(trigger => {
|
|
17
11
|
trigger.close();
|
|
18
12
|
});
|
|
19
13
|
this._isOpen = false;
|
|
20
14
|
}
|
|
21
|
-
if (this.triggers
|
|
15
|
+
if (this.triggers && this.triggers.length > 0) {
|
|
22
16
|
this.triggers.forEach(trigger => {
|
|
23
17
|
if (trigger.isOpen()) {
|
|
24
18
|
this._isOpen = true;
|
|
@@ -27,18 +21,18 @@ export class FwMenuCloseTriggersDirective {
|
|
|
27
21
|
}
|
|
28
22
|
}
|
|
29
23
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: FwMenuCloseTriggersDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
30
|
-
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.3.12", type: FwMenuCloseTriggersDirective, selector: "[fwMenuCloseTriggers]", host: { listeners: { "document:click": "outsideClick(
|
|
24
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.3.12", type: FwMenuCloseTriggersDirective, selector: "[fwMenuCloseTriggers]", host: { listeners: { "document:click": "outsideClick()" } }, queries: [{ propertyName: "triggers", predicate: CdkMenuTrigger, descendants: true }], ngImport: i0 }); }
|
|
31
25
|
}
|
|
32
26
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: FwMenuCloseTriggersDirective, decorators: [{
|
|
33
27
|
type: Directive,
|
|
34
28
|
args: [{
|
|
35
29
|
selector: '[fwMenuCloseTriggers]',
|
|
36
30
|
}]
|
|
37
|
-
}], propDecorators: {
|
|
31
|
+
}], propDecorators: { outsideClick: [{
|
|
32
|
+
type: HostListener,
|
|
33
|
+
args: ['document:click']
|
|
34
|
+
}], triggers: [{
|
|
38
35
|
type: ContentChildren,
|
|
39
36
|
args: [CdkMenuTrigger, { descendants: true }]
|
|
40
|
-
}], outsideClick: [{
|
|
41
|
-
type: HostListener,
|
|
42
|
-
args: ['document:click', ['$event']]
|
|
43
37
|
}] } });
|
|
44
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
38
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWVudS1jbG9zZS10cmlnZ2Vycy5kaXJlY3RpdmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9zcmMvY29tcG9uZW50cy9tZW51L21lbnUtY2xvc2UtdHJpZ2dlcnMuZGlyZWN0aXZlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSxtQkFBbUIsQ0FBQztBQUNuRCxPQUFPLEVBQUUsZUFBZSxFQUFFLFNBQVMsRUFBRSxZQUFZLEVBQWEsTUFBTSxlQUFlLENBQUM7O0FBS3BGLE1BQU0sT0FBTyw0QkFBNEI7SUFIekM7UUFzQlUsWUFBTyxHQUFHLEtBQUssQ0FBQztLQUN6QjtJQW5CaUMsWUFBWTtRQUMxQyxJQUFJLElBQUksQ0FBQyxPQUFPLElBQUksSUFBSSxDQUFDLFFBQVEsSUFBSSxJQUFJLENBQUMsUUFBUSxDQUFDLE1BQU0sR0FBRyxDQUFDLEVBQUUsQ0FBQztZQUM5RCxJQUFJLENBQUMsUUFBUSxDQUFDLE9BQU8sQ0FBQyxPQUFPLENBQUMsRUFBRTtnQkFDOUIsT0FBTyxDQUFDLEtBQUssRUFBRSxDQUFDO1lBQ2xCLENBQUMsQ0FBQyxDQUFDO1lBQ0gsSUFBSSxDQUFDLE9BQU8sR0FBRyxLQUFLLENBQUM7UUFDdkIsQ0FBQztRQUNELElBQUksSUFBSSxDQUFDLFFBQVEsSUFBSSxJQUFJLENBQUMsUUFBUSxDQUFDLE1BQU0sR0FBRyxDQUFDLEVBQUUsQ0FBQztZQUM5QyxJQUFJLENBQUMsUUFBUSxDQUFDLE9BQU8sQ0FBQyxPQUFPLENBQUMsRUFBRTtnQkFDOUIsSUFBSSxPQUFPLENBQUMsTUFBTSxFQUFFLEVBQUUsQ0FBQztvQkFDckIsSUFBSSxDQUFDLE9BQU8sR0FBRyxJQUFJLENBQUM7Z0JBQ3RCLENBQUM7WUFDSCxDQUFDLENBQUMsQ0FBQztRQUNMLENBQUM7SUFDSCxDQUFDOytHQWZVLDRCQUE0QjttR0FBNUIsNEJBQTRCLG1KQWlCdEIsY0FBYzs7NEZBakJwQiw0QkFBNEI7a0JBSHhDLFNBQVM7bUJBQUM7b0JBQ1QsUUFBUSxFQUFFLHVCQUF1QjtpQkFDbEM7OEJBRWlDLFlBQVk7c0JBQTNDLFlBQVk7dUJBQUMsZ0JBQWdCO2dCQWdCMEIsUUFBUTtzQkFBL0QsZUFBZTt1QkFBQyxjQUFjLEVBQUUsRUFBRSxXQUFXLEVBQUUsSUFBSSxFQUFFIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ2RrTWVudVRyaWdnZXIgfSBmcm9tICdAYW5ndWxhci9jZGsvbWVudSc7XG5pbXBvcnQgeyBDb250ZW50Q2hpbGRyZW4sIERpcmVjdGl2ZSwgSG9zdExpc3RlbmVyLCBRdWVyeUxpc3QgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuQERpcmVjdGl2ZSh7XG4gIHNlbGVjdG9yOiAnW2Z3TWVudUNsb3NlVHJpZ2dlcnNdJyxcbn0pXG5leHBvcnQgY2xhc3MgRndNZW51Q2xvc2VUcmlnZ2Vyc0RpcmVjdGl2ZSB7XG4gIEBIb3N0TGlzdGVuZXIoJ2RvY3VtZW50OmNsaWNrJykgb3V0c2lkZUNsaWNrKCk6IHZvaWQge1xuICAgIGlmICh0aGlzLl9pc09wZW4gJiYgdGhpcy50cmlnZ2VycyAmJiB0aGlzLnRyaWdnZXJzLmxlbmd0aCA+IDApIHtcbiAgICAgIHRoaXMudHJpZ2dlcnMuZm9yRWFjaCh0cmlnZ2VyID0+IHtcbiAgICAgICAgdHJpZ2dlci5jbG9zZSgpO1xuICAgICAgfSk7XG4gICAgICB0aGlzLl9pc09wZW4gPSBmYWxzZTtcbiAgICB9XG4gICAgaWYgKHRoaXMudHJpZ2dlcnMgJiYgdGhpcy50cmlnZ2Vycy5sZW5ndGggPiAwKSB7XG4gICAgICB0aGlzLnRyaWdnZXJzLmZvckVhY2godHJpZ2dlciA9PiB7XG4gICAgICAgIGlmICh0cmlnZ2VyLmlzT3BlbigpKSB7XG4gICAgICAgICAgdGhpcy5faXNPcGVuID0gdHJ1ZTtcbiAgICAgICAgfVxuICAgICAgfSk7XG4gICAgfVxuICB9XG5cbiAgQENvbnRlbnRDaGlsZHJlbihDZGtNZW51VHJpZ2dlciwgeyBkZXNjZW5kYW50czogdHJ1ZSB9KSB0cmlnZ2Vycz86IFF1ZXJ5TGlzdDxDZGtNZW51VHJpZ2dlcj47XG5cbiAgcHJpdmF0ZSBfaXNPcGVuID0gZmFsc2U7XG59XG4iXX0=
|