Refine preferences (#15597)
* wip
* wip
* wip
* test
* wip rollup pluginでsearchIndexの情報生成
* wip
* SPDX
* wip: markerIdを自動付与
* rollupでビルド時・devモード時に毎回uuidを生成するように
* 開発サーバーでだけ必要な挙動は開発サーバーのみで
* 条件が逆
* wip: childrenの生成
* update comment
* update comment
* rename auto generated file
* hashをパスと行数から決定
* Update privacy.vue
* Update privacy.vue
* wip
* Update general.vue
* Update general.vue
* wip
* wip
* Update SearchMarker.vue
* wip
* Update profile.vue
* Update mute-block.vue
* Update mute-block.vue
* Update general.vue
* Update general.vue
* childrenがduplicate key errorを吐く問題をいったん解決
* マーカーの形を成形
* loggerを置きかえ
* とりあえず省略記法に対応
* Refactor and Format codes
* wip
* Update settings-search-index.ts
* wip
* wip
* とりあえず不確定要因の仮置きidを削除
* hashの生成を正規化(絶対パスになっていたのを緩和)
* pathの入力を省略可能に
* adminでもパス生成できるように
* Update settings-search-index.ts
* Update privacy.vue
* wip
* build searchIndex
* wip
* build
* Update general.vue
* build
* Update sounds.vue
* build
* build
* Update sounds.vue
* 🎨
* 🎨
* Update privacy.vue
* Update privacy.vue
* Update security.vue
* create-search-indexを多少改善
* build
* Update 2fa.vue
* wip
* 必ずtransformCodeCacheを利用するように, キャッシュの明確な受け渡しを定義
* キャッシュはdevServerでなくても更新
* Revert "wip"
This reverts commit 41bffd3a13.
* inlining
* wip
* Update theme.vue
* 🎨
* wip normalize
* Update theme.vue
* キャッシュのパス変換
* build
* wip
* wip
* Update SearchMarker.vue
* i18n.ts['key'] の形式が取り出せない問題のFix
* build
* 仮でpath入れ
* 必ず絶対パスが使われるように
* wip
* 🎨
* storybookビルド時はcreateSearchIndexをしない
* inliningの構造化
* format code
* Update index.vue
* wip
* wip
* 🎨
* wip
* wip
* wip
* wip
* wip
* wip
* wip
* wip
* clean up
* wip
* wip
* wip
* Update rollup-plugin-unwind-css-module-class-name.test.ts
* Update navbar.vue
* clean up
* wip
* wip
* wip
* wip
* wip
* Update preferences-backups.vue
* Update common.ts
* Update preferences.ts
* wip
* wip
* wip
* wip
* Update MkPreferenceContainer.vue
* Update MkPreferenceContainer.vue
* Update MkPreferenceContainer.vue
* enhance: 検索で上下矢印を使用することで検索結果を移動できるように
* Update main-boot.ts
* refactor
* wip
* Update sounds.vue
* fix(frontend): PageWindowでSearchMarkerが動作するように
* enhance(frontend): SearchMarkerの点滅を一定時間で止める
* wip
* lint fix
* fix: 子要素監視が抜けていたのを修正
* アニメーションの回数はCSSで制御するように
* refactor
* enhance(frontend): 検索インデックス作成時のログを削減
* revert
* fix
* fix
* Update preferences.ts
* Update preferences.ts
* wip
* Update preferences.ts
* wip
* 🎨
* wip
* Update MkPreferenceContainer.vue
* wip
* Update preferences.ts
* wip
* Update preferences.ts
* Update preferences.ts
* wip
* wip
* Update preferences.ts
* wip
* wip
* Update preferences.ts
* Update CHANGELOG.md
* Update preferences.ts
* Update deck-store.ts
* deckStoreをdefaultStoreに統合
* wip
* defaultStore -> store
* Update profile.ts
* wip
* refactor
* wip: plugin
* plugin
* plugin
* plugin
* Update plugin.ts
* wip
* Update plugin.vue
* Update preferences.ts
* Update main-boot.ts
* wip
* fix test
* Update plugin.vue
* Update plugin.vue
* Update utility.ts
* wip
* wip
* Update utility.ts
* wip
* wip
* clean up
* Update utility.ts
---------
Co-authored-by: tai-cha <dev@taichan.site>
Co-authored-by: taichan <40626578+tai-cha@users.noreply.github.com>
Co-authored-by: kakkokari-gtyih <67428053+kakkokari-gtyih@users.noreply.github.com>
			
			
This commit is contained in:
		@@ -4,7 +4,7 @@ SPDX-License-Identifier: AGPL-3.0-only
 | 
			
		||||
-->
 | 
			
		||||
 | 
			
		||||
<template>
 | 
			
		||||
<div :class="[hide ? $style.hidden : $style.visible, (image.isSensitive && defaultStore.state.highlightSensitiveMedia) && $style.sensitive]" @click="onclick">
 | 
			
		||||
<div :class="[hide ? $style.hidden : $style.visible, (image.isSensitive && prefer.s.highlightSensitiveMedia) && $style.sensitive]" @click="onclick">
 | 
			
		||||
	<component
 | 
			
		||||
		:is="disableImageLink ? 'div' : 'a'"
 | 
			
		||||
		v-bind="disableImageLink ? {
 | 
			
		||||
@@ -19,7 +19,7 @@ SPDX-License-Identifier: AGPL-3.0-only
 | 
			
		||||
	>
 | 
			
		||||
		<ImgWithBlurhash
 | 
			
		||||
			:hash="image.blurhash"
 | 
			
		||||
			:src="(defaultStore.state.dataSaver.media && hide) ? null : url"
 | 
			
		||||
			:src="(prefer.s.dataSaver.media && hide) ? null : url"
 | 
			
		||||
			:forceBlurhash="hide"
 | 
			
		||||
			:cover="hide || cover"
 | 
			
		||||
			:alt="image.comment || image.name"
 | 
			
		||||
@@ -32,8 +32,8 @@ SPDX-License-Identifier: AGPL-3.0-only
 | 
			
		||||
	<template v-if="hide">
 | 
			
		||||
		<div :class="$style.hiddenText">
 | 
			
		||||
			<div :class="$style.hiddenTextWrapper">
 | 
			
		||||
				<b v-if="image.isSensitive" style="display: block;"><i class="ti ti-eye-exclamation"></i> {{ i18n.ts.sensitive }}{{ defaultStore.state.dataSaver.media ? ` (${i18n.ts.image}${image.size ? ' ' + bytes(image.size) : ''})` : '' }}</b>
 | 
			
		||||
				<b v-else style="display: block;"><i class="ti ti-photo"></i> {{ defaultStore.state.dataSaver.media && image.size ? bytes(image.size) : i18n.ts.image }}</b>
 | 
			
		||||
				<b v-if="image.isSensitive" style="display: block;"><i class="ti ti-eye-exclamation"></i> {{ i18n.ts.sensitive }}{{ prefer.s.dataSaver.media ? ` (${i18n.ts.image}${image.size ? ' ' + bytes(image.size) : ''})` : '' }}</b>
 | 
			
		||||
				<b v-else style="display: block;"><i class="ti ti-photo"></i> {{ prefer.s.dataSaver.media && image.size ? bytes(image.size) : i18n.ts.image }}</b>
 | 
			
		||||
				<span v-if="controls" style="display: block;">{{ i18n.ts.clickToShow }}</span>
 | 
			
		||||
			</div>
 | 
			
		||||
		</div>
 | 
			
		||||
@@ -58,10 +58,10 @@ import { copyToClipboard } from '@/scripts/copy-to-clipboard';
 | 
			
		||||
import { getStaticImageUrl } from '@/scripts/media-proxy.js';
 | 
			
		||||
import bytes from '@/filters/bytes.js';
 | 
			
		||||
import ImgWithBlurhash from '@/components/MkImgWithBlurhash.vue';
 | 
			
		||||
import { defaultStore } from '@/store.js';
 | 
			
		||||
import { i18n } from '@/i18n.js';
 | 
			
		||||
import * as os from '@/os.js';
 | 
			
		||||
import { $i, iAmModerator } from '@/account.js';
 | 
			
		||||
import { prefer } from '@/preferences.js';
 | 
			
		||||
 | 
			
		||||
const props = withDefaults(defineProps<{
 | 
			
		||||
	image: Misskey.entities.DriveFile;
 | 
			
		||||
@@ -77,9 +77,9 @@ const props = withDefaults(defineProps<{
 | 
			
		||||
 | 
			
		||||
const hide = ref(true);
 | 
			
		||||
 | 
			
		||||
const url = computed(() => (props.raw || defaultStore.state.loadRawImages)
 | 
			
		||||
const url = computed(() => (props.raw || prefer.s.loadRawImages)
 | 
			
		||||
	? props.image.url
 | 
			
		||||
	: defaultStore.state.disableShowingAnimatedImages
 | 
			
		||||
	: prefer.s.disableShowingAnimatedImages
 | 
			
		||||
		? getStaticImageUrl(props.image.url)
 | 
			
		||||
		: props.image.thumbnailUrl,
 | 
			
		||||
);
 | 
			
		||||
@@ -91,7 +91,7 @@ async function onclick(ev: MouseEvent) {
 | 
			
		||||
 | 
			
		||||
	if (hide.value) {
 | 
			
		||||
		ev.stopPropagation();
 | 
			
		||||
		if (props.image.isSensitive && defaultStore.state.confirmWhenRevealingSensitiveMedia) {
 | 
			
		||||
		if (props.image.isSensitive && prefer.s.confirmWhenRevealingSensitiveMedia) {
 | 
			
		||||
			const { canceled } = await os.confirm({
 | 
			
		||||
				type: 'question',
 | 
			
		||||
				text: i18n.ts.sensitiveMediaRevealConfirm,
 | 
			
		||||
@@ -105,7 +105,7 @@ async function onclick(ev: MouseEvent) {
 | 
			
		||||
 | 
			
		||||
// Plugin:register_note_view_interruptor を使って書き換えられる可能性があるためwatchする
 | 
			
		||||
watch(() => props.image, () => {
 | 
			
		||||
	hide.value = (defaultStore.state.nsfw === 'force' || defaultStore.state.dataSaver.media) ? true : (props.image.isSensitive && defaultStore.state.nsfw !== 'ignore');
 | 
			
		||||
	hide.value = (prefer.s.nsfw === 'force' || prefer.s.dataSaver.media) ? true : (props.image.isSensitive && prefer.s.nsfw !== 'ignore');
 | 
			
		||||
}, {
 | 
			
		||||
	deep: true,
 | 
			
		||||
	immediate: true,
 | 
			
		||||
@@ -166,7 +166,7 @@ function showMenu(ev: MouseEvent) {
 | 
			
		||||
		menuItems.push({ type: 'divider' }, ...details);
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	if (defaultStore.state.devMode) {
 | 
			
		||||
	if (prefer.s.devMode) {
 | 
			
		||||
		menuItems.push({ type: 'divider' }, {
 | 
			
		||||
			icon: 'ti ti-id',
 | 
			
		||||
			text: i18n.ts.copyFileId,
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user