SiteReviewsWidget::widgetConfig()   A
last analyzed

Complexity

Conditions 1
Paths 1

Size

Total Lines 48
Code Lines 38

Duplication

Lines 0
Ratio 0 %

Code Coverage

Tests 0
CRAP Score 2

Importance

Changes 1
Bugs 0 Features 1
Metric Value
eloc 38
c 1
b 0
f 1
dl 0
loc 48
ccs 0
cts 39
cp 0
rs 9.312
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\SiteReviewsShortcode;
8
9
class SiteReviewsWidget extends Widget
10
{
11
    protected function widgetConfig(): 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_terms' => [
20
                'description' => esc_html_x('Enter the Term ID or slug of a category.', 'admin-text', 'site-reviews'),
21
                'label' => esc_html_x('Limit Reviews by Assigned Categories', 'admin-text', 'site-reviews'),
22
                'type' => 'text',
23
            ],
24
            'assigned_users' => [
25
                'description' => esc_html_x('Enter "user_id" to use the ID of the logged-in user.', 'admin-text', 'site-reviews'),
26
                'label' => esc_html_x('Limit Reviews by Assigned Users', 'admin-text', 'site-reviews'),
27
                'type' => 'text',
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
            'display' => [
43
                'label' => esc_html_x('Reviews Per Page', 'admin-text', 'site-reviews'),
44
                'max' => 50,
45
                'min' => 1,
46
                'type' => 'number',
47
                'value' => 10,
48
            ],
49
            'rating' => [
50
                'label' => esc_html_x('Minimum Rating', 'admin-text', 'site-reviews'),
51
                'max' => Rating::max(),
52
                'min' => Rating::min(),
53
                'type' => 'number',
54
                'value' => Rating::min(),
55
            ],
56
            'hide' => [
57
                'options' => $this->shortcode->options('hide'),
58
                'type' => 'checkbox',
59
            ],
60
        ];
61
    }
62
63
    protected function widgetShortcode(): ShortcodeContract
64
    {
65
        return glsr(SiteReviewsShortcode::class);
0 ignored issues
show
Bug Best Practice introduced by
The expression return glsr(GeminiLabs\S...eviewsShortcode::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...
66
    }
67
}
68