Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 1 addition & 1 deletion projects/typescript-vue/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -9,7 +9,7 @@
"preview": "vite preview"
},
"dependencies": {
"@process-analytics/bpmn-visualization-addons": "0.8.0",
"@process-analytics/bpmn-visualization-addons": "0.9.0",
"bpmn-visualization": "0.47.0",
"spectre.css": "~0.5.9",
"vue": "~3.5.20"
Expand Down
29 changes: 20 additions & 9 deletions projects/typescript-vue/src/app.vue
Original file line number Diff line number Diff line change
@@ -1,10 +1,17 @@
<script setup lang="ts">
import { onMounted, ref } from 'vue';
import { BpmnElement, BpmnElementsRegistry, BpmnVisualization, FitType, OverlayPosition } from 'bpmn-visualization';
import {
BpmnElement,
BpmnElementsRegistry,
BpmnVisualization,
FitOptions,
FitType,
OverlayPosition,
ShapeBpmnElementKind,
} from 'bpmn-visualization';
import { ShapeUtil } from '@process-analytics/bpmn-visualization-addons';
import pizzaDiagram from "./pizza-collaboration.bpmn?raw"


let vis: BpmnVisualization;
let registry: BpmnElementsRegistry;
const allFlowNodes = ref<BpmnElement[]>([]);
Expand All @@ -17,6 +24,8 @@ const nodeDropdown = ref<string>();
const overlayText = ref<string>('');
const overlayPosition = ref<OverlayPosition>('top-left');

const fitOptions: FitOptions = { type: FitType.Center, margin: 30 };

onMounted(async () => {
vis = new BpmnVisualization({
container: "bpmn-container",
Expand All @@ -29,7 +38,7 @@ onMounted(async () => {
});
// load the BPMN diagram defined above
vis.load(pizzaDiagram, {
fit: { type: FitType.Center, margin: 30 },
fit: fitOptions,
});
registry = vis.bpmnElementsRegistry;
allFlowNodes.value = getAllFlowNodes();
Expand All @@ -38,22 +47,24 @@ onMounted(async () => {
})

function getAllFlowNodes(): BpmnElement[] {
return registry.getElementsByKinds(ShapeUtil.flowNodeKinds().filter(kind => !ShapeUtil.isBpmnArtifact(kind)));
// cannot use the bpmn-visualization ShapeUtil.flowNodeKinds() for now, as it includes artifacts
return registry.getElementsByKinds(Object.values(ShapeBpmnElementKind).filter(kind => ShapeUtil.isFlowNode(kind)));
}

function setupEventHandlers() {
allFlowNodes.value.forEach(item => {
const currentId = item.bpmnSemantic.id;
item.htmlElement.onclick = () => {
const htmlElement = item.htmlElement;
htmlElement.onclick = () => {
setSelectedElement(currentId);
};
item.htmlElement.onmouseenter = (ev) => {
htmlElement.onmouseenter = (ev) => {
if (ev.buttons == 1) {
return;
}
registry.addCssClasses(currentId, 'highlightNode');
};
item.htmlElement.onmouseleave = () => {
htmlElement.onmouseleave = () => {
registry.removeCssClasses(currentId, 'highlightNode');
};
});
Expand Down Expand Up @@ -95,7 +106,7 @@ function changeDiagram(event: Event): void {
reader.onload = () => {
try {
vis.load(reader.result?.toString() ?? '', {
fit: { type: FitType.Center, margin: 30 }
fit: fitOptions
});
allFlowNodes.value = getAllFlowNodes()
setupEventHandlers();
Expand Down Expand Up @@ -188,7 +199,7 @@ function changeDiagram(event: Event): void {
d="M432 256c0 17.7-14.3 32-32 32L48 288c-17.7 0-32-14.3-32-32s14.3-32 32-32l352 0c17.7 0 32 14.3 32 32z" />
</svg>
</button>
<button class="mainButton" @click="vis.navigation.fit({ type: FitType.Center, margin: 30 })">
<button class="mainButton" @click="vis.navigation.fit(fitOptions)">
<span class="fit">Fit</span>
</button>
<button class="sideButton" style="border-radius: 0 20px 20px 0; float: right" @click="vis.graph.zoomIn()">
Expand Down