You've already forked AstralRinth
forked from didirus/AstralRinth
* feat(theseus): Initial migration to Tauri v2 * feat(theseus): Added a way to zoom / scale UI * chore(theseus): Started cleaning up some plugins * fix(theseus): Github Actions * refactor(theseus): Reduced boilerplate & more work * feat(theseus): Allow multiple app instances to be open at once (#995) * fix(theseus): Lint & more * fix(theseus): App Release github action * fix(theseus): Open links in browser & macos builds * fix(theseus): Rebase fixes * fix(theseus): Updater & app release action * fix(theseus): Fixed definitions in `build.rs` * Fix MacOS deep linking, window decorations * fix(theseus): Closing & maximizing app * Fix macos build * add back release conf * acc fix build * make updater for release builds only * focus window on startup --------- Co-authored-by: Jai A <jaiagr+gpg@pm.me> Co-authored-by: Geometrically <18202329+Geometrically@users.noreply.github.com>
64 lines
1.6 KiB
Vue
64 lines
1.6 KiB
Vue
<script setup lang="ts">
|
|
import { DropdownIcon, FolderOpenIcon, SearchIcon } from '@modrinth/assets'
|
|
import { Button, OverflowMenu } from '@modrinth/ui'
|
|
import { open } from '@tauri-apps/plugin-dialog'
|
|
import { add_project_from_path } from '@/helpers/profile.js'
|
|
import { handleError } from '@/store/notifications.js'
|
|
import { useRouter } from 'vue-router'
|
|
|
|
const props = defineProps({
|
|
instance: {
|
|
type: Object,
|
|
required: true,
|
|
},
|
|
})
|
|
|
|
const router = useRouter()
|
|
|
|
const handleAddContentFromFile = async () => {
|
|
const newProject = await open({ multiple: true })
|
|
if (!newProject) return
|
|
|
|
for (const project of newProject) {
|
|
await add_project_from_path(props.instance.path, project).catch(handleError)
|
|
}
|
|
}
|
|
|
|
const handleSearchContent = async () => {
|
|
await router.push({
|
|
path: `/browse/${props.instance.loader === 'vanilla' ? 'datapack' : 'mod'}`,
|
|
query: { i: props.instance.path },
|
|
})
|
|
}
|
|
</script>
|
|
|
|
<template>
|
|
<div class="joined-buttons">
|
|
<Button color="primary" @click="handleSearchContent"><SearchIcon /> Add content </Button>
|
|
|
|
<OverflowMenu
|
|
:options="[
|
|
{
|
|
id: 'search',
|
|
action: handleSearchContent,
|
|
},
|
|
{
|
|
id: 'from_file',
|
|
action: handleAddContentFromFile,
|
|
},
|
|
]"
|
|
class="btn btn-primary btn-dropdown-animation icon-only"
|
|
>
|
|
<DropdownIcon />
|
|
<template #search>
|
|
<SearchIcon />
|
|
<span class="no-wrap"> Search </span>
|
|
</template>
|
|
<template #from_file>
|
|
<FolderOpenIcon />
|
|
<span class="no-wrap"> Add from file </span>
|
|
</template>
|
|
</OverflowMenu>
|
|
</div>
|
|
</template>
|