mirror of
https://github.com/UpsilonNumworks/Upsilon.git
synced 2026-01-18 16:27:34 +01:00
126 lines
4.3 KiB
C++
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];
|
|
}
|
|
|
|
}
|