Minor: Refactor the code-base for better organization and compartmentalization. (#934)
* 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>
This commit is contained in:
59
app.ts
59
app.ts
@@ -1,31 +1,27 @@
|
||||
import './src/lib/session';
|
||||
import './src/scss/style';
|
||||
import './src/shared/useTheme';
|
||||
import './src/shared/wallpaper';
|
||||
import './src/shared/systray';
|
||||
import './src/shared/dropdown';
|
||||
import './src/shared/utilities';
|
||||
import './src/components/bar/utils/sideEffects';
|
||||
|
||||
import './src/style';
|
||||
import 'src/core/behaviors/bar';
|
||||
import AstalHyprland from 'gi://AstalHyprland?version=0.1';
|
||||
const hyprland = AstalHyprland.get_default();
|
||||
|
||||
import { Bar } from './src/components/bar';
|
||||
import { DropdownMenus, StandardWindows } from './src/components/menus/exports';
|
||||
import Notifications from './src/components/notifications';
|
||||
import SettingsDialog from './src/components/settings/index';
|
||||
import { bash, forMonitors } from 'src/lib/utils';
|
||||
import options from 'src/options';
|
||||
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';
|
||||
import { isDropdownMenu } from 'src/lib/constants/options.js';
|
||||
import { initializeSystemBehaviors } from 'src/lib/behaviors';
|
||||
import { runCLI } from 'src/cli/commander';
|
||||
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(err));
|
||||
execAsync(`python3 ${SRC_DIR}/scripts/bluetooth.py`).catch((err) =>
|
||||
console.error('Failed to initialize bluetooth script:', err),
|
||||
);
|
||||
};
|
||||
|
||||
const initializeMenus = (): void => {
|
||||
@@ -38,7 +34,10 @@ const initializeMenus = (): void => {
|
||||
});
|
||||
|
||||
DropdownMenus.forEach((window) => {
|
||||
const windowName = window.name.replace('_default', '').concat('menu').toLowerCase();
|
||||
const windowName = window.name
|
||||
.replace(/_default.*/, '')
|
||||
.concat('menu')
|
||||
.toLowerCase();
|
||||
|
||||
if (!isDropdownMenu(windowName)) {
|
||||
return;
|
||||
@@ -54,18 +53,22 @@ App.start({
|
||||
runCLI(request, res);
|
||||
},
|
||||
async main() {
|
||||
initializeStartupScripts();
|
||||
try {
|
||||
initializeStartupScripts();
|
||||
|
||||
Notifications();
|
||||
OSD();
|
||||
Notifications();
|
||||
OSD();
|
||||
|
||||
const barsForMonitors = await forMonitors(Bar);
|
||||
barsForMonitors.forEach((bar: JSX.Element) => bar);
|
||||
const barsForMonitors = await forMonitors(Bar);
|
||||
barsForMonitors.forEach((bar: JSX.Element) => bar);
|
||||
|
||||
SettingsDialog();
|
||||
initializeMenus();
|
||||
SettingsDialog();
|
||||
initializeMenus();
|
||||
|
||||
initializeSystemBehaviors();
|
||||
initializeSystemBehaviors();
|
||||
} catch (error) {
|
||||
console.error('Error during application initialization:', error);
|
||||
}
|
||||
},
|
||||
});
|
||||
|
||||
@@ -73,6 +76,6 @@ hyprland.connect('monitor-added', () => {
|
||||
const { restartCommand } = options.hyprpanel;
|
||||
|
||||
if (options.hyprpanel.restartAgs.get()) {
|
||||
bash(restartCommand.get());
|
||||
SystemUtilities.bash(restartCommand.get());
|
||||
}
|
||||
});
|
||||
|
||||
Reference in New Issue
Block a user