2024-02-20 22:06:00 -06:00
|
|
|
# config
|
2024-02-20 20:47:39 -06:00
|
|
|
counter = :counters.new(1, [])
|
|
|
|
|
|
|
|
Application.put_env(:sfe, Sfe.Endpoint,
|
2024-02-20 20:37:55 -06:00
|
|
|
http: [ip: {127, 0, 0, 1}, port: 5001],
|
2024-02-20 22:06:00 -06:00
|
|
|
pubsub_server: Sfe.PubSub,
|
2024-02-20 20:37:55 -06:00
|
|
|
adapter: Bandit.PhoenixAdapter,
|
2024-02-20 22:06:00 -06:00
|
|
|
debug_errors: true,
|
|
|
|
code_reloader: true,
|
2024-02-20 20:37:55 -06:00
|
|
|
server: true,
|
|
|
|
live_view: [signing_salt: "aaaaaaaa"],
|
|
|
|
secret_key_base: String.duplicate("a", 64)
|
|
|
|
)
|
|
|
|
|
2024-02-20 20:47:39 -06:00
|
|
|
Application.put_env(:sfe, Sfe.HomeLive, counter_ref: counter)
|
|
|
|
|
2024-02-20 22:06:00 -06:00
|
|
|
# application
|
|
|
|
defmodule Sfe do
|
|
|
|
defmodule Application do
|
|
|
|
use Elixir.Application
|
2024-02-20 20:37:55 -06:00
|
|
|
|
2024-02-20 22:06:00 -06:00
|
|
|
require Logger
|
2024-02-20 20:47:39 -06:00
|
|
|
|
2024-02-20 22:06:00 -06:00
|
|
|
def start(_type, _args) do
|
|
|
|
Logger.debug("Sfe starting...")
|
|
|
|
|
|
|
|
children = [
|
|
|
|
Sfe.Endpoint,
|
|
|
|
{Phoenix.PubSub, name: Sfe.PubSub}
|
|
|
|
]
|
|
|
|
|
|
|
|
opts = [strategy: :one_for_one, name: Sfe.Supervisor]
|
|
|
|
Supervisor.start_link(children, opts)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
defmodule ErrorView do
|
|
|
|
def render(template, _), do: Phoenix.Controller.status_message_from_template(template)
|
|
|
|
end
|
|
|
|
|
|
|
|
defmodule Router do
|
|
|
|
use Phoenix.Router
|
|
|
|
import Phoenix.LiveView.Router
|
|
|
|
|
|
|
|
pipeline :browser do
|
|
|
|
plug(:accepts, ["html"])
|
|
|
|
end
|
|
|
|
|
|
|
|
scope "/", Sfe do
|
|
|
|
pipe_through(:browser)
|
|
|
|
|
|
|
|
live("/", HomeLive, :index)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
defmodule Endpoint do
|
|
|
|
use Phoenix.Endpoint, otp_app: :sfe
|
|
|
|
|
|
|
|
if code_reloading? do
|
|
|
|
socket("/phoenix/live_reload/socket", Phoenix.LiveReloader.Socket)
|
|
|
|
plug(Phoenix.LiveReloader)
|
|
|
|
plug(Phoenix.CodeReloader)
|
|
|
|
end
|
|
|
|
|
|
|
|
socket("/live", Phoenix.LiveView.Socket)
|
|
|
|
plug(Sfe.Router)
|
|
|
|
end
|
2024-02-20 20:37:55 -06:00
|
|
|
end
|
|
|
|
|
|
|
|
defmodule Sfe.HomeLive do
|
|
|
|
use Phoenix.LiveView, layout: {__MODULE__, :live}
|
|
|
|
|
2024-02-20 22:06:00 -06:00
|
|
|
@topic "counter"
|
|
|
|
|
2024-02-20 20:47:39 -06:00
|
|
|
defp counter_ref(), do: Application.get_env(:sfe, __MODULE__)[:counter_ref]
|
|
|
|
defp counter_value(), do: :counters.get(counter_ref(), 1)
|
|
|
|
|
2024-02-20 20:37:55 -06:00
|
|
|
def mount(_params, _session, socket) do
|
2024-02-20 22:06:00 -06:00
|
|
|
Sfe.Endpoint.subscribe(@topic)
|
2024-02-20 20:47:39 -06:00
|
|
|
{:ok, assign(socket, :count, counter_value())}
|
2024-02-20 20:37:55 -06:00
|
|
|
end
|
|
|
|
|
|
|
|
defp phx_vsn, do: Application.spec(:phoenix, :vsn)
|
|
|
|
defp lv_vsn, do: Application.spec(:phoenix_live_view, :vsn)
|
|
|
|
|
|
|
|
def render("live.html", assigns) do
|
|
|
|
~H"""
|
|
|
|
<script src={"https://cdn.jsdelivr.net/npm/phoenix@#{phx_vsn()}/priv/static/phoenix.min.js"}></script>
|
|
|
|
<script src={"https://cdn.jsdelivr.net/npm/phoenix_live_view@#{lv_vsn()}/priv/static/phoenix_live_view.min.js"}></script>
|
|
|
|
<script>
|
|
|
|
let liveSocket = new window.LiveView.LiveSocket("/live", window.Phoenix.Socket)
|
|
|
|
liveSocket.connect()
|
|
|
|
</script>
|
|
|
|
<style>
|
|
|
|
* { font-size: 1.1em; }
|
|
|
|
</style>
|
|
|
|
<%= @inner_content %>
|
|
|
|
"""
|
|
|
|
end
|
|
|
|
|
|
|
|
def render(assigns) do
|
|
|
|
~H"""
|
|
|
|
Multiplayer Counter
|
|
|
|
<%= @count %>
|
|
|
|
<button phx-click="inc">+</button>
|
|
|
|
<button phx-click="dec">-</button>
|
|
|
|
"""
|
|
|
|
end
|
|
|
|
|
|
|
|
def handle_event("inc", _params, socket) do
|
2024-02-20 20:47:39 -06:00
|
|
|
dbg(:counters.add(counter_ref(), 1, 1))
|
|
|
|
counter_value(socket)
|
2024-02-20 20:37:55 -06:00
|
|
|
end
|
|
|
|
|
|
|
|
def handle_event("dec", _params, socket) do
|
2024-02-20 20:47:39 -06:00
|
|
|
dbg(:counters.sub(counter_ref(), 1, 1))
|
|
|
|
counter_value(socket)
|
|
|
|
end
|
2024-02-20 22:06:00 -06:00
|
|
|
|
|
|
|
def handle_info(%{topic: "counter", event: "counter", payload: cval}, socket) do
|
|
|
|
{:noreply, assign(socket, :count, cval)}
|
|
|
|
end
|
2024-02-20 20:47:39 -06:00
|
|
|
|
|
|
|
defp counter_value(socket) do
|
2024-02-20 22:06:00 -06:00
|
|
|
Sfe.Endpoint.broadcast_from(self(), @topic, "counter", counter_value())
|
2024-02-20 20:47:39 -06:00
|
|
|
{:noreply, assign(socket, :count, counter_value())}
|
2024-02-20 20:37:55 -06:00
|
|
|
end
|
|
|
|
end
|