diff --git a/pages/index/index.vue b/pages/index/index.vue index d0dbfdb..f0e00a2 100644 --- a/pages/index/index.vue +++ b/pages/index/index.vue @@ -5,12 +5,15 @@ + - + + | @@ -18,9 +21,9 @@ + - @@ -30,6 +33,7 @@ + @@ -61,13 +65,11 @@ c_content: '', n_content: '', timer: '', - TEXT: '你好,我的名字叫大', - APPID: '2eda6c2e', // 控制台获取填写 - APIKey: '12ec1f9d113932575fc4b114a2f60ffd', - APISecret: 'MDEyMzE5YTc5YmQ5NjMwOTU1MWY4N2Y2', - sparkResult: '', + socketTask: {}, + TEXT: '', historyTextList: [], // 历史会话信息,由于最大token12000,可以结合实际使用,进行移出 tempRes: '', // 临时答复保存 + scrollTop: 0 } }, mounted() { @@ -80,9 +82,14 @@ if(e.height==0)h *= -1; else h = e.height; uni.createSelectorQuery().selectViewport().scrollOffset(function(res) { - const scrollTop = res.scrollTop; // 页面滚动距离 + let scrollTop = res.scrollTop; // 页面滚动距离 + // let os = uni.getSystemInfoSync(); + // // 可视窗口高度 = 设备可使用高度 - 状态栏高度 - 导航栏高度 + // const viewportHeight = os.windowHeight - os.statusBarHeight - (os.platform == "android" ? 50 : 45)-10; + // if(scrollTop { - // const height = rect?.height; - // console.log(height, rect); - // }) - // .exec(); }) } else { clearInterval(this.timer); @@ -151,7 +149,6 @@ return; // } - // 此处用到 ES7 的 async/await 知识,为使代码更加优美。不懂的请自行学习。 let get = async () => { this.hideLoadTips(); this.ajax.flag = false; @@ -197,7 +194,7 @@ } get(); }, - // 拼接历史记录消息,正式项目可替换为请求历史记录接口 + // 拼接历史记录消息 joinHistoryMsg() { let join = () => { let arr = []; @@ -269,6 +266,23 @@ }) return; } + try{ + clearInterval(this.timer); + this.talkList[this.talkList.length-1].content = this.c_content+''; + this.c_content = ''; + this.n_content = ''; + this.socketTask.close({ + success:(res)=> { + console.log('关闭成功', res); + this.wsLiveFlag = false; + }, + fail(err) { + console.log('关闭失败', err) + } + }) + }catch(e){ + //TODO handle the exception + } // 将当前发送信息 添加到消息列表。 let data = { "id": new Date().getTime(), @@ -286,6 +300,7 @@ "type": 2, "pic": "/static/avatar.png" }); + // return ; this.$nextTick(() => { // 清空内容框中的内容 this.content = ''; @@ -298,16 +313,15 @@ }, async sendToSpark() { - let myUrl = await this.getWebSocketUrl(); + // let myUrl = await this.getWebSocketUrl(); this.tempRes = ""; - // this.sparkResult = ""; let realThis = this; this.socketTask = uni.connectSocket({ //url: encodeURI(encodeURI(myUrl).replace(/\+/g, '%2B')), - url: myUrl, + url: 'wss://chat.lihaink.cn/chat', method: 'GET', success: res => { - console.log(res, "ws成功连接...", myUrl) + console.log(res, "ws成功连接...") realThis.wsLiveFlag = true; } }) @@ -319,31 +333,27 @@ "role": "user", "content": this.TEXT }) - console.info("wss的onOpen成功执行...", res) // 第一帧.......................................... - console.log('open成功...') - let params = { - "header": { - "app_id": this.APPID, - "uid": "aef9f963-7" - }, - "parameter": { - "chat": { - "domain": "generalv2", - "temperature": 0.5, - "max_tokens": 1024 - } - }, - "payload": { - "message": { - "text": this.historyTextList - } - } - }; - console.log("请求的params:" + JSON.stringify(params)) - this.sparkResult = this.sparkResult + "\r\n我:" + this.TEXT + "\r\n" - this.sparkResult = this.sparkResult + "大模型:" - console.log("发送第一帧...", params) + console.log('连接成功...') + // let params = { + // "header": { + // "app_id": this.APPID, + // "uid": "aef9f963-7" + // }, + // "parameter": { + // "chat": { + // "domain": "generalv2", + // "temperature": 0.5, + // "max_tokens": 1024 + // } + // }, + // "payload": { + // "message": { + // "text": this.historyTextList + // } + // } + // }; + let params = this.TEXT realThis.socketTask.send({ // 发送消息,,都用uni的官方版本 data: JSON.stringify(params), success() { @@ -359,12 +369,10 @@ // console.log("我打印的"+obj.payload); let dataArray = obj.payload.choices.text; for (let i = 0; i < dataArray.length; i++) { - realThis.sparkResult = realThis.sparkResult + dataArray[i].content; this.talkList[this.talkList.length - 1].content += dataArray[i].content; this.n_content = this.talkList[this.talkList.length - 1].content; realThis.tempRes = realThis.tempRes + dataArray[i].content } - // realThis.sparkResult =realThis.sparkResult+ let temp = JSON.parse(res.data) // console.log("0726",temp.header.code) if (temp.header.code !== 0) { @@ -381,16 +389,10 @@ } if (temp.header.code === 0) { if (res.data && temp.header.status === 2) { - realThis.sparkResult = realThis.sparkResult + - "\r\n**********************************************" this.historyTextList.push({ "role": "assistant", "content": this.tempRes }) - /* let dataArray= obj.payload.choices.text; - for(let i=0;i { realThis.socketTask.close({ success(res) { @@ -428,6 +430,18 @@ resolve(url); }); }, + // 滚动到头部 + bindScroll() { + if (this.userId == 0) { + this.getHistory(); + this.getproductInfo(); + this.getOrderInfo(); + this.getRefundDetail(); + this.getStoreDetail(); + } else { + this.getMerHistory(); + } + }, } } @@ -439,6 +453,20 @@ background-color: #f5f5f5; font-size: 28rpx; } + + @keyframes blink { + 0% { opacity: 1; } + 50% { opacity: 0; } + 100% { opacity: 1; } + } + + .blinking-box { + background-color: #333; + color: #333; + animation: blink 1s infinite; + width: 2px; + overflow: hidden; + } .wrapper { height: auto !important; diff --git a/unpackage/dist/dev/app-plus/app-service.js b/unpackage/dist/dev/app-plus/app-service.js index 464f838..ed78d79 100644 --- a/unpackage/dist/dev/app-plus/app-service.js +++ b/unpackage/dist/dev/app-plus/app-service.js @@ -253,126 +253,155 @@ var render = function () { _c( "view", { staticClass: _vm._$s(4, "sc", "talk-list"), attrs: { _i: 4 } }, - _vm._l( - _vm._$s(5, "f", { forItems: _vm.talkList }), - function (item, index, $20, $30) { - return _c( - "view", - { - key: _vm._$s(5, "f", { forIndex: $20, key: index }), - attrs: { - id: _vm._$s("5-" + $30, "a-id", "msg-" + item.id), - _i: "5-" + $30, - }, + [ + _c( + "scroll-view", + { + attrs: { + "scroll-top": _vm._$s(5, "a-scroll-top", _vm.scrollTop), + _i: 5, }, - [ - _c( + on: { scrolltoupper: _vm.bindScroll }, + }, + _vm._l( + _vm._$s(6, "f", { forItems: _vm.talkList }), + function (item, index, $20, $30) { + return _c( "view", { - staticClass: _vm._$s("6-" + $30, "sc", "item flex_col"), - class: _vm._$s( - "6-" + $30, - "c", - item.type == 1 ? "push" : "pull" - ), - attrs: { _i: "6-" + $30 }, + key: _vm._$s(6, "f", { forIndex: $20, key: index }), + attrs: { + id: _vm._$s("6-" + $30, "a-id", "msg-" + item.id), + _i: "6-" + $30, + }, }, [ - _c("image", { - staticClass: _vm._$s("7-" + $30, "sc", "pic"), - attrs: { - src: _vm._$s("7-" + $30, "a-src", item.pic), - _i: "7-" + $30, - }, - }), - _vm._$s( - "8-" + $30, - "i", - _vm.talkList.length - 1 == index - ) - ? _c( - "view", - { - staticClass: _vm._$s( - "8-" + $30, - "sc", - "content multiline-text" - ), - attrs: { _i: "8-" + $30 }, - }, - [ - _c("bing-math", { - key: _vm._$s( - "9-" + $30, - "a-key", - "math-" + item.id - ), - staticClass: _vm._$s( - "9-" + $30, - "sc", - "bing-math" - ), - attrs: { - latex: _vm.c_content, - _i: "9-" + $30, - }, - }), - ], - 1 - ) - : _c( - "view", - { - staticClass: _vm._$s( - "10-" + $30, - "sc", - "content multiline-text" - ), - attrs: { _i: "10-" + $30 }, - }, - [ - _c("bing-math", { - key: _vm._$s( - "11-" + $30, - "a-key", - "math-" + item.id - ), - staticClass: _vm._$s( - "11-" + $30, - "sc", - "bing-math" - ), - attrs: { - latex: item.content, - _i: "11-" + $30, - }, - }), - ], - 1 + _c( + "view", + { + staticClass: _vm._$s( + "7-" + $30, + "sc", + "item flex_col" ), + class: _vm._$s( + "7-" + $30, + "c", + item.type == 1 ? "push" : "pull" + ), + attrs: { _i: "7-" + $30 }, + }, + [ + _c("image", { + staticClass: _vm._$s("8-" + $30, "sc", "pic"), + attrs: { + src: _vm._$s("8-" + $30, "a-src", item.pic), + _i: "8-" + $30, + }, + }), + _vm._$s( + "9-" + $30, + "i", + _vm.talkList.length - 1 == index + ) + ? _c( + "view", + { + staticClass: _vm._$s( + "9-" + $30, + "sc", + "content multiline-text" + ), + attrs: { _i: "9-" + $30 }, + }, + [ + _vm._$s( + "10-" + $30, + "i", + _vm.c_content != "" + ) + ? _c("bing-math", { + key: _vm._$s( + "10-" + $30, + "a-key", + "math-" + item.id + ), + staticClass: _vm._$s( + "10-" + $30, + "sc", + "bing-math" + ), + attrs: { + latex: _vm.c_content, + _i: "10-" + $30, + }, + }) + : _c("view", { + staticClass: _vm._$s( + "11-" + $30, + "sc", + "blinking-box" + ), + attrs: { _i: "11-" + $30 }, + }), + ], + 1 + ) + : _c( + "view", + { + staticClass: _vm._$s( + "12-" + $30, + "sc", + "content multiline-text" + ), + attrs: { _i: "12-" + $30 }, + }, + [ + _c("bing-math", { + key: _vm._$s( + "13-" + $30, + "a-key", + "math-" + item.id + ), + staticClass: _vm._$s( + "13-" + $30, + "sc", + "bing-math" + ), + attrs: { + latex: item.content, + _i: "13-" + $30, + }, + }), + ], + 1 + ), + ] + ), ] - ), - ] - ) - } - ), - 0 + ) + } + ), + 0 + ), + ] ), ] ), _c( "view", - { staticClass: _vm._$s(12, "sc", "box-2"), attrs: { _i: 12 } }, + { staticClass: _vm._$s(14, "sc", "box-2"), attrs: { _i: 14 } }, [ _c( "view", - { staticClass: _vm._$s(13, "sc", "flex_col"), attrs: { _i: 13 } }, + { staticClass: _vm._$s(15, "sc", "flex_col"), attrs: { _i: 15 } }, [ _c( "view", { - staticClass: _vm._$s(14, "sc", "flex_grow"), - attrs: { _i: 14 }, + staticClass: _vm._$s(16, "sc", "flex_grow"), + attrs: { _i: 16 }, }, [ _c("input", { @@ -384,9 +413,9 @@ var render = function () { expression: "content", }, ], - staticClass: _vm._$s(15, "sc", "content"), - attrs: { _i: 15 }, - domProps: { value: _vm._$s(15, "v-model", _vm.content) }, + staticClass: _vm._$s(17, "sc", "content"), + attrs: { _i: 17 }, + domProps: { value: _vm._$s(17, "v-model", _vm.content) }, on: { focus: _vm.focus, confirm: _vm.send, @@ -401,8 +430,8 @@ var render = function () { ] ), _c("button", { - staticClass: _vm._$s(16, "sc", "send"), - attrs: { _i: 16 }, + staticClass: _vm._$s(18, "sc", "send"), + attrs: { _i: 18 }, on: { click: _vm.send }, }), ] @@ -661,7 +690,7 @@ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _HBu /***/ (function(module, exports, __webpack_require__) { "use strict"; -eval("/* WEBPACK VAR INJECTION */(function(__f__) {\n\nvar _interopRequireDefault = __webpack_require__(/*! @babel/runtime/helpers/interopRequireDefault */ 1);\nvar _typeof = __webpack_require__(/*! @babel/runtime/helpers/typeof */ 4);\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\nvar _regenerator = _interopRequireDefault(__webpack_require__(/*! @babel/runtime/regenerator */ 19));\nvar _toConsumableArray2 = _interopRequireDefault(__webpack_require__(/*! @babel/runtime/helpers/toConsumableArray */ 21));\nvar _asyncToGenerator2 = _interopRequireDefault(__webpack_require__(/*! @babel/runtime/helpers/asyncToGenerator */ 27));\nvar base64 = _interopRequireWildcard(__webpack_require__(/*! base-64 */ 28));\nvar _cryptoJs = _interopRequireDefault(__webpack_require__(/*! ../../static/crypto-js/crypto-js.js */ 32));\nvar _parser = _interopRequireDefault(__webpack_require__(/*! ../../static/fast-xml-parser/src/parser */ 190));\nvar utf8 = _interopRequireWildcard(__webpack_require__(/*! utf8 */ 199));\nvar _miniprogramFetch = _interopRequireDefault(__webpack_require__(/*! miniprogram-fetch */ 200));\nvar _axios = _interopRequireDefault(__webpack_require__(/*! axios */ 210));\nvar _bingMath = _interopRequireDefault(__webpack_require__(/*! @/components/bing-math/bing-math.vue */ 10));\nfunction _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== \"function\") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }\nfunction _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== \"object\" && typeof obj !== \"function\") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== \"default\" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\nvar _default = {\n components: {\n 'bing-math': _bingMath.default\n },\n data: function data() {\n return {\n talkList: [],\n ajax: {\n rows: 20,\n //每页数量\n page: 1,\n //页码\n flag: false,\n // 请求开关\n loading: false,\n // 加载中\n loadText: '正在获取消息'\n },\n keyboardHeight: 0,\n showplc: true,\n content: '',\n c_content: '',\n n_content: '',\n timer: '',\n TEXT: '你好,我的名字叫大',\n APPID: '2eda6c2e',\n // 控制台获取填写\n APIKey: '12ec1f9d113932575fc4b114a2f60ffd',\n APISecret: 'MDEyMzE5YTc5YmQ5NjMwOTU1MWY4N2Y2',\n sparkResult: '',\n historyTextList: [],\n // 历史会话信息,由于最大token12000,可以结合实际使用,进行移出\n tempRes: '' // 临时答复保存\n };\n },\n mounted: function mounted() {\n var _this = this;\n this.$nextTick(function () {\n _this.getHistoryMsg();\n });\n uni.onKeyboardHeightChange(function (e) {\n var h = _this.keyboardHeight;\n _this.keyboardHeight = e.height;\n if (e.height == 0) h *= -1;else h = e.height;\n uni.createSelectorQuery().selectViewport().scrollOffset(function (res) {\n var scrollTop = res.scrollTop; // 页面滚动距离\n uni.pageScrollTo({\n scrollTop: scrollTop + h,\n // 当前位置向下滚动\n duration: 0 // 滚动过渡时间为300ms,默认值为300ms\n });\n }).exec();\n });\n },\n beforeDestroy: function beforeDestroy() {\n uni.offKeyboardHeightChange();\n },\n onPageScroll: function onPageScroll(e) {\n if (e.scrollTop < 5) {\n this.getHistoryMsg();\n }\n },\n watch: {\n n_content: function n_content(n, o) {\n var _this2 = this;\n // this.c_content = n;\n if (this.timer) clearInterval(this.timer);\n var cl = this.c_content.length;\n var nc = this.n_content.split('');\n this.timer = setInterval(function () {\n if (cl < nc.length) {\n _this2.c_content += nc[cl];\n cl++;\n if (cl % 6 == 0) _this2.$nextTick(function () {\n uni.pageScrollTo({\n scrollTop: 999999\n });\n\n // uni.createSelectorQuery()\n // .in(this)\n // .select('.box-1')\n // .boundingClientRect((rect) => {\n // const height = rect?.height;\n // console.log(height, rect);\n // })\n // .exec();\n });\n } else {\n clearInterval(_this2.timer);\n _this2.$nextTick(function () {\n uni.pageScrollTo({\n scrollTop: 9999999\n });\n });\n }\n }, 60);\n }\n },\n methods: {\n copyText: function copyText(str) {\n uni.setClipboardData({\n data: str,\n success: function success() {\n uni.showToast({\n icon: 'none',\n title: '复制成功'\n });\n }\n });\n },\n // 获取历史消息\n getHistoryMsg: function getHistoryMsg() {\n var _this3 = this;\n if (!this.ajax.flag) {\n return; //\n }\n\n // 此处用到 ES7 的 async/await 知识,为使代码更加优美。不懂的请自行学习。\n var get = /*#__PURE__*/function () {\n var _ref = (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee() {\n var data, selector;\n return _regenerator.default.wrap(function _callee$(_context) {\n while (1) {\n switch (_context.prev = _context.next) {\n case 0:\n _this3.hideLoadTips();\n _this3.ajax.flag = false;\n _context.next = 4;\n return _this3.joinHistoryMsg();\n case 4:\n data = _context.sent;\n __f__(\"log\", '----- 模拟数据格式,供参考 -----', \" at pages/index/index.vue:160\");\n __f__(\"log\", data, \" at pages/index/index.vue:161\"); // 查看请求返回的数据结构 \n\n // 获取待滚动元素选择器,解决插入数据后,滚动条定位时使用\n selector = '';\n if (_this3.ajax.page > 1) {\n // 非第一页,则取历史消息数据的第一条信息元素\n selector = \"#msg-\".concat(_this3.talkList[0].id);\n } else {\n // 第一页,则取当前消息数据的最后一条信息元素\n selector = \"#msg-\".concat(data[data.length - 1].id);\n }\n\n // 将获取到的消息数据合并到消息数组中\n _this3.talkList = [].concat((0, _toConsumableArray2.default)(data), (0, _toConsumableArray2.default)(_this3.talkList));\n\n // 数据挂载后执行,不懂的请自行阅读 Vue.js 文档对 Vue.nextTick 函数说明。\n _this3.$nextTick(function () {\n // 设置当前滚动的位置\n _this3.setPageScrollTo(selector);\n _this3.hideLoadTips(true);\n if (data.length < _this3.ajax.rows) {\n // 当前消息数据条数小于请求要求条数时,则无更多消息,不再允许请求。\n // 可在此处编写无更多消息数据时的逻辑\n } else {\n _this3.ajax.page++;\n\n // 延迟 200ms ,以保证设置窗口滚动已完成\n setTimeout(function () {\n _this3.ajax.flag = true;\n }, 200);\n }\n });\n case 11:\n case \"end\":\n return _context.stop();\n }\n }\n }, _callee);\n }));\n return function get() {\n return _ref.apply(this, arguments);\n };\n }();\n get();\n },\n // 拼接历史记录消息,正式项目可替换为请求历史记录接口\n joinHistoryMsg: function joinHistoryMsg() {\n var _this4 = this;\n var join = function join() {\n var arr = [];\n\n //通过当前页码及页数,模拟数据内容\n var startIndex = (_this4.ajax.page - 1) * _this4.ajax.rows;\n var endIndex = startIndex + _this4.ajax.rows;\n for (var i = startIndex; i < endIndex; i++) {\n arr.push({\n \"id\": i,\n // 消息的ID\n \"content\": \"\\u8FD9\\u662F\\u5386\\u53F2\\u8BB0\\u5F55\\u7684\\u7B2C\".concat(i + 1, \"\\u6761\\u6D88\\u606F\"),\n // 消息内容\n \"type\": Math.random() > 0.5 ? 1 : 0,\n // 此为消息类别,设 1 为发出去的消息,0 为收到对方的消息,\n \"pic\": \"/static/avatar.png\" // 头像\n });\n }\n\n /*\n \t颠倒数组中元素的顺序。将最新的数据排在本次接口返回数据的最后面。\n \t后端接口按 消息的时间降序查找出当前页的数据后,再将本页数据按消息时间降序排序返回。\n \t这是数据的重点,因为页面滚动条和上拉加载历史的问题。\n */\n arr.reverse();\n return arr;\n };\n\n // 此处用到 ES6 的 Promise 知识,不懂的请自行学习。\n return new Promise(function (done, fail) {\n // 无数据请求接口,由 setTimeout 模拟,正式项目替换为 ajax 即可。\n setTimeout(function () {\n var data = join();\n done(data);\n }, 1500);\n });\n },\n focus: function focus() {\n uni.pageScrollTo({\n top: this.keyboardHeight\n });\n },\n // 设置页面滚动位置\n setPageScrollTo: function setPageScrollTo(selector) {\n var view = uni.createSelectorQuery().in(this).select(selector);\n view.boundingClientRect(function (res) {\n uni.pageScrollTo({\n scrollTop: res.top - 30,\n // -30 为多显示出大半个消息的高度,示意上面还有信息。\n duration: 0\n });\n }).exec();\n },\n // 隐藏加载提示\n hideLoadTips: function hideLoadTips(flag) {\n var _this5 = this;\n if (flag) {\n this.ajax.loadText = '消息获取成功';\n setTimeout(function () {\n _this5.ajax.loading = false;\n }, 300);\n } else {\n this.ajax.loading = true;\n this.ajax.loadText = '正在获取消息';\n }\n },\n // 发送信息\n send: function send() {\n var _this6 = this;\n if (!this.content) {\n uni.showToast({\n title: '请输入有效的内容',\n icon: 'none'\n });\n return;\n }\n // 将当前发送信息 添加到消息列表。\n var data = {\n \"id\": new Date().getTime(),\n \"content\": this.content,\n \"type\": 1,\n \"pic\": \"/static/avatar.png\"\n };\n this.TEXT = this.content;\n this.n_content = '';\n this.c_content = '';\n this.talkList.push(data);\n this.talkList.push({\n \"id\": new Date().getTime(),\n \"content\": '',\n \"type\": 2,\n \"pic\": \"/static/avatar.png\"\n });\n this.$nextTick(function () {\n // 清空内容框中的内容\n _this6.content = '';\n uni.pageScrollTo({\n scrollTop: 999999,\n // 设置一个超大值,以保证滚动条滚动到底部\n duration: 0\n });\n });\n this.sendToSpark();\n },\n sendToSpark: function sendToSpark() {\n var _this7 = this;\n return (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee2() {\n var myUrl, realThis;\n return _regenerator.default.wrap(function _callee2$(_context2) {\n while (1) {\n switch (_context2.prev = _context2.next) {\n case 0:\n _context2.next = 2;\n return _this7.getWebSocketUrl();\n case 2:\n myUrl = _context2.sent;\n _this7.tempRes = \"\";\n // this.sparkResult = \"\";\n realThis = _this7;\n _this7.socketTask = uni.connectSocket({\n //url: encodeURI(encodeURI(myUrl).replace(/\\+/g, '%2B')),\n url: myUrl,\n method: 'GET',\n success: function success(res) {\n __f__(\"log\", res, \"ws成功连接...\", myUrl, \" at pages/index/index.vue:310\");\n realThis.wsLiveFlag = true;\n }\n });\n realThis.socketTask.onError(function (res) {\n __f__(\"log\", \"连接发生错误,请检查appid是否填写\", res, \" at pages/index/index.vue:315\");\n });\n realThis.socketTask.onOpen(function (res) {\n _this7.historyTextList.push({\n \"role\": \"user\",\n \"content\": _this7.TEXT\n });\n __f__(\"info\", \"wss的onOpen成功执行...\", res, \" at pages/index/index.vue:322\");\n // 第一帧..........................................\n __f__(\"log\", 'open成功...', \" at pages/index/index.vue:324\");\n var params = {\n \"header\": {\n \"app_id\": _this7.APPID,\n \"uid\": \"aef9f963-7\"\n },\n \"parameter\": {\n \"chat\": {\n \"domain\": \"generalv2\",\n \"temperature\": 0.5,\n \"max_tokens\": 1024\n }\n },\n \"payload\": {\n \"message\": {\n \"text\": _this7.historyTextList\n }\n }\n };\n __f__(\"log\", \"请求的params:\" + JSON.stringify(params), \" at pages/index/index.vue:343\");\n _this7.sparkResult = _this7.sparkResult + \"\\r\\n我:\" + _this7.TEXT + \"\\r\\n\";\n _this7.sparkResult = _this7.sparkResult + \"大模型:\";\n __f__(\"log\", \"发送第一帧...\", params, \" at pages/index/index.vue:346\");\n realThis.socketTask.send({\n // 发送消息,,都用uni的官方版本\n data: JSON.stringify(params),\n success: function success() {\n __f__(\"log\", '第一帧发送成功', \" at pages/index/index.vue:350\");\n }\n });\n });\n\n // 接受到消息时\n realThis.socketTask.onMessage(function (res) {\n __f__(\"log\", '收到API返回的内容:', res.data, \" at pages/index/index.vue:357\");\n var obj = JSON.parse(res.data);\n // console.log(\"我打印的\"+obj.payload);\n var dataArray = obj.payload.choices.text;\n for (var i = 0; i < dataArray.length; i++) {\n realThis.sparkResult = realThis.sparkResult + dataArray[i].content;\n _this7.talkList[_this7.talkList.length - 1].content += dataArray[i].content;\n _this7.n_content = _this7.talkList[_this7.talkList.length - 1].content;\n realThis.tempRes = realThis.tempRes + dataArray[i].content;\n }\n // realThis.sparkResult =realThis.sparkResult+ \n var temp = JSON.parse(res.data);\n // console.log(\"0726\",temp.header.code)\n if (temp.header.code !== 0) {\n __f__(\"log\", \"\".concat(temp.header.code, \":\").concat(temp.message), \" at pages/index/index.vue:371\");\n realThis.socketTask.close({\n success: function success(res) {\n __f__(\"log\", '关闭成功', res, \" at pages/index/index.vue:374\");\n realThis.wsLiveFlag = false;\n },\n fail: function fail(err) {\n __f__(\"log\", '关闭失败', err, \" at pages/index/index.vue:378\");\n }\n });\n }\n if (temp.header.code === 0) {\n if (res.data && temp.header.status === 2) {\n realThis.sparkResult = realThis.sparkResult + \"\\r\\n**********************************************\";\n _this7.historyTextList.push({\n \"role\": \"assistant\",\n \"content\": _this7.tempRes\n });\n /* let dataArray= obj.payload.choices.text;\n for(let i=0;i 1) {\n // 非第一页,则取历史消息数据的第一条信息元素\n selector = \"#msg-\".concat(_this3.talkList[0].id);\n } else {\n // 第一页,则取当前消息数据的最后一条信息元素\n selector = \"#msg-\".concat(data[data.length - 1].id);\n }\n\n // 将获取到的消息数据合并到消息数组中\n _this3.talkList = [].concat((0, _toConsumableArray2.default)(data), (0, _toConsumableArray2.default)(_this3.talkList));\n\n // 数据挂载后执行,不懂的请自行阅读 Vue.js 文档对 Vue.nextTick 函数说明。\n _this3.$nextTick(function () {\n // 设置当前滚动的位置\n _this3.setPageScrollTo(selector);\n _this3.hideLoadTips(true);\n if (data.length < _this3.ajax.rows) {\n // 当前消息数据条数小于请求要求条数时,则无更多消息,不再允许请求。\n // 可在此处编写无更多消息数据时的逻辑\n } else {\n _this3.ajax.page++;\n\n // 延迟 200ms ,以保证设置窗口滚动已完成\n setTimeout(function () {\n _this3.ajax.flag = true;\n }, 200);\n }\n });\n case 11:\n case \"end\":\n return _context.stop();\n }\n }\n }, _callee);\n }));\n return function get() {\n return _ref.apply(this, arguments);\n };\n }();\n get();\n },\n // 拼接历史记录消息\n joinHistoryMsg: function joinHistoryMsg() {\n var _this4 = this;\n var join = function join() {\n var arr = [];\n\n //通过当前页码及页数,模拟数据内容\n var startIndex = (_this4.ajax.page - 1) * _this4.ajax.rows;\n var endIndex = startIndex + _this4.ajax.rows;\n for (var i = startIndex; i < endIndex; i++) {\n arr.push({\n \"id\": i,\n // 消息的ID\n \"content\": \"\\u8FD9\\u662F\\u5386\\u53F2\\u8BB0\\u5F55\\u7684\\u7B2C\".concat(i + 1, \"\\u6761\\u6D88\\u606F\"),\n // 消息内容\n \"type\": Math.random() > 0.5 ? 1 : 0,\n // 此为消息类别,设 1 为发出去的消息,0 为收到对方的消息,\n \"pic\": \"/static/avatar.png\" // 头像\n });\n }\n\n /*\n \t颠倒数组中元素的顺序。将最新的数据排在本次接口返回数据的最后面。\n \t后端接口按 消息的时间降序查找出当前页的数据后,再将本页数据按消息时间降序排序返回。\n \t这是数据的重点,因为页面滚动条和上拉加载历史的问题。\n */\n arr.reverse();\n return arr;\n };\n\n // 此处用到 ES6 的 Promise 知识,不懂的请自行学习。\n return new Promise(function (done, fail) {\n // 无数据请求接口,由 setTimeout 模拟,正式项目替换为 ajax 即可。\n setTimeout(function () {\n var data = join();\n done(data);\n }, 1500);\n });\n },\n focus: function focus() {\n uni.pageScrollTo({\n top: this.keyboardHeight\n });\n },\n // 设置页面滚动位置\n setPageScrollTo: function setPageScrollTo(selector) {\n var view = uni.createSelectorQuery().in(this).select(selector);\n view.boundingClientRect(function (res) {\n uni.pageScrollTo({\n scrollTop: res.top - 30,\n // -30 为多显示出大半个消息的高度,示意上面还有信息。\n duration: 0\n });\n }).exec();\n },\n // 隐藏加载提示\n hideLoadTips: function hideLoadTips(flag) {\n var _this5 = this;\n if (flag) {\n this.ajax.loadText = '消息获取成功';\n setTimeout(function () {\n _this5.ajax.loading = false;\n }, 300);\n } else {\n this.ajax.loading = true;\n this.ajax.loadText = '正在获取消息';\n }\n },\n // 发送信息\n send: function send() {\n var _this6 = this;\n if (!this.content) {\n uni.showToast({\n title: '请输入有效的内容',\n icon: 'none'\n });\n return;\n }\n try {\n clearInterval(this.timer);\n this.talkList[this.talkList.length - 1].content = this.c_content + '';\n this.c_content = '';\n this.n_content = '';\n this.socketTask.close({\n success: function success(res) {\n __f__(\"log\", '关闭成功', res, \" at pages/index/index.vue:276\");\n _this6.wsLiveFlag = false;\n },\n fail: function fail(err) {\n __f__(\"log\", '关闭失败', err, \" at pages/index/index.vue:280\");\n }\n });\n } catch (e) {\n //TODO handle the exception\n }\n // 将当前发送信息 添加到消息列表。\n var data = {\n \"id\": new Date().getTime(),\n \"content\": this.content,\n \"type\": 1,\n \"pic\": \"/static/avatar.png\"\n };\n this.TEXT = this.content;\n this.n_content = '';\n this.c_content = '';\n this.talkList.push(data);\n this.talkList.push({\n \"id\": new Date().getTime(),\n \"content\": '',\n \"type\": 2,\n \"pic\": \"/static/avatar.png\"\n });\n // return ;\n this.$nextTick(function () {\n // 清空内容框中的内容\n _this6.content = '';\n uni.pageScrollTo({\n scrollTop: 999999,\n // 设置一个超大值,以保证滚动条滚动到底部\n duration: 0\n });\n });\n this.sendToSpark();\n },\n sendToSpark: function sendToSpark() {\n var _this7 = this;\n return (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee2() {\n var realThis;\n return _regenerator.default.wrap(function _callee2$(_context2) {\n while (1) {\n switch (_context2.prev = _context2.next) {\n case 0:\n // let myUrl = await this.getWebSocketUrl();\n _this7.tempRes = \"\";\n realThis = _this7;\n _this7.socketTask = uni.connectSocket({\n //url: encodeURI(encodeURI(myUrl).replace(/\\+/g, '%2B')),\n url: 'wss://chat.lihaink.cn/chat',\n method: 'GET',\n success: function success(res) {\n __f__(\"log\", res, \"ws成功连接...\", \" at pages/index/index.vue:324\");\n realThis.wsLiveFlag = true;\n }\n });\n realThis.socketTask.onError(function (res) {\n __f__(\"log\", \"连接发生错误,请检查appid是否填写\", res, \" at pages/index/index.vue:329\");\n });\n realThis.socketTask.onOpen(function (res) {\n _this7.historyTextList.push({\n \"role\": \"user\",\n \"content\": _this7.TEXT\n });\n // 第一帧..........................................\n __f__(\"log\", '连接成功...', \" at pages/index/index.vue:337\");\n // let params = {\n // \"header\": {\n // \"app_id\": this.APPID,\n // \"uid\": \"aef9f963-7\"\n // },\n // \"parameter\": {\n // \"chat\": {\n // \"domain\": \"generalv2\",\n // \"temperature\": 0.5,\n // \"max_tokens\": 1024\n // }\n // },\n // \"payload\": {\n // \"message\": {\n // \"text\": this.historyTextList\n // }\n // }\n // };\n var params = _this7.TEXT;\n realThis.socketTask.send({\n // 发送消息,,都用uni的官方版本\n data: JSON.stringify(params),\n success: function success() {\n __f__(\"log\", '第一帧发送成功', \" at pages/index/index.vue:360\");\n }\n });\n });\n\n // 接受到消息时\n realThis.socketTask.onMessage(function (res) {\n __f__(\"log\", '收到API返回的内容:', res.data, \" at pages/index/index.vue:367\");\n var obj = JSON.parse(res.data);\n // console.log(\"我打印的\"+obj.payload);\n var dataArray = obj.payload.choices.text;\n for (var i = 0; i < dataArray.length; i++) {\n _this7.talkList[_this7.talkList.length - 1].content += dataArray[i].content;\n _this7.n_content = _this7.talkList[_this7.talkList.length - 1].content;\n realThis.tempRes = realThis.tempRes + dataArray[i].content;\n }\n var temp = JSON.parse(res.data);\n // console.log(\"0726\",temp.header.code)\n if (temp.header.code !== 0) {\n __f__(\"log\", \"\".concat(temp.header.code, \":\").concat(temp.message), \" at pages/index/index.vue:379\");\n realThis.socketTask.close({\n success: function success(res) {\n __f__(\"log\", '关闭成功', res, \" at pages/index/index.vue:382\");\n realThis.wsLiveFlag = false;\n },\n fail: function fail(err) {\n __f__(\"log\", '关闭失败', err, \" at pages/index/index.vue:386\");\n }\n });\n }\n if (temp.header.code === 0) {\n if (res.data && temp.header.status === 2) {\n _this7.historyTextList.push({\n \"role\": \"assistant\",\n \"content\": _this7.tempRes\n });\n setTimeout(function () {\n realThis.socketTask.close({\n success: function success(res) {\n __f__(\"log\", '关闭成功', res, \" at pages/index/index.vue:399\");\n },\n fail: function fail(err) {\n // console.log('关闭失败', err)\n }\n });\n }, 1000);\n }\n }\n });\n case 6:\n case \"end\":\n return _context2.stop();\n }\n }\n }, _callee2);\n }))();\n },\n // 鉴权\n getWebSocketUrl: function getWebSocketUrl() {\n var _this8 = this;\n return new Promise(function (resolve, reject) {\n // https://spark-api.xf-yun.com/v1.1/chat V1.5 domain general\n // https://spark-api.xf-yun.com/v2.1/chat V2.0 domain generalv2\n var url = \"wss://spark-api.xf-yun.com/v2.1/chat\";\n var host = \"spark-api.xf-yun.com\";\n var apiKeyName = \"api_key\";\n var date = new Date().toGMTString();\n var algorithm = \"hmac-sha256\";\n var headers = \"host date request-line\";\n var signatureOrigin = \"host: \".concat(host, \"\\ndate: \").concat(date, \"\\nGET /v2.1/chat HTTP/1.1\");\n var signatureSha = _cryptoJs.default.HmacSHA256(signatureOrigin, _this8.APISecret);\n var signature = _cryptoJs.default.enc.Base64.stringify(signatureSha);\n var authorizationOrigin = \"\".concat(apiKeyName, \"=\\\"\").concat(_this8.APIKey, \"\\\", algorithm=\\\"\").concat(algorithm, \"\\\", headers=\\\"\").concat(headers, \"\\\", signature=\\\"\").concat(signature, \"\\\"\");\n var authorization = base64.encode(authorizationOrigin);\n url = \"\".concat(url, \"?authorization=\").concat(authorization, \"&date=\").concat(encodeURI(date), \"&host=\").concat(host);\n\n // console.log(url)\n resolve(url);\n });\n },\n // 滚动到头部\n bindScroll: function bindScroll() {\n if (this.userId == 0) {\n this.getHistory();\n this.getproductInfo();\n this.getOrderInfo();\n this.getRefundDetail();\n this.getStoreDetail();\n } else {\n this.getMerHistory();\n }\n }\n }\n};\nexports.default = _default;\n/* WEBPACK VAR INJECTION */}.call(this, __webpack_require__(/*! ./node_modules/@dcloudio/vue-cli-plugin-uni/lib/format-log.js */ 18)[\"default\"]))//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["uni-app:///pages/index/index.vue"],"names":["components","data","talkList","ajax","rows","page","flag","loading","loadText","keyboardHeight","showplc","content","c_content","n_content","timer","socketTask","TEXT","historyTextList","tempRes","scrollTop","mounted","uni","h","duration","beforeDestroy","onPageScroll","watch","cl","clearInterval","methods","copyText","success","icon","title","getHistoryMsg","selector","setTimeout","get","joinHistoryMsg","arr","done","focus","top","setPageScrollTo","view","hideLoadTips","send","fail","sendToSpark","realThis","url","method","getWebSocketUrl","apiKeyName","resolve","bindScroll"],"mappings":";;;;;;;;;;;AAwCA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;eACA;EACAA;IACA;EACA;EACAC;IACA;MACAC;MACAC;QACAC;QAAA;QACAC;QAAA;QACAC;QAAA;QACAC;QAAA;QACAC;MACA;MACAC;MACAC;MACAC;MACAC;MACAC;MACAC;MACAC;MACAC;MACAC;MAAA;MACAC;MAAA;MACAC;IACA;EACA;EACAC;IAAA;IACA;MACA;IACA;IACAC;MACA;MACA;MACA,gCACAC;MACAD;QACA;QACA;QACA;QACA;QACA;QACAF;QACAE;UACAF;UAAA;UACAI;QACA;MACA;IACA;EACA;EACAC;IAEAH;EAEA;EACAI;IACA;MACA;IACA;EACA;EACAC;IACAb;MAAA;MACA;MACA;MACA;MACA;MACA;QACA;UACA;UACAc;UACA;YACAN;cACAF;YACA;UACA;QACA;UACAS;UACA;YACAP;cACAF;YACA;UACA;QACA;MACA;IACA;EACA;EACAU;IACAC;MACAT;QACApB;QACA8B;UACAV;YACAW;YACAC;UACA;QACA;MACA;IACA;IACA;IACAC;MAAA;MACA;QACA;MACA;;MAEA;QAAA;UAAA;UAAA;YAAA;cAAA;gBAAA;kBACA;kBACA;kBAAA;kBAAA,OACA;gBAAA;kBAAAjC;kBAEA;kBACA;;kBAEA;kBACAkC;kBAEA;oBACA;oBACAA;kBACA;oBACA;oBACAA;kBACA;;kBAEA;kBACA;;kBAEA;kBACA;oBACA;oBACA;oBAEA;oBAEA;sBACA;sBACA;oBAAA,CACA;sBACA;;sBAEA;sBACAC;wBACA;sBACA;oBACA;kBAEA;gBAAA;gBAAA;kBAAA;cAAA;YAAA;UAAA;QAAA,CACA;QAAA,gBA1CAC;UAAA;QAAA;MAAA,GA0CA;MACAA;IACA;IACA;IACAC;MAAA;MACA;QACA;;QAEA;QACA;QACA;QACA;UACAC;YACA;YAAA;YACA;YAAA;YACA;YAAA;YACA;UACA;QACA;;QAEA;AACA;AACA;AACA;AACA;QACAA;QAEA;MACA;;MAEA;MACA;QACA;QACAH;UACA;UACAI;QACA;MACA;IACA;IACAC;MACApB;QACAqB;MACA;IACA;IACA;IACAC;MACA;MACAC;QACAvB;UACAF;UAAA;UACAI;QACA;MACA;IACA;IACA;IACAsB;MAAA;MACA;QACA;QACAT;UACA;QACA;MACA;QACA;QACA;MACA;IACA;IACA;IACAU;MAAA;MACA;QACAzB;UACAY;UACAD;QACA;QACA;MACA;MACA;QACAJ;QACA;QACA;QACA;QACA;UACAG;YACA;YACA;UACA;UACAgB;YACA;UACA;QACA;MACA;QACA;MAAA;MAEA;MACA;QACA;QACA;QACA;QACA;MACA;MACA;MACA;MACA;MACA;MACA;QACA;QACA;QACA;QACA;MACA;MACA;MACA;QACA;QACA;QACA1B;UACAF;UAAA;UACAI;QACA;MACA;MACA;IAEA;IACAyB;MAAA;MAAA;QAAA;QAAA;UAAA;YAAA;cAAA;gBACA;gBACA;gBACAC;gBACA;kBACA;kBACAC;kBACAC;kBACApB;oBACA;oBACAkB;kBACA;gBACA;gBACAA;kBACA;gBACA;gBACAA;kBACA;oBACA;oBACA;kBACA;kBACA;kBACA;kBACA;kBACA;kBACA;kBACA;kBACA;kBACA;kBACA;kBACA;kBACA;kBACA;kBACA;kBACA;kBACA;kBACA;kBACA;kBACA;kBACA;kBACA;kBACA;kBACAA;oBAAA;oBACAhD;oBACA8B;sBACA;oBACA;kBACA;gBACA;;gBAEA;gBACAkB;kBACA;kBACA;kBACA;kBACA;kBACA;oBACA;oBACA;oBACAA;kBACA;kBACA;kBACA;kBACA;oBACA;oBACAA;sBACAlB;wBACA;wBACAkB;sBACA;sBACAF;wBACA;sBACA;oBACA;kBACA;kBACA;oBACA;sBACA;wBACA;wBACA;sBACA;sBACAX;wBACAa;0BACAlB;4BACA;0BACA;0BACAgB;4BACA;0BAAA;wBAEA;sBACA;oBACA;kBACA;gBACA;cAAA;cAAA;gBAAA;YAAA;UAAA;QAAA;MAAA;IACA;IACA;IACAK;MAAA;MACA;QACA;QACA;QACA;QACA;QACA;QACA;QACA;QACA;QACA;QACA;QACA;QACA,oCACAC;QACA;QACAH;;QAEA;QACAI;MACA;IACA;IACA;IACAC;MACA;QACA;QACA;QACA;QACA;QACA;MACA;QACA;MACA;IACA;EACA;AACA;AAAA,2B","file":"17.js","sourcesContent":["<template>\r\n  <view class=\"wrapper\">\r\n    <view class=\"tips color_fff size_12 align_c\" :class=\"{ 'show':ajax.loading }\" @tap=\"getHistoryMsg\">{{ajax.loadText}}\r\n    </view>\r\n    <view class=\"placeholder\"></view>\r\n    <view class=\"box-1\" id=\"list-box\" ref=\"box\">\r\n      <view class=\"talk-list\">\r\n        <scroll-view :scroll-y=\"true\" style=\"height: 100%;overflow: hidden;\" :scroll-top=\"scrollTop\"\r\n\t\t\t\t:scroll-with-animation=\"true\" @scrolltoupper=\"bindScroll\">\r\n        <view v-for=\"(item,index) in talkList\" :key=\"index\" :id=\"`msg-${item.id}`\">\r\n          <view class=\"item flex_col\" :class=\" item.type == 1 ? 'push':'pull' \">\r\n            <image :src=\"item.pic\" mode=\"aspectFill\" class=\"pic\"></image>\r\n            <view v-if=\"talkList.length-1==index\" class=\"content multiline-text\">\r\n              <!-- <rich-text :nodes=\"item.content\"></rich-text> -->\r\n              <bing-math v-if=\"c_content!=''\" :key=\"`math-${item.id}`\" class=\"bing-math\" :latex=\"c_content\"></bing-math>\r\n              <view v-else class=\"blinking-box\">|</view>\r\n            </view>\r\n            <view v-else class=\"content multiline-text\">\r\n              <!-- <rich-text :nodes=\"item.content\"></rich-text> -->\r\n              <bing-math :key=\"`math-${item.id}`\" class=\"bing-math\" :latex=\"item.content\"></bing-math>\r\n            </view>\r\n          </view>\r\n        </view>\r\n        </scroll-view>\r\n      </view>\r\n    </view>\r\n    <view class=\"box-2\">\r\n      <view class=\"flex_col\">\r\n        <view class=\"flex_grow\">\r\n          <input type=\"text\" class=\"content\" v-model=\"content\" placeholder=\"请输入聊天内容\" @focus=\"focus\" @confirm=\"send\"\r\n            placeholder-style=\"color:#DDD;\" :cursor-spacing=\"6\">\r\n        </view>\r\n        <button class=\"send\" @tap=\"send\">发送</button>\r\n      </view>\r\n    </view>\r\n    <!-- <view v-show=\"showplc\" :style=\"{'min-height': (keyboardHeight+200)+'px'}\" class=\"placeholder\">显示</view> -->\r\n  </view>\r\n</template>\r\n\r\n<script>\r\n  import * as base64 from \"base-64\"\r\n  import CryptoJS from '../../static/crypto-js/crypto-js.js'\r\n  import parser from '../../static/fast-xml-parser/src/parser'\r\n  import * as utf8 from \"utf8\"\r\n  import fetch from 'miniprogram-fetch';\r\n  import axios from 'axios';\r\n  import BingMath from \"@/components/bing-math/bing-math.vue\"\r\n  export default {\r\n    components: {\r\n      'bing-math': BingMath\r\n    },\r\n    data() {\r\n      return {\r\n        talkList: [],\r\n        ajax: {\r\n          rows: 20, //每页数量\r\n          page: 1, //页码\r\n          flag: false, // 请求开关\r\n          loading: false, // 加载中\r\n          loadText: '正在获取消息'\r\n        },\r\n        keyboardHeight: 0,\r\n        showplc: true,\r\n        content: '',\r\n        c_content: '',\r\n        n_content: '',\r\n        timer: '',\r\n        socketTask: {},\r\n        TEXT: '',\r\n        historyTextList: [], // 历史会话信息，由于最大token12000,可以结合实际使用，进行移出\r\n        tempRes: '', // 临时答复保存\r\n        scrollTop: 0\r\n      }\r\n    },\r\n    mounted() {\r\n      this.$nextTick(() => {\r\n        this.getHistoryMsg();\r\n      });\r\n      uni.onKeyboardHeightChange(e => {\r\n        let h = this.keyboardHeight;\r\n        this.keyboardHeight = e.height;\r\n        if(e.height==0)h *= -1;\r\n        else h = e.height;\r\n        uni.createSelectorQuery().selectViewport().scrollOffset(function(res) {\r\n          let scrollTop = res.scrollTop; // 页面滚动距离\r\n          // let os = uni.getSystemInfoSync();\r\n          // // 可视窗口高度 = 设备可使用高度 - 状态栏高度 - 导航栏高度\r\n          // const viewportHeight = os.windowHeight - os.statusBarHeight - (os.platform == \"android\" ? 50 : 45)-10;\r\n          // if(scrollTop<viewportHeight)scrollTop=viewportHeight;\r\n          scrollTop+=h;\r\n          uni.pageScrollTo({\r\n            scrollTop: scrollTop, // 当前位置向下滚动\r\n            duration: 0 // 滚动过渡时间为300ms，默认值为300ms\r\n          });\r\n        }).exec();\r\n      })\r\n    },\r\n    beforeDestroy() {\r\n      // #ifdef APP-PLUS\r\n      uni.offKeyboardHeightChange();\r\n      // #endif\r\n    },\r\n    onPageScroll(e) {\r\n      if (e.scrollTop < 5) {\r\n        this.getHistoryMsg();\r\n      }\r\n    },\r\n    watch: {\r\n      n_content(n, o) {\r\n        // this.c_content = n;\r\n        if (this.timer) clearInterval(this.timer);\r\n        let cl = this.c_content.length;\r\n        let nc = this.n_content.split('')\r\n        this.timer = setInterval(() => {\r\n          if (cl < nc.length) {\r\n            this.c_content += nc[cl];\r\n            cl++;\r\n            if (cl % 6 == 0) this.$nextTick(()=>{\r\n              uni.pageScrollTo({\r\n                scrollTop: 999999,\r\n              })\r\n            })\r\n          } else {\r\n            clearInterval(this.timer);\r\n            this.$nextTick(() => {\r\n              uni.pageScrollTo({\r\n                scrollTop: 9999999,\r\n              })\r\n            })\r\n          }\r\n        }, 60)\r\n      }\r\n    },\r\n    methods: {\r\n      copyText(str) {\r\n        uni.setClipboardData({\r\n          data: str,\r\n          success: function() {\r\n            uni.showToast({\r\n              icon: 'none',\r\n              title: '复制成功'\r\n            });\r\n          }\r\n        });\r\n      },\r\n      // 获取历史消息\r\n      getHistoryMsg() {\r\n        if (!this.ajax.flag) {\r\n          return; //\r\n        }\r\n\r\n        let get = async () => {\r\n          this.hideLoadTips();\r\n          this.ajax.flag = false;\r\n          let data = await this.joinHistoryMsg();\r\n\r\n          console.log('----- 模拟数据格式，供参考 -----');\r\n          console.log(data); // 查看请求返回的数据结构 \r\n\r\n          // 获取待滚动元素选择器，解决插入数据后，滚动条定位时使用\r\n          let selector = '';\r\n\r\n          if (this.ajax.page > 1) {\r\n            // 非第一页，则取历史消息数据的第一条信息元素\r\n            selector = `#msg-${this.talkList[0].id}`;\r\n          } else {\r\n            // 第一页，则取当前消息数据的最后一条信息元素\r\n            selector = `#msg-${data[data.length-1].id}`;\r\n          }\r\n\r\n          // 将获取到的消息数据合并到消息数组中\r\n          this.talkList = [...data, ...this.talkList];\r\n\r\n          // 数据挂载后执行，不懂的请自行阅读 Vue.js 文档对 Vue.nextTick 函数说明。\r\n          this.$nextTick(() => {\r\n            // 设置当前滚动的位置\r\n            this.setPageScrollTo(selector);\r\n\r\n            this.hideLoadTips(true);\r\n\r\n            if (data.length < this.ajax.rows) {\r\n              // 当前消息数据条数小于请求要求条数时，则无更多消息，不再允许请求。\r\n              // 可在此处编写无更多消息数据时的逻辑\r\n            } else {\r\n              this.ajax.page++;\r\n\r\n              // 延迟 200ms ，以保证设置窗口滚动已完成\r\n              setTimeout(() => {\r\n                this.ajax.flag = true;\r\n              }, 200)\r\n            }\r\n\r\n          })\r\n        }\r\n        get();\r\n      },\r\n      // 拼接历史记录消息\r\n      joinHistoryMsg() {\r\n        let join = () => {\r\n          let arr = [];\r\n\r\n          //通过当前页码及页数，模拟数据内容\r\n          let startIndex = (this.ajax.page - 1) * this.ajax.rows;\r\n          let endIndex = startIndex + this.ajax.rows;\r\n          for (let i = startIndex; i < endIndex; i++) {\r\n            arr.push({\r\n              \"id\": i, // 消息的ID\r\n              \"content\": `这是历史记录的第${i+1}条消息`, // 消息内容\r\n              \"type\": Math.random() > 0.5 ? 1 : 0, // 此为消息类别，设 1 为发出去的消息，0 为收到对方的消息,\r\n              \"pic\": \"/static/avatar.png\" // 头像\r\n            })\r\n          }\r\n\r\n          /*\r\n          \t颠倒数组中元素的顺序。将最新的数据排在本次接口返回数据的最后面。\r\n          \t后端接口按 消息的时间降序查找出当前页的数据后，再将本页数据按消息时间降序排序返回。\r\n          \t这是数据的重点，因为页面滚动条和上拉加载历史的问题。\r\n           */\r\n          arr.reverse();\r\n\r\n          return arr;\r\n        }\r\n\r\n        // 此处用到 ES6 的 Promise 知识，不懂的请自行学习。\r\n        return new Promise((done, fail) => {\r\n          // 无数据请求接口，由 setTimeout 模拟，正式项目替换为 ajax 即可。\r\n          setTimeout(() => {\r\n            let data = join();\r\n            done(data);\r\n          }, 1500);\r\n        })\r\n      },\r\n      focus(){\r\n        uni.pageScrollTo({\r\n          top: this.keyboardHeight\r\n        })\r\n      },\r\n      // 设置页面滚动位置\r\n      setPageScrollTo(selector) {\r\n        let view = uni.createSelectorQuery().in(this).select(selector);\r\n        view.boundingClientRect((res) => {\r\n          uni.pageScrollTo({\r\n            scrollTop: res.top - 30, // -30 为多显示出大半个消息的高度，示意上面还有信息。\r\n            duration: 0\r\n          });\r\n        }).exec();\r\n      },\r\n      // 隐藏加载提示\r\n      hideLoadTips(flag) {\r\n        if (flag) {\r\n          this.ajax.loadText = '消息获取成功';\r\n          setTimeout(() => {\r\n            this.ajax.loading = false;\r\n          }, 300);\r\n        } else {\r\n          this.ajax.loading = true;\r\n          this.ajax.loadText = '正在获取消息';\r\n        }\r\n      },\r\n      // 发送信息\r\n      send() {\r\n        if (!this.content) {\r\n          uni.showToast({\r\n            title: '请输入有效的内容',\r\n            icon: 'none'\r\n          })\r\n          return;\r\n        }\r\n        try{\r\n          clearInterval(this.timer);\r\n          this.talkList[this.talkList.length-1].content = this.c_content+'';\r\n          this.c_content = '';\r\n          this.n_content = '';\r\n          this.socketTask.close({\r\n            success:(res)=> {\r\n              console.log('关闭成功', res);\r\n              this.wsLiveFlag = false;\r\n            },\r\n            fail(err) {\r\n              console.log('关闭失败', err)\r\n            }\r\n          })\r\n        }catch(e){\r\n          //TODO handle the exception\r\n        }\r\n        // 将当前发送信息 添加到消息列表。\r\n        let data = {\r\n          \"id\": new Date().getTime(),\r\n          \"content\": this.content,\r\n          \"type\": 1,\r\n          \"pic\": \"/static/avatar.png\"\r\n        }\r\n        this.TEXT = this.content;\r\n        this.n_content = '';\r\n        this.c_content = '';\r\n        this.talkList.push(data);\r\n        this.talkList.push({\r\n          \"id\": new Date().getTime(),\r\n          \"content\": '',\r\n          \"type\": 2,\r\n          \"pic\": \"/static/avatar.png\"\r\n        });\r\n        // return ;\r\n        this.$nextTick(() => {\r\n          // 清空内容框中的内容\r\n          this.content = '';\r\n          uni.pageScrollTo({\r\n            scrollTop: 999999, // 设置一个超大值，以保证滚动条滚动到底部\r\n            duration: 0\r\n          });\r\n        })\r\n        this.sendToSpark();\r\n        \r\n      },\r\n      async sendToSpark() {\r\n        // let myUrl = await this.getWebSocketUrl();\r\n        this.tempRes = \"\";\r\n        let realThis = this;\r\n        this.socketTask = uni.connectSocket({\r\n          //url: encodeURI(encodeURI(myUrl).replace(/\\+/g, '%2B')),\r\n          url: 'wss://chat.lihaink.cn/chat',\r\n          method: 'GET',\r\n          success: res => {\r\n            console.log(res, \"ws成功连接...\")\r\n            realThis.wsLiveFlag = true;\r\n          }\r\n        })\r\n        realThis.socketTask.onError((res) => {\r\n          console.log(\"连接发生错误，请检查appid是否填写\", res)\r\n        })\r\n        realThis.socketTask.onOpen((res) => {\r\n          this.historyTextList.push({\r\n            \"role\": \"user\",\r\n            \"content\": this.TEXT\r\n          })\r\n          // 第一帧..........................................\r\n          console.log('连接成功...')\r\n          // let params = {\r\n          //   \"header\": {\r\n          //     \"app_id\": this.APPID,\r\n          //     \"uid\": \"aef9f963-7\"\r\n          //   },\r\n          //   \"parameter\": {\r\n          //     \"chat\": {\r\n          //       \"domain\": \"generalv2\",\r\n          //       \"temperature\": 0.5,\r\n          //       \"max_tokens\": 1024\r\n          //     }\r\n          //   },\r\n          //   \"payload\": {\r\n          //     \"message\": {\r\n          //       \"text\": this.historyTextList\r\n          //     }\r\n          //   }\r\n          // };\r\n          let params = this.TEXT\r\n          realThis.socketTask.send({ // 发送消息，，都用uni的官方版本\r\n            data: JSON.stringify(params),\r\n            success() {\r\n              console.log('第一帧发送成功')\r\n            }\r\n          });\r\n        });\r\n\r\n        // 接受到消息时\r\n        realThis.socketTask.onMessage((res) => {\r\n          console.log('收到API返回的内容：', res.data);\r\n          let obj = JSON.parse(res.data)\r\n          // console.log(\"我打印的\"+obj.payload);\r\n          let dataArray = obj.payload.choices.text;\r\n          for (let i = 0; i < dataArray.length; i++) {\r\n            this.talkList[this.talkList.length - 1].content += dataArray[i].content;\r\n            this.n_content = this.talkList[this.talkList.length - 1].content;\r\n            realThis.tempRes = realThis.tempRes + dataArray[i].content\r\n          }\r\n          let temp = JSON.parse(res.data)\r\n          // console.log(\"0726\",temp.header.code)\r\n          if (temp.header.code !== 0) {\r\n            console.log(`${temp.header.code}:${temp.message}`);\r\n            realThis.socketTask.close({\r\n              success(res) {\r\n                console.log('关闭成功', res)\r\n                realThis.wsLiveFlag = false;\r\n              },\r\n              fail(err) {\r\n                console.log('关闭失败', err)\r\n              }\r\n            })\r\n          }\r\n          if (temp.header.code === 0) {\r\n            if (res.data && temp.header.status === 2) {\r\n              this.historyTextList.push({\r\n                \"role\": \"assistant\",\r\n                \"content\": this.tempRes\r\n              })\r\n              setTimeout(() => {\r\n                realThis.socketTask.close({\r\n                  success(res) {\r\n                    console.log('关闭成功', res)\r\n                  },\r\n                  fail(err) {\r\n                    // console.log('关闭失败', err)\r\n                  }\r\n                })\r\n              }, 1000)\r\n            }\r\n          }\r\n        })\r\n      },\r\n      // 鉴权\r\n      getWebSocketUrl() {\r\n        return new Promise((resolve, reject) => {\r\n          // https://spark-api.xf-yun.com/v1.1/chat  V1.5 domain general\r\n          // https://spark-api.xf-yun.com/v2.1/chat  V2.0 domain generalv2\r\n          var url = \"wss://spark-api.xf-yun.com/v2.1/chat\";\r\n          var host = \"spark-api.xf-yun.com\";\r\n          var apiKeyName = \"api_key\";\r\n          var date = new Date().toGMTString();\r\n          var algorithm = \"hmac-sha256\";\r\n          var headers = \"host date request-line\";\r\n          var signatureOrigin = `host: ${host}\\ndate: ${date}\\nGET /v2.1/chat HTTP/1.1`;\r\n          var signatureSha = CryptoJS.HmacSHA256(signatureOrigin, this.APISecret);\r\n          var signature = CryptoJS.enc.Base64.stringify(signatureSha);\r\n          var authorizationOrigin =\r\n            `${apiKeyName}=\"${this.APIKey}\", algorithm=\"${algorithm}\", headers=\"${headers}\", signature=\"${signature}\"`;\r\n          var authorization = base64.encode(authorizationOrigin);\r\n          url = `${url}?authorization=${authorization}&date=${encodeURI(date)}&host=${host}`;\r\n\r\n          // console.log(url)\r\n          resolve(url);\r\n        });\r\n      },\r\n      // 滚动到头部\r\n      bindScroll() {\r\n      \tif (this.userId == 0) {\r\n      \t\tthis.getHistory();\r\n      \t\tthis.getproductInfo();\r\n      \t\tthis.getOrderInfo();\r\n      \t\tthis.getRefundDetail();\r\n      \t\tthis.getStoreDetail();\r\n      \t} else {\r\n      \t\tthis.getMerHistory();\r\n      \t}\r\n      },\r\n    }\r\n  }\r\n</script>\r\n\r\n<style lang=\"scss\">\r\n  @import \"../../lib/global.scss\";\r\n\r\n  page {\r\n    background-color: #f5f5f5;\r\n    font-size: 28rpx;\r\n  }\r\n  \r\n  @keyframes blink {\r\n    0% { opacity: 1; }\r\n    50% { opacity: 0; }\r\n    100% { opacity: 1; }\r\n  }\r\n  \r\n  .blinking-box {\r\n    background-color: #333;\r\n    color: #333;\r\n    animation: blink 1s infinite;\r\n    width: 2px;\r\n    overflow: hidden;\r\n  }\r\n\r\n  .wrapper {\r\n    height: auto !important;\r\n  }\r\n\r\n  /* 加载数据提示 */\r\n  .tips {\r\n    position: fixed;\r\n    left: 0;\r\n    top: var(--window-top);\r\n    width: 100%;\r\n    z-index: 9;\r\n    background-color: rgba(0, 0, 0, 0.15);\r\n    height: 72rpx;\r\n    line-height: 72rpx;\r\n    transform: translateY(-80rpx);\r\n    transition: transform 0.3s ease-in-out 0s;\r\n\r\n    &.show {\r\n      transform: translateY(0);\r\n    }\r\n  }\r\n\r\n  .box-1 {\r\n    width: 100%;\r\n    height: auto;\r\n    padding-bottom: 100rpx;\r\n    box-sizing: content-box;\r\n\r\n    /* 兼容iPhoneX */\r\n    margin-bottom: 0;\r\n    margin-bottom: constant(safe-area-inset-bottom);\r\n    margin-bottom: env(safe-area-inset-bottom);\r\n  }\r\n\r\n  .multiline-text {\r\n    white-space: pre-line;\r\n    /* 或 white-space: pre-wrap; */\r\n  }\r\n\r\n  .box-2 {\r\n    position: fixed;\r\n    left: 0;\r\n    width: 100%;\r\n    bottom: 0;\r\n    height: auto;\r\n    z-index: 2;\r\n    border-top: #e5e5e5 solid 1px;\r\n    box-sizing: content-box;\r\n    background-color: #f5f5f5;\r\n    transform: translateY(0); /* 初始化 transform 属性 */\r\n    transition: transform 0.3s ease; /* 添加过渡效果 */\r\n\r\n    /* 兼容iPhoneX */\r\n    padding-bottom: 0;\r\n    padding-bottom: constant(safe-area-inset-bottom);\r\n    padding-bottom: env(safe-area-inset-bottom);\r\n\r\n    >view {\r\n      padding: 0 20rpx;\r\n      height: 100rpx;\r\n    }\r\n\r\n    .content {\r\n      background-color: #fff;\r\n      height: 64rpx;\r\n      padding: 0 20rpx;\r\n      border-radius: 6rpx;\r\n      font-size: 28rpx;\r\n    }\r\n\r\n    .send {\r\n      background-color: #2573fb;\r\n      color: #fff;\r\n      height: 64rpx;\r\n      margin-left: 20rpx;\r\n      border-radius: 6rpx;\r\n      padding: 0;\r\n      width: 120rpx;\r\n      line-height: 62rpx;\r\n\r\n      &:active {\r\n        background-color: #1573fb;\r\n      }\r\n    }\r\n  }\r\n\r\n  .talk-list {\r\n    padding-bottom: 20rpx;\r\n\r\n    /* 消息项，基础类 */\r\n    .item {\r\n      padding: 20rpx 20rpx 0 20rpx;\r\n      align-items: flex-start;\r\n      align-content: flex-start;\r\n      color: #333;\r\n\r\n      .pic {\r\n        width: 92rpx;\r\n        height: 92rpx;\r\n        border-radius: 50%;\r\n        border: #fff solid 1px;\r\n      }\r\n\r\n      .content {\r\n        padding: 20rpx;\r\n        border-radius: 4px;\r\n        max-width: 500rpx;\r\n        word-break: break-all;\r\n        line-height: 52rpx;\r\n        position: relative;\r\n      }\r\n\r\n      /* 收到的消息 */\r\n      &.pull {\r\n        .content {\r\n          min-width: 20rpx;\r\n          min-height: 52rpx;\r\n          margin-left: 32rpx;\r\n          background-color: #fff;\r\n\r\n          &::after {\r\n            content: '';\r\n            display: block;\r\n            width: 0;\r\n            height: 0;\r\n            border-top: 16rpx solid transparent;\r\n            border-bottom: 16rpx solid transparent;\r\n            border-right: 20rpx solid #fff;\r\n            position: absolute;\r\n            top: 30rpx;\r\n            left: -18rpx;\r\n          }\r\n        }\r\n      }\r\n\r\n      /* 发出的消息 */\r\n      &.push {\r\n        /* 主轴为水平方向，起点在右端。使不修改DOM结构，也能改变元素排列顺序 */\r\n        flex-direction: row-reverse;\r\n\r\n        .content {\r\n          min-width: 20rpx;\r\n          min-height: 52rpx;\r\n          margin-right: 32rpx;\r\n          background-color: #2573fb;\r\n          color: #fff;\r\n\r\n          &::after {\r\n            content: '';\r\n            display: block;\r\n            width: 0;\r\n            height: 0;\r\n            border-top: 16rpx solid transparent;\r\n            border-bottom: 16rpx solid transparent;\r\n            border-left: 20rpx solid #2573fb;\r\n            position: absolute;\r\n            top: 30rpx;\r\n            right: -18rpx;\r\n          }\r\n        }\r\n      }\r\n    }\r\n  }\r\n\r\n  .bing-math {\r\n    margin: 0 !important;\r\n    padding: 0 !important;\r\n  }\r\n  .placeholder {\r\n    width: 100vw;\r\n    background-color: #1573fb;\r\n    // background-color: transparent;\r\n    // transform: translateY(0); /* 初始化 transform 属性 */\r\n    // transition: transform 0.3s ease; /* 添加过渡效果 */\r\n  }\r\n</style>"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///17\n"); /***/ }), /* 18 */ @@ -30310,7 +30339,7 @@ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _HBu /***/ (function(module, exports, __webpack_require__) { "use strict"; -eval("/* WEBPACK VAR INJECTION */(function(__f__) {\n\nvar _interopRequireDefault = __webpack_require__(/*! @babel/runtime/helpers/interopRequireDefault */ 1);\nvar _typeof = __webpack_require__(/*! @babel/runtime/helpers/typeof */ 4);\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\nvar _regenerator = _interopRequireDefault(__webpack_require__(/*! @babel/runtime/regenerator */ 19));\nvar _asyncToGenerator2 = _interopRequireDefault(__webpack_require__(/*! @babel/runtime/helpers/asyncToGenerator */ 27));\nvar base64 = _interopRequireWildcard(__webpack_require__(/*! base-64 */ 28));\nvar _cryptoJs = _interopRequireDefault(__webpack_require__(/*! ../../static/crypto-js/crypto-js.js */ 32));\nvar _parser = _interopRequireDefault(__webpack_require__(/*! ../../static/fast-xml-parser/src/parser */ 190));\nvar utf8 = _interopRequireWildcard(__webpack_require__(/*! utf8 */ 199));\nfunction _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== \"function\") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }\nfunction _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== \"object\" && typeof obj !== \"function\") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== \"default\" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }\n//\n//\n//\n//\n//\n//\n//\n//\nvar _default = {\n // https://spark-api.xf-yun.com/v1.1/chat V1.5 domain general\n // https://spark-api.xf-yun.com/v2.1/chat V2.0 domain generalv2\n data: function data() {\n return {\n TEXT: '你好,我的名字叫大王',\n APPID: '2eda6c2e',\n // 控制台获取填写\n APISecret: 'MDEyMzE5YTc5YmQ5NjMwOTU1MWY4N2Y2',\n APIKey: '12ec1f9d113932575fc4b114a2f60ffd',\n sparkResult: '',\n historyTextList: [],\n // 历史会话信息,由于最大token12000,可以结合实际使用,进行移出\n tempRes: '' // 临时答复保存\n };\n },\n\n methods: {\n sendToSpark: function sendToSpark() {\n var _this = this;\n return (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee() {\n var myUrl, realThis;\n return _regenerator.default.wrap(function _callee$(_context) {\n while (1) {\n switch (_context.prev = _context.next) {\n case 0:\n _context.next = 2;\n return _this.getWebSocketUrl();\n case 2:\n myUrl = _context.sent;\n _this.tempRes = \"\";\n // this.sparkResult = \"\";\n realThis = _this;\n _this.socketTask = uni.connectSocket({\n //url: encodeURI(encodeURI(myUrl).replace(/\\+/g, '%2B')),\n url: myUrl,\n method: 'GET',\n success: function success(res) {\n __f__(\"log\", res, \"ws成功连接...\", myUrl, \" at pages/index/chat.vue:39\");\n realThis.wsLiveFlag = true;\n }\n });\n realThis.socketTask.onError(function (res) {\n __f__(\"log\", \"连接发生错误,请检查appid是否填写\", res, \" at pages/index/chat.vue:44\");\n });\n realThis.socketTask.onOpen(function (res) {\n _this.historyTextList.push({\n \"role\": \"user\",\n \"content\": _this.TEXT\n });\n __f__(\"info\", \"wss的onOpen成功执行...\", res, \" at pages/index/chat.vue:51\");\n // 第一帧..........................................\n __f__(\"log\", 'open成功...', \" at pages/index/chat.vue:53\");\n var params = {\n \"header\": {\n \"app_id\": _this.APPID,\n \"uid\": \"aef9f963-7\"\n },\n \"parameter\": {\n \"chat\": {\n \"domain\": \"generalv2\",\n \"temperature\": 0.5,\n \"max_tokens\": 1024\n }\n },\n \"payload\": {\n \"message\": {\n \"text\": _this.historyTextList\n }\n }\n };\n __f__(\"log\", \"请求的params:\" + JSON.stringify(params), \" at pages/index/chat.vue:72\");\n _this.sparkResult = _this.sparkResult + \"\\r\\n我:\" + _this.TEXT + \"\\r\\n\";\n _this.sparkResult = _this.sparkResult + \"大模型:\";\n __f__(\"log\", \"发送第一帧...\", params, \" at pages/index/chat.vue:75\");\n realThis.socketTask.send({\n // 发送消息,,都用uni的官方版本\n data: JSON.stringify(params),\n success: function success() {\n __f__(\"log\", '第一帧发送成功', \" at pages/index/chat.vue:79\");\n }\n });\n });\n\n // 接受到消息时\n realThis.socketTask.onMessage(function (res) {\n __f__(\"log\", '收到API返回的内容:', res.data, \" at pages/index/chat.vue:86\");\n var obj = JSON.parse(res.data);\n // console.log(\"我打印的\"+obj.payload);\n var dataArray = obj.payload.choices.text;\n for (var i = 0; i < dataArray.length; i++) {\n realThis.sparkResult = realThis.sparkResult + dataArray[i].content;\n realThis.tempRes = realThis.tempRes + dataArray[i].content;\n }\n // realThis.sparkResult =realThis.sparkResult+ \n var temp = JSON.parse(res.data);\n // console.log(\"0726\",temp.header.code)\n if (temp.header.code !== 0) {\n __f__(\"log\", \"\".concat(temp.header.code, \":\").concat(temp.message), \" at pages/index/chat.vue:98\");\n realThis.socketTask.close({\n success: function success(res) {\n __f__(\"log\", '关闭成功', res, \" at pages/index/chat.vue:101\");\n realThis.wsLiveFlag = false;\n },\n fail: function fail(err) {\n __f__(\"log\", '关闭失败', err, \" at pages/index/chat.vue:105\");\n }\n });\n }\n if (temp.header.code === 0) {\n if (res.data && temp.header.status === 2) {\n realThis.sparkResult = realThis.sparkResult + \"\\r\\n**********************************************\";\n _this.historyTextList.push({\n \"role\": \"assistant\",\n \"content\": _this.tempRes\n });\n /* let dataArray= obj.payload.choices.text;\n for(let i=0;i uni-view {\r\n width: 50%;\n}\n.flex_col.flex_col_3 > uni-view {\r\n width: 33.33333%;\n}\n.flex_col.flex_col_4 > uni-view {\r\n width: 25%;\n}\n.flex_col.flex_col_5 > uni-view {\r\n width: 20%;\n}\n.flex_col.flex_col_6 > uni-view {\r\n width: 16.66666%;\n}\r\n/* 字体颜色 */\n.color_333 {\r\n color: #333;\n}\n.color_666 {\r\n color: #666;\n}\n.color_999 {\r\n color: #999;\n}\n.color_ccc {\r\n color: #ccc;\n}\n.color_fff {\r\n color: #fff;\n}\n.color_6dc {\r\n color: #6dca6d;\n}\n.color_d51 {\r\n color: #d51917;\n}\n.color_09f {\r\n color: #0099ff;\n}\r\n/* 背景色*/\n.bg_fff {\r\n background-color: #ffffff;\n}\r\n/* 字体大小 */\n.size_10 {\r\n font-size: 20rpx;\n}\n.size_12 {\r\n font-size: 24rpx;\n}\n.size_14 {\r\n font-size: 28rpx;\n}\n.size_16 {\r\n font-size: 32rpx;\n}\n.size_18 {\r\n font-size: 36rpx;\n}\n.size_20 {\r\n font-size: 40rpx;\n}\r\n/* 字体加粗 */\n.font_b {\r\n font-weight: bold;\n}\r\n/* 对齐方式 */\n.align_c {\r\n text-align: center;\n}\n.align_l {\r\n text-align: left;\n}\n.align_r {\r\n text-align: right;\n}\r\n/* 遮罩 */\n.shade {\r\n position: fixed;\r\n top: 0;\r\n right: 0;\r\n bottom: 0;\r\n left: 0;\r\n background-color: rgba(0, 0, 0, 0.8);\r\n z-index: 100;\n}\r\n/* 弹窗 */\n.shade_box {\r\n position: fixed;\r\n top: 0;\r\n right: 0;\r\n bottom: 0;\r\n left: 0;\r\n margin: auto;\r\n z-index: 101;\r\n min-width: 200rpx;\r\n min-height: 200rpx;\n}\nbody {\r\n background-color: #f5f5f5;\r\n font-size: 28rpx;\n}\n.wrapper {\r\n height: auto !important;\n}\r\n/* 加载数据提示 */\n.tips {\r\n position: fixed;\r\n left: 0;\r\n top: var(--window-top);\r\n width: 100%;\r\n z-index: 9;\r\n background-color: rgba(0, 0, 0, 0.15);\r\n height: 72rpx;\r\n line-height: 72rpx;\r\n -webkit-transform: translateY(-80rpx);\r\n transform: translateY(-80rpx);\r\n transition: -webkit-transform 0.3s ease-in-out 0s;\r\n transition: transform 0.3s ease-in-out 0s;\r\n transition: transform 0.3s ease-in-out 0s, -webkit-transform 0.3s ease-in-out 0s;\n}\n.tips.show {\r\n -webkit-transform: translateY(0);\r\n transform: translateY(0);\n}\n.box-1 {\r\n width: 100%;\r\n height: auto;\r\n padding-bottom: 100rpx;\r\n box-sizing: content-box;\r\n /* 兼容iPhoneX */\r\n margin-bottom: 0;\r\n margin-bottom: constant(safe-area-inset-bottom);\r\n margin-bottom: env(safe-area-inset-bottom);\n}\n.multiline-text {\r\n white-space: pre-line;\r\n /* 或 white-space: pre-wrap; */\n}\n.box-2 {\r\n position: fixed;\r\n left: 0;\r\n width: 100%;\r\n bottom: 0;\r\n height: auto;\r\n z-index: 2;\r\n border-top: #e5e5e5 solid 1px;\r\n box-sizing: content-box;\r\n background-color: #f5f5f5;\r\n -webkit-transform: translateY(0);\r\n transform: translateY(0);\r\n /* 初始化 transform 属性 */\r\n transition: -webkit-transform 0.3s ease;\r\n transition: transform 0.3s ease;\r\n transition: transform 0.3s ease, -webkit-transform 0.3s ease;\r\n /* 添加过渡效果 */\r\n /* 兼容iPhoneX */\r\n padding-bottom: 0;\r\n padding-bottom: constant(safe-area-inset-bottom);\r\n padding-bottom: env(safe-area-inset-bottom);\n}\n.box-2 > uni-view {\r\n padding: 0 20rpx;\r\n height: 100rpx;\n}\n.box-2 .content {\r\n background-color: #fff;\r\n height: 64rpx;\r\n padding: 0 20rpx;\r\n border-radius: 6rpx;\r\n font-size: 28rpx;\n}\n.box-2 .send {\r\n background-color: #2573fb;\r\n color: #fff;\r\n height: 64rpx;\r\n margin-left: 20rpx;\r\n border-radius: 6rpx;\r\n padding: 0;\r\n width: 120rpx;\r\n line-height: 62rpx;\n}\n.box-2 .send:active {\r\n background-color: #1573fb;\n}\n.talk-list {\r\n padding-bottom: 20rpx;\r\n /* 消息项,基础类 */\n}\n.talk-list .item {\r\n padding: 20rpx 20rpx 0 20rpx;\r\n align-items: flex-start;\r\n align-content: flex-start;\r\n color: #333;\r\n /* 收到的消息 */\r\n /* 发出的消息 */\n}\n.talk-list .item .pic {\r\n width: 92rpx;\r\n height: 92rpx;\r\n border-radius: 50%;\r\n border: #fff solid 1px;\n}\n.talk-list .item .content {\r\n padding: 20rpx;\r\n border-radius: 4px;\r\n max-width: 500rpx;\r\n word-break: break-all;\r\n line-height: 52rpx;\r\n position: relative;\n}\n.talk-list .item.pull .content {\r\n min-width: 20rpx;\r\n min-height: 52rpx;\r\n margin-left: 32rpx;\r\n background-color: #fff;\n}\n.talk-list .item.pull .content::after {\r\n content: '';\r\n display: block;\r\n width: 0;\r\n height: 0;\r\n border-top: 16rpx solid transparent;\r\n border-bottom: 16rpx solid transparent;\r\n border-right: 20rpx solid #fff;\r\n position: absolute;\r\n top: 30rpx;\r\n left: -18rpx;\n}\n.talk-list .item.push {\r\n /* 主轴为水平方向,起点在右端。使不修改DOM结构,也能改变元素排列顺序 */\r\n flex-direction: row-reverse;\n}\n.talk-list .item.push .content {\r\n min-width: 20rpx;\r\n min-height: 52rpx;\r\n margin-right: 32rpx;\r\n background-color: #2573fb;\r\n color: #fff;\n}\n.talk-list .item.push .content::after {\r\n content: '';\r\n display: block;\r\n width: 0;\r\n height: 0;\r\n border-top: 16rpx solid transparent;\r\n border-bottom: 16rpx solid transparent;\r\n border-left: 20rpx solid #2573fb;\r\n position: absolute;\r\n top: 30rpx;\r\n right: -18rpx;\n}\n.bing-math {\r\n margin: 0 !important;\r\n padding: 0 !important;\n}\n.placeholder {\r\n width: 100vw;\r\n background-color: #1573fb;\n}\r\n", ""]); +exports.push([module.i, "@charset \"UTF-8\";\r\n/**\r\n * 这里是uni-app内置的常用样式变量\r\n *\r\n * uni-app 官方扩展插件及插件市场(https://ext.dcloud.net.cn)上很多三方插件均使用了这些样式变量\r\n * 如果你是插件开发者,建议你使用scss预处理,并在插件代码中直接使用这些变量(无需 import 这个文件),方便用户通过搭积木的方式开发整体风格一致的App\r\n *\r\n */\r\n/**\r\n * 如果你是App开发者(插件使用者),你可以通过修改这些变量来定制自己的插件主题,实现自定义主题功能\r\n *\r\n * 如果你的项目同样使用了scss预处理,你也可以直接在你的 scss 代码中使用如下变量,同时无需 import 这个文件\r\n */\r\n/* 颜色变量 */\r\n/* 行为相关颜色 */\r\n/* 文字基本颜色 */\r\n/* 背景颜色 */\r\n/* 边框颜色 */\r\n/* 尺寸变量 */\r\n/* 文字尺寸 */\r\n/* 图片尺寸 */\r\n/* Border Radius */\r\n/* 水平间距 */\r\n/* 垂直间距 */\r\n/* 透明度 */\r\n/* 文章场景相关 */\r\n/* 根元素样式 设置页面背景、字体大小、字体颜色,字符间距、长单词换行 */\nbody {\r\n background-color: #f3f3f3;\r\n font-size: 28rpx;\r\n box-sizing: border-box;\r\n color: #333;\r\n letter-spacing: 0;\r\n word-wrap: break-word;\n}\r\n/* 设置常用元素尺寸规则 */\nuni-view, uni-textarea, uni-input, uni-label, uni-form, uni-button, uni-image {\r\n box-sizing: border-box;\n}\r\n/* 按钮样式处理 */\nuni-button {\r\n font-size: 28rpx;\n}\r\n/* 取消按钮默认的边框线效果 */\nuni-button:after {\r\n border: none;\n}\r\n/* 设置图片默认样式,取消默认尺寸 */\nuni-image {\r\n display: block;\r\n height: auto;\r\n width: auto;\n}\r\n/* 输入框默认字体大小 */\nuni-textarea, uni-input {\r\n font-size: 28rpx;\n}\r\n/* 列式弹性盒子 */\n.flex_col {\r\n display: flex;\r\n flex-direction: row;\r\n flex-wrap: nowrap;\r\n justify-content: flex-start;\r\n align-items: center;\r\n align-content: center;\n}\r\n/* 行式弹性盒子 */\n.flex_row {\r\n display: flex;\r\n flex-direction: column;\r\n flex-wrap: nowrap;\r\n justify-content: flex-start;\r\n align-items: flex-start;\r\n align-content: flex-start;\n}\r\n/* 弹性盒子弹性容器 */\n.flex_col .flex_grow {\r\n width: 0;\r\n flex-grow: 1;\n}\n.flex_row .flex_grow {\r\n flex-grow: 1;\n}\r\n/* 弹性盒子允许换行 */\n.flex_col.flex_wrap {\r\n flex-wrap: wrap;\n}\r\n/* 弹性盒子居中对齐 */\n.flex_col.flex_center, .flex_row.flex_center {\r\n justify-content: center;\n}\r\n/* 列式弹性盒子两端对齐 */\n.flex_col.flex_space {\r\n justify-content: space-between;\n}\r\n/* 弹性盒子快速分栏 ,这里非常郁闷 uniapp 居然不支持 * 选择器 */\n.flex_col.flex_col_2 > uni-view {\r\n width: 50%;\n}\n.flex_col.flex_col_3 > uni-view {\r\n width: 33.33333%;\n}\n.flex_col.flex_col_4 > uni-view {\r\n width: 25%;\n}\n.flex_col.flex_col_5 > uni-view {\r\n width: 20%;\n}\n.flex_col.flex_col_6 > uni-view {\r\n width: 16.66666%;\n}\r\n/* 字体颜色 */\n.color_333 {\r\n color: #333;\n}\n.color_666 {\r\n color: #666;\n}\n.color_999 {\r\n color: #999;\n}\n.color_ccc {\r\n color: #ccc;\n}\n.color_fff {\r\n color: #fff;\n}\n.color_6dc {\r\n color: #6dca6d;\n}\n.color_d51 {\r\n color: #d51917;\n}\n.color_09f {\r\n color: #0099ff;\n}\r\n/* 背景色*/\n.bg_fff {\r\n background-color: #ffffff;\n}\r\n/* 字体大小 */\n.size_10 {\r\n font-size: 20rpx;\n}\n.size_12 {\r\n font-size: 24rpx;\n}\n.size_14 {\r\n font-size: 28rpx;\n}\n.size_16 {\r\n font-size: 32rpx;\n}\n.size_18 {\r\n font-size: 36rpx;\n}\n.size_20 {\r\n font-size: 40rpx;\n}\r\n/* 字体加粗 */\n.font_b {\r\n font-weight: bold;\n}\r\n/* 对齐方式 */\n.align_c {\r\n text-align: center;\n}\n.align_l {\r\n text-align: left;\n}\n.align_r {\r\n text-align: right;\n}\r\n/* 遮罩 */\n.shade {\r\n position: fixed;\r\n top: 0;\r\n right: 0;\r\n bottom: 0;\r\n left: 0;\r\n background-color: rgba(0, 0, 0, 0.8);\r\n z-index: 100;\n}\r\n/* 弹窗 */\n.shade_box {\r\n position: fixed;\r\n top: 0;\r\n right: 0;\r\n bottom: 0;\r\n left: 0;\r\n margin: auto;\r\n z-index: 101;\r\n min-width: 200rpx;\r\n min-height: 200rpx;\n}\nbody {\r\n background-color: #f5f5f5;\r\n font-size: 28rpx;\n}\n@-webkit-keyframes blink {\n0% {\r\n opacity: 1;\n}\n50% {\r\n opacity: 0;\n}\n100% {\r\n opacity: 1;\n}\n}\n@keyframes blink {\n0% {\r\n opacity: 1;\n}\n50% {\r\n opacity: 0;\n}\n100% {\r\n opacity: 1;\n}\n}\n.blinking-box {\r\n background-color: #333;\r\n color: #333;\r\n -webkit-animation: blink 1s infinite;\r\n animation: blink 1s infinite;\r\n width: 2px;\r\n overflow: hidden;\n}\n.wrapper {\r\n height: auto !important;\n}\r\n/* 加载数据提示 */\n.tips {\r\n position: fixed;\r\n left: 0;\r\n top: var(--window-top);\r\n width: 100%;\r\n z-index: 9;\r\n background-color: rgba(0, 0, 0, 0.15);\r\n height: 72rpx;\r\n line-height: 72rpx;\r\n -webkit-transform: translateY(-80rpx);\r\n transform: translateY(-80rpx);\r\n transition: -webkit-transform 0.3s ease-in-out 0s;\r\n transition: transform 0.3s ease-in-out 0s;\r\n transition: transform 0.3s ease-in-out 0s, -webkit-transform 0.3s ease-in-out 0s;\n}\n.tips.show {\r\n -webkit-transform: translateY(0);\r\n transform: translateY(0);\n}\n.box-1 {\r\n width: 100%;\r\n height: auto;\r\n padding-bottom: 100rpx;\r\n box-sizing: content-box;\r\n /* 兼容iPhoneX */\r\n margin-bottom: 0;\r\n margin-bottom: constant(safe-area-inset-bottom);\r\n margin-bottom: env(safe-area-inset-bottom);\n}\n.multiline-text {\r\n white-space: pre-line;\r\n /* 或 white-space: pre-wrap; */\n}\n.box-2 {\r\n position: fixed;\r\n left: 0;\r\n width: 100%;\r\n bottom: 0;\r\n height: auto;\r\n z-index: 2;\r\n border-top: #e5e5e5 solid 1px;\r\n box-sizing: content-box;\r\n background-color: #f5f5f5;\r\n -webkit-transform: translateY(0);\r\n transform: translateY(0);\r\n /* 初始化 transform 属性 */\r\n transition: -webkit-transform 0.3s ease;\r\n transition: transform 0.3s ease;\r\n transition: transform 0.3s ease, -webkit-transform 0.3s ease;\r\n /* 添加过渡效果 */\r\n /* 兼容iPhoneX */\r\n padding-bottom: 0;\r\n padding-bottom: constant(safe-area-inset-bottom);\r\n padding-bottom: env(safe-area-inset-bottom);\n}\n.box-2 > uni-view {\r\n padding: 0 20rpx;\r\n height: 100rpx;\n}\n.box-2 .content {\r\n background-color: #fff;\r\n height: 64rpx;\r\n padding: 0 20rpx;\r\n border-radius: 6rpx;\r\n font-size: 28rpx;\n}\n.box-2 .send {\r\n background-color: #2573fb;\r\n color: #fff;\r\n height: 64rpx;\r\n margin-left: 20rpx;\r\n border-radius: 6rpx;\r\n padding: 0;\r\n width: 120rpx;\r\n line-height: 62rpx;\n}\n.box-2 .send:active {\r\n background-color: #1573fb;\n}\n.talk-list {\r\n padding-bottom: 20rpx;\r\n /* 消息项,基础类 */\n}\n.talk-list .item {\r\n padding: 20rpx 20rpx 0 20rpx;\r\n align-items: flex-start;\r\n align-content: flex-start;\r\n color: #333;\r\n /* 收到的消息 */\r\n /* 发出的消息 */\n}\n.talk-list .item .pic {\r\n width: 92rpx;\r\n height: 92rpx;\r\n border-radius: 50%;\r\n border: #fff solid 1px;\n}\n.talk-list .item .content {\r\n padding: 20rpx;\r\n border-radius: 4px;\r\n max-width: 500rpx;\r\n word-break: break-all;\r\n line-height: 52rpx;\r\n position: relative;\n}\n.talk-list .item.pull .content {\r\n min-width: 20rpx;\r\n min-height: 52rpx;\r\n margin-left: 32rpx;\r\n background-color: #fff;\n}\n.talk-list .item.pull .content::after {\r\n content: '';\r\n display: block;\r\n width: 0;\r\n height: 0;\r\n border-top: 16rpx solid transparent;\r\n border-bottom: 16rpx solid transparent;\r\n border-right: 20rpx solid #fff;\r\n position: absolute;\r\n top: 30rpx;\r\n left: -18rpx;\n}\n.talk-list .item.push {\r\n /* 主轴为水平方向,起点在右端。使不修改DOM结构,也能改变元素排列顺序 */\r\n flex-direction: row-reverse;\n}\n.talk-list .item.push .content {\r\n min-width: 20rpx;\r\n min-height: 52rpx;\r\n margin-right: 32rpx;\r\n background-color: #2573fb;\r\n color: #fff;\n}\n.talk-list .item.push .content::after {\r\n content: '';\r\n display: block;\r\n width: 0;\r\n height: 0;\r\n border-top: 16rpx solid transparent;\r\n border-bottom: 16rpx solid transparent;\r\n border-left: 20rpx solid #2573fb;\r\n position: absolute;\r\n top: 30rpx;\r\n right: -18rpx;\n}\n.bing-math {\r\n margin: 0 !important;\r\n padding: 0 !important;\n}\n.placeholder {\r\n width: 100vw;\r\n background-color: #1573fb;\n}\r\n", ""]); // Exports module.exports = exports;