ng-zorro-antd-mobile
Version:
An enterprise-class mobile UI components based on Ant Design and Angular
495 lines • 46.6 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import { Input, Output, Component, forwardRef, ElementRef, TemplateRef, EventEmitter, HostListener, ViewEncapsulation } from '@angular/core';
import { ModalOptions } from './modal-options.provider';
import { NG_VALUE_ACCESSOR } from '@angular/forms';
import { ModalRef } from './modal-ref.class';
/**
* @template T, R
*/
export class ModalComponent extends ModalRef {
/**
* @param {?} option
* @param {?} elementRef
*/
constructor(option, elementRef) {
super();
this.option = option;
this.elementRef = elementRef;
this.autoFocus = { focus: true, date: new Date() };
this.transitionName = '';
this.maskTransitionName = '';
this.wrapCls = {};
this.cls = {};
this.btnGroupClass = {};
this.data = {
text: '',
password: ''
};
this.onClose = new EventEmitter();
this.afterOpenEmitter = new EventEmitter();
this.afterCloseEmitter = new EventEmitter();
}
/**
* @param {?} value
* @return {?}
*/
set title(value) {
this.option.title = value;
}
/**
* @param {?} value
* @return {?}
*/
set closable(value) {
this.option.closable = value;
}
/**
* @param {?} value
* @return {?}
*/
set maskClosable(value) {
this.option.maskClosable = value;
}
/**
* @param {?} value
* @return {?}
*/
set popup(value) {
this.option.popup = value;
this.setClassMap();
}
/**
* @param {?} value
* @return {?}
*/
set animationType(value) {
this.option.animationType = value;
this.setClassMap();
}
/**
* @param {?} value
* @return {?}
*/
set transparent(value) {
this.option.transparent = value;
this.setClassMap();
}
/**
* @param {?} value
* @return {?}
*/
set footer(value) {
this.option.footer = value;
}
/**
* @param {?} value
* @return {?}
*/
set platform(value) {
this.option.platform = value;
this.setClassMap();
}
/**
* @param {?} value
* @return {?}
*/
set className(value) {
this.option.className = value;
this.setClassMap();
}
/**
* @param {?} value
* @return {?}
*/
set wrapClassName(value) {
this.option.wrapClassName = value;
this.setClassMap();
}
/**
* @param {?} value
* @return {?}
*/
set actions(value) {
this.option.footer = value;
this.setClassMap();
}
/**
* @param {?} value
* @return {?}
*/
set defaultValue(value) {
this.option.defaultValue = value !== undefined ? value : ['', ''];
}
/**
* @param {?} value
* @return {?}
*/
set type(value) {
this.option.type = value;
}
/**
* @param {?} value
* @return {?}
*/
set placeholders(value) {
this.option.placeholders = value;
}
/**
* @param {?} value
* @return {?}
*/
set operation(value) {
this.option.operation = value;
this.setClassMap();
}
/**
* @param {?} event
* @return {?}
*/
panend(event) {
if (this.option.closable || this.option.maskClosable || this.option.popup) {
if ((event && event.target && event.target.getAttribute('role') === 'dialog') ||
event.target.getAttribute('role') === 'close') {
event.preventDefault();
event.stopPropagation();
if (this.option.close) {
this.option.close();
}
else {
this.onClose.emit();
this.leaveAnimation();
}
}
}
}
/**
* @param {?} value
* @return {?}
*/
isTemplateRef(value) {
return value instanceof TemplateRef;
}
/**
* @param {?} value
* @return {?}
*/
isNoTitle(value) {
return value === '' || value === null || value === undefined;
}
/**
* @param {?} visible
* @return {?}
*/
setTransitionName(visible) {
if (!visible) {
this.leaveAnimation();
}
else {
if (this.option.animated) {
if (this.option.transparent) {
if (this.setActiveName(this.option.transitionName)) {
this.transitionName = this.setActiveName(this.option.transitionName);
this.maskTransitionName = this.setActiveName(this.option.maskTransitionName);
}
else {
this.transitionName = this.maskTransitionName = this.setActiveName('am-fade');
}
}
else {
if (this.setActiveName(this.option.transitionName)) {
this.transitionName = this.setActiveName(this.option.transitionName);
this.maskTransitionName = this.setActiveName(this.option.maskTransitionName);
}
else {
this.transitionName = this.maskTransitionName = this.setActiveName('am-slide-up');
}
}
if (this.option.popup) {
this.transitionName =
this.option.animationType === 'slide-up'
? this.setActiveName('am-slide-up')
: this.setActiveName('am-slide-down');
this.maskTransitionName = this.setActiveName('am-fade');
}
}
this.setClassMap();
}
}
/**
* @param {?} name
* @return {?}
*/
setActiveName(name) {
return name.length > 0 ? `${name}-enter ${name}-enter-active` : null;
}
/**
* @param {?} name
* @return {?}
*/
setLeaveActiveName(name) {
return name.length > 0 ? `${name}-leave ${name}-leave-active` : null;
}
/**
* @return {?}
*/
setClassMap() {
this.wrapCls = {
[this.option.wrapClassName]: true,
[`${this.option.prefixCls}-wrap-popup`]: this.option.popup
};
this.cls = {
[this.option.className]: true,
[`${this.option.prefixCls}-transparent`]: this.option.transparent,
[`${this.option.prefixCls}-popup`]: this.option.popup,
[`${this.option.prefixCls}-popup-${this.option.animationType}`]: this.option.popup && this.option.animationType,
[`${this.option.prefixCls}-android`]: this.option.platform === 'android'
};
this.btnGroupClass = {
[`${this.option.prefixCls}-button-group-${this.option.footer.length === 2 && !this.option.operation ? 'h' : 'v'}`]: true,
[`${this.option.prefixCls}-button-group-${this.option.operation ? 'operation' : 'normal'}`]: true
};
}
/**
* @param {?} type
* @param {?} value
* @return {?}
*/
inputChange(type, value) {
this.data[type] = value;
}
/**
* @return {?}
*/
leaveAnimation() {
if (this.option.animated) {
if (this.option.transparent) {
if (this.setLeaveActiveName(this.option.transitionName)) {
this.transitionName = this.setLeaveActiveName(this.option.transitionName);
this.maskTransitionName = this.setLeaveActiveName(this.option.maskTransitionName);
}
else {
this.transitionName = this.maskTransitionName = this.setLeaveActiveName('am-fade');
}
}
else {
if (this.setLeaveActiveName(this.option.transitionName)) {
this.transitionName = this.setLeaveActiveName(this.option.transitionName);
this.maskTransitionName = this.setLeaveActiveName(this.option.maskTransitionName);
}
else {
this.transitionName = this.maskTransitionName = this.setLeaveActiveName('am-slide-up');
}
}
if (this.option.popup) {
this.transitionName =
this.option.animationType === 'slide-up'
? this.setLeaveActiveName('am-slide-up')
: this.setLeaveActiveName('am-slide-down');
this.maskTransitionName = this.setLeaveActiveName('am-fade');
}
}
setTimeout((/**
* @return {?}
*/
() => {
this.option.visible = false;
if (this.onChanged) {
this.onChanged(this.option.visible);
}
}), 200);
}
/**
* @param {?} value
* @return {?}
*/
writeValue(value) {
if (value) {
this.option.visible = value;
}
this.setTransitionName(value);
}
/**
* @param {?} fn
* @return {?}
*/
registerOnChange(fn) {
this.onChanged = fn;
}
/**
* @param {?} fn
* @return {?}
*/
registerOnTouched(fn) {
this.onTouched = fn;
}
/**
* @return {?}
*/
get afterOpen() {
return this.afterOpenEmitter.asObservable();
}
/**
* @return {?}
*/
get afterClose() {
return this.afterCloseEmitter.asObservable();
}
/**
* @return {?}
*/
getInstance() {
return this;
}
/**
* @return {?}
*/
getElement() {
return this.elementRef && this.elementRef.nativeElement;
}
/**
* @return {?}
*/
close() {
if (this.option.closeWithAnimation) {
this.option.closeWithAnimation();
}
else {
this.onClose.emit();
this.leaveAnimation();
}
}
/**
* @return {?}
*/
triggerOk() {
if (this.option.footer.length > 1) {
/** @type {?} */
const button = this.option.footer[1];
button.onPress();
}
}
/**
* @return {?}
*/
triggerCancel() {
if (this.option.footer.length > 0) {
/** @type {?} */
const button = this.option.footer[0];
button.onPress();
}
}
/**
* @return {?}
*/
destroy() {
this.close();
}
}
ModalComponent.decorators = [
{ type: Component, args: [{
selector: 'Modal',
template: "<div *ngIf=\"option.visible\">\n <div class=\"{{ option.prefixCls }}-mask {{ maskTransitionName }}\"></div>\n <div role=\"dialog\" class=\"{{ option.prefixCls }}-wrap {{ transitionName }}\" [ngClass]=\"wrapCls\">\n <div role=\"document\" class=\"{{ option.prefixCls }}\" [ngClass]=\"cls\">\n <div class=\"{{ option.prefixCls }}-content\">\n <div *ngIf=\"option.closable\" style=\"width: 100%; height: 21px;\">\n <div role=\"close\" class=\"{{ option.prefixCls }}-close\">\n <span role=\"close\" class=\"{{ option.prefixCls }}-close-x\"></span>\n </div>\n </div>\n <div *ngIf=\"!isNoTitle(option.title)\" class=\"{{ option.prefixCls }}-header\">\n <div *ngIf=\"!isTemplateRef(option.title)\" class=\"{{ option.prefixCls }}-title\">{{ option.title }}</div>\n <ng-template *ngIf=\"isTemplateRef(option.title)\" [ngTemplateOutlet]=\"option.title\"></ng-template>\n </div>\n <div class=\"{{ option.prefixCls }}-body\">\n <ng-content></ng-content>\n <div *ngIf=\"!isTemplateRef(option.message)\" class=\"{{ option.prefixCls }}-alert-content\">\n {{ option.message }}\n </div>\n <ng-template *ngIf=\"isTemplateRef(option.message)\" [ngTemplateOutlet]=\"option.message\"></ng-template>\n <ng-template *ngIf=\"option.type === 'default'\" [ngTemplateOutlet]=\"promptDefault\"></ng-template>\n <ng-template *ngIf=\"option.type === 'secure-text'\" [ngTemplateOutlet]=\"promptSecure\"></ng-template>\n <ng-template *ngIf=\"option.type === 'login-password'\" [ngTemplateOutlet]=\"promptPassword\"></ng-template>\n </div>\n <div class=\"{{ option.prefixCls }}-footer\">\n <div [ngClass]=\"btnGroupClass\" role=\"group\">\n <div\n Button\n role=\"button\"\n *ngFor=\"let button of option.footer\"\n [className]=\"'am-modal-button'\"\n [ngStyle]=\"button.style\"\n (onClick)=\"button.onPress()\"\n >\n {{ button.text }}\n </div>\n </div>\n </div>\n </div>\n </div>\n </div>\n</div>\n\n<ng-template #promptPassword>\n <div class=\"{{ option.prefixCls }}-input-container\">\n <div class=\"{{ option.prefixCls }}-input\">\n <input\n #inputElement\n autofocus\n [type]=\"'text'\"\n [placeholder]=\"option.placeholders[0] || ''\"\n [(ngModel)]=\"option.defaultValue[0]\"\n (ngModelChange)=\"inputChange('text', $event)\"\n />\n </div>\n <div className=\"{{ option.prefixCls }}-input\">\n <input\n #inputElement\n [type]=\"'password'\"\n [placeholder]=\"option.placeholders[1] || ''\"\n [(ngModel)]=\"option.defaultValue[1]\"\n (ngModelChange)=\"inputChange('password', $event)\"\n />\n </div>\n </div>\n</ng-template>\n<ng-template #promptSecure>\n <div className=\"{{ option.prefixCls }}-input-container\">\n <div className=\"{{ option.prefixCls }}-input\">\n <input\n #inputElement\n autofocus\n [type]=\"'password'\"\n [placeholder]=\"option.placeholders[0] || ''\"\n [(ngModel)]=\"option.defaultValue[0]\"\n (ngModelChange)=\"inputChange('password', $event)\"\n />\n </div>\n </div>\n</ng-template>\n<ng-template #promptDefault>\n <div className=\"{{ option.prefixCls }}-input-container\">\n <div className=\"{{ option.prefixCls }}-input\">\n <input\n #inputElement\n autofocus\n [type]=\"'text'\"\n [placeholder]=\"option.placeholders[0] || ''\"\n [(ngModel)]=\"option.defaultValue[0]\"\n (ngModelChange)=\"inputChange('text', $event)\"\n />\n </div>\n </div>\n</ng-template>\n",
encapsulation: ViewEncapsulation.None,
providers: [
ModalOptions,
{
provide: NG_VALUE_ACCESSOR,
useExisting: forwardRef((/**
* @return {?}
*/
() => ModalComponent)),
multi: true
}
]
}] }
];
/** @nocollapse */
ModalComponent.ctorParameters = () => [
{ type: ModalOptions },
{ type: ElementRef }
];
ModalComponent.propDecorators = {
title: [{ type: Input }],
closable: [{ type: Input }],
maskClosable: [{ type: Input }],
popup: [{ type: Input }],
animationType: [{ type: Input }],
transparent: [{ type: Input }],
footer: [{ type: Input }],
platform: [{ type: Input }],
className: [{ type: Input }],
wrapClassName: [{ type: Input }],
actions: [{ type: Input }],
defaultValue: [{ type: Input }],
type: [{ type: Input }],
placeholders: [{ type: Input }],
operation: [{ type: Input }],
onClose: [{ type: Output }],
afterOpenEmitter: [{ type: Output }],
afterCloseEmitter: [{ type: Output }],
panend: [{ type: HostListener, args: ['mouseup', ['$event'],] }, { type: HostListener, args: ['touchend', ['$event'],] }]
};
if (false) {
/** @type {?} */
ModalComponent.prototype.autoFocus;
/** @type {?} */
ModalComponent.prototype.transitionName;
/** @type {?} */
ModalComponent.prototype.maskTransitionName;
/** @type {?} */
ModalComponent.prototype.wrapCls;
/** @type {?} */
ModalComponent.prototype.cls;
/** @type {?} */
ModalComponent.prototype.btnGroupClass;
/** @type {?} */
ModalComponent.prototype.data;
/** @type {?} */
ModalComponent.prototype.onChanged;
/** @type {?} */
ModalComponent.prototype.onTouched;
/** @type {?} */
ModalComponent.prototype.onClose;
/** @type {?} */
ModalComponent.prototype.afterOpenEmitter;
/** @type {?} */
ModalComponent.prototype.afterCloseEmitter;
/** @type {?} */
ModalComponent.prototype.option;
/** @type {?} */
ModalComponent.prototype.elementRef;
}
export class ModalServiceComponent extends ModalComponent {
/**
* @param {?} option
* @param {?} elementRef
*/
constructor(option, elementRef) {
super(option, elementRef);
this.option = option;
this.elementRef = elementRef;
this.setTransitionName(this.option.visible);
}
}
ModalServiceComponent.decorators = [
{ type: Component, args: [{
selector: 'ModalService',
template: "<div *ngIf=\"option.visible\">\n <div class=\"{{ option.prefixCls }}-mask {{ maskTransitionName }}\"></div>\n <div role=\"dialog\" class=\"{{ option.prefixCls }}-wrap {{ transitionName }}\" [ngClass]=\"wrapCls\">\n <div role=\"document\" class=\"{{ option.prefixCls }}\" [ngClass]=\"cls\">\n <div class=\"{{ option.prefixCls }}-content\">\n <div *ngIf=\"option.closable\" style=\"width: 100%; height: 21px;\">\n <div role=\"close\" class=\"{{ option.prefixCls }}-close\">\n <span role=\"close\" class=\"{{ option.prefixCls }}-close-x\"></span>\n </div>\n </div>\n <div *ngIf=\"!isNoTitle(option.title)\" class=\"{{ option.prefixCls }}-header\">\n <div *ngIf=\"!isTemplateRef(option.title)\" class=\"{{ option.prefixCls }}-title\">{{ option.title }}</div>\n <ng-template *ngIf=\"isTemplateRef(option.title)\" [ngTemplateOutlet]=\"option.title\"></ng-template>\n </div>\n <div class=\"{{ option.prefixCls }}-body\">\n <ng-content></ng-content>\n <div *ngIf=\"!isTemplateRef(option.message)\" class=\"{{ option.prefixCls }}-alert-content\">\n {{ option.message }}\n </div>\n <ng-template *ngIf=\"isTemplateRef(option.message)\" [ngTemplateOutlet]=\"option.message\"></ng-template>\n <ng-template *ngIf=\"option.type === 'default'\" [ngTemplateOutlet]=\"promptDefault\"></ng-template>\n <ng-template *ngIf=\"option.type === 'secure-text'\" [ngTemplateOutlet]=\"promptSecure\"></ng-template>\n <ng-template *ngIf=\"option.type === 'login-password'\" [ngTemplateOutlet]=\"promptPassword\"></ng-template>\n </div>\n <div class=\"{{ option.prefixCls }}-footer\">\n <div [ngClass]=\"btnGroupClass\" role=\"group\">\n <div\n Button\n role=\"button\"\n *ngFor=\"let button of option.footer\"\n [className]=\"'am-modal-button'\"\n [ngStyle]=\"button.style\"\n (onClick)=\"button.onPress()\"\n >\n {{ button.text }}\n </div>\n </div>\n </div>\n </div>\n </div>\n </div>\n</div>\n\n<ng-template #promptPassword>\n <div class=\"{{ option.prefixCls }}-input-container\">\n <div class=\"{{ option.prefixCls }}-input\">\n <input\n #inputElement\n autofocus\n [type]=\"'text'\"\n [placeholder]=\"option.placeholders[0] || ''\"\n [(ngModel)]=\"option.defaultValue[0]\"\n (ngModelChange)=\"inputChange('text', $event)\"\n />\n </div>\n <div className=\"{{ option.prefixCls }}-input\">\n <input\n #inputElement\n [type]=\"'password'\"\n [placeholder]=\"option.placeholders[1] || ''\"\n [(ngModel)]=\"option.defaultValue[1]\"\n (ngModelChange)=\"inputChange('password', $event)\"\n />\n </div>\n </div>\n</ng-template>\n<ng-template #promptSecure>\n <div className=\"{{ option.prefixCls }}-input-container\">\n <div className=\"{{ option.prefixCls }}-input\">\n <input\n #inputElement\n autofocus\n [type]=\"'password'\"\n [placeholder]=\"option.placeholders[0] || ''\"\n [(ngModel)]=\"option.defaultValue[0]\"\n (ngModelChange)=\"inputChange('password', $event)\"\n />\n </div>\n </div>\n</ng-template>\n<ng-template #promptDefault>\n <div className=\"{{ option.prefixCls }}-input-container\">\n <div className=\"{{ option.prefixCls }}-input\">\n <input\n #inputElement\n autofocus\n [type]=\"'text'\"\n [placeholder]=\"option.placeholders[0] || ''\"\n [(ngModel)]=\"option.defaultValue[0]\"\n (ngModelChange)=\"inputChange('text', $event)\"\n />\n </div>\n </div>\n</ng-template>\n",
encapsulation: ViewEncapsulation.None
}] }
];
/** @nocollapse */
ModalServiceComponent.ctorParameters = () => [
{ type: ModalOptions },
{ type: ElementRef }
];
if (false) {
/** @type {?} */
ModalServiceComponent.prototype.option;
/** @type {?} */
ModalServiceComponent.prototype.elementRef;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"modal.component.js","sourceRoot":"ng://ng-zorro-antd-mobile/","sources":["modal/modal.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Input,\n  Output,\n  Component,\n  forwardRef,\n  ElementRef,\n  TemplateRef,\n  EventEmitter,\n  HostListener,\n  ViewEncapsulation\n} from '@angular/core';\nimport { ModalOptions } from './modal-options.provider';\nimport { Observable } from 'rxjs';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { ModalRef } from './modal-ref.class';\n@Component({\n  selector: 'Modal',\n  templateUrl: './modal.component.html',\n  encapsulation: ViewEncapsulation.None,\n  providers: [\n    ModalOptions,\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => ModalComponent),\n      multi: true\n    }\n  ]\n})\nexport class ModalComponent<T = any, R = any> extends ModalRef<T, R> implements ControlValueAccessor {\n  autoFocus = { focus: true, date: new Date() };\n  transitionName: string = '';\n  maskTransitionName: string = '';\n  wrapCls: object = {};\n  cls: object = {};\n  btnGroupClass: object = {};\n  data = {\n    text: '',\n    password: ''\n  };\n\n  onChanged: (visiable: boolean) => {};\n  onTouched: () => {};\n\n  @Input()\n  set title(value: string | TemplateRef<any>) {\n    this.option.title = value;\n  }\n\n  @Input()\n  set closable(value: boolean) {\n    this.option.closable = value;\n  }\n  @Input()\n  set maskClosable(value: boolean) {\n    this.option.maskClosable = value;\n  }\n  @Input()\n  set popup(value: boolean) {\n    this.option.popup = value;\n    this.setClassMap();\n  }\n  @Input()\n  set animationType(value: string) {\n    this.option.animationType = value;\n    this.setClassMap();\n  }\n  @Input()\n  set transparent(value: boolean) {\n    this.option.transparent = value;\n    this.setClassMap();\n  }\n  @Input()\n  set footer(value: Array<any>) {\n    this.option.footer = value;\n  }\n  @Input()\n  set platform(value: string) {\n    this.option.platform = value;\n    this.setClassMap();\n  }\n  @Input()\n  set className(value: string) {\n    this.option.className = value;\n    this.setClassMap();\n  }\n  @Input()\n  set wrapClassName(value: string) {\n    this.option.wrapClassName = value;\n    this.setClassMap();\n  }\n  @Input()\n  set actions(value: Array<any>) {\n    this.option.footer = value;\n    this.setClassMap();\n  }\n  @Input()\n  set defaultValue(value: Array<string>) {\n    this.option.defaultValue = value !== undefined ? value : ['', ''];\n  }\n  @Input()\n  set type(value: string) {\n    this.option.type = value;\n  }\n  @Input()\n  set placeholders(value: Array<string>) {\n    this.option.placeholders = value;\n  }\n  @Input()\n  set operation(value: boolean) {\n    this.option.operation = value;\n    this.setClassMap();\n  }\n  @Output()\n  onClose: EventEmitter<any> = new EventEmitter();\n  @Output()\n  afterOpenEmitter: EventEmitter<any> = new EventEmitter<void>();\n  @Output()\n  afterCloseEmitter: EventEmitter<any> = new EventEmitter<void>();\n\n  @HostListener('mouseup', ['$event'])\n  @HostListener('touchend', ['$event'])\n  panend(event) {\n    if (this.option.closable || this.option.maskClosable || this.option.popup) {\n      if (\n        (event && event.target && event.target.getAttribute('role') === 'dialog') ||\n        event.target.getAttribute('role') === 'close'\n      ) {\n        event.preventDefault();\n        event.stopPropagation();\n        if (this.option.close) {\n          this.option.close();\n        } else {\n          this.onClose.emit();\n          this.leaveAnimation();\n        }\n      }\n    }\n  }\n\n  constructor(public option: ModalOptions, public elementRef: ElementRef) {\n    super();\n  }\n\n  isTemplateRef(value: string | TemplateRef<any>) {\n    return value instanceof TemplateRef;\n  }\n\n  isNoTitle(value: string | TemplateRef<any>) {\n    return value === '' || value === null || value === undefined;\n  }\n\n  setTransitionName(visible: boolean) {\n    if (!visible) {\n      this.leaveAnimation();\n    } else {\n      if (this.option.animated) {\n        if (this.option.transparent) {\n          if (this.setActiveName(this.option.transitionName)) {\n            this.transitionName = this.setActiveName(this.option.transitionName);\n            this.maskTransitionName = this.setActiveName(this.option.maskTransitionName);\n          } else {\n            this.transitionName = this.maskTransitionName = this.setActiveName('am-fade');\n          }\n        } else {\n          if (this.setActiveName(this.option.transitionName)) {\n            this.transitionName = this.setActiveName(this.option.transitionName);\n            this.maskTransitionName = this.setActiveName(this.option.maskTransitionName);\n          } else {\n            this.transitionName = this.maskTransitionName = this.setActiveName('am-slide-up');\n          }\n        }\n        if (this.option.popup) {\n          this.transitionName =\n            this.option.animationType === 'slide-up'\n              ? this.setActiveName('am-slide-up')\n              : this.setActiveName('am-slide-down');\n          this.maskTransitionName = this.setActiveName('am-fade');\n        }\n      }\n      this.setClassMap();\n    }\n  }\n\n  setActiveName(name: string) {\n    return name.length > 0 ? `${name}-enter ${name}-enter-active` : null;\n  }\n\n  setLeaveActiveName(name: string) {\n    return name.length > 0 ? `${name}-leave ${name}-leave-active` : null;\n  }\n\n  setClassMap() {\n    this.wrapCls = {\n      [this.option.wrapClassName]: true,\n      [`${this.option.prefixCls}-wrap-popup`]: this.option.popup\n    };\n\n    this.cls = {\n      [this.option.className]: true,\n      [`${this.option.prefixCls}-transparent`]: this.option.transparent,\n      [`${this.option.prefixCls}-popup`]: this.option.popup,\n      [`${this.option.prefixCls}-popup-${this.option.animationType}`]: this.option.popup && this.option.animationType,\n      [`${this.option.prefixCls}-android`]: this.option.platform === 'android'\n    };\n\n    this.btnGroupClass = {\n      [`${this.option.prefixCls}-button-group-${\n        this.option.footer.length === 2 && !this.option.operation ? 'h' : 'v'\n      }`]: true,\n      [`${this.option.prefixCls}-button-group-${this.option.operation ? 'operation' : 'normal'}`]: true\n    };\n  }\n\n  inputChange(type: string, value: string) {\n    this.data[type] = value;\n  }\n\n  leaveAnimation() {\n    if (this.option.animated) {\n      if (this.option.transparent) {\n        if (this.setLeaveActiveName(this.option.transitionName)) {\n          this.transitionName = this.setLeaveActiveName(this.option.transitionName);\n          this.maskTransitionName = this.setLeaveActiveName(this.option.maskTransitionName);\n        } else {\n          this.transitionName = this.maskTransitionName = this.setLeaveActiveName('am-fade');\n        }\n      } else {\n        if (this.setLeaveActiveName(this.option.transitionName)) {\n          this.transitionName = this.setLeaveActiveName(this.option.transitionName);\n          this.maskTransitionName = this.setLeaveActiveName(this.option.maskTransitionName);\n        } else {\n          this.transitionName = this.maskTransitionName = this.setLeaveActiveName('am-slide-up');\n        }\n      }\n      if (this.option.popup) {\n        this.transitionName =\n          this.option.animationType === 'slide-up'\n            ? this.setLeaveActiveName('am-slide-up')\n            : this.setLeaveActiveName('am-slide-down');\n        this.maskTransitionName = this.setLeaveActiveName('am-fade');\n      }\n    }\n    setTimeout(() => {\n      this.option.visible = false;\n      if (this.onChanged) {\n        this.onChanged(this.option.visible);\n      }\n    }, 200);\n  }\n\n  writeValue(value: boolean): void {\n    if (value) {\n      this.option.visible = value;\n    }\n    this.setTransitionName(value);\n  }\n\n  registerOnChange(fn: (_: boolean) => {}): void {\n    this.onChanged = fn;\n  }\n\n  registerOnTouched(fn: () => {}): void {\n    this.onTouched = fn;\n  }\n\n  get afterOpen(): Observable<void> {\n    return this.afterOpenEmitter.asObservable();\n  }\n\n  get afterClose(): Observable<R> {\n    return this.afterCloseEmitter.asObservable();\n  }\n\n  getInstance(): ModalComponent {\n    return this;\n  }\n\n  getElement(): HTMLElement {\n    return this.elementRef && this.elementRef.nativeElement;\n  }\n\n  close(): void {\n    if (this.option.closeWithAnimation) {\n      this.option.closeWithAnimation();\n    } else {\n      this.onClose.emit();\n      this.leaveAnimation();\n    }\n  }\n\n  triggerOk(): void {\n    if (this.option.footer.length > 1) {\n      const button = this.option.footer[1];\n      button.onPress();\n    }\n  }\n\n  triggerCancel(): void {\n    if (this.option.footer.length > 0) {\n      const button = this.option.footer[0];\n      button.onPress();\n    }\n  }\n\n  destroy(): void {\n    this.close();\n  }\n}\n\n@Component({\n  selector: 'ModalService',\n  templateUrl: './modal.component.html',\n  encapsulation: ViewEncapsulation.None\n})\nexport class ModalServiceComponent extends ModalComponent {\n  constructor(public option: ModalOptions, public elementRef: ElementRef) {\n    super(option, elementRef);\n    this.setTransitionName(this.option.visible);\n  }\n}\n"]}