@salla.sa/embedded-sdk 0.2.5 → 0.2.6
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/cjs/index.js +2 -2
- package/dist/cjs/index.js.map +1 -1
- package/dist/esm/index.js +377 -270
- package/dist/esm/index.js.map +1 -1
- package/dist/system/index.js +2 -2
- package/dist/system/index.js.map +1 -1
- package/dist/types/index.d.ts +50 -18
- package/dist/umd/index.js +2 -2
- package/dist/umd/index.js.map +1 -1
- package/package.json +1 -1
package/dist/cjs/index.js
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const o="embedded::",C={INIT:`${o}iframe.ready`,READY:`${o}ready`,DESTROY:`${o}destroy`},x={PROVIDE:`${o}context.provide`,THEME_CHANGE:`${o}theme.change`},h={LOADING:`${o}ui.loading`,BREADCRUMBS:`${o}ui.breadcrumbs`,TOAST:`${o}ui.toast`,CONFIRM:`${o}ui.confirm`,CONFIRM_RESPONSE:`${o}ui.confirm.response`},K={},j={REFRESH:`${o}auth.refresh`},E={NAVIGATE:`${o}page.navigate`,REDIRECT:`${o}page.redirect`,SET_TITLE:`${o}page.setTitle`},l={SET_ACTION:`${o}nav.setAction`,CLEAR_ACTION:`${o}nav.clearAction`,ACTION_CLICK:`${o}nav.actionClick`,ADD_ITEM:`${o}nav.addItem`,ADD_ITEM_RESPONSE:`${o}nav.addItem.response`,UPDATE_ITEM:`${o}nav.updateItem`,REMOVE_ITEM:`${o}nav.removeItem`,ITEM_CLICK:`${o}nav.itemClick`},g={CREATE:`${o}checkout.create`,RESPONSE:`${o}checkout.response`,GET_ADDONS:`${o}checkout.getAddons`,GET_ADDONS_RESPONSE:`${o}checkout.getAddons.response`,RESET_CACHE:`${o}checkout.resetCache`},R=K.version||"",B=1e4,X=["localhost","merchants.workers.dev","s.salla.sa",".salla.group",".salla.sa"],W=new Set(["ar","he","fa","ur","ps","sd","yi"]);function Y(t){const e=(t??"ar").toLowerCase().split(/[-_]/)[0];return W.has(e)?"rtl":"ltr"}let S={showVersion:!0,debug:!1};function Q(t){S={...S,...t}}function k(t){return`%c${t}`}function q(t,e="#fff"){return`background-color: ${t}; color: ${e}; padding: 2px 6px; border-radius: 3px; font-weight: 500; font-size: 11px;`}function y(t,...e){if(t==="debug"&&!S.debug)return;const r=[],i=[];r.push(k("EmbeddedSDK")),i.push(q("#10b981","#fff")),S.showVersion&&(r.push(k(`v${R}`)),i.push(q("#6b7280","#fff")));const n=r.join("").trim();(console[t]||console.log)(n,...i,...e)}const a={log:(...t)=>{y("log",...t)},warn:(...t)=>{y("warn",...t)},error:(...t)=>{y("error",...t)},info:(...t)=>{y("info",...t)},debug:(...t)=>{y("debug",...t)}};function J(t){try{const r=new URL(t).hostname;return X.some(i=>i.startsWith(".")?r.endsWith(i)||r===i.slice(1):r===i||r.startsWith(`${i}:`))}catch{return!1}}function Z(){return typeof window>"u"||window.parent===window?null:window.parent}function u(t,e,r="*",i,n){const s=Z();if(!s){a.warn("Not running in an iframe, cannot post to host");return}const d={event:t,payload:e||{},timestamp:Date.now(),source:"embedded-app",...i&&{requestId:i},metadata:{version:R}};s.postMessage(d,r)}const p=new Map;let A=!1;function F(t){if(process.env.NODE_ENV==="production"&&!J(t.origin))return;const e=t.data;if(!e||typeof e.event!="string"||!e.payload||typeof e.timestamp!="number"||!e.source){a.warn("Invalid message structure received:",e);return}const r=p.get(e.event);r&&r.forEach(n=>{try{n(e)}catch(s){a.error("Error in message handler:",s)}});const i=p.get("*");i&&i.forEach(n=>{try{n(e)}catch(s){a.error("Error in wildcard handler:",s)}})}function ee(){A||typeof window>"u"||(window.addEventListener("message",F),A=!0)}function m(t,e){ee(),p.has(t)||p.set(t,new Set);const r=p.get(t);return r.add(e),()=>{r.delete(e),r.size===0&&p.delete(t)}}function te(t,e=B){return new Promise((r,i)=>{const n=setTimeout(()=>{s(),i(new Error(`[EmbeddedSDK] Timeout waiting for "${t}" message`))},e),s=m(t,d=>{clearTimeout(n),s(),r(d)})})}function re(){p.clear(),A&&typeof window<"u"&&(window.removeEventListener("message",F),A=!1)}function ie(){return typeof window>"u"?!1:window.parent!==window}function ne(t,e,r){const i={event:t,payload:e,timestamp:Date.now(),source:"merchant-dashboard",...r,metadata:{version:R,synthetic:!0}};p.get(t)?.forEach(s=>{try{s(i)}catch(d){a.error("Error in message handler:",d)}})}const b=new Map,se=3e4;function H(){const t=Date.now(),e=Math.random().toString(36).slice(2,9);return`req_${t}_${e}`}function D(t,e={},r=se){const i=H();return new Promise((n,s)=>{const d=setTimeout(()=>{b.get(i)&&(b.delete(i),s(new Error(`[EmbeddedSDK] Request "${t}" timed out after ${r}ms`)))},r);b.set(i,{resolve:n,reject:s,timeout:d,event:t}),u(t,e,"*",i)})}function M(t,e,r){const i=b.get(t);if(!i){a.warn(`Received response for unknown request: ${t}`);return}clearTimeout(i.timeout),b.delete(t),i.resolve(e)}function ae(t="SDK cleanup"){b.forEach((e,r)=>{clearTimeout(e.timeout),e.reject(new Error(`[EmbeddedSDK] Request ${r} cancelled: ${t}`))}),b.clear()}function w(){const t=new Set;return{subscribe(e){return t.add(e),()=>{t.delete(e)}},notify(...e){t.forEach(r=>{try{r(...e)}catch(i){a.error("Error in subscription callback:",i)}})},clear(){t.clear()},size(){return t.size}}}const oe="https://api.salla.dev";class T extends Error{constructor(e,r,i){super(e),this.status=r,this.response=i,this.name="ApiError"}}async function ue(t,e={}){const{method:r="GET",headers:i={},body:n,timeout:s=3e4}=e,d=`${oe}${t}`,N=new AbortController,L=setTimeout(()=>{N.abort()},s);try{const c=await fetch(d,{method:r,headers:{"Content-Type":"application/json",...i},body:n?JSON.stringify(n):void 0,signal:N.signal});clearTimeout(L);let I;if(c.headers.get("content-type")?.includes("application/json")?I=await c.json():I=await c.text(),!c.ok)throw new T(`API request failed: ${c.statusText}`,c.status,I);return I}catch(c){throw clearTimeout(L),c instanceof T?c:c instanceof Error?c.name==="AbortError"?new T(`Request timeout after ${s}ms`):new T(`Request failed: ${c.message}`):new T("Unknown error occurred")}}function _(t){return{isVerified:!1,isError:!0,error:t,data:null}}async function de(t){const{token:e,appId:r,refreshOnError:i=!0}=t;if(!e){const n="Token is required. Provide it as a parameter or in URL as ?token=XXX";return a.error("Error in introspect:",n),_(n)}if(!r){const n="App ID is required. Provide it as a parameter or in URL as ?app_id=XXX";return a.error("Error in introspect:",n),_(n)}try{const n=await ue("/exchange-authority/v1/introspect",{method:"POST",headers:{"S-Source":r,"Content-Type":"application/json"},body:{env:"prod",token:e,iss:"merchant-dashboard",subject:"embedded-page"}}),s=n.success;return{isVerified:s,isError:!s,error:s?void 0:"API request failed",data:s?n.data:null}}catch(n){i&&(O().ui.toast.error(n?.toString()??"Introspect error"),u(j.REFRESH,{})),a.error("Error in introspect:",n);const s=n instanceof Error?n.message:n;return _(s)}}function ce(t){return{getToken(){return new URLSearchParams(window.location.search).get("token")},getAppId(){return new URLSearchParams(window.location.search).get("app_id")},refresh(){u(j.REFRESH,{})},async introspect(e={}){const r=e.token??this.getToken()??"",i=e.appId??this.getAppId()??"";return de({token:r,appId:i,refreshOnError:e.refreshOnError})}}}const P=["success","error","warning","info"];function le(t){const e=[];return t.type===void 0||t.type===null?e.push("Toast type is required"):(typeof t.type!="string"||!P.includes(t.type))&&e.push(`Invalid toast type "${t.type}". Expected: ${P.join(" | ")}`),t.message===void 0||t.message===null?e.push("Toast message is required"):typeof t.message!="string"?e.push("Toast message must be a string"):t.message.trim()===""&&e.push("Toast message cannot be empty"),t.duration!==void 0&&t.duration!==null&&(typeof t.duration!="number"?e.push("Toast duration must be a number"):t.duration<0&&e.push("Toast duration cannot be negative")),{valid:e.length===0,errors:e}}function z(t,e){const r=[];return typeof t!="object"||t===null?(r.push(`${e} must be an object`),r):((typeof t.type!="string"||t.type.trim()==="")&&r.push(`${e} must have a valid type`),(typeof t.slug!="string"||t.slug.trim()==="")&&r.push(`${e} must have a valid slug`),t.quantity!==void 0&&(typeof t.quantity!="number"||t.quantity<1)&&r.push(`${e} must have a quantity >= 1`),r)}function fe(t){const e=[];if(typeof t!="object"||t===null)return e.push("Checkout options must be an object"),{valid:!1,errors:e};const r="item"in t,i="items"in t;if(!r&&!i)return e.push("Checkout requires either 'item' or 'items'"),{valid:!1,errors:e};if(r){const n=z(t.item,"Item");return e.push(...n),{valid:e.length===0,errors:e}}return Array.isArray(t.items)?t.items.length===0?(e.push("At least one item is required"),{valid:!1,errors:e}):(t.items.forEach((n,s)=>{const d=z(n,`Item at index ${s}`);e.push(...d)}),{valid:e.length===0,errors:e}):(e.push("Checkout items must be an array"),{valid:!1,errors:e})}function he(t){const e=[];return t.path===void 0||t.path===null?e.push("Navigation path is required"):typeof t.path!="string"?e.push("Navigation path must be a string"):t.path.trim()===""&&e.push("Navigation path cannot be empty"),t.replace!==void 0&&typeof t.replace!="boolean"&&e.push("Navigation replace option must be a boolean"),{valid:e.length===0,errors:e}}function pe(t){const e=[];if(t.url===void 0||t.url===null)e.push("Redirect URL is required");else if(typeof t.url!="string")e.push("Redirect URL must be a string");else if(t.url.trim()==="")e.push("Redirect URL cannot be empty");else try{new URL(t.url)}catch{e.push(`Invalid redirect URL: "${t.url}"`)}return{valid:e.length===0,errors:e}}function me(t){const e=[];return t.title?typeof t.title!="string"&&e.push("Nav action title must be a string"):e.push("Nav action title is required"),t.value?typeof t.value!="string"&&e.push("Nav action value must be a string"):e.push("Nav action value is required"),t.subTitle!==void 0&&t.subTitle!==null&&typeof t.subTitle!="string"&&e.push("Nav action subTitle must be a string"),t.icon!==void 0&&t.icon!==null&&typeof t.icon!="string"&&e.push("Nav action icon must be a string"),t.disabled!==void 0&&t.disabled!==null&&typeof t.disabled!="boolean"&&e.push("Nav action disabled must be a boolean"),t.extendedActions!==void 0&&t.extendedActions!==null&&(Array.isArray(t.extendedActions)?t.extendedActions.forEach((r,i)=>{if(typeof r!="object"||r===null){e.push(`Extended action at index ${i} must be an object`);return}const n=r;(!n.title||typeof n.title!="string")&&e.push(`Extended action at index ${i} is missing required "title" property`),(!n.value||typeof n.value!="string")&&e.push(`Extended action at index ${i} is missing required "value" property`),n.subTitle!==void 0&&typeof n.subTitle!="string"&&e.push(`Extended action at index ${i} subTitle must be a string`),n.icon!==void 0&&typeof n.icon!="string"&&e.push(`Extended action at index ${i} icon must be a string`),n.disabled!==void 0&&typeof n.disabled!="boolean"&&e.push(`Extended action at index ${i} disabled must be a boolean`)}):e.push("Nav action extendedActions must be an array")),{valid:e.length===0,errors:e}}function ge(t){const e=[];if(typeof t!="object"||t===null)return e.push("Nav addItem expects an object item"),{valid:!1,errors:e};const r=t;return["title","value","url"].forEach(i=>{(typeof r[i]!="string"||!String(r[i]).trim())&&e.push(`Sub-nav addItem "${i}" must be non-empty string`)}),r.disabled!==void 0&&typeof r.disabled!="boolean"&&e.push('Sub-nav addItem "disabled" must be boolean'),r.active!==void 0&&typeof r.active!="boolean"&&e.push('Sub-nav addItem "active" must be boolean'),{valid:e.length===0,errors:e}}function be(t){const e=[];if(typeof t!="object"||t===null)return e.push("Nav updateItem expects an object item"),{valid:!1,errors:e};const r=t;if(typeof r.id!="string"||!r.id.trim())return e.push('Sub-nav updateItem requires string "id"'),{valid:!1,errors:e};let i=0;return r.title!==void 0&&i++,r.value!==void 0&&i++,r.url!==void 0&&i++,r.disabled!==void 0&&i++,r.active!==void 0&&i++,i===0?(e.push("Sub-nav updateItem must include at least one of title, value, url, disabled, active"),{valid:!1,errors:e}):(["title","value","url"].forEach(n=>{r[n]!==void 0&&(typeof r[n]!="string"||!r[n].trim())&&e.push(`Sub-nav updateItem "${n}" must be non-empty`)}),r.disabled!==void 0&&typeof r.disabled!="boolean"&&e.push('Sub-nav updateItem "disabled" must be boolean'),r.active!==void 0&&typeof r.active!="boolean"&&e.push('Sub-nav updateItem "active" must be boolean'),{valid:e.length===0,errors:e})}function Ee(t){const e=[];return(typeof t!="string"||!t.trim())&&e.push("Nav removeItem id must be non-empty string"),{valid:e.length===0,errors:e}}const U=["danger","warning","info"];function ve(t){const e=[];return t.title===void 0||t.title===null?e.push("Confirm dialog title is required"):typeof t.title!="string"?e.push("Confirm dialog title must be a string"):t.title.trim()===""&&e.push("Confirm dialog title cannot be empty"),t.message===void 0||t.message===null?e.push("Confirm dialog message is required"):typeof t.message!="string"?e.push("Confirm dialog message must be a string"):t.message.trim()===""&&e.push("Confirm dialog message cannot be empty"),t.confirmText!==void 0&&t.confirmText!==null&&typeof t.confirmText!="string"&&e.push("Confirm dialog confirmText must be a string"),t.cancelText!==void 0&&t.cancelText!==null&&typeof t.cancelText!="string"&&e.push("Confirm dialog cancelText must be a string"),t.variant!==void 0&&t.variant!==null&&(typeof t.variant!="string"||!U.includes(t.variant))&&e.push(`Invalid confirm variant "${t.variant}". Expected: ${U.join(" | ")}`),{valid:e.length===0,errors:e}}function f(t,e){a.error(`Validation failed for ${t}:
|
|
1
|
+
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const u="embedded::",q={INIT:`${u}iframe.ready`,READY:`${u}ready`,DESTROY:`${u}destroy`},j={PROVIDE:`${u}context.provide`,THEME_CHANGE:`${u}theme.change`},g={LOADING:`${u}ui.loading`,BREADCRUMBS:`${u}ui.breadcrumbs`,TOAST:`${u}ui.toast`,CONFIRM:`${u}ui.confirm`,CONFIRM_RESPONSE:`${u}ui.confirm.response`},ee={},W={REFRESH:`${u}auth.refresh`},T={NAVIGATE:`${u}page.navigate`,REDIRECT:`${u}page.redirect`,SET_TITLE:`${u}page.setTitle`},h={SET_ACTION:`${u}nav.setAction`,CLEAR_ACTION:`${u}nav.clearAction`,ACTION_CLICK:`${u}nav.actionClick`,ADD_ITEM:`${u}nav.addItem`,ADD_ITEM_RESPONSE:`${u}nav.addItem.response`,UPDATE_ITEM:`${u}nav.updateItem`,REMOVE_ITEM:`${u}nav.removeItem`,ITEM_CLICK:`${u}nav.itemClick`},y={CREATE:`${u}checkout.create`,RESPONSE:`${u}checkout.response`,GET_ADDONS:`${u}checkout.getAddons`,GET_ADDONS_RESPONSE:`${u}checkout.getAddons.response`,RESET_CACHE:`${u}checkout.resetCache`},D=ee.version||"",te=1e4,re=["localhost","merchants.workers.dev","s.salla.sa",".salla.group",".salla.sa"],ie=new Set(["ar","he","fa","ur","ps","sd","yi"]);function ne(t){const e=(t??"ar").toLowerCase().split(/[-_]/)[0];return ie.has(e)?"rtl":"ltr"}let N={showVersion:!0,debug:!1};function se(t){N={...N,...t}}function F(t){return`%c${t}`}function H(t,e="#fff"){return`background-color: ${t}; color: ${e}; padding: 2px 6px; border-radius: 3px; font-weight: 500; font-size: 11px;`}function S(t,...e){if(t==="debug"&&!N.debug)return;const r=[],i=[];r.push(F("EmbeddedSDK")),i.push(H("#10b981","#fff")),N.showVersion&&(r.push(F(`v${D}`)),i.push(H("#6b7280","#fff")));const n=r.join("").trim();(console[t]||console.log)(n,...i,...e)}const o={log:(...t)=>{S("log",...t)},warn:(...t)=>{S("warn",...t)},error:(...t)=>{S("error",...t)},info:(...t)=>{S("info",...t)},debug:(...t)=>{S("debug",...t)}};function ae(t){try{const r=new URL(t).hostname;return re.some(i=>i.startsWith(".")?r.endsWith(i)||r===i.slice(1):r===i||r.startsWith(`${i}:`))}catch{return!1}}function oe(){return typeof window>"u"||window.parent===window?null:window.parent}function c(t,e,r="*",i,n){const s=oe();if(!s){o.warn("Not running in an iframe, cannot post to host");return}const a={event:t,payload:e||{},timestamp:Date.now(),source:"embedded-app",...i&&{requestId:i},metadata:{version:D}};s.postMessage(a,r)}const v=new Map;let $=!1;function Y(t){if(process.env.NODE_ENV==="production"&&!ae(t.origin))return;const e=t.data;if(!e||typeof e.event!="string"||!e.payload||typeof e.timestamp!="number"||!e.source){o.warn("Invalid message structure received:",e);return}const r=v.get(e.event);r&&r.forEach(n=>{try{n(e)}catch(s){o.error("Error in message handler:",s)}});const i=v.get("*");i&&i.forEach(n=>{try{n(e)}catch(s){o.error("Error in wildcard handler:",s)}})}function ue(){$||typeof window>"u"||(window.addEventListener("message",Y),$=!0)}function b(t,e){ue(),v.has(t)||v.set(t,new Set);const r=v.get(t);return r.add(e),()=>{r.delete(e),r.size===0&&v.delete(t)}}function de(t,e=te){return new Promise((r,i)=>{const n=setTimeout(()=>{s(),i(new Error(`[EmbeddedSDK] Timeout waiting for "${t}" message`))},e),s=b(t,a=>{clearTimeout(n),s(),r(a)})})}function ce(){v.clear(),$&&typeof window<"u"&&(window.removeEventListener("message",Y),$=!1)}function le(){return typeof window>"u"?!1:window.parent!==window}function fe(t,e,r){const i={event:t,payload:e,timestamp:Date.now(),source:"merchant-dashboard",...r,metadata:{version:D,synthetic:!0}};v.get(t)?.forEach(s=>{try{s(i)}catch(a){o.error("Error in message handler:",a)}})}const E=new Map,he=3e4;function Q(){const t=Date.now(),e=Math.random().toString(36).slice(2,9);return`req_${t}_${e}`}function z(t,e={},r=he){const i=Q();return new Promise((n,s)=>{const a=setTimeout(()=>{E.get(i)&&(E.delete(i),s(new Error(`[EmbeddedSDK] Request "${t}" timed out after ${r}ms`)))},r);E.set(i,{resolve:n,reject:s,timeout:a,event:t}),c(t,e,"*",i)})}function C(t,e,r){const i=E.get(t);if(!i){o.warn(`Received response for unknown request: ${t}`);return}clearTimeout(i.timeout),E.delete(t),r?i.reject(new Error(r)):i.resolve(e)}function me(t="SDK cleanup"){E.forEach((e,r)=>{clearTimeout(e.timeout),e.reject(new Error(`[EmbeddedSDK] Request ${r} cancelled: ${t}`))}),E.clear()}function A(){const t=new Set;return{subscribe(e){return t.add(e),()=>{t.delete(e)}},notify(...e){t.forEach(r=>{try{r(...e)}catch(i){o.error("Error in subscription callback:",i)}})},clear(){t.clear()},size(){return t.size}}}const pe="https://api.salla.dev";class w extends Error{constructor(e,r,i){super(e),this.status=r,this.response=i,this.name="ApiError"}}async function ge(t,e={}){const{method:r="GET",headers:i={},body:n,timeout:s=3e4}=e,a=`${pe}${t}`,l=new AbortController,f=setTimeout(()=>{l.abort()},s);try{const d=await fetch(a,{method:r,headers:{"Content-Type":"application/json",...i},body:n?JSON.stringify(n):void 0,signal:l.signal});clearTimeout(f);let m;if(d.headers.get("content-type")?.includes("application/json")?m=await d.json():m=await d.text(),!d.ok)throw new w(`API request failed: ${d.statusText}`,d.status,m);return m}catch(d){throw clearTimeout(f),d instanceof w?d:d instanceof Error?d.name==="AbortError"?new w(`Request timeout after ${s}ms`):new w(`Request failed: ${d.message}`):new w("Unknown error occurred")}}function k(t){return{isVerified:!1,isError:!0,error:t,data:null}}async function ve(t){const{token:e,appId:r,refreshOnError:i=!0}=t;if(!e){const n="Token is required. Provide it as a parameter or in URL as ?token=XXX";return o.error("Error in introspect:",n),k(n)}if(!r){const n="App ID is required. Provide it as a parameter or in URL as ?app_id=XXX";return o.error("Error in introspect:",n),k(n)}try{const n=await ge("/exchange-authority/v1/introspect",{method:"POST",headers:{"S-Source":r,"Content-Type":"application/json"},body:{env:"prod",token:e,iss:"merchant-dashboard",subject:"embedded-page"}}),s=n.success;return{isVerified:s,isError:!s,error:s?void 0:"API request failed",data:s?n.data:null}}catch(n){i&&(U().ui.toast.error(n?.toString()??"Introspect error"),c(W.REFRESH,{})),o.error("Error in introspect:",n);const s=n instanceof Error?n.message:n;return k(s)}}function be(t){return{getToken(){return new URLSearchParams(window.location.search).get("token")},getAppId(){return new URLSearchParams(window.location.search).get("app_id")},refresh(){c(W.REFRESH,{})},async introspect(e={}){const r=e.token??this.getToken()??"",i=e.appId??this.getAppId()??"";return ve({token:r,appId:i,refreshOnError:e.refreshOnError})}}}const K=["success","error","warning","info"];function ye(t){const e=[];return t.type===void 0||t.type===null?e.push("Toast type is required"):(typeof t.type!="string"||!K.includes(t.type))&&e.push(`Invalid toast type "${t.type}". Expected: ${K.join(" | ")}`),t.message===void 0||t.message===null?e.push("Toast message is required"):typeof t.message!="string"?e.push("Toast message must be a string"):t.message.trim()===""&&e.push("Toast message cannot be empty"),t.duration!==void 0&&t.duration!==null&&(typeof t.duration!="number"?e.push("Toast duration must be a number"):t.duration<0&&e.push("Toast duration cannot be negative")),{valid:e.length===0,errors:e}}function G(t,e){const r=[];return typeof t!="object"||t===null?(r.push(`${e} must be an object`),r):((typeof t.type!="string"||t.type.trim()==="")&&r.push(`${e} must have a valid type`),(typeof t.slug!="string"||t.slug.trim()==="")&&r.push(`${e} must have a valid slug`),t.quantity!==void 0&&(typeof t.quantity!="number"||t.quantity<1)&&r.push(`${e} must have a quantity >= 1`),r)}function Ee(t){const e=[];if(typeof t!="object"||t===null)return e.push("Checkout options must be an object"),{valid:!1,errors:e};const r="item"in t,i="items"in t;if(!r&&!i)return e.push("Checkout requires either 'item' or 'items'"),{valid:!1,errors:e};if(r){const n=G(t.item,"Item");return e.push(...n),{valid:e.length===0,errors:e}}return Array.isArray(t.items)?t.items.length===0?(e.push("At least one item is required"),{valid:!1,errors:e}):(t.items.forEach((n,s)=>{const a=G(n,`Item at index ${s}`);e.push(...a)}),{valid:e.length===0,errors:e}):(e.push("Checkout items must be an array"),{valid:!1,errors:e})}function Te(t){const e=[];return t.path===void 0||t.path===null?e.push("Navigation path is required"):typeof t.path!="string"?e.push("Navigation path must be a string"):t.path.trim()===""&&e.push("Navigation path cannot be empty"),t.replace!==void 0&&typeof t.replace!="boolean"&&e.push("Navigation replace option must be a boolean"),{valid:e.length===0,errors:e}}function Ie(t){const e=[];if(t.url===void 0||t.url===null)e.push("Redirect URL is required");else if(typeof t.url!="string")e.push("Redirect URL must be a string");else if(t.url.trim()==="")e.push("Redirect URL cannot be empty");else try{new URL(t.url)}catch{e.push(`Invalid redirect URL: "${t.url}"`)}return{valid:e.length===0,errors:e}}function Se(t){const e=[];return t.title?typeof t.title!="string"&&e.push("Nav action title must be a string"):e.push("Nav action title is required"),t.value?typeof t.value!="string"&&e.push("Nav action value must be a string"):e.push("Nav action value is required"),t.subTitle!==void 0&&t.subTitle!==null&&typeof t.subTitle!="string"&&e.push("Nav action subTitle must be a string"),t.icon!==void 0&&t.icon!==null&&typeof t.icon!="string"&&e.push("Nav action icon must be a string"),t.disabled!==void 0&&t.disabled!==null&&typeof t.disabled!="boolean"&&e.push("Nav action disabled must be a boolean"),t.extendedActions!==void 0&&t.extendedActions!==null&&(Array.isArray(t.extendedActions)?t.extendedActions.forEach((r,i)=>{if(typeof r!="object"||r===null){e.push(`Extended action at index ${i} must be an object`);return}const n=r;(!n.title||typeof n.title!="string")&&e.push(`Extended action at index ${i} is missing required "title" property`),(!n.value||typeof n.value!="string")&&e.push(`Extended action at index ${i} is missing required "value" property`),n.subTitle!==void 0&&typeof n.subTitle!="string"&&e.push(`Extended action at index ${i} subTitle must be a string`),n.icon!==void 0&&typeof n.icon!="string"&&e.push(`Extended action at index ${i} icon must be a string`),n.disabled!==void 0&&typeof n.disabled!="boolean"&&e.push(`Extended action at index ${i} disabled must be a boolean`)}):e.push("Nav action extendedActions must be an array")),{valid:e.length===0,errors:e}}const _=50;function R(t,e){return t?`${t}.${e}`:e}function we(t,e){const r=[];["title","value","url"].forEach(s=>{(typeof t[s]!="string"||!String(t[s]).trim())&&r.push(`Sub-nav addItem "${R(e,s)}" must be non-empty string`)});const i=R(e,"disabled"),n=R(e,"active");return t.disabled!==void 0&&typeof t.disabled!="boolean"&&r.push(`Sub-nav addItem "${i}" must be boolean`),t.active!==void 0&&typeof t.active!="boolean"&&r.push(`Sub-nav addItem "${n}" must be boolean`),r}function V(t,e,r){if(typeof t!="object"||t===null)return[`Sub-nav addItem "${e||"item"}" must be an object`];const i=t,n=we(i,e),s=R(e,"children");return i.children===void 0?n:r?Array.isArray(i.children)?i.children.length>_?(n.push(`Sub-nav addItem "${s}" must have at most ${_} items`),n):(i.children.forEach((a,l)=>{const f=e?`${e}.children[${l}]`:`children[${l}]`;n.push(...V(a,f,!1))}),n):(n.push(`Sub-nav addItem "${s}" must be an array`),n):(Array.isArray(i.children)&&i.children.length===0||n.push(`Sub-nav addItem "${s}" is not supported on submenu rows (only one dropdown level)`),n)}function J(t,e,r,i){if(typeof t!="object"||t===null)return i;const n=t;return typeof n.value=="string"&&n.value.trim()&&i.push(n.value.trim()),!r||!Array.isArray(n.children)||n.children.forEach((s,a)=>{const l=e?`${e}.children[${a}]`:`children[${a}]`;J(s,l,!1,i)}),i}function Ae(t){const e=J(t,"",!0,[]),r=new Set,i=[];for(const n of e)r.has(n)&&i.push(n),r.add(n);return i.length===0?[]:[`Sub-nav addItem "value" must be globally unique within the item tree (duplicate: ${[...new Set(i)].join(", ")})`]}function Re(t){if(typeof t!="object"||t===null)return{valid:!1,errors:["Nav addItem expects an object item"]};const e=[...V(t,"",!0),...Ae(t)];return{valid:e.length===0,errors:e}}function Ne(t){const e=[];if(typeof t!="object"||t===null)return e.push("Nav updateItem expects an object item"),{valid:!1,errors:e};const r=t,i=typeof r.value=="string"&&String(r.value).trim().length>0,n=typeof r.id=="string"&&String(r.id).trim().length>0,s=i?String(r.value).trim():"",a=n?String(r.id).trim():"";if(!i&&!n)return e.push('Sub-nav updateItem requires non-empty string "value"'),{valid:!1,errors:e};if(i&&n&&s!==a)return e.push('Sub-nav updateItem must not specify different "id" and "value"; "value" is the immutable row key and cannot be renamed via patch'),{valid:!1,errors:e};const l=s||a;let f=0;if(r.title!==void 0&&f++,r.url!==void 0&&f++,r.disabled!==void 0&&f++,r.active!==void 0&&f++,r.children!==void 0&&f++,f===0)return e.push("Sub-nav updateItem must include at least one of title, url, disabled, active, children"),{valid:!1,errors:e};if(["title","url"].forEach(d=>{r[d]!==void 0&&(typeof r[d]!="string"||!r[d].trim())&&e.push(`Sub-nav updateItem "${d}" must be non-empty`)}),r.disabled!==void 0&&typeof r.disabled!="boolean"&&e.push('Sub-nav updateItem "disabled" must be boolean'),r.active!==void 0&&typeof r.active!="boolean"&&e.push('Sub-nav updateItem "active" must be boolean'),r.children!==void 0)if(!Array.isArray(r.children))e.push('Sub-nav updateItem "children" must be an array');else if(r.children.length>_)e.push(`Sub-nav updateItem "children" must have at most ${_} items`);else{const d=new Set;r.children.forEach((m,P)=>{const M=`children[${P}]`;if(e.push(...V(m,M,!1)),typeof m=="object"&&m!==null){const O=m.value;if(typeof O=="string"&&O.trim()){const L=O.trim();L===l&&e.push(`Sub-nav updateItem "${M}.value" must not equal the parent row identifier`),d.has(L)&&e.push(`Sub-nav updateItem "${M}.value" must be unique within children`),d.add(L)}}})}return{valid:e.length===0,errors:e}}function $e(t){const e=[];return(typeof t!="string"||!t.trim())&&e.push("Nav removeItem value must be non-empty string"),{valid:e.length===0,errors:e}}const B=["danger","warning","info"];function Ce(t){const e=[];return t.title===void 0||t.title===null?e.push("Confirm dialog title is required"):typeof t.title!="string"?e.push("Confirm dialog title must be a string"):t.title.trim()===""&&e.push("Confirm dialog title cannot be empty"),t.message===void 0||t.message===null?e.push("Confirm dialog message is required"):typeof t.message!="string"?e.push("Confirm dialog message must be a string"):t.message.trim()===""&&e.push("Confirm dialog message cannot be empty"),t.confirmText!==void 0&&t.confirmText!==null&&typeof t.confirmText!="string"&&e.push("Confirm dialog confirmText must be a string"),t.cancelText!==void 0&&t.cancelText!==null&&typeof t.cancelText!="string"&&e.push("Confirm dialog cancelText must be a string"),t.variant!==void 0&&t.variant!==null&&(typeof t.variant!="string"||!B.includes(t.variant))&&e.push(`Invalid confirm variant "${t.variant}". Expected: ${B.join(" | ")}`),{valid:e.length===0,errors:e}}function p(t,e){o.error(`Validation failed for ${t}:
|
|
2
2
|
`+e.map(r=>` • ${r}`).join(`
|
|
3
|
-
`))}function
|
|
3
|
+
`))}function _e(){return{resize:i=>{},autoResize:()=>{},stopAutoResize:()=>{}}}function De(){const{resize:t,autoResize:e,stopAutoResize:r}=_e();return{navigate(i,n){const s=Te({path:i,...n});if(!s.valid){p(T.NAVIGATE,s.errors);return}c(T.NAVIGATE,{path:i,state:n?.state,replace:n?.replace})},redirect(i){const n=Ie({url:i});if(!n.valid){p(T.REDIRECT,n.errors);return}c(T.REDIRECT,{url:i})},navTo(i,n){if(i.startsWith("http://")||i.startsWith("https://")){this.redirect(i);return}this.navigate(i,n)},setTitle(i){if(typeof i!="string"||!i.trim()){p(T.SET_TITLE,["Title must be a non-empty string"]);return}c(T.SET_TITLE,{title:i})},resize:t,autoResize:e,stopAutoResize:r}}function Me(){const t=A(),e=A(),r=[];return r.push(b(h.ACTION_CLICK,i=>{t.notify(i.payload.value)})),r.push(b(h.ADD_ITEM_RESPONSE,i=>{if(!i.requestId)return;const n=i.payload;if(typeof n.error=="string"&&n.error.trim()){const a=n.error.trim();o.warn(`embedded::nav.addItem failed: ${a}`),C(i.requestId,{},a);return}const s=n.item;if(s&&typeof s.value=="string"&&s.value.trim()){const a=s.value.trim(),l={value:a,id:a};C(i.requestId,l)}})),r.push(b(h.ITEM_CLICK,i=>{const n=i.payload,s=typeof n.value=="string"&&n.value.trim()?n.value.trim():typeof n.id=="string"&&n.id.trim()?n.id.trim():"";if(!s){e.notify(n);return}e.notify({...n,value:s,id:s})})),{setAction(i){const n=Se(i);if(!n.valid){p(h.SET_ACTION,n.errors);return}c(h.SET_ACTION,{title:i.title,value:i.value,subTitle:i.subTitle,icon:i.icon,disabled:i.disabled,extendedActions:i.extendedActions?.map(s=>({title:s.title,value:s.value,subTitle:s.subTitle,icon:s.icon,disabled:s.disabled}))})},clearAction(){c(h.CLEAR_ACTION,{})},onActionClick(i){return t.subscribe(i)},addNavItem(i){const n=Re(i);return n.valid?z(h.ADD_ITEM,{item:i},2e3):(p(h.ADD_ITEM,n.errors),Promise.reject(new Error(n.errors[0])))},updateNavItem(i){const n=Ne(i);if(!n.valid){p(h.UPDATE_ITEM,n.errors);return}const s=i,a=typeof s.value=="string"?s.value.trim():"",l=typeof s.id=="string"?s.id.trim():"",f=a||l,{id:d,...m}=s;c(h.UPDATE_ITEM,{item:{...m,value:f}})},removeNavItem(i){const n=$e(i);if(!n.valid){p(h.REMOVE_ITEM,n.errors);return}c(h.REMOVE_ITEM,{value:i})},onNavItemClick(i){return e.subscribe(i)},destroy(){r.forEach(i=>i()),r.length=0,t.clear(),e.clear()}}}function Oe(){return{show(){c(g.LOADING,{action:"show"})},hide(){c(g.LOADING,{action:"hide"})}}}function Le(){return{hide(){c(g.BREADCRUMBS,{action:"hide"})},show(){c(g.BREADCRUMBS,{action:"show"})}}}function qe(){const t=e=>{const r=ye(e);if(!r.valid){p(g.TOAST,r.errors);return}c(g.TOAST,{type:e.type,message:e.message,duration:e.duration})};return{show:t,success(e,r){t({type:"success",message:e,duration:r})},error(e,r){t({type:"error",message:e,duration:r})},warning(e,r){t({type:"warning",message:e,duration:r})},info(e,r){t({type:"info",message:e,duration:r})}}}function ke(){return async t=>{const e=Ce(t);return e.valid?z(g.CONFIRM,{title:t.title,message:t.message,confirmText:t.confirmText??"Confirm",cancelText:t.cancelText??"Cancel",variant:t.variant??"info"}):(p(g.CONFIRM,e.errors),Promise.reject(new Error(e.errors.join(", "))))}}function xe(){return{loading:Oe(),breadcrumbs:Le(),toast:qe(),confirm:ke()}}function ze(){const t=A(),e=[];return e.push(b(y.RESPONSE,r=>{t.notify({success:r.payload.success,order_id:r.payload.order_id,status:r.payload.status,error:r.payload.error,context:r.payload.context})})),e.push(b(y.GET_ADDONS_RESPONSE,r=>{r.requestId&&C(r.requestId,{success:r.payload.success,addons:r.payload.addons,error:r.payload.error})})),{create(r,i){const n=Array.isArray(r)?r:[r],s=Ee({items:n});if(!s.valid)throw p(y.CREATE,s.errors),new Error(s.errors[0]);c(y.CREATE,{items:n.map(a=>({type:a.type,slug:a.slug,quantity:a.quantity??1})),...i?.context!==void 0&&{context:i.context}},"*",Q())},onResult(r){return t.subscribe(r)},async getAddons(){try{return await z(y.GET_ADDONS,{},3e4)}catch(r){return{success:!1,error:{code:"REQUEST_FAILED",message:r instanceof Error?r.message:"Unknown error"}}}},resetCache(){c(y.RESET_CACHE,{},"*")},destroy(){e.forEach(r=>r()),e.length=0,t.clear()}}}const X={theme:"light",dir:"rtl",width:0,locale:"ar",currency:"SAR"};class Z{constructor(){this.initialized=!1,this.initializing=!1,this.debugMode=!1,this.appReady=!1,this.layout={...X},this.postInitHooks=[],this.themeSubscription=A(),this.initSubscription=A(),this.auth=be(),this.page=De(),this.nav=Me(),this.ui=xe(),this.checkout=ze(),this.registerPostInitHook(e=>{const r=e.payload.pendingCheckoutResult;r&&(o.debug("Dispatching pending checkout result:",r),queueMicrotask(()=>{fe(y.RESPONSE,{success:r.success,status:r.status,error:r.error,context:r.context})}))}),this.setupListeners()}registerPostInitHook(e){this.postInitHooks.push(e)}setupListeners(){b(j.THEME_CHANGE,e=>{this.layout.theme=e.payload.theme,o.debug("Theme changed:",e.payload.theme),this.themeSubscription.notify(e.payload.theme)}),b(g.CONFIRM_RESPONSE,e=>{o.debug("Received confirm response:",e),e.requestId&&C(e.requestId,{confirmed:e.payload.confirmed})})}getState(){return{ready:this.initialized,initializing:this.initializing,layout:{...this.layout}}}isReady(){return this.initialized}onThemeChange(e){return this.themeSubscription.subscribe(e)}onInit(e){if(this.initialized)try{e(this.getState())}catch(r){o.error("Error in init callback:",r)}return this.initSubscription.subscribe(e)}ready(){if(this.appReady){o.debug("App already signaled as ready");return}if(!this.initialized){o.warn("Cannot signal ready before init() is called");return}this.appReady=!0,c(q.READY,{}),o.debug("Sent ready signal to host")}async init(e={}){if(this.initialized)return o.debug("Already initialized, returning current layout"),{layout:{...this.layout}};if(this.initializing)return o.warn("Initialization already in progress"),new Promise(r=>{const i=this.onInit(n=>{i(),r({layout:{...n.layout}})})});this.initializing=!0,this.debugMode=e.debug??!1,se({debug:this.debugMode}),le()||o.warn("Not running in an iframe. Some features may not work."),o.debug("Initializing SDK...");try{c(q.INIT,{height:document.documentElement.scrollHeight}),o.debug("Sent iframe.ready message, waiting for context...");const r=await de(j.PROVIDE);o.debug("Received context from host:",r);const{layout:i}=r.payload;return this.layout={theme:i?.theme??"light",dir:i?.dir??ne(i?.locale),width:i?.width??0,locale:i?.locale??"ar",currency:i?.currency??"SAR"},this.postInitHooks.forEach(n=>{try{n(r)}catch(s){o.error("Error in post-init hook:",s)}}),this.initialized=!0,this.initializing=!1,o.debug("Initialization complete. Layout:",this.layout),this.initSubscription.notify(this.getState()),{layout:{...this.layout}}}catch(r){throw this.initializing=!1,r}}destroy(){o.debug("Destroying SDK instance"),this.initialized&&(c(q.DESTROY,{}),o.debug("Sent destroy event to host")),this.checkout.destroy(),this.nav.destroy(),me("SDK destroyed"),ce(),this.themeSubscription.clear(),this.initSubscription.clear(),this.postInitHooks=[],this.initialized=!1,this.initializing=!1,this.appReady=!1,this.layout={...X}}}let I=null;function U(){return I||(I=new Z),I}function Ve(){I&&(I.destroy(),I=null)}const x=U(),Ue=D;typeof window<"u"&&(window.salla=window.salla||window.Salla||{},window.Salla=window.salla,window.salla.embedded||(window.salla.embedded=x),window.Salla.embedded||(window.Salla.embedded=x));exports.EmbeddedApp=Z;exports.embedded=x;exports.getEmbeddedApp=U;exports.resetEmbeddedApp=Ve;exports.version=Ue;
|
|
4
4
|
//# sourceMappingURL=index.js.map
|