Implement interaction features in Step5Interaction component and add routing for interaction view
- Introduced the Step5Interaction component for user interaction with report agents and simulation profiles. - Added chat functionality to communicate with report agents and selected simulation agents. - Implemented a survey feature to gather responses from multiple agents. - Enhanced routing by adding a new InteractionView for seamless navigation to the interaction interface. - Updated the router configuration to include the new interaction route. - Improved UI elements and styles for better user experience in the interaction process.
This commit is contained in:
@@ -126,6 +126,15 @@
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<!-- Next Step Button - 在完成后显示 -->
|
||||
<button v-if="isComplete" class="next-step-btn" @click="goToInteraction">
|
||||
<span>进入深度互动</span>
|
||||
<svg viewBox="0 0 24 24" width="16" height="16" fill="none" stroke="currentColor" stroke-width="2">
|
||||
<line x1="5" y1="12" x2="19" y2="12"></line>
|
||||
<polyline points="12 5 19 12 12 19"></polyline>
|
||||
</svg>
|
||||
</button>
|
||||
|
||||
<div class="workflow-divider"></div>
|
||||
</div>
|
||||
|
||||
@@ -383,8 +392,11 @@
|
||||
|
||||
<script setup>
|
||||
import { ref, computed, watch, onMounted, onUnmounted, nextTick, h, reactive } from 'vue'
|
||||
import { useRouter } from 'vue-router'
|
||||
import { getAgentLog, getConsoleLog } from '../api/report'
|
||||
|
||||
const router = useRouter()
|
||||
|
||||
const props = defineProps({
|
||||
reportId: String,
|
||||
simulationId: String,
|
||||
@@ -393,6 +405,13 @@ const props = defineProps({
|
||||
|
||||
const emit = defineEmits(['add-log', 'update-status'])
|
||||
|
||||
// Navigation
|
||||
const goToInteraction = () => {
|
||||
if (props.reportId) {
|
||||
router.push({ name: 'Interaction', params: { reportId: props.reportId } })
|
||||
}
|
||||
}
|
||||
|
||||
// State
|
||||
const agentLogs = ref([])
|
||||
const consoleLogs = ref([])
|
||||
@@ -3344,6 +3363,36 @@ watch(() => props.reportId, (newId) => {
|
||||
font-size: 14px;
|
||||
}
|
||||
|
||||
.next-step-btn {
|
||||
display: flex;
|
||||
align-items: center;
|
||||
justify-content: center;
|
||||
gap: 8px;
|
||||
width: calc(100% - 40px);
|
||||
margin: 4px 20px 0 20px;
|
||||
padding: 14px 20px;
|
||||
font-size: 14px;
|
||||
font-weight: 600;
|
||||
color: #FFFFFF;
|
||||
background: #1F2937;
|
||||
border: none;
|
||||
border-radius: 8px;
|
||||
cursor: pointer;
|
||||
transition: all 0.2s ease;
|
||||
}
|
||||
|
||||
.next-step-btn:hover {
|
||||
background: #374151;
|
||||
}
|
||||
|
||||
.next-step-btn svg {
|
||||
transition: transform 0.2s ease;
|
||||
}
|
||||
|
||||
.next-step-btn:hover svg {
|
||||
transform: translateX(4px);
|
||||
}
|
||||
|
||||
/* Workflow Empty */
|
||||
.workflow-empty {
|
||||
display: flex;
|
||||
|
||||
1917
frontend/src/components/Step5Interaction.vue
Normal file
1917
frontend/src/components/Step5Interaction.vue
Normal file
File diff suppressed because it is too large
Load Diff
Reference in New Issue
Block a user