About Worse Nomnoml
What is this?
Worse Nomnoml is an experimental implementation of the Nomnoml UML diagram tool. Despite the self-deprecating name, this project aims to explore improvements to the original tool while serving as a learning experience in React development.
Features
- Diagram Editor: Create and edit UML diagrams using the Nomnoml syntax
- Natural Language: Add notes and descriptions to your diagrams
- Soon, I am planning to add my favourite feature: natural language input
- Structure Code: Automatically organize your diagram code
- This is entirely a preference of mine when writing a new diagram, but I quite enjoy having the components and flows separately organized. Helps with styling and keeps the flows clean. Pressing the 'Organize' button above the editor will let you do just that.
- Live Preview: See your diagram update in real-time as you type
- As you might have guessed, this uses Nomnoml in the background to render the SVG diagram.
- File Operations: Create, save, and load diagram files
- Export Options: Download your diagrams as SVG or PNG
Why "Worse"?
The name is a humble acknowledgment that this is an experimental project that doesn't (yet) have all the features and polish of the original Nomnoml. It's a work in progress and a learning journey.
Getting Started
To create a basic diagram:
[Customer]->[Order]
[Order]+->[LineItem]
[Customer]->[Feedback]
Nomnoml Syntax
Association types
- association
-> association
<-> association
--> dependency
<--> dependency
-:> generalization
<:- generalization
--:> implementation
<:-- implementation
+- composition
+-> composition
o- aggregation
o-> aggregation
-o) ball and socket
o<-) ball and socket
->o ball and socket
-- note
-/- hidden
Classifier types
[name]
[<abstract> name]
[<instance> name]
[<reference> name]
[<note> name]
[<package> name]
[<frame> name]
[<database> name]
[<pipe> name]
[<start> name]
[<end> name]
[<state> name]
[<choice> name]
[<sync> name]
[<input> name]
[<lollipop> lollipop]
[<sender> name]
[<socket> socket]
[<receiver> name]
[<transceiver> name]
[<actor> name]
[<usecase> name]
[<label> name]
[<hidden> name]
[<table> name| a | 5 || b | 7]
Comments
Comments are supported at the start of a line.
//[commented]