Как использовать GWT Binder UI Binder в "внешнем" пакете

Я работаю над веб-приложением, использующим GWT, и нахожусь в процессе его модификации, чтобы он создавался с использованием UiBinder.

У меня есть рабочая версия нескольких связывателей, содержащихся в том же пакете, что и классы, которые на них ссылаются, но у многих из них есть универсальная утилита для всего приложения, и я надеялся выделить их в пакет uibinders.

Вот некоторые фрагменты рабочего кода

Файл TableListPanel.ui.xml:

<!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">
<g:HTMLPanel>
<div id="tableListPanel">
    <g:HTMLPanel styleName="buttonPanel" ui:field="buttonPanel"></g:HTMLPanel>
    <g:HTMLPanel styleName="tableList" ui:field="tableList"></g:HTMLPanel>
    <table align="center"><tr>
        <td align="center"><g:HTMLPanel styleName="tableMenu" ui:field="tableMenu"></g:HTMLPanel></td>
    </tr></table>
</div>
</g:HTMLPanel>

</ui:UiBinder> 

Java-файл TableListPanelBinder:

public class TableListPanelBinder extends Composite implements HasText {

private static AuditPanelUiBinder uiBinder = GWT
        .create(AuditPanelUiBinder.class);

interface AuditPanelUiBinder extends UiBinder<Widget, TableListPanelBinder> {
}

public TableListPanelBinder() {
    initWidget(uiBinder.createAndBindUi(this));
}

@UiField
protected HTMLPanel buttonPanel;

@UiField
protected HTMLPanel tableList;

@UiField
protected HTMLPanel tableMenu;

public void bindUiElement(HTMLPanel container, Widget widjetObj) {
    container.add(widjetObj);
}

И, наконец, вызов в коде, который связывает виджеты с вышеуказанным пользовательским интерфейсом: fields:

public AuditReportProfilesPanel() {
    super();
    this.setWidth("100%");
    this.setSpacing(4);


    this.parmSetsTable = createParmSetsTable();
    SimplePager.Resources pagerResources = GWT.create(SimplePager.Resources.class);
    pager = new SimplePager(TextLocation.CENTER, pagerResources, false, 0, true);
    pager.setDisplay(parmSetsTable);

    TableListPanelBinder reportListBinder = new TableListPanelBinder();
    this.add(reportListBinder);

    // -START- Bind UI Elements -START-
    reportListBinder.bindUiElement(reportListBinder.tableList, parmSetsTable);
    reportListBinder.bindUiElement(reportListBinder.tableMenu, pager);
    reportListBinder.bindUiElement(reportListBinder.buttonPanel, createActionBar());
    //-END- Bind UI Elements -END-
}

Я знаю, что это, вероятно, не самый чистый способ настроить это, но я учусь на ходу.

Я знаю, что перемещение Binder в другой пакет означает, что модификаторы частного / защищенного доступа не позволят мне получить доступ к коду, но изменение их на public также не принесет мне никакой пользы.

Любые предложения по исправлению будет принята с благодарностью. Это приложение имеет несколько разных пакетов классов (которые по сути равны разным страницам в приложении), и все они используют одинаковые настройки таблиц, поэтому я бы хотел избежать дублирования кода в каждом пакете; Я просто не уверен на 100% в том, как этого добиться.

Решит ли проблему создание абстрактных классов в пакете Binders, а затем их расширение в отдельных пакетах приложений, или мне чего-то не хватает?

1 ответ

Решение
  1. Напишите ваш общий UiBinderS и соответствующие классы (либо Widgetс или Viewу) в назначенной общей упаковке. Давайте назовем это my.general.uibinders пакет.
  2. В твоем UiBinder что соответствует конкретной странице (или Place), импортируйте этот пакет как xmlns атрибут для ui:UiBinder метка во главе UiBinder, Сюда:

    <ui:UiBinder xmlns:ui="urn:ui:com.google.gwt.uibinder" 
        xmlns:g="urn:import:com.google.gwt.user.client.ui"
        xmlns:c="urn:import:my.general.uibinders"> <!-- this is the addition -->
    
  3. Отныне в этом UiBinder, c ссылка на классы, которые проживают в my.general.uibinders, Скажем, у вас есть класс с именем MyGeneralView, используйте это так: <c:MyGeneralView .../> через ваш UiBinder,

Другие вопросы по тегам