2021-04-25 12:07:45 -04:00
|
|
|
//! This example showcases setting up a basic application and window, setting up some views to
|
|
|
|
//! work with autolayout, and some basic ways to handle colors.
|
|
|
|
|
2022-07-31 19:27:11 -07:00
|
|
|
use cacao::appkit::menu::{Menu, MenuItem};
|
|
|
|
use cacao::appkit::toolbar::Toolbar;
|
|
|
|
use cacao::appkit::window::{Window, WindowConfig, WindowDelegate, WindowToolbarStyle};
|
|
|
|
use cacao::appkit::{App, AppDelegate};
|
2021-04-25 12:07:45 -04:00
|
|
|
|
2022-07-31 20:09:59 -07:00
|
|
|
use cacao::webview::{WebView, WebViewConfig, WebViewDelegate};
|
|
|
|
|
2021-04-25 12:07:45 -04:00
|
|
|
struct BasicApp {
|
|
|
|
window: Window<AppWindow>
|
|
|
|
}
|
|
|
|
|
|
|
|
impl AppDelegate for BasicApp {
|
|
|
|
fn did_finish_launching(&self) {
|
|
|
|
App::activate();
|
|
|
|
self.window.show();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
#[derive(Default)]
|
|
|
|
pub struct WebViewInstance;
|
|
|
|
|
|
|
|
impl WebViewDelegate for WebViewInstance {
|
2022-11-04 15:54:15 -07:00
|
|
|
const NAME: &'static str = "CustomWebViewDelegate";
|
|
|
|
|
2021-04-25 12:07:45 -04:00
|
|
|
fn on_custom_protocol_request(&self, path: &str) -> Option<Vec<u8>> {
|
|
|
|
let requested_asset_path = path.replace("cacao://", "");
|
|
|
|
|
|
|
|
let index_html = r#"
|
|
|
|
<!DOCTYPE html>
|
|
|
|
<html lang="en">
|
|
|
|
<head>
|
|
|
|
<meta charset="UTF-8" />
|
|
|
|
<meta http-equiv="X-UA-Compatible" content="IE=edge" />
|
|
|
|
<meta name="viewport" content="width=device-width, initial-scale=1.0" />
|
|
|
|
</head>
|
|
|
|
<body>
|
|
|
|
<h1>Welcome 🍫</h1>
|
|
|
|
<a href="/hello.html">Link</a>
|
|
|
|
</body>
|
2022-07-10 17:15:29 +02:00
|
|
|
</html>"#;
|
|
|
|
|
2021-04-25 12:07:45 -04:00
|
|
|
let link_html = r#"
|
|
|
|
<!DOCTYPE html>
|
|
|
|
<html lang="en">
|
|
|
|
<head>
|
|
|
|
<meta charset="UTF-8" />
|
|
|
|
<meta http-equiv="X-UA-Compatible" content="IE=edge" />
|
|
|
|
<meta name="viewport" content="width=device-width, initial-scale=1.0" />
|
|
|
|
</head>
|
|
|
|
<body>
|
|
|
|
<h1>Hello!</h1>
|
|
|
|
<a href="/index.html">Back home</a>
|
|
|
|
</body>
|
2022-07-10 17:15:29 +02:00
|
|
|
</html>"#;
|
2021-04-25 12:07:45 -04:00
|
|
|
|
|
|
|
return match requested_asset_path.as_str() {
|
|
|
|
"/hello.html" => Some(link_html.as_bytes().into()),
|
2022-07-15 16:14:02 +02:00
|
|
|
_ => Some(index_html.as_bytes().into())
|
|
|
|
};
|
2021-04-25 12:07:45 -04:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
struct AppWindow {
|
|
|
|
content: WebView<WebViewInstance>
|
|
|
|
}
|
|
|
|
|
|
|
|
impl AppWindow {
|
|
|
|
pub fn new() -> Self {
|
|
|
|
let mut webview_config = WebViewConfig::default();
|
|
|
|
|
|
|
|
// register the protocol in the webview
|
|
|
|
webview_config.add_custom_protocol("cacao");
|
|
|
|
|
|
|
|
AppWindow {
|
|
|
|
content: WebView::with(webview_config, WebViewInstance::default())
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
pub fn load_url(&self, url: &str) {
|
|
|
|
self.content.load_url(url);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
impl WindowDelegate for AppWindow {
|
|
|
|
const NAME: &'static str = "WindowDelegate";
|
|
|
|
|
|
|
|
fn did_load(&mut self, window: Window) {
|
|
|
|
window.set_title("Browser Example");
|
|
|
|
window.set_autosave_name("CacaoBrowserExample");
|
|
|
|
window.set_minimum_content_size(400., 400.);
|
|
|
|
|
|
|
|
window.set_content_view(&self.content);
|
|
|
|
|
|
|
|
// load custom protocol
|
|
|
|
self.load_url("cacao://");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
fn main() {
|
|
|
|
App::new("com.test.window", BasicApp {
|
|
|
|
window: Window::with(WindowConfig::default(), AppWindow::new())
|
2022-07-15 16:14:02 +02:00
|
|
|
})
|
|
|
|
.run();
|
2021-04-25 12:07:45 -04:00
|
|
|
}
|