Plugin Emoji (emoji
)
Dengan plugin ini, kamu bisa menambahkan emoji secara otomatis di pesan balasanmu tanpa perlu bolak-balik copy-paste emoji dari web ke kode kamu.
Kenapa Aku Perlu Plugin Ini?
Kenapa tidak? Orang-orang sering menggunakan emoji di kode mereka untuk mengilustrasikan pesan yang ingin disampaikan ataupun menata sesuatu supaya terlihat lebih baik. Sayangnya, kamu akan kehilangan fokus setiap kali kamu membutuhkan sebuah emoji baru.
- Pertama, kamu berhenti menulis kode untuk mencari emoji tersebut.
- Kemudian, kamu membuka chat Telegram lalu menghabiskan waktu kurang lebih 6 detik (atau bahkan lebih) untuk mencari emoji yang kamu inginkan.
- Terakhir, kamu menyalin emoji tersebut ke dalam kode, lalu melanjutkan menulis kode dan semoga kamu tidak lupa sudah sampai mana kamu tadi menulis kode (baca: kehilangan fokus).
Dengan plugin ini, kamu tidak akan kehilangan fokus karena berulang kali berhenti menulis kode hanya untuk menyalin emoji. Di samping itu, ada juga yang mengalami lag di sistem mereka ketika berpindah aplikasi atau bahkan code editor mereka tidak dapat menampilkan emoji, sehingga mereka hanya melihat sebuah kotak putih seperti pesan menyedihkan ini, I'm so happy □
.
Plugin ini bertujuan untuk mengatasi permasalahan tersebut dengan cara membantu kamu mengurai emoji di semua sistem dan menyediakan cara yang mudah untuk mencari emoji menggunakan fitur auto-complete. Sekarang, langkah-langkah di atas bisa dikurangi menjadi satu langkah berikut:
- Tulis emoji yang kamu inginkan langsung di kode kamu. Semudah itu.
Apakah Ini Ilmu Sulap?
Bukan sulap, bukan juga sihir. Teknik ini dinamakan template string. Kamu bisa membacanya lebih lanjut di sini.
Penginstalan dan Contoh Penggunaannya
Kamu bisa menginstal plugin ini di bot kamu dengan cara seperti ini:
import { Bot, Context } from "grammy";
import { EmojiFlavor, emojiParser } from "@grammyjs/emoji";
// Ini dinamakan Context Flavor
// Kamu bisa membacanya di sini:
// https://grammy.dev/id/guide/context#transformative-context-flavor
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.30.0/mod.ts";
import {
EmojiFlavor,
emojiParser,
} from "https://deno.land/x/grammy_emoji@v1.2.0/mod.ts";
// Ini dinamakan Context Flavor
// Kamu bisa membacanya di sini:
// https://grammy.dev/id/guide/context#transformative-context-flavor
type MyContext = EmojiFlavor<Context>;
const bot = new Bot<MyContext>("");
bot.use(emojiParser());
2
3
4
5
6
7
8
9
10
11
12
13
14
Sekarang, kamu bisa mencari emoji berdasarkan namanya:
bot.command("start", async (ctx) => {
const parsedString = ctx.emoji`Halo! ${"smiling_face_with_sunglasses"}`; // => Halo! 😎
await ctx.reply(parsedString);
});
2
3
4
Cara lainnya, kamu bisa membalas secara langsung menggunakan method reply
:
bot.command("ping", async (ctx) => {
await ctx.replyWithEmoji`Pong ${"ping_pong"}`; // => Pong 🏓
});
2
3
Perlu Diperhatikan
ctx
dan ctx
SELALU menggunakan template string. Jika kamu belum familiar dengan syntax tersebut, pahami terlebih dahulu materi ini.
Data Praktis untuk Reaksi
Ketika menggunakan reaksi, kamu tentu akan banyak berinteraksi dengan emoji. Memprogram dengan melibatkan emoji sangatlah menyebalkan. Plugin ini adalah surga untuk para pecinta emoji, kabar baiknya ia bisa digunakan untuk reaksi juga.
Kamu bisa meng-import Reactions
dari plugin ini lalu menggunakannya seperti ini:
bot.on("message", (ctx) => ctx.react(Reactions.thumbs_up));
Semudah itu. 😌