mirror of
https://github.com/UpsilonNumworks/Upsilon.git
synced 2026-01-19 00:37:25 +01:00
125 lines
5.3 KiB
C++
125 lines
5.3 KiB
C++
#include "store_controller.h"
|
|
#include "apps_container.h"
|
|
#include "constant.h"
|
|
#include <assert.h>
|
|
|
|
StoreController::StoreController(Responder * parentResponder, FloatPairStore * store, HeaderViewController * header) :
|
|
EditableCellTableViewController(parentResponder, Metric::TopMargin, Metric::RightMargin, Metric::BottomMargin, Metric::LeftMargin),
|
|
HeaderViewDelegate(header),
|
|
m_editableCells{EvenOddEditableTextCell(&m_selectableTableView, this, m_draftTextBuffer, KDText::FontSize::Large), EvenOddEditableTextCell(&m_selectableTableView, this, m_draftTextBuffer, KDText::FontSize::Large), EvenOddEditableTextCell(&m_selectableTableView, this, m_draftTextBuffer, KDText::FontSize::Large), EvenOddEditableTextCell(&m_selectableTableView, this, m_draftTextBuffer, KDText::FontSize::Large), EvenOddEditableTextCell(&m_selectableTableView, this, m_draftTextBuffer, KDText::FontSize::Large),
|
|
EvenOddEditableTextCell(&m_selectableTableView, this, m_draftTextBuffer, KDText::FontSize::Large), EvenOddEditableTextCell(&m_selectableTableView, this, m_draftTextBuffer, KDText::FontSize::Large), EvenOddEditableTextCell(&m_selectableTableView, this, m_draftTextBuffer, KDText::FontSize::Large), EvenOddEditableTextCell(&m_selectableTableView, this, m_draftTextBuffer, KDText::FontSize::Large), EvenOddEditableTextCell(&m_selectableTableView, this, m_draftTextBuffer, KDText::FontSize::Large),
|
|
EvenOddEditableTextCell(&m_selectableTableView, this, m_draftTextBuffer, KDText::FontSize::Large), EvenOddEditableTextCell(&m_selectableTableView, this, m_draftTextBuffer, KDText::FontSize::Large), EvenOddEditableTextCell(&m_selectableTableView, this, m_draftTextBuffer, KDText::FontSize::Large), EvenOddEditableTextCell(&m_selectableTableView, this, m_draftTextBuffer, KDText::FontSize::Large), EvenOddEditableTextCell(&m_selectableTableView, this, m_draftTextBuffer, KDText::FontSize::Large),
|
|
EvenOddEditableTextCell(&m_selectableTableView, this, m_draftTextBuffer, KDText::FontSize::Large), EvenOddEditableTextCell(&m_selectableTableView, this, m_draftTextBuffer, KDText::FontSize::Large), EvenOddEditableTextCell(&m_selectableTableView, this, m_draftTextBuffer, KDText::FontSize::Large), EvenOddEditableTextCell(&m_selectableTableView, this, m_draftTextBuffer, KDText::FontSize::Large), EvenOddEditableTextCell(&m_selectableTableView, this, m_draftTextBuffer, KDText::FontSize::Large)},
|
|
m_titleCells{EvenOddPointerTextCell(KDText::FontSize::Large), EvenOddPointerTextCell(KDText::FontSize::Large)},
|
|
m_store(store),
|
|
m_storeParameterController(this, store)
|
|
{
|
|
}
|
|
|
|
const char * StoreController::title() const {
|
|
return "Donnees";
|
|
}
|
|
|
|
int StoreController::numberOfColumns() {
|
|
return 2;
|
|
};
|
|
|
|
KDCoordinate StoreController::columnWidth(int i) {
|
|
return k_cellWidth;
|
|
}
|
|
|
|
KDCoordinate StoreController::cumulatedWidthFromIndex(int i) {
|
|
return i*k_cellWidth;
|
|
}
|
|
|
|
int StoreController::indexFromCumulatedWidth(KDCoordinate offsetX) {
|
|
return (offsetX-1) / k_cellWidth;
|
|
}
|
|
|
|
TableViewCell * StoreController::reusableCell(int index, int type) {
|
|
assert(index >= 0);
|
|
switch (type) {
|
|
case 0:
|
|
assert(index < k_numberOfTitleCells);
|
|
return &m_titleCells[index];
|
|
case 1:
|
|
assert(index < k_maxNumberOfEditableCells);
|
|
return &m_editableCells[index];
|
|
default:
|
|
assert(false);
|
|
return nullptr;
|
|
}
|
|
}
|
|
|
|
int StoreController::reusableCellCount(int type) {
|
|
if (type == 0) {
|
|
return k_numberOfTitleCells;
|
|
}
|
|
return k_maxNumberOfEditableCells;
|
|
}
|
|
|
|
void StoreController::willDisplayCellAtLocation(TableViewCell * cell, int i, int j) {
|
|
EditableCellTableViewController::willDisplayCellAtLocation(cell, i, j);
|
|
if (cellAtLocationIsEditable(i, j)) {
|
|
return;
|
|
}
|
|
EvenOddPointerTextCell * mytitleCell = (EvenOddPointerTextCell *)cell;
|
|
if (i == 0) {
|
|
mytitleCell->setText("Xi");
|
|
return;
|
|
}
|
|
mytitleCell->setText("Yi");
|
|
}
|
|
|
|
int StoreController::typeAtLocation(int i, int j) {
|
|
return j!=0;
|
|
}
|
|
|
|
bool StoreController::handleEvent(Ion::Events::Event event) {
|
|
if (event == Ion::Events::Up) {
|
|
m_selectableTableView.deselectTable();
|
|
assert(m_selectableTableView.selectedRow() == -1);
|
|
app()->setFirstResponder(tabController());
|
|
return true;
|
|
}
|
|
if (event == Ion::Events::OK && m_selectableTableView.selectedRow() == 0) {
|
|
m_storeParameterController.selectXColumn(m_selectableTableView.selectedColumn() == 0);
|
|
StackViewController * stack = ((StackViewController *)parentResponder()->parentResponder());
|
|
stack->push(&m_storeParameterController);
|
|
return true;
|
|
}
|
|
if (event == Ion::Events::Clear) {
|
|
m_store->deletePairAtIndex(m_selectableTableView.selectedRow()-1);
|
|
m_selectableTableView.reloadData();
|
|
return true;
|
|
}
|
|
return false;
|
|
}
|
|
|
|
Responder * StoreController::tabController() const {
|
|
return (parentResponder()->parentResponder()->parentResponder());
|
|
}
|
|
|
|
bool StoreController::cellAtLocationIsEditable(int columnIndex, int rowIndex) {
|
|
if (rowIndex > 0) {
|
|
return true;
|
|
}
|
|
return false;
|
|
}
|
|
|
|
void StoreController::setDataAtLocation(float floatBody, int columnIndex, int rowIndex) {
|
|
m_store->set(floatBody, columnIndex, rowIndex-1);
|
|
}
|
|
|
|
float StoreController::dataAtLocation(int columnIndex, int rowIndex) {
|
|
return m_store->get(columnIndex, rowIndex-1);
|
|
}
|
|
|
|
int StoreController::numberOfElements() {
|
|
return m_store->numberOfPairs();
|
|
}
|
|
|
|
int StoreController::maxNumberOfElements() const {
|
|
return FloatPairStore::k_maxNumberOfPairs;
|
|
}
|