fundamental-ngx
Version:
SAP Fundamentals, implemented in Angular
274 lines • 16.7 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import { Component, ElementRef, EventEmitter, forwardRef, Input, Output, ViewChild, ViewEncapsulation } from '@angular/core';
import { NG_VALUE_ACCESSOR } from '@angular/forms';
/** @type {?} */
var toggleUniqueId = 0;
/**
* 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.
*/
var ToggleComponent = /** @class */ (function () {
function ToggleComponent() {
/**
* Whether the toggle is disabled.
*/
this.disabled = false;
/**
* Id for the toggle component. If omitted, a unique one is generated.
*/
this.id = 'fd-toggle-' + toggleUniqueId++;
/**
* 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 {?}
*/
function () { });
/**
* @hidden
*/
this.onTouched = (/**
* @return {?}
*/
function () { });
}
/** @hidden */
/**
* @hidden
* @return {?}
*/
ToggleComponent.prototype.ngOnInit = /**
* @hidden
* @return {?}
*/
function () {
if (this.size && this.size !== 'xs' && this.size !== 's' && this.size !== 'l') {
this.size = null;
}
};
/** Set focus on the input element. */
/**
* Set focus on the input element.
* @return {?}
*/
ToggleComponent.prototype.focus = /**
* Set focus on the input element.
* @return {?}
*/
function () {
this.inputElement.nativeElement.focus();
};
Object.defineProperty(ToggleComponent.prototype, "innerInputId", {
/** Get the id of the inner input element of the toggle. */
get: /**
* Get the id of the inner input element of the toggle.
* @return {?}
*/
function () {
return this.id + "-input";
},
enumerable: true,
configurable: true
});
Object.defineProperty(ToggleComponent.prototype, "isChecked", {
/** Get the isChecked property of the toggle. */
get: /**
* Get the isChecked property of the toggle.
* @return {?}
*/
function () {
return this.checked;
},
/** Set the isChecked property of the toggle. */
set: /**
* Set the isChecked property of the toggle.
* @param {?} value
* @return {?}
*/
function (value) {
this.checked = value;
this.onChange(value);
this.onTouched();
this.checkedChange.emit(value);
},
enumerable: true,
configurable: true
});
/**
* @hidden
* @param value Sets the value of the *checked* property of the toggle.
*/
/**
* @hidden
* @param {?} value Sets the value of the *checked* property of the toggle.
* @return {?}
*/
ToggleComponent.prototype.writeValue = /**
* @hidden
* @param {?} value Sets the value of the *checked* property of the toggle.
* @return {?}
*/
function (value) {
this.checked = value;
};
/**
* @hidden
* @param fn User defined function that handles the *onChange* event of the toggle.
*/
/**
* @hidden
* @param {?} fn User defined function that handles the *onChange* event of the toggle.
* @return {?}
*/
ToggleComponent.prototype.registerOnChange = /**
* @hidden
* @param {?} fn User defined function that handles the *onChange* event of the toggle.
* @return {?}
*/
function (fn) {
this.onChange = fn;
};
/**
* @hidden
* @param fn User defined function that handles the *onTouch* event of the toggle.
*/
/**
* @hidden
* @param {?} fn User defined function that handles the *onTouch* event of the toggle.
* @return {?}
*/
ToggleComponent.prototype.registerOnTouched = /**
* @hidden
* @param {?} fn User defined function that handles the *onTouch* event of the toggle.
* @return {?}
*/
function (fn) {
this.onTouched = fn;
};
/**
* @hidden
* @param isDisabled Sets the value of the *disabled* property of the toggle.
*/
/**
* @hidden
* @param {?} isDisabled Sets the value of the *disabled* property of the toggle.
* @return {?}
*/
ToggleComponent.prototype.setDisabledState = /**
* @hidden
* @param {?} isDisabled Sets the value of the *disabled* property of the toggle.
* @return {?}
*/
function (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 {?}
*/
function () { return ToggleComponent; })),
multi: true
}
],
host: {
class: 'fd-form__item fd-form__item--check fd-toggle-custom',
'[attr.id]': 'id',
},
encapsulation: ViewEncapsulation.None,
styles: [".fd-toggle-custom{display:block}"]
}] }
];
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 }]
};
return ToggleComponent;
}());
export { ToggleComponent };
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;
}
//# 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 { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\n\nlet toggleUniqueId: number = 0;\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        '[attr.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 = 'fd-toggle-' + toggleUniqueId++;\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    ngOnInit() {\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"]}