From dd5b5f6d83a97704af9e29e39bbea3794eef0507 Mon Sep 17 00:00:00 2001 From: AKORA <65976562+A-K-O-R-A@users.noreply.github.com> Date: Mon, 30 Sep 2024 11:00:31 +0200 Subject: [PATCH] Make button a toggle instead of having only a disable button --- src/contentScripts/other/selma/layout.ts | 32 +++++++++++++----------- 1 file changed, 17 insertions(+), 15 deletions(-) diff --git a/src/contentScripts/other/selma/layout.ts b/src/contentScripts/other/selma/layout.ts index 50e9df2..0f0a03b 100644 --- a/src/contentScripts/other/selma/layout.ts +++ b/src/contentScripts/other/selma/layout.ts @@ -209,7 +209,9 @@ Actual logic // Create a small banner that indicates the user that the site was modified // It also adds a small toggle to disable the table -function createCreditsBanner () { +async function createCreditsBanner() { + const { improveSelma: settingEnabled } = await chrome.storage.local.get(['improveSelma']) + const imgUrl = chrome.runtime.getURL('/assets/images/tufast48.png') const credits = document.createElement('p') @@ -217,7 +219,7 @@ function createCreditsBanner () { credits.style.marginRight = '0' credits.style.color = '#002557' // Selma theme color credits.id = 'TUfastCredits' - credits.innerHTML = `Table powered by + credits.innerHTML = `Table ${settingEnabled ? 'powered by' : 'disabled'} TUfast by AKORA @@ -239,11 +241,11 @@ function createCreditsBanner () { // Tooltip disableButton.title = - 'Disable the "ImproveSelma" feature and reload the page to apply the change.' - disableButton.textContent = 'Disable' + 'Toggle the "ImproveSelma" feature and reload the page to apply the change.' + disableButton.textContent = settingEnabled ? 'Deactivate' : 'Activate' disableButton.onclick = async (event) => { event.preventDefault() - await chrome.storage.local.set({ improveSelma: false }) + await chrome.storage.local.set({ improveSelma: !settingEnabled }) window.location.reload() } credits.appendChild(disableButton) @@ -254,13 +256,19 @@ function createCreditsBanner () { (async () => { const { improveSelma } = await chrome.storage.local.get(['improveSelma']) - if (!improveSelma) return - // Apply all custom changes - document.addEventListener('DOMContentLoaded', eventListener) + document.addEventListener('DOMContentLoaded', async () => { + // Add Credit banner with toggle button + const creditElm = await createCreditsBanner() + document.querySelector('.semesterChoice')!.appendChild(creditElm) + + if (!improveSelma) return + + eventListener(); + }) })() -function eventListener () { +async function eventListener () { document.removeEventListener('DOMContentLoaded', eventListener) // Inject css @@ -275,12 +283,6 @@ function eventListener () { injectCSS('my_exams') } - // Add Credit banner - { - const creditElm = createCreditsBanner() - document.querySelector('.semesterChoice')!.appendChild(creditElm) - } - applyChanges() }