From 91e6a1f5cc55a24cc53dc09b44d25da21075a71a Mon Sep 17 00:00:00 2001 From: canwdev Date: Fri, 3 Jan 2025 14:19:13 +0800 Subject: [PATCH] update --- public/custom-configs/AICharacters.json | 74 ------------------- .../QuickLaunchCustomPlugins.json | 10 --- 2 files changed, 84 deletions(-) delete mode 100644 public/custom-configs/AICharacters.json delete mode 100644 public/custom-configs/QuickLaunchCustomPlugins.json diff --git a/public/custom-configs/AICharacters.json b/public/custom-configs/AICharacters.json deleted file mode 100644 index a6e297b..0000000 --- a/public/custom-configs/AICharacters.json +++ /dev/null @@ -1,74 +0,0 @@ -[ - { - "id": "default", - "name": "ChatGPT", - "desc": "", - "avatar": "", - "model": "gpt-4o", - "systemPrompt": "你是一个 TypeScript 专家,使用现代化的ES6语法,要求在项目中实现模块化、完善的注释、类型注解、async-await(可选)、箭头函数、解构赋值等特性,并确保代码的可读性和性能优化。\n\n注意:用户也是专业开发人员,因此回答时只提供代码、使用示例和注释,不需要额外的解释,除非用户让你解释。" - }, - { - "id": "fehelper", - "name": "Web 开发助手", - "desc": "", - "avatar": "", - "model": "gpt-4o", - "systemPrompt": "你是一位专业的 Web 开发者,精通 HTML5/CSS3/Sass,JavaScript/TypeScript/Node.js,并能够理解复杂的设计要求,帮助开发者实现 HTML/SCSS 样式的编写,JS/TS 代码功能实现,或Node.js 功能的实现。\n" - }, - { - "id": "vue_helper", - "name": "Vue开发助手", - "desc": "", - "avatar": "", - "model": "gpt-4o", - "systemPrompt": "你是一个 Vue 专家,熟练使用 Vue 3 和 Vue 2。你能够帮助我解决 Vue 开发中的各种问题,包括SFC组件开发、渲染函数、Pinia/VueX状态管理、路由配置和性能优化。请为我提供最佳实践、代码示例、代码注释,不需要提供额外解释。注意:\n- Vue3 使用 script setup 语法\n- 使用 div, span 等无自带样式标签来实现HTML模板,因为要考虑到未来跨框架的可移植性,可以使用原生 input,button 等元素\n- 给组件的根div元素定义一个类名,类名为param-case的组件名\n- 样式使用 scoped scss 语言,scss使用嵌套类名\n- 使用现代化 ES6 语法和 TypeScript" - }, - { - "id": "translator", - "name": "翻译助手", - "desc": "", - "avatar": "", - "model": "gpt-3.5-turbo", - "systemPrompt": "用户可以输入任意语言的内容。如果未指定翻译目标语言,则默认为翻译成英语,如果用户输入的是英语,则翻译成中文。系统仅返回翻译后的内容。" - }, - { - "id": "hsh", - "name": "前端页面开发者", - "desc": "", - "avatar": "", - "model": "gpt-3.5-turbo", - "systemPrompt": "背景故事:\n你是一位专业的 Web 前端页面开发者,精通 HTML5 和 Sass,并能够理解复杂的设计要求,帮助开发者实现 HTML 模板和 SCSS 样式的编写。\n\n技能:\n- 使用 div, span 等无自带样式标签来实现HTML模板,不要使用h1~h5, p, ul, li 等带样式元素,因为要考虑到未来跨框架的可移植性\n- 给元素起一些语义化类名,并在SCSS里**嵌套**使用,保证类名的通用性\n- 不要使用 width 和 height 固定尺寸,使用 padding、margin 等实现自适应布局\n- 生成灵活的布局,使用如 flex、grid 等。\n- 编写响应式媒体查询,适配移动端设备。\n- 控制字体样式,包括字体大小、粗细、字间距等。\n- (可选)生成状态变化伪类,例如 hover、focus、active 等。\n\n注意:不提供具体的示例使用,不提供解释,只输出HTML模板和SCSS代码\n" - }, - { - "id": "api_jie_kou_dai_ma_s", - "name": "API接口代码生成器", - "desc": "", - "avatar": "", - "model": "gpt-3.5-turbo", - "systemPrompt": "根据以下信息自动生成ts接口代码。\n\n用户输入信息为:\n```\nPOST\n/dms/v1/devices/firmwares/product-types/info-filtering\n对接\n(管理后台)分页查询产品信息列表\n```\n\n生成代码:\n```typescript\n// (管理后台)分页查询产品信息列表\nexport const dmsGetProductTypeList = (params = {}) => {\n return serviceDms.post('/v1/devices/firmwares/product-types/info-filtering', params)\n}\n```" - }, - { - "id": "prompt_helper", - "name": "提示词助手", - "desc": "帮用户写提示词", - "avatar": "", - "model": "gpt-4o", - "systemPrompt": "你是一个AI提示词助手,帮助用户写AI提示词,请使用简明、准确的语法根据用户需求写AI提示词。" - }, - { - "id": "docker_pro", - "name": "Docker专家", - "desc": "", - "avatar": "", - "model": "gpt-3.5-turbo", - "systemPrompt": "你是一位Docker专家,帮助用户编写Dockerfile,回答用户的问题,提供解决方案和最佳实践,指导用户如何优化和调试容器化应用。" - } -] diff --git a/public/custom-configs/QuickLaunchCustomPlugins.json b/public/custom-configs/QuickLaunchCustomPlugins.json deleted file mode 100644 index 8c77f7c..0000000 --- a/public/custom-configs/QuickLaunchCustomPlugins.json +++ /dev/null @@ -1,10 +0,0 @@ -[ - { - "name": "自定义文本转换", - "code": "const { addPlugin, copy } = window.$qlUtils\r\n\r\nconst labelArr = [\r\n {\r\n reg: /^阿拉伯语:|^Arabic:|^ar:/,\r\n name: 'عربى',\r\n iso: 'ar-AE',\r\n mLocale: 'ar',\r\n },\r\n {\r\n reg: /^德:|^德语:|^German:|^de:/,\r\n name: 'Deutsch',\r\n iso: 'de-DE',\r\n mLocale: 'de',\r\n },\r\n {\r\n reg: /^英:|^英语:|^English:|^en:/,\r\n name: 'English',\r\n iso: 'en-US',\r\n mLocale: 'en',\r\n },\r\n {\r\n reg: /^西:|^西语:|^西班牙语:|^Spanish:|^es:/,\r\n name: 'Español',\r\n iso: 'es-ES',\r\n mLocale: 'es',\r\n },\r\n {\r\n reg: /^法:|^法语:|^French:|^fr:/,\r\n name: 'Français',\r\n iso: 'fr-FR',\r\n mLocale: 'fr',\r\n },\r\n {\r\n reg: /^意:|^意大利语:|^Italian:|^it:/,\r\n name: 'Italiano',\r\n iso: 'it-IT',\r\n mLocale: 'it',\r\n },\r\n {\r\n reg: /^日:|^日语:|^Japanese:|^jp:/,\r\n name: '日本語',\r\n iso: 'ja-JP',\r\n mLocale: 'jp',\r\n },\r\n {\r\n reg: /^韩:|^韩语:|^Korean:|^kr:/,\r\n name: '한국어',\r\n iso: 'ko-KR',\r\n mLocale: 'kr',\r\n },\r\n {\r\n reg: /^简:|^中文:|^简中:|^Chinese Simplified:/,\r\n name: '简体中文',\r\n iso: 'zh-CN',\r\n mLocale: 'cn',\r\n },\r\n {\r\n reg: /^繁:|^繁体中文:|^繁中:|^Traditional Chinese:/,\r\n name: '繁體中文',\r\n iso: 'zh-TW',\r\n mLocale: 'zh',\r\n },\r\n]\r\nfunction getLocaleLabel(rawText) {\r\n if (!rawText) {\r\n return null\r\n }\r\n for (let i = 0; i < labelArr.length; i++) {\r\n const { reg, iso } = labelArr[i]\r\n const result = reg.exec(rawText)\r\n // console.log(result)\r\n if (result) {\r\n return {\r\n label: iso,\r\n value: rawText.slice(result[0].length, rawText.length).trim(),\r\n }\r\n }\r\n }\r\n return rawText\r\n}\r\nfunction convertText(text) {\r\n const lines = text.trim().split('\\n')\r\n return lines\r\n .map((line) => {\r\n return getLocaleLabel(line)\r\n })\r\n .filter(Boolean)\r\n}\r\n\r\nfunction convertObject(obj) {\r\n try {\r\n\r\n const result = {}\r\n for (const key in obj) {\r\n let value = obj[key] || ''\r\n\r\n if (typeof value !== 'string') {\r\n throw new Error('输入格式错误,请打开控制台检查')\r\n }\r\n\r\n let locale = key\r\n const f = labelArr.find((l) => l.name === key)\r\n if (f) {\r\n locale = f.mLocale\r\n }\r\n /**\r\n * 删除版本号的说明(用于latest.json的多语言内容)\r\n * 示例输入:\r\n * v8.2.3.1 Updates

1. Support RTSP\r\n * 示例输出:\r\n * 1. Support RTSP\r\n */\r\n value = value.replace(/v\\d+\\.\\d+\\.\\d+\\.\\d+\\s.+\\\\/, '');\r\n result[locale] = value\r\n }\r\n return result\r\n } catch (e) {\r\n console.error(e)\r\n window.$message.error(e.message)\r\n }\r\n}\r\n\r\naddPlugin((valRef) => {\r\n return {\r\n html: '💱 自定义文本转换',\r\n children: [\r\n {\r\n label: '⌨️ 多语言多行文本 -> JSON数组(ISO)',\r\n props: {\r\n onClick: async () => {\r\n\r\n if (!valRef.value) {\r\n window.$message.warning('请打开控制台,查看示例')\r\n console.log(`用途:将粘贴的GPT生成的翻译文案 转换为 标准化(ISO)JSON数组。\r\n\r\n示例输入:\r\nEnglish: Supports Windows® 10 and above, macOS® 11 and above.\r\nSpanish: Compatible con Windows® 10 y versiones superiores, macOS® 11 y versiones superiores.\r\nJapanese: Windows® 10 およびそれ以降、macOS® 11 およびそれ以降に対応しています。\r\n\r\n示例输出:\r\n[\r\n {\r\n \"label\": \"en-US\",\r\n \"value\": \"Supports Windows® 10 and above, macOS® 11 and above.\"\r\n },\r\n {\r\n \"label\": \"es-ES\",\r\n \"value\": \"Compatible con Windows® 10 y versiones superiores, macOS® 11 y versiones superiores.\"\r\n },\r\n {\r\n \"label\": \"ja-JP\",\r\n \"value\": \"Windows® 10 およびそれ以降、macOS® 11 およびそれ以降に対応しています。\"\r\n }\r\n]\r\n`)\r\n return\r\n }\r\n\r\n await copy(convertText(valRef.value), true)\r\n },\r\n },\r\n },\r\n {\r\n label: '⌨️ 多语言JSON对象 -> JSON对象(locale)',\r\n props: {\r\n onClick: async () => {\r\n\r\n if (!valRef.value) {\r\n window.$message.warning('请打开控制台,查看示例')\r\n console.log(`用途:批量格式化excel的更新内容到latest.json 。\r\n\r\n示例输入:\r\n{\r\n \"English\": \"v8.2.3.1 Updates

1. Support RTSP
2. Add album functionality
3. Adapt for OBSBOT Tail Air
4. Upgrade to NDI 6\",\r\n \"简体中文\": \"v8.2.3.1 更新内容

1. 支持 RTSP
2. 新增相册功能
3. 适配寻影 Tail Air
4. 升级至 NDI 6\",\r\n \"日本語\": \"v8.2.3.1 アップデートについて

1. RTSPサポートを追加する
2. アルバム機能を追加する
3. OBSBOT Tail Airに対応する
4. NDI 6にアップグレードする\"\r\n}\r\n\r\n示例输出:\r\n{\r\n \"en\": \"1. Support RTSP
2. Add album functionality
3. Adapt for OBSBOT Tail Air
4. Upgrade to NDI 6\",\r\n \"cn\": \"1. 支持 RTSP
2. 新增相册功能
3. 适配寻影 Tail Air
4. 升级至 NDI 6\",\r\n \"jp\": \"1. RTSPサポートを追加する
2. アルバム機能を追加する
3. OBSBOT Tail Airに対応する
4. NDI 6にアップグレードする\"\r\n}\r\n`)\r\n return\r\n }\r\n\r\n\r\n await copy(convertObject(JSON.parse(valRef.value.trim())), true)\r\n },\r\n },\r\n },\r\n ],\r\n }\r\n}, {\r\n isStaticPlugin: true,\r\n})\r\n" - }, - { - "name": "时间管理大师", - "code": "const { addPlugin, copy, computed, moment } = window.$qlUtils\n\nconst isTimestamp = (val) => {\n val = Number(val)\n const d = new Date(val)\n if (d.getTime() > 0) {\n return d\n }\n return false\n}\n\naddPlugin((valRef) => {\n return {\n html: '⌚ 时间管理大师',\n children: () => {\n return computed(() => {\n const fmt = valRef.value || 'YYYY-MM-DD HH:mm:ss'\n const ts = Date.now()\n const formattedTime = moment(ts).format(fmt)\n\n let timestampToDisplay\n\n const tsDate = isTimestamp(valRef.value)\n if (tsDate) {\n const display = moment(tsDate).format('YYYY-MM-DD HH:mm:ss')\n timestampToDisplay = {\n label: `📋 时间戳转时间展示\\n结果: ${display}`,\n props: { onClick: () => copy(display, true) },\n }\n } else {\n timestampToDisplay = {\n label: `📋 格式化时间 (格式: ${fmt})\\n结果: ${formattedTime}`,\n\n props: {\n onClick: async () => {\n await copy(formattedTime, true)\n },\n },\n }\n }\n\n return [\n timestampToDisplay,\n !valRef.value ?\n {\n label: `📋 当前时间戳\\n${ts}`,\n props: {\n onClick: async () => {\n await copy(ts, true)\n },\n },\n } :\n {\n label: `📋 转换输入值为时间戳`,\n props: {\n onClick: async () => {\n const result = moment(valRef.value).unix() * 1000\n if (!result) {\n window.$message.error('请输入类似于 2024-05-13 09:54:44 的值来进行转换!')\n return\n }\n await copy(result, true)\n },\n },\n },\n ].filter(Boolean)\n })\n }\n }\n}, {\n isStaticPlugin: true,\n})\n" - } -] \ No newline at end of file