summaryrefslogtreecommitdiffstats
path: root/share/extensions/web_interactive_mockup.py
diff options
context:
space:
mode:
Diffstat (limited to 'share/extensions/web_interactive_mockup.py')
-rwxr-xr-xshare/extensions/web_interactive_mockup.py43
1 files changed, 43 insertions, 0 deletions
diff --git a/share/extensions/web_interactive_mockup.py b/share/extensions/web_interactive_mockup.py
new file mode 100755
index 0000000..791ca25
--- /dev/null
+++ b/share/extensions/web_interactive_mockup.py
@@ -0,0 +1,43 @@
+#!/usr/bin/env python
+
+# Copyright (C) 2019 Gemy Cedric Activdesign.eu
+#
+# This program is free software; you can redistribute it and/or modify
+# it under the terms of the GNU General Public License as published by
+# the Free Software Foundation; either version 2 of the License, or
+# (at your option) any later version.
+#
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU General Public License for more details.
+#
+# You should have received a copy of the GNU General Public License
+# along with this program; if not, write to the Free Software
+# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
+#
+import inkwebeffect
+import inkex
+
+class InteractiveMockup(inkwebeffect.InkWebEffect):
+ def add_arguments(self, pars):
+ pars.add_argument("--when", default="onclick", help="Event that will trigger the action")
+ pars.add_argument("--tab")
+
+ def effect(self):
+ self.ensureInkWebSupport()
+
+ if len(self.options.ids) < 2:
+ raise inkex.AbortExtension("You must select at least two elements."
+ " The last one is the object you want to go to")
+
+ el_from = list(self.svg.selected.values())[:-1]
+
+ ev_code = "InkWeb.moveViewbox({from:this, to:'" + self.options.ids[-1] +"'})"
+ for elem in el_from:
+ prev_ev_code = elem.get(self.options.when)
+ el_ev_code = ev_code +";" + (prev_ev_code or '')
+ elem.set(self.options.when, el_ev_code)
+
+if __name__ == '__main__':
+ InteractiveMockup().run()