mirror of
				https://codeberg.org/yeentown/barkey.git
				synced 2025-10-25 02:34:51 +00:00 
			
		
		
		
	enhance(frontend): tweak settings page
This commit is contained in:
		
							parent
							
								
									abc1e9168d
								
							
						
					
					
						commit
						bdb74539d4
					
				
					 3 changed files with 77 additions and 80 deletions
				
			
		|  | @ -67,6 +67,45 @@ SPDX-License-Identifier: AGPL-3.0-only | ||||||
| 			</div> | 			</div> | ||||||
| 		</FormSection> | 		</FormSection> | ||||||
| 
 | 
 | ||||||
|  | 		<FormSection> | ||||||
|  | 			<div class="_gaps_m"> | ||||||
|  | 				<SearchMarker :keywords="['remember', 'keep', 'note', 'visibility']"> | ||||||
|  | 					<MkPreferenceContainer k="rememberNoteVisibility"> | ||||||
|  | 						<MkSwitch v-model="rememberNoteVisibility" @update:modelValue="save()"> | ||||||
|  | 							<template #label><SearchLabel>{{ i18n.ts.rememberNoteVisibility }}</SearchLabel></template> | ||||||
|  | 						</MkSwitch> | ||||||
|  | 					</MkPreferenceContainer> | ||||||
|  | 				</SearchMarker> | ||||||
|  | 
 | ||||||
|  | 				<SearchMarker :keywords="['default', 'note', 'visibility']"> | ||||||
|  | 					<MkDisableSection :disabled="rememberNoteVisibility"> | ||||||
|  | 						<MkFolder> | ||||||
|  | 							<template #label><SearchLabel>{{ i18n.ts.defaultNoteVisibility }}</SearchLabel></template> | ||||||
|  | 							<template v-if="defaultNoteVisibility === 'public'" #suffix>{{ i18n.ts._visibility.public }}</template> | ||||||
|  | 							<template v-else-if="defaultNoteVisibility === 'home'" #suffix>{{ i18n.ts._visibility.home }}</template> | ||||||
|  | 							<template v-else-if="defaultNoteVisibility === 'followers'" #suffix>{{ i18n.ts._visibility.followers }}</template> | ||||||
|  | 							<template v-else-if="defaultNoteVisibility === 'specified'" #suffix>{{ i18n.ts._visibility.specified }}</template> | ||||||
|  | 
 | ||||||
|  | 							<div class="_gaps_m"> | ||||||
|  | 								<MkPreferenceContainer k="defaultNoteVisibility"> | ||||||
|  | 									<MkSelect v-model="defaultNoteVisibility"> | ||||||
|  | 										<option value="public">{{ i18n.ts._visibility.public }}</option> | ||||||
|  | 										<option value="home">{{ i18n.ts._visibility.home }}</option> | ||||||
|  | 										<option value="followers">{{ i18n.ts._visibility.followers }}</option> | ||||||
|  | 										<option value="specified">{{ i18n.ts._visibility.specified }}</option> | ||||||
|  | 									</MkSelect> | ||||||
|  | 								</MkPreferenceContainer> | ||||||
|  | 
 | ||||||
|  | 								<MkPreferenceContainer k="defaultNoteLocalOnly"> | ||||||
|  | 									<MkSwitch v-model="defaultNoteLocalOnly">{{ i18n.ts._visibility.disableFederation }}</MkSwitch> | ||||||
|  | 								</MkPreferenceContainer> | ||||||
|  | 							</div> | ||||||
|  | 						</MkFolder> | ||||||
|  | 					</MkDisableSection> | ||||||
|  | 				</SearchMarker> | ||||||
|  | 			</div> | ||||||
|  | 		</FormSection> | ||||||
|  | 
 | ||||||
| 		<SearchMarker :keywords="['note']"> | 		<SearchMarker :keywords="['note']"> | ||||||
| 			<FormSection> | 			<FormSection> | ||||||
| 				<template #label><SearchLabel>{{ i18n.ts.note }}</SearchLabel></template> | 				<template #label><SearchLabel>{{ i18n.ts.note }}</SearchLabel></template> | ||||||
|  | @ -371,6 +410,9 @@ const alwaysConfirmFollow = prefer.model('alwaysConfirmFollow'); | ||||||
| const confirmWhenRevealingSensitiveMedia = prefer.model('confirmWhenRevealingSensitiveMedia'); | const confirmWhenRevealingSensitiveMedia = prefer.model('confirmWhenRevealingSensitiveMedia'); | ||||||
| const confirmOnReact = prefer.model('confirmOnReact'); | const confirmOnReact = prefer.model('confirmOnReact'); | ||||||
| const contextMenu = prefer.model('contextMenu'); | const contextMenu = prefer.model('contextMenu'); | ||||||
|  | const defaultNoteVisibility = prefer.model('defaultNoteVisibility'); | ||||||
|  | const defaultNoteLocalOnly = prefer.model('defaultNoteLocalOnly'); | ||||||
|  | const rememberNoteVisibility = prefer.model('rememberNoteVisibility'); | ||||||
| 
 | 
 | ||||||
| watch(lang, () => { | watch(lang, () => { | ||||||
| 	miLocalStorage.setItem('lang', lang.value as string); | 	miLocalStorage.setItem('lang', lang.value as string); | ||||||
|  |  | ||||||
|  | @ -168,45 +168,6 @@ SPDX-License-Identifier: AGPL-3.0-only | ||||||
| 				</div> | 				</div> | ||||||
| 			</FormSection> | 			</FormSection> | ||||||
| 		</SearchMarker> | 		</SearchMarker> | ||||||
| 
 |  | ||||||
| 		<FormSection> |  | ||||||
| 			<div class="_gaps_m"> |  | ||||||
| 				<SearchMarker :keywords="['remember', 'keep', 'note', 'visibility']"> |  | ||||||
| 					<MkPreferenceContainer k="rememberNoteVisibility"> |  | ||||||
| 						<MkSwitch v-model="rememberNoteVisibility" @update:modelValue="save()"> |  | ||||||
| 							<template #label><SearchLabel>{{ i18n.ts.rememberNoteVisibility }}</SearchLabel></template> |  | ||||||
| 						</MkSwitch> |  | ||||||
| 					</MkPreferenceContainer> |  | ||||||
| 				</SearchMarker> |  | ||||||
| 
 |  | ||||||
| 				<SearchMarker :keywords="['default', 'note', 'visibility']"> |  | ||||||
| 					<MkDisableSection :disabled="rememberNoteVisibility"> |  | ||||||
| 						<MkFolder> |  | ||||||
| 							<template #label><SearchLabel>{{ i18n.ts.defaultNoteVisibility }}</SearchLabel></template> |  | ||||||
| 							<template v-if="defaultNoteVisibility === 'public'" #suffix>{{ i18n.ts._visibility.public }}</template> |  | ||||||
| 							<template v-else-if="defaultNoteVisibility === 'home'" #suffix>{{ i18n.ts._visibility.home }}</template> |  | ||||||
| 							<template v-else-if="defaultNoteVisibility === 'followers'" #suffix>{{ i18n.ts._visibility.followers }}</template> |  | ||||||
| 							<template v-else-if="defaultNoteVisibility === 'specified'" #suffix>{{ i18n.ts._visibility.specified }}</template> |  | ||||||
| 
 |  | ||||||
| 							<div class="_gaps_m"> |  | ||||||
| 								<MkPreferenceContainer k="defaultNoteVisibility"> |  | ||||||
| 									<MkSelect v-model="defaultNoteVisibility"> |  | ||||||
| 										<option value="public">{{ i18n.ts._visibility.public }}</option> |  | ||||||
| 										<option value="home">{{ i18n.ts._visibility.home }}</option> |  | ||||||
| 										<option value="followers">{{ i18n.ts._visibility.followers }}</option> |  | ||||||
| 										<option value="specified">{{ i18n.ts._visibility.specified }}</option> |  | ||||||
| 									</MkSelect> |  | ||||||
| 								</MkPreferenceContainer> |  | ||||||
| 
 |  | ||||||
| 								<MkPreferenceContainer k="defaultNoteLocalOnly"> |  | ||||||
| 									<MkSwitch v-model="defaultNoteLocalOnly">{{ i18n.ts._visibility.disableFederation }}</MkSwitch> |  | ||||||
| 								</MkPreferenceContainer> |  | ||||||
| 							</div> |  | ||||||
| 						</MkFolder> |  | ||||||
| 					</MkDisableSection> |  | ||||||
| 				</SearchMarker> |  | ||||||
| 			</div> |  | ||||||
| 		</FormSection> |  | ||||||
| 	</div> | 	</div> | ||||||
| </SearchMarker> | </SearchMarker> | ||||||
| </template> | </template> | ||||||
|  | @ -227,8 +188,6 @@ import { formatDateTimeString } from '@/scripts/format-time-string.js'; | ||||||
| import MkInput from '@/components/MkInput.vue'; | import MkInput from '@/components/MkInput.vue'; | ||||||
| import * as os from '@/os.js'; | import * as os from '@/os.js'; | ||||||
| import MkDisableSection from '@/components/MkDisableSection.vue'; | import MkDisableSection from '@/components/MkDisableSection.vue'; | ||||||
| import { prefer } from '@/preferences.js'; |  | ||||||
| import MkPreferenceContainer from '@/components/MkPreferenceContainer.vue'; |  | ||||||
| 
 | 
 | ||||||
| const $i = signinRequired(); | const $i = signinRequired(); | ||||||
| 
 | 
 | ||||||
|  | @ -245,10 +204,6 @@ const publicReactions = ref($i.publicReactions); | ||||||
| const followingVisibility = ref($i.followingVisibility); | const followingVisibility = ref($i.followingVisibility); | ||||||
| const followersVisibility = ref($i.followersVisibility); | const followersVisibility = ref($i.followersVisibility); | ||||||
| 
 | 
 | ||||||
| const defaultNoteVisibility = prefer.model('defaultNoteVisibility'); |  | ||||||
| const defaultNoteLocalOnly = prefer.model('defaultNoteLocalOnly'); |  | ||||||
| const rememberNoteVisibility = prefer.model('rememberNoteVisibility'); |  | ||||||
| 
 |  | ||||||
| const makeNotesFollowersOnlyBefore_type = computed(() => { | const makeNotesFollowersOnlyBefore_type = computed(() => { | ||||||
| 	if (makeNotesFollowersOnlyBefore.value == null) { | 	if (makeNotesFollowersOnlyBefore.value == null) { | ||||||
| 		return null; | 		return null; | ||||||
|  |  | ||||||
|  | @ -261,16 +261,6 @@ export const searchIndexes: SearchIndexItem[] = [ | ||||||
| 				label: i18n.ts.lockdown, | 				label: i18n.ts.lockdown, | ||||||
| 				keywords: ['lockdown'], | 				keywords: ['lockdown'], | ||||||
| 			}, | 			}, | ||||||
| 			{ |  | ||||||
| 				id: '37QLEyrtk', |  | ||||||
| 				label: i18n.ts.rememberNoteVisibility, |  | ||||||
| 				keywords: ['remember', 'keep', 'note', 'visibility'], |  | ||||||
| 			}, |  | ||||||
| 			{ |  | ||||||
| 				id: '1u5HZuujV', |  | ||||||
| 				label: i18n.ts.defaultNoteVisibility, |  | ||||||
| 				keywords: ['default', 'note', 'visibility'], |  | ||||||
| 			}, |  | ||||||
| 		], | 		], | ||||||
| 		label: i18n.ts.privacy, | 		label: i18n.ts.privacy, | ||||||
| 		keywords: ['privacy'], | 		keywords: ['privacy'], | ||||||
|  | @ -311,35 +301,45 @@ export const searchIndexes: SearchIndexItem[] = [ | ||||||
| 				keywords: ['mfm', 'enable', 'show', 'advanced', 'picker', 'form', 'function', 'fn'], | 				keywords: ['mfm', 'enable', 'show', 'advanced', 'picker', 'form', 'function', 'fn'], | ||||||
| 			}, | 			}, | ||||||
| 			{ | 			{ | ||||||
| 				id: 'puIqj1a8b', | 				id: '1yhown1Xc', | ||||||
|  | 				label: i18n.ts.rememberNoteVisibility, | ||||||
|  | 				keywords: ['remember', 'keep', 'note', 'visibility'], | ||||||
|  | 			}, | ||||||
|  | 			{ | ||||||
|  | 				id: 'wUeAI5QBV', | ||||||
|  | 				label: i18n.ts.defaultNoteVisibility, | ||||||
|  | 				keywords: ['default', 'note', 'visibility'], | ||||||
|  | 			}, | ||||||
|  | 			{ | ||||||
|  | 				id: '6kMj4HVOg', | ||||||
| 				children: [ | 				children: [ | ||||||
| 					{ | 					{ | ||||||
| 						id: '1x3JNXj8N', | 						id: 'DQIcvf64G', | ||||||
| 						label: i18n.ts.collapseRenotes, | 						label: i18n.ts.collapseRenotes, | ||||||
| 						keywords: ['renote', i18n.ts.collapseRenotesDescription], | 						keywords: ['renote', i18n.ts.collapseRenotesDescription], | ||||||
| 					}, | 					}, | ||||||
| 					{ | 					{ | ||||||
| 						id: 'c98gbF9c6', | 						id: 'igFN7RIUa', | ||||||
| 						label: i18n.ts.showNoteActionsOnlyHover, | 						label: i18n.ts.showNoteActionsOnlyHover, | ||||||
| 						keywords: ['hover', 'show', 'footer', 'action'], | 						keywords: ['hover', 'show', 'footer', 'action'], | ||||||
| 					}, | 					}, | ||||||
| 					{ | 					{ | ||||||
| 						id: '4LxdiOMNh', | 						id: '9uxocbLO0', | ||||||
| 						label: i18n.ts.showClipButtonInNoteFooter, | 						label: i18n.ts.showClipButtonInNoteFooter, | ||||||
| 						keywords: ['footer', 'action', 'clip', 'show'], | 						keywords: ['footer', 'action', 'clip', 'show'], | ||||||
| 					}, | 					}, | ||||||
| 					{ | 					{ | ||||||
| 						id: '9gTCaLkIf', | 						id: 'eaT1O1Fao', | ||||||
| 						label: i18n.ts.enableAdvancedMfm, | 						label: i18n.ts.enableAdvancedMfm, | ||||||
| 						keywords: ['mfm', 'enable', 'show', 'advanced'], | 						keywords: ['mfm', 'enable', 'show', 'advanced'], | ||||||
| 					}, | 					}, | ||||||
| 					{ | 					{ | ||||||
| 						id: '6kMj4HVOg', | 						id: 'omxZk3eET', | ||||||
| 						label: i18n.ts.showReactionsCount, | 						label: i18n.ts.showReactionsCount, | ||||||
| 						keywords: ['reaction', 'count', 'show'], | 						keywords: ['reaction', 'count', 'show'], | ||||||
| 					}, | 					}, | ||||||
| 					{ | 					{ | ||||||
| 						id: 'dPersnkzh', | 						id: 'epvi2Nv2G', | ||||||
| 						label: i18n.ts.loadRawImages, | 						label: i18n.ts.loadRawImages, | ||||||
| 						keywords: ['image', 'photo', 'picture', 'media', 'thumbnail', 'quality', 'raw', 'attachment'], | 						keywords: ['image', 'photo', 'picture', 'media', 'thumbnail', 'quality', 'raw', 'attachment'], | ||||||
| 					}, | 					}, | ||||||
|  | @ -348,10 +348,10 @@ export const searchIndexes: SearchIndexItem[] = [ | ||||||
| 				keywords: ['note'], | 				keywords: ['note'], | ||||||
| 			}, | 			}, | ||||||
| 			{ | 			{ | ||||||
| 				id: '5XhS6ukl8', | 				id: 'jb3HUeyrx', | ||||||
| 				children: [ | 				children: [ | ||||||
| 					{ | 					{ | ||||||
| 						id: '3GcWIaZf8', | 						id: 'ykifk3NHS', | ||||||
| 						label: i18n.ts.useGroupedNotifications, | 						label: i18n.ts.useGroupedNotifications, | ||||||
| 						keywords: ['group'], | 						keywords: ['group'], | ||||||
| 					}, | 					}, | ||||||
|  | @ -360,60 +360,60 @@ export const searchIndexes: SearchIndexItem[] = [ | ||||||
| 				keywords: ['notification'], | 				keywords: ['notification'], | ||||||
| 			}, | 			}, | ||||||
| 			{ | 			{ | ||||||
| 				id: 'dSGDnj2PA', | 				id: 'abEAdSpYY', | ||||||
| 				children: [ | 				children: [ | ||||||
| 					{ | 					{ | ||||||
| 						id: '1LHOhDKGW', | 						id: 'lBbtAg0Hm', | ||||||
| 						label: i18n.ts.openImageInNewTab, | 						label: i18n.ts.openImageInNewTab, | ||||||
| 						keywords: ['image', 'photo', 'picture', 'media', 'thumbnail', 'new', 'tab'], | 						keywords: ['image', 'photo', 'picture', 'media', 'thumbnail', 'new', 'tab'], | ||||||
| 					}, | 					}, | ||||||
| 					{ | 					{ | ||||||
| 						id: 'DSzwvTp7i', | 						id: 'E9whefUtX', | ||||||
| 						label: i18n.ts.useReactionPickerForContextMenu, | 						label: i18n.ts.useReactionPickerForContextMenu, | ||||||
| 						keywords: ['reaction', 'picker', 'contextmenu', 'open'], | 						keywords: ['reaction', 'picker', 'contextmenu', 'open'], | ||||||
| 					}, | 					}, | ||||||
| 					{ | 					{ | ||||||
| 						id: '5QTUzrpT3', | 						id: 'iQaBbJBva', | ||||||
| 						label: i18n.ts.enableInfiniteScroll, | 						label: i18n.ts.enableInfiniteScroll, | ||||||
| 						keywords: ['load', 'auto', 'more'], | 						keywords: ['load', 'auto', 'more'], | ||||||
| 					}, | 					}, | ||||||
| 					{ | 					{ | ||||||
| 						id: '7Uf8ksn3q', | 						id: 'hgEVGgJa1', | ||||||
| 						label: i18n.ts.disableStreamingTimeline, | 						label: i18n.ts.disableStreamingTimeline, | ||||||
| 						keywords: ['disable', 'streaming', 'timeline'], | 						keywords: ['disable', 'streaming', 'timeline'], | ||||||
| 					}, | 					}, | ||||||
| 					{ | 					{ | ||||||
| 						id: 'whKYKvaQB', | 						id: 'yxehrHZ6x', | ||||||
| 						label: i18n.ts.alwaysConfirmFollow, | 						label: i18n.ts.alwaysConfirmFollow, | ||||||
| 						keywords: ['follow', 'confirm', 'always'], | 						keywords: ['follow', 'confirm', 'always'], | ||||||
| 					}, | 					}, | ||||||
| 					{ | 					{ | ||||||
| 						id: 'nf4kcPeYw', | 						id: 'DdoFLaSG8', | ||||||
| 						label: i18n.ts.confirmWhenRevealingSensitiveMedia, | 						label: i18n.ts.confirmWhenRevealingSensitiveMedia, | ||||||
| 						keywords: ['sensitive', 'nsfw', 'media', 'image', 'photo', 'picture', 'attachment', 'confirm'], | 						keywords: ['sensitive', 'nsfw', 'media', 'image', 'photo', 'picture', 'attachment', 'confirm'], | ||||||
| 					}, | 					}, | ||||||
| 					{ | 					{ | ||||||
| 						id: 'rRisK1YYQ', | 						id: 'uIMCIK7kG', | ||||||
| 						label: i18n.ts.confirmOnReact, | 						label: i18n.ts.confirmOnReact, | ||||||
| 						keywords: ['reaction', 'confirm'], | 						keywords: ['reaction', 'confirm'], | ||||||
| 					}, | 					}, | ||||||
| 					{ | 					{ | ||||||
| 						id: '6AH0lnjf1', | 						id: 'zvM13vl26', | ||||||
| 						label: i18n.ts.keepCw, | 						label: i18n.ts.keepCw, | ||||||
| 						keywords: ['remember', 'keep', 'note', 'cw'], | 						keywords: ['remember', 'keep', 'note', 'cw'], | ||||||
| 					}, | 					}, | ||||||
| 					{ | 					{ | ||||||
| 						id: 'uHcTVSGDv', | 						id: 'm75VEWI3S', | ||||||
| 						label: i18n.ts.whenServerDisconnected, | 						label: i18n.ts.whenServerDisconnected, | ||||||
| 						keywords: ['server', 'disconnect', 'reconnect', 'reload', 'streaming'], | 						keywords: ['server', 'disconnect', 'reconnect', 'reload', 'streaming'], | ||||||
| 					}, | 					}, | ||||||
| 					{ | 					{ | ||||||
| 						id: 'fzPca1Gk9', | 						id: 'bLO9vCyKW', | ||||||
| 						label: i18n.ts.numberOfPageCache, | 						label: i18n.ts.numberOfPageCache, | ||||||
| 						keywords: ['cache', 'page'], | 						keywords: ['cache', 'page'], | ||||||
| 					}, | 					}, | ||||||
| 					{ | 					{ | ||||||
| 						id: 'mNU5IBln7', | 						id: 'iQ7Er89l5', | ||||||
| 						label: i18n.ts.dataSaver, | 						label: i18n.ts.dataSaver, | ||||||
| 						keywords: ['datasaver'], | 						keywords: ['datasaver'], | ||||||
| 					}, | 					}, | ||||||
|  | @ -422,20 +422,20 @@ export const searchIndexes: SearchIndexItem[] = [ | ||||||
| 				keywords: ['behavior'], | 				keywords: ['behavior'], | ||||||
| 			}, | 			}, | ||||||
| 			{ | 			{ | ||||||
| 				id: 'C3psHYdZn', | 				id: 'C2WYcVM1d', | ||||||
| 				children: [ | 				children: [ | ||||||
| 					{ | 					{ | ||||||
| 						id: 'iCEiAg4Wg', | 						id: 'Cu7ErCM7C', | ||||||
| 						label: i18n.ts.forceShowAds, | 						label: i18n.ts.forceShowAds, | ||||||
| 						keywords: ['ad', 'show'], | 						keywords: ['ad', 'show'], | ||||||
| 					}, | 					}, | ||||||
| 					{ | 					{ | ||||||
| 						id: 'qj9eChQ5B', | 						id: 'BBxwy4F6E', | ||||||
| 						label: i18n.ts.hemisphere, | 						label: i18n.ts.hemisphere, | ||||||
| 						keywords: [], | 						keywords: [], | ||||||
| 					}, | 					}, | ||||||
| 					{ | 					{ | ||||||
| 						id: 'uItIge5hw', | 						id: '9YdUwDC8d', | ||||||
| 						label: i18n.ts.additionalEmojiDictionary, | 						label: i18n.ts.additionalEmojiDictionary, | ||||||
| 						keywords: ['emoji', 'dictionary', 'additional', 'extra'], | 						keywords: ['emoji', 'dictionary', 'additional', 'extra'], | ||||||
| 					}, | 					}, | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		
		Reference in a new issue