From aeb455a577c0a20684f357ff737203b5cb419cd4 Mon Sep 17 00:00:00 2001 From: Jez Ng Date: Fri, 26 Oct 2012 13:27:37 -0400 Subject: Implement marks. --- content_scripts/marks.coffee | 45 ++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 45 insertions(+) create mode 100644 content_scripts/marks.coffee (limited to 'content_scripts/marks.coffee') diff --git a/content_scripts/marks.coffee b/content_scripts/marks.coffee new file mode 100644 index 00000000..e280a3b1 --- /dev/null +++ b/content_scripts/marks.coffee @@ -0,0 +1,45 @@ +root = window.Marks = {} + +root.activateCreateMode = -> + handlerStack.push keydown: (e) -> + keyChar = KeyboardUtils.getKeyChar(event) + return unless keyChar isnt "" + + if /[A-Z]/.test keyChar + chrome.extension.sendRequest { + handler: 'createMark', + markName: keyChar + scrollX: window.scrollX, + scrollY: window.scrollY + }, -> HUD.showForDuration "Created global mark '#{keyChar}'", 1000 + else if /[a-z]/.test keyChar + [baseLocation, sep, hash] = window.location.href.split '#' + localStorage["vimiumMark|#{baseLocation}|#{keyChar}"] = JSON.stringify + scrollX: window.scrollX, + scrollY: window.scrollY + HUD.showForDuration "Created local mark '#{keyChar}'", 1000 + + @remove() + + false + +root.activateGotoMode = -> + handlerStack.push keydown: (e) -> + keyChar = KeyboardUtils.getKeyChar(event) + return unless keyChar isnt "" + + if /[A-Z]/.test keyChar + chrome.extension.sendRequest + handler: 'gotoMark' + markName: keyChar + else if /[a-z]/.test keyChar + [baseLocation, sep, hash] = window.location.href.split '#' + markString = localStorage["vimiumMark|#{baseLocation}|#{keyChar}"] + if markString? + mark = JSON.parse markString + window.scrollTo mark.scrollX, mark.scrollY + HUD.showForDuration "Jumped to local mark '#{keyChar}'", 1000 + + @remove() + + false -- cgit v1.2.3