Spark Holland intranet site
Ensure you have the following installed:
- Python 3.11 🐍
- Node 22 🟩
- pnpm 🧶
- Docker 🐳
- Clone the repository:
git clone [email protected]:ghnire/sparknet.git
cd sparknet
- Install both Backend and Frontend:
make install
- Create a new Plone site on your first run:
make backend-create-site
- Start the Backend at http://localhost:8080/:
make backend-start
- In a new terminal, start the Frontend at http://localhost:3000/:
make frontend-start
Voila! Your Plone site should be live and kicking! 🎉
Deploy a local Docker Compose
environment that includes:
- Docker images for Backend and Frontend 🖼️
- A stack with a Traefik router and a Postgres database 🗃️
- Accessible at http://sparknet.localhost 🌐
Execute the following:
make stack-start
make stack-create-site
And... you're all set! Your Plone site is up and running locally! 🚀
This monorepo consists of three distinct sections: backend
, frontend
, and devops
.
- backend: Houses the API and Plone installation, utilizing pip instead of buildout, and includes a policy package named sparknet.
- frontend: Contains the React (Volto) package.
- devops: Encompasses Docker Stack, Ansible playbooks, and Cache settings.
- All necessary codebases to run the site are contained within the repo (excluding existing addons for Plone and React).
- Specific GitHub Workflows are triggered based on changes in each codebase (refer to .github/workflows).
- Simplifies the creation of Docker images for each codebase.
- Demonstrates Plone installation/setup without buildout.
To automatically format your code and ensure it adheres to quality standards, execute:
make check
Linters can be run individually within the backend
or frontend
folders.
Generate translation files for Plone and Volto with ease:
make i18n
Crafted with care by Generated using Cookieplone (0.8.1) and cookiecutter-plone (7a2b499) on 2024-12-10 17:18:51.999011. A special thanks to all contributors and supporters!