"use strict"; const $ = require("jquery"); const socket = require("../socket"); const templates = require("../../views"); const sidebar = $("#sidebar"); const utils = require("../utils"); const {vueApp, initChannel, findChannel} = require("../vue"); socket.on("network", function(data) { const network = data.networks[0]; network.isJoinChannelShown = false; network.isCollapsed = false; network.channels.forEach(initChannel); vueApp.networks.push(network); vueApp.$nextTick(() => { sidebar .find(".chan") .last() .trigger("click"); }); $("#connect") .find(".btn") .prop("disabled", false); }); socket.on("network:options", function(data) { vueApp.networks.find((n) => n.uuid === data.network).serverOptions = data.serverOptions; }); socket.on("network:status", function(data) { const network = vueApp.networks.find((n) => n.uuid === data.network); if (!network) { return; } network.status.connected = data.connected; network.status.secure = data.secure; if (!data.connected) { network.channels.forEach((channel) => { channel.users = []; channel.state = 0; }); } }); socket.on("channel:state", function(data) { const channel = findChannel(data.chan); if (channel) { channel.channel.state = data.state; } }); socket.on("network:info", function(data) { $("#connect") .html(templates.windows.connect(data)) .find("form") .on("submit", function() { const uuid = $(this) .find("input[name=uuid]") .val(); const newName = $(this) .find("#connect\\:name") .val(); const network = vueApp.networks.find((n) => n.uuid === uuid); network.name = network.channels[0].name = newName; sidebar.find(`.network[data-uuid="${uuid}"] .chan.lobby .name`).click(); }); utils.togglePasswordField("#connect .reveal-password"); });