<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" />