Demo to preview the settings

Introduction

View the entire database of time zone IDs, identify your time zone by latitude and longitude and convert a time stamp between two time zones using this plugin.

Prerequisites

  1. You must have the TimeZoneDB account.
Image without caption

How to set up

Getting your API key

Before you start using this plugin, you'll need to create an account to acquire your API key. Follow this link to create an account, then grab your API key (this will be conveniently included in the confirmation email) and paste it into your plugin setting area:
Image without caption
That's it! Head over to any of the next four pages to learn more about each individual API call offered in this plugin.

List Time Zones

Returns a list of all time zones and includes a variety of information about each zone.
πŸ”—

Create your design

In most cases, you'll be using this API to view the results in either a dropdown to select from, or for some backend workflow action. We're using a repeating group on our example page to demonstrate the proper data source, but you can use this call in a variety of other ways as needed.
Select "Get Data from External API" for the Data to display, then find "TimeZoneDB - List Zones" from the list of API Providers
Select "Get Data from External API" for the Data to display, then find "TimeZoneDB - List Zones" from the list of API Providers
That's it! Depending on your use case, you can select from any of the fields available from this API to either display zone names, calculate times from the GMT offset, or view country information.

Get Time and Zone by Position

Determine the time and zone based on a User's current position or a set of coordinates from your database.
πŸ”—

Create your design

In this example, we'll use the Current User's geographic position's latitude and longitude to determine the current time and zone they're in. To achieve this, we'll send the results of this API call to a group, and use that group as a datasource to feed the inputs.
Select Get Time and Zone by Position (TimeZoneDB) from the list of content options
Select Get Time and Zone by Position (TimeZoneDB) from the list of content options
Depending on how you nest your elements within this group, ensure wherever you're displaying the results has the ability to refer to this group's information.

Set up the API call

Since we're working with a group as our datasource, we'll use the "Display data in group" action to send the results of the API there.
Image without caption
That's it! You can now display any information from the API call in your group. In our example, we're showing the time zone name, the current time in that zone, as well as the GMT offset number.

Get Local Time by Zone

Returns the local time in a specified time zone.
πŸ”—

Create your design

In this example, we're using the previously created repeating group as our datasource for the dropdown. If you don't use this, simply swap out the datasource with another API call to list all time zones. This API uses the zoneName attribute, so if you choose to save time zone information to your database, use this value for this API call.
Image without caption

Set up the API call

Using the same approach as the last API, use a "Display data in group" action.
This API requires the zoneName attribute, so be sure to select that after selecting the value from this API call
This API requires the zoneName attribute, so be sure to select that after selecting the value from this API call

Converting the Time

The resulting API response will give you two options for displaying the time. The "formatted" attribute will give you a text-based value that is not easily converted to a date/time value. The "gmtOffset" will give you... you guessed it... the GMT Offset!
In the below example, we'll take the GMT Offset of the new time zone we're attempting to convert to and use it to calculate the new time. By using the Current Date Time (which is formatted in your time zone) and adding the number of GMT Offset minutes, this will give us the time in whatever zone you select.
Image without caption
That's it! After initiating the API call, you'll see the current time in whatever zone you select from the dropdown.

Convert Zones

Takes the time in one time zone and returns the converted time to match a second time zone.
πŸ”—

Create your design

In our example, we'll use two dropdowns that are pulling the list of timezones acquired from the List Time Zones API call earlier on our demo page.
Once you've determined your data source, you'll want to create a design that displays the final result. We'll be using the built-in date and time picker element Bubble provides to display the converted date/time.
Image without caption
Since the result of this API is only returning the converted time, the Original Time group isn't necessary. We added this to further illustrate the difference between the two zones that are selected. If you inspect the workflow action further, you'll notice we're using the Get Local Time by Zone API call to show the Original Time.
Where ever you're wanting to display the newly converted time, make sure it can accept the type of content TimeZoneDB - Convert Zones and send the data there.
Image without caption
By default, the API call will use the current UTC time, which is fine for this use-case. Should you want to insert a different time to have converted, that will be placed in the time parameter space.
That's it! Run your test to select a starting time zone and an ending time zone, the resulting date displayed will be the current time in the selected conversion zone.
Image without caption
Image without caption

Changelogs


Powered by Notaku