@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>
400 lines • 26.6 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 { Radio } from './radio.component';
// tslint:disable-next-line: component-class-suffix
export class RadioGroup {
constructor() {
this.orientation = 'horizontal';
this.radioLabelPlacement = 'right';
/**
* Emits event notifying other classes of a change using a `RadioChange` class.
*/
// tslint:disable-next-line: no-output-native
this.change = new EventEmitter();
/**
* Set to true to disable the whole radio group
*/
this.disabled = false;
/**
* Binds 'form-item' value to the class for `RadioGroup`.
*/
this.radioButtonGroupClass = true;
/**
* To track whether the `RadioGroup` 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 `RadioGroup`.
*/
this._value = null;
/**
* The `Radio` within the `RadioGroup` that is selected.
*/
this._selected = null;
/**
* The name attribute associated with the `RadioGroup`.
*/
this._name = `radio-group-${RadioGroup.radioGroupCount++}`;
/**
* 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 `Radio` item as the selected input within the `RadioGroup`.
* @param {?} selected
* @return {?}
*/
set selected(selected) {
this._selected = selected;
this.value = selected ? selected.value : null;
this.checkSelectedRadio();
}
/**
* Returns the `Radio` that is selected within the `RadioGroup`.
* @return {?}
*/
get selected() {
return this._selected;
}
/**
* Sets the value/state of the selected `Radio` within the `RadioGroup` to the passed in value.
* @param {?} newValue
* @return {?}
*/
set value(newValue) {
if (this._value !== newValue) {
this._value = newValue;
this.updateSelectedRadioFromValue();
this.checkSelectedRadio();
}
}
/**
* Returns the value/state of the selected `Radio` within the `RadioGroup`.
* @return {?}
*/
get value() {
return this._value;
}
/**
* Replaces the name associated with the `RadioGroup` with the provided parameter.
* @param {?} name
* @return {?}
*/
set name(name) {
this._name = name;
this.updateRadios();
}
/**
* Returns the associated name of the `RadioGroup`.
* @return {?}
*/
get name() {
return this._name;
}
/**
* Returns the skeleton value in the `RadioGroup` if there is one.
* @return {?}
*/
get skeleton() {
return this._skeleton;
}
/**
* Sets the skeleton value for all `Radio` to the skeleton value of `RadioGroup`.
* @param {?} value
* @return {?}
*/
set skeleton(value) {
this._skeleton = value;
this.updateChildren();
}
/**
* Updates the selected `Radio` to be checked (selected).
* @return {?}
*/
checkSelectedRadio() {
if (this.selected && !this._selected.checked) {
this.selected.checked = true;
}
}
/**
* Use the value of the `RadioGroup` to update the selected radio to the right state (selected state).
* @return {?}
*/
updateSelectedRadioFromValue() {
/** @type {?} */
const alreadySelected = this._selected != null && this._selected.value === this._value;
if (this.radios && !alreadySelected) {
this._selected = null;
this.radios.forEach((/**
* @param {?} radio
* @return {?}
*/
radio => {
if (radio.checked) {
this._selected = radio;
}
}));
}
}
/**
* Creates a class of `RadioChange` to emit the change in the `RadioGroup`.
* @param {?} event
* @return {?}
*/
emitChangeEvent(event) {
this.change.emit(event);
this.propagateChange(event.value);
this.onTouched();
}
/**
* @return {?}
*/
updateRadioNames() {
console.warn('updateRadioNames had been deprecated. Use updateRadios instead');
this.updateRadios();
}
/**
* Synchronizes radio properties.
* @return {?}
*/
updateRadios() {
if (this.radios) {
setTimeout((/**
* @return {?}
*/
() => {
this.radios.forEach((/**
* @param {?} radio
* @return {?}
*/
radio => radio.name = this.name));
if (this.radioLabelPlacement === 'left') {
this.radios.forEach((/**
* @param {?} radio
* @return {?}
*/
radio => radio.labelPlacement = 'left'));
}
}));
}
}
/**
* Updates the value of the `RadioGroup` using the provided parameter.
* @param {?} value
* @return {?}
*/
writeValue(value) {
this.value = value;
}
/**
* @return {?}
*/
ngAfterContentInit() {
this.radios.changes.subscribe((/**
* @return {?}
*/
() => {
this.updateRadios();
this.updateRadioChangeHandler();
}));
this.updateChildren();
this.updateRadioChangeHandler();
}
/**
* @return {?}
*/
ngAfterViewInit() {
this.updateRadios();
}
/**
* 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.radios) {
this.radios.forEach((/**
* @param {?} child
* @return {?}
*/
child => child.skeleton = this.skeleton));
}
}
/**
* @protected
* @return {?}
*/
updateRadioChangeHandler() {
this.radios.forEach((/**
* @param {?} radio
* @return {?}
*/
radio => {
radio.registerRadioChangeHandler((/**
* @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);
}));
}));
}
}
RadioGroup.radioGroupCount = 0;
RadioGroup.decorators = [
{ type: Component, args: [{
selector: 'suka-radio-group',
template: `
<div
class="radio-button-group"
[ngClass]="{
'radio-button-group--vertical': orientation === 'vertical',
'radio-button-group--label-left': orientation === 'vertical' && radioLabelPlacement === 'left'
}"
role="radiogroup">
<ng-content></ng-content>
</div>
`,
providers: [
{
provide: NG_VALUE_ACCESSOR,
useExisting: RadioGroup,
multi: true
}
]
}] }
];
RadioGroup.propDecorators = {
orientation: [{ type: Input }],
radioLabelPlacement: [{ type: Input }],
change: [{ type: Output }],
radios: [{ type: ContentChildren, args: [forwardRef((/**
* @return {?}
*/
() => Radio)),] }],
selected: [{ type: Input }],
value: [{ type: Input }],
name: [{ type: Input }],
disabled: [{ type: Input }],
skeleton: [{ type: Input }],
radioButtonGroupClass: [{ type: HostBinding, args: ['class.form-item',] }]
};
if (false) {
/** @type {?} */
RadioGroup.radioGroupCount;
/** @type {?} */
RadioGroup.prototype.orientation;
/** @type {?} */
RadioGroup.prototype.radioLabelPlacement;
/**
* Emits event notifying other classes of a change using a `RadioChange` class.
* @type {?}
*/
RadioGroup.prototype.change;
/**
* The `Radio` input items in the `RadioGroup`.
* @type {?}
*/
RadioGroup.prototype.radios;
/**
* Set to true to disable the whole radio group
* @type {?}
*/
RadioGroup.prototype.disabled;
/**
* Binds 'form-item' value to the class for `RadioGroup`.
* @type {?}
*/
RadioGroup.prototype.radioButtonGroupClass;
/**
* To track whether the `RadioGroup` has been initialized.
* @type {?}
* @protected
*/
RadioGroup.prototype.isInitialized;
/**
* Reflects whether or not the input is disabled and cannot be selected.
* @type {?}
* @protected
*/
RadioGroup.prototype._disabled;
/**
* Reflects whether or not the dropdown is loading.
* @type {?}
* @protected
*/
RadioGroup.prototype._skeleton;
/**
* The value of the selected option within the `RadioGroup`.
* @type {?}
* @protected
*/
RadioGroup.prototype._value;
/**
* The `Radio` within the `RadioGroup` that is selected.
* @type {?}
* @protected
*/
RadioGroup.prototype._selected;
/**
* The name attribute associated with the `RadioGroup`.
* @type {?}
* @protected
*/
RadioGroup.prototype._name;
/**
* Needed to properly implement ControlValueAccessor.
* @type {?}
*/
RadioGroup.prototype.onTouched;
/**
* Method set in registerOnChange to propagate changes back to the form.
* @type {?}
*/
RadioGroup.prototype.propagateChange;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"radio-group.component.js","sourceRoot":"ng://@kushki/ng-suka/","sources":["lib/radio/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 { Radio } from './radio.component';\nimport { RadioChange } from './radio-change.class';\n\n@Component({\n  selector: 'suka-radio-group',\n  template: `\n    <div\n      class=\"radio-button-group\"\n      [ngClass]=\"{\n        'radio-button-group--vertical': orientation === 'vertical',\n        'radio-button-group--label-left': orientation === 'vertical' && radioLabelPlacement === 'left'\n      }\"\n      role=\"radiogroup\">\n      <ng-content></ng-content>\n    </div>\n  `,\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: RadioGroup,\n      multi: true\n    }\n  ]\n})\n// tslint:disable-next-line: component-class-suffix\nexport class RadioGroup implements AfterContentInit, AfterViewInit, ControlValueAccessor {\n  static radioGroupCount = 0;\n\n  @Input() orientation: 'horizontal' | 'vertical' = 'horizontal';\n\n  @Input() radioLabelPlacement: 'right' | 'left' = 'right';\n\n  /**\n   * Emits event notifying other classes of a change using a `RadioChange` class.\n   */\n  // tslint:disable-next-line: no-output-native\n  @Output() change: EventEmitter<RadioChange> = new EventEmitter<RadioChange>();\n\n  /**\n   * The `Radio` input items in the `RadioGroup`.\n   */\n  @ContentChildren(forwardRef(() => Radio)) radios: QueryList<Radio>;\n\n  /**\n   * Sets the passed in `Radio` item as the selected input within the `RadioGroup`.\n   */\n  @Input()\n  set selected(selected: Radio | null) {\n    this._selected = selected;\n    this.value = selected ? selected.value : null;\n    this.checkSelectedRadio();\n  }\n\n  /**\n   * Returns the `Radio` that is selected within the `RadioGroup`.\n   */\n  get selected() {\n    return this._selected;\n  }\n\n  /**\n   * Sets the value/state of the selected `Radio` within the `RadioGroup` 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.updateSelectedRadioFromValue();\n      this.checkSelectedRadio();\n    }\n  }\n\n  /**\n   * Returns the value/state of the selected `Radio` within the `RadioGroup`.\n   */\n  get value() {\n    return this._value;\n  }\n\n  /**\n   * Replaces the name associated with the `RadioGroup` with the provided parameter.\n   */\n  @Input()\n  set name(name: string) {\n    this._name = name;\n    this.updateRadios();\n  }\n  /**\n   * Returns the associated name of the `RadioGroup`.\n   */\n  get name() {\n    return this._name;\n  }\n\n  /**\n   * Set to true to disable the whole radio group\n   */\n  @Input() disabled = false;\n\n  /**\n   * Returns the skeleton value in the `RadioGroup` 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 `Radio` to the skeleton value of `RadioGroup`.\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 `RadioGroup`.\n   */\n  @HostBinding('class.form-item') radioButtonGroupClass = true;\n\n  /**\n   * To track whether the `RadioGroup` 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 `RadioGroup`.\n   */\n  protected _value: any = null;\n  /**\n   * The `Radio` within the `RadioGroup` that is selected.\n   */\n  protected _selected: Radio = null;\n  /**\n   * The name attribute associated with the `RadioGroup`.\n   */\n  protected _name = `radio-group-${RadioGroup.radioGroupCount++}`;\n\n  /**\n   * Updates the selected `Radio` to be checked (selected).\n   */\n  checkSelectedRadio() {\n    if (this.selected && !this._selected.checked) {\n      this.selected.checked = true;\n    }\n  }\n\n  /**\n   * Use the value of the `RadioGroup` to update the selected radio to the right state (selected state).\n   */\n  updateSelectedRadioFromValue() {\n    const alreadySelected = this._selected != null && this._selected.value === this._value;\n\n    if (this.radios && !alreadySelected) {\n      this._selected = null;\n      this.radios.forEach(radio => {\n        if (radio.checked) {\n          this._selected = radio;\n        }\n      });\n    }\n  }\n\n  /**\n   * Creates a class of `RadioChange` to emit the change in the `RadioGroup`.\n   */\n  emitChangeEvent(event: RadioChange) {\n    this.change.emit(event);\n    this.propagateChange(event.value);\n    this.onTouched();\n  }\n\n  updateRadioNames() {\n    console.warn('updateRadioNames had been deprecated. Use updateRadios instead');\n    this.updateRadios();\n  }\n\n  /**\n   * Synchronizes radio properties.\n   */\n  updateRadios() {\n    if (this.radios) {\n      setTimeout(() => {\n        this.radios.forEach(radio => radio.name = this.name);\n        if (this.radioLabelPlacement === 'left') {\n          this.radios.forEach(radio => radio.labelPlacement = 'left');\n        }\n      });\n    }\n  }\n\n  /**\n   * Updates the value of the `RadioGroup` using the provided parameter.\n   */\n  writeValue(value: any) {\n    this.value = value;\n  }\n\n  ngAfterContentInit() {\n    this.radios.changes.subscribe(() => {\n      this.updateRadios();\n      this.updateRadioChangeHandler();\n    });\n\n    this.updateChildren();\n    this.updateRadioChangeHandler();\n  }\n\n  ngAfterViewInit() {\n    this.updateRadios();\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.radios) {\n      this.radios.forEach(child => child.skeleton = this.skeleton);\n    }\n  }\n\n  protected updateRadioChangeHandler() {\n    this.radios.forEach(radio => {\n      radio.registerRadioChangeHandler((event: RadioChange) => {\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"]}