dmn-js-decision-table
Version:
A decision table view for dmn-js
42 lines (40 loc) • 1.45 kB
JavaScript
import InputNumberEdit from './components/InputNumberEdit';
import OutputNumberEdit from './components/OutputNumberEdit';
import { isInput, isOutput } from 'dmn-js-shared/lib/util/ModelUtil';
export default class SimpleNumberEdit {
constructor(components, simpleMode) {
simpleMode.registerProvider(element => {
const typeRef = getTypeRef(element);
return (isInput(element.col) || isOutput(element.col)) && isNumber(typeRef);
});
components.onGetComponent('context-menu', (context = {}) => {
if (context.contextMenuType && context.contextMenuType === 'simple-mode-edit') {
if (!context.element) {
return;
}
const typeRef = getTypeRef(context.element);
if (isNumber(typeRef)) {
if (isInput(context.element.col)) {
return InputNumberEdit;
} else if (isOutput(context.element.col)) {
return OutputNumberEdit;
}
}
}
});
}
}
SimpleNumberEdit.$inject = ['components', 'simpleMode'];
// helpers //////////////////////
function getTypeRef(element) {
if (isInput(element.col)) {
return element.col && element.col.businessObject.inputExpression.typeRef;
} else {
return element.col && element.col.businessObject.typeRef;
}
}
const numberTypes = ['number', 'integer', 'long', 'double'];
function isNumber(typeRef) {
return numberTypes.includes(typeRef);
}
//# sourceMappingURL=SimpleNumberEdit.js.map