WIP - refresh list after AI record creation

This commit is contained in:
Francisco Gaona
2026-01-13 00:00:40 +01:00
parent d2b3fce4eb
commit a62f68fc10
3 changed files with 55 additions and 2 deletions

View File

@@ -53,6 +53,17 @@ const handleSend = async () => {
role: 'assistant',
text: response.reply || 'Let me know what else you need.',
})
if (response.action === 'create_record') {
window.dispatchEvent(
new CustomEvent('ai-record-created', {
detail: {
objectApiName: buildContext().objectApiName,
record: response.record,
},
}),
)
}
} catch (error: any) {
console.error('Failed to send AI chat message:', error)
messages.value.push({

View File

@@ -1,5 +1,5 @@
<script setup lang="ts">
import { ref, computed, onMounted, watch, nextTick } from 'vue'
import { ref, computed, onMounted, onBeforeUnmount, watch, nextTick } from 'vue'
import { useRoute, useRouter } from 'vue-router'
import { useApi } from '@/composables/useApi'
import { useFields, useViewState } from '@/composables/useFieldViews'
@@ -48,6 +48,27 @@ const {
handleSave,
} = useViewState(`/runtime/objects/${objectApiName.value}/records`)
const handleAiRecordCreated = (event: Event) => {
const detail = (event as CustomEvent).detail || {}
if (
detail?.objectApiName &&
detail.objectApiName.toLowerCase() !== objectApiName.value.toLowerCase()
) {
return
}
if (view.value === 'list') {
fetchRecords()
}
}
onMounted(() => {
window.addEventListener('ai-record-created', handleAiRecordCreated)
})
onBeforeUnmount(() => {
window.removeEventListener('ai-record-created', handleAiRecordCreated)
})
// Compute breadcrumbs based on the current route and object data
const updateBreadcrumbs = () => {
if (!objectDefinition.value) {

View File

@@ -1,5 +1,5 @@
<script setup lang="ts">
import { ref, computed, onMounted, watch, nextTick } from 'vue'
import { ref, computed, onMounted, onBeforeUnmount, watch, nextTick } from 'vue'
import { useRoute, useRouter } from 'vue-router'
import { useApi } from '@/composables/useApi'
import { useFields, useViewState } from '@/composables/useFieldViews'
@@ -41,6 +41,27 @@ const {
handleSave,
} = useViewState(`/runtime/objects/${objectApiName.value}/records`)
const handleAiRecordCreated = (event: Event) => {
const detail = (event as CustomEvent).detail || {}
if (
detail?.objectApiName &&
detail.objectApiName.toLowerCase() !== objectApiName.value.toLowerCase()
) {
return
}
if (view.value === 'list') {
fetchRecords()
}
}
onMounted(() => {
window.addEventListener('ai-record-created', handleAiRecordCreated)
})
onBeforeUnmount(() => {
window.removeEventListener('ai-record-created', handleAiRecordCreated)
})
// View configs
const listConfig = computed(() => {
if (!objectDefinition.value) return null