diff --git a/manifest.json b/manifest.json index 04a8cdf..b732c14 100644 --- a/manifest.json +++ b/manifest.json @@ -1,6 +1,6 @@ { - "name" : "农业咨询", - "appid" : "__UNI__9620511", + "name" : "教育咨询", + "appid" : "__UNI__7AA205C", "description" : "", "versionName" : "1.0.0", "versionCode" : "100", diff --git a/pages.json b/pages.json index 60164b0..cc8240c 100644 --- a/pages.json +++ b/pages.json @@ -3,7 +3,7 @@ { "path": "pages/index/index", "style": { - "navigationBarTitleText": "农业咨询", + "navigationBarTitleText": "教育咨询", "bounce": "none" // "softinputMode": "adjustResize" } diff --git a/pages/index/index.vue b/pages/index/index.vue index e83ea64..5d8f5be 100644 --- a/pages/index/index.vue +++ b/pages/index/index.vue @@ -52,8 +52,8 @@ }, data() { return { - wssType: 'nongye', // 网络连接类型 - avatarType: "/static/icon/ny.png", // AI头像类型 + wssType: 'jiaoyu', // 网络连接类型 + avatarType: "/static/icon/jy.png", // AI头像类型 talkList: [], ajax: { rows: 15, //每页数量 diff --git a/test.js b/test.js deleted file mode 100644 index fd1413f..0000000 --- a/test.js +++ /dev/null @@ -1,141 +0,0 @@ - $.ajax({ -                url: host, -                data: data, -                type: "POST", -                dataType: "json", -                headers: headers, -                complete: () => { -                    let message = ai.lastMessage(chat); -                    if (!chat.loading || message.id !== lastId) { -                        return; -                    } -                    chat.lastChunkIndex = 0; -                    chat.loading = false; -                    lastMessage.completed = true; -                    ai.saveData(); -                }, -                success: function (res) { -                    let message = ai.lastMessage(chat); -                    if (!chat.loading || message.id !== lastId) { -                        return; -                    } -                    if (res && res.error && res.error.message) { -                        ai.lastMessage(chat).choices[0].delta.content = res.error.message; -                    } else if (res && res.data && res.data[0] && res.data[0].url) { -                        ai.lastMessage(chat).choices[0].delta.content = `![](${res.data[0].url})`; -                    } else { -                        console.log(res); -                    } -                }, -                xhr: this.xhrOnProgress(function (event) { -                    let message = ai.lastMessage(chat); -                    // 已经取消 -                    if (!chat.loading || message.id !== lastId) { -                        return; -                    } -                    const xhr = event.target; -                    const {responseText} = xhr; -                    let thunks = responseText.substring(chat.lastChunkIndex); -                    chat.lastChunkIndex = responseText.length; -                    const arr = thunks.split("\n"); -                    arr.forEach(function (chunk) { -                        if (chunk === "") return; -                        chunk = chunk.substring(6).trim(); -                        if (chunk === "" || chunk === "[DONE]") return; -                        tr - - - - - - -// uni.request({ - // url: 'https://ceshi-worker-task.lihaink.cn/api/xun_fei/chat?content=uniapp中js的回调有哪些', - // method: 'GET', - // responseType: 'arraybuffer', - // success: res => { - // console.log(res); - // }, - // fail: err => { - // // 处理请求失败 - // console.error(err); - // } - // }); - - // let that = this; - // this.talkList.push({ - // "id":new Date().getTime(), - // "content":'', - // "type":2, - // "pic":"/static/avatar.png" - // }); - // var xhr = new XMLHttpRequest(); - // xhr.open('GET', 'https://ceshi-worker-task.lihaink.cn/api/xun_fei/chat?content=uniapp中js的回调有哪些', true); // 设置请求方法、URL 和是否异步 - - // xhr.setRequestHeader('Content-Type', 'application/json'); // 设置请求头 - - // xhr.onreadystatechange = function() { - // console.log('请求成功:', xhr.responseText); - // that.talkList[that.talkList.length-1].content += xhr.responseText; - // }; - // xhr.send(); - - // fetch('https://ceshi-worker-task.lihaink.cn/api/xun_fei/chat?content=uniapp中js的回调有哪些') - // .then(response => response.body) - // .then(data => { - // // 在这里处理返回的数据 - // console.log(data); - // }) - // .catch(error => { - // // 在这里处理请求错误 - // console.error(error); - // }); - - // let that = this; - // this.talkList.push({ - // "id":new Date().getTime(), - // "content":'', - // "type":2, - // "pic":"/static/avatar.png" - // }); - // axios({ - // method: 'get', - // url: 'https://ceshi-worker-task.lihaink.cn/api/xun_fei/chat?content=uniapp中js的回调有哪些', - // responseType: 'text' - // }) - // .then(response => { - - // response.data.on('data', (chunk) => { - // // 处理流数据的逻辑 - // console.log(chunk); - // }); - - // response.data.on('end', () => { - // // 数据接收完成的逻辑 - // console.log('完成'); - // }); - - // }); - // fetch('https://ceshi-worker-task.lihaink.cn/api/xun_fei/chat?content=uniapp中js的回调有哪些') // 通过fetch获取一个Response对象 - // .then(response => response.body.getReader()) // 获取ReadableStreamDefaultReader对象 - // .then(reader => { - // function read() { - // return reader.read().then(({ done, value }) => { - // if (done) { - // console.log('读取完成'); - // return; - // } - - // const decoder = new TextDecoder(); - // console.log(decoder.decode(value)); - // that.talkList[that.talkList.length-1].content += decoder.decode(value); - // // console.log(value); // 输出读取到的数据 - // // 继续读取下一块数据 - // return read(); - // }); - // } - - // return read(); // 开始读取数据 - // }) - // .catch(error => console.error(error)); - // return ; \ No newline at end of file diff --git a/type.md b/type.md new file mode 100644 index 0000000..e69de29 diff --git a/unpackage/dist/dev/app-plus/app-config-service.js b/unpackage/dist/dev/app-plus/app-config-service.js index 6280a94..adf9f1c 100644 --- a/unpackage/dist/dev/app-plus/app-config-service.js +++ b/unpackage/dist/dev/app-plus/app-config-service.js @@ -1,8 +1,8 @@ var isReady=false;var onReadyCallbacks=[]; var isServiceReady=false;var onServiceReadyCallbacks=[]; -var __uniConfig = {"pages":["pages/index/index"],"window":{"navigationBarTextStyle":"black","navigationBarTitleText":"人工智能","navigationBarBackgroundColor":"#F8F8F8","backgroundColor":"#F8F8F8"},"darkmode":false,"nvueCompiler":"uni-app","nvueStyleCompiler":"uni-app","renderer":"auto","splashscreen":{"alwaysShowBeforeRender":true,"autoclose":false},"appname":"农业咨询","compilerVersion":"3.8.12","entryPagePath":"pages/index/index","networkTimeout":{"request":60000,"connectSocket":60000,"uploadFile":60000,"downloadFile":60000}}; -var __uniRoutes = [{"path":"/pages/index/index","meta":{"isQuit":true},"window":{"navigationBarTitleText":"农业咨询","bounce":"none"}}]; +var __uniConfig = {"pages":["pages/index/index"],"window":{"navigationBarTextStyle":"black","navigationBarTitleText":"人工智能","navigationBarBackgroundColor":"#F8F8F8","backgroundColor":"#F8F8F8"},"darkmode":false,"nvueCompiler":"uni-app","nvueStyleCompiler":"uni-app","renderer":"auto","splashscreen":{"alwaysShowBeforeRender":true,"autoclose":false},"appname":"教育咨询","compilerVersion":"3.8.12","entryPagePath":"pages/index/index","networkTimeout":{"request":60000,"connectSocket":60000,"uploadFile":60000,"downloadFile":60000}}; +var __uniRoutes = [{"path":"/pages/index/index","meta":{"isQuit":true},"window":{"navigationBarTitleText":"教育咨询","bounce":"none"}}]; __uniConfig.onReady=function(callback){if(__uniConfig.ready){callback()}else{onReadyCallbacks.push(callback)}};Object.defineProperty(__uniConfig,"ready",{get:function(){return isReady},set:function(val){isReady=val;if(!isReady){return}const callbacks=onReadyCallbacks.slice(0);onReadyCallbacks.length=0;callbacks.forEach(function(callback){callback()})}}); __uniConfig.onServiceReady=function(callback){if(__uniConfig.serviceReady){callback()}else{onServiceReadyCallbacks.push(callback)}};Object.defineProperty(__uniConfig,"serviceReady",{get:function(){return isServiceReady},set:function(val){isServiceReady=val;if(!isServiceReady){return}const callbacks=onServiceReadyCallbacks.slice(0);onServiceReadyCallbacks.length=0;callbacks.forEach(function(callback){callback()})}}); service.register("uni-app-config",{create(a,b,c){if(!__uniConfig.viewport){var d=b.weex.config.env.scale,e=b.weex.config.env.deviceWidth,f=Math.ceil(e/d);Object.assign(__uniConfig,{viewport:f,defaultFontSize:Math.round(f/20)})}return{instance:{__uniConfig:__uniConfig,__uniRoutes:__uniRoutes,global:void 0,window:void 0,document:void 0,frames:void 0,self:void 0,location:void 0,navigator:void 0,localStorage:void 0,history:void 0,Caches:void 0,screen:void 0,alert:void 0,confirm:void 0,prompt:void 0,fetch:void 0,XMLHttpRequest:void 0,WebSocket:void 0,webkit:void 0,print:void 0}}}}); diff --git a/unpackage/dist/dev/app-plus/app-service.js b/unpackage/dist/dev/app-plus/app-service.js index 6c6f8ea..1c3ed64 100644 --- a/unpackage/dist/dev/app-plus/app-service.js +++ b/unpackage/dist/dev/app-plus/app-service.js @@ -1058,7 +1058,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 */ 33));\nvar _toConsumableArray2 = _interopRequireDefault(__webpack_require__(/*! @babel/runtime/helpers/toConsumableArray */ 22));\nvar _asyncToGenerator2 = _interopRequireDefault(__webpack_require__(/*! @babel/runtime/helpers/asyncToGenerator */ 35));\nvar base64 = _interopRequireWildcard(__webpack_require__(/*! base-64 */ 36));\nvar _cryptoJs = _interopRequireDefault(__webpack_require__(/*! ../../static/crypto-js/crypto-js.js */ 40));\nvar _parser = _interopRequireDefault(__webpack_require__(/*! ../../static/fast-xml-parser/src/parser */ 198));\nvar utf8 = _interopRequireWildcard(__webpack_require__(/*! utf8 */ 207));\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//\n//\n//\n//\n//\n//\n//\n//\nvar _default = {\n components: {\n 'bing-math': _bingMath.default\n },\n data: function data() {\n return {\n wssType: 'nongye',\n // 网络连接类型\n avatarType: \"/static/icon/ny.png\",\n // AI头像类型\n talkList: [],\n ajax: {\n rows: 15,\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 avatar: '/static/avatar.png',\n // 用户头像\n params: [],\n // 发送的消息内容\n timer: '',\n socketTask: {},\n TEXT: '',\n historyTextList: [],\n // 历史会话信息,由于最大token12000,可以结合实际使用,进行移出\n tempRes: '',\n // 临时答复保存\n socketing: false,\n // 是否正在接收\n showStop: false,\n // 是否显示中断按钮\n scrollTop: 0,\n shouldScrollToBottom: true\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 _this.$nextTick(function () {\n setTimeout(function () {\n uni.pageScrollTo({\n scrollTop: 9999999,\n // 当前位置向下滚动\n duration: 300 // 滚动过渡时间为300ms,默认值为300ms\n });\n }, 0);\n });\n });\n },\n onLoad: function onLoad() {\n var _this2 = this;\n var avatar = uni.getStorageSync('avatar');\n avatar ? this.avatar = avatar : null;\n uni.$on('MPinfo', function (e) {\n _this2.avatar = e.avatar;\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 _this3 = 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 _this3.c_content += nc[cl];\n cl++;\n if (cl % 6 == 0) _this3.$nextTick(function () {\n uni.pageScrollTo({\n scrollTop: 999999\n });\n });\n } else {\n // console.log(this.socketing==false, cl == nc.length);\n if (_this3.socketing == false) _this3.showStop = false;\n clearInterval(_this3.timer);\n _this3.$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 _this4 = this;\n return;\n if (this.ajax.flag) {\n return; //\n }\n\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 _this4.hideLoadTips();\n _this4.ajax.flag = false;\n _context.next = 4;\n return _this4.joinHistoryMsg();\n case 4:\n data = _context.sent;\n __f__(\"log\", '----- 模拟数据格式,供参考 -----', \" at pages/index/index.vue:169\");\n __f__(\"log\", data, \" at pages/index/index.vue:170\"); // 查看请求返回的数据结构 \n\n // 获取待滚动元素选择器,解决插入数据后,滚动条定位时使用\n selector = '';\n if (_this4.ajax.page > 1) {\n // 非第一页,则取历史消息数据的第一条信息元素\n selector = \"#msg-\".concat(_this4.talkList[0].id);\n } else {\n // 第一页,则取当前消息数据的最后一条信息元素\n selector = \"#msg-\".concat(data[data.length - 1].id);\n }\n\n // 将获取到的消息数据合并到消息数组中\n _this4.talkList = [].concat((0, _toConsumableArray2.default)(data), (0, _toConsumableArray2.default)(_this4.talkList));\n\n // 数据挂载后执行,不懂的请自行阅读 Vue.js 文档对 Vue.nextTick 函数说明。\n _this4.$nextTick(function () {\n // 设置当前滚动的位置\n _this4.setPageScrollTo(selector);\n _this4.hideLoadTips(true);\n if (data.length < _this4.ajax.rows) {\n // 当前消息数据条数小于请求要求条数时,则无更多消息,不再允许请求。\n // 可在此处编写无更多消息数据时的逻辑\n } else {\n _this4.ajax.page++;\n\n // 延迟 200ms ,以保证设置窗口滚动已完成\n setTimeout(function () {\n _this4.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 _this5 = this;\n var join = function join() {\n var arr = [];\n\n //通过当前页码及页数,模拟数据内容\n var startIndex = (_this5.ajax.page - 1) * _this5.ajax.rows;\n var endIndex = startIndex + _this5.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 // this.$nextTick(()=>{\n // setTimeout(()=>{\n // uni.pageScrollTo({\n // scrollTop: 9999999, // 当前位置向下滚动\n // duration: 300 // 滚动过渡时间为300ms,默认值为300ms\n // });\n // }, 0)\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 _this6 = this;\n if (flag) {\n this.ajax.loadText = '消息获取成功';\n setTimeout(function () {\n _this6.ajax.loading = false;\n }, 300);\n } else {\n this.ajax.loading = true;\n this.ajax.loadText = '正在获取消息';\n }\n },\n // 关闭连接\n closeSocketTask: function closeSocketTask() {\n var _this7 = this;\n try {\n clearInterval(this.timer);\n this.talkList[this.talkList.length - 1].content = this.c_content + '';\n // console.log(this.talkList[this.talkList.length - 1].content);\n // this.c_content = '';\n // this.n_content = '';\n this.socketTask.close({\n code: 500,\n // APP端存在BUG,正常关闭的code为1000,无法正常关闭,需要将code换为其他值\n complete: function complete(res) {\n _this7.showStop = false;\n __f__(\"log\", '主动断开', res, \" at pages/index/index.vue:289\");\n _this7.wsLiveFlag = false;\n }\n });\n } catch (e) {\n //TODO handle the exception\n }\n },\n // 发送信息\n send: function send() {\n var _this8 = this;\n if (!this.content) {\n uni.showToast({\n title: '请输入有效的内容',\n icon: 'none'\n });\n return;\n }\n this.showStop = true;\n // 将当前发送信息 添加到消息列表。\n var data = {\n \"id\": new Date().getTime(),\n \"content\": this.content,\n \"type\": 1,\n \"pic\": this.avatar\n };\n __f__(\"log\", data, \" at pages/index/index.vue:314\");\n this.TEXT = this.content;\n this.talkList.push(data);\n this.talkList.push({\n \"id\": new Date().getTime(),\n \"content\": '',\n \"type\": 2,\n \"pic\": this.avatarType\n });\n this.n_content = '';\n this.c_content = '';\n this.socketing = true;\n // return ;\n this.$nextTick(function () {\n // 清空内容框中的内容\n _this8.content = '';\n // uni.pageScrollTo({\n // scrollTop: 999999, // 设置一个超大值,以保证滚动条滚动到底部\n // duration: 0\n // });\n });\n\n this.sendToSpark();\n },\n sendToSpark: function sendToSpark() {\n var _this9 = 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 _this9.tempRes = \"\";\n realThis = _this9;\n _this9.socketTask = uni.connectSocket({\n //url: encodeURI(encodeURI(myUrl).replace(/\\+/g, '%2B')),\n url: \"wss://chat.lihaink.cn/chat?type=\".concat(_this9.wssType, \"×tamp=\").concat(Date.now()),\n method: 'GET',\n token: '',\n success: function success(res) {\n __f__(\"log\", res, \"ws成功连接...\", \" at pages/index/index.vue:348\");\n realThis.wsLiveFlag = true;\n }\n });\n realThis.socketTask.onError(function (res) {\n __f__(\"log\", \"连接发生错误,请检查appid是否填写\", res, \" at pages/index/index.vue:353\");\n });\n realThis.socketTask.onOpen(function (res) {\n _this9.historyTextList.push({\n \"role\": \"user\",\n \"content\": _this9.TEXT\n });\n // 第一帧..........................................\n __f__(\"log\", '连接成功...', \" at pages/index/index.vue:361\");\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 if (_this9.historyTextList.length > 9) _this9.params = JSON.parse(JSON.stringify(_this9.historyTextList.splice(-9)));else _this9.params = JSON.parse(JSON.stringify(_this9.historyTextList));\n _this9.isSurpass();\n realThis.socketTask.send({\n // 发送消息,,都用uni的官方版本\n data: JSON.stringify(_this9.params),\n success: function success() {\n __f__(\"log\", '第一帧发送成功', \" at pages/index/index.vue:387\");\n }\n });\n });\n\n // 接受到消息时\n realThis.socketTask.onMessage(function (res) {\n __f__(\"log\", '收到API返回的内容:', res.data, \" at pages/index/index.vue:394\");\n var obj = JSON.parse(res.data);\n // console.log(\"我打印的\"+obj.payload);\n if (!realThis.wsLiveFlag) return;\n var dataArray = obj.payload.choices.text;\n for (var i = 0; i < dataArray.length; i++) {\n _this9.talkList[_this9.talkList.length - 1].content += dataArray[i].content;\n _this9.n_content = _this9.talkList[_this9.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 _this9.socketing = false;\n __f__(\"log\", \"\".concat(temp.header.code, \":\").concat(temp.message), \" at pages/index/index.vue:408\");\n realThis.socketTask.close({\n success: function success(res) {\n __f__(\"log\", '关闭成功', res, \" at pages/index/index.vue:411\");\n realThis.wsLiveFlag = false;\n },\n fail: function fail(err) {\n __f__(\"log\", '关闭失败', err, \" at pages/index/index.vue:415\");\n }\n });\n }\n if (temp.header.code === 0) {\n if (res.data && temp.header.status === 2) {\n _this9.socketing = false;\n _this9.historyTextList.push({\n \"role\": \"assistant\",\n \"content\": _this9.tempRes\n });\n setTimeout(function () {\n realThis.socketTask.close({\n success: function success(res) {\n __f__(\"log\", '关闭成功', res, \" at pages/index/index.vue:429\");\n realThis.wsLiveFlag = false;\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 isSurpass: function isSurpass() {\n var sum = this.params.reduce(function (accumulator, currentValue) {\n return accumulator + currentValue.content;\n }, '');\n if (sum.length > 5000) {\n this.params.shift();\n return this.isSurpass();\n } else {\n __f__(\"log\", \"\\u672C\\u6B21\\u53D1\\u9001\".concat(sum.length, \"\\u5B57\"), \" at pages/index/index.vue:450\");\n return sum;\n }\n },\n // 鉴权\n getWebSocketUrl: function getWebSocketUrl() {\n var _this10 = 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, _this10.APISecret);\n var signature = _cryptoJs.default.enc.Base64.stringify(signatureSha);\n var authorizationOrigin = \"\".concat(apiKeyName, \"=\\\"\").concat(_this10.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 touchmove: function touchmove(e) {\n uni.hideKeyboard();\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 */ 21)[\"default\"]))//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["uni-app:///pages/index/index.vue"],"names":["components","data","wssType","avatarType","talkList","ajax","rows","page","flag","loading","loadText","keyboardHeight","showplc","content","c_content","n_content","avatar","params","timer","socketTask","TEXT","historyTextList","tempRes","socketing","showStop","scrollTop","shouldScrollToBottom","mounted","uni","setTimeout","duration","onLoad","beforeDestroy","onPageScroll","watch","cl","clearInterval","methods","copyText","success","icon","title","getHistoryMsg","selector","get","joinHistoryMsg","arr","done","focus","setPageScrollTo","view","hideLoadTips","closeSocketTask","code","complete","send","sendToSpark","realThis","url","method","token","splice","fail","isSurpass","getWebSocketUrl","apiKeyName","resolve","bindScroll","touchmove"],"mappings":";;;;;;;;;;;AA2CA;AACA;AACA;AACA;AACA;AAAA;AAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;eACA;EACAA;IACA;EACA;EACAC;IACA;MACAC;MAAA;MACAC;MAAA;MACAC;MACAC;QACAC;QAAA;QACAC;QAAA;QACAC;QAAA;QACAC;QAAA;QACAC;MACA;MACAC;MACAC;MACAC;MACAC;MACAC;MACAC;MAAA;MACAC;MAAA;MACAC;MACAC;MACAC;MACAC;MAAA;MACAC;MAAA;MACAC;MAAA;MACAC;MAAA;MACAC;MACAC;IACA;EACA;EACAC;IAAA;IACA;MACA;IACA;IACAC;MACA;MACA;MACA;QACAC;UACAD;YACAH;YAAA;YACAK;UACA;QACA;MACA;IACA;EACA;EACAC;IAAA;IACA;IACAf;IACAY;MACA;IACA;EACA;EACAI;IAEAJ;EAEA;EACAK;IACA;MACA;IACA;EACA;EACAC;IACAnB;MAAA;MACA;MACA;MACA;MACA;MACA;QACA;UACA;UACAoB;UACA;YACAP;cACAH;YACA;UACA;QACA;UACA;UACA;UACAW;UACA;YACAR;cACAH;YACA;UACA;QACA;MACA;IACA;EACA;EACAY;IACAC;MACAV;QACA3B;QACAsC;UACAX;YACAY;YACAC;UACA;QACA;MACA;IACA;IACA;IACAC;MAAA;MACA;MACA;QACA;MACA;;MAEA;QAAA;UAAA;UAAA;YAAA;cAAA;gBAAA;kBACA;kBACA;kBAAA;kBAAA,OACA;gBAAA;kBAAAzC;kBAEA;kBACA;;kBAEA;kBACA0C;kBAEA;oBACA;oBACAA;kBACA;oBACA;oBACAA;kBACA;;kBAEA;kBACA;;kBAEA;kBACA;oBACA;oBACA;oBAEA;oBAEA;sBACA;sBACA;oBAAA,CACA;sBACA;;sBAEA;sBACAd;wBACA;sBACA;oBACA;kBAEA;gBAAA;gBAAA;kBAAA;cAAA;YAAA;UAAA;QAAA,CACA;QAAA,gBA1CAe;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;QACAjB;UACA;UACAkB;QACA;MACA;IACA;IACAC;MACA;MACA;MACA;MACA;MACA;MACA;MACA;MACA;IAAA,CACA;IACA;IACAC;MACA;MACAC;QACAtB;UACAH;UAAA;UACAK;QACA;MACA;IACA;IACA;IACAqB;MAAA;MACA;QACA;QACAtB;UACA;QACA;MACA;QACA;QACA;MACA;IACA;IACA;IACAuB;MAAA;MACA;QACAhB;QACA;QACA;QACA;QACA;QACA;UACAiB;UAAA;UACAC;YACA;YACA;YACA;UACA;QACA;MACA;QACA;MAAA;IAEA;IACA;IACAC;MAAA;MACA;QACA3B;UACAa;UACAD;QACA;QACA;MACA;MACA;MACA;MACA;QACA;QACA;QACA;QACA;MACA;MACA;MACA;MACA;MACA;QACA;QACA;QACA;QACA;MACA;MACA;MACA;MACA;MACA;MACA;QACA;QACA;QACA;QACA;QACA;QACA;MACA;;MACA;IAEA;IACAgB;MAAA;MAAA;QAAA;QAAA;UAAA;YAAA;cAAA;gBACA;gBACA;gBACAC;gBACA;kBACA;kBACAC;kBACAC;kBACAC;kBACArB;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,wGACAI,kBACA;kBACA;kBACAJ;oBAAA;oBACAxD;oBACAsC;sBACA;oBACA;kBACA;gBACA;;gBAEA;gBACAkB;kBACA;kBACA;kBACA;kBACA;kBACA;kBACA;oBACA;oBACA;oBACAA;kBACA;kBACA;kBACA;kBACA;oBACA;oBACA;oBACAA;sBACAlB;wBACA;wBACAkB;sBACA;sBACAK;wBACA;sBACA;oBACA;kBACA;kBACA;oBACA;sBACA;sBACA;wBACA;wBACA;sBACA;sBACAjC;wBACA4B;0BACAlB;4BACA;4BACAkB;0BACA;0BACAK;4BACA;0BAAA;wBAEA;sBACA;oBACA;kBACA;gBACA;cAAA;cAAA;gBAAA;YAAA;UAAA;QAAA;MAAA;IACA;IACA;IACAC;MACA;QACA;MACA;MACA;QACA;QACA;MACA;QACA;QACA;MACA;IACA;IACA;IACAC;MAAA;MACA;QACA;QACA;QACA;QACA;QACA;QACA;QACA;QACA;QACA;QACA;QACA;QACA,oCACAC;QACA;QACAP;;QAEA;QACAQ;MACA;IACA;IACA;IACAC;MACA;QACA;QACA;QACA;QACA;QACA;MACA;QACA;MACA;IACA;IACA;IACAC;MACAxC;IACA;EACA;AACA;AAAA,2B","file":"32.js","sourcesContent":["<template>\r\n  <view class=\"wrapper\" @touchmove=\"touchmove\">\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        <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.type==1?avatar: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        <view id=\"bottom-box\"></view>\r\n      </view>\r\n    </view>\r\n    <uni-transition custom-class=\"box-2\" mode-class=\"slide-left\" :show=\"showStop\">\r\n      <view class=\"flex_col\">\r\n        <view class=\"flex_grow content downsocket\" @click=\"closeSocketTask\">中断连接</view>\r\n      </view>\r\n    </uni-transition>\r\n    <uni-transition custom-class=\"box-2\" mode-class=\"slide-right\" :show=\"!showStop\">\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    </uni-transition>\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 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        wssType: 'nongye', // 网络连接类型\r\n        avatarType: \"/static/icon/ny.png\", // AI头像类型\r\n        talkList: [],\r\n        ajax: {\r\n          rows: 15, //每页数量\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        avatar: '/static/avatar.png', // 用户头像\r\n        params: [], // 发送的消息内容\r\n        timer: '',\r\n        socketTask: {},\r\n        TEXT: '',\r\n        historyTextList: [], // 历史会话信息，由于最大token12000,可以结合实际使用，进行移出\r\n        tempRes: '', // 临时答复保存\r\n        socketing: false, // 是否正在接收\r\n        showStop: false, // 是否显示中断按钮\r\n        scrollTop: 0,\r\n        shouldScrollToBottom: true\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        this.$nextTick(() => {\r\n          setTimeout(() => {\r\n            uni.pageScrollTo({\r\n              scrollTop: 9999999, // 当前位置向下滚动\r\n              duration: 300 // 滚动过渡时间为300ms，默认值为300ms\r\n            });\r\n          }, 0)\r\n        })\r\n      })\r\n    },\r\n    onLoad() {\r\n      let avatar = uni.getStorageSync('avatar');\r\n      avatar ? this.avatar = avatar : null;\r\n      uni.$on('MPinfo', (e) => {\r\n        this.avatar = e.avatar;\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            // console.log(this.socketing==false, cl == nc.length);\r\n            if (this.socketing == false) this.showStop = false;\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        return;\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        // this.$nextTick(()=>{\r\n        //   setTimeout(()=>{\r\n        //     uni.pageScrollTo({\r\n        //       scrollTop: 9999999, // 当前位置向下滚动\r\n        //       duration: 300 // 滚动过渡时间为300ms，默认值为300ms\r\n        //     });\r\n        //   }, 0)\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      closeSocketTask() {\r\n        try {\r\n          clearInterval(this.timer);\r\n          this.talkList[this.talkList.length - 1].content = this.c_content + '';\r\n          // console.log(this.talkList[this.talkList.length - 1].content);\r\n          // this.c_content = '';\r\n          // this.n_content = '';\r\n          this.socketTask.close({\r\n            code: 500, // APP端存在BUG,正常关闭的code为1000,无法正常关闭,需要将code换为其他值\r\n            complete: (res) => {\r\n              this.showStop = false;\r\n              console.log('主动断开', res);\r\n              this.wsLiveFlag = false;\r\n            }\r\n          })\r\n        } catch (e) {\r\n          //TODO handle the exception\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        this.showStop = true;\r\n        // 将当前发送信息 添加到消息列表。\r\n        let data = {\r\n          \"id\": new Date().getTime(),\r\n          \"content\": this.content,\r\n          \"type\": 1,\r\n          \"pic\": this.avatar\r\n        }\r\n        console.log(data);\r\n        this.TEXT = this.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\": this.avatarType\r\n        });\r\n        this.n_content = '';\r\n        this.c_content = '';\r\n        this.socketing = true;\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?type=${this.wssType}&timestamp=${Date.now()}`,\r\n          method: 'GET',\r\n          token: '',\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          if (this.historyTextList.length > 9) this.params = JSON.parse(JSON.stringify(this.historyTextList\r\n            .splice(-9)));\r\n          else this.params = JSON.parse(JSON.stringify(this.historyTextList));\r\n          this.isSurpass();\r\n          realThis.socketTask.send({ // 发送消息，，都用uni的官方版本\r\n            data: JSON.stringify(this.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          if (!realThis.wsLiveFlag) return;\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            this.socketing = false;\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.socketing = false;\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                    realThis.wsLiveFlag = false;\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      isSurpass() {\r\n        let sum = this.params.reduce((accumulator, currentValue) => {\r\n          return accumulator + currentValue.content;\r\n        }, '');\r\n        if (sum.length > 5000) {\r\n          this.params.shift();\r\n          return this.isSurpass();\r\n        } else {\r\n          console.log(`本次发送${sum.length}字`);\r\n          return sum;\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        if (this.userId == 0) {\r\n          this.getHistory();\r\n          this.getproductInfo();\r\n          this.getOrderInfo();\r\n          this.getRefundDetail();\r\n          this.getStoreDetail();\r\n        } else {\r\n          this.getMerHistory();\r\n        }\r\n      },\r\n      // 当滑动页面时,收起键盘,与微信聊天效果保持一致\r\n      touchmove(e) {\r\n        uni.hideKeyboard()\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% {\r\n      opacity: 1;\r\n    }\r\n\r\n    50% {\r\n      opacity: 0;\r\n    }\r\n\r\n    100% {\r\n      opacity: 1;\r\n    }\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    min-height: calc(100vh - 100rpx);\r\n    padding-bottom: 100rpx;\r\n    box-sizing: content-box;\r\n    display: flex;\r\n    flex-direction: column;\r\n    justify-content: flex-end;\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);\r\n    /* 初始化 transform 属性 */\r\n    transition: transform 0.3s ease;\r\n    /* 添加过渡效果 */\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\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\r\n  .downsocket {\r\n    display: flex;\r\n    justify-content: center;\r\n    align-items: center;\r\n    background-color: #2573fb !important;\r\n    color: #fff !important;\r\n  }\r\n</style>"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///32\n"); +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 */ 33));\nvar _toConsumableArray2 = _interopRequireDefault(__webpack_require__(/*! @babel/runtime/helpers/toConsumableArray */ 22));\nvar _asyncToGenerator2 = _interopRequireDefault(__webpack_require__(/*! @babel/runtime/helpers/asyncToGenerator */ 35));\nvar base64 = _interopRequireWildcard(__webpack_require__(/*! base-64 */ 36));\nvar _cryptoJs = _interopRequireDefault(__webpack_require__(/*! ../../static/crypto-js/crypto-js.js */ 40));\nvar _parser = _interopRequireDefault(__webpack_require__(/*! ../../static/fast-xml-parser/src/parser */ 198));\nvar utf8 = _interopRequireWildcard(__webpack_require__(/*! utf8 */ 207));\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//\n//\n//\n//\n//\n//\n//\n//\nvar _default = {\n components: {\n 'bing-math': _bingMath.default\n },\n data: function data() {\n return {\n wssType: 'jiaoyu',\n // 网络连接类型\n avatarType: \"/static/icon/jy.png\",\n // AI头像类型\n talkList: [],\n ajax: {\n rows: 15,\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 avatar: '/static/avatar.png',\n // 用户头像\n params: [],\n // 发送的消息内容\n timer: '',\n socketTask: {},\n TEXT: '',\n historyTextList: [],\n // 历史会话信息,由于最大token12000,可以结合实际使用,进行移出\n tempRes: '',\n // 临时答复保存\n socketing: false,\n // 是否正在接收\n showStop: false,\n // 是否显示中断按钮\n scrollTop: 0,\n shouldScrollToBottom: true\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 _this.$nextTick(function () {\n setTimeout(function () {\n uni.pageScrollTo({\n scrollTop: 9999999,\n // 当前位置向下滚动\n duration: 300 // 滚动过渡时间为300ms,默认值为300ms\n });\n }, 0);\n });\n });\n },\n onLoad: function onLoad() {\n var _this2 = this;\n var avatar = uni.getStorageSync('avatar');\n avatar ? this.avatar = avatar : null;\n uni.$on('MPinfo', function (e) {\n _this2.avatar = e.avatar;\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 _this3 = 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 _this3.c_content += nc[cl];\n cl++;\n if (cl % 6 == 0) _this3.$nextTick(function () {\n uni.pageScrollTo({\n scrollTop: 999999\n });\n });\n } else {\n // console.log(this.socketing==false, cl == nc.length);\n if (_this3.socketing == false) _this3.showStop = false;\n clearInterval(_this3.timer);\n _this3.$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 _this4 = this;\n return;\n if (this.ajax.flag) {\n return; //\n }\n\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 _this4.hideLoadTips();\n _this4.ajax.flag = false;\n _context.next = 4;\n return _this4.joinHistoryMsg();\n case 4:\n data = _context.sent;\n __f__(\"log\", '----- 模拟数据格式,供参考 -----', \" at pages/index/index.vue:169\");\n __f__(\"log\", data, \" at pages/index/index.vue:170\"); // 查看请求返回的数据结构 \n\n // 获取待滚动元素选择器,解决插入数据后,滚动条定位时使用\n selector = '';\n if (_this4.ajax.page > 1) {\n // 非第一页,则取历史消息数据的第一条信息元素\n selector = \"#msg-\".concat(_this4.talkList[0].id);\n } else {\n // 第一页,则取当前消息数据的最后一条信息元素\n selector = \"#msg-\".concat(data[data.length - 1].id);\n }\n\n // 将获取到的消息数据合并到消息数组中\n _this4.talkList = [].concat((0, _toConsumableArray2.default)(data), (0, _toConsumableArray2.default)(_this4.talkList));\n\n // 数据挂载后执行,不懂的请自行阅读 Vue.js 文档对 Vue.nextTick 函数说明。\n _this4.$nextTick(function () {\n // 设置当前滚动的位置\n _this4.setPageScrollTo(selector);\n _this4.hideLoadTips(true);\n if (data.length < _this4.ajax.rows) {\n // 当前消息数据条数小于请求要求条数时,则无更多消息,不再允许请求。\n // 可在此处编写无更多消息数据时的逻辑\n } else {\n _this4.ajax.page++;\n\n // 延迟 200ms ,以保证设置窗口滚动已完成\n setTimeout(function () {\n _this4.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 _this5 = this;\n var join = function join() {\n var arr = [];\n\n //通过当前页码及页数,模拟数据内容\n var startIndex = (_this5.ajax.page - 1) * _this5.ajax.rows;\n var endIndex = startIndex + _this5.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 // this.$nextTick(()=>{\n // setTimeout(()=>{\n // uni.pageScrollTo({\n // scrollTop: 9999999, // 当前位置向下滚动\n // duration: 300 // 滚动过渡时间为300ms,默认值为300ms\n // });\n // }, 0)\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 _this6 = this;\n if (flag) {\n this.ajax.loadText = '消息获取成功';\n setTimeout(function () {\n _this6.ajax.loading = false;\n }, 300);\n } else {\n this.ajax.loading = true;\n this.ajax.loadText = '正在获取消息';\n }\n },\n // 关闭连接\n closeSocketTask: function closeSocketTask() {\n var _this7 = this;\n try {\n clearInterval(this.timer);\n this.talkList[this.talkList.length - 1].content = this.c_content + '';\n // console.log(this.talkList[this.talkList.length - 1].content);\n // this.c_content = '';\n // this.n_content = '';\n this.socketTask.close({\n code: 500,\n // APP端存在BUG,正常关闭的code为1000,无法正常关闭,需要将code换为其他值\n complete: function complete(res) {\n _this7.showStop = false;\n __f__(\"log\", '主动断开', res, \" at pages/index/index.vue:289\");\n _this7.wsLiveFlag = false;\n }\n });\n } catch (e) {\n //TODO handle the exception\n }\n },\n // 发送信息\n send: function send() {\n var _this8 = this;\n if (!this.content) {\n uni.showToast({\n title: '请输入有效的内容',\n icon: 'none'\n });\n return;\n }\n this.showStop = true;\n // 将当前发送信息 添加到消息列表。\n var data = {\n \"id\": new Date().getTime(),\n \"content\": this.content,\n \"type\": 1,\n \"pic\": this.avatar\n };\n __f__(\"log\", data, \" at pages/index/index.vue:314\");\n this.TEXT = this.content;\n this.talkList.push(data);\n this.talkList.push({\n \"id\": new Date().getTime(),\n \"content\": '',\n \"type\": 2,\n \"pic\": this.avatarType\n });\n this.n_content = '';\n this.c_content = '';\n this.socketing = true;\n // return ;\n this.$nextTick(function () {\n // 清空内容框中的内容\n _this8.content = '';\n // uni.pageScrollTo({\n // scrollTop: 999999, // 设置一个超大值,以保证滚动条滚动到底部\n // duration: 0\n // });\n });\n\n this.sendToSpark();\n },\n sendToSpark: function sendToSpark() {\n var _this9 = 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 _this9.tempRes = \"\";\n realThis = _this9;\n _this9.socketTask = uni.connectSocket({\n //url: encodeURI(encodeURI(myUrl).replace(/\\+/g, '%2B')),\n url: \"wss://chat.lihaink.cn/chat?type=\".concat(_this9.wssType, \"×tamp=\").concat(Date.now()),\n method: 'GET',\n token: '',\n success: function success(res) {\n __f__(\"log\", res, \"ws成功连接...\", \" at pages/index/index.vue:348\");\n realThis.wsLiveFlag = true;\n }\n });\n realThis.socketTask.onError(function (res) {\n __f__(\"log\", \"连接发生错误,请检查appid是否填写\", res, \" at pages/index/index.vue:353\");\n });\n realThis.socketTask.onOpen(function (res) {\n _this9.historyTextList.push({\n \"role\": \"user\",\n \"content\": _this9.TEXT\n });\n // 第一帧..........................................\n __f__(\"log\", '连接成功...', \" at pages/index/index.vue:361\");\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 if (_this9.historyTextList.length > 9) _this9.params = JSON.parse(JSON.stringify(_this9.historyTextList.splice(-9)));else _this9.params = JSON.parse(JSON.stringify(_this9.historyTextList));\n _this9.isSurpass();\n realThis.socketTask.send({\n // 发送消息,,都用uni的官方版本\n data: JSON.stringify(_this9.params),\n success: function success() {\n __f__(\"log\", '第一帧发送成功', \" at pages/index/index.vue:387\");\n }\n });\n });\n\n // 接受到消息时\n realThis.socketTask.onMessage(function (res) {\n __f__(\"log\", '收到API返回的内容:', res.data, \" at pages/index/index.vue:394\");\n var obj = JSON.parse(res.data);\n // console.log(\"我打印的\"+obj.payload);\n if (!realThis.wsLiveFlag) return;\n var dataArray = obj.payload.choices.text;\n for (var i = 0; i < dataArray.length; i++) {\n _this9.talkList[_this9.talkList.length - 1].content += dataArray[i].content;\n _this9.n_content = _this9.talkList[_this9.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 _this9.socketing = false;\n __f__(\"log\", \"\".concat(temp.header.code, \":\").concat(temp.message), \" at pages/index/index.vue:408\");\n realThis.socketTask.close({\n success: function success(res) {\n __f__(\"log\", '关闭成功', res, \" at pages/index/index.vue:411\");\n realThis.wsLiveFlag = false;\n },\n fail: function fail(err) {\n __f__(\"log\", '关闭失败', err, \" at pages/index/index.vue:415\");\n }\n });\n }\n if (temp.header.code === 0) {\n if (res.data && temp.header.status === 2) {\n _this9.socketing = false;\n _this9.historyTextList.push({\n \"role\": \"assistant\",\n \"content\": _this9.tempRes\n });\n setTimeout(function () {\n realThis.socketTask.close({\n success: function success(res) {\n __f__(\"log\", '关闭成功', res, \" at pages/index/index.vue:429\");\n realThis.wsLiveFlag = false;\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 isSurpass: function isSurpass() {\n var sum = this.params.reduce(function (accumulator, currentValue) {\n return accumulator + currentValue.content;\n }, '');\n if (sum.length > 5000) {\n this.params.shift();\n return this.isSurpass();\n } else {\n __f__(\"log\", \"\\u672C\\u6B21\\u53D1\\u9001\".concat(sum.length, \"\\u5B57\"), \" at pages/index/index.vue:450\");\n return sum;\n }\n },\n // 鉴权\n getWebSocketUrl: function getWebSocketUrl() {\n var _this10 = 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, _this10.APISecret);\n var signature = _cryptoJs.default.enc.Base64.stringify(signatureSha);\n var authorizationOrigin = \"\".concat(apiKeyName, \"=\\\"\").concat(_this10.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 touchmove: function touchmove(e) {\n uni.hideKeyboard();\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 */ 21)[\"default\"]))//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["uni-app:///pages/index/index.vue"],"names":["components","BingMath","data","wssType","avatarType","talkList","ajax","rows","page","flag","loading","loadText","keyboardHeight","showplc","content","c_content","n_content","avatar","params","timer","socketTask","TEXT","historyTextList","tempRes","socketing","showStop","scrollTop","shouldScrollToBottom","mounted","$nextTick","getHistoryMsg","uni","onKeyboardHeightChange","e","h","height","setTimeout","pageScrollTo","duration","onLoad","getStorageSync","$on","beforeDestroy","offKeyboardHeightChange","onPageScroll","watch","n","o","clearInterval","cl","length","nc","split","setInterval","methods","copyText","str","setClipboardData","success","showToast","icon","title","get","hideLoadTips","joinHistoryMsg","selector","id","setPageScrollTo","join","arr","startIndex","endIndex","i","push","Math","random","reverse","Promise","done","fail","focus","view","createSelectorQuery","in","select","boundingClientRect","res","top","exec","closeSocketTask","close","code","complete","wsLiveFlag","send","Date","getTime","sendToSpark","realThis","connectSocket","url","now","method","token","onError","onOpen","JSON","parse","stringify","splice","isSurpass","onMessage","obj","dataArray","payload","choices","text","temp","header","message","err","status","sum","reduce","accumulator","currentValue","shift","getWebSocketUrl","resolve","reject","host","apiKeyName","date","toGMTString","algorithm","headers","signatureOrigin","signatureSha","CryptoJS","HmacSHA256","APISecret","signature","enc","Base64","authorizationOrigin","APIKey","authorization","base64","encode","encodeURI","bindScroll","userId","getHistory","getproductInfo","getOrderInfo","getRefundDetail","getStoreDetail","getMerHistory","touchmove","hideKeyboard"],"mappings":"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","file":"32.js","sourcesContent":["//\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//\n//\n//\n//\n//\n//\n//\n\nimport * as base64 from \"base-64\"\nimport CryptoJS from '../../static/crypto-js/crypto-js.js'\nimport parser from '../../static/fast-xml-parser/src/parser'\nimport * as utf8 from \"utf8\"\nimport BingMath from \"@/components/bing-math/bing-math.vue\"\nexport default {\n  components: {\n    'bing-math': BingMath\n  },\n  data() {\n    return {\n      wssType: 'jiaoyu', // 网络连接类型\n      avatarType: \"/static/icon/jy.png\", // AI头像类型\n      talkList: [],\n      ajax: {\n        rows: 15, //每页数量\n        page: 1, //页码\n        flag: false, // 请求开关\n        loading: false, // 加载中\n        loadText: '正在获取消息'\n      },\n      keyboardHeight: 0,\n      showplc: true,\n      content: '',\n      c_content: '',\n      n_content: '',\n      avatar: '/static/avatar.png', // 用户头像\n      params: [], // 发送的消息内容\n      timer: '',\n      socketTask: {},\n      TEXT: '',\n      historyTextList: [], // 历史会话信息，由于最大token12000,可以结合实际使用，进行移出\n      tempRes: '', // 临时答复保存\n      socketing: false, // 是否正在接收\n      showStop: false, // 是否显示中断按钮\n      scrollTop: 0,\n      shouldScrollToBottom: true\n    }\n  },\n  mounted() {\n    this.$nextTick(() => {\n      this.getHistoryMsg();\n    });\n    uni.onKeyboardHeightChange(e => {\n      let h = this.keyboardHeight;\n      this.keyboardHeight = e.height;\n      this.$nextTick(() => {\n        setTimeout(() => {\n          uni.pageScrollTo({\n            scrollTop: 9999999, // 当前位置向下滚动\n            duration: 300 // 滚动过渡时间为300ms，默认值为300ms\n          });\n        }, 0)\n      })\n    })\n  },\n  onLoad() {\n    let avatar = uni.getStorageSync('avatar');\n    avatar ? this.avatar = avatar : null;\n    uni.$on('MPinfo', (e) => {\n      this.avatar = e.avatar;\n    })\n  },\n  beforeDestroy() {\n\n    uni.offKeyboardHeightChange();\n\n  },\n  onPageScroll(e) {\n    if (e.scrollTop < 5) {\n      this.getHistoryMsg();\n    }\n  },\n  watch: {\n    n_content(n, o) {\n      // this.c_content = n;\n      if (this.timer) clearInterval(this.timer);\n      let cl = this.c_content.length;\n      let nc = this.n_content.split('');\n      this.timer = setInterval(() => {\n        if (cl < nc.length) {\n          this.c_content += nc[cl];\n          cl++;\n          if (cl % 6 == 0) this.$nextTick(() => {\n            uni.pageScrollTo({\n              scrollTop: 999999,\n            })\n          })\n        } else {\n          // console.log(this.socketing==false, cl == nc.length);\n          if (this.socketing == false) this.showStop = false;\n          clearInterval(this.timer);\n          this.$nextTick(() => {\n            uni.pageScrollTo({\n              scrollTop: 9999999,\n            })\n          })\n        }\n      }, 60)\n    },\n  },\n  methods: {\n    copyText(str) {\n      uni.setClipboardData({\n        data: str,\n        success: function() {\n          uni.showToast({\n            icon: 'none',\n            title: '复制成功'\n          });\n        }\n      });\n    },\n    // 获取历史消息\n    getHistoryMsg() {\n      return;\n      if (this.ajax.flag) {\n        return; //\n      }\n\n      let get = async () => {\n        this.hideLoadTips();\n        this.ajax.flag = false;\n        let data = await this.joinHistoryMsg();\n\n        console.log('----- 模拟数据格式，供参考 -----');\n        console.log(data); // 查看请求返回的数据结构 \n\n        // 获取待滚动元素选择器，解决插入数据后，滚动条定位时使用\n        let selector = '';\n\n        if (this.ajax.page > 1) {\n          // 非第一页，则取历史消息数据的第一条信息元素\n          selector = `#msg-${this.talkList[0].id}`;\n        } else {\n          // 第一页，则取当前消息数据的最后一条信息元素\n          selector = `#msg-${data[data.length-1].id}`;\n        }\n\n        // 将获取到的消息数据合并到消息数组中\n        this.talkList = [...data, ...this.talkList];\n\n        // 数据挂载后执行，不懂的请自行阅读 Vue.js 文档对 Vue.nextTick 函数说明。\n        this.$nextTick(() => {\n          // 设置当前滚动的位置\n          this.setPageScrollTo(selector);\n\n          this.hideLoadTips(true);\n\n          if (data.length < this.ajax.rows) {\n            // 当前消息数据条数小于请求要求条数时，则无更多消息，不再允许请求。\n            // 可在此处编写无更多消息数据时的逻辑\n          } else {\n            this.ajax.page++;\n\n            // 延迟 200ms ，以保证设置窗口滚动已完成\n            setTimeout(() => {\n              this.ajax.flag = true;\n            }, 200)\n          }\n\n        })\n      }\n      get();\n    },\n    // 拼接历史记录消息\n    joinHistoryMsg() {\n      let join = () => {\n        let arr = [];\n\n        //通过当前页码及页数，模拟数据内容\n        let startIndex = (this.ajax.page - 1) * this.ajax.rows;\n        let endIndex = startIndex + this.ajax.rows;\n        for (let i = startIndex; i < endIndex; i++) {\n          arr.push({\n            \"id\": i, // 消息的ID\n            \"content\": `这是历史记录的第${i+1}条消息`, // 消息内容\n            \"type\": Math.random() > 0.5 ? 1 : 0, // 此为消息类别，设 1 为发出去的消息，0 为收到对方的消息,\n            \"pic\": \"/static/avatar.png\" // 头像\n          })\n        }\n\n        /*\n        \t颠倒数组中元素的顺序。将最新的数据排在本次接口返回数据的最后面。\n        \t后端接口按 消息的时间降序查找出当前页的数据后，再将本页数据按消息时间降序排序返回。\n        \t这是数据的重点，因为页面滚动条和上拉加载历史的问题。\n         */\n        arr.reverse();\n\n        return arr;\n      }\n\n      // 此处用到 ES6 的 Promise 知识，不懂的请自行学习。\n      return new Promise((done, fail) => {\n        // 无数据请求接口，由 setTimeout 模拟，正式项目替换为 ajax 即可。\n        setTimeout(() => {\n          let data = join();\n          done(data);\n        }, 1500);\n      })\n    },\n    focus() {\n      // this.$nextTick(()=>{\n      //   setTimeout(()=>{\n      //     uni.pageScrollTo({\n      //       scrollTop: 9999999, // 当前位置向下滚动\n      //       duration: 300 // 滚动过渡时间为300ms，默认值为300ms\n      //     });\n      //   }, 0)\n      // })\n    },\n    // 设置页面滚动位置\n    setPageScrollTo(selector) {\n      let view = uni.createSelectorQuery().in(this).select(selector);\n      view.boundingClientRect((res) => {\n        uni.pageScrollTo({\n          scrollTop: res.top - 30, // -30 为多显示出大半个消息的高度，示意上面还有信息。\n          duration: 0\n        });\n      }).exec();\n    },\n    // 隐藏加载提示\n    hideLoadTips(flag) {\n      if (flag) {\n        this.ajax.loadText = '消息获取成功';\n        setTimeout(() => {\n          this.ajax.loading = false;\n        }, 300);\n      } else {\n        this.ajax.loading = true;\n        this.ajax.loadText = '正在获取消息';\n      }\n    },\n    // 关闭连接\n    closeSocketTask() {\n      try {\n        clearInterval(this.timer);\n        this.talkList[this.talkList.length - 1].content = this.c_content + '';\n        // console.log(this.talkList[this.talkList.length - 1].content);\n        // this.c_content = '';\n        // this.n_content = '';\n        this.socketTask.close({\n          code: 500, // APP端存在BUG,正常关闭的code为1000,无法正常关闭,需要将code换为其他值\n          complete: (res) => {\n            this.showStop = false;\n            console.log('主动断开', res);\n            this.wsLiveFlag = false;\n          }\n        })\n      } catch (e) {\n        //TODO handle the exception\n      }\n    },\n    // 发送信息\n    send() {\n      if (!this.content) {\n        uni.showToast({\n          title: '请输入有效的内容',\n          icon: 'none'\n        })\n        return;\n      }\n      this.showStop = true;\n      // 将当前发送信息 添加到消息列表。\n      let data = {\n        \"id\": new Date().getTime(),\n        \"content\": this.content,\n        \"type\": 1,\n        \"pic\": this.avatar\n      }\n      console.log(data);\n      this.TEXT = this.content;\n      this.talkList.push(data);\n      this.talkList.push({\n        \"id\": new Date().getTime(),\n        \"content\": '',\n        \"type\": 2,\n        \"pic\": this.avatarType\n      });\n      this.n_content = '';\n      this.c_content = '';\n      this.socketing = true;\n      // return ;\n      this.$nextTick(() => {\n        // 清空内容框中的内容\n        this.content = '';\n        // uni.pageScrollTo({\n        //   scrollTop: 999999, // 设置一个超大值，以保证滚动条滚动到底部\n        //   duration: 0\n        // });\n      })\n      this.sendToSpark();\n\n    },\n    async sendToSpark() {\n      // let myUrl = await this.getWebSocketUrl();\n      this.tempRes = \"\";\n      let realThis = this;\n      this.socketTask = uni.connectSocket({\n        //url: encodeURI(encodeURI(myUrl).replace(/\\+/g, '%2B')),\n        url: `wss://chat.lihaink.cn/chat?type=${this.wssType}&timestamp=${Date.now()}`,\n        method: 'GET',\n        token: '',\n        success: res => {\n          console.log(res, \"ws成功连接...\")\n          realThis.wsLiveFlag = true;\n        }\n      })\n      realThis.socketTask.onError((res) => {\n        console.log(\"连接发生错误，请检查appid是否填写\", res)\n      })\n      realThis.socketTask.onOpen((res) => {\n        this.historyTextList.push({\n          \"role\": \"user\",\n          \"content\": this.TEXT\n        })\n        // 第一帧..........................................\n        console.log('连接成功...')\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        if (this.historyTextList.length > 9) this.params = JSON.parse(JSON.stringify(this.historyTextList\n          .splice(-9)));\n        else this.params = JSON.parse(JSON.stringify(this.historyTextList));\n        this.isSurpass();\n        realThis.socketTask.send({ // 发送消息，，都用uni的官方版本\n          data: JSON.stringify(this.params),\n          success() {\n            console.log('第一帧发送成功');\n          }\n        });\n      });\n\n      // 接受到消息时\n      realThis.socketTask.onMessage((res) => {\n        console.log('收到API返回的内容：', res.data);\n        let obj = JSON.parse(res.data)\n        // console.log(\"我打印的\"+obj.payload);\n        if (!realThis.wsLiveFlag) return;\n        let dataArray = obj.payload.choices.text;\n        for (let i = 0; i < dataArray.length; i++) {\n          this.talkList[this.talkList.length - 1].content += dataArray[i].content;\n          this.n_content = this.talkList[this.talkList.length - 1].content;\n          realThis.tempRes = realThis.tempRes + dataArray[i].content\n        }\n        let temp = JSON.parse(res.data)\n        // console.log(\"0726\",temp.header.code)\n        if (temp.header.code !== 0) {\n          this.socketing = false;\n          console.log(`${temp.header.code}:${temp.message}`);\n          realThis.socketTask.close({\n            success(res) {\n              console.log('关闭成功', res)\n              realThis.wsLiveFlag = false;\n            },\n            fail(err) {\n              console.log('关闭失败', err)\n            }\n          })\n        }\n        if (temp.header.code === 0) {\n          if (res.data && temp.header.status === 2) {\n            this.socketing = false;\n            this.historyTextList.push({\n              \"role\": \"assistant\",\n              \"content\": this.tempRes\n            })\n            setTimeout(() => {\n              realThis.socketTask.close({\n                success(res) {\n                  console.log('关闭成功', res)\n                  realThis.wsLiveFlag = false;\n                },\n                fail(err) {\n                  // console.log('关闭失败', err)\n                }\n              })\n            }, 1000)\n          }\n        }\n      })\n    },\n    // 判断文字是否超过五千字\n    isSurpass() {\n      let sum = this.params.reduce((accumulator, currentValue) => {\n        return accumulator + currentValue.content;\n      }, '');\n      if (sum.length > 5000) {\n        this.params.shift();\n        return this.isSurpass();\n      } else {\n        console.log(`本次发送${sum.length}字`);\n        return sum;\n      }\n    },\n    // 鉴权\n    getWebSocketUrl() {\n      return new Promise((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: ${host}\\ndate: ${date}\\nGET /v2.1/chat HTTP/1.1`;\n        var signatureSha = CryptoJS.HmacSHA256(signatureOrigin, this.APISecret);\n        var signature = CryptoJS.enc.Base64.stringify(signatureSha);\n        var authorizationOrigin =\n          `${apiKeyName}=\"${this.APIKey}\", algorithm=\"${algorithm}\", headers=\"${headers}\", signature=\"${signature}\"`;\n        var authorization = base64.encode(authorizationOrigin);\n        url = `${url}?authorization=${authorization}&date=${encodeURI(date)}&host=${host}`;\n\n        // console.log(url)\n        resolve(url);\n      });\n    },\n    // 滚动到头部\n    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    touchmove(e) {\n      uni.hideKeyboard()\n    }\n  }\n}\n"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///32\n"); /***/ }), /* 33 */ diff --git a/unpackage/dist/dev/app-plus/manifest.json b/unpackage/dist/dev/app-plus/manifest.json index f1684ac..dbdcea8 100644 --- a/unpackage/dist/dev/app-plus/manifest.json +++ b/unpackage/dist/dev/app-plus/manifest.json @@ -1 +1 @@ -{"@platforms":["android","iPhone","iPad"],"id":"__UNI__9620511","name":"农业咨询","version":{"name":"1.0.0","code":"100"},"description":"","launch_path":"__uniappview.html","developer":{"name":"","email":"","url":""},"permissions":{"UniNView":{"description":"UniNView原生渲染"}},"plus":{"useragent":{"value":"uni-app","concatenate":true},"splashscreen":{"target":"id:1","autoclose":true,"waiting":true,"delay":0},"popGesture":"close","launchwebview":{"render":"always","id":"1","kernel":"WKWebview"},"statusbar":{"immersed":"supportedDevice","style":"dark","background":"#F8F8F8"},"usingComponents":true,"nvueStyleCompiler":"uni-app","compilerVersion":3,"distribute":{"google":{"permissions":["","","","","","","","","","","","","","",""],"abiFilters":["armeabi-v7a","arm64-v8a","x86"]},"apple":{"dSYMs":false},"plugins":{"ad":{},"audio":{"mp3":{"description":"Android平台录音支持MP3格式文件"}}}},"uniStatistics":{"enable":false},"arguments":"{\"name\":\"\",\"path\":\"\",\"query\":\"\",\"id\":0}","allowsInlineMediaPlayback":true,"uni-app":{"compilerVersion":"3.8.12","control":"uni-v3","nvueCompiler":"uni-app","renderer":"auto","nvue":{"flex-direction":"column"},"nvueLaunchMode":"normal"},"launch_path":"__uniappview.html"}} \ No newline at end of file +{"@platforms":["android","iPhone","iPad"],"id":"__UNI__7AA205C","name":"教育咨询","version":{"name":"1.0.0","code":"100"},"description":"","launch_path":"__uniappview.html","developer":{"name":"","email":"","url":""},"permissions":{"UniNView":{"description":"UniNView原生渲染"}},"plus":{"useragent":{"value":"uni-app","concatenate":true},"splashscreen":{"target":"id:1","autoclose":true,"waiting":true,"delay":0},"popGesture":"close","launchwebview":{"render":"always","id":"1","kernel":"WKWebview"},"statusbar":{"immersed":"supportedDevice","style":"dark","background":"#F8F8F8"},"usingComponents":true,"nvueStyleCompiler":"uni-app","compilerVersion":3,"distribute":{"google":{"permissions":["","","","","","","","","","","","","","",""],"abiFilters":["armeabi-v7a","arm64-v8a","x86"]},"apple":{"dSYMs":false},"plugins":{"ad":{},"audio":{"mp3":{"description":"Android平台录音支持MP3格式文件"}}}},"uniStatistics":{"enable":false},"arguments":"{\"name\":\"\",\"path\":\"\",\"query\":\"\",\"id\":0}","allowsInlineMediaPlayback":true,"uni-app":{"compilerVersion":"3.8.12","control":"uni-v3","nvueCompiler":"uni-app","renderer":"auto","nvue":{"flex-direction":"column"},"nvueLaunchMode":"normal"},"launch_path":"__uniappview.html"}} \ No newline at end of file