Build desktop applications using Go & Web Technologies.
Click me to Open/Close the directory listing
The traditional method of providing web interfaces to Go programs is via a built-in web server. Wails offers a different approach: it provides the ability to wrap both Go code and a web frontend into a single binary. Tools are provided to make this easy for you by handling project creation, compilation and bundling. All you have to do is get creative!
PLEASE NOTE: As we are approaching the v2 release, we are not accepting any new feature requests or bug reports for v1. If you have a critical issue, please open a ticket and state why it is critical.
Wails v2 has been released in Beta for all 3 platforms. Check out the new website if you are interested in trying it out.
The legacy v1 docs can be found at https://wails.app.
- Use standard Go for the backend
- Use any frontend technology to build your UI
- Quickly create Vue, Vuetify or React frontends for your Go programs
- Expose Go methods/functions to the frontend via a single bind command
- Uses native rendering engines - no embedded browser
- Shared events system
- Native file dialogs
- Powerful cli tool
- Multiplatform
This project is supported by these kind people / companies:
data:image/s3,"s3://crabby-images/07662/0766233176c82c8ecb9a9385af3a3fd6c7276cd4" alt=""
data:image/s3,"s3://crabby-images/aeb0d/aeb0dc7e6e287455cd1e79ff038af8a2066644cf" alt=""
data:image/s3,"s3://crabby-images/8e247/8e24728b34adf996a58931ff76043291a968b6b5" alt=""
data:image/s3,"s3://crabby-images/d1036/d10361c23aec9844f3abb53a13bc3375ae5f286d" alt=""
data:image/s3,"s3://crabby-images/2812b/2812bd13cc70af891aaaa2f57437daac7940dc94" alt=""
data:image/s3,"s3://crabby-images/081a4/081a4e6069f81b49ec6c54dbcae29a5fead65665" alt=""
data:image/s3,"s3://crabby-images/992c9/992c9d60d382fcbe27e7a9958f98b6c3f4fc6867" alt=""
data:image/s3,"s3://crabby-images/2504e/2504e634a82253178c02a1084430b8c3f9b13257" alt=""
data:image/s3,"s3://crabby-images/0bcb3/0bcb3ee59cf96364629ab0db0646d2597c8c06ae" alt=""
data:image/s3,"s3://crabby-images/0e6be/0e6be174d39b6828ab9363743aa8e44ddc9c6cf7" alt=""
data:image/s3,"s3://crabby-images/a5589/a558987103f5ae33bb47d18bd320975c4e08c994" alt=""
data:image/s3,"s3://crabby-images/c7e93/c7e934bbf2d87cb2c6a67da31451aac3071ff46f" alt=""
data:image/s3,"s3://crabby-images/1eb90/1eb90f91430588bc750ec73f1763abde1dcb098a" alt=""
data:image/s3,"s3://crabby-images/2b761/2b76101bfe4b22c0289f1d7a81e44f7ed33cd5be" alt=""
data:image/s3,"s3://crabby-images/60fac/60fac5896b568172a8062e0026fd16f63b502603" alt=""
data:image/s3,"s3://crabby-images/83ac7/83ac7cc11f36be99419b552eb0a03396b21a4e2c" alt=""
data:image/s3,"s3://crabby-images/2c998/2c99843624d733e028b7dc848136241caf6a5006" alt=""
data:image/s3,"s3://crabby-images/1646f/1646fceeafeae905cffe78e6ab1023aa8d112884" alt=""
data:image/s3,"s3://crabby-images/5a575/5a575cdfb36a7fc93302c1f212ffc11478afb406" alt=""
data:image/s3,"s3://crabby-images/d1cbc/d1cbc56496985fe93fde40bf55f0df8290ae6959" alt=""
data:image/s3,"s3://crabby-images/179ac/179ac6e0590683e7ee666ab90a508f741d63f3df" alt=""
data:image/s3,"s3://crabby-images/fcac3/fcac3e069e6a40ac7da89ccec923d2d246ed74ea" alt=""
data:image/s3,"s3://crabby-images/942b0/942b0183418c6c8e8a6ffd44e387a22cbf7d546c" alt=""
data:image/s3,"s3://crabby-images/011ce/011ce2c82f1b4635960ca2d95a6532109a6501c1" alt=""
data:image/s3,"s3://crabby-images/4bbe0/4bbe010886113c2556db13729edff72176f8c1dc" alt=""
data:image/s3,"s3://crabby-images/c7b1b/c7b1b0beb158009a90b1f244b9a72e3b5c9ca0b9" alt=""
data:image/s3,"s3://crabby-images/0873c/0873cee9fc4f3e560d4a63fe9b07be42dbb8490c" alt=""
data:image/s3,"s3://crabby-images/3e0d3/3e0d3a0a890608e344b48ceeb1bf88ab53b62818" alt=""
data:image/s3,"s3://crabby-images/399eb/399eb079e8c285303a8a857a1c8c47acafaea0f0" alt=""
data:image/s3,"s3://crabby-images/6d781/6d781355b8c071dc9266463455e72e71ea4427a8" alt=""
Wails uses cgo to bind to the native rendering engines so a number of platform dependent libraries are needed as well as an installation of Go. The basic requirements are:
- Go 1.16
- npm
Make sure you have the xcode command line tools installed. This can be done by running:
xcode-select --install
sudo apt install libgtk-3-dev libwebkit2gtk-4.0-dev
Debian: 8, 9, 10
Ubuntu: 16.04, 18.04, 19.04
Also succesfully tested on: Zorin 15, Parrot 4.7, Linuxmint 19, Elementary 5, Kali, Neon, Pop!_OS
sudo pacman -S webkit2gtk gtk3
Also succesfully test on: Manjaro & ArcoLinux
sudo yum install webkitgtk3-devel gtk3-devel
CentOS 6, 7
sudo yum install webkit2gtk3-devel gtk3-devel
Fedora 29, 30
xbps-install gtk+3-devel webkit2gtk-devel
sudo emerge gtk+:3 webkit-gtk
Windows requires gcc and related tooling. The recommended download is from http://tdm-gcc.tdragon.net/download. Once this is installed, you are good to go.
Ensure Go modules are enabled: GO111MODULE=on and go/bin is in your PATH variable.
Installation is as simple as running the following command:
go get -u github.com/wailsapp/wails/cmd/wails
It is recommended at this stage to read the comprehensive documentation at https://wails.app.
-
Is this an alternative to Electron?
Depends on your requirements. It's designed to make it easy for Go programmers to make lightweight desktop applications or add a frontend to their existing applications. Whilst Wails does not currently offer hooks into native elements such as menus, this may change in the future.
-
Who is this project aimed at?
Go programmers who want to bundle an HTML/JS/CSS frontend with their applications, without resorting to creating a server and opening a browser to view it.
-
What's with the name?
When I saw WebView, I thought "What I really want is tooling around building a WebView app, a bit like Rails is to Ruby". So initially it was a play on words (Webview on Rails). It just so happened to also be a homophone of the English name for the Country I am from. So it stuck.
Without the following people, this project would never have existed:
- Dustin Krysak - His support and feedback has been immense. More patience than you can throw a stick at (Not long now Dustin!).
- Serge Zaitsev - Creator of Webview which Wails uses for the windowing.
- Byron - At times, Byron has single handedly kept this project alive. Without his incredible input, we never would have got to v1.
This project was mainly coded to the following albums:
- Manic Street Preachers - Resistance Is Futile
- Manic Street Preachers - This Is My Truth, Tell Me Yours
- The Midnight - Endless Summer
- Gary Newman - Savage (Songs from a Broken World)
- Steve Vai - Passion & Warfare
- Ben Howard - Every Kingdom
- Ben Howard - Noonday Dream
- Adwaith - Melyn
- Gwidaith Hen Fran - Cedors Hen Wrach
- Metallica - Metallica
- Bloc Party - Silent Alarm
- Maxthor - Another World
- Alun Tan Lan - Y Distawrwydd
A huge thanks to Pace for sponsoring the project and helping the efforts to get Wails ported to Apple Silicon!
If you are looking for a Project Management tool that's powerful but quick and easy to use, check them out!
A special thank you to JetBrains for donating licenses to us!
Please click the logo to let them know your appreciation!