57 lines
1.1 KiB
Vue
57 lines
1.1 KiB
Vue
<template>
|
|
<div class="mk-sub-post-content">
|
|
<div class="body">
|
|
<a class="reply" v-if="post.reply_id">%fa:reply%</a>
|
|
<mk-post-html :ast="post.ast" :i="$root.$data.os.i"/>
|
|
<a class="quote" v-if="post.repost_id" :href="`/post:${post.repost_id}`">RP: ...</a>
|
|
<mk-url-preview v-for="url in urls" :url="url" :key="url"/>
|
|
</div>
|
|
<details v-if="post.media">
|
|
<summary>({{ post.media.length }}つのメディア)</summary>
|
|
<mk-images :images="post.media"/>
|
|
</details>
|
|
<details v-if="post.poll">
|
|
<summary>投票</summary>
|
|
<mk-poll :post="post"/>
|
|
</details>
|
|
</div>
|
|
</template>
|
|
|
|
<script lang="ts">
|
|
import Vue from 'vue';
|
|
|
|
export default Vue.extend({
|
|
props: ['post'],
|
|
computed: {
|
|
urls(): string[] {
|
|
if (this.post.ast) {
|
|
return this.post.ast
|
|
.filter(t => (t.type == 'url' || t.type == 'link') && !t.silent)
|
|
.map(t => t.url);
|
|
} else {
|
|
return null;
|
|
}
|
|
}
|
|
}
|
|
});
|
|
</script>
|
|
|
|
<style lang="stylus" scoped>
|
|
.mk-sub-post-content
|
|
overflow-wrap break-word
|
|
|
|
> .body
|
|
> .reply
|
|
margin-right 6px
|
|
color #717171
|
|
|
|
> .quote
|
|
margin-left 4px
|
|
font-style oblique
|
|
color #a0bf46
|
|
|
|
mk-poll
|
|
font-size 80%
|
|
|
|
</style>
|