Move fast. Climb mountains. Don't break things.
Mountaineer ๐๏ธ is a framework to easily build webapps in Python and React. If you've used either of these languages before for development, we think you'll be right at home.
Each framework has its own unique features and tradeoffs. Mountaineer focuses on developer productivity above all else, with production speed a close second.
- ๐ Typehints up and down the stack: frontend, backend, and database
- ๐๏ธ Trivially easy client<->server communication, data binding, and function calling
- ๐ Optimized server rendering for better accessibility and SEO
- ๐น Static analysis of web pages for strong validation: link validity, data access, etc.
- ๐คฉ Skip the API or Node.js server just to serve frontend clients
To get started as quickly as possible, we bundle a project generator that sets up a simple project after a quick Q&A. Make sure you have pipx installed.
$ pipx run create-mountaineer-app
Mountaineer projects all follow a similar structure. After running this CLI you should see a new folder called my_webapp
, with folders like the following:
my_webapp
/controllers
/home.py
/models
/mymodel.py
/views
/app
/home
/page.tsx
/layout.tsx
/package.json
/tsconfig.json
/app.py
/cli.py
pyproject.toml
poetry.lock
Every service file is nested under the my_webapp
root package. Views are defined in a disk-based hierarchy (views
) where nested routes are in nested folders. This folder acts as your React project and is where you can define requirements and build parameters in package.json
and tsconfig.json
. Controllers are defined nearby in a flat folder (controllers
) where each route is a separate file. Everything else is just standard Python code for you to modify as needed.
If you're starting a new application from scratch, you'll typically want to create your new database tables. Make sure you have postgres running. We bundle a docker compose file for convenience with create-mountaineer-app
.
docker compose up -d
poetry run createdb
Of course you can also use an existing database instance, simply configure it in the .env
file in the project root.
Mountaineer relies on watching your project for changes and doing progressive compilation. We provide a few CLI commands to help with this.
While doing development work, you'll usually want to preview the frontend and automatically build dependent files. You can do this with:
$ poetry run runserver
INFO: Started server process [93111]
INFO: Waiting for application startup.
INFO: Application startup complete.
INFO: Uvicorn running on http://127.0.0.1:5006 (Press CTRL+C to quit)
Navigate to http://127.0.0.1:5006 to see your new webapp running.
Or, if you just want to watch the source tree for changes without hosting the server. Watching will allow your frontend to pick up API definitions from your backend controllers:
$ poetry run watch
Both of these CLI commands are specified in your project's cli.py
file.