Passed
Push — develop ( c34e50...445d6d )
by Paul
06:42
created

SiteReviewsFormTinymce::fields()   A

Complexity

Conditions 1
Paths 1

Size

Total Lines 52
Code Lines 35

Duplication

Lines 0
Ratio 0 %

Code Coverage

Tests 0
CRAP Score 2

Importance

Changes 0
Metric Value
eloc 35
dl 0
loc 52
ccs 0
cts 51
cp 0
rs 9.36
c 0
b 0
f 0
cc 1
nc 1
nop 0
crap 2

How to fix   Long Method   

Long Method

Small methods make your code easier to understand, in particular if combined with a good name. Besides, if your method is small, finding a good name is usually much easier.

For example, if you find yourself adding comments to a method's body, this is usually a good sign to extract the commented part to a new method, and use the comment as a starting point when coming up with a good name for this new method.

Commonly applied refactorings include:

1
<?php
2
3
namespace GeminiLabs\SiteReviews\Tinymce;
4
5
use GeminiLabs\SiteReviews\Contracts\ShortcodeContract;
6
use GeminiLabs\SiteReviews\Shortcodes\SiteReviewsFormShortcode;
7
8
class SiteReviewsFormTinymce extends TinymceGenerator
9
{
10
    public function fields(): array
11
    {
12
        return [
13
            [
14
                'label' => esc_html_x('Assign Pages', 'admin-text', 'site-reviews'),
15
                'name' => 'assigned_posts',
16
                'tooltip' => sprintf(esc_html_x('Automatically assign reviews to a Post ID. You may also enter %s to use the Post ID of the current page.', 'admin-text', 'site-reviews'), '"post_id"'),
17
                'type' => 'textbox',
18
            ],
19
            [
20
                'label' => esc_html_x('Assign Categories', 'admin-text', 'site-reviews'),
21
                'name' => 'assigned_terms',
22
                'tooltip' => esc_html_x('Automatically assign reviews to a category. You may enter a Term ID or slug.', 'admin-text', 'site-reviews'),
23
                'type' => 'textbox',
24
            ],
25
            [
26
                'label' => esc_html_x('Assign Users', 'admin-text', 'site-reviews'),
27
                'name' => 'assigned_users',
28
                'tooltip' => sprintf(esc_html_x('Automatically assign reviews to a User ID. You may also enter %s to use the ID of the logged-in user.', 'admin-text', 'site-reviews'), '"user_id"'),
29
                'type' => 'textbox',
30
            ],
31
            [
32
                'columns' => 2,
33
                'items' => $this->hideOptions(),
34
                'label' => esc_html_x('Hide', 'admin-text', 'site-reviews'),
35
                'layout' => 'grid',
36
                'spacing' => 5,
37
                'type' => 'container',
38
            ],
39
            [
40
                'label' => esc_html_x('Latest Reviews ID', 'admin-text', 'site-reviews'),
41
                'name' => 'reviews_id',
42
                'tooltip' => _x('Enter the Custom ID of a Latest Reviews shortcode where the review should be displayed after submission.', 'admin-text', 'site-reviews'),
43
                'type' => 'textbox',
44
            ],
45
            [
46
                'label' => esc_html_x('Rating Summary ID', 'admin-text', 'site-reviews'),
47
                'name' => 'summary_id',
48
                'tooltip' => _x('Enter the Custom ID of a Rating Summary shortcode where the rating values should be updated after submission.', 'admin-text', 'site-reviews'),
49
                'type' => 'textbox',
50
            ],
51
            [
52
                'label' => esc_html_x('Custom ID', 'admin-text', 'site-reviews'),
53
                'name' => 'id',
54
                'tooltip' => esc_html_x('This should be a unique value.', 'admin-text', 'site-reviews'),
55
                'type' => 'textbox',
56
            ],
57
            [
58
                'label' => esc_html_x('Additional CSS classes', 'admin-text', 'site-reviews'),
59
                'name' => 'class',
60
                'tooltip' => esc_html_x('Separate multiple classes with spaces.', 'admin-text', 'site-reviews'),
61
                'type' => 'textbox',
62
            ],
63
        ];
64
    }
65
66
    public function shortcode(): ShortcodeContract
67
    {
68
        return glsr(SiteReviewsFormShortcode::class);
1 ignored issue
show
Bug Best Practice introduced by
The expression return glsr(GeminiLabs\S...wsFormShortcode::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