Why Build?
This is a fun example of what can be built with a custom CMS and Wagtail Blocks based on the theme of LCARS.
Description
In the Star Trek fictional universe set in the mid-24th Century, LCARS (Library Computer Access/Retrieval System) is an OS used by the United Federation of Planets on their starfleet vessels, starbases and space stations. Created by scenic art supervisor Michael Okuda, the flurry of activity that goes on all across the screens in The Star Trek: Next Generation, Star Trek: Deep Space Nine and Star Trek: Voyager and Star Trek: Picard has captured the hearts of fans all over.
Wagtail is an OS python CMS (Content Management System) built on Django. To learn more about some of the capabilities of Wagtail, check out Whats New in Wagtail 5, announcing the recent 4.1 LTS release 4.1.1 patch. The backend of this application is built on Wagtail.
Out of the box Wagtail Features:
- Admin, Auth + Django's strong approach to security
- Rapid development environment
StreamField
- a special collection of blocks to write templates to control blocks displayed (implemented)FormBuilder
- Flexible forms in Wagtail- awesome-wagtail community - https://github.com/springload/awesome-wagtail
- issues: https://github.com/dawnwages/LCARS-on-Wagtail/issues
- testing: TBD
- coverage: TBD
- snowpack
- Vue 3.1
- Python 3.11
- Wagtail 4.1.1
- Django 4.0
Separated between frontend LCARS
and backend wagtail
. Django Rest Framework
handles the API routes wagtail/LCARSAPP/api.py
wagtail/LCARSAPP/urls.py
. To learn more about Vue + Wagtail check out: Headless Wagtail Demo. The frontend vue application accesses this in LCARS/http-common.js
and LCARS/src/services/DataService.js
with axios.
- LCARS UI - https://lcars-monitor.netlify.app/
- Posts on page
- RichText, Image, Header block
- Deploy demo to heroku
- Basic blog elements: headers, bullets, images, embeds
- Use Wagtail Snippets to create LCARS widgets like carousels
- Forms
- Calendar (Daily, Monthly, Weekly)
- Complex tables
npm i
npm run start
<< will run on port 8080 without args
cd LCARSAPP
pip install --upgrade pip
pip install -r requirements.txt
./manage.py migrate
./manage.py createsuperuser
./manage.py runserver
<< will run on port 8000 without args
Check me out on Twitter @BajoranEngineer Masto: @[email protected] My website: dawnwages.info Blog: glittertech.dev
Shout out to Lou Huang @saikofish for the UI!