Emojis (emoji
)
Con este plugin, puedes insertar fácilmente emojis en tus respuestas buscándolos en lugar de copiar y pegar manualmente un emoji de la web en tu código.
¿Por qué debería utilizarlo?
¿Por qué no? La gente utiliza emojis en su código todo el tiempo para ilustrar mejor el mensaje que quieren pasar o para organizar las cosas. Pero se pierde el enfoque cada vez que se necesita un nuevo emoji, ver:
- Dejas de codificar para buscar un emoji específico.
- Vas a un chat de Telegram y te pasas ~6 segundos (por no decir más) buscando el emoji que quieres.
- Los copias y pegas en tu código y vuelves a codificar, pero con el foco perdido.
Con este plugin, simplemente no dejas de codificar ya que tampoco pierdes la concentración. También hay sistemas y/o editores que no les gusta y no muestran los emojis, por lo que terminas pegando un cuadrado blanco, como este triste-pequeño-cuidado mensaje: Estoy tan feliz □
.
Este plugin pretende resolver estos problemas, manejando por ti la difícil tarea de analizar los emojis en todos los sistemas y permitiéndote sólo buscarlos de forma sencilla (está disponible el autocompletado). Ahora, los pasos anteriores se pueden reducir a este:
- Describe el emoji que quieres y úsalo. Justo en tu código. Así de simple.
¿Esto es brujería?
No, se llama cadenas de plantillas. Puedes leer más sobre ellas aquí.
Instalación y ejemplos
Puedes instalar este plugin en tu bot así:
import { Bot, Context } from "grammy";
import { EmojiFlavor, emojiParser } from "@grammyjs/emoji";
// Esto se llama Context Flavoring
// Puedes leer más en:
// https://grammy.dev/es/guide/context#transformative-context-flavors
type MyContext = EmojiFlavor<Context>;
const bot = new Bot<MyContext>("");
bot.use(emojiParser());
2
3
4
5
6
7
8
9
10
11
const { Bot } = require("grammy");
const { emojiParser } = require("@grammyjs/emoji");
const bot = new Bot("");
bot.use(emojiParser());
2
3
4
5
6
import { Bot, Context } from "https://deno.land/x/grammy@v1.34.0/mod.ts";
importar {
EmojiFlavor,
emojiParser,
} from "https://deno.land/x/grammy_emoji@v1.2.0/mod.ts";
// Esto se llama Context Flavoring
// Puedes leer más en:
// https://grammy.dev/es/guide/context#transformative-context-flavors
tipo MyContext = EmojiFlavor<Context>;
const bot = new Bot<MyContext>("");
bot.use(emojiParser());
2
3
4
5
6
7
8
9
10
11
12
13
14
Ahora puedes obtener emojis por sus nombres:
bot.command("start", async (ctx) => {
const parsedString = ctx
.emoji`¡Bienvenido! ${"smiling_face_with_sunglasses"}`; // => ¡Bienvenido! 😎
await ctx.reply(parsedString);
});
2
3
4
5
También puedes responder directamente con el método reply
:
bot.command("ping", async (ctx) => {
await ctx.replyWithEmoji`Pong ${"ping_pong"}`; // => Pong 🏓
});
2
3
Ten en cuenta que
ctx
y ctx
Siempre utilizan cadenas de plantilla. Si no estás familiarizado con esta sintaxis, puedes leer más sobre ella aquí.
Datos útiles para Reacciones
Cuando usas reacciones con tu bot, ¡tendrás que programar mucho con emoji, también! Esto es igualmente molesto, y ya que este plugin es el sueño húmedo de todo tu uso de emoji, puede ayudarte con las reacciones, también.
Puedes importar Reactions
desde este plugin y luego usarlo como sigue.
bot.on("message", (ctx) => ctx.react(Reactions.thumbs_up));
Qué bien.
Resumen del plugin
- Nombre:
emoji
- Fuente
- Referencia