|
|
|
@ -25,59 +25,103 @@ |
|
|
|
|
<view class="stepBox"> |
|
|
|
|
<view class="step" v-for="(item, index) in tablist" :key="index"> |
|
|
|
|
<view class="stepItem"> |
|
|
|
|
<view :class="{ |
|
|
|
|
<view |
|
|
|
|
:class="{ |
|
|
|
|
stepCircleActive: index <= active, |
|
|
|
|
stepCircle: index > active, |
|
|
|
|
}">{{ index + 1 }} |
|
|
|
|
}" |
|
|
|
|
>{{ index + 1 }} |
|
|
|
|
</view> |
|
|
|
|
<view class="stepText" :style="{ color: index <= active ? '#000000' : '#bcc3cd' }">{{ item.title }} |
|
|
|
|
<view |
|
|
|
|
class="stepText" |
|
|
|
|
:style="{ color: index <= active ? '#000000' : '#bcc3cd' }" |
|
|
|
|
>{{ item.title }} |
|
|
|
|
</view> |
|
|
|
|
</view> |
|
|
|
|
<view v-if="index !== 3" class="circles"> |
|
|
|
|
<view :class="{ circleActive: index < active, circle: index >= active }" v-for="i in 8" :key="i"> |
|
|
|
|
<view |
|
|
|
|
:class="{ circleActive: index < active, circle: index >= active }" |
|
|
|
|
v-for="i in 8" |
|
|
|
|
:key="i" |
|
|
|
|
> |
|
|
|
|
</view> |
|
|
|
|
</view> |
|
|
|
|
</view> |
|
|
|
|
</view> |
|
|
|
|
<scroll-view scroll-y="true" :scroll-top="scrollTop" :style="{ |
|
|
|
|
<scroll-view |
|
|
|
|
scroll-y="true" |
|
|
|
|
:scroll-top="scrollTop" |
|
|
|
|
:style="{ |
|
|
|
|
height: isExpanded ? 'calc(100% - 350rpx)' : 'calc(100% - 250rpx)', |
|
|
|
|
}" class="chatlist" id="scrollView" ref="scrollView" @click="clickContent"> |
|
|
|
|
<view :class="['bar', item.answerId == '0' ? 'currAnswer' : '']" v-for="(item, i) in msgList" |
|
|
|
|
:key="item.id"> |
|
|
|
|
}" |
|
|
|
|
class="chatlist" |
|
|
|
|
id="scrollView" |
|
|
|
|
ref="scrollView" |
|
|
|
|
@click="clickContent" |
|
|
|
|
> |
|
|
|
|
<view |
|
|
|
|
:class="['bar', item.answerId == '0' ? 'currAnswer' : '']" |
|
|
|
|
v-for="(item, i) in msgList" |
|
|
|
|
:key="item.id" |
|
|
|
|
> |
|
|
|
|
<!-- <image |
|
|
|
|
:src=" |
|
|
|
|
item.answerId == '0' ? '/static/self.png' : '/static/left_user.png' |
|
|
|
|
" |
|
|
|
|
class="img" |
|
|
|
|
/> --> |
|
|
|
|
<image :src=" |
|
|
|
|
<image |
|
|
|
|
:src=" |
|
|
|
|
item.answerId == '0' |
|
|
|
|
? '' |
|
|
|
|
: '/static/left_user.png' |
|
|
|
|
" class="img" /> |
|
|
|
|
" |
|
|
|
|
class="img" |
|
|
|
|
/> |
|
|
|
|
<view class="content"> |
|
|
|
|
<view style="width: 100%; overflow: hidden;"> |
|
|
|
|
<zeroMarkdownView :markdown="item.data" /> |
|
|
|
|
<zeroMarkdownView :markdown="item.data || ''" /> |
|
|
|
|
</view> |
|
|
|
|
<!-- <ua-markdown :source="mdvalue" /> --> |
|
|
|
|
<view class="btnBox"> |
|
|
|
|
<view class="btn" @click="handleBtn(text)" v-for="(text, index) in item.options" :key="index"> |
|
|
|
|
{{ text }}</view> |
|
|
|
|
<view |
|
|
|
|
class="btn" |
|
|
|
|
@click="handleBtn(text)" |
|
|
|
|
v-for="(text, index) in item.options" |
|
|
|
|
:key="index" |
|
|
|
|
>{{ text }}</view |
|
|
|
|
> |
|
|
|
|
</view> |
|
|
|
|
<view v-if="item.answerOptions && item.answerOptions.length > 0 && item.optionType == 1" |
|
|
|
|
style="display: flex; flex-wrap: wrap;"> |
|
|
|
|
<u-checkbox-group v-model="item.checkboxValue1" placement="column" iconPlacement="right" |
|
|
|
|
style="width: 100%; padding: 0 15px; box-sizing: border-box"> |
|
|
|
|
<u-checkbox :customStyle="{ marginBottom: '8px' }" |
|
|
|
|
v-for="(item, index) in item.answerOptions" :key="index" :label="item" :name="item" |
|
|
|
|
style="background-color: #ededed;padding: 8px;"> |
|
|
|
|
<view |
|
|
|
|
v-if="item.answerOptions && item.answerOptions.length > 0 && item.optionType == 1" |
|
|
|
|
style="display: flex; flex-wrap: wrap;" |
|
|
|
|
:class="item.answerOptions.length > 1 ? '' : 'btnBox'" |
|
|
|
|
> |
|
|
|
|
<u-checkbox-group |
|
|
|
|
v-model="item.checkboxValue1" |
|
|
|
|
placement="column" |
|
|
|
|
iconPlacement="right" |
|
|
|
|
style="width: 100%; padding: 0 15px; box-sizing: border-box" |
|
|
|
|
> |
|
|
|
|
<u-checkbox |
|
|
|
|
:customStyle="{ marginBottom: '8px' }" |
|
|
|
|
v-for="(item, index) in item.answerOptions" |
|
|
|
|
:key="index" |
|
|
|
|
:label="item" |
|
|
|
|
:name="item" |
|
|
|
|
style="background-color: #ededed;padding: 8px;" |
|
|
|
|
> |
|
|
|
|
</u-checkbox> |
|
|
|
|
</u-checkbox-group> |
|
|
|
|
</view> |
|
|
|
|
<view v-if="item.answerOptions && item.answerOptions.length > 0 && item.optionType == 0" |
|
|
|
|
style="display: flex; flex-wrap: wrap;"> |
|
|
|
|
<view |
|
|
|
|
v-if="item.answerOptions && item.answerOptions.length > 0 && item.optionType == 0" |
|
|
|
|
:style="item.answerOptions.length > 1 ? 'display: flex; flex-wrap: wrap;' : ''" |
|
|
|
|
:class="item.answerOptions.length > 1 ? '' : 'btnBox'" |
|
|
|
|
> |
|
|
|
|
<view v-for="(item, index) in item.answerOptions" :key="index" |
|
|
|
|
style="padding: 8px 8px;margin:0 0 8px 8px;background-color: #ededed;" |
|
|
|
|
:style="item.answerOptions.length > 1 ? 'padding: 8px 8px;margin:0 0 8px 8px;background-color: #ededed;' : ''" |
|
|
|
|
:class="item.answerOptions.length > 1 ? '' : 'btn'" |
|
|
|
|
@click="handleGroup(item)"> |
|
|
|
|
{{ item }} |
|
|
|
|
</view> |
|
|
|
@ -97,9 +141,12 @@ |
|
|
|
|
> |
|
|
|
|
</u-radio> |
|
|
|
|
</u-radio-group> --> |
|
|
|
|
|
|
|
|
|
</view> |
|
|
|
|
<view class="btnBox" |
|
|
|
|
v-if="item.answerOptions && item.answerOptions.length > 0 && item.optionType == 1"> |
|
|
|
|
<view |
|
|
|
|
class="btnBox" |
|
|
|
|
v-if="item.answerOptions && item.answerOptions.length > 0 && item.optionType == 1" |
|
|
|
|
> |
|
|
|
|
<view class="btn" @click="handleGroup(item)">确认</view> |
|
|
|
|
<view class="btn" @click="handleGroup2(i)">清空</view> |
|
|
|
|
</view> |
|
|
|
@ -111,12 +158,27 @@ |
|
|
|
|
<view class="bounce-dot"></view> |
|
|
|
|
</view> |
|
|
|
|
</scroll-view> |
|
|
|
|
<view class="input-wrapper" :class="{ 'input-wrapper-expanded': isExpanded }"> |
|
|
|
|
<view |
|
|
|
|
class="input-wrapper" |
|
|
|
|
:class="{ 'input-wrapper-expanded': isExpanded }" |
|
|
|
|
> |
|
|
|
|
<view class="topContent"> |
|
|
|
|
<input class="uni-input" placeholder="请输入内容" :value="inputValue" @confirm="handleSend" |
|
|
|
|
@input="onKeyInput" /> |
|
|
|
|
|
|
|
|
|
<uni-icons class="uni-icon" type="plus" size="30" @click="handlePlus"></uni-icons> |
|
|
|
|
<input |
|
|
|
|
class="uni-input" |
|
|
|
|
:placeholder="loading ? '请等待回复结束' : '请输入内容'" |
|
|
|
|
:value="inputValue" |
|
|
|
|
@confirm="handleSend" |
|
|
|
|
@input="onKeyInput" |
|
|
|
|
:disabled="loading" |
|
|
|
|
/> |
|
|
|
|
|
|
|
|
|
<uni-icons |
|
|
|
|
class="uni-icon" |
|
|
|
|
type="plus" |
|
|
|
|
size="30" |
|
|
|
|
@click="handlePlus" |
|
|
|
|
:disabled="loading" |
|
|
|
|
></uni-icons> |
|
|
|
|
</view> |
|
|
|
|
<view v-if="isExpanded" class="expanded"> |
|
|
|
|
<view @click="chooseImage" class="expandedItem"> |
|
|
|
@ -133,22 +195,20 @@ |
|
|
|
|
</template> |
|
|
|
|
|
|
|
|
|
<script> |
|
|
|
|
// import AbortController from "abort-controller/dist/abort-controller"; |
|
|
|
|
import TopTitle from "../../components/top-title.vue"; |
|
|
|
|
// import headerNavBar from '../../components/headerNavBar/headerNavBar.vue' |
|
|
|
|
import zeroMarkdownView from "../../components/zeroMarkdownView/zeroMarkdownView.vue"; |
|
|
|
|
// import { |
|
|
|
|
// EventSourcePolyfill |
|
|
|
|
// } from 'event-source-polyfill'; |
|
|
|
|
import $ from "../../common/globalJs/globalJs.js"; |
|
|
|
|
import { |
|
|
|
|
fetchEventSource |
|
|
|
|
} from "@microsoft/fetch-event-source"; |
|
|
|
|
// import { |
|
|
|
|
// baseUrl |
|
|
|
|
// } from '../../utils/config.js'; |
|
|
|
|
|
|
|
|
|
export default { |
|
|
|
|
// import AbortController from "abort-controller/dist/abort-controller"; |
|
|
|
|
import TopTitle from "../../components/top-title.vue"; |
|
|
|
|
// import headerNavBar from '../../components/headerNavBar/headerNavBar.vue' |
|
|
|
|
import zeroMarkdownView from "../../components/zeroMarkdownView/zeroMarkdownView.vue"; |
|
|
|
|
// import { |
|
|
|
|
// EventSourcePolyfill |
|
|
|
|
// } from 'event-source-polyfill'; |
|
|
|
|
import $ from "../../common/globalJs/globalJs.js"; |
|
|
|
|
import { fetchEventSource } from "@microsoft/fetch-event-source"; |
|
|
|
|
// import { |
|
|
|
|
// baseUrl |
|
|
|
|
// } from '../../utils/config.js'; |
|
|
|
|
|
|
|
|
|
export default { |
|
|
|
|
components: { |
|
|
|
|
TopTitle, |
|
|
|
|
zeroMarkdownView, |
|
|
|
@ -156,7 +216,8 @@ |
|
|
|
|
data() { |
|
|
|
|
return { |
|
|
|
|
active: 0, |
|
|
|
|
tablist: [{ |
|
|
|
|
tablist: [ |
|
|
|
|
{ |
|
|
|
|
title: "信息确认", |
|
|
|
|
}, |
|
|
|
|
{ |
|
|
|
@ -195,6 +256,7 @@ |
|
|
|
|
// params.userId = "admin1"; |
|
|
|
|
this.params = params; |
|
|
|
|
let str = ""; |
|
|
|
|
this.getChatHistory() |
|
|
|
|
if (params.roadName) { |
|
|
|
|
str += "路段名:" + params.roadName; |
|
|
|
|
this.title = params.roadName + "智能排查"; |
|
|
|
@ -278,12 +340,14 @@ |
|
|
|
|
this.active = this.tabkey - 1 > 0 ? this.tabkey - 1 : 0; |
|
|
|
|
} |
|
|
|
|
if (this.msgList.length == 0) { |
|
|
|
|
this.msgList = [{ |
|
|
|
|
this.msgList = [ |
|
|
|
|
{ |
|
|
|
|
answerId, |
|
|
|
|
data: res.result.data.content, |
|
|
|
|
optionType: res.result.data?.optionType, |
|
|
|
|
answerOptions: res.result.data?.answerOptions || [], |
|
|
|
|
}, ]; |
|
|
|
|
}, |
|
|
|
|
]; |
|
|
|
|
} else { |
|
|
|
|
// debugger |
|
|
|
|
//回答 |
|
|
|
@ -329,10 +393,49 @@ |
|
|
|
|
}); |
|
|
|
|
}, |
|
|
|
|
|
|
|
|
|
async getChatHistory() { |
|
|
|
|
const [err, res] = await uni.request({ |
|
|
|
|
// url: 'http://10.16.3.159:8777/api/local_doc_qa/local_doc_chat', |
|
|
|
|
url: $.chatUrl + "/getChatHistory", |
|
|
|
|
dataType: "json", |
|
|
|
|
method: "POST", |
|
|
|
|
// responseType: 'arraybuffer', |
|
|
|
|
headers: { |
|
|
|
|
// 'Accept': 'text/event-stream', |
|
|
|
|
"content-type": "application/json", |
|
|
|
|
}, |
|
|
|
|
data: { |
|
|
|
|
userId: 'admin1', |
|
|
|
|
taskId:'RG202408319001' |
|
|
|
|
}, |
|
|
|
|
}); |
|
|
|
|
console.log('getChatHistory', res) |
|
|
|
|
if(res && res.data && res.data.code == 200) { |
|
|
|
|
const result = res.data.result |
|
|
|
|
let id = 1 |
|
|
|
|
result.forEach((item, index) => { |
|
|
|
|
let questionList = { |
|
|
|
|
answerId: '1', |
|
|
|
|
id, |
|
|
|
|
data: item.question |
|
|
|
|
} |
|
|
|
|
let responseList = { |
|
|
|
|
answerId: '0', |
|
|
|
|
id: id + 1, |
|
|
|
|
data: item.response |
|
|
|
|
} |
|
|
|
|
this.msgList.push(questionList) |
|
|
|
|
this.msgList.push(responseList) |
|
|
|
|
id += 2 |
|
|
|
|
}) |
|
|
|
|
console.log(this.msgList) |
|
|
|
|
} |
|
|
|
|
}, |
|
|
|
|
|
|
|
|
|
async queryChat(voiceText) { |
|
|
|
|
// console.log(voiceText,"voiceText"); |
|
|
|
|
this.loading = true; |
|
|
|
|
console.log({ |
|
|
|
|
console.log({ |
|
|
|
|
voiceText, |
|
|
|
|
sceneFlag: "", |
|
|
|
|
sessionId: "", |
|
|
|
@ -352,7 +455,7 @@ |
|
|
|
|
// "history": [] |
|
|
|
|
}) |
|
|
|
|
let sectionType = "2" |
|
|
|
|
if (this.params.sectionType != 'null') { |
|
|
|
|
if(this.params.sectionType != 'null') { |
|
|
|
|
sectionType = this.params.sectionType |
|
|
|
|
} |
|
|
|
|
const [err, res] = await uni.request({ |
|
|
|
@ -389,12 +492,8 @@ |
|
|
|
|
|
|
|
|
|
if (res && res.data && res.data.code == 200) { |
|
|
|
|
// console.log('request success', res.data) |
|
|
|
|
const { |
|
|
|
|
result = {} |
|
|
|
|
} = res.data; |
|
|
|
|
const { |
|
|
|
|
data = {} |
|
|
|
|
} = result; |
|
|
|
|
const { result = {} } = res.data; |
|
|
|
|
const { data = {} } = result; |
|
|
|
|
if (data.tabkey - 1 != this.active) { |
|
|
|
|
this.active = data.tabkey - 1 > 0 ? data.tabkey - 1 : 0; |
|
|
|
|
} |
|
|
|
@ -523,6 +622,7 @@ |
|
|
|
|
]; |
|
|
|
|
this.scrollBottom(); |
|
|
|
|
} |
|
|
|
|
console.log('检查msgList', this.msgList) |
|
|
|
|
}, |
|
|
|
|
|
|
|
|
|
handlePlus() { |
|
|
|
@ -548,7 +648,7 @@ |
|
|
|
|
uni.chooseImage({ |
|
|
|
|
count: 6, //默认9 |
|
|
|
|
sizeType: ["original", "compressed"], //可以指定是原图还是压缩图,默认二者都有 |
|
|
|
|
sourceType: ["album", 'camera'], //从相册选择 |
|
|
|
|
sourceType: ["album",'camera'], //从相册选择 |
|
|
|
|
success: async (res) => { |
|
|
|
|
console.log(res); |
|
|
|
|
if (res.tempFilePaths && res.tempFilePaths.length) { |
|
|
|
@ -601,15 +701,15 @@ |
|
|
|
|
}, |
|
|
|
|
handleGroup2(i) { |
|
|
|
|
this.msgList[i].checkboxValue1 = [] |
|
|
|
|
this.$set(this.msgList, i, this.msgList[i]) |
|
|
|
|
this.$set(this.msgList,i,this.msgList[i]) |
|
|
|
|
|
|
|
|
|
}, |
|
|
|
|
}, |
|
|
|
|
}; |
|
|
|
|
}; |
|
|
|
|
</script> |
|
|
|
|
|
|
|
|
|
<style scoped lang="scss"> |
|
|
|
|
.detail { |
|
|
|
|
.detail { |
|
|
|
|
width: 100%; |
|
|
|
|
margin: auto; |
|
|
|
|
height: 100vh; |
|
|
|
@ -707,13 +807,16 @@ |
|
|
|
|
justify-content: flex-end; |
|
|
|
|
position: absolute; |
|
|
|
|
right: -4px; |
|
|
|
|
bottom: -36px; |
|
|
|
|
|
|
|
|
|
bottom: -42px; |
|
|
|
|
.btn { |
|
|
|
|
color: #497cca; |
|
|
|
|
background-color: #d8e3f8; |
|
|
|
|
color: #2663BF; |
|
|
|
|
background-color: rgba(0, 102, 255, 0.1); |
|
|
|
|
display: flex; |
|
|
|
|
padding: 2rpx 20rpx; |
|
|
|
|
justify-content: center; |
|
|
|
|
align-items: center; |
|
|
|
|
// width: 132px; |
|
|
|
|
min-width: 72rpx; |
|
|
|
|
padding: 10rpx; |
|
|
|
|
margin: 10rpx; |
|
|
|
|
border-radius: 4rpx; |
|
|
|
|
} |
|
|
|
@ -840,10 +943,9 @@ |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
@keyframes bounce { |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
@keyframes bounce { |
|
|
|
|
0%, |
|
|
|
|
80%, |
|
|
|
|
100% { |
|
|
|
@ -853,8 +955,5 @@ |
|
|
|
|
40% { |
|
|
|
|
transform: scale(1); |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
/deep/ ._img{ |
|
|
|
|
max-width:220rpx; |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
</style> |