diff options
-rw-r--r-- | src/components/post_editor.rs | 274 | ||||
-rw-r--r-- | src/lib.rs | 2 | ||||
-rw-r--r-- | src/widgets.rs | 30 |
3 files changed, 149 insertions, 157 deletions
diff --git a/src/components/post_editor.rs b/src/components/post_editor.rs index be17251..56d2d94 100644 --- a/src/components/post_editor.rs +++ b/src/components/post_editor.rs @@ -120,149 +120,171 @@ impl<E: std::error::Error + std::fmt::Debug + 'static> Component for PostEditor< #[name = "content_wrapper"] adw::BreakpointBin { set_width_request: 360, - set_height_request: 480, - - #[name = "content"] - gtk::Box { - set_orientation: gtk::Orientation::Vertical, - set_spacing: 5, - set_margin_all: 5, - - #[name = "name_label"] - gtk::Label { - set_markup: "Name", - set_margin_vertical: 10, - set_margin_horizontal: 10, - set_halign: gtk::Align::Start, - set_valign: gtk::Align::Start, - }, - #[name = "name_field"] - gtk::Entry { - set_hexpand: true, - set_buffer: &model.name_buffer, - #[track = "model.changed(Self::sending())"] - set_sensitive: !model.sending, - }, + set_height_request: 200, - #[name = "summary_label"] - gtk::Label { - set_markup: "Summary", - set_margin_vertical: 10, - set_margin_horizontal: 10, - set_halign: gtk::Align::Start, - set_valign: gtk::Align::Start, - }, - #[name = "summary_field"] + gtk::ScrolledWindow { + #[name = "content"] gtk::Box { - set_orientation: gtk::Orientation::Horizontal, - add_css_class: "linked", - + set_orientation: gtk::Orientation::Vertical, + set_spacing: 5, + set_margin_all: 5, + + #[name = "name_label"] + gtk::Label { + set_markup: "Name", + set_margin_vertical: 10, + set_margin_horizontal: 10, + set_halign: gtk::Align::Start, + set_valign: gtk::Align::Start, + }, + #[name = "name_field"] gtk::Entry { set_hexpand: true, - set_buffer: &model.summary_buffer, - #[track = "model.busy_changed()"] - set_sensitive: !model.busy(), + set_buffer: &model.name_buffer, + #[track = "model.changed(Self::sending())"] + set_sensitive: !model.sending, }, - model.smart_summary.widget(), - }, + #[name = "summary_label"] + gtk::Label { + set_markup: "Summary", + set_margin_vertical: 10, + set_margin_horizontal: 10, + set_halign: gtk::Align::Start, + set_valign: gtk::Align::Start, + }, + #[name = "summary_field"] + gtk::Box { + set_orientation: gtk::Orientation::Horizontal, + add_css_class: "linked", - #[name = "tag_label"] - gtk::Label { - set_markup: "Tags", - set_margin_vertical: 10, - set_margin_horizontal: 10, - set_halign: gtk::Align::Start, - set_valign: gtk::Align::Start, - }, - #[name = "tag_holder"] - // TODO: tag component (because of complex logic) - gtk::Box { - add_css_class: "frame", - set_hexpand: true, - set_orientation: gtk::Orientation::Horizontal, - set_spacing: 5, - set_height_request: 36, - }, + gtk::Entry { + set_hexpand: true, + set_buffer: &model.summary_buffer, + #[track = "model.busy_changed()"] + set_sensitive: !model.busy(), + }, + model.smart_summary.widget(), + }, - #[name = "content_label"] - gtk::Label { - set_markup: "Content", - set_halign: gtk::Align::Start, - set_valign: gtk::Align::Start, - set_margin_vertical: 10, - set_margin_horizontal: 10, - }, + #[name = "tag_label"] + gtk::Label { + set_markup: "Tags", + set_margin_vertical: 10, + set_margin_horizontal: 10, + set_halign: gtk::Align::Start, + set_valign: gtk::Align::Start, + }, + #[name = "tag_holder"] + gtk::Box { + set_hexpand: true, + set_orientation: gtk::Orientation::Vertical, + set_spacing: 5, + set_height_request: 36, + + gtk::Box { + add_css_class: "linked", + set_orientation: gtk::Orientation::Horizontal, + + #[name = "pending_tag_entry"] + gtk::Entry { + set_hexpand: true, + set_width_request: 200, + #[track = "model.changed(Self::sending())"] + set_sensitive: !model.sending, + }, + gtk::Button { + set_icon_name: "plus-symbolic", + add_css_class: "suggested-action", + } + }, - #[name = "content_textarea"] - gtk::ScrolledWindow { - set_vexpand: true, - gtk::TextView { - set_buffer: Some(&model.content_buffer), - set_hexpand: true, - #[iterate] - add_css_class: &["frame", "view"], - set_monospace: true, - set_wrap_mode: gtk::WrapMode::Word, - set_vscroll_policy: gtk::ScrollablePolicy::Natural, + #[name = "content_label"] + gtk::Label { + set_markup: "Content", + set_halign: gtk::Align::Start, + set_valign: gtk::Align::Start, + set_margin_vertical: 10, + set_margin_horizontal: 10, + }, - set_left_margin: 8, - set_right_margin: 8, - set_top_margin: 8, - set_bottom_margin: 8, + #[name = "content_textarea_wrapper"] + gtk::ScrolledWindow { + set_vexpand: true, + set_height_request: 200, + #[name = "content_textarea"] + gtk::TextView { + set_buffer: Some(&model.content_buffer), + set_hexpand: true, + #[iterate] + add_css_class: &["frame", "view"], + + set_monospace: true, + set_wrap_mode: gtk::WrapMode::Word, + set_vscroll_policy: gtk::ScrollablePolicy::Natural, + + set_left_margin: 8, + set_right_margin: 8, + set_top_margin: 8, + set_bottom_margin: 8, + + #[track = "model.changed(Self::sending())"] + set_sensitive: !model.sending + } + }, - #[track = "model.changed(Self::sending())"] - set_sensitive: !model.sending - } - }, + #[name = "misc_prop_wrapper"] + gtk::Box { + set_hexpand: true, - #[name = "misc_prop_wrapper"] - gtk::Box { - set_hexpand: true, + gtk::FlowBox { + set_hexpand: false, + set_orientation: gtk::Orientation::Horizontal, + set_homogeneous: false, + set_column_spacing: 0, + set_min_children_per_line: 2, + set_max_children_per_line: 6, + set_selection_mode: gtk::SelectionMode::None, - gtk::FlowBox { - set_hexpand: false, - set_orientation: gtk::Orientation::Horizontal, - set_homogeneous: false, - set_column_spacing: 0, - set_min_children_per_line: 2, - set_max_children_per_line: 6, - set_selection_mode: gtk::SelectionMode::None, - - append = >k::Box { - set_spacing: 5, - - #[name = "visibility_label"] - gtk::Label { - set_markup: "Visibility", + append = >k::FlowBoxChild { set_halign: gtk::Align::Start, - set_valign: gtk::Align::Start, - set_margin_vertical: 10, - set_margin_horizontal: 10, - }, - #[name = "visibility_selector"] - gtk::DropDown { - set_model: Some(&visibility_model), - set_hexpand: false, - - #[track = "model.changed(Self::sending())"] - set_sensitive: !model.sending, - connect_selected_item_notify[sender] => move |w| { - if let Some(obj) = w.selected_item() { - let v = obj.downcast::<adw::EnumListItem>() - .unwrap() - .value(); - let v = glib::EnumClass::new::<Visibility>() - .to_value(v) - .unwrap() - .get() - .unwrap(); - sender.input(Self::Input::VisibilitySelected(v)); - } + gtk::Box { + set_spacing: 5, + + #[name = "visibility_label"] + gtk::Label { + set_markup: "Visibility", + set_halign: gtk::Align::Start, + set_valign: gtk::Align::Start, + set_margin_vertical: 10, + set_margin_horizontal: 10, + }, + #[name = "visibility_selector"] + gtk::DropDown { + set_model: Some(&visibility_model), + set_hexpand: false, + + #[track = "model.changed(Self::sending())"] + set_sensitive: !model.sending, + + connect_selected_item_notify[sender] => move |w| { + if let Some(obj) = w.selected_item() { + let v = obj.downcast::<adw::EnumListItem>() + .unwrap() + .value(); + let v = glib::EnumClass::new::<Visibility>() + .to_value(v) + .unwrap() + .get() + .unwrap(); + sender.input(Self::Input::VisibilitySelected(v)); + } + }, + }, }, }, }, @@ -355,7 +377,7 @@ impl<E: std::error::Error + std::fmt::Debug + 'static> Component for PostEditor< Row::TwoColumn(&widgets.name_label, widgets.name_field.upcast_ref::<gtk::Widget>()), Row::TwoColumn(&widgets.summary_label, widgets.summary_field.upcast_ref::<gtk::Widget>()), Row::TwoColumn(&widgets.tag_label, widgets.tag_holder.upcast_ref::<gtk::Widget>()), - Row::TwoColumn(&widgets.content_label, widgets.content_textarea.upcast_ref::<gtk::Widget>()), + Row::TwoColumn(&widgets.content_label, widgets.content_textarea_wrapper.upcast_ref::<gtk::Widget>()), Row::Span(widgets.misc_prop_wrapper.upcast_ref::<gtk::Widget>()), ].into_iter().enumerate() { match content { diff --git a/src/lib.rs b/src/lib.rs index a9335bc..c5705db 100644 --- a/src/lib.rs +++ b/src/lib.rs @@ -55,7 +55,7 @@ impl AsyncComponent for App { adw::ApplicationWindow { set_title: Some("Create post"), set_width_request: 360, - set_height_request: 480, + set_height_request: 294, adw::ToolbarView { add_top_bar: &{ diff --git a/src/widgets.rs b/src/widgets.rs index eb5766b..e69de29 100644 --- a/src/widgets.rs +++ b/src/widgets.rs @@ -1,30 +0,0 @@ -use gtk::prelude::*; -use relm4::{ - gtk, RelmWidgetExt, WidgetTemplate, -}; - - -#[relm4::widget_template(pub)] -impl WidgetTemplate for FieldWithLabel { - view! { - #[name = "layout"] - gtk::Box { - set_orientation: gtk::Orientation::Horizontal, - - #[name = "label"] - gtk::Label { - set_width_request: 150, - set_height_request: 36, - }, - - #[name = "input_wrapper"] - gtk::Box { - set_orientation: gtk::Orientation::Horizontal, - set_css_classes: &["linked"], - - #[name = "input"] - gtk::Entry { set_hexpand: true }, - }, - } - } -} |