@talend/react-containers
Version:
Provide connected components aka containers for @talend/react-cmf based on @talend/react-components.
80 lines (79 loc) • 3.12 kB
JavaScript
;
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.default = exports.QUERY_ATTR = exports.DISPLAY_NAME = exports.DEFAULT_STATE = void 0;
var _reactCmf = require("@talend/react-cmf");
var _react = require("react");
var _propTypes = _interopRequireDefault(require("prop-types"));
var _immutable = _interopRequireDefault(require("immutable"));
var _reactComponents = require("@talend/react-components");
var _lodash = require("lodash");
var _jsxRuntime = require("react/jsx-runtime");
function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
function _defineProperty(e, r, t) { return (r = _toPropertyKey(r)) in e ? Object.defineProperty(e, r, { value: t, enumerable: !0, configurable: !0, writable: !0 }) : e[r] = t, e; }
function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == typeof i ? i : i + ""; }
function _toPrimitive(t, r) { if ("object" != typeof t || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != typeof i) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); }
const QUERY_ATTR = exports.QUERY_ATTR = 'query';
const DEFAULT_STATE = exports.DEFAULT_STATE = new _immutable.default.Map({
[QUERY_ATTR]: '',
docked: true
});
const DISPLAY_NAME = exports.DISPLAY_NAME = 'Container(FilterBar)';
const DOCKED_ATTR = 'docked';
class FilterBar extends _react.Component {
constructor(props) {
super(props);
this.onFilter = this.onFilter.bind(this);
this.onToggle = this.onToggle.bind(this);
}
onFilter(event, value) {
this.props.setState({
query: value
});
if (this.props.onFilter) {
this.props.onFilter(event, {
query: value,
props: this.props
});
}
}
onToggle(event) {
this.props.setState(prevState => {
let state = prevState.state;
if (this.props.dockable) {
state = state.set('docked', !this.props.state.get('docked'));
}
return state;
});
if (this.props.onToggle) {
this.props.onToggle(event);
}
}
render() {
const state = this.props.state || DEFAULT_STATE;
const props = {
...(0, _lodash.omit)(this.props, _reactCmf.cmfConnect.INJECTED_PROPS),
docked: this.props.docked != null ? this.props.docked : state.get(DOCKED_ATTR),
value: this.props.value ? this.props.value : state.get(QUERY_ATTR, ''),
onToggle: this.onToggle,
onFilter: this.onFilter
};
return /*#__PURE__*/(0, _jsxRuntime.jsx)(_reactComponents.FilterBar, {
...props
});
}
}
_defineProperty(FilterBar, "displayName", DISPLAY_NAME);
_defineProperty(FilterBar, "propTypes", {
..._reactCmf.cmfConnect.propTypes,
id: _propTypes.default.string,
placeholder: _propTypes.default.string,
filterInputValue: _propTypes.default.string,
dockable: _propTypes.default.bool
});
_defineProperty(FilterBar, "defaultProps", {
dockable: true
});
var _default = exports.default = FilterBar;
//# sourceMappingURL=FilterBar.container.js.map