mirror of
				https://github.com/subsurface/subsurface.git
				synced 2025-02-19 22:16:15 +00:00 
			
		
		
		
	Map: in dive-site-edit mode, select those maps we filter for
When dive sites are edited, we shouldn't highlight the sites of the current dive, but the currently edited site(s). Signed-off-by: Berthold Stoeger <bstoeger@mail.tuwien.ac.at>
This commit is contained in:
		
							parent
							
								
									d29f82c52d
								
							
						
					
					
						commit
						cd5489e08d
					
				
					 3 changed files with 11 additions and 2 deletions
				
			
		|  | @ -278,6 +278,11 @@ void MultiFilterSortModel::stopFilterDiveSites() | ||||||
| 	myInvalidate(); | 	myInvalidate(); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | const QVector<dive_site *> &MultiFilterSortModel::filteredDiveSites() const | ||||||
|  | { | ||||||
|  | 	return dive_sites; | ||||||
|  | } | ||||||
|  | 
 | ||||||
| bool MultiFilterSortModel::diveSiteMode() const | bool MultiFilterSortModel::diveSiteMode() const | ||||||
| { | { | ||||||
| 	return !dive_sites.isEmpty(); | 	return !dive_sites.isEmpty(); | ||||||
|  |  | ||||||
|  | @ -64,6 +64,7 @@ public: | ||||||
| 	int divesDisplayed; | 	int divesDisplayed; | ||||||
| 	bool lessThan(const QModelIndex &, const QModelIndex &) const override; | 	bool lessThan(const QModelIndex &, const QModelIndex &) const override; | ||||||
| 	bool diveSiteMode() const; // returns true if we're filtering on dive site
 | 	bool diveSiteMode() const; // returns true if we're filtering on dive site
 | ||||||
|  | 	const QVector<dive_site *> &filteredDiveSites() const; | ||||||
| public | public | ||||||
| slots: | slots: | ||||||
| 	void myInvalidate(); | 	void myInvalidate(); | ||||||
|  |  | ||||||
|  | @ -136,8 +136,11 @@ void MapLocationModel::reload() | ||||||
| #else | #else | ||||||
| 	// In dive site mode (that is when either editing a dive site or on
 | 	// In dive site mode (that is when either editing a dive site or on
 | ||||||
| 	// the dive site tab), we want to show all dive sites, not only those
 | 	// the dive site tab), we want to show all dive sites, not only those
 | ||||||
| 	// of the non-hidden dives.
 | 	// of the non-hidden dives. Moreover, the selected dive sites are those
 | ||||||
|  | 	// that we filter for.
 | ||||||
| 	bool diveSiteMode = MultiFilterSortModel::instance()->diveSiteMode(); | 	bool diveSiteMode = MultiFilterSortModel::instance()->diveSiteMode(); | ||||||
|  | 	if (diveSiteMode) | ||||||
|  | 		m_selectedDs = MultiFilterSortModel::instance()->filteredDiveSites(); | ||||||
| #endif | #endif | ||||||
| 	for_each_dive(idx, dive) { | 	for_each_dive(idx, dive) { | ||||||
| 		// Don't show dive sites of hidden dives, unless this is the currently
 | 		// Don't show dive sites of hidden dives, unless this is the currently
 | ||||||
|  | @ -147,7 +150,7 @@ void MapLocationModel::reload() | ||||||
| 		struct dive_site *ds = get_dive_site_for_dive(dive); | 		struct dive_site *ds = get_dive_site_for_dive(dive); | ||||||
| 		if (!dive_site_has_gps_location(ds)) | 		if (!dive_site_has_gps_location(ds)) | ||||||
| 			continue; | 			continue; | ||||||
| 		if (dive->selected && !m_selectedDs.contains(ds)) | 		if (!diveSiteMode && dive->selected && !m_selectedDs.contains(ds)) | ||||||
| 			m_selectedDs.append(ds); | 			m_selectedDs.append(ds); | ||||||
| 		if (locations.contains(ds)) | 		if (locations.contains(ds)) | ||||||
| 			continue; | 			continue; | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue