A micro CMS
During the first weeks at XPUB I spent some time trying to figure out how to archive and log the various projects going on. I felt to do it here in the Soupboat, because it's more flexible and playful than the wiki, that remains of course the source of truth and the future-proof archiving system etc. etc. 👹👺
After the second page though I was already ultra annoyed by the fact of rewriting or copy-pasting the HTML from a page to the other to keep at least a bit of style and structure and add contents manually. I wrote then a bit of code to have a default page and then used a JSON file filled with a list of projects. The script traversed this list and created a table with the basic informations about each one.
The model for a project was something like that:
{
"title": "Text Weaving",
"date": "Oct 5, 2021",
"url": "10-05-2021-weaving/",
"git": "https://git.xpub.nl/kamo/text_weaving",
"pad": "https://pad.xpub.nl/p/replacing_cats",
"links": [
{
"url": "",
"title": "",
}
],
"categories": [
"Python",
"NLTK",
"Text"
]
},
Each proj has a title, a date, an URL to a dedicated page. Then a list of links: the git repository for sharing the source code and the pad, that are the two most common types of link, and then a list of generic other links, each one composed by an URL and a title. There is also a list of categories, in order to give some hints about the project.
The dedicated page for a project could have been something somewhere in the Soupboat, or a subfolder in my personal folder.
The structure of the whole thing was: an index.html
page with a cms.js
script and a cms.json
file. (Such imagination in these filenames). Then a style.css
and a global.css
for sharing the style with the various projects.
Not really a revolutionary CMS but a starting point. Ah ah
I'm writing this while im migrating everything into a flask based one, that will use more or less the same structure we developed for the SI16! Really happy with it. Good night