UNPKG

@kushki/ng-suka

Version:

<p align="center"> <h1 align="center">Suka Components Angular</h1> <p align="center"> An Angular implementation of the Suka Design System </p> </p>

381 lines 26.3 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ // tslint:disable: variable-name import { ContentChildren, Component, EventEmitter, forwardRef, Input, Output, QueryList, HostBinding } from '@angular/core'; import { NG_VALUE_ACCESSOR } from '@angular/forms'; import { ButtonRadio } from './button-radio.component'; // tslint:disable-next-line: component-class-suffix export class ButtonRadioGroup { constructor() { /** * Emits event notifying other classes of a change using a `ButtonRadioChange` class. */ // tslint:disable-next-line: no-output-native this.change = new EventEmitter(); /** * Set to true to disable the whole buttonRadio group */ this.disabled = false; /** * Binds 'form-item' value to the class for `ButtonRadioGroup`. */ this.buttonRadioButtonGroupClass = true; /** * To track whether the `ButtonRadioGroup` has been initialized. */ this.isInitialized = false; /** * Reflects whether or not the input is disabled and cannot be selected. */ this._disabled = false; /** * Reflects whether or not the dropdown is loading. */ this._skeleton = false; /** * The value of the selected option within the `ButtonRadioGroup`. */ this._value = null; /** * The `ButtonRadio` within the `ButtonRadioGroup` that is selected. */ this._selected = null; /** * The name attribute associated with the `ButtonRadioGroup`. */ this._name = `button-radio-group-${ButtonRadioGroup.buttonRadioGroupCount++}`; /** * Needed to properly implement ControlValueAccessor. */ this.onTouched = (/** * @return {?} */ () => { }); /** * Method set in registerOnChange to propagate changes back to the form. */ this.propagateChange = (/** * @param {?} _ * @return {?} */ (_) => { }); } /** * Sets the passed in `ButtonRadio` item as the selected input within the `ButtonRadioGroup`. * @param {?} selected * @return {?} */ set selected(selected) { this._selected = selected; this.value = selected ? selected.value : null; this.checkSelectedButtonRadio(); } /** * Returns the `ButtonRadio` that is selected within the `ButtonRadioGroup`. * @return {?} */ get selected() { return this._selected; } /** * Sets the value/state of the selected `ButtonRadio` within the `ButtonRadioGroup` to the passed in value. * @param {?} newValue * @return {?} */ set value(newValue) { if (this._value !== newValue) { this._value = newValue; this.updateSelectedButtonRadioFromValue(); this.checkSelectedButtonRadio(); } } /** * Returns the value/state of the selected `ButtonRadio` within the `ButtonRadioGroup`. * @return {?} */ get value() { return this._value; } /** * Replaces the name associated with the `ButtonRadioGroup` with the provided parameter. * @param {?} name * @return {?} */ set name(name) { this._name = name; this.updateButtonRadios(); } /** * Returns the associated name of the `ButtonRadioGroup`. * @return {?} */ get name() { return this._name; } /** * Returns the skeleton value in the `ButtonRadioGroup` if there is one. * @return {?} */ get skeleton() { return this._skeleton; } /** * Sets the skeleton value for all `ButtonRadio` to the skeleton value of `ButtonRadioGroup`. * @param {?} value * @return {?} */ set skeleton(value) { this._skeleton = value; this.updateChildren(); } /** * Updates the selected `ButtonRadio` to be checked (selected). * @return {?} */ checkSelectedButtonRadio() { if (this.selected && !this._selected.checked) { this.selected.checked = true; } } /** * Use the value of the `ButtonRadioGroup` to update the selected buttonRadio to the right state (selected state). * @return {?} */ updateSelectedButtonRadioFromValue() { /** @type {?} */ const alreadySelected = this._selected != null && this._selected.value === this._value; if (this.buttonRadios && !alreadySelected) { this._selected = null; this.buttonRadios.forEach((/** * @param {?} buttonRadio * @return {?} */ buttonRadio => { if (buttonRadio.checked) { this._selected = buttonRadio; } })); } } /** * Creates a class of `ButtonRadioChange` to emit the change in the `ButtonRadioGroup`. * @param {?} event * @return {?} */ emitChangeEvent(event) { this.change.emit(event); this.propagateChange(event.value); this.onTouched(); } /** * @return {?} */ updateButtonRadioNames() { console.warn('updateButtonRadioNames had been deprecated. Use updateButtonRadios instead'); this.updateButtonRadios(); } /** * Synchronizes buttonRadio properties. * @return {?} */ updateButtonRadios() { if (this.buttonRadios) { setTimeout((/** * @return {?} */ () => { this.buttonRadios.forEach((/** * @param {?} buttonRadio * @return {?} */ buttonRadio => buttonRadio.name = this.name)); })); } } /** * Updates the value of the `ButtonRadioGroup` using the provided parameter. * @param {?} value * @return {?} */ writeValue(value) { this.value = value; } /** * @return {?} */ ngAfterContentInit() { this.buttonRadios.changes.subscribe((/** * @return {?} */ () => { this.updateButtonRadios(); this.updateButtonRadioChangeHandler(); })); this.updateChildren(); this.updateButtonRadioChangeHandler(); } /** * @return {?} */ ngAfterViewInit() { this.updateButtonRadios(); } /** * Used to set method to propagate changes back to the form. * @param {?} fn * @return {?} */ registerOnChange(fn) { this.propagateChange = fn; } /** * Registers a callback to be triggered when the control has been touched. * @param {?} fn Callback to be triggered when the checkbox is touched. * @return {?} */ registerOnTouched(fn) { this.onTouched = fn; } /** * @protected * @return {?} */ updateChildren() { if (this.buttonRadios) { this.buttonRadios.forEach((/** * @param {?} child * @return {?} */ child => child.skeleton = this.skeleton)); } } /** * @protected * @return {?} */ updateButtonRadioChangeHandler() { this.buttonRadios.forEach((/** * @param {?} buttonRadio * @return {?} */ buttonRadio => { buttonRadio.registerButtonRadioChangeHandler((/** * @param {?} event * @return {?} */ (event) => { // update selected and value from the event this._selected = event.source; this._value = event.value; // bubble the event this.emitChangeEvent(event); })); })); } } ButtonRadioGroup.buttonRadioGroupCount = 0; ButtonRadioGroup.decorators = [ { type: Component, args: [{ selector: 'suka-button-radio-group', template: ` <div class="button-radio-group" role="buttonRadiogroup"> <ng-content></ng-content> </div> `, providers: [ { provide: NG_VALUE_ACCESSOR, useExisting: ButtonRadioGroup, multi: true } ] }] } ]; ButtonRadioGroup.propDecorators = { change: [{ type: Output }], buttonRadios: [{ type: ContentChildren, args: [forwardRef((/** * @return {?} */ () => ButtonRadio)),] }], selected: [{ type: Input }], value: [{ type: Input }], name: [{ type: Input }], disabled: [{ type: Input }], skeleton: [{ type: Input }], buttonRadioButtonGroupClass: [{ type: HostBinding, args: ['class.form-item',] }] }; if (false) { /** @type {?} */ ButtonRadioGroup.buttonRadioGroupCount; /** * Emits event notifying other classes of a change using a `ButtonRadioChange` class. * @type {?} */ ButtonRadioGroup.prototype.change; /** * The `ButtonRadio` input items in the `ButtonRadioGroup`. * @type {?} */ ButtonRadioGroup.prototype.buttonRadios; /** * Set to true to disable the whole buttonRadio group * @type {?} */ ButtonRadioGroup.prototype.disabled; /** * Binds 'form-item' value to the class for `ButtonRadioGroup`. * @type {?} */ ButtonRadioGroup.prototype.buttonRadioButtonGroupClass; /** * To track whether the `ButtonRadioGroup` has been initialized. * @type {?} * @protected */ ButtonRadioGroup.prototype.isInitialized; /** * Reflects whether or not the input is disabled and cannot be selected. * @type {?} * @protected */ ButtonRadioGroup.prototype._disabled; /** * Reflects whether or not the dropdown is loading. * @type {?} * @protected */ ButtonRadioGroup.prototype._skeleton; /** * The value of the selected option within the `ButtonRadioGroup`. * @type {?} * @protected */ ButtonRadioGroup.prototype._value; /** * The `ButtonRadio` within the `ButtonRadioGroup` that is selected. * @type {?} * @protected */ ButtonRadioGroup.prototype._selected; /** * The name attribute associated with the `ButtonRadioGroup`. * @type {?} * @protected */ ButtonRadioGroup.prototype._name; /** * Needed to properly implement ControlValueAccessor. * @type {?} */ ButtonRadioGroup.prototype.onTouched; /** * Method set in registerOnChange to propagate changes back to the form. * @type {?} */ ButtonRadioGroup.prototype.propagateChange; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"button-radio-group.component.js","sourceRoot":"ng://@kushki/ng-suka/","sources":["lib/button-radio/button-radio-group.component.ts"],"names":[],"mappings":"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","sourcesContent":["// tslint:disable: variable-name\n\nimport {\n  AfterContentInit,\n  ContentChildren,\n  Component,\n  EventEmitter,\n  forwardRef,\n  Input,\n  Output,\n  QueryList,\n  HostBinding,\n  AfterViewInit\n} from '@angular/core';\nimport { NG_VALUE_ACCESSOR, ControlValueAccessor } from '@angular/forms';\nimport { ButtonRadio } from './button-radio.component';\nimport { ButtonRadioChange } from './button-radio-change.class';\n\n@Component({\n  selector: 'suka-button-radio-group',\n  template: `\n    <div\n      class=\"button-radio-group\"\n      role=\"buttonRadiogroup\">\n      <ng-content></ng-content>\n    </div>\n  `,\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: ButtonRadioGroup,\n      multi: true\n    }\n  ]\n})\n// tslint:disable-next-line: component-class-suffix\nexport class ButtonRadioGroup implements AfterContentInit, AfterViewInit, ControlValueAccessor {\n  static buttonRadioGroupCount = 0;\n\n  /**\n   * Emits event notifying other classes of a change using a `ButtonRadioChange` class.\n   */\n  // tslint:disable-next-line: no-output-native\n  @Output() change: EventEmitter<ButtonRadioChange> = new EventEmitter<ButtonRadioChange>();\n\n  /**\n   * The `ButtonRadio` input items in the `ButtonRadioGroup`.\n   */\n  @ContentChildren(forwardRef(() => ButtonRadio)) buttonRadios: QueryList<ButtonRadio>;\n\n  /**\n   * Sets the passed in `ButtonRadio` item as the selected input within the `ButtonRadioGroup`.\n   */\n  @Input()\n  set selected(selected: ButtonRadio | null) {\n    this._selected = selected;\n    this.value = selected ? selected.value : null;\n    this.checkSelectedButtonRadio();\n  }\n\n  /**\n   * Returns the `ButtonRadio` that is selected within the `ButtonRadioGroup`.\n   */\n  get selected() {\n    return this._selected;\n  }\n\n  /**\n   * Sets the value/state of the selected `ButtonRadio` within the `ButtonRadioGroup` to the passed in value.\n   */\n  @Input()\n  set value(newValue: any) {\n    if (this._value !== newValue) {\n      this._value = newValue;\n\n      this.updateSelectedButtonRadioFromValue();\n      this.checkSelectedButtonRadio();\n    }\n  }\n\n  /**\n   * Returns the value/state of the selected `ButtonRadio` within the `ButtonRadioGroup`.\n   */\n  get value() {\n    return this._value;\n  }\n\n  /**\n   * Replaces the name associated with the `ButtonRadioGroup` with the provided parameter.\n   */\n  @Input()\n  set name(name: string) {\n    this._name = name;\n    this.updateButtonRadios();\n  }\n  /**\n   * Returns the associated name of the `ButtonRadioGroup`.\n   */\n  get name() {\n    return this._name;\n  }\n\n  /**\n   * Set to true to disable the whole buttonRadio group\n   */\n  @Input() disabled = false;\n\n  /**\n   * Returns the skeleton value in the `ButtonRadioGroup` if there is one.\n   */\n  @Input()\n  get skeleton(): any {\n    return this._skeleton;\n  }\n\n  /**\n   * Sets the skeleton value for all `ButtonRadio` to the skeleton value of `ButtonRadioGroup`.\n   */\n  set skeleton(value: any) {\n    this._skeleton = value;\n    this.updateChildren();\n  }\n\n  /**\n   * Binds 'form-item' value to the class for `ButtonRadioGroup`.\n   */\n  @HostBinding('class.form-item') buttonRadioButtonGroupClass = true;\n\n  /**\n   * To track whether the `ButtonRadioGroup` has been initialized.\n   */\n  protected isInitialized = false;\n  /**\n   * Reflects whether or not the input is disabled and cannot be selected.\n   */\n  protected _disabled = false;\n  /**\n   * Reflects whether or not the dropdown is loading.\n   */\n  protected _skeleton = false;\n  /**\n   * The value of the selected option within the `ButtonRadioGroup`.\n   */\n  protected _value: any = null;\n  /**\n   * The `ButtonRadio` within the `ButtonRadioGroup` that is selected.\n   */\n  protected _selected: ButtonRadio = null;\n  /**\n   * The name attribute associated with the `ButtonRadioGroup`.\n   */\n  protected _name = `button-radio-group-${ButtonRadioGroup.buttonRadioGroupCount++}`;\n\n  /**\n   * Updates the selected `ButtonRadio` to be checked (selected).\n   */\n  checkSelectedButtonRadio() {\n    if (this.selected && !this._selected.checked) {\n      this.selected.checked = true;\n    }\n  }\n\n  /**\n   * Use the value of the `ButtonRadioGroup` to update the selected buttonRadio to the right state (selected state).\n   */\n  updateSelectedButtonRadioFromValue() {\n    const alreadySelected = this._selected != null && this._selected.value === this._value;\n\n    if (this.buttonRadios && !alreadySelected) {\n      this._selected = null;\n      this.buttonRadios.forEach(buttonRadio => {\n        if (buttonRadio.checked) {\n          this._selected = buttonRadio;\n        }\n      });\n    }\n  }\n\n  /**\n   * Creates a class of `ButtonRadioChange` to emit the change in the `ButtonRadioGroup`.\n   */\n  emitChangeEvent(event: ButtonRadioChange) {\n    this.change.emit(event);\n    this.propagateChange(event.value);\n    this.onTouched();\n  }\n\n  updateButtonRadioNames() {\n    console.warn('updateButtonRadioNames had been deprecated. Use updateButtonRadios instead');\n    this.updateButtonRadios();\n  }\n\n  /**\n   * Synchronizes buttonRadio properties.\n   */\n  updateButtonRadios() {\n    if (this.buttonRadios) {\n      setTimeout(() => {\n        this.buttonRadios.forEach(buttonRadio => buttonRadio.name = this.name);\n      });\n    }\n  }\n\n  /**\n   * Updates the value of the `ButtonRadioGroup` using the provided parameter.\n   */\n  writeValue(value: any) {\n    this.value = value;\n  }\n\n  ngAfterContentInit() {\n    this.buttonRadios.changes.subscribe(() => {\n      this.updateButtonRadios();\n      this.updateButtonRadioChangeHandler();\n    });\n\n    this.updateChildren();\n    this.updateButtonRadioChangeHandler();\n  }\n\n  ngAfterViewInit() {\n    this.updateButtonRadios();\n  }\n\n  /**\n   * Used to set method to propagate changes back to the form.\n   */\n  public registerOnChange(fn: any) {\n    this.propagateChange = fn;\n  }\n\n  /**\n   * Registers a callback to be triggered when the control has been touched.\n   * @param fn Callback to be triggered when the checkbox is touched.\n   */\n  public registerOnTouched(fn: any) {\n    this.onTouched = fn;\n  }\n\n  /**\n   * Needed to properly implement ControlValueAccessor.\n   */\n  onTouched: () => any = () => { };\n\n  /**\n   * Method set in registerOnChange to propagate changes back to the form.\n   */\n  propagateChange = (_: any) => { };\n\n  protected updateChildren() {\n    if (this.buttonRadios) {\n      this.buttonRadios.forEach(child => child.skeleton = this.skeleton);\n    }\n  }\n\n  protected updateButtonRadioChangeHandler() {\n    this.buttonRadios.forEach(buttonRadio => {\n      buttonRadio.registerButtonRadioChangeHandler((event: ButtonRadioChange) => {\n        // update selected and value from the event\n        this._selected = event.source;\n        this._value = event.value;\n        // bubble the event\n        this.emitChangeEvent(event);\n      });\n    });\n  }\n}\n"]}