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

79 lines
2.6 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;
noDefaultStyle?: boolean;
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>) {
const classList: string[] = [];
if (!column.noDefaultStyle) {
classList.push("details-list-value");
}
if (column.className) {
classList.push(column.className);
}
return <div
className={classList.join(" ")}
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 };