Reporter
📊 Export Craft data as CSVs in a snap!
⚡️ Features
- 🏎 Reports are processed with Query Batching, making exports run quickly and without exhausting your memory limit
- 🧘 Inspired by Element API, create reports with a simple and familiar structure
- 📦 Reports stored using Asset volumes so you can host reports locally or on a cloud-based service like Amazon S3
📦 Installing
Install Reporter one of two ways:
- Install via Craft's Plugin Store
- Run
composer require trendyminds/craft-reporter
and enable the plugin from "Settings > Plugins"
🔌 Setup
To setup reports, create a reporter.php
file in config/
. Below is an example config file.
Example Config
<?php
use craft\elements\Entry;
use craft\elements\Asset;
return [
// The name to use throughout the control panel (defaults to "Reporter")
'displayName' => 'Reports',
// The asset volume handle where your reports should be saved
// NOTE: Your reports are publicly accessible if your volume has "Assets in this volume have public URLs" enabled
'volume' => 'uploads',
// An optional folder path if you would like to nest the reports in a specific directory
'folder' => 'resources/reports',
// An array of reports to produce
'reports' => [
'pages' => function () {
return [
'name' => 'All Pages',
'description' => 'A simple export of all the pages on the site.',
'elementType' => Entry::class,
'criteria' => [
'section' => 'pages'
],
'transformer' => function (Entry $entry) {
return [
"id" => $entry->id,
"title" => $entry->title,
"url" => $entry->url,
];
}
];
},
'allImages' => function () {
return [
'name' => 'Uploaded Images',
'description' => 'A list of all images uploaded into Craft',
'elementType' => Asset::class,
'criteria' => [
'kind' => 'image'
],
'transformer' => function (Asset $asset) {
return [
"id" => $asset->id,
"title" => $asset->title,
"filename" => $asset->filename,
];
}
];
},
]
];
🤝 Contributing
If you would like to contribute to Reporter we tried to make it as easy as possible:
- Clone the repo
- Run
npm i
to install the Node dependencies - Run
npm start
to begin the watch task - Make your changes
- Run
npm run build
to compile and minify the CSS and JS - Submit a PR!
Installation Instructions
To install this plugin, copy the command above to your terminal.
Reviews
This plugin doesn't have any reviews.
Active Installs
84
License
MIT
Last release
May 18, 2023
Activity (30 days)
0
Closed Issues
0
Open Issues
0
Merged PRs
0
Open PRs