From a1969faf8e4f95bca5c5e86fc1a6630a9df8a29b Mon Sep 17 00:00:00 2001 From: Hailey Date: Fri, 6 Sep 2024 08:26:37 -0700 Subject: [PATCH] [Video] Fix alt text dialog on iOS and Android (#5177) Co-authored-by: Samuel Newman --- src/view/com/composer/Composer.tsx | 4 +- .../com/composer/videos/SubtitleDialog.tsx | 37 ++++++++++++------- 2 files changed, 25 insertions(+), 16 deletions(-) diff --git a/src/view/com/composer/Composer.tsx b/src/view/com/composer/Composer.tsx index 6406026187..8ae92b0181 100644 --- a/src/view/com/composer/Composer.tsx +++ b/src/view/com/composer/Composer.tsx @@ -764,8 +764,8 @@ export const ComposePost = observer(function ComposePost({ /> ) : null)} diff --git a/src/view/com/composer/videos/SubtitleDialog.tsx b/src/view/com/composer/videos/SubtitleDialog.tsx index a1cdb906d2..009087452c 100644 --- a/src/view/com/composer/videos/SubtitleDialog.tsx +++ b/src/view/com/composer/videos/SubtitleDialog.tsx @@ -1,4 +1,4 @@ -import React, {useCallback} from 'react' +import React, {useCallback, useState} from 'react' import {Keyboard, StyleProp, View, ViewStyle} from 'react-native' import RNPickerSelect from 'react-native-picker-select' import {msg, Trans} from '@lingui/macro' @@ -7,7 +7,7 @@ import {useLingui} from '@lingui/react' import {MAX_ALT_TEXT} from '#/lib/constants' import {useEnforceMaxGraphemeCount} from '#/lib/strings/helpers' import {LANGUAGES} from '#/locale/languages' -import {isWeb} from '#/platform/detection' +import {isAndroid, isWeb} from '#/platform/detection' import {useLanguagePrefs} from '#/state/preferences' import {atoms as a, useTheme, web} from '#/alf' import {Button, ButtonIcon, ButtonText} from '#/components/Button' @@ -21,9 +21,9 @@ import {Text} from '#/components/Typography' import {SubtitleFilePicker} from './SubtitleFilePicker' interface Props { - altText: string + defaultAltText: string captions: {lang: string; file: File}[] - setAltText: (altText: string) => void + saveAltText: (altText: string) => void setCaptions: React.Dispatch< React.SetStateAction<{lang: string; file: File}[]> > @@ -54,7 +54,9 @@ export function SubtitleDialogBtn(props: Props) { {isWeb ? Captions & alt text : Alt text} - + @@ -63,8 +65,8 @@ export function SubtitleDialogBtn(props: Props) { } function SubtitleDialogInner({ - altText, - setAltText, + defaultAltText, + saveAltText, captions, setCaptions, }: Props) { @@ -74,6 +76,8 @@ function SubtitleDialogInner({ const enforceLen = useEnforceMaxGraphemeCount() const {primaryLanguage} = useLanguagePrefs() + const [altText, setAltText] = useState(defaultAltText) + const handleSelectFile = useCallback( (file: File) => { setCaptions(subs => [ @@ -105,6 +109,7 @@ function SubtitleDialogInner({ onChangeText={evt => setAltText(enforceLen(evt, MAX_ALT_TEXT))} maxLength={MAX_ALT_TEXT * 10} multiline + style={{maxHeight: 300}} numberOfLines={3} onKeyPress={({nativeEvent}) => { if (nativeEvent.key === 'Escape') { @@ -147,22 +152,26 @@ function SubtitleDialogInner({ /> ))} + {subtitleMissingLanguage && ( + + + Ensure you have selected a language for each subtitle file. + + + )} )} - {subtitleMissingLanguage && ( - - Ensure you have selected a language for each subtitle file. - - )} -