living-together/source/Component/DetailsList/DetailsList.tsx

71 lines
2.4 KiB
TypeScript

import { Icon } from "@fluentui/react";
import { Component, ReactNode } from "react";
import { BackgroundLevel, FontLevel, Theme } from "../Theme/Theme";
import "./DetailsList.scss";
type IItems = Record<string, any> & {key: string, select?: boolean};
interface IColumns<D extends IItems, K extends keyof D> {
key: K;
className?: string;
beforeCheckbox?: boolean;
render: (data: D[K]) => ReactNode,
click?: (data: D[K]) => any,
}
interface IDetailsListProps {
items: IItems[];
columns: IColumns<this["items"][number], keyof this["items"][number]>[];
hideCheckBox?: boolean;
checkboxClassName?: string;
}
class DetailsList extends Component<IDetailsListProps> {
private renderValue<D extends IItems, K extends keyof D>(item: IItems, column: IColumns<D, K>) {
return <div
className={"details-list-value" + (column.className ? ` ${column.className}` : "")}
key={column.key as any}
>
{column.render(item[column.key as any])}
</div>
}
public render(): ReactNode {
return <Theme
className="details-list"
backgroundLevel={BackgroundLevel.Level4}
fontLevel={FontLevel.normal}
>{
this.props.items.map((item) => {
const { checkboxClassName } = this.props;
return <div className="details-list-item" key={item.key}>
{
this.props.columns.map((column) => {
if (column.beforeCheckbox) {
return this.renderValue(item, column);
}
})
}
{
this.props.hideCheckBox ? null :
<div
className={"details-list-checkbox" + (checkboxClassName ? ` ${checkboxClassName}` : "")}
>
<Icon iconName="CheckMark"></Icon>
</div>
}
{
this.props.columns.map((column) => {
if (!column.beforeCheckbox) {
return this.renderValue(item, column);
}
})
}
</div>
})
}</Theme>
}
}
export { DetailsList };