2022-03-21 22:50:25 -07:00
|
|
|
import type { Document } from "@lib/types"
|
2022-03-22 21:18:26 -07:00
|
|
|
import DocumentComponent from "@components/edit-document"
|
2022-03-21 22:50:25 -07:00
|
|
|
import { ChangeEvent, memo, useCallback } from "react"
|
|
|
|
|
2022-03-23 16:42:56 -07:00
|
|
|
const DocumentList = ({ docs, removeDoc, updateDocContent, updateDocTitle, onPaste }: {
|
2022-03-21 22:50:25 -07:00
|
|
|
docs: Document[],
|
|
|
|
updateDocTitle: (i: number) => (title: string) => void
|
|
|
|
updateDocContent: (i: number) => (content: string) => void
|
|
|
|
removeDoc: (i: number) => () => void
|
2022-03-23 16:42:56 -07:00
|
|
|
onPaste: (e: any) => void
|
2022-03-21 22:50:25 -07:00
|
|
|
}) => {
|
|
|
|
const handleOnChange = useCallback((i) => (e: ChangeEvent<HTMLTextAreaElement>) => {
|
|
|
|
updateDocContent(i)(e.target.value)
|
|
|
|
}, [updateDocContent])
|
|
|
|
|
|
|
|
return (<>{
|
|
|
|
docs.map(({ content, id, title }, i) => {
|
|
|
|
return (
|
|
|
|
<DocumentComponent
|
2022-03-23 16:42:56 -07:00
|
|
|
onPaste={onPaste}
|
2022-03-21 22:50:25 -07:00
|
|
|
key={id}
|
|
|
|
remove={removeDoc(i)}
|
|
|
|
setContent={updateDocContent(i)}
|
|
|
|
setTitle={updateDocTitle(i)}
|
|
|
|
handleOnContentChange={handleOnChange(i)}
|
|
|
|
content={content}
|
|
|
|
title={title}
|
|
|
|
/>
|
|
|
|
)
|
|
|
|
})
|
|
|
|
}
|
|
|
|
</>)
|
|
|
|
}
|
|
|
|
|
|
|
|
export default memo(DocumentList)
|