X-Git-Url: http://gitweb.fperrin.net/?p=GpsPrune.git;a=blobdiff_plain;f=src%2Ftim%2Fprune%2Ffunction%2FDisconnectPhotoFunction.java;fp=src%2Ftim%2Fprune%2Ffunction%2FDisconnectPhotoFunction.java;h=96e039dbe8856475f8a3fd464180ba606f64399a;hp=0000000000000000000000000000000000000000;hb=ce6f2161b8596f7018d6a76bff79bc9e571f35fd;hpb=2d8cb72e84d5cc1089ce77baf1e34ea3ea2f8465 diff --git a/src/tim/prune/function/DisconnectPhotoFunction.java b/src/tim/prune/function/DisconnectPhotoFunction.java new file mode 100644 index 0000000..96e039d --- /dev/null +++ b/src/tim/prune/function/DisconnectPhotoFunction.java @@ -0,0 +1,47 @@ +package tim.prune.function; + +import tim.prune.App; +import tim.prune.DataSubscriber; +import tim.prune.GenericFunction; +import tim.prune.I18nManager; +import tim.prune.UpdateMessageBroker; +import tim.prune.data.DataPoint; +import tim.prune.data.Photo; +import tim.prune.undo.UndoDisconnectMedia; + +/** + * Function to disconnect the current photo from the current point + */ +public class DisconnectPhotoFunction extends GenericFunction +{ + /** + * Constructor + * @param inApp app object + */ + public DisconnectPhotoFunction(App inApp) { + super(inApp); + } + + /** @return name key */ + public String getNameKey() { + return "function.disconnectfrompoint"; + } + + /** + * Perform the operation + */ + public void begin() + { + Photo photo = _app.getTrackInfo().getCurrentPhoto(); + if (photo != null && photo.getDataPoint() != null) + { + DataPoint point = photo.getDataPoint(); + UndoDisconnectMedia undo = new UndoDisconnectMedia(point, true, false, photo.getName()); + // disconnect + photo.setDataPoint(null); + point.setPhoto(null); + UpdateMessageBroker.informSubscribers(DataSubscriber.SELECTION_CHANGED); + _app.completeFunction(undo, I18nManager.getText("confirm.photo.disconnect")); + } + } +}