Spaces:
Sleeping
Sleeping
Brunwo
commited on
Commit
·
7071579
1
Parent(s):
dfb37e3
working gradio js client, local & HF
Browse files- .gitignore +1 -0
- README.md +3 -0
- build.sh +3 -0
- frontendsetup.sh +4 -0
- index.html +3 -1
- script.js +47 -28
- vite.config.js +9 -0
.gitignore
CHANGED
@@ -7,3 +7,4 @@ flagged/log.csv
|
|
7 |
.aider*
|
8 |
locales/fr/LC_MESSAGES/messages.mo
|
9 |
locales/en/LC_MESSAGES/messages.mo
|
|
|
|
7 |
.aider*
|
8 |
locales/fr/LC_MESSAGES/messages.mo
|
9 |
locales/en/LC_MESSAGES/messages.mo
|
10 |
+
node_modules/
|
README.md
CHANGED
@@ -35,3 +35,6 @@ ngrok http 8000
|
|
35 |
|
36 |
sudo apt-get install gettext
|
37 |
|
|
|
|
|
|
|
|
35 |
|
36 |
sudo apt-get install gettext
|
37 |
|
38 |
+
|
39 |
+
|
40 |
+
npx vite
|
build.sh
CHANGED
@@ -1,3 +1,6 @@
|
|
1 |
msgfmt locales/fr/LC_MESSAGES/messages.po -o locales/fr/LC_MESSAGES/messages.mo
|
2 |
msgfmt locales/es/LC_MESSAGES/messages.po -o locales/es/LC_MESSAGES/messages.mo
|
3 |
msgfmt locales/en/LC_MESSAGES/messages.po -o locales/en/LC_MESSAGES/messages.mo
|
|
|
|
|
|
|
|
1 |
msgfmt locales/fr/LC_MESSAGES/messages.po -o locales/fr/LC_MESSAGES/messages.mo
|
2 |
msgfmt locales/es/LC_MESSAGES/messages.po -o locales/es/LC_MESSAGES/messages.mo
|
3 |
msgfmt locales/en/LC_MESSAGES/messages.po -o locales/en/LC_MESSAGES/messages.mo
|
4 |
+
|
5 |
+
|
6 |
+
npx vite build
|
frontendsetup.sh
ADDED
@@ -0,0 +1,4 @@
|
|
|
|
|
|
|
|
|
|
|
1 |
+
|
2 |
+
npm init -y
|
3 |
+
npm install vite @gradio/client
|
4 |
+
touch vite.config.js
|
index.html
CHANGED
@@ -32,6 +32,8 @@
|
|
32 |
</div>
|
33 |
</div>
|
34 |
|
35 |
-
|
|
|
|
|
36 |
</body>
|
37 |
</html>
|
|
|
32 |
</div>
|
33 |
</div>
|
34 |
|
35 |
+
|
36 |
+
<script type="module" src="script.js"></script>
|
37 |
+
<!-- <script src="/script.js"></script> -->
|
38 |
</body>
|
39 |
</html>
|
script.js
CHANGED
@@ -1,3 +1,5 @@
|
|
|
|
|
|
1 |
document.addEventListener("DOMContentLoaded", function() {
|
2 |
const audioPlayer = document.getElementById('player');
|
3 |
const settingsBtn = document.getElementById('settingsBtn');
|
@@ -86,9 +88,13 @@ document.addEventListener("DOMContentLoaded", function() {
|
|
86 |
|
87 |
// Function to fetch MP3 from API endpoint when a link is shared
|
88 |
async function fetchMp3(link) {
|
|
|
89 |
try {
|
90 |
const apiKey = localStorage.getItem('openaiApiKey');
|
91 |
const apiServer = localStorage.getItem('apiServer');
|
|
|
|
|
|
|
92 |
if (!apiKey) {
|
93 |
throw new Error("API key not set. Please set your OpenAI API key in the settings.");
|
94 |
}
|
@@ -96,51 +102,64 @@ document.addEventListener("DOMContentLoaded", function() {
|
|
96 |
throw new Error("API server not set. Please set the API server in the settings.");
|
97 |
}
|
98 |
|
99 |
-
|
100 |
-
|
101 |
-
|
102 |
-
|
103 |
-
|
104 |
-
|
105 |
-
|
106 |
-
|
107 |
-
|
108 |
-
|
109 |
-
|
110 |
-
|
111 |
-
|
112 |
-
|
113 |
-
"", // edited_transcript
|
114 |
-
"", // user_feedback
|
115 |
-
"summary" // original_text
|
116 |
-
]
|
117 |
-
}),
|
118 |
-
});
|
119 |
-
|
120 |
-
if (!response.ok) {
|
121 |
-
throw new Error(`HTTP error! status: ${response.status}`);
|
122 |
-
}
|
123 |
|
124 |
-
const result = await
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
125 |
|
126 |
// Assuming the audio file URL is the first item in the result
|
127 |
const audioFileUrl = result.data[0];
|
|
|
128 |
|
129 |
// Set the audio player source
|
130 |
audioPlayer.src = audioFileUrl;
|
131 |
audioPlayer.play();
|
|
|
132 |
} catch (error) {
|
133 |
-
console.error('Error
|
134 |
-
|
|
|
135 |
}
|
136 |
}
|
137 |
|
138 |
// Get the link from the shared URL
|
139 |
const queryParams = new URLSearchParams(window.location.search);
|
140 |
const sharedLink = queryParams.get('url');
|
141 |
-
|
|
|
|
|
142 |
// Only call the API to get MP3 if a valid URL is provided
|
143 |
if (sharedLink) {
|
|
|
144 |
fetchMp3(sharedLink);
|
145 |
} else {
|
146 |
console.log("No URL provided. Waiting for user input.");
|
|
|
1 |
+
import { Client } from "@gradio/client";
|
2 |
+
|
3 |
document.addEventListener("DOMContentLoaded", function() {
|
4 |
const audioPlayer = document.getElementById('player');
|
5 |
const settingsBtn = document.getElementById('settingsBtn');
|
|
|
88 |
|
89 |
// Function to fetch MP3 from API endpoint when a link is shared
|
90 |
async function fetchMp3(link) {
|
91 |
+
console.log('Starting fetchMp3 function with link:', link);
|
92 |
try {
|
93 |
const apiKey = localStorage.getItem('openaiApiKey');
|
94 |
const apiServer = localStorage.getItem('apiServer');
|
95 |
+
console.log('Retrieved API key and server from localStorage');
|
96 |
+
console.log('API Server:', apiServer);
|
97 |
+
|
98 |
if (!apiKey) {
|
99 |
throw new Error("API key not set. Please set your OpenAI API key in the settings.");
|
100 |
}
|
|
|
102 |
throw new Error("API server not set. Please set the API server in the settings.");
|
103 |
}
|
104 |
|
105 |
+
console.log('Attempting to connect to Gradio app...');
|
106 |
+
|
107 |
+
// Connect to local Gradio app
|
108 |
+
const client = await Client.connect(apiServer);
|
109 |
+
|
110 |
+
//connect to HF deployed one OK
|
111 |
+
//const client = await Client.connect("Mightypeacock/webtoaudio");
|
112 |
+
|
113 |
+
console.log('Gradio client created successfully');
|
114 |
+
|
115 |
+
console.log(await client.view_api())
|
116 |
+
|
117 |
+
console.log('Preparing to make prediction...');
|
118 |
+
// Make the prediction
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
119 |
|
120 |
+
const result = await client.predict("/generate_audio", {
|
121 |
+
url:link,
|
122 |
+
openai_api_key: apiKey,
|
123 |
+
text_model: "gpt-4o-mini",
|
124 |
+
audio_model: "tts-1",
|
125 |
+
speaker_1_voice: "alloy",
|
126 |
+
speaker_2_voice: "echo",
|
127 |
+
api_base: null, // api_base
|
128 |
+
edited_transcript: "", // edited_transcript
|
129 |
+
user_feedback: "", // user_feedback
|
130 |
+
original_text: "summary" // original_text
|
131 |
+
// debug: true,
|
132 |
+
});
|
133 |
+
|
134 |
+
console.log(result.data);
|
135 |
+
|
136 |
+
|
137 |
+
console.log('Prediction made successfully');
|
138 |
|
139 |
// Assuming the audio file URL is the first item in the result
|
140 |
const audioFileUrl = result.data[0];
|
141 |
+
console.log('Received audio file URL:', audioFileUrl);
|
142 |
|
143 |
// Set the audio player source
|
144 |
audioPlayer.src = audioFileUrl;
|
145 |
audioPlayer.play();
|
146 |
+
console.log('Audio playback started');
|
147 |
} catch (error) {
|
148 |
+
console.error('Error in fetchMp3:', error);
|
149 |
+
console.error('Error stack:', error.stack);
|
150 |
+
alert(`Error fetching MP3: ${error.message}`);
|
151 |
}
|
152 |
}
|
153 |
|
154 |
// Get the link from the shared URL
|
155 |
const queryParams = new URLSearchParams(window.location.search);
|
156 |
const sharedLink = queryParams.get('url');
|
157 |
+
|
158 |
+
console.log('Shared link from URL:', sharedLink);
|
159 |
+
|
160 |
// Only call the API to get MP3 if a valid URL is provided
|
161 |
if (sharedLink) {
|
162 |
+
console.log('Valid URL provided, calling fetchMp3');
|
163 |
fetchMp3(sharedLink);
|
164 |
} else {
|
165 |
console.log("No URL provided. Waiting for user input.");
|
vite.config.js
ADDED
@@ -0,0 +1,9 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
1 |
+
|
2 |
+
// vite.config.js
|
3 |
+
import { defineConfig } from 'vite';
|
4 |
+
|
5 |
+
export default defineConfig({
|
6 |
+
build: {
|
7 |
+
outDir: 'dist', // The output directory for bundled files
|
8 |
+
},
|
9 |
+
});
|