@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
|
@@ -80,8 +80,16 @@ export class FwMenuItemComponent {
|
|
|
80
80
|
evt.stopPropagation();
|
|
81
81
|
}
|
|
82
82
|
}
|
|
83
|
+
/**
|
|
84
|
+
* stops the browser built-in tooltip from showing up
|
|
85
|
+
* @see https://developer.mozilla.org/en-US/docs/Web/HTML/Reference/Global_attributes/title
|
|
86
|
+
*/
|
|
87
|
+
get attrTitle() {
|
|
88
|
+
return '';
|
|
89
|
+
}
|
|
90
|
+
;
|
|
83
91
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: FwMenuItemComponent, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
84
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "17.3.12", type: FwMenuItemComponent, selector: "fw-menu-item", inputs: { value: { classPropertyName: "value", publicName: "value", isSignal: false, isRequired: false, transformFunction: null }, size: { classPropertyName: "size", publicName: "size", isSignal: false, isRequired: false, transformFunction: null }, title: { classPropertyName: "title", publicName: "title", isSignal: false, isRequired: false, transformFunction: null }, description: { classPropertyName: "description", publicName: "description", isSignal: false, isRequired: false, transformFunction: null }, icon: { classPropertyName: "icon", publicName: "icon", isSignal: false, isRequired: false, transformFunction: null }, iconColor: { classPropertyName: "iconColor", publicName: "iconColor", isSignal: false, isRequired: false, transformFunction: null }, disabled: { classPropertyName: "disabled", publicName: "disabled", isSignal: false, isRequired: false, transformFunction: null }, showCheckbox: { classPropertyName: "showCheckbox", publicName: "showCheckbox", isSignal: false, isRequired: false, transformFunction: null }, checkboxColor: { classPropertyName: "checkboxColor", publicName: "checkboxColor", isSignal: false, isRequired: false, transformFunction: null }, multiSelect: { classPropertyName: "multiSelect", publicName: "multiSelect", isSignal: false, isRequired: false, transformFunction: null }, hidden: { classPropertyName: "hidden", publicName: "hidden", isSignal: false, isRequired: false, transformFunction: null }, collapsed: { classPropertyName: "collapsed", publicName: "collapsed", isSignal: false, isRequired: false, transformFunction: null }, href: { classPropertyName: "href", publicName: "href", isSignal: false, isRequired: false, transformFunction: null }, target: { classPropertyName: "target", publicName: "target", isSignal: false, isRequired: false, transformFunction: null }, subItemsOpen: { classPropertyName: "subItemsOpen", publicName: "subItemsOpen", isSignal: false, isRequired: false, transformFunction: null }, mouseEnterHandler: { classPropertyName: "mouseEnterHandler", publicName: "mouseEnterHandler", isSignal: true, isRequired: false, transformFunction: null }, focused: { classPropertyName: "focused", publicName: "focused", isSignal: false, isRequired: false, transformFunction: null }, selected: { classPropertyName: "selected", publicName: "selected", isSignal: false, isRequired: false, transformFunction: null } }, outputs: { mouseEnterHandler: "mouseEnterHandlerChange", click: "click" }, host: { listeners: { "mouseenter": "onMouseEnter($event)" }, properties: { "class.collapsed": "this.collapsed", "class.focused": "this.focused", "class.selected": "this.selected" } }, queries: [{ propertyName: "subItems", predicate: FwMenuSubItemComponent }], usesOnChanges: true, ngImport: i0, template: "<div (click)=\"handleClick($event)\" *ngIf=\"!hidden\">\n <div\n [ngClass]=\"['menu-item', 'size-'+size, disabled?'disabled':'']\"\n [class.disabled]=\"disabled\">\n <div class=\"item-checkbox\" *ngIf=\"showCheckbox && multiSelect\">\n <fw-checkbox\n [disabled]=\"disabled\"\n [color]=\"checkboxColor\"\n [checked]=\"selected\">\n </fw-checkbox>\n </div>\n <div class=\"item-radiobutton\" *ngIf=\"showCheckbox && !multiSelect\">\n <fw-radio-button\n [value]=\"value\"\n [color]=\"checkboxColor\"\n [disabled]=\"disabled\"\n [checked]=\"selected\">\n </fw-radio-button>\n </div>\n <fw-icon [color]=\"iconColor\" *ngIf=\"icon\" class=\"menu-icon {{iconColor}}\">{{ icon }}</fw-icon>\n <ng-content select=\"fw-avatar\"></ng-content>\n <div class=\"menu-text\" *ngIf=\"title\">\n <h4 class=\"vision-h4\">{{ title }}</h4>\n <p *ngIf=\"description\" class=\"vision-p4 description\">{{ description }}</p>\n </div>\n <div class=\"key-text vision-p2\">\n <ng-content select=\"p\"></ng-content>\n <ng-content select=\"fw-badge\"></ng-content>\n <ng-content select=\"fw-icon\"></ng-content>\n <ng-content select=\"fw-icon-button\"></ng-content>\n <fw-icon-button\n [size]=\"'small'\"\n [icon]=\"subItemsOpen?'chevron-up':'chevron-down'\"\n *ngIf=\"subItems.length>0\"\n (click)=\"toggleSubItemsView()\">\n </fw-icon-button>\n </div>\n </div>\n</div>\n<div class=\"item-subitems\">\n <ng-content select=\"fw-menu-sub-item\"></ng-content>\n</div>\n", styles: [":host{position:relative;display:flex;flex-direction:column}:host>div{display:flex;flex:1;text-decoration:none;max-width:100%}:host h4{text-overflow:ellipsis}:host:hover:not(.selected) .menu-item:not(.disabled),:host.focused .menu-item:not(.disabled){background-color:var(--slate-hover);cursor:pointer}:host:hover:not(.selected) .menu-item:not(.disabled) .menu-icon,:host.focused .menu-item:not(.disabled) .menu-icon{color:var(--primary-base)}:host:hover:not(.selected) .menu-item:not(.disabled) .menu-text h4,:host.focused .menu-item:not(.disabled) .menu-text h4{color:var(--typography-base)}:host.selected .menu-item{background-color:var(--primary-hover);cursor:pointer}:host.selected .menu-item .menu-icon{color:var(--primary-base)}:host.selected .menu-item .menu-text h4{color:var(--typography-base)}:host.collapsed .menu-item{container-name:menuitem;container-type:size}:host .menu-item{box-sizing:border-box;display:flex;flex-direction:row;align-items:center;flex:1;gap:8px;padding:8px;margin:1px 4px;border-radius:4px;color:var(--typography-muted);min-height:40px;width:stretch}:host .menu-item .item-checkbox:empty{display:none}:host .menu-item .item-radiobutton{padding:0}:host .menu-item .item-radiobutton:empty{display:none}:host .menu-item .menu-icon{font-size:18px;min-width:18px;width:18px;white-space:nowrap}:host .menu-item .menu-text{flex:1;overflow:hidden;padding:2px 0}:host .menu-item .menu-text h4{margin:0;color:var(--typography-muted);white-space:nowrap;overflow:hidden}:host .menu-item .menu-text p{margin:0}:host .menu-item .menu-text p.description{color:var(--typography-light)}:host .menu-item .key-text{display:flex;align-items:center;gap:8px;color:var(--typography-light)}:host .menu-item .key-text fw-icon-button{min-height:22px!important;min-width:22px!important;width:22px!important}:host .menu-item.size-compact{min-height:32px}:host .menu-item.size-compact .menu-text .description{display:none}:host .menu-item.disabled{opacity:.4;cursor:not-allowed}:host .item-subitems{display:flex;flex-direction:column}@container menuitem (max-width: 60px){.menu-item{gap:0}.menu-item .menu-text{opacity:0}}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.FwIconButtonComponent, selector: "fw-icon-button", inputs: ["color", "icon", "size", "disabled", "selected"] }, { kind: "component", type: i3.FwIconComponent, selector: "fw-icon", inputs: ["size", "color"] }, { kind: "component", type: i4.FwCheckboxComponent, selector: "fw-checkbox", inputs: ["name", "disabled", "size", "color", "title", "focused", "checked"], outputs: ["change"] }, { kind: "component", type: i5.FwRadioComponent, selector: "fw-radio-button", inputs: ["checked", "value", "group", "disabled", "size", "color", "title", "focused"], outputs: ["change"] }] }); }
|
|
92
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "17.3.12", type: FwMenuItemComponent, selector: "fw-menu-item", inputs: { value: { classPropertyName: "value", publicName: "value", isSignal: false, isRequired: false, transformFunction: null }, size: { classPropertyName: "size", publicName: "size", isSignal: false, isRequired: false, transformFunction: null }, title: { classPropertyName: "title", publicName: "title", isSignal: false, isRequired: false, transformFunction: null }, description: { classPropertyName: "description", publicName: "description", isSignal: false, isRequired: false, transformFunction: null }, icon: { classPropertyName: "icon", publicName: "icon", isSignal: false, isRequired: false, transformFunction: null }, iconColor: { classPropertyName: "iconColor", publicName: "iconColor", isSignal: false, isRequired: false, transformFunction: null }, disabled: { classPropertyName: "disabled", publicName: "disabled", isSignal: false, isRequired: false, transformFunction: null }, showCheckbox: { classPropertyName: "showCheckbox", publicName: "showCheckbox", isSignal: false, isRequired: false, transformFunction: null }, checkboxColor: { classPropertyName: "checkboxColor", publicName: "checkboxColor", isSignal: false, isRequired: false, transformFunction: null }, multiSelect: { classPropertyName: "multiSelect", publicName: "multiSelect", isSignal: false, isRequired: false, transformFunction: null }, hidden: { classPropertyName: "hidden", publicName: "hidden", isSignal: false, isRequired: false, transformFunction: null }, collapsed: { classPropertyName: "collapsed", publicName: "collapsed", isSignal: false, isRequired: false, transformFunction: null }, href: { classPropertyName: "href", publicName: "href", isSignal: false, isRequired: false, transformFunction: null }, target: { classPropertyName: "target", publicName: "target", isSignal: false, isRequired: false, transformFunction: null }, subItemsOpen: { classPropertyName: "subItemsOpen", publicName: "subItemsOpen", isSignal: false, isRequired: false, transformFunction: null }, mouseEnterHandler: { classPropertyName: "mouseEnterHandler", publicName: "mouseEnterHandler", isSignal: true, isRequired: false, transformFunction: null }, focused: { classPropertyName: "focused", publicName: "focused", isSignal: false, isRequired: false, transformFunction: null }, selected: { classPropertyName: "selected", publicName: "selected", isSignal: false, isRequired: false, transformFunction: null } }, outputs: { mouseEnterHandler: "mouseEnterHandlerChange", click: "click" }, host: { listeners: { "mouseenter": "onMouseEnter($event)" }, properties: { "class.collapsed": "this.collapsed", "class.focused": "this.focused", "class.selected": "this.selected", "attr.title": "this.attrTitle" } }, queries: [{ propertyName: "subItems", predicate: FwMenuSubItemComponent }], usesOnChanges: true, ngImport: i0, template: "<div (click)=\"handleClick($event)\" *ngIf=\"!hidden\">\n <div\n [ngClass]=\"['menu-item', 'size-'+size, disabled?'disabled':'']\"\n [class.disabled]=\"disabled\">\n <div class=\"item-checkbox\" *ngIf=\"showCheckbox && multiSelect\">\n <fw-checkbox\n [disabled]=\"disabled\"\n [color]=\"checkboxColor\"\n [checked]=\"selected\">\n </fw-checkbox>\n </div>\n <div class=\"item-radiobutton\" *ngIf=\"showCheckbox && !multiSelect\">\n <fw-radio-button\n [value]=\"value\"\n [color]=\"checkboxColor\"\n [disabled]=\"disabled\"\n [checked]=\"selected\">\n </fw-radio-button>\n </div>\n <fw-icon [color]=\"iconColor\" *ngIf=\"icon\" class=\"menu-icon {{iconColor}}\">{{ icon }}</fw-icon>\n <ng-content select=\"fw-avatar\"></ng-content>\n <div class=\"menu-text\" *ngIf=\"title\">\n <h4 class=\"vision-h4\">{{ title }}</h4>\n <p *ngIf=\"description\" class=\"vision-p4 description\">{{ description }}</p>\n </div>\n <div class=\"key-text vision-p2\">\n <ng-content select=\"p\"></ng-content>\n <ng-content select=\"fw-badge\"></ng-content>\n <ng-content select=\"fw-icon\"></ng-content>\n <ng-content select=\"fw-icon-button\"></ng-content>\n <fw-icon-button\n [size]=\"'small'\"\n [icon]=\"subItemsOpen?'chevron-up':'chevron-down'\"\n *ngIf=\"subItems.length>0\"\n (click)=\"toggleSubItemsView()\">\n </fw-icon-button>\n </div>\n </div>\n</div>\n<div class=\"item-subitems\">\n <ng-content select=\"fw-menu-sub-item\"></ng-content>\n</div>\n", styles: [":host{position:relative;display:flex;flex-direction:column}:host>div{display:flex;flex:1;text-decoration:none;max-width:100%}:host h4{text-overflow:ellipsis}:host:hover:not(.selected) .menu-item:not(.disabled),:host.focused .menu-item:not(.disabled){background-color:var(--slate-hover);cursor:pointer}:host:hover:not(.selected) .menu-item:not(.disabled) .menu-icon,:host.focused .menu-item:not(.disabled) .menu-icon{color:var(--primary-base)}:host:hover:not(.selected) .menu-item:not(.disabled) .menu-text h4,:host.focused .menu-item:not(.disabled) .menu-text h4{color:var(--typography-base)}:host.selected .menu-item{background-color:var(--primary-hover);cursor:pointer}:host.selected .menu-item .menu-icon{color:var(--primary-base)}:host.selected .menu-item .menu-text h4{color:var(--typography-base)}:host.collapsed .menu-item{container-name:menuitem;container-type:size}:host .menu-item{box-sizing:border-box;display:flex;flex-direction:row;align-items:center;flex:1;gap:8px;padding:8px;margin:1px 4px;border-radius:4px;color:var(--typography-muted);min-height:40px;width:stretch}:host .menu-item .item-checkbox:empty{display:none}:host .menu-item .item-radiobutton{padding:0}:host .menu-item .item-radiobutton:empty{display:none}:host .menu-item .menu-icon{font-size:18px;min-width:18px;width:18px;white-space:nowrap}:host .menu-item .menu-text{flex:1;overflow:hidden;padding:2px 0}:host .menu-item .menu-text h4{margin:0;color:var(--typography-muted);white-space:nowrap;overflow:hidden}:host .menu-item .menu-text p{margin:0}:host .menu-item .menu-text p.description{color:var(--typography-light)}:host .menu-item .key-text{display:flex;align-items:center;gap:8px;color:var(--typography-light)}:host .menu-item .key-text fw-icon-button{min-height:22px!important;min-width:22px!important;width:22px!important}:host .menu-item.size-compact{min-height:32px}:host .menu-item.size-compact .menu-text .description{display:none}:host .menu-item.disabled{opacity:.4;cursor:not-allowed}:host .item-subitems{display:flex;flex-direction:column}@container menuitem (max-width: 60px){.menu-item{gap:0}.menu-item .menu-text{opacity:0}}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.FwIconButtonComponent, selector: "fw-icon-button", inputs: ["color", "icon", "size", "disabled", "selected"] }, { kind: "component", type: i3.FwIconComponent, selector: "fw-icon", inputs: ["size", "color"] }, { kind: "component", type: i4.FwCheckboxComponent, selector: "fw-checkbox", inputs: ["name", "disabled", "size", "color", "title", "focused", "checked"], outputs: ["change"] }, { kind: "component", type: i5.FwRadioComponent, selector: "fw-radio-button", inputs: ["checked", "value", "group", "disabled", "size", "color", "title", "focused"], outputs: ["change"] }] }); }
|
|
85
93
|
}
|
|
86
94
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: FwMenuItemComponent, decorators: [{
|
|
87
95
|
type: Component,
|
|
@@ -137,5 +145,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
137
145
|
}], onMouseEnter: [{
|
|
138
146
|
type: HostListener,
|
|
139
147
|
args: ['mouseenter', ['$event']]
|
|
148
|
+
}], attrTitle: [{
|
|
149
|
+
type: HostBinding,
|
|
150
|
+
args: ['attr.title']
|
|
140
151
|
}] } });
|
|
141
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"menu-item.component.js","sourceRoot":"","sources":["../../../../../../src/components/menu/menu-item/menu-item.component.ts","../../../../../../src/components/menu/menu-item/menu-item.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterContentInit,\n  Component,\n  ContentChildren,\n  ElementRef,\n  EventEmitter,\n  HostBinding,\n  HostListener,\n  Input,\n  model,\n  OnChanges,\n  OnDestroy,\n  Output,\n  QueryList,\n  SimpleChanges,\n} from '@angular/core';\nimport { Subscription } from 'rxjs';\n\nimport { IconType } from '../../icon/icon.types';\nimport { FwMenuSubItemComponent } from '../menu-sub-item/menu-sub-item.component';\n\ntype MouseEnterHandler = ($event: PointerEvent, item: FwMenuItemComponent) => void;\n\n@Component({\n  selector: 'fw-menu-item',\n  templateUrl: './menu-item.component.html',\n  styleUrls: ['./menu-item.component.scss'],\n})\nexport class FwMenuItemComponent implements OnChanges, OnDestroy, AfterContentInit {\n  @Input() value?: string;\n  @Input() size?: 'default' | 'compact' = 'default';\n  @Input() title: string;\n  @Input() description?: string;\n  @Input() icon?: IconType;\n  @Input() iconColor?: 'primary' | 'secondary' | 'red' | 'orange' | 'green' | 'slate' | 'typography' = 'primary';\n  @Input() disabled?: boolean;\n  @Input() showCheckbox?: boolean = false;\n  @Input() checkboxColor?: 'primary' | 'secondary' = 'primary';\n  @Input() multiSelect?: boolean = false;\n  @Input() hidden?: boolean = false;\n  @HostBinding('class.collapsed') @Input() collapsed?: boolean;\n  @Input() href?: string;\n  @Input() target?: string;\n  @Input() subItemsOpen: boolean = false;\n  mouseEnterHandler = model<MouseEnterHandler>(() => {});\n  // eslint-disable-next-line @angular-eslint/no-output-native\n  @Output() click: EventEmitter<string> = new EventEmitter<string>();\n  @HostBinding('class.focused') @Input() focused?: boolean = false;\n  @HostBinding('class.selected') @Input() selected?: boolean = false;\n  @ContentChildren(FwMenuSubItemComponent) subItems: QueryList<FwMenuSubItemComponent>;\n  private subscriptions: Subscription[] = [];\n\n  constructor(private elementRef: ElementRef<HTMLElement>) {}\n\n  scrollIntoView(): void {\n    // eslint-disable-next-line @rx-angular/prefer-no-layout-sensitive-apis\n    this.elementRef.nativeElement.scrollIntoView({ behavior: 'smooth' });\n  }\n\n  // eslint-disable-next-line @typescript-eslint/no-unused-vars\n  ngOnChanges(changes: SimpleChanges): void {\n    this.updateLayout();\n  }\n\n  ngOnDestroy(): void {\n    for (const subscription of this.subscriptions) {\n      subscription.unsubscribe();\n    }\n  }\n\n  ngAfterContentInit(): void {\n    this.subItems.forEach(subItem => {\n      const sub = subItem.click.subscribe(value => this.click.emit(value));\n      this.subscriptions.push(sub);\n    });\n    this.updateLayout();\n  }\n\n  @HostListener('mouseenter', ['$event']) onMouseEnter(event: PointerEvent): void {\n    this.mouseEnterHandler()?.(event, this);\n  }\n\n  updateLayout(): void {\n    if (this.subItems) {\n      this.subItems.forEach(subItem => {\n        subItem.size = this.size;\n        subItem.hidden = !(this.subItemsOpen && !this.collapsed);\n        subItem.collapsed = this.collapsed;\n      });\n    }\n  }\n\n  toggleSubItemsView(): void {\n    this.subItemsOpen = !this.subItemsOpen;\n    this.updateLayout();\n  }\n\n  handleClick(evt?: Event): void {\n    if (this.disabled) {\n      evt.stopPropagation();\n      return;\n    }\n\n    if (this.href) {\n      if (this.target) {\n        // eslint-disable-next-line @rx-angular/prefer-no-layout-sensitive-apis\n        window.open(this.href, this.target).focus();\n      } else {\n        window.location.href = this.href;\n      }\n      evt.stopPropagation();\n      return;\n    }\n\n    if (this.value) {\n      this.click.emit(this.value);\n      evt.stopPropagation();\n    }\n  }\n}\n","<div (click)=\"handleClick($event)\" *ngIf=\"!hidden\">\n  <div\n    [ngClass]=\"['menu-item', 'size-'+size, disabled?'disabled':'']\"\n    [class.disabled]=\"disabled\">\n    <div class=\"item-checkbox\" *ngIf=\"showCheckbox && multiSelect\">\n      <fw-checkbox\n        [disabled]=\"disabled\"\n        [color]=\"checkboxColor\"\n        [checked]=\"selected\">\n      </fw-checkbox>\n    </div>\n    <div class=\"item-radiobutton\" *ngIf=\"showCheckbox && !multiSelect\">\n      <fw-radio-button\n        [value]=\"value\"\n        [color]=\"checkboxColor\"\n        [disabled]=\"disabled\"\n        [checked]=\"selected\">\n      </fw-radio-button>\n    </div>\n    <fw-icon [color]=\"iconColor\" *ngIf=\"icon\" class=\"menu-icon {{iconColor}}\">{{ icon }}</fw-icon>\n    <ng-content select=\"fw-avatar\"></ng-content>\n    <div class=\"menu-text\" *ngIf=\"title\">\n      <h4 class=\"vision-h4\">{{ title }}</h4>\n      <p *ngIf=\"description\" class=\"vision-p4 description\">{{ description }}</p>\n    </div>\n    <div class=\"key-text vision-p2\">\n      <ng-content select=\"p\"></ng-content>\n      <ng-content select=\"fw-badge\"></ng-content>\n      <ng-content select=\"fw-icon\"></ng-content>\n      <ng-content select=\"fw-icon-button\"></ng-content>\n      <fw-icon-button\n        [size]=\"'small'\"\n        [icon]=\"subItemsOpen?'chevron-up':'chevron-down'\"\n        *ngIf=\"subItems.length>0\"\n        (click)=\"toggleSubItemsView()\">\n      </fw-icon-button>\n    </div>\n  </div>\n</div>\n<div class=\"item-subitems\">\n  <ng-content select=\"fw-menu-sub-item\"></ng-content>\n</div>\n"]}
|
|
152
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"menu-item.component.js","sourceRoot":"","sources":["../../../../../../src/components/menu/menu-item/menu-item.component.ts","../../../../../../src/components/menu/menu-item/menu-item.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterContentInit,\n  Component,\n  ContentChildren,\n  ElementRef,\n  EventEmitter,\n  HostBinding,\n  HostListener,\n  Input,\n  model,\n  OnChanges,\n  OnDestroy,\n  Output,\n  QueryList,\n  SimpleChanges,\n} from '@angular/core';\nimport { Subscription } from 'rxjs';\n\nimport { IconType } from '../../icon/icon.types';\nimport { FwMenuSubItemComponent } from '../menu-sub-item/menu-sub-item.component';\n\ntype MouseEnterHandler = ($event: PointerEvent, item: FwMenuItemComponent) => void;\n\n@Component({\n  selector: 'fw-menu-item',\n  templateUrl: './menu-item.component.html',\n  styleUrls: ['./menu-item.component.scss'],\n})\nexport class FwMenuItemComponent implements OnChanges, OnDestroy, AfterContentInit {\n  @Input() value?: string;\n  @Input() size?: 'default' | 'compact' = 'default';\n  @Input() title: string;\n  @Input() description?: string;\n  @Input() icon?: IconType;\n  @Input() iconColor?: 'primary' | 'secondary' | 'red' | 'orange' | 'green' | 'slate' | 'typography' = 'primary';\n  @Input() disabled?: boolean;\n  @Input() showCheckbox?: boolean = false;\n  @Input() checkboxColor?: 'primary' | 'secondary' = 'primary';\n  @Input() multiSelect?: boolean = false;\n  @Input() hidden?: boolean = false;\n  @HostBinding('class.collapsed') @Input() collapsed?: boolean;\n  @Input() href?: string;\n  @Input() target?: string;\n  @Input() subItemsOpen: boolean = false;\n  mouseEnterHandler = model<MouseEnterHandler>(() => {});\n  // eslint-disable-next-line @angular-eslint/no-output-native\n  @Output() click: EventEmitter<string> = new EventEmitter<string>();\n  @HostBinding('class.focused') @Input() focused?: boolean = false;\n  @HostBinding('class.selected') @Input() selected?: boolean = false;\n  @ContentChildren(FwMenuSubItemComponent) subItems: QueryList<FwMenuSubItemComponent>;\n  private subscriptions: Subscription[] = [];\n\n  constructor(private elementRef: ElementRef<HTMLElement>) {}\n\n  scrollIntoView(): void {\n    // eslint-disable-next-line @rx-angular/prefer-no-layout-sensitive-apis\n    this.elementRef.nativeElement.scrollIntoView({ behavior: 'smooth' });\n  }\n\n  // eslint-disable-next-line @typescript-eslint/no-unused-vars\n  ngOnChanges(changes: SimpleChanges): void {\n    this.updateLayout();\n  }\n\n  ngOnDestroy(): void {\n    for (const subscription of this.subscriptions) {\n      subscription.unsubscribe();\n    }\n  }\n\n  ngAfterContentInit(): void {\n    this.subItems.forEach(subItem => {\n      const sub = subItem.click.subscribe(value => this.click.emit(value));\n      this.subscriptions.push(sub);\n    });\n    this.updateLayout();\n  }\n\n  @HostListener('mouseenter', ['$event']) onMouseEnter(event: PointerEvent): void {\n    this.mouseEnterHandler()?.(event, this);\n  }\n\n  updateLayout(): void {\n    if (this.subItems) {\n      this.subItems.forEach(subItem => {\n        subItem.size = this.size;\n        subItem.hidden = !(this.subItemsOpen && !this.collapsed);\n        subItem.collapsed = this.collapsed;\n      });\n    }\n  }\n\n  toggleSubItemsView(): void {\n    this.subItemsOpen = !this.subItemsOpen;\n    this.updateLayout();\n  }\n\n  handleClick(evt?: Event): void {\n    if (this.disabled) {\n      evt.stopPropagation();\n      return;\n    }\n\n    if (this.href) {\n      if (this.target) {\n        // eslint-disable-next-line @rx-angular/prefer-no-layout-sensitive-apis\n        window.open(this.href, this.target).focus();\n      } else {\n        window.location.href = this.href;\n      }\n      evt.stopPropagation();\n      return;\n    }\n\n    if (this.value) {\n      this.click.emit(this.value);\n      evt.stopPropagation();\n    }\n  }\n\n  /**\n   * stops the browser built-in tooltip from showing up\n   * @see https://developer.mozilla.org/en-US/docs/Web/HTML/Reference/Global_attributes/title\n  */\n  @HostBinding('attr.title') get attrTitle(): string {\n    return '';\n  };\n}\n","<div (click)=\"handleClick($event)\" *ngIf=\"!hidden\">\n  <div\n    [ngClass]=\"['menu-item', 'size-'+size, disabled?'disabled':'']\"\n    [class.disabled]=\"disabled\">\n    <div class=\"item-checkbox\" *ngIf=\"showCheckbox && multiSelect\">\n      <fw-checkbox\n        [disabled]=\"disabled\"\n        [color]=\"checkboxColor\"\n        [checked]=\"selected\">\n      </fw-checkbox>\n    </div>\n    <div class=\"item-radiobutton\" *ngIf=\"showCheckbox && !multiSelect\">\n      <fw-radio-button\n        [value]=\"value\"\n        [color]=\"checkboxColor\"\n        [disabled]=\"disabled\"\n        [checked]=\"selected\">\n      </fw-radio-button>\n    </div>\n    <fw-icon [color]=\"iconColor\" *ngIf=\"icon\" class=\"menu-icon {{iconColor}}\">{{ icon }}</fw-icon>\n    <ng-content select=\"fw-avatar\"></ng-content>\n    <div class=\"menu-text\" *ngIf=\"title\">\n      <h4 class=\"vision-h4\">{{ title }}</h4>\n      <p *ngIf=\"description\" class=\"vision-p4 description\">{{ description }}</p>\n    </div>\n    <div class=\"key-text vision-p2\">\n      <ng-content select=\"p\"></ng-content>\n      <ng-content select=\"fw-badge\"></ng-content>\n      <ng-content select=\"fw-icon\"></ng-content>\n      <ng-content select=\"fw-icon-button\"></ng-content>\n      <fw-icon-button\n        [size]=\"'small'\"\n        [icon]=\"subItemsOpen?'chevron-up':'chevron-down'\"\n        *ngIf=\"subItems.length>0\"\n        (click)=\"toggleSubItemsView()\">\n      </fw-icon-button>\n    </div>\n  </div>\n</div>\n<div class=\"item-subitems\">\n  <ng-content select=\"fw-menu-sub-item\"></ng-content>\n</div>\n"]}
|
|
@@ -1,11 +1,55 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { animate, style, transition, trigger } from '@angular/animations';
|
|
2
|
+
import { CdkOverlayOrigin, Overlay } from '@angular/cdk/overlay';
|
|
3
|
+
import { Component, computed, effect, EventEmitter, HostBinding, HostListener, inject, Input, input, Output, ViewEncapsulation } from '@angular/core';
|
|
2
4
|
import * as i0 from "@angular/core";
|
|
3
5
|
import * as i1 from "@angular/common";
|
|
6
|
+
const delayMap = {
|
|
7
|
+
'none': 0,
|
|
8
|
+
'short': 400,
|
|
9
|
+
'long': 700,
|
|
10
|
+
};
|
|
11
|
+
const positionMap = {
|
|
12
|
+
'none': { originX: 'center', originY: 'top', overlayX: 'center', overlayY: 'bottom', offsetY: 3 },
|
|
13
|
+
'above': { originX: 'center', originY: 'top', overlayX: 'center', overlayY: 'bottom', offsetY: 3 },
|
|
14
|
+
'below': { originX: 'center', originY: 'bottom', overlayX: 'center', overlayY: 'top', offsetY: -3 },
|
|
15
|
+
'left': { originX: 'start', originY: 'center', overlayX: 'end', overlayY: 'center' },
|
|
16
|
+
'right': { originX: 'end', originY: 'center', overlayX: 'start', overlayY: 'center' },
|
|
17
|
+
};
|
|
18
|
+
const isElementRef = (input) => ((Boolean(input.nativeElement)));
|
|
4
19
|
export class FwTooltipPanelComponent {
|
|
5
20
|
constructor() {
|
|
6
|
-
this.
|
|
21
|
+
this.trigger = input(undefined, {
|
|
22
|
+
transform: (unparsed) => {
|
|
23
|
+
if (isElementRef(unparsed)) {
|
|
24
|
+
return new CdkOverlayOrigin(unparsed);
|
|
25
|
+
}
|
|
26
|
+
return unparsed;
|
|
27
|
+
},
|
|
28
|
+
});
|
|
29
|
+
this.title = '';
|
|
30
|
+
this.isOpen = input(false);
|
|
31
|
+
this.position = input('below');
|
|
32
|
+
this.connectedPosition = computed(() => [positionMap[this.position()]]);
|
|
33
|
+
this.color = 'dark';
|
|
7
34
|
this.maxWidth = 200;
|
|
8
35
|
this.mouseLeave = new EventEmitter();
|
|
36
|
+
this.delay = input('short');
|
|
37
|
+
this.delayMs = computed(() => delayMap[this.delay()]);
|
|
38
|
+
/*
|
|
39
|
+
<ng-template
|
|
40
|
+
cdkConnectedOverlay
|
|
41
|
+
[cdkConnectedOverlayOrigin]="trigger"
|
|
42
|
+
[cdkConnectedOverlayOpen]="isOpen"
|
|
43
|
+
[cdkConnectedOverlayPositions]="connectedPosition()"
|
|
44
|
+
[cdkConnectedOverlayScrollStrategy]="this.overlayService.scrollStrategies.close()">
|
|
45
|
+
*/
|
|
46
|
+
this.overlayService = inject(Overlay);
|
|
47
|
+
this.updateOverlayOnChange = effect(() => {
|
|
48
|
+
// this.overlayRef.origin = this.trigger();
|
|
49
|
+
// this.overlayRef.positions = this.connectedPosition();
|
|
50
|
+
// this.overlayRef.open = this.isOpen();
|
|
51
|
+
// this.overlayRef.scrollStrategy = this.overlayService.scrollStrategies.close();
|
|
52
|
+
});
|
|
9
53
|
}
|
|
10
54
|
get classes() {
|
|
11
55
|
return ['fw-tooltip-panel', 'fw-tooltip-' + this.position].join(' ');
|
|
@@ -14,12 +58,32 @@ export class FwTooltipPanelComponent {
|
|
|
14
58
|
this.mouseLeave.emit(e);
|
|
15
59
|
}
|
|
16
60
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: FwTooltipPanelComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
17
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "
|
|
61
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "17.3.12", type: FwTooltipPanelComponent, selector: "fw-tooltip-panel", inputs: { trigger: { classPropertyName: "trigger", publicName: "trigger", isSignal: true, isRequired: false, transformFunction: null }, title: { classPropertyName: "title", publicName: "title", isSignal: false, isRequired: false, transformFunction: null }, isOpen: { classPropertyName: "isOpen", publicName: "isOpen", isSignal: true, isRequired: false, transformFunction: null }, position: { classPropertyName: "position", publicName: "position", isSignal: true, isRequired: false, transformFunction: null }, color: { classPropertyName: "color", publicName: "color", isSignal: false, isRequired: false, transformFunction: null }, maxWidth: { classPropertyName: "maxWidth", publicName: "maxWidth", isSignal: false, isRequired: false, transformFunction: null }, delay: { classPropertyName: "delay", publicName: "delay", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { mouseLeave: "mouseLeave" }, host: { listeners: { "mouseleave": "hidePopover($event)" }, properties: { "attr.class": "this.classes" } }, ngImport: i0, template: "<div\n @fadeInFadeOut\n class=\"fw-tooltip-content-wrapper vision-dark-theme\"\n [ngClass]=\"'fw-tooltip-' + position()\"\n [ngStyle]=\"{'maxWidth': maxWidth+'px'}\">\n <ng-content></ng-content>\n <h5 class=\"vision-h5\">{{ title }}</h5>\n <div class=\"fw-tooltip-caret\"></div>\n</div>\n", styles: [":host{position:absolute;height:0;width:0}.fw-tooltip-content-wrapper{position:relative;border-radius:8px;border:1px solid var(--separations-border);min-width:60px;box-sizing:border-box;padding:4px 8px;background-color:var(--card-header);text-align:center;overflow-wrap:break-word;white-space:pre-wrap}.fw-tooltip-content-wrapper h5{margin:0!important;color:var(--typography-muted)}.fw-tooltip-content-wrapper .fw-tooltip-caret{position:absolute;overflow:hidden;width:16px;height:16px}.fw-tooltip-content-wrapper .fw-tooltip-caret:after{display:block;content:\"\";width:10px;height:10px;background:var(--separations-border);border:1px solid var(--separations-border);transform:rotate(45deg);position:relative}.fw-tooltip-content-wrapper.fw-tooltip-none{margin-bottom:10px}.fw-tooltip-content-wrapper.fw-tooltip-none .fw-tooltip-caret{display:none}.fw-tooltip-content-wrapper.fw-tooltip-above{margin-bottom:10px}.fw-tooltip-content-wrapper.fw-tooltip-above .fw-tooltip-caret{left:calc(50% - 8px);bottom:-10px;height:10px!important}.fw-tooltip-content-wrapper.fw-tooltip-above .fw-tooltip-caret:after{margin:-8px auto;width:10px}.fw-tooltip-content-wrapper.fw-tooltip-below{margin-top:10px}.fw-tooltip-content-wrapper.fw-tooltip-below .fw-tooltip-caret{left:calc(50% - 8px);top:-10px;height:10px!important}.fw-tooltip-content-wrapper.fw-tooltip-below .fw-tooltip-caret:after{top:10px;margin:-4px auto;width:10px}.fw-tooltip-content-wrapper.fw-tooltip-left{margin-right:10px}.fw-tooltip-content-wrapper.fw-tooltip-left .fw-tooltip-caret{right:-10px;top:max(50% - 10px,3px);width:10px!important}.fw-tooltip-content-wrapper.fw-tooltip-left .fw-tooltip-caret:after{top:calc(50% - 5px);left:-8px;width:10px}.fw-tooltip-content-wrapper.fw-tooltip-right{margin-left:10px}.fw-tooltip-content-wrapper.fw-tooltip-right .fw-tooltip-caret{left:-10px;top:max(50% - 10px,3px);width:10px!important}.fw-tooltip-content-wrapper.fw-tooltip-right .fw-tooltip-caret:after{top:calc(50% - 5px);right:-6px;width:10px}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }], animations: [
|
|
62
|
+
trigger('fadeInFadeOut', [
|
|
63
|
+
transition(':enter', [
|
|
64
|
+
style({ opacity: 0 }),
|
|
65
|
+
animate('150ms', style({ opacity: 1 })),
|
|
66
|
+
]),
|
|
67
|
+
transition(':leave', [
|
|
68
|
+
animate('200ms', style({ opacity: 0 })),
|
|
69
|
+
]),
|
|
70
|
+
]),
|
|
71
|
+
], encapsulation: i0.ViewEncapsulation.None }); }
|
|
18
72
|
}
|
|
19
73
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: FwTooltipPanelComponent, decorators: [{
|
|
20
74
|
type: Component,
|
|
21
|
-
args: [{ selector: 'fw-tooltip-panel', encapsulation: ViewEncapsulation.None,
|
|
22
|
-
|
|
75
|
+
args: [{ selector: 'fw-tooltip-panel', encapsulation: ViewEncapsulation.None, animations: [
|
|
76
|
+
trigger('fadeInFadeOut', [
|
|
77
|
+
transition(':enter', [
|
|
78
|
+
style({ opacity: 0 }),
|
|
79
|
+
animate('150ms', style({ opacity: 1 })),
|
|
80
|
+
]),
|
|
81
|
+
transition(':leave', [
|
|
82
|
+
animate('200ms', style({ opacity: 0 })),
|
|
83
|
+
]),
|
|
84
|
+
]),
|
|
85
|
+
], template: "<div\n @fadeInFadeOut\n class=\"fw-tooltip-content-wrapper vision-dark-theme\"\n [ngClass]=\"'fw-tooltip-' + position()\"\n [ngStyle]=\"{'maxWidth': maxWidth+'px'}\">\n <ng-content></ng-content>\n <h5 class=\"vision-h5\">{{ title }}</h5>\n <div class=\"fw-tooltip-caret\"></div>\n</div>\n", styles: [":host{position:absolute;height:0;width:0}.fw-tooltip-content-wrapper{position:relative;border-radius:8px;border:1px solid var(--separations-border);min-width:60px;box-sizing:border-box;padding:4px 8px;background-color:var(--card-header);text-align:center;overflow-wrap:break-word;white-space:pre-wrap}.fw-tooltip-content-wrapper h5{margin:0!important;color:var(--typography-muted)}.fw-tooltip-content-wrapper .fw-tooltip-caret{position:absolute;overflow:hidden;width:16px;height:16px}.fw-tooltip-content-wrapper .fw-tooltip-caret:after{display:block;content:\"\";width:10px;height:10px;background:var(--separations-border);border:1px solid var(--separations-border);transform:rotate(45deg);position:relative}.fw-tooltip-content-wrapper.fw-tooltip-none{margin-bottom:10px}.fw-tooltip-content-wrapper.fw-tooltip-none .fw-tooltip-caret{display:none}.fw-tooltip-content-wrapper.fw-tooltip-above{margin-bottom:10px}.fw-tooltip-content-wrapper.fw-tooltip-above .fw-tooltip-caret{left:calc(50% - 8px);bottom:-10px;height:10px!important}.fw-tooltip-content-wrapper.fw-tooltip-above .fw-tooltip-caret:after{margin:-8px auto;width:10px}.fw-tooltip-content-wrapper.fw-tooltip-below{margin-top:10px}.fw-tooltip-content-wrapper.fw-tooltip-below .fw-tooltip-caret{left:calc(50% - 8px);top:-10px;height:10px!important}.fw-tooltip-content-wrapper.fw-tooltip-below .fw-tooltip-caret:after{top:10px;margin:-4px auto;width:10px}.fw-tooltip-content-wrapper.fw-tooltip-left{margin-right:10px}.fw-tooltip-content-wrapper.fw-tooltip-left .fw-tooltip-caret{right:-10px;top:max(50% - 10px,3px);width:10px!important}.fw-tooltip-content-wrapper.fw-tooltip-left .fw-tooltip-caret:after{top:calc(50% - 5px);left:-8px;width:10px}.fw-tooltip-content-wrapper.fw-tooltip-right{margin-left:10px}.fw-tooltip-content-wrapper.fw-tooltip-right .fw-tooltip-caret{left:-10px;top:max(50% - 10px,3px);width:10px!important}.fw-tooltip-content-wrapper.fw-tooltip-right .fw-tooltip-caret:after{top:calc(50% - 5px);right:-6px;width:10px}\n"] }]
|
|
86
|
+
}], propDecorators: { title: [{
|
|
23
87
|
type: Input
|
|
24
88
|
}], color: [{
|
|
25
89
|
type: Input
|
|
@@ -34,4 +98,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
34
98
|
type: HostListener,
|
|
35
99
|
args: ['mouseleave', ['$event']]
|
|
36
100
|
}] } });
|
|
37
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
101
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tooltip-panel.component.js","sourceRoot":"","sources":["../../../../../../src/components/tooltip/tooltip-panel/tooltip-panel.component.ts","../../../../../../src/components/tooltip/tooltip-panel/tooltip-panel.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,UAAU,EAAE,OAAO,EAAE,MAAM,qBAAqB,CAAC;AAC1E,OAAO,EAAE,gBAAgB,EAAqB,OAAO,EAAE,MAAM,sBAAsB,CAAC;AACpF,OAAO,EAAE,SAAS,EAAE,QAAQ,EAAE,MAAM,EAAc,YAAY,EAAE,WAAW,EAAE,YAAY,EAAE,MAAM,EAAE,KAAK,EAAE,KAAK,EAAE,MAAM,EAAE,iBAAiB,EAAE,MAAM,eAAe,CAAC;;;AAIlK,MAAM,QAAQ,GAAa;IACzB,MAAM,EAAE,CAAC;IACT,OAAO,EAAE,GAAG;IACZ,MAAM,EAAE,GAAG;CACZ,CAAA;AAGD,MAAM,WAAW,GAAyC;IACxD,MAAM,EAAE,EAAE,OAAO,EAAE,QAAQ,EAAE,OAAO,EAAE,KAAK,EAAE,QAAQ,EAAE,QAAQ,EAAE,QAAQ,EAAE,QAAQ,EAAE,OAAO,EAAE,CAAC,EAAE;IACjG,OAAO,EAAE,EAAE,OAAO,EAAE,QAAQ,EAAE,OAAO,EAAE,KAAK,EAAE,QAAQ,EAAE,QAAQ,EAAE,QAAQ,EAAE,QAAQ,EAAE,OAAO,EAAE,CAAC,EAAE;IAClG,OAAO,EAAE,EAAE,OAAO,EAAE,QAAQ,EAAE,OAAO,EAAE,QAAQ,EAAE,QAAQ,EAAE,QAAQ,EAAE,QAAQ,EAAE,KAAK,EAAE,OAAO,EAAE,CAAC,CAAC,EAAE;IACnG,MAAM,EAAE,EAAE,OAAO,EAAE,OAAO,EAAE,OAAO,EAAE,QAAQ,EAAE,QAAQ,EAAE,KAAK,EAAE,QAAQ,EAAE,QAAQ,EAAE;IACpF,OAAO,EAAE,EAAE,OAAO,EAAE,KAAK,EAAE,OAAO,EAAE,QAAQ,EAAE,QAAQ,EAAE,OAAO,EAAE,QAAQ,EAAE,QAAQ,EAAE;CACtF,CAAC;AAEF,MAAM,YAAY,GAAG,CAAC,KAAc,EAAoC,EAAE,CAAC,CACzE,CAAC,OAAO,CAAE,KAAiC,CAAC,aAAa,CAAC,CAAC,CAC5D,CAAA;AAmBD,MAAM,OAAO,uBAAuB;IAjBpC;QAmBE,YAAO,GAAG,KAAK,CAAC,SAAS,EAAE;YACzB,SAAS,EAAE,CAAC,QAAoD,EAAoB,EAAE;gBACpF,IAAI,YAAY,CAAC,QAAQ,CAAC,EAAE,CAAC;oBAC3B,OAAO,IAAI,gBAAgB,CAAC,QAAQ,CAAC,CAAC;gBACxC,CAAC;gBACD,OAAO,QAAQ,CAAC;YAClB,CAAC;SACF,CAAC,CAAA;QACO,UAAK,GAAG,EAAE,CAAC;QACpB,WAAM,GAAG,KAAK,CAAC,KAAK,CAAC,CAAC;QACtB,aAAQ,GAAG,KAAK,CAAiB,OAAO,CAAC,CAAC;QAC1C,sBAAiB,GAAG,QAAQ,CAAC,GAAG,EAAE,CAAC,CAAC,WAAW,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC,CAAC,CAAC;QAC1D,UAAK,GAAsB,MAAM,CAAC;QAClC,aAAQ,GAAY,GAAG,CAAC;QACvB,eAAU,GAA6B,IAAI,YAAY,EAAc,CAAC;QAChF,UAAK,GAAG,KAAK,CAAc,OAAO,CAAC,CAAC;QACpC,YAAO,GAAG,QAAQ,CAAC,GAAG,EAAE,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC;QAEjD;;;;;;;UAOE;QACF,mBAAc,GAAG,MAAM,CAAC,OAAO,CAAC,CAAC;QAEjC,0BAAqB,GAAG,MAAM,CAAC,GAAG,EAAE;YAClC,2CAA2C;YAC3C,wDAAwD;YACxD,wCAAwC;YACxC,iFAAiF;QACnF,CAAC,CAAC,CAAA;KASH;IAPC,IAA+B,OAAO;QACpC,OAAO,CAAC,kBAAkB,EAAE,aAAa,GAAG,IAAI,CAAC,QAAQ,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;IACvE,CAAC;IAEuC,WAAW,CAAC,CAAa;QAC/D,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IAC1B,CAAC;+GA3CU,uBAAuB;mGAAvB,uBAAuB,6jCC1CpC,ySASA,wqEDqBc;YACV,OAAO,CAAC,eAAe,EAAE;gBACvB,UAAU,CAAC,QAAQ,EAAE;oBACnB,KAAK,CAAC,EAAE,OAAO,EAAE,CAAC,EAAE,CAAC;oBACrB,OAAO,CAAC,OAAO,EAAE,KAAK,CAAC,EAAE,OAAO,EAAE,CAAC,EAAE,CAAC,CAAC;iBACxC,CAAC;gBACF,UAAU,CAAC,QAAQ,EAAE;oBACnB,OAAO,CAAC,OAAO,EAAE,KAAK,CAAC,EAAE,OAAO,EAAE,CAAC,EAAE,CAAC,CAAC;iBACxC,CAAC;aACH,CAAC;SACH;;4FAEU,uBAAuB;kBAjBnC,SAAS;+BACE,kBAAkB,iBAGb,iBAAiB,CAAC,IAAI,cACzB;wBACV,OAAO,CAAC,eAAe,EAAE;4BACvB,UAAU,CAAC,QAAQ,EAAE;gCACnB,KAAK,CAAC,EAAE,OAAO,EAAE,CAAC,EAAE,CAAC;gCACrB,OAAO,CAAC,OAAO,EAAE,KAAK,CAAC,EAAE,OAAO,EAAE,CAAC,EAAE,CAAC,CAAC;6BACxC,CAAC;4BACF,UAAU,CAAC,QAAQ,EAAE;gCACnB,OAAO,CAAC,OAAO,EAAE,KAAK,CAAC,EAAE,OAAO,EAAE,CAAC,EAAE,CAAC,CAAC;6BACxC,CAAC;yBACH,CAAC;qBACH;8BAYQ,KAAK;sBAAb,KAAK;gBAIG,KAAK;sBAAb,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBACI,UAAU;sBAAnB,MAAM;gBAqBwB,OAAO;sBAArC,WAAW;uBAAC,YAAY;gBAIe,WAAW;sBAAlD,YAAY;uBAAC,YAAY,EAAE,CAAC,QAAQ,CAAC","sourcesContent":["import { animate, style, transition, trigger } from '@angular/animations';\nimport { CdkOverlayOrigin, ConnectedPosition, Overlay } from '@angular/cdk/overlay';\nimport { Component, computed, effect, ElementRef, EventEmitter, HostBinding, HostListener, inject, Input, input, Output, ViewEncapsulation } from '@angular/core';\n\nexport type DelayLength = 'none' | 'short' | 'long';\ntype DelayMap = { [K in DelayLength]: number };\nconst delayMap: DelayMap = {\n  'none': 0,\n  'short': 400,\n  'long': 700,\n}\n\nexport type SimplePosition = 'above' | 'below' | 'left' | 'right' | 'none';\nconst positionMap: { [key: string]: ConnectedPosition } = {\n  'none': { originX: 'center', originY: 'top', overlayX: 'center', overlayY: 'bottom', offsetY: 3 },\n  'above': { originX: 'center', originY: 'top', overlayX: 'center', overlayY: 'bottom', offsetY: 3 },\n  'below': { originX: 'center', originY: 'bottom', overlayX: 'center', overlayY: 'top', offsetY: -3 },\n  'left': { originX: 'start', originY: 'center', overlayX: 'end', overlayY: 'center' },\n  'right': { originX: 'end', originY: 'center', overlayX: 'start', overlayY: 'center' },\n};\n\nconst isElementRef = (input: unknown): input is ElementRef<HTMLElement> => (\n  (Boolean((input as ElementRef<HTMLElement>).nativeElement))\n)\n\n@Component({\n  selector: 'fw-tooltip-panel',\n  templateUrl: './tooltip-panel.component.html',\n  styleUrls: ['./tooltip-panel.component.scss'],\n  encapsulation: ViewEncapsulation.None,\n  animations: [\n    trigger('fadeInFadeOut', [\n      transition(':enter', [\n        style({ opacity: 0 }),\n        animate('150ms', style({ opacity: 1 })),\n      ]),\n      transition(':leave', [\n        animate('200ms', style({ opacity: 0 })),\n      ]),\n    ]),\n  ],\n})\nexport class FwTooltipPanelComponent {\n\n  trigger = input(undefined, {\n    transform: (unparsed: CdkOverlayOrigin | ElementRef<HTMLElement>): CdkOverlayOrigin => {\n      if (isElementRef(unparsed)) {\n        return new CdkOverlayOrigin(unparsed);\n      }\n      return unparsed;\n    },\n  })\n  @Input() title = '';\n  isOpen = input(false);\n  position = input<SimplePosition>('below');\n  connectedPosition = computed(() => [positionMap[this.position()]]);\n  @Input() color?: 'light' | 'dark' = 'dark';\n  @Input() maxWidth?: number = 200;\n  @Output() mouseLeave: EventEmitter<MouseEvent> = new EventEmitter<MouseEvent>();\n  delay = input<DelayLength>('short');\n  delayMs = computed(() => delayMap[this.delay()]);\n\n  /*\n  <ng-template\n  cdkConnectedOverlay\n  [cdkConnectedOverlayOrigin]=\"trigger\"\n  [cdkConnectedOverlayOpen]=\"isOpen\"\n  [cdkConnectedOverlayPositions]=\"connectedPosition()\"\n  [cdkConnectedOverlayScrollStrategy]=\"this.overlayService.scrollStrategies.close()\">\n  */\n  overlayService = inject(Overlay);\n\n  updateOverlayOnChange = effect(() => {\n    // this.overlayRef.origin = this.trigger();\n    // this.overlayRef.positions = this.connectedPosition();\n    // this.overlayRef.open = this.isOpen();\n    // this.overlayRef.scrollStrategy = this.overlayService.scrollStrategies.close();\n  })\n\n  @HostBinding('attr.class') get classes(): string {\n    return ['fw-tooltip-panel', 'fw-tooltip-' + this.position].join(' ');\n  }\n\n  @HostListener('mouseleave', ['$event']) hidePopover(e: MouseEvent): void {\n    this.mouseLeave.emit(e);\n  }\n}\n","<div\n  @fadeInFadeOut\n  class=\"fw-tooltip-content-wrapper vision-dark-theme\"\n  [ngClass]=\"'fw-tooltip-' + position()\"\n  [ngStyle]=\"{'maxWidth': maxWidth+'px'}\">\n  <ng-content></ng-content>\n  <h5 class=\"vision-h5\">{{ title }}</h5>\n  <div class=\"fw-tooltip-caret\"></div>\n</div>\n"]}
|
|
@@ -1,93 +1,39 @@
|
|
|
1
|
-
|
|
2
|
-
import { animate, style, transition, trigger } from '@angular/animations';
|
|
3
|
-
import { ChangeDetectorRef, Component, computed, HostBinding, inject, Input, input } from '@angular/core';
|
|
1
|
+
import { Component, HostBinding, Input, input } from '@angular/core';
|
|
4
2
|
import * as i0 from "@angular/core";
|
|
5
3
|
import * as i1 from "@angular/common";
|
|
6
|
-
import * as i2 from "
|
|
7
|
-
import * as i3 from "./tooltip-panel/tooltip-panel.component";
|
|
8
|
-
const delayMap = {
|
|
9
|
-
'none': 0,
|
|
10
|
-
'short': 400,
|
|
11
|
-
'long': 700,
|
|
12
|
-
};
|
|
4
|
+
import * as i2 from "./tooltip.directive";
|
|
13
5
|
/**
|
|
14
6
|
* component for giving extra context when a user hovers something
|
|
15
7
|
* @see [Vision Docs](https://cdn.flywheel.io/docs/vision/master/?path=/docs/components-tooltip--docs)
|
|
16
8
|
*/
|
|
17
9
|
export class FwTooltipComponent {
|
|
18
10
|
constructor() {
|
|
19
|
-
this.color = '
|
|
11
|
+
this.color = 'dark';
|
|
20
12
|
this.position = 'above';
|
|
21
13
|
this.maxWidth = 200;
|
|
22
14
|
this.fullWidth = false;
|
|
15
|
+
// TODO v3: remove, we shouldn't need to give direct control over a tooltip's open state
|
|
23
16
|
this.isOpen = false;
|
|
24
|
-
this.cdRef = inject(ChangeDetectorRef);
|
|
25
17
|
this.delay = input('short');
|
|
26
|
-
this.delayMs = computed(() => delayMap[this.delay()]);
|
|
27
|
-
this.positionMap = {
|
|
28
|
-
'none': { originX: 'center', originY: 'top', overlayX: 'center', overlayY: 'bottom', offsetY: 3 },
|
|
29
|
-
'above': { originX: 'center', originY: 'top', overlayX: 'center', overlayY: 'bottom', offsetY: 3 },
|
|
30
|
-
'below': { originX: 'center', originY: 'bottom', overlayX: 'center', overlayY: 'top', offsetY: -3 },
|
|
31
|
-
'left': { originX: 'start', originY: 'center', overlayX: 'end', overlayY: 'center' },
|
|
32
|
-
'right': { originX: 'end', originY: 'center', overlayX: 'start', overlayY: 'center' },
|
|
33
|
-
};
|
|
34
18
|
}
|
|
35
19
|
get classes() {
|
|
36
20
|
return ['fw-tooltip', this.fullWidth ? 'full-width' : null].filter(Boolean).join(' ');
|
|
37
21
|
}
|
|
38
22
|
;
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
const delayMs = this.delayMs();
|
|
46
|
-
if (!delayMs) {
|
|
47
|
-
this.isOpen = true;
|
|
48
|
-
this.openDelayTimer = null;
|
|
49
|
-
}
|
|
50
|
-
else {
|
|
51
|
-
this.openDelayTimer = window.setTimeout(() => {
|
|
52
|
-
this.isOpen = true;
|
|
53
|
-
this.openDelayTimer = null;
|
|
54
|
-
// eslint-disable-next-line @rx-angular/no-explicit-change-detection-apis
|
|
55
|
-
this.cdRef.detectChanges();
|
|
56
|
-
}, delayMs);
|
|
57
|
-
}
|
|
58
|
-
}
|
|
59
|
-
handleMouseLeave() {
|
|
60
|
-
if (this.openDelayTimer) {
|
|
61
|
-
window.clearTimeout(this.openDelayTimer);
|
|
62
|
-
}
|
|
63
|
-
this.isOpen = false;
|
|
23
|
+
/**
|
|
24
|
+
* stops the browser built-in tooltip from showing up
|
|
25
|
+
* @see https://developer.mozilla.org/en-US/docs/Web/HTML/Reference/Global_attributes/title
|
|
26
|
+
*/
|
|
27
|
+
get attrTitle() {
|
|
28
|
+
return '';
|
|
64
29
|
}
|
|
30
|
+
;
|
|
65
31
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: FwTooltipComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
66
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "17.3.12", type: FwTooltipComponent, selector: "fw-tooltip", inputs: { title: { classPropertyName: "title", publicName: "title", isSignal: false, isRequired: false, transformFunction: null }, color: { classPropertyName: "color", publicName: "color", isSignal: false, isRequired: false, transformFunction: null }, position: { classPropertyName: "position", publicName: "position", isSignal: false, isRequired: false, transformFunction: null }, maxWidth: { classPropertyName: "maxWidth", publicName: "maxWidth", isSignal: false, isRequired: false, transformFunction: null }, fullWidth: { classPropertyName: "fullWidth", publicName: "fullWidth", isSignal: false, isRequired: false, transformFunction: null }, isOpen: { classPropertyName: "isOpen", publicName: "isOpen", isSignal: false, isRequired: false, transformFunction: null }, trigger: { classPropertyName: "trigger", publicName: "trigger", isSignal: false, isRequired: false, transformFunction: null }, delay: { classPropertyName: "delay", publicName: "delay", isSignal: true, isRequired: false, transformFunction: null } }, host: { properties: { "attr.class": "this.classes", "attr.title": "this
|
|
67
|
-
trigger('fadeInFadeOut', [
|
|
68
|
-
transition(':enter', [
|
|
69
|
-
style({ opacity: 0 }),
|
|
70
|
-
animate('150ms', style({ opacity: 1 })),
|
|
71
|
-
]),
|
|
72
|
-
transition(':leave', [
|
|
73
|
-
animate('200ms', style({ opacity: 0 })),
|
|
74
|
-
]),
|
|
75
|
-
]),
|
|
76
|
-
] }); }
|
|
32
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "17.3.12", type: FwTooltipComponent, selector: "fw-tooltip", inputs: { title: { classPropertyName: "title", publicName: "title", isSignal: false, isRequired: false, transformFunction: null }, color: { classPropertyName: "color", publicName: "color", isSignal: false, isRequired: false, transformFunction: null }, position: { classPropertyName: "position", publicName: "position", isSignal: false, isRequired: false, transformFunction: null }, maxWidth: { classPropertyName: "maxWidth", publicName: "maxWidth", isSignal: false, isRequired: false, transformFunction: null }, fullWidth: { classPropertyName: "fullWidth", publicName: "fullWidth", isSignal: false, isRequired: false, transformFunction: null }, isOpen: { classPropertyName: "isOpen", publicName: "isOpen", isSignal: false, isRequired: false, transformFunction: null }, trigger: { classPropertyName: "trigger", publicName: "trigger", isSignal: false, isRequired: false, transformFunction: null }, delay: { classPropertyName: "delay", publicName: "delay", isSignal: true, isRequired: false, transformFunction: null } }, host: { properties: { "attr.class": "this.classes", "attr.title": "this.attrTitle" } }, ngImport: i0, template: "<div\n [ngClass]=\"['tooltip-trigger',fullWidth?'full-width':'']\"\n [fwTooltip]=\"title\"\n [fwTooltipDelay]=\"delay()\"\n [fwTooltipPosition]=\"position\">\n <ng-content></ng-content>\n</div>\n", styles: [":host.full-width{flex:1;display:flex;width:stretch}:host.full-width button{flex:1}:host .tooltip-trigger{width:fit-content;display:inline-block}:host .tooltip-trigger.full-width{flex:1;display:flex;width:stretch}:host .tooltip-trigger.full-width button{flex:1}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.FwTooltipDirective, selector: "[fwTooltip]", inputs: ["fwTooltipDelay", "fwTooltip", "fwTooltipPosition", "fwTooltipMaxWidthPx", "fwTooltipEnabled"], outputs: ["fwTooltipChange", "fwTooltipPositionChange", "fwTooltipMaxWidthPxChange", "fwTooltipEnabledChange"] }] }); }
|
|
77
33
|
}
|
|
78
34
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: FwTooltipComponent, decorators: [{
|
|
79
35
|
type: Component,
|
|
80
|
-
args: [{ selector: 'fw-tooltip',
|
|
81
|
-
trigger('fadeInFadeOut', [
|
|
82
|
-
transition(':enter', [
|
|
83
|
-
style({ opacity: 0 }),
|
|
84
|
-
animate('150ms', style({ opacity: 1 })),
|
|
85
|
-
]),
|
|
86
|
-
transition(':leave', [
|
|
87
|
-
animate('200ms', style({ opacity: 0 })),
|
|
88
|
-
]),
|
|
89
|
-
]),
|
|
90
|
-
], template: "<ng-template\n cdkConnectedOverlay\n [cdkConnectedOverlayOrigin]=\"trigger\"\n [cdkConnectedOverlayOpen]=\"isOpen\"\n [cdkConnectedOverlayPositions]=\"[positionMap[position]]\">\n <fw-tooltip-panel\n @fadeInFadeOut\n *ngIf=\"title\"\n [position]=\"position\"\n [color]=\"color\"\n [maxWidth]=\"maxWidth\">\n <h5 class=\"vision-h5\">{{ title }}</h5>\n </fw-tooltip-panel>\n</ng-template>\n<div\n [ngClass]=\"['tooltip-trigger',fullWidth?'full-width':'']\"\n cdkOverlayOrigin #trigger=\"cdkOverlayOrigin\"\n (mouseenter)=\"handleMouseEnter($event)\" (mouseleave)=\"handleMouseLeave()\">\n <ng-content></ng-content>\n</div>\n", styles: [":host.full-width{flex:1;display:flex;width:stretch}:host.full-width button{flex:1}:host .tooltip-trigger{width:fit-content;display:inline-block}:host .tooltip-trigger.full-width{flex:1;display:flex;width:stretch}:host .tooltip-trigger.full-width button{flex:1}\n"] }]
|
|
36
|
+
args: [{ selector: 'fw-tooltip', template: "<div\n [ngClass]=\"['tooltip-trigger',fullWidth?'full-width':'']\"\n [fwTooltip]=\"title\"\n [fwTooltipDelay]=\"delay()\"\n [fwTooltipPosition]=\"position\">\n <ng-content></ng-content>\n</div>\n", styles: [":host.full-width{flex:1;display:flex;width:stretch}:host.full-width button{flex:1}:host .tooltip-trigger{width:fit-content;display:inline-block}:host .tooltip-trigger.full-width{flex:1;display:flex;width:stretch}:host .tooltip-trigger.full-width button{flex:1}\n"] }]
|
|
91
37
|
}], propDecorators: { title: [{
|
|
92
38
|
type: Input
|
|
93
39
|
}], color: [{
|
|
@@ -105,8 +51,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
105
51
|
}], classes: [{
|
|
106
52
|
type: HostBinding,
|
|
107
53
|
args: ['attr.class']
|
|
108
|
-
}],
|
|
54
|
+
}], attrTitle: [{
|
|
109
55
|
type: HostBinding,
|
|
110
56
|
args: ['attr.title']
|
|
111
57
|
}] } });
|
|
112
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
58
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidG9vbHRpcC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9zcmMvY29tcG9uZW50cy90b29sdGlwL3Rvb2x0aXAuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vc3JjL2NvbXBvbmVudHMvdG9vbHRpcC90b29sdGlwLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUVBLE9BQU8sRUFBRSxTQUFTLEVBQUUsV0FBVyxFQUFFLEtBQUssRUFBQyxLQUFLLEVBQUUsTUFBTSxlQUFlLENBQUM7Ozs7QUFNcEU7OztHQUdHO0FBTUgsTUFBTSxPQUFPLGtCQUFrQjtJQUwvQjtRQU9XLFVBQUssR0FBcUIsTUFBTSxDQUFDO1FBQ2pDLGFBQVEsR0FBbUIsT0FBTyxDQUFDO1FBQ25DLGFBQVEsR0FBWSxHQUFHLENBQUM7UUFDeEIsY0FBUyxHQUFhLEtBQUssQ0FBQztRQUNyQyx3RkFBd0Y7UUFDL0UsV0FBTSxHQUFZLEtBQUssQ0FBQztRQUlqQyxVQUFLLEdBQUcsS0FBSyxDQUFjLE9BQU8sQ0FBQyxDQUFDO0tBY3JDO0lBWkMsSUFBK0IsT0FBTztRQUNwQyxPQUFPLENBQUMsWUFBWSxFQUFFLElBQUksQ0FBQyxTQUFTLENBQUMsQ0FBQyxDQUFDLFlBQVksQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLENBQUMsTUFBTSxDQUFDLE9BQU8sQ0FBQyxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsQ0FBQztJQUN4RixDQUFDO0lBQUEsQ0FBQztJQUVGOzs7TUFHRTtJQUNGLElBQStCLFNBQVM7UUFDdEMsT0FBTyxFQUFFLENBQUM7SUFDWixDQUFDO0lBQUEsQ0FBQzsrR0F2QlMsa0JBQWtCO21HQUFsQixrQkFBa0Isb29DQ2pCL0IsME1BT0E7OzRGRFVhLGtCQUFrQjtrQkFMOUIsU0FBUzsrQkFDRSxZQUFZOzhCQUtiLEtBQUs7c0JBQWIsS0FBSztnQkFDRyxLQUFLO3NCQUFiLEtBQUs7Z0JBQ0csUUFBUTtzQkFBaEIsS0FBSztnQkFDRyxRQUFRO3NCQUFoQixLQUFLO2dCQUNHLFNBQVM7c0JBQWpCLEtBQUs7Z0JBRUcsTUFBTTtzQkFBZCxLQUFLO2dCQUVHLE9BQU87c0JBQWYsS0FBSztnQkFJeUIsT0FBTztzQkFBckMsV0FBVzt1QkFBQyxZQUFZO2dCQVFNLFNBQVM7c0JBQXZDLFdBQVc7dUJBQUMsWUFBWSIsInNvdXJjZXNDb250ZW50IjpbIi8qIGVzbGludC1kaXNhYmxlIEByeC1hbmd1bGFyL3ByZWZlci1uby1sYXlvdXQtc2Vuc2l0aXZlLWFwaXMgKi9cbmltcG9ydCB7IENka092ZXJsYXlPcmlnaW4sIEZsZXhpYmxlQ29ubmVjdGVkUG9zaXRpb25TdHJhdGVneU9yaWdpbiB9IGZyb20gJ0Bhbmd1bGFyL2Nkay9vdmVybGF5JztcbmltcG9ydCB7IENvbXBvbmVudCwgSG9zdEJpbmRpbmcsIElucHV0LGlucHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbmltcG9ydCB7IFNpbXBsZVBvc2l0aW9uIH0gZnJvbSAnLi90b29sdGlwLXBhbmVsL3Rvb2x0aXAtcGFuZWwuY29tcG9uZW50JztcblxudHlwZSBEZWxheUxlbmd0aCA9ICdub25lJyB8ICdzaG9ydCcgfCAnbG9uZyc7XG5cbi8qKlxuICogY29tcG9uZW50IGZvciBnaXZpbmcgZXh0cmEgY29udGV4dCB3aGVuIGEgdXNlciBob3ZlcnMgc29tZXRoaW5nXG4gKiBAc2VlIFtWaXNpb24gRG9jc10oaHR0cHM6Ly9jZG4uZmx5d2hlZWwuaW8vZG9jcy92aXNpb24vbWFzdGVyLz9wYXRoPS9kb2NzL2NvbXBvbmVudHMtdG9vbHRpcC0tZG9jcylcbiAqL1xuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnZnctdG9vbHRpcCcsXG4gIHRlbXBsYXRlVXJsOiAnLi90b29sdGlwLmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmxzOiBbJy4vdG9vbHRpcC5jb21wb25lbnQuc2NzcyddLFxufSlcbmV4cG9ydCBjbGFzcyBGd1Rvb2x0aXBDb21wb25lbnQge1xuICBASW5wdXQoKSB0aXRsZTogc3RyaW5nO1xuICBASW5wdXQoKSBjb2xvcjogJ2xpZ2h0JyB8ICdkYXJrJyA9ICdkYXJrJztcbiAgQElucHV0KCkgcG9zaXRpb246IFNpbXBsZVBvc2l0aW9uID0gJ2Fib3ZlJztcbiAgQElucHV0KCkgbWF4V2lkdGg/OiBudW1iZXIgPSAyMDA7XG4gIEBJbnB1dCgpIGZ1bGxXaWR0aD86IGJvb2xlYW4gPSBmYWxzZTtcbiAgLy8gVE9ETyB2MzogcmVtb3ZlLCB3ZSBzaG91bGRuJ3QgbmVlZCB0byBnaXZlIGRpcmVjdCBjb250cm9sIG92ZXIgYSB0b29sdGlwJ3Mgb3BlbiBzdGF0ZVxuICBASW5wdXQoKSBpc09wZW46IGJvb2xlYW4gPSBmYWxzZTtcbiAgLy8gVE9ETyB2MzogdGhpcyBpcyBhIG5vLW9wIGlucHV0LCB3ZSBzaG91bGQgcmVtb3ZlXG4gIEBJbnB1dCgpIHRyaWdnZXI6IENka092ZXJsYXlPcmlnaW4gfCBGbGV4aWJsZUNvbm5lY3RlZFBvc2l0aW9uU3RyYXRlZ3lPcmlnaW47XG5cbiAgZGVsYXkgPSBpbnB1dDxEZWxheUxlbmd0aD4oJ3Nob3J0Jyk7XG5cbiAgQEhvc3RCaW5kaW5nKCdhdHRyLmNsYXNzJykgZ2V0IGNsYXNzZXMoKTogc3RyaW5nIHtcbiAgICByZXR1cm4gWydmdy10b29sdGlwJywgdGhpcy5mdWxsV2lkdGggPyAnZnVsbC13aWR0aCcgOiBudWxsXS5maWx0ZXIoQm9vbGVhbikuam9pbignICcpO1xuICB9O1xuXG4gIC8qKlxuICAgKiBzdG9wcyB0aGUgYnJvd3NlciBidWlsdC1pbiB0b29sdGlwIGZyb20gc2hvd2luZyB1cFxuICAgKiBAc2VlIGh0dHBzOi8vZGV2ZWxvcGVyLm1vemlsbGEub3JnL2VuLVVTL2RvY3MvV2ViL0hUTUwvUmVmZXJlbmNlL0dsb2JhbF9hdHRyaWJ1dGVzL3RpdGxlXG4gICovXG4gIEBIb3N0QmluZGluZygnYXR0ci50aXRsZScpIGdldCBhdHRyVGl0bGUoKTogc3RyaW5nIHtcbiAgICByZXR1cm4gJyc7XG4gIH07XG5cbn1cbiIsIjxkaXZcbiAgW25nQ2xhc3NdPVwiWyd0b29sdGlwLXRyaWdnZXInLGZ1bGxXaWR0aD8nZnVsbC13aWR0aCc6JyddXCJcbiAgW2Z3VG9vbHRpcF09XCJ0aXRsZVwiXG4gIFtmd1Rvb2x0aXBEZWxheV09XCJkZWxheSgpXCJcbiAgW2Z3VG9vbHRpcFBvc2l0aW9uXT1cInBvc2l0aW9uXCI+XG4gIDxuZy1jb250ZW50PjwvbmctY29udGVudD5cbjwvZGl2PlxuIl19
|
|
@@ -0,0 +1,114 @@
|
|
|
1
|
+
import { Overlay } from '@angular/cdk/overlay';
|
|
2
|
+
import { ComponentPortal } from '@angular/cdk/portal';
|
|
3
|
+
import { computed, Directive, effect, ElementRef, inject, input, model, signal, ViewContainerRef } from '@angular/core';
|
|
4
|
+
import { FwTooltipPanelComponent } from './tooltip-panel/tooltip-panel.component';
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
const positionMap = {
|
|
7
|
+
'none': { originX: 'center', originY: 'top', overlayX: 'center', overlayY: 'bottom', offsetY: 3 },
|
|
8
|
+
'above': { originX: 'center', originY: 'top', overlayX: 'center', overlayY: 'bottom', offsetY: 3 },
|
|
9
|
+
'below': { originX: 'center', originY: 'bottom', overlayX: 'center', overlayY: 'top', offsetY: -3 },
|
|
10
|
+
'left': { originX: 'start', originY: 'center', overlayX: 'end', overlayY: 'center' },
|
|
11
|
+
'right': { originX: 'end', originY: 'center', overlayX: 'start', overlayY: 'center' },
|
|
12
|
+
};
|
|
13
|
+
const delayMap = {
|
|
14
|
+
'none': 0,
|
|
15
|
+
'short': 400,
|
|
16
|
+
'long': 700,
|
|
17
|
+
};
|
|
18
|
+
const delayNameToMs = (name) => {
|
|
19
|
+
return delayMap[name];
|
|
20
|
+
};
|
|
21
|
+
export class FwTooltipDirective {
|
|
22
|
+
constructor() {
|
|
23
|
+
// External Context
|
|
24
|
+
this.elementRef = inject(ElementRef);
|
|
25
|
+
this.viewContainerRef = inject(ViewContainerRef);
|
|
26
|
+
this.overlayService = inject(Overlay);
|
|
27
|
+
// Internal refs
|
|
28
|
+
this.overlayRef = signal(undefined);
|
|
29
|
+
this.tooltipRef = signal(undefined);
|
|
30
|
+
// Inputs
|
|
31
|
+
this.delayMs = input(400, {
|
|
32
|
+
transform: delayNameToMs,
|
|
33
|
+
alias: 'fwTooltipDelay',
|
|
34
|
+
});
|
|
35
|
+
// a lot of these ideally wouldn't be models,
|
|
36
|
+
// but it makes it easier to interact with this from derivative directives
|
|
37
|
+
this.title = model('undefined', {
|
|
38
|
+
alias: 'fwTooltip',
|
|
39
|
+
});
|
|
40
|
+
this.position = model('above', {
|
|
41
|
+
alias: 'fwTooltipPosition',
|
|
42
|
+
});
|
|
43
|
+
this.maxWidth = model(200, {
|
|
44
|
+
alias: 'fwTooltipMaxWidthPx',
|
|
45
|
+
});
|
|
46
|
+
this.enabled = model(true, {
|
|
47
|
+
alias: 'fwTooltipEnabled'
|
|
48
|
+
});
|
|
49
|
+
// derived state
|
|
50
|
+
this.connectedPosition = computed(() => [positionMap[this.position()]]);
|
|
51
|
+
this.positionStrategy = computed(() => {
|
|
52
|
+
const positionBuilder = this.overlayService.position();
|
|
53
|
+
const withOrigin = positionBuilder.flexibleConnectedTo(this.elementRef);
|
|
54
|
+
const completedStrategy = withOrigin.withPositions(this.connectedPosition());
|
|
55
|
+
return completedStrategy;
|
|
56
|
+
});
|
|
57
|
+
this.overlayConfig = computed(() => ({
|
|
58
|
+
positionStrategy: this.positionStrategy(),
|
|
59
|
+
maxWidth: this.maxWidth(),
|
|
60
|
+
ScrollStrategyOptions: this.overlayService.scrollStrategies.close(),
|
|
61
|
+
disposeOnNavigation: true,
|
|
62
|
+
}));
|
|
63
|
+
// effects and methods
|
|
64
|
+
this.addMouseEventListeners = effect(() => {
|
|
65
|
+
const nativeElement = this.elementRef.nativeElement;
|
|
66
|
+
nativeElement.addEventListener('mouseenter', () => {
|
|
67
|
+
this.showTooltip();
|
|
68
|
+
});
|
|
69
|
+
nativeElement.addEventListener('mouseleave', () => {
|
|
70
|
+
this.hideTooltip();
|
|
71
|
+
});
|
|
72
|
+
});
|
|
73
|
+
}
|
|
74
|
+
ngOnInit() {
|
|
75
|
+
this.tooltipPortal = new ComponentPortal(FwTooltipPanelComponent, this.viewContainerRef);
|
|
76
|
+
this.overlayRef.set(this.overlayService.create());
|
|
77
|
+
}
|
|
78
|
+
showTooltip() {
|
|
79
|
+
if (!this.enabled() || !this.title()) {
|
|
80
|
+
return;
|
|
81
|
+
}
|
|
82
|
+
const overlayRef = this.overlayRef();
|
|
83
|
+
overlayRef.updatePositionStrategy(this.positionStrategy());
|
|
84
|
+
if (this.openDelayTimer) {
|
|
85
|
+
return;
|
|
86
|
+
}
|
|
87
|
+
this.openDelayTimer = window.setTimeout(() => {
|
|
88
|
+
const tooltipRef = overlayRef.attach(this.tooltipPortal);
|
|
89
|
+
this.tooltipRef.set(tooltipRef);
|
|
90
|
+
tooltipRef.setInput('title', this.title());
|
|
91
|
+
tooltipRef.setInput('position', this.position());
|
|
92
|
+
tooltipRef.changeDetectorRef.detectChanges();
|
|
93
|
+
}, this.delayMs());
|
|
94
|
+
}
|
|
95
|
+
hideTooltip() {
|
|
96
|
+
const animationDelayMs = 200;
|
|
97
|
+
this.closeDelayTimer = window.setTimeout(() => {
|
|
98
|
+
window.clearTimeout(this.openDelayTimer);
|
|
99
|
+
this.openDelayTimer = undefined;
|
|
100
|
+
this.overlayRef().detach();
|
|
101
|
+
this.tooltipRef.set(undefined);
|
|
102
|
+
}, animationDelayMs);
|
|
103
|
+
}
|
|
104
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: FwTooltipDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
105
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "17.1.0", version: "17.3.12", type: FwTooltipDirective, isStandalone: true, selector: "[fwTooltip]", inputs: { delayMs: { classPropertyName: "delayMs", publicName: "fwTooltipDelay", isSignal: true, isRequired: false, transformFunction: null }, title: { classPropertyName: "title", publicName: "fwTooltip", isSignal: true, isRequired: false, transformFunction: null }, position: { classPropertyName: "position", publicName: "fwTooltipPosition", isSignal: true, isRequired: false, transformFunction: null }, maxWidth: { classPropertyName: "maxWidth", publicName: "fwTooltipMaxWidthPx", isSignal: true, isRequired: false, transformFunction: null }, enabled: { classPropertyName: "enabled", publicName: "fwTooltipEnabled", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { title: "fwTooltipChange", position: "fwTooltipPositionChange", maxWidth: "fwTooltipMaxWidthPxChange", enabled: "fwTooltipEnabledChange" }, ngImport: i0 }); }
|
|
106
|
+
}
|
|
107
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: FwTooltipDirective, decorators: [{
|
|
108
|
+
type: Directive,
|
|
109
|
+
args: [{
|
|
110
|
+
selector: '[fwTooltip]',
|
|
111
|
+
standalone: true,
|
|
112
|
+
}]
|
|
113
|
+
}] });
|
|
114
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tooltip.directive.js","sourceRoot":"","sources":["../../../../../src/components/tooltip/tooltip.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { ConnectedPosition, Overlay, OverlayConfig, OverlayRef } from '@angular/cdk/overlay';\nimport { ComponentPortal } from '@angular/cdk/portal';\nimport { ComponentRef, computed, Directive, effect, ElementRef, inject, input, model, OnInit, signal, ViewContainerRef } from '@angular/core';\n\nimport { FwTooltipPanelComponent, SimplePosition } from './tooltip-panel/tooltip-panel.component';\n\ntype DelayLength = 'none' | 'short' | 'long';\ntype DelayMap = { [K in DelayLength]: number };\n\nconst positionMap: { [key: string]: ConnectedPosition } = {\n  'none': { originX: 'center', originY: 'top', overlayX: 'center', overlayY: 'bottom', offsetY: 3 },\n  'above': { originX: 'center', originY: 'top', overlayX: 'center', overlayY: 'bottom', offsetY: 3 },\n  'below': { originX: 'center', originY: 'bottom', overlayX: 'center', overlayY: 'top', offsetY: -3 },\n  'left': { originX: 'start', originY: 'center', overlayX: 'end', overlayY: 'center' },\n  'right': { originX: 'end', originY: 'center', overlayX: 'start', overlayY: 'center' },\n};\n\nconst delayMap: DelayMap = {\n  'none': 0,\n  'short': 400,\n  'long': 700,\n}\n\nconst delayNameToMs = (name: DelayLength): number => {\n  return delayMap[name];\n}\n\n@Directive({\n  selector: '[fwTooltip]',\n  standalone: true,\n})\nexport class FwTooltipDirective implements OnInit {\n\n  // External Context\n  private elementRef = inject<ElementRef<HTMLElement>>(ElementRef);\n  private viewContainerRef = inject(ViewContainerRef);\n  private overlayService = inject(Overlay);\n\n  // Internal refs\n  private overlayRef = signal<OverlayRef>(undefined);\n  private tooltipRef = signal<ComponentRef<FwTooltipPanelComponent>>(undefined);\n  private tooltipPortal: ComponentPortal<FwTooltipPanelComponent>;\n\n  // Inputs\n  delayMs = input(400, {\n    transform: delayNameToMs,\n    alias: 'fwTooltipDelay',\n  });\n\n  // a lot of these ideally wouldn't be models,\n  // but it makes it easier to interact with this from derivative directives\n\n  title = model<string>('undefined', {\n    alias: 'fwTooltip',\n  })\n\n  position = model<SimplePosition>('above', {\n    alias: 'fwTooltipPosition',\n  });\n\n  maxWidth = model<number>(200, {\n    alias: 'fwTooltipMaxWidthPx',\n  })\n\n  enabled = model(true, {\n    alias: 'fwTooltipEnabled'\n  });\n\n  // derived state\n  connectedPosition = computed(() => [positionMap[this.position()]]);\n\n  positionStrategy = computed(() => {\n    const positionBuilder = this.overlayService.position();\n    const withOrigin = positionBuilder.flexibleConnectedTo(this.elementRef);\n    const completedStrategy = withOrigin.withPositions(this.connectedPosition());\n    return completedStrategy;\n  });\n\n  overlayConfig = computed<OverlayConfig>(() => ({\n    positionStrategy: this.positionStrategy(),\n    maxWidth: this.maxWidth(),\n    ScrollStrategyOptions: this.overlayService.scrollStrategies.close(),\n    disposeOnNavigation: true,\n  }));\n\n  // effects and methods\n  addMouseEventListeners = effect(() => {\n\n    const nativeElement = this.elementRef.nativeElement;\n\n    nativeElement.addEventListener('mouseenter', () => {\n      this.showTooltip();\n    });\n\n    nativeElement.addEventListener('mouseleave', () => {\n      this.hideTooltip();\n    });\n  })\n\n  ngOnInit(): void {\n    this.tooltipPortal = new ComponentPortal(FwTooltipPanelComponent, this.viewContainerRef);\n\n    this.overlayRef.set(this.overlayService.create());\n  }\n\n\n  private openDelayTimer: number;\n  private closeDelayTimer: number;\n\n  showTooltip(): void {\n\n    if(!this.enabled() || !this.title()) {\n      return;\n    }\n\n    const overlayRef = this.overlayRef();\n    overlayRef.updatePositionStrategy(this.positionStrategy());\n\n    if (this.openDelayTimer) {\n      return;\n    }\n\n    this.openDelayTimer = window.setTimeout(() => {\n      const tooltipRef = overlayRef.attach(this.tooltipPortal);\n      this.tooltipRef.set(tooltipRef);\n\n      tooltipRef.setInput('title', this.title());\n      tooltipRef.setInput('position', this.position());\n      tooltipRef.changeDetectorRef.detectChanges();\n    }, this.delayMs());\n  }\n\n  hideTooltip(): void {\n\n    const animationDelayMs = 200;\n\n\n    this.closeDelayTimer = window.setTimeout(() => {\n      window.clearTimeout(this.openDelayTimer);\n      this.openDelayTimer = undefined;\n      this.overlayRef().detach();\n      this.tooltipRef.set(undefined);\n    }, animationDelayMs);\n  }\n\n}\n"]}
|