Refactor js
This commit is contained in:
56
script.js
56
script.js
@@ -262,12 +262,9 @@
|
|||||||
})();
|
})();
|
||||||
|
|
||||||
// ============================================================
|
// ============================================================
|
||||||
// Gallery Thumbnails
|
// Gallery Thumbnails Module
|
||||||
// ============================================================
|
// ============================================================
|
||||||
function initGalleryThumbs() {
|
var GalleryThumbnails = (function () {
|
||||||
var imgs = document.querySelectorAll('div.luxtools-gallery img[data-thumb-src]');
|
|
||||||
if (!imgs || !imgs.length) return;
|
|
||||||
|
|
||||||
function loadThumb(img) {
|
function loadThumb(img) {
|
||||||
var src = img.getAttribute('data-thumb-src') || '';
|
var src = img.getAttribute('data-thumb-src') || '';
|
||||||
if (!src) return;
|
if (!src) return;
|
||||||
@@ -286,6 +283,10 @@
|
|||||||
pre.src = src;
|
pre.src = src;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function init() {
|
||||||
|
var imgs = document.querySelectorAll('div.luxtools-gallery img[data-thumb-src]');
|
||||||
|
if (!imgs || !imgs.length) return;
|
||||||
|
|
||||||
if ('IntersectionObserver' in window) {
|
if ('IntersectionObserver' in window) {
|
||||||
var io = new window.IntersectionObserver(function (entries) {
|
var io = new window.IntersectionObserver(function (entries) {
|
||||||
entries.forEach(function (entry) {
|
entries.forEach(function (entry) {
|
||||||
@@ -304,9 +305,15 @@
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
return {
|
||||||
|
init: init
|
||||||
|
};
|
||||||
|
})();
|
||||||
|
|
||||||
// ============================================================
|
// ============================================================
|
||||||
// Open Service (file:// links)
|
// Open Service Module (file:// links)
|
||||||
// ============================================================
|
// ============================================================
|
||||||
|
var OpenService = (function () {
|
||||||
function getServiceUrl(el) {
|
function getServiceUrl(el) {
|
||||||
var url = el.getAttribute('data-service-url') || '';
|
var url = el.getAttribute('data-service-url') || '';
|
||||||
url = (url || '').trim();
|
url = (url || '').trim();
|
||||||
@@ -383,10 +390,17 @@
|
|||||||
return path;
|
return path;
|
||||||
}
|
}
|
||||||
|
|
||||||
function initScratchpads() {
|
return {
|
||||||
var pads = document.querySelectorAll('div.luxtools-scratchpad[data-luxtools-scratchpad="1"]');
|
openViaService: openViaService,
|
||||||
if (!pads || !pads.length) return;
|
pingOpenViaImage: pingOpenViaImage,
|
||||||
|
normalizeToFileUrl: normalizeToFileUrl
|
||||||
|
};
|
||||||
|
})();
|
||||||
|
|
||||||
|
// ============================================================
|
||||||
|
// Scratchpads Module
|
||||||
|
// ============================================================
|
||||||
|
var Scratchpads = (function () {
|
||||||
function setEditMode(root, isEditing) {
|
function setEditMode(root, isEditing) {
|
||||||
if (!root || !root.classList) return;
|
if (!root || !root.classList) return;
|
||||||
|
|
||||||
@@ -511,7 +525,7 @@
|
|||||||
setStatus(root, '');
|
setStatus(root, '');
|
||||||
}
|
}
|
||||||
|
|
||||||
document.addEventListener('click', function (e) {
|
function onClick(e) {
|
||||||
var t = e.target;
|
var t = e.target;
|
||||||
if (!t) return;
|
if (!t) return;
|
||||||
|
|
||||||
@@ -550,9 +564,19 @@
|
|||||||
e.preventDefault();
|
e.preventDefault();
|
||||||
closeEditor(rootC);
|
closeEditor(rootC);
|
||||||
}
|
}
|
||||||
}, true);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function init() {
|
||||||
|
var pads = document.querySelectorAll('div.luxtools-scratchpad[data-luxtools-scratchpad="1"]');
|
||||||
|
if (!pads || !pads.length) return;
|
||||||
|
document.addEventListener('click', onClick, true);
|
||||||
|
}
|
||||||
|
|
||||||
|
return {
|
||||||
|
init: init
|
||||||
|
};
|
||||||
|
})();
|
||||||
|
|
||||||
// ============================================================
|
// ============================================================
|
||||||
// Click Handlers
|
// Click Handlers
|
||||||
// ============================================================
|
// ============================================================
|
||||||
@@ -598,14 +622,14 @@
|
|||||||
if (!raw) return;
|
if (!raw) return;
|
||||||
|
|
||||||
// Prefer local client service.
|
// Prefer local client service.
|
||||||
openViaService(el, raw)
|
OpenService.openViaService(el, raw)
|
||||||
.catch(function (err) {
|
.catch(function (err) {
|
||||||
// If the browser blocks the request before it reaches localhost (mixed-content,
|
// If the browser blocks the request before it reaches localhost (mixed-content,
|
||||||
// extensions, stricter CORS handling), fall back to a no-CORS GET ping.
|
// extensions, stricter CORS handling), fall back to a no-CORS GET ping.
|
||||||
pingOpenViaImage(el, raw);
|
OpenService.pingOpenViaImage(el, raw);
|
||||||
|
|
||||||
// Fallback to old behavior (often blocked in modern browsers).
|
// Fallback to old behavior (often blocked in modern browsers).
|
||||||
var url = normalizeToFileUrl(raw);
|
var url = OpenService.normalizeToFileUrl(raw);
|
||||||
if (!url) return;
|
if (!url) return;
|
||||||
console.warn('Local client service failed, falling back to file:// navigation:', err);
|
console.warn('Local client service failed, falling back to file:// navigation:', err);
|
||||||
try {
|
try {
|
||||||
@@ -624,6 +648,6 @@
|
|||||||
// Initialize
|
// Initialize
|
||||||
// ============================================================
|
// ============================================================
|
||||||
document.addEventListener('click', onClick, false);
|
document.addEventListener('click', onClick, false);
|
||||||
document.addEventListener('DOMContentLoaded', initGalleryThumbs, false);
|
document.addEventListener('DOMContentLoaded', GalleryThumbnails.init, false);
|
||||||
document.addEventListener('DOMContentLoaded', initScratchpads, false);
|
document.addEventListener('DOMContentLoaded', Scratchpads.init, false);
|
||||||
})();
|
})();
|
||||||
|
|||||||
Reference in New Issue
Block a user