<p: ajax> слушатель никогда не вызывается - PullRequest
0 голосов
/ 02 марта 2012

Я новичок в простейших лицах. Я перехожу с primefaces2.2 на primefaces3.1.1, потому что я должен включить в приложение новые функции primefaces3.1.1.

В приложении была функциональность dragndrop. Он отлично работает с primefaces2.2, но когда я внес изменения в соответствии со спецификациями primefaces3.1.1. Функциональность dragndrop не работает.

На самом деле сценарий похож на

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

Строка с данными должна быть перетащена в область дерева. При этом я написал слушателю, но он никогда не вызывается.

Здесь я предоставляю код

workflow.xhtml

 <p:fieldset  id="workflowtabs" legend="Drop here" rendered="#{workflowStep2Bean.childCount gt 0}">
   <p:outputPanel id="dropArea">
<p:treeTable id="testtable" value="#{workflowStep2Bean.root}"  var="selected" rendered="#{not empty workflowStep2Bean.root}" >
                                                            <p:column rendered="#{selected.type eq 'Folder'}">
                                                                <p:commandButton icon="ui-icon ui-icon-folder-open" disabled="true"/>
                                                            </p:column>                                                                
                                                            <p:column rendered="#{selected.type eq 'Folder'}" >
                                                                <h:inputText value="#{selected.name}" />                                                                        
                                                            </p:column>                                                                  
                                                        </p:treeTable>
                                                    </p:outputPanel>      
                                                </p:fieldset>  
<p:fieldset  id="testfields" legend="#{msg.tests}" rendered="#{workflowStep2Bean.childCount gt 0}">
                                                    <p:dataTable id="teststable" value="#{workflowStep2Bean.tests}" var="testList"  >
                                                        <p:column style="height: 20px" headerText="Drag">
                                                            <h:outputText id="dragIcon" styleClass="ui-icon ui-icon-arrow-4"/>
                                                            <p:draggable for="dragIcon" revert="true" scope="#{dragIcon.position}" stack=".ui-icon ui-icon-arrow-4"/>                                                                
                                                        </p:column>                                                           
                                                        <p:column headerText="Name">
                                                            <h:outputText value="#{testList.name}"></h:outputText>
                                                        </p:column>                                                                            
                                                    </p:dataTable>                                                                                                                                                   
                                                </p:fieldset>
<p:droppable for="workflowtabs" tolerance="touch" activeStyleClass="ui-state-highlight" datasource="teststable" onDrop="handleDrop">  
                                            <p:ajax  listener="#{workflowStep2Bean.onTestDrop}" update="dropArea teststable" />  
                                    </p:droppable>  

и вот мой рабочий процесс Step2Bean.java

public void onTestDrop(DragDropEvent ddEvent) {
    if (getTabs().size() > 0) {
        TreeNode tab = getTabs().get(getTabs().size() - 1);
        Test t = (Test) ddEvent.getData();
        tests.remove(t);
        ((Tab) tab.getData()).getTests().add(t);
        TreeNode tabC = new DefaultTreeNode(t, tab);
    }
}

Пожалуйста, скажите мне, где я делаю неправильно. Спасибо заранее

Я использую простые лица 3.1.1, Mojorra 2.1.3, Glassfish 3.1.1, JSF2.0

1 Ответ

0 голосов
/ 22 февраля 2014

У меня была похожая проблема, которую я решил следующим образом:

Наличие <p:droppable> с аргументом onDrop="" и введенной командой <p:ajax ... /> не работало.

Следуя объяснению, приведенному в https://stackoverflow.com/a/19223442/1431979, Сначала я удалил аргумент onDrop="handleDrop()" в моем

<p:droppable for="PD" accept=".#{item.classeInverse}" onDrop="handelDrop()" />

и заменил его, подключив три следующих слушателя событий к классу пользовательского интерфейса-dropppable после загрузки страницы:

jQuery(window).load(function(){

    $(".ui-droppable").on("dragover", function() {
        event.preventDefault();
        event.stopPropagation();
        $(this).addClass('dragging');
    });

    $(".ui-droppable").on("dragleave", function() {
        event.preventDefault();
        event.stopPropagation();
        $(this).removeClass('dragging');
    });

    $(".ui-droppable").on("drop", function(event) {
        event.preventDefault();
        event.stopPropagation();
        console.log("Dropped!");
    });

});

Тогда вы сможете изменить указанную выше функцию on("drop"... для выполнения вызова ajax с помощью команды <p:remoteCommand>.

Надеюсь, это поможет.

...