From 95baade90cc1d433201fe6a43455b40b5907ea4b Mon Sep 17 00:00:00 2001
From: yinbangzhong <zhongbangyin@126.com>
Date: 星期四, 01 八月 2024 15:54:35 +0800
Subject: [PATCH] 权限智能体添加

---
 src/views/dmx/knowledgeLib/index.vue |  114 +++++++++++++++++++++++++++++++++++++++++++--------------
 1 files changed, 86 insertions(+), 28 deletions(-)

diff --git a/src/views/dmx/knowledgeLib/index.vue b/src/views/dmx/knowledgeLib/index.vue
index 8c3947b..2fa72fd 100644
--- a/src/views/dmx/knowledgeLib/index.vue
+++ b/src/views/dmx/knowledgeLib/index.vue
@@ -26,7 +26,6 @@
                   <a-popconfirm content="纭畾鍒犻櫎鍚�?" @ok="deleteKnowledge(tab.id)" type="warning">
                     <span style="cursor: pointer;color: #0960bd;font-size: 12px"><icon-delete />鍒犻櫎</span>
                   </a-popconfirm>
-
                 </template>
               </a-popover>
             </div>
@@ -37,7 +36,7 @@
         <a-tabs default-active-key="1">
           <a-tab-pane key="1" :title= "t('dmx.list.DataSet')">
             <div class="rt-container-main">
-              <a-card  ref="account" class="general-card" :title="$t('')" style="padding-top: 20px">
+              <a-card  ref="account" class="general-card" title="" style="padding-top: 20px">
                 <a-row>
                   <a-col :flex="1" :span="12">
                     <a-form
@@ -51,8 +50,10 @@
                           <a-input-search
                             :placeholder="$t('cardList.searchInput.placeholder')"
                             style="width: 200px;margin-right: 10px"
+                            v-model="keywords"
+                            @change="search"
                           />
-                          <!--            鏂板缓-->
+                          <!--鏂板缓-->
                           <add :kbobj="kbobj" @changeFetchData="changeFetchData"/>
                         </a-col>
                       </a-row>
@@ -89,7 +90,7 @@
                     <!--            {{ $t('searchTable.operation.download') }}-->
                     <!--          </a-button>-->
                     <a-tooltip :content="$t('searchTable.actions.refresh')">
-                      <div class="action-icon" @click="search"
+                      <div class="action-icon"
                       ><icon-refresh size="18"
                       /></div>
                     </a-tooltip>
@@ -170,7 +171,7 @@
 <!--                    <span>{{ parser_ids[record.parser_id]}}</span>-->
 <!--                  </template>-->
                   <template #status="{ record }">
-                    <a-switch v-model="record.status"  checked-value="1" unchecked-value="0" @change="handleChangeStatus(record)"/>
+                    <a-switch v-model="record.status" size="small" checked-value="1" unchecked-value="0" @change="handleChangeStatus(record)"/>
                   </template>
                   <template #run="{ record }">
                     <div style="display: flex;align-items: center;">
@@ -222,11 +223,18 @@
                         </template>
                       </a-button>
                     </a-popconfirm>
-                    <a-button type="text" size="small">
+                    <a-button type="text" size="small" @click="onDownloadDocument(record)">
                       <template #icon>
                         <icon-download />
                       </template>
                     </a-button>
+
+                    <a-button type="text" size="small"  @click="seeload(record)">
+                      <template #icon>
+                        <icon-eye />
+                      </template>
+                    </a-button>
+
                   </template>
                 </a-table>
               </a-card>
@@ -234,12 +242,12 @@
           </a-tab-pane>
           <a-tab-pane key="2" :title="t('dmx.list.test')">
             <div class="rt-container-main">
-              <test ></test>
+              <test ref="testForm"></test>
             </div>
           </a-tab-pane>
           <a-tab-pane key="3" :title="t('dmx.list.disposition')">
             <div class="rt-container-main">
-              <config ></config>
+              <config ref="configForm" :kbtenantInfo="kbtenantInfo"  :kbobj="kbobj"></config>
             </div>
           </a-tab-pane>
         </a-tabs>
@@ -281,11 +289,17 @@
         </div>
       </div>
     </div>
+    <a-modal v-model:visible="visible" :footer="false" fullscreen>
+<!--      <docx v-if="documenttype=='docx'" previewSrc="http://192.168.20.116:1080/v1/document/get/405c3efa4d8c11ef97560242ac120006"></docx>-->
+      <docx v-if="documenttype=='docx'" :previewSrc="previewSrc"></docx>
+      <excel v-if="documenttype=='excel'" :previewSrc="previewSrc"></excel>
+      <txtPdf v-if="documenttype=='txtPdf'" :previewSrc="previewSrc"></txtPdf>
+    </a-modal>
   </div>
 </template>
 
 <script lang="ts" setup>
-import { computed, ref, reactive, watch, nextTick, onBeforeMount } from "vue";
+import { computed, ref, reactive, watch, nextTick, onBeforeMount, onMounted } from "vue";
   import { useI18n } from 'vue-i18n';
   import useLoading from '@/hooks/loading';
 import {
@@ -295,7 +309,7 @@
   queryKbDocumentList,
   deleteKnow,
   queryKbdetail,
-  queryKbtenantInfo, kbdocumentrm, kbdocumentchangeparser, kbdocumentrun, kbdocumentchangeStatus
+  queryKbtenantInfo, kbdocumentrm, kbdocumentchangeparser, kbdocumentrun, kbdocumentchangeStatus,downloadFile
 } from "@/api/kbList";
   import { Pagination } from '@/types/global';
   import type { SelectOptionData } from '@arco-design/web-vue/es/select/interface';
@@ -309,8 +323,13 @@
   import test from '@/views/dmx/knowledgeLib/test.vue'
   import tool from '@/views/dmx/knowledgeLib/tool.vue'
   import addDetails from '@/views/dmx/knowledgeLib/addDetails.vue'
-import { Message } from "@arco-design/web-vue";
-import { parseTime } from "@/utils";
+  import docx from '@/views/dmx/knowledgeLib/components/docx.vue'
+  import excel from '@/views/dmx/knowledgeLib/components/excel.vue'
+  import txtPdf from '@/views/dmx/knowledgeLib/components/txtPdf.vue'
+  import { Message } from "@arco-design/web-vue";
+  import { parseTime } from "@/utils";
+  import { usePinia } from "@/store";
+  const store = usePinia();
   type SizeProps = 'mini' | 'small' | 'medium' | 'large';
   type Column = TableColumnData & { checked?: true };
   const account = ref(null)
@@ -333,11 +352,18 @@
 
   const size = ref<SizeProps>('medium');
   let visible = ref(false)
+  let keywords = ref('')
   let detailsShow = ref(false)
   let selectedTab = ref(0)
+  let testForm = ref(null)
+  let configForm = ref(null)
+  let documenttype = ref('docx')
+  let previewSrc = ref('')
+  let kbId = ref('')
   let kbobj = reactive({})
   let kbdetail = reactive({})
   let parser_ids = reactive({})
+  let seeObj = reactive({})
   let kbtenantInfo = reactive({
     "asr_id": "paraformer-realtime-8k-v1",
     "embd_id": "BAAI/bge-large-zh-v1.5",
@@ -354,8 +380,11 @@
 
   const  selectTab = (index,item) => {
     selectedTab.value= index;
-    console.log(item.id);
-    kbobj= item
+    // console.log(item.id);
+    kbobj= item;
+    kbId = kbobj.id;
+    testForm.value.changekbid(kbId);
+    configForm.value.changekbObj(kbobj);
     fetchData({
       kb_id: kbobj.id,
       page: 1,
@@ -423,8 +452,8 @@
       title: t('dmx.column.Operate'),
       dataIndex: 'action',
       slotName: 'action',
-      width: 150,
-      minWidth: 150,
+      width: 200,
+      minWidth: 200,
     },
   ]);
   const contentTypeOptions = computed<SelectOptionData[]>(() => [
@@ -474,7 +503,7 @@
           acc[key] = value;
           return acc;
         }, {});
-        console.log(parser_ids, 'parser_ids');
+        // console.log(parser_ids, 'parser_ids');
         kbtenantInfo.parser_idObj = parser_ids;
         renderData.value = data.data.docs||[];
         renderData.value = renderData.value.map((item) => {
@@ -484,7 +513,7 @@
             parser_id: parser_ids[item.parser_id],
           };
         });
-        console.log(renderData.value, 'renderData.value');
+        console.log(renderData.value, 'renderData');
 
         pagination.current = params.page;
         pagination.total = data.data.total;
@@ -505,11 +534,12 @@
   };
 
   const search = () => {
-    alert(1)
-    // fetchData({
-    //   ...basePagination,
-    //   ...formModel.value,
-    // });
+    fetchData({
+      kb_id: kbobj.id,
+      page: 1,
+      page_size: 20,
+      keywords:keywords.value
+    })
   };
 
   const handleClick = ()=>{
@@ -531,6 +561,9 @@
       console.log(tabs.value, 'tabs');
       if(tabs.value.length>0 && tabs.value[0]){
         kbobj = tabs.value[0]
+        kbId = kbobj.id;
+        testForm.value.changekbid(kbId);
+        configForm.value.changekbObj(kbobj);
         fetchData({
           kb_id: kbobj.id,
           page: 1,
@@ -645,6 +678,33 @@
       })
     }
   }
+  const   onDownloadDocument =  async (record)=>{
+    console.log(record);
+    downloadFile({
+      url: `/api/v1/document/get/${record.id}`,
+      filename: record.name,
+    });
+  }
+const   seeload = async (row)=>{
+  Object.assign(seeObj, row)
+  console.log(seeObj.name, 'seeObj');
+  let type = seeObj.name.split('.')[1];
+  console.log(type);
+  if(type=='pdf'){
+    documenttype.value = 'txtPdf'
+  }else if(type=='docx'){
+    documenttype.value = 'docx'
+  }else if(type=='xlsx'){
+    documenttype.value = 'excel'
+  }else if(type=='txt'){
+    documenttype.value = 'txtPdf'
+  }else {
+    return false
+  }
+  previewSrc.value = `${import.meta.env.VITE_API_BASE_URL}/v1/document/get/${row.id}`
+  visible.value = true;
+
+}
 
 const   handleChangeStatus =  async (row)=>{
   console.log(row);
@@ -671,11 +731,6 @@
     doc_ids: [row.id],
     run: run
   })
-  // let data = await kbdocumentchangeparser({
-  //   parser_id: row.parser_id,
-  //   doc_id: row.id,
-  //   parser_config: row.parser_config,
-  // })
   if(data.code == 0){
     Message.success('瑙f瀽鎴愬姛');
     row.run = '3';
@@ -707,6 +762,9 @@
   );
 
   onBeforeMount(()=>{
+
+  })
+  onMounted(()=>{
     knowledgeData()
   })
 

--
Gitblit v1.8.0