Skip to content

This is an extension based on sd-webui, aimed at improving the user experience of the prompt/negative prompt input box. It has a more intuitive and powerful input interface function, and provides automatic translation, history record, and bookmarking functions. 这是一个基于 sd-webui 的扩展,旨在提高提示词/反向提示词输入框的使用体验。它拥有更直观、强大的输入界面功能,它提供了自动翻译、历史记录和收藏等功能。

License

Notifications You must be signed in to change notification settings

strongshuai/sd-webui-prompt-all-in-one

 
 

Repository files navigation

sd-webui-prompt-all-in-one

GitHub stars GitHub forks GitHub issues GitHub license

sd-webui-prompt-all-in-one is an extension based on stable-diffusion-webui that aims to improve the user experience of the prompt/negative prompt input box. It has a more intuitive and powerful input interface, provides automatic translation, history and collection functions, and supports multiple languages to meet the needs of different users.

sd-webui-prompt-all-in-one 是一个基于 stable-diffusion-webui 的扩展,旨在提高提示词/反向提示词输入框的使用体验。它拥有更直观、强大的输入界面功能,它提供了自动翻译、历史记录和收藏等功能,它支持多种语言,满足不同用户的需求。


The localized language interface is currently available in 中文 English Русский 日本語 한국어 Français Deutsch Español Português Italiano العربية, and the translation function supports the majority of countries worldwide.

目前支持以下语言的本地化语言界面:中文 English Русский 日本語 한국어 Français Deutsch Español Português Italiano العربية,翻译功能支持目前世界上绝大多数国家。

If you find this extension helpful, please give me a star on Github! You could also buy me a coffee: donate

如果你觉得这个扩展有帮助,请在Github上给我一颗星! 你也可以请我喝杯咖啡: donate

QQ群:820700336

Demo / 演示

  • Switch language / 切换语言

  • Translation API settings / 翻译API设置

  • Show/Hide content / 显示/折叠内容

  • Show/Hide the WebUI input box / 显示/隐藏WebUI输入框

  • Automatic translation / 自动翻译

  • One-click translation / 一键翻译

  • Concise input / 简洁的输入

  • Elegant input / 优雅的输入

  • Quick adjustment / 快速调整

  • Favorite and History / 收藏和历史记录

  • Writing in WebUI input box / 在WebUI的输入框中编写

  • Support for a1111-sd-webui-tagcomplete / 支持a1111-sd-webui-tagcomplete

  • Use danbooru.csv in a1111-sd-webui-tagcomplete to enhance the translation function / 使用 a1111-sd-webui-tagcomplete 中的 danbooru.csv 增强翻译功能

  • Custom Theme / Extension styles / 自定义主题/扩展风格

Installation and Usage / 安装使用

  • Method 1 (Recommended) / 方式一(推荐)

    1. Open the terminal and enter your stable-diffusion-webui directory.

      打开终端,进入到你的 stable-diffusion-webui 目录下。

      For example / 例如

      cd "C:\stable-diffusion-webui"

    2. Use git to clone sd-webui-prompt-all-in-one to the extensions directory of stable-diffusion-webui.

      使用 git 克隆 sd-webui-prompt-all-in-one 到 stable-diffusion-webui 的 extensions 目录下。

      git clone "https://github.com/Physton/sd-webui-prompt-all-in-one.git" extensions/sd-webui-prompt-all-in-one

      China中国镜像地址:

      git clone "https://gitee.com/physton/sd-webui-prompt-all-in-one.git" extensions/sd-webui-prompt-all-in-one
  • Method 2 / 方式二

    In the extension tab of stable-diffusion-webui, select "Install from URL", enter https://github.com/Physton/sd-webui-prompt-all-in-one.git, and click on install.

    在 stable-diffusion-webui 的扩展选项卡中,选择从网址安装,输入 https://github.com/Physton/sd-webui-prompt-all-in-one.git, 然后点击安装。

    China中国镜像地址: https://gitee.com/physton/sd-webui-prompt-all-in-one.git

  • Method 3 / 方式三

    In the extensions tab of stable-diffusion-webui, load the official online extension library, find sd-webui-prompt-all-in-one, and click Install.

    在 stable-diffusion-webui 的扩展选项卡中,加载官方在线扩展库,找到sd-webui-prompt-all-in-one,点击安装

  • Method 4 (Not recommended) / 方式四(不推荐)

    Download the source code package of sd-webui-prompt-all-in-one, and unzip it to the extensions directory of stable-diffusion-webui.

    下载 sd-webui-prompt-all-in-one 的源码压缩包,解压到 stable-diffusion-webui 的 extensions 目录下。

Restart stable-diffusion-webui. (Not Reload WebUI)

重启 stable-diffusion-webui。(不是Reload重载WebUI)

Extension update description (important) / 扩展更新说明(重要)

  1. All your data, including API keys, history records, and favorite data, are stored in the storage directory of the extension.

    你的所有数据:API KEY、历史记录、收藏数据等,都保存在扩展的 storage 目录下。

  2. Using the built-in updater in WebUI or updating via git will not cause your data to be lost.

    使用WebUI自带的更新器,或者使用git更新,都不会导致你的数据丢失。

  3. Overwriting the extension installation with a compressed file or deleting the extension and reinstalling it will result in data loss.

    使用压缩包等方式覆盖安装,或者删除扩展后重新安装,都会导致你的数据丢失。

  4. If you want to backup your data, you can copy the storage directory to another location and then copy it back when needed.

    如果你想备份你的数据,可以将 storage 目录复制到其他地方,然后在需要的时候将其复制回来。

Contributing / 帮助开发

Click to expand / 点击展开 If you want to contribute to sd-webui-prompt-all-in-one, welcome to submit issues and pull requests. You can also contact me via:

如果你想为 sd-webui-prompt-all-in-one 做出贡献,欢迎提交 issue 和 pull request。同时,你也可以通过以下方式联系我:

Development / 开发方式

Click to expand / 点击展开
  • Front-end development (vue) / 前端开发(vue)

    1. Enter the src directory / 进入 src 目录

      cd ./sd-webui-prompt-all-in-one/src

    2. Initialize the node environment / 初始化node环境

      npm install

    3. Modify the code / 修改代码

    4. Compile / 编译

      npm run build

    5. Restart stable-diffusion-webui / 重启 stable-diffusion-webui。

  • Back-end development (python) / 后端开发(python)

    1. Enter the extension directory / 进入扩展目录cd ./sd-webui-prompt-all-in-one
    2. Modify the code / 修改代码
    3. Restart stable-diffusion-webui / 重启 stable-diffusion-webui。

Custom Theme / 自定义主题

If you need to customize the style theme of this extension, please refer to:

如果你需要自定义此扩展的样式主题,请参考:

https://github.com/Physton/sd-webui-prompt-all-in-one/tree/main/styles/extensions

FAQ / 常见问题列表

Q: What is the difference between translation interfaces that do not require API keys and those that require API keys?

A: The translation interface that does not require an API key is obtained through crawling and does not require the user to apply for an API key. However, there may be translation failures, instability, slow speed, and lack of support for concurrency. The translation interface that requires an API key calls the API interface of a third-party translation service and requires the user to apply for an API key. However, the translation success rate is relatively high, some interfaces support high concurrency, and the translation speed is fast.

Q: Unable to use translation service, clicking "Test!" results in "No module named 'xxx'" error message?

A: This is because the dependencies required by webui are not installed properly at startup. You can solve this issue by following these steps:

  1. Switch to the python/bin directory used by sd-webui.
  2. Run the following commands:
    ./python -m pip install chardet
    ./python -m pip install translators
    ./python -m pip install openai
    ./python -m pip install boto3
    ./python -m pip install aliyun-python-sdk-core
    ./python -m pip install aliyun-python-sdk-alimt
    ./python -m pip install tencentcloud-sdk-python
    
  3. After the installation is complete, restart webui.
Q: Display error message: "Connection to backend API service failed. Please manually refresh the webpage. If it still doesn't work, please restart the WebUI."

A:

  • You may need to refresh the web page or restart the WebUI.
  • This is because the dependencies required by webui are not installed properly at startup. Please refer to the above installation method for installing modules.
  • Go to the extensions\sd-webui-prompt-all-in-one\storage directory, change the encoding of the history.*.json and favorite.*.json files to UTF-8 encoding, or delete them (remember to backup first).
Q: Why did the extension install successfully and there were no error outputs in the console, but there is still no extension panel on the webpage?

A: You need to make sure that your WebUI version is 22bcc7b or higher. If your WebUI version is lower than this, you need to update WebUI.

Q: Don't need translation services, just want to use it in an offline environment?

A:

  1. During initialization, the extension will install some translation interface SDK packages, such as translatorsopenaiboto3aliyun-python-sdk-corealiyun-python-sdk-alimttencentcloud-sdk-python, etc. If you don't need translation services and don't want to install them, please manually open install.py, delete the code according to the comments in the code. This will not affect the use of the extension. Then uncheck the automatic translation button in the extension settings.
  2. You can also directly change the local language to English en_US in the extension, which will hide all translation-related buttons. Although the extension will still install these translation interface SDK packages during initialization, they are imported on-demand in the code without using translation services, so they will not be loaded.
Q: 无需api key的翻译接口和需要api key的翻译接口有什么区别?

A: 无需api key的翻译接口,是通过爬虫获取的,不需要用户自己申请api key,但是可能会存在翻译失败的情况,稳定下差,速度慢,不支持并发。需要api key的翻译接口,是通过调用第三方翻译服务的api接口,需要用户自己申请api key,但是翻译成功率较高,某些接口支持高并发,翻译速度快。

Q: 无法使用翻译服务,点击“测试”,提示“No module named 'xxx'”?

A: 这是由于webui启动时,没有正确的安装依赖导致的,可以通过以下方式解决:

  1. 切换到webui所使用的python/bin目录。
  2. 执行命令:
    ./python -m pip install chardet
    ./python -m pip install translators
    ./python -m pip install openai
    ./python -m pip install boto3
    ./python -m pip install aliyun-python-sdk-core
    ./python -m pip install aliyun-python-sdk-alimt
    ./python -m pip install tencentcloud-sdk-python
    
  3. 等待安装完成后,重启webui。
Q: 显示错误消息:"连接到后台接口服务失败,请手动再刷新一次网页。如果还是不行,请重启WebUI"。

A:

  • 你可能需要刷新网页或者重启WebUI。
  • 这是由于WebUI启动时,没有正确的安装依赖,参考上方安装模块的方法。
  • 进入extensions\sd-webui-prompt-all-in-one\storage目录,将history.*.jsonfavorite.*.json文件编码改为UTF-8编码,或者删除它们(记得先备份)。
Q: 为什么扩展安装成功了,控制台也没有错误输出,但网页中就是没有扩展的面板?

A: 你需要确保你的WebUI版本是 22bcc7b(2023年第13周) 及更高。如果你的WebUI版本低于此版本,你需要更新WebUI。

Q: 不需要翻译服务,只想在离线环境中使用?

A:

  1. 扩展在初始化的时候会安装一些翻译接口的SDK包,如translatorsopenaiboto3aliyun-python-sdk-corealiyun-python-sdk-alimttencentcloud-sdk-python等等,如果你不需要翻译服务,也不想安装它们,请手动打开install.py,根据代码中的注释,删除代码,这并不会影响扩展的使用。然后取消勾选扩展设置中的自动翻译按钮。
  2. 你也可以直接在扩展中将本地语言改为英文en_US,这样所有翻译相关的按钮都将被隐藏。虽然扩展在初始化时还会安装这些翻译接口的SDK包,但它们在代码中都是按需导入的,没有使用翻译服务,它们也不会被加载。

Donate

Donation list / 捐赠列表DONATE.MD

Buy me a coffee / 请我喝杯咖啡

  • BTC-Bitcoin 3LdXwHkkVsspQzgowdy3pymwty9LiFBHda

  • ETH-Ethereum 3DbapbGRQdbrDqBazBPYWfyKjbM5uN2SDy

  • USDT-ERC20 0xb8b7a067c5639e7befb9665be9bd00a4c75b6614

  • USDT-TRC20 TWtnKQgSTpHu1eiQGrppSniGyzYtggZYFf

  • Paypal [email protected]

  • Alipay / 支付宝 [email protected]

  • Wechat / 微信赞赏

Developed by: https://www.physton.com

About

This is an extension based on sd-webui, aimed at improving the user experience of the prompt/negative prompt input box. It has a more intuitive and powerful input interface function, and provides automatic translation, history record, and bookmarking functions. 这是一个基于 sd-webui 的扩展,旨在提高提示词/反向提示词输入框的使用体验。它拥有更直观、强大的输入界面功能,它提供了自动翻译、历史记录和收藏等功能。

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Vue 48.7%
  • JavaScript 19.2%
  • Less 17.3%
  • Python 14.7%
  • HTML 0.1%