UNPKG

materialize-angular

Version:
246 lines 17.5 kB
/** * @fileoverview added by tsickle * Generated from: app/completed-components/button-toggle-group/button-toggle-group.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, EventEmitter, forwardRef, Input, Output, QueryList } from '@angular/core'; import { NG_VALUE_ACCESSOR } from '@angular/forms'; import { ButtonToggleComponent } from './button-toggle/button-toggle.component'; import { config } from '../../config'; var ButtonToggleGroupComponent = /** @class */ (function () { function ButtonToggleGroupComponent() { this.canUncheck = ButtonToggleGroupComponent.defaultProps.canUncheck; this.className = ButtonToggleGroupComponent.defaultProps.className; this.disabled = ButtonToggleGroupComponent.defaultProps.disabled; this.value = ButtonToggleGroupComponent.defaultProps.value; this.prefix = config.components.prefix; this.isFocused = false; this.onChangeEmitter = new EventEmitter(); this.initButtons = this.initButtons.bind(this); this.registerButtons = this.registerButtons.bind(this); this.toggleButton = this.toggleButton.bind(this); } /** * @return {?} */ ButtonToggleGroupComponent.prototype.ngAfterContentInit = /** * @return {?} */ function () { this.initButtons(); this.buttonsQueryList.changes.subscribe(this.initButtons); }; /** * @return {?} */ ButtonToggleGroupComponent.prototype.initButtons = /** * @return {?} */ function () { if (this.disabled) { this.disableButtons(this.disabled); } setTimeout(this.registerButtons, 0); }; /** * @param {?} disabled * @return {?} */ ButtonToggleGroupComponent.prototype.disableButtons = /** * @param {?} disabled * @return {?} */ function (disabled) { this.buttonsQueryList.forEach((/** * @param {?} item * @return {?} */ function (item) { item.disabled = disabled; })); }; /** * @return {?} */ ButtonToggleGroupComponent.prototype.registerButtons = /** * @return {?} */ function () { var _this = this; this.buttonsQueryList.forEach((/** * @param {?} button * @return {?} */ function (button) { button.isActive = (_this.value.lastIndexOf(button.value) >= 0); button.onClickEmitter.subscribe(_this.toggleButton); })); }; /** * @param {?} value * @return {?} */ ButtonToggleGroupComponent.prototype.toggleButton = /** * @param {?} value * @return {?} */ function (value) { this.setValueAllButtons(value); /** @type {?} */ var currentButton = this.buttonsQueryList.find((/** * @param {?} item * @return {?} */ function (item) { return item.value === value; })); this.value = currentButton && currentButton.isActive ? currentButton.value : ''; this.onTouched(); this.onChange(this.value); this.onChangeEmitter.emit(this.value); }; /** * @param {?} value * @return {?} */ ButtonToggleGroupComponent.prototype.setValueAllButtons = /** * @param {?} value * @return {?} */ function (value) { var _this = this; this.buttonsQueryList.forEach((/** * @param {?} button * @return {?} */ function (button) { if (button.value !== value) { button.isActive = false; } if (button.value === value && !_this.canUncheck) { button.isActive = true; } })); }; /** * @param {?} isDisabled * @return {?} */ ButtonToggleGroupComponent.prototype.setDisabledState = /** * @param {?} isDisabled * @return {?} */ function (isDisabled) { this.disabled = isDisabled; this.disableButtons(this.disabled); }; /** * @param {?} value * @return {?} */ ButtonToggleGroupComponent.prototype.writeValue = /** * @param {?} value * @return {?} */ function (value) { this.value = value; }; /** * @param {?} fn * @return {?} */ ButtonToggleGroupComponent.prototype.registerOnChange = /** * @param {?} fn * @return {?} */ function (fn) { this.onChange = fn; }; /** * @param {?} fn * @return {?} */ ButtonToggleGroupComponent.prototype.registerOnTouched = /** * @param {?} fn * @return {?} */ function (fn) { this.onTouched = fn; }; /** * @param {?} value * @return {?} */ ButtonToggleGroupComponent.prototype.onChange = /** * @param {?} value * @return {?} */ function (value) { }; /** * @return {?} */ ButtonToggleGroupComponent.prototype.onTouched = /** * @return {?} */ function () { }; ButtonToggleGroupComponent.defaultProps = { canUncheck: false, className: '', disabled: false, value: '' }; ButtonToggleGroupComponent.decorators = [ { type: Component, args: [{ providers: [{ multi: true, provide: NG_VALUE_ACCESSOR, useExisting: forwardRef((/** * @return {?} */ function () { return ButtonToggleGroupComponent; })) }], selector: config.components.prefix + "-button-toggle-group }", template: "<div \n [ngClass]=\"[prefix + '-button-toggle-group', className]\"\n [class.disabled]=\"disabled\"\n>\n <ng-content select=\"materialize-button-toggle\"></ng-content>\n</div>\n " }] } ]; /** @nocollapse */ ButtonToggleGroupComponent.ctorParameters = function () { return []; }; ButtonToggleGroupComponent.propDecorators = { buttonsQueryList: [{ type: ContentChildren, args: [ButtonToggleComponent,] }], onChangeEmitter: [{ type: Output, args: ['onChange',] }], canUncheck: [{ type: Input }], className: [{ type: Input }], disabled: [{ type: Input }], value: [{ type: Input }] }; return ButtonToggleGroupComponent; }()); export { ButtonToggleGroupComponent }; if (false) { /** @type {?} */ ButtonToggleGroupComponent.defaultProps; /** @type {?} */ ButtonToggleGroupComponent.prototype.buttonsQueryList; /** @type {?} */ ButtonToggleGroupComponent.prototype.onChangeEmitter; /** @type {?} */ ButtonToggleGroupComponent.prototype.canUncheck; /** @type {?} */ ButtonToggleGroupComponent.prototype.className; /** @type {?} */ ButtonToggleGroupComponent.prototype.disabled; /** @type {?} */ ButtonToggleGroupComponent.prototype.value; /** @type {?} */ ButtonToggleGroupComponent.prototype.prefix; /** @type {?} */ ButtonToggleGroupComponent.prototype.isFocused; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"button-toggle-group.component.js","sourceRoot":"ng://materialize-angular/","sources":["app/completed-components/button-toggle-group/button-toggle-group.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  EventEmitter,\n  forwardRef,\n  Input,\n  Output,\n  QueryList\n} from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { ButtonToggleComponent } from './button-toggle/button-toggle.component';\nimport { ButtonToggleGroupModel } from './button-toggle-group.model';\nimport { config } from '../../config';\n\n@Component({\n  providers: [{\n    multi: true,\n    provide: NG_VALUE_ACCESSOR,\n    useExisting: forwardRef(() => ButtonToggleGroupComponent)\n  }],\n  selector: `${ config.components.prefix }-button-toggle-group }`,\n  templateUrl: './button-toggle-group.component.html'\n})\nexport class ButtonToggleGroupComponent implements ControlValueAccessor, AfterContentInit, ButtonToggleGroupModel {\n  static readonly defaultProps: ButtonToggleGroupModel = {\n    canUncheck: false,\n    className: '',\n    disabled: false,\n    value: ''\n  };\n\n  @ContentChildren(ButtonToggleComponent) buttonsQueryList: QueryList<ButtonToggleComponent>;\n\n  @Output('onChange') onChangeEmitter: EventEmitter<string>;\n\n  @Input() canUncheck: boolean = ButtonToggleGroupComponent.defaultProps.canUncheck;\n  @Input() className: string = ButtonToggleGroupComponent.defaultProps.className;\n  @Input() disabled: boolean = ButtonToggleGroupComponent.defaultProps.disabled;\n  @Input() value: string = ButtonToggleGroupComponent.defaultProps.value;\n\n  public prefix = config.components.prefix;\n\n  public isFocused: boolean;\n\n  constructor() {\n    this.isFocused = false;\n    this.onChangeEmitter = new EventEmitter();\n\n    this.initButtons = this.initButtons.bind(this);\n    this.registerButtons = this.registerButtons.bind(this);\n    this.toggleButton = this.toggleButton.bind(this);\n  }\n\n  ngAfterContentInit() {\n    this.initButtons();\n\n    this.buttonsQueryList.changes.subscribe(this.initButtons);\n  }\n\n  initButtons() {\n    if (this.disabled) {\n      this.disableButtons(this.disabled);\n    }\n\n    setTimeout(this.registerButtons, 0);\n  }\n\n  disableButtons(disabled: boolean) {\n    this.buttonsQueryList.forEach(item => {\n      item.disabled = disabled;\n    });\n  }\n\n  registerButtons() {\n    this.buttonsQueryList.forEach(button => {\n      button.isActive = (this.value.lastIndexOf(button.value) >= 0);\n\n      button.onClickEmitter.subscribe(this.toggleButton);\n    });\n  }\n\n  toggleButton(value: string) {\n    this.setValueAllButtons(value);\n\n    const currentButton = this.buttonsQueryList.find(item => item.value === value);\n\n    this.value = currentButton && currentButton.isActive\n      ? currentButton.value\n      : '';\n\n    this.onTouched();\n    this.onChange(this.value);\n\n    this.onChangeEmitter.emit(this.value);\n  }\n\n  setValueAllButtons(value: string) {\n    this.buttonsQueryList.forEach(button => {\n      if (button.value !== value) {\n        button.isActive = false;\n      }\n\n      if (button.value === value && !this.canUncheck) {\n        button.isActive = true;\n      }\n    });\n  }\n\n  setDisabledState(isDisabled: boolean): void {\n    this.disabled = isDisabled;\n\n    this.disableButtons(this.disabled);\n  }\n\n  writeValue(value: string): void {\n    this.value = value;\n  }\n\n  registerOnChange(fn: (value: string) => void): void {\n    this.onChange = fn;\n  }\n\n  registerOnTouched(fn: () => void): void {\n    this.onTouched = fn;\n  }\n\n  onChange(value: string): void {}\n\n  onTouched(): void {}\n}\n"]}