rudeshark.net/src/client/components/global/ad.vue

177 lines
3.2 KiB
Vue
Raw Normal View History

<template>
<div class="qiivuoyo" v-if="ad">
<div class="main" :class="ad.place" v-if="!showMenu">
<a :href="ad.url" target="_blank">
<img :src="ad.imageUrl">
<button class="_button menu" @click.prevent.stop="toggleMenu"><span class="fas fa-info-circle"></span></button>
</a>
</div>
<div class="menu" v-else>
<div class="body">
<div>Ads by {{ host }}</div>
<!--<MkButton>{{ $ts.stopThisAd }}</MkButton>-->
<button class="_textButton" @click="toggleMenu">{{ $ts.close }}</button>
</div>
</div>
</div>
2021-05-04 16:12:36 +02:00
<div v-else></div>
</template>
<script lang="ts">
import { defineComponent, ref } from 'vue';
2021-05-07 07:22:13 +02:00
import { Instance, instance } from '@client/instance';
import { host } from '@client/config';
import MkButton from '@client/components/ui/button.vue';
export default defineComponent({
components: {
MkButton
},
props: {
prefer: {
2021-05-05 12:05:19 +02:00
type: Array,
required: true
},
2021-05-04 16:12:36 +02:00
specify: {
type: Object,
required: false
},
},
setup(props) {
const showMenu = ref(false);
const toggleMenu = () => {
showMenu.value = !showMenu.value;
};
2021-05-07 07:22:13 +02:00
const choseAd = (): Instance['ads'][number] | null => {
if (props.specify) {
return props.specify as Instance['ads'][number];
}
2021-05-05 12:05:19 +02:00
let ads = instance.ads.filter(ad => props.prefer.includes(ad.place));
if (ads.length === 0) {
ads = instance.ads.filter(ad => ad.place === 'square');
}
2021-05-07 07:22:13 +02:00
const lowPriorityAds = ads.filter(ad => ad.ratio === 0);
ads = ads.filter(ad => ad.ratio !== 0);
2021-05-07 07:22:13 +02:00
if (ads.length === 0) {
if (lowPriorityAds.length !== 0) {
return lowPriorityAds[Math.floor(Math.random() * lowPriorityAds.length)];
} else {
return null;
}
}
2021-05-07 07:22:13 +02:00
const totalFactor = ads.reduce((a, b) => a + b.ratio, 0);
const r = Math.random() * totalFactor;
let stackedFactor = 0;
for (const ad of ads) {
if (r >= stackedFactor && r <= stackedFactor + ad.ratio) {
return ad;
} else {
stackedFactor += ad.ratio;
}
}
return null;
};
return {
2021-05-07 07:22:13 +02:00
ad: choseAd(),
showMenu,
toggleMenu,
host,
};
}
});
</script>
<style lang="scss" scoped>
.qiivuoyo {
background-size: auto auto;
background-image: repeating-linear-gradient(45deg, transparent, transparent 8px, var(--ad) 8px, var(--ad) 14px );
> .main {
2021-05-04 16:39:17 +02:00
text-align: center;
> a {
2021-05-04 16:39:17 +02:00
display: inline-block;
position: relative;
2021-05-05 07:06:57 +02:00
vertical-align: bottom;
&:hover {
> img {
filter: contrast(120%);
}
}
> img {
display: block;
object-fit: contain;
2021-05-04 16:39:17 +02:00
margin: auto;
}
> .menu {
position: absolute;
top: 0;
right: 0;
background: var(--panel);
}
}
&.square {
2021-05-04 16:39:17 +02:00
> a ,
> a > img {
max-width: min(300px, 100%);
2021-05-04 16:39:17 +02:00
max-height: 300px;
}
}
&.horizontal {
padding: 8px;
2021-05-04 16:39:17 +02:00
> a ,
> a > img {
max-width: min(600px, 100%);
2021-05-05 07:06:57 +02:00
max-height: 80px;
}
}
2021-05-05 12:05:19 +02:00
&.horizontal-big {
padding: 8px;
> a ,
> a > img {
max-width: min(600px, 100%);
max-height: 250px;
}
}
&.vertical {
2021-05-04 16:39:17 +02:00
> a ,
> a > img {
max-width: min(100px, 100%);
}
}
}
> .menu {
padding: 8px;
text-align: center;
> .body {
padding: 8px;
margin: 0 auto;
max-width: 400px;
border: solid 1px var(--divider);
}
}
}
</style>