UNPKG

materialize-angular

Version:
319 lines 27.6 kB
/** * @fileoverview added by tsickle * Generated from: app/completed-components/select/select.component.ts * @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ /** * @license * Copyright Workylab. All Rights Reserved. * * Use of this source code is governed by an MIT-style license that can be * found in the LICENSE file at https://raw.githubusercontent.com/workylab/materialize-angular/master/LICENSE */ import { Component, ContentChildren, ElementRef, EventEmitter, forwardRef, Input, Output, QueryList, Renderer2, ViewChild } from '@angular/core'; import { NG_VALUE_ACCESSOR } from '@angular/forms'; import { config } from '../../config'; import { SelectOptionComponent } from './select-option/select-option.component'; export class SelectComponent { /** * @param {?} renderer */ constructor(renderer) { this.renderer = renderer; this.className = SelectComponent.defaultProps.className; this.disabled = SelectComponent.defaultProps.disabled; this.floatLabel = SelectComponent.defaultProps.floatLabel; this.id = SelectComponent.defaultProps.id; this.isNativeControl = SelectComponent.defaultProps.isNativeControl; this.name = SelectComponent.defaultProps.name; this.required = SelectComponent.defaultProps.required; this.value = SelectComponent.defaultProps.value; this.prefix = config.components.prefix; this.isFocused = false; this.isOpen = false; this.onChangeEmitter = new EventEmitter(); this.addBackdropListener = this.addBackdropListener.bind(this); this.onChangeOption = this.onChangeOption.bind(this); this.registerOptions = this.registerOptions.bind(this); } /** * @return {?} */ ngAfterContentInit() { setTimeout(this.registerOptions, 0); this.options.changes.subscribe((/** * @param {?} changes * @return {?} */ changes => { setTimeout(this.registerOptions, 0); })); } /** * @return {?} */ registerOptions() { this.options.forEach((/** * @param {?} option * @return {?} */ option => { option.isActive = (option.value === this.value); option.onClickEmitter.subscribe(this.onChangeOption); })); this.updateControl(this.value); } /** * @param {?} value * @return {?} */ updateControl(value) { this.value = value; this.isOpen = false; this.activeSelectedOption(this.value); } /** * @param {?} value * @return {?} */ onChangeOption(value) { this.updateControl(value); this.onChangeEmitter.emit(this.value); this.onChange(this.value); } /** * @param {?} value * @return {?} */ activeSelectedOption(value) { this.options.forEach((/** * @param {?} option * @return {?} */ option => { if (option.value === value) { option.isActive = true; this.activeSelectClass(option); this.cloneOption(option); } else { option.isActive = false; } })); } /** * @param {?} selectedOption * @return {?} */ cloneOption(selectedOption) { if (!this.labelContainerRef) { return; } const { nativeElement: labelContainer } = this.labelContainerRef; const { optionTemplateRef, disabled } = selectedOption; if (labelContainer.firstChild) { this.renderer.removeChild(labelContainer, labelContainer.firstChild); } if (optionTemplateRef) { const { firstChild } = optionTemplateRef.nativeElement; /** @type {?} */ const cloned = firstChild.cloneNode(true); if (disabled) { this.renderer.addClass(cloned, 'option-disabled'); } this.renderer.appendChild(labelContainer, cloned); } } /** * @param {?} event * @return {?} */ onChangeNativeOption(event) { const { selectedOptions } = event.target; const { value } = selectedOptions[0]; this.value = value; this.activeSelectClass(selectedOptions[0]); this.onChangeEmitter.emit(this.value); this.onChange(this.value); } /** * @return {?} */ onBlur() { this.isFocused = false; } /** * @return {?} */ onFocus() { if (!this.disabled) { this.isFocused = true; this.onTouched(); } } /** * @return {?} */ onClick() { if (!this.disabled) { this.isFocused = true; this.isOpen = true; if (!this.isNativeControl) { setTimeout(this.addBackdropListener, 0); } } } /** * @return {?} */ addBackdropListener() { this.backdropRef.nativeElement.addEventListener('click', (/** * @return {?} */ () => { this.isOpen = false; })); } /** * @param {?} isDisabled * @return {?} */ setDisabledState(isDisabled) { this.disabled = isDisabled; } /** * @param {?} value * @return {?} */ writeValue(value) { this.value = value; setTimeout((/** * @return {?} */ () => { this.updateControl(this.value); }), 0); } /** * @param {?} fn * @return {?} */ registerOnChange(fn) { this.onChange = fn; } /** * @param {?} fn * @return {?} */ registerOnTouched(fn) { this.onTouched = fn; } /** * @param {?} value * @return {?} */ onChange(value) { } /** * @return {?} */ onTouched() { } /** * @param {?} selectedOption * @return {?} */ activeSelectClass(selectedOption) { if (this.selectElementRef && selectedOption.disabled) { this.renderer.addClass(this.selectElementRef.nativeElement, 'option-disabled'); } else if (this.selectElementRef && !selectedOption.disabled) { this.renderer.removeClass(this.selectElementRef.nativeElement, 'option-disabled'); } } } SelectComponent.defaultProps = { className: '', disabled: false, floatLabel: '', id: null, isNativeControl: false, name: '', required: false, value: null }; SelectComponent.decorators = [ { type: Component, args: [{ providers: [{ multi: true, provide: NG_VALUE_ACCESSOR, useExisting: forwardRef((/** * @return {?} */ () => SelectComponent)) }], selector: `${config.components.prefix}-select }`, template: "<div [ngClass]=\"[className, prefix + '-form-control-select-container']\" *ngIf=\"isNativeControl\">\n <div [ngClass]=\"prefix + '-form-control-container'\"\n [class.float-label]=\"floatLabel\"\n [class.active]=\"value\"\n [class.focused]=\"isFocused\"\n [class.disabled]=\"disabled\"\n >\n <div [ngClass]=\"prefix + '-form-control-wrapper'\">\n <div [ngClass]=\"prefix + '-form-control-label'\">{{ floatLabel }}</div>\n\n <select #selectElement (blur)=\"onBlur()\" (click)=\"onClick()\" (focus)=\"onFocus()\" (input)=\"onChangeNativeOption($event)\"\n [ngClass]=\"prefix + '-form-control'\"\n [attr.id]=\"id\"\n [disabled]=\"disabled\"\n [name]=\"name\"\n [required]=\"required\"\n [value]=\"value\"\n >\n <option\n [selected]=\"option.value === value\"\n [value]=\"option.value\"\n [disabled]=\"option.disabled\"\n *ngFor=\"let option of options\">\n {{ option.content }}\n </option>\n </select>\n </div>\n\n <materialize-icon [className]=\"prefix + '-form-control-select-icon'\" size=\"lg\">arrow_drop_down</materialize-icon>\n </div>\n</div>\n\n\n<div (focus)=\"onFocus()\" (blur)=\"onBlur()\" *ngIf=\"!isNativeControl\"\n [ngClass]=\"[className, prefix + '-form-control-select-container']\"\n [class.open]=\"isOpen\"\n [tabindex]=\"disabled ? '-1' : '0'\"\n>\n <div #backdrop *ngIf=\"isOpen\" [ngClass]=\"prefix + '-form-control-select-backdrop'\"></div>\n\n <div (click)=\"onClick()\"\n [ngClass]=\"[prefix + '-form-control-container' , className]\"\n [class.float-label]=\"floatLabel\"\n [class.active]=\"value\"\n [class.focused]=\"isFocused\"\n [class.disabled]=\"disabled\"\n >\n <div [ngClass]=\"prefix + '-form-control-wrapper'\">\n <div [ngClass]=\"prefix + '-form-control-label'\">{{ floatLabel }}</div>\n <div [ngClass]=\"prefix + '-form-control'\" #labelContainer>&nbsp;</div>\n </div>\n\n <materialize-icon [className]=\"prefix + '-form-control-select-icon'\" size=\"lg\">arrow_drop_down</materialize-icon>\n </div>\n\n <div [className]=\"prefix + '-form-control-select-menu'\">\n <ng-content select=\"materialize-select-option\"></ng-content>\n </div>\n</div>\n" }] } ]; /** @nocollapse */ SelectComponent.ctorParameters = () => [ { type: Renderer2 } ]; SelectComponent.propDecorators = { backdropRef: [{ type: ViewChild, args: ['backdrop', { static: false },] }], labelContainerRef: [{ type: ViewChild, args: ['labelContainer', { static: false },] }], selectElementRef: [{ type: ViewChild, args: ['selectElement', { static: false },] }], options: [{ type: ContentChildren, args: [SelectOptionComponent,] }], onChangeEmitter: [{ type: Output, args: ['onChange',] }], className: [{ type: Input }], disabled: [{ type: Input }], floatLabel: [{ type: Input }], id: [{ type: Input }], isNativeControl: [{ type: Input }], name: [{ type: Input }], required: [{ type: Input }], value: [{ type: Input }] }; if (false) { /** @type {?} */ SelectComponent.defaultProps; /** @type {?} */ SelectComponent.prototype.backdropRef; /** @type {?} */ SelectComponent.prototype.labelContainerRef; /** @type {?} */ SelectComponent.prototype.selectElementRef; /** @type {?} */ SelectComponent.prototype.options; /** @type {?} */ SelectComponent.prototype.onChangeEmitter; /** @type {?} */ SelectComponent.prototype.className; /** @type {?} */ SelectComponent.prototype.disabled; /** @type {?} */ SelectComponent.prototype.floatLabel; /** @type {?} */ SelectComponent.prototype.id; /** @type {?} */ SelectComponent.prototype.isNativeControl; /** @type {?} */ SelectComponent.prototype.name; /** @type {?} */ SelectComponent.prototype.required; /** @type {?} */ SelectComponent.prototype.value; /** @type {?} */ SelectComponent.prototype.prefix; /** @type {?} */ SelectComponent.prototype.isFocused; /** @type {?} */ SelectComponent.prototype.isOpen; /** @type {?} */ SelectComponent.prototype.valueLabel; /** * @type {?} * @private */ SelectComponent.prototype.renderer; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select.component.js","sourceRoot":"ng://materialize-angular/","sources":["app/completed-components/select/select.component.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Workylab. All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://raw.githubusercontent.com/workylab/materialize-angular/master/LICENSE\n */\n\nimport {\n  AfterContentInit,\n  Component,\n  ContentChildren,\n  ElementRef,\n  EventEmitter,\n  forwardRef,\n  Input,\n  Output,\n  QueryList,\n  Renderer2,\n  ViewChild\n} from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { config } from '../../config';\nimport { SelectModel } from './select.model';\nimport { SelectOptionComponent } from './select-option/select-option.component';\nimport { SelectOptionModel } from './select-option/select-option.model';\n\n@Component({\n  providers: [{\n    multi: true,\n    provide: NG_VALUE_ACCESSOR,\n    useExisting: forwardRef(() => SelectComponent)\n  }],\n  selector: `${ config.components.prefix }-select }`,\n  templateUrl: './select.component.html'\n})\nexport class SelectComponent implements ControlValueAccessor, AfterContentInit, SelectModel {\n  static readonly defaultProps: SelectModel = {\n    className: '',\n    disabled: false,\n    floatLabel: '',\n    id: null,\n    isNativeControl: false,\n    name: '',\n    required: false,\n    value: null\n  };\n\n  @ViewChild('backdrop', { static: false }) backdropRef: ElementRef;\n  @ViewChild('labelContainer', { static: false }) labelContainerRef: ElementRef;\n  @ViewChild('selectElement', { static: false }) selectElementRef: ElementRef;\n\n  @ContentChildren(SelectOptionComponent) options: QueryList<SelectOptionComponent>;\n\n  @Output('onChange') onChangeEmitter: EventEmitter<string | number | boolean | null>;\n\n  @Input() className: string = SelectComponent.defaultProps.className;\n  @Input() disabled: boolean = SelectComponent.defaultProps.disabled;\n  @Input() floatLabel: string = SelectComponent.defaultProps.floatLabel;\n  @Input() id: string | null = SelectComponent.defaultProps.id;\n  @Input() isNativeControl: boolean = SelectComponent.defaultProps.isNativeControl;\n  @Input() name: string = SelectComponent.defaultProps.name;\n  @Input() required: boolean = SelectComponent.defaultProps.required;\n  @Input() value: string | number | boolean | null = SelectComponent.defaultProps.value;\n\n  public prefix = config.components.prefix;\n\n  public isFocused: boolean;\n  public isOpen: boolean;\n  public valueLabel: string;\n\n  constructor(private renderer: Renderer2) {\n    this.isFocused = false;\n    this.isOpen = false;\n    this.onChangeEmitter = new EventEmitter();\n\n    this.addBackdropListener = this.addBackdropListener.bind(this);\n    this.onChangeOption = this.onChangeOption.bind(this);\n    this.registerOptions = this.registerOptions.bind(this);\n  }\n\n  ngAfterContentInit() {\n    setTimeout(this.registerOptions, 0);\n\n    this.options.changes.subscribe(changes => {\n      setTimeout(this.registerOptions, 0);\n    });\n  }\n\n  registerOptions() {\n    this.options.forEach(option => {\n      option.isActive = (option.value === this.value);\n\n      option.onClickEmitter.subscribe(this.onChangeOption);\n    });\n\n    this.updateControl(this.value);\n  }\n\n  updateControl(value: string | number | boolean | null) {\n    this.value = value;\n    this.isOpen = false;\n\n    this.activeSelectedOption(this.value);\n  }\n\n  onChangeOption(value: string | number | boolean | null) {\n    this.updateControl(value);\n\n    this.onChangeEmitter.emit(this.value);\n    this.onChange(this.value);\n  }\n\n  activeSelectedOption(value: string | number | boolean | null) {\n    this.options.forEach(option => {\n      if (option.value === value) {\n        option.isActive = true;\n\n        this.activeSelectClass(option);\n\n        this.cloneOption(option);\n      } else {\n        option.isActive = false;\n      }\n    });\n  }\n\n  cloneOption(selectedOption: SelectOptionComponent) {\n    if (!this.labelContainerRef) {\n      return;\n    }\n\n    const { nativeElement: labelContainer } = this.labelContainerRef;\n    const { optionTemplateRef, disabled } = selectedOption;\n\n    if (labelContainer.firstChild) {\n      this.renderer.removeChild(labelContainer, labelContainer.firstChild);\n    }\n\n    if (optionTemplateRef) {\n      const { firstChild } = optionTemplateRef.nativeElement;\n      const cloned = firstChild.cloneNode(true);\n\n      if (disabled) {\n        this.renderer.addClass(cloned, 'option-disabled');\n      }\n      this.renderer.appendChild(labelContainer, cloned);\n    }\n  }\n\n  onChangeNativeOption(event: any) {\n    const { selectedOptions } = event.target;\n    const { value } = selectedOptions[0];\n\n    this.value = value;\n\n    this.activeSelectClass(selectedOptions[0]);\n\n    this.onChangeEmitter.emit(this.value);\n    this.onChange(this.value);\n  }\n\n  onBlur(): void {\n    this.isFocused = false;\n  }\n\n  onFocus(): void {\n    if (!this.disabled) {\n      this.isFocused = true;\n\n      this.onTouched();\n    }\n  }\n\n  onClick() {\n    if (!this.disabled) {\n      this.isFocused = true;\n      this.isOpen = true;\n\n      if (!this.isNativeControl) {\n        setTimeout(this.addBackdropListener, 0);\n      }\n    }\n  }\n\n  addBackdropListener() {\n    this.backdropRef.nativeElement.addEventListener('click', () => {\n      this.isOpen = false;\n    });\n  }\n\n  setDisabledState(isDisabled: boolean): void {\n    this.disabled = isDisabled;\n  }\n\n  writeValue(value: string | number | boolean | null): void {\n    this.value = value;\n\n    setTimeout(() => {\n      this.updateControl(this.value);\n    }, 0);\n  }\n\n  registerOnChange(fn: (value: string | number | boolean | null) => void): void {\n    this.onChange = fn;\n  }\n\n  registerOnTouched(fn: () => void): void {\n    this.onTouched = fn;\n  }\n\n  onChange(value: string | number | boolean | null): void {}\n\n  onTouched(): void {}\n\n  activeSelectClass(selectedOption: SelectOptionModel) {\n    if (this.selectElementRef && selectedOption.disabled) {\n      this.renderer.addClass(this.selectElementRef.nativeElement, 'option-disabled');\n    } else if (this.selectElementRef && !selectedOption.disabled) {\n      this.renderer.removeClass(this.selectElementRef.nativeElement, 'option-disabled');\n    }\n  }\n}\n"]}