fix:(规则引擎版本)

master
zhang xu 2024-05-08 17:09:12 +08:00
parent 57f894455d
commit 654025f3c3
2 changed files with 660 additions and 68 deletions

View File

@ -122,14 +122,14 @@
<!-- @click="testMethod(scope.row)"-->
<!-- >调用测试</el-button>-->
<el-button type="primary" @click="testMethod(scope.row)"></el-button>
<!-- <el-button-->
<!-- size="mini"-->
<!-- type="text"-->
<!-- icon="el-icon-takeaway-box"-->
<!-- @click="toEngineVersion(scope.row)"-->
<!-- v-hasPermi="['system:engine:edit']"-->
<!-- >规则维护</el-button>-->
<el-button type="primary" @click="toEngineVersion(scope.row)"></el-button>
<el-button
size="mini"
type="text"
icon="el-icon-takeaway-box"
@click="toEngineVersion(scope.row)"
v-hasPermi="['system:engine:edit']"
>规则维护</el-button>
<!-- <el-button type="primary" @click="toEngineVersion(scope.row)"></el-button>-->
<el-button
size="mini"
type="text"
@ -243,18 +243,18 @@
<!--dummy dialog-->
<el-dialog title="提示" :visible.sync="dialogVisible" width="30%" :before-close="handleClose">
<el-card style="height: 90%">
<div slot="header" class="clearfix">
<span>{{ruleEngineInfo.name}}</span>
<el-button @click="updRuleEngine(ruleEngineInfo)" style="float: right;" type="primary">保存</el-button>
</div>
<div class="text item">
<encoding ref="encoding" style="height: 800px" :modification="modification" :value="ruleEngineInfo.codeText"></encoding>
</div>
</el-card>
<!-- <el-dialog title="提示" :visible.sync="dialogVisible" width="30%" :before-close="handleClose">-->
<!-- <el-card style="height: 90%">-->
<!-- <div slot="header" class="clearfix">-->
<!-- <span>{{ruleEngineInfo.name}}</span>-->
<!-- <el-button @click="updRuleEngine(ruleEngineInfo)" style="float: right;" type="primary">保存</el-button>-->
<!-- </div>-->
<!-- <div class="text item">-->
<!-- <encoding ref="encoding" style="height: 800px" :modification="modification" :value="ruleEngineInfo.codeText"></encoding>-->
<!-- </div>-->
<!-- </el-card>-->
</el-dialog>
<!-- </el-dialog>-->
</div>
</template>
@ -350,15 +350,18 @@ export default {
},
methods: {
updRuleEngine(ruleEngineInfo){
this.modification = parseInt(ruleEngineInfo.id)
setTimeout(() => {
this.modification = null
this.dialogVisible = false
},50)
toEngineVersion(row){
this.$router.push({ path: `/ruleEngine/engineVersion/${row.id}`});
},
// updRuleEngine(ruleEngineInfo){
// this.modification = parseInt(ruleEngineInfo.id)
// setTimeout(() => {
// this.modification = null
// this.dialogVisible = false
// },50)
// },
handleClose(done) {
@ -399,14 +402,14 @@ export default {
}
})
},
toEngineVersion(row){
getMaintenance(row.id).then(res => {
this.ruleEngineInfo = res.data
console.log(this.ruleEngineInfo)
})
this.dialogVisible=true
},
// toEngineVersion(row){
// getMaintenance(row.id).then(res => {
// this.ruleEngineInfo = res.data
// console.log(this.ruleEngineInfo)
// })
// this.dialogVisible=true
//
// },
/** 查询规则引擎列表 */
getList() {
this.loading = true;

View File

@ -1,67 +1,656 @@
<template>
<div>
<el-card style="height: 90%">
<div class="app-container">
<el-descriptions class="margin-top" :title="ruleEngineInfo.name" :column="3" border>
<template slot="extra">
<el-dropdown split-button type="primary" @command="handleClick">
更多操作
<el-dropdown-menu slot="dropdown">
<el-dropdown-item command="add">版本添加</el-dropdown-item>
<el-dropdown-item command="activate">{{(ruleEngineInfo.isActivate === 'no-activate' ? "激活": "禁用")+'引擎'}}</el-dropdown-item>
<el-dropdown-item command="status">{{(ruleEngineInfo.status === '0' ? "关闭": "开启")+'引擎'}}</el-dropdown-item>
</el-dropdown-menu>
</el-dropdown>
</template>
<el-descriptions-item label="规则名称"> {{ruleEngineInfo.name}} </el-descriptions-item>
<el-descriptions-item label="规则类型">
<dict-tag :options="dict.type.rule_engine_type" :value="ruleEngineInfo.type"/>
</el-descriptions-item>
<el-descriptions-item label="规则作用域">
<dict-tag :options="dict.type.rule_engine_level" :value="ruleEngineInfo.level"/>
</el-descriptions-item>
<el-descriptions-item label="引擎编码"> {{ruleEngineInfo.code + " ("+ruleEngineInfo.engineCode+")"}} </el-descriptions-item>
<el-descriptions-item label="是否激活">
<dict-tag :options="dict.type.rule_engine_activate_status" :value="ruleEngineInfo.isActivate"/>
</el-descriptions-item>
<el-descriptions-item label="规则状态">
<dict-tag :options="dict.type.sys_normal_disable" :value="ruleEngineInfo.status"/>
</el-descriptions-item>
</el-descriptions>
<editor style="margin-top: 20px" :read-only="true" v-model="ruleEngineInfo.description"></editor>
<el-card class="box-card">
<div slot="header" class="clearfix">
<span>{{ruleEngineInfo.name}}</span>
<el-button @click="dialogVisible = true" style="float: right;" type="primary">保存</el-button>
</div>
<div class="text item">
<encoding ref="encoding" style="height: 800px" :modification="modification" :value="ruleEngineInfo.codeText"></encoding>
<span>规则引擎版本</span>
</div>
<el-row :gutter="20">
<el-col :span="12" v-for="ruleEngineVersion in ruleEngineInfo.ruleEngineVersionList">
<el-card class="box-card">
<div slot="header" class="clearfix">
<span>{{ruleEngineVersion.name + "-" + ruleEngineVersion.code}}</span>
<el-dropdown style="float: right; padding: 3px 0" @command="checkRuleEngineVersion">
<span class="el-dropdown-link">
更多操作<i class="el-icon-arrow-down el-icon--right"></i>
</span>
<el-dropdown-menu slot="dropdown">
<el-dropdown-item :command="{event: 'info', ruleEngineVersion: ruleEngineVersion}">规则详情</el-dropdown-item>
<el-dropdown-item :command="{event: 'test', ruleEngineVersion: ruleEngineVersion}"
:disabled="ruleEngineVersion.status === '0'"
>测试规则</el-dropdown-item>
<el-dropdown-item :command="{event: 'status', ruleEngineVersion: ruleEngineVersion}" :disabled="ruleEngineVersion.status !== '2'">
{{ruleEngineVersion.isActivate !== 'no-activate' ? "禁用" : "激活"}}规则
</el-dropdown-item>
<el-dropdown-item
:command="{event: 'publish', ruleEngineVersion: ruleEngineVersion}"
v-if="ruleEngineVersion.status === '1' && ruleEngineVersion.isTest === '1'">
发布规则
</el-dropdown-item>
</el-dropdown-menu>
</el-dropdown>
</div>
<el-descriptions class="margin-top" :column="2" border>
<el-descriptions-item label="版本类" :span="2"> {{ruleEngineVersion.versionCode}} </el-descriptions-item>
<el-descriptions-item label="版本名称"> {{ruleEngineVersion.name}} </el-descriptions-item>
<el-descriptions-item label="版本CODE"> {{ruleEngineVersion.code}} </el-descriptions-item>
<el-descriptions-item label="是否激活">
<dict-tag :options="dict.type.rule_engine_activate_status" :value="ruleEngineVersion.isActivate"/>
</el-descriptions-item>
<el-descriptions-item label="版本状态">
<dict-tag :options="dict.type.rule_engine_version_status" :value="ruleEngineVersion.status"/>
</el-descriptions-item>
<el-descriptions-item label="是否测试">
<dict-tag :options="dict.type.rule_engine_activate_is_test" :value="ruleEngineVersion.isTest"/>
</el-descriptions-item>
</el-descriptions>
<editor style="margin-top: 10px" :read-only="true" v-model="ruleEngineVersion.description"></editor>
</el-card>
</el-col>
</el-row>
</el-card>
<el-dialog
title="提示"
:visible.sync="dialogVisible"
width="20%">
<span style="font-size: 16px;align-content: center">确认保存吗?</span>
<span slot="footer" class="dialog-footer">
<el-button @click="dialogVisible = false"> </el-button>
<el-button type="primary" @click="updRuleEngine"> </el-button>
</span>
</el-dialog>
title="新增版本" :visible.sync="addVersionStatus"
width="75%">
<el-card class="box-card">
<div slot="header" class="clearfix">
<span>基本信息</span>
<el-button style="float: right; padding: 3px 0" type="text" @click="genEngineVersion"></el-button>
</div>
<el-form :label-position="engineVersionForm" label-width="80px" :model="engineVersionForm">
<el-row>
<el-col :span="24">
<el-form-item label="版本类">
<el-input v-model="engineVersionForm.versionCode" disabled placeholder="点击类生成自动生成类名称"></el-input>
</el-form-item>
</el-col>
</el-row>
<el-row>
<el-col :span="12">
<el-form-item label="名称">
<el-input v-model="engineVersionForm.name"></el-input>
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="编码">
<el-input v-model="engineVersionForm.code"></el-input>
</el-form-item>
</el-col>
</el-row>
<el-row>
<el-col :span="12">
<el-form-item label="状态">
<dict-tag :options="dict.type.rule_engine_version_status" :value="engineVersionForm.status"/>
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="是否激活">
<dict-tag :options="dict.type.rule_engine_activate_status" :value="engineVersionForm.isActivate"/>
</el-form-item>
</el-col>
</el-row>
</el-form>
<editor v-model="engineVersionForm.description" :min-height="150"/>
</el-card>
<el-card class="box-card" v-if="engineVersionForm.codeIng != null">
<div slot="header" class="clearfix">
<span>引擎编码</span>
</div>
<encoding style="height: 800px" v-model="engineVersionForm.codeIng"></encoding>
</el-card>
<span slot="footer" class="dialog-footer">
<el-button @click="addVersionCancel"> </el-button>
<el-button type="primary" @click="addVersionSubmission"> </el-button>
</span>
</el-dialog>
<el-drawer
title="规则版本详情" size="80%" :before-close="ruleEngineVersionInfoStatusClose"
:visible.sync="ruleEngineVersionInfoStatus"
:direction="'rtl'">
<div class="app-container">
<el-descriptions v-if="ruleEngineVersionInfoAndTest != null" class="margin-top" :column="2" border>
<el-descriptions-item label="版本类" :span="2"> {{ruleEngineVersionInfoAndTest.versionCode}} </el-descriptions-item>
<el-descriptions-item label="版本名称"> {{ruleEngineVersionInfoAndTest.name}} </el-descriptions-item>
<el-descriptions-item label="版本CODE"> {{ruleEngineVersionInfoAndTest.code}} </el-descriptions-item>
<el-descriptions-item label="是否激活">
<dict-tag :options="dict.type.rule_engine_activate_status" :value="ruleEngineVersionInfoAndTest.isActivate"/>
</el-descriptions-item>
<el-descriptions-item label="版本状态">
<dict-tag :options="dict.type.rule_engine_version_status" :value="ruleEngineVersionInfoAndTest.status"/>
</el-descriptions-item>
<el-descriptions-item label="是否测试">
<dict-tag :options="dict.type.rule_engine_activate_is_test" :value="ruleEngineVersionInfoAndTest.isTest"/>
</el-descriptions-item>
</el-descriptions>
<editor style="margin-top: 10px" :read-only="true" :min-height="100" v-model="ruleEngineVersionInfoAndTest.description"></editor>
<el-row style="margin-top: 10px">
<el-button @click="saveCoding"></el-button>
</el-row>
<encoding style="height: 800px; margin-top: 20px" v-model="ruleEngineVersionInfoAndTest.codeIng"></encoding>
</div>
</el-drawer>
<el-drawer
title="规则版本测试" size="80%" :before-close="ruleEngineVersionTestStatusClose"
:visible.sync="ruleEngineVersionTestStatus"
:direction="'rtl'">
<el-row :gutter="20">
<el-col :span="12">
<el-descriptions v-if="ruleEngineVersionInfoAndTest != null" class="margin-top" :column="2" border>
<el-descriptions-item label="版本类" :span="2"> {{ruleEngineVersionInfoAndTest.versionCode}} </el-descriptions-item>
<el-descriptions-item label="版本名称"> {{ruleEngineVersionInfoAndTest.name}} </el-descriptions-item>
<el-descriptions-item label="版本CODE"> {{ruleEngineVersionInfoAndTest.code}} </el-descriptions-item>
<el-descriptions-item label="是否激活">
<dict-tag :options="dict.type.rule_engine_activate_status" :value="ruleEngineVersionInfoAndTest.isActivate"/>
</el-descriptions-item>
<el-descriptions-item label="版本状态">
<dict-tag :options="dict.type.rule_engine_version_status" :value="ruleEngineVersionInfoAndTest.status"/>
</el-descriptions-item>
<el-descriptions-item label="是否测试">
<dict-tag :options="dict.type.rule_engine_activate_is_test" :value="ruleEngineVersionInfoAndTest.isTest"/>
</el-descriptions-item>
</el-descriptions>
</el-col>
<el-col :span="12">
<editor style="margin-top: 10px" :read-only="true" :min-height="105" v-model="ruleEngineVersionInfoAndTest.description"></editor>
</el-col>
</el-row>
<el-row :gutter="20">
<el-col :span="12">
<encoding style="margin-top: 20px" v-model="ruleEngineVersionInfoAndTest.codeIng" :read-only="true"></encoding>
</el-col>
<el-col :span="12">
<el-col :span="assetStructure == null ? 24 : 12">
<el-card class="box-card">
<div slot="header" class="clearfix">
<span>选择数据接入</span>
</div>
<el-select v-model="assetStructure" style="width: 100%;">
<el-option v-for="_assetStructure in assetStructureList"
:key="_assetStructure.name"
:value="_assetStructure.name"
:label="_assetStructure.name+'('+_assetStructure.systemName+')'"
></el-option>
</el-select>
</el-card>
</el-col>
<el-col :span="12" v-if="assetStructure != null">
<el-card class="box-card" >
<div slot="header" class="clearfix">
<span>选择资产结构</span>
</div>
<el-select v-model="assets" style="width: 100%;">
<el-option v-for="_assets in assetsList"
:key="_assets.name"
:value="_assets.name"
:label="_assets.name+'('+_assets.as+')'"
></el-option>
</el-select>
</el-card>
</el-col>
<el-col :span="24">
<el-card class="box-card" v-if="assets != null">
<div slot="header" class="clearfix">
<span>选择资产模型</span>
</div>
<el-descriptions direction="vertical" :column="3" border>
<el-descriptions-item v-for="_dataModel in dataModelList"
:label='_dataModel.name + "("+_dataModel.comment+")"'>
<el-radio v-model="dataMode" :label="_dataModel.name" :value="_dataModel.id">{{dataModeMap[_dataModel.name]}}</el-radio>
</el-descriptions-item>
</el-descriptions>
</el-card>
</el-col>
<el-col :span="24" style="margin-top: 10px" v-if="dataMode != null">
<el-button>测试</el-button>
<el-input style="margin-top: 10px" v-model="testResult" type="textarea" placeholder="请点击测试" />
</el-col>
</el-col>
</el-row>
</el-drawer>
</div>
</template>
<script>
import {getMaintenance, updateMaintenance} from "@/api/ruleEngine/maintenance";
import Encoding from "@/components/Encoding/index.vue";
import {getVersion, listVersion} from "@/api/ruleEngine/version";
import {getMaintenance} from "@/api/ruleEngine/maintenance";
export default {
name: "EngineVersion",
components: {Encoding},
dicts: ['rule_engine_activate_status', 'rule_engine_type', 'sys_normal_disable',
'rule_engine_level', 'rule_engine_version_status', 'rule_engine_activate_is_test'],
data() {
return {
dialogVisible: false,
ruleEngineId: this.$route.params.ruleEngineId,
ruleEngineInfo:{},
modification: null
ruleEngineId: this.$route.params && this.$route.params.ruleEngineId,
ruleEngineInfo: {
id: 0,
name: null,
type: null,
isActivate: null,
status: null,
description: null,
remark:null,
code: null,
engineCode: null,
level: null,
ruleEngineVersionList: []
},
//
addVersionStatus: false,
engineVersionForm: {
"name": "", "code": "", "status": "0",
"versionCode": "",
"isActivate": "no-activate",
"description": "",
"codeIng": null
},
//
ruleEngineVersionInfoStatus: false,
//
ruleEngineVersionTestStatus: false,
//
ruleEngineVersionInfoAndTest: {},
//
assetStructureList: [
{
name: "测试1",
systemName: "云计算系统",
databaseName: "yunjisuan",
type: "dataSource"
},
{
name: "测试2",
systemName: "网站系统",
databaseName: "wangzhan",
type: "dataSource"
},
{
name: "测试3",
systemName: "物联网系统",
databaseName: "wulianwang",
type: "dataSource"
},
{
name: "测试4",
systemName: "传媒系统",
databaseName: "chuanmei",
type: "dataSource"
},
],
//
assetStructure: null,
//
assetsList: [
{
name: "sys_user",
as: "用户表",
dataTotal: 635847,
type: "dataTable",
childrenList: []
},
{
name: "sys_dept",
as: "部门表",
dataTotal: 362548,
type: "dataTable",
childrenList: []
},
{
name: "sys_notice",
as: "通知公告",
dataTotal: 6347,
type: "dataTable",
childrenList: []
}
],
//
assets: null,
//
dataModelList: [
{
id: 1,
name: "id",
comment: "主键",
isPrimaryKey: "Y",
type: "bigint",
mappingType: "Long",
length: "-",
decimalPlaces: "-",
isNull: "N",
defaultValue: "-",
isDict: "N",
dictKey: "-",
}, {
id: 2,
name: "name",
comment: "姓名",
isPrimaryKey: "N",
type: "varchar",
mappingType: "String",
length: "64",
decimalPlaces: "-",
isNull: "N",
defaultValue: "-",
isDict: "N",
dictKey: "-",
}, {
id: 3,
name: "sex",
comment: "性别",
isPrimaryKey: "N",
type: "char",
mappingType: "String",
length: "1",
decimalPlaces: "-",
isNull: "N",
defaultValue: "-",
isDict: "Y",
dictKey: "system_sex",
}, {
id: 4,
name: "price",
comment: "金额",
isPrimaryKey: "N",
type: "double",
mappingType: "BigDecimal",
length: "10",
decimalPlaces: "2",
isNull: "N",
defaultValue: "0.00",
isDict: "N",
dictKey: "-",
}, {
id: 5,
name: "create_time",
comment: "创建时间",
isPrimaryKey: "N",
type: "datetime",
mappingType: "Date",
length: "-",
decimalPlaces: "-",
isNull: "Y",
defaultValue: "-",
isDict: "N",
dictKey: "-",
},
],
//
dataMode: null,
//
dataModeMap: {
id: 1,
name: "张三",
sex: 1,
price: "653.69",
create_time: "2024-5-7 16:37:16",
},
testResult: ""
}
},
created() {
this.getInfo()
// this.initRuleEngine();
this.getListEngineMaintenance();
this.getListVersion()
},
methods: {
updRuleEngine(){
console.log(this.modification)
this.modification = parseInt(this.ruleEngineId)
setTimeout(() => {
this.modification = null
this.dialogVisible = false
},100)
saveCoding(){
this.$message.success('编码保存成功');
},
getInfo(){
getMaintenance(this.$route.params.ruleEngineId).then(res => {
ruleEngineVersionInfoStatusClose(done) {
this.$confirm('确认关闭?')
.then(_ => {
this.ruleEngineVersionInfoAndTest = {};
done();
})
.catch(_ => {});
},
ruleEngineVersionTestStatusClose(done) {
this.$confirm('确认关闭?')
.then(_ => {
this.ruleEngineVersionInfoAndTest = {};
done();
})
.catch(_ => {});
},
//
checkRuleEngineVersion(command) {
switch (command.event) {
case "info"://
this.ruleEngineVersionInfoStatus = true;
this.ruleEngineVersionInfoAndTest = command.ruleEngineVersion;
break;
case "test"://
this.ruleEngineVersionTestStatus = true;
this.ruleEngineVersionInfoAndTest = command.ruleEngineVersion;
break;
case "status"://
command.ruleEngineVersion.isActivate = 'no-activate' === command.ruleEngineVersion.isActivate ? 'activated' : 'no-activate'
break;
case "publish"://
command.ruleEngineVersion.status = '2'
break;
}
console.log(command.event);
console.log(command.ruleEngineVersion);
},
//
genEngineVersion(){
if (this.engineVersionForm.name == null || this.engineVersionForm.name === "") {
this.$message.error('规则名称不可为空');
return false;
}
if (this.engineVersionForm.code == null || this.engineVersionForm.code === "") {
this.$message.error('规则CODE不可为空');
return false;
}
if (this.engineVersionForm.description == null || this.engineVersionForm.description === "") {
this.$message.error('规则版本使用描述不可为空');
return false;
}
this.engineVersionForm.versionCode = this.ruleEngineInfo.engineCode + "_" + this.engineVersionForm.code
this.engineVersionForm.codeIng = this.getCodeIng()
},
//
addVersionSubmission(){
this.ruleEngineInfo.ruleEngineVersionList.push({... this.engineVersionForm})
this.addVersionStatus = false;
},
//
addVersionCancel(){
this.engineVersionForm = {
"name": "", "code": "", "status": "0", "isTest": "0",
"versionCode": "",
"isActivate": "no-activate",
"description": "",
"codeIng": null, "ruleEngineVersionList": []
};
this.addVersionStatus = false;
},
handleClick(clickType){
if (clickType === "add"){
this.addVersionStatus = true;
}else if(clickType === "activate"){
this.ruleEngineInfo.isActivate = 'no-activate' === this.ruleEngineInfo.isActivate ? 'activated' : 'no-activate'
this.$modal.msgSuccess("引擎激活状态修改成功");
}else if(clickType === "status"){
this.ruleEngineInfo.status = '0' === this.ruleEngineInfo.status ? '1' : '0'
this.$modal.msgSuccess("引擎状态操作成功");
}
},
getListEngineMaintenance(){
getMaintenance(this.ruleEngineId).then(res=>{
console.log(res,'1')
this.ruleEngineInfo = res.data
console.log(this.ruleEngineInfo)
})
//
},
getListVersion(){
getVersion(this.ruleEngineId).then(res=>{
console.log(res,'2')
this.ruleEngineInfo.ruleEngineVersionList = res.data
})
},
// initRuleEngine(){
// let response = {
// "code": 200,
// "msg": "",
// "data": {
// "id": 1,
// "name": "",
// "type": "rule-custom",
// "isActivate": "no-activate",
// "status": "0",
// "description": "<p></p>",
// "remark": "-",
// "code": "email",
// "engineCode": "engine_custom_email",
// "level": "data-field",
// "ruleEngineVersionList": [
// {
// "name": "163", "code": "IAW3S02", "status": "0", "isTest": "0",
// "versionCode": "engine_custom_email_IAW3S02", "isActivate": "no-activate",
// "description": "<p></p>","codeIng": "package com.muyu.rule.engine.custom;\n" +
// "\n" +
// "import com.muyu.engine.action.ActionDiscard;\n" +
// "import com.muyu.engine.scope.DataModelEngine;\n" +
// "\n" +
// "/**\n" +
// " * @Author: DongZeLiang\n" +
// " * @date: 2024/5/6\n" +
// " * @Description: ce-IAW3S02\n" +
// " * @Version: 1.0\n" +
// " */\n" +
// "public class engine_custom_email_IAW3S02 extends DataModelEngine {\n" +
// " @Override\n" +
// " public void execution () {\n" +
// " Object value = getValue();\n" +
// "\n" +
// " if (value == null || \"\".equals(value) || \"null\".equals(value)) {\n" +
// " throw new ActionDiscard();\n" +
// " }\n" +
// " }\n" +
// "}"
// },
// {
// "name": "", "code": "JISID8S", "status": "2", "isTest": "1",
// "versionCode": "engine_custom_email_JISID8S", "isActivate": "activated",
// "description": "<p></p>","codeIng": "package com.muyu.rule.engine.custom;\n" +
// "\n" +
// "import com.muyu.engine.action.ActionDiscard;\n" +
// "import com.muyu.engine.scope.DataModelEngine;\n" +
// "\n" +
// "/**\n" +
// " * @Author: DongZeLiang\n" +
// " * @date: 2024/5/6\n" +
// " * @Description: ce-JISID8S\n" +
// " * @Version: 1.0\n" +
// " */\n" +
// "public class engine_custom_email_JISID8S extends DataModelEngine {\n" +
// " @Override\n" +
// " public void execution () {\n" +
// " Object value = getValue();\n" +
// "\n" +
// " if (value == null || \"\".equals(value) || \"null\".equals(value)) {\n" +
// " throw new ActionDiscard();\n" +
// " }\n" +
// " }\n" +
// "}"
// },
// {
// "name": "", "code": "DJ8S9EA", "status": "2", "isTest": "2",
// "versionCode": "engine_custom_email_DJ8S9EA", "isActivate": "no-activate",
// "description": "<p></p>"
// },
// {
// "name": "", "code": "XJS9E0S", "status": "1", "isTest": "0",
// "versionCode": "engine_custom_email_XJS9E0S", "isActivate": "no-activate",
// "description": "<p></p>"
// }
// ]
// }
// }
// this.ruleEngineInfo = response.data
// },
//
getCodeIng(){
let packageName = "com.muyu.rule.engine";
let customName = "custom";
let templateName = "template";
let parentClass = "DataModelEngine";
let codeIng = `package ${packageName}.${customName};
import com.muyu.engine.action.ActionDiscard;
import com.muyu.engine.scope.${parentClass};
/**
* @Author: DongZeLiang
* @date: 2024/5/6
* @Description: ${this.engineVersionForm.name}-${this.engineVersionForm.code}
* @Version: 1.0
*/
public class ${this.engineVersionForm.versionCode} extends ${parentClass} {
@Override
public void execution () {
Object value = getValue();
if (value == null || "".equals(value) || "null".equals(value)) {
throw new ActionDiscard();
}
}
}`;
return codeIng;
}
}
}
</script>
<style scoped>
.box-card{
margin-top: 20px;
}
.el-dropdown-link {
cursor: pointer;
color: #409EFF;
}
.el-icon-arrow-down {
font-size: 12px;
}
.CodeMirror {
height: 600px;
}
</style>