simplify bluetooth entry

This commit is contained in:
takotori 2023-12-06 19:48:54 +01:00
parent 8518d6e247
commit 0184fba8b4
5 changed files with 30 additions and 147 deletions

View file

@ -295,13 +295,15 @@ pub fn start_bluetooth_listener(listeners: Arc<Listeners>, bluetooth_box: Arc<Bl
list_entry
.0
.imp()
.reset_bluetooth_button
.button
.borrow()
.set_sensitive(true);
} else {
list_entry
.0
.imp()
.reset_bluetooth_button
.button
.borrow()
.set_sensitive(false);
}
}

View file

@ -1,20 +1,22 @@
use std::ops::Deref;
use std::sync::Arc;
use std::time::Duration;
use crate::components::bluetooth::bluetooth_entry_impl;
use adw::glib::Object;
use adw::subclass::prelude::ObjectSubclassIsExt;
use adw::{glib, ActionRow};
use adw::prelude::{ActionRowExt, PreferencesRowExt};
use dbus::blocking::Connection;
use dbus::{Error, Path};
use glib::subclass::prelude::ObjectSubclassIsExt;
use gtk::prelude::{ButtonExt, ListBoxRowExt, WidgetExt};
use gtk::{gio, GestureClick};
use gtk::{gio, GestureClick, Image, Button, Align};
use re_set_lib::bluetooth::bluetooth_structures::BluetoothDevice;
glib::wrapper! {
pub struct BluetoothEntry(ObjectSubclass<bluetooth_entry_impl::BluetoothEntry>)
@extends ActionRow, gtk::Widget,
@implements gtk::Accessible, gtk::Buildable, gtk::Actionable, gtk::ConstraintTarget, gtk::ListBoxRow;
@implements gtk::Accessible, gtk::Buildable, gtk::Actionable, gtk::ConstraintTarget, gtk::ListBoxRow, adw::PreferencesRow;
}
unsafe impl Send for BluetoothEntry {}
@ -24,31 +26,25 @@ impl BluetoothEntry {
pub fn new(device: &BluetoothDevice) -> Self {
let entry: BluetoothEntry = Object::builder().build();
let entry_imp = entry.imp();
entry_imp
.reset_bluetooth_label
.get()
.set_text(&device.alias);
entry_imp
.reset_bluetooth_address
.get()
.set_text(&device.address);
entry.set_title(&device.alias);
entry.set_subtitle(&device.address);
entry.set_activatable(true);
entry_imp.button.replace(Button::builder().icon_name("user-trash-symbolic").valign(Align::Center).build());
entry.add_suffix(entry_imp.button.borrow().deref());
if device.icon.is_empty() {
entry_imp
.reset_bluetooth_device_type
.set_icon_name(Some("dialog-question-symbolic"));
entry.add_prefix(&Image::from_icon_name("dialog-question-symbolic"));
} else {
entry_imp
.reset_bluetooth_device_type
.set_icon_name(Some(&device.icon));
entry.add_prefix(&Image::from_icon_name(&device.icon));
}
if device.connected || device.paired {
entry_imp.reset_bluetooth_button.set_sensitive(true);
entry_imp.button.borrow().set_sensitive(true);
} else {
entry_imp.reset_bluetooth_button.set_sensitive(false);
entry_imp.button.borrow().set_sensitive(false);
}
let path = Arc::new(device.path.clone());
entry_imp.reset_bluetooth_button.connect_clicked(move |_| {
entry_imp.button.borrow().connect_clicked(move |_| {
remove_device_pairing((*path).clone());
});
let gesture = GestureClick::new();

View file

@ -3,20 +3,13 @@ use adw::subclass::action_row::ActionRowImpl;
use adw::subclass::preferences_row::PreferencesRowImpl;
use adw::ActionRow;
use gtk::subclass::prelude::*;
use gtk::{glib, Button, CompositeTemplate, Image, Label};
use gtk::{glib, Button, CompositeTemplate};
use std::cell::RefCell;
#[derive(Default, CompositeTemplate)]
#[template(resource = "/org/Xetibo/ReSet/resetBluetoothEntry.ui")]
pub struct BluetoothEntry {
#[template_child]
pub reset_bluetooth_device_type: TemplateChild<Image>,
#[template_child]
pub reset_bluetooth_label: TemplateChild<Label>,
#[template_child]
pub reset_bluetooth_address: TemplateChild<Label>,
#[template_child]
pub reset_bluetooth_button: TemplateChild<Button>,
pub button: RefCell<Button>,
pub device_name: RefCell<String>,
}

View file

@ -1,63 +1,8 @@
<?xml version='1.0' encoding='UTF-8'?>
<!-- Created with Cambalache 0.17.0 -->
<interface>
<requires lib="gtk" version="4.12"/>
<requires lib="libadwaita" version="1.0"/>
<template class="resetBluetoothEntry" parent="AdwActionRow">
<property name="child">
<object class="GtkBox">
<child>
<object class="GtkImage" id="reset_bluetooth_device_type">
<property name="halign">start</property>
<property name="icon-name">input-mouse-symbolic</property>
<property name="margin-end">15</property>
</object>
</child>
<child>
<object class="GtkBox">
<property name="hexpand">True</property>
<property name="hexpand-set">True</property>
<property name="orientation">vertical</property>
<child>
<object class="GtkLabel" id="reset_bluetooth_label">
<property name="ellipsize">end</property>
<property name="hexpand">True</property>
<property name="hexpand-set">True</property>
<property name="label">LoremIpsum Wireless Mouse</property>
<property name="margin-end">10</property>
<property name="single-line-mode">True</property>
<property name="vexpand">True</property>
<property name="vexpand-set">True</property>
<property name="width-request">200</property>
<property name="xalign">0.0</property>
</object>
</child>
<child>
<object class="GtkLabel" id="reset_bluetooth_address">
<property name="ellipsize">end</property>
<property name="hexpand">True</property>
<property name="hexpand-set">True</property>
<property name="label">LoremIpsum Wireless Mouse</property>
<property name="margin-end">10</property>
<property name="sensitive">False</property>
<property name="single-line-mode">True</property>
<property name="vexpand">True</property>
<property name="vexpand-set">True</property>
<property name="width-request">200</property>
<property name="xalign">0.0</property>
</object>
</child>
</object>
</child>
<child>
<object class="GtkButton" id="reset_bluetooth_button">
<property name="halign">end</property>
<property name="has-frame">False</property>
<property name="icon-name">user-trash-symbolic</property>
</object>
</child>
</object>
</property>
<property name="margin-start">5</property>
</template>
</interface>

View file

@ -9,7 +9,7 @@
(7,14,None,"resetInputStreamEntry.ui",None,None,None,None,None,None,None),
(8,1,None,"resetAudioOutput.ui",None,None,None,None,None,None,None),
(10,1,None,"resetBluetooth.ui",None,None,None,None,None,None,None),
(11,32,None,"resetBluetoothEntry.ui",None,None,None,None,None,None,None),
(11,1,None,"resetBluetoothEntry.ui",None,None,None,None,None,None,None),
(12,11,None,"resetAudioInput.ui",None,None,None,None,None,None,None),
(13,22,None,"resetOutputStreamEntry.ui",None,None,None,None,None,None,None),
(14,3,None,"resetSettingBox.ui",None,None,None,None,None,None,None),
@ -158,13 +158,7 @@
(10,204,"AdwPreferencesGroup","reset_bluetooth_available_devices",121,None,None,None,1,None),
(10,206,"AdwPreferencesGroup","reset_bluetooth_connected_devices",121,None,None,None,2,None),
(10,207,"GtkButton","reset_bluetooth_refresh_button",204,None,None,None,-1,None),
(11,32,"AdwActionRow","resetBluetoothEntry",None,None,None,None,-1,None),
(11,39,"GtkBox",None,32,None,None,None,-1,None),
(11,40,"GtkImage","reset_bluetooth_device_type",39,None,None,None,None,None),
(11,44,"GtkButton","reset_bluetooth_button",39,None,None,None,3,None),
(11,47,"GtkBox",None,39,None,None,None,2,None),
(11,48,"GtkLabel","reset_bluetooth_label",47,None,None,None,None,None),
(11,49,"GtkLabel","reset_bluetooth_address",47,None,None,None,1,None),
(11,1,"AdwActionRow","resetBluetoothEntry",None,None,None,None,None,None),
(12,11,"GtkBox","resetAudioInput",None,None,None,None,None,None),
(12,12,"GtkLabel",None,11,None,None,None,None,None),
(12,13,"AdwNavigationView",None,11,None,None,None,1,None),
@ -315,16 +309,8 @@
(23,9,"GtkBox",None,2,None,None,None,None,None),
(23,10,"AdwEntryRow","reset_route_address",9,None,None,None,None,None),
(23,11,"AdwEntryRow","reset_route_prefix",9,None,None,None,1,None),
(24,1,"AdwPreferencesGroup",None,None,None,None,None,-1,None),
(24,4,"GtkButton",None,1,None,None,None,-1,None),
(24,5,"GtkScrolledWindow",None,1,None,None,None,None,None),
(24,6,"GtkViewport",None,5,None,None,None,None,None),
(24,9,"GtkBox",None,6,None,None,None,None,None),
(24,10,"AdwActionRow",None,9,None,None,None,None,None),
(24,11,"AdwActionRow",None,9,None,None,None,1,None),
(24,12,"AdwActionRow",None,9,None,None,None,2,None),
(24,13,"AdwActionRow",None,9,None,None,None,3,None),
(24,14,"AdwActionRow",None,9,None,None,None,4,None)
(24,1,"AdwActionRow","resetBluetoothEntry",None,None,None,None,None,None),
(24,2,"GtkButton",None,1,None,None,None,-1,None)
</object>
<object_property>
(3,1,"GtkWidget","height-request","200",None,None,None,None,None,None,None,None,None),
@ -598,38 +584,7 @@
(10,206,"GtkWidget","margin-start","5",None,None,None,None,None,None,None,None,None),
(10,206,"GtkWidget","margin-top","5",None,None,None,None,None,None,None,None,None),
(10,207,"GtkButton","icon-name","view-refresh-symbolic",None,None,None,None,None,None,None,None,None),
(11,32,"GtkListBoxRow","child",None,None,None,None,None,39,None,None,None,None),
(11,32,"GtkWidget","margin-start","5",None,None,None,None,None,None,None,None,None),
(11,40,"GtkImage","icon-name","input-mouse-symbolic",None,None,None,None,None,None,None,None,None),
(11,40,"GtkWidget","halign","start",None,None,None,None,None,None,None,None,None),
(11,40,"GtkWidget","margin-end","15",None,None,None,None,None,None,None,None,None),
(11,44,"GtkButton","has-frame","False",None,None,None,None,None,None,None,None,None),
(11,44,"GtkButton","icon-name","user-trash-symbolic",None,None,None,None,None,None,None,None,None),
(11,44,"GtkWidget","halign","end",None,None,None,None,None,None,None,None,None),
(11,47,"GtkOrientable","orientation","vertical",None,None,None,None,None,None,None,None,None),
(11,47,"GtkWidget","hexpand","True",None,None,None,None,None,None,None,None,None),
(11,47,"GtkWidget","hexpand-set","True",None,None,None,None,None,None,None,None,None),
(11,48,"GtkLabel","ellipsize","end",None,None,None,None,None,None,None,None,None),
(11,48,"GtkLabel","label","LoremIpsum Wireless Mouse",None,None,None,None,None,None,None,None,None),
(11,48,"GtkLabel","single-line-mode","True",None,None,None,None,None,None,None,None,None),
(11,48,"GtkLabel","xalign","0.0",None,None,None,None,None,None,None,None,None),
(11,48,"GtkWidget","hexpand","True",None,None,None,None,None,None,None,None,None),
(11,48,"GtkWidget","hexpand-set","True",None,None,None,None,None,None,None,None,None),
(11,48,"GtkWidget","margin-end","10",None,None,None,None,None,None,None,None,None),
(11,48,"GtkWidget","vexpand","True",None,None,None,None,None,None,None,None,None),
(11,48,"GtkWidget","vexpand-set","True",None,None,None,None,None,None,None,None,None),
(11,48,"GtkWidget","width-request","200",None,None,None,None,None,None,None,None,None),
(11,49,"GtkLabel","ellipsize","end",None,None,None,None,None,None,None,None,None),
(11,49,"GtkLabel","label","LoremIpsum Wireless Mouse",None,None,None,None,None,None,None,None,None),
(11,49,"GtkLabel","single-line-mode","True",None,None,None,None,None,None,None,None,None),
(11,49,"GtkLabel","xalign","0.0",None,None,None,None,None,None,None,None,None),
(11,49,"GtkWidget","hexpand","True",None,None,None,None,None,None,None,None,None),
(11,49,"GtkWidget","hexpand-set","True",None,None,None,None,None,None,None,None,None),
(11,49,"GtkWidget","margin-end","10",None,None,None,None,None,None,None,None,None),
(11,49,"GtkWidget","sensitive","False",None,None,None,None,None,None,None,None,None),
(11,49,"GtkWidget","vexpand","True",None,None,None,None,None,None,None,None,None),
(11,49,"GtkWidget","vexpand-set","True",None,None,None,None,None,None,None,None,None),
(11,49,"GtkWidget","width-request","200",None,None,None,None,None,None,None,None,None),
(11,1,"GtkWidget","margin-start","5",None,None,None,None,None,None,None,None,None),
(12,11,"GtkOrientable","orientation","vertical",None,None,None,None,None,None,None,None,None),
(12,11,"GtkWidget","valign","start",None,None,None,None,None,None,None,None,None),
(12,12,"GtkLabel","label","Input",None,None,None,None,None,None,None,None,None),
@ -903,17 +858,9 @@
(23,10,"GtkWidget","hexpand","True",None,None,None,None,None,None,None,None,None),
(23,11,"AdwPreferencesRow","title","Prefix",None,None,None,None,None,None,None,None,None),
(23,11,"GtkEditable","max-width-chars","5",None,None,None,None,None,None,None,None,None),
(24,1,"AdwPreferencesGroup","header-suffix",None,None,None,None,None,4,None,None,None,None),
(24,1,"AdwPreferencesGroup","title","Available Devices",None,None,None,None,None,None,None,None,None),
(24,4,"GtkButton","icon-name","view-refresh-symbolic",None,None,None,None,None,None,None,None,None),
(24,5,"GtkScrolledWindow","min-content-height","100",None,None,None,None,None,None,None,None,None),
(24,5,"GtkScrolledWindow","propagate-natural-height","True",None,None,None,None,None,None,None,None,None),
(24,9,"GtkOrientable","orientation","vertical",None,None,None,None,None,None,None,None,None),
(24,10,"AdwPreferencesRow","title","device 2",None,None,None,None,None,None,None,None,None),
(24,11,"AdwPreferencesRow","title","device 1",None,None,None,None,None,None,None,None,None),
(24,12,"AdwPreferencesRow","title","device 2",None,None,None,None,None,None,None,None,None),
(24,13,"AdwPreferencesRow","title","device 2",None,None,None,None,None,None,None,None,None),
(24,14,"AdwPreferencesRow","title","device 2",None,None,None,None,None,None,None,None,None)
(24,1,"GtkWidget","margin-start","5",None,None,None,None,None,None,None,None,None),
(24,2,"GtkButton","icon-name","user-trash-symbolic",None,None,None,None,None,None,None,None,None),
(24,2,"GtkWidget","valign","center",None,None,None,None,None,None,None,None,None)
</object_property>
<object_data>
(3,42,"GtkWidget",1,1,None,None,None,None,None,None),