Filter   A
last analyzed

Complexity

Total Complexity 7

Size/Duplication

Total Lines 64
Duplicated Lines 0 %

Coupling/Cohesion

Components 2
Dependencies 2

Importance

Changes 0
Metric Value
wmc 7
lcom 2
cbo 2
dl 0
loc 64
rs 10
c 0
b 0
f 0

7 Methods

Rating   Name   Duplication   Size   Complexity  
A __construct() 0 7 1
A getIdentifier() 0 3 1
A getName() 0 3 1
A getPriority() 0 3 1
A getIcon() 0 3 1
A filterTypes() 0 3 1
A allowedApps() 0 3 1
1
<?php
2
/**
3
 * @copyright Copyright (c) 2018 Julius Härtl <[email protected]>
4
 *
5
 * @author Julius Härtl <[email protected]>
6
 *
7
 * @license GNU AGPL version 3 or any later version
8
 *
9
 * This program is free software: you can redistribute it and/or modify
10
 * it under the terms of the GNU Affero General Public License as
11
 * published by the Free Software Foundation, either version 3 of the
12
 * License, or (at your option) any later version.
13
 *
14
 * This program is distributed in the hope that it will be useful,
15
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
16
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
17
 * GNU Affero General Public License for more details.
18
 *
19
 * You should have received a copy of the GNU Affero General Public License
20
 * along with this program. If not, see <http://www.gnu.org/licenses/>.
21
 *
22
 */
23
24
namespace OCA\Deck\Activity;
25
26
use OCP\IL10N;
27
use OCP\IURLGenerator;
28
29
class Filter implements \OCP\Activity\IFilter {
30
31
	private $l10n;
32
	private $urlGenerator;
33
34
	public function __construct(
35
		IL10N $l10n,
36
		IURLGenerator $urlGenerator
37
	) {
38
		$this->l10n = $l10n;
39
		$this->urlGenerator = $urlGenerator;
40
	}
41
42
	/**
43
	 * @return string Lowercase a-z and underscore only identifier
44
	 * @since 11.0.0
45
	 */
46
	public function getIdentifier() {
47
		return 'deck';
48
	}
49
50
	/**
51
	 * @return string A translated string
52
	 * @since 11.0.0
53
	 */
54
	public function getName() {
55
		return $this->l10n->t('Deck');
56
	}
57
58
	/**
59
	 * @return int whether the filter should be rather on the top or bottom of
60
	 * the admin section. The filters are arranged in ascending order of the
61
	 * priority values. It is required to return a value between 0 and 100.
62
	 * @since 11.0.0
63
	 */
64
	public function getPriority() {
65
		return 90;
66
	}
67
68
	/**
69
	 * @return string Full URL to an icon, empty string when none is given
70
	 * @since 11.0.0
71
	 */
72
	public function getIcon() {
73
		return $this->urlGenerator->imagePath('deck', 'deck-dark.svg');
74
	}
75
76
	/**
77
	 * @param string[] $types
78
	 * @return string[] An array of allowed apps from which activities should be displayed
79
	 * @since 11.0.0
80
	 */
81
	public function filterTypes(array $types) {
82
		return array_merge($types, ['deck_comment']);
83
	}
84
85
	/**
86
	 * @return string[] An array of allowed apps from which activities should be displayed
87
	 * @since 11.0.0
88
	 */
89
	public function allowedApps() {
90
		return ['deck'];
91
	}
92
}
93