[apps/sequence] Reorder list parameter controller

Change-Id: I7054c3c5f7f0608b25d22bf817f7b01514c9abf9
This commit is contained in:
Émilie Feral
2017-02-17 17:02:11 +01:00
parent 42149265d4
commit 9b2b344f05
3 changed files with 62 additions and 44 deletions

View File

@@ -23,21 +23,30 @@ void ListParameterController::setFunction(Shared::Function * function) {
}
bool ListParameterController::handleEvent(Ion::Events::Event event) {
if (event == Ion::Events::OK && m_selectableTableView.selectedRow() == 3) {
StackViewController * stack = (StackViewController *)(parentResponder());
m_typeParameterController.setSequence(m_sequence);
stack->push(&m_typeParameterController);
return true;
}
if (event == Ion::Events::OK && m_selectableTableView.selectedRow() == 2) {
if (m_functionStore->numberOfFunctions() > 0) {
m_functionStore->removeFunction(m_function);
StackViewController * stack = (StackViewController *)(parentResponder());
stack->pop();
return true;
if (event == Ion::Events::OK) {
int selectedRowIndex = m_selectableTableView.selectedRow();
switch (selectedRowIndex) {
case 0:
return handleEnterOnRow(selectedRowIndex);
case 1:
{
StackViewController * stack = (StackViewController *)(parentResponder());
m_typeParameterController.setSequence(m_sequence);
stack->push(&m_typeParameterController);
return true;
}
case 3:
if (m_functionStore->numberOfFunctions() > 0) {
m_functionStore->removeFunction(m_function);
StackViewController * stack = (StackViewController *)(parentResponder());
stack->pop();
return true;
}
default:
return handleEnterOnRow(selectedRowIndex-1);
}
}
return Shared::ListParameterController::handleEvent(event);
return false;
}
int ListParameterController::numberOfRows() {
@@ -45,10 +54,14 @@ int ListParameterController::numberOfRows() {
};
HighlightCell * ListParameterController::reusableCell(int index) {
if (index == 3) {
switch (index) {
case 0:
return Shared::ListParameterController::reusableCell(index);
case 1:
return &m_typeCell;
default:
return Shared::ListParameterController::reusableCell(index-1);
}
return Shared::ListParameterController::reusableCell(index);
}
int ListParameterController::reusableCellCount() {

View File

@@ -46,35 +46,7 @@ void ListParameterController::setFunction(Function * function) {
bool ListParameterController::handleEvent(Ion::Events::Event event) {
if (event == Ion::Events::OK) {
switch (m_selectableTableView.selectedRow()) {
case 0:
return true;
case 1:
m_function->setActive(!m_function->isActive());
m_selectableTableView.reloadData();
return true;
case 2:
{
if (m_functionStore->numberOfFunctions() > 1) {
m_functionStore->removeFunction(m_function);
StackViewController * stack = (StackViewController *)(parentResponder());
stack->pop();
return true;
} else {
if (m_functionStore->numberOfDefinedFunctions() == 1) {
Function * f = m_functionStore->definedFunctionAtIndex(0);
f->setContent("");
StackViewController * stack = (StackViewController *)(parentResponder());
stack->pop();
return true;
}
app()->displayWarning("Pas de fonction a supprimer");
return false;
}
}
default:
return false;
}
return handleEnterOnRow(m_selectableTableView.selectedRow());
}
return false;
}
@@ -98,4 +70,36 @@ KDCoordinate ListParameterController::cellHeight() {
return Metric::ParameterCellHeight;
}
bool ListParameterController::handleEnterOnRow(int rowIndex) {
switch (rowIndex) {
case 0:
return true;
case 1:
m_function->setActive(!m_function->isActive());
m_selectableTableView.reloadData();
return true;
case 2:
{
if (m_functionStore->numberOfFunctions() > 1) {
m_functionStore->removeFunction(m_function);
StackViewController * stack = (StackViewController *)(parentResponder());
stack->pop();
return true;
} else {
if (m_functionStore->numberOfDefinedFunctions() == 1) {
Function * f = m_functionStore->definedFunctionAtIndex(0);
f->setContent("");
StackViewController * stack = (StackViewController *)(parentResponder());
stack->pop();
return true;
}
app()->displayWarning("Pas de fonction a supprimer");
return false;
}
}
default:
return false;
}
}
}

View File

@@ -22,6 +22,7 @@ public:
int reusableCellCount() override;
void willDisplayCellForIndex(HighlightCell * cell, int index) override;
protected:
bool handleEnterOnRow(int rowIndex);
SelectableTableView m_selectableTableView;
FunctionStore * m_functionStore;
Function * m_function;