2021-11-17 09:25:56 +00:00
|
|
|
import { domify, classes } from 'min-dom';
|
2021-10-18 08:28:36 +00:00
|
|
|
|
|
|
|
import { escapeHTML } from 'diagram-js/lib/util/EscapeUtil';
|
|
|
|
import { getBusinessObject, is } from '../../util/ModelUtil';
|
2021-12-15 09:09:57 +00:00
|
|
|
import { planeId } from '../../util/DrilldownUtil';
|
2021-10-18 08:28:36 +00:00
|
|
|
|
2021-11-17 09:25:56 +00:00
|
|
|
var OPEN_CLASS = 'bjs-breadcrumbs-shown';
|
|
|
|
|
2021-12-10 10:29:03 +00:00
|
|
|
|
2021-11-03 09:29:54 +00:00
|
|
|
/**
|
|
|
|
* Adds Overlays that allow switching planes on collapsed subprocesses.
|
|
|
|
*
|
|
|
|
* @param {eventBus} eventBus
|
|
|
|
* @param {elementRegistry} elementRegistry
|
|
|
|
* @param {overlays} overlays
|
|
|
|
* @param {canvas} canvas
|
|
|
|
*/
|
2021-12-15 09:09:57 +00:00
|
|
|
export default function DrilldownBreadcrumbs(eventBus, elementRegistry, overlays, canvas) {
|
2021-11-17 09:25:56 +00:00
|
|
|
var breadcrumbs = domify('<ul class="bjs-breadcrumbs"></ul>');
|
2021-10-18 08:28:36 +00:00
|
|
|
var container = canvas.getContainer();
|
2021-11-17 09:25:56 +00:00
|
|
|
var containerClasses = classes(container);
|
2021-10-18 08:28:36 +00:00
|
|
|
container.appendChild(breadcrumbs);
|
|
|
|
|
2021-12-09 23:31:00 +00:00
|
|
|
function updateBreadcrumbs(element) {
|
|
|
|
var parents = getParentChain(element);
|
2021-10-18 08:28:36 +00:00
|
|
|
|
|
|
|
var path = parents.map(function(el) {
|
2021-11-03 09:29:54 +00:00
|
|
|
var title = escapeHTML(el.name || el.id);
|
|
|
|
var link = domify('<li><span class="bjs-crumb"><a title="' + title + '">' + title + '</a></span></li>');
|
2021-10-18 08:28:36 +00:00
|
|
|
|
|
|
|
link.addEventListener('click', function() {
|
2021-12-09 23:31:00 +00:00
|
|
|
canvas.setRootElement(canvas.findRoot(planeId(el)) || canvas.findRoot(el.id));
|
2021-10-18 08:28:36 +00:00
|
|
|
});
|
|
|
|
|
|
|
|
return link;
|
|
|
|
});
|
|
|
|
|
|
|
|
breadcrumbs.innerHTML = '';
|
|
|
|
|
2021-11-17 09:25:56 +00:00
|
|
|
// show breadcrumbs and expose state to .djs-container
|
|
|
|
var visible = path.length > 1;
|
|
|
|
containerClasses.toggle(OPEN_CLASS, visible);
|
2021-10-18 08:28:36 +00:00
|
|
|
|
|
|
|
path.forEach(function(el) {
|
|
|
|
breadcrumbs.appendChild(el);
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
2021-12-09 23:31:00 +00:00
|
|
|
eventBus.on('root.set', function(event) {
|
|
|
|
updateBreadcrumbs(event.element);
|
2021-10-18 08:28:36 +00:00
|
|
|
});
|
|
|
|
|
|
|
|
}
|
|
|
|
|
2021-12-15 09:09:57 +00:00
|
|
|
DrilldownBreadcrumbs.$inject = [ 'eventBus', 'elementRegistry', 'overlays', 'canvas' ];
|
2021-10-18 08:28:36 +00:00
|
|
|
|
|
|
|
|
2021-11-03 09:29:54 +00:00
|
|
|
// helpers
|
2021-12-09 23:31:00 +00:00
|
|
|
function getParentChain(child) {
|
2021-10-18 08:28:36 +00:00
|
|
|
var bo = getBusinessObject(child);
|
|
|
|
|
|
|
|
var parents = [];
|
|
|
|
|
|
|
|
for (var element = bo; element; element = element.$parent) {
|
|
|
|
if (is(element, 'bpmn:SubProcess') || is(element, 'bpmn:Process')) {
|
|
|
|
parents.push(element);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return parents.reverse();
|
2021-12-09 23:31:00 +00:00
|
|
|
}
|