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>
62 lines
1.1 KiB
Vue
62 lines
1.1 KiB
Vue
<script setup lang="ts">
|
|
import { DropdownIcon } from '@modrinth/assets'
|
|
import { reactive } from 'vue'
|
|
import Button from './Button.vue'
|
|
|
|
const props = defineProps({
|
|
collapsible: {
|
|
type: Boolean,
|
|
default: false,
|
|
},
|
|
defaultCollapsed: {
|
|
type: Boolean,
|
|
default: false,
|
|
},
|
|
noAutoBody: {
|
|
type: Boolean,
|
|
default: false,
|
|
},
|
|
})
|
|
|
|
const state = reactive({
|
|
collapsed: props.defaultCollapsed,
|
|
})
|
|
|
|
function toggleCollapsed() {
|
|
state.collapsed = !state.collapsed
|
|
}
|
|
</script>
|
|
|
|
<template>
|
|
<div class="card">
|
|
<div v-if="!!$slots.header || collapsible" class="header">
|
|
<slot name="header"></slot>
|
|
<div v-if="collapsible" class="btn-group">
|
|
<Button :action="toggleCollapsed">
|
|
<DropdownIcon :style="{ transform: `rotate(${state.collapsed ? 0 : 180}deg)` }" />
|
|
</Button>
|
|
</div>
|
|
</div>
|
|
<slot v-if="!state.collapsed" />
|
|
</div>
|
|
</template>
|
|
|
|
<style lang="scss" scoped>
|
|
.header {
|
|
display: flex;
|
|
|
|
:deep(h1, h2, h3, h4) {
|
|
margin-block: 0;
|
|
}
|
|
|
|
&:not(:last-child) {
|
|
margin-bottom: var(--gap-lg);
|
|
}
|
|
}
|
|
|
|
.btn-group {
|
|
margin-left: auto;
|
|
margin-right: 0;
|
|
}
|
|
</style>
|