Yoda/src/app/browser/window.rs
2025-01-26 10:54:28 +02:00

214 lines
5.6 KiB
Rust

mod action;
mod database;
mod header;
pub mod tab;
mod widget;
use action::{Action, Position};
use header::Header;
use sqlite::Transaction;
use tab::Tab;
use widget::Widget;
use super::Action as BrowserAction;
use crate::Profile;
use gtk::glib::GString;
use std::rc::Rc;
pub struct Window {
pub action: Rc<Action>,
pub tab: Rc<Tab>,
pub widget: Rc<Widget>,
}
impl Window {
// Constructors
/// Build new `Self`
pub fn build(profile: &Rc<Profile>, browser_action: &Rc<BrowserAction>) -> Self {
// Init local actions
let action = Rc::new(Action::new());
// Init components
let tab = Rc::new(Tab::build(profile, (browser_action, &action)));
let header = Rc::new(Header::build(
(browser_action, &action),
profile,
&tab.widget.tab_view,
));
let widget = Rc::new(Widget::build(
&header.widget.toolbar_view,
&tab.widget.tab_view,
));
// Init events
action.append.connect_activate({
let tab = tab.clone();
move |position, request, is_pinned, is_selected, is_attention, is_load| {
tab.append(
position,
request.as_deref(),
is_pinned,
is_selected,
is_attention,
is_load,
);
}
});
action.bookmark.connect_activate({
let tab = tab.clone();
move |position| {
if tab.bookmark(position).is_err() {
todo!()
}
}
});
action.pin.connect_activate({
let tab = tab.clone();
move |position| tab.pin(position)
});
action.reload.connect_activate({
let tab = tab.clone();
move |position| tab.page_reload(position)
});
action.home.connect_activate({
let tab = tab.clone();
move |position| tab.page_home(position)
});
action.close.connect_activate({
let tab = tab.clone();
move |position| tab.close(position)
});
action.close_all.connect_activate({
let tab = tab.clone();
move |_| tab.close_all()
});
action.find.connect_activate({
let tab = tab.clone();
move |position| tab.find(position)
});
action.save_as.connect_activate({
let tab = tab.clone();
move |position| tab.save_as(position)
});
action.source.connect_activate({
let tab = tab.clone();
move |position| tab.source(position)
});
action.history_back.connect_activate({
let tab = tab.clone();
move |position| {
tab.page_history_back(position);
} // @TODO rename destination method
});
action.history_forward.connect_activate({
let tab = tab.clone();
move |position| {
tab.page_history_forward(position);
} // @TODO rename destination method
});
action.open.on_activate({
let tab = tab.clone();
move |_, request| {
tab.append(Position::End, Some(&request), false, true, false, true);
}
});
// Init struct
Self {
action,
tab,
widget,
}
}
// Actions
pub fn escape(&self, tab_item_id: Option<GString>) {
self.tab.escape(tab_item_id);
}
pub fn update(&self, tab_item_id: Option<GString>) {
self.tab.update(tab_item_id);
}
pub fn clean(&self, transaction: &Transaction, app_browser_id: i64) -> Result<(), String> {
match database::select(transaction, app_browser_id) {
Ok(records) => {
for record in records {
match database::delete(transaction, record.id) {
Ok(_) => {
// Delegate clean action to childs
self.tab.clean(transaction, record.id)?;
}
Err(e) => return Err(e.to_string()),
}
}
}
Err(e) => return Err(e.to_string()),
}
Ok(())
}
pub fn restore(&self, transaction: &Transaction, app_browser_id: i64) -> Result<(), String> {
match database::select(transaction, app_browser_id) {
Ok(records) => {
for record in records {
// Delegate restore action to childs
self.tab.restore(transaction, record.id)?;
}
}
Err(e) => return Err(e.to_string()),
}
Ok(())
}
pub fn save(&self, transaction: &Transaction, app_browser_id: i64) -> Result<(), String> {
match database::insert(transaction, app_browser_id) {
Ok(_) => {
// Delegate save action to childs
if let Err(e) = self
.tab
.save(transaction, database::last_insert_id(transaction))
{
return Err(e.to_string());
}
}
Err(e) => return Err(e.to_string()),
}
Ok(())
}
pub fn init(&self) {
self.tab.init();
}
}
// Tools
pub fn migrate(tx: &Transaction) -> Result<(), String> {
// Migrate self components
if let Err(e) = database::init(tx) {
return Err(e.to_string());
}
// Delegate migration to childs
tab::migrate(tx)?;
// Success
Ok(())
}