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

Android targetSdk 35 update - remove SafeAreaView and use padding #95

Conversation

alanleedev
Copy link
Collaborator

@alanleedev alanleedev commented Jan 9, 2025

Summary:

This is an alternative implementation for PR #94 which removes SafeAreaView entirely and uses magic padding for both iOS and Android.

Updating to targetSdk 35 on Android enforces edge-to-edge on Android 15+.
We decided not to use react-native-safe-area-context in the template (PR #84 ) to reduce external dependency although it is the recommendation.
To account for UI overlap, we are using a magic padding value for both iOS and Android in the template.
Also SafeAreaView (iOS only) was removed so same code is used on both platforms.

Changelog:

[ANDROID][CHANGED] - update targetSdk to 35 which will enforce edge-to-edge on Android 15+
[GENERAL][REMOVED] - Removed use of SafeAreaView

Test Plan:

ios_hacky_padding_only.mp4
ios_hacky_padding_only_land.mp4
android_hacky_padding.mp4
android_hacky_padding_land.mp4

Remove use of SafeAreaView and ScrollView.contentInsetAdjustmentBehavior prop.
return (
<SafeAreaView style={backgroundStyle}>
Copy link
Collaborator Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

SafeAreaView is removed

template/App.tsx Outdated
@@ -62,19 +61,25 @@ function App(): React.JSX.Element {
backgroundColor: isDarkMode ? Colors.darker : Colors.lighter,
};

// Note: adding hacky padding to avoid importing rn-safe-area-context library but should not be done in production
const hackyPadding = '5%';
Copy link
Collaborator Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

magic padding is used for both iOS and Android

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

See my other comment. Can we not call this 'hackyPadding' but more like 'safePadding' or 'areaPadding' etc.

<StatusBar
barStyle={isDarkMode ? 'light-content' : 'dark-content'}
backgroundColor={backgroundStyle.backgroundColor}
/>
<ScrollView
contentInsetAdjustmentBehavior="automatic"
Copy link
Collaborator Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

removed iOS only prop: contentInsetAdjustmentBehavior

template/App.tsx Outdated
style={backgroundStyle}>
<Header />
<View style={{paddingRight: hackyPadding}}>
Copy link
Collaborator Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

right padding for RN version indicator

template/App.tsx Outdated
<View
style={{
backgroundColor: isDarkMode ? Colors.black : Colors.white,
paddingHorizontal: hackyPadding,
Copy link
Collaborator Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

left, right padding for content within ScrollView

template/App.tsx Outdated
<View
style={{
backgroundColor: isDarkMode ? Colors.black : Colors.white,
paddingHorizontal: hackyPadding,
paddingBottom: hackyPadding,
Copy link
Collaborator Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

bottom padding to prevent content overlap with button nav bar

Copy link
Contributor

@cipolleschi cipolleschi left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I personally prefer this alternative because:

  • It provides a clear message that SafeAreaView should not be used.
  • reduces differences between iOS and Android.

How does this behave in landscape mode?

template/App.tsx Outdated Show resolved Hide resolved
template/App.tsx Outdated
@@ -62,19 +61,25 @@ function App(): React.JSX.Element {
backgroundColor: isDarkMode ? Colors.darker : Colors.lighter,
};

// Note: adding hacky padding to avoid importing rn-safe-area-context library but should not be done in production
const hackyPadding = '5%';
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

See my other comment. Can we not call this 'hackyPadding' but more like 'safePadding' or 'areaPadding' etc.

rename padding variable and add additional context on its use

Co-authored-by: Nicola Corti <corti.nico@gmail.com>
@alanleedev alanleedev marked this pull request as ready for review January 14, 2025 15:42
@alanleedev
Copy link
Collaborator Author

@cipolleschi
2nd video in description is landscape although the video itself is rotated.

ios_hacky_padding_only_land.mp4

I personally prefer this alternative because:

* It provides a clear message that SafeAreaView should not be used.

* reduces differences between iOS and Android.

How does this behave in landscape mode?

@alanleedev alanleedev self-assigned this Jan 14, 2025
@alanleedev alanleedev merged commit 3398194 into react-native-community:main Jan 14, 2025
1 check passed
alanleedev added a commit to alanleedev/template that referenced this pull request Jan 14, 2025
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants