summaryrefslogtreecommitdiff
path: root/packages/frontend/src/scripts
diff options
context:
space:
mode:
authorsyuilo <Syuilotan@yahoo.co.jp>2023-04-13 12:18:07 +0900
committerGitHub <noreply@github.com>2023-04-13 12:18:07 +0900
commitc5d2dba28d1e99f9c152840ca7f47e8f51c7423b (patch)
tree8d4b388039b3f936e7dfb8914efa827bf026b110 /packages/frontend/src/scripts
parentMerge pull request #10606 from misskey-dev/EbiseLutica-patch-1 (diff)
parent[ci skip] improve readability (diff)
downloadmisskey-c5d2dba28d1e99f9c152840ca7f47e8f51c7423b.tar.gz
misskey-c5d2dba28d1e99f9c152840ca7f47e8f51c7423b.tar.bz2
misskey-c5d2dba28d1e99f9c152840ca7f47e8f51c7423b.zip
Merge pull request #10608 from misskey-dev/develop
Release: 13.11.3
Diffstat (limited to 'packages/frontend/src/scripts')
-rw-r--r--packages/frontend/src/scripts/media-proxy.ts4
-rw-r--r--packages/frontend/src/scripts/sound.ts61
2 files changed, 59 insertions, 6 deletions
diff --git a/packages/frontend/src/scripts/media-proxy.ts b/packages/frontend/src/scripts/media-proxy.ts
index 91ac14c06d..3a3dbffb47 100644
--- a/packages/frontend/src/scripts/media-proxy.ts
+++ b/packages/frontend/src/scripts/media-proxy.ts
@@ -2,7 +2,7 @@ import { query } from '@/scripts/url';
import { url } from '@/config';
import { instance } from '@/instance';
-export function getProxiedImageUrl(imageUrl: string, type?: 'preview', mustOrigin: boolean = false): string {
+export function getProxiedImageUrl(imageUrl: string, type?: 'preview' | 'emoji' | 'avatar', mustOrigin: boolean = false, noFallback: boolean = false): string {
const localProxy = `${url}/proxy`;
if (imageUrl.startsWith(instance.mediaProxy + '/') || imageUrl.startsWith('/proxy/') || imageUrl.startsWith(localProxy + '/')) {
@@ -15,7 +15,7 @@ export function getProxiedImageUrl(imageUrl: string, type?: 'preview', mustOrigi
: 'image.webp'
}?${query({
url: imageUrl,
- fallback: '1',
+ ...(!noFallback ? { 'fallback': '1' } : {}),
...(type ? { [type]: '1' } : {}),
...(mustOrigin ? { origin: '1' } : {}),
})}`;
diff --git a/packages/frontend/src/scripts/sound.ts b/packages/frontend/src/scripts/sound.ts
index 35fd007e64..7a5dd4dbfa 100644
--- a/packages/frontend/src/scripts/sound.ts
+++ b/packages/frontend/src/scripts/sound.ts
@@ -1,4 +1,56 @@
-import { ColdDeviceStorage } from '@/store';
+import { markRaw } from 'vue';
+import { Storage } from '@/pizzax';
+
+export const soundConfigStore = markRaw(new Storage('sound', {
+ mediaVolume: {
+ where: 'device',
+ default: 0.5
+ },
+ sound_masterVolume: {
+ where: 'device',
+ default: 0.3
+ },
+ sound_note: {
+ where: 'account',
+ default: { type: 'syuilo/n-aec', volume: 1 }
+ },
+ sound_noteMy: {
+ where: 'account',
+ default: { type: 'syuilo/n-cea-4va', volume: 1 }
+ },
+ sound_notification: {
+ where: 'account',
+ default: { type: 'syuilo/n-ea', volume: 1 }
+ },
+ sound_chat: {
+ where: 'account',
+ default: { type: 'syuilo/pope1', volume: 1 }
+ },
+ sound_chatBg: {
+ where: 'account',
+ default: { type: 'syuilo/waon', volume: 1 }
+ },
+ sound_antenna: {
+ where: 'account',
+ default: { type: 'syuilo/triple', volume: 1 }
+ },
+ sound_channel: {
+ where: 'account',
+ default: { type: 'syuilo/square-pico', volume: 1 }
+ },
+}));
+
+await soundConfigStore.ready;
+
+//#region サウンドのColdDeviceStorage => indexedDBのマイグレーション
+for (const target of Object.keys(soundConfigStore.state) as Array<keyof typeof soundConfigStore.state>) {
+ const value = localStorage.getItem(`miux:${target}`);
+ if (value) {
+ soundConfigStore.set(target, JSON.parse(value) as typeof soundConfigStore.def[typeof target]['default']);
+ localStorage.removeItem(`miux:${target}`);
+ }
+}
+//#endregion
const cache = new Map<string, HTMLAudioElement>();
@@ -67,19 +119,20 @@ export function getAudio(file: string, useCache = true): HTMLAudioElement {
}
export function setVolume(audio: HTMLAudioElement, volume: number): HTMLAudioElement {
- const masterVolume = ColdDeviceStorage.get('sound_masterVolume');
+ const masterVolume = soundConfigStore.state.sound_masterVolume;
audio.volume = masterVolume - ((1 - volume) * masterVolume);
return audio;
}
export function play(type: 'noteMy' | 'note' | 'antenna' | 'channel' | 'notification') {
- const sound = ColdDeviceStorage.get(`sound_${type}`);
+ const sound = soundConfigStore.state[`sound_${type}`];
+ if (_DEV_) console.log('play', type, sound);
if (sound.type == null) return;
playFile(sound.type, sound.volume);
}
export function playFile(file: string, volume: number) {
- const masterVolume = ColdDeviceStorage.get('sound_masterVolume');
+ const masterVolume = soundConfigStore.state.sound_masterVolume;
if (masterVolume === 0) return;
const audio = setVolume(getAudio(file), volume);