Software Guidebook (SGB)
Voor de documentatie gebruik je het Software Guidebook van Simon Brown als uitgangspunt.
Maar je kunt ook de Reader gebruiken die we beschikbaar stellen.
De resultaten van de onderzoeken verwerk je in een Software Guidebook
Zorg dat jullie Software Guidebook in ieder geval de volgende hoofdstukken bevat.
- Context
- Functional Overview
- Quality Attributes
- Constraints
- Principles
- Software Architecture
- Code
- Data
- Infrastructure Architecture
- Deployment
- Operation and Support
- Development Environment
- Decision Log

Daarnaast is er waarschijnlijk nog andere documentatie met onderzoeken en onderzoeksresultaten. Deze documentatie kun je integreren in het software guidebook, maar je kunt ook linken naar specifieke plekken in jullie repo als dat handiger is.
GitHub Pages
In het vak SoEx heb je een voorbeeld gezien van een Software Guidebook geschreven in MarkDown in een GitHub repo. In dit project vragen we van jullie om het Software Guidebook in GitHub Pages te publiceren.
Zie https://pages.github.com/ voor een introductie in publiceren op github pages.
Voor het toevoegen van basis-styling kun je het beste een static site generator gebruiken. GitHub raadt zelf Jekyll aan. Zie:
Populaire alternatieven zijn:
Aanbevolen: Docusaurus

Wij adviseren in PEXE om Docusaurus te gebruiken voor het Software Guidebook.
Waarom dit praktisch is voor dit project:
- Navigatie en structuur voor hoofdstukken zoals Context, Architecture en Decision Log.
- Zoeken over alle pagina's (via plugin).
- Goed te combineren met C4 en UML diagrammen en voorbeelden in Markdown/MDX.
- Makkelijk te publiceren via GitHub Pages met GitHub Actions pipeline (bekend uit PWAC project).
Diagrammen met remark-kroki-a11y
Als je in je SGB veel domeinmodellen, C4-diagrammen en user story map visualisaties hebt, voeg dan remark-kroki-a11y toe:
- Het helpt blinde en slechtziende lezers via toegankelijke beschrijvingen
- Het helpt ook bij situationele disabilities: bijvoorbeeld opdrachtgevers of domeinexperts die een klassendiagram niet kunnen of niet willen lezen, maar wel snel een begrijpelijke uitleg nodig hebben
Check uitklapbalk voor achtergronden en how-to's.
Achtergrond/how to en voorbeeld (uitklappen)
Kroki is een verzameltool voor allerlei text-to-diagrans tools, zoals PlantUML, Mermaid en C4. Kroki...
"provides a unified API with support for BlockDiag (BlockDiag, SeqDiag, ActDiag, NwDiag, PacketDiag, RackDiag), BPMN, Bytefield, C4 (with PlantUML), D2, DBML, Ditaa, Erd, Excalidraw, GraphViz, Mermaid, Nomnoml, Pikchr, PlantUML, Structurizr, SvgBob, Symbolator, TikZ, UMLet, Vega, Vega-Lite, WaveDrom, WireViz... and more to come!" — kroki.io
Remark is:
"an ecosystem of plugins that work with markdown as structured data, specifically ASTs (abstract syntax trees). ASTs make it easy for programs to deal with markdown. We call those programs plugins. Plugins inspect and change trees. You can use the many existing plugins or you can make your own." — remark
En Markdown is:
"a simple way to format text that looks great on any device. It doesn’t do anything fancy like change the font size, color, or type — just the essentials, using keyboard symbols you already know." — commonmark.com
Voorbeelden markdown syntax:
# Heading 1 -> # Heading 1
*Italic*-> Italic**Bold**-> Bold[Linktekst voor website a](http://a.com)-> Linktekst voor website a ⋮ De installatie- en configuratiestappen staan hier.
Werkt dit ook met Jekyll of MkDocs?
In principe zou de plugin daar ook moeten werken omdat de plremark (en deze plugin) draait.
Omdat remark-kroki-a11y een remark-plugin is, is de techniek niet strikt Docusaurus-specifiek.
De standaard Jekyll- en MkDocs-pipelines draaien dit niet automatisch, dus je hebt daar extra integratie of een pre-build stap nodig.
Voor dit vak is Docusaurus daarom waarschijnlijk de snelste route.
Voorbeeld domein model
Voorbeeld met For devs / Simpler toggle op een domeinmodel: