HumanBreak/src/types/plugin.d.ts

171 lines
4.3 KiB
TypeScript
Raw Normal View History

2022-11-13 18:02:05 +08:00
// 这里包含所有插件导出的函数及变量声明声明的函数会在类型标注中标注到core上
2022-11-14 17:11:23 +08:00
type Ref<T> = {
value: T;
};
2022-11-19 11:30:14 +08:00
type DragFn = (x: number, y: number, e: MouseEvent | TouchEvent) => void;
2022-11-21 20:00:34 +08:00
type CanParseCss = keyof {
[P in keyof CSSStyleDeclaration as CSSStyleDeclaration[P] extends string
? P extends string
? P
: never
: never]: CSSStyleDeclaration[P];
};
2022-12-29 19:57:31 +08:00
interface PluginDeclaration extends PluginUtils, PluginUis, PluginUse {
2022-11-13 18:02:05 +08:00
/**
* 使core.addPop或core.plugin.addPop调用
* @param px
* @param py
* @param value
*/
addPop(px: number, py: number, value: string): void;
/** 添加变量 例所有的正在弹出的文字像这个就可以使用core.plugin.pop获取 */
pop: any[];
2022-11-14 17:11:23 +08:00
2022-12-29 19:57:31 +08:00
/** 状态栏信息,取反后刷新状态栏 */
readonly statusBarStatus: Ref<boolean>;
/** 检查标记的怪物,取反后更新显示信息 */
readonly checkMarkedStatus: Ref<boolean>;
/**
*
* @param fn
*/
addAnimate(fn: (time: number) => void);
/**
*
* @param fn
*/
removeAnimate(fn: (time: number) => void);
/**
*
*/
checkMarkedEnemy(): void;
/**
*
*/
resetSettings(): void;
}
interface PluginUtils {
/**
* undefined或null
* @param value
*/
has<T>(value: T): value is NonNullable<T>;
/**
*
* @param damage
*/
getDamageColor(damage: number): string;
/**
* css字符串为CSSStyleDeclaration对象
* @param css css字符串
*/
parseCss(css: string): Partial<Record<CanParseCss, string>>;
}
interface PluginUis {
2022-11-19 11:30:14 +08:00
/** 怪物手册的怪物详细信息的初始位置 */
bookDetailPos: number;
/** 怪物手册详细信息展示的怪物 */
2022-12-29 00:26:12 +08:00
bookDetailEnemy: DetailedEnemy;
2022-11-19 11:30:14 +08:00
2022-11-21 20:00:34 +08:00
/** ui是否使用渐变 */
readonly transition: Ref<boolean>;
2022-11-14 17:11:23 +08:00
/** 手册是否打开 */
readonly bookOpened: Ref<boolean>;
2022-11-21 20:00:34 +08:00
/** 道具栏是否打开 */
readonly toolOpened: Ref<boolean>;
2022-11-30 16:42:44 +08:00
/** 装备栏是否打开 */
readonly equipOpened: Ref<boolean>;
2022-12-28 20:34:23 +08:00
/** 是否显示状态栏 */
readonly showStatusBar: Ref<boolean>;
2022-12-29 00:26:12 +08:00
/** 设置界面是否打开 */
readonly settingsOpened: Ref<boolean>;
2022-12-29 19:57:31 +08:00
/** 是否正在进行章节显示 */
readonly chapterShowed: Ref<boolean>;
/** 章节显示的内容 */
readonly chapterContent: Ref<boolean>;
2022-11-14 17:11:23 +08:00
/** ui栈 */
readonly uiStack: Ref<Component[]>;
2022-12-29 19:57:31 +08:00
/**
*
* @param chapter
*/
showChapter(chapter: string): void;
}
interface PluginUse {
2022-11-16 23:01:23 +08:00
/** 是否是移动设备 */
readonly isMobile: boolean;
2022-11-14 17:11:23 +08:00
/**
*
* @param ele
* @param fn x y和鼠标事件或点击事件
* @param ondown
* @param global
*/
useDrag(
ele: HTMLElement,
2022-11-19 11:30:14 +08:00
fn: DragFn,
ondown?: DragFn,
onUp?: (e: MouseEvent | TouchEvent) => void,
2022-11-14 17:11:23 +08:00
global: boolean = false
): void;
2022-11-19 11:30:14 +08:00
/**
*
* @param fn
*/
cancelGlobalDrag(fn: DragFn): void;
2022-11-14 17:11:23 +08:00
/**
*
* @param ele
* @param fn
*/
useWheel(
ele: HTMLElement,
fn: (x: number, y: number, z: number, e: WheelEvent) => void
): void;
2022-11-16 23:01:23 +08:00
2022-11-19 11:30:14 +08:00
/**
*
* @param ele
* @param fn
*/
useUp(ele: HTMLElement, fn: DragFn): void;
2022-11-13 18:02:05 +08:00
}
type Forward<T> = {
[K in keyof T as T[K] extends Function
? K extends `_${string}`
? never
: K
: never]: T[K];
};
type ForwardKeys<T> = keyof Forward<T>;