mirror of
				https://github.com/subsurface/subsurface.git
				synced 2025-02-19 22:16:15 +00:00 
			
		
		
		
	Desktop: don't connect to remove() slot of model from TableModel
When connecting a model to the TableModel class, it would connect clicking on an item to the remove() slot of the model. This breaks the program flow implied by the undo code: Ui --> Undo-Command --> Model --> UI Moreover, the naming of the remove() slot is illogical, because clicks can also have different effects, as for example in the cylinder-table. Therefore, move the connect() call from TableModel to the callers. In the case of TabDiveSite, move the remove() function from the model to the TabWidget, where it makes more sense. Signed-off-by: Berthold Stoeger <bstoeger@mail.tuwien.ac.at>
This commit is contained in:
		
							parent
							
								
									147a36647c
								
							
						
					
					
						commit
						b3253304a5
					
				
					 9 changed files with 34 additions and 35 deletions
				
			
		|  | @ -7,9 +7,7 @@ | |||
| #include "core/metrics.h" | ||||
| #ifndef SUBSURFACE_MOBILE | ||||
| #include "cleanertablemodel.h" // for trashIcon() and editIcon()
 | ||||
| #include "desktop-widgets/mainwindow.h" // to place message box
 | ||||
| #include "commands/command.h" | ||||
| #include <QMessageBox> | ||||
| #endif | ||||
| #include <QLineEdit> | ||||
| #include <QIcon> | ||||
|  | @ -262,27 +260,6 @@ bool DiveSiteSortedModel::setData(const QModelIndex &index, const QVariant &valu | |||
| 	} | ||||
| } | ||||
| 
 | ||||
| // TODO: Remove or edit. It doesn't make sense to call the model here, which calls the undo command,
 | ||||
| // which in turn calls the model.
 | ||||
| void DiveSiteSortedModel::remove(const QModelIndex &index) | ||||
| { | ||||
| 	struct dive_site *ds = getDiveSite(index); | ||||
| 	if (!ds) | ||||
| 		return; | ||||
| 	switch (index.column()) { | ||||
| 	case LocationInformationModel::EDIT: | ||||
| 		MainWindow::instance()->editDiveSite(ds); | ||||
| 		break; | ||||
| 	case LocationInformationModel::REMOVE: | ||||
| 		if (ds->dives.nr > 0 && | ||||
| 		    QMessageBox::warning(MainWindow::instance(), tr("Delete dive site?"), | ||||
| 					 tr("This dive site has %n dive(s). Do you really want to delete it?\n", "", ds->dives.nr), | ||||
| 					 QMessageBox::Yes|QMessageBox::No) == QMessageBox::No) | ||||
| 				return; | ||||
| 		Command::deleteDiveSites(QVector<dive_site *>{ds}); | ||||
| 		break; | ||||
| 	} | ||||
| } | ||||
| #endif // SUBSURFACE_MOBILE
 | ||||
| 
 | ||||
| void DiveSiteSortedModel::setFilter(const QString &text) | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue