I spent the morning trying to work out why all the Electron applications on my desktop (vscodium, the Signal client …) were once-a-fuc•ing-gain showing me clunky, foreign file-open and file-save dialogues (presumably from gtk) instead of correctly showing KDE’s dialogues via the very-cursed XDG-desktop-portal mechanism.
I’m on Gentoo. Had I, perhaps, broken something?
Nope. It’s just yet another regression up-stream, in Electron:
- https://github.com/microsoft/vscode/issues/231173#issuecomment-2410885232
- https://github.com/electron/electron/issues/43819#issuecomment-2379445244
- https://github.com/flathub/org.signal.Signal/issues/719
Once again, despite knowing that nobody has support for something because that thing has not been released as stable at all, yet, the whole Electron stack follows the belief that it’s perfectly OK to release a change that depends on that thing and, without it, breaks every KDE user’s desktop integration.
Then they blame it on xdg-desktop-portal not having released, yet. And won’t roll the change back because December is their “quiet month” – neither will they fix it nor make a work-around, seemingly.
Anyway. Writing this post has served to exhaust my ire. One day, we’ll see the back of Electron for good – I can only hope!
Let it also serve as a PSA: don’t bother trying to work out if you’ve accidentally broken something on your Linux desktop – particularly if you’re on Gentoo, Arch, Slackware or other hacker-friendly distribution. It’s not you. It’s not your system. It’s just fuc•ing Electron – again!
because electron is rubbish and there’s zero reason to use it.
An alternative for it has been steadily developing and it’s rather nice
What’s the alternative?
Tauri, it’s got awful Linux support (dated theme) but it’s improving
Its what I use for the gui of my map making software
Doesn’t it only support rust at the moment ? Is Python support on the way ?
Try intellij. It’s really neat and not built on electron.
This doesn’t solve the underlying issue, but if my primary code writing interface was doing this type of shit, I would ditch it immediately.
Why did your distro update those Electron apps, if they have unsatisfied dependencies?
It’s a good question for the package maintainers.
In their defence: it isn’t a direct dependency, it isn’t advertised, and it is likely that the distro package maintainers just don’t know about it – Electron hardly announce that they chose to depend on something that they know isn’t released, anywhere, yet, and won’t be for months.
The apps are Flatpak’ed, so they update independently of the system.
But yeah why did Flatpak update them when Flatpak has unsatisfied dependencies? (To be fair the apps still work, it’s mostly a ergonomic and cosmetic regression)
This doesn’t only affect Flatpak apps. The
xdg-desktop-portal
mechanism is used by many things. Even “gtk native” applications like Firefox use it when running on a correctly configured KDE environment and one of the nuances of this issue is that those applications – today – continue to work perfectly. Electron is not part of their stack.I have
flatpak
on my desktop just for Steam and even flatpak’d steam still seems to work, correctly.
To lighten the mood, here’s a screenshot of one of the lowest points I achieved while hacking away, trying to resolve the issue: What even is going on, there?
- pixelated menu
- “Cancel” button at the top left??
- “Open” button at the top right??
- clearly Adwaita but not actually Adwaita as configured – the VSCodium window (behind) shows how Adwaita is actually configured on my system and that’s how all native gtk applications actually draw.
But isn’t that the new gtk adwaita file chooser? I kinda dislike how those action buttons in dialogs are in the headerbar now but that’s now just how it is.
See Gimp 3.0.
The new Gnome file chooser is part of Gnome’s Files app and I doubt OP has that installed when they’re using KDE Plasma. Aside from that, I’m also pretty sure this is the default GTK file chooser (so the old one) from the way it looks. For context, I use Gnome.
Thanks for the PSA, I was about to go on a troubleshooting spree with Discord not using KDE’s file picker
Another example of Microsoft using its control of FOSS projects to push you towards their web-based alternatives to something you already except now for the low low price of a monthly subscription fee, AI slop, and all ur data.
Microsoft controls electron?
Microsoft controls github which controls electron.
As much as I like to shit on Microsoft, that is not how this works. Github doesn’t magically control the projects hosted on it.
Thats not what i mean. Microsoft owns github, github who created electron.
What’s your source for that? I’ve never heard it before
From memory but wikepedia back me up: https://en.wikipedia.org/wiki/Electron_(software_framework)
I was technicaly correct in Github created it but they nolonger maintain it so idk what control they still have over the project.
It’s currently maintained by OpenJS Foundation with founding members included Google, Microsoft, IBM, PayPal, GoDaddy, and Joyent. https://en.wikipedia.org/wiki/OpenJS_Foundation
If Emmet/keymapping is important, then https://zed.dev/ is the only editor that matches VSCodium as far as I know.
I feel kind of bad for the one responsible developer replying to all those issues. She’s taking a lot of heat, lol
Can you link the thread? I can’t find their response to the issue.
https://github.com/electron/electron/issues/43819#issuecomment-2379445244
look for user codebytere
I don’t see it as a “lol” matter.
The Electron project made an extremely stupid decision. Individual people who are left to wrangle with the fall-out and manage the PR have nothing but my utmost sympathy, as do all the down-stream projects (Signal, Discord, VSCodium…) who have to do the same. Even the developers of
xdg-desktop-portal
are facing unnecessary backlash because of this. Their release schedule and time-line for whenorg.freedesktop.portal.FileChooser
v. 4 could be reliably expected to exist in the wild was surely not kept in secret!I rescind my lol
It is understandable people are frustrated, I am frustrated, and joined several conversation regarding this problem. However, I don’t appreciate some of the rant from many users. This change is certainly out-of-touch, potentially due to them don’t quite foresee the amount of flatpak/kde users who are affected by this change.
But many complaints have been dangerously close to the line, if not over the line. Their quite month policy is reasonable IMO, developers need breaks, especially those with frequent interaction with the community. Love or hate electron (same apply to CEF), it seems clear to me, the work if these developers brings many wonderful apps into the linux world.
I personally don’t feel people, who are not paying or contributing the development of electron, have the right to demand free work from the electron developer.
It seems like a lot of people who do that don’t understand that there’s an inverse relationship between devs soaking up all the emotional labor that comes with being the target of end users’ ire and having the energy to get the actual work done. Especially when it comes to open source stuff, they could literally be spending the time they’re spending shouting at a dev to do more dev things like… learning to fix it themselves and submitting a commit.
I use as few Electron apps as possible. I replaced VSCode with (depending on what I’m trying to achieve) Helix, Sublime Text or a JetBrains IDE.
KDE’s built-in editor, Kate, is quite capable, too.
Kate has excellent lsp support nowadays as well.
I feel one of the hardship for Linux to catch on is the lack of commercial interest to make it usable for consumers.
If this problem happened on Windows and macOS, MS and Apple would just send an engineer to spend a week or a day to have it fixed. This change has been in electron for Month, and no one bother to fix it.
Same with bugs in chrome and libsecrate, which have been open for 4 freaking years… https://gitlab.gnome.org/GNOME/libsecret/-/issues/49
It also took chrome half a decade to support text-input-v3: https://issues.chromium.org/issues/40113488#comment1, which is added by a third party developer. And it still breaks KDE’s implementate https://bugs.kde.org/show_bug.cgi?id=492225 …
So these things always get me confused because I swear there was a neat electron thing in the single digit two thousands that was a small project and really cool and I keep on expecting this to be the grown up version but when I look it up they seem to have nothing to do with each other. I can’t even find the thing I remember from early in the millenium.