You've already forked AstralRinth
forked from didirus/AstralRinth
* fix tauri config * fix package patch * regen pnpm lock * use new workflow * New GH actions * Update lockfile * update scripts * Fix build script * Fix missing deps * Fix assets eslint * Update libraries lint * Fix all lint configs * update lockfile * add fmt + clippy fails * Separate App Tauri portion * fix app features * Fix lints * install tauri cli * update lockfile * corepack, fix lints * add store path * fix unused import * Fix tests * Issue templates + port over tauri release * fix actions * fix before build command * Add X86 target * Update build matrix * finalize actions * make debug build smaller * Use debug build to make cache smaller * dummy commit * change proj name * update file name * Use release builds for less space use * Remove rust cache * Readd for app build * add merge queue trigger
181 lines
5.7 KiB
JavaScript
181 lines
5.7 KiB
JavaScript
/**
|
|
* All theseus API calls return serialized values (both return values and errors);
|
|
* So, for example, addDefaultInstance creates a blank Profile object, where the Rust struct is serialized,
|
|
* and deserialized into a usable JS object.
|
|
*/
|
|
import { invoke } from '@tauri-apps/api/tauri'
|
|
|
|
/// Add instance
|
|
/*
|
|
name: String, // the name of the profile, and relative path to create
|
|
game_version: String, // the game version of the profile
|
|
modloader: ModLoader, // the modloader to use
|
|
- ModLoader is an enum, with the following variants: Vanilla, Forge, Fabric, Quilt
|
|
loader_version: String, // the modloader version to use, set to "latest", "stable", or the ID of your chosen loader
|
|
icon: Path, // the icon for the profile
|
|
- icon is a path to an image file, which will be copied into the profile directory
|
|
*/
|
|
|
|
export async function create(name, gameVersion, modloader, loaderVersion, icon, noWatch) {
|
|
//Trim string name to avoid "Unable to find directory"
|
|
name = name.trim()
|
|
return await invoke('plugin:profile_create|profile_create', {
|
|
name,
|
|
gameVersion,
|
|
modloader,
|
|
loaderVersion,
|
|
icon,
|
|
noWatch,
|
|
})
|
|
}
|
|
|
|
// duplicate a profile
|
|
export async function duplicate(path) {
|
|
return await invoke('plugin:profile_create|profile_duplicate', { path })
|
|
}
|
|
|
|
// Remove a profile
|
|
export async function remove(path) {
|
|
return await invoke('plugin:profile|profile_remove', { path })
|
|
}
|
|
|
|
// Get a profile by path
|
|
// Returns a Profile
|
|
export async function get(path, clearProjects) {
|
|
return await invoke('plugin:profile|profile_get', { path, clearProjects })
|
|
}
|
|
|
|
// Get a profile's full fs path
|
|
// Returns a path
|
|
export async function get_full_path(path) {
|
|
return await invoke('plugin:profile|profile_get_full_path', { path })
|
|
}
|
|
|
|
// Get's a mod's full fs path
|
|
// Returns a path
|
|
export async function get_mod_full_path(path, projectPath) {
|
|
return await invoke('plugin:profile|profile_get_mod_full_path', { path, projectPath })
|
|
}
|
|
|
|
// Get optimal java version from profile
|
|
// Returns a java version
|
|
export async function get_optimal_jre_key(path) {
|
|
return await invoke('plugin:profile|profile_get_optimal_jre_key', { path })
|
|
}
|
|
|
|
// Get a copy of the profile set
|
|
// Returns hashmap of path -> Profile
|
|
export async function list(clearProjects) {
|
|
return await invoke('plugin:profile|profile_list', { clearProjects })
|
|
}
|
|
|
|
export async function check_installed(path, projectId) {
|
|
return await invoke('plugin:profile|profile_check_installed', { path, projectId })
|
|
}
|
|
|
|
// Installs/Repairs a profile
|
|
export async function install(path, force) {
|
|
return await invoke('plugin:profile|profile_install', { path, force })
|
|
}
|
|
|
|
// Updates all of a profile's projects
|
|
export async function update_all(path) {
|
|
return await invoke('plugin:profile|profile_update_all', { path })
|
|
}
|
|
|
|
// Updates a specified project
|
|
export async function update_project(path, projectPath) {
|
|
return await invoke('plugin:profile|profile_update_project', { path, projectPath })
|
|
}
|
|
|
|
// Add a project to a profile from a version
|
|
// Returns a path to the new project file
|
|
export async function add_project_from_version(path, versionId) {
|
|
return await invoke('plugin:profile|profile_add_project_from_version', { path, versionId })
|
|
}
|
|
|
|
// Add a project to a profile from a path + project_type
|
|
// Returns a path to the new project file
|
|
export async function add_project_from_path(path, projectPath, projectType) {
|
|
return await invoke('plugin:profile|profile_add_project_from_path', {
|
|
path,
|
|
projectPath,
|
|
projectType,
|
|
})
|
|
}
|
|
|
|
// Toggle disabling a project
|
|
export async function toggle_disable_project(path, projectPath) {
|
|
return await invoke('plugin:profile|profile_toggle_disable_project', { path, projectPath })
|
|
}
|
|
|
|
// Remove a project
|
|
export async function remove_project(path, projectPath) {
|
|
return await invoke('plugin:profile|profile_remove_project', { path, projectPath })
|
|
}
|
|
|
|
// Update a managed Modrinth profile to a specific version
|
|
export async function update_managed_modrinth_version(path, versionId) {
|
|
return await invoke('plugin:profile|profile_update_managed_modrinth_version', { path, versionId })
|
|
}
|
|
|
|
// Repair a managed Modrinth profile
|
|
export async function update_repair_modrinth(path) {
|
|
return await invoke('plugin:profile|profile_repair_managed_modrinth', { path })
|
|
}
|
|
|
|
// Export a profile to .mrpack
|
|
/// included_overrides is an array of paths to override folders to include (ie: 'mods', 'resource_packs')
|
|
// Version id is optional (ie: 1.1.5)
|
|
export async function export_profile_mrpack(
|
|
path,
|
|
exportLocation,
|
|
includedOverrides,
|
|
versionId,
|
|
description,
|
|
name,
|
|
) {
|
|
return await invoke('plugin:profile|profile_export_mrpack', {
|
|
path,
|
|
exportLocation,
|
|
includedOverrides,
|
|
versionId,
|
|
description,
|
|
name,
|
|
})
|
|
}
|
|
|
|
// Given a folder path, populate an array of all the subfolders
|
|
// Intended to be used for finding potential override folders
|
|
// profile
|
|
// -- mods
|
|
// -- resourcepacks
|
|
// -- file1
|
|
// => [mods, resourcepacks]
|
|
// allows selection for 'included_overrides' in export_profile_mrpack
|
|
export async function get_pack_export_candidates(profilePath) {
|
|
return await invoke('plugin:profile|profile_get_pack_export_candidates', { profilePath })
|
|
}
|
|
|
|
// Run Minecraft using a pathed profile
|
|
// Returns PID of child
|
|
export async function run(path) {
|
|
return await invoke('plugin:profile|profile_run', { path })
|
|
}
|
|
|
|
// Run Minecraft using a pathed profile
|
|
// Waits for end
|
|
export async function run_wait(path) {
|
|
return await invoke('plugin:profile|profile_run_wait', { path })
|
|
}
|
|
|
|
// Edits a profile
|
|
export async function edit(path, editProfile) {
|
|
return await invoke('plugin:profile|profile_edit', { path, editProfile })
|
|
}
|
|
|
|
// Edits a profile's icon
|
|
export async function edit_icon(path, iconPath) {
|
|
return await invoke('plugin:profile|profile_edit_icon', { path, iconPath })
|
|
}
|