bavan / eloquent-ifrs
Eloquent Double Entry Accounting with focus on IFRS Compliant Reporting
Installs: 2
Dependents: 0
Suggesters: 0
Security: 0
Stars: 0
Watchers: 0
Forks: 0
pkg:composer/bavan/eloquent-ifrs
Requires
- php: ^8.1
- doctrine/dbal: ^2.10|^3.1|^4.2
- illuminate/auth: ^10.0|^11.0|^12.0
- illuminate/database: ^10.0|^11.0|^12.0
Requires (Dev)
- laravel/legacy-factories: 1.x-dev|^1.4
- nunomaduro/collision: ^7.0
- orchestra/testbench: ^6.0|^7.0|^8.0|^10.0
- phpunit/phpunit: ^9.4|^11.5.3
- spatie/laravel-ignition: ^1.6.4|^2.0
- squizlabs/php_codesniffer: *
This package is auto-updated.
Last update: 2025-12-15 11:18:26 UTC
README
Eloquent IFRS
حسابداری دوطرفه و گزارشدهی IFRS برای Laravel
این پکیج یک سیستم حسابداری دفتردوبل کامل، چندشرکتی، چندارزی با گزارشهای استاندارد IFRS را به پروژههای لاراول اضافه میکند.
پشتیبانی از VAT، کنترل تغییرات، محافظت از دفترکل، و گزارشهای مالی حرفهای.
فهرست مطالب
- ویژگیها
- نصب
- پیکربندی
- شروع کار
- مثالهای عملی
- گزارشگیری
- گزارشهای میانی
- نقشه راه
- مشارکت
- لایسنس
- تغییرات نسخهها
ویژگیها
✔ پشتیبانی چندشرکتی (Entity)
✔ حسابداری دفتردوبل کامل
✔ حسابهای چندارزی + تفاوت نرخ ارز
✔ محافظت در برابر تغییرات مستقیم DB
✔ VAT ورودی، خروجی، ترکیبی
✔ گزارشهای کامل IFRS شامل:
- Income Statement
- Balance Sheet
- Cash Flow
- Trial Balance
✔ زمانبندی بدهکار/بستانکار (Aging)
✔ ثبتهای نقدی و اعتباری برای فروش/خرید
✔ گزارش Account Statement و Account Schedule
نصب
composer require "bavan/eloquent-ifrs"
php artisan migrate
اگر از Lumen استفاده میکنید:
$app->register(IFRS\IFRSServiceProvider::class);
پیکربندی
انتشار فایل config:
php artisan vendor:publish --provider="IFRS\IFRSServiceProvider"
این فایل ایجاد میشود:
config/ifrs.php
مهمترین تنظیمات
user_model→ مدل User پروژهlocales→ زبانهاforex_scale→ دقت نرخ ارزsingle_currency→ حسابهای محدود به یک ارزaging_schedule_brackets→ بازههای زمانی بدهکار/بستانکار- ساختار درآمد، هزینه، دارایی، بدهی، حقوق صاحبان سهام
- تنظیمات Cashflow
شروع کار
افزودن خصوصیات به مدل User:
use IFRS\Traits\IFRSUser; use IFRS\Traits\Recycling; class User extends Authenticatable { use IFRSUser, Recycling; }
مثالهای عملی
۱. ساخت شرکت و ارز
$entity = Entity::create(['name' => 'شرکت نمونه']); $currency = Currency::create([ 'name' => 'Euro', 'currency_code' => 'EUR' ]); $entity->currency_id = $currency->id; $entity->save();
۲. تعریف VAT
$outputVat = Vat::create([ 'name' => "Standard Output Vat", 'code' => "O", 'rate' => 20, 'account_id' => Account::create([ 'name' => "Sales VAT Account", 'account_type' => Account::CONTROL, ]) ]);
۳. تعریف حسابها
$bank = Account::create([ 'name' => "Bank Account", 'account_type' => Account::BANK, ]); $revenue = Account::create([ 'name' => "Sales Revenue", 'account_type' => Account::OPERATING_REVENUE, ]);
۴. ساخت دوره مالی
$period = ReportingPeriod::create([ 'period_count' => 1, 'calendar_year' => 2024, ]);
۵. ثبت فروش نقدی (Cash Sale)
$cashSale = CashSale::create([ 'account_id' => $bank->id, 'date' => now(), 'narration' => "Example Cash Sale", ]);
ایجاد Line Item
$item = LineItem::create([ 'account_id' => $revenue->id, 'narration' => "Sale Item", 'quantity' => 1, 'amount' => 100, ]); $item->addVat($outputVat); $cashSale->addLineItem($item); $cashSale->post(); // ثبت در دفتر کل
ثبتهای دیگر
$clientInvoice = ClientInvoice::create([...]); $cashPurchase = CashPurchase::create([...]); $supplierBill = SupplierBill::create([...]); $clientReceipt = ClientReceipt::create([...]);
تخصیص (Assignment)
Assignment::create([ 'assignment_date'=> now(), 'transaction_id' => $clientReceipt->id, 'cleared_id' => $clientInvoice->id, 'cleared_type'=> $clientInvoice->clearedType, 'amount' => 50, ]);
گزارشگیری
صورت سود و زیان (Income Statement)
$income = new IncomeStatement("2021-01-01","2021-12-31"); echo $income->toString();
ترازنامه (Balance Sheet)
$bs = new BalanceSheet("2021-12-31"); echo $bs->toString();
Cash Flow
$cf = new CashFlowStatement("2021-12-31");
گزارشهای میانی
Account Statement
$statement = new AccountStatement($clientAccount)->getTransactions();
Account Schedule
$schedule = new AccountSchedule($clientAccount, $currency)->getTransactions();
نقشه راه
- Cashflow Statement
- Laravel 8–12 Compatibility
- Multicurrency
- VAT پیشرفته
- گزارشهای تلفیقی
- پشتیبانی کامل لاراول 12+
- ماژول دارایی ثابت
لایسنس
انتشار تحت مجوز MIT.
تغییرات نسخهها
از CHANGELOG رسمی پکیج
- Laravel 12 Compatibility
- Laravel 11 Compatibility
- Attachments to Transactions
- Laravel 10 Compatibility
- Laravel 9 Compatibility
- Compound VAT
- Forex Difference هنگام تسویه
- Forex Translation
- پشتیبانی Lumen
- Cash Flow Statement
- گزارش Aging
- اصلاحات پایدار
legers:
post_account = حسابی که خودش Debit یا Credit میشود.
folio_account = حساب طرف مقابل.
entry_type = نوع بدهکار یا بستانکار بودن.
line_item_id = اگر برای آیتم خاص است، اینجاست؛ بانک همیشه null.
amount = مبلغ واقعی ثبتشده.
rate = نرخ ارز.
transaction_id = به کدام ClientReceipt/Invoice/Bill تعلق دارد.
post_account = حسابی که در همان Ledger در نقش D یا C قرار دارد
در پرداخت:
Ledger بانک → post_account = bank
Ledger آیتم → post_account = service/patientShare/etc
✔ folio_account = حساب طرف مقابل در همان ثبت دوبل
در پرداخت:
Ledger بانک → folio_account = account of first LineItem
Ledger آیتم → folio_account = bank