defmodule Jido.Chat.Telegram.ReactionOptions do
@moduledoc """
Typed options for Telegram reaction operations.
"""
alias Jido.Chat.Telegram.Transport.ExGramClient
@schema Zoi.struct(
__MODULE__,
%{
token: Zoi.string() |> Zoi.nullish(),
transport: Zoi.any() |> Zoi.default(ExGramClient),
is_big: Zoi.boolean() |> Zoi.default(false),
debug: Zoi.boolean() |> Zoi.nullish(),
check_params: Zoi.boolean() |> Zoi.nullish(),
ex_gram_module: Zoi.any() |> Zoi.nullish(),
ex_gram_adapter: Zoi.any() |> Zoi.nullish()
},
coerce: true
)
@type t :: unquote(Zoi.type_spec(@schema))
@enforce_keys Zoi.Struct.enforce_keys(@schema)
defstruct Zoi.Struct.struct_fields(@schema)
@doc "Returns the Zoi schema for reaction options."
def schema, do: @schema
@doc "Builds typed reaction options from keyword, map, or struct input."
def new(%__MODULE__{} = opts), do: opts
def new(opts) when is_list(opts), do: opts |> Map.new() |> new()
def new(opts) when is_map(opts), do: Jido.Chat.Schema.parse!(__MODULE__, @schema, opts)
@doc "Builds Telegram API payload options for `setMessageReaction`."
@spec payload_opts(t()) :: map()
def payload_opts(%__MODULE__{} = opts), do: %{"is_big" => opts.is_big}
@doc "Builds transport-level options consumed by `ExGramClient`."
@spec transport_opts(t()) :: keyword()
def transport_opts(%__MODULE__{} = opts) do
[]
|> maybe_kw(:debug, opts.debug)
|> maybe_kw(:check_params, opts.check_params)
|> maybe_kw(:ex_gram_module, opts.ex_gram_module)
|> maybe_kw(:ex_gram_adapter, opts.ex_gram_adapter)
end
defp maybe_kw(keyword, _key, nil), do: keyword
defp maybe_kw(keyword, key, value), do: Keyword.put(keyword, key, value)
end