mirror of
https://github.com/glitch-soc/mastodon.git
synced 2025-12-14 00:08:46 +00:00
89 lines
2.5 KiB
TypeScript
89 lines
2.5 KiB
TypeScript
import { initialState } from '@/flavours/glitch/initial_state';
|
|
|
|
import { toSupportedLocale } from './locale';
|
|
import type { LocaleOrCustom } from './types';
|
|
import { emojiLogger } from './utils';
|
|
// eslint-disable-next-line import/default -- Importing via worker loader.
|
|
import EmojiWorker from './worker?worker&inline';
|
|
|
|
const userLocale = toSupportedLocale(initialState?.meta.locale ?? 'en');
|
|
|
|
let worker: Worker | null = null;
|
|
|
|
const log = emojiLogger('index');
|
|
|
|
const WORKER_TIMEOUT = 1_000; // 1 second
|
|
|
|
export function initializeEmoji() {
|
|
log('initializing emojis');
|
|
if (!worker && 'Worker' in window) {
|
|
try {
|
|
worker = new EmojiWorker();
|
|
} catch (err) {
|
|
console.warn('Error creating web worker:', err);
|
|
}
|
|
}
|
|
|
|
if (worker) {
|
|
const timeoutId = setTimeout(() => {
|
|
log('worker is not ready after timeout');
|
|
worker = null;
|
|
void fallbackLoad();
|
|
}, WORKER_TIMEOUT);
|
|
worker.addEventListener('message', (event: MessageEvent<string>) => {
|
|
const { data: message } = event;
|
|
if (message === 'ready') {
|
|
log('worker ready, loading data');
|
|
clearTimeout(timeoutId);
|
|
messageWorker('custom');
|
|
void loadEmojiLocale(userLocale);
|
|
// Load English locale as well, because people are still used to
|
|
// using it from before we supported other locales.
|
|
if (userLocale !== 'en') {
|
|
void loadEmojiLocale('en');
|
|
}
|
|
} else {
|
|
log('got worker message: %s', message);
|
|
}
|
|
});
|
|
} else {
|
|
void fallbackLoad();
|
|
}
|
|
}
|
|
|
|
async function fallbackLoad() {
|
|
log('falling back to main thread for loading');
|
|
const { importCustomEmojiData } = await import('./loader');
|
|
const emojis = await importCustomEmojiData();
|
|
if (emojis) {
|
|
log('loaded %d custom emojis', emojis.length);
|
|
}
|
|
await loadEmojiLocale(userLocale);
|
|
if (userLocale !== 'en') {
|
|
await loadEmojiLocale('en');
|
|
}
|
|
}
|
|
|
|
async function loadEmojiLocale(localeString: string) {
|
|
const locale = toSupportedLocale(localeString);
|
|
const { importEmojiData, localeToPath } = await import('./loader');
|
|
|
|
if (worker) {
|
|
const path = await localeToPath(locale);
|
|
log('asking worker to load locale %s from %s', locale, path);
|
|
messageWorker(locale, path);
|
|
} else {
|
|
const emojis = await importEmojiData(locale);
|
|
if (emojis) {
|
|
log('loaded %d emojis to locale %s', emojis.length, locale);
|
|
}
|
|
}
|
|
}
|
|
|
|
function messageWorker(locale: LocaleOrCustom, path?: string) {
|
|
if (!worker) {
|
|
return;
|
|
}
|
|
worker.postMessage({ locale, path });
|
|
}
|