UNPKG

@junte/ui

Version:

Quality Angular UI components kit

249 lines 23.1 kB
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'; let ButtonComponent = class ButtonComponent { constructor() { 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(); } set shape(shape) { this._shape = shape || Shape.square; } set _icon(icon) { this.icon = (typeof icon === 'string' ? { icon: icon, position: Position.left } : icon); } set scheme(scheme) { this._scheme = scheme || Scheme.primary; } set size(size) { this._size = size || Size.normal; } get size() { return this._size; } get withText() { return !!this.text; } set outline(outline) { this._outline = outline || Outline.fill; } set width(width) { this._width = width || Width.default; } get disable() { return this.disabled || this.loading; } set type(type) { this._type = type || ButtonType.button; } get type() { return this._type; } }; __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); 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,eAAe,GAA5B,MAAa,eAAe;IAA5B;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,IAAI,KAAK,CAAC,KAAY;QACpB,IAAI,CAAC,MAAM,GAAG,KAAK,IAAI,KAAK,CAAC,MAAM,CAAC;IACtC,CAAC;IAiBD,IAAI,KAAK,CAAC,IAAmB;QAC3B,IAAI,CAAC,IAAI,GAAU,CAAC,OAAO,IAAI,KAAK,QAAQ;YAC1C,CAAC,CAAC,EAAC,IAAI,EAAE,IAAI,EAAE,QAAQ,EAAE,QAAQ,CAAC,IAAI,EAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC;IACpD,CAAC;IASD,IAAI,MAAM,CAAC,MAAc;QACvB,IAAI,CAAC,OAAO,GAAG,MAAM,IAAI,MAAM,CAAC,OAAO,CAAC;IAC1C,CAAC;IASD,IAAI,IAAI,CAAC,IAAU;QACjB,IAAI,CAAC,KAAK,GAAG,IAAI,IAAI,IAAI,CAAC,MAAM,CAAC;IACnC,CAAC;IAED,IAAI,IAAI;QACN,OAAO,IAAI,CAAC,KAAK,CAAC;IACpB,CAAC;IAGD,IAAI,QAAQ;QACV,OAAO,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC;IACrB,CAAC;IASD,IAAI,OAAO,CAAC,OAAgB;QAC1B,IAAI,CAAC,QAAQ,GAAG,OAAO,IAAI,OAAO,CAAC,IAAI,CAAC;IAC1C,CAAC;IASD,IAAI,KAAK,CAAC,KAAY;QACpB,IAAI,CAAC,MAAM,GAAG,KAAK,IAAI,KAAK,CAAC,OAAO,CAAC;IACvC,CAAC;IAGD,IAAI,OAAO;QACT,OAAO,IAAI,CAAC,QAAQ,IAAI,IAAI,CAAC,OAAO,CAAC;IACvC,CAAC;IAiBD,IAAI,IAAI,CAAC,IAAgB;QACvB,IAAI,CAAC,KAAK,GAAG,IAAI,IAAI,UAAU,CAAC,MAAM,CAAC;IACzC,CAAC;IAED,IAAI,IAAI;QACN,OAAO,IAAI,CAAC,KAAK,CAAC;IACpB,CAAC;CAkBF,CAAA;AAtJC;IADC,WAAW,CAAC,WAAW,CAAC;;6CACS;AAQlC;IADC,WAAW,CAAC,kBAAkB,CAAC;;gDACC;AAGjC;IADC,WAAW,CAAC,gBAAgB,CAAC;;8CACJ;AAG1B;IADC,WAAW,CAAC,mBAAmB,CAAC;;iDACA;AAGjC;IADC,WAAW,CAAC,iBAAiB,CAAC;;+CACD;AAG9B;IADC,WAAW,CAAC,iBAAiB,CAAC;;+CACF;AAS7B;IAPC,WAAW,CAAC;QACX,WAAW,EAAE,cAAc;QAC3B,IAAI,EAAE,UAAU;QAChB,OAAO,EAAE,KAAK,CAAC,MAAM;QACrB,OAAO,EAAE,CAAC,KAAK,CAAC,MAAM,EAAE,KAAK,CAAC,MAAM,CAAC;KACtC,CAAC;IACD,KAAK,EAAE;;;4CAGP;AASD;IAPC,WAAW,CAAC;QACX,WAAW,EAAE,kCAAkC;QAC/C,IAAI,EAAE,SAAS;QACf,OAAO,EAAE,OAAO;KACjB,CAAC;IACD,WAAW,CAAC,mBAAmB,CAAC;IAChC,KAAK,EAAE;;gDACQ;AAQhB;IANC,WAAW,CAAC;QACX,IAAI,EAAE,MAAM;QACZ,WAAW,EAAE,iBAAiB;QAC9B,IAAI,EAAE,6CAA6C;KACpD,CAAC;IACD,KAAK,CAAC,MAAM,CAAC;;;4CAIb;AASD;IAPC,WAAW,CAAC;QACX,WAAW,EAAE,qBAAqB;QAClC,IAAI,EAAE,WAAW;QACjB,OAAO,EAAE,CAAC,MAAM,CAAC,OAAO,EAAE,MAAM,CAAC,SAAS,EAAE,MAAM,CAAC,OAAO,EAAE,MAAM,CAAC,IAAI,CAAC;QACxE,OAAO,EAAE,MAAM,CAAC,OAAO;KACxB,CAAC;IACD,KAAK,EAAE;;;6CAGP;AASD;IAPC,WAAW,CAAC;QACX,WAAW,EAAE,aAAa;QAC1B,IAAI,EAAE,SAAS;QACf,OAAO,EAAE,CAAC,IAAI,CAAC,IAAI,EAAE,IAAI,CAAC,KAAK,EAAE,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,KAAK,CAAC;QACzD,OAAO,EAAE,IAAI,CAAC,MAAM;KACrB,CAAC;IACD,KAAK,EAAE;;;2CAGP;AAOD;IADC,WAAW,CAAC,qBAAqB,CAAC;;;+CAGlC;AASD;IAPC,WAAW,CAAC;QACX,WAAW,EAAE,gBAAgB;QAC7B,IAAI,EAAE,YAAY;QAClB,OAAO,EAAE,OAAO,CAAC,IAAI;QACrB,OAAO,EAAE,CAAC,OAAO,CAAC,WAAW,EAAE,OAAO,CAAC,KAAK,EAAE,OAAO,CAAC,IAAI,CAAC;KAC5D,CAAC;IACD,KAAK,EAAE;;;8CAGP;AASD;IAPC,WAAW,CAAC;QACX,WAAW,EAAE,cAAc;QAC3B,IAAI,EAAE,UAAU;QAChB,OAAO,EAAE,KAAK,CAAC,OAAO;QACtB,OAAO,EAAE,CAAC,KAAK,CAAC,OAAO,EAAE,KAAK,CAAC,KAAK,CAAC;KACtC,CAAC;IACD,KAAK,EAAE;;;4CAGP;AAGD;IADC,WAAW,CAAC,oBAAoB,CAAC;;;8CAGjC;AAQD;IANC,WAAW,CAAC;QACX,WAAW,EAAE,oBAAoB;QACjC,IAAI,EAAE,SAAS;QACf,OAAO,EAAE,OAAO;KACjB,CAAC;IACD,KAAK,EAAE;;iDACS;AASjB;IAPC,WAAW,CAAC;QACX,WAAW,EAAE,oBAAoB;QACjC,IAAI,EAAE,gBAAgB;QACtB,OAAO,EAAE,UAAU,CAAC,MAAM;QAC1B,OAAO,EAAE,CAAC,UAAU,CAAC,MAAM,EAAE,UAAU,CAAC,MAAM,CAAC;KAChD,CAAC;IACD,KAAK,EAAE;;;2CAGP;AAWD;IALC,WAAW,CAAC;QACX,WAAW,EAAE,gBAAgB;QAC7B,IAAI,EAAE,QAAQ;KACf,CAAC;IACD,KAAK,EAAE;;6CACK;AAOb;IALC,WAAW,CAAC;QACX,WAAW,EAAE,aAAa;QAC1B,IAAI,EAAE,cAAc;KACrB,CAAC;IACD,MAAM,EAAE;;8CACuB;AAGhC;IADC,eAAe,CAAC,cAAc,CAAC;8BACxB,SAAS;+CAAiB;AAxJvB,eAAe;IA9C3B,SAAS,CAAC;QACT,QAAQ,EAAE,YAAY;QACtB,4qDAAyC;QACzC,UAAU,EAAE;YACV,OAAO,CAAC,QAAQ,EAAE;gBACd,KAAK,CACH,MAAM,EACN,KAAK,CAAC;oBACJ,OAAO,EAAE,CAAC;oBACV,KAAK,EAAE,OAAO;oBACd,MAAM,EAAE,OAAO;iBAChB,CAAC,CACH;gBACD,KAAK,CACH,GAAG,EACH,KAAK,CAAC;oBACJ,OAAO,EAAE,CAAC;oBACV,KAAK,EAAE,GAAG;oBACV,MAAM,EAAE,GAAG;iBACZ,CAAC,CACH;gBACD,UAAU,CACR,WAAW,EACX;oBACE,OAAO,CAAC,iBAAiB,CAAC;iBAC3B,CACF;aACF,CACF;YAED,OAAO,CAAC,YAAY,EAAE;gBACpB,KAAK,CAAC,MAAM,EAAE,KAAK,CAAC;oBAClB,UAAU,EAAE,SAAS;oBACrB,OAAO,EAAE,CAAC;iBACX,CAAC,CAAC;gBACH,KAAK,CAAC,MAAM,EAAE,KAAK,CAAC;oBAClB,UAAU,EAAE,UAAU;oBACtB,OAAO,EAAE,CAAC;iBACX,CAAC,CAAC;gBACH,UAAU,CAAC,eAAe,EAAE;oBAC1B,OAAO,CAAC,iBAAiB,CAAC;iBAC3B,CAAC;aACH,CAAC;SACH;KACF,CAAC;GAEW,eAAe,CAyJ3B;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"]}