Skip to content

Instantly share code, notes, and snippets.

@aversan
Created April 22, 2020 10:59
Show Gist options
  • Star 0 You must be signed in to star a gist
  • Fork 0 You must be signed in to fork a gist
  • Save aversan/410528c94248cf86f93ea0e8f1029c59 to your computer and use it in GitHub Desktop.
Save aversan/410528c94248cf86f93ea0e8f1029c59 to your computer and use it in GitHub Desktop.
<template>
<div class="mx-n2_5 mx-xl-0">
<Swiper
ref="swiperComponent"
:options="swiperOptions"
:class="{
'slider-container main-slider mx-auto mt-2 mt-xl-4_75 mb-0 mb-xl-6_75 px-2_5 px-xl-0 pb-7 pb-xl-0': true,
}"
class=""
>
<SwiperSlide class="slider-slide text-center flex align-items-center justify-content-center position-relative" v-for="slide in slides" :key="slide.image">
<div class="embed-responsive slider-slide-embed rounded-xl">
<a class="stretched-link" :href="slide.url">
<picture class="w-100 h-100">
<source :srcset="slide.image" type="image/jpg" media="(min-width: 768px)">
<source :srcset="slide.imageMobile" type="image/jpg">
<img class="embed-responsive-item cover-object" :src="slide.image" loading="lazy" />
</picture>
</a>
</div>
</SwiperSlide>
<div
:class="{
'swiper-pagination slider-pagination d-xl-none': true,
'mb-2_5': $device.isDesktopOrTablet,
'slider-pagination-mobile mb-2_5': $device.isMobile,
}"
slot="pagination"></div>
<div class="swiper-button-prev slider-prev w-7_25 h-7_25 rounded-pill" title="Назад" slot="button-prev" v-if="$device.isDesktopOrTablet">
<svgicon class="text-white w-3 h-3" name="chevron-left" />
</div>
<div class="swiper-button-next slider-next w-7_25 h-7_25 rounded-pill" title="Вперед" slot="button-next" v-if="$device.isDesktopOrTablet">
<svgicon class="text-white w-3 h-3" name="chevron-right" />
</div>
</Swiper>
</div>
</template>
<script>
import { Swiper, SwiperSlide, directive } from 'vue-awesome-swiper';
import 'swiper/css/swiper.css';
import '@/components/icons/chevron-left';
import '@/components/icons/chevron-right';
export default {
data() {
return {
slides: [
{ image: "/images/banner-01-desktop.jpg", imageMobile: "/images/banner-01-mobile.jpg", url: "#" },
{ image: "/images/banner-01-desktop.jpg", imageMobile: "/images/banner-01-mobile.jpg", url: "#" },
{ image: "/images/banner-01-desktop.jpg", imageMobile: "/images/banner-01-mobile.jpg", url: "#" },
],
swiperOptions: {
effect: 'coverflow',
loop: true,
grabCursor: true,
centeredSlides: true,
slidesPerView: 1,
spaceBetween: 20,
slideToClickedSlide: true,
noSwiping: true,
coverflowEffect: {
rotate: 0,
stretch: 0,
depth: 0,
modifier: 1,
slideShadows : false,
},
breakpoints: {
1200: {
slidesPerView: 2,
spaceBetween: 0,
coverflowEffect: {
rotate: 0,
stretch: 240,
depth: 100,
modifier: 1,
slideShadows : false,
},
}
},
pagination: {
el: '.swiper-pagination',
},
navigation: {
nextEl: '.swiper-button-next',
prevEl: '.swiper-button-prev',
},
}
}
},
computed: {
swiper() {
return this.$refs.mySwiper.$swiper;
}
},
mounted() {
// console.log('Current Swiper instance object', this.swiper)
// this.swiper.slideTo(3, 1000, false)
},
components: {
Swiper,
SwiperSlide,
},
directives: {
swiper: directive,
}
}
</script>
<style lang="scss">
.main-slider {
max-width: 1404px;
.slider-slide {
width: calc(100% / 2);
@media (max-width: 1200px) {
width: 100%;
}
&:not(.swiper-slide-active) .stretched-link {
pointer-events: none !important;
}
}
.slider-slide-embed {
transition: all .2s;
transform: scale(.7);
&::before {
padding-top: percentage(311 / 702);
}
.embed-responsive-item {
filter: blur(5px);
@media (max-width: 1200px) {
filter: none;
}
}
}
.slider-slide.swiper-slide-active .slider-slide-embed {
transform: scale(1);
.embed-responsive-item {
filter: none;
}
}
.slider-slide.swiper-slide-prev .slider-slide-embed,
.slider-slide.swiper-slide-next .slider-slide-embed, {
transform: scale(.85);
@media (max-width: 1200px) {
transform: scale(1);
}
}
.slider-prev,
.slider-next {
margin-top: calc(-1 * 3.625rem / 2);
@media (max-width: 1200px) {
margin-top: calc(-1 * 3.625rem / 2 + -1 * 3.5rem / 2);
}
}
.slider-prev {
left: calc(25% - 1.8125rem);
@media (max-width: 1200px) {
left: 1.25rem;
}
}
.slider-next {
right: calc(25% - 1.8125rem);
@media (max-width: 1200px) {
right: 1.25rem;
}
}
}
</style>
<template>
<b-tbody
:class="{
'match-table-body bg-white text-gray-950': true,
'match-table-body-mobile': $device.isMobile,
}"
>
<b-tr class="match-table-row h-1" v-if="$device.isDesktopOrTablet">
<b-td class="match-table-cell cell-hr p-0 bg-black" colspan="9"></b-td>
</b-tr>
<b-tr class="match-table-row first h-1_25" v-if="$device.isDesktopOrTablet">
<b-td class="match-table-cell cell-hr p-0" colspan="9"></b-td>
</b-tr>
<b-tr class="match-table-row" v-if="$device.isMobile">
<b-th class="match-table-cell align-middle font-weight-semibold text-xl" colspan="3">
Мы нашли:
</b-th>
</b-tr>
<b-tr class="match-table-row">
<b-td class="match-table-cell text-center align-middle cell-date" rowspan="2" v-if="$device.isDesktopOrTablet">
<strong class="text-xl time d-block">21:00</strong>
<small class="text-sm font-weight-medium text-gray-525 d-block day">Сегодня</small>
</b-td>
<b-td class="match-table-cell align-middle text-center cell-match" rowspan="2" v-if="$device.isDesktopOrTablet">
<MatchInfo variant="short-small" />
</b-td>
<b-th class="match-table-cell align-middle font-weight-semibold text-lg text-white bg-red-500 rounded-tl-xl" v-if="$device.isDesktopOrTablet">
Мы нашли
</b-th>
<b-td class="match-table-cell cell-bet text-center align-middle">
<BetFactor factor="1.5" percent="13" outline />
</b-td>
<b-td class="match-table-cell cell-bet text-center align-middle">
<BetFactor factor="1.5" percent="13" outline />
</b-td>
<b-td
:class="{
'match-table-cell cell-bet text-center align-middle': true,
'rounded-tr-xl': $device.isDesktopOrTablet,
}"
>
<BetFactor factor="1.5" percent="13" outline />
</b-td>
<b-td class="match-table-cell p-0 cell-vr w-1_25" rowspan="2" v-if="$device.isDesktopOrTablet"></b-td>
<b-td class="match-table-cell text-center align-middle font-weight-bold text-base text-primary bg-gray-200 cell-count rounded-xl" rowspan="2" v-if="$device.isDesktopOrTablet">
+1245
</b-td>
<b-td class="match-table-cell p-0 cell-vr w-1_25" rowspan="2" v-if="$device.isDesktopOrTablet"></b-td>
</b-tr>
<b-tr class="match-table-row" v-if="$device.isMobile">
<b-th
class="match-table-cell align-middle font-weight-semibold text-xl" colspan="3">
Букмекеры РФ:
</b-th>
</b-tr>
<b-tr
:class="{
'match-table-row': true,
'last': $device.isMobile,
}"
>
<b-th class="match-table-cell align-middle font-weight-semibold text-xs text-gray-950 bg-gray-300 rounded-bl-xl" v-if="$device.isDesktopOrTablet">
Букмекеры России
</b-th>
<b-td
:class="{
'match-table-cell text-center align-middle bg-gray-200': true,
'text-lg': $device.isDesktopOrTablet,
'text-xl': $device.isMobile,
}"
>
1.5
</b-td>
<b-td
:class="{
'match-table-cell text-center align-middle bg-gray-200': true,
'text-lg': $device.isDesktopOrTablet,
'text-3xl': $device.isMobile,
}"
>
1.5
</b-td>
<b-td
:class="{
'match-table-cell text-center align-middle bg-gray-200': true,
'text-lg rounded-br-xl': $device.isDesktopOrTablet,
'text-3xl': $device.isMobile,
}"
>
1.5
</b-td>
</b-tr>
<b-tr class="match-table-row last h-1_25" v-if="$device.isDesktopOrTablet">
<b-td class="match-table-cell cell-hr p-0" colspan="9"></b-td>
</b-tr>
</b-tbody>
</template>
<script>
import MatchInfo from '@/components/match/match-info';
import BetFactor from '@/components/bet/bet-factor';
export default {
components: {
MatchInfo,
BetFactor,
}
}
</script>
<style lang="scss">
.match-table-body {
.match-table-row.first .match-table-cell {
&:first-child,
&:last-child {
position: relative;
}
&:first-child::before,
&:last-child::after {
position: absolute;
content: '';
width: 10px;
height: 10px;
overflow: hidden;
background-image: url('');
}
&:first-child::before {
top: 0;
left: 0;
background-position: 0 0;
}
&:last-child::after {
top: 0;
right: 0;
background-position: 100% 0;
}
}
.match-table-row.last .match-table-cell {
&:first-child {
border-bottom-left-radius: 10px;
}
&:last-child {
border-bottom-right-radius: 10px;
}
}
.match-table-cell.cell-bet {
background-color: var(--primary);
}
}
.match-table-body-mobile {
td.match-table-cell {
padding-top: .625rem;
padding-bottom: .625rem;
&.cell-bet {
padding-top: .875rem;
padding-bottom: .875rem;
}
}
th.match-table-cell {
padding-top: .25rem;
padding-bottom: .25rem;
}
.match-table-cell.cell-bet {
background-color: var(--gray-200);
}
}
</style>
<template>
<div
:class="{
'd-flex flex-nowrap align-items-center match-team': true,
'match-team-1': !second,
'match-team-2 flex-row-reverse': second,
'match-team-large': size == 'large',
'match-team-medium': size == 'medium',
'match-team-small': size == 'small',
}"
>
<div class="flex-grow-1">
<div
:class="{
'match-team-name': true,
'text-right': !second,
'text-left': second,
'text-2xl font-weight-bold': size == 'large' && $device.isDesktopOrTablet,
'text-xl font-weight-bold': size == 'large' && $device.isMobile,
'text-sm-2 font-weight-semibold': size == 'medium' && $device.isDesktopOrTablet,
'text-xl font-weight-semibold': size == 'medium' && $device.isMobile,
'text-sm-2 font-weight-semibold': size == 'small' && $device.isDesktopOrTablet,
'text-xl font-weight-semibold': size == 'small' && $device.isMobile,
}"
>
{{ namesMap[name] }}
</div>
</div>
<img
v-if="!text"
:class="{
'match-team-logo cover-object flex-shrink-0': true,
'ml-2_5': size == 'large' && !second,
'mr-2_5': size == 'large' && second,
'ml-2_25': size == 'medium' && !second,
'mr-2_25': size == 'medium' && second,
'ml-2': size == 'small' && !second,
'mr-2': size == 'small' && second,
'w-7_5 h-7_5': size == 'large',
'w-6 h-6': size == 'medium',
'w-3_75 h-3_75': size == 'small',
}"
:src="logosMap[name]"
alt=""
>
</div>
</template>
<script>
export default {
data() {
return {
logosMap: {
'manchester-united': '/team-logos/manchester-united.svg',
'chelsea': '/team-logos/chelsea.svg',
},
namesMap: {
'manchester-united': 'Манчестер Юнайтед',
'chelsea': 'Челси',
},
}
},
props: {
name: {
type: String,
default: 'Нонейм',
},
logo: {
type: String,
default: 'http://placehold.it/60x60',
},
text: {
type: Boolean,
default: false,
},
second: {
type: Boolean,
default: false,
},
size: {
type: String,
default: 'large', // large medium small
},
},
components: {
},
}
</script>
<style lang="scss">
.match-team {
&-name {
line-height: 1.2;
}
}
</style>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment