- Add support for groupIdentify calls
- Added
trackingOptions
as a configuration option. This allows you to disable the automatic tracking of specific user properties such as ip_address, city, country, etc. See the Help Center Documentation for instructions on setting up th is configuration.
- Add more context to the 'No request sent' responses
- Add
resetSessionId
method that sets the sessionId to the current time.
- Fix bug where cookie data such as device id from older releases were not migrated
-
Allow for numeric user ids
-
Namespace local storage with api key to prevent cross domain contamination
- Default
forceHttps
option totrue
.
- Add
logLevel
config option
- Add
setSessionId(sesionId)
method. Note this is not recommended unless you know what are you doing. - Added support for Bower. Install using
bower install amplitude-js
. - Switched from webpack to Rollup for building the SDK.
- Supports clean NPM module loading eg:
const amplitude = require('amplitude');
orimport 'amplitude' from 'amplitude-js';
- SDK is now a proper UMD module. Supports RequireJS with r.js builds now.
- Updated build process to use webpack
- Handle SDK loading errors in the load snippet. Please update the load snippets on your website to the latest version.
- Migrating setup instructions and SDK documentation in the README file to Zendesk articles.
- Add
logEventWithTimestamp
to allow logging events with a custom timestamp. The timestamp should a number representing the time in milliseconds since epoch. See documentation for more details. - Add configuration option
deviceIdFromUrlParam
, which when set totrue
will have the SDK parse device IDs from url parameteramp_device_id
if available. Device IDs defined in the configuration options during init will take priority over device IDs from url parameters.
- Updated our UA-parser-js fork to properly parse the version number for Chrome Mobile browsers.
- Fix bug where tracking UTM params and referrer drops unsent events that have been saved to localStorage.
- Add option to track GCLID (Google Click ID) as a user property (set
includeGclid
totrue
in the SDK configuration). - Add option to track new UTM parameters, referrer, and GCLID values during the same session. By default the SDK only saves the values once at the start of the session. You can remove this restriction by setting
saveParamsReferrerOncePerSession
tofalse
in the SDK configuration. See the Readme for more information.
- Block event property and user property dictionaries that have more than 1000 items. This is to block properties that are set unintentionally (for example in a loop). A single call to
logEvent
should not have more than 1000 event properties. Similarly a single call tosetUserProperties
should not have more than 1000 user properties.
- Add configuration option
forceHttps
, which when set totrue
forces the SDK to always upload to HTTPS endpoint. By default the SDK uses the endpoint that matches the embedding site's protocol (for example if your site is HTTP, it will use the HTTP endpoint).
productId
is no longer a required field forRevenue
logged vialogRevenueV2
.- Track raw user agent string for backend filtering.
- Update README with link to our Google Tag Manager integration demo app.
- Fix bug where referrer and UTM params were being captured more than once per session.
- Add support for logging events to multiple Amplitude apps. Note this is a major update, and may break backwards compatability. See Readme for details.
- Init callback now passes the Amplitude instance as an argument to the callback function.
- Update our fork of UAParser.js from v0.7.7 to v0.7.10. This will improve the resolution of user agent strings to device and OS information.
- Silence console warnings for various UTM property keys with undefined values.
- Add support for setting groups for users and events. See the Readme for more information.
- Add
logRevenueV2
and newRevenue
class to support logging revenue events with properties, and revenue type. See Readme for more info. - Add helper method to regenerate a new random deviceId. This can be used to anonymize a user after they log out. Note this is not recommended unless you know what are you doing. See Readme for more information.
- Add tracking of each user's initial_utm parameters (which is captured as a set once operation). Utm parameters are now sent only once per user session.
- Add documentation for SDK functions. You can take a look here. A link has also been added to the Readme.
- Fix cookie test bug. In rare cases, the cookie test failed to delete the key used in testing. Reloading the page generated new keys, filling up the cookie over time. Fixed test to re-use the same key.
- Identify function now accepts a callback function as an argument. The callback will be run after the identify event is sent.
- Add support for
prepend
user property operation. This allows you to insert value(s) at the front of a list. See Readme for more details. - Keep sessions and event metadata in-sync across multiple windows/tabs.
- Fix bug where saveReferrer throws exception if sessionStorage is disabled.
- Log messages with a try/catch to support IE 8.
- Validate event properties during logEvent and initialization before sending request.
- Add instructions for proper integration with RequireJS.
- Add ability to clear all user properties.
- Add getSessionId helper method to fetch the current sessionId.
- Add support for append user property operation.
- Add tracking of each user's initial_referrer property (which is captured as a set once operation). Referrer property captured once per user session.
- If cookies are disabled by user, then fallback to localstorage to save the cookie data.
- Migrate sessionId, lastEventTime, eventId, identifyId, and sequenceNumber to cookie storage to support sessions across different subdomains.
- Fix bug where response code is not passed to XDomainRequest callback (affects IE versions 10 and lower).
- Localstorage is not persisted across subdomains, reverting cookie data migration and adding a reverse migration path for users already on 2.6.0.
- Migrate cookie data to local storage to address issue where having cookies disabled causes SDK to generate a new deviceId for returning users. - DEPRECATED
- Add support for user properties operations (set, setOnce, add, unset).
- Fix bug to run queued functions after script element is loaded and set to window.
- Add support for passing callback function to init.
- Fix bug to check that Window localStorage is available for use.
- Fix bug to prevent scheduling multiple event uploads.
- Add support for passing callback functions to logEvent.
- Add option to batch events into a single request.
- Fix bug where multi-byte unicode characters were hashed improperly.
- Add option to send referrer information as user properties.
- Use gzipped version of the library by default. If you still need the uncompressed version, remove ".gz" from the script url in your integration snippet.
- Upgrade user agent parser for browser detection to keep up-to-date with browser updates.
- Fix bug where Android browsers were reported as Safari on Linux.
- Fix bug with line endings in UTF-8 encoder that was causing issues with checksums.
- Add support for logging revenue data.
- Add opt out setting to disable logging for a user.
- Add option to gather UTM parameters and send them as event properties
- Add support for detecting new sessions
- Add language detection
- Fix detect.js for AMD compatibility
- Fix bug where session ids weren't stored when a session timed out
- Add setDeviceId method
- Fix iPad detection in user agent
- Calls to setUserProperties now merge new properties instead of replacing
- Fix bugs in cookies. Add reverse compatibility
- Incorporate browser/device detection
- Fix null/undefined error when missing config
- Add session tracking
- Add overrideable device id
- Fix error where events were not getting removed from local storage
- UTF-8 encode strings before MD5 hashing
- Update to version 2 of data collection API.
- Send client upload time and checksum
- Rename setGlobalUserProperties to setUserProperties
- Added ability to specifiy domain with cookies using setDomain method
- Fixed Base64 encode method if window doesn't have bota method
- Added try/catch around all public methods
- Added Internet Explorer compatibility for JSON, toString.call and Ajax request
- Add saveEvents configuration option
- Use native Base64 encoding when available
- Remove LZW/Base64 encoding from saving to localStorage to reduce latency
- Save user id and global user properties to cookie
- Save global user properties, change sdk url to https
- Initial release
- Add setVersionName function
- Default global properties to empty array