| | |
| | | > |
| | | <span class="custom-tree-node" slot-scope="{ node, data }"> |
| | | <span>{{ node.label }}</span> |
| | | <span> |
| | | <span v-if="data.id > 0"> |
| | | <el-button |
| | | type="text" |
| | | icon="el-icon-delete" |
| | |
| | | size="mini" |
| | | @click="() => remove(node, data)" |
| | | > |
| | | </el-button> |
| | | </span> |
| | | <span v-if="data.id > 0"> |
| | | <el-button |
| | | type="text" |
| | | circle |
| | | size="mini" |
| | | @click="() => altertag(node, data)" |
| | | ><span class="button-textxg" |
| | | ><i class="el-icon-edit-outline"></i |
| | | ></span> |
| | | </el-button> |
| | | </span> |
| | | </span> |
| | |
| | | prop="id" |
| | | /> |
| | | <el-table-column |
| | | label="值类型" |
| | | label="结果类型" |
| | | fixed |
| | | align="center" |
| | | key="isenable" |
| | | prop="isenable" |
| | | key="valueType" |
| | | prop="valueType" |
| | | :show-overflow-tooltip="true" |
| | | > |
| | | <template slot-scope="scope"> |
| | | <dict-tag :options="valuetype" :value="scope.row.isenable" /> |
| | | <dict-tag |
| | | :options="valuetypelb" |
| | | :value="scope.row.valueType" |
| | | /> |
| | | </template> |
| | | </el-table-column> |
| | | <el-table-column |
| | |
| | | /><el-table-column |
| | | label="适用方式" |
| | | align="center" |
| | | key="suitWay" |
| | | prop="suitWay" |
| | | key="suitWayList" |
| | | prop="suitWayList" |
| | | width="120" |
| | | > |
| | | <template slot-scope="scope"> |
| | | <dict-tag :options="mode" :value="scope.row.suitWay" /> |
| | | <dict-tag :options="mode" :value="scope.row.suitWayList" /> |
| | | </template> |
| | | </el-table-column> |
| | | <el-table-column |
| | |
| | | <el-dialog |
| | | :title="title" |
| | | :visible.sync="indexopen" |
| | | :close-on-click-modal="false" |
| | | width="900px" |
| | | append-to-body |
| | | > |
| | |
| | | > |
| | | <el-row v-if="!measurement"> |
| | | <el-col :span="12"> |
| | | <el-form-item label="指标名称" prop="deptId"> |
| | | <el-form-item label="指标名称" prop="targetname"> |
| | | <el-input |
| | | v-model="indexform.targetname" |
| | | placeholder="请输入指标种类" |
| | |
| | | <el-form-item label="版本号" prop="deptId"> |
| | | <el-input |
| | | v-model="indexform.version" |
| | | placeholder="请输入指标种类" |
| | | placeholder="默认1.0" |
| | | maxlength="40" |
| | | /> |
| | | </el-form-item> |
| | |
| | | <!-- deptOptions --> |
| | | <el-row v-if="!measurement"> |
| | | <el-col :span="8"> |
| | | <el-form-item label="指标分类"> |
| | | <el-form-item label="指标分类" prop="assortid"> |
| | | <el-select |
| | | v-model="indexform.assortid" |
| | | size="medium" |
| | |
| | | </el-form-item> |
| | | </el-col> |
| | | <el-col :span="8"> |
| | | <el-form-item label="语言" prop="deptId"> |
| | | <el-form-item label="语言" prop="language"> |
| | | <el-select |
| | | v-model="indexform.language" |
| | | placeholder="请选择语言" |
| | |
| | | <el-row v-if="!measurement"> |
| | | <el-col :span="24"> |
| | | <el-form-item label="值类型"> |
| | | <el-radio-group v-model="indexform.isenable"> |
| | | <el-radio-group v-model="indexform.valueType"> |
| | | <el-radio :label="1">选项</el-radio> |
| | | <el-radio :label="2">文本</el-radio> |
| | | <el-radio :label="3">数值</el-radio> |
| | |
| | | </el-form-item> |
| | | </el-col></el-row |
| | | > |
| | | <el-row v-if="!measurement"> |
| | | <el-col :span="24"> |
| | | <el-form-item label="题目类型"> |
| | | <el-radio-group v-model="indexform.scriptType"> |
| | | <el-radio :label="1">单选</el-radio> |
| | | <el-radio :label="2">多选</el-radio> |
| | | <el-radio :label="3">填空</el-radio> |
| | | </el-radio-group> |
| | | </el-form-item> |
| | | </el-col></el-row |
| | | > |
| | | |
| | | <el-row v-if="!measurement"> |
| | | <el-col :span="24"> |
| | | <el-form-item label="适用方式" prop="email"> |
| | | <el-select v-model="indexform.suitWay" placeholder="请选择"> |
| | | <el-form-item label="适用场景" prop="suitWayList"> |
| | | <el-select |
| | | v-model="indexform.suitWayList" |
| | | multiple |
| | | placeholder="请选择" |
| | | > |
| | | <el-option |
| | | v-for="index in mode" |
| | | :key="index.value" |
| | |
| | | <el-card |
| | | class="box-card" |
| | | style="margin-bottom: 20px" |
| | | v-if="indexform.isenable == 1" |
| | | v-if="indexform.valueType == 1" |
| | | > |
| | | <Regular |
| | | :TargetoptionList="testuserList" |
| | |
| | | @xiayioption="xiayioption" |
| | | /> |
| | | </el-card> |
| | | <div v-if="indexform.isenable == 2"> |
| | | <div v-if="indexform.valueType == 2"> |
| | | <el-form-item label="收集信息"> |
| | | <el-input |
| | | type="textarea" |
| | | :rows="2" |
| | | placeholder="填入收集信息" |
| | | v-model="indexform.textarea" |
| | | v-model="indexform.reply" |
| | | maxlength="50" |
| | | show-word-limit |
| | | > |
| | | </el-input |
| | | ></el-form-item> |
| | | </div> |
| | | <div v-if="indexform.isenable == 3"> |
| | | <div v-if="indexform.valueType == 3"> |
| | | <el-form-item label="收集信息"> |
| | | <el-input |
| | | type="text" |
| | | placeholder="填入收集信息" |
| | | v-model="indexform.textarea" |
| | | v-model="indexform.reply" |
| | | > |
| | | </el-input |
| | | ></el-form-item> |
| | |
| | | <el-col :span="12"> |
| | | <el-form-item label="测试输入" prop="nickName"> |
| | | <el-input |
| | | v-model="testvalue" |
| | | v-model="indexform.content" |
| | | placeholder="请输入测试内容" |
| | | maxlength="40" |
| | | /> |
| | | </el-form-item> |
| | | </el-col> |
| | | <el-col :span="4"> |
| | | <el-button type="success">开始测试</el-button> |
| | | <el-button type="success" @click="testtagerlist" |
| | | >开始测试</el-button |
| | | > |
| | | </el-col> |
| | | </el-row> |
| | | </el-form> |
| | |
| | | </el-form-item> |
| | | </el-form> |
| | | <div slot="footer" class="dialog-footer"> |
| | | <el-button @click="dialogFormVisible = false">取 消</el-button> |
| | | <el-button @click="getDeptTree()">取 消</el-button> |
| | | <el-button type="primary" @click="submitsidecolumn">确 定</el-button> |
| | | </div> |
| | | </el-dialog> |
| | |
| | | gettargetInfo, |
| | | particulartarget, |
| | | gettargetInfoedit, |
| | | testtagerlist, |
| | | addtarget, |
| | | deletetarget, |
| | | getillnesslist, |
| | |
| | | addtargetillness, |
| | | selectIvrLibaTargetAssortList, |
| | | addtreeselectIvrLibaTargetAssort, |
| | | edittreeselectIvrLibaTargetAssort, |
| | | delselectIvrLibaTargetAssort, |
| | | } from "@/api/AiCentre/index"; |
| | | import { getToken } from "@/utils/auth"; |
| | |
| | | pageNum: 1, |
| | | pageSize: 10, |
| | | }, |
| | | valuetypelb: [], |
| | | |
| | | // 表单校验 |
| | | rules: {}, |
| | | rules: { |
| | | targetname: [ |
| | | { required: true, message: "指标名称不能为空", trigger: "blur" }, |
| | | ], |
| | | assortid: [ |
| | | { required: true, message: "指标分类不能为空", trigger: "blur" }, |
| | | ], |
| | | language: [ |
| | | { required: true, message: "指标语言不能为空", trigger: "blur" }, |
| | | ], |
| | | isAvailable: [ |
| | | { required: true, message: "指标语言不能为空", trigger: "blur" }, |
| | | ], |
| | | }, |
| | | }; |
| | | }, |
| | | watch: { |
| | |
| | | this.gettabList(); |
| | | this.getDeptTree(); |
| | | this.mode = store.getters.mode; |
| | | this.valuetype = store.getters.valuetype; |
| | | this.valuetypelb = store.getters.valuetypelb; |
| | | this.languagelist = store.getters.languagelist; |
| | | this.qyoptions = store.getters.usable; |
| | | }, |
| | |
| | | guid: 1, |
| | | id: this.indexform.id, |
| | | targettype: this.indexform.targettype, |
| | | isoperation: 1, |
| | | targetvalue: "", |
| | | targetregex: "", |
| | | targetregex2: "", |
| | |
| | | if (index !== -1) { |
| | | this.testuserList[index].isoperation = 3; |
| | | this.targetoptionList.push(this.testuserList[index]); |
| | | console.log(this.targetoptionList, "aaaa.targetoptionList"); |
| | | this.testuserList.splice(index, 1); // 从索引位置删除一个元素 |
| | | this.sortFn(); |
| | | } else { |
| | |
| | | targetvalue: item.targetvalue, |
| | | targetregex2: item.targetregex2, |
| | | targetregex: item.targetregex, |
| | | targetoptionid: item.targetoptionid, |
| | | id: this.indexform.id, |
| | | targettype: this.indexform.targettype, |
| | | isoperation: item.targetoptionid ? 2 : 1, |
| | |
| | | nodynamiccruxs: item.nodynamiccruxs, |
| | | dynamiccruxsJson: item.dynamiccruxsJson, |
| | | nodynamiccruxsJson: item.nodynamiccruxsJson, |
| | | targetoptionid: item.targetoptionid, |
| | | }; |
| | | }); |
| | | console.log(this.testuserList); |
| | |
| | | getDeptTree() { |
| | | selectIvrLibaTargetAssortList({}).then((res) => { |
| | | this.deptOptions = res.rows; |
| | | this.dialogFormVisible = false; |
| | | }); |
| | | }, |
| | | // 筛选节点 |
| | |
| | | }, |
| | | // 添加类别树 |
| | | submitsidecolumn() { |
| | | if (this.classifyform.id) { |
| | | edittreeselectIvrLibaTargetAssort(this.classifyform).then((res) => { |
| | | this.getDeptTree(); |
| | | this.$modal.msgSuccess("修改成功"); |
| | | this.classifyform = {}; |
| | | this.dialogFormVisible = false; |
| | | }); |
| | | return; |
| | | } |
| | | let calssvalue = {}; |
| | | if ( |
| | | this.classifyform.pid && |
| | |
| | | .catch(() => {}); |
| | | } |
| | | }, |
| | | altertag(a, b) { |
| | | this.dialogFormVisible = true; |
| | | if (!b.pid) { |
| | | this.radio = "主分类"; |
| | | } else { |
| | | this.radio = "子分类"; |
| | | } |
| | | this.classifyform = b; |
| | | this.dialogFormVisible = true; |
| | | }, |
| | | handleNodeClick(data) { |
| | | this.queryParams.assortid = data.id; |
| | | this.getList(); |
| | |
| | | |
| | | // 取消按钮 |
| | | cancel() { |
| | | this.indexform = null; |
| | | this.indexopen = false; |
| | | this.reset(); |
| | | }, |
| | |
| | | // 表单重置 |
| | | reset() { |
| | | this.indexform = { |
| | | suitWay: undefined, |
| | | suitWayList: undefined, |
| | | id: undefined, |
| | | targetdesc: undefined, |
| | | baseTagList: [], |
| | | targetoptionList: [], |
| | | }; |
| | | this.resetForm("indexform"); |
| | | // this.resetForm("indexform"); |
| | | }, |
| | | /** 搜索按钮操作 */ |
| | | handleQuery() { |
| | |
| | | targetvalue: "", |
| | | targetregex: "", |
| | | targetregex2: "", |
| | | isoperation: 1, |
| | | dynamiccruxs: [], |
| | | nodynamiccruxs: [], |
| | | dynamiccruxsJson: "", |
| | |
| | | this.reset(); |
| | | console.log(row); |
| | | this.title = "指标详情"; |
| | | this.indexform = {}; |
| | | this.indexform = row; |
| | | if (!row.targetoptionList[0]) { |
| | | row.targetoptionList = [ |
| | | { |
| | | targettype: "1", |
| | | targetvalue: "", |
| | | targetregex: "", |
| | | targetregex2: "", |
| | | isoperation: 1, |
| | | dynamiccruxs: [], |
| | | nodynamiccruxs: [], |
| | | dynamiccruxsJson: "", |
| | | nodynamiccruxsJson: "", |
| | | }, |
| | | ]; |
| | | } |
| | | this.dynamicTags = row.baseTagList.map(this.processElement); |
| | | this.testuserList = row.targetoptionList; |
| | | console.log(this.testuserList, "bbbb"); |
| | | this.testvalue = ""; |
| | | this.indexopen = true; |
| | | this.measurement = false; |
| | | }, |
| | |
| | | |
| | | /** 更新/修改提交按钮 */ |
| | | submitForm: function () { |
| | | // this.indexform.targetoptionList=[] |
| | | this.indexform.targetoptionList = this.indexform.targetoptionList.map( |
| | | (res) => { |
| | | res.isoperation = 2; |
| | | return res; |
| | | } |
| | | ); |
| | | // this.indexform.targetoptionList = this.indexform.targetoptionList.map( |
| | | // (res) => { |
| | | // res.isoperation = 2; |
| | | // return res; |
| | | // } |
| | | // ); |
| | | |
| | | this.$refs["indexform"].validate((valid) => { |
| | | this.indexform.targetoptionList = this.testuserList.concat( |
| | | this.targetoptionList |
| | | ); |
| | | console.log(this.indexform.targetoptionList, "11"); |
| | | this.indexform.targetoptionList.forEach((item) => { |
| | | if (item.isoperation != 3 && item.targetoptionid) { |
| | | console.log(item, "item"); |
| | | item.isoperation = 2; |
| | | } else { |
| | | } |
| | | }); |
| | | if (valid) { |
| | | if (!this.indexform.version) this.indexform.version = "1.0"; |
| | | if (this.indexform.id != undefined) { |
| | | this.indexform.isoperation = 2; |
| | | gettargetInfoedit(this.indexform).then((response) => { |
| | |
| | | } |
| | | }); |
| | | }, |
| | | // 测试表单 |
| | | testtagerlist() { |
| | | if (this.indexform.content) { |
| | | let data = this.indexform; |
| | | data.targetoptionList = this.testuserList.concat(this.targetoptionList); |
| | | testtagerlist(data).then((res) => { |
| | | this.$modal.msgSuccess("测试成功"); |
| | | this.testgovalue = res.msg; |
| | | this.getList(); |
| | | }); |
| | | } else { |
| | | this.$modal.msgError("请填写测试内容"); |
| | | return; |
| | | } |
| | | }, |
| | | /** 删除按钮操作 */ |
| | | handleDelete(row) { |
| | | const userIds = row.id || this.ids; |