@uniqueli/openwork 0.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -0,0 +1,170 @@
1
+ "use strict";
2
+ const electron = require("electron");
3
+ const electronAPI = {
4
+ ipcRenderer: {
5
+ send: (channel, ...args) => electron.ipcRenderer.send(channel, ...args),
6
+ on: (channel, listener) => {
7
+ electron.ipcRenderer.on(channel, (_event, ...args) => listener(...args));
8
+ return () => electron.ipcRenderer.removeListener(channel, listener);
9
+ },
10
+ once: (channel, listener) => {
11
+ electron.ipcRenderer.once(channel, (_event, ...args) => listener(...args));
12
+ },
13
+ invoke: (channel, ...args) => electron.ipcRenderer.invoke(channel, ...args)
14
+ },
15
+ process: {
16
+ platform: process.platform,
17
+ versions: process.versions
18
+ }
19
+ };
20
+ const api = {
21
+ agent: {
22
+ // Send message and receive events via callback
23
+ invoke: (threadId, message, onEvent) => {
24
+ const channel = `agent:stream:${threadId}`;
25
+ const handler = (_, data) => {
26
+ onEvent(data);
27
+ if (data.type === "done" || data.type === "error") {
28
+ electron.ipcRenderer.removeListener(channel, handler);
29
+ }
30
+ };
31
+ electron.ipcRenderer.on(channel, handler);
32
+ electron.ipcRenderer.send("agent:invoke", { threadId, message });
33
+ return () => {
34
+ electron.ipcRenderer.removeListener(channel, handler);
35
+ };
36
+ },
37
+ // Stream agent events for useStream transport
38
+ streamAgent: (threadId, message, command, onEvent) => {
39
+ const channel = `agent:stream:${threadId}`;
40
+ const handler = (_, data) => {
41
+ onEvent(data);
42
+ if (data.type === "done" || data.type === "error") {
43
+ electron.ipcRenderer.removeListener(channel, handler);
44
+ }
45
+ };
46
+ electron.ipcRenderer.on(channel, handler);
47
+ if (command) {
48
+ electron.ipcRenderer.send("agent:resume", { threadId, command });
49
+ } else {
50
+ electron.ipcRenderer.send("agent:invoke", { threadId, message });
51
+ }
52
+ return () => {
53
+ electron.ipcRenderer.removeListener(channel, handler);
54
+ };
55
+ },
56
+ interrupt: (threadId, decision, onEvent) => {
57
+ const channel = `agent:stream:${threadId}`;
58
+ const handler = (_, data) => {
59
+ onEvent?.(data);
60
+ if (data.type === "done" || data.type === "error") {
61
+ electron.ipcRenderer.removeListener(channel, handler);
62
+ }
63
+ };
64
+ electron.ipcRenderer.on(channel, handler);
65
+ electron.ipcRenderer.send("agent:interrupt", { threadId, decision });
66
+ return () => {
67
+ electron.ipcRenderer.removeListener(channel, handler);
68
+ };
69
+ },
70
+ cancel: (threadId) => {
71
+ return electron.ipcRenderer.invoke("agent:cancel", { threadId });
72
+ }
73
+ },
74
+ threads: {
75
+ list: () => {
76
+ return electron.ipcRenderer.invoke("threads:list");
77
+ },
78
+ get: (threadId) => {
79
+ return electron.ipcRenderer.invoke("threads:get", threadId);
80
+ },
81
+ create: (metadata) => {
82
+ return electron.ipcRenderer.invoke("threads:create", metadata);
83
+ },
84
+ update: (threadId, updates) => {
85
+ return electron.ipcRenderer.invoke("threads:update", { threadId, updates });
86
+ },
87
+ delete: (threadId) => {
88
+ return electron.ipcRenderer.invoke("threads:delete", threadId);
89
+ },
90
+ getHistory: (threadId) => {
91
+ return electron.ipcRenderer.invoke("threads:history", threadId);
92
+ },
93
+ generateTitle: (message) => {
94
+ return electron.ipcRenderer.invoke("threads:generateTitle", message);
95
+ }
96
+ },
97
+ models: {
98
+ list: () => {
99
+ return electron.ipcRenderer.invoke("models:list");
100
+ },
101
+ listProviders: () => {
102
+ return electron.ipcRenderer.invoke("models:listProviders");
103
+ },
104
+ getDefault: () => {
105
+ return electron.ipcRenderer.invoke("models:getDefault");
106
+ },
107
+ setDefault: (modelId) => {
108
+ return electron.ipcRenderer.invoke("models:setDefault", modelId);
109
+ },
110
+ setApiKey: (provider, apiKey) => {
111
+ return electron.ipcRenderer.invoke("models:setApiKey", { provider, apiKey });
112
+ },
113
+ getApiKey: (provider) => {
114
+ return electron.ipcRenderer.invoke("models:getApiKey", provider);
115
+ },
116
+ deleteApiKey: (provider) => {
117
+ return electron.ipcRenderer.invoke("models:deleteApiKey", provider);
118
+ },
119
+ getCustomApiConfig: () => {
120
+ return electron.ipcRenderer.invoke("models:getCustomApiConfig");
121
+ },
122
+ setCustomApiConfig: (config) => {
123
+ return electron.ipcRenderer.invoke("models:setCustomApiConfig", config);
124
+ },
125
+ deleteCustomApiConfig: () => {
126
+ return electron.ipcRenderer.invoke("models:deleteCustomApiConfig");
127
+ }
128
+ },
129
+ workspace: {
130
+ get: (threadId) => {
131
+ return electron.ipcRenderer.invoke("workspace:get", threadId);
132
+ },
133
+ set: (threadId, path) => {
134
+ return electron.ipcRenderer.invoke("workspace:set", { threadId, path });
135
+ },
136
+ select: (threadId) => {
137
+ return electron.ipcRenderer.invoke("workspace:select", threadId);
138
+ },
139
+ loadFromDisk: (threadId) => {
140
+ return electron.ipcRenderer.invoke("workspace:loadFromDisk", { threadId });
141
+ },
142
+ readFile: (threadId, filePath) => {
143
+ return electron.ipcRenderer.invoke("workspace:readFile", { threadId, filePath });
144
+ },
145
+ readBinaryFile: (threadId, filePath) => {
146
+ return electron.ipcRenderer.invoke("workspace:readBinaryFile", { threadId, filePath });
147
+ },
148
+ // Listen for file changes in the workspace
149
+ onFilesChanged: (callback) => {
150
+ const handler = (_, data) => {
151
+ callback(data);
152
+ };
153
+ electron.ipcRenderer.on("workspace:files-changed", handler);
154
+ return () => {
155
+ electron.ipcRenderer.removeListener("workspace:files-changed", handler);
156
+ };
157
+ }
158
+ }
159
+ };
160
+ if (process.contextIsolated) {
161
+ try {
162
+ electron.contextBridge.exposeInMainWorld("electron", electronAPI);
163
+ electron.contextBridge.exposeInMainWorld("api", api);
164
+ } catch (error) {
165
+ console.error(error);
166
+ }
167
+ } else {
168
+ window.electron = electronAPI;
169
+ window.api = api;
170
+ }