承接 whilesmart/eloquent-expenses 相关项目开发

从需求分析到上线部署,全程专人跟进,保证项目质量与交付效率

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

whilesmart/eloquent-expenses

Composer 安装命令:

composer require whilesmart/eloquent-expenses

包简介

Polymorphic expense tracking for Laravel applications.

README 文档

README

Polymorphic expense tracking for Laravel. Money-out counterpart to whilesmart/eloquent-invoices.

Install

composer require whilesmart/eloquent-expenses
php artisan migrate

Attach HasExpenses to the model that owns expenses (workspace / organisation / user):

use Whilesmart\Expenses\Traits\HasExpenses;

class Workspace extends Model
{
    use HasExpenses;
}

Attach IsVendor to any model that can be a vendor:

use Whilesmart\Expenses\Contracts\Vendor;
use Whilesmart\Expenses\Traits\IsVendor;

class Supplier extends Model implements Vendor
{
    use IsVendor;
}

Data model

Two polymorphic relations plus a vendor name snapshot:

  • owner -- who the expense is booked against (required).
  • vendor -- who was paid, optional polymorphic link (vendor_type + vendor_id).
  • vendor_name -- snapshot string; used when there is no linked record, or to preserve the display name at entry time so future vendor renames don't mutate history.

Other fields: number, category, description, amount_cents, tax_cents, total_cents, currency, status (draft | submitted | approved | paid | rejected), payment_method, incurred_at, paid_at, receipt_url, notes, metadata.

Routes

Registers an apiResource at the configured prefix (default api, middleware ['api', 'auth:sanctum']):

GET    /api/expenses
POST   /api/expenses
GET    /api/expenses/{expense}
PUT    /api/expenses/{expense}
DELETE /api/expenses/{expense}

Index filters: owner_type, owner_id, vendor_type, vendor_id, status, category, from, to, q, per_page.

Relationship to other packages

  • whilesmart/eloquent-invoices -- invoices are money in; expenses are money out. Same polymorphic owner pattern.
  • whilesmart/eloquent-payments (sibling package) -- when you settle an expense through a gateway, record a Payment against the expense. payment_method on the expense is a summary; Payment records are the audit trail.
  • whilesmart/eloquent-customers / eloquent-organizations -- typical models that would implement Vendor.

Config

php artisan vendor:publish --tag=expenses-config:

return [
    'register_routes' => env('EXPENSES_REGISTER_ROUTES', true),
    'route_prefix' => env('EXPENSES_ROUTE_PREFIX', 'api'),
    'route_middleware' => ['api', 'auth:sanctum'],
    'table' => env('EXPENSES_TABLE', 'expenses'),
];

统计信息

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

GitHub 信息

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

其他信息

  • 授权协议: MIT
  • 更新时间: 2026-04-24

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固