"use strict"; const $ = require("jquery"); const escape = require("css.escape"); const socket = require("../socket"); const webpush = require("../webpush"); const slideoutMenu = require("../slideout"); const sidebar = $("#sidebar"); const storage = require("../localStorage"); const utils = require("../utils"); const {vueApp} = require("../vue"); socket.on("init", function(data) { $("#loading-page-message, #connection-error").text("Rendering…"); let previousActive = vueApp.activeChannel && vueApp.activeChannel.channel.id; const networks = new Set(JSON.parse(storage.get("thelounge.networks.collapsed"))); for (const network of data.networks) { const currentNetwork = vueApp.networks.find((n) => n.uuid === network.uuid); // TODO: Make this updating more efficient if (currentNetwork) { network.isJoinChannelShown = currentNetwork.isJoinChannelShown; network.isCollapsed = currentNetwork.isCollapsed; for (const channel of network.channels) { const currentChannel = currentNetwork.channels.find((c) => c.id === channel.id); if (currentChannel && currentChannel.messages) { channel.scrolledToBottom = currentChannel.scrolledToBottom; channel.messages = currentChannel.messages.concat(channel.messages); if (currentChannel.moreHistoryAvailable) { channel.moreHistoryAvailable = true; } } } } else { network.isJoinChannelShown = false; network.isCollapsed = networks.has(network.uuid); } for (const channel of network.channels) { if (channel.type === "channel") { channel.usersOutdated = true; } } } vueApp.networks = data.networks; vueApp.connected = true; $("#connection-error").removeClass("shown"); if (!vueApp.initialized) { vueApp.initialized = true; if (data.token) { storage.set("token", data.token); } webpush.configurePushNotifications(data.pushSubscription, data.applicationServerKey); slideoutMenu.enable(); const viewport = $("#viewport"); const viewportWidth = $(window).outerWidth(); let isUserlistOpen = storage.get("thelounge.state.userlist"); if (viewportWidth > utils.mobileViewportPixels) { slideoutMenu.toggle(storage.get("thelounge.state.sidebar") !== "false"); } // If The Lounge is opened on a small screen (less than 1024px), and we don't have stored // user list state, close it by default if (viewportWidth >= 1024 && isUserlistOpen !== "true" && isUserlistOpen !== "false") { isUserlistOpen = "true"; } viewport.toggleClass("userlist-open", isUserlistOpen === "true"); $(document.body).removeClass("signed-out"); $("#loading").remove(); $("#sign-in").remove(); if (window.g_LoungeErrorHandler) { window.removeEventListener("error", window.g_LoungeErrorHandler); window.g_LoungeErrorHandler = null; } } vueApp.$nextTick(() => openCorrectChannel(previousActive, data.active)); utils.confirmExit(); for (const network of vueApp.networks) { for (const channel of network.channels) { if (channel.highlight > 0) { utils.updateTitle(); utils.toggleNotificationMarkers(true); return; } } } }); function openCorrectChannel(clientActive, serverActive) { let target = $(); // Open last active channel if (clientActive > 0) { target = sidebar.find(`.chan[data-id="${clientActive}"]`); } // Open window provided in location.hash if (target.length === 0 && window.location.hash) { target = $(`[data-target="${escape(window.location.hash)}"]`).first(); } // Open last active channel according to the server if (serverActive > 0 && target.length === 0) { target = sidebar.find(`.chan[data-id="${serverActive}"]`); } // Open first available channel if (target.length === 0) { target = sidebar.find(".chan").first(); } // If target channel is found, open it if (target.length > 0) { target.trigger("click", { replaceHistory: true, }); return; } // Open the connect window $("#footer .connect").trigger("click", { pushState: false, }); }