webexmemebot/app/meme.py

146 lines
5.0 KiB
Python
Raw Permalink Normal View History

2023-07-21 22:57:14 +01:00
from webex_bot.models.command import Command
from webex_bot.models.response import Response, response_from_adaptive_card
from webexteamssdk.models.cards import (
AdaptiveCard,
Column,
ColumnSet,
FontSize,
FontWeight,
Text,
TextBlock,
Choice,
Choices,
)
from webexteamssdk.models.cards.actions import Submit, OpenUrl
2023-12-14 20:55:17 +00:00
from app import img
2023-07-21 22:57:14 +01:00
TEMPLATES = img.get_templates()
class MakeMemeCommand(Command):
2024-03-26 22:22:08 +00:00
"""Class for initial Webex interactive card."""
2023-07-21 22:57:14 +01:00
def __init__(self) -> None:
super().__init__(
command_keyword="/meme",
help_message="Make a Meme",
chained_commands=[MakeMemeCallback()],
delete_previous_message=True,
)
def pre_execute(self, message, attachment_actions, activity) -> None:
return
def execute(self, message, attachment_actions, activity) -> Response:
card_body: list = [
ColumnSet(
columns=[
Column(
width=1,
items=[
TextBlock(
"Make a Meme",
weight=FontWeight.BOLDER,
size=FontSize.MEDIUM,
),
TextBlock(
2023-07-24 16:16:30 +01:00
"This bot uses memegen.link to generate memes. Click 'View Templates' to view available templates.",
2023-07-21 22:57:14 +01:00
weight=FontWeight.LIGHTER,
size=FontSize.SMALL,
2023-07-24 16:16:30 +01:00
wrap=True,
2023-07-21 22:57:14 +01:00
),
TextBlock(
2023-07-24 16:16:30 +01:00
"Both fields are required. If you do not want to specify a value, please type a space.",
2023-07-21 22:57:14 +01:00
weight=FontWeight.LIGHTER,
size=FontSize.SMALL,
2023-07-24 16:16:30 +01:00
wrap=True,
2023-07-21 22:57:14 +01:00
),
],
),
]
),
ColumnSet(
columns=[
Column(
width=1,
items=[
Choices(
id="meme_type",
isMultiSelect=False,
choices=[
2023-07-24 16:16:30 +01:00
Choice(title=x["name"], value=x["choiceval"]) for x in TEMPLATES
2023-07-21 22:57:14 +01:00
],
),
Text(id="text_top", placeholder="Top Text", maxLength=100),
Text(
id="text_bottom",
placeholder="Bottom Text",
maxLength=100,
),
],
),
]
),
]
card: AdaptiveCard = AdaptiveCard(
body=card_body,
actions=[
Submit(
title="Go!",
data={"callback_keyword": "make_meme_callback_rbamzfyx"},
),
OpenUrl(url="https://memegen.link/#templates", title="View Templates"),
Submit(title="Cancel", data={"command_keyword": "exit"}),
],
)
return response_from_adaptive_card(card)
class MakeMemeCallback(Command):
2024-03-26 22:22:08 +00:00
"""Class to process user data and return meme."""
2023-07-21 22:57:14 +01:00
def __init__(self) -> None:
super().__init__(
card_callback_keyword="make_meme_callback_rbamzfyx",
delete_previous_message=True,
)
self.error: bool = False
self.text_top: str = ""
self.text_bottom: str = ""
self.meme: str = ""
self.meme_filename: str = ""
def pre_execute(self, message, attachment_actions, activity) -> str:
self.meme: str = attachment_actions.inputs.get("meme_type")
self.text_top: str = attachment_actions.inputs.get("text_top")
self.text_bottom: str = attachment_actions.inputs.get("text_bottom")
if not self.text_top and not self.text_bottom:
self.error = True
return "Please provide at least one positional text argument."
if ".gif" in self.meme:
return "Generating your meme. GIF-based memes take a little longer. Please wait..."
return "Generating your meme..."
2024-03-26 22:22:08 +00:00
def execute(self, message, attachment_actions, activity) -> Response | None:
if self.error:
2024-03-26 22:26:13 +00:00
return None
2024-03-26 22:22:08 +00:00
self.meme_filename: str = img.generate_api_url(
self.meme, self.text_top, self.text_bottom
)
msg: Response = Response(
attributes={
"roomId": activity["target"]["globalId"],
"parentId": "",
"files": [self.meme_filename],
}
)
return msg
2023-07-21 22:57:14 +01:00
def post_execute(self, message, attachment_actions, activity) -> None:
return