com.alee.laf.filechooser.WebFileChooserUI Maven / Gradle / Ivy
/*
* This file is part of WebLookAndFeel library.
*
* WebLookAndFeel library is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* WebLookAndFeel library is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with WebLookAndFeel library. If not, see .
*/
package com.alee.laf.filechooser;
import com.alee.global.GlobalConstants;
import com.alee.laf.WebLookAndFeel;
import com.alee.managers.language.LanguageManager;
import com.alee.utils.FileUtils;
import com.alee.utils.LafUtils;
import com.alee.utils.filefilter.AbstractFileFilter;
import javax.swing.*;
import javax.swing.filechooser.FileFilter;
import javax.swing.filechooser.FileView;
import javax.swing.plaf.ComponentUI;
import javax.swing.plaf.FileChooserUI;
import java.awt.*;
import java.awt.event.ActionEvent;
import java.awt.event.ActionListener;
import java.beans.PropertyChangeEvent;
import java.beans.PropertyChangeListener;
import java.io.File;
import java.util.ArrayList;
import java.util.List;
/**
* Custom UI for JFileChooser component.
*
* @author Mikle Garin
*/
public class WebFileChooserUI extends FileChooserUI
{
/**
* File chooser which is decorated by this UI class.
*/
private JFileChooser fileChooser;
/**
* Special FileView for file chooser.
*/
private WebFileView fileView;
/**
* File chooser panel that contains al UI elements.
*/
private WebFileChooserPanel fileChooserPanel;
/**
* FilChooser listeners.
*/
private PropertyChangeListener propertyChangeListener;
/**
* Mark to ignore file selection property events.
*/
private boolean ignoreFileSelectionChanges = false;
/**
* Returns an instance of the WebFileChooserUI for the specified component.
* This tricky method is used by UIManager to create component UIs when needed.
*
* @param c component that will use UI instance
* @return instance of the WebFileChooserUI
*/
@SuppressWarnings ("UnusedParameters")
public static ComponentUI createUI ( final JComponent c )
{
return new WebFileChooserUI ();
}
/**
* Constructs new WebFileChooserUI.
*/
public WebFileChooserUI ()
{
super ();
}
/**
* Installs UI in the specified component.
*
* @param c component for this UI
*/
@Override
public void installUI ( final JComponent c )
{
fileChooser = ( JFileChooser ) c;
fileView = new WebFileView ();
fileChooser.setLayout ( new BorderLayout () );
fileChooser.setBorder ( LafUtils.createWebBorder ( 0, 0, 0, 0 ) );
fileChooserPanel = new WebFileChooserPanel ( getFileChooserType (), fileChooser.getControlButtonsAreShown () );
fileChooserPanel.setMultiSelectionEnabled ( fileChooser.isMultiSelectionEnabled () );
fileChooserPanel.setShowHiddenFiles ( !fileChooser.isFileHidingEnabled () );
fileChooserPanel.setApproveListener ( new ActionListener ()
{
@Override
public void actionPerformed ( final ActionEvent e )
{
ignoreFileSelectionChanges = true;
final List selectedFiles = fileChooserPanel.getSelectedFiles ();
fileChooser.setSelectedFiles ( selectedFiles.toArray ( new File[ selectedFiles.size () ] ) );
ignoreFileSelectionChanges = false;
fileChooser.approveSelection ();
}
} );
fileChooserPanel.setCancelListener ( new ActionListener ()
{
@Override
public void actionPerformed ( final ActionEvent e )
{
fileChooser.cancelSelection ();
}
} );
// fileChooserPanel.addFileChooserListener ( new FileChooserListener ()
// {
// public void directoryChanged ( File newDirectory )
// {
// ignoreFileSelectionChanges = true;
// fileChooser.setCurrentDirectory ( newDirectory );
// ignoreFileSelectionChanges = false;
// }
//
// public void selectionChanged ( List selectedFiles )
// {
// ignoreFileSelectionChanges = true;
// fileChooser.setSelectedFiles ( selectedFiles.toArray ( new File[ selectedFiles.size () ] ) );
// ignoreFileSelectionChanges = false;
// }
// } );
fileChooser.add ( fileChooserPanel, BorderLayout.CENTER );
propertyChangeListener = new PropertyChangeListener ()
{
@Override
public void propertyChange ( final PropertyChangeEvent evt )
{
propertyChanged ( evt );
}
};
fileChooser.addPropertyChangeListener ( propertyChangeListener );
}
/**
* Uninstalls UI from the specified component.
*
* @param c component with this UI
*/
@Override
public void uninstallUI ( final JComponent c )
{
fileChooser.removePropertyChangeListener ( propertyChangeListener );
fileChooserPanel = null;
fileChooser = null;
fileView = null;
}
/**
* Returns file chooser panel.
*
* @return file chooser panel
*/
public WebFileChooserPanel getFileChooserPanel ()
{
return fileChooserPanel;
}
/**
* Returns list of available file filters.
*
* @return list of available file filters
*/
public List getAvailableFilters ()
{
return fileChooserPanel.getAvailableFilters ();
}
/**
* Returns currenly active file filter.
*
* @return currenly active file filter
*/
public AbstractFileFilter getActiveFileFilter ()
{
return fileChooserPanel.getActiveFileFilter ();
}
/**
* Returns whether file thumbnails are generated or not.
*
* @return true if file thumbnails are generated, false otherwise
*/
public boolean isGenerateThumbnails ()
{
return fileChooserPanel.isGenerateThumbnails ();
}
/**
* Sets whether file thumbnails should be generated or not.
*
* @param generate whether file thumbnails should be generated or not
*/
public void setGenerateThumbnails ( final boolean generate )
{
fileChooserPanel.setGenerateThumbnails ( generate );
}
/**
* Sets approve button text type.
*
* @param approveText approve button text type
*/
public void setApproveButtonText ( final FileApproveText approveText )
{
fileChooserPanel.setApproveButtonText ( approveText );
}
/**
* Sets approve button language key.
*
* @param key approve button language key
*/
public void setApproveButtonLanguage ( final String key )
{
fileChooserPanel.setApproveButtonLanguage ( key );
}
/**
* Fired when some of JFileChooser properties changes.
*
* @param event property change event
*/
protected void propertyChanged ( final PropertyChangeEvent event )
{
final String prop = event.getPropertyName ();
if ( prop.equals ( JFileChooser.APPROVE_BUTTON_TEXT_CHANGED_PROPERTY ) )
{
fileChooserPanel.setApproveButtonText ( fileChooser.getApproveButtonText () );
}
else if ( prop.equals ( JFileChooser.CONTROL_BUTTONS_ARE_SHOWN_CHANGED_PROPERTY ) )
{
fileChooserPanel.setShowControlButtons ( fileChooser.getControlButtonsAreShown () );
}
else if ( prop.equals ( JFileChooser.MULTI_SELECTION_ENABLED_CHANGED_PROPERTY ) )
{
fileChooserPanel.setMultiSelectionEnabled ( fileChooser.isMultiSelectionEnabled () );
}
else if ( prop.equals ( JFileChooser.FILE_FILTER_CHANGED_PROPERTY ) ||
prop.equals ( JFileChooser.CHOOSABLE_FILE_FILTER_CHANGED_PROPERTY ) ||
prop.equals ( JFileChooser.ACCEPT_ALL_FILE_FILTER_USED_CHANGED_PROPERTY ) )
{
final FileFilter filter = fileChooser.getFileFilter ();
final FileFilter[] filters = fileChooser.getChoosableFileFilters ();
// Collecting all filters
final int initialCapacity = ( filters != null ? filters.length : 0 ) + ( filter != null ? 1 : 0 );
final List collected = new ArrayList ( initialCapacity );
if ( filter != null )
{
collected.add ( filter );
}
if ( filters != null && filters.length > 0 )
{
for ( final FileFilter fileFilter : filters )
{
if ( !collected.contains ( fileFilter ) )
{
collected.add ( fileFilter );
}
}
}
// Applying filters
if ( collected.size () > 0 )
{
fileChooserPanel.setFileFilters ( collected.toArray ( new FileFilter[ collected.size () ] ) );
}
else
{
fileChooserPanel.setFileFilter ( GlobalConstants.ALL_FILES_FILTER );
}
}
else if ( prop.equals ( JFileChooser.DIRECTORY_CHANGED_PROPERTY ) )
{
if ( !ignoreFileSelectionChanges )
{
fileChooserPanel.setCurrentFolder ( fileChooser.getCurrentDirectory () );
}
}
else if ( prop.equals ( JFileChooser.SELECTED_FILE_CHANGED_PROPERTY ) )
{
if ( !ignoreFileSelectionChanges )
{
final File[] selectedFiles = fileChooser.getSelectedFiles ();
if ( selectedFiles.length > 0 )
{
// Update displayed directory and select all files
// fileChooserPanel.setCurrentFolder ( selectedFiles[ 0 ].getParentFile () );
// fileChooserPanel.setSelectedFiles ( selectedFiles );
fileChooserPanel.setSelectedFiles ( selectedFiles );
}
else
{
// Simply pass the file, it will be selected when directory is opened
// fileChooserPanel.setCurrentFolder ( fileChooser.getSelectedFile () );
fileChooserPanel.setSelectedFile ( fileChooser.getSelectedFile () );
}
}
}
else if ( prop.equals ( JFileChooser.DIALOG_TYPE_CHANGED_PROPERTY ) )
{
fileChooserPanel.setChooserType ( getFileChooserType () );
}
else if ( prop.equals ( JFileChooser.FILE_HIDING_CHANGED_PROPERTY ) )
{
fileChooserPanel.setShowHiddenFiles ( !fileChooser.isFileHidingEnabled () );
}
else if ( prop.equals ( JFileChooser.FILE_SELECTION_MODE_CHANGED_PROPERTY ) )
{
fileChooserPanel.setMultiSelectionEnabled ( fileChooser.isMultiSelectionEnabled () );
}
else if ( prop.equals ( WebLookAndFeel.ORIENTATION_PROPERTY ) )
{
fileChooserPanel.applyComponentOrientation ( fileChooser.getComponentOrientation () );
}
}
/**
* {@inheritDoc}
*/
@Override
public FileFilter getAcceptAllFileFilter ( final JFileChooser fc )
{
return GlobalConstants.ALL_FILES_FILTER;
}
/**
* {@inheritDoc}
*/
@Override
public FileView getFileView ( final JFileChooser fc )
{
return fileView;
}
/**
* @param fileView
*/
public void setFileView ( final WebFileView fileView )
{
this.fileView = fileView;
}
/**
* {@inheritDoc}
*/
@Override
public String getApproveButtonText ( final JFileChooser fc )
{
return fileChooserPanel.getApproveButtonText ();
}
/**
* {@inheritDoc}
*/
@Override
public String getDialogTitle ( final JFileChooser fc )
{
final String dialogTitle = fc.getDialogTitle ();
return dialogTitle != null ? dialogTitle : LanguageManager.get ( "weblaf.filechooser.title" );
}
/**
* {@inheritDoc}
*/
@Override
public void rescanCurrentDirectory ( final JFileChooser fc )
{
fileChooserPanel.reloadCurrentFolder ();
}
/**
* {@inheritDoc}
*/
@Override
public void ensureFileIsVisible ( final JFileChooser fc, final File f )
{
// // This is pretty annoying and pointless method, will ignore it for now
// ignoreFileSelectionChanges = true;
// fileChooserPanel.setSelectedFile ( f );
// ignoreFileSelectionChanges = true;
}
/**
* Returns JFileChooser type converted into FileChooserType form.
*
* @return JFileChooser type converted into FileChooserType form
*/
public FileChooserType getFileChooserType ()
{
if ( fileChooser.getDialogType () == JFileChooser.SAVE_DIALOG )
{
return FileChooserType.save;
}
else if ( fileChooser.getDialogType () == JFileChooser.OPEN_DIALOG )
{
return FileChooserType.open;
}
else
{
return FileChooserType.custom;
}
}
/**
* Special FileView for file chooser.
*/
protected class WebFileView extends FileView
{
/**
* Constructs new WebFileView instance.
*/
public WebFileView ()
{
super ();
}
/**
* {@inheritDoc}
*/
@Override
public String getName ( final File f )
{
return FileUtils.getDisplayFileName ( f );
}
/**
* {@inheritDoc}
*/
@Override
public String getDescription ( final File f )
{
return getTypeDescription ( f );
}
/**
* {@inheritDoc}
*/
@Override
public String getTypeDescription ( final File f )
{
return FileUtils.getFileTypeDescription ( f );
}
/**
* {@inheritDoc}
*/
@Override
public Icon getIcon ( final File f )
{
return FileUtils.getFileIcon ( f );
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy