refacto(front): whitebardId init
* More straightforward * Use std for getting url params * Show the final whiteboardid in url
This commit is contained in:
parent
b11520788e
commit
d268eb6d93
@ -8,29 +8,37 @@ import pdfjsLib from "pdfjs-dist/webpack";
|
|||||||
import shortcutFunctions from "./shortcutFunctions";
|
import shortcutFunctions from "./shortcutFunctions";
|
||||||
import ReadOnlyService from "./services/ReadOnlyService";
|
import ReadOnlyService from "./services/ReadOnlyService";
|
||||||
import InfoService from "./services/InfoService";
|
import InfoService from "./services/InfoService";
|
||||||
import { getQueryVariable, getSubDir } from "./utils";
|
import { getSubDir } from "./utils";
|
||||||
import ConfigService from "./services/ConfigService";
|
import ConfigService from "./services/ConfigService";
|
||||||
import { v4 as uuidv4 } from "uuid";
|
import { v4 as uuidv4 } from "uuid";
|
||||||
|
|
||||||
let whiteboardId = getQueryVariable("whiteboardid");
|
|
||||||
const randomid = getQueryVariable("randomid");
|
|
||||||
if (randomid && !whiteboardId) {
|
|
||||||
//set random whiteboard on empty whiteboardid
|
|
||||||
whiteboardId = uuidv4();
|
|
||||||
const urlParams = new URLSearchParams(window.location.search);
|
const urlParams = new URLSearchParams(window.location.search);
|
||||||
|
let whiteboardId = urlParams.get("whiteboardid");
|
||||||
|
const randomid = urlParams.get("randomid");
|
||||||
|
|
||||||
|
if (randomid) {
|
||||||
|
whiteboardId = uuidv4();
|
||||||
urlParams.delete("randomid");
|
urlParams.delete("randomid");
|
||||||
|
window.location.search = urlParams;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!whiteboardId) {
|
||||||
|
whiteboardId = "myNewWhiteboard";
|
||||||
|
}
|
||||||
|
|
||||||
|
whiteboardId = unescape(encodeURIComponent(whiteboardId)).replace(/[^a-zA-Z0-9\-]/g, "");
|
||||||
|
|
||||||
|
if (urlParams.get("whiteboardid") !== whiteboardId) {
|
||||||
urlParams.set("whiteboardid", whiteboardId);
|
urlParams.set("whiteboardid", whiteboardId);
|
||||||
window.location.search = urlParams;
|
window.location.search = urlParams;
|
||||||
}
|
}
|
||||||
|
|
||||||
whiteboardId = whiteboardId || "myNewWhiteboard";
|
const myUsername = urlParams.get("username") || "unknown" + (Math.random() + "").substring(2, 6);
|
||||||
whiteboardId = unescape(encodeURIComponent(whiteboardId)).replace(/[^a-zA-Z0-9\-]/g, "");
|
const accessToken = urlParams.get("accesstoken") || "";
|
||||||
const myUsername = getQueryVariable("username") || "unknown" + (Math.random() + "").substring(2, 6);
|
|
||||||
const accessToken = getQueryVariable("accesstoken") || "";
|
|
||||||
|
|
||||||
// Custom Html Title
|
// Custom Html Title
|
||||||
const title = getQueryVariable("title");
|
const title = urlParams.get("title");
|
||||||
if (!title === false) {
|
if (title) {
|
||||||
document.title = decodeURIComponent(title);
|
document.title = decodeURIComponent(title);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -131,7 +139,7 @@ function initWhiteboard() {
|
|||||||
// by default set in readOnly mode
|
// by default set in readOnly mode
|
||||||
ReadOnlyService.activateReadOnlyMode();
|
ReadOnlyService.activateReadOnlyMode();
|
||||||
|
|
||||||
if (getQueryVariable("webdav") == "true") {
|
if (urlParams.get("webdav") === "true") {
|
||||||
$("#uploadWebDavBtn").show();
|
$("#uploadWebDavBtn").show();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -15,23 +15,6 @@ export function getCurrentTimeMs() {
|
|||||||
return new Date().getTime();
|
return new Date().getTime();
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* get 'GET' parameter by variable name
|
|
||||||
* @param variable
|
|
||||||
* @return {boolean|*}
|
|
||||||
*/
|
|
||||||
export function getQueryVariable(variable) {
|
|
||||||
const query = window.location.search.substring(1);
|
|
||||||
const vars = query.split("&");
|
|
||||||
for (let i = 0; i < vars.length; i++) {
|
|
||||||
const pair = vars[i].split("=");
|
|
||||||
if (pair[0] === variable) {
|
|
||||||
return pair[1];
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
export function getSubDir() {
|
export function getSubDir() {
|
||||||
const url = document.URL.substr(0, document.URL.lastIndexOf("/"));
|
const url = document.URL.substr(0, document.URL.lastIndexOf("/"));
|
||||||
const urlSplit = url.split("/");
|
const urlSplit = url.split("/");
|
||||||
|
@ -64,7 +64,6 @@ const whiteboard = {
|
|||||||
this.settings[i] = newSettings[i];
|
this.settings[i] = newSettings[i];
|
||||||
}
|
}
|
||||||
this.settings["username"] = this.settings["username"].replace(/[^0-9a-z]/gi, "");
|
this.settings["username"] = this.settings["username"].replace(/[^0-9a-z]/gi, "");
|
||||||
this.settings["whiteboardId"] = this.settings["whiteboardId"].replace(/[^0-9a-z]/gi, "");
|
|
||||||
|
|
||||||
//background grid (repeating image) and smallest screen indication
|
//background grid (repeating image) and smallest screen indication
|
||||||
_this.backgroundGrid = $(
|
_this.backgroundGrid = $(
|
||||||
|
Loading…
Reference in New Issue
Block a user