@junte/ui
Version:
Quality Angular UI components kit
249 lines • 23.1 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';
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":"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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"]}