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

48 lines
1.4 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';
2019-11-13 14:20:47 -05:00
import { DownIcon, RightIcon } 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;
showCount?: boolean;
2019-10-08 09:20:22 -04:00
}
const DataEntryGroup: React.FunctionComponent<DataEntryGroupProps> = (props) => {
const {
collapsed: initialCollapsed = true,
showCount = 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'>{showCount && ` (${React.Children.count(props.children)} attributes)`}</span>
</span>
</div>
<div className={`data-entry-group-body ${collapsed ? 'collapse' : ''}`}>
{props.children}
</div>
</Fragment>
);
2019-11-07 03:13:30 -05:00
};
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
};