From 3bab59284578d6e6d2fa2f807895c60ebc54bdcc Mon Sep 17 00:00:00 2001
From: WXL <1785969728@qq.com>
Date: 星期二, 17 六月 2025 16:01:23 +0800
Subject: [PATCH] 测试完成
---
 src/views/knowledge/questionbank/particulars/index.vue | 1394 ++++++++++++++++++++++++++++++++++++++++------------------
 1 files changed, 962 insertions(+), 432 deletions(-)
diff --git a/src/views/knowledge/questionbank/particulars/index.vue b/src/views/knowledge/questionbank/particulars/index.vue
index 71d52f4..e519639 100644
--- a/src/views/knowledge/questionbank/particulars/index.vue
+++ b/src/views/knowledge/questionbank/particulars/index.vue
@@ -1,376 +1,550 @@
 <template>
   <div>
     <div class="presentation-right">
-      <el-card class="box-card">
-        <el-form :inline="true" :model="topicobj" class="demo-form-inline">
-          <div class="headline">
-            棰樼洰璁剧疆璇︽儏
-            <span style="margin-left: 30px"
-              ><el-button type="primary" @click="compileissue"
-                >淇� 瀛�</el-button
-              ></span
-            ><span style="margin-left: 30px"
-              ><el-button type="success" round @click="drawer = true"
-                >+閫夋嫨鎸囨爣</el-button
-              ></span
-            >
-          </div>
-          <div style="margin-left: 8%">
-            <el-row :gutter="10">
-              <el-col :span="10">
-                <el-form-item label="闂鍒嗙被">
-                  <el-select
-                    v-model="topicobj.categoryid"
-                    size="medium"
-                    filterable
-                    placeholder="璇烽�夋嫨鍒嗙被"
-                  >
-                    <el-option-group
-                      v-for="group in classifylist"
-                      :key="group.id"
-                      :label="group.name"
+      <div class="sidecolumn">
+        <div>
+          <el-steps finish-status="success" :active="Editprogress" simple>
+            <el-step>
+              <template slot="title">
+                <span style="cursor: pointer" @click="Editprogress = 1"
+                  >闂鍩虹淇℃伅缂栬緫</span
+                >
+              </template>
+            </el-step>
+            <el-step>
+              <template slot="title">
+                <span style="cursor: pointer" @click="nextstep"
+                  >闂鎸囨爣缂栬緫</span
+                >
+              </template>
+            </el-step>
+          </el-steps>
+        </div>
+      </div>
+      <div v-if="Editprogress == 1">
+        <el-card class="box-card">
+          <el-form :inline="true" ref="topicobj" :model="topicobj" :rules="rules" class="demo-form-inline">
+            <div class="headline">
+              鍩虹淇℃伅閰嶇疆
+              <span style="margin-left: 30px"
+                ><el-button type="success" @click="topicVisible = true"
+                  >棰勮</el-button
+                >
+              </span>
+              <span style="margin-left: 30px"
+                ><el-button type="primary" @click="Saveproblem"
+                  >淇� 瀛�</el-button
+                >
+              </span>
+            </div>
+            <el-divider></el-divider>
+
+            <div style="margin-left: 8%">
+              <el-form-item label="闂鍐呭" prop="scriptContent">
+                <el-input
+                  style="width: 40vw"
+                  type="textarea"
+                  id="scriptContent"
+                  v-model="topicobj.scriptContent"
+                  @focus="handleInput('scriptContent')"
+                  placeholder="璇疯緭鍏ラ棶棰樺唴瀹�"
+                ></el-input>
+              </el-form-item>
+              <el-form-item label="闂璇存槑" prop="targetname">
+                <el-input
+                  style="width: 40vw"
+                  type="textarea"
+                  v-model="topicobj.scriptDesc"
+                  placeholder="璇疯緭鍏ヨ鏄�"
+                ></el-input>
+              </el-form-item>
+              <el-row :gutter="10">
+                <el-col :span="8">
+                  <el-form-item label="闂鍒嗙被" prop="categoryid">
+                    <el-select
+                      v-model="topicobj.categoryid"
+                      size="medium"
+                      filterable
+                      placeholder="璇烽�夋嫨鍒嗙被"
+                    >
+                      <el-option-group
+                        v-for="group in classifylist"
+                        :key="group.id"
+                        :label="group.name"
+                      >
+                        <el-option
+                          v-for="item in group.svyLibScriptCategoryList"
+                          :key="item.id"
+                          :label="item.name"
+                          :value="item.id"
+                        >
+                        </el-option>
+                      </el-option-group>
+                    </el-select>
+                  </el-form-item>
+                </el-col>
+                <el-col :span="8">
+                  <el-form-item label="璇勪环绫诲瀷" prop="scoretype">
+                    <el-select
+                      v-model="topicobj.scoretype"
+                      placeholder="璇烽�夋嫨鍒嗙被"
                     >
                       <el-option
-                        v-for="item in group.svyLibTopicCategoryList"
-                        :key="item.id"
-                        :label="item.name"
-                        :value="item.id"
+                        v-for="group in appraiselist"
+                        :key="group.value"
+                        :label="group.label"
+                        :value="group.value"
                       >
                       </el-option>
-                    </el-option-group>
-                  </el-select>
-                </el-form-item>
-              </el-col>
-              <el-col :span="10">
-                <el-form-item label="璇勪环绫诲瀷">
-                  <el-select
-                    v-model="topicobj.evaluateid"
-                    placeholder="璇烽�夋嫨鍒嗙被"
-                  >
-                    <el-option
-                      v-for="group in appraiselist"
-                      :key="group.value"
-                      :label="group.label"
-                      :value="group.value"
-                    >
-                    </el-option>
-                  </el-select>
-                </el-form-item>
-              </el-col>
-            </el-row>
-
-            <el-row :gutter="10">
-              <el-col :span="6"
-                ><el-form-item label="棰樼洰鏍囬">
-                  <el-input
-                    v-model="topicobj.topic"
-                    placeholder="璇疯緭鍏ユ爣棰�"
-                  ></el-input> </el-form-item
-              ></el-col>
-              <el-col :span="6"
-                ><el-form-item label="鏄惁鍙敤">
-                  <el-select
-                    v-model="topicobj.isavailable"
-                    size="medium"
-                    filterable
-                    placeholder="璇烽�夋嫨鍒嗙被"
-                  >
-                    <el-option
-                      class="topicobjaa"
-                      v-for="item in usable"
-                      :key="item.value"
-                      :label="item.label"
-                      :value="item.value"
-                    >
-                    </el-option>
-                  </el-select> </el-form-item
-              ></el-col>
-              <el-col :span="8"
-                ><el-form-item label="璇█(缂�)">
-                  <el-select
-                    v-model="topicobj.language"
-                    size="medium"
-                    filterable
-                    placeholder="璇烽�夋嫨鍒嗙被"
-                  >
-                    <el-option
-                      class="topicobjaa"
-                      v-for="item in languagelist"
-                      :key="item.value"
-                      :label="item.label"
-                      :value="item.value"
-                    >
-                    </el-option>
-                  </el-select> </el-form-item
-              ></el-col>
-            </el-row>
-            <el-row :gutter="10">
-              <el-col :span="6"
-                ><el-form-item label="鏄惁蹇呭~">
-                  <el-select
-                    v-model="topicobj.ismandatory"
-                    size="medium"
-                    filterable
-                    placeholder="璇烽�夋嫨鍒嗙被"
-                  >
-                    <el-option
-                      class="topicobjaa"
-                      v-for="item in required"
-                      :key="item.value"
-                      :label="item.label"
-                      :value="item.value"
-                    >
-                    </el-option>
-                  </el-select> </el-form-item
-              ></el-col>
-              <el-col :span="6"
-                ><el-form-item label="棰樼洰绫诲瀷">
-                  <el-select
-                    v-model="topicobj.valueType"
-                    size="medium"
-                    filterable
-                    placeholder="璇烽�夋嫨鍒嗙被"
-                  >
-                    <el-option
-                      class="topicobjaa"
-                      v-for="item in valuetype"
-                      :key="item.value"
-                      :label="item.label"
-                      :value="item.value"
-                    >
-                    </el-option>
-                  </el-select> </el-form-item
-              ></el-col>
-              <el-col :span="8"
-                ><el-form-item label="閫傜敤鏂瑰紡">
-                  <el-select
-                    v-model="topicobj.suitway"
-                    size="medium"
-                    filterable
-                    placeholder="璇烽�夋嫨鍒嗙被"
-                  >
-                    <el-option
-                      class="topicobjaa"
-                      v-for="item in mode"
-                      :key="item.value"
-                      :label="item.label"
-                      :value="item.value"
-                    >
-                    </el-option> </el-select></el-form-item
-              ></el-col>
-            </el-row>
-            <el-form-item label="棰樼洰鍐呭">
-              <el-input
-                style="width: 40vw"
-                type="textarea"
-                id="topicContent"
-                v-model="topicobj.topicContent"
-                @focus="handleInput('topicContent')"
-                placeholder="璇疯緭鍏ユ爣棰�"
-              ></el-input>
-            </el-form-item>
-
-            <el-row>
-              <el-form-item label="鏍囩" prop="desc">
-                <div class="xinz-inf">
-                  <el-tag
-                    :key="tag"
-                    type="success"
-                    v-for="tag in dynamicTags"
-                    closable
-                    :disable-transitions="false"
-                    @close="handleClosetag(tag)"
-                  >
-                    {{ tag }}
-                  </el-tag>
-                  <el-select
-                    v-model="inputValue"
-                    v-if="inputVisible"
-                    @change="handleInputConfirm"
-                    filterable
-                    remote
-                    reserve-keyword
-                    default-first-option
-                    :remote-method="remoteMethodtag"
-                    :loading="loading"
-                    placeholder="璇烽�夋嫨"
-                  >
-                    <el-option
-                      v-for="item in optionstag"
-                      :key="item.tagid"
-                      :label="item.tagname"
-                      :value="item.tagname"
-                    >
-                    </el-option>
-                  </el-select>
-                  <el-button
-                    v-else
-                    class="button-new-tag"
-                    size="small"
-                    @click="showInput"
-                    >+ 鏂板鏍囩</el-button
-                  >
-                </div>
-              </el-form-item>
-            </el-row>
-            <el-row>
-              <el-form-item label="閫傜敤鐤剧梾" prop="region">
-                <div class="xinz-inf">
-                  <el-tag
-                    :key="item.icd10name"
-                    type="warning"
-                    v-for="item in illnesslist"
-                    closable
-                    :disable-transitions="false"
-                    @close="handleCloseillness(item)"
-                  >
-                    {{ item.icd10name }}
-                  </el-tag>
-                  <el-select
-                    v-model="inputValueillness"
-                    v-if="inputVisibleillness"
-                    @change="illnessConfirm"
-                    :remote-method="remoteMethod"
-                    filterable
-                    remote
-                    allow-create
-                    default-first-option
-                    placeholder="璇烽�夋嫨/鏌ヨ"
-                    :loading="loading"
-                  >
-                    <el-option
-                      v-for="item in optionsillness"
-                      :key="item.icdid"
-                      :label="item.icdname"
-                      :value="item.icdid"
-                    >
-                    </el-option>
-                  </el-select>
-                  <el-button
-                    v-else
-                    class="button-new-tag"
-                    size="small"
-                    @click="inputVisibleillness = true"
-                    >+ 鏂板鐤剧梾</el-button
-                  >
-                </div>
-              </el-form-item>
-            </el-row>
-            <!-- <el-form-item label="閫氱煡鍙橀噺" prop="name">
-              <div style="margin-bottom: 5px" v-for="item in variablelist">
-                <el-row>
-                  <el-col :span="5">
+                    </el-select>
+                  </el-form-item>
+                </el-col>
+                <el-col :span="8" v-if="topicobj.scoretype == 1">
+                  <el-form-item label="闂寰楀垎" prop="score">
                     <el-input
-                      v-model="item.variatename"
-                      placeholder="璇疯緭鍏ュ彉閲忓悕"
+                      v-model="topicobj.score"
+                      placeholder="璇疯緭鍏ュ垎鏁�"
                     ></el-input>
-                  </el-col>
-                  <el-col :span="8" :offset="1">
-                    <el-input
-                      v-model="item.variate"
-                      placeholder="璇疯緭鍏ュ彉閲忓唴瀹�"
-                    ></el-input>
-                  </el-col>
-                  <el-col :span="8" :offset="1">
-                    <el-button
-                      type="success"
-                      icon="el-icon-plus"
-                      circle
-                      @click="addvariable(item)"
-                    ></el-button>
-                    <el-button
-                      v-if="!item.default"
-                      type="danger"
-                      icon="el-icon-delete"
-                      circle
-                      @click="delvariable(item)"
-                    ></el-button>
-                  </el-col>
-                </el-row>
-              </div>
-            </el-form-item>
-            <el-row>
-              <el-col :span="24">
-                <div
-                  style="display: flex; margin-left: 66px; margin-bottom: 10px"
-                >
-                  <div
-                    v-for="item in variablelist"
-                    class="tsgname"
-                    @click="tsgnameto(item)"
-                  >
-                    {{ item.variatename }}
-                  </div>
-                </div>
-              </el-col></el-row
-            > -->
-          </div>
-          <div v-if="topicobj.valueType == 1">
-            <div class="headline">
-              閫夐」璁剧疆<span style="margin-left: 30px"
-                ><el-button type="primary" round @click="addoption"
-                  >+鏂板</el-button
-                ></span
-              >
-            </div>
-            <div
-              class="topicxq"
-              v-for="item in topicobj.svyLibTopicoptions"
-              v-if="item.isoperation != 3"
-            >
-              <el-row :gutter="10">
-                <el-col :span="11"
-                  ><el-form-item label="閫夐」">
-                    <el-input
-                      type="text"
-                      placeholder="璇疯緭鍏ラ�夐」"
-                      v-model="item.optioncontent"
-                      show-word-limit
-                    >
-                    </el-input> </el-form-item
-                ></el-col>
-                <el-col :span="11"
-                  ><el-form-item label="鍒嗗��">
-                    <el-input
-                      type="text"
-                      placeholder="璇疯緭鍏�"
-                      v-model="item.score"
-                      show-word-limit
-                    >
-                    </el-input> </el-form-item
-                ></el-col>
-                <el-col :span="2">
-                  <el-button
-                    type="danger"
-                    icon="el-icon-delete"
-                    circle
-                    @click="deletexuanx(item)"
-                  ></el-button>
+                  </el-form-item>
                 </el-col>
               </el-row>
 
               <el-row :gutter="10">
-                <el-form-item label="閫変腑鎻愮ず">
-                  <el-input
-                    style="width: 40vw"
-                    type="textarea"
-                    autosize
-                    placeholder="璇疯緭鍏ュ唴瀹�"
-                    v-model="item.prompt"
-                  >
-                  </el-input
-                ></el-form-item>
+                <el-col :span="8"
+                  ><el-form-item label="闂鏍囬" prop="scriptTopic">
+                    <el-input
+                      v-model="topicobj.scriptTopic"
+                      placeholder="璇疯緭鍏ユ爣棰�"
+                    ></el-input> </el-form-item
+                ></el-col>
+                <el-col :span="8"
+                  ><el-form-item label="鏄惁鍙敤" prop="isavailable">
+                    <el-radio-group v-model="topicobj.isavailable">
+                      <el-radio
+                      @change="$forceUpdate()"
+                        v-for="(item, index) in usable"
+                        :label="item.value"
+                        >{{ item.label }}</el-radio
+                      >
+                    </el-radio-group>
+                  </el-form-item></el-col
+                >
+                <!-- <el-col :span="8">
+                  <el-form-item label="鏄惁蹇呭~" prop="ismandatory">
+                    <el-radio-group v-model="topicobj.ismandatory">
+                      <el-radio
+                      @change="$forceUpdate()"
+                        v-for="(item, index) in required"
+                        :label="item.value"
+                        >{{ item.label }}</el-radio
+                      >
+                    </el-radio-group>
+                  </el-form-item>
+                </el-col> -->
               </el-row>
+              <el-row :gutter="10">
+
+                <el-col :span="8"
+                  ><el-form-item label="闂绫诲瀷" prop="scriptType">
+                    <el-select
+                      v-model="topicobj.scriptType"
+                      @change="changefn"
+                      size="medium"
+                      filterable
+                      placeholder="璇烽�夋嫨鍒嗙被"
+                    >
+                      <el-option
+                        class="topicobjaa"
+                        v-for="item in valuetype"
+                        :key="item.value"
+                        :label="item.label"
+                        :value="item.value"
+                      >
+                      </el-option>
+                    </el-select> </el-form-item
+                ></el-col>
+                <el-col :span="8"
+                  ><el-form-item label="閫傜敤鏂瑰紡" prop="suitway">
+                    <el-select
+                      v-model="topicobj.suitway"
+                      disabled
+                      placeholder="璇烽�夋嫨"
+                    >
+                      <el-option
+                        class="topicobjaa"
+                        v-for="item in mode"
+                        :key="item.value"
+                        :label="item.label"
+                        :value="item.value"
+                      >
+                      </el-option> </el-select></el-form-item
+                ></el-col>
+                <el-col :span="8">
+                  <el-form-item label="璇█" prop="language">
+                    <el-select
+                      v-model="topicobj.language"
+                      size="medium"
+                      filterable
+                      placeholder="璇烽�夋嫨鍒嗙被"
+                    >
+                      <el-option
+                        class="topicobjaa"
+                        v-for="item in languagelist"
+                        :key="item.value"
+                        :label="item.label"
+                        :value="item.value"
+                      >
+                      </el-option>
+                    </el-select>
+                  </el-form-item>
+                </el-col>
+              </el-row>
+
+              <!-- <el-form-item
+              label=""
+              prop="scriptContent"
+              v-if="topicobj.scriptType == 3"
+            >
+              <div style="display: flex; margin-bottom: 10px">
+                <div class="tsgnames" @click="tsgnametos">鎻掑叆濉┖鏍囪</div>
+              </div>
+            </el-form-item> -->
+              <!-- <el-row>
+              <el-col :span="20">
+                <el-form-item
+                  label="濉┖淇℃伅"
+                  v-if="
+                    topicobj.scriptType == 3 &&
+                    topicobj.svyLibScriptOptions.length
+                  "
+                >
+                  <el-card class="box-card" style="width: 200%">
+                    <div
+                      v-for="item in topicobj.svyLibScriptOptions"
+                      v-if="item.isoperation != 3"
+                      style="margin-bottom: 10px"
+                    >
+                      <el-input
+                        type="text"
+                        placeholder="濉叆鍐呭淇℃伅"
+                        v-model="item.aaa"
+                      >
+                        <el-button
+                          slot="append"
+                          @click="deletexuanx(item)"
+                          type="danger"
+                          icon="el-icon-delete"
+                          circle
+                        ></el-button>
+                        <span slot="prepend">{{
+                          "(" + item.orderno + ")"
+                        }}</span>
+                      </el-input>
+                    </div>
+                  </el-card>
+                </el-form-item>
+              </el-col>
+            </el-row> -->
+
+
+              <!-- <el-form-item label="閫変腑鎸囨爣锛�">
+                <span style="margin-left: 30px"
+                  ><el-tag type="success" effect="dark">{{
+                    topicobj.targetname ? topicobj.targetname : "鏈�夋嫨"
+                  }}</el-tag></span
+                >
+                <span style="margin-left: 30px"
+                  ><el-button type="success" round @click="gettargetInfo"
+                    >+閫夋嫨鎸囨爣</el-button
+                  ></span
+                >
+              </el-form-item> -->
             </div>
-          </div>
-        </el-form>
-      </el-card>
+            <div class="headline">鍏宠仈淇℃伅閰嶇疆</div>
+            <el-divider></el-divider>
+
+            <div style="margin-left: 8%">
+              <el-row>
+                <el-form-item label="鏍囩" prop="desc">
+                  <div class="xinz-inf">
+                    <el-tag
+                      :key="tag.tagname"
+                      type="success"
+                      v-for="tag in dynamicTags"
+                      closable
+                      :disable-transitions="false"
+                      @close="handleClosetag(tag)"
+                    >
+                      {{ tag.tagname }}
+                    </el-tag>
+                    <el-select
+                      v-model="inputValue"
+                      v-if="inputVisible"
+                      @change="handleInputConfirm"
+                      filterable
+                      remote
+                      allow-create
+                      reserve-keyword
+                      default-first-option
+                      :remote-method="remoteMethodtag"
+                      :loading="loading"
+                      placeholder="璇烽�夋嫨"
+                    >
+                      <el-option
+                        v-for="item in optionstag"
+                        :key="item.tagid"
+                        :label="item.tagname"
+                        :value="item.tagname"
+                      >
+                      </el-option>
+                    </el-select>
+                    <el-button
+                      v-else
+                      class="button-new-tag"
+                      size="small"
+                      @click="showInput"
+                      >+ 鏂板鏍囩</el-button
+                    >
+                  </div>
+                </el-form-item>
+              </el-row>
+
+              <el-form-item label="棰樺共鏂囦欢" prop="sickness">
+                <div style="width: 40vw">
+                  <el-upload
+                    class="upload-demo"
+                    :action="uploadImgUrl"
+                    :headers="headers"
+                    accept=".jpg,.png,image/*"
+                    :on-success="handleChangetg"
+                  >
+                    <el-button size="small" type="primary">鐐瑰嚮涓婁紶</el-button>
+                    <div slot="tip" class="el-upload__tip">
+                      鍙兘涓婁紶jpg/png绫诲瀷鏂囦欢
+                    </div>
+                  </el-upload>
+
+                  <div style="margin: 20px">
+                    <el-image
+                      style="width: 100px; height: 100px"
+                      :src="topicobj.picturePath"
+                      :preview-src-list="[...topicobj.picturePath]"
+                    >
+                    </el-image>
+                  </div>
+                </div>
+              </el-form-item>
+            </div>
+          </el-form>
+        </el-card>
+      </div>
+      <div v-if="Editprogress == 2">
+        <el-card class="box-card">
+          <el-form :inline="true" ref="topicobj" :model="topicobj" class="demo-form-inline">
+            <div class="headline">
+              鎸囨爣璁剧疆璇︽儏
+              <span v-if="topicobj.targetname" style="margin-left: 30px"
+                ><el-button type="success" @click="topicVisible = true"
+                  >棰勮</el-button
+                ></span
+              >
+              <span style="margin-left: 30px"
+                ><el-button type="primary" round @click="gettargetInfo">{{
+                  topicobj.targetname ? "淇敼鎸囨爣" : "+閫夋嫨鎸囨爣"
+                }}</el-button></span
+              >
+              <span style="margin-left: 30px"
+                ><el-button type="primary" @click="Saveproblem"
+                  >淇� 瀛�</el-button
+                >
+              </span>
+            </div>
+            <el-divider></el-divider>
+            <el-form ref="form">
+              <el-row>
+                <el-col :span="10">
+                  <el-form-item label="鎸囨爣鍚嶇О" prop="deptId">
+                    <el-input
+                      disabled
+                      v-model="topicobj.targetname"
+                      placeholder="璇疯緭鍏ユ寚鏍囧悕绉�"
+                      maxlength="20"
+                    />
+                  </el-form-item>
+                </el-col>
+                <el-col :span="12">
+                  <el-form-item label="鎸囨爣鎻忚堪" prop="deptId">
+                    <el-input
+                      disabled
+                      v-model="topicobj.targetdesc"
+                      placeholder="璇疯緭鍏ユ寚鏍囨弿杩�"
+                      maxlength="60"
+                    />
+                  </el-form-item>
+                </el-col>
+              </el-row>
+
+              <el-row>
+                <el-col :span="10">
+                  <el-form-item label="缁撴灉绫诲瀷">
+                    <el-radio-group
+                      :disabled="true"
+                      v-model="topicobj.valueType"
+                    >
+                      <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-col :span="12">
+                  <el-form-item label="闂棰樺瀷">
+                    <el-radio-group
+                      :disabled="true"
+                      v-model="topicobj.scriptType"
+                    >
+                      <el-radio :label="'1'">鍗曢��</el-radio>
+                      <el-radio :label="'2'">澶氶��</el-radio>
+                      <el-radio :label="'4'">闂瓟</el-radio>
+                    </el-radio-group>
+                  </el-form-item>
+                </el-col>
+              </el-row>
+            </el-form>
+            <div>
+              <el-divider></el-divider>
+              <div v-if="topicobj.scriptType != 4">
+                <div class="headline">
+                  閫夐」璁剧疆<span style="margin-left: 30px"
+                    ><el-button type="primary" round @click="addoption"
+                      >+鏂板</el-button
+                    ></span
+                  >
+                </div>
+                <div
+                  class="topicxq"
+                  v-for="item in topicobj.svyLibScriptOptions"
+                  v-if="item.isoperation != 3"
+                >
+                  <el-row :gutter="10">
+                    <el-col :span="11"
+                      ><el-form-item label="閫夐」鍚嶇О">
+                        <el-input
+                          type="text"
+                          placeholder="璇疯緭鍏ラ�夐」鍒嗗��"
+                          v-model="item.optioncontent"
+                          show-word-limit
+                        >
+                        </el-input> </el-form-item
+                    ></el-col>
+                    <el-col :span="11">
+                      <el-form-item v-if="topicobj.scoretype == 1" label="鍒嗗��">
+                        <el-input
+                          type="text"
+                          placeholder="璇疯緭鍏ラ�夐」鍒嗗��"
+                          v-model="item.score"
+                          show-word-limit
+                        >
+                        </el-input>
+                      </el-form-item>
+                      <el-form-item
+                        v-else-if="topicobj.scoretype == 2"
+                        label="ABC绛夌骇"
+                      >
+                        <el-radio-group v-model="item.score">
+                          <el-radio label="A">A</el-radio>
+                          <el-radio label="B">B</el-radio>
+                          <el-radio label="C">C</el-radio>
+                        </el-radio-group>
+                      </el-form-item>
+                      <el-form-item
+                        v-else-if="topicobj.scoretype == 3"
+                        label="浼樿壇绛夌骇"
+                      >
+                        <el-radio-group v-model="item.score">
+                          <el-radio label="浼�">浼�</el-radio>
+                          <el-radio label="鑹�">鑹�</el-radio>
+                          <el-radio label="宸�">宸�</el-radio>
+                        </el-radio-group>
+                      </el-form-item>
+                    </el-col>
+
+                    <el-col
+                      :span="2"
+                      :offsset="topicobj.scoretype == 4 ? 11 : 0"
+                    >
+                      <el-button
+                        type="danger"
+                        icon="el-icon-delete"
+                        circle
+                        @click="deletexuanx(item)"
+                      ></el-button>
+                    </el-col>
+                  </el-row>
+                  <el-row :gutter="10">
+                    <el-form-item label="寮傚父鎻愰啋">
+                      <el-radio-group v-model="item.isabnormal">
+                        <el-radio :label="1">鏄�</el-radio>
+                        <el-radio :label="0">鍚�</el-radio>
+                      </el-radio-group>
+                    </el-form-item>
+                  </el-row>
+                  <el-row :gutter="10">
+                    <el-form-item label="閫変腑鎻愮ず">
+                      <el-input
+                        style="width: 40vw"
+                        type="textarea"
+                        autosize
+                        placeholder="璇疯緭鍏ュ唴瀹�"
+                        v-model="item.prompt"
+                      >
+                      </el-input
+                    ></el-form-item>
+                  </el-row>
+                  <el-form-item label="閫夐」鏂囦欢" prop="sickness">
+                    <div style="width: 40vw">
+                      <el-upload
+                        class="upload-demo"
+                        :action="uploadImgUrl"
+                        :headers="headers"
+                        accept=".jpg,.png,image/*"
+                        :on-success="handleChange.bind(this, item)"
+                      >
+                        <el-button size="small" type="primary"
+                          >鐐瑰嚮涓婁紶</el-button
+                        >
+                      </el-upload>
+                      <div style="margin: 20px">
+                        <el-image
+                          style="width: 100px; height: 100px"
+                          :src="item.picturePath"
+                          :preview-src-list="[...item.picturePath]"
+                        >
+                        </el-image>
+                      </div>
+                    </div>
+                  </el-form-item>
+                </div>
+              </div>
+              <div v-else class="topicxq">
+                <el-input
+                  type="textarea"
+                  :rows="4"
+                  placeholder="姝ゅ灞曠ず闂瓟棰樻敹闆嗕俊鎭�"
+                  v-model="testgovalue"
+                >
+                </el-input>
+              </div>
+            </div>
+          </el-form>
+        </el-card>
+      </div>
     </div>
     <el-drawer
-      title="娣诲姞閫夐」"
+      title="閫夋嫨鎸囨爣"
       :visible.sync="drawer"
       custom-class="demo-drawer"
-      width="66%"
+      size="50%"
     >
       <div class="preview-left">
         <el-form
@@ -380,7 +554,7 @@
           :inline="true"
           label-width="98px"
         >
-          <el-form-item label="鏍囬" prop="userName">
+          <el-form-item label="鎸囨爣鍚嶇О" prop="userName">
             <el-input
               v-model="queryParams.targetname"
               placeholder="璇疯緭鍏�"
@@ -388,6 +562,26 @@
               style="width: 200px"
               @keyup.enter.native="gettargetInfo"
             />
+          </el-form-item>
+          <el-form-item label="鎸囨爣璇存槑" prop="userName">
+            <el-input
+              v-model="queryParams.targetdesc"
+              placeholder="璇疯緭鍏�"
+              clearable
+              style="width: 200px"
+              @keyup.enter.native="gettargetInfo"
+            />
+          </el-form-item>
+          <el-form-item label="鎸囨爣绫诲瀷" prop="scriptType">
+            <el-select v-model="queryParams.scriptType" placeholder="璇烽�夋嫨">
+              <el-option
+                v-for="(item, index) in qyoptions"
+                :key="item.value"
+                :label="item.label"
+                :value="item.value"
+              >
+              </el-option>
+            </el-select>
           </el-form-item>
 
           <el-form-item>
@@ -405,17 +599,45 @@
         </el-form>
         <el-table v-loading="loading" :data="targetList">
           <el-table-column
-            label="鏍囬"
+            label="鎸囨爣鍚嶇О"
             align="center"
             key="targetname"
             prop="targetname"
             width="100"
           />
           <el-table-column
-            label="闂鍐呭"
+            label="鎸囨爣璇存槑"
             align="center"
             key="targetdesc"
             prop="targetdesc"
+            width="200"
+            :show-overflow-tooltip="true"
+          />
+          <el-table-column
+            label="鏄惁鍙敤"
+            align="center"
+            key="isavailable"
+            prop="isavailable"
+          >
+            <template slot-scope="scope">
+              <dict-tag :options="usable" :value="scope.row.isavailable" />
+            </template>
+          </el-table-column>
+          <el-table-column
+            label="闂绫诲瀷"
+            align="center"
+            key="scriptType"
+            prop="scriptType"
+          >
+            <template slot-scope="scope">
+              <dict-tag :options="valuetype" :value="scope.row.scriptType" />
+            </template>
+          </el-table-column>
+          <el-table-column
+            label="閫夐」璇存槑"
+            align="center"
+            key="optionDesc"
+            prop="optionDesc"
             width="200"
             :show-overflow-tooltip="true"
           />
@@ -423,6 +645,7 @@
           <el-table-column
             label="鎿嶄綔"
             align="center"
+            fixed="right"
             class-name="small-padding fixed-width"
           >
             <template slot-scope="scope">
@@ -446,6 +669,35 @@
         />
       </div>
     </el-drawer>
+    <el-dialog title="闂棰勮" :visible.sync="topicVisible" width="50%">
+      <div class="preview-left">
+        <div class="dev-text">
+          <span>{{ topicobj.scriptContent }}</span>
+        </div>
+
+        <div
+          class="dev-xx"
+          v-if="topicobj.scriptType != 3 && topicobj.scriptType != 4"
+        >
+          <el-radio-group v-model="topicobj.asrtext">
+            <el-radio
+              v-for="(topicobjs, index) in topicobj.svyLibScriptOptions"
+              :key="topicobjs.optioncontent"
+              :label="topicobjs.optioncontent"
+              >{{ topicobjs.optioncontent }}</el-radio
+            >
+          </el-radio-group>
+        </div>
+        <div v-else>
+          <el-input
+            type="textarea"
+            placeholder="璇疯緭鍏ュ唴瀹�"
+            v-model.sync="topicobj.asrtext"
+            :rows="2"
+          />
+        </div>
+      </div>
+    </el-dialog>
   </div>
 </template>
 
@@ -466,20 +718,32 @@
   illnesslistget,
   getillness,
 } from "@/api/AiCentre/index";
+import { getToken } from "@/utils/auth";
 
 export default {
   data() {
     return {
       topicobj: {
-        svyLibTopicoptions: [],
+        svyLibScriptOptions: [],
+        svyLibScriptTagList: [],
+        suitway: "1",
+        scoretype:'4',
+        language:'鏅�氳瘽',
       },
+      headers: {
+        Authorization: "Bearer " + getToken(),
+      },
+      uploadImgUrl: process.env.VUE_APP_BASE_API + "/common/uploadSort",
       inputVisible: false,
       inputValue: "",
       currentInputId: "",
+      scriptTypels: "",
       total: 0,
       drawer: false,
       loading: false,
+      topicVisible: false, //棰勮寮规
       id: [],
+      suitwaylist: [],
       targetList: [],
       dynamicTags: [],
       optionsclass: [],
@@ -488,18 +752,26 @@
         { variatename: "鐢佃瘽", variate: "${phone}", default: 1 },
         { variatename: "鐥呮儏", variate: "${illness}", default: 1 },
       ],
+      url: "https://fuss10.elemecdn.com/e/5d/4a731a90594a4af544c0c25941171jpeg.jpeg",
+      srcList: [
+        "https://fuss10.elemecdn.com/8/27/f01c15bb73e1ef3793e64e6b7bbccjpeg.jpeg",
+        "https://fuss10.elemecdn.com/1/8e/aeffeb4de74e2fde4bd74fc7b4486jpeg.jpeg",
+      ],
       // 鏌ヨ鍙傛暟
       queryParams: {
         pageNum: 1,
         pageSize: 10,
         isavailable: "",
+        scriptType: "",
       },
+      Editprogress: 1,
       optionlist: [
-        { value: "topic", table: "topic" },
-        { value: "topic", table: "topic" },
-        { value: "topic", table: "topic" },
+        { value: "scriptTopic", table: "scriptTopic" },
+        { value: "scriptTopic", table: "scriptTopic" },
+        { value: "scriptTopic", table: "scriptTopic" },
       ],
       inputValueillness: "",
+      testgovalue: "",
       required: [],
       themelist: [],
       languagelist: [],
@@ -509,37 +781,73 @@
       inputVisibleillness: false,
       illnessVisible: false, //鎸囨爣鐤剧梾寮规
       deptOptions: [],
+      qyoptions: [],
       optionsillness: [],
       illnesslistapi: [],
       illnesslist: [],
       classifylist: [],
       appraiselist: [
-        { label: "鍒嗘暟", value: 1 },
-        { label: "ABC绛夌骇", value: 2 },
-        { label: "浼樿壇绛夌骇", value: 3 },
+        { label: "鍒嗘暟", value: "1" },
+        { label: "ABC绛夌骇", value: "2" },
+        { label: "浼樿壇绛夌骇", value: "3" },
+        { label: "鏃�", value: "4" },
       ],
       optionstag: [],
       valuetype: [],
       usable: [],
       mode: [], //鏂瑰紡
+      // 琛ㄥ崟鏍¢獙
+      rules: {
+        categoryid: [
+          { required: true, message: "闂鍒嗙被涓嶈兘涓虹┖", trigger: "blur" },
+        ],
+        scoretype: [
+          { required: true, message: "璇勪环绫诲瀷涓嶈兘涓虹┖", trigger: "blur" },
+        ],
+        language: [
+          { required: true, message: "璇█涓嶈兘涓虹┖", trigger: "blur" },
+        ],
+        isavailable: [
+          { required: true, message: "鍙敤鐘舵�佷笉鑳戒负绌�", trigger: "blur" },
+        ],
+        scriptTopic: [
+          { required: true, message: "闂鏍囬涓嶈兘涓虹┖", trigger: "blur" },
+        ],
+        ismandatory: [
+          { required: true, message: "鏄惁蹇呭~涓嶈兘涓虹┖", trigger: "blur" },
+        ],
+        scriptType: [
+          { required: true, message: "闂绫诲瀷涓嶈兘涓虹┖", trigger: "blur" },
+        ],
+        suitway: [
+          { required: true, message: "閫傜敤鏂瑰紡涓嶈兘涓虹┖", trigger: "blur" },
+        ],
+        scriptContent: [
+          { required: true, message: "闂鍐呭涓嶈兘涓虹┖", trigger: "blur" },
+        ],
+      },
     };
   },
 
   created() {
     this.gettabList();
     this.getissueinfo();
-    this.gettargetInfo();
+    // this.gettargetInfo();
     this.mode = store.getters.mode;
     this.languagelist = store.getters.languagelist;
     this.usable = store.getters.usable;
     this.valuetype = store.getters.askvaluetype;
     this.required = store.getters.required;
+    this.qyoptions = store.getters.askvaluetype;
   },
 
   methods: {
     // 鍏叡鏂规硶---------------
     getIndexInArray(arr, obj) {
       return arr.indexOf(obj);
+    },
+    processElement(element) {
+      return { ...element, isoperation: 1 };
     },
     // 閫掑綊鎵佸钩鍖�
     flattenArray(arr) {
@@ -560,6 +868,10 @@
     // 鑾峰彇鏁版嵁
     getissueinfo() {
       this.id = this.$route.query.id;
+      if (this.$route.query.categoryid) {
+        this.topicobj.categoryid = Number(this.$route.query.categoryid);
+      }
+
       // 鍒嗙被
       getissueclassify({}).then((res) => {
         this.classifylist = res.rows;
@@ -567,9 +879,15 @@
       if (!this.id) {
         return;
       }
-      getissuelist({ topicid: this.id }).then((res) => {
+      getissuelist({ id: this.id }).then((res) => {
         this.topicobj = res.rows[0];
-        this.dynamicTags = this.topicobj.tag.split(",");
+        if (!this.topicobj.svyLibScriptTagList) {
+          this.topicobj.svyLibScriptTagList = [];
+        }
+        this.dynamicTags = this.topicobj.svyLibScriptTagList.map(
+          this.processElement
+        );
+        this.scriptTypels = this.topicobj.scriptType;
         this.variablelist = JSON.parse(this.topicobj.otherdata)
           ? JSON.parse(this.topicobj.otherdata)
           : this.variablelist;
@@ -585,14 +903,22 @@
       });
     },
     gettargetInfo() {
+      if (!this.queryParams.scriptType) {
+        this.queryParams.scriptType = this.topicobj.scriptType;
+      }
+
+      this.queryParams.suitWay = 1;
       gettargetInfo(this.queryParams).then((res) => {
         this.targetList = res.rows;
         this.total = res.total;
+        this.drawer = true;
       });
     },
     // 鏂板鎴栦慨鏀硅鎯�
     compileissue() {
-      this.topicobj.svyLibTopicoptions = this.topicobj.svyLibTopicoptions.map(
+      this.$refs["topicobj"].validate((valid) => {
+        if (valid) {
+          this.topicobj.svyLibScriptOptions = this.topicobj.svyLibScriptOptions.map(
         (item) => {
           if (item.isoperation != 1 && item.isoperation != 3) {
             item.isoperation = 2;
@@ -600,8 +926,11 @@
           return item;
         }
       );
+      this.topicobj.targetoptions = this.topicobj.svyLibScriptOptions
+        .filter((item) => item.isoperation != 3)
+        .map((item) => item.optioncontent)
+        .join(", ");
       this.topicobj.otherdata = JSON.stringify(this.variablelist);
-      this.topicobj.tag = this.dynamicTags.join(",");
       if (this.id) {
         this.topicobj.isoperation = 2;
         compileissue(this.topicobj).then((res) => {
@@ -643,19 +972,107 @@
       if (this.illnesslistapi.length) {
         deltargetillness(this.illnesslistapi.join(",")).then((res) => {});
       }
+        }
+      })
+
+
     },
+    // 鍒ゆ柇鍒嗗��
+    Scorejudgment() {
+      let scorearr = this.topicobj.svyLibScriptOptions;
+      let isValid = scorearr.every((score, index) => {
+        if (this.topicobj.scriptType == 1) {
+          if (score.score||score.score==0) {
+            if (
+              Number(score.score) < 0 ||
+              Number(score.score) > Number(this.topicobj.score)
+            ) {
+              console.log(score, "閿欒鍒嗗��");
+              this.$message({
+                message: "閫夐」鍒嗗�煎繀椤诲湪0鍒�" + this.topicobj.score + "鍒嗕箣闂�",
+                type: "warning",
+              });
+              return false;
+            }
+            return true;
+          } else {
+            this.$message({
+              message: "閫夐」鍒嗗�兼湭璁剧疆",
+              type: "warning",
+            });
+            return false;
+          }
+        } else if (this.topicobj.scriptType == 2) {
+          // 绱姞鍒嗗��
+          const totalScore = scorearr.reduce((acc, score) => {
+            if (score.score) {
+              return acc + Number(score.score);
+            }
+            return acc; // 濡傛灉 score.score 涓嶅瓨鍦紝涓嶇疮鍔�
+          }, 0);
+
+          // 妫�鏌ョ疮鍔犵殑鍒嗗�兼槸鍚︾瓑浜� this.topicobj.score
+          if (totalScore !== Number(this.topicobj.score)) {
+            this.$message({
+              message:
+                "澶氶�夐閫夐」鍒嗗�兼�诲拰蹇呴』绛変簬 " + this.topicobj.score + " 鍒�",
+              type: "warning",
+            });
+            return false;
+          }
+          return true; // 濡傛灉鎬诲垎姝g‘锛岃繑鍥� true
+        } else if (this.topicobj.scriptType == 4) {
+          return true;
+        }
+      });
+
+      if (isValid) {
+        this.compileissue();
+      }
+    },
+    Saveproblem() {
+      if (this.topicobj.scoretype == 1) {
+        this.Scorejudgment();
+      } else {
+        this.compileissue();
+      }
+    },
+    // 鍒ゆ柇鎸囨爣
+    changefn(item) {
+      console.log(item);
+      if (this.topicobj.targetname || this.topicobj.svyLibScriptOptions[0]) {
+        this.$modal
+          .confirm("鏇存敼绫诲瀷鍚庨�夐」灏嗘竻绌烘槸鍚︾户缁紵")
+          .then(() => {
+            this.scriptTypels = this.topicobj.scriptType;
+            this.topicobj.svyLibScriptOptions.forEach((item) => {
+              item.isoperation = 3;
+            });
+          })
+          .catch(() => {
+            this.topicobj.scriptType = this.scriptTypels;
+          });
+      }
+    },
+
     // 鍒犻櫎閫夐」
     deletexuanx(row) {
-      const index = this.getIndexInArray(this.topicobj.svyLibTopicoptions, row);
-      if (this.topicobj.svyLibTopicoptions[index].topicid) {
-        this.topicobj.svyLibTopicoptions[index].isoperation = 3;
+      const index = this.getIndexInArray(
+        this.topicobj.svyLibScriptOptions,
+        row
+      );
+      console.log(this.topicobj.svyLibScriptOptions);
+
+      if (this.topicobj.svyLibScriptOptions[index].id) {
+        this.topicobj.svyLibScriptOptions[index].isoperation = 3;
       } else {
-        this.topicobj.svyLibTopicoptions.splice(index, 1);
+        this.topicobj.svyLibScriptOptions.splice(index, 1);
       }
     },
     // 鏂板閫夐」
     addoption() {
-      this.topicobj.svyLibTopicoptions.push({
+      console.log(this.topicobj, "obj");
+      this.topicobj.svyLibScriptOptions.push({
         score: "",
         isoperation: 1,
       });
@@ -664,20 +1081,23 @@
     selectlabel(row) {
       this.$modal
         .confirm(
-          '鏄惁閫夋嫨鏍囬涓�"' + row.targetname + '"鐨勬寚鏍囧苟鏇挎崲濉厖闂淇℃伅锛�'
+          '鏄惁閫夋嫨鏍囬涓�"' +
+            row.targetname +
+            '"鐨勬寚鏍囧苟鏇挎崲濉厖闂鍙婇�夐」淇℃伅锛�'
         )
         .then(() => {
           console.log(row);
-          console.log(this.topicobj);
-          this.topicobj.topic = row.targetname;
+          this.topicobj.scriptTopic = row.targetname;
           this.topicobj.valueType = row.valueType;
-          this.topicobj.topicContent = row.targetdesc;
-          this.topicobj.isavailable = "0";
-          this.topicobj.language = "鏅�氳瘽";
-          this.topicobj.svyLibTopicoptions = [];
+          this.topicobj.scriptType = row.scriptType;
+          this.topicobj.scriptContent = row.targetdesc;
+          this.topicobj.targetid = row.id;
+          this.topicobj.prompt = row.prompt;
+          this.topicobj.targetname = row.targetname;
+          this.topicobj.svyLibScriptOptions = [];
           const labellist = row.targetoptionList;
           labellist.forEach((item) => {
-            this.topicobj.svyLibTopicoptions.push({
+            this.topicobj.svyLibScriptOptions.push({
               optioncontent: item.targetvalue,
               isoperation: 1,
             });
@@ -695,14 +1115,14 @@
         tagcategoryid: "0",
       };
       listtag(tagqueryParams).then((response) => {
-        console.log(response);
         this.optionstag = response.rows;
       });
     },
     handleClosetag(tag) {
-      console.log(tag);
       console.log(this.dynamicTags.indexOf(tag));
+      const lindex = this.dynamicTags.indexOf(tag);
       this.dynamicTags.splice(this.dynamicTags.indexOf(tag), 1);
+      this.topicobj.svyLibScriptTagList[lindex].delFlag = 1;
     },
     handleInputConfirm() {
       let tagvalue = {};
@@ -724,7 +1144,8 @@
             };
           }
           // this.dynamicTags.push(tagvalue);
-          this.dynamicTags.push(tagvalue.tagname);
+          this.topicobj.svyLibScriptTagList.push(tagvalue);
+          this.dynamicTags.push(tagvalue);
         });
       }
       this.inputVisible = false;
@@ -787,36 +1208,38 @@
       this.inputVisibleillness = false;
       this.inputValueillness = "";
     },
-    // 淇濆瓨
-    confirmillness() {
-      this.illnesslist.forEach((item, index) => {
-        if (!item.id) {
-          addtargetillness(item).then((res) => {});
-        }
-      });
-      if (this.illnesslistapi.length) {
-        deltargetillness(this.illnesslistapi.join(",")).then((res) => {});
-      }
-      this.illnessVisible = false;
-      this.$modal.msgSuccess("缂栬緫鎴愬姛");
+    // // 淇濆瓨
+    // confirmillness() {
+    //   this.illnesslist.forEach((item, index) => {
+    //     if (!item.id) {
+    //       addtargetillness(item).then((res) => {});
+    //     }
+    //   });
+    //   if (this.illnesslistapi.length) {
+    //     deltargetillness(this.illnesslistapi.join(",")).then((res) => {});
+    //   }
+    //   this.illnessVisible = false;
+    //   this.$modal.msgSuccess("缂栬緫鎴愬姛");
+    // },
+    resetQuery() {
+      this.queryParams = {
+        pageNum: 1,
+        pageSize: 10,
+      };
+      this.gettargetInfo();
     },
-    resetQuery() {},
-    // 渚挎嵎鏍囩
-    tsgnameto(row) {
+
+    // 渚挎嵎鏍囩鎻掑叆濉┖
+    tsgnametos(row) {
       let inputValueArr = "";
+      let value = this.topicobj.svyLibScriptOptions.length + 1;
+
       let el = document.querySelector("#" + this.currentInputId);
       //el.selectionStart; 杩欏氨鏄綋鍓嶅厜鏍囨墍鍦ㄧ殑浣嶇疆锛堝瓧绗︿覆涓瓧绗︾殑index锛�
-      if (this.currentInputId == "topicContent") {
-        inputValueArr = this.topicobj.topicContent.split("");
-        console.log(123);
-      } else if (this.currentInputId == "nomatchtext") {
-        inputValueArr = this.topicobj.nomatchtext.split("");
-      } else if (this.currentInputId == "sliencetext") {
-        inputValueArr = this.topicobj.sliencetext.split("");
-      } else if (this.currentInputId == "noclearlytext") {
-        inputValueArr = this.topicobj.noclearlytext.split("");
-      } else if (this.currentInputId == "submoduletext") {
-        inputValueArr = this.topicobj.submoduletext.split("");
+      if (this.currentInputId == "scriptContent") {
+        console.log(1);
+        inputValueArr = this.topicobj.scriptContent.split("");
+        console.log(2);
       } else {
         return;
       }
@@ -825,20 +1248,22 @@
       // 鎷垮埌閫変腑鏂囧瓧鐨勯暱搴︼紙鍚庣画鍙互鐢ㄦ潵鏇挎崲閫変腑鐨勬枃瀛楋級
       let selectLength = el.selectionEnd - el.selectionStart;
       // 灏嗚鎻掑叆/鏇挎崲鐨勬枃瀛楁彃鍏�/鏇挎崲锛坴alue.name鏄鎻掑叆/鏇挎崲鐨勫瓧绗︿覆锛�
-      inputValueArr.splice(el.selectionStart, selectLength, `${row.variate}`);
+      inputValueArr.splice(
+        el.selectionStart,
+        selectLength,
+        "__" + value + "__"
+      );
+      this.topicobj.svyLibScriptOptions.push({
+        orderno: value,
+        optiondesc: "",
+        isoperation: 1,
+      });
       // 鎶婃暟缁勯噸鏂拌浆鎹负瀛楃涓插苟璧嬪��
       inputValueArr = inputValueArr.join("");
+
       console.log(inputValueArr);
-      if (this.currentInputId == "topicContent") {
-        this.topicobj.topicContent = inputValueArr;
-      } else if (this.currentInputId == "nomatchtext") {
-        this.topicobj.nomatchtext = inputValueArr;
-      } else if (this.currentInputId == "sliencetext") {
-        this.topicobj.sliencetext = inputValueArr;
-      } else if (this.currentInputId == "noclearlytext") {
-        this.topicobj.noclearlytext = inputValueArr;
-      } else if (this.currentInputId == "submoduletext") {
-        this.topicobj.submoduletext = inputValueArr;
+      if (this.currentInputId == "scriptContent") {
+        this.topicobj.scriptContent = inputValueArr;
       } else {
         return;
       }
@@ -866,6 +1291,87 @@
       console.log("杈撳叆妗嗙殑鍊煎凡鏇存柊:", this.currentInputId);
       // 鍦ㄨ繖閲屾墽琛屾洿鏂版暟鎹殑閫昏緫
     },
+    // 娣峰悎璺嚎
+    generateCombinations(arrays, currentIndex = 0, currentCombination = []) {
+      if (currentIndex === arrays.length) {
+        return [currentCombination];
+      }
+
+      const currentArray = arrays[currentIndex];
+      const newCombinations = [];
+
+      for (const item of currentArray) {
+        const newCombination = [...currentCombination, item];
+        const combinations = this.generateCombinations(
+          arrays,
+          currentIndex + 1,
+          newCombination
+        );
+        newCombinations.push(...combinations);
+      }
+      return newCombinations;
+    },
+    // 鎵ц
+    test() {
+      const arrays = [
+        ["2", "3", "4", "5"],
+        ["1", "2", "5", "6"],
+        ["3", "4", "5", "3"],
+        ["3", "2", "5", "7"],
+      ];
+
+      const newMixArray = this.generateCombinations(arrays);
+      console.log(newMixArray, "鍏ㄩ儴璺嚎");
+      this.screen(newMixArray);
+    },
+    // 鏁扮粍姹傚拰
+    sumArray(arr) {
+      return arr.reduce((acc, curr) => acc + parseInt(curr), 0);
+    },
+    // 绛涢�夐敊璇矾绾�
+    screen(data) {
+      const arraysGreaterThan10 = data.filter((arr) => this.sumArray(arr) > 21);
+      console.log(arraysGreaterThan10, "绛涢�夐敊璇矾绾垮ぇ浜�13鍒�");
+    },
+    // 閫夐」鏂囦欢涓婁紶
+    handleChange(item, response, file, fileList) {
+      console.log(response);
+      if (response.code == 200) {
+        console.log(item);
+        let index = this.topicobj.svyLibScriptOptions.findIndex(
+          (obj) => obj.optioncontent == item.optioncontent
+        );
+        console.log(index);
+        this.topicobj.svyLibScriptOptions[index].picturePath = response.url;
+        console.log(this.topicobj.svyLibScriptOptions[index]);
+        this.$forceUpdate();
+      } else {
+        this.$message.error("鍥剧墖鎻掑叆澶辫触");
+      }
+    },
+    // 棰樺共鏂囦欢涓婁紶
+    handleChangetg(response, file, fileList) {
+      if (response.code == 200) {
+        this.topicobj.picturePath = response.url;
+      } else {
+        this.$message.error("鍥剧墖鎻掑叆澶辫触");
+      }
+    },
+    // 涓嬩竴姝�
+    nextstep() {
+      if (this.Editprogress <= 1) {
+        // if (this.indexform.targetid) {
+        return this.Editprogress++;
+        // } else {
+        //   this.$message.warning("璇峰厛閫夋嫨鍏宠仈鎸囨爣");
+        // }
+      } else {
+      }
+    },
+    // 涓婁竴姝�
+    laststep() {
+      this.Editprogress = this.Editprogress - 1;
+    },
   },
 };
 </script>
@@ -876,20 +1382,14 @@
   padding: 0 20px;
   font-size: 18px;
   overflow: auto;
-  .headline {
-    font-size: 20px;
-    border-left: 3px solid #41a1be;
-    padding-left: 5px;
-    margin: 15px 0;
-  }
+
   .topicxq {
-    width: 68%;
+    width: 72%;
     background-color: #e2f5fc;
     border-radius: 4px;
     margin-top: 15px;
     margin-left: 10%;
-    padding-left: 10px;
-    padding-top: 15px;
+    padding: 20px;
     border: 1px solid #dcdfe6;
     -webkit-box-shadow: 0 2px 4px 0 rgba(0, 0, 0, 0.12),
       0 0 6px 0 rgba(0, 0, 0, 0.04);
@@ -919,6 +1419,21 @@
     }
   }
 }
+.sidecolumn {
+  margin-bottom: 10px;
+  padding: 15px;
+  background: #edf1f7;
+  border: 1px solid #dcdfe6;
+  -webkit-box-shadow: 0 2px 4px 0 rgba(0, 0, 0, 0.12),
+    0 0 6px 0 rgba(0, 0, 0, 0.04);
+}
+.headline {
+  display: flex;
+  font-size: 20px;
+  border-left: 4px solid #41a1be;
+  padding-left: 5px;
+  margin: 15px 0;
+}
 .tsgname {
   width: 90px;
   margin-right: 10px;
@@ -934,6 +1449,21 @@
 .tsgname:hover {
   background: #3366f5;
 }
+.tsgnames {
+  width: 120px;
+  margin-right: 10px;
+  text-align: center;
+  cursor: pointer;
+  height: 40px;
+  line-height: 40px;
+  background: #66c18c;
+  color: #ffff;
+  font-size: 18px;
+  border-radius: 5px;
+}
+.tsgnames:hover {
+  background: #20894d;
+}
 .preview-left {
   margin: 20px;
   //   margin: 20px;
@@ -942,7 +1472,7 @@
   border: 1px solid #dcdfe6;
   -webkit-box-shadow: 0 2px 4px 0 rgba(0, 0, 0, 0.12),
     0 0 6px 0 rgba(0, 0, 0, 0.04);
-  .topic-dev {
+  .scriptTopic-dev {
     margin-bottom: 25px;
     font-size: 20px !important;
     .dev-text {
--
Gitblit v1.9.3