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>

191 lines 14.8 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ import { Component, Inject, TemplateRef, HostListener, EventEmitter, HostBinding } from '@angular/core'; import { ModalRef } from './modal-ref'; import { MODAL_CONTENT_DATA } from './modal.tokens'; import { trigger, state, style, transition, animate } from '@angular/animations'; /** @type {?} */ const ESCAPE_KEY = 27; /** @type {?} */ const MODAL_ANIMATION_TIMINGS = '200ms cubic-bezier(0.64, 0, 0.35, 1)'; export class ModalContainer { /** * @param {?} dialogRef * @param {?} content */ constructor(dialogRef, content) { this.dialogRef = dialogRef; this.content = content; this.animationState = 'enter'; this.animationStateChanged = new EventEmitter(); this.showFooter = false; this.baseClass = true; } /** * @return {?} */ ngOnInit() { if (this.content.actions && this.content.actions.length > 0) { this.showFooter = true; this.primaryActions = this.content.actions.filter((/** * @param {?} action * @return {?} */ (action) => action.type === 'primary')); this.secondaryActions = this.content.actions.filter((/** * @param {?} action * @return {?} */ (action) => action.type === 'secondary')); } } /** * @param {?} value * @return {?} */ isTemplate(value) { return value instanceof TemplateRef; } /** * @param {?=} event * @return {?} */ onClose(event) { this.dialogRef.close('cancel'); } /** * @param {?} tag * @return {?} */ onAction(tag) { this.dialogRef.close(tag); } /** * @param {?} event * @return {?} */ handleKeydown(event) { // tslint:disable-next-line: deprecation if (event.keyCode === ESCAPE_KEY) { this.dialogRef.close('cancel'); } } /** * @param {?} event * @return {?} */ onAnimationStart(event) { this.animationStateChanged.emit(event); } /** * @param {?} event * @return {?} */ onAnimationDone(event) { this.animationStateChanged.emit(event); } /** * @return {?} */ startExitAnimation() { this.animationState = 'leave'; } /** * @param {?} $event * @return {?} */ closeModal($event) { this.dialogRef.close($event); } } ModalContainer.decorators = [ { type: Component, args: [{ selector: 'suka-modal', template: ` <div class="modal" [@slideContent]="animationState" (@slideContent.start)="onAnimationStart($event)" (@slideContent.done)="onAnimationDone($event)" cdkTrapFocus > <div class="modal__header"> <h5> <ng-container *ngIf="!isTemplate(content.title)">{{content.title}}</ng-container> <ng-template *ngIf="isTemplate(content.title)" [ngTemplateOutlet]="content.title"></ng-template> </h5> <button *ngIf="content.closeButton" sukaButton="plain" (click)="onClose($event)" > <suka-icon icon="x"></suka-icon> </button> </div> <div class="modal__content"> <ng-container *ngIf="!isTemplate(content.body)">{{content.body}}</ng-container> <ng-container *ngIf="isTemplate(content.body)"> <ng-container *ngTemplateOutlet="content.body; context: {closeModal: closeModal.bind(this)}" ></ng-container> </ng-container> </div> <div class="modal__footer" *ngIf="showFooter"> <suka-button-group> <button *ngFor="let secondaryAction of secondaryActions" sukaButton="plain" (click)="onAction(secondaryAction.tag)" > {{secondaryAction.label}} </button> <button *ngFor="let primaryAction of primaryActions" sukaButton="primary" (click)="onAction(primaryAction.tag)" > {{primaryAction.label}} </button> </suka-button-group> </div> </div> `, animations: [ trigger('slideContent', [ state('void', style({ transform: 'translate3d(0, 20rem, 0)', opacity: 0 })), state('enter', style({ transform: 'none', opacity: 1 })), state('leave', style({ transform: 'translate3d(0, 20rem, 0)', opacity: 0 })), transition('* => *', animate(MODAL_ANIMATION_TIMINGS)), ]) ] }] } ]; /** @nocollapse */ ModalContainer.ctorParameters = () => [ { type: ModalRef }, { type: undefined, decorators: [{ type: Inject, args: [MODAL_CONTENT_DATA,] }] } ]; ModalContainer.propDecorators = { baseClass: [{ type: HostBinding, args: ['class.modal--default',] }], handleKeydown: [{ type: HostListener, args: ['document:keydown', ['$event'],] }] }; if (false) { /** @type {?} */ ModalContainer.prototype.animationState; /** @type {?} */ ModalContainer.prototype.animationStateChanged; /** @type {?} */ ModalContainer.prototype.showFooter; /** @type {?} */ ModalContainer.prototype.primaryActions; /** @type {?} */ ModalContainer.prototype.secondaryActions; /** @type {?} */ ModalContainer.prototype.baseClass; /** @type {?} */ ModalContainer.prototype.dialogRef; /** @type {?} */ ModalContainer.prototype.content; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"modal-container.component.js","sourceRoot":"ng://@kushki/ng-suka/","sources":["lib/modal/modal-container.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, Inject, TemplateRef, HostListener, EventEmitter, OnInit, HostBinding } from '@angular/core';\n\nimport { ModalRef } from './modal-ref';\nimport { MODAL_CONTENT_DATA } from './modal.tokens';\nimport { AnimationEvent, trigger, state, style, transition, animate } from '@angular/animations';\n\nconst ESCAPE_KEY = 27;\nconst MODAL_ANIMATION_TIMINGS = '200ms cubic-bezier(0.64, 0, 0.35, 1)';\n\n@Component({\n  selector: 'suka-modal',\n  template: `\n    <div class=\"modal\"\n      [@slideContent]=\"animationState\"\n      (@slideContent.start)=\"onAnimationStart($event)\"\n      (@slideContent.done)=\"onAnimationDone($event)\"\n      cdkTrapFocus\n    >\n      <div class=\"modal__header\">\n        <h5>\n          <ng-container *ngIf=\"!isTemplate(content.title)\">{{content.title}}</ng-container>\n          <ng-template *ngIf=\"isTemplate(content.title)\" [ngTemplateOutlet]=\"content.title\"></ng-template>\n        </h5>\n        <button\n          *ngIf=\"content.closeButton\"\n          sukaButton=\"plain\"\n          (click)=\"onClose($event)\"\n        >\n          <suka-icon icon=\"x\"></suka-icon>\n        </button>\n      </div>\n      <div class=\"modal__content\">\n        <ng-container *ngIf=\"!isTemplate(content.body)\">{{content.body}}</ng-container>\n        <ng-container *ngIf=\"isTemplate(content.body)\">\n          <ng-container\n            *ngTemplateOutlet=\"content.body; context: {closeModal: closeModal.bind(this)}\"\n          ></ng-container>\n        </ng-container>\n      </div>\n      <div class=\"modal__footer\" *ngIf=\"showFooter\">\n        <suka-button-group>\n          <button\n            *ngFor=\"let secondaryAction of secondaryActions\"\n            sukaButton=\"plain\"\n            (click)=\"onAction(secondaryAction.tag)\"\n          >\n            {{secondaryAction.label}}\n          </button>\n          <button\n            *ngFor=\"let primaryAction of primaryActions\"\n            sukaButton=\"primary\"\n            (click)=\"onAction(primaryAction.tag)\"\n          >\n            {{primaryAction.label}}\n          </button>\n        </suka-button-group>\n      </div>\n    </div>\n  `,\n  animations: [\n    trigger('slideContent', [\n      state('void', style({ transform: 'translate3d(0, 20rem, 0)', opacity: 0 })),\n      state('enter', style({ transform: 'none', opacity: 1 })),\n      state('leave', style({ transform: 'translate3d(0, 20rem, 0)', opacity: 0 })),\n      transition('* => *', animate(MODAL_ANIMATION_TIMINGS)),\n    ])\n  ]\n})\nexport class ModalContainer implements OnInit {\n  public animationState: 'void' | 'enter' | 'leave' = 'enter';\n  public animationStateChanged = new EventEmitter<AnimationEvent>();\n  showFooter = false;\n  primaryActions: [];\n  secondaryActions: [];\n\n  @HostBinding('class.modal--default') baseClass = true;\n\n  constructor(\n    public dialogRef: ModalRef,\n    @Inject(MODAL_CONTENT_DATA) public content: any\n  ) { }\n\n  public ngOnInit() {\n    if (this.content.actions && this.content.actions.length > 0) {\n      this.showFooter = true;\n      this.primaryActions = this.content.actions.filter((action) => action.type === 'primary');\n      this.secondaryActions = this.content.actions.filter((action) => action.type === 'secondary');\n    }\n  }\n\n  public isTemplate(value) {\n    return value instanceof TemplateRef;\n  }\n\n  public onClose(event?: any) {\n    this.dialogRef.close('cancel');\n  }\n\n  public onAction(tag: string) {\n    this.dialogRef.close(tag);\n  }\n\n  @HostListener('document:keydown', ['$event']) public handleKeydown(event: KeyboardEvent) {\n    // tslint:disable-next-line: deprecation\n    if (event.keyCode === ESCAPE_KEY) {\n      this.dialogRef.close('cancel');\n    }\n  }\n\n  onAnimationStart(event: AnimationEvent) {\n    this.animationStateChanged.emit(event);\n  }\n\n  onAnimationDone(event: AnimationEvent) {\n    this.animationStateChanged.emit(event);\n  }\n\n  startExitAnimation() {\n    this.animationState = 'leave';\n  }\n\n  closeModal($event: any) {\n    this.dialogRef.close($event);\n  }\n}\n"]}