grommet
Version:
focus on the essential experience
64 lines (63 loc) • 2.44 kB
JavaScript
;
exports.__esModule = true;
exports["default"] = exports.WithStickyDiv = void 0;
var _react = _interopRequireWildcard(require("react"));
var _grommet = require("grommet");
function _interopRequireWildcard(e, t) { if ("function" == typeof WeakMap) var r = new WeakMap(), n = new WeakMap(); return (_interopRequireWildcard = function _interopRequireWildcard(e, t) { if (!t && e && e.__esModule) return e; var o, i, f = { __proto__: null, "default": e }; if (null === e || "object" != typeof e && "function" != typeof e) return f; if (o = t ? n : r) { if (o.has(e)) return o.get(e); o.set(e, f); } for (var _t in e) "default" !== _t && {}.hasOwnProperty.call(e, _t) && ((i = (o = Object.defineProperty) && Object.getOwnPropertyDescriptor(e, _t)) && (i.get || i.set) ? o(f, _t, i) : f[_t] = e[_t]); return f; })(e, t); }
var boxStyle = {
position: 'relative',
display: 'block'
};
var titleBoxBackground = {
color: 'light-2'
};
var titleBoxStyle = {
position: 'sticky',
top: 0
};
var checkboxes = Array(8).fill().map(function (_, i) {
return "item " + (i + 1);
});
var removeItemFromArray = function removeItemFromArray(array, value) {
return array.filter(function (item) {
return item !== value;
});
};
var WithStickyDiv = exports.WithStickyDiv = function WithStickyDiv() {
var _useState = (0, _react.useState)([]),
checks = _useState[0],
setChecks = _useState[1];
var onCheck = function onCheck(value) {
return function (_ref) {
var target = _ref.target;
if (target.checked) {
setChecks([].concat(checks, [value]));
} else {
setChecks(removeItemFromArray(checks, value));
}
};
};
return /*#__PURE__*/_react["default"].createElement(_grommet.Box, {
pad: "large",
align: "center"
}, /*#__PURE__*/_react["default"].createElement(_grommet.Box, {
height: "120px",
width: "120px",
overflow: "auto",
style: boxStyle
}, /*#__PURE__*/_react["default"].createElement(_grommet.Box, {
background: titleBoxBackground,
style: titleBoxStyle
}, "Click & Scroll"), checkboxes.map(function (item) {
return /*#__PURE__*/_react["default"].createElement(_grommet.CheckBox, {
key: item,
checked: checks.includes(item),
label: item,
onChange: onCheck(item)
});
})));
};
WithStickyDiv.storyName = 'With sticky div';
var _default = exports["default"] = {
title: 'Input/CheckBox/With sticky div'
};