Test Failed
Push — develop ( db5b9c...b55dd4 )
by Paul
17:52
created

SiteReviewsSummaryWidget::widgetConfig()   A

Complexity

Conditions 1
Paths 1

Size

Total Lines 46
Code Lines 36

Duplication

Lines 0
Ratio 0 %

Code Coverage

Tests 0
CRAP Score 2

Importance

Changes 0
Metric Value
eloc 36
c 0
b 0
f 0
dl 0
loc 46
ccs 0
cts 40
cp 0
rs 9.344
cc 1
nc 1
nop 0
crap 2
1
<?php
2
3
namespace GeminiLabs\SiteReviews\Widgets;
4
5
use GeminiLabs\SiteReviews\Contracts\ShortcodeContract;
6
use GeminiLabs\SiteReviews\Modules\Rating;
7
use GeminiLabs\SiteReviews\Shortcodes\SiteReviewsSummaryShortcode;
8
9
class SiteReviewsSummaryWidget extends Widget
10
{
11
    protected function wConfig(): array
12
    {
13
        return [
14
            'assigned_posts' => [
15
                'description' => esc_html_x('Enter "post_id" to use the Post ID of the current page.', 'admin-text', 'site-reviews'),
16
                'label' => esc_html_x('Limit Reviews by Assigned Pages', 'admin-text', 'site-reviews'),
17
                'type' => 'text',
18
            ],
19
            'assigned_users' => [
20
                'description' => esc_html_x('Enter "user_id" to use the ID of the logged-in user.', 'admin-text', 'site-reviews'),
21
                'label' => esc_html_x('Limit Reviews by Assigned Users', 'admin-text', 'site-reviews'),
22
                'type' => 'text',
23
            ],
24
            'assigned_terms' => [
25
                'label' => esc_html_x('Limit Reviews by Categories', 'admin-text', 'site-reviews'),
26
                'options' => $this->fieldAssignedTermsOptions(),
27
                'type' => 'select',
28
            ],
29
            'terms' => [
30
                'label' => esc_html_x('Limit Reviews by Accepted Terms', 'admin-text', 'site-reviews'),
31
                'options' => $this->shortcode->options('terms', [
32
                    'placeholder' => _x('— Select —', 'admin-text', 'site-reviews'),
33
                ]),
34
                'type' => 'select',
35
            ],
36
            'type' => [
37
                'label' => esc_html_x('Limit Reviews by Type', 'admin-text', 'site-reviews'),
38
                'options' => $this->shortcode->options('type'),
39
                'type' => 'select',
40
                'value' => 'local',
41
            ],
42
            'rating' => [
43
                'label' => esc_html_x('The minimum rating to display', 'admin-text', 'site-reviews'),
44
                'max' => Rating::max(),
45
                'min' => max(1, Rating::min()),
46
                'type' => 'number',
47
                'value' => max(1, Rating::min()),
48
            ],
49
            'hide' => [
50
                'options' => $this->shortcode->options('hide'),
51
                'type' => 'checkbox',
52
            ],
53
            'id' => [
54
                'description' => esc_html_x('This should be a unique value.', 'admin-text', 'site-reviews'),
55
                'label' => esc_html_x('Custom ID', 'admin-text', 'site-reviews'),
56
                'type' => 'text',
57
            ],
58
            'class' => [
59
                'description' => esc_html_x('Separate multiple classes with spaces.', 'admin-text', 'site-reviews'),
60
                'label' => esc_html_x('Additional CSS classes', 'admin-text', 'site-reviews'),
61
                'type' => 'text',
62
            ],
63
        ];
64
    }
65
66
    protected function wShortcode(): ShortcodeContract
67
    {
68
        return glsr(SiteReviewsSummaryShortcode::class);
0 ignored issues
show
Bug Best Practice introduced by
The expression return glsr(GeminiLabs\S...ummaryShortcode::class) could return the type callable which is incompatible with the type-hinted return GeminiLabs\SiteReviews\Contracts\ShortcodeContract. Consider adding an additional type-check to rule them out.
Loading history...
69
    }
70
}
71