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-04-09 17:48:19 -07:00
|
|
|
const DocumentList = ({
|
|
|
|
docs,
|
|
|
|
removeDoc,
|
|
|
|
updateDocContent,
|
|
|
|
updateDocTitle,
|
|
|
|
onPaste
|
|
|
|
}: {
|
|
|
|
docs: Document[]
|
|
|
|
updateDocTitle: (i: number) => (title: string) => void
|
|
|
|
updateDocContent: (i: number) => (content: string) => void
|
|
|
|
removeDoc: (i: number) => () => void
|
|
|
|
onPaste: (e: any) => void
|
2022-03-21 22:50:25 -07:00
|
|
|
}) => {
|
2022-04-09 17:48:19 -07:00
|
|
|
const handleOnChange = useCallback(
|
2022-04-09 17:54:08 -07:00
|
|
|
(i: number) => (e: ChangeEvent<HTMLTextAreaElement>) => {
|
2022-04-09 17:48:19 -07:00
|
|
|
updateDocContent(i)(e.target.value)
|
|
|
|
},
|
|
|
|
[updateDocContent]
|
|
|
|
)
|
2022-03-21 22:50:25 -07:00
|
|
|
|
2022-04-09 17:48:19 -07:00
|
|
|
return (
|
|
|
|
<>
|
|
|
|
{docs.map(({ content, id, title }, i) => {
|
|
|
|
return (
|
|
|
|
<DocumentComponent
|
|
|
|
onPaste={onPaste}
|
|
|
|
key={id}
|
|
|
|
remove={removeDoc(i)}
|
|
|
|
setTitle={updateDocTitle(i)}
|
|
|
|
handleOnContentChange={handleOnChange(i)}
|
|
|
|
content={content}
|
|
|
|
title={title}
|
|
|
|
/>
|
|
|
|
)
|
|
|
|
})}
|
|
|
|
</>
|
|
|
|
)
|
2022-03-21 22:50:25 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
export default memo(DocumentList)
|