InvokeAI/invokeai/frontend/web/docs/README.md

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

50 lines
2.2 KiB
Markdown
Raw Normal View History

2023-03-07 10:56:01 +00:00
# InvokeAI Web UI
2023-04-03 01:04:24 +00:00
- [InvokeAI Web UI](#invokeai-web-ui)
2023-04-05 13:48:21 +00:00
- [Stack](#stack)
2023-04-03 01:04:24 +00:00
- [Contributing](#contributing)
- [Dev Environment](#dev-environment)
- [Production builds](#production-builds)
2023-03-07 10:56:01 +00:00
The UI is a fairly straightforward Typescript React app. The only really fancy stuff is the Unified Canvas.
2023-03-07 10:56:01 +00:00
Code in `invokeai/frontend/web/` if you want to have a look.
2023-04-05 13:48:21 +00:00
## Stack
2023-03-07 10:56:01 +00:00
State management is Redux via [Redux Toolkit](https://github.com/reduxjs/redux-toolkit). Communication with server is a mix of HTTP and [socket.io](https://github.com/socketio/socket.io-client) (with a custom redux middleware to help).
2023-03-07 10:56:01 +00:00
[Chakra-UI](https://github.com/chakra-ui/chakra-ui) for components and styling.
[Konva](https://github.com/konvajs/react-konva) for the canvas, but we are pushing the limits of what is feasible with it (and HTML canvas in general). We plan to rebuild it with [PixiJS](https://github.com/pixijs/pixijs) to take advantage of WebGL's improved raster handling.
[Vite](https://vitejs.dev/) for bundling.
Localisation is via [i18next](https://github.com/i18next/react-i18next), but translation happens on our [Weblate](https://hosted.weblate.org/engage/invokeai/) project. Only the English source strings should be changed on this repo.
## Contributing
Thanks for your interest in contributing to the InvokeAI Web UI!
We encourage you to ping @psychedelicious and @blessedcoolant on [Discord](https://discord.gg/ZmtBAhwWhy) if you want to contribute, just to touch base and ensure your work doesn't conflict with anything else going on. The project is very active.
### Dev Environment
Install [node](https://nodejs.org/en/download/) and [yarn classic](https://classic.yarnpkg.com/lang/en/).
From `invokeai/frontend/web/` run `yarn install` to get everything set up.
Start everything in dev mode:
2023-02-05 22:07:44 +00:00
1. Start the dev server: `yarn dev`
2. Start the InvokeAI UI per usual: `invokeai --web`
2023-04-03 01:04:24 +00:00
3. Point your browser to the dev server address e.g. <http://localhost:5173/>
2023-03-07 10:56:01 +00:00
### Production builds
For a number of technical and logistical reasons, we need to commit UI build artefacts to the repo.
If you submit a PR, there is a good chance we will ask you to include a separate commit with a build of the app.
2023-03-07 10:56:01 +00:00
To build for production, run `yarn build`.