diff --git a/webview-ui/src/components/chat/BrowserSessionRow.tsx b/webview-ui/src/components/chat/BrowserSessionRow.tsx index 17b3fb3..e9f6d09 100644 --- a/webview-ui/src/components/chat/BrowserSessionRow.tsx +++ b/webview-ui/src/components/chat/BrowserSessionRow.tsx @@ -1,5 +1,5 @@ import deepEqual from "fast-deep-equal" -import React, { memo, useEffect, useRef } from "react" +import React, { memo, useEffect, useRef, useState } from "react" import { useSize } from "react-use" import { BrowserActionResult, ClineMessage, ClineSayBrowserAction } from "../../../../src/shared/ExtensionMessage" import { vscode } from "../../utils/vscode" @@ -16,13 +16,113 @@ interface BrowserSessionRowProps { onHeightChange: (isTaller: boolean) => void } +/* + +- console logs will be aggregate up to that current page +*/ + const BrowserSessionRow = memo((props: BrowserSessionRowProps) => { const { messages, isLast, onHeightChange } = props const prevHeightRef = useRef(0) + const [consoleLogsExpanded, setConsoleLogsExpanded] = useState(false) + const consoleLogs = "console logs\nhere\n..." + const [browserSessionRow, { height }] = useSize(

Browser Session Group

+ +
+
+ {"https://example.com/thisisalongurl/asdfasfdasdf?asdfasdfasf"} +
+
+ {/*
*/} +
+ +
+ +
+
+
{ + if (consoleLogs) { + setConsoleLogsExpanded(!consoleLogsExpanded) + } + }} + style={{ + display: "flex", + alignItems: "center", + gap: "4px", + width: "100%", + justifyContent: "flex-start", + cursor: consoleLogs ? "pointer" : "default", + opacity: consoleLogs ? 1 : 0.5, + padding: `8px 8px ${consoleLogsExpanded ? 0 : 8}px 8px`, + }}> + + Console Logs +
+ {consoleLogsExpanded && } +
+
+ {messages.map((message, index) => ( ))} @@ -156,4 +256,22 @@ const BrowserSessionRowContent = ({ } } +const BrowserCursor: React.FC<{ style?: React.CSSProperties }> = ({ style }) => { + // (can't use svgs in vsc extensions) + const cursorBase64 = + "" + + return ( + cursor + ) +} + export default BrowserSessionRow