/*
*
* * Copyright (c) 2016. David Sowerby
* *
* * Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with
* * the License. You may obtain a copy of the License at http://www.apache.org/licenses/LICENSE-2.0
* *
* * Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on
* * an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the
* * specific language governing permissions and limitations under the License.
*
*/
package uk.q3c.krail.core.i18n;
import uk.q3c.krail.core.guice.vsscope.VaadinSessionScoped;
import java.util.Locale;
/**
* Provides a reference to the currently selected Locale. Changes to Locale are published by the session scoped event bus. It is expected that implementations
* will generally be {@link VaadinSessionScoped} as the selection of locale is a choice usually available to an individual user.
* <p>
*
* @author David Sowerby 3 Mar 2013
*/
public interface CurrentLocale {
/**
* Sets up the locale from the environment (typically browser locale and user option settings)
*/
void readFromEnvironment();
Locale getLocale();
/**
* Equivalent to {@link #setLocale(Locale, boolean)} with fireListeners = true
*
* @param locale
*/
void setLocale(Locale locale);
void setLocale(Locale locale, boolean fireListeners);
}