{-# LANGUAGE DeriveLift #-}
module Data.Morpheus.Types.Internal.DataD
( TypeD(..)
, ConsD(..)
, QueryD(..)
, GQLTypeD(..)
) where
import Language.Haskell.TH.Syntax (Lift (..))
import Data.Morpheus.Types.Internal.Data (DataField, DataTypeKind)
data GQLTypeD = GQLTypeD
{ typeD :: TypeD
, typeKindD :: DataTypeKind
, typeArgD :: [TypeD]
} deriving (Show, Lift)
data QueryD = QueryD
{ queryText :: String
, queryTypes :: [TypeD]
, queryArgTypes :: [TypeD]
} deriving (Show, Lift)
data TypeD = TypeD
{ tName :: String
, tCons :: [ConsD]
} deriving (Show, Lift)
data ConsD = ConsD
{ cName :: String
, cFields :: [DataField]
} deriving (Show, Lift)