Remix and Shadow-Cljs
Included in this repo is poc of using ClojureScript rumext
library to be
rendered by remix
.
Based on npx create-remix@latest
, with the assistance of this article
https://kentcdodds.com/blog/super-simple-start-to-remix that provide information
on barebone remix application structure.
TLDR;
npm run shadow
npm run build
npm run start
Welcome to Remix!
Development
You'll need to run two terminals (or bring in a process manager like concurrently/pm2-dev if you like):
Start the Remix development asset server
npm run dev
In a new tab start your express app:
npm run start:dev
This starts your app in development mode, which will purge the server require cache when Remix rebuilds assets so you don't need a process manager restarting the express server.
Deployment
First, build your app for production:
npm run build
Then run the app in production mode:
npm start
Now you'll need to pick a host to deploy it to.
DIY
If you're familiar with deploying express applications you should be right at home just make sure to deploy the output of remix build
server/build/
public/build/
Using a Template
When you ran npx create-remix@latest
there were a few choices for hosting. You can run that again to create a new project, then copy over your app/
folder to the new project that's pre-configured for your target server.
cd ..
# create a new project, and pick a pre-configured host
npx create-remix@latest
cd my-new-remix-app
# remove the new project's app (not the old one!)
rm -rf app
# copy your app over
cp -R ../my-old-remix-app/app app