summaryrefslogtreecommitdiff
path: root/src/modules/popdowns
diff options
context:
space:
mode:
Diffstat (limited to 'src/modules/popdowns')
-rw-r--r--src/modules/popdowns/bluetoothdevices.tsx93
-rw-r--r--src/modules/popdowns/index.tsx2
-rw-r--r--src/modules/popdowns/notifications.tsx2
3 files changed, 96 insertions, 1 deletions
diff --git a/src/modules/popdowns/bluetoothdevices.tsx b/src/modules/popdowns/bluetoothdevices.tsx
new file mode 100644
index 0000000..f41516a
--- /dev/null
+++ b/src/modules/popdowns/bluetoothdevices.tsx
@@ -0,0 +1,93 @@
+import { bind, Variable } from "astal";
+import { Gtk } from "astal/gtk3";
+import AstalBluetooth from "gi://AstalBluetooth";
+import PopdownWindow from "../../widgets/popdownwindow";
+
+const BluetoothDevice = (device: AstalBluetooth.Device) => (
+ <box className="device">
+ <icon className="icon" icon={bind(device, "icon").as(i => `${i}-symbolic`)} />
+ <label
+ truncate
+ xalign={0}
+ setup={self => {
+ const update = () =>
+ (self.label = `${device.alias}${
+ device.connected || device.paired ? ` (${device.connected ? "Connected" : "Paired"})` : ""
+ }`);
+ self.hook(device, "notify::alias", update);
+ self.hook(device, "notify::connected", update);
+ self.hook(device, "notify::paired", update);
+ update();
+ }}
+ />
+ <box hexpand />
+ <button
+ cursor="pointer"
+ onClicked={self => {
+ if (device.connected)
+ device.disconnect_device((_, res) => {
+ self.sensitive = true;
+ device.disconnect_device_finish(res);
+ });
+ else
+ device.connect_device((_, res) => {
+ self.sensitive = true;
+ device.connect_device_finish(res);
+ });
+ self.sensitive = false;
+ }}
+ label={bind(device, "connected").as(c => (c ? "Disconnect" : "Connect"))}
+ />
+ <button
+ cursor="pointer"
+ onClicked={() => AstalBluetooth.get_default().adapter.remove_device(device)}
+ label="Remove"
+ />
+ </box>
+);
+
+const List = () => (
+ <box vertical valign={Gtk.Align.START} className="list">
+ {bind(AstalBluetooth.get_default(), "devices").as(d => d.map(BluetoothDevice))}
+ </box>
+);
+
+export default () => {
+ const bluetooth = AstalBluetooth.get_default();
+ const label = Variable("");
+
+ const update = () => {
+ const devices = bluetooth.get_devices();
+ const connected = devices.filter(d => d.connected).length;
+ label.set(`${connected} connected device${connected === 1 ? "" : "s"} (${devices.length} available)`);
+ };
+ bluetooth.get_devices().forEach(d => d.connect("notify::connected", update));
+ bluetooth.connect("device-added", (_, device) => device.connect("notify::connected", update));
+ bluetooth.connect("notify::devices", update);
+ update();
+
+ return (
+ <PopdownWindow
+ name="bluetooth-devices"
+ count={bind(bluetooth, "devices").as(n => n.length)}
+ countLabel={bind(label)}
+ headerButtons={[
+ {
+ label: bind(bluetooth, "isPowered").as(p => (p ? "Disable" : "Enable")),
+ onClicked: () => bluetooth.toggle(),
+ },
+ {
+ label: "Discovery",
+ onClicked: () => {
+ if (bluetooth.adapter.discovering) bluetooth.adapter.start_discovery();
+ else bluetooth.adapter.stop_discovery();
+ },
+ enabled: bind(bluetooth.adapter, "discovering"),
+ },
+ ]}
+ emptyIcon="bluetooth_disabled"
+ emptyLabel="No Bluetooth devices"
+ list={<List />}
+ />
+ );
+};
diff --git a/src/modules/popdowns/index.tsx b/src/modules/popdowns/index.tsx
index db3245b..ee6208d 100644
--- a/src/modules/popdowns/index.tsx
+++ b/src/modules/popdowns/index.tsx
@@ -1,9 +1,11 @@
+import BluetoothDevices from "./bluetoothdevices";
import Notifications from "./notifications";
import Updates from "./updates";
export default () => {
<Notifications />;
<Updates />;
+ <BluetoothDevices />;
return null;
};
diff --git a/src/modules/popdowns/notifications.tsx b/src/modules/popdowns/notifications.tsx
index bb08c13..4ab0095 100644
--- a/src/modules/popdowns/notifications.tsx
+++ b/src/modules/popdowns/notifications.tsx
@@ -51,7 +51,7 @@ export default () => (
{
label: "Silence",
onClicked: () => (AstalNotifd.get_default().dontDisturb = !AstalNotifd.get_default().dontDisturb),
- className: bind(AstalNotifd.get_default(), "dontDisturb").as(d => (d ? "enabled" : "")),
+ enabled: bind(AstalNotifd.get_default(), "dontDisturb"),
},
{
label: "Clear",