Skip to content

Commit

Permalink
Add 'replace selected' action to relation editor
Browse files Browse the repository at this point in the history
  • Loading branch information
Woazboat committed Mar 17, 2022
1 parent 4bfe2b9 commit 6af03cb
Show file tree
Hide file tree
Showing 5 changed files with 226 additions and 13 deletions.
105 changes: 105 additions & 0 deletions resources/images/dialogs/relation/replaceselectedright.svg
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Original file line number Diff line number Diff line change
Expand Up @@ -86,6 +86,7 @@
import org.openstreetmap.josm.gui.dialogs.relation.actions.RefreshAction;
import org.openstreetmap.josm.gui.dialogs.relation.actions.RemoveAction;
import org.openstreetmap.josm.gui.dialogs.relation.actions.RemoveSelectedAction;
import org.openstreetmap.josm.gui.dialogs.relation.actions.ReplaceSelectedAction;
import org.openstreetmap.josm.gui.dialogs.relation.actions.ReverseAction;
import org.openstreetmap.josm.gui.dialogs.relation.actions.SelectAction;
import org.openstreetmap.josm.gui.dialogs.relation.actions.SelectPrimitivesForSelectedMembersAction;
Expand Down Expand Up @@ -703,10 +704,13 @@ protected static JToolBar buildSelectionControlButtonToolbar(IRelationEditorActi
new AddSelectedAtEndAction(editorAccess)
));
groups.add(buildNativeGroup(20,
new ReplaceSelectedAction(editorAccess)
));
groups.add(buildNativeGroup(30,
new SelectedMembersForSelectionAction(editorAccess),
new SelectPrimitivesForSelectedMembersAction(editorAccess)
));
groups.add(buildNativeGroup(30,
groups.add(buildNativeGroup(40,
new RemoveSelectedAction(editorAccess)
));
groups.addAll(RelationEditorHooks.getSelectActions());
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -505,6 +505,40 @@ public void updateRole(int[] idx, String role) {
addToSelectedMembers(selected);
}

/**
* updates the referenced primitive of the members given by the index in <code>index</code>
*
* @param index the index to update
* @param newPrimitive the new primitive
*/
public void updateMemberPrimitive(int index, OsmPrimitive newPrimitive) {
if (index >= members.size()) {
return;
}

RelationMember newMember = new RelationMember(members.get(index).getRole(), newPrimitive);
updateMember(index, newMember);
}

/**
* replace the member at <code>index</code> with a new one
*
* @param index the index to update
* @param newMember the new member
*/
public void updateMember(int index, RelationMember newMember) {
if (index >= members.size()) {
return;
}

RelationMember oldMember = members.get(index);
if (oldMember.equals(newMember))
return;

setValue(index, newMember);
fireTableDataChanged();
}

/**
* Get the currently selected relation members
*
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -30,27 +30,40 @@ protected boolean isPotentialDuplicate(OsmPrimitive primitive) {
}

protected List<OsmPrimitive> filterConfirmedPrimitives(List<OsmPrimitive> primitives) throws AddAbortException {
return filterConfirmedPrimitives(primitives, false);
}

protected List<OsmPrimitive> filterConfirmedPrimitives(List<OsmPrimitive> primitives, boolean abortOnSkip) throws AddAbortException {
if (Utils.isEmpty(primitives))
return primitives;
List<OsmPrimitive> ret = new ArrayList<>();
ConditionalOptionPaneUtil.startBulkOperation("add_primitive_to_relation");
for (OsmPrimitive primitive : primitives) {
if (primitive instanceof Relation) {
List<Relation> loop = RelationChecker.checkAddMember(editorAccess.getEditor().getRelation(), (Relation) primitive);
if (!loop.isEmpty() && loop.get(0).equals(loop.get(loop.size() - 1))) {
GenericRelationEditor.warnOfCircularReferences(primitive, loop);
continue;
try {
for (OsmPrimitive primitive : primitives) {
if (primitive instanceof Relation) {
List<Relation> loop = RelationChecker.checkAddMember(editorAccess.getEditor().getRelation(), (Relation) primitive);
if (!loop.isEmpty() && loop.get(0).equals(loop.get(loop.size() - 1))) {
GenericRelationEditor.warnOfCircularReferences(primitive, loop);
if (abortOnSkip) {
throw new AddAbortException();
}
continue;
}
}
}
if (isPotentialDuplicate(primitive)) {
if (GenericRelationEditor.confirmAddingPrimitive(primitive)) {
if (isPotentialDuplicate(primitive)) {
if (GenericRelationEditor.confirmAddingPrimitive(primitive)) {
ret.add(primitive);
} else if (abortOnSkip) {
throw new AddAbortException();
}
} else {
ret.add(primitive);
}
} else {
ret.add(primitive);
}
} finally {
ConditionalOptionPaneUtil.endBulkOperation("add_primitive_to_relation");
}
ConditionalOptionPaneUtil.endBulkOperation("add_primitive_to_relation");

return ret;
}
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,57 @@
// License: GPL. For details, see LICENSE file.
package org.openstreetmap.josm.gui.dialogs.relation.actions;

import static org.openstreetmap.josm.tools.I18n.tr;

import java.awt.event.ActionEvent;
import java.util.List;

import org.openstreetmap.josm.data.osm.OsmPrimitive;
import org.openstreetmap.josm.gui.dialogs.relation.GenericRelationEditor.AddAbortException;
import org.openstreetmap.josm.tools.ImageProvider;
import org.openstreetmap.josm.tools.Logging;

/**
* Replace selected relation members with the objects selected in the current dataset
* @since xxx
*/
public class ReplaceSelectedAction extends AddFromSelectionAction {

/**
* Constructs a new {@code ReplaceSelectedAction}.
* @param editorAccess An interface to access the relation editor contents.
*/
public ReplaceSelectedAction(IRelationEditorActionAccess editorAccess) {
super(editorAccess, IRelationEditorUpdateOn.MEMBER_TABLE_SELECTION, IRelationEditorUpdateOn.SELECTION_TABLE_CHANGE);
putValue(SHORT_DESCRIPTION, tr("Replace members with selected objects"));
new ImageProvider("dialogs/relation", "replaceselectedright").getResource().attachImageIcon(this, true);
updateEnabledState();
}

@Override
protected void updateEnabledState() {
int numSelected = getSelectionTableModel().getRowCount();
setEnabled(numSelected > 0 &&
numSelected == getMemberTableModel().getSelectedIndices().length);
}

@Override
public void actionPerformed(ActionEvent e) {
try {
int[] selectedMemberIndices = getMemberTableModel().getSelectedIndices();
List<OsmPrimitive> selection = getSelectionTableModel().getSelection();
int numSelectedPrimitives = selection.size();
if (numSelectedPrimitives != selectedMemberIndices.length) {
return;
}

List<OsmPrimitive> filteredSelection = filterConfirmedPrimitives(selection, true);

for (int i = 0; i < selectedMemberIndices.length; i++) {
getMemberTableModel().updateMemberPrimitive(selectedMemberIndices[i], filteredSelection.get(i));
}
} catch (AddAbortException ex) {
Logging.trace(ex);
}
}
}

0 comments on commit 6af03cb

Please sign in to comment.