implemented trait-interface for builders
This commit is contained in:
parent
1d62f3810c
commit
5bd783b75b
|
@ -0,0 +1,17 @@
|
||||||
|
pub trait Product<B, T> {
|
||||||
|
|
||||||
|
fn builder() -> B;
|
||||||
|
|
||||||
|
fn get(self) -> T;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
pub trait Builder<T, I, P> {
|
||||||
|
|
||||||
|
fn build(&self, build_arg: P) -> T;
|
||||||
|
|
||||||
|
fn append_item(self, item: I) -> Self;
|
||||||
|
|
||||||
|
fn append_items(self, items: Vec<I>) -> Self;
|
||||||
|
|
||||||
|
}
|
|
@ -2,3 +2,4 @@ pub mod tabs;
|
||||||
pub mod pages;
|
pub mod pages;
|
||||||
pub mod switch;
|
pub mod switch;
|
||||||
pub mod wrapper;
|
pub mod wrapper;
|
||||||
|
pub mod builder_pattern_traits;
|
||||||
|
|
|
@ -1,26 +1,71 @@
|
||||||
|
use std::ops::Deref;
|
||||||
use gtk4 as gtk;
|
use gtk4 as gtk;
|
||||||
|
|
||||||
use gtk::{Stack, StackSidebar, Box};
|
use gtk::{
|
||||||
use gtk4::{Orientation, StackSwitcher, StackTransitionType, Widget};
|
Box,
|
||||||
use gtk4::prelude::{BoxExt, IsA};
|
Stack,
|
||||||
|
Widget,
|
||||||
|
Orientation,
|
||||||
|
StackSidebar,
|
||||||
|
StackSwitcher,
|
||||||
|
StackTransitionType,
|
||||||
|
prelude::{BoxExt, IsA},
|
||||||
|
};
|
||||||
|
|
||||||
|
use crate::view::components::builder_pattern_traits::{Builder, Product};
|
||||||
|
|
||||||
|
pub type Page<'a> = (&'a str, &'a str, &'a Box);
|
||||||
|
|
||||||
pub struct Pages{
|
pub struct Pages{
|
||||||
all_pages: Box
|
wrapper: Box
|
||||||
}
|
}
|
||||||
|
|
||||||
pub struct PagesBuilder{
|
pub struct PagesBuilder{
|
||||||
pages_content: Stack,
|
pages_content: Stack,
|
||||||
}
|
}
|
||||||
|
|
||||||
impl Pages {
|
impl Product<PagesBuilder, Box> for Pages {
|
||||||
pub fn builder() -> PagesBuilder{
|
fn builder() -> PagesBuilder {
|
||||||
PagesBuilder {
|
PagesBuilder {
|
||||||
pages_content: Stack::new(),
|
pages_content: Stack::new(),
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn get(self) -> Box {
|
fn get(self) -> Box {
|
||||||
self.all_pages
|
self.wrapper
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Builder<Pages, Page<'_>, i32> for PagesBuilder{
|
||||||
|
fn build(&self, build_param: i32) -> Pages {
|
||||||
|
let stack_sidebar = StackSidebar::new();
|
||||||
|
let stack_switcher = StackSwitcher::new();
|
||||||
|
|
||||||
|
stack_sidebar.set_stack(&self.pages_content);
|
||||||
|
stack_switcher.set_stack(Some(&self.pages_content));
|
||||||
|
|
||||||
|
let wrapper = Box::new(Orientation::Horizontal, build_param);
|
||||||
|
|
||||||
|
wrapper.append(&stack_sidebar);
|
||||||
|
wrapper.append(&self.pages_content);
|
||||||
|
|
||||||
|
Pages{
|
||||||
|
wrapper
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
fn append_item(self, item: Page) -> Self {
|
||||||
|
self.append_page_private(item);
|
||||||
|
self
|
||||||
|
}
|
||||||
|
|
||||||
|
fn append_items(self, items: Vec<Page>) -> Self {
|
||||||
|
items.iter()
|
||||||
|
.for_each(|&item| {
|
||||||
|
self.append_page_private(item);
|
||||||
|
});
|
||||||
|
|
||||||
|
self
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -28,11 +73,9 @@ impl PagesBuilder {
|
||||||
|
|
||||||
fn append_page_private(
|
fn append_page_private(
|
||||||
&self,
|
&self,
|
||||||
page_name: &str,
|
item: Page
|
||||||
page_title: &str,
|
|
||||||
content: &impl IsA<Widget>
|
|
||||||
) {
|
) {
|
||||||
self.pages_content.add_titled(content, Some(page_name), page_title);
|
self.pages_content.add_titled(item.2, Some(item.1), item.0);
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn set_transition(
|
pub fn set_transition(
|
||||||
|
@ -46,43 +89,4 @@ impl PagesBuilder {
|
||||||
self
|
self
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn add_page(
|
|
||||||
self,
|
|
||||||
page_name: &str,
|
|
||||||
page_title: &str,
|
|
||||||
content: &impl IsA<Widget>
|
|
||||||
) -> Self {
|
|
||||||
self.append_page_private(page_name, page_title, content);
|
|
||||||
self
|
|
||||||
}
|
|
||||||
|
|
||||||
pub fn add_pages(
|
|
||||||
self,
|
|
||||||
pages: Vec<(&str, &str, &impl IsA<Widget>)>,
|
|
||||||
) -> Self {
|
|
||||||
pages.iter()
|
|
||||||
.for_each(|(name, title, content)| {
|
|
||||||
self.append_page_private(*name, *title, *content);
|
|
||||||
});
|
|
||||||
|
|
||||||
self
|
|
||||||
}
|
|
||||||
|
|
||||||
pub fn build(&self, spacing: i32) -> Pages {
|
|
||||||
let stack_sidebar = StackSidebar::new();
|
|
||||||
let stack_switcher = StackSwitcher::new();
|
|
||||||
|
|
||||||
stack_sidebar.set_stack(&self.pages_content);
|
|
||||||
stack_switcher.set_stack(Some(&self.pages_content));
|
|
||||||
|
|
||||||
let wrapper = Box::new(Orientation::Horizontal, spacing);
|
|
||||||
|
|
||||||
wrapper.append(&stack_sidebar);
|
|
||||||
wrapper.append(&self.pages_content);
|
|
||||||
|
|
||||||
Pages{
|
|
||||||
all_pages: wrapper
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
}
|
|
@ -1,9 +1,12 @@
|
||||||
use gtk4 as gtk;
|
use gtk4 as gtk;
|
||||||
|
|
||||||
|
use std::boxed::Box as BoxPtr;
|
||||||
use gtk::{Notebook, Label, Box};
|
use gtk::{Notebook, Label, Box};
|
||||||
|
use super::builder_pattern_traits::*;
|
||||||
|
|
||||||
pub type TabLabel = Label;
|
pub type TabLabel = Label;
|
||||||
pub type TabContent = Box;
|
pub type TabContent = Box;
|
||||||
|
pub type TabPage = (BoxPtr<str>, TabContent);
|
||||||
|
|
||||||
#[derive(Clone)]
|
#[derive(Clone)]
|
||||||
pub struct TabsBuilder {
|
pub struct TabsBuilder {
|
||||||
|
@ -14,42 +17,25 @@ pub struct Tabs {
|
||||||
tabs_wrapper: Notebook
|
tabs_wrapper: Notebook
|
||||||
}
|
}
|
||||||
|
|
||||||
impl Tabs {
|
impl Product<TabsBuilder, Notebook> for Tabs {
|
||||||
pub fn builder() -> TabsBuilder {
|
|
||||||
TabsBuilder{
|
fn builder() -> TabsBuilder {
|
||||||
|
TabsBuilder {
|
||||||
tabs: Vec::new(),
|
tabs: Vec::new(),
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn get(self) -> Notebook {
|
fn get(self) -> Notebook {
|
||||||
self.tabs_wrapper
|
self.tabs_wrapper
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
impl TabsBuilder {
|
impl Builder<Tabs, TabPage, &str> for TabsBuilder{
|
||||||
|
|
||||||
fn append_tab_private(&mut self, label: &str, page: TabContent) {
|
fn build(&self, build_param: &str) -> Tabs {
|
||||||
let tab_label = Label::new(Some(label));
|
|
||||||
self.tabs.push((tab_label, page));
|
|
||||||
}
|
|
||||||
|
|
||||||
pub fn add_tab(mut self, label: &str, page: TabContent) -> Self {
|
|
||||||
self.append_tab_private(label, page);
|
|
||||||
|
|
||||||
self
|
|
||||||
}
|
|
||||||
|
|
||||||
pub fn add_tabs(mut self, labels: Vec<&str>, pages: Vec<TabContent>) -> Self {
|
|
||||||
for (label, page) in labels.iter().zip(pages) {
|
|
||||||
self.append_tab_private(label, page);
|
|
||||||
}
|
|
||||||
|
|
||||||
self
|
|
||||||
}
|
|
||||||
|
|
||||||
pub fn build(&self, group_name: &str) -> Tabs {
|
|
||||||
let tabs_wrapper = Notebook::builder()
|
let tabs_wrapper = Notebook::builder()
|
||||||
.group_name(group_name)
|
.group_name(build_param)
|
||||||
.build();
|
.build();
|
||||||
|
|
||||||
self.tabs
|
self.tabs
|
||||||
|
@ -63,4 +49,28 @@ impl TabsBuilder {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
fn append_item(mut self, item: TabPage) -> Self {
|
||||||
|
self.append_tab_private(&item.0, item.1);
|
||||||
|
|
||||||
|
self
|
||||||
|
}
|
||||||
|
|
||||||
|
fn append_items(mut self, items: Vec<TabPage>) -> Self {
|
||||||
|
for item in items{
|
||||||
|
self.append_tab_private(&item.0, item.1);
|
||||||
|
}
|
||||||
|
|
||||||
|
self
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
impl TabsBuilder {
|
||||||
|
|
||||||
|
fn append_tab_private(&mut self, label: &str, page: TabContent) {
|
||||||
|
let tab_label = Label::new(Some(label));
|
||||||
|
self.tabs.push((tab_label, page));
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
|
@ -1,3 +1,4 @@
|
||||||
|
use crate::view::components::builder_pattern_traits::{Builder, Product};
|
||||||
use gtk4 as gtk;
|
use gtk4 as gtk;
|
||||||
|
|
||||||
use gtk::{*, prelude::*};
|
use gtk::{*, prelude::*};
|
||||||
|
@ -174,7 +175,7 @@ pub fn ui(application: &adw::Application) {
|
||||||
|
|
||||||
let pages = Pages::builder()
|
let pages = Pages::builder()
|
||||||
.set_transition(SlideLeftRight, 200)
|
.set_transition(SlideLeftRight, 200)
|
||||||
.add_pages(vec![
|
.append_items(vec![
|
||||||
("Код Хэмминга", "Код Хэмминга", &mutual_wrapper),
|
("Код Хэмминга", "Код Хэмминга", &mutual_wrapper),
|
||||||
("Код Хафмана", "Код Хафмана", &second_wrapper)
|
("Код Хафмана", "Код Хафмана", &second_wrapper)
|
||||||
])
|
])
|
||||||
|
|
Loading…
Reference in New Issue