zudoku 0.1.1-dev.13 → 0.1.1-dev.14
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/config/config.d.ts +0 -1
- package/dist/vite/build.js +2 -8
- package/dist/vite/build.js.map +1 -1
- package/dist/vite/config.d.ts +7 -3
- package/dist/vite/config.js +13 -17
- package/dist/vite/config.js.map +1 -1
- package/dist/vite/dev-server.js +7 -4
- package/dist/vite/dev-server.js.map +1 -1
- package/dist/vite/plugin-api.js +1 -1
- package/dist/vite/plugin-api.js.map +1 -1
- package/dist/vite/plugin-auth.js +1 -2
- package/dist/vite/plugin-auth.js.map +1 -1
- package/dist/vite/plugin-docs.js +1 -1
- package/dist/vite/plugin-docs.js.map +1 -1
- package/dist/vite/plugin-docs.test.js +0 -1
- package/dist/vite/plugin-docs.test.js.map +1 -1
- package/package.json +7 -2
- package/src/app/App.tsx +30 -0
- package/src/app/DevPortal.tsx +93 -0
- package/src/app/Heading.tsx +60 -0
- package/src/app/Router.tsx +28 -0
- package/src/app/authentication/authentication.ts +18 -0
- package/src/app/authentication/clerk.ts +47 -0
- package/src/app/authentication/openid.ts +192 -0
- package/src/app/components/AnchorLink.tsx +19 -0
- package/src/app/components/CategoryHeading.tsx +16 -0
- package/src/app/components/Dialog.tsx +119 -0
- package/src/app/components/DynamicIcon.tsx +60 -0
- package/src/app/components/Header.tsx +69 -0
- package/src/app/components/Input.tsx +24 -0
- package/src/app/components/Layout.tsx +56 -0
- package/src/app/components/Markdown.tsx +37 -0
- package/src/app/components/SyntaxHighlight.tsx +94 -0
- package/src/app/components/TopNavigation.tsx +32 -0
- package/src/app/components/context/ComponentsContext.tsx +24 -0
- package/src/app/components/context/DevPortalProvider.ts +54 -0
- package/src/app/components/context/PluginSystem.ts +0 -0
- package/src/app/components/context/ThemeContext.tsx +46 -0
- package/src/app/components/context/ViewportAnchorContext.tsx +139 -0
- package/src/app/components/navigation/SideNavigation.tsx +18 -0
- package/src/app/components/navigation/SideNavigationCategory.tsx +74 -0
- package/src/app/components/navigation/SideNavigationItem.tsx +143 -0
- package/src/app/components/navigation/SideNavigationWrapper.tsx +15 -0
- package/src/app/components/navigation/useNavigationCollapsibleState.ts +27 -0
- package/src/app/components/navigation/util.ts +38 -0
- package/src/app/core/DevPortalContext.ts +164 -0
- package/src/app/core/helmet.ts +5 -0
- package/src/app/core/icons.tsx +1 -0
- package/src/app/core/plugins.ts +43 -0
- package/src/app/core/router.tsx +1 -0
- package/src/app/core/types/combine.ts +16 -0
- package/src/app/main.css +137 -0
- package/src/app/main.tsx +9 -0
- package/src/app/oas/graphql/index.ts +422 -0
- package/src/app/oas/graphql/server.ts +10 -0
- package/src/app/oas/parser/dereference/index.ts +59 -0
- package/src/app/oas/parser/dereference/resolveRef.ts +32 -0
- package/src/app/oas/parser/index.ts +94 -0
- package/src/app/oas/parser/schemas/v3.0.json +1489 -0
- package/src/app/oas/parser/schemas/v3.1.json +1298 -0
- package/src/app/oas/parser/upgrade/index.ts +108 -0
- package/src/app/plugins/api-key/SettingsApiKeys.tsx +22 -0
- package/src/app/plugins/api-key/index.tsx +123 -0
- package/src/app/plugins/markdown/MdxPage.tsx +128 -0
- package/src/app/plugins/markdown/Toc.tsx +122 -0
- package/src/app/plugins/markdown/generateRoutes.tsx +72 -0
- package/src/app/plugins/markdown/index.tsx +31 -0
- package/src/app/plugins/openapi/ColorizedParam.tsx +82 -0
- package/src/app/plugins/openapi/MakeRequest.tsx +49 -0
- package/src/app/plugins/openapi/MethodBadge.tsx +36 -0
- package/src/app/plugins/openapi/OperationList.tsx +117 -0
- package/src/app/plugins/openapi/OperationListItem.tsx +55 -0
- package/src/app/plugins/openapi/ParameterList.tsx +32 -0
- package/src/app/plugins/openapi/ParameterListItem.tsx +60 -0
- package/src/app/plugins/openapi/RequestBodySidecarBox.tsx +51 -0
- package/src/app/plugins/openapi/ResponsesSidecarBox.tsx +60 -0
- package/src/app/plugins/openapi/Select.tsx +35 -0
- package/src/app/plugins/openapi/Sidecar.tsx +160 -0
- package/src/app/plugins/openapi/SidecarBox.tsx +36 -0
- package/src/app/plugins/openapi/graphql/fragment-masking.ts +111 -0
- package/src/app/plugins/openapi/graphql/gql.ts +70 -0
- package/src/app/plugins/openapi/graphql/graphql.ts +795 -0
- package/src/app/plugins/openapi/graphql/index.ts +2 -0
- package/src/app/plugins/openapi/index.tsx +142 -0
- package/src/app/plugins/openapi/playground/Playground.tsx +309 -0
- package/src/app/plugins/openapi/queries.graphql +6 -0
- package/src/app/plugins/openapi/util/generateSchemaExample.ts +59 -0
- package/src/app/plugins/openapi/util/urql.ts +8 -0
- package/src/app/plugins/openapi/worker/createSharedWorkerClient.ts +60 -0
- package/src/app/plugins/openapi/worker/worker.ts +30 -0
- package/src/app/plugins/redirect/index.tsx +20 -0
- package/src/app/tailwind.ts +72 -0
- package/src/app/ui/Button.tsx +56 -0
- package/src/app/ui/Callout.tsx +87 -0
- package/src/app/ui/Card.tsx +82 -0
- package/src/app/ui/Note.tsx +58 -0
- package/src/app/ui/Tabs.tsx +52 -0
- package/src/app/util/MdxComponents.tsx +70 -0
- package/src/app/util/cn.ts +6 -0
- package/src/app/util/createVariantComponent.tsx +30 -0
- package/src/app/util/createWaitForNotify.ts +18 -0
- package/src/app/util/groupBy.ts +24 -0
- package/src/app/util/joinPath.tsx +10 -0
- package/src/app/util/pastellize.ts +25 -0
- package/src/app/util/slugify.ts +3 -0
- package/src/app/util/traverseNavigation.ts +55 -0
- package/src/app/util/useScrollToAnchor.ts +38 -0
- package/src/app/util/useScrollToTop.ts +13 -0
package/dist/config/config.d.ts
CHANGED
package/dist/vite/build.js
CHANGED
|
@@ -1,15 +1,9 @@
|
|
|
1
1
|
import { writeFile } from "fs/promises";
|
|
2
2
|
import { build as viteBuild } from "vite";
|
|
3
|
-
import {
|
|
3
|
+
import { getViteConfig } from "./config.js";
|
|
4
4
|
import { getBuildHtml } from "./html.js";
|
|
5
5
|
export async function runBuild(options) {
|
|
6
|
-
const viteConfig = await getViteConfig(options.dir);
|
|
7
|
-
viteConfig.build = {
|
|
8
|
-
rollupOptions: {
|
|
9
|
-
external: ["@mdx-js/react"],
|
|
10
|
-
input: getAppMainTsxPath(),
|
|
11
|
-
},
|
|
12
|
-
};
|
|
6
|
+
const viteConfig = await getViteConfig({ dir: options.dir, mode: "build" });
|
|
13
7
|
const result = await viteBuild(viteConfig);
|
|
14
8
|
if (Array.isArray(result)) {
|
|
15
9
|
throw new Error("Build failed");
|
package/dist/vite/build.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"build.js","sourceRoot":"","sources":["../../src/vite/build.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,aAAa,CAAC;AACxC,OAAO,EAAE,KAAK,IAAI,SAAS,EAAE,MAAM,MAAM,CAAC;AAC1C,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"build.js","sourceRoot":"","sources":["../../src/vite/build.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,aAAa,CAAC;AACxC,OAAO,EAAE,KAAK,IAAI,SAAS,EAAE,MAAM,MAAM,CAAC;AAC1C,OAAO,EAAE,aAAa,EAAE,MAAM,aAAa,CAAC;AAC5C,OAAO,EAAE,YAAY,EAAE,MAAM,WAAW,CAAC;AAEzC,MAAM,CAAC,KAAK,UAAU,QAAQ,CAAC,OAAwB;IACrD,MAAM,UAAU,GAAG,MAAM,aAAa,CAAC,EAAE,GAAG,EAAE,OAAO,CAAC,GAAG,EAAE,IAAI,EAAE,OAAO,EAAE,CAAC,CAAC;IAE5E,MAAM,MAAM,GAAG,MAAM,SAAS,CAAC,UAAU,CAAC,CAAC;IAE3C,IAAI,KAAK,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE,CAAC;QAC1B,MAAM,IAAI,KAAK,CAAC,cAAc,CAAC,CAAC;IAClC,CAAC;IAED,IAAI,QAAQ,IAAI,MAAM,EAAE,CAAC;QACvB,MAAM,OAAO,GAAG,MAAM,CAAC,MAAM,CAAC,IAAI,CAChC,CAAC,CAAC,EAAE,EAAE,CAAC,SAAS,IAAI,CAAC,IAAI,CAAC,CAAC,OAAO,CACnC,EAAE,QAAQ,CAAC;QACZ,MAAM,QAAQ,GAAG,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CACxC,CAAC,CAAC,QAAQ,CAAC,QAAQ,CAAC,MAAM,CAAC,CAC5B,EAAE,QAAQ,CAAC;QAEZ,MAAM,IAAI,GAAG,YAAY,CAAC;YACxB,OAAO,EAAE,IAAI,OAAO,EAAE;YACtB,QAAQ,EAAE,IAAI,QAAQ,EAAE;SACzB,CAAC,CAAC;QAEH,MAAM,SAAS,CAAC,GAAG,OAAO,CAAC,GAAG,kBAAkB,EAAE,IAAI,EAAE,OAAO,CAAC,CAAC;QACjE,OAAO;IACT,CAAC;IAED,MAAM,IAAI,KAAK,CAAC,cAAc,CAAC,CAAC;AAClC,CAAC"}
|
package/dist/vite/config.d.ts
CHANGED
|
@@ -1,7 +1,11 @@
|
|
|
1
1
|
import { InlineConfig } from "vite";
|
|
2
2
|
import { ZudokuConfig } from "../config/config.js";
|
|
3
|
+
export interface ZudokuViteConfig extends InlineConfig {
|
|
4
|
+
appDir: string;
|
|
5
|
+
}
|
|
3
6
|
export declare function loadZuploConfig(rootDir: string): Promise<ZudokuConfig>;
|
|
4
|
-
export declare function
|
|
5
|
-
|
|
6
|
-
|
|
7
|
+
export declare function getViteConfig({ dir, mode, }: {
|
|
8
|
+
dir: string;
|
|
9
|
+
mode: "dev" | "build";
|
|
10
|
+
}): Promise<ZudokuViteConfig>;
|
|
7
11
|
export declare function loadConfig(rootPath: string, fileName: string): Promise<any>;
|
package/dist/vite/config.js
CHANGED
|
@@ -30,23 +30,19 @@ export async function loadZuploConfig(rootDir) {
|
|
|
30
30
|
logger.warn("No zudoku.config file found");
|
|
31
31
|
return {};
|
|
32
32
|
}
|
|
33
|
-
|
|
33
|
+
function getAppDir(rootDir, internalDevMode) {
|
|
34
|
+
// Internally we resolve to the typescript files so live reload works
|
|
35
|
+
// when the module is published, we use the compiled js files.
|
|
34
36
|
if (internalDevMode) {
|
|
35
|
-
|
|
36
|
-
// runs the compiled JS files, but vite uses the raw TS files
|
|
37
|
-
return new URL("../../src/app", import.meta.url).pathname;
|
|
37
|
+
return path.join(rootDir, "node_modules", "zudoku", "src", "app");
|
|
38
38
|
}
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
}
|
|
42
|
-
}
|
|
43
|
-
export function getAppMainTsxPath(internalDevMode = false) {
|
|
44
|
-
const appDir = getAppDir(internalDevMode);
|
|
45
|
-
return path.join(appDir, internalDevMode ? "main.tsx" : "main.js");
|
|
39
|
+
const zudokuDir = new URL(import.meta.resolve("zudoku")).pathname.replace("/dist/index.js", "");
|
|
40
|
+
return path.join(zudokuDir, "dist", "app");
|
|
46
41
|
}
|
|
47
|
-
export async function getViteConfig(dir) {
|
|
42
|
+
export async function getViteConfig({ dir, mode, }) {
|
|
43
|
+
const internalDevMode = mode === "dev" && !!process.env.NX_TASK_TARGET_PROJECT;
|
|
48
44
|
const rootDir = path.resolve(process.cwd(), dir);
|
|
49
|
-
const appDir = getAppDir(
|
|
45
|
+
const appDir = getAppDir(rootDir, internalDevMode);
|
|
50
46
|
const config = await loadZuploConfig(rootDir);
|
|
51
47
|
let websocketPort = 9800;
|
|
52
48
|
while (!(await isPortAvailable("localhost", websocketPort)) &&
|
|
@@ -55,6 +51,7 @@ export async function getViteConfig(dir) {
|
|
|
55
51
|
}
|
|
56
52
|
const viteConfig = {
|
|
57
53
|
root: rootDir,
|
|
54
|
+
appDir,
|
|
58
55
|
configFile: false,
|
|
59
56
|
clearScreen: false,
|
|
60
57
|
logLevel: (process.env.LOG_LEVEL || "info"),
|
|
@@ -82,9 +79,8 @@ export async function getViteConfig(dir) {
|
|
|
82
79
|
build: {
|
|
83
80
|
outDir: path.resolve(rootDir, "out"),
|
|
84
81
|
rollupOptions: {
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
},
|
|
82
|
+
// external: ["@mdx-js/react"],
|
|
83
|
+
input: mode === "build" ? "zudoku/app/main.tsx" : undefined,
|
|
88
84
|
},
|
|
89
85
|
},
|
|
90
86
|
optimizeDeps: {
|
|
@@ -103,7 +99,7 @@ export async function getViteConfig(dir) {
|
|
|
103
99
|
],
|
|
104
100
|
},
|
|
105
101
|
appType: "custom",
|
|
106
|
-
plugins: [vitePlugin({ ...config, rootDir
|
|
102
|
+
plugins: [vitePlugin({ ...config, rootDir })],
|
|
107
103
|
css: {
|
|
108
104
|
postcss: {
|
|
109
105
|
plugins: [
|
package/dist/vite/config.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"config.js","sourceRoot":"","sources":["../../src/vite/config.ts"],"names":[],"mappings":"AAAA,OAAO,YAAY,MAAM,cAAc,CAAC;AACxC,OAAO,OAAO,MAAM,SAAS,CAAC;AAC9B,OAAO,EAAE,IAAI,EAAE,MAAM,kBAAkB,CAAC;AACxC,OAAO,IAAI,MAAM,WAAW,CAAC;AAC7B,OAAO,WAAW,MAAM,aAAa,CAAC;AAEtC,OAAO,cAAc,MAAM,oBAAoB,CAAC;AAChD,OAAO,EAAE,MAAM,EAAE,MAAM,yBAAyB,CAAC;AACjD,OAAO,EAAE,eAAe,EAAE,MAAM,8BAA8B,CAAC;AAE/D,OAAO,UAAU,MAAM,aAAa,CAAC;AAErC,MAAM,UAAU,GAAG,CAAC,IAAI,EAAE,KAAK,EAAE,IAAI,EAAE,KAAK,EAAE,KAAK,CAAC,CAAC;
|
|
1
|
+
{"version":3,"file":"config.js","sourceRoot":"","sources":["../../src/vite/config.ts"],"names":[],"mappings":"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"}
|
package/dist/vite/dev-server.js
CHANGED
|
@@ -1,7 +1,8 @@
|
|
|
1
1
|
import express from "express";
|
|
2
2
|
import { createServer as createViteServer } from "vite";
|
|
3
|
+
import path from "node:path";
|
|
3
4
|
import { createGraphQLServer } from "../app/oas/graphql/index.js";
|
|
4
|
-
import {
|
|
5
|
+
import { getViteConfig } from "./config.js";
|
|
5
6
|
import { getDevHtml } from "./html.js";
|
|
6
7
|
export class DevServer {
|
|
7
8
|
options;
|
|
@@ -11,7 +12,10 @@ export class DevServer {
|
|
|
11
12
|
}
|
|
12
13
|
async start() {
|
|
13
14
|
const app = express();
|
|
14
|
-
const viteConfig = await getViteConfig(
|
|
15
|
+
const viteConfig = await getViteConfig({
|
|
16
|
+
dir: this.options.dir,
|
|
17
|
+
mode: "dev",
|
|
18
|
+
});
|
|
15
19
|
const vite = await createViteServer(viteConfig);
|
|
16
20
|
const graphql = createGraphQLServer({
|
|
17
21
|
graphqlEndpoint: "/__z/graphql",
|
|
@@ -20,8 +24,7 @@ export class DevServer {
|
|
|
20
24
|
app.use(vite.middlewares);
|
|
21
25
|
app.use("*", async (req, res) => {
|
|
22
26
|
try {
|
|
23
|
-
const
|
|
24
|
-
const rawHtml = getDevHtml(jsEntry);
|
|
27
|
+
const rawHtml = getDevHtml(path.join(viteConfig.appDir, "app.tsx"));
|
|
25
28
|
const indexHtml = await vite.transformIndexHtml(req.url, rawHtml);
|
|
26
29
|
// Send the transformed index.html back to the client
|
|
27
30
|
res.status(200).set({ "Content-Type": "text/html" }).end(indexHtml);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"dev-server.js","sourceRoot":"","sources":["../../src/vite/dev-server.ts"],"names":[],"mappings":"AAAA,OAAO,OAAO,MAAM,SAAS,CAAC;AAE9B,OAAO,EAAE,YAAY,IAAI,gBAAgB,EAAE,MAAM,MAAM,CAAC;AAExD,OAAO,EAAE,mBAAmB,EAAE,MAAM,6BAA6B,CAAC;AAClE,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"dev-server.js","sourceRoot":"","sources":["../../src/vite/dev-server.ts"],"names":[],"mappings":"AAAA,OAAO,OAAO,MAAM,SAAS,CAAC;AAE9B,OAAO,EAAE,YAAY,IAAI,gBAAgB,EAAE,MAAM,MAAM,CAAC;AAExD,OAAO,IAAI,MAAM,WAAW,CAAC;AAC7B,OAAO,EAAE,mBAAmB,EAAE,MAAM,6BAA6B,CAAC;AAClE,OAAO,EAAE,aAAa,EAAE,MAAM,aAAa,CAAC;AAC5C,OAAO,EAAE,UAAU,EAAE,MAAM,WAAW,CAAC;AAEvC,MAAM,OAAO,SAAS;IAGA;IAFZ,MAAM,CAAqB;IAEnC,YAAoB,OAAsC;QAAtC,YAAO,GAAP,OAAO,CAA+B;IAAG,CAAC;IAE9D,KAAK,CAAC,KAAK;QACT,MAAM,GAAG,GAAG,OAAO,EAAE,CAAC;QAEtB,MAAM,UAAU,GAAG,MAAM,aAAa,CAAC;YACrC,GAAG,EAAE,IAAI,CAAC,OAAO,CAAC,GAAG;YACrB,IAAI,EAAE,KAAK;SACZ,CAAC,CAAC;QAEH,MAAM,IAAI,GAAG,MAAM,gBAAgB,CAAC,UAAU,CAAC,CAAC;QAEhD,MAAM,OAAO,GAAG,mBAAmB,CAAC;YAClC,eAAe,EAAE,cAAc;SAChC,CAAC,CAAC;QAEH,GAAG,CAAC,GAAG,CAAC,OAAO,CAAC,eAAe,EAAE,OAAO,CAAC,CAAC;QAC1C,GAAG,CAAC,GAAG,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;QAE1B,GAAG,CAAC,GAAG,CAAC,GAAG,EAAE,KAAK,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE;YAC9B,IAAI,CAAC;gBACH,MAAM,OAAO,GAAG,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,MAAM,EAAE,SAAS,CAAC,CAAC,CAAC;gBACpE,MAAM,SAAS,GAAG,MAAM,IAAI,CAAC,kBAAkB,CAAC,GAAG,CAAC,GAAG,EAAE,OAAO,CAAC,CAAC;gBAElE,qDAAqD;gBACrD,GAAG,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,EAAE,cAAc,EAAE,WAAW,EAAE,CAAC,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC;YACtE,CAAC;YAAC,OAAO,CAAC,EAAE,CAAC;gBACX,IAAI,CAAC,gBAAgB,CAAC,CAAC,CAAC,CAAC;gBACzB,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;gBACjB,GAAG,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC;YACjC,CAAC;QACH,CAAC,CAAC,CAAC;QAEH,OAAO,IAAI,OAAO,CAAO,CAAC,OAAO,EAAE,EAAE;YACnC,IAAI,CAAC,MAAM,GAAG,GAAG,CAAC,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,IAAI,EAAE,OAAO,CAAC,CAAC;QACvD,CAAC,CAAC,CAAC;IACL,CAAC;IAED,KAAK,CAAC,IAAI;QACR,IAAI,IAAI,CAAC,MAAM,EAAE,CAAC;YAChB,OAAO,IAAI,OAAO,CAAO,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;gBAC3C,IAAI,CAAC,MAAO,CAAC,KAAK,CAAC,CAAC,GAAG,EAAE,EAAE;oBACzB,IAAI,GAAG,EAAE,CAAC;wBACR,MAAM,CAAC,GAAG,CAAC,CAAC;oBACd,CAAC;yBAAM,CAAC;wBACN,OAAO,EAAE,CAAC;oBACZ,CAAC;gBACH,CAAC,CAAC,CAAC;YACL,CAAC,CAAC,CAAC;QACL,CAAC;IACH,CAAC;CACF"}
|
package/dist/vite/plugin-api.js
CHANGED
|
@@ -15,7 +15,7 @@ const viteApiPlugin = (config) => {
|
|
|
15
15
|
// IMPORTANT! This path here is important, we MUST resolve
|
|
16
16
|
// files here as Typescript from the appDir
|
|
17
17
|
getConfigExportCode(config.rootDir),
|
|
18
|
-
`import { openApiPlugin } from "
|
|
18
|
+
`import { openApiPlugin } from "zudoku/app/plugins/openapi/index.tsx";`,
|
|
19
19
|
`const configuredApiPlugins = [];`,
|
|
20
20
|
];
|
|
21
21
|
if (config?.apis) {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"plugin-api.js","sourceRoot":"","sources":["../../src/vite/plugin-api.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,mBAAmB,EAAE,MAAM,oBAAoB,CAAC;AAEzD,MAAM,aAAa,GAAG,CAAC,MAA2B,EAAU,EAAE;IAC5D,MAAM,eAAe,GAAG,4BAA4B,CAAC;IACrD,MAAM,uBAAuB,GAAG,IAAI,GAAG,eAAe,CAAC;IAEvD,OAAO;QACL,IAAI,EAAE,yBAAyB;QAC/B,SAAS,CAAC,EAAE;YACV,IAAI,EAAE,KAAK,eAAe,EAAE,CAAC;gBAC3B,OAAO,uBAAuB,CAAC;YACjC,CAAC;QACH,CAAC;QACD,IAAI,CAAC,EAAE;YACL,IAAI,EAAE,KAAK,uBAAuB,EAAE,CAAC;gBACnC,MAAM,IAAI,GAAa;oBACrB,0DAA0D;oBAC1D,2CAA2C;oBAC3C,mBAAmB,CAAC,MAAM,CAAC,OAAO,CAAC;oBACnC,
|
|
1
|
+
{"version":3,"file":"plugin-api.js","sourceRoot":"","sources":["../../src/vite/plugin-api.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,mBAAmB,EAAE,MAAM,oBAAoB,CAAC;AAEzD,MAAM,aAAa,GAAG,CAAC,MAA2B,EAAU,EAAE;IAC5D,MAAM,eAAe,GAAG,4BAA4B,CAAC;IACrD,MAAM,uBAAuB,GAAG,IAAI,GAAG,eAAe,CAAC;IAEvD,OAAO;QACL,IAAI,EAAE,yBAAyB;QAC/B,SAAS,CAAC,EAAE;YACV,IAAI,EAAE,KAAK,eAAe,EAAE,CAAC;gBAC3B,OAAO,uBAAuB,CAAC;YACjC,CAAC;QACH,CAAC;QACD,IAAI,CAAC,EAAE;YACL,IAAI,EAAE,KAAK,uBAAuB,EAAE,CAAC;gBACnC,MAAM,IAAI,GAAa;oBACrB,0DAA0D;oBAC1D,2CAA2C;oBAC3C,mBAAmB,CAAC,MAAM,CAAC,OAAO,CAAC;oBACnC,uEAAuE;oBACvE,kCAAkC;iBACnC,CAAC;gBAEF,IAAI,MAAM,EAAE,IAAI,EAAE,CAAC;oBACjB,IAAI,KAAK,CAAC,OAAO,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC;wBAC/B,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE;4BAC3B,IAAI,CAAC,IAAI,CACP,GAAG;gCACD,eAAe,EAAE,qBAAqB;gCACtC,wDAAwD,CAAC,MAAM;6BAChE,CACF,CAAC;wBACJ,CAAC,CAAC,CAAC;oBACL,CAAC;yBAAM,CAAC;wBACN,IAAI,CAAC,IAAI,CACP,GAAG;4BACD,eAAe,EAAE,qBAAqB;4BACtC,wDAAwD;yBACzD,CACF,CAAC;oBACJ,CAAC;gBACH,CAAC;gBAED,IAAI,CAAC,IAAI,CAAC,kCAAkC,CAAC,CAAC;gBAE9C,OAAO;oBACL,IAAI,EAAE,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC;oBACrB,GAAG,EAAE,IAAI;iBACV,CAAC;YACJ,CAAC;QACH,CAAC;KACF,CAAC;AACJ,CAAC,CAAC;AAEF,eAAe,aAAa,CAAC"}
|
package/dist/vite/plugin-auth.js
CHANGED
|
@@ -1,4 +1,3 @@
|
|
|
1
|
-
import path from "node:path";
|
|
2
1
|
import { getConfigExportCode } from "./plugin-config.js";
|
|
3
2
|
const viteAuthPlugin = (config) => {
|
|
4
3
|
const virtualModuleId = "virtual:zudoku-auth";
|
|
@@ -18,7 +17,7 @@ const viteAuthPlugin = (config) => {
|
|
|
18
17
|
// TODO: Validate that the authConfig.type is a valid authentication provider
|
|
19
18
|
return [
|
|
20
19
|
getConfigExportCode(config.rootDir),
|
|
21
|
-
`import authProvider from "
|
|
20
|
+
`import authProvider from "zudoku/app/authentication/${config.authentication.type}.ts";`,
|
|
22
21
|
`export const configuredAuthProvider = authProvider(config.authentication);`,
|
|
23
22
|
].join("\n");
|
|
24
23
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"plugin-auth.js","sourceRoot":"","sources":["../../src/vite/plugin-auth.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"plugin-auth.js","sourceRoot":"","sources":["../../src/vite/plugin-auth.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,mBAAmB,EAAE,MAAM,oBAAoB,CAAC;AAEzD,MAAM,cAAc,GAAG,CAAC,MAA2B,EAAgB,EAAE;IACnE,MAAM,eAAe,GAAG,qBAAqB,CAAC;IAC9C,MAAM,uBAAuB,GAAG,IAAI,GAAG,eAAe,CAAC;IAEvD,OAAO;QACL,IAAI,EAAE,oBAAoB,EAAE,gDAAgD;QAC5E,SAAS,CAAC,EAAE;YACV,IAAI,EAAE,KAAK,eAAe,EAAE,CAAC;gBAC3B,OAAO,uBAAuB,CAAC;YACjC,CAAC;QACH,CAAC;QACD,IAAI,CAAC,EAAE;YACL,IAAI,EAAE,KAAK,uBAAuB,EAAE,CAAC;gBACnC,IAAI,CAAC,MAAM,CAAC,cAAc,EAAE,CAAC;oBAC3B,OAAO,kDAAkD,CAAC;gBAC5D,CAAC;gBACD,6EAA6E;gBAC7E,OAAO;oBACL,mBAAmB,CAAC,MAAM,CAAC,OAAO,CAAC;oBACnC,uDAAuD,MAAM,CAAC,cAAc,CAAC,IAAI,OAAO;oBACxF,4EAA4E;iBAC7E,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;YACf,CAAC;QACH,CAAC;KACF,CAAC;AACJ,CAAC,CAAC;AAEF,eAAe,cAAc,CAAC"}
|
package/dist/vite/plugin-docs.js
CHANGED
|
@@ -13,7 +13,7 @@ const viteDocsPlugin = (config) => {
|
|
|
13
13
|
const code = [
|
|
14
14
|
// IMPORTANT! This path here is important, we MUST resolve
|
|
15
15
|
// files here as Typescript from the appDir
|
|
16
|
-
`import { markdownPlugin } from "
|
|
16
|
+
`import { markdownPlugin } from "zudoku/app/plugins/markdown/index.tsx";`,
|
|
17
17
|
`const configuredDocsPlugins = [];`,
|
|
18
18
|
];
|
|
19
19
|
const docsConfigs = config?.docs
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"plugin-docs.js","sourceRoot":"","sources":["../../src/vite/plugin-docs.ts"],"names":[],"mappings":"AAGA,MAAM,cAAc,GAAG,CAAC,MAA2B,EAAU,EAAE;IAC7D,MAAM,eAAe,GAAG,6BAA6B,CAAC;IACtD,MAAM,uBAAuB,GAAG,IAAI,GAAG,eAAe,CAAC;IAEvD,OAAO;QACL,IAAI,EAAE,yBAAyB;QAC/B,SAAS,CAAC,EAAE;YACV,IAAI,EAAE,KAAK,eAAe,EAAE,CAAC;gBAC3B,OAAO,uBAAuB,CAAC;YACjC,CAAC;QACH,CAAC;QACD,IAAI,CAAC,EAAE;YACL,IAAI,EAAE,KAAK,uBAAuB,EAAE,CAAC;gBACnC,MAAM,IAAI,GAAa;oBACrB,0DAA0D;oBAC1D,2CAA2C;oBAC3C,
|
|
1
|
+
{"version":3,"file":"plugin-docs.js","sourceRoot":"","sources":["../../src/vite/plugin-docs.ts"],"names":[],"mappings":"AAGA,MAAM,cAAc,GAAG,CAAC,MAA2B,EAAU,EAAE;IAC7D,MAAM,eAAe,GAAG,6BAA6B,CAAC;IACtD,MAAM,uBAAuB,GAAG,IAAI,GAAG,eAAe,CAAC;IAEvD,OAAO;QACL,IAAI,EAAE,yBAAyB;QAC/B,SAAS,CAAC,EAAE;YACV,IAAI,EAAE,KAAK,eAAe,EAAE,CAAC;gBAC3B,OAAO,uBAAuB,CAAC;YACjC,CAAC;QACH,CAAC;QACD,IAAI,CAAC,EAAE;YACL,IAAI,EAAE,KAAK,uBAAuB,EAAE,CAAC;gBACnC,MAAM,IAAI,GAAa;oBACrB,0DAA0D;oBAC1D,2CAA2C;oBAC3C,yEAAyE;oBACzE,mCAAmC;iBACpC,CAAC;gBACF,MAAM,WAAW,GAAiB,MAAM,EAAE,IAAI;oBAC5C,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,MAAM,CAAC,IAAI,CAAC;wBAC1B,CAAC,CAAC,MAAM,CAAC,IAAI;wBACb,CAAC,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC;oBACjB,CAAC,CAAC,EAAE,CAAC;gBAEP,WAAW,CAAC,OAAO,CAAC,CAAC,UAAU,EAAE,EAAE;oBACjC,IAAI,CAAC,IAAI,CACP,GAAG;wBACD,eAAe,EAAE,qBAAqB;wBACtC,0CAA0C,IAAI,CAAC,SAAS,CAAC,UAAU,CAAC,KAAK,CAAC,KAAK;wBAC/E,iBAAiB;wBACjB,KAAK;wBACL,gEAAgE;qBACjE,CACF,CAAC;gBACJ,CAAC,CAAC,CAAC;gBAEH,IAAI,CAAC,IAAI,CAAC,mCAAmC,CAAC,CAAC;gBAE/C,OAAO;oBACL,IAAI,EAAE,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC;oBACrB,GAAG,EAAE,IAAI;iBACV,CAAC;YACJ,CAAC;QACH,CAAC;KACF,CAAC;AACJ,CAAC,CAAC;AAEF,eAAe,cAAc,CAAC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"plugin-docs.test.js","sourceRoot":"","sources":["../../src/vite/plugin-docs.test.ts"],"names":[],"mappings":"AAAA,uDAAuD;AACvD,OAAO,MAAM,MAAM,aAAa,CAAC;AACjC,OAAO,IAAI,MAAM,WAAW,CAAC;AAC7B,OAAO,EAAE,qBAAqB,EAAE,MAAM,UAAU,CAAC;AACjD,OAAO,cAAc,MAAM,kBAAkB,CAAC;AAE9C,IAAI,CAAC,IAAI,CAAC,aAAa,EAAE,KAAK,EAAE,CAAC,EAAE,EAAE;IACnC,MAAM,MAAM,GAAG,cAAc,CAAC;QAC5B,IAAI,EAAE,EAAE,KAAK,EAAE,cAAc,EAAE;
|
|
1
|
+
{"version":3,"file":"plugin-docs.test.js","sourceRoot":"","sources":["../../src/vite/plugin-docs.test.ts"],"names":[],"mappings":"AAAA,uDAAuD;AACvD,OAAO,MAAM,MAAM,aAAa,CAAC;AACjC,OAAO,IAAI,MAAM,WAAW,CAAC;AAC7B,OAAO,EAAE,qBAAqB,EAAE,MAAM,UAAU,CAAC;AACjD,OAAO,cAAc,MAAM,kBAAkB,CAAC;AAE9C,IAAI,CAAC,IAAI,CAAC,aAAa,EAAE,KAAK,EAAE,CAAC,EAAE,EAAE;IACnC,MAAM,MAAM,GAAG,cAAc,CAAC;QAC5B,IAAI,EAAE,EAAE,KAAK,EAAE,cAAc,EAAE;KACzB,CAAC,CAAC;IACV,IAAI,CAAC,MAAM,CAAC,IAAI,EAAE,CAAC;QACjB,MAAM,IAAI,KAAK,CAAC,sCAAsC,CAAC,CAAC;IAC1D,CAAC;IACD,IAAI,OAAO,MAAM,CAAC,IAAI,KAAK,UAAU,EAAE,CAAC;QACtC,MAAM,IAAI,KAAK,CAAC,+BAA+B,CAAC,CAAC;IACnD,CAAC;IAED,MAAM,MAAM,GAAG,MAAM,MAAM,CAAC,IAAI,CAAC,IAAI;IACnC,8DAA8D;IAC9D,EAAS,EACT,4BAA4B,CAC7B,CAAC;IACF,IAAI,MAAM,IAAI,OAAO,MAAM,KAAK,QAAQ,IAAI,MAAM,IAAI,MAAM,EAAE,CAAC;QAC7D,MAAM,WAAW,GAAG,MAAM,qBAAqB,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;QAC7D,IAAI,WAAW,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YAC3B,OAAO,CAAC,KAAK,CAAC,WAAW,CAAC,CAAC;QAC7B,CAAC;QACD,MAAM,CAAC,KAAK,CAAC,WAAW,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC;IACtC,CAAC;SAAM,CAAC;QACN,MAAM,CAAC,IAAI,CAAC,uCAAuC,CAAC,CAAC;IACvD,CAAC;AACH,CAAC,CAAC,CAAC"}
|
package/package.json
CHANGED
|
@@ -1,10 +1,11 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "zudoku",
|
|
3
|
-
"version": "0.1.1-dev.
|
|
3
|
+
"version": "0.1.1-dev.14",
|
|
4
4
|
"type": "module",
|
|
5
5
|
"files": [
|
|
6
6
|
"dist",
|
|
7
|
-
"cli.js"
|
|
7
|
+
"cli.js",
|
|
8
|
+
"src/app"
|
|
8
9
|
],
|
|
9
10
|
"module": "./dist/index.js",
|
|
10
11
|
"types": "./dist/index.d.ts",
|
|
@@ -36,6 +37,10 @@
|
|
|
36
37
|
"./main.css": {
|
|
37
38
|
"require": "./src/app/main.css",
|
|
38
39
|
"import": "./src/app/main.css"
|
|
40
|
+
},
|
|
41
|
+
"./app/*": {
|
|
42
|
+
"require": "./src/app/*",
|
|
43
|
+
"import": "./src/app/*"
|
|
39
44
|
}
|
|
40
45
|
},
|
|
41
46
|
"dependencies": {
|
package/src/app/App.tsx
ADDED
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
import "./main.css";
|
|
2
|
+
|
|
3
|
+
// Virtual config
|
|
4
|
+
import config from "virtual:zudoku-config";
|
|
5
|
+
|
|
6
|
+
// Virtual Plugins
|
|
7
|
+
import { configuredApiPlugins } from "virtual:zudoku-api-plugins";
|
|
8
|
+
import { configuredAuthProvider } from "virtual:zudoku-auth";
|
|
9
|
+
import { configuredDocsPlugins } from "virtual:zudoku-docs-plugins";
|
|
10
|
+
|
|
11
|
+
// Base React Component
|
|
12
|
+
import DevPortal from "./DevPortal.js";
|
|
13
|
+
|
|
14
|
+
export default function App() {
|
|
15
|
+
return (
|
|
16
|
+
<DevPortal
|
|
17
|
+
meta={{
|
|
18
|
+
headerTitle: config?.ui?.headerTitle ?? "Developer Portal",
|
|
19
|
+
pageTitle: config?.ui?.pageTitle ?? "%s | Dev Portal",
|
|
20
|
+
logo: config?.ui?.logo ?? "https://cdn.zuplo.com/www/favicon.png",
|
|
21
|
+
favicon:
|
|
22
|
+
config?.ui?.metadata?.favicon ??
|
|
23
|
+
"https://cdn.zuplo.com/www/favicon.png",
|
|
24
|
+
}}
|
|
25
|
+
navigation={config.navigation ?? []}
|
|
26
|
+
authentication={configuredAuthProvider}
|
|
27
|
+
plugins={[...configuredDocsPlugins, ...configuredApiPlugins]}
|
|
28
|
+
/>
|
|
29
|
+
);
|
|
30
|
+
}
|
|
@@ -0,0 +1,93 @@
|
|
|
1
|
+
import { MDXProvider } from "@mdx-js/react";
|
|
2
|
+
import { QueryClientProvider } from "@tanstack/react-query";
|
|
3
|
+
import { memo, Suspense, useEffect, useMemo } from "react";
|
|
4
|
+
import { type AuthProvider } from "./authentication/authentication.js";
|
|
5
|
+
import {
|
|
6
|
+
ComponentsProvider,
|
|
7
|
+
DEFAULT_COMPONENTS,
|
|
8
|
+
type ComponentsContextType,
|
|
9
|
+
} from "./components/context/ComponentsContext.js";
|
|
10
|
+
import { DevPortalProvider } from "./components/context/DevPortalProvider.js";
|
|
11
|
+
import { ThemeProvider } from "./components/context/ThemeContext.js";
|
|
12
|
+
import { ViewportAnchorProvider } from "./components/context/ViewportAnchorContext.js";
|
|
13
|
+
import {
|
|
14
|
+
DevPortalContext,
|
|
15
|
+
queryClient,
|
|
16
|
+
type NavigationItem,
|
|
17
|
+
} from "./core/DevPortalContext.js";
|
|
18
|
+
import { HelmetProvider } from "./core/helmet.js";
|
|
19
|
+
import { type DevPortalPlugin } from "./core/plugins.js";
|
|
20
|
+
import { Router } from "./Router.js";
|
|
21
|
+
import { MdxComponents, type MdxComponentsType } from "./util/MdxComponents.js";
|
|
22
|
+
|
|
23
|
+
export const DevPortalSystemPaths = {
|
|
24
|
+
Settings: "/settings",
|
|
25
|
+
} as const;
|
|
26
|
+
|
|
27
|
+
export type DevPortalPath =
|
|
28
|
+
| string
|
|
29
|
+
| (typeof DevPortalSystemPaths)[keyof typeof DevPortalSystemPaths];
|
|
30
|
+
|
|
31
|
+
export type DevPortalProps = {
|
|
32
|
+
meta?: Partial<{
|
|
33
|
+
headerTitle: string;
|
|
34
|
+
pageTitle: string;
|
|
35
|
+
description: string;
|
|
36
|
+
logo: string;
|
|
37
|
+
favicon: string;
|
|
38
|
+
}>;
|
|
39
|
+
authentication?: AuthProvider;
|
|
40
|
+
navigation: NavigationItem[];
|
|
41
|
+
plugins?: DevPortalPlugin[];
|
|
42
|
+
mdxComponents?: MdxComponentsType;
|
|
43
|
+
overrides?: ComponentsContextType;
|
|
44
|
+
};
|
|
45
|
+
|
|
46
|
+
const DevPortal = (props: DevPortalProps) => {
|
|
47
|
+
const components = useMemo(
|
|
48
|
+
() => ({ ...DEFAULT_COMPONENTS, ...props.overrides }),
|
|
49
|
+
[props.overrides],
|
|
50
|
+
);
|
|
51
|
+
|
|
52
|
+
const mdxComponents = useMemo(
|
|
53
|
+
() => ({ ...MdxComponents, ...props.mdxComponents }),
|
|
54
|
+
[props.mdxComponents],
|
|
55
|
+
);
|
|
56
|
+
|
|
57
|
+
const devPortalContext = useMemo(() => new DevPortalContext(props), [props]);
|
|
58
|
+
|
|
59
|
+
useEffect(() => {
|
|
60
|
+
void devPortalContext.initialize();
|
|
61
|
+
}, [devPortalContext]);
|
|
62
|
+
|
|
63
|
+
return (
|
|
64
|
+
<QueryClientProvider client={queryClient}>
|
|
65
|
+
<HelmetProvider>
|
|
66
|
+
<DevPortalProvider value={devPortalContext}>
|
|
67
|
+
<MDXProvider components={mdxComponents}>
|
|
68
|
+
<ThemeProvider>
|
|
69
|
+
<ComponentsProvider value={components}>
|
|
70
|
+
<ViewportAnchorProvider>
|
|
71
|
+
<Suspense
|
|
72
|
+
fallback={
|
|
73
|
+
<div className="grid place-items-center h-full">
|
|
74
|
+
Loading...
|
|
75
|
+
</div>
|
|
76
|
+
}
|
|
77
|
+
>
|
|
78
|
+
<Router plugins={props.plugins} />
|
|
79
|
+
</Suspense>
|
|
80
|
+
</ViewportAnchorProvider>
|
|
81
|
+
</ComponentsProvider>
|
|
82
|
+
</ThemeProvider>
|
|
83
|
+
</MDXProvider>
|
|
84
|
+
</DevPortalProvider>
|
|
85
|
+
</HelmetProvider>
|
|
86
|
+
</QueryClientProvider>
|
|
87
|
+
);
|
|
88
|
+
};
|
|
89
|
+
|
|
90
|
+
const MemoDevPortal = memo(DevPortal);
|
|
91
|
+
MemoDevPortal.displayName = "DevPortal";
|
|
92
|
+
|
|
93
|
+
export default MemoDevPortal;
|
|
@@ -0,0 +1,60 @@
|
|
|
1
|
+
import { type ReactNode } from "react";
|
|
2
|
+
import { useRegisterAnchorElement } from "./components/context/ViewportAnchorContext.js";
|
|
3
|
+
import { cn } from "./util/cn.js";
|
|
4
|
+
|
|
5
|
+
const getComponent = (level: number) => {
|
|
6
|
+
switch (level) {
|
|
7
|
+
case 1:
|
|
8
|
+
return "h1";
|
|
9
|
+
case 2:
|
|
10
|
+
return "h2";
|
|
11
|
+
case 3:
|
|
12
|
+
return "h3";
|
|
13
|
+
case 4:
|
|
14
|
+
return "h4";
|
|
15
|
+
case 5:
|
|
16
|
+
return "h5";
|
|
17
|
+
case 6:
|
|
18
|
+
return "h6";
|
|
19
|
+
default:
|
|
20
|
+
return "h1";
|
|
21
|
+
}
|
|
22
|
+
};
|
|
23
|
+
|
|
24
|
+
export type HeadingProps = {
|
|
25
|
+
children: ReactNode;
|
|
26
|
+
className?: string;
|
|
27
|
+
id?: string;
|
|
28
|
+
level?: 1 | 2 | 3 | 4 | 5 | 6;
|
|
29
|
+
registerSidebarAnchor?: boolean;
|
|
30
|
+
};
|
|
31
|
+
|
|
32
|
+
export const Heading = ({
|
|
33
|
+
level,
|
|
34
|
+
children,
|
|
35
|
+
id,
|
|
36
|
+
className,
|
|
37
|
+
registerSidebarAnchor,
|
|
38
|
+
}: HeadingProps) => {
|
|
39
|
+
const Component = getComponent(level ?? 1);
|
|
40
|
+
const { ref } = useRegisterAnchorElement();
|
|
41
|
+
|
|
42
|
+
return (
|
|
43
|
+
<Component
|
|
44
|
+
className={cn("group relative", className)}
|
|
45
|
+
ref={registerSidebarAnchor ? ref : undefined}
|
|
46
|
+
id={id}
|
|
47
|
+
>
|
|
48
|
+
{id && (
|
|
49
|
+
<a
|
|
50
|
+
href={`#${id}`}
|
|
51
|
+
className="no-underline absolute text-primary -left-[0.8em] pr-2.5 opacity-0 group-hover:opacity-50 hover:!opacity-100 transition-opacity duration-200"
|
|
52
|
+
aria-label={`Link to ${id}`}
|
|
53
|
+
>
|
|
54
|
+
#
|
|
55
|
+
</a>
|
|
56
|
+
)}
|
|
57
|
+
{children}
|
|
58
|
+
</Component>
|
|
59
|
+
);
|
|
60
|
+
};
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
import { useMemo } from "react";
|
|
2
|
+
import { createBrowserRouter, RouterProvider } from "react-router-dom";
|
|
3
|
+
import { Layout } from "./components/Layout.js";
|
|
4
|
+
import { DevPortalPlugin, isNavigationPlugin } from "./core/plugins.js";
|
|
5
|
+
|
|
6
|
+
export function Router({ plugins }: { plugins?: DevPortalPlugin[] }) {
|
|
7
|
+
const router = useMemo(() => {
|
|
8
|
+
const routes = (plugins ?? []).flatMap((plugin) =>
|
|
9
|
+
isNavigationPlugin(plugin) ? plugin.getRoutes() : [],
|
|
10
|
+
);
|
|
11
|
+
|
|
12
|
+
return createBrowserRouter([
|
|
13
|
+
{
|
|
14
|
+
path: "/",
|
|
15
|
+
element: <Layout />,
|
|
16
|
+
errorElement: (
|
|
17
|
+
<Layout>
|
|
18
|
+
<div className="h-[75vh] flex items-center justify-center">
|
|
19
|
+
Error, look at the console
|
|
20
|
+
</div>
|
|
21
|
+
</Layout>
|
|
22
|
+
),
|
|
23
|
+
children: routes,
|
|
24
|
+
},
|
|
25
|
+
]);
|
|
26
|
+
}, [plugins]);
|
|
27
|
+
return <RouterProvider router={router} />;
|
|
28
|
+
}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import { DevPortalContext } from "../core/DevPortalContext.js";
|
|
2
|
+
|
|
3
|
+
export interface AuthProvider {
|
|
4
|
+
initialize(context: DevPortalContext): Promise<unknown>;
|
|
5
|
+
login(context: DevPortalContext): Promise<unknown>;
|
|
6
|
+
getToken?: (context: DevPortalContext) => Promise<string | undefined>;
|
|
7
|
+
handleAuthenticationResponse?: (
|
|
8
|
+
path: Path,
|
|
9
|
+
context: DevPortalContext,
|
|
10
|
+
) => Promise<unknown>;
|
|
11
|
+
signOut(context: DevPortalContext): void;
|
|
12
|
+
}
|
|
13
|
+
|
|
14
|
+
export type Path = {
|
|
15
|
+
pathname: string;
|
|
16
|
+
search: string;
|
|
17
|
+
hash: string;
|
|
18
|
+
};
|
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
import { Clerk } from "@clerk/clerk-js";
|
|
2
|
+
import { type AuthProvider } from "./authentication.js";
|
|
3
|
+
|
|
4
|
+
const clerkProvider = ({
|
|
5
|
+
clerkPubKey,
|
|
6
|
+
}: {
|
|
7
|
+
clerkPubKey: string;
|
|
8
|
+
}): AuthProvider => {
|
|
9
|
+
const clerkApi = new Clerk(clerkPubKey);
|
|
10
|
+
|
|
11
|
+
const clerkIsLoaded = clerkApi.load({});
|
|
12
|
+
|
|
13
|
+
return {
|
|
14
|
+
initialize: async (context) => {
|
|
15
|
+
await clerkIsLoaded;
|
|
16
|
+
|
|
17
|
+
if (clerkApi.session) {
|
|
18
|
+
await context.setUserProfile({
|
|
19
|
+
isLoggedIn: true,
|
|
20
|
+
name: clerkApi.session.user.fullName ?? undefined,
|
|
21
|
+
email:
|
|
22
|
+
clerkApi.session.user.emailAddresses.at(0)?.emailAddress ??
|
|
23
|
+
undefined,
|
|
24
|
+
});
|
|
25
|
+
} else {
|
|
26
|
+
await context.setUserProfile({
|
|
27
|
+
isLoggedIn: false,
|
|
28
|
+
});
|
|
29
|
+
}
|
|
30
|
+
},
|
|
31
|
+
|
|
32
|
+
getToken: async () => {
|
|
33
|
+
await clerkIsLoaded;
|
|
34
|
+
const token = await clerkApi.session?.getToken();
|
|
35
|
+
return token ?? undefined;
|
|
36
|
+
},
|
|
37
|
+
|
|
38
|
+
signOut() {
|
|
39
|
+
clerkApi.signOut();
|
|
40
|
+
},
|
|
41
|
+
login: async () => {
|
|
42
|
+
await clerkApi.redirectToSignIn();
|
|
43
|
+
},
|
|
44
|
+
};
|
|
45
|
+
};
|
|
46
|
+
|
|
47
|
+
export default clerkProvider;
|