Profectus-Demo/src/game/events.ts

62 lines
2.5 KiB
TypeScript
Raw Normal View History

2022-06-27 00:17:22 +00:00
import type { Settings } from "game/settings";
2022-01-14 04:25:47 +00:00
import { createNanoEvents } from "nanoevents";
import type { App } from "vue";
2022-06-27 00:17:22 +00:00
import type { GenericLayer } from "./layers";
2022-01-14 04:25:47 +00:00
2022-07-15 05:55:36 +00:00
/** All types of events able to be sent or emitted from the global event bus. */
2022-01-14 04:25:47 +00:00
export interface GlobalEvents {
2022-07-15 05:55:36 +00:00
/**
* Sent whenever a layer is added.
* @param layer The layer being added.
* @param saveData The layer's save data object within player.
*/
2022-01-14 04:25:47 +00:00
addLayer: (layer: GenericLayer, saveData: Record<string, unknown>) => void;
2022-07-15 05:55:36 +00:00
/**
* Sent whenever a layer is removed.
* @param layer The layer being removed.
*/
2022-01-14 04:25:47 +00:00
removeLayer: (layer: GenericLayer) => void;
2022-07-15 05:55:36 +00:00
/**
* Sent every game tick. Runs the life cycle of the project.
* @param diff The delta time since last tick, in ms.
* @param trueDiff The delta time since last tick, in ms. Unaffected by time modifiers like {@link game/player.Player.devSpeed} or {@link game/player.Player.offlineTime}. Intended for things like updating animations.
*/
update: (diff: number, trueDiff: number) => void;
2022-07-15 05:55:36 +00:00
/**
* Sent when constructing the {@link Settings} object.
* Use it to add default values for custom properties to the object.
* @param settings The settings object being constructed.
* @see {@link features/features.setDefault} for setting default values.
*/
2022-01-14 04:25:47 +00:00
loadSettings: (settings: Partial<Settings>) => void;
2022-07-15 05:55:36 +00:00
/**
* Sent when the game has ended.
*/
2022-03-11 23:26:39 +00:00
gameWon: VoidFunction;
2022-07-15 05:55:36 +00:00
/**
* Sent when setting up the Vue Application instance.
* Use it to register global components or otherwise set up things that should affect Vue globally.
* @param vue The Vue App being constructed.
*/
2022-01-14 04:25:47 +00:00
setupVue: (vue: App) => void;
2022-07-22 00:23:33 +00:00
/**
* Sent whenever a save has finished loading.
* Happens when the page is opened and upon switching saves in the saves manager.
*/
onLoad: VoidFunction;
/**
* Using document.fonts.ready returns too early on firefox, so we use document.fonts.onloadingdone instead, which doesn't accept multiple listeners.
* This event fires when that callback is called.
*/
fontsLoaded: VoidFunction;
2022-01-14 04:25:47 +00:00
}
2022-07-15 05:55:36 +00:00
/** A global event bus for hooking into {@link GlobalEvents}. */
2022-01-14 04:25:47 +00:00
export const globalBus = createNanoEvents<GlobalEvents>();
2023-02-16 05:15:55 +00:00
if ("fonts" in document) {
// This line breaks tests
// JSDom doesn't add document.fonts, and Object.defineProperty doesn't seem to work on document
document.fonts.onloadingdone = () => globalBus.emit("fontsLoaded");
}