We read every piece of feedback, and take your input very seriously.
To see all available qualifiers, see our documentation.
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Suggested by Claude Sonnet 3.5:
NodeProcessor
public interface NodeProcessor { JPanel processNode(); }
public class TextNodeProcessor implements NodeProcessor { private final Node node; public TextNodeProcessor(Node node) { this.node = node; } @Override public JPanel processNode() { // Process text node // Return a JPanel with the processed content } } public class CodeBlockNodeProcessor implements NodeProcessor { private final FencedCodeBlock codeBlock; private final ChatMessageContext chatMessageContext; public CodeBlockNodeProcessor(FencedCodeBlock codeBlock, ChatMessageContext chatMessageContext) { this.codeBlock = codeBlock; this.chatMessageContext = chatMessageContext; } @Override public JPanel processNode() { // Process code block // Return a JPanel with the processed content, including syntax highlighting and buttons } }
NodeProcessorFactory
public class NodeProcessorFactory { public static NodeProcessor createProcessor(Node node, ChatMessageContext chatMessageContext) { if (node instanceof FencedCodeBlock) { return new CodeBlockNodeProcessor((FencedCodeBlock) node, chatMessageContext); } else { return new TextNodeProcessor(node); } } }
ChatResponsePanel
public class ChatResponsePanel extends BackgroundPanel { private final ChatMessageContext chatMessageContext; public ChatResponsePanel(ChatMessageContext chatMessageContext) { super(chatMessageContext.getName()); this.chatMessageContext = chatMessageContext; setLayout(new BoxLayout(this, BoxLayout.Y_AXIS)); add(new ResponseHeaderPanel(chatMessageContext)); addResponsePane(chatMessageContext); if (chatMessageContext.hasFiles()) { addFileListPanel(); } if (DevoxxGenieStateService.getInstance().getShowExecutionTime()) { addExecutionInfoPanel(); } } private void addResponsePane(ChatMessageContext chatMessageContext) { String markDownResponse = chatMessageContext.getAiMessage().text(); Node document = Parser.builder().build().parse(markDownResponse); Node node = document.getFirstChild(); while (node != null) { NodeProcessor processor = NodeProcessorFactory.createProcessor(node, chatMessageContext); JPanel panel = processor.processNode(); add(panel); node = node.getNext(); } } private void addFileListPanel() { List<VirtualFile> files = FileListManager.getInstance().getFiles(); ExpandablePanel fileListPanel = new ExpandablePanel(chatMessageContext, files); add(fileListPanel); } private void addExecutionInfoPanel() { // Add execution time, token usage and cost information JPanel infoPanel = new ExecutionInfoPanel(chatMessageContext); add(infoPanel); } }
ExecutionInfoPanel
public class ExecutionInfoPanel extends JPanel { public ExecutionInfoPanel(ChatMessageContext chatMessageContext) { setLayout(new FlowLayout(FlowLayout.LEFT)); setOpaque(false); TokenUsage tokenUsage = chatMessageContext.getTokenUsage(); if (tokenUsage != null) { String cost = ""; if (DefaultLLMSettingsUtil.isApiKeyBasedProvider(chatMessageContext.getLanguageModel().getProvider())) { cost = String.format("- %.5f $", chatMessageContext.getCost()); } NumberFormat numberFormat = NumberFormat.getNumberInstance(Locale.getDefault()); String formattedInputTokens = numberFormat.format(tokenUsage.inputTokenCount()); String formattedOutputTokens = numberFormat.format(tokenUsage.outputTokenCount()); String infoText = String.format("ϟ %.2fs - Tokens ↑ %s ↓️ %s %s", chatMessageContext.getExecutionTimeMs() / 1000.0, formattedInputTokens, formattedOutputTokens, cost); JLabel infoLabel = new JLabel(infoText); infoLabel.setForeground(JBColor.GRAY); infoLabel.setFont(infoLabel.getFont().deriveFont(12f)); add(infoLabel); } } }
This refactoring brings several benefits:
To fully implement this refactoring, you'll need to:
TextNodeProcessor
CodeBlockNodeProcessor
ChatMessageContext
This refactored provides a more modular and maintainable structure for handling different types of content in the response panel.
The text was updated successfully, but these errors were encountered:
Hello @stephanj i'm rollbacking the modification here please check everything is back to an "ok" situation
Meanwhile i'll keep working on this issue until the UI result is perfect. I'll keep you in touch
Apologize 🙏
Sorry, something went wrong.
No branches or pull requests
Suggested by Claude Sonnet 3.5:
NodeProcessor
interface:NodeProcessorFactory
:ChatResponsePanel
:ExecutionInfoPanel
to encapsulate the execution information:This refactoring brings several benefits:
ChatResponsePanel
is now more focused on composition and layout, delegating the processing of content to specialized classes.To fully implement this refactoring, you'll need to:
TextNodeProcessor
andCodeBlockNodeProcessor
to handle the specific rendering logic for each type of content.ChatMessageContext
contains all necessary information for rendering (like the project instance for opening files).ChatResponsePanel
to work with this new structure.This refactored provides a more modular and maintainable structure for handling different types of content in the response panel.
The text was updated successfully, but these errors were encountered: