mirror of
https://github.com/pixelfed/pixelfed.git
synced 2025-01-15 17:10:46 +00:00
201 lines
5.9 KiB
Vue
201 lines
5.9 KiB
Vue
|
<template>
|
||
|
<div class="story-carousel-component">
|
||
|
<div v-if="canShow" class="d-flex story-carousel-component-wrapper" style="overflow-y: auto;z-index: 3;">
|
||
|
<a class="col-4 col-lg-3 col-xl-2 px-1 text-dark text-decoration-none" href="/i/stories/new" style="max-width: 120px;">
|
||
|
<template v-if="selfStory && selfStory.length">
|
||
|
<div
|
||
|
class="story-wrapper text-white shadow-sm mb-3"
|
||
|
:style="{ background: `linear-gradient(rgba(0,0,0,0.2),rgba(0,0,0,0.4)), url(${selfStory[0].latest.preview_url})`, backgroundSize: 'cover', backgroundPosition: 'center'}"
|
||
|
style="width: 100%;height:200px;border-radius:15px;">
|
||
|
<div class="story-wrapper-blur d-flex flex-column align-items-center justify-content-between" style="display: block;width: 100%;height:100%;">
|
||
|
<p class="mb-4"></p>
|
||
|
<p class="mb-0"><i class="fal fa-plus-circle fa-2x"></i></p>
|
||
|
<p class="font-weight-bold">My Story</p>
|
||
|
</div>
|
||
|
</div>
|
||
|
</template>
|
||
|
<template v-else>
|
||
|
<div
|
||
|
class="story-wrapper text-white shadow-sm d-flex flex-column align-items-center justify-content-between"
|
||
|
style="width: 100%;height:200px;border-radius:15px;">
|
||
|
<p class="mb-4"></p>
|
||
|
<p class="mb-0"><i class="fal fa-plus-circle fa-2x"></i></p>
|
||
|
<p class="font-weight-bold">{{ $t('story.add') }}</p>
|
||
|
</div>
|
||
|
</template>
|
||
|
</a>
|
||
|
|
||
|
<div v-for="(story, index) in stories" class="col-4 col-lg-3 col-xl-2 px-1" style="max-width: 120px;">
|
||
|
<template v-if="story.hasOwnProperty('url')">
|
||
|
<a class="story" :href="story.url">
|
||
|
<div
|
||
|
v-if="story.latest && story.latest.type == 'photo'"
|
||
|
class="shadow-sm story-wrapper"
|
||
|
:class="{ seen: story.seen }"
|
||
|
:style="{ background: `linear-gradient(rgba(0,0,0,0.2),rgba(0,0,0,0.4)), url(${story.latest.preview_url})`, backgroundSize: 'cover', backgroundPosition: 'center'}">
|
||
|
<div class="story-wrapper-blur" style="display: block;width: 100%;height:100%;position:relative;">
|
||
|
<div class="px-2" style="display: block;width: 100%;bottom:0;position: absolute;">
|
||
|
<p class="mt-3 mb-0">
|
||
|
<img :src="story.avatar" width="30" height="30" class="avatar" draggable="false" onerror="this.onerror=null;this.src='/storage/avatars/default.jpg?v=0';">
|
||
|
</p>
|
||
|
<p class="mb-0"></p>
|
||
|
<p class="username font-weight-bold small text-truncate">
|
||
|
{{ story.username }}
|
||
|
</p>
|
||
|
</div>
|
||
|
</div>
|
||
|
</div>
|
||
|
|
||
|
<div
|
||
|
v-else
|
||
|
class="shadow-sm story-wrapper">
|
||
|
<div class="px-2" style="display: block;width: 100%;bottom:0;position: absolute;">
|
||
|
<p class="mt-3 mb-0">
|
||
|
<img :src="story.avatar" width="30" height="30" class="avatar">
|
||
|
</p>
|
||
|
<p class="mb-0"></p>
|
||
|
<p class="username font-weight-bold small text-truncate">
|
||
|
{{ story.username }}
|
||
|
</p>
|
||
|
</div>
|
||
|
</div>
|
||
|
</a>
|
||
|
</template>
|
||
|
|
||
|
<template v-else>
|
||
|
<div
|
||
|
class="story shadow-sm story-wrapper seen"
|
||
|
:style="{ background: `linear-gradient(rgba(0,0,0,0.01),rgba(0,0,0,0.04))`}">
|
||
|
<div class="story-wrapper-blur" style="display: block;width: 100%;height:100%;position:relative;">
|
||
|
<div class="px-2" style="display: block;width: 100%;bottom:0;position: absolute;">
|
||
|
<p class="mt-3 mb-0">
|
||
|
</p>
|
||
|
<p class="mb-0"></p>
|
||
|
<p class="username font-weight-bold small text-truncate">
|
||
|
</p>
|
||
|
</div>
|
||
|
</div>
|
||
|
</div>
|
||
|
</template>
|
||
|
</div>
|
||
|
|
||
|
<template v-if="selfStory && selfStory.length && stories.length < 2">
|
||
|
<div v-for="i in 5" class="col-4 col-lg-3 col-xl-2 px-1 story" style="max-width: 120px;">
|
||
|
<div
|
||
|
class="shadow-sm story-wrapper seen"
|
||
|
:style="{ background: `linear-gradient(rgba(0,0,0,0.01),rgba(0,0,0,0.04))`}">
|
||
|
<div class="story-wrapper-blur" style="display: block;width: 100%;height:100%;position:relative;">
|
||
|
<div class="px-2" style="display: block;width: 100%;bottom:0;position: absolute;">
|
||
|
<p class="mt-3 mb-0">
|
||
|
</p>
|
||
|
<p class="mb-0"></p>
|
||
|
<p class="username font-weight-bold small text-truncate">
|
||
|
</p>
|
||
|
</div>
|
||
|
</div>
|
||
|
</div>
|
||
|
</div>
|
||
|
</template>
|
||
|
</div>
|
||
|
</div>
|
||
|
</template>
|
||
|
|
||
|
<script type="text/javascript">
|
||
|
export default {
|
||
|
props: {
|
||
|
profile: {
|
||
|
type: Object
|
||
|
}
|
||
|
},
|
||
|
|
||
|
data() {
|
||
|
return {
|
||
|
canShow: false,
|
||
|
stories: [],
|
||
|
selfStory: undefined
|
||
|
}
|
||
|
},
|
||
|
|
||
|
mounted() {
|
||
|
this.fetchStories();
|
||
|
},
|
||
|
|
||
|
methods: {
|
||
|
fetchStories() {
|
||
|
axios.get('/api/web/stories/v1/recent')
|
||
|
.then(res => {
|
||
|
if(res.data && res.data.length) {
|
||
|
this.selfStory = res.data.filter(s => s.pid == this.profile.id);
|
||
|
let activeStories = res.data.filter(s => s.pid !== this.profile.id);
|
||
|
this.stories = activeStories;
|
||
|
this.canShow = true;
|
||
|
|
||
|
|
||
|
if(!activeStories || !activeStories.length || activeStories.length < 5) {
|
||
|
this.stories.push(...Array(5 - activeStories.length).keys())
|
||
|
}
|
||
|
}
|
||
|
})
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
</script>
|
||
|
|
||
|
<style lang="scss">
|
||
|
.story-carousel-component {
|
||
|
&-wrapper {
|
||
|
-ms-overflow-style: none;
|
||
|
scrollbar-width: none;
|
||
|
|
||
|
&::-webkit-scrollbar {
|
||
|
width: 0 !important
|
||
|
}
|
||
|
}
|
||
|
|
||
|
.story {
|
||
|
&-wrapper {
|
||
|
display: block;
|
||
|
position: relative;
|
||
|
width: 100%;
|
||
|
height: 200px;
|
||
|
border-radius: 15px;
|
||
|
margin-bottom: 1rem;
|
||
|
background: #b24592;
|
||
|
background: -webkit-linear-gradient(to right, #b24592, #f15f79);
|
||
|
background: linear-gradient(to right, #b24592, #f15f79);
|
||
|
overflow: hidden;
|
||
|
border: 1px solid var(--border-color);
|
||
|
|
||
|
.username {
|
||
|
color: #fff;
|
||
|
}
|
||
|
|
||
|
.avatar {
|
||
|
border-radius: 6px;
|
||
|
margin-bottom: 5px;
|
||
|
}
|
||
|
|
||
|
&.seen {
|
||
|
opacity: 30%;
|
||
|
}
|
||
|
|
||
|
&-blur {
|
||
|
border-radius: 15px;
|
||
|
overflow: hidden;
|
||
|
background: rgba(0, 0, 0, 0.2);
|
||
|
backdrop-filter: blur(8px);
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
.force-dark-mode {
|
||
|
.story-wrapper {
|
||
|
&.seen {
|
||
|
opacity: 50%;
|
||
|
background: linear-gradient(rgba(255,255,255,0.12),rgba(255,255,255,0.14)) !important;
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
</style>
|