Merge pull request #1315 from vector-im/SimonBrandner/fix/broken-urls
This commit is contained in:
@@ -102,12 +102,12 @@ export const getUrlParams = (
|
|||||||
pathname = window.location.pathname,
|
pathname = window.location.pathname,
|
||||||
hash = window.location.hash
|
hash = window.location.hash
|
||||||
): UrlParams => {
|
): UrlParams => {
|
||||||
let roomAlias: string | undefined;
|
let roomAlias: string | null = null;
|
||||||
if (!ignoreRoomAlias) {
|
if (!ignoreRoomAlias) {
|
||||||
if (hash === "") {
|
if (hash === "") {
|
||||||
roomAlias = pathname.substring(1); // Strip the "/"
|
roomAlias = pathname.substring(1); // Strip the "/"
|
||||||
|
|
||||||
// Delete "/room/" and "?", if present
|
// Delete "/room/", if present
|
||||||
if (roomAlias.startsWith("room/")) {
|
if (roomAlias.startsWith("room/")) {
|
||||||
roomAlias = roomAlias.substring("room/".length);
|
roomAlias = roomAlias.substring("room/".length);
|
||||||
}
|
}
|
||||||
@@ -123,6 +123,14 @@ export const getUrlParams = (
|
|||||||
if (!roomAlias.includes(":")) {
|
if (!roomAlias.includes(":")) {
|
||||||
roomAlias = `${roomAlias}:${Config.defaultServerName()}`;
|
roomAlias = `${roomAlias}:${Config.defaultServerName()}`;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Delete "?" and what comes afterwards
|
||||||
|
roomAlias = roomAlias.split("?")[0];
|
||||||
|
|
||||||
|
// Make roomAlias undefined, if empty
|
||||||
|
if (roomAlias.length <= 1) {
|
||||||
|
roomAlias = null;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
const fragmentQueryStart = hash.indexOf("?");
|
const fragmentQueryStart = hash.indexOf("?");
|
||||||
@@ -145,9 +153,17 @@ export const getUrlParams = (
|
|||||||
|
|
||||||
const fontScale = parseFloat(getParam("fontScale") ?? "");
|
const fontScale = parseFloat(getParam("fontScale") ?? "");
|
||||||
|
|
||||||
|
// Make sure roomId is valid
|
||||||
|
let roomId: string | null = getParam("roomId");
|
||||||
|
if (!roomId?.startsWith("!")) {
|
||||||
|
roomId = null;
|
||||||
|
} else if (!roomId.includes("")) {
|
||||||
|
roomId = null;
|
||||||
|
}
|
||||||
|
|
||||||
return {
|
return {
|
||||||
roomAlias: !roomAlias || roomAlias.includes("!") ? null : roomAlias,
|
roomAlias,
|
||||||
roomId: getParam("roomId"),
|
roomId,
|
||||||
viaServers: getAllParams("via"),
|
viaServers: getAllParams("via"),
|
||||||
isEmbedded: hasParam("embed"),
|
isEmbedded: hasParam("embed"),
|
||||||
preload: hasParam("preload"),
|
preload: hasParam("preload"),
|
||||||
|
|||||||
@@ -15,7 +15,6 @@ limitations under the License.
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
import { FC, useEffect, useState, useCallback } from "react";
|
import { FC, useEffect, useState, useCallback } from "react";
|
||||||
import { useTranslation } from "react-i18next";
|
|
||||||
|
|
||||||
import type { GroupCall } from "matrix-js-sdk/src/webrtc/groupCall";
|
import type { GroupCall } from "matrix-js-sdk/src/webrtc/groupCall";
|
||||||
import { useClientLegacy } from "../ClientContext";
|
import { useClientLegacy } from "../ClientContext";
|
||||||
@@ -25,12 +24,10 @@ import { GroupCallLoader } from "./GroupCallLoader";
|
|||||||
import { GroupCallView } from "./GroupCallView";
|
import { GroupCallView } from "./GroupCallView";
|
||||||
import { useUrlParams } from "../UrlParams";
|
import { useUrlParams } from "../UrlParams";
|
||||||
import { useRegisterPasswordlessUser } from "../auth/useRegisterPasswordlessUser";
|
import { useRegisterPasswordlessUser } from "../auth/useRegisterPasswordlessUser";
|
||||||
import { translatedError } from "../TranslatedError";
|
|
||||||
import { useOptInAnalytics } from "../settings/useSetting";
|
import { useOptInAnalytics } from "../settings/useSetting";
|
||||||
|
import { HomePage } from "../home/HomePage";
|
||||||
|
|
||||||
export const RoomPage: FC = () => {
|
export const RoomPage: FC = () => {
|
||||||
const { t } = useTranslation();
|
|
||||||
|
|
||||||
const {
|
const {
|
||||||
roomAlias,
|
roomAlias,
|
||||||
roomId,
|
roomId,
|
||||||
@@ -42,7 +39,9 @@ export const RoomPage: FC = () => {
|
|||||||
displayName,
|
displayName,
|
||||||
} = useUrlParams();
|
} = useUrlParams();
|
||||||
const roomIdOrAlias = roomId ?? roomAlias;
|
const roomIdOrAlias = roomId ?? roomAlias;
|
||||||
if (!roomIdOrAlias) throw translatedError("No room specified", t);
|
if (!roomIdOrAlias) {
|
||||||
|
console.error("No room specified");
|
||||||
|
}
|
||||||
|
|
||||||
const [optInAnalytics, setOptInAnalytics] = useOptInAnalytics();
|
const [optInAnalytics, setOptInAnalytics] = useOptInAnalytics();
|
||||||
const { registerPasswordlessUser } = useRegisterPasswordlessUser();
|
const { registerPasswordlessUser } = useRegisterPasswordlessUser();
|
||||||
@@ -99,6 +98,10 @@ export const RoomPage: FC = () => {
|
|||||||
return <RoomAuthView />;
|
return <RoomAuthView />;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (!roomIdOrAlias) {
|
||||||
|
return <HomePage />;
|
||||||
|
}
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<GroupCallLoader
|
<GroupCallLoader
|
||||||
client={client}
|
client={client}
|
||||||
|
|||||||
@@ -19,7 +19,7 @@ import { getUrlParams } from "../src/UrlParams";
|
|||||||
import { Config } from "../src/config/Config";
|
import { Config } from "../src/config/Config";
|
||||||
|
|
||||||
const ROOM_NAME = "roomNameHere";
|
const ROOM_NAME = "roomNameHere";
|
||||||
const ROOM_ID = "d45f138fsd";
|
const ROOM_ID = "!d45f138fsd";
|
||||||
const ORIGIN = "https://call.element.io";
|
const ORIGIN = "https://call.element.io";
|
||||||
const HOMESERVER = "call.ems.host";
|
const HOMESERVER = "call.ems.host";
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user