@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>
482 lines • 30.5 kB
JavaScript
/**
* @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';
var ButtonRadioGroup = /** @class */ (function () {
function ButtonRadioGroup() {
/**
* 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 {?}
*/
function () { });
/**
* Method set in registerOnChange to propagate changes back to the form.
*/
this.propagateChange = (/**
* @param {?} _
* @return {?}
*/
function (_) { });
}
Object.defineProperty(ButtonRadioGroup.prototype, "selected", {
/**
* Returns the `ButtonRadio` that is selected within the `ButtonRadioGroup`.
*/
get: /**
* Returns the `ButtonRadio` that is selected within the `ButtonRadioGroup`.
* @return {?}
*/
function () {
return this._selected;
},
/**
* Sets the passed in `ButtonRadio` item as the selected input within the `ButtonRadioGroup`.
*/
set: /**
* Sets the passed in `ButtonRadio` item as the selected input within the `ButtonRadioGroup`.
* @param {?} selected
* @return {?}
*/
function (selected) {
this._selected = selected;
this.value = selected ? selected.value : null;
this.checkSelectedButtonRadio();
},
enumerable: true,
configurable: true
});
Object.defineProperty(ButtonRadioGroup.prototype, "value", {
/**
* Returns the value/state of the selected `ButtonRadio` within the `ButtonRadioGroup`.
*/
get: /**
* Returns the value/state of the selected `ButtonRadio` within the `ButtonRadioGroup`.
* @return {?}
*/
function () {
return this._value;
},
/**
* Sets the value/state of the selected `ButtonRadio` within the `ButtonRadioGroup` to the passed in value.
*/
set: /**
* Sets the value/state of the selected `ButtonRadio` within the `ButtonRadioGroup` to the passed in value.
* @param {?} newValue
* @return {?}
*/
function (newValue) {
if (this._value !== newValue) {
this._value = newValue;
this.updateSelectedButtonRadioFromValue();
this.checkSelectedButtonRadio();
}
},
enumerable: true,
configurable: true
});
Object.defineProperty(ButtonRadioGroup.prototype, "name", {
/**
* Returns the associated name of the `ButtonRadioGroup`.
*/
get: /**
* Returns the associated name of the `ButtonRadioGroup`.
* @return {?}
*/
function () {
return this._name;
},
/**
* Replaces the name associated with the `ButtonRadioGroup` with the provided parameter.
*/
set: /**
* Replaces the name associated with the `ButtonRadioGroup` with the provided parameter.
* @param {?} name
* @return {?}
*/
function (name) {
this._name = name;
this.updateButtonRadios();
},
enumerable: true,
configurable: true
});
Object.defineProperty(ButtonRadioGroup.prototype, "skeleton", {
/**
* Returns the skeleton value in the `ButtonRadioGroup` if there is one.
*/
get: /**
* Returns the skeleton value in the `ButtonRadioGroup` if there is one.
* @return {?}
*/
function () {
return this._skeleton;
},
/**
* Sets the skeleton value for all `ButtonRadio` to the skeleton value of `ButtonRadioGroup`.
*/
set: /**
* Sets the skeleton value for all `ButtonRadio` to the skeleton value of `ButtonRadioGroup`.
* @param {?} value
* @return {?}
*/
function (value) {
this._skeleton = value;
this.updateChildren();
},
enumerable: true,
configurable: true
});
/**
* Updates the selected `ButtonRadio` to be checked (selected).
*/
/**
* Updates the selected `ButtonRadio` to be checked (selected).
* @return {?}
*/
ButtonRadioGroup.prototype.checkSelectedButtonRadio = /**
* Updates the selected `ButtonRadio` to be checked (selected).
* @return {?}
*/
function () {
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).
*/
/**
* Use the value of the `ButtonRadioGroup` to update the selected buttonRadio to the right state (selected state).
* @return {?}
*/
ButtonRadioGroup.prototype.updateSelectedButtonRadioFromValue = /**
* Use the value of the `ButtonRadioGroup` to update the selected buttonRadio to the right state (selected state).
* @return {?}
*/
function () {
var _this = this;
/** @type {?} */
var alreadySelected = this._selected != null && this._selected.value === this._value;
if (this.buttonRadios && !alreadySelected) {
this._selected = null;
this.buttonRadios.forEach((/**
* @param {?} buttonRadio
* @return {?}
*/
function (buttonRadio) {
if (buttonRadio.checked) {
_this._selected = buttonRadio;
}
}));
}
};
/**
* Creates a class of `ButtonRadioChange` to emit the change in the `ButtonRadioGroup`.
*/
/**
* Creates a class of `ButtonRadioChange` to emit the change in the `ButtonRadioGroup`.
* @param {?} event
* @return {?}
*/
ButtonRadioGroup.prototype.emitChangeEvent = /**
* Creates a class of `ButtonRadioChange` to emit the change in the `ButtonRadioGroup`.
* @param {?} event
* @return {?}
*/
function (event) {
this.change.emit(event);
this.propagateChange(event.value);
this.onTouched();
};
/**
* Synchronizes buttonRadio properties.
*/
/**
* Synchronizes buttonRadio properties.
* @return {?}
*/
ButtonRadioGroup.prototype.updateButtonRadios = /**
* Synchronizes buttonRadio properties.
* @return {?}
*/
function () {
var _this = this;
if (this.buttonRadios) {
setTimeout((/**
* @return {?}
*/
function () {
_this.buttonRadios.forEach((/**
* @param {?} buttonRadio
* @return {?}
*/
function (buttonRadio) { return buttonRadio.name = _this.name; }));
}));
}
};
/**
* Updates the value of the `ButtonRadioGroup` using the provided parameter.
*/
/**
* Updates the value of the `ButtonRadioGroup` using the provided parameter.
* @param {?} value
* @return {?}
*/
ButtonRadioGroup.prototype.writeValue = /**
* Updates the value of the `ButtonRadioGroup` using the provided parameter.
* @param {?} value
* @return {?}
*/
function (value) {
this.value = value;
};
/**
* @return {?}
*/
ButtonRadioGroup.prototype.ngAfterContentInit = /**
* @return {?}
*/
function () {
var _this = this;
this.buttonRadios.changes.subscribe((/**
* @return {?}
*/
function () {
_this.updateButtonRadios();
_this.updateButtonRadioChangeHandler();
}));
this.updateChildren();
this.updateButtonRadioChangeHandler();
};
/**
* @return {?}
*/
ButtonRadioGroup.prototype.ngAfterViewInit = /**
* @return {?}
*/
function () {
this.updateButtonRadios();
};
/**
* Used to set method to propagate changes back to the form.
*/
/**
* Used to set method to propagate changes back to the form.
* @param {?} fn
* @return {?}
*/
ButtonRadioGroup.prototype.registerOnChange = /**
* Used to set method to propagate changes back to the form.
* @param {?} fn
* @return {?}
*/
function (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.
*/
/**
* Registers a callback to be triggered when the control has been touched.
* @param {?} fn Callback to be triggered when the checkbox is touched.
* @return {?}
*/
ButtonRadioGroup.prototype.registerOnTouched = /**
* Registers a callback to be triggered when the control has been touched.
* @param {?} fn Callback to be triggered when the checkbox is touched.
* @return {?}
*/
function (fn) {
this.onTouched = fn;
};
/**
* @protected
* @return {?}
*/
ButtonRadioGroup.prototype.updateChildren = /**
* @protected
* @return {?}
*/
function () {
var _this = this;
if (this.buttonRadios) {
this.buttonRadios.forEach((/**
* @param {?} child
* @return {?}
*/
function (child) { return child.skeleton = _this.skeleton; }));
}
};
/**
* @protected
* @return {?}
*/
ButtonRadioGroup.prototype.updateButtonRadioChangeHandler = /**
* @protected
* @return {?}
*/
function () {
var _this = this;
this.buttonRadios.forEach((/**
* @param {?} buttonRadio
* @return {?}
*/
function (buttonRadio) {
buttonRadio.registerButtonRadioChangeHandler((/**
* @param {?} event
* @return {?}
*/
function (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: "\n <div\n class=\"button-radio-group\"\n role=\"buttonRadiogroup\">\n <ng-content></ng-content>\n </div>\n ",
providers: [
{
provide: NG_VALUE_ACCESSOR,
useExisting: ButtonRadioGroup,
multi: true
}
]
}] }
];
ButtonRadioGroup.propDecorators = {
change: [{ type: Output }],
buttonRadios: [{ type: ContentChildren, args: [forwardRef((/**
* @return {?}
*/
function () { return ButtonRadio; })),] }],
selected: [{ type: Input }],
value: [{ type: Input }],
name: [{ type: Input }],
disabled: [{ type: Input }],
skeleton: [{ type: Input }],
buttonRadioButtonGroupClass: [{ type: HostBinding, args: ['class.form-item',] }]
};
return ButtonRadioGroup;
}());
export { ButtonRadioGroup };
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  /**\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"]}