/
PagesDataProvider.php
72 lines (64 loc) · 2.64 KB
/
PagesDataProvider.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
<?php
declare(strict_types=1);
namespace Fixpunkt\Backendtools\Widgets\Provider;
use TYPO3\CMS\Core\Database\Connection;
use TYPO3\CMS\Core\Database\ConnectionPool;
use TYPO3\CMS\Core\Utility\GeneralUtility;
use TYPO3\CMS\Dashboard\WidgetApi;
use TYPO3\CMS\Dashboard\Widgets\ChartDataProviderInterface;
class PagesDataProvider implements ChartDataProviderInterface
{
/**
* @inheritDoc
*/
public function getChartData(): array
{
$visiblePages = $this->getNumberOfPages(0);
$hideInMenuPages = $this->getNumberOfPages(1);
$hiddenPages = $this->getNumberOfPages(2);
$deletedPages = $this->getNumberOfPages(3);
return [
'labels' => [
'Enabled',
'Hidden',
'Deleted',
'Hidden in menu'
],
'datasets' => [
[
'backgroundColor' => WidgetApi::getDefaultChartColors(),
'data' => [$visiblePages, $hiddenPages, $deletedPages, $hideInMenuPages],
],
],
];
}
protected function getNumberOfPages(int $mode = 0): int
{
$expression = null;
$queryBuilder = GeneralUtility::makeInstance(ConnectionPool::class)->getQueryBuilderForTable('pages');
$queryBuilder
->getRestrictions()
->removeAll();
if (!$mode) {
$expression = $queryBuilder->expr()->and($queryBuilder->expr()->eq('deleted', $queryBuilder->createNamedParameter(0)), $queryBuilder->expr()->eq('hidden', $queryBuilder->createNamedParameter(0)), $queryBuilder->expr()->eq('nav_hide', $queryBuilder->createNamedParameter(0)));
} elseif ($mode == 1) {
$expression = $queryBuilder->expr()->and($queryBuilder->expr()->eq('deleted', $queryBuilder->createNamedParameter(0)), $queryBuilder->expr()->eq('hidden', $queryBuilder->createNamedParameter(0)), $queryBuilder->expr()->eq('nav_hide', $queryBuilder->createNamedParameter(1)));
} elseif ($mode == 2) {
$expression = $queryBuilder->expr()->and($queryBuilder->expr()->eq('deleted', $queryBuilder->createNamedParameter(0)), $queryBuilder->expr()->eq('hidden', $queryBuilder->createNamedParameter(1)));
} elseif ($mode == 3) {
$expression = $queryBuilder->expr()->eq('deleted', $queryBuilder->createNamedParameter(1));
}
return (int)$queryBuilder
->count('*')
->from('pages')
->where(
$expression
)
->executeQuery()
->fetchOne();
}
public function getOptions(): array
{
return $this->options;
}
}