Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Feature request: support drag and drop for opening local PDF #9690

Closed
iamCristYe opened this issue Apr 25, 2018 · 15 comments
Closed

Feature request: support drag and drop for opening local PDF #9690

iamCristYe opened this issue Apr 25, 2018 · 15 comments

Comments

@iamCristYe
Copy link

Could you please add support for drag a PDF into the view to open it?

@lalagias
Copy link
Contributor

I want to contribute to this issue! Could I have a bit more context, about how to implement this feature and what exactly do you want to achieve?

@iamCristYe
Copy link
Author

@lalagias Hey! Thank you for replying! By drag and drop, I mean to open a PDF a by drag a PDF into the PDF.js tab and drop it, like in https://smallpdf.com/compress-pdf or https://www.w3schools.com/html/html5_draganddrop.asp

@lalagias
Copy link
Contributor

@iamCristYe So do you want a UI solution to your issue like smallpdf.com and the ability to drag-drop the PDF? Also, the drag and drop feature is getting handled in Firefox Browser.

@iamCristYe
Copy link
Author

@lalagias Yes. Note that actually I'm using PDF.js in Chrome/Edge.

@lalagias
Copy link
Contributor

dragndrop

@iamCristYe Is that the feature you asked for? Any feedback could be really useful, I'm trying to contribute to this project and I like your request.

@iamCristYe
Copy link
Author

iamCristYe commented May 16, 2018

This looks great! @lalagias

@lalagias
Copy link
Contributor

@timvandermeij can we talk about how I should proceed this UI solution?

@timvandermeij
Copy link
Contributor

I'm thinking that for the UI we don't have to do much actually. For users it would be easiest to stay close to how Firefox currently handles this. If you open a new tab for example and drag a file onto it, it will open the file in that tab without any additional UI. For PDF.js we could do the same: the entire viewer could have an invisible drag-'n-drop zone so you can just drag the file into the viewer.

@lalagias
Copy link
Contributor

@timvandermeij so we are dropping the UI solution and we are going to replace it with a Mozilla-like solution, for Chrome/Edge, I agree 100%. Although the solution we are discussing, it has implemented by pdf.js or it is implemented within Mozilla browser?

Furthermore, the use case that we want to handle is to open a pdf with pdf.js and the entire viewer will be a drag'n'drop zone so if we drag'n'drop a new pdf file there it will reload and render the new one.

So, firstly I should try to make a drag'n'drop zone and then try to fetch the new pdf?

@timvandermeij
Copy link
Contributor

It's not really a Mozilla-specific solution, but I think it's how browsers and operating systems handle this in general. For example in IDEs you can also drop a file and it will be opened without any additional UI. I think that's nice because it keeps it simple and if we do that it will also be closer to the behavior users expect.

@lalagias
Copy link
Contributor

You are 100% right, about the user experience. The OS, browser and even IDEs solution you mentioned is by far the most appropriate for this feature request.

So, I want to contribute to this feature, should I proceed and try to figure out a way to implement this?

@iamCristYe
Copy link
Author

@lalagias I think you should proceed

@lalagias
Copy link
Contributor

lalagias commented Jun 1, 2018

@timvandermeij Hello, currently I have set the drop zone with a div element in the viewer.html file, and I have written some drag functions to test it out in a dragNdrop.js file.

I think I need to implement the Open File functionality to the drag'n'drop zone.

How should I proceed?
My thoughts, at the moment, are either find and use the Open File functionality or somehow try to call the right functions to process the new dropped file.

@timvandermeij
Copy link
Contributor

I think you can use https://github.com/mozilla/pdf.js/blob/master/web/app.js#L701 for that.

@lalagias
Copy link
Contributor

lalagias commented Jun 2, 2018

@timvandermeij The functionality is done, and I have made a pull request. The branch is called Drag'N'Drop.
Could a reviewer help me with my pull request?

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

No branches or pull requests

3 participants