<template>
  <div
    id="app"
    :class="{
      hideOutlines: hideOutlines,
      rightAligned: isRightAligned
    }"
  >
    <top-nav ref="topNav" />
    <side-nav ref="sideNav" />
    <ft-flex-box
      v-if="showUpdatesBanner || showBlogBanner"
      class="flexBox routerView"
      :class="{ expand: !isOpen }"
    >
      <ft-notification-banner
        v-if="showUpdatesBanner"
        class="banner"
        :message="updateBannerMessage"
        @click="handleUpdateBannerClick"
      />
      <ft-notification-banner
        v-if="showBlogBanner"
        class="banner"
        :message="blogBannerMessage"
        @click="handleNewBlogBannerClick"
      />
    </ft-flex-box>
    <transition
      mode="out-in"
      name="fade"
    >
      <!-- <keep-alive> -->
      <RouterView
        ref="router"
        class="routerView"
        :class="{ expand: !isOpen }"
      />
      <!-- </keep-alive> -->
    </transition>
    <ft-prompt
      v-if="showReleaseNotes"
      @click="showReleaseNotes = !showReleaseNotes"
    >
      <h2>
        {{ changeLogTitle }}
      </h2>
      <span v-html="updateChangelog" />
      <ft-flex-box>
        <ft-button
          :label="$t('Download From Site')"
          @click="openDownloadsPage"
        />
      </ft-flex-box>
    </ft-prompt>
    <ft-toast />
    <ft-progress-bar
      v-if="showProgressBar"
    />
  </div>
</template>

<script src="./App.js" />

<style src="./themes.css" />
<style src="./videoJS.css" />
<style scoped src="./App.css" />