aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorusk <usk@>2018-01-03 07:19:25 +0900
committerusk <usk@>2018-01-03 07:34:41 +0900
commit54a7662cd1e7372910e9ce81aae1a904f3b26c82 (patch)
tree36ffce8107cb7242b540d88cf4f4d4db709de3af /src
parentf484fda718d86603bee0c739f54a6156a012162a (diff)
open clipboard's URL in current/new tab
Diffstat (limited to 'src')
-rw-r--r--src/content/actions/operation.js2
-rw-r--r--src/content/urls.js26
-rw-r--r--src/settings/components/form/keymaps-form.jsx2
-rw-r--r--src/shared/operations.js3
-rw-r--r--src/shared/settings/default.js2
5 files changed, 33 insertions, 2 deletions
diff --git a/src/content/actions/operation.js b/src/content/actions/operation.js
index 767f14b..0a5cd97 100644
--- a/src/content/actions/operation.js
+++ b/src/content/actions/operation.js
@@ -60,6 +60,8 @@ const exec = (operation) => {
type: messages.CONSOLE_SHOW_INFO,
text: 'Current url yanked',
});
+ case operations.URLS_PASTE:
+ return urls.paste(window, operation.newTab ? operation.newTab : false);
default:
browser.runtime.sendMessage({
type: messages.BACKGROUND_OPERATION,
diff --git a/src/content/urls.js b/src/content/urls.js
index 8f8a1ac..9b7b284 100644
--- a/src/content/urls.js
+++ b/src/content/urls.js
@@ -1,3 +1,5 @@
+import messages from 'shared/messages';
+
const yank = (win) => {
let input = win.document.createElement('input');
win.document.body.append(input);
@@ -12,4 +14,26 @@ const yank = (win) => {
input.remove();
};
-export { yank };
+const paste = (win, newTab) => {
+ let textarea = win.document.createElement('textarea');
+ win.document.body.append(textarea);
+
+ textarea.style.position = 'fixed';
+ textarea.style.top = '-100px';
+ textarea.contentEditable = 'true';
+ textarea.focus();
+
+ if (win.document.execCommand('paste')) {
+ if (/^(https?|ftp):\/\//.test(textarea.textContent)) {
+ browser.runtime.sendMessage({
+ type: messages.OPEN_URL,
+ url: textarea.textContent,
+ newTab: newTab ? newTab : false,
+ });
+ }
+ }
+
+ textarea.remove();
+};
+
+export { yank, paste };
diff --git a/src/settings/components/form/keymaps-form.jsx b/src/settings/components/form/keymaps-form.jsx
index c399570..eb77e52 100644
--- a/src/settings/components/form/keymaps-form.jsx
+++ b/src/settings/components/form/keymaps-form.jsx
@@ -52,6 +52,8 @@ const KeyMapFields = [
], [
['addon.toggle.enabled', 'Enable or disable'],
['urls.yank', 'Copy current URL'],
+ ['urls.paste?{"newTab":false}', 'Open clipboard\'s URL in current tab'],
+ ['urls.paste?{"newTab":true}', 'Open clipboard\'s URL in new tab'],
['zoom.in', 'Zoom-in'],
['zoom.out', 'Zoom-out'],
['zoom.neutral', 'Reset zoom level'],
diff --git a/src/shared/operations.js b/src/shared/operations.js
index 4c221ba..7334369 100644
--- a/src/shared/operations.js
+++ b/src/shared/operations.js
@@ -49,8 +49,9 @@ export default {
ZOOM_OUT: 'zoom.out',
ZOOM_NEUTRAL: 'zoom.neutral',
- // Url yank
+ // Url yank/paste
URLS_YANK: 'urls.yank',
+ URLS_PASTE: 'urls.paste',
// Find
FIND_START: 'find.start',
diff --git a/src/shared/settings/default.js b/src/shared/settings/default.js
index d187565..6b71717 100644
--- a/src/shared/settings/default.js
+++ b/src/shared/settings/default.js
@@ -44,6 +44,8 @@ export default {
"gu": { "type": "navigate.parent" },
"gU": { "type": "navigate.root" },
"y": { "type": "urls.yank" },
+ "p": { "type": "urls.paste", "newTab": false },
+ "P": { "type": "urls.paste", "newTab": true },
"/": { "type": "find.start" },
"n": { "type": "find.next" },
"N": { "type": "find.prev" },