ng-zorro-antd-mobile
Version:
An enterprise-class mobile UI components based on Ant Design and Angular
631 lines • 52.1 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import * as tslib_1 from "tslib";
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
*/
var ModalComponent = /** @class */ (function (_super) {
tslib_1.__extends(ModalComponent, _super);
function ModalComponent(option, elementRef) {
var _this = _super.call(this) || this;
_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();
return _this;
}
Object.defineProperty(ModalComponent.prototype, "title", {
set: /**
* @param {?} value
* @return {?}
*/
function (value) {
this.option.title = value;
},
enumerable: true,
configurable: true
});
Object.defineProperty(ModalComponent.prototype, "closable", {
set: /**
* @param {?} value
* @return {?}
*/
function (value) {
this.option.closable = value;
},
enumerable: true,
configurable: true
});
Object.defineProperty(ModalComponent.prototype, "maskClosable", {
set: /**
* @param {?} value
* @return {?}
*/
function (value) {
this.option.maskClosable = value;
},
enumerable: true,
configurable: true
});
Object.defineProperty(ModalComponent.prototype, "popup", {
set: /**
* @param {?} value
* @return {?}
*/
function (value) {
this.option.popup = value;
this.setClassMap();
},
enumerable: true,
configurable: true
});
Object.defineProperty(ModalComponent.prototype, "animationType", {
set: /**
* @param {?} value
* @return {?}
*/
function (value) {
this.option.animationType = value;
this.setClassMap();
},
enumerable: true,
configurable: true
});
Object.defineProperty(ModalComponent.prototype, "transparent", {
set: /**
* @param {?} value
* @return {?}
*/
function (value) {
this.option.transparent = value;
this.setClassMap();
},
enumerable: true,
configurable: true
});
Object.defineProperty(ModalComponent.prototype, "footer", {
set: /**
* @param {?} value
* @return {?}
*/
function (value) {
this.option.footer = value;
},
enumerable: true,
configurable: true
});
Object.defineProperty(ModalComponent.prototype, "platform", {
set: /**
* @param {?} value
* @return {?}
*/
function (value) {
this.option.platform = value;
this.setClassMap();
},
enumerable: true,
configurable: true
});
Object.defineProperty(ModalComponent.prototype, "className", {
set: /**
* @param {?} value
* @return {?}
*/
function (value) {
this.option.className = value;
this.setClassMap();
},
enumerable: true,
configurable: true
});
Object.defineProperty(ModalComponent.prototype, "wrapClassName", {
set: /**
* @param {?} value
* @return {?}
*/
function (value) {
this.option.wrapClassName = value;
this.setClassMap();
},
enumerable: true,
configurable: true
});
Object.defineProperty(ModalComponent.prototype, "actions", {
set: /**
* @param {?} value
* @return {?}
*/
function (value) {
this.option.footer = value;
this.setClassMap();
},
enumerable: true,
configurable: true
});
Object.defineProperty(ModalComponent.prototype, "defaultValue", {
set: /**
* @param {?} value
* @return {?}
*/
function (value) {
this.option.defaultValue = value !== undefined ? value : ['', ''];
},
enumerable: true,
configurable: true
});
Object.defineProperty(ModalComponent.prototype, "type", {
set: /**
* @param {?} value
* @return {?}
*/
function (value) {
this.option.type = value;
},
enumerable: true,
configurable: true
});
Object.defineProperty(ModalComponent.prototype, "placeholders", {
set: /**
* @param {?} value
* @return {?}
*/
function (value) {
this.option.placeholders = value;
},
enumerable: true,
configurable: true
});
Object.defineProperty(ModalComponent.prototype, "operation", {
set: /**
* @param {?} value
* @return {?}
*/
function (value) {
this.option.operation = value;
this.setClassMap();
},
enumerable: true,
configurable: true
});
/**
* @param {?} event
* @return {?}
*/
ModalComponent.prototype.panend = /**
* @param {?} event
* @return {?}
*/
function (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 {?}
*/
ModalComponent.prototype.isTemplateRef = /**
* @param {?} value
* @return {?}
*/
function (value) {
return value instanceof TemplateRef;
};
/**
* @param {?} value
* @return {?}
*/
ModalComponent.prototype.isNoTitle = /**
* @param {?} value
* @return {?}
*/
function (value) {
return value === '' || value === null || value === undefined;
};
/**
* @param {?} visible
* @return {?}
*/
ModalComponent.prototype.setTransitionName = /**
* @param {?} visible
* @return {?}
*/
function (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 {?}
*/
ModalComponent.prototype.setActiveName = /**
* @param {?} name
* @return {?}
*/
function (name) {
return name.length > 0 ? name + "-enter " + name + "-enter-active" : null;
};
/**
* @param {?} name
* @return {?}
*/
ModalComponent.prototype.setLeaveActiveName = /**
* @param {?} name
* @return {?}
*/
function (name) {
return name.length > 0 ? name + "-leave " + name + "-leave-active" : null;
};
/**
* @return {?}
*/
ModalComponent.prototype.setClassMap = /**
* @return {?}
*/
function () {
var _a, _b, _c;
this.wrapCls = (_a = {},
_a[this.option.wrapClassName] = true,
_a[this.option.prefixCls + "-wrap-popup"] = this.option.popup,
_a);
this.cls = (_b = {},
_b[this.option.className] = true,
_b[this.option.prefixCls + "-transparent"] = this.option.transparent,
_b[this.option.prefixCls + "-popup"] = this.option.popup,
_b[this.option.prefixCls + "-popup-" + this.option.animationType] = this.option.popup && this.option.animationType,
_b[this.option.prefixCls + "-android"] = this.option.platform === 'android',
_b);
this.btnGroupClass = (_c = {},
_c[this.option.prefixCls + "-button-group-" + (this.option.footer.length === 2 && !this.option.operation ? 'h' : 'v')] = true,
_c[this.option.prefixCls + "-button-group-" + (this.option.operation ? 'operation' : 'normal')] = true,
_c);
};
/**
* @param {?} type
* @param {?} value
* @return {?}
*/
ModalComponent.prototype.inputChange = /**
* @param {?} type
* @param {?} value
* @return {?}
*/
function (type, value) {
this.data[type] = value;
};
/**
* @return {?}
*/
ModalComponent.prototype.leaveAnimation = /**
* @return {?}
*/
function () {
var _this = this;
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 {?}
*/
function () {
_this.option.visible = false;
if (_this.onChanged) {
_this.onChanged(_this.option.visible);
}
}), 200);
};
/**
* @param {?} value
* @return {?}
*/
ModalComponent.prototype.writeValue = /**
* @param {?} value
* @return {?}
*/
function (value) {
if (value) {
this.option.visible = value;
}
this.setTransitionName(value);
};
/**
* @param {?} fn
* @return {?}
*/
ModalComponent.prototype.registerOnChange = /**
* @param {?} fn
* @return {?}
*/
function (fn) {
this.onChanged = fn;
};
/**
* @param {?} fn
* @return {?}
*/
ModalComponent.prototype.registerOnTouched = /**
* @param {?} fn
* @return {?}
*/
function (fn) {
this.onTouched = fn;
};
Object.defineProperty(ModalComponent.prototype, "afterOpen", {
get: /**
* @return {?}
*/
function () {
return this.afterOpenEmitter.asObservable();
},
enumerable: true,
configurable: true
});
Object.defineProperty(ModalComponent.prototype, "afterClose", {
get: /**
* @return {?}
*/
function () {
return this.afterCloseEmitter.asObservable();
},
enumerable: true,
configurable: true
});
/**
* @return {?}
*/
ModalComponent.prototype.getInstance = /**
* @return {?}
*/
function () {
return this;
};
/**
* @return {?}
*/
ModalComponent.prototype.getElement = /**
* @return {?}
*/
function () {
return this.elementRef && this.elementRef.nativeElement;
};
/**
* @return {?}
*/
ModalComponent.prototype.close = /**
* @return {?}
*/
function () {
if (this.option.closeWithAnimation) {
this.option.closeWithAnimation();
}
else {
this.onClose.emit();
this.leaveAnimation();
}
};
/**
* @return {?}
*/
ModalComponent.prototype.triggerOk = /**
* @return {?}
*/
function () {
if (this.option.footer.length > 1) {
/** @type {?} */
var button = this.option.footer[1];
button.onPress();
}
};
/**
* @return {?}
*/
ModalComponent.prototype.triggerCancel = /**
* @return {?}
*/
function () {
if (this.option.footer.length > 0) {
/** @type {?} */
var button = this.option.footer[0];
button.onPress();
}
};
/**
* @return {?}
*/
ModalComponent.prototype.destroy = /**
* @return {?}
*/
function () {
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 {?}
*/
function () { return ModalComponent; })),
multi: true
}
]
}] }
];
/** @nocollapse */
ModalComponent.ctorParameters = function () { return [
{ 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'],] }]
};
return ModalComponent;
}(ModalRef));
export { ModalComponent };
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;
}
var ModalServiceComponent = /** @class */ (function (_super) {
tslib_1.__extends(ModalServiceComponent, _super);
function ModalServiceComponent(option, elementRef) {
var _this = _super.call(this, option, elementRef) || this;
_this.option = option;
_this.elementRef = elementRef;
_this.setTransitionName(_this.option.visible);
return _this;
}
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 = function () { return [
{ type: ModalOptions },
{ type: ElementRef }
]; };
return ModalServiceComponent;
}(ModalComponent));
export { ModalServiceComponent };
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.