Finish up LabeledItem
This commit is contained in:
parent
6ec9e8037c
commit
fad8689dc6
2 changed files with 85 additions and 24 deletions
|
|
@ -1,5 +1,6 @@
|
||||||
use gtk4::{prelude::*, Align, Label, Orientation, Widget};
|
use gtk4::{prelude::*, Align, Label, Orientation, Widget};
|
||||||
use relm4::{ComponentParts, Sender, SimpleComponent};
|
use relm4::{ComponentBuilder, ComponentParts, Sender, SimpleComponent};
|
||||||
|
use std::cell::RefCell;
|
||||||
|
|
||||||
#[derive(Debug)]
|
#[derive(Debug)]
|
||||||
pub enum LabeledItemMessage {
|
pub enum LabeledItemMessage {
|
||||||
|
|
@ -10,14 +11,64 @@ pub enum LabeledItemMessage {
|
||||||
}
|
}
|
||||||
|
|
||||||
#[track]
|
#[track]
|
||||||
struct LabeledItem {
|
pub struct LabeledItem {
|
||||||
title: String,
|
_title: String,
|
||||||
desc: Option<String>,
|
_desc: Option<String>,
|
||||||
align: Align,
|
_align: Align,
|
||||||
child: Option<Widget>,
|
_child: Option<Widget>,
|
||||||
|
#[do_not_track]
|
||||||
|
_remove_child: RefCell<Option<Widget>>,
|
||||||
|
#[do_not_track]
|
||||||
|
_sender: Sender<LabeledItemMessage>,
|
||||||
}
|
}
|
||||||
|
|
||||||
#[component]
|
impl LabeledItem {
|
||||||
|
pub fn new() -> ComponentBuilder<Self, gtk4::Box> {
|
||||||
|
Self::init()
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn title(&self) -> &str {
|
||||||
|
&self._title
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn description(&self) -> &str {
|
||||||
|
&self._title
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn alignment(&self) -> Align {
|
||||||
|
self._align
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn child(&self) -> Option<&Widget> {
|
||||||
|
self._child.as_ref()
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn set_title<S>(&self, title: S)
|
||||||
|
where
|
||||||
|
S: ToString,
|
||||||
|
{
|
||||||
|
self._sender
|
||||||
|
.send(LabeledItemMessage::Title(title.to_string()));
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn set_description<S>(&self, title: Option<S>)
|
||||||
|
where
|
||||||
|
S: ToString,
|
||||||
|
{
|
||||||
|
self._sender
|
||||||
|
.send(LabeledItemMessage::Desc(title.map(|s| s.to_string())));
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn set_alignment(&self, align: Align) {
|
||||||
|
self._sender.send(LabeledItemMessage::Align(align));
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn set_child(&self, child: Widget) {
|
||||||
|
self._sender.send(LabeledItemMessage::Child(child));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
#[component(pub)]
|
||||||
impl SimpleComponent for LabeledItem {
|
impl SimpleComponent for LabeledItem {
|
||||||
type Widgets = AppWidgets;
|
type Widgets = AppWidgets;
|
||||||
type InitParams = ();
|
type InitParams = ();
|
||||||
|
|
@ -43,13 +94,13 @@ impl SimpleComponent for LabeledItem {
|
||||||
&Label {
|
&Label {
|
||||||
add_css_class: "labeled-item-title",
|
add_css_class: "labeled-item-title",
|
||||||
set_halign: Align::Start,
|
set_halign: Align::Start,
|
||||||
set_label: watch! { &model.title }
|
set_label: watch! { &model._title }
|
||||||
},
|
},
|
||||||
&Label {
|
&Label {
|
||||||
add_css_class: "labeled-item-desc",
|
add_css_class: "labeled-item-desc",
|
||||||
set_halign: Align::Start,
|
set_halign: Align::Start,
|
||||||
set_visible: watch! { model.desc.is_some() },
|
set_visible: watch! { model._desc.is_some() },
|
||||||
set_label: watch! { &model.desc.clone().unwrap_or_default() }
|
set_label: watch! { &model._desc.clone().unwrap_or_default() }
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
@ -58,14 +109,16 @@ impl SimpleComponent for LabeledItem {
|
||||||
fn init_parts(
|
fn init_parts(
|
||||||
_init_params: Self::InitParams,
|
_init_params: Self::InitParams,
|
||||||
root: &Self::Root,
|
root: &Self::Root,
|
||||||
_input: &Sender<Self::Input>,
|
input: &Sender<Self::Input>,
|
||||||
_output: &Sender<Self::Output>,
|
_output: &Sender<Self::Output>,
|
||||||
) -> ComponentParts<Self, Self::Widgets> {
|
) -> ComponentParts<Self, Self::Widgets> {
|
||||||
let model = LabeledItem {
|
let model = LabeledItem {
|
||||||
title: String::default(),
|
_title: String::default(),
|
||||||
desc: None,
|
_desc: None,
|
||||||
align: Align::Start,
|
_align: Align::Start,
|
||||||
child: None,
|
_child: None,
|
||||||
|
_remove_child: RefCell::new(None),
|
||||||
|
_sender: input.clone(),
|
||||||
tracker: 0,
|
tracker: 0,
|
||||||
};
|
};
|
||||||
let widgets = view_output!();
|
let widgets = view_output!();
|
||||||
|
|
@ -81,21 +134,27 @@ impl SimpleComponent for LabeledItem {
|
||||||
) {
|
) {
|
||||||
self.reset();
|
self.reset();
|
||||||
match msg {
|
match msg {
|
||||||
LabeledItemMessage::Title(title) => self.set_title(title),
|
LabeledItemMessage::Title(title) => self.set__title(title),
|
||||||
LabeledItemMessage::Desc(desc) => self.set_desc(desc),
|
LabeledItemMessage::Desc(desc) => self.set__desc(desc),
|
||||||
LabeledItemMessage::Align(align) => self.set_align(align),
|
LabeledItemMessage::Align(align) => self.set__align(align),
|
||||||
LabeledItemMessage::Child(child) => self.set_child(Some(child)),
|
LabeledItemMessage::Child(child) => {
|
||||||
|
*self._remove_child.borrow_mut() = self._child.take();
|
||||||
|
self.set__child(Some(child))
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
fn post_view() {
|
fn post_view() {
|
||||||
if self.changed(LabeledItem::child()) {
|
if let Some(child) = self._remove_child.borrow_mut().take() {
|
||||||
let child = self.child.as_ref().expect("there's no child??");
|
widgets.base_box.remove(&child);
|
||||||
|
}
|
||||||
|
if self.changed(LabeledItem::_child()) {
|
||||||
|
let child = self._child.as_ref().expect("there's no child??");
|
||||||
widgets.base_box.append(child);
|
widgets.base_box.append(child);
|
||||||
}
|
}
|
||||||
if self.changed(LabeledItem::align()) {
|
if self.changed(LabeledItem::_align()) {
|
||||||
let child = self.child.as_ref().expect("set alignment without child");
|
let child = self._child.as_ref().expect("set alignment without child");
|
||||||
match self.align {
|
match self._align {
|
||||||
Align::Start => {
|
Align::Start => {
|
||||||
widgets
|
widgets
|
||||||
.base_box
|
.base_box
|
||||||
|
|
|
||||||
|
|
@ -4,3 +4,5 @@ extern crate relm4_macros;
|
||||||
extern crate tracker;
|
extern crate tracker;
|
||||||
|
|
||||||
pub mod labeled_item;
|
pub mod labeled_item;
|
||||||
|
|
||||||
|
pub use labeled_item::LabeledItem;
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue