@uex/web-extensions
Version:
Uex extensions for Angular 6+ web projects
473 lines • 35.1 kB
JavaScript
/**
* @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"]}