Merge pull request #109 from Hikari-Haru/translation-view-fixes

Some fixes to the translation message command
Hikari Haru 2 years ago committed by GitHub
commit e1181871b3
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

@ -1,17 +1,9 @@
import asyncio
import os
import traceback
import aiohttp import aiohttp
import discord import discord
# We don't use the converser cog here because we want to be able to redo for the last images and text prompts at the same time
from sqlitedict import SqliteDict
from models.deepl_model import TranslationModel from models.deepl_model import TranslationModel
from services.environment_service import EnvService from services.environment_service import EnvService
from services.image_service import ImageService
from services.text_service import TextService
ALLOWED_GUILDS = EnvService.get_allowed_guilds() ALLOWED_GUILDS = EnvService.get_allowed_guilds()
@ -19,7 +11,7 @@ ALLOWED_GUILDS = EnvService.get_allowed_guilds()
def build_translation_embed(text, translated_text, translated_language): def build_translation_embed(text, translated_text, translated_language):
"""Build an embed for the translation""" """Build an embed for the translation"""
embed = discord.Embed( embed = discord.Embed(
title=f"Translation to " + translated_language, title=f"Translation to {translated_language}",
color=0x311432, color=0x311432,
) )
embed.add_field(name="Original text", value=text, inline=False) embed.add_field(name="Original text", value=text, inline=False)
@ -29,7 +21,7 @@ def build_translation_embed(text, translated_text, translated_language):
class TranslationService(discord.Cog, name="TranslationService"): class TranslationService(discord.Cog, name="TranslationService"):
"""Cog containing a draw commands and file management for saved images""" """Cog containing translation commands and retrieval of translation services"""
def __init__( def __init__(
self, self,
@ -44,7 +36,7 @@ class TranslationService(discord.Cog, name="TranslationService"):
def build_supported_language_embed(self): def build_supported_language_embed(self):
"""Build an embed for the translation""" """Build an embed for the translation"""
embed = discord.Embed( embed = discord.Embed(
title=f"Translator supported languages", title="Translator supported languages",
color=0x311432, color=0x311432,
) )
# Add the list of supported languages in a nice format # Add the list of supported languages in a nice format
@ -59,7 +51,7 @@ class TranslationService(discord.Cog, name="TranslationService"):
return embed return embed
async def translate_command(self, ctx, text, target_language, formality): async def translate_command(self, ctx, text, target_language, formality):
"""Delete all local images""" """Command handler for the translation command"""
await ctx.defer() await ctx.defer()
# TODO Add pagination! # TODO Add pagination!
@ -107,6 +99,7 @@ class TranslateView(discord.ui.View):
self.translation_model = translation_model self.translation_model = translation_model
self.message = message self.message = message
self.selection_message = selection_message self.selection_message = selection_message
self.formality = None
@discord.ui.select( # the decorator that lets you specify the properties of the select menu @discord.ui.select( # the decorator that lets you specify the properties of the select menu
placeholder="Language", # the placeholder text that will be displayed if nothing is selected placeholder="Language", # the placeholder text that will be displayed if nothing is selected
@ -123,9 +116,11 @@ class TranslateView(discord.ui.View):
self, select, interaction self, select, interaction
): # the function called when the user is done selecting options ): # the function called when the user is done selecting options
try: try:
await interaction.response.defer()
response = await self.translation_model.send_translate_request( response = await self.translation_model.send_translate_request(
self.message.content, self.message.content,
TranslationModel.get_country_code_from_name(select.values[0]), TranslationModel.get_country_code_from_name(select.values[0]),
self.formality
) )
await self.message.reply( await self.message.reply(
mention_author=False, mention_author=False,
@ -146,3 +141,30 @@ class TranslateView(discord.ui.View):
f"There was an error: {e}", ephemeral=True, delete_after=15 f"There was an error: {e}", ephemeral=True, delete_after=15
) )
return return
@discord.ui.select(
placeholder="Formality (optional)",
min_values=1,
max_values=1,
options=[discord.SelectOption(label="Prefer more", value="prefer_more"),
discord.SelectOption(label="default", value="default"),
discord.SelectOption(label="Prefer less", value="prefer_less")]
)
async def formality_callback(
self, select, interaction
):
try:
self.formality = select.values[0]
await interaction.response.defer()
except aiohttp.ClientResponseError as e:
await interaction.response.send_message(
f"There was an error with the DeepL API: {e.message}",
ephemeral=True,
delete_after=15,
)
return
except Exception as e:
await interaction.response.send_message(
f"There was an error: {e}", ephemeral=True, delete_after=15
)
return
Loading…
Cancel
Save