ref: 0639326eebcfbf54440d100feceb90ee9400b49a
parent: 4eda0a73c1b856dd4d41c2fcea49e3e2e1b00725
author: Philip Silva <[email protected]>
date: Sun Jan 3 14:17:59 EST 2021
Fix a click closure
--- a/browser/browser.go
+++ b/browser/browser.go
@@ -31,6 +31,8 @@
const stashElements = true
const experimentalUseSlicedDrawing = false
+const EnterKey = 10
+
var cursor = [2 * 16]uint8{255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 90, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255}
var DebugDumpCSS *bool
@@ -440,7 +442,12 @@
return
}
- f := browser.SetAndLoadUrl(href)
+ u, err := browser.LinkedUrl(href)
+ if err != nil {
+ log.Errorf("makeLink from %v: %v", href, err)
+ return
+ }
+ f := browser.SetAndLoadUrl(u)
TraverseTree(el, func(ui duit.UI) {
el, ok := ui.(*Element)
if ok && el != nil {
@@ -1015,7 +1022,7 @@
}
func PrintTree(ui duit.UI) {
- if log.Debug {
+ if log.Debug && debugPrintHtml {
printTree(0, ui)
}
}
@@ -1128,8 +1135,17 @@
Text: initUrl,
Font: Style.Font(),
Keys: func(k rune, m draw.Mouse) (e duit.Event) {
- if k == 10 {
- return b.LoadUrl()
+ if k == EnterKey {
+ a := b.LocationField.Text
+ if !strings.HasPrefix(strings.ToLower(a), "http") {
+ a = "http://" + a
+ }
+ u, err := url.Parse(a)
+ if err != nil {
+ log.Errorf("parse url: %v", err)
+ return
+ }
+ return b.LoadUrl(u)
}
return
},
@@ -1189,24 +1205,16 @@
if len(b.History.urls) > 0 {
b.History.Back()
b.LocationField.Text = b.History.URL().String()
- b.LoadUrl()
+ b.LoadUrl(b.History.URL())
}
e.Consumed = true
return
}
-func (b *Browser) SetAndLoadUrl(addr string) func() duit.Event {
- a := addr
+func (b *Browser) SetAndLoadUrl(u *url.URL) func() duit.Event {
return func() duit.Event {
- log.Printf("SetAndLoadUrl::callback: addr=%v", addr)
- log.Printf(" b.URL=%v", b.URL())
- url, err := b.LinkedUrl(addr)
- if err == nil {
- b.LocationField.Text = url.String()
- b.LoadUrl()
- } else {
- log.Printf("parse url %v: %v", a, err)
- }
+ b.LocationField.Text = u.String()
+ b.LoadUrl(u)
return duit.Event{
Consumed: true,
@@ -1224,26 +1232,12 @@
dui.Render()
}
-func (b *Browser) LoadUrl() (e duit.Event) {
- addr := b.LocationField.Text
- if !strings.HasPrefix(addr, "http") {
- addr = "http://" + addr
- }
- log.Printf("Getting %v...", addr)
- url, err := url.Parse(addr)
- if err != nil {
- log.Errorf("load url: error parsing %v", addr)
- return
- }
+func (b *Browser) LoadUrl(url *url.URL) (e duit.Event) {
buf, contentType, err := b.get(url, true)
if err != nil {
- log.Errorf("error loading %v: %v", addr, err)
+ log.Errorf("error loading %v: %v", url, err)
if er := errors.Unwrap(err); er != nil {
err = er
- }
- if strings.Contains(err.Error(), "HTTP response to HTTPS client") {
- b.LocationField.Text = strings.Replace(url.String(), "https://", "http://", 1)
- return b.LoadUrl()
}
b.showBodyMessage(err.Error())
return
--- a/browser/browser_test.go
+++ b/browser/browser_test.go
@@ -104,4 +104,3 @@
t.Fail()
}
}
-