rip out native translate (#4482)
This commit is contained in:
		
							parent
							
								
									fac5f6cdac
								
							
						
					
					
						commit
						3573f7ea40
					
				
					 13 changed files with 4 additions and 227 deletions
				
			
		|  | @ -1,6 +0,0 @@ | |||
| { | ||||
|   "platforms": ["ios"], | ||||
|   "ios": { | ||||
|     "modules": ["ExpoBlueskyTranslateModule"] | ||||
|   } | ||||
| } | ||||
|  | @ -1,6 +0,0 @@ | |||
| export { | ||||
|   isAvailable, | ||||
|   isLanguageSupported, | ||||
|   NativeTranslationModule, | ||||
|   NativeTranslationView, | ||||
| } from './src/ExpoBlueskyTranslateView' | ||||
|  | @ -1,20 +0,0 @@ | |||
| import ExpoModulesCore | ||||
| import SwiftUI | ||||
| 
 | ||||
| // Thanks to Andrew Levy for this code snippet | ||||
| // https://github.com/andrew-levy/swiftui-react-native/blob/d3fbb2abf07601ff0d4b83055e7717bb980910d6/ios/Common/ExpoView%2BUIHostingController.swift | ||||
| 
 | ||||
| extension ExpoView { | ||||
|   func setupHostingController(_ hostingController: UIHostingController<some View>) { | ||||
|     hostingController.view.translatesAutoresizingMaskIntoConstraints = false | ||||
|     hostingController.view.backgroundColor = .clear | ||||
| 
 | ||||
|     addSubview(hostingController.view) | ||||
|     NSLayoutConstraint.activate([ | ||||
|       hostingController.view.topAnchor.constraint(equalTo: self.topAnchor), | ||||
|       hostingController.view.bottomAnchor.constraint(equalTo: self.bottomAnchor), | ||||
|       hostingController.view.leftAnchor.constraint(equalTo: self.leftAnchor), | ||||
|       hostingController.view.rightAnchor.constraint(equalTo: self.rightAnchor), | ||||
|     ]) | ||||
|   } | ||||
| } | ||||
|  | @ -1,21 +0,0 @@ | |||
| Pod::Spec.new do |s| | ||||
|   s.name           = 'ExpoBlueskyTranslate' | ||||
|   s.version        = '1.0.0' | ||||
|   s.summary        = 'Uses SwiftUI translation to translate text.' | ||||
|   s.description    = 'Uses SwiftUI translation to translate text.' | ||||
|   s.author         = '' | ||||
|   s.homepage       = 'https://docs.expo.dev/modules/' | ||||
|   s.platforms      = { :ios => '13.4' } | ||||
|   s.source         = { git: '' } | ||||
|   s.static_framework = true | ||||
| 
 | ||||
|   s.dependency 'ExpoModulesCore' | ||||
| 
 | ||||
|   # Swift/Objective-C compatibility | ||||
|   s.pod_target_xcconfig = { | ||||
|     'DEFINES_MODULE' => 'YES', | ||||
|     'SWIFT_COMPILATION_MODE' => 'wholemodule' | ||||
|   } | ||||
| 
 | ||||
|   s.source_files = "**/*.{h,m,mm,swift,hpp,cpp}" | ||||
| end | ||||
|  | @ -1,18 +0,0 @@ | |||
| import ExpoModulesCore | ||||
| import Foundation | ||||
| import SwiftUI | ||||
| 
 | ||||
| public class ExpoBlueskyTranslateModule: Module { | ||||
|   public func definition() -> ModuleDefinition { | ||||
|     Name("ExpoBlueskyTranslate") | ||||
|      | ||||
|     AsyncFunction("presentAsync") { (text: String) in | ||||
|       DispatchQueue.main.async { [weak state = TranslateViewState.shared] in | ||||
|         state?.isPresented = true | ||||
|         state?.text = text | ||||
|       } | ||||
|     } | ||||
|      | ||||
|     View(ExpoBlueskyTranslateView.self) {} | ||||
|   } | ||||
| } | ||||
|  | @ -1,22 +0,0 @@ | |||
| import ExpoModulesCore | ||||
| import Foundation | ||||
| import SwiftUI | ||||
| 
 | ||||
| class TranslateViewState: ObservableObject { | ||||
|   static var shared = TranslateViewState() | ||||
|    | ||||
|   @Published var isPresented = false | ||||
|   @Published var text = "" | ||||
| } | ||||
| 
 | ||||
| class ExpoBlueskyTranslateView: ExpoView { | ||||
|   required init(appContext: AppContext? = nil) { | ||||
|     if #available(iOS 14.0, *) { | ||||
|       let hostingController = UIHostingController(rootView: TranslateView()) | ||||
|       super.init(appContext: appContext) | ||||
|       setupHostingController(hostingController) | ||||
|     } else { | ||||
|       super.init(appContext: appContext) | ||||
|     } | ||||
|   } | ||||
| } | ||||
|  | @ -1,31 +0,0 @@ | |||
| import SwiftUI | ||||
| // conditionally import the Translation module | ||||
| #if canImport(Translation) | ||||
| import Translation | ||||
| #endif | ||||
| 
 | ||||
| struct TranslateView: View { | ||||
|   @ObservedObject var state = TranslateViewState.shared | ||||
| 
 | ||||
|   var body: some View { | ||||
|     if #available(iOS 17.4, *) { | ||||
|       VStack { | ||||
|         UIViewRepresentableWrapper(view: UIView(frame: .zero)) | ||||
|       } | ||||
|       .translationPresentation( | ||||
|         isPresented: $state.isPresented, | ||||
|         text: state.text | ||||
|       ) | ||||
|     } | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| struct UIViewRepresentableWrapper: UIViewRepresentable { | ||||
|   let view: UIView | ||||
| 
 | ||||
|   func makeUIView(context: Context) -> UIView { | ||||
|     return view | ||||
|   } | ||||
| 
 | ||||
|   func updateUIView(_ uiView: UIView, context: Context) {} | ||||
| } | ||||
|  | @ -1,3 +0,0 @@ | |||
| export type ExpoBlueskyTranslateModule = { | ||||
|   presentAsync: (text: string) => Promise<void> | ||||
| } | ||||
|  | @ -1,51 +0,0 @@ | |||
| import React from 'react' | ||||
| import {Platform} from 'react-native' | ||||
| import {requireNativeModule, requireNativeViewManager} from 'expo-modules-core' | ||||
| 
 | ||||
| import {ExpoBlueskyTranslateModule} from './ExpoBlueskyTranslate.types' | ||||
| 
 | ||||
| export const NativeTranslationModule = | ||||
|   requireNativeModule<ExpoBlueskyTranslateModule>('ExpoBlueskyTranslate') | ||||
| 
 | ||||
| const NativeView: React.ComponentType = requireNativeViewManager( | ||||
|   'ExpoBlueskyTranslate', | ||||
| ) | ||||
| 
 | ||||
| export function NativeTranslationView() { | ||||
|   return <NativeView /> | ||||
| } | ||||
| 
 | ||||
| // can be something like "17.5.1", so just take the first two parts
 | ||||
| const version = String(Platform.Version).split('.').slice(0, 2).join('.') | ||||
| 
 | ||||
| export const isAvailable = Number(version) >= 17.4 | ||||
| 
 | ||||
| // https://en.wikipedia.org/wiki/Translate_(Apple)#Languages
 | ||||
| const SUPPORTED_LANGUAGES = [ | ||||
|   'ar', | ||||
|   'zh', | ||||
|   'zh', | ||||
|   'nl', | ||||
|   'en', | ||||
|   'en', | ||||
|   'fr', | ||||
|   'de', | ||||
|   'id', | ||||
|   'it', | ||||
|   'ja', | ||||
|   'ko', | ||||
|   'pl', | ||||
|   'pt', | ||||
|   'ru', | ||||
|   'es', | ||||
|   'th', | ||||
|   'tr', | ||||
|   'uk', | ||||
|   'vi', | ||||
| ] | ||||
| 
 | ||||
| export function isLanguageSupported(lang?: string) { | ||||
|   // If the language is not provided, we assume it is supported
 | ||||
|   if (!lang) return true | ||||
|   return SUPPORTED_LANGUAGES.includes(lang) | ||||
| } | ||||
|  | @ -1,13 +0,0 @@ | |||
| export const NativeTranslationModule = { | ||||
|   presentAsync: async (_: string) => {}, | ||||
| } | ||||
| 
 | ||||
| export function NativeTranslationView() { | ||||
|   return null | ||||
| } | ||||
| 
 | ||||
| export const isAvailable = false | ||||
| 
 | ||||
| export function isLanguageSupported(_lang?: string) { | ||||
|   return false | ||||
| } | ||||
|  | @ -30,11 +30,6 @@ import {useSession} from 'state/session' | |||
| import {PostThreadFollowBtn} from 'view/com/post-thread/PostThreadFollowBtn' | ||||
| import {atoms as a} from '#/alf' | ||||
| import {RichText} from '#/components/RichText' | ||||
| import { | ||||
|   isAvailable as isNativeTranslationAvailable, | ||||
|   isLanguageSupported, | ||||
|   NativeTranslationModule, | ||||
| } from '../../../../modules/expo-bluesky-translate' | ||||
| import {ContentHider} from '../../../components/moderation/ContentHider' | ||||
| import {LabelsOnMyPost} from '../../../components/moderation/LabelsOnMe' | ||||
| import {PostAlerts} from '../../../components/moderation/PostAlerts' | ||||
|  | @ -344,7 +339,6 @@ let PostThreadItemLoaded = ({ | |||
|             </ContentHider> | ||||
|             <ExpandedPostDetails | ||||
|               post={post} | ||||
|               record={record} | ||||
|               translatorUrl={translatorUrl} | ||||
|               needsTranslation={needsTranslation} | ||||
|             /> | ||||
|  | @ -653,12 +647,10 @@ function PostOuterWrapper({ | |||
| 
 | ||||
| function ExpandedPostDetails({ | ||||
|   post, | ||||
|   record, | ||||
|   needsTranslation, | ||||
|   translatorUrl, | ||||
| }: { | ||||
|   post: AppBskyFeedDefs.PostView | ||||
|   record?: AppBskyFeedPost.Record | ||||
|   needsTranslation: boolean | ||||
|   translatorUrl: string | ||||
| }) { | ||||
|  | @ -666,18 +658,9 @@ function ExpandedPostDetails({ | |||
|   const {_} = useLingui() | ||||
|   const openLink = useOpenLink() | ||||
| 
 | ||||
|   const text = record?.text || '' | ||||
| 
 | ||||
|   const onTranslatePress = React.useCallback(() => { | ||||
|     if ( | ||||
|       isNativeTranslationAvailable && | ||||
|       isLanguageSupported(record?.langs?.at(0)) | ||||
|     ) { | ||||
|       NativeTranslationModule.presentAsync(text) | ||||
|     } else { | ||||
|     openLink(translatorUrl) | ||||
|     } | ||||
|   }, [openLink, text, translatorUrl, record]) | ||||
|   }, [openLink, translatorUrl]) | ||||
| 
 | ||||
|   return ( | ||||
|     <View style={[s.flexRow, s.mt2, s.mb10]}> | ||||
|  |  | |||
|  | @ -57,11 +57,6 @@ import {Warning_Stroke2_Corner0_Rounded as Warning} from '#/components/icons/War | |||
| import * as Menu from '#/components/Menu' | ||||
| import * as Prompt from '#/components/Prompt' | ||||
| import {ReportDialog, useReportDialogControl} from '#/components/ReportDialog' | ||||
| import { | ||||
|   isAvailable as isNativeTranslationAvailable, | ||||
|   isLanguageSupported, | ||||
|   NativeTranslationModule, | ||||
| } from '../../../../../modules/expo-bluesky-translate' | ||||
| import {EventStopper} from '../EventStopper' | ||||
| import * as Toast from '../Toast' | ||||
| 
 | ||||
|  | @ -188,16 +183,8 @@ let PostDropdownBtn = ({ | |||
|   }, [_, richText]) | ||||
| 
 | ||||
|   const onPressTranslate = React.useCallback(() => { | ||||
|     if ( | ||||
|       isNativeTranslationAvailable && | ||||
|       isLanguageSupported(record?.langs?.at(0)) | ||||
|     ) { | ||||
|       const text = richTextToString(richText, true) | ||||
|       NativeTranslationModule.presentAsync(text) | ||||
|     } else { | ||||
|     openLink(translatorUrl) | ||||
|     } | ||||
|   }, [openLink, record?.langs, richText, translatorUrl]) | ||||
|   }, [openLink, translatorUrl]) | ||||
| 
 | ||||
|   const onHidePost = React.useCallback(() => { | ||||
|     hidePost({uri: postUri}) | ||||
|  |  | |||
|  | @ -33,7 +33,6 @@ import {ErrorBoundary} from 'view/com/util/ErrorBoundary' | |||
| import {MutedWordsDialog} from '#/components/dialogs/MutedWords' | ||||
| import {SigninDialog} from '#/components/dialogs/Signin' | ||||
| import {Outlet as PortalOutlet} from '#/components/Portal' | ||||
| import {NativeTranslationView} from '../../../modules/expo-bluesky-translate' | ||||
| import {RoutesContainer, TabsNavigator} from '../../Navigation' | ||||
| import {Composer} from './Composer' | ||||
| import {DrawerContent} from './Drawer' | ||||
|  | @ -94,7 +93,6 @@ function ShellInner() { | |||
|           </Drawer> | ||||
|         </ErrorBoundary> | ||||
|       </Animated.View> | ||||
|       <NativeTranslationView /> | ||||
|       <Composer winHeight={winDim.height} /> | ||||
|       <ModalsContainer /> | ||||
|       <MutedWordsDialog /> | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue