materialize-angular
Version:
Material UI Angular library
388 lines • 29.8 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';
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> </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"]}