Get SortProxyFilterModel stuff working?
Came back from a break and forgot what I was fixing
This commit is contained in:
		
							
								
								
									
										3
									
								
								.gitmodules
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										3
									
								
								.gitmodules
									
									
									
									
										vendored
									
									
								
							| @@ -10,3 +10,6 @@ | ||||
| [submodule "submodules/gel"] | ||||
| 	path = submodules/gel | ||||
| 	url = https://github.com/Cutehacks/gel | ||||
| [submodule "submodules/SortFilterProxyModel"] | ||||
| 	path = submodules/SortFilterProxyModel | ||||
| 	url = https://github.com/oKcerG/SortFilterProxyModel | ||||
|   | ||||
| @@ -43,8 +43,7 @@ executables.files       = $$TARGET | ||||
|  | ||||
| # Libraries includes | ||||
|  | ||||
| include(submodules/qsyncable/qsyncable.pri) | ||||
| include(submodules/gel/com_cutehacks_gel.pri) | ||||
| include(submodules/SortFilterProxyModel/SortFilterProxyModel.pri) | ||||
|  | ||||
|  | ||||
| # Custom functions | ||||
|   | ||||
| @@ -45,11 +45,6 @@ class Account(ModelItem): | ||||
|         other_name = other.display_name or other.id[1:] | ||||
|         return name.lower() < other_name.lower() | ||||
|  | ||||
|     @property | ||||
|     def filter_string(self) -> str: | ||||
|         """Filter based on display name.""" | ||||
|         return self.display_name | ||||
|  | ||||
|  | ||||
| @dataclass | ||||
| class Room(ModelItem): | ||||
| @@ -106,12 +101,6 @@ class Room(ModelItem): | ||||
|             (other.display_name or other.id).lower(), | ||||
|         ) | ||||
|  | ||||
|     @property | ||||
|     def filter_string(self) -> str: | ||||
|         """Filter based on room display name, topic, and last event content.""" | ||||
|  | ||||
|         return " ".join((self.display_name, self.topic)) | ||||
|  | ||||
|  | ||||
| @dataclass | ||||
| class Member(ModelItem): | ||||
|   | ||||
| @@ -12,7 +12,7 @@ HTileDelegate { | ||||
|     bottomPadding: topPadding | ||||
|  | ||||
|     backgroundColor: theme.mainPane.account.background | ||||
|     opacity: collapsed && ! anyFilter ? | ||||
|     opacity: collapsed && ! mainPane.filter ? | ||||
|              theme.mainPane.account.collapsedOpacity : 1 | ||||
|  | ||||
|     title.color: theme.mainPane.account.name | ||||
| @@ -51,8 +51,6 @@ HTileDelegate { | ||||
|     readonly property bool collapsed: | ||||
|         window.uiState.collapseAccounts[model.id] || false | ||||
|  | ||||
|     readonly property bool anyFilter: Boolean(mainPaneList.filter) | ||||
|  | ||||
|  | ||||
|     function toggleCollapse() { | ||||
|         window.uiState.collapseAccounts[model.id] = ! collapsed | ||||
| @@ -99,7 +97,7 @@ HTileDelegate { | ||||
|         leftPadding: theme.spacing / 2 | ||||
|         rightPadding: leftPadding | ||||
|  | ||||
|         opacity: ! loading && account.anyFilter ? 0 : 1 | ||||
|         opacity: ! loading && mainPane.filter ? 0 : 1 | ||||
|         visible: opacity > 0 && Layout.maximumWidth > 0 | ||||
|  | ||||
|         Layout.fillHeight: true | ||||
|   | ||||
| @@ -1,66 +1,68 @@ | ||||
| // SPDX-License-Identifier: LGPL-3.0-or-later | ||||
|  | ||||
| import QtQuick 2.12 | ||||
| import SortFilterProxyModel 0.2 | ||||
| import ".." | ||||
| import "../Base" | ||||
|  | ||||
| Column { | ||||
|     id: delegate | ||||
|     // visible: account.opacity > 0 | ||||
|  | ||||
|  | ||||
|     property string userId: model.id | ||||
|     readonly property HListView view: ListView.view | ||||
|     readonly property bool hide: | ||||
|         mainPane.filter && | ||||
|         roomList.model.count < 1 && | ||||
|         ! utils.filterMatches(mainPane.filter, model.display_name) | ||||
|  | ||||
|  | ||||
|     Account { | ||||
|         id: account | ||||
|         width: parent.width | ||||
|         view: delegate.view | ||||
|  | ||||
|         opacity: hide ? | ||||
|                  0 : | ||||
|                  collapsed && ! mainPane.filter ? | ||||
|                  theme.mainPane.account.collapsedOpacity : | ||||
|                  1 | ||||
|         scale: hide ? opacity : 1 | ||||
|         height: implicitHeight * (hide ? opacity : 1) | ||||
|  | ||||
|         Behavior on opacity { HNumberAnimation {} } | ||||
|     } | ||||
|  | ||||
|     HListView { | ||||
|         id: roomList | ||||
|         width: parent.width | ||||
|         height: contentHeight * opacity | ||||
|         opacity: account.collapsed ? 0 : 1 | ||||
|         visible: opacity > 0 | ||||
|         height: hide ? 0 : contentHeight | ||||
|         visible: ! hide | ||||
|         interactive: false | ||||
|  | ||||
|         model: ModelStore.get(delegate.userId, "rooms") | ||||
|         // model: HSortFilterProxy { | ||||
|         //     model: ModelStore.get(delegate.userId, "rooms") | ||||
|         //     comparator: (a, b) => | ||||
|         //         // Sort by membership, then last event date (most recent first) | ||||
|         //         // then room display name or ID. | ||||
|         //         // Invited rooms are first, then joined rooms, then left rooms. | ||||
|         model: SortFilterProxyModel { | ||||
|             sourceModel: ModelStore.get(delegate.userId, "rooms") | ||||
|  | ||||
|         //         // Left rooms may still have an inviter_id, so check left first | ||||
|         //         [ | ||||
|         //             a.left, | ||||
|         //             b.inviter_id, | ||||
|             filters: [ | ||||
|                 ExpressionFilter { | ||||
|                     expression: ! account.collapsed | ||||
|                     enabled: ! mainPane.filter | ||||
|                 }, | ||||
|  | ||||
|         //             b.last_event && b.last_event.date ? | ||||
|         //             b.last_event.date.getTime() : 0, | ||||
|  | ||||
|         //             (a.display_name || a.id).toLocaleLowerCase(), | ||||
|         //         ] < [ | ||||
|         //             b.left, | ||||
|         //             a.inviter_id, | ||||
|  | ||||
|         //             a.last_event && a.last_event.date ? | ||||
|         //             a.last_event.date.getTime() : 0, | ||||
|  | ||||
|         //             (b.display_name || b.id).toLocaleLowerCase(), | ||||
|         //         ] | ||||
|         // } | ||||
|                 ExpressionFilter { | ||||
|                     expression: utils.filterMatches( | ||||
|                         mainPane.filter, model.display_name, | ||||
|                     ) | ||||
|                 } | ||||
|             ] | ||||
|         } | ||||
|  | ||||
|         delegate: Room { | ||||
|             width: roomList.width | ||||
|             userId: delegate.userId | ||||
|         } | ||||
|  | ||||
|         Behavior on opacity { | ||||
|             HNumberAnimation { easing.type: Easing.InOutCirc } | ||||
|         } | ||||
|         Behavior on height { HNumberAnimation {} } | ||||
|     } | ||||
| } | ||||
|   | ||||
| @@ -1,20 +1,13 @@ | ||||
| // SPDX-License-Identifier: LGPL-3.0-or-later | ||||
|  | ||||
| import QtQuick 2.12 | ||||
| import SortFilterProxyModel 0.2 | ||||
| import ".." | ||||
| import "../Base" | ||||
|  | ||||
| HListView { | ||||
|     id: mainPaneList | ||||
|  | ||||
|     model: ModelStore.get("accounts") | ||||
|     // model: HSortFilterProxy { | ||||
|     //     model: ModelStore.get("accounts") | ||||
|     //     comparator: (a, b) => | ||||
|     //         // Sort by display name or user ID | ||||
|     //         (a.display_name || a.id).toLocaleLowerCase() < | ||||
|     //         (b.display_name || b.id).toLocaleLowerCase() | ||||
|     // } | ||||
|  | ||||
|     delegate: AccountRoomsDelegate { | ||||
|         width: mainPaneList.width | ||||
| @@ -22,9 +15,6 @@ HListView { | ||||
|     } | ||||
|  | ||||
|  | ||||
|     readonly property string filter: toolBar.roomFilter | ||||
|  | ||||
|  | ||||
|     function previous(activate=true) { | ||||
|         decrementCurrentIndex() | ||||
|         if (activate) activateLimiter.restart() | ||||
| @@ -58,7 +48,7 @@ HListView { | ||||
|     } | ||||
|  | ||||
|     function toggleCollapseAccount() { | ||||
|         if (filter) return | ||||
|         if (mainPane.filter) return | ||||
|  | ||||
|         if (! currentItem) incrementCurrentIndex() | ||||
|  | ||||
|   | ||||
| @@ -11,9 +11,10 @@ HDrawer { | ||||
|     minimumSize: theme.controls.avatar.size + theme.spacing * 2 | ||||
|  | ||||
|  | ||||
|     property bool hasFocus: toolBar.filterField.activeFocus | ||||
|     property alias mainPaneList: mainPaneList | ||||
|     property alias toolBar: toolBar | ||||
|     readonly property bool hasFocus: toolBar.filterField.activeFocus | ||||
|     readonly property alias mainPaneList: mainPaneList | ||||
|     readonly property alias toolBar: toolBar | ||||
|     property alias filter: toolBar.roomFilter | ||||
|  | ||||
|  | ||||
|     function toggleFocus() { | ||||
|   | ||||
							
								
								
									
										1
									
								
								submodules/SortFilterProxyModel
									
									
									
									
									
										Submodule
									
								
							
							
								
								
								
								
								
							
						
						
									
										1
									
								
								submodules/SortFilterProxyModel
									
									
									
									
									
										Submodule
									
								
							 Submodule submodules/SortFilterProxyModel added at 36befddf5d
									
								
							
		Reference in New Issue
	
	Block a user
	