refactor(client): use css modules
This commit is contained in:
		
							parent
							
								
									34a7b52105
								
							
						
					
					
						commit
						203a7ad073
					
				
					 1 changed files with 157 additions and 155 deletions
				
			
		|  | @ -1,36 +1,36 @@ | ||||||
| <template> | <template> | ||||||
| <div v-if="show" ref="el" class="fdidabkb" :class="{ slim: narrow, thin: thin_ }" :style="{ background: bg }" @click="onClick"> | <div v-if="show" ref="el" :class="[$style.root, { [$style.slim]: narrow, [$style.thin]: thin_ }]" :style="{ background: bg }" @click="onClick"> | ||||||
| 	<div v-if="narrow" class="buttons left"> | 	<div v-if="narrow" :class="$style.buttonsLeft"> | ||||||
| 		<MkAvatar v-if="props.displayMyAvatar && $i" class="avatar" :user="$i" :disable-preview="true"/> | 		<MkAvatar v-if="props.displayMyAvatar && $i" :class="$style.avatar" :user="$i" :disable-preview="true"/> | ||||||
| 	</div> | 	</div> | ||||||
| 	<template v-if="metadata"> | 	<template v-if="metadata"> | ||||||
| 		<div v-if="!hideTitle" class="titleContainer" @click="showTabsPopup"> | 		<div v-if="!hideTitle" :class="$style.titleContainer" @click="showTabsPopup"> | ||||||
| 			<MkAvatar v-if="metadata.avatar" class="avatar" :user="metadata.avatar" :disable-preview="true" :show-indicator="true"/> | 			<MkAvatar v-if="metadata.avatar" :class="$style.titleAvatar" :user="metadata.avatar" :disable-preview="true" :show-indicator="true"/> | ||||||
| 			<i v-else-if="metadata.icon" class="icon" :class="metadata.icon"></i> | 			<i v-else-if="metadata.icon" :class="[$style.titleIcon, metadata.icon]"></i> | ||||||
| 
 | 
 | ||||||
| 			<div class="title"> | 			<div :class="$style.title"> | ||||||
| 				<MkUserName v-if="metadata.userName" :user="metadata.userName" :nowrap="true" class="title"/> | 				<MkUserName v-if="metadata.userName" :user="metadata.userName" :nowrap="true"/> | ||||||
| 				<div v-else-if="metadata.title" class="title">{{ metadata.title }}</div> | 				<div v-else-if="metadata.title">{{ metadata.title }}</div> | ||||||
| 				<div v-if="!narrow && metadata.subtitle" class="subtitle"> | 				<div v-if="!narrow && metadata.subtitle" :class="$style.subtitle"> | ||||||
| 					{{ metadata.subtitle }} | 					{{ metadata.subtitle }} | ||||||
| 				</div> | 				</div> | ||||||
| 				<div v-if="narrow && hasTabs" class="subtitle activeTab"> | 				<div v-if="narrow && hasTabs" :class="[$style.subtitle, $style.activeTab]"> | ||||||
| 					{{ tabs.find(tab => tab.key === props.tab)?.title }} | 					{{ tabs.find(tab => tab.key === props.tab)?.title }} | ||||||
| 					<i class="chevron ti ti-chevron-down"></i> | 					<i class="ti ti-chevron-down" :class="$style.chevron"></i> | ||||||
| 				</div> | 				</div> | ||||||
| 			</div> | 			</div> | ||||||
| 		</div> | 		</div> | ||||||
| 		<div v-if="!narrow || hideTitle" class="tabs"> | 		<div v-if="!narrow || hideTitle" :class="$style.tabs"> | ||||||
| 			<button v-for="tab in tabs" :ref="(el) => tabRefs[tab.key] = (el as HTMLElement)" v-tooltip.noDelay="tab.title" class="tab _button" :class="{ active: tab.key != null && tab.key === props.tab }" @mousedown="(ev) => onTabMousedown(tab, ev)" @click="(ev) => onTabClick(tab, ev)"> | 			<button v-for="tab in tabs" :ref="(el) => tabRefs[tab.key] = (el as HTMLElement)" v-tooltip.noDelay="tab.title" class="_button" :class="[$style.tab, { [$style.active]: tab.key != null && tab.key === props.tab }]" @mousedown="(ev) => onTabMousedown(tab, ev)" @click="(ev) => onTabClick(tab, ev)"> | ||||||
| 				<i v-if="tab.icon" class="icon" :class="tab.icon"></i> | 				<i v-if="tab.icon" :class="[$style.tabIcon, tab.icon]"></i> | ||||||
| 				<span v-if="!tab.iconOnly" class="title">{{ tab.title }}</span> | 				<span v-if="!tab.iconOnly" :class="$style.tabTitle">{{ tab.title }}</span> | ||||||
| 			</button> | 			</button> | ||||||
| 			<div ref="tabHighlightEl" class="highlight"></div> | 			<div ref="tabHighlightEl" :class="$style.tabHighlight"></div> | ||||||
| 		</div> | 		</div> | ||||||
| 	</template> | 	</template> | ||||||
| 	<div class="buttons right"> | 	<div :class="$style.buttonsRight"> | ||||||
| 		<template v-for="action in actions"> | 		<template v-for="action in actions"> | ||||||
| 			<button v-tooltip.noDelay="action.text" class="_button button" :class="{ highlighted: action.highlighted }" @click.stop="action.handler" @touchstart="preventDrag"><i :class="action.icon"></i></button> | 			<button v-tooltip.noDelay="action.text" class="_button" :class="[$style.button, { [$style.highlighted]: action.highlighted }]" @click.stop="action.handler" @touchstart="preventDrag"><i :class="action.icon"></i></button> | ||||||
| 		</template> | 		</template> | ||||||
| 	</div> | 	</div> | ||||||
| </div> | </div> | ||||||
|  | @ -178,8 +178,8 @@ onUnmounted(() => { | ||||||
| }); | }); | ||||||
| </script> | </script> | ||||||
| 
 | 
 | ||||||
| <style lang="scss" scoped> | <style lang="scss" module> | ||||||
| .fdidabkb { | .root { | ||||||
| 	--height: 50px; | 	--height: 50px; | ||||||
| 	display: flex; | 	display: flex; | ||||||
| 	width: 100%; | 	width: 100%; | ||||||
|  | @ -215,154 +215,156 @@ onUnmounted(() => { | ||||||
| 			} | 			} | ||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
|  | } | ||||||
| 
 | 
 | ||||||
| 	> .buttons { | .buttons { | ||||||
| 		--margin: 8px; | 	--margin: 8px; | ||||||
| 		display: flex; | 	display: flex; | ||||||
|     align-items: center; | 	align-items: center; | ||||||
| 		min-width: var(--height); | 	min-width: var(--height); | ||||||
| 		height: var(--height); | 	height: var(--height); | ||||||
| 		margin: 0 var(--margin); | 	margin: 0 var(--margin); | ||||||
| 
 | 
 | ||||||
| 		&.left { | 	&:empty { | ||||||
| 			margin-right: auto; | 		width: var(--height); | ||||||
|  | 	} | ||||||
|  | } | ||||||
| 
 | 
 | ||||||
| 			> .avatar { | .buttonsLeft { | ||||||
| 				$size: 32px; | 	composes: buttons; | ||||||
| 				display: inline-block; | 	margin-right: auto; | ||||||
| 				width: $size; | } | ||||||
| 				height: $size; |  | ||||||
| 				vertical-align: bottom; |  | ||||||
| 				margin: 0 8px; |  | ||||||
| 				pointer-events: none; |  | ||||||
| 			} |  | ||||||
| 		} |  | ||||||
| 
 | 
 | ||||||
| 		&.right { | .buttonsRight { | ||||||
| 			margin-left: auto; | 	composes: buttons; | ||||||
| 		} | 	margin-left: auto; | ||||||
|  | } | ||||||
| 
 | 
 | ||||||
| 		&:empty { | .avatar { | ||||||
| 			width: var(--height); | 	$size: 32px; | ||||||
| 		} | 	display: inline-block; | ||||||
|  | 	width: $size; | ||||||
|  | 	height: $size; | ||||||
|  | 	vertical-align: bottom; | ||||||
|  | 	margin: 0 8px; | ||||||
|  | 	pointer-events: none; | ||||||
|  | } | ||||||
| 
 | 
 | ||||||
| 		> .button { | .button { | ||||||
| 			display: flex; | 	display: flex; | ||||||
| 			align-items: center; | 	align-items: center; | ||||||
| 			justify-content: center; | 	justify-content: center; | ||||||
| 			height: calc(var(--height) - (var(--margin) * 2)); | 	height: calc(var(--height) - (var(--margin) * 2)); | ||||||
| 			width: calc(var(--height) - (var(--margin) * 2)); | 	width: calc(var(--height) - (var(--margin) * 2)); | ||||||
| 			box-sizing: border-box; | 	box-sizing: border-box; | ||||||
| 			position: relative; | 	position: relative; | ||||||
| 			border-radius: 5px; | 	border-radius: 5px; | ||||||
| 
 | 
 | ||||||
| 			&:hover { | 	&:hover { | ||||||
| 				background: rgba(0, 0, 0, 0.05); | 		background: rgba(0, 0, 0, 0.05); | ||||||
| 			} |  | ||||||
| 
 |  | ||||||
| 			&.highlighted { |  | ||||||
| 				color: var(--accent); |  | ||||||
| 			} |  | ||||||
| 		} |  | ||||||
| 
 |  | ||||||
| 		> .fullButton { |  | ||||||
| 			& + .fullButton { |  | ||||||
| 				margin-left: 12px; |  | ||||||
| 			} |  | ||||||
| 		} |  | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	> .titleContainer { | 	&.highlighted { | ||||||
| 		display: flex; | 		color: var(--accent); | ||||||
| 		align-items: center; |  | ||||||
| 		max-width: 400px; |  | ||||||
| 		overflow: auto; |  | ||||||
| 		white-space: nowrap; |  | ||||||
| 		text-align: left; |  | ||||||
| 		font-weight: bold; |  | ||||||
| 		flex-shrink: 0; |  | ||||||
| 		margin-left: 24px; |  | ||||||
| 
 |  | ||||||
| 		> .avatar { |  | ||||||
| 			$size: 32px; |  | ||||||
| 			display: inline-block; |  | ||||||
| 			width: $size; |  | ||||||
| 			height: $size; |  | ||||||
| 			vertical-align: bottom; |  | ||||||
| 			margin: 0 8px; |  | ||||||
| 			pointer-events: none; |  | ||||||
| 		} |  | ||||||
| 
 |  | ||||||
| 		> .icon { |  | ||||||
| 			margin-right: 8px; |  | ||||||
| 			width: 16px; |  | ||||||
| 			text-align: center; |  | ||||||
| 		} |  | ||||||
| 
 |  | ||||||
| 		> .title { |  | ||||||
| 			min-width: 0; |  | ||||||
| 			overflow: hidden; |  | ||||||
| 			text-overflow: ellipsis; |  | ||||||
| 			white-space: nowrap; |  | ||||||
| 			line-height: 1.1; |  | ||||||
| 
 |  | ||||||
| 			> .subtitle { |  | ||||||
| 				opacity: 0.6; |  | ||||||
| 				font-size: 0.8em; |  | ||||||
| 				font-weight: normal; |  | ||||||
| 				white-space: nowrap; |  | ||||||
| 				overflow: hidden; |  | ||||||
| 				text-overflow: ellipsis; |  | ||||||
| 
 |  | ||||||
| 				&.activeTab { |  | ||||||
| 					text-align: center; |  | ||||||
| 
 |  | ||||||
| 					> .chevron { |  | ||||||
| 						display: inline-block; |  | ||||||
| 						margin-left: 6px; |  | ||||||
| 					} |  | ||||||
| 				} |  | ||||||
| 			} |  | ||||||
| 		} |  | ||||||
| 	} | 	} | ||||||
|  | } | ||||||
| 
 | 
 | ||||||
| 	> .tabs { | .fullButton { | ||||||
| 		position: relative; | 	& + .fullButton { | ||||||
| 		margin-left: 16px; | 		margin-left: 12px; | ||||||
| 		font-size: 0.8em; | 	} | ||||||
| 		overflow: auto; | } | ||||||
| 		white-space: nowrap; |  | ||||||
| 
 | 
 | ||||||
| 		> .tab { | .titleContainer { | ||||||
|  | 	display: flex; | ||||||
|  | 	align-items: center; | ||||||
|  | 	max-width: 400px; | ||||||
|  | 	overflow: auto; | ||||||
|  | 	white-space: nowrap; | ||||||
|  | 	text-align: left; | ||||||
|  | 	font-weight: bold; | ||||||
|  | 	flex-shrink: 0; | ||||||
|  | 	margin-left: 24px; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | .titleAvatar { | ||||||
|  | 	$size: 32px; | ||||||
|  | 	display: inline-block; | ||||||
|  | 	width: $size; | ||||||
|  | 	height: $size; | ||||||
|  | 	vertical-align: bottom; | ||||||
|  | 	margin: 0 8px; | ||||||
|  | 	pointer-events: none; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | .titleIcon { | ||||||
|  | 	margin-right: 8px; | ||||||
|  | 	width: 16px; | ||||||
|  | 	text-align: center; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | .title { | ||||||
|  | 	min-width: 0; | ||||||
|  | 	overflow: hidden; | ||||||
|  | 	text-overflow: ellipsis; | ||||||
|  | 	white-space: nowrap; | ||||||
|  | 	line-height: 1.1; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | .subtitle { | ||||||
|  | 	opacity: 0.6; | ||||||
|  | 	font-size: 0.8em; | ||||||
|  | 	font-weight: normal; | ||||||
|  | 	white-space: nowrap; | ||||||
|  | 	overflow: hidden; | ||||||
|  | 	text-overflow: ellipsis; | ||||||
|  | 
 | ||||||
|  | 	&.activeTab { | ||||||
|  | 		text-align: center; | ||||||
|  | 
 | ||||||
|  | 		> .chevron { | ||||||
| 			display: inline-block; | 			display: inline-block; | ||||||
| 			position: relative; | 			margin-left: 6px; | ||||||
| 			padding: 0 10px; |  | ||||||
| 			height: 100%; |  | ||||||
| 			font-weight: normal; |  | ||||||
| 			opacity: 0.7; |  | ||||||
| 
 |  | ||||||
| 			&:hover { |  | ||||||
| 				opacity: 1; |  | ||||||
| 			} |  | ||||||
| 
 |  | ||||||
| 			&.active { |  | ||||||
| 				opacity: 1; |  | ||||||
| 			} |  | ||||||
| 
 |  | ||||||
| 			> .icon + .title { |  | ||||||
| 				margin-left: 8px; |  | ||||||
| 			} |  | ||||||
| 		} |  | ||||||
| 
 |  | ||||||
| 		> .highlight { |  | ||||||
| 			position: absolute; |  | ||||||
| 			bottom: 0; |  | ||||||
| 			height: 3px; |  | ||||||
| 			background: var(--accent); |  | ||||||
| 			border-radius: 999px; |  | ||||||
| 			transition: all 0.2s ease; |  | ||||||
| 			pointer-events: none; |  | ||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
| } | } | ||||||
|  | 
 | ||||||
|  | .tabs { | ||||||
|  | 	position: relative; | ||||||
|  | 	margin-left: 16px; | ||||||
|  | 	font-size: 0.8em; | ||||||
|  | 	overflow: auto; | ||||||
|  | 	white-space: nowrap; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | .tab { | ||||||
|  | 	display: inline-block; | ||||||
|  | 	position: relative; | ||||||
|  | 	padding: 0 10px; | ||||||
|  | 	height: 100%; | ||||||
|  | 	font-weight: normal; | ||||||
|  | 	opacity: 0.7; | ||||||
|  | 
 | ||||||
|  | 	&:hover { | ||||||
|  | 		opacity: 1; | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
|  | 	&.active { | ||||||
|  | 		opacity: 1; | ||||||
|  | 	} | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | .tabIcon + .tabTitle { | ||||||
|  | 	margin-left: 8px; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | .tabHighlight { | ||||||
|  | 	position: absolute; | ||||||
|  | 	bottom: 0; | ||||||
|  | 	height: 3px; | ||||||
|  | 	background: var(--accent); | ||||||
|  | 	border-radius: 999px; | ||||||
|  | 	transition: all 0.2s ease; | ||||||
|  | 	pointer-events: none; | ||||||
|  | } | ||||||
| </style> | </style> | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue