From 5fb58865b0256a83c578ff746307cf9b2916c279 Mon Sep 17 00:00:00 2001 From: Guillaume Dufour Date: Sun, 14 Apr 2024 18:55:42 +0200 Subject: [PATCH] first try --- addon/button.js | 70 +++++++++++++++++++++++++++++++------------------ 1 file changed, 45 insertions(+), 25 deletions(-) diff --git a/addon/button.js b/addon/button.js index 587069cb5..2b202fcdb 100644 --- a/addon/button.js +++ b/addon/button.js @@ -23,8 +23,8 @@ function initButton(sfHost, inInspector) { btn.tabIndex = 0; btn.accessKey = "i"; btn.title = "Show Salesforce details (Alt+I / Shift+Alt+I)"; - rootEl.appendChild(btn); loadPopup(); + rootEl.appendChild(btn); document.body.appendChild(rootEl); addFlowScrollability(); @@ -81,22 +81,34 @@ function initButton(sfHost, inInspector) { } } - function setRootCSSProperties(rootElement, buttonElement) { + function updateButtonCSSPropertiesFromStorage(rootElement, buttonElement) { let popupArrowOrientation = iFrameLocalStorage.popupArrowOrientation ? iFrameLocalStorage.popupArrowOrientation : "vertical"; let popupArrowPosition = iFrameLocalStorage.popupArrowPosition ? (iFrameLocalStorage.popupArrowPosition + "%") : "122px"; - let img = document.createElement("img"); + updateButtonCSSPropertiesIfNeeded(rootElement, buttonElement, popupArrowOrientation, popupArrowPosition); + } + + function updateButtonCSSPropertiesIfNeeded(rootElement, buttonElement, popupArrowOrientation, popupArrowPosition) { if (popupArrowOrientation == "vertical") { - rootElement.style.right = 0; rootElement.style.top = popupArrowPosition; - img.src = ""; - buttonElement.classList.add("insext-btn-vertical"); + if (!(buttonElement.classList.contains("insext-btn-vertical"))) { + rootElement.style.right = "0px"; + buttonElement.classList.add("insext-btn-vertical"); + buttonElement.classList.remove("insext-btn-horizontal"); + let img = document.createElement("img"); + img.src = ""; + buttonElement.appendChild(img); + } } else { - rootElement.style.bottom = "0px"; rootElement.style.right = popupArrowPosition; - img.src = ""; - buttonElement.classList.add("insext-btn-horizontal"); + if (!(buttonElement.classList.contains("insext-btn-horizontal"))) { + rootElement.style.bottom = "0px"; + buttonElement.classList.add("insext-btn-horizontal"); + buttonElement.classList.remove("insext-btn-vertical"); + let img = document.createElement("img"); + img.src = ""; + buttonElement.appendChild(img); + } } - buttonElement.appendChild(img); } function loadPopup() { @@ -107,27 +119,35 @@ function initButton(sfHost, inInspector) { closePopup(); } }); - //manage our self the darg n drop - btn.ondragstart = function() { - return false; - }; + function onbuttonmove(event) { console.log('move to '+event.clientX+' , '+event.clientY); console.log(' on ' + rootEl.getBoundingClientRect()); - //if - //localStorage.setItem("popupArrowOrientation", orientation); - //localStorage.setItem("popupArrowPosition", position); + let popupArrowOrientation; + let popupArrowPosition; + // if above the diagonal + if (event.clientY > (rootEl.getBoundingClientRect().width * event.clientX) * rootEl.getBoundingClientRect().height) { + popupArrowOrientation = "horizontal"; + popupArrowPosition = event.clientX / rootEl.getBoundingClientRect().width; + } else { + popupArrowOrientation = "vertical"; + popupArrowPosition = event.clientY / rootEl.getBoundingClientRect().height; + } + updateButtonCSSPropertiesIfNeeded(rootEl, btn, popupArrowOrientation, popupArrowPosition) + }; - btn.addEventListener("dragstart", (event) => { - event.dataTransfer.dropEffect = "move"; - }); - btn.addEventListener("drag", (event) => { - onbuttonmove(event); + btn.addEventListener("mousedown", (event) => { + console.log('start'); + btn.addEventListener("mousemove", onbuttonmove); }); - btn.addEventListener("drop", (event) => { - onbuttonmove(event); + btn.addEventListener("mouseup", (event) => { + console.log('end'); + btn.removeEventListener("mousemove", onbuttonmove); + iFrameLocalStorage.setItem("popupArrowOrientation", popupArrowOrientation); + iFrameLocalStorage.setItem("popupArrowPosition", popupArrowPosition); + updateButtonCSSPropertiesFromStorage(rootEl, btn) }); let popupSrc = chrome.runtime.getURL("popup.html"); @@ -156,7 +176,7 @@ function initButton(sfHost, inInspector) { popupEl.classList.add("insext-popup-vertical-up"); } } - setRootCSSProperties(rootEl, btn); + updateButtonCSSPropertiesFromStorage(rootEl, btn); addFlowScrollability(popupEl); popupEl.contentWindow.postMessage({ insextInitResponse: true,