<template>
<div class="mk-welcome-timeline">
	<div v-for="note in notes">
		<mk-avatar class="avatar" :user="note.user" target="_blank"/>
		<div class="body">
			<header>
				<router-link class="name" :to="note.user | userPage" v-user-preview="note.user.id">{{ note.user | userName }}</router-link>
				<span class="username">@{{ note.user | acct }}</span>
				<div class="info">
					<router-link class="created-at" :to="note | notePage">
						<mk-time :time="note.createdAt"/>
					</router-link>
				</div>
			</header>
			<div class="text">
				<mk-note-html :text="note.text"/>
			</div>
		</div>
	</div>
</div>
</template>

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

export default Vue.extend({
	data() {
		return {
			fetching: true,
			notes: []
		};
	},
	mounted() {
		this.fetch();
	},
	methods: {
		fetch(cb?) {
			this.fetching = true;
			(this as any).api('notes', {
				local: true,
				reply: false,
				renote: false,
				media: false,
				poll: false,
				bot: false
			}).then(notes => {
				this.notes = notes;
				this.fetching = false;
			});
		}
	}
});
</script>

<style lang="stylus" scoped>
.mk-welcome-timeline
	background #fff

	> div
		padding 16px
		overflow-wrap break-word
		font-size .9em
		color #4C4C4C
		border-bottom 1px solid rgba(#000, 0.05)

		&:after
			content ""
			display block
			clear both

		> .avatar
			display block
			float left
			position -webkit-sticky
			position sticky
			top 16px
			width 42px
			height 42px
			border-radius 6px

		> .body
			float right
			width calc(100% - 42px)
			padding-left 12px

			> header
				display flex
				align-items center
				margin-bottom 4px
				white-space nowrap

				> .name
					display block
					margin 0 .5em 0 0
					padding 0
					overflow hidden
					font-weight bold
					text-overflow ellipsis
					color #627079

				> .username
					margin 0 .5em 0 0
					color #ccc

				> .info
					margin-left auto
					font-size 0.9em

					> .created-at
						color #c0c0c0

</style>