ng-zorro-antd-mobile
Version:
An enterprise-class mobile UI components based on Ant Design and Angular
231 lines • 17.3 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import * as tslib_1 from "tslib";
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 {?} */
var NORMAL = 'NORMAL';
/** @type {?} */
var SHARE = 'SHARE';
/**
* @return {?}
*/
function noop() { }
var ActionSheetService = /** @class */ (function (_super) {
tslib_1.__extends(ActionSheetService, _super);
function ActionSheetService() {
var _this = _super !== null && _super.apply(this, arguments) || this;
_this.compRef = null;
_this._actionSheetCompFactory = null;
_this.appRef = null;
_this.comRef = null;
_this.instance = null;
return _this;
}
/**
* @param {?} config
* @param {?=} options
* @return {?}
*/
ActionSheetService.prototype._initConfig = /**
* @param {?} config
* @param {?=} options
* @return {?}
*/
function (config, options) {
if (options === void 0) { options = {}; }
/** @type {?} */
var props = new ActionSheetOptions();
/** @type {?} */
var optionalParams = [
'prefixCls',
'maskClosable',
'cancelButtonText',
'cancelButtonIndex',
'destructiveButtonIndex',
'title',
'message',
'className',
'transitionName',
'maskTransitionName',
'options',
'locale',
'close'
];
/** @type {?} */
var self = this;
config = Object.assign(options, config, {
close: (/**
* @return {?}
*/
function () {
if (config.maskClosable) {
self.closeWithAnimation(config.transitionName, config.maskTransitionName);
}
})
});
optionalParams.forEach((/**
* @param {?} key
* @return {?}
*/
function (key) {
if (config[key] !== undefined) {
props[key] = config[key];
}
}));
return props;
};
/**
* @param {?} props
* @return {?}
*/
ActionSheetService.prototype._open = /**
* @param {?} props
* @return {?}
*/
function (props) {
this.comRef = this.showPopup(ActionSheetComponent);
this.comRef.instance.option = props;
return this.comRef && this.comRef.instance;
};
/**
* @param {?} flag
* @param {?} config
* @param {?} callback
* @return {?}
*/
ActionSheetService.prototype.createActionSheet = /**
* @param {?} flag
* @param {?} config
* @param {?} callback
* @return {?}
*/
function (flag, config, callback) {
/** @type {?} */
var options = flag === NORMAL ? new ActionSheetOptions() : new ShareActionSheetWithOptions();
/** @type {?} */
var transitionName = config.transitionName ? config.transitionName : options.transitionName;
options.transitionName = transitionName + "-enter " + transitionName + "-enter-active";
/** @type {?} */
var maskTransitionName = config.maskTransitionName ? config.maskTransitionName : options.maskTransitionName;
options.maskTransitionName = maskTransitionName + "-enter " + maskTransitionName + "-enter-active";
/** @type {?} */
var props = this._initConfig(config, options);
Object.assign(props, { onPress: cb }, { flag: flag }, { maskClose: props.maskClosable ? cb : (/**
* @return {?}
*/
function () { }) });
/** @type {?} */
var self = this;
/**
* @param {?} index
* @param {?=} rowIndex
* @param {?=} event
* @return {?}
*/
function cb(index, rowIndex, event) {
if (rowIndex === void 0) { rowIndex = 0; }
event.stopPropagation();
/** @type {?} */
var res = callback(index, rowIndex);
if (res && res.then) {
res.then((/**
* @return {?}
*/
function () {
self.closeWithAnimation(transitionName, maskTransitionName);
}));
}
else {
self.closeWithAnimation(transitionName, maskTransitionName);
}
}
return this._open(props);
};
/**
* @param {?} transitionName
* @param {?} maskTransitionName
* @return {?}
*/
ActionSheetService.prototype.closeWithAnimation = /**
* @param {?} transitionName
* @param {?} maskTransitionName
* @return {?}
*/
function (transitionName, maskTransitionName) {
var _this = this;
this.comRef.instance.option.transitionName = transitionName + "-leave " + transitionName + "-leave-active";
this.comRef.instance.option.maskTransitionName = maskTransitionName + "-leave " + maskTransitionName + "-leave-active";
setTimeout((/**
* @return {?}
*/
function () {
_this.close();
}), 200);
};
/**
* @param {?} config
* @param {?=} callback
* @return {?}
*/
ActionSheetService.prototype.showActionSheetWithOptions = /**
* @param {?} config
* @param {?=} callback
* @return {?}
*/
function (config, callback) {
if (callback === void 0) { callback = noop; }
return this.createActionSheet(NORMAL, config, callback);
};
/**
* @param {?} config
* @param {?=} callback
* @return {?}
*/
ActionSheetService.prototype.showShareActionSheetWithOptions = /**
* @param {?} config
* @param {?=} callback
* @return {?}
*/
function (config, callback) {
if (callback === void 0) { callback = noop; }
return this.createActionSheet(SHARE, config, callback);
};
/**
* @return {?}
*/
ActionSheetService.prototype.close = /**
* @return {?}
*/
function () {
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" });
return ActionSheetService;
}(PopupService));
export { ActionSheetService };
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"]}