UNPKG

@universal-material/angular

Version:

This library was generated with [Angular CLI](https://github.com/angular/angular-cli) version 16.1.0.

136 lines 20.3 kB
import { Component, forwardRef, Inject, Input, LOCALE_ID, Optional, ViewChild, ViewEncapsulation } from '@angular/core'; import { NG_VALUE_ACCESSOR } from '@angular/forms'; import { FormFieldComponent } from '../../form-field/form-field.component'; import { DropdownMenuDirective } from '../../dropdown/dropdown-menu.directive'; import { DatepickerBaseComponent } from '../datepicker-base.component'; import { DATEPICKER_DEFAULT_OPTIONS } from '../datepicker-config.model'; import { DatepickerAdapter } from '../datepicker-adapter'; import { DropdownDirective } from '../../dropdown/dropdown.directive'; import * as i0 from "@angular/core"; import * as i1 from "../default-datepicker-adapter"; import * as i2 from "@angular/common"; import * as i3 from "../../dropdown/dropdown.directive"; import * as i4 from "../../dropdown/dropdown-menu.directive"; import * as i5 from "../datepicker-content/datepicker-content.component"; import * as i6 from "../datepicker-adapter"; import * as i7 from "../../form-field/form-field.component"; const DatepickerInputValueAcessor = { provide: NG_VALUE_ACCESSOR, useExisting: forwardRef(() => DatepickerInputComponent), multi: true }; export class DatepickerInputComponent extends DatepickerBaseComponent { // get focused(): boolean { // return this._dropdownMenu && this._dropdownMenu.show; // } get empty() { return !this.date; } get disabled() { return this._disabled; } constructor(elementRef, _locale, datepickerAdapter, _defaultConfig, defaultDatepickerAdapter, formField) { super(_locale, _defaultConfig, datepickerAdapter, defaultDatepickerAdapter); this.autoClose = 'outside'; this.placeholder = null; this.direction = 'auto'; this.tabIndex = null; this.inputFormatter = null; this.date = null; this._disabled = false; this.focused = false; this._onTouched = () => { }; this._onChange = (_) => { }; elementRef.nativeElement.classList.add('u-text-input'); if (!formField) { return; } formField.selectionField = true; formField._input = this; } _setDate(date) { super._setDate(date); if (!this._onChange) { return; } this._onChange(date); if (this.autoClose && this._dropdownMenu) { this._dropdownMenu.show = false; } } focus() { this._dropdown.toggle(); this.toggle.nativeElement.focus(); } registerOnChange(fn) { this._onChange = fn; } registerOnTouched(fn) { this._onTouched = fn; } writeValue(value) { this._setDate(value); } setDisabledState(isDisabled) { this._disabled = isDisabled; } _focusChanged(focused) { if (focused === this.focused) { return; } this.focused = focused; if (!focused) { this._dropdown.close(); } } static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DatepickerInputComponent, deps: [{ token: i0.ElementRef }, { token: LOCALE_ID }, { token: DatepickerAdapter, optional: true }, { token: DATEPICKER_DEFAULT_OPTIONS, optional: true }, { token: i1.DefaultDatepickerAdapter }, { token: forwardRef(() => FormFieldComponent), optional: true }], target: i0.ɵɵFactoryTarget.Component }); } static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: DatepickerInputComponent, selector: "u-datepicker-input", inputs: { autoClose: "autoClose", placeholder: "placeholder", direction: "direction", tabIndex: "tabIndex", inputFormatter: "inputFormatter" }, providers: [ DatepickerInputValueAcessor, { provide: DatepickerBaseComponent, useExisting: DatepickerInputComponent } ], viewQueries: [{ propertyName: "toggle", first: true, predicate: ["toggle"], descendants: true }, { propertyName: "_dropdown", first: true, predicate: DropdownDirective, descendants: true }, { propertyName: "_dropdownMenu", first: true, predicate: DropdownMenuDirective, descendants: true }], usesInheritance: true, ngImport: i0, template: "<div class=\"u-dropdown\" uDropdown [autoClose]=\"autoClose\">\n <button\n #toggle\n class=\"u-text-input u-dropdown-toggle\"\n type=\"button\"\n [disabled]=\"_disabled\"\n [attr.tabindex]=\"tabIndex\"\n (click)=\"focus()\"\n (focus)=\"_focusChanged(true)\"\n (blur)=\"_focusChanged(false)\">\n <div class=\"u-text-input-value\" *ngIf=\"date; else inputPlaceholder\">{{inputFormatter ? inputFormatter(date) : formattedDate}}</div>\n <ng-template #inputPlaceholder>\n <div class=\"u-text-input-placeholder\">{{placeholder}}</div>\n </ng-template>\n </button>\n <div class=\"u-dropdown-menu\" uDropdownMenu [direction]=\"direction\">\n <u-datepicker-content [disabled]=\"!focused\"></u-datepicker-content>\n </div>\n</div>\n", styles: ["u-datepicker-input{display:block;pointer-events:none}u-datepicker-input .u-dropdown-toggle{width:100%}@media (max-width: 991.99px),(max-height: 800px){u-datepicker-input .u-dropdown-menu{position:fixed;inset:0!important;display:flex;align-items:center;justify-content:center;background:#00000080;z-index:9999;transform:none!important;transition:opacity .25s!important;pointer-events:none!important}}u-datepicker-input .u-dropdown-menu{padding:0}u-datepicker-input .u-dropdown-menu.show .u-datepicker{pointer-events:auto;border-radius:4px;overflow:hidden}button.u-text-input{padding:0!important}\n"], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.DropdownDirective, selector: "[uDropdown]", inputs: ["autoClose"] }, { kind: "directive", type: i4.DropdownMenuDirective, selector: "[uDropdownMenu]", inputs: ["direction"] }, { kind: "component", type: i5.DatepickerContentComponent, selector: "u-datepicker-content", inputs: ["disabled"] }], encapsulation: i0.ViewEncapsulation.None }); } } i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DatepickerInputComponent, decorators: [{ type: Component, args: [{ selector: 'u-datepicker-input', providers: [ DatepickerInputValueAcessor, { provide: DatepickerBaseComponent, useExisting: DatepickerInputComponent } ], encapsulation: ViewEncapsulation.None, template: "<div class=\"u-dropdown\" uDropdown [autoClose]=\"autoClose\">\n <button\n #toggle\n class=\"u-text-input u-dropdown-toggle\"\n type=\"button\"\n [disabled]=\"_disabled\"\n [attr.tabindex]=\"tabIndex\"\n (click)=\"focus()\"\n (focus)=\"_focusChanged(true)\"\n (blur)=\"_focusChanged(false)\">\n <div class=\"u-text-input-value\" *ngIf=\"date; else inputPlaceholder\">{{inputFormatter ? inputFormatter(date) : formattedDate}}</div>\n <ng-template #inputPlaceholder>\n <div class=\"u-text-input-placeholder\">{{placeholder}}</div>\n </ng-template>\n </button>\n <div class=\"u-dropdown-menu\" uDropdownMenu [direction]=\"direction\">\n <u-datepicker-content [disabled]=\"!focused\"></u-datepicker-content>\n </div>\n</div>\n", styles: ["u-datepicker-input{display:block;pointer-events:none}u-datepicker-input .u-dropdown-toggle{width:100%}@media (max-width: 991.99px),(max-height: 800px){u-datepicker-input .u-dropdown-menu{position:fixed;inset:0!important;display:flex;align-items:center;justify-content:center;background:#00000080;z-index:9999;transform:none!important;transition:opacity .25s!important;pointer-events:none!important}}u-datepicker-input .u-dropdown-menu{padding:0}u-datepicker-input .u-dropdown-menu.show .u-datepicker{pointer-events:auto;border-radius:4px;overflow:hidden}button.u-text-input{padding:0!important}\n"] }] }], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: undefined, decorators: [{ type: Inject, args: [LOCALE_ID] }] }, { type: i6.DatepickerAdapter, decorators: [{ type: Optional }, { type: Inject, args: [DatepickerAdapter] }] }, { type: undefined, decorators: [{ type: Optional }, { type: Inject, args: [DATEPICKER_DEFAULT_OPTIONS] }] }, { type: i1.DefaultDatepickerAdapter }, { type: i7.FormFieldComponent, decorators: [{ type: Optional }, { type: Inject, args: [forwardRef(() => FormFieldComponent)] }] }]; }, propDecorators: { autoClose: [{ type: Input }], placeholder: [{ type: Input }], direction: [{ type: Input }], tabIndex: [{ type: Input }], inputFormatter: [{ type: Input }], toggle: [{ type: ViewChild, args: ['toggle'] }], _dropdown: [{ type: ViewChild, args: [DropdownDirective] }], _dropdownMenu: [{ type: ViewChild, args: [DropdownMenuDirective] }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"datepicker-input.component.js","sourceRoot":"","sources":["../../../../../../src/datepicker/datepicker-input/datepicker-input.component.ts","../../../../../../src/datepicker/datepicker-input/datepicker-input.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, forwardRef, Inject, Input, LOCALE_ID, Optional, ViewChild, ViewEncapsulation } from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\n\nimport { InputBaseComponent } from '../../shared/input-base.component';\nimport { FormFieldComponent } from '../../form-field/form-field.component';\nimport { Direction } from '../../util/direction';\nimport { DropdownMenuDirective } from '../../dropdown/dropdown-menu.directive';\n\nimport { DatepickerBaseComponent } from '../datepicker-base.component';\nimport { DATEPICKER_DEFAULT_OPTIONS, DatepickerConfig } from '../datepicker-config.model';\nimport { DatepickerAdapter } from '../datepicker-adapter';\nimport { DefaultDatepickerAdapter } from '../default-datepicker-adapter';\nimport { DropdownDirective } from '../../dropdown/dropdown.directive';\n\nconst DatepickerInputValueAcessor = {\n  provide: NG_VALUE_ACCESSOR,\n  useExisting: forwardRef(() => DatepickerInputComponent),\n  multi: true\n};\n\n@Component({\n  selector: 'u-datepicker-input',\n  templateUrl: './datepicker-input.component.html',\n  styleUrls: ['./datepicker-input.component.scss'],\n  providers: [\n    DatepickerInputValueAcessor,\n    {provide: DatepickerBaseComponent, useExisting: DatepickerInputComponent}\n  ],\n  encapsulation: ViewEncapsulation.None\n})\nexport class DatepickerInputComponent extends DatepickerBaseComponent implements InputBaseComponent, ControlValueAccessor {\n\n  @Input() autoClose: boolean | 'outside' = 'outside';\n  @Input() placeholder: string | null = null;\n  @Input() direction: Direction = 'auto';\n  @Input() tabIndex: number | null = null;\n  @Input() inputFormatter: ((value: Date) => string | null) | null = null;\n  // @Input() config: DatepickerInputConfig;\n\n  @ViewChild('toggle') toggle!: ElementRef<HTMLButtonElement>;\n\n  @ViewChild(DropdownDirective) _dropdown!: DropdownDirective;\n  @ViewChild(DropdownMenuDirective) _dropdownMenu!: DropdownMenuDirective;\n\n  override date: Date | null = null;\n  _disabled = false;\n\n  focused = false;\n  // get focused(): boolean {\n  //   return this._dropdownMenu && this._dropdownMenu.show;\n  // }\n\n  get empty(): boolean {\n    return !this.date;\n  }\n\n  get disabled(): boolean {\n    return this._disabled;\n  }\n\n  constructor(elementRef: ElementRef<HTMLElement>,\n              @Inject(LOCALE_ID) _locale: string,\n              @Optional() @Inject(DatepickerAdapter) datepickerAdapter: DatepickerAdapter,\n              @Optional() @Inject(DATEPICKER_DEFAULT_OPTIONS) _defaultConfig: DatepickerConfig,\n              defaultDatepickerAdapter: DefaultDatepickerAdapter,\n              @Optional() @Inject(forwardRef(() => FormFieldComponent)) formField: FormFieldComponent) {\n    super(_locale, _defaultConfig, datepickerAdapter, defaultDatepickerAdapter);\n\n    elementRef.nativeElement.classList.add('u-text-input');\n\n    if (!formField) {\n      return;\n    }\n\n    formField.selectionField = true;\n    formField._input = this;\n  }\n\n  private _onTouched = () => {};\n  private _onChange = (_: any) => {};\n\n  override _setDate(date: Date): void {\n    super._setDate(date);\n\n    if (!this._onChange) {\n      return;\n    }\n\n    this._onChange(date);\n\n    if (this.autoClose && this._dropdownMenu) {\n      this._dropdownMenu.show = false;\n    }\n  }\n\n  focus(): void {\n    this._dropdown.toggle();\n    this.toggle.nativeElement.focus();\n  }\n\n  registerOnChange(fn: (value: any) => any): void {\n    this._onChange = fn;\n  }\n\n  registerOnTouched(fn: () => any): void {\n    this._onTouched = fn;\n  }\n\n  writeValue(value: Date) {\n    this._setDate(value);\n  }\n\n  setDisabledState(isDisabled: boolean): void {\n    this._disabled = isDisabled;\n  }\n\n  _focusChanged(focused: boolean) {\n    if (focused === this.focused) {\n      return;\n    }\n\n    this.focused = focused;\n\n    if (!focused) {\n      this._dropdown.close();\n    }\n  }\n}\n","<div class=\"u-dropdown\" uDropdown [autoClose]=\"autoClose\">\n  <button\n    #toggle\n    class=\"u-text-input u-dropdown-toggle\"\n    type=\"button\"\n    [disabled]=\"_disabled\"\n    [attr.tabindex]=\"tabIndex\"\n    (click)=\"focus()\"\n    (focus)=\"_focusChanged(true)\"\n    (blur)=\"_focusChanged(false)\">\n    <div class=\"u-text-input-value\" *ngIf=\"date; else inputPlaceholder\">{{inputFormatter ? inputFormatter(date) : formattedDate}}</div>\n    <ng-template #inputPlaceholder>\n      <div class=\"u-text-input-placeholder\">{{placeholder}}</div>\n    </ng-template>\n  </button>\n  <div class=\"u-dropdown-menu\" uDropdownMenu [direction]=\"direction\">\n    <u-datepicker-content [disabled]=\"!focused\"></u-datepicker-content>\n  </div>\n</div>\n"]}