Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/fuma-nama/discord-bot-dashboard
A Full-Featured Modern Dashboard Template for Discord Bots
https://github.com/fuma-nama/discord-bot-dashboard
dashboard dashboard-templates discord discord-bot discord-bot-dashboard discord-bot-website javascript web
Last synced: 15 days ago
JSON representation
A Full-Featured Modern Dashboard Template for Discord Bots
- Host: GitHub
- URL: https://github.com/fuma-nama/discord-bot-dashboard
- Owner: fuma-nama
- License: mit
- Created: 2022-08-08T14:57:57.000Z (over 2 years ago)
- Default Branch: master
- Last Pushed: 2023-07-26T12:19:20.000Z (over 1 year ago)
- Last Synced: 2024-12-31T09:31:50.886Z (21 days ago)
- Topics: dashboard, dashboard-templates, discord, discord-bot, discord-bot-dashboard, discord-bot-website, javascript, web
- Language: JavaScript
- Homepage:
- Size: 21.7 MB
- Stars: 96
- Watchers: 2
- Forks: 51
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
> Next generation of the Dashboard is out!
> https://github.com/SonMooSans/discord-bot-dashboard-2![Demo](document/img.png)
# D-Dash: Discord Bot Dashboard
A Full-Featured Dashboard Template for Discord Bots
You can modify `config/config.js` to edit configuration without touching the codes
Feel free to contribute this project**Watch the Demo on [YouTube](https://youtu.be/Z90Ax-v4uH4)**
## Features
* Modern Design with Chakra UI
* Localization Support (English and Chinese)
* Customizable UI (`config.js`)
* Built-in **Features** and **Actions** System
* Existing Backend Implementation## Getting Started
**First, clone this Template**
```
git clone https://github.com/SonMooSans/discord-bot-dashboard.git
```D-Dash is not just a Template, it supports to add **Feature** and **Action** in configuration
Therefore, it requires a full Backend Implementation.
For the implementation in Kotlin, See the [Example](https://github.com/SonMooSans/discord-bot-dashboard-backend)You may implement your own Backend APi in another languages by implementing routes mentioned in its README
## Configuration
Go to the [config.js](src/config/config.js)
This configuration allows you to customize the UI, there is a `config.d.ts` for type annotations### Normal Settings
You need to specify the API Url and invite url of your bot
You might also add footer items in configuration
```javascript
const config = {
name: "Bot Name",
footer: [
{
name: "Hello World",
url: "https://github.com"
}
],
//API url
serverUrl: "http://localhost:8080",
//Invite url of your bot
inviteUrl: "https://discord.com/api/oauth2/authorize?client_id=1004280473956139038&permissions=8&scope=bot",
}
```### Display Data or Statistics
You can customize data to display in your dashboard.
#### Items function
it reads `detail` and `state`, then returns `DataItem` array which determines what to display#### Dashboard Data
It is an Array of Dashboard Data Row, you can customize options of each row to get additional data from `state`Each Data Row contains a items function
You can set `advanced` to true, so the dashboard will fetch `/guild/:guild/detail/advanced` and pass the result to the function by `state.advanced`
It will be displayed in **Statistics** Tab#### Actions and Features Data
They are both **Items function**It will be displayed in **Actions** and **Features** Tab
you can display the statistics of things like **Ranks**, **Reaction Role**```javascript
const config = {
data: {
dashboard: [
{
advanced: true,
count: 3, //count of placeholders
//advanced will be null if row.advanced is false
items: (detail, {advanced}) => [
DataItem
]
}
],
actions: detail => [
DataItem
],
features: detail => [
DataItem
]
}
}
```### Features and Actions
You must define bot features and actions in configuration
Also, the Features and Actions System must be implemented at your API#### Feature
**Feature** is something that can be enabled or disabled, after enabling a feature.
User can edit its options and customize the behavior of bot#### Action
**Action** contains multi **Tasks**, User can publish or delete Tasks
User must define some options before publishing a taskAction can be used for `Reaction Role` since you might want the Reaction Role can be enabled for multi messages
#### Options
Each Feature and Action requires an options array used to customize settings
When user updates options, server will receive a map of ids and its valueThe **Options Function** will receive the `values` of feature/action fetched from server
For **Action**, values will be null before user publish the Task```javascript
const config = {
features: {
"id_of_feature": {
name: "Welcome Message",
description: "Send a Mesage to welcome a member when they just joined the Server",
options: (values) => [
//Example option
{
id: "message",
name: "Message",
description: "The message to be sent",
type: OptionTypes.Message_Create, //A Message/Embed Creator
value: values? values.message : "",
}
]
}
},
actions: {
"id_of_action": {
name: "Reaction Role",
description: "Give user a role when reacts to a Message",
//values will be null before user publish the Task
options: (values) => [
//Example option
{
id: "message",
name: "Message",
description: "The message to be sent",
type: OptionTypes.Message_Create, //A Message/Embed Creator
value: values? values.message : "",
},
]
}
}
}
```### Multi Languages
Some fields support Multi Languages
You can see their type annotations to check about itFor those fields, you can use:
```javascript
text = {
zh: "Chinese",
en: "English"
}
```For now, we only supports **English (en)** or **Chinese (zh)**.
You can use `` on some fields since they may supports `JSXElement`## the Template of Template
This Dashboard is Based on [Horizon UI ⚡️](https://horizon-ui.com/horizon-ui-chakra)