* feat: Implement DNS management for macOS - Added `set_public_dns` and `restore_public_dns` functions in `dns.rs` to manage system DNS settings. - Introduced `resolve` module to encapsulate DNS and scheme resolution functionalities. - Implemented `resolve_scheme` function in `scheme.rs` to handle deep links and profile imports. - Created UI readiness management in `ui.rs` to track and update UI loading states. - Developed window management logic in `window.rs` to handle window creation and visibility. - Added initial loading overlay script in `window_script.rs` for better user experience during startup. - Updated server handling in `server.rs` to integrate new resolve functionalities. - Refactored window creation calls in `window_manager.rs` to use the new window management logic. * refactor: streamline asynchronous handling in config and resolve setup * Revert "refactor: streamline asynchronous handling in config and resolve setup" This reverts commit 23d7dc86d5b87a3a34df2ae69c2caacef803ef81. * fix: optimize asynchronous memory handling * fix: enhance task logging by adding size check for special cases * refactor: enhance async initialization and streamline setup process * refactor: optimize async setup by consolidating initialization tasks * chore: update changelog for Mihomo(Meta) kernel upgrade to v1.19.13 * fix: improve startup phase initialization performance * refactor: optimize file read/write performance to reduce application wait time * refactor: simplify app instance exit logic and adjust system proxy guard initialization * refactor: change resolve_setup_async to synchronous execution for improved performance * refactor: update resolve_setup_async to accept AppHandle for improved initialization flow * refactor: remove unnecessary initialization of portable flag in run function * refactor: consolidate async initialization tasks into a single blocking call for improved execution flow * refactor: optimize resolve_setup_async by restructuring async tasks for improved concurrency * refactor: streamline resolve_setup_async and embed_server for improved async handling * refactor: separate synchronous and asynchronous setup functions for improved clarity * refactor: simplify async notification handling and remove redundant network manager initialization * refactor: enhance async handling in proxy request cache and window creation logic * refactor: improve code formatting and readability in ProxyRequestCache * refactor: adjust singleton check timeout and optimize trace size conditions * refactor: update TRACE_SPECIAL_SIZE to include additional size condition * refactor: update kode-bridge dependency to version 0.2.1-rc2 * refactor: replace RwLock with AtomicBool for UI readiness and implement event-driven monitoring * refactor: convert async functions to synchronous for window management * Update src-tauri/src/utils/resolve/window.rs * fix: handle missing app_handle in create_window function * Update src-tauri/src/module/lightweight.rs
72 lines
2.6 KiB
Rust
72 lines
2.6 KiB
Rust
pub const WINDOW_INITIAL_SCRIPT: &str = r#"
|
|
console.log('[Tauri] 窗口初始化脚本开始执行');
|
|
|
|
function createLoadingOverlay() {
|
|
|
|
if (document.getElementById('initial-loading-overlay')) {
|
|
console.log('[Tauri] 加载指示器已存在');
|
|
return;
|
|
}
|
|
|
|
console.log('[Tauri] 创建加载指示器');
|
|
const loadingDiv = document.createElement('div');
|
|
loadingDiv.id = 'initial-loading-overlay';
|
|
loadingDiv.innerHTML = `
|
|
<div style="
|
|
position: fixed; top: 0; left: 0; right: 0; bottom: 0;
|
|
background: var(--bg-color, #f5f5f5); color: var(--text-color, #333);
|
|
display: flex; flex-direction: column; align-items: center;
|
|
justify-content: center; z-index: 9999;
|
|
font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
|
|
transition: opacity 0.3s ease;
|
|
">
|
|
<div style="margin-bottom: 20px;">
|
|
<div style="
|
|
width: 40px; height: 40px; border: 3px solid #e3e3e3;
|
|
border-top: 3px solid #3498db; border-radius: 50%;
|
|
animation: spin 1s linear infinite;
|
|
"></div>
|
|
</div>
|
|
<div style="font-size: 14px; opacity: 0.7;">Loading Clash Verge...</div>
|
|
</div>
|
|
<style>
|
|
@keyframes spin {
|
|
0% { transform: rotate(0deg); }
|
|
100% { transform: rotate(360deg); }
|
|
}
|
|
@media (prefers-color-scheme: dark) {
|
|
:root { --bg-color: #1a1a1a; --text-color: #ffffff; }
|
|
}
|
|
</style>
|
|
`;
|
|
|
|
if (document.body) {
|
|
document.body.appendChild(loadingDiv);
|
|
} else {
|
|
document.addEventListener('DOMContentLoaded', () => {
|
|
if (document.body && !document.getElementById('initial-loading-overlay')) {
|
|
document.body.appendChild(loadingDiv);
|
|
}
|
|
});
|
|
}
|
|
}
|
|
|
|
createLoadingOverlay();
|
|
|
|
if (document.readyState === 'loading') {
|
|
document.addEventListener('DOMContentLoaded', createLoadingOverlay);
|
|
} else {
|
|
createLoadingOverlay();
|
|
}
|
|
|
|
console.log('[Tauri] 窗口初始化脚本执行完成');
|
|
"#;
|
|
|
|
pub const INITIAL_LOADING_OVERLAY: &str = r"
|
|
const overlay = document.getElementById('initial-loading-overlay');
|
|
if (overlay) {
|
|
overlay.style.opacity = '0';
|
|
setTimeout(() => overlay.remove(), 300);
|
|
}
|
|
";
|