obi-sdk 0.1.2 → 0.1.4

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,234 @@
1
+ import { m as mitt } from "./mitt-3c1f932d.js";
2
+ import { S as SDKState, O as ObiSDKConfigSchema, E as EventType, a as ObiWidget } from "./obi-widget-0d63936f.js";
3
+ class ObiSDK {
4
+ constructor(config = {}) {
5
+ this.state = SDKState.READY;
6
+ this.emitter = mitt();
7
+ this.voiceEnabled = false;
8
+ this.screenCaptureEnabled = false;
9
+ this.config = ObiSDKConfigSchema.parse(config);
10
+ if (this.config.debug) {
11
+ console.log("ObiSDK initialized with config:", this.config);
12
+ }
13
+ }
14
+ async init() {
15
+ try {
16
+ if (this.config.enableVoice) {
17
+ await this.initVoice();
18
+ }
19
+ if (this.config.enableScreenCapture) {
20
+ await this.initScreenCapture();
21
+ }
22
+ this.setState(SDKState.READY);
23
+ this.emitter.emit(EventType.READY);
24
+ if (this.config.debug) {
25
+ console.log("ObiSDK ready");
26
+ }
27
+ } catch (error) {
28
+ const sdkError = {
29
+ code: "init_failed",
30
+ message: "Failed to initialize SDK",
31
+ details: error
32
+ };
33
+ this.handleError(sdkError);
34
+ }
35
+ }
36
+ async initVoice() {
37
+ if (!window.navigator.mediaDevices || !window.navigator.mediaDevices.getUserMedia) {
38
+ throw new Error("Voice recording not supported in this browser");
39
+ }
40
+ try {
41
+ await window.navigator.mediaDevices.getUserMedia({ audio: true });
42
+ this.voiceEnabled = true;
43
+ if (this.config.debug) {
44
+ console.log("Voice capabilities initialized");
45
+ }
46
+ } catch (error) {
47
+ throw new Error(`Microphone access denied: ${error}`);
48
+ }
49
+ }
50
+ async initScreenCapture() {
51
+ if (!window.navigator.mediaDevices || !window.navigator.mediaDevices.getDisplayMedia) {
52
+ throw new Error("Screen capture not supported in this browser");
53
+ }
54
+ this.screenCaptureEnabled = true;
55
+ if (this.config.debug) {
56
+ console.log("Screen capture capabilities initialized");
57
+ }
58
+ }
59
+ /**
60
+ * Set the SDK state and emit state change event
61
+ */
62
+ setState(newState) {
63
+ this.state = newState;
64
+ this.emitter.emit(EventType.STATE_CHANGE, newState);
65
+ }
66
+ /**
67
+ * Handle SDK errors
68
+ */
69
+ handleError(error) {
70
+ this.setState(SDKState.ERROR);
71
+ this.emitter.emit(EventType.ERROR, error);
72
+ if (this.config.debug) {
73
+ console.error("ObiSDK error:", error);
74
+ }
75
+ }
76
+ /**
77
+ * Start voice recording
78
+ */
79
+ async startVoiceRecording() {
80
+ if (!this.voiceEnabled) {
81
+ this.handleError({
82
+ code: "voice_disabled",
83
+ message: "Voice recording is not enabled or available"
84
+ });
85
+ return;
86
+ }
87
+ try {
88
+ this.setState(SDKState.AGENT_SPEAKING);
89
+ this.emitter.emit(EventType.VOICE_START);
90
+ if (this.config.debug) {
91
+ console.log("Voice recording started");
92
+ }
93
+ } catch (error) {
94
+ this.handleError({
95
+ code: "voice_start_failed",
96
+ message: "Failed to start voice recording",
97
+ details: error
98
+ });
99
+ }
100
+ }
101
+ /**
102
+ * Stop voice recording
103
+ */
104
+ async stopVoiceRecording() {
105
+ if (this.state === SDKState.READY) {
106
+ return { transcript: void 0 };
107
+ }
108
+ try {
109
+ const result = { transcript: "Sample transcript" };
110
+ this.setState(SDKState.READY);
111
+ this.emitter.emit(EventType.VOICE_STOP, result);
112
+ if (this.config.debug) {
113
+ console.log("Voice recording stopped:", result);
114
+ }
115
+ return result;
116
+ } catch (error) {
117
+ this.handleError({
118
+ code: "voice_stop_failed",
119
+ message: "Failed to stop voice recording",
120
+ details: error
121
+ });
122
+ return { transcript: void 0 };
123
+ }
124
+ }
125
+ /**
126
+ * Start screen capture
127
+ */
128
+ async startScreenCapture() {
129
+ if (!this.screenCaptureEnabled) {
130
+ this.handleError({
131
+ code: "screen_capture_disabled",
132
+ message: "Screen capture is not enabled or available"
133
+ });
134
+ return;
135
+ }
136
+ try {
137
+ this.setState(SDKState.AGENT_SPEAKING);
138
+ this.emitter.emit(EventType.SCREEN_CAPTURE_START);
139
+ if (this.config.debug) {
140
+ console.log("Screen capture started");
141
+ }
142
+ } catch (error) {
143
+ this.handleError({
144
+ code: "screen_capture_start_failed",
145
+ message: "Failed to start screen capture",
146
+ details: error
147
+ });
148
+ }
149
+ }
150
+ /**
151
+ * Stop screen capture
152
+ */
153
+ async stopScreenCapture() {
154
+ if (this.state === SDKState.READY) {
155
+ return { screenshot: void 0 };
156
+ }
157
+ try {
158
+ const result = { screenshot: "data:image/png;base64,..." };
159
+ this.setState(SDKState.READY);
160
+ this.emitter.emit(EventType.SCREEN_CAPTURE_STOP, result);
161
+ if (this.config.debug) {
162
+ console.log("Screen capture stopped");
163
+ }
164
+ return result;
165
+ } catch (error) {
166
+ this.handleError({
167
+ code: "screen_capture_stop_failed",
168
+ message: "Failed to stop screen capture",
169
+ details: error
170
+ });
171
+ return { screenshot: void 0 };
172
+ }
173
+ }
174
+ /**
175
+ * Subscribe to SDK events
176
+ */
177
+ on(event, handler) {
178
+ this.emitter.on(event, handler);
179
+ }
180
+ /**
181
+ * Unsubscribe from SDK events
182
+ */
183
+ off(event, handler) {
184
+ this.emitter.off(event, handler);
185
+ }
186
+ /**
187
+ * Get current SDK state
188
+ */
189
+ getState() {
190
+ return this.state;
191
+ }
192
+ /**
193
+ * Cleanup and dispose SDK resources
194
+ */
195
+ dispose() {
196
+ this.emitter.all.clear();
197
+ if (this.config.debug) {
198
+ console.log("ObiSDK disposed");
199
+ }
200
+ }
201
+ }
202
+ const registerWidget = () => {
203
+ if (!customElements.get("obi-widget")) {
204
+ customElements.define("obi-widget", ObiWidget);
205
+ }
206
+ };
207
+ class ObiAssistant {
208
+ /**
209
+ * Initialize the Obi Widget with the provided configuration
210
+ * This creates and mounts the widget to the page
211
+ */
212
+ static init(config) {
213
+ registerWidget();
214
+ const widget = document.createElement("obi-widget");
215
+ if (config.apiKey) {
216
+ widget.apiKey = config.apiKey;
217
+ }
218
+ if (config.position) {
219
+ widget.position = config.position;
220
+ }
221
+ if (config.user) {
222
+ widget.user = config.user;
223
+ }
224
+ window.obiWidgetConfig = config;
225
+ document.body.appendChild(widget);
226
+ console.log("Obi Widget initialized and mounted");
227
+ return widget;
228
+ }
229
+ }
230
+ export {
231
+ ObiSDK as O,
232
+ ObiAssistant as a
233
+ };
234
+ //# sourceMappingURL=assistant-5a47c1b4.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"assistant-5a47c1b4.js","sources":["../../../src/core/sdk.ts","../../../src/core/assistant.ts"],"sourcesContent":["import mitt from \"mitt\"\n\nimport { EventType, ObiError, ObiSDKConfig, ObiSDKConfigSchema, SDKState } from \"./types\"\n\ntype Events = {\n [EventType.READY]: void\n [EventType.ERROR]: ObiError\n [EventType.VOICE_START]: void\n [EventType.VOICE_STOP]: { transcript?: string }\n [EventType.SCREEN_CAPTURE_START]: void\n [EventType.SCREEN_CAPTURE_STOP]: { screenshot?: string }\n [EventType.STATE_CHANGE]: SDKState\n}\n\nexport class ObiSDK {\n private config: ObiSDKConfig\n private state: SDKState = SDKState.READY\n private emitter = mitt<Events>()\n private voiceEnabled = false\n private screenCaptureEnabled = false\n\n constructor(config: Partial<ObiSDKConfig> = {}) {\n this.config = ObiSDKConfigSchema.parse(config)\n\n if (this.config.debug) {\n console.log(\"ObiSDK initialized with config:\", this.config)\n }\n }\n\n async init(): Promise<void> {\n try {\n if (this.config.enableVoice) {\n await this.initVoice()\n }\n\n if (this.config.enableScreenCapture) {\n await this.initScreenCapture()\n }\n\n this.setState(SDKState.READY)\n this.emitter.emit(EventType.READY)\n\n if (this.config.debug) {\n console.log(\"ObiSDK ready\")\n }\n } catch (error) {\n const sdkError: ObiError = {\n code: \"init_failed\",\n message: \"Failed to initialize SDK\",\n details: error,\n }\n this.handleError(sdkError)\n }\n }\n\n private async initVoice(): Promise<void> {\n // Check if browser supports required voice APIs\n if (!window.navigator.mediaDevices || !window.navigator.mediaDevices.getUserMedia) {\n throw new Error(\"Voice recording not supported in this browser\")\n }\n\n try {\n // Request microphone permissions\n await window.navigator.mediaDevices.getUserMedia({ audio: true })\n this.voiceEnabled = true\n\n if (this.config.debug) {\n console.log(\"Voice capabilities initialized\")\n }\n } catch (error) {\n throw new Error(`Microphone access denied: ${error}`)\n }\n }\n\n private async initScreenCapture(): Promise<void> {\n // Check if browser supports required screen capture APIs\n if (!window.navigator.mediaDevices || !window.navigator.mediaDevices.getDisplayMedia) {\n throw new Error(\"Screen capture not supported in this browser\")\n }\n\n this.screenCaptureEnabled = true\n\n if (this.config.debug) {\n console.log(\"Screen capture capabilities initialized\")\n }\n }\n\n /**\n * Set the SDK state and emit state change event\n */\n private setState(newState: SDKState): void {\n this.state = newState\n this.emitter.emit(EventType.STATE_CHANGE, newState)\n }\n\n /**\n * Handle SDK errors\n */\n private handleError(error: ObiError): void {\n this.setState(SDKState.ERROR)\n this.emitter.emit(EventType.ERROR, error)\n\n if (this.config.debug) {\n console.error(\"ObiSDK error:\", error)\n }\n }\n\n /**\n * Start voice recording\n */\n async startVoiceRecording(): Promise<void> {\n if (!this.voiceEnabled) {\n this.handleError({\n code: \"voice_disabled\",\n message: \"Voice recording is not enabled or available\",\n })\n return\n }\n\n try {\n this.setState(SDKState.AGENT_SPEAKING)\n this.emitter.emit(EventType.VOICE_START)\n\n if (this.config.debug) {\n console.log(\"Voice recording started\")\n }\n } catch (error) {\n this.handleError({\n code: \"voice_start_failed\",\n message: \"Failed to start voice recording\",\n details: error,\n })\n }\n }\n\n /**\n * Stop voice recording\n */\n async stopVoiceRecording(): Promise<{ transcript?: string }> {\n if (this.state === SDKState.READY) {\n return { transcript: undefined }\n }\n\n try {\n const result = { transcript: \"Sample transcript\" } // Placeholder for real implementation\n\n this.setState(SDKState.READY)\n this.emitter.emit(EventType.VOICE_STOP, result)\n\n if (this.config.debug) {\n console.log(\"Voice recording stopped:\", result)\n }\n\n return result\n } catch (error) {\n this.handleError({\n code: \"voice_stop_failed\",\n message: \"Failed to stop voice recording\",\n details: error,\n })\n return { transcript: undefined }\n }\n }\n\n /**\n * Start screen capture\n */\n async startScreenCapture(): Promise<void> {\n if (!this.screenCaptureEnabled) {\n this.handleError({\n code: \"screen_capture_disabled\",\n message: \"Screen capture is not enabled or available\",\n })\n return\n }\n\n try {\n this.setState(SDKState.AGENT_SPEAKING)\n this.emitter.emit(EventType.SCREEN_CAPTURE_START)\n\n if (this.config.debug) {\n console.log(\"Screen capture started\")\n }\n } catch (error) {\n this.handleError({\n code: \"screen_capture_start_failed\",\n message: \"Failed to start screen capture\",\n details: error,\n })\n }\n }\n\n /**\n * Stop screen capture\n */\n async stopScreenCapture(): Promise<{ screenshot?: string }> {\n if (this.state === SDKState.READY) {\n return { screenshot: undefined }\n }\n\n try {\n const result = { screenshot: \"data:image/png;base64,...\" } // Placeholder for real implementation\n\n this.setState(SDKState.READY)\n this.emitter.emit(EventType.SCREEN_CAPTURE_STOP, result)\n\n if (this.config.debug) {\n console.log(\"Screen capture stopped\")\n }\n\n return result\n } catch (error) {\n this.handleError({\n code: \"screen_capture_stop_failed\",\n message: \"Failed to stop screen capture\",\n details: error,\n })\n return { screenshot: undefined }\n }\n }\n\n /**\n * Subscribe to SDK events\n */\n on<E extends EventType>(event: E, handler: (data: Events[E]) => void): void {\n this.emitter.on(event, handler as any)\n }\n\n /**\n * Unsubscribe from SDK events\n */\n off<E extends EventType>(event: E, handler: (data: Events[E]) => void): void {\n this.emitter.off(event, handler as any)\n }\n\n /**\n * Get current SDK state\n */\n getState(): SDKState {\n return this.state\n }\n\n /**\n * Cleanup and dispose SDK resources\n */\n dispose(): void {\n this.emitter.all.clear()\n\n if (this.config.debug) {\n console.log(\"ObiSDK disposed\")\n }\n }\n}\n","/**\n * ObiAssistant provides a simple way to initialize the Obi Widget\n * with a single method call.\n */\n\nimport { ObiWidget } from \"../ui/components/obi-widget\"\n\n// Define the configuration interface\nexport interface ObiAssistantConfig {\n apiKey: string\n position?: \"bottom-right\" | \"bottom-left\" | \"top-right\" | \"top-left\"\n user?: {\n id: string\n email?: string\n metadata?: Record<string, any>\n }\n}\n\n// Register the custom element if it hasn't been registered yet\nconst registerWidget = () => {\n if (!customElements.get(\"obi-widget\")) {\n customElements.define(\"obi-widget\", ObiWidget)\n }\n}\n\n/**\n * ObiAssistant class with static init method for easier initialization\n */\nexport class ObiAssistant {\n /**\n * Initialize the Obi Widget with the provided configuration\n * This creates and mounts the widget to the page\n */\n static init(config: ObiAssistantConfig): HTMLElement {\n // Make sure the widget is defined\n registerWidget()\n\n // Create widget instance\n const widget = document.createElement(\"obi-widget\") as ObiWidget\n\n // Set API key\n if (config.apiKey) {\n widget.apiKey = config.apiKey\n }\n\n // Set position if provided\n if (config.position) {\n widget.position = config.position\n }\n\n // Set user information if provided\n if (config.user) {\n widget.user = config.user\n }\n\n // Save config for access from anywhere\n window.obiWidgetConfig = config\n\n // Add the widget to the document body\n document.body.appendChild(widget)\n\n console.log(\"Obi Widget initialized and mounted\")\n\n return widget\n }\n}\n"],"names":[],"mappings":"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"}
@@ -0,0 +1,20 @@
1
+ function mitt(n) {
2
+ return { all: n = n || /* @__PURE__ */ new Map(), on: function(t, e) {
3
+ var i = n.get(t);
4
+ i ? i.push(e) : n.set(t, [e]);
5
+ }, off: function(t, e) {
6
+ var i = n.get(t);
7
+ i && (e ? i.splice(i.indexOf(e) >>> 0, 1) : n.set(t, []));
8
+ }, emit: function(t, e) {
9
+ var i = n.get(t);
10
+ i && i.slice().map(function(n2) {
11
+ n2(e);
12
+ }), (i = n.get("*")) && i.slice().map(function(n2) {
13
+ n2(t, e);
14
+ });
15
+ } };
16
+ }
17
+ export {
18
+ mitt as m
19
+ };
20
+ //# sourceMappingURL=mitt-3c1f932d.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"mitt-3c1f932d.js","sources":["../../../node_modules/mitt/dist/mitt.mjs"],"sourcesContent":["export default function(n){return{all:n=n||new Map,on:function(t,e){var i=n.get(t);i?i.push(e):n.set(t,[e])},off:function(t,e){var i=n.get(t);i&&(e?i.splice(i.indexOf(e)>>>0,1):n.set(t,[]))},emit:function(t,e){var i=n.get(t);i&&i.slice().map(function(n){n(e)}),(i=n.get(\"*\"))&&i.slice().map(function(n){n(t,e)})}}}\n//# sourceMappingURL=mitt.mjs.map\n"],"names":["n"],"mappings":"AAAe,SAAA,KAAS,GAAE;AAAC,SAAM,EAAC,KAAI,IAAE,KAAG,oBAAI,OAAI,IAAG,SAAS,GAAE,GAAE;AAAC,QAAI,IAAE,EAAE,IAAI,CAAC;AAAE,QAAE,EAAE,KAAK,CAAC,IAAE,EAAE,IAAI,GAAE,CAAC,CAAC,CAAC;AAAA,EAAC,GAAE,KAAI,SAAS,GAAE,GAAE;AAAC,QAAI,IAAE,EAAE,IAAI,CAAC;AAAE,UAAI,IAAE,EAAE,OAAO,EAAE,QAAQ,CAAC,MAAI,GAAE,CAAC,IAAE,EAAE,IAAI,GAAE,EAAE;AAAA,EAAE,GAAE,MAAK,SAAS,GAAE,GAAE;AAAC,QAAI,IAAE,EAAE,IAAI,CAAC;AAAE,SAAG,EAAE,QAAQ,IAAI,SAASA,IAAE;AAAC,MAAAA,GAAE,CAAC;AAAA,IAAC,CAAC,IAAG,IAAE,EAAE,IAAI,GAAG,MAAI,EAAE,MAAO,EAAC,IAAI,SAASA,IAAE;AAAC,MAAAA,GAAE,GAAE,CAAC;AAAA,IAAC,CAAC;AAAA,EAAC,EAAC;AAAC;","x_google_ignoreList":[0]}