diff --git a/alfalfa_web/alfalfa.svg b/alfalfa_web/alfalfa.svg deleted file mode 100644 index 04a1a8ad..00000000 --- a/alfalfa_web/alfalfa.svg +++ /dev/null @@ -1 +0,0 @@ - diff --git a/alfalfa_web/components/App/App.js b/alfalfa_web/components/App/App.js index c27b4091..0b7ac16b 100644 --- a/alfalfa_web/components/App/App.js +++ b/alfalfa_web/components/App/App.js @@ -17,7 +17,7 @@ export const App = () => {
- + diff --git a/alfalfa_web/app.js b/alfalfa_web/components/app.js similarity index 76% rename from alfalfa_web/app.js rename to alfalfa_web/components/app.js index f21a59d2..0602f038 100644 --- a/alfalfa_web/app.js +++ b/alfalfa_web/components/app.js @@ -4,11 +4,13 @@ import "@fontsource/roboto"; import "normalize.css/normalize.css"; import ReactDOM from "react-dom"; import { BrowserRouter } from "react-router-dom"; -import { App } from "./components/App/App.js"; +import { App } from "./App/App.js"; ReactDOM.render( - + + + , document.getElementById("root") ); diff --git a/alfalfa_web/generate-docs.js b/alfalfa_web/generate-docs.js index f0bb8fe8..293f6000 100644 --- a/alfalfa_web/generate-docs.js +++ b/alfalfa_web/generate-docs.js @@ -17,7 +17,7 @@ const openapiSpecification = swaggerJsdoc({ description: "Alfalfa transforms Building Energy Models (BEMs) into virtual buildings by providing industry standard building control interfaces for interacting with models as they run", "x-logo": { - url: "/assets/alfalfa.svg" + url: "" } }, servers: [ @@ -203,6 +203,3 @@ mkdirp.sync("build/app/assets"); fs.writeFileSync("build/app/openapi.json", JSON.stringify(openapiSpecification)); npmRun.execSync("redoc-cli build openapi.json -t ../../docs.hbs", { cwd: __dirname + "/build/app" }); - -fs.copyFileSync("alfalfa.svg", "build/app/assets/alfalfa.svg"); -fs.renameSync("build/app/redoc-static.html", "build/app/docs.html"); diff --git a/alfalfa_web/package.json b/alfalfa_web/package.json index af9a9c18..910cc083 100644 --- a/alfalfa_web/package.json +++ b/alfalfa_web/package.json @@ -9,8 +9,10 @@ "build-server": "babel -d ./build ./server", "clean": "npx rimraf build", "start": "node ./build/index.js", - "start-dev": "npm run build-server && env-cmd -f ../.env npm start", - "watch": "nodemon -e js,html --ignore build/ --exec \"npm run build-app && npm run build-server && npm start\"" + "watch": "run-p watch-app watch-docs watch-server", + "watch-app": "webpack --watch", + "watch-docs": "nodemon --watch generate-docs.js --watch server/api-v2.js --watch server/api-haystack.js generate-docs.js", + "watch-server": "nodemon --watch server --exec \"npm run build-server && env-cmd -f ../.env npm start\"" }, "author": "", "license": "ISC", diff --git a/alfalfa_web/server/api.js b/alfalfa_web/server/api.js index 02a2b98e..ec721908 100644 --- a/alfalfa_web/server/api.js +++ b/alfalfa_web/server/api.js @@ -32,6 +32,7 @@ class AlfalfaAPI { this.s3 = new S3Client({ credentials, endpoint: process.env.S3_URL_EXTERNAL || process.env.S3_URL, + forcePathStyle: true, region }); } diff --git a/alfalfa_web/server/index.js b/alfalfa_web/server/index.js index 4e1b2a19..077b4874 100644 --- a/alfalfa_web/server/index.js +++ b/alfalfa_web/server/index.js @@ -11,6 +11,7 @@ import { createClient } from "redis"; import alfalfaServer from "./alfalfa-server"; import apiv2 from "./api-v2"; +const isProd = process.env.NODE_ENV === "production"; const redis = createClient({ host: process.env.REDIS_HOST }); MongoClient.connect(process.env.MONGO_URL, { useUnifiedTopology: true }) @@ -35,13 +36,21 @@ MongoClient.connect(process.env.MONGO_URL, { useUnifiedTopology: true }) }); }); - app.get("/redoc", (req, res) => { - const docsPath = path.join(__dirname, "/app/docs.html"); + let cachedDocs; + app.get("/redoc", async (req, res) => { + if (isProd && cachedDocs) { + return res.type("html").send(cachedDocs); + } + + const docsPath = path.join(__dirname, "app/redoc-static.html"); - fsp - .access(docsPath, fsp.constants.F_OK) - .then(() => res.sendFile(docsPath)) - .catch(() => res.status(404).type("txt").send("Documentation has not been generated")); + try { + await fsp.access(docsPath, fsp.constants.F_OK); + res.sendFile(docsPath); + if (isProd) cachedDocs = await fsp.readFile(docsPath, "utf-8"); + } catch (e) { + res.status(404).type("txt").send("Documentation has not been generated"); + } }); app.use("/api/v2/", apiv2({ api: app.locals.alfalfaServer.api })); diff --git a/alfalfa_web/webpack.config.js b/alfalfa_web/webpack.config.js index 077bb323..2ee4659d 100644 --- a/alfalfa_web/webpack.config.js +++ b/alfalfa_web/webpack.config.js @@ -25,20 +25,10 @@ const getSha = () => { module.exports = { mode: isProd ? "production" : "development", devtool: isProd ? false : "source-map", - entry: "./app.js", + entry: "./components/app.js", cache: { type: "filesystem" }, - devServer: { - static: { - directory: path.join(__dirname, "public") - }, - compress: true, - port: 80 - }, - watchOptions: { - ignored: ["**/node_modules", "**/scripts", "**/server"] - }, output: { path: path.resolve(__dirname, "build/app"), filename: "app.bundle.js" @@ -53,6 +43,9 @@ module.exports = { }) ] }, + performance: { + hints: false + }, module: { rules: [ {