mirror of
				https://github.com/SoftFever/OrcaSlicer.git
				synced 2025-10-25 17:51:10 -06:00 
			
		
		
		
	DiffPresetDialog, non modal to compare two presets.
Added menu item "Window->Compare presets" to compare more than one type
of presets.
Code refactoring for PresetComboBox: Use suffix "modified" just for
PlaterPresetComboBox and TabPresetComboBox
Code refactoring. wxDataViewCtrl and related functions extracted from
DiffPresetDialog and UnsavedChangesDialog to the separate class
DiffViewCtrl
Code refactoring, Tab.cpp: Build all unregular pages on a first build of
the Printer Settings
Squashed commit of the following:
commit 91f45a8a2d97d252337c7306dd02db607fd79c00
Author: Vojtech Bubnik <bubnikv@gmail.com>
Date:   Thu Feb 4 09:34:29 2021 +0100
    Fixed after merge
commit 09aa502498b08c059ecdf334f5db1567739b4520
Merge: 6df8e83e1 0baa92fab
Author: Vojtech Bubnik <bubnikv@gmail.com>
Date:   Thu Feb 4 09:31:43 2021 +0100
    Merge remote-tracking branch 'remotes/origin/master' into ys_diff_dlg
commit 6df8e83e1af3ba096ac39d25985b6deb2e0a245b
Author: Vojtech Bubnik <bubnikv@gmail.com>
Date:   Thu Feb 4 09:29:53 2021 +0100
    Tiny beautification.
commit e781ceaaf7c39bc073476409cc02918d9f182930
Author: Vojtech Bubnik <bubnikv@gmail.com>
Date:   Wed Feb 3 18:05:19 2021 +0100
    Reworked copying of PresetBundles:
    1) Simplified by using the default copy constructors and copy operators.
    2) Made safer by not allowing PresetCollection and PhysicalPrinterPresetCollection
       to be copied or instantiated outside of PresetBundle.
    3) Fixed Preset::vendor pointers after copying PresetBundle.
commit a8f0b7aa5156465cdb3e3dbb86feb66a64bcebc0
Author: YuSanka <yusanka@gmail.com>
Date:   Mon Jan 25 16:13:53 2021 +0100
    DiffPresetsDialog: Show compatibility to print/printer presets selected in DiffPresetDialog
commit 597451f930a4330376966d8cf3350056d4f85a73
Merge: cce5b5710 59017a7da
Author: YuSanka <yusanka@gmail.com>
Date:   Thu Jan 21 12:14:48 2021 +0100
    Merge remote-tracking branch 'origin/master' into ys_diff_dlg
commit cce5b5710d1225c7eaa52d0abb4b3f66fbd3b6a1
Author: YuSanka <yusanka@gmail.com>
Date:   Thu Jan 21 12:11:40 2021 +0100
    DiffPresetDialog: Fixed crash on ASAN build
commit ad8d728d89d7a75c2ac136ea8cdbb730ab774cd9
Author: YuSanka <yusanka@gmail.com>
Date:   Wed Jan 20 16:38:28 2021 +0100
    FullCompareDialog improvements
commit 316bafbeec9bb63f731b653d296062d9e22dd02f
Author: YuSanka <yusanka@gmail.com>
Date:   Wed Jan 20 09:25:46 2021 +0100
    DiffPresetDialog improvements:
    * Update presets lists after save changes in edited preset or change printer_technology
    * Tab.cpp: Build all unregular pages on a first build of the Printer Settings
commit 01171c8ef50389d0801b0ccc5746ab0c3b731b11
Author: YuSanka <yusanka@gmail.com>
Date:   Tue Jan 19 17:26:28 2021 +0100
    DiffPresetDialog : improvements
    * This dialog is non-modal now
    * "Compare presets" menu item is moved from "View" to the "Window" menu group
    * Added info tooltips for the bitmap buttons between presets
    * Added "Show all presets" checkbox
    * Show full difference between printer presets with different count of extruders
commit 3d38b62f3c9de8aab352ed3bcff297d5c0239b2e
Merge: e50fe6de9 9a2310ae9
Author: YuSanka <yusanka@gmail.com>
Date:   Mon Jan 18 10:00:18 2021 +0100
    Merge remote-tracking branch 'origin/master' into ys_diff_dlg
commit e50fe6de984decadfef3d4b952f0eec8ab9e6670
Author: YuSanka <yusanka@gmail.com>
Date:   Sat Jan 16 02:27:24 2021 +0100
    DiffPresetDialog improvements
    Added menu item "View->Compare presets" to compare more than one type of presets
commit bf08b7c8c969ad0ca631b9eeac1bc231f474e72b
Author: YuSanka <yusanka@gmail.com>
Date:   Sat Jan 16 00:28:39 2021 +0100
    Code refactoring. wxDataViewCtrl and related functions extracted from DiffPresetDialog and UnsavedChangesDialog to the separate class DiffViewCtrl
commit 7aeb63032b0bc2bd06e60990c060008660a5c44f
Author: YuSanka <yusanka@gmail.com>
Date:   Fri Jan 15 21:35:43 2021 +0100
    DiffPresetDialog: first implementation
commit 2f23d5af9d6b5dd670dfb7d06eedbe0e6d2960c6
Author: YuSanka <yusanka@gmail.com>
Date:   Thu Jan 14 16:28:43 2021 +0100
    Code refactoring for PresetComboBox.
    Use suffix "modified" just for PlaterPresetComboBox and TabPresetComboBox
			
			
This commit is contained in:
		
							parent
							
								
									0baa92fab8
								
							
						
					
					
						commit
						4cdcfe6005
					
				
					 17 changed files with 1150 additions and 315 deletions
				
			
		|  | @ -326,6 +326,53 @@ const Option& OptionsSearcher::get_option(const std::string& opt_key) const | |||
|     return options[it - options.begin()]; | ||||
| } | ||||
| 
 | ||||
| static Option create_option(const std::string& opt_key, const wxString& label, Preset::Type type, const GroupAndCategory& gc) | ||||
| { | ||||
|     wxString suffix; | ||||
|     wxString suffix_local; | ||||
|     if (gc.category == "Machine limits") { | ||||
|         suffix = opt_key.back() == '1' ? L("Stealth") : L("Normal"); | ||||
|         suffix_local = " " + _(suffix); | ||||
|         suffix = " " + suffix; | ||||
|     } | ||||
| 
 | ||||
|     wxString category = gc.category; | ||||
|     if (type == Preset::TYPE_PRINTER && category.Contains("Extruder ")) { | ||||
|         std::string opt_idx = opt_key.substr(opt_key.find("#") + 1); | ||||
|         category = wxString::Format("%s %d", "Extruder", atoi(opt_idx.c_str()) + 1); | ||||
|     } | ||||
| 
 | ||||
|     return Option{ boost::nowide::widen(opt_key), type, | ||||
|                 (label + suffix).ToStdWstring(), (_(label) + suffix_local).ToStdWstring(), | ||||
|                 gc.group.ToStdWstring(), _(gc.group).ToStdWstring(), | ||||
|                 gc.category.ToStdWstring(), GUI::Tab::translate_category(category, type).ToStdWstring() }; | ||||
| } | ||||
| 
 | ||||
| Option OptionsSearcher::get_option(const std::string& opt_key, const wxString& label, Preset::Type type) const | ||||
| { | ||||
|     auto it = std::lower_bound(options.begin(), options.end(), Option({ boost::nowide::widen(opt_key) })); | ||||
|     if(it->opt_key == boost::nowide::widen(opt_key)) | ||||
|         return options[it - options.begin()]; | ||||
|     if (groups_and_categories.find(opt_key) == groups_and_categories.end()) { | ||||
|         size_t pos = opt_key.find('#'); | ||||
|         if (pos == std::string::npos) | ||||
|             return options[it - options.begin()]; | ||||
| 
 | ||||
|         std::string zero_opt_key = opt_key.substr(0, pos + 1) + "0"; | ||||
| 
 | ||||
|         if(groups_and_categories.find(zero_opt_key) == groups_and_categories.end()) | ||||
|             return options[it - options.begin()]; | ||||
| 
 | ||||
|         return create_option(opt_key, label, type, groups_and_categories.at(zero_opt_key)); | ||||
|     } | ||||
| 
 | ||||
|     const GroupAndCategory& gc = groups_and_categories.at(opt_key); | ||||
|     if (gc.group.IsEmpty() || gc.category.IsEmpty()) | ||||
|         return options[it - options.begin()]; | ||||
| 
 | ||||
|     return create_option(opt_key, label, type, gc); | ||||
| } | ||||
| 
 | ||||
| void OptionsSearcher::add_key(const std::string& opt_key, const wxString& group, const wxString& category) | ||||
| { | ||||
|     groups_and_categories[opt_key] = GroupAndCategory{group, category}; | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Vojtech Bubnik
						Vojtech Bubnik