Jelajahi Sumber

fix(code-completion): open ws depends on code completion status

Jacky 5 bulan lalu
induk
melakukan
f68b18d49a
2 mengubah file dengan 11 tambahan dan 7 penghapusan
  1. 2 1
      app/src/api/openai.ts
  2. 9 6
      app/src/components/CodeEditor/CodeCompletion.ts

+ 2 - 1
app/src/api/openai.ts

@@ -1,3 +1,4 @@
+import type ReconnectingWebSocket from 'reconnecting-websocket'
 import { http } from '@uozi-admin/request'
 import ws from '@/lib/websocket'
 
@@ -27,7 +28,7 @@ const openai = {
     return http.post('/chatgpt_record', data)
   },
   code_completion() {
-    return ws('/api/code_completion')
+    return ws('/api/code_completion') as ReconnectingWebSocket
   },
   get_code_completion_enabled_status() {
     return http.get<{ enabled: boolean }>('/code_completion/enabled')

+ 9 - 6
app/src/components/CodeEditor/CodeCompletion.ts

@@ -1,5 +1,6 @@
 import type { Editor } from 'ace-builds'
 import type { Point } from 'ace-builds-internal/document'
+import type ReconnectingWebSocket from 'reconnecting-websocket'
 import { debounce } from 'lodash'
 import { v4 as uuidv4 } from 'uuid'
 import openai from '@/api/openai'
@@ -27,7 +28,7 @@ function useCodeCompletion() {
   const currentGhostText = ref<string>('')
   const isConfigFile = ref<boolean>(false)
 
-  const ws = openai.code_completion()
+  const ws = shallowRef<ReconnectingWebSocket>()
 
   // Check if the current file is a configuration file
   function checkIfConfigFile(filename: string, content: string): boolean {
@@ -46,7 +47,7 @@ function useCodeCompletion() {
   }
 
   function getAISuggestions(code: string, context: string, position: Point, callback: (suggestion: string) => void, language: string = 'nginx', suffix: string = '', requestId: string) {
-    if (!ws || ws.readyState !== WebSocket.OPEN) {
+    if (!ws.value || ws.value.readyState !== WebSocket.OPEN) {
       debug('WebSocket is not open')
       return
     }
@@ -78,9 +79,9 @@ function useCodeCompletion() {
 
     debug('Sending message', message)
 
-    ws.send(JSON.stringify(message))
+    ws.value.send(JSON.stringify(message))
 
-    ws.onmessage = event => {
+    ws.value.onmessage = event => {
       const data = JSON.parse(event.data)
       debug(`Received message`, data, requestId)
       if (data.request_id === requestId) {
@@ -232,6 +233,8 @@ function useCodeCompletion() {
       return
     }
 
+    ws.value = openai.code_completion()
+
     editorRef.value = editor
 
     // Determine if the current file is a configuration file
@@ -268,8 +271,8 @@ function useCodeCompletion() {
   }
 
   function cleanUp() {
-    if (ws) {
-      ws.close()
+    if (ws.value) {
+      ws.value.close()
     }
     debug('CodeCompletion unmounted')
   }