Arrastar e soltar com transferidor por repetidor
Existem algumas perguntas semelhantes a esta e eu li todas elas. No entanto, ainda não consigo fazer com que a sequência de ação funcione conforme o esperado no transferidor.
Tenho uma lista de itens que podem ser arrastados e preciso testar os resultados depois que eles são reorganizados. No entanto, não consigo arrastar / soltar para funcionar corretamente. Aqui está uma simulação simplificada do que tenho até agora.
funções auxiliares:
var getRow = function (num){
return element(by.repeater('p in pList').row(num - 1));
};
var getField = function (rowNum){
return getRow(rowNum).findElement(by.css('td.ng-binding'));
};
var moveIndexToIndex = function (startIndex, endIndex) {
return getField(endIndex).then(function (endPoint) {
getField(startIndex).then(function (startPoint) {
// browser.actions().dragAndDrop(startPoint, endPoint).perform(); // doesn't work either
browser.actions().
mouseMove(startPoint, {x: 0, y: 0}).
mouseDown().
mouseMove(endPoint).
mouseUp().
perform();
});
});
});
Eu estou chamando a função auxiliar de movimentação com literais assim:
moveIndexToIndex(2, 5);
E o html se parece com isso:
<tbody>
<!-- ngRepeat: p in pList -->
<tr ng-repeat="p in pList" eg-draggable="p" eg-droppable="eg-droppable" class="ng-scope" draggable="true" style="cursor: move;">
<td class="ng-binding">DummyValue 1</td>
</tr><!-- end ngRepeat: p in pList --><tr ng-repeat="p in pList" eg-draggable="p" eg-droppable="eg-droppable" class="ng-scope" draggable="true" style="cursor: move;">
<td class="ng-binding">DummyValue 2</td>
</tr><!-- end ngRepeat: p in pList --><tr ng-repeat="p in pList" eg-draggable="p" eg-droppable="eg-droppable" class="ng-scope" draggable="true" style="cursor: move;">
<td class="ng-binding">DummyValue 3</td>
</tr><!-- end ngRepeat: p in pList --><tr ng-repeat="p in pList" eg-draggable="p" eg-droppable="eg-droppable" class="ng-scope" draggable="true" style="cursor: move;">
<td class="ng-binding">DummyValue 4</td>
</tr><!-- end ngRepeat: p in pList --><tr ng-repeat="p in pList" eg-draggable="p" eg-droppable="eg-droppable" class="ng-scope" draggable="true" style="cursor: move;">
<td class="ng-binding">DummyValue 5</td>
</tr><!-- end ngRepeat: p in pList --><tr ng-repeat="p in pList" eg-draggable="p" eg-droppable="eg-droppable" class="ng-scope" draggable="true" style="cursor: move;">
<td class="ng-binding">DummyValue 6</td>
</tr><!-- end ngRepeat: p in pList --><tr ng-repeat="p in pList" eg-draggable="p" eg-droppable="eg-droppable" class="ng-scope" draggable="true" style="cursor: move;">
<td class="ng-binding">DummyValue 7</td>
</tr><!-- end ngRepeat: p in pList --><tr ng-repeat="p in pList" eg-draggable="p" eg-droppable="eg-droppable" class="ng-scope" draggable="true" style="cursor: move;">
<td class="ng-binding">DummyValue 8</td>
</tr><!-- end ngRepeat: p in pList --><tr ng-repeat="p in pList" eg-draggable="p" eg-droppable="eg-droppable" class="ng-scope" draggable="true" style="cursor: move;">
<td class="ng-binding">DummyValue 9</td>
</tr><!-- end ngRepeat: p in pList --><tr ng-repeat="p in pList" eg-draggable="p" eg-droppable="eg-droppable" class="ng-scope" draggable="true" style="cursor: move;">
<td class="ng-binding">DummyValue 10</td>
</tr>
<!-- end ngRepeat: p in pList -->
</tbody>
Como posso arrastar e soltar para o trabalho? Estou fazendo algo errado?