@colijnit/corecomponents_v12 12.1.1 → 12.1.3

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.
@@ -63,7 +63,7 @@ CoDialogComponent.decorators = [
63
63
  <ng-container [ngTemplateOutlet]="headerTemplate"></ng-container>
64
64
  </div>
65
65
  <div class="dialog-close-button" *ngIf="showCloseIcon" (click)="handleCloseDialog($event)">
66
- <co-icon [icon]="icons.Cancel"></co-icon>
66
+ <co-icon [icon]="icons.CrossSkinny"></co-icon>
67
67
  </div>
68
68
  </div>
69
69
  <div class="dialog-content" [ngClass]="customCssClass ? customCssClass : undefined">
@@ -107,4 +107,4 @@ CoDialogComponent.propDecorators = {
107
107
  mobile: [{ type: HostBinding, args: ['class.is-mobile',] }],
108
108
  ngOnInit: [{ type: HostBinding, args: ['@showHideCoDialog',] }]
109
109
  };
110
- //# 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-wrapper\" [ngClass]=\"customCssClass ? customCssClass : undefined\" @showHideDialog>\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.Cancel\"></co-icon>\n                </div>\n            </div>\n            <div class=\"dialog-content\" [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    `,\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"]}
110
+ //# 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-wrapper\" [ngClass]=\"customCssClass ? customCssClass : undefined\" @showHideDialog>\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\" [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    `,\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"]}
@@ -15,6 +15,9 @@ export class InputDateRangePickerComponent extends BaseInputDatePickerDirective
15
15
  this.toggleCalendar();
16
16
  }
17
17
  }
18
+ clearDate(index) {
19
+ this.model[index] = undefined;
20
+ }
18
21
  toggleCalendar() {
19
22
  if (this.readonly) {
20
23
  return;
@@ -82,6 +85,7 @@ InputDateRangePickerComponent.decorators = [
82
85
  [leftIconData]="leftIconData"
83
86
  [placeholder]="placeholder"
84
87
  (blur)="handleFirstDateChanged(firstDateAsString)"
88
+ (clearIconClick)="clearDate(0)"
85
89
  ></co-input-text>
86
90
  <co-input-text class="no-focus-line custom-height"
87
91
  [(model)]= "secondDateAsString"
@@ -91,6 +95,7 @@ InputDateRangePickerComponent.decorators = [
91
95
  [rightIcon]="rightIcon"
92
96
  (rightIconClick)="toggleCalendar()"
93
97
  (blur)="handleSecondDateChanged(secondDateAsString)"
98
+ (clearIconClick)="clearDate(1)"
94
99
  ></co-input-text>
95
100
  </div>
96
101
  `,
@@ -110,4 +115,4 @@ InputDateRangePickerComponent.decorators = [
110
115
  InputDateRangePickerComponent.propDecorators = {
111
116
  showClass: [{ type: HostBinding, args: ['class.co-input-date-range',] }]
112
117
  };
113
- //# 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":"AAAA,OAAO,EACL,SAAS,EAGT,UAAU,EACV,WAAW,EAIX,iBAAiB,EAClB,MAAM,eAAe,CAAC;AAEvB,OAAO,EACH,8CAA8C,EACjD,MAAM,iEAAiE,CAAC;AACzE,OAAO,EAAC,cAAc,EAAC,MAAM,+BAA+B,CAAC;AAC7D,OAAO,EAAC,4BAA4B,EAAC,MAAM,4DAA4D,CAAC;AACxG,OAAO,EAAC,uBAAuB,EAAC,MAAM,8CAA8C,CAAC;AAsCrF,MAAM,OAAO,6BAA8B,SAAQ,4BAA4B;IAQpE,SAAS;QACZ,OAAO,IAAI,CAAC;IAChB,CAAC;IAEI,mBAAmB,CAAC,KAAa;QACtC,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;IACvB,CAAC;IAEM,wBAAwB;QAC7B,IAAI,IAAI,CAAC,uBAAuB,EAAE;YAChC,IAAI,CAAC,cAAc,EAAE,CAAC;SACvB;IACH,CAAC;IAEM,cAAc;QACnB,IAAI,IAAI,CAAC,QAAQ,EAAE;YACjB,OAAO;SACR;QAED,IAAI,CAAC,YAAY,GAAG,CAAC,IAAI,CAAC,YAAY,CAAC;QAEvC,IAAI,IAAI,CAAC,YAAY,EAAE;YACrB,IAAI,CAAC,2BAA2B,GAAG,IAAI,CAAC,cAAc,CAAC,eAAe,CAAC,uBAAuB,EAAE;gBAC9F,gBAAgB,EAAE,IAAI,CAAC,gBAAgB;gBACvC,aAAa,EAAE,IAAI,CAAC,KAAK;aAC1B,EAAE;gBACD,aAAa,EAAE,CAAC,KAAK,EAAE,EAAE,CAAC,IAAI,CAAC,mBAAmB,CAAC,KAAK,CAAC;gBACzD,kBAAkB,EAAE,GAAG,EAAE,CAAC,IAAI,CAAC,wBAAwB,EAAE;gBACzD,cAAc,EAAE,GAAG,EAAE,CAAC,IAAI,CAAC,cAAc,EAAE;aAC5C,CAAC,CAAC;SACJ;aAAM;YACL,IAAI,CAAC,cAAc,CAAC,eAAe,CAAC,IAAI,CAAC,2BAA2B,CAAC,CAAC;SACvE;IACH,CAAC;IAEM,sBAAsB,CAAC,KAAa;QACzC,IAAI,KAAK,EAAE;YACT,IAAI,CAAC,IAAI,CAAC,KAAK,EAAE;gBACf,IAAI,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC;aACnB;YACD,IAAI,CAAC,QAAQ,CAAC,CAAC,IAAI,IAAI,CAAC,KAAK,CAAC,EAAE,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC;SACxE;IACH,CAAC;IAEM,uBAAuB,CAAC,KAAa;QAC1C,IAAI,KAAK,EAAE;YACT,IAAI,CAAC,IAAI,CAAC,KAAK,EAAE;gBACf,IAAI,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC;aACnB;YACD,IAAI,CAAC,QAAQ,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,EAAE,IAAI,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;SACxE;IACH,CAAC;IAES,QAAQ;QAChB,IAAI,CAAC,gBAAgB,EAAE,CAAC;IAC1B,CAAC;IAEO,gBAAgB;QACtB,IAAI,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE;YACjB,MAAM,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,cAAc,CAAC,SAAS,EAAE,EAAE,IAAI,EAAE,SAAS,EAAE,CAAC,CAAC;YAC1E,MAAM,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,cAAc,CAAC,SAAS,EAAE,EAAE,KAAK,EAAE,SAAS,EAAE,CAAC,CAAC;YAC5E,MAAM,GAAG,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,cAAc,CAAC,SAAS,EAAE,EAAE,GAAG,EAAE,SAAS,EAAE,CAAC,CAAC;YACxE,IAAI,CAAC,iBAAiB,GAAG,GAAG,IAAI,IAAI,KAAK,IAAI,GAAG,EAAE,CAAC;SACpD;QACD,IAAI,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE;YACjB,MAAM,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,cAAc,CAAC,SAAS,EAAE,EAAE,IAAI,EAAE,SAAS,EAAE,CAAC,CAAC;YAC1E,MAAM,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,cAAc,CAAC,SAAS,EAAE,EAAE,KAAK,EAAE,SAAS,EAAE,CAAC,CAAC;YAC5E,MAAM,GAAG,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,cAAc,CAAC,SAAS,EAAE,EAAE,GAAG,EAAE,SAAS,EAAE,CAAC,CAAC;YACxE,IAAI,CAAC,kBAAkB,GAAG,GAAG,IAAI,IAAI,KAAK,IAAI,GAAG,EAAE,CAAC;SACrD;IACH,CAAC;;;YAlHF,SAAS,SAAC;gBACP,QAAQ,EAAE,qBAAqB;gBAC/B,QAAQ,EAAE;;;;;;;;;;;;;;;;;;;;;;KAsBT;gBACD,SAAS,EAAE;oBACP,cAAc;oBACd;wBACI,OAAO,EAAE,8CAA8C;wBACvD,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,6BAA6B,CAAC;qBAC/D,EAAE;wBACC,OAAO,EAAE,4BAA4B;wBACrC,WAAW,EAAE,6BAA6B;qBAC7C;iBAAC;gBACN,aAAa,EAAE,iBAAiB,CAAC,IAAI;aACxC;;;wBAQI,WAAW,SAAC,2BAA2B","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        ></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        ></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 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    }\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    }\r\n  }\r\n}\r\n"]}
118
+ //# 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    }\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    }\r\n  }\r\n}\r\n"]}
@@ -126,6 +126,9 @@ export class InputNumberPickerComponent extends BaseInputComponent {
126
126
  return false;
127
127
  }
128
128
  }
129
+ handleBlur() {
130
+ this.modelChange.next(this.model);
131
+ }
129
132
  handleChangeModel(value) {
130
133
  this._changeFromButton = false;
131
134
  this.numberLogic.setValue(value);
@@ -253,7 +256,8 @@ InputNumberPickerComponent.decorators = [
253
256
  [disabled]="disabled"
254
257
  [required]="required"
255
258
  (ngModelChange)="handleChangeModel($event)"
256
- (keydown)="handleInputKeyDown($event)"/>
259
+ (keydown)="handleInputKeyDown($event)"
260
+ (blur)="handleBlur()"/>
257
261
  <div class="button-wrapper">
258
262
  <co-button *ngIf="showButtons" class="plus-operator" [class.select]="plusSelected" tabindex="-1"
259
263
  [disabled]="readonly"
@@ -307,4 +311,4 @@ InputNumberPickerComponent.propDecorators = {
307
311
  __decorate([
308
312
  InputBoolean()
309
313
  ], InputNumberPickerComponent.prototype, "noValidation", void 0);
310
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-number-picker.component.js","sourceRoot":"","sources":["../../../../../../projects/corecomponents/src/lib/components/input-number-picker/input-number-picker.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    ComponentFactoryResolver, ElementRef,\n    EventEmitter,\n    forwardRef,\n    HostBinding,\n    Inject,\n    Input,\n    NgZone,\n    OnDestroy,\n    OnInit,\n    Optional,\n    Output,\n    ViewChild,\n    ViewEncapsulation\n} from '@angular/core';\nimport {BaseInputComponent} from '../base/base-input.component';\nimport {InputBoolean} from '../../core/decorator/input-boolean.decorator';\nimport {Subscription} from 'rxjs';\nimport {BoundsConstrainedNumberValue} from '../../core/model/bounds-constrained-number-value';\nimport {NUMBER_INPUTS_KEY_DOWN_WHITE_LIST} from '../../core/constant/number-inputs-key-down-white-list';\nimport {KeyboardCode} from '../../core/enum/keyboard-code.enum';\nimport {InputTextComponent} from '../input-text/input-text.component';\nimport {FormInputUserModelChangeListenerService} from '../../core/service/form-input-user-change-listener.service';\nimport {InputNumberPickerButtonShowMode} from '../../core/enum/input-number-picker-show-mode.enum';\nimport {IconCacheService} from '../icon/icon-cache.service';\nimport {CoreComponentsIcon} from '../../core/enum/core-components-icon.enum';\nimport {SCREEN_CONFIG_ADAPTER_COMPONENT_INTERFACE_NAME} from '../../interfaces/screen-config-adapter-component-interface-name';\nimport {FormComponent} from '../form/form.component';\nimport {OverlayService} from '../../service/overlay.service';\nimport {SafeHtml} from '@angular/platform-browser';\nimport {NgZoneWrapperService} from '../../core/service/ng-zone-wrapper.service';\n\n@Component({\n    selector: 'co-input-number-picker',\n    template: `\n        <div class=\"icon-wrapper\" *ngIf=\"leftIconData\">\n            <co-icon class=\"input-number-picker-icon\" [iconData]=\"leftIconData\" (click)=\"iconClick.emit($event)\"></co-icon>\n            <div class=\"spacer\"></div>\n        </div>\n        <div class=\"button-wrapper\">\n            <co-button *ngIf=\"showButtons\" class=\"minus-operator\" [class.select]=\"minSelected\" tabindex=\"-1\"\n                       [disabled]=\"readonly\"\n                       [iconData]=\"iconCacheService.getIcon(minusIcon)\"\n                       (mousedown)=\"onMinusMouseDown($event)\"\n                       (mouseup)=\"stopAutoCounting()\" (mouseleave)=\"stopAutoCounting()\"></co-button>\n        </div>\n        <input type=\"text\"\n               [tabIndex]=\"readonly ? -1 : 0\"\n               [ngModel]=\"model\"\n               [readonly]=\"readonly\"\n               [disabled]=\"disabled\"\n               [required]=\"required\"\n               (ngModelChange)=\"handleChangeModel($event)\"\n               (keydown)=\"handleInputKeyDown($event)\"/>\n        <div class=\"button-wrapper\">\n            <co-button *ngIf=\"showButtons\" class=\"plus-operator\" [class.select]=\"plusSelected\" tabindex=\"-1\"\n                       [disabled]=\"readonly\"\n                       [iconData]=\"iconCacheService.getIcon(plusIcon)\"\n                       (mousedown)=\"onPlusMouseDown($event)\"\n                       (mouseup)=\"stopAutoCounting()\" (mouseleave)=\"stopAutoCounting()\"></co-button>\n        </div>\n    `,\n    providers: [\n        OverlayService, {\n            provide: SCREEN_CONFIG_ADAPTER_COMPONENT_INTERFACE_NAME, useExisting: forwardRef(() => InputNumberPickerComponent)\n        }, {\n            provide: BaseInputComponent,\n            useExisting: InputNumberPickerComponent\n        }],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    encapsulation: ViewEncapsulation.None,\n})\n// A component that lets users pick a number by increasing and decreasing it with buttons, or by typing.\nexport class InputNumberPickerComponent extends BaseInputComponent<number> implements OnInit, OnDestroy {\n\n    // @override\n    @Input()\n    public set model(model: number) {\n        // this.setValue(model, true);\n        super.model = model;\n    }\n\n    public get model(): number {\n        return super.model;\n    }\n\n    @Input()\n    public modelChangeOnEnter: boolean = true;\n\n    @HostBinding('class.has-icon')\n    @Input()\n    public leftIconData: SafeHtml | undefined;\n\n    @Input()\n    public set min(min: number) {\n        this.numberLogic.min = min;\n    }\n\n    @Input()\n    public set step(step: number) {\n        this.numberLogic.step = step;\n    }\n\n    @Input()\n    public set max(max: number) {\n        this.numberLogic.max = max;\n    }\n\n    @Input()\n    public ngModelOptions: any;\n\n    @Input()\n    public minusIcon: CoreComponentsIcon = CoreComponentsIcon.MinusSimple;\n\n    @Input()\n    public plusIcon: CoreComponentsIcon = CoreComponentsIcon.PlusSimple;\n\n    // Whether to show buttons 'always', 'onFocusOnly', or 'never'\n    @Input()\n    public buttonShowMode: InputNumberPickerButtonShowMode = InputNumberPickerButtonShowMode.Always;\n\n    // @override Default true for us.\n    @Input() @InputBoolean()\n    public noValidation: boolean = true;\n\n    @Input()\n    public set decimals(decimals: number) {\n        this.numberLogic.decimals = decimals;\n    }\n\n    // @override\n    @Output()\n    public readonly modelChange: EventEmitter<number> = new EventEmitter<number>();\n\n    @Output()\n    public readonly iconClick: EventEmitter<MouseEvent> = new EventEmitter<MouseEvent>();\n\n    @HostBinding('class.show-buttons-on-focus-only')\n    public get showButtonsOnFocusOnly(): boolean {\n        return this.buttonShowMode === InputNumberPickerButtonShowMode.OnFocusOnly;\n    }\n\n    @HostBinding('class.has-label')\n    public get hasLabel(): boolean {\n        return !!this.label;\n    }\n\n    @HostBinding('class.co-input-number-picker')\n    public showClass(): boolean {\n        return true;\n    }\n\n    public showButtons: boolean;\n\n    public readonly myKeyDownWhiteList: KeyboardCode[] = NUMBER_INPUTS_KEY_DOWN_WHITE_LIST;\n\n    public readonly numberLogic: BoundsConstrainedNumberValue = new BoundsConstrainedNumberValue();\n\n    public minSelected: boolean = false;\n    public plusSelected: boolean = false;\n\n    private _numberInputHasFocus: boolean = false;\n    private _changeFromButton: boolean = false;\n\n    private _numberLogicValueChangeSub: Subscription;\n    private readonly _delayBeforeStartAutoCountMs: number = 666;\n    // the 'speed gears' for auto counting\n    private readonly _stepFactors: number[] = [1, 10, 20];\n    // increase step size timing\n    private readonly _msChangeStepFactor: number = 1000;\n    // step speed\n    private readonly _msDoStep: number = 5;\n    // hold the mouse down and this increases for a faster auto increment\n    private _stepFactor: number = this._stepFactors[0];\n    private _mayAutoCount: boolean = false;\n\n    private _autoCountTimeout: number;\n    private _stepIncrementTimeout: number;\n    private _startAutocountTimeout: number;\n\n    constructor(\n        @Optional() public formComponent: FormComponent,\n        @Inject(IconCacheService) public iconCacheService: IconCacheService,\n        protected overlayService: OverlayService,\n        private _ngZone: NgZone,\n        protected componentFactoryResolver: ComponentFactoryResolver,\n        changeDetector: ChangeDetectorRef,\n        formUserChangeListener: FormInputUserModelChangeListenerService,\n        protected ngZoneWrapper?: NgZoneWrapperService,\n        public elementRef?: ElementRef,\n    ) {\n        super(changeDetector, componentFactoryResolver, overlayService, formUserChangeListener, ngZoneWrapper, elementRef);\n\n        this._numberLogicValueChangeSub = this.numberLogic.valueChange.subscribe((value: number) => {\n            if (!this._mayAutoCount) {\n                this.model = value;\n                if (!this.modelChangeOnEnter || this._changeFromButton) {\n                    this.modelChange.emit(value);\n                }\n                // custom form user chagne listener .next because we don't user super.updateModel() which normally does that for us\n                if (this._markedAsUserTouched) {\n                    this.formUserChangeListener.userModelChange.next(value);\n                    this.userModelChange.next(value);\n                }\n            }\n        });\n    }\n\n    ngOnInit(): void {\n        this.numberLogic.setValue(this.model, true);\n        // this.numberLogic.init(true);\n        this._updateButtonsShowState();\n    }\n\n    ngOnDestroy(): void {\n        this._numberLogicValueChangeSub.unsubscribe();\n        clearTimeout(this._autoCountTimeout);\n        clearTimeout(this._stepIncrementTimeout);\n        clearTimeout(this._startAutocountTimeout);\n    }\n\n    // Note: recursive through setTimeout().\n    public doIncrementAuto(): void {\n        this._mayAutoCount = true;\n\n        this.increment(this._stepFactor);\n\n        this._ngZone.runOutsideAngular(() => {\n            this._autoCountTimeout = window.setTimeout(() => {\n                if (this._mayAutoCount) {\n                    this.doIncrementAuto();\n                    this.changeDetector.detectChanges();\n                }\n            }, this._msDoStep);\n        });\n    }\n\n    public handleInputKeyDown(event: KeyboardEvent): boolean {\n        // event.preventDefault();\n        if (event.code === 'Enter' || event.code === 'NumpadEnter') {\n            this.modelChange.next(this.model);\n            return false;\n        }\n        if (this.myKeyDownWhiteList.find((k) => k === event.keyCode) === undefined) {\n            return false;\n        }\n    }\n\n    public handleChangeModel(value: number): void {\n        this._changeFromButton = false;\n        this.numberLogic.setValue(value);\n    }\n\n    // Note: recursive through setTimeout().\n    public doDecrementAuto(): void {\n        this._mayAutoCount = true;\n\n        this.decrement(this._stepFactor);\n\n        this._ngZone.runOutsideAngular(() => {\n            this._autoCountTimeout = window.setTimeout(() => {\n                if (this._mayAutoCount) {\n                    this.doDecrementAuto();\n                    this.changeDetector.detectChanges();\n                }\n            }, this._msDoStep);\n        });\n    }\n\n    public stopAutoCounting(): void {\n        this.minSelected = false;\n        this.plusSelected = false;\n        this._mayAutoCount = false;\n        this._stepFactor = this._stepFactors[0];\n    }\n\n    // Sets the current number value with given newValue, optionally silent (no valueChange event fired).\n    public setValue(newValue: number, silent: boolean = false): void {\n        this.numberLogic.setValue(newValue, silent);\n    }\n\n    public increment(steps: number = 1): void {\n        this._changeFromButton = true;\n        this.numberLogic.increment(steps);\n    }\n\n    public decrement(steps: number = 1): void {\n        this._changeFromButton = true;\n        this.numberLogic.decrement(steps);\n    }\n\n    public onPlusMouseDown(event: Event): void {\n        if (this.readonly) {\n            event.preventDefault();\n            return;\n        }\n        this.plusSelected = true;\n        this._markedAsUserTouched = true;\n\n        // keeps focus on input text instead of button\n        event.preventDefault();\n\n        this.increment();\n        this._mayAutoCount = true;\n\n        clearTimeout(this._startAutocountTimeout);\n        this._startAutocountTimeout = window.setTimeout(() => {\n            if (this._mayAutoCount) {\n                this.doIncrementAuto();\n                this._doIncreaseStepFactor();\n            }\n        }, this._delayBeforeStartAutoCountMs);\n    }\n\n    public onMinusMouseDown(event: Event): void {\n        if (this.readonly) {\n            event.preventDefault();\n            return;\n        }\n        this.minSelected = true;\n        this._markedAsUserTouched = true;\n        // keeps focus on input text instead of button\n        event.preventDefault();\n\n        this.decrement();\n        this._mayAutoCount = true;\n\n        clearTimeout(this._startAutocountTimeout);\n        this._startAutocountTimeout = window.setTimeout(() => {\n            if (this._mayAutoCount) {\n                this.doDecrementAuto();\n                this._doIncreaseStepFactor();\n            }\n        }, this._delayBeforeStartAutoCountMs);\n    }\n\n    // Note: recursive.\n    private _doIncreaseStepFactor(): void {\n        this._stepIncrementTimeout = window.setTimeout(() => {\n            if (this._mayAutoCount) {\n                this._stepFactor = this._getNextStepFactorMouseDown();\n                this._doIncreaseStepFactor();\n            }\n        }, this._msChangeStepFactor);\n    }\n\n    private _getNextStepFactorMouseDown(): number {\n        const curIdx: number = this._stepFactors.indexOf(this._stepFactor);\n        if (curIdx < this._stepFactors.length - 1) {\n            return this._stepFactors[curIdx + 1];\n        }\n        return this._stepFactor;\n    }\n\n    // Show or hide + and - buttons. Might hide buttons if number input lost focus and button show mode is on focus only.\n    private _updateButtonsShowState(): void {\n        switch (this.buttonShowMode) {\n            case InputNumberPickerButtonShowMode.Always:\n            default:\n                this.showButtons = true;\n                break;\n            case InputNumberPickerButtonShowMode.OnFocusOnly:\n                this.showButtons = this._numberInputHasFocus;\n                break;\n            case InputNumberPickerButtonShowMode.Never:\n                this.showButtons = false;\n                break;\n        }\n    }\n}\n"]}
314
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-number-picker.component.js","sourceRoot":"","sources":["../../../../../../projects/corecomponents/src/lib/components/input-number-picker/input-number-picker.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    ComponentFactoryResolver, ElementRef,\n    EventEmitter,\n    forwardRef,\n    HostBinding,\n    Inject,\n    Input,\n    NgZone,\n    OnDestroy,\n    OnInit,\n    Optional,\n    Output,\n    ViewChild,\n    ViewEncapsulation\n} from '@angular/core';\nimport {BaseInputComponent} from '../base/base-input.component';\nimport {InputBoolean} from '../../core/decorator/input-boolean.decorator';\nimport {Subscription} from 'rxjs';\nimport {BoundsConstrainedNumberValue} from '../../core/model/bounds-constrained-number-value';\nimport {NUMBER_INPUTS_KEY_DOWN_WHITE_LIST} from '../../core/constant/number-inputs-key-down-white-list';\nimport {KeyboardCode} from '../../core/enum/keyboard-code.enum';\nimport {InputTextComponent} from '../input-text/input-text.component';\nimport {FormInputUserModelChangeListenerService} from '../../core/service/form-input-user-change-listener.service';\nimport {InputNumberPickerButtonShowMode} from '../../core/enum/input-number-picker-show-mode.enum';\nimport {IconCacheService} from '../icon/icon-cache.service';\nimport {CoreComponentsIcon} from '../../core/enum/core-components-icon.enum';\nimport {SCREEN_CONFIG_ADAPTER_COMPONENT_INTERFACE_NAME} from '../../interfaces/screen-config-adapter-component-interface-name';\nimport {FormComponent} from '../form/form.component';\nimport {OverlayService} from '../../service/overlay.service';\nimport {SafeHtml} from '@angular/platform-browser';\nimport {NgZoneWrapperService} from '../../core/service/ng-zone-wrapper.service';\n\n@Component({\n    selector: 'co-input-number-picker',\n    template: `\n        <div class=\"icon-wrapper\" *ngIf=\"leftIconData\">\n            <co-icon class=\"input-number-picker-icon\" [iconData]=\"leftIconData\" (click)=\"iconClick.emit($event)\"></co-icon>\n            <div class=\"spacer\"></div>\n        </div>\n        <div class=\"button-wrapper\">\n            <co-button *ngIf=\"showButtons\" class=\"minus-operator\" [class.select]=\"minSelected\" tabindex=\"-1\"\n                       [disabled]=\"readonly\"\n                       [iconData]=\"iconCacheService.getIcon(minusIcon)\"\n                       (mousedown)=\"onMinusMouseDown($event)\"\n                       (mouseup)=\"stopAutoCounting()\" (mouseleave)=\"stopAutoCounting()\"></co-button>\n        </div>\n        <input type=\"text\"\n               [tabIndex]=\"readonly ? -1 : 0\"\n               [ngModel]=\"model\"\n               [readonly]=\"readonly\"\n               [disabled]=\"disabled\"\n               [required]=\"required\"\n               (ngModelChange)=\"handleChangeModel($event)\"\n               (keydown)=\"handleInputKeyDown($event)\"\n               (blur)=\"handleBlur()\"/>\n        <div class=\"button-wrapper\">\n            <co-button *ngIf=\"showButtons\" class=\"plus-operator\" [class.select]=\"plusSelected\" tabindex=\"-1\"\n                       [disabled]=\"readonly\"\n                       [iconData]=\"iconCacheService.getIcon(plusIcon)\"\n                       (mousedown)=\"onPlusMouseDown($event)\"\n                       (mouseup)=\"stopAutoCounting()\" (mouseleave)=\"stopAutoCounting()\"></co-button>\n        </div>\n    `,\n    providers: [\n        OverlayService, {\n            provide: SCREEN_CONFIG_ADAPTER_COMPONENT_INTERFACE_NAME, useExisting: forwardRef(() => InputNumberPickerComponent)\n        }, {\n            provide: BaseInputComponent,\n            useExisting: InputNumberPickerComponent\n        }],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    encapsulation: ViewEncapsulation.None,\n})\n// A component that lets users pick a number by increasing and decreasing it with buttons, or by typing.\nexport class InputNumberPickerComponent extends BaseInputComponent<number> implements OnInit, OnDestroy {\n\n    // @override\n    @Input()\n    public set model(model: number) {\n        // this.setValue(model, true);\n        super.model = model;\n    }\n\n    public get model(): number {\n        return super.model;\n    }\n\n    @Input()\n    public modelChangeOnEnter: boolean = true;\n\n    @HostBinding('class.has-icon')\n    @Input()\n    public leftIconData: SafeHtml | undefined;\n\n    @Input()\n    public set min(min: number) {\n        this.numberLogic.min = min;\n    }\n\n    @Input()\n    public set step(step: number) {\n        this.numberLogic.step = step;\n    }\n\n    @Input()\n    public set max(max: number) {\n        this.numberLogic.max = max;\n    }\n\n    @Input()\n    public ngModelOptions: any;\n\n    @Input()\n    public minusIcon: CoreComponentsIcon = CoreComponentsIcon.MinusSimple;\n\n    @Input()\n    public plusIcon: CoreComponentsIcon = CoreComponentsIcon.PlusSimple;\n\n    // Whether to show buttons 'always', 'onFocusOnly', or 'never'\n    @Input()\n    public buttonShowMode: InputNumberPickerButtonShowMode = InputNumberPickerButtonShowMode.Always;\n\n    // @override Default true for us.\n    @Input() @InputBoolean()\n    public noValidation: boolean = true;\n\n    @Input()\n    public set decimals(decimals: number) {\n        this.numberLogic.decimals = decimals;\n    }\n\n    // @override\n    @Output()\n    public readonly modelChange: EventEmitter<number> = new EventEmitter<number>();\n\n    @Output()\n    public readonly iconClick: EventEmitter<MouseEvent> = new EventEmitter<MouseEvent>();\n\n    @HostBinding('class.show-buttons-on-focus-only')\n    public get showButtonsOnFocusOnly(): boolean {\n        return this.buttonShowMode === InputNumberPickerButtonShowMode.OnFocusOnly;\n    }\n\n    @HostBinding('class.has-label')\n    public get hasLabel(): boolean {\n        return !!this.label;\n    }\n\n    @HostBinding('class.co-input-number-picker')\n    public showClass(): boolean {\n        return true;\n    }\n\n    public showButtons: boolean;\n\n    public readonly myKeyDownWhiteList: KeyboardCode[] = NUMBER_INPUTS_KEY_DOWN_WHITE_LIST;\n\n    public readonly numberLogic: BoundsConstrainedNumberValue = new BoundsConstrainedNumberValue();\n\n    public minSelected: boolean = false;\n    public plusSelected: boolean = false;\n\n    private _numberInputHasFocus: boolean = false;\n    private _changeFromButton: boolean = false;\n\n    private _numberLogicValueChangeSub: Subscription;\n    private readonly _delayBeforeStartAutoCountMs: number = 666;\n    // the 'speed gears' for auto counting\n    private readonly _stepFactors: number[] = [1, 10, 20];\n    // increase step size timing\n    private readonly _msChangeStepFactor: number = 1000;\n    // step speed\n    private readonly _msDoStep: number = 5;\n    // hold the mouse down and this increases for a faster auto increment\n    private _stepFactor: number = this._stepFactors[0];\n    private _mayAutoCount: boolean = false;\n\n    private _autoCountTimeout: number;\n    private _stepIncrementTimeout: number;\n    private _startAutocountTimeout: number;\n\n    constructor(\n        @Optional() public formComponent: FormComponent,\n        @Inject(IconCacheService) public iconCacheService: IconCacheService,\n        protected overlayService: OverlayService,\n        private _ngZone: NgZone,\n        protected componentFactoryResolver: ComponentFactoryResolver,\n        changeDetector: ChangeDetectorRef,\n        formUserChangeListener: FormInputUserModelChangeListenerService,\n        protected ngZoneWrapper?: NgZoneWrapperService,\n        public elementRef?: ElementRef,\n    ) {\n        super(changeDetector, componentFactoryResolver, overlayService, formUserChangeListener, ngZoneWrapper, elementRef);\n\n        this._numberLogicValueChangeSub = this.numberLogic.valueChange.subscribe((value: number) => {\n            if (!this._mayAutoCount) {\n                this.model = value;\n                if (!this.modelChangeOnEnter || this._changeFromButton) {\n                    this.modelChange.emit(value);\n                }\n                // custom form user chagne listener .next because we don't user super.updateModel() which normally does that for us\n                if (this._markedAsUserTouched) {\n                    this.formUserChangeListener.userModelChange.next(value);\n                    this.userModelChange.next(value);\n                }\n            }\n        });\n    }\n\n    ngOnInit(): void {\n        this.numberLogic.setValue(this.model, true);\n        // this.numberLogic.init(true);\n        this._updateButtonsShowState();\n    }\n\n    ngOnDestroy(): void {\n        this._numberLogicValueChangeSub.unsubscribe();\n        clearTimeout(this._autoCountTimeout);\n        clearTimeout(this._stepIncrementTimeout);\n        clearTimeout(this._startAutocountTimeout);\n    }\n\n    // Note: recursive through setTimeout().\n    public doIncrementAuto(): void {\n        this._mayAutoCount = true;\n\n        this.increment(this._stepFactor);\n\n        this._ngZone.runOutsideAngular(() => {\n            this._autoCountTimeout = window.setTimeout(() => {\n                if (this._mayAutoCount) {\n                    this.doIncrementAuto();\n                    this.changeDetector.detectChanges();\n                }\n            }, this._msDoStep);\n        });\n    }\n\n    public handleInputKeyDown(event: KeyboardEvent): boolean {\n        // event.preventDefault();\n        if (event.code === 'Enter' || event.code === 'NumpadEnter') {\n            this.modelChange.next(this.model);\n            return false;\n        }\n        if (this.myKeyDownWhiteList.find((k) => k === event.keyCode) === undefined) {\n            return false;\n        }\n    }\n\n    public handleBlur(): void {\n        this.modelChange.next(this.model);\n    }\n\n    public handleChangeModel(value: number): void {\n        this._changeFromButton = false;\n        this.numberLogic.setValue(value);\n    }\n\n    // Note: recursive through setTimeout().\n    public doDecrementAuto(): void {\n        this._mayAutoCount = true;\n\n        this.decrement(this._stepFactor);\n\n        this._ngZone.runOutsideAngular(() => {\n            this._autoCountTimeout = window.setTimeout(() => {\n                if (this._mayAutoCount) {\n                    this.doDecrementAuto();\n                    this.changeDetector.detectChanges();\n                }\n            }, this._msDoStep);\n        });\n    }\n\n    public stopAutoCounting(): void {\n        this.minSelected = false;\n        this.plusSelected = false;\n        this._mayAutoCount = false;\n        this._stepFactor = this._stepFactors[0];\n    }\n\n    // Sets the current number value with given newValue, optionally silent (no valueChange event fired).\n    public setValue(newValue: number, silent: boolean = false): void {\n        this.numberLogic.setValue(newValue, silent);\n    }\n\n    public increment(steps: number = 1): void {\n        this._changeFromButton = true;\n        this.numberLogic.increment(steps);\n    }\n\n    public decrement(steps: number = 1): void {\n        this._changeFromButton = true;\n        this.numberLogic.decrement(steps);\n    }\n\n    public onPlusMouseDown(event: Event): void {\n        if (this.readonly) {\n            event.preventDefault();\n            return;\n        }\n        this.plusSelected = true;\n        this._markedAsUserTouched = true;\n\n        // keeps focus on input text instead of button\n        event.preventDefault();\n\n        this.increment();\n        this._mayAutoCount = true;\n\n        clearTimeout(this._startAutocountTimeout);\n        this._startAutocountTimeout = window.setTimeout(() => {\n            if (this._mayAutoCount) {\n                this.doIncrementAuto();\n                this._doIncreaseStepFactor();\n            }\n        }, this._delayBeforeStartAutoCountMs);\n    }\n\n    public onMinusMouseDown(event: Event): void {\n        if (this.readonly) {\n            event.preventDefault();\n            return;\n        }\n        this.minSelected = true;\n        this._markedAsUserTouched = true;\n        // keeps focus on input text instead of button\n        event.preventDefault();\n\n        this.decrement();\n        this._mayAutoCount = true;\n\n        clearTimeout(this._startAutocountTimeout);\n        this._startAutocountTimeout = window.setTimeout(() => {\n            if (this._mayAutoCount) {\n                this.doDecrementAuto();\n                this._doIncreaseStepFactor();\n            }\n        }, this._delayBeforeStartAutoCountMs);\n    }\n\n    // Note: recursive.\n    private _doIncreaseStepFactor(): void {\n        this._stepIncrementTimeout = window.setTimeout(() => {\n            if (this._mayAutoCount) {\n                this._stepFactor = this._getNextStepFactorMouseDown();\n                this._doIncreaseStepFactor();\n            }\n        }, this._msChangeStepFactor);\n    }\n\n    private _getNextStepFactorMouseDown(): number {\n        const curIdx: number = this._stepFactors.indexOf(this._stepFactor);\n        if (curIdx < this._stepFactors.length - 1) {\n            return this._stepFactors[curIdx + 1];\n        }\n        return this._stepFactor;\n    }\n\n    // Show or hide + and - buttons. Might hide buttons if number input lost focus and button show mode is on focus only.\n    private _updateButtonsShowState(): void {\n        switch (this.buttonShowMode) {\n            case InputNumberPickerButtonShowMode.Always:\n            default:\n                this.showButtons = true;\n                break;\n            case InputNumberPickerButtonShowMode.OnFocusOnly:\n                this.showButtons = this._numberInputHasFocus;\n                break;\n            case InputNumberPickerButtonShowMode.Never:\n                this.showButtons = false;\n                break;\n        }\n    }\n}\n"]}
@@ -1,5 +1,6 @@
1
1
  import { Component, ElementRef, EventEmitter, HostBinding, Input, Output, ViewChild, ViewChildren, ViewEncapsulation } from '@angular/core';
2
2
  import { InputSearchComponent } from '../input-search/input-search.component';
3
+ import { KeyboardKey } from '../../core/enum/keyboard-key.enum';
3
4
  export class ListOfValuesPopupComponent {
4
5
  constructor() {
5
6
  this.multiselect = false;
@@ -12,7 +13,6 @@ export class ListOfValuesPopupComponent {
12
13
  this._collection = [];
13
14
  this._searchTerm = '';
14
15
  this._lovItems = [];
15
- this._activeIndex = -1;
16
16
  }
17
17
  set lovItems(children) {
18
18
  this._lovItems = children.toArray();
@@ -38,6 +38,8 @@ export class ListOfValuesPopupComponent {
38
38
  }
39
39
  set searchTerm(value) {
40
40
  this._searchTerm = value;
41
+ this.model = undefined;
42
+ this.highLightModel = undefined;
41
43
  this.filterViewModels();
42
44
  }
43
45
  get searchTerm() {
@@ -46,7 +48,6 @@ export class ListOfValuesPopupComponent {
46
48
  ngOnInit() {
47
49
  if (this.model) {
48
50
  if (!this.multiselect) {
49
- this._activeIndex = this.viewModelsMain.findIndex(v => v.model === this.model);
50
51
  this._scrollIntoView();
51
52
  }
52
53
  else {
@@ -59,52 +60,87 @@ export class ListOfValuesPopupComponent {
59
60
  }
60
61
  }
61
62
  }
63
+ handleInputKeyDown(event) {
64
+ if (event) {
65
+ switch (event.code) {
66
+ case KeyboardKey.Down:
67
+ this.selectNextOption();
68
+ return false;
69
+ case KeyboardKey.Up:
70
+ this.selectNextOption(true);
71
+ return false;
72
+ case KeyboardKey.SpaceBar:
73
+ if (this.highLightModel) {
74
+ this.selectViewModel(this.highLightModel, false);
75
+ return false;
76
+ }
77
+ }
78
+ }
79
+ }
62
80
  filterViewModels() {
63
81
  if (!this.collection) {
64
82
  return;
65
83
  }
66
84
  this._prepareViewModels();
67
85
  }
68
- selectViewModel(viewModel) {
69
- const idx = this.viewModelsMain.findIndex(vm => vm === viewModel);
86
+ selectViewModel(viewModel, closePopup = true) {
70
87
  if (!this.multiselect) {
71
- this._activeIndex = idx;
72
- this.selectOptionByActiveIndex();
88
+ this.selectModelByViewModel(viewModel, closePopup);
73
89
  }
74
90
  else {
75
- this.viewModelsMain[idx].checked = !this.viewModelsMain[idx].checked;
91
+ const idx = this.viewModels.findIndex(vm => vm === viewModel);
92
+ this.viewModels[idx].checked = !this.viewModels[idx].checked;
76
93
  this.selectOptions();
77
94
  }
78
95
  }
96
+ selectModelByViewModel(viewModel, closePopup = true) {
97
+ this.model = this.viewModelsMain.find(vm => vm === viewModel).model;
98
+ this.modelChange.emit(this.model);
99
+ this._scrollIntoView();
100
+ if (closePopup) {
101
+ this.closePopup.emit();
102
+ }
103
+ }
79
104
  // for single select
80
- selectOptionByActiveIndex(closePopup = true) {
81
- if (this._activeIndex > -1) {
82
- this.model = this.viewModelsMain[this._activeIndex].model;
83
- this.modelChange.emit(this.model);
84
- this._scrollIntoView();
85
- if (closePopup) {
86
- this.closePopup.emit();
105
+ selectOptionAndClosePopup() {
106
+ if (!this.model && this.searchTerm) {
107
+ const wishModel = this.viewModelsMain.find(vmm => vmm.model[this.displayField] === this.searchTerm);
108
+ if (wishModel) {
109
+ this.selectViewModel(wishModel);
110
+ }
111
+ else {
112
+ this.model = undefined;
113
+ this.modelChange.emit(this.model);
114
+ this.searchTerm = '';
87
115
  }
88
116
  }
117
+ else {
118
+ this.closePopup.emit();
119
+ }
89
120
  }
90
121
  // for multi select
91
122
  selectOptions() {
92
123
  this.model = this.viewModelsMain.filter(v => v.checked).map(m => m.model);
93
124
  this.modelChange.emit(this.model);
94
125
  }
95
- selectNextOption() {
96
- if (!this._lovItems || this._activeIndex >= this._lovItems.length - 1) {
97
- return;
126
+ selectNextOption(back = false) {
127
+ let nextModel;
128
+ if (!this.highLightModel) {
129
+ nextModel = this.viewModels[back ? this.viewModels.length - 1 : 0];
98
130
  }
99
- this._activeIndex++;
100
- this.selectOptionByActiveIndex(false);
101
- }
102
- selectPreviousOption() {
103
- if (this._activeIndex <= 0) {
104
- return;
131
+ else {
132
+ const currentViewModelIdx = this.viewModels.findIndex(vm => vm === this.highLightModel);
133
+ if (back) {
134
+ nextModel = this.viewModels[currentViewModelIdx <= 0 ? this.viewModels.length - 1 : currentViewModelIdx - 1];
135
+ }
136
+ else {
137
+ nextModel = this.viewModels[currentViewModelIdx >= this.viewModels.length - 1 ? 0 : currentViewModelIdx + 1];
138
+ }
139
+ }
140
+ this.highLightModel = nextModel;
141
+ if (!this.multiselect) {
142
+ this.selectViewModel(nextModel, false);
105
143
  }
106
- this._activeIndex--;
107
- this.selectOptionByActiveIndex(false);
108
144
  }
109
145
  _prepareViewModelsMain() {
110
146
  this.viewModelsMain.length = 0;
@@ -117,10 +153,11 @@ export class ListOfValuesPopupComponent {
117
153
  this.viewModels = this.viewModelsMain.filter(vm => vm.model[this.displayField] && vm.model[this.displayField].toLowerCase().includes(this.searchTerm ? this.searchTerm.toLowerCase() : ""));
118
154
  }
119
155
  _scrollIntoView() {
120
- if (!this._lovItems || this._lovItems.length <= 0 || this._activeIndex < 0 || !this._lovItems[this._activeIndex] || !this.dropDownList) {
156
+ const activeIndex = this.viewModels.findIndex(vmm => vmm === this.highLightModel);
157
+ if (!this._lovItems || this._lovItems.length <= 0 || activeIndex < 0 || !this.dropDownList) {
121
158
  return;
122
159
  }
123
- const activeItem = this._lovItems[this._activeIndex].nativeElement ? this._lovItems[this._activeIndex].nativeElement : undefined;
160
+ const activeItem = this._lovItems[activeIndex].nativeElement ? this._lovItems[activeIndex].nativeElement : undefined;
124
161
  const scrollParent = this.dropDownList.nativeElement ? this.dropDownList.nativeElement : undefined;
125
162
  this._scrollActiveItemIntoView(activeItem, scrollParent);
126
163
  }
@@ -144,18 +181,22 @@ ListOfValuesPopupComponent.decorators = [
144
181
  { type: Component, args: [{
145
182
  selector: 'co-list-of-values-popup',
146
183
  template: `
147
- <div class="lov-options" #dropDownList [overlay]="parentForOverlay" [inheritWidth]="true" [ngClass]="customCssClass" id="lov-popup"
184
+ <div class="lov-options" [overlay]="parentForOverlay" [inheritWidth]="true" [ngClass]="customCssClass" id="lov-popup"
148
185
  [tabIndex]="-1" role="listbox"
149
186
  (clickOutside)="closePopup.emit($event)">
150
- <co-input-search *ngIf="multiselect" [(model)]="searchTerm" (modelChange)="filterViewModels()" [placeholder]="searchPlaceholder"></co-input-search>
151
- <ul class="dropdown-list">
152
- <li #lovItem *ngFor="let viewModel of viewModels; let index = index" [class.selected]="viewModel.model === model"
153
- (click)="selectViewModel(viewModel)" role="option">
187
+ <co-input-search *ngIf="multiselect"
188
+ [(model)]="searchTerm"
189
+ [placeholder]="searchPlaceholder"
190
+ (keydown)="handleInputKeyDown($event)"
191
+ (modelChange)="filterViewModels()"></co-input-search>
192
+ <ul class="dropdown-list" #dropDownList>
193
+ <li #lovItem *ngFor="let viewModel of viewModels; let index = index" [class.selected]="viewModel === highLightModel"
194
+ (click)="selectViewModel(viewModel, false)" role="option">
154
195
  <ng-container *ngIf="!multiselect">
155
196
  <span class="lov-options-text" [textContent]="viewModel.model[displayField]"></span>
156
197
  </ng-container>
157
198
  <ng-container *ngIf="multiselect">
158
- <co-input-checkbox [model]="viewModel.checked" (modelChange)="selectViewModel(viewModel)"></co-input-checkbox>
199
+ <co-input-checkbox [model]="viewModel.checked" (modelChange)="selectViewModel(viewModel, false)"></co-input-checkbox>
159
200
  <span class="lov-options-text" [textContent]="viewModel.model[displayField]"></span>
160
201
  </ng-container>
161
202
  </li>
@@ -181,4 +222,4 @@ ListOfValuesPopupComponent.propDecorators = {
181
222
  closePopup: [{ type: Output }],
182
223
  showClass: [{ type: HostBinding, args: ['class.co-list-of-values-popup',] }]
183
224
  };
184
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"list-of-values-popup.component.js","sourceRoot":"","sources":["../../../../../../projects/corecomponents/src/lib/components/list-of-values/list-of-values-popup.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n    Component,\r\n    ElementRef,\r\n    EventEmitter,\r\n    HostBinding,\r\n    Input,\r\n    OnInit,\r\n    Output,\r\n    ViewChild,\r\n    ViewChildren,\r\n    ViewEncapsulation\r\n} from '@angular/core';\r\nimport {InputSearchComponent} from '../input-search/input-search.component';\r\n\r\nexport interface lovViewModel {\r\n    checked: boolean\r\n    model: any\r\n}\r\n\r\n@Component({\r\n    selector: 'co-list-of-values-popup',\r\n    template: `\r\n        <div class=\"lov-options\" #dropDownList [overlay]=\"parentForOverlay\" [inheritWidth]=\"true\" [ngClass]=\"customCssClass\" id=\"lov-popup\"\r\n             [tabIndex]=\"-1\" role=\"listbox\"\r\n             (clickOutside)=\"closePopup.emit($event)\">\r\n            <co-input-search *ngIf=\"multiselect\" [(model)]=\"searchTerm\" (modelChange)=\"filterViewModels()\" [placeholder]=\"searchPlaceholder\"></co-input-search>\r\n            <ul class=\"dropdown-list\">\r\n                <li #lovItem *ngFor=\"let viewModel of viewModels; let index = index\" [class.selected]=\"viewModel.model === model\"\r\n                    (click)=\"selectViewModel(viewModel)\" role=\"option\">\r\n                    <ng-container *ngIf=\"!multiselect\">\r\n                        <span class=\"lov-options-text\" [textContent]=\"viewModel.model[displayField]\"></span>\r\n                    </ng-container>\r\n                    <ng-container *ngIf=\"multiselect\">\r\n                        <co-input-checkbox [model]=\"viewModel.checked\" (modelChange)=\"selectViewModel(viewModel)\"></co-input-checkbox>\r\n                        <span class=\"lov-options-text\" [textContent]=\"viewModel.model[displayField]\"></span>\r\n                    </ng-container>\r\n                </li>\r\n            </ul>\r\n        </div>\r\n    `,\r\n    encapsulation: ViewEncapsulation.None,\r\n})\r\nexport class ListOfValuesPopupComponent implements OnInit {\r\n    @ViewChildren('lovItem', { read: ElementRef }) set lovItems(children) {\r\n        this._lovItems = children.toArray();\r\n        this._scrollIntoView();\r\n    }\r\n\r\n    @ViewChild('dropDownList', { read: ElementRef })\r\n    public dropDownList: ElementRef;\r\n\r\n    @ViewChild(InputSearchComponent) set inputSearch(component: InputSearchComponent) {\r\n        this._searchInput = component;\r\n        if (this._searchInput) {\r\n            this._searchInput.requestFocus();\r\n        }\r\n    }\r\n\r\n    @Input()\r\n    public model: any;\r\n\r\n    @Input()\r\n    public multiselect: boolean = false;\r\n\r\n    @Input()\r\n    public displayField: string = 'description';\r\n\r\n    @Input()\r\n    public searchPlaceholder: string;\r\n\r\n    @Input()\r\n    public customCssClass: string;\r\n\r\n    @Input()\r\n    public searchDisabled: boolean = false;\r\n\r\n    @Input()\r\n    public parentForOverlay: ElementRef;\r\n\r\n    @Input()\r\n    public set collection(value: any[]) {\r\n        this._collection = value || [];\r\n        this._prepareViewModelsMain();\r\n        this._prepareViewModels();\r\n        this.filterViewModels();\r\n    }\r\n\r\n    public get collection(): any[] {\r\n        return this._collection;\r\n    }\r\n\r\n    @Output()\r\n    public modelChange: EventEmitter<any> = new EventEmitter<any>();\r\n\r\n    @Output()\r\n    public closePopup: EventEmitter<Event> = new EventEmitter<Event>();\r\n\r\n    @HostBinding('class.co-list-of-values-popup')\r\n    public showClass() {\r\n        return true;\r\n    }\r\n\r\n    public set searchTerm(value: string) {\r\n        this._searchTerm = value;\r\n        this.filterViewModels();\r\n    }\r\n\r\n    public get searchTerm(): string {\r\n        return this._searchTerm;\r\n    }\r\n\r\n    public viewModels: lovViewModel[] = [];\r\n    public viewModelsMain: lovViewModel[] = [];\r\n\r\n    private _collection: any[] = [];\r\n    private _searchTerm: string = '';\r\n    private _lovItems: ElementRef[] = [];\r\n    private _activeIndex: number = -1;\r\n    private _searchInput: InputSearchComponent;\r\n\r\n    ngOnInit() {\r\n        if (this.model) {\r\n            if (!this.multiselect) {\r\n                this._activeIndex = this.viewModelsMain.findIndex(v => v.model === this.model);\r\n                this._scrollIntoView();\r\n            } else {\r\n                for (let i = 0; i < this.model.length; i++) {\r\n                    const viewModel: lovViewModel = this.viewModelsMain.find(v => JSON.stringify(v.model) === JSON.stringify(this.model[i]));\r\n                    if (viewModel) {\r\n                        viewModel.checked = true;\r\n                    }\r\n                }\r\n            }\r\n        }\r\n    }\r\n\r\n    public filterViewModels(): void {\r\n        if (!this.collection) {\r\n            return;\r\n        }\r\n        this._prepareViewModels();\r\n    }\r\n\r\n    public selectViewModel(viewModel: lovViewModel): void {\r\n        const idx: number = this.viewModelsMain.findIndex(vm => vm === viewModel);\r\n        if (!this.multiselect) {\r\n            this._activeIndex = idx;\r\n            this.selectOptionByActiveIndex();\r\n        } else {\r\n            this.viewModelsMain[idx].checked = !this.viewModelsMain[idx].checked;\r\n            this.selectOptions();\r\n        }\r\n    }\r\n\r\n    // for single select\r\n    public selectOptionByActiveIndex(closePopup: boolean = true): void {\r\n        if (this._activeIndex > -1) {\r\n            this.model = this.viewModelsMain[this._activeIndex].model;\r\n            this.modelChange.emit(this.model);\r\n            this._scrollIntoView();\r\n            if (closePopup) {\r\n                this.closePopup.emit();\r\n            }\r\n        }\r\n    }\r\n\r\n    // for multi select\r\n    public selectOptions(): void {\r\n        this.model = this.viewModelsMain.filter(v => v.checked).map(m => m.model);\r\n        this.modelChange.emit(this.model);\r\n    }\r\n\r\n    public selectNextOption(): void {\r\n        if (!this._lovItems || this._activeIndex >= this._lovItems.length - 1) {\r\n            return;\r\n        }\r\n        this._activeIndex++;\r\n        this.selectOptionByActiveIndex(false);\r\n    }\r\n\r\n    public selectPreviousOption(): void {\r\n        if (this._activeIndex <= 0) {\r\n            return;\r\n        }\r\n        this._activeIndex--;\r\n        this.selectOptionByActiveIndex(false);\r\n    }\r\n\r\n    private _prepareViewModelsMain(): void {\r\n        this.viewModelsMain.length = 0;\r\n        this.collection.forEach(m => {\r\n            this.viewModelsMain.push({checked: false, model: m});\r\n        })\r\n    }\r\n\r\n    private _prepareViewModels(): void {\r\n        this.viewModels.length = 0;\r\n        this.viewModels = this.viewModelsMain.filter(\r\n            vm => vm.model[this.displayField] && vm.model[this.displayField].toLowerCase().includes(this.searchTerm ? this.searchTerm.toLowerCase() : \"\"))\r\n    }\r\n\r\n    private _scrollIntoView(): void {\r\n        if (!this._lovItems || this._lovItems.length <= 0 || this._activeIndex < 0 || !this._lovItems[this._activeIndex] || !this.dropDownList) {\r\n            return;\r\n        }\r\n        const activeItem = this._lovItems[this._activeIndex].nativeElement ? this._lovItems[this._activeIndex].nativeElement : undefined;\r\n        const scrollParent = this.dropDownList.nativeElement ? this.dropDownList.nativeElement : undefined;\r\n        this._scrollActiveItemIntoView(activeItem, scrollParent);\r\n    }\r\n\r\n    private _scrollActiveItemIntoView(activeItem: any, scrollParent: any): void {\r\n        if (!activeItem || !scrollParent) {\r\n            return;\r\n        }\r\n        const { offsetHeight, offsetTop } = activeItem;\r\n        const { offsetHeight: parentOffsetHeight, scrollTop } = scrollParent;\r\n\r\n        const isAbove = offsetTop < scrollTop;\r\n        const isBelow = offsetTop + offsetHeight > scrollTop + parentOffsetHeight;\r\n\r\n        if (isAbove) {\r\n            scrollParent.scrollTo(0, offsetTop);\r\n        } else if (isBelow) {\r\n            scrollParent.scrollTo(0, offsetTop - parentOffsetHeight + offsetHeight);\r\n        }\r\n    }\r\n}\r\n"]}
225
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"list-of-values-popup.component.js","sourceRoot":"","sources":["../../../../../../projects/corecomponents/src/lib/components/list-of-values/list-of-values-popup.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n    Component,\r\n    ElementRef,\r\n    EventEmitter,\r\n    HostBinding,\r\n    Input,\r\n    OnInit,\r\n    Output,\r\n    ViewChild,\r\n    ViewChildren,\r\n    ViewEncapsulation\r\n} from '@angular/core';\r\nimport {InputSearchComponent} from '../input-search/input-search.component';\r\nimport {KeyboardKey} from '../../core/enum/keyboard-key.enum';\r\n\r\nexport interface lovViewModel {\r\n    checked: boolean\r\n    model: any\r\n}\r\n\r\n@Component({\r\n    selector: 'co-list-of-values-popup',\r\n    template: `\r\n        <div class=\"lov-options\" [overlay]=\"parentForOverlay\" [inheritWidth]=\"true\" [ngClass]=\"customCssClass\" id=\"lov-popup\"\r\n             [tabIndex]=\"-1\" role=\"listbox\"\r\n             (clickOutside)=\"closePopup.emit($event)\">\r\n            <co-input-search *ngIf=\"multiselect\" \r\n                             [(model)]=\"searchTerm\"\r\n                             [placeholder]=\"searchPlaceholder\"\r\n                             (keydown)=\"handleInputKeyDown($event)\"\r\n                             (modelChange)=\"filterViewModels()\"></co-input-search>\r\n            <ul class=\"dropdown-list\" #dropDownList>\r\n                <li #lovItem *ngFor=\"let viewModel of viewModels; let index = index\" [class.selected]=\"viewModel === highLightModel\"\r\n                    (click)=\"selectViewModel(viewModel, false)\" role=\"option\">\r\n                    <ng-container *ngIf=\"!multiselect\">\r\n                        <span class=\"lov-options-text\" [textContent]=\"viewModel.model[displayField]\"></span>\r\n                    </ng-container>\r\n                    <ng-container *ngIf=\"multiselect\">\r\n                        <co-input-checkbox [model]=\"viewModel.checked\" (modelChange)=\"selectViewModel(viewModel, false)\"></co-input-checkbox>\r\n                        <span class=\"lov-options-text\" [textContent]=\"viewModel.model[displayField]\"></span>\r\n                    </ng-container>\r\n                </li>\r\n            </ul>\r\n        </div>\r\n    `,\r\n    encapsulation: ViewEncapsulation.None,\r\n})\r\nexport class ListOfValuesPopupComponent implements OnInit {\r\n    @ViewChildren('lovItem', { read: ElementRef }) set lovItems(children) {\r\n        this._lovItems = children.toArray();\r\n        this._scrollIntoView();\r\n    }\r\n\r\n    @ViewChild('dropDownList', { read: ElementRef })\r\n    public dropDownList: ElementRef;\r\n\r\n    @ViewChild(InputSearchComponent) set inputSearch(component: InputSearchComponent) {\r\n        this._searchInput = component;\r\n        if (this._searchInput) {\r\n            this._searchInput.requestFocus();\r\n        }\r\n    }\r\n\r\n    @Input()\r\n    public model: any;\r\n\r\n    @Input()\r\n    public multiselect: boolean = false;\r\n\r\n    @Input()\r\n    public displayField: string = 'description';\r\n\r\n    @Input()\r\n    public searchPlaceholder: string;\r\n\r\n    @Input()\r\n    public customCssClass: string;\r\n\r\n    @Input()\r\n    public searchDisabled: boolean = false;\r\n\r\n    @Input()\r\n    public parentForOverlay: ElementRef;\r\n\r\n    @Input()\r\n    public set collection(value: any[]) {\r\n        this._collection = value || [];\r\n        this._prepareViewModelsMain();\r\n        this._prepareViewModels();\r\n        this.filterViewModels();\r\n    }\r\n\r\n    public get collection(): any[] {\r\n        return this._collection;\r\n    }\r\n\r\n    @Output()\r\n    public modelChange: EventEmitter<any> = new EventEmitter<any>();\r\n\r\n    @Output()\r\n    public closePopup: EventEmitter<Event> = new EventEmitter<Event>();\r\n\r\n    @HostBinding('class.co-list-of-values-popup')\r\n    public showClass() {\r\n        return true;\r\n    }\r\n\r\n    public set searchTerm(value: string) {\r\n        this._searchTerm = value;\r\n        this.model = undefined;\r\n        this.highLightModel = undefined;\r\n        this.filterViewModels();\r\n    }\r\n\r\n    public get searchTerm(): string {\r\n        return this._searchTerm;\r\n    }\r\n\r\n    public viewModels: lovViewModel[] = [];\r\n    public viewModelsMain: lovViewModel[] = [];\r\n    public highLightModel: lovViewModel;\r\n\r\n    private _collection: any[] = [];\r\n    private _searchTerm: string = '';\r\n    private _lovItems: ElementRef[] = [];\r\n    private _searchInput: InputSearchComponent;\r\n\r\n    ngOnInit() {\r\n        if (this.model) {\r\n            if (!this.multiselect) {\r\n                this._scrollIntoView();\r\n            } else {\r\n                for (let i = 0; i < this.model.length; i++) {\r\n                    const viewModel: lovViewModel = this.viewModelsMain.find(v => JSON.stringify(v.model) === JSON.stringify(this.model[i]));\r\n                    if (viewModel) {\r\n                        viewModel.checked = true;\r\n                    }\r\n                }\r\n            }\r\n        }\r\n    }\r\n\r\n    public handleInputKeyDown(event: KeyboardEvent): boolean {\r\n        if (event) {\r\n            switch (event.code) {\r\n                case KeyboardKey.Down:\r\n                    this.selectNextOption();\r\n                    return false;\r\n                case KeyboardKey.Up:\r\n                    this.selectNextOption(true);\r\n                    return false;\r\n                case KeyboardKey.SpaceBar:\r\n                    if (this.highLightModel) {\r\n                        this.selectViewModel(this.highLightModel, false);\r\n                        return false;\r\n                    }\r\n            }\r\n        }\r\n    }\r\n\r\n    public filterViewModels(): void {\r\n        if (!this.collection) {\r\n            return;\r\n        }\r\n        this._prepareViewModels();\r\n    }\r\n\r\n    public selectViewModel(viewModel: lovViewModel, closePopup: boolean = true): void {\r\n        if (!this.multiselect) {\r\n            this.selectModelByViewModel(viewModel, closePopup);\r\n        } else {\r\n            const idx: number = this.viewModels.findIndex(vm => vm === viewModel);\r\n            this.viewModels[idx].checked = !this.viewModels[idx].checked;\r\n            this.selectOptions();\r\n        }\r\n    }\r\n\r\n    public selectModelByViewModel(viewModel: lovViewModel, closePopup: boolean = true): void {\r\n        this.model = this.viewModelsMain.find(vm => vm === viewModel).model;\r\n        this.modelChange.emit(this.model);\r\n        this._scrollIntoView();\r\n        if (closePopup) {\r\n            this.closePopup.emit();\r\n        }\r\n    }\r\n\r\n    // for single select\r\n    public selectOptionAndClosePopup(): void {\r\n        if (!this.model && this.searchTerm) {\r\n            const wishModel: lovViewModel = this.viewModelsMain.find(vmm => vmm.model[this.displayField] === this.searchTerm);\r\n            if (wishModel) {\r\n                this.selectViewModel(wishModel);\r\n            } else {\r\n                this.model = undefined;\r\n                this.modelChange.emit(this.model);\r\n                this.searchTerm = '';\r\n            }\r\n        } else {\r\n            this.closePopup.emit();\r\n        }\r\n    }\r\n\r\n    // for multi select\r\n    public selectOptions(): void {\r\n        this.model = this.viewModelsMain.filter(v => v.checked).map(m => m.model);\r\n        this.modelChange.emit(this.model);\r\n    }\r\n\r\n    public selectNextOption(back: boolean = false): void {\r\n        let nextModel: any;\r\n        if (!this.highLightModel) {\r\n            nextModel = this.viewModels[back ? this.viewModels.length - 1 : 0];\r\n        } else {\r\n            const currentViewModelIdx: number = this.viewModels.findIndex(vm => vm === this.highLightModel);\r\n            if (back) {\r\n                nextModel = this.viewModels[currentViewModelIdx <= 0 ? this.viewModels.length - 1 : currentViewModelIdx - 1];\r\n            } else {\r\n                nextModel = this.viewModels[currentViewModelIdx >= this.viewModels.length - 1 ? 0 : currentViewModelIdx + 1];\r\n            }\r\n        }\r\n        this.highLightModel = nextModel;\r\n        if (!this.multiselect) {\r\n            this.selectViewModel(nextModel, false);\r\n        }\r\n    }\r\n\r\n    private _prepareViewModelsMain(): void {\r\n        this.viewModelsMain.length = 0;\r\n        this.collection.forEach(m => {\r\n            this.viewModelsMain.push({checked: false, model: m});\r\n        })\r\n    }\r\n\r\n    private _prepareViewModels(): void {\r\n        this.viewModels.length = 0;\r\n        this.viewModels = this.viewModelsMain.filter(\r\n            vm => vm.model[this.displayField] && vm.model[this.displayField].toLowerCase().includes(this.searchTerm ? this.searchTerm.toLowerCase() : \"\"))\r\n    }\r\n\r\n    private _scrollIntoView(): void {\r\n        const activeIndex: number = this.viewModels.findIndex(vmm => vmm === this.highLightModel);\r\n        if (!this._lovItems || this._lovItems.length <= 0 || activeIndex < 0 || !this.dropDownList) {\r\n            return;\r\n        }\r\n        const activeItem = this._lovItems[activeIndex].nativeElement ? this._lovItems[activeIndex].nativeElement : undefined;\r\n        const scrollParent = this.dropDownList.nativeElement ? this.dropDownList.nativeElement : undefined;\r\n        this._scrollActiveItemIntoView(activeItem, scrollParent);\r\n    }\r\n\r\n    private _scrollActiveItemIntoView(activeItem: any, scrollParent: any): void {\r\n        if (!activeItem || !scrollParent) {\r\n            return;\r\n        }\r\n        const { offsetHeight, offsetTop } = activeItem;\r\n        const { offsetHeight: parentOffsetHeight, scrollTop } = scrollParent;\r\n\r\n        const isAbove = offsetTop < scrollTop;\r\n        const isBelow = offsetTop + offsetHeight > scrollTop + parentOffsetHeight;\r\n\r\n        if (isAbove) {\r\n            scrollParent.scrollTo(0, offsetTop);\r\n        } else if (isBelow) {\r\n            scrollParent.scrollTo(0, offsetTop - parentOffsetHeight + offsetHeight);\r\n        }\r\n    }\r\n}\r\n"]}