@sprig-technologies/sprig-browser 2.33.1 → 2.33.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/core.cjs CHANGED
@@ -1 +1 @@
1
- "use strict";Object.defineProperties(exports,{__esModule:{value:!0},[Symbol.toStringTag]:{value:"Module"}});const i=require("./metricsReporter-Cdy0iTSw.cjs"),e=require("./core-BSewKENy.cjs");exports.DismissReason=i.DismissReason,exports.SprigEvent=i.SprigEvent,exports.SprigAPI=e.SprigAPI,exports.default=e.core,exports.sprig=e.sprig;
1
+ "use strict";Object.defineProperties(exports,{__esModule:{value:!0},[Symbol.toStringTag]:{value:"Module"}});const i=require("./metricsReporter-BLXrIaei.cjs"),e=require("./core-B164snRL.cjs");exports.DismissReason=i.DismissReason,exports.SprigEvent=i.SprigEvent,exports.SprigAPI=e.SprigAPI,exports.default=e.core,exports.sprig=e.sprig;
package/dist/core.d.ts CHANGED
@@ -1897,6 +1897,7 @@ declare namespace sprigConfig {
1897
1897
  showSurveyCallback?: (surveyId?: number) => Promise<boolean>,
1898
1898
  calledFromApi?: boolean,
1899
1899
  ) => void;
1900
+ trackHistory?: ({ event: string }) => void;
1900
1901
  unmute: () => void;
1901
1902
  }
1902
1903
 
package/dist/core.js CHANGED
@@ -1,5 +1,5 @@
1
- import { D as r, S as e } from "./metricsReporter-Dsn4xUH7.js";
2
- import { S as o, c as p, s as t } from "./core-BPGg40bv.js";
1
+ import { D as r, S as e } from "./metricsReporter-uTmb1eaJ.js";
2
+ import { S as o, c as p, s as t } from "./core-C0XvmpIu.js";
3
3
  export {
4
4
  r as DismissReason,
5
5
  o as SprigAPI,
package/dist/electron.js CHANGED
@@ -1,13 +1,11 @@
1
1
  const o = () => typeof window < "u" && typeof window.process == "object" && window.process.type === "renderer" || !(typeof process > "u" || typeof process.versions != "object" || !process.versions.electron) || typeof navigator == "object" && typeof navigator.userAgent == "string" && navigator.userAgent.indexOf("Electron") >= 0;
2
2
  function s() {
3
- if (!o())
4
- throw new Error("Only can preload contextBridge within Electron apps.");
3
+ if (!o()) throw new Error("Only can preload contextBridge within Electron apps.");
5
4
  const { contextBridge: e, ipcRenderer: r } = require("electron");
6
5
  e.exposeInMainWorld("sprigAPI", { openUrl: (n) => r.send("sprig-sdk-url-open", { url: n }) });
7
6
  }
8
7
  function i() {
9
- if (!o())
10
- throw new Error("Only can register IPC within Electron apps.");
8
+ if (!o()) throw new Error("Only can register IPC within Electron apps.");
11
9
  const { shell: e, ipcMain: r } = require("electron");
12
10
  r.on("sprig-sdk-url-open", (n, { url: t }) => {
13
11
  e.openExternal(t);
package/dist/index.cjs CHANGED
@@ -1 +1 @@
1
- "use strict";Object.defineProperties(exports,{__esModule:{value:!0},[Symbol.toStringTag]:{value:"Module"}});const e=require("./core-BSewKENy.cjs");require("./replay.cjs");const r=require("./metricsReporter-Cdy0iTSw.cjs");exports.SprigAPI=e.SprigAPI,exports.default=e.core,exports.sprig=e.sprig,exports.DismissReason=r.DismissReason,exports.SprigEvent=r.SprigEvent;
1
+ "use strict";Object.defineProperties(exports,{__esModule:{value:!0},[Symbol.toStringTag]:{value:"Module"}});const e=require("./core-B164snRL.cjs");require("./replay.cjs");const r=require("./metricsReporter-BLXrIaei.cjs");exports.SprigAPI=e.SprigAPI,exports.default=e.core,exports.sprig=e.sprig,exports.DismissReason=r.DismissReason,exports.SprigEvent=r.SprigEvent;
package/dist/index.d.ts CHANGED
@@ -1897,6 +1897,7 @@ declare namespace sprigConfig {
1897
1897
  showSurveyCallback?: (surveyId?: number) => Promise<boolean>,
1898
1898
  calledFromApi?: boolean,
1899
1899
  ) => void;
1900
+ trackHistory?: ({ event: string }) => void;
1900
1901
  unmute: () => void;
1901
1902
  }
1902
1903
 
package/dist/index.js CHANGED
@@ -1,6 +1,6 @@
1
- import { S as i, c as o, s as p } from "./core-BPGg40bv.js";
1
+ import { S as i, c as o, s as p } from "./core-C0XvmpIu.js";
2
2
  import "./replay.js";
3
- import { D as t, S as m } from "./metricsReporter-Dsn4xUH7.js";
3
+ import { D as t, S as m } from "./metricsReporter-uTmb1eaJ.js";
4
4
  export {
5
5
  t as DismissReason,
6
6
  i as SprigAPI,
@@ -0,0 +1 @@
1
+ "use strict";var Y=Object.defineProperty;var j=(e,t,r)=>t in e?Y(e,t,{enumerable:!0,configurable:!0,writable:!0,value:r}):e[t]=r;var l=(e,t,r)=>j(e,typeof t!="symbol"?t+"":t,r);var U=(e=>(e.Closed="close.click",e.Complete="survey.completed",e.FeedbackClosed="feedback.closed",e.PageChange="page.change",e.API="api",e.Override="override",e))(U||{}),A=(e=>(e.ReplayCapture="replay.capture",e.FeedbackButtonLoaded="feedback.button.loaded",e.SDKReady="sdk.ready",e.SurveyAppeared="survey.appeared",e.SurveyCloseRequested="survey.closeRequested",e.SurveyClosed="survey.closed",e.SurveyDimensions="survey.dimensions",e.SurveyFadingOut="survey.fadingOut",e.SurveyHeight="survey.height",e.SurveyPresented="survey.presented",e.SurveyLifeCycle="survey.lifeCycle",e.SurveyWidth="survey.width",e.SurveyWillClose="survey.willClose",e.SurveyWillPresent="survey.will.present",e.CloseSurveyOnOverlayClick="close.survey.overlayClick",e.VisitorIDUpdated="visitor.id.updated",e.QuestionAnswered="question.answered",e))(A||{});let m;const H=new Uint8Array(16);function q(){if(!m&&(m=typeof crypto<"u"&&crypto.getRandomValues&&crypto.getRandomValues.bind(crypto),!m))throw new Error("crypto.getRandomValues() not supported. See https://github.com/uuidjs/uuid#getrandomvalues-not-supported");return m(H)}const o=[];for(let e=0;e<256;++e)o.push((e+256).toString(16).slice(1));const w={randomUUID:typeof crypto<"u"&&crypto.randomUUID&&crypto.randomUUID.bind(crypto)},b=new class{constructor(){l(this,"breadcrumbs",[])}getTimeStamp(){return new Date().toISOString()}addBreadcrumb(e){this.breadcrumbs.push(e),this.breadcrumbs.length>300&&this.breadcrumbs.shift()}debug(e,t="debug"){this.addBreadcrumb({category:t,level:"info",message:e,timestamp:this.getTimeStamp(),type:"debug"})}error(e,t={}){this.addBreadcrumb({category:"error",data:t,level:"error",message:e,timestamp:this.getTimeStamp(),type:"error"})}http(e,t){this.addBreadcrumb({category:"xhr",data:t,message:e,timestamp:this.getTimeStamp(),type:"http"})}info(e,t={}){this.addBreadcrumb({category:"info",data:t,level:"info",message:e,timestamp:this.getTimeStamp(),type:"info"})}navigation(e,t){this.addBreadcrumb({category:"navigation",data:t,message:e,timestamp:this.getTimeStamp(),type:"navigation"})}};var B=class extends Error{constructor(e,t,r){super(`Possible EventEmitter memory leak detected. ${r} ${t.toString()} listeners added. Use emitter.setMaxListeners() to increase limit`),this.emitter=e,this.type=t,this.count=r,this.name="MaxListenersExceededWarning"}},D=class{static listenerCount(e,t){return e.listenerCount(t)}constructor(){this.events=new Map,this.maxListeners=D.defaultMaxListeners,this.hasWarnedAboutPotentialMemoryLeak=!1}_emitInternalEvent(e,t,r){this.emit(e,t,r)}_getListeners(e){return Array.prototype.concat.apply([],this.events.get(e))||[]}_removeListener(e,t){const r=e.indexOf(t);return r>-1&&e.splice(r,1),[]}_wrapOnceListener(e,t){const r=(...s)=>(this.removeListener(e,r),t.apply(this,s));return Object.defineProperty(r,"name",{value:t.name}),r}setMaxListeners(e){return this.maxListeners=e,this}getMaxListeners(){return this.maxListeners}eventNames(){return Array.from(this.events.keys())}emit(e,...t){const r=this._getListeners(e);return r.forEach(s=>{s.apply(this,t)}),r.length>0}addListener(e,t){this._emitInternalEvent("newListener",e,t);const r=this._getListeners(e).concat(t);if(this.events.set(e,r),this.maxListeners>0&&this.listenerCount(e)>this.maxListeners&&!this.hasWarnedAboutPotentialMemoryLeak){this.hasWarnedAboutPotentialMemoryLeak=!0;const s=new B(this,e,this.listenerCount(e));console.warn(s)}return this}on(e,t){return this.addListener(e,t)}once(e,t){return this.addListener(e,this._wrapOnceListener(e,t))}prependListener(e,t){const r=this._getListeners(e);if(r.length>0){const s=[t].concat(r);this.events.set(e,s)}else this.events.set(e,r.concat(t));return this}prependOnceListener(e,t){return this.prependListener(e,this._wrapOnceListener(e,t))}removeListener(e,t){const r=this._getListeners(e);return r.length>0&&(this._removeListener(r,t),this.events.set(e,r),this._emitInternalEvent("removeListener",e,t)),this}off(e,t){return this.removeListener(e,t)}removeAllListeners(e){return e?this.events.delete(e):this.events.clear(),this}listeners(e){return Array.from(this._getListeners(e))}listenerCount(e){return this._getListeners(e).length}rawListeners(e){return this.listeners(e)}},C=D;C.defaultMaxListeners=10;const F=new C,S=async e=>{await new Promise(t=>{setTimeout(t,e)})};class x{constructor(t){l(this,"storage");l(this,"tempStorage",{});l(this,"isStorageAvailable");try{this.storage=window[t];const r="__storage_test__";this.storage.setItem(r,r),this.storage.removeItem(r),this.isStorageAvailable=!0}catch{this.isStorageAvailable=!1}}setItem(t,r){this.isStorageAvailable&&this.storage?this.storage.setItem(t,r):this.tempStorage[t]=r}setItemObject(t,r){try{this.setItem(t,JSON.stringify(r))}catch(s){s instanceof Error&&(s.stack=t+": "+r,window.UserLeap.reportError("Failed to save to local storage",s))}}getItem(t){return this.isStorageAvailable&&this.storage?this.storage.getItem(t):this.tempStorage[t]}getItemObject(t){const r=this.getItem(t);if(r)try{return JSON.parse(r)}catch(s){s instanceof Error&&(s.stack=t+": "+r,window.UserLeap.reportError("Failed to parse local storage",s))}return{}}removeItem(t){this.isStorageAvailable&&this.storage?this.storage.removeItem(t):delete this.tempStorage[t]}clear(){this.isStorageAvailable&&this.storage?this.storage.clear():this.tempStorage={}}}const J=new x("sessionStorage"),$=new x("localStorage");class K{constructor(t){l(this,"payload");l(this,"promise");l(this,"reject",()=>{});l(this,"resolve",()=>{});this.payload=t,this.promise=new Promise((r,s)=>{this.reject=s,this.resolve=r})}resolveRequest(t){this.resolve(t)}}const E={replay:null},G=()=>{const e=[];return E.replay&&e.push("replay"),e.join(",")},z=10;let T=!1,M="",g=!1,P=!1,y=[];const Q=e=>e._config&&e._config.installationMethod?e._config.installationMethod:e._gtm?"web-gtm":e._segment?"web-segment":"web-snippet",N=(e="")=>{T=!0,M=e},R=async({shouldDropOnRateLimit:e,...t})=>{if(e)return{status:429};{const r=new K(t);return y.push(r),r.promise}},v=async(e,t)=>{const{retries:r=0,shouldDropOnRateLimit:s=!1,shouldRetryRequest:i=!1,...n}=t,d={url:e,options:n,retries:r,shouldDropOnRateLimit:s};if(g&&!i)return R(d);const u={ok:!1,reportError:!1};if(T)return console.info(`UserLeap - ${M}`),u;try{const c=await fetch(e,n);if(c.status===429){if(!g&&!s||i){g=!0;const a=c.headers.has("ratelimit-reset")?Number(c.headers.get("ratelimit-reset")):z;return await S(1e3*a),v(e,{...n,shouldDropOnRateLimit:s,shouldRetryRequest:!0})}return R(d)}if(g=!1,y.length&&(y.map(a=>{const h=a.payload;v(h.url,{...h.options,retries:h.retries,shouldDropOnRateLimit:h.shouldDropOnRateLimit}).then(W=>{a.resolveRequest(W)})}),y=[]),c.ok){if(c.status===249)return N(),u;const a=await c.text();try{return a&&a!=="OK"&&(c.json=JSON.parse(a)),c}catch{return{ok:!1,reportError:!1,error:new Error(`failed parsing response json for ${e} - ${a}`)}}}return c}catch(c){const a=r+1;return a>5||P?{ok:!1,reportError:!1,error:c}:(await S(1e3*Math.pow(2,r)),v(e,{...n,retries:a}))}},I=Object.freeze({contains:(e,t)=>t.includes(e),notContains:(e,t)=>!t.includes(e),exactly:(e,t)=>t===e,notExactly:(e,t)=>t!==e,startsWith:(e,t)=>t.startsWith(e),endsWith:(e,t)=>t.endsWith(e),regex:(e,t)=>new RegExp(e).test(t),legacy:(e,t)=>new RegExp(e,"i").test(t)});function k(e,t){const{matchType:r,pattern:s}=e,i=r?I[r]:I.legacy;let n=!1;try{n=i(s,t)}catch(d){const u=`[Sprig] (ERR-445) Failed to check url match with pattern ${s}`;d instanceof Error&&(console.warn(u,d),d.stack=JSON.stringify(e),window.UserLeap.reportError(u,d))}return n}let V=!0,f=!1;const X=["sdk_event_queue_latency_seconds","sdk_replay_add_event_batch_seconds","sdk_replay_cleanup_seconds","sdk_replay_compression_seconds","sdk_replay_get_events_between_seconds","sdk_replay_snapshot_seconds","sdk_mutations_nodes_added","sdk_mutations_nodes_removed","sdk_mutations_attributes_changed","sdk_mutations_character_data","sdk_dom_nodes_count","sdk_page_html_characters"];let L,p={};class Z{constructor(t){l(this,"_values",[]);l(this,"_isWebMetric");this.name=t,this._isWebMetric=X.includes(this.name)}report(t){if(V&&this._values.push({time:Date.now(),value:t}),f||!this._isWebMetric)return;const r=this.findExceededThreshold(t);r&&L&&L(t,r)}collect(){const t=this._values;return this._values=[],t}findExceededThreshold(t){const r=p[this.name];if(r)return r.find(s=>this.valueExceedsThreshold(t,s))}valueExceedsThreshold(t,r){return r.type==="max"?t>r.value:r.type==="min"&&t<r.value}}const _={},O=e=>{const t=new Z(e);return _[e]=t,t};exports.DismissReason=U,exports.EVENTS={FEEDBACK_BUTTON_LOADED:"feedback.button.loaded",SDK_READY:"sdk.ready",SURVEY_APPEARED:"survey.appeared",SURVEY_CLOSED:"survey.closed",SURVEY_DIMENSIONS:"survey.dimensions",SURVEY_FADING_OUT:"survey.fadingOut",SURVEY_HEIGHT:"survey.height",SURVEY_WIDTH:"survey.width",SURVEY_PRESENTED:"survey.presented",SURVEY_LIFE_CYCLE:"survey.lifeCycle",SURVEY_WILL_CLOSE:"survey.willClose",SURVEY_WILL_PRESENT:"survey.will.present",QUESTION_ANSWERED:"question.answered",REPLAY_CAPTURE:"replay.capture",CLOSE_SURVEY_ON_OVERLAY_CLICK:"close.survey.overlayClick",VISITOR_ID_UPDATED:"visitor.id.updated",DATA:{DISMISS_REASONS:{API:"api",CLOSED:"close.click",COMPLETE:"survey.completed",PAGE_CHANGE:"page.change",OVERRIDE:"override"},SURVEY_ID:"survey.id"}},exports.PerformanceMetrics=_,exports.SprigEvent=A,exports.breadcrumbsLogger=b,exports.checkUrlMatch=k,exports.checkUrlStillMatching=e=>{const{pageUrlEvents:t}=window.UserLeap._config,r=t==null?void 0:t.find(s=>s.id===e);return!!r&&k(r,window.location.href)},exports.cspViolationHandler=e=>{var t;(t=e==null?void 0:e.blockedURI)!=null&&t.includes(window.UserLeap._API_URL)&&(P=!0,console.warn(`[Sprig] ${e.blockedURI} is blocked by Content-Security-Policy`))},exports.delay=S,exports.disableThresholdChecking=()=>f=!0,exports.eventEmitter=F,exports.getHttpHeaders=function(e={}){const t={"Content-Type":"application/json","userleap-platform":"web","x-ul-sdk-version":"2.33.2","x-ul-installation-method":Q(e),"sprig-modules":G()};if(e.envId&&(t["x-ul-environment-id"]=e.envId),e.token&&(t.Authorization="Bearer "+e.token),e.userId&&(t["x-ul-user-id"]=e.userId),e.visitorId&&(t["x-ul-visitor-id"]=e.visitorId),e.partnerAnonymousId&&(t["x-ul-anonymous-id"]=e.partnerAnonymousId),e.mobileHeadersJSON){const r=JSON.parse(e.mobileHeadersJSON);Object.assign(t,r)}return e.locale&&(t["accept-language"]=e.locale),window.previewMode&&(t["x-ul-preview-mode"]="1"),t},exports.initPerformanceReporting=({reportingIntervalSeconds:e,postMetrics:t})=>{e?setInterval(()=>{(async r=>{const s=Object.values(_).map(i=>({name:i.name,values:i.collect()}));if(s.some(i=>i.values.length))try{await r(JSON.stringify(s))}catch(i){i instanceof Error&&b.error("MetricsErr",{error:{message:i.message,name:i.name}})}})(t)},1e3*e):V=!1},exports.killNetworkRequests=N,exports.localStorageHelper=$,exports.modules=E,exports.registerMetric=O,exports.registerReplay=e=>{E.replay=e},exports.registerThresholds=(e,t)=>{p={},f=!1,e==null||e.forEach(r=>{var s;r.metric in p||(p[r.metric]=[]),(s=p[r.metric])==null||s.push(r)}),L=t},exports.reportAndRegister=(e,t)=>{let r=_[e];return r||(r=O(e)),r.report(t)},exports.sessionStorageHelper=J,exports.shouldDirectEmbed=({"userleap-platform":e})=>{var t;return((t=window.UserLeap)==null?void 0:t.forceDirectEmbed)||e!=="web"},exports.sprigFetch=v,exports.v4=function(e,t,r){if(w.randomUUID&&!e)return w.randomUUID();const s=(e=e||{}).random||(e.rng||q)();return s[6]=15&s[6]|64,s[8]=63&s[8]|128,function(i,n=0){return o[i[n+0]]+o[i[n+1]]+o[i[n+2]]+o[i[n+3]]+"-"+o[i[n+4]]+o[i[n+5]]+"-"+o[i[n+6]]+o[i[n+7]]+"-"+o[i[n+8]]+o[i[n+9]]+"-"+o[i[n+10]]+o[i[n+11]]+o[i[n+12]]+o[i[n+13]]+o[i[n+14]]+o[i[n+15]]}(s)};
@@ -1,22 +1,19 @@
1
1
  var T = Object.defineProperty;
2
2
  var P = (e, t, s) => t in e ? T(e, t, { enumerable: !0, configurable: !0, writable: !0, value: s }) : e[t] = s;
3
- var l = (e, t, s) => (P(e, typeof t != "symbol" ? t + "" : t, s), s);
3
+ var l = (e, t, s) => P(e, typeof t != "symbol" ? t + "" : t, s);
4
4
  var M = ((e) => (e.Closed = "close.click", e.Complete = "survey.completed", e.FeedbackClosed = "feedback.closed", e.PageChange = "page.change", e.API = "api", e.Override = "override", e))(M || {}), N = ((e) => (e.ReplayCapture = "replay.capture", e.FeedbackButtonLoaded = "feedback.button.loaded", e.SDKReady = "sdk.ready", e.SurveyAppeared = "survey.appeared", e.SurveyCloseRequested = "survey.closeRequested", e.SurveyClosed = "survey.closed", e.SurveyDimensions = "survey.dimensions", e.SurveyFadingOut = "survey.fadingOut", e.SurveyHeight = "survey.height", e.SurveyPresented = "survey.presented", e.SurveyLifeCycle = "survey.lifeCycle", e.SurveyWidth = "survey.width", e.SurveyWillClose = "survey.willClose", e.SurveyWillPresent = "survey.will.present", e.CloseSurveyOnOverlayClick = "close.survey.overlayClick", e.VisitorIDUpdated = "visitor.id.updated", e.QuestionAnswered = "question.answered", e))(N || {});
5
5
  const X = { FEEDBACK_BUTTON_LOADED: "feedback.button.loaded", SDK_READY: "sdk.ready", SURVEY_APPEARED: "survey.appeared", SURVEY_CLOSED: "survey.closed", SURVEY_DIMENSIONS: "survey.dimensions", SURVEY_FADING_OUT: "survey.fadingOut", SURVEY_HEIGHT: "survey.height", SURVEY_WIDTH: "survey.width", SURVEY_PRESENTED: "survey.presented", SURVEY_LIFE_CYCLE: "survey.lifeCycle", SURVEY_WILL_CLOSE: "survey.willClose", SURVEY_WILL_PRESENT: "survey.will.present", QUESTION_ANSWERED: "question.answered", REPLAY_CAPTURE: "replay.capture", CLOSE_SURVEY_ON_OVERLAY_CLICK: "close.survey.overlayClick", VISITOR_ID_UPDATED: "visitor.id.updated", DATA: { DISMISS_REASONS: { API: "api", CLOSED: "close.click", COMPLETE: "survey.completed", PAGE_CHANGE: "page.change", OVERRIDE: "override" }, SURVEY_ID: "survey.id" } };
6
6
  let m;
7
7
  const V = new Uint8Array(16);
8
8
  function W() {
9
- if (!m && (m = typeof crypto < "u" && crypto.getRandomValues && crypto.getRandomValues.bind(crypto), !m))
10
- throw new Error("crypto.getRandomValues() not supported. See https://github.com/uuidjs/uuid#getrandomvalues-not-supported");
9
+ if (!m && (m = typeof crypto < "u" && crypto.getRandomValues && crypto.getRandomValues.bind(crypto), !m)) throw new Error("crypto.getRandomValues() not supported. See https://github.com/uuidjs/uuid#getrandomvalues-not-supported");
11
10
  return m(V);
12
11
  }
13
12
  const a = [];
14
- for (let e = 0; e < 256; ++e)
15
- a.push((e + 256).toString(16).slice(1));
13
+ for (let e = 0; e < 256; ++e) a.push((e + 256).toString(16).slice(1));
16
14
  const f = { randomUUID: typeof crypto < "u" && crypto.randomUUID && crypto.randomUUID.bind(crypto) };
17
15
  function Z(e, t, s) {
18
- if (f.randomUUID && !t && !e)
19
- return f.randomUUID();
16
+ if (f.randomUUID && !e) return f.randomUUID();
20
17
  const r = (e = e || {}).random || (e.rng || W)();
21
18
  return r[6] = 15 & r[6] | 64, r[8] = 63 & r[8] | 128, function(n, i = 0) {
22
19
  return a[n[i + 0]] + a[n[i + 1]] + a[n[i + 2]] + a[n[i + 3]] + "-" + a[n[i + 4]] + a[n[i + 5]] + "-" + a[n[i + 6]] + a[n[i + 7]] + "-" + a[n[i + 8]] + a[n[i + 9]] + "-" + a[n[i + 10]] + a[n[i + 11]] + a[n[i + 12]] + a[n[i + 13]] + a[n[i + 14]] + a[n[i + 15]];
@@ -109,8 +106,7 @@ var j = class extends Error {
109
106
  if (s.length > 0) {
110
107
  const r = [t].concat(s);
111
108
  this.events.set(e, r);
112
- } else
113
- this.events.set(e, s.concat(t));
109
+ } else this.events.set(e, s.concat(t));
114
110
  return this;
115
111
  }
116
112
  prependOnceListener(e, t) {
@@ -173,12 +169,11 @@ class O {
173
169
  }
174
170
  getItemObject(t) {
175
171
  const s = this.getItem(t);
176
- if (s)
177
- try {
178
- return JSON.parse(s);
179
- } catch (r) {
180
- r instanceof Error && (r.stack = t + ": " + s, window.UserLeap.reportError("Failed to parse local storage", r));
181
- }
172
+ if (s) try {
173
+ return JSON.parse(s);
174
+ } catch (r) {
175
+ r instanceof Error && (r.stack = t + ": " + s, window.UserLeap.reportError("Failed to parse local storage", r));
176
+ }
182
177
  return {};
183
178
  }
184
179
  removeItem(t) {
@@ -219,7 +214,7 @@ const J = (e) => e._config && e._config.installationMethod ? e._config.installat
219
214
  U = !0, A = e;
220
215
  };
221
216
  function ae(e = {}) {
222
- const t = { "Content-Type": "application/json", "userleap-platform": "web", "x-ul-sdk-version": "2.33.1", "x-ul-installation-method": J(e), "sprig-modules": B() };
217
+ const t = { "Content-Type": "application/json", "userleap-platform": "web", "x-ul-sdk-version": "2.33.2", "x-ul-installation-method": J(e), "sprig-modules": B() };
223
218
  if (e.envId && (t["x-ul-environment-id"] = e.envId), e.token && (t.Authorization = "Bearer " + e.token), e.userId && (t["x-ul-user-id"] = e.userId), e.visitorId && (t["x-ul-visitor-id"] = e.visitorId), e.partnerAnonymousId && (t["x-ul-anonymous-id"] = e.partnerAnonymousId), e.mobileHeadersJSON) {
224
219
  const s = JSON.parse(e.mobileHeadersJSON);
225
220
  Object.assign(t, s);
@@ -227,19 +222,16 @@ function ae(e = {}) {
227
222
  return e.locale && (t["accept-language"] = e.locale), window.previewMode && (t["x-ul-preview-mode"] = "1"), t;
228
223
  }
229
224
  const w = async ({ shouldDropOnRateLimit: e, ...t }) => {
230
- if (e)
231
- return { status: 429 };
225
+ if (e) return { status: 429 };
232
226
  {
233
227
  const s = new q(t);
234
228
  return g.push(s), s.promise;
235
229
  }
236
230
  }, v = async (e, t) => {
237
231
  const { retries: s = 0, shouldDropOnRateLimit: r = !1, shouldRetryRequest: n = !1, ...i } = t, d = { url: e, options: i, retries: s, shouldDropOnRateLimit: r };
238
- if (y && !n)
239
- return w(d);
232
+ if (y && !n) return w(d);
240
233
  const u = { ok: !1, reportError: !1 };
241
- if (U)
242
- return console.info(`UserLeap - ${A}`), u;
234
+ if (U) return console.info(`UserLeap - ${A}`), u;
243
235
  try {
244
236
  const c = await fetch(e, i);
245
237
  if (c.status === 429) {
@@ -256,8 +248,7 @@ const w = async ({ shouldDropOnRateLimit: e, ...t }) => {
256
248
  o.resolveRequest(x);
257
249
  });
258
250
  }), g = []), c.ok) {
259
- if (c.status === 249)
260
- return H(), u;
251
+ if (c.status === 249) return H(), u;
261
252
  const o = await c.text();
262
253
  try {
263
254
  return o && o !== "OK" && (c.json = JSON.parse(o)), c;
@@ -296,8 +287,7 @@ class G {
296
287
  this.name = t, this._isWebMetric = K.includes(this.name);
297
288
  }
298
289
  report(t) {
299
- if (C && this._values.push({ time: Date.now(), value: t }), S || !this._isWebMetric)
300
- return;
290
+ if (C && this._values.push({ time: Date.now(), value: t }), S || !this._isWebMetric) return;
301
291
  const s = this.findExceededThreshold(t);
302
292
  s && _ && _(t, s);
303
293
  }
@@ -307,8 +297,7 @@ class G {
307
297
  }
308
298
  findExceededThreshold(t) {
309
299
  const s = p[this.name];
310
- if (s)
311
- return s.find((r) => this.valueExceedsThreshold(t, r));
300
+ if (s) return s.find((r) => this.valueExceedsThreshold(t, r));
312
301
  }
313
302
  valueExceedsThreshold(t, s) {
314
303
  return s.type === "max" ? t > s.value : s.type === "min" && t < s.value;
@@ -329,12 +318,11 @@ const le = (e, t) => {
329
318
  e ? setInterval(() => {
330
319
  (async (s) => {
331
320
  const r = Object.values(E).map((n) => ({ name: n.name, values: n.collect() }));
332
- if (r.some((n) => n.values.length))
333
- try {
334
- await s(JSON.stringify(r));
335
- } catch (n) {
336
- n instanceof Error && Y.error("MetricsErr", { error: { message: n.message, name: n.name } });
337
- }
321
+ if (r.some((n) => n.values.length)) try {
322
+ await s(JSON.stringify(r));
323
+ } catch (n) {
324
+ n instanceof Error && Y.error("MetricsErr", { error: { message: n.message, name: n.name } });
325
+ }
338
326
  })(t);
339
327
  }, 1e3 * e) : C = !1;
340
328
  };
package/dist/replay.cjs CHANGED
@@ -1 +1 @@
1
- "use strict";var qe=Object.defineProperty;var ze=(e,t,r)=>t in e?qe(e,t,{enumerable:!0,configurable:!0,writable:!0,value:r}):e[t]=r;var $=(e,t,r)=>(ze(e,typeof t!="symbol"?t+"":t,r),r);const s=require("./metricsReporter-Cdy0iTSw.cjs");var k=(e=>(e[e.DomContentLoaded=0]="DomContentLoaded",e[e.Load=1]="Load",e[e.FullSnapshot=2]="FullSnapshot",e[e.IncrementalSnapshot=3]="IncrementalSnapshot",e[e.Meta=4]="Meta",e[e.Custom=5]="Custom",e[e.Plugin=6]="Plugin",e))(k||{}),D=(e=>(e[e.Mutation=0]="Mutation",e[e.MouseMove=1]="MouseMove",e[e.MouseInteraction=2]="MouseInteraction",e[e.Scroll=3]="Scroll",e[e.ViewportResize=4]="ViewportResize",e[e.Input=5]="Input",e[e.TouchMove=6]="TouchMove",e[e.MediaInteraction=7]="MediaInteraction",e[e.StyleSheetRule=8]="StyleSheetRule",e[e.CanvasMutation=9]="CanvasMutation",e[e.Font=10]="Font",e[e.Log=11]="Log",e[e.Drag=12]="Drag",e[e.StyleDeclaration=13]="StyleDeclaration",e[e.Selection=14]="Selection",e[e.AdoptedStyleSheet=15]="AdoptedStyleSheet",e[e.CustomElement=16]="CustomElement",e))(D||{});const z=(e,t)=>t.some(r=>e instanceof r);let ue,le;const Q=new WeakMap,K=new WeakMap,F=new WeakMap;let X={get(e,t,r){if(e instanceof IDBTransaction){if(t==="done")return Q.get(e);if(t==="store")return r.objectStoreNames[1]?void 0:r.objectStore(r.objectStoreNames[0])}return R(e[t])},set:(e,t,r)=>(e[t]=r,!0),has:(e,t)=>e instanceof IDBTransaction&&(t==="done"||t==="store")||t in e};function he(e){X=e(X)}function Qe(e){return(le||(le=[IDBCursor.prototype.advance,IDBCursor.prototype.continue,IDBCursor.prototype.continuePrimaryKey])).includes(e)?function(...t){return e.apply(Y(this),t),R(this.request)}:function(...t){return R(e.apply(Y(this),t))}}function Xe(e){return typeof e=="function"?Qe(e):(e instanceof IDBTransaction&&function(t){if(Q.has(t))return;const r=new Promise((n,a)=>{const o=()=>{a(t.error||new DOMException("AbortError","AbortError"))};t.oncomplete=()=>{n()},t.onerror=o,t.onabort=o});Q.set(t,r)}(e),z(e,ue||(ue=[IDBDatabase,IDBObjectStore,IDBIndex,IDBCursor,IDBTransaction]))?new Proxy(e,X):e)}function R(e){if(e instanceof IDBRequest)return function(r){const n=new Promise((a,o)=>{r.onsuccess=()=>{a(R(r.result))},r.onerror=()=>{o(r.error)}});return F.set(n,r),n}(e);if(K.has(e))return K.get(e);const t=Xe(e);return t!==e&&(K.set(e,t),F.set(t,e)),t}const Y=e=>F.get(e);function Z(e,{blocked:t}={}){const r=indexedDB.deleteDatabase(e);return t&&(r.onblocked=n=>t(n.oldVersion,n)),R(r).then(()=>{})}const Ye=["get","getKey","getAll","getAllKeys","count"],Ze=["put","add","delete","clear"],W=new Map;function pe(e,t){if(!(e instanceof IDBDatabase)||t in e||typeof t!="string")return;if(W.get(t))return W.get(t);const r=t.replace(/FromIndex$/,""),n=t!==r,a=Ze.includes(r);if(!(r in(n?IDBIndex:IDBObjectStore).prototype)||!a&&!Ye.includes(r))return;const o=async function(i,...c){const d=this.transaction(i,a?"readwrite":"readonly");let u=d.store;return n&&(u=u.index(c.shift())),(await Promise.all([u[r](...c),a&&d.done]))[0]};return W.set(t,o),o}he(e=>({...e,get:(t,r,n)=>pe(t,r)||e.get(t,r,n),has:(t,r)=>!!pe(t,r)||e.has(t,r)}));const et=["continue","continuePrimaryKey","advance"],ge={},ee=new WeakMap,Ie=new WeakMap,tt={get(e,t){if(!et.includes(t))return e[t];let r=ge[t];return r||(r=ge[t]=function(...n){ee.set(this,Ie.get(this)[t](...n))}),r}};async function*rt(...e){let t=this;if(t instanceof IDBCursor||(t=await t.openCursor(...e)),!t)return;const r=new Proxy(t,tt);for(Ie.set(r,t),F.set(r,Y(t));t;)yield r,t=await(ee.get(r)||t.continue()),ee.delete(r)}function me(e,t){return t===Symbol.asyncIterator&&z(e,[IDBIndex,IDBObjectStore,IDBCursor])||t==="iterate"&&z(e,[IDBIndex,IDBObjectStore])}he(e=>({...e,get:(t,r,n)=>me(t,r)?rt:e.get(t,r,n),has:(t,r)=>me(t,r)||e.has(t,r)}));const be=new class{constructor(e){$(this,"awaitingResolvers",[]);$(this,"activeCount",0);this.capacity=e}async acquire(){if(!(this.activeCount<this.capacity))return new Promise(e=>{this.awaitingResolvers.push(e)});this.activeCount++}release(){const e=this.awaitingResolvers.shift();e&&this.activeCount<=this.capacity?e():this.activeCount--}async execute(e){try{return await this.acquire(),await e()}finally{this.release()}}setLimit(e){this.capacity=e}}(2),ve=async({apiUrl:e,surveyId:t,uploadId:r,etags:n,headers:a,responseGroupUuid:o,replayDuration:i,eventDigest:c},d=!1)=>{var y;if(!d&&!r&&!n)return void s.breadcrumbsLogger.error("UploadErr",{isMobile:d,uploadId:r,etags:n});s.breadcrumbsLogger.info("MarkUploadComplete",{surveyId:t});const u=await s.sprigFetch(`${e}/sdk/1/completeSessionReplay`,{method:"POST",body:JSON.stringify({etags:n,uploadId:r,responseGroupUuid:o,surveyId:t,replayDuration:i,eventDigest:c,userAgent:(y=window==null?void 0:window.navigator)==null?void 0:y.userAgent}),headers:a,shouldRetryRequest:!0});return s.breadcrumbsLogger.info("MarkUploadDone",{surveyId:t}),u},nt=e=>{if(e instanceof Attr)return null;let t=1;for(let r=e.previousSibling;r;r=r.previousSibling)r.nodeName===e.nodeName&&++t;return t},Se=e=>{if(e===null)return"";const t=[];if(e instanceof Document)return"/";for(let r=e;r&&!(r instanceof Document)&&r!==null;r=r instanceof Attr?r.ownerElement:r.parentElement){const n=t[t.length]={name:void 0,position:null};switch(r.nodeType){case Node.TEXT_NODE:n.name="text()";break;case Node.ATTRIBUTE_NODE:n.name="@"+r.nodeName;break;case Node.PROCESSING_INSTRUCTION_NODE:n.name="processing-instruction()";break;case Node.COMMENT_NODE:n.name="comment()";break;case Node.ELEMENT_NODE:n.name=r.nodeName}n.position=nt(r)}return"/"+t.reverse().map(r=>r.position!==null?`/${r.name}[${r.position}]`:`/${r.name}`).join("")},b={capture:!0,passive:!0},at=["a","button","input","option","li","link"],ot=["Escape","Enter","Backspace","F5","Tab"];let j=!1;const st=["label","type","role","title","placeholder","errormessage","valuetext","href"],it="aria-",we=e=>{var n;if(((n=e.tagName)==null?void 0:n.toLowerCase())==="html")return{element:"html"};const t=e.textContent,r=t?{text:t}:{};r.element=(a=>{if(!a.tagName)return"No tagName";const o=a.getAttribute("type");return o?`${o} ${a.tagName.toLowerCase()}`:a.tagName.toLowerCase()})(e);for(const a of e.attributes){let o=a.name;const i=a.value;o.startsWith(it)&&(o=o.substring(5)),st.includes(o)&&(r[o]=i)}return r},dt=e=>{var n;if(!e)return{};const t={...we(e)},r=e.parentElement;if(r&&at.includes((n=r.tagName)==null?void 0:n.toLowerCase())){const a=we(r);Object.assign(t,a)}return t},De=(e,t)=>{var n;let r=t.target;t.target===((n=window.document)==null?void 0:n.body)&&window.Sprig.pointerDownTarget&&(r=window.Sprig.pointerDownTarget),ut({x:t.x,y:t.y,type:e,elementAttributes:dt(r),windowHeight:window.innerHeight,windowWidth:window.innerWidth,...r instanceof HTMLElement?{rect:r==null?void 0:r.getBoundingClientRect(),xPath:Se(r)}:{}})},Ee=e=>{ot.includes(e.key)&&gt({key:e.key})},Ce=((e,t)=>{let r;return n=>{clearTimeout(r),r=window.setTimeout(()=>e(n),t)}})(e=>{if(!(e.target instanceof HTMLElement||e.target instanceof Document))return;let t=e.target;"scrollTop"in t||(t=t.documentElement),mt({xPath:Se(t),x:t.scrollLeft,y:t.scrollTop,elementAttributes:{targetScrollWidth:t.scrollWidth,targetClientWidth:t.clientWidth,targetScrollHeight:t.scrollHeight,targetClientHeight:t.clientHeight}})},750),ke=(ye="left_click",e=>De(ye,e));var ye;const Re=e=>{e.button===2&&De("right_click",e)},Ue=e=>{window.Sprig&&(window.Sprig.pointerDownTarget=e.target)},ct=()=>{j||(window.addEventListener("click",ke,b),window.addEventListener("pointerdown",Ue,b),window.addEventListener("mousedown",Re,b),window.addEventListener("keydown",Ee,b),window.addEventListener("scroll",Ce,b),j=!0,window.performance.getEntriesByType("navigation").map(e=>e.type).includes("reload")&&lt({url:window.location.href,currentPageTitle:document.title}),window.performance.getEntriesByType("navigation").map(e=>e.type).includes("back_forward")&&pt({curUrl:window.location.href,fromUrl:document.referrer,currentPageTitle:document.title}))},w={isRecording:!1,scrollEventUuids:{},stopRecording:()=>{}},Pe=()=>window.indexedDB&&window.IDBKeyRange&&window.CompressionStream,f=(()=>{const e=s.sessionStorageHelper.getItem("sprig.sessionId");if(e)return s.breadcrumbsLogger.info("SessionIDFound",{savedSessionId:e}),s.sessionStorageHelper.removeItem("sprig.sessionId"),e;const t=s.v4();return s.breadcrumbsLogger.info("GeneratedSessionID",{uuid:t}),t})(),te=()=>{s.sessionStorageHelper.setItem("sprig.disableReplayRecording","disabled")},S=()=>!!s.sessionStorageHelper.getItem("sprig.disableReplayRecording");window.addEventListener("beforeunload",()=>{s.breadcrumbsLogger.info("BeforeUnload",{sessionId:f}),s.sessionStorageHelper.setItem("sprig.sessionId",f)});const ie=e=>e&&e.trim().substring(0,500).replace(/\s\s+/g," ").replace(/\r?\n|\r/g," ").substring(0,250),v=(e,t)=>{var r,n;if(!S()&&w.isRecording)try{(n=(r=window.rrwebRecord)==null?void 0:r.addCustomEvent)==null||n.call(r,e,t)}catch(a){G("Error recording custom event",a)}},ut=e=>{var t;(t=e==null?void 0:e.elementAttributes)!=null&&t.text&&(e.elementAttributes.text=ie(e.elementAttributes.text)),v("Sprig_Click",e)},lt=e=>{v("Sprig_Refresh",e)},pt=e=>{e.currentPageTitle&&(e.currentPageTitle=ie(e.currentPageTitle)),v("Sprig_BackForward",e)},gt=e=>{v("Sprig_Keystroke",e)},mt=async e=>{const{x:t,xPath:r,y:n}=e,a=w.scrollEventUuids[r];if(a)return h(async()=>{var c,d,u,y;const o=await l.openDB(),i=await o.get("events",a);if(i!=null&&i.event){const p=JSON.parse(i.event),m=t>((d=(c=p.data)==null?void 0:c.payload)==null?void 0:d.x),g=n>((y=(u=p.data)==null?void 0:u.payload)==null?void 0:y.y);if(!m&&!g)return null;m&&(p.data.payload.x=t),g&&(p.data.payload.y=n),p.data.payload.elementAttributes=e.elementAttributes,i.event=JSON.stringify(p),await o.put("events",i)}else v("Sprig_Scroll",e)},"Error updating scroll event");v("Sprig_Scroll",e)},xe=()=>{w.stopRecording&&(w.stopRecording(),w.stopRecording=void 0),w.isRecording=!1,["cleanupInterval","inactivityInterval","pendingCheckInterval"].forEach(e=>{w[e]&&(clearInterval(w[e]),w[e]=void 0)}),j&&(window.removeEventListener("click",ke,b),window.removeEventListener("pointerdown",Ue,b),window.removeEventListener("mousedown",Re,b),window.removeEventListener("keydown",Ee,b),window.removeEventListener("scroll",Ce,b),j=!1)},wt=["did not allow mutations","called in an invalid security context"],yt=(e,t,{reportError:r=!0,extraInfo:n={}})=>{if(!S()&&t instanceof Error){if(te(),t.name==="VersionError")return s.breadcrumbsLogger.error("VersionErr",{message:e}),l.deleteDB();(a=>{if(!a)return!0;for(const o of wt)if(a.toLowerCase().includes(o))return!1;return!0})(t==null?void 0:t.message)&&(r&&window.UserLeap.reportError(e,t,n),l.clearAll())}},G=(e,t,{reportError:r}={reportError:!0})=>{xe(),s.breadcrumbsLogger.error("ReplayErr",{code:t.code,name:t.name}),yt(e,t,{reportError:r})},h=async(e,t)=>{try{return await e()}catch(r){G(t,r)}};Pe()&&(Z("replayStorage").catch(console.error),Z("sprig.replay").catch(console.error));const l=new class{openDB(){return function(e,t,{blocked:r,upgrade:n,blocking:a,terminated:o}={}){const i=indexedDB.open(e,t),c=R(i);return n&&(i.onupgradeneeded=d=>{n(R(i.result),d.oldVersion,d.newVersion,R(i.transaction),d)}),r&&(i.onblocked=d=>r(d.oldVersion,d.newVersion,d)),c.then(d=>{o&&(d.onclose=()=>o()),a&&(d.onversionchange=u=>a(u.oldVersion,u.newVersion,u))}).catch(()=>{}),c}("sprigReplay",1,{upgrade:(e,t,r)=>{if(r===0&&s.sessionStorageHelper.setItem("sprig.pendingCount","0"),!e.objectStoreNames.contains("events")){const n=e.createObjectStore("events",{keyPath:"uuid"});n.createIndex("sessionId","sessionId"),n.createIndex("timestamp","timestamp"),n.createIndex("[sessionId+timestamp]",["sessionId","timestamp"])}if(!e.objectStoreNames.contains("chunkUploads")){const n=e.createObjectStore("chunkUploads",{keyPath:"uuid"});n.createIndex("sessionId","sessionId"),n.createIndex("timestamp","timestamp"),n.createIndex("[sessionId+status]",["sessionId","status"]),n.createIndex("[uploadId+status]",["uploadId","status"]),n.createIndex("[sessionId+status+uploadId]",["sessionId","status","uploadId"])}if(!e.objectStoreNames.contains("pendingCaptures")){const n=e.createObjectStore("pendingCaptures",{keyPath:"uuid"});n.createIndex("sessionId","sessionId"),n.createIndex("timestamp","timestamp"),n.createIndex("[sessionId+targetTimestamp]",["sessionId","targetTimestamp"])}}})}deleteDB(){return Z("sprigReplay").catch(console.error)}async bulkAdd(e,t){const r=(await this.openDB()).transaction(e,"readwrite");return Promise.all([...t.map(n=>r.store.add(n)),r.done])}async clearAll(){const e=(await this.openDB()).transaction(["events","chunkUploads","pendingCaptures"],"readwrite");return Promise.all([e.objectStore("events").clear(),e.objectStore("chunkUploads").clear(),e.objectStore("pendingCaptures").clear()])}async deleteBySessionId(e,t){const r=IDBKeyRange.only(t),n=(await this.openDB()).transaction(e,"readwrite"),a=n.store.index("sessionId");for await(const o of a.iterate(r))await o.delete();await n.done}async updatePartial(e,t,r){const n=(await this.openDB()).transaction(e,"readwrite"),a=await n.store.get(t);a&&await n.store.put({...a,...r}),await n.done}async deleteRowsBefore(e,t,r=()=>!0){const n=IDBKeyRange.upperBound(t,!0),a=(await this.openDB()).transaction(e,"readwrite"),o=a.store.index("timestamp");for await(const i of o.iterate(n))r(i.value)&&await i.delete();await a.done}async getEventsBetween(e,t=Date.now()){if(e>=t)return Promise.resolve([]);const r=IDBKeyRange.bound([f,e],[f,t],!1,!0);return(await this.openDB()).getAllFromIndex("events","[sessionId+timestamp]",r)}async updateEventsExpiredAt(e,t,r=30){const n=new Date,a=n.setMinutes(n.getMinutes()+(r??30)),o=(await this.openDB()).transaction("events","readwrite"),i=o.store.index("[sessionId+timestamp]"),c=IDBKeyRange.bound([f,e],[f,t],!1,!0);for await(const d of i.iterate(c))await d.update({...d.value,expiredAt:a});await o.done}async deleteChunkUploads(e,t){const r=IDBKeyRange.only([t,e]),n=(await this.openDB()).transaction("chunkUploads","readwrite");let o=await n.store.index("[uploadId+status]").openCursor(r);for(;o;)o.delete(),o=await o.continue();await n.done}async getChunkUploadsByStatus({sessionId:e,status:t,uploadId:r}){const n=(await this.openDB()).transaction("chunkUploads","readonly"),a=r?n.store.index("[uploadId+status]"):n.store.index("[sessionId+status]"),o=r?IDBKeyRange.only([r,t]):IDBKeyRange.only([e,t]);return a.getAll(o)}async getPendingCaptures(e={}){return(await(await this.openDB()).getAllFromIndex("pendingCaptures","sessionId",f)).filter(r=>!e.beforePresent||r.targetTimestamp<Date.now()).filter(r=>!e.isBeforeType||r.captureParams.replayParams.replayDurationType==="before").filter(r=>!e.isHeatmap||(r.captureParams.isHeatmap??!1))}async markPendingCaptureToCanUpload(e){const t=(await this.openDB()).transaction("pendingCaptures","readwrite"),r=t.store.index("sessionId");for await(const n of r.iterate(f)){const a=n.value;a.captureParams.responseGroupId===e&&await n.update({...a,canUpload:!0})}await t.done}async markPendingHeatmapsReady(e){if(parseInt(s.sessionStorageHelper.getItem("sprig.pendingCount")??"0")===0)return null;const t=Date.now(),r=(await this.openDB()).transaction("pendingCaptures","readwrite"),n=r.store.index("sessionId");for await(const a of n.iterate(f)){const o=a.value;!o.captureParams.isHeatmap||e&&!e.includes(o.uuid)||await a.update({...o,targetTimestamp:t,captureParams:{...o.captureParams,triggerTimestamp:t,replayParams:{...o.captureParams.replayParams,replayDurationSeconds:Math.floor((t-o.timestamp)/1e3)}}})}await r.done}},E=[];let M,Be,V,Le,H,Te,P=[],L=!1,B=0,O=!1,Me=!1,de=[],J=!1;const T=()=>O&&!L&&Date.now()<=V,ft=({apiUrl:e,config:t,triggerSnapshot:r,forceInit:n=!1})=>{O&&!n||(s.sessionStorageHelper.isStorageAvailable?(P=[],de.splice(0),E.splice(0),B=0,H=r,Be=e,M={responseGroupUuid:t.responseGroupUuid,surveyId:t.surveyId,userAgent:t.userAgent,sdkVersion:t.sdkVersion},Le=t.maxDurationSeconds,vt(),O||(Te=window.setInterval(bt,500)),O=!0):L=!0)},ht=[D.Drag,D.Input,D.MediaInteraction,D.MouseInteraction,D.MouseMove,D.Scroll,D.Selection,D.TouchMove],It=e=>e.type===k.Custom||e.type===k.IncrementalSnapshot&&ht.includes(e.data.source),ce=e=>e.some(It),bt=async()=>{if(!T())return void window.clearInterval(Te);if(Ae(),!ce(E))return;const e=E[0].timestamp;Date.now()-e>35e3&&(H==null||H())},Ae=async()=>{if(P.length||J)return;J=!0;const e=await Dt();if(!e)return void(L=!0);de.splice(0,e.length).forEach(t=>t(e.shift())),e.forEach(t=>P.push(t)),J=!1},vt=()=>{const e=s.sessionStorageHelper.getItem("sprig.alwayson.info");if(e){s.breadcrumbsLogger.info("Read stored session state",e);const t=JSON.parse(e);L=t.disabled,M=t.metadata,P=t.uploadUrls,B=t.currentIndex,V=t.expirationTimestamp,t.pendingEventTimestamp&&(s.breadcrumbsLogger.info(`Uploading with pending timestamp: ${t.pendingEventTimestamp}`),St(t.pendingEventTimestamp))}else V=1e3*Le+Date.now()},St=async e=>{const t=Date.now(),r=(await l.getEventsBetween(e,t)).map(a=>JSON.parse(a.event));if(!ce(r))return;Oe(r);const n=await He();n&&await Ne(n,r)},_e=async(e,t)=>{try{const r=await e();if(!r.ok)throw new Error(`Error ${t}`);return r}catch{L=!0}},Ne=async(e,t)=>{if(!T()||!e)return;const r=await(async n=>{const a=new TextEncoder,o=new CompressionStream("gzip"),i=o.writable.getWriter(),c=a.encode(JSON.stringify(n));return i.write(c),i.close(),new Uint8Array(await new Response(o.readable).arrayBuffer())})(t);s.breadcrumbsLogger.info("Uploading always-on events with presigned url"),await _e(()=>s.sprigFetch(e,{body:r,method:"PUT"}),"uploading always-on with presigned url")},Dt=async()=>{if(!T())return;const{surveyId:e,responseGroupUuid:t}=M,r={responseGroupUuid:t,surveyId:e,index:B+1};s.breadcrumbsLogger.info("Fetching always-on upload urls",r);const n=await _e(()=>s.sprigFetch(`${Be}/sdk/1/replayUrls`,{method:"POST",body:JSON.stringify(r),headers:s.getHttpHeaders(window.UserLeap)}),"fetching always-on signed urls");if(!n)return;const a=n.json.signedUrls;return s.breadcrumbsLogger.info("Fetched more always-on upload urls",{body:r,urls:a}),a},He=async()=>{if(P.length)return P.shift();const e=new Promise(t=>{de.push(t)});return Ae(),e},Oe=e=>{var a,o,i;const t=e.length?e[e.length-1].timestamp:Date.now(),r=B,n=((o=(a=window.UserLeap)==null?void 0:a.config)==null?void 0:o.customMetadata)??((i=window.__cfg)==null?void 0:i.customMetadata);B++,e.push({timestamp:t,type:k.Custom,data:{tag:"Sprig_Meta",payload:{...M,index:r,visitorId:window.UserLeap.visitorId??"",timestamp:t,customMetadata:n}}})},Et=(e,t)=>{T()&&!Me&&(e||E.length)&&(e&&E.length&&(async()=>{const r=E.splice(0);if(!ce(r))return;s.breadcrumbsLogger.info("Capturing always-on event array to upload"),Oe(r);const n=await He();n&&await Ne(n,r)})(),E.push(t))};window.addEventListener("beforeunload",async()=>{Me=!0,T()&&(s.breadcrumbsLogger.info("Always On handle page unload"),(()=>{let e;E.length&&(e=E[0].timestamp);const t={disabled:L,metadata:M,uploadUrls:P,currentIndex:B,pendingEventTimestamp:e,expirationTimestamp:V};s.breadcrumbsLogger.info("Storing session state on unload",t),s.sessionStorageHelper.setItem("sprig.alwayson.info",JSON.stringify(t))})())});const Fe=async(e,t)=>{const r=performance.now();let n;try{n=await e()}finally{const a=performance.now()-r;let o=s.PerformanceMetrics[t];o||(o=s.registerMetric(t)),o.report(a/1e3)}return n},je=(e,t)=>{const r=performance.now();try{e()}finally{const n=performance.now()-r;let a=s.PerformanceMetrics[t];a||(a=s.registerMetric(t)),a.report(n/1e3)}};let Ve=5e3,re=6e4,ne=0,U,ae=!1,oe=[];const Ct=e=>{var t,r,n,a;if((t=e.event)!=null&&t.includes("Sprig_Scroll")){const o=(a=(n=(r=JSON.parse(e.event))==null?void 0:r.data)==null?void 0:n.payload)==null?void 0:a.xPath;if(!o)return;w.scrollEventUuids[o]=e.uuid}oe.push(e),ae||kt()},kt=()=>{ae=!0,setTimeout(async()=>{if(S())return;const e=oe;oe=[],ae=!1,je(async()=>{await(async t=>{const r=t.map(n=>({...n,sessionId:n.sessionId??f}));if(r.length!==0)return h(()=>l.bulkAdd("events",r),"Error storing replay events")})(e)},"sdk_replay_add_event_batch_seconds")},500)},Rt=(e,t,r)=>{w.cleanupInterval=window.setInterval(()=>{const n=Date.now();Fe(()=>h(async()=>{S()||await Promise.all([l.deleteRowsBefore("events",n-1e3*e,a=>a.expiredAt===void 0||a.expiredAt<n-1e3*e),l.deleteRowsBefore("chunkUploads",n-1e3*t),l.deleteRowsBefore("pendingCaptures",n-1e3*r,a=>!a.canUpload)])},"Error deleting table rows"),"sdk_replay_cleanup_seconds"),s.breadcrumbsLogger.debug("CleanupComplete")},3e4)},Ut=()=>{w.pendingCheckInterval=window.setInterval(async()=>{h(async()=>{await se()},"Error initiating pending captures")},5e3)};let q=!1;const se=async(e=!1)=>{if(!q)try{q=!0;const t=parseInt(U??"0");if(t===0)return;const r=await l.getPendingCaptures({beforePresent:!0,isBeforeType:e}),n=await l.openDB();await Promise.all(r.map(async a=>(await n.delete("pendingCaptures",a.uuid),Ke(a.captureParams,a.canUpload)))),U=(t-r.length).toString(),s.sessionStorageHelper.setItem("sprig.pendingCount",U)}finally{q=!1}},Pt=async(e,t,r,n,a)=>{const o=Math.min(e+a,r),i=await Fe(()=>l.getEventsBetween(e,o),"sdk_replay_get_events_between_seconds");if(!(i!=null&&i.length))return s.breadcrumbsLogger.debug("NoEventsFound"),{validStartFound:n,events:[]};if(!n){s.breadcrumbsLogger.debug("ValidStartSearch");let c=-1;return i==null||i.forEach((d,u)=>{if(!d.isValidStart)return;const y=d.timestamp<=t;(c<0||y)&&(c=u)}),c<0?(s.breadcrumbsLogger.debug("ValidStartNotFound"),{validStartFound:n,events:[]}):{validStartFound:!0,events:i==null?void 0:i.slice(c)}}return{validStartFound:n,events:i}},Ge=e=>Promise.all(e.map(async t=>{const r=await(async n=>be.execute(async()=>{var i;s.breadcrumbsLogger.info("UploadChunkStart",{chunkIndex:n.chunkIndex,surveyId:n.surveyId});const a=await s.sprigFetch(n.uploadUrl,{body:n.data,method:"PUT"});s.breadcrumbsLogger.http("UploadChunkEnd",{url:n.uploadUrl,method:"PUT",status_code:a.status,reason:a.statusText??"OK",chunkIndex:n.chunkIndex,surveyId:n.surveyId});const o=(i=a.headers)==null?void 0:i.get("ETag");if(!o)throw new Error(`Upload response did not include etag for upload ${n.uploadId}, part ${n.chunkIndex}`);return o}))(t);return await l.updatePartial("chunkUploads",t.uuid,{data:null,etag:r,status:"UploadComplete"}),t.uploadId})),$e=async e=>{const t=await l.getChunkUploadsByStatus({status:"UploadComplete",uploadId:e});if(!(t!=null&&t.length))return void s.breadcrumbsLogger.info("NoChunksForUpload",{uploadId:e});const r=t.reduce((o,i)=>(o.find(c=>c.chunkIndex===i.chunkIndex)||o.push(i),o),[]);r.sort((o,i)=>o.chunkIndex-i.chunkIndex);const n=r.map(o=>({ETag:o.etag,PartNumber:o.chunkIndex})).filter(o=>o.ETag!==null),a=r[0];await ve({apiUrl:a.apiUrl,surveyId:a.surveyId,uploadId:e,responseGroupUuid:a.responseGroupId,etags:n,headers:a.completeUploadHeaders,replayDuration:a.replayDuration}),await l.deleteChunkUploads("UploadComplete",e)},xt=()=>{h(async()=>{const e=await l.getChunkUploadsByStatus({sessionId:f,status:"ReadyForUpload"});if(!(e!=null&&e.length))return;const t=await Ge(e);t!=null&&t.length&&await Promise.all(t.map(r=>{if(r)return $e(r)}))},"Error uploading unfinished chunks")},Bt=async(e,t)=>{const r=t??Date.now();return(async(n,a)=>{const o=new TextEncoder;let i=null;const c=new CompressionStream("gzip"),d=c.writable.getWriter();let u=!1,y=!1,[p,m]=[0,0],g=[];for(let C=n-35e3;C<a;C+=re){if({validStartFound:y,events:g}=await Pt(C,n,a,y,re),!(g!=null&&g.length)){s.breadcrumbsLogger.debug("NoEventsFound");continue}p===0&&(p=g[0].timestamp),m=g[g.length-1].timestamp;const A=g.map(x=>x.event);A.push(`{"timestamp":${a}}`);const _=`${u?",":"["}${A}`,N=o.encode(_);je(()=>{d.write(N)},"sdk_replay_compression_seconds"),u=!0}if(m-p<Ve)return s.breadcrumbsLogger.debug("ReplayTooShort"),null;const I=o.encode("]");return d.write(I),d.close(),i=new Uint8Array(await new Response(c.readable).arrayBuffer()),i})(r-e,r)},fe=async e=>{const{surveyId:t,responseGroupId:r,visitorId:n,apiUrl:a,completeUploadHeaders:o,replayParams:i,triggerTimestamp:c}=e,d=await Bt(1e3*i.replayDurationSeconds,c);if(!(d!=null&&d.length))return void s.breadcrumbsLogger.info("FileDataEmpty",{surveyId:t});const u=((p,m,g)=>{const I=p.length,C=1024*m*1024,A=Math.ceil(I/g),_=Math.max(C,A),N=[];let x=0;for(;x<I;)N.push(p.slice(x,x+_)),x+=_;return N})(d,i.minimumChunkSizeMb,i.signedUrls.length),y=await Promise.all(u.map(async(p,m)=>{const g=s.v4(),I={apiUrl:a,chunkIndex:m+1,completeUploadHeaders:o,etag:null,responseGroupId:r,status:"ReadyForUpload",surveyId:t,timestamp:c,totalChunks:u.length,data:p,uploadId:i.uploadId,uploadUrl:i.signedUrls[m].url,uuid:g,visitorId:n};return await(await l.openDB()).add("chunkUploads",{...I,sessionId:I.sessionId??f}),I}));await(async(p,m)=>{await Ge(m),await Promise.all(p.map(g=>$e(g)))})([i.uploadId],y)},Ke=async(e,t)=>{if(S())return s.breadcrumbsLogger.debug("ReplayDisabled-ScheduleOrCapture");const{isHeatmap:r,isStandalone:n,replayParams:a,triggerTimestamp:o,responseGroupId:i}=e,c=async()=>{setTimeout(()=>s.eventEmitter.removeListener(s.SprigEvent.QuestionAnswered,c),0),h(async()=>{a.replayDurationType==="before"?await fe(e):await l.markPendingCaptureToCanUpload(i)},"Error in schedule/capture callback")};h(async()=>{if(a.replayDurationType==="after"||a.replayDurationType==="beforeAndAfter")return!n&&!r&&s.eventEmitter.on(s.SprigEvent.QuestionAnswered,c),void await Je(e);if(n||r||t)await fe(e),r&&Lt();else{const d=35+a.replayDurationSeconds,u=o-1e3*d,y=o;await l.updateEventsExpiredAt(u,y,a.expirationTimeLimitMinutes),s.eventEmitter.on(s.SprigEvent.QuestionAnswered,c)}},"Error in scheduling/capturing replay")},Lt=async()=>{parseInt(U??"0")||s.sessionStorageHelper.removeItem("sprig.isCapturingHeatmap"),s.sessionStorageHelper.getItem("sprig.teardownAfterCapture")&&(xe(),We(),s.sessionStorageHelper.removeItem("sprig.teardownAfterCapture"))},We=async()=>S()?s.breadcrumbsLogger.debug("ReplayDisabled-ClearData"):Promise.all([l.deleteBySessionId("events",f),l.deleteBySessionId("pendingCaptures",f)]).catch(e=>{G("Error clearing user replay data",e)}),Je=async e=>{if(S())return;const{isHeatmap:t,surveyId:r}=e,n=await l.getPendingCaptures(),a=n==null?void 0:n.filter(d=>d.captureParams.surveyId===r);if(a!=null&&a.length)return void s.breadcrumbsLogger.info("PendingCaptureExists",{surveyId:r});t&&(w.isRecording&&h(()=>{var d,u;return(u=(d=window.rrwebRecord)==null?void 0:d.takeFullSnapshot)==null?void 0:u.call(d,!0)},"Error recording full snapshot"),s.sessionStorageHelper.setItem("sprig.isCapturingHeatmap","true"),ne=Date.now(),w.inactivityInterval||(w.inactivityInterval=window.setInterval(()=>{var d;d=ne,Date.now()-d>=3e4&&h(()=>l.markPendingHeatmapsReady(),"Error in heatmap inactivity")},1e3)));const o={...e,replayParams:{...e.replayParams}};e.replayParams.replayDurationType==="beforeAndAfter"&&(o.replayParams.replayDurationSeconds*=2),o.replayParams.replayDurationType="before";const i=e.triggerTimestamp+1e3*e.replayParams.replayDurationSeconds;o.triggerTimestamp=i,U=(parseInt(U??"0")+1).toString(),s.sessionStorageHelper.setItem("sprig.pendingCount",U),await(await l.openDB()).add("pendingCaptures",{canUpload:!1,captureParams:o,sessionId:f,targetTimestamp:i,timestamp:Date.now(),uuid:s.v4()})},Tt=Object.freeze(Object.defineProperty({__proto__:null,RecordEvent:e=>{v("Sprig_TrackEvent",e)},RecordPageView:e=>{e.description&&(e.description=ie(e.description)),v("Sprig_PageView",e)},RecordSurveyShown:e=>{v("Sprig_ShowSurvey",e)},_completeSessionReplay:async({surveyId:e,responseGroupUuid:t,eventDigest:r,headers:n})=>{if(!e||!t)return!1;const a=window.UserLeap._API_URL,o=await ve({surveyId:e,responseGroupUuid:t,eventDigest:r,apiUrl:a,headers:n},!0);return!(o!=null&&o.error)},checkPendingHeatmapsUrl:()=>S()?s.breadcrumbsLogger.debug("ReplayDisabled-PendingHeatmaps"):h(async()=>{const e=(await l.getPendingCaptures({isHeatmap:!0})).map(t=>({eventId:t.captureParams.eventId,uuid:t.uuid})).filter(({eventId:t})=>!s.checkUrlStillMatching(t)).map(({uuid:t})=>t);return s.breadcrumbsLogger.info("PendingHeatmapsToComplete",{count:e.length}),e.length&&(await l.markPendingHeatmapsReady(e),s.breadcrumbsLogger.info("MarkedPendingHeatmapsReady")),e.length},"Error marking pending heatmaps ready"),clearUserReplayData:We,disableRecording:G,initializeReplay:async({maxReplayDurationSeconds:e,maxInflightRequests:t=2,replaySettings:r,teardownAfter:n=!1,apiUrl:a,alwaysOnConfig:o})=>{if(o&&ft({apiUrl:a,config:o,triggerSnapshot:()=>{var d;return(d=window.rrwebRecord)==null?void 0:d.takeFullSnapshot(!0)}}),U=s.sessionStorageHelper.getItem("sprig.pendingCount"),w.isRecording)return;if(n&&s.sessionStorageHelper.setItem("sprig.teardownAfterCapture","true"),S())return s.breadcrumbsLogger.debug("ReplayDisabled");if(await(async()=>{var d;if(!Pe())return!0;if((d=window.navigator.storage)!=null&&d.estimate)try{const{quota:u=0,usage:y=0}=await window.navigator.storage.estimate(),p=(u-y)/1024**3;return s.breadcrumbsLogger.info("Storage",{availableGb:p}),p<.5}catch{return!0}return!1})())return s.breadcrumbsLogger.debug("IDBNotSupported"),te();try{const d=await l.openDB();s.breadcrumbsLogger.info("DBVersion",{version:d.version})}catch(d){return s.breadcrumbsLogger.error("ReplayOpenErr",{name:d.name}),d.name==="VersionError"&&l.deleteDB(),te()}h(async()=>{await se(!0)},"Error uploading ready pending captures");const i=T()?30:0,c=Math.max(e??0,i);if(!c)return s.breadcrumbsLogger.debug("MissingDuration");s.breadcrumbsLogger.debug("ReplayInit"),await h(async()=>{var d;if(r!=null&&r.minDuration&&(Ve=r.minDuration),r!=null&&r.batchDuration&&(re=r.batchDuration),d=t,be.setLimit(d),xt(),Rt(c+35,1800,c+35),Ut(),!window.rrwebRecord){const{record:m}=await import(window.UserLeap.replayLibraryURL??"https://cdn.sprig.com/dependencies/record-2.0.0-alpha.17.min.js");window.rrwebRecord=m}const u=window.rrwebRecord;if(!u)return s.breadcrumbsLogger.error("RecordScriptFailed");let y=!0,p=0;w.stopRecording=u({checkoutEveryNms:3e4,sampling:{input:"last",scroll:250,media:800},emit:(m,g)=>{if(m.type===k.Custom&&(ne=Date.now()),S())return;if(g&&m.type===k.Meta)p=performance.now();else if(g&&p&&m.type===k.FullSnapshot){const C=performance.now()-p;s.reportAndRegister("sdk_replay_snapshot_seconds",C/1e3)}const I=y||!!g&&m.type===k.Meta;y=!1,Et(I,m),Ct({uuid:s.v4(),event:JSON.stringify(m),isValidStart:I,timestamp:Date.now()})},...r}),w.isRecording=!!w.stopRecording,w.isRecording&&(s.eventEmitter.on("survey.complete",m=>{var g;g={id:m,userAgent:window.navigator.userAgent},v("Sprig_SubmitSurvey",g)}),ct())},"Error initializing replay")},isReplayRecording:()=>w.isRecording,scheduleCapture:Je,scheduleOrCaptureReplay:Ke,tryReplayAction:h,uploadReadyPendingCaptures:se},Symbol.toStringTag,{value:"Module"}));s.registerReplay(Tt);
1
+ "use strict";var Ye=Object.defineProperty;var Ze=(e,t,r)=>t in e?Ye(e,t,{enumerable:!0,configurable:!0,writable:!0,value:r}):e[t]=r;var W=(e,t,r)=>Ze(e,typeof t!="symbol"?t+"":t,r);const o=require("./metricsReporter-BLXrIaei.cjs");var x=(e=>(e[e.DomContentLoaded=0]="DomContentLoaded",e[e.Load=1]="Load",e[e.FullSnapshot=2]="FullSnapshot",e[e.IncrementalSnapshot=3]="IncrementalSnapshot",e[e.Meta=4]="Meta",e[e.Custom=5]="Custom",e[e.Plugin=6]="Plugin",e))(x||{}),U=(e=>(e[e.Mutation=0]="Mutation",e[e.MouseMove=1]="MouseMove",e[e.MouseInteraction=2]="MouseInteraction",e[e.Scroll=3]="Scroll",e[e.ViewportResize=4]="ViewportResize",e[e.Input=5]="Input",e[e.TouchMove=6]="TouchMove",e[e.MediaInteraction=7]="MediaInteraction",e[e.StyleSheetRule=8]="StyleSheetRule",e[e.CanvasMutation=9]="CanvasMutation",e[e.Font=10]="Font",e[e.Log=11]="Log",e[e.Drag=12]="Drag",e[e.StyleDeclaration=13]="StyleDeclaration",e[e.Selection=14]="Selection",e[e.AdoptedStyleSheet=15]="AdoptedStyleSheet",e[e.CustomElement=16]="CustomElement",e))(U||{});const X=(e,t)=>t.some(r=>e instanceof r);let ge,me;const Y=new WeakMap,J=new WeakMap,G=new WeakMap;let Z={get(e,t,r){if(e instanceof IDBTransaction){if(t==="done")return Y.get(e);if(t==="store")return r.objectStoreNames[1]?void 0:r.objectStore(r.objectStoreNames[0])}return L(e[t])},set:(e,t,r)=>(e[t]=r,!0),has:(e,t)=>e instanceof IDBTransaction&&(t==="done"||t==="store")||t in e};function be(e){Z=e(Z)}function et(e){return(me||(me=[IDBCursor.prototype.advance,IDBCursor.prototype.continue,IDBCursor.prototype.continuePrimaryKey])).includes(e)?function(...t){return e.apply(ee(this),t),L(this.request)}:function(...t){return L(e.apply(ee(this),t))}}function tt(e){return typeof e=="function"?et(e):(e instanceof IDBTransaction&&function(t){if(Y.has(t))return;const r=new Promise((n,a)=>{const s=()=>{a(t.error||new DOMException("AbortError","AbortError"))};t.oncomplete=()=>{n()},t.onerror=s,t.onabort=s});Y.set(t,r)}(e),X(e,ge||(ge=[IDBDatabase,IDBObjectStore,IDBIndex,IDBCursor,IDBTransaction]))?new Proxy(e,Z):e)}function L(e){if(e instanceof IDBRequest)return function(r){const n=new Promise((a,s)=>{r.onsuccess=()=>{a(L(r.result))},r.onerror=()=>{s(r.error)}});return G.set(n,r),n}(e);if(J.has(e))return J.get(e);const t=tt(e);return t!==e&&(J.set(e,t),G.set(t,e)),t}const ee=e=>G.get(e);function te(e,{blocked:t}={}){const r=indexedDB.deleteDatabase(e);return t&&(r.onblocked=n=>t(n.oldVersion,n)),L(r).then(()=>{})}const rt=["get","getKey","getAll","getAllKeys","count"],nt=["put","add","delete","clear"],q=new Map;function we(e,t){if(!(e instanceof IDBDatabase)||t in e||typeof t!="string")return;if(q.get(t))return q.get(t);const r=t.replace(/FromIndex$/,""),n=t!==r,a=nt.includes(r);if(!(r in(n?IDBIndex:IDBObjectStore).prototype)||!a&&!rt.includes(r))return;const s=async function(i,...c){const d=this.transaction(i,a?"readwrite":"readonly");let u=d.store;return n&&(u=u.index(c.shift())),(await Promise.all([u[r](...c),a&&d.done]))[0]};return q.set(t,s),s}be(e=>({...e,get:(t,r,n)=>we(t,r)||e.get(t,r,n),has:(t,r)=>!!we(t,r)||e.has(t,r)}));const at=["continue","continuePrimaryKey","advance"],ye={},re=new WeakMap,Se=new WeakMap,st={get(e,t){if(!at.includes(t))return e[t];let r=ye[t];return r||(r=ye[t]=function(...n){re.set(this,Se.get(this)[t](...n))}),r}};async function*ot(...e){let t=this;if(t instanceof IDBCursor||(t=await t.openCursor(...e)),!t)return;const r=new Proxy(t,st);for(Se.set(r,t),G.set(r,ee(t));t;)yield r,t=await(re.get(r)||t.continue()),re.delete(r)}function fe(e,t){return t===Symbol.asyncIterator&&X(e,[IDBIndex,IDBObjectStore,IDBCursor])||t==="iterate"&&X(e,[IDBIndex,IDBObjectStore])}be(e=>({...e,get:(t,r,n)=>fe(t,r)?ot:e.get(t,r,n),has:(t,r)=>fe(t,r)||e.has(t,r)}));const it="sprigReplayIframeLoaded",dt="sprigReplayIframeSettings",ct="sprigReplayIframeTakeFullSnapshot",ut="sprigReplayTeardown",ce=[],De=new class{constructor(e){W(this,"awaitingResolvers",[]);W(this,"activeCount",0);this.capacity=e}async acquire(){if(!(this.activeCount<this.capacity))return new Promise(e=>{this.awaitingResolvers.push(e)});this.activeCount++}release(){const e=this.awaitingResolvers.shift();e&&this.activeCount<=this.capacity?e():this.activeCount--}async execute(e){try{return await this.acquire(),await e()}finally{this.release()}}setLimit(e){this.capacity=e}}(2),Ee=async({apiUrl:e,surveyId:t,uploadId:r,etags:n,headers:a,responseGroupUuid:s,replayDuration:i,eventDigest:c},d=!1)=>{var w;if(!d&&!r&&!n)return void o.breadcrumbsLogger.error("UploadErr",{isMobile:d,uploadId:r,etags:n});o.breadcrumbsLogger.info("MarkUploadComplete",{surveyId:t});const u=await o.sprigFetch(`${e}/sdk/1/completeSessionReplay`,{method:"POST",body:JSON.stringify({etags:n,uploadId:r,responseGroupUuid:s,surveyId:t,replayDuration:i,eventDigest:c,userAgent:(w=window==null?void 0:window.navigator)==null?void 0:w.userAgent}),headers:a,shouldRetryRequest:!0});return o.breadcrumbsLogger.info("MarkUploadDone",{surveyId:t}),u},lt=e=>{if(e instanceof Attr)return null;let t=1;for(let r=e.previousSibling;r;r=r.previousSibling)r.nodeName===e.nodeName&&++t;return t},Ce=e=>{if(e===null)return"";const t=[];if(e instanceof Document)return"/";for(let r=e;r&&!(r instanceof Document)&&r!==null;r=r instanceof Attr?r.ownerElement:r.parentElement){const n=t[t.length]={name:void 0,position:null};switch(r.nodeType){case Node.TEXT_NODE:n.name="text()";break;case Node.ATTRIBUTE_NODE:n.name="@"+r.nodeName;break;case Node.PROCESSING_INSTRUCTION_NODE:n.name="processing-instruction()";break;case Node.COMMENT_NODE:n.name="comment()";break;case Node.ELEMENT_NODE:n.name=r.nodeName}n.position=lt(r)}return"/"+t.reverse().map(r=>r.position!==null?`/${r.name}[${r.position}]`:`/${r.name}`).join("")},ue=e=>e&&e.trim().substring(0,500).replace(/\s\s+/g," ").replace(/\r?\n|\r/g," ").substring(0,250),C={capture:!0,passive:!0},pt=["a","button","input","option","li","link"],gt=["Escape","Enter","Backspace","F5","Tab"];let $=!1,S=null,O=null;const he=e=>{var r;if(((r=e.tagName)==null?void 0:r.toLowerCase())==="html")return{element:"html"};const t={};return t.element=(n=>{if(!n.tagName)return"No tagName";const a=n.getAttribute("type");return a?`${a} ${n.tagName.toLowerCase()}`:n.tagName.toLowerCase()})(e),t},mt=e=>{var n;if(!e)return{};const t={...he(e)},r=e.parentElement;if(r&&pt.includes((n=r.tagName)==null?void 0:n.toLowerCase())){const a=he(r);Object.assign(t,a)}return t},ke=(e,t)=>{var a,s;let r=t.target;var n;t.target===((a=window.document)==null?void 0:a.body)&&window.Sprig.pointerDownTarget&&(r=window.Sprig.pointerDownTarget),n={x:t.x,y:t.y,type:e,elementAttributes:mt(r),windowHeight:window.innerHeight,windowWidth:window.innerWidth,...r instanceof HTMLElement?{rect:r==null?void 0:r.getBoundingClientRect(),xPath:Ce(r)}:{}},(s=n==null?void 0:n.elementAttributes)!=null&&s.text&&(n.elementAttributes.text=ue(n.elementAttributes.text)),S==null||S("Sprig_Click",n)},Re=e=>{var t;gt.includes(e.key)&&(t={key:e.key},S==null||S("Sprig_Keystroke",t))},wt=()=>{var e;window.performance.getEntriesByType("navigation").map(t=>t.type).includes("reload")&&(e={url:window.location.href,currentPageTitle:document.title},S==null||S("Sprig_Refresh",e))},yt=()=>{var e;window.performance.getEntriesByType("navigation").map(t=>t.type).includes("back_forward")&&((e={curUrl:window.location.href,fromUrl:document.referrer,currentPageTitle:document.title}).currentPageTitle&&(e.currentPageTitle=ue(e.currentPageTitle)),S==null||S("Sprig_BackForward",e))},Ue=((e,t)=>{let r;return n=>{clearTimeout(r),r=window.setTimeout(()=>e(n),t)}})(e=>{if(!(e.target instanceof HTMLElement||e.target instanceof Document))return;let t=e.target;"scrollTop"in t||(t=t.documentElement),O==null||O({xPath:Ce(t),x:t.scrollLeft,y:t.scrollTop,elementAttributes:{targetScrollWidth:t.scrollWidth,targetClientWidth:t.clientWidth,targetScrollHeight:t.scrollHeight,targetClientHeight:t.clientHeight}})},750),Pe=(Ie="left_click",e=>ke(Ie,e));var Ie;const xe=e=>{e.button===2&&ke("right_click",e)},Le=e=>{window.Sprig&&(window.Sprig.pointerDownTarget=e.target)},g={isRecording:!1,scrollEventUuids:{},stopRecording:()=>{}},Be=()=>window.indexedDB&&window.IDBKeyRange&&window.CompressionStream,h=(()=>{const e=o.sessionStorageHelper.getItem("sprig.sessionId");if(e)return o.breadcrumbsLogger.info("SessionIDFound",{savedSessionId:e}),o.sessionStorageHelper.removeItem("sprig.sessionId"),e;const t=o.v4();return o.breadcrumbsLogger.info("GeneratedSessionID",{uuid:t}),t})(),ne=()=>{o.sessionStorageHelper.setItem("sprig.disableReplayRecording","disabled")},k=()=>!!o.sessionStorageHelper.getItem("sprig.disableReplayRecording");window.addEventListener("beforeunload",()=>{o.breadcrumbsLogger.info("BeforeUnload",{sessionId:h}),o.sessionStorageHelper.setItem("sprig.sessionId",h)});const T=(e,t)=>{var r,n;if(!k()&&g.isRecording)try{(n=(r=window.rrwebRecord)==null?void 0:r.addCustomEvent)==null||n.call(r,e,t)}catch(a){K("Error recording custom event",a)}},ft=async e=>{const{x:t,xPath:r,y:n}=e,a=g.scrollEventUuids[r];if(a)return b(async()=>{var c,d,u,w;const s=await l.openDB(),i=await s.get("events",a);if(i!=null&&i.event){const p=JSON.parse(i.event),f=t>((d=(c=p.data)==null?void 0:c.payload)==null?void 0:d.x),m=n>((w=(u=p.data)==null?void 0:u.payload)==null?void 0:w.y);if(!f&&!m)return null;f&&(p.data.payload.x=t),m&&(p.data.payload.y=n),p.data.payload.elementAttributes=e.elementAttributes,i.event=JSON.stringify(p),await s.put("events",i)}else T("Sprig_Scroll",e)},"Error updating scroll event");T("Sprig_Scroll",e)},Te=()=>{g.stopRecording&&(g.stopRecording(),g.stopRecording=void 0),g.isRecording=!1,["cleanupInterval","inactivityInterval","pendingCheckInterval"].forEach(e=>{g[e]&&(clearInterval(g[e]),g[e]=void 0)}),$&&(window.removeEventListener("click",Pe,C),window.removeEventListener("pointerdown",Le,C),window.removeEventListener("mousedown",xe,C),window.removeEventListener("keydown",Re,C),window.removeEventListener("scroll",Ue,C),$=!1),ce.forEach(e=>{var t;(t=e.source)==null||t.postMessage({type:ut},{targetOrigin:e.origin})})},ht=["did not allow mutations","called in an invalid security context"],It=(e,t,{reportError:r=!0,extraInfo:n={}})=>{if(!k()&&t instanceof Error){if(ne(),t.name==="VersionError")return o.breadcrumbsLogger.error("VersionErr",{message:e}),l.deleteDB();(a=>{if(!a)return!0;for(const s of ht)if(a.toLowerCase().includes(s))return!1;return!0})(t==null?void 0:t.message)&&(r&&window.UserLeap.reportError(e,t,n),l.clearAll())}},K=(e,t,{reportError:r}={reportError:!0})=>{Te(),o.breadcrumbsLogger.error("ReplayErr",{code:t.code,name:t.name}),It(e,t,{reportError:r})},b=async(e,t)=>{try{return await e()}catch(r){K(t,r)}},Me=()=>{g.isRecording&&(b(()=>{var e,t;return(t=(e=window.rrwebRecord)==null?void 0:e.takeFullSnapshot)==null?void 0:t.call(e,!0)},"Error recording full snapshot"),ce.forEach(e=>{var t;(t=e.source)==null||t.postMessage({type:ct},{targetOrigin:e.origin})}))};Be()&&(te("replayStorage").catch(console.error),te("sprig.replay").catch(console.error));const l=new class{openDB(){return function(e,t,{blocked:r,upgrade:n,blocking:a,terminated:s}={}){const i=indexedDB.open(e,t),c=L(i);return n&&(i.onupgradeneeded=d=>{n(L(i.result),d.oldVersion,d.newVersion,L(i.transaction),d)}),r&&(i.onblocked=d=>r(d.oldVersion,d.newVersion,d)),c.then(d=>{s&&(d.onclose=()=>s()),a&&(d.onversionchange=u=>a(u.oldVersion,u.newVersion,u))}).catch(()=>{}),c}("sprigReplay",1,{upgrade:(e,t,r)=>{if(r===0&&o.sessionStorageHelper.setItem("sprig.pendingCount","0"),!e.objectStoreNames.contains("events")){const n=e.createObjectStore("events",{keyPath:"uuid"});n.createIndex("sessionId","sessionId"),n.createIndex("timestamp","timestamp"),n.createIndex("[sessionId+timestamp]",["sessionId","timestamp"])}if(!e.objectStoreNames.contains("chunkUploads")){const n=e.createObjectStore("chunkUploads",{keyPath:"uuid"});n.createIndex("sessionId","sessionId"),n.createIndex("timestamp","timestamp"),n.createIndex("[sessionId+status]",["sessionId","status"]),n.createIndex("[uploadId+status]",["uploadId","status"]),n.createIndex("[sessionId+status+uploadId]",["sessionId","status","uploadId"])}if(!e.objectStoreNames.contains("pendingCaptures")){const n=e.createObjectStore("pendingCaptures",{keyPath:"uuid"});n.createIndex("sessionId","sessionId"),n.createIndex("timestamp","timestamp"),n.createIndex("[sessionId+targetTimestamp]",["sessionId","targetTimestamp"])}}})}deleteDB(){return te("sprigReplay").catch(console.error)}async bulkAdd(e,t){const r=(await this.openDB()).transaction(e,"readwrite");return Promise.all([...t.map(n=>r.store.add(n)),r.done])}async clearAll(){const e=(await this.openDB()).transaction(["events","chunkUploads","pendingCaptures"],"readwrite");return Promise.all([e.objectStore("events").clear(),e.objectStore("chunkUploads").clear(),e.objectStore("pendingCaptures").clear()])}async deleteBySessionId(e,t){const r=IDBKeyRange.only(t),n=(await this.openDB()).transaction(e,"readwrite"),a=n.store.index("sessionId");for await(const s of a.iterate(r))await s.delete();await n.done}async updatePartial(e,t,r){const n=(await this.openDB()).transaction(e,"readwrite"),a=await n.store.get(t);a&&await n.store.put({...a,...r}),await n.done}async deleteRowsBefore(e,t,r=()=>!0){const n=IDBKeyRange.upperBound(t,!0),a=(await this.openDB()).transaction(e,"readwrite"),s=a.store.index("timestamp");for await(const i of s.iterate(n))r(i.value)&&await i.delete();await a.done}async getEventsBetween(e,t=Date.now()){if(e>=t)return Promise.resolve([]);const r=IDBKeyRange.bound([h,e],[h,t],!1,!0);return(await this.openDB()).getAllFromIndex("events","[sessionId+timestamp]",r)}async updateEventsExpiredAt(e,t,r=30){const n=new Date,a=n.setMinutes(n.getMinutes()+(r??30)),s=(await this.openDB()).transaction("events","readwrite"),i=s.store.index("[sessionId+timestamp]"),c=IDBKeyRange.bound([h,e],[h,t],!1,!0);for await(const d of i.iterate(c))await d.update({...d.value,expiredAt:a});await s.done}async deleteChunkUploads(e,t){const r=IDBKeyRange.only([t,e]),n=(await this.openDB()).transaction("chunkUploads","readwrite");let s=await n.store.index("[uploadId+status]").openCursor(r);for(;s;)s.delete(),s=await s.continue();await n.done}async getChunkUploadsByStatus({sessionId:e,status:t,uploadId:r}){const n=(await this.openDB()).transaction("chunkUploads","readonly"),a=r?n.store.index("[uploadId+status]"):n.store.index("[sessionId+status]"),s=r?IDBKeyRange.only([r,t]):IDBKeyRange.only([e,t]);return a.getAll(s)}async getPendingCaptures(e={}){return(await(await this.openDB()).getAllFromIndex("pendingCaptures","sessionId",h)).filter(r=>!e.beforePresent||r.targetTimestamp<Date.now()).filter(r=>!e.isBeforeType||r.captureParams.replayParams.replayDurationType==="before").filter(r=>!e.isHeatmap||(r.captureParams.isHeatmap??!1))}async markPendingCaptureToCanUpload(e){const t=(await this.openDB()).transaction("pendingCaptures","readwrite"),r=t.store.index("sessionId");for await(const n of r.iterate(h)){const a=n.value;a.captureParams.responseGroupId===e&&await n.update({...a,canUpload:!0})}await t.done}async markPendingHeatmapsReady(e){if(parseInt(o.sessionStorageHelper.getItem("sprig.pendingCount")??"0")===0)return null;const t=Date.now(),r=(await this.openDB()).transaction("pendingCaptures","readwrite"),n=r.store.index("sessionId");for await(const a of n.iterate(h)){const s=a.value;!s.captureParams.isHeatmap||e&&!e.includes(s.uuid)||await a.update({...s,targetTimestamp:t,captureParams:{...s.captureParams,triggerTimestamp:t,replayParams:{...s.captureParams.replayParams,replayDurationSeconds:Math.floor((t-s.timestamp)/1e3)}}})}await r.done}},P=[];let H,Ae,j,_e,F,Ne,M=[],_=!1,A=0,V=!1,He=!1,le=[],z=!1;const N=()=>V&&!_&&Date.now()<=j,vt=({apiUrl:e,config:t,triggerSnapshot:r,forceInit:n=!1})=>{V&&!n||(o.sessionStorageHelper.isStorageAvailable?(M=[],le.splice(0),P.splice(0),A=0,F=r,Ae=e,H={responseGroupUuid:t.responseGroupUuid,surveyId:t.surveyId,userAgent:t.userAgent,sdkVersion:t.sdkVersion},_e=t.maxDurationSeconds,Et(),V||(Ne=window.setInterval(Dt,500)),V=!0):_=!0)},bt=[U.Drag,U.Input,U.MediaInteraction,U.MouseInteraction,U.MouseMove,U.Scroll,U.Selection,U.TouchMove],St=e=>e.type===x.Custom||e.type===x.IncrementalSnapshot&&bt.includes(e.data.source),pe=e=>e.some(St),Dt=async()=>{if(!N())return void window.clearInterval(Ne);if(Oe(),!pe(P))return;const e=P[0].timestamp;Date.now()-e>35e3&&(F==null||F())},Oe=async()=>{if(M.length||z)return;z=!0;const e=await kt();if(!e)return void(_=!0);le.splice(0,e.length).forEach(t=>t(e.shift())),e.forEach(t=>M.push(t)),z=!1},Et=()=>{const e=o.sessionStorageHelper.getItem("sprig.alwayson.info");if(e){o.breadcrumbsLogger.info("Read stored session state",e);const t=JSON.parse(e);_=t.disabled,H=t.metadata,M=t.uploadUrls,A=t.currentIndex,j=t.expirationTimestamp,t.pendingEventTimestamp&&(o.breadcrumbsLogger.info(`Uploading with pending timestamp: ${t.pendingEventTimestamp}`),Ct(t.pendingEventTimestamp))}else j=1e3*_e+Date.now()},Ct=async e=>{const t=Date.now(),r=(await l.getEventsBetween(e,t)).map(a=>JSON.parse(a.event));if(!pe(r))return;$e(r);const n=await Ge();n&&await Ve(n,r)},Fe=async(e,t)=>{try{const r=await e();if(!r.ok)throw new Error(`Error ${t}`);return r}catch{_=!0}},Ve=async(e,t)=>{if(!N()||!e)return;const r=await(async n=>{const a=new TextEncoder,s=new CompressionStream("gzip"),i=s.writable.getWriter(),c=a.encode(JSON.stringify(n));return i.write(c),i.close(),new Uint8Array(await new Response(s.readable).arrayBuffer())})(t);o.breadcrumbsLogger.info("Uploading always-on events with presigned url"),await Fe(()=>o.sprigFetch(e,{body:r,method:"PUT"}),"uploading always-on with presigned url")},kt=async()=>{if(!N())return;const{surveyId:e,responseGroupUuid:t}=H,r={responseGroupUuid:t,surveyId:e,index:A+1};o.breadcrumbsLogger.info("Fetching always-on upload urls",r);const n=await Fe(()=>o.sprigFetch(`${Ae}/sdk/1/replayUrls`,{method:"POST",body:JSON.stringify(r),headers:o.getHttpHeaders(window.UserLeap)}),"fetching always-on signed urls");if(!n)return;const a=n.json.signedUrls;return o.breadcrumbsLogger.info("Fetched more always-on upload urls",{body:r,urls:a}),a},Ge=async()=>{if(M.length)return M.shift();const e=new Promise(t=>{le.push(t)});return Oe(),e},$e=e=>{var a,s,i;const t=e.length?e[e.length-1].timestamp:Date.now(),r=A,n=((s=(a=window.UserLeap)==null?void 0:a.config)==null?void 0:s.customMetadata)??((i=window.__cfg)==null?void 0:i.customMetadata);A++,e.push({timestamp:t,type:x.Custom,data:{tag:"Sprig_Meta",payload:{...H,index:r,visitorId:window.UserLeap.visitorId??"",timestamp:t,customMetadata:n}}})},Rt=(e,t)=>{N()&&!He&&(e||P.length)&&(e&&P.length&&(async()=>{const r=P.splice(0);if(!pe(r))return;o.breadcrumbsLogger.info("Capturing always-on event array to upload"),$e(r);const n=await Ge();n&&await Ve(n,r)})(),P.push(t))};window.addEventListener("beforeunload",async()=>{He=!0,N()&&(o.breadcrumbsLogger.info("Always On handle page unload"),(()=>{let e;P.length&&(e=P[0].timestamp);const t={disabled:_,metadata:H,uploadUrls:M,currentIndex:A,pendingEventTimestamp:e,expirationTimestamp:j};o.breadcrumbsLogger.info("Storing session state on unload",t),o.sessionStorageHelper.setItem("sprig.alwayson.info",JSON.stringify(t))})())});const je=async(e,t)=>{const r=performance.now();let n;try{n=await e()}finally{const a=performance.now()-r;let s=o.PerformanceMetrics[t];s||(s=o.registerMetric(t)),s.report(a/1e3)}return n},Ke=(e,t)=>{const r=performance.now();try{e()}finally{const n=performance.now()-r;let a=o.PerformanceMetrics[t];a||(a=o.registerMetric(t)),a.report(n/1e3)}};let We=5e3,ae=6e4,se=0,B,oe=!1,ie=[];const Ut=e=>{var t,r,n,a;if((t=e.event)!=null&&t.includes("Sprig_Scroll")){const s=(a=(n=(r=JSON.parse(e.event))==null?void 0:r.data)==null?void 0:n.payload)==null?void 0:a.xPath;if(!s)return;g.scrollEventUuids[s]=e.uuid}ie.push(e),oe||Pt()},Pt=()=>{oe=!0,setTimeout(async()=>{if(k())return;const e=ie;ie=[],oe=!1,Ke(async()=>{await(async t=>{const r=t.map(n=>({...n,sessionId:n.sessionId??h}));if(r.length!==0)return b(()=>l.bulkAdd("events",r),"Error storing replay events")})(e)},"sdk_replay_add_event_batch_seconds")},500)},xt=(e,t,r)=>{g.cleanupInterval=window.setInterval(()=>{const n=Date.now();je(()=>b(async()=>{k()||await Promise.all([l.deleteRowsBefore("events",n-1e3*e,a=>a.expiredAt===void 0||a.expiredAt<n-1e3*e),l.deleteRowsBefore("chunkUploads",n-1e3*t),l.deleteRowsBefore("pendingCaptures",n-1e3*r,a=>!a.canUpload)])},"Error deleting table rows"),"sdk_replay_cleanup_seconds"),o.breadcrumbsLogger.debug("CleanupComplete")},3e4)},Lt=()=>{g.pendingCheckInterval=window.setInterval(async()=>{b(async()=>{await de()},"Error initiating pending captures")},5e3)};let Q=!1;const de=async(e=!1)=>{if(!Q)try{Q=!0;const t=parseInt(B??"0");if(t===0)return;const r=await l.getPendingCaptures({beforePresent:!0,isBeforeType:e}),n=await l.openDB();await Promise.all(r.map(async a=>(await n.delete("pendingCaptures",a.uuid),ze(a.captureParams,a.canUpload)))),B=(t-r.length).toString(),o.sessionStorageHelper.setItem("sprig.pendingCount",B)}finally{Q=!1}},Bt=async(e,t,r,n,a)=>{const s=Math.min(e+a,r),i=await je(()=>l.getEventsBetween(e,s),"sdk_replay_get_events_between_seconds");if(!(i!=null&&i.length))return o.breadcrumbsLogger.debug("NoEventsFound"),{validStartFound:n,events:[]};if(!n){o.breadcrumbsLogger.debug("ValidStartSearch");let c=-1;return i==null||i.forEach((d,u)=>{if(!d.isValidStart)return;const w=d.timestamp<=t;(c<0||w)&&(c=u)}),c<0?(o.breadcrumbsLogger.debug("ValidStartNotFound"),{validStartFound:n,events:[]}):{validStartFound:!0,events:i==null?void 0:i.slice(c)}}return{validStartFound:n,events:i}},Je=e=>Promise.all(e.map(async t=>{const r=await(async n=>De.execute(async()=>{var i;o.breadcrumbsLogger.info("UploadChunkStart",{chunkIndex:n.chunkIndex,surveyId:n.surveyId});const a=await o.sprigFetch(n.uploadUrl,{body:n.data,method:"PUT"});o.breadcrumbsLogger.http("UploadChunkEnd",{url:n.uploadUrl,method:"PUT",status_code:a.status,reason:a.statusText??"OK",chunkIndex:n.chunkIndex,surveyId:n.surveyId});const s=(i=a.headers)==null?void 0:i.get("ETag");if(!s)throw new Error(`Upload response did not include etag for upload ${n.uploadId}, part ${n.chunkIndex}`);return s}))(t);return await l.updatePartial("chunkUploads",t.uuid,{data:null,etag:r,status:"UploadComplete"}),t.uploadId})),qe=async e=>{const t=await l.getChunkUploadsByStatus({status:"UploadComplete",uploadId:e});if(!(t!=null&&t.length))return void o.breadcrumbsLogger.info("NoChunksForUpload",{uploadId:e});const r=t.reduce((s,i)=>(s.find(c=>c.chunkIndex===i.chunkIndex)||s.push(i),s),[]);r.sort((s,i)=>s.chunkIndex-i.chunkIndex);const n=r.map(s=>({ETag:s.etag,PartNumber:s.chunkIndex})).filter(s=>s.ETag!==null),a=r[0];await Ee({apiUrl:a.apiUrl,surveyId:a.surveyId,uploadId:e,responseGroupUuid:a.responseGroupId,etags:n,headers:a.completeUploadHeaders,replayDuration:a.replayDuration}),await l.deleteChunkUploads("UploadComplete",e)},Tt=()=>{b(async()=>{const e=await l.getChunkUploadsByStatus({sessionId:h,status:"ReadyForUpload"});if(!(e!=null&&e.length))return;const t=await Je(e);t!=null&&t.length&&await Promise.all(t.map(r=>{if(r)return qe(r)}))},"Error uploading unfinished chunks")},Mt=async(e,t)=>{const r=t??Date.now();return(async(n,a)=>{const s=new TextEncoder;let i=null;const c=new CompressionStream("gzip"),d=c.writable.getWriter();let u=!1,w=!1,[p,f]=[0,0],m=[];for(let R=n-35e3;R<a;R+=ae){if({validStartFound:w,events:m}=await Bt(R,n,a,w,ae),!(m!=null&&m.length)){o.breadcrumbsLogger.debug("NoEventsFound");continue}p===0&&(p=m[0].timestamp),f=m[m.length-1].timestamp;const y=m.map(E=>E.event);y.push(`{"timestamp":${a}}`);const I=`${u?",":"["}${y}`,v=s.encode(I);Ke(()=>{d.write(v)},"sdk_replay_compression_seconds"),u=!0}if(f-p<We)return o.breadcrumbsLogger.debug("ReplayTooShort"),null;const D=s.encode("]");return d.write(D),d.close(),i=new Uint8Array(await new Response(c.readable).arrayBuffer()),i})(r-e,r)},ve=async e=>{const{surveyId:t,responseGroupId:r,visitorId:n,apiUrl:a,completeUploadHeaders:s,replayParams:i,triggerTimestamp:c}=e,d=await Mt(1e3*i.replayDurationSeconds,c);if(!(d!=null&&d.length))return void o.breadcrumbsLogger.info("FileDataEmpty",{surveyId:t});const u=((p,f,m)=>{const D=p.length,R=1024*f*1024,y=Math.ceil(D/m),I=Math.max(R,y),v=[];let E=0;for(;E<D;)v.push(p.slice(E,E+I)),E+=I;return v})(d,i.minimumChunkSizeMb,i.signedUrls.length),w=await Promise.all(u.map(async(p,f)=>{const m=o.v4(),D={apiUrl:a,chunkIndex:f+1,completeUploadHeaders:s,etag:null,responseGroupId:r,status:"ReadyForUpload",surveyId:t,timestamp:c,totalChunks:u.length,data:p,uploadId:i.uploadId,uploadUrl:i.signedUrls[f].url,uuid:m,visitorId:n};return await(await l.openDB()).add("chunkUploads",{...D,sessionId:D.sessionId??h}),D}));await(async(p,f)=>{await Je(f),await Promise.all(p.map(m=>qe(m)))})([i.uploadId],w)},ze=async(e,t)=>{if(k())return o.breadcrumbsLogger.debug("ReplayDisabled-ScheduleOrCapture");const{isHeatmap:r,isStandalone:n,replayParams:a,triggerTimestamp:s,responseGroupId:i}=e,c=async()=>{setTimeout(()=>o.eventEmitter.removeListener(o.SprigEvent.QuestionAnswered,c),0),b(async()=>{a.replayDurationType==="before"?await ve(e):await l.markPendingCaptureToCanUpload(i)},"Error in schedule/capture callback")};b(async()=>{if(a.replayDurationType==="after"||a.replayDurationType==="beforeAndAfter")return!n&&!r&&o.eventEmitter.on(o.SprigEvent.QuestionAnswered,c),void await Xe(e);if(n||r||t)await ve(e),r&&At();else{const d=35+a.replayDurationSeconds,u=s-1e3*d,w=s;await l.updateEventsExpiredAt(u,w,a.expirationTimeLimitMinutes),o.eventEmitter.on(o.SprigEvent.QuestionAnswered,c)}},"Error in scheduling/capturing replay")},At=async()=>{parseInt(B??"0")||o.sessionStorageHelper.removeItem("sprig.isCapturingHeatmap"),o.sessionStorageHelper.getItem("sprig.teardownAfterCapture")&&(Te(),Qe(),o.sessionStorageHelper.removeItem("sprig.teardownAfterCapture"))},Qe=async()=>k()?o.breadcrumbsLogger.debug("ReplayDisabled-ClearData"):Promise.all([l.deleteBySessionId("events",h),l.deleteBySessionId("pendingCaptures",h)]).catch(e=>{K("Error clearing user replay data",e)}),Xe=async e=>{if(k())return;const{isHeatmap:t,surveyId:r}=e,n=await l.getPendingCaptures(),a=n==null?void 0:n.filter(d=>d.captureParams.surveyId===r);if(a!=null&&a.length)return void o.breadcrumbsLogger.info("PendingCaptureExists",{surveyId:r});t&&(Me(),o.sessionStorageHelper.setItem("sprig.isCapturingHeatmap","true"),se=Date.now(),g.inactivityInterval||(g.inactivityInterval=window.setInterval(()=>{var d;d=se,Date.now()-d>=3e4&&b(()=>l.markPendingHeatmapsReady(),"Error in heatmap inactivity")},1e3)));const s={...e,replayParams:{...e.replayParams}};e.replayParams.replayDurationType==="beforeAndAfter"&&(s.replayParams.replayDurationSeconds*=2),s.replayParams.replayDurationType="before";const i=e.triggerTimestamp+1e3*e.replayParams.replayDurationSeconds;s.triggerTimestamp=i,B=(parseInt(B??"0")+1).toString(),o.sessionStorageHelper.setItem("sprig.pendingCount",B),await(await l.openDB()).add("pendingCaptures",{canUpload:!1,captureParams:s,sessionId:h,targetTimestamp:i,timestamp:Date.now(),uuid:o.v4()})},_t=Object.freeze(Object.defineProperty({__proto__:null,RecordEvent:e=>{T("Sprig_TrackEvent",e)},RecordPageView:e=>{e.description&&(e.description=ue(e.description)),T("Sprig_PageView",e)},RecordSurveyShown:e=>{T("Sprig_ShowSurvey",e)},_completeSessionReplay:async({surveyId:e,responseGroupUuid:t,eventDigest:r,headers:n})=>{if(!e||!t)return!1;const a=window.UserLeap._API_URL,s=await Ee({surveyId:e,responseGroupUuid:t,eventDigest:r,apiUrl:a,headers:n},!0);return!(s!=null&&s.error)},checkPendingHeatmapsUrl:()=>k()?o.breadcrumbsLogger.debug("ReplayDisabled-PendingHeatmaps"):b(async()=>{const e=(await l.getPendingCaptures({isHeatmap:!0})).map(t=>({eventId:t.captureParams.eventId,uuid:t.uuid})).filter(({eventId:t})=>!o.checkUrlStillMatching(t)).map(({uuid:t})=>t);return o.breadcrumbsLogger.info("PendingHeatmapsToComplete",{count:e.length}),e.length&&(await l.markPendingHeatmapsReady(e),o.breadcrumbsLogger.info("MarkedPendingHeatmapsReady")),e.length},"Error marking pending heatmaps ready"),clearUserReplayData:Qe,disableRecording:K,initializeReplay:async({maxReplayDurationSeconds:e,maxInflightRequests:t=2,replaySettings:r,teardownAfter:n=!1,apiUrl:a,alwaysOnConfig:s})=>{if(s&&vt({apiUrl:a,config:s,triggerSnapshot:()=>{Me()}}),B=o.sessionStorageHelper.getItem("sprig.pendingCount"),g.isRecording)return;if(n&&o.sessionStorageHelper.setItem("sprig.teardownAfterCapture","true"),k())return o.breadcrumbsLogger.debug("ReplayDisabled");if(await(async()=>{var d;if(!Be())return!0;if((d=window.navigator.storage)!=null&&d.estimate)try{const{quota:u=0,usage:w=0}=await window.navigator.storage.estimate(),p=(u-w)/1024**3;return o.breadcrumbsLogger.info("Storage",{availableGb:p}),p<.5}catch{return!0}return!1})())return o.breadcrumbsLogger.debug("IDBNotSupported"),ne();try{const d=await l.openDB();o.breadcrumbsLogger.info("DBVersion",{version:d.version})}catch(d){return o.breadcrumbsLogger.error("ReplayOpenErr",{name:d.name}),d.name==="VersionError"&&l.deleteDB(),ne()}b(async()=>{await de(!0)},"Error uploading ready pending captures");const i=N()?30:0,c=Math.max(e??0,i);if(!c)return o.breadcrumbsLogger.debug("MissingDuration");o.breadcrumbsLogger.debug("ReplayInit"),await b(async()=>{var d;r!=null&&r.minDuration&&(We=r.minDuration),r!=null&&r.batchDuration&&(ae=r.batchDuration),d=t,De.setLimit(d),Tt(),xt(c+35,1800,c+35),Lt();const u=window.UserLeap.replayLibraryURL??"https://cdn.sprig.com/dependencies/record-2.0.0-alpha.17.min.js";if(!window.rrwebRecord){const{record:y}=await import(u);window.rrwebRecord=y}const w=window.rrwebRecord;if(!w)return o.breadcrumbsLogger.error("RecordScriptFailed");let p=!0,f=0;const m={checkoutEveryNms:3e4,sampling:{input:"last",scroll:250,media:800},...r};var D,R;g.stopRecording=w({emit:(y,I)=>{if(y.type===x.Custom&&(se=Date.now()),k())return;if(I&&y.type===x.Meta)f=performance.now();else if(I&&f&&y.type===x.FullSnapshot){const E=performance.now()-f;o.reportAndRegister("sdk_replay_snapshot_seconds",E/1e3)}const v=p||!!I&&y.type===x.Meta;p=!1,Rt(v,y),Ut({uuid:o.v4(),event:JSON.stringify(y),isValidStart:v,timestamp:Date.now()})},...m}),g.isRecording=!!g.stopRecording,g.isRecording&&(((y,I)=>{window.addEventListener("message",v=>{var E;v.data.type===it&&(ce.push({source:v.source,origin:v.origin}),(E=v.source)==null||E.postMessage({type:dt,settings:y,replayLibraryUrl:I},{targetOrigin:v.origin}))})})(m,u),o.eventEmitter.on("survey.complete",y=>{var I;I={id:y,userAgent:window.navigator.userAgent},T("Sprig_SubmitSurvey",I)}),D=T,R=ft,$||(S=D,O=R,window.addEventListener("click",Pe,C),window.addEventListener("pointerdown",Le,C),window.addEventListener("mousedown",xe,C),window.addEventListener("keydown",Re,C),window.addEventListener("scroll",Ue,C),$=!0,wt(),yt()))},"Error initializing replay")},isReplayRecording:()=>g.isRecording,scheduleCapture:Xe,scheduleOrCaptureReplay:ze,tryReplayAction:b,uploadReadyPendingCaptures:de},Symbol.toStringTag,{value:"Module"}));o.registerReplay(_t);