/**
* Copyright (C) 2012-2014 the original author or authors.
*
* 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 controllers;
import ninja.Context;
import ninja.Result;
import ninja.Results;
import ninja.i18n.Lang;
import ninja.params.PathParam;
import com.google.inject.Inject;
import com.google.inject.Singleton;
@Singleton
public class I18nController {
@Inject
Lang lang;
public Result index(Context context) {
// Only render the page. It contains some language specific strings.
// It will use the requested language (or a fallback language)
// from Accept-Language header
Result result = Results.html();
// just in case we set the language => we remove it...
lang.clearLanguage(result);
return result;
}
public Result indexWithLanguage(@PathParam("language") String language) {
Result result = Results.ok().html().template("/views/I18nController/index.ftl.html");
// This gets an url like /i18n/en
// language is then the "en" part of the url.
// We take that part and set that language as the default language
// of the framework for this user.
lang.setLanguage(language, result);
return result;
}
}