Add topnav layout with MainNavigation, SubNavigation, GlobalSearchBar, SplitLayout
Some checks failed
Build Docker Image / build (push) Failing after 1m25s

This commit is contained in:
Ruslan Bakiev
2026-01-08 01:03:07 +07:00
parent 4235c9f1e9
commit 737ec91473
11 changed files with 775 additions and 0 deletions

View File

@@ -0,0 +1,49 @@
<template>
<div class="flex-1 flex flex-col lg:flex-row min-h-0">
<!-- List panel -->
<div
class="flex-1 overflow-auto lg:w-3/5 lg:max-w-none"
:class="{ 'hidden lg:block': mobileView === 'map' }"
>
<slot name="list" />
</div>
<!-- Map panel -->
<div
class="lg:w-2/5 lg:sticky lg:top-0 lg:h-[calc(100vh-13rem)]"
:class="{ 'hidden lg:block': mobileView === 'list', 'flex-1': mobileView === 'map' }"
>
<slot name="map" />
</div>
<!-- Mobile toggle -->
<div class="lg:hidden fixed bottom-4 left-1/2 -translate-x-1/2 z-30">
<div class="btn-group shadow-lg">
<button
class="btn btn-sm"
:class="{ 'btn-active': mobileView === 'list' }"
@click="mobileView = 'list'"
>
<Icon name="lucide:list" size="16" />
{{ $t('common.list') }}
</button>
<button
class="btn btn-sm"
:class="{ 'btn-active': mobileView === 'map' }"
@click="mobileView = 'map'"
>
<Icon name="lucide:map" size="16" />
{{ $t('common.map') }}
</button>
</div>
</div>
</div>
</template>
<script setup lang="ts">
const props = defineProps<{
defaultView?: 'list' | 'map'
}>()
const mobileView = ref<'list' | 'map'>(props.defaultView || 'list')
</script>