UNPKG

igniteui-angular

Version:

Ignite UI for Angular is a dependency-free Angular toolkit for building modern web apps

231 lines • 14.7 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ import { Directive, ElementRef, EventEmitter, HostBinding, Input, Output, NgModule, Renderer2, HostListener } from '@angular/core'; export class IgxButtonDirective { /** * @param {?} element * @param {?} _renderer */ constructor(element, _renderer) { this.element = element; this._renderer = _renderer; /** * @hidden */ this._type = 'flat'; /** * @hidden */ this._cssClass = 'igx-button'; /** * Called when the button is clicked */ this.buttonClick = new EventEmitter(); /** * Sets/gets the `role` attribute. * ```typescript * this.button.role = 'navbutton'; * ``` * ```typescript * let buttonRole = this.button.role; * ``` * \@memberof IgxButtonDirective */ this.role = 'button'; /** * Gets or sets whether the button is selected. * Mainly used in the IgxButtonGroup component and it will have no effect if set separately. * ```html * <button igxButton="flat" [selected]="button.selected"></button> * ``` * \@memberof IgxButtonDirective */ this.selected = false; } /** * Returns the underlying DOM element * @return {?} */ get nativeElement() { return this.element.nativeElement; } /** * Sets the type of the button. * ```html * <button igxButton= "icon"></button> * ``` * \@memberof IgxButtonDirective * @param {?} value * @return {?} */ set type(value) { this._type = value || this._type; this._renderer.addClass(this.nativeElement, `${this._cssClass}--${this._type}`); } /** * Sets the button text color. * ```html * <button igxButton="gradient" igxButtonColor="blue"></button> * ``` * \@memberof IgxButtonDirective * @param {?} value * @return {?} */ set color(value) { this._color = value || this.nativeElement.style.color; this._renderer.setStyle(this.nativeElement, 'color', this._color); } /** * Sets the background color of the button. * ```html * <button igxButton="raised" igxButtonBackground="red"></button> * ``` * \@memberof IgxButtonDirective * @param {?} value * @return {?} */ set background(value) { this._backgroundColor = value || this._backgroundColor; this._renderer.setStyle(this.nativeElement, 'background', this._backgroundColor); } /** * Sets the `aria-label` attribute. * ```html * <button igxButton= "flat" igxLabel="Label"></button> * ``` * \@memberof IgxButtonDirective * @param {?} value * @return {?} */ set label(value) { this._label = value || this._label; this._renderer.setAttribute(this.nativeElement, `aria-label`, this._label); } /** * Enables/disables the button. * ```html * <button igxButton= "fab" [disabled]="true"></button> * ``` * \@memberof IgxButtonDirective * @param {?} val * @return {?} */ set disabled(val) { val = !!val; if (val) { this._renderer.addClass(this.nativeElement, `${this._cssClass}--disabled`); } else { this._renderer.removeClass(this.nativeElement, `${this._cssClass}--disabled`); } } /** * @hidden * @param {?} ev * @return {?} */ onClick(ev) { this.buttonClick.emit(ev); } } IgxButtonDirective.decorators = [ { type: Directive, args: [{ selector: '[igxButton]' },] } ]; /** @nocollapse */ IgxButtonDirective.ctorParameters = () => [ { type: ElementRef }, { type: Renderer2 } ]; IgxButtonDirective.propDecorators = { buttonClick: [{ type: Output }], role: [{ type: HostBinding, args: ['attr.role',] }], type: [{ type: Input, args: ['igxButton',] }], color: [{ type: Input, args: ['igxButtonColor',] }], background: [{ type: Input, args: ['igxButtonBackground',] }], label: [{ type: Input, args: ['igxLabel',] }], disabled: [{ type: Input }], selected: [{ type: Input }], onClick: [{ type: HostListener, args: ['click', ['$event'],] }] }; if (false) { /** * @hidden * @type {?} * @private */ IgxButtonDirective.prototype._type; /** * @hidden * @type {?} * @private */ IgxButtonDirective.prototype._cssClass; /** * @hidden * @type {?} * @private */ IgxButtonDirective.prototype._color; /** * @hidden * @type {?} * @private */ IgxButtonDirective.prototype._label; /** * @hidden * @type {?} * @private */ IgxButtonDirective.prototype._backgroundColor; /** * Called when the button is clicked * @type {?} */ IgxButtonDirective.prototype.buttonClick; /** * Sets/gets the `role` attribute. * ```typescript * this.button.role = 'navbutton'; * ``` * ```typescript * let buttonRole = this.button.role; * ``` * \@memberof IgxButtonDirective * @type {?} */ IgxButtonDirective.prototype.role; /** * Gets or sets whether the button is selected. * Mainly used in the IgxButtonGroup component and it will have no effect if set separately. * ```html * <button igxButton="flat" [selected]="button.selected"></button> * ``` * \@memberof IgxButtonDirective * @type {?} */ IgxButtonDirective.prototype.selected; /** @type {?} */ IgxButtonDirective.prototype.element; /** * @type {?} * @private */ IgxButtonDirective.prototype._renderer; } /** * @hidden */ export class IgxButtonModule { } IgxButtonModule.decorators = [ { type: NgModule, args: [{ declarations: [IgxButtonDirective], exports: [IgxButtonDirective] },] } ]; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"button.directive.js","sourceRoot":"ng://igniteui-angular/","sources":["lib/directives/button/button.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, ElementRef, EventEmitter, HostBinding, Input, Output, NgModule, Renderer2, HostListener } from '@angular/core';\n\n@Directive({\n    selector: '[igxButton]'\n})\nexport class IgxButtonDirective {\n    /**\n     *@hidden\n     */\n    private _type = 'flat';\n    /**\n     *@hidden\n     */\n    private _cssClass = 'igx-button';\n    /**\n     *@hidden\n     */\n    private _color: string;\n    /**\n     *@hidden\n     */\n    private _label: string;\n    /**\n     *@hidden\n     */\n    private _backgroundColor: string;\n\n    constructor(public element: ElementRef, private _renderer: Renderer2) { }\n\n    /**\n     * Returns the underlying DOM element\n     */\n    public get nativeElement() {\n        return this.element.nativeElement;\n    }\n\n    /**\n     * Called when the button is clicked\n     */\n    @Output()\n    public buttonClick = new EventEmitter<any>();\n\n    /**\n     * Sets/gets the `role` attribute.\n     * ```typescript\n     * this.button.role = 'navbutton';\n     * ```\n     * ```typescript\n     * let buttonRole =  this.button.role;\n     * ```\n     * @memberof IgxButtonDirective\n     */\n    @HostBinding('attr.role') public role = 'button';\n    /**\n     * Sets the type of the button.\n     * ```html\n     * <button  igxButton= \"icon\"></button>\n     * ```\n     * @memberof IgxButtonDirective\n     */\n    @Input('igxButton') set type(value: string) {\n        this._type = value || this._type;\n        this._renderer.addClass(this.nativeElement, `${this._cssClass}--${this._type}`);\n    }\n    /**\n     * Sets the button text color.\n     * ```html\n     * <button igxButton=\"gradient\" igxButtonColor=\"blue\"></button>\n     * ```\n     * @memberof IgxButtonDirective\n     */\n    @Input('igxButtonColor') set color(value: string) {\n        this._color = value || this.nativeElement.style.color;\n        this._renderer.setStyle(this.nativeElement, 'color', this._color);\n    }\n    /**\n     * Sets the background color of the button.\n     * ```html\n     * <button igxButton=\"raised\" igxButtonBackground=\"red\"></button>\n     * ```\n     * @memberof IgxButtonDirective\n     */\n    @Input('igxButtonBackground') set background(value: string) {\n        this._backgroundColor = value || this._backgroundColor;\n        this._renderer.setStyle(this.nativeElement, 'background', this._backgroundColor);\n    }\n    /**\n     * Sets the `aria-label` attribute.\n     * ```html\n     * <button igxButton= \"flat\" igxLabel=\"Label\"></button>\n     * ```\n     * @memberof IgxButtonDirective\n     */\n    @Input('igxLabel') set label(value: string) {\n        this._label = value || this._label;\n        this._renderer.setAttribute(this.nativeElement, `aria-label`, this._label);\n    }\n    /**\n     * Enables/disables the button.\n     *  ```html\n     * <button igxButton= \"fab\" [disabled]=\"true\"></button>\n     * ```\n     * @memberof IgxButtonDirective\n     */\n    @Input() set disabled(val) {\n        val = !!val;\n        if (val) {\n            this._renderer.addClass(this.nativeElement, `${this._cssClass}--disabled`);\n        } else {\n            this._renderer.removeClass(this.nativeElement, `${this._cssClass}--disabled`);\n        }\n    }\n\n    /**\n     * Gets or sets whether the button is selected.\n     * Mainly used in the IgxButtonGroup component and it will have no effect if set separately.\n     * ```html\n     * <button igxButton=\"flat\" [selected]=\"button.selected\"></button>\n     * ```\n     * @memberof IgxButtonDirective\n     */\n    @Input() public selected = false;\n\n    /**\n     *@hidden\n     */\n    @HostListener('click',  ['$event'])\n    public onClick(ev) {\n        this.buttonClick.emit(ev);\n    }\n}\n\n/**\n * @hidden\n */\n@NgModule({\n    declarations: [IgxButtonDirective],\n    exports: [IgxButtonDirective]\n})\nexport class IgxButtonModule { }\n"]}