Skip to content

romestylez/multi-chat-overlay

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

24 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Chat Overlay (Twitch + Kick + 7TV + BetterTTV + FrankerFaceZ)

A simple overlay for OBS that displays Twitch chat and Kick chat simultaneously, including 7TV, BetterTTV and FrankerFaceZ emotes.
The overlay runs completely locally in OBS as a Browser Source – no external service required.


🚀 Features

  • Display Twitch and Kick chat
  • Support for Twitch emotes, 7TV emotes, BetterTTV emotes and FrankerFaceZ emotes
  • Unified layout with CSS (font, size, emote alignment)
  • Blacklist support: ignore messages from specific users (e.g. bots)

📦 Installation

  1. Clone or download the repository:

    git clone https://github.com/YOURNAME/chat-overlay.git
    cd chat-overlay
  2. Copy the example config:

    cp config.js.example config.js
  3. Enter your own values in config.js:

    • Twitch channel name
    • Twitch OAuth token
    • Kick App Key + Chatroom ID
    • 7TV user ID
    • BTTV Twitch user ID
    • (optional) Blocked users list
  4. In OBS, add a Browser Source:

    • Select the local file: overlay.html
    • Set the size, e.g., 800x600 or whatever fits your layout

🔑 Required Data

Twitch

  • TWITCH_CHANNEL = your Twitch channel name (e.g. smtxlost)
  • TWITCH_OAUTH = Chat token in the format oauth:xxxxxxxxxxxx

👉 How to get your token:

⚠️ Note: Tokens can expire. If that happens, you’ll need to generate a new one.

Kick

  • KICK_APP_KEY and KICK_CLUSTERpublic values used by Kick for all users (not secret, usually 32cbd69e4b950bf97679 and us2)
  • KICK_CHATROOM_ID → unique per channel. Find it via the API:
    https://kick.com/api/v1/channels/YOUR_CHANNEL
    Look in the JSON for: chatroom":{"id":...}

7TV

BTTV

FrankerFaceZ (FFZ)

  • FFZ_CHANNEL → your Twitch channel name (same as TWITCH_CHANNEL)
    Used to load your channel-specific FrankerFaceZ emotes.

User Blacklist

  • BLOCKED_USERS → an array of usernames to ignore (case-insensitive).
    Example:
    BLOCKED_USERS: ["nightbot", "streamelements", "moobot"]
    Messages from these users will not appear in the overlay.

📄 License

MIT License – free to use and adapt.

About

OBS browser source overlay for Twitch & Kick chat with 7TV and BTTV emotes.

Topics

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published