@catull/igniteui-angular
Version:
Ignite UI for Angular is a dependency-free Angular toolkit for building modern web apps
246 lines • 21.4 kB
JavaScript
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":";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,IAAa,kBAAkB,GAA/B,MAAa,kBAAmB,SAAQ,kBAAkB;IAqCtD,YAAmB,OAAmB,EAAU,SAAoB,EACb,sBAA8C;QACjG,KAAK,CAAC,sBAAsB,CAAC,CAAC;QAFf,YAAO,GAAP,OAAO,CAAY;QAAU,cAAS,GAAT,SAAS,CAAW;QACb,2BAAsB,GAAtB,sBAAsB,CAAwB;QA/BrG;;WAEG;QACK,iBAAY,GAAG,MAAM,CAAC;QAE9B;;WAEG;QACK,oBAAe,GAAG,YAAY,CAAC;QAkCvC;;WAEG;QAEI,gBAAW,GAAG,IAAI,YAAY,EAAO,CAAC;QAE7C;;;;;;;;;WASG;QAEI,SAAI,GAAG,QAAQ,CAAC;QAkHvB;;;;;;;WAOG;QACa,aAAQ,GAAG,KAAK,CAAC;IApJjC,CAAC;IAED;;OAEG;IACH,IAAW,aAAa;QACpB,OAAO,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC;IACtC,CAAC;IAqBD;;;;;;OAMG;IAEH,IAAI,IAAI,CAAC,KAAa;QAClB,MAAM,QAAQ,GAAG,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC;QACnD,IAAI,IAAI,CAAC,KAAK,KAAK,QAAQ,EAAE;YACzB,IAAI,CAAC,SAAS,CAAC,WAAW,CAAC,IAAI,CAAC,aAAa,EAAE,GAAG,IAAI,CAAC,eAAe,KAAK,IAAI,CAAC,KAAK,EAAE,CAAC,CAAC;YACzF,IAAI,CAAC,KAAK,GAAG,QAAQ,CAAC;YACtB,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,IAAI,CAAC,aAAa,EAAE,GAAG,IAAI,CAAC,eAAe,KAAK,IAAI,CAAC,KAAK,EAAE,CAAC,CAAC;SACzF;IACL,CAAC;IAED;;;;;;OAMG;IACsB,IAAI,KAAK,CAAC,KAAa;QAC5C,IAAI,CAAC,MAAM,GAAG,KAAK,IAAI,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC,KAAK,CAAC;QACtD,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,IAAI,CAAC,aAAa,EAAE,OAAO,EAAE,IAAI,CAAC,MAAM,CAAC,CAAC;IACtE,CAAC;IAED;;;;;;OAMG;IAC2B,IAAI,UAAU,CAAC,KAAa;QACtD,IAAI,CAAC,gBAAgB,GAAG,KAAK,IAAI,IAAI,CAAC,gBAAgB,CAAC;QACvD,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,IAAI,CAAC,aAAa,EAAE,YAAY,EAAE,IAAI,CAAC,gBAAgB,CAAC,CAAC;IACrF,CAAC;IAED;;;;;;OAMG;IACgB,IAAI,KAAK,CAAC,KAAa;QACtC,IAAI,CAAC,MAAM,GAAG,KAAK,IAAI,IAAI,CAAC,MAAM,CAAC;QACnC,IAAI,CAAC,SAAS,CAAC,YAAY,CAAC,IAAI,CAAC,aAAa,EAAE,YAAY,EAAE,IAAI,CAAC,MAAM,CAAC,CAAC;IAC/E,CAAC;IAED;;;;;;OAMG;IACM,IAAI,QAAQ,CAAC,GAAG;QACrB,GAAG,GAAG,CAAC,CAAC,GAAG,CAAC;QACZ,IAAI,CAAC,SAAS,GAAG,GAAG,CAAC;QACrB,IAAI,GAAG,EAAE;YACL,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,IAAI,CAAC,aAAa,EAAE,GAAG,IAAI,CAAC,eAAe,YAAY,CAAC,CAAC;SACpF;aAAM;YACH,IAAI,CAAC,SAAS,CAAC,WAAW,CAAC,IAAI,CAAC,aAAa,EAAE,GAAG,IAAI,CAAC,eAAe,YAAY,CAAC,CAAC;SACvF;IACL,CAAC;IAED;;OAEG;IAEH,IAAW,YAAY;QACnB,OAAO,CAAC,IAAI,CAAC,KAAK,KAAK,MAAM,IAAI,IAAI,CAAC,KAAK,KAAK,QAAQ,IAAI,IAAI,CAAC,KAAK,KAAK,UAAU,CAAC;YAClF,IAAI,CAAC,cAAc,KAAK,cAAc,CAAC,IAAI,CAAC;IACpD,CAAC;IAED;;OAEG;IAEH,IAAW,eAAe;QACtB,OAAO,CAAC,IAAI,CAAC,KAAK,KAAK,MAAM,IAAI,IAAI,CAAC,KAAK,KAAK,QAAQ,IAAI,IAAI,CAAC,KAAK,KAAK,UAAU,CAAC;YAClF,IAAI,CAAC,cAAc,KAAK,cAAc,CAAC,OAAO,CAAC;IACvD,CAAC;IAED;;OAEG;IAEH,IAAW,eAAe;QACtB,OAAO,IAAI,CAAC,KAAK,KAAK,KAAK,IAAI,IAAI,CAAC,cAAc,KAAK,cAAc,CAAC,IAAI,CAAC;IAC/E,CAAC;IAED;;OAEG;IAEH,IAAW,kBAAkB;QACzB,OAAO,IAAI,CAAC,KAAK,KAAK,KAAK,IAAI,IAAI,CAAC,cAAc,KAAK,cAAc,CAAC,OAAO,CAAC;IAClF,CAAC;IAED;;OAEG;IAEH,IAAW,iBAAiB;QACxB,OAAO,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,IAAI,CAAC;IAClD,CAAC;IAYD;;OAEG;IAEI,OAAO,CAAC,EAAE;QACb,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;IAC9B,CAAC;CACJ,CAAA;;YAhK+B,UAAU;YAAqB,SAAS;4CAC/D,QAAQ,YAAI,MAAM,SAAC,mBAAmB;;AAe3C;IADC,MAAM,EAAE;;uDACoC;AAa7C;IADC,WAAW,CAAC,WAAW,CAAC;;gDACF;AAUvB;IADC,KAAK,CAAC,WAAW,CAAC;;;8CAQlB;AASwB;IAAxB,KAAK,CAAC,gBAAgB,CAAC;;;+CAGvB;AAS6B;IAA7B,KAAK,CAAC,qBAAqB,CAAC;;;oDAG5B;AASkB;IAAlB,KAAK,CAAC,UAAU,CAAC;;;+CAGjB;AASQ;IAAR,KAAK,EAAE;;;kDAQP;AAMD;IADC,WAAW,CAAC,wBAAwB,CAAC;;;sDAIrC;AAMD;IADC,WAAW,CAAC,2BAA2B,CAAC;;;yDAIxC;AAMD;IADC,WAAW,CAAC,4BAA4B,CAAC;;;yDAGzC;AAMD;IADC,WAAW,CAAC,+BAA+B,CAAC;;;4DAG5C;AAMD;IADC,WAAW,CAAC,eAAe,CAAC;;;2DAG5B;AAUQ;IAAR,KAAK,EAAE;;oDAAyB;AAMjC;IADC,YAAY,CAAC,OAAO,EAAE,CAAC,QAAQ,CAAC,CAAC;;;;iDAGjC;AApMQ,kBAAkB;IAH9B,SAAS,CAAC;QACP,QAAQ,EAAE,aAAa;KAC1B,CAAC;IAuCO,WAAA,QAAQ,EAAE,CAAA,EAAE,WAAA,MAAM,CAAC,mBAAmB,CAAC,CAAA;qCADhB,UAAU,EAAqB,SAAS;GArC3D,kBAAkB,CAqM9B;SArMY,kBAAkB;AAuM/B;;GAEG;AAKH,IAAa,eAAe,GAA5B,MAAa,eAAe;CAAI,CAAA;AAAnB,eAAe;IAJ3B,QAAQ,CAAC;QACN,YAAY,EAAE,CAAC,kBAAkB,CAAC;QAClC,OAAO,EAAE,CAAC,kBAAkB,CAAC;KAChC,CAAC;GACW,eAAe,CAAI;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"]}