mirror of
https://git.sr.ht/~eliasnaur/gio
synced 2026-07-04 17:05:38 +00:00
widget: [API] move Enum state update to Changed, rename it to Update
Similar to an earlier change for other widgets, this change separate Enum state changes for access earlier than Layout. Signed-off-by: Elias Naur <mail@eliasnaur.com>
This commit is contained in:
+50
-51
@@ -20,8 +20,6 @@ type Enum struct {
|
|||||||
focus string
|
focus string
|
||||||
focused bool
|
focused bool
|
||||||
|
|
||||||
changed bool
|
|
||||||
|
|
||||||
keys []*enumKey
|
keys []*enumKey
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -40,11 +38,55 @@ func (e *Enum) index(k string) *enumKey {
|
|||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
// Changed reports whether Value has changed by user interaction since the last
|
// Update the state and report whether Value has changed by user interaction.
|
||||||
// call to Changed.
|
func (e *Enum) Update(gtx layout.Context) bool {
|
||||||
func (e *Enum) Changed() bool {
|
if gtx.Queue == nil {
|
||||||
changed := e.changed
|
e.focused = false
|
||||||
e.changed = false
|
}
|
||||||
|
e.hovering = false
|
||||||
|
changed := false
|
||||||
|
for _, state := range e.keys {
|
||||||
|
for _, ev := range state.click.Events(gtx) {
|
||||||
|
switch ev.Kind {
|
||||||
|
case gesture.KindPress:
|
||||||
|
if ev.Source == pointer.Mouse {
|
||||||
|
key.FocusOp{Tag: &state.tag}.Add(gtx.Ops)
|
||||||
|
}
|
||||||
|
case gesture.KindClick:
|
||||||
|
if state.key != e.Value {
|
||||||
|
e.Value = state.key
|
||||||
|
changed = true
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
for _, ev := range gtx.Events(&state.tag) {
|
||||||
|
switch ev := ev.(type) {
|
||||||
|
case key.FocusEvent:
|
||||||
|
if ev.Focus {
|
||||||
|
e.focused = true
|
||||||
|
e.focus = state.key
|
||||||
|
} else if state.key == e.focus {
|
||||||
|
e.focused = false
|
||||||
|
}
|
||||||
|
case key.Event:
|
||||||
|
if !e.focused || ev.State != key.Release {
|
||||||
|
break
|
||||||
|
}
|
||||||
|
if ev.Name != key.NameReturn && ev.Name != key.NameSpace {
|
||||||
|
break
|
||||||
|
}
|
||||||
|
if state.key != e.Value {
|
||||||
|
e.Value = state.key
|
||||||
|
changed = true
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if state.click.Hovered() {
|
||||||
|
e.hovered = state.key
|
||||||
|
e.hovering = true
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
return changed
|
return changed
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -60,6 +102,7 @@ func (e *Enum) Focused() (string, bool) {
|
|||||||
|
|
||||||
// Layout adds the event handler for the key k.
|
// Layout adds the event handler for the key k.
|
||||||
func (e *Enum) Layout(gtx layout.Context, k string, content layout.Widget) layout.Dimensions {
|
func (e *Enum) Layout(gtx layout.Context, k string, content layout.Widget) layout.Dimensions {
|
||||||
|
e.Update(gtx)
|
||||||
m := op.Record(gtx.Ops)
|
m := op.Record(gtx.Ops)
|
||||||
dims := content(gtx)
|
dims := content(gtx)
|
||||||
c := m.Stop()
|
c := m.Stop()
|
||||||
@@ -73,54 +116,10 @@ func (e *Enum) Layout(gtx layout.Context, k string, content layout.Widget) layou
|
|||||||
e.keys = append(e.keys, state)
|
e.keys = append(e.keys, state)
|
||||||
}
|
}
|
||||||
clk := &state.click
|
clk := &state.click
|
||||||
for _, ev := range clk.Events(gtx) {
|
|
||||||
switch ev.Kind {
|
|
||||||
case gesture.KindPress:
|
|
||||||
if ev.Source == pointer.Mouse {
|
|
||||||
key.FocusOp{Tag: &state.tag}.Add(gtx.Ops)
|
|
||||||
}
|
|
||||||
case gesture.KindClick:
|
|
||||||
if state.key != e.Value {
|
|
||||||
e.Value = state.key
|
|
||||||
e.changed = true
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
for _, ev := range gtx.Events(&state.tag) {
|
|
||||||
switch ev := ev.(type) {
|
|
||||||
case key.FocusEvent:
|
|
||||||
if ev.Focus {
|
|
||||||
e.focused = true
|
|
||||||
e.focus = state.key
|
|
||||||
} else if state.key == e.focus {
|
|
||||||
e.focused = false
|
|
||||||
}
|
|
||||||
case key.Event:
|
|
||||||
if !e.focused || ev.State != key.Release {
|
|
||||||
break
|
|
||||||
}
|
|
||||||
if ev.Name != key.NameReturn && ev.Name != key.NameSpace {
|
|
||||||
break
|
|
||||||
}
|
|
||||||
if state.key != e.Value {
|
|
||||||
e.Value = state.key
|
|
||||||
e.changed = true
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if clk.Hovered() {
|
|
||||||
e.hovered = k
|
|
||||||
e.hovering = true
|
|
||||||
} else if e.hovered == k {
|
|
||||||
e.hovering = false
|
|
||||||
}
|
|
||||||
|
|
||||||
clk.Add(gtx.Ops)
|
clk.Add(gtx.Ops)
|
||||||
enabled := gtx.Queue != nil
|
enabled := gtx.Queue != nil
|
||||||
if enabled {
|
if enabled {
|
||||||
key.InputOp{Tag: &state.tag, Keys: "⏎|Space"}.Add(gtx.Ops)
|
key.InputOp{Tag: &state.tag, Keys: "⏎|Space"}.Add(gtx.Ops)
|
||||||
} else if e.focus == k {
|
|
||||||
e.focused = false
|
|
||||||
}
|
}
|
||||||
semantic.SelectedOp(k == e.Value).Add(gtx.Ops)
|
semantic.SelectedOp(k == e.Value).Add(gtx.Ops)
|
||||||
semantic.EnabledOp(enabled).Add(gtx.Ops)
|
semantic.EnabledOp(enabled).Add(gtx.Ops)
|
||||||
|
|||||||
Reference in New Issue
Block a user