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

Show margin and padding of inspected element #666

Open
3 tasks
km1chno opened this issue Oct 28, 2024 · 0 comments
Open
3 tasks

Show margin and padding of inspected element #666

km1chno opened this issue Oct 28, 2024 · 0 comments
Labels
enhancement New feature or request

Comments

@km1chno
Copy link
Contributor

km1chno commented Oct 28, 2024

This requires several steps

@km1chno km1chno self-assigned this Oct 28, 2024
@km1chno km1chno added the enhancement New feature or request label Nov 13, 2024
@km1chno km1chno removed their assignment Nov 14, 2024
kmagiera added a commit that referenced this issue Nov 22, 2024
## Changes

Fixes #692 

This PR is also necessary for #666 

This PR aims to fix the issue with inspector stack that not all
ancestors of inspected elements are discovered. It turns out that the
hierarchy returned by `getInspectorData()` is already missing these
ancestors, so we have to traverse the component tree ourselves.

The first node is the `closestInstance` in object returned by
`getInspectorDataViewAtPoint`. To access parent node of a node, we look
at `node.return`. This way we can simply traverse the whole path from
first node up to the root. Along the way, we collect all necessary
information and create a stack that is returned at the end. We use
`getInspectorDataForInstance(node)` renderer function to obtain
inspector data for given fiber node.

This version is a lot more accurate, from my testing it returns all the
most used visible components (like `<View>`, `<Text>`, `<Button>`),
which is already an improvement compared to the current solution.

## Demos

The following are demos how the inspect stack looks like before and
after changes from this PR. The component hierarchy of the app consists
of several nested components, which have border for visualization.

#### Before


https://github.com/user-attachments/assets/39501ea3-9c95-46bb-9a06-9b1db9c6123f

#### After


https://github.com/user-attachments/assets/414f43f8-62a6-429f-a25e-6ab374dfcab9

### How Has This Been Tested: 

**Test 1:**
- Open shared app 
- Expand step
- Inspect (right-click) text in step
- Make sure all components are in the trace (for example ScrollView)

<img width="425" alt="step"
src="https://github.com/user-attachments/assets/301fca24-dca9-4c76-a3f5-a869dec0b241">


**Test 2:**

- Open shared app 
- Add after last `Step`:
```
<View>
  <View>
    <View>
      <Text>Nested texts</Text>
    </View>
  </View>
</View>
```
- Inspect (right click) `Nested texts` 
- Make sure all 4 Views are visible 

<img width="377" alt="nested"
src="https://github.com/user-attachments/assets/da385ba3-9cb5-43c6-98a9-de5264fbcbb1">

---------

Co-authored-by: Krzysztof Magiera <krzys@swmansion.com>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
enhancement New feature or request
Projects
None yet
Development

No branches or pull requests

1 participant