colouring-montreal/app/src/frontend/building/data-components/data-entry-group.tsx

43 lines
1.3 KiB
TypeScript
Raw Normal View History

import React, { Fragment, useState } from "react";
2019-10-08 09:20:22 -04:00
import './data-entry-group.css';
import { RightIcon, DownIcon } from "../../components/icons";
interface DataEntryGroupProps {
/** Name of the group */
2019-10-08 09:20:22 -04:00
name: string;
/** Whether the group should be collapsed initially */
collapsed?: boolean;
2019-10-08 09:20:22 -04:00
}
const DataEntryGroup: React.FunctionComponent<DataEntryGroupProps> = (props) => {
const {collapsed: initialCollapsed = true} = props;
const [collapsed, setCollapsed] = useState(initialCollapsed);
return (
<Fragment>
<div className='data-entry-group-header' onClick={() => setCollapsed(!collapsed)}>
<CollapseIcon collapsed={collapsed} />
<span className='data-entry-group-title'>
{props.name}
<span className='data-entry-group-count'>{` (${React.Children.count(props.children)} attributes)`}</span>
</span>
</div>
<div className={`data-entry-group-body ${collapsed ? 'collapse' : ''}`}>
{props.children}
</div>
</Fragment>
);
2019-10-08 09:20:22 -04:00
}
const CollapseIcon: React.FunctionComponent<{collapsed: boolean}> = (props) => (
<span className="collapse-icon">
{props.collapsed ? <RightIcon/> : <DownIcon/>}
</span>
);
export {
DataEntryGroup
};