-
Notifications
You must be signed in to change notification settings - Fork 92
/
Copy pathpreload.js
123 lines (97 loc) · 4.43 KB
/
preload.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
const { ipcRenderer } = require('electron');
document.addEventListener("DOMContentLoaded", function () {
// mini-browser setup
const urlInput = document.getElementById('urlInput');
const webview = document.getElementById('webview');
document.getElementById('backButton').addEventListener('click', () => {
webview.send('navigate-webview', 'goBack');
});
document.getElementById('forwardButton').addEventListener('click', () => {
webview.send('navigate-webview', 'goForward');
});
document.getElementById('reloadButton').addEventListener('click', () => {
webview.send('navigate-webview', 'reload');
});
urlInput.addEventListener('keypress', (e) => {
if (e.key === 'Enter') {
webview.send('navigate-webview', 'loadURL', urlInput.value);
}
});
webview.addEventListener('will-navigate', (event) => {
console.log(event);
urlInput.value = event.url;
});
ipcRenderer.on('update-url', (event, url) => {
urlInput.value = url;
});
webview.addEventListener('dom-ready', () => {
console.log(webview.getWebContentsId());
ipcRenderer.send('webview-ready', webview.getWebContentsId());
});
// Agent stuff
const inputElement = document.querySelector('input[type="text"]');
const sendButton = document.querySelector('button#send');
const chatContainer = document.querySelector('#chat-container');
const thinkingIndicator = document.createElement('div');
thinkingIndicator.classList.add('mb-2', 'mr-8', 'hidden');
thinkingIndicator.innerHTML = `
<div class="py-2 px-3 bg-transparent text-indigo-200 rounded-lg break-words">
🧠 Thinking...
</div>
`;
ipcRenderer.on('thinking', (event, isThinking) => {
if (isThinking) {
chatContainer.appendChild(thinkingIndicator);
thinkingIndicator.classList.remove('hidden');
} else {
thinkingIndicator.classList.add('hidden');
}
requestAnimationFrame(() => {
chatContainer.scrollTop = chatContainer.scrollHeight;
});
});
document.querySelector('#screenshot').addEventListener('click', () => ipcRenderer.send('screenshot'));
document.querySelector('#continue').addEventListener('click', () => ipcRenderer.send('continue'));
document.querySelector('#execute').addEventListener('click', () => ipcRenderer.send('execute'));
document.querySelector('#mark').addEventListener('click', () => webview.send('observer', 'screenshot-start'));
document.querySelector('#unmark').addEventListener('click', () => webview.send('observer', 'screenshot-end'));
// document.querySelector('#export').addEventListener('click', () => ipcRenderer.send('export'));
// document.querySelector('#randomize').addEventListener('click', () => ipcRenderer.send('randomize'));
ipcRenderer.on('end_turn', (event, content) => {
if (thinkingIndicator.parentNode === chatContainer) {
chatContainer.removeChild(thinkingIndicator);
}
const messageDiv = document.createElement('div');
messageDiv.className = "py-2 px-3 bg-indigo-700 text-indigo-200 rounded-lg shadow-md break-words";
messageDiv.textContent = content;
const containerDiv = document.createElement('div');
containerDiv.className = "mb-2 mr-8";
containerDiv.appendChild(messageDiv);
chatContainer.appendChild(containerDiv);
chatContainer.appendChild(thinkingIndicator);
chatContainer.scrollTop = chatContainer.scrollHeight;
});
function sendMessage() {
const userMessage = inputElement.value;
if (!userMessage.trim()) return;
// Append user's message
chatContainer.innerHTML += `
<div class="mb-2 ml-8">
<div class="py-2 px-3 bg-zinc-200 text-zinc-700 rounded-lg shadow-md break-words">
${userMessage}
</div>
</div>
`;
// Clear the input after sending the message
inputElement.value = '';
// Scroll to the bottom to show the newest messages
chatContainer.scrollTop = chatContainer.scrollHeight;
ipcRenderer.send('send', userMessage);
}
inputElement.addEventListener('keypress', function (e) {
if (e.key === 'Enter') {
sendMessage();
}
});
sendButton.addEventListener('click', sendMessage);
});