Code Coverage
 
Lines
Functions and Methods
Classes and Traits
Total
n/a
0 / 0
n/a
0 / 0
CRAP
n/a
0 / 0
1<?php
2
3/**
4 * This file is part of the MADIS - RGPD Management application.
5 *
6 * @copyright Copyright (c) 2018-2019 Soluris - Solutions Numériques Territoriales Innovantes
7 *
8 * This program is free software: you can redistribute it and/or modify
9 * it under the terms of the GNU Affero General Public License as published by
10 * the Free Software Foundation, either version 3 of the License, or
11 * (at your option) any later version.
12 *
13 * This program is distributed in the hope that it will be useful,
14 * but WITHOUT ANY WARRANTY; without even the implied warranty of
15 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16 * GNU Affero General Public License for more details.
17 *
18 * You should have received a copy of the GNU Affero General Public License
19 * along with this program. If not, see <https://www.gnu.org/licenses/>.
20 */
21
22declare(strict_types=1);
23
24namespace App\Domain\Registry\Repository;
25
26use App\Application\DDD\Repository\CRUDRepositoryInterface;
27use App\Application\Doctrine\Repository\DataTablesRepository;
28use App\Domain\User\Model\Collectivity;
29use App\Domain\User\Model\User;
30
31interface Mesurement extends CRUDRepositoryInterface, DataTablesRepository
32{
33    /**
34     * Find all mesurements by associated collectivity.
35     *
36     * @param Collectivity $collectivity The collectivity to search with
37     * @param array        $order        Order results
38     *
39     * @return array The array of mesurements given by the collectivity
40     */
41    public function findAllByCollectivity(Collectivity $collectivity, array $order = []);
42
43    /**
44     * Find all mesurements by criteria.
45     *
46     * @param array $criteria List of criteria
47     *
48     * @return array The array of mesurements given by criteria
49     */
50    public function findBy(array $criteria = []);
51
52    /**
53     * Find all planified mesurements by criteria.
54     *
55     * @param array $criteria List of criteria
56     *
57     * @return array The array of mesurements given by criteria
58     */
59    public function findByPlanified(array $criteria = []);
60
61    /**
62     * Count all planified and not applied mesurements by collectivity.
63     *
64     * @return string The count of mesurements
65     */
66    public function countPlanifiedByCollectivity(Collectivity $collectivity);
67
68    /**
69     * Count all applied mesurements by collectivity.
70     *
71     * @return string The count of mesurements
72     */
73    public function countAppliedByCollectivity(Collectivity $collectivity);
74
75    /**
76     * Mesurement planified average mesurements.
77     *
78     * @return string The average
79     */
80    public function planifiedAverageOnAllCollectivity($collectivities);
81
82    /**
83     * Return all mesurement from active collectivity.
84     *
85     * @return array
86     */
87    public function findAllByActiveCollectivity(bool $active = true, ?User $user = null);
88
89    /**
90     * Find all by collectivity of their clonedFrom.
91     */
92    public function findAllByClonedFromCollectivity(Collectivity $collectivity);
93
94    /**
95     * Return all action planified for dashboard.
96     *
97     * @return array
98     */
99    public function getPlanifiedActionsDashBoard($limit, Collectivity $collectivity);
100
101    /**
102     * Set clonedFrom to null by collectivity.
103     */
104    public function resetClonedFromCollectivity(Collectivity $collectivity);
105}