import React from 'react'
import {Platform, StyleSheet, TextProps, ViewStyle} from 'react-native'
import {RNUITextView, RNUITextViewChild} from './index'
const TextAncestorContext = React.createContext<[boolean, ViewStyle]>([
  false,
  StyleSheet.create({}),
])
const useTextAncestorContext = () => React.useContext(TextAncestorContext)
const textDefaults: TextProps = {
  allowFontScaling: true,
  selectable: true,
}
export function UITextView({style, children, ...rest}: TextProps) {
  const [isAncestor, rootStyle] = useTextAncestorContext()
  // Flatten the styles, and apply the root styles when needed
  const flattenedStyle = React.useMemo(
    () => StyleSheet.flatten([rootStyle, style]),
    [rootStyle, style],
  )
  if (Platform.OS !== 'ios') {
    throw new Error('UITextView is only available on iOS')
  }
  if (!isAncestor) {
    return (
      
        
          {React.Children.toArray(children).map((c, index) => {
            if (React.isValidElement(c)) {
              return c
            } else if (typeof c === 'string') {
              return (
                
              )
            }
          })}
        
      
    )
  } else {
    return (
      <>
        {React.Children.toArray(children).map((c, index) => {
          if (React.isValidElement(c)) {
            return c
          } else if (typeof c === 'string') {
            return (
              
            )
          }
        })}
      >
    )
  }
}