Mermaid Diagrams
Making cool diagrams for my LunchTrak project
data:image/s3,"s3://crabby-images/f7316/f7316eb896cfc8ecdaf9f2556d3718c265e26381" alt="Mermaid Diagrams"
Documentation for any project is an important component that helps increase maintainability. Of course, writing docs are never fun. Last month, on my 8-hour flight back from London, I decided I might as well document as much as possible for my LunchTrak project. This was my first time flying business, and I just wanna say, I had the nicest nap ever (those seats go all the way down!).
data:image/s3,"s3://crabby-images/edcc1/edcc12e5c32897dd140f3c6dc9d442808636a47b" alt=""
It was pretty easy to explain in the README.md file what the purpose of each repo was, but I wanted to do more. I wanted to draw a state diagram to easily see the states and transitions of the Application State Machine (ASM) so I wouldn't have to spend lots of time hand-drawing them to debug.
data:image/s3,"s3://crabby-images/4b8b9/4b8b9c2b1631603f4601e9d5a3cf7d5fd65e440e" alt=""
Luckily, Mr. Lera introduced our CS Capstone class to a tool called Mermaid, which allows us to make state diagrams easily. The syntax is easy and integrates nicely with GitHub's readme visualizer. Here's the basic format:
STATE --> NEXT_STATE: OPERATION
Luckily, I don't need to type each connection by hand. I already wrote all the state machine definitions in my source code, so all I needed was a little Vscode finesse-ing and I was all set. With just a few CTRL+D and CTRL+arrowkeys, I turned my code into the Mermaid diagram below.
data:image/s3,"s3://crabby-images/adb50/adb5019545c69e89e4addff96072ab105b10447c" alt=""
data:image/s3,"s3://crabby-images/e6476/e64768373e62f8c3eee9458b4a436875524f7d7e" alt=""
And yay! Now we have a really pretty diagram to show on our GitHub readme. Too bad I'm not making my repo public for others to see.
data:image/s3,"s3://crabby-images/bd4f1/bd4f1d1469df7a961116e6488a86da33b128c93e" alt=""
Not gonna lie, I think my state machine is too complicated...