module Data.FpML.V53.Swaps.Return
( module Data.FpML.V53.Swaps.Return
, module Data.FpML.V53.Shared.EQ
) where
import Text.XML.HaXml.Schema.Schema (SchemaType(..),SimpleType(..),Extension(..),Restricts(..))
import Text.XML.HaXml.Schema.Schema as Schema
import Text.XML.HaXml.OneOfN
import qualified Text.XML.HaXml.Schema.PrimitiveTypes as Xsd
import Data.FpML.V53.Shared.EQ
data EquitySwapTransactionSupplement = EquitySwapTransactionSupplement
{ equitySwapTransSuppl_ID :: Maybe Xsd.ID
, equitySwapTransSuppl_primaryAssetClass :: Maybe AssetClass
, equitySwapTransSuppl_secondaryAssetClass :: [AssetClass]
, equitySwapTransSuppl_productType :: [ProductType]
, equitySwapTransSuppl_productId :: [ProductId]
, equitySwapTransSuppl_buyerPartyReference :: Maybe PartyReference
, equitySwapTransSuppl_buyerAccountReference :: Maybe AccountReference
, equitySwapTransSuppl_sellerPartyReference :: Maybe PartyReference
, equitySwapTransSuppl_sellerAccountReference :: Maybe AccountReference
, equitySwapTransSuppl_returnSwapLeg :: [DirectionalLeg]
, equitySwapTransSuppl_principalExchangeFeatures :: Maybe PrincipalExchangeFeatures
, equitySwapTransSuppl_choice10 :: (Maybe (OneOf2 Xsd.Boolean ((Maybe (Xsd.Boolean)),(Maybe (Xsd.Boolean)),(Maybe (FeeElectionEnum)),(Maybe (NonNegativeDecimal)))))
, equitySwapTransSuppl_choice11 :: (Maybe (OneOf2 Xsd.Boolean Xsd.Boolean))
, equitySwapTransSuppl_localJurisdiction :: Maybe CountryCode
, equitySwapTransSuppl_relevantJurisdiction :: Maybe CountryCode
, equitySwapTransSuppl_extraordinaryEvents :: Maybe ExtraordinaryEvents
}
deriving (Eq,Show)
instance SchemaType EquitySwapTransactionSupplement where
parseSchemaType s = do
(pos,e) <- posnElement [s]
a0 <- optional $ getAttribute "id" e pos
commit $ interior e $ return (EquitySwapTransactionSupplement a0)
`apply` optional (parseSchemaType "primaryAssetClass")
`apply` many (parseSchemaType "secondaryAssetClass")
`apply` many (parseSchemaType "productType")
`apply` many (parseSchemaType "productId")
`apply` optional (parseSchemaType "buyerPartyReference")
`apply` optional (parseSchemaType "buyerAccountReference")
`apply` optional (parseSchemaType "sellerPartyReference")
`apply` optional (parseSchemaType "sellerAccountReference")
`apply` between (Occurs (Just 0) (Just 2))
(elementReturnSwapLeg)
`apply` optional (parseSchemaType "principalExchangeFeatures")
`apply` optional (oneOf' [ ("Xsd.Boolean", fmap OneOf2 (parseSchemaType "mutualEarlyTermination"))
, ("Maybe Xsd.Boolean Maybe Xsd.Boolean Maybe FeeElectionEnum Maybe NonNegativeDecimal", fmap TwoOf2 (return (,,,) `apply` optional (parseSchemaType "optionalEarlyTermination")
`apply` optional (parseSchemaType "breakFundingRecovery")
`apply` optional (parseSchemaType "breakFeeElection")
`apply` optional (parseSchemaType "breakFeeRate")))
])
`apply` optional (oneOf' [ ("Xsd.Boolean", fmap OneOf2 (parseSchemaType "multipleExchangeIndexAnnexFallback"))
, ("Xsd.Boolean", fmap TwoOf2 (parseSchemaType "componentSecurityIndexAnnexFallback"))
])
`apply` optional (parseSchemaType "localJurisdiction")
`apply` optional (parseSchemaType "relevantJurisdiction")
`apply` optional (parseSchemaType "extraordinaryEvents")
schemaTypeToXML s x@EquitySwapTransactionSupplement{} =
toXMLElement s [ maybe [] (toXMLAttribute "id") $ equitySwapTransSuppl_ID x
]
[ maybe [] (schemaTypeToXML "primaryAssetClass") $ equitySwapTransSuppl_primaryAssetClass x
, concatMap (schemaTypeToXML "secondaryAssetClass") $ equitySwapTransSuppl_secondaryAssetClass x
, concatMap (schemaTypeToXML "productType") $ equitySwapTransSuppl_productType x
, concatMap (schemaTypeToXML "productId") $ equitySwapTransSuppl_productId x
, maybe [] (schemaTypeToXML "buyerPartyReference") $ equitySwapTransSuppl_buyerPartyReference x
, maybe [] (schemaTypeToXML "buyerAccountReference") $ equitySwapTransSuppl_buyerAccountReference x
, maybe [] (schemaTypeToXML "sellerPartyReference") $ equitySwapTransSuppl_sellerPartyReference x
, maybe [] (schemaTypeToXML "sellerAccountReference") $ equitySwapTransSuppl_sellerAccountReference x
, concatMap (elementToXMLReturnSwapLeg) $ equitySwapTransSuppl_returnSwapLeg x
, maybe [] (schemaTypeToXML "principalExchangeFeatures") $ equitySwapTransSuppl_principalExchangeFeatures x
, maybe [] (foldOneOf2 (schemaTypeToXML "mutualEarlyTermination")
(\ (a,b,c,d) -> concat [ maybe [] (schemaTypeToXML "optionalEarlyTermination") a
, maybe [] (schemaTypeToXML "breakFundingRecovery") b
, maybe [] (schemaTypeToXML "breakFeeElection") c
, maybe [] (schemaTypeToXML "breakFeeRate") d
])
) $ equitySwapTransSuppl_choice10 x
, maybe [] (foldOneOf2 (schemaTypeToXML "multipleExchangeIndexAnnexFallback")
(schemaTypeToXML "componentSecurityIndexAnnexFallback")
) $ equitySwapTransSuppl_choice11 x
, maybe [] (schemaTypeToXML "localJurisdiction") $ equitySwapTransSuppl_localJurisdiction x
, maybe [] (schemaTypeToXML "relevantJurisdiction") $ equitySwapTransSuppl_relevantJurisdiction x
, maybe [] (schemaTypeToXML "extraordinaryEvents") $ equitySwapTransSuppl_extraordinaryEvents x
]
instance Extension EquitySwapTransactionSupplement ReturnSwapBase where
supertype v = ReturnSwapBase_EquitySwapTransactionSupplement v
instance Extension EquitySwapTransactionSupplement Product where
supertype = (supertype :: ReturnSwapBase -> Product)
. (supertype :: EquitySwapTransactionSupplement -> ReturnSwapBase)
elementEquitySwapTransactionSupplement :: XMLParser EquitySwapTransactionSupplement
elementEquitySwapTransactionSupplement = parseSchemaType "equitySwapTransactionSupplement"
elementToXMLEquitySwapTransactionSupplement :: EquitySwapTransactionSupplement -> [Content ()]
elementToXMLEquitySwapTransactionSupplement = schemaTypeToXML "equitySwapTransactionSupplement"