summaryrefslogtreecommitdiff
path: root/lib/extensions/reorder.py
diff options
context:
space:
mode:
authorKaalleen <36401965+kaalleen@users.noreply.github.com>2025-03-22 17:43:50 +0100
committerGitHub <noreply@github.com>2025-03-22 17:43:50 +0100
commit40405edfe1ab9735e33fd705b090dc467983611f (patch)
tree1c475c7ab627a9959327fef8cba69815a5739397 /lib/extensions/reorder.py
parentee14e4e28aed2abcfefe05980f7f35ace8634a1c (diff)
parent.remove -> delete (#3600)
Diffstat (limited to 'lib/extensions/reorder.py')
-rw-r--r--lib/extensions/reorder.py19
1 files changed, 5 insertions, 14 deletions
diff --git a/lib/extensions/reorder.py b/lib/extensions/reorder.py
index 2c10559d..a2715e62 100644
--- a/lib/extensions/reorder.py
+++ b/lib/extensions/reorder.py
@@ -10,28 +10,19 @@ from .base import InkstitchExtension
class Reorder(InkstitchExtension):
- # Remove selected objects from the document and re-add them in the order they
- # were selected.
+ # Re-stack elements in the order they were selected.
def effect(self):
objects = self.svg.selection
-
- if not objects:
+ if len(objects) < 2:
errormsg(_("Please select at least two elements to reorder."))
return
- for obj in objects:
- if not obj == objects.first():
- obj.getparent().remove(obj)
-
insert_parent = objects[0].getparent()
- insert_pos = insert_parent.index(objects[0])
-
- insert_parent.remove(objects[0])
+ insert_pos = insert_parent.index(objects[0]) + 1
- insert_parent[insert_pos:insert_pos] = objects
+ insert_parent[insert_pos:insert_pos] = list(objects)[1:]
if __name__ == '__main__':
- e = Reorder()
- e.run()
+ Reorder().run()