<script lang="ts" setup>
const route = useRoute()

const wideLayout = computed(() => route.meta.wideLayout ?? false)
</script>

<template>
  <div h-full :class="{ zen: isZenMode }">
    <div v-if="isHydrated.value && showUserSwitcherSidebar" fixed h-full hidden lg:block bg-code border-r-1 border-base>
      <UserPicker />
    </div>
    <main flex w-full mxa lg:max-w-80rem :class="isHydrated.value && showUserSwitcherSidebar ? 'user-switcher-sidebar' : ''">
      <aside class="hidden sm:flex w-1/8 md:w-1/6 justify-end lg:w-1/4 zen-hide" relative>
        <div sticky top-0 w-20 lg:w-100 h-screen flex="~ col">
          <slot name="left">
            <NavTitle mx3 mt4 mb2 self-start />
            <div flex="~ col" overflow-y-auto justify-between h-full>
              <div flex flex-col>
                <NavSide />
                <PublishButton m5 />
              </div>
              <div v-if="isMastoInitialised" flex flex-col>
                <UserSignInEntry v-if="!currentUser" sm:hidden />
                <div v-if="currentUser" p6 pb8 w-full flex="~" items-center justify-between>
                  <NuxtLink
                    hidden lg:block
                    rounded-full text-start w-full
                    hover:bg-active cursor-pointer transition-100
                    :to="getAccountRoute(currentUser.account)"
                  >
                    <AccountInfo :account="currentUser.account" md:break-words />
                  </NuxtLink>
                  <VDropdown :distance="0" placement="bottom-end">
                    <button btn-action-icon :aria-label="$t('action.switch_account')">
                      <div hidden lg:block i-ri:more-2-line />
                      <AccountAvatar lg:hidden :account="currentUser.account" w-9 h-9 />
                    </button>
                    <template #popper="{ hide }">
                      <UserSwitcher @click="hide" />
                    </template>
                  </VDropdown>
                </div>
              </div>
            </div>
          </slot>
        </div>
      </aside>
      <div class="w-full min-h-screen" :class="wideLayout ? 'lg:w-full sm:w-600px' : 'sm:w-600px'" sm:border-l sm:border-r border-base>
        <div min-h="[calc(100vh-3.5rem)]" sm:min-h-screen>
          <slot />
        </div>
        <div sm:hidden sticky left-0 right-0 bottom-0 z-10 bg-base pb="[env(safe-area-inset-bottom)]" transition="padding 20">
          <CommonOfflineChecker :small-screen="isHydrated.value" />
          <NavBottom v-if="isHydrated.value" />
        </div>
      </div>
      <aside v-if="!wideLayout" class="hidden sm:none lg:block w-1/4 zen-hide">
        <div sticky top-0 h-screen flex="~ col" py3>
          <slot name="right">
            <SearchWidget />
            <div flex-auto />
            <PwaPrompt />
            <NavFooter />
          </slot>
        </div>
      </aside>
    </main>
    <ModalContainer />
  </div>
</template>

<style scoped>
@media (max-width: 1500px) and (min-width: 1024px) {
  .user-switcher-sidebar {
    padding-left: min(5rem, calc((1500px - 100vw) / 2));
  }
}
</style>