feat(issues): added new cog
Some checks failed
Gitea Actions Demo / Explore-Gitea-Actions (push) Failing after 17s
Some checks failed
Gitea Actions Demo / Explore-Gitea-Actions (push) Failing after 17s
This commit is contained in:
parent
aa501a0f14
commit
52752f06b5
3 changed files with 99 additions and 0 deletions
5
issues/__init__.py
Normal file
5
issues/__init__.py
Normal file
|
@ -0,0 +1,5 @@
|
||||||
|
from .issues import Issues
|
||||||
|
|
||||||
|
|
||||||
|
async def setup(bot):
|
||||||
|
await bot.add_cog(Issues(bot))
|
8
issues/info.json
Normal file
8
issues/info.json
Normal file
|
@ -0,0 +1,8 @@
|
||||||
|
{
|
||||||
|
"author" : ["SeaswimmerTheFsh"],
|
||||||
|
"install_msg" : "Thank you for installing Issues!\nYou can find the source code of this cog here: https://git.seaswimmer.cc/SeaswimmerTheFsh/GalaxyCogs",
|
||||||
|
"name" : "Issues",
|
||||||
|
"short" : "This cog allows you to create Gitea issues through a Discord modal.",
|
||||||
|
"description" : "This cog allows you to create Gitea issues through a Discord modal.",
|
||||||
|
"end_user_data_statement" : "This cog does not store any End User Data."
|
||||||
|
}
|
86
issues/issues.py
Normal file
86
issues/issues.py
Normal file
|
@ -0,0 +1,86 @@
|
||||||
|
from typing import Union
|
||||||
|
from redbot.core import commands, Config
|
||||||
|
import discord
|
||||||
|
|
||||||
|
class Issues(commands.Cog):
|
||||||
|
"""This cog allows you to create Gitea issues through a Discord modal.
|
||||||
|
Developed by SeaswimmerTheFsh."""
|
||||||
|
|
||||||
|
def __init__(self, bot):
|
||||||
|
self.bot = bot
|
||||||
|
self.config = Config.get_conf(self, identifier=4285273314713, force_registration=True)
|
||||||
|
self.config.register_guild(
|
||||||
|
channel = None,
|
||||||
|
)
|
||||||
|
|
||||||
|
@commands.command()
|
||||||
|
async def issuestest(self, ctx: commands.Context):
|
||||||
|
await ctx.message.reply(content="Hello world!", view=self.IssueButtons)
|
||||||
|
|
||||||
|
async def send_to_target(self, target: Union[discord.Member, discord.TextChannel], interaction: discord.Interaction, message: str, secondary_message: str = None):
|
||||||
|
if isinstance(target, discord.Member):
|
||||||
|
target_type = "member"
|
||||||
|
elif isinstance(target, discord.TextChannel):
|
||||||
|
target_type = "textchannel"
|
||||||
|
try:
|
||||||
|
await target.send(message)
|
||||||
|
if secondary_message is not None:
|
||||||
|
await target.send(secondary_message)
|
||||||
|
await interaction.response.send_message(content=f"Message sent to {target.mention}!\nMessage contents:\n```{message}```\n```{secondary_message}```", ephemeral=True)
|
||||||
|
else:
|
||||||
|
await interaction.response.send_message(content=f"Message sent to {target.mention}!\nMessage contents:\n```{message}```", ephemeral=True)
|
||||||
|
except (discord.HTTPException, discord.Forbidden) as error:
|
||||||
|
if target_type == "member":
|
||||||
|
await interaction.response.send_message(content="That user has their direct messages closed!", ephemeral=True)
|
||||||
|
elif target_type == "textchannel":
|
||||||
|
await interaction.response.send_message(content="I cannot access that channel!", ephemeral=True)
|
||||||
|
|
||||||
|
class IssueButtons(discord.ui.View):
|
||||||
|
def __init__(self, timeout):
|
||||||
|
super().__init__()
|
||||||
|
self.timeout = timeout
|
||||||
|
|
||||||
|
@discord.ui.button(label="Yes", style=discord.ButtonStyle.success)
|
||||||
|
async def issue_button_bot(self, button: discord.ui.Button, interaction: discord.Interaction):
|
||||||
|
await interaction.response.send_modal(Issues.BotModal())
|
||||||
|
|
||||||
|
class BotModal(discord.ui.Modal, title="Creating issue..."):
|
||||||
|
description = discord.ui.TextInput(
|
||||||
|
label="Describe the bug",
|
||||||
|
placeholder="A clear and concise description of what the bug is.",
|
||||||
|
style=discord.TextStyle.paragraph,
|
||||||
|
max_length=2048
|
||||||
|
)
|
||||||
|
reproduction_steps = discord.ui.TextInput(
|
||||||
|
label="To Reproduce",
|
||||||
|
placeholder="What caused the bug?",
|
||||||
|
style=discord.TextStyle.paragraph,
|
||||||
|
required=True,
|
||||||
|
max_length=2048
|
||||||
|
)
|
||||||
|
expected_behavior = discord.ui.TextInput(
|
||||||
|
label="Expected Behavior",
|
||||||
|
placeholder="A clear and concise description of what you expected to happen.",
|
||||||
|
style=discord.TextStyle.paragraph,
|
||||||
|
required=True,
|
||||||
|
max_length=2048
|
||||||
|
)
|
||||||
|
additional_context = discord.ui.TextInput(
|
||||||
|
label="Additional Context",
|
||||||
|
placeholder="Add any other context about the problem here.",
|
||||||
|
style=discord.TextStyle.paragraph,
|
||||||
|
required=False,
|
||||||
|
max_length=2048
|
||||||
|
)
|
||||||
|
screenshots = discord.ui.TextInput(
|
||||||
|
label="Screenshots",
|
||||||
|
placeholder="If applicable, add screenshots to help explain your problem. Seperate each screenshot with a newline.",
|
||||||
|
style=discord.TextStyle.paragraph,
|
||||||
|
required=False,
|
||||||
|
max_length=2048
|
||||||
|
)
|
||||||
|
|
||||||
|
async def on_submit(self, interaction: discord.Interaction):
|
||||||
|
embed = discord.Embed(title="Issue Request", color=await Issues.bot.get_embed_color(None))
|
||||||
|
fields = [self.description, self.reproduction_steps, self.expected_behavior, self.additional_context, self.screenshots]
|
||||||
|
await Issues.send_to_target(self, self.target, interaction, self.message, self.secondary_message)
|
Loading…
Reference in a new issue