mirror of
https://github.com/RGBCube/serenity
synced 2025-07-27 00:27:45 +00:00
Spreadsheet: Add undo/redo implementation
The Spreadsheet application currently does not support undo/redo, and with this update, we are starting the process of adding this feature :-) Additionally, the save dialog has been updated to use GUI::MessageBox::ask_about_unsaved_changes() for system cohesity. Spreadsheet: Add basic undo functinoality The spreadsheet application now has basic support for undo. Testing of this feature is limited, and may not work as intended yet. Spreadsheet: Add callback when a cell's value is changed In addition to the callback being added, this commit also exposes the SheetModel class via a getter in SpreadSheetView. Spreadsheet: Remove debug statements and use cell change callback This commit uses the on_cell_data_change callback from within the SheetModel class. This allows for us to push/pop changes to the undo stack. With this, we have basic Undo/Redo functionality :-) Spreadsheet: Actually add window::set_modified Spreadsheet: Const-correctness :-) Spreadsheet: Reorder the edit menu actions
This commit is contained in:
parent
d00781de36
commit
e41dfa6599
7 changed files with 89 additions and 2 deletions
|
@ -191,4 +191,21 @@ void Cell::copy_from(const Cell& other)
|
|||
m_thrown_value = other.m_thrown_value;
|
||||
}
|
||||
|
||||
CellUndoCommand::CellUndoCommand(Cell& cell, String const& previous_data)
|
||||
: m_cell(cell)
|
||||
, m_current_data(cell.data())
|
||||
, m_previous_data(previous_data)
|
||||
{
|
||||
}
|
||||
|
||||
void CellUndoCommand::undo()
|
||||
{
|
||||
m_cell.set_data(m_previous_data);
|
||||
}
|
||||
|
||||
void CellUndoCommand::redo()
|
||||
{
|
||||
m_cell.set_data(m_current_data);
|
||||
}
|
||||
|
||||
}
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue