mirror of
https://github.com/status-im/spiff-arena.git
synced 2025-01-17 21:51:43 +00:00
118 lines
3.4 KiB
JavaScript
118 lines
3.4 KiB
JavaScript
const SPIFF_PARENT_PROP = 'spiffworkflow:properties';
|
|
const SPIFF_PROP = 'spiffworkflow:property';
|
|
const PREFIX = 'spiffworkflow:';
|
|
|
|
/**
|
|
*
|
|
* Spiff Extensions can show up in two distinct ways. The useProperties toggles between them
|
|
*
|
|
* 1. They might be a top level extension, such as a buisness rule, for example:
|
|
*
|
|
* <bpmn:extensionElements>
|
|
* <spiffworkflow:calledDecisionId>my_id</spiffworkflow:calledDecisionId>
|
|
* </bpmn:extensionElements>
|
|
*
|
|
* 2. Or the extension value may exist in a name/value pair inside a Spiffworkflow Properties extension. You would
|
|
* do this if you wanted to hide the values from the SpiffWorkflow enginge completely, and pass these values
|
|
* through unaltered to your actual application. For Example:
|
|
*
|
|
* <bpmn:extensionElements>
|
|
* <spiffworkflow:properties>
|
|
* <spiffworkflow:property name="formJsonSchemaFilename" value="json_schema.json" />
|
|
* </spiffworkflow:properties>
|
|
* </bpmn:extensionElements>
|
|
*
|
|
*
|
|
*/
|
|
|
|
|
|
/**
|
|
* Returns the string value of the spiff extension with the given name on the provided element. ""
|
|
* @param useProperties if set to true, will look inside extensions/spiffworkflow:properties otherwise, just
|
|
* looks for a spiffworkflow:[name] and returns that value inside of it.
|
|
* @param element
|
|
* @param name
|
|
*/
|
|
export function getExtensionValue(element, name) {
|
|
|
|
const useProperties = !name.startsWith(PREFIX);
|
|
let extension;
|
|
if (useProperties) {
|
|
extension = getExtensionProperty(element, name);
|
|
} else {
|
|
extension = getExtension(element, name);
|
|
}
|
|
if (extension) {
|
|
return extension.value;
|
|
}
|
|
return '';
|
|
}
|
|
|
|
export function setExtensionValue(element, name, value, moddle, commandStack) {
|
|
|
|
const useProperties = !name.startsWith(PREFIX)
|
|
const { businessObject } = element;
|
|
|
|
// Assure we have extensions
|
|
let extensions = businessObject.extensionElements;
|
|
if (!extensions) {
|
|
extensions = moddle.create('bpmn:ExtensionElements');
|
|
}
|
|
|
|
if (useProperties) {
|
|
let properties = getExtension(element, SPIFF_PARENT_PROP);
|
|
let property = getExtensionProperty(element, name);
|
|
if (!properties) {
|
|
properties = moddle.create(SPIFF_PARENT_PROP);
|
|
extensions.get('values').push(properties);
|
|
}
|
|
if (!property) {
|
|
property = moddle.create(SPIFF_PROP);
|
|
properties.get('properties').push(property);
|
|
}
|
|
property.value = value;
|
|
property.name = name;
|
|
} else {
|
|
let extension = getExtension(element, name);
|
|
if (!extension) {
|
|
extension = moddle.create(name);
|
|
extensions.get('values').push(extension)
|
|
}
|
|
extension.value = value;
|
|
}
|
|
|
|
commandStack.execute('element.updateModdleProperties', {
|
|
element,
|
|
moddleElement: businessObject,
|
|
properties: {
|
|
extensionElements: extensions,
|
|
},
|
|
});
|
|
}
|
|
|
|
function getExtension(element, name) {
|
|
const bizObj = element.businessObject;
|
|
if (!bizObj.extensionElements) {
|
|
return null;
|
|
}
|
|
const extensionElements = bizObj.extensionElements.get('values');
|
|
return extensionElements.filter(function (extensionElement) {
|
|
if (extensionElement.$instanceOf(name)) {
|
|
return true;
|
|
}
|
|
})[0];
|
|
}
|
|
|
|
|
|
function getExtensionProperty(element, name) {
|
|
const parentElement = getExtension(element, SPIFF_PARENT_PROP);
|
|
if (parentElement) {
|
|
return parentElement.get('properties').filter(function (propertyElement) {
|
|
return (
|
|
propertyElement.$instanceOf(SPIFF_PROP) && propertyElement.name === name
|
|
);
|
|
})[0];
|
|
}
|
|
return null;
|
|
}
|