kcm/kwinrules: Fix header in properties list

This provides a better fix for the header positioning bug in
the properties list sheet, instead of the previous workaround
(which wasn't enough in some situations)

Upstream bugfix (in the Kirigami component) is not advisable as
it could cause unintended consequencies in other uses/apps

See also: https://bugs.kde.org/show_bug.cgi?id=422289

BUG: 421583
FIXED-IN: 5.24
This commit is contained in:
Ismael Asensio 2022-01-07 11:04:42 +00:00
parent bd1fab3458
commit d13c39bec6

View file

@ -173,7 +173,10 @@ ScrollViewKCM {
section { section {
property: "section" property: "section"
delegate: Kirigami.ListSectionHeader { label: section } delegate: Kirigami.ListSectionHeader {
label: section
height: implicitHeight
}
} }
delegate: Kirigami.AbstractListItem { delegate: Kirigami.AbstractListItem {
@ -240,7 +243,6 @@ ScrollViewKCM {
onSheetOpenChanged: { onSheetOpenChanged: {
searchField.text = ""; searchField.text = "";
if (sheetOpen) { if (sheetOpen) {
overlayModel.ready = true;
searchField.forceActiveFocus(); searchField.forceActiveFocus();
} else { } else {
overlayModel.onlySuggestions = false; overlayModel.onlySuggestions = false;
@ -290,19 +292,8 @@ ScrollViewKCM {
invalidateFilter(); invalidateFilter();
} }
// Delay the model filtering until `ready` is set
// FIXME: Workaround https://bugs.kde.org/show_bug.cgi?id=422289
property bool ready: false
onReadyChanged: {
invalidateFilter();
}
filterString: searchField.text.trim().toLowerCase() filterString: searchField.text.trim().toLowerCase()
filterRowCallback: (source_row, source_parent) => { filterRowCallback: (source_row, source_parent) => {
if (!ready) {
return false;
}
var index = sourceModel.index(source_row, 0, source_parent); var index = sourceModel.index(source_row, 0, source_parent);
var hasSuggestion = sourceModel.data(index, RulesModel.SuggestedValueRole) != null; var hasSuggestion = sourceModel.data(index, RulesModel.SuggestedValueRole) != null;