bavan/eloquent-ifrs 问题修复 & 功能扩展

解决BUG、新增功能、兼容多环境部署,快速响应你的开发需求

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

bavan/eloquent-ifrs

最新稳定版本:1.0.1

Composer 安装命令:

composer require bavan/eloquent-ifrs

包简介

Eloquent Double Entry Accounting with focus on IFRS Compliant Reporting

README 文档

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

统计信息

  • 总下载量: 8
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 0
  • 点击次数: 3
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 0
  • Watchers: 0
  • Forks: 0
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2025-12-15

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固