Refactor to include different eventListeners

MYC-Refactor
Hammy 3 years ago
parent c59a3fc388
commit 4a65587182

@ -5,30 +5,70 @@ import java.io.File;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.List; import java.util.List;
import me.goudham.domain.OldClipboardContent; import me.goudham.domain.OldClipboardContent;
import me.goudham.event.ClipboardEvent; import me.goudham.event.FileEvent;
import me.goudham.event.ImageEvent;
import me.goudham.event.TextEvent;
/** /**
* Stores all eventListeners and produces notifications that are to be consumed by users using {@link MyClipboard} * Stores all eventListeners and produces notifications that are to be consumed by users using {@link MyClipboard}
*/ */
class EventManager { class EventManager {
List<ClipboardEvent> eventListeners = new ArrayList<>(); List<TextEvent> textEventListener = new ArrayList<>();
List<ImageEvent> imageEventListener = new ArrayList<>();
List<FileEvent> fileEventListener = new ArrayList<>();
/** /**
* Adds a {@link ClipboardEvent} to the {@code eventListeners} * Adds a {@link TextEvent} to the {@code textEventListener}
* *
* @param clipboardEvent The {@link ClipboardEvent} to be added * @param textEvent The {@link TextEvent} to be added
*/ */
void addEventListener(ClipboardEvent clipboardEvent) { void addEventListener(TextEvent textEvent) {
eventListeners.add(clipboardEvent); textEventListener.add(textEvent);
} }
/** /**
* Removes a {@link ClipboardEvent} from the {@code eventListeners} * Adds a {@link ImageEvent} to the {@code imageEventListener}
* *
* @param clipboardEvent The {@link ClipboardEvent} to be removed * @param imageEvent The {@link ImageEvent} to be added
*/ */
void removeEventListener(ClipboardEvent clipboardEvent) { void addEventListener(ImageEvent imageEvent) {
eventListeners.remove(clipboardEvent); imageEventListener.add(imageEvent);
}
/**
* Adds a {@link FileEvent} to the {@code fileEventListener}
*
* @param fileEvent The {@link FileEvent} to be added
*/
void addEventListener(FileEvent fileEvent) {
fileEventListener.add(fileEvent);
}
/**
* Removes a {@link TextEvent} from the {@code textEventListener}
*
* @param textEvent The {@link TextEvent} to be removed
*/
void removeEventListener(TextEvent textEvent) {
textEventListener.remove(textEvent);
}
/**
* Removes a {@link ImageEvent} from the {@code imageEventListener}
*
* @param imageEvent The {@link ImageEvent} to be removed
*/
void removeEventListener(ImageEvent imageEvent) {
imageEventListener.remove(imageEvent);
}
/**
* Removes a {@link FileEvent} from the {@code fileEventListener}
*
* @param fileEvent The {@link FileEvent} to be removed
*/
void removeEventListener(FileEvent fileEvent) {
fileEventListener.remove(fileEvent);
} }
/** /**
@ -38,8 +78,8 @@ class EventManager {
* @param stringContent {@link String} to be consumed * @param stringContent {@link String} to be consumed
*/ */
void notifyTextEvent(OldClipboardContent oldClipboardContent, String stringContent) { void notifyTextEvent(OldClipboardContent oldClipboardContent, String stringContent) {
for (ClipboardEvent clipboardEvent : eventListeners) { for (TextEvent textEvent : textEventListener) {
clipboardEvent.onCopyText(oldClipboardContent, stringContent); textEvent.onCopyText(oldClipboardContent, stringContent);
} }
} }
@ -50,8 +90,8 @@ class EventManager {
* @param imageContent {@link BufferedImage} to be consumed * @param imageContent {@link BufferedImage} to be consumed
*/ */
void notifyImageEvent(OldClipboardContent oldClipboardContent, BufferedImage imageContent) { void notifyImageEvent(OldClipboardContent oldClipboardContent, BufferedImage imageContent) {
for (ClipboardEvent clipboardEvent : eventListeners) { for (ImageEvent imageEvent : imageEventListener) {
clipboardEvent.onCopyImage(oldClipboardContent, imageContent); imageEvent.onCopyImage(oldClipboardContent, imageContent);
} }
} }
@ -59,11 +99,11 @@ class EventManager {
* Produces {@link List} of {@link File} change notifications to all consumers listening * Produces {@link List} of {@link File} change notifications to all consumers listening
* *
* @param oldClipboardContent The previous clipboard contents * @param oldClipboardContent The previous clipboard contents
* @param fileListContent {@link List} of {@link File} to be consumed * @param fileContent {@link List} of {@link File} to be consumed
*/ */
void notifyFilesEvent(OldClipboardContent oldClipboardContent, List<File> fileListContent) { void notifyFilesEvent(OldClipboardContent oldClipboardContent, List<File> fileContent) {
for (ClipboardEvent clipboardEvent : eventListeners) { for (FileEvent fileEvent : fileEventListener) {
clipboardEvent.onCopyFiles(oldClipboardContent, fileListContent); fileEvent.onCopyFiles(oldClipboardContent, fileContent);
} }
} }
} }

@ -1,12 +1,4 @@
package me.goudham.event; package me.goudham.event;
import java.awt.image.BufferedImage; interface ClipboardEvent {
import java.io.File;
import java.util.List;
import me.goudham.domain.OldClipboardContent;
public interface ClipboardEvent {
void onCopyText(OldClipboardContent oldContent, String newContent);
void onCopyImage(OldClipboardContent oldContent, BufferedImage newContent);
void onCopyFiles(OldClipboardContent oldContent, List<File> newContent);
} }

Loading…
Cancel
Save