UNPKG

@uex/web-extensions

Version:

Uex extensions for Angular 6+ web projects

473 lines 35.1 kB
/** * @fileoverview added by tsickle * Generated from: lib/modules/button/button.component.ts * @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ import { Component, Input, ElementRef } from '@angular/core'; import * as _ from 'lodash'; import { RippleDirective } from './directives/ripple.directive'; /** * Define estilos de botões para elementos. Por razões de acessibilidade, os botões usam um elemento button padrão. * * É uma abstração para os [botões do Bootstrap 4]{\@link https://getbootstrap.com/docs/4.1/components/buttons}, com algumas melhorias e estilos personalizados. * * Demo: {\@link https://gituex.gitlab.io/extensions/web-extensions#components/button} */ export class ButtonComponent extends RippleDirective { /** * @ignore * @param {?} elementRef */ constructor(elementRef) { super(elementRef); this.elementRef = elementRef; /** * Define o atributo "title" de layout que será aplicado ao botão */ this.type = 'button'; this._color = 'primary'; this._mode = 'raised'; this._size = 'default'; this._rounded = false; this._block = false; this._icon_only = false; this._icon_right = false; this._icon_left = false; this._classes = []; this.is_button = false; } /** * Define o modo de layout que será aplicado ao botão * @private * @param {?} mode * @return {?} */ set _setMode(mode) { this._mode = mode; this._updateClasses(); } /** * Define a cor que será aplicada ao botão * @private * @param {?} color * @return {?} */ set _setColor(color) { this._color = color; this._updateClasses(); } /** * Define o tamanho que será aplicado ao botão * @private * @param {?} size * @return {?} */ set _setSize(size) { this._size = size; this._updateClasses(); } /** * Define se será aplicada borda arredondada ao botão * @private * @param {?} rounded * @return {?} */ set _setRounded(rounded) { this._rounded = this._getAttribute(rounded, true); this._updateClasses(); } /** * Define se será aplicada largura "100%" arredondada ao botão * @private * @param {?} block * @return {?} */ set _setBlock(block) { this._block = this._getAttribute(block, true); this._updateClasses(); } /** * Define se o botão deverá se ajustar para receber apenas um icone * @private * @param {?} icon_only * @return {?} */ set _setIconOnly(icon_only) { this._icon_only = this._getAttribute(icon_only, true); this._updateClasses(); } /** * Define se o botão deverá se ajustar para receber um icone a direita * @private * @param {?} icon_right * @return {?} */ set _setIconRight(icon_right) { this._icon_right = this._getAttribute(icon_right, true); this._updateClasses(); } /** * Define se o botão deverá se ajustar para receber um icone a esquerda * @private * @param {?} icon_left * @return {?} */ set _setIconLeft(icon_left) { this._icon_left = this._getAttribute(icon_left, true); this._updateClasses(); } /** * @return {?} */ ngOnInit() { this.is_button = this.elementRef.nativeElement.tagName == 'BUTTON'; this._updateClasses(); } /** * Distância do elemento para o topo do elemento pai mais próximo posicionado com relative * @return {?} */ get offsetTop() { return this.elementRef.nativeElement.offsetTop; } /** * Dispara o gatilho de focus do botão * * @param {?=} has_delay * @return {?} */ focus(has_delay = false) { if (has_delay) { setTimeout((/** * @return {?} */ () => this._doFocus()), 300); } else { this._doFocus(); } } /** * \@internal * @return {?} */ hasRipple() { return !this.no_ripple && !this._isOutline(); } /** * \@internal * @return {?} */ isDarkRipple() { return this.hasRipple() && this._isClear(); } // Modes /** * @private * @return {?} */ _isFab() { return this._mode == 'fab'; } /** * @private * @return {?} */ _isFabFlat() { return this._mode == 'fab-flat'; } /** * @private * @return {?} */ _isClear() { return this._mode == 'clear'; } /** * @private * @return {?} */ _isIcon() { return this._mode == 'icon'; } /** * @private * @return {?} */ _isOutline() { return this._mode == 'outline'; } /** * @private * @return {?} */ _isRaised() { return this._mode == 'raised'; } // Sizes /** * @private * @return {?} */ _isXSmall() { return this._size == 'micro' || this._size == 'xsmall' || this._size == 'xs'; } /** * @private * @return {?} */ _isSmall() { return this._size == 'mini' || this._size == 'small' || this._size == 'sm'; } /** * @private * @return {?} */ _isLarge() { return this._size == 'large' || this._size == 'lg'; } /** * @private * @return {?} */ _isXLarge() { return this._size == 'xlarge' || this._size == 'xl'; } // Miscellaneous /** * @private * @return {?} */ _isRounded() { return this._rounded && !this._isIcon() && !this._isFab() && !this._isFabFlat(); } /** * @private * @return {?} */ _isBlock() { return this._block && !this._isIcon() && !this._isFab() && !this._isFabFlat(); } /** * @private * @return {?} */ _isIconOnly() { return this._icon_only && !this._isIcon() && !this._isFab() && !this._isFabFlat(); } /** * @private * @return {?} */ _isIconRight() { return this._icon_right && !this._isIcon() && !this._isFab() && !this._isFabFlat(); } /** * @private * @return {?} */ _isIconLeft() { return this._icon_left && !this._isIcon() && !this._isFab() && !this._isFabFlat(); } // Colors /** * @private * @return {?} */ _updateClasses() { this._clearClasses(); this._classes.push('btn'); if (this._isFab()) { this._classes.push('btn-fab'); } if (this._isFabFlat()) { this._classes.push('btn-fab-flat'); } if (this._isClear()) { this._classes.push('btn-clear'); } if (this._isIcon()) { this._classes.push('btn-icon'); } if (this._isOutline()) { this._classes.push('btn-outline'); } if (this._isRaised()) { this._classes.push('btn-raised'); } if (this._isRounded()) { this._classes.push('btn-rounded'); } if (this._isBlock()) { this._classes.push('btn-block'); } if (this._isIconOnly()) { this._classes.push('btn-icon-only'); } if (this._isIconRight()) { this._classes.push('btn-icon-right'); } if (this._isIconLeft()) { this._classes.push('btn-icon-left'); } if (this._isXSmall()) { this._classes.push('btn-xs'); } if (this._isSmall()) { this._classes.push('btn-sm'); } if (this._isLarge()) { this._classes.push('btn-lg'); } if (this._isXLarge()) { this._classes.push('btn-xl'); } if (this._color == 'link') { this._classes.push(`btn-${this._color}`); } else { this._classes.push(`btn-${this._isOutline() ? 'outline-' : ''}${this._color || 'default'}`); } this._setClasses(); } /** * @private * @return {?} */ _clearClasses() { if (this._classes) { /** @type {?} */ const current_classes = this.elementRef.nativeElement.className.split(' '); this._classes.forEach((/** * @param {?} _class * @return {?} */ (_class) => { /** @type {?} */ const index = current_classes.indexOf(_class); if (index > -1) { current_classes.splice(index, 1); } })); this._classes = []; this.elementRef.nativeElement.className = current_classes.join(' '); } } /** * @private * @return {?} */ _setClasses() { /** @type {?} */ const current_classes = this.elementRef.nativeElement.className.split(' ').filter((/** * @param {?} i * @return {?} */ (i) => !!i)); this.elementRef.nativeElement.className = _.concat(current_classes, this._classes).join(' '); } /** * @private * @return {?} */ _doFocus() { this.elementRef.nativeElement.focus(); } /** * @private * @template T * @param {?} value * @param {?=} boolean * @return {?} */ _getAttribute(value, boolean = false) { if (boolean) { return (_.isString(value) && value !== 'false') || (_.isBoolean(value) && !!value); } return !!value ? value : null; } } ButtonComponent.decorators = [ { type: Component, args: [{ selector: '[uex-button]', template: "<ng-content></ng-content>\r\n", host: { 'class': 'uex-button', '[attr.type]': 'is_button ? type : null', '[class.with-ripple]': 'hasRipple()', '[class.ripple-dark]': 'isDarkRipple()' } }] } ]; /** @nocollapse */ ButtonComponent.ctorParameters = () => [ { type: ElementRef } ]; ButtonComponent.propDecorators = { type: [{ type: Input, args: ['type',] }], _setMode: [{ type: Input, args: ['mode',] }], _setColor: [{ type: Input, args: ['color',] }], _setSize: [{ type: Input, args: ['size',] }], _setRounded: [{ type: Input, args: ['rounded',] }], _setBlock: [{ type: Input, args: ['block',] }], _setIconOnly: [{ type: Input, args: ['icon-only',] }], _setIconRight: [{ type: Input, args: ['icon-right',] }], _setIconLeft: [{ type: Input, args: ['icon-left',] }] }; if (false) { /** * Define o atributo "title" de layout que será aplicado ao botão * @type {?} */ ButtonComponent.prototype.type; /** * @type {?} * @private */ ButtonComponent.prototype._color; /** * @type {?} * @private */ ButtonComponent.prototype._mode; /** * @type {?} * @private */ ButtonComponent.prototype._size; /** * @type {?} * @private */ ButtonComponent.prototype._rounded; /** * @type {?} * @private */ ButtonComponent.prototype._block; /** * @type {?} * @private */ ButtonComponent.prototype._icon_only; /** * @type {?} * @private */ ButtonComponent.prototype._icon_right; /** * @type {?} * @private */ ButtonComponent.prototype._icon_left; /** * @type {?} * @private */ ButtonComponent.prototype._classes; /** @type {?} */ ButtonComponent.prototype.is_button; /** @type {?} */ ButtonComponent.prototype.elementRef; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"button.component.js","sourceRoot":"ng://@uex/web-extensions/","sources":["lib/modules/button/button.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, ElementRef } from '@angular/core';\r\n\r\nimport * as _ from 'lodash';\r\n\r\nimport { RippleDirective } from './directives/ripple.directive';\r\n\r\n/**\r\n * Define estilos de botões para elementos. Por razões de acessibilidade, os botões usam um elemento button padrão.\r\n *\r\n * É uma abstração para os [botões do Bootstrap 4]{@link https://getbootstrap.com/docs/4.1/components/buttons}, com algumas melhorias e estilos personalizados.\r\n *\r\n * Demo: {@link https://gituex.gitlab.io/extensions/web-extensions#components/button}\r\n */\r\n@Component({\r\n  selector: '[uex-button]',\r\n  templateUrl: './button.component.html',\r\n  host: {\r\n    'class': 'uex-button',\r\n    '[attr.type]': 'is_button ? type : null',\r\n    '[class.with-ripple]': 'hasRipple()',\r\n    '[class.ripple-dark]': 'isDarkRipple()'\r\n  }\r\n})\r\nexport class ButtonComponent extends RippleDirective {\r\n\r\n  /**\r\n   * Define o atributo \"title\" de layout que será aplicado ao botão\r\n   */\r\n  @Input('type') type = 'button';\r\n\r\n  /**\r\n   * Define o modo de layout que será aplicado ao botão\r\n   */\r\n  @Input('mode')\r\n  private set _setMode(mode: ButtonMode) {\r\n    this._mode = mode;\r\n    this._updateClasses();\r\n  }\r\n\r\n  /**\r\n   * Define a cor que será aplicada ao botão\r\n   */\r\n  @Input('color')\r\n  private set _setColor(color: string) {\r\n    this._color = color;\r\n    this._updateClasses();\r\n  }\r\n\r\n  /**\r\n   * Define o tamanho que será aplicado ao botão\r\n   */\r\n  @Input('size')\r\n  private set _setSize(size: ButtonSize) {\r\n    this._size = size;\r\n    this._updateClasses();\r\n  }\r\n\r\n  /**\r\n   * Define se será aplicada borda arredondada ao botão\r\n   */\r\n  @Input('rounded')\r\n  private set _setRounded(rounded: boolean) {\r\n    this._rounded = this._getAttribute(rounded, true);\r\n    this._updateClasses();\r\n  }\r\n\r\n  /**\r\n   * Define se será aplicada largura \"100%\" arredondada ao botão\r\n   */\r\n  @Input('block')\r\n  private set _setBlock(block: boolean) {\r\n    this._block = this._getAttribute(block, true);\r\n    this._updateClasses();\r\n  }\r\n\r\n  /**\r\n   * Define se o botão deverá se ajustar para receber apenas um icone\r\n   */\r\n  @Input('icon-only')\r\n  private set _setIconOnly(icon_only: boolean) {\r\n    this._icon_only = this._getAttribute(icon_only, true);\r\n    this._updateClasses();\r\n  }\r\n\r\n  /**\r\n   * Define se o botão deverá se ajustar para receber um icone a direita\r\n   */\r\n  @Input('icon-right')\r\n  private set _setIconRight(icon_right: boolean) {\r\n    this._icon_right = this._getAttribute(icon_right, true);\r\n    this._updateClasses();\r\n  }\r\n\r\n  /**\r\n   * Define se o botão deverá se ajustar para receber um icone a esquerda\r\n   */\r\n  @Input('icon-left')\r\n  private set _setIconLeft(icon_left: boolean) {\r\n    this._icon_left = this._getAttribute(icon_left, true);\r\n    this._updateClasses();\r\n  }\r\n\r\n  /**\r\n   * @ignore\r\n   */\r\n  constructor(\r\n    public elementRef: ElementRef\r\n  ) {\r\n    super(elementRef);\r\n  }\r\n\r\n  private _color = 'primary';\r\n  private _mode: ButtonMode = 'raised';\r\n  private _size: ButtonSize = 'default';\r\n  private _rounded = false;\r\n  private _block = false;\r\n  private _icon_only = false;\r\n  private _icon_right = false;\r\n  private _icon_left = false;\r\n\r\n  private _classes: Array<string> = [];\r\n\r\n  public is_button = false;\r\n\r\n  public ngOnInit() {\r\n    this.is_button = this.elementRef.nativeElement.tagName == 'BUTTON';\r\n    this._updateClasses();\r\n  }\r\n\r\n  /**\r\n   * Distância do elemento para o topo do elemento pai mais próximo posicionado com relative\r\n   */\r\n  public get offsetTop(): number {\r\n    return this.elementRef.nativeElement.offsetTop;\r\n  }\r\n\r\n  /**\r\n   * Dispara o gatilho de focus do botão\r\n   *\r\n   * @param [has_delay=false] - Adiciona um delay de 300ms para disparar o gatilho depois\r\n   */\r\n  public focus(has_delay: boolean = false) {\r\n    if (has_delay) {\r\n      setTimeout(() => this._doFocus(), 300);\r\n    } else {\r\n      this._doFocus();\r\n    }\r\n  }\r\n\r\n  /**\r\n   * @internal\r\n   */\r\n  public hasRipple(): boolean {\r\n    return !this.no_ripple && !this._isOutline();\r\n  }\r\n\r\n  /**\r\n   * @internal\r\n   */\r\n  public isDarkRipple(): boolean {\r\n    return this.hasRipple() && this._isClear();\r\n  }\r\n\r\n\r\n  // Modes\r\n\r\n  private _isFab(): boolean {\r\n    return this._mode == 'fab';\r\n  }\r\n\r\n  private _isFabFlat(): boolean {\r\n    return this._mode == 'fab-flat';\r\n  }\r\n\r\n  private _isClear(): boolean {\r\n    return this._mode == 'clear';\r\n  }\r\n\r\n  private _isIcon(): boolean {\r\n    return this._mode == 'icon';\r\n  }\r\n\r\n  private _isOutline(): boolean {\r\n    return this._mode == 'outline';\r\n  }\r\n\r\n  private _isRaised(): boolean {\r\n    return this._mode == 'raised';\r\n  }\r\n\r\n  // Sizes\r\n\r\n  private _isXSmall(): boolean {\r\n    return this._size == 'micro' || this._size == 'xsmall' || this._size == 'xs';\r\n  }\r\n\r\n  private _isSmall(): boolean {\r\n    return this._size == 'mini' || this._size == 'small' || this._size == 'sm';\r\n  }\r\n\r\n  private _isLarge(): boolean {\r\n    return this._size == 'large' || this._size == 'lg';\r\n  }\r\n\r\n  private _isXLarge(): boolean {\r\n    return this._size == 'xlarge' || this._size == 'xl';\r\n  }\r\n\r\n  // Miscellaneous\r\n\r\n  private _isRounded(): boolean {\r\n    return this._rounded && !this._isIcon() && !this._isFab() && !this._isFabFlat();\r\n  }\r\n\r\n  private _isBlock(): boolean {\r\n    return this._block && !this._isIcon() && !this._isFab() && !this._isFabFlat();\r\n  }\r\n\r\n  private _isIconOnly(): boolean {\r\n    return this._icon_only && !this._isIcon() && !this._isFab() && !this._isFabFlat();\r\n  }\r\n\r\n  private _isIconRight(): boolean {\r\n    return this._icon_right && !this._isIcon() && !this._isFab() && !this._isFabFlat();\r\n  }\r\n\r\n  private _isIconLeft(): boolean {\r\n    return this._icon_left && !this._isIcon() && !this._isFab() && !this._isFabFlat();\r\n  }\r\n\r\n  // Colors\r\n\r\n  private _updateClasses() {\r\n    this._clearClasses();\r\n\r\n    this._classes.push('btn');\r\n\r\n    if (this._isFab()) { this._classes.push('btn-fab'); }\r\n    if (this._isFabFlat()) { this._classes.push('btn-fab-flat'); }\r\n    if (this._isClear()) { this._classes.push('btn-clear'); }\r\n    if (this._isIcon()) { this._classes.push('btn-icon'); }\r\n    if (this._isOutline()) { this._classes.push('btn-outline'); }\r\n    if (this._isRaised()) { this._classes.push('btn-raised'); }\r\n\r\n    if (this._isRounded()) { this._classes.push('btn-rounded'); }\r\n    if (this._isBlock()) { this._classes.push('btn-block'); }\r\n    if (this._isIconOnly()) { this._classes.push('btn-icon-only'); }\r\n    if (this._isIconRight()) { this._classes.push('btn-icon-right'); }\r\n    if (this._isIconLeft()) { this._classes.push('btn-icon-left'); }\r\n\r\n    if (this._isXSmall()) { this._classes.push('btn-xs'); }\r\n    if (this._isSmall()) { this._classes.push('btn-sm'); }\r\n    if (this._isLarge()) { this._classes.push('btn-lg'); }\r\n    if (this._isXLarge()) { this._classes.push('btn-xl'); }\r\n\r\n    if (this._color == 'link') {\r\n      this._classes.push(`btn-${this._color}`);\r\n    } else {\r\n      this._classes.push(`btn-${this._isOutline() ? 'outline-' : ''}${this._color || 'default'}`);\r\n    }\r\n\r\n    this._setClasses();\r\n  }\r\n\r\n  private _clearClasses() {\r\n    if (this._classes) {\r\n      const current_classes = this.elementRef.nativeElement.className.split(' ');\r\n      this._classes.forEach((_class) => {\r\n        const index = current_classes.indexOf(_class);\r\n        if (index > -1) { current_classes.splice(index, 1); }\r\n      });\r\n      this._classes = [];\r\n      this.elementRef.nativeElement.className = current_classes.join(' ');\r\n    }\r\n  }\r\n\r\n  private _setClasses() {\r\n    const current_classes = this.elementRef.nativeElement.className.split(' ').filter((i) => !!i);\r\n    this.elementRef.nativeElement.className = _.concat(current_classes, this._classes).join(' ');\r\n  }\r\n\r\n  private _doFocus() {\r\n    this.elementRef.nativeElement.focus();\r\n  }\r\n\r\n  private _getAttribute<T>(value: any, boolean: boolean = false): any {\r\n    if (boolean) { return (_.isString(value) && value !== 'false') || (_.isBoolean(value) && !!value); }\r\n    return !!value ? value : null;\r\n  }\r\n}\r\n\r\ntype ButtonModeDefault = 'flat';\r\ntype ButtonModeFab = 'fab' | 'fab-flat';\r\ntype ButtonModeClear = 'clear';\r\ntype ButtonModeIcon = 'icon';\r\ntype ButtonModeRaised = 'raised';\r\ntype ButtonModeOutline = 'outline';\r\n\r\n/**\r\n * Modos suportados pelo botão\r\n */\r\nexport type ButtonMode = ButtonModeDefault | ButtonModeFab | ButtonModeClear | ButtonModeIcon | ButtonModeRaised | ButtonModeOutline;\r\n\r\ntype ButtonSizeDefault = 'default';\r\ntype ButtonSizeXSmall = 'micro' | 'xsmall' | 'xs';\r\ntype ButtonSizeSmall = 'mini' | 'small' | 'sm';\r\ntype ButtonSizeLarge = 'large' | 'lg';\r\ntype ButtonSizeXLarge = 'xlarge' | 'xl';\r\n\r\n/**\r\n * Tamanhos suportados pelo botão\r\n */\r\nexport type ButtonSize = ButtonSizeDefault | ButtonSizeXSmall | ButtonSizeSmall | ButtonSizeLarge | ButtonSizeXLarge;\r\n"]}