UNPKG

ng-zorro-antd-mobile

Version:

An enterprise-class mobile UI components based on Ant Design and Angular

321 lines 26 kB
/** * @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"]}