this post was submitted on 27 Dec 2024
172 points (100.0% liked)

Free and Open Source Software

18082 readers
88 users here now

If it's free and open source and it's also software, it can be discussed here. Subcommunity of Technology.


This community's icon was made by Aaron Schneider, under the CC-BY-NC-SA 4.0 license.

founded 2 years ago
MODERATORS
 

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:

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!

top 38 comments
sorted by: hot top controversial new old
[–] [email protected] 41 points 3 weeks ago (3 children)

I feel kind of bad for the one responsible developer replying to all those issues. She's taking a lot of heat, lol

[–] [email protected] 30 points 3 weeks ago* (last edited 3 weeks ago) (1 children)

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 quiet month policy is reasonable IMO, developers need breaks, especially those interacts frequently with the community. Love or hate electron (same apply to CEF), these works clearly bring many wonderful apps into the linux world.

I personally don't believe that non-contributors have the right to demand free work from the electron developers.

[–] [email protected] 13 points 3 weeks ago

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.

[–] [email protected] 14 points 3 weeks ago* (last edited 3 weeks ago) (1 children)

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 when org.freedesktop.portal.FileChooser v. 4 could be reliably expected to exist in the wild was surely not kept in secret!

[–] [email protected] 15 points 3 weeks ago

I rescind my lol

[–] [email protected] 2 points 3 weeks ago (1 children)

Can you link the thread? I can't find their response to the issue.

[–] [email protected] 2 points 3 weeks ago (1 children)
[–] [email protected] 1 points 3 weeks ago

Ahh, thank you. The issue seems to be that firefox didnt load any comments at all. Im seeing them in chrome now.

[–] [email protected] 31 points 3 weeks ago

Thanks for the PSA, I was about to go on a troubleshooting spree with Discord not using KDE's file picker

[–] [email protected] 25 points 3 weeks ago (1 children)

To lighten the mood, here's a screenshot of one of the lowest points I achieved while hacking away, trying to resolve the issue: comedic relief screenshot 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.
[–] [email protected] 4 points 3 weeks ago (1 children)

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.

[–] [email protected] 5 points 3 weeks ago

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.

[–] [email protected] 22 points 3 weeks ago (1 children)

because electron is rubbish and there's zero reason to use it.

[–] [email protected] 2 points 3 weeks ago (1 children)

An alternative for it has been steadily developing and it's rather nice

[–] [email protected] 4 points 3 weeks ago (1 children)
[–] [email protected] 9 points 3 weeks ago (1 children)

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

[–] [email protected] 2 points 3 weeks ago

Doesn't it only support rust at the moment ? Is Python support on the way ?

[–] [email protected] 19 points 3 weeks ago* (last edited 3 weeks ago) (1 children)

Another example of Microsoft using its control of FOSS projects to push you towards their web-based alternatives of something you already have except now for the low low price of a monthly subscription fee, AI slop, and all ur data.

[–] [email protected] 4 points 3 weeks ago (1 children)

Microsoft controls electron?

[–] [email protected] 2 points 3 weeks ago (1 children)

Microsoft controls github which controls electron.

[–] [email protected] 8 points 3 weeks ago (1 children)

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.

[–] [email protected] 3 points 3 weeks ago (1 children)

Thats not what i mean. Microsoft owns github, github who created electron.

[–] [email protected] 2 points 3 weeks ago (1 children)

What's your source for that? I've never heard it before

[–] [email protected] 4 points 3 weeks ago

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

[–] [email protected] 18 points 3 weeks ago* (last edited 3 weeks ago) (1 children)

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 months, 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 ...

[–] [email protected] 1 points 3 weeks ago

This kind of stuff made me stop using Linux as a desktop. It just doesn’t have the developer support it needs.

[–] [email protected] 15 points 3 weeks ago (2 children)

Why did your distro update those Electron apps, if they have unsatisfied dependencies?

[–] [email protected] 27 points 3 weeks ago (1 children)

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)

[–] [email protected] 15 points 3 weeks ago

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.

[–] [email protected] 21 points 3 weeks ago

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.

[–] [email protected] 11 points 3 weeks ago (1 children)

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.

[–] [email protected] 16 points 3 weeks ago (1 children)

KDE's built-in editor, Kate, is quite capable, too.

[–] [email protected] 6 points 3 weeks ago

Kate has excellent lsp support nowadays as well.

[–] [email protected] 2 points 3 weeks ago

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.

[–] [email protected] 2 points 3 weeks ago

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.

[–] [email protected] 1 points 3 weeks ago

Why not use KDevelop or Kate?

[–] [email protected] 1 points 3 weeks ago* (last edited 3 weeks ago) (1 children)

If Emmet/keymapping is important, then https://zed.dev/ is the only editor that matches VSCodium as far as I know.

[–] [email protected] 1 points 3 weeks ago

Zed is very interesting. I know it.

Very recently, I found a fork of Zed that gutted the AI Assistant integration and Telemetry. I forked that, myself, and took it further: gutting automatic updates, paid feature-gating, downloading of executable binaries and runtimes like Node.js (for extensions that don't compile to WASI), integration with their online services, voice-calling, screen sharing, etc.

My branch ended up down 140 000 lines[^1] of code and up less than 300! It was educational and the outcome was absolutely brilliant, to be fair. In all honesty, forking it and engaging in this experiment took less than 24 hours even though I restarted three times, with different levels of "stringency" in my quest.

[^1]: No word of a lie! The upstream repo is well over 20k commits and over 100 MB in volume. Zed is not a nice, small, simple code-base: it is VAST and a huge percentage of that is simply uninteresting to me.

This experiment was very realisable. Forking Zed and hacking on it was quite possible – the same cannot be said for just "forking Electron" or "forking VS Code" or even getting up to speed on those projects to the point of being able to fix the underlying issues (like this OP) and submit merge-requests to those projects. They have a degree of inscrutability that I absolutely could overcome but would not, unless I was paid to at my usual rates. (I have two decades of professional development experience.)

I shelved the effort – for the time being – for a few reasons I don't particularly want to extenuate, today, but I shall continue to follow Zed very closely and I truly, deeply hope that there is a future in which I see hope (and, thus, motivation) in maintaining a ready-to-go, batteries-included, AI-free, telemetry-free, cloud-free fork.

Part of maintaining a fork would include sending merge-requests upstream even though I should hardly expect that my fork would be viewed favourably by the Zed business. But, from what I can tell, Zed seem to act true to the open-source principles – unlike many other corporate owners of open-source projects – and I see no reason (yet) to believe they would play unfairly.