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

borderRadius in containerStyle prop not working #18

Closed
theneekz opened this issue Apr 7, 2021 · 5 comments
Closed

borderRadius in containerStyle prop not working #18

theneekz opened this issue Apr 7, 2021 · 5 comments

Comments

@theneekz
Copy link

theneekz commented Apr 7, 2021

Describe the bug
Trying to use borderRadius in containerStyle prop doesn't work.

To Reproduce

<SegmentedControl
tabs={values}
paddingVertical={5}
containerStyle={{
marginVertical: 10,
alignSelf: 'center',
borderColor: '#E4E8F5',
borderStyle: 'solid',
borderRadius: 15,
borderWidth: 3,
}}
activeSegmentBackgroundColor="#568CEB"
segmentedControlBackgroundColor="#E4E8F5"
textStyle={{
color: '#616467',
textTransform: 'uppercase',
}}
activeTextColor="#fff"
activeTextWeight="800"
currentIndex={selectedIndex}
onChange={onPress}
/>

Expected behavior
Expected the border radius to change with different number inputs

Screenshots
If applicable, add screenshots to help explain your problem.
screenshot

Smartphone (please complete the following information):

  • Device: iPhone 11, Google Pixel 4
  • OS: ios 14.3, Android 11 (Google APIs)
@Karthik-B-06
Copy link
Owner

Karthik-B-06 commented Apr 15, 2021

Hey @theneekz. Understood the issue.

Screenshot 2021-04-15 at 10 44 28 PM

You are trying to set the value using containerStyle prop which gets overridden by my segmentedControlWrapper style.

There are 2 possible solutions I can think of right away.

  1. Taking out the border radius of the container as a separate prop.
  2. Or moving segmentedControlWrapper before the containerStyle so that the user-given styles are correctly overridden.

Which one of the above two you think is more apt?

@theneekz
Copy link
Author

Hey @Karthik-B-06, thanks for the response.

I would think that you would want to put the containerStyle second in the array, to allow custom styles to override the default... But maybe only allow certain properties? Like how textStyle allows all style properties except the label colors set by props? I don't know enough about View styles to know what will interfere with functionality.

@Karthik-B-06
Copy link
Owner

Karthik-B-06 commented Apr 23, 2021

@theneekz
I am sorry for the delay.

Tried enabling the border-radius to work by overriding the values. But the style structure of segmented control breaks.

Screenshot 2021-04-23 at 10 34 36 PM

I should probably have to think of a work-around for this. Rest assured I will get back with a solution. :) Thank you for your patience.

@Karthik-B-06
Copy link
Owner

@theneekz A new version supporting change of borderRadius through containerStyle props is available.

You will have to use something like this so that the style structure does not break.

<SegmentedControl
        tabs={["Label", "Label"]}
        onChange={() => {}}
        paddingVertical={6}
        containerStyle={{
          marginVertical: 20,
          borderRadius: 15,
        }}
        tileStyle={{
          borderRadius: 15,
        }}
        currentIndex={tabIndex}
        onChange={handleTabsChange}
        theme={theme}
/>

Which will look something like this.

Screenshot 2021-04-24 at 10 18 00 AM

Added a new prop tileStyle to match the borderRadius of the container.

Closing this issue for now 🎉 .

If you are still facing any issues feel free to reopen it. :)

@theneekz
Copy link
Author

theneekz commented Apr 24, 2021 via email

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

No branches or pull requests

2 participants