Bug 201863

Summary: System Settings doesn't respect default single click setting
Product: [Applications] systemsettings Reporter: Allan Sandfeld <kde>
Component: generalAssignee: System Settings Bugs <sourtooth+ssbugs>
Status: RESOLVED FIXED    
Severity: normal CC: cfeck, ereslibre, finex, thomas.luebking
Priority: NOR    
Version: unspecified   
Target Milestone: ---   
Platform: Compiled Sources   
OS: Unspecified   
Latest Commit: Version Fixed In:
Sentry Crash Report:
Attachments: Patch for single-click behavior
Patch for following single/double click actions
Attached an improved patch as requested
Updated patch

Description Allan Sandfeld 2009-07-29 10:33:18 UTC
Version:            (using Devel)
Installed from:    Compiled sources

It has always been default in KDE to use single click for opening, but configurable to double-click. but in 4.3 System Settings now requires double click to open sub-settings. This means it is not respecting the single click settings, and breaking every KDE UI-standard. (And I fear what it does in double- click setting, require quadruple click?).
Comment 1 Allan Sandfeld 2009-07-29 11:47:08 UTC
Created attachment 35716 [details]
Patch for single-click behavior

This is a quick patch to respect single click settings. It doesn't add the more advanced timered hover settings, but such an implementation should probably be made more general.
Comment 2 Allan Sandfeld 2009-07-29 16:41:40 UTC
Note that the problem doesn't present itself when using the Oxygen style, because it sets a behavioral style hint for Qt. 

This also means my patch is misbehaving when combined with Oxygen style. What probably should be done, is stop using the activated() signal and instead emit an execute() signal like KListWidget does.
Comment 3 FiNeX 2009-07-29 23:35:57 UTC
I'm not able to reproduce using current trunk: the icons on system settings follows the configuration. Exactly which KDE version are you using?
Comment 4 Allan Sandfeld 2009-07-30 09:15:14 UTC
I am using KDE 4.3 branch last updated 29/7.

Note that single click works when using the Oxygen widget style, but auto-select hover doesn't.

When using widget styles supplied by Qt, single click doesn't work. This is because KStyle is setting the SH_IconView_ActivateOnSingleClick hint. The problem is the with this model of putting behavior in the QStyle means we can't rely on Qt to enforce KDE settings, we need to add the functionality in the KDE widget classes.
Comment 5 Ben Cooksley 2009-08-05 09:21:10 UTC
Bug confirmed using Plastique style.

Please update your patch to latest Trunk and submit it to kde-core-devel@kde.org.
Comment 6 Ben Cooksley 2009-09-10 09:22:29 UTC
@Rafael: is this something that needs to be handled in KCategorizedView or in System Settings itself?
Comment 7 Rafael Fernández López 2009-09-18 01:45:07 UTC
Created attachment 37028 [details]
Patch for following single/double click actions

This patch applies the same solution Dolphin has for this issue.

Can I commit the attached patch ?
Comment 8 Ben Cooksley 2009-09-18 06:43:13 UTC
Please go ahead and commit the patch.
Comment 9 Allan Sandfeld 2009-09-18 08:21:59 UTC
The patch is very simple, but has the weakness in that it doesn't switch style when settings are changed. 

A combination of this patch and my patch might work better. Change my patch to emit an new signal for instance "executed" and then connect from that instead of activated.
Comment 10 Rafael Fernández López 2009-09-19 06:47:11 UTC
Created attachment 37052 [details]
Attached an improved patch as requested

Hi there. This patch takes into account in-runtime changes of settings.

Is this patch OK to commit ?
Comment 11 Ben Cooksley 2009-09-19 11:22:37 UTC
Patch is mostly ok. It would be best if the KGlobalSettings section wasn't duplicated. Maybe that area should just call settingsChanged( KGlobalSettings::SETTINGS_MOUSE )?

Otherwise patch may be committed.
Comment 12 Rafael Fernández López 2009-09-19 15:06:20 UTC
Created attachment 37060 [details]
Updated patch

Ben, I think keeping that logic out with a proper name and calling it is a better solution than calling the slot with that very specific name.

Is this patch OK ?
Comment 13 Ben Cooksley 2009-09-19 22:21:38 UTC
Definitely makes more sense. Please note the you need to connect to the activated() signal as well to allow keyboard navigation.
Also, I don't think connectAllViews() needs to be in the d-pointer.

Otherwise patch is perfect.
Comment 14 Allan Sandfeld 2009-09-20 20:10:41 UTC
SVN commit 1026068 by carewolf:

Use stylesheet to set activate-on-singleclick hint for non-KDE QStyles
BUG:201863


 M  +19 -0     kglobalsettings.cpp  


WebSVN link: http://websvn.kde.org/?view=rev&revision=1026068
Comment 15 Christoph Feck 2009-09-21 01:34:34 UTC
Hm, the commit sets an application global style sheet. I don't like this, as it affects performance of all widgets, and breaks applications that already set a stylesheet. Has this been discussed anywhere? Does this bug need to be fixed at all? To me, the only correct solution is to document that KDE settings are respected by KDE styles only. Other platform's styles even might have their own settings, and KDE should not enforce its settings, but respect platform settings.
Comment 16 Allan Sandfeld 2009-09-21 08:24:25 UTC
That is how KDE applications has always worked. There might be a problem with other stylesheets, which would need to be merged.

If single-click only affects styles it would be an option for QStyles, and needs to be moved to the widget style configuration.
Comment 17 Thomas Lübking 2009-09-26 22:56:46 UTC
i fully second cristoph
(i just ran into this and lost som time in figuring out why i couldn't apply a stylesheet to an application)

Applying a global stylesheet to handle the click policy (for a subset of QStyles) is
a) sheer overhead
b) an inconsequent solution (as apps could either fail to successfully apply their sheets or remove this "patch" by successfully applying global sheets)
c) possibly triggering a behavioural break between KDE and Qt apps
d) simply a /bug/ if styles have host system relative settings on this (and KDE apps are used within a non KDE desktop environment)

so i really strongly vote for reverting this.

the proper fix (if required) for this would be for QStyles (i case they do not option this anyway or aren't strongly DE mimics) to either detect the KDE environment, read the setting and adjust the stylehint in this regard or simply provide a property/setter on this (though the latter is probably not what QStlyes were meant to be)
Comment 18 Christoph Feck 2009-09-27 00:37:23 UTC
Thanks Thomas for being with me :) I was going to raise the discussion again, too, because I even got Qt 4.6 to crash when simply calling setStyle() in system settings.

This isn't the primary reason for not liking the patch, as Qt could be fixed. Thomas already wrote what other reasons there are, mainly that it overrides platform settings (e.g. people that use QWindowsVistaStyle would really like KDE to follow the settings from the Windows Control Panel) and it breaks applications that use their own style sheet, because KDE now overrides this.

The real fix would be to get a patch in for Qt's QCommonStyle. It could check if the application is running on KDE, and then read KDE's global setting. QStyles that do not have a native policy for that option would then respect KDE's setting. Qt is increasingly enhanced to support KDE settings for palettes, toolbar icon sizes, toolbar text positions, icon themes, button order, etc.

@Allen, I do not understand your comment "That is how KDE applications has always worked". Are you suggesting that KDE always set a global style sheet? I only see some style sheets for selected widgets.

I am reopening the bug, just to make others aware of the problem. If there can be no agreement to revert this patch here, I would like to discuss this on kde-devel-core.
Comment 19 Ben Cooksley 2009-09-27 00:51:09 UTC
In agreement with Thomas and Christoph. Please revert the stylesheet change, adding this to Qt is the correct way to handle it.
Comment 20 Thomas Lübking 2009-09-27 18:24:04 UTC
Ok, two or three more things i ran into
(short version: this /must/ be reverted)

a) QStyleSheetStyle operates on qApp->palette() /only/
as a consequence if a widget gets a custom palette all its children will continue to use the app wide palette rather than the custom one (leading to invisible text in doubt and given the vast amount of palette->setColor(QPalette::Window, Qt::transparent); -what is wrong by itself, but happens- probably some unexpected solid visuals (KFilePlacesView is a prominient example)

b) After this patch is applied, qApp->style() (and regularly non custom QWidget::style()s) will (::inherits("KStyle") == false) - even if the original style did (so any code checking for this will fail)
For similar reasons the painting of custom widgets might be impacted (e.g. the runtime style elements as currently used at least by KCapacityBar) will fail (for /every/ style as QStyleSheeetStyle simply does not support this feature)

Last, an "imho".
As I see the QStyle design, it's done to integrate Qt applications into the hosting system (though X11 has no default, but there's support for motif, cde, and Gnome - KDE is a special case here.
::setStyleSheet() then /can/ be used to pass the end user the ultimate opportunity to skin a specific application.

But using stylesheets to do anything but this (including the unfortunate usage of stylesheets to paint images onto dialogs) is plain abuse of this feature.
From my personal experience, applying a global stylesheet and /not/ handle all used UI elements by the stylesheet, regularly leeds to visual flaws (as e.g. many styles don't use the general focus indicator to indicate the focus of elements like buttons - but QStyleSheetStyle /does/)

It might be a convinient way but is likely to cause interferences.
While this might be a corner case for the dialog background images/watermarks it's really prominent on global stylesheets.
Comment 21 Allan Sandfeld 2009-09-28 09:38:01 UTC
Okay, at least we agree that it is a setting that has to be applied globably? I used the stylesheet because it was the only way short of wrapping all QStyles in KStyles.

I have a few notes:
- I am considering adding a KApplication::addStylesheet so you can have multiple stylesheet and only remove per name, etc.
- We do a very bad job of supporting double-click. If we want double-click we should probably use it more limited like Windows does. Right now, every listView suddenly requires double-click which is unexpected for both KDE and Windows users. We could possibly decide to uses click() signal instead, because single-click activation would be expected on a double-click platform such as Windows too. This is the case with systemsettings, but also document list in Kate etc.
Comment 22 Ben Cooksley 2009-09-28 13:12:12 UTC
The correct signal to connect to is activated() otherwise then the keyboard is not used. The proper way to fix it would be to fix QStyle once more to use single click on tree views / list views.
Comment 23 Allan Sandfeld 2009-09-28 13:41:18 UTC
The patch has been reverted. Not cc'ed here due to a typo in CCBUG.

I see two major roads
1. Fixing only KCategoryView
2. Fixing all QAbstractItemView

1. For the first, the existing patches were not acceptable because they didn't handle keyboard events. Another approach would be overloading mouseReleaseEvent or setting widget stylesheet.
2. I can only see wrapping all QStyles in KStyles or changing Qt itself
Comment 24 Thomas Lübking 2009-09-28 16:23:19 UTC
First off: thanks for reverting this =D

As for the solutions:
a) Neither "fixing" KCategoryView nor QAbstractItemView will really do the job - the click policy might be used on other classes as well.

The usage of metastyles* has one _major_ design flaw:
The app's click behaviour will depend on the used constructor (QApplication vs. KApplication) what is no way obvious to the user.
I.e.: some apps might use single click and some use double click - eww :-\

This is imho worse than some styles forcing a click policy on the user (what is at least a consistent experience)

So to me the only valid solution is to handle this in QCommonStyle or QStyle (what however does not prevent inheriting styles to hardcode a behaviour, that's in the scope of styles)

(This is now rather OT, but) to force a certain activation mode, i usually apply an eventFilter to the widget (if i don't need to inherit it anyway) and emit activated() on the event in question (MouseButtonPress) or blockSignals in case.
KDE ItemView variants or even QItemView could of course provide a convenient function like "::forceActivationMode()" or so...

*setStyleSheet() basically does this, but there's no point in using overheaded css parsing stuff for this - a simple metastyle that passes through all style functions and overrides this values /would/ do and has by far less traps
Comment 25 Ben Cooksley 2009-11-23 05:02:51 UTC
This should be proposed for fixing with Qt platform plugins.
Comment 26 Christoph Feck 2009-12-02 13:30:20 UTC
This is implemented in qguiplatformplugin_kde starting with 4.4. When Qt detects that it is running in an KDE environment, it queries KDE's single-click setting in QCommonStyle using this plugin.

Some styles might still override that behavior (e.g. QWindowsStyle probably reads Windows Control Panel settings), but for most styles, the KDE setting is now respected.

This does not mean all applications follow automatically, only those that actually use activated() instead of clicked() or doubleClicked(), but this has to be fixed in individual applications.