Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/ahkohd/tauri-nspanel
Tauri plugin to convert a window to panel
https://github.com/ahkohd/tauri-nspanel
macos objcective-c rust tauri tauri-plugin
Last synced: 11 days ago
JSON representation
Tauri plugin to convert a window to panel
- Host: GitHub
- URL: https://github.com/ahkohd/tauri-nspanel
- Owner: ahkohd
- License: apache-2.0
- Created: 2023-03-20T06:32:24.000Z (over 1 year ago)
- Default Branch: v2
- Last Pushed: 2024-10-23T21:41:41.000Z (18 days ago)
- Last Synced: 2024-10-24T08:22:52.218Z (18 days ago)
- Topics: macos, objcective-c, rust, tauri, tauri-plugin
- Language: Rust
- Homepage: https://ahkohd.github.io/tauri-nspanel/
- Size: 337 MB
- Stars: 110
- Watchers: 3
- Forks: 11
- Open Issues: 3
-
Metadata Files:
- Readme: README.md
- License: LICENSE_APACHE-2.0
Awesome Lists containing this project
- awesome-tauri - tauri-nspanel - Convert a window to panel. (Development / Plugins)
README
Convert a Tauri `WebviewWindow` ([`NSWindow`](https://developer.apple.com/documentation/appkit/nswindow)) to panel ([`NSPanel`](https://developer.apple.com/documentation/appkit/nspanel))
# Install
There are three general methods of installation that we can recommend.
- Use crates.io and npm (easiest, and requires you to trust that our publishing pipeline worked)
- Pull sources directly from Github using git tags / revision hashes (most secure)
- Git submodule install this repo in your tauri project and then use file protocol to ingest the source (most secure, but inconvenient to use)Install the plugin by adding the following to your `Cargo.toml` file:
```toml
[dependencies]
tauri-nspanel = { git = "https://github.com/ahkohd/tauri-nspanel", branch = "v2" }
```# Usage
1. First you need to register the core plugin with Tauri:
`src-tauri/src/main.rs`
```rust
fn main() {
tauri::Builder::default()
.plugin(tauri_nspanel::init())
.run(tauri::generate_context!())
.expect("error while running tauri application");
}
```2. To swizzle a window's `NSWindow` to `NSPanel`, use the `to_panel()` method:
```rust
use tauri_nspanel::WebviewWindowExt;// ...
let panel = window.to_panel().unwrap();
```The window will be swizzled to `NSPanel`.
> Only call the `to_panel()` method once on a webview window.
3. To access your panels, use the `app_handle.get_webview_panel("label")`:
```rust
use tauri_nspanel::ManagerExt;// ...
let my_panel = app_handle.get_webview_panel("main");
```4. To respond to panel events, such as resizing, moving, exposing, and minimizing ([See the exhaustive list](https://developer.apple.com/documentation/appkit/nswindowdelegate?language=objc)), you need to setup a `NSWindowDelegate` for your panel.
Use the `panel_delegate!()` macro to do this:
```rust
use tauri::Wry;
use tauri_nspanel::{objc_id::Id, panel_delegate, ManagerExt, Panel, WindowExt};// ...
// Use the `panel_delegate!()` macro to create your custom delegate// Specify your handlers
// See, https://developer.apple.com/documentation/appkit/nswindowdelegate?language=objc
// for an exhaustive list of handlers.
//
// Example: to respond to windowDidBecomeKey:
// specify in snake case: window_did_become_keylet delegate = panel_delegate!(MyPanelDelegate {
window_did_become_key,
window_did_resign_key
});// Listen to when a delegate is called
delegate.set_listener(Box::new(|delegate_name: String| {
println!("{} was called!", delegate_name);
}));// Set your panel's delegate
panel.set_delegate(delegate);
```5. Simply calling the `.close()` method on your NSPanel instance may not be sufficient to fully release its resources. This is because, by default,
`NSPanels` are not released when they are closed. This is because NSPanels are often lightweight and designed for reuse.To ensure that your NSPanel is fully released:
```rust
// ...panel.released_when_closed(true);
panel.close();
```6. For more information on panel methods, please refer to the [documentation page](https://ahkohd.github.io/tauri-nspanel/tauri_nspanel/raw_nspanel/struct.RawNSPanel.html).
# Related
The following are projects related to this plugin:
- [tauri-plugin-spotlight](https://github.com/zzzze/tauri-plugin-spotlight)
- [tauri-nspanel-example](https://github.com/ahkohd/tauri-nspanel/tree/v2/examples/vanilla)
- [tauri-macos-spotlight-example](https://github.com/ahkohd/tauri-macos-spotlight-example)# Showcase
Here are some projects using `tauri-nspanel`
- [Cap](https://github.com/CapSoftware/Cap)
- [EcoPaste](https://github.com/EcoPasteHub/EcoPaste)
- [Overlayed](https://github.com/overlayeddev/overlayed)
- [Lume](https://github.com/lumehq/lume)
- [Verve](https://github.com/ParthJadhav/verve)
- [Buffer](https://buffer.md)# Contributing
PRs accepted. Please make sure to read the Contributing Guide before making a pull request.
# License
MIT or MIT/Apache 2.0 where applicable.