108 lines
2.9 KiB
Vue
108 lines
2.9 KiB
Vue
<template>
|
||
<div class="tool-logger">
|
||
<span>
|
||
<span>{{ t('response') }}</span>
|
||
<span style="width: 200px;">
|
||
<el-switch v-model="showRawJson" inline-prompt active-text="JSON" inactive-text="Text"
|
||
style="margin-left: 10px; width: 200px;"
|
||
:inactive-action-style="'backgroundColor: var(--sidebar)'" />
|
||
</span>
|
||
</span>
|
||
<el-scrollbar height="500px">
|
||
<div class="output-content" contenteditable="false">
|
||
|
||
<!-- TODO: 更加稳定,现在通过下面这个来判断上一次执行结果是否成功 -->
|
||
<div v-if="typeof tabStorage.lastToolCallResponse === 'string'" class="error-tool-call">
|
||
<span>
|
||
{{ tabStorage.lastToolCallResponse }}
|
||
</span>
|
||
</div>
|
||
|
||
<div v-else>
|
||
<!-- 展示原本的信息 -->
|
||
<template v-if="!showRawJson">
|
||
{{tabStorage.lastToolCallResponse?.content.map(c => c.text).join('\n')}}
|
||
</template>
|
||
|
||
<!-- 展示 json -->
|
||
<template v-else>
|
||
<json-render :json="tabStorage.lastToolCallResponse"/>
|
||
</template>
|
||
</div>
|
||
|
||
</div>
|
||
</el-scrollbar>
|
||
</div>
|
||
</template>
|
||
|
||
<script setup lang="ts">
|
||
import { defineComponent, defineProps, computed, ref } from 'vue';
|
||
import { useI18n } from 'vue-i18n';
|
||
import { tabs } from '../panel';
|
||
import { ToolStorage } from './tools';
|
||
import JsonRender from '@/components/json-render/index.vue';
|
||
|
||
defineComponent({ name: 'tool-logger' });
|
||
const { t } = useI18n();
|
||
|
||
const props = defineProps({
|
||
tabId: {
|
||
type: Number,
|
||
required: true
|
||
}
|
||
});
|
||
|
||
const tab = tabs.content[props.tabId];
|
||
const tabStorage = tab.storage as ToolStorage;
|
||
|
||
const showRawJson = ref(false);
|
||
|
||
</script>
|
||
|
||
<style>
|
||
.tool-logger {
|
||
border-radius: .5em;
|
||
background-color: var(--background);
|
||
padding: 10px;
|
||
}
|
||
|
||
.tool-logger .el-switch__core {
|
||
border: 1px solid var(--main-color) !important;
|
||
width: 60px !important;
|
||
}
|
||
|
||
.tool-logger .el-switch .el-switch__action {
|
||
background-color: var(--main-color);
|
||
}
|
||
|
||
.tool-logger .el-switch.is-checked .el-switch__action {
|
||
background-color: var(--sidebar);
|
||
}
|
||
|
||
.tool-logger>span:first-child {
|
||
margin-bottom: 5px;
|
||
display: flex;
|
||
align-items: center;
|
||
}
|
||
|
||
.tool-logger .output-content {
|
||
border-radius: .5em;
|
||
padding: 15px;
|
||
min-height: 450px;
|
||
height: fit-content;
|
||
font-family: var(--code-font-family);
|
||
white-space: pre-wrap;
|
||
word-break: break-all;
|
||
user-select: text;
|
||
cursor: text;
|
||
font-size: 15px;
|
||
line-height: 1.5;
|
||
background-color: var(--sidebar);
|
||
}
|
||
|
||
.error-tool-call {
|
||
background-color: rgba(245, 108, 108, 0.5);
|
||
padding: 5px 9px;
|
||
border-radius: .5em;
|
||
}
|
||
</style> |