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

com.alee.laf.text.AbstractTextFieldPainter Maven / Gradle / Ivy

package com.alee.laf.text;

import com.alee.api.annotations.NotNull;
import com.alee.api.annotations.Nullable;
import com.alee.api.jdk.Objects;
import com.alee.laf.WebLookAndFeel;
import com.alee.painter.decoration.IDecoration;
import com.alee.utils.SwingUtils;

import javax.swing.plaf.basic.BasicTextUI;
import javax.swing.text.JTextComponent;
import java.awt.*;
import java.awt.event.ComponentAdapter;
import java.awt.event.ComponentEvent;

/**
 * Abstract painter for {@link JTextComponent}-based text field implementations.
 *
 * @param  component type
 * @param  component UI type
 * @param  decoration type
 * @author Alexandr Zernov
 * @author Mikle Garin
 */
public abstract class AbstractTextFieldPainter>
        extends AbstractTextEditorPainter implements IAbstractTextFieldPainter
{
    /**
     * Leading and trailing components resize listener.
     */
    protected transient ComponentAdapter componentResizeListener;

    @Override
    protected void installPropertiesAndListeners ()
    {
        super.installPropertiesAndListeners ();
        installCustomSettings ();
        installLeadingTrailingResizeListener ();
    }

    @Override
    protected void uninstallPropertiesAndListeners ()
    {
        uninstallLeadingTrailingResizeListener ();
        uninstallCustomLayout ();
        super.uninstallPropertiesAndListeners ();
    }

    @Override
    protected void propertyChanged ( @NotNull final String property, @Nullable final Object oldValue, @Nullable final Object newValue )
    {
        // Perform basic actions on property changes
        super.propertyChanged ( property, oldValue, newValue );

        // Updating leading and trailing components state
        if ( Objects.equals ( property, WebLookAndFeel.ENABLED_PROPERTY ) )
        {
            if ( getLeadingComponent () != null )
            {
                SwingUtils.setEnabledRecursively ( getLeadingComponent (), component.isEnabled () );
            }
            if ( getTrailingComponent () != null )
            {
                SwingUtils.setEnabledRecursively ( getTrailingComponent (), component.isEnabled () );
            }
        }

        // Updating listeners and borders on leading or trailing component change
        if ( Objects.equals ( property, WebLookAndFeel.LEADING_COMPONENT_PROPERTY, WebLookAndFeel.TRAILING_COMPONENT_PROPERTY ) )
        {
            uninstallResizeListener ( ( Component ) oldValue );
            installResizeListener ( ( Component ) newValue );
            updateBorder ();
        }
    }

    /**
     * Installs custom field settings.
     */
    protected void installCustomSettings ()
    {
        // Configuring enabled state handling
        SwingUtils.setHandlesEnableStateMark ( component );

        // Installing custom field layout that can handle leading and trailing components
        component.setLayout ( new TextFieldLayout ( this ) );
    }

    /**
     * Uninstalls custom field settings.
     */
    protected void uninstallCustomLayout ()
    {
        // Uninstalling custom layout from the field
        component.setLayout ( null );

        // Restoring enabled state handling
        SwingUtils.removeHandlesEnableStateMark ( component );
    }

    /**
     * Installs resize listener into leading and trailing components.
     */
    protected void installLeadingTrailingResizeListener ()
    {
        componentResizeListener = new ComponentAdapter ()
        {
            @Override
            public void componentResized ( final ComponentEvent e )
            {
                updateBorder ();
            }
        };
        installResizeListener ( getLeadingComponent () );
        installResizeListener ( getTrailingComponent () );
    }

    /**
     * Uninstalls resize listener from leading and trailing components.
     */
    protected void uninstallLeadingTrailingResizeListener ()
    {
        uninstallResizeListener ( getTrailingComponent () );
        uninstallResizeListener ( getLeadingComponent () );
        componentResizeListener = null;
    }

    /**
     * Installs resize listener into the specified component.
     *
     * @param component component to install listener into
     */
    protected void installResizeListener ( final Component component )
    {
        if ( component != null )
        {
            component.addComponentListener ( componentResizeListener );
        }
    }

    /**
     * Uninstalls resize listener from the specified component.
     *
     * @param component component to uninstall listener from
     */
    protected void uninstallResizeListener ( final Component component )
    {
        if ( component != null )
        {
            component.removeComponentListener ( componentResizeListener );
        }
    }

    @Nullable
    @Override
    protected Insets getBorder ()
    {
        final Insets border = super.getBorder ();
        final Component lc = getLeadingComponent ();
        final Component tc = getTrailingComponent ();
        final Insets result;
        if ( lc != null || tc != null )
        {
            final int left = lc != null ? lc.getPreferredSize ().width : 0;
            final int right = tc != null ? tc.getPreferredSize ().width : 0;
            if ( border != null )
            {
                result = new Insets ( border.top, border.left + left, border.bottom, border.right + right );
            }
            else
            {
                result = new Insets ( 0, left, 0, right );
            }
        }
        else
        {
            result = border;
        }
        return result;
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy