From 5b3c3608b4f3169a58b1d8c841b8b9782c086c07 Mon Sep 17 00:00:00 2001 From: Joe Jarvis Date: Tue, 24 Jul 2018 17:33:05 -0400 Subject: [PATCH] Textbox for exporting options and notes --- extension/options.css | 3 +++ extension/options.html | 2 ++ extension/options.js | 11 ++++++++++- 3 files changed, 15 insertions(+), 1 deletion(-) diff --git a/extension/options.css b/extension/options.css index 7a4da56..e6183e4 100644 --- a/extension/options.css +++ b/extension/options.css @@ -36,3 +36,6 @@ tr:hover a { button { height: 30px; } +#exportTextarea { + height: 500px; +} diff --git a/extension/options.html b/extension/options.html index 8583d57..8f184ce 100644 --- a/extension/options.html +++ b/extension/options.html @@ -218,6 +218,8 @@ (Please export notes and options before downloading from sync, just in case.) + This text box contains the raw JSON for notes and options. + diff --git a/extension/options.js b/extension/options.js index d4f5b43..5138c2c 100644 --- a/extension/options.js +++ b/extension/options.js @@ -29,6 +29,7 @@ const bullet_types = document.getElementById("bullet-types"); const get_params = document.getElementById("get-params"); const exportButton = document.getElementById("export"); const importButton = document.getElementById("import"); +const exportTextarea = document.getElementById("exportTextarea"); const tabnos = document.getElementById("tabnos"); // End element variables @@ -107,7 +108,13 @@ async function restoreOptions() { if (res.options.subdomains_mode === "whitelist") { domain_mode.innerText = "Enforce"; } + exportNotesAndOptions(); +} + +async function exportNotesAndOptions() { + var res = await browser.storage.local.get(); exportButton.href = "data:text/json;charset=utf-8," + JSON.stringify(res); + exportTextarea.value = JSON.stringify(res, null, " "); } function importOptions() { @@ -148,9 +155,11 @@ table.addEventListener("input", colorSync); // Subdomain Sync subdomains_mode.addEventListener("input", domainModeSync); // save options -table.addEventListener("change", saveOptions); // Event delegation is a lot simpler than what I was trying +table.addEventListener("input", saveOptions); // Event delegation is a lot simpler than what I was trying // badges notification_badge_color.addEventListener("input", changeBadgeColor); notification_badge_color_picker.addEventListener("input", changeBadgeColor); +// on storage change +browser.storage.onChanged.addListener(exportNotesAndOptions); // onload document.addEventListener("DOMContentLoaded", restoreOptions);