Skip to content
Snippets Groups Projects
ui.header.account.vue 5.3 KiB
Newer Older
こぴなたみぽ's avatar
wip
こぴなたみぽ committed
<template>
syuilo's avatar
syuilo committed
<div class="account">
こぴなたみぽ's avatar
wip
こぴなたみぽ committed
	<button class="header" :data-active="isOpen" @click="toggle">
syuilo's avatar
syuilo committed
		<span class="username">{{ os.i.username }}<template v-if="!isOpen">%fa:angle-down%</template><template v-if="isOpen">%fa:angle-up%</template></span>
syuilo's avatar
syuilo committed
		<img class="avatar" :src="`${ os.i.avatarUrl }?thumbnail&size=64`" alt="avatar"/>
こぴなたみぽ's avatar
wip
こぴなたみぽ committed
	</button>
syuilo's avatar
syuilo committed
	<transition name="zoom-in-top">
		<div class="menu" v-if="isOpen">
			<ul>
				<li>
syuilo's avatar
syuilo committed
					<router-link :to="`/@${ os.i.username }`">%fa:user%<span>%i18n:@profile%</span>%fa:angle-right%</router-link>
syuilo's avatar
syuilo committed
				</li>
				<li @click="drive">
syuilo's avatar
syuilo committed
					<p>%fa:cloud%<span>%i18n:@drive%</span>%fa:angle-right%</p>
syuilo's avatar
syuilo committed
				</li>
syuilo's avatar
syuilo committed
				<li>
					<router-link to="/i/favorites">%fa:star%<span>%i18n:@favorites%</span>%fa:angle-right%</router-link>
				</li>
syuilo's avatar
syuilo committed
				<li @click="list">
syuilo's avatar
syuilo committed
					<p>%fa:list%<span>%i18n:@lists%</span>%fa:angle-right%</p>
syuilo's avatar
syuilo committed
				</li>
syuilo's avatar
syuilo committed
			</ul>
			<ul>
syuilo's avatar
syuilo committed
				<li>
syuilo's avatar
syuilo committed
					<a href="/i/customize-home">%fa:wrench%<span>%i18n:@customize%</span>%fa:angle-right%</a>
syuilo's avatar
syuilo committed
				</li>
syuilo's avatar
syuilo committed
				<li @click="settings">
syuilo's avatar
syuilo committed
					<p>%fa:cog%<span>%i18n:@settings%</span>%fa:angle-right%</p>
syuilo's avatar
syuilo committed
				</li>
			</ul>
			<ul>
				<li @click="signout">
syuilo's avatar
syuilo committed
					<p class="signout">%fa:power-off%<span>%i18n:@signout%</span></p>
syuilo's avatar
syuilo committed
				</li>
			</ul>
			<ul>
				<li @click="dark">
					<p><span>%i18n:@dark%</span><template v-if="_darkmode_">%fa:moon%</template><template v-else>%fa:R moon%</template></p>
syuilo's avatar
syuilo committed
				</li>
			</ul>
		</div>
	</transition>
こぴなたみぽ's avatar
wip
こぴなたみぽ committed
</div>
</template>

<script lang="ts">
import Vue from 'vue';
syuilo's avatar
syuilo committed
import MkSettingsWindow from './settings-window.vue';
syuilo's avatar
syuilo committed
import MkDriveWindow from './drive-window.vue';
こぴなたみぽ's avatar
wip
こぴなたみぽ committed
import contains from '../../../common/scripts/contains';

export default Vue.extend({
	data() {
		return {
syuilo's avatar
syuilo committed
			isOpen: false
こぴなたみぽ's avatar
wip
こぴなたみぽ committed
		};
	},
	beforeDestroy() {
		this.close();
	},
	methods: {
		toggle() {
			this.isOpen ? this.close() : this.open();
		},
		open() {
			this.isOpen = true;
			Array.from(document.querySelectorAll('body *')).forEach(el => {
				el.addEventListener('mousedown', this.onMousedown);
			});
		},
		close() {
			this.isOpen = false;
			Array.from(document.querySelectorAll('body *')).forEach(el => {
				el.removeEventListener('mousedown', this.onMousedown);
			});
		},
		onMousedown(e) {
			e.preventDefault();
			if (!contains(this.$el, e.target) && this.$el != e.target) this.close();
			return false;
		},
		drive() {
			this.close();
syuilo's avatar
syuilo committed
			(this as any).os.new(MkDriveWindow);
こぴなたみぽ's avatar
wip
こぴなたみぽ committed
		},
		settings() {
			this.close();
syuilo's avatar
syuilo committed
			(this as any).os.new(MkSettingsWindow);
syuilo's avatar
syuilo committed
		},
		signout() {
			(this as any).os.signout();
syuilo's avatar
syuilo committed
		},
		dark() {
			(this as any)._updateDarkmode_(!(this as any)._darkmode_);
こぴなたみぽ's avatar
wip
こぴなたみぽ committed
		}
	}
});
</script>

<style lang="stylus" scoped>
syuilo's avatar
syuilo committed
@import '~const.styl'

syuilo's avatar
syuilo committed
root(isDark)
こぴなたみぽ's avatar
wip
こぴなたみぽ committed
	> .header
		display block
		margin 0
		padding 0
		color #9eaba8
		border none
		background transparent
		cursor pointer

		*
			pointer-events none

		&:hover
		&[data-active='true']
syuilo's avatar
syuilo committed
			color isDark ? #fff : darken(#9eaba8, 20%)
こぴなたみぽ's avatar
wip
こぴなたみぽ committed

			> .avatar
				filter saturate(150%)

		&:active
syuilo's avatar
syuilo committed
			color isDark ? #fff : darken(#9eaba8, 30%)
こぴなたみぽ's avatar
wip
こぴなたみぽ committed

		> .username
			display block
			float left
			margin 0 12px 0 16px
			max-width 16em
			line-height 48px
			font-weight bold
			font-family Meiryo, sans-serif
			text-decoration none

			[data-fa]
				margin-left 8px

		> .avatar
			display block
			float left
			min-width 32px
			max-width 32px
			min-height 32px
			max-height 32px
			margin 8px 8px 8px 0
			border-radius 4px
			transition filter 100ms ease

	> .menu
syuilo's avatar
syuilo committed
		$bgcolor = isDark ? #282c37 : #fff
こぴなたみぽ's avatar
wip
こぴなたみぽ committed
		display block
		position absolute
		top 56px
		right -2px
		width 230px
		font-size 0.8em
syuilo's avatar
syuilo committed
		background $bgcolor
こぴなたみぽ's avatar
wip
こぴなたみぽ committed
		border-radius 4px
		box-shadow 0 1px 4px rgba(0, 0, 0, 0.25)

		&:before
			content ""
			pointer-events none
			display block
			position absolute
			top -28px
			right 12px
			border-top solid 14px transparent
			border-right solid 14px transparent
			border-bottom solid 14px rgba(0, 0, 0, 0.1)
			border-left solid 14px transparent

		&:after
			content ""
			pointer-events none
			display block
			position absolute
			top -27px
			right 12px
			border-top solid 14px transparent
			border-right solid 14px transparent
syuilo's avatar
syuilo committed
			border-bottom solid 14px $bgcolor
こぴなたみぽ's avatar
wip
こぴなたみぽ committed
			border-left solid 14px transparent

		ul
			display block
			margin 10px 0
			padding 0
			list-style none

			& + ul
				padding-top 10px
syuilo's avatar
syuilo committed
				border-top solid 1px isDark ? #1c2023 : #eee
こぴなたみぽ's avatar
wip
こぴなたみぽ committed

			> li
				display block
				margin 0
				padding 0

				> a
				> p
					display block
					z-index 1
					padding 0 28px
					margin 0
					line-height 40px
syuilo's avatar
syuilo committed
					color isDark ? #c8cece : #868C8C
こぴなたみぽ's avatar
wip
こぴなたみぽ committed
					cursor pointer

					*
						pointer-events none

syuilo's avatar
syuilo committed
					> span:first-child
syuilo's avatar
syuilo committed
						padding-left 22px
syuilo's avatar
syuilo committed

					> [data-fa]:first-child
こぴなたみぽ's avatar
wip
こぴなたみぽ committed
						margin-right 6px
syuilo's avatar
syuilo committed
						width 16px
こぴなたみぽ's avatar
wip
こぴなたみぽ committed

syuilo's avatar
syuilo committed
					> [data-fa]:last-child
こぴなたみぽ's avatar
wip
こぴなたみぽ committed
						display block
						position absolute
						top 0
						right 8px
						z-index 1
						padding 0 20px
						font-size 1.2em
						line-height 40px

					&:hover, &:active
						text-decoration none
						background $theme-color
						color $theme-color-foreground

syuilo's avatar
syuilo committed
					&:active
						background darken($theme-color, 10%)

syuilo's avatar
syuilo committed
					&.signout
						$color = #e64137

						&:hover, &:active
							background $color
							color #fff

						&:active
							background darken($color, 10%)

syuilo's avatar
syuilo committed
.zoom-in-top-enter-active,
.zoom-in-top-leave-active {
	transform-origin: center -16px;
}

syuilo's avatar
syuilo committed
.account[data-darkmode]
	root(true)

.account:not([data-darkmode])
	root(false)

こぴなたみぽ's avatar
wip
こぴなたみぽ committed
</style>