summaryrefslogtreecommitdiff
path: root/src/client/app/mobile/views/components/note-preview.vue
blob: 1c97e610d7f09819a47b944aa327630cf115dae8 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
<template>
<div class="mk-note-preview" :class="{ smart: $store.state.device.postStyle == 'smart' }">
	<mk-avatar class="avatar" :user="note.user" v-if="$store.state.device.postStyle != 'smart'"/>
	<div class="main">
		<header>
			<mk-avatar class="avatar" :user="note.user" v-if="$store.state.device.postStyle == 'smart'"/>
			<router-link class="name" :to="note.user | userPage">{{ note.user | userName }}</router-link>
			<span class="is-admin" v-if="note.user.isAdmin">%i18n:@admin%</span>
			<span class="is-bot" v-if="note.user.isBot">%i18n:@bot%</span>
			<span class="is-cat" v-if="note.user.isCat">%i18n:@cat%</span>
			<span class="username"><mk-acct :user="note.user"/></span>
			<router-link class="time" :to="note | notePage">
				<mk-time :time="note.createdAt"/>
			</router-link>
		</header>
		<div class="body">
			<mk-sub-note-content class="text" :note="note"/>
		</div>
	</div>
</div>
</template>

<script lang="ts">
import Vue from 'vue';

export default Vue.extend({
	props: ['note']
});
</script>

<style lang="stylus" scoped>
root(isDark)
	margin 0
	padding 0
	font-size 0.9em

	&:after
		content ""
		display block
		clear both

	&.smart
		> .main
			width 100%

			> header
				align-items center

	> .avatar
		display block
		float left
		margin 0 12px 0 0
		width 48px
		height 48px
		border-radius 8px

	> .main
		float left
		width calc(100% - 60px)

		> header
			display flex
			align-items baseline
			margin-bottom 2px
			white-space nowrap

			> .avatar
				flex-shrink 0
				margin-right 8px
				width 18px
				height 18px
				border-radius 100%

			> .name
				display block
				margin 0 .5em 0 0
				padding 0
				overflow hidden
				color isDark ? #fff : #607073
				font-size 1em
				font-weight 700
				text-align left
				text-decoration none
				text-overflow ellipsis

			> .is-admin
			> .is-bot
			> .is-cat
				margin 0 0.5em 0 0
				padding 1px 6px
				font-size 10px
				color isDark ? #758188 : #aaa
				border solid 1px isDark ? #57616f : #ddd
				border-radius 3px

				&.is-admin
					border-color isDark ? #d42c41 : #f56a7b
					color isDark ? #d42c41 : #f56a7b

			> .username
				margin 0 .5em 0 0
				overflow hidden
				text-overflow ellipsis
				color isDark ? #606984 : #d1d8da

			> .time
				margin-left auto
				color isDark ? #606984 : #b2b8bb

		> .body

			> .text
				cursor default
				margin 0
				padding 0
				font-size 1.1em
				color isDark ? #959ba7 : #717171

.mk-note-preview[data-darkmode]
	root(true)

.mk-note-preview:not([data-darkmode])
	root(false)

</style>