phanpy/src/components/media-alt-modal.jsx

95 lines
2.7 KiB
React
Raw Normal View History

2024-08-13 10:26:23 +03:00
import { t, Trans } from '@lingui/macro';
2023-09-28 10:48:32 +03:00
import { Menu, MenuItem } from '@szhsin/react-menu';
import { useState } from 'preact/hooks';
import { useSnapshot } from 'valtio';
import getTranslateTargetLanguage from '../utils/get-translate-target-language';
import localeMatch from '../utils/locale-match';
2023-12-21 13:17:14 +03:00
import { speak, supportsTTS } from '../utils/speech';
import states from '../utils/states';
2023-09-28 10:48:32 +03:00
import Icon from './icon';
import Menu2 from './menu2';
2023-09-28 10:48:32 +03:00
import TranslationBlock from './translation-block';
export default function MediaAltModal({ alt, lang, onClose }) {
const snapStates = useSnapshot(states);
2023-09-28 10:48:32 +03:00
const [forceTranslate, setForceTranslate] = useState(false);
const targetLanguage = getTranslateTargetLanguage(true);
const contentTranslationHideLanguages =
snapStates.settings.contentTranslationHideLanguages || [];
const differentLanguage =
!!lang &&
lang !== targetLanguage &&
!localeMatch([lang], [targetLanguage]) &&
!contentTranslationHideLanguages.find(
(l) => lang === l || localeMatch([lang], [l]),
);
2023-09-28 10:48:32 +03:00
return (
2023-10-25 21:18:39 +03:00
<div class="sheet" tabindex="-1">
2023-09-28 10:48:32 +03:00
{!!onClose && (
<button type="button" class="sheet-close outer" onClick={onClose}>
2024-08-13 10:26:23 +03:00
<Icon icon="x" alt={t`Close`} />
2023-09-28 10:48:32 +03:00
</button>
)}
<header class="header-grid">
2024-08-13 10:26:23 +03:00
<h2>
<Trans>Media description</Trans>
</h2>
2023-09-28 10:48:32 +03:00
<div class="header-side">
<Menu2
2023-09-28 10:48:32 +03:00
align="end"
menuButton={
<button type="button" class="plain4">
2024-08-13 10:26:23 +03:00
<Icon icon="more" alt={t`More`} size="xl" />
2023-09-28 10:48:32 +03:00
</button>
}
>
<MenuItem
disabled={forceTranslate}
onClick={() => {
setForceTranslate(true);
}}
>
<Icon icon="translate" />
2024-08-13 10:26:23 +03:00
<span>
<Trans>Translate</Trans>
</span>
2023-09-28 10:48:32 +03:00
</MenuItem>
2023-12-21 13:17:14 +03:00
{supportsTTS && (
<MenuItem
onClick={() => {
speak(alt, lang);
}}
>
<Icon icon="speak" />
2024-08-13 10:26:23 +03:00
<span>
<Trans>Speak</Trans>
</span>
2023-12-21 13:17:14 +03:00
</MenuItem>
)}
</Menu2>
2023-09-28 10:48:32 +03:00
</div>
</header>
<main lang={lang} dir="auto">
2023-09-28 10:48:32 +03:00
<p
style={{
whiteSpace: 'pre-wrap',
2023-11-02 08:00:07 +03:00
textWrap: 'pretty',
2023-09-28 10:48:32 +03:00
}}
>
{alt}
</p>
{(differentLanguage || forceTranslate) && (
<TranslationBlock
forceTranslate={forceTranslate}
sourceLanguage={lang}
text={alt}
/>
2023-09-28 10:48:32 +03:00
)}
</main>
</div>
);
}