Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add FXIOS-11179 [Dark Mode] Use darkreader for webviews #24327

Merged
merged 14 commits into from
Jan 30, 2025

Conversation

issammani
Copy link
Collaborator

@issammani issammani commented Jan 24, 2025

📜 Tickets

Jira ticket
Github issue

💡 Description

This PR:

  • Pulls in darkreader into the app.
  • Adds JS interface to switch between darkreader and old night mode depending on feature flag.
  • Adds darkreader to Licenses.html
  • Adds darkreader script to its own namespace isolated from other scripts.

📝 Checklist

You have to check all boxes before merging

  • Filled in the above information (tickets numbers and description of your work)
  • Updated the PR name to follow our PR naming guidelines
  • Wrote unit tests and/or ensured the tests suite is passing
  • When working on UI, I checked and implemented accessibility (minimum Dynamic Text and VoiceOver)
  • If needed, I updated documentation / comments for complex code and public methods
  • If needed, added a backport comment (example @Mergifyio backport release/v120)

@mobiletest-ci-bot
Copy link

mobiletest-ci-bot commented Jan 24, 2025

Messages
📖 Project coverage: 33.95%
📖 Edited 18 files
📖 Created 5 files

Client.app: Coverage: 32.3

File Coverage
BrowserViewController.swift 3.52% ⚠️
UserScriptManager.swift 97.98%
Tab.swift 42.24% ⚠️
NightModeHelper.swift 24.39% ⚠️
NimbusFlaggableFeature.swift 99.31%
NimbusFeatureFlagLayer.swift 64.14%

WebEngine: Coverage: 71.09

File Coverage
WKEngineConfiguration.swift 20.83% ⚠️
WKContentScriptManager.swift 69.05%

Generated by 🚫 Danger Swift against d95d709

@lmarceau
Copy link
Contributor

Nit; could you fix the tasks link in the PR description? 😄 I wanted to have a look at them since I was curious about the work!

@issammani issammani changed the title Add [WIP] [Dark Mode] Use darkreader for webviews Add FXIOS-11179 [Dark Mode] Use darkreader for webviews Jan 27, 2025
@issammani
Copy link
Collaborator Author

Nit; could you fix the tasks link in the PR description? 😄 I wanted to have a look at them since I was curious about the work!

Sure. I was too lazy to do it last Friday 😂 Done now. I added a link to the spec doc in the jira ticket.

@issammani issammani marked this pull request as ready for review January 29, 2025 15:20
@issammani issammani requested a review from a team as a code owner January 29, 2025 15:20
@issammani issammani requested a review from dataports January 29, 2025 15:20
@issammani issammani force-pushed the poc/dark-reader-lib branch 2 times, most recently from 52a7f00 to d95d709 Compare January 29, 2025 16:39
Comment on lines +67 to +68
// If a script already exists on the page, skip adding this duplicate.
guard scripts[name] == nil else { return }
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

nice

@dataports
Copy link
Contributor

This looks great! Is this a candidate to add to the feature flags toggle panel in the secret settings menu for testing purposes?

I noticed while testing that there was this weirdness with Twitter/X Google button but I'm guessing that's just them having a bad asset? (This is with Night Mode enabled)
image

I don't really feel qualified to hit approve on this because I'm not a JS dev at alllll, so I'll let @nbhasin2 do it, but the swift looks good to me! TIL what WKContentWorld is ⭐

@nbhasin2
Copy link
Contributor

That google button is odd but I doubt we can do anything with it. My understanding is it can be fixed by DarkReader when they update their scripts.

@issammani
Copy link
Collaborator Author

issammani commented Jan 30, 2025

I noticed while testing that there was this weirdness with Twitter/X Google button but I'm guessing that's just them having a bad asset? (This is with Night Mode enabled)

Ok I prematurely bumped the package version yesterday 🙈 . I downgraded it now and it behaves as expected for x.com. I tried the build from source and it also behaves correctly. It seems to be a bad version in between. Will update to the latest version once that's published to npm. Thanks for flagging @dataports 😄

My understanding is it can be fixed by DarkReader when they update their scripts.

Exactly, this is the goal. They merge a few PRs a day fixing things so we should benefit from those fixes. Once we finish up phase 3, we should be updating this more regularly.

@issammani issammani force-pushed the poc/dark-reader-lib branch from 96902ad to 056dccf Compare January 30, 2025 02:37
@issammani
Copy link
Collaborator Author

Ok BR is failing. Will check back tomorrow what's happening. Seems unrelated...

@issammani issammani merged commit 3fbead0 into main Jan 30, 2025
13 checks passed
@issammani issammani deleted the poc/dark-reader-lib branch January 30, 2025 15:38
@issammani
Copy link
Collaborator Author

@Mergifyio backport release/v135

Copy link
Contributor

mergify bot commented Jan 30, 2025

backport release/v135

✅ Backports have been created

mergify bot pushed a commit that referenced this pull request Jan 30, 2025
* chore: add darkreader lib

* feat: add nimbus flag

* feat: pass down flag to JS

* feat: move old code to LegacyNightModeHelper and add logic to pick treatment

* fix: lint

* fix: wrong flag value

* fix: cleanup flag check

* fix: typo

Co-authored-by: Nishant Bhasin <nish.bhasin@gmail.com>

* fix: remove vim modeline

Co-authored-by: Nishant Bhasin <nish.bhasin@gmail.com>

* chore: add license

* chore: move night mode to separate dir

* feat: isolate nightmode into its own content world

* fix: update mocks

* fix: downgrade darkreader to previous version

---------

Co-authored-by: Nishant Bhasin <nish.bhasin@gmail.com>
(cherry picked from commit 3fbead0)

# Conflicts:
#	firefox-ios/Client/FeatureFlags/NimbusFlaggableFeature.swift
rvandermeulen pushed a commit that referenced this pull request Feb 7, 2025
) (#24453)

* Add FXIOS-11179 [Dark Mode] Use darkreader for webviews (#24327)

* chore: add darkreader lib

* feat: add nimbus flag

* feat: pass down flag to JS

* feat: move old code to LegacyNightModeHelper and add logic to pick treatment

* fix: lint

* fix: wrong flag value

* fix: cleanup flag check

* fix: typo

Co-authored-by: Nishant Bhasin <nish.bhasin@gmail.com>

* fix: remove vim modeline

Co-authored-by: Nishant Bhasin <nish.bhasin@gmail.com>

* chore: add license

* chore: move night mode to separate dir

* feat: isolate nightmode into its own content world

* fix: update mocks

* fix: downgrade darkreader to previous version

---------

Co-authored-by: Nishant Bhasin <nish.bhasin@gmail.com>
(cherry picked from commit 3fbead0)

# Conflicts:
#	firefox-ios/Client/FeatureFlags/NimbusFlaggableFeature.swift

* fix: merge conflict

---------

Co-authored-by: Issam Mani <issamouu69@gmail.com>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

5 participants