@colijnit/corecomponents_v12 12.2.11 → 12.2.12

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.
@@ -59,7 +59,8 @@ CoDialogComponent.decorators = [
59
59
  <div class="co-dialog-overlay" (click)="handleOverlayClick($event)"></div>
60
60
  <div class="co-dialog-placeholder">
61
61
  <div class="co-dialog-wrapper" [ngClass]="customCssClass ? customCssClass : undefined" @showHideDialog cdkDrag>
62
- <div class="dialog-header" *ngIf="!borderless" cdkDragHandle>
62
+ <div *ngIf="!borderless" class="dialog-drag-handle" cdkDragHandle></div>
63
+ <div class="dialog-header" *ngIf="!borderless">
63
64
  <div class="dialog-header-caption" *ngIf="headerTemplate">
64
65
  <ng-container [ngTemplateOutlet]="headerTemplate"></ng-container>
65
66
  </div>
@@ -109,4 +110,4 @@ CoDialogComponent.propDecorators = {
109
110
  mobile: [{ type: HostBinding, args: ['class.is-mobile',] }],
110
111
  ngOnInit: [{ type: HostBinding, args: ['@showHideCoDialog',] }]
111
112
  };
112
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"co-dialog.component.js","sourceRoot":"","sources":["../../../../../../projects/corecomponents/src/lib/components/co-dialog/co-dialog.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {Component, EventEmitter, HostBinding, HostListener, Input, OnInit, Output, TemplateRef, ViewEncapsulation} from '@angular/core';\nimport {CoreComponentsIcon} from '../../core/enum/core-components-icon.enum';\nimport {animate, animateChild, AnimationTriggerMetadata, query, state, style, transition, trigger} from '@angular/animations';\n\nexport const showHideDialog = [\n    window.innerWidth > 700 ?\n        trigger('showHideDialog', [\n            state('*', style({opacity: 1})),\n            state('void', style({opacity: 0})),\n            transition('void <=> *', animate(200))\n        ]) :\n        trigger('showHideDialog', [\n            state('*', style({bottom: 0})),\n            state('void', style({bottom: '-100%'})),\n            transition('void <=> *', animate(200))\n        ])\n]\n\n@Component({\n    selector: 'co-dialog',\n    template: `\n        <div class=\"co-dialog-overlay\" (click)=\"handleOverlayClick($event)\"></div>\n        <div class=\"co-dialog-placeholder\">\n            <div class=\"co-dialog-wrapper\" [ngClass]=\"customCssClass ? customCssClass : undefined\" @showHideDialog cdkDrag>\n                <div class=\"dialog-header\" *ngIf=\"!borderless\" cdkDragHandle>\n                    <div class=\"dialog-header-caption\" *ngIf=\"headerTemplate\">\n                        <ng-container [ngTemplateOutlet]=\"headerTemplate\"></ng-container>\n                    </div>\n                    <div class=\"dialog-close-button\" *ngIf=\"showCloseIcon\" (click)=\"handleCloseDialog($event)\">\n                        <co-icon [icon]=\"icons.CrossSkinny\"></co-icon>\n                    </div>\n                </div>\n                <div class=\"dialog-content co-small-scrollbar\" [ngClass]=\"customCssClass ? customCssClass : undefined\">\n                    <ng-content></ng-content>\n                </div>\n                <div class=\"dialog-footer\" *ngIf=\"footerTemplate\">\n                    <ng-container [ngTemplateOutlet]=\"footerTemplate\"></ng-container>\n                </div>\n            </div>\n        </div>\n    `,\n    animations: [\n        trigger('showHideCoDialog', [\n            transition('void => *', [\n                query('.co-dialog-overlay', style({opacity: 0})),\n                // query('.co-dialog-wrapper', style({bottom: '-100%'})),\n                query('.co-dialog-overlay', animate(200, style({opacity: 1}))),\n                query('@showHideDialog', animateChild())\n\n            ]),\n            transition('* => void', [\n                // query('.co-dialog-wrapper', style({bottom: 0})),\n                query('@showHideDialog', animateChild()),\n                query('.co-dialog-overlay', animate(200, style({opacity: 0})))\n            ]),\n        ]),\n        showHideDialog\n    ],\n    encapsulation: ViewEncapsulation.None\n})\nexport class CoDialogComponent implements OnInit {\n    public readonly icons: typeof CoreComponentsIcon = CoreComponentsIcon;\n\n    @Input()\n    public customCssClass: string;\n\n    @Input()\n    public headerTemplate: TemplateRef<any>;\n\n    @Input()\n    public footerTemplate: TemplateRef<any>;\n\n    @Input()\n    public showCloseIcon: boolean = true;\n\n    @Input()\n    public modal: boolean = false;\n\n    @HostBinding('class.borderless')\n    @Input()\n    public borderless: boolean = false;\n\n    @Output()\n    public readonly closeClick: EventEmitter<MouseEvent> = new EventEmitter<MouseEvent>();\n\n    @HostBinding('class.co-dialog')\n    public showClass(): boolean {\n        return true;\n    }\n\n    @HostListener('window:keydown', ['$event'])\n    public handleKeyDown(event: KeyboardEvent): void {\n        switch (event.code) {\n            case 'Escape':\n                this.handleCloseDialog();\n        }\n    }\n\n    @HostBinding('class.is-touch')\n    public isTouch: boolean = false;\n\n    @HostBinding('class.is-mobile')\n    public mobile: boolean = false;\n\n    public state: string = 'closed';\n\n    @HostBinding('@showHideCoDialog')\n\n    ngOnInit(): void {\n        this._checkDevice();\n    }\n\n    public handleCloseDialog(event?: MouseEvent): void {\n        this.closeClick.emit(event);\n    }\n\n    public handleOverlayClick(event: MouseEvent): void {\n        if (!this.modal) {\n            this.closeClick.emit(event);\n        }\n    }\n\n    private _checkDevice(): void {\n        this.isTouch = ('ontouchstart' in window) ||\n            (navigator.maxTouchPoints > 0) ||\n            (navigator.msMaxTouchPoints > 0);\n        this.mobile = window.innerWidth < 700;\n    }\n}\n"]}
113
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"co-dialog.component.js","sourceRoot":"","sources":["../../../../../../projects/corecomponents/src/lib/components/co-dialog/co-dialog.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {Component, EventEmitter, HostBinding, HostListener, Input, OnInit, Output, TemplateRef, ViewEncapsulation} from '@angular/core';\nimport {CoreComponentsIcon} from '../../core/enum/core-components-icon.enum';\nimport {animate, animateChild, AnimationTriggerMetadata, query, state, style, transition, trigger} from '@angular/animations';\n\nexport const showHideDialog = [\n    window.innerWidth > 700 ?\n        trigger('showHideDialog', [\n            state('*', style({opacity: 1})),\n            state('void', style({opacity: 0})),\n            transition('void <=> *', animate(200))\n        ]) :\n        trigger('showHideDialog', [\n            state('*', style({bottom: 0})),\n            state('void', style({bottom: '-100%'})),\n            transition('void <=> *', animate(200))\n        ])\n]\n\n@Component({\n    selector: 'co-dialog',\n    template: `\n        <div class=\"co-dialog-overlay\" (click)=\"handleOverlayClick($event)\"></div>\n        <div class=\"co-dialog-placeholder\">\n            <div class=\"co-dialog-wrapper\" [ngClass]=\"customCssClass ? customCssClass : undefined\" @showHideDialog cdkDrag>\n                <div *ngIf=\"!borderless\" class=\"dialog-drag-handle\" cdkDragHandle></div>\n                <div class=\"dialog-header\" *ngIf=\"!borderless\">\n                    <div class=\"dialog-header-caption\" *ngIf=\"headerTemplate\">\n                        <ng-container [ngTemplateOutlet]=\"headerTemplate\"></ng-container>\n                    </div>\n                    <div class=\"dialog-close-button\" *ngIf=\"showCloseIcon\" (click)=\"handleCloseDialog($event)\">\n                        <co-icon [icon]=\"icons.CrossSkinny\"></co-icon>\n                    </div>\n                </div>\n                <div class=\"dialog-content co-small-scrollbar\" [ngClass]=\"customCssClass ? customCssClass : undefined\">\n                    <ng-content></ng-content>\n                </div>\n                <div class=\"dialog-footer\" *ngIf=\"footerTemplate\">\n                    <ng-container [ngTemplateOutlet]=\"footerTemplate\"></ng-container>\n                </div>\n            </div>\n        </div>\n    `,\n    animations: [\n        trigger('showHideCoDialog', [\n            transition('void => *', [\n                query('.co-dialog-overlay', style({opacity: 0})),\n                // query('.co-dialog-wrapper', style({bottom: '-100%'})),\n                query('.co-dialog-overlay', animate(200, style({opacity: 1}))),\n                query('@showHideDialog', animateChild())\n\n            ]),\n            transition('* => void', [\n                // query('.co-dialog-wrapper', style({bottom: 0})),\n                query('@showHideDialog', animateChild()),\n                query('.co-dialog-overlay', animate(200, style({opacity: 0})))\n            ]),\n        ]),\n        showHideDialog\n    ],\n    encapsulation: ViewEncapsulation.None\n})\nexport class CoDialogComponent implements OnInit {\n    public readonly icons: typeof CoreComponentsIcon = CoreComponentsIcon;\n\n    @Input()\n    public customCssClass: string;\n\n    @Input()\n    public headerTemplate: TemplateRef<any>;\n\n    @Input()\n    public footerTemplate: TemplateRef<any>;\n\n    @Input()\n    public showCloseIcon: boolean = true;\n\n    @Input()\n    public modal: boolean = false;\n\n    @HostBinding('class.borderless')\n    @Input()\n    public borderless: boolean = false;\n\n    @Output()\n    public readonly closeClick: EventEmitter<MouseEvent> = new EventEmitter<MouseEvent>();\n\n    @HostBinding('class.co-dialog')\n    public showClass(): boolean {\n        return true;\n    }\n\n    @HostListener('window:keydown', ['$event'])\n    public handleKeyDown(event: KeyboardEvent): void {\n        switch (event.code) {\n            case 'Escape':\n                this.handleCloseDialog();\n        }\n    }\n\n    @HostBinding('class.is-touch')\n    public isTouch: boolean = false;\n\n    @HostBinding('class.is-mobile')\n    public mobile: boolean = false;\n\n    public state: string = 'closed';\n\n    @HostBinding('@showHideCoDialog')\n\n    ngOnInit(): void {\n        this._checkDevice();\n    }\n\n    public handleCloseDialog(event?: MouseEvent): void {\n        this.closeClick.emit(event);\n    }\n\n    public handleOverlayClick(event: MouseEvent): void {\n        if (!this.modal) {\n            this.closeClick.emit(event);\n        }\n    }\n\n    private _checkDevice(): void {\n        this.isTouch = ('ontouchstart' in window) ||\n            (navigator.maxTouchPoints > 0) ||\n            (navigator.msMaxTouchPoints > 0);\n        this.mobile = window.innerWidth < 700;\n    }\n}\n"]}
@@ -1,4 +1,4 @@
1
- import { Component, forwardRef, HostBinding, ViewEncapsulation } from '@angular/core';
1
+ import { Component, forwardRef, HostBinding, ViewChild, ViewEncapsulation } from '@angular/core';
2
2
  import { SCREEN_CONFIG_ADAPTER_COMPONENT_INTERFACE_NAME } from '../../interfaces/screen-config-adapter-component-interface-name';
3
3
  import { OverlayService } from '../../service/overlay.service';
4
4
  import { BaseInputDatePickerDirective } from "../base-input-date-picker/base-input-date-picker.directive";
@@ -7,6 +7,12 @@ export class InputDateRangePickerComponent extends BaseInputDatePickerDirective
7
7
  showClass() {
8
8
  return true;
9
9
  }
10
+ handleFirstInputClick(event) {
11
+ event.stopPropagation();
12
+ }
13
+ handleSecondInputClick(event) {
14
+ event.stopPropagation();
15
+ }
10
16
  handleDatesSelected(dates) {
11
17
  this.setModel(dates);
12
18
  }
@@ -82,7 +88,7 @@ InputDateRangePickerComponent.decorators = [
82
88
  selector: 'co-input-date-range',
83
89
  template: `
84
90
  <div class="inputs-wrapper" overlayParent #parentForOverlay="overlayParent">
85
- <co-input-text class="no-focus-line custom-height"
91
+ <co-input-text #firstInput class="no-focus-line custom-height"
86
92
  [(model)]="firstDateAsString"
87
93
  [noClickFocus]="true"
88
94
  [pattern]="'yyyy-MM-dd'"
@@ -92,8 +98,9 @@ InputDateRangePickerComponent.decorators = [
92
98
  [placeholder]="placeholder"
93
99
  (blur)="handleFirstDateChanged(firstDateAsString)"
94
100
  (clearIconClick)="clearDate(0)"
101
+ (click)="handleFirstInputClick($event)"
95
102
  ></co-input-text>
96
- <co-input-text class="no-focus-line custom-height"
103
+ <co-input-text #secondInput class="no-focus-line custom-height"
97
104
  [(model)]= "secondDateAsString"
98
105
  [noClickFocus]="true"
99
106
  [pattern]="'yyyy-MM-dd'"
@@ -102,6 +109,7 @@ InputDateRangePickerComponent.decorators = [
102
109
  (rightIconClick)="toggleCalendar()"
103
110
  (blur)="handleSecondDateChanged(secondDateAsString)"
104
111
  (clearIconClick)="clearDate(1)"
112
+ (click)="handleSecondInputClick($event)"
105
113
  ></co-input-text>
106
114
  </div>
107
115
  `,
@@ -119,6 +127,8 @@ InputDateRangePickerComponent.decorators = [
119
127
  },] }
120
128
  ];
121
129
  InputDateRangePickerComponent.propDecorators = {
130
+ firstInput: [{ type: ViewChild, args: ['firstInput',] }],
131
+ secondInput: [{ type: ViewChild, args: ['secondInput',] }],
122
132
  showClass: [{ type: HostBinding, args: ['class.co-input-date-range',] }]
123
133
  };
124
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-date-range-picker.component.js","sourceRoot":"","sources":["../../../../../../projects/corecomponents/src/lib/components/input-date-range-picker/input-date-range-picker.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  ComponentRef,\r\n  EventEmitter,\r\n  forwardRef,\r\n  HostBinding,\r\n  Input,\r\n  Output,\r\n  ViewChild,\r\n  ViewEncapsulation\r\n} from '@angular/core';\r\nimport {BaseInputComponent} from '../base/base-input.component';\r\nimport {\r\n    SCREEN_CONFIG_ADAPTER_COMPONENT_INTERFACE_NAME\r\n} from '../../interfaces/screen-config-adapter-component-interface-name';\r\nimport {OverlayService} from '../../service/overlay.service';\r\nimport {BaseInputDatePickerDirective} from \"../base-input-date-picker/base-input-date-picker.directive\";\r\nimport {DoubleCalendarComponent} from \"../double-calendar/double-calendar.component\";\r\n\r\n@Component({\r\n    selector: 'co-input-date-range',\r\n    template: `\r\n      <div class=\"inputs-wrapper\" overlayParent #parentForOverlay=\"overlayParent\">\r\n        <co-input-text class=\"no-focus-line custom-height\"\r\n                       [(model)]=\"firstDateAsString\"\r\n                       [noClickFocus]=\"true\"\r\n                       [pattern]=\"'yyyy-MM-dd'\"\r\n                       [type]=\"'date'\"\r\n                       [leftIcon]=\"leftIcon\"\r\n                       [leftIconData]=\"leftIconData\"\r\n                       [placeholder]=\"placeholder\"\r\n                       (blur)=\"handleFirstDateChanged(firstDateAsString)\"\r\n                       (clearIconClick)=\"clearDate(0)\"\r\n        ></co-input-text>\r\n        <co-input-text class=\"no-focus-line custom-height\"\r\n                       [(model)]= \"secondDateAsString\"\r\n                       [noClickFocus]=\"true\"\r\n                       [pattern]=\"'yyyy-MM-dd'\"\r\n                       [type]=\"'date'\"\r\n                       [rightIcon]=\"rightIcon\"\r\n                       (rightIconClick)=\"toggleCalendar()\"\r\n                       (blur)=\"handleSecondDateChanged(secondDateAsString)\"\r\n                       (clearIconClick)=\"clearDate(1)\"\r\n        ></co-input-text>\r\n      </div>\r\n    `,\r\n    providers: [\r\n        OverlayService,\r\n        {\r\n            provide: SCREEN_CONFIG_ADAPTER_COMPONENT_INTERFACE_NAME,\r\n            useExisting: forwardRef(() => InputDateRangePickerComponent)\r\n        }, {\r\n            provide: BaseInputDatePickerDirective,\r\n            useExisting: InputDateRangePickerComponent\r\n        }],\r\n    encapsulation: ViewEncapsulation.None\r\n})\r\nexport class InputDateRangePickerComponent extends BaseInputDatePickerDirective {\r\n\r\n  public firstDateAsString;\r\n  public secondDateAsString;\r\n\r\n  private _doubleCalendarComponentRef: ComponentRef<DoubleCalendarComponent>;\r\n\r\n    @HostBinding('class.co-input-date-range')\r\n    public showClass(): boolean {\r\n        return true;\r\n    }\r\n\r\n  public handleDatesSelected(dates: Date[]): void {\r\n    this.setModel(dates);\r\n  }\r\n\r\n  public handleSecondDateSelected(): void {\r\n    if (this.closeAfterDateSelection) {\r\n      this.toggleCalendar();\r\n    }\r\n  }\r\n\r\n  public clearDate(index: number): void {\r\n      this.model[index] = undefined;\r\n  }\r\n\r\n  public toggleCalendar(): void {\r\n    if (this.readonly) {\r\n      return;\r\n    }\r\n\r\n    this.showCalendar = !this.showCalendar;\r\n\r\n    if (this.showCalendar) {\r\n      this._doubleCalendarComponentRef = this.overlayService.createComponent(DoubleCalendarComponent, {\r\n        parentForOverlay: this.parentForOverlay,\r\n        selectedDates: this.model\r\n      }, {\r\n        datesSelected: (event) => this.handleDatesSelected(event),\r\n        secondDateSelected: () => this.handleSecondDateSelected(),\r\n        clickedOutside: () => this.toggleCalendar()\r\n      });\r\n    } else {\r\n      this.overlayService.removeComponent(this._doubleCalendarComponentRef);\r\n    }\r\n  }\r\n\r\n  public handleFirstDateChanged(value: string): void {\r\n    if (value) {\r\n      if (!this.model) {\r\n        this.setModel([]);\r\n      }\r\n      this.setModel([new Date(value), this.model[1] ? this.model[1] : null]);\r\n    }\r\n  }\r\n\r\n  public handleSecondDateChanged(value: string): void {\r\n    if (value) {\r\n      if (!this.model) {\r\n        this.setModel([]);\r\n      }\r\n      this.setModel([this.model[0] ? this.model[0] : null, new Date(value)]);\r\n    }\r\n  }\r\n\r\n  protected modelSet(): void {\r\n    this.setModelAsString();\r\n  }\r\n\r\n  private setModelAsString(): void {\r\n    if (this.model[0]) {\r\n      const year = this.model[0].toLocaleString(\"default\", { year: \"numeric\" });\r\n      const month = this.model[0].toLocaleString(\"default\", { month: \"2-digit\" });\r\n      const day = this.model[0].toLocaleString(\"default\", { day: \"2-digit\" });\r\n      this.firstDateAsString = `${year}-${month}-${day}`;\r\n    } else {\r\n      this.firstDateAsString = ``;\r\n    }\r\n    if (this.model[1]) {\r\n      const year = this.model[1].toLocaleString(\"default\", { year: \"numeric\" });\r\n      const month = this.model[1].toLocaleString(\"default\", { month: \"2-digit\" });\r\n      const day = this.model[1].toLocaleString(\"default\", { day: \"2-digit\" });\r\n      this.secondDateAsString = `${year}-${month}-${day}`;\r\n    } else {\r\n      this.secondDateAsString = ``;\r\n    }\r\n  }\r\n}\r\n"]}
134
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-date-range-picker.component.js","sourceRoot":"","sources":["../../../../../../projects/corecomponents/src/lib/components/input-date-range-picker/input-date-range-picker.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  ComponentRef, ElementRef,\r\n  EventEmitter,\r\n  forwardRef,\r\n  HostBinding,\r\n  Input,\r\n  Output,\r\n  ViewChild,\r\n  ViewEncapsulation\r\n} from '@angular/core';\r\nimport {BaseInputComponent} from '../base/base-input.component';\r\nimport {\r\n    SCREEN_CONFIG_ADAPTER_COMPONENT_INTERFACE_NAME\r\n} from '../../interfaces/screen-config-adapter-component-interface-name';\r\nimport {OverlayService} from '../../service/overlay.service';\r\nimport {BaseInputDatePickerDirective} from \"../base-input-date-picker/base-input-date-picker.directive\";\r\nimport {DoubleCalendarComponent} from \"../double-calendar/double-calendar.component\";\r\n\r\n@Component({\r\n    selector: 'co-input-date-range',\r\n    template: `\r\n      <div class=\"inputs-wrapper\" overlayParent #parentForOverlay=\"overlayParent\">\r\n        <co-input-text #firstInput class=\"no-focus-line custom-height\"\r\n                       [(model)]=\"firstDateAsString\"\r\n                       [noClickFocus]=\"true\"\r\n                       [pattern]=\"'yyyy-MM-dd'\"\r\n                       [type]=\"'date'\"\r\n                       [leftIcon]=\"leftIcon\"\r\n                       [leftIconData]=\"leftIconData\"\r\n                       [placeholder]=\"placeholder\"\r\n                       (blur)=\"handleFirstDateChanged(firstDateAsString)\"\r\n                       (clearIconClick)=\"clearDate(0)\"\r\n                       (click)=\"handleFirstInputClick($event)\"\r\n        ></co-input-text>\r\n        <co-input-text #secondInput class=\"no-focus-line custom-height\"\r\n                       [(model)]= \"secondDateAsString\"\r\n                       [noClickFocus]=\"true\"\r\n                       [pattern]=\"'yyyy-MM-dd'\"\r\n                       [type]=\"'date'\"\r\n                       [rightIcon]=\"rightIcon\"\r\n                       (rightIconClick)=\"toggleCalendar()\"\r\n                       (blur)=\"handleSecondDateChanged(secondDateAsString)\"\r\n                       (clearIconClick)=\"clearDate(1)\"\r\n                       (click)=\"handleSecondInputClick($event)\"\r\n        ></co-input-text>\r\n      </div>\r\n    `,\r\n    providers: [\r\n        OverlayService,\r\n        {\r\n            provide: SCREEN_CONFIG_ADAPTER_COMPONENT_INTERFACE_NAME,\r\n            useExisting: forwardRef(() => InputDateRangePickerComponent)\r\n        }, {\r\n            provide: BaseInputDatePickerDirective,\r\n            useExisting: InputDateRangePickerComponent\r\n        }],\r\n    encapsulation: ViewEncapsulation.None\r\n})\r\nexport class InputDateRangePickerComponent extends BaseInputDatePickerDirective {\r\n\r\n  public firstDateAsString;\r\n  public secondDateAsString;\r\n\r\n  private _doubleCalendarComponentRef: ComponentRef<DoubleCalendarComponent>;\r\n\r\n  @ViewChild('firstInput') firstInput: ElementRef;\r\n  @ViewChild('secondInput') secondInput: ElementRef;\r\n    @HostBinding('class.co-input-date-range')\r\n    public showClass(): boolean {\r\n        return true;\r\n    }\r\n  handleFirstInputClick(event: Event): void {\r\n    event.stopPropagation();\r\n  }\r\n\r\n  handleSecondInputClick(event: Event): void {\r\n    event.stopPropagation();\r\n  }\r\n  public handleDatesSelected(dates: Date[]): void {\r\n    this.setModel(dates);\r\n  }\r\n\r\n  public handleSecondDateSelected(): void {\r\n    if (this.closeAfterDateSelection) {\r\n      this.toggleCalendar();\r\n    }\r\n  }\r\n\r\n  public clearDate(index: number): void {\r\n      this.model[index] = undefined;\r\n  }\r\n\r\n  public toggleCalendar(): void {\r\n    if (this.readonly) {\r\n      return;\r\n    }\r\n\r\n    this.showCalendar = !this.showCalendar;\r\n\r\n    if (this.showCalendar) {\r\n      this._doubleCalendarComponentRef = this.overlayService.createComponent(DoubleCalendarComponent, {\r\n        parentForOverlay: this.parentForOverlay,\r\n        selectedDates: this.model\r\n      }, {\r\n        datesSelected: (event) => this.handleDatesSelected(event),\r\n        secondDateSelected: () => this.handleSecondDateSelected(),\r\n        clickedOutside: () => this.toggleCalendar()\r\n      });\r\n    } else {\r\n      this.overlayService.removeComponent(this._doubleCalendarComponentRef);\r\n    }\r\n  }\r\n\r\n  public handleFirstDateChanged(value: string): void {\r\n    if (value) {\r\n      if (!this.model) {\r\n        this.setModel([]);\r\n      }\r\n      this.setModel([new Date(value), this.model[1] ? this.model[1] : null]);\r\n    }\r\n  }\r\n\r\n  public handleSecondDateChanged(value: string): void {\r\n    if (value) {\r\n      if (!this.model) {\r\n        this.setModel([]);\r\n      }\r\n      this.setModel([this.model[0] ? this.model[0] : null, new Date(value)]);\r\n    }\r\n  }\r\n\r\n  protected modelSet(): void {\r\n    this.setModelAsString();\r\n  }\r\n\r\n  private setModelAsString(): void {\r\n    if (this.model[0]) {\r\n      const year = this.model[0].toLocaleString(\"default\", { year: \"numeric\" });\r\n      const month = this.model[0].toLocaleString(\"default\", { month: \"2-digit\" });\r\n      const day = this.model[0].toLocaleString(\"default\", { day: \"2-digit\" });\r\n      this.firstDateAsString = `${year}-${month}-${day}`;\r\n    } else {\r\n      this.firstDateAsString = ``;\r\n    }\r\n    if (this.model[1]) {\r\n      const year = this.model[1].toLocaleString(\"default\", { year: \"numeric\" });\r\n      const month = this.model[1].toLocaleString(\"default\", { month: \"2-digit\" });\r\n      const day = this.model[1].toLocaleString(\"default\", { day: \"2-digit\" });\r\n      this.secondDateAsString = `${year}-${month}-${day}`;\r\n    } else {\r\n      this.secondDateAsString = ``;\r\n    }\r\n  }\r\n}\r\n"]}
@@ -1,4 +1,5 @@
1
1
  import { Directive, ElementRef, Input } from '@angular/core';
2
+ import { OverlayParentDirective } from './overlay-parent.directive';
2
3
  export class OverlayDirective {
3
4
  constructor(elementRef) {
4
5
  /**
@@ -17,7 +18,15 @@ export class OverlayDirective {
17
18
  }
18
19
  set parent(value) {
19
20
  if (value) {
20
- this._parent = value instanceof ElementRef ? value : value.elementRef;
21
+ if (value instanceof ElementRef) {
22
+ this._parent = value.nativeElement;
23
+ }
24
+ else if (value instanceof OverlayParentDirective) {
25
+ this._parent = value.elementRef.nativeElement;
26
+ }
27
+ else {
28
+ this._parent = value;
29
+ }
21
30
  }
22
31
  else {
23
32
  if (this._parent && this._resizeObserver) {
@@ -58,14 +67,14 @@ export class OverlayDirective {
58
67
  root: null
59
68
  });
60
69
  if (this._parent) {
61
- this._intersectionObserver.observe(this._parent.nativeElement); // observe parent for visibility
70
+ this._intersectionObserver.observe(this._parent); // observe parent for visibility
62
71
  }
63
72
  this._resizeObserver.observe(document.body);
64
73
  }
65
74
  _checkAndPlaceElement() {
66
- if (this._elementRef && this._elementRef.nativeElement && this._parent && this._parent.nativeElement) {
75
+ if (this._elementRef && this._elementRef.nativeElement && this._parent) {
67
76
  const elementRect = this._elementRef.nativeElement.getBoundingClientRect();
68
- const parentBoundingRect = this._parent.nativeElement.getBoundingClientRect();
77
+ const parentBoundingRect = this._parent.getBoundingClientRect();
69
78
  let parentRect = {};
70
79
  if (!this.inline) {
71
80
  parentRect = {
@@ -78,10 +87,10 @@ export class OverlayDirective {
78
87
  }
79
88
  else {
80
89
  parentRect = {
81
- bottom: this._parent.nativeElement.offsetTop + parentBoundingRect.height,
82
- right: this._parent.nativeElement.offsetLeft + parentBoundingRect.width,
83
- left: this._parent.nativeElement.offsetLeft,
84
- top: this._parent.nativeElement.offsetTop,
90
+ bottom: this._parent.offsetTop + parentBoundingRect.height,
91
+ right: this._parent.offsetLeft + parentBoundingRect.width,
92
+ left: this._parent.offsetLeft,
93
+ top: this._parent.offsetTop,
85
94
  width: parentBoundingRect.width
86
95
  };
87
96
  }
@@ -143,4 +152,4 @@ OverlayDirective.propDecorators = {
143
152
  rightAlign: [{ type: Input }],
144
153
  fullSize: [{ type: Input }]
145
154
  };
146
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"overlay.directive.js","sourceRoot":"","sources":["../../../../../../projects/corecomponents/src/lib/directives/overlay/overlay.directive.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,SAAS,EAAE,UAAU,EAAE,KAAK,EAAoB,MAAM,eAAe,CAAC;AAM9E,MAAM,OAAO,gBAAgB;IAwC3B,YACI,UAAsB;QAzB1B;;;WAGG;QAEI,WAAM,GAAY,KAAK,CAAC;QAGxB,eAAU,GAAY,KAAK,CAAC;QAG5B,iBAAY,GAAY,KAAK,CAAC;QAG9B,eAAU,GAAY,KAAK,CAAC;QAG5B,aAAQ,GAAY,KAAK,CAAC;QAuD1B,iBAAY,GAAG,CAAC,KAAY,EAAE,EAAE;YACrC,IAAI,CAAC,qBAAqB,EAAE,CAAC;QAC/B,CAAC,CAAA;QA/CC,IAAI,CAAC,WAAW,GAAG,UAAU,CAAC;IAChC,CAAC;IA1CD,IACW,MAAM,CAAC,KAA0C;QAC1D,IAAI,KAAK,EAAE;YACT,IAAI,CAAC,OAAO,GAAG,KAAK,YAAY,UAAU,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,UAAU,CAAC;SACvE;aAAM;YACL,IAAI,IAAI,CAAC,OAAO,IAAI,IAAI,CAAC,eAAe,EAAE;gBACxC,IAAI,CAAC,eAAe,CAAC,UAAU,EAAE,CAAC;aACnC;SACF;IACH,CAAC;IAmCM,WAAW;QAChB,QAAQ,CAAC,mBAAmB,CAAC,QAAQ,EAAE,IAAI,CAAC,YAAY,EAAE,IAAI,CAAC,CAAC;QAChE,IAAI,IAAI,CAAC,qBAAqB,EAAE;YAC9B,IAAI,CAAC,qBAAqB,CAAC,UAAU,EAAE,CAAC;SACzC;QACD,IAAI,IAAI,CAAC,eAAe,EAAE;YACxB,IAAI,CAAC,eAAe,CAAC,UAAU,EAAE,CAAC;SACnC;QACD,IAAI,CAAC,WAAW,GAAG,SAAS,CAAC;QAC7B,IAAI,CAAC,OAAO,GAAG,SAAS,CAAC;IAC3B,CAAC;IAED,QAAQ;QACN,IAAI,CAAC,IAAI,CAAC,WAAW,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,aAAa,EAAE;YACxD,OAAO;SACR;QACD,QAAQ,CAAC,gBAAgB,CAAC,QAAQ,EAAE,IAAI,CAAC,YAAY,EAAE,IAAI,CAAC,CAAC;QAC7D,IAAI,CAAC,qBAAqB,EAAE,CAAC;QAC7B,IAAI,CAAC,eAAe,GAAG,IAAI,cAAc,CACrC,CAAC,OAAO,EAAE,EAAE;YACV,IAAI,CAAC,qBAAqB,EAAE,CAAC;QAC/B,CAAC,CACJ,CAAC;QACF,IAAI,CAAC,qBAAqB,GAAG,IAAI,oBAAoB,CACjD,CAAC,OAAoC,EAAE,EAAE;YACvC,IAAI,OAAO,IAAI,OAAO,CAAC,MAAM,GAAG,CAAC,EAAE;gBACjC,IAAI,OAAO,CAAC,CAAC,CAAC,CAAC,cAAc,KAAK,KAAK,EAAE;oBACvC,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,KAAK,CAAC,OAAO,GAAG,CAAC,CAAC,CAAC,mCAAmC;iBACtF;qBAAM;oBACL,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,KAAK,CAAC,OAAO,GAAG,CAAC,CAAC;iBAClD;aACF;QACH,CAAC,EAAE;YACD,IAAI,EAAE,IAAI;SACX,CACJ,CAAC;QACF,IAAI,IAAI,CAAC,OAAO,EAAE;YAChB,IAAI,CAAC,qBAAqB,CAAC,OAAO,CAAC,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC,CAAC,CAAC,gCAAgC;SACjG;QACD,IAAI,CAAC,eAAe,CAAC,OAAO,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;IAC9C,CAAC;IAMO,qBAAqB;QAC3B,IAAI,IAAI,CAAC,WAAW,IAAI,IAAI,CAAC,WAAW,CAAC,aAAa,IAAI,IAAI,CAAC,OAAO,IAAI,IAAI,CAAC,OAAO,CAAC,aAAa,EAAE;YACpG,MAAM,WAAW,GAAe,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,qBAAqB,EAAE,CAAC;YACvF,MAAM,kBAAkB,GAAe,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC,qBAAqB,EAAE,CAAC;YAC1F,IAAI,UAAU,GAAO,EAAE,CAAC;YACxB,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE;gBAChB,UAAU,GAAG;oBACX,MAAM,EAAE,kBAAkB,CAAC,MAAM;oBACjC,KAAK,EAAE,kBAAkB,CAAC,KAAK;oBAC/B,IAAI,EAAE,kBAAkB,CAAC,IAAI;oBAC7B,GAAG,EAAE,kBAAkB,CAAC,GAAG;oBAC3B,KAAK,EAAE,kBAAkB,CAAC,KAAK;iBAChC,CAAA;aACF;iBAAM;gBACL,UAAU,GAAG;oBACX,MAAM,EAAE,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC,SAAS,GAAG,kBAAkB,CAAC,MAAM;oBACxE,KAAK,EAAE,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC,UAAU,GAAG,kBAAkB,CAAC,KAAK;oBACvE,IAAI,EAAE,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC,UAAU;oBAC3C,GAAG,EAAE,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC,SAAS;oBACzC,KAAK,EAAE,kBAAkB,CAAC,KAAK;iBAChC,CAAA;aACF;YACD,IAAI,CAAC,aAAa,CAAC,MAAM,CAAC,WAAW,EAAE,MAAM,CAAC,UAAU,EAAE,UAAU,EAAE,WAAW,CAAC,CAAC;SACpF;IACH,CAAC;IAEO,aAAa,CAAC,MAAc,EAAE,KAAa,EAAE,UAAe,EAAE,WAAuB;QAC3F,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,KAAK,CAAC,QAAQ,GAAG,OAAO,CAAC;QACxD,IAAI,MAAM,GAAG,UAAU,CAAC,MAAM,GAAG,WAAW,CAAC,MAAM,EAAE,EAAE,kCAAkC;YACvF,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,KAAK,CAAC,GAAG,GAAG,CAAC,UAAU,CAAC,GAAG,GAAG,WAAW,CAAC,MAAM,CAAC,GAAG,IAAI,CAAC;YACxF,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,SAAS,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;SACrD;aAAM;YACL,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,SAAS,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;YACvD,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,KAAK,CAAC,GAAG,GAAG,UAAU,CAAC,MAAM,GAAG,IAAI,CAAC;SACrE;QACD,IAAI,IAAI,CAAC,YAAY,EAAE;YACrB,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,KAAK,CAAC,KAAK,GAAG,UAAU,CAAC,KAAK,GAAG,IAAI,CAAC;SACtE;QACD,IAAI,IAAI,CAAC,UAAU,EAAE;YACnB,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,KAAK,CAAC,IAAI,GAAG,CAAC,UAAU,CAAC,KAAK,GAAG,WAAW,CAAC,KAAK,CAAC,GAAG,IAAI,CAAC;SAC3F;aAAM,IAAI,IAAI,CAAC,QAAQ,EAAE;YACxB,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,KAAK,CAAC,IAAI,GAAG,KAAK,CAAC;SACnD;aAAM;YACL,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,KAAK,CAAC,IAAI,GAAG,UAAU,CAAC,IAAI,GAAG,IAAI,CAAC;SACpE;QACD,IAAI,IAAI,CAAC,UAAU,EAAE;YACnB,MAAM,YAAY,GAAQ,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,MAAM,CAAC;YACzD,MAAM,SAAS,GAAW,YAAY,CAAC,UAAU,IAAI,YAAY,CAAC,WAAW,CAAC;YAC9E,IAAI,WAAW,CAAC,KAAK,GAAG,SAAS,EAAE;gBACjC,mCAAmC;gBACnC,IAAI,CAAC,CAAC,SAAS,GAAG,WAAW,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE;oBAC3D,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,KAAK,CAAC,IAAI,GAAG,CAAC,SAAS,GAAG,WAAW,CAAC,KAAK,CAAC,GAAG,IAAI,CAAC;iBACpF;qBAAM,EAAE,6BAA6B;oBACpC,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,KAAK,CAAC,KAAK,GAAG,SAAS,GAAG,IAAI,CAAC;oBAC9D,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,KAAK,CAAC,IAAI,GAAG,YAAY,CAAC,UAAU,GAAG,IAAI,CAAC;iBAC5E;aACF;SACF;IACH,CAAC;;;YAzJF,SAAS,SAAC;gBACT,QAAQ,EAAE,WAAW;aACtB;;;YALkB,UAAU;;;qBAQ1B,KAAK,SAAC,SAAS;mBAWf,KAAK;qBAOL,KAAK;yBAGL,KAAK;2BAGL,KAAK;yBAGL,KAAK;uBAGL,KAAK","sourcesContent":["import {Directive, ElementRef, Input, OnDestroy, OnInit} from '@angular/core';\r\nimport {OverlayParentDirective} from './overlay-parent.directive';\r\n\r\n@Directive({\r\n  selector: \"[overlay]\"\r\n})\r\nexport class OverlayDirective implements OnDestroy, OnInit {\r\n\r\n  @Input(\"overlay\")\r\n  public set parent(value: OverlayParentDirective | ElementRef) {\r\n    if (value) {\r\n      this._parent = value instanceof ElementRef ? value : value.elementRef;\r\n    } else {\r\n      if (this._parent && this._resizeObserver) {\r\n        this._resizeObserver.disconnect();\r\n      }\r\n    }\r\n  }\r\n\r\n  @Input()\r\n  public view: HTMLElement;\r\n\r\n  /**\r\n   * true; Element is added to the parent template\r\n   * false; Element is added to the bottom of the DOM\r\n   */\r\n  @Input()\r\n  public inline: boolean = false;\r\n\r\n  @Input()\r\n  public keepInView: boolean = false;\r\n\r\n  @Input()\r\n  public inheritWidth: boolean = false;\r\n\r\n  @Input()\r\n  public rightAlign: boolean = false;\r\n\r\n  @Input()\r\n  public fullSize: boolean = false;\r\n\r\n  private _elementRef: ElementRef;\r\n  private _resizeObserver: ResizeObserver;\r\n  private _intersectionObserver: IntersectionObserver;\r\n  private _parent: ElementRef;\r\n\r\n  constructor(\r\n      elementRef: ElementRef\r\n  ) {\r\n    this._elementRef = elementRef;\r\n  }\r\n\r\n  public ngOnDestroy(): void {\r\n    document.removeEventListener(\"scroll\", this.handleScroll, true);\r\n    if (this._intersectionObserver) {\r\n      this._intersectionObserver.disconnect();\r\n    }\r\n    if (this._resizeObserver) {\r\n      this._resizeObserver.disconnect();\r\n    }\r\n    this._elementRef = undefined;\r\n    this._parent = undefined;\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    if (!this._elementRef || !this._elementRef.nativeElement) {\r\n      return;\r\n    }\r\n    document.addEventListener(\"scroll\", this.handleScroll, true);\r\n    this._checkAndPlaceElement();\r\n    this._resizeObserver = new ResizeObserver(\r\n        (entries) => {\r\n          this._checkAndPlaceElement();\r\n        }\r\n    );\r\n    this._intersectionObserver = new IntersectionObserver(\r\n        (entries: IntersectionObserverEntry[]) => {\r\n          if (entries && entries.length > 0) {\r\n            if (entries[0].isIntersecting === false) {\r\n              this._elementRef.nativeElement.style.opacity = 0; // hide cause parent is not visible\r\n            } else {\r\n              this._elementRef.nativeElement.style.opacity = 1;\r\n            }\r\n          }\r\n        }, {\r\n          root: null\r\n        }\r\n    );\r\n    if (this._parent) {\r\n      this._intersectionObserver.observe(this._parent.nativeElement); // observe parent for visibility\r\n    }\r\n    this._resizeObserver.observe(document.body);\r\n  }\r\n\r\n  public handleScroll = (event: Event) => {\r\n    this._checkAndPlaceElement();\r\n  }\r\n\r\n  private _checkAndPlaceElement(): void {\r\n    if (this._elementRef && this._elementRef.nativeElement && this._parent && this._parent.nativeElement) {\r\n      const elementRect: ClientRect = this._elementRef.nativeElement.getBoundingClientRect();\r\n      const parentBoundingRect: ClientRect = this._parent.nativeElement.getBoundingClientRect();\r\n      let parentRect: {} = {};\r\n      if (!this.inline) {\r\n        parentRect = {\r\n          bottom: parentBoundingRect.bottom,\r\n          right: parentBoundingRect.right,\r\n          left: parentBoundingRect.left,\r\n          top: parentBoundingRect.top,\r\n          width: parentBoundingRect.width\r\n        }\r\n      } else {\r\n        parentRect = {\r\n          bottom: this._parent.nativeElement.offsetTop + parentBoundingRect.height,\r\n          right: this._parent.nativeElement.offsetLeft + parentBoundingRect.width,\r\n          left: this._parent.nativeElement.offsetLeft,\r\n          top: this._parent.nativeElement.offsetTop,\r\n          width: parentBoundingRect.width\r\n        }\r\n      }\r\n      this._placeElement(window.innerHeight, window.innerWidth, parentRect, elementRect);\r\n    }\r\n  }\r\n\r\n  private _placeElement(bottom: number, right: number, parentRect: any, elementRect: ClientRect): void {\r\n    this._elementRef.nativeElement.style.position = \"fixed\";\r\n    if (bottom < parentRect.bottom + elementRect.height) { // make sure it fits at the bottom\r\n      this._elementRef.nativeElement.style.top = (parentRect.top - elementRect.height) + \"px\";\r\n      this._elementRef.nativeElement.classList.add('top');\r\n    } else {\r\n      this._elementRef.nativeElement.classList.remove('top');\r\n      this._elementRef.nativeElement.style.top = parentRect.bottom + \"px\";\r\n    }\r\n    if (this.inheritWidth) {\r\n      this._elementRef.nativeElement.style.width = parentRect.width + \"px\";\r\n    }\r\n    if (this.rightAlign) {\r\n      this._elementRef.nativeElement.style.left = (parentRect.right - elementRect.width) + \"px\";\r\n    } else if (this.fullSize) {\r\n      this._elementRef.nativeElement.style.left = \"0px\";\r\n    } else {\r\n      this._elementRef.nativeElement.style.left = parentRect.left + \"px\";\r\n    }\r\n    if (this.keepInView) {\r\n      const viewToKeepIn: any = this.view ? this.view : window;\r\n      const viewWidth: number = viewToKeepIn.innerWidth || viewToKeepIn.clientWidth;\r\n      if (elementRect.right > viewWidth) {\r\n        //see if we can move it to the left\r\n        if (((viewWidth - elementRect.width) > 0) && !this.fullSize) {\r\n          this._elementRef.nativeElement.style.left = (viewWidth - elementRect.width) + \"px\";\r\n        } else { //resize so it fits into view\r\n          this._elementRef.nativeElement.style.width = viewWidth + \"px\";\r\n          this._elementRef.nativeElement.style.left = viewToKeepIn.offsetLeft + \"px\";\r\n        }\r\n      }\r\n    }\r\n  }\r\n}\r\n"]}
155
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"overlay.directive.js","sourceRoot":"","sources":["../../../../../../projects/corecomponents/src/lib/directives/overlay/overlay.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {Directive, ElementRef, Input, OnDestroy, OnInit} from '@angular/core';\r\nimport {OverlayParentDirective} from './overlay-parent.directive';\r\n\r\n@Directive({\r\n  selector: \"[overlay]\"\r\n})\r\nexport class OverlayDirective implements OnDestroy, OnInit {\r\n\r\n  @Input(\"overlay\")\r\n  public set parent(value: OverlayParentDirective | ElementRef | HTMLElement) {\r\n    if (value) {\r\n      if (value instanceof ElementRef) {\r\n        this._parent = value.nativeElement;\r\n      } else if (value instanceof OverlayParentDirective) {\r\n        this._parent = value.elementRef.nativeElement;\r\n      } else {\r\n        this._parent = value;\r\n      }\r\n    } else {\r\n      if (this._parent && this._resizeObserver) {\r\n        this._resizeObserver.disconnect();\r\n      }\r\n    }\r\n  }\r\n\r\n  @Input()\r\n  public view: HTMLElement;\r\n\r\n  /**\r\n   * true; Element is added to the parent template\r\n   * false; Element is added to the bottom of the DOM\r\n   */\r\n  @Input()\r\n  public inline: boolean = false;\r\n\r\n  @Input()\r\n  public keepInView: boolean = false;\r\n\r\n  @Input()\r\n  public inheritWidth: boolean = false;\r\n\r\n  @Input()\r\n  public rightAlign: boolean = false;\r\n\r\n  @Input()\r\n  public fullSize: boolean = false;\r\n\r\n  private _elementRef: ElementRef;\r\n  private _resizeObserver: ResizeObserver;\r\n  private _intersectionObserver: IntersectionObserver;\r\n  private _parent: HTMLElement;\r\n\r\n  constructor(\r\n      elementRef: ElementRef\r\n  ) {\r\n    this._elementRef = elementRef;\r\n  }\r\n\r\n  public ngOnDestroy(): void {\r\n    document.removeEventListener(\"scroll\", this.handleScroll, true);\r\n    if (this._intersectionObserver) {\r\n      this._intersectionObserver.disconnect();\r\n    }\r\n    if (this._resizeObserver) {\r\n      this._resizeObserver.disconnect();\r\n    }\r\n    this._elementRef = undefined;\r\n    this._parent = undefined;\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    if (!this._elementRef || !this._elementRef.nativeElement) {\r\n      return;\r\n    }\r\n    document.addEventListener(\"scroll\", this.handleScroll, true);\r\n    this._checkAndPlaceElement();\r\n    this._resizeObserver = new ResizeObserver(\r\n        (entries) => {\r\n          this._checkAndPlaceElement();\r\n        }\r\n    );\r\n    this._intersectionObserver = new IntersectionObserver(\r\n        (entries: IntersectionObserverEntry[]) => {\r\n          if (entries && entries.length > 0) {\r\n            if (entries[0].isIntersecting === false) {\r\n              this._elementRef.nativeElement.style.opacity = 0; // hide cause parent is not visible\r\n            } else {\r\n              this._elementRef.nativeElement.style.opacity = 1;\r\n            }\r\n          }\r\n        }, {\r\n          root: null\r\n        }\r\n    );\r\n    if (this._parent) {\r\n      this._intersectionObserver.observe(this._parent); // observe parent for visibility\r\n    }\r\n    this._resizeObserver.observe(document.body);\r\n  }\r\n\r\n  public handleScroll = (event: Event) => {\r\n    this._checkAndPlaceElement();\r\n  }\r\n\r\n  private _checkAndPlaceElement(): void {\r\n    if (this._elementRef && this._elementRef.nativeElement && this._parent) {\r\n      const elementRect: ClientRect = this._elementRef.nativeElement.getBoundingClientRect();\r\n      const parentBoundingRect: ClientRect = this._parent.getBoundingClientRect();\r\n      let parentRect: {} = {};\r\n      if (!this.inline) {\r\n        parentRect = {\r\n          bottom: parentBoundingRect.bottom,\r\n          right: parentBoundingRect.right,\r\n          left: parentBoundingRect.left,\r\n          top: parentBoundingRect.top,\r\n          width: parentBoundingRect.width\r\n        }\r\n      } else {\r\n        parentRect = {\r\n          bottom: this._parent.offsetTop + parentBoundingRect.height,\r\n          right: this._parent.offsetLeft + parentBoundingRect.width,\r\n          left: this._parent.offsetLeft,\r\n          top: this._parent.offsetTop,\r\n          width: parentBoundingRect.width\r\n        }\r\n      }\r\n      this._placeElement(window.innerHeight, window.innerWidth, parentRect, elementRect);\r\n    }\r\n  }\r\n\r\n  private _placeElement(bottom: number, right: number, parentRect: any, elementRect: ClientRect): void {\r\n    this._elementRef.nativeElement.style.position = \"fixed\";\r\n    if (bottom < parentRect.bottom + elementRect.height) { // make sure it fits at the bottom\r\n      this._elementRef.nativeElement.style.top = (parentRect.top - elementRect.height) + \"px\";\r\n      this._elementRef.nativeElement.classList.add('top');\r\n    } else {\r\n      this._elementRef.nativeElement.classList.remove('top');\r\n      this._elementRef.nativeElement.style.top = parentRect.bottom + \"px\";\r\n    }\r\n    if (this.inheritWidth) {\r\n      this._elementRef.nativeElement.style.width = parentRect.width + \"px\";\r\n    }\r\n    if (this.rightAlign) {\r\n      this._elementRef.nativeElement.style.left = (parentRect.right - elementRect.width) + \"px\";\r\n    } else if (this.fullSize) {\r\n      this._elementRef.nativeElement.style.left = \"0px\";\r\n    } else {\r\n      this._elementRef.nativeElement.style.left = parentRect.left + \"px\";\r\n    }\r\n    if (this.keepInView) {\r\n      const viewToKeepIn: any = this.view ? this.view : window;\r\n      const viewWidth: number = viewToKeepIn.innerWidth || viewToKeepIn.clientWidth;\r\n      if (elementRect.right > viewWidth) {\r\n        //see if we can move it to the left\r\n        if (((viewWidth - elementRect.width) > 0) && !this.fullSize) {\r\n          this._elementRef.nativeElement.style.left = (viewWidth - elementRect.width) + \"px\";\r\n        } else { //resize so it fits into view\r\n          this._elementRef.nativeElement.style.width = viewWidth + \"px\";\r\n          this._elementRef.nativeElement.style.left = viewToKeepIn.offsetLeft + \"px\";\r\n        }\r\n      }\r\n    }\r\n  }\r\n}\r\n"]}
@@ -4408,7 +4408,8 @@ CoDialogComponent.decorators = [
4408
4408
  <div class="co-dialog-overlay" (click)="handleOverlayClick($event)"></div>
4409
4409
  <div class="co-dialog-placeholder">
4410
4410
  <div class="co-dialog-wrapper" [ngClass]="customCssClass ? customCssClass : undefined" @showHideDialog cdkDrag>
4411
- <div class="dialog-header" *ngIf="!borderless" cdkDragHandle>
4411
+ <div *ngIf="!borderless" class="dialog-drag-handle" cdkDragHandle></div>
4412
+ <div class="dialog-header" *ngIf="!borderless">
4412
4413
  <div class="dialog-header-caption" *ngIf="headerTemplate">
4413
4414
  <ng-container [ngTemplateOutlet]="headerTemplate"></ng-container>
4414
4415
  </div>
@@ -5465,6 +5466,24 @@ InputDatePickerComponent.propDecorators = {
5465
5466
  showClass: [{ type: HostBinding, args: ['class.co-input-date',] }]
5466
5467
  };
5467
5468
 
5469
+ class OverlayParentDirective {
5470
+ constructor(elementRef) {
5471
+ this.elementRef = elementRef;
5472
+ }
5473
+ ngOnDestroy() {
5474
+ this.elementRef = undefined;
5475
+ }
5476
+ }
5477
+ OverlayParentDirective.decorators = [
5478
+ { type: Directive, args: [{
5479
+ selector: '[overlayParent]',
5480
+ exportAs: 'overlayParent'
5481
+ },] }
5482
+ ];
5483
+ OverlayParentDirective.ctorParameters = () => [
5484
+ { type: ElementRef }
5485
+ ];
5486
+
5468
5487
  class OverlayDirective {
5469
5488
  constructor(elementRef) {
5470
5489
  /**
@@ -5483,7 +5502,15 @@ class OverlayDirective {
5483
5502
  }
5484
5503
  set parent(value) {
5485
5504
  if (value) {
5486
- this._parent = value instanceof ElementRef ? value : value.elementRef;
5505
+ if (value instanceof ElementRef) {
5506
+ this._parent = value.nativeElement;
5507
+ }
5508
+ else if (value instanceof OverlayParentDirective) {
5509
+ this._parent = value.elementRef.nativeElement;
5510
+ }
5511
+ else {
5512
+ this._parent = value;
5513
+ }
5487
5514
  }
5488
5515
  else {
5489
5516
  if (this._parent && this._resizeObserver) {
@@ -5524,14 +5551,14 @@ class OverlayDirective {
5524
5551
  root: null
5525
5552
  });
5526
5553
  if (this._parent) {
5527
- this._intersectionObserver.observe(this._parent.nativeElement); // observe parent for visibility
5554
+ this._intersectionObserver.observe(this._parent); // observe parent for visibility
5528
5555
  }
5529
5556
  this._resizeObserver.observe(document.body);
5530
5557
  }
5531
5558
  _checkAndPlaceElement() {
5532
- if (this._elementRef && this._elementRef.nativeElement && this._parent && this._parent.nativeElement) {
5559
+ if (this._elementRef && this._elementRef.nativeElement && this._parent) {
5533
5560
  const elementRect = this._elementRef.nativeElement.getBoundingClientRect();
5534
- const parentBoundingRect = this._parent.nativeElement.getBoundingClientRect();
5561
+ const parentBoundingRect = this._parent.getBoundingClientRect();
5535
5562
  let parentRect = {};
5536
5563
  if (!this.inline) {
5537
5564
  parentRect = {
@@ -5544,10 +5571,10 @@ class OverlayDirective {
5544
5571
  }
5545
5572
  else {
5546
5573
  parentRect = {
5547
- bottom: this._parent.nativeElement.offsetTop + parentBoundingRect.height,
5548
- right: this._parent.nativeElement.offsetLeft + parentBoundingRect.width,
5549
- left: this._parent.nativeElement.offsetLeft,
5550
- top: this._parent.nativeElement.offsetTop,
5574
+ bottom: this._parent.offsetTop + parentBoundingRect.height,
5575
+ right: this._parent.offsetLeft + parentBoundingRect.width,
5576
+ left: this._parent.offsetLeft,
5577
+ top: this._parent.offsetTop,
5551
5578
  width: parentBoundingRect.width
5552
5579
  };
5553
5580
  }
@@ -5610,24 +5637,6 @@ OverlayDirective.propDecorators = {
5610
5637
  fullSize: [{ type: Input }]
5611
5638
  };
5612
5639
 
5613
- class OverlayParentDirective {
5614
- constructor(elementRef) {
5615
- this.elementRef = elementRef;
5616
- }
5617
- ngOnDestroy() {
5618
- this.elementRef = undefined;
5619
- }
5620
- }
5621
- OverlayParentDirective.decorators = [
5622
- { type: Directive, args: [{
5623
- selector: '[overlayParent]',
5624
- exportAs: 'overlayParent'
5625
- },] }
5626
- ];
5627
- OverlayParentDirective.ctorParameters = () => [
5628
- { type: ElementRef }
5629
- ];
5630
-
5631
5640
  class OverlayModule {
5632
5641
  }
5633
5642
  OverlayModule.decorators = [
@@ -6731,6 +6740,12 @@ class InputDateRangePickerComponent extends BaseInputDatePickerDirective {
6731
6740
  showClass() {
6732
6741
  return true;
6733
6742
  }
6743
+ handleFirstInputClick(event) {
6744
+ event.stopPropagation();
6745
+ }
6746
+ handleSecondInputClick(event) {
6747
+ event.stopPropagation();
6748
+ }
6734
6749
  handleDatesSelected(dates) {
6735
6750
  this.setModel(dates);
6736
6751
  }
@@ -6806,7 +6821,7 @@ InputDateRangePickerComponent.decorators = [
6806
6821
  selector: 'co-input-date-range',
6807
6822
  template: `
6808
6823
  <div class="inputs-wrapper" overlayParent #parentForOverlay="overlayParent">
6809
- <co-input-text class="no-focus-line custom-height"
6824
+ <co-input-text #firstInput class="no-focus-line custom-height"
6810
6825
  [(model)]="firstDateAsString"
6811
6826
  [noClickFocus]="true"
6812
6827
  [pattern]="'yyyy-MM-dd'"
@@ -6816,8 +6831,9 @@ InputDateRangePickerComponent.decorators = [
6816
6831
  [placeholder]="placeholder"
6817
6832
  (blur)="handleFirstDateChanged(firstDateAsString)"
6818
6833
  (clearIconClick)="clearDate(0)"
6834
+ (click)="handleFirstInputClick($event)"
6819
6835
  ></co-input-text>
6820
- <co-input-text class="no-focus-line custom-height"
6836
+ <co-input-text #secondInput class="no-focus-line custom-height"
6821
6837
  [(model)]= "secondDateAsString"
6822
6838
  [noClickFocus]="true"
6823
6839
  [pattern]="'yyyy-MM-dd'"
@@ -6826,6 +6842,7 @@ InputDateRangePickerComponent.decorators = [
6826
6842
  (rightIconClick)="toggleCalendar()"
6827
6843
  (blur)="handleSecondDateChanged(secondDateAsString)"
6828
6844
  (clearIconClick)="clearDate(1)"
6845
+ (click)="handleSecondInputClick($event)"
6829
6846
  ></co-input-text>
6830
6847
  </div>
6831
6848
  `,
@@ -6843,6 +6860,8 @@ InputDateRangePickerComponent.decorators = [
6843
6860
  },] }
6844
6861
  ];
6845
6862
  InputDateRangePickerComponent.propDecorators = {
6863
+ firstInput: [{ type: ViewChild, args: ['firstInput',] }],
6864
+ secondInput: [{ type: ViewChild, args: ['secondInput',] }],
6846
6865
  showClass: [{ type: HostBinding, args: ['class.co-input-date-range',] }]
6847
6866
  };
6848
6867