mirror of
				https://codeberg.org/yeentown/barkey.git
				synced 2025-10-25 10:44:51 +00:00 
			
		
		
		
	* refactor(frontend): prefix css variables * `MI_UI` -> `MI` * fix * `stickyBottom` * stickyTop
		
			
				
	
	
		
			104 lines
		
	
	
	
		
			1.9 KiB
		
	
	
	
		
			Vue
		
	
	
	
	
	
			
		
		
	
	
			104 lines
		
	
	
	
		
			1.9 KiB
		
	
	
	
		
			Vue
		
	
	
	
	
	
| <!--
 | |
| SPDX-FileCopyrightText: syuilo and misskey-project
 | |
| SPDX-License-Identifier: AGPL-3.0-only
 | |
| -->
 | |
| 
 | |
| <template>
 | |
| <div :class="$style.root">
 | |
| 	<MkAvatar :class="$style.avatar" :user="note.user" link preview/>
 | |
| 	<div :class="$style.main">
 | |
| 		<MkNoteHeader :class="$style.header" :note="note" :mini="true"/>
 | |
| 		<div>
 | |
| 			<p v-if="note.cw != null" :class="$style.cw">
 | |
| 				<Mfm v-if="note.cw != ''" style="margin-right: 8px;" :text="note.cw" :author="note.user" :nyaize="'respect'" :emojiUrls="note.emojis"/>
 | |
| 				<MkCwButton v-model="showContent" :text="note.text" :files="note.files" :poll="note.poll"/>
 | |
| 			</p>
 | |
| 			<div v-show="note.cw == null || showContent">
 | |
| 				<MkSubNoteContent :class="$style.text" :note="note"/>
 | |
| 			</div>
 | |
| 		</div>
 | |
| 	</div>
 | |
| </div>
 | |
| </template>
 | |
| 
 | |
| <script lang="ts" setup>
 | |
| import { ref } from 'vue';
 | |
| import * as Misskey from 'misskey-js';
 | |
| import MkNoteHeader from '@/components/MkNoteHeader.vue';
 | |
| import MkSubNoteContent from '@/components/MkSubNoteContent.vue';
 | |
| import MkCwButton from '@/components/MkCwButton.vue';
 | |
| 
 | |
| const props = defineProps<{
 | |
| 	note: Misskey.entities.Note;
 | |
| }>();
 | |
| 
 | |
| const showContent = ref(false);
 | |
| </script>
 | |
| 
 | |
| <style lang="scss" module>
 | |
| .root {
 | |
| 	display: flex;
 | |
| 	margin: 0;
 | |
| 	padding: 0;
 | |
| 	font-size: 0.95em;
 | |
| }
 | |
| 
 | |
| .avatar {
 | |
| 	flex-shrink: 0;
 | |
| 	display: block;
 | |
| 	margin: 0 10px 0 0;
 | |
| 	width: 34px;
 | |
| 	height: 34px;
 | |
| 	border-radius: 8px;
 | |
| 	position: sticky !important;
 | |
| 	top: calc(16px + var(--MI-stickyTop, 0px));
 | |
| 	left: 0;
 | |
| }
 | |
| 
 | |
| .main {
 | |
| 	flex: 1;
 | |
| 	min-width: 0;
 | |
| }
 | |
| 
 | |
| .header {
 | |
| 	margin-bottom: 2px;
 | |
| }
 | |
| 
 | |
| .cw {
 | |
| 	cursor: default;
 | |
| 	display: block;
 | |
| 	margin: 0;
 | |
| 	padding: 0;
 | |
| 	overflow-wrap: break-word;
 | |
| }
 | |
| 
 | |
| .text {
 | |
| 	cursor: default;
 | |
| 	margin: 0;
 | |
| 	padding: 0;
 | |
| }
 | |
| 
 | |
| @container (min-width: 250px) {
 | |
| 	.avatar {
 | |
| 		margin: 0 10px 0 0;
 | |
| 		width: 40px;
 | |
| 		height: 40px;
 | |
| 	}
 | |
| }
 | |
| 
 | |
| @container (min-width: 350px) {
 | |
| 	.avatar {
 | |
| 		margin: 0 10px 0 0;
 | |
| 		width: 44px;
 | |
| 		height: 44px;
 | |
| 	}
 | |
| }
 | |
| 
 | |
| @container (min-width: 500px) {
 | |
| 	.avatar {
 | |
| 		margin: 0 12px 0 0;
 | |
| 		width: 48px;
 | |
| 		height: 48px;
 | |
| 	}
 | |
| }
 | |
| </style>
 |