Files
Upsilon/apps/shared/store_parameter_controller.cpp
2020-12-16 11:40:54 +01:00

126 lines
4.3 KiB
C++

#include "store_parameter_controller.h"
#include "store_controller.h"
#include <poincare/helpers.h>
#include <assert.h>
namespace Shared {
StoreParameterController::StoreParameterController(Responder * parentResponder, DoublePairStore * store, StoreController * storeController) :
ViewController(parentResponder),
m_store(store),
m_series(0),
m_selectableTableView(this, this, this),
m_cells{I18n::Message::ClearColumn, I18n::Message::FillWithFormula},
m_storeController(storeController),
m_xColumnSelected(true)
{
}
void StoreParameterController::willDisplayCellForIndex(HighlightCell * cell, int index) {
MessageTableCellWithEditableText * myCell = static_cast<MessageTableCellWithEditableText *>(cell);
assert(index >= 0 && index < k_totalNumberOfCell);
if (index == 2) {
myCell->setMessage(sortMessage());
}
ListViewDataSource::willDisplayCellForIndex(cell, index);
}
const char * StoreParameterController::title() {
return I18n::translate(I18n::Message::ColumnOptions);
}
void StoreParameterController::viewWillAppear() {
m_selectableTableView.reloadData();
}
void StoreParameterController::didBecomeFirstResponder() {
selectCellAtLocation(0, 0);
Container::activeApp()->setFirstResponder(&m_selectableTableView);
}
bool StoreParameterController::handleEvent(Ion::Events::Event event) {
if (event != Ion::Events::OK && event != Ion::Events::EXE) {
return false;
}
switch (selectedRow()) {
case 0:
{
if (m_xColumnSelected) {
m_store->deleteAllPairsOfSeries(m_series);
} else {
m_store->resetColumn(m_series, !m_xColumnSelected);
}
break;
}
case 1:
{
m_storeController->displayFormulaInput();
break;
}
case 2:
{
Poincare::Helpers::Swap swapRows = [](int i, int j, void * context, int numberOfElements) {
double * contextI = (static_cast<double*>(context) + i);
double * contextJ = (static_cast<double*>(context) + j);
double * contextIOtherColumn = (static_cast<double*>(context) + DoublePairStore::k_maxNumberOfPairs + i);
double * contextJOtherColumn = (static_cast<double*>(context) + DoublePairStore::k_maxNumberOfPairs + j);
double temp1 = *contextI;
double temp2 = *contextIOtherColumn;
*contextI = *contextJ;
*contextIOtherColumn = *contextJOtherColumn;
*contextJ = temp1;
*contextJOtherColumn = temp2;
};
Poincare::Helpers::Compare compareX = [](int a, int b, void * context, int numberOfElements)->bool{
double * contextA = (static_cast<double*>(context) + a);
double * contextB = (static_cast<double*>(context) + b);
return *contextA > *contextB;
};
Poincare::Helpers::Compare compareY = [](int a, int b, void * context, int numberOfElements)->bool{
double * contextAOtherColumn = (static_cast<double*>(context) + DoublePairStore::k_maxNumberOfPairs + a);
double * contextBOtherColumn = (static_cast<double*>(context) + DoublePairStore::k_maxNumberOfPairs + b);
return *contextAOtherColumn > *contextBOtherColumn;
};
double * seriesContext = m_store->data() + m_series * DoublePairStore::k_numberOfColumnsPerSeries * DoublePairStore::k_maxNumberOfPairs;
if (m_xColumnSelected) {
Poincare::Helpers::Sort(swapRows, compareX, seriesContext, m_store->numberOfPairsOfSeries(m_series));
} else {
Poincare::Helpers::Sort(swapRows, compareY, seriesContext, m_store->numberOfPairsOfSeries(m_series));
}
break;
}
}
assert(selectedRow() >= 0 && selectedRow() <= 2);
StackViewController * stack = static_cast<StackViewController *>(parentResponder());
stack->pop();
return true;
}
KDCoordinate StoreParameterController::cumulatedHeightFromIndex(int j) {
assert (j >= 0 && j <= numberOfRows());
KDCoordinate result = 0;
for (int i = 0; i < j; i++) {
result+= rowHeight(i);
}
return result;
}
int StoreParameterController::indexFromCumulatedHeight(KDCoordinate offsetY) {
int result = 0;
int j = 0;
while (result < offsetY && j < numberOfRows()) {
result += rowHeight(j++);
}
return (result < offsetY || offsetY == 0) ? j : j - 1;
}
HighlightCell * StoreParameterController::reusableCell(int index, int type) {
assert(type == k_standardCellType);
assert(index >= 0);
assert(index < k_totalNumberOfCell);
return &m_cells[index];
}
}