1
0
mirror of https://github.com/lexogrine/cs2-react-hud.git synced 2025-12-10 02:42:49 +01:00

71 lines
1.9 KiB
TypeScript

export type ActionHandler<T = any> = (data: T) => void;
export default class ActionManager {
handlers: { [K in string]?: ActionHandler[] };
constructor(){
this.handlers = {}
/*this.on('data', _data => {
});*/
}
execute = <T = any>(eventName: string, argument?: T) => {
const handlers = this.handlers[eventName] || [];
for(const handler of handlers){
handler(argument);
}
}
on = <T = any>(eventName: string, handler: ActionHandler<T>) => {
if(!this.handlers[eventName]) this.handlers[eventName] = [];
this.handlers[eventName]!.push(handler);
}
off = (eventName: string, handler: ActionHandler) => {
if(!this.handlers[eventName]) this.handlers[eventName] = [];
this.handlers[eventName] = this.handlers[eventName]!.filter(h => h !== handler);
}
}
export class ConfigManager {
listeners: ActionHandler[];
data: { [K in string]?: any };
constructor(){
this.listeners = [];
this.data = {};
}
save(data: { [K in string]?: any }){
this.data = data;
this.execute();
/*const listeners = this.listeners.get(eventName);
if(!listeners) return false;
listeners.forEach(callback => {
if(argument) callback(argument);
else callback();
});
return true;*/
}
execute(){
const listeners = this.listeners;
if(!listeners || !listeners.length) return false;
listeners.forEach(listener => {
listener(this.data);
});
return true;
}
onChange = (listener: ActionHandler) => {
const listOfListeners = this.listeners || [];
listOfListeners.push(listener);
this.listeners = listOfListeners;
return true;
}
off = (listener: ActionHandler) => {
this.listeners = this.listeners.filter(l => l !== listener);
}
}