mirror of
https://github.com/mitb-archive/filebot
synced 2025-01-11 05:48:01 -05:00
Refactor FormatDialog
This commit is contained in:
parent
f9fdf3e375
commit
3f56e58b8b
@ -15,7 +15,6 @@ import java.awt.Dimension;
|
||||
import java.awt.Font;
|
||||
import java.awt.Rectangle;
|
||||
import java.awt.Window;
|
||||
import java.awt.event.ActionEvent;
|
||||
import java.awt.event.WindowAdapter;
|
||||
import java.awt.event.WindowEvent;
|
||||
import java.io.File;
|
||||
@ -37,7 +36,6 @@ import java.util.logging.Level;
|
||||
import java.util.prefs.Preferences;
|
||||
|
||||
import javax.script.ScriptException;
|
||||
import javax.swing.AbstractAction;
|
||||
import javax.swing.Action;
|
||||
import javax.swing.JButton;
|
||||
import javax.swing.JComponent;
|
||||
@ -68,7 +66,6 @@ import net.filebot.format.SuppressedThrowables;
|
||||
import net.filebot.mac.MacAppUtilities;
|
||||
import net.filebot.media.MetaAttributes;
|
||||
import net.filebot.util.DefaultThreadFactory;
|
||||
import net.filebot.util.ExceptionUtilities;
|
||||
import net.filebot.util.PreferencesList;
|
||||
import net.filebot.util.PreferencesMap.PreferencesEntry;
|
||||
import net.filebot.util.ui.GradientStyle;
|
||||
@ -111,22 +108,23 @@ public class FormatDialog extends JDialog {
|
||||
private static final PreferencesEntry<String> persistentSampleFile = Settings.forPackage(FormatDialog.class).entry("format.sample.file");
|
||||
|
||||
public enum Mode {
|
||||
|
||||
Episode, Movie, Music, File;
|
||||
|
||||
public Mode next() {
|
||||
// cycle through Episode -> Movie -> Music (but ignore generic File mode)
|
||||
return values()[(this.ordinal() + 1) % File.ordinal()];
|
||||
return values()[(ordinal() + 1) % File.ordinal()];
|
||||
}
|
||||
|
||||
public String key() {
|
||||
return this.name().toLowerCase();
|
||||
return name().toLowerCase();
|
||||
}
|
||||
|
||||
public Format getFormat() {
|
||||
switch (this) {
|
||||
case Episode:
|
||||
return new EpisodeFormat();
|
||||
case Movie: // case Movie
|
||||
case Movie:
|
||||
return new MovieFormat(true, true, false);
|
||||
case Music:
|
||||
return new AudioTrackFormat();
|
||||
@ -157,6 +155,7 @@ public class FormatDialog extends JDialog {
|
||||
if (key.startsWith(prefix))
|
||||
examples.put(key, bundle.getString(key));
|
||||
}
|
||||
|
||||
return examples.values();
|
||||
}
|
||||
|
||||
@ -526,7 +525,7 @@ public class FormatDialog extends JDialog {
|
||||
executor.execute(currentPreviewFuture);
|
||||
} catch (ScriptException e) {
|
||||
// incorrect syntax
|
||||
status.setText(ExceptionUtilities.getRootCauseMessage(e));
|
||||
status.setText(getRootCauseMessage(e));
|
||||
status.setIcon(ResourceManager.getIcon("status.error"));
|
||||
status.setVisible(true);
|
||||
|
||||
@ -587,10 +586,7 @@ public class FormatDialog extends JDialog {
|
||||
return popup;
|
||||
}
|
||||
|
||||
protected final Action changeSampleAction = new AbstractAction("Change Sample", ResourceManager.getIcon("action.variables")) {
|
||||
|
||||
@Override
|
||||
public void actionPerformed(ActionEvent evt) {
|
||||
protected final Action changeSampleAction = newAction("Change Sample", ResourceManager.getIcon("action.variables"), evt -> {
|
||||
BindingDialog dialog = new BindingDialog(getWindow(evt.getSource()), String.format("%s Bindings", mode), mode.getFormat(), !locked);
|
||||
dialog.setSample(sample);
|
||||
|
||||
@ -616,13 +612,9 @@ public class FormatDialog extends JDialog {
|
||||
// reevaluate everything
|
||||
fireSampleChanged();
|
||||
}
|
||||
}
|
||||
};
|
||||
});
|
||||
|
||||
protected final Action selectFolderAction = new AbstractAction("Change Folder", ResourceManager.getIcon("action.load")) {
|
||||
|
||||
@Override
|
||||
public void actionPerformed(ActionEvent evt) {
|
||||
protected final Action selectFolderAction = newAction("Change Folder", ResourceManager.getIcon("action.load"), evt -> {
|
||||
String relativeFormat = editor.getText().trim();
|
||||
File absoluteFolder = null;
|
||||
|
||||
@ -645,41 +637,24 @@ public class FormatDialog extends JDialog {
|
||||
if (selectedFolder != null) {
|
||||
editor.setText(normalizePathSeparators(selectedFolder.getAbsolutePath()) + "/" + relativeFormat);
|
||||
}
|
||||
}
|
||||
});
|
||||
|
||||
};
|
||||
|
||||
protected final Action showRecentAction = new AbstractAction("Change Format", ResourceManager.getIcon("action.menu")) {
|
||||
|
||||
@Override
|
||||
public void actionPerformed(ActionEvent evt) {
|
||||
protected final Action showRecentAction = newAction("Change Format", ResourceManager.getIcon("action.menu"), evt -> {
|
||||
// display popup below format editor
|
||||
JComponent c = (JComponent) evt.getSource();
|
||||
editor.getComponentPopupMenu().show(c, 0, c.getHeight() + 3);
|
||||
}
|
||||
};
|
||||
});
|
||||
|
||||
protected final Action cancelAction = new AbstractAction("Cancel", ResourceManager.getIcon("dialog.cancel")) {
|
||||
|
||||
@Override
|
||||
public void actionPerformed(ActionEvent e) {
|
||||
protected final Action cancelAction = newAction("Cancel", ResourceManager.getIcon("dialog.cancel"), evt -> {
|
||||
finish(false);
|
||||
}
|
||||
};
|
||||
});
|
||||
|
||||
protected final Action switchEditModeAction = new AbstractAction("Switch Mode", ResourceManager.getIcon("dialog.switch")) {
|
||||
|
||||
@Override
|
||||
public void actionPerformed(ActionEvent e) {
|
||||
protected final Action switchEditModeAction = newAction("Switch Mode", ResourceManager.getIcon("dialog.switch"), evt -> {
|
||||
Mode next = mode.next();
|
||||
setState(next, restoreSample(next), false);
|
||||
}
|
||||
};
|
||||
});
|
||||
|
||||
protected final Action approveFormatAction = new AbstractAction("Use Format", ResourceManager.getIcon("dialog.continue")) {
|
||||
|
||||
@Override
|
||||
public void actionPerformed(ActionEvent evt) {
|
||||
protected final Action approveFormatAction = newAction("Use Format", ResourceManager.getIcon("dialog.continue"), evt -> {
|
||||
try {
|
||||
// check syntax
|
||||
format = new ExpressionFormat(editor.getText().trim());
|
||||
@ -711,12 +686,11 @@ public class FormatDialog extends JDialog {
|
||||
|
||||
finish(true);
|
||||
} catch (ScriptException e) {
|
||||
log.log(Level.WARNING, ExceptionUtilities.getRootCauseMessage(e));
|
||||
log.log(Level.WARNING, getRootCauseMessage(e));
|
||||
} catch (Exception e) {
|
||||
log.log(Level.WARNING, e.getMessage(), e);
|
||||
}
|
||||
}
|
||||
};
|
||||
});
|
||||
|
||||
protected void fireSampleChanged() {
|
||||
firePropertyChange("sample", null, sample);
|
||||
|
Loading…
Reference in New Issue
Block a user