fix rooting to be able to handle appRootPath

This commit is contained in:
Michael Shanks 2020-02-21 15:20:00 +00:00
parent 4b807d8f09
commit 56f00f4e1d
5 changed files with 54 additions and 11 deletions

View File

@ -45,7 +45,11 @@ export const createApp = (
currentUrl = url currentUrl = url
} }
routeTo = screenRouter(frontendDefinition.screens, onScreenSelected) routeTo = screenRouter(
frontendDefinition.screens,
onScreenSelected,
frontendDefinition.appRootPath
)
routeTo(currentUrl || window.location.pathname) routeTo(currentUrl || window.location.pathname)
} }

View File

@ -23,14 +23,14 @@ export const loadBudibase = async (opts) => {
temp: false, temp: false,
} }
const rootPath = frontendDefinition.appRootPath =
frontendDefinition.appRootPath === "" frontendDefinition.appRootPath === ""
? "" ? ""
: "/" + trimSlash(frontendDefinition.appRootPath) : "/" + trimSlash(frontendDefinition.appRootPath)
if (!componentLibraries) { if (!componentLibraries) {
const componentLibraryUrl = lib => rootPath + "/" + trimSlash(lib) const componentLibraryUrl = lib => frontendDefinition.appRootPath + "/" + trimSlash(lib)
componentLibraries = {} componentLibraries = {}
for (let lib of frontendDefinition.componentLibraries) { for (let lib of frontendDefinition.componentLibraries) {
@ -52,7 +52,7 @@ export const loadBudibase = async (opts) => {
) )
const route = _window.location const route = _window.location
? _window.location.pathname.replace(rootPath, "") ? _window.location.pathname.replace(frontendDefinition.appRootPath, "")
: ""; : "";
return { return {

View File

@ -1,16 +1,17 @@
import regexparam from "regexparam" import regexparam from "regexparam"
import { writable } from "svelte/store" import { writable } from "svelte/store"
export const screenRouter = (screens, onScreenSelected) => { export const screenRouter = (screens, onScreenSelected, appRootPath) => {
const routes = screens.map(s => s.route) const makeRootedPath = url => (appRootPath ? `${appRootPath}/${url}` : url)
const routes = screens.map(s => makeRootedPath(s.route))
let fallback = routes.findIndex(([p]) => p === "*") let fallback = routes.findIndex(([p]) => p === "*")
if (fallback < 0) fallback = 0 if (fallback < 0) fallback = 0
let current let current
function route(url) { function route(url) {
const _url = makeRootedPath(url.state || url)
const _url = url.state || url
current = routes.findIndex( current = routes.findIndex(
p => p !== "*" && new RegExp("^" + p + "$").test(_url) p => p !== "*" && new RegExp("^" + p + "$").test(_url)
) )

View File

@ -16,6 +16,20 @@ describe("screenRouting", () => {
expect(screenRoot.children[0].children[0].innerText).toBe("screen 2") expect(screenRoot.children[0].children[0].innerText).toBe("screen 2")
}) })
it("should load correct screen, for initial URL, when appRootPath is something", async () => {
const { page, screens } = pageWith3Screens()
const { dom } = await load(page, screens, "/testApp/screen2", "/testApp")
const rootDiv = dom.window.document.body.children[0]
expect(rootDiv.children.length).toBe(1)
const screenRoot = rootDiv.children[0]
expect(screenRoot.children.length).toBe(1)
expect(screenRoot.children[0].children.length).toBe(1)
expect(screenRoot.children[0].children[0].innerText).toBe("screen 2")
})
it("should be able to route to the correct screen", async () => { it("should be able to route to the correct screen", async () => {
const { page, screens } = pageWith3Screens() const { page, screens } = pageWith3Screens()
const { dom, app } = await load(page, screens, "/screen2") const { dom, app } = await load(page, screens, "/screen2")
@ -31,6 +45,26 @@ describe("screenRouting", () => {
expect(screenRoot.children[0].children[0].innerText).toBe("screen 3") expect(screenRoot.children[0].children[0].innerText).toBe("screen 3")
}) })
it("should be able to route to the correct screen, when appRootPath is something", async () => {
const { page, screens } = pageWith3Screens()
const { dom, app } = await load(
page,
screens,
"/testApp/screen2",
"/testApp"
)
app.routeTo()("/screen3")
const rootDiv = dom.window.document.body.children[0]
expect(rootDiv.children.length).toBe(1)
const screenRoot = rootDiv.children[0]
expect(screenRoot.children.length).toBe(1)
expect(screenRoot.children[0].children.length).toBe(1)
expect(screenRoot.children[0].children[0].innerText).toBe("screen 3")
})
it("should destroy and unsubscribe all components on a screen whe screen is changed", async () => { it("should destroy and unsubscribe all components on a screen whe screen is changed", async () => {
const { page, screens } = pageWith3Screens() const { page, screens } = pageWith3Screens()
const { app } = await load(page, screens, "/screen2") const { app } = await load(page, screens, "/screen2")

View File

@ -1,7 +1,10 @@
import { JSDOM } from "jsdom" import { JSDOM } from "jsdom"
import { loadBudibase } from "../src/index" import { loadBudibase } from "../src/index"
export const load = async (page, screens = [], url = "/") => { export const load = async (page, screens, url, appRootPath) => {
screens = screens || []
url = url || "/"
appRootPath = appRootPath || ""
const dom = new JSDOM("<!DOCTYPE html><html><body></body><html>", { const dom = new JSDOM("<!DOCTYPE html><html><body></body><html>", {
url: `http://test${url}`, url: `http://test${url}`,
}) })
@ -10,7 +13,7 @@ export const load = async (page, screens = [], url = "/") => {
autoAssignIds(s.props) autoAssignIds(s.props)
} }
setAppDef(dom.window, page, screens) setAppDef(dom.window, page, screens)
addWindowGlobals(dom.window, page, screens, uiFunctions, { addWindowGlobals(dom.window, page, screens, appRootPath, uiFunctions, {
hierarchy: {}, hierarchy: {},
actions: [], actions: [],
triggers: [], triggers: [],
@ -28,6 +31,7 @@ const addWindowGlobals = (
window, window,
page, page,
screens, screens,
appRootPath,
uiFunctions, uiFunctions,
appDefinition appDefinition
) => { ) => {
@ -35,7 +39,7 @@ const addWindowGlobals = (
window["##BUDIBASE_FRONTEND_DEFINITION##"] = { window["##BUDIBASE_FRONTEND_DEFINITION##"] = {
page, page,
screens, screens,
appRootPath: "", appRootPath,
} }
window["##BUDIBASE_FRONTEND_FUNCTIONS##"] = uiFunctions window["##BUDIBASE_FRONTEND_FUNCTIONS##"] = uiFunctions
} }