Top 10 Popular posts plugin for WordPress

Price: FREE
Sold By:

Tags: popular posts, top 10, counter, top posts, daily popular, page views, statistics, tracker
Contributors: webberzone, Ajay
Donate link:
Stable tag: trunk
Requires at least: 4.8
Tested up to: 5.3
License: GPLv2 or later

Track daily and total visits on your blog posts. Display the count as well as popular and trending posts.

== Description ==

WordPress doesn't have an in-built system to track page views or displaying popular posts. [Top 10]( is an easy to use, yet, powerful WordPress plugin that will count the number of page views of your posts, pages and any custom post types. You can then display the page view counts as well as display your most popular posts.

Top 10 adds two widgets that you can use to display a list of popular posts and the counta cross all your blog posts.

Although several similar plugins exist today, Top 10 is one of the most feature-rich popular post plugins with support for thumbnails, shortcodes, widgets, custom post types and CSS styles. The inbuilt caching system also helps reduce server load by caching your popular posts output. The tracking uses ajax and is thus compatible with most popular caching plugins.

Top 10 also has powerful API and is fully extendable with WordPress actions and filters to allow you easily extend the code base to add new features or tweak existing ones.

= Features =

* **Page counter**: Counts page views on single posts, pages and *custom post types* on an hourly basis which can then be easily displayed automatically, using shortcodes or functions
* **Popular posts**: Display a list of popular posts either for total counts or for a custom period. You can choose how many posts are to be displayed along with loads of other customisation options
* **Widget ready**: Sidebar widgets available for daily popular and overall popular posts. Highly customizable widgets to control what you want to display in the list of posts
* **Shortcodes**: The plugin includes two shortcodes `[tptn_list]` and `[tptn_views]` to display the posts list and the number of views respectively
* **Thumbnail support**
* Support for WordPress post thumbnails. Top 10 will create a custom image size (`tptn_thumbnail`) with the dimensions specified in the Settings page
* Auto-extract the first image in your post to be displayed as a thumbnail
* Manually enter the URL of the thumbnail via [WordPress meta fields]( Specify this using the meta box in your Edit screens.
* **Exclusions**: Exclude posts from select categories from appearing in the top posts list. Also exclude posts by ID from appearing in the list
* **Styles**: The output is wrapped in CSS classes which allows you to easily style the list. You can enter your custom CSS styles from within WordPress Admin area or use the style included.
* **Admin interface**: View list of daily and/or overall popular posts from within the dashboard. Top 10 also adds two sortable columns to your All Posts and All Pages pages in your WordPress Admin area
* **Export/Import interface**: Export the count tables and settings to restore in the same site or on other installs
* **Works with caching plugins** like WP-Super-Cache, W3 Total Cache or Quick Cache
* **Extendable code**: Top 10 has tonnes of filters and actions that allow any developer to easily add features, edit outputs, etc.

= GDPR =
Top 10 is GDPR compliant as it doesn't collect any personal data about your visitors when installed out of the box. You can see the data the plugin stores in the `wp_top_ten` and `wp_top_ten_daily` tables in the database. Note: the prefix `wp` might be different if you have changed it from the default.


= Donations =

I spend a significant amount of my free time maintaining, updating and more importantly supporting this plugin. If you have been using this plugin and find this useful, do consider making a donation. This helps me pay for my hosting and domains.

= Translations =
Top 10 is available for [translation directly on]( Check out the official [Translator Handbook]( to contribute.

= Contribute =

Top 10 is also available on [Github](
So, if you've got some cool feature that you'd like to implement into the plugin or a bug you've been able to fix, consider forking the project and sending me a pull request. Please don't use that for support requests.

== Screenshots ==

1. Top 10 options - General options
2. Top 10 options - Counter and Tracker options
3. Top 10 options - Popular post list options
4. Top 10 options - Thumbnail options
5. Top 10 options - Styles
6. Top 10 options - Maintenance
7. Top 10 options - Feed
8. Top 10 widget options
9. Top 10 Meta box on the Edit Post screen
10. Top 10 Tools page
11. Top 10 - Popular posts view in Admin
12. Top 10 Export/Import interface
13. Top 10 - Popular posts view in Network Admin

== Installation ==

= WordPress install (the easy way) =
1. Navigate to Plugins within your WordPress Admin Area

2. Click "Add new" and in the search box enter "Top 10"

3. Find the plugin in the list (usually the first result) and click "Install Now"

= Manual install =
1. Download the plugin

2. Extract the contents of to wp-content/plugins/ folder. You should get a folder called top-10.

3. Activate the Plugin in WP-Admin.

4. Go to **Top 10** to configure

5. Go to **Appearance » Widgets** to add the Popular Posts sidebar widget to your theme

6. Go to **Top 10 » View Popular Posts** to view the list of popular posts

== Frequently Asked Questions ==

Check out the [FAQ on the plugin page]( and the [FAQ on the WebberZone knowledgebase](
It is the fastest way to get support as I monitor the forums regularly. I also provide [premium *paid* support via email](

= How can I customise the output? =

Several customization options are available via the Settings page in WordPress Admin. You can access this via Settings » Top 10

The main CSS classes include:

* **tptn_posts** and **tptn_posts_daily**: Class of the main wrapper `div`. If you are displaying the related posts on non-singular pages, then you should style this

* **tptn_title**: Class of the `span` tag for title of the post

* **tptn_excerpt**: Class of the `span` tag for excerpt (if included)

* **tptn_thumb**: Class of the post thumbnail `img` tag

* **tptn_list_count**: Class of the `span` tag for post count in top posts list

* **tptn_counter**: Class of the `div` tag that wraps the post count that is driven by the field "Format to display the count in: " under 'Output Options'

= Shortcodes =

You can find details of the shortcodes in this [article](

= Manual install =

The below functions need to be added by editing your theme files where you wish to display them.

Display the post count with ``

Display the overall most popular posts with ``

Display the daily/custom period popular posts with ``

You can also use the WordPress Widgets to display the popular posts in your sidebar / other widgetized areas of your theme

View [examples of the plugin API]( to fetch the popular posts

= Can this plugin replace Google Analytics? =

No. Top 10 has been designed to only track the number of page-views on your blog posts and display the same. It isn't designed to replace Google Analytics or any other full fledged statistics application.

= How does the scheduled maintenance work? =

When you enabled the scheduled maintenance, Top 10 will create a cron job that will run at a predefined interval and clean up old entries from the `wp_top_ten_daily` table.
*Note: If you enable this option, WordPress will execute this job when it is scheduled the first time*

= How to make the columns on the Custom Post Type admin pages sortable? =
Add the following code to your functions.php file of your theme.

add_filter( 'manage_edit-{$cpt}_sortable_columns', 'tptn_column_register_sortable' );

Replace `{$cpt}` by the slug of your custom post type. E.g. to make the columns on your 'projects' post type sortable, you will need to add:
add_filter( 'manage_edit-projects_sortable_columns', 'tptn_column_register_sortable' );

== Changelog ==

= 2.8.0 =

Release post: [](

* Features:
* Custom feed for popular posts: Find new options under a new tab called Feed in the settings page where you can set the URL for the overall and daily feeds
* New page in the network admin menu to view the popular posts across the network
* Also delete transients and other settings on uninstall

= 2.7.0 =

Release post: [](

* Features:
* Recreate the Top 10 database tables. You can find the button in the Tools page. Backup your database first
* New export/import interface to export and import the Top 10 tables and settings

* Enhancements:
* `tptn_views` shortcode adds a new parameter 'count' to explicitly set the count type. Choose from daily, total or overall. This is overridden if daily is set to 0 (backwards compatibility)

= 2.6.3 =

Release post: [](

* Enhancements:
* `tptn_get_first_image` filter has additional attributes `$image_attributes[0], $postid, $thumb_width, $thumb_height`

* Bug fixes:
* Reverted PolyLang implementation that was broken in v2.6.2
* Delete deprecated settings on save
* Fix settings link in plugins listing page
* Fix exclude categories setting on save

= 2.6.2 =

* Enhancements:
* Select a date range in the Popular Posts listing page in the admin

* Bug fixes:
* Fixed "Published post date" setting was not working. Thanks [@jherrerai](
* Modified PolyLang and WPML function implementations

= 2.6.1 =

* Bug fixes:
* Fixed widget daily and hourly range not working which was broken in v2.6.0

= 2.6.0 =

* Features:
* New option to disable creation of image thumbnails. Find this under Thumbnail options
* Thumbnail HTML markup includes `srcset` and `sizes` attributes when available. Read [Responsive Images in WordPress 4.4](
* New option to turn on debug mode. You can turn this on when requesting support. Find it under the Counter/Tracker tab
* New option to add the tracker js file on all pages, not just singular pages. Helps with minification/concatenation
* New date filter in the Popular posts listing page to see the views on a particular date
* New option to turn ON/OFF the number formatting of the post counts. ON by default

* Enhancements:
* Load tracker in footer
* Renamed top-10-tracker.js to top-10-tracker.min.js

* Bug fixes:
* Only delete option if null value is passed to tptn_update_option
* "Exclude display on these post IDs" moved under Counter section

= 2.5.7 =

* Enhancements:
* Tools page now has the code to Recreate the PRIMARY KEY in case the button gives an error. You will need to run this in phpMyAdmin or Adminer

* Bug fixes:
* Fixed translation of " by " which had the incorrect text domain
* Post types to includes selects "post" in case no option is selected
* Unchecking all boxes of a "Display number of views on" setting would sometimes pick the default value

= 2.5.6 =

* Features:
* Added new button under Tools to recreate the PRIMARY KEYs

= 2.5.5 =

* Bug fixes:
* Fixed missing semi-colon in tracker code
* Multi-site tracking failed in old installs where the PRIMARY KEY was not properly updated in the database. DB version has been updated to 6.0 to initiate primary key across all installs

= 2.5.4 =

* Features:
* New button in the Tools page to delete the pre-2.5.x settings

* Enhancements:
* New function `tptn_trim_char` replaces `tptn_max_formatted_content` which should now support non-English characters as well
* Counts in the "Popular Posts" page are now number formatted

* Bug fixes:
* Fixed PHP Illegal string offset error

= 2.5.3 =

* Bug fixes:
* Fixed number of posts displayed in the popular posts list

= 2.5.2 =

* Bug fixes:
* Settings / Thumbnail / Thumbnail size did not display the correct option even though the admin had this correctly saved

= 2.5.1 =

* Bug fixes:
* Custom CSS did not get upgraded or saved properly
* Uninstalling the plugin will delete the settings properly

= 2.5.0 =

* Features:
* Upgrade old options to Settings API
* New widget to display the overall count i.e. visits across all your site posts
* Added a filter to override the number of days that maintenance considers to delete the database entries
* New option to disable tracking for logged in users. Find "Track logged-in users" under the "Counter/Tracker" tab in the settings screen

* Enhancements:
* Make $ajax_tptn_tracker global. Contributed by [@pkirk](

* Bug fixes:
* Make sure that $post object is available in `tptn_pc_content` filter. Contributed by [@mtws](
* When editing Attachment post types, metabox should now save correctly
* Disable `top_ten_nonce` as it wasn't needed for front-end users and conflicted with caching plugins

* Deprecated:
* `tptn_default_options` (no replacement) and `tptn_read_options` (Use `tptn_get_settings` instead)

For previous changelog entries, please refer to the separate changelog.txt file

== Upgrade Notice ==

= 2.6.3 =
* Bug fix release! Please verify your settings after upgrade.
Check the Changelog for more details

Top 10 Popular posts plugin for WordPress
Price: FREE

WordPress doesn't have an in-built system to track page views or displaying popular posts.

View Cart