You've already forked AstralRinth
forked from didirus/AstralRinth
* Make theseus capable of logging messages from the `log` crate * Move update checking entirely into JS and open a modal if an update is available * Fix formatjs on Windows and run formatjs * Add in the buttons and body * Fix lint * Show update size in modal * Fix update not being rechecked if the update modal was directly dismissed * Slight UI tweaks * Fix lint * Implement skipping the update * Implement the Update Now button * Implement updating at next exit * Turn download progress into an error bar on failure * Restore 5 minute update check instead of 30 seconds * Fix PendingUpdateData being seen as a unit struct * Fix lint * Make CI also lint updater code * feat: create AppearingProgressBar component * feat: polish update available modal * feat: add error handling * Open changelog with tauri-plugin-opener * Run intl:extract * Update completion toasts (#3978) * Use single LAUNCHER_USER_AGENT constant for all user agents * Fix build on Mac * Request the update size with HEAD instead of GET * UI tweaks * lint * Fix lint * fix: hide modal header & add "Hide update reminder" button w/ tooltip * Run intl:extract * fix: lint issues * fix: merge issues * notifications.js no longer exists * Add metered network checking * Add a timeout to macOS is_network_metered * Fix tauri.conf.json * vibe debugging * Set a dispatch queue * Have a popup that asks you if you'd like to disable automatic file downloads if you're on a metered network * Move UpdateModal to modal package * Fix lint * Add a toggle for automatic downloads * Fix type Co-authored-by: Alejandro González <7822554+AlexTMjugador@users.noreply.github.com> Signed-off-by: Josiah Glosson <soujournme@gmail.com> * Redo updating UI and experience * lint * fix unlistener issue * remove unneeded translation keys * Fix expose issue * temp disable cranelift, tweak some messages * change version back * Clean up App.vue * move toast to top right * update reload icon * Fixed the bug!!!!!!!!!!!! * improve messages * intl:extract * Add liquid glass icon file * not you! * use dependency injection * lint on apple icon * Fix imports, move download size to button * change update check back to 5 mins * lint + move to providers * intl:extract --------- Signed-off-by: Cal H. <hendersoncal117@gmail.com> Signed-off-by: Josiah Glosson <soujournme@gmail.com> Co-authored-by: Calum <calum@modrinth.com> Co-authored-by: Prospector <prospectordev@gmail.com> Co-authored-by: Cal H. <hendersoncal117@gmail.com> Co-authored-by: Prospector <6166773+Prospector@users.noreply.github.com> Co-authored-by: Alejandro González <7822554+AlexTMjugador@users.noreply.github.com>
77 lines
1.9 KiB
JavaScript
77 lines
1.9 KiB
JavaScript
import { invoke } from '@tauri-apps/api/core'
|
|
|
|
import { get_full_path, get_mod_full_path } from '@/helpers/profile'
|
|
|
|
export async function isDev() {
|
|
return await invoke('is_dev')
|
|
}
|
|
|
|
export async function areUpdatesEnabled() {
|
|
return await invoke('are_updates_enabled')
|
|
}
|
|
|
|
export async function getUpdateSize(updateRid) {
|
|
return await invoke('get_update_size', { rid: updateRid })
|
|
}
|
|
|
|
export async function enqueueUpdateForInstallation(updateRid) {
|
|
return await invoke('enqueue_update_for_installation', { rid: updateRid })
|
|
}
|
|
|
|
export async function removeEnqueuedUpdate() {
|
|
return await invoke('remove_enqueued_update')
|
|
}
|
|
|
|
// One of 'Windows', 'Linux', 'MacOS'
|
|
export async function getOS() {
|
|
return await invoke('plugin:utils|get_os')
|
|
}
|
|
|
|
export async function isNetworkMetered() {
|
|
return await invoke('plugin:utils|is_network_metered')
|
|
}
|
|
|
|
export async function openPath(path) {
|
|
return await invoke('plugin:utils|open_path', { path })
|
|
}
|
|
|
|
export async function highlightInFolder(path) {
|
|
return await invoke('plugin:utils|highlight_in_folder', { path })
|
|
}
|
|
|
|
export async function showLauncherLogsFolder() {
|
|
return await invoke('plugin:utils|show_launcher_logs_folder', {})
|
|
}
|
|
|
|
// Opens a profile's folder in the OS file explorer
|
|
export async function showProfileInFolder(path) {
|
|
const fullPath = await get_full_path(path)
|
|
return await openPath(fullPath)
|
|
}
|
|
|
|
export async function highlightModInProfile(profilePath, projectPath) {
|
|
const fullPath = await get_mod_full_path(profilePath, projectPath)
|
|
return await highlightInFolder(fullPath)
|
|
}
|
|
|
|
export async function restartApp() {
|
|
return await invoke('restart_app')
|
|
}
|
|
|
|
export const releaseColor = (releaseType) => {
|
|
switch (releaseType) {
|
|
case 'release':
|
|
return 'green'
|
|
case 'beta':
|
|
return 'orange'
|
|
case 'alpha':
|
|
return 'red'
|
|
default:
|
|
return ''
|
|
}
|
|
}
|
|
|
|
export async function copyToClipboard(text) {
|
|
await navigator.clipboard.writeText(text)
|
|
}
|