2.2.2 ⢠Published 2 years ago
narze-youtube-chat v2.2.2
youtube-chat
Fetch YouTube live chat without API
⢠You will need to take full responsibility for your action ā¢
Getting started
- Install
npm i youtube-chatyarn add youtube-chat
- Import
- Javascript
const { LiveChat } = require("youtube-chat")- Typescript
import { LiveChat } from "youtube-chat" Create instance with ChannelID or LiveID
// If channelId is specified, liveId in the current stream is automatically acquired. // Recommended const liveChat = new LiveChat({channelId: "CHANNEL_ID_HERE"}) // Or specify LiveID in Stream manually. const liveChat = new LiveChat({liveId: "LIVE_ID_HERE"})Add events
// Emit at start of observation chat. // liveId: string liveChat.on("start", (liveId) => { /* Your code here! */ }) // Emit at end of observation chat. // reason: string? liveChat.on("end", (reason) => { /* Your code here! */ }) // Emit at receive chat. // chat: ChatItem liveChat.on("chat", (chatItem) => { /* Your code here! */ }) // Emit when an error occurs // err: Error or any liveChat.on("error", (err) => { /* Your code here! */ })Start
// Start fetch loop const ok = await liveChat.start() if (!ok) { console.log("Failed to start, check emitted error") }- Stop loop
liveChat.stop()
Types
ChatItem
interface ChatItem {
author: {
name: string
thumbnail?: ImageItem
channelId: string
badge?: {
thumbnail: ImageItem
label: string
}
}
message: MessageItem[]
superchat?: {
amount: string
color: string
sticker?: ImageItem
}
isMembership: boolean
isVerified: boolean
isOwner: boolean
isModerator: boolean
timestamp: Date
}MessageItem
type MessageItem = { text: string } | EmojiItemImageItem
interface ImageItem {
url: string
alt: string
}EmojiItem
interface EmojiItem extends ImageItem {
emojiText: string
isCustomEmoji: boolean
}References
Thank you!š