1 {-# LANGUAGE DeriveAnyClass #-}
2 {-# LANGUAGE OverloadedLists #-}
4 module Tests.Accounting where
6 import Literate.Accounting
7 import Literate.Accounting.PlanComptableGénéral qualified as PCG
8 import Literate.Invoice
9 import Literate.Organization
10 import Literate.Prelude
11 import Tests.Invoice qualified as Invoice
12 import Tests.Organization qualified as Orga
16 deriving (Eq, Ord, Show, Generic, NFData)
18 data Account = Account
19 { accountOwner :: Maybe Orga.EntityId
20 , accountScope :: Set (Set Scope)
21 , accountPCG :: Maybe PCG.PCG
23 deriving (Eq, Ord, Show, Generic, NFData)
26 { accountOwner = Nothing
28 , accountPCG = Nothing
31 newtype Ors a = Ors {ors :: Set a}
32 deriving (Eq, Ord, Show, Generic)
33 deriving newtype (NFData)
34 newtype Ands a = Ands {ands :: Set a}
35 deriving (Eq, Ord, Show, Generic)
36 deriving newtype (NFData)
37 data Boolean a = BooleanTrue a | BooleanFalse a
38 deriving (Eq, Ord, Show, Generic, NFData)
42 { metaCause :: Ands (Ors Cause)
43 , metaOwner :: Set Cause
45 deriving (Eq, Ord, Show, Generic, NFData)
49 { causeEntity :: Maybe Orga.EntityId
50 , causePeriod :: Maybe Period
51 , causeInvoice :: Maybe Invoice.InvoiceId
53 deriving (Eq, Ord, Show, Generic, NFData)
56 { causeEntity = Nothing
57 , causeInvoice = Nothing
58 , causePeriod = Nothing
63 { amountsEuro :: Amount 100 (UnitName "€")
65 deriving (Eq, Ord, Show, Generic, NFData)
66 instance FromRational Amounts where
67 fromRational r = Amounts{amountsEuro = fromRational r}
69 accounting :: [Movement Cause Account Amounts]
72 { moveDescription = ""
73 , moveDate = "2026-01-27"
74 , movePostings = equalPostings account{accountOwner = Just Orga.EntityUpwork} account{accountOwner = Just Orga.EntityJulmInfo} 174.30
78 { moveDescription = ""
79 , moveDate = "2026-01-28"
80 , movePostings = equalPostings account{accountOwner = Just Orga.EntityNixOSFoundationNGITeam} account{accountOwner = Just Orga.EntityJulmInfo} 2000.00
84 { moveDescription = ""
85 , moveDate = "2026-01-29"
86 , movePostings = equalPostings account{accountOwner = Just Orga.EntityNixOSFoundationNGITeam} account{accountOwner = Just Orga.EntityJulmInfo} 4643.75
90 { moveDescription = "Cotisation URSSAF"
93 { causeEntity = Just Orga.EntityUrssaf
94 , causePeriod = Just Period{periodBeginning = "2026-01-01", periodEnd = "2026-01-31"}
97 , moveDate = "2026-02-01"
100 { postingAccount = account{accountOwner = Just Orga.EntityJulmInfo}
101 , postingFlow = FlowOrigin 1691.00
105 { postingAccount = account{accountOwner = Just Orga.EntityUrssaf}
106 , postingFlow = FlowTarget 1677.00
110 { postingAccount = account{accountOwner = Just Orga.EntityUrssaf}
111 , postingFlow = FlowTarget 14.00