summaryrefslogtreecommitdiff
path: root/src/modules
diff options
context:
space:
mode:
author2 * r + 2 * t <61896496+soramanew@users.noreply.github.com>2025-01-17 00:16:40 +1100
committer2 * r + 2 * t <61896496+soramanew@users.noreply.github.com>2025-01-17 00:16:40 +1100
commit0518ec4214583bcc26f5b052f02fd93b12a00a77 (patch)
tree0cfac1c39d54a504215a4b98c8be271e66759295 /src/modules
parentrefactor: move popdowns to own folder (diff)
downloadcaelestia-shell-0518ec4214583bcc26f5b052f02fd93b12a00a77.tar.gz
caelestia-shell-0518ec4214583bcc26f5b052f02fd93b12a00a77.tar.bz2
caelestia-shell-0518ec4214583bcc26f5b052f02fd93b12a00a77.zip
bluetoothdevices: make popup window
Diffstat (limited to 'src/modules')
-rw-r--r--src/modules/bar.tsx37
-rw-r--r--src/modules/popdowns/bluetoothdevices.tsx93
-rw-r--r--src/modules/popdowns/index.tsx2
-rw-r--r--src/modules/popdowns/notifications.tsx2
4 files changed, 111 insertions, 23 deletions
diff --git a/src/modules/bar.tsx b/src/modules/bar.tsx
index 1bcbc08..0bc4485 100644
--- a/src/modules/bar.tsx
+++ b/src/modules/bar.tsx
@@ -36,6 +36,14 @@ const hookFocusedClientProp = (
callback(lastClient);
};
+const togglePopup = (self: JSX.Element, event: Astal.ClickEvent, name: string) => {
+ const popup = App.get_window(name) as PopupWindow | null;
+ if (popup) {
+ if (popup.visible) popup.hide();
+ else popup.popup_at_widget(self, event);
+ }
+};
+
const OSIcon = () => <label className="module os-icon" label={osIcon} />;
const ActiveWindow = () => (
@@ -315,10 +323,9 @@ const Network = () => (
const Bluetooth = () => (
<button
- onClick={(_, event) => {
- if (event.button === Astal.MouseButton.PRIMARY) {
- // TODO: bluetooth panel
- } else if (event.button === Astal.MouseButton.SECONDARY) AstalBluetooth.get_default().toggle();
+ onClick={(self, event) => {
+ if (event.button === Astal.MouseButton.PRIMARY) togglePopup(self, event, "bluetooth-devices");
+ else if (event.button === Astal.MouseButton.SECONDARY) AstalBluetooth.get_default().toggle();
else if (event.button === Astal.MouseButton.MIDDLE)
execAsync("uwsm app -- blueman-manager").catch(console.error);
}}
@@ -366,15 +373,7 @@ const StatusIcons = () => (
const PkgUpdates = () => (
<button
- onClick={(self, event) => {
- if (event.button === Astal.MouseButton.PRIMARY) {
- const popup = App.get_window("updates") as PopupWindow | null;
- if (popup) {
- if (popup.visible) popup.hide();
- else popup.popup_at_widget(self, event);
- }
- }
- }}
+ onClick={(self, event) => event.button === Astal.MouseButton.PRIMARY && togglePopup(self, event, "updates")}
setup={self =>
setupCustomTooltip(
self,
@@ -391,15 +390,9 @@ const PkgUpdates = () => (
const NotifCount = () => (
<button
- onClick={(self, event) => {
- if (event.button === Astal.MouseButton.PRIMARY) {
- const popup = App.get_window("notifications") as PopupWindow | null;
- if (popup) {
- if (popup.visible) popup.hide();
- else popup.popup_at_widget(self, event);
- }
- }
- }}
+ onClick={(self, event) =>
+ event.button === Astal.MouseButton.PRIMARY && togglePopup(self, event, "notifications")
+ }
setup={self =>
setupCustomTooltip(
self,
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",