Fix file drag and drop (#2575)

# Description

Drag and drop only loading first page.

Closes #(2560)

## Checklist

- [ X] I have read the [Contribution
Guidelines](https://github.com/Stirling-Tools/Stirling-PDF/blob/main/CONTRIBUTING.md)
- [ X] I have performed a self-review of my own code
- [ X] I have attached images of the change if it is UI based
- [ X] I have commented my code, particularly in hard-to-understand
areas
- [ X] If my code has heavily changed functionality I have updated
relevant docs on [Stirling-PDFs doc
repo](https://github.com/Stirling-Tools/Stirling-Tools.github.io/blob/main/docs/)
- [ X] My changes generate no new warnings
- [ X] I have read the section [Add New Translation
Tags](https://github.com/Stirling-Tools/Stirling-PDF/blob/main/HowToAddNewLanguage.md#add-new-translation-tags)
(for new translation tags only)
This commit is contained in:
reecebrowne 2024-12-31 10:44:49 +00:00 committed by GitHub
parent 2e23149090
commit 574c474804
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
3 changed files with 40 additions and 25 deletions

View File

@ -168,6 +168,21 @@ class PdfContainer {
input.click(); input.click();
}); });
} }
async handleDroppedFiles(files, nextSiblingElement = null) {
if (files.length > 0) {
const pages = await this.addFilesFromFiles(files, nextSiblingElement, []);
this.updateFilename(files[0]?.name || 'untitled');
const selectAll = document.getElementById('select-pages-container');
if (selectAll) {
selectAll.classList.remove('hidden');
}
return pages;
}
}
async addFilesFromFiles(files, nextSiblingElement, pages) { async addFilesFromFiles(files, nextSiblingElement, pages) {
this.fileName = files[0].name; this.fileName = files[0].name;
for (var i = 0; i < files.length; i++) { for (var i = 0; i < files.length; i++) {

View File

@ -8,7 +8,7 @@ class FileDragManager {
this.setCallback(cb); this.setCallback(cb);
// Prevent default behavior for drag events // Prevent default behavior for drag events
["dragenter", "dragover", "dragleave", "drop"].forEach((eventName) => { ['dragenter', 'dragover', 'dragleave', 'drop'].forEach((eventName) => {
document.body.addEventListener(eventName, preventDefaults, false); document.body.addEventListener(eventName, preventDefaults, false);
}); });
@ -21,10 +21,10 @@ class FileDragManager {
this.dragleaveListener = this.dragleaveListener.bind(this); this.dragleaveListener = this.dragleaveListener.bind(this);
this.dropListener = this.dropListener.bind(this); this.dropListener = this.dropListener.bind(this);
document.body.addEventListener("dragenter", this.dragenterListener); document.body.addEventListener('dragenter', this.dragenterListener);
document.body.addEventListener("dragleave", this.dragleaveListener); document.body.addEventListener('dragleave', this.dragleaveListener);
// Add drop event listener // Add drop event listener
document.body.addEventListener("drop", this.dropListener); document.body.addEventListener('drop', this.dropListener);
} }
setActions({updateFilename}) { setActions({updateFilename}) {
@ -35,7 +35,7 @@ class FileDragManager {
if (cb) { if (cb) {
this.callback = cb; this.callback = cb;
} else { } else {
this.callback = (files) => console.warn("FileDragManager not set"); this.callback = (files) => console.warn('FileDragManager not set');
} }
} }
@ -43,21 +43,21 @@ class FileDragManager {
this.dragCounter++; this.dragCounter++;
if (!this.overlay) { if (!this.overlay) {
// Create and show the overlay // Create and show the overlay
this.overlay = document.createElement("div"); this.overlay = document.createElement('div');
this.overlay.style.position = "fixed"; this.overlay.style.position = 'fixed';
this.overlay.style.top = 0; this.overlay.style.top = 0;
this.overlay.style.left = 0; this.overlay.style.left = 0;
this.overlay.style.width = "100%"; this.overlay.style.width = '100%';
this.overlay.style.height = "100%"; this.overlay.style.height = '100%';
this.overlay.style.background = "rgba(0, 0, 0, 0.5)"; this.overlay.style.background = 'rgba(0, 0, 0, 0.5)';
this.overlay.style.color = "#fff"; this.overlay.style.color = '#fff';
this.overlay.style.zIndex = "1000"; this.overlay.style.zIndex = '1000';
this.overlay.style.display = "flex"; this.overlay.style.display = 'flex';
this.overlay.style.alignItems = "center"; this.overlay.style.alignItems = 'center';
this.overlay.style.justifyContent = "center"; this.overlay.style.justifyContent = 'center';
this.overlay.style.pointerEvents = "none"; this.overlay.style.pointerEvents = 'none';
this.overlay.innerHTML = "<p>Drop files anywhere to upload</p>"; this.overlay.innerHTML = '<p>Drop files anywhere to upload</p>';
document.getElementById("content-wrap").appendChild(this.overlay); document.getElementById('content-wrap').appendChild(this.overlay);
} }
} }
@ -87,16 +87,16 @@ class FileDragManager {
this.overlay = null; this.overlay = null;
} }
this.updateFilename(files ? files[0].name : ""); this.updateFilename(files ? files[0].name : '');
}); });
} }
async addImageFile(file, nextSiblingElement) { async addImageFile(file, nextSiblingElement) {
const div = document.createElement("div"); const div = document.createElement('div');
div.classList.add("page-container"); div.classList.add('page-container');
var img = document.createElement("img"); var img = document.createElement('img');
img.classList.add("page-image"); img.classList.add('page-image');
img.src = URL.createObjectURL(file); img.src = URL.createObjectURL(file);
div.appendChild(img); div.appendChild(img);

View File

@ -216,7 +216,7 @@
undoManager undoManager
) )
fileDragManager.setCallback(async (files) => pdfContainer.addFilesFromFiles(files)); fileDragManager.setCallback(async (files) => pdfContainer.handleDroppedFiles(files));
document.addEventListener('keydown', function(event) { document.addEventListener('keydown', function(event) {
let targetElementId = event.target.id; let targetElementId = event.target.id;