summaryrefslogtreecommitdiff
path: root/gui.go
blob: 3f0e42e3f4366892e09705c68de75e0d57abcce6 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
package main

import (
	"image/color"
	"log"

	"gioui.org/io/system"
	"gioui.org/layout"
	"gioui.org/text"
	"gioui.org/widget/material"
)

func (l *Limox) draw(e system.FrameEvent) {
	switch l.State {
	case Connected:
		l.rosterView(e)
	default:
		l.mainView(e)
	}
}

func (l *Limox) rosterView(e system.FrameEvent) {
	gtx := layout.NewContext(&l.Operations, e)

	flex := layout.Flex{
		Axis:    layout.Vertical,
		Spacing: layout.SpaceStart,
	}

	widgets := make([]layout.Widget, 0)
	for _, v := range l.Roster {
		widgets = append(widgets, func(gtx layout.Context) layout.Dimensions {
			jid := material.H6(l.Theme, v.Jid)
			return jid.Layout(gtx)
		})
	}

	flex.Layout(gtx,
		layout.Rigid(
			func(gtx layout.Context) layout.Dimensions {
				btn := material.Button(l.Theme, &l.DisconnectButton,
					"Disconnect")
				return btn.Layout(gtx)
			},
		),
	)

	e.Frame(gtx.Ops)
}

func (l *Limox) mainView(e system.FrameEvent) {
	gtx := layout.NewContext(&l.Operations, e)

	flex := layout.Flex{
		Axis:    layout.Vertical,
		Spacing: layout.SpaceBetween,
	}

	flex.Layout(gtx,
		layout.Rigid(
			func(gtx layout.Context) layout.Dimensions {
				h2 := material.H2(l.Theme, "LimoX")
				h2.Color = color.NRGBA{R: 20, G: 20, B: 20, A: 255}
				h2.Alignment = text.Middle
				return h2.Layout(gtx)
			},
		),
		layout.Rigid(
			func(gtx layout.Context) layout.Dimensions {
				jid := material.Editor(l.Theme, &l.JidEditor, "user@example.com")
				jid.Editor.Alignment = text.Middle
				return jid.Layout(gtx)
			},
		),
		layout.Rigid(
			func(gtx layout.Context) layout.Dimensions {
				pwd := material.Editor(l.Theme, &l.PwdEditor, "mySafePassword")
				pwd.Editor.Alignment = text.Middle
				pwd.Editor.Mask = '*'
				return pwd.Layout(gtx)
			},
		),
		layout.Rigid(
			func(gtx layout.Context) layout.Dimensions {
				btn := material.Button(l.Theme, &l.ConnectButton,
					l.buttonLabel())
				return btn.Layout(gtx)
			},
		),
	)

	e.Frame(gtx.Ops)
}

func (l *Limox) buttonLabel() string {
	var label string
	switch l.State {
	case Disconnected:
		label = "Connect"
	case Connecting:
		label = "Abort"
	case Connected:
		label = "Disconnect"
	default:
		log.Printf("Unknown Limox state '%d'\n", l.State)
	}
	return label
}