digikraaft / laravel-dashboard-paystack-transactions-tile
A tile to show list of Paystack Transactions on Laravel Dashboard
Installs: 2
Dependents: 0
Suggesters: 0
Security: 0
Stars: 1
Watchers: 0
Forks: 0
Open Issues: 0
pkg:composer/digikraaft/laravel-dashboard-paystack-transactions-tile
Requires
- php: ^7.4
- digikraaft/paystack-php: ^1.0
- illuminate/console: ^8.0
- illuminate/pagination: ^8.0
- illuminate/support: ^8.0
- spatie/laravel-dashboard: ^2.0
Requires (Dev)
- phpunit/phpunit: ^9.0
This package is auto-updated.
Last update: 2025-10-10 17:15:17 UTC
README
This tile displays the list of Paystack transactions. It can be used on the Laravel Dashboard.
Installation
You can install the package via composer:
composer require digikraaft/laravel-dashboard-paystack-transactions-tile
You need to publish the migrations and config file of the Laravel Dashboard package.
In the dashboard config file, you can optionally add this configuration in the tiles key and customize it for your own needs:
// in config/dashboard.php
'tiles' => [
        /**
         * Paystack configuration settings
         */
        'paystack' => [
            'secret_key' => env('PAYSTACK_SECRET'),
            'transactions' => [
                /**
                 * the values here must be supported by the Paystack API
                 * @link https://paystack.com/docs/api/#transaction-list
                 */
                'params' => [
                    'perPage' => 5,
                    'from' => now()->subMonths(3)->toDateString(),
                    'to' => now()->toDateString(),
                ],
                /**
                 * How often should the data be refreshed in seconds
                 */
                'refresh_interval_in_seconds' => 1800,
            ],
        ],
    ],
You must set your PAYSTACK_SECRET in the .env file. You can get this from your Paystack dashboard.
To load transactions data from Paystack, you need to schedule the FetchTransactionsDataFromPaystackApi
command:
// in app/Console/Kernel.php
use Digikraaft\PaystackTransactionsTile\FetchTransactionsDataFromPaystackApi;
protected function schedule(Schedule $schedule)
{
    $schedule->command(FetchTransactionsDataFromPaystackApi::class)->daily();
}
You can change the frequency of the schedule as desired. You can also use the
php artisan dashboard:fetch-transactions-data-from-paystack-api command.
Usage
In your dashboard view you use the livewire:paystack-transactions-tile component.
<x-dashboard> <livewire:paystack-transactions-tile position="e7:e16" /> </x-dashboard>
You can add an optional title:
<x-dashboard> <livewire:paystack-transactions-tile position="e7:e16" title="Paystack Transactions" /> </x-dashboard>
Pagination
The package paginates data by default. The default value is 5. This can be changed by adding a perPage
property to the tile:
<x-dashboard> <livewire:paystack-transactions-tile position="e7:e16" title="Paystack Transactions" perPage="10" /> </x-dashboard>
Testing
Use the command below to run your tests:
composer test
More Good Stuff
Check here for more awesome free stuff!
Changelog
Please see CHANGELOG for more information on what has changed recently.
Contributing
Please see CONTRIBUTING for details.
Security
If you discover any security related issues, please email dev@digitalkraaft.com instead of using the issue tracker.
Credits
Thanks to
- Spatie for the Laravel Dashboard package
License
The MIT License (MIT). Please see License File for more information.
