mirror of
https://github.com/misskey-dev/misskey.git
synced 2026-05-03 00:56:00 +02:00
* 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>
309 lines
5.8 KiB
TypeScript
309 lines
5.8 KiB
TypeScript
/*
|
||
* SPDX-FileCopyrightText: syuilo and misskey-project
|
||
* SPDX-License-Identifier: AGPL-3.0-only
|
||
*/
|
||
|
||
import * as Misskey from 'misskey-js';
|
||
import { hemisphere } from '@@/js/intl-const.js';
|
||
import type { Theme } from '@/scripts/theme.js';
|
||
import type { SoundType } from '@/scripts/sound.js';
|
||
import type { Plugin } from '@/plugin.js';
|
||
import { DEFAULT_DEVICE_KIND } from '@/scripts/device-kind.js';
|
||
|
||
/** サウンド設定 */
|
||
export type SoundStore = {
|
||
type: Exclude<SoundType, '_driveFile_'>;
|
||
volume: number;
|
||
} | {
|
||
type: '_driveFile_';
|
||
|
||
/** ドライブのファイルID */
|
||
fileId: string;
|
||
|
||
/** ファイルURL(こちらが優先される) */
|
||
fileUrl: string;
|
||
|
||
volume: number;
|
||
};
|
||
|
||
export const PREF_DEF = {
|
||
pinnedUserLists: {
|
||
accountDependent: true,
|
||
default: [] as Misskey.entities.UserList[],
|
||
},
|
||
uploadFolder: {
|
||
accountDependent: true,
|
||
default: null as string | null,
|
||
},
|
||
|
||
themes: {
|
||
default: [] as Theme[],
|
||
},
|
||
lightTheme: {
|
||
default: null as Theme | null,
|
||
},
|
||
darkTheme: {
|
||
default: null as Theme | null,
|
||
},
|
||
syncDeviceDarkMode: {
|
||
default: true,
|
||
},
|
||
defaultNoteVisibility: {
|
||
default: 'public' as (typeof Misskey.noteVisibilities)[number],
|
||
},
|
||
defaultNoteLocalOnly: {
|
||
default: false,
|
||
},
|
||
keepCw: {
|
||
default: true,
|
||
},
|
||
keepOriginalUploading: {
|
||
default: false,
|
||
},
|
||
rememberNoteVisibility: {
|
||
default: false,
|
||
},
|
||
reportError: {
|
||
default: false,
|
||
},
|
||
collapseRenotes: {
|
||
default: true,
|
||
},
|
||
menu: {
|
||
default: [
|
||
'notifications',
|
||
'clips',
|
||
'drive',
|
||
'followRequests',
|
||
'-',
|
||
'explore',
|
||
'announcements',
|
||
'search',
|
||
'-',
|
||
'ui',
|
||
],
|
||
},
|
||
statusbars: {
|
||
default: [] as {
|
||
name: string;
|
||
id: string;
|
||
type: string;
|
||
size: 'verySmall' | 'small' | 'medium' | 'large' | 'veryLarge';
|
||
black: boolean;
|
||
props: Record<string, any>;
|
||
}[],
|
||
},
|
||
serverDisconnectedBehavior: {
|
||
default: 'quiet' as 'quiet' | 'reload' | 'dialog',
|
||
},
|
||
nsfw: {
|
||
default: 'respect' as 'respect' | 'force' | 'ignore',
|
||
},
|
||
highlightSensitiveMedia: {
|
||
default: false,
|
||
},
|
||
animation: {
|
||
default: !window.matchMedia('(prefers-reduced-motion)').matches,
|
||
},
|
||
animatedMfm: {
|
||
default: !window.matchMedia('(prefers-reduced-motion)').matches,
|
||
},
|
||
advancedMfm: {
|
||
default: true,
|
||
},
|
||
showReactionsCount: {
|
||
default: false,
|
||
},
|
||
enableQuickAddMfmFunction: {
|
||
default: false,
|
||
},
|
||
loadRawImages: {
|
||
default: false,
|
||
},
|
||
imageNewTab: {
|
||
default: false,
|
||
},
|
||
disableShowingAnimatedImages: {
|
||
default: window.matchMedia('(prefers-reduced-motion)').matches,
|
||
},
|
||
emojiStyle: {
|
||
default: 'twemoji', // twemoji / fluentEmoji / native
|
||
},
|
||
menuStyle: {
|
||
default: 'auto' as 'auto' | 'popup' | 'drawer',
|
||
},
|
||
useBlurEffectForModal: {
|
||
default: DEFAULT_DEVICE_KIND === 'desktop',
|
||
},
|
||
useBlurEffect: {
|
||
default: DEFAULT_DEVICE_KIND === 'desktop',
|
||
},
|
||
showFixedPostForm: {
|
||
default: false,
|
||
},
|
||
showFixedPostFormInChannel: {
|
||
default: false,
|
||
},
|
||
enableInfiniteScroll: {
|
||
default: true,
|
||
},
|
||
useReactionPickerForContextMenu: {
|
||
default: false,
|
||
},
|
||
showGapBetweenNotesInTimeline: {
|
||
default: false,
|
||
},
|
||
instanceTicker: {
|
||
default: 'remote' as 'none' | 'remote' | 'always',
|
||
},
|
||
emojiPickerScale: {
|
||
default: 1,
|
||
},
|
||
emojiPickerWidth: {
|
||
default: 1,
|
||
},
|
||
emojiPickerHeight: {
|
||
default: 2,
|
||
},
|
||
emojiPickerStyle: {
|
||
default: 'auto' as 'auto' | 'popup' | 'drawer',
|
||
},
|
||
squareAvatars: {
|
||
default: false,
|
||
},
|
||
showAvatarDecorations: {
|
||
default: true,
|
||
},
|
||
numberOfPageCache: {
|
||
default: 3,
|
||
},
|
||
showNoteActionsOnlyHover: {
|
||
default: false,
|
||
},
|
||
showClipButtonInNoteFooter: {
|
||
default: false,
|
||
},
|
||
reactionsDisplaySize: {
|
||
default: 'medium' as 'small' | 'medium' | 'large',
|
||
},
|
||
limitWidthOfReaction: {
|
||
default: true,
|
||
},
|
||
forceShowAds: {
|
||
default: false,
|
||
},
|
||
aiChanMode: {
|
||
default: false,
|
||
},
|
||
devMode: {
|
||
default: false,
|
||
},
|
||
mediaListWithOneImageAppearance: {
|
||
default: 'expand' as 'expand' | '16_9' | '1_1' | '2_3',
|
||
},
|
||
notificationPosition: {
|
||
default: 'rightBottom' as 'leftTop' | 'leftBottom' | 'rightTop' | 'rightBottom',
|
||
},
|
||
notificationStackAxis: {
|
||
default: 'horizontal' as 'vertical' | 'horizontal',
|
||
},
|
||
enableCondensedLine: {
|
||
default: true,
|
||
},
|
||
keepScreenOn: {
|
||
default: false,
|
||
},
|
||
disableStreamingTimeline: {
|
||
default: false,
|
||
},
|
||
useGroupedNotifications: {
|
||
default: true,
|
||
},
|
||
dataSaver: {
|
||
default: {
|
||
media: false,
|
||
avatar: false,
|
||
urlPreview: false,
|
||
code: false,
|
||
} as Record<string, boolean>,
|
||
},
|
||
hemisphere: {
|
||
default: hemisphere as 'N' | 'S',
|
||
},
|
||
enableSeasonalScreenEffect: {
|
||
default: false,
|
||
},
|
||
enableHorizontalSwipe: {
|
||
default: true,
|
||
},
|
||
useNativeUiForVideoAudioPlayer: {
|
||
default: false,
|
||
},
|
||
keepOriginalFilename: {
|
||
default: true,
|
||
},
|
||
alwaysConfirmFollow: {
|
||
default: true,
|
||
},
|
||
confirmWhenRevealingSensitiveMedia: {
|
||
default: false,
|
||
},
|
||
contextMenu: {
|
||
default: 'app' as 'app' | 'appWithShift' | 'native',
|
||
},
|
||
skipNoteRender: {
|
||
default: true,
|
||
},
|
||
showSoftWordMutedWord: {
|
||
default: false,
|
||
},
|
||
confirmOnReact: {
|
||
default: false,
|
||
},
|
||
plugins: {
|
||
default: [] as Plugin[],
|
||
},
|
||
'sound.masterVolume': {
|
||
default: 0.3,
|
||
},
|
||
'sound.notUseSound': {
|
||
default: false,
|
||
},
|
||
'sound.useSoundOnlyWhenActive': {
|
||
default: false,
|
||
},
|
||
'sound.on.note': {
|
||
default: { type: 'syuilo/n-aec', volume: 1 } as SoundStore,
|
||
},
|
||
'sound.on.noteMy': {
|
||
default: { type: 'syuilo/n-cea-4va', volume: 1 } as SoundStore,
|
||
},
|
||
'sound.on.notification': {
|
||
default: { type: 'syuilo/n-ea', volume: 1 } as SoundStore,
|
||
},
|
||
'sound.on.reaction': {
|
||
default: { type: 'syuilo/bubble2', volume: 1 } as SoundStore,
|
||
},
|
||
'deck.alwaysShowMainColumn': {
|
||
default: true,
|
||
},
|
||
'deck.navWindow': {
|
||
default: true,
|
||
},
|
||
'deck.useSimpleUiForNonRootPages': {
|
||
default: true,
|
||
},
|
||
'deck.columnAlign': {
|
||
default: 'left' as 'left' | 'right' | 'center',
|
||
},
|
||
'game.dropAndFusion': {
|
||
default: {
|
||
bgmVolume: 0.25,
|
||
sfxVolume: 1,
|
||
},
|
||
},
|
||
} satisfies Record<string, {
|
||
default: any;
|
||
accountDependent?: boolean;
|
||
}>;
|