fix(striker-ui): use key-value instead of array messages in MessageGroup

main
Tsu-ba-me 2 years ago
parent 9e88a44894
commit b4528fdf7e
  1. 53
      striker-ui/components/MessageGroup.tsx

@ -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}</>;

Loading…
Cancel
Save