* 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>
87 lines
2.4 KiB
TypeScript
87 lines
2.4 KiB
TypeScript
import { Widget } from 'astal/gtk3';
|
|
import { handleClick, hasCommand } from '../helpers';
|
|
import options from 'src/configuration';
|
|
import { isPrimaryClick } from 'src/lib/events/mouse';
|
|
import { ShortcutVariable } from '../types';
|
|
|
|
const { left, right } = options.menus.dashboard.shortcuts;
|
|
|
|
const ShortcutButton = ({ shortcut, ...props }: ShortcutButtonProps): JSX.Element => {
|
|
return (
|
|
<button
|
|
vexpand
|
|
tooltipText={shortcut.tooltip.get()}
|
|
onClick={(_, event) => {
|
|
if (isPrimaryClick(event)) {
|
|
handleClick(shortcut.command.get());
|
|
}
|
|
}}
|
|
{...props}
|
|
>
|
|
<label className={'button-label txt-icon'} label={shortcut.icon.get()} />
|
|
</button>
|
|
);
|
|
};
|
|
|
|
export const LeftShortcut1 = (): JSX.Element => {
|
|
if (!hasCommand(left.shortcut1)) {
|
|
return <box />;
|
|
}
|
|
|
|
return (
|
|
<ShortcutButton
|
|
shortcut={left.shortcut1}
|
|
className={`dashboard-button top-button ${hasCommand(left.shortcut2) ? 'paired' : ''}`}
|
|
/>
|
|
);
|
|
};
|
|
|
|
export const LeftShortcut2 = (): JSX.Element => {
|
|
if (!hasCommand(left.shortcut2)) {
|
|
return <box />;
|
|
}
|
|
|
|
return <ShortcutButton shortcut={left.shortcut2} className={'dashboard-button'} />;
|
|
};
|
|
|
|
export const LeftShortcut3 = (): JSX.Element => {
|
|
if (!hasCommand(left.shortcut3)) {
|
|
return <box />;
|
|
}
|
|
|
|
return (
|
|
<ShortcutButton
|
|
shortcut={left.shortcut3}
|
|
className={`dashboard-button top-button ${hasCommand(left.shortcut4) ? 'paired' : ''}`}
|
|
/>
|
|
);
|
|
};
|
|
|
|
export const LeftShortcut4 = (): JSX.Element => {
|
|
if (!hasCommand(left.shortcut4)) {
|
|
return <box />;
|
|
}
|
|
|
|
return <ShortcutButton shortcut={left.shortcut4} className={'dashboard-button '} />;
|
|
};
|
|
|
|
export const RightShortcut1 = (): JSX.Element => {
|
|
if (!hasCommand(right.shortcut1)) {
|
|
return <box />;
|
|
}
|
|
|
|
return <ShortcutButton shortcut={right.shortcut1} className={'dashboard-button top-button paired'} />;
|
|
};
|
|
|
|
export const RightShortcut3 = (): JSX.Element => {
|
|
if (!hasCommand(right.shortcut3)) {
|
|
return <box />;
|
|
}
|
|
|
|
return <ShortcutButton shortcut={right.shortcut3} className={'dashboard-button top-button paired'} />;
|
|
};
|
|
|
|
interface ShortcutButtonProps extends Widget.ButtonProps {
|
|
shortcut: ShortcutVariable;
|
|
}
|