@biit-solutions/wizardry-theme 1.22.12 → 1.22.13

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.
@@ -248,4 +248,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImpo
248
248
  type: HostListener,
249
249
  args: ['keydown.esc', ['$event']]
250
250
  }] } });
251
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"biit-datepicker.component.js","sourceRoot":"","sources":["../../../../../projects/wizardry-theme/inputs/src/biit-datepicker/biit-datepicker.component.ts","../../../../../projects/wizardry-theme/inputs/src/biit-datepicker/biit-datepicker.component.html"],"names":[],"mappings":"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","sourcesContent":["import {Component, Input, forwardRef, OnInit, ElementRef, HostListener} from '@angular/core';\nimport {ControlValueAccessor, NG_VALUE_ACCESSOR} from '@angular/forms';\nimport {eachDayOfInterval, add, setDate, startOfWeek, sub, setDefaultOptions, Locale, parseISO} from 'date-fns'\nimport {TRANSLOCO_SCOPE, TranslocoService} from \"@ngneat/transloco\";\nimport {enGB, es, nl} from \"date-fns/locale\";\nimport {coerceBooleanProperty} from \"@angular/cdk/coercion\";\n\n@Component({\n  selector: 'biit-datepicker',\n  templateUrl: 'biit-datepicker.component.html',\n  styleUrls: ['biit-datepicker.component.scss'],\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => BiitDatePickerComponent),\n      multi: true\n    },\n    {\n      provide: TRANSLOCO_SCOPE,\n      useValue: {scope: 'wizardry-theme/inputs', alias: \"inputs\"}\n    }\n  ],\n  host: {\n    '(document:pointerdown)': 'handleMouseEvents($event)'\n  }\n})\nexport class BiitDatePickerComponent implements ControlValueAccessor, OnInit {\n  @Input() disabled: boolean;\n  @Input() readonly: boolean;\n  @Input() required: boolean;\n  @Input('calendar-mode') set isCalendarMode(value: any) {\n    this.calendarMode = coerceBooleanProperty(value);\n  }\n  protected calendarMode: boolean = false;\n  @Input() disabledDays: Date[] = [];\n  @Input() disableWeekdays: boolean;\n  @Input() disableWeekends: boolean;\n  @Input() timePicker: boolean;\n  @Input() min: Date;\n  @Input() max: Date;\n  @Input() set placeholder(placeholder: string) {\n    this._placeholder = placeholder;\n  }\n  protected _placeholder = '';\n  @Input() error: string = \"\";\n  @Input() description: string;\n\n  protected value: Date;\n  protected dropdownOpen: boolean = false;\n  protected monthSelector: boolean = false;\n  protected days: Date[] = [];\n  protected headers = [\"Mo\", \"Tu\", \"We\", \"Th\", \"Fr\", \"Sa\", \"Su\"];\n  protected viewerDate = new Date();\n  protected locale: Locale;\n\n  protected get inputElement(): HTMLElement {return this.elem.nativeElement.querySelector('.input-object')}\n  protected get dropdownElement(): HTMLElement {return this.elem.nativeElement.querySelector('.popup')}\n\n  protected readonly add = add;\n  protected readonly sub = sub;\n  protected readonly parseISO = parseISO;\n\n  @HostListener('keydown.esc', ['$event'])\n  onKeyDown(e) {\n    this.closeDropdown();\n  }\n\n  constructor(\n    private elem: ElementRef,\n    private transloco: TranslocoService\n  ) { }\n\n  checkBooleanInput(value) {\n    switch (value) {\n      case undefined:\n        return false;\n      case false:\n        return false;\n      default:\n        return true;\n    }\n  }\n\n  onChange = (value: Date) => {};\n  onTouched = () => {};\n\n  registerOnChange(fn: any): void {\n    this.onChange = fn;\n  }\n\n  registerOnTouched(fn: any): void {\n    this.onTouched = fn;\n  }\n\n  writeValue(value: Date): void {\n    if (this.calendarMode && !value) {\n      this.value = new Date();\n    } else {\n      this.value = value;\n    }\n  }\n\n  onModelChange(value: Date) {\n    if (value) {\n      if (this.min && new Date(value).getTime() <= (new Date(this.min).getTime())) value = add(this.min, {minutes: 1});\n      if (this.max && new Date(value).getTime() > new Date(this.max).getTime()) value = sub(this.max, {minutes: 1});\n\n      this.value = new Date(value);\n      this.viewerDate = new Date(value);\n      this.onChange(value);\n    }\n  }\n\n  ngOnInit(): void {\n    this.initLocalization();\n\n    this.disabled = this.checkBooleanInput(this.disabled);\n    this.readonly = this.checkBooleanInput(this.readonly);\n    this.required = this.checkBooleanInput(this.required);\n    this.disableWeekdays = this.checkBooleanInput(this.disableWeekdays);\n    this.disableWeekends = this.checkBooleanInput(this.disableWeekends);\n    this.timePicker = this.checkBooleanInput(this.timePicker);\n\n    this.drawCalendar();\n  }\n\n  private initLocalization() {\n    switch (this.transloco.getActiveLang()) {\n      case 'es':\n        this.locale = es;\n        break;\n      case 'nl':\n        this.locale = nl;\n        break;\n      default:\n        this.locale = enGB;\n    }\n\n    setDefaultOptions({locale: this.locale});\n  }\n\n  handleMouseEvents($event: PointerEvent) {\n    if (this.dropdownOpen && !this.elem.nativeElement.contains($event.target)) {\n      this.closeDropdown();\n    }\n  }\n\n  changeView() {\n    this.monthSelector = !this.monthSelector;\n    this.setPopupComponentProperties();\n  }\n\n  openDropdown() {\n    if (!this.value) this.onModelChange(new Date());\n\n    this.viewerDate = this.value;\n    this.monthSelector = false;\n    this.drawCalendar();\n    this.setPopupComponentProperties();\n    (this.inputElement as HTMLInputElement).focus();\n\n    // Setting a timeout because it doesn't load upwards/downwards css classes on execution time\n    setTimeout(() => {\n      this.dropdownOpen = true;\n      this.dropdownElement.setAttribute('aria-expanded', \"true\");\n    }, 100);\n  }\n\n  closeDropdown() {\n    this.dropdownOpen = false;\n    this.dropdownElement.setAttribute('aria-expanded', \"false\");\n    this.inputElement.focus();\n  }\n\n  private setPopupComponentProperties() {\n    let dropdown = this.dropdownElement;\n    dropdown.style.display = 'block';\n\n    let input = this.inputElement;\n\n    // Checking available screen space\n    const fitsBottom = bottomCheck();\n    const fitsRight = rightCheck();\n    const fitsLeft = leftCheck();\n\n    if (!fitsRight && fitsLeft) {\n      dropdown.style.marginLeft = input.offsetWidth - dropdown.offsetWidth + 'px';\n    } else {\n      dropdown.style.marginLeft = null;\n    }\n\n    dropdown.classList.remove('onwards');\n    dropdown.classList.remove('downwards');\n\n    if (!fitsBottom) {\n      dropdown.classList.add('onwards');\n      dropdown.style.marginTop = -(dropdown.offsetHeight + input.offsetHeight) + 'px';\n    } else {\n      dropdown.classList.add('downwards');\n      dropdown.style.marginTop = null;\n    }\n\n    // Support inner functions\n    function bottomCheck(): boolean {\n      return input.getBoundingClientRect().bottom + dropdown.offsetHeight <= window.innerHeight ||\n        input.getBoundingClientRect().top - dropdown.offsetHeight <= 0;\n    }\n\n    function rightCheck(): boolean {\n      return input.getBoundingClientRect().right + dropdown.offsetWidth <= window.innerWidth;\n    }\n\n    function leftCheck(): boolean {\n      return input.getBoundingClientRect().right - dropdown.offsetWidth >= 0;\n    }\n  }\n\n  drawCalendar(): void {\n    const firstDay = startOfWeek(setDate(this.viewerDate, 1));\n    const lastDay = add(firstDay, {days:41});\n\n    this.days = eachDayOfInterval({start:firstDay, end:lastDay});\n  }\n\n  prevMonth(): void {\n    this.viewerDate = sub(this.viewerDate, {months:1})\n    this.drawCalendar();\n  }\n\n  nextMonth(): void {\n    this.viewerDate = add(this.viewerDate, {months:1});\n    this.drawCalendar();\n  }\n\n  setToday(): void {\n    this.viewerDate = new Date();\n    this.drawCalendar();\n    this.onModelChange(new Date());\n  }\n\n  log(value) {\n    console.debug('DEVELOPMENT LOG: ', value);\n  }\n}\n\n\n","<ng-container *ngIf=\"calendarMode; then calendarModeTemplate else datePickerTemplate\"></ng-container>\n\n<ng-template #datePickerTemplate>\n  <div class=\"biit-input\" [class.disabled]=\"disabled\" [class.readonly]=\"readonly\" >\n    <div class=\"input-container\">\n      <input class=\"input-object\"\n             [ngModel]=\"value && !timePicker ? (value | date: 'yyyy-MM-dd') :\n                        value && timePicker ? (value | date: 'yyyy-MM-dd\\THH:mm') :\n                        undefined\"\n             (ngModelChange)=\"onModelChange(parseISO($event))\"\n             [type]=\"timePicker ? 'datetime-local' : 'date'\" required\n             [style.background]=\"dropdownOpen ? '#D9D9D9' : null\"\n             [min]=\"min ? (min | date: 'yyyy-MM-dd') : undefined\"\n             [max]=\"max ? (max | date: 'yyyy-MM-dd') : undefined\"\n             [disabled]=\"disabled\"\n      >\n      <div class=\"input-show-icon-container\"\n           [style.background]=\"dropdownOpen ? '#D9D9D9' : null\"\n           (click)=\"dropdownOpen ? closeDropdown(): openDropdown()\"\n           (keydown.enter)=\"dropdownOpen ? closeDropdown(): openDropdown()\"\n           tabindex=\"0\">\n        <biit-icon [name]=\"'calendar'\"\n                   class=\"input-show-icon\"\n                   [pathStyle]=\"{fill: dropdownOpen ? '#F20D5E' : '#262626'}\"\n        ></biit-icon>\n      </div>\n      <div class=\"input-placeholder input-filled\">\n        {{_placeholder}}\n        <a *ngIf=\"required\"\n           [style.color]=\"value ? null : 'red'\">*</a>\n      </div>\n      <biit-icon *ngIf=\"error || (value | isDisabled: disabledDays: disableWeekdays: disableWeekends: min: max)\"\n                 name=\"exclamation\"\n                 class=\"input-error-icon\"\n                 [pathStyle]=\"{fill:'#A1093F'}\"\n      ></biit-icon>\n      <div *ngIf=\"description\" class=\"input-description\">\n        <a>\n          {{description}}\n        </a>\n      </div>\n\n      <div style=\"position: relative; height: 0;\">\n        <div class=\"popup\"\n             [class.dropdown-open]=\"dropdownOpen\"\n             [style.height]=\"!monthSelector && timePicker ? '29.1em + 3px)' : null\">\n          <div *ngIf=\"!monthSelector\"\n               class=\"month-view\">\n            <div class=\"month-selector\">\n              <button biit-icon\n                      [icon]=\"'right_arrow'\"\n                      style=\"rotate: 180deg\"\n                      (click)=\"prevMonth()\"\n              ></button>\n              <button biit-button tertiary\n                      class=\"month-label\"\n                      (click)=\"changeView()\">\n                {{viewerDate | translocoDate: {month: 'long'} }}\n                {{viewerDate | translocoDate: {year: 'numeric'} }}\n              </button>\n              <button biit-icon\n                      [icon]=\"'right_arrow'\"\n                      (click)=\"nextMonth()\"\n              ></button>\n            </div>\n\n            <div class=\"grid\">\n              <div *ngFor=\"let day of days | slice:0:7\"\n                   class=\"grid-element header\">\n                {{(day | translocoDate: {weekday: 'short'}).substring(0,2) }}\n              </div>\n              <button *ngFor=\"let day of days\"\n                      class=\"grid-element day\"\n                      [class.outer-day]=\"day | outOfMonth: viewerDate\"\n                      [class.is-today]=\"day | isToday\"\n                      [class.selected]=\"day | isSameDay: value\"\n                      [class.disabled]=\"day | isDisabled: disabledDays: disableWeekdays: disableWeekends: sub(min, {days: 1}): add(max, {days: 1})\"\n                      (click)=\"onModelChange(day)\"\n                      tabindex=\"0\"\n              >\n                {{day | calendarDate}}\n              </button>\n            </div>\n\n            <div class=\"buttons\">\n              <button biit-button tertiary\n                      class=\"today-btn\"\n                      (click)=\"setToday()\">\n                {{'inputs.today' | transloco}}\n              </button>\n              <button biit-button tertiary\n                      (click)=\"closeDropdown()\">\n                {{'inputs.done' | transloco}}\n              </button>\n            </div>\n\n            <div class=\"time-picker\" *ngIf=\"!monthSelector && timePicker\">\n              <div class=\"selector\">\n                <div class=\"column\"\n                     style=\"min-width: 2em;\">\n                  <div class=\"item arrow\"\n                       (click)=\"onModelChange(sub(value, {hours: 1}))\">\n                    <biit-icon [name]=\"'right_arrow'\"\n                               [pathStyle]=\"{fill: '#262626'}\"\n                               class=\"up\"\n                    ></biit-icon>\n                  </div>\n                  <div class=\"item secondary\"\n                       (click)=\"onModelChange(sub(value, {hours: 1}))\">\n                    {{ value ? (sub(value, {hours: 1}) | date: 'H') : '' }}\n                  </div>\n                  <div class=\"item primary\">\n                    {{ value ? (value | date: 'H') : '' }}\n                  </div>\n                  <div class=\"item secondary\"\n                       (click)=\"onModelChange(add(value, {hours: 1}))\">\n                    {{ value ? (add(value, {hours: 1}) | date: 'H') : '' }}\n                  </div>\n                  <div class=\"item arrow\"\n                       (click)=\"onModelChange(add(value, {hours: 1}))\">\n                    <biit-icon [name]=\"'right_arrow'\"\n                               [pathStyle]=\"{fill: '#262626'}\"\n                               class=\"down\"\n                    ></biit-icon>\n                  </div>\n                </div>\n                <div class=\"column\"\n                     style=\"min-width: 2em;\">\n                  <div class=\"item arrow\"\n                       (click)=\"onModelChange(sub(value, {minutes: 1}))\">\n                    <biit-icon [name]=\"'right_arrow'\"\n                               [pathStyle]=\"{fill: '#262626'}\"\n                               class=\"up\"\n                    ></biit-icon>\n                  </div>\n                  <div class=\"item secondary\"\n                       (click)=\"onModelChange(sub(value, {minutes: 1}))\">\n                    {{ value ? (sub(value, {minutes: 1}) | date: 'mm') : '' }}\n                  </div>\n                  <div class=\"item primary\">\n                    {{ value ? (value | date: 'mm') : '' }}\n                  </div>\n                  <div class=\"item secondary\"\n                       (click)=\"onModelChange(add(value, {minutes: 1}))\">\n                    {{ value ? (add(value, {minutes: 1}) | date: 'mm') : '' }}\n                  </div>\n                  <div class=\"item arrow\"\n                       (click)=\"onModelChange(add(value, {minutes: 1}))\">\n                    <biit-icon [name]=\"'right_arrow'\"\n                               [pathStyle]=\"{fill: '#262626'}\"\n                               class=\"down\"\n                    ></biit-icon>\n                  </div>\n                </div>\n              </div>\n            </div>\n          </div>\n\n          <div class=\"year-view\" *ngIf=\"monthSelector\">\n            <div class=\"month-selector\">\n              <button biit-button tertiary\n                      class=\"month-label\"\n                      (click)=\"changeView()\">\n                {{viewerDate | translocoDate: {month: 'long'} }}\n                {{viewerDate | translocoDate: {year: 'numeric'} }}\n              </button>\n            </div>\n\n            <div class=\"selector\">\n              <div class=\"column\"\n                   style=\"min-width: 8em;\">\n                <div class=\"item arrow\"\n                     (click)=\"prevMonth()\">\n                  <biit-icon [name]=\"'right_arrow'\"\n                             [pathStyle]=\"{fill: '#262626'}\"\n                             class=\"up\"\n                  ></biit-icon>\n                </div>\n                <div class=\"item tertiary\"\n                     (click)=\"viewerDate = sub(viewerDate, {months: 2})\">\n                  {{sub(viewerDate, {months: 2}) | translocoDate: {month: 'long'} }}\n                </div>\n                <div class=\"item secondary\"\n                     (click)=\"prevMonth()\">\n                  {{sub(viewerDate, {months: 1}) | translocoDate: {month: 'long'} }}\n                </div>\n                <div class=\"item primary\">\n                  {{viewerDate | translocoDate: {month: 'long'} }}\n                </div>\n                <div class=\"item secondary\"\n                     (click)=\"nextMonth()\">\n                  {{add(viewerDate, {months: 1}) | translocoDate: {month: 'long'} }}\n                </div>\n                <div class=\"item tertiary\"\n                     (click)=\"viewerDate = add(viewerDate, {months: 2})\">\n                  {{add(viewerDate, {months: 2}) | translocoDate: {month: 'long'} }}\n                </div>\n                <div class=\"item arrow\"\n                     (click)=\"nextMonth()\">\n                  <biit-icon [name]=\"'right_arrow'\"\n                             [pathStyle]=\"{fill: '#262626'}\"\n                             class=\"down\"\n                  ></biit-icon>\n                </div>\n              </div>\n\n              <div class=\"column\"\n                   style=\"min-width: 5em;\">\n                <div class=\"item arrow\"\n                     (click)=\"viewerDate = sub(viewerDate, {years: 1})\">\n                  <biit-icon [name]=\"'right_arrow'\"\n                             [pathStyle]=\"{fill: '#262626'}\"\n                             class=\"up\"\n                  ></biit-icon>\n                </div>\n                <div class=\"item tertiary\"\n                     (click)=\"viewerDate = sub(viewerDate, {years: 2})\">\n                  {{sub(viewerDate, {years: 2}) | translocoDate: {year: 'numeric'} }}\n                </div>\n                <div class=\"item secondary\"\n                     (click)=\"viewerDate = sub(viewerDate, {years: 1})\">\n                  {{sub(viewerDate, {years: 1}) | translocoDate: {year: 'numeric'} }}\n                </div>\n                <div class=\"item primary\">\n                  {{viewerDate | translocoDate: {year: 'numeric'} }}\n                </div>\n                <div class=\"item secondary\"\n                     (click)=\"viewerDate = add(viewerDate, {years: 1})\">\n                  {{add(viewerDate, {years: 1}) | translocoDate: {year: 'numeric'} }}\n                </div>\n                <div class=\"item tertiary\"\n                     (click)=\"viewerDate = add(viewerDate, {years: 2})\">\n                  {{add(viewerDate, {years: 2}) | translocoDate: {year: 'numeric'} }}\n                </div>\n                <div class=\"item arrow\"\n                     (click)=\"viewerDate = add(viewerDate, {years: 1})\">\n                  <biit-icon [name]=\"'right_arrow'\"\n                             [pathStyle]=\"{fill: '#262626'}\"\n                             class=\"down\"\n                  ></biit-icon>\n                </div>\n              </div>\n            </div>\n\n            <div class=\"buttons\">\n              <button biit-button tertiary\n                      (click)=\"drawCalendar(); changeView()\">\n                {{'inputs.back' | transloco}}\n              </button>\n            </div>\n          </div>\n        </div>\n      </div>\n\n      <div class=\"bottom-line\"></div>\n      <div *ngIf=\"error\" class=\"input-error-msg\">\n        <a>\n          {{error}}\n        </a>\n      </div>\n      <div *ngIf=\"value | isDisabled: disabledDays: disableWeekdays: disableWeekends: min: max\" class=\"input-error-msg\">\n        <a>\n          {{'inputs.date-error' | transloco}}\n        </a>\n      </div>\n    </div>\n  </div>\n</ng-template>\n\n<ng-template #calendarModeTemplate>\n  <div class=\"popup calendar-mode\"\n       [style.height]=\"!monthSelector && timePicker ? 'calc(29.1em + 3px)' : null\">\n    <div *ngIf=\"!monthSelector\"\n         class=\"month-view\">\n      <div class=\"month-selector\">\n        <button biit-icon\n                [icon]=\"'right_arrow'\"\n                style=\"rotate: 180deg\"\n                (click)=\"prevMonth()\"\n        ></button>\n        <button biit-button tertiary\n                class=\"month-label\"\n                (click)=\"changeView()\">\n          {{viewerDate | translocoDate: {month: 'long'} }}\n          {{viewerDate | translocoDate: {year: 'numeric'} }}\n        </button>\n        <button biit-icon\n                [icon]=\"'right_arrow'\"\n                (click)=\"nextMonth()\"\n        ></button>\n      </div>\n\n      <div class=\"grid\">\n        <div *ngFor=\"let day of days | slice:0:7\"\n             class=\"grid-element header\">\n          {{(day | translocoDate: {weekday: 'short'}).substring(0,2) }}\n        </div>\n        <button *ngFor=\"let day of days\"\n                class=\"grid-element day\"\n                [class.outer-day]=\"day | outOfMonth: viewerDate\"\n                [class.is-today]=\"day | isToday\"\n                [class.selected]=\"day | isSameDay: value\"\n                [class.disabled]=\"day | isDisabled: disabledDays: disableWeekdays: disableWeekends: sub(min, {days: 1}): add(max, {days: 1})\"\n                (click)=\"onModelChange(day)\"\n                tabindex=\"0\"\n        >\n          {{day | calendarDate}}\n        </button>\n      </div>\n\n      <div class=\"buttons\">\n        <button biit-button tertiary\n                class=\"today-btn\"\n                (click)=\"setToday()\">\n          {{'inputs.today' | transloco}}\n        </button>\n      </div>\n    </div>\n\n    <div class=\"time-picker\" *ngIf=\"!monthSelector && timePicker\">\n      <div class=\"selector\">\n        <div class=\"column\"\n             style=\"min-width: 2em;\">\n          <div class=\"item arrow\"\n               (click)=\"onModelChange(sub(value, {hours: 1}))\">\n            <biit-icon [name]=\"'right_arrow'\"\n                       [pathStyle]=\"{fill: '#262626'}\"\n                       class=\"up\"\n            ></biit-icon>\n          </div>\n          <div class=\"item secondary\"\n               (click)=\"onModelChange(sub(value, {hours: 1}))\">\n            {{ value ? (sub(value, {hours: 1}) | date: 'H') : '' }}\n          </div>\n          <div class=\"item primary\">\n            {{ value ? (value | date: 'H') : '' }}\n          </div>\n          <div class=\"item secondary\"\n               (click)=\"onModelChange(add(value, {hours: 1}))\">\n            {{ value ? (add(value, {hours: 1}) | date: 'H') : '' }}\n          </div>\n          <div class=\"item arrow\"\n               (click)=\"onModelChange(add(value, {hours: 1}))\">\n            <biit-icon [name]=\"'right_arrow'\"\n                       [pathStyle]=\"{fill: '#262626'}\"\n                       class=\"down\"\n            ></biit-icon>\n          </div>\n        </div>\n        <div class=\"column\"\n             style=\"min-width: 2em;\">\n          <div class=\"item arrow\"\n               (click)=\"onModelChange(sub(value, {minutes: 1}))\">\n            <biit-icon [name]=\"'right_arrow'\"\n                       [pathStyle]=\"{fill: '#262626'}\"\n                       class=\"up\"\n            ></biit-icon>\n          </div>\n          <div class=\"item secondary\"\n               (click)=\"onModelChange(sub(value, {hours: 1}))\">\n            {{ value ? (sub(value, {minutes: 1}) | date: 'mm') : '' }}\n          </div>\n          <div class=\"item primary\">\n            {{ value ? (value | date: 'mm') : '' }}\n          </div>\n          <div class=\"item secondary\"\n               (click)=\"onModelChange(add(value, {hours: 1}))\">\n            {{ value ? (add(value, {minutes: 1}) | date: 'mm') : '' }}\n          </div>\n          <div class=\"item arrow\"\n               (click)=\"onModelChange(add(value, {minutes: 1}))\">\n            <biit-icon [name]=\"'right_arrow'\"\n                       [pathStyle]=\"{fill: '#262626'}\"\n                       class=\"down\"\n            ></biit-icon>\n          </div>\n        </div>\n      </div>\n    </div>\n\n    <div class=\"year-view\" *ngIf=\"monthSelector\">\n      <div class=\"month-selector\">\n        <button biit-button tertiary\n                class=\"month-label\"\n                (click)=\"changeView()\">\n          {{viewerDate | translocoDate: {month: 'long'} }}\n          {{viewerDate | translocoDate: {year: 'numeric'} }}\n        </button>\n      </div>\n\n      <div class=\"selector\">\n        <div class=\"column\"\n             style=\"min-width: 8em;\">\n          <div class=\"item arrow\"\n               (click)=\"prevMonth()\">\n            <biit-icon [name]=\"'right_arrow'\"\n                       [pathStyle]=\"{fill: '#262626'}\"\n                       class=\"up\"\n            ></biit-icon>\n          </div>\n          <div class=\"item tertiary\"\n               (click)=\"viewerDate = sub(viewerDate, {months: 2})\">\n            {{sub(viewerDate, {months: 2}) | translocoDate: {month: 'long'} }}\n          </div>\n          <div class=\"item secondary\"\n               (click)=\"prevMonth()\">\n            {{sub(viewerDate, {months: 1}) | translocoDate: {month: 'long'} }}\n          </div>\n          <div class=\"item primary\">\n            {{viewerDate | translocoDate: {month: 'long'} }}\n          </div>\n          <div class=\"item secondary\"\n               (click)=\"nextMonth()\">\n            {{add(viewerDate, {months: 1}) | translocoDate: {month: 'long'} }}\n          </div>\n          <div class=\"item tertiary\"\n               (click)=\"viewerDate = add(viewerDate, {months: 2})\">\n            {{add(viewerDate, {months: 2}) | translocoDate: {month: 'long'} }}\n          </div>\n          <div class=\"item arrow\"\n               (click)=\"nextMonth()\">\n            <biit-icon [name]=\"'right_arrow'\"\n                       [pathStyle]=\"{fill: '#262626'}\"\n                       class=\"down\"\n            ></biit-icon>\n          </div>\n        </div>\n\n        <div class=\"column\"\n             style=\"min-width: 5em;\">\n          <div class=\"item arrow\"\n               (click)=\"viewerDate = sub(viewerDate, {years: 1})\">\n            <biit-icon [name]=\"'right_arrow'\"\n                       [pathStyle]=\"{fill: '#262626'}\"\n                       class=\"up\"\n            ></biit-icon>\n          </div>\n          <div class=\"item tertiary\"\n               (click)=\"viewerDate = sub(viewerDate, {years: 2})\">\n            {{sub(viewerDate, {years: 2}) | translocoDate: {year: 'numeric'} }}\n          </div>\n          <div class=\"item secondary\"\n               (click)=\"viewerDate = sub(viewerDate, {years: 1})\">\n            {{sub(viewerDate, {years: 1}) | translocoDate: {year: 'numeric'} }}\n          </div>\n          <div class=\"item primary\">\n            {{viewerDate | translocoDate: {year: 'numeric'} }}\n          </div>\n          <div class=\"item secondary\"\n               (click)=\"viewerDate = add(viewerDate, {years: 1})\">\n            {{add(viewerDate, {years: 1}) | translocoDate: {year: 'numeric'} }}\n          </div>\n          <div class=\"item tertiary\"\n               (click)=\"viewerDate = add(viewerDate, {years: 2})\">\n            {{add(viewerDate, {years: 2}) | translocoDate: {year: 'numeric'} }}\n          </div>\n          <div class=\"item arrow\"\n               (click)=\"viewerDate = add(viewerDate, {years: 1})\">\n            <biit-icon [name]=\"'right_arrow'\"\n                       [pathStyle]=\"{fill: '#262626'}\"\n                       class=\"down\"\n            ></biit-icon>\n          </div>\n        </div>\n      </div>\n\n      <div class=\"buttons\">\n        <button biit-button tertiary\n                (click)=\"drawCalendar(); changeView()\">\n          {{'inputs.back' | transloco}}\n        </button>\n      </div>\n    </div>\n  </div>\n</ng-template>\n"]}
251
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"biit-datepicker.component.js","sourceRoot":"","sources":["../../../../../projects/wizardry-theme/inputs/src/biit-datepicker/biit-datepicker.component.ts","../../../../../projects/wizardry-theme/inputs/src/biit-datepicker/biit-datepicker.component.html"],"names":[],"mappings":"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","sourcesContent":["import {Component, Input, forwardRef, OnInit, ElementRef, HostListener} from '@angular/core';\nimport {ControlValueAccessor, NG_VALUE_ACCESSOR} from '@angular/forms';\nimport {eachDayOfInterval, add, setDate, startOfWeek, sub, setDefaultOptions, Locale, parseISO} from 'date-fns'\nimport {TRANSLOCO_SCOPE, TranslocoService} from \"@ngneat/transloco\";\nimport {enGB, es, nl} from \"date-fns/locale\";\nimport {coerceBooleanProperty} from \"@angular/cdk/coercion\";\n\n@Component({\n  selector: 'biit-datepicker',\n  templateUrl: 'biit-datepicker.component.html',\n  styleUrls: ['biit-datepicker.component.scss'],\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => BiitDatePickerComponent),\n      multi: true\n    },\n    {\n      provide: TRANSLOCO_SCOPE,\n      useValue: {scope: 'wizardry-theme/inputs', alias: \"inputs\"}\n    }\n  ],\n  host: {\n    '(document:pointerdown)': 'handleMouseEvents($event)'\n  }\n})\nexport class BiitDatePickerComponent implements ControlValueAccessor, OnInit {\n  @Input() disabled: boolean;\n  @Input() readonly: boolean;\n  @Input() required: boolean;\n  @Input('calendar-mode') set isCalendarMode(value: any) {\n    this.calendarMode = coerceBooleanProperty(value);\n  }\n  protected calendarMode: boolean = false;\n  @Input() disabledDays: Date[] = [];\n  @Input() disableWeekdays: boolean;\n  @Input() disableWeekends: boolean;\n  @Input() timePicker: boolean;\n  @Input() min: Date;\n  @Input() max: Date;\n  @Input() set placeholder(placeholder: string) {\n    this._placeholder = placeholder;\n  }\n  protected _placeholder = '';\n  @Input() error: string | undefined = \"\";\n  @Input() description: string;\n\n  protected value: Date;\n  protected dropdownOpen: boolean = false;\n  protected monthSelector: boolean = false;\n  protected days: Date[] = [];\n  protected headers = [\"Mo\", \"Tu\", \"We\", \"Th\", \"Fr\", \"Sa\", \"Su\"];\n  protected viewerDate = new Date();\n  protected locale: Locale;\n\n  protected get inputElement(): HTMLElement {return this.elem.nativeElement.querySelector('.input-object')}\n  protected get dropdownElement(): HTMLElement {return this.elem.nativeElement.querySelector('.popup')}\n\n  protected readonly add = add;\n  protected readonly sub = sub;\n  protected readonly parseISO = parseISO;\n\n  @HostListener('keydown.esc', ['$event'])\n  onKeyDown(e) {\n    this.closeDropdown();\n  }\n\n  constructor(\n    private elem: ElementRef,\n    private transloco: TranslocoService\n  ) { }\n\n  checkBooleanInput(value) {\n    switch (value) {\n      case undefined:\n        return false;\n      case false:\n        return false;\n      default:\n        return true;\n    }\n  }\n\n  onChange = (value: Date) => {};\n  onTouched = () => {};\n\n  registerOnChange(fn: any): void {\n    this.onChange = fn;\n  }\n\n  registerOnTouched(fn: any): void {\n    this.onTouched = fn;\n  }\n\n  writeValue(value: Date): void {\n    if (this.calendarMode && !value) {\n      this.value = new Date();\n    } else {\n      this.value = value;\n    }\n  }\n\n  onModelChange(value: Date) {\n    if (value) {\n      if (this.min && new Date(value).getTime() <= (new Date(this.min).getTime())) value = add(this.min, {minutes: 1});\n      if (this.max && new Date(value).getTime() > new Date(this.max).getTime()) value = sub(this.max, {minutes: 1});\n\n      this.value = new Date(value);\n      this.viewerDate = new Date(value);\n      this.onChange(value);\n    }\n  }\n\n  ngOnInit(): void {\n    this.initLocalization();\n\n    this.disabled = this.checkBooleanInput(this.disabled);\n    this.readonly = this.checkBooleanInput(this.readonly);\n    this.required = this.checkBooleanInput(this.required);\n    this.disableWeekdays = this.checkBooleanInput(this.disableWeekdays);\n    this.disableWeekends = this.checkBooleanInput(this.disableWeekends);\n    this.timePicker = this.checkBooleanInput(this.timePicker);\n\n    this.drawCalendar();\n  }\n\n  private initLocalization() {\n    switch (this.transloco.getActiveLang()) {\n      case 'es':\n        this.locale = es;\n        break;\n      case 'nl':\n        this.locale = nl;\n        break;\n      default:\n        this.locale = enGB;\n    }\n\n    setDefaultOptions({locale: this.locale});\n  }\n\n  handleMouseEvents($event: PointerEvent) {\n    if (this.dropdownOpen && !this.elem.nativeElement.contains($event.target)) {\n      this.closeDropdown();\n    }\n  }\n\n  changeView() {\n    this.monthSelector = !this.monthSelector;\n    this.setPopupComponentProperties();\n  }\n\n  openDropdown() {\n    if (!this.value) this.onModelChange(new Date());\n\n    this.viewerDate = this.value;\n    this.monthSelector = false;\n    this.drawCalendar();\n    this.setPopupComponentProperties();\n    (this.inputElement as HTMLInputElement).focus();\n\n    // Setting a timeout because it doesn't load upwards/downwards css classes on execution time\n    setTimeout(() => {\n      this.dropdownOpen = true;\n      this.dropdownElement.setAttribute('aria-expanded', \"true\");\n    }, 100);\n  }\n\n  closeDropdown() {\n    this.dropdownOpen = false;\n    this.dropdownElement.setAttribute('aria-expanded', \"false\");\n    this.inputElement.focus();\n  }\n\n  private setPopupComponentProperties() {\n    let dropdown = this.dropdownElement;\n    dropdown.style.display = 'block';\n\n    let input = this.inputElement;\n\n    // Checking available screen space\n    const fitsBottom = bottomCheck();\n    const fitsRight = rightCheck();\n    const fitsLeft = leftCheck();\n\n    if (!fitsRight && fitsLeft) {\n      dropdown.style.marginLeft = input.offsetWidth - dropdown.offsetWidth + 'px';\n    } else {\n      dropdown.style.marginLeft = null;\n    }\n\n    dropdown.classList.remove('onwards');\n    dropdown.classList.remove('downwards');\n\n    if (!fitsBottom) {\n      dropdown.classList.add('onwards');\n      dropdown.style.marginTop = -(dropdown.offsetHeight + input.offsetHeight) + 'px';\n    } else {\n      dropdown.classList.add('downwards');\n      dropdown.style.marginTop = null;\n    }\n\n    // Support inner functions\n    function bottomCheck(): boolean {\n      return input.getBoundingClientRect().bottom + dropdown.offsetHeight <= window.innerHeight ||\n        input.getBoundingClientRect().top - dropdown.offsetHeight <= 0;\n    }\n\n    function rightCheck(): boolean {\n      return input.getBoundingClientRect().right + dropdown.offsetWidth <= window.innerWidth;\n    }\n\n    function leftCheck(): boolean {\n      return input.getBoundingClientRect().right - dropdown.offsetWidth >= 0;\n    }\n  }\n\n  drawCalendar(): void {\n    const firstDay = startOfWeek(setDate(this.viewerDate, 1));\n    const lastDay = add(firstDay, {days:41});\n\n    this.days = eachDayOfInterval({start:firstDay, end:lastDay});\n  }\n\n  prevMonth(): void {\n    this.viewerDate = sub(this.viewerDate, {months:1})\n    this.drawCalendar();\n  }\n\n  nextMonth(): void {\n    this.viewerDate = add(this.viewerDate, {months:1});\n    this.drawCalendar();\n  }\n\n  setToday(): void {\n    this.viewerDate = new Date();\n    this.drawCalendar();\n    this.onModelChange(new Date());\n  }\n\n  log(value) {\n    console.debug('DEVELOPMENT LOG: ', value);\n  }\n}\n\n\n","<ng-container *ngIf=\"calendarMode; then calendarModeTemplate else datePickerTemplate\"></ng-container>\n\n<ng-template #datePickerTemplate>\n  <div class=\"biit-input\" [class.disabled]=\"disabled\" [class.readonly]=\"readonly\" >\n    <div class=\"input-container\">\n      <input class=\"input-object\"\n             [ngModel]=\"value && !timePicker ? (value | date: 'yyyy-MM-dd') :\n                        value && timePicker ? (value | date: 'yyyy-MM-dd\\THH:mm') :\n                        undefined\"\n             (ngModelChange)=\"onModelChange(parseISO($event))\"\n             [type]=\"timePicker ? 'datetime-local' : 'date'\" required\n             [style.background]=\"dropdownOpen ? '#D9D9D9' : null\"\n             [min]=\"min ? (min | date: 'yyyy-MM-dd') : undefined\"\n             [max]=\"max ? (max | date: 'yyyy-MM-dd') : undefined\"\n             [disabled]=\"disabled\"\n      >\n      <div class=\"input-show-icon-container\"\n           [style.background]=\"dropdownOpen ? '#D9D9D9' : null\"\n           (click)=\"dropdownOpen ? closeDropdown(): openDropdown()\"\n           (keydown.enter)=\"dropdownOpen ? closeDropdown(): openDropdown()\"\n           tabindex=\"0\">\n        <biit-icon [name]=\"'calendar'\"\n                   class=\"input-show-icon\"\n                   [pathStyle]=\"{fill: dropdownOpen ? '#F20D5E' : '#262626'}\"\n        ></biit-icon>\n      </div>\n      <div class=\"input-placeholder input-filled\">\n        {{_placeholder}}\n        <a *ngIf=\"required\"\n           [style.color]=\"value ? null : 'red'\">*</a>\n      </div>\n      <biit-icon *ngIf=\"error || (value | isDisabled: disabledDays: disableWeekdays: disableWeekends: min: max)\"\n                 name=\"exclamation\"\n                 class=\"input-error-icon\"\n                 [pathStyle]=\"{fill:'#A1093F'}\"\n      ></biit-icon>\n      <div *ngIf=\"description\" class=\"input-description\">\n        <a>\n          {{description}}\n        </a>\n      </div>\n\n      <div style=\"position: relative; height: 0;\">\n        <div class=\"popup\"\n             [class.dropdown-open]=\"dropdownOpen\"\n             [style.height]=\"!monthSelector && timePicker ? '29.1em + 3px)' : null\">\n          <div *ngIf=\"!monthSelector\"\n               class=\"month-view\">\n            <div class=\"month-selector\">\n              <button biit-icon\n                      [icon]=\"'right_arrow'\"\n                      style=\"rotate: 180deg\"\n                      (click)=\"prevMonth()\"\n              ></button>\n              <button biit-button tertiary\n                      class=\"month-label\"\n                      (click)=\"changeView()\">\n                {{viewerDate | translocoDate: {month: 'long'} }}\n                {{viewerDate | translocoDate: {year: 'numeric'} }}\n              </button>\n              <button biit-icon\n                      [icon]=\"'right_arrow'\"\n                      (click)=\"nextMonth()\"\n              ></button>\n            </div>\n\n            <div class=\"grid\">\n              <div *ngFor=\"let day of days | slice:0:7\"\n                   class=\"grid-element header\">\n                {{(day | translocoDate: {weekday: 'short'}).substring(0,2) }}\n              </div>\n              <button *ngFor=\"let day of days\"\n                      class=\"grid-element day\"\n                      [class.outer-day]=\"day | outOfMonth: viewerDate\"\n                      [class.is-today]=\"day | isToday\"\n                      [class.selected]=\"day | isSameDay: value\"\n                      [class.disabled]=\"day | isDisabled: disabledDays: disableWeekdays: disableWeekends: sub(min, {days: 1}): add(max, {days: 1})\"\n                      (click)=\"onModelChange(day)\"\n                      tabindex=\"0\"\n              >\n                {{day | calendarDate}}\n              </button>\n            </div>\n\n            <div class=\"buttons\">\n              <button biit-button tertiary\n                      class=\"today-btn\"\n                      (click)=\"setToday()\">\n                {{'inputs.today' | transloco}}\n              </button>\n              <button biit-button tertiary\n                      (click)=\"closeDropdown()\">\n                {{'inputs.done' | transloco}}\n              </button>\n            </div>\n\n            <div class=\"time-picker\" *ngIf=\"!monthSelector && timePicker\">\n              <div class=\"selector\">\n                <div class=\"column\"\n                     style=\"min-width: 2em;\">\n                  <div class=\"item arrow\"\n                       (click)=\"onModelChange(sub(value, {hours: 1}))\">\n                    <biit-icon [name]=\"'right_arrow'\"\n                               [pathStyle]=\"{fill: '#262626'}\"\n                               class=\"up\"\n                    ></biit-icon>\n                  </div>\n                  <div class=\"item secondary\"\n                       (click)=\"onModelChange(sub(value, {hours: 1}))\">\n                    {{ value ? (sub(value, {hours: 1}) | date: 'H') : '' }}\n                  </div>\n                  <div class=\"item primary\">\n                    {{ value ? (value | date: 'H') : '' }}\n                  </div>\n                  <div class=\"item secondary\"\n                       (click)=\"onModelChange(add(value, {hours: 1}))\">\n                    {{ value ? (add(value, {hours: 1}) | date: 'H') : '' }}\n                  </div>\n                  <div class=\"item arrow\"\n                       (click)=\"onModelChange(add(value, {hours: 1}))\">\n                    <biit-icon [name]=\"'right_arrow'\"\n                               [pathStyle]=\"{fill: '#262626'}\"\n                               class=\"down\"\n                    ></biit-icon>\n                  </div>\n                </div>\n                <div class=\"column\"\n                     style=\"min-width: 2em;\">\n                  <div class=\"item arrow\"\n                       (click)=\"onModelChange(sub(value, {minutes: 1}))\">\n                    <biit-icon [name]=\"'right_arrow'\"\n                               [pathStyle]=\"{fill: '#262626'}\"\n                               class=\"up\"\n                    ></biit-icon>\n                  </div>\n                  <div class=\"item secondary\"\n                       (click)=\"onModelChange(sub(value, {minutes: 1}))\">\n                    {{ value ? (sub(value, {minutes: 1}) | date: 'mm') : '' }}\n                  </div>\n                  <div class=\"item primary\">\n                    {{ value ? (value | date: 'mm') : '' }}\n                  </div>\n                  <div class=\"item secondary\"\n                       (click)=\"onModelChange(add(value, {minutes: 1}))\">\n                    {{ value ? (add(value, {minutes: 1}) | date: 'mm') : '' }}\n                  </div>\n                  <div class=\"item arrow\"\n                       (click)=\"onModelChange(add(value, {minutes: 1}))\">\n                    <biit-icon [name]=\"'right_arrow'\"\n                               [pathStyle]=\"{fill: '#262626'}\"\n                               class=\"down\"\n                    ></biit-icon>\n                  </div>\n                </div>\n              </div>\n            </div>\n          </div>\n\n          <div class=\"year-view\" *ngIf=\"monthSelector\">\n            <div class=\"month-selector\">\n              <button biit-button tertiary\n                      class=\"month-label\"\n                      (click)=\"changeView()\">\n                {{viewerDate | translocoDate: {month: 'long'} }}\n                {{viewerDate | translocoDate: {year: 'numeric'} }}\n              </button>\n            </div>\n\n            <div class=\"selector\">\n              <div class=\"column\"\n                   style=\"min-width: 8em;\">\n                <div class=\"item arrow\"\n                     (click)=\"prevMonth()\">\n                  <biit-icon [name]=\"'right_arrow'\"\n                             [pathStyle]=\"{fill: '#262626'}\"\n                             class=\"up\"\n                  ></biit-icon>\n                </div>\n                <div class=\"item tertiary\"\n                     (click)=\"viewerDate = sub(viewerDate, {months: 2})\">\n                  {{sub(viewerDate, {months: 2}) | translocoDate: {month: 'long'} }}\n                </div>\n                <div class=\"item secondary\"\n                     (click)=\"prevMonth()\">\n                  {{sub(viewerDate, {months: 1}) | translocoDate: {month: 'long'} }}\n                </div>\n                <div class=\"item primary\">\n                  {{viewerDate | translocoDate: {month: 'long'} }}\n                </div>\n                <div class=\"item secondary\"\n                     (click)=\"nextMonth()\">\n                  {{add(viewerDate, {months: 1}) | translocoDate: {month: 'long'} }}\n                </div>\n                <div class=\"item tertiary\"\n                     (click)=\"viewerDate = add(viewerDate, {months: 2})\">\n                  {{add(viewerDate, {months: 2}) | translocoDate: {month: 'long'} }}\n                </div>\n                <div class=\"item arrow\"\n                     (click)=\"nextMonth()\">\n                  <biit-icon [name]=\"'right_arrow'\"\n                             [pathStyle]=\"{fill: '#262626'}\"\n                             class=\"down\"\n                  ></biit-icon>\n                </div>\n              </div>\n\n              <div class=\"column\"\n                   style=\"min-width: 5em;\">\n                <div class=\"item arrow\"\n                     (click)=\"viewerDate = sub(viewerDate, {years: 1})\">\n                  <biit-icon [name]=\"'right_arrow'\"\n                             [pathStyle]=\"{fill: '#262626'}\"\n                             class=\"up\"\n                  ></biit-icon>\n                </div>\n                <div class=\"item tertiary\"\n                     (click)=\"viewerDate = sub(viewerDate, {years: 2})\">\n                  {{sub(viewerDate, {years: 2}) | translocoDate: {year: 'numeric'} }}\n                </div>\n                <div class=\"item secondary\"\n                     (click)=\"viewerDate = sub(viewerDate, {years: 1})\">\n                  {{sub(viewerDate, {years: 1}) | translocoDate: {year: 'numeric'} }}\n                </div>\n                <div class=\"item primary\">\n                  {{viewerDate | translocoDate: {year: 'numeric'} }}\n                </div>\n                <div class=\"item secondary\"\n                     (click)=\"viewerDate = add(viewerDate, {years: 1})\">\n                  {{add(viewerDate, {years: 1}) | translocoDate: {year: 'numeric'} }}\n                </div>\n                <div class=\"item tertiary\"\n                     (click)=\"viewerDate = add(viewerDate, {years: 2})\">\n                  {{add(viewerDate, {years: 2}) | translocoDate: {year: 'numeric'} }}\n                </div>\n                <div class=\"item arrow\"\n                     (click)=\"viewerDate = add(viewerDate, {years: 1})\">\n                  <biit-icon [name]=\"'right_arrow'\"\n                             [pathStyle]=\"{fill: '#262626'}\"\n                             class=\"down\"\n                  ></biit-icon>\n                </div>\n              </div>\n            </div>\n\n            <div class=\"buttons\">\n              <button biit-button tertiary\n                      (click)=\"drawCalendar(); changeView()\">\n                {{'inputs.back' | transloco}}\n              </button>\n            </div>\n          </div>\n        </div>\n      </div>\n\n      <div class=\"bottom-line\"></div>\n      <div *ngIf=\"error\" class=\"input-error-msg\">\n        <a>\n          {{error}}\n        </a>\n      </div>\n      <div *ngIf=\"value | isDisabled: disabledDays: disableWeekdays: disableWeekends: min: max\" class=\"input-error-msg\">\n        <a>\n          {{'inputs.date-error' | transloco}}\n        </a>\n      </div>\n    </div>\n  </div>\n</ng-template>\n\n<ng-template #calendarModeTemplate>\n  <div class=\"popup calendar-mode\"\n       [style.height]=\"!monthSelector && timePicker ? 'calc(29.1em + 3px)' : null\">\n    <div *ngIf=\"!monthSelector\"\n         class=\"month-view\">\n      <div class=\"month-selector\">\n        <button biit-icon\n                [icon]=\"'right_arrow'\"\n                style=\"rotate: 180deg\"\n                (click)=\"prevMonth()\"\n        ></button>\n        <button biit-button tertiary\n                class=\"month-label\"\n                (click)=\"changeView()\">\n          {{viewerDate | translocoDate: {month: 'long'} }}\n          {{viewerDate | translocoDate: {year: 'numeric'} }}\n        </button>\n        <button biit-icon\n                [icon]=\"'right_arrow'\"\n                (click)=\"nextMonth()\"\n        ></button>\n      </div>\n\n      <div class=\"grid\">\n        <div *ngFor=\"let day of days | slice:0:7\"\n             class=\"grid-element header\">\n          {{(day | translocoDate: {weekday: 'short'}).substring(0,2) }}\n        </div>\n        <button *ngFor=\"let day of days\"\n                class=\"grid-element day\"\n                [class.outer-day]=\"day | outOfMonth: viewerDate\"\n                [class.is-today]=\"day | isToday\"\n                [class.selected]=\"day | isSameDay: value\"\n                [class.disabled]=\"day | isDisabled: disabledDays: disableWeekdays: disableWeekends: sub(min, {days: 1}): add(max, {days: 1})\"\n                (click)=\"onModelChange(day)\"\n                tabindex=\"0\"\n        >\n          {{day | calendarDate}}\n        </button>\n      </div>\n\n      <div class=\"buttons\">\n        <button biit-button tertiary\n                class=\"today-btn\"\n                (click)=\"setToday()\">\n          {{'inputs.today' | transloco}}\n        </button>\n      </div>\n    </div>\n\n    <div class=\"time-picker\" *ngIf=\"!monthSelector && timePicker\">\n      <div class=\"selector\">\n        <div class=\"column\"\n             style=\"min-width: 2em;\">\n          <div class=\"item arrow\"\n               (click)=\"onModelChange(sub(value, {hours: 1}))\">\n            <biit-icon [name]=\"'right_arrow'\"\n                       [pathStyle]=\"{fill: '#262626'}\"\n                       class=\"up\"\n            ></biit-icon>\n          </div>\n          <div class=\"item secondary\"\n               (click)=\"onModelChange(sub(value, {hours: 1}))\">\n            {{ value ? (sub(value, {hours: 1}) | date: 'H') : '' }}\n          </div>\n          <div class=\"item primary\">\n            {{ value ? (value | date: 'H') : '' }}\n          </div>\n          <div class=\"item secondary\"\n               (click)=\"onModelChange(add(value, {hours: 1}))\">\n            {{ value ? (add(value, {hours: 1}) | date: 'H') : '' }}\n          </div>\n          <div class=\"item arrow\"\n               (click)=\"onModelChange(add(value, {hours: 1}))\">\n            <biit-icon [name]=\"'right_arrow'\"\n                       [pathStyle]=\"{fill: '#262626'}\"\n                       class=\"down\"\n            ></biit-icon>\n          </div>\n        </div>\n        <div class=\"column\"\n             style=\"min-width: 2em;\">\n          <div class=\"item arrow\"\n               (click)=\"onModelChange(sub(value, {minutes: 1}))\">\n            <biit-icon [name]=\"'right_arrow'\"\n                       [pathStyle]=\"{fill: '#262626'}\"\n                       class=\"up\"\n            ></biit-icon>\n          </div>\n          <div class=\"item secondary\"\n               (click)=\"onModelChange(sub(value, {hours: 1}))\">\n            {{ value ? (sub(value, {minutes: 1}) | date: 'mm') : '' }}\n          </div>\n          <div class=\"item primary\">\n            {{ value ? (value | date: 'mm') : '' }}\n          </div>\n          <div class=\"item secondary\"\n               (click)=\"onModelChange(add(value, {hours: 1}))\">\n            {{ value ? (add(value, {minutes: 1}) | date: 'mm') : '' }}\n          </div>\n          <div class=\"item arrow\"\n               (click)=\"onModelChange(add(value, {minutes: 1}))\">\n            <biit-icon [name]=\"'right_arrow'\"\n                       [pathStyle]=\"{fill: '#262626'}\"\n                       class=\"down\"\n            ></biit-icon>\n          </div>\n        </div>\n      </div>\n    </div>\n\n    <div class=\"year-view\" *ngIf=\"monthSelector\">\n      <div class=\"month-selector\">\n        <button biit-button tertiary\n                class=\"month-label\"\n                (click)=\"changeView()\">\n          {{viewerDate | translocoDate: {month: 'long'} }}\n          {{viewerDate | translocoDate: {year: 'numeric'} }}\n        </button>\n      </div>\n\n      <div class=\"selector\">\n        <div class=\"column\"\n             style=\"min-width: 8em;\">\n          <div class=\"item arrow\"\n               (click)=\"prevMonth()\">\n            <biit-icon [name]=\"'right_arrow'\"\n                       [pathStyle]=\"{fill: '#262626'}\"\n                       class=\"up\"\n            ></biit-icon>\n          </div>\n          <div class=\"item tertiary\"\n               (click)=\"viewerDate = sub(viewerDate, {months: 2})\">\n            {{sub(viewerDate, {months: 2}) | translocoDate: {month: 'long'} }}\n          </div>\n          <div class=\"item secondary\"\n               (click)=\"prevMonth()\">\n            {{sub(viewerDate, {months: 1}) | translocoDate: {month: 'long'} }}\n          </div>\n          <div class=\"item primary\">\n            {{viewerDate | translocoDate: {month: 'long'} }}\n          </div>\n          <div class=\"item secondary\"\n               (click)=\"nextMonth()\">\n            {{add(viewerDate, {months: 1}) | translocoDate: {month: 'long'} }}\n          </div>\n          <div class=\"item tertiary\"\n               (click)=\"viewerDate = add(viewerDate, {months: 2})\">\n            {{add(viewerDate, {months: 2}) | translocoDate: {month: 'long'} }}\n          </div>\n          <div class=\"item arrow\"\n               (click)=\"nextMonth()\">\n            <biit-icon [name]=\"'right_arrow'\"\n                       [pathStyle]=\"{fill: '#262626'}\"\n                       class=\"down\"\n            ></biit-icon>\n          </div>\n        </div>\n\n        <div class=\"column\"\n             style=\"min-width: 5em;\">\n          <div class=\"item arrow\"\n               (click)=\"viewerDate = sub(viewerDate, {years: 1})\">\n            <biit-icon [name]=\"'right_arrow'\"\n                       [pathStyle]=\"{fill: '#262626'}\"\n                       class=\"up\"\n            ></biit-icon>\n          </div>\n          <div class=\"item tertiary\"\n               (click)=\"viewerDate = sub(viewerDate, {years: 2})\">\n            {{sub(viewerDate, {years: 2}) | translocoDate: {year: 'numeric'} }}\n          </div>\n          <div class=\"item secondary\"\n               (click)=\"viewerDate = sub(viewerDate, {years: 1})\">\n            {{sub(viewerDate, {years: 1}) | translocoDate: {year: 'numeric'} }}\n          </div>\n          <div class=\"item primary\">\n            {{viewerDate | translocoDate: {year: 'numeric'} }}\n          </div>\n          <div class=\"item secondary\"\n               (click)=\"viewerDate = add(viewerDate, {years: 1})\">\n            {{add(viewerDate, {years: 1}) | translocoDate: {year: 'numeric'} }}\n          </div>\n          <div class=\"item tertiary\"\n               (click)=\"viewerDate = add(viewerDate, {years: 2})\">\n            {{add(viewerDate, {years: 2}) | translocoDate: {year: 'numeric'} }}\n          </div>\n          <div class=\"item arrow\"\n               (click)=\"viewerDate = add(viewerDate, {years: 1})\">\n            <biit-icon [name]=\"'right_arrow'\"\n                       [pathStyle]=\"{fill: '#262626'}\"\n                       class=\"down\"\n            ></biit-icon>\n          </div>\n        </div>\n      </div>\n\n      <div class=\"buttons\">\n        <button biit-button tertiary\n                (click)=\"drawCalendar(); changeView()\">\n          {{'inputs.back' | transloco}}\n        </button>\n      </div>\n    </div>\n  </div>\n</ng-template>\n"]}
@@ -139,4 +139,4 @@ export var Type;
139
139
  Type["EMAIL"] = "EMAIL";
140
140
  Type["PASSWORD"] = "PASSWORD";
141
141
  })(Type || (Type = {}));
142
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"biit-input-text.component.js","sourceRoot":"","sources":["../../../../../projects/wizardry-theme/inputs/src/biit-input-text/biit-input-text.component.ts","../../../../../projects/wizardry-theme/inputs/src/biit-input-text/biit-input-text.component.html"],"names":[],"mappings":"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","sourcesContent":["import {Component, EventEmitter, forwardRef, Input, OnInit, Output, ChangeDetectorRef} from '@angular/core';\nimport {ControlValueAccessor, NG_VALUE_ACCESSOR} from \"@angular/forms\";\nimport {biitIcon} from '@biit-solutions/biit-icons-collection';\nimport {TRANSLOCO_SCOPE} from \"@ngneat/transloco\";\nimport {coerceBooleanProperty} from \"@angular/cdk/coercion\";\n\n@Component({\n  selector: 'biit-input-text',\n  templateUrl: './biit-input-text.component.html',\n  styleUrls: ['./biit-input-text.component.scss'],\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => BiitInputTextComponent),\n      multi: true\n    },\n    {\n      provide: TRANSLOCO_SCOPE,\n      useValue: {scope: 'wizardry-theme/inputs', alias: \"inputs\"}\n    }\n  ]\n})\nexport class BiitInputTextComponent implements ControlValueAccessor, OnInit {\n\n  @Input() set placeholder(placeholder: string) {\n    this._placeholder = placeholder;\n  }\n  protected _placeholder = '';\n  @Input() error: string;\n  @Input() description: string;\n  @Input() info: string;\n  @Input() type: Type;\n  @Input() icon: biitIcon;\n  @Input() fieldName: string;\n  @Input() disabled;\n  @Input() required;\n  @Input() readonly;\n  @Input() min: number;\n  @Input() max: number;\n  @Input() minLength: number;\n  @Input() maxLength: number;\n  @Input() regEx: RegExp;\n  @Output() onActionPerformed: EventEmitter<string> = new EventEmitter<string>();\n\n  reveal: boolean = false;\n  value: string;\n  minLengthError: boolean = false;\n  regExError: boolean = false;\n  protected readonly Type = Type;\n\n  ngOnInit() {\n    this.disabled = coerceBooleanProperty(this.disabled);\n    this.required = coerceBooleanProperty(this.required);\n    this.readonly = coerceBooleanProperty(this.readonly);\n\n    if (this.type == Type.EMAIL) {\n      this.regEx = new RegExp(\"(?:[a-z0-9!#$%&'*+/=?^_`{|}~-]+(?:\\\\.[a-z0-9!#$%&'*+/=?^_`{|}~-]+)*|\\\"(?:[\\x01-\\x08\\x0b\\x0c\\x0e-\\x1f\\x21\\x23-\\x5b\\x5d-\\x7f]|\\\\\\\\[\\x01-\\x09\\x0b\\x0c\\x0e-\\x7f])*\\\")@(?:(?:[a-z0-9](?:[a-z0-9-]*[a-z0-9])?\\\\.)+[a-z0-9](?:[a-z0-9-]*[a-z0-9])?|\\\\[(?:(?:25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)\\\\.){3}(?:25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?|[a-z0-9-]*[a-z0-9]:(?:[\\x01-\\x08\\x0b\\x0c\\x0e-\\x1f\\x21-\\x5a\\x53-\\x7f]|\\\\\\\\[\\x01-\\x09\\x0b\\x0c\\x0e-\\x7f])+)\\\\])\");\n    }\n  }\n\n  validateInput() {\n    if (this.value !== undefined) {\n      if (this.regEx) {\n        this.regExError = !this.regEx.test(this.value);\n      }\n      if (this.minLength) {\n        this.minLengthError = this.value.length < this.minLength;\n      }\n    } else {\n      this.regExError = false;\n      this.minLengthError = false;\n    }\n  }\n\n  onChange = (_: any) => {};\n  onTouch = () => {};\n\n  registerOnChange(fn: any): void {\n    this.onChange = fn;\n  }\n\n  registerOnTouched(fn: any): void {\n    this.onTouch = fn;\n  }\n\n  writeValue(value: string): void {\n    this.value = value;\n  }\n\n  protected checkValue(event: KeyboardEvent) {\n    if (this.type === Type.NUMBER) {\n      const input = event.target as HTMLInputElement;\n      const cursorPos = input.selectionStart ?? 0;\n      const value = input.value;\n\n      // Allow digits and control keys\n      if (/[0-9]/.test(event.key) || ['Backspace', 'Tab', 'ArrowLeft', 'ArrowRight', 'Delete'].includes(event.key)) {\n        return;\n      }\n      // Allow '-' only at the start and if not already present\n      if (event.key === '-' && cursorPos === 0 && !value.startsWith('-')) {\n        return;\n      }\n      // Allow '.' or ',' only if neither is present\n      if ((event.key === '.' || event.key === ',') && !value.includes('.') && !value.includes(',')) {\n        return;\n      }\n      event.preventDefault();\n    }\n  }\n}\n\nexport enum Type {\n  TEXT = 'TEXT',\n  NUMBER = 'NUMBER',\n  EMAIL = 'EMAIL',\n  PASSWORD = 'PASSWORD'\n}\n","<div class=\"biit-input\" [class.disabled]=\"disabled\" [class.readonly]=\"readonly\" *transloco=\"let t\">\n  <div class=\"input-container\">\n    <biit-tooltip-icon *ngIf=\"info\"\n                       class=\"tooltip-icon\"\n                       [text]=\"info\"></biit-tooltip-icon>\n    <input\n           class=\"input-object\"\n           (keydown)=\"checkValue($event)\"\n           [(ngModel)]=\"value\"\n           (input)=\"value\"\n           (ngModelChange)=\"onChange($event); validateInput();\"\n           (keydown.enter)=\"onActionPerformed.emit(value)\"\n           [type]=\"reveal ? Type.TEXT : type\" required\n           [min]=\"min\"\n           [max]=\"max\"\n           [minlength]=\"minLength\"\n           [maxlength]=\"maxLength ? maxLength : 100\"\n           [attr.name]=\"fieldName\"\n           [class.error]=\"error || regExError || minLengthError\"\n           [class.reveal]=\"reveal\"\n    >\n    <div *ngIf=\"type === Type.PASSWORD || icon\" class=\"input-show-icon-container\"\n         (click)=\"reveal = (type === Type.PASSWORD ? !reveal : false); onActionPerformed.emit(value)\"\n         (keydown.enter)=\"reveal = (type === Type.PASSWORD ? !reveal : false); onActionPerformed.emit(value)\"\n         tabindex=\"0\">\n      <biit-icon [name]=\"type === Type.PASSWORD ? 'show' : icon\"\n                 class=\"input-show-icon\"\n                 [pathStyle]=\"{fill: reveal ? '#F20D5E' : '#262626'}\"\n      ></biit-icon>\n    </div>\n    <div class=\"input-placeholder\" [class.input-filled]=\"this.value?.toString().length\">\n      {{ _placeholder }}\n      <a *ngIf=\"required\"\n         [style.color]=\"value ? null : 'red'\">*</a>\n    </div>\n    <biit-icon *ngIf=\"error || regExError || minLengthError\" id=\"exclamation\" name=\"exclamation\"\n               class=\"input-error-icon\" [pathStyle]=\"{fill:'#A1093F'}\"></biit-icon>\n    <div class=\"bottom-line\"\n         [class.disabled]=\"disabled\"\n         [class.readonly]=\"readonly\"\n    ></div>\n    <div *ngIf=\"error\" class=\"input-error-msg\" id=\"error-message\">\n      <a id=\"message\">\n        {{ error }}\n      </a>\n    </div>\n    <div *ngIf=\"regExError && !error\" id=\"regex-error-message\" class=\"input-error-msg\">\n      <a id=\"regex-message\">\n        {{ t('inputs.regex-error') }}\n      </a>\n    </div>\n    <div *ngIf=\"minLengthError && !error && !regExError\" id=\"length-error-message\" class=\"input-error-msg\">\n      <a id=\"length-message\">\n        {{ t('inputs.minlength-error') }}\n      </a>\n    </div>\n    <span *ngIf=\"description\" id=\"description\" class=\"input-description\">\n      {{ description }}\n    </span>\n  </div>\n</div>\n"]}
142
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"biit-input-text.component.js","sourceRoot":"","sources":["../../../../../projects/wizardry-theme/inputs/src/biit-input-text/biit-input-text.component.ts","../../../../../projects/wizardry-theme/inputs/src/biit-input-text/biit-input-text.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAC,SAAS,EAAE,YAAY,EAAE,UAAU,EAAE,KAAK,EAAU,MAAM,EAAoB,MAAM,eAAe,CAAC;AAC5G,OAAO,EAAuB,iBAAiB,EAAC,MAAM,gBAAgB,CAAC;AAEvE,OAAO,EAAC,eAAe,EAAC,MAAM,mBAAmB,CAAC;AAClD,OAAO,EAAC,qBAAqB,EAAC,MAAM,uBAAuB,CAAC;;;;;;;AAkB5D,MAAM,OAAO,sBAAsB;IAhBnC;QAqBY,iBAAY,GAAG,EAAE,CAAC;QAelB,sBAAiB,GAAyB,IAAI,YAAY,EAAU,CAAC;QAE/E,WAAM,GAAY,KAAK,CAAC;QAExB,mBAAc,GAAY,KAAK,CAAC;QAChC,eAAU,GAAY,KAAK,CAAC;QACT,SAAI,GAAG,IAAI,CAAC;QA0B/B,aAAQ,GAAG,CAAC,CAAM,EAAE,EAAE,GAAE,CAAC,CAAC;QAC1B,YAAO,GAAG,GAAG,EAAE,GAAE,CAAC,CAAC;KAmCpB;IAtFC,IAAa,WAAW,CAAC,WAAmB;QAC1C,IAAI,CAAC,YAAY,GAAG,WAAW,CAAC;IAClC,CAAC;IAwBD,QAAQ;QACN,IAAI,CAAC,QAAQ,GAAG,qBAAqB,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QACrD,IAAI,CAAC,QAAQ,GAAG,qBAAqB,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QACrD,IAAI,CAAC,QAAQ,GAAG,qBAAqB,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QAErD,IAAI,IAAI,CAAC,IAAI,IAAI,IAAI,CAAC,KAAK,EAAE;YAC3B,IAAI,CAAC,KAAK,GAAG,IAAI,MAAM,CAAC,ubAAub,CAAC,CAAC;SACld;IACH,CAAC;IAED,aAAa;QACX,IAAI,IAAI,CAAC,KAAK,KAAK,SAAS,EAAE;YAC5B,IAAI,IAAI,CAAC,KAAK,EAAE;gBACd,IAAI,CAAC,UAAU,GAAG,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;aAChD;YACD,IAAI,IAAI,CAAC,SAAS,EAAE;gBAClB,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,GAAG,IAAI,CAAC,SAAS,CAAC;aAC1D;SACF;aAAM;YACL,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC;YACxB,IAAI,CAAC,cAAc,GAAG,KAAK,CAAC;SAC7B;IACH,CAAC;IAKD,gBAAgB,CAAC,EAAO;QACtB,IAAI,CAAC,QAAQ,GAAG,EAAE,CAAC;IACrB,CAAC;IAED,iBAAiB,CAAC,EAAO;QACvB,IAAI,CAAC,OAAO,GAAG,EAAE,CAAC;IACpB,CAAC;IAED,UAAU,CAAC,KAAa;QACtB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;IACrB,CAAC;IAES,UAAU,CAAC,KAAoB;QACvC,IAAI,IAAI,CAAC,IAAI,KAAK,IAAI,CAAC,MAAM,EAAE;YAC7B,MAAM,KAAK,GAAG,KAAK,CAAC,MAA0B,CAAC;YAC/C,MAAM,SAAS,GAAG,KAAK,CAAC,cAAc,IAAI,CAAC,CAAC;YAC5C,MAAM,KAAK,GAAG,KAAK,CAAC,KAAK,CAAC;YAE1B,gCAAgC;YAChC,IAAI,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,WAAW,EAAE,KAAK,EAAE,WAAW,EAAE,YAAY,EAAE,QAAQ,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC,GAAG,CAAC,EAAE;gBAC5G,OAAO;aACR;YACD,yDAAyD;YACzD,IAAI,KAAK,CAAC,GAAG,KAAK,GAAG,IAAI,SAAS,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,GAAG,CAAC,EAAE;gBAClE,OAAO;aACR;YACD,8CAA8C;YAC9C,IAAI,CAAC,KAAK,CAAC,GAAG,KAAK,GAAG,IAAI,KAAK,CAAC,GAAG,KAAK,GAAG,CAAC,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,GAAG,CAAC,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,GAAG,CAAC,EAAE;gBAC5F,OAAO;aACR;YACD,KAAK,CAAC,cAAc,EAAE,CAAC;SACxB;IACH,CAAC;;oHAvFU,sBAAsB;wGAAtB,sBAAsB,+YAZtB;QACT;YACE,OAAO,EAAE,iBAAiB;YAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,sBAAsB,CAAC;YACrD,KAAK,EAAE,IAAI;SACZ;QACD;YACE,OAAO,EAAE,eAAe;YACxB,QAAQ,EAAE,EAAC,KAAK,EAAE,uBAAuB,EAAE,KAAK,EAAE,QAAQ,EAAC;SAC5D;KACF,0BCpBH,+oFA6DA;4FDvCa,sBAAsB;kBAhBlC,SAAS;+BACE,iBAAiB,aAGhB;wBACT;4BACE,OAAO,EAAE,iBAAiB;4BAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,uBAAuB,CAAC;4BACrD,KAAK,EAAE,IAAI;yBACZ;wBACD;4BACE,OAAO,EAAE,eAAe;4BACxB,QAAQ,EAAE,EAAC,KAAK,EAAE,uBAAuB,EAAE,KAAK,EAAE,QAAQ,EAAC;yBAC5D;qBACF;8BAIY,WAAW;sBAAvB,KAAK;gBAIG,KAAK;sBAAb,KAAK;gBACG,WAAW;sBAAnB,KAAK;gBACG,IAAI;sBAAZ,KAAK;gBACG,IAAI;sBAAZ,KAAK;gBACG,IAAI;sBAAZ,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBACG,GAAG;sBAAX,KAAK;gBACG,GAAG;sBAAX,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBACG,KAAK;sBAAb,KAAK;gBACI,iBAAiB;sBAA1B,MAAM;;AAsET,MAAM,CAAN,IAAY,IAKX;AALD,WAAY,IAAI;IACd,qBAAa,CAAA;IACb,yBAAiB,CAAA;IACjB,uBAAe,CAAA;IACf,6BAAqB,CAAA;AACvB,CAAC,EALW,IAAI,KAAJ,IAAI,QAKf","sourcesContent":["import {Component, EventEmitter, forwardRef, Input, OnInit, Output, ChangeDetectorRef} from '@angular/core';\nimport {ControlValueAccessor, NG_VALUE_ACCESSOR} from \"@angular/forms\";\nimport {biitIcon} from '@biit-solutions/biit-icons-collection';\nimport {TRANSLOCO_SCOPE} from \"@ngneat/transloco\";\nimport {coerceBooleanProperty} from \"@angular/cdk/coercion\";\n\n@Component({\n  selector: 'biit-input-text',\n  templateUrl: './biit-input-text.component.html',\n  styleUrls: ['./biit-input-text.component.scss'],\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => BiitInputTextComponent),\n      multi: true\n    },\n    {\n      provide: TRANSLOCO_SCOPE,\n      useValue: {scope: 'wizardry-theme/inputs', alias: \"inputs\"}\n    }\n  ]\n})\nexport class BiitInputTextComponent implements ControlValueAccessor, OnInit {\n\n  @Input() set placeholder(placeholder: string) {\n    this._placeholder = placeholder;\n  }\n  protected _placeholder = '';\n  @Input() error: string | undefined;\n  @Input() description: string;\n  @Input() info: string;\n  @Input() type: Type;\n  @Input() icon: biitIcon;\n  @Input() fieldName: string;\n  @Input() disabled;\n  @Input() required;\n  @Input() readonly;\n  @Input() min: number;\n  @Input() max: number;\n  @Input() minLength: number;\n  @Input() maxLength: number;\n  @Input() regEx: RegExp;\n  @Output() onActionPerformed: EventEmitter<string> = new EventEmitter<string>();\n\n  reveal: boolean = false;\n  value: string;\n  minLengthError: boolean = false;\n  regExError: boolean = false;\n  protected readonly Type = Type;\n\n  ngOnInit() {\n    this.disabled = coerceBooleanProperty(this.disabled);\n    this.required = coerceBooleanProperty(this.required);\n    this.readonly = coerceBooleanProperty(this.readonly);\n\n    if (this.type == Type.EMAIL) {\n      this.regEx = new RegExp(\"(?:[a-z0-9!#$%&'*+/=?^_`{|}~-]+(?:\\\\.[a-z0-9!#$%&'*+/=?^_`{|}~-]+)*|\\\"(?:[\\x01-\\x08\\x0b\\x0c\\x0e-\\x1f\\x21\\x23-\\x5b\\x5d-\\x7f]|\\\\\\\\[\\x01-\\x09\\x0b\\x0c\\x0e-\\x7f])*\\\")@(?:(?:[a-z0-9](?:[a-z0-9-]*[a-z0-9])?\\\\.)+[a-z0-9](?:[a-z0-9-]*[a-z0-9])?|\\\\[(?:(?:25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)\\\\.){3}(?:25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?|[a-z0-9-]*[a-z0-9]:(?:[\\x01-\\x08\\x0b\\x0c\\x0e-\\x1f\\x21-\\x5a\\x53-\\x7f]|\\\\\\\\[\\x01-\\x09\\x0b\\x0c\\x0e-\\x7f])+)\\\\])\");\n    }\n  }\n\n  validateInput() {\n    if (this.value !== undefined) {\n      if (this.regEx) {\n        this.regExError = !this.regEx.test(this.value);\n      }\n      if (this.minLength) {\n        this.minLengthError = this.value.length < this.minLength;\n      }\n    } else {\n      this.regExError = false;\n      this.minLengthError = false;\n    }\n  }\n\n  onChange = (_: any) => {};\n  onTouch = () => {};\n\n  registerOnChange(fn: any): void {\n    this.onChange = fn;\n  }\n\n  registerOnTouched(fn: any): void {\n    this.onTouch = fn;\n  }\n\n  writeValue(value: string): void {\n    this.value = value;\n  }\n\n  protected checkValue(event: KeyboardEvent) {\n    if (this.type === Type.NUMBER) {\n      const input = event.target as HTMLInputElement;\n      const cursorPos = input.selectionStart ?? 0;\n      const value = input.value;\n\n      // Allow digits and control keys\n      if (/[0-9]/.test(event.key) || ['Backspace', 'Tab', 'ArrowLeft', 'ArrowRight', 'Delete'].includes(event.key)) {\n        return;\n      }\n      // Allow '-' only at the start and if not already present\n      if (event.key === '-' && cursorPos === 0 && !value.startsWith('-')) {\n        return;\n      }\n      // Allow '.' or ',' only if neither is present\n      if ((event.key === '.' || event.key === ',') && !value.includes('.') && !value.includes(',')) {\n        return;\n      }\n      event.preventDefault();\n    }\n  }\n}\n\nexport enum Type {\n  TEXT = 'TEXT',\n  NUMBER = 'NUMBER',\n  EMAIL = 'EMAIL',\n  PASSWORD = 'PASSWORD'\n}\n","<div class=\"biit-input\" [class.disabled]=\"disabled\" [class.readonly]=\"readonly\" *transloco=\"let t\">\n  <div class=\"input-container\">\n    <biit-tooltip-icon *ngIf=\"info\"\n                       class=\"tooltip-icon\"\n                       [text]=\"info\"></biit-tooltip-icon>\n    <input\n           class=\"input-object\"\n           (keydown)=\"checkValue($event)\"\n           [(ngModel)]=\"value\"\n           (input)=\"value\"\n           (ngModelChange)=\"onChange($event); validateInput();\"\n           (keydown.enter)=\"onActionPerformed.emit(value)\"\n           [type]=\"reveal ? Type.TEXT : type\" required\n           [min]=\"min\"\n           [max]=\"max\"\n           [minlength]=\"minLength\"\n           [maxlength]=\"maxLength ? maxLength : 100\"\n           [attr.name]=\"fieldName\"\n           [class.error]=\"error || regExError || minLengthError\"\n           [class.reveal]=\"reveal\"\n    >\n    <div *ngIf=\"type === Type.PASSWORD || icon\" class=\"input-show-icon-container\"\n         (click)=\"reveal = (type === Type.PASSWORD ? !reveal : false); onActionPerformed.emit(value)\"\n         (keydown.enter)=\"reveal = (type === Type.PASSWORD ? !reveal : false); onActionPerformed.emit(value)\"\n         tabindex=\"0\">\n      <biit-icon [name]=\"type === Type.PASSWORD ? 'show' : icon\"\n                 class=\"input-show-icon\"\n                 [pathStyle]=\"{fill: reveal ? '#F20D5E' : '#262626'}\"\n      ></biit-icon>\n    </div>\n    <div class=\"input-placeholder\" [class.input-filled]=\"this.value?.toString().length\">\n      {{ _placeholder }}\n      <a *ngIf=\"required\"\n         [style.color]=\"value ? null : 'red'\">*</a>\n    </div>\n    <biit-icon *ngIf=\"error || regExError || minLengthError\" id=\"exclamation\" name=\"exclamation\"\n               class=\"input-error-icon\" [pathStyle]=\"{fill:'#A1093F'}\"></biit-icon>\n    <div class=\"bottom-line\"\n         [class.disabled]=\"disabled\"\n         [class.readonly]=\"readonly\"\n    ></div>\n    <div *ngIf=\"error\" class=\"input-error-msg\" id=\"error-message\">\n      <a id=\"message\">\n        {{ error }}\n      </a>\n    </div>\n    <div *ngIf=\"regExError && !error\" id=\"regex-error-message\" class=\"input-error-msg\">\n      <a id=\"regex-message\">\n        {{ t('inputs.regex-error') }}\n      </a>\n    </div>\n    <div *ngIf=\"minLengthError && !error && !regExError\" id=\"length-error-message\" class=\"input-error-msg\">\n      <a id=\"length-message\">\n        {{ t('inputs.minlength-error') }}\n      </a>\n    </div>\n    <span *ngIf=\"description\" id=\"description\" class=\"input-description\">\n      {{ description }}\n    </span>\n  </div>\n</div>\n"]}
@@ -96,4 +96,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImpo
96
96
  }], onActionPerformed: [{
97
97
  type: Output
98
98
  }] } });
99
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmlpdC10ZXh0YXJlYS5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy93aXphcmRyeS10aGVtZS9pbnB1dHMvc3JjL2JpaXQtdGV4dGFyZWEvYmlpdC10ZXh0YXJlYS5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy93aXphcmRyeS10aGVtZS9pbnB1dHMvc3JjL2JpaXQtdGV4dGFyZWEvYmlpdC10ZXh0YXJlYS5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsU0FBUyxFQUFFLFlBQVksRUFBRSxVQUFVLEVBQUUsS0FBSyxFQUFVLE1BQU0sRUFBQyxNQUFNLGVBQWUsQ0FBQztBQUN6RixPQUFPLEVBQXVCLGlCQUFpQixFQUFDLE1BQU0sZ0JBQWdCLENBQUM7Ozs7OztBQWV2RSxNQUFNLE9BQU8scUJBQXFCO0lBWmxDO1FBY1csZ0JBQVcsR0FBVyxFQUFFLENBQUM7UUFZeEIsc0JBQWlCLEdBQXlCLElBQUksWUFBWSxFQUFVLENBQUM7UUFFL0UsV0FBTSxHQUFZLEtBQUssQ0FBQztRQUN4QixXQUFNLEdBQVcsTUFBTSxDQUFDO1FBOEJ4QixhQUFRLEdBQUcsQ0FBQyxDQUFNLEVBQUUsRUFBRSxHQUFFLENBQUMsQ0FBQztRQUMxQixZQUFPLEdBQUcsR0FBRyxFQUFFLEdBQUUsQ0FBQyxDQUFDO0tBYXBCO0lBekNDLFFBQVE7UUFDTixJQUFJLENBQUMsUUFBUSxHQUFHLElBQUksQ0FBQyxpQkFBaUIsQ0FBQyxJQUFJLENBQUMsUUFBUSxDQUFDLENBQUM7UUFDdEQsSUFBSSxDQUFDLE9BQU8sR0FBRyxJQUFJLENBQUMsaUJBQWlCLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxDQUFDO1FBQ3BELElBQUksQ0FBQyxPQUFPLEdBQUcsSUFBSSxDQUFDLGlCQUFpQixDQUFDLElBQUksQ0FBQyxPQUFPLENBQUMsQ0FBQztRQUNwRCxJQUFJLENBQUMsUUFBUSxHQUFHLElBQUksQ0FBQyxpQkFBaUIsQ0FBQyxJQUFJLENBQUMsUUFBUSxDQUFDLENBQUM7UUFDdEQsSUFBSSxDQUFDLFFBQVEsR0FBRyxJQUFJLENBQUMsaUJBQWlCLENBQUMsSUFBSSxDQUFDLFFBQVEsQ0FBQyxDQUFDO1FBRXRELElBQUksSUFBSSxDQUFDLE9BQU8sSUFBSSxJQUFJLENBQUMsT0FBTyxFQUFFO1lBQ2hDLElBQUksQ0FBQyxNQUFNLEdBQUcsTUFBTSxDQUFBO1NBQ3JCO2FBQU0sSUFBSSxJQUFJLENBQUMsT0FBTyxFQUFFO1lBQ3ZCLElBQUksQ0FBQyxNQUFNLEdBQUcsWUFBWSxDQUFDO1NBQzVCO2FBQU0sSUFBSSxJQUFJLENBQUMsT0FBTyxFQUFFO1lBQ3ZCLElBQUksQ0FBQyxNQUFNLEdBQUcsVUFBVSxDQUFDO1NBQzFCO0lBQ0gsQ0FBQztJQUVELGlCQUFpQixDQUFDLEtBQUs7UUFDckIsUUFBUSxLQUFLLEVBQUU7WUFDYixLQUFLLFNBQVM7Z0JBQ1osT0FBTyxLQUFLLENBQUM7WUFDZixLQUFLLEtBQUs7Z0JBQ1IsT0FBTyxLQUFLLENBQUM7WUFDZjtnQkFDRSxPQUFPLElBQUksQ0FBQztTQUNmO0lBQ0gsQ0FBQztJQUtELGdCQUFnQixDQUFDLEVBQU87UUFDdEIsSUFBSSxDQUFDLFFBQVEsR0FBRyxFQUFFLENBQUM7SUFDckIsQ0FBQztJQUVELGlCQUFpQixDQUFDLEVBQU87UUFDdkIsSUFBSSxDQUFDLE9BQU8sR0FBRyxFQUFFLENBQUM7SUFDcEIsQ0FBQztJQUVELFVBQVUsQ0FBQyxLQUFhO1FBQ3RCLElBQUksQ0FBQyxLQUFLLEdBQUcsS0FBSyxDQUFDO0lBQ3JCLENBQUM7O21IQTVEVSxxQkFBcUI7dUdBQXJCLHFCQUFxQixtWUFSckI7UUFDVDtZQUNFLE9BQU8sRUFBRSxpQkFBaUI7WUFDMUIsV0FBVyxFQUFFLFVBQVUsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxxQkFBcUIsQ0FBQztZQUNwRCxLQUFLLEVBQUUsSUFBSTtTQUNaO0tBQ0YsMEJDZEgsbXVDQWlDQTs0RkRqQmEscUJBQXFCO2tCQVpqQyxTQUFTOytCQUNFLGVBQWUsYUFHZDt3QkFDVDs0QkFDRSxPQUFPLEVBQUUsaUJBQWlCOzRCQUMxQixXQUFXLEVBQUUsVUFBVSxDQUFDLEdBQUcsRUFBRSxzQkFBc0IsQ0FBQzs0QkFDcEQsS0FBSyxFQUFFLElBQUk7eUJBQ1o7cUJBQ0Y7OEJBSVEsV0FBVztzQkFBbkIsS0FBSztnQkFDRyxLQUFLO3NCQUFiLEtBQUs7Z0JBQ0csV0FBVztzQkFBbkIsS0FBSztnQkFDRyxJQUFJO3NCQUFaLEtBQUs7Z0JBQ0csSUFBSTtzQkFBWixLQUFLO2dCQUNHLFNBQVM7c0JBQWpCLEtBQUs7Z0JBQ0csU0FBUztzQkFBakIsS0FBSztnQkFDRyxRQUFRO3NCQUFoQixLQUFLO2dCQUNhLE9BQU87c0JBQXpCLEtBQUs7dUJBQUMsVUFBVTtnQkFDRSxPQUFPO3NCQUF6QixLQUFLO3VCQUFDLFVBQVU7Z0JBQ1IsUUFBUTtzQkFBaEIsS0FBSztnQkFDRyxRQUFRO3NCQUFoQixLQUFLO2dCQUNJLGlCQUFpQjtzQkFBMUIsTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7Q29tcG9uZW50LCBFdmVudEVtaXR0ZXIsIGZvcndhcmRSZWYsIElucHV0LCBPbkluaXQsIE91dHB1dH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQge0NvbnRyb2xWYWx1ZUFjY2Vzc29yLCBOR19WQUxVRV9BQ0NFU1NPUn0gZnJvbSBcIkBhbmd1bGFyL2Zvcm1zXCI7XG5pbXBvcnQge2JpaXRJY29ufSBmcm9tICdAYmlpdC1zb2x1dGlvbnMvYmlpdC1pY29ucy1jb2xsZWN0aW9uJztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnYmlpdC10ZXh0YXJlYScsXG4gIHRlbXBsYXRlVXJsOiAnLi9iaWl0LXRleHRhcmVhLmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmxzOiBbJy4vYmlpdC10ZXh0YXJlYS5jb21wb25lbnQuc2NzcyddLFxuICBwcm92aWRlcnM6IFtcbiAgICB7XG4gICAgICBwcm92aWRlOiBOR19WQUxVRV9BQ0NFU1NPUixcbiAgICAgIHVzZUV4aXN0aW5nOiBmb3J3YXJkUmVmKCgpID0+IEJpaXRUZXh0YXJlYUNvbXBvbmVudCksXG4gICAgICBtdWx0aTogdHJ1ZVxuICAgIH1cbiAgXVxufSlcbmV4cG9ydCBjbGFzcyBCaWl0VGV4dGFyZWFDb21wb25lbnQgaW1wbGVtZW50cyBDb250cm9sVmFsdWVBY2Nlc3NvciwgT25Jbml0IHtcblxuICBASW5wdXQoKSBwbGFjZWhvbGRlcjogc3RyaW5nID0gJyc7XG4gIEBJbnB1dCgpIGVycm9yOiBzdHJpbmc7XG4gIEBJbnB1dCgpIGRlc2NyaXB0aW9uOiBzdHJpbmc7XG4gIEBJbnB1dCgpIGluZm86IHN0cmluZztcbiAgQElucHV0KCkgaWNvbjogYmlpdEljb247XG4gIEBJbnB1dCgpIGZpZWxkTmFtZTogc3RyaW5nO1xuICBASW5wdXQoKSBtYXhMZW5ndGg6IG51bWJlcjtcbiAgQElucHV0KCkgcmVhZG9ubHk6IGJvb2xlYW47XG4gIEBJbnB1dCgncmVzaXplLXgnKSByZXNpemVYOiBib29sZWFuO1xuICBASW5wdXQoJ3Jlc2l6ZS15JykgcmVzaXplWTogYm9vbGVhbjtcbiAgQElucHV0KCkgZGlzYWJsZWQ6IGJvb2xlYW47XG4gIEBJbnB1dCgpIHJlcXVpcmVkOiBib29sZWFuO1xuICBAT3V0cHV0KCkgb25BY3Rpb25QZXJmb3JtZWQ6IEV2ZW50RW1pdHRlcjxzdHJpbmc+ID0gbmV3IEV2ZW50RW1pdHRlcjxzdHJpbmc+KCk7XG5cbiAgcmV2ZWFsOiBib29sZWFuID0gZmFsc2U7XG4gIHJlc2l6ZTogc3RyaW5nID0gJ25vbmUnO1xuICB2YWx1ZTogc3RyaW5nO1xuXG4gIG5nT25Jbml0KCkge1xuICAgIHRoaXMucmVhZG9ubHkgPSB0aGlzLmNoZWNrQm9vbGVhbklucHV0KHRoaXMucmVhZG9ubHkpO1xuICAgIHRoaXMucmVzaXplWCA9IHRoaXMuY2hlY2tCb29sZWFuSW5wdXQodGhpcy5yZXNpemVYKTtcbiAgICB0aGlzLnJlc2l6ZVkgPSB0aGlzLmNoZWNrQm9vbGVhbklucHV0KHRoaXMucmVzaXplWCk7XG4gICAgdGhpcy5kaXNhYmxlZCA9IHRoaXMuY2hlY2tCb29sZWFuSW5wdXQodGhpcy5kaXNhYmxlZCk7XG4gICAgdGhpcy5yZXF1aXJlZCA9IHRoaXMuY2hlY2tCb29sZWFuSW5wdXQodGhpcy5yZXF1aXJlZCk7XG5cbiAgICBpZiAodGhpcy5yZXNpemVYICYmIHRoaXMucmVzaXplWSkge1xuICAgICAgdGhpcy5yZXNpemUgPSAnYm90aCdcbiAgICB9IGVsc2UgaWYgKHRoaXMucmVzaXplWCkge1xuICAgICAgdGhpcy5yZXNpemUgPSAnaG9yaXpvbnRhbCc7XG4gICAgfSBlbHNlIGlmICh0aGlzLnJlc2l6ZVkpIHtcbiAgICAgIHRoaXMucmVzaXplID0gJ3ZlcnRpY2FsJztcbiAgICB9XG4gIH1cblxuICBjaGVja0Jvb2xlYW5JbnB1dCh2YWx1ZSkge1xuICAgIHN3aXRjaCAodmFsdWUpIHtcbiAgICAgIGNhc2UgdW5kZWZpbmVkOlxuICAgICAgICByZXR1cm4gZmFsc2U7XG4gICAgICBjYXNlIGZhbHNlOlxuICAgICAgICByZXR1cm4gZmFsc2U7XG4gICAgICBkZWZhdWx0OlxuICAgICAgICByZXR1cm4gdHJ1ZTtcbiAgICB9XG4gIH1cblxuICBvbkNoYW5nZSA9IChfOiBhbnkpID0+IHt9O1xuICBvblRvdWNoID0gKCkgPT4ge307XG5cbiAgcmVnaXN0ZXJPbkNoYW5nZShmbjogYW55KTogdm9pZCB7XG4gICAgdGhpcy5vbkNoYW5nZSA9IGZuO1xuICB9XG5cbiAgcmVnaXN0ZXJPblRvdWNoZWQoZm46IGFueSk6IHZvaWQge1xuICAgIHRoaXMub25Ub3VjaCA9IGZuO1xuICB9XG5cbiAgd3JpdGVWYWx1ZSh2YWx1ZTogc3RyaW5nKTogdm9pZCB7XG4gICAgdGhpcy52YWx1ZSA9IHZhbHVlO1xuICB9XG59XG4iLCI8ZGl2IGNsYXNzPVwiYmlpdC1pbnB1dFwiIFtjbGFzcy5kaXNhYmxlZF09XCJkaXNhYmxlZFwiIFtjbGFzcy5yZWFkb25seV09XCJyZWFkb25seVwiPlxuICA8ZGl2IGNsYXNzPVwiaW5wdXQtY29udGFpbmVyXCI+XG4gICAgPGJpaXQtdG9vbHRpcC1pY29uICpuZ0lmPVwiaW5mb1wiXG4gICAgICAgICAgICAgICAgICAgICAgIGNsYXNzPVwidG9vbHRpcC1pY29uXCJcbiAgICAgICAgICAgICAgICAgICAgICAgW3RleHRdPVwiaW5mb1wiPjwvYmlpdC10b29sdGlwLWljb24+XG4gICAgPHRleHRhcmVhXG4gICAgICBjbGFzcz1cImlucHV0LW9iamVjdFwiIHJlcXVpcmVkXG4gICAgICBbKG5nTW9kZWwpXT1cInZhbHVlXCJcbiAgICAgIChuZ01vZGVsQ2hhbmdlKT1cInRoaXMub25DaGFuZ2UoJGV2ZW50KTtcIlxuICAgICAgKGtleWRvd24uZW50ZXIpPVwib25BY3Rpb25QZXJmb3JtZWQuZW1pdCh2YWx1ZSlcIlxuICAgICAgW2F0dHIubmFtZV09XCJmaWVsZE5hbWVcIlxuICAgICAgW2F0dHIubWF4bGVuZ3RoXT1cIm1heExlbmd0aFwiXG4gICAgICBbY2xhc3MuZXJyb3JdPVwiZXJyb3JcIlxuICAgICAgW2NsYXNzLnJldmVhbF09XCJyZXZlYWxcIlxuICAgICAgW3N0eWxlLnJlc2l6ZV09XCJyZXNpemVcIlxuICAgID48L3RleHRhcmVhPlxuICAgIDxkaXYgY2xhc3M9XCJpbnB1dC1wbGFjZWhvbGRlclwiPlxuICAgICAge3sgcGxhY2Vob2xkZXIgfX1cbiAgICAgIDxhICpuZ0lmPVwicmVxdWlyZWRcIlxuICAgICAgICAgW3N0eWxlLmNvbG9yXT1cInZhbHVlID8gbnVsbCA6ICdyZWQnXCI+KjwvYT5cbiAgICA8L2Rpdj5cbiAgICA8YmlpdC1pY29uICpuZ0lmPVwiZXJyb3JcIiBpZD1cImV4Y2xhbWF0aW9uXCIgbmFtZT1cImV4Y2xhbWF0aW9uXCIgY2xhc3M9XCJpbnB1dC1lcnJvci1pY29uXCJcbiAgICAgICAgICAgICAgIFtwYXRoU3R5bGVdPVwie2ZpbGw6JyNBMTA5M0YnfVwiPjwvYmlpdC1pY29uPlxuICAgIDxkaXYgKm5nSWY9XCJlcnJvclwiIGNsYXNzPVwiaW5wdXQtZXJyb3ItbXNnXCIgaWQ9XCJlcnJvci1tZXNzYWdlXCI+XG4gICAgICA8YSBpZD1cIm1lc3NhZ2VcIj5cbiAgICAgICAge3sgZXJyb3IgfX1cbiAgICAgIDwvYT5cbiAgICA8L2Rpdj5cbiAgICA8c3BhbiAqbmdJZj1cImRlc2NyaXB0aW9uXCIgaWQ9XCJkZXNjcmlwdGlvblwiIGNsYXNzPVwiaW5wdXQtZGVzY3JpcHRpb25cIj5cbiAgICAgIHt7IGRlc2NyaXB0aW9uIH19XG4gICAgPC9zcGFuPlxuICA8L2Rpdj5cbjwvZGl2PlxuIl19
99
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmlpdC10ZXh0YXJlYS5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy93aXphcmRyeS10aGVtZS9pbnB1dHMvc3JjL2JpaXQtdGV4dGFyZWEvYmlpdC10ZXh0YXJlYS5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy93aXphcmRyeS10aGVtZS9pbnB1dHMvc3JjL2JpaXQtdGV4dGFyZWEvYmlpdC10ZXh0YXJlYS5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsU0FBUyxFQUFFLFlBQVksRUFBRSxVQUFVLEVBQUUsS0FBSyxFQUFVLE1BQU0sRUFBQyxNQUFNLGVBQWUsQ0FBQztBQUN6RixPQUFPLEVBQXVCLGlCQUFpQixFQUFDLE1BQU0sZ0JBQWdCLENBQUM7Ozs7OztBQWV2RSxNQUFNLE9BQU8scUJBQXFCO0lBWmxDO1FBY1csZ0JBQVcsR0FBVyxFQUFFLENBQUM7UUFZeEIsc0JBQWlCLEdBQXlCLElBQUksWUFBWSxFQUFVLENBQUM7UUFFL0UsV0FBTSxHQUFZLEtBQUssQ0FBQztRQUN4QixXQUFNLEdBQVcsTUFBTSxDQUFDO1FBOEJ4QixhQUFRLEdBQUcsQ0FBQyxDQUFNLEVBQUUsRUFBRSxHQUFFLENBQUMsQ0FBQztRQUMxQixZQUFPLEdBQUcsR0FBRyxFQUFFLEdBQUUsQ0FBQyxDQUFDO0tBYXBCO0lBekNDLFFBQVE7UUFDTixJQUFJLENBQUMsUUFBUSxHQUFHLElBQUksQ0FBQyxpQkFBaUIsQ0FBQyxJQUFJLENBQUMsUUFBUSxDQUFDLENBQUM7UUFDdEQsSUFBSSxDQUFDLE9BQU8sR0FBRyxJQUFJLENBQUMsaUJBQWlCLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxDQUFDO1FBQ3BELElBQUksQ0FBQyxPQUFPLEdBQUcsSUFBSSxDQUFDLGlCQUFpQixDQUFDLElBQUksQ0FBQyxPQUFPLENBQUMsQ0FBQztRQUNwRCxJQUFJLENBQUMsUUFBUSxHQUFHLElBQUksQ0FBQyxpQkFBaUIsQ0FBQyxJQUFJLENBQUMsUUFBUSxDQUFDLENBQUM7UUFDdEQsSUFBSSxDQUFDLFFBQVEsR0FBRyxJQUFJLENBQUMsaUJBQWlCLENBQUMsSUFBSSxDQUFDLFFBQVEsQ0FBQyxDQUFDO1FBRXRELElBQUksSUFBSSxDQUFDLE9BQU8sSUFBSSxJQUFJLENBQUMsT0FBTyxFQUFFO1lBQ2hDLElBQUksQ0FBQyxNQUFNLEdBQUcsTUFBTSxDQUFBO1NBQ3JCO2FBQU0sSUFBSSxJQUFJLENBQUMsT0FBTyxFQUFFO1lBQ3ZCLElBQUksQ0FBQyxNQUFNLEdBQUcsWUFBWSxDQUFDO1NBQzVCO2FBQU0sSUFBSSxJQUFJLENBQUMsT0FBTyxFQUFFO1lBQ3ZCLElBQUksQ0FBQyxNQUFNLEdBQUcsVUFBVSxDQUFDO1NBQzFCO0lBQ0gsQ0FBQztJQUVELGlCQUFpQixDQUFDLEtBQUs7UUFDckIsUUFBUSxLQUFLLEVBQUU7WUFDYixLQUFLLFNBQVM7Z0JBQ1osT0FBTyxLQUFLLENBQUM7WUFDZixLQUFLLEtBQUs7Z0JBQ1IsT0FBTyxLQUFLLENBQUM7WUFDZjtnQkFDRSxPQUFPLElBQUksQ0FBQztTQUNmO0lBQ0gsQ0FBQztJQUtELGdCQUFnQixDQUFDLEVBQU87UUFDdEIsSUFBSSxDQUFDLFFBQVEsR0FBRyxFQUFFLENBQUM7SUFDckIsQ0FBQztJQUVELGlCQUFpQixDQUFDLEVBQU87UUFDdkIsSUFBSSxDQUFDLE9BQU8sR0FBRyxFQUFFLENBQUM7SUFDcEIsQ0FBQztJQUVELFVBQVUsQ0FBQyxLQUFhO1FBQ3RCLElBQUksQ0FBQyxLQUFLLEdBQUcsS0FBSyxDQUFDO0lBQ3JCLENBQUM7O21IQTVEVSxxQkFBcUI7dUdBQXJCLHFCQUFxQixtWUFSckI7UUFDVDtZQUNFLE9BQU8sRUFBRSxpQkFBaUI7WUFDMUIsV0FBVyxFQUFFLFVBQVUsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxxQkFBcUIsQ0FBQztZQUNwRCxLQUFLLEVBQUUsSUFBSTtTQUNaO0tBQ0YsMEJDZEgsbXVDQWlDQTs0RkRqQmEscUJBQXFCO2tCQVpqQyxTQUFTOytCQUNFLGVBQWUsYUFHZDt3QkFDVDs0QkFDRSxPQUFPLEVBQUUsaUJBQWlCOzRCQUMxQixXQUFXLEVBQUUsVUFBVSxDQUFDLEdBQUcsRUFBRSxzQkFBc0IsQ0FBQzs0QkFDcEQsS0FBSyxFQUFFLElBQUk7eUJBQ1o7cUJBQ0Y7OEJBSVEsV0FBVztzQkFBbkIsS0FBSztnQkFDRyxLQUFLO3NCQUFiLEtBQUs7Z0JBQ0csV0FBVztzQkFBbkIsS0FBSztnQkFDRyxJQUFJO3NCQUFaLEtBQUs7Z0JBQ0csSUFBSTtzQkFBWixLQUFLO2dCQUNHLFNBQVM7c0JBQWpCLEtBQUs7Z0JBQ0csU0FBUztzQkFBakIsS0FBSztnQkFDRyxRQUFRO3NCQUFoQixLQUFLO2dCQUNhLE9BQU87c0JBQXpCLEtBQUs7dUJBQUMsVUFBVTtnQkFDRSxPQUFPO3NCQUF6QixLQUFLO3VCQUFDLFVBQVU7Z0JBQ1IsUUFBUTtzQkFBaEIsS0FBSztnQkFDRyxRQUFRO3NCQUFoQixLQUFLO2dCQUNJLGlCQUFpQjtzQkFBMUIsTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7Q29tcG9uZW50LCBFdmVudEVtaXR0ZXIsIGZvcndhcmRSZWYsIElucHV0LCBPbkluaXQsIE91dHB1dH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQge0NvbnRyb2xWYWx1ZUFjY2Vzc29yLCBOR19WQUxVRV9BQ0NFU1NPUn0gZnJvbSBcIkBhbmd1bGFyL2Zvcm1zXCI7XG5pbXBvcnQge2JpaXRJY29ufSBmcm9tICdAYmlpdC1zb2x1dGlvbnMvYmlpdC1pY29ucy1jb2xsZWN0aW9uJztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnYmlpdC10ZXh0YXJlYScsXG4gIHRlbXBsYXRlVXJsOiAnLi9iaWl0LXRleHRhcmVhLmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmxzOiBbJy4vYmlpdC10ZXh0YXJlYS5jb21wb25lbnQuc2NzcyddLFxuICBwcm92aWRlcnM6IFtcbiAgICB7XG4gICAgICBwcm92aWRlOiBOR19WQUxVRV9BQ0NFU1NPUixcbiAgICAgIHVzZUV4aXN0aW5nOiBmb3J3YXJkUmVmKCgpID0+IEJpaXRUZXh0YXJlYUNvbXBvbmVudCksXG4gICAgICBtdWx0aTogdHJ1ZVxuICAgIH1cbiAgXVxufSlcbmV4cG9ydCBjbGFzcyBCaWl0VGV4dGFyZWFDb21wb25lbnQgaW1wbGVtZW50cyBDb250cm9sVmFsdWVBY2Nlc3NvciwgT25Jbml0IHtcblxuICBASW5wdXQoKSBwbGFjZWhvbGRlcjogc3RyaW5nID0gJyc7XG4gIEBJbnB1dCgpIGVycm9yOiBzdHJpbmcgfCB1bmRlZmluZWQ7XG4gIEBJbnB1dCgpIGRlc2NyaXB0aW9uOiBzdHJpbmc7XG4gIEBJbnB1dCgpIGluZm86IHN0cmluZztcbiAgQElucHV0KCkgaWNvbjogYmlpdEljb247XG4gIEBJbnB1dCgpIGZpZWxkTmFtZTogc3RyaW5nO1xuICBASW5wdXQoKSBtYXhMZW5ndGg6IG51bWJlcjtcbiAgQElucHV0KCkgcmVhZG9ubHk6IGJvb2xlYW47XG4gIEBJbnB1dCgncmVzaXplLXgnKSByZXNpemVYOiBib29sZWFuO1xuICBASW5wdXQoJ3Jlc2l6ZS15JykgcmVzaXplWTogYm9vbGVhbjtcbiAgQElucHV0KCkgZGlzYWJsZWQ6IGJvb2xlYW47XG4gIEBJbnB1dCgpIHJlcXVpcmVkOiBib29sZWFuO1xuICBAT3V0cHV0KCkgb25BY3Rpb25QZXJmb3JtZWQ6IEV2ZW50RW1pdHRlcjxzdHJpbmc+ID0gbmV3IEV2ZW50RW1pdHRlcjxzdHJpbmc+KCk7XG5cbiAgcmV2ZWFsOiBib29sZWFuID0gZmFsc2U7XG4gIHJlc2l6ZTogc3RyaW5nID0gJ25vbmUnO1xuICB2YWx1ZTogc3RyaW5nO1xuXG4gIG5nT25Jbml0KCkge1xuICAgIHRoaXMucmVhZG9ubHkgPSB0aGlzLmNoZWNrQm9vbGVhbklucHV0KHRoaXMucmVhZG9ubHkpO1xuICAgIHRoaXMucmVzaXplWCA9IHRoaXMuY2hlY2tCb29sZWFuSW5wdXQodGhpcy5yZXNpemVYKTtcbiAgICB0aGlzLnJlc2l6ZVkgPSB0aGlzLmNoZWNrQm9vbGVhbklucHV0KHRoaXMucmVzaXplWCk7XG4gICAgdGhpcy5kaXNhYmxlZCA9IHRoaXMuY2hlY2tCb29sZWFuSW5wdXQodGhpcy5kaXNhYmxlZCk7XG4gICAgdGhpcy5yZXF1aXJlZCA9IHRoaXMuY2hlY2tCb29sZWFuSW5wdXQodGhpcy5yZXF1aXJlZCk7XG5cbiAgICBpZiAodGhpcy5yZXNpemVYICYmIHRoaXMucmVzaXplWSkge1xuICAgICAgdGhpcy5yZXNpemUgPSAnYm90aCdcbiAgICB9IGVsc2UgaWYgKHRoaXMucmVzaXplWCkge1xuICAgICAgdGhpcy5yZXNpemUgPSAnaG9yaXpvbnRhbCc7XG4gICAgfSBlbHNlIGlmICh0aGlzLnJlc2l6ZVkpIHtcbiAgICAgIHRoaXMucmVzaXplID0gJ3ZlcnRpY2FsJztcbiAgICB9XG4gIH1cblxuICBjaGVja0Jvb2xlYW5JbnB1dCh2YWx1ZSkge1xuICAgIHN3aXRjaCAodmFsdWUpIHtcbiAgICAgIGNhc2UgdW5kZWZpbmVkOlxuICAgICAgICByZXR1cm4gZmFsc2U7XG4gICAgICBjYXNlIGZhbHNlOlxuICAgICAgICByZXR1cm4gZmFsc2U7XG4gICAgICBkZWZhdWx0OlxuICAgICAgICByZXR1cm4gdHJ1ZTtcbiAgICB9XG4gIH1cblxuICBvbkNoYW5nZSA9IChfOiBhbnkpID0+IHt9O1xuICBvblRvdWNoID0gKCkgPT4ge307XG5cbiAgcmVnaXN0ZXJPbkNoYW5nZShmbjogYW55KTogdm9pZCB7XG4gICAgdGhpcy5vbkNoYW5nZSA9IGZuO1xuICB9XG5cbiAgcmVnaXN0ZXJPblRvdWNoZWQoZm46IGFueSk6IHZvaWQge1xuICAgIHRoaXMub25Ub3VjaCA9IGZuO1xuICB9XG5cbiAgd3JpdGVWYWx1ZSh2YWx1ZTogc3RyaW5nKTogdm9pZCB7XG4gICAgdGhpcy52YWx1ZSA9IHZhbHVlO1xuICB9XG59XG4iLCI8ZGl2IGNsYXNzPVwiYmlpdC1pbnB1dFwiIFtjbGFzcy5kaXNhYmxlZF09XCJkaXNhYmxlZFwiIFtjbGFzcy5yZWFkb25seV09XCJyZWFkb25seVwiPlxuICA8ZGl2IGNsYXNzPVwiaW5wdXQtY29udGFpbmVyXCI+XG4gICAgPGJpaXQtdG9vbHRpcC1pY29uICpuZ0lmPVwiaW5mb1wiXG4gICAgICAgICAgICAgICAgICAgICAgIGNsYXNzPVwidG9vbHRpcC1pY29uXCJcbiAgICAgICAgICAgICAgICAgICAgICAgW3RleHRdPVwiaW5mb1wiPjwvYmlpdC10b29sdGlwLWljb24+XG4gICAgPHRleHRhcmVhXG4gICAgICBjbGFzcz1cImlucHV0LW9iamVjdFwiIHJlcXVpcmVkXG4gICAgICBbKG5nTW9kZWwpXT1cInZhbHVlXCJcbiAgICAgIChuZ01vZGVsQ2hhbmdlKT1cInRoaXMub25DaGFuZ2UoJGV2ZW50KTtcIlxuICAgICAgKGtleWRvd24uZW50ZXIpPVwib25BY3Rpb25QZXJmb3JtZWQuZW1pdCh2YWx1ZSlcIlxuICAgICAgW2F0dHIubmFtZV09XCJmaWVsZE5hbWVcIlxuICAgICAgW2F0dHIubWF4bGVuZ3RoXT1cIm1heExlbmd0aFwiXG4gICAgICBbY2xhc3MuZXJyb3JdPVwiZXJyb3JcIlxuICAgICAgW2NsYXNzLnJldmVhbF09XCJyZXZlYWxcIlxuICAgICAgW3N0eWxlLnJlc2l6ZV09XCJyZXNpemVcIlxuICAgID48L3RleHRhcmVhPlxuICAgIDxkaXYgY2xhc3M9XCJpbnB1dC1wbGFjZWhvbGRlclwiPlxuICAgICAge3sgcGxhY2Vob2xkZXIgfX1cbiAgICAgIDxhICpuZ0lmPVwicmVxdWlyZWRcIlxuICAgICAgICAgW3N0eWxlLmNvbG9yXT1cInZhbHVlID8gbnVsbCA6ICdyZWQnXCI+KjwvYT5cbiAgICA8L2Rpdj5cbiAgICA8YmlpdC1pY29uICpuZ0lmPVwiZXJyb3JcIiBpZD1cImV4Y2xhbWF0aW9uXCIgbmFtZT1cImV4Y2xhbWF0aW9uXCIgY2xhc3M9XCJpbnB1dC1lcnJvci1pY29uXCJcbiAgICAgICAgICAgICAgIFtwYXRoU3R5bGVdPVwie2ZpbGw6JyNBMTA5M0YnfVwiPjwvYmlpdC1pY29uPlxuICAgIDxkaXYgKm5nSWY9XCJlcnJvclwiIGNsYXNzPVwiaW5wdXQtZXJyb3ItbXNnXCIgaWQ9XCJlcnJvci1tZXNzYWdlXCI+XG4gICAgICA8YSBpZD1cIm1lc3NhZ2VcIj5cbiAgICAgICAge3sgZXJyb3IgfX1cbiAgICAgIDwvYT5cbiAgICA8L2Rpdj5cbiAgICA8c3BhbiAqbmdJZj1cImRlc2NyaXB0aW9uXCIgaWQ9XCJkZXNjcmlwdGlvblwiIGNsYXNzPVwiaW5wdXQtZGVzY3JpcHRpb25cIj5cbiAgICAgIHt7IGRlc2NyaXB0aW9uIH19XG4gICAgPC9zcGFuPlxuICA8L2Rpdj5cbjwvZGl2PlxuIl19