You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

311 lines
11 KiB

1 year ago
<template>
<div style="height: 100%">
<w-grid
ref="gridRef"
10 months ago
:title="$t('re.lib.tab.indicator.title')"
draggable="server"
10 months ago
dense
1 year ago
hide-bottom
10 months ago
db-click-operation="edit"
1 year ago
:config-button="true"
selection="multiple"
10 months ago
:checkbox-selection="true"
1 year ago
:tree="false"
:fetch-data-url="Environment.apiContextPath('api/re/indicator?lib=' + lib.id)"
:data-url="Environment.apiContextPath('api/re/indicator')"
:pageable="false"
:toolbar-configure="{ noIcon: false }"
:toolbar-actions="[
'query',
'refresh',
'separator',
[
{
name: 'addGroup',
label: $t('re.lib.grid.toolbar.addGroup'),
icon: 'add',
10 months ago
enableIf: (arg) => {
return !readOnly;
},
1 year ago
click: undefined,
},
{
extend: 'add',
name: 'addInterface',
10 months ago
label: $t('re.indicator.grid.toolbar.addInterface'),
1 year ago
afterClick: (arg) => {
10 months ago
arg.grid.getEditorForm().setFieldValue('type', 'INTERFACE');
1 year ago
},
},
{
extend: 'add',
name: 'addIndicator',
10 months ago
label: $t('re.indicator.grid.toolbar.addIndicator'),
1 year ago
afterClick: (arg) => {
10 months ago
arg.grid.getEditorForm().setFieldValue('type', 'INDICATOR');
1 year ago
},
},
],
[
{
name: 'cloneGroup',
label: $t('re.lib.grid.toolbar.cloneGroup'),
icon: 'content_copy',
click: undefined,
enableIf: (arg) => {
10 months ago
return !readOnly && arg.selected;
1 year ago
},
},
'clone',
{
extend: 'deepClone',
name: 'deepClone',
label: $t('re.lib.grid.toolbar.deepClone'),
icon: 'bi-copy',
enableIf: (arg) => {
10 months ago
return !readOnly && arg.selected;
1 year ago
},
click: (arg) => {
DialogManager.confirm($t('re.lib.grid.toolbar.deepClone.tip'), () => {
axios.post(Environment.apiContextPath('/api/re/lib/deepClone/' + arg.selected.id)).then(() => {
libTreeGridRef.refresh();
});
});
},
},
],
'separator',
10 months ago
{
extend: 'edit',
enableIf: (arg) => {
return !readOnly && arg.selected;
},
},
{
extend: 'remove',
enableIf: (arg) => {
return !readOnly && arg.selected;
},
},
1 year ago
'separator',
'view',
'separator',
'export',
]"
10 months ago
:query-form-cols-num="6"
1 year ago
:query-form-fields="[
8 months ago
{ colSpan: 2, name: 'code', label: $t('code'), type: 'w-text', clearable: true },
{ colSpan: 3, name: 'name', label: $t('name'), type: 'w-text', clearable: true },
1 year ago
]"
:columns="[
{ width: 60, name: 'order', label: $t('order'), align: 'right' },
{ width: 250, name: 'name', label: $t('name') },
{ width: 100, name: 'type', label: $t('type'), format: Formater.enum(Enums.IndicatorType) },
{
10 months ago
width: 200,
1 year ago
name: 'valueType',
label: $t('valueType'),
format: (value, row) => {
10 months ago
if (row.valueTypeVersion) {
return ValueTypeMap[value] + ' (V' + row.valueTypeVersion + ')';
}
if (row.valueType == 'java.math.BigDecimal') {
if (row.valueRoundingMode == 'HALF_UP') {
return ValueTypeMap[value] + '(' + row.valueScale + ')';
} else {
return ValueTypeMap[value] + '(' + row.valueScale + ',' + Formater.enum(Enums.RoundingMode)(row.valueRoundingMode) + ')';
}
}
var result = ValueTypeMap[value];
result = result || row.valueType;
if (result) {
result = result.replace('<', '&lt;');
result = result.replace('>', '&gt;');
}
return result;
1 year ago
},
},
9 months ago
{ width: 90, name: 'valueTypeIsList', label: $t('re.resources.designer.parameter.grid.entity.valueTypeIsList'), format: Formater.checkTag() },
{ width: 100, name: 'defaultValue', label: $t('defaultValue') },
1 year ago
]"
:editor="{
dialog: {
width: '600px',
},
form: {
colsNum: 1,
10 months ago
fields: [
8 months ago
{ name: 'lib', label: $t('lib'), type: 'w-text', defaultValue: lib.id, showIf: false },
8 months ago
{ name: 'name', label: $t('name'), type: 'w-text' },
{ name: 'type', label: $t('type'), type: 'w-select', options: Options.enum(Enums.IndicatorType) },
10 months ago
{
name: 'valueType',
10 months ago
label: $t('re.resources.designer.parameter.grid.entity.valueType'),
8 months ago
type: 'w-select',
10 months ago
options: ValueTypeList,
'onUpdate:modelValue': (value) => {
axios.get(Environment.apiContextPath('/api/re/dictionary/getVersionsByCode?code=' + value)).then((response) => {
const data = response.data;
const options = [];
8 months ago
data.forEach((item) => {
10 months ago
options.push({ label: item.key, value: item.value });
8 months ago
});
10 months ago
valueTypeVersionRef = options;
});
},
},
{
name: 'valueTypeVersion',
label: $t('re.resources.designer.parameter.grid.entity.valueTypeVersion'),
8 months ago
type: 'w-select',
10 months ago
options: valueTypeVersionRef,
showIf: (arg) => {
const valueType = arg.form.getFieldValue('valueType');
if (valueType) {
if (
valueType == 'java.lang.Boolean' ||
valueType == 'java.lang.Long' ||
valueType == 'java.lang.Float' ||
valueType == 'Float' ||
valueType == 'java.math.BigDecimal' ||
valueType == 'java.lang.String' ||
valueType == 'java.util.Date' ||
valueType == 'io.sc.engine.rule.core.classes.ResourceAbstract' ||
valueType == 'io.sc.engine.rule.core.classes.RuleResult' ||
valueType == 'io.sc.engine.rule.core.classes.SingleRuleResult' ||
valueType.startsWith('List') ||
valueType.startsWith('Map')
) {
return false;
} else if (Tools.isUndefinedOrNull(ValueTypeMap[valueType])) {
return false;
} else {
return true;
}
}
return false;
},
},
{
name: 'valueScale',
label: $t('re.resources.designer.parameter.grid.entity.valueScale'),
8 months ago
type: 'w-number',
10 months ago
defaultValue: 6,
10 months ago
showIf: (arg) => {
const valueType = arg.form.getFieldValue('valueType');
const type = arg.form.getFieldValue('type');
if (valueType == 'java.math.BigDecimal' && type === 'INDICATOR') {
return true;
}
return false;
},
},
{
name: 'valueRoundingMode',
label: $t('re.resources.designer.parameter.grid.entity.valueRoundingMode'),
8 months ago
type: 'w-select',
10 months ago
options: Options.enum(Enums.RoundingMode),
10 months ago
defaultValue: 'HALF_UP',
10 months ago
showIf: (arg) => {
const valueType = arg.form.getFieldValue('valueType');
const type = arg.form.getFieldValue('type');
if (valueType == 'java.math.BigDecimal' && type === 'INDICATOR') {
return true;
}
return false;
},
},
{
name: 'valueTypeIsList',
label: $t('re.resources.designer.parameter.grid.entity.valueTypeIsList'),
8 months ago
type: 'w-checkbox',
10 months ago
defaultValue: false,
10 months ago
},
10 months ago
{
name: 'defaultValue',
label: $t('defaultValue'),
8 months ago
type: 'w-text',
10 months ago
},
8 months ago
{ name: 'order', label: $t('order'), type: 'w-number' },
10 months ago
],
1 year ago
},
}"
:viewer="{
panel: {
columnNum: 1,
fields: [
10 months ago
{ name: 'order', label: $t('order') },
{ name: 'id', label: $t('id') },
{ name: 'lib', label: $t('lib') },
{ name: 'type', label: $t('type') },
{ name: 'code', label: $t('code') },
{ name: 'name', label: $t('name') },
{ name: 'description', label: $t('description') },
{ name: 'valueType', label: $t('re.resources.designer.parameter.grid.entity.valueType') },
{ name: 'valueTypeVersion', label: $t('re.resources.designer.parameter.grid.entity.valueTypeVersion') },
{ name: 'valueScale', label: $t('re.resources.designer.parameter.grid.entity.valueScale') },
{ name: 'valueRoundingMode', label: $t('re.resources.designer.parameter.grid.entity.valueRoundingMode') },
{ name: 'valueTypeIsList', label: $t('re.resources.designer.parameter.grid.entity.valueTypeIsList') },
{ name: 'defaultValue', label: $t('defaultValue') },
1 year ago
{ name: 'dataComeFrom', label: $t('dataComeFrom') },
{ name: 'creator', label: $t('creator') },
{ name: 'createDate', label: $t('createDate') },
{ name: 'lastModifier', label: $t('lastModifier') },
{ name: 'lastModifyDate', label: $t('lastModifyDate'), format: Formater.none() },
],
},
}"
v-bind="attrs"
></w-grid>
<ImportDialog ref="importDialogRef"></ImportDialog>
</div>
</template>
<script setup lang="ts">
import 'tailwindcss/utilities.css';
1 year ago
import { ref, useAttrs, onMounted } from 'vue';
10 months ago
import { axios, Environment, EnumTools, Formater, Options, DialogManager, Tools } from 'platform-core';
import { IndicatorManager } from '@/views/shared/IndicatorManager';
1 year ago
import ImportDialog from './ImportDialog.vue';
const attrs = useAttrs();
const props = defineProps({
lib: { type: Object, default: undefined },
10 months ago
readOnly: { type: Boolean, default: false },
1 year ago
});
const gridRef = ref();
10 months ago
const valueTypeVersionRef = ref();
1 year ago
const refresh = () => {
1 year ago
gridRef?.value?.refresh();
1 year ago
};
onMounted(() => {
1 year ago
gridRef?.value?.refresh();
1 year ago
});
defineExpose({
refresh,
});
10 months ago
const Enums = await EnumTools.fetch([
'io.sc.engine.rule.core.enums.IndicatorType',
'io.sc.engine.rule.core.enums.DeployStatus',
'io.sc.platform.core.enums.RoundingMode',
]);
1 year ago
let ValueTypeMap = {};
1 year ago
let ValueTypeList = [];
1 year ago
const response = await axios.get(Environment.apiContextPath('/api/re/dictionary/getAllDictionaryMap'));
if (response && response.data) {
ValueTypeMap = {};
1 year ago
ValueTypeList = [];
8 months ago
response.data.forEach((item) => {
1 year ago
ValueTypeMap[item.key] = item.value;
ValueTypeList.push({ value: item.key, label: item.value });
8 months ago
});
1 year ago
}
</script>