Files
l7/L7/LGridComboEditor.cpp
SET aaacf88071 Added classes to manage simple tabular data of known structure using a
popup containing a wxGrid object.

BasePicker : Abstract class adding a popup to wxPickerBase  styled with
a wxTextCtrl.
BaseGridPicker : Abstract class adding a wxGrid in the popup.

JsonGridPickerCtrl : UI control storing the tabular data in a JSON
array.
LBoundJsonGridPicker : connect JsonGridPicker to database.
LGridJsonCellEditor : use LBoundJsonGridPicker in other wxGrid objects.
LGridJsonCellRenderer : render cell JSON data.

XmlGridPickerCtrl : UI control storing the tabular data in as XML
document.
LBoundXmlGridPicker : connect XmlGridPicker to database.
LGridXmlCellEditor : grid editor for LBoundXmlGridPicker.
LGridXmlCellRenderer : grid renderer for LBoundXmlGridPicker.

JsonHelper and XmlHelper : for applications to quickly get intent value
from database data..

The structure of managed tabular data :

Column 1 : Intent - this is what we want to store/edit. This can be
telephone numbers, email addresses, instant messaging addresses...
any single line piece of information that can exist many times for one
entity (person, company...).
Column 2 : Type - A short description of the intent : 'Home, Work,
Mobile, Fax, Other...'. It is displayed in a non editable wxComboBox.
Column 3 : Preferred - One line of data can be selected as the preferred
one. It is not mandatory, but it must be a single choice.
Column 4 : Notes - single line notes.

Adjust sql scripts and L7.dox.
Applied ANSI formatting style to all files.

Other changes :

Work around a nasty misbehavior.
Grid columns edited by a translated combobox expect full string
data as cell values. LResultSet::BEData() will report these mapped strings,
instead of database real data. LBoundComboBox::IsDirty() will always be
true even if the editor is unchanged once created.
Simplest workaround : disconnect m_BoundComboBox if unchanged.

LGridTextEditor::ProvideFormEditor() : set the form editor's value
explicitely.; wxTextCtrl does not interpret data it receives

LBoundControl::SetNull must be void.

LBoundGrid : Unbind:: instructions should limit to the widget's id, like Bind::

LConnection::GetReturnedKeys should return NULL.
LConnection::SetData should return void.

Notes : wxJSON must be configured with the same prefix as wxWidgets,
here /usr/local/{wxWidgets,wxWidgets-Release}.
2019-12-23 08:12:01 +01:00

121 lines
3.5 KiB
C++

/*
* File: LGridComboEditor.cpp
* Author: SET - nmset@netcourrier.com
* License : LGPL version 2.1
* Copyright SET, M. D. - © 2014
*
* Created on 12 juin 2014, 18:34
*/
#include "LGridComboEditor.h"
#include "LBoundGrid.h"
LGridComboEditor::LGridComboEditor(const wxString& newColName)
{
m_colName = newColName;
m_type = LGridColEditor::COMBO;
m_formEditor = NULL;
m_BoundControl = NULL;
m_BoundComboBox = NULL;
}
LGridComboEditor::~LGridComboEditor()
{
wxDELETE(m_control);
}
void LGridComboEditor::Create(wxWindow* parent, wxWindowID id, wxEvtHandler* evtHandler)
{
m_control = new LBoundComboBox(parent, id);
m_BoundComboBox = static_cast<LBoundComboBox*> (m_control);
m_BoundComboBox->SetColumnName(m_colName);
m_BoundControl = m_BoundComboBox;
m_control->Show(false);
}
void LGridComboEditor::BeginEdit(int row, int col, wxGrid* grid)
{
if (m_control == NULL)
{
Create(grid->GetGridWindow(), wxID_ANY, NULL);
}
m_BoundComboBox->SetResultSet(((LBoundGrid *) grid)->GetResultSet());
const wxString cellVal = grid->GetTable()->GetValue(row, col);
if (cellVal.IsEmpty())
{
m_BoundComboBox->SetNull();
}
else
{
m_BoundComboBox->SetStringSelection(cellVal);
}
m_BoundComboBox->Show(true);
}
wxGridCellEditor* LGridComboEditor::Clone() const
{
return new LGridComboEditor(m_colName);
}
bool LGridComboEditor::EndEdit(int row, int col, const wxGrid* grid, const wxString& oldval, wxString* newval)
{
/*
* Work around a nasty misbehavior.
* Grid columns edited by a translated combobox expect full string
* data as cell values. LResultSet::BEData() will report these mapped strings,
* instead of database real data. LBoundComboBox::IsDirty() will always be
* true even if m_BoundComboBox is unchanged once created.
* Simplest workaround : disconnect m_BoundComboBox if unchanged.
*/
if (m_BoundComboBox->GetStringSelection() == oldval && m_BoundComboBox->IsTranslated())
{
LResultSet * rs = ((LBoundGrid *) grid)->GetResultSet();
rs->UnRegisterControl(m_BoundComboBox);
}
return true;
}
void LGridComboEditor::ApplyEdit(int row, int col, wxGrid* grid)
{
grid->GetTable()->SetValue(row, col, m_BoundComboBox->GetStringSelection());
}
void LGridComboEditor::Reset()
{
wxDELETE(m_control);
m_BoundControl = NULL;
m_BoundComboBox = NULL;
}
wxString LGridComboEditor::GetValue() const
{
return m_control == NULL ? wxString(wxEmptyString) : m_BoundControl->GetData().As<wxString>();
}
wxControl* LGridComboEditor::ProvideFormEditor(wxWindow* parent)
{
if (!m_formEditor)
{
m_formEditor = new wxComboBox(parent, wxID_ANY, wxEmptyString, wxDefaultPosition, wxDefaultSize, wxArrayString(), m_BoundComboBox->GetWindowStyleFlag());
for (unsigned int i = 0; i < m_BoundComboBox->GetCount(); i++)
{
m_formEditor->Append(m_BoundComboBox->GetString(i));
}
m_formEditor->Select(m_BoundComboBox->GetSelection());
m_formEditor->SetName(m_BoundComboBox->GetName());
if (m_BoundComboBox->GetValidator()) m_formEditor->SetValidator(*(m_BoundComboBox->GetValidator()));
}
return m_formEditor;
}
void LGridComboEditor::SyncBack(const int row, const int col, wxGrid* grid)
{
if (!m_formEditor) return;
m_BoundComboBox->Select(m_formEditor->GetSelection());
ApplyEdit(row, col, grid);
grid->ForceRefresh();
grid->GetGridWindow()->SetFocus();
delete m_formEditor;
m_formEditor = NULL;
}