diff --git a/pages/index/index.vue b/pages/index/index.vue index b3e08a3..e83ea64 100644 --- a/pages/index/index.vue +++ b/pages/index/index.vue @@ -52,6 +52,8 @@ }, data() { return { + wssType: 'nongye', // 网络连接类型 + avatarType: "/static/icon/ny.png", // AI头像类型 talkList: [], ajax: { rows: 15, //每页数量 @@ -316,7 +318,7 @@ "id": new Date().getTime(), "content": '', "type": 2, - "pic": "/static/icon/ny.png" + "pic": this.avatarType }); this.n_content = ''; this.c_content = ''; @@ -339,7 +341,7 @@ let realThis = this; this.socketTask = uni.connectSocket({ //url: encodeURI(encodeURI(myUrl).replace(/\+/g, '%2B')), - url: `wss://chat.lihaink.cn/chat?type=农业咨询×tamp=${Date.now()}`, + url: `wss://chat.lihaink.cn/chat?type=${this.wssType}×tamp=${Date.now()}`, method: 'GET', token: '', success: res => { diff --git a/unpackage/dist/dev/app-plus/app-config-service.js b/unpackage/dist/dev/app-plus/app-config-service.js index 02db4d8..6280a94 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","pages/index/chat"],"window":{"navigationBarTextStyle":"black","navigationBarTitleText":"人工智能","navigationBarBackgroundColor":"#F8F8F8","backgroundColor":"#F8F8F8"},"darkmode":false,"nvueCompiler":"uni-app","nvueStyleCompiler":"uni-app","renderer":"auto","splashscreen":{"alwaysShowBeforeRender":true,"autoclose":false},"appname":"xunfeiAi","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":"讯飞AI","bounce":"none"}},{"path":"/pages/index/chat","meta":{},"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 9b20895..6c6f8ea 100644 --- a/unpackage/dist/dev/app-plus/app-service.js +++ b/unpackage/dist/dev/app-plus/app-service.js @@ -7,7 +7,7 @@ /***/ (function(module, exports, __webpack_require__) { "use strict"; -eval("\n\nvar _interopRequireDefault = __webpack_require__(/*! @babel/runtime/helpers/interopRequireDefault */ 1);\nvar _defineProperty2 = _interopRequireDefault(__webpack_require__(/*! @babel/runtime/helpers/defineProperty */ 2));\n__webpack_require__(/*! uni-pages */ 6);\nvar _App = _interopRequireDefault(__webpack_require__(/*! ./App */ 213));\nvar _vue = _interopRequireDefault(__webpack_require__(/*! vue */ 216));\n__webpack_require__(/*! ./uni.promisify.adaptor */ 217);\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { (0, _defineProperty2.default)(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\n_vue.default.config.productionTip = false;\n_App.default.mpType = 'app';\nvar app = new _vue.default(_objectSpread({}, _App.default));\napp.$mount();//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInVuaS1hcHA6Ly8vbWFpbi5qcyJdLCJuYW1lcyI6WyJWdWUiLCJjb25maWciLCJwcm9kdWN0aW9uVGlwIiwiQXBwIiwibXBUeXBlIiwiYXBwIiwiJG1vdW50Il0sIm1hcHBpbmdzIjoiOzs7O0FBQUE7QUFBbUI7QUFHbkI7QUFDQTtBQUFnQztBQUFBO0FBQ2hDQSxZQUFHLENBQUNDLE1BQU0sQ0FBQ0MsYUFBYSxHQUFHLEtBQUs7QUFDaENDLFlBQUcsQ0FBQ0MsTUFBTSxHQUFHLEtBQUs7QUFDbEIsSUFBTUMsR0FBRyxHQUFHLElBQUlMLFlBQUcsbUJBQ2RHLFlBQUcsRUFDTjtBQUNGRSxHQUFHLENBQUNDLE1BQU0sRUFBRSIsImZpbGUiOiIwLmpzIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0ICd1bmktcGFnZXMnO2ltcG9ydCBBcHAgZnJvbSAnLi9BcHAnXG5cblxuaW1wb3J0IFZ1ZSBmcm9tICd2dWUnXG5pbXBvcnQgJy4vdW5pLnByb21pc2lmeS5hZGFwdG9yJ1xuVnVlLmNvbmZpZy5wcm9kdWN0aW9uVGlwID0gZmFsc2VcbkFwcC5tcFR5cGUgPSAnYXBwJ1xuY29uc3QgYXBwID0gbmV3IFZ1ZSh7XG4gIC4uLkFwcFxufSlcbmFwcC4kbW91bnQoKVxuXG5cblxuXG5cblxuXG5cblxuXG4iXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///0\n"); +eval("\n\nvar _interopRequireDefault = __webpack_require__(/*! @babel/runtime/helpers/interopRequireDefault */ 1);\nvar _defineProperty2 = _interopRequireDefault(__webpack_require__(/*! @babel/runtime/helpers/defineProperty */ 2));\n__webpack_require__(/*! uni-pages */ 6);\nvar _App = _interopRequireDefault(__webpack_require__(/*! ./App */ 208));\nvar _vue = _interopRequireDefault(__webpack_require__(/*! vue */ 211));\n__webpack_require__(/*! ./uni.promisify.adaptor */ 212);\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { (0, _defineProperty2.default)(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\n_vue.default.config.productionTip = false;\n_App.default.mpType = 'app';\nvar app = new _vue.default(_objectSpread({}, _App.default));\napp.$mount();//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInVuaS1hcHA6Ly8vbWFpbi5qcyJdLCJuYW1lcyI6WyJWdWUiLCJjb25maWciLCJwcm9kdWN0aW9uVGlwIiwiQXBwIiwibXBUeXBlIiwiYXBwIiwiJG1vdW50Il0sIm1hcHBpbmdzIjoiOzs7O0FBQUE7QUFBbUI7QUFHbkI7QUFDQTtBQUFnQztBQUFBO0FBQ2hDQSxZQUFHLENBQUNDLE1BQU0sQ0FBQ0MsYUFBYSxHQUFHLEtBQUs7QUFDaENDLFlBQUcsQ0FBQ0MsTUFBTSxHQUFHLEtBQUs7QUFDbEIsSUFBTUMsR0FBRyxHQUFHLElBQUlMLFlBQUcsbUJBQ2RHLFlBQUcsRUFDTjtBQUNGRSxHQUFHLENBQUNDLE1BQU0sRUFBRSIsImZpbGUiOiIwLmpzIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0ICd1bmktcGFnZXMnO2ltcG9ydCBBcHAgZnJvbSAnLi9BcHAnXG5cblxuaW1wb3J0IFZ1ZSBmcm9tICd2dWUnXG5pbXBvcnQgJy4vdW5pLnByb21pc2lmeS5hZGFwdG9yJ1xuVnVlLmNvbmZpZy5wcm9kdWN0aW9uVGlwID0gZmFsc2VcbkFwcC5tcFR5cGUgPSAnYXBwJ1xuY29uc3QgYXBwID0gbmV3IFZ1ZSh7XG4gIC4uLkFwcFxufSlcbmFwcC4kbW91bnQoKVxuXG5cblxuXG5cblxuXG5cblxuXG4iXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///0\n"); /***/ }), /* 1 */ @@ -148,9 +148,6 @@ if (uni.restoreGlobal) { __definePage('pages/index/index', function () { return Vue.extend(__webpack_require__(/*! pages/index/index.vue?mpType=page */ 7).default); }); -__definePage('pages/index/chat', function () { - return Vue.extend(__webpack_require__(/*! pages/index/chat.vue?mpType=page */ 208).default); -}); /***/ }), /* 7 */ @@ -293,7 +290,11 @@ var render = function () { _c("image", { staticClass: _vm._$s("7-" + $30, "sc", "pic"), attrs: { - src: _vm._$s("7-" + $30, "a-src", item.pic), + src: _vm._$s( + "7-" + $30, + "a-src", + item.type == 1 ? _vm.avatar : item.pic + ), _i: "7-" + $30, }, }), @@ -1057,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 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 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 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 } else {\n // console.log(this.socketing==false, cl == nc.length);\n if (_this2.socketing == false) _this2.showStop = false;\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 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 _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:159\");\n __f__(\"log\", data, \" at pages/index/index.vue:160\"); // 查看请求返回的数据结构 \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 // 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 _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 closeSocketTask: function closeSocketTask() {\n var _this6 = 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 _this6.showStop = false;\n __f__(\"log\", '主动断开', res, \" at pages/index/index.vue:279\");\n _this6.wsLiveFlag = false;\n }\n });\n } catch (e) {\n //TODO handle the exception\n }\n },\n // 发送信息\n send: function send() {\n var _this7 = 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\": \"/static/avatar.png\"\n };\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\": \"/static/avatar.png\"\n });\n this.n_content = '';\n this.c_content = '';\n this.socketing = true;\n // return ;\n this.$nextTick(function () {\n // 清空内容框中的内容\n _this7.content = '';\n // uni.pageScrollTo({\n // scrollTop: 999999, // 设置一个超大值,以保证滚动条滚动到底部\n // duration: 0\n // });\n });\n\n this.sendToSpark();\n },\n sendToSpark: function sendToSpark() {\n var _this8 = 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 _this8.tempRes = \"\";\n realThis = _this8;\n _this8.socketTask = uni.connectSocket({\n //url: encodeURI(encodeURI(myUrl).replace(/\\+/g, '%2B')),\n url: 'wss://chat.lihaink.cn/chat' + '?timestamp=' + Date.now(),\n method: 'GET',\n success: function success(res) {\n __f__(\"log\", res, \"ws成功连接...\", \" at pages/index/index.vue:336\");\n realThis.wsLiveFlag = true;\n }\n });\n realThis.socketTask.onError(function (res) {\n __f__(\"log\", \"连接发生错误,请检查appid是否填写\", res, \" at pages/index/index.vue:341\");\n });\n realThis.socketTask.onOpen(function (res) {\n _this8.historyTextList.push({\n \"role\": \"user\",\n \"content\": _this8.TEXT\n });\n // 第一帧..........................................\n __f__(\"log\", '连接成功...', \" at pages/index/index.vue:349\");\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 (_this8.historyTextList.length > 9) _this8.params = JSON.parse(JSON.stringify(_this8.historyTextList.splice(-9)));else _this8.params = JSON.parse(JSON.stringify(_this8.historyTextList));\n _this8.isSurpass();\n realThis.socketTask.send({\n // 发送消息,,都用uni的官方版本\n data: JSON.stringify(_this8.params),\n success: function success() {\n __f__(\"log\", '第一帧发送成功', \" at pages/index/index.vue:375\");\n }\n });\n });\n\n // 接受到消息时\n realThis.socketTask.onMessage(function (res) {\n __f__(\"log\", '收到API返回的内容:', res.data, \" at pages/index/index.vue:382\");\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 _this8.talkList[_this8.talkList.length - 1].content += dataArray[i].content;\n _this8.n_content = _this8.talkList[_this8.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 _this8.socketing = false;\n __f__(\"log\", \"\".concat(temp.header.code, \":\").concat(temp.message), \" at pages/index/index.vue:396\");\n realThis.socketTask.close({\n success: function success(res) {\n __f__(\"log\", '关闭成功', res, \" at pages/index/index.vue:399\");\n realThis.wsLiveFlag = false;\n },\n fail: function fail(err) {\n __f__(\"log\", '关闭失败', err, \" at pages/index/index.vue:403\");\n }\n });\n }\n if (temp.header.code === 0) {\n if (res.data && temp.header.status === 2) {\n _this8.socketing = false;\n _this8.historyTextList.push({\n \"role\": \"assistant\",\n \"content\": _this8.tempRes\n });\n setTimeout(function () {\n realThis.socketTask.close({\n success: function success(res) {\n __f__(\"log\", '关闭成功', res, \" at pages/index/index.vue:417\");\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:438\");\n return sum;\n }\n },\n // 鉴权\n getWebSocketUrl: function getWebSocketUrl() {\n var _this9 = 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, _this9.APISecret);\n var signature = _cryptoJs.default.enc.Base64.stringify(signatureSha);\n var authorizationOrigin = \"\".concat(apiKeyName, \"=\\\"\").concat(_this9.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","talkList","ajax","rows","page","flag","loading","loadText","keyboardHeight","showplc","content","c_content","n_content","params","timer","socketTask","TEXT","historyTextList","tempRes","socketing","showStop","scrollTop","shouldScrollToBottom","mounted","uni","setTimeout","duration","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","splice","fail","isSurpass","getWebSocketUrl","apiKeyName","resolve","bindScroll","touchmove"],"mappings":";;;;;;;;;;;AA2CA;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;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;IAEAH;EAEA;EACAI;IACA;MACA;IACA;EACA;EACAC;IACAjB;MAAA;MACA;MACA;MACA;MACA;MACA;QACA;UACA;UACAkB;UACA;YACAN;cACAH;YACA;UACA;QACA;UACA;UACA;UACAU;UACA;YACAP;cACAH;YACA;UACA;QACA;MACA;IACA;EACA;EACAW;IACAC;MACAT;QACAxB;QACAkC;UACAV;YACAW;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;kBAAArC;kBAEA;kBACA;;kBAEA;kBACAsC;kBAEA;oBACA;oBACAA;kBACA;oBACA;oBACAA;kBACA;;kBAEA;kBACA;;kBAEA;kBACA;oBACA;oBACA;oBAEA;oBAEA;sBACA;sBACA;oBAAA,CACA;sBACA;;sBAEA;sBACAb;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;QACAhB;UACA;UACAiB;QACA;MACA;IACA;IACAC;MACA;MACA;MACA;MACA;MACA;MACA;MACA;MACA;IAAA,CACA;IACA;IACAC;MACA;MACAC;QACArB;UACAH;UAAA;UACAK;QACA;MACA;IACA;IACA;IACAoB;MAAA;MACA;QACA;QACArB;UACA;QACA;MACA;QACA;QACA;MACA;IACA;IACA;IACAsB;MAAA;MACA;QACAhB;QACA;QACA;QACA;QACA;QACA;UACAiB;UAAA;UACAC;YACA;YACA;YACA;UACA;QACA;MACA;QACA;MAAA;IAEA;IACA;IACAC;MAAA;MACA;QACA1B;UACAY;UACAD;QACA;QACA;MACA;MACA;MACA;MACA;QACA;QACA;QACA;QACA;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;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,wGACAG,kBACA;kBACA;kBACAH;oBAAA;oBACApD;oBACAkC;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;sBACAI;wBACA;sBACA;oBACA;kBACA;kBACA;oBACA;sBACA;sBACA;wBACA;wBACA;sBACA;sBACA/B;wBACA2B;0BACAlB;4BACA;4BACAkB;0BACA;0BACAI;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;QACAN;;QAEA;QACAO;MACA;IACA;IACA;IACAC;MACA;QACA;QACA;QACA;QACA;QACA;MACA;QACA;MACA;IACA;IACA;IACAC;MACAtC;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.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        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        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    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\": \"/static/avatar.png\"\r\n        }\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\": \"/static/avatar.png\"\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' + '?timestamp=' + Date.now(),\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          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: '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"); /***/ }), /* 33 */ @@ -25415,117 +25416,6 @@ eval("\n\n//parse Empty Node as self closing node\nvar _typeof = __webpack_requi /***/ }), /* 208 */ -/*!***********************************************************!*\ - !*** D:/里海数字乡村/xunfeiAi/pages/index/chat.vue?mpType=page ***! - \***********************************************************/ -/*! no static exports found */ -/***/ (function(module, __webpack_exports__, __webpack_require__) { - -"use strict"; -eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _chat_vue_vue_type_template_id_4e295d7e_mpType_page__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./chat.vue?vue&type=template&id=4e295d7e&mpType=page */ 209);\n/* harmony import */ var _chat_vue_vue_type_script_lang_js_mpType_page__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./chat.vue?vue&type=script&lang=js&mpType=page */ 211);\n/* harmony reexport (unknown) */ for(var __WEBPACK_IMPORT_KEY__ in _chat_vue_vue_type_script_lang_js_mpType_page__WEBPACK_IMPORTED_MODULE_1__) if([\"default\"].indexOf(__WEBPACK_IMPORT_KEY__) < 0) (function(key) { __webpack_require__.d(__webpack_exports__, key, function() { return _chat_vue_vue_type_script_lang_js_mpType_page__WEBPACK_IMPORTED_MODULE_1__[key]; }) }(__WEBPACK_IMPORT_KEY__));\n/* harmony import */ var _HBuilderX_plugins_uniapp_cli_node_modules_dcloudio_vue_cli_plugin_uni_packages_vue_loader_lib_runtime_componentNormalizer_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../../../../HBuilderX/plugins/uniapp-cli/node_modules/@dcloudio/vue-cli-plugin-uni/packages/vue-loader/lib/runtime/componentNormalizer.js */ 15);\n\nvar renderjs\n\n\n\n\n/* normalize component */\n\nvar component = Object(_HBuilderX_plugins_uniapp_cli_node_modules_dcloudio_vue_cli_plugin_uni_packages_vue_loader_lib_runtime_componentNormalizer_js__WEBPACK_IMPORTED_MODULE_2__[\"default\"])(\n _chat_vue_vue_type_script_lang_js_mpType_page__WEBPACK_IMPORTED_MODULE_1__[\"default\"],\n _chat_vue_vue_type_template_id_4e295d7e_mpType_page__WEBPACK_IMPORTED_MODULE_0__[\"render\"],\n _chat_vue_vue_type_template_id_4e295d7e_mpType_page__WEBPACK_IMPORTED_MODULE_0__[\"staticRenderFns\"],\n false,\n null,\n null,\n null,\n false,\n _chat_vue_vue_type_template_id_4e295d7e_mpType_page__WEBPACK_IMPORTED_MODULE_0__[\"components\"],\n renderjs\n)\n\ncomponent.options.__file = \"pages/index/chat.vue\"\n/* harmony default export */ __webpack_exports__[\"default\"] = (component.exports);//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbbnVsbF0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBNEg7QUFDNUg7QUFDbUU7QUFDTDs7O0FBRzlEO0FBQ21LO0FBQ25LLGdCQUFnQiw2S0FBVTtBQUMxQixFQUFFLHFGQUFNO0FBQ1IsRUFBRSwwRkFBTTtBQUNSLEVBQUUsbUdBQWU7QUFDakI7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLEVBQUUsOEZBQVU7QUFDWjtBQUNBOztBQUVBO0FBQ2UsZ0YiLCJmaWxlIjoiMjA4LmpzIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgcmVuZGVyLCBzdGF0aWNSZW5kZXJGbnMsIHJlY3ljbGFibGVSZW5kZXIsIGNvbXBvbmVudHMgfSBmcm9tIFwiLi9jaGF0LnZ1ZT92dWUmdHlwZT10ZW1wbGF0ZSZpZD00ZTI5NWQ3ZSZtcFR5cGU9cGFnZVwiXG52YXIgcmVuZGVyanNcbmltcG9ydCBzY3JpcHQgZnJvbSBcIi4vY2hhdC52dWU/dnVlJnR5cGU9c2NyaXB0Jmxhbmc9anMmbXBUeXBlPXBhZ2VcIlxuZXhwb3J0ICogZnJvbSBcIi4vY2hhdC52dWU/dnVlJnR5cGU9c2NyaXB0Jmxhbmc9anMmbXBUeXBlPXBhZ2VcIlxuXG5cbi8qIG5vcm1hbGl6ZSBjb21wb25lbnQgKi9cbmltcG9ydCBub3JtYWxpemVyIGZyb20gXCIhLi4vLi4vLi4vLi4vSEJ1aWxkZXJYL3BsdWdpbnMvdW5pYXBwLWNsaS9ub2RlX21vZHVsZXMvQGRjbG91ZGlvL3Z1ZS1jbGktcGx1Z2luLXVuaS9wYWNrYWdlcy92dWUtbG9hZGVyL2xpYi9ydW50aW1lL2NvbXBvbmVudE5vcm1hbGl6ZXIuanNcIlxudmFyIGNvbXBvbmVudCA9IG5vcm1hbGl6ZXIoXG4gIHNjcmlwdCxcbiAgcmVuZGVyLFxuICBzdGF0aWNSZW5kZXJGbnMsXG4gIGZhbHNlLFxuICBudWxsLFxuICBudWxsLFxuICBudWxsLFxuICBmYWxzZSxcbiAgY29tcG9uZW50cyxcbiAgcmVuZGVyanNcbilcblxuY29tcG9uZW50Lm9wdGlvbnMuX19maWxlID0gXCJwYWdlcy9pbmRleC9jaGF0LnZ1ZVwiXG5leHBvcnQgZGVmYXVsdCBjb21wb25lbnQuZXhwb3J0cyJdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///208\n"); - -/***/ }), -/* 209 */ -/*!*****************************************************************************************!*\ - !*** D:/里海数字乡村/xunfeiAi/pages/index/chat.vue?vue&type=template&id=4e295d7e&mpType=page ***! - \*****************************************************************************************/ -/*! exports provided: render, staticRenderFns, recyclableRender, components */ -/***/ (function(module, __webpack_exports__, __webpack_require__) { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony import */ var _HBuilderX_plugins_uniapp_cli_node_modules_dcloudio_vue_cli_plugin_uni_packages_vue_loader_lib_loaders_templateLoader_js_vue_loader_options_HBuilderX_plugins_uniapp_cli_node_modules_dcloudio_vue_cli_plugin_uni_packages_webpack_preprocess_loader_index_js_ref_11_0_HBuilderX_plugins_uniapp_cli_node_modules_dcloudio_vue_cli_plugin_uni_packages_webpack_uni_app_loader_filter_modules_template_js_HBuilderX_plugins_uniapp_cli_node_modules_dcloudio_vue_cli_plugin_uni_packages_webpack_uni_app_loader_page_meta_js_HBuilderX_plugins_uniapp_cli_node_modules_dcloudio_vue_cli_plugin_uni_packages_vue_loader_lib_index_js_vue_loader_options_chat_vue_vue_type_template_id_4e295d7e_mpType_page__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! -!../../../../HBuilderX/plugins/uniapp-cli/node_modules/@dcloudio/vue-cli-plugin-uni/packages/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!../../../../HBuilderX/plugins/uniapp-cli/node_modules/@dcloudio/vue-cli-plugin-uni/packages/webpack-preprocess-loader??ref--11-0!../../../../HBuilderX/plugins/uniapp-cli/node_modules/@dcloudio/vue-cli-plugin-uni/packages/webpack-uni-app-loader/filter-modules-template.js!../../../../HBuilderX/plugins/uniapp-cli/node_modules/@dcloudio/vue-cli-plugin-uni/packages/webpack-uni-app-loader/page-meta.js!../../../../HBuilderX/plugins/uniapp-cli/node_modules/@dcloudio/vue-cli-plugin-uni/packages/vue-loader/lib??vue-loader-options!./chat.vue?vue&type=template&id=4e295d7e&mpType=page */ 210); -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "render", function() { return _HBuilderX_plugins_uniapp_cli_node_modules_dcloudio_vue_cli_plugin_uni_packages_vue_loader_lib_loaders_templateLoader_js_vue_loader_options_HBuilderX_plugins_uniapp_cli_node_modules_dcloudio_vue_cli_plugin_uni_packages_webpack_preprocess_loader_index_js_ref_11_0_HBuilderX_plugins_uniapp_cli_node_modules_dcloudio_vue_cli_plugin_uni_packages_webpack_uni_app_loader_filter_modules_template_js_HBuilderX_plugins_uniapp_cli_node_modules_dcloudio_vue_cli_plugin_uni_packages_webpack_uni_app_loader_page_meta_js_HBuilderX_plugins_uniapp_cli_node_modules_dcloudio_vue_cli_plugin_uni_packages_vue_loader_lib_index_js_vue_loader_options_chat_vue_vue_type_template_id_4e295d7e_mpType_page__WEBPACK_IMPORTED_MODULE_0__["render"]; }); - -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "staticRenderFns", function() { return _HBuilderX_plugins_uniapp_cli_node_modules_dcloudio_vue_cli_plugin_uni_packages_vue_loader_lib_loaders_templateLoader_js_vue_loader_options_HBuilderX_plugins_uniapp_cli_node_modules_dcloudio_vue_cli_plugin_uni_packages_webpack_preprocess_loader_index_js_ref_11_0_HBuilderX_plugins_uniapp_cli_node_modules_dcloudio_vue_cli_plugin_uni_packages_webpack_uni_app_loader_filter_modules_template_js_HBuilderX_plugins_uniapp_cli_node_modules_dcloudio_vue_cli_plugin_uni_packages_webpack_uni_app_loader_page_meta_js_HBuilderX_plugins_uniapp_cli_node_modules_dcloudio_vue_cli_plugin_uni_packages_vue_loader_lib_index_js_vue_loader_options_chat_vue_vue_type_template_id_4e295d7e_mpType_page__WEBPACK_IMPORTED_MODULE_0__["staticRenderFns"]; }); - -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "recyclableRender", function() { return _HBuilderX_plugins_uniapp_cli_node_modules_dcloudio_vue_cli_plugin_uni_packages_vue_loader_lib_loaders_templateLoader_js_vue_loader_options_HBuilderX_plugins_uniapp_cli_node_modules_dcloudio_vue_cli_plugin_uni_packages_webpack_preprocess_loader_index_js_ref_11_0_HBuilderX_plugins_uniapp_cli_node_modules_dcloudio_vue_cli_plugin_uni_packages_webpack_uni_app_loader_filter_modules_template_js_HBuilderX_plugins_uniapp_cli_node_modules_dcloudio_vue_cli_plugin_uni_packages_webpack_uni_app_loader_page_meta_js_HBuilderX_plugins_uniapp_cli_node_modules_dcloudio_vue_cli_plugin_uni_packages_vue_loader_lib_index_js_vue_loader_options_chat_vue_vue_type_template_id_4e295d7e_mpType_page__WEBPACK_IMPORTED_MODULE_0__["recyclableRender"]; }); - -/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "components", function() { return _HBuilderX_plugins_uniapp_cli_node_modules_dcloudio_vue_cli_plugin_uni_packages_vue_loader_lib_loaders_templateLoader_js_vue_loader_options_HBuilderX_plugins_uniapp_cli_node_modules_dcloudio_vue_cli_plugin_uni_packages_webpack_preprocess_loader_index_js_ref_11_0_HBuilderX_plugins_uniapp_cli_node_modules_dcloudio_vue_cli_plugin_uni_packages_webpack_uni_app_loader_filter_modules_template_js_HBuilderX_plugins_uniapp_cli_node_modules_dcloudio_vue_cli_plugin_uni_packages_webpack_uni_app_loader_page_meta_js_HBuilderX_plugins_uniapp_cli_node_modules_dcloudio_vue_cli_plugin_uni_packages_vue_loader_lib_index_js_vue_loader_options_chat_vue_vue_type_template_id_4e295d7e_mpType_page__WEBPACK_IMPORTED_MODULE_0__["components"]; }); - - - -/***/ }), -/* 210 */ -/*!*********************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************!*\ - !*** ./node_modules/@dcloudio/vue-cli-plugin-uni/packages/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/@dcloudio/vue-cli-plugin-uni/packages/webpack-preprocess-loader??ref--11-0!./node_modules/@dcloudio/vue-cli-plugin-uni/packages/webpack-uni-app-loader/filter-modules-template.js!./node_modules/@dcloudio/vue-cli-plugin-uni/packages/webpack-uni-app-loader/page-meta.js!./node_modules/@dcloudio/vue-cli-plugin-uni/packages/vue-loader/lib??vue-loader-options!D:/里海数字乡村/xunfeiAi/pages/index/chat.vue?vue&type=template&id=4e295d7e&mpType=page ***! - \*********************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************/ -/*! exports provided: render, staticRenderFns, recyclableRender, components */ -/***/ (function(module, __webpack_exports__, __webpack_require__) { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "render", function() { return render; }); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "staticRenderFns", function() { return staticRenderFns; }); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "recyclableRender", function() { return recyclableRender; }); -/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "components", function() { return components; }); -var components -var render = function () { - var _vm = this - var _h = _vm.$createElement - var _c = _vm._self._c || _h - return _c("view", [ - _c("input", { - directives: [ - { - name: "model", - rawName: "v-model", - value: _vm.TEXT, - expression: "TEXT", - }, - ], - attrs: { _i: 1 }, - domProps: { value: _vm._$s(1, "v-model", _vm.TEXT) }, - on: { - input: function ($event) { - if ($event.target.composing) { - return - } - _vm.TEXT = $event.target.value - }, - }, - }), - _c("button", { - attrs: { _i: 2 }, - on: { - click: function ($event) { - return _vm.sendToSpark() - }, - }, - }), - _c("text", [_vm._v(_vm._$s(3, "t0-0", _vm._s(_vm.sparkResult)))]), - ]) -} -var recyclableRender = false -var staticRenderFns = [] -render._withStripped = true - - - -/***/ }), -/* 211 */ -/*!***********************************************************************************!*\ - !*** D:/里海数字乡村/xunfeiAi/pages/index/chat.vue?vue&type=script&lang=js&mpType=page ***! - \***********************************************************************************/ -/*! no static exports found */ -/***/ (function(module, __webpack_exports__, __webpack_require__) { - -"use strict"; -eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _HBuilderX_plugins_uniapp_cli_node_modules_babel_loader_lib_index_js_HBuilderX_plugins_uniapp_cli_node_modules_dcloudio_vue_cli_plugin_uni_packages_webpack_preprocess_loader_index_js_ref_7_1_HBuilderX_plugins_uniapp_cli_node_modules_dcloudio_vue_cli_plugin_uni_packages_webpack_uni_app_loader_using_components_js_HBuilderX_plugins_uniapp_cli_node_modules_dcloudio_vue_cli_plugin_uni_packages_vue_loader_lib_index_js_vue_loader_options_chat_vue_vue_type_script_lang_js_mpType_page__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! -!../../../../HBuilderX/plugins/uniapp-cli/node_modules/babel-loader/lib!../../../../HBuilderX/plugins/uniapp-cli/node_modules/@dcloudio/vue-cli-plugin-uni/packages/webpack-preprocess-loader??ref--7-1!../../../../HBuilderX/plugins/uniapp-cli/node_modules/@dcloudio/vue-cli-plugin-uni/packages/webpack-uni-app-loader/using-components.js!../../../../HBuilderX/plugins/uniapp-cli/node_modules/@dcloudio/vue-cli-plugin-uni/packages/vue-loader/lib??vue-loader-options!./chat.vue?vue&type=script&lang=js&mpType=page */ 212);\n/* harmony import */ var _HBuilderX_plugins_uniapp_cli_node_modules_babel_loader_lib_index_js_HBuilderX_plugins_uniapp_cli_node_modules_dcloudio_vue_cli_plugin_uni_packages_webpack_preprocess_loader_index_js_ref_7_1_HBuilderX_plugins_uniapp_cli_node_modules_dcloudio_vue_cli_plugin_uni_packages_webpack_uni_app_loader_using_components_js_HBuilderX_plugins_uniapp_cli_node_modules_dcloudio_vue_cli_plugin_uni_packages_vue_loader_lib_index_js_vue_loader_options_chat_vue_vue_type_script_lang_js_mpType_page__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_HBuilderX_plugins_uniapp_cli_node_modules_babel_loader_lib_index_js_HBuilderX_plugins_uniapp_cli_node_modules_dcloudio_vue_cli_plugin_uni_packages_webpack_preprocess_loader_index_js_ref_7_1_HBuilderX_plugins_uniapp_cli_node_modules_dcloudio_vue_cli_plugin_uni_packages_webpack_uni_app_loader_using_components_js_HBuilderX_plugins_uniapp_cli_node_modules_dcloudio_vue_cli_plugin_uni_packages_vue_loader_lib_index_js_vue_loader_options_chat_vue_vue_type_script_lang_js_mpType_page__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony reexport (unknown) */ for(var __WEBPACK_IMPORT_KEY__ in _HBuilderX_plugins_uniapp_cli_node_modules_babel_loader_lib_index_js_HBuilderX_plugins_uniapp_cli_node_modules_dcloudio_vue_cli_plugin_uni_packages_webpack_preprocess_loader_index_js_ref_7_1_HBuilderX_plugins_uniapp_cli_node_modules_dcloudio_vue_cli_plugin_uni_packages_webpack_uni_app_loader_using_components_js_HBuilderX_plugins_uniapp_cli_node_modules_dcloudio_vue_cli_plugin_uni_packages_vue_loader_lib_index_js_vue_loader_options_chat_vue_vue_type_script_lang_js_mpType_page__WEBPACK_IMPORTED_MODULE_0__) if([\"default\"].indexOf(__WEBPACK_IMPORT_KEY__) < 0) (function(key) { __webpack_require__.d(__webpack_exports__, key, function() { return _HBuilderX_plugins_uniapp_cli_node_modules_babel_loader_lib_index_js_HBuilderX_plugins_uniapp_cli_node_modules_dcloudio_vue_cli_plugin_uni_packages_webpack_preprocess_loader_index_js_ref_7_1_HBuilderX_plugins_uniapp_cli_node_modules_dcloudio_vue_cli_plugin_uni_packages_webpack_uni_app_loader_using_components_js_HBuilderX_plugins_uniapp_cli_node_modules_dcloudio_vue_cli_plugin_uni_packages_vue_loader_lib_index_js_vue_loader_options_chat_vue_vue_type_script_lang_js_mpType_page__WEBPACK_IMPORTED_MODULE_0__[key]; }) }(__WEBPACK_IMPORT_KEY__));\n /* harmony default export */ __webpack_exports__[\"default\"] = (_HBuilderX_plugins_uniapp_cli_node_modules_babel_loader_lib_index_js_HBuilderX_plugins_uniapp_cli_node_modules_dcloudio_vue_cli_plugin_uni_packages_webpack_preprocess_loader_index_js_ref_7_1_HBuilderX_plugins_uniapp_cli_node_modules_dcloudio_vue_cli_plugin_uni_packages_webpack_uni_app_loader_using_components_js_HBuilderX_plugins_uniapp_cli_node_modules_dcloudio_vue_cli_plugin_uni_packages_vue_loader_lib_index_js_vue_loader_options_chat_vue_vue_type_script_lang_js_mpType_page__WEBPACK_IMPORTED_MODULE_0___default.a); //# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbbnVsbF0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQTJpQixDQUFnQixxa0JBQUcsRUFBQyIsImZpbGUiOiIyMTEuanMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgbW9kIGZyb20gXCItIS4uLy4uLy4uLy4uL0hCdWlsZGVyWC9wbHVnaW5zL3VuaWFwcC1jbGkvbm9kZV9tb2R1bGVzL2JhYmVsLWxvYWRlci9saWIvaW5kZXguanMhLi4vLi4vLi4vLi4vSEJ1aWxkZXJYL3BsdWdpbnMvdW5pYXBwLWNsaS9ub2RlX21vZHVsZXMvQGRjbG91ZGlvL3Z1ZS1jbGktcGx1Z2luLXVuaS9wYWNrYWdlcy93ZWJwYWNrLXByZXByb2Nlc3MtbG9hZGVyL2luZGV4LmpzPz9yZWYtLTctMSEuLi8uLi8uLi8uLi9IQnVpbGRlclgvcGx1Z2lucy91bmlhcHAtY2xpL25vZGVfbW9kdWxlcy9AZGNsb3VkaW8vdnVlLWNsaS1wbHVnaW4tdW5pL3BhY2thZ2VzL3dlYnBhY2stdW5pLWFwcC1sb2FkZXIvdXNpbmctY29tcG9uZW50cy5qcyEuLi8uLi8uLi8uLi9IQnVpbGRlclgvcGx1Z2lucy91bmlhcHAtY2xpL25vZGVfbW9kdWxlcy9AZGNsb3VkaW8vdnVlLWNsaS1wbHVnaW4tdW5pL3BhY2thZ2VzL3Z1ZS1sb2FkZXIvbGliL2luZGV4LmpzPz92dWUtbG9hZGVyLW9wdGlvbnMhLi9jaGF0LnZ1ZT92dWUmdHlwZT1zY3JpcHQmbGFuZz1qcyZtcFR5cGU9cGFnZVwiOyBleHBvcnQgZGVmYXVsdCBtb2Q7IGV4cG9ydCAqIGZyb20gXCItIS4uLy4uLy4uLy4uL0hCdWlsZGVyWC9wbHVnaW5zL3VuaWFwcC1jbGkvbm9kZV9tb2R1bGVzL2JhYmVsLWxvYWRlci9saWIvaW5kZXguanMhLi4vLi4vLi4vLi4vSEJ1aWxkZXJYL3BsdWdpbnMvdW5pYXBwLWNsaS9ub2RlX21vZHVsZXMvQGRjbG91ZGlvL3Z1ZS1jbGktcGx1Z2luLXVuaS9wYWNrYWdlcy93ZWJwYWNrLXByZXByb2Nlc3MtbG9hZGVyL2luZGV4LmpzPz9yZWYtLTctMSEuLi8uLi8uLi8uLi9IQnVpbGRlclgvcGx1Z2lucy91bmlhcHAtY2xpL25vZGVfbW9kdWxlcy9AZGNsb3VkaW8vdnVlLWNsaS1wbHVnaW4tdW5pL3BhY2thZ2VzL3dlYnBhY2stdW5pLWFwcC1sb2FkZXIvdXNpbmctY29tcG9uZW50cy5qcyEuLi8uLi8uLi8uLi9IQnVpbGRlclgvcGx1Z2lucy91bmlhcHAtY2xpL25vZGVfbW9kdWxlcy9AZGNsb3VkaW8vdnVlLWNsaS1wbHVnaW4tdW5pL3BhY2thZ2VzL3Z1ZS1sb2FkZXIvbGliL2luZGV4LmpzPz92dWUtbG9hZGVyLW9wdGlvbnMhLi9jaGF0LnZ1ZT92dWUmdHlwZT1zY3JpcHQmbGFuZz1qcyZtcFR5cGU9cGFnZVwiIl0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///211\n"); - -/***/ }), -/* 212 */ -/*!****************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************!*\ - !*** ./node_modules/babel-loader/lib!./node_modules/@dcloudio/vue-cli-plugin-uni/packages/webpack-preprocess-loader??ref--7-1!./node_modules/@dcloudio/vue-cli-plugin-uni/packages/webpack-uni-app-loader/using-components.js!./node_modules/@dcloudio/vue-cli-plugin-uni/packages/vue-loader/lib??vue-loader-options!D:/里海数字乡村/xunfeiAi/pages/index/chat.vue?vue&type=script&lang=js&mpType=page ***! - \****************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************/ -/*! no static exports found */ -/***/ (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 _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));\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 tag // load the styles -var content = __webpack_require__(/*! !../../HBuilderX/plugins/uniapp-cli/node_modules/css-loader/dist/cjs.js??ref--6-oneOf-1-1!../../HBuilderX/plugins/uniapp-cli/node_modules/@dcloudio/vue-cli-plugin-uni/packages/vue-loader/lib/loaders/stylePostLoader.js!../../HBuilderX/plugins/uniapp-cli/node_modules/@dcloudio/vue-cli-plugin-uni/packages/webpack-preprocess-loader??ref--6-oneOf-1-2!../../HBuilderX/plugins/uniapp-cli/node_modules/postcss-loader/src??ref--6-oneOf-1-3!../../HBuilderX/plugins/uniapp-cli/node_modules/@dcloudio/vue-cli-plugin-uni/packages/vue-loader/lib??vue-loader-options!../../HBuilderX/plugins/uniapp-cli/node_modules/@dcloudio/vue-cli-plugin-uni/packages/webpack-uni-app-loader/view/style.js!./App.vue?vue&type=style&index=0&lang=css& */ 36); +var content = __webpack_require__(/*! !../../HBuilderX/plugins/uniapp-cli/node_modules/css-loader/dist/cjs.js??ref--6-oneOf-1-1!../../HBuilderX/plugins/uniapp-cli/node_modules/@dcloudio/vue-cli-plugin-uni/packages/vue-loader/lib/loaders/stylePostLoader.js!../../HBuilderX/plugins/uniapp-cli/node_modules/@dcloudio/vue-cli-plugin-uni/packages/webpack-preprocess-loader??ref--6-oneOf-1-2!../../HBuilderX/plugins/uniapp-cli/node_modules/postcss-loader/src??ref--6-oneOf-1-3!../../HBuilderX/plugins/uniapp-cli/node_modules/@dcloudio/vue-cli-plugin-uni/packages/vue-loader/lib??vue-loader-options!../../HBuilderX/plugins/uniapp-cli/node_modules/@dcloudio/vue-cli-plugin-uni/packages/webpack-uni-app-loader/view/style.js!./App.vue?vue&type=style&index=0&lang=css& */ 31); if(content.__esModule) content = content.default; if(typeof content === 'string') content = [[module.i, content, '']]; if(content.locals) module.exports = content.locals; @@ -1855,7 +1687,7 @@ var update = add("547d3d93", content, false, {"sourceMap":false,"shadowMode":fal if(false) {} /***/ }), -/* 36 */ +/* 31 */ /*!*****************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************!*\ !*** ./node_modules/css-loader/dist/cjs.js??ref--6-oneOf-1-1!./node_modules/@dcloudio/vue-cli-plugin-uni/packages/vue-loader/lib/loaders/stylePostLoader.js!./node_modules/@dcloudio/vue-cli-plugin-uni/packages/webpack-preprocess-loader??ref--6-oneOf-1-2!./node_modules/postcss-loader/src??ref--6-oneOf-1-3!./node_modules/@dcloudio/vue-cli-plugin-uni/packages/vue-loader/lib??vue-loader-options!./node_modules/@dcloudio/vue-cli-plugin-uni/packages/webpack-uni-app-loader/view/style.js!D:/里海数字乡村/xunfeiAi/App.vue?vue&type=style&index=0&lang=css& ***! \*****************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************/ @@ -1866,7 +1698,7 @@ if(false) {} var ___CSS_LOADER_API_IMPORT___ = __webpack_require__(/*! ../../HBuilderX/plugins/uniapp-cli/node_modules/css-loader/dist/runtime/api.js */ 26); exports = ___CSS_LOADER_API_IMPORT___(false); // Module -exports.push([module.i, "\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n/*每个页面公共css */\n", ""]); +exports.push([module.i, "\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/*每个页面公共css */\n", ""]); // Exports module.exports = exports; diff --git a/unpackage/dist/dev/app-plus/manifest.json b/unpackage/dist/dev/app-plus/manifest.json index 299e55a..f1684ac 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":"xunfeiAi","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__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 diff --git a/unpackage/dist/dev/app-plus/static/avatar.png b/unpackage/dist/dev/app-plus/static/avatar.png index 4aa23de..2f531da 100644 Binary files a/unpackage/dist/dev/app-plus/static/avatar.png and b/unpackage/dist/dev/app-plus/static/avatar.png differ diff --git a/unpackage/dist/dev/app-plus/static/iat.png b/unpackage/dist/dev/app-plus/static/iat.png deleted file mode 100644 index eb114a9..0000000 Binary files a/unpackage/dist/dev/app-plus/static/iat.png and /dev/null differ diff --git a/unpackage/dist/dev/app-plus/static/iat_active.png b/unpackage/dist/dev/app-plus/static/iat_active.png deleted file mode 100644 index 7310a3a..0000000 Binary files a/unpackage/dist/dev/app-plus/static/iat_active.png and /dev/null differ diff --git a/unpackage/dist/dev/app-plus/static/ise.png b/unpackage/dist/dev/app-plus/static/ise.png deleted file mode 100644 index 1b2991a..0000000 Binary files a/unpackage/dist/dev/app-plus/static/ise.png and /dev/null differ diff --git a/unpackage/dist/dev/app-plus/static/ise_active.png b/unpackage/dist/dev/app-plus/static/ise_active.png deleted file mode 100644 index 71e7578..0000000 Binary files a/unpackage/dist/dev/app-plus/static/ise_active.png and /dev/null differ diff --git a/unpackage/dist/dev/app-plus/static/logo.png b/unpackage/dist/dev/app-plus/static/logo.png deleted file mode 100644 index b5771e2..0000000 Binary files a/unpackage/dist/dev/app-plus/static/logo.png and /dev/null differ diff --git a/unpackage/dist/dev/app-plus/static/tts.png b/unpackage/dist/dev/app-plus/static/tts.png deleted file mode 100644 index c33108b..0000000 Binary files a/unpackage/dist/dev/app-plus/static/tts.png and /dev/null differ diff --git a/unpackage/dist/dev/app-plus/static/tts_avtive.png b/unpackage/dist/dev/app-plus/static/tts_avtive.png deleted file mode 100644 index a7f8be8..0000000 Binary files a/unpackage/dist/dev/app-plus/static/tts_avtive.png and /dev/null differ