UNPKG

@anvilco/gatsby-plugin-segment-js

Version:

Easily add Segment JS snippet to your website

53 lines (40 loc) 3.81 kB
"use strict"; var _react = require("react"); var _react2 = _interopRequireDefault(_react); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } exports.onRenderBody = function (_ref, pluginOptions) { var setHeadComponents = _ref.setHeadComponents; var trackPage = pluginOptions.trackPage, prodKey = pluginOptions.prodKey, devKey = pluginOptions.devKey, _pluginOptions$host = pluginOptions.host, host = _pluginOptions$host === undefined ? "https://cdn.segment.io" : _pluginOptions$host, delayLoad = pluginOptions.delayLoad, delayLoadTime = pluginOptions.delayLoadTime, manualLoad = pluginOptions.manualLoad, customSnippet = pluginOptions.customSnippet; if (!prodKey || prodKey.length < 10) console.error("segment prodKey must be at least 10 char in length"); if (devKey && devKey.length < 10) console.error("if present, devKey must be at least 10 char in length"); var writeKey = process.env.NODE_ENV === "production" ? prodKey : devKey; var snippet = void 0; if (customSnippet) { snippet = eval('`' + customSnippet + '`'); } else { snippet = "!function(){var analytics=window.analytics=window.analytics||[];if(!analytics.initialize)if(analytics.invoked)window.console&&console.error&&console.error(\"Segment snippet included twice.\");else{analytics.invoked=!0;analytics.methods=[\"trackSubmit\",\"trackClick\",\"trackLink\",\"trackForm\",\"pageview\",\"identify\",\"reset\",\"group\",\"track\",\"ready\",\"alias\",\"debug\",\"page\",\"once\",\"off\",\"on\",\"addSourceMiddleware\",\"addIntegrationMiddleware\",\"setAnonymousId\",\"addDestinationMiddleware\"];analytics.factory=function(e){return function(){var t=Array.prototype.slice.call(arguments);t.unshift(e);analytics.push(t);return analytics}};for(var e=0;e<analytics.methods.length;e++){var key=analytics.methods[e];analytics[key]=analytics.factory(key)}analytics.load=function(key,e){var t=document.createElement(\"script\");t.type=\"text/javascript\";t.async=!0;t.src=\"" + host + "/analytics.js/v1/\" + key + \"/analytics.min.js\";var n=document.getElementsByTagName(\"script\")[0];n.parentNode.insertBefore(t,n);analytics._loadOptions=e};analytics._writeKey=\"" + writeKey + "\";analytics.SNIPPET_VERSION=\"4.13.2\";"; if (!(delayLoad || manualLoad)) { snippet += "\nanalytics.load('" + writeKey + "');"; if (trackPage) { snippet += 'analytics.page();'; } } snippet += '\n}}();'; } var delayedLoader = "\n window.segmentSnippetLoaded = false;\n window.segmentSnippetLoading = false;\n\n window.segmentSnippetLoader = function (callback) {\n if (!window.segmentSnippetLoaded && !window.segmentSnippetLoading) {\n window.segmentSnippetLoading = true;\n\n function loader() {\n window.analytics.load('" + writeKey + "');" + (trackPage ? 'window.analytics.page();' : '') + "\n window.segmentSnippetLoading = false;\n window.segmentSnippetLoaded = true;\n if(callback) {callback()}\n };\n\n setTimeout(\n function () {\n \"requestIdleCallback\" in window\n ? requestIdleCallback(function () {loader()})\n : loader();\n },\n " + delayLoadTime + " || 1000\n );\n }\n }\n window.addEventListener('scroll',function () {window.segmentSnippetLoader()}, { once: true });\n "; var snippetToUse = "\n " + (delayLoad && !manualLoad ? delayedLoader : "") + "\n " + snippet + "\n "; if (writeKey) { setHeadComponents([_react2.default.createElement("script", { key: "plugin-segment", dangerouslySetInnerHTML: { __html: snippetToUse } })]); } };