mirror of
https://github.com/correl/mage.git
synced 2025-01-12 19:25:44 +00:00
Ability to drag-and-drop decklists onto DeckEditorPanel in deck editor.
This commit is contained in:
parent
8319fbf9ad
commit
13efdd5b0b
2 changed files with 146 additions and 18 deletions
|
@ -4,6 +4,7 @@ import mage.cards.Card;
|
||||||
import mage.cards.Sets;
|
import mage.cards.Sets;
|
||||||
import mage.cards.decks.Deck;
|
import mage.cards.decks.Deck;
|
||||||
import mage.cards.decks.DeckCardLists;
|
import mage.cards.decks.DeckCardLists;
|
||||||
|
import mage.cards.decks.DnDDeckTargetListener;
|
||||||
import mage.cards.decks.importer.DeckImporter;
|
import mage.cards.decks.importer.DeckImporter;
|
||||||
import mage.cards.repository.CardInfo;
|
import mage.cards.repository.CardInfo;
|
||||||
import mage.cards.repository.CardRepository;
|
import mage.cards.repository.CardRepository;
|
||||||
|
@ -30,11 +31,13 @@ import org.apache.log4j.Logger;
|
||||||
import javax.swing.*;
|
import javax.swing.*;
|
||||||
import javax.swing.filechooser.FileFilter;
|
import javax.swing.filechooser.FileFilter;
|
||||||
import java.awt.*;
|
import java.awt.*;
|
||||||
|
import java.awt.dnd.DropTarget;
|
||||||
import java.awt.event.*;
|
import java.awt.event.*;
|
||||||
import java.io.File;
|
import java.io.File;
|
||||||
import java.io.FileNotFoundException;
|
import java.io.FileNotFoundException;
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.util.*;
|
import java.util.*;
|
||||||
|
import java.util.List;
|
||||||
import java.util.concurrent.*;
|
import java.util.concurrent.*;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -445,6 +448,16 @@ public class DeckEditorPanel extends javax.swing.JPanel {
|
||||||
});
|
});
|
||||||
refreshDeck();
|
refreshDeck();
|
||||||
|
|
||||||
|
if (mode == DeckEditorMode.FREE_BUILDING) {
|
||||||
|
setDropTarget(new DropTarget(this, new DnDDeckTargetListener() {
|
||||||
|
@Override
|
||||||
|
protected boolean handleFilesDrop(boolean move, List<File> files) {
|
||||||
|
loadDeck(files.get(0).getAbsolutePath());
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
}));
|
||||||
|
}
|
||||||
|
|
||||||
this.setVisible(true);
|
this.setVisible(true);
|
||||||
this.repaint();
|
this.repaint();
|
||||||
}
|
}
|
||||||
|
@ -785,6 +798,29 @@ public class DeckEditorPanel extends javax.swing.JPanel {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private boolean loadDeck(String file) {
|
||||||
|
Deck newDeck = null;
|
||||||
|
StringBuilder errorMessages = new StringBuilder();
|
||||||
|
|
||||||
|
MageFrame.getDesktop().setCursor(new Cursor(Cursor.WAIT_CURSOR));
|
||||||
|
try {
|
||||||
|
newDeck = Deck.load(DeckImporter.importDeckFromFile(file, errorMessages), true, true);
|
||||||
|
processAndShowImportErrors(errorMessages);
|
||||||
|
|
||||||
|
if (newDeck != null) {
|
||||||
|
deck = newDeck;
|
||||||
|
refreshDeck();
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
} catch (GameException e1) {
|
||||||
|
JOptionPane.showMessageDialog(MageFrame.getDesktop(), e1.getMessage(), "Error loading deck", JOptionPane.ERROR_MESSAGE);
|
||||||
|
} finally {
|
||||||
|
MageFrame.getDesktop().setCursor(new Cursor(Cursor.DEFAULT_CURSOR));
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @param evt ActionEvent
|
* @param evt ActionEvent
|
||||||
*/
|
*/
|
||||||
|
@ -796,24 +832,7 @@ public class DeckEditorPanel extends javax.swing.JPanel {
|
||||||
dialog.addWindowListener(new WindowAdapter() {
|
dialog.addWindowListener(new WindowAdapter() {
|
||||||
@Override
|
@Override
|
||||||
public void windowClosed(WindowEvent e) {
|
public void windowClosed(WindowEvent e) {
|
||||||
Deck newDeck = null;
|
loadDeck(dialog.getTmpPath());
|
||||||
StringBuilder errorMessages = new StringBuilder();
|
|
||||||
|
|
||||||
MageFrame.getDesktop().setCursor(new Cursor(Cursor.WAIT_CURSOR));
|
|
||||||
try {
|
|
||||||
newDeck = Deck.load(DeckImporter.importDeckFromFile(dialog.getTmpPath(), errorMessages), true, true);
|
|
||||||
processAndShowImportErrors(errorMessages);
|
|
||||||
|
|
||||||
if (newDeck != null) {
|
|
||||||
deck = newDeck;
|
|
||||||
refreshDeck();
|
|
||||||
}
|
|
||||||
|
|
||||||
} catch (GameException e1) {
|
|
||||||
JOptionPane.showMessageDialog(MageFrame.getDesktop(), e1.getMessage(), "Error loading deck", JOptionPane.ERROR_MESSAGE);
|
|
||||||
} finally {
|
|
||||||
MageFrame.getDesktop().setCursor(new Cursor(Cursor.DEFAULT_CURSOR));
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
109
Mage/src/main/java/mage/cards/decks/DnDDeckTargetListener.java
Normal file
109
Mage/src/main/java/mage/cards/decks/DnDDeckTargetListener.java
Normal file
|
@ -0,0 +1,109 @@
|
||||||
|
package mage.cards.decks;
|
||||||
|
|
||||||
|
import javax.swing.*;
|
||||||
|
import java.awt.datatransfer.DataFlavor;
|
||||||
|
import java.awt.datatransfer.UnsupportedFlavorException;
|
||||||
|
import java.awt.dnd.DropTargetAdapter;
|
||||||
|
import java.awt.dnd.DropTargetDragEvent;
|
||||||
|
import java.awt.dnd.DropTargetDropEvent;
|
||||||
|
import java.io.File;
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.net.URI;
|
||||||
|
import java.net.URISyntaxException;
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
public class DnDDeckTargetListener extends DropTargetAdapter {
|
||||||
|
|
||||||
|
private static final DataFlavor fileFlavor = DataFlavor.javaFileListFlavor;
|
||||||
|
private static final DataFlavor plainTextFlavor = DataFlavor.stringFlavor;
|
||||||
|
|
||||||
|
private boolean isCopyOrMove(int dropAction) {
|
||||||
|
return (dropAction & TransferHandler.COPY_OR_MOVE) != 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
private boolean isCopyAction(int dropAction) {
|
||||||
|
return (dropAction & TransferHandler.COPY) != 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
private boolean isMoveAction(int dropAction) {
|
||||||
|
return (dropAction & TransferHandler.MOVE) != 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
private boolean isAcceptable(DropTargetDragEvent dtde) {
|
||||||
|
boolean copyOrMove = isCopyOrMove(dtde.getDropAction());
|
||||||
|
boolean flavorSupported = dtde.isDataFlavorSupported(plainTextFlavor) || dtde.isDataFlavorSupported(fileFlavor);
|
||||||
|
return copyOrMove && flavorSupported;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void dragEnter(DropTargetDragEvent dtde) {
|
||||||
|
if (isAcceptable(dtde)) {
|
||||||
|
dtde.acceptDrag(TransferHandler.COPY);
|
||||||
|
} else {
|
||||||
|
dtde.rejectDrag();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void dragOver(DropTargetDragEvent dtde) {
|
||||||
|
if (isAcceptable(dtde)) {
|
||||||
|
dtde.acceptDrag(TransferHandler.COPY);
|
||||||
|
} else {
|
||||||
|
dtde.rejectDrag();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void dropActionChanged(DropTargetDragEvent dtde) {
|
||||||
|
if (isAcceptable(dtde)) {
|
||||||
|
dtde.acceptDrag(TransferHandler.COPY);
|
||||||
|
} else {
|
||||||
|
dtde.rejectDrag();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void drop(DropTargetDropEvent dtde) {
|
||||||
|
if (isCopyOrMove(dtde.getDropAction()) && dtde.isDataFlavorSupported(fileFlavor)) {
|
||||||
|
dtde.acceptDrop(TransferHandler.COPY);
|
||||||
|
} else if (isCopyOrMove(dtde.getDropAction()) && dtde.isDataFlavorSupported(plainTextFlavor)) {
|
||||||
|
dtde.acceptDrop(TransferHandler.COPY);
|
||||||
|
} else {
|
||||||
|
dtde.rejectDrop();
|
||||||
|
dtde.dropComplete(false);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
boolean move = isMoveAction(dtde.getDropAction());
|
||||||
|
|
||||||
|
try {
|
||||||
|
if (dtde.isDataFlavorSupported(fileFlavor)) {
|
||||||
|
List<File> files = (List<File>) dtde.getTransferable().getTransferData(fileFlavor);
|
||||||
|
dtde.dropComplete(handleFilesDrop(move, files));
|
||||||
|
} else if (dtde.isDataFlavorSupported(plainTextFlavor)) {
|
||||||
|
String text = (String) dtde.getTransferable().getTransferData(plainTextFlavor);
|
||||||
|
try {
|
||||||
|
dtde.dropComplete(handleUriDrop(move, new URI(text)));
|
||||||
|
} catch (URISyntaxException e) {
|
||||||
|
dtde.dropComplete(handlePlainTextDrop(move, text));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} catch (UnsupportedFlavorException | IOException e) {
|
||||||
|
e.printStackTrace();
|
||||||
|
dtde.dropComplete(false);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
protected boolean handlePlainTextDrop(boolean move, String text) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
protected boolean handleUriDrop(boolean move, URI uri) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
protected boolean handleFilesDrop(boolean move, List<File> files) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
Loading…
Reference in a new issue