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

com.alee.extended.language.LanguageChooserModel 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.extended.language;

import com.alee.api.annotations.NotNull;
import com.alee.laf.combobox.WebComboBoxModel;
import com.alee.managers.language.*;
import com.alee.managers.language.data.Dictionary;
import com.alee.utils.CollectionUtils;
import com.alee.utils.collection.ImmutableList;

import java.util.ArrayList;
import java.util.Collection;
import java.util.List;
import java.util.Locale;

/**
 * Custom model for {@link LanguageChooser}.
 *
 * @author Mikle Garin
 */
public class LanguageChooserModel extends WebComboBoxModel implements LanguageListener, DictionaryListener
{
    /**
     * {@link List} of {@link Locale}s to limit choice to.
     * Although only {@link Locale}s that are {@link LanguageManager#isSuportedLocale(Locale)} will be used.
     * In case this list is not specified full list of {@link LanguageManager#getSupportedLocales()} will be used.
     */
    protected List locales;

    /**
     * Constructs new {@link LanguageChooserModel}.
     */
    public LanguageChooserModel ()
    {
        this ( new ImmutableList () );
    }

    /**
     * Constructs new {@link LanguageChooserModel}.
     *
     * @param locales {@link Locale}s to limit choice to
     */
    public LanguageChooserModel ( final Locale... locales )
    {
        this ( new ImmutableList ( locales ) );
    }

    /**
     * Constructs new {@link LanguageChooserModel}.
     *
     * @param locales {@link Collection} of {@link Locale}s to limit choice to
     */
    public LanguageChooserModel ( final Collection locales )
    {
        super ();
        this.locales = new ImmutableList ( locales );
        updateLocales ();
    }

    /**
     * Returns {@link List} of {@link Locale}s to choice is limited to.
     *
     * @return {@link List} of {@link Locale}s to choice is limited to
     */
    public List getLocales ()
    {
        return locales;
    }

    /**
     * Sets {@link Locale}s to limit choice to.
     *
     * @param locales new {@link Locale}s to limit choice to
     */
    public void setLocales ( final Locale... locales )
    {
        this.locales = new ImmutableList ( locales );
        updateLocales ();
    }

    /**
     * Sets {@link Collection} of {@link Locale}s to limit choice to.
     *
     * @param locales new {@link Collection} of {@link Locale}s to limit choice to
     */
    public void setLocales ( final Collection locales )
    {
        this.locales = new ImmutableList ( locales );
        updateLocales ();
    }

    /**
     * Updates model data according to currently supported and default global locales.
     */
    protected void updateLocales ()
    {
        final List data;
        if ( CollectionUtils.notEmpty ( locales ) )
        {
            // If locales are limited we use all supported ones from the limitation list
            data = LanguageManager.getSupportedLocales ( locales );
        }
        else
        {
            // If locales are not explicitly limited we use all supported ones
            data = new ArrayList ( LanguageManager.getSupportedLocales () );

            // We also try to add default system locale into the list if it is not there yet
            // This will help us to avoid confusion of supported system local being initially selected while not in the options list
            final Locale systemLocale = LanguageUtils.getSystemLocale ();
            if ( LanguageManager.isSuportedLocale ( systemLocale ) && !data.contains ( systemLocale ) )
            {
                data.add ( 0, systemLocale );
            }
        }
        setAll ( data );

        // Selected locale will always be selected in LanguageChooser as well
        // Even if it is not included into limitation list or it is not even supported
        // That is why you have to handle initialy selected language properly within your application
        setSelectedItem ( LanguageManager.getLocale () );
    }

    @Override
    public void languageChanged ( @NotNull final Language oldLanguage, @NotNull final Language newLanguage )
    {
        updateLocales ();
    }

    @Override
    public void dictionaryAdded ( @NotNull final Dictionary dictionary )
    {
        updateLocales ();
    }

    @Override
    public void dictionaryRemoved ( @NotNull final Dictionary dictionary )
    {
        updateLocales ();
    }

    @Override
    public void dictionariesCleared ()
    {
        updateLocales ();
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy