Display DMN decision tables and DRD diagrams in your Slidev presentations. Whether you're presenting decision logic, explaining business rules, or teaching DMN concepts β this addon has you covered! π‘
Powered by dmn-js from bpmn.io.
- Install the addon in your Slidev project
- Place your
.dmnfiles in thepublic/folder - Use the
<DmnDrd>,<DmnTable>or<DmnModeler>components in your slides
That's it β your DMN diagrams are ready to present!
npm install slidev-addon-dmnThen register the addon in your slide's frontmatter:
---
addons:
- slidev-addon-dmn
---Or in your package.json:
{
"slidev": {
"addons": ["slidev-addon-dmn"]
}
}This addon provides three complementary components for different use cases:
<DmnDrd>- Static DRD rendering for PDFs, presentations, and documentation<DmnTable>- Decision Table rendering for visualizing business rules<DmnModeler>- Interactive DMN modeler for live editing during workshops and trainings, with an optional Camunda properties panel
Renders Decision Requirements Diagrams as static SVG images. Perfect for PDF exports and presentations.
<DmnDrd
dmnFilePath="./my-decisions.dmn"
width="100%"
height="400px"
/>Props:
| Name | Type | Default | Description |
|---|---|---|---|
dmnFilePath |
string |
required | Path to the .dmn file (relative to public/) |
width |
string |
'100%' |
Maximum width of the diagram |
height |
string |
'auto' |
Height of the diagram |
fontSize |
string |
'12px' |
Font size of the diagram labels |
Renders DMN Decision Tables directly in the slide. Perfect for presenting business rules and decision logic.
<DmnTable
dmnFilePath="./my-decisions.dmn"
width="100%"
decisionId="Decision_Dish"
/>Props:
| Name | Type | Default | Description |
|---|---|---|---|
dmnFilePath |
string |
required | Path to the .dmn file (relative to public/) |
width |
string |
'100%' |
Width of the table container |
height |
string |
'auto' |
Height of the table container (defaults to 500px when 'auto') |
decisionId |
string |
first found | ID of the decision to display (optional, defaults to the first decision table) |
fontSize |
string |
'12px' |
Font size of the table content |
showAnnotations |
boolean |
false |
Show or hide the annotations column |
Embeds an interactive DMN modeler for live editing. A thumbnail of the DRD is shown in the slide; clicking Edit opens the model fullscreen where you can rearrange the DRD and double-click a decision to edit its table. On Close, any changes are reflected back in the slide thumbnail. Ideal for workshops, trainings, and collaborative sessions.
<DmnModeler
dmnFilePath="./my-decisions.dmn"
width="100%"
height="500px"
/>Or start with a blank canvas:
<DmnModeler height="500px" />Pass engine="camunda" to mount the Camunda properties panel side-by-side with the canvas, so you can edit ids, names, and Camunda-specific execution properties live:
<DmnModeler dmnFilePath="./my-decisions.dmn" engine="camunda" height="500px" />In fullscreen mode, the panel can be hidden and shown again via the toolbar β handy when you need the full canvas width.
Props:
| Name | Type | Default | Description |
|---|---|---|---|
dmnFilePath |
string |
β | Optional path to a .dmn file (relative to public/). Omit for a blank diagram. |
width |
string |
'100%' |
Width of the modeler container |
height |
string |
'500px' |
Height of the modeler container |
engine |
'camunda' |
β | Optional engine. Mounts a dmn-js-properties-panel configured for Camunda. Omit for a panel-less modeler. |
- File location: DMN files must be placed in the
public/folder - Supported formats: Standard DMN 1.3 XML files (exported from Camunda Modeler, bpmn.io, etc.)
- Multiple decisions: Use the
decisionIdprop to select a specific decision table when your DMN file contains multiple decisions - Styling: Use Tailwind classes via the
classprop to control sizing - Export: The
<DmnDrd>component works seamlessly with Slidev's PDF/PNG export features
Looking for BPMN? If you're modeling business processes alongside your decisions, check out slidev-addon-bpmn β the sister addon for rendering BPMN diagrams in Slidev!
Contributions are welcome! Feel free to report bugs, suggest features via issues, submit pull requests with improvements, or share your ideas and use cases.
To develop locally: clone the repo, run npm install, then npm run dev to test your changes.
- dmn-js by bpmn.io
- bavaria-ipsum - for making the example slide a little more entertaining π₯¨
