[{"data":1,"prerenderedAt":-1},["ShallowReactive",2],{"project-8191":3},{"id":4,"name":5,"fullName":6,"owner":5,"repo":5,"description":7,"homepage":8,"htmlUrl":9,"language":10,"languages":9,"totalLinesOfCode":9,"stars":11,"forks":12,"watchers":13,"openIssues":14,"contributorsCount":15,"subscribersCount":15,"size":15,"stars1d":16,"stars7d":17,"stars30d":18,"stars90d":15,"forks30d":15,"starsTrendScore":19,"compositeScore":20,"rankGlobal":9,"rankLanguage":9,"license":21,"archived":22,"fork":22,"defaultBranch":23,"hasWiki":24,"hasPages":22,"topics":25,"createdAt":9,"pushedAt":9,"updatedAt":41,"readmeContent":42,"aiSummary":43,"trendingCount":15,"starSnapshotCount":15,"syncStatus":44,"lastSyncTime":45,"discoverSource":46},8191,"invoiceninja","invoiceninja\u002Finvoiceninja","A source-available invoice, quote, project and time-tracking app built with Laravel","https:\u002F\u002Finvoiceninja.com",null,"PHP",9815,2648,212,904,0,4,21,90,20,93.5,"Other",false,"v5-stable",true,[26,27,28,29,30,5,31,32,33,34,35,36,37,38,39,40],"einvoicing","expenses","flutter","hacktoberfest","invoice","invoices","javascript","kanban","laravel","payments","php","projects","quotes","tasks","time-tracker","2026-06-12 04:00:38","\u003Cp align=\"center\">\n\u003Ca href =\"https:\u002F\u002Fwww.youtube.com\u002Fwatch?v=CxGxXiotv0I\" target=\"_blank\" title=\"Invoice Ninja Overview Video\">\u003Cimg src=\"https:\u002F\u002Fraw.githubusercontent.com\u002Fhillelcoren\u002Finvoice-ninja\u002Fmaster\u002Fpublic\u002Fimages\u002Fround_logo.png\" alt=\"Sublime's custom image\"\u002F>\u003C\u002Fa>\n\u003C\u002Fp>\n\n![v5-develop phpunit](https:\u002F\u002Fgithub.com\u002Finvoiceninja\u002Finvoiceninja\u002Fworkflows\u002Fphpunit\u002Fbadge.svg?branch=v5-develop)\n[![Codacy Badge](https:\u002F\u002Fapp.codacy.com\u002Fproject\u002Fbadge\u002FGrade\u002Fd16c78aad8574466bf83232b513ef4fb)](https:\u002F\u002Fwww.codacy.com\u002Fgh\u002Fturbo124\u002Finvoiceninja\u002Fdashboard?utm_source=github.com&amp;utm_medium=referral&amp;utm_content=turbo124\u002Finvoiceninja&amp;utm_campaign=Badge_Grade)\n\u003Ca href=\"https:\u002F\u002Fcla-assistant.io\u002Finvoiceninja\u002Finvoiceninja\">\u003Cimg src=\"https:\u002F\u002Fcla-assistant.io\u002Freadme\u002Fbadge\u002Finvoiceninja\u002Finvoiceninja\" alt=\"CLA assistant\" \u002F>\u003C\u002Fa>\n\n# Invoice Ninja 5\n\nInvoice Ninja Version 5 is here! We've taken the best parts of version 4 and added the most requested features to create an invoicing application like no other. Check the [Invoice Ninja YouTube Channel](https:\u002F\u002Fwww.youtube.com\u002F@appinvoiceninja) to get up to speed, or try the [Demo](https:\u002F\u002Freact.invoicing.co\u002Fdemo) now.\n\n**Choose your setup**\n\n- [Hosted](https:\u002F\u002Fwww.invoiceninja.com): Our hosted version is a Software as a Service (SaaS) solution. You're up and running in under 5 minutes, with no need to worry about hosting or server infrastructure.\n- [Self-Hosted](https:\u002F\u002Fwww.invoiceninja.org): For those who prefer to manage their own hosting and server infrastructure. This version gives you full control and flexibility.\n\nAll Pro and Enterprise features from the hosted app are included in the source-available code. We offer a $40 per year white-label license to remove the Invoice Ninja branding from client-facing parts of the app.\n\n#### Get social with us\n\n* [Support Forum](https:\u002F\u002Fforum.invoiceninja.com)\n* [Slack](http:\u002F\u002Fslack.invoiceninja.com)\n* [Discord](https:\u002F\u002Fdiscord.gg\u002FZwEdtfCwXA)\n* [Instagram](https:\u002F\u002Fwww.instagram.com\u002Fappinvoiceninja)\n\n#### Documentation\n\n* [Invoice Ninja - API](https:\u002F\u002Fapi-docs.invoicing.co\u002F)\n* [Invoice Ninja - Developer Guide](https:\u002F\u002Finvoiceninja.github.io\u002Fen\u002Fdeveloper-guide\u002F)\n* [Invoice Ninja - User Guide](https:\u002F\u002Finvoiceninja.github.io\u002Fen\u002Fuser-guide\u002F)\n* [Invoice Ninja - Self-Hosted Installation Guide](https:\u002F\u002Finvoiceninja.github.io\u002Fen\u002Fself-host-installation\u002F)\n\n## Installation Options and Clients\n\n### Mobile Apps\n* [iPhone](https:\u002F\u002Fapps.apple.com\u002Fapp\u002Fid1503970375?platform=iphone)\n* [Android](https:\u002F\u002Fplay.google.com\u002Fstore\u002Fapps\u002Fdetails?id=com.invoiceninja.app)\n* [F-Droid](https:\u002F\u002Ff-droid.org\u002Fen\u002Fpackages\u002Fcom.invoiceninja.app)\n\n### Desktop Apps\n* [macOS](https:\u002F\u002Fapps.apple.com\u002Fapp\u002Fid1503970375?platform=mac)\n* [Windows](https:\u002F\u002Fmicrosoft.com\u002Fen-us\u002Fp\u002Finvoice-ninja\u002F9n3f2bbcfdr6)\n* [Linux - Snap](https:\u002F\u002Fsnapcraft.io\u002Finvoiceninja)\n* [Linux - Flatpak](https:\u002F\u002Fflathub.org\u002Fapps\u002Fcom.invoiceninja.InvoiceNinja)\n\n### Self-Hosted Server Installation \n**Note:** The self-hosted options do support the desktop and mobile apps.\n\n* [Server or VM](https:\u002F\u002Finvoiceninja.github.io\u002Fen\u002Fself-host-installation\u002F)\n* [Docker File](https:\u002F\u002Fhub.docker.com\u002Fr\u002Finvoiceninja\u002Finvoiceninja\u002F)\n* [Cloudron](https:\u002F\u002Fwww.cloudron.io\u002Fstore\u002Fcom.invoiceninja.cloudronapp2.html)\n* [Softaculous](https:\u002F\u002Fwww.softaculous.com\u002Fapps\u002Fecommerce\u002FInvoice_Ninja)\n* [Elestio](https:\u002F\u002Felest.io\u002Fopen-source\u002Finvoiceninja)\n* [YunoHost](https:\u002F\u002Fapps.yunohost.org\u002Fapp\u002Finvoiceninja5)\n\n### Recommended Providers\n* [Stripe](https:\u002F\u002Fstripe.com\u002F)\n* [Postmark](https:\u002F\u002Fpostmarkapp.com\u002F)\n\n### SDKs available for easier API consumption\n* [Go SDK](https:\u002F\u002Fgithub.com\u002FAshkanYarmoradi\u002Fgo-invoice-ninja)\n\n## [Advanced] Quick Hosting Setup\n\nIn addition to the official [Invoice Ninja - Self-Hosted Installation Guide](https:\u002F\u002Finvoiceninja.github.io\u002Fen\u002Fself-host-installation\u002F) we have a few commands for you.\n\n```sh\ngit clone --depth 1 -b v5.11.53 https:\u002F\u002Fgithub.com\u002Finvoiceninja\u002Finvoiceninja.git\ncp .env.example .env\ncomposer i -o --no-dev\n```\n\n**Note** replace v5.11.53 with the latest tag version, you will also want to ensure that when performing updates, you use the latest tag version rather than a particular branch, ie v5-develop. This will ensure that you are not pulling in work in progress code.\n\nPlease Note: \nYour APP_KEY in the .env file is used to encrypt data, if you lose this you will not be able to run the application.\n\nRun if you want to load sample data, remember to configure .env\n```sh\nphp artisan migrate:fresh --seed && php artisan db:seed && php artisan ninja:create-test-data\n```\n\nTo run the web server\n```sh\nphp artisan serve \n```\n\nNavigate to (replace localhost with the appropriate domain)\n```\nhttp:\u002F\u002Flocalhost:8000\u002Fsetup - To setup your configuration if you did not load sample data.\nhttp:\u002F\u002Flocalhost:8000\u002F - For Administrator Logon\n\nuser: small@example.com\npass: password\n\nhttp:\u002F\u002Flocalhost:8000\u002Fclient\u002Flogin - For Client Portal\n\nuser: user@example.com\npass: password\n```\n## Developers Guide\n\nIn addition to the official [Invoice Ninja - Developer Guide](https:\u002F\u002Finvoiceninja.github.io\u002Fen\u002Fdeveloper-guide\u002F) we've got your back with some insights.\n\n### App Design\n\nThe API and client portal have been developed using [Laravel](https:\u002F\u002Flaravel.com) if you wish to contribute to this project familiarity with Laravel is essential.\n\nWhen inspecting functionality of the API, the best place to start would be in the routes\u002Fapi.php file which describes all of the availabe API endpoints. The controller methods then describe all the entry points into each domain of the application, ie InvoiceController \u002F QuoteController\n\nThe average API request follows this path into the application.\n\n* Middleware processes the request initially inspecting the domain being requested + provides the authentication layer.\n* The request then passes into a Form Request (Type hinted in the controller methods) which is used to provide authorization and also validation of the request. If successful, the request is then passed into the controller method where it is digested, here is an example:\n\n```php\npublic function store(StoreInvoiceRequest $request)\n{\n\n    $invoice = $this->invoice_repo->save($request->all(), InvoiceFactory::create(auth()->user()->company()->id, auth()->user()->id));\n\n    $invoice = $invoice->service()\n                        ->fillDefaults()\n                        ->triggeredActions($request)\n                        ->adjustInventory()\n                        ->save();\n\n    event(new InvoiceWasCreated($invoice, $invoice->company, Ninja::eventVars(auth()->user() ? auth()->user()->id : null)));\n\n    return $this->itemResponse($invoice);\n\n}\n```\n\nHere for example we are storing a new invoice, we pass the validated request along with a factory into the invoice repository where it is processed and saved.\n\nThe returned invoice then passes through its service class (app\u002FServices\u002FInvoice) where various actions are performed.\n\nA event is then fired which notifies listeners in the application (app\u002FProviders\u002FEventServiceProvider) which perform non blocking sub tasks \n\nFinally the invoice is transformed (app\u002FTransformers\u002F) and returned as a response via Fractal.\n\n### Developer environment\n\nUsing the Quick Hosting Setup describe above you can quickly get started building out your development environment. Instead of using \n\n```\ncomposer i -o --no-dev\n``` \n\nuse\n\n```\ncomposer i -o\n```\n\nThis provides the developer tools including phpunit which allows the test suite to be run.\n\nIf you are considering contributing back to the main repository, please add in any tests for new functionality \u002F modifications. This will greatly increase the chances of your PR being accepted\n\nAlso, if you plan any additions for the main repository, you may want to discuss this with us first on Slack where we can assist with any technical information and provide advice.\n\n## Credits\n* [Hillel Coren](https:\u002F\u002Fhillelcoren.com\u002F)\n* [David Bomba](https:\u002F\u002Fgithub.com\u002Fturbo124)\n* [Benjamin Beganović](https:\u002F\u002Fgithub.com\u002Fbeganovich)\n* [All Contributors](https:\u002F\u002Fgithub.com\u002Finvoiceninja\u002Finvoiceninja\u002Fgraphs\u002Fcontributors)\n\n\n## Want More?\nCheckout our other projects here!\n\n[Event Schedule](https:\u002F\u002Fwww.eventschedule.com\u002F)\n\n\n## Security\n\nIf you find a security issue with this application, please send an email to contact@invoiceninja.com.\nPlease follow responsible disclosure procedures if you detect an issue.\nFor further information on responsible disclosure please read [here](https:\u002F\u002Fcheatsheetseries.owasp.org\u002Fcheatsheets\u002FVulnerability_Disclosure_Cheat_Sheet.html).\n\n## License\nInvoice Ninja is released under the Elastic License.  \nSee [LICENSE](LICENSE) for details.","Invoice Ninja 是一个基于 Laravel 构建的开源发票、报价、项目管理和时间跟踪应用程序。其核心功能包括生成和管理发票、处理支付、跟踪时间和费用，以及提供项目管理工具。技术上，该项目采用 PHP 语言开发，并集成了 JavaScript 和 Flutter 技术以支持跨平台客户端应用。Invoice Ninja 适用于自由职业者、小型企业和需要高效管理财务流程的组织。它提供了托管服务和自托管两种部署方式，满足不同用户的需求。",2,"2026-06-11 03:16:42","top_language"]