What is this?
Do you keep opening terminals to run your scripts/commands/tasks etc,. If you have to do that everyday for same project (Example running scripts from
package.json for multiple projects),
Ten Hands makes it easier to organize all your tasks in one place.
You can organize tasks into projects and run them whenever you want with a click of button.
Downloads are available in
IMPORTANT NOTE: I couldn't afford signing certificates. So, you'll have to allow the app to run.
Steps to build
Install dependencies (Use yarn because I used workspaces).
yarn install. Only in root folder.
To start in development mode -
To build the app -
Installers will be available in
I am making updates in
v2.0.0 branch. Check Projects tab to see what I'm working on. You can pull and build that branch to get latest updates (with a risk of getting unstable build).
config.json is supported which is placed at
portoption can be changed. Default port is
Gotchas & Tips
This project is in experimental stage, so there are some limitations to use the app. Expect them to be resolved soon.
Currently, tasks can be extracted only from
package.json. But, If you have other type of project, you can create a project without any such file. Then, add the tasks using
New Commandbutton inside the project.
Every project when opened, will render terminals for all the tasks in the project which can be costly based on the number of tasks. So, if you do not use a certain command, consider deleting it (not from your project file. Inside
Ten Hands). This will make project switching faster. Performance will improve in coming versions.
The default port is
5010. If app doesn't start, try changing the port in
~/.ten-hands/config.jsonto any one that is not being used and reopen the app.
This project started as educational for myself to learn more about react hooks, sockets, typescript and other stuff. So there might be some weirdness around the code.
Please create issue/pr for any kind of improvements/suggestions regardless of how small it is.
MIT - Sai Sandeep Vaddi