fixed hotkey meta + v

This commit is contained in:
pandadev 2024-07-17 00:30:06 +02:00
parent fa7797cabf
commit 0ee166a3c0
No known key found for this signature in database
GPG key ID: C39629DACB8E762F
2 changed files with 40 additions and 42 deletions

View file

@ -1,47 +1,47 @@
use rdev::{listen, EventType, Key};
use std::sync::mpsc;
use std::sync::{Arc, Mutex, mpsc};
use tauri::Manager;
pub fn setup(app_handle: tauri::AppHandle) {
let (tx, rx) = mpsc::channel();
let meta_pressed = Arc::new(Mutex::new(false));
std::thread::spawn(move || {
listen(move |event| {
tx.send(event).unwrap();
})
.unwrap();
std::thread::spawn({
let meta_pressed = Arc::clone(&meta_pressed);
move || {
listen(move |event| {
match event.event_type {
EventType::KeyPress(Key::MetaLeft) | EventType::KeyPress(Key::MetaRight) => {
let mut meta = meta_pressed.lock().unwrap();
*meta = true;
tx.send(event).unwrap();
}
EventType::KeyRelease(Key::MetaLeft) | EventType::KeyRelease(Key::MetaRight) => {
let mut meta = meta_pressed.lock().unwrap();
*meta = false;
}
_ => {
tx.send(event).unwrap();
}
}
})
.unwrap();
}
});
std::thread::spawn(move || {
let mut meta_pressed = false;
while let Ok(event) = rx.recv() {
match event.event_type {
EventType::KeyPress(Key::MetaLeft) | EventType::KeyPress(Key::MetaRight) => {
meta_pressed = true;
println!("Meta key pressed");
let meta = meta_pressed.lock().unwrap();
if *meta && matches!(event.event_type, EventType::KeyPress(Key::KeyV)) {
println!("Meta and Key V pressed");
let window = app_handle.get_webview_window("main").unwrap();
let is_visible = window.is_visible().unwrap();
if is_visible {
window.hide().unwrap();
} else {
window.show().unwrap();
window.set_focus().unwrap();
}
EventType::KeyRelease(Key::MetaLeft) | EventType::KeyRelease(Key::MetaRight) => {
meta_pressed = false;
println!("Meta key released");
}
EventType::KeyPress(Key::KeyV) => {
println!("V key pressed");
if meta_pressed {
println!("Meta+V detected");
let window = app_handle.get_webview_window("main").unwrap();
let is_visible = window.is_visible().unwrap();
if is_visible {
println!("Hiding window");
window.hide().unwrap();
} else {
println!("Showing window");
window.show().unwrap();
window.set_focus().unwrap();
}
}
}
_ => {}
}
}
});