开启辅助访问 切换到宽版

精易论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

用微信号发送消息登录论坛

新人指南 邀请好友注册 - 我关注人的新帖 教你赚取精币 - 每日签到


求职/招聘- 论坛接单- 开发者大厅

论坛版规 总版规 - 建议/投诉 - 应聘版主 - 精华帖总集 积分说明 - 禁言标准 - 有奖举报

查看: 2280|回复: 7
收起左侧

[技术专题] ChatGPT中文版源码

[复制链接]
发表于 2023-5-15 13:03:34 | 显示全部楼层 |阅读模式   云南省昆明市
ChatGPT最近很火爆大家都知道吧,今天废话不多说 直接给大家带来一个ChatGPT中文版的源码

先对整体进行一个介绍,这套源码界面很有科技感,其次是功能方面有专门的指令输入框,让你可以舒舒服服的玩转你手中的prompts

其次有黑夜和白天两个模式以及回到顶部功能

下面废话不多说 直接上代码

由于代码太多 我直接放前端页面的代码

代码是基于nodejs写的

下面是header文件

import Logo from './Logo.astro'
import Themetoggle from './Themetoggle.astro'

<header>






CTGPT.
CN

基于 OpenAI API (gpt-3.5-turbo)开发.




下面是footer文件





border-b border-slate border-none hover:border-dashed
target="_blank"

安卓端下载
|

border-b border-slate border-none hover:border-dashed
target="_blank"

苹果端下载(safari打开安装需要去设置描述文件安装)








下面是问题框代码

import type { ChatMessage } from '@/types'
import { createSignal, Index, Show } from 'solid-js'
import IconClear from './icons/Clear'
import MessageItem from './MessageItem'
import SystemRoleSettings from './SystemRoleSettings'
import _ from 'lodash'
import { generateSignature } from '@/utils/auth'

export default () => {
let inputRef: HTMLTextAreaElement
const [currentSystemRoleSettings, setCurrentSystemRoleSettings] = createSignal('')
const [systemRoleEditing, setSystemRoleEditing] = createSignal(false)
const [messageList, setMessageList] = createSignal([])
const [currentAssistantMessage, setCurrentAssistantMessage] = createSignal('')
const [loading, setLoading] = createSignal(false)
const [controller, setController] = createSignal(null)

const handleButtonClick = async () => {
const inputValue = inputRef.value
if (!inputValue) {
return
}
// @ts-ignore
if (window?.umami) umami.trackEvent('chatgenerate')
inputRef.value = ''
setMessageList([
...messageList(),
{
role: 'user',
content: inputValue,
},
])
requestWithLatestMessage()
}
const throttle =
.throttle(function(){
window.scrollTo({top: document.body.scrollHeight, behavior: 'smooth'})
}, 300, {
leading: true,
trailing: false
})
const requestWithLatestMessage = async () => {
setLoading(true)
setCurrentAssistantMessage('')
const storagePassword = localStorage.getItem('pass')
try {
const controller = new AbortController()
setController(controller)
const requestMessageList = [...messageList()]
if (currentSystemRoleSettings()) {
requestMessageList.unshift({
role: 'system',
content: currentSystemRoleSettings(),
})
}
const timestamp = Date.now()
const response = await fetch('/api/generate', {
method: 'POST',
body: JSON.stringify({
messages: requestMessageList,
time: timestamp,
pass: storagePassword,
sign: await generateSignature({
t: timestamp,
m: requestMessageList?.[requestMessageList.length - 1]?.content || '',
}),
}),
signal: controller.signal,
})
if (!response.ok) {
throw new Error(response.statusText)
}
const data = response.body
if (!data) {
throw new Error('No data')
}
const reader = data.getReader()
const decoder = new TextDecoder('utf-8')
let done = false

  while (!done) {
    const { value, done: readerDone } = await reader.read()
    if (value) {
      let char = decoder.decode(value)
      if (char === '\n' && currentAssistantMessage().endsWith('\n')) {
        continue
      }
      if (char) {
        setCurrentAssistantMessage(currentAssistantMessage() + char)
      }
      throttle()
    }
    done = readerDone
  }
} catch (e) {
  console.error(e)
  setLoading(false)
  setController(null)
  return
}
archiveCurrentMessage()

}

const archiveCurrentMessage = () => {
if (currentAssistantMessage()) {
setMessageList([
...messageList(),
{
role: 'assistant',
content: currentAssistantMessage(),
},
])
setCurrentAssistantMessage('')
setLoading(false)
setController(null)
inputRef.focus()
}
}

const clear = () => {
inputRef.value = ''
inputRef.style.height = 'auto';
setMessageList([])
setCurrentAssistantMessage('')
setCurrentSystemRoleSettings('')
}

const stopStreamFetch = () => {
if (controller()) {
controller().abort()
archiveCurrentMessage()
}
}

const retryLastFetch = () => {
if (messageList().length > 0) {
const lastMessage = messageList()[messageList().length - 1]
console.log(lastMessage)
if (lastMessage.role === 'assistant') {
setMessageList(messageList().slice(0, -1))
requestWithLatestMessage()
}
}
}

const handleKeydown = (e: KeyboardEvent) => {
if (e.isComposing || e.shiftKey) {
return
}
if (e.key === 'Enter') {
handleButtonClick()
}
}

return (


canEdit={() => messageList().length === 0}
systemRoleEditing={systemRoleEditing}
setSystemRoleEditing={setSystemRoleEditing}
currentSystemRoleSettings={currentSystemRoleSettings}
setCurrentSystemRoleSettings={setCurrentSystemRoleSettings}
/>

{(message, index) => (
role={message().role}
message={message().content}
showRetry={() => (message().role === 'assistant' && index === messageList().length - 1)}
onRetry={retryLastFetch}
/>
)}

{currentAssistantMessage() && (
role="assistant"
message={currentAssistantMessage}
/>
)}
when={!loading()}
fallback={() => (

AI正在思考中...
停止


)}


ref={inputRef!}
disabled={systemRoleEditing()}
onKeyDown={handleKeydown}
placeholder="问些问题吧..."
autocomplete="off"
autofocus
onInput={() => {
inputRef.style.height = 'auto';
inputRef.style.height = inputRef.scrollHeight + 'px';
}}
rows="1"
w-full
px-3 py-3
min-h-12
max-h-36
rounded-sm
bg-slate
bg-op-15
resize-none
focus:bg-op-20
focus:ring-0
focus:outline-none
placeholder:op-50
dark="placeholder:op-30"
scroll-pa-8px
/>





)
}



结帖率:88% (36/41)

签到天数: 2 天

发表于 2024-6-2 05:32:51 | 显示全部楼层   云南省红河哈尼族彝族自治州
66666666666666666
回复 支持 反对

使用道具 举报

结帖率:100% (13/13)

签到天数: 3 天

发表于 2023-10-25 09:24:23 | 显示全部楼层   广东省中山市
我看到了一个按钮Send
回复 支持 反对

使用道具 举报

发表于 2023-8-28 10:52:45 | 显示全部楼层   安徽省亳州市
回复 支持 反对

使用道具 举报

结帖率:100% (1/1)
发表于 2023-8-1 20:18:35 | 显示全部楼层   江西省景德镇市
感谢分享,很给力!~
回复 支持 反对

使用道具 举报

发表于 2023-6-6 19:26:23 | 显示全部楼层   广东省广州市
感谢感谢,感谢感谢为了获得积分
回复 支持 反对

使用道具 举报

签到天数: 12 天

发表于 2023-5-15 15:01:08 | 显示全部楼层   江西省吉安市
玩玩这个http://gptapi.cc
回复 支持 反对

使用道具 举报

结帖率:100% (6/6)

签到天数: 16 天

发表于 2023-5-15 13:09:51 | 显示全部楼层   河南省郑州市
都被玩烂了
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 注册

本版积分规则 致发广告者

发布主题 收藏帖子 返回列表

sitemap| 易语言源码| 易语言教程| 易语言论坛| 易语言模块| 手机版| 广告投放| 精易论坛
拒绝任何人以任何形式在本论坛发表与中华人民共和国法律相抵触的言论,本站内容均为会员发表,并不代表精易立场!
论坛帖子内容仅用于技术交流学习和研究的目的,严禁用于非法目的,否则造成一切后果自负!如帖子内容侵害到你的权益,请联系我们!
防范网络诈骗,远离网络犯罪 违法和不良信息举报电话0663-3422125,QQ: 793400750,邮箱:wp@125.la
网站简介:精易论坛成立于2009年,是一个程序设计学习交流技术论坛,隶属于揭阳市揭东区精易科技有限公司所有。
Powered by Discuz! X3.4 揭阳市揭东区精易科技有限公司 ( 粤ICP备12094385号-1) 粤公网安备 44522102000125 增值电信业务经营许可证 粤B2-20192173

快速回复 返回顶部 返回列表