From 12a2d994bace6430a49e390b2ed3df9e00af6168 Mon Sep 17 00:00:00 2001 From: suerprisePlus <15810472099@163.com> Date: 星期四, 27 六月 2024 17:05:37 +0800 Subject: [PATCH] 方案2 --- src/views/chartView/index.vue | 366 ++++++++++++++++++++++++++++++++++++++++++++++++--- 1 files changed, 339 insertions(+), 27 deletions(-) diff --git a/src/views/chartView/index.vue b/src/views/chartView/index.vue index ddf0cee..f757b69 100644 --- a/src/views/chartView/index.vue +++ b/src/views/chartView/index.vue @@ -1,12 +1,7 @@ <template> <div class="chartBox"> <div class="ChartBox"> - <JwChat-index - :taleList="list" - @enter="bindEnter" - v-model="inputMsg" - :toolConfig="tool" - > + <JwChat-index :taleList="list" @enter="bindEnter" v-model="inputMsg" :toolConfig="tool"> </JwChat-index> </div> </div> @@ -17,7 +12,16 @@ import msgData from "../../assets/js/msg/msgData"; import store from "../../store"; import bus from "./../../assets/js/bus.js"; -import { getAIMessage } from "../../api/api.js"; +import { getAIMessage, getV1Fastgpt, getChartMessage } from "../../api/api.js"; +import { getQueryEentity } from "../../api/modelBase.js"; +import mapInfo from "../../assets/js/map/mapInfo.js"; +import axios from "axios"; +import layerJson from "../../assets/js/map/mapJsonLayer.js"; +import { factors } from "@turf/turf"; +import mapConfig from "../../assets/js/map/mapConfig.js"; +import { getToken } from "../../utils/auth.js"; +import modelLayer from "../../assets/js/map/modelLayer.js"; + export default { name: "jwChat", @@ -67,42 +71,333 @@ clearInterval(window.timer); window.timer = null; } + // this.setLoading(); setTimeout(() => { this.setMsgStart("鎮ㄥソ"); - }, config.loadTime); + }, 1000); + setTimeout(() => { + const obj = mapConfig.setJsonToMd([{ + h6: "璀﹀憡: 鑿插緥瀹捐嫃姣斿厠婀惧尯鍩熸娴嬪嚭寮傚父鍐涗簨鐩爣!" + }, { + p: "寮傚父浠e彿:4r5as5s001" + }]); + var roleMsg = msgData.getJsonToMdData(obj); + this.list.push(roleMsg) + }, 3000); bus.$on("mapInfo", (res) => { if (res) { - this.setMapInfo(res); + // this.setMapInfo(res); } }); + bus.$on("setInsertMarkDown", (res) => { + if (res) { + this.setMarkDownInfo(res); + } + }); + bus.$on("setRagMoreListAll", res => { + if (res) { + this.setRagMoreList(res); + } + }); + // axios.get("http://192.168.11.89:12315/Markdown.md").then((response) => { + // if (response.status == 200) { + // console.log(response); + // this.setMarkDownInfo(response.data); + // } + // }); }, methods: { + getMd() { + const obj = mapConfig.setJsonToMd(); + const length = this.list.length - 1; + var roleMsg = msgData.getJsonToMdData(obj); + this.list[length].list = roleMsg.list + this.loading = false; + }, bindEnter() { const msg = this.inputMsg; + if (!msg) return; + this.getMsg("role", msg); + + this.setLoading(); setTimeout(() => { - // this.loading = true; + this.setMsgStart(msg); - // const loader = msgData.getLoader(); - // this.list.push(loader); + + }, 200); }, - async setMsgStart(res) { - const data = await getAIMessage(res); - - // var msg = aiData.aiMsg[0] - this.getMsg("ai", data); - if (res == "hi") { - this.$nextTick(() => { - setTimeout(() => { - this.$store.state.erroInfoMessage = { - title: "璀﹀憡锛氳彶寰嬪鑻忔瘮鍏嬫咕鍖哄煙妫�娴嬪嚭寮傚父鍐涗簨鐩爣锛�", - val: "寮傚父浠e彿锛�4r5as5s001" - }; - }, 5000); - }); + getQueryGroupBy(layer, filed) { + const layerId = modelLayer.layers.filter((item) => { + if (item.name == layer) { + return item; + } + }); + if (layerId.length <= 0) { + return; } + const obj = [ + { + type: "count", + field: filed, + outfield: "count_" + filed + } + ]; + return { + layerid: layerId[0].id, + dbid: modelLayer.dbid, + token: getToken(), + statistics: JSON.stringify(obj), + containCount: true, + groupby: filed + } + + }, + async getQueryEentityGroupBy(res, filed) { + const data = await getQueryEentity(res); + const message = mapConfig.setScanList(data.data, filed) + + this.getMsg("ai", message); + }, + async getQueryEentityDescription(res) { + const std = []; + const str = []; + const data = await getQueryEentity({ + token: res.token, + start: 1, + count: 0, + containCount: true, + layerid: res.layerid, + dbid: res.dbid, + }); + const items = data.data.items; + + items.map(rs => { + var name = rs["weaponname"] + if (name) { + var boolen = true; + if (str.length == 0) { + boolen = true; + } else if (str.indexOf(name) > -1) { + boolen = false; + } else { + boolen = true; + } + if (boolen) { + const obj = mapConfig.setArrList(rs["descriptio"]) + for (var i in obj) { + std.push(obj[i]) + } + str.push(name) + } + } + }) + const jstomd = mapConfig.setJsonToMd(std) + const length = this.list.length - 1; + var roleMsg = msgData.getJsonToMdData(jstomd); + this.list[length].list = roleMsg.list + this.loading = false; + }, + + async setMsgStart(res) { + if (res.indexOf("鍐涗簨鐩爣") > -1 || res.indexOf("姘戝畢") > -1 || res.indexOf("缁忔祹鐩爣") > -1 || res.indexOf("娴峰啗闄嗘垬闃�") > -1 || res.indexOf("鍫や赴") > -1) { + this.$store.state.setScreenFlag = true; + this.list.splice(-1, 1); + this.loading = false; + layerJson.setQyeryData(res); + } else if (res.indexOf("markDown") > -1) { + setTimeout(() => { + this.getMd(); + }, 2000); + + } else if (res.indexOf("scanWeapon") > -1) { + this.setQueryMapPlan("scanWeapon") + } else if (res.indexOf("weaponParameters") > -1) { + this.setQueryMapPlan("weaponParameters") + } else if (res.indexOf("searchTarget") > -1) { + this.setQueryMapPlan("searchTarget") + } else if (res.indexOf("searchStrikeableTarget") > -1) { + this.setQueryMapPlan("searchStrikeableTarget") + } else if (res.indexOf("USAFCommandCenterQuery") > -1) { + this.setQueryMapPlan("USAFCommandCenterQuery") + } else if (res.indexOf("attackUSAFCommandCenter") > -1) { + this.setQueryMapPlan("attackUSAFCommandCenter") + } else if (res.indexOf("defenceRangeTyphoonSystem") > -1) { + this.setQueryMapPlan("defenceRangeTyphoonSystem") + } + // else if(res.indexOf("鑻忔瘮鍏嬫咕") > -1){ + // this.$store.state.setScreenFlag = true; + // this.list.splice(-1, 1); + // this.loading = false; + // this.$nextTick(() => { + // setTimeout(() => { + // mapInfo.setEntityQueryInput(); + // }, 1000); + // }); + // } + else if (res == "涓夌淮瀹炴櫙") { + layerJson.setTitleSetRest(); + this.setV1Fastgpt(res) + } else { + const data = await getAIMessage(res); + + if (data.status == 200) { + if (data.content) { + this.getMsg("ai", data.content); + } else { + this.getMsg("ai", ""); + } + if (data.name) { + this.$store.state.setScreenFlag = true; + this.$nextTick(() => { + setTimeout(() => { + this.setQueryMapPlan(data.name) + + }, 1000); + }); + } + } + } + }, + setQueryMapPlan(res) { + + if (this.$store.state.setScreenFlag == false) { + this.$store.state.setScreenFlag = true; + } + layerJson.setTitleSetRest(); + mapInfo.setEntityQueryInput(); + switch (res) { + case "scanWeapon": + mapInfo.setFlyTo({ + "longitude": 120.26907736668211, + "latitude": 14.791708841800627, + "height": 1371.1909347746105 + }); + var obj = this.getQueryGroupBy("姝﹀櫒", "weaponname") + this.getQueryEentityGroupBy(obj, "weaponname") + layerJson.setAddWfsLayer(); + // layerJson.setAddWfsJson(); + break; + case "weaponParameters": + var obj = this.getQueryGroupBy("姝﹀櫒", "description") + this.getQueryEentityDescription(obj) + break; + case "searchTarget": + var obj = this.getQueryGroupBy("寤虹瓚", "targettype") + this.getQueryEentityGroupBy(obj, "targettype") + var list = [{ + name: "鍐涗簨鐩爣", + color: "#409EFF" + }, { + name: "姘戝畢", + color: "#808080" + }, { + name: "缁忔祹鐩爣", + color: "#FFFF00" + } + ] + layerJson.setQueryByFiledList(list, 0) + break; + case "searchStrikeableTarget": + var obj = "strikeable = 'TRUE'" + ""; + layerJson.setQueryByFiled(obj, "#FF0000", false) + this.getMsg("ai", "鐩稿叧淇℃伅宸插湪鍦板浘妯″潡灞曠ず"); + break; + case "USAFCommandCenterQuery": + var obj = "ejfl like '%绌哄啗鍩哄湴%'"; + layerJson.setQueryExtent2(obj, false) + this.getMsg("ai", "鐩稿叧淇℃伅宸插湪鍦板浘妯″潡灞曠ず"); + break; + case "attackUSAFCommandCenter": + var obj = "ejfl like '%绌哄啗鍩哄湴%'"; + layerJson.setQueryExtent2(obj, true) + this.getMsg("ai", "鐩稿叧淇℃伅宸插湪鍦板浘妯″潡灞曠ず"); + break; + case "defenceRangeTyphoonSystem": + var obj = "weaponname like '%" + name + "%'" + ""; + layerJson.setQueryTF2(obj) + this.getMsg("ai", "鐩稿叧淇℃伅宸插湪鍦板浘妯″潡灞曠ず"); + break; + + default: + mapInfo.init(res); + break; + } + }, + + + + + + setRagMoreList(res) { + const obj = this.$store.state.ragList + const val_data = obj.filter(item => { + if (item.quest === res) { + return item; + } + }); + if (val_data.length <= 0) return + + this.$store.state.ragList = obj; + const val_obj = val_data[0] + const key = val_obj.index; + const val = val_obj.val; + this.list[key].list[0].more = false; + var flag = 1; + var intValTime = setInterval(() => { + if (flag >= val.length) { + const obj = JSON.parse(JSON.stringify(this.list)) + this.list = obj + for (var i in obj) { + if (obj[i].quest === res) { + obj.splice(i, 1) + } + } + + clearInterval(intValTime) + return + } + const valitem = val[flag]; + const roleMsg = msgData.getRagData(valitem, false, ""); + this.list[key].list.push(roleMsg[0]) + flag++ + }, 1000); + + }, + setRagInterval(flag, index, res) { + if (flag < res.length) { + const obj = res[flag] + + this.list[index].list.push(roleMsg[0]) + setTimeout(() => { + flag++; + this.setRagInterval(flag, index, res) + }, 1000); + } else { + return + } + }, + async setV1Fastgpt(res) { + const data = await getV1Fastgpt(res); + + const length = this.list.length - 1; + + const obj = data[0].quoteList + this.$store.state.ragList.push({ + quest: res, + index: length, + val: obj + }) + var roleMsg = msgData.getRagData(obj[0], true, res); + this.list[length].list = roleMsg + this.loading = false; + }, + setMarkDownInfo(res) { + var roleMsg = msgData.getRole("markDown", res); + this.list.push(roleMsg.msg); + // }, setMapInfo(res) { var msg = ""; @@ -110,10 +405,21 @@ msg = "<div>寮傚父鏌ヨ</div>" + res.value; } this.getMsg("role", msg); + this.setMsgStart(res.value); }, getMsg(type, msg) { var roleMsg = msgData.getRole(type, msg); - this.list.push(roleMsg.msg); + + + if (this.loading) { + + this.loading = false; + + + this.list[this.list.length - 1].list = roleMsg.msg.list; + } else { + this.list.push(roleMsg.msg); + } }, setShowMsg() { if (this.msgData.text) { @@ -140,6 +446,11 @@ this.list.push(val); } + }, + setLoading() { + const loader = msgData.getLoader(); + this.list.push(loader); + this.loading = true; }, getLoadingFlag() { if (this.list.length == 0) { @@ -202,6 +513,7 @@ line-height: 30px; border-bottom: 1px solid #c1c1c1; } + @keyframes siz { from { width: 0; -- Gitblit v1.9.3