Table of Contents

Namespace Payetools.Common.Model

Namespaces Classes

CountriesForTaxPurposesConverter

Converter that translates between the string format of countries based on ISO-3166 and CountriesForTaxPurposes enum values.

HmrcAccountsOfficeReference

Represents an HMRC Accounts Office Reference, as defined at https://design.tax.service.gov.uk/hmrc-design-patterns/accounts-office-reference/, which is formatted as follows:

  • 3 numbers
  • The letter 'P'
  • 8 numbers, or 7 numbers and the letter ‘X’
(from )
PayFrequencyExtensions

Extension methods for PayFrequency.

PayrollId

Represents a payroll ID (also known as a "worker ID", "payroll number", "works number") as reported to HMRC.

PostalAddress

Represents a postal address. If it is a UK address, Postcode should be supplied and ForeignCountry set to null; if the address is non-UK, then Postcode should be null and ForeignCountry should be provided.

TaxTreatmentExtensions

Extension methods for TaxTreatment.

TaxYear

Represents a given UK tax year, running from 6th April of a given year through to 5th April the following year.

TaxYearEndingExtensions

Extension methods for TaxYearEnding enum.

UkPostcode

Represents a UK Postcode.

Namespaces Structs

DateRange

Represents a date range.

HmrcPayeReference

Represents an HMRC PAYE Reference, as defined at https://design.tax.service.gov.uk/hmrc-design-patterns/employer-paye-reference/, which is formatted as follows:

  • 3 numbers
  • a forward slash ('/')
  • between 1 and 10 characters, which can be letters and numbers
NiNumber

Represents a Uk National Insurance number, also referred to as NI number or NINO. A NINO is made up of 2 letters, 6 numbers and a final letter which is always A, B, C or D. (See HMRC's National Insurance Manual, section NIM39110 (https://www.gov.uk/hmrc-internal-manuals/national-insurance-manual/nim39110.)

PayDate

Represents a specific pay date for a specific pay frequency.

TaxCode

Represents a UK tax code, with the ability to calculate tax-free pay based the code and the relevant tax period.

Title

Represents an individual's title (e.g., Mr., Mrs).

Namespaces Interfaces

IApplicableFromTill

Interface for reference data that indicates the period that a reference data applies for.

INamedPerson

Represents a named individual, i.e., a (usually living) person. This interface is provided for all the situations where a contact person is required, but is also the base entity for employees.

Namespaces Enums

CountriesForTaxPurposes

Represents one or more countries within the United Kingdom for tax purposes. For example, Scotland has had its own thresholds and rates of income tax since 2016. Note that this enum is marked with the [Flags} attribute as it is possible to combine countries for situations where the same set of tax parameters applies to more than one country, e.g. England and Northern Ireland.

Gender

Enum representing a person's gender. Note that HMRC only recognises the genders male and female for PAYE purposes, hence only two options (plus unknown) are provided.

NiCategory

Represents the set of National Insurance category letters assigned by HMRC. Taken from https://www.gov.uk/national-insurance-rates-letters/category-letters (retrieved 5-Dec-2022).

NormalHoursWorkedBand

Enumeration that is used to indicate a band of normal hours worked by an employee.

PayFrequency

Enumerated value for payment frequency.

PensionTaxTreatment

Enum that represents the tax treatment to be applied to employee pension contributions.

PensionsEarningsBasis

Represents the earnings basis which is used to calculate pension contributions.

StudentLoanType

Enum that represents a given type of student loan plan. Post-graduate loans are handled separately.

TaxTreatment

Enum representing the tax treatment aspect of the tax code.

TaxYearEnding

Enum representing a given tax year based on the last day of the tax year (i.e., 5 April 20xx).