@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>
176 lines • 15.7 kB
JavaScript
/**
* @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 { SheetRef } from './sheet-ref';
import { SHEET_CONTENT_DATA } from './sheet.tokens';
import { trigger, state, style, transition, animate } from '@angular/animations';
/** @type {?} */
var ESCAPE_KEY = 27;
/** @type {?} */
var SHEET_ANIMATION_TIMINGS = '200ms cubic-bezier(0.64, 0, 0.35, 1)';
var SheetContainer = /** @class */ (function () {
function SheetContainer(dialogRef, content) {
this.dialogRef = dialogRef;
this.content = content;
this.animationState = 'enter';
this.animationStateChanged = new EventEmitter();
this.showFooter = false;
this.baseClass = true;
}
/**
* @return {?}
*/
SheetContainer.prototype.ngOnInit = /**
* @return {?}
*/
function () {
if (this.content.actions && this.content.actions.length > 0) {
this.showFooter = true;
this.primaryActions = this.content.actions.filter((/**
* @param {?} action
* @return {?}
*/
function (action) { return action.type === 'primary'; }));
this.secondaryActions = this.content.actions.filter((/**
* @param {?} action
* @return {?}
*/
function (action) { return action.type === 'secondary'; }));
}
};
/**
* @param {?} value
* @return {?}
*/
SheetContainer.prototype.isTemplate = /**
* @param {?} value
* @return {?}
*/
function (value) {
return value instanceof TemplateRef;
};
/**
* @param {?=} event
* @return {?}
*/
SheetContainer.prototype.onClose = /**
* @param {?=} event
* @return {?}
*/
function (event) {
this.dialogRef.close('cancel');
};
/**
* @param {?} tag
* @return {?}
*/
SheetContainer.prototype.onAction = /**
* @param {?} tag
* @return {?}
*/
function (tag) {
this.dialogRef.close(tag);
};
/**
* @param {?} event
* @return {?}
*/
SheetContainer.prototype.handleKeydown = /**
* @param {?} event
* @return {?}
*/
function (event) {
// tslint:disable-next-line: deprecation
if (event.keyCode === ESCAPE_KEY) {
this.dialogRef.close('cancel');
}
};
/**
* @param {?} event
* @return {?}
*/
SheetContainer.prototype.onAnimationStart = /**
* @param {?} event
* @return {?}
*/
function (event) {
this.animationStateChanged.emit(event);
};
/**
* @param {?} event
* @return {?}
*/
SheetContainer.prototype.onAnimationDone = /**
* @param {?} event
* @return {?}
*/
function (event) {
this.animationStateChanged.emit(event);
};
/**
* @return {?}
*/
SheetContainer.prototype.startExitAnimation = /**
* @return {?}
*/
function () {
this.animationState = 'leave';
};
/**
* @param {?} $event
* @return {?}
*/
SheetContainer.prototype.closeSheet = /**
* @param {?} $event
* @return {?}
*/
function ($event) {
this.dialogRef.close($event);
};
SheetContainer.decorators = [
{ type: Component, args: [{
selector: 'suka-sheet',
template: "\n <div class=\"sheet\"\n [@slideContent]=\"animationState\"\n (@slideContent.start)=\"onAnimationStart($event)\"\n (@slideContent.done)=\"onAnimationDone($event)\"\n cdkTrapFocus\n >\n <div class=\"sheet__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 sukaButton=\"plain\"\n (click)=\"onClose($event)\"\n >\n <suka-icon icon=\"x\"></suka-icon>\n </button>\n </div>\n <div class=\"sheet__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: {closeSheet: closeSheet.bind(this)}\"\n ></ng-container>\n </ng-container>\n </div>\n <div class=\"sheet__footer\" *ngIf=\"showFooter\">\n <button\n *ngFor=\"let secondaryAction of secondaryActions\"\n sukaButton=\"plain\"\n (click)=\"onAction(secondaryAction.tag)\"\n >\n {{secondaryAction.label}}\n </button>\n\n <button\n *ngFor=\"let primaryAction of primaryActions\"\n sukaButton=\"primary\"\n (click)=\"onAction(primaryAction.tag)\"\n >\n {{primaryAction.label}}\n </button>\n </div>\n </div>\n ",
animations: [
trigger('slideContent', [
state('void', style({ transform: 'translate3d(20rem, 0, 0)', opacity: 0 })),
state('enter', style({ transform: 'none', opacity: 1 })),
state('leave', style({ transform: 'translate3d(20rem, 0, 0)', opacity: 0 })),
transition('* => *', animate(SHEET_ANIMATION_TIMINGS)),
])
]
}] }
];
/** @nocollapse */
SheetContainer.ctorParameters = function () { return [
{ type: SheetRef },
{ type: undefined, decorators: [{ type: Inject, args: [SHEET_CONTENT_DATA,] }] }
]; };
SheetContainer.propDecorators = {
baseClass: [{ type: HostBinding, args: ['class.sheet--default',] }],
handleKeydown: [{ type: HostListener, args: ['document:keydown', ['$event'],] }]
};
return SheetContainer;
}());
export { SheetContainer };
if (false) {
/** @type {?} */
SheetContainer.prototype.animationState;
/** @type {?} */
SheetContainer.prototype.animationStateChanged;
/** @type {?} */
SheetContainer.prototype.showFooter;
/** @type {?} */
SheetContainer.prototype.primaryActions;
/** @type {?} */
SheetContainer.prototype.secondaryActions;
/** @type {?} */
SheetContainer.prototype.baseClass;
/** @type {?} */
SheetContainer.prototype.dialogRef;
/** @type {?} */
SheetContainer.prototype.content;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"sheet-container.component.js","sourceRoot":"ng://@kushki/ng-suka/","sources":["lib/sheet/sheet-container.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, Inject, TemplateRef, HostListener, EventEmitter, OnInit, HostBinding } from '@angular/core';\n\nimport { SheetRef } from './sheet-ref';\nimport { SHEET_CONTENT_DATA } from './sheet.tokens';\nimport { AnimationEvent, trigger, state, style, transition, animate } from '@angular/animations';\n\nconst ESCAPE_KEY = 27;\nconst SHEET_ANIMATION_TIMINGS = '200ms cubic-bezier(0.64, 0, 0.35, 1)';\n\n@Component({\n  selector: 'suka-sheet',\n  template: `\n    <div class=\"sheet\"\n      [@slideContent]=\"animationState\"\n      (@slideContent.start)=\"onAnimationStart($event)\"\n      (@slideContent.done)=\"onAnimationDone($event)\"\n      cdkTrapFocus\n    >\n      <div class=\"sheet__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          sukaButton=\"plain\"\n          (click)=\"onClose($event)\"\n        >\n          <suka-icon icon=\"x\"></suka-icon>\n        </button>\n      </div>\n      <div class=\"sheet__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: {closeSheet: closeSheet.bind(this)}\"\n          ></ng-container>\n        </ng-container>\n      </div>\n      <div class=\"sheet__footer\" *ngIf=\"showFooter\">\n        <button\n          *ngFor=\"let secondaryAction of secondaryActions\"\n          sukaButton=\"plain\"\n          (click)=\"onAction(secondaryAction.tag)\"\n        >\n          {{secondaryAction.label}}\n        </button>\n\n        <button\n          *ngFor=\"let primaryAction of primaryActions\"\n          sukaButton=\"primary\"\n          (click)=\"onAction(primaryAction.tag)\"\n        >\n          {{primaryAction.label}}\n        </button>\n      </div>\n    </div>\n  `,\n  animations: [\n    trigger('slideContent', [\n      state('void', style({ transform: 'translate3d(20rem, 0, 0)', opacity: 0 })),\n      state('enter', style({ transform: 'none', opacity: 1 })),\n      state('leave', style({ transform: 'translate3d(20rem, 0, 0)', opacity: 0 })),\n      transition('* => *', animate(SHEET_ANIMATION_TIMINGS)),\n    ])\n  ]\n})\nexport class SheetContainer 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.sheet--default') baseClass = true;\n\n  constructor(\n    public dialogRef: SheetRef,\n    @Inject(SHEET_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  closeSheet($event: any) {\n    this.dialogRef.close($event);\n  }\n}\n"]}