UNPKG

materialize-angular

Version:
388 lines 29.8 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'; var SelectComponent = /** @class */ (function () { function SelectComponent(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 {?} */ SelectComponent.prototype.ngAfterContentInit = /** * @return {?} */ function () { var _this = this; setTimeout(this.registerOptions, 0); this.options.changes.subscribe((/** * @param {?} changes * @return {?} */ function (changes) { setTimeout(_this.registerOptions, 0); })); }; /** * @return {?} */ SelectComponent.prototype.registerOptions = /** * @return {?} */ function () { var _this = this; this.options.forEach((/** * @param {?} option * @return {?} */ function (option) { option.isActive = (option.value === _this.value); option.onClickEmitter.subscribe(_this.onChangeOption); })); this.updateControl(this.value); }; /** * @param {?} value * @return {?} */ SelectComponent.prototype.updateControl = /** * @param {?} value * @return {?} */ function (value) { this.value = value; this.isOpen = false; this.activeSelectedOption(this.value); }; /** * @param {?} value * @return {?} */ SelectComponent.prototype.onChangeOption = /** * @param {?} value * @return {?} */ function (value) { this.updateControl(value); this.onChangeEmitter.emit(this.value); this.onChange(this.value); }; /** * @param {?} value * @return {?} */ SelectComponent.prototype.activeSelectedOption = /** * @param {?} value * @return {?} */ function (value) { var _this = this; this.options.forEach((/** * @param {?} option * @return {?} */ function (option) { if (option.value === value) { option.isActive = true; _this.activeSelectClass(option); _this.cloneOption(option); } else { option.isActive = false; } })); }; /** * @param {?} selectedOption * @return {?} */ SelectComponent.prototype.cloneOption = /** * @param {?} selectedOption * @return {?} */ function (selectedOption) { if (!this.labelContainerRef) { return; } var labelContainer = this.labelContainerRef.nativeElement; var optionTemplateRef = selectedOption.optionTemplateRef, disabled = selectedOption.disabled; if (labelContainer.firstChild) { this.renderer.removeChild(labelContainer, labelContainer.firstChild); } if (optionTemplateRef) { var firstChild = optionTemplateRef.nativeElement.firstChild; /** @type {?} */ var cloned = firstChild.cloneNode(true); if (disabled) { this.renderer.addClass(cloned, 'option-disabled'); } this.renderer.appendChild(labelContainer, cloned); } }; /** * @param {?} event * @return {?} */ SelectComponent.prototype.onChangeNativeOption = /** * @param {?} event * @return {?} */ function (event) { var selectedOptions = event.target.selectedOptions; var value = selectedOptions[0].value; this.value = value; this.activeSelectClass(selectedOptions[0]); this.onChangeEmitter.emit(this.value); this.onChange(this.value); }; /** * @return {?} */ SelectComponent.prototype.onBlur = /** * @return {?} */ function () { this.isFocused = false; }; /** * @return {?} */ SelectComponent.prototype.onFocus = /** * @return {?} */ function () { if (!this.disabled) { this.isFocused = true; this.onTouched(); } }; /** * @return {?} */ SelectComponent.prototype.onClick = /** * @return {?} */ function () { if (!this.disabled) { this.isFocused = true; this.isOpen = true; if (!this.isNativeControl) { setTimeout(this.addBackdropListener, 0); } } }; /** * @return {?} */ SelectComponent.prototype.addBackdropListener = /** * @return {?} */ function () { var _this = this; this.backdropRef.nativeElement.addEventListener('click', (/** * @return {?} */ function () { _this.isOpen = false; })); }; /** * @param {?} isDisabled * @return {?} */ SelectComponent.prototype.setDisabledState = /** * @param {?} isDisabled * @return {?} */ function (isDisabled) { this.disabled = isDisabled; }; /** * @param {?} value * @return {?} */ SelectComponent.prototype.writeValue = /** * @param {?} value * @return {?} */ function (value) { var _this = this; this.value = value; setTimeout((/** * @return {?} */ function () { _this.updateControl(_this.value); }), 0); }; /** * @param {?} fn * @return {?} */ SelectComponent.prototype.registerOnChange = /** * @param {?} fn * @return {?} */ function (fn) { this.onChange = fn; }; /** * @param {?} fn * @return {?} */ SelectComponent.prototype.registerOnTouched = /** * @param {?} fn * @return {?} */ function (fn) { this.onTouched = fn; }; /** * @param {?} value * @return {?} */ SelectComponent.prototype.onChange = /** * @param {?} value * @return {?} */ function (value) { }; /** * @return {?} */ SelectComponent.prototype.onTouched = /** * @return {?} */ function () { }; /** * @param {?} selectedOption * @return {?} */ SelectComponent.prototype.activeSelectClass = /** * @param {?} selectedOption * @return {?} */ function (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 {?} */ function () { 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 = function () { return [ { 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 }] }; return SelectComponent; }()); export { SelectComponent }; 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"]}