Compare commits

...

6 Commits

Author SHA1 Message Date
Maarten Heremans
7325554288 Updated i18n to v0.1.0 2024-08-12 14:39:46 +02:00
Maarten Heremans
40dad494d9 Added ability to prevent closing the app when the view is displayed 2024-08-12 14:37:42 +02:00
Maarten Heremans
ce11540123 Fix dialog layout 2024-08-06 21:30:11 +02:00
64e96e6800 Merge pull request 'move-to-gitea' (#1) from move-to-gitea into main
Reviewed-on: #1
2024-08-06 10:32:27 +02:00
Maarten Heremans
e2fa726a37 Modified code for move to gitea.hevanto-it.com 2024-08-06 10:31:43 +02:00
987d25ecd0 Update go.mod 2024-08-06 10:23:04 +02:00
14 changed files with 124 additions and 22 deletions

View File

@@ -148,3 +148,7 @@ func (v *BaseView) RegisterResizeCallback(cb ResizeCallbackFn) {
func (v *BaseView) RegisterMoveCallback(cb MoveCallbackFn) {
v.ScreenHandler.RegisterMoveCallback(cb)
}
func (v BaseView) PreventClose() bool {
return false
}

View File

@@ -5,11 +5,11 @@ import (
"fmt"
"io/fs"
"bitbucket.org/hevanto/ui/screen"
"fyne.io/fyne/v2"
"fyne.io/fyne/v2/data/binding"
"fyne.io/fyne/v2/dialog"
"fyne.io/fyne/v2/widget"
"gitea.hevanto-it.com/hevanto/ui/screen"
"github.com/google/uuid"
"github.com/nicksnyder/go-i18n/v2/i18n"
)
@@ -100,7 +100,7 @@ func NewBaseDialogWithScreen(
parent, confirm)
var err error
d.ScreenHandler, err = NewScreenHandler(
d.ScreenHandler, err = NewDialogScreenHandler(
filesystem, screenName, viewModel, localizer, assetLoader)
if err != nil {
LogWindowError(d, LoadScreen, err)
@@ -148,7 +148,7 @@ func NewBaseDialogWithDataAndScreen(
parent, confirm, data)
var err error
d.ScreenHandler, err = NewScreenHandler(
d.ScreenHandler, err = NewDialogScreenHandler(
filesystem, screenName, viewModel, localizer, assetLoader)
if err != nil {
LogWindowError(d, LoadScreen, err)
@@ -228,7 +228,7 @@ func (d *BaseDialog) Initialize() fyne.CanvasObject {
LogWindowError(d, Initialize, err)
return nil
}
d.CanvasObj = obj
d.CanvasObj = obj.(*screen.DialogScreen).AsContainer()
}
return d.CanvasObj
}
@@ -256,6 +256,10 @@ func (d *BaseDialog) GetCanvasObject() fyne.CanvasObject {
return d.CanvasObj
}
func (d BaseDialog) PreventClose() bool {
return false
}
type FormDialogItemsFn func() []*widget.FormItem
type FormDialog struct {
@@ -358,7 +362,7 @@ func (d *FormDialog) SetButtonLabels(
func (d *FormDialog) Initialize() fyne.CanvasObject {
if d.itemsFn == nil {
form := d.BaseDialog.Initialize().(*screen.Screen).AsContainer()
form := d.BaseDialog.Initialize().(*fyne.Container)
d.itemsFn = func() []*widget.FormItem {
res := make([]*widget.FormItem, 0, len(form.Objects)/2)
for i := 0; i < len(form.Objects); i += 2 {

4
go.mod
View File

@@ -1,11 +1,11 @@
module bitbucket.org/hevanto/ui
module gitea.hevanto-it.com/hevanto/ui
go 1.22.1
require (
bitbucket.org/hevanto/i18n v0.0.0-20240508095543-e6c69773011a
fyne.io/fyne/v2 v2.4.5
fyne.io/x/fyne v0.0.0-20240421102438-d5a080914907
gitea.hevanto-it.com/hevanto/i18n v0.1.0
github.com/google/uuid v1.6.0
github.com/nicksnyder/go-i18n/v2 v2.4.0
gopkg.in/yaml.v2 v2.4.0

4
go.sum
View File

@@ -1,5 +1,3 @@
bitbucket.org/hevanto/i18n v0.0.0-20240508095543-e6c69773011a h1:c2jY4iLeCeWGPX7gi92w21OPzeR2jwbPrb4G2FtsEpE=
bitbucket.org/hevanto/i18n v0.0.0-20240508095543-e6c69773011a/go.mod h1:H9tdjNHWWrrOOqOduC1WCTRLswAmjvxb19akWOef9EU=
cloud.google.com/go v0.26.0/go.mod h1:aQUYkXzVsufM+DwF1aE+0xfcU+56JwCaLick0ClmMTw=
cloud.google.com/go v0.34.0/go.mod h1:aQUYkXzVsufM+DwF1aE+0xfcU+56JwCaLick0ClmMTw=
cloud.google.com/go v0.38.0/go.mod h1:990N+gfupTy94rShfmMCWGDn0LpTmnzTp2qbd1dvSRU=
@@ -43,6 +41,8 @@ fyne.io/fyne/v2 v2.4.5 h1:W6jpAEmLoBbKyBB+EXqI7GMJ7kLgHQWCa0wZHUV2VfQ=
fyne.io/fyne/v2 v2.4.5/go.mod h1:SlOgbca0y80cRObu/JOhxIJdIgtoW7aCyqUVlTMgs0Y=
fyne.io/x/fyne v0.0.0-20240421102438-d5a080914907 h1:Ajr8gCMkVv6f7H2IPviMjfZCq40/+HrgWhAh/ZUOm/k=
fyne.io/x/fyne v0.0.0-20240421102438-d5a080914907/go.mod h1:1pa3ZVIopRWNvfSG4ZrSkcZ3mJ8qoHPZv4PT8/zpn1o=
gitea.hevanto-it.com/hevanto/i18n v0.1.0 h1:SHsFugp1p+1a63MYrkXVAfgRp1zTSXWv3a6c/gU9Oy0=
gitea.hevanto-it.com/hevanto/i18n v0.1.0/go.mod h1:Ib85itweX6FuNHKFJNlMHglTq02TqaYdgvr4xDaQtQY=
github.com/BurntSushi/toml v0.3.1/go.mod h1:xHWCNGjB5oqiDr8zfno3MHue2Ht5sIBksp03qcyfWMU=
github.com/BurntSushi/toml v1.3.2 h1:o7IhLm0Msx3BaB+n3Ag7L8EVlByGnpq14C4YWiu/gL8=
github.com/BurntSushi/toml v1.3.2/go.mod h1:CxXYINrC8qIiEnFrOxCa7Jy5BFHlXnUU2pbicEuybxQ=

View File

@@ -1,7 +1,7 @@
package screen
import (
"bitbucket.org/hevanto/ui/uiwidget"
"gitea.hevanto-it.com/hevanto/ui/uiwidget"
"fyne.io/fyne/v2"
"fyne.io/fyne/v2/container"
"fyne.io/fyne/v2/layout"

View File

@@ -3,7 +3,7 @@ package screen
import (
"fmt"
"bitbucket.org/hevanto/i18n"
"gitea.hevanto-it.com/hevanto/i18n"
"fyne.io/fyne/v2"
)
@@ -47,6 +47,11 @@ func (p *Padding) HasPadding() bool {
return p.Top > 0 || p.Bottom > 0 || p.Left > 0 || p.Right > 0
}
type ToolTip struct {
Content string `yaml:"content"`
Localized bool `yaml:"localized"`
}
// Element represents the yaml description of a ui element
type Element struct {
ID string `yaml:"id"`
@@ -97,6 +102,7 @@ type Element struct {
Options map[string]any `yaml:"options"`
Disabled bool `yaml:"disabled"`
Hidden bool `yaml:"hidden"`
ToolTip *ToolTip `yaml:"tooltip"`
// Properties shared by most widgets
Placeholder string `yaml:"placeholder"`

View File

@@ -4,7 +4,7 @@ import (
"errors"
"fmt"
"bitbucket.org/hevanto/ui/uilayout"
"gitea.hevanto-it.com/hevanto/ui/uilayout"
"fyne.io/fyne/v2"
"fyne.io/fyne/v2/container"
"fyne.io/fyne/v2/layout"

View File

@@ -1,7 +1,7 @@
package screen
import (
"bitbucket.org/hevanto/ui/uilayout"
"gitea.hevanto-it.com/hevanto/ui/uilayout"
"fyne.io/fyne/v2"
"fyne.io/fyne/v2/container"
)

View File

@@ -1,7 +1,7 @@
package screen
import (
"bitbucket.org/hevanto/ui/uilayout"
"gitea.hevanto-it.com/hevanto/ui/uilayout"
"fyne.io/fyne/v2"
"fyne.io/fyne/v2/container"
)

View File

@@ -133,8 +133,12 @@ func (s *Screen) Resize(sz fyne.Size) {
}
}
func (s *Screen) MinSize() fyne.Size {
return s.CanvasObject.MinSize()
}
func (s *Screen) CreateRenderer() fyne.WidgetRenderer {
return widget.NewSimpleRenderer(s.CanvasObject)
return widget.NewSimpleRenderer(s.AsContainer())
}
func (s *Screen) RegisterResizeCallback(cb func(fyne.Size)) {
@@ -149,6 +153,42 @@ func (s *Screen) AsContainer() *fyne.Container {
return s.CanvasObject.(*fyne.Container)
}
type DialogScreen struct {
*Screen
}
func NewDialogScreen(
filesystem embed.FS,
name string,
screenHandler ScreenHandler,
) (src *DialogScreen, err error) {
screen, err := New(filesystem, name, screenHandler)
if err != nil {
return
}
src = &DialogScreen{screen}
return
}
func (s *DialogScreen) Initialize() (obj fyne.CanvasObject, err error) {
if s.CanvasObject, err = s.rootElement.BuildUI(s.screenHandler); err != nil {
err = fmt.Errorf("failed to build screen: %w", err)
return
}
obj = s
return
}
func (s *DialogScreen) Move(p fyne.Position) {
c := fyne.CurrentApp().Driver().CanvasForObject(s.CanvasObject)
movePos := fyne.Position{
X: p.X / c.Scale(),
Y: p.Y / c.Scale(),
}
s.CanvasObject.Move(movePos)
//fmt.Printf("%+v\n", s.CanvasObject.Position());
}
type TemplateScreenHandler struct {
localizer *i18n.Localizer
elementsMap map[string]*UIElement

View File

@@ -7,7 +7,7 @@ import (
"strconv"
"time"
"bitbucket.org/hevanto/ui/uiwidget"
"gitea.hevanto-it.com/hevanto/ui/uiwidget"
"fyne.io/fyne/v2"
"fyne.io/fyne/v2/data/binding"
"fyne.io/fyne/v2/layout"

View File

@@ -2,18 +2,34 @@ package ui
import (
"embed"
"errors"
"fmt"
"io/fs"
"log"
"strings"
"bitbucket.org/hevanto/ui/screen"
"gitea.hevanto-it.com/hevanto/ui/screen"
"fyne.io/fyne/v2"
"fyne.io/fyne/v2/data/binding"
"fyne.io/fyne/v2/theme"
"github.com/nicksnyder/go-i18n/v2/i18n"
)
type screenType int
const (
stScreen screenType = iota
stDialog
)
type ScreenDefinition interface {
fyne.Widget
Initialize() (fyne.CanvasObject, error)
RegisterResizeCallback(func(fyne.Size))
RegisterMoveCallback(func(fyne.Position))
AsContainer() *fyne.Container
}
// ScreenHandler represents the handler for a screen.
//
// It provides:
@@ -24,7 +40,7 @@ import (
// - List item templates and renderers
// - User interaction handlers
type ScreenHandler struct {
screenDefinition *screen.Screen
screenDefinition ScreenDefinition
localizer *i18n.Localizer
viewModel BaseViewModel
assetLoader func(string) (fs.File, error)
@@ -63,18 +79,48 @@ func NewScreenHandler(
viewModel BaseViewModel,
localizer *i18n.Localizer,
assetLoader func(string) (fs.File, error),
) (h *ScreenHandler, err error) {
return newScreenHandler(
stScreen, filesystem, screenName, viewModel, localizer, assetLoader)
}
func NewDialogScreenHandler(
filesystem embed.FS,
screenName string,
viewModel BaseViewModel,
localizer *i18n.Localizer,
assetLoader func(string) (fs.File, error),
) (h *ScreenHandler, err error) {
return newScreenHandler(
stDialog, filesystem, screenName, viewModel, localizer, assetLoader)
}
func newScreenHandler(
screenType screenType,
fileSystem embed.FS,
screenName string,
viewModel BaseViewModel,
localizer *i18n.Localizer,
assetLoader func(string) (fs.File, error),
) (h *ScreenHandler, err error) {
h = new(ScreenHandler)
h.viewModel = viewModel
h.localizer = localizer
def, err := screen.New(filesystem, screenName, h)
switch screenType {
case stScreen:
h.screenDefinition, err = screen.New(fileSystem, screenName, h)
case stDialog:
h.screenDefinition, err = screen.NewDialogScreen(fileSystem, screenName, h)
default:
err = errors.New("Unsupported screen type")
}
if err != nil {
err = fmt.Errorf("failure loading screen: %w", err)
return
}
h.screenDefinition = def
h.assetLoader = assetLoader
h.exportedElements = make(map[string]*screen.UIElement)
@@ -93,7 +139,7 @@ func NewScreenHandler(
}
// ScreenDefinition returns the screen definition for the ScreenHandler.
func (h *ScreenHandler) ScreenDefinition() *screen.Screen {
func (h *ScreenHandler) ScreenDefinition() ScreenDefinition {
return h.screenDefinition
}

View File

@@ -4,7 +4,7 @@ import (
"fmt"
"strings"
"bitbucket.org/hevanto/ui/uilayout"
"gitea.hevanto-it.com/hevanto/ui/uilayout"
"fyne.io/fyne/v2"
"fyne.io/fyne/v2/container"
"fyne.io/fyne/v2/data/binding"

View File

@@ -54,4 +54,6 @@ type View interface {
OnHide()
GetCanvasObject() fyne.CanvasObject
PreventClose() bool
}