@stratio/egeo
Version:
248 lines • 16.7 kB
JavaScript
/**
* @fileoverview added by tsickle
* Generated from: lib/st-checkbox/st-checkbox.component.ts
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
/*
* © 2017 Stratio Big Data Inc., Sucursal en España.
*
* This software is licensed under the Apache License, Version 2.0.
* This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY;
* without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
* See the terms of the License for more details.
*
* SPDX-License-Identifier: Apache-2.0.
*/
import { Component, Input, Output, EventEmitter, forwardRef, ChangeDetectorRef, ChangeDetectionStrategy } from '@angular/core';
import { NG_VALUE_ACCESSOR } from '@angular/forms';
/** @type {?} */
export var CHECKBOX_CONTROL_ACCESSOR = {
provide: NG_VALUE_ACCESSOR,
// tslint:disable-next-line:no-use-before-declare
useExisting: forwardRef((/**
* @return {?}
*/
function () { return StCheckboxComponent; })),
multi: true
};
/**
* \@description {Component} [Checkbox]
*
* The checkbox component represents a custom input of the checkbox type.
*
* \@example
*
* {html}
*
* ```
* <st-checkbox name="option" value="1">
* Option 1
* </st-checkbox>
* ```
*
*/
var StCheckboxComponent = /** @class */ (function () {
function StCheckboxComponent(_changeDetectorRef) {
this._changeDetectorRef = _changeDetectorRef;
/**
* \@Output {{ checked: boolean, value: any }} [change=''] This is emitted when user clicks on the checkbox
*/
this.change = new EventEmitter();
this._checked = false;
this._controlValueAccessorChangeFn = (/**
* @param {?} value
* @return {?}
*/
function (value) { });
this.onTouched = (/**
* @return {?}
*/
function () { });
}
Object.defineProperty(StCheckboxComponent.prototype, "checked", {
/** @Input {boolean} [checked=''] */
get: /**
* \@Input {boolean} [checked='']
* @return {?}
*/
function () {
return this._checked;
},
set: /**
* @param {?} checked
* @return {?}
*/
function (checked) {
if (checked !== this.checked) {
this._checked = checked;
this._changeDetectorRef.markForCheck();
}
},
enumerable: true,
configurable: true
});
Object.defineProperty(StCheckboxComponent.prototype, "labelQaTag", {
get: /**
* @return {?}
*/
function () {
return (this.qaTag || this.name) + '-label';
},
enumerable: true,
configurable: true
});
/**
* @return {?}
*/
StCheckboxComponent.prototype.handleClick = /**
* @return {?}
*/
function () {
if (!this.readonly) {
if (!this.disabled) {
this._checked = !this._checked;
this._controlValueAccessorChangeFn(this._checked);
this.change.emit({ checked: this.checked, value: this.value });
}
}
};
/**
* @param {?} $event
* @return {?}
*/
StCheckboxComponent.prototype.handleChange = /**
* @param {?} $event
* @return {?}
*/
function ($event) {
$event.stopPropagation();
};
/**
* @param {?} value
* @return {?}
*/
StCheckboxComponent.prototype.writeValue = /**
* @param {?} value
* @return {?}
*/
function (value) {
this._checked = value;
this._changeDetectorRef.markForCheck();
};
/**
* @param {?} fn
* @return {?}
*/
StCheckboxComponent.prototype.registerOnChange = /**
* @param {?} fn
* @return {?}
*/
function (fn) {
this._controlValueAccessorChangeFn = fn;
};
/**
* @param {?} fn
* @return {?}
*/
StCheckboxComponent.prototype.registerOnTouched = /**
* @param {?} fn
* @return {?}
*/
function (fn) {
this.onTouched = fn;
};
/**
* @param {?} isDisabled
* @return {?}
*/
StCheckboxComponent.prototype.setDisabledState = /**
* @param {?} isDisabled
* @return {?}
*/
function (isDisabled) {
this.disabled = isDisabled;
this._changeDetectorRef.markForCheck();
};
StCheckboxComponent.decorators = [
{ type: Component, args: [{
selector: 'st-checkbox',
template: "<!--\n\n \u00A9 2017 Stratio Big Data Inc., Sucursal en Espa\u00F1a.\n\n This software is licensed under the Apache License, Version 2.0.\n This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY;\n without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.\n See the terms of the License for more details.\n\n SPDX-License-Identifier: Apache-2.0.\n\n-->\n<label st-label class=\"st-checkbox\" [ngClass]=\"{'disabled' : disabled}\" [attr.id]=\"labelQaTag\" [attr.title]=\"contextualHelp\">\n <div class=\"st-checkbox-container\">\n <input\n type=\"checkbox\"\n [id]=\"qaTag\"\n [name]=\"name\"\n [required]=\"required\"\n [checked]=\"checked\"\n [disabled]=\"disabled\"\n [value]=\"value\"\n [hidden]=\"true\"\n [readonly]=\"readonly\"\n (click)=\"handleClick()\"\n (change)=\"handleChange($event)\" />\n </div>\n <div class=\"custom-checkbox st-checkbox-custom\" [ngClass]=\"{'custom-checkbox--checked' : checked}\"></div><ng-content></ng-content>\n</label>\n",
providers: [CHECKBOX_CONTROL_ACCESSOR],
changeDetection: ChangeDetectionStrategy.OnPush
}] }
];
/** @nocollapse */
StCheckboxComponent.ctorParameters = function () { return [
{ type: ChangeDetectorRef }
]; };
StCheckboxComponent.propDecorators = {
checked: [{ type: Input }],
name: [{ type: Input }],
qaTag: [{ type: Input }],
disabled: [{ type: Input }],
required: [{ type: Input }],
readonly: [{ type: Input }],
value: [{ type: Input }],
contextualHelp: [{ type: Input }],
change: [{ type: Output }]
};
return StCheckboxComponent;
}());
export { StCheckboxComponent };
if (false) {
/**
* \@Input {boolean} [name=''] This parameter shows the final name of the input
* @type {?}
*/
StCheckboxComponent.prototype.name;
/**
* \@Input {boolean} [qaTag=''] Id value for qa test
* @type {?}
*/
StCheckboxComponent.prototype.qaTag;
/**
* \@Input {boolean} [disabled=''] It allows to disable the input component of the checkbox
* @type {?}
*/
StCheckboxComponent.prototype.disabled;
/**
* \@Input {boolean} [required=''] It converts the component into a mandatory field in a form
* @type {?}
*/
StCheckboxComponent.prototype.required;
/**
* \@Input {boolean} [readonly=''] This parameter disables the checkbox and it can not be modified by the user
* @type {?}
*/
StCheckboxComponent.prototype.readonly;
/**
* \@Input {any} [value=''] The value of the checkbox
* @type {?}
*/
StCheckboxComponent.prototype.value;
/**
* \@Input {string} [contextualHelp=''] Information displayed at a tooltip
* @type {?}
*/
StCheckboxComponent.prototype.contextualHelp;
/**
* \@Output {{ checked: boolean, value: any }} [change=''] This is emitted when user clicks on the checkbox
* @type {?}
*/
StCheckboxComponent.prototype.change;
/**
* @type {?}
* @private
*/
StCheckboxComponent.prototype._checked;
/** @type {?} */
StCheckboxComponent.prototype._controlValueAccessorChangeFn;
/** @type {?} */
StCheckboxComponent.prototype.onTouched;
/**
* @type {?}
* @private
*/
StCheckboxComponent.prototype._changeDetectorRef;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"st-checkbox.component.js","sourceRoot":"ng://@stratio/egeo/","sources":["lib/st-checkbox/st-checkbox.component.ts"],"names":[],"mappings":"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","sourcesContent":["/*\n * © 2017 Stratio Big Data Inc., Sucursal en España.\n *\n * This software is licensed under the Apache License, Version 2.0.\n * This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY;\n * without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.\n * See the terms of the License for more details.\n *\n * SPDX-License-Identifier: Apache-2.0.\n */\nimport { Component, Input, Output, EventEmitter, forwardRef, ChangeDetectorRef, ChangeDetectionStrategy } from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\n\nexport const CHECKBOX_CONTROL_ACCESSOR: any = {\n   provide: NG_VALUE_ACCESSOR,\n   // tslint:disable-next-line:no-use-before-declare\n   useExisting: forwardRef(() => StCheckboxComponent),\n   multi: true\n};\n\n/**\n * @description {Component} [Checkbox]\n *\n * The checkbox component represents a custom input of the checkbox type.\n *\n * @example\n *\n * {html}\n *\n * ```\n * <st-checkbox name=\"option\" value=\"1\">\n *    Option 1\n * </st-checkbox>\n * ```\n *\n */\n@Component({\n   selector: 'st-checkbox',\n   templateUrl: './st-checkbox.component.html',\n   providers: [CHECKBOX_CONTROL_ACCESSOR],\n   changeDetection: ChangeDetectionStrategy.OnPush\n})\n\nexport class StCheckboxComponent implements ControlValueAccessor {\n   /** @Input {boolean} [checked='']  */\n   @Input() get checked(): boolean {\n      return this._checked;\n   }\n\n   set checked(checked: boolean) {\n      if (checked !== this.checked) {\n         this._checked = checked;\n         this._changeDetectorRef.markForCheck();\n      }\n   }\n   /** @Input {boolean} [name=''] This parameter shows the final name of the input */\n   @Input() name: string;\n   /** @Input {boolean} [qaTag=''] Id value for qa test */\n   @Input() qaTag: string;\n   /** @Input {boolean} [disabled=''] It allows to disable the input component of the checkbox */\n   @Input() disabled: boolean;\n   /** @Input {boolean} [required=''] It converts the component into a mandatory field in a form */\n   @Input() required: boolean;\n   /** @Input {boolean} [readonly=''] This parameter disables the checkbox and it can not be modified by the user */\n   @Input() readonly: boolean;\n   /** @Input {any} [value=''] The value of the checkbox */\n   @Input() value: any;\n   /** @Input {string} [contextualHelp=''] Information displayed at a tooltip */\n   @Input() contextualHelp: string;\n   /** @Output {{ checked: boolean, value: any }} [change=''] This is emitted when user clicks on the checkbox */\n   @Output() change: EventEmitter<{ checked: boolean, value: any }> = new EventEmitter<{ checked: boolean, value: any }>();\n\n   private _checked: boolean = false;\n\n   constructor(\n      private _changeDetectorRef: ChangeDetectorRef\n   ) {\n\n   }\n\n   _controlValueAccessorChangeFn: (value: any) => void = (value) => { };\n\n   onTouched: () => any = () => { };\n\n   get labelQaTag(): string {\n      return (this.qaTag || this.name) + '-label';\n   }\n\n   handleClick(): void {\n      if (!this.readonly) {\n         if (!this.disabled) {\n            this._checked = !this._checked;\n            this._controlValueAccessorChangeFn(this._checked);\n            this.change.emit({ checked: this.checked, value: this.value });\n         }\n      }\n   }\n\n   handleChange($event: Event): void {\n      $event.stopPropagation();\n   }\n\n   writeValue(value: any): void {\n      this._checked = value;\n      this._changeDetectorRef.markForCheck();\n   }\n\n   registerOnChange(fn: (value: any) => void): void {\n      this._controlValueAccessorChangeFn = fn;\n   }\n\n   registerOnTouched(fn: any): void {\n      this.onTouched = fn;\n   }\n\n   setDisabledState(isDisabled: boolean): void {\n      this.disabled = isDisabled;\n      this._changeDetectorRef.markForCheck();\n   }\n\n}\n"]}