UNPKG

chatgpt-app

Version:

基于react、webSocket开发的类ChatGPT组件

21 lines (19 loc) 51 kB
!function(e,t){"object"==typeof exports&&"undefined"!=typeof module?module.exports=t(require("react"),require("axios")):"function"==typeof define&&define.amd?define(["react","axios"],t):(e="undefined"!=typeof globalThis?globalThis:e||self).message=t(e.React,e.axios)}(this,(function(e,t){"use strict";var n=function(){return n=Object.assign||function(e){for(var t,n=1,r=arguments.length;n<r;n++)for(var o in t=arguments[n])Object.prototype.hasOwnProperty.call(t,o)&&(e[o]=t[o]);return e},n.apply(this,arguments)};function r(e,t,n,r){return new(n||(n=Promise))((function(o,i){function s(e){try{c(r.next(e))}catch(e){i(e)}}function a(e){try{c(r.throw(e))}catch(e){i(e)}}function c(e){var t;e.done?o(e.value):(t=e.value,t instanceof n?t:new n((function(e){e(t)}))).then(s,a)}c((r=r.apply(e,t||[])).next())}))}function o(e,t){var n,r,o,i,s={label:0,sent:function(){if(1&o[0])throw o[1];return o[1]},trys:[],ops:[]};return i={next:a(0),throw:a(1),return:a(2)},"function"==typeof Symbol&&(i[Symbol.iterator]=function(){return this}),i;function a(a){return function(c){return function(a){if(n)throw new TypeError("Generator is already executing.");for(;i&&(i=0,a[0]&&(s=0)),s;)try{if(n=1,r&&(o=2&a[0]?r.return:a[0]?r.throw||((o=r.return)&&o.call(r),0):r.next)&&!(o=o.call(r,a[1])).done)return o;switch(r=0,o&&(a=[2&a[0],o.value]),a[0]){case 0:case 1:o=a;break;case 4:return s.label++,{value:a[1],done:!1};case 5:s.label++,r=a[1],a=[0];continue;case 7:a=s.ops.pop(),s.trys.pop();continue;default:if(!(o=s.trys,(o=o.length>0&&o[o.length-1])||6!==a[0]&&2!==a[0])){s=0;continue}if(3===a[0]&&(!o||a[1]>o[0]&&a[1]<o[3])){s.label=a[1];break}if(6===a[0]&&s.label<o[1]){s.label=o[1],o=a;break}if(o&&s.label<o[2]){s.label=o[2],s.ops.push(a);break}o[2]&&s.ops.pop(),s.trys.pop();continue}a=t.call(e,s)}catch(e){a=[6,e],r=0}finally{n=o=0}if(5&a[0])throw a[1];return{value:a[0]?a[1]:void 0,done:!0}}([a,c])}}}function i(e,t,n){if(n||2===arguments.length)for(var r,o=0,i=t.length;o<i;o++)!r&&o in t||(r||(r=Array.prototype.slice.call(t,0,o)),r[o]=t[o]);return e.concat(r||Array.prototype.slice.call(t))}var s={}; /*! Copyright (c) 2018 Jed Watson. Licensed under the MIT License (MIT), see http://jedwatson.github.io/classnames */ !function(e){!function(){var t={}.hasOwnProperty;function n(){for(var e=[],r=0;r<arguments.length;r++){var o=arguments[r];if(o){var i=typeof o;if("string"===i||"number"===i)e.push(o);else if(Array.isArray(o)){if(o.length){var s=n.apply(null,o);s&&e.push(s)}}else if("object"===i){if(o.toString!==Object.prototype.toString&&!o.toString.toString().includes("[native code]")){e.push(o.toString());continue}for(var a in o)t.call(o,a)&&o[a]&&e.push(a)}}}return e.join(" ")}e.exports?(n.default=n,e.exports=n):window.classNames=n}()}({get exports(){return s},set exports(e){s=e}});for(var a,c=s,u=256,l=[];u--;)l[u]=(u+256).toString(16).substring(1);function f(e){var t=0,n=e||11;if(!a||u+n>512)for(a="",u=0;t<256;t++)a+=l[256*Math.random()|0];return a.substring(u,u+++n)} /*! ***************************************************************************** Copyright (c) Microsoft Corporation. All rights reserved. Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at http://www.apache.org/licenses/LICENSE-2.0 THIS CODE IS PROVIDED ON AN *AS IS* BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED, INCLUDING WITHOUT LIMITATION ANY IMPLIED WARRANTIES OR CONDITIONS OF TITLE, FITNESS FOR A PARTICULAR PURPOSE, MERCHANTABLITY OR NON-INFRINGEMENT. See the Apache Version 2.0 License for specific language governing permissions and limitations under the License. ***************************************************************************** */var p=function(e,t){return p=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var n in t)t.hasOwnProperty(n)&&(e[n]=t[n])},p(e,t)};function d(e,t){function n(){this.constructor=e}p(e,t),e.prototype=null===t?Object.create(t):(n.prototype=t.prototype,new n)}function A(e,t){var n="function"==typeof Symbol&&e[Symbol.iterator];if(!n)return e;var r,o,i=n.call(e),s=[];try{for(;(void 0===t||t-- >0)&&!(r=i.next()).done;)s.push(r.value)}catch(e){o={error:e}}finally{try{r&&!r.done&&(n=i.return)&&n.call(i)}finally{if(o)throw o.error}}return s}var h=function(e,t){this.target=t,this.type=e},v=function(e){function t(t,n){var r=e.call(this,"error",n)||this;return r.message=t.message,r.error=t,r}return d(t,e),t}(h),y=function(e){function t(t,n,r){void 0===t&&(t=1e3),void 0===n&&(n="");var o=e.call(this,"close",r)||this;return o.wasClean=!0,o.code=t,o.reason=n,o}return d(t,e),t}(h),m=function(){if("undefined"!=typeof WebSocket)return WebSocket},g={maxReconnectionDelay:1e4,minReconnectionDelay:1e3+4e3*Math.random(),minUptime:5e3,reconnectionDelayGrowFactor:1.3,connectionTimeout:4e3,maxRetries:1/0,maxEnqueuedMessages:1/0,startClosed:!1,debug:!1},b=function(){function e(e,t,n){var r=this;void 0===n&&(n={}),this._listeners={error:[],message:[],open:[],close:[]},this._retryCount=-1,this._shouldReconnect=!0,this._connectLock=!1,this._binaryType="blob",this._closeCalled=!1,this._messageQueue=[],this.onclose=null,this.onerror=null,this.onmessage=null,this.onopen=null,this._handleOpen=function(e){r._debug("open event");var t=r._options.minUptime,n=void 0===t?g.minUptime:t;clearTimeout(r._connectTimeout),r._uptimeTimeout=setTimeout((function(){return r._acceptOpen()}),n),r._ws.binaryType=r._binaryType,r._messageQueue.forEach((function(e){return r._ws.send(e)})),r._messageQueue=[],r.onopen&&r.onopen(e),r._listeners.open.forEach((function(t){return r._callEventListener(e,t)}))},this._handleMessage=function(e){r._debug("message event"),r.onmessage&&r.onmessage(e),r._listeners.message.forEach((function(t){return r._callEventListener(e,t)}))},this._handleError=function(e){r._debug("error event",e.message),r._disconnect(void 0,"TIMEOUT"===e.message?"timeout":void 0),r.onerror&&r.onerror(e),r._debug("exec error listeners"),r._listeners.error.forEach((function(t){return r._callEventListener(e,t)})),r._connect()},this._handleClose=function(e){r._debug("close event"),r._clearTimeouts(),r._shouldReconnect&&r._connect(),r.onclose&&r.onclose(e),r._listeners.close.forEach((function(t){return r._callEventListener(e,t)}))},this._url=e,this._protocols=t,this._options=n,this._options.startClosed&&(this._shouldReconnect=!1),this._connect()}return Object.defineProperty(e,"CONNECTING",{get:function(){return 0},enumerable:!0,configurable:!0}),Object.defineProperty(e,"OPEN",{get:function(){return 1},enumerable:!0,configurable:!0}),Object.defineProperty(e,"CLOSING",{get:function(){return 2},enumerable:!0,configurable:!0}),Object.defineProperty(e,"CLOSED",{get:function(){return 3},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"CONNECTING",{get:function(){return e.CONNECTING},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"OPEN",{get:function(){return e.OPEN},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"CLOSING",{get:function(){return e.CLOSING},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"CLOSED",{get:function(){return e.CLOSED},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"binaryType",{get:function(){return this._ws?this._ws.binaryType:this._binaryType},set:function(e){this._binaryType=e,this._ws&&(this._ws.binaryType=e)},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"retryCount",{get:function(){return Math.max(this._retryCount,0)},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"bufferedAmount",{get:function(){return this._messageQueue.reduce((function(e,t){return"string"==typeof t?e+=t.length:t instanceof Blob?e+=t.size:e+=t.byteLength,e}),0)+(this._ws?this._ws.bufferedAmount:0)},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"extensions",{get:function(){return this._ws?this._ws.extensions:""},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"protocol",{get:function(){return this._ws?this._ws.protocol:""},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"readyState",{get:function(){return this._ws?this._ws.readyState:this._options.startClosed?e.CLOSED:e.CONNECTING},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"url",{get:function(){return this._ws?this._ws.url:""},enumerable:!0,configurable:!0}),e.prototype.close=function(e,t){void 0===e&&(e=1e3),this._closeCalled=!0,this._shouldReconnect=!1,this._clearTimeouts(),this._ws?this._ws.readyState!==this.CLOSED?this._ws.close(e,t):this._debug("close: already closed"):this._debug("close enqueued: no ws instance")},e.prototype.reconnect=function(e,t){this._shouldReconnect=!0,this._closeCalled=!1,this._retryCount=-1,this._ws&&this._ws.readyState!==this.CLOSED?(this._disconnect(e,t),this._connect()):this._connect()},e.prototype.send=function(e){if(this._ws&&this._ws.readyState===this.OPEN)this._debug("send",e),this._ws.send(e);else{var t=this._options.maxEnqueuedMessages,n=void 0===t?g.maxEnqueuedMessages:t;this._messageQueue.length<n&&(this._debug("enqueue",e),this._messageQueue.push(e))}},e.prototype.addEventListener=function(e,t){this._listeners[e]&&this._listeners[e].push(t)},e.prototype.dispatchEvent=function(e){var t,n,r=this._listeners[e.type];if(r)try{for(var o=function(e){var t="function"==typeof Symbol&&e[Symbol.iterator],n=0;return t?t.call(e):{next:function(){return e&&n>=e.length&&(e=void 0),{value:e&&e[n++],done:!e}}}}(r),i=o.next();!i.done;i=o.next()){var s=i.value;this._callEventListener(e,s)}}catch(e){t={error:e}}finally{try{i&&!i.done&&(n=o.return)&&n.call(o)}finally{if(t)throw t.error}}return!0},e.prototype.removeEventListener=function(e,t){this._listeners[e]&&(this._listeners[e]=this._listeners[e].filter((function(e){return e!==t})))},e.prototype._debug=function(){for(var e=[],t=0;t<arguments.length;t++)e[t]=arguments[t];this._options.debug&&console.log.apply(console,function(){for(var e=[],t=0;t<arguments.length;t++)e=e.concat(A(arguments[t]));return e}(["RWS>"],e))},e.prototype._getNextDelay=function(){var e=this._options,t=e.reconnectionDelayGrowFactor,n=void 0===t?g.reconnectionDelayGrowFactor:t,r=e.minReconnectionDelay,o=void 0===r?g.minReconnectionDelay:r,i=e.maxReconnectionDelay,s=void 0===i?g.maxReconnectionDelay:i,a=0;return this._retryCount>0&&(a=o*Math.pow(n,this._retryCount-1))>s&&(a=s),this._debug("next delay",a),a},e.prototype._wait=function(){var e=this;return new Promise((function(t){setTimeout(t,e._getNextDelay())}))},e.prototype._getNextUrl=function(e){if("string"==typeof e)return Promise.resolve(e);if("function"==typeof e){var t=e();if("string"==typeof t)return Promise.resolve(t);if(t.then)return t}throw Error("Invalid URL")},e.prototype._connect=function(){var e=this;if(!this._connectLock&&this._shouldReconnect){this._connectLock=!0;var t=this._options,n=t.maxRetries,r=void 0===n?g.maxRetries:n,o=t.connectionTimeout,i=void 0===o?g.connectionTimeout:o,s=t.WebSocket,a=void 0===s?m():s;if(this._retryCount>=r)this._debug("max retries reached",this._retryCount,">=",r);else{if(this._retryCount++,this._debug("connect",this._retryCount),this._removeListeners(),void 0===(c=a)||!c||2!==c.CLOSING)throw Error("No valid WebSocket class provided");var c;this._wait().then((function(){return e._getNextUrl(e._url)})).then((function(t){e._closeCalled||(e._debug("connect",{url:t,protocols:e._protocols}),e._ws=e._protocols?new a(t,e._protocols):new a(t),e._ws.binaryType=e._binaryType,e._connectLock=!1,e._addListeners(),e._connectTimeout=setTimeout((function(){return e._handleTimeout()}),i))}))}}},e.prototype._handleTimeout=function(){this._debug("timeout event"),this._handleError(new v(Error("TIMEOUT"),this))},e.prototype._disconnect=function(e,t){if(void 0===e&&(e=1e3),this._clearTimeouts(),this._ws){this._removeListeners();try{this._ws.close(e,t),this._handleClose(new y(e,t,this))}catch(e){}}},e.prototype._acceptOpen=function(){this._debug("accept open"),this._retryCount=0},e.prototype._callEventListener=function(e,t){"handleEvent"in t?t.handleEvent(e):t(e)},e.prototype._removeListeners=function(){this._ws&&(this._debug("removeListeners"),this._ws.removeEventListener("open",this._handleOpen),this._ws.removeEventListener("close",this._handleClose),this._ws.removeEventListener("message",this._handleMessage),this._ws.removeEventListener("error",this._handleError))},e.prototype._addListeners=function(){this._ws&&(this._debug("addListeners"),this._ws.addEventListener("open",this._handleOpen),this._ws.addEventListener("close",this._handleClose),this._ws.addEventListener("message",this._handleMessage),this._ws.addEventListener("error",this._handleError))},e.prototype._clearTimeouts=function(){clearTimeout(this._connectTimeout),clearTimeout(this._uptimeTimeout)},e}();function w(e,t){var n=localStorage.getItem(t)||e;return{set:function(e){n=e,localStorage.setItem(t,e)},get:function(e){return e?localStorage.getItem(t):n},remove:function(){n=void 0,localStorage.removeItem(t)},clear:function(){localStorage.clear()}}}var O=w("eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJ1c2VySWQiOiIxIiwiZW52IjoiZGV2IiwiaWF0IjoxNjc5NjI3OTUwLCJleHAiOjE3MTExNjM5NTB9.YSNUJXFRFrSGYQ-0sNPekEn6KhRB7cSc9XKEP4lHUEk","__tk__"),E=w("","__info__");w("","__first__");var C=["payment/status"];function T(e){var i,s=e.api,a=e.id;return i={url:"".concat(s).concat("","/question/").concat(a),method:"get"},r(void 0,void 0,void 0,(function(){var e,r,s,a,c,u,l,f,p,d,A;return o(this,(function(o){switch(o.label){case 0:e=i.url,r=i.data,s=void 0===r?{}:r,a=i.headers,c=void 0===a?{}:a,u=i.method,f=["GET","DELETE"].indexOf((l=void 0===u?"get":u).toUpperCase())>=0,o.label=1;case 1:return o.trys.push([1,3,,4]),[4,t({url:e,data:f?void 0:s,params:f?s:void 0,method:l,headers:n(n({},c),{Authorization:O.get()})})];case 2:if(p=o.sent(),C.some((function(t){return e.startsWith(t)})))return[2,p.data];if(200!==p.status||!p.data||200!==p.data.code)throw(d=new Error).response=p,d;return console.log("request success:",e,p),[2,p.data];case 3:return A=o.sent(),console.log("request failed:",i,A),A.response&&A.response.data&&401===A.response.data.code&&O.remove(),A.response&&A.response.data&&A.response.data.error?[2,{code:-1,msg:A.response.data.error}]:[2,{code:-1,msg:A.message}];case 4:return[2]}}))}))}var N={},S=function(){var e=document.getSelection();if(!e.rangeCount)return function(){};for(var t=document.activeElement,n=[],r=0;r<e.rangeCount;r++)n.push(e.getRangeAt(r));switch(t.tagName.toUpperCase()){case"INPUT":case"TEXTAREA":t.blur();break;default:t=null}return e.removeAllRanges(),function(){"Caret"===e.type&&e.removeAllRanges(),e.rangeCount||n.forEach((function(t){e.addRange(t)})),t&&t.focus()}},P={"text/plain":"Text","text/html":"Url",default:"Text"};var j=function(e,t){var n,r,o,i,s,a,c=!1;t||(t={}),n=t.debug||!1;try{if(o=S(),i=document.createRange(),s=document.getSelection(),(a=document.createElement("span")).textContent=e,a.ariaHidden="true",a.style.all="unset",a.style.position="fixed",a.style.top=0,a.style.clip="rect(0, 0, 0, 0)",a.style.whiteSpace="pre",a.style.webkitUserSelect="text",a.style.MozUserSelect="text",a.style.msUserSelect="text",a.style.userSelect="text",a.addEventListener("copy",(function(r){if(r.stopPropagation(),t.format)if(r.preventDefault(),void 0===r.clipboardData){n&&console.warn("unable to use e.clipboardData"),n&&console.warn("trying IE specific stuff"),window.clipboardData.clearData();var o=P[t.format]||P.default;window.clipboardData.setData(o,e)}else r.clipboardData.clearData(),r.clipboardData.setData(t.format,e);t.onCopy&&(r.preventDefault(),t.onCopy(r.clipboardData))})),document.body.appendChild(a),i.selectNodeContents(a),s.addRange(i),!document.execCommand("copy"))throw new Error("copy command was unsuccessful");c=!0}catch(o){n&&console.error("unable to copy using execCommand: ",o),n&&console.warn("trying IE specific stuff");try{window.clipboardData.setData(t.format||"text",e),t.onCopy&&t.onCopy(window.clipboardData),c=!0}catch(o){n&&console.error("unable to copy using clipboardData: ",o),n&&console.error("falling back to prompt"),r=function(e){var t=(/mac os x/i.test(navigator.userAgent)?"⌘":"Ctrl")+"+C";return e.replace(/#{\s*key\s*}/g,t)}("message"in t?t.message:"Copy to clipboard: #{key}, Enter"),window.prompt(r,e)}}finally{s&&("function"==typeof s.removeRange?s.removeRange(i):s.removeAllRanges()),a&&document.body.removeChild(a),o()}return c};function R(e){return R="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(e){return typeof e}:function(e){return e&&"function"==typeof Symbol&&e.constructor===Symbol&&e!==Symbol.prototype?"symbol":typeof e},R(e)}Object.defineProperty(N,"__esModule",{value:!0}),N.CopyToClipboard=void 0;var L=k(e),x=k(j),D=["text","onCopy","options","children"];function k(e){return e&&e.__esModule?e:{default:e}}function U(e,t){var n=Object.keys(e);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(e);t&&(r=r.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),n.push.apply(n,r)}return n}function z(e){for(var t=1;t<arguments.length;t++){var n=null!=arguments[t]?arguments[t]:{};t%2?U(Object(n),!0).forEach((function(t){X(e,t,n[t])})):Object.getOwnPropertyDescriptors?Object.defineProperties(e,Object.getOwnPropertyDescriptors(n)):U(Object(n)).forEach((function(t){Object.defineProperty(e,t,Object.getOwnPropertyDescriptor(n,t))}))}return e}function H(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},i=Object.keys(e);for(r=0;r<i.length;r++)n=i[r],t.indexOf(n)>=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var i=Object.getOwnPropertySymbols(e);for(r=0;r<i.length;r++)n=i[r],t.indexOf(n)>=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}function B(e,t){for(var n=0;n<t.length;n++){var r=t[n];r.enumerable=r.enumerable||!1,r.configurable=!0,"value"in r&&(r.writable=!0),Object.defineProperty(e,r.key,r)}}function I(e,t){return I=Object.setPrototypeOf||function(e,t){return e.__proto__=t,e},I(e,t)}function K(e){var t=function(){if("undefined"==typeof Reflect||!Reflect.construct)return!1;if(Reflect.construct.sham)return!1;if("function"==typeof Proxy)return!0;try{return Boolean.prototype.valueOf.call(Reflect.construct(Boolean,[],(function(){}))),!0}catch(e){return!1}}();return function(){var n,r=J(e);if(t){var o=J(this).constructor;n=Reflect.construct(r,arguments,o)}else n=r.apply(this,arguments);return function(e,t){if(t&&("object"===R(t)||"function"==typeof t))return t;if(void 0!==t)throw new TypeError("Derived constructors may only return object or undefined");return F(e)}(this,n)}}function F(e){if(void 0===e)throw new ReferenceError("this hasn't been initialised - super() hasn't been called");return e}function J(e){return J=Object.setPrototypeOf?Object.getPrototypeOf:function(e){return e.__proto__||Object.getPrototypeOf(e)},J(e)}function X(e,t,n){return t in e?Object.defineProperty(e,t,{value:n,enumerable:!0,configurable:!0,writable:!0}):e[t]=n,e}var G=function(e){!function(e,t){if("function"!=typeof t&&null!==t)throw new TypeError("Super expression must either be null or a function");e.prototype=Object.create(t&&t.prototype,{constructor:{value:e,writable:!0,configurable:!0}}),Object.defineProperty(e,"prototype",{writable:!1}),t&&I(e,t)}(i,e);var t,n,r,o=K(i);function i(){var e;!function(e,t){if(!(e instanceof t))throw new TypeError("Cannot call a class as a function")}(this,i);for(var t=arguments.length,n=new Array(t),r=0;r<t;r++)n[r]=arguments[r];return X(F(e=o.call.apply(o,[this].concat(n))),"onClick",(function(t){var n=e.props,r=n.text,o=n.onCopy,i=n.children,s=n.options,a=L.default.Children.only(i),c=(0,x.default)(r,s);o&&o(r,c),a&&a.props&&"function"==typeof a.props.onClick&&a.props.onClick(t)})),e}return t=i,(n=[{key:"render",value:function(){var e=this.props;e.text,e.onCopy,e.options;var t=e.children,n=H(e,D),r=L.default.Children.only(t);return L.default.cloneElement(r,z(z({},n),{},{onClick:this.onClick}))}}])&&B(t.prototype,n),r&&B(t,r),Object.defineProperty(t,"prototype",{writable:!1}),i}(L.default.PureComponent);N.CopyToClipboard=G,X(G,"defaultProps",{onCopy:void 0,options:void 0});var W=N.CopyToClipboard;W.CopyToClipboard=W;var q=W,Q="",Y=function(t){var n=t.data,r=t.className,o=t.onCopy,i={};try{i=JSON.parse(E.get()||"")}catch(e){i={userProfile:"",userName:"小蜜蜂"}}return e.createElement("div",{className:c("question-wrap",r)},e.createElement("div",{className:"question-box"},e.createElement("div",{className:"question-avatar"},e.createElement("img",{src:null==i?void 0:i.userProfile,className:"question-avatar-img"})),e.createElement("div",{className:"question-right"},e.createElement("div",{className:"question-content-box"},e.createElement("div",{className:"question-name"},null==i?void 0:i.userName),e.createElement("div",{className:"question-content"},n)),e.createElement(q.CopyToClipboard,{text:n,onCopy:function(){o&&o("question")}},e.createElement("div",{className:"question-icon-box"},e.createElement("img",{className:"question-icon",src:Q}))))))},V=function(t){var n=t.data,r=void 0===n?"":n,o=t.className,i=t.isDone,s=void 0===i||i,a=t.status,u=t.onCopy;return e.createElement("div",{className:c("answer-wrap",o)},e.createElement("div",{className:"answer-box"},e.createElement("div",{className:"answer-avatar"},e.createElement("img",{src:"",className:"answer-avatar-img"})),e.createElement("div",{className:"answer-content"},e.createElement("div",{className:"answer-text-box"},e.createElement("div",{className:"answer-text"},r?r.trim():"",!s&&e.createElement("div",{className:c("answer-cursor",{1:"gray",2:"black",3:"green",4:"red",5:"undefi"}[a||5])}))),e.createElement(q.CopyToClipboard,{text:r,onCopy:function(){u&&u("answer")}},e.createElement("div",{className:"question-icon-box"},e.createElement("img",{className:"question-icon",src:Q}))))))},M=function(t){var n=t.data,r=t.className,o=t.onCopy,i=t.domScrollFn,s=t.onGetScrollSwicth,a=t.Question,u=t.Answer,l=n.answer,f=n.question,p=n.isDone,d=n.status;return e.useEffect((function(){s()&&i()}),[l]),e.createElement("div",{id:null==n?void 0:n.id,className:c("chat-wrap",r)},a?e.createElement(a,{data:f}):e.createElement(Y,{data:f,onCopy:o}),u?e.createElement(u,{data:l,isDone:p,status:d}):e.createElement(V,{data:l,isDone:p,status:d,onCopy:o}))},Z="NET_OFFLINE",_="SERVICE_NOT_RESPONDING",$="INSUFFICIENT_BALANCE",ee="WS_ERROR",te=e.forwardRef((function(t,n){var s=t.className,a=t.userId,u=t.onError,l=t.onCopy,p=t.Question,d=t.Answer,A=t.baseConfig,h=e.useState([]),v=h[0],y=h[1],m=e.useState(""),g=m[0],w=m[1],E=e.useRef(null),C=e.useRef(!0),N=e.useRef(null),S=e.useRef([]),P=e.useRef(""),j=e.useRef(null),R=e.useRef({}),L=e.useRef(null),x=e.useRef(null),D=e.useRef(!1),k=e.useRef(0),U=e.useRef(null),z=e.useRef(""),H=A.httpAPI,B=void 0===H?"":H,I=A.wsAPI,K=void 0===I?"":I,F=A.waitTimer,J=void 0===F?5:F,X=A.answeringTimer,G=void 0===X?3:X,W=A.questionFetchCountMax,q=void 0===W?10:W,Q=A.socketHeartbeat,Y=void 0===Q?30:Q,V=A.questionFetchTimer,te=void 0===V?3:V,ne=A.httpError,re=void 0===ne?function(){}:ne;e.useImperativeHandle(n,(function(){return{getAllData:function(){return v}}}));var oe=function(){if(C.current&&E.current){var e=E.current;e.scrollTop=e.scrollHeight}},ie=function(e,t){if("question"!==t)if("status"!==t){var n=e.id,r=e.answer,o=e.isDone,s=e.status;y((function(e){return e.map((function(e){return(null==e?void 0:e.id)===n?(e.answer=r,e.isDone=o,e.status=s,e):e}))}))}else{var a=e.id,c=e.isDone,u=e.status;y((function(e){return e.map((function(e){return(null==e?void 0:e.id)===a?(e.isDone=c,e.status=u,e):e}))}))}else y((function(t){return i(i([],t,!0),[e],!1)}))},se=function(){g&&g.trim()?O.get()?navigator.onLine?(R.current={},N.current=function(e){var t=e.wsAPI,n=e.successFn,r=e.errorFn,o=new b("".concat(t,"?token=").concat(O.get()));return o.addEventListener("message",(function(e){var t=e.data;try{var o=JSON.parse(t);n(o)}catch(e){r("socket JSON.parse error ~")}})),o}({wsAPI:K,successFn:function(e){var t,n,r=e.op,o=e.webId,i=e.question,s=e.timestamp,a=e.answer,c=e.index,l=e.message,f=e.isDone,p=e.status;return"error"===r?(S.current=[],4201==+l?void u($):void u(ee,l)):"status"===r?(R.current={isDone:f,status:p},1===p?void clearTimeout(L.current):2===p?void(x.current=setTimeout(ae,1e3*G)):void(3!==p&&4!==p||(D.current||clearTimeout(x.current),N.current&&N.current.close(),R.current={},ie({id:o,isDone:f,status:p,question:"",answer:"",timestamp:0},"status")))):"answer"===r?(S.current[c]=a,ie({id:o,question:i,answer:S.current.filter(Boolean).join(""),timestamp:s,isDone:null===(t=R.current)||void 0===t?void 0:t.isDone,status:null===(n=R.current)||void 0===n?void 0:n.status},"answer"),void(D.current||(clearTimeout(x.current),x.current=setTimeout(ae,1e3*G)))):void 0},errorFn:function(e){}}),N.current.addEventListener("open",(function(){!function(e){var t,n,r;if(N.current){var o=f(),i=a?{op:"question",webId:o,question:e,userId:a}:{op:"question",webId:o,question:e},s=JSON.stringify(i);null===(t=N.current)||void 0===t||t.send(s),L.current=setTimeout((function(){u(_),clearTimeout(L.current)}),1e3*J),D.current=!1,S.current=[],P.current=o,ie({id:o,question:g,answer:"",timestamp:+new Date,isDone:null===(n=R.current)||void 0===n?void 0:n.isDone,status:null===(r=R.current)||void 0===r?void 0:r.status},"question")}}(g?g.trim():""),w(""),clearInterval(j.current),j.current=setInterval((function(){var e;null===(e=N.current)||void 0===e||e.send("ping")}),1e3*Y)})),N.current.addEventListener("close",(function(e){return ce()})),N.current.addEventListener("error",(function(e){return ce()})),N.current):u(Z):u("NOT_LOGIN"):u("INPUT_EMPTY")};var ae=function(){D.current=!0;var e=P.current;if(e){k.current=0;var t=function(){return r(void 0,void 0,void 0,(function(){var n,r,i;return o(this,(function(o){switch(o.label){case 0:return k.current=k.current+1,[4,T({api:B,id:e})];case 1:return 200===(n=o.sent()).code?null==(r=null===(i=null==n?void 0:n.data)||void 0===i?void 0:i.answer)?(console.log("questionFetchCount.current",k.current),k.current>=q?(u("QUESTION_FETCH_MAX"),[2]):(clearTimeout(U.current),U.current=setTimeout((function(){t()}),1e3*te),[2])):(N.current&&(N.current.close(),console.log("🚀 ~ file: index.tsx:184 ~ onQuestionFetch ~ close:")),ie({id:e,question:"",answer:r,timestamp:0},"answer"),[2]):(re&&re(n.msg),[2])}}))}))};t()}};var ce=function(e,t){clearInterval(j.current)};function ue(){u(Z)}var le=function(){j.current&&clearInterval(j.current),y([]),w(""),window.removeEventListener("offline",ue)};return e.useEffect((function(){return w(""),y([{id:f(),question:"Hello",answer:"你好,我是人工智能大师,什么问题都能回答,快来和我聊天吧!",timestamp:1}]),window.addEventListener("offline",ue),le}),[]),e.createElement("div",{className:c(["index",s])},e.createElement("div",{className:"index-list",ref:E},v.map((function(t,n){return e.createElement(M,{key:t.id+n,data:t,onCopy:l,domScrollFn:oe,onGetScrollSwicth:function(){return C.current},Question:p,Answer:d})}))),e.createElement("div",{className:"input-bottom"},e.createElement("div",{className:"index-input-box"},e.createElement("input",{placeholder:"试试打字和我聊天吧",className:"index-input",value:g,onChange:function(e){w(e.target.value)},onKeyDown:function(e){"Enter"===e.key&&(z.current=g,se())}}),e.createElement("div",{className:c("index-input-right",{active:!!g.length})},e.createElement("img",{src:"