* 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>
41 lines
1.2 KiB
TypeScript
41 lines
1.2 KiB
TypeScript
import Gio from 'gi://Gio';
|
|
import {
|
|
filterConfigForThemeOnly,
|
|
loadJsonFile,
|
|
saveConfigToFile,
|
|
} from '../../components/settings/shared/FileChooser';
|
|
import options from 'src/configuration';
|
|
import { errorHandler } from 'src/core/errors/handler';
|
|
import { SystemUtilities } from 'src/core/system/SystemUtilities';
|
|
|
|
const { restartCommand } = options.hyprpanel;
|
|
export const hexColorPattern = /^#([0-9A-Fa-f]{6}|[0-9A-Fa-f]{8})$/;
|
|
|
|
export function useTheme(filePath: string): void {
|
|
try {
|
|
const importedConfig = loadJsonFile(filePath);
|
|
|
|
if (!importedConfig) {
|
|
return;
|
|
}
|
|
|
|
const optionsConfigFile = Gio.File.new_for_path(CONFIG_FILE);
|
|
|
|
const [optionsSuccess, optionsContent] = optionsConfigFile.load_contents(null);
|
|
|
|
if (!optionsSuccess) {
|
|
throw new Error('Failed to load theme file.');
|
|
}
|
|
|
|
let optionsConfig = JSON.parse(new TextDecoder('utf-8').decode(optionsContent));
|
|
|
|
const filteredConfig = filterConfigForThemeOnly(importedConfig);
|
|
optionsConfig = { ...optionsConfig, ...filteredConfig };
|
|
|
|
saveConfigToFile(optionsConfig, CONFIG_FILE);
|
|
SystemUtilities.bash(restartCommand.get());
|
|
} catch (error) {
|
|
errorHandler(error);
|
|
}
|
|
}
|