Datatable wewnątrz programowo dodanego komponentu kompozytowego

Nawiązując do mojego wcześniejszego pytania (Programowo utwórz i dodaj komponent kompozytowy w fasoli podkładowej) Udało mi się dodać komponenty kompozytowe z fasoli podkładowej. Teraz mam nowy problem, ponieważ komponent złożony z leniwą datatable w ogóle nie wywołuje metody load (). Wystąpił błąd dotyczący tego (https://code.google.com/p/primefaces/issues/detail?id=3258), ale jest to oznaczone jako związane z PF3.0.RC1 i nie mam pojęcia, czy jest to poprawione dla wersji 3.5, której używam.

Używam dokładnie tego samego kodu, o którym wspomniał BalusC, z możliwością dodawania wyrażeń wartości do komponentu złożonego:

public void includeCompositeComponent(UIComponent parent, String libraryName, String resourceName, String id, Map<String, String> valueExpressions) {
    ...
    if (!valueExpressions.isEmpty()) {
        ExpressionFactory factory = application.getExpressionFactory();
        ELContext ctx = context.getELContext();
        for (Map.Entry<String, String> entry : valueExpressions.entrySet()) {
            ValueExpression expr = factory.createValueExpression(ctx, entry.getValue(), String.class);
            composite.setValueExpression(entry.getKey(), expr);
        }
    } 
    ...
}

A to jest mój złożony komponent testDatatable.xhtml:

<cc:interface>
    <composite:attribute name="model" required="true" type="org.primefaces.model.LazyDataModel"/>
    <composite:attribute name="id" default="dataTable"/>
</cc:interface>
<cc:implementation>
    <h:form id="dataTableForm">    
        <p:dataTable id="#{cc.attrs.id}" value="#{cc.attrs.model}" var="test" paginator="true" rows="10"
                     paginatorTemplate="{RowsPerPageDropdown} {FirstPageLink} {PreviousPageLink} {CurrentPageReport} {NextPageLink} {LastPageLink}"
                     rowsPerPageTemplate="5,10,15,20" lazy="true">
            <p:column>
                <h:outputText value="#{test.car.model}"/>
            </p:column>
         </p:dataTable>
    </h:form>
</cc:implementation>

A oto tworzenie komponentu kompozytowego z fasoli podkładowej:

Map<String, String> v = new HashMap<String, String>();
v.put("model", "#{testBean.lazyModel}");
addCompositeComponent(rootPanel, "comp", "testDatatable.xhtml", "table", v);

Oto leniwy model danych ładuję w @PostConstruct

pulic class TestBean {
    private TestLazyDataModel<TestClass> lazyModel;

    @PostConstruct
    public void init() {
        lazyModel = new TestLazyDataModel();
    }

    public TestLazyDataModel<TestClass> getLazyModel() {
        return lazyModel;
    }

    class TestLazyDataModel extends LazyDataModel<TestClass> {
        @Override
        public List<TestClass> load(int first, int pageSize, String sort, SortOrder sortOrder, Map<String, String> filters) {
            List<TestClass> ret = new ArrayList<TestClass>();
            TestClass t = new TestClass();
            Car c = new Car("Volvo");
            t.setCar(c);
            ret.add(t);
            return ret;
        }
    }
}

I niektóre klasy pomocnicze:

public class TestClass {
    private Car car;

    public void setCar(Car car) {
        this.car = car;
    }

    public Car getCar() {
        return car;
    }
}

public class Car {
    public String model;

    public Car(String model) {
        this.model = model;
    }

    public String getModel() {
        return model;
    } 
}

Podsumowując, gdy strona jest teraz otwarta:

Komponent bean tworzy model danych leniwych OKLeniwy model danych jest prawidłowo pobierany z komponentu kompozytowegoGdy datatable próbuje zapętlić w nim elementy, błąd: klasa 'java.lang.String' nie ma właściwości 'car'

Zmienianie<h:outputText value="#{test.car.model}"/> do<h:outputText value="#{test.class.name}"/> także java.lang.String, ale tym razem nie ulega awarii. Podczas debugowania metoda load () metody TestLazyDataModel nigdy nie jest wywoływana.

Jeszcze dziwniejsze jest to, że jeśli używam tego samego komponentu kompozytowego z dowolnej innej strony xhtml, takiej jak:

<comp:testDatatable model="#{anotherBean.model}"> 

to działa dobrze. czego mi brakuje? Czy jest to w jakiś sposób związane z kolejnością renderowania komponentów? Każda pomoc jest bardzo ceniona!

questionAnswers(1)

yourAnswerToTheQuestion