crux_structs v0.2.3 Crux.Structs.Member View Source
Represents a Discord Guild Member Object.
Differences opposed to the Discord API Object:
:useris just the user id
Link to this section Summary
Functions
Creates a t:Crux.Structs.Member.t/0 struct from raw data.
Resolves the id of a t:Crux.Structs.Member.t/0.
Converts a t:Crux.Structs.Member.t/0 into its discord mention format.
Link to this section Types
Specs
id_resolvable() :: Crux.Structs.User.id_resolvable()
All available types that can be resolved into a user id.
Specs
t() :: %Crux.Structs.Member{
deaf: boolean() | nil,
guild_id: Crux.Structs.Snowflake.t() | nil,
joined_at: String.t(),
mute: boolean() | nil,
nick: String.t() | nil,
premium_since: String.t() | nil,
roles: MapSet.t(Crux.Structs.Snowflake.t()),
user: Crux.Structs.Snowflake.t()
}
Link to this section Functions
Specs
Creates a t:Crux.Structs.Member.t/0 struct from raw data.
Automatically invoked by
Crux.Structs.create/2.
Specs
resolve_id(id_resolvable()) :: Crux.Structs.Snowflake.t() | nil
Resolves the id of a t:Crux.Structs.Member.t/0.
Automatically invoked by
Crux.Structs.resolve_id/2.
iex> %Crux.Structs.Member{user: 218348062828003328}
...> |> Crux.Structs.Member.resolve_id()
218348062828003328For more examples see Crux.Structs.User.resolve_id/1.
Specs
to_mention(user :: Crux.Structs.Member.t()) :: String.t()
Converts a t:Crux.Structs.Member.t/0 into its discord mention format.
Examples
# Without nickname
iex> %Crux.Structs.Member{user: 218348062828003328, nick: nil}
...> |> Crux.Structs.Member.to_mention()
"<@218348062828003328>"
# With nickname
iex> %Crux.Structs.Member{user: 218348062828003328, nick: "weltraum"}
...> |> Crux.Structs.Member.to_mention()
"<@!218348062828003328>"