UNPKG

@catull/igniteui-angular

Version:

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

296 lines 24.1 kB
import { __decorate, __extends, __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'; var IgxButtonDirective = /** @class */ (function (_super) { __extends(IgxButtonDirective, _super); function IgxButtonDirective(element, _renderer, _displayDensityOptions) { var _this = _super.call(this, _displayDensityOptions) || this; _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; return _this; } Object.defineProperty(IgxButtonDirective.prototype, "nativeElement", { /** * Returns the underlying DOM element */ get: function () { return this.element.nativeElement; }, enumerable: true, configurable: true }); Object.defineProperty(IgxButtonDirective.prototype, "type", { /** * Sets the type of the button. * ```html * <button igxButton= "icon"></button> * ``` * @memberof IgxButtonDirective */ set: function (value) { var 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); } }, enumerable: true, configurable: true }); Object.defineProperty(IgxButtonDirective.prototype, "color", { /** * Sets the button text color. * ```html * <button igxButton="gradient" igxButtonColor="blue"></button> * ``` * @memberof IgxButtonDirective */ set: function (value) { this._color = value || this.nativeElement.style.color; this._renderer.setStyle(this.nativeElement, 'color', this._color); }, enumerable: true, configurable: true }); Object.defineProperty(IgxButtonDirective.prototype, "background", { /** * Sets the background color of the button. * ```html * <button igxButton="raised" igxButtonBackground="red"></button> * ``` * @memberof IgxButtonDirective */ set: function (value) { this._backgroundColor = value || this._backgroundColor; this._renderer.setStyle(this.nativeElement, 'background', this._backgroundColor); }, enumerable: true, configurable: true }); Object.defineProperty(IgxButtonDirective.prototype, "label", { /** * Sets the `aria-label` attribute. * ```html * <button igxButton= "flat" igxLabel="Label"></button> * ``` * @memberof IgxButtonDirective */ set: function (value) { this._label = value || this._label; this._renderer.setAttribute(this.nativeElement, "aria-label", this._label); }, enumerable: true, configurable: true }); Object.defineProperty(IgxButtonDirective.prototype, "disabled", { /** * Enables/disables the button. * ```html * <button igxButton= "fab" [disabled]="true"></button> * ``` * @memberof IgxButtonDirective */ set: function (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"); } }, enumerable: true, configurable: true }); Object.defineProperty(IgxButtonDirective.prototype, "cssClassCosy", { /** * @hidden */ get: function () { return (this._type === 'flat' || this._type === 'raised' || this._type === 'outlined') && this.displayDensity === DisplayDensity.cosy; }, enumerable: true, configurable: true }); Object.defineProperty(IgxButtonDirective.prototype, "cssClassCompact", { /** * @hidden */ get: function () { return (this._type === 'flat' || this._type === 'raised' || this._type === 'outlined') && this.displayDensity === DisplayDensity.compact; }, enumerable: true, configurable: true }); Object.defineProperty(IgxButtonDirective.prototype, "cssClassCosyFab", { /** * @hidden */ get: function () { return this._type === 'fab' && this.displayDensity === DisplayDensity.cosy; }, enumerable: true, configurable: true }); Object.defineProperty(IgxButtonDirective.prototype, "cssClassCompactFab", { /** * @hidden */ get: function () { return this._type === 'fab' && this.displayDensity === DisplayDensity.compact; }, enumerable: true, configurable: true }); Object.defineProperty(IgxButtonDirective.prototype, "disabledAttribute", { /** * @hidden */ get: function () { return this._disabled ? this._disabled : null; }, enumerable: true, configurable: true }); /** *@hidden */ IgxButtonDirective.prototype.onClick = function (ev) { this.buttonClick.emit(ev); }; IgxButtonDirective.ctorParameters = function () { return [ { 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); return IgxButtonDirective; }(DisplayDensityBase)); export { IgxButtonDirective }; /** * @hidden */ var IgxButtonModule = /** @class */ (function () { function IgxButtonModule() { } IgxButtonModule = __decorate([ NgModule({ declarations: [IgxButtonDirective], exports: [IgxButtonDirective] }) ], IgxButtonModule); return 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":";AAAA,OAAO,EACH,SAAS,EACT,UAAU,EACV,YAAY,EACZ,WAAW,EACX,KAAK,EACL,MAAM,EACN,QAAQ,EACR,SAAS,EACT,YAAY,EACZ,QAAQ,EACR,MAAM,EACT,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,kBAAkB,EAAE,mBAAmB,EAA0B,cAAc,EAAE,MAAM,oBAAoB,CAAC;AAKrH;IAAwC,sCAAkB;IAqCtD,4BAAmB,OAAmB,EAAU,SAAoB,EACb,sBAA8C;QADrG,YAEI,kBAAM,sBAAsB,CAAC,SAChC;QAHkB,aAAO,GAAP,OAAO,CAAY;QAAU,eAAS,GAAT,SAAS,CAAW;QACb,4BAAsB,GAAtB,sBAAsB,CAAwB;QA/BrG;;WAEG;QACK,kBAAY,GAAG,MAAM,CAAC;QAE9B;;WAEG;QACK,qBAAe,GAAG,YAAY,CAAC;QAkCvC;;WAEG;QAEI,iBAAW,GAAG,IAAI,YAAY,EAAO,CAAC;QAE7C;;;;;;;;;WASG;QAEI,UAAI,GAAG,QAAQ,CAAC;QAkHvB;;;;;;;WAOG;QACa,cAAQ,GAAG,KAAK,CAAC;;IApJjC,CAAC;IAKD,sBAAW,6CAAa;QAHxB;;WAEG;aACH;YACI,OAAO,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC;QACtC,CAAC;;;OAAA;IA6BD,sBAAI,oCAAI;QARR;;;;;;WAMG;aAEH,UAAS,KAAa;YAClB,IAAM,QAAQ,GAAG,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC;YACnD,IAAI,IAAI,CAAC,KAAK,KAAK,QAAQ,EAAE;gBACzB,IAAI,CAAC,SAAS,CAAC,WAAW,CAAC,IAAI,CAAC,aAAa,EAAK,IAAI,CAAC,eAAe,UAAK,IAAI,CAAC,KAAO,CAAC,CAAC;gBACzF,IAAI,CAAC,KAAK,GAAG,QAAQ,CAAC;gBACtB,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,IAAI,CAAC,aAAa,EAAK,IAAI,CAAC,eAAe,UAAK,IAAI,CAAC,KAAO,CAAC,CAAC;aACzF;QACL,CAAC;;;OAAA;IASwB,sBAAI,qCAAK;QAPlC;;;;;;WAMG;aACsB,UAAU,KAAa;YAC5C,IAAI,CAAC,MAAM,GAAG,KAAK,IAAI,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC,KAAK,CAAC;YACtD,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,IAAI,CAAC,aAAa,EAAE,OAAO,EAAE,IAAI,CAAC,MAAM,CAAC,CAAC;QACtE,CAAC;;;OAAA;IAS6B,sBAAI,0CAAU;QAP5C;;;;;;WAMG;aAC2B,UAAe,KAAa;YACtD,IAAI,CAAC,gBAAgB,GAAG,KAAK,IAAI,IAAI,CAAC,gBAAgB,CAAC;YACvD,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,IAAI,CAAC,aAAa,EAAE,YAAY,EAAE,IAAI,CAAC,gBAAgB,CAAC,CAAC;QACrF,CAAC;;;OAAA;IASkB,sBAAI,qCAAK;QAP5B;;;;;;WAMG;aACgB,UAAU,KAAa;YACtC,IAAI,CAAC,MAAM,GAAG,KAAK,IAAI,IAAI,CAAC,MAAM,CAAC;YACnC,IAAI,CAAC,SAAS,CAAC,YAAY,CAAC,IAAI,CAAC,aAAa,EAAE,YAAY,EAAE,IAAI,CAAC,MAAM,CAAC,CAAC;QAC/E,CAAC;;;OAAA;IASQ,sBAAI,wCAAQ;QAPrB;;;;;;WAMG;aACM,UAAa,GAAG;YACrB,GAAG,GAAG,CAAC,CAAC,GAAG,CAAC;YACZ,IAAI,CAAC,SAAS,GAAG,GAAG,CAAC;YACrB,IAAI,GAAG,EAAE;gBACL,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,IAAI,CAAC,aAAa,EAAK,IAAI,CAAC,eAAe,eAAY,CAAC,CAAC;aACpF;iBAAM;gBACH,IAAI,CAAC,SAAS,CAAC,WAAW,CAAC,IAAI,CAAC,aAAa,EAAK,IAAI,CAAC,eAAe,eAAY,CAAC,CAAC;aACvF;QACL,CAAC;;;OAAA;IAMD,sBAAW,4CAAY;QAJvB;;WAEG;aAEH;YACI,OAAO,CAAC,IAAI,CAAC,KAAK,KAAK,MAAM,IAAI,IAAI,CAAC,KAAK,KAAK,QAAQ,IAAI,IAAI,CAAC,KAAK,KAAK,UAAU,CAAC;gBAClF,IAAI,CAAC,cAAc,KAAK,cAAc,CAAC,IAAI,CAAC;QACpD,CAAC;;;OAAA;IAMD,sBAAW,+CAAe;QAJ1B;;WAEG;aAEH;YACI,OAAO,CAAC,IAAI,CAAC,KAAK,KAAK,MAAM,IAAI,IAAI,CAAC,KAAK,KAAK,QAAQ,IAAI,IAAI,CAAC,KAAK,KAAK,UAAU,CAAC;gBAClF,IAAI,CAAC,cAAc,KAAK,cAAc,CAAC,OAAO,CAAC;QACvD,CAAC;;;OAAA;IAMD,sBAAW,+CAAe;QAJ1B;;WAEG;aAEH;YACI,OAAO,IAAI,CAAC,KAAK,KAAK,KAAK,IAAI,IAAI,CAAC,cAAc,KAAK,cAAc,CAAC,IAAI,CAAC;QAC/E,CAAC;;;OAAA;IAMD,sBAAW,kDAAkB;QAJ7B;;WAEG;aAEH;YACI,OAAO,IAAI,CAAC,KAAK,KAAK,KAAK,IAAI,IAAI,CAAC,cAAc,KAAK,cAAc,CAAC,OAAO,CAAC;QAClF,CAAC;;;OAAA;IAMD,sBAAW,iDAAiB;QAJ5B;;WAEG;aAEH;YACI,OAAO,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,IAAI,CAAC;QAClD,CAAC;;;OAAA;IAYD;;OAEG;IAEI,oCAAO,GAAd,UAAe,EAAE;QACb,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;IAC9B,CAAC;;gBA/J2B,UAAU;gBAAqB,SAAS;gDAC/D,QAAQ,YAAI,MAAM,SAAC,mBAAmB;;IAe3C;QADC,MAAM,EAAE;;2DACoC;IAa7C;QADC,WAAW,CAAC,WAAW,CAAC;;oDACF;IAUvB;QADC,KAAK,CAAC,WAAW,CAAC;;;kDAQlB;IASwB;QAAxB,KAAK,CAAC,gBAAgB,CAAC;;;mDAGvB;IAS6B;QAA7B,KAAK,CAAC,qBAAqB,CAAC;;;wDAG5B;IASkB;QAAlB,KAAK,CAAC,UAAU,CAAC;;;mDAGjB;IASQ;QAAR,KAAK,EAAE;;;sDAQP;IAMD;QADC,WAAW,CAAC,wBAAwB,CAAC;;;0DAIrC;IAMD;QADC,WAAW,CAAC,2BAA2B,CAAC;;;6DAIxC;IAMD;QADC,WAAW,CAAC,4BAA4B,CAAC;;;6DAGzC;IAMD;QADC,WAAW,CAAC,+BAA+B,CAAC;;;gEAG5C;IAMD;QADC,WAAW,CAAC,eAAe,CAAC;;;+DAG5B;IAUQ;QAAR,KAAK,EAAE;;wDAAyB;IAMjC;QADC,YAAY,CAAC,OAAO,EAAE,CAAC,QAAQ,CAAC,CAAC;;;;qDAGjC;IApMQ,kBAAkB;QAH9B,SAAS,CAAC;YACP,QAAQ,EAAE,aAAa;SAC1B,CAAC;QAuCO,WAAA,QAAQ,EAAE,CAAA,EAAE,WAAA,MAAM,CAAC,mBAAmB,CAAC,CAAA;yCADhB,UAAU,EAAqB,SAAS;OArC3D,kBAAkB,CAqM9B;IAAD,yBAAC;CAAA,AArMD,CAAwC,kBAAkB,GAqMzD;SArMY,kBAAkB;AAuM/B;;GAEG;AAKH;IAAA;IAA+B,CAAC;IAAnB,eAAe;QAJ3B,QAAQ,CAAC;YACN,YAAY,EAAE,CAAC,kBAAkB,CAAC;YAClC,OAAO,EAAE,CAAC,kBAAkB,CAAC;SAChC,CAAC;OACW,eAAe,CAAI;IAAD,sBAAC;CAAA,AAAhC,IAAgC;SAAnB,eAAe","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"]}