From 3a22df383af6fc137fd66cc29408b120619ee95f Mon Sep 17 00:00:00 2001
From: liudong <liudong>
Date: 星期五, 16 八月 2024 20:25:11 +0800
Subject: [PATCH] 会话页面开发

---
 src/views/dmx/knowledgeLib/tool.vue |  162 +++++++++++++++++++++++++++++++++++++++---------------
 1 files changed, 117 insertions(+), 45 deletions(-)

diff --git a/src/views/dmx/knowledgeLib/tool.vue b/src/views/dmx/knowledgeLib/tool.vue
index d203189..9fd67da 100644
--- a/src/views/dmx/knowledgeLib/tool.vue
+++ b/src/views/dmx/knowledgeLib/tool.vue
@@ -1,5 +1,5 @@
 <template>
-  <a-button type="text" @click="handleClick" size="small">
+  <a-button type="text"  :disabled="props.item.run == '1'" @click="handleClick" size="small">
     <template #icon>
       <icon-tool />
     </template>
@@ -15,10 +15,13 @@
   >
     <a-tabs default-active-key="1">
       <a-tab-pane key="1">
-        <template #title> <icon-calendar /> 瑙f瀽鏂规硶 </template>
+        <template #title>
+          <icon-calendar />
+          瑙f瀽鏂规硶
+        </template>
         <div style="width: 100%">
           <div style="display: flex; align-items: center">
-            <div> 瑙f瀽鏂规硶: </div>
+            <div> 瑙f瀽鏂规硶:</div>
             <div style="margin-left: 10px">
               <a-select v-model="form.parser_id" placeholder="璇烽�夋嫨">
                 <a-option
@@ -38,8 +41,15 @@
               auto-label-width
               @submit="handleSubmit"
             >
-              <a-divider style="margin-top: 10px" />
-              <a-form-item field="slider" label="鍧桾oken鏁�">
+              <a-divider
+                style="margin-top: 10px"
+                v-if="form.parser_id === 'naive'"
+              />
+              <a-form-item
+                field="slider"
+                label="鍧桾oken鏁�"
+                v-if="form.parser_id === 'naive'"
+              >
                 <a-slider
                   v-model="form.chunk_token_num"
                   :min="0"
@@ -47,14 +57,32 @@
                   show-input
                 />
               </a-form-item>
-              <a-divider style="margin-top: 10px" />
-              <a-form-item field="raptor" label="浣跨敤鍙洖澧炲己RAPTOR绛栫暐">
-                <a-space direction="vertical" size="large">
-                  <a-switch
-                    v-model="form.use_raptor"
-                    @change="onChangeRAPTOR"
-                  />
-                </a-space>
+              <a-divider
+                style="margin-top: 10px"
+                v-if="
+                  form.parser_id === 'naive' ||
+                  form.parser_id === 'qa' ||
+                  form.parser_id === 'manual' ||
+                  form.parser_id === 'laws' ||
+                  form.parser_id === 'book'
+                "
+              />
+              <a-form-item
+                field="raptor"
+                label="浣跨敤鍙洖澧炲己RAPTOR绛栫暐"
+                v-if="
+                  form.parser_id === 'naive' ||
+                  form.parser_id === 'qa' ||
+                  form.parser_id === 'manual' ||
+                  form.parser_id === 'laws' ||
+                  form.parser_id === 'book'
+                "
+              >
+                <a-switch
+                  v-model="form.use_raptor"
+                  @change="onChangeRAPTOR"
+                  size="small"
+                />
               </a-form-item>
               <div v-if="form.use_raptor">
                 <a-form-item field="prompt" label="鎻愮ず璇�">
@@ -125,8 +153,8 @@
                     style="margin-left: 10px"
                     type="primary"
                     html-type="submit"
-                    >纭畾</a-button
-                  >
+                    >纭畾
+                  </a-button>
                 </div>
               </a-form-item>
             </a-form>
@@ -134,7 +162,10 @@
         </div>
       </a-tab-pane>
       <a-tab-pane key="2">
-        <template #title> <icon-clock-circle /> 鍒涘缓瑙f瀽鍧� </template>
+        <template #title>
+          <icon-clock-circle />
+          鍒涘缓瑙f瀽鍧�
+        </template>
         <div class="details">
           <div class="details-header">
             <div
@@ -158,8 +189,9 @@
                   type="outline"
                   class="button"
                   style="margin-right: 10px"
-                  >鎵归噺<icon-down style="margin-left: 4px"
-                /></a-button>
+                  >鎵归噺
+                  <icon-down style="margin-left: 4px" />
+                </a-button>
                 <template #content>
                   <a-space direction="vertical">
                     <a-checkbox
@@ -246,8 +278,9 @@
                   type="outline"
                   class="button"
                   style="margin-right: 10px"
-                  ><icon-sort
-                /></a-button>
+                >
+                  <icon-sort />
+                </a-button>
                 <template #content>
                   <a-radio-group
                     v-model="available_int"
@@ -274,8 +307,8 @@
                 <div
                   class="groupList"
                   :class="{
-                    groupActive: keyBg == '1',
-                    groupNoActive: keyBg != '1',
+                    groupActive: keyBg == index,
+                    groupNoActive: keyBg != index,
                   }"
                   v-for="(item, index) in listData"
                   :key="index"
@@ -283,8 +316,8 @@
                   <a-checkbox :value="item.chunk_id"></a-checkbox>
                   <div
                     class="groupList-content emphaRed"
-                    @click="groupListContentClick('1')"
-                    @dblclick="contentClick(1)"
+                    @click="groupListContentClick(index)"
+                    @dblclick="contentClick(item)"
                     v-html="item.content_with_weight"
                   >
                   </div>
@@ -294,6 +327,7 @@
                       :checked-value="1"
                       :unchecked-value="0"
                       @change="handleChangeStatus(item)"
+                      size="small"
                     />
                   </div>
                 </div>
@@ -301,7 +335,12 @@
             </a-spin>
           </div>
         </div>
-        <eidtDetails ref="eidtDil"></eidtDetails>
+        <eidtDetails
+          ref="eidtDil"
+          :item="eidtDilinfo"
+          v-model:eidtDilVisible="eidtDilVisible"
+          @canplaythrough="canplaythrough"
+        ></eidtDetails>
       </a-tab-pane>
     </a-tabs>
   </a-modal>
@@ -323,14 +362,18 @@
     queryChunkList,
     chunkSwitch,
     chunkRm,
+    achunkGet,
   } from '@/api/kbList';
   import addDetails from '@/views/dmx/knowledgeLib/addDetails.vue';
   import eidtDetails from '@/views/dmx/knowledgeLib/eidtDetails.vue';
+
   const visible = ref(false);
   const loading = ref(false);
   const radio = ref('1');
   const keyBg = ref('');
   const eidtDil = ref();
+  const eidtDilVisible = ref(false);
+  const eidtDilinfo = reactive({});
 
   const props = defineProps(['kbtenantInfo', 'item', 'kbdetail']);
   // const emit =  defineEmits(['upTabdateItem'])
@@ -348,6 +391,18 @@
       value: value1,
     };
   });
+
+  // 杩囨护瑙f瀽鏂规硶
+
+  const filterParserArr = [
+    'naive',
+    'qa',
+    'resume',
+    'manual',
+    'book',
+    'laws',
+    'one',
+  ];
 
   const isBtn = ref(true);
 
@@ -367,7 +422,7 @@
   });
 
   const form = reactive({
-    parser_id: props.item.parser_id,
+    parser_id: '',
     doc_id: props.item.id,
     max_token: 698,
     threshold: 0.3,
@@ -397,6 +452,7 @@
   const formatter = (value) => {
     return value / 100;
   };
+
   function randomNumber() {
     // 鐢熸垚涓�涓粙浜巑in鍜宮ax涔嬮棿鐨勯殢鏈烘暣鏁帮紙鍖呭惈min鍜宮ax锛�
     const min = 1; // 鏈�灏忓��
@@ -438,14 +494,30 @@
     visible.value = false;
   };
 
-  const contentClick = (done) => {
-    eidtDil.value.handleClick();
+  const contentClick = async (item) => {
+    try {
+      const data = await achunkGet({
+        chunk_id: item.chunk_id,
+      });
+      // console.log(data.data);
+      Object.assign(eidtDilinfo, data.data);
+      eidtDilVisible.value = true;
+    } catch (error) {
+      Message.error('鑾峰彇澶辫触');
+    }
   };
   const handleOpened = (el) => {
     // console.log('props',props.kbtenantInfo);
-    // console.log('props',props.item);
+    console.log('props', props.item);
     // console.log('props',props.kbdetail);
     console.log(parser_ids, 'parser_ids');
+    let parser_id = props.item.parser_id;
+    parser_ids.forEach((item) => {
+      if (item.name == parser_id) {
+        form.parser_id = item.value;
+      }
+    });
+
     // Object.assign(form,{
     //   name: '',// 鐢ㄦ埛鍚�
     //   nameJoin: '',// 鏄电О
@@ -482,16 +554,6 @@
 
   const handleChange = (values) => {
     data.value = values;
-    // if (values.length === 3) {
-    //   checkedAll.value = true;
-    //   indeterminate.value = false;
-    // } else if (values.length === 0) {
-    //   checkedAll.value = false;
-    //   indeterminate.value = false;
-    // } else {
-    //   checkedAll.value = false;
-    //   indeterminate.value = true;
-    // }
   };
 
   //鎵归噺鍚敤鍒犻櫎绂佺敤
@@ -530,14 +592,13 @@
   };
 
   const handleChangeStatus = (val) => {
-    console.log(val);
     updateChunkStatus(val);
   };
   const isLoading = ref(true);
   // 鑷畾涔夊姞杞芥彁绀烘枃鏈�
   const tip = '鍔犺浇涓紝璇风◢鍊�...';
   //鑾峰彇鍒楄〃
-  const getList = () => {
+  const getList = async () => {
     let params = {
       doc_id: props.item.id,
       keywords: form.keywords,
@@ -547,7 +608,7 @@
     if (available_int.value !== '') {
       params.available_int = available_int.value;
     }
-    queryChunkList(params).then((res) => {
+    await queryChunkList(params).then((res) => {
       if (res.code == 0) {
         listData.value = res.data.chunks;
         isLoading.value = false;
@@ -598,31 +659,39 @@
     });
   };
 
-  onBeforeMount(() => {});
-  onMounted(() => {
+  onBeforeMount(() => {
     getList();
   });
+  onMounted(() => {});
 </script>
 
 <style scoped lang="less">
   .parser {
     width: 100%;
-    ::v-deep .arco-btn-outline:hover,
+
+    .arco-btn-outline:hover,
     .arco-btn-outline,
     .arco-btn-outline[type='button'] {
       color: #2a2a2b;
       border: 1px solid #2a2a2b;
     }
+
     .button {
       //color: #2a2a2b!important;
     }
   }
+
+  ::-webkit-scrollbar {
+    display: none;
+  }
+
   .groupMain {
     width: 100%;
     height: 500px;
     overflow: auto;
     display: flex;
     justify-content: center;
+
     .groupList {
       display: flex;
       padding: 24px;
@@ -631,6 +700,7 @@
       border: 1px solid #f0f0f0;
       margin-bottom: 20px;
       overflow: auto;
+
       .groupList-content {
         width: 700px;
         //height: 100px;
@@ -645,6 +715,7 @@
       }
     }
   }
+
   :deep(.emphaRed em) {
     color: red !important;
   }
@@ -652,6 +723,7 @@
   .groupActive {
     background: #eff8ff;
   }
+
   .groupNoActive {
     background: var(--color-bg-1);
     color: var(--color-text-1);

--
Gitblit v1.8.0