Bug 486304

Summary: With monospace UI font, Plasmoid license viewer cannot scroll to bottom of license until window is resized
Product: [Plasma] plasmashell Reporter: Roke Julian Lockhart Beedell <4wy78uwh>
Component: generalAssignee: Plasma Bugs List <plasma-bugs-null>
Status: CONFIRMED ---    
Severity: minor CC: alexander.lohnau, christoph, cwo.kde, kde, kdedev, nate
Priority: NOR Flags: 4wy78uwh: performance-
Version First Reported In: 6.0.4   
Target Milestone: 1.0   
Platform: Fedora RPMs   
OS: Linux   
See Also: https://bugs.kde.org/show_bug.cgi?id=486308
Latest Commit: Version Fixed/Implemented In:
Sentry Crash Report:
Attachments: What scrolling to the bottom of the license viewer looks like by default.
What scrolling to the bottom of the license viewer looks like when resized.
What scrolling to the bottom of the license viewer looks like when resized in Plasma 6.1.4.
What scrolling to the bottom of the license viewer looks like when resized in Plasma 6.1.5.
License pane in App Launcher settings
Smallest Window Size for Application Menu in KDE Plasma 6.3.4

Description Roke Julian Lockhart Beedell 2024-04-29 15:51:58 UTC
Created attachment 169002 [details]
What scrolling to the bottom of the license viewer looks like by default.

SUMMARY
The Plasmoid license viewer cannot scroll to the bottom of the license until its parent window is resized.

STEPS TO REPRODUCE
1.  Open any plasmoid with an About page (which contains a license) like Application Launcher and Kate Sessions.
2.  Invoke the link to the fake dialog overlay which displays the license.
3.  Scroll to the bottom of the license without resizing the window, using the scroll wheel on the content.

    You shouldn't be able to see the absolute bottom.

4.  Resize the window.
5.  Scroll downward.

    You should be able to now.

OBSERVED RESULT
I'm unable to read the bottom of the license until I resize its parent window.

EXPECTED RESULT
I should be able to read it all without needing to resize its parent window.

SOFTWARE/OS VERSIONS
Operating System: Fedora Linux 40
KDE Plasma Version: 6.0.4
KDE Frameworks Version: 6.1.0
Qt Version: 6.7.0
Kernel Version: 6.8.8-300.fc40.x86_64 (64-bit)
Graphics Platform: Wayland
Processors: 12 × AMD Ryzen 5 7600X 6-Core Processor
Memory: 30.5 GiB of RAM
Graphics Processor: AMD Radeon RX 5700
Manufacturer: ASRock
Product Name: X670E Taichi

ADDITIONAL INFORMATION
I've set this as minor merely because not many users use this fake dialog.
Comment 1 Roke Julian Lockhart Beedell 2024-04-29 15:53:53 UTC
Created attachment 169005 [details]
What scrolling to the bottom of the license viewer looks like when resized.
Comment 2 cwo 2024-09-15 21:18:18 UTC
I can't reproduce this on master (With Application Launcher, Kate Sessions no longer has a configuration dialog). Is this still an issue for you? If so, could you state which font you are using? I wonder if that may have an influence on this.
Comment 3 Roke Julian Lockhart Beedell 2024-09-16 00:14:47 UTC
Created attachment 173708 [details]
What scrolling to the bottom of the license viewer looks like when resized in Plasma 6.1.4.

(In reply to Roke Julian Lockhart Beedell from comment #1)

Christoph.Wolk@gmx.de, I've attached what it looks like for me using the undermentioned (per `kinfo`):

> ```YAML
> Operating System: Fedora Linux 40
> KDE Plasma Version: 6.1.4
> KDE Frameworks Version: 6.5.0
> Qt Version: 6.7.2
> Kernel Version: 6.10.10-200.fc40.x86_64 (64-bit)
> Graphics Platform: Wayland
> Processors: 12 × AMD Ryzen 5 7600X 6-Core Processor
> Memory: 30.5 GiB of RAM
> Graphics Processor: AMD Radeon RX 5700
> ```

Summarily, the problem remains.

Font
----

Per [this Reddit comment](https://www.reddit.com/r/kde/comments/4fvug4/comment/d2csqpo/?utm_source=share&utm_medium=web3x&utm_name=web3xcss&utm_term=1&utm_content=share_button), `/home/RokeJulianLockhart/.config/kdeglobals` contains the undermentioned:

> ```ini
> [General]
> fixed=Monospace,10,-1,5,400,0,0,0,0,0,0,0,0,0,0,1
> font=Monospace,10,-1,5,400,0,0,0,0,0,0,0,0,0,0,1
> menuFont=Monospace,10,-1,5,400,0,0,0,0,0,0,0,0,0,0,1
> smallestReadableFont=Monospace,10,-1,5,400,0,0,0,0,0,0,0,0,0,0,1
> toolBarFont=Monospace,10,-1,5,400,0,0,0,0,0,0,0,0,0,0,1
> 
> [WM]
> activeFont=Monospace,10,-1,5,400,0,0,0,0,0,0,0,0,0,0,1
> ```

...which `fc-match 'monospace'` lists as [*Noto Sans Mono Regular*](https://koji.fedoraproject.org/koji/rpminfo?rpmID=38077645):

> ```log
> PS /home/RokeJulianLockhart> fc-match monospace                
> NotoSansMono-Regular.ttf: "Noto Sans Mono" "Regular"
> ```
Comment 4 cwo 2024-09-16 08:44:45 UTC
Thanks for the info. Can reproduce in a Fedora VM with Monospace, but not on Tuxedo with master.  Might be fixed, or depend on some other factor (screen size, scaling, etc).
Comment 5 TraceyC 2024-09-27 15:32:55 UTC
Tested with the application launcher configure window
Sized it as small as possible before opening the license info

On KDE Neon and default fonts, I cannot reproduce
(Plasma 6.1.5, Frameworks 6.6.0, Qt 6.7.2)
With all fonts at monospace 10, also not able to reproduce

On git-master, I cannot reproduce with default fonts
With all fonts at monospace 10, also not able to reproduce

If you still see this bug with 6.1.5, what is the resolution of your display?
Comment 6 Roke Julian Lockhart Beedell 2024-09-27 15:51:23 UTC
Created attachment 174143 [details]
What scrolling to the bottom of the license viewer looks like when resized in Plasma 6.1.5.

(In reply to TraceyC from comment #5)

> ```YAML
> Operating System: Fedora Linux 40
> KDE Plasma Version: 6.1.5
> KDE Frameworks Version: 6.6.0
> Qt Version: 6.7.2
> Kernel Version: 6.10.11-200.fc40.x86_64 (64-bit)
> Graphics Platform: Wayland
> Processors: 12 × AMD Ryzen 5 7600X 6-Core Processor
> Memory: 30.5 GiB of RAM
> Graphics Processor: AMD Radeon RX 5700
> Manufacturer: ASRock
> Product Name: X670E Taichi
> ```

I use a 2560x1440px display. It's an [AOC Q3279WG5B](https://linux-hardware.org/?id=eisa:aoc-q3279wg5b-2560x1440) - unfortunately, none of the probes listed are mine (yet).
Comment 7 Roke Julian Lockhart Beedell 2024-09-27 15:52:25 UTC
(In reply to Roke Julian Lockhart Beedell from comment #6)
> none of the probes listed are mine (yet)

It's https://linux-hardware.org/?probe=38c09012e1, if of use.
Comment 8 TraceyC 2024-09-27 20:55:20 UTC
Thanks for the additional detail. I did some further testing.
I changed my laptop display to be 2560x1440 (Plasma 6.1.5). I checked at 150% and 100%
With default fonts, or with all fonts set to monospace I'm still not able to reproduce the bug.
I resized the Application Launcher Settings window as small as it would go, and brought up the license info. If I scroll down to the bottom, the text at the end is visible for me. 

I'm attaching a screenshot of the license window, as it initially appears when I scroll to the bottom.

I'll leave this open so others can try to reproduce.
Comment 9 TraceyC 2024-09-27 20:56:17 UTC
Created attachment 174157 [details]
License pane in App Launcher settings
Comment 10 Roke Julian Lockhart Beedell 2024-09-27 21:09:09 UTC
(In reply to TraceyC from comment #9)
Thanks for that. Perplexing how it can happen to 50% but not the other 50%. Is your monitor of a higher resolution? I ask because you state that you changed its resolution to 1440p, which would be unusual if that's 1:1 for your pixel matrix.
Comment 11 TraceyC 2024-09-27 22:46:49 UTC
My laptop screen's native resolution is 3840x2400. I tested at various other resolutions with different aspect ratios
I also tested on an external monitor, native resolution of 3440x1440 at various resolutions
Comment 12 Roke Julian Lockhart Beedell 2024-09-27 23:02:15 UTC
(In reply to TraceyC from comment #11)
Thanks for doing that.
Comment 13 Nate Graham 2025-04-08 19:45:26 UTC
Can you check again in Plasma 6.3 or later and see if this is still happening?

Thanks a lot!
Comment 14 Roke Julian Lockhart Beedell 2025-04-09 15:35:08 UTC
Created attachment 180123 [details]
Smallest Window Size for Application Menu in KDE Plasma 6.3.4

Yes. It's actually worse now, for resizing the window doesn't make the content visible. I've attached a screenshot to demonstrate this. (I really think this overlay should merely be its own window, or better yet, open the default text editor.)

> Operating System: Fedora Linux 41  
> KDE Plasma Version: 6.3.4  
> KDE Frameworks Version: 6.12.0  
> Qt Version: 6.8.2  
> Kernel Version: 6.13.9-200.fc41.x86_64 (64-bit)  
> Graphics Platform: Wayland
Comment 15 Nate Graham 2025-04-09 20:18:08 UTC
Thanks. Can confirm with these exact settings.
Comment 16 cwo 2025-04-09 21:43:00 UTC
I can reproduce this with non-monospace fonts as well.

The problem is the width - if the text wraps, it's broken. (the joys of TextEdit word wrap...)

The SelectableLabel that contains the text has the correct implicitHeight (and contentHeight)
The OverlaySheet has the correct contentHeight
The ScrollView in the OverlaySheet has the correct contentHeight
The ScrollView's Flickable (contentHeight) is too short
The Flickable's contentItem (implicitHeight) is too short
The Flickable's contentItem's childrenRect has the correct size again.

It happens right at the end. If I forcibly overwrite the Flickable's contentHeight it works (but if I do it earlier with a binding it gets overwritten).

I have no idea why this happens. Might be an issue in Kirigami or in Qt. I don't think it's a problem in Plasma's use of OverlaySheet.
Comment 17 Nate Graham 2025-04-10 14:42:03 UTC
Maybe the problem here is that the text is manually line-broken? If we replaced every lone line break with a space, the text might wrap better.
Comment 18 cwo 2025-04-10 14:51:46 UTC
(In reply to Nate Graham from comment #17)
> Maybe the problem here is that the text is manually line-broken? If we
> replaced every lone line break with a space, the text might wrap better.

I don't think so (even though it would look nicer on smaller window sizes) - you'd still have the text height changing as it does the word wrap, and having to do any word wrap seems to be what is causing the problem. If I increase the horizontal size of the window (before opening the OverlaySheet) so that the word wrap is no longer necessary, it works and allows scrolling right to the end.