@patternplate/client
Version:
Universal javascript client application for patternplate
37 lines (28 loc) • 1.56 kB
JavaScript
;
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.mountable = mountable;
exports.skippable = skippable;
var _react = _interopRequireDefault(require("react"));
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
function _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; }
function mountable(Component) {
return class MountableComponent extends _react.default.Component {
componentDidMount() {
if (typeof this.props.onMount === "function") {
this.props.onMount();
}
}
render() {
const _props = this.props,
onMount = _props.onMount,
rest = _objectWithoutProperties(_props, ["onMount"]);
return _react.default.createElement(Component, rest);
}
};
}
function skippable(Component, prop = "active") {
return props => props[prop] === true ? _react.default.createElement(Component, props) : null;
}
//# sourceMappingURL=behaviours.js.map