UNPKG

fundamental-ngx

Version:

SAP Fiori Fundamentals, implemented in Angular

227 lines 14.8 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ import { Component, ElementRef, EventEmitter, forwardRef, Input, Output, ViewChild, ViewEncapsulation } from '@angular/core'; import { HashService } from '../utils/hash.service'; import { NG_VALUE_ACCESSOR } from '@angular/forms'; /** * The Toggle component is used to activate or deactivate an element. * It uses a visual metaphor to inform the user of the state of the toggle. */ export class ToggleComponent { /** * @hidden * @param {?} hasher */ constructor(hasher) { this.hasher = hasher; /** * Whether the toggle is disabled. */ this.disabled = false; /** * Whether the toggle is checked. */ this.checked = false; /** * aria-label attribute of the inner input element. */ this.ariaLabel = null; /** * aria-labelledby attribute of the inner input element. */ this.ariaLabelledby = null; /** * Event fired when the state of the toggle changes. * *$event* can be used to retrieve the new state of the toggle. */ this.checkedChange = new EventEmitter(); /** * @hidden */ this.onChange = (/** * @return {?} */ () => { }); /** * @hidden */ this.onTouched = (/** * @return {?} */ () => { }); } /** * @hidden * @return {?} */ ngOnInit() { if (!this.id) { this.id = this.hasher.hash(); } if (this.size && this.size !== 'xs' && this.size !== 's' && this.size !== 'l') { this.size = null; } } /** * Set focus on the input element. * @return {?} */ focus() { this.inputElement.nativeElement.focus(); } /** * Get the id of the inner input element of the toggle. * @return {?} */ get innerInputId() { return `${this.id}-input`; } /** * Get the isChecked property of the toggle. * @return {?} */ get isChecked() { return this.checked; } /** * Set the isChecked property of the toggle. * @param {?} value * @return {?} */ set isChecked(value) { this.checked = value; this.onChange(value); this.onTouched(); this.checkedChange.emit(value); } /** * @hidden * @param {?} value Sets the value of the *checked* property of the toggle. * @return {?} */ writeValue(value) { this.checked = value; } /** * @hidden * @param {?} fn User defined function that handles the *onChange* event of the toggle. * @return {?} */ registerOnChange(fn) { this.onChange = fn; } /** * @hidden * @param {?} fn User defined function that handles the *onTouch* event of the toggle. * @return {?} */ registerOnTouched(fn) { this.onTouched = fn; } /** * @hidden * @param {?} isDisabled Sets the value of the *disabled* property of the toggle. * @return {?} */ setDisabledState(isDisabled) { this.disabled = isDisabled; } } ToggleComponent.decorators = [ { type: Component, args: [{ selector: 'fd-toggle', template: "<label class=\"fd-form__label\" [attr.for]=\"innerInputId\">\n <span class=\"fd-toggle fd-form__control\" [ngClass]=\"(this.size ? ('fd-toggle--' + this.size) : '')\">\n <input #input\n type=\"checkbox\"\n [id]=\"innerInputId\"\n [disabled]=\"this.disabled\"\n [attr.aria-checked]=\"checked\"\n [attr.aria-label]=\"this.ariaLabel\"\n [attr.aria-labelledby]=\"this.ariaLabelledby\"\n [(ngModel)]=\"this.isChecked\">\n <span class=\"fd-toggle__switch\" role=\"presentation\"></span>\n </span>\n <ng-content></ng-content>\n</label>\n", providers: [ { provide: NG_VALUE_ACCESSOR, useExisting: forwardRef((/** * @return {?} */ () => ToggleComponent)), multi: true } ], host: { class: 'fd-form__item fd-form__item--check fd-toggle-custom', '[id]': 'id', }, encapsulation: ViewEncapsulation.None, styles: [".fd-toggle-custom{display:block}"] }] } ]; /** @nocollapse */ ToggleComponent.ctorParameters = () => [ { type: HashService } ]; ToggleComponent.propDecorators = { inputElement: [{ type: ViewChild, args: ['input',] }], size: [{ type: Input }], disabled: [{ type: Input }], id: [{ type: Input }], checked: [{ type: Input }], ariaLabel: [{ type: Input }], ariaLabelledby: [{ type: Input }], checkedChange: [{ type: Output }] }; if (false) { /** * @hidden * @type {?} */ ToggleComponent.prototype.inputElement; /** * The size of the toggle. * Can be one of the four *xs*, *s*, *l*, *error* or default. * @type {?} */ ToggleComponent.prototype.size; /** * Whether the toggle is disabled. * @type {?} */ ToggleComponent.prototype.disabled; /** * Id for the toggle component. If omitted, a unique one is generated. * @type {?} */ ToggleComponent.prototype.id; /** * Whether the toggle is checked. * @type {?} */ ToggleComponent.prototype.checked; /** * aria-label attribute of the inner input element. * @type {?} */ ToggleComponent.prototype.ariaLabel; /** * aria-labelledby attribute of the inner input element. * @type {?} */ ToggleComponent.prototype.ariaLabelledby; /** * Event fired when the state of the toggle changes. * *$event* can be used to retrieve the new state of the toggle. * @type {?} */ ToggleComponent.prototype.checkedChange; /** * @hidden * @type {?} */ ToggleComponent.prototype.onChange; /** * @hidden * @type {?} */ ToggleComponent.prototype.onTouched; /** * @type {?} * @private */ ToggleComponent.prototype.hasher; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"toggle.component.js","sourceRoot":"ng://fundamental-ngx/","sources":["lib/toggle/toggle.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, EventEmitter, forwardRef, Input, OnInit, Output, ViewChild, ViewEncapsulation } from '@angular/core';\nimport { HashService } from '../utils/hash.service';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\n\n/**\n * The Toggle component is used to activate or deactivate an element. \n * It uses a visual metaphor to inform the user of the state of the toggle. \n */\n@Component({\n    selector: 'fd-toggle',\n    templateUrl: './toggle.component.html',\n    styleUrls: ['./toggle.component.scss'],\n    providers: [\n        {\n            provide: NG_VALUE_ACCESSOR,\n            useExisting: forwardRef(() => ToggleComponent),\n            multi: true\n        }\n    ],\n    host: {\n        class: 'fd-form__item fd-form__item--check fd-toggle-custom',\n        '[id]': 'id',\n    },\n    encapsulation: ViewEncapsulation.None\n})\nexport class ToggleComponent implements OnInit, ControlValueAccessor {\n    /** @hidden */\n    @ViewChild('input')\n    inputElement: ElementRef<HTMLInputElement>;\n\n    /** \n     * The size of the toggle. \n     * Can be one of the four *xs*, *s*, *l*, *error* or default. \n     */\n    @Input()\n    size: string;\n\n    /** Whether the toggle is disabled. */\n    @Input()\n    disabled: boolean = false;\n\n    /** Id for the toggle component. If omitted, a unique one is generated. */\n    @Input()\n    id: string;\n\n    /** Whether the toggle is checked. */\n    @Input()\n    checked: boolean = false;\n\n    /** aria-label attribute of the inner input element. */\n    @Input()\n    ariaLabel: string = null;\n\n    /** aria-labelledby attribute of the inner input element. */\n    @Input()\n    ariaLabelledby: string = null;\n\n    /** \n     * Event fired when the state of the toggle changes. \n     * *$event* can be used to retrieve the new state of the toggle.\n     */\n    @Output()\n    readonly checkedChange: EventEmitter<boolean> = new EventEmitter<boolean>();\n\n    /** @hidden */\n    onChange: any = () => {};\n\n    /** @hidden */\n    onTouched: any = () => {};\n\n    /** @hidden */\n    constructor(private hasher: HashService) {}\n\n    /** @hidden */\n    ngOnInit() {\n        if (!this.id) {\n            this.id = this.hasher.hash();\n        }\n\n        if (this.size && this.size !== 'xs' && this.size !== 's' && this.size !== 'l') {\n            this.size = null;\n        }\n    }\n\n    /** Set focus on the input element. */\n    public focus(): void {\n        this.inputElement.nativeElement.focus();\n    }\n\n    /** Get the id of the inner input element of the toggle. */\n    get innerInputId(): string {\n        return `${this.id}-input`;\n    }\n\n    /** Get the isChecked property of the toggle. */\n    get isChecked() {\n        return this.checked;\n    }\n\n    /** Set the isChecked property of the toggle. */\n    set isChecked(value) {\n        this.checked = value;\n        this.onChange(value);\n        this.onTouched();\n        this.checkedChange.emit(value);\n    }\n\n    /**\n     * @hidden \n     * @param value Sets the value of the *checked* property of the toggle.\n     */\n    writeValue(value: any) {\n        this.checked = value;\n    }\n\n    /** \n     * @hidden \n     * @param fn User defined function that handles the *onChange* event of the toggle.\n     */\n    registerOnChange(fn) {\n        this.onChange = fn;\n    }\n\n    /** \n     * @hidden \n     * @param fn User defined function that handles the *onTouch* event of the toggle.\n     */\n    registerOnTouched(fn) {\n        this.onTouched = fn;\n    }\n\n    /**\n     * @hidden \n     * @param isDisabled Sets the value of the *disabled* property of the toggle.\n     */\n    setDisabledState(isDisabled: boolean): void {\n        this.disabled = isDisabled;\n    }\n\n}\n"]}