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/webslicer_create_group.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 '')
-rwxr-xr-x | share/extensions/webslicer_create_group.py | 56 |
1 files changed, 56 insertions, 0 deletions
diff --git a/share/extensions/webslicer_create_group.py b/share/extensions/webslicer_create_group.py new file mode 100755 index 0000000..59e9cd8 --- /dev/null +++ b/share/extensions/webslicer_create_group.py @@ -0,0 +1,56 @@ +#!/usr/bin/env python +# +# Copyright (C) 2010 Aurelio A. Heckert, aurium (a) gmail dot com +# +# 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. +# +"""Create webslicer group""" + +import inkex +from inkex.localization import inkex_gettext as _ +from webslicer_effect import WebSlicerMixin + +class CreateGroup(WebSlicerMixin, inkex.EffectExtension): + """Create new webslicer group""" + def add_arguments(self, pars): + pars.add_argument("--tab") + pars.add_argument("--html-id", dest="html_id") + pars.add_argument("--html-class", dest="html_class") + pars.add_argument("--width-unity", dest="width_unity") + pars.add_argument("--height-unity", dest="height_unity") + pars.add_argument("--bg-color", dest="bg_color") + + def effect(self): + if not self.svg.selected: + raise inkex.AbortExtension(_('You must to select some "Slicer rectangles" ' + 'or other "Layout groups".')) + + base_elements = self.get_slicer_layer().descendants() + for key, node in self.svg.selected.id_dict().items(): + if node not in base_elements: + raise inkex.AbortExtension(_('The element "{}" is not in the Web Slicer layer'.format(key))) + g_parent = node.getparent() + + group = g_parent.add(inkex.Group()) + desc = group.add(inkex.Desc()) + desc.text = self.get_conf_text_from_list( + ['html_id', 'html_class', 'width_unity', 'height_unity', 'bg_color']) + + for node in self.svg.selected.values(): + group.insert(1, node) + + +if __name__ == '__main__': + CreateGroup().run() |