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
14 data Account = Account
15 { accountOwner :: Maybe Orga.EntityId
16 , accountScope :: Set (Set Scope)
17 , accountPCG :: Maybe PCG.PCG
19 deriving (Eq, Ord, Show, Generic, NFData)
22 { accountOwner = Nothing
24 , accountPCG = Nothing
27 newtype Ors a = Ors {ors :: Set a}
28 deriving (Eq, Ord, Show, Generic)
29 deriving newtype (NFData)
30 newtype Ands a = Ands {ands :: Set a}
31 deriving (Eq, Ord, Show, Generic)
32 deriving newtype (NFData)
33 data Boolean a = BooleanTrue a | BooleanFalse a
34 deriving (Eq, Ord, Show, Generic, NFData)
38 { metaCause :: Ands (Ors Cause)
39 , metaOwner :: Set Cause
41 deriving (Eq, Ord, Show, Generic, NFData)
45 { causeEntity :: Maybe Orga.EntityId
46 , causePeriod :: Maybe Period
47 , causeInvoice :: Maybe Invoice.InvoiceId
49 deriving (Eq, Ord, Show, Generic, NFData)
52 { causeEntity = Nothing
53 , causeInvoice = Nothing
54 , causePeriod = Nothing
59 { amountsEuro :: Amount 100 (UnitName "€")
61 deriving (Eq, Ord, Show, Generic, NFData)
62 instance FromRational Amounts where
63 fromRational r = Amounts{amountsEuro = fromRational r}
65 accounting :: [Movement Cause Account Amounts]
68 { moveDescription = ""
69 , moveDate = "2026-01-27"
70 , movePostings = equalPostings account{accountOwner = Just Orga.EntityUpwork} account{accountOwner = Just Orga.EntityJulmInfo} 174.30
74 { moveDescription = ""
75 , moveDate = "2026-01-28"
76 , movePostings = equalPostings account{accountOwner = Just Orga.EntityNixOSFoundationNGITeam} account{accountOwner = Just Orga.EntityJulmInfo} 2000.00
80 { moveDescription = ""
81 , moveDate = "2026-01-29"
82 , movePostings = equalPostings account{accountOwner = Just Orga.EntityNixOSFoundationNGITeam} account{accountOwner = Just Orga.EntityJulmInfo} 4643.75
86 { moveDescription = "Cotisation URSSAF"
89 { causeEntity = Just Orga.EntityUrssaf
90 , causePeriod = Just Period{periodBeginning = "2026-01-01", periodEnd = "2026-01-31"}
93 , moveDate = "2026-02-01"
96 { postingAccount = account{accountOwner = Just Orga.EntityJulmInfo}
97 , postingFlow = FlowOrigin 1691.00
101 { postingAccount = account{accountOwner = Just Orga.EntityUrssaf}
102 , postingFlow = FlowTarget 1677.00
106 { postingAccount = account{accountOwner = Just Orga.EntityUrssaf}
107 , postingFlow = FlowTarget 14.00