This commit is contained in:
parent
14adead519
commit
c0e4f647a2
@ -19,15 +19,6 @@ func Setup(listener models.ChatListener) {
|
|||||||
pingCh := make(chan models.PingMessage)
|
pingCh := make(chan models.PingMessage)
|
||||||
doneCh := make(chan bool)
|
doneCh := make(chan bool)
|
||||||
errCh := make(chan error)
|
errCh := make(chan error)
|
||||||
|
|
||||||
// Demo messages only. Remove me eventually!!!
|
|
||||||
messages = append(messages, models.ChatMessage{"", "Tom Nook", "I'll be there with Bells on! Ho ho!", "https://gamepedia.cursecdn.com/animalcrossingpocketcamp_gamepedia_en/thumb/4/4f/Timmy_Icon.png/120px-Timmy_Icon.png?version=87b38d7d6130411d113486c2db151385", "demo-message-1", "CHAT", true, time.Now()})
|
|
||||||
messages = append(messages, models.ChatMessage{"", "Redd", "Fool me once, shame on you. Fool me twice, stop foolin' me.", "https://vignette.wikia.nocookie.net/animalcrossing/images/3/3d/Redd2.gif/revision/latest?cb=20100710004252", "demo-message-2", "CHAT", true, time.Now()})
|
|
||||||
messages = append(messages, models.ChatMessage{"", "Kevin", "You just caught me before I was about to go work out weeweewee!", "https://vignette.wikia.nocookie.net/animalcrossing/images/2/20/NH-Kevin_poster.png/revision/latest/scale-to-width-down/100?cb=20200410185817", "demo-message-3", "CHAT", true, time.Now()})
|
|
||||||
messages = append(messages, models.ChatMessage{"", "Isabelle", " Isabelle is the mayor's highly capable secretary. She can be forgetful sometimes, but you can always count on her for information about the town. She wears her hair up in a bun that makes her look like a shih tzu. Mostly because she is one! She also has a twin brother named Digby.", "https://dodo.ac/np/images/thumb/7/7b/IsabelleTrophyWiiU.png/200px-IsabelleTrophyWiiU.png", "demo-message-4", "CHAT", true, time.Now()})
|
|
||||||
messages = append(messages, models.ChatMessage{"", "Judy", "myohmy, I'm dancing my dreams away.", "https://vignette.wikia.nocookie.net/animalcrossing/images/5/50/NH-Judy_poster.png/revision/latest/scale-to-width-down/100?cb=20200522063219", "demo-message-5", "CHAT", true, time.Now()})
|
|
||||||
messages = append(messages, models.ChatMessage{"", "Blathers", "Blathers is an owl with brown feathers. His face is white and he has a yellow beak. His arms are wing shaped and he has yellow talons. His eyes are very big with small black irises. He also has big pink cheek circles on his cheeks. His belly appears to be checkered in diamonds with light brown and white squares, similar to an argyle vest, which is traditionally associated with academia. His green bowtie further alludes to his academic nature.", "https://vignette.wikia.nocookie.net/animalcrossing/images/b/b3/NH-character-Blathers.png/revision/latest?cb=20200229053519", "demo-message-6", "CHAT", true, time.Now()})
|
|
||||||
|
|
||||||
messages = append(messages, getChatHistory()...)
|
messages = append(messages, getChatHistory()...)
|
||||||
|
|
||||||
_server = &server{
|
_server = &server{
|
||||||
|
@ -8,6 +8,7 @@ import (
|
|||||||
log "github.com/sirupsen/logrus"
|
log "github.com/sirupsen/logrus"
|
||||||
"golang.org/x/net/websocket"
|
"golang.org/x/net/websocket"
|
||||||
|
|
||||||
|
"github.com/gabek/owncast/config"
|
||||||
"github.com/gabek/owncast/models"
|
"github.com/gabek/owncast/models"
|
||||||
)
|
)
|
||||||
|
|
||||||
@ -98,6 +99,7 @@ func (s *server) Listen() {
|
|||||||
s.Clients[c.id] = c
|
s.Clients[c.id] = c
|
||||||
|
|
||||||
s.listener.ClientAdded(c.id)
|
s.listener.ClientAdded(c.id)
|
||||||
|
s.sendWelcomeMessageToClient(c)
|
||||||
|
|
||||||
// remove a client
|
// remove a client
|
||||||
case c := <-s.delCh:
|
case c := <-s.delCh:
|
||||||
@ -121,3 +123,14 @@ func (s *server) Listen() {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (s *server) sendWelcomeMessageToClient(c *Client) {
|
||||||
|
go func() {
|
||||||
|
time.Sleep(5 * time.Second)
|
||||||
|
|
||||||
|
initialChatMessageText := fmt.Sprintf("Welcome to %s! %s", config.Config.InstanceDetails.Title, config.Config.InstanceDetails.Summary)
|
||||||
|
initialMessage := models.ChatMessage{"owncast-server", config.Config.InstanceDetails.Name, initialChatMessageText, config.Config.InstanceDetails.Logo["small"], "initial-message-1", "CHAT", true, time.Now()}
|
||||||
|
c.Write(initialMessage)
|
||||||
|
}()
|
||||||
|
|
||||||
|
}
|
||||||
|
@ -15,7 +15,8 @@
|
|||||||
</head>
|
</head>
|
||||||
|
|
||||||
<body class="bg-gray-300 text-gray-800">
|
<body class="bg-gray-300 text-gray-800">
|
||||||
<div id="app-container" v-cloak class="flex no-chat">
|
|
||||||
|
<div id="app-container" class="flex chat">
|
||||||
<div id="top-content">
|
<div id="top-content">
|
||||||
<header class="flex border-b border-gray-900 border-solid shadow-md">
|
<header class="flex border-b border-gray-900 border-solid shadow-md">
|
||||||
<h1 v-cloak class="flex text-gray-400">
|
<h1 v-cloak class="flex text-gray-400">
|
||||||
|
@ -293,6 +293,6 @@ class Owncast {
|
|||||||
}
|
}
|
||||||
|
|
||||||
setChatHistory(messages) {
|
setChatHistory(messages) {
|
||||||
this.vueApp.messages = messages;
|
this.vueApp.messages = messages.concat(this.vueApp.messages);
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
@ -91,7 +91,7 @@ class MessagingInterface {
|
|||||||
getLocalStorage(KEY_AVATAR) || generateAvatar(`${this.username}${Date.now()}`);
|
getLocalStorage(KEY_AVATAR) || generateAvatar(`${this.username}${Date.now()}`);
|
||||||
this.updateUsernameFields(this.username);
|
this.updateUsernameFields(this.username);
|
||||||
|
|
||||||
this.chatDisplayed = getLocalStorage(KEY_CHAT_DISPLAYED) || false;
|
this.chatDisplayed = getLocalStorage(KEY_CHAT_DISPLAYED) || true;
|
||||||
this.displayChat();
|
this.displayChat();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -110,6 +110,7 @@ class MessagingInterface {
|
|||||||
this.tagAppContainer.classList.add('no-chat');
|
this.tagAppContainer.classList.add('no-chat');
|
||||||
this.tagAppContainer.classList.remove('chat');
|
this.tagAppContainer.classList.remove('chat');
|
||||||
}
|
}
|
||||||
|
this.setChatPlaceholderText();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -225,6 +226,12 @@ class MessagingInterface {
|
|||||||
// clear out things.
|
// clear out things.
|
||||||
this.formMessageInput.value = '';
|
this.formMessageInput.value = '';
|
||||||
this.tagMessageFormWarning.innerText = '';
|
this.tagMessageFormWarning.innerText = '';
|
||||||
|
|
||||||
|
const hasSentFirstChatMessage = getLocalStorage(KEY_CHAT_FIRST_MESSAGE_SENT);
|
||||||
|
if (!hasSentFirstChatMessage) {
|
||||||
|
setLocalStorage(KEY_CHAT_FIRST_MESSAGE_SENT, true);
|
||||||
|
this.setChatPlaceholderText();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
disableChat() {
|
disableChat() {
|
||||||
@ -236,9 +243,18 @@ class MessagingInterface {
|
|||||||
enableChat() {
|
enableChat() {
|
||||||
if (this.formMessageInput) {
|
if (this.formMessageInput) {
|
||||||
this.formMessageInput.disabled = false;
|
this.formMessageInput.disabled = false;
|
||||||
this.formMessageInput.placeholder = "Message"
|
this.setChatPlaceholderText();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
setChatPlaceholderText() {
|
||||||
|
const firstMessageChatPlacholderText = "Type here to chat, no account necessary.";
|
||||||
|
const chatPlaceholderText = "Message"
|
||||||
|
|
||||||
|
const hasSentFirstChatMessage = getLocalStorage(KEY_CHAT_FIRST_MESSAGE_SENT);
|
||||||
|
this.formMessageInput.placeholder = hasSentFirstChatMessage ? chatPlaceholderText : firstMessageChatPlacholderText
|
||||||
|
}
|
||||||
|
|
||||||
// handle Vue.js message display
|
// handle Vue.js message display
|
||||||
onReceivedMessages(newMessages, oldMessages) {
|
onReceivedMessages(newMessages, oldMessages) {
|
||||||
if (newMessages.length !== oldMessages.length) {
|
if (newMessages.length !== oldMessages.length) {
|
||||||
|
@ -42,6 +42,7 @@ const VIDEO_OPTIONS = {
|
|||||||
const KEY_USERNAME = 'owncast_username';
|
const KEY_USERNAME = 'owncast_username';
|
||||||
const KEY_AVATAR = 'owncast_avatar';
|
const KEY_AVATAR = 'owncast_avatar';
|
||||||
const KEY_CHAT_DISPLAYED = 'owncast_chat';
|
const KEY_CHAT_DISPLAYED = 'owncast_chat';
|
||||||
|
const KEY_CHAT_FIRST_MESSAGE_SENT = 'owncast_first_message_sent';
|
||||||
|
|
||||||
const TIMER_STATUS_UPDATE = 5000; // ms
|
const TIMER_STATUS_UPDATE = 5000; // ms
|
||||||
const TIMER_WEBSOCKET_RECONNECT = 5000; // ms
|
const TIMER_WEBSOCKET_RECONNECT = 5000; // ms
|
||||||
|
Loading…
x
Reference in New Issue
Block a user