Hi, please help me. After generating presigned_url from presigned_upload, I am expecting handle_event(“save”) to be called, but it is not fire. Kindly help me; I don’t know what I am doing wrong.
@impl true
def render(assigns) do
~H"""
<div>
<.header>
<%= @title %>
<:subtitle>Add new project to database.</:subtitle>
</.header>
<.simple_form
:let={f}
for={@changeset}
id="project-form"
phx-target={@myself}
phx-change="validate"
phx-submit="save"
>
<.input field={{f, :title}} type="text" label="Title" />
<.input field={{f, :description}} type="text" label="Description" />
<.input field={{f, :active}} type="checkbox" label="Active" />
<.live_file_input upload={@uploads.images} />
<div class="bg-gray-100 p-6" phx-drop-target="{@uploads.images.ref}">
<%= for {_ref, err} <- @uploads.images.errors do %>
<p class="alert alert-danger"><%= Phoenix.Naming.humanize(err) %></p>
<% end %>
<div class="grid grid-cols-2 gap-4">
<%= for entry <- @uploads.images.entries do %>
<div class="flex items-center space-x-4 p-4">
<.live_img_preview entry={entry} width: 5 />
<div>
<div>
<p class="text-xl"><%= entry.client_name %></p>
</div>
</div>
</div>
<% end %>
</div>
</div>
<:actions>
<.button phx-disable-with="Saving...">Save Project</.button>
</:actions>
</.simple_form>
</div>
"""
end
@impl true
def update(%{project: project} = assigns, socket) do
changeset = Projects.change_project(project)
{:ok,
socket
|> assign(assigns)
|> assign(:changeset, changeset)
|> assign(:uploaded_files, [])
|> allow_upload(:images,
accept: ~w(.jpg .jpeg .png),
max_entries: 5,
# max_file_size: 50_000,
external: &presigned_upload/2
)}
end
defp presigned_upload(entry, socket) do
bucket = "tes-portfolio"
key = "public/#{entry.client_name}"
{:ok, presigned_url} = ExAws.Config.new(:s3) |> ExAws.S3.presigned_url(:put, bucket, key)
meta = %{uploader: "S3", bucket: bucket, key: key, url: presigned_url}
{:ok, meta, socket}
end
@impl true
def handle_event("cancel-upload", %{"ref" => ref}, socket) do
{:noreply, cancel_upload(socket, :images, ref)}
end
@impl true
def handle_event("validate", %{"project" => project_params}, socket) do
changeset =
socket.assigns.project
|> Projects.change_project(project_params)
|> Map.put(:action, :validate)
{:noreply, assign(socket, :changeset, changeset)}
end
def handle_event("save", %{"project" => project_params}, socket) do
uploaded_files =
consume_uploaded_entries(socket, :images, fn %{} = meta, _entry ->
{:ok, presigned_url} =
ExAws.Config.new(:s3)
|> ExAws.S3.presigned_url(:get, meta.bucket, meta.key, expires_in: 86_400)
presigned_url
end) |> IO.inspect
save_project(socket, socket.assigns.action, project_params)
end