{#key currentMessageId} {#each Object.keys(groupedMessages) as modelIdx} {#if groupedMessagesIdx[modelIdx] !== undefined && groupedMessages[modelIdx].messages.length > 0} {@const message = groupedMessages[modelIdx].messages[groupedMessagesIdx[modelIdx]]}
{ if (currentMessageId != message.id) { currentMessageId = message.id; let messageId = message.id; console.log(messageId); // let messageChildrenIds = history.messages[messageId].childrenIds; while (messageChildrenIds.length !== 0) { messageId = messageChildrenIds.at(-1); messageChildrenIds = history.messages[messageId].childrenIds; } history.currentId = messageId; dispatch('change'); } }} > {#key history.currentId} {#if message} m.id)} isLastMessage={true} {updateChatMessages} {confirmEditResponseMessage} showPreviousMessage={() => showPreviousMessage(modelIdx)} showNextMessage={() => showNextMessage(modelIdx)} {readOnly} {rateMessage} {copyToClipboard} {continueGeneration} regenerateResponse={async (message) => { regenerateResponse(message); await tick(); groupedMessagesIdx[modelIdx] = groupedMessages[modelIdx].messages.length - 1; }} on:save={async (e) => { console.log('save', e); const message = e.detail; history.messages[message.id] = message; await updateChatById(localStorage.token, chatId, { messages: messages, history: history }); }} /> {/if} {/key}
{/if} {/each} {/key}
{#if !readOnly} {#if !parentMessage?.childrenIds.map((id) => history.messages[id]).find((m) => !m.done)}
{/if} {/if}