|
|
@ -1,25 +1,25 @@ |
|
|
|
import { |
|
|
|
import { |
|
|
|
forwardRef, |
|
|
|
forwardRef, |
|
|
|
useCallback, |
|
|
|
useCallback, |
|
|
|
useEffect, |
|
|
|
|
|
|
|
useImperativeHandle, |
|
|
|
useImperativeHandle, |
|
|
|
useMemo, |
|
|
|
useMemo, |
|
|
|
useState, |
|
|
|
useState, |
|
|
|
} from 'react'; |
|
|
|
} from 'react'; |
|
|
|
import { v4 as uuidv4 } from 'uuid'; |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
import MessageBox, { Message, MessageBoxProps } from './MessageBox'; |
|
|
|
import MessageBox, { Message, MessageBoxProps } from './MessageBox'; |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
type Messages = { |
|
|
|
|
|
|
|
[messageKey: string]: Message | undefined; |
|
|
|
|
|
|
|
}; |
|
|
|
|
|
|
|
|
|
|
|
type MessageGroupOptionalProps = { |
|
|
|
type MessageGroupOptionalProps = { |
|
|
|
defaultMessageType?: MessageBoxProps['type']; |
|
|
|
defaultMessageType?: MessageBoxProps['type']; |
|
|
|
}; |
|
|
|
}; |
|
|
|
|
|
|
|
|
|
|
|
type MessageGroupProps = MessageGroupOptionalProps & { |
|
|
|
type MessageGroupProps = MessageGroupOptionalProps; |
|
|
|
count: number; |
|
|
|
|
|
|
|
}; |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
type MessageGroupForwardedRefContent = { |
|
|
|
type MessageGroupForwardedRefContent = { |
|
|
|
setMessage?: (index: number, message?: Message) => void; |
|
|
|
setMessage?: (key: string, message?: Message) => void; |
|
|
|
}; |
|
|
|
}; |
|
|
|
|
|
|
|
|
|
|
|
const MESSAGE_GROUP_DEFAULT_PROPS: Required<MessageGroupOptionalProps> = { |
|
|
|
const MESSAGE_GROUP_DEFAULT_PROPS: Required<MessageGroupOptionalProps> = { |
|
|
@ -31,25 +31,16 @@ const MessageGroup = forwardRef< |
|
|
|
MessageGroupProps |
|
|
|
MessageGroupProps |
|
|
|
>( |
|
|
|
>( |
|
|
|
( |
|
|
|
( |
|
|
|
{ |
|
|
|
{ defaultMessageType = MESSAGE_GROUP_DEFAULT_PROPS.defaultMessageType }, |
|
|
|
count, |
|
|
|
|
|
|
|
defaultMessageType = MESSAGE_GROUP_DEFAULT_PROPS.defaultMessageType, |
|
|
|
|
|
|
|
}, |
|
|
|
|
|
|
|
ref, |
|
|
|
ref, |
|
|
|
) => { |
|
|
|
) => { |
|
|
|
const [messageKeys, setMessageKeys] = useState<string[]>([]); |
|
|
|
const [messages, setMessages] = useState<Messages>({}); |
|
|
|
const [messages, setMessages] = useState<Array<Message | undefined>>([]); |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
const setMessage = useCallback((index: number, message?: Message) => { |
|
|
|
const setMessage = useCallback((key: string, message?: Message) => { |
|
|
|
setMessages((previous) => { |
|
|
|
setMessages((previous) => { |
|
|
|
const result = [...previous]; |
|
|
|
const result = { ...previous }; |
|
|
|
const diff = index + 1 - result.length; |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (diff > 0) { |
|
|
|
result[key] = message; |
|
|
|
result.push(...Array.from({ length: diff }, () => undefined)); |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
result.splice(index, 1, message); |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
return result; |
|
|
|
return result; |
|
|
|
}); |
|
|
|
}); |
|
|
@ -57,7 +48,7 @@ const MessageGroup = forwardRef< |
|
|
|
|
|
|
|
|
|
|
|
const messageElements = useMemo( |
|
|
|
const messageElements = useMemo( |
|
|
|
() => |
|
|
|
() => |
|
|
|
messages.map((message, messageIndex) => { |
|
|
|
Object.entries(messages).map(([messageKey, message]) => { |
|
|
|
let messageElement; |
|
|
|
let messageElement; |
|
|
|
|
|
|
|
|
|
|
|
if (message) { |
|
|
|
if (message) { |
|
|
@ -65,10 +56,7 @@ const MessageGroup = forwardRef< |
|
|
|
message; |
|
|
|
message; |
|
|
|
|
|
|
|
|
|
|
|
messageElement = ( |
|
|
|
messageElement = ( |
|
|
|
<MessageBox |
|
|
|
<MessageBox key={`message-${messageKey}`} type={type}> |
|
|
|
key={`message-${messageKeys[messageIndex]}`} |
|
|
|
|
|
|
|
type={type} |
|
|
|
|
|
|
|
> |
|
|
|
|
|
|
|
{messageChildren} |
|
|
|
{messageChildren} |
|
|
|
</MessageBox> |
|
|
|
</MessageBox> |
|
|
|
); |
|
|
|
); |
|
|
@ -76,22 +64,9 @@ const MessageGroup = forwardRef< |
|
|
|
|
|
|
|
|
|
|
|
return messageElement; |
|
|
|
return messageElement; |
|
|
|
}), |
|
|
|
}), |
|
|
|
[defaultMessageType, messages, messageKeys], |
|
|
|
[defaultMessageType, messages], |
|
|
|
); |
|
|
|
); |
|
|
|
|
|
|
|
|
|
|
|
useEffect(() => { |
|
|
|
|
|
|
|
setMessageKeys((previous) => { |
|
|
|
|
|
|
|
const result = [...previous]; |
|
|
|
|
|
|
|
const diff = count - result.length; |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (diff > 0) { |
|
|
|
|
|
|
|
result.push(...Array.from({ length: diff }, () => uuidv4())); |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
return result; |
|
|
|
|
|
|
|
}); |
|
|
|
|
|
|
|
}, [count]); |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
useImperativeHandle(ref, () => ({ setMessage }), [setMessage]); |
|
|
|
useImperativeHandle(ref, () => ({ setMessage }), [setMessage]); |
|
|
|
|
|
|
|
|
|
|
|
return <>{messageElements}</>; |
|
|
|
return <>{messageElements}</>; |
|
|
|