summaryrefslogtreecommitdiffstats
path: root/share/extensions/inkscape_follow_link.py
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-27 16:29:01 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-27 16:29:01 +0000
commit35a96bde514a8897f6f0fcc41c5833bf63df2e2a (patch)
tree657d15a03cc46bd099fc2c6546a7a4ad43815d9f /share/extensions/inkscape_follow_link.py
parentInitial commit. (diff)
downloadinkscape-upstream.tar.xz
inkscape-upstream.zip
Adding upstream version 1.0.2.upstream/1.0.2upstream
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to '')
-rwxr-xr-xshare/extensions/inkscape_follow_link.py28
1 files changed, 28 insertions, 0 deletions
diff --git a/share/extensions/inkscape_follow_link.py b/share/extensions/inkscape_follow_link.py
new file mode 100755
index 0000000..426651f
--- /dev/null
+++ b/share/extensions/inkscape_follow_link.py
@@ -0,0 +1,28 @@
+#!/usr/bin/env python
+# coding=utf-8
+
+import threading
+import webbrowser
+
+import inkex
+from inkex import Anchor
+
+class ThreadWebsite(threading.Thread):
+ """Visit the website without locking inkscape"""
+ def __init__(self, url):
+ threading.Thread.__init__(self)
+ self.url = url
+
+ def run(self):
+ webbrowser.open(self.url)
+
+class FollowLink(inkex.EffectExtension):
+ """Get the first selected item and follow it's href/url"""
+ def effect(self):
+ for node in self.svg.selection.filter(Anchor):
+ vwswli = ThreadWebsite(node.get('xlink:href'))
+ vwswli.start()
+ break
+
+if __name__ == '__main__':
+ FollowLink().run()