-
Notifications
You must be signed in to change notification settings - Fork 2
Expand file tree
/
Copy pathbackground.js
More file actions
108 lines (96 loc) · 3.28 KB
/
background.js
File metadata and controls
108 lines (96 loc) · 3.28 KB
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
chrome.runtime.onMessage.addListener((request, sender, sendResponse) => {
if (request.action === 'convertImage') {
// Show loading badge (down arrow)
chrome.action.setBadgeText({ text: '↓' });
chrome.action.setBadgeBackgroundColor({ color: '#4285f4' });
handleConversion(request.imageData, request.settings)
.then(result => {
// Clear badge on success
chrome.action.setBadgeText({ text: '' });
sendResponse({ success: true, data: result });
})
.catch(error => {
// Clear badge on error
chrome.action.setBadgeText({ text: '' });
sendResponse({ success: false, error: error.message });
});
return true; // Keep message channel open for async response
}
});
async function handleConversion(imageData, settings) {
try {
if (settings.debugMode) {
console.log('CSV Everything Debug - Request settings:', {
model: settings.model,
prompt: settings.prompt,
hasApiKey: !!settings.apiKey
});
}
// Send to OpenRouter API
const response = await fetch('https://openrouter.ai/api/v1/chat/completions', {
method: 'POST',
headers: {
'Authorization': `Bearer ${settings.apiKey}`,
'Content-Type': 'application/json',
'HTTP-Referer': chrome.runtime.getURL(''),
'X-Title': 'CSV Everything Chrome Extension'
},
body: JSON.stringify({
model: settings.model || 'google/gemini-2.5-flash',
messages: [
{
role: 'user',
content: [
{
type: 'text',
text: settings.prompt || 'turn the image into a csv. only return a csv.'
},
{
type: 'image_url',
image_url: {
url: imageData
}
}
]
}
],
max_tokens: 4000
})
});
// Always log response in debug mode, even for errors
if (settings.debugMode) {
const responseClone = response.clone();
const responseText = await responseClone.text();
console.log('CSV Everything Debug - Full API Response:', {
status: response.status,
statusText: response.statusText,
headers: Object.fromEntries(response.headers.entries()),
body: responseText
});
}
if (!response.ok) {
const errorData = await response.json().catch(() => ({}));
throw new Error(`API Error: ${errorData.error?.message || response.statusText}`);
}
const data = await response.json();
let csvContent = data.choices?.[0]?.message?.content;
if (!csvContent) {
throw new Error('Could not convert this image to a csv');
}
// Strip markdown formatting
csvContent = csvContent.replace(/```csv\n?/g, '');
csvContent = csvContent.replace(/```\n?/g, '');
csvContent = csvContent.trim();
// Create download using data URL (works in service worker)
const dataUrl = 'data:text/csv;charset=utf-8,' + encodeURIComponent(csvContent);
const downloadId = await chrome.downloads.download({
url: dataUrl,
filename: 'data.csv',
saveAs: true
});
return csvContent;
} catch (error) {
console.error('Background conversion error:', error);
throw error;
}
}