module Rattletrap.Type.Attribute.LoadoutsOnline where

import qualified Data.Map as Map
import qualified Rattletrap.BitGet as BitGet
import qualified Rattletrap.BitPut as BitPut
import qualified Rattletrap.Schema as Schema
import qualified Rattletrap.Type.Attribute.LoadoutOnline as LoadoutOnline
import qualified Rattletrap.Type.Str as Str
import qualified Rattletrap.Type.U32 as U32
import qualified Rattletrap.Type.Version as Version
import qualified Rattletrap.Utility.Json as Json

data LoadoutsOnline = LoadoutsOnline
  { LoadoutsOnline -> LoadoutOnline
blue :: LoadoutOnline.LoadoutOnline,
    LoadoutsOnline -> LoadoutOnline
orange :: LoadoutOnline.LoadoutOnline,
    LoadoutsOnline -> Bool
unknown1 :: Bool,
    LoadoutsOnline -> Bool
unknown2 :: Bool
  }
  deriving (LoadoutsOnline -> LoadoutsOnline -> Bool
(LoadoutsOnline -> LoadoutsOnline -> Bool)
-> (LoadoutsOnline -> LoadoutsOnline -> Bool) -> Eq LoadoutsOnline
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
$c== :: LoadoutsOnline -> LoadoutsOnline -> Bool
== :: LoadoutsOnline -> LoadoutsOnline -> Bool
$c/= :: LoadoutsOnline -> LoadoutsOnline -> Bool
/= :: LoadoutsOnline -> LoadoutsOnline -> Bool
Eq, Int -> LoadoutsOnline -> ShowS
[LoadoutsOnline] -> ShowS
LoadoutsOnline -> String
(Int -> LoadoutsOnline -> ShowS)
-> (LoadoutsOnline -> String)
-> ([LoadoutsOnline] -> ShowS)
-> Show LoadoutsOnline
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
$cshowsPrec :: Int -> LoadoutsOnline -> ShowS
showsPrec :: Int -> LoadoutsOnline -> ShowS
$cshow :: LoadoutsOnline -> String
show :: LoadoutsOnline -> String
$cshowList :: [LoadoutsOnline] -> ShowS
showList :: [LoadoutsOnline] -> ShowS
Show)

instance Json.FromJSON LoadoutsOnline where
  parseJSON :: Value -> Parser LoadoutsOnline
parseJSON = String
-> (Object -> Parser LoadoutsOnline)
-> Value
-> Parser LoadoutsOnline
forall a. String -> (Object -> Parser a) -> Value -> Parser a
Json.withObject String
"LoadoutsOnline" ((Object -> Parser LoadoutsOnline)
 -> Value -> Parser LoadoutsOnline)
-> (Object -> Parser LoadoutsOnline)
-> Value
-> Parser LoadoutsOnline
forall a b. (a -> b) -> a -> b
$ \Object
object -> do
    blue <- Object -> String -> Parser LoadoutOnline
forall value. FromJSON value => Object -> String -> Parser value
Json.required Object
object String
"blue"
    orange <- Json.required object "orange"
    unknown1 <- Json.required object "unknown1"
    unknown2 <- Json.required object "unknown2"
    pure LoadoutsOnline {blue, orange, unknown1, unknown2}

instance Json.ToJSON LoadoutsOnline where
  toJSON :: LoadoutsOnline -> Value
toJSON LoadoutsOnline
x =
    [(Key, Value)] -> Value
Json.object
      [ String -> LoadoutOnline -> (Key, Value)
forall value e p.
(ToJSON value, KeyValue e p) =>
String -> value -> p
Json.pair String
"blue" (LoadoutOnline -> (Key, Value)) -> LoadoutOnline -> (Key, Value)
forall a b. (a -> b) -> a -> b
$ LoadoutsOnline -> LoadoutOnline
blue LoadoutsOnline
x,
        String -> LoadoutOnline -> (Key, Value)
forall value e p.
(ToJSON value, KeyValue e p) =>
String -> value -> p
Json.pair String
"orange" (LoadoutOnline -> (Key, Value)) -> LoadoutOnline -> (Key, Value)
forall a b. (a -> b) -> a -> b
$ LoadoutsOnline -> LoadoutOnline
orange LoadoutsOnline
x,
        String -> Bool -> (Key, Value)
forall value e p.
(ToJSON value, KeyValue e p) =>
String -> value -> p
Json.pair String
"unknown1" (Bool -> (Key, Value)) -> Bool -> (Key, Value)
forall a b. (a -> b) -> a -> b
$ LoadoutsOnline -> Bool
unknown1 LoadoutsOnline
x,
        String -> Bool -> (Key, Value)
forall value e p.
(ToJSON value, KeyValue e p) =>
String -> value -> p
Json.pair String
"unknown2" (Bool -> (Key, Value)) -> Bool -> (Key, Value)
forall a b. (a -> b) -> a -> b
$ LoadoutsOnline -> Bool
unknown2 LoadoutsOnline
x
      ]

schema :: Schema.Schema
schema :: Schema
schema =
  String -> Value -> Schema
Schema.named String
"attribute-loadouts-online" (Value -> Schema) -> Value -> Schema
forall a b. (a -> b) -> a -> b
$
    [((Key, Value), Bool)] -> Value
Schema.object
      [ (String -> Value -> (Key, Value)
forall value e p.
(ToJSON value, KeyValue e p) =>
String -> value -> p
Json.pair String
"blue" (Value -> (Key, Value)) -> Value -> (Key, Value)
forall a b. (a -> b) -> a -> b
$ Schema -> Value
Schema.ref Schema
LoadoutOnline.schema, Bool
True),
        (String -> Value -> (Key, Value)
forall value e p.
(ToJSON value, KeyValue e p) =>
String -> value -> p
Json.pair String
"orange" (Value -> (Key, Value)) -> Value -> (Key, Value)
forall a b. (a -> b) -> a -> b
$ Schema -> Value
Schema.ref Schema
LoadoutOnline.schema, Bool
True),
        (String -> Value -> (Key, Value)
forall value e p.
(ToJSON value, KeyValue e p) =>
String -> value -> p
Json.pair String
"unknown1" (Value -> (Key, Value)) -> Value -> (Key, Value)
forall a b. (a -> b) -> a -> b
$ Schema -> Value
Schema.ref Schema
Schema.boolean, Bool
True),
        (String -> Value -> (Key, Value)
forall value e p.
(ToJSON value, KeyValue e p) =>
String -> value -> p
Json.pair String
"unknown2" (Value -> (Key, Value)) -> Value -> (Key, Value)
forall a b. (a -> b) -> a -> b
$ Schema -> Value
Schema.ref Schema
Schema.boolean, Bool
True)
      ]

bitPut :: LoadoutsOnline -> BitPut.BitPut
bitPut :: LoadoutsOnline -> BitPut
bitPut LoadoutsOnline
loadoutsOnlineAttribute =
  LoadoutOnline -> BitPut
LoadoutOnline.bitPut (LoadoutsOnline -> LoadoutOnline
blue LoadoutsOnline
loadoutsOnlineAttribute)
    BitPut -> BitPut -> BitPut
forall a. Semigroup a => a -> a -> a
<> LoadoutOnline -> BitPut
LoadoutOnline.bitPut (LoadoutsOnline -> LoadoutOnline
orange LoadoutsOnline
loadoutsOnlineAttribute)
    BitPut -> BitPut -> BitPut
forall a. Semigroup a => a -> a -> a
<> Bool -> BitPut
BitPut.bool (LoadoutsOnline -> Bool
unknown1 LoadoutsOnline
loadoutsOnlineAttribute)
    BitPut -> BitPut -> BitPut
forall a. Semigroup a => a -> a -> a
<> Bool -> BitPut
BitPut.bool (LoadoutsOnline -> Bool
unknown2 LoadoutsOnline
loadoutsOnlineAttribute)

bitGet ::
  Version.Version -> Map.Map U32.U32 Str.Str -> BitGet.BitGet LoadoutsOnline
bitGet :: Version -> Map U32 Str -> BitGet LoadoutsOnline
bitGet Version
version Map U32 Str
objectMap = String -> BitGet LoadoutsOnline -> BitGet LoadoutsOnline
forall a. String -> BitGet a -> BitGet a
BitGet.label String
"LoadoutsOnline" (BitGet LoadoutsOnline -> BitGet LoadoutsOnline)
-> BitGet LoadoutsOnline -> BitGet LoadoutsOnline
forall a b. (a -> b) -> a -> b
$ do
  blue <- String -> BitGet LoadoutOnline -> BitGet LoadoutOnline
forall a. String -> BitGet a -> BitGet a
BitGet.label String
"blue" (BitGet LoadoutOnline -> BitGet LoadoutOnline)
-> BitGet LoadoutOnline -> BitGet LoadoutOnline
forall a b. (a -> b) -> a -> b
$ Version -> Map U32 Str -> BitGet LoadoutOnline
LoadoutOnline.bitGet Version
version Map U32 Str
objectMap
  orange <- BitGet.label "orange" $ LoadoutOnline.bitGet version objectMap
  unknown1 <- BitGet.label "unknown1" BitGet.bool
  unknown2 <- BitGet.label "unknown2" BitGet.bool
  pure LoadoutsOnline {blue, orange, unknown1, unknown2}