Eloquent Double Entry Accounting with a focus on IFRS Compliant Reporting

Published on by

Eloquent Double Entry Accounting with a focus on IFRS Compliant Reporting image

Eloquent IFRS is a package by Edward Mungai that provides “double-entry accounting with a focus on International Financial Reporting Standards (IFRS) compliant reporting.”

According to the documentation’s introduction, this package can help you generate compliant reports:

The Eloquent IFRS package gives any Laravel application or Lumen API the ability to generate a comprehensive set of financial reports by providing an embedded double-entry bookkeeping system.

The Accounting objects are created with a consistent and fluent interface, allowing seamless integration with the Business objects of the parent application.

Here’s a high-level example from the readme, which demonstrates some of the models:

use IFRS\Models\Account;
use IFRS\models\LineItem;
 
$bankAccount = new Account([
'name' => "Sales Account",
'account_type' => Account::BANK,
])->save();
 
// Intermediate save does not record the transaction in the Ledger
$cashSale = new CashSale([
'account_id' => $bankAccount->id,
'date' => Carbon::now(),
'narration' => "Example Cash Sale",
])->save();
 
// This posts the Transaction to the Ledger
$cashSaleLineItem = new LineItem([
'vat_id' => $outputVat->id,
'account_id' => $revenueAccount->id,
'vat_account_id' => $salesVatAccount->id,
'description' => "Example Cash Sale Line Item",
'quantity' => 1,
'amount' => 100,
])->save();
 
$cashSale->addLineItem($cashSaleLineItem);
$cashSale->post();

Here’s an example of an income report (profit and loss):

use IFRS\Reports\IncomeStatement;
 
$incomeStatement = new IncomeStatement(
"2020-01-01", // Report start date
"2020-12-31", // Report end date
)->getSections();// Fetch balances from the ledger and store them internally
 
/**
* this function is only for demonstration and
* debugging use and should never be called in production
*/
dd($incomeStatement->toString());
 
Example Company
Income Statement
For the Period: Jan 01 2020 to Dec 31 2020
 
Operating Revenues
Operating Revenue 200 (100 cash sales + 100 credit sales)
 
Operating Expenses
Operating Expense 100 (cash purchase)
---------------
Operations Gross Profit 100
 
Non Operating Revenues
Non Operating Revenue 0
---------------
Total Revenue 100
 
Non Operating Expenses
Direct Expense 0
Overhead Expense 0
Other Expense 0
---------------
Total Expenses 0
---------------
Net Profit 100
===============

All of the above examples come from the project readme, and is only a sample of what the package provides. The details of the package (and IFRS reporting) are quite intricate, and you should consult the full documentation.

I find this package unique because it’s created by a “finance guy turned developer.” It’s fantastic to see professionals in other industries turn to Laravel to develop ideas.

You can learn more about this package, get full installation instructions, and view the source code on GitHub at ekmungai/eloquent-ifrs.

Paul Redmond photo

Staff writer at Laravel News. Full stack web developer and author.

Filed in:
Cube

Laravel Newsletter

Join 40k+ other developers and never miss out on new tips, tutorials, and more.

image
Acquaint Softtech

Hire Laravel developers with AI expertise at $20/hr. Get started in 48 hours.

Visit Acquaint Softtech
Laravel Cloud logo

Laravel Cloud

Easily create and manage your servers and deploy your Laravel applications in seconds.

Laravel Cloud
SaaSykit: Laravel SaaS Starter Kit logo

SaaSykit: Laravel SaaS Starter Kit

SaaSykit is a Multi-tenant Laravel SaaS Starter Kit that comes with all features required to run a modern SaaS. Payments, Beautiful Checkout, Admin Panel, User dashboard, Auth, Ready Components, Stats, Blog, Docs and more.

SaaSykit: Laravel SaaS Starter Kit
PhpStorm logo

PhpStorm

The go-to PHP IDE with extensive out-of-the-box support for Laravel and its ecosystem.

PhpStorm
No Compromises logo

No Compromises

Joel and Aaron, the two seasoned devs from the No Compromises podcast, are now available to hire for your Laravel project. ⬧ Flat rate of $9500/mo. ⬧ No lengthy sales process. ⬧ No contracts. ⬧ 100% money back guarantee.

No Compromises
Kirschbaum logo

Kirschbaum

Providing innovation and stability to ensure your web application succeeds.

Kirschbaum
Harpoon: Next generation time tracking and invoicing logo

Harpoon: Next generation time tracking and invoicing

The next generation time-tracking and billing software that helps your agency plan and forecast a profitable future.

Harpoon: Next generation time tracking and invoicing
Acquaint Softtech logo

Acquaint Softtech

Acquaint Softtech offers AI-ready Laravel developers who onboard in 48 hours at $3000/Month with no lengthy sales process and a 100 percent money-back guarantee.

Acquaint Softtech
Tinkerwell logo

Tinkerwell

The must-have code runner for Laravel developers. Tinker with AI, autocompletion and instant feedback on local and production environments.

Tinkerwell
Shift logo

Shift

Running an old Laravel version? Instant, automated Laravel upgrades and code modernization to keep your applications fresh.

Shift
Lucky Media logo

Lucky Media

Get Lucky Now - the ideal choice for Laravel Development, with over a decade of experience!

Lucky Media

The latest

View all →
Monitor Laravel Queues, Commands, and Schedulers on Any Driver with Vigilance image

Monitor Laravel Queues, Commands, and Schedulers on Any Driver with Vigilance

Read article
Watch the Teaser for 'The Story of PHP' Documentary image

Watch the Teaser for 'The Story of PHP' Documentary

Read article
Ship AI with Laravel: Give Your AI Agent Live Web Search image

Ship AI with Laravel: Give Your AI Agent Live Web Search

Read article
Lattice: Describe Inertia UIs in PHP image

Lattice: Describe Inertia UIs in PHP

Read article
How We Cached Laravel News at the Edge with Fast Laravel image

How We Cached Laravel News at the Edge with Fast Laravel

Read article
The artisan dev Command in Laravel 13.16.0 image

The artisan dev Command in Laravel 13.16.0

Read article