mirror of
				https://codeberg.org/yeentown/barkey.git
				synced 2025-10-26 11:07:48 +00:00 
			
		
		
		
	enhance(frontend): 設定検索時に対象が含まれるMkFolderを自動で開いておくように
This commit is contained in:
		
							parent
							
								
									e8758bf77d
								
							
						
					
					
						commit
						3d206d2a0f
					
				
					 2 changed files with 21 additions and 20 deletions
				
			
		|  | @ -5,7 +5,7 @@ SPDX-License-Identifier: AGPL-3.0-only | ||||||
| 
 | 
 | ||||||
| <template> | <template> | ||||||
| <div ref="root" :class="[$style.root, { [$style.highlighted]: highlighted }]"> | <div ref="root" :class="[$style.root, { [$style.highlighted]: highlighted }]"> | ||||||
| 	<slot></slot> | 	<slot :isParentOfTarget="isParentOfTarget"></slot> | ||||||
| </div> | </div> | ||||||
| </template> | </template> | ||||||
| 
 | 
 | ||||||
|  | @ -39,9 +39,10 @@ const rootElMutationObserver = new MutationObserver(() => { | ||||||
| const injectedSearchMarkerId = inject(DI.inAppSearchMarkerId, null); | const injectedSearchMarkerId = inject(DI.inAppSearchMarkerId, null); | ||||||
| const searchMarkerId = computed(() => injectedSearchMarkerId?.value ?? window.location.hash.slice(1)); | const searchMarkerId = computed(() => injectedSearchMarkerId?.value ?? window.location.hash.slice(1)); | ||||||
| const highlighted = ref(props.markerId === searchMarkerId.value); | const highlighted = ref(props.markerId === searchMarkerId.value); | ||||||
|  | const isParentOfTarget = computed(() => props.children?.includes(searchMarkerId.value)); | ||||||
| 
 | 
 | ||||||
| function checkChildren() { | function checkChildren() { | ||||||
| 	if (props.children?.includes(searchMarkerId.value)) { | 	if (isParentOfTarget.value) { | ||||||
| 		const el = window.document.querySelector(`[data-in-app-search-marker-id="${searchMarkerId.value}"]`); | 		const el = window.document.querySelector(`[data-in-app-search-marker-id="${searchMarkerId.value}"]`); | ||||||
| 		highlighted.value = el == null; | 		highlighted.value = el == null; | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
|  | @ -11,8 +11,8 @@ SPDX-License-Identifier: AGPL-3.0-only | ||||||
| 		</MkFeatureBanner> | 		</MkFeatureBanner> | ||||||
| 
 | 
 | ||||||
| 		<div class="_gaps_s"> | 		<div class="_gaps_s"> | ||||||
| 			<SearchMarker :keywords="['general']"> | 			<SearchMarker v-slot="slotProps" :keywords="['general']"> | ||||||
| 				<MkFolder> | 				<MkFolder :defaultOpen="slotProps.isParentOfTarget"> | ||||||
| 					<template #label><SearchLabel>{{ i18n.ts.general }}</SearchLabel></template> | 					<template #label><SearchLabel>{{ i18n.ts.general }}</SearchLabel></template> | ||||||
| 					<template #icon><SearchIcon><i class="ti ti-settings"></i></SearchIcon></template> | 					<template #icon><SearchIcon><i class="ti ti-settings"></i></SearchIcon></template> | ||||||
| 
 | 
 | ||||||
|  | @ -108,8 +108,8 @@ SPDX-License-Identifier: AGPL-3.0-only | ||||||
| 				</MkFolder> | 				</MkFolder> | ||||||
| 			</SearchMarker> | 			</SearchMarker> | ||||||
| 
 | 
 | ||||||
| 			<SearchMarker :keywords="['timeline', 'note']"> | 			<SearchMarker v-slot="slotProps" :keywords="['timeline', 'note']"> | ||||||
| 				<MkFolder> | 				<MkFolder :defaultOpen="slotProps.isParentOfTarget"> | ||||||
| 					<template #label><SearchLabel>{{ i18n.ts._settings.timelineAndNote }}</SearchLabel></template> | 					<template #label><SearchLabel>{{ i18n.ts._settings.timelineAndNote }}</SearchLabel></template> | ||||||
| 					<template #icon><SearchIcon><i class="ti ti-notes"></i></SearchIcon></template> | 					<template #icon><SearchIcon><i class="ti ti-notes"></i></SearchIcon></template> | ||||||
| 
 | 
 | ||||||
|  | @ -276,8 +276,8 @@ SPDX-License-Identifier: AGPL-3.0-only | ||||||
| 				</MkFolder> | 				</MkFolder> | ||||||
| 			</SearchMarker> | 			</SearchMarker> | ||||||
| 
 | 
 | ||||||
| 			<SearchMarker :keywords="['post', 'form']"> | 			<SearchMarker v-slot="slotProps" :keywords="['post', 'form']"> | ||||||
| 				<MkFolder> | 				<MkFolder :defaultOpen="slotProps.isParentOfTarget"> | ||||||
| 					<template #label><SearchLabel>{{ i18n.ts.postForm }}</SearchLabel></template> | 					<template #label><SearchLabel>{{ i18n.ts.postForm }}</SearchLabel></template> | ||||||
| 					<template #icon><SearchIcon><i class="ti ti-edit"></i></SearchIcon></template> | 					<template #icon><SearchIcon><i class="ti ti-edit"></i></SearchIcon></template> | ||||||
| 
 | 
 | ||||||
|  | @ -338,8 +338,8 @@ SPDX-License-Identifier: AGPL-3.0-only | ||||||
| 				</MkFolder> | 				</MkFolder> | ||||||
| 			</SearchMarker> | 			</SearchMarker> | ||||||
| 
 | 
 | ||||||
| 			<SearchMarker :keywords="['notification']"> | 			<SearchMarker v-slot="slotProps" :keywords="['notification']"> | ||||||
| 				<MkFolder> | 				<MkFolder :defaultOpen="slotProps.isParentOfTarget"> | ||||||
| 					<template #label><SearchLabel>{{ i18n.ts.notifications }}</SearchLabel></template> | 					<template #label><SearchLabel>{{ i18n.ts.notifications }}</SearchLabel></template> | ||||||
| 					<template #icon><SearchIcon><i class="ti ti-bell"></i></SearchIcon></template> | 					<template #icon><SearchIcon><i class="ti ti-bell"></i></SearchIcon></template> | ||||||
| 
 | 
 | ||||||
|  | @ -380,8 +380,8 @@ SPDX-License-Identifier: AGPL-3.0-only | ||||||
| 			</SearchMarker> | 			</SearchMarker> | ||||||
| 
 | 
 | ||||||
| 			<template v-if="$i.policies.chatAvailability !== 'unavailable'"> | 			<template v-if="$i.policies.chatAvailability !== 'unavailable'"> | ||||||
| 				<SearchMarker :keywords="['chat', 'messaging']"> | 				<SearchMarker v-slot="slotProps" :keywords="['chat', 'messaging']"> | ||||||
| 					<MkFolder> | 					<MkFolder :defaultOpen="slotProps.isParentOfTarget"> | ||||||
| 						<template #label><SearchLabel>{{ i18n.ts.chat }}</SearchLabel></template> | 						<template #label><SearchLabel>{{ i18n.ts.chat }}</SearchLabel></template> | ||||||
| 						<template #icon><SearchIcon><i class="ti ti-messages"></i></SearchIcon></template> | 						<template #icon><SearchIcon><i class="ti ti-messages"></i></SearchIcon></template> | ||||||
| 
 | 
 | ||||||
|  | @ -420,8 +420,8 @@ SPDX-License-Identifier: AGPL-3.0-only | ||||||
| 				</SearchMarker> | 				</SearchMarker> | ||||||
| 			</template> | 			</template> | ||||||
| 
 | 
 | ||||||
| 			<SearchMarker :keywords="['accessibility']"> | 			<SearchMarker v-slot="slotProps" :keywords="['accessibility']"> | ||||||
| 				<MkFolder> | 				<MkFolder :defaultOpen="slotProps.isParentOfTarget"> | ||||||
| 					<template #label><SearchLabel>{{ i18n.ts.accessibility }}</SearchLabel></template> | 					<template #label><SearchLabel>{{ i18n.ts.accessibility }}</SearchLabel></template> | ||||||
| 					<template #icon><SearchIcon><i class="ti ti-accessible"></i></SearchIcon></template> | 					<template #icon><SearchIcon><i class="ti ti-accessible"></i></SearchIcon></template> | ||||||
| 
 | 
 | ||||||
|  | @ -530,8 +530,8 @@ SPDX-License-Identifier: AGPL-3.0-only | ||||||
| 				</MkFolder> | 				</MkFolder> | ||||||
| 			</SearchMarker> | 			</SearchMarker> | ||||||
| 
 | 
 | ||||||
| 			<SearchMarker :keywords="['performance']"> | 			<SearchMarker v-slot="slotProps" :keywords="['performance']"> | ||||||
| 				<MkFolder> | 				<MkFolder :defaultOpen="slotProps.isParentOfTarget"> | ||||||
| 					<template #label><SearchLabel>{{ i18n.ts.performance }}</SearchLabel></template> | 					<template #label><SearchLabel>{{ i18n.ts.performance }}</SearchLabel></template> | ||||||
| 					<template #icon><SearchIcon><i class="ti ti-battery-vertical-eco"></i></SearchIcon></template> | 					<template #icon><SearchIcon><i class="ti ti-battery-vertical-eco"></i></SearchIcon></template> | ||||||
| 
 | 
 | ||||||
|  | @ -566,8 +566,8 @@ SPDX-License-Identifier: AGPL-3.0-only | ||||||
| 				</MkFolder> | 				</MkFolder> | ||||||
| 			</SearchMarker> | 			</SearchMarker> | ||||||
| 
 | 
 | ||||||
| 			<SearchMarker :keywords="['datasaver']"> | 			<SearchMarker v-slot="slotProps" :keywords="['datasaver']"> | ||||||
| 				<MkFolder> | 				<MkFolder :defaultOpen="slotProps.isParentOfTarget"> | ||||||
| 					<template #label><SearchLabel>{{ i18n.ts.dataSaver }}</SearchLabel></template> | 					<template #label><SearchLabel>{{ i18n.ts.dataSaver }}</SearchLabel></template> | ||||||
| 					<template #icon><SearchIcon><i class="ti ti-antenna-bars-3"></i></SearchIcon></template> | 					<template #icon><SearchIcon><i class="ti ti-antenna-bars-3"></i></SearchIcon></template> | ||||||
| 
 | 
 | ||||||
|  | @ -600,8 +600,8 @@ SPDX-License-Identifier: AGPL-3.0-only | ||||||
| 				</MkFolder> | 				</MkFolder> | ||||||
| 			</SearchMarker> | 			</SearchMarker> | ||||||
| 
 | 
 | ||||||
| 			<SearchMarker :keywords="['other']"> | 			<SearchMarker v-slot="slotProps" :keywords="['other']"> | ||||||
| 				<MkFolder> | 				<MkFolder :defaultOpen="slotProps.isParentOfTarget"> | ||||||
| 					<template #label><SearchLabel>{{ i18n.ts.other }}</SearchLabel></template> | 					<template #label><SearchLabel>{{ i18n.ts.other }}</SearchLabel></template> | ||||||
| 					<template #icon><SearchIcon><i class="ti ti-settings-cog"></i></SearchIcon></template> | 					<template #icon><SearchIcon><i class="ti ti-settings-cog"></i></SearchIcon></template> | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		
		Reference in a new issue