module TD.Query.GetChatMessagePosition
  (GetChatMessagePosition(..)
  , defaultGetChatMessagePosition
  ) where

import qualified Data.Aeson as A
import qualified Data.Aeson.Types as AT
import qualified TD.Lib.Internal as I
import qualified TD.Data.MessageTopic as MessageTopic
import qualified TD.Data.SearchMessagesFilter as SearchMessagesFilter

-- | Returns approximate 1-based position of a message among messages, which can be found by the specified filter in the chat and topic. Cannot be used in secret chats. Returns 'TD.Data.Count.Count'
data GetChatMessagePosition
  = GetChatMessagePosition
    { GetChatMessagePosition -> Maybe Int
chat_id    :: Maybe Int                                       -- ^ Identifier of the chat in which to find message position
    , GetChatMessagePosition -> Maybe MessageTopic
topic_id   :: Maybe MessageTopic.MessageTopic                 -- ^ Pass topic identifier to get position among messages only in specific topic; pass null to get position among all chat messages
    , GetChatMessagePosition -> Maybe SearchMessagesFilter
_filter    :: Maybe SearchMessagesFilter.SearchMessagesFilter -- ^ Filter for message content; searchMessagesFilterEmpty, searchMessagesFilterUnreadMention, searchMessagesFilterUnreadReaction, and searchMessagesFilterFailedToSend are unsupported in this function
    , GetChatMessagePosition -> Maybe Int
message_id :: Maybe Int                                       -- ^ Message identifier
    }
  deriving (GetChatMessagePosition -> GetChatMessagePosition -> Bool
(GetChatMessagePosition -> GetChatMessagePosition -> Bool)
-> (GetChatMessagePosition -> GetChatMessagePosition -> Bool)
-> Eq GetChatMessagePosition
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
$c== :: GetChatMessagePosition -> GetChatMessagePosition -> Bool
== :: GetChatMessagePosition -> GetChatMessagePosition -> Bool
$c/= :: GetChatMessagePosition -> GetChatMessagePosition -> Bool
/= :: GetChatMessagePosition -> GetChatMessagePosition -> Bool
Eq, Int -> GetChatMessagePosition -> ShowS
[GetChatMessagePosition] -> ShowS
GetChatMessagePosition -> String
(Int -> GetChatMessagePosition -> ShowS)
-> (GetChatMessagePosition -> String)
-> ([GetChatMessagePosition] -> ShowS)
-> Show GetChatMessagePosition
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
$cshowsPrec :: Int -> GetChatMessagePosition -> ShowS
showsPrec :: Int -> GetChatMessagePosition -> ShowS
$cshow :: GetChatMessagePosition -> String
show :: GetChatMessagePosition -> String
$cshowList :: [GetChatMessagePosition] -> ShowS
showList :: [GetChatMessagePosition] -> ShowS
Show)

instance I.ShortShow GetChatMessagePosition where
  shortShow :: GetChatMessagePosition -> String
shortShow
    GetChatMessagePosition
      { chat_id :: GetChatMessagePosition -> Maybe Int
chat_id    = Maybe Int
chat_id_
      , topic_id :: GetChatMessagePosition -> Maybe MessageTopic
topic_id   = Maybe MessageTopic
topic_id_
      , _filter :: GetChatMessagePosition -> Maybe SearchMessagesFilter
_filter    = Maybe SearchMessagesFilter
_filter_
      , message_id :: GetChatMessagePosition -> Maybe Int
message_id = Maybe Int
message_id_
      }
        = String
"GetChatMessagePosition"
          String -> ShowS
forall a. [a] -> [a] -> [a]
++ [String] -> String
I.cc
          [ String
"chat_id"    String -> Maybe Int -> String
forall a. ShortShow a => String -> Maybe a -> String
`I.p` Maybe Int
chat_id_
          , String
"topic_id"   String -> Maybe MessageTopic -> String
forall a. ShortShow a => String -> Maybe a -> String
`I.p` Maybe MessageTopic
topic_id_
          , String
"_filter"    String -> Maybe SearchMessagesFilter -> String
forall a. ShortShow a => String -> Maybe a -> String
`I.p` Maybe SearchMessagesFilter
_filter_
          , String
"message_id" String -> Maybe Int -> String
forall a. ShortShow a => String -> Maybe a -> String
`I.p` Maybe Int
message_id_
          ]

instance AT.ToJSON GetChatMessagePosition where
  toJSON :: GetChatMessagePosition -> Value
toJSON
    GetChatMessagePosition
      { chat_id :: GetChatMessagePosition -> Maybe Int
chat_id    = Maybe Int
chat_id_
      , topic_id :: GetChatMessagePosition -> Maybe MessageTopic
topic_id   = Maybe MessageTopic
topic_id_
      , _filter :: GetChatMessagePosition -> Maybe SearchMessagesFilter
_filter    = Maybe SearchMessagesFilter
_filter_
      , message_id :: GetChatMessagePosition -> Maybe Int
message_id = Maybe Int
message_id_
      }
        = [Pair] -> Value
A.object
          [ Key
"@type"      Key -> Value -> Pair
forall kv v. (KeyValue kv, ToJSON v) => Key -> v -> kv
forall v. ToJSON v => Key -> v -> Pair
A..= Text -> Value
AT.String Text
"getChatMessagePosition"
          , Key
"chat_id"    Key -> Maybe Int -> Pair
forall kv v. (KeyValue kv, ToJSON v) => Key -> v -> kv
forall v. ToJSON v => Key -> v -> Pair
A..= Maybe Int
chat_id_
          , Key
"topic_id"   Key -> Maybe MessageTopic -> Pair
forall kv v. (KeyValue kv, ToJSON v) => Key -> v -> kv
forall v. ToJSON v => Key -> v -> Pair
A..= Maybe MessageTopic
topic_id_
          , Key
"filter"     Key -> Maybe SearchMessagesFilter -> Pair
forall kv v. (KeyValue kv, ToJSON v) => Key -> v -> kv
forall v. ToJSON v => Key -> v -> Pair
A..= Maybe SearchMessagesFilter
_filter_
          , Key
"message_id" Key -> Maybe Int -> Pair
forall kv v. (KeyValue kv, ToJSON v) => Key -> v -> kv
forall v. ToJSON v => Key -> v -> Pair
A..= Maybe Int
message_id_
          ]

defaultGetChatMessagePosition :: GetChatMessagePosition
defaultGetChatMessagePosition :: GetChatMessagePosition
defaultGetChatMessagePosition =
  GetChatMessagePosition
    { chat_id :: Maybe Int
chat_id    = Maybe Int
forall a. Maybe a
Nothing
    , topic_id :: Maybe MessageTopic
topic_id   = Maybe MessageTopic
forall a. Maybe a
Nothing
    , _filter :: Maybe SearchMessagesFilter
_filter    = Maybe SearchMessagesFilter
forall a. Maybe a
Nothing
    , message_id :: Maybe Int
message_id = Maybe Int
forall a. Maybe a
Nothing
    }