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
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
|
package main
import (
"image/color"
"log"
"gioui.org/io/system"
"gioui.org/layout"
"gioui.org/text"
"gioui.org/widget"
"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 {
wl := widget.List{
List: layout.List{
Axis: layout.Vertical,
},
}
ml := material.List(l.Theme, wl)
return list.Layout(gtx, len(widgets), func(gtx layout.Context, i int) layout.Dimensions {
return layout.UniformInset(unit.Dp(16)).Layout(gtx, widgets[i])
})
},
),
// l := material.List(th, list).Layout(gtx, len(widgets), func(gtx C, i int) D {
// return layout.UniformInset(unit.Dp(16)).Layout(gtx, widgets[i])
// }
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
}
|