mirror of
				https://codeberg.org/yeentown/barkey.git
				synced 2025-10-25 02:34:51 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			94 lines
		
	
	
	
		
			2.1 KiB
		
	
	
	
		
			Vue
		
	
	
	
	
	
			
		
		
	
	
			94 lines
		
	
	
	
		
			2.1 KiB
		
	
	
	
		
			Vue
		
	
	
	
	
	
| <!--
 | |
| SPDX-FileCopyrightText: syuilo and misskey-project
 | |
| SPDX-License-Identifier: AGPL-3.0-only
 | |
| -->
 | |
| 
 | |
| <template>
 | |
| <div v-adaptive-bg :class="[$style.root]">
 | |
| 	<MkAvatar :class="$style.avatar" :user="user" indicator/>
 | |
| 	<div :class="$style.body">
 | |
| 		<span :class="$style.name"><MkUserName :user="user"/></span>
 | |
| 		<span :class="$style.sub"><span class="_monospace">@{{ acct(user) }}</span></span>
 | |
| 	</div>
 | |
| 	<MkMiniChart v-if="chartValues" :class="$style.chart" :src="chartValues"/>
 | |
| </div>
 | |
| </template>
 | |
| 
 | |
| <script lang="ts" setup>
 | |
| import * as Misskey from 'misskey-js';
 | |
| import { onMounted, ref } from 'vue';
 | |
| import MkMiniChart from '@/components/MkMiniChart.vue';
 | |
| import { misskeyApiGet } from '@/utility/misskey-api.js';
 | |
| import { acct } from '@/filters/user.js';
 | |
| 
 | |
| const props = withDefaults(defineProps<{
 | |
| 	user: Misskey.entities.User;
 | |
| 	withChart?: boolean;
 | |
| }>(), {
 | |
| 	withChart: true,
 | |
| });
 | |
| 
 | |
| const chartValues = ref<number[] | null>(null);
 | |
| 
 | |
| onMounted(() => {
 | |
| 	if (props.withChart) {
 | |
| 		misskeyApiGet('charts/user/notes', { userId: props.user.id, limit: 16 + 1, span: 'day' }).then(res => {
 | |
| 			// 今日のぶんの値はまだ途中の値であり、それも含めると大抵の場合前日よりも下降しているようなグラフになってしまうため今日は弾く
 | |
| 			res.inc.splice(0, 1);
 | |
| 			chartValues.value = res.inc;
 | |
| 		});
 | |
| 	}
 | |
| });
 | |
| </script>
 | |
| 
 | |
| <style lang="scss" module>
 | |
| $bodyTitleHieght: 18px;
 | |
| $bodyInfoHieght: 16px;
 | |
| 
 | |
| .root {
 | |
| 	display: flex;
 | |
| 	align-items: center;
 | |
| 	padding: 16px;
 | |
| 	background: var(--MI_THEME-panel);
 | |
| 	border-radius: 8px;
 | |
| }
 | |
| 
 | |
| .avatar {
 | |
| 	display: block;
 | |
| 	width: ($bodyTitleHieght + $bodyInfoHieght);
 | |
| 	height: ($bodyTitleHieght + $bodyInfoHieght);
 | |
| 	margin-right: 12px;
 | |
| }
 | |
| 
 | |
| .body {
 | |
| 	flex: 1;
 | |
| 	overflow: hidden;
 | |
| 	font-size: 0.9em;
 | |
| 	color: var(--MI_THEME-fg);
 | |
| 	padding-right: 8px;
 | |
| }
 | |
| 
 | |
| .name {
 | |
| 	display: block;
 | |
| 	width: 100%;
 | |
| 	white-space: nowrap;
 | |
| 	overflow: hidden;
 | |
| 	text-overflow: ellipsis;
 | |
| 	line-height: $bodyTitleHieght;
 | |
| }
 | |
| 
 | |
| .sub {
 | |
| 	display: block;
 | |
| 	width: 100%;
 | |
| 	font-size: 95%;
 | |
| 	opacity: 0.7;
 | |
| 	line-height: $bodyInfoHieght;
 | |
| 	white-space: nowrap;
 | |
| 	overflow: hidden;
 | |
| 	text-overflow: ellipsis;
 | |
| }
 | |
| 
 | |
| .chart {
 | |
| 	height: 30px;
 | |
| }
 | |
| </style>
 |