2022-10-12 10:21:19 -04:00
|
|
|
import {useService } from 'bpmn-js-properties-panel';
|
|
|
|
import { SelectEntry } from '@bpmn-io/properties-panel';
|
2022-11-24 14:59:09 -05:00
|
|
|
import {findDataObjects, idToHumanReadableName} from '../DataObjectHelpers';
|
2022-10-12 10:21:19 -04:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Finds the value of the given type within the extensionElements
|
|
|
|
* given a type of "spiff:preScript", would find it in this, and return
|
|
|
|
* the object.
|
|
|
|
*
|
|
|
|
* <bpmn:
|
|
|
|
<bpmn:userTask id="123" name="My User Task!">
|
|
|
|
<bpmn:extensionElements>
|
|
|
|
<spiffworkflow:preScript>
|
|
|
|
me = "100% awesome"
|
|
|
|
</spiffworkflow:preScript>
|
|
|
|
</bpmn:extensionElements>
|
|
|
|
...
|
|
|
|
</bpmn:userTask>
|
|
|
|
*
|
|
|
|
* @returns {string|null|*}
|
|
|
|
*/
|
|
|
|
export function DataObjectSelect(props) {
|
|
|
|
const element = props.element;
|
|
|
|
const commandStack = props.commandStack;
|
|
|
|
const debounce = useService('debounceInput');
|
|
|
|
|
|
|
|
|
|
|
|
const getValue = () => {
|
|
|
|
return element.businessObject.dataObjectRef.id
|
|
|
|
}
|
|
|
|
|
|
|
|
const setValue = value => {
|
|
|
|
const businessObject = element.businessObject;
|
|
|
|
for (const flowElem of businessObject.$parent.flowElements) {
|
|
|
|
if (flowElem.$type === 'bpmn:DataObject' && flowElem.id === value) {
|
|
|
|
commandStack.execute('element.updateModdleProperties', {
|
|
|
|
element,
|
|
|
|
moddleElement: businessObject,
|
|
|
|
properties: {
|
|
|
|
dataObjectRef: flowElem
|
|
|
|
}
|
|
|
|
});
|
|
|
|
commandStack.execute('element.updateProperties', {
|
|
|
|
element,
|
|
|
|
moddleElement: businessObject,
|
|
|
|
properties: {
|
2022-11-17 14:58:28 -05:00
|
|
|
'name': idToHumanReadableName(flowElem.id)
|
2022-10-12 10:21:19 -04:00
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
const getOptions = value => {
|
|
|
|
const businessObject = element.businessObject;
|
|
|
|
const parent = businessObject.$parent;
|
2022-11-24 14:59:09 -05:00
|
|
|
let dataObjects = findDataObjects(parent);
|
|
|
|
let options = [];
|
|
|
|
dataObjects.forEach(dataObj => {
|
|
|
|
options.push({label: dataObj.id, value: dataObj.id})
|
|
|
|
});
|
|
|
|
return options;
|
2022-10-12 10:21:19 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
return <SelectEntry
|
|
|
|
id={'selectDataObject'}
|
|
|
|
element={element}
|
|
|
|
description={"Select the Data Object this represents."}
|
|
|
|
label={"Which Data Object does this reference?"}
|
|
|
|
getValue={ getValue }
|
|
|
|
setValue={ setValue }
|
|
|
|
getOptions={ getOptions }
|
|
|
|
debounce={debounce}
|
|
|
|
/>;
|
|
|
|
|
|
|
|
}
|