Sprout Invoices 19.9.5

Does Sprout Invoices work with WordPress 5.8 and PHP 7.4.8? A smoke test was performed on .

Summary

Errors
1PHP notices
1Unrecognized messages in the PHP error log
7JavaScript exceptions
All test pages loaded successfully
No resource errors
Performance

Memory usage: 1.84 MiB
The average PHP memory usage increased by this amount after activating by the plugin.

Page speed impact: insignificant.
The plugin didn't make the site noticeably slower.

Environment
WordPress version5.8
PHP version7.4.8
MySQL version8.0.21
PHP memory limit256M
Plugin Info
Last updated
Active installs 2,000+
WordPress.org page https://wordpress.org/plugins/sprout-invoices/
Badges

WordPress compatibility badge PHP compatibility badge

Get badge code

Pages 18

Getting Started ‹ Test site — WordPress

Page screenshot: Getting Started ‹ Test site — WordPress
URL /wp-admin/admin.php?page=sprout-invoices
Requested URL /wp-admin/plugins.php?action=activate&plugin=sprout-invoices%2Fsprout-invoices.php&plugin_status=all&paged=1&s&_wpnonce=d8d28dbc7e
Aspect after-activation
HTTP status 200
Load time 2.515 s
Memory usage 5.07 MiB
JS errors None
Resource errors None

Invoices

Page screenshot: Invoices
URL /wp-admin/edit.php?post_type=sa_invoice
Aspect menu-item
HTTP status 200
Load time 0.295 s
Memory usage 5.04 MiB
JS errors None
Resource errors None

Invoices → Add Invoice

Page screenshot: Invoices → Add Invoice
URL /wp-admin/post-new.php?post_type=sa_invoice
Aspect menu-item
HTTP status 200
Load time 0.437 s
Memory usage 5.08 MiB
JS errors None
Resource errors None

Invoices → Payments

Page screenshot: Invoices → Payments
URL /wp-admin/edit.php?post_type=sa_invoice&page=sprout-apps%2Finvoice_payments
Requested URL /wp-admin/edit.php?post_type=sa_invoice&page=sprout-apps/invoice_payments
Aspect menu-item
HTTP status 200
Load time 0.262 s
Memory usage 4.95 MiB
JS errors None
Resource errors None

Invoices → Clients

Page screenshot: Invoices → Clients
URL /wp-admin/edit.php?post_type=sa_client
Aspect menu-item
HTTP status 200
Load time 0.232 s
Memory usage 5.04 MiB
JS errors None
Resource errors None

Invoices → Projects

Page screenshot: Invoices → Projects
URL /wp-admin/edit.php?post_type=sa_project
Aspect menu-item
HTTP status 200
Load time 0.257 s
Memory usage 5.04 MiB
JS errors None
Resource errors None

Estimates

Page screenshot: Estimates
URL /wp-admin/edit.php?post_type=sa_estimate
Aspect menu-item
HTTP status 200
Load time 0.223 s
Memory usage 5.04 MiB
JS errors None
Resource errors None

Estimates → Add Estimate

Page screenshot: Estimates → Add Estimate
URL /wp-admin/post-new.php?post_type=sa_estimate
Aspect menu-item
HTTP status 200
Load time 0.381 s
Memory usage 5.07 MiB
JS errors None
Resource errors None

Tools → Sprout Records

Page screenshot: Tools → Sprout Records
URL /wp-admin/tools.php?page=si_records
Aspect menu-item
HTTP status 200
Load time 0.205 s
Memory usage 4.95 MiB
JS errors None
Resource errors None

Sprout Invoices

Page screenshot: Sprout Invoices
URL /wp-admin/admin.php?page=sprout-invoices
Aspect menu-item
HTTP status 200
Load time 0.582 s
Memory usage 4.95 MiB
JS errors None
Resource errors None

Sprout Invoices → General Settings

Page screenshot: Sprout Invoices → General Settings
URL /wp-admin/admin.php?page=sprout-invoices-settings
Aspect menu-item
HTTP status 200
Load time 0.680 s
Memory usage 4.95 MiB
JS errors None
Resource errors None

Sprout Invoices → Payment Settings

Page screenshot: Sprout Invoices → Payment Settings
URL /wp-admin/admin.php?page=sprout-invoices-payments
Aspect menu-item
HTTP status 200
Load time 0.463 s
Memory usage 4.95 MiB
JS errors None
Resource errors None

Sprout Invoices → Notifications

Page screenshot: Sprout Invoices → Notifications
URL /wp-admin/admin.php?page=sprout-invoices-notifications
Aspect menu-item
HTTP status 200
Load time 1.243 s
Memory usage 4.95 MiB
JS errors None
Resource errors None

Sprout Invoices → Add-ons

Page screenshot: Sprout Invoices → Add-ons
URL /wp-admin/admin.php?page=sprout-invoices-addons
Aspect menu-item
HTTP status 200
Load time 1.672 s
Memory usage 5.86 MiB
JS errors None
Resource errors None

Sprout Invoices → Reports

Page screenshot: Sprout Invoices → Reports
URL /wp-admin/admin.php?page=sprout-invoices-reports
Aspect menu-item
HTTP status 200
Load time 0.448 s
Memory usage 4.97 MiB
JS errors
[
    {
        "message": "TypeError: Cannot read property 'length' of undefined\n    at s.buildScale (/wp-content/plugins/sprout-invoices/resources/admin/plugins/chartjs/chart.min.js?ver=5.8:11:9205)\n    at s.<anonymous> (/wp-content/plugins/sprout-invoices/resources/admin/plugins/chartjs/chart.min.js?ver=5.8:11:8189)\n    at Object.s.each (/wp-content/plugins/sprout-invoices/resources/admin/plugins/chartjs/chart.min.js?ver=5.8:10:1836)\n    at s.initialize (/wp-content/plugins/sprout-invoices/resources/admin/plugins/chartjs/chart.min.js?ver=5.8:11:7706)\n    at s.e.Type (/wp-content/plugins/sprout-invoices/resources/admin/plugins/chartjs/chart.min.js?ver=5.8:10:10855)\n    at new s (/wp-content/plugins/sprout-invoices/resources/admin/plugins/chartjs/chart.min.js?ver=5.8:10:14765)\n    at e.<computed> [as Line] (/wp-content/plugins/sprout-invoices/resources/admin/plugins/chartjs/chart.min.js?ver=5.8:10:15107)\n    at payments_chart (/wp-admin/admin.php?page=sprout-invoices-reports:417:32)\n    at Object.success (/wp-admin/admin.php?page=sprout-invoices-reports:458:7)\n    at c (/wp-admin/load-scripts.php?c=0&load%5Bchunk_0%5D=jquery-core,jquery-migrate,utils&ver=5.8:2:28327)",
        "trace": null,
        "code": null
    },
    {
        "message": "TypeError: Cannot read property 'length' of undefined\n    at s.buildScale (/wp-content/plugins/sprout-invoices/resources/admin/plugins/chartjs/chart.min.js?ver=5.8:11:9205)\n    at s.<anonymous> (/wp-content/plugins/sprout-invoices/resources/admin/plugins/chartjs/chart.min.js?ver=5.8:11:8189)\n    at Object.s.each (/wp-content/plugins/sprout-invoices/resources/admin/plugins/chartjs/chart.min.js?ver=5.8:10:1836)\n    at s.initialize (/wp-content/plugins/sprout-invoices/resources/admin/plugins/chartjs/chart.min.js?ver=5.8:11:7706)\n    at s.e.Type (/wp-content/plugins/sprout-invoices/resources/admin/plugins/chartjs/chart.min.js?ver=5.8:10:10855)\n    at new s (/wp-content/plugins/sprout-invoices/resources/admin/plugins/chartjs/chart.min.js?ver=5.8:10:14765)\n    at e.<computed> [as Line] (/wp-content/plugins/sprout-invoices/resources/admin/plugins/chartjs/chart.min.js?ver=5.8:10:15107)\n    at payments_chart (/wp-admin/admin.php?page=sprout-invoices-reports:417:32)\n    at Object.success (/wp-admin/admin.php?page=sprout-invoices-reports:458:7)\n    at c (/wp-admin/load-scripts.php?c=0&load%5Bchunk_0%5D=jquery-core,jquery-migrate,utils&ver=5.8:2:28327)",
        "trace": null,
        "code": null
    },
    {
        "message": "TypeError: Cannot read property 'length' of undefined\n    at s.buildScale (/wp-content/plugins/sprout-invoices/resources/admin/plugins/chartjs/chart.min.js?ver=5.8:11:790)\n    at s.initialize (/wp-content/plugins/sprout-invoices/resources/admin/plugins/chartjs/chart.min.js?ver=5.8:10:31645)\n    at s.e.Type (/wp-content/plugins/sprout-invoices/resources/admin/plugins/chartjs/chart.min.js?ver=5.8:10:10855)\n    at new s (/wp-content/plugins/sprout-invoices/resources/admin/plugins/chartjs/chart.min.js?ver=5.8:10:14765)\n    at e.<computed> [as Bar] (/wp-content/plugins/sprout-invoices/resources/admin/plugins/chartjs/chart.min.js?ver=5.8:10:15107)\n    at est_invoices_chart (/wp-admin/admin.php?page=sprout-invoices-reports:563:32)\n    at Object.success (/wp-admin/admin.php?page=sprout-invoices-reports:601:7)\n    at c (/wp-admin/load-scripts.php?c=0&load%5Bchunk_0%5D=jquery-core,jquery-migrate,utils&ver=5.8:2:28327)\n    at Object.fireWith [as resolveWith] (/wp-admin/load-scripts.php?c=0&load%5Bchunk_0%5D=jquery-core,jquery-migrate,utils&ver=5.8:2:29072)\n    at l (/wp-admin/load-scripts.php?c=0&load%5Bchunk_0%5D=jquery-core,jquery-migrate,utils&ver=5.8:2:79901)",
        "trace": null,
        "code": null
    },
    {
        "message": "TypeError: Cannot read property 'length' of undefined\n    at s.buildScale (/wp-content/plugins/sprout-invoices/resources/admin/plugins/chartjs/chart.min.js?ver=5.8:11:790)\n    at s.initialize (/wp-content/plugins/sprout-invoices/resources/admin/plugins/chartjs/chart.min.js?ver=5.8:10:31645)\n    at s.e.Type (/wp-content/plugins/sprout-invoices/resources/admin/plugins/chartjs/chart.min.js?ver=5.8:10:10855)\n    at new s (/wp-content/plugins/sprout-invoices/resources/admin/plugins/chartjs/chart.min.js?ver=5.8:10:14765)\n    at e.<computed> [as Bar] (/wp-content/plugins/sprout-invoices/resources/admin/plugins/chartjs/chart.min.js?ver=5.8:10:15107)\n    at est_invoices_chart (/wp-admin/admin.php?page=sprout-invoices-reports:563:32)\n    at dispatch (/wp-admin/load-scripts.php?c=0&load%5Bchunk_0%5D=jquery-core,jquery-migrate,utils&ver=5.8:2:43064)\n    at v.handle (/wp-admin/load-scripts.php?c=0&load%5Bchunk_0%5D=jquery-core,jquery-migrate,utils&ver=5.8:2:41048)",
        "trace": null,
        "code": null
    },
    {
        "message": "TypeError: Cannot read property 'update' of undefined\n    at s.reflow (/wp-content/plugins/sprout-invoices/resources/admin/plugins/chartjs/chart.min.js?ver=5.8:11:10914)\n    at s.render (/wp-content/plugins/sprout-invoices/resources/admin/plugins/chartjs/chart.min.js?ver=5.8:10:11395)\n    at s.resize (/wp-content/plugins/sprout-invoices/resources/admin/plugins/chartjs/chart.min.js?ver=5.8:10:11298)\n    at /wp-content/plugins/sprout-invoices/resources/admin/plugins/chartjs/chart.min.js?ver=5.8:10:29582\n    at s.each (/wp-content/plugins/sprout-invoices/resources/admin/plugins/chartjs/chart.min.js?ver=5.8:10:1886)\n    at /wp-content/plugins/sprout-invoices/resources/admin/plugins/chartjs/chart.min.js?ver=5.8:10:29532",
        "trace": null,
        "code": null
    },
    {
        "message": "TypeError: Cannot read property 'length' of undefined\n    at s.buildScale (/wp-content/plugins/sprout-invoices/resources/admin/plugins/chartjs/chart.min.js?ver=5.8:11:790)\n    at s.initialize (/wp-content/plugins/sprout-invoices/resources/admin/plugins/chartjs/chart.min.js?ver=5.8:10:31645)\n    at s.e.Type (/wp-content/plugins/sprout-invoices/resources/admin/plugins/chartjs/chart.min.js?ver=5.8:10:10855)\n    at new s (/wp-content/plugins/sprout-invoices/resources/admin/plugins/chartjs/chart.min.js?ver=5.8:10:14765)\n    at e.<computed> [as Bar] (/wp-content/plugins/sprout-invoices/resources/admin/plugins/chartjs/chart.min.js?ver=5.8:10:15107)\n    at est_invoices_chart (/wp-admin/admin.php?page=sprout-invoices-reports:563:32)\n    at dispatch (/wp-admin/load-scripts.php?c=0&load%5Bchunk_0%5D=jquery-core,jquery-migrate,utils&ver=5.8:2:43064)\n    at v.handle (/wp-admin/load-scripts.php?c=0&load%5Bchunk_0%5D=jquery-core,jquery-migrate,utils&ver=5.8:2:41048)",
        "trace": null,
        "code": null
    }
]
Resource errors None

Sprout Invoices → Import

Page screenshot: Sprout Invoices → Import
URL /wp-admin/admin.php?page=sprout-invoices-import
Aspect menu-item
HTTP status 200
Load time 0.347 s
Memory usage 4.96 MiB
JS errors
[
    {
        "message": "TypeError: Cannot read property 'update' of undefined\n    at s.reflow (/wp-content/plugins/sprout-invoices/resources/admin/plugins/chartjs/chart.min.js?ver=5.8:11:10914)\n    at s.render (/wp-content/plugins/sprout-invoices/resources/admin/plugins/chartjs/chart.min.js?ver=5.8:10:11395)\n    at s.resize (/wp-content/plugins/sprout-invoices/resources/admin/plugins/chartjs/chart.min.js?ver=5.8:10:11298)\n    at /wp-content/plugins/sprout-invoices/resources/admin/plugins/chartjs/chart.min.js?ver=5.8:10:29582\n    at s.each (/wp-content/plugins/sprout-invoices/resources/admin/plugins/chartjs/chart.min.js?ver=5.8:10:1886)\n    at /wp-content/plugins/sprout-invoices/resources/admin/plugins/chartjs/chart.min.js?ver=5.8:10:29532",
        "trace": null,
        "code": null
    }
]
Resource errors None

Test site – Just another WordPress site

Page screenshot: Test site – Just another WordPress site
URL /
Aspect front-page
HTTP status 200
Load time 0.383 s
Memory usage 4.31 MiB
JS errors None
Resource errors None

Dashboard ‹ Test site — WordPress

Page screenshot: Dashboard ‹ Test site — WordPress
URL /wp-admin/index.php
Aspect new-meta-boxes
HTTP status 200
Load time 0.325 s
Memory usage 4.98 MiB
JS errors None
Resource errors None

Benchmark

URL Load time Memory usage
Inactive Active Change Inactive Active Change
/wp-admin/index.php0.306 s0.367 s+0.061 s3.08 MiB4.98 MiB+ 1.9 MiB
/wp-admin/edit.php0.186 s0.229 s+0.043 s3.11 MiB5.05 MiB+ 1.94 MiB
/wp-admin/post-new.php0.999 s1.234 s+0.235 s5.27 MiB6.95 MiB+ 1.69 MiB
/wp-admin/upload.php0.534 s0.462 s-0.072 s3.03 MiB4.97 MiB+ 1.94 MiB
/wp-admin/options-writing.php0.149 s0.184 s+0.035 s3.02 MiB4.95 MiB+ 1.92 MiB
/wp-admin/media-new.php0.344 s0.391 s+0.047 s3.01 MiB4.95 MiB+ 1.94 MiB
/wp-admin/edit-tags.php?taxonomy=category0.197 s0.295 s+0.098 s3.04 MiB4.98 MiB+ 1.94 MiB
/wp-admin/post-new.php?post_type=page1.124 s1.000 s-0.124 s5.26 MiB6.94 MiB+ 1.69 MiB
/wp-admin/options-discussion.php0.440 s0.374 s-0.066 s3 MiB4.95 MiB+ 1.94 MiB
/wp-admin/edit-comments.php0.255 s0.270 s+0.015 s3.04 MiB4.98 MiB+ 1.94 MiB
/0.989 s0.250 s-0.739 s2.91 MiB4.31 MiB+ 1.4 MiB
Average 0.502 s0.460 s-0.042 s3.43 MiB5.27 MiB+ 1.84 MiB

Code Statistics

Note: Third-party libraries and minified JS/CSS files are excluded from these statistics where possible, so the numbers you see here may be lower than those reported by other tools.

PO File
PHP
Language % Lines of code Comment lines Files
PO File58.2%59,78638,79719
PHP31.4%32,25711,458264
CSS6.9%7,1214259
JavaScript2.3%2,34945062
Sass0.5%532613
HTML0.5%50512
Markdown0.1%7003
Bourne Shell0.1%5941
SVG0.0%3201
JSON0.0%2202
XML0.0%1401
Total 102,747 51,141 377

PHP Code Analysis | More results »

Lines of code 25,551
Total complexity 5,346
Median class complexity 26.5
Median method complexity 2.0
Most complex class SI_Notifications
Most complex function SA_Init_Addon_Processors::load_bundled_payment_processor()
Classes 104
Methods 1,471
Functions 237

Additions

Things that the plugin adds to the site. This section is not intended to be comprehensive. The test tool only looks for a few specific types of added content.

Options wp_options 7

Custom Post Types 7

ID Name
sa_recordRecords
sa_notificationNotifications
sa_invoiceInvoices
sa_estimateEstimates
sa_clientClients
sa_paymentPayments
sa_projectProjects

Meta Boxes

{
    "dashboard": {
        "invoice_dashboard": {
            "title": "Invoices Dashboard",
            "context": "normal"
        },
        "estimates_dashboard": {
            "title": "Estimates Dashboard",
            "context": "side"
        }
    },
    "sa_notification": {
        "si_notification_submit": {
            "title": "Update",
            "context": "side"
        },
        "si_notification_shortcodes_send_estimate": {
            "title": "Estimate Available Shortcodes",
            "context": "normal"
        },
        "si_notification_shortcodes_send_invoice": {
            "title": "Invoice Available Shortcodes",
            "context": "normal"
        },
        "si_notification_shortcodes_deposit_payment": {
            "title": "Deposit Payment Received Shortcodes",
            "context": "normal"
        },
        "si_notification_shortcodes_payment_cleared": {
            "title": "Payment Cleared Shortcodes",
            "context": "normal"
        },
        "si_notification_shortcodes_final_payment": {
            "title": "Invoice Paid Shortcodes",
            "context": "normal"
        },
        "si_notification_shortcodes_reminder_payment": {
            "title": "Payment Reminder Shortcodes",
            "context": "normal"
        },
        "si_notification_shortcodes_accepted_estimate": {
            "title": "Estimate Accepted Shortcodes",
            "context": "normal"
        },
        "si_notification_shortcodes_declined_estimate": {
            "title": "Estimate Declined Shortcodes",
            "context": "normal"
        },
        "si_notification_shortcodes_payment_notification": {
            "title": "Payment Received Shortcodes",
            "context": "normal"
        }
    },
    "sa_client": {
        "si_client_information": {
            "title": "Information",
            "context": "normal"
        },
        "si_client_advanced": {
            "title": "Advanced",
            "context": "normal"
        },
        "si_client_history": {
            "title": "History",
            "context": "normal"
        },
        "si_client_submit": {
            "title": "Update",
            "context": "side"
        }
    },
    "sa_invoice": {
        "si_invoice_line_items": {
            "title": "Management",
            "context": "normal"
        },
        "si_invoice_update": {
            "title": "Information",
            "context": "normal"
        },
        "si_invoice_history": {
            "title": "Invoice History",
            "context": "normal"
        },
        "si_doc_send": {
            "title": "Send Notification",
            "context": "normal"
        },
        "si_invoice_payment": {
            "title": "Admin Payment",
            "context": "normal"
        },
        "si_invoice_notes": {
            "title": "Terms & Notes",
            "context": "normal"
        }
    },
    "sa_estimate": {
        "si_estimate_line_items": {
            "title": "Management",
            "context": "normal"
        },
        "si_estimate_update": {
            "title": "Information",
            "context": "normal"
        },
        "si_estimate_history": {
            "title": "Estimate History",
            "context": "normal"
        },
        "si_doc_send": {
            "title": "Send Notification",
            "context": "normal"
        },
        "si_estimate_notes": {
            "title": "Terms & Notes",
            "context": "normal"
        }
    },
    "sa_project": {
        "si_project_information": {
            "title": "Information",
            "context": "normal"
        },
        "si_project_history": {
            "title": "History",
            "context": "normal"
        },
        "si_project_submit": {
            "title": "Update",
            "context": "side"
        },
        "psp_project_info": {
            "title": "Project Panorama",
            "context": "side"
        }
    }
}

Roles 1

ID Name
sa_clientClient

Capabilities 8

PHP Error Log 2 lines

[22-Jul-2021 13:22:40 UTC] PHP Notice:  Undefined variable: key in /wp-content/plugins/sprout-invoices/views/admin/addons/free-settings.php on line 38
[22-Jul-2021 13:22:53 UTC] ** Sprout_Invoices Already Loaded **
See also: All tests for this plugin, How to Hide Sprout Invoices Admin Menus and More