mirror of
https://github.com/UpsilonNumworks/Upsilon.git
synced 2026-01-19 00:37:25 +01:00
163 lines
5.9 KiB
C++
163 lines
5.9 KiB
C++
#include "list_parameter_controller.h"
|
|
#include "list_controller.h"
|
|
#include "../app.h"
|
|
#include "../../shared/poincare_helpers.h"
|
|
|
|
using namespace Poincare;
|
|
using namespace Shared;
|
|
|
|
namespace Sequence {
|
|
|
|
ListParameterController::ListParameterController(::InputEventHandlerDelegate * inputEventHandlerDelegate, ListController * listController) :
|
|
Shared::ListParameterController(listController, I18n::Message::SequenceColor, I18n::Message::DeleteSequence, this),
|
|
m_typeCell(I18n::Message::SequenceType),
|
|
m_initialRankCell(&m_selectableTableView, inputEventHandlerDelegate, this, m_draftTextBuffer, I18n::Message::FirstTermIndex),
|
|
m_typeParameterController(this, listController, TableCell::Layout::Horizontal, Metric::CommonTopMargin, Metric::CommonRightMargin,
|
|
Metric::CommonBottomMargin, Metric::CommonLeftMargin)
|
|
{
|
|
static_cast<ExpressionView *>(m_typeCell.subAccessoryView())->setHorizontalMargin(Metric::ExpressionViewHorizontalMargin);
|
|
}
|
|
|
|
const char * ListParameterController::title() {
|
|
return I18n::translate(I18n::Message::SequenceOptions);
|
|
}
|
|
|
|
bool ListParameterController::handleEvent(Ion::Events::Event event) {
|
|
bool hasAdditionalRow = hasInitialRankRow();
|
|
#if FUNCTION_COLOR_CHOICE
|
|
if (event == Ion::Events::OK || event == Ion::Events::EXE || (event == Ion::Events::Right && selectedRow() == 1)) {
|
|
#else
|
|
if (event == Ion::Events::OK || event == Ion::Events::EXE || (event == Ion::Events::Right && selectedRow() == 0)) {
|
|
#endif
|
|
int selectedRowIndex = selectedRow();
|
|
#if FUNCTION_COLOR_CHOICE
|
|
if (selectedRowIndex == 0) {
|
|
return handleEnterOnRow(selectedRowIndex);
|
|
}
|
|
if (selectedRowIndex == 1) {
|
|
#else
|
|
if (selectedRowIndex == 0) {
|
|
#endif
|
|
StackViewController * stack = (StackViewController *)(parentResponder());
|
|
m_typeParameterController.setRecord(m_record);
|
|
stack->push(&m_typeParameterController);
|
|
return true;
|
|
}
|
|
#if FUNCTION_COLOR_CHOICE
|
|
if (selectedRowIndex == 2+hasAdditionalRow) {
|
|
|
|
#else
|
|
if (selectedRowIndex == 1+hasAdditionalRow) {
|
|
#endif
|
|
return handleEnterOnRow(selectedRowIndex-hasAdditionalRow-1);
|
|
}
|
|
#if FUNCTION_COLOR_CHOICE
|
|
if (selectedRowIndex == 3+hasAdditionalRow) {
|
|
#else
|
|
if (selectedRowIndex == 2+hasAdditionalRow) {
|
|
#endif
|
|
app()->localContext()->resetCache();
|
|
return handleEnterOnRow(selectedRowIndex-hasAdditionalRow-1);
|
|
}
|
|
}
|
|
return false;
|
|
}
|
|
|
|
bool ListParameterController::textFieldShouldFinishEditing(TextField * textField, Ion::Events::Event event) {
|
|
return event == Ion::Events::Down || event == Ion::Events::Up || TextFieldDelegate::textFieldShouldFinishEditing(textField, event);
|
|
}
|
|
|
|
bool ListParameterController::textFieldDidFinishEditing(TextField * textField, const char * text, Ion::Events::Event event) {
|
|
static float maxFirstIndex = std::pow(10.0f, Sequence::k_initialRankNumberOfDigits) - 1.0f;
|
|
/* -1 to take into account a double recursive sequence, which has
|
|
* SecondIndex = FirstIndex + 1 */
|
|
double floatBody;
|
|
if (textFieldDelegateApp()->hasUndefinedValue(text, floatBody)) {
|
|
return false;
|
|
}
|
|
int index = std::round(floatBody);
|
|
if (index < 0 || floatBody >= maxFirstIndex) {
|
|
app()->displayWarning(I18n::Message::ForbiddenValue);
|
|
return false;
|
|
}
|
|
sequence()->setInitialRank(index);
|
|
// Invalidate sequence context cache when changing sequence type
|
|
app()->localContext()->resetCache();
|
|
m_selectableTableView.reloadCellAtLocation(0, selectedRow());
|
|
m_selectableTableView.handleEvent(event);
|
|
return true;
|
|
}
|
|
|
|
void ListParameterController::tableViewDidChangeSelection(SelectableTableView * t, int previousSelectedCellX, int previousSelectedCellY, bool withinTemporarySelection) {
|
|
if (withinTemporarySelection || (previousSelectedCellX == t->selectedColumn() && previousSelectedCellY == t->selectedRow())) {
|
|
return;
|
|
}
|
|
if (!hasInitialRankRow()) {
|
|
return;
|
|
}
|
|
#if FUNCTION_COLOR_CHOICE
|
|
if (previousSelectedCellY == 2) {
|
|
#else
|
|
if (previousSelectedCellY == 1) {
|
|
#endif
|
|
MessageTableCellWithEditableText * myCell = (MessageTableCellWithEditableText *)t->cellAtLocation(previousSelectedCellX, previousSelectedCellY);
|
|
if (myCell) {
|
|
myCell->setEditing(false);
|
|
}
|
|
app()->setFirstResponder(&m_selectableTableView);
|
|
}
|
|
#if FUNCTION_COLOR_CHOICE
|
|
if (t->selectedRow() == 2) {
|
|
#else
|
|
if (t->selectedRow() == 1) {
|
|
#endif
|
|
MessageTableCellWithEditableText * myNewCell = (MessageTableCellWithEditableText *)t->selectedCell();
|
|
app()->setFirstResponder(myNewCell);
|
|
}
|
|
}
|
|
|
|
HighlightCell * ListParameterController::reusableCell(int index, int type) {
|
|
switch (type) {
|
|
/*case 0:
|
|
return Shared::ListParameterController::reusableCell(index);*/
|
|
case 0://1:
|
|
return &m_typeCell;
|
|
case 1:
|
|
if (hasInitialRankRow()) {
|
|
return &m_initialRankCell;
|
|
}
|
|
default:
|
|
return Shared::ListParameterController::reusableCell(index, type-1-hasInitialRankRow());
|
|
}
|
|
}
|
|
|
|
void ListParameterController::willDisplayCellForIndex(HighlightCell * cell, int index) {
|
|
cell->setHighlighted(index == selectedRow()); // See FIXME in SelectableTableView::reloadData()
|
|
Shared::ListParameterController::willDisplayCellForIndex(cell, index);
|
|
if (cell == &m_typeCell && !m_record.isNull()) {
|
|
m_typeCell.setLayout(sequence()->definitionName());
|
|
}
|
|
if (cell == &m_initialRankCell && !m_record.isNull()) {
|
|
MessageTableCellWithEditableText * myCell = (MessageTableCellWithEditableText *) cell;
|
|
if (myCell->isEditing()) {
|
|
return;
|
|
}
|
|
char buffer[Sequence::k_initialRankNumberOfDigits+1];
|
|
Poincare::Integer(sequence()->initialRank()).serialize(buffer, Sequence::k_initialRankNumberOfDigits+1);
|
|
myCell->setAccessoryText(buffer);
|
|
}
|
|
}
|
|
|
|
int ListParameterController::totalNumberOfCells() const {
|
|
if (hasInitialRankRow()) {
|
|
return k_totalNumberOfCell;
|
|
}
|
|
return k_totalNumberOfCell-1;
|
|
};
|
|
|
|
bool ListParameterController::hasInitialRankRow() const {
|
|
return !m_record.isNull() && const_cast<ListParameterController *>(this)->sequence()->type() != Sequence::Type::Explicit;
|
|
}
|
|
|
|
}
|