{-# LANGUAGE TemplateHaskell #-}

-- | Updated messages
module Calamity.Types.Model.Channel.UpdatedMessage (
  UpdatedMessage (..),
) where

import Calamity.Internal.Utils
import Calamity.Types.Model.Channel
import Calamity.Types.Model.Guild.Role
import Calamity.Types.Model.User
import Calamity.Types.Snowflake
import Data.Aeson ((.:), (.:!), (.:?))
import qualified Data.Aeson as Aeson
import Data.Text (Text)
import Data.Time
import qualified Data.Vector.Unboxing as UV
import Data.Word
import Optics.TH
import qualified TextShow

data UpdatedMessage = UpdatedMessage
  { UpdatedMessage -> Snowflake Message
id :: Snowflake Message
  , UpdatedMessage -> Snowflake Channel
channelID :: Snowflake Channel
  , UpdatedMessage -> Maybe Text
content :: Maybe Text
  , UpdatedMessage -> Maybe (MaybeNull UTCTime)
editedTimestamp :: Maybe (MaybeNull UTCTime)
  , UpdatedMessage -> Maybe Bool
tts :: Maybe Bool
  , UpdatedMessage -> Maybe Bool
mentionEveryone :: Maybe Bool
  , UpdatedMessage -> Maybe [User]
mentions :: Maybe [User]
  , UpdatedMessage -> Maybe (Vector (Snowflake Role))
mentionRoles :: Maybe (UV.Vector (Snowflake Role))
  , UpdatedMessage -> Maybe [ChannelMention]
mentionChannels :: Maybe [ChannelMention]
  , UpdatedMessage -> Maybe [Attachment]
attachments :: Maybe [Attachment]
  , UpdatedMessage -> Maybe [Embed]
embeds :: Maybe [Embed]
  , UpdatedMessage -> Maybe [Reaction]
reactions :: Maybe [Reaction]
  , UpdatedMessage -> Maybe Bool
pinned :: Maybe Bool
  , UpdatedMessage -> Maybe MessageType
type_ :: Maybe MessageType
  , UpdatedMessage -> Maybe (MaybeNull Object)
activity :: Maybe (MaybeNull Aeson.Object)
  , UpdatedMessage -> Maybe (MaybeNull Object)
application :: Maybe (MaybeNull Aeson.Object)
  , UpdatedMessage -> Maybe (MaybeNull MessageReference)
messageReference :: Maybe (MaybeNull MessageReference)
  , UpdatedMessage -> Maybe Word64
flags :: Maybe Word64
  , UpdatedMessage -> Maybe (MaybeNull Message)
referencedMessage :: Maybe (MaybeNull Message)
  , UpdatedMessage -> Maybe (MaybeNull Object)
interaction :: Maybe (MaybeNull Aeson.Object)
  , UpdatedMessage -> Maybe [Component]
components :: Maybe [Component]
  }
  deriving (Int -> UpdatedMessage -> ShowS
[UpdatedMessage] -> ShowS
UpdatedMessage -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [UpdatedMessage] -> ShowS
$cshowList :: [UpdatedMessage] -> ShowS
show :: UpdatedMessage -> String
$cshow :: UpdatedMessage -> String
showsPrec :: Int -> UpdatedMessage -> ShowS
$cshowsPrec :: Int -> UpdatedMessage -> ShowS
Show)
  deriving (Int -> UpdatedMessage -> Builder
Int -> UpdatedMessage -> Text
Int -> UpdatedMessage -> Text
[UpdatedMessage] -> Builder
[UpdatedMessage] -> Text
[UpdatedMessage] -> Text
UpdatedMessage -> Builder
UpdatedMessage -> Text
UpdatedMessage -> Text
forall a.
(Int -> a -> Builder)
-> (a -> Builder)
-> ([a] -> Builder)
-> (Int -> a -> Text)
-> (a -> Text)
-> ([a] -> Text)
-> (Int -> a -> Text)
-> (a -> Text)
-> ([a] -> Text)
-> TextShow a
showtlList :: [UpdatedMessage] -> Text
$cshowtlList :: [UpdatedMessage] -> Text
showtl :: UpdatedMessage -> Text
$cshowtl :: UpdatedMessage -> Text
showtlPrec :: Int -> UpdatedMessage -> Text
$cshowtlPrec :: Int -> UpdatedMessage -> Text
showtList :: [UpdatedMessage] -> Text
$cshowtList :: [UpdatedMessage] -> Text
showt :: UpdatedMessage -> Text
$cshowt :: UpdatedMessage -> Text
showtPrec :: Int -> UpdatedMessage -> Text
$cshowtPrec :: Int -> UpdatedMessage -> Text
showbList :: [UpdatedMessage] -> Builder
$cshowbList :: [UpdatedMessage] -> Builder
showb :: UpdatedMessage -> Builder
$cshowb :: UpdatedMessage -> Builder
showbPrec :: Int -> UpdatedMessage -> Builder
$cshowbPrec :: Int -> UpdatedMessage -> Builder
TextShow.TextShow) via TextShow.FromStringShow UpdatedMessage
  deriving (HasID Message) via HasIDField "id" UpdatedMessage
  deriving (HasID Channel) via HasIDField "channelID" UpdatedMessage

instance Aeson.FromJSON UpdatedMessage where
  parseJSON :: Value -> Parser UpdatedMessage
parseJSON = forall a. String -> (Object -> Parser a) -> Value -> Parser a
Aeson.withObject String
"UpdatedMessage" forall a b. (a -> b) -> a -> b
$ \Object
v ->
    Snowflake Message
-> Snowflake Channel
-> Maybe Text
-> Maybe (MaybeNull UTCTime)
-> Maybe Bool
-> Maybe Bool
-> Maybe [User]
-> Maybe (Vector (Snowflake Role))
-> Maybe [ChannelMention]
-> Maybe [Attachment]
-> Maybe [Embed]
-> Maybe [Reaction]
-> Maybe Bool
-> Maybe MessageType
-> Maybe (MaybeNull Object)
-> Maybe (MaybeNull Object)
-> Maybe (MaybeNull MessageReference)
-> Maybe Word64
-> Maybe (MaybeNull Message)
-> Maybe (MaybeNull Object)
-> Maybe [Component]
-> UpdatedMessage
UpdatedMessage
      forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> Object
v forall a. FromJSON a => Object -> Key -> Parser a
.: Key
"id"
      forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
<*> Object
v forall a. FromJSON a => Object -> Key -> Parser a
.: Key
"channel_id"
      forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
<*> Object
v forall a. FromJSON a => Object -> Key -> Parser (Maybe a)
.:? Key
"content"
      forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
<*> Object
v forall a. FromJSON a => Object -> Key -> Parser (Maybe a)
.:! Key
"edited_timestamp"
      forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
<*> Object
v forall a. FromJSON a => Object -> Key -> Parser (Maybe a)
.:? Key
"tts"
      forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
<*> Object
v forall a. FromJSON a => Object -> Key -> Parser (Maybe a)
.:? Key
"mention_everyone"
      forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
<*> Object
v forall a. FromJSON a => Object -> Key -> Parser (Maybe a)
.:? Key
"mentions"
      forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
<*> (forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
fmap forall a. AesonVector a -> Vector a
unAesonVector forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> Object
v forall a. FromJSON a => Object -> Key -> Parser (Maybe a)
.:? Key
"mention_roles")
      forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
<*> Object
v forall a. FromJSON a => Object -> Key -> Parser (Maybe a)
.:? Key
"mention_channels"
      forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
<*> Object
v forall a. FromJSON a => Object -> Key -> Parser (Maybe a)
.:? Key
"attachments"
      forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
<*> Object
v forall a. FromJSON a => Object -> Key -> Parser (Maybe a)
.:? Key
"embeds"
      forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
<*> Object
v forall a. FromJSON a => Object -> Key -> Parser (Maybe a)
.:? Key
"reactions"
      forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
<*> Object
v forall a. FromJSON a => Object -> Key -> Parser (Maybe a)
.:? Key
"pinned"
      forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
<*> Object
v forall a. FromJSON a => Object -> Key -> Parser (Maybe a)
.:? Key
"type"
      forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
<*> Object
v forall a. FromJSON a => Object -> Key -> Parser (Maybe a)
.:! Key
"activity"
      forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
<*> Object
v forall a. FromJSON a => Object -> Key -> Parser (Maybe a)
.:! Key
"application"
      forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
<*> Object
v forall a. FromJSON a => Object -> Key -> Parser (Maybe a)
.:! Key
"message_reference"
      forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
<*> Object
v forall a. FromJSON a => Object -> Key -> Parser (Maybe a)
.:? Key
"flags"
      forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
<*> Object
v forall a. FromJSON a => Object -> Key -> Parser (Maybe a)
.:! Key
"referenced_message"
      forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
<*> Object
v forall a. FromJSON a => Object -> Key -> Parser (Maybe a)
.:! Key
"interaction"
      forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
<*> Object
v forall a. FromJSON a => Object -> Key -> Parser (Maybe a)
.:? Key
"components"

$(makeFieldLabelsNoPrefix ''UpdatedMessage)