Performance (#89)

* jre async

* mac support

* fixed some settings not being saved to file

* fixed older version of mac random crashing bug

* added specific mac version detection

* linux support for jre changes

* added app storage options

* tauri features change

* dependency fix

* removed debug statement

* restructured to not pass css through rust

* changed to os_info

* rerun cicd
This commit is contained in:
Wyatt Verchere
2023-04-19 11:44:44 -07:00
committed by GitHub
parent d414e07f41
commit 16e015b527
14 changed files with 164 additions and 82 deletions

12
Cargo.lock generated
View File

@@ -2215,6 +2215,17 @@ dependencies = [
"vcpkg", "vcpkg",
] ]
[[package]]
name = "os_info"
version = "3.7.0"
source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "006e42d5b888366f1880eda20371fedde764ed2213dc8496f49622fa0c99cd5e"
dependencies = [
"log",
"serde",
"winapi",
]
[[package]] [[package]]
name = "overload" name = "overload"
version = "0.1.1" version = "0.1.1"
@@ -3628,6 +3639,7 @@ version = "0.0.0"
dependencies = [ dependencies = [
"daedalus", "daedalus",
"futures", "futures",
"os_info",
"regex", "regex",
"serde", "serde",
"serde_json", "serde_json",

View File

@@ -15,10 +15,10 @@ pub const JAVA_18PLUS_KEY: &str = "JAVA_18PLUS";
// Autodetect JavaSettings default // Autodetect JavaSettings default
// Make a guess for what the default Java global settings should be // Make a guess for what the default Java global settings should be
pub fn autodetect_java_globals() -> crate::Result<JavaGlobals> { pub async fn autodetect_java_globals() -> crate::Result<JavaGlobals> {
let mut java_8 = find_java8_jres()?; let mut java_8 = find_java8_jres().await?;
let mut java_17 = find_java17_jres()?; let mut java_17 = find_java17_jres().await?;
let mut java_18plus = find_java18plus_jres()?; let mut java_18plus = find_java18plus_jres().await?;
// Simply select last one found for initial guess // Simply select last one found for initial guess
let mut java_globals = JavaGlobals::new(); let mut java_globals = JavaGlobals::new();
@@ -76,9 +76,9 @@ pub async fn get_optimal_jre_key(profile: &Profile) -> crate::Result<String> {
} }
// Searches for jres on the system that are 1.18 or higher // Searches for jres on the system that are 1.18 or higher
pub fn find_java18plus_jres() -> crate::Result<Vec<JavaVersion>> { pub async fn find_java18plus_jres() -> crate::Result<Vec<JavaVersion>> {
let version = extract_java_majorminor_version("1.18")?; let version = extract_java_majorminor_version("1.18")?;
let jres = jre::get_all_jre()?; let jres = jre::get_all_jre().await?;
// Filter out JREs that are not 1.17 or higher // Filter out JREs that are not 1.17 or higher
Ok(jres Ok(jres
.into_iter() .into_iter()
@@ -94,9 +94,9 @@ pub fn find_java18plus_jres() -> crate::Result<Vec<JavaVersion>> {
} }
// Searches for jres on the system that are 1.8 exactly // Searches for jres on the system that are 1.8 exactly
pub fn find_java8_jres() -> crate::Result<Vec<JavaVersion>> { pub async fn find_java8_jres() -> crate::Result<Vec<JavaVersion>> {
let version = extract_java_majorminor_version("1.8")?; let version = extract_java_majorminor_version("1.8")?;
let jres = jre::get_all_jre()?; let jres = jre::get_all_jre().await?;
// Filter out JREs that are not 1.8 // Filter out JREs that are not 1.8
Ok(jres Ok(jres
@@ -113,9 +113,9 @@ pub fn find_java8_jres() -> crate::Result<Vec<JavaVersion>> {
} }
// Searches for jres on the system that are 1.17 exactly // Searches for jres on the system that are 1.17 exactly
pub fn find_java17_jres() -> crate::Result<Vec<JavaVersion>> { pub async fn find_java17_jres() -> crate::Result<Vec<JavaVersion>> {
let version = extract_java_majorminor_version("1.17")?; let version = extract_java_majorminor_version("1.17")?;
let jres = jre::get_all_jre()?; let jres = jre::get_all_jre().await?;
// Filter out JREs that are not 1.8 // Filter out JREs that are not 1.8
Ok(jres Ok(jres
@@ -132,17 +132,17 @@ pub fn find_java17_jres() -> crate::Result<Vec<JavaVersion>> {
} }
// Get all JREs that exist on the system // Get all JREs that exist on the system
pub fn get_all_jre() -> crate::Result<Vec<JavaVersion>> { pub async fn get_all_jre() -> crate::Result<Vec<JavaVersion>> {
Ok(jre::get_all_jre()?) Ok(jre::get_all_jre().await?)
} }
pub async fn validate_globals() -> crate::Result<bool> { pub async fn validate_globals() -> crate::Result<bool> {
let state = State::get().await?; let state = State::get().await?;
let settings = state.settings.read().await; let settings = state.settings.read().await;
Ok(settings.java_globals.is_all_valid()) Ok(settings.java_globals.is_all_valid().await)
} }
// Validates JRE at a given at a given path // Validates JRE at a given at a given path
pub async fn check_jre(path: PathBuf) -> crate::Result<Option<JavaVersion>> { pub async fn check_jre(path: PathBuf) -> crate::Result<Option<JavaVersion>> {
Ok(jre::check_java_at_filepath(&path)) Ok(jre::check_java_at_filepath(&path).await)
} }

View File

@@ -21,5 +21,6 @@ pub async fn set(settings: Settings) -> crate::Result<()> {
// Replaces the settings struct in the RwLock with the passed argument // Replaces the settings struct in the RwLock with the passed argument
*state.settings.write().await = settings; *state.settings.write().await = settings;
state.reset_semaphore().await; // reset semaphore to new max state.reset_semaphore().await; // reset semaphore to new max
State::sync().await?;
Ok(()) Ok(())
} }

View File

@@ -26,7 +26,6 @@ impl DirectoryInfo {
"Could not find valid config dir".to_string(), "Could not find valid config dir".to_string(),
))?; ))?;
dbg!(&config_dir);
fs::create_dir_all(&config_dir).await.map_err(|err| { fs::create_dir_all(&config_dir).await.map_err(|err| {
crate::ErrorKind::FSError(format!( crate::ErrorKind::FSError(format!(
"Error creating Theseus config directory: {err}" "Error creating Theseus config directory: {err}"

View File

@@ -37,11 +37,12 @@ impl JavaGlobals {
// Validates that every path here is a valid Java version and that the version matches the version stored here // Validates that every path here is a valid Java version and that the version matches the version stored here
// If false, when checked, the user should be prompted to reselect the Java version // If false, when checked, the user should be prompted to reselect the Java version
pub fn is_all_valid(&self) -> bool { pub async fn is_all_valid(&self) -> bool {
for (_, java) in self.0.iter() { for (_, java) in self.0.iter() {
let jre = jre::check_java_at_filepath( let jre = jre::check_java_at_filepath(
PathBuf::from(&java.path).as_path(), PathBuf::from(&java.path).as_path(),
); )
.await;
if let Some(jre) = jre { if let Some(jre) = jre {
if jre.version != java.version { if jre.version != java.version {
return false; return false;

View File

@@ -130,7 +130,7 @@ impl State {
// On launcher initialization, if global java variables are unset, try to find and set them // On launcher initialization, if global java variables are unset, try to find and set them
// (they are required for the game to launch) // (they are required for the game to launch)
if settings.java_globals.count() == 0 { if settings.java_globals.count() == 0 {
settings.java_globals = jre::autodetect_java_globals()?; settings.java_globals = jre::autodetect_java_globals().await?;
} }
Ok(Arc::new(Self { Ok(Arc::new(Self {

View File

@@ -1,4 +1,5 @@
use dunce::canonicalize; use dunce::canonicalize;
use futures::prelude::*;
use lazy_static::lazy_static; use lazy_static::lazy_static;
use regex::Regex; use regex::Regex;
use serde::{Deserialize, Serialize}; use serde::{Deserialize, Serialize};
@@ -6,6 +7,7 @@ use std::env;
use std::path::PathBuf; use std::path::PathBuf;
use std::process::Command; use std::process::Command;
use std::{collections::HashSet, path::Path}; use std::{collections::HashSet, path::Path};
use tokio::task::JoinError;
#[cfg(target_os = "windows")] #[cfg(target_os = "windows")]
use winreg::{ use winreg::{
@@ -23,12 +25,11 @@ pub struct JavaVersion {
// Returns a Vec of unique JavaVersions from the PATH, Windows Registry Keys and common Java locations // Returns a Vec of unique JavaVersions from the PATH, Windows Registry Keys and common Java locations
#[cfg(target_os = "windows")] #[cfg(target_os = "windows")]
#[tracing::instrument] #[tracing::instrument]
pub fn get_all_jre() -> Result<Vec<JavaVersion>, JREError> { pub async fn get_all_jre() -> Result<Vec<JavaVersion>, JREError> {
// Use HashSet to avoid duplicates let mut jre_paths = HashSet::new();
let mut jres = HashSet::new();
// Add JRES directly on PATH // Add JRES directly on PATH
jres.extend(get_all_jre_path()?); jre_paths.extend(get_all_jre_path().await?);
// Hard paths for locations for commonly installed .exes // Hard paths for locations for commonly installed .exes
let java_paths = [r"C:/Program Files/Java", r"C:/Program Files (x86)/Java"]; let java_paths = [r"C:/Program Files/Java", r"C:/Program Files (x86)/Java"];
@@ -36,9 +37,7 @@ pub fn get_all_jre() -> Result<Vec<JavaVersion>, JREError> {
let Ok(java_subpaths) = std::fs::read_dir(java_path) else {continue }; let Ok(java_subpaths) = std::fs::read_dir(java_path) else {continue };
for java_subpath in java_subpaths { for java_subpath in java_subpaths {
let path = java_subpath?.path(); let path = java_subpath?.path();
if let Some(j) = check_java_at_filepath(&path.join("bin")) { jre_paths.insert(path.join("bin"));
jres.insert(j);
}
} }
} }
@@ -53,28 +52,35 @@ pub fn get_all_jre() -> Result<Vec<JavaVersion>, JREError> {
r"SOFTWARE\\Eclipse Foundation\\JDK", // Eclipse r"SOFTWARE\\Eclipse Foundation\\JDK", // Eclipse
r"SOFTWARE\\Microsoft\\JDK", // Microsoft r"SOFTWARE\\Microsoft\\JDK", // Microsoft
]; ];
for key in key_paths { for key in key_paths {
if let Ok(jre_key) = RegKey::predef(HKEY_LOCAL_MACHINE) if let Ok(jre_key) = RegKey::predef(HKEY_LOCAL_MACHINE)
.open_subkey_with_flags(key, KEY_READ | KEY_WOW64_32KEY) .open_subkey_with_flags(key, KEY_READ | KEY_WOW64_32KEY)
{ {
jres.extend(get_all_jre_winregkey(jre_key)?); jre_paths.extend(get_paths_from_jre_winregkey(jre_key)?);
} }
if let Ok(jre_key) = RegKey::predef(HKEY_LOCAL_MACHINE) if let Ok(jre_key) = RegKey::predef(HKEY_LOCAL_MACHINE)
.open_subkey_with_flags(key, KEY_READ | KEY_WOW64_64KEY) .open_subkey_with_flags(key, KEY_READ | KEY_WOW64_64KEY)
{ {
jres.extend(get_all_jre_winregkey(jre_key)?); jre_paths.extend(get_paths_from_jre_winregkey(jre_key)?);
} }
} }
Ok(jres.into_iter().collect()) // Get JRE versions from potential paths concurrently
let j = check_java_at_filepaths(jre_paths)
.await?
.into_iter()
.collect();
Ok(j)
} }
// Gets paths rather than search directly as RegKeys should not be passed asynchronously (do not impl Send)
#[cfg(target_os = "windows")] #[cfg(target_os = "windows")]
#[tracing::instrument] #[tracing::instrument]
pub fn get_all_jre_winregkey( pub fn get_paths_from_jre_winregkey(
jre_key: RegKey, jre_key: RegKey,
) -> Result<HashSet<JavaVersion>, JREError> { ) -> Result<HashSet<PathBuf>, JREError> {
let mut jres = HashSet::new(); let mut jre_paths = HashSet::new();
for subkey in jre_key.enum_keys() { for subkey in jre_key.enum_keys() {
let subkey = subkey?; let subkey = subkey?;
@@ -87,26 +93,23 @@ pub fn get_all_jre_winregkey(
let path: Result<String, std::io::Error> = let path: Result<String, std::io::Error> =
subkey.get_value(subkey_value); subkey.get_value(subkey_value);
let Ok(path) = path else {continue}; let Ok(path) = path else {continue};
if let Some(j) =
check_java_at_filepath(&PathBuf::from(path).join("bin")) jre_paths.insert(PathBuf::from(path).join("bin"));
{
jres.insert(j);
}
} }
} }
Ok(jres) Ok(jre_paths)
} }
// Entrypoint function (Mac) // Entrypoint function (Mac)
// Returns a Vec of unique JavaVersions from the PATH, and common Java locations // Returns a Vec of unique JavaVersions from the PATH, and common Java locations
#[cfg(target_os = "macos")] #[cfg(target_os = "macos")]
#[tracing::instrument] #[tracing::instrument]
pub fn get_all_jre() -> Result<Vec<JavaVersion>, JREError> { pub async fn get_all_jre() -> Result<Vec<JavaVersion>, JREError> {
// Use HashSet to avoid duplicates // Use HashSet to avoid duplicates
let mut jres = HashSet::new(); let mut jre_paths = HashSet::new();
// Add JREs directly on PATH // Add JREs directly on PATH
jres.extend(get_all_jre_path()?); jre_paths.extend(get_all_jre_path().await?);
// Hard paths for locations for commonly installed .exes // Hard paths for locations for commonly installed .exes
let java_paths = [ let java_paths = [
@@ -115,36 +118,34 @@ pub fn get_all_jre() -> Result<Vec<JavaVersion>, JREError> {
r"/System/Library/Frameworks/JavaVM.framework/Versions/Current/Commands", r"/System/Library/Frameworks/JavaVM.framework/Versions/Current/Commands",
]; ];
for path in java_paths { for path in java_paths {
if let Some(j) = jre_paths.insert(PathBuf::from(path));
check_java_at_filepath(&PathBuf::from(path).join("bin"))
{
jres.insert(j);
}
} }
// Iterate over JavaVirtualMachines/(something)/Contents/Home/bin // Iterate over JavaVirtualMachines/(something)/Contents/Home/bin
let base_path = PathBuf::from("/Library/Java/JavaVirtualMachines/"); let base_path = PathBuf::from("/Library/Java/JavaVirtualMachines/");
if base_path.is_dir() { if base_path.is_dir() {
for entry in std::fs::read_dir(base_path)? { for entry in std::fs::read_dir(base_path)? {
let entry = entry?.path().join("Contents/Home/bin"); let entry = entry?.path().join("Contents/Home/bin");
if let Some(j) = check_java_at_filepath(entry.as_path()) { jre_paths.insert(entry);
jres.insert(j);
}
} }
} }
// Get JRE versions from potential paths concurrently
Ok(jres.into_iter().collect()) let j = check_java_at_filepaths(jre_paths)
.await?
.into_iter()
.collect();
Ok(j)
} }
// Entrypoint function (Linux) // Entrypoint function (Linux)
// Returns a Vec of unique JavaVersions from the PATH, and common Java locations // Returns a Vec of unique JavaVersions from the PATH, and common Java locations
#[cfg(target_os = "linux")] #[cfg(target_os = "linux")]
#[tracing::instrument] #[tracing::instrument]
pub fn get_all_jre() -> Result<Vec<JavaVersion>, JREError> { pub async fn get_all_jre() -> Result<Vec<JavaVersion>, JREError> {
// Use HashSet to avoid duplicates // Use HashSet to avoid duplicates
let mut jres = HashSet::new(); let mut jre_paths = HashSet::new();
// Add JREs directly on PATH // Add JREs directly on PATH
jres.extend(get_all_jre_path()?); jre_paths.extend(get_all_jre_path().await?);
// Hard paths for locations for commonly installed locations // Hard paths for locations for commonly installed locations
let java_paths = [ let java_paths = [
@@ -156,34 +157,23 @@ pub fn get_all_jre() -> Result<Vec<JavaVersion>, JREError> {
r"/opt/jdks", r"/opt/jdks",
]; ];
for path in java_paths { for path in java_paths {
if let Some(j) = jre_paths.insert(PathBuf::from(path).join("jre").join("bin"));
check_java_at_filepath(&PathBuf::from(path).join("jre").join("bin")) jre_paths.insert(PathBuf::from(path).join("bin"));
{
jres.insert(j);
}
if let Some(j) =
check_java_at_filepath(&PathBuf::from(path).join("bin"))
{
jres.insert(j);
}
} }
Ok(jres.into_iter().collect()) // Get JRE versions from potential paths concurrently
let j = check_java_at_filepaths(jre_paths)
.await?
.into_iter()
.collect();
Ok(j)
} }
// Gets all JREs from the PATH env variable // Gets all JREs from the PATH env variable
#[tracing::instrument] #[tracing::instrument]
fn get_all_jre_path() -> Result<HashSet<JavaVersion>, JREError> { async fn get_all_jre_path() -> Result<HashSet<PathBuf>, JREError> {
// Iterate over values in PATH variable, where accessible JREs are referenced // Iterate over values in PATH variable, where accessible JREs are referenced
let paths = env::var("PATH")?; let paths = env::var("PATH")?;
let paths = env::split_paths(&paths); Ok(env::split_paths(&paths).collect())
let mut jres = HashSet::new();
for path in paths {
if let Some(j) = check_java_at_filepath(&path) {
jres.insert(j);
}
}
Ok(jres)
} }
#[cfg(target_os = "windows")] #[cfg(target_os = "windows")]
@@ -194,10 +184,28 @@ const JAVA_BIN: &str = "java.exe";
#[allow(dead_code)] #[allow(dead_code)]
const JAVA_BIN: &str = "java"; const JAVA_BIN: &str = "java";
// For each example filepath in 'paths', perform check_java_at_filepath, checking each one concurrently
// and returning a JavaVersion for every valid path that points to a java bin
#[tracing::instrument]
pub async fn check_java_at_filepaths(
paths: HashSet<PathBuf>,
) -> Result<HashSet<JavaVersion>, JREError> {
let jres = stream::iter(paths.into_iter())
.map(|p: PathBuf| {
tokio::task::spawn(async move { check_java_at_filepath(&p).await })
})
.buffer_unordered(64)
.collect::<Vec<_>>()
.await;
let jres: Result<Vec<_>, JoinError> = jres.into_iter().collect();
Ok(jres?.into_iter().flatten().collect())
}
// For example filepath 'path', attempt to resolve it and get a Java version at this path // For example filepath 'path', attempt to resolve it and get a Java version at this path
// If no such path exists, or no such valid java at this path exists, returns None // If no such path exists, or no such valid java at this path exists, returns None
#[tracing::instrument] #[tracing::instrument]
pub fn check_java_at_filepath(path: &Path) -> Option<JavaVersion> { pub async fn check_java_at_filepath(path: &Path) -> Option<JavaVersion> {
// Attempt to canonicalize the potential java filepath // Attempt to canonicalize the potential java filepath
// If it fails, this path does not exist and None is returned (no Java here) // If it fails, this path does not exist and None is returned (no Java here)
let Ok(path) = canonicalize(path) else { return None }; let Ok(path) = canonicalize(path) else { return None };
@@ -289,6 +297,9 @@ pub enum JREError {
#[error("Parsing error: {0}")] #[error("Parsing error: {0}")]
ParseError(#[from] std::num::ParseIntError), ParseError(#[from] std::num::ParseIntError),
#[error("Join error: {0}")]
JoinError(#[from] JoinError),
#[error("No stored tag for Minecraft Version {0}")] #[error("No stored tag for Minecraft Version {0}")]
NoMinecraftVersionFound(String), NoMinecraftVersionFound(String),
} }

View File

@@ -28,6 +28,7 @@ daedalus = {version = "0.1.15", features = ["bincode"] }
url = "2.2" url = "2.2"
uuid = { version = "1.1", features = ["serde", "v4"] } uuid = { version = "1.1", features = ["serde", "v4"] }
os_info = "3.7.0"
[features] [features]
# by default Tauri runs in production mode # by default Tauri runs in production mode

View File

@@ -9,32 +9,32 @@ use super::TheseusSerializableError;
/// Get all JREs that exist on the system /// Get all JREs that exist on the system
#[tauri::command] #[tauri::command]
pub async fn jre_get_all_jre() -> Result<Vec<JavaVersion>> { pub async fn jre_get_all_jre() -> Result<Vec<JavaVersion>> {
Ok(jre::get_all_jre()?) Ok(jre::get_all_jre().await?)
} }
// Finds the isntallation of Java 7, if it exists // Finds the isntallation of Java 7, if it exists
#[tauri::command] #[tauri::command]
pub async fn jre_find_jre_8_jres() -> Result<Vec<JavaVersion>> { pub async fn jre_find_jre_8_jres() -> Result<Vec<JavaVersion>> {
Ok(jre::find_java8_jres()?) Ok(jre::find_java8_jres().await?)
} }
// finds the installation of Java 17, if it exists // finds the installation of Java 17, if it exists
#[tauri::command] #[tauri::command]
pub async fn jre_find_jre_17_jres() -> Result<Vec<JavaVersion>> { pub async fn jre_find_jre_17_jres() -> Result<Vec<JavaVersion>> {
Ok(jre::find_java17_jres()?) Ok(jre::find_java17_jres().await?)
} }
// Finds the highest version of Java 18+, if it exists // Finds the highest version of Java 18+, if it exists
#[tauri::command] #[tauri::command]
pub async fn jre_find_jre_18plus_jres() -> Result<Vec<JavaVersion>> { pub async fn jre_find_jre_18plus_jres() -> Result<Vec<JavaVersion>> {
Ok(jre::find_java18plus_jres()?) Ok(jre::find_java18plus_jres().await?)
} }
// Autodetect Java globals, by searching the users computer. // Autodetect Java globals, by searching the users computer.
// Returns a *NEW* JavaGlobals that can be put into Settings // Returns a *NEW* JavaGlobals that can be put into Settings
#[tauri::command] #[tauri::command]
pub async fn jre_autodetect_java_globals() -> Result<JavaGlobals> { pub async fn jre_autodetect_java_globals() -> Result<JavaGlobals> {
Ok(jre::autodetect_java_globals()?) Ok(jre::autodetect_java_globals().await?)
} }
// Gets key for the optimal JRE to use, for a given profile Profile // Gets key for the optimal JRE to use, for a given profile Profile

View File

@@ -15,10 +15,32 @@ async fn initialize_state(app: tauri::AppHandle) -> api::Result<()> {
Ok(()) Ok(())
} }
// cfg only on mac os
// disables mouseover and fixes a random crash error only fixed by recent versions of macos
#[cfg(target_os = "macos")]
#[tauri::command]
async fn should_disable_mouseover() -> bool {
// We try to match version to 12.2 or higher. If unrecognizable to pattern or lower, we default to the css with disabled mouseover for safety
let os = os_info::get();
if let os_info::Version::Semantic(major, minor, _) = os.version() {
if *major >= 12 && *minor >= 3 {
// Mac os version is 12.3 or higher, we allow mouseover
return false;
}
}
true
}
#[cfg(not(target_os = "macos"))]
#[tauri::command]
async fn should_disable_mouseover() -> bool {
false
}
fn main() { fn main() {
tauri::Builder::default() tauri::Builder::default()
.invoke_handler(tauri::generate_handler![ .invoke_handler(tauri::generate_handler![
initialize_state, initialize_state,
should_disable_mouseover,
api::profile_create::profile_create_empty, api::profile_create::profile_create_empty,
api::profile_create::profile_create, api::profile_create::profile_create,
api::profile::profile_remove, api::profile::profile_remove,

View File

@@ -15,7 +15,11 @@
"all": false, "all": false,
"protocol": { "protocol": {
"asset": true, "asset": true,
"assetScope": ["$APPDATA/caches/icons/*"] "assetScope": [
"$APPDATA/caches/icons/*",
"$APPCONFIG/caches/icons/*",
"$CONFIG/caches/icons/*"
]
}, },
"window": { "window": {
"create": true, "create": true,

View File

@@ -0,0 +1,3 @@
img {
pointer-events: none !important;
}

View File

@@ -6,11 +6,12 @@ import '../node_modules/omorphia/dist/style.css'
import '@/assets/stylesheets/global.scss' import '@/assets/stylesheets/global.scss'
import FloatingVue from 'floating-vue' import FloatingVue from 'floating-vue'
import { initialize_state } from '@/helpers/state' import { initialize_state } from '@/helpers/state'
import loadCssMixin from './mixins/macCssFix.js'
const pinia = createPinia() const pinia = createPinia()
initialize_state() initialize_state()
.then(() => { .then(() => {
createApp(App).use(router).use(pinia).use(FloatingVue).mount('#app') createApp(App).use(router).use(pinia).use(FloatingVue).mixin(loadCssMixin).mount('#app')
}) })
.catch((err) => console.error(err)) .catch((err) => console.error(err))

View File

@@ -0,0 +1,27 @@
import { invoke } from '@tauri-apps/api/tauri'
import cssContent from '@/assets/stylesheets/macFix.css?inline'
export default {
async mounted() {
await this.checkDisableMouseover()
},
methods: {
async checkDisableMouseover() {
try {
// Fetch the CSS content from the Rust backend
const should_disable_mouseover = await invoke('should_disable_mouseover')
if (should_disable_mouseover) {
// Create a style element and set its content
const styleElement = document.createElement('style')
styleElement.innerHTML = cssContent
// Append the style element to the document's head
document.head.appendChild(styleElement)
}
} catch (error) {
console.error('Error checking OS version from Rust backend', error)
}
},
},
}