Я пытаюсь интернационализировать приложение UIBinder файлами свойств. Так как у нас уже есть много переводов, представленных com.google.gwt.i18n.client. Интерфейс сообщений (GWT 1.7.1), мы хотели бы снова использовать эти сообщения.
Я попробовал следующее:
<!DOCTYPE ui:UiBinder SYSTEM "http://dl.google.com/gwt/DTD/xhtml.ent">
<ui:UiBinder xmlns:ui="urn:ui:com.google.gwt.uibinder"
xmlns:g="urn:import:com.google.gwt.user.client.ui"
xmlns:res="ui:with:be.credoc.iov.webapp.client.MessageConstants">
<g:HTMLPanel>
<div>
<res:msg key="email">Emaileke</res:msg>:
<g:TextBox ui:field="email" />
</div>
</g:HTMLPanel>
</ui:UiBinder>
Класс MessageConstants похож на это:
@DefaultLocale("nl")
public interface MessageConstants extends Messages {
String email();
}
Однако это не работает. Как я могу сделать это?
Обновление:
проверьте ответ логана ниже, чтобы узнать о решении, доступном в последних версиях GWT.
У меня была (фактически была) та же проблема, что и у вас - после перехода на GWT 2.0 у меня был файл свойств, который я хотел использовать в своих файлах UiBinder. К сожалению, мне не удалось заставить его работать так, как я хотел - похоже, разработчики GWT хотят, чтобы люди использовали синтаксис, описанный в руководстве i18n для UiBinder - где интерфейс сообщений создается во время компиляции для каждого Шаблон UiBinder и т. Д.
В любом случае, вы все еще можете использовать внешние интерфейсы Сообщения
, например:
<!DOCTYPE ui:UiBinder SYSTEM "http://dl.google.com/gwt/DTD/xhtml.ent">
<ui:UiBinder xmlns:ui="urn:ui:com.google.gwt.uibinder"
xmlns:g="urn:import:com.google.gwt.user.client.ui">
<ui:with field='cc' type='path.to.i18n.SomeMessages'/>
<ui:with field='res' type='path.to.resource.ResourceBundle'/>
<ui:style>
.required {
color: red;
font-weight: bold;
}
.right {
text-align: right;
}
.textBox {
margin-right: 7px;
}
</ui:style>
<g:HTMLPanel styleName='{res.style.form} {res.style.mbox}' ui:field='mainPanel'>
<h2 ui:field='loginHeader' />
<h3 ui:field='loginLabel' />
<div class='{style.textBox}'><g:TextBox ui:field="loginBox" /></div>
<h3 ui:field='passwordLabel' />
<div class='{style.textBox}'><g:PasswordTextBox ui:field="passwordBox" /></div>
<div><g:CheckBox ui:field='rememberMeCheckBox' text='{cc.rememberMeCheckboxText}' /></div>
<div class='{style.right}'><g:Button ui:field='submitButton' text='{cc.loginSubmitButtonText}' /></div>
</g:HTMLPanel>
</ui:UiBinder>
Хотя это работает только для таких вещей, как заголовок Button
и т. Д., не содержимое разделов: / Вы можете заполнить их в классе за шаблоном UiBinder, но должен быть способ получше.
Я надеялся, что вы сможете установить внутренний HTML-код с помощью innerHTML
(поскольку UiBinder должен распознавать этот метод и позволять устанавливать его значение с помощью шаблона XML / UiBinder), но, увы, в прошлый раз, когда я это проверял, этого не произошло. t work: /
Существует известная проблема с UiBinder в сочетании с интернационализацией, см. Также эту недавнюю ветку в багтрекере gwt: http: // code. google.com/p/google-web-toolkit/issues/detail?id=4355.
В комментарии 4 дано решение:
Если ваш файл UiBinder называется, скажем, 'LoginView.ui.xml', затем вызовите свойства файл LoginViewLoginViewUiBinderImplGenMessages.properties (да, 'LoginView' появляется дважды) и поместите его рядом с файлом java представления в исходном пакете, так что всего у вас будет 3 файла:
LoginView.ui.xml LoginView.java LoginViewLoginViewUiBinderImplGenMessages.properties