UNPKG

@junte/ui

Version:

Quality Angular UI components kit

286 lines 25.3 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'; 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":"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","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"]}