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.

204 lines
6.8 KiB

1 year ago
<template>
<div style="height: 100%">
<w-grid
ref="gridRef"
10 months ago
:title="$t('re.lib.tab.indicator.title')"
1 year ago
dense-body
hide-bottom
:config-button="true"
selection="multiple"
:checkbox-selection="false"
: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="[
10 months ago
{ colSpan: 2, name: 'code', label: $t('code'), type: 'text', clearable: true },
{ colSpan: 3, name: 'name', label: $t('name'), type: '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) },
{
width: 100,
name: 'valueType',
label: $t('valueType'),
format: (value, row) => {
return ValueTypeMap[value];
},
},
{ width: 80, name: 'valueTypeIsList', label: $t('re.resources.designer.parameter.grid.entity.valueTypeIsList'), format: Formater.checkTag() },
{ width: '100%', name: 'defaultValue', label: $t('defaultValue') },
]"
:editor="{
dialog: {
width: '600px',
},
form: {
colsNum: 1,
10 months ago
fields: [
{ name: 'name', label: $t('name'), type: 'text' },
{ name: 'type', label: $t('type'), type: 'select', options: Options.enum(Enums.IndicatorType) },
{
name: 'valueType',
label: $t('valueType'),
type: 'select',
options: [],
},
{ name: 'valueTypeIsList', label: $t('re.resources.designer.parameter.grid.entity.valueTypeIsList'), type: 'checkbox' },
{ name: 'defaultValue', label: $t('defaultValue'), type: 'text' },
{ name: 'order', label: $t('order'), type: 'number' },
],
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 { ref, useAttrs, onMounted } from 'vue';
10 months ago
import { axios, Environment, EnumTools, Formater, Options, DialogManager } from 'platform-core';
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();
const refresh = () => {
1 year ago
gridRef?.value?.refresh();
1 year ago
};
onMounted(() => {
1 year ago
gridRef?.value?.refresh();
1 year ago
});
defineExpose({
refresh,
});
const Enums = await EnumTools.fetch(['io.sc.engine.rule.core.enums.IndicatorType', 'io.sc.engine.rule.core.enums.DeployStatus']);
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 = [];
1 year ago
for (const item of response.data) {
ValueTypeMap[item.key] = item.value;
ValueTypeList.push({ value: item.key, label: item.value });
}
}
</script>