mirror of
https://github.com/invoiceninja/invoiceninja.git
synced 2024-11-10 05:02:36 +01:00
54 lines
1.5 KiB
PHP
54 lines
1.5 KiB
PHP
<?php
|
|
|
|
namespace App\Ninja\Reports;
|
|
|
|
use App\Models\Activity;
|
|
use Auth;
|
|
|
|
class ActivityReport extends AbstractReport
|
|
{
|
|
public function getColumns()
|
|
{
|
|
return [
|
|
'date' => [],
|
|
'client' => [],
|
|
'user' => [],
|
|
'activity' => [],
|
|
];
|
|
}
|
|
|
|
public function run()
|
|
{
|
|
$account = Auth::user()->account;
|
|
|
|
$startDate = $this->startDate;;
|
|
$endDate = $this->endDate;
|
|
$subgroup = $this->options['subgroup'];
|
|
|
|
$activities = Activity::scope()
|
|
->with('client.contacts', 'user', 'invoice', 'payment', 'credit', 'task', 'expense', 'account')
|
|
->whereRaw("DATE(created_at) >= \"{$startDate}\" and DATE(created_at) <= \"$endDate\"")
|
|
->orderBy('id', 'desc');
|
|
|
|
foreach ($activities->get() as $activity) {
|
|
$client = $activity->client;
|
|
$this->data[] = [
|
|
$activity->present()->createdAt,
|
|
$client ? ($this->isExport ? $client->getDisplayName() : $client->present()->link) : '',
|
|
$activity->present()->user,
|
|
$this->isExport ? strip_tags($activity->getMessage()) : $activity->getMessage(),
|
|
];
|
|
|
|
if ($subgroup == 'category') {
|
|
$dimension = trans('texts.' . $activity->relatedEntityType());
|
|
} else {
|
|
$dimension = $this->getDimension($activity);
|
|
}
|
|
|
|
$this->addChartData($dimension, $activity->created_at, 1);
|
|
}
|
|
|
|
//dd($this->getChartData());
|
|
}
|
|
}
|