Recently I encountered a situation where I needed to overlay a div on top of another div. The standard way to do this is to use CSS and absolute or fixed positioning (https://stackoverflow.com/questions/2941189/how-to-overlay-one-div-over-another-div).
Sounds simple enough, however I need to do this from within a deep hierarchy of elements:
-> Detail Component
-> Action Bar Component
-> Items Component: Loop through and display expandable content divs
-> On Click : overlay a component which is a div containing "expandable content"
The "items" component uses a standard bootstrap table to align the elements like so:
item 1 | item 2 |
item 3 | item 4 |
This layout means that when you select the onClick() for "item 1" and you render the expandable component which is essentially just a div, and it is positioned relatively the the content will appear in place of item one in the table.
item 1 (expandable content) | item 2 |
item 3 | item 4 |
Cut a long story short, every which way I tried to style the popup unwanted styles would be inherited from the table and other components above it. I also found that I had to place it absolutely to get the effect I was looking for which created a raft of further problems. Finally, it was suggested that this might be a good use case for React Portals which did indeed save the day.
I also learned on this project how much Redux can be over utilized. "When you have a hammer, everything starts to look like a nail". This was said a lot, and it should be, because when you are deep into the detail of a project it can be hard to see that it has been over-engineered.
I also learned on this project how much Redux can be over utilized. "When you have a hammer, everything starts to look like a nail". This was said a lot, and it should be, because when you are deep into the detail of a project it can be hard to see that it has been over-engineered.
No comments:
Post a Comment