Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Text component moves child element to left when using RTL in system #48571

Open
whiskeycola opened this issue Jan 9, 2025 · 3 comments
Open
Labels
Issue: Author Provided Repro This issue can be reproduced in Snack or an attached project. Newer Patch Available

Comments

@whiskeycola
Copy link

whiskeycola commented Jan 9, 2025

Description

If the phone has the RTL (Hebrew) language installed, then the Text component behaves incomprehensibly. The child element moves to the left. This bug does not occur on all devices. In the emulator, Galaxy Tab S6, web or in expo go, everything is displayed well. I noticed this bug on the Galaxy A9. If you change the system language to LTR, then everything is fine and the shift disappears.
React components should be able to be placed anywhere in the application. In my case, I wanted to place a View in a Link from @react-navigation/native and noticed this bug. But this only applies to View component
my code:

import React from 'react';
import {SafeAreaView, Text, View} from 'react-native';

function App(): React.JSX.Element {
  return (
    <SafeAreaView>
      <View
        style={{
          backgroundColor: 'black',
          paddingVertical: 10,
          paddingHorizontal: 50,
        }}>
        <Text style={{backgroundColor: 'red', paddingVertical: 5}}>
          <View
            style={{
              backgroundColor: 'yellow',
              paddingVertical: 5,
              width: '100%',
            }}>
            <Text style={{backgroundColor: 'green'}}>
              {'\u05E9\u05DC\u05D5\u05DD'}
            </Text>
          </View>
        </Text>
      </View>
    </SafeAreaView>
  );
}

export default App;

Steps to reproduce

  1. Set language on mobile device Hebrew
  2. Install app to device
  3. Look at the block offset

React Native Version

0.76.5

Affected Platforms

Runtime - Android, Build - Linux

Output of npx react-native info

info Fetching system and libraries information...
System:
  OS: Linux 6.12 Arch Linux
  CPU: (12) x64 Intel(R) Core(TM) i7-8700 CPU @ 3.20GHz
  Memory: 16.67 GB / 31.26 GB
  Shell:
    version: "5.9"
    path: /usr/bin/zsh
Binaries:
  Node:
    version: 20.10.0
    path: ~/.nvm/versions/node/v20.10.0/bin/node
  Yarn:
    version: 1.22.22
    path: /usr/bin/yarn
  npm:
    version: 10.9.2
    path: ~/.nvm/versions/node/v20.10.0/bin/npm
  Watchman: Not Found
SDKs:
  Android SDK:
    API Levels:
      - "30"
      - "34"
      - "35"
    Build Tools:
      - 30.0.2
      - 34.0.0
      - 35.0.0
    System Images:
      - android-35 | Google Play Intel x86_64 Atom
    Android NDK: Not Found
IDEs:
  Android Studio: AI-242.23339.11.2421.12700392
Languages:
  Java:
    version: javac 23
    path: /usr/bin/javac
  Ruby: Not Found
npmPackages:
  "@react-native-community/cli":
    installed: 15.0.1
    wanted: 15.0.1
  react:
    installed: 18.3.1
    wanted: 18.3.1
  react-native:
    installed: 0.76.5
    wanted: 0.76.5
npmGlobalPackages:
  "*react-native*": Not Found
Android:
  hermesEnabled: true
  newArchEnabled: true
iOS:
  hermesEnabled: Not found
  newArchEnabled: false

Stacktrace or Logs

not have error in logs

Reproducer

https://github.com/whiskeycola/test-react-native-text

Screenshots and Videos

This is what I got as a result:
изображение
Expected behavior: the child element must fit within the Text horizontally.
изображение

@react-native-bot
Copy link
Collaborator

Tip

Newer version available: You are on a supported minor version, but it looks like there's a newer patch available - 0.76.6. Please upgrade to the highest patch for your minor or latest and verify if the issue persists (alternatively, create a new project and repro the issue in it). If it does not repro, please let us know so we can close out this issue. This helps us ensure we are looking at issues that still exist in the most recent releases.

@react-native-bot
Copy link
Collaborator

Tip

Newer version available: You are on a supported minor version, but it looks like there's a newer patch available - undefined. Please upgrade to the highest patch for your minor or latest and verify if the issue persists (alternatively, create a new project and repro the issue in it). If it does not repro, please let us know so we can close out this issue. This helps us ensure we are looking at issues that still exist in the most recent releases.

@whiskeycola
Copy link
Author

Кончик

**Доступна более новая версия ** : вы используете поддерживаемую дополнительную версию, но, похоже, доступен более новый патч — undefined. Пожалуйста, обновите свой второстепенный или последний патч до самой последней версии и проверьте, сохраняется ли проблема (в качестве альтернативы создайте новый проект и воспроизведите в нем проблему). Если воспроизведение не происходит, сообщите нам об этом, чтобы мы могли решить эту проблему. Это помогает нам гарантировать, что мы рассматриваем проблемы, которые все еще существуют в самых последних выпусках.

I updated React Native to version 0.76.6 but the problem remains

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Issue: Author Provided Repro This issue can be reproduced in Snack or an attached project. Newer Patch Available
Projects
None yet
Development

No branches or pull requests

3 participants