UNPKG

@kushki/ng-suka

Version:

<p align="center"> <h1 align="center">Suka Components Angular</h1> <p align="center"> An Angular implementation of the Suka Design System </p> </p>

293 lines 19.3 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ import { Directive, HostBinding, Input, ChangeDetectorRef, ElementRef, Renderer2, ViewContainerRef, ComponentFactoryResolver } from '@angular/core'; import { Loading } from '../loading/loading.module'; /** * Buttons are used primarily for actions, such as “Add”, “Close”, “Cancel”, or “Save”. * Plain buttons, which look similar to links, are used for less important or less commonly used actions, such as “view shipping settings”. * * For navigational actions that appear within or directly following a sentence, use the link component. */ var Button = /** @class */ (function () { function Button(ref, el, renderer, viewContainerRef, componentFactoryResolver) { this.ref = ref; this.el = el; this.renderer = renderer; this.viewContainerRef = viewContainerRef; this.componentFactoryResolver = componentFactoryResolver; /** * Sets the button type. Can be `primary`, `basic`, `plain`, `destructive` or `outline_white`. */ this.sukaButton = 'basic'; /** * Button size. Can be `md` (Medium), `sm` (Small) or `lg` (Large). */ this.size = 'md'; /** * Set to `true` for a skeleton state button. */ this.skeleton = false; /** * Set to `true` to display the outline version of the button. */ this.outline = false; /** * Set to `true` for a hover effect. */ this.hover = false; /** * Set to `true` for a button that uses the full horizontal width; */ this.fullWidth = false; /** * Sets to `true` when the button is on a button group. */ this.inGroup = false; /** * Set to `true` for a loading button. */ this.loading = false; } Object.defineProperty(Button.prototype, "basic", { get: /** * @return {?} */ function () { return this.getType('basic'); }, enumerable: true, configurable: true }); Object.defineProperty(Button.prototype, "primary", { get: /** * @return {?} */ function () { return this.getType('primary'); }, enumerable: true, configurable: true }); Object.defineProperty(Button.prototype, "plain", { get: /** * @return {?} */ function () { return this.getType('plain'); }, enumerable: true, configurable: true }); Object.defineProperty(Button.prototype, "destructive", { get: /** * @return {?} */ function () { return this.getType('destructive'); }, enumerable: true, configurable: true }); Object.defineProperty(Button.prototype, "outline_white", { get: /** * @return {?} */ function () { return this.getType('outline_white'); }, enumerable: true, configurable: true }); Object.defineProperty(Button.prototype, "buttonSmall", { get: /** * @return {?} */ function () { return this.size === 'sm'; }, enumerable: true, configurable: true }); Object.defineProperty(Button.prototype, "buttonLarge", { get: /** * @return {?} */ function () { return this.size === 'lg'; }, enumerable: true, configurable: true }); /** * @private * @param {?} type * @return {?} */ Button.prototype.getType = /** * @private * @param {?} type * @return {?} */ function (type) { return this.sukaButton === type; }; /** * @return {?} */ Button.prototype.ngOnInit = /** * @return {?} */ function () { if (!this.sukaButton) { this.sukaButton = 'basic'; } // Create the spinner /** @type {?} */ var factory = this.componentFactoryResolver.resolveComponentFactory(Loading); /** @type {?} */ var componentRef = this.viewContainerRef.createComponent(factory); this.loadingSpinner = componentRef.instance; this.loadingSpinner.size = 'sm'; this.renderer.setStyle(this.loadingSpinner.elementRef.nativeElement, 'display', 'none'); this.renderer.appendChild(this.el.nativeElement, this.loadingSpinner.elementRef.nativeElement); if (this.loading) { this.renderer.setStyle(this.loadingSpinner.elementRef.nativeElement, 'display', 'inherit'); this.el.nativeElement.disabled = true; } }; /** * @param {?} changes * @return {?} */ Button.prototype.ngOnChanges = /** * @param {?} changes * @return {?} */ function (changes) { if (changes.loading && this.loadingSpinner) { if (this.loading) { this.renderer.setStyle(this.loadingSpinner.elementRef.nativeElement, 'display', 'inherit'); } else { this.renderer.setStyle(this.loadingSpinner.elementRef.nativeElement, 'display', 'none'); } this.el.nativeElement.disabled = changes.loading.currentValue; } }; /** * @return {?} */ Button.prototype.ngAfterViewInit = /** * @return {?} */ function () { this.ref.detectChanges(); }; Button.decorators = [ { type: Directive, args: [{ selector: '[sukaButton]' },] } ]; /** @nocollapse */ Button.ctorParameters = function () { return [ { type: ChangeDetectorRef }, { type: ElementRef }, { type: Renderer2 }, { type: ViewContainerRef }, { type: ComponentFactoryResolver } ]; }; Button.propDecorators = { sukaButton: [{ type: Input }], size: [{ type: Input }], basic: [{ type: HostBinding, args: ['class.btn--basic',] }], primary: [{ type: HostBinding, args: ['class.btn--primary',] }], plain: [{ type: HostBinding, args: ['class.btn--plain',] }], destructive: [{ type: HostBinding, args: ['class.btn--destructive',] }], outline_white: [{ type: HostBinding, args: ['class.btn--outline_white',] }], skeleton: [{ type: HostBinding, args: ['class.skeleton',] }, { type: Input }], outline: [{ type: HostBinding, args: ['class.btn--outline',] }, { type: Input }], hover: [{ type: HostBinding, args: ['class.btn--hover',] }, { type: Input }], fullWidth: [{ type: HostBinding, args: ['class.btn--full_width',] }, { type: Input }], inGroup: [{ type: HostBinding, args: ['class.btn--group_item',] }, { type: Input }], loading: [{ type: HostBinding, args: ['class.btn--loading',] }, { type: Input }], buttonSmall: [{ type: HostBinding, args: ['class.btn--sm',] }], buttonLarge: [{ type: HostBinding, args: ['class.btn--lg',] }] }; return Button; }()); export { Button }; if (false) { /** * Sets the button type. Can be `primary`, `basic`, `plain`, `destructive` or `outline_white`. * @type {?} */ Button.prototype.sukaButton; /** * Button size. Can be `md` (Medium), `sm` (Small) or `lg` (Large). * @type {?} */ Button.prototype.size; /** * Set to `true` for a skeleton state button. * @type {?} */ Button.prototype.skeleton; /** * Set to `true` to display the outline version of the button. * @type {?} */ Button.prototype.outline; /** * Set to `true` for a hover effect. * @type {?} */ Button.prototype.hover; /** * Set to `true` for a button that uses the full horizontal width; * @type {?} */ Button.prototype.fullWidth; /** * Sets to `true` when the button is on a button group. * @type {?} */ Button.prototype.inGroup; /** * Set to `true` for a loading button. * @type {?} */ Button.prototype.loading; /** * @ignore * @type {?} */ Button.prototype.loadingSpinner; /** * @type {?} * @private */ Button.prototype.ref; /** * @type {?} * @private */ Button.prototype.el; /** * @type {?} * @private */ Button.prototype.renderer; /** * @type {?} * @private */ Button.prototype.viewContainerRef; /** * @type {?} * @private */ Button.prototype.componentFactoryResolver; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"button.directive.js","sourceRoot":"ng://@kushki/ng-suka/","sources":["lib/button/button.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Directive,\n  HostBinding,\n  Input,\n  OnInit,\n  OnChanges,\n  AfterViewInit,\n  ChangeDetectorRef,\n  ElementRef,\n  Renderer2,\n  ViewContainerRef,\n  ComponentFactoryResolver,\n  SimpleChanges\n} from '@angular/core';\nimport { Loading } from '../loading/loading.module';\nimport { ButtonType } from './button-types';\n\n\n/**\n * Buttons are used primarily for actions, such as “Add”, “Close”, “Cancel”, or “Save”.\n * Plain buttons, which look similar to links, are used for less important or less commonly used actions, such as “view shipping settings”.\n *\n * For navigational actions that appear within or directly following a sentence, use the link component.\n */\n@Directive({\n  selector: '[sukaButton]'\n})\nexport class Button implements OnInit, AfterViewInit, OnChanges {\n  /**\n   * Sets the button type. Can be `primary`, `basic`, `plain`, `destructive` or `outline_white`.\n   */\n  @Input() sukaButton: ButtonType = 'basic';\n\n  /**\n   * Button size. Can be `md` (Medium), `sm` (Small) or `lg` (Large).\n   */\n  @Input() size?: 'md' | 'sm' | 'lg' = 'md';\n\n  @HostBinding('class.btn--basic') get basic() {\n    return this.getType('basic');\n  }\n  @HostBinding('class.btn--primary') get primary() {\n    return this.getType('primary');\n  }\n  @HostBinding('class.btn--plain') get plain() {\n    return this.getType('plain');\n  }\n  @HostBinding('class.btn--destructive') get destructive() {\n    return this.getType('destructive');\n  }\n  @HostBinding('class.btn--outline_white') get outline_white() {\n    return this.getType('outline_white');\n  }\n\n  /**\n   * Set to `true` for a skeleton state button.\n   */\n  @HostBinding('class.skeleton') @Input() skeleton ? = false;\n  /**\n   * Set to `true` to display the outline version of the button.\n   */\n  @HostBinding('class.btn--outline') @Input() outline ? = false;\n  /**\n   * Set to `true` for a hover effect.\n   */\n  @HostBinding('class.btn--hover') @Input() hover ? = false;\n  /**\n   * Set to `true` for a button that uses the full horizontal width;\n   */\n  @HostBinding('class.btn--full_width') @Input() fullWidth ? = false;\n  /**\n   * Sets to `true` when the button is on a button group.\n   */\n  @HostBinding('class.btn--group_item') @Input() inGroup ? = false;\n  /**\n   * Set to `true` for a loading button.\n   */\n  @HostBinding('class.btn--loading') @Input() loading ? = false;\n\n  @HostBinding('class.btn--sm') get buttonSmall() {\n    return this.size === 'sm';\n  }\n  @HostBinding('class.btn--lg') get buttonLarge() {\n    return this.size === 'lg';\n  }\n\n  /**\n   * @ignore\n   */\n  loadingSpinner: Loading;\n\n  constructor(\n    private ref: ChangeDetectorRef,\n    private el: ElementRef,\n    private renderer: Renderer2,\n    private viewContainerRef: ViewContainerRef,\n    private componentFactoryResolver: ComponentFactoryResolver\n  ) {}\n\n  private getType(type: ButtonType): boolean {\n    return this.sukaButton === type;\n  }\n\n  public ngOnInit() {\n    if (!this.sukaButton) {\n      this.sukaButton = 'basic';\n    }\n\n    // Create the spinner\n    const factory = this.componentFactoryResolver.resolveComponentFactory(Loading);\n    const componentRef = this.viewContainerRef.createComponent(factory);\n    this.loadingSpinner = componentRef.instance;\n\n    this.loadingSpinner.size = 'sm';\n\n    this.renderer.setStyle(this.loadingSpinner.elementRef.nativeElement, 'display', 'none');\n\n    this.renderer.appendChild(this.el.nativeElement, this.loadingSpinner.elementRef.nativeElement);\n\n    if (this.loading) {\n      this.renderer.setStyle(this.loadingSpinner.elementRef.nativeElement, 'display', 'inherit');\n      this.el.nativeElement.disabled = true;\n    }\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    if (changes.loading && this.loadingSpinner) {\n      if (this.loading) {\n        this.renderer.setStyle(this.loadingSpinner.elementRef.nativeElement, 'display', 'inherit');\n      } else {\n        this.renderer.setStyle(this.loadingSpinner.elementRef.nativeElement, 'display', 'none');\n      }\n\n      this.el.nativeElement.disabled = changes.loading.currentValue;\n    }\n  }\n\n  ngAfterViewInit() {\n    this.ref.detectChanges();\n  }\n}\n"]}