* 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>
59 lines
2.1 KiB
TypeScript
59 lines
2.1 KiB
TypeScript
import { bind } from 'astal';
|
|
import { Gdk, Gtk } from 'astal/gtk3';
|
|
import AstalWp from 'gi://AstalWp?version=0.1';
|
|
import options from 'src/configuration';
|
|
import { isScrollUp, isScrollDown } from 'src/lib/events/mouse';
|
|
import { capitalizeFirstLetter } from 'src/lib/string/formatters';
|
|
|
|
const { raiseMaximumVolume } = options.menus.volume;
|
|
|
|
export const Slider = ({ device, type }: SliderProps): JSX.Element => {
|
|
return (
|
|
<box vertical>
|
|
<label
|
|
className={`menu-active ${type}`}
|
|
halign={Gtk.Align.START}
|
|
truncate
|
|
hexpand
|
|
wrap
|
|
label={bind(device, 'description').as((description) =>
|
|
capitalizeFirstLetter(description ?? `Unknown ${type} Device`),
|
|
)}
|
|
/>
|
|
<slider
|
|
value={bind(device, 'volume')}
|
|
className={`menu-active-slider menu-slider ${type}`}
|
|
drawValue={false}
|
|
hexpand
|
|
min={0}
|
|
max={type === 'playback' ? bind(raiseMaximumVolume).as((raise) => (raise ? 1.5 : 1)) : 1}
|
|
onDragged={({ value, dragging }) => {
|
|
if (dragging) {
|
|
device.set_volume(value);
|
|
device.set_mute(false);
|
|
}
|
|
}}
|
|
setup={(self) => {
|
|
self.connect('scroll-event', (_, event: Gdk.Event) => {
|
|
if (isScrollUp(event)) {
|
|
const newVolume = device.volume + 0.05;
|
|
const minVolume = raiseMaximumVolume.get() ? 1.5 : 1;
|
|
device.set_volume(Math.min(newVolume, minVolume));
|
|
}
|
|
|
|
if (isScrollDown(event)) {
|
|
const newVolume = device.volume - 0.05;
|
|
device.set_volume(newVolume);
|
|
}
|
|
});
|
|
}}
|
|
/>
|
|
</box>
|
|
);
|
|
};
|
|
|
|
interface SliderProps {
|
|
device: AstalWp.Endpoint;
|
|
type: 'playback' | 'input';
|
|
}
|