mirror of
https://github.com/mitb-archive/filebot
synced 2025-01-11 22:08:01 -05:00
Support sending selected episode data from Episodes panel to Rename panel via context menu (not just clipboard copy & paste)
This commit is contained in:
parent
4bd0ed265d
commit
ec501bc2ed
@ -36,6 +36,8 @@ import javax.swing.border.LineBorder;
|
|||||||
import javax.swing.event.ListSelectionEvent;
|
import javax.swing.event.ListSelectionEvent;
|
||||||
import javax.swing.event.ListSelectionListener;
|
import javax.swing.event.ListSelectionListener;
|
||||||
|
|
||||||
|
import com.google.common.eventbus.Subscribe;
|
||||||
|
|
||||||
import net.filebot.CacheManager;
|
import net.filebot.CacheManager;
|
||||||
import net.filebot.Settings;
|
import net.filebot.Settings;
|
||||||
import net.filebot.cli.GroovyPad;
|
import net.filebot.cli.GroovyPad;
|
||||||
@ -137,9 +139,16 @@ public class MainFrame extends JFrame {
|
|||||||
installAction(this.getRootPane(), getKeyStroke(VK_F1, 0), newAction("Help", evt -> {
|
installAction(this.getRootPane(), getKeyStroke(VK_F1, 0), newAction("Help", evt -> {
|
||||||
GettingStartedStage.start();
|
GettingStartedStage.start();
|
||||||
}));
|
}));
|
||||||
|
|
||||||
|
SwingEventBus.getInstance().register(this);
|
||||||
}
|
}
|
||||||
|
|
||||||
protected void showPanel(PanelBuilder selectedBuilder) {
|
@Subscribe
|
||||||
|
public void selectPanel(PanelBuilder panel) {
|
||||||
|
selectionList.setSelectedValue(panel, false);
|
||||||
|
}
|
||||||
|
|
||||||
|
private void showPanel(PanelBuilder selectedBuilder) {
|
||||||
JComponent contentPane = (JComponent) getContentPane();
|
JComponent contentPane = (JComponent) getContentPane();
|
||||||
JComponent selectedPanel = null;
|
JComponent selectedPanel = null;
|
||||||
|
|
||||||
|
@ -19,6 +19,11 @@ public class AnalyzePanelBuilder implements PanelBuilder {
|
|||||||
return ResourceManager.getIcon("panel.analyze");
|
return ResourceManager.getIcon("panel.analyze");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean equals(Object obj) {
|
||||||
|
return obj instanceof AnalyzePanelBuilder;
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public JComponent create() {
|
public JComponent create() {
|
||||||
AnalyzePanel panel = new AnalyzePanel();
|
AnalyzePanel panel = new AnalyzePanel();
|
||||||
|
@ -39,6 +39,7 @@ import net.filebot.ui.FileBotList;
|
|||||||
import net.filebot.ui.FileBotListExportHandler;
|
import net.filebot.ui.FileBotListExportHandler;
|
||||||
import net.filebot.ui.LanguageComboBox;
|
import net.filebot.ui.LanguageComboBox;
|
||||||
import net.filebot.ui.SelectDialog;
|
import net.filebot.ui.SelectDialog;
|
||||||
|
import net.filebot.ui.rename.RenamePanelBuilder;
|
||||||
import net.filebot.ui.transfer.ArrayTransferable;
|
import net.filebot.ui.transfer.ArrayTransferable;
|
||||||
import net.filebot.ui.transfer.ClipboardHandler;
|
import net.filebot.ui.transfer.ClipboardHandler;
|
||||||
import net.filebot.ui.transfer.CompositeTranserable;
|
import net.filebot.ui.transfer.CompositeTranserable;
|
||||||
@ -47,6 +48,7 @@ import net.filebot.util.StringUtilities;
|
|||||||
import net.filebot.util.ui.LabelProvider;
|
import net.filebot.util.ui.LabelProvider;
|
||||||
import net.filebot.util.ui.SelectButton;
|
import net.filebot.util.ui.SelectButton;
|
||||||
import net.filebot.util.ui.SimpleLabelProvider;
|
import net.filebot.util.ui.SimpleLabelProvider;
|
||||||
|
import net.filebot.util.ui.SwingEventBus;
|
||||||
import net.filebot.web.Episode;
|
import net.filebot.web.Episode;
|
||||||
import net.filebot.web.EpisodeListProvider;
|
import net.filebot.web.EpisodeListProvider;
|
||||||
import net.filebot.web.SearchResult;
|
import net.filebot.web.SearchResult;
|
||||||
@ -251,6 +253,13 @@ public class EpisodeListPanel extends AbstractSearchPanel<EpisodeListProvider, E
|
|||||||
|
|
||||||
// popup menu
|
// popup menu
|
||||||
JPopupMenu popup = new JPopupMenu("Episodes");
|
JPopupMenu popup = new JPopupMenu("Episodes");
|
||||||
|
popup.add(newAction("Import", ResourceManager.getIcon("database.go"), evt -> {
|
||||||
|
// switch to Rename panel
|
||||||
|
SwingEventBus.getInstance().post(new RenamePanelBuilder());
|
||||||
|
|
||||||
|
// load episode data
|
||||||
|
invokeLater(200, () -> SwingEventBus.getInstance().post(EpisodeListExportHandler.export(this, false)));
|
||||||
|
}));
|
||||||
popup.add(newAction("Copy", ResourceManager.getIcon("rename.action.copy"), evt -> {
|
popup.add(newAction("Copy", ResourceManager.getIcon("rename.action.copy"), evt -> {
|
||||||
getTransferHandler().getClipboardHandler().exportToClipboard(this, Toolkit.getDefaultToolkit().getSystemClipboard(), TransferHandler.COPY);
|
getTransferHandler().getClipboardHandler().exportToClipboard(this, Toolkit.getDefaultToolkit().getSystemClipboard(), TransferHandler.COPY);
|
||||||
}));
|
}));
|
||||||
@ -268,7 +277,7 @@ public class EpisodeListPanel extends AbstractSearchPanel<EpisodeListProvider, E
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public Transferable createTransferable(JComponent c) {
|
public Transferable createTransferable(JComponent c) {
|
||||||
Transferable episodeArray = new ArrayTransferable<Episode>(list.getModel().toArray(new Episode[0]));
|
Transferable episodeArray = export(list, true);
|
||||||
Transferable textFile = super.createTransferable(c);
|
Transferable textFile = super.createTransferable(c);
|
||||||
|
|
||||||
return new CompositeTranserable(episodeArray, textFile);
|
return new CompositeTranserable(episodeArray, textFile);
|
||||||
@ -276,16 +285,20 @@ public class EpisodeListPanel extends AbstractSearchPanel<EpisodeListProvider, E
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void exportToClipboard(JComponent c, Clipboard clipboard, int action) throws IllegalStateException {
|
public void exportToClipboard(JComponent c, Clipboard clipboard, int action) throws IllegalStateException {
|
||||||
|
ArrayTransferable<Episode> episodeData = export(list, false);
|
||||||
|
Transferable stringSelection = new StringSelection(StringUtilities.join(episodeData.getArray(), System.lineSeparator()));
|
||||||
|
|
||||||
|
clipboard.setContents(new CompositeTranserable(episodeData, stringSelection), null);
|
||||||
|
}
|
||||||
|
|
||||||
|
public static ArrayTransferable<Episode> export(FileBotList<?> list, boolean forceAll) {
|
||||||
Episode[] selection = ((List<?>) list.getListComponent().getSelectedValuesList()).stream().map(Episode.class::cast).toArray(Episode[]::new);
|
Episode[] selection = ((List<?>) list.getListComponent().getSelectedValuesList()).stream().map(Episode.class::cast).toArray(Episode[]::new);
|
||||||
|
|
||||||
if (selection.length == 0) {
|
if (forceAll || selection.length == 0) {
|
||||||
selection = list.getModel().stream().map(Episode.class::cast).toArray(Episode[]::new);
|
selection = list.getModel().stream().map(Episode.class::cast).toArray(Episode[]::new);
|
||||||
}
|
}
|
||||||
|
|
||||||
Transferable episodeArray = new ArrayTransferable<Episode>(selection);
|
return new ArrayTransferable<Episode>(selection);
|
||||||
Transferable stringSelection = new StringSelection(StringUtilities.join(selection, "\n"));
|
|
||||||
|
|
||||||
clipboard.setContents(new CompositeTranserable(episodeArray, stringSelection), null);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1,14 +1,12 @@
|
|||||||
|
|
||||||
package net.filebot.ui.episodelist;
|
package net.filebot.ui.episodelist;
|
||||||
|
|
||||||
|
|
||||||
import javax.swing.Icon;
|
import javax.swing.Icon;
|
||||||
import javax.swing.JComponent;
|
import javax.swing.JComponent;
|
||||||
|
|
||||||
import net.filebot.ResourceManager;
|
import net.filebot.ResourceManager;
|
||||||
import net.filebot.ui.PanelBuilder;
|
import net.filebot.ui.PanelBuilder;
|
||||||
|
|
||||||
|
|
||||||
public class EpisodeListPanelBuilder implements PanelBuilder {
|
public class EpisodeListPanelBuilder implements PanelBuilder {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@ -16,12 +14,15 @@ public class EpisodeListPanelBuilder implements PanelBuilder {
|
|||||||
return "Episodes";
|
return "Episodes";
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public Icon getIcon() {
|
public Icon getIcon() {
|
||||||
return ResourceManager.getIcon("panel.episodelist");
|
return ResourceManager.getIcon("panel.episodelist");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean equals(Object obj) {
|
||||||
|
return obj instanceof EpisodeListPanelBuilder;
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public JComponent create() {
|
public JComponent create() {
|
||||||
|
@ -1,14 +1,12 @@
|
|||||||
|
|
||||||
package net.filebot.ui.list;
|
package net.filebot.ui.list;
|
||||||
|
|
||||||
|
|
||||||
import javax.swing.Icon;
|
import javax.swing.Icon;
|
||||||
import javax.swing.JComponent;
|
import javax.swing.JComponent;
|
||||||
|
|
||||||
import net.filebot.ResourceManager;
|
import net.filebot.ResourceManager;
|
||||||
import net.filebot.ui.PanelBuilder;
|
import net.filebot.ui.PanelBuilder;
|
||||||
|
|
||||||
|
|
||||||
public class ListPanelBuilder implements PanelBuilder {
|
public class ListPanelBuilder implements PanelBuilder {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@ -16,12 +14,15 @@ public class ListPanelBuilder implements PanelBuilder {
|
|||||||
return "List";
|
return "List";
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public Icon getIcon() {
|
public Icon getIcon() {
|
||||||
return ResourceManager.getIcon("panel.list");
|
return ResourceManager.getIcon("panel.list");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean equals(Object obj) {
|
||||||
|
return obj instanceof ListPanelBuilder;
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public JComponent create() {
|
public JComponent create() {
|
||||||
|
@ -43,7 +43,7 @@ class NamesListTransferablePolicy extends FileTransferablePolicy {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean accept(Transferable tr) throws Exception {
|
public boolean accept(Transferable tr) throws Exception {
|
||||||
return tr.isDataFlavorSupported(stringFlavor) || hasFileListFlavor(tr);
|
return hasFileListFlavor(tr) || tr.isDataFlavorSupported(stringFlavor) || tr.isDataFlavorSupported(episodeArrayFlavor);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -647,10 +647,12 @@ public class RenamePanel extends JComponent {
|
|||||||
|
|
||||||
@Subscribe
|
@Subscribe
|
||||||
public void handle(Transferable transferable) throws Exception {
|
public void handle(Transferable transferable) throws Exception {
|
||||||
TransferablePolicy handler = filesList.getTransferablePolicy();
|
for (TransferablePolicy handler : new TransferablePolicy[] { filesList.getTransferablePolicy(), namesList.getTransferablePolicy() }) {
|
||||||
|
System.out.println(handler.accept(transferable));
|
||||||
if (handler != null && handler.accept(transferable)) {
|
if (handler != null && handler.accept(transferable)) {
|
||||||
handler.handleTransferable(transferable, TransferAction.PUT);
|
handler.handleTransferable(transferable, TransferAction.PUT);
|
||||||
|
return;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1,14 +1,12 @@
|
|||||||
|
|
||||||
package net.filebot.ui.rename;
|
package net.filebot.ui.rename;
|
||||||
|
|
||||||
|
|
||||||
import javax.swing.Icon;
|
import javax.swing.Icon;
|
||||||
import javax.swing.JComponent;
|
import javax.swing.JComponent;
|
||||||
|
|
||||||
import net.filebot.ResourceManager;
|
import net.filebot.ResourceManager;
|
||||||
import net.filebot.ui.PanelBuilder;
|
import net.filebot.ui.PanelBuilder;
|
||||||
|
|
||||||
|
|
||||||
public class RenamePanelBuilder implements PanelBuilder {
|
public class RenamePanelBuilder implements PanelBuilder {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@ -16,12 +14,15 @@ public class RenamePanelBuilder implements PanelBuilder {
|
|||||||
return "Rename";
|
return "Rename";
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public Icon getIcon() {
|
public Icon getIcon() {
|
||||||
return ResourceManager.getIcon("panel.rename");
|
return ResourceManager.getIcon("panel.rename");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean equals(Object obj) {
|
||||||
|
return obj instanceof RenamePanelBuilder;
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public JComponent create() {
|
public JComponent create() {
|
||||||
|
@ -1,14 +1,12 @@
|
|||||||
|
|
||||||
package net.filebot.ui.sfv;
|
package net.filebot.ui.sfv;
|
||||||
|
|
||||||
|
|
||||||
import javax.swing.Icon;
|
import javax.swing.Icon;
|
||||||
import javax.swing.JComponent;
|
import javax.swing.JComponent;
|
||||||
|
|
||||||
import net.filebot.ResourceManager;
|
import net.filebot.ResourceManager;
|
||||||
import net.filebot.ui.PanelBuilder;
|
import net.filebot.ui.PanelBuilder;
|
||||||
|
|
||||||
|
|
||||||
public class SfvPanelBuilder implements PanelBuilder {
|
public class SfvPanelBuilder implements PanelBuilder {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@ -16,12 +14,15 @@ public class SfvPanelBuilder implements PanelBuilder {
|
|||||||
return "SFV";
|
return "SFV";
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public Icon getIcon() {
|
public Icon getIcon() {
|
||||||
return ResourceManager.getIcon("panel.sfv");
|
return ResourceManager.getIcon("panel.sfv");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean equals(Object obj) {
|
||||||
|
return obj instanceof SfvPanelBuilder;
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public JComponent create() {
|
public JComponent create() {
|
||||||
|
@ -1,14 +1,12 @@
|
|||||||
|
|
||||||
package net.filebot.ui.subtitle;
|
package net.filebot.ui.subtitle;
|
||||||
|
|
||||||
|
|
||||||
import javax.swing.Icon;
|
import javax.swing.Icon;
|
||||||
import javax.swing.JComponent;
|
import javax.swing.JComponent;
|
||||||
|
|
||||||
import net.filebot.ResourceManager;
|
import net.filebot.ResourceManager;
|
||||||
import net.filebot.ui.PanelBuilder;
|
import net.filebot.ui.PanelBuilder;
|
||||||
|
|
||||||
|
|
||||||
public class SubtitlePanelBuilder implements PanelBuilder {
|
public class SubtitlePanelBuilder implements PanelBuilder {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@ -16,12 +14,15 @@ public class SubtitlePanelBuilder implements PanelBuilder {
|
|||||||
return "Subtitles";
|
return "Subtitles";
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public Icon getIcon() {
|
public Icon getIcon() {
|
||||||
return ResourceManager.getIcon("panel.subtitle");
|
return ResourceManager.getIcon("panel.subtitle");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean equals(Object obj) {
|
||||||
|
return obj instanceof SubtitlePanelBuilder;
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public JComponent create() {
|
public JComponent create() {
|
||||||
|
@ -18,10 +18,14 @@ public class ArrayTransferable<T> implements Transferable {
|
|||||||
this.array = array;
|
this.array = array;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public T[] getArray() {
|
||||||
|
return array.clone();
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public Object getTransferData(DataFlavor flavor) throws UnsupportedFlavorException, IOException {
|
public Object getTransferData(DataFlavor flavor) throws UnsupportedFlavorException, IOException {
|
||||||
if (isDataFlavorSupported(flavor)) {
|
if (isDataFlavorSupported(flavor)) {
|
||||||
return array;
|
return getArray();
|
||||||
}
|
}
|
||||||
|
|
||||||
return null;
|
return null;
|
||||||
|
@ -24,6 +24,21 @@ public class SwingEventBus extends AsyncEventBus {
|
|||||||
super(SwingUtilities::invokeLater, SwingEventBus::handleException);
|
super(SwingUtilities::invokeLater, SwingEventBus::handleException);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void register(Object object) {
|
||||||
|
SwingUtilities.invokeLater(() -> super.register(object));
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void unregister(Object object) {
|
||||||
|
SwingUtilities.invokeLater(() -> super.unregister(object));
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void post(Object object) {
|
||||||
|
SwingUtilities.invokeLater(() -> super.post(object));
|
||||||
|
}
|
||||||
|
|
||||||
protected static void handleException(Throwable throwable, SubscriberExceptionContext context) {
|
protected static void handleException(Throwable throwable, SubscriberExceptionContext context) {
|
||||||
debug.log(Level.WARNING, "Failed to handle event: " + context.getEvent(), throwable);
|
debug.log(Level.WARNING, "Failed to handle event: " + context.getEvent(), throwable);
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user