olympus-r
Version:
一个力求简单易用的前端开发框架 #### 开发语言 TypeScript #### 核心架构 MVC #### 模块间通讯和解耦 采用事件机制,利用一个全局唯一的事件派发器进行模块间通讯,解耦模块间依赖 #### 表现层结构 使用桥接模式拆分接口与实现,达到一套核心驱动多套表现层的目的(目前支持DOM、Egret、PixiJS三种表现层),同时支持表现层的未来可扩展性 #### TypeScript装饰器注入 框架提供TypeScript装饰器注入功能,便捷获取托管对象。例如:
51 lines (50 loc) • 1.59 kB
TypeScript
import IDisposable from "../../core/interfaces/IDisposable";
import IOpenClose from "../../core/interfaces/IOpenClose";
import IHasBridge from "../bridge/IHasBridge";
import IPanelPolicy from "./IPanelPolicy";
/**
* @author Raykid
* @email initial_r@qq.com
* @create date 2017-09-06
* @modify date 2017-09-06
*
* 弹窗接口
*/
export default interface IPanel<S = any, OD = any, CD = any> extends IHasBridge<S>, IOpenClose<OD, CD>, IDisposable {
/** 实际显示对象 */
skin: S;
/** 弹出策略 */
policy: IPanelPolicy<S>;
/** 自定义弹窗遮罩透明度,不传则使用项目默认透明度 */
maskAlpha?: number;
/** 弹出当前弹窗(等同于调用PanelManager.pop方法) */
open(data?: OD, isModel?: boolean, from?: {
x: number;
y: number;
}): Promise<any>;
/** 关闭当前弹窗(等同于调用PanelManager.drop方法) */
close(data?: CD, to?: {
x: number;
y: number;
}): Promise<any>;
/** 在弹出前调用的方法 */
onBeforePop(data?: OD, isModel?: boolean, from?: {
x: number;
y: number;
}): void;
/** 在弹出后调用的方法 */
onAfterPop(data?: OD, isModel?: boolean, from?: {
x: number;
y: number;
}): void;
/** 在关闭前调用的方法 */
onBeforeDrop(data?: CD, to?: {
x: number;
y: number;
}): void;
/** 在关闭后调用的方法 */
onAfterDrop(data?: CD, to?: {
x: number;
y: number;
}): void;
}