materialize-angular
Version:
Material UI Angular library
319 lines • 27.6 kB
JavaScript
/**
* @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> </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"]}