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

Fix/hint position #3469

Open
wants to merge 7 commits into
base: master
Choose a base branch
from
Open

Fix/hint position #3469

wants to merge 7 commits into from

Conversation

ethanshar
Copy link
Collaborator

@ethanshar ethanshar commented Dec 25, 2024

Description

  • I renamed Hint's component internal methods to make it a little more readable
  • I fixed the position of the Hint when the target is being pushed by another element - causing it to be misaligned and missed by our calculations.
    There's a dedicate method that calculates the offset for the hint message
  • I added an example in HintScreen the showcase the issue so it's easier to check

Changelog

Fix Hint positioning when target is pushed by another element

Additional info

Copy link
Contributor

@nitzanyiz nitzanyiz left a comment

Choose a reason for hiding this comment

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

@ethanshar, Why did we fix this only for short messages?

src/components/hint/index.tsx Outdated Show resolved Hide resolved
@ethanshar
Copy link
Collaborator Author

@ethanshar, Why did we fix this only for short messages?

@nitzanyiz Two reasons

  • If the message is long enough, there's no issue because the hint's tip is positioned ok with the hint
  • If the message is long enough and we add it an offset it might get out of screen boundaries

@ethanshar ethanshar requested a review from nitzanyiz December 29, 2024 12:14
@nitzanyiz
Copy link
Contributor

I think most of the cases where we saw this bug is where they wanted to use the hint without a side tip and the target was on the sides of the screen. Currently after your fix, for short messages, it is fixed but for a little longer messages it not and it even get out of the screen. Not sure what is better 😅

import React, {Component} from 'react';
import {View, Text, Card, TextField, Button, Hint} from 'react-native-ui-lib';

export default class PlaygroundScreen extends Component {
  render() {
    return (
      <View bg-grey80 flex padding-20>
        <View style={{alignSelf: 'flex-start'}} bg-red30>
          <Hint message={'This is a short message'} visible useSideTip={false}>
            <Text>Hello</Text>
          </Hint>
        </View>
      </View>
    );
  }
}

image

@ethanshar
Copy link
Collaborator Author

ethanshar commented Dec 30, 2024

<View bg-grey80 flex padding-20>
        <View style={{alignSelf: 'flex-start'}} bg-red30>
          <Hint message={'This is a short message'} visible useSideTip={false}>
            <Text>Hello</Text>
          </Hint>
        </View>
      </View>

Ok, we'll have to improve the logic. The assumption I did for short message is not good enough, I'll check if we can have a better solution

The problem is that your use case should have worked ok, maybe it's a different bug

@ethanshar
Copy link
Collaborator Author

@nitzanyiz After something digging, what you are showing is totally different issue
Unfortunately we made a lot of assumptions when rendering side hints and there are a lot of factor that affect the hint position. For example if you'll pass onBackgroundPress callback it will work differently
In any case the recommended UI for side hint is the side tip, when users change it they break the UI

Back to the issue I have fixed, I see it requires the user pass useSideTip={false} and it's not trivial so Im trying to fix it

@ethanshar
Copy link
Collaborator Author

@nitzanyiz @Inbal-Tish
I did extra adjustments, please review

  • I increased the threshold that determine if the target positioned on left/right to get a little more accurate results
  • As for the issue Nitzan showed, it's a different issue - I fixed it by changing the default edgeMargins when the hint is not rendered in a modal (assuming the margins are coming from the screen so we don't need to include them) - let me know if you need me to elaborate on that

I think these fixes solve most of the issues, for some cases where users do "stupid" things we can always fix but we can guide them which props to pass and how (useSideTip, edgeMargins, etc..)

@Inbal-Tish
Copy link
Collaborator

This simple example doesn't look good:
<View row center> <Hint visible={this.state.showHint} message={'xx'}> <Button label="Button" onPress={() => this.setState({showHint: !this.state.showHint})}/> </Hint> </View>
I think we need to set minimum width

@ethanshar
Copy link
Collaborator Author

This simple example doesn't look good: <View row center> <Hint visible={this.state.showHint} message={'xx'}> <Button label="Button" onPress={() => this.setState({showHint: !this.state.showHint})}/> </Hint> </View> I think we need to set minimum width

Yes, it also happens in master it's a different issue, it's because you don't pass onBackgroundPress
When not passing it, it doesn't render inside a modal and in that case we have all kind of issues

@ethanshar
Copy link
Collaborator Author

ethanshar commented Jan 2, 2025

@Inbal-Tish @nitzanyiz
I pushed another fix with a min width as Inbal suggested, it fixes the edge case you found

Unfortunately, there's a root issue with this component which we need to consider refactoring
The component handles two use cases:

  • Hint rendered in a modal (when onBackgroundPress is passed)
  • Hint rendered in the screen of the target

The latter is a more complex scenario because we have scenarios where the hint's target is deeply nested which force us to do all kind of calculations to make the hint appear in the right location.
Because the Hint's code covers both cases there's no good separation and fixing an issue in one use case usually affects the other use case.
My suggestion for future refactor is to separate the Hint into two components: HintInModal, HintInScreen and separate the calculations as well.

Anyway, for now, I believe this PR fix most of issues users complained on so we can merge it (unless you find other regression issues)
Let me know what you think

@ethanshar ethanshar added the Important for Next Release PR that must be included in the release version label Jan 8, 2025
@nitzanyiz
Copy link
Contributor

Now when we render it with a side tip it the side hint goes a little inside the hint and not on its side.

Master with default useSideTip (useSideTip={true}) Current with default useSideTip (useSideTip={true}) Current with useSideTip false
image image image

with this example: (I removed the center on the view and then useSideTip={false})

<View marginT-100 row>
  {targetPosition !== 'flex-start' && <Text marginH-s3>Text pushing button</Text>}
  <Hint
    message={'Hint'}
    visible={showSecondHint}
    onBackgroundPress={this.toggleSecondHint}
    // useSideTip={false}
    
  >
    <Button label="Button" onPress={this.toggleSecondHint}/>
  </Hint>
  {targetPosition === 'flex-start' && <Text marginH-s3>Text pushing button</Text>}
</View>

@nitzanyiz nitzanyiz assigned ethanshar and unassigned nitzanyiz Jan 8, 2025
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Important for Next Release PR that must be included in the release version waiting-for-response
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants