igniteui-angular
Version:
Ignite UI for Angular is a dependency-free Angular toolkit for building modern web apps
231 lines • 14.7 kB
JavaScript
/**
* @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"]}