No description
  • Go 66.2%
  • JavaScript 11.9%
  • HTML 10.5%
  • Objective-C 4.2%
  • NSIS 1.8%
  • Other 5.4%
Find a file
Lea Anthony 47ebe47090
docs: audit and fix hallucinated v3 documentation (#4975)
* docs: comprehensive audit and fix of hallucinated v3 documentation

Three-pass audit of all v3 documentation against source code on v3-alpha,
fixing hundreds of hallucinated API patterns, fabricated CLI flags, wrong
method signatures, and incorrect struct fields across 59 files.

Pass 1: Pattern-matched sweep for known wrong API names
Pass 2: Source-code-first specialist agents (6 agents by area)
Pass 3: Deep field-by-field verification (7 specialist agents)

Key fixes:
- Removed fabricated OnStartup/OnBeforeClose hooks, replaced with
  ServiceStartup interface, ShouldQuit, RegisterHook patterns
- Removed fabricated window convenience methods (OnClose, OnFocus, etc.),
  replaced with OnWindowEvent(events.Common.*, ...) pattern
- Removed fabricated CLI flags (-platform, -o, -ldflags, -icon, etc.),
  documented actual Taskfile-based build system with GOOS/GOARCH
- Fixed package-level dialog functions to Manager API
- Fixed JS runtime imports (OnEvent/Emit -> Events.On/Events.Emit)
- Fixed platform option struct names (MacOptions->MacWindow, etc.)
- Fixed Screen struct fields, WebviewWindowOptions fields
- Added missing documentation for 20+ window methods, 30+ platform
  option fields, complete Application Options table, missing CLI commands
- Fixed event callback signatures, event constant names
- Fixed ServiceShutdown signature, OnClick callback signatures

Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>

* docs: apply PR review principles - JS event objects, directives, lifecycle

Address feedback from PR #4975 review by fbbdev and Copilot:

JS event callbacks (Principle 3 - 14 fixes across 10 files):
- All JS event callbacks now correctly receive event object, access
  payload via event.data instead of receiving data directly
- Fixed in: reference/window, concepts/bridge, concepts/architecture,
  migration/v2-to-v3, guides/gin-routing, guides/gin-services,
  features/dialogs/custom, features/bindings/best-practices

Wails directives (Principle 2 - 2 files):
- Fixed //wails:internal semantics: IS exported to frontend but kept
  module-private (not re-exported from index), NOT "prevents export"
- Fixed //wails:ignore description: completely excluded from JS bindings
- Added new "Internal + Inject Pattern" section with real SQLite service
  example showing how //wails:internal + //wails:inject work together

ContextMenu.Update() (Principle 5):
- Added missing Update() call in guides/menus.mdx image gallery example

Lifecycle patterns verified correct - ServiceStartup usage is for
business logic init, not lifecycle hooks. EventManager.Emit confirmed
to return bool per source (Principle 4 in audit doc was incorrect).

Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>

* docs: fix lifecycle docs - use events not services for lifecycle hooks

ServiceStartup is for service resource initialization (DB, config),
NOT for application lifecycle hooks. Application lifecycle events
(events.Common.ApplicationStarted, ThemeChanged) are the correct
mechanism for reacting to lifecycle stages.

- architecture.mdx: replace misleading "Lifecycle hooks" section
- lifecycle.mdx: add Application Lifecycle Events section (new §3)
- lifecycle.mdx: rename "Service Startup" to "Service Initialisation"
- lifecycle.mdx: categorize reference table (events/services/options)
- lifecycle.mdx: update d2 diagram with ApplicationStarted stage
- lifecycle.mdx: update best practices to distinguish init vs lifecycle

Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>

* docs: fix issues from PR review comments

- menus.mdx: add Update() call after adding items to context menu snippet
- application.mdx: fix Emit() signature — remove fabricated bool return
- events-reference.mdx: fix files-dropped JS example to account for
  variadic wrapping (event.data[0] is the files array)
- bridge.mdx: fix progress event example — use variadic args directly
  and destructure event.data array in JS

Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>

---------

Co-authored-by: Claude Opus 4.6 <noreply@anthropic.com>
2026-02-09 21:48:08 +11:00
.github Fix commit of npm package changes 2025-09-28 08:00:42 +10:00
assets/images [ImgBot] Optimize images (#1812) 2022-09-12 21:57:07 +10:00
docs docs: audit and fix hallucinated v3 documentation (#4975) 2026-02-09 21:48:08 +11:00
mkdocs-website/docs/en [V3] feat: add Windows getAccentColor implementation (#4427) 2025-07-25 21:46:05 +10:00
scripts Add issue management automation tools 2025-05-14 20:47:45 +10:00
v2 Dependency updates 2025-05-15 06:26:20 +10:00
v3 docs: Complete documentation redesign with enhanced landing page 2025-10-04 22:15:35 +10:00
website Improve documentation clarity and reduce cognitive load 2025-11-15 08:42:09 +11:00
.all-contributorsrc [v3] Add starlight website (#3917) 2024-12-08 12:09:13 +11:00
.coderabbit.yaml Add code rabbit for alpha 2024-07-29 20:46:15 +10:00
.gitignore docs: Complete documentation redesign with enhanced landing page 2025-10-04 22:15:35 +10:00
.prettierignore chore: add Prettier as format tool (#2689) 2023-05-30 07:40:54 +10:00
.prettierrc.yml [v3] Add starlight website (#3917) 2024-12-08 12:09:13 +11:00
.tool-versions docs: Complete documentation redesign with enhanced landing page 2025-10-04 22:15:35 +10:00
AGENTS.md docs: Complete documentation redesign with enhanced landing page 2025-10-04 22:15:35 +10:00
astro.config.mjs docs: Complete documentation redesign with enhanced landing page 2025-10-04 22:15:35 +10:00
CHANGELOG.md chore: sort out files (#1776) 2022-08-22 20:02:27 +10:00
CNAME Add CNAME 2023-10-29 09:48:37 +11:00
CONTRIBUTING.md chore: sort out files (#1776) 2022-08-22 20:02:27 +10:00
CONTRIBUTORS.md Fix BackgroundColour documentation. Update changelog. Move contributors into website. Create changelog link. 2022-07-25 20:11:04 +10:00
DEVELOPER_GUIDE.md docs: Complete documentation redesign with enhanced landing page 2025-10-04 22:15:35 +10:00
DND_ANALYSIS.md docs: Complete documentation redesign with enhanced landing page 2025-10-04 22:15:35 +10:00
DND_ISSUES.md docs: Complete documentation redesign with enhanced landing page 2025-10-04 22:15:35 +10:00
LICENSE Update license and readme 2019-04-08 19:18:39 +10:00
package-lock.json docs: Complete documentation redesign with enhanced landing page 2025-10-04 22:15:35 +10:00
package.json docs: Complete documentation redesign with enhanced landing page 2025-10-04 22:15:35 +10:00
qodana.yaml Add status table to docs. 2023-09-06 20:59:45 +10:00
README.de.md German Readme (#3483) 2024-06-08 21:15:42 +10:00
README.es.md German Readme (#3483) 2024-06-08 21:15:42 +10:00
README.fr.md German Readme (#3483) 2024-06-08 21:15:42 +10:00
README.ja.md German Readme (#3483) 2024-06-08 21:15:42 +10:00
README.ko.md German Readme (#3483) 2024-06-08 21:15:42 +10:00
README.md German Readme (#3483) 2024-06-08 21:15:42 +10:00
README.pt-br.md German Readme (#3483) 2024-06-08 21:15:42 +10:00
README.ru.md Update README.ru.md (#3544) 2024-06-17 18:40:22 +10:00
README.tr.md Added README.tr.md for supporting turkish language (#3528) 2024-06-08 09:51:35 +10:00
README.uz.md German Readme (#3483) 2024-06-08 21:15:42 +10:00
README.zh-Hans.md German Readme (#3483) 2024-06-08 21:15:42 +10:00
SECURITY.md Update SECURITY.md 2024-02-14 18:15:24 +11:00
Taskfile.yaml Docs change 2024-12-13 22:00:25 +11:00
test-changelog-extraction.sh Add test workflow for nightly releases 2025-07-06 06:59:28 +10:00
test-version-logic.sh Add test workflow for nightly releases 2025-07-06 06:59:28 +10:00
test-workflow.md Add test workflow for nightly releases 2025-07-06 06:59:28 +10:00


Build desktop applications using Go & Web Technologies.

GitHub Go Reference CodeFactor Awesome Discord
Build GitHub tag (latest SemVer pre-release)

Table of Contents

Introduction

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!

Features

  • Use standard Go for the backend
  • Use any frontend technology you are already familiar with to build your UI
  • Quickly create rich frontends for your Go programs using pre-built templates
  • Easily call Go methods from Javascript
  • Auto-generated Typescript definitions for your Go structs and methods
  • Native Dialogs & Menus
  • Native Dark / Light mode support
  • Supports modern translucency and "frosted window" effects
  • Unified eventing system between Go and Javascript
  • Powerful cli tool to quickly generate and build your projects
  • Multiplatform
  • Uses native rendering engines - no embedded browser!

Roadmap

The project roadmap may be found here. Please consult it before creating an enhancement request.

Getting Started

The installation instructions are on the official website.

Sponsors

This project is supported by these kind people / companies:

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. Wails does offer native elements such as menus and dialogs, so it could be considered a lightweight electron alternative.

  • 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.

Stargazers over time

Star History Chart

Contributors

The contributors list is getting too big for the readme! All the amazing people who have contributed to this project have their own page here.

License

FOSSA Status

Inspiration

This project was mainly coded to the following albums: