Title: Webxperthub Post Views &amp; Reading Time
Author: iftiarhossain
Published: <strong>May 24, 2026</strong>
Last modified: May 24, 2026

---

Search plugins

![](https://ps.w.org/webxperthub-post-views-reading-time/assets/banner-772x250.png?
rev=3545752)

![](https://ps.w.org/webxperthub-post-views-reading-time/assets/icon-256x256.png?
rev=3545752)

# Webxperthub Post Views & Reading Time

 By [iftiarhossain](https://profiles.wordpress.org/iftiarhossain/)

[Download](https://downloads.wordpress.org/plugin/webxperthub-post-views-reading-time.1.0.0.zip)

 * [Details](https://wordpress.org/plugins/webxperthub-post-views-reading-time/#description)
 * [Reviews](https://wordpress.org/plugins/webxperthub-post-views-reading-time/#reviews)
 *  [Installation](https://wordpress.org/plugins/webxperthub-post-views-reading-time/#installation)
 * [Development](https://wordpress.org/plugins/webxperthub-post-views-reading-time/#developers)

 [Support](https://wordpress.org/support/plugin/webxperthub-post-views-reading-time/)

## Description

Webxperthub Post Views & Reading Time is a lightweight WordPress plugin that automatically
tracks how many times each post is viewed and measures the total reading time accumulated
from all visitors. Perfect for bloggers, content creators, and site owners who want
to understand their audience engagement at a glance.

**Key Features:**

 * **View Tracking** – Automatically count the number of unique sessions viewing
   each post with intelligent bounce filtering
 * **Reading Time Analytics** – Measure actual time visitors spend reading your 
   posts
 * **Admin Dashboard Widget** – Beautiful analytics widget showing total views, 
   posts, and cumulative reading time
 * **Post List Columns** – Display views and reading time directly in the post list
   for quick reference
 * **Smart User Filtering** – Automatically excludes administrators, editors, authors,
   and contributors from view counts to track real visitor engagement
 * **Session-based Counting** – Prevents artificially inflating counts by tracking
   views per session, not per page load
 * **Security First** – Built with WordPress security standards including nonce 
   verification, input sanitization, and proper output escaping
 * **Lightweight & Efficient** – Minimal database footprint with optimized AJAX 
   requests and prepared statements
 * **Zero Configuration** – Works automatically after activation, no settings to
   configure
 * **Responsive Design** – Dashboard widget looks great on all screen sizes

### How It Works

**View Tracking Process:**
 1. When a visitor loads a post, JavaScript waits 2 seconds(
bounce filter) before sending a tracking request 2. An AJAX request is sent to your
WordPress backend 3. The view count for that post is incremented in the post meta
4. SessionStorage records that this post was counted in the current session to prevent
duplicates

**Reading Time Tracking Process:**
 1. JavaScript monitors how long a visitor spends
on the page 2. Timing begins after the initial 2-second bounce delay 3. Timing ends
when the visitor leaves the page or switches browser tabs 4. Only intervals of 3
+ seconds are counted (minimum threshold) 5. A maximum of 30-minute intervals are
recorded (filters outliers like tabs left open) 6. The accumulated time is added
to the post’s total reading time meta

**Dashboard Widget:**
 The admin dashboard displays: – Total number of published
posts – Sum of all views across all posts – Cumulative reading time from all visitors(
formatted as “X hours Y minutes”)

**Post List Columns:**
 Two new columns in the Posts list show: – Views: Total view
count for each post – Read Time: Total accumulated reading time (click column header
to sort)

### Technical Details

**Database:**
 – `_webxperthub_pvrt_view_count` — Stores the total view count for
each post – `_webxperthub_pvrt_reading_time` — Stores total reading time in seconds
for each post – Uses standard WordPress post meta (no custom tables)

**Security:**
 – All AJAX endpoints verify nonces for CSRF protection – User input
is sanitized and validated before use – Output is properly escaped for display –
User roles are verified to exclude staff accounts – Only published posts are tracked

**Performance:**
 – Efficient prepared statements for all database queries – Asynchronous
AJAX requests do not block user interaction – SessionStorage prevents redundant 
database calls – Minimal CSS and JavaScript payload – No external API calls or third-
party services

### Support

For support, feature requests, or bug reports, please visit the plugin’s WordPress.
org support forum. When posting, please include:

 1. A clear description of your issue
 2. Your WordPress version and PHP version
 3. A list of your currently active plugins
 4. Any error messages from your browser console (press F12)

### Credits

Developed by Iftiar Hossain — Webxperthub

### License

This plugin is licensed under the GPL-2.0-or-later license. You are free to use,
modify, and distribute this plugin under the terms of the GNU General Public License.

For more information about the GPL, visit: https://www.gnu.org/licenses/gpl-2.0.
html

## Installation

 1. Log in to your WordPress admin panel
 2. Navigate to **Plugins > Add New**
 3. Search for **“Webxperthub Post Views”**
 4. Click **Install Now** and then **Activate**
 5. Visit your **Dashboard** to see the new analytics widget
 6. Go to **Posts** to see the new Views and Read Time columns

**Manual Installation:**

 1. Download the plugin ZIP from WordPress.org
 2. Upload the `webxperthub-post-views-reading-time` folder to `/wp-content/plugins/`
 3. Activate the plugin through the **Plugins** menu in WordPress
 4. The plugin will start tracking immediately — no configuration required

## FAQ

### Does this plugin track admin views?

No. By design, administrators, editors, authors, and contributors are excluded from
view counts. Only real visitor views are counted, giving you accurate engagement
metrics.

### How accurate is the reading time?

Reading time is measured from actual visitor activity on your posts. It begins after
a 2-second initial delay (to filter out bounces) and stops when visitors leave the
page or switch tabs. Times are capped at 30 minutes to exclude outliers.

### Will this slow down my site?

No. The plugin uses efficient AJAX requests and minimal database queries. All tracking
is done asynchronously with no noticeable impact on site performance.

### How is the data stored?

All data is stored using WordPress standard post meta. No custom database tables
are created, keeping your database clean and easy to manage.

### Can I reset the view counts?

Currently, view and reading time data cannot be reset through the plugin interface.
You can manually remove the data through phpMyAdmin by deleting the post meta keys`
_webxperthub_pvrt_view_count` and `_webxperthub_pvrt_reading_time`.

### What browsers are supported?

The plugin works on all modern browsers including Chrome, Firefox, Safari, Edge,
and Opera. JavaScript must be enabled for tracking to work.

### Does this plugin use cookies?

The plugin uses browser sessionStorage (not cookies) to prevent double-counting 
views within the same session. SessionStorage is cleared automatically when the 
browser closes.

### Is my visitor data private?

Yes. All data is stored locally in your WordPress database. No information is sent
to external servers or third parties.

## Reviews

There are no reviews for this plugin.

## Contributors & Developers

“Webxperthub Post Views & Reading Time” is open source software. The following people
have contributed to this plugin.

Contributors

 *   [ iftiarhossain ](https://profiles.wordpress.org/iftiarhossain/)

[Translate “Webxperthub Post Views & Reading Time” into your language.](https://translate.wordpress.org/projects/wp-plugins/webxperthub-post-views-reading-time)

### Interested in development?

[Browse the code](https://plugins.trac.wordpress.org/browser/webxperthub-post-views-reading-time/),
check out the [SVN repository](https://plugins.svn.wordpress.org/webxperthub-post-views-reading-time/),
or subscribe to the [development log](https://plugins.trac.wordpress.org/log/webxperthub-post-views-reading-time/)
by [RSS](https://plugins.trac.wordpress.org/log/webxperthub-post-views-reading-time/?limit=100&mode=stop_on_copy&format=rss).

## Changelog

#### 1.0.0

 * Initial release
 * View tracking with bounce filtering
 * Reading time analytics with min/max thresholds
 * Admin dashboard widget with engagement metrics
 * Post list columns for views and reading time
 * Smart user role filtering
 * Security-first implementation with nonce verification

## Meta

 *  Version **1.0.0**
 *  Last updated **15 hours ago**
 *  Active installations **Fewer than 10**
 *  WordPress version ** 5.0 or higher **
 *  Tested up to **7.0**
 *  PHP version ** 7.4 or higher **
 * Tags
 * [analytics](https://wordpress.org/plugins/tags/analytics/)[engagement](https://wordpress.org/plugins/tags/engagement/)
   [post views](https://wordpress.org/plugins/tags/post-views/)[reading time](https://wordpress.org/plugins/tags/reading-time/)
   [tracking](https://wordpress.org/plugins/tags/tracking/)
 *  [Advanced View](https://wordpress.org/plugins/webxperthub-post-views-reading-time/advanced/)

## Ratings

No reviews have been submitted yet.

[Your review](https://wordpress.org/support/plugin/webxperthub-post-views-reading-time/reviews/#new-post)

[See all reviews](https://wordpress.org/support/plugin/webxperthub-post-views-reading-time/reviews/)

## Contributors

 *   [ iftiarhossain ](https://profiles.wordpress.org/iftiarhossain/)

## Support

Got something to say? Need help?

 [View support forum](https://wordpress.org/support/plugin/webxperthub-post-views-reading-time/)