WXL
2024-07-04 245a9200ddaa5c2a9ab9f6a68969527bb121ec2f
src/views/repositoryai/intention/index.vue
@@ -232,12 +232,12 @@
              /><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
@@ -333,6 +333,7 @@
        <el-dialog
          :title="title"
          :visible.sync="indexopen"
          :close-on-click-modal="false"
          width="900px"
          append-to-body
        >
@@ -344,7 +345,7 @@
          >
            <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="请输入指标种类"
@@ -365,7 +366,7 @@
            <!-- 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"
@@ -389,7 +390,7 @@
                </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="请选择语言"
@@ -481,8 +482,12 @@
            <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"
@@ -535,14 +540,16 @@
              <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>
@@ -652,6 +659,7 @@
  gettargetInfo,
  particulartarget,
  gettargetInfoedit,
  testtagerlist,
  addtarget,
  deletetarget,
  getillnesslist,
@@ -706,9 +714,7 @@
      }, //类别表单
      // 表格数据
      targetList: null,
      testuserList: [
      ],
      testuserList: [],
      // 弹出层标题
      title: "",
      // 是否显示弹出层
@@ -753,7 +759,20 @@
      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: {
@@ -936,6 +955,7 @@
        guid: 1,
        id: this.indexform.id,
        targettype: this.indexform.targettype,
        isoperation: 1,
        targetvalue: "",
        targetregex: "",
        targetregex2: "",
@@ -954,6 +974,7 @@
      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 {
@@ -979,7 +1000,6 @@
          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,
@@ -989,6 +1009,7 @@
          nodynamiccruxs: item.nodynamiccruxs,
          dynamiccruxsJson: item.dynamiccruxsJson,
          nodynamiccruxsJson: item.nodynamiccruxsJson,
          targetoptionid: item.targetoptionid,
        };
      });
      console.log(this.testuserList);
@@ -1090,6 +1111,7 @@
    // 取消按钮
    cancel() {
      this.indexform = null;
      this.indexopen = false;
      this.reset();
    },
@@ -1097,13 +1119,13 @@
    // 表单重置
    reset() {
      this.indexform = {
        suitWay: undefined,
        suitWayList: undefined,
        id: undefined,
        targetdesc: undefined,
        baseTagList: [],
        targetoptionList: [],
      };
      this.resetForm("indexform");
      // this.resetForm("indexform");
    },
    /** 搜索按钮操作 */
    handleQuery() {
@@ -1157,22 +1179,26 @@
      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: "",
        },]
      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;
@@ -1192,17 +1218,25 @@
    /** 更新/修改提交按钮 */
    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) {
@@ -1224,6 +1258,21 @@
        }
      });
    },
    // 测试表单
    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;