Building DevTools-Like UI in React #
I've been working on a new DevTools experience I'm calling Tailor. I was inspired by Tailscan and wanted to understand how I'd build a clone of it as a starting point.
- The most annoying interaction problem I faced was when/ how to activate and deactivate DevTools. Tailscan does this super well, you have a button to activate/ deactivate DevTools. When you click on an element the toolbar remains but the hover behaviour is disabled. When you click anywhere outside the toolbar again you reactivate the hover behavior.
- Make the toolbar follow the cursor for a more natural feeling placement instead of making it relative to the element you place.
- When you add and remove
mouseover
listeners fordocument
inside a React component, make sure you wrap the callback function you pass in inside auseCallback
. Otherwise React creates new functions each time the component re-renders and you won't properly remove the event listeners. pointer-events: none
is your best friend for the overlay/ toolbar UI you build.- css-box-model is a great package to do math for you.