* Clean up unused code * Fix media player formatting issue for labels with new line characteres. * Refactor the media player handlers into a class. * More code cleanup and organize shared weather utils into distinct classes. * Flatten some nesting. * Move weather manager in dedicated class and build HTTP Utility class for Rest API calling. * Remove logs * Rebase master merge * Reorg code (WIP) * More reorg * Delete utility scripts * Reorg options * Finish moving all options over * Fix typescript issues * Update options imports to default * missed update * Screw barrel files honestly, work of the devil. * Only initialize power profiles if power-profiles-daemon is running. * Fix window positioning and weather service naming * style dir * More organization * Restructure types to be closer to their source * Remove lib types and constants * Update basic weather object to be saner with extensibility. * Service updates * Fix initialization strategy for services. * Fix Config Manager to only emit changed objects and added missing temp converters. * Update storage service to handle unit changes. * Added cpu temp sensor auto-discovery * Added missing JSDocs to services * remove unused * Migrate to network service. * Fix network password issue. * Move out password input into helper * Rename password mask constant to be less double-negativey. * Dropdown menu rename * Added a component to edit JSON in the settings dialog (rough/WIP) * Align settings * Add and style JSON Editor. * Adjust padding * perf(shortcuts): ⚡ avoid unnecessary polling when shortcuts are disabled Stops the recording poller when shortcuts are disabled, preventing redundant polling and reducing resource usage. * Fix types and return value if shortcut not enabled. * Move the swww daemon checking process outside of the wallpaper service into a dedicated deamon lifecyle processor. * Add more string formatters and use title case for weather status (as it was). * Fix startup errors. * Rgba fix * Remove zod from dependencies --------- Co-authored-by: KernelDiego <gonzalezdiego.contact@gmail.com>
56 lines
1.4 KiB
TypeScript
56 lines
1.4 KiB
TypeScript
import { CustomModules } from '../customModules';
|
|
|
|
export type WidgetFactory = (monitor: number) => JSX.Element;
|
|
|
|
/**
|
|
* Manages registration and creation of widgets
|
|
*/
|
|
export class WidgetRegistry {
|
|
private _widgets: Record<string, WidgetFactory> = {};
|
|
private _initialized = false;
|
|
|
|
constructor(coreWidgets: Record<string, WidgetFactory>) {
|
|
this._widgets = { ...coreWidgets };
|
|
}
|
|
|
|
/**
|
|
* Initialize the registry with core and custom widgets
|
|
*/
|
|
public async initialize(): Promise<void> {
|
|
if (this._initialized) return;
|
|
|
|
try {
|
|
const customWidgets = await CustomModules.build();
|
|
|
|
this._widgets = {
|
|
...this._widgets,
|
|
...customWidgets,
|
|
};
|
|
|
|
this._initialized = true;
|
|
} catch (error) {
|
|
console.error('Failed to initialize widget registry:', error);
|
|
throw error;
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Check if a widget is registered
|
|
*/
|
|
public hasWidget(name: string): boolean {
|
|
return Object.keys(this._widgets).includes(name);
|
|
}
|
|
|
|
/**
|
|
* Create an instance of a widget
|
|
*/
|
|
public createWidget(name: string, monitor: number): JSX.Element {
|
|
if (!this.hasWidget(name)) {
|
|
console.error(`Widget "${name}" not found`);
|
|
return <box />;
|
|
}
|
|
|
|
return this._widgets[name](monitor);
|
|
}
|
|
}
|