revolt.js is a direct implementation of the entire Revolt API and provides a way to authenticate and start communicating with Revolt servers. This repository is a fork of revolt.js v6 with various API updates.
import { Client } from "revolt.js";
let client = new Client();
client.on("ready", async () =>
console.info(`Logged in as ${client.user.username}!`),
);
client.on("message", async (message) => {
if (message.content === "hello") {
message.channel.sendMessage("world");
}
});
client.loginBot("..");
If you're using Node 18 or earlier, you must specify --experimental-specifier-resolution=node
when running your code (for example, node --experimental-specifier-resolution=node index.js
).
If you're using Node 19 or later, you'll need to use a custom loader. Install commonjs-extension-resolution-loader
using your preferred package manager (e.g. yarn add commonjs-extension-resolution-loader
), then specify --loader=commonjs-extension-resolution-loader
when running your code (for example, node --loader=commonjs-extension-resolution-loader index.js
).
const { Client } = require("revolt.js");
let client = new Client();
client.on("ready", async () =>
console.info(`Logged in as ${client.user.username}!`),
);
client.on("message", async (message) => {
if (message.content === "hello") {
message.channel.sendMessage("world");
}
});
client.loginBot("..");
import { Client } from "revolt.js";
let client = new Client();
client.on("ready", async () =>
console.info(`Logged in as ${client.user!.username}!`),
);
client.on("message", async (message) => {
if (message.content === "hello") {
message.channel!.sendMessage("world");
}
});
client.loginBot("..");
MobX is used behind the scenes so you can subscribe to any change as you normally would, e.g. with mobx-react(-lite)
or mobx's utility functions.
import { autorun } from 'mobx';
[..]
client.once('ready', () => {
autorun(() => {
console.log(`Current username is ${client.user!.username}!`);
});
});
All revolt-api
types are re-exported from this library under API
.
import { API } from "revolt.js";
// API.Channel;
// API.[..];