about summary refs log tree commit diff stats
diff options
context:
space:
mode:
-rw-r--r--res/config.toml9
-rw-r--r--src/local/pager.nim9
2 files changed, 15 insertions, 3 deletions
diff --git a/res/config.toml b/res/config.toml
index 48eb0e64..ea3fcff5 100644
--- a/res/config.toml
+++ b/res/config.toml
@@ -124,7 +124,14 @@ scrollUp = 'n => pager.scrollUp(n)'
 scrollLeft = 'n => pager.scrollLeft(n)'
 scrollRight = 'n => pager.scrollRight(n)'
 click = '() => pager.click()'
-viewImage = '() => pager.gotoURL(pager.hoverImage)'
+viewImage = '''
+() => {
+	if (pager.hoverImage) {
+		const headers = new Headers({Accept: "*/*"});
+		pager.gotoURL(new Request(pager.hoverImage, {headers: headers}));
+	}
+}
+'''
 toggleImages = '() => pager.toggleImages()'
 markURL = '() => pager.markURL()'
 redraw = '() => pager.redraw()'
diff --git a/src/local/pager.nim b/src/local/pager.nim
index 16cd20a0..8076020f 100644
--- a/src/local/pager.nim
+++ b/src/local/pager.nim
@@ -1302,8 +1302,13 @@ proc load(pager: Pager; s = "") {.jsfunc.} =
     pager.setLineEdit(lmLocation, s)
 
 # Go to specific URL (for JS)
-proc jsGotoURL(pager: Pager; s: string): JSResult[void] {.jsfunc: "gotoURL".} =
-  pager.gotoURL(newRequest(?newURL(s)))
+proc jsGotoURL(pager: Pager; v: JSValue): JSResult[void] {.jsfunc: "gotoURL".} =
+  let req = fromJS[JSRequest](pager.jsctx, v)
+  if req.isSome:
+    pager.gotoURL(req.get.request)
+  else:
+    let s = ?fromJS[string](pager.jsctx, v)
+    pager.gotoURL(newRequest(?newURL(s)))
   ok()
 
 # Reload the page in a new buffer, then kill the previous buffer.