autoproxy
v1.0.1
Published
A higher-order decorator to automatically proxy properties from the original function to the decorated one
Downloads
68
Readme
autoproxy
A higher-order decorator to automatically proxy properties from the original function to the decorated one so that higher-order components don't get in the way.
How does autoproxy help?
For example, a React component with Redux looks like this:
@connect(data => { size: data.layout.size })
class Box extends React.Component {
static NUMBER_OF_SIDES = 4;
bounce() {
...
}
render() {
...
}
}
This component defines a static property called NUMBER_OF_SIDES
and method called bounce
.
Without autoproxy
Without autoproxy, to access these properties we have to write code like this:
class Root extends React.Component {
render() {
return <Box ref={component => { this._box = component; }} />;
}
componentDidMount() {
console.log('There are %d sides', Box.WrappedComponent.NUMBER_OF_SIDES);
this._box.getWrappedInstance().bounce();
}
}
See how we need WrappedComponent
and getWrappedInstance()
? This is because the connect
decorator defines Box to wrap the underlying class. As a result Box.NUMBER_OF_SIDES
and this._box.bounce
are both undefined.
With autoproxy
With autoproxy
, the wrapper class automatically proxies the underlying class' properties. Use @autoproxy
to decorate a decorator:
@autoproxy(connect(data => { size: data.layout.size }))
class Box extends React.Component {
...
}
Then you can write Box.NUMBER_OF_SIDES
and this._box.bounce
.