All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.alee.extended.tree.FileTreeNode Maven / Gradle / Ivy

There is a newer version: 1.2.14
Show newest version
/*
 * 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.extended.tree;

import com.alee.api.annotations.NotNull;
import com.alee.api.annotations.Nullable;
import com.alee.api.ui.TextBridge;
import com.alee.laf.tree.TreeNodeParameters;
import com.alee.utils.FileUtils;

import javax.swing.*;
import java.io.File;

/**
 * {@link AsyncUniqueNode} representing single {@link File}.
 *
 * @author Mikle Garin
 */
public class FileTreeNode extends AsyncUniqueNode
        implements TextBridge>>
{
    /**
     * Root node ID.
     */
    public static final String rootId = "File.tree.root";

    /**
     * Custom node title.
     */
    @Nullable
    protected String title;

    /**
     * Constructs file node for the specified file.
     *
     * @param file node file
     */
    public FileTreeNode ( @Nullable final File file )
    {
        super ( file );
        this.title = null;
    }

    @NotNull
    @Override
    public String getId ()
    {
        final File file = getUserObject ();
        return file != null ? file.getAbsolutePath () : rootId;
    }

    /**
     * Returns file for this node.
     *
     * @return file for this node
     */
    @Nullable
    public File getFile ()
    {
        return getUserObject ();
    }

    /**
     * Sets file for this node.
     *
     * @param file file for this node
     */
    public void setFile ( @Nullable final File file )
    {
        setUserObject ( file );
    }

    @Nullable
    @Override
    public Icon getNodeIcon ( @NotNull final TreeNodeParameters> parameters )
    {
        final File file = getUserObject ();
        return file != null ? FileUtils.getFileIcon ( file, false ) : null;
    }

    @Override
    public String getText ( @NotNull final TreeNodeParameters> parameters )
    {
        return getTitle ();
    }

    /**
     * Returns node title.
     *
     * @return node title
     */
    @NotNull
    public String getTitle ()
    {
        final String title;
        if ( this.title != null )
        {
            title = this.title;
        }
        else
        {
            final File file = getUserObject ();
            if ( file != null )
            {
                String name = FileUtils.getDisplayFileName ( file );
                if ( name != null && !name.trim ().equals ( "" ) )
                {
                    title = name;
                }
                else
                {
                    name = file.getName ();
                    if ( !name.trim ().equals ( "" ) )
                    {
                        title = name;
                    }
                    else
                    {
                        title = FileUtils.getFileDescription ( file, null ).getDescription ();
                    }
                }
            }
            else
            {
                title = rootId;
            }
        }
        return title;
    }

    /**
     * Sets custom name for this node.
     *
     * @param title custom name for this node
     */
    public void setTitle ( @Nullable final String title )
    {
        this.title = title;
    }

    /**
     * Returns index of child node with the specified file.
     *
     * @param file file to search for in child nodes
     * @return index of child node with the specified file
     */
    public int indexOfFileChild ( @Nullable final File file )
    {
        int index = -1;
        for ( int i = 0; i < getChildCount (); i++ )
        {
            if ( FileUtils.equals ( getChildAt ( i ).getFile (), file ) )
            {
                index = i;
                break;
            }
        }
        return index;
    }

    @NotNull
    @Override
    public String toString ()
    {
        return getTitle ();
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy