larshei
Live_file_input does not work
Somehow, I cannot manage to get file uploads to work.
I have read the docs and watched the videos from Chris and also a tutorial at pragmatic studio.
So far, I understand the following:
- I need to allow file uploads:
This will add andef mount(params, session, socket) do {:ok, socket |> allow_upload(:csv, accept: ~w(.csv), max_entries: 1)} end@uploadsassign that holds a description of the constraints and, once selected, files and upload progress. - And can use the
live_file_inputto render a file upload button:
Note: Im using Surface UI with Phoenix Live View 0.16.4def render(assigns) do ~F""" <form id="id" for={:data} phx-submit="upload"> <div class="ui segment" phx-drop-target={@uploads.csv.ref}> {live_file_input @uploads.csv} </div> <p>{inspect @uploads.csv}</p> <Button text={gettext "Upload"} icon="upload" extra_attributes="labeled violet"/> </form> """ end
This renders a “Choose File…” button as expected and shows no file selected next to it. - Consume an upload using consume_uploaded_entries. I did not get to this point.
Expectations
With the setup above, I expected
- Clicking the “Choose File” button opens a file selector and
- when rendering
@uploads.csvafter selecting a file it contains information on the selected file in its:entryfield.
What happens
- Clicking the “Choose File” button does not do anything in Chrome. In Safari, a file browser is opened.
- After selecting a file in Safari, the
@uploadsassign seems to not contain anything (<p>{inspect @uploads.csv}</p>):#Phoenix.LiveView.UploadConfig< accept: ".csv", auto_upload?: false, entries: [], errors: [], max_entries: 1, max_file_size: 8000000, name: :csv, progress_event: nil, ref: "phx-FtoOkG01s4jRVQ-F", ... >
I am not sure if something is missing and would appreciate ideas/hints on what to check ![]()
Solutions
Solution to missing info in
@uploadassigns:
As @Xty mentioned below, aphx-changeis required on the form (which can simply return{:noreply, socket}) to properly update the@uploadsassign.
Marked As Solved
Xty
It’s hard to tell if the code samples you’ve provided are complete or boiled down examples, but I’m fairly sure that the LiveView upload features are expected to be used from within a form element.
Have you tried putting the live_file_input inside of a form? If not, I think that would be a good place to start.
Another thing that has caused me issues with live uploads is not having a phx-change handler on the form. Even if that handler does nothing but respond {:noreply, socket} it’s still needed for live uploads.
I’d recommend reading through the official documentation if you haven’t, it should cover everything you need and is likely more up-to-date than the videos you’ve mentioned.
Also Liked
larshei
You are right, it was inside a form.
I minimized the example a bit too much and have added the form to the initial post.
phx-change was missing as you mentioned. Adding it to the form now updates the socket data correctly, so it fixed one of my two issues ![]()
Now that you mention it, I recognized this is actually mentioned in the docs ![]()
Important: You must bind
phx-submitandphx-changeon the form.
However, Chrome still does not work at all, as no file browser is opened on button click.
03juan
I just tested this with my Chrome file inputs, because I’ve had no problems clicking it, and realised that I’m using a label element in place of your div.
When I change my element to div, drop works but click stops working. Even the section element in the Upload Entries doc example doesn’t work with Chrome. This is either a browser bug or something in the live_view.js, not really sure.








