add no-JS fallback for contact page order tracking form
Some checks failed
deploy / deploy (push) Has been cancelled
Some checks failed
deploy / deploy (push) Has been cancelled
Both order tracking forms now have action="/contact/lookup" so they POST to a new OrderLookupController.lookup action when JS is off. The controller mirrors the LiveView handler: checks for paid orders, sends the verification email, and redirects with a flash message. Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
This commit is contained in:
@@ -1,9 +1,45 @@
|
||||
defmodule BerrypodWeb.OrderLookupController do
|
||||
use BerrypodWeb, :controller
|
||||
|
||||
alias Berrypod.Orders
|
||||
alias Berrypod.Orders.OrderNotifier
|
||||
|
||||
@salt "order_lookup"
|
||||
@max_age 3_600
|
||||
|
||||
@doc """
|
||||
Looks up orders by email and sends a verification link (no-JS fallback).
|
||||
"""
|
||||
def lookup(conn, %{"email" => email}) when is_binary(email) and email != "" do
|
||||
orders = Orders.list_orders_by_email(email)
|
||||
|
||||
if orders == [] do
|
||||
conn
|
||||
|> put_flash(
|
||||
:error,
|
||||
"No orders found for that address. Make sure you use the same email you checked out with."
|
||||
)
|
||||
|> redirect(to: ~p"/contact")
|
||||
else
|
||||
token = generate_token(email)
|
||||
link = BerrypodWeb.Endpoint.url() <> ~p"/orders/verify/#{token}"
|
||||
OrderNotifier.deliver_order_lookup(email, link)
|
||||
|
||||
conn
|
||||
|> put_flash(
|
||||
:info,
|
||||
"We've sent a link to your email address. It'll expire after an hour."
|
||||
)
|
||||
|> redirect(to: ~p"/contact")
|
||||
end
|
||||
end
|
||||
|
||||
def lookup(conn, _params) do
|
||||
conn
|
||||
|> put_flash(:error, "Please enter your email address.")
|
||||
|> redirect(to: ~p"/contact")
|
||||
end
|
||||
|
||||
def verify(conn, %{"token" => token}) do
|
||||
case Phoenix.Token.verify(BerrypodWeb.Endpoint, @salt, token, max_age: @max_age) do
|
||||
{:ok, email} ->
|
||||
|
||||
Reference in New Issue
Block a user