jointrashposs/components/content/MkIndex.vue

72 lines
1.9 KiB
Vue
Raw Normal View History

2023-07-11 19:19:32 +02:00
<template>
<div :class="['grid grid-cols-1 md:grid-cols-2 gap-4', wide && 'lg:grid-cols-3']">
<ContentNavigation v-slot="{ navigation }" :query="query">
<GNuxtLink
class="block p-4 rounded-lg border border-slate-200 dark:border-accent-900 transition-colors hover:bg-slate-100 dark:hover:bg-slate-800 hover:!no-underline"
v-for="item in findDeepObject((navigation[0] as Record<string, any>), (v) => realBasePath.replace(/\/$/, '') === v?._path.replace(/\/$/, ''))?.children ?? []"
:key="item._path"
:to="localePath(item._path)"
>
<h3 class="font-bold !text-lg !mt-0 !mb-2">
2023-07-11 19:19:32 +02:00
{{ item.navTitle || item.title }}<ArrowRightIco class="ml-1.5" />
</h3>
<p class="text-sm text-slate-500 dark:text-slate-400 !mb-0 truncate-box">
2023-07-11 19:19:32 +02:00
{{ item.description ?? "" }}
</p>
</GNuxtLink>
</ContentNavigation>
</div>
</template>
<script setup lang="ts">
import ArrowRightIco from "bi/arrow-right.svg";
const route = useRoute();
const { locale } = useI18n();
const props = withDefaults(defineProps<{
basePath?: string;
wide?: boolean;
}>(), {
wide: false,
});
const realBasePath = computed<string>(() => {
if (props.basePath) {
return props.basePath;
}
return route.path.replace(/^.*\/docs/, `/${locale.value}/docs`);
});
const localePath = useLocalePath();
const findDeepObject = (obj: Record<string, any>, condition: (v: any) => boolean): Record<string, any> | null => {
if (condition(obj)) {
return obj;
}
2023-07-13 18:00:20 +02:00
if (obj?.children && obj.children.length > 0) {
2023-07-11 19:19:32 +02:00
for (let i = 0; i < obj.children.length; i++) {
const result = findDeepObject(obj.children[i], condition);
if (result) {
return result;
}
}
}
return null;
};
const query = queryContent(realBasePath.value);
</script>
<style scoped>
.truncate-box {
-webkit-line-clamp: 2;
-webkit-box-orient: vertical;
overflow: hidden;
text-overflow: ellipsis;
word-break: break-all;
display: -webkit-box;
}
</style>