@wf-financing/ui-sdk 3.3.0 → 3.4.1

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/index.cjs.js CHANGED
@@ -1 +1 @@
1
- "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});var h=Object.defineProperty,v=(r,e,t)=>e in r?h(r,e,{enumerable:!0,configurable:!0,writable:!0,value:t}):r[e]=t,d=(r,e,t)=>v(r,typeof e!="symbol"?e+"":e,t);const I="https://api.wayflyer.com",b="https://sandbox-api.wayflyer.com",k=r=>{try{return JSON.parse(atob(r.split(".")[1]))}catch{return null}},E={"Content-Type":"application/json"},y={event:"/financing/v1/company/event/",error:"/financing/v1/error/"},u="wf_session_v1",U=1800*1e3,A=1440*60*1e3;class D{getSessionId(){const e=Date.now();let t=this.loadSession();return(!t||this.isSessionExpired(t,e))&&(t=this.mintNewSession(e)),t.lastActivity=e,this.saveSession(t),t.sessionId}isSessionExpired(e,t){const n=t-e.lastActivity>U,s=t-e.createdAt>A;return n||s}mintNewSession(e){return{sessionId:crypto.randomUUID(),createdAt:e,lastActivity:e}}loadSession(){try{const e=sessionStorage.getItem(u);return e?JSON.parse(e):null}catch{return null}}saveSession(e){try{sessionStorage.setItem(u,JSON.stringify(e))}catch{console.warn("Failed to save session context")}}}const w=class a{constructor(e,t,n){d(this,"baseUrl",null),d(this,"sessionManager"),d(this,"headers"),this.companyToken=e,this.baseUrl=n?b:I,this.sessionManager=new D,this.headers={...E,...t?{"X-SDK-Version":t}:{}}}get requestHeaders(){const e=a.getInstance(),t=e.sessionManager.getSessionId();return{Authorization:`Bearer ${e.companyToken}`,"X-Session-ID":t,...e.headers}}static getGlobalInstance(){return window.WayflyerLogger||null}static setGlobalInstance(e){window.WayflyerLogger=e}static initialize(e,t,n){a.getGlobalInstance()&&console.warn("Logger re-initialized");const s=new a(e,t,n==null?void 0:n.isSandbox);a.setGlobalInstance(s)}static getMandatoryProperties(e){const t=k(e),[n,s]=(t==null?void 0:t.sub.split("|"))||[],i=t==null?void 0:t.user_id;return{partner_id:n,company_id:s,user_id:i}}static getInstance(){const e=a.getGlobalInstance();if(!e)throw new Error("Logger not initialized. Call initialize() first.");return e}static async logEvent(e,t){if(this.isDevEnvironment)return;const n=a.getInstance();try{const s={...a.getMandatoryProperties(n.companyToken),...t},i=await fetch(n.baseUrl+y.event,{method:"POST",headers:n.requestHeaders,body:JSON.stringify({timestamp:new Date().toISOString(),event_name:e,properties:s})});if(i.status===200)return await i.json()}catch(s){console.error("Failed to log event",s)}}static async logError(e,t){if(this.isDevEnvironment){console.error(e);return}const n=a.getInstance();try{const s={...a.getMandatoryProperties(n.companyToken),...t},i=await fetch(n.baseUrl+y.error,{method:"POST",headers:n.requestHeaders,body:JSON.stringify({timestamp:new Date().toISOString(),message:e,properties:s})});if(i.status===200)return await i.json()}catch(s){console.warn("Failed to log error",s)}}};d(w,"isDevEnvironment",!1);let l=w;const g=(r,e)=>{if(!window.WayflyerUiSdk)throw new Error("SDK code was fetched successfully, but WayflyerUiSdk is unavailable on window");const t=window.WayflyerUiSdk;return new t(r,e)},p="wayflyer-ui-package",_="https://embedded-finance-frontend.vercel.app/npm/@wf-financing/ui@4",S="3.3.0",z=async(r,e)=>document.getElementById(p)?g(r,e):new Promise((n,s)=>{const i=document.createElement("script");i.src=_,i.type="module",i.id=p,i.async=!0,i.onload=()=>{try{const o=g(r,e);n(o)}catch(o){s(o)}},i.onerror=()=>{s(new Error(`Failed to load UI SDK script from ${i.src}`))},document.head.appendChild(i)}),O="ui";class P{static async loadSdk(e,t){const n=Date.now();let s;try{s=await z(e,t)}catch(c){const m=c instanceof Error?c:new Error(String(c));throw l.initialize(e,void 0,t),l.logError(m.message,{entry_point_version:S}),c}const o=Date.now()-n,f=s.sdkVersion;return l.initialize(e,f,t),l.logEvent("ui_sdk_initialized",{entry_point_version:S,entry_point_type:O,sdk_initialization_latency:o}),s}}exports.WayflyerUiSdk=P;
1
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});var m=Object.defineProperty,p=(s,e,t)=>e in s?m(s,e,{enumerable:!0,configurable:!0,writable:!0,value:t}):s[e]=t,l=(s,e,t)=>p(s,typeof e!="symbol"?e+"":e,t);const v="https://api.wayflyer.com",I="https://sandbox-api.wayflyer.com",E=s=>{try{return JSON.parse(atob(s.split(".")[1]))}catch{return null}},b={"Content-Type":"application/json"},u={event:"/financing/v1/company/event/",error:"/financing/v1/error/"},y="wf_session_v1",U=1800*1e3,k=1440*60*1e3;class _{getSessionId(){const e=Date.now();let t=this.loadSession();return(!t||this.isSessionExpired(t,e))&&(t=this.mintNewSession(e)),t.lastActivity=e,this.saveSession(t),t.sessionId}isSessionExpired(e,t){const i=t-e.lastActivity>U,n=t-e.createdAt>k;return i||n}mintNewSession(e){return{sessionId:crypto.randomUUID(),createdAt:e,lastActivity:e}}loadSession(){try{const e=sessionStorage.getItem(y);return e?JSON.parse(e):null}catch{return null}}saveSession(e){try{sessionStorage.setItem(y,JSON.stringify(e))}catch{console.warn("Failed to save session context")}}}const f=class a{constructor(e,t,i){l(this,"baseUrl",null),l(this,"sessionManager"),l(this,"headers"),this.companyToken=e,this.baseUrl=i?I:v,this.sessionManager=new _,this.headers={...b,...t?{"X-SDK-Version":t}:{}}}get requestHeaders(){const e=a.getInstance(),t=e.sessionManager.getSessionId();return{Authorization:`Bearer ${e.companyToken}`,"X-Session-ID":t,...e.headers}}static getGlobalInstance(){return window.WayflyerLogger||null}static setGlobalInstance(e){window.WayflyerLogger=e}static initialize(e,t,i){a.getGlobalInstance()&&console.warn("Logger re-initialized");const n=new a(e,t,i==null?void 0:i.isSandbox);a.setGlobalInstance(n)}static getMandatoryProperties(e){const t=E(e),[i,n]=(t==null?void 0:t.sub.split("|"))||[],r=t==null?void 0:t.user_id;return{partner_id:i,company_id:n,user_id:r}}static getInstance(){const e=a.getGlobalInstance();if(!e)throw new Error("Logger not initialized. Call initialize() first.");return e}static async logEvent(e,t){if(this.isDevEnvironment)return;const i=a.getInstance();try{const n={...a.getMandatoryProperties(i.companyToken),...t},r=await fetch(i.baseUrl+u.event,{method:"POST",headers:i.requestHeaders,body:JSON.stringify({timestamp:new Date().toISOString(),event_name:e,properties:n})});if(r.status===200)return await r.json()}catch(n){console.error("Failed to log event",n)}}static async logError(e,t){if(this.isDevEnvironment){console.error(e);return}const i=a.getInstance();try{const n={...a.getMandatoryProperties(i.companyToken),...t},r=await fetch(i.baseUrl+u.error,{method:"POST",headers:i.requestHeaders,body:JSON.stringify({timestamp:new Date().toISOString(),message:e,properties:n})});if(r.status===200)return await r.json()}catch(n){console.warn("Failed to log error",n)}}};l(f,"isDevEnvironment",!1);let o=f;const S=(s,e)=>{if(!window.WayflyerUiSdk)throw new Error("SDK code was fetched successfully, but WayflyerUiSdk is unavailable on window");const t=window.WayflyerUiSdk;return new t(s,e)},D="wayflyer-ui-package",A="https://embedded-finance-frontend.vercel.app/npm/@wf-financing/ui@4",g="3.4.1",w="UI_SDK_READY_EVENT",P=async(s,e)=>window.WayflyerUiSdk?S(s,e):new Promise((i,n)=>{const r=document.createElement("script");r.src=A,r.type="module",r.id=D,r.async=!0,r.onerror=()=>{n(new Error(`Failed to load UI SDK script from ${r.src}`))};const d=()=>{const h=S(s,e);i(h)};window.addEventListener(w,d,{once:!0}),setTimeout(()=>{n(new Error("UI SDK initialization timeout exceeded")),window.removeEventListener(w,d)},1e3),document.head.appendChild(r)}),z="ui";let c=null;class L{static async loadSdk(e,t){var n;c??(c=this.getLoadSdkPromise(e,t));const i=await c;return((n=i==null?void 0:i.options)==null?void 0:n.language)!==(t==null?void 0:t.language)?(c=this.getLoadSdkPromise(e,t),await c):i}static async getLoadSdkPromise(e,t){const i=Date.now();try{const n=await P(e,t),r=Date.now()-i;return o.initialize(e,n.sdkVersion,t),o.logEvent("ui_sdk_initialized",{entry_point_version:g,entry_point_type:z,sdk_initialization_latency:r}),n}catch(n){const r=n instanceof Error?n:new Error(String(n));throw o.initialize(e,void 0,t),o.logError(r.message,{entry_point_version:g}),n}}}exports.WayflyerUiSdk=L;
package/dist/index.es.js CHANGED
@@ -1,25 +1,25 @@
1
- var f = Object.defineProperty, v = (r, e, t) => e in r ? f(r, e, { enumerable: !0, configurable: !0, writable: !0, value: t }) : r[e] = t, d = (r, e, t) => v(r, typeof e != "symbol" ? e + "" : e, t);
2
- const I = "https://api.wayflyer.com", b = "https://sandbox-api.wayflyer.com", E = (r) => {
1
+ var m = Object.defineProperty, p = (r, e, t) => e in r ? m(r, e, { enumerable: !0, configurable: !0, writable: !0, value: t }) : r[e] = t, l = (r, e, t) => p(r, typeof e != "symbol" ? e + "" : e, t);
2
+ const v = "https://api.wayflyer.com", I = "https://sandbox-api.wayflyer.com", E = (r) => {
3
3
  try {
4
4
  return JSON.parse(atob(r.split(".")[1]));
5
5
  } catch {
6
6
  return null;
7
7
  }
8
- }, k = {
8
+ }, b = {
9
9
  "Content-Type": "application/json"
10
- }, y = {
10
+ }, u = {
11
11
  event: "/financing/v1/company/event/",
12
12
  error: "/financing/v1/error/"
13
- }, u = "wf_session_v1", U = 1800 * 1e3, A = 1440 * 60 * 1e3;
14
- class D {
13
+ }, y = "wf_session_v1", U = 1800 * 1e3, k = 1440 * 60 * 1e3;
14
+ class _ {
15
15
  getSessionId() {
16
16
  const e = Date.now();
17
17
  let t = this.loadSession();
18
18
  return (!t || this.isSessionExpired(t, e)) && (t = this.mintNewSession(e)), t.lastActivity = e, this.saveSession(t), t.sessionId;
19
19
  }
20
20
  isSessionExpired(e, t) {
21
- const n = t - e.lastActivity > U, s = t - e.createdAt > A;
22
- return n || s;
21
+ const i = t - e.lastActivity > U, n = t - e.createdAt > k;
22
+ return i || n;
23
23
  }
24
24
  mintNewSession(e) {
25
25
  return {
@@ -30,7 +30,7 @@ class D {
30
30
  }
31
31
  loadSession() {
32
32
  try {
33
- const e = sessionStorage.getItem(u);
33
+ const e = sessionStorage.getItem(y);
34
34
  return e ? JSON.parse(e) : null;
35
35
  } catch {
36
36
  return null;
@@ -38,16 +38,16 @@ class D {
38
38
  }
39
39
  saveSession(e) {
40
40
  try {
41
- sessionStorage.setItem(u, JSON.stringify(e));
41
+ sessionStorage.setItem(y, JSON.stringify(e));
42
42
  } catch {
43
43
  console.warn("Failed to save session context");
44
44
  }
45
45
  }
46
46
  }
47
- const w = class a {
48
- constructor(e, t, n) {
49
- d(this, "baseUrl", null), d(this, "sessionManager"), d(this, "headers"), this.companyToken = e, this.baseUrl = n ? b : I, this.sessionManager = new D(), this.headers = {
50
- ...k,
47
+ const f = class a {
48
+ constructor(e, t, i) {
49
+ l(this, "baseUrl", null), l(this, "sessionManager"), l(this, "headers"), this.companyToken = e, this.baseUrl = i ? I : v, this.sessionManager = new _(), this.headers = {
50
+ ...b,
51
51
  ...t ? { "X-SDK-Version": t } : {}
52
52
  };
53
53
  }
@@ -65,14 +65,14 @@ const w = class a {
65
65
  static setGlobalInstance(e) {
66
66
  window.WayflyerLogger = e;
67
67
  }
68
- static initialize(e, t, n) {
68
+ static initialize(e, t, i) {
69
69
  a.getGlobalInstance() && console.warn("Logger re-initialized");
70
- const s = new a(e, t, n == null ? void 0 : n.isSandbox);
71
- a.setGlobalInstance(s);
70
+ const n = new a(e, t, i == null ? void 0 : i.isSandbox);
71
+ a.setGlobalInstance(n);
72
72
  }
73
73
  static getMandatoryProperties(e) {
74
- const t = E(e), [n, s] = (t == null ? void 0 : t.sub.split("|")) || [], i = t == null ? void 0 : t.user_id;
75
- return { partner_id: n, company_id: s, user_id: i };
74
+ const t = E(e), [i, n] = (t == null ? void 0 : t.sub.split("|")) || [], s = t == null ? void 0 : t.user_id;
75
+ return { partner_id: i, company_id: n, user_id: s };
76
76
  }
77
77
  static getInstance() {
78
78
  const e = a.getGlobalInstance();
@@ -82,24 +82,24 @@ const w = class a {
82
82
  }
83
83
  static async logEvent(e, t) {
84
84
  if (this.isDevEnvironment) return;
85
- const n = a.getInstance();
85
+ const i = a.getInstance();
86
86
  try {
87
- const s = {
88
- ...a.getMandatoryProperties(n.companyToken),
87
+ const n = {
88
+ ...a.getMandatoryProperties(i.companyToken),
89
89
  ...t
90
- }, i = await fetch(n.baseUrl + y.event, {
90
+ }, s = await fetch(i.baseUrl + u.event, {
91
91
  method: "POST",
92
- headers: n.requestHeaders,
92
+ headers: i.requestHeaders,
93
93
  body: JSON.stringify({
94
94
  timestamp: (/* @__PURE__ */ new Date()).toISOString(),
95
95
  event_name: e,
96
- properties: s
96
+ properties: n
97
97
  })
98
98
  });
99
- if (i.status === 200)
100
- return await i.json();
101
- } catch (s) {
102
- console.error("Failed to log event", s);
99
+ if (s.status === 200)
100
+ return await s.json();
101
+ } catch (n) {
102
+ console.error("Failed to log event", n);
103
103
  }
104
104
  }
105
105
  static async logError(e, t) {
@@ -107,65 +107,72 @@ const w = class a {
107
107
  console.error(e);
108
108
  return;
109
109
  }
110
- const n = a.getInstance();
110
+ const i = a.getInstance();
111
111
  try {
112
- const s = {
113
- ...a.getMandatoryProperties(n.companyToken),
112
+ const n = {
113
+ ...a.getMandatoryProperties(i.companyToken),
114
114
  ...t
115
- }, i = await fetch(n.baseUrl + y.error, {
115
+ }, s = await fetch(i.baseUrl + u.error, {
116
116
  method: "POST",
117
- headers: n.requestHeaders,
117
+ headers: i.requestHeaders,
118
118
  body: JSON.stringify({
119
119
  timestamp: (/* @__PURE__ */ new Date()).toISOString(),
120
120
  message: e,
121
- properties: s
121
+ properties: n
122
122
  })
123
123
  });
124
- if (i.status === 200)
125
- return await i.json();
126
- } catch (s) {
127
- console.warn("Failed to log error", s);
124
+ if (s.status === 200)
125
+ return await s.json();
126
+ } catch (n) {
127
+ console.warn("Failed to log error", n);
128
128
  }
129
129
  }
130
130
  };
131
- d(w, "isDevEnvironment", !1);
132
- let l = w;
131
+ l(f, "isDevEnvironment", !1);
132
+ let o = f;
133
133
  const g = (r, e) => {
134
134
  if (!window.WayflyerUiSdk)
135
135
  throw new Error("SDK code was fetched successfully, but WayflyerUiSdk is unavailable on window");
136
136
  const t = window.WayflyerUiSdk;
137
137
  return new t(r, e);
138
- }, p = "wayflyer-ui-package", _ = "https://embedded-finance-frontend.vercel.app/npm/@wf-financing/ui@4", S = "3.3.0", z = async (r, e) => document.getElementById(p) ? g(r, e) : new Promise((n, s) => {
139
- const i = document.createElement("script");
140
- i.src = _, i.type = "module", i.id = p, i.async = !0, i.onload = () => {
141
- try {
142
- const o = g(r, e);
143
- n(o);
144
- } catch (o) {
145
- s(o);
146
- }
147
- }, i.onerror = () => {
148
- s(new Error(`Failed to load UI SDK script from ${i.src}`));
149
- }, document.head.appendChild(i);
150
- }), O = "ui";
151
- class P {
138
+ }, D = "wayflyer-ui-package", A = "https://embedded-finance-frontend.vercel.app/npm/@wf-financing/ui@4", S = "3.4.1", w = "UI_SDK_READY_EVENT", P = async (r, e) => window.WayflyerUiSdk ? g(r, e) : new Promise((i, n) => {
139
+ const s = document.createElement("script");
140
+ s.src = A, s.type = "module", s.id = D, s.async = !0, s.onerror = () => {
141
+ n(new Error(`Failed to load UI SDK script from ${s.src}`));
142
+ };
143
+ const d = () => {
144
+ const h = g(r, e);
145
+ i(h);
146
+ };
147
+ window.addEventListener(w, d, { once: !0 }), setTimeout(() => {
148
+ n(new Error("UI SDK initialization timeout exceeded")), window.removeEventListener(w, d);
149
+ }, 1e3), document.head.appendChild(s);
150
+ }), z = "ui";
151
+ let c = null;
152
+ class L {
152
153
  static async loadSdk(e, t) {
153
- const n = Date.now();
154
- let s;
154
+ var n;
155
+ c ?? (c = this.getLoadSdkPromise(e, t));
156
+ const i = await c;
157
+ return ((n = i == null ? void 0 : i.options) == null ? void 0 : n.language) !== (t == null ? void 0 : t.language) ? (c = this.getLoadSdkPromise(e, t), await c) : i;
158
+ }
159
+ static async getLoadSdkPromise(e, t) {
160
+ const i = Date.now();
155
161
  try {
156
- s = await z(e, t);
157
- } catch (c) {
158
- const m = c instanceof Error ? c : new Error(String(c));
159
- throw l.initialize(e, void 0, t), l.logError(m.message, { entry_point_version: S }), c;
162
+ const n = await P(e, t), s = Date.now() - i;
163
+ return o.initialize(e, n.sdkVersion, t), o.logEvent("ui_sdk_initialized", {
164
+ entry_point_version: S,
165
+ entry_point_type: z,
166
+ sdk_initialization_latency: s
167
+ }), n;
168
+ } catch (n) {
169
+ const s = n instanceof Error ? n : new Error(String(n));
170
+ throw o.initialize(e, void 0, t), o.logError(s.message, {
171
+ entry_point_version: S
172
+ }), n;
160
173
  }
161
- const o = Date.now() - n, h = s.sdkVersion;
162
- return l.initialize(e, h, t), l.logEvent("ui_sdk_initialized", {
163
- entry_point_version: S,
164
- entry_point_type: O,
165
- sdk_initialization_latency: o
166
- }), s;
167
174
  }
168
175
  }
169
176
  export {
170
- P as WayflyerUiSdk
177
+ L as WayflyerUiSdk
171
178
  };
@@ -2,4 +2,5 @@ import { UiSdkOptions, IWayflyerUiSdk } from '@wf-financing/embedded-types';
2
2
 
3
3
  export declare class WayflyerUiSdk {
4
4
  static loadSdk(companyToken: string, options?: UiSdkOptions): Promise<IWayflyerUiSdk>;
5
+ private static getLoadSdkPromise;
5
6
  }
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@wf-financing/ui-sdk",
3
- "version": "3.3.0",
3
+ "version": "3.4.1",
4
4
  "main": "dist/index.cjs.js",
5
5
  "module": "dist/index.es.js",
6
6
  "types": "dist/index.d.ts",
@@ -15,8 +15,8 @@
15
15
  "dist"
16
16
  ],
17
17
  "dependencies": {
18
- "@wf-financing/embedded-types": "1.1.0",
19
- "@wf-financing/logger": "2.2.0"
18
+ "@wf-financing/embedded-types": "1.1.1",
19
+ "@wf-financing/logger": "2.2.1"
20
20
  },
21
21
  "devDependencies": {
22
22
  "vite": "^6.3.5",