mirror of
https://github.com/uhIgnacio/EmoteManager.git
synced 2024-08-15 02:23:13 +00:00
allow use of the actual emote in place of the emote name
This commit is contained in:
parent
67027e5f0f
commit
8f170d7f13
1 changed files with 25 additions and 12 deletions
|
@ -139,7 +139,7 @@ class Emotes:
|
||||||
The list of possible emotes you can copy is here:
|
The list of possible emotes you can copy is here:
|
||||||
https://emoji-connoissuer.python-for.life/list
|
https://emoji-connoissuer.python-for.life/list
|
||||||
"""
|
"""
|
||||||
|
name = name.strip(':')
|
||||||
try:
|
try:
|
||||||
emote = await self.aioec.emote(name)
|
emote = await self.aioec.emote(name)
|
||||||
except aioec.NotFound:
|
except aioec.NotFound:
|
||||||
|
@ -207,27 +207,29 @@ class Emotes:
|
||||||
reason=reason)
|
reason=reason)
|
||||||
|
|
||||||
@commands.command(aliases=('delete', 'delet', 'rm'))
|
@commands.command(aliases=('delete', 'delet', 'rm'))
|
||||||
async def remove(self, context, *names):
|
async def remove(self, context, *emotes):
|
||||||
"""Remove an emote from this server.
|
"""Remove an emote from this server.
|
||||||
|
|
||||||
names: the names of one or more emotes you'd like to remove.
|
emotes: the name of an emote or of one or more emotes you'd like to remove.
|
||||||
"""
|
"""
|
||||||
if len(names) == 1:
|
if len(emotes) == 1:
|
||||||
emote = await self.disambiguate(context, names[0])
|
emote = await self.parse_emote(context, emotes[0])
|
||||||
await emote.delete(reason=f'Removed by {utils.format_user(self.bot, context.author.id)}')
|
await emote.delete(reason=f'Removed by {utils.format_user(self.bot, context.author.id)}')
|
||||||
await context.send(f'Emote \:{emote.name}: successfully removed.')
|
await context.send(f'Emote \:{emote.name}: successfully removed.')
|
||||||
else:
|
else:
|
||||||
for name in names:
|
for emote in emotes:
|
||||||
await context.invoke(self.remove, name)
|
await context.invoke(self.remove, emote)
|
||||||
|
with contextlib.suppress(discord.HTTPException):
|
||||||
|
await context.message.add_reaction('✅')
|
||||||
|
|
||||||
@commands.command(aliases=('mv',))
|
@commands.command(aliases=('mv',))
|
||||||
async def rename(self, context, old_name, new_name):
|
async def rename(self, context, old, new_name):
|
||||||
"""Rename an emote on this server.
|
"""Rename an emote on this server.
|
||||||
|
|
||||||
old_name: the name of the emote to rename
|
old: the name of the emote to rename, or the emote itself
|
||||||
new_name: what you'd like to rename it to
|
new_name: what you'd like to rename it to
|
||||||
"""
|
"""
|
||||||
emote = await self.disambiguate(context, old_name)
|
emote = await self.parse_emote(context, old)
|
||||||
try:
|
try:
|
||||||
await emote.edit(
|
await emote.edit(
|
||||||
name=new_name,
|
name=new_name,
|
||||||
|
@ -237,9 +239,9 @@ class Emotes:
|
||||||
'An error occurred while renaming the emote:\n'
|
'An error occurred while renaming the emote:\n'
|
||||||
+ utils.format_http_exception(ex))
|
+ utils.format_http_exception(ex))
|
||||||
|
|
||||||
await context.send(f'Emote \:{old_name}: successfully renamed to \:{new_name}:')
|
await context.send(f'Emote successfully renamed to \:{new_name}:')
|
||||||
|
|
||||||
@commands.command(aliases=('ls',))
|
@commands.command(aliases=('ls', 'dir'))
|
||||||
async def list(self, context):
|
async def list(self, context):
|
||||||
"""A list of all emotes on this server.
|
"""A list of all emotes on this server.
|
||||||
|
|
||||||
|
@ -258,7 +260,18 @@ class Emotes:
|
||||||
self.paginators.add(paginator)
|
self.paginators.add(paginator)
|
||||||
await paginator.begin()
|
await paginator.begin()
|
||||||
|
|
||||||
|
async def parse_emote(self, context, name_or_emote):
|
||||||
|
match = utils.emote.RE_CUSTOM_EMOTE.match(name_or_emote)
|
||||||
|
if match:
|
||||||
|
id = int(match.group('id'))
|
||||||
|
emote = discord.utils.get(context.guild.emojis, id=id)
|
||||||
|
if emote:
|
||||||
|
return emote
|
||||||
|
name = name_or_emote
|
||||||
|
return await self.disambiguate(context, name)
|
||||||
|
|
||||||
async def disambiguate(self, context, name):
|
async def disambiguate(self, context, name):
|
||||||
|
name = name.strip(':') # in case the user tries :foo: and foo is animated
|
||||||
candidates = [e for e in context.guild.emojis if e.name.lower() == name.lower() and e.require_colons]
|
candidates = [e for e in context.guild.emojis if e.name.lower() == name.lower() and e.require_colons]
|
||||||
if not candidates:
|
if not candidates:
|
||||||
raise errors.EmoteNotFoundError(name)
|
raise errors.EmoteNotFoundError(name)
|
||||||
|
|
Loading…
Reference in a new issue