@junte/ui
Version:
Quality Angular UI components kit
286 lines • 25.3 kB
JavaScript
import { __decorate, __metadata } from "tslib";
import { animate, state, style, transition, trigger } from '@angular/animations';
import { Component, ContentChildren, EventEmitter, HostBinding, Input, Output, QueryList } from '@angular/core';
import { Shape } from '../../core/enums/shape';
import { PropertyApi } from '../../core/decorators/api';
import { Outline } from '../../core/enums/outline';
import { Position } from '../../core/enums/position';
import { Scheme } from '../../core/enums/scheme';
import { Size } from '../../core/enums/size';
import { UI } from '../../core/enums/ui';
import { Width } from '../../core/enums/width';
import { BadgeComponent } from '../../elements/badge/badge.component';
import { ButtonType } from './button.enums';
var ButtonComponent = /** @class */ (function () {
function ButtonComponent() {
this.host = 'jnt-button-host';
this.ui = UI;
this._type = ButtonType.button;
this._scheme = Scheme.primary;
this._size = Size.normal;
this._outline = Outline.fill;
this._width = Width.default;
this._shape = Shape.square;
this.loading = false;
this.disabled = false;
this.click = new EventEmitter();
}
Object.defineProperty(ButtonComponent.prototype, "shape", {
set: function (shape) {
this._shape = shape || Shape.square;
},
enumerable: true,
configurable: true
});
Object.defineProperty(ButtonComponent.prototype, "_icon", {
set: function (icon) {
this.icon = (typeof icon === 'string'
? { icon: icon, position: Position.left } : icon);
},
enumerable: true,
configurable: true
});
Object.defineProperty(ButtonComponent.prototype, "scheme", {
set: function (scheme) {
this._scheme = scheme || Scheme.primary;
},
enumerable: true,
configurable: true
});
Object.defineProperty(ButtonComponent.prototype, "size", {
get: function () {
return this._size;
},
set: function (size) {
this._size = size || Size.normal;
},
enumerable: true,
configurable: true
});
Object.defineProperty(ButtonComponent.prototype, "withText", {
get: function () {
return !!this.text;
},
enumerable: true,
configurable: true
});
Object.defineProperty(ButtonComponent.prototype, "outline", {
set: function (outline) {
this._outline = outline || Outline.fill;
},
enumerable: true,
configurable: true
});
Object.defineProperty(ButtonComponent.prototype, "width", {
set: function (width) {
this._width = width || Width.default;
},
enumerable: true,
configurable: true
});
Object.defineProperty(ButtonComponent.prototype, "disable", {
get: function () {
return this.disabled || this.loading;
},
enumerable: true,
configurable: true
});
Object.defineProperty(ButtonComponent.prototype, "type", {
get: function () {
return this._type;
},
set: function (type) {
this._type = type || ButtonType.button;
},
enumerable: true,
configurable: true
});
__decorate([
HostBinding('attr.host'),
__metadata("design:type", Object)
], ButtonComponent.prototype, "host", void 0);
__decorate([
HostBinding('attr.data-scheme'),
__metadata("design:type", String)
], ButtonComponent.prototype, "_scheme", void 0);
__decorate([
HostBinding('attr.data-size'),
__metadata("design:type", String)
], ButtonComponent.prototype, "_size", void 0);
__decorate([
HostBinding('attr.data-outline'),
__metadata("design:type", String)
], ButtonComponent.prototype, "_outline", void 0);
__decorate([
HostBinding('attr.data-width'),
__metadata("design:type", String)
], ButtonComponent.prototype, "_width", void 0);
__decorate([
HostBinding('attr.data-shape'),
__metadata("design:type", String)
], ButtonComponent.prototype, "_shape", void 0);
__decorate([
PropertyApi({
description: 'Button shape',
path: 'ui.shape',
default: Shape.square,
options: [Shape.circle, Shape.square]
}),
Input(),
__metadata("design:type", String),
__metadata("design:paramtypes", [String])
], ButtonComponent.prototype, "shape", null);
__decorate([
PropertyApi({
description: 'Set the loading status of button',
type: 'boolean',
default: 'false'
}),
HostBinding('attr.data-loading'),
Input(),
__metadata("design:type", Object)
], ButtonComponent.prototype, "loading", void 0);
__decorate([
PropertyApi({
name: 'icon',
description: 'Icon for button',
type: 'string | {icon: string, position: Position}'
}),
Input('icon'),
__metadata("design:type", Object),
__metadata("design:paramtypes", [Object])
], ButtonComponent.prototype, "_icon", null);
__decorate([
PropertyApi({
description: 'Button color scheme',
path: 'ui.scheme',
options: [Scheme.primary, Scheme.secondary, Scheme.success, Scheme.fail],
default: Scheme.primary
}),
Input(),
__metadata("design:type", String),
__metadata("design:paramtypes", [String])
], ButtonComponent.prototype, "scheme", null);
__decorate([
PropertyApi({
description: 'Button size',
path: 'ui.size',
options: [Size.tiny, Size.small, Size.normal, Size.large],
default: Size.normal
}),
Input(),
__metadata("design:type", String),
__metadata("design:paramtypes", [String])
], ButtonComponent.prototype, "size", null);
__decorate([
HostBinding('attr.data-with-text'),
__metadata("design:type", Object),
__metadata("design:paramtypes", [])
], ButtonComponent.prototype, "withText", null);
__decorate([
PropertyApi({
description: 'Button outline',
path: 'ui.outline',
default: Outline.fill,
options: [Outline.transparent, Outline.ghost, Outline.fill]
}),
Input(),
__metadata("design:type", String),
__metadata("design:paramtypes", [String])
], ButtonComponent.prototype, "outline", null);
__decorate([
PropertyApi({
description: 'Button width',
path: 'ui.width',
default: Width.default,
options: [Width.default, Width.fluid]
}),
Input(),
__metadata("design:type", String),
__metadata("design:paramtypes", [String])
], ButtonComponent.prototype, "width", null);
__decorate([
HostBinding('attr.data-disabled'),
__metadata("design:type", Object),
__metadata("design:paramtypes", [])
], ButtonComponent.prototype, "disable", null);
__decorate([
PropertyApi({
description: 'Set disabled state',
type: 'boolean',
default: 'false',
}),
Input(),
__metadata("design:type", Object)
], ButtonComponent.prototype, "disabled", void 0);
__decorate([
PropertyApi({
description: 'Button typeControl',
path: 'ui.button.type',
default: ButtonType.button,
options: [ButtonType.button, ButtonType.submit]
}),
Input(),
__metadata("design:type", String),
__metadata("design:paramtypes", [String])
], ButtonComponent.prototype, "type", null);
__decorate([
PropertyApi({
description: 'Text on button',
type: 'string',
}),
Input(),
__metadata("design:type", String)
], ButtonComponent.prototype, "text", void 0);
__decorate([
PropertyApi({
description: 'Click event',
path: 'EventEmitter'
}),
Output(),
__metadata("design:type", Object)
], ButtonComponent.prototype, "click", void 0);
__decorate([
ContentChildren(BadgeComponent),
__metadata("design:type", QueryList)
], ButtonComponent.prototype, "badges", void 0);
ButtonComponent = __decorate([
Component({
selector: 'jnt-button',
template: "<button child-of=\"jnt-button-host\" [type]=\"type\" [disabled]=\"disabled || loading\">\n <jnt-spinner child-of=\"jnt-button-host\" data-loading *ngIf=\"loading\" [@appear]=\"loading\"></jnt-spinner>\n <jnt-stack child-of=\"jnt-button-host\" [orientation]=\"ui.orientation.horizontal\"\n [align]=\"ui.align.center\"\n [gutter]=\"ui.gutter.small\">\n <jnt-icon child-of=\"jnt-button-host\" *ngIf=\"!!icon && icon.position === ui.position.left\"\n [@visibility]=\"loading ? 'hide' : 'show'\"\n [icon]=\"icon?.icon\">\n </jnt-icon>\n\n <div child-of=\"jnt-button-host\" data-text *ngIf=\"!!text\"\n [@visibility]=\"loading ? 'hide' : 'show'\">\n {{text}}\n </div>\n\n <jnt-stack child-of=\"jnt-button-host\" data-badges *ngIf=\"badges.length > 0\"\n [@visibility]=\"loading ? 'hide' : 'show'\"\n [orientation]=\"ui.orientation.horizontal\"\n [gutter]=\"ui.gutter.tiny\">\n <jnt-badge child-of=\"jnt-button-host\" data-badge *ngFor=\"let badge of badges\"\n [color]=\"badge.color\"\n [value]=\"badge.value\"\n [overflow]=\"badge.overflow\"\n [position]=\"ui.position.inline\">\n </jnt-badge>\n </jnt-stack>\n\n <jnt-icon child-of=\"jnt-button-host\" *ngIf=\"!!icon && icon.position === ui.position.right\"\n [@visibility]=\"loading ? 'hide' : 'show'\"\n [icon]=\"icon?.icon\">\n </jnt-icon>\n\n <div child-of=\"jnt-button-host\" data-empty *ngIf=\"!icon && !badges.length && !text\" [@visibility]=\"loading ? 'hide' : 'show'\"></div>\n </jnt-stack>\n</button>",
animations: [
trigger('appear', [
state('void', style({
opacity: 0,
width: '200px',
height: '200px'
})),
state('*', style({
opacity: 1,
width: '*',
height: '*'
})),
transition('void => *', [
animate('.5s ease-in-out')
]),
]),
trigger('visibility', [
state('show', style({
visibility: 'visible',
opacity: 1
})),
state('hide', style({
visibility: 'collapse',
opacity: 0
})),
transition('show <=> hide', [
animate('.5s ease-in-out')
]),
])
]
})
], ButtonComponent);
return ButtonComponent;
}());
export { ButtonComponent };
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"button.component.js","sourceRoot":"ng://@junte/ui/","sources":["lib/forms/button/button.component.ts"],"names":[],"mappings":";AAAA,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,KAAK,EAAE,UAAU,EAAE,OAAO,EAAE,MAAM,qBAAqB,CAAC;AACjF,OAAO,EAAE,SAAS,EAAE,eAAe,EAAE,YAAY,EAAE,WAAW,EAAE,KAAK,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,eAAe,CAAC;AAChH,OAAO,EAAE,KAAK,EAAE,MAAM,wBAAwB,CAAC;AAC/C,OAAO,EAAE,WAAW,EAAE,MAAM,2BAA2B,CAAC;AACxD,OAAO,EAAE,OAAO,EAAE,MAAM,0BAA0B,CAAC;AACnD,OAAO,EAAE,QAAQ,EAAE,MAAM,2BAA2B,CAAC;AACrD,OAAO,EAAE,MAAM,EAAE,MAAM,yBAAyB,CAAC;AACjD,OAAO,EAAE,IAAI,EAAE,MAAM,uBAAuB,CAAC;AAC7C,OAAO,EAAE,EAAE,EAAE,MAAM,qBAAqB,CAAC;AACzC,OAAO,EAAE,KAAK,EAAE,MAAM,wBAAwB,CAAC;AAC/C,OAAO,EAAE,cAAc,EAAE,MAAM,sCAAsC,CAAC;AACtE,OAAO,EAAE,UAAU,EAAE,MAAM,gBAAgB,CAAC;AAqD5C;IAAA;QAGW,SAAI,GAAG,iBAAiB,CAAC;QAElC,OAAE,GAAG,EAAE,CAAC;QAEA,UAAK,GAAe,UAAU,CAAC,MAAM,CAAC;QAI9C,YAAO,GAAW,MAAM,CAAC,OAAO,CAAC;QAGjC,UAAK,GAAS,IAAI,CAAC,MAAM,CAAC;QAG1B,aAAQ,GAAY,OAAO,CAAC,IAAI,CAAC;QAGjC,WAAM,GAAU,KAAK,CAAC,OAAO,CAAC;QAG9B,WAAM,GAAU,KAAK,CAAC,MAAM,CAAC;QAoB7B,YAAO,GAAG,KAAK,CAAC;QA6EhB,aAAQ,GAAG,KAAK,CAAC;QA6BjB,UAAK,GAAG,IAAI,YAAY,EAAO,CAAC;IAIlC,CAAC;IAzHC,sBAAI,kCAAK;aAAT,UAAU,KAAY;YACpB,IAAI,CAAC,MAAM,GAAG,KAAK,IAAI,KAAK,CAAC,MAAM,CAAC;QACtC,CAAC;;;OAAA;IAiBD,sBAAI,kCAAK;aAAT,UAAU,IAAmB;YAC3B,IAAI,CAAC,IAAI,GAAU,CAAC,OAAO,IAAI,KAAK,QAAQ;gBAC1C,CAAC,CAAC,EAAC,IAAI,EAAE,IAAI,EAAE,QAAQ,EAAE,QAAQ,CAAC,IAAI,EAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC;QACpD,CAAC;;;OAAA;IASD,sBAAI,mCAAM;aAAV,UAAW,MAAc;YACvB,IAAI,CAAC,OAAO,GAAG,MAAM,IAAI,MAAM,CAAC,OAAO,CAAC;QAC1C,CAAC;;;OAAA;IASD,sBAAI,iCAAI;aAIR;YACE,OAAO,IAAI,CAAC,KAAK,CAAC;QACpB,CAAC;aAND,UAAS,IAAU;YACjB,IAAI,CAAC,KAAK,GAAG,IAAI,IAAI,IAAI,CAAC,MAAM,CAAC;QACnC,CAAC;;;OAAA;IAOD,sBAAI,qCAAQ;aAAZ;YACE,OAAO,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC;QACrB,CAAC;;;OAAA;IASD,sBAAI,oCAAO;aAAX,UAAY,OAAgB;YAC1B,IAAI,CAAC,QAAQ,GAAG,OAAO,IAAI,OAAO,CAAC,IAAI,CAAC;QAC1C,CAAC;;;OAAA;IASD,sBAAI,kCAAK;aAAT,UAAU,KAAY;YACpB,IAAI,CAAC,MAAM,GAAG,KAAK,IAAI,KAAK,CAAC,OAAO,CAAC;QACvC,CAAC;;;OAAA;IAGD,sBAAI,oCAAO;aAAX;YACE,OAAO,IAAI,CAAC,QAAQ,IAAI,IAAI,CAAC,OAAO,CAAC;QACvC,CAAC;;;OAAA;IAiBD,sBAAI,iCAAI;aAIR;YACE,OAAO,IAAI,CAAC,KAAK,CAAC;QACpB,CAAC;aAND,UAAS,IAAgB;YACvB,IAAI,CAAC,KAAK,GAAG,IAAI,IAAI,UAAU,CAAC,MAAM,CAAC;QACzC,CAAC;;;OAAA;IAhID;QADC,WAAW,CAAC,WAAW,CAAC;;iDACS;IAQlC;QADC,WAAW,CAAC,kBAAkB,CAAC;;oDACC;IAGjC;QADC,WAAW,CAAC,gBAAgB,CAAC;;kDACJ;IAG1B;QADC,WAAW,CAAC,mBAAmB,CAAC;;qDACA;IAGjC;QADC,WAAW,CAAC,iBAAiB,CAAC;;mDACD;IAG9B;QADC,WAAW,CAAC,iBAAiB,CAAC;;mDACF;IAS7B;QAPC,WAAW,CAAC;YACX,WAAW,EAAE,cAAc;YAC3B,IAAI,EAAE,UAAU;YAChB,OAAO,EAAE,KAAK,CAAC,MAAM;YACrB,OAAO,EAAE,CAAC,KAAK,CAAC,MAAM,EAAE,KAAK,CAAC,MAAM,CAAC;SACtC,CAAC;QACD,KAAK,EAAE;;;gDAGP;IASD;QAPC,WAAW,CAAC;YACX,WAAW,EAAE,kCAAkC;YAC/C,IAAI,EAAE,SAAS;YACf,OAAO,EAAE,OAAO;SACjB,CAAC;QACD,WAAW,CAAC,mBAAmB,CAAC;QAChC,KAAK,EAAE;;oDACQ;IAQhB;QANC,WAAW,CAAC;YACX,IAAI,EAAE,MAAM;YACZ,WAAW,EAAE,iBAAiB;YAC9B,IAAI,EAAE,6CAA6C;SACpD,CAAC;QACD,KAAK,CAAC,MAAM,CAAC;;;gDAIb;IASD;QAPC,WAAW,CAAC;YACX,WAAW,EAAE,qBAAqB;YAClC,IAAI,EAAE,WAAW;YACjB,OAAO,EAAE,CAAC,MAAM,CAAC,OAAO,EAAE,MAAM,CAAC,SAAS,EAAE,MAAM,CAAC,OAAO,EAAE,MAAM,CAAC,IAAI,CAAC;YACxE,OAAO,EAAE,MAAM,CAAC,OAAO;SACxB,CAAC;QACD,KAAK,EAAE;;;iDAGP;IASD;QAPC,WAAW,CAAC;YACX,WAAW,EAAE,aAAa;YAC1B,IAAI,EAAE,SAAS;YACf,OAAO,EAAE,CAAC,IAAI,CAAC,IAAI,EAAE,IAAI,CAAC,KAAK,EAAE,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,KAAK,CAAC;YACzD,OAAO,EAAE,IAAI,CAAC,MAAM;SACrB,CAAC;QACD,KAAK,EAAE;;;+CAGP;IAOD;QADC,WAAW,CAAC,qBAAqB,CAAC;;;mDAGlC;IASD;QAPC,WAAW,CAAC;YACX,WAAW,EAAE,gBAAgB;YAC7B,IAAI,EAAE,YAAY;YAClB,OAAO,EAAE,OAAO,CAAC,IAAI;YACrB,OAAO,EAAE,CAAC,OAAO,CAAC,WAAW,EAAE,OAAO,CAAC,KAAK,EAAE,OAAO,CAAC,IAAI,CAAC;SAC5D,CAAC;QACD,KAAK,EAAE;;;kDAGP;IASD;QAPC,WAAW,CAAC;YACX,WAAW,EAAE,cAAc;YAC3B,IAAI,EAAE,UAAU;YAChB,OAAO,EAAE,KAAK,CAAC,OAAO;YACtB,OAAO,EAAE,CAAC,KAAK,CAAC,OAAO,EAAE,KAAK,CAAC,KAAK,CAAC;SACtC,CAAC;QACD,KAAK,EAAE;;;gDAGP;IAGD;QADC,WAAW,CAAC,oBAAoB,CAAC;;;kDAGjC;IAQD;QANC,WAAW,CAAC;YACX,WAAW,EAAE,oBAAoB;YACjC,IAAI,EAAE,SAAS;YACf,OAAO,EAAE,OAAO;SACjB,CAAC;QACD,KAAK,EAAE;;qDACS;IASjB;QAPC,WAAW,CAAC;YACX,WAAW,EAAE,oBAAoB;YACjC,IAAI,EAAE,gBAAgB;YACtB,OAAO,EAAE,UAAU,CAAC,MAAM;YAC1B,OAAO,EAAE,CAAC,UAAU,CAAC,MAAM,EAAE,UAAU,CAAC,MAAM,CAAC;SAChD,CAAC;QACD,KAAK,EAAE;;;+CAGP;IAWD;QALC,WAAW,CAAC;YACX,WAAW,EAAE,gBAAgB;YAC7B,IAAI,EAAE,QAAQ;SACf,CAAC;QACD,KAAK,EAAE;;iDACK;IAOb;QALC,WAAW,CAAC;YACX,WAAW,EAAE,aAAa;YAC1B,IAAI,EAAE,cAAc;SACrB,CAAC;QACD,MAAM,EAAE;;kDACuB;IAGhC;QADC,eAAe,CAAC,cAAc,CAAC;kCACxB,SAAS;mDAAiB;IAxJvB,eAAe;QA9C3B,SAAS,CAAC;YACT,QAAQ,EAAE,YAAY;YACtB,4qDAAyC;YACzC,UAAU,EAAE;gBACV,OAAO,CAAC,QAAQ,EAAE;oBACd,KAAK,CACH,MAAM,EACN,KAAK,CAAC;wBACJ,OAAO,EAAE,CAAC;wBACV,KAAK,EAAE,OAAO;wBACd,MAAM,EAAE,OAAO;qBAChB,CAAC,CACH;oBACD,KAAK,CACH,GAAG,EACH,KAAK,CAAC;wBACJ,OAAO,EAAE,CAAC;wBACV,KAAK,EAAE,GAAG;wBACV,MAAM,EAAE,GAAG;qBACZ,CAAC,CACH;oBACD,UAAU,CACR,WAAW,EACX;wBACE,OAAO,CAAC,iBAAiB,CAAC;qBAC3B,CACF;iBACF,CACF;gBAED,OAAO,CAAC,YAAY,EAAE;oBACpB,KAAK,CAAC,MAAM,EAAE,KAAK,CAAC;wBAClB,UAAU,EAAE,SAAS;wBACrB,OAAO,EAAE,CAAC;qBACX,CAAC,CAAC;oBACH,KAAK,CAAC,MAAM,EAAE,KAAK,CAAC;wBAClB,UAAU,EAAE,UAAU;wBACtB,OAAO,EAAE,CAAC;qBACX,CAAC,CAAC;oBACH,UAAU,CAAC,eAAe,EAAE;wBAC1B,OAAO,CAAC,iBAAiB,CAAC;qBAC3B,CAAC;iBACH,CAAC;aACH;SACF,CAAC;OAEW,eAAe,CAyJ3B;IAAD,sBAAC;CAAA,AAzJD,IAyJC;SAzJY,eAAe","sourcesContent":["import { animate, state, style, transition, trigger } from '@angular/animations';\nimport { Component, ContentChildren, EventEmitter, HostBinding, Input, Output, QueryList } from '@angular/core';\nimport { Shape } from '../../core/enums/shape';\nimport { PropertyApi } from '../../core/decorators/api';\nimport { Outline } from '../../core/enums/outline';\nimport { Position } from '../../core/enums/position';\nimport { Scheme } from '../../core/enums/scheme';\nimport { Size } from '../../core/enums/size';\nimport { UI } from '../../core/enums/ui';\nimport { Width } from '../../core/enums/width';\nimport { BadgeComponent } from '../../elements/badge/badge.component';\nimport { ButtonType } from './button.enums';\n\ninterface Icon {\n  icon: string;\n  position: Position;\n}\n\n@Component({\n  selector: 'jnt-button',\n  templateUrl: './button.encapsulated.html',\n  animations: [\n    trigger('appear', [\n        state(\n          'void',\n          style({\n            opacity: 0,\n            width: '200px',\n            height: '200px'\n          })\n        ),\n        state(\n          '*',\n          style({\n            opacity: 1,\n            width: '*',\n            height: '*'\n          })\n        ),\n        transition(\n          'void => *',\n          [\n            animate('.5s ease-in-out')\n          ]\n        ),\n      ]\n    ),\n\n    trigger('visibility', [\n      state('show', style({\n        visibility: 'visible',\n        opacity: 1\n      })),\n      state('hide', style({\n        visibility: 'collapse',\n        opacity: 0\n      })),\n      transition('show <=> hide', [\n        animate('.5s ease-in-out')\n      ]),\n    ])\n  ]\n})\n\nexport class ButtonComponent {\n\n  @HostBinding('attr.host')\n  readonly host = 'jnt-button-host';\n\n  ui = UI;\n\n  private _type: ButtonType = ButtonType.button;\n  icon: Icon;\n\n  @HostBinding('attr.data-scheme')\n  _scheme: Scheme = Scheme.primary;\n\n  @HostBinding('attr.data-size')\n  _size: Size = Size.normal;\n\n  @HostBinding('attr.data-outline')\n  _outline: Outline = Outline.fill;\n\n  @HostBinding('attr.data-width')\n  _width: Width = Width.default;\n\n  @HostBinding('attr.data-shape')\n  _shape: Shape = Shape.square;\n\n  @PropertyApi({\n    description: 'Button shape',\n    path: 'ui.shape',\n    default: Shape.square,\n    options: [Shape.circle, Shape.square]\n  })\n  @Input()\n  set shape(shape: Shape) {\n    this._shape = shape || Shape.square;\n  }\n\n  @PropertyApi({\n    description: 'Set the loading status of button',\n    type: 'boolean',\n    default: 'false'\n  })\n  @HostBinding('attr.data-loading')\n  @Input()\n  loading = false;\n\n  @PropertyApi({\n    name: 'icon',\n    description: 'Icon for button',\n    type: 'string | {icon: string, position: Position}'\n  })\n  @Input('icon')\n  set _icon(icon: string | Icon) {\n    this.icon =  <Icon>(typeof icon === 'string'\n      ? {icon: icon, position: Position.left} : icon);\n  }\n\n  @PropertyApi({\n    description: 'Button color scheme',\n    path: 'ui.scheme',\n    options: [Scheme.primary, Scheme.secondary, Scheme.success, Scheme.fail],\n    default: Scheme.primary\n  })\n  @Input()\n  set scheme(scheme: Scheme) {\n    this._scheme = scheme || Scheme.primary;\n  }\n\n  @PropertyApi({\n    description: 'Button size',\n    path: 'ui.size',\n    options: [Size.tiny, Size.small, Size.normal, Size.large],\n    default: Size.normal\n  })\n  @Input()\n  set size(size: Size) {\n    this._size = size || Size.normal;\n  }\n\n  get size() {\n    return this._size;\n  }\n\n  @HostBinding('attr.data-with-text')\n  get withText() {\n    return !!this.text;\n  }\n\n  @PropertyApi({\n    description: 'Button outline',\n    path: 'ui.outline',\n    default: Outline.fill,\n    options: [Outline.transparent, Outline.ghost, Outline.fill]\n  })\n  @Input()\n  set outline(outline: Outline) {\n    this._outline = outline || Outline.fill;\n  }\n\n  @PropertyApi({\n    description: 'Button width',\n    path: 'ui.width',\n    default: Width.default,\n    options: [Width.default, Width.fluid]\n  })\n  @Input()\n  set width(width: Width) {\n    this._width = width || Width.default;\n  }\n\n  @HostBinding('attr.data-disabled')\n  get disable() {\n    return this.disabled || this.loading;\n  }\n\n  @PropertyApi({\n    description: 'Set disabled state',\n    type: 'boolean',\n    default: 'false',\n  })\n  @Input()\n  disabled = false;\n\n  @PropertyApi({\n    description: 'Button typeControl',\n    path: 'ui.button.type',\n    default: ButtonType.button,\n    options: [ButtonType.button, ButtonType.submit]\n  })\n  @Input()\n  set type(type: ButtonType) {\n    this._type = type || ButtonType.button;\n  }\n\n  get type() {\n    return this._type;\n  }\n\n  @PropertyApi({\n    description: 'Text on button',\n    type: 'string',\n  })\n  @Input()\n  text: string;\n\n  @PropertyApi({\n    description: 'Click event',\n    path: 'EventEmitter'\n  })\n  @Output()\n  click = new EventEmitter<any>();\n\n  @ContentChildren(BadgeComponent)\n  badges: QueryList<BadgeComponent>;\n}\n"]}