From 6207d8a75e40aa76008edaffbbe138bbc9f6baa4 Mon Sep 17 00:00:00 2001 From: auric <104602845+ihateamongus@users.noreply.github.com> Date: Thu, 11 Sep 2025 15:13:57 -0500 Subject: Add dynamic Firefox accent color extension --- browsers/firefox/accent_host.py | 36 ++++++++++++++++++++++++++++++++ browsers/firefox/extension/background.js | 34 ++++++++++++++++++++++++++++++ browsers/firefox/extension/content.js | 15 +++++++++++++ browsers/firefox/extension/manifest.json | 22 +++++++++++++++++++ browsers/firefox/install-native-host.sh | 15 +++++++++++++ browsers/firefox/update-userchrome.sh | 10 +++++++++ browsers/firefox/userChrome.template.css | 7 +++++++ 7 files changed, 139 insertions(+) create mode 100755 browsers/firefox/accent_host.py create mode 100644 browsers/firefox/extension/background.js create mode 100644 browsers/firefox/extension/content.js create mode 100644 browsers/firefox/extension/manifest.json create mode 100755 browsers/firefox/install-native-host.sh create mode 100755 browsers/firefox/update-userchrome.sh create mode 100644 browsers/firefox/userChrome.template.css (limited to 'browsers/firefox') diff --git a/browsers/firefox/accent_host.py b/browsers/firefox/accent_host.py new file mode 100755 index 0000000..ec0a166 --- /dev/null +++ b/browsers/firefox/accent_host.py @@ -0,0 +1,36 @@ +#!/usr/bin/env python3 +import json +import os +import struct +import subprocess +import sys + +def send(msg): + data = json.dumps(msg).encode('utf-8') + sys.stdout.buffer.write(struct.pack('I', len(data))) + sys.stdout.buffer.write(data) + sys.stdout.buffer.flush() + +def read(): + raw = sys.stdin.buffer.read(4) + if len(raw) == 0: + return None + length = struct.unpack('I', raw)[0] + return json.loads(sys.stdin.buffer.read(length).decode('utf-8')) + +def get_accent(): + try: + helper = os.path.join(os.path.dirname(__file__), '..', 'getaccent') + color = subprocess.check_output([helper], stderr=subprocess.DEVNULL).decode().strip() + if color: + return color + except Exception: + pass + return '#000000' + +while True: + msg = read() + if msg is None: + break + if msg.get('query') == 'color': + send({'color': get_accent()}) diff --git a/browsers/firefox/extension/background.js b/browsers/firefox/extension/background.js new file mode 100644 index 0000000..df0ee80 --- /dev/null +++ b/browsers/firefox/extension/background.js @@ -0,0 +1,34 @@ +let port = browser.runtime.connectNative("accent_color"); +let current = null; + +function broadcast(color) { + browser.tabs.query({}).then(tabs => { + for (let tab of tabs) { + browser.tabs.sendMessage(tab.id, {color}).catch(() => {}); + } + }); + browser.theme.update({colors: {toolbar: color}}); +} + +port.onMessage.addListener(msg => { + if (msg.color && msg.color !== current) { + current = msg.color; + broadcast(current); + } +}); + +function poll() { + try { + port.postMessage({query: "color"}); + } catch (e) { + // ignore + } +} +setInterval(poll, 1000); +poll(); + +browser.runtime.onMessage.addListener((msg, sender) => { + if (msg.request === "color") { + return Promise.resolve({color: current}); + } +}); diff --git a/browsers/firefox/extension/content.js b/browsers/firefox/extension/content.js new file mode 100644 index 0000000..118c7ee --- /dev/null +++ b/browsers/firefox/extension/content.js @@ -0,0 +1,15 @@ +function apply(color) { + document.documentElement.style.setProperty("--accent-color", color); +} + +browser.runtime.onMessage.addListener(msg => { + if (msg.color) { + apply(msg.color); + } +}); + +browser.runtime.sendMessage({request: "color"}).then(msg => { + if (msg && msg.color) { + apply(msg.color); + } +}); diff --git a/browsers/firefox/extension/manifest.json b/browsers/firefox/extension/manifest.json new file mode 100644 index 0000000..abcbe08 --- /dev/null +++ b/browsers/firefox/extension/manifest.json @@ -0,0 +1,22 @@ +{ + "manifest_version": 2, + "name": "Accent Color Updater", + "version": "0.1", + "description": "Updates CSS variable --accent-color using a native host", + "applications": { + "gecko": { + "id": "accent-color@example.com" + } + }, + "background": { + "scripts": ["background.js"] + }, + "permissions": ["nativeMessaging", "tabs", ""], + "content_scripts": [ + { + "matches": [""], + "js": ["content.js"], + "run_at": "document_start" + } + ] +} diff --git a/browsers/firefox/install-native-host.sh b/browsers/firefox/install-native-host.sh new file mode 100755 index 0000000..33a6c88 --- /dev/null +++ b/browsers/firefox/install-native-host.sh @@ -0,0 +1,15 @@ +#!/bin/sh +set -eu +cd "$(dirname "$0")" +HOST_DIR="${HOME}/.mozilla/native-messaging-hosts" +mkdir -p "$HOST_DIR" +cat >"$HOST_DIR/accent_color.json" <&2; exit 1; } +PROFILE="$PROFILE_DIR/$PROFILE" +mkdir -p "$PROFILE/chrome" +sed "s/ACCENT/$ACCENT/" userChrome.template.css > "$PROFILE/chrome/userChrome.css" diff --git a/browsers/firefox/userChrome.template.css b/browsers/firefox/userChrome.template.css new file mode 100644 index 0000000..509ed81 --- /dev/null +++ b/browsers/firefox/userChrome.template.css @@ -0,0 +1,7 @@ +:root{ + --accent-color: ACCENT; +} + +#navigator-toolbox { + background-color: var(--accent-color) !important; +} -- cgit v1.2.3