code-server-2/src/common/util.ts

68 lines
1.9 KiB
TypeScript
Raw Normal View History

2020-02-04 19:27:46 +00:00
import { logger } from "@coder/logger"
export interface Options {
base: string
commit: string
2020-02-05 23:30:09 +00:00
logLevel: number
sessionId?: string
2020-02-04 19:27:46 +00:00
}
2019-10-28 19:03:13 +00:00
/**
* Split a string up to the delimiter. If the delimiter doesn't exist the first
* item will have all the text and the second item will be an empty string.
*/
export const split = (str: string, delimiter: string): [string, string] => {
2020-02-04 19:27:46 +00:00
const index = str.indexOf(delimiter)
return index !== -1 ? [str.substring(0, index).trim(), str.substring(index + 1)] : [str, ""]
}
export const plural = (count: number): string => (count === 1 ? "" : "s")
export const generateUuid = (length = 24): string => {
const possible = "0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz"
return Array(length)
.fill(1)
.map(() => possible[Math.floor(Math.random() * possible.length)])
.join("")
}
/**
* Remove extra slashes in a URL.
*/
export const normalize = (url: string, keepTrailing = false): string => {
return url.replace(/\/\/+/g, "/").replace(/\/+$/, keepTrailing ? "/" : "")
}
2020-02-04 19:27:46 +00:00
/**
* Get options embedded in the HTML from the server.
*/
export const getOptions = <T extends Options>(): T => {
2020-02-05 00:16:45 +00:00
if (typeof document === "undefined") {
return {} as T
}
2020-02-04 19:27:46 +00:00
const el = document.getElementById("coder-options")
try {
if (!el) {
throw new Error("no options element")
}
const value = el.getAttribute("data-settings")
if (!value) {
throw new Error("no options value")
}
const options = JSON.parse(value)
if (typeof options.logLevel !== "undefined") {
logger.level = options.logLevel
}
const parts = window.location.pathname.replace(/^\//g, "").split("/")
parts[parts.length - 1] = options.base
const url = new URL(window.location.origin + "/" + parts.join("/"))
return {
...options,
base: normalize(url.pathname, true),
}
2020-02-04 19:27:46 +00:00
} catch (error) {
logger.warn(error.message)
return {} as T
}
}