asksuite-citrus 1.5.7 → 1.5.9

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.
@@ -2,6 +2,7 @@ import { Directive, EventEmitter, HostListener, Input, Output } from '@angular/c
2
2
  import { DropdownContainerComponent } from "../components/dropdown-container/dropdown-container.component";
3
3
  import { ComponentPortal } from "@angular/cdk/portal";
4
4
  import { takeUntilDestroyed } from "@angular/core/rxjs-interop";
5
+ import { fromEvent } from "rxjs";
5
6
  import * as i0 from "@angular/core";
6
7
  import * as i1 from "@angular/cdk/overlay";
7
8
  export class AskDropdownDirective {
@@ -12,7 +13,10 @@ export class AskDropdownDirective {
12
13
  this._destroyRef = _destroyRef;
13
14
  this.dropdownName = '';
14
15
  this.dropdownDisabled = false;
16
+ this.dropdownOpenOnHover = false;
17
+ this.mouseThreshold = 300;
15
18
  this.askDropdownOnClose = new EventEmitter();
19
+ this.mouseLocation = { mouseX: 0, mouseY: 0 };
16
20
  this._isRendered = false;
17
21
  this.overlayConfig = {};
18
22
  this.AVAILABLE_POSITIONS = {
@@ -31,7 +35,7 @@ export class AskDropdownDirective {
31
35
  const positionStrategy = this.overlayPositionBuilder
32
36
  .flexibleConnectedTo(this.elementRef)
33
37
  .withPositions(this.getOverlayPosition());
34
- const scrollStrategy = this.overlay.scrollStrategies.block();
38
+ const scrollStrategy = this.overlay.scrollStrategies.reposition();
35
39
  this.overlayConfig = {
36
40
  hasBackdrop: true,
37
41
  backdropClass: 'cdk-overlay-transparent-backdrop',
@@ -70,6 +74,19 @@ export class AskDropdownDirective {
70
74
  event.stopPropagation();
71
75
  });
72
76
  }
77
+ showOnHoverIn() {
78
+ if (this.dropdownOpenOnHover) {
79
+ this.show();
80
+ this.mouseLocation = this.onMouseMove(event);
81
+ this.mouseDistanceSubscription = fromEvent(document.body, 'mousemove').subscribe((e) => {
82
+ const mouseYCloseOn = Math.abs(this.mouseLocation.mouseY - e.pageY) <= this.mouseThreshold;
83
+ const mouseXCloseOn = Math.abs(this.mouseLocation.mouseX - e.pageX) <= this.mouseThreshold;
84
+ if (!(mouseYCloseOn && mouseXCloseOn)) {
85
+ this.close();
86
+ }
87
+ });
88
+ }
89
+ }
73
90
  show() {
74
91
  if (!this.askDropdown || this.isRendered || this.dropdownDisabled) {
75
92
  this.close();
@@ -77,19 +94,40 @@ export class AskDropdownDirective {
77
94
  }
78
95
  this.containerRef = this.overlayRef.attach(new ComponentPortal(DropdownContainerComponent));
79
96
  this.containerRef.instance.content = this.askDropdown;
97
+ if (this.dropdownOpenOnHover) {
98
+ this.mouseOutSubscription = fromEvent(this.containerRef.location.nativeElement, 'mouseout')
99
+ .subscribe((event) => {
100
+ if (event.relatedTarget?.classList.contains('cdk-overlay-backdrop')) {
101
+ this.close();
102
+ }
103
+ });
104
+ }
80
105
  this._isRendered = true;
81
106
  }
107
+ onMouseMove(event) {
108
+ const location = {
109
+ mouseX: event.clientX,
110
+ mouseY: event.pageY
111
+ };
112
+ return location;
113
+ }
82
114
  close() {
83
115
  this.containerRef = undefined;
84
116
  this.overlayRef.detach();
85
117
  this._isRendered = false;
86
118
  this.askDropdownOnClose.emit();
119
+ if (this.mouseOutSubscription) {
120
+ this.mouseOutSubscription.unsubscribe();
121
+ }
122
+ if (this.mouseDistanceSubscription) {
123
+ this.mouseDistanceSubscription.unsubscribe();
124
+ }
87
125
  }
88
126
  get isRendered() {
89
127
  return this._isRendered;
90
128
  }
91
129
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.6", ngImport: i0, type: AskDropdownDirective, deps: [{ token: i1.OverlayPositionBuilder }, { token: i0.ElementRef }, { token: i1.Overlay }, { token: i0.DestroyRef }], target: i0.ɵɵFactoryTarget.Directive }); }
92
- static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.1.6", type: AskDropdownDirective, selector: "[askDropdown]", inputs: { askDropdown: "askDropdown", dropdownName: "dropdownName", positions: "positions", dropdownDisabled: "dropdownDisabled" }, outputs: { askDropdownOnClose: "askDropdownOnClose" }, host: { listeners: { "click": "show()" } }, ngImport: i0 }); }
130
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.1.6", type: AskDropdownDirective, selector: "[askDropdown]", inputs: { askDropdown: "askDropdown", dropdownName: "dropdownName", positions: "positions", dropdownDisabled: "dropdownDisabled", dropdownOpenOnHover: "dropdownOpenOnHover", mouseThreshold: "mouseThreshold" }, outputs: { askDropdownOnClose: "askDropdownOnClose" }, host: { listeners: { "mouseenter": "showOnHoverIn()", "click": "show()" } }, ngImport: i0 }); }
93
131
  }
94
132
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.6", ngImport: i0, type: AskDropdownDirective, decorators: [{
95
133
  type: Directive,
@@ -104,10 +142,17 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.6", ngImpor
104
142
  type: Input
105
143
  }], dropdownDisabled: [{
106
144
  type: Input
145
+ }], dropdownOpenOnHover: [{
146
+ type: Input
147
+ }], mouseThreshold: [{
148
+ type: Input
107
149
  }], askDropdownOnClose: [{
108
150
  type: Output
151
+ }], showOnHoverIn: [{
152
+ type: HostListener,
153
+ args: ['mouseenter']
109
154
  }], show: [{
110
155
  type: HostListener,
111
156
  args: ['click']
112
157
  }] } });
113
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ask-dropdown.directive.js","sourceRoot":"","sources":["../../../../../projects/asksuite-citrus/src/lib/directives/ask-dropdown.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  ComponentRef,\n  DestroyRef,\n  Directive,\n  ElementRef,\n  EventEmitter,\n  HostListener,\n  inject,\n  Input,\n  OnInit,\n  Output,\n  TemplateRef\n} from '@angular/core';\nimport {DropdownContainerComponent} from \"../components/dropdown-container/dropdown-container.component\";\nimport {ConnectedPosition, Overlay, OverlayConfig, OverlayPositionBuilder, OverlayRef} from \"@angular/cdk/overlay\";\nimport {ComponentPortal} from \"@angular/cdk/portal\";\nimport {takeUntilDestroyed} from \"@angular/core/rxjs-interop\";\n\n@Directive({\n  selector: '[askDropdown]'\n})\nexport class AskDropdownDirective implements OnInit {\n\n  @Input() askDropdown?: TemplateRef<any>;\n  @Input() dropdownName = '';\n  @Input() positions?: Array<ConnectedPosition> | 'TOP_RIGHT' | 'TOP_LEFT' | 'BOTTOM_RIGHT' | 'BOTTOM_LEFT';\n  @Input() dropdownDisabled = false;\n\n  @Output() askDropdownOnClose = new EventEmitter();\n\n  private _isRendered: boolean = false;\n  private overlayConfig: OverlayConfig = {};\n  private overlayRef!: OverlayRef;\n  private containerRef!: ComponentRef<DropdownContainerComponent> | undefined;\n\n  private readonly AVAILABLE_POSITIONS: { TOP_RIGHT: ConnectedPosition; TOP_LEFT: ConnectedPosition; BOTTOM_RIGHT: ConnectedPosition; BOTTOM_LEFT: ConnectedPosition; } = {\n    TOP_RIGHT: { panelClass: 'ask-dropdown-top-right', originX: 'end', originY: 'top', overlayX: 'start', overlayY: 'top' },\n    TOP_LEFT: { panelClass: 'ask-dropdown-top-left', originX: 'start', originY: 'top', overlayX: 'end', overlayY: 'top' },\n    BOTTOM_RIGHT: { panelClass: 'ask-dropdown-bottom-right', originX: 'end', originY: 'bottom', overlayX: 'end', overlayY: 'top' },\n    BOTTOM_LEFT: { panelClass: 'ask-dropdown-bottom-left', originX: 'start', originY: 'bottom', overlayX: 'start', overlayY: 'top' },\n  }\n\n  constructor(\n    private overlayPositionBuilder: OverlayPositionBuilder,\n    private elementRef: ElementRef,\n    private overlay: Overlay,\n    private _destroyRef: DestroyRef,\n  ) { }\n\n  ngOnInit() {\n    this.setOverlayConfig();\n    this.createOverlay();\n    this.listenOutsideClicks();\n  }\n\n  private setOverlayConfig() {\n    const positionStrategy = this.overlayPositionBuilder\n      .flexibleConnectedTo(this.elementRef)\n      .withPositions(this.getOverlayPosition());\n\n    const scrollStrategy = this.overlay.scrollStrategies.block();\n\n    this.overlayConfig = {\n      hasBackdrop: true,\n      backdropClass: 'cdk-overlay-transparent-backdrop',\n      positionStrategy,\n      scrollStrategy\n    };\n  }\n\n  private createOverlay() {\n    this.overlayRef = this.overlay.create(this.overlayConfig);\n  }\n\n  private getOverlayPosition(): ConnectedPosition[] {\n    if (this.positions) {\n      let chosenPositions: Array<ConnectedPosition> = [];\n\n      if (typeof this.positions === 'string') {\n        chosenPositions.push(this.AVAILABLE_POSITIONS[this.positions]);\n      }\n\n      else if (Array.isArray(this.positions)) {\n        chosenPositions = [...this.positions];\n      }\n\n      chosenPositions = chosenPositions.filter(p => !!p);\n\n      if (chosenPositions.length) return chosenPositions;\n    }\n\n    return [\n      this.AVAILABLE_POSITIONS.BOTTOM_RIGHT,\n      this.AVAILABLE_POSITIONS.BOTTOM_LEFT,\n      this.AVAILABLE_POSITIONS.TOP_RIGHT,\n      this.AVAILABLE_POSITIONS.TOP_LEFT,\n    ]\n  }\n\n  private listenOutsideClicks() {\n    this.overlayRef.backdropClick()\n      .pipe(takeUntilDestroyed(this._destroyRef))\n      .subscribe((event) => {\n      this.close();\n      event.stopPropagation()\n    })\n  }\n\n  @HostListener('click')\n  public show() {\n    if (!this.askDropdown || this.isRendered || this.dropdownDisabled ) {\n      this.close();\n      return;\n    }\n\n    this.containerRef = this.overlayRef.attach(new ComponentPortal(DropdownContainerComponent));\n    this.containerRef.instance.content = this.askDropdown;\n    this._isRendered = true;\n  }\n\n  public close() {\n    this.containerRef = undefined;\n    this.overlayRef.detach();\n    this._isRendered = false;\n    this.askDropdownOnClose.emit();\n  }\n\n  public get isRendered() {\n    return this._isRendered;\n  }\n\n}\n"]}
158
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ask-dropdown.directive.js","sourceRoot":"","sources":["../../../../../projects/asksuite-citrus/src/lib/directives/ask-dropdown.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  ComponentRef,\n  DestroyRef,\n  Directive,\n  ElementRef,\n  EventEmitter,\n  HostListener,\n  inject,\n  Input,\n  OnInit,\n  Output,\n  TemplateRef\n} from '@angular/core';\nimport {DropdownContainerComponent} from \"../components/dropdown-container/dropdown-container.component\";\nimport {ConnectedPosition, Overlay, OverlayConfig, OverlayPositionBuilder, OverlayRef} from \"@angular/cdk/overlay\";\nimport {ComponentPortal} from \"@angular/cdk/portal\";\nimport {takeUntilDestroyed} from \"@angular/core/rxjs-interop\";\nimport {fromEvent, Observable, Subscription} from \"rxjs\";\n\n@Directive({\n  selector: '[askDropdown]'\n})\nexport class AskDropdownDirective implements OnInit {\n\n  @Input() askDropdown?: TemplateRef<any>;\n  @Input() dropdownName = '';\n  @Input() positions?: Array<ConnectedPosition> | 'TOP_RIGHT' | 'TOP_LEFT' | 'BOTTOM_RIGHT' | 'BOTTOM_LEFT';\n  @Input() dropdownDisabled = false;\n  @Input() dropdownOpenOnHover: boolean = false;\n  @Input() mouseThreshold = 300;\n  @Output() askDropdownOnClose = new EventEmitter();\n  private mouseLocation: {mouseX: number; mouseY: number} = {mouseX: 0, mouseY: 0};\n  private _isRendered: boolean = false;\n  private overlayConfig: OverlayConfig = {};\n  private overlayRef!: OverlayRef;\n  private containerRef!: ComponentRef<DropdownContainerComponent> | undefined;\n  private mouseOutSubscription?: Subscription;\n  private mouseDistanceSubscription?: Subscription;\n\n  private readonly AVAILABLE_POSITIONS: { TOP_RIGHT: ConnectedPosition; TOP_LEFT: ConnectedPosition; BOTTOM_RIGHT: ConnectedPosition; BOTTOM_LEFT: ConnectedPosition; } = {\n    TOP_RIGHT: { panelClass: 'ask-dropdown-top-right', originX: 'end', originY: 'top', overlayX: 'start', overlayY: 'top' },\n    TOP_LEFT: { panelClass: 'ask-dropdown-top-left', originX: 'start', originY: 'top', overlayX: 'end', overlayY: 'top' },\n    BOTTOM_RIGHT: { panelClass: 'ask-dropdown-bottom-right', originX: 'end', originY: 'bottom', overlayX: 'end', overlayY: 'top' },\n    BOTTOM_LEFT: { panelClass: 'ask-dropdown-bottom-left', originX: 'start', originY: 'bottom', overlayX: 'start', overlayY: 'top' },\n  }\n\n  constructor(\n    private overlayPositionBuilder: OverlayPositionBuilder,\n    private elementRef: ElementRef,\n    private overlay: Overlay,\n    private _destroyRef: DestroyRef,\n  ) { }\n\n  ngOnInit() {\n    this.setOverlayConfig();\n    this.createOverlay();\n    this.listenOutsideClicks();\n  }\n\n  private setOverlayConfig() {\n    const positionStrategy = this.overlayPositionBuilder\n      .flexibleConnectedTo(this.elementRef)\n      .withPositions(this.getOverlayPosition());\n\n    const scrollStrategy = this.overlay.scrollStrategies.reposition();\n\n    this.overlayConfig = {\n      hasBackdrop: true,\n      backdropClass: 'cdk-overlay-transparent-backdrop',\n      positionStrategy,\n      scrollStrategy\n    };\n  }\n\n  private createOverlay() {\n    this.overlayRef = this.overlay.create(this.overlayConfig);\n  }\n\n  private getOverlayPosition(): ConnectedPosition[] {\n    if (this.positions) {\n      let chosenPositions: Array<ConnectedPosition> = [];\n\n      if (typeof this.positions === 'string') {\n        chosenPositions.push(this.AVAILABLE_POSITIONS[this.positions]);\n      }\n\n      else if (Array.isArray(this.positions)) {\n        chosenPositions = [...this.positions];\n      }\n\n      chosenPositions = chosenPositions.filter(p => !!p);\n\n      if (chosenPositions.length) return chosenPositions;\n    }\n\n    return [\n      this.AVAILABLE_POSITIONS.BOTTOM_RIGHT,\n      this.AVAILABLE_POSITIONS.BOTTOM_LEFT,\n      this.AVAILABLE_POSITIONS.TOP_RIGHT,\n      this.AVAILABLE_POSITIONS.TOP_LEFT,\n    ]\n  }\n\n  private listenOutsideClicks() {\n    this.overlayRef.backdropClick()\n      .pipe(takeUntilDestroyed(this._destroyRef))\n      .subscribe((event) => {\n      this.close();\n      event.stopPropagation()\n    })\n  }\n\n  @HostListener('mouseenter')\n  public showOnHoverIn() {\n    if (this.dropdownOpenOnHover) {\n\n      this.show();\n      this.mouseLocation = this.onMouseMove(event)\n      this.mouseDistanceSubscription = fromEvent(document.body, 'mousemove').subscribe((e: any) => {\n\n        const mouseYCloseOn = Math.abs(this.mouseLocation.mouseY - e.pageY) <= this.mouseThreshold;\n        const mouseXCloseOn = Math.abs(this.mouseLocation.mouseX - e.pageX) <= this.mouseThreshold;\n        if (!(mouseYCloseOn && mouseXCloseOn)){\n          this.close();\n\n        }\n      });\n    }\n  }\n  @HostListener('click')\n  public show() {\n    if (!this.askDropdown || this.isRendered || this.dropdownDisabled ) {\n      this.close();\n      return;\n    }\n\n    this.containerRef = this.overlayRef.attach(new ComponentPortal(DropdownContainerComponent));\n    this.containerRef.instance.content = this.askDropdown;\n    if (this.dropdownOpenOnHover) {\n      this.mouseOutSubscription = fromEvent(this.containerRef.location.nativeElement, 'mouseout')\n        .subscribe((event: any) => {\n          if (event.relatedTarget?.classList.contains('cdk-overlay-backdrop')) {\n            this.close();\n          }\n        });\n    }\n    this._isRendered = true;\n  }\n  public onMouseMove(event: any): {mouseX: number; mouseY: number} {\n    const location = {\n      mouseX: event.clientX,\n      mouseY: event.pageY\n    }\n\n    return location;\n  }\n  public close() {\n    this.containerRef = undefined;\n    this.overlayRef.detach();\n    this._isRendered = false;\n    this.askDropdownOnClose.emit();\n\n    if (this.mouseOutSubscription) {\n      this.mouseOutSubscription.unsubscribe();\n    }\n    if (this.mouseDistanceSubscription) {\n      this.mouseDistanceSubscription.unsubscribe();\n    }\n  }\n\n  public get isRendered() {\n    return this._isRendered;\n  }\n\n}\n"]}
@@ -6,7 +6,7 @@ import * as i1$2 from '@angular/material/tooltip';
6
6
  import { MatTooltip, MatTooltipModule } from '@angular/material/tooltip';
7
7
  import * as i1$1 from '@angular/forms';
8
8
  import { NG_VALUE_ACCESSOR, FormControl, FormsModule, ReactiveFormsModule } from '@angular/forms';
9
- import { debounceTime, tap, map, Subject } from 'rxjs';
9
+ import { debounceTime, tap, map, fromEvent, Subject } from 'rxjs';
10
10
  import { TemplatePortal, ComponentPortal } from '@angular/cdk/portal';
11
11
  import { takeUntilDestroyed } from '@angular/core/rxjs-interop';
12
12
  import * as i1$3 from '@angular/cdk/overlay';
@@ -1592,7 +1592,10 @@ class AskDropdownDirective {
1592
1592
  this._destroyRef = _destroyRef;
1593
1593
  this.dropdownName = '';
1594
1594
  this.dropdownDisabled = false;
1595
+ this.dropdownOpenOnHover = false;
1596
+ this.mouseThreshold = 300;
1595
1597
  this.askDropdownOnClose = new EventEmitter();
1598
+ this.mouseLocation = { mouseX: 0, mouseY: 0 };
1596
1599
  this._isRendered = false;
1597
1600
  this.overlayConfig = {};
1598
1601
  this.AVAILABLE_POSITIONS = {
@@ -1611,7 +1614,7 @@ class AskDropdownDirective {
1611
1614
  const positionStrategy = this.overlayPositionBuilder
1612
1615
  .flexibleConnectedTo(this.elementRef)
1613
1616
  .withPositions(this.getOverlayPosition());
1614
- const scrollStrategy = this.overlay.scrollStrategies.block();
1617
+ const scrollStrategy = this.overlay.scrollStrategies.reposition();
1615
1618
  this.overlayConfig = {
1616
1619
  hasBackdrop: true,
1617
1620
  backdropClass: 'cdk-overlay-transparent-backdrop',
@@ -1650,6 +1653,19 @@ class AskDropdownDirective {
1650
1653
  event.stopPropagation();
1651
1654
  });
1652
1655
  }
1656
+ showOnHoverIn() {
1657
+ if (this.dropdownOpenOnHover) {
1658
+ this.show();
1659
+ this.mouseLocation = this.onMouseMove(event);
1660
+ this.mouseDistanceSubscription = fromEvent(document.body, 'mousemove').subscribe((e) => {
1661
+ const mouseYCloseOn = Math.abs(this.mouseLocation.mouseY - e.pageY) <= this.mouseThreshold;
1662
+ const mouseXCloseOn = Math.abs(this.mouseLocation.mouseX - e.pageX) <= this.mouseThreshold;
1663
+ if (!(mouseYCloseOn && mouseXCloseOn)) {
1664
+ this.close();
1665
+ }
1666
+ });
1667
+ }
1668
+ }
1653
1669
  show() {
1654
1670
  if (!this.askDropdown || this.isRendered || this.dropdownDisabled) {
1655
1671
  this.close();
@@ -1657,19 +1673,40 @@ class AskDropdownDirective {
1657
1673
  }
1658
1674
  this.containerRef = this.overlayRef.attach(new ComponentPortal(DropdownContainerComponent));
1659
1675
  this.containerRef.instance.content = this.askDropdown;
1676
+ if (this.dropdownOpenOnHover) {
1677
+ this.mouseOutSubscription = fromEvent(this.containerRef.location.nativeElement, 'mouseout')
1678
+ .subscribe((event) => {
1679
+ if (event.relatedTarget?.classList.contains('cdk-overlay-backdrop')) {
1680
+ this.close();
1681
+ }
1682
+ });
1683
+ }
1660
1684
  this._isRendered = true;
1661
1685
  }
1686
+ onMouseMove(event) {
1687
+ const location = {
1688
+ mouseX: event.clientX,
1689
+ mouseY: event.pageY
1690
+ };
1691
+ return location;
1692
+ }
1662
1693
  close() {
1663
1694
  this.containerRef = undefined;
1664
1695
  this.overlayRef.detach();
1665
1696
  this._isRendered = false;
1666
1697
  this.askDropdownOnClose.emit();
1698
+ if (this.mouseOutSubscription) {
1699
+ this.mouseOutSubscription.unsubscribe();
1700
+ }
1701
+ if (this.mouseDistanceSubscription) {
1702
+ this.mouseDistanceSubscription.unsubscribe();
1703
+ }
1667
1704
  }
1668
1705
  get isRendered() {
1669
1706
  return this._isRendered;
1670
1707
  }
1671
1708
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.6", ngImport: i0, type: AskDropdownDirective, deps: [{ token: i1$3.OverlayPositionBuilder }, { token: i0.ElementRef }, { token: i1$3.Overlay }, { token: i0.DestroyRef }], target: i0.ɵɵFactoryTarget.Directive }); }
1672
- static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.1.6", type: AskDropdownDirective, selector: "[askDropdown]", inputs: { askDropdown: "askDropdown", dropdownName: "dropdownName", positions: "positions", dropdownDisabled: "dropdownDisabled" }, outputs: { askDropdownOnClose: "askDropdownOnClose" }, host: { listeners: { "click": "show()" } }, ngImport: i0 }); }
1709
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.1.6", type: AskDropdownDirective, selector: "[askDropdown]", inputs: { askDropdown: "askDropdown", dropdownName: "dropdownName", positions: "positions", dropdownDisabled: "dropdownDisabled", dropdownOpenOnHover: "dropdownOpenOnHover", mouseThreshold: "mouseThreshold" }, outputs: { askDropdownOnClose: "askDropdownOnClose" }, host: { listeners: { "mouseenter": "showOnHoverIn()", "click": "show()" } }, ngImport: i0 }); }
1673
1710
  }
1674
1711
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.6", ngImport: i0, type: AskDropdownDirective, decorators: [{
1675
1712
  type: Directive,
@@ -1684,8 +1721,15 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.6", ngImpor
1684
1721
  type: Input
1685
1722
  }], dropdownDisabled: [{
1686
1723
  type: Input
1724
+ }], dropdownOpenOnHover: [{
1725
+ type: Input
1726
+ }], mouseThreshold: [{
1727
+ type: Input
1687
1728
  }], askDropdownOnClose: [{
1688
1729
  type: Output
1730
+ }], showOnHoverIn: [{
1731
+ type: HostListener,
1732
+ args: ['mouseenter']
1689
1733
  }], show: [{
1690
1734
  type: HostListener,
1691
1735
  args: ['click']