|
import time |
|
|
|
import gradio as gr |
|
|
|
from gui.asset_components import AssetComponentsUtils |
|
from gui.ui_abstract_component import AbstractComponentUI |
|
from shortGPT.api_utils.eleven_api import ElevenLabsAPI |
|
from shortGPT.config.api_db import ApiKeyManager |
|
|
|
|
|
class ConfigUI(AbstractComponentUI): |
|
def __init__(self): |
|
self.api_key_manager = ApiKeyManager() |
|
eleven_key = self.api_key_manager.get_api_key('ELEVEN LABS') |
|
self.eleven_labs_api = ElevenLabsAPI(eleven_key) if eleven_key else None |
|
|
|
def on_show(self, button_text, textbox, button): |
|
'''Show or hide the API key''' |
|
if button_text == "Show": |
|
return gr.Textbox.update(type="text"), gr.Button.update(value="Hide") |
|
return gr.Textbox.update(type="password"), gr.Button.update(value="Show") |
|
|
|
def verify_eleven_key(self, eleven_key, remaining_chars): |
|
'''Verify the ElevenLabs API key''' |
|
if (eleven_key and self.api_key_manager.get_api_key('ELEVEN LABS') != eleven_key): |
|
try: |
|
self.eleven_labs_api = ElevenLabsAPI(eleven_key) |
|
print(self.eleven_labs_api) |
|
return self.eleven_labs_api.get_remaining_characters() |
|
except Exception as e: |
|
raise gr.Error(e.args[0]) |
|
return remaining_chars |
|
|
|
def save_keys(self, openai_key, eleven_key, pexels_key): |
|
'''Save the keys in the database''' |
|
if (self.api_key_manager.get_api_key('OPENAI') != openai_key): |
|
self.api_key_manager.set_api_key("OPENAI", openai_key) |
|
if (self.api_key_manager.get_api_key('PEXELS') != pexels_key): |
|
self.api_key_manager.set_api_key("PEXELS", pexels_key) |
|
if (self.api_key_manager.get_api_key('ELEVEN LABS') != eleven_key): |
|
self.api_key_manager.set_api_key("ELEVEN LABS", eleven_key) |
|
new_eleven_voices = AssetComponentsUtils.getElevenlabsVoices() |
|
return gr.Textbox.update(value=openai_key),\ |
|
gr.Textbox.update(value=eleven_key),\ |
|
gr.Textbox.update(value=pexels_key),\ |
|
gr.Radio.update(choices=new_eleven_voices),\ |
|
gr.Radio.update(choices=new_eleven_voices) |
|
|
|
return gr.Textbox.update(value=openai_key),\ |
|
gr.Textbox.update(value=eleven_key),\ |
|
gr.Textbox.update(value=pexels_key),\ |
|
gr.Radio.update(visible=True),\ |
|
gr.Radio.update(visible=True) |
|
|
|
def get_eleven_remaining(self,): |
|
'''Get the remaining characters from ElevenLabs API''' |
|
if (self.eleven_labs_api): |
|
try: |
|
return self.eleven_labs_api.get_remaining_characters() |
|
except Exception as e: |
|
return e.args[0] |
|
return "" |
|
|
|
def back_to_normal(self): |
|
'''Back to normal after 3 seconds''' |
|
time.sleep(3) |
|
return gr.Button.update(value="save") |
|
|
|
def create_ui(self): |
|
'''Create the config UI''' |
|
with gr.Tab("Config") as config_ui: |
|
with gr.Row(): |
|
with gr.Column(): |
|
with gr.Row(): |
|
openai_textbox = gr.Textbox(value=self.api_key_manager.get_api_key("OPENAI"), label=f"OPENAI API KEY", show_label=True, interactive=True, show_copy_button=True, type="password", scale=40) |
|
show_openai_key = gr.Button("Show", size="sm", scale=1) |
|
show_openai_key.click(self.on_show, [show_openai_key], [openai_textbox, show_openai_key]) |
|
with gr.Row(): |
|
eleven_labs_textbox = gr.Textbox(value=self.api_key_manager.get_api_key("ELEVEN LABS"), label=f"ELEVEN LABS API KEY", show_label=True, interactive=True, show_copy_button=True, type="password", scale=40) |
|
eleven_characters_remaining = gr.Textbox(value=self.get_eleven_remaining(), label=f"CHARACTERS REMAINING", show_label=True, interactive=False, type="text", scale=40) |
|
show_eleven_key = gr.Button("Show", size="sm", scale=1) |
|
show_eleven_key.click(self.on_show, [show_eleven_key], [eleven_labs_textbox, show_eleven_key]) |
|
with gr.Row(): |
|
pexels_textbox = gr.Textbox(value=self.api_key_manager.get_api_key("PEXELS"), label=f"PEXELS KEY", show_label=True, interactive=True, show_copy_button=True, type="password", scale=40) |
|
show_pexels_key = gr.Button("Show", size="sm", scale=1) |
|
show_pexels_key.click(self.on_show, [show_pexels_key], [pexels_textbox, show_pexels_key]) |
|
save_button = gr.Button("save", size="sm", scale=1) |
|
save_button.click(self.verify_eleven_key, [eleven_labs_textbox, eleven_characters_remaining], [eleven_characters_remaining]).success( |
|
self.save_keys, [openai_textbox, eleven_labs_textbox, pexels_textbox], [openai_textbox, eleven_labs_textbox, pexels_textbox, AssetComponentsUtils.voiceChoice(), AssetComponentsUtils.voiceChoiceTranslation()]) |
|
save_button.click(lambda _: gr.Button.update(value="Keys Saved !"), [], [save_button]) |
|
save_button.click(self.back_to_normal, [], [save_button]) |
|
return config_ui |
|
|