ng-zorro-antd-mobile
Version:
An enterprise-class mobile UI components based on Ant Design and Angular
103 lines • 14.1 kB
JavaScript
import { Injectable } from '@angular/core';
import { ActionSheetComponent } from './action-sheet.component';
import { ActionSheetOptions, ShareActionSheetWithOptions } from './action-sheet-options.provider';
import { PopupService } from 'ng-zorro-antd-mobile/core';
import * as i0 from "@angular/core";
const NORMAL = 'NORMAL';
const SHARE = 'SHARE';
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;
}
_initConfig(config, options = {}) {
const props = new ActionSheetOptions();
const optionalParams = [
'prefixCls',
'maskClosable',
'cancelButtonText',
'cancelButtonIndex',
'destructiveButtonIndex',
'title',
'message',
'className',
'transitionName',
'maskTransitionName',
'options',
'locale',
'close'
];
const self = this;
config = Object.assign(options, config, {
close: () => {
if (config.maskClosable) {
self.closeWithAnimation(config.transitionName, config.maskTransitionName);
}
}
});
optionalParams.forEach(key => {
if (config[key] !== undefined) {
props[key] = config[key];
}
});
return props;
}
_open(props) {
this.comRef = this.showPopup(ActionSheetComponent);
this.comRef.instance.option = props;
return this.comRef && this.comRef.instance;
}
createActionSheet(flag, config, callback) {
const options = flag === NORMAL ? new ActionSheetOptions() : new ShareActionSheetWithOptions();
const transitionName = config.transitionName ? config.transitionName : options.transitionName;
options.transitionName = `${transitionName}-enter ${transitionName}-enter-active`;
const maskTransitionName = config.maskTransitionName ? config.maskTransitionName : options.maskTransitionName;
options.maskTransitionName = `${maskTransitionName}-enter ${maskTransitionName}-enter-active`;
const props = this._initConfig(config, options);
Object.assign(props, { onPress: cb }, { flag: flag }, { maskClose: props.maskClosable ? cb : () => { } });
const self = this;
function cb(index, rowIndex = 0, event) {
event.stopPropagation();
const res = callback(index, rowIndex);
if (res && res.then) {
res.then(() => {
self.closeWithAnimation(transitionName, maskTransitionName);
});
}
else {
self.closeWithAnimation(transitionName, maskTransitionName);
}
}
return this._open(props);
}
closeWithAnimation(transitionName, maskTransitionName) {
this.comRef.instance.option.transitionName = `${transitionName}-leave ${transitionName}-leave-active`;
this.comRef.instance.option.maskTransitionName = `${maskTransitionName}-leave ${maskTransitionName}-leave-active`;
setTimeout(() => {
this.close();
}, 200);
}
showActionSheetWithOptions(config, callback = noop) {
return this.createActionSheet(NORMAL, config, callback);
}
showShareActionSheetWithOptions(config, callback = noop) {
return this.createActionSheet(SHARE, config, callback);
}
close() {
this.hidePopup();
}
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: ActionSheetService, deps: null, target: i0.ɵɵFactoryTarget.Injectable }); }
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: ActionSheetService, providedIn: 'root' }); }
}
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: ActionSheetService, decorators: [{
type: Injectable,
args: [{
providedIn: 'root'
}]
}] });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"action-sheet.service.js","sourceRoot":"","sources":["../../../components/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 'ng-zorro-antd-mobile/core';\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"]}