dmn-js-decision-table
Version:
A decision table view for dmn-js
41 lines (39 loc) • 1.39 kB
JavaScript
import InputDateEdit from './components/InputDateTimeEdit';
import OutputDateEdit from './components/OutputDateTimeEdit';
import { isInput, isOutput } from 'dmn-js-shared/lib/util/ModelUtil';
export default class SimpleDateEdit {
constructor(components, simpleMode) {
simpleMode.registerProvider(element => {
const typeRef = getTypeRef(element);
return (isInput(element.col) || isOutput(element.col)) && isDateTime(typeRef);
});
components.onGetComponent('context-menu', (context = {}) => {
if (context.contextMenuType && context.contextMenuType === 'simple-mode-edit') {
if (!context.element) {
return;
}
const typeRef = getTypeRef(context.element);
if (isDateTime(typeRef)) {
if (isInput(context.element.col)) {
return InputDateEdit;
} else if (isOutput(context.element.col)) {
return OutputDateEdit;
}
}
}
});
}
}
SimpleDateEdit.$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;
}
}
function isDateTime(typeRef) {
return typeRef === 'dateTime';
}
//# sourceMappingURL=SimpleDateTimeEdit.js.map