diff options
author | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-27 16:29:01 +0000 |
---|---|---|
committer | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-27 16:29:01 +0000 |
commit | 35a96bde514a8897f6f0fcc41c5833bf63df2e2a (patch) | |
tree | 657d15a03cc46bd099fc2c6546a7a4ad43815d9f /share/extensions/inkscape_follow_link.py | |
parent | Initial commit. (diff) | |
download | inkscape-35a96bde514a8897f6f0fcc41c5833bf63df2e2a.tar.xz inkscape-35a96bde514a8897f6f0fcc41c5833bf63df2e2a.zip |
Adding upstream version 1.0.2.upstream/1.0.2upstream
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'share/extensions/inkscape_follow_link.py')
-rwxr-xr-x | share/extensions/inkscape_follow_link.py | 28 |
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() |