From 4e7803305a9b5149065416fda5fc01b4bdb34607 Mon Sep 17 00:00:00 2001 From: "(quasar) nebula" Date: Sat, 30 Nov 2024 18:25:06 -0400 Subject: client: image-overlay: grab color from clicked image --- src/static/js/client/image-overlay.js | 35 +++++++++++++++++++++++++++++++++++ 1 file changed, 35 insertions(+) (limited to 'src/static') diff --git a/src/static/js/client/image-overlay.js b/src/static/js/client/image-overlay.js index a8f211af..b51d57a4 100644 --- a/src/static/js/client/image-overlay.js +++ b/src/static/js/client/image-overlay.js @@ -1,5 +1,7 @@ /* eslint-env browser */ +import {getColors} from '../../shared-util/colors.js'; + import {cssProp} from '../client-util.js'; import {fetchWithProgress} from '../xhr-util.js'; @@ -120,6 +122,7 @@ async function handleImageLinkClicked(evt) { const details = getImageLinkDetails(evt.target); + updateImageOverlayColors(details); updateFileSizeInformation(details.originalFileSize); for (const link of info.viewOriginalLinks) { @@ -145,6 +148,9 @@ function getImageLinkDetails(imageLink) { availableThumbList: img.dataset.thumbs, + + color: + cssProp(imageLink, '--primary-color'), }; Object.assign(details, getImageSources(details)); @@ -172,6 +178,35 @@ function getImageSources(details) { } } +function updateImageOverlayColors(details) { + if (details.color) { + let colors; + try { + colors = + getColors(details.color, { + chroma: window.chroma, + }); + } catch (error) { + console.warn(error); + return; + } + + cssProp(info.container, { + '--primary-color': colors.primary, + '--deep-color': colors.deep, + '--deep-ghost-color': colors.deepGhost, + '--bg-black-color': colors.bgBlack, + }); + } else { + cssProp(info.container, { + '--primary-color': null, + '--deep-color': null, + '--deep-ghost-color': null, + '--bg-black-color': null, + }); + } +} + async function loadOverlayImage(details) { if (details.thumbSrc) { info.thumbImage.src = details.thumbSrc; -- cgit 1.3.0-6-gf8a5