UNPKG

@catull/igniteui-angular

Version:

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

246 lines 21.4 kB
import { __decorate, __metadata, __param } from "tslib"; import { Directive, ElementRef, EventEmitter, HostBinding, Input, Output, NgModule, Renderer2, HostListener, Optional, Inject } from '@angular/core'; import { DisplayDensityBase, DisplayDensityToken, DisplayDensity } from '../../core/density'; let IgxButtonDirective = class IgxButtonDirective extends DisplayDensityBase { constructor(element, _renderer, _displayDensityOptions) { super(_displayDensityOptions); this.element = element; this._renderer = _renderer; this._displayDensityOptions = _displayDensityOptions; /** *@hidden */ this._defaultType = 'flat'; /** *@hidden */ this._cssClassPrefix = '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 */ get nativeElement() { return this.element.nativeElement; } /** * Sets the type of the button. * ```html * <button igxButton= "icon"></button> * ``` * @memberof IgxButtonDirective */ set type(value) { const newValue = value ? value : this._defaultType; if (this._type !== newValue) { this._renderer.removeClass(this.nativeElement, `${this._cssClassPrefix}--${this._type}`); this._type = newValue; this._renderer.addClass(this.nativeElement, `${this._cssClassPrefix}--${this._type}`); } } /** * Sets the button text color. * ```html * <button igxButton="gradient" igxButtonColor="blue"></button> * ``` * @memberof IgxButtonDirective */ 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 */ 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 */ 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 */ set disabled(val) { val = !!val; this._disabled = val; if (val) { this._renderer.addClass(this.nativeElement, `${this._cssClassPrefix}--disabled`); } else { this._renderer.removeClass(this.nativeElement, `${this._cssClassPrefix}--disabled`); } } /** * @hidden */ get cssClassCosy() { return (this._type === 'flat' || this._type === 'raised' || this._type === 'outlined') && this.displayDensity === DisplayDensity.cosy; } /** * @hidden */ get cssClassCompact() { return (this._type === 'flat' || this._type === 'raised' || this._type === 'outlined') && this.displayDensity === DisplayDensity.compact; } /** * @hidden */ get cssClassCosyFab() { return this._type === 'fab' && this.displayDensity === DisplayDensity.cosy; } /** * @hidden */ get cssClassCompactFab() { return this._type === 'fab' && this.displayDensity === DisplayDensity.compact; } /** * @hidden */ get disabledAttribute() { return this._disabled ? this._disabled : null; } /** *@hidden */ onClick(ev) { this.buttonClick.emit(ev); } }; IgxButtonDirective.ctorParameters = () => [ { type: ElementRef }, { type: Renderer2 }, { type: undefined, decorators: [{ type: Optional }, { type: Inject, args: [DisplayDensityToken,] }] } ]; __decorate([ Output(), __metadata("design:type", Object) ], IgxButtonDirective.prototype, "buttonClick", void 0); __decorate([ HostBinding('attr.role'), __metadata("design:type", Object) ], IgxButtonDirective.prototype, "role", void 0); __decorate([ Input('igxButton'), __metadata("design:type", String), __metadata("design:paramtypes", [String]) ], IgxButtonDirective.prototype, "type", null); __decorate([ Input('igxButtonColor'), __metadata("design:type", String), __metadata("design:paramtypes", [String]) ], IgxButtonDirective.prototype, "color", null); __decorate([ Input('igxButtonBackground'), __metadata("design:type", String), __metadata("design:paramtypes", [String]) ], IgxButtonDirective.prototype, "background", null); __decorate([ Input('igxLabel'), __metadata("design:type", String), __metadata("design:paramtypes", [String]) ], IgxButtonDirective.prototype, "label", null); __decorate([ Input(), __metadata("design:type", Object), __metadata("design:paramtypes", [Object]) ], IgxButtonDirective.prototype, "disabled", null); __decorate([ HostBinding('class.igx-button--cosy'), __metadata("design:type", Boolean), __metadata("design:paramtypes", []) ], IgxButtonDirective.prototype, "cssClassCosy", null); __decorate([ HostBinding('class.igx-button--compact'), __metadata("design:type", Boolean), __metadata("design:paramtypes", []) ], IgxButtonDirective.prototype, "cssClassCompact", null); __decorate([ HostBinding('class.igx-button--fab-cosy'), __metadata("design:type", Boolean), __metadata("design:paramtypes", []) ], IgxButtonDirective.prototype, "cssClassCosyFab", null); __decorate([ HostBinding('class.igx-button--fab-compact'), __metadata("design:type", Boolean), __metadata("design:paramtypes", []) ], IgxButtonDirective.prototype, "cssClassCompactFab", null); __decorate([ HostBinding('attr.disabled'), __metadata("design:type", Object), __metadata("design:paramtypes", []) ], IgxButtonDirective.prototype, "disabledAttribute", null); __decorate([ Input(), __metadata("design:type", Object) ], IgxButtonDirective.prototype, "selected", void 0); __decorate([ HostListener('click', ['$event']), __metadata("design:type", Function), __metadata("design:paramtypes", [Object]), __metadata("design:returntype", void 0) ], IgxButtonDirective.prototype, "onClick", null); IgxButtonDirective = __decorate([ Directive({ selector: '[igxButton]' }), __param(2, Optional()), __param(2, Inject(DisplayDensityToken)), __metadata("design:paramtypes", [ElementRef, Renderer2, Object]) ], IgxButtonDirective); export { IgxButtonDirective }; /** * @hidden */ let IgxButtonModule = class IgxButtonModule { }; IgxButtonModule = __decorate([ NgModule({ declarations: [IgxButtonDirective], exports: [IgxButtonDirective] }) ], IgxButtonModule); export { IgxButtonModule }; //# 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 {\n    Directive,\n    ElementRef,\n    EventEmitter,\n    HostBinding,\n    Input,\n    Output,\n    NgModule,\n    Renderer2,\n    HostListener,\n    Optional,\n    Inject\n} from '@angular/core';\nimport { DisplayDensityBase, DisplayDensityToken, IDisplayDensityOptions, DisplayDensity } from '../../core/density';\n\n@Directive({\n    selector: '[igxButton]'\n})\nexport class IgxButtonDirective extends DisplayDensityBase {\n\n    /**\n     *@hidden\n     */\n    private _type: string;\n\n    /**\n     *@hidden\n     */\n    private _defaultType = 'flat';\n\n    /**\n     *@hidden\n     */\n    private _cssClassPrefix = 'igx-button';\n\n    /**\n     *@hidden\n     */\n    private _color: string;\n\n    /**\n     *@hidden\n     */\n    private _label: string;\n\n    /**\n     *@hidden\n     */\n    private _backgroundColor: string;\n\n    /**\n     *@hidden\n     */\n    private _disabled: boolean;\n\n    constructor(public element: ElementRef, private _renderer: Renderer2,\n        @Optional() @Inject(DisplayDensityToken) protected _displayDensityOptions: IDisplayDensityOptions) {\n        super(_displayDensityOptions);\n    }\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')\n    public role = 'button';\n\n    /**\n     * Sets the type of the button.\n     * ```html\n     * <button  igxButton= \"icon\"></button>\n     * ```\n     * @memberof IgxButtonDirective\n     */\n    @Input('igxButton')\n    set type(value: string) {\n        const newValue = value ? value : this._defaultType;\n        if (this._type !== newValue) {\n            this._renderer.removeClass(this.nativeElement, `${this._cssClassPrefix}--${this._type}`);\n            this._type = newValue;\n            this._renderer.addClass(this.nativeElement, `${this._cssClassPrefix}--${this._type}`);\n        }\n    }\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    /**\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    /**\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    /**\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        this._disabled = val;\n        if (val) {\n            this._renderer.addClass(this.nativeElement, `${this._cssClassPrefix}--disabled`);\n        } else {\n            this._renderer.removeClass(this.nativeElement, `${this._cssClassPrefix}--disabled`);\n        }\n    }\n\n    /**\n     * @hidden\n     */\n    @HostBinding('class.igx-button--cosy')\n    public get cssClassCosy(): boolean {\n        return (this._type === 'flat' || this._type === 'raised' || this._type === 'outlined') &&\n            this.displayDensity === DisplayDensity.cosy;\n    }\n\n    /**\n     * @hidden\n     */\n    @HostBinding('class.igx-button--compact')\n    public get cssClassCompact(): boolean {\n        return (this._type === 'flat' || this._type === 'raised' || this._type === 'outlined') &&\n            this.displayDensity === DisplayDensity.compact;\n    }\n\n    /**\n     * @hidden\n     */\n    @HostBinding('class.igx-button--fab-cosy')\n    public get cssClassCosyFab(): boolean {\n        return this._type === 'fab' && this.displayDensity === DisplayDensity.cosy;\n    }\n\n    /**\n     * @hidden\n     */\n    @HostBinding('class.igx-button--fab-compact')\n    public get cssClassCompactFab(): boolean {\n        return this._type === 'fab' && this.displayDensity === DisplayDensity.compact;\n    }\n\n    /**\n     * @hidden\n     */\n    @HostBinding('attr.disabled')\n    public get disabledAttribute() {\n        return this._disabled ? this._disabled : null;\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"]}