* directly use NSOpenPanel for via Objective-C bridge for FILES_AND_DIRECTORIES mode
This commit is contained in:
parent
2ed4c50be0
commit
98e3df40a1
@ -276,7 +276,7 @@
|
||||
<option value="-Dapplication.cache=./Library/Caches/ehcache.disk.store" />
|
||||
<option value="-Djava.io.tmpdir=./Library/Caches/java.io.tmpdir" />
|
||||
|
||||
<option value="-Dnet.filebot.UserFiles.fileChooser=AWT" />
|
||||
<option value="-Dnet.filebot.UserFiles.fileChooser=COCOA" />
|
||||
|
||||
<option value="-Dapplication.deployment=mas" />
|
||||
<option value="-Dapplication.update=skip" />
|
||||
|
@ -20,6 +20,7 @@ import java.util.logging.Logger;
|
||||
import javax.swing.JFileChooser;
|
||||
|
||||
import net.filebot.mac.MacAppUtilities;
|
||||
import net.filebot.mac.NativeFileDialog;
|
||||
import net.filebot.util.FileUtilities.ExtensionFileFilter;
|
||||
|
||||
public class UserFiles {
|
||||
@ -189,6 +190,39 @@ public class UserFiles {
|
||||
}
|
||||
},
|
||||
|
||||
COCOA {
|
||||
|
||||
@Override
|
||||
public List<File> showLoadDialogSelectFiles(boolean folderMode, boolean multiSelection, File defaultFile, ExtensionFileFilter filter, String title, Object parent) {
|
||||
// directly use NSOpenPanel for via Objective-C bridge for FILES_AND_DIRECTORIES mode
|
||||
if (folderMode && filter != null) {
|
||||
try {
|
||||
NativeFileDialog nsOpenPanel = new NativeFileDialog(title, FileDialog.LOAD);
|
||||
nsOpenPanel.setMultipleMode(true);
|
||||
nsOpenPanel.setCanChooseDirectories(true);
|
||||
nsOpenPanel.setCanChooseFiles(true);
|
||||
if (!filter.acceptAny()) {
|
||||
nsOpenPanel.setAllowedFileTypes(asList(filter.extensions()));
|
||||
}
|
||||
nsOpenPanel.setVisible(true);
|
||||
return asList(nsOpenPanel.getFiles());
|
||||
} catch (Throwable e) {
|
||||
Logger.getLogger(UserFiles.class.getName()).log(Level.WARNING, e.toString());
|
||||
}
|
||||
}
|
||||
|
||||
// default to AWT implementation
|
||||
return AWT.showLoadDialogSelectFiles(folderMode, multiSelection, defaultFile, filter, title, parent);
|
||||
}
|
||||
|
||||
@Override
|
||||
public File showSaveDialogSelectFile(boolean folderMode, File defaultFile, String title, Object parent) {
|
||||
// default to AWT implementation
|
||||
return AWT.showSaveDialogSelectFile(folderMode, defaultFile, title, parent);
|
||||
}
|
||||
|
||||
},
|
||||
|
||||
JavaFX {
|
||||
|
||||
@Override
|
||||
|
@ -1,6 +1,5 @@
|
||||
package net.filebot.ui.list;
|
||||
|
||||
import static java.util.Arrays.*;
|
||||
import static net.filebot.MediaTypes.*;
|
||||
import static net.filebot.util.FileUtilities.*;
|
||||
|
||||
@ -13,6 +12,7 @@ import net.filebot.torrent.Torrent;
|
||||
import net.filebot.ui.FileBotList;
|
||||
import net.filebot.ui.transfer.FileTransferablePolicy;
|
||||
import net.filebot.util.FileUtilities;
|
||||
import net.filebot.util.FileUtilities.ExtensionFileFilter;
|
||||
|
||||
class FileListTransferablePolicy extends FileTransferablePolicy {
|
||||
|
||||
@ -80,7 +80,7 @@ class FileListTransferablePolicy extends FileTransferablePolicy {
|
||||
|
||||
@Override
|
||||
public List<String> getFileFilterExtensions() {
|
||||
return asList("*");
|
||||
return ExtensionFileFilter.WILDCARD;
|
||||
}
|
||||
|
||||
}
|
||||
|
@ -1,6 +1,5 @@
|
||||
package net.filebot.ui.rename;
|
||||
|
||||
import static java.util.Arrays.*;
|
||||
import static net.filebot.MediaTypes.*;
|
||||
import static net.filebot.ui.NotificationLogging.*;
|
||||
import static net.filebot.util.FileUtilities.*;
|
||||
@ -18,6 +17,7 @@ import net.filebot.media.MediaDetection;
|
||||
import net.filebot.ui.transfer.BackgroundFileTransferablePolicy;
|
||||
import net.filebot.util.ExceptionUtilities;
|
||||
import net.filebot.util.FastFile;
|
||||
import net.filebot.util.FileUtilities.ExtensionFileFilter;
|
||||
|
||||
class FilesListTransferablePolicy extends BackgroundFileTransferablePolicy<File> {
|
||||
|
||||
@ -102,7 +102,7 @@ class FilesListTransferablePolicy extends BackgroundFileTransferablePolicy<File>
|
||||
|
||||
@Override
|
||||
public List<String> getFileFilterExtensions() {
|
||||
return asList("*");
|
||||
return ExtensionFileFilter.WILDCARD;
|
||||
}
|
||||
|
||||
@Override
|
||||
|
@ -1,6 +1,7 @@
|
||||
package net.filebot.util;
|
||||
|
||||
import static java.util.Arrays.*;
|
||||
import static java.util.Collections.*;
|
||||
|
||||
import java.io.BufferedInputStream;
|
||||
import java.io.File;
|
||||
@ -718,6 +719,8 @@ public final class FileUtilities {
|
||||
|
||||
public static class ExtensionFileFilter implements FileFilter, FilenameFilter {
|
||||
|
||||
public static final List<String> WILDCARD = singletonList("*");
|
||||
|
||||
private final String[] extensions;
|
||||
|
||||
public ExtensionFileFilter(String... extensions) {
|
||||
@ -742,12 +745,21 @@ public final class FileUtilities {
|
||||
return hasExtension(name, extensions);
|
||||
}
|
||||
|
||||
public boolean acceptAny() {
|
||||
return extensions.length == 1 && WILDCARD.get(0).equals(extensions[0]);
|
||||
}
|
||||
|
||||
public boolean acceptExtension(String extension) {
|
||||
for (String other : extensions) {
|
||||
if (other.equalsIgnoreCase(extension))
|
||||
if (acceptAny()) {
|
||||
return true;
|
||||
}
|
||||
|
||||
for (String other : extensions) {
|
||||
if (other.equalsIgnoreCase(extension)) {
|
||||
return true;
|
||||
}
|
||||
}
|
||||
|
||||
return false;
|
||||
}
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user