diff --git a/docker/.env b/docker/.env index e7e3a00a..602a7fb0 100644 --- a/docker/.env +++ b/docker/.env @@ -1,21 +1,22 @@ # This is the port the vue.js frontend listens on. You can # access it via http://localhost:${FRONTEND_PORT}. -FRONTEND_PORT=8896 +WHATRECORD_FRONTEND_PORT=8896 # This is the container name, so the frontend can communicate with the backend -API_HOST=whatrecord +WHATRECORD_API_HOST=whatrecord +# Alternatively, if run locally or on a different host, you could make this +# the hostname/IP address: +# WHATRECORD_API_HOST=127.0.0.1 # This is the port the backend (whatrecord server) listens on. You can # access it via localhost:${API_PORT}. -API_PORT=8895 +WHATRECORD_API_PORT=8895 # These are the default plugins to enable. This is used by the server # to selectively enable the plugins, and the frontend to selectively # display them to the user. Other plugins include: # twincat_pytmc epicsarch netconfig WHATRECORD_PLUGINS=happi -VUE_APP_WHATRECORD_PLUGINS=happi -# Why twice? The frontend requires a prefix of VUE_APP*. # The default version to use for IOCs WHATRECORD_BASE_VERSION=3.15 @@ -35,8 +36,8 @@ WHATRECORD_SERVER_SCAN_PERIOD=600 WHATRECORD_AUTOSAVE_RELOAD_PERIOD=60 # These are optional to show off the plugins: -HAPPI_CFG=/usr/share/whatrecord/support/happi.cfg +WHATRECORD_HAPPI_CFG=/usr/share/whatrecord/support/happi.cfg # A placeholder for the archiver appliance viewer URL (not supported in this # demo): -VUE_APP_WHATRECORD_ARCHIVER_URL=http://localhost/ +WHATRECORD_ARCHIVER_URL=http://localhost/ diff --git a/docker/docker-compose.yml b/docker/docker-compose.yml index 924cab0d..92eb67f8 100644 --- a/docker/docker-compose.yml +++ b/docker/docker-compose.yml @@ -7,12 +7,12 @@ services: image: node:18.9-alpine working_dir: /usr/src/app ports: - - "${FRONTEND_PORT}:${FRONTEND_PORT}" + - "${WHATRECORD_FRONTEND_PORT}:${WHATRECORD_FRONTEND_PORT}" volumes: - ../frontend:/usr/src/app - ./support:/usr/share/whatrecord/support entrypoint: /bin/sh - command: /usr/share/whatrecord/support/run_frontend.sh + command: /usr/share/whatrecord/support/start_frontend.sh depends_on: - whatrecord @@ -31,7 +31,7 @@ services: image: pcdshub/whatrecord:latest command: bash /usr/share/whatrecord/support/start_example.sh ports: - - "${API_PORT}:${API_PORT}" + - "${WHATRECORD_API_PORT}:${WHATRECORD_API_PORT}" volumes: - ./cache/:/var/lib/whatrecord/cache - ./support:/usr/share/whatrecord/support diff --git a/docker/support/run_frontend.sh b/docker/support/run_frontend.sh deleted file mode 100755 index dace22f8..00000000 --- a/docker/support/run_frontend.sh +++ /dev/null @@ -1,4 +0,0 @@ -#!/bin/sh - -yarn install -yarn serve --port "${FRONTEND_PORT}" diff --git a/docker/support/start_example.sh b/docker/support/start_example.sh index 36f83344..1c93380f 100644 --- a/docker/support/start_example.sh +++ b/docker/support/start_example.sh @@ -2,7 +2,7 @@ # Note: this is meant to be run from docker via docker-compose and not on its # own. -[ -z ${API_PORT} ] && echo "API port unset?" && exit 1; +[ -z ${WHATRECORD_API_PORT} ] && echo "API port unset?" && exit 1; echo Installing dev whatrecord from your source tree... @@ -19,8 +19,8 @@ STARTUP_SCRIPTS=${STARTUP_SCRIPTS-/usr/local/src/whatrecord/whatrecord/tests/ioc ls -la ${STARTUP_SCRIPTS} -echo Running API server on port ${API_PORT}... +echo Running API server on port ${WHATRECORD_API_PORT}... whatrecord server \ - --port=${API_PORT} \ + --port=${WHATRECORD_API_PORT} \ --gateway-config=/usr/share/whatrecord/support/gateway/ \ --scripts ${STARTUP_SCRIPTS} diff --git a/docker/support/start_frontend.sh b/docker/support/start_frontend.sh new file mode 100755 index 00000000..6100ae34 --- /dev/null +++ b/docker/support/start_frontend.sh @@ -0,0 +1,11 @@ +#!/bin/sh +# +WHATRECORD_FRONTEND_PORT=${WHATRECORD_FRONTEND_PORT-8896} + +echo "* Installing frontend dependencies..." +yarn install +echo "* Monitoring frontend files in the background to rebuild automatically when they update." +echo "* Note: it may take a few seconds before the pages are ready to be served" +yarn build --watch & +echo "* Running the development server on port ${WHATRECORD_FRONTEND_PORT}." +yarn serve --port "${WHATRECORD_FRONTEND_PORT}" --host --strictPort # --debug --logLevel debug diff --git a/frontend/.eslintrc b/frontend/.eslintrc new file mode 100644 index 00000000..2fbcbd26 --- /dev/null +++ b/frontend/.eslintrc @@ -0,0 +1,4 @@ +env: { + node: true, + es2022: true, +} diff --git a/frontend/babel.config.js b/frontend/babel.config.js deleted file mode 100644 index 162a3ea9..00000000 --- a/frontend/babel.config.js +++ /dev/null @@ -1,3 +0,0 @@ -module.exports = { - presets: ["@vue/cli-plugin-babel/preset"], -}; diff --git a/frontend/index.html b/frontend/index.html new file mode 100644 index 00000000..d94451b3 --- /dev/null +++ b/frontend/index.html @@ -0,0 +1,13 @@ + + +
+ + + +