Merge pull request #10 from JosueGalRe/main

feature(zenThemesImporter): write saved preferences to dom on startup
This commit is contained in:
mauro 🤙 2024-09-14 12:03:44 +02:00 committed by GitHub
commit 6a7d1046fb
No known key found for this signature in database
GPG key ID: B5690EEEBB952194

View file

@ -36,8 +36,9 @@ var gZenThemeImporter = new (class {
constructor() {
console.info('ZenThemeImporter: Initiating Zen theme importer');
try {
window.SessionStore.promiseInitialized.then(() => {
window.SessionStore.promiseInitialized.then(async () => {
this.insertStylesheet();
await this.writeToDom();
});
console.info('ZenThemeImporter: Zen theme imported');
} catch (e) {
@ -108,9 +109,68 @@ var gZenThemeImporter = new (class {
async updateStylesheet() {
this.removeStylesheet();
await this.writeStylesheet();
await this.writeToDom();
this.insertStylesheet();
}
_getBrowser() {
if (!this.__browser) {
this.__browser = Services.wm.getMostRecentWindow("navigator:browser")
}
return this.__browser
}
async _getThemePreferences(theme) {
const themePath = PathUtils.join(this.getThemeFolder(theme), 'preferences.json');
if (!(await IOUtils.exists(themePath)) || !theme.preferences) {
return { preferences: [], isLegacyMode: false };
}
let preferences = await IOUtils.readJSON(themePath);
// skip transformation, we won't be writing old preferences to dom, all of them can only be checkboxes
if (typeof preferences === "object" && !Array.isArray(preferences)) {
return { preferences: [], areOldPreferences: true };
}
return { preferences, areOldPreferences: false };
}
async writeToDom() {
const browser = this._getBrowser()
for (const theme of Object.values(await this.getThemes())) {
const { preferences, areOldPreferences } = await this._getThemePreferences(theme);
if (areOldPreferences) {
continue;
}
const themePreferences = preferences.filter(({ type }) => type === "dropdown")
for (const { property } of themePreferences) {
const value = Services.prefs.getStringPref(property, "")
if (value !== "") {
let element = browser.document.getElementById(theme.name)
if (!element) {
element = browser.document.createElement("div")
element.style.display = "none"
element.setAttribute("id", theme.name)
browser.document.body.appendChild(element)
}
element.setAttribute(property, value)
}
}
}
}
async writeStylesheet() {
const themes = [];
this._themes = null;