Я пытаюсь отобразить дерево категорий, следуя базовым примерам CellTree gwt.
Я застрял в определении "листового" состояния категории.
AКатегория "это лист", когда нет детей, верно?Итак, вот моя категория (я использую Objectify для персистентности appengine):
@Entity
public class Categoria implements Serializable {
private static final long serialVersionUID = 1L;
@Id
Long id;
String nome;
Key<Categoria> parent;
public Categoria() { }
public Categoria(String nome) {
super();
this.nome = nome;
}
public String getNome() {
return nome;
}
public void setNome(String nome) {
this.nome = nome;
}
public Key<Categoria> getParent() {
return parent;
}
public void setParent(Key<Categoria> parent) {
this.parent = parent;
}
}
Мой TreeViewModel основан на AsyncDataProvider (который я передаю извне):
public class CategorieTreeViewModel implements TreeViewModel {
private AbstractDataProvider<Categoria> dataProvider;
public CategorieTreeViewModel(AbstractDataProvider<Categoria> dataProvider) {
this.dataProvider = dataProvider;
}
@Override
public <T> NodeInfo<?> getNodeInfo(T value) {
return new DefaultNodeInfo<Categoria>(dataProvider, new CategoriaCell());
}
@Override
public boolean isLeaf(Object value) {
return false;
}
}
Так вот этоэто:
dataProvider = new AsyncDataProvider<Categoria>() {
@Override
protected void onRangeChanged(HasData<Categoria> display) {
updateTree();
}
};
private void updateTree() {
rpcService.getCategorie(new AsyncCallback<Categoria[]>() {
@Override
public void onSuccess(Categoria[] result) {
dataProvider.updateRowCount(result.length, true);
dataProvider.updateRowData(0, Arrays.asList(result));
}
@Override
public void onFailure(Throwable caught) {
Window.alert(caught.toString());
}
});
}
Вопрос: поскольку у меня нет «свойства листа» в моем компоненте категории, как я могу узнать, есть ли у него дети или нет?Выполняя запрос, очевидно, но метод isLeaf должен возвращаться синхронно, как я могу сделать мой вызов RPC?
Или я могу получить эту «листовую» информацию в вызове getCategorie (), заполняя свойство во время выполнения, но это может быть проблемой производительности.
Что я могу сделать?