Skip to content

Instantly share code, notes, and snippets.

@jsmanifest
Created April 14, 2020 15:01
Show Gist options
  • Save jsmanifest/c8341482ca26b6ea123332f0e6d53998 to your computer and use it in GitHub Desktop.
Save jsmanifest/c8341482ca26b6ea123332f0e6d53998 to your computer and use it in GitHub Desktop.
function ListComponent({ label, items = [], collapsed, toggle, limit, total }) {
return (
<ul>
<p>{label}</p>
{items.map((member) => (
<li key={member}>{member}</li>
))}
{total > limit && (
<li className="expand">
<button type="button" onClick={toggle}>
{collapsed ? 'Expand' : 'Collapse'}
</button>
</li>
)}
</ul>
)
}
function List({ header, label, items = [], limit = 3 }) {
const [collapsed, setCollapsed] = React.useState(items.length > limit)
function toggle() {
setCollapsed((prevValue) => !prevValue)
}
return (
<ListRoot>
<ListHeader>{header}</ListHeader>
<ListComponent
label={label}
items={
collapsed && items.length > limit ? items.slice(0, limit) : items
}
collapsed={collapsed}
toggle={toggle}
limit={limit}
total={items.length}
/>
</ListRoot>
)
}
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment