* Eslint updates * linter fixes * Type fixes * More type fixes * Fix isvis * More type fixes * Type Fixes * Consolidate logic to manage options * Linter fixes * Package lock update * Update configs * Version checker * Debug pipeline * Package lock update * Update ci * Strict check * Revert ci * Eslint * Remove rule since it causes issues in CI * Actual matugen fix
58 lines
2.1 KiB
TypeScript
58 lines
2.1 KiB
TypeScript
import { bind } from 'astal';
|
|
import { Gdk, Gtk } from 'astal/gtk3';
|
|
import AstalWp from 'gi://AstalWp?version=0.1';
|
|
import { capitalizeFirstLetter, isScrollDown, isScrollUp } from 'src/lib/utils';
|
|
import options from 'src/options';
|
|
|
|
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';
|
|
}
|