Skip to content

Commit

Permalink
docs: add VueSchool Summer Sale banner (#3564)
Browse files Browse the repository at this point in the history
  • Loading branch information
nicodevs committed Jun 14, 2021
1 parent 11dd184 commit 046a093
Show file tree
Hide file tree
Showing 7 changed files with 276 additions and 44 deletions.
10 changes: 8 additions & 2 deletions docs/.vuepress/components/HomeSponsors.vue
Expand Up @@ -27,11 +27,17 @@ export default {
<style>
#sponsors {
text-align: center;
padding: 35px 40px 45px;
margin: 0 -2rem;
padding: 35px 30px 45px;
background-color: #f6f6f6;
}
@media (min-width: 768px) {
#sponsors {
padding: 35px 40px 45px;
margin: 0 -2rem;
}
}
#sponsors h3 {
color: #999;
margin: 0 0 10px;
Expand Down
7 changes: 7 additions & 0 deletions docs/.vuepress/public/images/vueschool/close.svg
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
13 changes: 13 additions & 0 deletions docs/.vuepress/public/images/vueschool/vs-iso.svg
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
16 changes: 16 additions & 0 deletions docs/.vuepress/public/images/vueschool/vs-logo.svg
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
104 changes: 62 additions & 42 deletions docs/.vuepress/theme/Layout.vue
@@ -1,42 +1,51 @@
<template>
<ParentLayout>
<template #page-top>
<CarbonAds
v-if="$site.themeConfig.carbonAds"
:key="'ca:' + $page.path"
:code="$site.themeConfig.carbonAds.carbon"
:placement="$site.themeConfig.carbonAds.placement"
/>
</template>
<template #page-bottom>
<BuySellAds
v-if="$site.themeConfig.carbonAds"
:key="'bsa:' + $page.path"
:code="$site.themeConfig.carbonAds.custom"
:placement="$site.themeConfig.carbonAds.placement"
/>
</template>
<template #sidebar-bottom>
<div class="sponsors">
<a
href="https://github.com/sponsors/posva"
target="_blank"
rel="noopener"
>Sponsors</a
>
<div
class="main-container"
:class="{ 'has-top-banner': showTopBanner }"
>
<BannerTop
v-if="showTopBanner"
@close="closeBannerTop"
/>
<ParentLayout>
<template #page-top>
<CarbonAds
v-if="$site.themeConfig.carbonAds"
:key="'ca:' + $page.path"
:code="$site.themeConfig.carbonAds.carbon"
:placement="$site.themeConfig.carbonAds.placement"
/>
</template>
<template #page-bottom>
<BuySellAds
v-if="$site.themeConfig.carbonAds"
:key="'bsa:' + $page.path"
:code="$site.themeConfig.carbonAds.custom"
:placement="$site.themeConfig.carbonAds.placement"
/>
</template>
<template #sidebar-bottom>
<div class="sponsors">
<a
href="https://github.com/sponsors/posva"
target="_blank"
rel="noopener"
>Sponsors</a
>

<a
v-for="sponsor in sponsors.gold"
:href="sponsor.href"
:key="sponsor.href"
target="_blank"
rel="noopener"
>
<img :src="sponsor.imgSrcLight" :alt="sponsor.alt" />
</a>
</div>
</template>
</ParentLayout>
<a
v-for="sponsor in sponsors.gold"
:href="sponsor.href"
:key="sponsor.href"
target="_blank"
rel="noopener"
>
<img :src="sponsor.imgSrcLight" :alt="sponsor.alt" />
</a>
</div>
</template>
</ParentLayout>
</div>
</template>

<script>
Expand All @@ -47,15 +56,26 @@ import sponsors from '../components/sponsors.json'
export default {
name: 'Layout',
components: {
ParentLayout,
CarbonAds,
BuySellAds
BuySellAds,
BannerTop: () => import('./components/BannerTop.vue')
},
created() {
this.sponsors = sponsors
data () {
return {
sponsors,
showTopBanner: false
}
},
mounted () {
this.showTopBanner = !localStorage.getItem('VS_SUMMER_BANNER_CLOSED')
},
methods: {
closeBannerTop () {
this.showTopBanner = false
localStorage.setItem('VS_SUMMER_BANNER_CLOSED', 1)
}
}
}
</script>
Expand Down
170 changes: 170 additions & 0 deletions docs/.vuepress/theme/components/BannerTop.vue
@@ -0,0 +1,170 @@
<template>
<a id="vs" href="https://vueschool.io/sales/summer-vue?friend=vuerouter" target="_blank" rel="noreferrer">
<div class="vs-iso">
<img src="/images/vueschool/vs-iso.svg" alt="Vue School Logo">
</div>
<div class="vs-logo">
<img src="/images/vueschool/vs-logo.svg" alt="Vue School Logo">
</div>
<div class="vs-core">
<div class="vs-backpack">
<img src="/images/vueschool/vs-backpack.png" alt="Backpack">
</div>
<div class="vs-slogan">
3-months Vue School for only $49 <span style="text-decoration: line-through">$75</span>!
<span class="vs-slogan-light">
Limited Time Offer
</span>
</div>
<div class="vs-button">
GET ACCESS
</div>
</div>
<div
id="vs-close"
class="vs-close"
@click.stop.prevent="$emit('close')">
<img src="/images/vueschool/close.svg" alt="Close">
</div>
</a>
</template>

<style lang="stylus">
$topBannerHeight ?= 5rem
$topBannerHeightMobile ?= 3.125rem
$navbarHeight ?= 3.6rem
$contentClass = '.theme-default-content'
@import url('https://fonts.googleapis.com/css?family=Roboto')
// Banner
#vs
align-items: center
background-color: #202A5A
box-sizing: border-box
color: #fff
display: none
font-family 'Roboto', Oxygen, Fira Sans, Helvetica Neue, sans-serif
justify-content: center
position: fixed
padding: 0 10px
left: 0
right: 0
top: 0
z-index: 100
height: $topBannerHeightMobile
@media (min-width: 680px)
height: $topBannerHeight
&:hover
.vs-core
.vs-button
background: #f22606
.vs-iso
position: absolute
left: 20px
height: 26px
display: none
img
height: 26px
@media (min-width: 680px)
display: block
left: 40px
height: 40px
img
height: 40px
@media (min-width: 900px)
display: none
.vs-logo
position: absolute
display: none
left: 40px
@media (min-width: 900px)
display: block
.vs-core
display: flex
align-items: center
margin-right: 20px
@media (min-width: 680px)
margin-right: 0
.vs-backpack
margin-right: 6px
@media (min-width: 680px)
margin-right: 14px
img
height: 50px
@media (min-width: 680px)
height: 74px
.vs-slogan
color: #FFF
font-weight: bold
font-size: 14px
@media (min-width: 680px)
font-size: 18px
> .vs-slogan-light
color: #ff5338
display: block
text-align: left
@media (min-width: 900px)
text-align: center
display: inline
.vs-button
margin-left: 43px
color: #FFF
padding: 13px 24px
border-radius: 40px
display: none
background: #ff5338
font-weight: bold
@media (min-width: 680px)
display: inline-block
.vs-close
right: 10px
position: absolute
padding: 10px
@media (min-width: 680px)
right: 20px
&:hover
color: #56D8FF
/************************************/
// Show banner only if the container has class "has-top-banner"
.main-container.has-top-banner
#vs
display: flex
// Add margin top to body, navbar and sidebar
.main-container.has-top-banner
margin-top: $topBannerHeightMobile
.navbar
margin-top: $topBannerHeightMobile
.sidebar
margin-top: $topBannerHeightMobile
@media (min-width: 680px)
.main-container.has-top-banner
margin-top: $topBannerHeight
.navbar
margin-top: $topBannerHeight
.sidebar
margin-top: $topBannerHeight
// Adjust titles margin and padding for anchor links
.main-container.has-top-banner
{$contentClass}:not(.custom)
h1, h2, h3, h4, h5, h6
margin-top (2.5rem - $topBannerHeightMobile - $navbarHeight)
padding-top ($navbarHeight + $topBannerHeightMobile + 1rem)
@media (min-width: 680px)
.main-container.has-top-banner
{$contentClass}:not(.custom)
h1, h2, h3, h4, h5, h6
margin-top (2.5rem - $topBannerHeight - $navbarHeight)
padding-top ($navbarHeight + $topBannerHeight + 1rem)
</style>

0 comments on commit 046a093

Please sign in to comment.