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/eidtDetails.vue |  216 +++++++++++++++++++++++++++++------------------------
 1 files changed, 117 insertions(+), 99 deletions(-)

diff --git a/src/views/dmx/knowledgeLib/eidtDetails.vue b/src/views/dmx/knowledgeLib/eidtDetails.vue
index 3e1a521..ba242bb 100644
--- a/src/views/dmx/knowledgeLib/eidtDetails.vue
+++ b/src/views/dmx/knowledgeLib/eidtDetails.vue
@@ -1,31 +1,46 @@
-
 <template>
-  <a-modal v-model:visible="visible" title="缂栬緫瑙f瀽鍧�" @before-open="handleOpened" @cancel="handleCancel" :footer="false" title-align="start">
-    <a-form ref="formRef" :rules="rules" :model="form" @submit="handleSubmit" layout="vertical" >
+  <a-modal
+    v-model:visible="visible"
+    title="缂栬緫瑙f瀽鍧�"
+    @before-open="handleOpened"
+    @cancel="handleCancel"
+    :footer="false"
+    title-align="start"
+  >
+    <a-form
+      ref="formRef"
+      :rules="rules"
+      :model="form"
+      @submit="handleSubmit"
+      layout="vertical"
+    >
       <a-form-item field="content_with_weight" label="瑙f瀽鍧�">
-        <a-textarea v-model="form.content_with_weight" placeholder="" style="height: 100px"  auto-size />
+        <a-textarea
+          v-model="form.content_with_weight"
+          placeholder=""
+          style="height: 100px;overflow: auto;"
+          auto-size
+        />
       </a-form-item>
       <a-form-item field="important_kwd_key" label="鍏抽敭璇� *">
         <div style="width: auto">
           <a-tag
-            v-for="(item,index) in form.important_kwd"
-            :key="index"
+            v-for="(item, index) in form.important_kwd"
+            :key="item"
             closable
             bordered
-            @close="form.important_kwd.splice(index,1)"
+            @close="deleteKey(item)"
             style="margin-right: 10px"
           >
-            {{item}}
+            {{ item }}
           </a-tag>
-
-
           <a-input
             ref="formInput"
             v-show="keyVisible"
             v-model="form.important_kwd_key"
             placeholder=""
             size="small"
-            style="width: 80px;margin-right: 16px"
+            style="width: 80px; margin-right: 16px"
             @blur="inputChange"
           />
           <a-button type="dashed" shape="circle" size="small" @click="addKey">
@@ -34,20 +49,23 @@
         </div>
       </a-form-item>
 
-      <div>
-        <a-divider style="margin: 10px 0" />
-        <a-switch size="small"/> <span style="color: var(--color-text-2);">鍚敤</span>
-        <a-button type="text" style="color: var(--color-text-2);">
-          <template #icon>
-            <icon-delete />
-          </template>
-          鍒犻櫎
-        </a-button>
-      </div>
+<!--      <div>-->
+<!--        <a-divider style="margin: 10px 0" />-->
+<!--        <a-switch size="small" />-->
+<!--        <span style="color: var(&#45;&#45;color-text-2)">鍚敤</span>-->
+<!--        <a-button type="text" style="color: var(&#45;&#45;color-text-2)">-->
+<!--          <template #icon>-->
+<!--            <icon-delete />-->
+<!--          </template>-->
+<!--          鍒犻櫎-->
+<!--        </a-button>-->
+<!--      </div>-->
       <a-form-item>
-        <div style="width: 100%;text-align: right">
+        <div style="width: 100%; text-align: right">
           <a-button @click="visible = false">鍙栨秷</a-button>
-          <a-button style="margin-left: 10px" type="primary" html-type="submit">纭畾</a-button>
+          <a-button style="margin-left: 10px" type="primary" html-type="submit"
+            >纭畾</a-button
+          >
         </div>
       </a-form-item>
     </a-form>
@@ -55,92 +73,92 @@
 </template>
 
 <script lang="ts" setup>
-import { onMounted ,onBeforeMount, reactive, ref } from "vue";
-import { achunkCreate } from "@/api/kbList";
+import { onMounted, onBeforeMount, reactive, ref, nextTick } from "vue";
+import { achunkCreate, achunkSet } from "@/api/kbList";
 
-const props = defineProps(['item'])
-
-const visible = ref(false);
-const keyVisible = ref(false);
-const loading = ref(false);
-const form = reactive({
-  content_with_weight: '',
-  important_kwd: [],
-  important_kwd_key: '',
-});
-const formRef = ref(null);
-const formInput = ref(null);
-const rules = {
-  content_with_weight: [
-    {
-      required: true,
-      message:'璇疯緭鍏ュ�硷紒',
-    },
-  ],
-}
-
-
-const handleSubmit = async ({values, errors}) => {
-  console.log(props.item.id);
-  if(!errors){
-    const res = await achunkCreate({
-      content_with_weight: values.content_with_weight,
-      important_kwd: values.important_kwd,
-      doc_id: props.item.id,
-    })
-  }
-}
-
-const handleClick = () => {
-  visible.value = true;
-};
-
-defineExpose({
-  handleClick
-})
-const handleBeforeOk = (done) => {
-    formRef.value.validate().then(res => {
-      console.log('form:', form)
-    })
-};
-const handleCancel = () => {
-  visible.value = false;
-}
-
-const handleOpened =(el) => {
-  Object.assign(form,{
+  const props = defineProps(['item']);
+  const visible =defineModel('eidtDilVisible');
+  const emit = defineEmits(['canplaythrough']);
+  const keyVisible = ref(false);
+  const loading = ref(false);
+  const form = reactive({
     content_with_weight: '',
     important_kwd: [],
     important_kwd_key: '',
   });
-  formRef.value.resetFields();
-  keyVisible.value= false;
-}
+  const formRef = ref(null);
+  const formInput = ref(null);
+  const rules = {
+    content_with_weight: [
+      {
+        required: true,
+        message: '璇疯緭鍏ュ�硷紒',
+      },
+    ],
+  };
 
-const addKey = () => {
-  form.important_kwd_key = '';
-  formInput.value.focus();
-  keyVisible.value= true;
-}
+  const handleSubmit = async ({ values, errors }) => {
+    if (!errors) {
+      const res = await achunkSet({
+        content_with_weight: values.content_with_weight,
+        important_kwd: values.important_kwd,
+        doc_id: props.item.doc_id,
+        chunk_id: props.item.chunk_id,
+      });
+      if (res.code === 0) {
+        visible.value = false;
+        emit('canplaythrough');
+      }
+    }
+  };
 
-const inputChange = (e) => {
-  if (!form.important_kwd.includes(form.important_kwd_key) && form.important_kwd_key){
-    form.important_kwd.push(form.important_kwd_key)
-  }else {
+  const handleClick = () => {
+    visible.value = true;
+  };
 
-  }
-  keyVisible.value= false;
-}
+  const handleBeforeOk = (done) => {
+    formRef.value.validate().then((res) => {
+      console.log('form:', form);
+    });
+  };
+  const handleCancel = () => {
+    visible.value = false;
+  };
 
+  const handleOpened = (el) => {
+    console.log(props.item);
+    nextTick(()=>{
+      Object.assign(form, props.item);
+      console.log(form.important_kwd);
+    })
+    formRef.value.resetFields();
+    keyVisible.value = false;
+  };
 
+  const deleteKey = (row) => {
+    console.log(form.important_kwd);
+    console.log(row);
+    // form.important_kwd.splice(index, 1);
+    form.important_kwd = form.important_kwd.filter((item) => item !== row);
+  };
 
+  const addKey = () => {
+    form.important_kwd_key = '';
+    formInput.value.focus();
+    keyVisible.value = true;
+  };
 
+  const inputChange = (e) => {
+    if (
+      !form.important_kwd.includes(form.important_kwd_key) &&
+      form.important_kwd_key
+    ) {
+      form.important_kwd.push(form.important_kwd_key);
+    } else {
+    }
+    keyVisible.value = false;
+  };
 
-onBeforeMount(()=>{
-
-})
-onMounted(()=>{
-
-
-})
-</script>
\ No newline at end of file
+  onBeforeMount(() => {});
+  onMounted(() => {});
+</script>

--
Gitblit v1.8.0