feat: show sub tile of manual
Some checks failed
Spell Check / Spell Check with Typos (push) Failing after 8s
Some checks failed
Spell Check / Spell Check with Typos (push) Failing after 8s
This commit is contained in:
parent
34079ac9c6
commit
d7e33fe817
2 changed files with 47 additions and 4 deletions
|
|
@ -1,28 +1,71 @@
|
||||||
<script setup lang="ts">
|
<script setup lang="ts">
|
||||||
// NOTE: Library
|
// NOTE: Library
|
||||||
import { storeToRefs } from 'pinia';
|
import { storeToRefs } from 'pinia';
|
||||||
|
import { onMounted, ref } from 'vue';
|
||||||
|
import { useRouter } from 'vue-router';
|
||||||
|
|
||||||
// NOTE: Components
|
// NOTE: Components
|
||||||
|
|
||||||
// NOTE: Stores & Type
|
// NOTE: Stores & Type
|
||||||
|
|
||||||
|
import { Manual } from 'src/stores/manual/types';
|
||||||
import { useManualStore } from 'src/stores/manual';
|
import { useManualStore } from 'src/stores/manual';
|
||||||
import { onMounted } from 'vue';
|
import { useNavigator } from 'src/stores/navigator';
|
||||||
|
|
||||||
// NOTE: Variable
|
// NOTE: Variable
|
||||||
const manualStore = useManualStore();
|
const manualStore = useManualStore();
|
||||||
|
const navigatorStore = useNavigator();
|
||||||
const { dataManual } = storeToRefs(manualStore);
|
const { dataManual } = storeToRefs(manualStore);
|
||||||
|
const selectedManual = ref<string>('');
|
||||||
|
const router = useRouter();
|
||||||
|
|
||||||
async function fatchManual() {
|
async function fatchManual() {
|
||||||
const res = await manualStore.getManual();
|
const res = await manualStore.getManual();
|
||||||
dataManual.value = res ? res : [];
|
dataManual.value = res ? res : [];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function navigateTo(path: string) {
|
||||||
|
router.push(`${path}`);
|
||||||
|
}
|
||||||
|
|
||||||
onMounted(async () => {
|
onMounted(async () => {
|
||||||
|
navigatorStore.current.title = 'menu.manual.title';
|
||||||
|
navigatorStore.current.path = [{ text: '' }];
|
||||||
await fatchManual();
|
await fatchManual();
|
||||||
});
|
});
|
||||||
</script>
|
</script>
|
||||||
|
|
||||||
<template>
|
<template>
|
||||||
<div></div>
|
<div
|
||||||
|
class="column full-height no-wrap surface-1 rounded bordered overflow-hidden q-pa-sm"
|
||||||
|
>
|
||||||
|
<section class="scroll">
|
||||||
|
<template v-for="v in dataManual">
|
||||||
|
<q-item clickable dense class="items-center rounded">
|
||||||
|
{{ v.label }}
|
||||||
|
</q-item>
|
||||||
|
<template v-if="v.page">
|
||||||
|
<div class="q-pl-md">
|
||||||
|
<q-item
|
||||||
|
v-for="x in v.page"
|
||||||
|
clickable
|
||||||
|
dense
|
||||||
|
class="dot items-center rounded"
|
||||||
|
@click="() => navigateTo(`${v.category}/${x.name}`)"
|
||||||
|
>
|
||||||
|
{{ x.label }}
|
||||||
|
</q-item>
|
||||||
|
</div>
|
||||||
|
</template>
|
||||||
|
</template>
|
||||||
|
</section>
|
||||||
|
</div>
|
||||||
</template>
|
</template>
|
||||||
|
|
||||||
|
<style scoped>
|
||||||
|
.dot::before {
|
||||||
|
content: '•';
|
||||||
|
margin-right: 8px;
|
||||||
|
font-size: 1.2em;
|
||||||
|
}
|
||||||
|
</style>
|
||||||
|
|
|
||||||
|
|
@ -6,7 +6,7 @@ export type Manual = {
|
||||||
};
|
};
|
||||||
|
|
||||||
type Page = {
|
type Page = {
|
||||||
namee: string;
|
name: string;
|
||||||
label: string;
|
label: string;
|
||||||
labelEN: string;
|
labelEN: string;
|
||||||
};
|
};
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue