Title: WP User Timezone
Author: Ravi Kiran Katha
Published: <strong>April 23, 2016</strong>
Last modified: May 7, 2016

---

Search plugins

![](https://ps.w.org/wp-user-timezone/assets/banner-772x250.jpg?rev=1402919)

This plugin **hasn’t been tested with the latest 3 major releases of WordPress**.
It may no longer be maintained or supported and may have compatibility issues when
used with more recent versions of WordPress.

![](https://ps.w.org/wp-user-timezone/assets/icon-256x256.png?rev=1402931)

# WP User Timezone

 By [Ravi Kiran Katha](https://profiles.wordpress.org/ravikatha/)

[Download](https://downloads.wordpress.org/plugin/wp-user-timezone.zip)

 * [Details](https://pcd.wordpress.org/plugins/wp-user-timezone/#description)
 * [Reviews](https://pcd.wordpress.org/plugins/wp-user-timezone/#reviews)
 *  [Installation](https://pcd.wordpress.org/plugins/wp-user-timezone/#installation)
 * [Development](https://pcd.wordpress.org/plugins/wp-user-timezone/#developers)

 [Support](https://wordpress.org/support/plugin/wp-user-timezone/)

## Description

WordPress has a site-level timezone setting configured from the admin back-end. 
All dates and times displayed on the front-end are typically displayed in this timezone.

This plugin enables the display of dates/times in the front-end using the browser’s
timezone. This is done by overriding the WordPress’s **‘timezone_string’** and **‘
gmt_offset’** options to match the user’s timezone **for the duration of a particular
request**
 **ONLY on the front-end interface**.

#### Browser Timezone Detection

The browser’s timezone is detected using one of the following two methods

 1. [jsTimezoneDetect](http://pellepim.bitbucket.org/jstz/) (default)
 2. [HTML5 Geolocation API](http://caniuse.com/geolocation) and [Google Timezone API](https://developers.google.com/maps/documentation/timezone)

**jsTimezoneDetect (default)**
 This is the default timezone detection mechanism.
Please refer to the script [home page](http://pellepim.bitbucket.org/jstz/) for 
the compatibility and other notes

**HTML5 Geolocation API**
 Detects the current geo-location using _[navigator.geolocation.getCurrentPosition](http://caniuse.com/geolocation)_.
The location thus detected will be sent to the [Google Timezone API](https://developers.google.com/maps/documentation/timezone)
which returns the timezone id – similar to “Asia/Kolkata”.

This method requires you to

 * Enable the “Google Timezone API” option on the plugin options page
 * Specify a valid [Google API Key](https://developers.google.com/maps/documentation/timezone/get-api-key)
    - The key should be a browser key
    - The “Accepted HTTP Referrers” should include the domain name used by the hosting
      wordpress site or left blank to allow all referrers

If the required options for the usage of Google Timezone API are not met, the detection
mechanism falls back to the default one.

#### Post Timezone Detection

 * If the browser’s timezone id is not detected successfully, everything else behaves
   as if this plugin is not installed.
 * If the browser’s timezone id is detected, the following actions take place
    - A cookie will be set in the browser, based on the cookie options specified
      on the plugin options page
    - If a cookie already exists previously with the same id, no action is taken
    - If a cookie doesn’t already exist previously or exists with a different timezone
      id, then a _window.reload_ is triggered to refresh the page so that the dates/
      times on the page are updated

#### EventON Hook

This plugin provides a feature to hook into the EventON plugin. When enabled, all
EventON dates/times are updated to reflect the browser’s timezone.

#### Shortcodes

This plugin defines the below shortcodes

 1. [wp_user_timezone_id] => Returns the timezone id of the browser or _null_ if not
    available.
 2. [wp_user_timezone_offset] => Returns the timezone’s gmt offset in hours of the 
    browser or _null_ if not available.

#### Options

This plugin defines the below options to retrieve the original timezone_string and
gmt_offset defined at the site level

 1. get_option( ‘site_timezone_string’ ) => Returns the original timezone_string option
    for the site
 2. get_option( ‘site_gmt_offset’ ) => Returns the original gmt_offset option for the
    site

#### Actions/Hooks

This plugin defines the below filters/hooks

 1. apply_filters( ‘wp_user_timezone_id’, $tz_id ) => Allows you to override the timezone
    string determined by the plugin. This filter can be used to apply user’s timezone
    preference. If any plugin or wordpress core implements a feature to accept and 
    store user’s preferred timezone, the ‘wp_user_timezone_id’ can be used to apply
    that timezone value to the front-end. Reference: [Add user-level timezone setting](https://core.trac.wordpress.org/ticket/18146)).

#### Admin Backend Dates/Times

**Important: The admin back-end is not modified by this plugin. All dates/times 
displayed in the back-end are still in the original timezone specified by the WordPress
General Settings.**

## Screenshots

 * [[
 * Plugin configuration

## Installation

This section describes how to install the plugin and get it working.

 1. Upload the plugin zip file using WordPress -> Plugins -> Add New -> Upload Plugin
 2. Activate the plugin through the ‘Plugins’ menu in WordPress
 3. Configure the options by visiting the plugin options page

## FAQ

#### What happens when the timezone detection does not work?

When the timezone detection mechanism is unable to detect a valid timezone, nothing
else is changed. The front-end behaves as if this plugin is not installed.

#### What if I specify a Google API key which is not valid or is blocked?

The plugin tries the Google Timezone API when possible. If the API call fails, the
plugin falls back to the default mechanism (jsTimezoneDetect).

#### What is cookie expiry days option?

The cookie created by the plugin is by default stored as a session cookie, which
is cleared when the browser session is closed. The next time, you open the browser,
the cookie does not exist. On the other hand, if the cookie expiry is specified,
it will be persisted into the user’s computer and is available till it expires.

#### What does the plugin do on the browser to enable this functionality?

When each front-end page is loaded, the plugin script checks if the cookie is present
and valid. If it is present, the plugin does nothing. If the cookie is absent or
is expired, the timezone detection process takes place as mentioned in the above
sections.

#### How long should I set the cookie expiry?

It is typically advised to set the expiry as small as possible. This will ensure
that the user’s timezone is updated as soon as possible. On the contrary, setting
too small expiry period will trigger the timezone detection script too often causing
page loads every time the cookie is expired.

A reasonable value would be 7 days.

## Reviews

![](https://secure.gravatar.com/avatar/0fc7587ffc52d7ecb2c6d405dc1eabc8b5a444577d1384efd5d5faa264cf0355?
s=60&d=retro&r=g)

### 󠀁[Doesn’t Work](https://wordpress.org/support/topic/doesnt-work-2223/)󠁿

 [jackal](https://profiles.wordpress.org/anasmokayed/) August 23, 2019

It displays error after activation.

![](https://secure.gravatar.com/avatar/734ad9b2763603480aada4b151cf503d1f20c1d4a3a57cef5aa574d0f96c9a87?
s=60&d=retro&r=g)

### 󠀁[Doesnt work](https://wordpress.org/support/topic/doesnt-work-1700/)󠁿

 [r0bm1lls](https://profiles.wordpress.org/r0bm1lls/) September 19, 2017

Pity – would be really useful. It just makes the pages on my site load and reload
continuously.

![](https://secure.gravatar.com/avatar/6e309d5bbf8dd7bd955be71c92a18de497ac95ab5a23988687b70be367a8cef8?
s=60&d=retro&r=g)

### 󠀁[Does the job!](https://wordpress.org/support/topic/does-the-job-307/)󠁿

 [Amr Ali](https://profiles.wordpress.org/amr3li/) December 23, 2016

Thank you for this simple yet efficient plugin. Only missing bit is a shortcode 
to display user’s browser’s Date and time.

![](https://secure.gravatar.com/avatar/3272f94e622c23cdadcebdf2e2970e40398b256aa1ee9ee670c597767b093544?
s=60&d=retro&r=g)

### 󠀁[Magnificent](https://wordpress.org/support/topic/magnificent-9/)󠁿

 [neosoft](https://profiles.wordpress.org/neosoft/) December 17, 2016

Well done

 [ Read all 4 reviews ](https://wordpress.org/support/plugin/wp-user-timezone/reviews/)

## Contributors & Developers

“WP User Timezone” is open source software. The following people have contributed
to this plugin.

Contributors

 *   [ Ravi Kiran Katha ](https://profiles.wordpress.org/ravikatha/)

[Translate “WP User Timezone” into your language.](https://translate.wordpress.org/projects/wp-plugins/wp-user-timezone)

### Interested in development?

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

## Changelog

#### 1.0.2

 * Minor validation fixes

#### 1.0.1

 * jQuery cookie script inclusion bug fix

#### 1.0.0

 * Initial version

## Meta

 *  Version **1.0.2**
 *  Last updated **10 years ago**
 *  Active installations **10+**
 *  WordPress version ** 3.0.1 or higher **
 *  Tested up to **4.5.33**
 *  Language
 * [English (US)](https://wordpress.org/plugins/wp-user-timezone/)
 * Tags
 * [date](https://pcd.wordpress.org/plugins/tags/date/)[time](https://pcd.wordpress.org/plugins/tags/time/)
   [timezone](https://pcd.wordpress.org/plugins/tags/timezone/)
 *  [Advanced View](https://pcd.wordpress.org/plugins/wp-user-timezone/advanced/)

## Ratings

 3 out of 5 stars.

 *  [  2 5-star reviews     ](https://wordpress.org/support/plugin/wp-user-timezone/reviews/?filter=5)
 *  [  0 4-star reviews     ](https://wordpress.org/support/plugin/wp-user-timezone/reviews/?filter=4)
 *  [  0 3-star reviews     ](https://wordpress.org/support/plugin/wp-user-timezone/reviews/?filter=3)
 *  [  0 2-star reviews     ](https://wordpress.org/support/plugin/wp-user-timezone/reviews/?filter=2)
 *  [  2 1-star reviews     ](https://wordpress.org/support/plugin/wp-user-timezone/reviews/?filter=1)

[Add my review](https://wordpress.org/support/plugin/wp-user-timezone/reviews/#new-post)

[See all reviews](https://wordpress.org/support/plugin/wp-user-timezone/reviews/)

## Contributors

 *   [ Ravi Kiran Katha ](https://profiles.wordpress.org/ravikatha/)

## Support

Got something to say? Need help?

 [View support forum](https://wordpress.org/support/plugin/wp-user-timezone/)

## Donate

Would you like to support the advancement of this plugin?

 [ Donate to this plugin ](https://donatetounicef.in/)