@dotconnor/grommet
Version:
focus on the essential experience
80 lines (67 loc) • 2.83 kB
JavaScript
exports.__esModule = true;
exports.WithStickyDiv = void 0;
var _react = _interopRequireWildcard(require("react"));
var _grommet = require("grommet");
var _themes = require("grommet/themes");
function _getRequireWildcardCache() { if (typeof WeakMap !== "function") return null; var cache = new WeakMap(); _getRequireWildcardCache = function _getRequireWildcardCache() { return cache; }; return cache; }
function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } if (obj === null || typeof obj !== "object" && typeof obj !== "function") { return { "default": obj }; } var cache = _getRequireWildcardCache(); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj["default"] = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
var boxStyle = {
position: 'relative',
display: 'block'
};
var titleBoxBackground = {
color: 'neutral-1'
};
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 = 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.Grommet, {
theme: _themes.grommet
}, /*#__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)
});
}))));
};
exports.WithStickyDiv = WithStickyDiv;
WithStickyDiv.story = {
name: 'With sticky div'
};
;