Compare commits
3 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
b55f933a32 | ||
|
|
5fa102b157 | ||
|
|
1e8a33c0c4 |
@@ -18,7 +18,7 @@ from flanautils import Media, MediaType, NotFoundError, OrderedSet, Source, Time
|
||||
from multibot import Action, BadRoleError, BotAction, MultiBot, SendError, User, admin, bot_mentioned, constants as multibot_constants, group, ignore_self_message, inline, reply
|
||||
|
||||
from flanabot import constants
|
||||
from flanabot.models import ButtonsMessageType, Chat, Message, Punishment, WeatherChart
|
||||
from flanabot.models import Chat, Message, Punishment, WeatherChart
|
||||
|
||||
|
||||
# ----------------------------------------------------------------------------------------------------- #
|
||||
@@ -131,7 +131,8 @@ class FlanaBot(MultiBot, ABC):
|
||||
self.register(self._on_weather_chart_config_show, (constants.KEYWORDS['weather_chart'], multibot_constants.KEYWORDS['config']))
|
||||
self.register(self._on_weather_chart_config_show, (multibot_constants.KEYWORDS['show'], constants.KEYWORDS['weather_chart'], multibot_constants.KEYWORDS['config']))
|
||||
|
||||
self.register_button(self._on_button_press)
|
||||
self.register_button(self._on_config_button_press, list(Chat.DEFAULT_CONFIG.keys()))
|
||||
self.register_button(self._on_weather_button_press, WeatherEmoji.values)
|
||||
|
||||
async def _change_config(self, config_name: str, message: Message, value: bool = None):
|
||||
if value is None:
|
||||
@@ -296,50 +297,20 @@ class FlanaBot(MultiBot, ABC):
|
||||
# ---------------------------------------------- #
|
||||
# HANDLERS #
|
||||
# ---------------------------------------------- #
|
||||
async def _on_button_press(self, message: Message):
|
||||
await self._accept_button_event(message)
|
||||
|
||||
match message.button_pressed_text:
|
||||
case WeatherEmoji.ZOOM_IN.value:
|
||||
buttons_message_type = ButtonsMessageType.WEATHER
|
||||
message.weather_chart.zoom_in()
|
||||
case WeatherEmoji.ZOOM_OUT.value:
|
||||
buttons_message_type = ButtonsMessageType.WEATHER
|
||||
message.weather_chart.zoom_out()
|
||||
case WeatherEmoji.LEFT.value:
|
||||
buttons_message_type = ButtonsMessageType.WEATHER
|
||||
message.weather_chart.move_left()
|
||||
case WeatherEmoji.RIGHT.value:
|
||||
buttons_message_type = ButtonsMessageType.WEATHER
|
||||
message.weather_chart.move_right()
|
||||
case WeatherEmoji.PRECIPITATION_VOLUME.value:
|
||||
buttons_message_type = ButtonsMessageType.WEATHER
|
||||
message.weather_chart.trace_metadatas['rain_volume'].show = not message.weather_chart.trace_metadatas['rain_volume'].show
|
||||
message.weather_chart.trace_metadatas['snow_volume'].show = not message.weather_chart.trace_metadatas['snow_volume'].show
|
||||
case emoji if emoji in WeatherEmoji.values:
|
||||
buttons_message_type = ButtonsMessageType.WEATHER
|
||||
trace_metadata_name = WeatherEmoji(emoji).name.lower()
|
||||
message.weather_chart.trace_metadatas[trace_metadata_name].show = not message.weather_chart.trace_metadatas[trace_metadata_name].show
|
||||
case _ if message.button_pressed_user.is_admin and 'auto_' in (config := message.button_pressed_text.split()[1]):
|
||||
buttons_message_type = ButtonsMessageType.CONFIG
|
||||
message.chat.config[config] = not message.chat.config[config]
|
||||
message.save()
|
||||
await self.edit('<b>Estos son los ajustes del grupo:</b>\n\n', self._get_config_buttons(message), message)
|
||||
case _:
|
||||
return
|
||||
|
||||
if buttons_message_type is ButtonsMessageType.WEATHER:
|
||||
message.weather_chart.apply_zoom()
|
||||
message.weather_chart.draw()
|
||||
message.save()
|
||||
|
||||
image_bytes = message.weather_chart.to_image()
|
||||
await self.edit(Media(image_bytes, MediaType.IMAGE), message)
|
||||
|
||||
async def _on_bye(self, message: Message):
|
||||
if not message.chat.is_group or self.is_bot_mentioned(message):
|
||||
await self.send_bye(message)
|
||||
|
||||
async def _on_config_button_press(self, message: Message):
|
||||
await self._accept_button_event(message)
|
||||
|
||||
if not message.button_pressed_user.is_admin or 'auto_' not in (config := message.button_pressed_text.split()[1]):
|
||||
return
|
||||
|
||||
message.chat.config[config] = not message.chat.config[config]
|
||||
message.save()
|
||||
await self.edit('<b>Estos son los ajustes del grupo:</b>\n\n', self._get_config_buttons(message), message)
|
||||
|
||||
@group
|
||||
@bot_mentioned
|
||||
async def _on_config_list_show(self, message: Message):
|
||||
@@ -478,7 +449,11 @@ class FlanaBot(MultiBot, ABC):
|
||||
await self.send(deleted_message.text, message)
|
||||
|
||||
async def _on_scraping(self, message: Message, delete_original: bool = None) -> OrderedSet[Media]:
|
||||
sended_media_messages = await self._search_and_send_medias(message.replied_message) if message.replied_message else OrderedSet()
|
||||
sended_media_messages = OrderedSet()
|
||||
if message.replied_message:
|
||||
word_matches = flanautils.cartesian_product_string_matching(message.text, constants.KEYWORDS['scraping'], min_ratio=multibot_constants.PARSE_CALLBACKS_MIN_RATIO_DEFAULT)
|
||||
if sum(max(matches.values()) for matches in word_matches.values()):
|
||||
sended_media_messages += await self._search_and_send_medias(message.replied_message)
|
||||
sended_media_messages += await self._search_and_send_medias(message)
|
||||
await self.send_inline_results(message)
|
||||
|
||||
@@ -491,6 +466,8 @@ class FlanaBot(MultiBot, ABC):
|
||||
(
|
||||
delete_original is None
|
||||
and
|
||||
not message.replied_message
|
||||
and
|
||||
message.chat.config['auto_delete_original']
|
||||
)
|
||||
or
|
||||
@@ -548,6 +525,34 @@ class FlanaBot(MultiBot, ABC):
|
||||
for user in await self._find_users_to_punish(message):
|
||||
await self.unpunish(user, message, message)
|
||||
|
||||
async def _on_weather_button_press(self, message: Message):
|
||||
await self._accept_button_event(message)
|
||||
|
||||
match message.button_pressed_text:
|
||||
case WeatherEmoji.ZOOM_IN.value:
|
||||
message.weather_chart.zoom_in()
|
||||
case WeatherEmoji.ZOOM_OUT.value:
|
||||
message.weather_chart.zoom_out()
|
||||
case WeatherEmoji.LEFT.value:
|
||||
message.weather_chart.move_left()
|
||||
case WeatherEmoji.RIGHT.value:
|
||||
message.weather_chart.move_right()
|
||||
case WeatherEmoji.PRECIPITATION_VOLUME.value:
|
||||
message.weather_chart.trace_metadatas['rain_volume'].show = not message.weather_chart.trace_metadatas['rain_volume'].show
|
||||
message.weather_chart.trace_metadatas['snow_volume'].show = not message.weather_chart.trace_metadatas['snow_volume'].show
|
||||
case emoji if emoji in WeatherEmoji.values:
|
||||
trace_metadata_name = WeatherEmoji(emoji).name.lower()
|
||||
message.weather_chart.trace_metadatas[trace_metadata_name].show = not message.weather_chart.trace_metadatas[trace_metadata_name].show
|
||||
case _:
|
||||
return
|
||||
|
||||
message.weather_chart.apply_zoom()
|
||||
message.weather_chart.draw()
|
||||
message.save()
|
||||
|
||||
image_bytes = message.weather_chart.to_image()
|
||||
await self.edit(Media(image_bytes, MediaType.IMAGE), message)
|
||||
|
||||
async def _on_weather_chart(self, message: Message):
|
||||
bot_state_message: Message | None = None
|
||||
if message.is_inline:
|
||||
@@ -568,7 +573,7 @@ class FlanaBot(MultiBot, ABC):
|
||||
possible_mentioned_ids.append(user.name.split('#')[0].lower())
|
||||
possible_mentioned_ids.append(f'@{user.id}')
|
||||
|
||||
if roles := await self.get_group_roles(message):
|
||||
if roles := await self.get_roles(message):
|
||||
for role in roles:
|
||||
possible_mentioned_ids.append(f'@{role.id}')
|
||||
|
||||
|
||||
@@ -19,30 +19,66 @@ BYE_PHRASES = ('Adiós.', 'adieu', 'adio', 'adioh', 'adios', 'adió', 'adiós',
|
||||
HELLO_PHRASES = ('alo', 'aloh', 'buenas', 'Hola.', 'hello', 'hey', 'hi', 'hola', 'holaaaa', 'holaaaaaaa', 'ola',
|
||||
'ola k ase', 'pa ti mi cola', 'saludos')
|
||||
INSULTS = (
|
||||
'Cállate ya anda.',
|
||||
'¿Quién te ha preguntado?',
|
||||
'¿Tú eres así o te dan apagones cerebrales?',
|
||||
'._.',
|
||||
'Aléjate de mi.',
|
||||
'Ante la duda mi dedo corazón te saluda.',
|
||||
'Enjoy cancer brain.',
|
||||
'Calla noob.',
|
||||
'Hablas tanta mierda que tu culo tiene envidia de tu boca.',
|
||||
'jAJjajAJjajAJjajAJajJAJajJA',
|
||||
'enjoy xd',
|
||||
'Reported.',
|
||||
'Baneito pa ti en breve.',
|
||||
'Despídete de tu cuenta.',
|
||||
'Flanagan es más guapo que tú.',
|
||||
'jajaj',
|
||||
'xd',
|
||||
'Hay un concurso de hostias y tienes todas las papeletas.',
|
||||
'¿Por qué no te callas?',
|
||||
'Calla noob.',
|
||||
'Cansino.',
|
||||
'Cuentame menos.',
|
||||
'Cuentame más.',
|
||||
'Cállate ya anda.',
|
||||
'Cállate.',
|
||||
'Das penilla.',
|
||||
'De verdad. Estás para encerrarte.',
|
||||
'Deberían hacerte la táctica del C4.',
|
||||
'Te voy romper las pelotas.',
|
||||
'Más tonto y no naces.',
|
||||
'Despídete de tu cuenta.',
|
||||
'Déjame tranquilo.',
|
||||
'Enjoy cancer brain.',
|
||||
'Eres cortito, ¿eh?',
|
||||
'Eres más malo que pegarle a un padre.',
|
||||
'Eres más tonto que peinar bombillas.',
|
||||
'Eres más tonto que pellizcar cristales.',
|
||||
'Eres más malo que pegarle a un padre.'
|
||||
'Estás mal de la azotea.',
|
||||
'Estás mal de la cabeza.',
|
||||
'Flanagan es más guapo que tú.',
|
||||
'Hablas tanta mierda que tu culo tiene envidia de tu boca.',
|
||||
'Hay un concurso de hostias y tienes todas las papeletas.',
|
||||
'Loco.',
|
||||
'Más tonto y no naces.',
|
||||
'No eres muy avispado tú...',
|
||||
'Pesado',
|
||||
'Que bien, ¿eh?',
|
||||
'Que me dejes en paz.',
|
||||
'Qué pesado.',
|
||||
'Quita bicho.',
|
||||
'Reportaito mi arma.',
|
||||
'Reported.',
|
||||
'Retard.',
|
||||
'Te voy romper las pelotas.',
|
||||
'Tú... no estás muy bien, ¿no?',
|
||||
'Ya estamos otra vez...',
|
||||
'Ya estamos...',
|
||||
'enjoy xd',
|
||||
'jAJjajAJjajAJjajAJajJAJajJA',
|
||||
'jajaj',
|
||||
'o_O',
|
||||
'xd',
|
||||
'¿Otra vez tú?',
|
||||
'¿Pero cuándo te vas a callar?',
|
||||
'¿Por qué no te callas?',
|
||||
'¿Quién te ha preguntado?',
|
||||
'¿Qúe quieres?',
|
||||
'¿Te callas o te callo?',
|
||||
'¿Te imaginas que me interesa?aha',
|
||||
'¿Te quieres callar?',
|
||||
'¿Todo bien?',
|
||||
'¿Tú eres así o te dan apagones cerebrales?',
|
||||
'🖕',
|
||||
'😑',
|
||||
'🙄',
|
||||
'🤔',
|
||||
'🤨'
|
||||
)
|
||||
|
||||
KEYWORDS = {
|
||||
|
||||
@@ -1,5 +1,4 @@
|
||||
from flanabot.models.chat import *
|
||||
from flanabot.models.enums import *
|
||||
from flanabot.models.message import *
|
||||
from flanabot.models.punishment import *
|
||||
from flanabot.models.weather_chart import *
|
||||
|
||||
@@ -1,10 +0,0 @@
|
||||
__all__ = ['ButtonsMessageType']
|
||||
|
||||
from enum import auto
|
||||
|
||||
from flanautils import FlanaEnum
|
||||
|
||||
|
||||
class ButtonsMessageType(FlanaEnum):
|
||||
CONFIG = auto()
|
||||
WEATHER = auto()
|
||||
Reference in New Issue
Block a user