asksuite-citrus 1.5.6 → 1.5.8

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.
@@ -32,9 +32,9 @@ export class InputComponent {
32
32
  onModelChange(newValue) {
33
33
  if (this.value !== newValue) {
34
34
  this.writeValue(newValue);
35
- this.onChange(newValue);
35
+ this.onChange && this.onChange(newValue);
36
36
  }
37
- this.onTouch();
37
+ this.onTouch && this.onTouch();
38
38
  }
39
39
  handleChange(event) {
40
40
  this.change.emit(event);
@@ -110,4 +110,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.6", ngImpor
110
110
  type: ViewChild,
111
111
  args: ['inputElement', { static: true }]
112
112
  }] } });
113
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input.component.js","sourceRoot":"","sources":["../../../../../../projects/asksuite-citrus/src/lib/components/input/input.component.ts","../../../../../../projects/asksuite-citrus/src/lib/components/input/input.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  ElementRef,\n  EventEmitter,\n  forwardRef,\n  Input,\n  OnInit,\n  Output,\n  Provider,\n  ViewChild,\n} from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\n\nconst valueAccessor: Provider = {\n  provide: NG_VALUE_ACCESSOR,\n  multi: true,\n  useExisting: forwardRef(() => InputComponent),\n};\n\n@Component({\n  selector: 'ask-input',\n  templateUrl: './input.component.html',\n  styleUrls: ['./input.component.scss'],\n  providers: [valueAccessor],\n})\nexport class InputComponent implements ControlValueAccessor {\n  _iconColor = '';\n\n  @Input() value: string = '';\n  @Input() type: 'text' | 'email' | 'password' = 'text';\n  @Input() variation: 'filled' | 'outlined' = 'outlined'\n  @Input() placeholder!: string;\n  @Input() leftIcon?: string;\n  @Input() rightIcon?: string;\n  @Input() disabled: boolean = false;\n  @Input() noBorder: boolean = false;\n\n\n  @Input() set iconColor(color: string) {\n    this._iconColor = `var(--${color})`;\n  }\n\n  @Output() valueChange = new EventEmitter<string>();\n  @Output() change = new EventEmitter<Event>();\n  @Output() input = new EventEmitter<Event>();\n  @Output() click = new EventEmitter<MouseEvent>();\n  @Output() focus = new EventEmitter<FocusEvent>();\n  @Output() blur = new EventEmitter<FocusEvent>();\n  @Output() leftIconClick = new EventEmitter<MouseEvent>();\n  @Output() rightIconClick = new EventEmitter<MouseEvent>();\n\n  onChange!: (value?: any) => void;\n  onTouch!: () => void;\n\n  isFocused = false;\n\n  @ViewChild('inputElement', { static: true }) inputElement!: ElementRef;\n\n\n  onModelChange(newValue: string) {\n    if (this.value !== newValue) {\n      this.writeValue(newValue);\n      this.onChange(newValue);\n    }\n    this.onTouch();\n  }\n\n  handleChange(event: Event) {\n    this.change.emit(event);\n  }\n\n  handleInput(event: Event) {\n    this.input.emit(event);\n  }\n\n  handleFocus(event: FocusEvent) {\n    this.isFocused = true;\n    this.focus.emit(event);\n  }\n\n  handleBlur(event: FocusEvent) {\n    this.isFocused = false;\n    this.blur.emit(event);\n  }\n\n  /*\n   * Control value accessor methods\n   */\n\n  registerOnChange(fn: any): void {\n    this.onChange = fn;\n  }\n\n  registerOnTouched(fn: any): void {\n    this.onTouch = fn;\n  }\n\n  setDisabledState(isDisabled: boolean): void {\n    this.disabled = isDisabled;\n  }\n\n  writeValue(value: string): void {\n    this.value = value;\n    this.valueChange.emit(this.value);\n  }\n}\n","<div\n  class=\"input-container\"\n  [ngClass]=\"{\n    'focus': isFocused,\n    'disabled': disabled,\n    'left-icon': leftIcon,\n    'right-icon': rightIcon,\n  }\"\n  (click)=\"inputElement.focus()\"\n>\n  <span\n    *ngIf=\"leftIcon\"\n    class=\"material-icons icon-left\"\n    [style.color]=\"_iconColor\"\n    (click)=\"leftIconClick.emit($event)\"\n  >\n    {{ leftIcon }}\n  </span>\n\n  <input\n    #inputElement\n    class=\"ask-input\"\n    [class.-no-border]=\"noBorder\"\n    [class.-filled]=\"variation === 'filled'\"\n    [type]=\"type\"\n    [placeholder]=\"placeholder || ''\"\n    (click)=\"click.emit($event)\"\n    (focus)=\"handleFocus($event)\"\n    (blur)=\"handleBlur($event)\"\n    (change)=\"handleChange($event)\"\n    (input)=\"handleInput($event)\"\n    [disabled]=\"disabled\"\n    [ngModel]=\"value\"\n    (ngModelChange)=\"onModelChange($event)\"\n  />\n\n  <span\n    *ngIf=\"rightIcon\"\n    class=\"material-icons icon-right\"\n    [style.color]=\"_iconColor\"\n    (click)=\"rightIconClick.emit($event)\"\n  >\n    {{ rightIcon }}\n  </span>\n</div>\n"]}
113
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input.component.js","sourceRoot":"","sources":["../../../../../../projects/asksuite-citrus/src/lib/components/input/input.component.ts","../../../../../../projects/asksuite-citrus/src/lib/components/input/input.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  ElementRef,\n  EventEmitter,\n  forwardRef,\n  Input,\n  OnInit,\n  Output,\n  Provider,\n  ViewChild,\n} from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\n\nconst valueAccessor: Provider = {\n  provide: NG_VALUE_ACCESSOR,\n  multi: true,\n  useExisting: forwardRef(() => InputComponent),\n};\n\n@Component({\n  selector: 'ask-input',\n  templateUrl: './input.component.html',\n  styleUrls: ['./input.component.scss'],\n  providers: [valueAccessor],\n})\nexport class InputComponent implements ControlValueAccessor {\n  _iconColor = '';\n\n  @Input() value: string = '';\n  @Input() type: 'text' | 'email' | 'password' = 'text';\n  @Input() variation: 'filled' | 'outlined' = 'outlined'\n  @Input() placeholder!: string;\n  @Input() leftIcon?: string;\n  @Input() rightIcon?: string;\n  @Input() disabled: boolean = false;\n  @Input() noBorder: boolean = false;\n\n\n  @Input() set iconColor(color: string) {\n    this._iconColor = `var(--${color})`;\n  }\n\n  @Output() valueChange = new EventEmitter<string>();\n  @Output() change = new EventEmitter<Event>();\n  @Output() input = new EventEmitter<Event>();\n  @Output() click = new EventEmitter<MouseEvent>();\n  @Output() focus = new EventEmitter<FocusEvent>();\n  @Output() blur = new EventEmitter<FocusEvent>();\n  @Output() leftIconClick = new EventEmitter<MouseEvent>();\n  @Output() rightIconClick = new EventEmitter<MouseEvent>();\n\n  onChange!: (value?: any) => void;\n  onTouch!: () => void;\n\n  isFocused = false;\n\n  @ViewChild('inputElement', { static: true }) inputElement!: ElementRef;\n\n\n  onModelChange(newValue: string) {\n    if (this.value !== newValue) {\n      this.writeValue(newValue);\n      this.onChange && this.onChange(newValue);\n    }\n    this.onTouch && this.onTouch();\n  }\n\n  handleChange(event: Event) {\n    this.change.emit(event);\n  }\n\n  handleInput(event: Event) {\n    this.input.emit(event);\n  }\n\n  handleFocus(event: FocusEvent) {\n    this.isFocused = true;\n    this.focus.emit(event);\n  }\n\n  handleBlur(event: FocusEvent) {\n    this.isFocused = false;\n    this.blur.emit(event);\n  }\n\n  /*\n   * Control value accessor methods\n   */\n\n  registerOnChange(fn: any): void {\n    this.onChange = fn;\n  }\n\n  registerOnTouched(fn: any): void {\n    this.onTouch = fn;\n  }\n\n  setDisabledState(isDisabled: boolean): void {\n    this.disabled = isDisabled;\n  }\n\n  writeValue(value: string): void {\n    this.value = value;\n    this.valueChange.emit(this.value);\n  }\n}\n","<div\n  class=\"input-container\"\n  [ngClass]=\"{\n    'focus': isFocused,\n    'disabled': disabled,\n    'left-icon': leftIcon,\n    'right-icon': rightIcon,\n  }\"\n  (click)=\"inputElement.focus()\"\n>\n  <span\n    *ngIf=\"leftIcon\"\n    class=\"material-icons icon-left\"\n    [style.color]=\"_iconColor\"\n    (click)=\"leftIconClick.emit($event)\"\n  >\n    {{ leftIcon }}\n  </span>\n\n  <input\n    #inputElement\n    class=\"ask-input\"\n    [class.-no-border]=\"noBorder\"\n    [class.-filled]=\"variation === 'filled'\"\n    [type]=\"type\"\n    [placeholder]=\"placeholder || ''\"\n    (click)=\"click.emit($event)\"\n    (focus)=\"handleFocus($event)\"\n    (blur)=\"handleBlur($event)\"\n    (change)=\"handleChange($event)\"\n    (input)=\"handleInput($event)\"\n    [disabled]=\"disabled\"\n    [ngModel]=\"value\"\n    (ngModelChange)=\"onModelChange($event)\"\n  />\n\n  <span\n    *ngIf=\"rightIcon\"\n    class=\"material-icons icon-right\"\n    [style.color]=\"_iconColor\"\n    (click)=\"rightIconClick.emit($event)\"\n  >\n    {{ rightIcon }}\n  </span>\n</div>\n"]}
@@ -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,6 +13,7 @@ export class AskDropdownDirective {
12
13
  this._destroyRef = _destroyRef;
13
14
  this.dropdownName = '';
14
15
  this.dropdownDisabled = false;
16
+ this.dropdownOpenOnHover = false;
15
17
  this.askDropdownOnClose = new EventEmitter();
16
18
  this._isRendered = false;
17
19
  this.overlayConfig = {};
@@ -31,7 +33,7 @@ export class AskDropdownDirective {
31
33
  const positionStrategy = this.overlayPositionBuilder
32
34
  .flexibleConnectedTo(this.elementRef)
33
35
  .withPositions(this.getOverlayPosition());
34
- const scrollStrategy = this.overlay.scrollStrategies.block();
36
+ const scrollStrategy = this.overlay.scrollStrategies.reposition();
35
37
  this.overlayConfig = {
36
38
  hasBackdrop: true,
37
39
  backdropClass: 'cdk-overlay-transparent-backdrop',
@@ -70,6 +72,11 @@ export class AskDropdownDirective {
70
72
  event.stopPropagation();
71
73
  });
72
74
  }
75
+ showOnHoverIn() {
76
+ if (this.dropdownOpenOnHover) {
77
+ this.show();
78
+ }
79
+ }
73
80
  show() {
74
81
  if (!this.askDropdown || this.isRendered || this.dropdownDisabled) {
75
82
  this.close();
@@ -77,6 +84,14 @@ export class AskDropdownDirective {
77
84
  }
78
85
  this.containerRef = this.overlayRef.attach(new ComponentPortal(DropdownContainerComponent));
79
86
  this.containerRef.instance.content = this.askDropdown;
87
+ if (this.dropdownOpenOnHover) {
88
+ this.mouseOutSubscription = fromEvent(this.containerRef.location.nativeElement, 'mouseout')
89
+ .subscribe((event) => {
90
+ if (event.relatedTarget?.classList.contains('cdk-overlay-backdrop')) {
91
+ this.close();
92
+ }
93
+ });
94
+ }
80
95
  this._isRendered = true;
81
96
  }
82
97
  close() {
@@ -84,12 +99,15 @@ export class AskDropdownDirective {
84
99
  this.overlayRef.detach();
85
100
  this._isRendered = false;
86
101
  this.askDropdownOnClose.emit();
102
+ if (this.mouseOutSubscription) {
103
+ this.mouseOutSubscription.unsubscribe();
104
+ }
87
105
  }
88
106
  get isRendered() {
89
107
  return this._isRendered;
90
108
  }
91
109
  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 }); }
110
+ 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" }, outputs: { askDropdownOnClose: "askDropdownOnClose" }, host: { listeners: { "mouseenter": "showOnHoverIn()", "click": "show()" } }, ngImport: i0 }); }
93
111
  }
94
112
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.6", ngImport: i0, type: AskDropdownDirective, decorators: [{
95
113
  type: Directive,
@@ -104,10 +122,15 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.6", ngImpor
104
122
  type: Input
105
123
  }], dropdownDisabled: [{
106
124
  type: Input
125
+ }], dropdownOpenOnHover: [{
126
+ type: Input
107
127
  }], askDropdownOnClose: [{
108
128
  type: Output
129
+ }], showOnHoverIn: [{
130
+ type: HostListener,
131
+ args: ['mouseenter']
109
132
  }], show: [{
110
133
  type: HostListener,
111
134
  args: ['click']
112
135
  }] } });
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"]}
136
+ //# 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":"AAAA,OAAO,EAGL,SAAS,EAET,YAAY,EACZ,YAAY,EAEZ,KAAK,EAEL,MAAM,EAEP,MAAM,eAAe,CAAC;AACvB,OAAO,EAAC,0BAA0B,EAAC,MAAM,+DAA+D,CAAC;AAEzG,OAAO,EAAC,eAAe,EAAC,MAAM,qBAAqB,CAAC;AACpD,OAAO,EAAC,kBAAkB,EAAC,MAAM,4BAA4B,CAAC;AAC9D,OAAO,EAAC,SAAS,EAAe,MAAM,MAAM,CAAC;;;AAK7C,MAAM,OAAO,oBAAoB;IAuB/B,YACU,sBAA8C,EAC9C,UAAsB,EACtB,OAAgB,EAChB,WAAuB;QAHvB,2BAAsB,GAAtB,sBAAsB,CAAwB;QAC9C,eAAU,GAAV,UAAU,CAAY;QACtB,YAAO,GAAP,OAAO,CAAS;QAChB,gBAAW,GAAX,WAAW,CAAY;QAxBxB,iBAAY,GAAG,EAAE,CAAC;QAElB,qBAAgB,GAAG,KAAK,CAAC;QACzB,wBAAmB,GAAY,KAAK,CAAC;QAEpC,uBAAkB,GAAG,IAAI,YAAY,EAAE,CAAC;QAE1C,gBAAW,GAAY,KAAK,CAAC;QAC7B,kBAAa,GAAkB,EAAE,CAAC;QAKzB,wBAAmB,GAAoI;YACtK,SAAS,EAAE,EAAE,UAAU,EAAE,wBAAwB,EAAE,OAAO,EAAE,KAAK,EAAE,OAAO,EAAE,KAAK,EAAE,QAAQ,EAAE,OAAO,EAAE,QAAQ,EAAE,KAAK,EAAE;YACvH,QAAQ,EAAE,EAAE,UAAU,EAAE,uBAAuB,EAAE,OAAO,EAAE,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,QAAQ,EAAE,KAAK,EAAE,QAAQ,EAAE,KAAK,EAAE;YACrH,YAAY,EAAE,EAAE,UAAU,EAAE,2BAA2B,EAAE,OAAO,EAAE,KAAK,EAAE,OAAO,EAAE,QAAQ,EAAE,QAAQ,EAAE,KAAK,EAAE,QAAQ,EAAE,KAAK,EAAE;YAC9H,WAAW,EAAE,EAAE,UAAU,EAAE,0BAA0B,EAAE,OAAO,EAAE,OAAO,EAAE,OAAO,EAAE,QAAQ,EAAE,QAAQ,EAAE,OAAO,EAAE,QAAQ,EAAE,KAAK,EAAE;SACjI,CAAA;IAOG,CAAC;IAEL,QAAQ;QACN,IAAI,CAAC,gBAAgB,EAAE,CAAC;QACxB,IAAI,CAAC,aAAa,EAAE,CAAC;QACrB,IAAI,CAAC,mBAAmB,EAAE,CAAC;IAC7B,CAAC;IAEO,gBAAgB;QACtB,MAAM,gBAAgB,GAAG,IAAI,CAAC,sBAAsB;aACjD,mBAAmB,CAAC,IAAI,CAAC,UAAU,CAAC;aACpC,aAAa,CAAC,IAAI,CAAC,kBAAkB,EAAE,CAAC,CAAC;QAE5C,MAAM,cAAc,GAAG,IAAI,CAAC,OAAO,CAAC,gBAAgB,CAAC,UAAU,EAAE,CAAC;QAElE,IAAI,CAAC,aAAa,GAAG;YACnB,WAAW,EAAE,IAAI;YACjB,aAAa,EAAE,kCAAkC;YACjD,gBAAgB;YAChB,cAAc;SACf,CAAC;IACJ,CAAC;IAEO,aAAa;QACnB,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;IAC5D,CAAC;IAEO,kBAAkB;QACxB,IAAI,IAAI,CAAC,SAAS,EAAE;YAClB,IAAI,eAAe,GAA6B,EAAE,CAAC;YAEnD,IAAI,OAAO,IAAI,CAAC,SAAS,KAAK,QAAQ,EAAE;gBACtC,eAAe,CAAC,IAAI,CAAC,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC;aAChE;iBAEI,IAAI,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,SAAS,CAAC,EAAE;gBACtC,eAAe,GAAG,CAAC,GAAG,IAAI,CAAC,SAAS,CAAC,CAAC;aACvC;YAED,eAAe,GAAG,eAAe,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;YAEnD,IAAI,eAAe,CAAC,MAAM;gBAAE,OAAO,eAAe,CAAC;SACpD;QAED,OAAO;YACL,IAAI,CAAC,mBAAmB,CAAC,YAAY;YACrC,IAAI,CAAC,mBAAmB,CAAC,WAAW;YACpC,IAAI,CAAC,mBAAmB,CAAC,SAAS;YAClC,IAAI,CAAC,mBAAmB,CAAC,QAAQ;SAClC,CAAA;IACH,CAAC;IAEO,mBAAmB;QACzB,IAAI,CAAC,UAAU,CAAC,aAAa,EAAE;aAC5B,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;aAC1C,SAAS,CAAC,CAAC,KAAK,EAAE,EAAE;YACrB,IAAI,CAAC,KAAK,EAAE,CAAC;YACb,KAAK,CAAC,eAAe,EAAE,CAAA;QACzB,CAAC,CAAC,CAAA;IACJ,CAAC;IAGM,aAAa;QAClB,IAAI,IAAI,CAAC,mBAAmB,EAAE;YAC5B,IAAI,CAAC,IAAI,EAAE,CAAC;SACb;IACH,CAAC;IAGM,IAAI;QACT,IAAI,CAAC,IAAI,CAAC,WAAW,IAAI,IAAI,CAAC,UAAU,IAAI,IAAI,CAAC,gBAAgB,EAAG;YAClE,IAAI,CAAC,KAAK,EAAE,CAAC;YACb,OAAO;SACR;QAED,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC,IAAI,eAAe,CAAC,0BAA0B,CAAC,CAAC,CAAC;QAC5F,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,OAAO,GAAG,IAAI,CAAC,WAAW,CAAC;QACtD,IAAI,IAAI,CAAC,mBAAmB,EAAE;YAC5B,IAAI,CAAC,oBAAoB,GAAG,SAAS,CAAC,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,aAAa,EAAE,UAAU,CAAC;iBACxF,SAAS,CAAC,CAAC,KAAU,EAAE,EAAE;gBACxB,IAAI,KAAK,CAAC,aAAa,EAAE,SAAS,CAAC,QAAQ,CAAC,sBAAsB,CAAC,EAAE;oBACnE,IAAI,CAAC,KAAK,EAAE,CAAC;iBACd;YACH,CAAC,CAAC,CAAC;SACN;QACD,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC;IAC1B,CAAC;IAEM,KAAK;QACV,IAAI,CAAC,YAAY,GAAG,SAAS,CAAC;QAC9B,IAAI,CAAC,UAAU,CAAC,MAAM,EAAE,CAAC;QACzB,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC;QACzB,IAAI,CAAC,kBAAkB,CAAC,IAAI,EAAE,CAAC;QAE/B,IAAI,IAAI,CAAC,oBAAoB,EAAE;YAC7B,IAAI,CAAC,oBAAoB,CAAC,WAAW,EAAE,CAAC;SACzC;IACH,CAAC;IAED,IAAW,UAAU;QACnB,OAAO,IAAI,CAAC,WAAW,CAAC;IAC1B,CAAC;8GAjIU,oBAAoB;kGAApB,oBAAoB;;2FAApB,oBAAoB;kBAHhC,SAAS;mBAAC;oBACT,QAAQ,EAAE,eAAe;iBAC1B;qLAGU,WAAW;sBAAnB,KAAK;gBACG,YAAY;sBAApB,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBACG,gBAAgB;sBAAxB,KAAK;gBACG,mBAAmB;sBAA3B,KAAK;gBAEI,kBAAkB;sBAA3B,MAAM;gBAkFA,aAAa;sBADnB,YAAY;uBAAC,YAAY;gBAQnB,IAAI;sBADV,YAAY;uBAAC,OAAO","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, 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\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  private mouseOutSubscription?: 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      this.show();\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\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  }\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';
@@ -96,9 +96,9 @@ class InputComponent {
96
96
  onModelChange(newValue) {
97
97
  if (this.value !== newValue) {
98
98
  this.writeValue(newValue);
99
- this.onChange(newValue);
99
+ this.onChange && this.onChange(newValue);
100
100
  }
101
- this.onTouch();
101
+ this.onTouch && this.onTouch();
102
102
  }
103
103
  handleChange(event) {
104
104
  this.change.emit(event);
@@ -1592,6 +1592,7 @@ class AskDropdownDirective {
1592
1592
  this._destroyRef = _destroyRef;
1593
1593
  this.dropdownName = '';
1594
1594
  this.dropdownDisabled = false;
1595
+ this.dropdownOpenOnHover = false;
1595
1596
  this.askDropdownOnClose = new EventEmitter();
1596
1597
  this._isRendered = false;
1597
1598
  this.overlayConfig = {};
@@ -1611,7 +1612,7 @@ class AskDropdownDirective {
1611
1612
  const positionStrategy = this.overlayPositionBuilder
1612
1613
  .flexibleConnectedTo(this.elementRef)
1613
1614
  .withPositions(this.getOverlayPosition());
1614
- const scrollStrategy = this.overlay.scrollStrategies.block();
1615
+ const scrollStrategy = this.overlay.scrollStrategies.reposition();
1615
1616
  this.overlayConfig = {
1616
1617
  hasBackdrop: true,
1617
1618
  backdropClass: 'cdk-overlay-transparent-backdrop',
@@ -1650,6 +1651,11 @@ class AskDropdownDirective {
1650
1651
  event.stopPropagation();
1651
1652
  });
1652
1653
  }
1654
+ showOnHoverIn() {
1655
+ if (this.dropdownOpenOnHover) {
1656
+ this.show();
1657
+ }
1658
+ }
1653
1659
  show() {
1654
1660
  if (!this.askDropdown || this.isRendered || this.dropdownDisabled) {
1655
1661
  this.close();
@@ -1657,6 +1663,14 @@ class AskDropdownDirective {
1657
1663
  }
1658
1664
  this.containerRef = this.overlayRef.attach(new ComponentPortal(DropdownContainerComponent));
1659
1665
  this.containerRef.instance.content = this.askDropdown;
1666
+ if (this.dropdownOpenOnHover) {
1667
+ this.mouseOutSubscription = fromEvent(this.containerRef.location.nativeElement, 'mouseout')
1668
+ .subscribe((event) => {
1669
+ if (event.relatedTarget?.classList.contains('cdk-overlay-backdrop')) {
1670
+ this.close();
1671
+ }
1672
+ });
1673
+ }
1660
1674
  this._isRendered = true;
1661
1675
  }
1662
1676
  close() {
@@ -1664,12 +1678,15 @@ class AskDropdownDirective {
1664
1678
  this.overlayRef.detach();
1665
1679
  this._isRendered = false;
1666
1680
  this.askDropdownOnClose.emit();
1681
+ if (this.mouseOutSubscription) {
1682
+ this.mouseOutSubscription.unsubscribe();
1683
+ }
1667
1684
  }
1668
1685
  get isRendered() {
1669
1686
  return this._isRendered;
1670
1687
  }
1671
1688
  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 }); }
1689
+ 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" }, outputs: { askDropdownOnClose: "askDropdownOnClose" }, host: { listeners: { "mouseenter": "showOnHoverIn()", "click": "show()" } }, ngImport: i0 }); }
1673
1690
  }
1674
1691
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.6", ngImport: i0, type: AskDropdownDirective, decorators: [{
1675
1692
  type: Directive,
@@ -1684,8 +1701,13 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.6", ngImpor
1684
1701
  type: Input
1685
1702
  }], dropdownDisabled: [{
1686
1703
  type: Input
1704
+ }], dropdownOpenOnHover: [{
1705
+ type: Input
1687
1706
  }], askDropdownOnClose: [{
1688
1707
  type: Output
1708
+ }], showOnHoverIn: [{
1709
+ type: HostListener,
1710
+ args: ['mouseenter']
1689
1711
  }], show: [{
1690
1712
  type: HostListener,
1691
1713
  args: ['click']