A little cleanup
This commit is contained in:
parent
104692007f
commit
cebfa6ac84
@ -3,7 +3,6 @@
|
|||||||
const $ = require("jquery");
|
const $ = require("jquery");
|
||||||
const escapeRegExp = require("lodash/escapeRegExp");
|
const escapeRegExp = require("lodash/escapeRegExp");
|
||||||
const storage = require("./localStorage");
|
const storage = require("./localStorage");
|
||||||
const tz = require("./libs/handlebars/tz");
|
|
||||||
const socket = require("./socket");
|
const socket = require("./socket");
|
||||||
const {vueApp} = require("./vue");
|
const {vueApp} = require("./vue");
|
||||||
require("../js/autocompletion");
|
require("../js/autocompletion");
|
||||||
|
@ -18,20 +18,31 @@ socket.on("init", function(data) {
|
|||||||
const networks = new Set(JSON.parse(storage.get("thelounge.networks.collapsed")));
|
const networks = new Set(JSON.parse(storage.get("thelounge.networks.collapsed")));
|
||||||
|
|
||||||
for (const network of data.networks) {
|
for (const network of data.networks) {
|
||||||
|
network.isCollapsed = networks.has(network.uuid);
|
||||||
|
network.channels.forEach(initChannel);
|
||||||
|
|
||||||
const currentNetwork = vueApp.networks.find((n) => n.uuid === network.uuid);
|
const currentNetwork = vueApp.networks.find((n) => n.uuid === network.uuid);
|
||||||
|
|
||||||
// TODO: Make this updating more efficient
|
// If we are reconnecting, merge existing state variables because they don't exist on the server
|
||||||
if (currentNetwork) {
|
if (!currentNetwork) {
|
||||||
|
network.isJoinChannelShown = false;
|
||||||
|
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
network.isJoinChannelShown = currentNetwork.isJoinChannelShown;
|
network.isJoinChannelShown = currentNetwork.isJoinChannelShown;
|
||||||
network.isCollapsed = currentNetwork.isCollapsed;
|
|
||||||
|
|
||||||
for (const channel of network.channels) {
|
for (const channel of network.channels) {
|
||||||
const currentChannel = currentNetwork.channels.find((c) => c.id === channel.id);
|
const currentChannel = currentNetwork.channels.find((c) => c.id === channel.id);
|
||||||
|
|
||||||
if (currentChannel) {
|
if (!currentChannel) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
channel.scrolledToBottom = currentChannel.scrolledToBottom;
|
channel.scrolledToBottom = currentChannel.scrolledToBottom;
|
||||||
channel.pendingMessage = currentChannel.pendingMessage;
|
channel.pendingMessage = currentChannel.pendingMessage;
|
||||||
|
|
||||||
|
// Reconnection only sends new messages, so merge it on the client
|
||||||
if (currentChannel.messages) {
|
if (currentChannel.messages) {
|
||||||
channel.messages = currentChannel.messages.concat(channel.messages);
|
channel.messages = currentChannel.messages.concat(channel.messages);
|
||||||
}
|
}
|
||||||
@ -41,13 +52,6 @@ socket.on("init", function(data) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else {
|
|
||||||
network.isJoinChannelShown = false;
|
|
||||||
network.isCollapsed = networks.has(network.uuid);
|
|
||||||
}
|
|
||||||
|
|
||||||
network.channels.forEach(initChannel);
|
|
||||||
}
|
|
||||||
|
|
||||||
vueApp.networks = data.networks;
|
vueApp.networks = data.networks;
|
||||||
vueApp.connected = true;
|
vueApp.connected = true;
|
||||||
|
@ -14,10 +14,6 @@ socket.on("network", function(data) {
|
|||||||
network.isCollapsed = false;
|
network.isCollapsed = false;
|
||||||
network.channels.forEach(initChannel);
|
network.channels.forEach(initChannel);
|
||||||
|
|
||||||
for (const channel of network.channels) {
|
|
||||||
initChannel(channel);
|
|
||||||
}
|
|
||||||
|
|
||||||
vueApp.networks.push(network);
|
vueApp.networks.push(network);
|
||||||
|
|
||||||
vueApp.$nextTick(() => {
|
vueApp.$nextTick(() => {
|
||||||
|
Loading…
Reference in New Issue
Block a user