ng-zorro-antd-mobile
Version:
An enterprise-class mobile UI components based on Ant Design and Angular
321 lines • 26 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import { Injectable, Injector } from '@angular/core';
import { ModalServiceComponent } from './modal.component';
import { ModalBaseOptions, ModalOptions, AlertOptions } from './modal-options.provider';
import { PopupService } from '../core/services/popup.service';
export class ModalService extends PopupService {
constructor() {
super(...arguments);
this.modalRef = null;
}
/**
* @param {?} config
* @param {?} options
* @return {?}
*/
_initConfig(config, options) {
/** @type {?} */
const props = new ModalBaseOptions();
/** @type {?} */
const optionalParams = [
'visible',
'focus',
'prefixCls',
'animated',
'closable',
'maskClosable',
'onClose',
'transparent',
'popup',
'animationType',
'title',
'footer',
'platform',
'className',
'wrapClassName',
'message',
'actions',
'callbackOrActions',
'type',
'defaultValue',
'placeholders',
'operation',
'transitionName',
'maskTransitionName',
'close',
'closeWithAnimation'
];
/** @type {?} */
const self = this;
config = Object.assign(options, config, {
close: (/**
* @return {?}
*/
() => {
if (config.maskClosable || config.closable) {
self.closeWithAnimation();
}
})
}, {
closeWithAnimation: (/**
* @return {?}
*/
() => {
self.closeWithAnimation();
})
});
optionalParams.forEach((/**
* @param {?} key
* @return {?}
*/
key => {
if (config[key] !== undefined) {
props[key] = config[key];
}
}));
return props;
}
/**
* @param {?} props
* @return {?}
*/
_open(props) {
/** @type {?} */
const childInjector = Injector.create([
{
provide: ModalOptions,
useValue: props
}
]);
this.modalRef = this.showPopup(ModalServiceComponent, childInjector);
return this.modalRef && this.modalRef.instance;
}
/**
* @return {?}
*/
closeWithAnimation() {
/** @type {?} */
const options = new ModalBaseOptions();
this.modalRef.instance.transitionName = `${options.transitionName}-leave ${options.transitionName}-leave-active`;
this.modalRef.instance.maskTransitionName = `${options.maskTransitionName}-leave ${options.maskTransitionName}-leave-active`;
setTimeout((/**
* @return {?}
*/
() => {
this.close();
}), 200);
}
/**
* @param {?=} title
* @param {?=} message
* @param {?=} actions
* @param {?=} platform
* @return {?}
*/
alert(title, message, actions, platform) {
/** @type {?} */
const options = new AlertOptions();
options.visible = true;
options.transparent = true;
options.closable = false;
options.maskClosable = false;
options.platform = 'ios';
/** @type {?} */
const footer = getFooter.call(this, actions);
/** @type {?} */
const config = Object.assign({
title: title,
message: message,
footer: footer,
actions: footer,
platform: platform ? platform : 'ios'
});
/** @type {?} */
const props = this._initConfig(config, options);
return this._open(props);
}
/**
* @param {?=} title
* @param {?=} message
* @param {?=} callbackOrActions
* @param {?=} type
* @param {?=} defaultValue
* @param {?=} placeholders
* @param {?=} platform
* @return {?}
*/
prompt(title, message, callbackOrActions, type, defaultValue, placeholders, platform) {
/** @type {?} */
const options = new ModalOptions();
options.visible = true;
options.transparent = true;
options.closable = false;
options.maskClosable = false;
options.className = 'am-modal-alert-content';
options.defaultValue = defaultValue || ['', ''];
options.placeholders = placeholders;
(options.type = type ? type : 'default'), (options.platform = platform ? platform : 'ios');
/**
* @param {?} self
* @param {?} func
* @return {?}
*/
function getArgs(self, func) {
/** @type {?} */
let text;
/** @type {?} */
let password;
if (self.modalRef) {
text = self.modalRef.instance.data.text || options.defaultValue[0];
password = self.modalRef.instance.data.password || options.defaultValue[1];
}
else {
text = options.defaultValue[0];
password = options.defaultValue[1];
}
if (type === 'login-password') {
return func(text, password);
}
else if (type === 'secure-text') {
return func(password);
}
return func(text);
}
/** @type {?} */
let actions;
if (typeof callbackOrActions === 'function') {
actions = [
{ text: 'Cancel' },
{
text: 'OK',
onPress: (/**
* @return {?}
*/
() => {
getArgs(this, callbackOrActions);
})
}
];
}
else {
actions = callbackOrActions.map((/**
* @param {?} item
* @return {?}
*/
item => {
return {
text: item.text,
onPress: (/**
* @return {?}
*/
() => {
if (item.onPress) {
return getArgs(this, item.onPress);
}
})
};
}));
}
/** @type {?} */
const footer = getFooter.call(this, actions);
/** @type {?} */
const config = Object.assign({
title: title,
message: message,
type: type ? type : 'default',
footer: footer,
actions: footer,
platform: platform ? platform : 'ios'
});
/** @type {?} */
const props = this._initConfig(config, options);
return this._open(props);
}
/**
* @param {?=} actions
* @param {?=} platform
* @return {?}
*/
operation(actions, platform) {
/** @type {?} */
const options = new ModalOptions();
options.visible = true;
options.transparent = true;
options.closable = false;
options.maskClosable = false;
options.operation = true;
options.className = 'am-modal-operation';
/** @type {?} */
const footer = getFooter.call(this, actions);
/** @type {?} */
const config = Object.assign({
footer: footer,
actions: footer,
platform: platform ? platform : 'ios'
});
/** @type {?} */
const props = this._initConfig(config, options);
return this._open(props);
}
/**
* @return {?}
*/
close() {
this.hidePopup();
}
}
ModalService.decorators = [
{ type: Injectable, args: [{
providedIn: 'root'
},] },
{ type: Injectable }
];
if (false) {
/** @type {?} */
ModalService.prototype.modalRef;
}
/**
* @param {?} actions
* @return {?}
*/
function getFooter(actions) {
/** @type {?} */
let action = actions ? actions : [{ text: 'OK', onPress: (/**
* @return {?}
*/
() => { }) }];
return action.map((/**
* @param {?} button
* @return {?}
*/
(button) => {
/** @type {?} */
const orginPress = button.onPress || (/**
* @return {?}
*/
function () { });
button.onPress = (/**
* @return {?}
*/
() => {
/** @type {?} */
const res = orginPress();
if (res && res.then) {
res.then((/**
* @return {?}
*/
() => {
this.closeWithAnimation();
}));
}
else {
this.closeWithAnimation();
}
});
return button;
}));
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"modal.service.js","sourceRoot":"ng://ng-zorro-antd-mobile/","sources":["modal/modal.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, Injector, ComponentRef, TemplateRef } from '@angular/core';\nimport { ModalServiceComponent } from './modal.component';\nimport { ModalBaseOptions, ModalOptions, AlertOptions, Action } from './modal-options.provider';\nimport { PopupService } from '../core/services/popup.service';\nimport { ModalRef } from './modal-ref.class';\n@Injectable({\n  providedIn: 'root'\n})\n@Injectable()\nexport class ModalService extends PopupService {\n  modalRef: ComponentRef<ModalServiceComponent> = null;\n  _initConfig(config: ModalBaseOptions, options: any): ModalBaseOptions {\n    const props: ModalBaseOptions = new ModalBaseOptions();\n    const optionalParams: string[] = [\n      'visible',\n      'focus',\n      'prefixCls',\n      'animated',\n      'closable',\n      'maskClosable',\n      'onClose',\n      'transparent',\n      'popup',\n      'animationType',\n      'title',\n      'footer',\n      'platform',\n      'className',\n      'wrapClassName',\n      'message',\n      'actions',\n      'callbackOrActions',\n      'type',\n      'defaultValue',\n      'placeholders',\n      'operation',\n      'transitionName',\n      'maskTransitionName',\n      'close',\n      'closeWithAnimation'\n    ];\n    const self = this;\n    config = Object.assign(\n      options,\n      config,\n      {\n        close: (): void => {\n          if (config.maskClosable || config.closable) {\n            self.closeWithAnimation();\n          }\n        }\n      },\n      {\n        closeWithAnimation: (): void => {\n          self.closeWithAnimation();\n        }\n      }\n    );\n    optionalParams.forEach(key => {\n      if (config[key] !== undefined) {\n        props[key] = config[key];\n      }\n    });\n    return props;\n  }\n\n  _open(props: ModalBaseOptions): any {\n    const childInjector = Injector.create([\n      {\n        provide: ModalOptions,\n        useValue: props\n      }\n    ]);\n    this.modalRef = this.showPopup(ModalServiceComponent, childInjector);\n    return this.modalRef && this.modalRef.instance;\n  }\n\n  closeWithAnimation() {\n    const options: ModalBaseOptions = new ModalBaseOptions();\n    this.modalRef.instance.transitionName = `${options.transitionName}-leave ${options.transitionName}-leave-active`;\n    this.modalRef.instance.maskTransitionName = `${options.maskTransitionName}-leave ${options.maskTransitionName}-leave-active`;\n    setTimeout(() => {\n      this.close();\n    }, 200);\n  }\n\n  alert(\n    title?: string | TemplateRef<any>,\n    message?: string | TemplateRef<any>,\n    actions?: Array<any>,\n    platform?: string\n  ): any {\n    const options: AlertOptions = new AlertOptions();\n    options.visible = true;\n    options.transparent = true;\n    options.closable = false;\n    options.maskClosable = false;\n    options.platform = 'ios';\n\n    const footer = getFooter.call(this, actions);\n\n    const config = Object.assign({\n      title: title,\n      message: message,\n      footer: footer,\n      actions: footer,\n      platform: platform ? platform : 'ios'\n    });\n\n    const props = this._initConfig(config, options);\n    return this._open(props);\n  }\n\n  prompt(\n    title?: string | TemplateRef<any>,\n    message?: string | TemplateRef<any>,\n    callbackOrActions?: any,\n    type?: string,\n    defaultValue?: Array<string>,\n    placeholders?: Array<any>,\n    platform?: string\n  ): any {\n    const options: ModalOptions = new ModalOptions();\n    options.visible = true;\n    options.transparent = true;\n    options.closable = false;\n    options.maskClosable = false;\n    options.className = 'am-modal-alert-content';\n    options.defaultValue = defaultValue || ['', ''];\n    options.placeholders = placeholders;\n    (options.type = type ? type : 'default'), (options.platform = platform ? platform : 'ios');\n\n    function getArgs(self: any, func: any) {\n      let text: any, password: any;\n      if (self.modalRef) {\n        text = self.modalRef.instance.data.text || options.defaultValue[0];\n        password = self.modalRef.instance.data.password || options.defaultValue[1];\n      } else {\n        text = options.defaultValue[0];\n        password = options.defaultValue[1];\n      }\n\n      if (type === 'login-password') {\n        return func(text, password);\n      } else if (type === 'secure-text') {\n        return func(password);\n      }\n      return func(text);\n    }\n\n    let actions;\n    if (typeof callbackOrActions === 'function') {\n      actions = [\n        { text: 'Cancel' },\n        {\n          text: 'OK',\n          onPress: () => {\n            getArgs(this, callbackOrActions);\n          }\n        }\n      ];\n    } else {\n      actions = callbackOrActions.map(item => {\n        return {\n          text: item.text,\n          onPress: () => {\n            if (item.onPress) {\n              return getArgs(this, item.onPress);\n            }\n          }\n        };\n      });\n    }\n\n    const footer = getFooter.call(this, actions);\n    const config = Object.assign({\n      title: title,\n      message: message,\n      type: type ? type : 'default',\n      footer: footer,\n      actions: footer,\n      platform: platform ? platform : 'ios'\n    });\n    const props = this._initConfig(config, options);\n    return this._open(props);\n  }\n\n  operation(actions?: any, platform?: string): any {\n    const options: ModalOptions = new ModalOptions();\n    options.visible = true;\n    options.transparent = true;\n    options.closable = false;\n    options.maskClosable = false;\n    options.operation = true;\n    options.className = 'am-modal-operation';\n    const footer = getFooter.call(this, actions);\n\n    const config = Object.assign({\n      footer: footer,\n      actions: footer,\n      platform: platform ? platform : 'ios'\n    });\n    const props = this._initConfig(config, options);\n    return this._open(props);\n  }\n\n  close() {\n    this.hidePopup();\n  }\n}\n\nfunction getFooter(actions) {\n  let action = actions ? actions : [{ text: 'OK', onPress: () => {} }];\n  return action.map((button: Action) => {\n    const orginPress = button.onPress || function() {};\n    button.onPress = () => {\n      const res = orginPress();\n      if (res && res.then) {\n        res.then(() => {\n          this.closeWithAnimation();\n        });\n      } else {\n        this.closeWithAnimation();\n      }\n    };\n    return button;\n  });\n}\n"]}