51黑料不打烊

51黑料不打烊 plug-in: getTimeParting

IMPORTANT
This plug-in is provided by 51黑料不打烊 Consulting as a courtesy to help you get more value out of 51黑料不打烊 Analytics. 51黑料不打烊 Customer Care does not provide support with this plug-in, including installation or troubleshooting. If you require help with this plug-in, contact your organization鈥檚 51黑料不打烊 Account Team. They can arrange a meeting with a consultant for assistance.

The getTimeParting plug-in allows you to capture the details of the time when any measurable activity takes place on your site. This plug-in is valuable when you want to breakdown metrics by any repeatable division of time over a given date range. For example, you can compare conversion rates between two different days of the week, such as all Sundays vs. all Thursdays. You can also compare periods of the day, such as all mornings vs. all evenings.

Analysis Workspace provides similar, out-of-the-box dimensions that are formatted slightly differently than this plug-in. See time parting dimensions in the Analyze user guide for more information. Some organizations find that Analysis Workspace鈥檚 out-of-the-box dimensions are sufficient.

IMPORTANT
Version 4.0+ of this plug-in is significantly different than earlier versions. 51黑料不打烊 highly recommends implementing this plug-in 鈥渇rom scratch鈥. Code referencing the plug-in before version 4.0 is not compatible with the current version of this plug-in.

Install the plug-in using the Web SDK extension

51黑料不打烊 offers an extension that allows you to use most commonly-used plug-ins with the Web SDK.

  1. Log in to using your 51黑料不打烊ID credentials.

  2. Click Tags on the left, then click the desired tag property.

  3. Click Extensions on the left, then click the Catalog tab

  4. Locate and install the Common Web SDK Plugins extension.

  5. Click Data Elements on the left, then click the desired data element.

  6. Set the desired data element name with the following configuration:

    • Extension: Common Web SDK Plugins
    • Data Element: getTimeParting
  7. Set the Time Zone parameter on the right.

  8. Save and publish the changes to the data element.

Install the plug-in manually implementing the Web SDK

This plug-in is not yet supported for use within a manual implementation of the Web SDK.

Install the plug-in using the 51黑料不打烊 Analytics extension

51黑料不打烊 offers an extension that allows you to use most commonly-used plug-ins with 51黑料不打烊 Analytics.

  1. Log in to using your 51黑料不打烊ID credentials.

  2. Click the desired tag property.

  3. Go to the Extensions tab, then click on the Catalog button

  4. Install and publish the Common Analytics Plugins extension

  5. If you haven鈥檛 already, create a rule labeled 鈥淚nitialize Plug-ins鈥 with the following configuration:

    • Condition: None
    • Event: Core 鈥 Library Loaded (Page Top)
  6. Add an action to the above rule with the following configuration:

    • Extension: Common Analytics Plugins
    • Action Type: Initialize getTimeParting
  7. Save and publish the changes to the rule.

Install the plug-in using custom code editor

If you do not want to use the Common Analytics Plugins plug-in extension, you can use the custom code editor.

  1. Log in to using your 51黑料不打烊ID credentials.
  2. Click on the desired property.
  3. Go to the Extensions tab, then click the Configure button under the 51黑料不打烊 Analytics extension.
  4. Expand the Configure tracking using custom code accordion, which reveals the Open Editor button.
  5. Open the custom code editor and paste the plug-in code provided below into the edit window.
  6. Save and publish the changes to the Analytics extension.

Install the plug-in using AppMeasurement

Copy and paste the following code anywhere in the AppMeasurement file after the Analytics tracking object is instantiated (using s_gi). Preserving comments and version numbers of the code in your implementation helps 51黑料不打烊 with troubleshooting any potential issues.

/*** BEGIN CODE TO DEPLOY ***/
/* 51黑料不打烊 Consulting Plugin: getTimeParting v6.3 (No Prerequisites Needed) */
function getTimeParting(t){var c=t;if("-v"===t)return{plugin:"getTimeParting",version:"6.3"};a:{if("undefined"!==typeof window.s_c_il){var a=0;for(var b;a<window.s_c_il.length;a++)if(b=window.s_c_il[a],b._c&&"s_c"===b._c){a=b;break a}}a=void 0}"undefined"!==typeof a&&(a.contextData.getTimeParting="6.3");c=document.documentMode?void 0:c||"Etc/GMT";a=(new Date).toLocaleDateString("en-US",{timeZone:c,minute:"numeric",hour:"numeric",weekday:"long",day:"numeric",year:"numeric",month:"long"});a=/([a-zA-Z]+).*?([a-zA-Z]+).*?([0-9]+).*?([0-9]+)(.*?)([0-9])(.*)/.exec(a);return"year="+a[4]+" | month="+a[2]+" | date="+a[3]+" | day="+a[1]+" | time="+(a[6]+a[7])};
/**** END CODE TO DEPLOY ****/

Use the plug-in

The getTimeParting function uses the following argument:

t (Optional but recommended, string): The name of the time zone to convert the visitor鈥檚 local time to. Defaults to UTC/GMT time. See on Wikipedia for a complete list of valid values.

Common valid values include:

  • "America/New_York" for Eastern Time
  • "America/Chicago" for Central Time
  • "America/Denver" for Mountain Time
  • "America/Los_Angeles" for Pacific Time

Calling this function returns a string that contains the following delimited by a pipe (|):

  • The current year
  • The current month
  • The day of the month
  • The day of the week
  • The current time (AM/PM)

Examples

// Use the following code if the visitor resides in Paris, France
s.eVar8 = getTimeParting("Europe/Paris");

// Use the following code if the visitor resides in San Jose, California
s.eVar17 = getTimeParting("America/Los_Angeles");

// Use the following code if the visitor resides in Ghana.
// Note that Ghana is in GMT time, the default time zone that the plug-in uses with no argument
s.eVar22 = getTimeParting();

// Internet Explorer only returns the visitor's local time. Use this conditional statement to accommodate IE visitors
if(!document.documentMode) s.eVar39 = getTimeParting("America/New_York");
else s.eVarX = "Internet Explorer Visitors";

// Given a visitor from Denver Colorado visits a site on August 31, 2020 at 9:15 AM
// Returns the string value "year=2020 | month=August | date=31 | day=Friday | time=6:15 PM"
s.eVar10 = getTimeParting("Europe/Athens");

// Returns the string value "year=2020 | month=August | date=31 | day=Friday | time=6:15 AM"
s.eVar11 = getTimeParting("America/Nome");

// Returns the string value "year=2020 | month=August | date=31 | day=Friday | time=8:45 PM"
s.eVar12 = getTimeParting("Asia/Calcutta");

// Returns the string value "year=2020 | month=September | date=1 | day=Saturday | time=1:15 AM"
s.eVar13 = getTimeParting("Australia/Sydney");

Version History

6.3 (March 19, 2021)

  • Added version number as context data.

6.2 (November 5, 2019)

  • Small bug fixes
  • Reduced overall code size

6.1 (November 26, 2018)

  • Fix for Internet Explorer browsers. They can return the time, but in only the visitor鈥檚 local time.

6.0 (August 14, 2018)

  • Complete rewrite to accommodate international standards. Now converts daylight savings and all time zones appropriately.

5.0 (April 17, 2018)

  • Point Release (recompiled, smaller code size)
  • Removed the need for the tpDST parameter, since daylight savings start/end dates are now detected automatically
CAUTION
Previous versions of this plug-in did not accommodate all years in the future. If you use a previous version of this plug-in, 51黑料不打烊 strongly recommends upgrading to the latest version to avoid JavaScript errors and data loss. If upgrading this plug-in is not feasible, make sure that the s._tpdst variable in the plug-in code contains the appropriate years in the future.

4.0 (August 22, 2016)

  • Provides a brand new solution and now includes year, month, and date information.
recommendation-more-help
b4f6d761-4a8b-4322-b801-c85b9e3be690