xref: /webtrees/app/Statistics/Repository/NewsRepository.php (revision 00b1984e374faddab4698e73088f0c964e529b65)
1<?php
2
3/**
4 * webtrees: online genealogy
5 * Copyright (C) 2019 webtrees development team
6 * This program is free software: you can redistribute it and/or modify
7 * it under the terms of the GNU General Public License as published by
8 * the Free Software Foundation, either version 3 of the License, or
9 * (at your option) any later version.
10 * This program is distributed in the hope that it will be useful,
11 * but WITHOUT ANY WARRANTY; without even the implied warranty of
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 * GNU General Public License for more details.
14 * You should have received a copy of the GNU General Public License
15 * along with this program. If not, see <http://www.gnu.org/licenses/>.
16 */
17
18declare(strict_types=1);
19
20namespace Fisharebest\Webtrees\Statistics\Repository;
21
22use Fisharebest\Webtrees\Auth;
23use Fisharebest\Webtrees\I18N;
24use Fisharebest\Webtrees\Statistics\Repository\Interfaces\NewsRepositoryInterface;
25use Fisharebest\Webtrees\Tree;
26use Illuminate\Database\Capsule\Manager as DB;
27
28/**
29 * A repository providing methods for news related statistics.
30 */
31class NewsRepository implements NewsRepositoryInterface
32{
33    /**
34     * @var Tree
35     */
36    private $tree;
37
38    /**
39     * Constructor.
40     *
41     * @param Tree $tree
42     */
43    public function __construct(Tree $tree)
44    {
45        $this->tree = $tree;
46    }
47
48    /**
49     * @inheritDoc
50     */
51    public function totalUserJournal(): string
52    {
53        $number = DB::table('news')
54            ->where('user_id', '=', Auth::id())
55            ->count();
56
57        return I18N::number($number);
58    }
59
60    /**
61     * @inheritDoc
62     */
63    public function totalGedcomNews(): string
64    {
65        $number = DB::table('news')
66            ->where('gedcom_id', '=', $this->tree->id())
67            ->count();
68
69        return I18N::number($number);
70    }
71}
72