leilukin-tumbleblog/modules/lightbox/javascript.php

215 lines
6.3 KiB
PHP
Raw Normal View History

2024-06-20 14:10:42 +00:00
<?php
if (!defined('CHYRP_VERSION'))
exit;
?>
var ChyrpLightbox = {
background: "<?php esce($config->module_lightbox["background"]); ?>",
protect: <?php esce($config->module_lightbox["protect"]); ?>,
busy: false,
styles: {
fg: {
"box-sizing": "border-box",
"display": "block",
"width": "100%",
"height": "100%",
"padding": "0px",
"margin": "0px",
"aspect-ratio": "auto",
"object-fit": "contain",
"background-color": "transparent"
},
bg: {
"box-sizing": "border-box",
"display": "block",
"position": "fixed",
2025-01-13 09:56:01 +00:00
"inset": "0px",
"margin": "0rem",
2024-06-20 14:10:42 +00:00
"padding": "3rem",
2025-01-13 09:56:01 +00:00
"opacity": "0",
2024-06-20 14:10:42 +00:00
"cursor": "wait",
2025-01-13 09:56:01 +00:00
"z-index": "2147483646",
2024-06-20 14:10:42 +00:00
"background-repeat": "no-repeat",
"background-size": "1.5rem",
"background-position": "right 0.75rem top 0.75rem",
"background-image": "url('" + Site.chyrp_url + "/modules/lightbox/images/close.svg')"
},
show: {
2025-01-13 09:56:01 +00:00
"opacity": "1",
2024-06-20 14:10:42 +00:00
"cursor": "pointer"
},
images: {
"cursor": "pointer"
},
spacing: {
"padding": Math.abs("<?php esce($config->module_lightbox["spacing"]); ?>") + "px"
},
black: {
2025-01-13 09:56:01 +00:00
"background-color": "black",
2024-06-20 14:10:42 +00:00
"background-blend-mode": "difference"
},
grey: {
2025-01-13 09:56:01 +00:00
"background-color": "grey",
"background-blend-mode": "lighten"
2024-06-20 14:10:42 +00:00
},
white: {
2025-01-13 09:56:01 +00:00
"background-color": "white",
2024-06-20 14:10:42 +00:00
"background-blend-mode": "difference"
},
inherit: {
"background-color": "inherit",
"background-blend-mode": "difference"
},
2025-01-13 09:56:01 +00:00
transparent: {
"background-color": "transparent",
"background-blend-mode": "normal",
"backdrop-filter": "blur(8px) contrast(0.8)"
}
2024-06-20 14:10:42 +00:00
},
2025-01-13 09:56:01 +00:00
init: function(
) {
2024-06-20 14:10:42 +00:00
$.extend(
ChyrpLightbox.styles.fg,
ChyrpLightbox.styles.spacing
);
$.extend(
ChyrpLightbox.styles.bg,
ChyrpLightbox.styles[ChyrpLightbox.background]
);
$("section img").not(".suppress_lightbox").each(
function() {
$(this).on(
"click",
ChyrpLightbox.load
).css(
ChyrpLightbox.styles.images
);
if (ChyrpLightbox.protect) {
if (!$(this).hasClass("suppress_protect"))
$(this).on(
"contextmenu",
ChyrpLightbox.prevent
);
}
}
);
$(window).on("popstate", ChyrpLightbox.hide);
ChyrpLightbox.watch();
},
2025-01-13 09:56:01 +00:00
prevent: function(
e
) {
2024-06-20 14:10:42 +00:00
e.preventDefault();
},
2025-01-13 09:56:01 +00:00
watch: function(
) {
2024-06-20 14:10:42 +00:00
// Watch for DOM additions on blog pages.
if (!!window.MutationObserver && $(".post").length) {
var target = $(".post").last().parent()[0];
var observer = new MutationObserver(
function(mutations) {
mutations.forEach(
function(mutation) {
for (var i = 0; i < mutation.addedNodes.length; ++i) {
var item = mutation.addedNodes[i];
$(item).find("section img").not(".suppress_lightbox").each(
function() {
$(this).on(
"click",
ChyrpLightbox.load
).css(
ChyrpLightbox.styles.images
);
if (ChyrpLightbox.protect) {
if (!$(this).hasClass("suppress_protect"))
$(this).on(
"contextmenu",
ChyrpLightbox.prevent
);
}
}
);
}
}
);
}
);
var config = {
childList: true,
subtree: true
};
observer.observe(target, config);
}
},
2025-01-13 09:56:01 +00:00
load: function(
e
) {
2024-06-20 14:10:42 +00:00
if (ChyrpLightbox.busy)
return;
ChyrpLightbox.busy = true;
e.preventDefault();
var src = e.target.currentSrc;
var alt = e.target.alt;
$(
"<div>",
{
"id": "ChyrpLightbox-bg",
"role": "button",
"tabindex": "0",
"accesskey": "x",
"aria-label": '<?php esce(__("Stop displaying this image", "lightbox")); ?>'
}
).css(
ChyrpLightbox.styles.bg
).on(
"click",
ChyrpLightbox.hide
).append(
$(
"<img>",
{
"id": "ChyrpLightbox-fg",
"src": src,
"alt": alt
}
).css(
ChyrpLightbox.styles.fg
).on(
"load",
ChyrpLightbox.show
)
).appendTo("body");
},
2025-01-13 09:56:01 +00:00
show: function(
) {
2024-06-20 14:10:42 +00:00
var fg = $("#ChyrpLightbox-fg");
var bg = $("#ChyrpLightbox-bg");
if (ChyrpLightbox.protect)
$(fg).on(
"contextmenu",
ChyrpLightbox.prevent
);
bg.css(
ChyrpLightbox.styles.show
);
bg.focus();
},
2025-01-13 09:56:01 +00:00
hide: function(
) {
2024-06-20 14:10:42 +00:00
$("#ChyrpLightbox-bg").remove();
ChyrpLightbox.busy = false;
}
}
$(document).ready(ChyrpLightbox.init);