ng-zorro-antd-mobile
Version:
An enterprise-class mobile UI components based on Ant Design and Angular
188 lines • 15.8 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import { Injectable } from '@angular/core';
import { ActionSheetComponent } from './action-sheet.component';
import { ActionSheetOptions, ShareActionSheetWithOptions } from './action-sheet-options.provider';
import { PopupService } from '../core/services/popup.service';
import * as i0 from "@angular/core";
import * as i1 from "./public-api";
import * as i2 from "@angular/cdk/overlay";
/** @type {?} */
const NORMAL = 'NORMAL';
/** @type {?} */
const SHARE = 'SHARE';
/**
* @return {?}
*/
function noop() { }
export class ActionSheetService extends PopupService {
constructor() {
super(...arguments);
this.compRef = null;
this._actionSheetCompFactory = null;
this.appRef = null;
this.comRef = null;
this.instance = null;
}
/**
* @param {?} config
* @param {?=} options
* @return {?}
*/
_initConfig(config, options = {}) {
/** @type {?} */
const props = new ActionSheetOptions();
/** @type {?} */
const optionalParams = [
'prefixCls',
'maskClosable',
'cancelButtonText',
'cancelButtonIndex',
'destructiveButtonIndex',
'title',
'message',
'className',
'transitionName',
'maskTransitionName',
'options',
'locale',
'close'
];
/** @type {?} */
const self = this;
config = Object.assign(options, config, {
close: (/**
* @return {?}
*/
() => {
if (config.maskClosable) {
self.closeWithAnimation(config.transitionName, config.maskTransitionName);
}
})
});
optionalParams.forEach((/**
* @param {?} key
* @return {?}
*/
key => {
if (config[key] !== undefined) {
props[key] = config[key];
}
}));
return props;
}
/**
* @param {?} props
* @return {?}
*/
_open(props) {
this.comRef = this.showPopup(ActionSheetComponent);
this.comRef.instance.option = props;
return this.comRef && this.comRef.instance;
}
/**
* @param {?} flag
* @param {?} config
* @param {?} callback
* @return {?}
*/
createActionSheet(flag, config, callback) {
/** @type {?} */
const options = flag === NORMAL ? new ActionSheetOptions() : new ShareActionSheetWithOptions();
/** @type {?} */
const transitionName = config.transitionName ? config.transitionName : options.transitionName;
options.transitionName = `${transitionName}-enter ${transitionName}-enter-active`;
/** @type {?} */
const maskTransitionName = config.maskTransitionName ? config.maskTransitionName : options.maskTransitionName;
options.maskTransitionName = `${maskTransitionName}-enter ${maskTransitionName}-enter-active`;
/** @type {?} */
const props = this._initConfig(config, options);
Object.assign(props, { onPress: cb }, { flag: flag }, { maskClose: props.maskClosable ? cb : (/**
* @return {?}
*/
() => { }) });
/** @type {?} */
const self = this;
/**
* @param {?} index
* @param {?=} rowIndex
* @param {?=} event
* @return {?}
*/
function cb(index, rowIndex = 0, event) {
event.stopPropagation();
/** @type {?} */
const res = callback(index, rowIndex);
if (res && res.then) {
res.then((/**
* @return {?}
*/
() => {
self.closeWithAnimation(transitionName, maskTransitionName);
}));
}
else {
self.closeWithAnimation(transitionName, maskTransitionName);
}
}
return this._open(props);
}
/**
* @param {?} transitionName
* @param {?} maskTransitionName
* @return {?}
*/
closeWithAnimation(transitionName, maskTransitionName) {
this.comRef.instance.option.transitionName = `${transitionName}-leave ${transitionName}-leave-active`;
this.comRef.instance.option.maskTransitionName = `${maskTransitionName}-leave ${maskTransitionName}-leave-active`;
setTimeout((/**
* @return {?}
*/
() => {
this.close();
}), 200);
}
/**
* @param {?} config
* @param {?=} callback
* @return {?}
*/
showActionSheetWithOptions(config, callback = noop) {
return this.createActionSheet(NORMAL, config, callback);
}
/**
* @param {?} config
* @param {?=} callback
* @return {?}
*/
showShareActionSheetWithOptions(config, callback = noop) {
return this.createActionSheet(SHARE, config, callback);
}
/**
* @return {?}
*/
close() {
this.hidePopup();
}
}
ActionSheetService.decorators = [
{ type: Injectable, args: [{
providedIn: 'root'
},] }
];
/** @nocollapse */ ActionSheetService.ngInjectableDef = i0.ɵɵdefineInjectable({ factory: function ActionSheetService_Factory() { return new i1.ActionSheet(i0.ɵɵinject(i2.Overlay)); }, token: i1.ActionSheet, providedIn: "root" });
if (false) {
/** @type {?} */
ActionSheetService.prototype.compRef;
/** @type {?} */
ActionSheetService.prototype._actionSheetCompFactory;
/** @type {?} */
ActionSheetService.prototype.appRef;
/** @type {?} */
ActionSheetService.prototype.comRef;
/** @type {?} */
ActionSheetService.prototype.instance;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"action-sheet.service.js","sourceRoot":"ng://ng-zorro-antd-mobile/","sources":["action-sheet/action-sheet.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, ComponentRef, ComponentFactory, ApplicationRef } from '@angular/core';\nimport { ActionSheetComponent } from './action-sheet.component';\nimport {\n  ActionCallBack,\n  ActionSheetOptions,\n  ActionSheetWithOptions,\n  ShareActionSheetWithOptions\n} from './action-sheet-options.provider';\nimport { PopupService } from '../core/services/popup.service';\n\nconst NORMAL = 'NORMAL';\nconst SHARE = 'SHARE';\nfunction noop() {}\n@Injectable({\n  providedIn: 'root'\n})\nexport class ActionSheetService extends PopupService {\n  compRef: ComponentRef<any> = null;\n  _actionSheetCompFactory: ComponentFactory<ActionSheetComponent> = null;\n  appRef: ApplicationRef = null;\n  comRef: ComponentRef<ActionSheetComponent> = null;\n\n  instance = null;\n\n  _initConfig(config: ActionSheetOptions, options: Object = {}): ActionSheetOptions {\n    const props: ActionSheetOptions = new ActionSheetOptions();\n    const optionalParams: string[] = [\n      'prefixCls',\n      'maskClosable',\n      'cancelButtonText',\n      'cancelButtonIndex',\n      'destructiveButtonIndex',\n      'title',\n      'message',\n      'className',\n      'transitionName',\n      'maskTransitionName',\n      'options',\n      'locale',\n      'close'\n    ];\n    const self = this;\n    config = Object.assign(options, config, {\n      close: (): void => {\n        if (config.maskClosable) {\n          self.closeWithAnimation(config.transitionName, config.maskTransitionName);\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: ActionSheetOptions) {\n    this.comRef = this.showPopup(ActionSheetComponent);\n    this.comRef.instance.option = props;\n    return this.comRef && this.comRef.instance;\n  }\n\n  createActionSheet(\n    flag: string,\n    config: ActionSheetWithOptions | ShareActionSheetWithOptions,\n    callback: ActionCallBack\n  ) {\n    const options = flag === NORMAL ? new ActionSheetOptions() : new ShareActionSheetWithOptions();\n    const transitionName = config.transitionName ? config.transitionName : options.transitionName;\n    options.transitionName = `${transitionName}-enter ${transitionName}-enter-active`;\n    const maskTransitionName = config.maskTransitionName ? config.maskTransitionName : options.maskTransitionName;\n    options.maskTransitionName = `${maskTransitionName}-enter ${maskTransitionName}-enter-active`;\n    const props = this._initConfig(config, options);\n    Object.assign(props, { onPress: cb }, { flag: flag }, { maskClose: props.maskClosable ? cb : () => {} });\n    const self = this;\n    function cb(index: any, rowIndex = 0, event) {\n      event.stopPropagation();\n      const res = callback(index, rowIndex);\n      if (res && res.then) {\n        res.then(() => {\n          self.closeWithAnimation(transitionName, maskTransitionName);\n        });\n      } else {\n        self.closeWithAnimation(transitionName, maskTransitionName);\n      }\n    }\n    return this._open(props);\n  }\n\n  closeWithAnimation(transitionName, maskTransitionName) {\n    this.comRef.instance.option.transitionName = `${transitionName}-leave ${transitionName}-leave-active`;\n    this.comRef.instance.option.maskTransitionName = `${maskTransitionName}-leave ${maskTransitionName}-leave-active`;\n    setTimeout(() => {\n      this.close();\n    }, 200);\n  }\n\n  showActionSheetWithOptions(config: ActionSheetWithOptions, callback: ActionCallBack = noop) {\n    return this.createActionSheet(NORMAL, config, callback);\n  }\n\n  showShareActionSheetWithOptions(config: ShareActionSheetWithOptions, callback: ActionCallBack = noop) {\n    return this.createActionSheet(SHARE, config, callback);\n  }\n\n  close() {\n    this.hidePopup();\n  }\n}\n"]}