ruoyi-vue-nocode/ruoyi-ui/ruoyi-bpmnjs/resources/properties-panel/provider/activiti/parts/implementation/Script.js
2022-08-11 16:10:41 +08:00

174 lines
5.7 KiB
JavaScript

'use strict';
var domQuery = require('min-dom').query,
escapeHTML = require('../../../../Utils').escapeHTML,
utils = require('../../../../Utils');
function getScriptType(node) {
return utils.selectedType('select[name=scriptType]', node.parentElement);
}
module.exports = function(scriptLanguagePropName, scriptValuePropName, isFormatRequired, translate) {
return {
template:
'<div class="bpp-row bpp-textfield">' +
'<label for="cam-script-format">' + escapeHTML(translate('Script Format')) + '</label>' +
'<div class="bpp-field-wrapper">' +
'<input id="cam-script-format" type="text" name="scriptFormat" />' +
'<button class="clear" data-action="script.clearScriptFormat" data-show="script.canClearScriptFormat">' +
'<span>X</span>' +
'</button>' +
'</div>' +
'</div>' +
'<div class="bpp-row">' +
'<label for="cam-script-type">' + escapeHTML(translate('Script Type')) + '</label>' +
'<div class="bpp-field-wrapper">' +
'<select id="cam-script-type" name="scriptType" data-value>' +
'<option value="script" selected>' + escapeHTML(translate('Inline Script')) + '</option>' +
'<option value="scriptResource">' + escapeHTML(translate('External Resource')) + '</option>' +
'</select>' +
'</div>' +
'</div>' +
'<div class="bpp-row bpp-textfield">' +
'<label for="cam-script-resource-val" data-show="script.isScriptResource">' + escapeHTML(translate('Resource')) + '</label>' +
'<div class="bpp-field-wrapper" data-show="script.isScriptResource">' +
'<input id="cam-script-resource-val" type="text" name="scriptResourceValue" />' +
'<button class="clear" data-action="script.clearScriptResource" data-show="script.canClearScriptResource">' +
'<span>X</span>' +
'</button>' +
'</div>' +
'</div>' +
'<div class="bpp-row">' +
'<label for="cam-script-val" data-show="script.isScript">' + escapeHTML(translate('Script')) + '</label>' +
'<div class="bpp-field-wrapper" data-show="script.isScript">' +
'<textarea id="cam-script-val" type="text" name="scriptValue"></textarea>' +
'</div>'+
'</div>',
get: function(element, bo) {
var values = {};
// read values from xml:
var boScriptResource = bo.get('activiti:resource'),
boScript = bo.get(scriptValuePropName),
boScriptFormat = bo.get(scriptLanguagePropName);
if (typeof boScriptResource !== 'undefined') {
values.scriptResourceValue = boScriptResource;
values.scriptType = 'scriptResource';
} else {
values.scriptValue = boScript;
values.scriptType = 'script';
}
values.scriptFormat = boScriptFormat;
return values;
},
set: function(element, values, containerElement) {
var scriptFormat = values.scriptFormat,
scriptType = values.scriptType,
scriptResourceValue = values.scriptResourceValue,
scriptValue = values.scriptValue;
// init update
var update = {
'activiti:resource': undefined
};
update[scriptValuePropName] = undefined;
update[scriptLanguagePropName] = undefined;
if (isFormatRequired) {
// always set language
update[scriptLanguagePropName] = scriptFormat || '';
} else
// set language only when scriptFormat has a value
if (scriptFormat !== '') {
update[scriptLanguagePropName] = scriptFormat;
}
// set either inline script or resource
if ('scriptResource' === scriptType) {
update['activiti:resource'] = scriptResourceValue || '';
} else {
update[scriptValuePropName] = scriptValue || '';
}
return update;
},
validate: function(element, values) {
var validationResult = {};
if (values.scriptType === 'script' && !values.scriptValue) {
validationResult.scriptValue = translate('Must provide a value');
}
if (values.scriptType === 'scriptResource' && !values.scriptResourceValue) {
validationResult.scriptResourceValue = translate('Must provide a value');
}
if (isFormatRequired && (!values.scriptFormat || values.scriptFormat.length === 0)) {
validationResult.scriptFormat = translate('Must provide a value');
}
return validationResult;
},
clearScriptFormat: function(element, inputNode, btnNode, scopeNode) {
domQuery('input[name=scriptFormat]', scopeNode).value='';
return true;
},
canClearScriptFormat: function(element, inputNode, btnNode, scopeNode) {
var input = domQuery('input[name=scriptFormat]', scopeNode);
return input.value !== '';
},
clearScriptResource: function(element, inputNode, btnNode, scopeNode) {
domQuery('input[name=scriptResourceValue]', scopeNode).value='';
return true;
},
canClearScriptResource: function(element, inputNode, btnNode, scopeNode) {
var input = domQuery('input[name=scriptResourceValue]', scopeNode);
return input.value !== '';
},
clearScript: function(element, inputNode, btnNode, scopeNode) {
domQuery('textarea[name=scriptValue]', scopeNode).value='';
return true;
},
canClearScript: function(element, inputNode, btnNode, scopeNode) {
var input = domQuery('textarea[name=scriptValue]', scopeNode);
return input.value !== '';
},
isScriptResource: function(element, inputNode, btnNode, scopeNode) {
var scriptType = getScriptType(scopeNode);
return scriptType === 'scriptResource';
},
isScript: function(element, inputNode, btnNode, scopeNode) {
var scriptType = getScriptType(scopeNode);
return scriptType === 'script';
}
};
};