mirror of
https://github.com/wailsapp/wails.git
synced 2025-05-06 10:50:45 +08:00
162 lines
7.6 KiB
Markdown
162 lines
7.6 KiB
Markdown
<p align="center" style="text-align: center">
|
|
<img src="logo_cropped.png" width="40%"><br/>
|
|
</p>
|
|
<p align="center">
|
|
A framework for building desktop applications using Go & Web Technologies.<br/><br/>
|
|
<a href="https://github.com/wailsapp/wails/blob/master/LICENSE"><img src="https://img.shields.io/badge/License-MIT-blue.svg"></a>
|
|
<a href="https://goreportcard.com/report/github.com/wailsapp/wails"><img src="https://goreportcard.com/badge/github.com/wailsapp/wails"/></a>
|
|
<a href="http://godoc.org/github.com/wailsapp/wails"><img src="https://img.shields.io/badge/godoc-reference-blue.svg"/></a>
|
|
<a href="https://www.codefactor.io/repository/github/wailsapp/wails"><img src="https://www.codefactor.io/repository/github/wailsapp/wails/badge" alt="CodeFactor" /></a>
|
|
<a href="https://github.com/wailsapp/wails/issues"><img src="https://img.shields.io/badge/contributions-welcome-brightgreen.svg?style=flat" alt="CodeFactor" /></a>
|
|
<a href="https://app.fossa.io/projects/git%2Bgithub.com%2Fwailsapp%2Fwails?ref=badge_shield" alt="FOSSA Status"><img src="https://app.fossa.io/api/projects/git%2Bgithub.com%2Fwailsapp%2Fwails.svg?type=shield"/></a>
|
|
<a href="https://houndci.com"><img src="https://img.shields.io/badge/Reviewed_by-Hound-8E64B0.svg"/></a>
|
|
<a href="https://github.com/avelino/awesome-go" rel="nofollow"><img src="https://cdn.rawgit.com/sindresorhus/awesome/d7305f38d29fed78fa85652e3a63e154dd8e8829/media/badge.svg" alt="Awesome"></a>
|
|
<a href="https://github.com/wailsapp/wails/workflows/release/badge.svg?branch=master" rel="nofollow"><img src="https://github.com/wailsapp/wails/workflows/release/badge.svg?branch=master" alt="Release Pipelines"></a>
|
|
</p>
|
|
|
|
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!
|
|
|
|
The official docs can be found at [https://wails.app](https://wails.app).
|
|
|
|
## Features
|
|
|
|
- Use standard Go libraries/frameworks 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
|
|
|
|
|
|
## Installation
|
|
|
|
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.13
|
|
- npm
|
|
|
|
### MacOS
|
|
|
|
Make sure you have the xcode command line tools installed. This can be done by running:
|
|
|
|
`xcode-select --install`
|
|
|
|
### Linux
|
|
|
|
#### Debian/Ubuntu
|
|
|
|
`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
|
|
|
|
#### Arch Linux / ArchLabs / Ctlos Linux
|
|
|
|
`sudo pacman -S webkit2gtk gtk3`
|
|
|
|
_Also succesfully test on: Manjaro & ArcoLinux_
|
|
|
|
#### Centos
|
|
|
|
`sudo yum install webkitgtk3-devel gtk3-devel`
|
|
|
|
_CentOS 6, 7_
|
|
|
|
#### Fedora
|
|
|
|
`sudo yum install webkit2gtk3-devel gtk3-devel`
|
|
|
|
_Fedora 29, 30_
|
|
|
|
#### VoidLinux & VoidLinux-musl
|
|
|
|
`xbps-install gtk+3-devel webkit2gtk-devel`
|
|
|
|
#### Gentoo
|
|
|
|
`sudo emerge gtk+:3 webkit-gtk`
|
|
|
|
### Windows
|
|
|
|
Windows requires gcc and related tooling. The recommended download is from [http://tdm-gcc.tdragon.net/download](http://tdm-gcc.tdragon.net/download). Once this is installed, you are good to go.
|
|
|
|
## Installation
|
|
|
|
**Ensure Go modules are enabled: GO111MODULE=on and go/bin is in your PATH variable.**
|
|
|
|
Installation is as simple as running the following command:
|
|
|
|
<pre style='color:white'>
|
|
go get -u github.com/wailsapp/wails/cmd/wails
|
|
</pre>
|
|
|
|
## Next Steps
|
|
|
|
It is recommended at this stage to read the comprehensive documentation at [https://wails.app](https://wails.app).
|
|
|
|
## FAQ
|
|
|
|
* 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](https://en.wikipedia.org/wiki/Wales) I am from. So it stuck.
|
|
|
|
## Shoulders of Giants
|
|
|
|
Without the following people, this project would never have existed:
|
|
|
|
* [Dustin Krysak](https://wiki.ubuntu.com/bashfulrobot) - His support and feedback has been immense. More patience than you can throw a stick at (Not long now Dustin!).
|
|
* [Serge Zaitsev](https://github.com/zserge) - Creator of [Webview](https://github.com/zserge/webview) which Wails uses for the windowing.
|
|
|
|
And without [these people](CONTRIBUTORS.md), it wouldn't be what it is today. A huge thank you to each and every one of you!
|
|
|
|
Special Mentions:
|
|
|
|
* [Byron](https://github.com/bh90210) - 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](https://open.spotify.com/album/1R2rsEUqXjIvAbzM0yHrxA)
|
|
* [Manic Street Preachers - This Is My Truth, Tell Me Yours](https://open.spotify.com/album/4VzCL9kjhgGQeKCiojK1YN)
|
|
* [The Midnight - Endless Summer](https://open.spotify.com/album/4Krg8zvprquh7TVn9OxZn8)
|
|
* [Gary Newman - Savage (Songs from a Broken World)](https://open.spotify.com/album/3kMfsD07Q32HRWKRrpcexr)
|
|
* [Steve Vai - Passion & Warfare](https://open.spotify.com/album/0oL0OhrE2rYVns4IGj8h2m)
|
|
* [Ben Howard - Every Kingdom](https://open.spotify.com/album/1nJsbWm3Yy2DW1KIc1OKle)
|
|
* [Ben Howard - Noonday Dream](https://open.spotify.com/album/6astw05cTiXEc2OvyByaPs)
|
|
* [Adwaith - Melyn](https://open.spotify.com/album/2vBE40Rp60tl7rNqIZjaXM)
|
|
* [Gwidaith Hen Fran - Cedors Hen Wrach](https://open.spotify.com/album/3v2hrfNGINPLuDP0YDTOjm)
|
|
* [Metallica - Metallica](https://open.spotify.com/album/2Kh43m04B1UkVcpcRa1Zug)
|
|
* [Bloc Party - Silent Alarm](https://open.spotify.com/album/6SsIdN05HQg2GwYLfXuzLB)
|
|
* [Maxthor - Another World](https://open.spotify.com/album/3tklE2Fgw1hCIUstIwPBJF)
|
|
* [Alun Tan Lan - Y Distawrwydd](https://open.spotify.com/album/0c32OywcLpdJCWWMC6vB8v)
|
|
|
|
## Licensing
|
|
|
|
[](https://app.fossa.io/projects/git%2Bgithub.com%2Fwailsapp%2Fwails?ref=badge_large)
|
|
|
|
## Special Thanks
|
|
|
|
<p align="center" style="text-align: center">
|
|
A *huge* thanks to <a href="https://pace.dev"><img src="pace.jpeg"/> Pace</a> for sponsoring the project and helping the efforts to get Wails ported to Apple Silicon!<br/><br/>
|
|
If you are looking for a Project Management tool that's powerful but quick and easy to use, check them out!<br/><br/>
|
|
</p>
|
|
|
|
<p align="center" style="text-align: center">
|
|
A special thank you to JetBrains for donating licenses to us!<br/><br/>
|
|
Please click the logo to let them know your appreciation!<br/><br/>
|
|
<a href="https://www.jetbrains.com?from=Wails"><img src="jetbrains-grayscale.png" width="30%"></a>
|
|
</p>
|