2017-12-24 01:16:45 -05:00
|
|
|
// This function binds the given `handlers` to the `target`.
|
|
|
|
export function assignHandlers (target, handlers) {
|
|
|
|
if (!target || !handlers) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
// We just bind each handler to the `target`.
|
|
|
|
const handle = target.handlers = {};
|
2018-01-03 15:36:21 -05:00
|
|
|
Object.keys(handlers).forEach(
|
2023-02-03 14:52:07 -05:00
|
|
|
key => handle[key] = handlers[key].bind(target),
|
2017-12-24 01:16:45 -05:00
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
// This function only returns the component if the result of calling
|
|
|
|
// `test` with `data` is `true`. Useful with funciton binding.
|
|
|
|
export function conditionalRender (test, data, component) {
|
2017-12-26 19:54:28 -05:00
|
|
|
return test(data) ? component : null;
|
2017-12-24 01:16:45 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
// This object provides props to make the component not visible.
|
|
|
|
export const hiddenComponent = { style: { display: 'none' } };
|