|
|
|
@ -1,61 +1,65 @@
|
|
|
|
|
<template>
|
|
|
|
|
<div class="_root">
|
|
|
|
|
<transition name="fade" mode="out-in">
|
|
|
|
|
<div v-if="page" class="xcukqgmh" :key="page.id" v-size="{ max: [450] }">
|
|
|
|
|
<div class="_block main">
|
|
|
|
|
<!--
|
|
|
|
|
<div class="header">
|
|
|
|
|
<h1>{{ page.title }}</h1>
|
|
|
|
|
</div>
|
|
|
|
|
-->
|
|
|
|
|
<div class="banner">
|
|
|
|
|
<img :src="page.eyeCatchingImage.url" v-if="page.eyeCatchingImageId"/>
|
|
|
|
|
</div>
|
|
|
|
|
<div class="content">
|
|
|
|
|
<XPage :page="page"/>
|
|
|
|
|
</div>
|
|
|
|
|
<div class="actions">
|
|
|
|
|
<div class="like">
|
|
|
|
|
<MkButton class="button" @click="unlike()" v-if="page.isLiked" v-tooltip="$ts._pages.unlike" primary><i class="fas fa-heart"></i><span class="count" v-if="page.likedCount > 0">{{ page.likedCount }}</span></MkButton>
|
|
|
|
|
<MkButton class="button" @click="like()" v-else v-tooltip="$ts._pages.like"><i class="far fa-heart"></i><span class="count" v-if="page.likedCount > 0">{{ page.likedCount }}</span></MkButton>
|
|
|
|
|
<div>
|
|
|
|
|
<MkHeader :info="header"/>
|
|
|
|
|
|
|
|
|
|
<div class="_root">
|
|
|
|
|
<transition name="fade" mode="out-in">
|
|
|
|
|
<div v-if="page" class="xcukqgmh" :key="page.id" v-size="{ max: [450] }">
|
|
|
|
|
<div class="_block main">
|
|
|
|
|
<!--
|
|
|
|
|
<div class="header">
|
|
|
|
|
<h1>{{ page.title }}</h1>
|
|
|
|
|
</div>
|
|
|
|
|
<div class="other">
|
|
|
|
|
<button class="_button" @click="shareWithNote" v-tooltip="$ts.shareWithNote" v-click-anime><i class="fas fa-retweet fa-fw"></i></button>
|
|
|
|
|
<button class="_button" @click="share" v-tooltip="$ts.share" v-click-anime><i class="fas fa-share-alt fa-fw"></i></button>
|
|
|
|
|
-->
|
|
|
|
|
<div class="banner">
|
|
|
|
|
<img :src="page.eyeCatchingImage.url" v-if="page.eyeCatchingImageId"/>
|
|
|
|
|
</div>
|
|
|
|
|
<div class="content">
|
|
|
|
|
<XPage :page="page"/>
|
|
|
|
|
</div>
|
|
|
|
|
<div class="actions">
|
|
|
|
|
<div class="like">
|
|
|
|
|
<MkButton class="button" @click="unlike()" v-if="page.isLiked" v-tooltip="$ts._pages.unlike" primary><i class="fas fa-heart"></i><span class="count" v-if="page.likedCount > 0">{{ page.likedCount }}</span></MkButton>
|
|
|
|
|
<MkButton class="button" @click="like()" v-else v-tooltip="$ts._pages.like"><i class="far fa-heart"></i><span class="count" v-if="page.likedCount > 0">{{ page.likedCount }}</span></MkButton>
|
|
|
|
|
</div>
|
|
|
|
|
<div class="other">
|
|
|
|
|
<button class="_button" @click="shareWithNote" v-tooltip="$ts.shareWithNote" v-click-anime><i class="fas fa-retweet fa-fw"></i></button>
|
|
|
|
|
<button class="_button" @click="share" v-tooltip="$ts.share" v-click-anime><i class="fas fa-share-alt fa-fw"></i></button>
|
|
|
|
|
</div>
|
|
|
|
|
</div>
|
|
|
|
|
<div class="user">
|
|
|
|
|
<MkAvatar :user="page.user" class="avatar"/>
|
|
|
|
|
<div class="name">
|
|
|
|
|
<MkUserName :user="page.user" style="display: block;"/>
|
|
|
|
|
<MkAcct :user="page.user"/>
|
|
|
|
|
</div>
|
|
|
|
|
<MkFollowButton v-if="!$i || $i.id != page.user.id" :user="page.user" :inline="true" :transparent="false" :full="true" large class="koudoku"/>
|
|
|
|
|
</div>
|
|
|
|
|
<div class="links">
|
|
|
|
|
<MkA :to="`/@${username}/pages/${pageName}/view-source`" class="link">{{ $ts._pages.viewSource }}</MkA>
|
|
|
|
|
<template v-if="$i && $i.id === page.userId">
|
|
|
|
|
<MkA :to="`/pages/edit/${page.id}`" class="link">{{ $ts._pages.editThisPage }}</MkA>
|
|
|
|
|
<button v-if="$i.pinnedPageId === page.id" @click="pin(false)" class="link _textButton">{{ $ts.unpin }}</button>
|
|
|
|
|
<button v-else @click="pin(true)" class="link _textButton">{{ $ts.pin }}</button>
|
|
|
|
|
</template>
|
|
|
|
|
</div>
|
|
|
|
|
</div>
|
|
|
|
|
<div class="user">
|
|
|
|
|
<MkAvatar :user="page.user" class="avatar"/>
|
|
|
|
|
<div class="name">
|
|
|
|
|
<MkUserName :user="page.user" style="display: block;"/>
|
|
|
|
|
<MkAcct :user="page.user"/>
|
|
|
|
|
</div>
|
|
|
|
|
<MkFollowButton v-if="!$i || $i.id != page.user.id" :user="page.user" :inline="true" :transparent="false" :full="true" large class="koudoku"/>
|
|
|
|
|
</div>
|
|
|
|
|
<div class="links">
|
|
|
|
|
<MkA :to="`/@${username}/pages/${pageName}/view-source`" class="link">{{ $ts._pages.viewSource }}</MkA>
|
|
|
|
|
<template v-if="$i && $i.id === page.userId">
|
|
|
|
|
<MkA :to="`/pages/edit/${page.id}`" class="link">{{ $ts._pages.editThisPage }}</MkA>
|
|
|
|
|
<button v-if="$i.pinnedPageId === page.id" @click="pin(false)" class="link _textButton">{{ $ts.unpin }}</button>
|
|
|
|
|
<button v-else @click="pin(true)" class="link _textButton">{{ $ts.pin }}</button>
|
|
|
|
|
</template>
|
|
|
|
|
<div class="footer">
|
|
|
|
|
<div><i class="far fa-clock"></i> {{ $ts.createdAt }}: <MkTime :time="page.createdAt" mode="detail"/></div>
|
|
|
|
|
<div v-if="page.createdAt != page.updatedAt"><i class="far fa-clock"></i> {{ $ts.updatedAt }}: <MkTime :time="page.updatedAt" mode="detail"/></div>
|
|
|
|
|
</div>
|
|
|
|
|
<MkAd :prefer="['horizontal', 'horizontal-big']"/>
|
|
|
|
|
<MkContainer :max-height="300" :foldable="true" class="other">
|
|
|
|
|
<template #header><i class="fas fa-clock"></i> {{ $ts.recentPosts }}</template>
|
|
|
|
|
<MkPagination :pagination="otherPostsPagination" #default="{items}">
|
|
|
|
|
<MkPagePreview v-for="page in items" :page="page" :key="page.id" class="_gap"/>
|
|
|
|
|
</MkPagination>
|
|
|
|
|
</MkContainer>
|
|
|
|
|
</div>
|
|
|
|
|
<div class="footer">
|
|
|
|
|
<div><i class="far fa-clock"></i> {{ $ts.createdAt }}: <MkTime :time="page.createdAt" mode="detail"/></div>
|
|
|
|
|
<div v-if="page.createdAt != page.updatedAt"><i class="far fa-clock"></i> {{ $ts.updatedAt }}: <MkTime :time="page.updatedAt" mode="detail"/></div>
|
|
|
|
|
</div>
|
|
|
|
|
<MkAd :prefer="['horizontal', 'horizontal-big']"/>
|
|
|
|
|
<MkContainer :max-height="300" :foldable="true" class="other">
|
|
|
|
|
<template #header><i class="fas fa-clock"></i> {{ $ts.recentPosts }}</template>
|
|
|
|
|
<MkPagination :pagination="otherPostsPagination" #default="{items}">
|
|
|
|
|
<MkPagePreview v-for="page in items" :page="page" :key="page.id" class="_gap"/>
|
|
|
|
|
</MkPagination>
|
|
|
|
|
</MkContainer>
|
|
|
|
|
</div>
|
|
|
|
|
<MkError v-else-if="error" @retry="fetch()"/>
|
|
|
|
|
<MkLoading v-else/>
|
|
|
|
|
</transition>
|
|
|
|
|
<MkError v-else-if="error" @retry="fetch()"/>
|
|
|
|
|
<MkLoading v-else/>
|
|
|
|
|
</transition>
|
|
|
|
|
</div>
|
|
|
|
|
</div>
|
|
|
|
|
</template>
|
|
|
|
|
|
|
|
|
@ -97,6 +101,10 @@ export default defineComponent({
|
|
|
|
|
[symbols.PAGE_INFO]: computed(() => this.page ? {
|
|
|
|
|
title: computed(() => this.page.title || this.page.name),
|
|
|
|
|
avatar: this.page.user,
|
|
|
|
|
} : null),
|
|
|
|
|
header: computed(() => this.page ? {
|
|
|
|
|
title: computed(() => this.page.title || this.page.name),
|
|
|
|
|
avatar: this.page.user,
|
|
|
|
|
path: `/@${this.page.user.username}/pages/${this.page.name}`,
|
|
|
|
|
share: {
|
|
|
|
|
title: this.page.title || this.page.name,
|
|
|
|
|