Go to file Use this template
2025-02-24 12:55:12 +01:00
frontend add notifications 2025-02-24 12:55:12 +01:00
model add gorm backend 2025-02-10 13:00:41 +01:00
things add gorm backend 2025-02-10 13:00:41 +01:00
.gitignore cross compile for windows 2025-02-10 11:38:45 +01:00
app.go add notifications 2025-02-24 12:55:12 +01:00
go.mod add notifications 2025-02-24 12:55:12 +01:00
go.sum add notifications 2025-02-24 12:55:12 +01:00
main.go add gorm backend 2025-02-10 13:00:41 +01:00
README.md add notifications 2025-02-24 12:55:12 +01:00
setup.sh replace author 2025-02-19 15:17:23 +01:00
wails.json add gorm backend 2025-02-10 13:00:41 +01:00

README

Fixes

X-Compilation

for Windows:

sudo pacman -S mingw-w64-gcc
wails dev # to generate bindings
env GOOS=windows GOARCH=amd64 CGO_ENABLED=1 CC=x86_64-w64-mingw32-gcc CXX=x86_64-w64-mingw32-g++ CGO_CXXFLAGS="-IC:\msys64\mingw64\include" wails build -ldflags '-extldflags "-static"' -skipbindings

Branches:

  • main: in memory
  • gorm-sqlite: gorm with SQLite and one to many association.

Live Development

To run in live development mode, run wails dev in the project directory. This will run a Vite development server that will provide very fast hot reload of your frontend changes. If you want to develop in a browser and have access to your Go methods, there is also a dev server that runs on http://localhost:34115. Connect to this in your browser, and you can call your Go code from devtools.

Building

To build a redistributable, production mode package, use wails build.

Tricks:

Notifications:

err := beeep.Notify("Title", "Content", "path/to/icon.png")
if err != nil {
  // handle error
}

Inputs for date objects

<div class="m-5">
<Label>Start</Label>
<Input
  type="datetime-local"
  value={session.Start.toISOString().slice(0, 16)}
  onchange={(e) => {
    // @ts-ignore
    session.Start = new Date(e.target.value);
  }}
  required
/>