Security News
pnpm 10.0.0 Blocks Lifecycle Scripts by Default
pnpm 10 blocks lifecycle scripts by default to improve security, addressing supply chain attack risks but sparking debate over compatibility and workflow changes.
Handling interactions with dumb react components.
Complex DOM events and interactions are not easy to be handled by stateless dumb components as you often need to keep a state about the current interaction and care about setting up DOM level event listeners.
With Intreact (typo intended) you can keep your components simple, clean and stateless and wrap them to handle all the interactions you may need.
At its current state Intreact uses hammerjs to handle touch-like interactions and preserve all the synthetic events to be handled by react.
This is particularly useful with stateless components on a flux architecture: basically you will not dispatch any action inside the components, but will keep them in the "smart" container where you will wrap all your "dumb" components using Intreact and other "wrappers" (e.g. layouting, mediaqueries, etc...).
Add intreact
as a dependency
$ npm install --save intreact
then simply use the provided component inside your "smart containers".
The actions provided to Intreact will most likely trigger some changes on the central state of the whole app and the stateless components will update whenever their props will change.
import React from 'react';
import ReactDOM from 'react-dom';
import Intreact from 'intreact';
ReactDOM.render(
<Intreact
onClick={clickAction}
onMouseOver={mouseOverAction}
onTap={tapAction}
onTapoutside={tapoutsideAction}
onSwipeleft={swipeleftAction}
onSwiperight={swiperightAction}
onEscape={onEscapeAction}
autofocus={true}
>
<DumbComponent>INTERACT WITH ME!</DumbComponent>
</Intreact>,
document.getElementById('intreact-example')
);
Intreact supports all the events provided by hammerjs, you just need to add "on" in front of the event name and uppercase the first letter (e.g. "tap" -> onTap, "swiperight" -> onSwiperight).
onTapoutside is a special handler that will be triggered when tapping outside of the wrapped element. To make it possible a global Hammer Manager must be instantiated, however Intreact will always check if it already exist and in that case it will just add the new listener to it. When the component get unmounted the onTapoutside listener will be removed, however the global Hammer Manager will not be removed as it may be used by other Intreact components. If you really want to get rid of it and you are sure that no other Intreact components are listening for onTapoutside events you can destroy the window.intreact_hammer object.
You can freely continue to add standard react synthetic events to your stateless components, however if you want to keep all the interactions inside Intreact wrappers you can simply add the usual synthetic events to Intreact as well and it will pass them down to the underlying component.
You can use some special keyboard events: onEscape
, onArrowUp
, onArrowRight
, onArrowDown
, onArrowLeft
, that will automatically setup onKeyDown event on the children element to trigger the eventually alreadydefined onKeyDown handler and then execute the custom handler if the key pressed is the one specified by he event. Please note that no global handler is created, instead the handler is attached to the child node and a tabIndex is specified, then if autofocus is true it will automatically focus on mount or update and the default outline is removed from the style; this way the element will start listening on these event when mounted and stop when unfocused or unmounted avoiding conflicts on the global scope.
Hammerjs support a lot of events, Intreact however will only create event listeners for the required events and will take care of removing them as well as destroying the Hammer instance when not needed anymore.
If you only use synthetic events no Hammer instance will be created at all.
At the moment Intreact only supports touch events using hammerjs, however it would be quite simple to extend it in order to support other libraries for different kind of events.
The main idea is to group all the best interaction libraries specific type of events and create the required instances and listeners only when needed.
Clone the repository then
$ npm install
$ npm start
to start a dev server on localhost:8080
to run tests just use
$ npm test
or
$ npm run test:watch
This component should not not be considered ready for production (until it will reach 1.0.0), however testing and contributions are really welcome.
FAQs
Handling interactions with dumb react components
We found that intreact demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
pnpm 10 blocks lifecycle scripts by default to improve security, addressing supply chain attack risks but sparking debate over compatibility and workflow changes.
Product
Socket now supports uv.lock files to ensure consistent, secure dependency resolution for Python projects and enhance supply chain security.
Research
Security News
Socket researchers have discovered multiple malicious npm packages targeting Solana private keys, abusing Gmail to exfiltrate the data and drain Solana wallets.