* 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>
82 lines
2.5 KiB
TypeScript
82 lines
2.5 KiB
TypeScript
import './src/lib/session';
|
|
import './src/style';
|
|
import 'src/core/behaviors/bar';
|
|
import AstalHyprland from 'gi://AstalHyprland?version=0.1';
|
|
import { Bar } from './src/components/bar';
|
|
import Notifications from './src/components/notifications';
|
|
import SettingsDialog from './src/components/settings/index';
|
|
import OSD from 'src/components/osd/index';
|
|
import { App } from 'astal/gtk3';
|
|
import { execAsync } from 'astal';
|
|
import { handleRealization } from 'src/components/menus/shared/dropdown/helpers/helpers';
|
|
import { isDropdownMenu } from 'src/components/settings/constants.js';
|
|
import { initializeSystemBehaviors } from 'src/core/behaviors';
|
|
import { runCLI } from 'src/services/cli/commander';
|
|
import { DropdownMenus, StandardWindows } from 'src/components/menus';
|
|
import { forMonitors } from 'src/components/bar/utils/monitors';
|
|
import options from 'src/configuration';
|
|
import { SystemUtilities } from 'src/core/system/SystemUtilities';
|
|
|
|
const hyprland = AstalHyprland.get_default();
|
|
const initializeStartupScripts = (): void => {
|
|
execAsync(`python3 ${SRC_DIR}/scripts/bluetooth.py`).catch((err) =>
|
|
console.error('Failed to initialize bluetooth script:', err),
|
|
);
|
|
};
|
|
|
|
const initializeMenus = (): void => {
|
|
StandardWindows.forEach((window) => {
|
|
return window();
|
|
});
|
|
|
|
DropdownMenus.forEach((window) => {
|
|
return window();
|
|
});
|
|
|
|
DropdownMenus.forEach((window) => {
|
|
const windowName = window.name
|
|
.replace(/_default.*/, '')
|
|
.concat('menu')
|
|
.toLowerCase();
|
|
|
|
if (!isDropdownMenu(windowName)) {
|
|
return;
|
|
}
|
|
|
|
handleRealization(windowName);
|
|
});
|
|
};
|
|
|
|
App.start({
|
|
instanceName: 'hyprpanel',
|
|
requestHandler(request: string, res: (response: unknown) => void) {
|
|
runCLI(request, res);
|
|
},
|
|
async main() {
|
|
try {
|
|
initializeStartupScripts();
|
|
|
|
Notifications();
|
|
OSD();
|
|
|
|
const barsForMonitors = await forMonitors(Bar);
|
|
barsForMonitors.forEach((bar: JSX.Element) => bar);
|
|
|
|
SettingsDialog();
|
|
initializeMenus();
|
|
|
|
initializeSystemBehaviors();
|
|
} catch (error) {
|
|
console.error('Error during application initialization:', error);
|
|
}
|
|
},
|
|
});
|
|
|
|
hyprland.connect('monitor-added', () => {
|
|
const { restartCommand } = options.hyprpanel;
|
|
|
|
if (options.hyprpanel.restartAgs.get()) {
|
|
SystemUtilities.bash(restartCommand.get());
|
|
}
|
|
});
|