## Description Display the total count of generated FAQs in the Related FAQs dialog title to give users immediate visibility into how many FAQs were generated from a document. ## Type of change Please delete options that are not relevant. - [ ] New feature (non-breaking change which adds functionality) ## Snapshots? <img width="717" height="268" alt="Screenshot 2026-02-04 at 1 47 36 AM" src="https://github.com/user-attachments/assets/c3e927ce-6d09-499d-8d02-8a44e0c353e2" /> ## Checklist: - [ ] My code follows the style guidelines of this project - [ ] I have performed a self-review of my code - [ ] I have commented on my code, particularly in hard-to-understand areas - [ ] I have made corresponding changes to the documentation - [ ] My changes generate no new warnings - [ ] I have added tests that prove my fix is effective or that my feature works - [ ] New and existing unit tests pass locally with my changes - [ ] Any dependent changes have been merged and published in downstream modules <!-- CURSOR_SUMMARY --> --- > [!NOTE] > **Low Risk** > Small UI-only change using existing store metadata; risk is limited to incorrect/blank counts if `meta.totalCount` is missing or stale. > > **Overview** > Updates the `RelatedResponses` dialog to display the total related response count in the title by reading `captainResponses/getMeta.totalCount` (defaulting to 0) and appending it as `(<count>)`. > > <sup>Written by [Cursor Bugbot](https://cursor.com/dashboard?tab=bugbot) for commit 7cd67c9991faceeff33d33c319e324b1c6cf73f4. This will update automatically on new commits. Configure [here](https://cursor.com/dashboard?tab=bugbot).</sup> <!-- /CURSOR_SUMMARY -->
72 lines
2.0 KiB
Vue
72 lines
2.0 KiB
Vue
<script setup>
|
|
import { ref, computed, onMounted } from 'vue';
|
|
import { useStore, useMapGetter } from 'dashboard/composables/store';
|
|
import { useI18n } from 'vue-i18n';
|
|
import Spinner from 'dashboard/components-next/spinner/Spinner.vue';
|
|
import Dialog from 'dashboard/components-next/dialog/Dialog.vue';
|
|
import ResponseCard from '../../assistant/ResponseCard.vue';
|
|
const props = defineProps({
|
|
captainDocument: {
|
|
type: Object,
|
|
required: true,
|
|
},
|
|
});
|
|
const emit = defineEmits(['close']);
|
|
const { t } = useI18n();
|
|
const store = useStore();
|
|
const dialogRef = ref(null);
|
|
|
|
const uiFlags = useMapGetter('captainResponses/getUIFlags');
|
|
const responses = useMapGetter('captainResponses/getRecords');
|
|
const meta = useMapGetter('captainResponses/getMeta');
|
|
const isFetching = computed(() => uiFlags.value.fetchingList);
|
|
const totalCount = computed(() => meta.value.totalCount || 0);
|
|
|
|
const handleClose = () => {
|
|
emit('close');
|
|
};
|
|
|
|
onMounted(() => {
|
|
store.dispatch('captainResponses/get', {
|
|
assistantId: props.captainDocument.assistant.id,
|
|
documentId: props.captainDocument.id,
|
|
});
|
|
});
|
|
defineExpose({ dialogRef });
|
|
</script>
|
|
|
|
<template>
|
|
<Dialog
|
|
ref="dialogRef"
|
|
type="edit"
|
|
:title="`${t('CAPTAIN.DOCUMENTS.RELATED_RESPONSES.TITLE')} (${totalCount})`"
|
|
:description="t('CAPTAIN.DOCUMENTS.RELATED_RESPONSES.DESCRIPTION')"
|
|
:show-cancel-button="false"
|
|
:show-confirm-button="false"
|
|
overflow-y-auto
|
|
width="3xl"
|
|
@close="handleClose"
|
|
>
|
|
<div
|
|
v-if="isFetching"
|
|
class="flex items-center justify-center py-10 text-n-slate-11"
|
|
>
|
|
<Spinner />
|
|
</div>
|
|
<div v-else class="flex flex-col gap-3 min-h-48">
|
|
<ResponseCard
|
|
v-for="response in responses"
|
|
:id="response.id"
|
|
:key="response.id"
|
|
:question="response.question"
|
|
:status="response.status"
|
|
:answer="response.answer"
|
|
:assistant="response.assistant"
|
|
:created-at="response.created_at"
|
|
:updated-at="response.updated_at"
|
|
compact
|
|
/>
|
|
</div>
|
|
</Dialog>
|
|
</template>
|