<template>
<div class="mk-user-photos">
	<p class="title">%fa:camera%%i18n:desktop.tags.mk-user.photos.title%</p>
	<p class="initializing" v-if="fetching">%fa:spinner .pulse .fw%%i18n:desktop.tags.mk-user.photos.loading%<mk-ellipsis/></p>
	<div class="stream" v-if="!fetching && images.length > 0">
		<div v-for="image in images" :key="image.id"
			class="img"
			:style="`background-image: url(${image.url}?thumbnail&size=256)`"
		></div>
	</div>
	<p class="empty" v-if="!fetching && images.length == 0">%i18n:desktop.tags.mk-user.photos.no-photos%</p>
</div>
</template>

<script lang="ts">
import Vue from 'vue';
export default Vue.extend({
	props: ['user'],
	data() {
		return {
			images: [],
			fetching: true
		};
	},
	mounted() {
		this.$root.$data.os.api('users/posts', {
			user_id: this.user.id,
			with_media: true,
			limit: 9
		}).then(posts => {
			this.fetching = false;
			posts.forEach(post => {
				post.media.forEach(media => {
					if (this.images.length < 9) this.images.push(media);
				});
			});
		});
	}
});
</script>

<style lang="stylus" scoped>
.mk-user-photos
	background #fff
	border solid 1px rgba(0, 0, 0, 0.075)
	border-radius 6px

	> .title
		z-index 1
		margin 0
		padding 0 16px
		line-height 42px
		font-size 0.9em
		font-weight bold
		color #888
		box-shadow 0 1px rgba(0, 0, 0, 0.07)

		> i
			margin-right 4px

	> .stream
		display -webkit-flex
		display -moz-flex
		display -ms-flex
		display flex
		justify-content center
		flex-wrap wrap
		padding 8px

		> .img
			flex 1 1 33%
			width 33%
			height 80px
			background-position center center
			background-size cover
			background-clip content-box
			border solid 2px transparent

	> .initializing
	> .empty
		margin 0
		padding 16px
		text-align center
		color #aaa

		> i
			margin-right 4px

</style>