diff --git a/client/js/lounge.js b/client/js/lounge.js index 3aa7ebc9..1f5a5251 100644 --- a/client/js/lounge.js +++ b/client/js/lounge.js @@ -318,9 +318,9 @@ $(function() { if (history && history.pushState) { if (data && data.replaceHistory && history.replaceState) { - history.replaceState(state, null, null); + history.replaceState(state, null, target); } else { - history.pushState(state, null, null); + history.pushState(state, null, target); } } }); @@ -486,7 +486,8 @@ $(function() { } }); }); - if ($("body").hasClass("public")) { + + if ($("body").hasClass("public") && window.location.hash === "#connect") { $("#connect").one("show", function() { var params = URI(document.location.search); params = params.search(true); diff --git a/client/js/socket-events/init.js b/client/js/socket-events/init.js index a78c07fa..cd66f391 100644 --- a/client/js/socket-events/init.js +++ b/client/js/socket-events/init.js @@ -32,7 +32,10 @@ socket.on("init", function(data) { const target = sidebar.find("[data-id='" + id + "']").trigger("click", { replaceHistory: true }); - if (target.length === 0) { + const dataTarget = document.querySelector("[data-target='" + window.location.hash + "']"); + if (window.location.hash && dataTarget) { + dataTarget.click(); + } else if (target.length === 0) { const first = sidebar.find(".chan") .eq(0) .trigger("click");