@osdk/create-app 2.1.0-beta.8 → 2.1.0-rc.32
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/CHANGELOG.md +56 -0
- package/build/esm/{esm-FXURBNU2.js → esm-4SFFV2ZK.js} +6 -6
- package/build/esm/esm-4SFFV2ZK.js.map +1 -0
- package/build/esm/esm-BFQ5RNHV.js +1249 -0
- package/build/esm/esm-BFQ5RNHV.js.map +1 -0
- package/build/esm/{esm-G7B67PJ6.js → esm-EXZTN5HA.js} +5 -5
- package/build/esm/esm-EXZTN5HA.js.map +1 -0
- package/build/{browser/esm-S2OWTMMF.js → esm/esm-FZSV3C5D.js} +73 -53
- package/build/esm/esm-FZSV3C5D.js.map +1 -0
- package/build/{browser/esm-F6Y6OKER.js → esm/esm-HA4JIHHL.js} +4 -4
- package/build/esm/esm-HA4JIHHL.js.map +1 -0
- package/build/esm/{esm-LF7OTAKA.js → esm-NFVUE2AE.js} +6 -6
- package/build/esm/esm-NFVUE2AE.js.map +1 -0
- package/build/{browser/esm-4QSCBEZC.js → esm/esm-WPYEYT7F.js} +31 -34
- package/build/esm/esm-WPYEYT7F.js.map +1 -0
- package/build/esm/{esm-PQDKPDBA.js → esm-XWXVWZDN.js} +8 -8
- package/build/esm/esm-XWXVWZDN.js.map +1 -0
- package/build/{browser/esm-Y7D2PCM4.js → esm/esm-YVNV3MQG.js} +8 -8
- package/build/esm/esm-YVNV3MQG.js.map +1 -0
- package/build/esm/{esm-H2IADGOR.js → esm-ZDKAQEHX.js} +33 -37
- package/build/esm/esm-ZDKAQEHX.js.map +1 -0
- package/build/esm/{esm-IWXD7ZFP.js → esm-ZXMFAUNZ.js} +8 -8
- package/build/esm/esm-ZXMFAUNZ.js.map +1 -0
- package/build/esm/index.js +28 -18
- package/build/esm/index.js.map +1 -1
- package/build/{esm → types}/cli.d.ts +0 -1
- package/build/types/cli.d.ts.map +1 -0
- package/build/types/cli.test.d.ts +1 -0
- package/build/types/cli.test.d.ts.map +1 -0
- package/build/{esm → types}/consola.d.ts +0 -1
- package/build/types/consola.d.ts.map +1 -0
- package/build/types/generate/generateEnv.d.ts +12 -0
- package/build/types/generate/generateEnv.d.ts.map +1 -0
- package/build/types/generate/generateEnv.test.d.ts +1 -0
- package/build/types/generate/generateEnv.test.d.ts.map +1 -0
- package/build/types/generate/generateFoundryConfigJson.d.ts +5 -0
- package/build/types/generate/generateFoundryConfigJson.d.ts.map +1 -0
- package/build/types/generate/generateFoundryConfigJson.test.d.ts +1 -0
- package/build/types/generate/generateFoundryConfigJson.test.d.ts.map +1 -0
- package/build/types/generate/generateNpmRc.d.ts +4 -0
- package/build/types/generate/generateNpmRc.d.ts.map +1 -0
- package/build/types/generate/generateNpmRc.test.d.ts +1 -0
- package/build/types/generate/generateNpmRc.test.d.ts.map +1 -0
- package/build/{esm → types}/generatedNoCheck/templates.d.ts +0 -1
- package/build/types/generatedNoCheck/templates.d.ts.map +1 -0
- package/build/{esm → types}/getPackageFiles.d.ts +1 -2
- package/build/types/getPackageFiles.d.ts.map +1 -0
- package/build/{esm → types}/highlight.d.ts +0 -1
- package/build/types/highlight.d.ts.map +1 -0
- package/build/{esm → types}/index.d.ts +1 -2
- package/build/types/index.d.ts.map +1 -0
- package/build/{esm → types}/prompts/promptApplicationRid.d.ts +1 -2
- package/build/types/prompts/promptApplicationRid.d.ts.map +1 -0
- package/build/types/prompts/promptApplicationRid.test.d.ts +1 -0
- package/build/types/prompts/promptApplicationRid.test.d.ts.map +1 -0
- package/build/{esm → types}/prompts/promptApplicationUrl.d.ts +2 -3
- package/build/types/prompts/promptApplicationUrl.d.ts.map +1 -0
- package/build/types/prompts/promptApplicationUrl.test.d.ts +1 -0
- package/build/types/prompts/promptApplicationUrl.test.d.ts.map +1 -0
- package/build/{esm → types}/prompts/promptClientId.d.ts +1 -2
- package/build/types/prompts/promptClientId.d.ts.map +1 -0
- package/build/types/prompts/promptClientId.test.d.ts +1 -0
- package/build/types/prompts/promptClientId.test.d.ts.map +1 -0
- package/build/{esm → types}/prompts/promptCorsProxy.d.ts +1 -2
- package/build/types/prompts/promptCorsProxy.d.ts.map +1 -0
- package/build/types/prompts/promptCorsProxy.test.d.ts +1 -0
- package/build/types/prompts/promptCorsProxy.test.d.ts.map +1 -0
- package/build/{esm → types}/prompts/promptFoundryUrl.d.ts +1 -2
- package/build/types/prompts/promptFoundryUrl.d.ts.map +1 -0
- package/build/types/prompts/promptFoundryUrl.test.d.ts +1 -0
- package/build/types/prompts/promptFoundryUrl.test.d.ts.map +1 -0
- package/build/{esm → types}/prompts/promptOsdkPackage.d.ts +1 -2
- package/build/types/prompts/promptOsdkPackage.d.ts.map +1 -0
- package/build/types/prompts/promptOsdkPackage.test.d.ts +1 -0
- package/build/types/prompts/promptOsdkPackage.test.d.ts.map +1 -0
- package/build/{esm → types}/prompts/promptOsdkRegistryUrl.d.ts +1 -2
- package/build/types/prompts/promptOsdkRegistryUrl.d.ts.map +1 -0
- package/build/types/prompts/promptOsdkRegistryUrl.test.d.ts +1 -0
- package/build/types/prompts/promptOsdkRegistryUrl.test.d.ts.map +1 -0
- package/build/types/prompts/promptOverwrite.d.ts +4 -0
- package/build/types/prompts/promptOverwrite.d.ts.map +1 -0
- package/build/types/prompts/promptOverwrite.test.d.ts +1 -0
- package/build/types/prompts/promptOverwrite.test.d.ts.map +1 -0
- package/build/{esm → types}/prompts/promptProject.d.ts +1 -2
- package/build/types/prompts/promptProject.d.ts.map +1 -0
- package/build/types/prompts/promptProject.test.d.ts +1 -0
- package/build/types/prompts/promptProject.test.d.ts.map +1 -0
- package/build/{esm → types}/prompts/promptScopes.d.ts +1 -2
- package/build/types/prompts/promptScopes.d.ts.map +1 -0
- package/build/{esm → types}/prompts/promptSdkVersion.d.ts +2 -3
- package/build/types/prompts/promptSdkVersion.d.ts.map +1 -0
- package/build/{esm → types}/prompts/promptTemplate.d.ts +2 -3
- package/build/types/prompts/promptTemplate.d.ts.map +1 -0
- package/build/types/prompts/promptTemplate.test.d.ts +1 -0
- package/build/types/prompts/promptTemplate.test.d.ts.map +1 -0
- package/build/types/run.d.ts +17 -0
- package/build/types/run.d.ts.map +1 -0
- package/build/types/templates.d.ts +25 -0
- package/build/types/templates.d.ts.map +1 -0
- package/package.json +33 -28
- package/build/browser/esm-4QSCBEZC.js.map +0 -1
- package/build/browser/esm-F6Y6OKER.js.map +0 -1
- package/build/browser/esm-FXURBNU2.js +0 -421
- package/build/browser/esm-FXURBNU2.js.map +0 -1
- package/build/browser/esm-G7B67PJ6.js +0 -281
- package/build/browser/esm-G7B67PJ6.js.map +0 -1
- package/build/browser/esm-H2IADGOR.js +0 -1184
- package/build/browser/esm-H2IADGOR.js.map +0 -1
- package/build/browser/esm-IWXD7ZFP.js +0 -453
- package/build/browser/esm-IWXD7ZFP.js.map +0 -1
- package/build/browser/esm-LF7OTAKA.js +0 -394
- package/build/browser/esm-LF7OTAKA.js.map +0 -1
- package/build/browser/esm-PQDKPDBA.js +0 -903
- package/build/browser/esm-PQDKPDBA.js.map +0 -1
- package/build/browser/esm-S2OWTMMF.js.map +0 -1
- package/build/browser/esm-Y7D2PCM4.js.map +0 -1
- package/build/browser/index.js +0 -668
- package/build/browser/index.js.map +0 -1
- package/build/esm/cli.d.ts.map +0 -1
- package/build/esm/cli.test.d.ts +0 -2
- package/build/esm/cli.test.d.ts.map +0 -1
- package/build/esm/consola.d.ts.map +0 -1
- package/build/esm/esm-4QSCBEZC.js +0 -916
- package/build/esm/esm-4QSCBEZC.js.map +0 -1
- package/build/esm/esm-F6Y6OKER.js +0 -260
- package/build/esm/esm-F6Y6OKER.js.map +0 -1
- package/build/esm/esm-FXURBNU2.js.map +0 -1
- package/build/esm/esm-G7B67PJ6.js.map +0 -1
- package/build/esm/esm-H2IADGOR.js.map +0 -1
- package/build/esm/esm-IWXD7ZFP.js.map +0 -1
- package/build/esm/esm-LF7OTAKA.js.map +0 -1
- package/build/esm/esm-PQDKPDBA.js.map +0 -1
- package/build/esm/esm-S2OWTMMF.js +0 -383
- package/build/esm/esm-S2OWTMMF.js.map +0 -1
- package/build/esm/esm-Y7D2PCM4.js +0 -1171
- package/build/esm/esm-Y7D2PCM4.js.map +0 -1
- package/build/esm/generate/generateEnv.d.ts +0 -13
- package/build/esm/generate/generateEnv.d.ts.map +0 -1
- package/build/esm/generate/generateEnv.test.d.ts +0 -2
- package/build/esm/generate/generateEnv.test.d.ts.map +0 -1
- package/build/esm/generate/generateFoundryConfigJson.d.ts +0 -6
- package/build/esm/generate/generateFoundryConfigJson.d.ts.map +0 -1
- package/build/esm/generate/generateFoundryConfigJson.test.d.ts +0 -2
- package/build/esm/generate/generateFoundryConfigJson.test.d.ts.map +0 -1
- package/build/esm/generate/generateNpmRc.d.ts +0 -5
- package/build/esm/generate/generateNpmRc.d.ts.map +0 -1
- package/build/esm/generate/generateNpmRc.test.d.ts +0 -2
- package/build/esm/generate/generateNpmRc.test.d.ts.map +0 -1
- package/build/esm/generatedNoCheck/templates.d.ts.map +0 -1
- package/build/esm/getPackageFiles.d.ts.map +0 -1
- package/build/esm/highlight.d.ts.map +0 -1
- package/build/esm/index.d.ts.map +0 -1
- package/build/esm/prompts/promptApplicationRid.d.ts.map +0 -1
- package/build/esm/prompts/promptApplicationRid.test.d.ts +0 -2
- package/build/esm/prompts/promptApplicationRid.test.d.ts.map +0 -1
- package/build/esm/prompts/promptApplicationUrl.d.ts.map +0 -1
- package/build/esm/prompts/promptApplicationUrl.test.d.ts +0 -2
- package/build/esm/prompts/promptApplicationUrl.test.d.ts.map +0 -1
- package/build/esm/prompts/promptClientId.d.ts.map +0 -1
- package/build/esm/prompts/promptClientId.test.d.ts +0 -2
- package/build/esm/prompts/promptClientId.test.d.ts.map +0 -1
- package/build/esm/prompts/promptCorsProxy.d.ts.map +0 -1
- package/build/esm/prompts/promptCorsProxy.test.d.ts +0 -2
- package/build/esm/prompts/promptCorsProxy.test.d.ts.map +0 -1
- package/build/esm/prompts/promptFoundryUrl.d.ts.map +0 -1
- package/build/esm/prompts/promptFoundryUrl.test.d.ts +0 -2
- package/build/esm/prompts/promptFoundryUrl.test.d.ts.map +0 -1
- package/build/esm/prompts/promptOsdkPackage.d.ts.map +0 -1
- package/build/esm/prompts/promptOsdkPackage.test.d.ts +0 -2
- package/build/esm/prompts/promptOsdkPackage.test.d.ts.map +0 -1
- package/build/esm/prompts/promptOsdkRegistryUrl.d.ts.map +0 -1
- package/build/esm/prompts/promptOsdkRegistryUrl.test.d.ts +0 -2
- package/build/esm/prompts/promptOsdkRegistryUrl.test.d.ts.map +0 -1
- package/build/esm/prompts/promptOverwrite.d.ts +0 -5
- package/build/esm/prompts/promptOverwrite.d.ts.map +0 -1
- package/build/esm/prompts/promptOverwrite.test.d.ts +0 -2
- package/build/esm/prompts/promptOverwrite.test.d.ts.map +0 -1
- package/build/esm/prompts/promptProject.d.ts.map +0 -1
- package/build/esm/prompts/promptProject.test.d.ts +0 -2
- package/build/esm/prompts/promptProject.test.d.ts.map +0 -1
- package/build/esm/prompts/promptScopes.d.ts.map +0 -1
- package/build/esm/prompts/promptSdkVersion.d.ts.map +0 -1
- package/build/esm/prompts/promptTemplate.d.ts.map +0 -1
- package/build/esm/prompts/promptTemplate.test.d.ts +0 -2
- package/build/esm/prompts/promptTemplate.test.d.ts.map +0 -1
- package/build/esm/run.d.ts +0 -18
- package/build/esm/run.d.ts.map +0 -1
- package/build/esm/templates.d.ts +0 -28
- package/build/esm/templates.d.ts.map +0 -1
|
@@ -1,1184 +0,0 @@
|
|
|
1
|
-
// ../create-app.template.tutorial-todo-aip-app.beta/build/esm/generatedNoCheck/index.js
|
|
2
|
-
var files = /* @__PURE__ */ new Map([["README.md.hbs", {
|
|
3
|
-
type: "raw",
|
|
4
|
-
body: `# {{project}}
|
|
5
|
-
|
|
6
|
-
This project was generated with [\`@osdk/create-app\`](https://www.npmjs.com/package/@osdk/create-app) and is intended to be used alongside the Developer Console tutorial for creating an AIP Logic backed To Do App against a reference Ontology.
|
|
7
|
-
|
|
8
|
-
## Developing
|
|
9
|
-
|
|
10
|
-
Run the following command or equivalent with your preferred package manager to start a local development server on \`http://localhost:8080\`:
|
|
11
|
-
|
|
12
|
-
\`\`\`sh
|
|
13
|
-
npm run dev
|
|
14
|
-
\`\`\`
|
|
15
|
-
|
|
16
|
-
Development configuration is stored in \`.env.development\`.
|
|
17
|
-
|
|
18
|
-
{{#if corsProxy}}
|
|
19
|
-
In order to make API requests to Foundry, a CORS proxy has been set up for local development which may be removed if the stack is configured to allow \`http://localhost:8080\` to load resources. The configured OAuth client must also allow \`http://localhost:8080/auth/callback\` as a redirect URL.
|
|
20
|
-
{{else}}
|
|
21
|
-
In order to make API requests to Foundry, CORS must be configured for the stack to allow \`http://localhost:8080\` to load resources. If this has not been configured and you are unable to request this, you can alternatively generate your project again with \`--corsProxy true\` to use a proxy for API requests during local development. The configured OAuth client must also allow \`http://localhost:8080/auth/callback\` as a redirect URL.
|
|
22
|
-
{{/if}}
|
|
23
|
-
|
|
24
|
-
## Deploying
|
|
25
|
-
|
|
26
|
-
Run the following command or equivalent with your preferred package manager to create a production build of your application:
|
|
27
|
-
|
|
28
|
-
\`\`\`sh
|
|
29
|
-
npm run build
|
|
30
|
-
\`\`\`
|
|
31
|
-
|
|
32
|
-
Production configuration is stored in \`.env.production\`.
|
|
33
|
-
|
|
34
|
-
If you did not fill in the URL your production application will be hosted on you will need to fill in the \`VITE_FOUNDRY_REDIRECT_URL\` in \`.env.production\`. A default test is included in \`env.test.ts\` to verify your production environment variables which you can enable by removing the skip condition or running tests with the environment variable set \`VERIFY_ENV_PRODUCTION=true\`.
|
|
35
|
-
|
|
36
|
-
In order to make API requests to Foundry, CORS must be configured for the stack to allow the production origin to load resources. This will be automatically done for you if you are using Foundry website hosting. The configured OAuth client must also allow the production origin auth callback as a redirect URL.
|
|
37
|
-
|
|
38
|
-
A \`foundry.config.json\` file is included in the root of this project to make deploying to Foundry website hosting with [\`@osdk/cli\`](https://www.npmjs.com/package/@osdk/cli) easier. If you are not using Foundry website hosting for your application you may delete this file.
|
|
39
|
-
`
|
|
40
|
-
}], [".gitignore", {
|
|
41
|
-
type: "raw",
|
|
42
|
-
body: `# Logs
|
|
43
|
-
logs
|
|
44
|
-
*.log
|
|
45
|
-
npm-debug.log*
|
|
46
|
-
yarn-debug.log*
|
|
47
|
-
yarn-error.log*
|
|
48
|
-
pnpm-debug.log*
|
|
49
|
-
lerna-debug.log*
|
|
50
|
-
|
|
51
|
-
node_modules
|
|
52
|
-
dist
|
|
53
|
-
dist-ssr
|
|
54
|
-
*.local
|
|
55
|
-
|
|
56
|
-
# Editor directories and files
|
|
57
|
-
.vscode/*
|
|
58
|
-
!.vscode/extensions.json
|
|
59
|
-
.idea
|
|
60
|
-
.DS_Store
|
|
61
|
-
*.suo
|
|
62
|
-
*.ntvs*
|
|
63
|
-
*.njsproj
|
|
64
|
-
*.sln
|
|
65
|
-
*.sw?
|
|
66
|
-
`
|
|
67
|
-
}], ["eslint.config.mjs", {
|
|
68
|
-
"type": "base64",
|
|
69
|
-
"body": "Ly8gQHRzLWNoZWNrCmltcG9ydCBlc2xpbnQgZnJvbSAiQGVzbGludC9qcyI7CmltcG9ydCB0c1BhcnNlciBmcm9tICJAdHlwZXNjcmlwdC1lc2xpbnQvcGFyc2VyIjsKaW1wb3J0ICogYXMgaW1wb3J0UGx1Z2luIGZyb20gImVzbGludC1wbHVnaW4taW1wb3J0IjsKaW1wb3J0IGpzeEExMXlQbHVnaW4gZnJvbSAiZXNsaW50LXBsdWdpbi1qc3gtYTExeSI7CmltcG9ydCByZWFjdFBsdWdpbiBmcm9tICJlc2xpbnQtcGx1Z2luLXJlYWN0IjsKaW1wb3J0IHJlYWN0SG9va3NQbHVnaW4gZnJvbSAiZXNsaW50LXBsdWdpbi1yZWFjdC1ob29rcyI7CmltcG9ydCByZWFjdFJlZnJlc2ggZnJvbSAiZXNsaW50LXBsdWdpbi1yZWFjdC1yZWZyZXNoIjsKaW1wb3J0IGdsb2JhbHMgZnJvbSAiZ2xvYmFscyI7CmltcG9ydCB0c2VzbGludCBmcm9tICJ0eXBlc2NyaXB0LWVzbGludCI7CgpleHBvcnQgZGVmYXVsdCB0c2VzbGludC5jb25maWcoewogIGZpbGVzOiBbImVzbGludC5jb25maWcubWpzIiwgInNyYy8qKi8qLntqcyxtanMsY2pzLHRzLGpzeCx0c3h9Il0sCiAgc2V0dGluZ3M6IHsKICAgIHJlYWN0OiB7CiAgICAgIHZlcnNpb246ICJkZXRlY3QiLAogICAgfSwKCiAgICAiaW1wb3J0L3Jlc29sdmVyIjogewogICAgICBub2RlOiB7CiAgICAgICAgZXh0ZW5zaW9uczogWyIuanMiLCAiLmpzeCIsICIudHMiLCAiLnRzeCJdLAogICAgICB9LAogICAgfSwKICB9LAogIGxhbmd1YWdlT3B0aW9uczogewogICAgZ2xvYmFsczogewogICAgICAuLi5nbG9iYWxzLmJyb3dzZXIsCiAgICB9LAoKICAgIHBhcnNlcjogdHNQYXJzZXIsCiAgfSwKICBleHRlbmRzOiBbCiAgICBlc2xpbnQuY29uZmlncy5yZWNvbW1lbmRlZCwKICAgIC4uLnRzZXNsaW50LmNvbmZpZ3MucmVjb21tZW5kZWQsCiAgXSwKICBwbHVnaW5zOiB7CiAgICAicmVhY3QiOiAvKiogQHR5cGUgaW1wb3J0KCJlc2xpbnQiKS5FU0xpbnQuUGx1Z2luICovIChyZWFjdFBsdWdpbiksCiAgICAicmVhY3QtcmVmcmVzaCI6IHJlYWN0UmVmcmVzaCwKICAgICJyZWFjdC1ob29rcyI6CiAgICAgIC8qKiBAdHlwZSBpbXBvcnQoImVzbGludCIpLkVTTGludC5QbHVnaW4gKi8gKHJlYWN0SG9va3NQbHVnaW4pLAogICAgImpzeC1hMTF5IjoganN4QTExeVBsdWdpbiwKICAgICJpbXBvcnQiOiBpbXBvcnRQbHVnaW4sCiAgfSwKICBydWxlczogewogICAgLi4uKAogICAgICAvKiogQHR5cGUgaW1wb3J0KCJlc2xpbnQiKS5MaW50ZXIuUnVsZXNSZWNvcmQgKi8KICAgICAgKHJlYWN0UGx1Z2luLmNvbmZpZ3MuZmxhdD8ucmVjb21tZW5kZWQucnVsZXMpCiAgICApLAogICAgInJlYWN0LWhvb2tzL3J1bGVzLW9mLWhvb2tzIjogImVycm9yIiwKICAgICJyZWFjdC1ob29rcy9leGhhdXN0aXZlLWRlcHMiOiAid2FybiIsCiAgICAuLi5qc3hBMTF5UGx1Z2luLmNvbmZpZ3MucmVjb21tZW5kZWQucnVsZXMsCiAgICAicmVhY3QtcmVmcmVzaC9vbmx5LWV4cG9ydC1jb21wb25lbnRzIjogWyJ3YXJuIiwgewogICAgICBhbGxvd0NvbnN0YW50RXhwb3J0OiB0cnVlLAogICAgfV0sCgogICAgImltcG9ydC9uYW1lZCI6ICJlcnJvciIsCiAgICAiaW1wb3J0L2RlZmF1bHQiOiAiZXJyb3IiLAogICAgImltcG9ydC9uYW1lc3BhY2UiOiAiZXJyb3IiLAogICAgImltcG9ydC9uby1kdXBsaWNhdGVzIjogImVycm9yIiwKICAgICJpbXBvcnQvbm8tZXh0cmFuZW91cy1kZXBlbmRlbmNpZXMiOiAiZXJyb3IiLAoKICAgICJyZWFjdC9yZWFjdC1pbi1qc3gtc2NvcGUiOiAib2ZmIiwKICB9LAp9KTsK"
|
|
70
|
-
}], ["index.html", {
|
|
71
|
-
type: "raw",
|
|
72
|
-
body: `<!doctype html>
|
|
73
|
-
<html lang="en">
|
|
74
|
-
<head>
|
|
75
|
-
<meta charset="UTF-8" />
|
|
76
|
-
<link rel="icon" type="image/svg+xml" href="/todo-aip-app.svg" />
|
|
77
|
-
<meta name="viewport" content="width=device-width, initial-scale=1.0" />
|
|
78
|
-
<title>Ontology SDK Tutorial - To do AIP App</title>
|
|
79
|
-
</head>
|
|
80
|
-
<body>
|
|
81
|
-
<div id="root-container">
|
|
82
|
-
<div id="root"></div>
|
|
83
|
-
</div>
|
|
84
|
-
<script type="module" src="/src/main.tsx"></script>
|
|
85
|
-
</body>
|
|
86
|
-
</html>
|
|
87
|
-
`
|
|
88
|
-
}], ["package.json.hbs", {
|
|
89
|
-
type: "raw",
|
|
90
|
-
body: `{
|
|
91
|
-
"name": "{{project}}",
|
|
92
|
-
"private": true,
|
|
93
|
-
"version": "0.0.0",
|
|
94
|
-
"type": "module",
|
|
95
|
-
"scripts": {
|
|
96
|
-
"dev": "vite",
|
|
97
|
-
"build": "tsc && vite build",
|
|
98
|
-
"lint": "eslint . --report-unused-disable-directives --max-warnings 0",
|
|
99
|
-
"test": "vitest run",
|
|
100
|
-
"preview": "vite preview"
|
|
101
|
-
},
|
|
102
|
-
"dependencies": {
|
|
103
|
-
"{{osdkPackage}}": "latest",
|
|
104
|
-
"@osdk/client": "{{clientVersion}}",
|
|
105
|
-
"@osdk/oauth": "^1.0.0",
|
|
106
|
-
"react": "^18",
|
|
107
|
-
"react-dom": "^18",
|
|
108
|
-
"react-router-dom": "^6.23.1",
|
|
109
|
-
"swr": "^2.2.5"
|
|
110
|
-
},
|
|
111
|
-
"devDependencies": {
|
|
112
|
-
"@eslint/js": "^9.13.0",
|
|
113
|
-
"@types/react": "^18",
|
|
114
|
-
"@types/react-dom": "^18",
|
|
115
|
-
"@typescript-eslint/eslint-plugin": "^8.11.0",
|
|
116
|
-
"@typescript-eslint/parser": "^8.11.0",
|
|
117
|
-
"@vitejs/plugin-react": "^4.2.0",
|
|
118
|
-
"eslint": "^9.13.0",
|
|
119
|
-
"eslint-plugin-import": "^2.31.0",
|
|
120
|
-
"eslint-plugin-jsx-a11y": "^6.10.1",
|
|
121
|
-
"eslint-plugin-react": "^7.37.2",
|
|
122
|
-
"eslint-plugin-react-hooks": "^5.0.0",
|
|
123
|
-
"eslint-plugin-react-refresh": "^0.4.14",
|
|
124
|
-
"globals": "^15.11.0",
|
|
125
|
-
"typescript": "~5.5.4",
|
|
126
|
-
"typescript-eslint": "^8.11.0",
|
|
127
|
-
"vite": "^5.3.4",
|
|
128
|
-
"vitest": "^2.0.5"
|
|
129
|
-
}
|
|
130
|
-
}`
|
|
131
|
-
}], ["public/aip-icon.svg", {
|
|
132
|
-
"type": "base64",
|
|
133
|
-
"body": "PHN2ZyB3aWR0aD0iMTYiIGhlaWdodD0iMTYiIHZpZXdCb3g9IjAgMCAxNiAxNiIgZmlsbD0ibm9uZSIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj4KPHBhdGggZmlsbC1ydWxlPSJldmVub2RkIiBjbGlwLXJ1bGU9ImV2ZW5vZGQiIGQ9Ik03Ljk5OTQ5IDFIMi4wNjE4NkMwLjQ3NzI5NCAxIC0wLjUxMzI3NiAyLjY2NjI0IDAuMjc4NTY1IDMuOTk5NjhMMi42NTQwOSA4TDAuMjc4NTY1IDEyLjAwMDNDLTAuNTEzMjc2IDEzLjMzMzggMC40NzcyOTUgMTUgMi4wNjE4NiAxNUgxMy45MzgxQzE1LjUyMjcgMTUgMTYuNTEzMyAxMy4zMzM4IDE1LjcyMTQgMTIuMDAwM0wxMy4zNDU5IDhMMTUuNzIxNCAzLjk5OTY4QzE2LjUxMzMgMi42NjYyNCAxNS41MjI3IDEgMTMuOTM4MSAxSDguMDAwNTFINy45OTk0OVpNNi4yMTcwNCAyLjAwMDA4SDIuMDYxODZDMS4yNjk1NyAyLjAwMDA4IDAuNzc0Mjg5IDIuODMzMiAxLjE3MDIxIDMuNDk5OTJMMy4yNDgzIDYuOTk5MzdMNi4yMTcwNCAyLjAwMDA4Wk0zLjI0ODMgOS4wMDA2M0wxLjE3MDIxIDEyLjUwMDFDMC43NzQyOSAxMy4xNjY4IDEuMjY5NTcgMTMuOTk5OSAyLjA2MTg2IDEzLjk5OTlINi4yMTcwNEwzLjI0ODMgOS4wMDA2M1pNOS43ODI5NiAxMy45OTk5SDEzLjkzODFDMTQuNzMwNCAxMy45OTk5IDE1LjIyNTcgMTMuMTY2OCAxNC44Mjk4IDEyLjUwMDFMMTIuNzUxNyA5LjAwMDYzTDkuNzgyOTYgMTMuOTk5OVpNMTIuMTU3NSA4TDguODkxNjQgMTMuNDk5NkM4LjQ5NTUgMTQuMTY2NyA3LjUwNDUgMTQuMTY2NyA3LjEwODM2IDEzLjQ5OTZMMy44NDI1MSA4TDcuMTA4MzYgMi41MDA0QzcuNTA0NSAxLjgzMzMxIDguNDk1NTEgMS44MzMzMSA4Ljg5MTY1IDIuNTAwNEwxMi4xNTc1IDhaTTEyLjc1MTcgNi45OTkzNkwxNC44Mjk4IDMuNDk5OTJDMTUuMjI1NyAyLjgzMzIgMTQuNzMwNCAyLjAwMDA4IDEzLjkzODEgMi4wMDAwOEg5Ljc4Mjk2TDEyLjc1MTcgNi45OTkzNloiIGZpbGw9IndoaXRlIi8+Cjwvc3ZnPgo="
|
|
134
|
-
}], ["public/todo-aip-app.svg", {
|
|
135
|
-
"type": "base64",
|
|
136
|
-
"body": "PHN2ZyB3aWR0aD0iNTAiIGhlaWdodD0iNTAiIHZpZXdCb3g9IjAgMCA1MCA1MCIgZmlsbD0ibm9uZSIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj4KPGcgY2xpcC1wYXRoPSJ1cmwoI2NsaXAwXzM1NzJfNjIxOTUpIj4KPHJlY3Qgb3BhY2l0eT0iMC4xIiB3aWR0aD0iNTAiIGhlaWdodD0iNTAiIGZpbGw9IiM5ODgxRjMiLz4KPHJlY3QgeD0iNyIgeT0iMTEiIHdpZHRoPSIxMiIgaGVpZ2h0PSIxMiIgcng9IjIiIGZpbGw9IiM3OTYxREIiLz4KPHJlY3QgeD0iNy41IiB5PSIxMS41IiB3aWR0aD0iMTEiIGhlaWdodD0iMTEiIHJ4PSIxLjUiIHN0cm9rZT0id2hpdGUiIHN0cm9rZS1vcGFjaXR5PSIwLjEiLz4KPHBhdGggZmlsbC1ydWxlPSJldmVub2RkIiBjbGlwLXJ1bGU9ImV2ZW5vZGQiIGQ9Ik0xNiAxNC4zNzVDMTUuNzkgMTQuMzc1IDE1LjYwMjUgMTQuNDU3NSAxNS40Njc1IDE0LjU5MjVMMTIuMjUgMTcuODE3NUwxMC41MzI1IDE2LjA5MjVDMTAuMzk3NSAxNS45NTc1IDEwLjIxIDE1Ljg3NSAxMCAxNS44NzVDOS41ODc1IDE1Ljg3NSA5LjI1IDE2LjIxMjUgOS4yNSAxNi42MjVDOS4yNSAxNi44MzUgOS4zMzI1IDE3LjAyMjUgOS40Njc1IDE3LjE1NzVMMTEuNzE3NSAxOS40MDc1QzExLjg1MjUgMTkuNTQyNSAxMi4wNCAxOS42MjUgMTIuMjUgMTkuNjI1QzEyLjQ2IDE5LjYyNSAxMi42NDc1IDE5LjU0MjUgMTIuNzgyNSAxOS40MDc1TDE2LjUzMjUgMTUuNjU3NUMxNi42Njc1IDE1LjUyMjUgMTYuNzUgMTUuMzM1IDE2Ljc1IDE1LjEyNUMxNi43NSAxNC43MTI1IDE2LjQxMjUgMTQuMzc1IDE2IDE0LjM3NVoiIGZpbGw9IndoaXRlIi8+CjxyZWN0IG9wYWNpdHk9IjAuNSIgeD0iMjIiIHk9IjE1IiB3aWR0aD0iMTIiIGhlaWdodD0iNSIgcng9IjIuNSIgZmlsbD0iIzYzNERCRiIvPgo8cmVjdCBvcGFjaXR5PSIwLjUiIHg9IjM2IiB5PSIxNSIgd2lkdGg9IjkiIGhlaWdodD0iNSIgcng9IjIuNSIgZmlsbD0iIzYzNERCRiIvPgo8cmVjdCB4PSI3LjUiIHk9IjI4LjUiIHdpZHRoPSIxMSIgaGVpZ2h0PSIxMSIgcng9IjEuNSIgZmlsbD0iI0E3OUJEQSIgZmlsbC1vcGFjaXR5PSIwLjEiLz4KPHJlY3QgeD0iNy41IiB5PSIyOC41IiB3aWR0aD0iMTEiIGhlaWdodD0iMTEiIHJ4PSIxLjUiIHN0cm9rZT0iI0EzOUNDMSIvPgo8cmVjdCBvcGFjaXR5PSIwLjUiIHg9IjIzIiB5PSIzMiIgd2lkdGg9IjYiIGhlaWdodD0iNSIgcng9IjIuNSIgZmlsbD0iIzYzNERCRiIvPgo8cGF0aCBvcGFjaXR5PSIwLjUiIGQ9Ik0zMSAzNC41QzMxIDMzLjExOTMgMzIuMzIyOCAzMiAzMy45NTQ1IDMySDQxLjA0NTVDNDIuNjc3MiAzMiA0NCAzMy4xMTkzIDQ0IDM0LjVDNDQgMzUuODgwNyA0Mi42NzcyIDM3IDQxLjA0NTUgMzdIMzMuOTU0NUMzMi4zMjI4IDM3IDMxIDM1Ljg4MDcgMzEgMzQuNVoiIGZpbGw9IiM2MzREQkYiLz4KPC9nPgo8ZGVmcz4KPGNsaXBQYXRoIGlkPSJjbGlwMF8zNTcyXzYyMTk1Ij4KPHJlY3Qgd2lkdGg9IjUwIiBoZWlnaHQ9IjUwIiByeD0iNCIgZmlsbD0id2hpdGUiLz4KPC9jbGlwUGF0aD4KPC9kZWZzPgo8L3N2Zz4K"
|
|
137
|
-
}], ["src/AuthCallback.tsx", {
|
|
138
|
-
type: "raw",
|
|
139
|
-
body: `import { useEffect, useState } from "react";
|
|
140
|
-
import { useNavigate } from "react-router-dom";
|
|
141
|
-
import { auth } from "./client";
|
|
142
|
-
|
|
143
|
-
/**
|
|
144
|
-
* Component to render at \`/auth/callback\`
|
|
145
|
-
* This calls signIn() again to save the token, and then navigates the user back to the home page.
|
|
146
|
-
*/
|
|
147
|
-
function AuthCallback() {
|
|
148
|
-
const [error, setError] = useState<string | undefined>(undefined);
|
|
149
|
-
const navigate = useNavigate();
|
|
150
|
-
|
|
151
|
-
// This effect conflicts with React 18 strict mode in development
|
|
152
|
-
// https://react.dev/learn/synchronizing-with-effects#how-to-handle-the-effect-firing-twice-in-development
|
|
153
|
-
useEffect(() => {
|
|
154
|
-
auth
|
|
155
|
-
.signIn()
|
|
156
|
-
.then(() => navigate("/", { replace: true }))
|
|
157
|
-
.catch((e: unknown) => setError((e as Error).message ?? e));
|
|
158
|
-
}, [navigate]);
|
|
159
|
-
return <div>{error != null ? error : "Authenticating\u2026"}</div>;
|
|
160
|
-
}
|
|
161
|
-
|
|
162
|
-
export default AuthCallback;
|
|
163
|
-
`
|
|
164
|
-
}], ["src/AuthenticatedRoute.tsx", {
|
|
165
|
-
type: "raw",
|
|
166
|
-
body: `import { useEffect, useState } from "react";
|
|
167
|
-
import { Outlet, useNavigate } from "react-router-dom";
|
|
168
|
-
import { auth } from "./client";
|
|
169
|
-
|
|
170
|
-
/**
|
|
171
|
-
* A component that can be used to wrap routes that require authentication.
|
|
172
|
-
* Nested routes may assume that a valid token is present.
|
|
173
|
-
*/
|
|
174
|
-
function AuthenticatedRoute() {
|
|
175
|
-
const navigate = useNavigate();
|
|
176
|
-
const [token, setToken] = useState(auth.getTokenOrUndefined());
|
|
177
|
-
useEffect(() => {
|
|
178
|
-
if (auth.getTokenOrUndefined() == null) {
|
|
179
|
-
auth
|
|
180
|
-
.refresh()
|
|
181
|
-
.then(() => {
|
|
182
|
-
setToken(auth.getTokenOrUndefined());
|
|
183
|
-
})
|
|
184
|
-
.catch(() => {
|
|
185
|
-
// If we cannot refresh the token (i.e. the user is not logged in) we redirect to the login page
|
|
186
|
-
navigate("/login");
|
|
187
|
-
});
|
|
188
|
-
}
|
|
189
|
-
}, [navigate]);
|
|
190
|
-
|
|
191
|
-
if (token == null) {
|
|
192
|
-
return null;
|
|
193
|
-
}
|
|
194
|
-
|
|
195
|
-
return <Outlet />;
|
|
196
|
-
}
|
|
197
|
-
|
|
198
|
-
export default AuthenticatedRoute;
|
|
199
|
-
`
|
|
200
|
-
}], ["src/CreateProjectButton.module.css", {
|
|
201
|
-
"type": "base64",
|
|
202
|
-
"body": "LmJ1dHRvbiB7CiAgYm9yZGVyOiAxcHggc29saWQgI2NjYzsKfQo="
|
|
203
|
-
}], ["src/CreateProjectButton.tsx", {
|
|
204
|
-
type: "raw",
|
|
205
|
-
body: `import { useCallback, useState } from "react";
|
|
206
|
-
import css from "./CreateProjectButton.module.css";
|
|
207
|
-
import CreateProjectDialog from "./CreateProjectDialog";
|
|
208
|
-
import useProjects from "./useProjects";
|
|
209
|
-
|
|
210
|
-
interface CreateProjectButtonProps {
|
|
211
|
-
onProjectCreated?: (projectId: string) => void;
|
|
212
|
-
}
|
|
213
|
-
|
|
214
|
-
function CreateProjectButton({ onProjectCreated }: CreateProjectButtonProps) {
|
|
215
|
-
const { isLoading: isLoadingProjects, isError: isErrorProjects } =
|
|
216
|
-
useProjects();
|
|
217
|
-
|
|
218
|
-
const [isOpen, setIsOpen] = useState(false);
|
|
219
|
-
const handleOpen = useCallback(() => setIsOpen(true), []);
|
|
220
|
-
const handleClose = useCallback(() => setIsOpen(false), []);
|
|
221
|
-
|
|
222
|
-
if (isLoadingProjects || isErrorProjects) {
|
|
223
|
-
return null;
|
|
224
|
-
}
|
|
225
|
-
|
|
226
|
-
return (
|
|
227
|
-
<>
|
|
228
|
-
<button onClick={handleOpen} className={css.button}>
|
|
229
|
-
Create Project
|
|
230
|
-
</button>
|
|
231
|
-
<CreateProjectDialog
|
|
232
|
-
isOpen={isOpen}
|
|
233
|
-
onClose={handleClose}
|
|
234
|
-
onProjectCreated={onProjectCreated}
|
|
235
|
-
/>
|
|
236
|
-
</>
|
|
237
|
-
);
|
|
238
|
-
}
|
|
239
|
-
|
|
240
|
-
export default CreateProjectButton;
|
|
241
|
-
`
|
|
242
|
-
}], ["src/CreateProjectDialog.module.css", {
|
|
243
|
-
"type": "base64",
|
|
244
|
-
"body": "LnByb2plY3QgewogICAgZGlzcGxheTogZmxleDsKICAgIGZsZXgtZGlyZWN0aW9uOiBjb2x1bW47CiAgICBhbGlnbi1jb250ZW50OiBzcGFjZS1iZXR3ZWVuOwogICAgZ2FwOiAxMHB4Owp9Ci5sYWJlbCB7CiAgZGlzcGxheTogZmxleDsKICBqdXN0aWZ5LWNvbnRlbnQ6IHNwYWNlLWJldHdlZW47CiAgZ2FwOiA1cHg7Cn0KCi5idXR0b24gewogIGJvcmRlcjogMXB4IHNvbGlkICNjY2M7Cn0K"
|
|
245
|
-
}], ["src/CreateProjectDialog.tsx", {
|
|
246
|
-
type: "raw",
|
|
247
|
-
body: `import type { ChangeEvent } from "react";
|
|
248
|
-
import { useCallback, useEffect, useState } from "react";
|
|
249
|
-
import css from "./CreateProjectDialog.module.css";
|
|
250
|
-
|
|
251
|
-
import Dialog from "./Dialog";
|
|
252
|
-
import useProjects from "./useProjects";
|
|
253
|
-
|
|
254
|
-
interface CreateProjectDialogProps {
|
|
255
|
-
isOpen: boolean;
|
|
256
|
-
onClose: () => void;
|
|
257
|
-
onProjectCreated?: (projectId: string) => void;
|
|
258
|
-
}
|
|
259
|
-
|
|
260
|
-
function CreateProjectDialog({
|
|
261
|
-
isOpen,
|
|
262
|
-
onClose,
|
|
263
|
-
onProjectCreated,
|
|
264
|
-
}: CreateProjectDialogProps) {
|
|
265
|
-
const { createProject } = useProjects();
|
|
266
|
-
|
|
267
|
-
const [name, setName] = useState<string>("New project");
|
|
268
|
-
|
|
269
|
-
const handleChangeProjectName = useCallback(
|
|
270
|
-
(e: ChangeEvent<HTMLInputElement>) => setName(e.target.value),
|
|
271
|
-
[],
|
|
272
|
-
);
|
|
273
|
-
|
|
274
|
-
useEffect(() => setName("New project"), [isOpen]);
|
|
275
|
-
|
|
276
|
-
const [isCreating, setIsCreating] = useState(false);
|
|
277
|
-
|
|
278
|
-
const handleSubmit = useCallback(async () => {
|
|
279
|
-
setIsCreating(true);
|
|
280
|
-
try {
|
|
281
|
-
const projectId = await createProject(name);
|
|
282
|
-
onProjectCreated?.(projectId);
|
|
283
|
-
} finally {
|
|
284
|
-
setIsCreating(false);
|
|
285
|
-
onClose();
|
|
286
|
-
}
|
|
287
|
-
}, [onProjectCreated, onClose, createProject, name]);
|
|
288
|
-
|
|
289
|
-
return (
|
|
290
|
-
<Dialog
|
|
291
|
-
isOpen={isOpen}
|
|
292
|
-
buttons={[
|
|
293
|
-
<button
|
|
294
|
-
disabled={isCreating}
|
|
295
|
-
onClick={onClose}
|
|
296
|
-
key="cancel"
|
|
297
|
-
className={css.button}
|
|
298
|
-
>
|
|
299
|
-
Cancel
|
|
300
|
-
</button>,
|
|
301
|
-
<button
|
|
302
|
-
disabled={isCreating}
|
|
303
|
-
onClick={handleSubmit}
|
|
304
|
-
key="create"
|
|
305
|
-
className={css.button}
|
|
306
|
-
>
|
|
307
|
-
Create project
|
|
308
|
-
</button>,
|
|
309
|
-
]}
|
|
310
|
-
>
|
|
311
|
-
<div className={css.project}>
|
|
312
|
-
<label className={css.label}>
|
|
313
|
-
Project name:{" "}
|
|
314
|
-
<input type="text" value={name} onChange={handleChangeProjectName} />
|
|
315
|
-
</label>
|
|
316
|
-
</div>
|
|
317
|
-
</Dialog>
|
|
318
|
-
);
|
|
319
|
-
}
|
|
320
|
-
export default CreateProjectDialog;
|
|
321
|
-
`
|
|
322
|
-
}], ["src/CreateTaskButton.module.css", {
|
|
323
|
-
"type": "base64",
|
|
324
|
-
"body": "LmJ1dHRvbiB7CiAgYm9yZGVyOiAxcHggc29saWQgI2NjYzsKfQo="
|
|
325
|
-
}], ["src/CreateTaskButton.tsx", {
|
|
326
|
-
type: "raw",
|
|
327
|
-
body: `import { useCallback, useState } from "react";
|
|
328
|
-
import css from "./CreateTaskButton.module.css";
|
|
329
|
-
import CreateTaskDialog from "./CreateTaskDialog";
|
|
330
|
-
import type { MockProject } from "./mocks";
|
|
331
|
-
import { useProjectTasks } from "./useProjectTasks";
|
|
332
|
-
|
|
333
|
-
interface CreateTaskButtonProps {
|
|
334
|
-
project: MockProject;
|
|
335
|
-
onTaskCreated: (taskId: string) => void;
|
|
336
|
-
}
|
|
337
|
-
|
|
338
|
-
function CreateTaskButton({ project, onTaskCreated }: CreateTaskButtonProps) {
|
|
339
|
-
const { isLoading: isLoadingTasks, isError: isErrorTasks } = useProjectTasks(
|
|
340
|
-
project,
|
|
341
|
-
);
|
|
342
|
-
|
|
343
|
-
const [isOpen, setIsOpen] = useState(false);
|
|
344
|
-
const handleOpen = useCallback(() => setIsOpen(true), []);
|
|
345
|
-
const handleClose = useCallback(() => setIsOpen(false), []);
|
|
346
|
-
|
|
347
|
-
if (isLoadingTasks || isErrorTasks) {
|
|
348
|
-
return null;
|
|
349
|
-
}
|
|
350
|
-
|
|
351
|
-
return (
|
|
352
|
-
<>
|
|
353
|
-
<button onClick={handleOpen} className={css.button}>Create Task</button>
|
|
354
|
-
<CreateTaskDialog
|
|
355
|
-
project={project}
|
|
356
|
-
isOpen={isOpen}
|
|
357
|
-
onClose={handleClose}
|
|
358
|
-
onTaskCreated={onTaskCreated}
|
|
359
|
-
/>
|
|
360
|
-
</>
|
|
361
|
-
);
|
|
362
|
-
}
|
|
363
|
-
|
|
364
|
-
export default CreateTaskButton;
|
|
365
|
-
`
|
|
366
|
-
}], ["src/CreateTaskDialog.module.css", {
|
|
367
|
-
"type": "base64",
|
|
368
|
-
"body": "LnRhc2sgewogICAgZGlzcGxheTogZ3JpZDsKICAgIGdyaWQtdGVtcGxhdGUtY29sdW1uczogMWZyIDFmcjsKICAgIGdyaWQtdGVtcGxhdGUtcm93czogYXV0byBtaW4tY29udGVudDsKICAgIGdhcDogMTBweDsKICAgIHdpZHRoOiA1MDBweDsKfQoubGFiZWwgewogIGRpc3BsYXk6IGZsZXg7CiAgZ2FwOiA1cHg7CiAgcmVzaXplOiBub25lOwp9CgouaW5wdXQgewogIHdpZHRoOiAzMDBweDsKICBib3JkZXI6IDFweCBzb2xpZCBncmF5OwogIGJvcmRlci1yYWRpdXM6IDVweDsKfQoKLnRleHRBcmVhIHsKICB3aWR0aDogMzAwcHg7CiAgcmVzaXplOiB2ZXJ0aWNhbDsKICBib3JkZXI6IDFweCBzb2xpZCBncmF5OwogIGJvcmRlci1yYWRpdXM6IDVweDsKICBwYWRkaW5nOiA1cHg7Cn0KCi5haXAgewogIGJhY2tncm91bmQtY29sb3I6ICM3OTYxREI7CiAgYm9yZGVyOiAxcHggc29saWQgI2NjYzsKICBwYWRkaW5nOiAycHggNXB4OwogIGRpc3BsYXk6IGZsZXg7CiAganVzdGlmeS1jb250ZW50OiBjZW50ZXI7CiAgYWxpZ24taXRlbXM6IGNlbnRlcjsKfQoKLnByb2Nlc3NpbmcgewogIGN1cnNvcjogcHJvZ3Jlc3M7Cn0KCi5pbWFnZSB7CiAgd2lkdGg6IDE2cHg7CiAgaGVpZ2h0OiAxNnB4Owp9CgouY29udGFpbmVyIHsKICBkaXNwbGF5OiBmbGV4OwogIGFsaWduLWl0ZW1zOmZsZXgtc3RhcnQ7CiAgZ2FwOiA1cHg7Cn0KCi5kaWFsb2dDb250YWluZXIgewogIHBvc2l0aW9uOiBmaXhlZDsKICB0b3A6IDA7CiAgcmlnaHQ6IDA7CiAgYm90dG9tOiAwOwogIGxlZnQ6IDA7CiAgZGlzcGxheTogZmxleDsKICBqdXN0aWZ5LWNvbnRlbnQ6IGNlbnRlcjsKICBhbGlnbi1pdGVtczogY2VudGVyOwogIGJhY2tncm91bmQtY29sb3I6IHJnYmEoMCwgMCwgMCwgMC41KTsgLyogT3B0aW9uYWw6IGZvciBkaW1tZWQgYmFja2dyb3VuZCAqLwp9CgouYnV0dG9uIHsKICBib3JkZXI6IDFweCBzb2xpZCAjY2NjOwp9Cg=="
|
|
369
|
-
}], ["src/CreateTaskDialog.tsx", {
|
|
370
|
-
type: "raw",
|
|
371
|
-
body: `import aipLogo from "/aip-icon.svg";
|
|
372
|
-
import type { ChangeEvent } from "react";
|
|
373
|
-
import { useCallback, useEffect, useRef, useState } from "react";
|
|
374
|
-
import css from "./CreateTaskDialog.module.css";
|
|
375
|
-
import Dialog from "./Dialog";
|
|
376
|
-
import type { MockProject } from "./mocks";
|
|
377
|
-
import { useProjectTasks } from "./useProjectTasks";
|
|
378
|
-
|
|
379
|
-
interface CreateTaskDialogProps {
|
|
380
|
-
project: MockProject;
|
|
381
|
-
isOpen: boolean;
|
|
382
|
-
onClose: () => void;
|
|
383
|
-
onTaskCreated: (taskId: string) => void;
|
|
384
|
-
}
|
|
385
|
-
|
|
386
|
-
function CreateTaskDialog(
|
|
387
|
-
{ project, isOpen, onClose, onTaskCreated }: CreateTaskDialogProps,
|
|
388
|
-
) {
|
|
389
|
-
const { createTask, getRecommendedTaskDescription } = useProjectTasks(
|
|
390
|
-
project,
|
|
391
|
-
);
|
|
392
|
-
|
|
393
|
-
const [name, setName] = useState<string>("New task");
|
|
394
|
-
const [description, setDescription] = useState<string>("");
|
|
395
|
-
const [isProcessing, setIsProcessing] = useState<boolean>(false);
|
|
396
|
-
const [isCreating, setIsCreating] = useState(false);
|
|
397
|
-
const textAreaRef = useRef<HTMLTextAreaElement>(null);
|
|
398
|
-
|
|
399
|
-
const handleChangeTaskName = useCallback(
|
|
400
|
-
(e: ChangeEvent<HTMLInputElement>) => setName(e.target.value),
|
|
401
|
-
[],
|
|
402
|
-
);
|
|
403
|
-
|
|
404
|
-
const handleChangeTaskDescription = useCallback(
|
|
405
|
-
(e: ChangeEvent<HTMLTextAreaElement>) => setDescription(e.target.value),
|
|
406
|
-
[],
|
|
407
|
-
);
|
|
408
|
-
|
|
409
|
-
const handleTaskDescriptionRecommendation = useCallback(async () => {
|
|
410
|
-
setIsProcessing(true);
|
|
411
|
-
const recommendedDescription = await getRecommendedTaskDescription(name);
|
|
412
|
-
setDescription(recommendedDescription);
|
|
413
|
-
setIsProcessing(false);
|
|
414
|
-
}, [getRecommendedTaskDescription, name]);
|
|
415
|
-
|
|
416
|
-
useEffect(() => {
|
|
417
|
-
setName("New task");
|
|
418
|
-
setDescription("");
|
|
419
|
-
}, [isOpen]);
|
|
420
|
-
useEffect(() => {
|
|
421
|
-
if (textAreaRef.current) {
|
|
422
|
-
const textArea = textAreaRef.current;
|
|
423
|
-
textArea.style.height = "auto";
|
|
424
|
-
textArea.style.height = \`\${textArea.scrollHeight}px\`;
|
|
425
|
-
}
|
|
426
|
-
}, [description]);
|
|
427
|
-
|
|
428
|
-
const handleSubmit = useCallback(async () => {
|
|
429
|
-
setIsCreating(true);
|
|
430
|
-
try {
|
|
431
|
-
const taskId = await createTask(name, description);
|
|
432
|
-
if (taskId != null) {
|
|
433
|
-
onTaskCreated(taskId);
|
|
434
|
-
}
|
|
435
|
-
} finally {
|
|
436
|
-
setIsCreating(false);
|
|
437
|
-
onClose();
|
|
438
|
-
}
|
|
439
|
-
}, [onClose, createTask, onTaskCreated, name, description]);
|
|
440
|
-
|
|
441
|
-
return (
|
|
442
|
-
<>
|
|
443
|
-
{isOpen && (
|
|
444
|
-
<div className={css.dialogContainer}>
|
|
445
|
-
<Dialog
|
|
446
|
-
isOpen={isOpen}
|
|
447
|
-
buttons={[
|
|
448
|
-
<button
|
|
449
|
-
disabled={isCreating}
|
|
450
|
-
onClick={onClose}
|
|
451
|
-
key="cancel"
|
|
452
|
-
className={css.button}
|
|
453
|
-
>
|
|
454
|
-
Cancel
|
|
455
|
-
</button>,
|
|
456
|
-
<button
|
|
457
|
-
disabled={isCreating}
|
|
458
|
-
onClick={handleSubmit}
|
|
459
|
-
key="create"
|
|
460
|
-
className={css.button}
|
|
461
|
-
>
|
|
462
|
-
Create task
|
|
463
|
-
</button>,
|
|
464
|
-
]}
|
|
465
|
-
>
|
|
466
|
-
<div className={css.task}>
|
|
467
|
-
<label className={css.label}>
|
|
468
|
-
Task name:{" "}
|
|
469
|
-
</label>
|
|
470
|
-
<input
|
|
471
|
-
type="text"
|
|
472
|
-
value={name}
|
|
473
|
-
onChange={handleChangeTaskName}
|
|
474
|
-
className={css.input}
|
|
475
|
-
/>
|
|
476
|
-
|
|
477
|
-
<label className={css.label}>
|
|
478
|
-
Task description:{" "}
|
|
479
|
-
</label>
|
|
480
|
-
<div className={css.container}>
|
|
481
|
-
<textarea
|
|
482
|
-
ref={textAreaRef}
|
|
483
|
-
value={description}
|
|
484
|
-
onChange={handleChangeTaskDescription}
|
|
485
|
-
className={css.textArea}
|
|
486
|
-
rows={2}
|
|
487
|
-
/>
|
|
488
|
-
<button
|
|
489
|
-
disabled={isProcessing}
|
|
490
|
-
className={\`\${css.aip} \${isProcessing ? css.processing : ""}\`}
|
|
491
|
-
title="Click here to get AIP task description recommendation"
|
|
492
|
-
type="button"
|
|
493
|
-
onClick={handleTaskDescriptionRecommendation}
|
|
494
|
-
>
|
|
495
|
-
<img
|
|
496
|
-
src={aipLogo}
|
|
497
|
-
alt="AIP"
|
|
498
|
-
className={css.image}
|
|
499
|
-
/>
|
|
500
|
-
</button>
|
|
501
|
-
</div>
|
|
502
|
-
</div>
|
|
503
|
-
</Dialog>
|
|
504
|
-
</div>
|
|
505
|
-
)}
|
|
506
|
-
</>
|
|
507
|
-
);
|
|
508
|
-
}
|
|
509
|
-
|
|
510
|
-
export default CreateTaskDialog;
|
|
511
|
-
`
|
|
512
|
-
}], ["src/DeleteProjectButton.module.css", {
|
|
513
|
-
"type": "base64",
|
|
514
|
-
"body": "LmJ1dHRvbiB7CiAgYm9yZGVyOiAxcHggc29saWQgI2NjYzsKfQo="
|
|
515
|
-
}], ["src/DeleteProjectButton.tsx", {
|
|
516
|
-
type: "raw",
|
|
517
|
-
body: `import { useCallback, useState } from "react";
|
|
518
|
-
import css from "./DeleteProjectButton.module.css";
|
|
519
|
-
import DeleteProjectDialog from "./DeleteProjectDialog";
|
|
520
|
-
import type { MockProject } from "./mocks";
|
|
521
|
-
import useProjects from "./useProjects";
|
|
522
|
-
|
|
523
|
-
interface DeleteProjectButtonProps {
|
|
524
|
-
project: MockProject;
|
|
525
|
-
}
|
|
526
|
-
|
|
527
|
-
function DeleteProjectButton({ project }: DeleteProjectButtonProps) {
|
|
528
|
-
const { isLoading: isLoadingProjects, isError: isErrorProjects } =
|
|
529
|
-
useProjects();
|
|
530
|
-
|
|
531
|
-
const [isOpen, setIsOpen] = useState(false);
|
|
532
|
-
const handleOpen = useCallback(() => setIsOpen(true), []);
|
|
533
|
-
const handleClose = useCallback(() => setIsOpen(false), []);
|
|
534
|
-
|
|
535
|
-
if (isLoadingProjects || isErrorProjects) {
|
|
536
|
-
return null;
|
|
537
|
-
}
|
|
538
|
-
|
|
539
|
-
return (
|
|
540
|
-
<>
|
|
541
|
-
<button onClick={handleOpen} className={css.button}>
|
|
542
|
-
Delete Project
|
|
543
|
-
</button>
|
|
544
|
-
<DeleteProjectDialog
|
|
545
|
-
project={project}
|
|
546
|
-
isOpen={isOpen}
|
|
547
|
-
onClose={handleClose}
|
|
548
|
-
/>
|
|
549
|
-
</>
|
|
550
|
-
);
|
|
551
|
-
}
|
|
552
|
-
|
|
553
|
-
export default DeleteProjectButton;
|
|
554
|
-
`
|
|
555
|
-
}], ["src/DeleteProjectDialog.module.css", {
|
|
556
|
-
"type": "base64",
|
|
557
|
-
"body": "LmJ1dHRvbiB7CiAgYm9yZGVyOiAxcHggc29saWQgI2NjYzsKfQo="
|
|
558
|
-
}], ["src/DeleteProjectDialog.tsx", {
|
|
559
|
-
type: "raw",
|
|
560
|
-
body: `import { useCallback, useState } from "react";
|
|
561
|
-
import css from "./DeleteProjectDialog.module.css";
|
|
562
|
-
import Dialog from "./Dialog";
|
|
563
|
-
import type { MockProject } from "./mocks";
|
|
564
|
-
import useProjects from "./useProjects";
|
|
565
|
-
|
|
566
|
-
interface DeleteProjectDialogProps {
|
|
567
|
-
project: MockProject;
|
|
568
|
-
isOpen: boolean;
|
|
569
|
-
onClose: () => void;
|
|
570
|
-
}
|
|
571
|
-
|
|
572
|
-
function DeleteProjectDialog({
|
|
573
|
-
project,
|
|
574
|
-
isOpen,
|
|
575
|
-
onClose,
|
|
576
|
-
}: DeleteProjectDialogProps) {
|
|
577
|
-
const { deleteProject } = useProjects();
|
|
578
|
-
|
|
579
|
-
const [isDeleting, setIsDeleting] = useState(false);
|
|
580
|
-
const handleSubmit = useCallback(async () => {
|
|
581
|
-
setIsDeleting(true);
|
|
582
|
-
try {
|
|
583
|
-
await deleteProject(project);
|
|
584
|
-
} finally {
|
|
585
|
-
setIsDeleting(false);
|
|
586
|
-
onClose();
|
|
587
|
-
}
|
|
588
|
-
}, [deleteProject, onClose, project]);
|
|
589
|
-
|
|
590
|
-
return (
|
|
591
|
-
<Dialog
|
|
592
|
-
isOpen={isOpen}
|
|
593
|
-
buttons={[
|
|
594
|
-
<button
|
|
595
|
-
disabled={isDeleting}
|
|
596
|
-
onClick={onClose}
|
|
597
|
-
key="cancel"
|
|
598
|
-
className={css.button}
|
|
599
|
-
>
|
|
600
|
-
Cancel
|
|
601
|
-
</button>,
|
|
602
|
-
<button
|
|
603
|
-
disabled={isDeleting}
|
|
604
|
-
onClick={handleSubmit}
|
|
605
|
-
key="delete"
|
|
606
|
-
className={css.button}
|
|
607
|
-
>
|
|
608
|
-
Delete
|
|
609
|
-
</button>,
|
|
610
|
-
]}
|
|
611
|
-
>
|
|
612
|
-
Are you sure you want to delete this project?
|
|
613
|
-
</Dialog>
|
|
614
|
-
);
|
|
615
|
-
}
|
|
616
|
-
export default DeleteProjectDialog;
|
|
617
|
-
`
|
|
618
|
-
}], ["src/Dialog.module.css", {
|
|
619
|
-
"type": "base64",
|
|
620
|
-
"body": "LmJ1dHRvbnMgewogIGRpc3BsYXk6IGZsZXg7CiAgZ2FwOiAxZW07CiAgbWFyZ2luLXRvcDogMWVtOwogIGp1c3RpZnktY29udGVudDogZmxleC1lbmQ7Cn0KCi5kaWFsb2cgewogIGJvcmRlcjogMXB4IHNvbGlkIGJsYWNrOwogIGJvcmRlci1yYWRpdXM6IDEwcHg7Cn0K"
|
|
621
|
-
}], ["src/Dialog.tsx", {
|
|
622
|
-
type: "raw",
|
|
623
|
-
body: `import { PropsWithChildren } from "react";
|
|
624
|
-
import css from "./Dialog.module.css";
|
|
625
|
-
|
|
626
|
-
interface DialogProps {
|
|
627
|
-
isOpen: boolean;
|
|
628
|
-
buttons?: React.ReactElement[];
|
|
629
|
-
}
|
|
630
|
-
|
|
631
|
-
function Dialog({ children, isOpen, buttons }: PropsWithChildren<DialogProps>) {
|
|
632
|
-
return (
|
|
633
|
-
<dialog open={isOpen} className={css.dialog}>
|
|
634
|
-
{children}
|
|
635
|
-
{buttons != null && buttons.length > 0 && (
|
|
636
|
-
<div className={css.buttons}>{buttons}</div>
|
|
637
|
-
)}
|
|
638
|
-
</dialog>
|
|
639
|
-
);
|
|
640
|
-
}
|
|
641
|
-
export default Dialog;
|
|
642
|
-
`
|
|
643
|
-
}], ["src/Home.module.css", {
|
|
644
|
-
"type": "base64",
|
|
645
|
-
"body": "LnR1dG9yaWFsQmFubmVyV3JhcHBlciB7CiAgZGlzcGxheTogZmxleDsKICBtYXJnaW46IDJlbTsKfQoKLnR1dG9yaWFsQmFubmVyIHsKICBmbGV4OiAxOwogIHdpZHRoOiAwOwogIGJhY2tncm91bmQ6IHJnYmEoMTIxLCA5NywgMjE5LCAwLjcpOwogIGNvbG9yOiAjZmZmZmZmOwogIGJvcmRlci1yYWRpdXM6IDFlbTsKICBwYWRkaW5nOiAxZW07CiAgYm94LXNoYWRvdzogMCAxMHB4IDE1cHggLTNweCByZ2IoMCAwIDAgLyAwLjEpLCAwIDRweCA2cHggLTRweCByZ2IoMCAwIDAgLyAwLjEpOwp9CgoudHV0b3JpYWxCYW5uZXJUaXRsZSB7CiAgbWFyZ2luLXRvcDogMDsKICBmb250LXdlaWdodDogNjAwOwp9CgoucHJvamVjdFNlbGVjdCB7CiAgZGlzcGxheTogZmxleDsKICBhbGlnbi1pdGVtczogY2VudGVyOwogIGdhcDogMWVtOwogIG1hcmdpbjogMmVtOwogIGZvbnQtd2VpZ2h0OiA2MDA7Cn0KCg=="
|
|
646
|
-
}], ["src/Home.tsx", {
|
|
647
|
-
type: "raw",
|
|
648
|
-
body: `import { useCallback, useEffect, useState } from "react";
|
|
649
|
-
import CreateProjectButton from "./CreateProjectButton";
|
|
650
|
-
import DeleteProjectButton from "./DeleteProjectButton";
|
|
651
|
-
import css from "./Home.module.css";
|
|
652
|
-
import Layout from "./Layout";
|
|
653
|
-
import type { MockProject } from "./mocks";
|
|
654
|
-
import { ProjectDetails } from "./ProjectDetails";
|
|
655
|
-
import ProjectSelect from "./ProjectSelect";
|
|
656
|
-
import useProjects from "./useProjects";
|
|
657
|
-
|
|
658
|
-
function Home() {
|
|
659
|
-
const [projectId, setProjectId] = useState<string | undefined>(undefined);
|
|
660
|
-
const { projects } = useProjects();
|
|
661
|
-
|
|
662
|
-
const project = projects?.find((p) => p.id === projectId);
|
|
663
|
-
|
|
664
|
-
const handleSelectProject = useCallback(
|
|
665
|
-
(p: MockProject) => setProjectId(p.id),
|
|
666
|
-
[],
|
|
667
|
-
);
|
|
668
|
-
|
|
669
|
-
useEffect(() => {
|
|
670
|
-
if (project == null && projects != null && projects.length > 0) {
|
|
671
|
-
setProjectId(projects[0].id);
|
|
672
|
-
}
|
|
673
|
-
}, [project, projects]);
|
|
674
|
-
|
|
675
|
-
const handleOnProjectCreated = useCallback(
|
|
676
|
-
(projectId: string | undefined) => {
|
|
677
|
-
setProjectId(projectId);
|
|
678
|
-
},
|
|
679
|
-
[],
|
|
680
|
-
);
|
|
681
|
-
|
|
682
|
-
return (
|
|
683
|
-
<Layout>
|
|
684
|
-
<div className={css.tutorialBannerWrapper}>
|
|
685
|
-
<div className={css.tutorialBanner}>
|
|
686
|
-
<p className={css.tutorialBannerTitle}>
|
|
687
|
-
\u{1F4A1} Welcome to the To Do AIP App tutorial!
|
|
688
|
-
</p>
|
|
689
|
-
<p>
|
|
690
|
-
The application is implemented with mock in memory data.
|
|
691
|
-
<br />Can you solve how to change it to use the Ontology SDK
|
|
692
|
-
instead?
|
|
693
|
-
</p>
|
|
694
|
-
</div>
|
|
695
|
-
</div>
|
|
696
|
-
<div className={css.projectSelect}>
|
|
697
|
-
<span>Project:</span>
|
|
698
|
-
<ProjectSelect
|
|
699
|
-
project={project}
|
|
700
|
-
projects={projects ?? []}
|
|
701
|
-
onSelectProject={handleSelectProject}
|
|
702
|
-
/>
|
|
703
|
-
<CreateProjectButton onProjectCreated={handleOnProjectCreated} />
|
|
704
|
-
{project != null && <DeleteProjectButton project={project} />}
|
|
705
|
-
</div>
|
|
706
|
-
{project != null && <ProjectDetails project={project} />}
|
|
707
|
-
</Layout>
|
|
708
|
-
);
|
|
709
|
-
}
|
|
710
|
-
|
|
711
|
-
export default Home;
|
|
712
|
-
`
|
|
713
|
-
}], ["src/Layout.module.css", {
|
|
714
|
-
"type": "base64",
|
|
715
|
-
"body": "LmhlYWRlciB7CiAgZGlzcGxheTogZmxleDsKICBhbGlnbi1pdGVtczogY2VudGVyOwogIG1hcmdpbjogMmVtOwp9CgoubG9nbyB7CiAgaGVpZ2h0OiA0ZW07CiAgYWxpZ24taXRlbXM6IGNlbnRlcjsKICBtYXJnaW4tcmlnaHQ6IDFlbTsKfQoKLnRpdGxlIHsKICBmb250LXdlaWdodDogNjAwOwogIGZvbnQtc2l6ZTogMS41ZW07Cn0K"
|
|
716
|
-
}], ["src/Layout.tsx", {
|
|
717
|
-
type: "raw",
|
|
718
|
-
body: `import todoAppLogo from "/todo-aip-app.svg";
|
|
719
|
-
import React from "react";
|
|
720
|
-
import css from "./Layout.module.css";
|
|
721
|
-
|
|
722
|
-
interface LayoutProps {
|
|
723
|
-
children?: React.ReactNode;
|
|
724
|
-
}
|
|
725
|
-
|
|
726
|
-
function Layout({ children }: LayoutProps) {
|
|
727
|
-
return (
|
|
728
|
-
<>
|
|
729
|
-
<div className={css.header}>
|
|
730
|
-
<img src={todoAppLogo} className={css.logo} alt="Todo App logo" />
|
|
731
|
-
<div className={css.title}>
|
|
732
|
-
Ontology SDK Tutorial - To Do App Powered by AIP
|
|
733
|
-
</div>
|
|
734
|
-
</div>
|
|
735
|
-
{children}
|
|
736
|
-
</>
|
|
737
|
-
);
|
|
738
|
-
}
|
|
739
|
-
|
|
740
|
-
export default Layout;
|
|
741
|
-
`
|
|
742
|
-
}], ["src/Login.module.css", {
|
|
743
|
-
"type": "base64",
|
|
744
|
-
"body": "LmxvZ2luQnV0dG9uIHsKICBkaXNwbGF5OiBmbGV4OwogIGp1c3RpZnktY29udGVudDogY2VudGVyOwogIG1hcmdpbjogMmVtOwp9Cg=="
|
|
745
|
-
}], ["src/Login.tsx", {
|
|
746
|
-
type: "raw",
|
|
747
|
-
body: `import { useCallback, useState } from "react";
|
|
748
|
-
import { Navigate } from "react-router-dom";
|
|
749
|
-
import { auth } from "./client";
|
|
750
|
-
import Layout from "./Layout";
|
|
751
|
-
import css from "./Login.module.css";
|
|
752
|
-
|
|
753
|
-
function Login() {
|
|
754
|
-
const [isLoggingIn, setIsLoggingIn] = useState(false);
|
|
755
|
-
const [error, setError] = useState<string | undefined>(undefined);
|
|
756
|
-
const token = auth.getTokenOrUndefined();
|
|
757
|
-
|
|
758
|
-
const handleLogin = useCallback(async () => {
|
|
759
|
-
setIsLoggingIn(true);
|
|
760
|
-
try {
|
|
761
|
-
// Initiate the OAuth flow, which will redirect the user to log into Foundry
|
|
762
|
-
// Once the login has completed, the user will be redirected back to the route defined via the
|
|
763
|
-
// FOUNDRY_REDIRECT_URL variable in .env.development
|
|
764
|
-
await auth.signIn();
|
|
765
|
-
} catch (e: unknown) {
|
|
766
|
-
console.error(e);
|
|
767
|
-
setError((e as Error).message ?? e);
|
|
768
|
-
} finally {
|
|
769
|
-
setIsLoggingIn(false);
|
|
770
|
-
}
|
|
771
|
-
}, []);
|
|
772
|
-
|
|
773
|
-
// If the token exists but a user tries to load /login, redirect to the home page instead
|
|
774
|
-
if (token != null) {
|
|
775
|
-
return <Navigate to="/" replace={true} />;
|
|
776
|
-
}
|
|
777
|
-
|
|
778
|
-
return (
|
|
779
|
-
<Layout>
|
|
780
|
-
<div className={css.loginButton}>
|
|
781
|
-
<button onClick={handleLogin}>
|
|
782
|
-
{isLoggingIn ? "Logging in\u2026" : "Log in "}
|
|
783
|
-
</button>
|
|
784
|
-
</div>
|
|
785
|
-
{error && <div>Unable to log in: {error}</div>}
|
|
786
|
-
</Layout>
|
|
787
|
-
);
|
|
788
|
-
}
|
|
789
|
-
|
|
790
|
-
export default Login;
|
|
791
|
-
`
|
|
792
|
-
}], ["src/ProjectDetails.module.css", {
|
|
793
|
-
"type": "base64",
|
|
794
|
-
"body": "LnByb2plY3RDYXJkIHsKICBtYXJnaW46IDJlbTsKICBwYWRkaW5nOiAwLjVlbTsKICBib3JkZXI6IDFweCBzb2xpZCAjY2NjOwogIC8qIG1hcmdpbjogMC41ZW07ICovCiAgZ2FwOiAwLjVlbTsKICBib3JkZXItcmFkaXVzOiA1cHg7Cgp9CgoucHJvamVjdFRpdGxlIHsKICBmb250LXNpemU6IDEuNWVtOwp9CgouZGVzY3JpcHRpb24gewogIGRpc3BsYXk6IGZsZXg7CiAgZmxleC1kaXJlY3Rpb246IGNvbHVtbjsKICBnYXA6IDVweDsKfQoKLmltYWdlIHsKICBoZWlnaHQ6IDE2cHg7CiAgd2lkdGg6IDE2cHg7Cn0KCi5haXAgewogIGJhY2tncm91bmQtY29sb3I6ICM3OTYxREI7CiAgY29sb3I6ICNmZmZmZmY7CiAgYm9yZGVyOiAxcHggc29saWQgI2NjYzsKICBwYWRkaW5nOiAycHg7CiAgZ2FwOiAxMHB4OwogIGhlaWdodDogMzBweDsKfQoKLnByb2Nlc3NpbmcgewogIGN1cnNvcjogcHJvZ3Jlc3M7Cn0KCi5haXBUZXh0IHsKICBkaXNwbGF5OiBmbGV4OwogIGp1c3RpZnktY29udGVudDogY2VudGVyOwogIGdhcDogMTBweDsKICBhbGlnbi1pdGVtczogY2VudGVyOwogIHBhZGRpbmc6IDAgMTBweDsKfQoKLnRleHRBcmVhIHsKICBib3JkZXI6IG5vbmU7CiAgY29sb3I6IGdyYXk7CiAgcmVzaXplOiBub25lOwogIG92ZXJmbG93OiBoaWRkZW47CiAgcG9pbnRlci1ldmVudHM6IG5vbmU7Cn0K"
|
|
795
|
-
}], ["src/ProjectDetails.tsx", {
|
|
796
|
-
type: "raw",
|
|
797
|
-
body: `import aipLogo from "/aip-icon.svg";
|
|
798
|
-
import { useCallback, useEffect, useRef, useState } from "react";
|
|
799
|
-
import CreateTaskButton from "./CreateTaskButton";
|
|
800
|
-
import type { MockProject } from "./mocks";
|
|
801
|
-
import css from "./ProjectDetails.module.css";
|
|
802
|
-
import TaskList from "./TaskList";
|
|
803
|
-
import useProjects from "./useProjects";
|
|
804
|
-
import { useProjectTasks } from "./useProjectTasks";
|
|
805
|
-
|
|
806
|
-
interface ProjectDetailsProps {
|
|
807
|
-
project: MockProject;
|
|
808
|
-
}
|
|
809
|
-
|
|
810
|
-
export function ProjectDetails({ project }: ProjectDetailsProps) {
|
|
811
|
-
const [projectHasTasks, setProjectHasTasks] = useState<boolean>(false);
|
|
812
|
-
const [isProcessing, setIsProcessing] = useState<boolean>(false);
|
|
813
|
-
const { updateProjectDescription } = useProjects();
|
|
814
|
-
const tasks = useProjectTasks(project).tasks;
|
|
815
|
-
const textAreaRef = useRef<HTMLTextAreaElement>(null);
|
|
816
|
-
|
|
817
|
-
useEffect(() => {
|
|
818
|
-
setProjectHasTasks(tasks == null ? false : tasks.length > 0);
|
|
819
|
-
}, [project, tasks]);
|
|
820
|
-
|
|
821
|
-
const handleProjectDescriptionRecommendation = useCallback(async () => {
|
|
822
|
-
if (project == null) {
|
|
823
|
-
return;
|
|
824
|
-
}
|
|
825
|
-
setIsProcessing(true);
|
|
826
|
-
await updateProjectDescription(project);
|
|
827
|
-
setIsProcessing(false);
|
|
828
|
-
}, [project, updateProjectDescription]);
|
|
829
|
-
|
|
830
|
-
useEffect(() => {
|
|
831
|
-
if (textAreaRef.current) {
|
|
832
|
-
const textArea = textAreaRef.current;
|
|
833
|
-
textArea.style.height = "auto";
|
|
834
|
-
textArea.style.height = \`\${textArea.scrollHeight}px\`;
|
|
835
|
-
}
|
|
836
|
-
}, [project.description]);
|
|
837
|
-
|
|
838
|
-
const handleOnTaskCreated = useCallback(() => {
|
|
839
|
-
setProjectHasTasks(true);
|
|
840
|
-
}, []);
|
|
841
|
-
|
|
842
|
-
const handleOnTaskDeleted = useCallback(() => {
|
|
843
|
-
if (tasks?.length === 0) {
|
|
844
|
-
setProjectHasTasks(false);
|
|
845
|
-
}
|
|
846
|
-
}, [tasks]);
|
|
847
|
-
|
|
848
|
-
return (
|
|
849
|
-
<div className={css.projectCard} key={project.id}>
|
|
850
|
-
<h1 className={css.projectTitle}>{project.name}</h1>
|
|
851
|
-
{projectHasTasks && (
|
|
852
|
-
<div className={css.description}>
|
|
853
|
-
<textarea
|
|
854
|
-
ref={textAreaRef}
|
|
855
|
-
readOnly
|
|
856
|
-
value={project.description}
|
|
857
|
-
className={css.textArea}
|
|
858
|
-
/>
|
|
859
|
-
<button
|
|
860
|
-
disabled={isProcessing}
|
|
861
|
-
className={\`\${css.aip} \${isProcessing ? css.processing : ""}\`}
|
|
862
|
-
title="Click here to update project description based on AIP Logic"
|
|
863
|
-
type="button"
|
|
864
|
-
onClick={handleProjectDescriptionRecommendation}
|
|
865
|
-
>
|
|
866
|
-
<div className={css.aipText}>
|
|
867
|
-
<img
|
|
868
|
-
src={aipLogo}
|
|
869
|
-
alt="AIP"
|
|
870
|
-
className={css.image}
|
|
871
|
-
/>
|
|
872
|
-
Get description recommendation
|
|
873
|
-
</div>
|
|
874
|
-
</button>
|
|
875
|
-
</div>
|
|
876
|
-
)}
|
|
877
|
-
<TaskList project={project} onTaskDeleted={handleOnTaskDeleted} />
|
|
878
|
-
<CreateTaskButton
|
|
879
|
-
project={project}
|
|
880
|
-
onTaskCreated={handleOnTaskCreated}
|
|
881
|
-
/>
|
|
882
|
-
</div>
|
|
883
|
-
);
|
|
884
|
-
}
|
|
885
|
-
`
|
|
886
|
-
}], ["src/ProjectSelect.tsx", {
|
|
887
|
-
type: "raw",
|
|
888
|
-
body: `import { ChangeEvent, useCallback } from "react";
|
|
889
|
-
import { MockProject } from "./mocks";
|
|
890
|
-
|
|
891
|
-
interface ProjectSelectProps {
|
|
892
|
-
project: MockProject | undefined;
|
|
893
|
-
projects: MockProject[];
|
|
894
|
-
onSelectProject: (project: MockProject) => void;
|
|
895
|
-
}
|
|
896
|
-
|
|
897
|
-
function ProjectSelect({
|
|
898
|
-
project,
|
|
899
|
-
projects,
|
|
900
|
-
onSelectProject,
|
|
901
|
-
}: ProjectSelectProps) {
|
|
902
|
-
const handleSelect = useCallback(
|
|
903
|
-
(e: ChangeEvent<HTMLSelectElement>) => {
|
|
904
|
-
const nextProject = projects.find((p) => \`\${p.id}\` === e.target.value);
|
|
905
|
-
if (nextProject != null) {
|
|
906
|
-
onSelectProject(nextProject);
|
|
907
|
-
}
|
|
908
|
-
},
|
|
909
|
-
[projects, onSelectProject],
|
|
910
|
-
);
|
|
911
|
-
|
|
912
|
-
return (
|
|
913
|
-
<select value={project?.id} onChange={handleSelect}>
|
|
914
|
-
<option hidden disabled value="">
|
|
915
|
-
-- select a project --
|
|
916
|
-
</option>
|
|
917
|
-
|
|
918
|
-
{projects.map((p) => (
|
|
919
|
-
<option key={p.id} value={p.id}>
|
|
920
|
-
{p.name}
|
|
921
|
-
</option>
|
|
922
|
-
))}
|
|
923
|
-
</select>
|
|
924
|
-
);
|
|
925
|
-
}
|
|
926
|
-
|
|
927
|
-
export default ProjectSelect;
|
|
928
|
-
`
|
|
929
|
-
}], ["src/TaskList.module.css", {
|
|
930
|
-
"type": "base64",
|
|
931
|
-
"body": "LnRhc2tMaXN0IHsKICBsaXN0LXN0eWxlOiBub25lOwogIHBhZGRpbmc6IDA7CiAgbWFyZ2luLXRvcDogMWVtOwogIG1hcmdpbi1ib3R0b206IDFlbTsKICB3aWR0aDogMTAwJTsKfQo="
|
|
932
|
-
}], ["src/TaskList.tsx", {
|
|
933
|
-
type: "raw",
|
|
934
|
-
body: `import type { MockProject } from "./mocks";
|
|
935
|
-
import css from "./TaskList.module.css";
|
|
936
|
-
import TaskListItem from "./TaskListItem";
|
|
937
|
-
import { useProjectTasks } from "./useProjectTasks";
|
|
938
|
-
|
|
939
|
-
interface TaskListProps {
|
|
940
|
-
project: MockProject;
|
|
941
|
-
onTaskDeleted: (taskId: string | undefined) => void;
|
|
942
|
-
}
|
|
943
|
-
|
|
944
|
-
function TaskList({ project, onTaskDeleted }: TaskListProps) {
|
|
945
|
-
const {
|
|
946
|
-
tasks,
|
|
947
|
-
isLoading: isLoadingTasks,
|
|
948
|
-
isError: isErrorTasks,
|
|
949
|
-
deleteTask,
|
|
950
|
-
} = useProjectTasks(project);
|
|
951
|
-
|
|
952
|
-
if (isErrorTasks) {
|
|
953
|
-
return <div className={css.taskList}>Error loading tasks!</div>;
|
|
954
|
-
} else if (isLoadingTasks) {
|
|
955
|
-
return null;
|
|
956
|
-
}
|
|
957
|
-
|
|
958
|
-
const data = tasks ?? [];
|
|
959
|
-
if (data.length === 0) {
|
|
960
|
-
return <div className={css.taskList}>No tasks found</div>;
|
|
961
|
-
}
|
|
962
|
-
|
|
963
|
-
return (
|
|
964
|
-
<ul className={css.taskList}>
|
|
965
|
-
{data.map((task) => (
|
|
966
|
-
<TaskListItem
|
|
967
|
-
key={task.id}
|
|
968
|
-
task={task}
|
|
969
|
-
deleteTask={deleteTask}
|
|
970
|
-
onTaskDeleted={onTaskDeleted}
|
|
971
|
-
/>
|
|
972
|
-
))}
|
|
973
|
-
</ul>
|
|
974
|
-
);
|
|
975
|
-
}
|
|
976
|
-
|
|
977
|
-
export default TaskList;
|
|
978
|
-
`
|
|
979
|
-
}], ["src/TaskListItem.module.css", {
|
|
980
|
-
"type": "base64",
|
|
981
|
-
"body": "LmxpIHsKICBkaXNwbGF5OiBmbGV4OwogIGZsZXgtZGlyZWN0aW9uOiByb3c7CiAgYWxpZ24taXRlbXM6IGZsZXgtc3RhcnQ7CiAgcGFkZGluZzogNXB4OwogIGJvcmRlcjogMXB4IHNvbGlkICNjY2M7CiAgZ2FwOiA1cHg7CiAgYm9yZGVyLXJhZGl1czogNXB4OwogIGJhY2tncm91bmQtY29sb3I6ICNmOWY5Zjk7CiAgbWFyZ2luOiAxMHB4IDA7Cn0KCi5jaGVja2VkIHsKICB0ZXh0LWRlY29yYXRpb246IGxpbmUtdGhyb3VnaDsKfQoKLmRlbGV0ZSB7CiAgYm9yZGVyOiAxcHggc29saWQgI2NjYzsKICBwYWRkaW5nOiAycHg7Cn0KCi50YXNrIHsKICBkaXNwbGF5OiBmbGV4OwogIGZsZXgtZGlyZWN0aW9uOiBjb2x1bW47CiAgd2lkdGg6IDEwMCU7Cn0KCi50ZXh0QXJlYSB7CiAgYm9yZGVyOiBub25lOwogIGJhY2tncm91bmQtY29sb3I6ICNmOWY5Zjk7CiAgY29sb3I6IGdyYXk7CiAgcmVzaXplOiBub25lOwogIG92ZXJmbG93OiBoaWRkZW47CiAgcG9pbnRlci1ldmVudHM6IG5vbmU7Cn0K"
|
|
982
|
-
}], ["src/TaskListItem.tsx", {
|
|
983
|
-
type: "raw",
|
|
984
|
-
body: `import { useCallback, useEffect, useRef, useState } from "react";
|
|
985
|
-
import type { MockTask } from "./mocks";
|
|
986
|
-
import css from "./TaskListItem.module.css";
|
|
987
|
-
|
|
988
|
-
interface TaskListItemProps {
|
|
989
|
-
task: MockTask;
|
|
990
|
-
deleteTask: (task: MockTask) => Promise<void>;
|
|
991
|
-
onTaskDeleted: (taskId: string | undefined) => void;
|
|
992
|
-
}
|
|
993
|
-
|
|
994
|
-
function TaskListItem({ task, deleteTask, onTaskDeleted }: TaskListItemProps) {
|
|
995
|
-
const [isDeleting, setIsDeleting] = useState(false);
|
|
996
|
-
const textAreaRef = useRef<HTMLTextAreaElement>(null);
|
|
997
|
-
|
|
998
|
-
const handleClick = useCallback(async () => {
|
|
999
|
-
setIsDeleting(true);
|
|
1000
|
-
try {
|
|
1001
|
-
await deleteTask(task);
|
|
1002
|
-
} finally {
|
|
1003
|
-
onTaskDeleted(task.id);
|
|
1004
|
-
setIsDeleting(false);
|
|
1005
|
-
}
|
|
1006
|
-
}, [deleteTask, task, onTaskDeleted]);
|
|
1007
|
-
|
|
1008
|
-
useEffect(() => {
|
|
1009
|
-
if (textAreaRef.current) {
|
|
1010
|
-
const textArea = textAreaRef.current;
|
|
1011
|
-
textArea.style.height = "auto";
|
|
1012
|
-
textArea.style.height = \`\${textArea.scrollHeight}px\`;
|
|
1013
|
-
}
|
|
1014
|
-
}, [task.description]);
|
|
1015
|
-
const cleanDescription = task.description?.trim();
|
|
1016
|
-
return (
|
|
1017
|
-
<li className={css.li}>
|
|
1018
|
-
<input
|
|
1019
|
-
type="checkbox"
|
|
1020
|
-
onChange={handleClick}
|
|
1021
|
-
checked={isDeleting}
|
|
1022
|
-
className={css.delete}
|
|
1023
|
-
title="Delete task"
|
|
1024
|
-
/>
|
|
1025
|
-
<div className={\`\${css.task} \${isDeleting ? css.checked : ""}\`}>
|
|
1026
|
-
<span>{task.title}</span>
|
|
1027
|
-
{cleanDescription != null && (
|
|
1028
|
-
<textarea
|
|
1029
|
-
ref={textAreaRef}
|
|
1030
|
-
readOnly
|
|
1031
|
-
value={task.description}
|
|
1032
|
-
className={css.textArea}
|
|
1033
|
-
rows={1}
|
|
1034
|
-
/>
|
|
1035
|
-
)}
|
|
1036
|
-
</div>
|
|
1037
|
-
</li>
|
|
1038
|
-
);
|
|
1039
|
-
}
|
|
1040
|
-
|
|
1041
|
-
export default TaskListItem;
|
|
1042
|
-
`
|
|
1043
|
-
}], ["src/client.ts.hbs", {
|
|
1044
|
-
type: "raw",
|
|
1045
|
-
body: `import { createClient } from "@osdk/client";
|
|
1046
|
-
import { createPublicOauthClient } from "@osdk/oauth";
|
|
1047
|
-
import { $ontologyRid } from "{{osdkPackage}}";
|
|
1048
|
-
|
|
1049
|
-
const url = import.meta.env.VITE_FOUNDRY_API_URL;
|
|
1050
|
-
const clientId = import.meta.env.VITE_FOUNDRY_CLIENT_ID;
|
|
1051
|
-
const redirectUrl = import.meta.env.VITE_FOUNDRY_REDIRECT_URL;
|
|
1052
|
-
checkEnv(url, "VITE_FOUNDRY_API_URL");
|
|
1053
|
-
checkEnv(clientId, "VITE_FOUNDRY_CLIENT_ID");
|
|
1054
|
-
checkEnv(redirectUrl, "VITE_FOUNDRY_REDIRECT_URL");
|
|
1055
|
-
{{#if scopes}}
|
|
1056
|
-
const scopes = [
|
|
1057
|
-
{{#each scopes}}
|
|
1058
|
-
"{{this}}",
|
|
1059
|
-
{{/each}}
|
|
1060
|
-
];
|
|
1061
|
-
{{/if}}
|
|
1062
|
-
|
|
1063
|
-
function checkEnv(
|
|
1064
|
-
value: string | undefined,
|
|
1065
|
-
name: string,
|
|
1066
|
-
): asserts value is string {
|
|
1067
|
-
if (value == null) {
|
|
1068
|
-
throw new Error(\`Missing environment variable: \${name}\`);
|
|
1069
|
-
}
|
|
1070
|
-
}
|
|
1071
|
-
|
|
1072
|
-
/**
|
|
1073
|
-
* Initialize the client to interact with the Ontology SDK
|
|
1074
|
-
*/
|
|
1075
|
-
const auth = createPublicOauthClient(
|
|
1076
|
-
clientId,
|
|
1077
|
-
url,
|
|
1078
|
-
redirectUrl,
|
|
1079
|
-
{{#if scopes}}
|
|
1080
|
-
true,
|
|
1081
|
-
undefined,
|
|
1082
|
-
window.location.toString(),
|
|
1083
|
-
scopes,
|
|
1084
|
-
{{/if}}
|
|
1085
|
-
);
|
|
1086
|
-
|
|
1087
|
-
const client = createClient(
|
|
1088
|
-
url,
|
|
1089
|
-
$ontologyRid,
|
|
1090
|
-
auth,
|
|
1091
|
-
);
|
|
1092
|
-
|
|
1093
|
-
export { auth, client };
|
|
1094
|
-
`
|
|
1095
|
-
}], ["src/env.test.ts", {
|
|
1096
|
-
"type": "base64",
|
|
1097
|
-
"body": "aW1wb3J0IHsgbG9hZEVudiB9IGZyb20gInZpdGUiOwppbXBvcnQgeyBleHBlY3QsIHRlc3QgfSBmcm9tICJ2aXRlc3QiOwoKY29uc3QgRU5WX1ZBUlMgPSBbCiAgIlZJVEVfRk9VTkRSWV9BUElfVVJMIiwKICAiVklURV9GT1VORFJZX0NMSUVOVF9JRCIsCiAgIlZJVEVfRk9VTkRSWV9SRURJUkVDVF9VUkwiLApdOwoKZm9yIChjb25zdCBlbnZWYXIgb2YgRU5WX1ZBUlMpIHsKICB0ZXN0LnNraXBJZihwcm9jZXNzLmVudi5WRVJJRllfRU5WX1BST0RVQ1RJT04gIT09ICJ0cnVlIikoCiAgICBgcHJvZHVjdGlvbiBlbnYgc2hvdWxkIGNvbnRhaW4gJHtlbnZWYXJ9YCwKICAgICgpID0+IHsKICAgICAgY29uc3QgZW52ID0gbG9hZEVudigicHJvZHVjdGlvbiIsIHByb2Nlc3MuY3dkKCkpOwogICAgICBleHBlY3QoZW52W2VudlZhcl0sIGAke2VudlZhcn0gc2hvdWxkIGJlIGRlZmluZWRgKS50b0JlRGVmaW5lZCgpOwogICAgICBleHBlY3QoCiAgICAgICAgZW52W2VudlZhcl0sCiAgICAgICAgYCR7ZW52VmFyfSBzaG91bGQgbm90IGNvbnRhaW4gcGxhY2Vob2xkZXIgdmFsdWVgLAogICAgICApLm5vdC50b01hdGNoKC88Lio+Lyk7CiAgICB9LAogICk7Cn0K"
|
|
1098
|
-
}], ["src/index.css", {
|
|
1099
|
-
"type": "base64",
|
|
1100
|
-
"body": "OnJvb3QgewogIGZvbnQtZmFtaWx5OiBJbnRlciwgc3lzdGVtLXVpLCBBdmVuaXIsIEhlbHZldGljYSwgQXJpYWwsIHNhbnMtc2VyaWY7CiAgbGluZS1oZWlnaHQ6IDEuNTsKICBmb250LXdlaWdodDogNDAwOwoKICBmb250LXN5bnRoZXNpczogbm9uZTsKICB0ZXh0LXJlbmRlcmluZzogb3B0aW1pemVMZWdpYmlsaXR5OwogIC13ZWJraXQtZm9udC1zbW9vdGhpbmc6IGFudGlhbGlhc2VkOwogIC1tb3otb3N4LWZvbnQtc21vb3RoaW5nOiBncmF5c2NhbGU7Cn0KCiNyb290LWNvbnRhaW5lciB7CiAgZGlzcGxheTogZmxleDsKICBmbGV4OiAxOwogIGFsaWduLWl0ZW1zOiBjZW50ZXI7Cn0KCiNyb290IHsKICBtYXgtd2lkdGg6IDEyODBweDsKICBtYXJnaW46IDJyZW0gYXV0bzsKICBwYWRkaW5nOiAycmVtOwp9CgphIHsKICBmb250LXdlaWdodDogNTAwOwogIGNvbG9yOiAjNjQ2Y2ZmOwogIHRleHQtZGVjb3JhdGlvbjogaW5oZXJpdDsKfQphOmhvdmVyIHsKICBjb2xvcjogIzUzNWJmMjsKfQoKYm9keSB7CiAgbWFyZ2luOiAwOwogIGRpc3BsYXk6IGZsZXg7CiAgZmxleC1kaXJlY3Rpb246IGNvbHVtbjsKICBtaW4td2lkdGg6IDMyMHB4OwogIG1pbi1oZWlnaHQ6IDEwMHZoOwp9CgpoMSB7CiAgZm9udC1zaXplOiAzLjJlbTsKICBsaW5lLWhlaWdodDogMS4xOwp9CgpidXR0b24gewogIGJvcmRlci1yYWRpdXM6IDhweDsKICBib3JkZXI6IDFweCBzb2xpZCB0cmFuc3BhcmVudDsKICBwYWRkaW5nOiAwLjZlbSAxLjJlbTsKICBmb250LXNpemU6IDFlbTsKICBmb250LXdlaWdodDogNTAwOwogIGZvbnQtZmFtaWx5OiBpbmhlcml0OwogIGN1cnNvcjogcG9pbnRlcjsKICB0cmFuc2l0aW9uOiBib3JkZXItY29sb3IgMC4yNXM7Cn0KYnV0dG9uOmhvdmVyIHsKICBib3JkZXItY29sb3I6ICM2NDZjZmY7Cn0KYnV0dG9uOmZvY3VzLApidXR0b246Zm9jdXMtdmlzaWJsZSB7CiAgb3V0bGluZTogNHB4IGF1dG8gLXdlYmtpdC1mb2N1cy1yaW5nLWNvbG9yOwp9CgpAbWVkaWEgKHByZWZlcnMtY29sb3Itc2NoZW1lOiBsaWdodCkgewogIDpyb290IHsKICAgIGNvbG9yOiAjMjEzNTQ3OwogICAgYmFja2dyb3VuZC1jb2xvcjogI2ZmZmZmZjsKICB9CiAgYTpob3ZlciB7CiAgICBjb2xvcjogIzc0N2JmZjsKICB9CiAgYnV0dG9uIHsKICAgIGJhY2tncm91bmQtY29sb3I6ICNmOWY5Zjk7CiAgfQp9Cg=="
|
|
1101
|
-
}], ["src/main.tsx", {
|
|
1102
|
-
type: "raw",
|
|
1103
|
-
body: `import ReactDOM from "react-dom/client";
|
|
1104
|
-
import { createBrowserRouter, RouterProvider } from "react-router-dom";
|
|
1105
|
-
import AuthCallback from "./AuthCallback";
|
|
1106
|
-
import AuthenticatedRoute from "./AuthenticatedRoute";
|
|
1107
|
-
import Home from "./Home";
|
|
1108
|
-
import Login from "./Login";
|
|
1109
|
-
import "./index.css";
|
|
1110
|
-
|
|
1111
|
-
const router = createBrowserRouter(
|
|
1112
|
-
[
|
|
1113
|
-
{
|
|
1114
|
-
path: "/",
|
|
1115
|
-
element: <AuthenticatedRoute />,
|
|
1116
|
-
children: [
|
|
1117
|
-
{
|
|
1118
|
-
path: "/",
|
|
1119
|
-
element: <Home />,
|
|
1120
|
-
},
|
|
1121
|
-
],
|
|
1122
|
-
},
|
|
1123
|
-
{
|
|
1124
|
-
path: "/login",
|
|
1125
|
-
element: <Login />,
|
|
1126
|
-
},
|
|
1127
|
-
{
|
|
1128
|
-
// This is the route defined in your application's redirect URL
|
|
1129
|
-
path: "/auth/callback",
|
|
1130
|
-
element: <AuthCallback />,
|
|
1131
|
-
},
|
|
1132
|
-
],
|
|
1133
|
-
{ basename: import.meta.env.BASE_URL },
|
|
1134
|
-
);
|
|
1135
|
-
|
|
1136
|
-
ReactDOM.createRoot(document.getElementById("root")!).render(
|
|
1137
|
-
<RouterProvider router={router} />,
|
|
1138
|
-
);
|
|
1139
|
-
`
|
|
1140
|
-
}], ["src/mocks.ts", {
|
|
1141
|
-
"type": "base64",
|
|
1142
|
-
"body": "ZXhwb3J0IGludGVyZmFjZSBNb2NrUHJvamVjdCB7CiAgJGFwaU5hbWU6IHN0cmluZzsKICAkcHJpbWFyeUtleTogc3RyaW5nOwogIGlkOiBzdHJpbmc7CiAgbmFtZTogc3RyaW5nOwogIGRlc2NyaXB0aW9uOiBzdHJpbmc7CiAgdGFza3M6IE1vY2tUYXNrW107Cn0KCmV4cG9ydCBpbnRlcmZhY2UgTW9ja1Rhc2sgewogICRhcGlOYW1lOiBzdHJpbmc7CiAgJHByaW1hcnlLZXk6IHN0cmluZzsKICBpZDogc3RyaW5nOwogIHRpdGxlOiBzdHJpbmc7CiAgZGVzY3JpcHRpb246IHN0cmluZzsKfQoKY29uc3QgcHJvamVjdHM6IE1vY2tQcm9qZWN0W10gPSBbCiAgewogICAgJGFwaU5hbWU6ICJNb2NrUHJvamVjdCIsCiAgICAkcHJpbWFyeUtleTogIjEiLAogICAgaWQ6ICIxIiwKICAgIG5hbWU6ICJNb2NrIHByb2plY3QiLAogICAgZGVzY3JpcHRpb246ICJUaGlzIGlzIGEgbW9jayBkZXNjcmlwdGlvbiIsCiAgICB0YXNrczogWwogICAgICB7CiAgICAgICAgJGFwaU5hbWU6ICJNb2NrVGFzayIsCiAgICAgICAgJHByaW1hcnlLZXk6ICIxIiwKICAgICAgICBpZDogIjEiLAogICAgICAgIHRpdGxlOiAiVHJ5IHRvIiwKICAgICAgICBkZXNjcmlwdGlvbjogInRhc2sgZGVzY3JpcHRpb24gMSIsCiAgICAgIH0sCiAgICAgIHsKICAgICAgICAkYXBpTmFtZTogIk1vY2tUYXNrIiwKICAgICAgICAkcHJpbWFyeUtleTogIjIiLAogICAgICAgIGlkOiAiMiIsCiAgICAgICAgdGl0bGU6ICJJbXBsZW1lbnQgdGhpcyIsCiAgICAgICAgZGVzY3JpcHRpb246ICJ0YXNrIGRlc2NyaXB0aW9uIDIiLAogICAgICB9LAogICAgICB7CiAgICAgICAgJGFwaU5hbWU6ICJNb2NrVGFzayIsCiAgICAgICAgJHByaW1hcnlLZXk6ICIzIiwKICAgICAgICBpZDogIjMiLAogICAgICAgIHRpdGxlOiAiV2l0aCB0aGUgT250b2xvZ3kgU0RLISIsCiAgICAgICAgZGVzY3JpcHRpb246ICJ0YXNrIGRlc2NyaXB0aW9uIDMiLAogICAgICB9LAogICAgXSwKICB9LAogIHsKICAgICRhcGlOYW1lOiAiTW9ja1Byb2plY3QiLAogICAgJHByaW1hcnlLZXk6ICIyIiwKICAgIGlkOiAiMiIsCiAgICBuYW1lOiAiWWV0IGFub3RoZXIgbW9jayBwcm9qZWN0IiwKICAgIGRlc2NyaXB0aW9uOiAiVGhpcyBpcyBhbm90aGVyIG1vY2sgZGVzY3JpcHRpb24iLAogICAgdGFza3M6IFsKICAgICAgewogICAgICAgICRhcGlOYW1lOiAiTW9ja1Rhc2siLAogICAgICAgICRwcmltYXJ5S2V5OiAiNCIsCiAgICAgICAgaWQ6ICI0IiwKICAgICAgICB0aXRsZTogIk1vcmUgdGFza3MgaGVyZSIsCiAgICAgICAgZGVzY3JpcHRpb246ICJNb3JlIHRhc2sgZGVzY3JpcHRpb24iLAogICAgICB9LAogICAgXSwKICB9LApdOwoKYXN5bmMgZnVuY3Rpb24gZGVsYXkoKTogUHJvbWlzZTx2b2lkPiB7CiAgcmV0dXJuIG5ldyBQcm9taXNlKChyZXNvbHZlKSA9PgogICAgc2V0VGltZW91dCgoKSA9PiByZXNvbHZlKCksIDUwMCArIE1hdGgucmFuZG9tKCkgKiAxMDAwKQogICk7Cn0KCi8vIEdvb2QgZW5vdWdoIHJhbmRvbSBpZCBmb3IgbW9ja3MKZnVuY3Rpb24gcmFuZG9tSWQoKTogc3RyaW5nIHsKICByZXR1cm4gYCR7TWF0aC5mbG9vcihNYXRoLnJhbmRvbSgpICogMiAqKiAzMSl9YDsKfQoKYXN5bmMgZnVuY3Rpb24gZ2V0UHJvamVjdHMoKTogUHJvbWlzZTxNb2NrUHJvamVjdFtdPiB7CiAgYXdhaXQgZGVsYXkoKTsKICBjb25zdCByZXN1bHQgPSBbLi4ucHJvamVjdHNdOwogIHJlc3VsdC5zb3J0KChwMSwgcDIpID0+IHAxLm5hbWUubG9jYWxlQ29tcGFyZShwMi5uYW1lKSk7CiAgcmV0dXJuIHJlc3VsdDsKfQoKYXN5bmMgZnVuY3Rpb24gY3JlYXRlUHJvamVjdCh7CiAgbmFtZSwKICBkZXNjcmlwdGlvbiA9ICIiLAp9OiB7CiAgbmFtZTogc3RyaW5nOwogIGRlc2NyaXB0aW9uPzogc3RyaW5nOwp9KTogUHJvbWlzZTxNb2NrUHJvamVjdFsiJHByaW1hcnlLZXkiXT4gewogIGF3YWl0IGRlbGF5KCk7CiAgY29uc3QgaWQgPSByYW5kb21JZCgpOwogIHByb2plY3RzLnB1c2goewogICAgJGFwaU5hbWU6ICJNb2NrUHJvamVjdCIsCiAgICAkcHJpbWFyeUtleTogaWQsCiAgICBpZCwKICAgIG5hbWUsCiAgICBkZXNjcmlwdGlvbiwKICAgIHRhc2tzOiBbXSwKICB9KTsKICByZXR1cm4gaWQ7Cn0KCmFzeW5jIGZ1bmN0aW9uIGdldFJlY29tbWVuZGVkUHJvamVjdERlc2NyaXB0aW9uKAogIHByb2plY3Q6IE1vY2tQcm9qZWN0LAopOiBQcm9taXNlPHN0cmluZz4gewogIGF3YWl0IGRlbGF5KCk7CiAgaWYgKHByb2plY3QudGFza3MgIT0gbnVsbCAmJiBwcm9qZWN0LnRhc2tzLmxlbmd0aCA9PT0gMCkgewogICAgdGhyb3cgbmV3IEVycm9yKCJQcm9qZWN0IGRlc2NyaXB0aW9uIHJlY29tbWVuZGF0aW9uIHJlcXVpcmVzIHRhc2tzIik7CiAgfQogIHJldHVybiBgQUlQIExvZ2ljIG1vY2sgZGVzY3JpcHRpb24gZm9yIHByb2plY3RgOwp9Cgphc3luYyBmdW5jdGlvbiB1cGRhdGVQcm9qZWN0RGVzY3JpcHRpb24oCiAgcHJvamVjdDogTW9ja1Byb2plY3QsCik6IFByb21pc2U8dm9pZD4gewogIGF3YWl0IGRlbGF5KCk7CiAgcHJvamVjdC5kZXNjcmlwdGlvbiA9IGF3YWl0IGdldFJlY29tbWVuZGVkUHJvamVjdERlc2NyaXB0aW9uKHByb2plY3QpOwp9Cgphc3luYyBmdW5jdGlvbiBkZWxldGVQcm9qZWN0KGlkOiBzdHJpbmcpOiBQcm9taXNlPHZvaWQ+IHsKICBhd2FpdCBkZWxheSgpOwogIGNvbnN0IGlkeCA9IHByb2plY3RzLmZpbmRJbmRleCgocCkgPT4gcC5pZCA9PT0gaWQpOwogIGlmIChpZHggIT09IC0xKSB7CiAgICBwcm9qZWN0cy5zcGxpY2UoaWR4LCAxKTsKICB9Cn0KCmFzeW5jIGZ1bmN0aW9uIGNyZWF0ZVRhc2soewogIHRpdGxlLAogIGRlc2NyaXB0aW9uID0gIiIsCiAgcHJvamVjdElkLAp9OiB7CiAgdGl0bGU6IHN0cmluZzsKICBkZXNjcmlwdGlvbjogc3RyaW5nOwogIHByb2plY3RJZDogc3RyaW5nOwp9KTogUHJvbWlzZTxNb2NrVGFza1siJHByaW1hcnlLZXkiXT4gewogIGF3YWl0IGRlbGF5KCk7CiAgY29uc3QgcHJvamVjdCA9IHByb2plY3RzLmZpbmQoKHApID0+IHAuaWQgPT09IHByb2plY3RJZCk7CiAgaWYgKHByb2plY3QgPT0gbnVsbCkgewogICAgdGhyb3cgbmV3IEVycm9yKGBQcm9qZWN0ICR7cHJvamVjdElkfSBub3QgZm91bmQhYCk7CiAgfQogIGNvbnN0IGlkID0gcmFuZG9tSWQoKTsKICBwcm9qZWN0LnRhc2tzLnVuc2hpZnQoewogICAgJGFwaU5hbWU6ICJNb2NrVGFzayIsCiAgICAkcHJpbWFyeUtleTogaWQsCiAgICBpZCwKICAgIHRpdGxlLAogICAgZGVzY3JpcHRpb24sCiAgfSk7CiAgcmV0dXJuIGlkOwp9Cgphc3luYyBmdW5jdGlvbiBnZXRSZWNvbW1lbmRlZFRhc2tEZXNjcmlwdGlvbigKICB0YXNrTmFtZTogc3RyaW5nLAopOiBQcm9taXNlPHN0cmluZz4gewogIGF3YWl0IGRlbGF5KCk7CiAgaWYgKHRhc2tOYW1lLmxlbmd0aCA9PT0gMCkgewogICAgdGhyb3cgbmV3IEVycm9yKCJUYXNrIG5hbWUgbXVzdCBub3QgYmUgZW1wdHkiKTsKICB9CiAgcmV0dXJuIGBNb2NrIEFJUCBkZXNjcmlwdGlvbiBmb3IgdGFza2A7Cn0KCmFzeW5jIGZ1bmN0aW9uIGRlbGV0ZVRhc2soaWQ6IHN0cmluZyk6IFByb21pc2U8dm9pZD4gewogIGF3YWl0IGRlbGF5KCk7CiAgZm9yIChjb25zdCBwcm9qZWN0IG9mIHByb2plY3RzKSB7CiAgICBjb25zdCBpZHggPSBwcm9qZWN0LnRhc2tzLmZpbmRJbmRleCgodCkgPT4gdC5pZCA9PT0gaWQpOwogICAgaWYgKGlkeCAhPT0gLTEpIHsKICAgICAgcHJvamVjdC50YXNrcy5zcGxpY2UoaWR4LCAxKTsKICAgIH0KICB9Cn0KCmNvbnN0IE1vY2tzID0gewogIGdldFByb2plY3RzLAogIGNyZWF0ZVByb2plY3QsCiAgZ2V0UmVjb21tZW5kZWRQcm9qZWN0RGVzY3JpcHRpb24sCiAgZGVsZXRlUHJvamVjdCwKICBjcmVhdGVUYXNrLAogIGRlbGV0ZVRhc2ssCiAgZ2V0UmVjb21tZW5kZWRUYXNrRGVzY3JpcHRpb24sCiAgdXBkYXRlUHJvamVjdERlc2NyaXB0aW9uLAp9OwoKZXhwb3J0IGRlZmF1bHQgTW9ja3M7Cg=="
|
|
1143
|
-
}], ["src/useProjectTasks.ts", {
|
|
1144
|
-
"type": "base64",
|
|
1145
|
-
"body": "aW1wb3J0IHsgdXNlQ2FsbGJhY2sgfSBmcm9tICJyZWFjdCI7CmltcG9ydCB1c2VTV1IgZnJvbSAic3dyIjsKaW1wb3J0IE1vY2tzLCB7IE1vY2tQcm9qZWN0LCBNb2NrVGFzayB9IGZyb20gIi4vbW9ja3MiOwoKZXhwb3J0IGZ1bmN0aW9uIHVzZVByb2plY3RUYXNrcyhwcm9qZWN0OiBNb2NrUHJvamVjdCB8IHVuZGVmaW5lZCkgewogIGNvbnN0IHsgZGF0YSwgaXNMb2FkaW5nLCBpc1ZhbGlkYXRpbmcsIGVycm9yLCBtdXRhdGUgfSA9IHVzZVNXUjxNb2NrVGFza1tdPigKICAgIHByb2plY3QgIT0gbnVsbCA/IGBwcm9qZWN0cy8ke3Byb2plY3QuaWR9L3Rhc2tzYCA6IG51bGwsCiAgICAvLyBUcnkgdG8gaW1wbGVtZW50IHRoaXMgd2l0aCB0aGUgT250b2xvZ3kgU0RLIQogICAgYXN5bmMgKCkgPT4gewogICAgICBpZiAocHJvamVjdCA9PSBudWxsKSB7CiAgICAgICAgcmV0dXJuIFtdOwogICAgICB9CiAgICAgIHJldHVybiBwcm9qZWN0LnRhc2tzOwogICAgfSwKICApOwoKICBjb25zdCBjcmVhdGVUYXNrOiAoCiAgICB0aXRsZTogc3RyaW5nLAogICAgZGVzY3JpcHRpb246IHN0cmluZywKICApID0+IFByb21pc2U8TW9ja1Rhc2tbIiRwcmltYXJ5S2V5Il0gfCB1bmRlZmluZWQ+ID0gdXNlQ2FsbGJhY2soCiAgICBhc3luYyAodGl0bGU6IHN0cmluZywgZGVzY3JpcHRpb246IHN0cmluZykgPT4gewogICAgICBpZiAocHJvamVjdCA9PSBudWxsKSB7CiAgICAgICAgcmV0dXJuIHVuZGVmaW5lZDsKICAgICAgfQogICAgICAvLyBUcnkgdG8gaW1wbGVtZW50IHRoaXMgd2l0aCB0aGUgT250b2xvZ3kgU0RLIQogICAgICBjb25zdCBpZCA9IGF3YWl0IE1vY2tzLmNyZWF0ZVRhc2soewogICAgICAgIHRpdGxlLAogICAgICAgIGRlc2NyaXB0aW9uLAogICAgICAgIHByb2plY3RJZDogcHJvamVjdC4kcHJpbWFyeUtleSwKICAgICAgfSk7CiAgICAgIGF3YWl0IG11dGF0ZSgpOwogICAgICByZXR1cm4gaWQ7CiAgICB9LAogICAgW3Byb2plY3QsIG11dGF0ZV0sCiAgKTsKCiAgY29uc3QgZGVsZXRlVGFzazogKHRhc2s6IE1vY2tUYXNrKSA9PiBQcm9taXNlPHZvaWQ+ID0gdXNlQ2FsbGJhY2soCiAgICBhc3luYyAodGFzaykgPT4gewogICAgICBpZiAocHJvamVjdCA9PSBudWxsKSB7CiAgICAgICAgcmV0dXJuOwogICAgICB9CiAgICAgIGF3YWl0IHNsZWVwKDEwMDApOwogICAgICAvLyBUcnkgdG8gaW1wbGVtZW50IHRoaXMgd2l0aCB0aGUgT250b2xvZ3kgU0RLIQogICAgICBhd2FpdCBNb2Nrcy5kZWxldGVUYXNrKHRhc2suJHByaW1hcnlLZXkpOwogICAgICBhd2FpdCBtdXRhdGUoKTsKICAgIH0sCiAgICBbcHJvamVjdCwgbXV0YXRlXSwKICApOwoKICBjb25zdCBnZXRSZWNvbW1lbmRlZFRhc2tEZXNjcmlwdGlvbjogKHRhc2tOYW1lOiBzdHJpbmcpID0+IFByb21pc2U8c3RyaW5nPiA9CiAgICB1c2VDYWxsYmFjaygKICAgICAgYXN5bmMgKHRhc2tOYW1lOiBzdHJpbmcpID0+IHsKICAgICAgICAvLyBUcnkgdG8gaW1wbGVtZW50IHRoaXMgd2l0aCB0aGUgT250b2xvZ3kgU0RLIQogICAgICAgIGNvbnN0IHJlY29tbWVuZGVkVGFza0Rlc2NyaXB0aW9uID0gYXdhaXQgTW9ja3MKICAgICAgICAgIC5nZXRSZWNvbW1lbmRlZFRhc2tEZXNjcmlwdGlvbih0YXNrTmFtZSk7CiAgICAgICAgYXdhaXQgbXV0YXRlKCk7CiAgICAgICAgcmV0dXJuIHJlY29tbWVuZGVkVGFza0Rlc2NyaXB0aW9uOwogICAgICB9LAogICAgICBbbXV0YXRlXSwKICAgICk7CgogIHJldHVybiB7CiAgICB0YXNrczogZGF0YSwKICAgIGlzTG9hZGluZywKICAgIGlzVmFsaWRhdGluZywKICAgIGlzRXJyb3I6IGVycm9yLAogICAgY3JlYXRlVGFzaywKICAgIGRlbGV0ZVRhc2ssCiAgICBnZXRSZWNvbW1lbmRlZFRhc2tEZXNjcmlwdGlvbiwKICB9Owp9CgpmdW5jdGlvbiBzbGVlcChtczogbnVtYmVyKSB7CiAgcmV0dXJuIG5ldyBQcm9taXNlKHJlc29sdmUgPT4gc2V0VGltZW91dChyZXNvbHZlLCBtcykpOwp9Cg=="
|
|
1146
|
-
}], ["src/useProjects.ts", {
|
|
1147
|
-
"type": "base64",
|
|
1148
|
-
"body": "aW1wb3J0IHsgdXNlQ2FsbGJhY2sgfSBmcm9tICJyZWFjdCI7CmltcG9ydCB1c2VTV1IgZnJvbSAic3dyIjsKaW1wb3J0IHR5cGUgeyBNb2NrUHJvamVjdCB9IGZyb20gIi4vbW9ja3MiOwppbXBvcnQgTW9ja3MgZnJvbSAiLi9tb2NrcyI7CgpmdW5jdGlvbiB1c2VQcm9qZWN0cygpIHsKICBjb25zdCB7IGRhdGEsIGlzTG9hZGluZywgaXNWYWxpZGF0aW5nLCBlcnJvciwgbXV0YXRlIH0gPSB1c2VTV1I8CiAgICBNb2NrUHJvamVjdFtdCiAgPigicHJvamVjdHMiLCBhc3luYyAoKSA9PiB7CiAgICAvLyBUcnkgdG8gaW1wbGVtZW50IHRoaXMgd2l0aCB0aGUgT250b2xvZ3kgU0RLIQogICAgcmV0dXJuIE1vY2tzLmdldFByb2plY3RzKCk7CiAgfSk7CgogIGNvbnN0IGNyZWF0ZVByb2plY3Q6ICgKICAgIG5hbWU6IHN0cmluZywKICApID0+IFByb21pc2U8TW9ja1Byb2plY3RbIiRwcmltYXJ5S2V5Il0+ID0gdXNlQ2FsbGJhY2soCiAgICBhc3luYyAobmFtZTogc3RyaW5nKSA9PiB7CiAgICAgIC8vIFRyeSB0byBpbXBsZW1lbnQgdGhpcyB3aXRoIHRoZSBPbnRvbG9neSBTREshCiAgICAgIGNvbnN0IGlkID0gYXdhaXQgTW9ja3MuY3JlYXRlUHJvamVjdCh7IG5hbWUgfSk7CiAgICAgIGF3YWl0IG11dGF0ZSgpOwogICAgICByZXR1cm4gaWQ7CiAgICB9LAogICAgW211dGF0ZV0sCiAgKTsKCiAgY29uc3QgdXBkYXRlUHJvamVjdERlc2NyaXB0aW9uOiAoCiAgICBwcm9qZWN0OiBNb2NrUHJvamVjdCwKICApID0+IFByb21pc2U8dm9pZD4gPSB1c2VDYWxsYmFjaygKICAgIGFzeW5jIChwcm9qZWN0KSA9PiB7CiAgICAgIC8vIFRyeSB0byBpbXBsZW1lbnQgdGhpcyB3aXRoIHRoZSBPbnRvbG9neSBTREshCiAgICAgIGF3YWl0IE1vY2tzLnVwZGF0ZVByb2plY3REZXNjcmlwdGlvbihwcm9qZWN0KTsKICAgICAgYXdhaXQgbXV0YXRlKCk7CiAgICB9LAogICAgW211dGF0ZV0sCiAgKTsKCiAgY29uc3QgZGVsZXRlUHJvamVjdDogKHByb2plY3Q6IE1vY2tQcm9qZWN0KSA9PiBQcm9taXNlPHZvaWQ+ID0gdXNlQ2FsbGJhY2soCiAgICBhc3luYyAocHJvamVjdCkgPT4gewogICAgICAvLyBUcnkgdG8gaW1wbGVtZW50IHRoaXMgd2l0aCB0aGUgT250b2xvZ3kgU0RLIQogICAgICBhd2FpdCBNb2Nrcy5kZWxldGVQcm9qZWN0KHByb2plY3QuJHByaW1hcnlLZXkpOwogICAgICBhd2FpdCBtdXRhdGUoKTsKICAgIH0sCiAgICBbbXV0YXRlXSwKICApOwoKICByZXR1cm4gewogICAgcHJvamVjdHM6IGRhdGEsCiAgICBpc0xvYWRpbmcsCiAgICBpc1ZhbGlkYXRpbmcsCiAgICBpc0Vycm9yOiBlcnJvciwKICAgIGNyZWF0ZVByb2plY3QsCiAgICBkZWxldGVQcm9qZWN0LAogICAgdXBkYXRlUHJvamVjdERlc2NyaXB0aW9uLAogIH07Cn0KCmV4cG9ydCBkZWZhdWx0IHVzZVByb2plY3RzOwo="
|
|
1149
|
-
}], ["src/vite-env.d.ts", {
|
|
1150
|
-
"type": "base64",
|
|
1151
|
-
"body": "Ly8vIDxyZWZlcmVuY2UgdHlwZXM9InZpdGUvY2xpZW50IiAvPgo="
|
|
1152
|
-
}], ["tsconfig.json", {
|
|
1153
|
-
"type": "base64",
|
|
1154
|
-
"body": "ewogICJjb21waWxlck9wdGlvbnMiOiB7CiAgICAidGFyZ2V0IjogIkVTMjAyMCIsCiAgICAidXNlRGVmaW5lRm9yQ2xhc3NGaWVsZHMiOiB0cnVlLAogICAgImxpYiI6IFsiRVMyMDIwIiwgIkRPTSIsICJET00uSXRlcmFibGUiXSwKICAgICJtb2R1bGUiOiAiRVNOZXh0IiwKICAgICJza2lwTGliQ2hlY2siOiB0cnVlLAoKICAgIC8qIEJ1bmRsZXIgbW9kZSAqLwogICAgIm1vZHVsZVJlc29sdXRpb24iOiAiYnVuZGxlciIsCiAgICAiYWxsb3dJbXBvcnRpbmdUc0V4dGVuc2lvbnMiOiB0cnVlLAogICAgInJlc29sdmVKc29uTW9kdWxlIjogdHJ1ZSwKICAgICJpc29sYXRlZE1vZHVsZXMiOiB0cnVlLAogICAgIm5vRW1pdCI6IHRydWUsCiAgICAianN4IjogInJlYWN0LWpzeCIsCgogICAgLyogTGludGluZyAqLwogICAgInN0cmljdCI6IHRydWUsCiAgICAibm9VbnVzZWRMb2NhbHMiOiB0cnVlLAogICAgIm5vVW51c2VkUGFyYW1ldGVycyI6IHRydWUsCiAgICAibm9GYWxsdGhyb3VnaENhc2VzSW5Td2l0Y2giOiB0cnVlCiAgfSwKICAiaW5jbHVkZSI6IFsic3JjIl0sCiAgInJlZmVyZW5jZXMiOiBbeyAicGF0aCI6ICIuL3RzY29uZmlnLm5vZGUuanNvbiIgfV0KfQo="
|
|
1155
|
-
}], ["tsconfig.node.json", {
|
|
1156
|
-
"type": "base64",
|
|
1157
|
-
"body": "ewogICJjb21waWxlck9wdGlvbnMiOiB7CiAgICAiY29tcG9zaXRlIjogdHJ1ZSwKICAgICJza2lwTGliQ2hlY2siOiB0cnVlLAogICAgIm1vZHVsZSI6ICJFU05leHQiLAogICAgIm1vZHVsZVJlc29sdXRpb24iOiAiYnVuZGxlciIsCiAgICAiYWxsb3dTeW50aGV0aWNEZWZhdWx0SW1wb3J0cyI6IHRydWUKICB9LAogICJpbmNsdWRlIjogWyJ2aXRlLmNvbmZpZy50cyJdCn0K"
|
|
1158
|
-
}], ["vite.config.ts.hbs", {
|
|
1159
|
-
type: "raw",
|
|
1160
|
-
body: `import react from "@vitejs/plugin-react";
|
|
1161
|
-
import { defineConfig } from "vite";
|
|
1162
|
-
|
|
1163
|
-
// https://vitejs.dev/config/
|
|
1164
|
-
export default defineConfig({
|
|
1165
|
-
plugins: [react()],
|
|
1166
|
-
server: {
|
|
1167
|
-
port: 8080,
|
|
1168
|
-
{{#if corsProxy}}
|
|
1169
|
-
proxy: {
|
|
1170
|
-
"^(/multipass/api|/api)": {
|
|
1171
|
-
target: "{{foundryUrl}}",
|
|
1172
|
-
changeOrigin: true,
|
|
1173
|
-
secure: true,
|
|
1174
|
-
},
|
|
1175
|
-
},
|
|
1176
|
-
{{/if}}
|
|
1177
|
-
},
|
|
1178
|
-
});
|
|
1179
|
-
`
|
|
1180
|
-
}]]);
|
|
1181
|
-
|
|
1182
|
-
export { files };
|
|
1183
|
-
//# sourceMappingURL=esm-H2IADGOR.js.map
|
|
1184
|
-
//# sourceMappingURL=esm-H2IADGOR.js.map
|