Lewati ke konten

API Application

Application adalah inti aplikasi Wails Anda. Mengelola window, service, event, dan menyediakan akses ke semua fitur platform.

import "github.com/wailsapp/wails/v3/pkg/application"
app := application.New(application.Options{
Name: "My App",
Description: "My awesome application",
Services: []application.Service{
application.NewService(&MyService{}),
},
})

Memulai event loop aplikasi.

func (a *App) Run() error

Contoh:

err := app.Run()
if err != nil {
log.Fatal(err)
}

Mengembalikan: Error jika startup gagal

Menutup aplikasi dengan graceful.

func (a *App) Quit()

Contoh:

// In a menu handler
menu.Add("Quit").OnClick(func(ctx *application.Context) {
app.Quit()
})

Mengembalikan konfigurasi aplikasi.

func (a *App) Config() Options

Contoh:

config := app.Config()
fmt.Println("App name:", config.Name)

Membuat webview window baru dengan opsi default.

func (wm *WindowManager) New() *WebviewWindow

Contoh:

window := app.Window.New()
window.Show()

Membuat webview window baru dengan opsi kustom.

func (wm *WindowManager) NewWithOptions(options WebviewWindowOptions) *WebviewWindow

Contoh:

window := app.Window.NewWithOptions(application.WebviewWindowOptions{
Title: "My Window",
Width: 800,
Height: 600,
BackgroundColour: application.NewRGB(255, 255, 255),
})

Mendapatkan window berdasarkan namanya. Mengembalikan window dan apakah ditemukan.

func (wm *WindowManager) GetByName(name string) (Window, bool)

Contoh:

if window, ok := app.Window.GetByName("main"); ok {
window.Show()
}

Mengembalikan semua window aplikasi.

func (wm *WindowManager) GetAll() []Window

Contoh:

windows := app.Window.GetAll()
for _, window := range windows {
fmt.Println("Window:", window.Name())
}

Application menyediakan akses ke berbagai manager melalui properti:

app.Window // Window management
app.Menu // Menu management
app.Dialog // Dialog management
app.Event // Event management
app.Clipboard // Clipboard operations
app.Screen // Screen information
app.SystemTray // System tray
app.Browser // Browser operations
app.Env // Environment variables
app.ContextMenu // Context-menu management
app.KeyBinding // Global keyboard shortcuts
app.Logger // *slog.Logger
// Create window
window := app.Window.New()
// Show dialog
app.Dialog.Info().SetMessage("Hello!").Show()
// Copy to clipboard
app.Clipboard.SetText("Copied text")
// Get screens
screens := app.Screen.GetAll()

Mendaftarkan service ke aplikasi.

func (a *App) RegisterService(service Service)

RegisterService tidak mengembalikan nilai; error inisialisasi service muncul via kegagalan ServiceStartup selama app.Run().

Contoh:

type MyService struct {
app *application.App
}
func NewMyService(app *application.App) *MyService {
return &MyService{app: app}
}
// Register after app creation
app.RegisterService(application.NewService(NewMyService(app)))

Memancarkan event kustom. Mengembalikan true jika hook membatalkan emit.

func (em *EventManager) Emit(name string, data ...any) bool

Contoh:

// Emit event with data
app.Event.Emit("user-logged-in", map[string]interface{}{
"username": "john",
"timestamp": time.Now(),
})

Mendengarkan event kustom. Mengembalikan func() unsubscribe.

func (em *EventManager) On(name string, callback func(*CustomEvent)) func()

Contoh:

app.Event.On("user-logged-in", func(e *application.CustomEvent) {
data := e.Data.(map[string]interface{})
username := data["username"].(string)
fmt.Println("User logged in:", username)
})

Mendengarkan event siklus hidup aplikasi. Parameter eventType adalah events.ApplicationEventType (dari paket events).

func (em *EventManager) OnApplicationEvent(
eventType events.ApplicationEventType,
callback func(*ApplicationEvent),
) func()

Contoh:

import "github.com/wailsapp/wails/v3/pkg/events"
// Listen for app-started
app.Event.OnApplicationEvent(events.Common.ApplicationStarted, func(e *application.ApplicationEvent) {
fmt.Println("Application started")
})
// Application shutdown is NOT an event constant; register cleanup via:
app.OnShutdown(func() {
fmt.Println("Application shutting down")
})

Dialog diakses melalui manager app.Dialog. Lihat API Dialog untuk referensi lengkap.

// Information dialog
app.Dialog.Info().
SetTitle("Success").
SetMessage("Operation completed!").
Show()
// Error dialog
app.Dialog.Error().
SetTitle("Error").
SetMessage("Something went wrong.").
Show()
// Warning dialog
app.Dialog.Warning().
SetTitle("Warning").
SetMessage("This action cannot be undone.").
Show()

Dialog pertanyaan menggunakan callback tombol untuk menangani respons pengguna:

dialog := app.Dialog.Question().
SetTitle("Confirm").
SetMessage("Continue?")
yes := dialog.AddButton("Yes")
yes.OnClick(func() {
// Handle yes
})
no := dialog.AddButton("No")
no.OnClick(func() {
// Handle no
})
dialog.SetDefaultButton(yes)
dialog.SetCancelButton(no)
dialog.Show()
// Open file dialog
path, err := app.Dialog.OpenFile().
SetTitle("Select File").
AddFilter("Images", "*.png;*.jpg").
PromptForSingleSelection()
// Save file dialog
path, err := app.Dialog.SaveFile().
SetTitle("Save File").
SetFilename("document.pdf").
AddFilter("PDF", "*.pdf").
PromptForSingleSelection()
// Folder selection (use OpenFile with directory options)
path, err := app.Dialog.OpenFile().
SetTitle("Select Folder").
CanChooseDirectories(true).
CanChooseFiles(false).
PromptForSingleSelection()

Aplikasi menyediakan structured logger:

app.Logger.Info("Message", "key", "value")
app.Logger.Error("Error occurred", "error", err)
app.Logger.Debug("Debug info")
app.Logger.Warn("Warning message")

Contoh:

func (s *MyService) ProcessData(data string) error {
s.app.Logger.Info("Processing data", "length", len(data))
if err := process(data); err != nil {
s.app.Logger.Error("Processing failed", "error", err)
return err
}
s.app.Logger.Info("Processing complete")
return nil
}

Untuk aplikasi yang memerlukan kontrol langsung tingkat rendah atas komunikasi frontend-ke-backend, Wails menyediakan opsi RawMessageHandler. Ini melewati sistem binding standar.

RawMessageHandler adalah field pada application.Options, bukan metode. Runtime memanggilnya untuk setiap raw message yang dikirim dari frontend via System.invoke().

type Options struct {
// ... other fields ...
RawMessageHandler func(window Window, message string, originInfo *OriginInfo)
}

OriginInfo membawa Origin, TopOrigin, dan IsMainFrame (platform mengisi subset berbeda — lihat Panduan Raw Messages untuk matriks per platform).

Contoh:

app := application.New(application.Options{
Name: "My App",
RawMessageHandler: func(window application.Window, message string, originInfo *application.OriginInfo) {
// Handle the raw message
fmt.Printf("Received from %s (%s): %s\n", window.Name(), originInfo.Origin, message)
// You can respond using events
window.EmitEvent("response", processMessage(message))
},
})

Untuk detail selengkapnya, lihat Panduan Raw Messages.

Konfigurasi perilaku khusus Windows di level aplikasi:

app := application.New(application.Options{
Name: "My App",
Windows: application.WindowsOptions{
// WebView2 browser flags (apply to ALL windows)
EnabledFeatures: []string{"msWebView2EnableDraggableRegions"},
DisabledFeatures: []string{"msExperimentalFeature"},
AdditionalBrowserArgs: []string{"--remote-debugging-port=9222"},
// Other Windows options
WndClass: "MyAppClass",
WebviewUserDataPath: "", // Default: %APPDATA%\[BinaryName.exe]
WebviewBrowserPath: "", // Default: system WebView2
DisableQuitOnLastWindowClosed: false,
},
})

Flag Browser:

  • EnabledFeatures - Feature flag WebView2 untuk diaktifkan
  • DisabledFeatures - Feature flag WebView2 untuk dinonaktifkan
  • AdditionalBrowserArgs - Argumen command-line Chromium

Lihat Opsi Window - Opsi Windows Level Aplikasi untuk dokumentasi detail.

app := application.New(application.Options{
Name: "My App",
Mac: application.MacOptions{
ActivationPolicy: application.ActivationPolicyRegular,
ApplicationShouldTerminateAfterLastWindowClosed: true,
},
})
app := application.New(application.Options{
Name: "My App",
Linux: application.LinuxOptions{
ProgramName: "my-app",
DisableQuitOnLastWindowClosed: false,
},
})
package main
import (
"github.com/wailsapp/wails/v3/pkg/application"
)
func main() {
app := application.New(application.Options{
Name: "My Application",
Description: "A demo application",
Mac: application.MacOptions{
ApplicationShouldTerminateAfterLastWindowClosed: true,
},
})
// Create main window
window := app.Window.NewWithOptions(application.WebviewWindowOptions{
Title: "My App",
Width: 1024,
Height: 768,
MinWidth: 800,
MinHeight: 600,
BackgroundColour: application.NewRGB(255, 255, 255),
URL: "http://wails.localhost/",
})
window.Center()
window.Show()
app.Run()
}