First off, thanks for taking the time to contribute! ❤️
All types of contributions are encouraged and valued. Please make sure to read the relevant section before making your contribution. It will make it a lot easier for us maintainers and smooth out the experience for all involved. The community looks forward to your contributions. 🎉
And if you like the project, but just don't have time to contribute, that's fine. There are other easy ways to support the project and show your appreciation, which we would also be very happy about:
- Star the project
- Tweet about it
- Refer this project in your project's readme
- Mention the project at local meetups and tell your friends/colleagues
If you want to ask a question or report a bug, we assume that you have read the available Documentation.
Before you ask a question, it is best to search for existing Issues that might help you. In case you have found a suitable issue and still need clarification, you can write your question in this issue. It is also advisable to search the internet for answers first.
If you then still feel the need to ask a question and need clarification, we recommend the following:
- Open an Issue.
- Provide as much context as you can about what you're running into.
- Provide project and platform versions (nodejs, npm, etc), depending on what seems relevant.
We will then take care of the issue as soon as possible.
This is a Monorepo project including the following technologies:
- Cross-platform framework: Electron
- Interface:
- State management and communication:
- Automation framework/toolkit:
- Test framework
.
├── README.md
├── apps
│ └── ui-tars
│ └── src
│ ├── main
│ ├── preload
│ └── renderer
│
├── packages
│ ├── agent-infra
│ │ ├── browser
│ │ ├── browser-use
│ │ ├── logger
│ │ ├── mcp-client
│ │ ├── mcp-servers
│ │ ├── search
│ │ └── shared
│ ├── common
│ │ ├── configs
│ │ └── electron-build
│ └── ui-tars
│ ├── action-parser
│ ├── cli
│ ├── electron-ipc
│ ├── operators
│ ├── sdk
│ ├── shared
│ ├── tsconfig.node.json
│ ├── utio
│ └── visualizer
└── vitest.*.mts # Unit test configurationNote: The
srcdirectory is located in the top-level directory instead of theapps/{main,preload,renderer}directories because Electron Forge previously did not support Pnpm's hoisting mechanism(electron/forge#2633), requiring thesrcdirectory to be placed in the top-level directory.
$ git clone https://github.com/bytedance/ui-tars-desktop.git
$ cd ui-tars-desktop$ pnpm install$ pnpm run dev:ui-tars # Start UI-TARS DesktopAfter the application starts, you can see the UI-TARS interface within the application.
Note: On MacOS, you need to grant permissions to the app (e.g., iTerm2, Terminal) you are using to run commands.
By default, pnpm run dev only has frontend Hot Module Replacement (HMR) hot updates. If you need to simultaneously reload the main process during debugging, you can execute pnpm run dev:w.
$ pnpm run dev:wRun pnpm run build in current system, it will output into out/* directory.
To build the products of other systems, run:
- Mac x64:
pnpm run publish:mac-x64 - Mac ARM:
pnpm run publish:mac-arm64 - Windows x64:
pnpm run publish:win32 - Windows ARM:
pnpm run publish:win32-arm64
The CI pipeline to execute is .github/workflows/release.yml, only manual triggered by maintainers. If you're a maintainer, you can follow the steps below to release the application:
- Edit the
versioninpackage.json - Git commit and push to the
release/${version}branch, create a PR targetingmainbranch, titledrelease(app): ${version} - Trigger the release workflow manually after the PR is merged
Currently, the release workflow supports the following platforms:
- MacOS x64
- MacOS arm64
- Windows x64
If you want to publish the latest version packages to the npm registry, you can run the following command:
pnpm changesetto specify the changelogs for the packages you want to publish- Git commit and push to the
release-pkgs/${version}branch, create a PR targetingmainbranch, titledrelease(pkgs): ${version} pnpm run publish:packagesto publish the packages in latestorigin/mainbranch after the PR is merged
If you want to publish the beta version packages to the npm registry, you can run the following command:
pnpm changesetto specify the changelogs for the packages you want to publish- Git commit and push to the branch
pnpm run publish-beta:packagesto publish the packages in current branch
The documents are placed in the docs/*.md directory, formatted in markdown. There is currently no documentation site, but the docs/*.md directory will be converted into a documentation site in the future.
We use Husky and lint-staged to enforce the pre-commit hooks. The hooks include:
prettier --writeto format the codenpm run typecheckto strictly check the type
We use Conventional Commits to standardize the commit messages.
Each PR or main branch push will trigger the CI pipeline to run the unit test and E2E test.
pnpm run testpnpm run test:e2e- Push your changes to a feature branch in your fork of the repository.
- Submit a pull request to this repository
- Accept the CLA in your PR.