mirror of
				https://codeberg.org/yeentown/barkey.git
				synced 2025-11-04 07:24:13 +00:00 
			
		
		
		
	upd: rework threading ui 2/2
Co-authored-by: daph <d@waal.me> Co-authored-by: Marie <marie@kaifa.ch>
This commit is contained in:
		
							parent
							
								
									419bde43a6
								
							
						
					
					
						commit
						5db163bc67
					
				
					 1 changed files with 92 additions and 5 deletions
				
			
		| 
						 | 
					@ -8,7 +8,14 @@ SPDX-License-Identifier: AGPL-3.0-only
 | 
				
			||||||
	<div v-if="!hideLine" :class="$style.line"></div>
 | 
						<div v-if="!hideLine" :class="$style.line"></div>
 | 
				
			||||||
	<div :class="$style.main">
 | 
						<div :class="$style.main">
 | 
				
			||||||
		<div v-if="note.channel" :class="$style.colorBar" :style="{ background: note.channel.color }"></div>
 | 
							<div v-if="note.channel" :class="$style.colorBar" :style="{ background: note.channel.color }"></div>
 | 
				
			||||||
		<MkAvatar :class="$style.avatar" :user="note.user" link preview/>
 | 
							<!-- new avatar container with line (post section) -->
 | 
				
			||||||
 | 
							<div :class="$style.avatarContainer">
 | 
				
			||||||
 | 
								<MkAvatar :class="$style.avatar" :user="note.user" link preview/>
 | 
				
			||||||
 | 
								<template v-if="note.repliesCount > 0">
 | 
				
			||||||
 | 
									<div v-if="hideLine" :class="$style.threadLine"></div>
 | 
				
			||||||
 | 
								</template>
 | 
				
			||||||
 | 
							</div>
 | 
				
			||||||
 | 
							<!-- end new avatar container -->
 | 
				
			||||||
		<div :class="$style.body">
 | 
							<div :class="$style.body">
 | 
				
			||||||
			<SkNoteHeader :class="$style.header" :note="note" :classic="true" :mini="true"/>
 | 
								<SkNoteHeader :class="$style.header" :note="note" :classic="true" :mini="true"/>
 | 
				
			||||||
			<div :class="$style.content">
 | 
								<div :class="$style.content">
 | 
				
			||||||
| 
						 | 
					@ -66,7 +73,7 @@ SPDX-License-Identifier: AGPL-3.0-only
 | 
				
			||||||
		</div>
 | 
							</div>
 | 
				
			||||||
	</div>
 | 
						</div>
 | 
				
			||||||
	<template v-if="depth < 5">
 | 
						<template v-if="depth < 5">
 | 
				
			||||||
		<SkNoteSub v-for="reply in replies" :key="reply.id" :note="reply" :class="$style.reply" :detail="true" :depth="depth + 1" :expandAllCws="props.expandAllCws"/>
 | 
							<SkNoteSub v-for="reply in replies" :key="reply.id" :note="reply" :class="[$style.reply, { [$style.single]: replies.length === 1 }]" :detail="true" :depth="depth + 1" :expandAllCws="props.expandAllCws"/>
 | 
				
			||||||
	</template>
 | 
						</template>
 | 
				
			||||||
	<div v-else :class="$style.more">
 | 
						<div v-else :class="$style.more">
 | 
				
			||||||
		<MkA class="_link" :to="notePage(note)">{{ i18n.ts.continueThread }} <i class="ph-caret-double-right ph-bold ph-lg"></i></MkA>
 | 
							<MkA class="_link" :to="notePage(note)">{{ i18n.ts.continueThread }} <i class="ph-caret-double-right ph-bold ph-lg"></i></MkA>
 | 
				
			||||||
| 
						 | 
					@ -444,9 +451,9 @@ if (props.detail) {
 | 
				
			||||||
		color: var(--fgHighlighted);
 | 
							color: var(--fgHighlighted);
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					// Responsible for Reply borders 448 and 508
 | 
				
			||||||
.reply, .more {
 | 
					.reply, .more {
 | 
				
			||||||
	border-left: solid 0.5px var(--divider);
 | 
						//border-left: solid 0.5px var(--divider);
 | 
				
			||||||
	margin-top: 10px;
 | 
						margin-top: 10px;
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
| 
						 | 
					@ -505,8 +512,9 @@ if (props.detail) {
 | 
				
			||||||
	padding: 0;
 | 
						padding: 0;
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
.reply, .more {
 | 
					.reply, .more {
 | 
				
			||||||
	border-left: solid 0.5px var(--divider);
 | 
						//border-left: solid 0.5px var(--divider);
 | 
				
			||||||
	margin-top: 10px;
 | 
						margin-top: 10px;
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
| 
						 | 
					@ -542,4 +550,83 @@ if (props.detail) {
 | 
				
			||||||
	margin: 8px 8px 0 8px;
 | 
						margin: 8px 8px 0 8px;
 | 
				
			||||||
	border-radius: var(--radius-sm);
 | 
						border-radius: var(--radius-sm);
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// avatar container with line
 | 
				
			||||||
 | 
					.avatarContainer {
 | 
				
			||||||
 | 
						display: flex;
 | 
				
			||||||
 | 
						flex-direction: column;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					.threadLine {
 | 
				
			||||||
 | 
						width: 0;
 | 
				
			||||||
 | 
						flex-grow: 1;
 | 
				
			||||||
 | 
						border-left: 2.5px solid rgb(174, 174, 174);
 | 
				
			||||||
 | 
						margin-left: 29px;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					.reply {
 | 
				
			||||||
 | 
						margin-left: 29px;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					.reply:not(:last-child) {
 | 
				
			||||||
 | 
						border-left: 2.5px solid rgb(174, 174, 174);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						&::before {
 | 
				
			||||||
 | 
							left: -2px;
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					.reply::before {
 | 
				
			||||||
 | 
						position: absolute;
 | 
				
			||||||
 | 
						content: '';
 | 
				
			||||||
 | 
						left: 0px;
 | 
				
			||||||
 | 
						top: -10px;
 | 
				
			||||||
 | 
						height: 49px;
 | 
				
			||||||
 | 
						width: 15px;
 | 
				
			||||||
 | 
						border-left: 2.5px solid rgb(174, 174, 174);
 | 
				
			||||||
 | 
						border-bottom: 2.5px solid rgb(174, 174, 174);
 | 
				
			||||||
 | 
						border-bottom-left-radius: 15px;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					.single {
 | 
				
			||||||
 | 
						margin-left: 0;
 | 
				
			||||||
 | 
						padding-left: 0 !important;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						&::before {
 | 
				
			||||||
 | 
							left: 29px;
 | 
				
			||||||
 | 
							width: 0;
 | 
				
			||||||
 | 
							border-bottom: unset;
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					@container (max-width: 580px) {
 | 
				
			||||||
 | 
						.threadLine, .reply {
 | 
				
			||||||
 | 
							margin-left: 25px;
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
						.reply::before {
 | 
				
			||||||
 | 
							height: 45px;
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
						.single::before {
 | 
				
			||||||
 | 
							left: 25px;
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
						.single {
 | 
				
			||||||
 | 
							margin-left: 0;
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					@container (max-width: 450px) {
 | 
				
			||||||
 | 
						.threadLine, .reply {
 | 
				
			||||||
 | 
							margin-left: 23px;
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
						.reply::before {
 | 
				
			||||||
 | 
							height: 43px;
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
						.single::before {
 | 
				
			||||||
 | 
							left: 23px;
 | 
				
			||||||
 | 
							width: 9px;
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
						.single {
 | 
				
			||||||
 | 
							margin-left: 0;
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
</style>
 | 
					</style>
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
		Loading…
	
	Add table
		
		Reference in a new issue