grommet
Version:
focus on the essential experience
68 lines (62 loc) • 1.78 kB
JavaScript
import React, { useState } from 'react';
import { storiesOf } from '@storybook/react';
import { Box, CheckBox, Grommet } from 'grommet';
import { grommet } from 'grommet/themes';
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 CheckBoxWithStickyDiv = function CheckBoxWithStickyDiv() {
var _useState = 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.createElement(Grommet, {
theme: grommet
}, /*#__PURE__*/React.createElement(Box, {
pad: "large",
align: "center"
}, /*#__PURE__*/React.createElement(Box, {
height: "120px",
width: "120px",
overflow: "auto",
style: boxStyle
}, /*#__PURE__*/React.createElement(Box, {
background: titleBoxBackground,
style: titleBoxStyle
}, "Click & Scroll"), checkboxes.map(function (item) {
return /*#__PURE__*/React.createElement(CheckBox, {
key: item,
checked: checks.includes(item),
label: item,
onChange: onCheck(item)
});
}))));
};
storiesOf('CheckBox', module).add('With Sticky Div', function () {
return /*#__PURE__*/React.createElement(CheckBoxWithStickyDiv, null);
});