@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>
192 lines • 14.4 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
// tslint:disable: no-input-rename no-output-rename
import { Input, Directive, HostListener, EventEmitter, Output } from '@angular/core';
import { SheetService } from './sheet.service';
/** @type {?} */
var PRIMARY_ACTION_TAG = 'primaryAction';
/** @type {?} */
var SECONDARY_ACTION_TAG = 'secondaryAction';
/**
* Sheets are overlays that prevent users from interacting with the rest of the application until a specific action is taken. They can be disruptive because they require users to take an action before they can continue interacting with the rest of the application.
* It should be used thoughtfully and sparingly.
*/
var SheetDirective = /** @class */ (function () {
function SheetDirective(sheetService) {
this.sheetService = sheetService;
/**
* Set to `true` to show a close button on the top right corner. Defaults to `false`.
*/
this.closeButton = false;
/**
* Sets to `false` to stop the sheet from closing when the user clicks on the backdrop. Defaults to `true`.
*/
this.closeOnBackdropClick = true;
/**
* Callback when the sheet closes.
*/
this.close = new EventEmitter();
/**
* Callback when the secondary action is triggered.
*/
this.secondaryAction = new EventEmitter();
/**
* Callback when the primary action is triggered.
*/
this.primaryAction = new EventEmitter();
}
/**
* @return {?}
*/
SheetDirective.prototype.onClick = /**
* @return {?}
*/
function () {
this.openSheet();
};
/**
* Opens the sheet.
*/
/**
* Opens the sheet.
* @private
* @return {?}
*/
SheetDirective.prototype.openSheet = /**
* Opens the sheet.
* @private
* @return {?}
*/
function () {
var _this = this;
/** @type {?} */
var sheetConfig = {
closeOnBackdropClick: this.closeOnBackdropClick,
content: {
closeButton: this.closeButton,
title: this.title,
body: this.body,
}
};
if (this.primaryActionLabel || this.secondaryActionLabel) {
sheetConfig.content.actions = [];
if (this.primaryActionLabel) {
sheetConfig.content.actions.push({
label: this.primaryActionLabel,
type: 'primary',
tag: PRIMARY_ACTION_TAG
});
}
if (this.secondaryActionLabel) {
sheetConfig.content.actions.push({
label: this.secondaryActionLabel,
type: 'secondary',
tag: SECONDARY_ACTION_TAG
});
}
}
/** @type {?} */
var sheetRef = this.sheetService.open(sheetConfig);
sheetRef.afterClosed().subscribe((/**
* @param {?} result
* @return {?}
*/
function (result) {
switch (result) {
case PRIMARY_ACTION_TAG:
if (_this.primaryAction.observers.length > 0) {
_this.primaryAction.emit(result);
}
break;
case SECONDARY_ACTION_TAG:
if (_this.secondaryAction.observers.length > 0) {
_this.secondaryAction.emit(result);
}
break;
default:
if (_this.close.observers.length > 0) {
_this.close.emit();
}
break;
}
}));
};
SheetDirective.decorators = [
{ type: Directive, args: [{
selector: '[sukaSheet]'
},] }
];
/** @nocollapse */
SheetDirective.ctorParameters = function () { return [
{ type: SheetService }
]; };
SheetDirective.propDecorators = {
closeButton: [{ type: Input, args: ['sheetCloseButton',] }],
title: [{ type: Input, args: ['sheetTitle',] }],
body: [{ type: Input, args: ['sheetBody',] }],
closeOnBackdropClick: [{ type: Input, args: ['sheetCloseOnBackdropClick',] }],
close: [{ type: Output, args: ['sheetClose',] }],
secondaryActionLabel: [{ type: Input, args: ['sheetSecondaryActionLabel',] }],
secondaryAction: [{ type: Output, args: ['sheetSecondaryAction',] }],
primaryActionLabel: [{ type: Input, args: ['sheetPrimaryActionLabel',] }],
primaryAction: [{ type: Output, args: ['sheetPrimaryAction',] }],
onClick: [{ type: HostListener, args: ['click',] }]
};
return SheetDirective;
}());
export { SheetDirective };
if (false) {
/**
* Set to `true` to show a close button on the top right corner. Defaults to `false`.
* @type {?}
*/
SheetDirective.prototype.closeButton;
/**
* Sets the sheet title.
* @type {?}
*/
SheetDirective.prototype.title;
/**
* Sets the body of the sheet.
* @type {?}
*/
SheetDirective.prototype.body;
/**
* Sets to `false` to stop the sheet from closing when the user clicks on the backdrop. Defaults to `true`.
* @type {?}
*/
SheetDirective.prototype.closeOnBackdropClick;
/**
* Callback when the sheet closes.
* @type {?}
*/
SheetDirective.prototype.close;
/**
* Sets the sheet secondary action button label.
* @type {?}
*/
SheetDirective.prototype.secondaryActionLabel;
/**
* Callback when the secondary action is triggered.
* @type {?}
*/
SheetDirective.prototype.secondaryAction;
/**
* Sets the sheet primary action button label.
* @type {?}
*/
SheetDirective.prototype.primaryActionLabel;
/**
* Callback when the primary action is triggered.
* @type {?}
*/
SheetDirective.prototype.primaryAction;
/**
* @type {?}
* @protected
*/
SheetDirective.prototype.sheetService;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"sheet.directive.js","sourceRoot":"ng://@kushki/ng-suka/","sources":["lib/sheet/sheet.directive.ts"],"names":[],"mappings":"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","sourcesContent":["// tslint:disable: no-input-rename no-output-rename\n\nimport { Input, TemplateRef, Directive, HostListener, EventEmitter, Output, OnDestroy } from '@angular/core';\nimport { SheetService, SheetConfig } from './sheet.service';\nimport { Subscription } from 'rxjs';\n\nconst PRIMARY_ACTION_TAG = 'primaryAction';\nconst SECONDARY_ACTION_TAG = 'secondaryAction';\n\n/**\n * Sheets are overlays that prevent users from interacting with the rest of the application until a specific action is taken. They can be disruptive because they require users to take an action before they can continue interacting with the rest of the application.\n * It should be used thoughtfully and sparingly.\n */\n@Directive({\n  selector: '[sukaSheet]'\n})\nexport class SheetDirective {\n  constructor(protected sheetService: SheetService) { }\n\n  /**\n   * Set to `true` to show a close button on the top right corner. Defaults to `false`.\n   */\n  @Input('sheetCloseButton') closeButton = false;\n  /**\n   * Sets the sheet title.\n   */\n  @Input('sheetTitle') title: string | TemplateRef<any>;\n  /**\n   * Sets the body of the sheet.\n   */\n  @Input('sheetBody') body: string | TemplateRef<any>;\n  /**\n   * Sets to `false` to stop the sheet from closing when the user clicks on the backdrop. Defaults to `true`.\n   */\n  @Input('sheetCloseOnBackdropClick') closeOnBackdropClick = true;\n\n  /**\n   * Callback when the sheet closes.\n   */\n  @Output('sheetClose') close = new EventEmitter();\n\n  /**\n   * Sets the sheet secondary action button label.\n   */\n  @Input('sheetSecondaryActionLabel') secondaryActionLabel: string;\n  /**\n   * Callback when the secondary action is triggered.\n   */\n  @Output('sheetSecondaryAction') secondaryAction = new EventEmitter();\n\n  /**\n   * Sets the sheet primary action button label.\n   */\n  @Input('sheetPrimaryActionLabel') primaryActionLabel: string;\n  /**\n   * Callback when the primary action is triggered.\n   */\n  @Output('sheetPrimaryAction') primaryAction = new EventEmitter();\n\n  @HostListener('click')\n  onClick() {\n    this.openSheet();\n  }\n\n  /**\n   * Opens the sheet.\n   */\n  private openSheet() {\n    const sheetConfig: SheetConfig = {\n      closeOnBackdropClick: this.closeOnBackdropClick,\n      content: {\n        closeButton: this.closeButton,\n        title: this.title,\n        body: this.body,\n      }\n    };\n\n    if (this.primaryActionLabel || this.secondaryActionLabel) {\n      sheetConfig.content.actions = [];\n\n      if (this.primaryActionLabel) {\n        sheetConfig.content.actions.push({\n          label: this.primaryActionLabel,\n          type: 'primary',\n          tag: PRIMARY_ACTION_TAG\n        });\n      }\n\n      if (this.secondaryActionLabel) {\n        sheetConfig.content.actions.push({\n          label: this.secondaryActionLabel,\n          type: 'secondary',\n          tag: SECONDARY_ACTION_TAG\n        });\n      }\n    }\n\n    const sheetRef = this.sheetService.open(sheetConfig);\n\n    sheetRef.afterClosed().subscribe((result: any) => {\n      switch (result) {\n        case PRIMARY_ACTION_TAG:\n          if (this.primaryAction.observers.length > 0) {\n            this.primaryAction.emit(result);\n          }\n          break;\n        case SECONDARY_ACTION_TAG:\n          if (this.secondaryAction.observers.length > 0) {\n            this.secondaryAction.emit(result);\n          }\n          break;\n        default:\n          if (this.close.observers.length > 0) {\n            this.close.emit();\n          }\n          break;\n      }\n    });\n  }\n}\n"]}