@viu/emporix-sdk-react 2.7.0 → 2.9.0

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.d.cts CHANGED
@@ -1,7 +1,7 @@
1
1
  export { E as EmporixProvider, a as EmporixProviderProps, c as EmporixTelemetryEvent, S as SiteContextValue, u as useEmporix, d as useEmporixTelemetry } from './provider-WHISqTG2.cjs';
2
2
  import { EmporixStorage } from './storage.cjs';
3
3
  export { PersistedAnonymousSession, TokenStorage, createCookieStorage, createLocalStorageStorage, createMemoryStorage } from './storage.cjs';
4
- export { A as AddressMutationsApi, C as CartMutationsApi, a as CheckoutApi, b as CompanySwitcherApi, c as CouponActionVars, d as CustomerSessionApi, P as PasswordResetApi, U as UseAvailabilitiesOptions, e as UseAvailabilityOptions, g as UseMyOrdersInfiniteOptions, h as UseMyOrdersOptions, n as UseVariantChildrenOptions, u as useActiveCart, o as useAddToShoppingList, p as useAddressMutations, q as useAssignContact, r as useAvailabilities, s as useAvailability, t as useCancelOrder, v as useCart, w as useCartMutations, x as useCategories, y as useCategoriesInfinite, z as useCategory, B as useCategoryTree, D as useChangePassword, E as useCheckout, F as useCompany, G as useCompanyContacts, H as useCompanyGroups, I as useCompanyLocations, J as useCompanySwitcher, K as useCreateCart, L as useCreateCompany, M as useCreateLocation, N as useCreateReturn, O as useCreateShoppingList, Q as useCustomerAddresses, R as useCustomerSession, S as useDefaultSite, T as useDeleteCompany, V as useDeleteLocation, W as useDeleteShoppingList, X as useMatchPrices, Y as useMatchPricesChunked, Z as useMyCompanies, _ as useMyOrders, $ as useMyOrdersInfinite, a0 as useMyReturns, a1 as useMyRewardPoints, a2 as useMyRewardPointsSummary, a3 as useMySegmentCategories, a4 as useMySegmentCategoriesInfinite, a5 as useMySegmentCategoryTree, a6 as useMySegmentItems, a7 as useMySegmentProducts, a8 as useMySegmentProductsInfinite, a9 as useMySegments, aa as useOrder, ab as useOrderTransition, ac as usePasswordReset, ad as usePaymentModes, ae as useProduct, af as useProductByCode, ag as useProductMedia, ah as useProductSearch, ai as useProducts, aj as useProductsByCodes, ak as useProductsInCategory, al as useProductsInCategoryInfinite, am as useProductsInfinite, an as useRedeemCoupon, ao as useRedeemOptions, ap as useRedeemRewardPoints, aq as useRemoveFromShoppingList, ar as useReorder, as as useReturn, at as useSalesOrder, au as useSetShoppingListItemQuantity, av as useShoppingLists, aw as useSiteContext, ax as useSites, ay as useSubcategories, az as useUnassignContact, aA as useUpdateCompany, aB as useUpdateContactAssignment, aC as useUpdateCustomer, aD as useUpdateLocation, aE as useUpdateSalesOrder, aF as useValidateCoupon, aG as useVariantChildren } from './use-returns-BMcuyi9J.cjs';
4
+ export { A as AddressMutationsApi, C as CartMutationsApi, a as CheckoutApi, b as CompanySwitcherApi, c as CouponActionVars, d as CustomerSessionApi, P as PasswordResetApi, U as UseAvailabilitiesOptions, e as UseAvailabilityOptions, g as UseMyOrdersInfiniteOptions, h as UseMyOrdersOptions, n as UseVariantChildrenOptions, u as useActiveCart, o as useAddGroupMember, p as useAddToShoppingList, q as useAddressMutations, r as useAssignContact, s as useAvailabilities, t as useAvailability, v as useCancelOrder, w as useCart, x as useCartMutations, y as useCategories, z as useCategoriesInfinite, B as useCategory, D as useCategoryTree, E as useChangePassword, F as useCheckout, G as useCompany, H as useCompanyContacts, I as useCompanyGroups, J as useCompanyLocations, K as useCompanySwitcher, L as useCreateCart, M as useCreateCompany, N as useCreateLocation, O as useCreateReturn, Q as useCreateShoppingList, R as useCustomerAddresses, S as useCustomerSession, T as useDefaultSite, V as useDeleteCompany, W as useDeleteLocation, X as useDeleteShoppingList, Y as useMatchPrices, Z as useMatchPricesChunked, _ as useMyCompanies, $ as useMyOrders, a0 as useMyOrdersInfinite, a1 as useMyReturns, a2 as useMyRewardPoints, a3 as useMyRewardPointsSummary, a4 as useMySegmentCategories, a5 as useMySegmentCategoriesInfinite, a6 as useMySegmentCategoryTree, a7 as useMySegmentItems, a8 as useMySegmentProducts, a9 as useMySegmentProductsInfinite, aa as useMySegments, ab as useOrder, ac as useOrderTransition, ad as usePasswordReset, ae as usePaymentModes, af as useProduct, ag as useProductByCode, ah as useProductMedia, ai as useProductNameSearch, aj as useProductSearch, ak as useProducts, al as useProductsByCodes, am as useProductsInCategory, an as useProductsInCategoryInfinite, ao as useProductsInfinite, ap as useRedeemCoupon, aq as useRedeemOptions, ar as useRedeemRewardPoints, as as useRemoveFromShoppingList, at as useRemoveGroupMember, au as useReorder, av as useReturn, aw as useSalesOrder, ax as useSetShoppingListItemQuantity, ay as useShoppingLists, az as useSiteContext, aA as useSites, aB as useSubcategories, aC as useUnassignContact, aD as useUpdateCompany, aE as useUpdateContactAssignment, aF as useUpdateCustomer, aG as useUpdateLocation, aH as useUpdateSalesOrder, aI as useValidateCoupon, aJ as useVariantChildren } from './use-returns-D-P399mP.cjs';
5
5
  import * as react from 'react';
6
6
  import { Component, ReactNode, ErrorInfo } from 'react';
7
7
  import { EmporixAuthError, EmporixError, EmporixClient, LegalEntity } from '@viu/emporix-sdk';
package/dist/index.d.ts CHANGED
@@ -1,7 +1,7 @@
1
1
  export { E as EmporixProvider, a as EmporixProviderProps, c as EmporixTelemetryEvent, S as SiteContextValue, u as useEmporix, d as useEmporixTelemetry } from './provider-CLNEKOuu.js';
2
2
  import { EmporixStorage } from './storage.js';
3
3
  export { PersistedAnonymousSession, TokenStorage, createCookieStorage, createLocalStorageStorage, createMemoryStorage } from './storage.js';
4
- export { A as AddressMutationsApi, C as CartMutationsApi, a as CheckoutApi, b as CompanySwitcherApi, c as CouponActionVars, d as CustomerSessionApi, P as PasswordResetApi, U as UseAvailabilitiesOptions, e as UseAvailabilityOptions, g as UseMyOrdersInfiniteOptions, h as UseMyOrdersOptions, n as UseVariantChildrenOptions, u as useActiveCart, o as useAddToShoppingList, p as useAddressMutations, q as useAssignContact, r as useAvailabilities, s as useAvailability, t as useCancelOrder, v as useCart, w as useCartMutations, x as useCategories, y as useCategoriesInfinite, z as useCategory, B as useCategoryTree, D as useChangePassword, E as useCheckout, F as useCompany, G as useCompanyContacts, H as useCompanyGroups, I as useCompanyLocations, J as useCompanySwitcher, K as useCreateCart, L as useCreateCompany, M as useCreateLocation, N as useCreateReturn, O as useCreateShoppingList, Q as useCustomerAddresses, R as useCustomerSession, S as useDefaultSite, T as useDeleteCompany, V as useDeleteLocation, W as useDeleteShoppingList, X as useMatchPrices, Y as useMatchPricesChunked, Z as useMyCompanies, _ as useMyOrders, $ as useMyOrdersInfinite, a0 as useMyReturns, a1 as useMyRewardPoints, a2 as useMyRewardPointsSummary, a3 as useMySegmentCategories, a4 as useMySegmentCategoriesInfinite, a5 as useMySegmentCategoryTree, a6 as useMySegmentItems, a7 as useMySegmentProducts, a8 as useMySegmentProductsInfinite, a9 as useMySegments, aa as useOrder, ab as useOrderTransition, ac as usePasswordReset, ad as usePaymentModes, ae as useProduct, af as useProductByCode, ag as useProductMedia, ah as useProductSearch, ai as useProducts, aj as useProductsByCodes, ak as useProductsInCategory, al as useProductsInCategoryInfinite, am as useProductsInfinite, an as useRedeemCoupon, ao as useRedeemOptions, ap as useRedeemRewardPoints, aq as useRemoveFromShoppingList, ar as useReorder, as as useReturn, at as useSalesOrder, au as useSetShoppingListItemQuantity, av as useShoppingLists, aw as useSiteContext, ax as useSites, ay as useSubcategories, az as useUnassignContact, aA as useUpdateCompany, aB as useUpdateContactAssignment, aC as useUpdateCustomer, aD as useUpdateLocation, aE as useUpdateSalesOrder, aF as useValidateCoupon, aG as useVariantChildren } from './use-returns-FGAfGMpY.js';
4
+ export { A as AddressMutationsApi, C as CartMutationsApi, a as CheckoutApi, b as CompanySwitcherApi, c as CouponActionVars, d as CustomerSessionApi, P as PasswordResetApi, U as UseAvailabilitiesOptions, e as UseAvailabilityOptions, g as UseMyOrdersInfiniteOptions, h as UseMyOrdersOptions, n as UseVariantChildrenOptions, u as useActiveCart, o as useAddGroupMember, p as useAddToShoppingList, q as useAddressMutations, r as useAssignContact, s as useAvailabilities, t as useAvailability, v as useCancelOrder, w as useCart, x as useCartMutations, y as useCategories, z as useCategoriesInfinite, B as useCategory, D as useCategoryTree, E as useChangePassword, F as useCheckout, G as useCompany, H as useCompanyContacts, I as useCompanyGroups, J as useCompanyLocations, K as useCompanySwitcher, L as useCreateCart, M as useCreateCompany, N as useCreateLocation, O as useCreateReturn, Q as useCreateShoppingList, R as useCustomerAddresses, S as useCustomerSession, T as useDefaultSite, V as useDeleteCompany, W as useDeleteLocation, X as useDeleteShoppingList, Y as useMatchPrices, Z as useMatchPricesChunked, _ as useMyCompanies, $ as useMyOrders, a0 as useMyOrdersInfinite, a1 as useMyReturns, a2 as useMyRewardPoints, a3 as useMyRewardPointsSummary, a4 as useMySegmentCategories, a5 as useMySegmentCategoriesInfinite, a6 as useMySegmentCategoryTree, a7 as useMySegmentItems, a8 as useMySegmentProducts, a9 as useMySegmentProductsInfinite, aa as useMySegments, ab as useOrder, ac as useOrderTransition, ad as usePasswordReset, ae as usePaymentModes, af as useProduct, ag as useProductByCode, ah as useProductMedia, ai as useProductNameSearch, aj as useProductSearch, ak as useProducts, al as useProductsByCodes, am as useProductsInCategory, an as useProductsInCategoryInfinite, ao as useProductsInfinite, ap as useRedeemCoupon, aq as useRedeemOptions, ar as useRedeemRewardPoints, as as useRemoveFromShoppingList, at as useRemoveGroupMember, au as useReorder, av as useReturn, aw as useSalesOrder, ax as useSetShoppingListItemQuantity, ay as useShoppingLists, az as useSiteContext, aA as useSites, aB as useSubcategories, aC as useUnassignContact, aD as useUpdateCompany, aE as useUpdateContactAssignment, aF as useUpdateCustomer, aG as useUpdateLocation, aH as useUpdateSalesOrder, aI as useValidateCoupon, aJ as useVariantChildren } from './use-returns-cBvLR-tm.js';
5
5
  import * as react from 'react';
6
6
  import { Component, ReactNode, ErrorInfo } from 'react';
7
7
  import { EmporixAuthError, EmporixError, EmporixClient, LegalEntity } from '@viu/emporix-sdk';
package/dist/index.js CHANGED
@@ -1,5 +1,5 @@
1
- export { useActiveCart, useAddToShoppingList, useAddressMutations, useAssignContact, useAvailabilities, useAvailability, useCancelOrder, useCart, useCartMutations, useCategories, useCategoriesInfinite, useCategory, useCategoryTree, useChangePassword, useCheckout, useCompany, useCompanyContacts, useCompanyGroups, useCompanyLocations, useCompanySwitcher, useCreateCart, useCreateCompany, useCreateLocation, useCreateReturn, useCreateShoppingList, useCustomerAddresses, useCustomerSession, useDefaultSite, useDeleteCompany, useDeleteLocation, useDeleteShoppingList, useMatchPrices, useMatchPricesChunked, useMyCompanies, useMyOrders, useMyOrdersInfinite, useMyReturns, useMyRewardPoints, useMyRewardPointsSummary, useMySegmentCategories, useMySegmentCategoriesInfinite, useMySegmentCategoryTree, useMySegmentItems, useMySegmentProducts, useMySegmentProductsInfinite, useMySegments, useOrder, useOrderTransition, usePasswordReset, usePaymentModes, useProduct, useProductByCode, useProductMedia, useProductSearch, useProducts, useProductsByCodes, useProductsInCategory, useProductsInCategoryInfinite, useProductsInfinite, useRedeemCoupon, useRedeemOptions, useRedeemRewardPoints, useRemoveFromShoppingList, useReorder, useReturn, useSalesOrder, useSetShoppingListItemQuantity, useShoppingLists, useSiteContext, useSites, useSubcategories, useUnassignContact, useUpdateCompany, useUpdateContactAssignment, useUpdateCustomer, useUpdateLocation, useUpdateSalesOrder, useValidateCoupon, useVariantChildren } from './chunk-TJXNTSXN.js';
2
- export { CompanyContextProvider, EmporixCompanyContext, EmporixProvider, useActiveCompany, useEmporix, useEmporixTelemetry } from './chunk-SDRV73LG.js';
1
+ export { useActiveCart, useAddGroupMember, useAddToShoppingList, useAddressMutations, useAssignContact, useAvailabilities, useAvailability, useCancelOrder, useCart, useCartMutations, useCategories, useCategoriesInfinite, useCategory, useCategoryTree, useChangePassword, useCheckout, useCompany, useCompanyContacts, useCompanyGroups, useCompanyLocations, useCompanySwitcher, useCreateCart, useCreateCompany, useCreateLocation, useCreateReturn, useCreateShoppingList, useCustomerAddresses, useCustomerSession, useDefaultSite, useDeleteCompany, useDeleteLocation, useDeleteShoppingList, useMatchPrices, useMatchPricesChunked, useMyCompanies, useMyOrders, useMyOrdersInfinite, useMyReturns, useMyRewardPoints, useMyRewardPointsSummary, useMySegmentCategories, useMySegmentCategoriesInfinite, useMySegmentCategoryTree, useMySegmentItems, useMySegmentProducts, useMySegmentProductsInfinite, useMySegments, useOrder, useOrderTransition, usePasswordReset, usePaymentModes, useProduct, useProductByCode, useProductMedia, useProductNameSearch, useProductSearch, useProducts, useProductsByCodes, useProductsInCategory, useProductsInCategoryInfinite, useProductsInfinite, useRedeemCoupon, useRedeemOptions, useRedeemRewardPoints, useRemoveFromShoppingList, useRemoveGroupMember, useReorder, useReturn, useSalesOrder, useSetShoppingListItemQuantity, useShoppingLists, useSiteContext, useSites, useSubcategories, useUnassignContact, useUpdateCompany, useUpdateContactAssignment, useUpdateCustomer, useUpdateLocation, useUpdateSalesOrder, useValidateCoupon, useVariantChildren } from './chunk-3W3TIKRV.js';
2
+ export { CompanyContextProvider, EmporixCompanyContext, EmporixProvider, useActiveCompany, useEmporix, useEmporixTelemetry } from './chunk-JZRSYM3W.js';
3
3
  export { createCookieStorage, createLocalStorageStorage, createMemoryStorage } from './chunk-FBQY2N7S.js';
4
4
  export { prefetchCart, prefetchOrder, prefetchProduct } from './chunk-TIS4BKHK.js';
5
5
  import { Component } from 'react';
package/dist/provider.cjs CHANGED
@@ -161,7 +161,7 @@ function CompanyContextProvider({
161
161
  if (matched) {
162
162
  setActive(matched);
163
163
  if (storage.getActiveLegalEntityId() !== matched.id) {
164
- storage.setActiveLegalEntityId(matched.id);
164
+ storage.setActiveLegalEntityId(matched.id ?? null);
165
165
  }
166
166
  } else if (companies.length === 1) {
167
167
  await switchTo(companies[0] ?? null);
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/storage/index.ts","../src/storage/memory.ts","../src/telemetry.ts","../src/company-context.tsx","../src/provider.tsx"],"names":["createContext","useContext","useQueryClient","useState","useRef","useCallback","auth","useEffect","useMemo","jsx","QueryClient","storage","QueryClientProvider"],"mappings":"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","file":"provider.cjs","sourcesContent":["/** Pluggable persistence for SDK session state. SSR-safe by default (memory). */\nexport interface EmporixStorage {\n // Customer token (unchanged).\n getCustomerToken(): string | null;\n setCustomerToken(token: string | null): void;\n subscribe?(listener: (token: string | null) => void): () => void;\n\n // Active guest / customer cart id.\n getCartId(): string | null;\n setCartId(id: string | null): void;\n\n // Anonymous session — used by DefaultTokenProvider (via EmporixProvider\n // wiring) to preserve sessionId across page reloads.\n getAnonymousSession(): PersistedAnonymousSession | null;\n setAnonymousSession(session: PersistedAnonymousSession | null): void;\n\n // Active site code (MS-2). `null` = no site bound yet.\n getSiteCode(): string | null;\n setSiteCode(code: string | null): void;\n\n // Active legal entity id (B2B). `null` = B2C mode.\n getActiveLegalEntityId(): string | null;\n setActiveLegalEntityId(id: string | null): void;\n\n // Refresh token — optional persistence. When absent, B2B company-switch\n // falls back to a local-state-only update (no server-side token rescope).\n getRefreshToken(): string | null;\n setRefreshToken(token: string | null): void;\n\n /**\n * Subscribe to any storage write. The listener receives the key that\n * changed. Returns an unsubscribe function. Optional — backends may no-op.\n * Used by the telemetry layer to emit `storage.write` events.\n */\n subscribeAll?(\n listener: (key: EmporixStorageKey) => void,\n ): () => void;\n}\n\n/** Minimal subset of `AnonymousSession` that needs to outlive a page load. */\nexport interface PersistedAnonymousSession {\n refreshToken: string;\n sessionId: string;\n}\n\n/** Backward-compat alias. New code should prefer `EmporixStorage`. */\nexport type TokenStorage = EmporixStorage;\n\n/** Keys that participate in {@link EmporixStorage.subscribeAll}. */\nexport type EmporixStorageKey =\n | \"customerToken\"\n | \"cartId\"\n | \"siteCode\"\n | \"anonymousSession\"\n | \"activeLegalEntityId\"\n | \"refreshToken\";\n\n/**\n * Internal: create a swallow-on-throw listener set used by all three storage\n * backends for `subscribeAll`. Centralizes the try/catch wrapper so a buggy\n * telemetry handler never breaks a storage write.\n */\nexport function createListenerSet<T>(): {\n add(l: (value: T) => void): () => void;\n notify(value: T): void;\n} {\n const listeners = new Set<(v: T) => void>();\n return {\n add(l) {\n listeners.add(l);\n return () => listeners.delete(l);\n },\n notify(value) {\n for (const l of listeners) {\n try {\n l(value);\n } catch {\n // Swallow handler errors; telemetry must never break writes.\n }\n }\n },\n };\n}\n\n/**\n * Internal: parses a raw `anonymousSession` JSON payload (from localStorage\n * or a cookie) into a {@link PersistedAnonymousSession}. Returns `null` for\n * any malformed or missing input.\n */\nexport function parseAnonymousSession(raw: string | null): PersistedAnonymousSession | null {\n if (!raw) return null;\n try {\n const parsed = JSON.parse(raw) as Partial<PersistedAnonymousSession>;\n if (typeof parsed.refreshToken === \"string\" && typeof parsed.sessionId === \"string\") {\n return { refreshToken: parsed.refreshToken, sessionId: parsed.sessionId };\n }\n return null;\n } catch {\n return null;\n }\n}\n\nexport { createMemoryStorage } from \"./memory\";\nexport { createLocalStorageStorage } from \"./local-storage\";\nexport { createCookieStorage } from \"./cookie\";\n","import {\n createListenerSet,\n type EmporixStorage,\n type EmporixStorageKey,\n type PersistedAnonymousSession,\n} from \"./index\";\n\n/** In-memory token store. Default, SSR-safe, no persistence. */\nexport function createMemoryStorage(opts: { initial?: string } = {}): EmporixStorage {\n let token: string | null = opts.initial ?? null;\n let cartId: string | null = null;\n let anon: PersistedAnonymousSession | null = null;\n let siteCode: string | null = null;\n let activeLegalEntityId: string | null = null;\n let refreshToken: string | null = null;\n const tokenListeners = new Set<(t: string | null) => void>();\n const all = createListenerSet<EmporixStorageKey>();\n return {\n getCustomerToken: () => token,\n setCustomerToken: (t) => {\n token = t;\n for (const l of tokenListeners) l(token);\n all.notify(\"customerToken\");\n },\n subscribe: (l) => {\n tokenListeners.add(l);\n return () => tokenListeners.delete(l);\n },\n getCartId: () => cartId,\n setCartId: (id) => {\n cartId = id;\n all.notify(\"cartId\");\n },\n getAnonymousSession: () => anon,\n setAnonymousSession: (s) => {\n anon = s;\n all.notify(\"anonymousSession\");\n },\n getSiteCode: () => siteCode,\n setSiteCode: (code) => {\n siteCode = code;\n all.notify(\"siteCode\");\n },\n getActiveLegalEntityId: () => activeLegalEntityId,\n setActiveLegalEntityId: (id) => {\n activeLegalEntityId = id;\n all.notify(\"activeLegalEntityId\");\n },\n getRefreshToken: () => refreshToken,\n setRefreshToken: (t) => {\n refreshToken = t;\n all.notify(\"refreshToken\");\n },\n subscribeAll: (l) => all.add(l),\n };\n}\n","import { createContext, useContext } from \"react\";\n\n/**\n * All telemetry events emitted through the EmporixProvider's `onTelemetry`\n * callback. Discriminated by `type` — exhaustive switch is type-safe.\n *\n * Consumers can emit their own `{ type: \"custom\" }` events via\n * {@link useEmporixTelemetry}. Namespace `name` with an app-specific\n * prefix (e.g. `\"app.checkout-cta-click\"`) to avoid collisions with\n * future SDK event types.\n */\nexport type EmporixTelemetryEvent =\n // Cache lifecycle (React-Query QueryCache)\n | { type: \"cache.hit\"; queryKey: readonly unknown[]; tenant: string }\n | {\n type: \"cache.miss\";\n queryKey: readonly unknown[];\n tenant: string;\n durationMs: number;\n }\n | {\n type: \"query.refetch\";\n queryKey: readonly unknown[];\n tenant: string;\n reason: \"invalidate\" | \"focus\" | \"stale\";\n }\n | {\n type: \"query.error\";\n queryKey: readonly unknown[];\n tenant: string;\n error: unknown;\n }\n // Mutation lifecycle\n | {\n type: \"mutation.success\";\n mutationKey?: readonly unknown[];\n tenant: string;\n durationMs: number;\n }\n | {\n type: \"mutation.error\";\n mutationKey?: readonly unknown[];\n tenant: string;\n error: unknown;\n durationMs: number;\n }\n // Auth refresh (SDK-side)\n | {\n type: \"auth.refresh\";\n kind: \"anonymous\" | \"customer\";\n tenant: string;\n success: boolean;\n }\n // Storage writes\n | {\n type: \"storage.write\";\n key: \"customerToken\" | \"cartId\" | \"siteCode\" | \"anonymousSession\" | \"activeLegalEntityId\" | \"refreshToken\";\n }\n // Active-company switch (B2B)\n | {\n type: \"company:switched\";\n from: string | null;\n to: string | null;\n durationMs: number;\n }\n // Consumer-emitted\n | { type: \"custom\"; name: string; props?: Record<string, unknown> };\n\n/** Internal: the React context carrying the emit function down the tree. */\nexport const EmporixTelemetryContext = createContext<{\n emit: (event: EmporixTelemetryEvent) => void;\n} | null>(null);\n\n/**\n * Hook to emit custom telemetry events through the same channel as SDK\n * events. Throws when used outside an {@link EmporixProvider}.\n *\n * When the provider has no `onTelemetry` callback configured, `emit` is a\n * no-op — calling it is safe and incurs no overhead.\n */\nexport function useEmporixTelemetry(): {\n emit: (event: EmporixTelemetryEvent) => void;\n} {\n const ctx = useContext(EmporixTelemetryContext);\n if (!ctx) {\n throw new Error(\"useEmporixTelemetry must be used within an EmporixProvider\");\n }\n return ctx;\n}\n","import {\n createContext,\n useCallback,\n useContext,\n useEffect,\n useMemo,\n useRef,\n useState,\n type ReactNode,\n} from \"react\";\nimport { useQueryClient } from \"@tanstack/react-query\";\nimport { auth, type EmporixClient, type LegalEntity } from \"@viu/emporix-sdk\";\nimport type { EmporixStorage } from \"./storage\";\nimport { useEmporixTelemetry } from \"./telemetry\";\n\nexport type CompanyMode = \"b2c\" | \"b2b\" | \"unresolved\";\n\nexport interface CompanyContextValue {\n /** Active legal entity. `null` = B2C mode. */\n activeCompany: LegalEntity | null;\n /** All legal entities the customer is assigned to. */\n myCompanies: LegalEntity[];\n /**\n * `b2b` = a company is active; `b2c` = none active (and ≤1 available);\n * `unresolved` = multiple companies available, none picked yet — the\n * storefront must render a picker.\n */\n mode: CompanyMode;\n status: \"idle\" | \"loading\" | \"switching\" | \"error\";\n error: unknown;\n /**\n * Switch the active company. Eagerly calls\n * `client.customers.refresh({ legalEntityId })` so the customer token is\n * rescoped server-side, drops the cart id, then invalidates company-scoped\n * queries. Falls back to a local-state-only update when no refresh token\n * is in storage (e.g. fresh page load with memory storage).\n */\n setActiveCompany: (legalEntityId: string | null) => Promise<void>;\n refetchMyCompanies: () => Promise<void>;\n}\n\nconst NULL_CTX: CompanyContextValue = {\n activeCompany: null,\n myCompanies: [],\n mode: \"b2c\",\n status: \"idle\",\n error: null,\n setActiveCompany: async () => {\n throw new Error(\"CompanyContextProvider not mounted\");\n },\n refetchMyCompanies: async () => {},\n};\n\nexport const EmporixCompanyContext = createContext<CompanyContextValue>(NULL_CTX);\n\n/** Returns the active-company context. Safe outside the provider — returns idle B2C defaults. */\nexport function useActiveCompany(): CompanyContextValue {\n return useContext(EmporixCompanyContext);\n}\n\nexport interface CompanyContextProviderProps {\n client: EmporixClient;\n storage: EmporixStorage;\n initialActiveLegalEntityId?: string | null;\n children: ReactNode;\n}\n\nexport function CompanyContextProvider({\n client,\n storage,\n initialActiveLegalEntityId,\n children,\n}: CompanyContextProviderProps): React.JSX.Element {\n const qc = useQueryClient();\n const { emit } = useEmporixTelemetry();\n const [myCompanies, setMyCompanies] = useState<LegalEntity[]>([]);\n const [activeCompany, setActive] = useState<LegalEntity | null>(null);\n const [status, setStatus] = useState<CompanyContextValue[\"status\"]>(\"idle\");\n const [error, setError] = useState<unknown>(null);\n // Ref so switchTo can capture the latest `activeCompany` for telemetry `from`.\n const activeRef = useRef<LegalEntity | null>(null);\n activeRef.current = activeCompany;\n\n /** Internal: eager refresh + storage write + state update. */\n const switchTo = useCallback(\n async (target: LegalEntity | null) => {\n const start = Date.now();\n const from = activeRef.current?.id ?? null;\n const refreshToken = storage.getRefreshToken();\n const token = storage.getCustomerToken();\n if (!refreshToken || !token) {\n // Local-state-only fallback — no rescope possible.\n setActive(target);\n storage.setActiveLegalEntityId(target?.id ?? null);\n } else {\n const next = await client.customers.refresh({\n refreshToken,\n ...(target ? { legalEntityId: target.id } : {}),\n });\n storage.setCustomerToken(next.customerToken);\n if (next.refreshToken) storage.setRefreshToken(next.refreshToken);\n storage.setCartId(null);\n storage.setActiveLegalEntityId(target?.id ?? null);\n setActive(target);\n qc.invalidateQueries({\n predicate: (q) =>\n Array.isArray(q.queryKey) &&\n q.queryKey.some(\n (k) =>\n k === \"cart\" ||\n k === \"companies\" ||\n k === \"customer\" ||\n k === from ||\n (target !== null && k === target.id),\n ),\n });\n }\n emit({\n type: \"company:switched\",\n from,\n to: target?.id ?? null,\n durationMs: Date.now() - start,\n });\n },\n [client, storage, qc, emit],\n );\n\n const load = useCallback(async () => {\n const token = storage.getCustomerToken();\n if (!token) {\n setMyCompanies([]);\n setActive(null);\n setStatus(\"idle\");\n return;\n }\n setStatus(\"loading\");\n try {\n const companies = await client.companies.listMine(auth.customer(token));\n setMyCompanies(companies);\n const persisted = initialActiveLegalEntityId ?? storage.getActiveLegalEntityId();\n const matched = persisted ? companies.find((c) => c.id === persisted) ?? null : null;\n if (matched) {\n setActive(matched);\n if (storage.getActiveLegalEntityId() !== matched.id) {\n storage.setActiveLegalEntityId(matched.id);\n }\n } else if (companies.length === 1) {\n await switchTo(companies[0] ?? null);\n } else {\n setActive(null);\n if (persisted && !matched) storage.setActiveLegalEntityId(null);\n }\n setStatus(\"idle\");\n } catch (e) {\n setError(e);\n setStatus(\"error\");\n }\n }, [client, storage, initialActiveLegalEntityId, switchTo]);\n\n useEffect(() => {\n void load();\n }, [load]);\n\n // Re-run bootstrap only on token-presence transitions (login/logout). A\n // mid-session token swap (e.g. switch-driven refresh) keeps prev/next both\n // truthy and is ignored — otherwise the auto-pick branch would clobber an\n // explicit B2C choice as soon as the new token is written.\n useEffect(() => {\n let prev = storage.getCustomerToken();\n return storage.subscribe?.((next) => {\n const becameAuth = !prev && next;\n const becameUnauth = prev && !next;\n prev = next;\n if (becameAuth || becameUnauth) void load();\n });\n }, [storage, load]);\n\n const setActiveCompany = useCallback(\n async (legalEntityId: string | null) => {\n setStatus(\"switching\");\n try {\n if (legalEntityId === null) {\n await switchTo(null);\n } else {\n const target = myCompanies.find((c) => c.id === legalEntityId) ?? null;\n if (!target) throw new Error(`setActiveCompany: unknown legalEntityId ${legalEntityId}`);\n await switchTo(target);\n }\n setStatus(\"idle\");\n } catch (e) {\n setError(e);\n setStatus(\"error\");\n throw e;\n }\n },\n [myCompanies, switchTo],\n );\n\n const value = useMemo<CompanyContextValue>(() => {\n const mode: CompanyMode = activeCompany\n ? \"b2b\"\n : myCompanies.length > 1\n ? \"unresolved\"\n : \"b2c\";\n return {\n activeCompany,\n myCompanies,\n mode,\n status,\n error,\n setActiveCompany,\n refetchMyCompanies: load,\n };\n }, [activeCompany, myCompanies, status, error, setActiveCompany, load]);\n\n return (\n <EmporixCompanyContext.Provider value={value}>{children}</EmporixCompanyContext.Provider>\n );\n}\n","import { createContext, useCallback, useContext, useEffect, useMemo, useState, type ReactNode } from \"react\";\nimport { QueryClient, QueryClientProvider, useQueryClient } from \"@tanstack/react-query\";\nimport { auth, type EmporixClient } from \"@viu/emporix-sdk\";\nimport type { EmporixStorage } from \"./storage/index\";\nimport { createMemoryStorage } from \"./storage/memory\";\nimport { EmporixTelemetryContext, type EmporixTelemetryEvent } from \"./telemetry\";\nimport { CompanyContextProvider } from \"./company-context\";\n\ninterface EmporixContextValue {\n client: EmporixClient;\n storage: EmporixStorage;\n}\n\nexport interface SiteContextValue {\n siteCode: string | null;\n /** MS-4 populates this from the active site's DTO. */\n currency: string | null;\n /** MS-4 populates this from the active site's DTO. */\n targetLocation: string | null;\n /**\n * Asynchronous site switch. Updates local state + storage immediately\n * (optimistic), then PATCHes `/session-context/{tenant}/me/context` so\n * the server sees the same site on the next request. When no session\n * context exists yet (first visit, before any cart), the PATCH is\n * skipped — local state still flips.\n *\n * `isSwitching` is `true` while the PATCH is in flight. `switchError`\n * surfaces a PATCH failure; the optimistic state is NOT rolled back\n * (the cache was already invalidated, the UI already moved on).\n */\n setSite: (code: string | null) => Promise<void>;\n isSwitching: boolean;\n switchError: Error | null;\n}\n\nconst EmporixContext = createContext<EmporixContextValue | null>(null);\nexport const EmporixSiteContext = createContext<SiteContextValue | null>(null);\n\n/**\n * Balanced React-Query defaults applied to the provider's fallback QueryClient\n * (only when no `queryClient` prop is passed). Keeps the Emporix API-quota in\n * check by suppressing window-focus refetches and capping retries.\n */\nconst DEFAULT_QUERY_OPTIONS = {\n staleTime: 30_000,\n refetchOnWindowFocus: false,\n retry: 1,\n} as const;\n\n/** Props for {@link EmporixProvider}. */\nexport interface EmporixProviderProps {\n client: EmporixClient;\n queryClient?: QueryClient;\n storage?: EmporixStorage;\n initialCustomerToken?: string;\n /**\n * Initial site code. Resolution order: this prop → `storage.getSiteCode()` →\n * `client.config.credentials.storefront.context.siteCode` → `null`.\n */\n initialSiteCode?: string;\n /**\n * Initial active legal-entity id (B2B). When set, the CompanyContext\n * provider tries to match it against `companies.listMine()` once the\n * customer is loaded; mismatches are dropped silently.\n */\n initialActiveLegalEntityId?: string | null;\n /**\n * Opt-in telemetry callback. Receives a typed event stream covering cache\n * hit/miss, refetches, errors, mutations, auth refreshes, storage writes,\n * and consumer-emitted custom events. Wire this to Datadog/Sentry/custom\n * analytics. The handler is wrapped in try/catch — a throwing handler\n * never breaks the provider.\n */\n onTelemetry?: (event: EmporixTelemetryEvent) => void;\n /**\n * Opt in to reactive customer-token auto-refresh: on a `customer`-kind 401,\n * the SDK refreshes once (via the stored refresh token + anonymous auth) and\n * retries. Default: false (the customer token stays caller-owned).\n */\n autoRefreshCustomerToken?: boolean;\n /**\n * Called when a customer-token refresh is needed but fails (refresh token\n * expired/revoked) or no refresh token is stored. Use to drive logout /\n * redirect to login.\n */\n onCustomerSessionExpired?: () => void;\n children: ReactNode;\n}\n\n/** Provides the SDK client, token storage, react-query client, and site context to the tree. */\nexport function EmporixProvider({\n client,\n queryClient,\n storage,\n initialCustomerToken,\n initialSiteCode,\n initialActiveLegalEntityId,\n onTelemetry,\n autoRefreshCustomerToken,\n onCustomerSessionExpired,\n children,\n}: EmporixProviderProps): React.JSX.Element {\n const value = useMemo<EmporixContextValue>(() => {\n const s =\n storage ??\n createMemoryStorage(\n initialCustomerToken !== undefined ? { initial: initialCustomerToken } : {},\n );\n if (initialCustomerToken && storage && storage.getCustomerToken() === null) {\n storage.setCustomerToken(initialCustomerToken);\n }\n return { client, storage: s };\n \n }, [client, storage, initialCustomerToken]);\n const qc = useMemo(\n () =>\n queryClient ??\n new QueryClient({ defaultOptions: { queries: DEFAULT_QUERY_OPTIONS } }),\n [queryClient],\n );\n\n // Idempotent one-time wiring: attaches a storage-backed adapter to the SDK's\n // token provider so anonymous sessions survive reloads. Runs once per\n // (client, storage) pair via useState's lazy initializer.\n useState(() => {\n client.tokenProvider.attachAnonymousStore?.({\n read: () => value.storage.getAnonymousSession(),\n write: (s) => value.storage.setAnonymousSession(s),\n });\n return null;\n });\n\n // Telemetry: stable safeEmit + context value. emit is no-op when no\n // onTelemetry callback was provided (no overhead).\n const safeEmit = useCallback(\n (event: EmporixTelemetryEvent) => {\n if (!onTelemetry) return;\n try {\n onTelemetry(event);\n } catch (err) {\n // eslint-disable-next-line no-console\n console.error(\"[emporix] telemetry handler threw:\", err);\n }\n },\n [onTelemetry],\n );\n const telemetryValue = useMemo(() => ({ emit: safeEmit }), [safeEmit]);\n\n // Source subscriptions: cache + mutation cache + token-provider + storage.\n // All only active when onTelemetry is provided.\n useEffect(() => {\n if (!onTelemetry) return;\n const startedAt = new Map<string, number>();\n\n const unsubQuery = qc.getQueryCache().subscribe((event) => {\n const key = event.query.queryKey;\n if (!Array.isArray(key) || key[0] !== \"emporix\") return;\n if (event.type === \"updated\") {\n const action = event.action as { type: string };\n if (action.type === \"fetch\") {\n const isRefetch = event.query.state.dataUpdateCount > 0;\n if (isRefetch) {\n safeEmit({\n type: \"query.refetch\",\n queryKey: key,\n tenant: client.tenant,\n reason: \"invalidate\",\n });\n }\n startedAt.set(event.query.queryHash, Date.now());\n } else if (action.type === \"success\") {\n const start = startedAt.get(event.query.queryHash);\n startedAt.delete(event.query.queryHash);\n safeEmit({\n type: \"cache.miss\",\n queryKey: key,\n tenant: client.tenant,\n durationMs: start ? Date.now() - start : 0,\n });\n } else if (action.type === \"error\") {\n startedAt.delete(event.query.queryHash);\n safeEmit({\n type: \"query.error\",\n queryKey: key,\n tenant: client.tenant,\n error: event.query.state.error,\n });\n }\n } else if (event.type === \"observerResultsUpdated\") {\n const s = event.query.state;\n if (s.status === \"success\" && s.fetchStatus === \"idle\" && s.dataUpdateCount > 0) {\n safeEmit({ type: \"cache.hit\", queryKey: key, tenant: client.tenant });\n }\n }\n });\n\n const unsubMut = qc.getMutationCache().subscribe((event) => {\n if (event.type !== \"updated\") return;\n const m = event.mutation;\n const dur = Date.now() - (m.state.submittedAt ?? Date.now());\n const mk = m.options.mutationKey;\n if (m.state.status === \"success\") {\n safeEmit({\n type: \"mutation.success\",\n ...(mk ? { mutationKey: mk as readonly unknown[] } : {}),\n tenant: client.tenant,\n durationMs: dur,\n });\n } else if (m.state.status === \"error\") {\n safeEmit({\n type: \"mutation.error\",\n ...(mk ? { mutationKey: mk as readonly unknown[] } : {}),\n tenant: client.tenant,\n error: m.state.error,\n durationMs: dur,\n });\n }\n });\n\n const unsubAuth = client.tokenProvider.onRefresh?.((evt) =>\n safeEmit({ type: \"auth.refresh\", ...evt, tenant: client.tenant }),\n );\n\n const unsubStorage = value.storage.subscribeAll?.((key) =>\n safeEmit({ type: \"storage.write\", key }),\n );\n\n return () => {\n unsubQuery();\n unsubMut();\n unsubAuth?.();\n unsubStorage?.();\n };\n }, [qc, onTelemetry, client, value.storage, safeEmit]);\n\n // Opt-in reactive customer-token auto-refresh. Registered on the client so\n // the core HttpClient can refresh-and-retry a customer 401. Single-flight is\n // handled in the core registry. Off unless `autoRefreshCustomerToken`.\n useEffect(() => {\n if (!autoRefreshCustomerToken) return;\n const storage = value.storage;\n client.setCustomerTokenRefresher({\n refresh: async () => {\n const refreshToken = storage.getRefreshToken();\n if (!refreshToken) {\n safeEmit({ type: \"auth.refresh\", kind: \"customer\", success: false, tenant: client.tenant });\n onCustomerSessionExpired?.();\n return null;\n }\n try {\n const legalEntityId = storage.getActiveLegalEntityId() ?? undefined;\n const s = await client.customers.refresh({\n refreshToken,\n ...(legalEntityId ? { legalEntityId } : {}),\n });\n storage.setCustomerToken(s.customerToken);\n if (s.refreshToken) storage.setRefreshToken(s.refreshToken);\n safeEmit({ type: \"auth.refresh\", kind: \"customer\", success: true, tenant: client.tenant });\n return s.customerToken;\n } catch {\n safeEmit({ type: \"auth.refresh\", kind: \"customer\", success: false, tenant: client.tenant });\n onCustomerSessionExpired?.();\n return null;\n }\n },\n });\n return () => client.setCustomerTokenRefresher(null);\n }, [autoRefreshCustomerToken, client, value.storage, safeEmit, onCustomerSessionExpired]);\n\n return (\n <EmporixContext.Provider value={value}>\n <EmporixTelemetryContext.Provider value={telemetryValue}>\n <QueryClientProvider client={qc}>\n <SiteContextProvider\n client={client}\n storage={value.storage}\n {...(initialSiteCode !== undefined ? { initialSiteCode } : {})}\n >\n <CompanyContextProvider\n client={client}\n storage={value.storage}\n {...(initialActiveLegalEntityId !== undefined\n ? { initialActiveLegalEntityId }\n : {})}\n >\n {children}\n </CompanyContextProvider>\n </SiteContextProvider>\n </QueryClientProvider>\n </EmporixTelemetryContext.Provider>\n </EmporixContext.Provider>\n );\n}\n\n/**\n * Manages the active-site state. Sits inside `QueryClientProvider` so\n * `setSite` can invalidate the React-Query cache on switch.\n */\nfunction SiteContextProvider({\n client,\n storage,\n initialSiteCode,\n children,\n}: {\n client: EmporixClient;\n storage: EmporixStorage;\n initialSiteCode?: string;\n children: ReactNode;\n}): React.JSX.Element {\n const qc = useQueryClient();\n const [siteCode, setSiteCodeState] = useState<string | null>(() => {\n if (initialSiteCode !== undefined) return initialSiteCode;\n const fromStorage = storage.getSiteCode();\n if (fromStorage !== null) return fromStorage;\n return client.config?.credentials?.storefront?.context?.siteCode ?? null;\n });\n const [currency, setCurrency] = useState<string | null>(null);\n const [targetLocation, setTargetLocation] = useState<string | null>(null);\n const [isSwitching, setIsSwitching] = useState(false);\n const [switchError, setSwitchError] = useState<Error | null>(null);\n\n // Mount-time derivation: if a siteCode is already resolved, fetch its DTO\n // once so currency + targetLocation populate without a user-driven switch.\n useEffect(() => {\n if (!siteCode || currency !== null) return;\n let cancelled = false;\n const token = storage.getCustomerToken();\n const authCtx = token ? auth.customer(token) : auth.anonymous();\n qc.fetchQuery({\n queryKey: [\n \"emporix\",\n \"site-by-code\",\n siteCode,\n { tenant: client.tenant, authKind: authCtx.kind },\n ],\n queryFn: () => client.sites.get(siteCode, authCtx),\n staleTime: 5 * 60_000,\n })\n .then((site) => {\n if (cancelled) return;\n setCurrency(site.currency);\n setTargetLocation(site.homeBase?.address?.country ?? null);\n })\n .catch(() => {\n // Best-effort — silent. setSite-driven derivation surfaces real errors.\n });\n return () => {\n cancelled = true;\n };\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [siteCode]);\n\n const setSite = useCallback(\n async (code: string | null) => {\n // 1) Optimistic flip — UI moves immediately.\n storage.setSiteCode(code);\n storage.setCartId(null);\n setSiteCodeState(code);\n setSwitchError(null);\n void qc.invalidateQueries({ queryKey: [\"emporix\"] });\n\n if (code === null) {\n setCurrency(null);\n setTargetLocation(null);\n return;\n }\n\n setIsSwitching(true);\n try {\n const token = storage.getCustomerToken();\n const authCtx = token ? auth.customer(token) : auth.anonymous();\n // 2) Derive currency + targetLocation from the site DTO (cached 5min).\n const site = await qc.fetchQuery({\n queryKey: [\n \"emporix\",\n \"site-by-code\",\n code,\n { tenant: client.tenant, authKind: authCtx.kind },\n ],\n queryFn: () => client.sites.get(code, authCtx),\n staleTime: 5 * 60_000,\n });\n const nextCurrency = site.currency;\n const nextTarget = site.homeBase?.address?.country ?? null;\n setCurrency(nextCurrency);\n setTargetLocation(nextTarget);\n // 3) Push everything into the session-context PATCH.\n await client.sessionContext.patch(\n {\n siteCode: code,\n ...(nextCurrency ? { currency: nextCurrency } : {}),\n ...(nextTarget ? { targetLocation: nextTarget } : {}),\n },\n authCtx,\n );\n } catch (e) {\n setSwitchError(e instanceof Error ? e : new Error(String(e)));\n } finally {\n setIsSwitching(false);\n }\n },\n [client, storage, qc],\n );\n\n const value = useMemo<SiteContextValue>(\n () => ({\n siteCode,\n currency,\n targetLocation,\n setSite,\n isSwitching,\n switchError,\n }),\n [siteCode, currency, targetLocation, setSite, isSwitching, switchError],\n );\n\n return <EmporixSiteContext.Provider value={value}>{children}</EmporixSiteContext.Provider>;\n}\n\n/** Returns the SDK client and token storage. Throws outside an {@link EmporixProvider}. */\nexport function useEmporix(): EmporixContextValue {\n const ctx = useContext(EmporixContext);\n if (!ctx) throw new Error(\"useEmporix must be used within an EmporixProvider\");\n return ctx;\n}\n"]}
1
+ {"version":3,"sources":["../src/storage/index.ts","../src/storage/memory.ts","../src/telemetry.ts","../src/company-context.tsx","../src/provider.tsx"],"names":["createContext","useContext","useQueryClient","useState","useRef","useCallback","auth","useEffect","useMemo","jsx","QueryClient","storage","QueryClientProvider"],"mappings":";;;;;;;;;;AA8DO,SAAS,iBAAA,GAGd;AACA,EAAA,MAAM,SAAA,uBAAgB,GAAA,EAAoB;AAC1C,EAAA,OAAO;AAAA,IACL,IAAI,CAAA,EAAG;AACL,MAAA,SAAA,CAAU,IAAI,CAAC,CAAA;AACf,MAAA,OAAO,MAAM,SAAA,CAAU,MAAA,CAAO,CAAC,CAAA;AAAA,IACjC,CAAA;AAAA,IACA,OAAO,KAAA,EAAO;AACZ,MAAA,KAAA,MAAW,KAAK,SAAA,EAAW;AACzB,QAAA,IAAI;AACF,UAAA,CAAA,CAAE,KAAK,CAAA;AAAA,QACT,CAAA,CAAA,MAAQ;AAAA,QAER;AAAA,MACF;AAAA,IACF;AAAA,GACF;AACF;;;AC1EO,SAAS,mBAAA,CAAoB,IAAA,GAA6B,EAAC,EAAmB;AACnF,EAAA,IAAI,KAAA,GAAuB,KAAK,OAAA,IAAW,IAAA;AAC3C,EAAA,IAAI,MAAA,GAAwB,IAAA;AAC5B,EAAA,IAAI,IAAA,GAAyC,IAAA;AAC7C,EAAA,IAAI,QAAA,GAA0B,IAAA;AAC9B,EAAA,IAAI,mBAAA,GAAqC,IAAA;AACzC,EAAA,IAAI,YAAA,GAA8B,IAAA;AAClC,EAAA,MAAM,cAAA,uBAAqB,GAAA,EAAgC;AAC3D,EAAA,MAAM,MAAM,iBAAA,EAAqC;AACjD,EAAA,OAAO;AAAA,IACL,kBAAkB,MAAM,KAAA;AAAA,IACxB,gBAAA,EAAkB,CAAC,CAAA,KAAM;AACvB,MAAA,KAAA,GAAQ,CAAA;AACR,MAAA,KAAA,MAAW,CAAA,IAAK,cAAA,EAAgB,CAAA,CAAE,KAAK,CAAA;AACvC,MAAA,GAAA,CAAI,OAAO,eAAe,CAAA;AAAA,IAC5B,CAAA;AAAA,IACA,SAAA,EAAW,CAAC,CAAA,KAAM;AAChB,MAAA,cAAA,CAAe,IAAI,CAAC,CAAA;AACpB,MAAA,OAAO,MAAM,cAAA,CAAe,MAAA,CAAO,CAAC,CAAA;AAAA,IACtC,CAAA;AAAA,IACA,WAAW,MAAM,MAAA;AAAA,IACjB,SAAA,EAAW,CAAC,EAAA,KAAO;AACjB,MAAA,MAAA,GAAS,EAAA;AACT,MAAA,GAAA,CAAI,OAAO,QAAQ,CAAA;AAAA,IACrB,CAAA;AAAA,IACA,qBAAqB,MAAM,IAAA;AAAA,IAC3B,mBAAA,EAAqB,CAAC,CAAA,KAAM;AAC1B,MAAA,IAAA,GAAO,CAAA;AACP,MAAA,GAAA,CAAI,OAAO,kBAAkB,CAAA;AAAA,IAC/B,CAAA;AAAA,IACA,aAAa,MAAM,QAAA;AAAA,IACnB,WAAA,EAAa,CAAC,IAAA,KAAS;AACrB,MAAA,QAAA,GAAW,IAAA;AACX,MAAA,GAAA,CAAI,OAAO,UAAU,CAAA;AAAA,IACvB,CAAA;AAAA,IACA,wBAAwB,MAAM,mBAAA;AAAA,IAC9B,sBAAA,EAAwB,CAAC,EAAA,KAAO;AAC9B,MAAA,mBAAA,GAAsB,EAAA;AACtB,MAAA,GAAA,CAAI,OAAO,qBAAqB,CAAA;AAAA,IAClC,CAAA;AAAA,IACA,iBAAiB,MAAM,YAAA;AAAA,IACvB,eAAA,EAAiB,CAAC,CAAA,KAAM;AACtB,MAAA,YAAA,GAAe,CAAA;AACf,MAAA,GAAA,CAAI,OAAO,cAAc,CAAA;AAAA,IAC3B,CAAA;AAAA,IACA,YAAA,EAAc,CAAC,CAAA,KAAM,GAAA,CAAI,IAAI,CAAC;AAAA,GAChC;AACF;ACcO,IAAM,uBAAA,GAA0BA,oBAE7B,IAAI,CAAA;AASP,SAAS,mBAAA,GAEd;AACA,EAAA,MAAM,GAAA,GAAMC,iBAAW,uBAAuB,CAAA;AAC9C,EAAA,IAAI,CAAC,GAAA,EAAK;AACR,IAAA,MAAM,IAAI,MAAM,4DAA4D,CAAA;AAAA,EAC9E;AACA,EAAA,OAAO,GAAA;AACT;AC/CA,IAAM,QAAA,GAAgC;AAAA,EACpC,aAAA,EAAe,IAAA;AAAA,EACf,aAAa,EAAC;AAAA,EACd,IAAA,EAAM,KAAA;AAAA,EACN,MAAA,EAAQ,MAAA;AAAA,EACR,KAAA,EAAO,IAAA;AAAA,EACP,kBAAkB,YAAY;AAC5B,IAAA,MAAM,IAAI,MAAM,oCAAoC,CAAA;AAAA,EACtD,CAAA;AAAA,EACA,oBAAoB,YAAY;AAAA,EAAC;AACnC,CAAA;AAEO,IAAM,qBAAA,GAAwBD,oBAAmC,QAAQ,CAAA;AAczE,SAAS,sBAAA,CAAuB;AAAA,EACrC,MAAA;AAAA,EACA,OAAA;AAAA,EACA,0BAAA;AAAA,EACA;AACF,CAAA,EAAmD;AACjD,EAAA,MAAM,KAAKE,yBAAA,EAAe;AAC1B,EAAA,MAAM,EAAE,IAAA,EAAK,GAAI,mBAAA,EAAoB;AACrC,EAAA,MAAM,CAAC,WAAA,EAAa,cAAc,CAAA,GAAIC,cAAA,CAAwB,EAAE,CAAA;AAChE,EAAA,MAAM,CAAC,aAAA,EAAe,SAAS,CAAA,GAAIA,eAA6B,IAAI,CAAA;AACpE,EAAA,MAAM,CAAC,MAAA,EAAQ,SAAS,CAAA,GAAIA,eAAwC,MAAM,CAAA;AAC1E,EAAA,MAAM,CAAC,KAAA,EAAO,QAAQ,CAAA,GAAIA,eAAkB,IAAI,CAAA;AAEhD,EAAA,MAAM,SAAA,GAAYC,aAA2B,IAAI,CAAA;AACjD,EAAA,SAAA,CAAU,OAAA,GAAU,aAAA;AAGpB,EAAA,MAAM,QAAA,GAAWC,iBAAA;AAAA,IACf,OAAO,MAAA,KAA+B;AACpC,MAAA,MAAM,KAAA,GAAQ,KAAK,GAAA,EAAI;AACvB,MAAA,MAAM,IAAA,GAAO,SAAA,CAAU,OAAA,EAAS,EAAA,IAAM,IAAA;AACtC,MAAA,MAAM,YAAA,GAAe,QAAQ,eAAA,EAAgB;AAC7C,MAAA,MAAM,KAAA,GAAQ,QAAQ,gBAAA,EAAiB;AACvC,MAAA,IAAI,CAAC,YAAA,IAAgB,CAAC,KAAA,EAAO;AAE3B,QAAA,SAAA,CAAU,MAAM,CAAA;AAChB,QAAA,OAAA,CAAQ,sBAAA,CAAuB,MAAA,EAAQ,EAAA,IAAM,IAAI,CAAA;AAAA,MACnD,CAAA,MAAO;AACL,QAAA,MAAM,IAAA,GAAO,MAAM,MAAA,CAAO,SAAA,CAAU,OAAA,CAAQ;AAAA,UAC1C,YAAA;AAAA,UACA,GAAI,MAAA,GAAS,EAAE,eAAe,MAAA,CAAO,EAAA,KAAO;AAAC,SAC9C,CAAA;AACD,QAAA,OAAA,CAAQ,gBAAA,CAAiB,KAAK,aAAa,CAAA;AAC3C,QAAA,IAAI,IAAA,CAAK,YAAA,EAAc,OAAA,CAAQ,eAAA,CAAgB,KAAK,YAAY,CAAA;AAChE,QAAA,OAAA,CAAQ,UAAU,IAAI,CAAA;AACtB,QAAA,OAAA,CAAQ,sBAAA,CAAuB,MAAA,EAAQ,EAAA,IAAM,IAAI,CAAA;AACjD,QAAA,SAAA,CAAU,MAAM,CAAA;AAChB,QAAA,EAAA,CAAG,iBAAA,CAAkB;AAAA,UACnB,SAAA,EAAW,CAAC,CAAA,KACV,KAAA,CAAM,QAAQ,CAAA,CAAE,QAAQ,CAAA,IACxB,CAAA,CAAE,QAAA,CAAS,IAAA;AAAA,YACT,CAAC,CAAA,KACC,CAAA,KAAM,MAAA,IACN,CAAA,KAAM,WAAA,IACN,CAAA,KAAM,UAAA,IACN,CAAA,KAAM,IAAA,IACL,MAAA,KAAW,IAAA,IAAQ,MAAM,MAAA,CAAO;AAAA;AACrC,SACH,CAAA;AAAA,MACH;AACA,MAAA,IAAA,CAAK;AAAA,QACH,IAAA,EAAM,kBAAA;AAAA,QACN,IAAA;AAAA,QACA,EAAA,EAAI,QAAQ,EAAA,IAAM,IAAA;AAAA,QAClB,UAAA,EAAY,IAAA,CAAK,GAAA,EAAI,GAAI;AAAA,OAC1B,CAAA;AAAA,IACH,CAAA;AAAA,IACA,CAAC,MAAA,EAAQ,OAAA,EAAS,EAAA,EAAI,IAAI;AAAA,GAC5B;AAEA,EAAA,MAAM,IAAA,GAAOA,kBAAY,YAAY;AACnC,IAAA,MAAM,KAAA,GAAQ,QAAQ,gBAAA,EAAiB;AACvC,IAAA,IAAI,CAAC,KAAA,EAAO;AACV,MAAA,cAAA,CAAe,EAAE,CAAA;AACjB,MAAA,SAAA,CAAU,IAAI,CAAA;AACd,MAAA,SAAA,CAAU,MAAM,CAAA;AAChB,MAAA;AAAA,IACF;AACA,IAAA,SAAA,CAAU,SAAS,CAAA;AACnB,IAAA,IAAI;AACF,MAAA,MAAM,SAAA,GAAY,MAAM,MAAA,CAAO,SAAA,CAAU,SAASC,eAAA,CAAK,QAAA,CAAS,KAAK,CAAC,CAAA;AACtE,MAAA,cAAA,CAAe,SAAS,CAAA;AACxB,MAAA,MAAM,SAAA,GAAY,0BAAA,IAA8B,OAAA,CAAQ,sBAAA,EAAuB;AAC/E,MAAA,MAAM,OAAA,GAAU,SAAA,GAAY,SAAA,CAAU,IAAA,CAAK,CAAC,MAAM,CAAA,CAAE,EAAA,KAAO,SAAS,CAAA,IAAK,IAAA,GAAO,IAAA;AAChF,MAAA,IAAI,OAAA,EAAS;AACX,QAAA,SAAA,CAAU,OAAO,CAAA;AACjB,QAAA,IAAI,OAAA,CAAQ,sBAAA,EAAuB,KAAM,OAAA,CAAQ,EAAA,EAAI;AACnD,UAAA,OAAA,CAAQ,sBAAA,CAAuB,OAAA,CAAQ,EAAA,IAAM,IAAI,CAAA;AAAA,QACnD;AAAA,MACF,CAAA,MAAA,IAAW,SAAA,CAAU,MAAA,KAAW,CAAA,EAAG;AACjC,QAAA,MAAM,QAAA,CAAS,SAAA,CAAU,CAAC,CAAA,IAAK,IAAI,CAAA;AAAA,MACrC,CAAA,MAAO;AACL,QAAA,SAAA,CAAU,IAAI,CAAA;AACd,QAAA,IAAI,SAAA,IAAa,CAAC,OAAA,EAAS,OAAA,CAAQ,uBAAuB,IAAI,CAAA;AAAA,MAChE;AACA,MAAA,SAAA,CAAU,MAAM,CAAA;AAAA,IAClB,SAAS,CAAA,EAAG;AACV,MAAA,QAAA,CAAS,CAAC,CAAA;AACV,MAAA,SAAA,CAAU,OAAO,CAAA;AAAA,IACnB;AAAA,EACF,GAAG,CAAC,MAAA,EAAQ,OAAA,EAAS,0BAAA,EAA4B,QAAQ,CAAC,CAAA;AAE1D,EAAAC,eAAA,CAAU,MAAM;AACd,IAAA,KAAK,IAAA,EAAK;AAAA,EACZ,CAAA,EAAG,CAAC,IAAI,CAAC,CAAA;AAMT,EAAAA,eAAA,CAAU,MAAM;AACd,IAAA,IAAI,IAAA,GAAO,QAAQ,gBAAA,EAAiB;AACpC,IAAA,OAAO,OAAA,CAAQ,SAAA,GAAY,CAAC,IAAA,KAAS;AACnC,MAAA,MAAM,UAAA,GAAa,CAAC,IAAA,IAAQ,IAAA;AAC5B,MAAA,MAAM,YAAA,GAAe,QAAQ,CAAC,IAAA;AAC9B,MAAA,IAAA,GAAO,IAAA;AACP,MAAA,IAAI,UAAA,IAAc,YAAA,EAAc,KAAK,IAAA,EAAK;AAAA,IAC5C,CAAC,CAAA;AAAA,EACH,CAAA,EAAG,CAAC,OAAA,EAAS,IAAI,CAAC,CAAA;AAElB,EAAA,MAAM,gBAAA,GAAmBF,iBAAA;AAAA,IACvB,OAAO,aAAA,KAAiC;AACtC,MAAA,SAAA,CAAU,WAAW,CAAA;AACrB,MAAA,IAAI;AACF,QAAA,IAAI,kBAAkB,IAAA,EAAM;AAC1B,UAAA,MAAM,SAAS,IAAI,CAAA;AAAA,QACrB,CAAA,MAAO;AACL,UAAA,MAAM,MAAA,GAAS,YAAY,IAAA,CAAK,CAAC,MAAM,CAAA,CAAE,EAAA,KAAO,aAAa,CAAA,IAAK,IAAA;AAClE,UAAA,IAAI,CAAC,MAAA,EAAQ,MAAM,IAAI,KAAA,CAAM,CAAA,wCAAA,EAA2C,aAAa,CAAA,CAAE,CAAA;AACvF,UAAA,MAAM,SAAS,MAAM,CAAA;AAAA,QACvB;AACA,QAAA,SAAA,CAAU,MAAM,CAAA;AAAA,MAClB,SAAS,CAAA,EAAG;AACV,QAAA,QAAA,CAAS,CAAC,CAAA;AACV,QAAA,SAAA,CAAU,OAAO,CAAA;AACjB,QAAA,MAAM,CAAA;AAAA,MACR;AAAA,IACF,CAAA;AAAA,IACA,CAAC,aAAa,QAAQ;AAAA,GACxB;AAEA,EAAA,MAAM,KAAA,GAAQG,cAA6B,MAAM;AAC/C,IAAA,MAAM,OAAoB,aAAA,GACtB,KAAA,GACA,WAAA,CAAY,MAAA,GAAS,IACnB,YAAA,GACA,KAAA;AACN,IAAA,OAAO;AAAA,MACL,aAAA;AAAA,MACA,WAAA;AAAA,MACA,IAAA;AAAA,MACA,MAAA;AAAA,MACA,KAAA;AAAA,MACA,gBAAA;AAAA,MACA,kBAAA,EAAoB;AAAA,KACtB;AAAA,EACF,CAAA,EAAG,CAAC,aAAA,EAAe,WAAA,EAAa,QAAQ,KAAA,EAAO,gBAAA,EAAkB,IAAI,CAAC,CAAA;AAEtE,EAAA,uBACEC,cAAA,CAAC,qBAAA,CAAsB,QAAA,EAAtB,EAA+B,OAAe,QAAA,EAAS,CAAA;AAE5D;ACvLA,IAAM,cAAA,GAAiBT,oBAA0C,IAAI,CAAA;AAC9D,IAAM,kBAAA,GAAqBA,oBAAuC,IAAI;AAO7E,IAAM,qBAAA,GAAwB;AAAA,EAC5B,SAAA,EAAW,GAAA;AAAA,EACX,oBAAA,EAAsB,KAAA;AAAA,EACtB,KAAA,EAAO;AACT,CAAA;AA2CO,SAAS,eAAA,CAAgB;AAAA,EAC9B,MAAA;AAAA,EACA,WAAA;AAAA,EACA,OAAA;AAAA,EACA,oBAAA;AAAA,EACA,eAAA;AAAA,EACA,0BAAA;AAAA,EACA,WAAA;AAAA,EACA,wBAAA;AAAA,EACA,wBAAA;AAAA,EACA;AACF,CAAA,EAA4C;AAC1C,EAAA,MAAM,KAAA,GAAQQ,cAA6B,MAAM;AAC/C,IAAA,MAAM,IACJ,OAAA,IACA,mBAAA;AAAA,MACE,yBAAyB,MAAA,GAAY,EAAE,OAAA,EAAS,oBAAA,KAAyB;AAAC,KAC5E;AACF,IAAA,IAAI,oBAAA,IAAwB,OAAA,IAAW,OAAA,CAAQ,gBAAA,OAAuB,IAAA,EAAM;AAC1E,MAAA,OAAA,CAAQ,iBAAiB,oBAAoB,CAAA;AAAA,IAC/C;AACA,IAAA,OAAO,EAAE,MAAA,EAAQ,OAAA,EAAS,CAAA,EAAE;AAAA,EAE9B,CAAA,EAAG,CAAC,MAAA,EAAQ,OAAA,EAAS,oBAAoB,CAAC,CAAA;AAC1C,EAAA,MAAM,EAAA,GAAKA,aAAAA;AAAA,IACT,MACE,WAAA,IACA,IAAIE,sBAAA,CAAY,EAAE,gBAAgB,EAAE,OAAA,EAAS,qBAAA,EAAsB,EAAG,CAAA;AAAA,IACxE,CAAC,WAAW;AAAA,GACd;AAKA,EAAAP,eAAS,MAAM;AACb,IAAA,MAAA,CAAO,cAAc,oBAAA,GAAuB;AAAA,MAC1C,IAAA,EAAM,MAAM,KAAA,CAAM,OAAA,CAAQ,mBAAA,EAAoB;AAAA,MAC9C,OAAO,CAAC,CAAA,KAAM,KAAA,CAAM,OAAA,CAAQ,oBAAoB,CAAC;AAAA,KAClD,CAAA;AACD,IAAA,OAAO,IAAA;AAAA,EACT,CAAC,CAAA;AAID,EAAA,MAAM,QAAA,GAAWE,iBAAAA;AAAA,IACf,CAAC,KAAA,KAAiC;AAChC,MAAA,IAAI,CAAC,WAAA,EAAa;AAClB,MAAA,IAAI;AACF,QAAA,WAAA,CAAY,KAAK,CAAA;AAAA,MACnB,SAAS,GAAA,EAAK;AAEZ,QAAA,OAAA,CAAQ,KAAA,CAAM,sCAAsC,GAAG,CAAA;AAAA,MACzD;AAAA,IACF,CAAA;AAAA,IACA,CAAC,WAAW;AAAA,GACd;AACA,EAAA,MAAM,cAAA,GAAiBG,cAAQ,OAAO,EAAE,MAAM,QAAA,EAAS,CAAA,EAAI,CAAC,QAAQ,CAAC,CAAA;AAIrE,EAAAD,gBAAU,MAAM;AACd,IAAA,IAAI,CAAC,WAAA,EAAa;AAClB,IAAA,MAAM,SAAA,uBAAgB,GAAA,EAAoB;AAE1C,IAAA,MAAM,aAAa,EAAA,CAAG,aAAA,EAAc,CAAE,SAAA,CAAU,CAAC,KAAA,KAAU;AACzD,MAAA,MAAM,GAAA,GAAM,MAAM,KAAA,CAAM,QAAA;AACxB,MAAA,IAAI,CAAC,MAAM,OAAA,CAAQ,GAAG,KAAK,GAAA,CAAI,CAAC,MAAM,SAAA,EAAW;AACjD,MAAA,IAAI,KAAA,CAAM,SAAS,SAAA,EAAW;AAC5B,QAAA,MAAM,SAAS,KAAA,CAAM,MAAA;AACrB,QAAA,IAAI,MAAA,CAAO,SAAS,OAAA,EAAS;AAC3B,UAAA,MAAM,SAAA,GAAY,KAAA,CAAM,KAAA,CAAM,KAAA,CAAM,eAAA,GAAkB,CAAA;AACtD,UAAA,IAAI,SAAA,EAAW;AACb,YAAA,QAAA,CAAS;AAAA,cACP,IAAA,EAAM,eAAA;AAAA,cACN,QAAA,EAAU,GAAA;AAAA,cACV,QAAQ,MAAA,CAAO,MAAA;AAAA,cACf,MAAA,EAAQ;AAAA,aACT,CAAA;AAAA,UACH;AACA,UAAA,SAAA,CAAU,IAAI,KAAA,CAAM,KAAA,CAAM,SAAA,EAAW,IAAA,CAAK,KAAK,CAAA;AAAA,QACjD,CAAA,MAAA,IAAW,MAAA,CAAO,IAAA,KAAS,SAAA,EAAW;AACpC,UAAA,MAAM,KAAA,GAAQ,SAAA,CAAU,GAAA,CAAI,KAAA,CAAM,MAAM,SAAS,CAAA;AACjD,UAAA,SAAA,CAAU,MAAA,CAAO,KAAA,CAAM,KAAA,CAAM,SAAS,CAAA;AACtC,UAAA,QAAA,CAAS;AAAA,YACP,IAAA,EAAM,YAAA;AAAA,YACN,QAAA,EAAU,GAAA;AAAA,YACV,QAAQ,MAAA,CAAO,MAAA;AAAA,YACf,UAAA,EAAY,KAAA,GAAQ,IAAA,CAAK,GAAA,KAAQ,KAAA,GAAQ;AAAA,WAC1C,CAAA;AAAA,QACH,CAAA,MAAA,IAAW,MAAA,CAAO,IAAA,KAAS,OAAA,EAAS;AAClC,UAAA,SAAA,CAAU,MAAA,CAAO,KAAA,CAAM,KAAA,CAAM,SAAS,CAAA;AACtC,UAAA,QAAA,CAAS;AAAA,YACP,IAAA,EAAM,aAAA;AAAA,YACN,QAAA,EAAU,GAAA;AAAA,YACV,QAAQ,MAAA,CAAO,MAAA;AAAA,YACf,KAAA,EAAO,KAAA,CAAM,KAAA,CAAM,KAAA,CAAM;AAAA,WAC1B,CAAA;AAAA,QACH;AAAA,MACF,CAAA,MAAA,IAAW,KAAA,CAAM,IAAA,KAAS,wBAAA,EAA0B;AAClD,QAAA,MAAM,CAAA,GAAI,MAAM,KAAA,CAAM,KAAA;AACtB,QAAA,IAAI,CAAA,CAAE,WAAW,SAAA,IAAa,CAAA,CAAE,gBAAgB,MAAA,IAAU,CAAA,CAAE,kBAAkB,CAAA,EAAG;AAC/E,UAAA,QAAA,CAAS,EAAE,MAAM,WAAA,EAAa,QAAA,EAAU,KAAK,MAAA,EAAQ,MAAA,CAAO,QAAQ,CAAA;AAAA,QACtE;AAAA,MACF;AAAA,IACF,CAAC,CAAA;AAED,IAAA,MAAM,WAAW,EAAA,CAAG,gBAAA,EAAiB,CAAE,SAAA,CAAU,CAAC,KAAA,KAAU;AAC1D,MAAA,IAAI,KAAA,CAAM,SAAS,SAAA,EAAW;AAC9B,MAAA,MAAM,IAAI,KAAA,CAAM,QAAA;AAChB,MAAA,MAAM,GAAA,GAAM,KAAK,GAAA,EAAI,IAAK,EAAE,KAAA,CAAM,WAAA,IAAe,KAAK,GAAA,EAAI,CAAA;AAC1D,MAAA,MAAM,EAAA,GAAK,EAAE,OAAA,CAAQ,WAAA;AACrB,MAAA,IAAI,CAAA,CAAE,KAAA,CAAM,MAAA,KAAW,SAAA,EAAW;AAChC,QAAA,QAAA,CAAS;AAAA,UACP,IAAA,EAAM,kBAAA;AAAA,UACN,GAAI,EAAA,GAAK,EAAE,WAAA,EAAa,EAAA,KAA6B,EAAC;AAAA,UACtD,QAAQ,MAAA,CAAO,MAAA;AAAA,UACf,UAAA,EAAY;AAAA,SACb,CAAA;AAAA,MACH,CAAA,MAAA,IAAW,CAAA,CAAE,KAAA,CAAM,MAAA,KAAW,OAAA,EAAS;AACrC,QAAA,QAAA,CAAS;AAAA,UACP,IAAA,EAAM,gBAAA;AAAA,UACN,GAAI,EAAA,GAAK,EAAE,WAAA,EAAa,EAAA,KAA6B,EAAC;AAAA,UACtD,QAAQ,MAAA,CAAO,MAAA;AAAA,UACf,KAAA,EAAO,EAAE,KAAA,CAAM,KAAA;AAAA,UACf,UAAA,EAAY;AAAA,SACb,CAAA;AAAA,MACH;AAAA,IACF,CAAC,CAAA;AAED,IAAA,MAAM,SAAA,GAAY,OAAO,aAAA,CAAc,SAAA;AAAA,MAAY,CAAC,GAAA,KAClD,QAAA,CAAS,EAAE,IAAA,EAAM,cAAA,EAAgB,GAAG,GAAA,EAAK,MAAA,EAAQ,MAAA,CAAO,MAAA,EAAQ;AAAA,KAClE;AAEA,IAAA,MAAM,YAAA,GAAe,MAAM,OAAA,CAAQ,YAAA;AAAA,MAAe,CAAC,GAAA,KACjD,QAAA,CAAS,EAAE,IAAA,EAAM,eAAA,EAAiB,KAAK;AAAA,KACzC;AAEA,IAAA,OAAO,MAAM;AACX,MAAA,UAAA,EAAW;AACX,MAAA,QAAA,EAAS;AACT,MAAA,SAAA,IAAY;AACZ,MAAA,YAAA,IAAe;AAAA,IACjB,CAAA;AAAA,EACF,CAAA,EAAG,CAAC,EAAA,EAAI,WAAA,EAAa,QAAQ,KAAA,CAAM,OAAA,EAAS,QAAQ,CAAC,CAAA;AAKrD,EAAAA,gBAAU,MAAM;AACd,IAAA,IAAI,CAAC,wBAAA,EAA0B;AAC/B,IAAA,MAAMI,WAAU,KAAA,CAAM,OAAA;AACtB,IAAA,MAAA,CAAO,yBAAA,CAA0B;AAAA,MAC/B,SAAS,YAAY;AACnB,QAAA,MAAM,YAAA,GAAeA,SAAQ,eAAA,EAAgB;AAC7C,QAAA,IAAI,CAAC,YAAA,EAAc;AACjB,UAAA,QAAA,CAAS,EAAE,IAAA,EAAM,cAAA,EAAgB,IAAA,EAAM,UAAA,EAAY,SAAS,KAAA,EAAO,MAAA,EAAQ,MAAA,CAAO,MAAA,EAAQ,CAAA;AAC1F,UAAA,wBAAA,IAA2B;AAC3B,UAAA,OAAO,IAAA;AAAA,QACT;AACA,QAAA,IAAI;AACF,UAAA,MAAM,aAAA,GAAgBA,QAAAA,CAAQ,sBAAA,EAAuB,IAAK,KAAA,CAAA;AAC1D,UAAA,MAAM,CAAA,GAAI,MAAM,MAAA,CAAO,SAAA,CAAU,OAAA,CAAQ;AAAA,YACvC,YAAA;AAAA,YACA,GAAI,aAAA,GAAgB,EAAE,aAAA,KAAkB;AAAC,WAC1C,CAAA;AACD,UAAAA,QAAAA,CAAQ,gBAAA,CAAiB,CAAA,CAAE,aAAa,CAAA;AACxC,UAAA,IAAI,EAAE,YAAA,EAAcA,QAAAA,CAAQ,eAAA,CAAgB,EAAE,YAAY,CAAA;AAC1D,UAAA,QAAA,CAAS,EAAE,IAAA,EAAM,cAAA,EAAgB,IAAA,EAAM,UAAA,EAAY,SAAS,IAAA,EAAM,MAAA,EAAQ,MAAA,CAAO,MAAA,EAAQ,CAAA;AACzF,UAAA,OAAO,CAAA,CAAE,aAAA;AAAA,QACX,CAAA,CAAA,MAAQ;AACN,UAAA,QAAA,CAAS,EAAE,IAAA,EAAM,cAAA,EAAgB,IAAA,EAAM,UAAA,EAAY,SAAS,KAAA,EAAO,MAAA,EAAQ,MAAA,CAAO,MAAA,EAAQ,CAAA;AAC1F,UAAA,wBAAA,IAA2B;AAC3B,UAAA,OAAO,IAAA;AAAA,QACT;AAAA,MACF;AAAA,KACD,CAAA;AACD,IAAA,OAAO,MAAM,MAAA,CAAO,yBAAA,CAA0B,IAAI,CAAA;AAAA,EACpD,CAAA,EAAG,CAAC,wBAAA,EAA0B,MAAA,EAAQ,MAAM,OAAA,EAAS,QAAA,EAAU,wBAAwB,CAAC,CAAA;AAExF,EAAA,uBACEF,cAAAA,CAAC,cAAA,CAAe,UAAf,EAAwB,KAAA,EACvB,0BAAAA,cAAAA,CAAC,uBAAA,CAAwB,QAAA,EAAxB,EAAiC,OAAO,cAAA,EACvC,QAAA,kBAAAA,eAACG,8BAAA,EAAA,EAAoB,MAAA,EAAQ,IAC3B,QAAA,kBAAAH,cAAAA;AAAA,IAAC,mBAAA;AAAA,IAAA;AAAA,MACC,MAAA;AAAA,MACA,SAAS,KAAA,CAAM,OAAA;AAAA,MACd,GAAI,eAAA,KAAoB,MAAA,GAAY,EAAE,eAAA,KAAoB,EAAC;AAAA,MAE5D,QAAA,kBAAAA,cAAAA;AAAA,QAAC,sBAAA;AAAA,QAAA;AAAA,UACC,MAAA;AAAA,UACA,SAAS,KAAA,CAAM,OAAA;AAAA,UACd,GAAI,0BAAA,KAA+B,MAAA,GAChC,EAAE,0BAAA,KACF,EAAC;AAAA,UAEJ;AAAA;AAAA;AACH;AAAA,GACF,EACF,GACF,CAAA,EACF,CAAA;AAEJ;AAMA,SAAS,mBAAA,CAAoB;AAAA,EAC3B,MAAA;AAAA,EACA,OAAA;AAAA,EACA,eAAA;AAAA,EACA;AACF,CAAA,EAKsB;AACpB,EAAA,MAAM,KAAKP,yBAAAA,EAAe;AAC1B,EAAA,MAAM,CAAC,QAAA,EAAU,gBAAgB,CAAA,GAAIC,eAAwB,MAAM;AACjE,IAAA,IAAI,eAAA,KAAoB,QAAW,OAAO,eAAA;AAC1C,IAAA,MAAM,WAAA,GAAc,QAAQ,WAAA,EAAY;AACxC,IAAA,IAAI,WAAA,KAAgB,MAAM,OAAO,WAAA;AACjC,IAAA,OAAO,MAAA,CAAO,MAAA,EAAQ,WAAA,EAAa,UAAA,EAAY,SAAS,QAAA,IAAY,IAAA;AAAA,EACtE,CAAC,CAAA;AACD,EAAA,MAAM,CAAC,QAAA,EAAU,WAAW,CAAA,GAAIA,eAAwB,IAAI,CAAA;AAC5D,EAAA,MAAM,CAAC,cAAA,EAAgB,iBAAiB,CAAA,GAAIA,eAAwB,IAAI,CAAA;AACxE,EAAA,MAAM,CAAC,WAAA,EAAa,cAAc,CAAA,GAAIA,eAAS,KAAK,CAAA;AACpD,EAAA,MAAM,CAAC,WAAA,EAAa,cAAc,CAAA,GAAIA,eAAuB,IAAI,CAAA;AAIjE,EAAAI,gBAAU,MAAM;AACd,IAAA,IAAI,CAAC,QAAA,IAAY,QAAA,KAAa,IAAA,EAAM;AACpC,IAAA,IAAI,SAAA,GAAY,KAAA;AAChB,IAAA,MAAM,KAAA,GAAQ,QAAQ,gBAAA,EAAiB;AACvC,IAAA,MAAM,UAAU,KAAA,GAAQD,eAAAA,CAAK,SAAS,KAAK,CAAA,GAAIA,gBAAK,SAAA,EAAU;AAC9D,IAAA,EAAA,CAAG,UAAA,CAAW;AAAA,MACZ,QAAA,EAAU;AAAA,QACR,SAAA;AAAA,QACA,cAAA;AAAA,QACA,QAAA;AAAA,QACA,EAAE,MAAA,EAAQ,MAAA,CAAO,MAAA,EAAQ,QAAA,EAAU,QAAQ,IAAA;AAAK,OAClD;AAAA,MACA,SAAS,MAAM,MAAA,CAAO,KAAA,CAAM,GAAA,CAAI,UAAU,OAAO,CAAA;AAAA,MACjD,WAAW,CAAA,GAAI;AAAA,KAChB,CAAA,CACE,IAAA,CAAK,CAAC,IAAA,KAAS;AACd,MAAA,IAAI,SAAA,EAAW;AACf,MAAA,WAAA,CAAY,KAAK,QAAQ,CAAA;AACzB,MAAA,iBAAA,CAAkB,IAAA,CAAK,QAAA,EAAU,OAAA,EAAS,OAAA,IAAW,IAAI,CAAA;AAAA,IAC3D,CAAC,CAAA,CACA,KAAA,CAAM,MAAM;AAAA,IAEb,CAAC,CAAA;AACH,IAAA,OAAO,MAAM;AACX,MAAA,SAAA,GAAY,IAAA;AAAA,IACd,CAAA;AAAA,EAEF,CAAA,EAAG,CAAC,QAAQ,CAAC,CAAA;AAEb,EAAA,MAAM,OAAA,GAAUD,iBAAAA;AAAA,IACd,OAAO,IAAA,KAAwB;AAE7B,MAAA,OAAA,CAAQ,YAAY,IAAI,CAAA;AACxB,MAAA,OAAA,CAAQ,UAAU,IAAI,CAAA;AACtB,MAAA,gBAAA,CAAiB,IAAI,CAAA;AACrB,MAAA,cAAA,CAAe,IAAI,CAAA;AACnB,MAAA,KAAK,GAAG,iBAAA,CAAkB,EAAE,UAAU,CAAC,SAAS,GAAG,CAAA;AAEnD,MAAA,IAAI,SAAS,IAAA,EAAM;AACjB,QAAA,WAAA,CAAY,IAAI,CAAA;AAChB,QAAA,iBAAA,CAAkB,IAAI,CAAA;AACtB,QAAA;AAAA,MACF;AAEA,MAAA,cAAA,CAAe,IAAI,CAAA;AACnB,MAAA,IAAI;AACF,QAAA,MAAM,KAAA,GAAQ,QAAQ,gBAAA,EAAiB;AACvC,QAAA,MAAM,UAAU,KAAA,GAAQC,eAAAA,CAAK,SAAS,KAAK,CAAA,GAAIA,gBAAK,SAAA,EAAU;AAE9D,QAAA,MAAM,IAAA,GAAO,MAAM,EAAA,CAAG,UAAA,CAAW;AAAA,UAC/B,QAAA,EAAU;AAAA,YACR,SAAA;AAAA,YACA,cAAA;AAAA,YACA,IAAA;AAAA,YACA,EAAE,MAAA,EAAQ,MAAA,CAAO,MAAA,EAAQ,QAAA,EAAU,QAAQ,IAAA;AAAK,WAClD;AAAA,UACA,SAAS,MAAM,MAAA,CAAO,KAAA,CAAM,GAAA,CAAI,MAAM,OAAO,CAAA;AAAA,UAC7C,WAAW,CAAA,GAAI;AAAA,SAChB,CAAA;AACD,QAAA,MAAM,eAAe,IAAA,CAAK,QAAA;AAC1B,QAAA,MAAM,UAAA,GAAa,IAAA,CAAK,QAAA,EAAU,OAAA,EAAS,OAAA,IAAW,IAAA;AACtD,QAAA,WAAA,CAAY,YAAY,CAAA;AACxB,QAAA,iBAAA,CAAkB,UAAU,CAAA;AAE5B,QAAA,MAAM,OAAO,cAAA,CAAe,KAAA;AAAA,UAC1B;AAAA,YACE,QAAA,EAAU,IAAA;AAAA,YACV,GAAI,YAAA,GAAe,EAAE,QAAA,EAAU,YAAA,KAAiB,EAAC;AAAA,YACjD,GAAI,UAAA,GAAa,EAAE,cAAA,EAAgB,UAAA,KAAe;AAAC,WACrD;AAAA,UACA;AAAA,SACF;AAAA,MACF,SAAS,CAAA,EAAG;AACV,QAAA,cAAA,CAAe,CAAA,YAAa,QAAQ,CAAA,GAAI,IAAI,MAAM,MAAA,CAAO,CAAC,CAAC,CAAC,CAAA;AAAA,MAC9D,CAAA,SAAE;AACA,QAAA,cAAA,CAAe,KAAK,CAAA;AAAA,MACtB;AAAA,IACF,CAAA;AAAA,IACA,CAAC,MAAA,EAAQ,OAAA,EAAS,EAAE;AAAA,GACtB;AAEA,EAAA,MAAM,KAAA,GAAQE,aAAAA;AAAA,IACZ,OAAO;AAAA,MACL,QAAA;AAAA,MACA,QAAA;AAAA,MACA,cAAA;AAAA,MACA,OAAA;AAAA,MACA,WAAA;AAAA,MACA;AAAA,KACF,CAAA;AAAA,IACA,CAAC,QAAA,EAAU,QAAA,EAAU,cAAA,EAAgB,OAAA,EAAS,aAAa,WAAW;AAAA,GACxE;AAEA,EAAA,uBAAOC,cAAAA,CAAC,kBAAA,CAAmB,QAAA,EAAnB,EAA4B,OAAe,QAAA,EAAS,CAAA;AAC9D;AAGO,SAAS,UAAA,GAAkC;AAChD,EAAA,MAAM,GAAA,GAAMR,iBAAW,cAAc,CAAA;AACrC,EAAA,IAAI,CAAC,GAAA,EAAK,MAAM,IAAI,MAAM,mDAAmD,CAAA;AAC7E,EAAA,OAAO,GAAA;AACT","file":"provider.cjs","sourcesContent":["/** Pluggable persistence for SDK session state. SSR-safe by default (memory). */\nexport interface EmporixStorage {\n // Customer token (unchanged).\n getCustomerToken(): string | null;\n setCustomerToken(token: string | null): void;\n subscribe?(listener: (token: string | null) => void): () => void;\n\n // Active guest / customer cart id.\n getCartId(): string | null;\n setCartId(id: string | null): void;\n\n // Anonymous session — used by DefaultTokenProvider (via EmporixProvider\n // wiring) to preserve sessionId across page reloads.\n getAnonymousSession(): PersistedAnonymousSession | null;\n setAnonymousSession(session: PersistedAnonymousSession | null): void;\n\n // Active site code (MS-2). `null` = no site bound yet.\n getSiteCode(): string | null;\n setSiteCode(code: string | null): void;\n\n // Active legal entity id (B2B). `null` = B2C mode.\n getActiveLegalEntityId(): string | null;\n setActiveLegalEntityId(id: string | null): void;\n\n // Refresh token — optional persistence. When absent, B2B company-switch\n // falls back to a local-state-only update (no server-side token rescope).\n getRefreshToken(): string | null;\n setRefreshToken(token: string | null): void;\n\n /**\n * Subscribe to any storage write. The listener receives the key that\n * changed. Returns an unsubscribe function. Optional — backends may no-op.\n * Used by the telemetry layer to emit `storage.write` events.\n */\n subscribeAll?(\n listener: (key: EmporixStorageKey) => void,\n ): () => void;\n}\n\n/** Minimal subset of `AnonymousSession` that needs to outlive a page load. */\nexport interface PersistedAnonymousSession {\n refreshToken: string;\n sessionId: string;\n}\n\n/** Backward-compat alias. New code should prefer `EmporixStorage`. */\nexport type TokenStorage = EmporixStorage;\n\n/** Keys that participate in {@link EmporixStorage.subscribeAll}. */\nexport type EmporixStorageKey =\n | \"customerToken\"\n | \"cartId\"\n | \"siteCode\"\n | \"anonymousSession\"\n | \"activeLegalEntityId\"\n | \"refreshToken\";\n\n/**\n * Internal: create a swallow-on-throw listener set used by all three storage\n * backends for `subscribeAll`. Centralizes the try/catch wrapper so a buggy\n * telemetry handler never breaks a storage write.\n */\nexport function createListenerSet<T>(): {\n add(l: (value: T) => void): () => void;\n notify(value: T): void;\n} {\n const listeners = new Set<(v: T) => void>();\n return {\n add(l) {\n listeners.add(l);\n return () => listeners.delete(l);\n },\n notify(value) {\n for (const l of listeners) {\n try {\n l(value);\n } catch {\n // Swallow handler errors; telemetry must never break writes.\n }\n }\n },\n };\n}\n\n/**\n * Internal: parses a raw `anonymousSession` JSON payload (from localStorage\n * or a cookie) into a {@link PersistedAnonymousSession}. Returns `null` for\n * any malformed or missing input.\n */\nexport function parseAnonymousSession(raw: string | null): PersistedAnonymousSession | null {\n if (!raw) return null;\n try {\n const parsed = JSON.parse(raw) as Partial<PersistedAnonymousSession>;\n if (typeof parsed.refreshToken === \"string\" && typeof parsed.sessionId === \"string\") {\n return { refreshToken: parsed.refreshToken, sessionId: parsed.sessionId };\n }\n return null;\n } catch {\n return null;\n }\n}\n\nexport { createMemoryStorage } from \"./memory\";\nexport { createLocalStorageStorage } from \"./local-storage\";\nexport { createCookieStorage } from \"./cookie\";\n","import {\n createListenerSet,\n type EmporixStorage,\n type EmporixStorageKey,\n type PersistedAnonymousSession,\n} from \"./index\";\n\n/** In-memory token store. Default, SSR-safe, no persistence. */\nexport function createMemoryStorage(opts: { initial?: string } = {}): EmporixStorage {\n let token: string | null = opts.initial ?? null;\n let cartId: string | null = null;\n let anon: PersistedAnonymousSession | null = null;\n let siteCode: string | null = null;\n let activeLegalEntityId: string | null = null;\n let refreshToken: string | null = null;\n const tokenListeners = new Set<(t: string | null) => void>();\n const all = createListenerSet<EmporixStorageKey>();\n return {\n getCustomerToken: () => token,\n setCustomerToken: (t) => {\n token = t;\n for (const l of tokenListeners) l(token);\n all.notify(\"customerToken\");\n },\n subscribe: (l) => {\n tokenListeners.add(l);\n return () => tokenListeners.delete(l);\n },\n getCartId: () => cartId,\n setCartId: (id) => {\n cartId = id;\n all.notify(\"cartId\");\n },\n getAnonymousSession: () => anon,\n setAnonymousSession: (s) => {\n anon = s;\n all.notify(\"anonymousSession\");\n },\n getSiteCode: () => siteCode,\n setSiteCode: (code) => {\n siteCode = code;\n all.notify(\"siteCode\");\n },\n getActiveLegalEntityId: () => activeLegalEntityId,\n setActiveLegalEntityId: (id) => {\n activeLegalEntityId = id;\n all.notify(\"activeLegalEntityId\");\n },\n getRefreshToken: () => refreshToken,\n setRefreshToken: (t) => {\n refreshToken = t;\n all.notify(\"refreshToken\");\n },\n subscribeAll: (l) => all.add(l),\n };\n}\n","import { createContext, useContext } from \"react\";\n\n/**\n * All telemetry events emitted through the EmporixProvider's `onTelemetry`\n * callback. Discriminated by `type` — exhaustive switch is type-safe.\n *\n * Consumers can emit their own `{ type: \"custom\" }` events via\n * {@link useEmporixTelemetry}. Namespace `name` with an app-specific\n * prefix (e.g. `\"app.checkout-cta-click\"`) to avoid collisions with\n * future SDK event types.\n */\nexport type EmporixTelemetryEvent =\n // Cache lifecycle (React-Query QueryCache)\n | { type: \"cache.hit\"; queryKey: readonly unknown[]; tenant: string }\n | {\n type: \"cache.miss\";\n queryKey: readonly unknown[];\n tenant: string;\n durationMs: number;\n }\n | {\n type: \"query.refetch\";\n queryKey: readonly unknown[];\n tenant: string;\n reason: \"invalidate\" | \"focus\" | \"stale\";\n }\n | {\n type: \"query.error\";\n queryKey: readonly unknown[];\n tenant: string;\n error: unknown;\n }\n // Mutation lifecycle\n | {\n type: \"mutation.success\";\n mutationKey?: readonly unknown[];\n tenant: string;\n durationMs: number;\n }\n | {\n type: \"mutation.error\";\n mutationKey?: readonly unknown[];\n tenant: string;\n error: unknown;\n durationMs: number;\n }\n // Auth refresh (SDK-side)\n | {\n type: \"auth.refresh\";\n kind: \"anonymous\" | \"customer\";\n tenant: string;\n success: boolean;\n }\n // Storage writes\n | {\n type: \"storage.write\";\n key: \"customerToken\" | \"cartId\" | \"siteCode\" | \"anonymousSession\" | \"activeLegalEntityId\" | \"refreshToken\";\n }\n // Active-company switch (B2B)\n | {\n type: \"company:switched\";\n from: string | null;\n to: string | null;\n durationMs: number;\n }\n // Consumer-emitted\n | { type: \"custom\"; name: string; props?: Record<string, unknown> };\n\n/** Internal: the React context carrying the emit function down the tree. */\nexport const EmporixTelemetryContext = createContext<{\n emit: (event: EmporixTelemetryEvent) => void;\n} | null>(null);\n\n/**\n * Hook to emit custom telemetry events through the same channel as SDK\n * events. Throws when used outside an {@link EmporixProvider}.\n *\n * When the provider has no `onTelemetry` callback configured, `emit` is a\n * no-op — calling it is safe and incurs no overhead.\n */\nexport function useEmporixTelemetry(): {\n emit: (event: EmporixTelemetryEvent) => void;\n} {\n const ctx = useContext(EmporixTelemetryContext);\n if (!ctx) {\n throw new Error(\"useEmporixTelemetry must be used within an EmporixProvider\");\n }\n return ctx;\n}\n","import {\n createContext,\n useCallback,\n useContext,\n useEffect,\n useMemo,\n useRef,\n useState,\n type ReactNode,\n} from \"react\";\nimport { useQueryClient } from \"@tanstack/react-query\";\nimport { auth, type EmporixClient, type LegalEntity } from \"@viu/emporix-sdk\";\nimport type { EmporixStorage } from \"./storage\";\nimport { useEmporixTelemetry } from \"./telemetry\";\n\nexport type CompanyMode = \"b2c\" | \"b2b\" | \"unresolved\";\n\nexport interface CompanyContextValue {\n /** Active legal entity. `null` = B2C mode. */\n activeCompany: LegalEntity | null;\n /** All legal entities the customer is assigned to. */\n myCompanies: LegalEntity[];\n /**\n * `b2b` = a company is active; `b2c` = none active (and ≤1 available);\n * `unresolved` = multiple companies available, none picked yet — the\n * storefront must render a picker.\n */\n mode: CompanyMode;\n status: \"idle\" | \"loading\" | \"switching\" | \"error\";\n error: unknown;\n /**\n * Switch the active company. Eagerly calls\n * `client.customers.refresh({ legalEntityId })` so the customer token is\n * rescoped server-side, drops the cart id, then invalidates company-scoped\n * queries. Falls back to a local-state-only update when no refresh token\n * is in storage (e.g. fresh page load with memory storage).\n */\n setActiveCompany: (legalEntityId: string | null) => Promise<void>;\n refetchMyCompanies: () => Promise<void>;\n}\n\nconst NULL_CTX: CompanyContextValue = {\n activeCompany: null,\n myCompanies: [],\n mode: \"b2c\",\n status: \"idle\",\n error: null,\n setActiveCompany: async () => {\n throw new Error(\"CompanyContextProvider not mounted\");\n },\n refetchMyCompanies: async () => {},\n};\n\nexport const EmporixCompanyContext = createContext<CompanyContextValue>(NULL_CTX);\n\n/** Returns the active-company context. Safe outside the provider — returns idle B2C defaults. */\nexport function useActiveCompany(): CompanyContextValue {\n return useContext(EmporixCompanyContext);\n}\n\nexport interface CompanyContextProviderProps {\n client: EmporixClient;\n storage: EmporixStorage;\n initialActiveLegalEntityId?: string | null;\n children: ReactNode;\n}\n\nexport function CompanyContextProvider({\n client,\n storage,\n initialActiveLegalEntityId,\n children,\n}: CompanyContextProviderProps): React.JSX.Element {\n const qc = useQueryClient();\n const { emit } = useEmporixTelemetry();\n const [myCompanies, setMyCompanies] = useState<LegalEntity[]>([]);\n const [activeCompany, setActive] = useState<LegalEntity | null>(null);\n const [status, setStatus] = useState<CompanyContextValue[\"status\"]>(\"idle\");\n const [error, setError] = useState<unknown>(null);\n // Ref so switchTo can capture the latest `activeCompany` for telemetry `from`.\n const activeRef = useRef<LegalEntity | null>(null);\n activeRef.current = activeCompany;\n\n /** Internal: eager refresh + storage write + state update. */\n const switchTo = useCallback(\n async (target: LegalEntity | null) => {\n const start = Date.now();\n const from = activeRef.current?.id ?? null;\n const refreshToken = storage.getRefreshToken();\n const token = storage.getCustomerToken();\n if (!refreshToken || !token) {\n // Local-state-only fallback — no rescope possible.\n setActive(target);\n storage.setActiveLegalEntityId(target?.id ?? null);\n } else {\n const next = await client.customers.refresh({\n refreshToken,\n ...(target ? { legalEntityId: target.id } : {}),\n });\n storage.setCustomerToken(next.customerToken);\n if (next.refreshToken) storage.setRefreshToken(next.refreshToken);\n storage.setCartId(null);\n storage.setActiveLegalEntityId(target?.id ?? null);\n setActive(target);\n qc.invalidateQueries({\n predicate: (q) =>\n Array.isArray(q.queryKey) &&\n q.queryKey.some(\n (k) =>\n k === \"cart\" ||\n k === \"companies\" ||\n k === \"customer\" ||\n k === from ||\n (target !== null && k === target.id),\n ),\n });\n }\n emit({\n type: \"company:switched\",\n from,\n to: target?.id ?? null,\n durationMs: Date.now() - start,\n });\n },\n [client, storage, qc, emit],\n );\n\n const load = useCallback(async () => {\n const token = storage.getCustomerToken();\n if (!token) {\n setMyCompanies([]);\n setActive(null);\n setStatus(\"idle\");\n return;\n }\n setStatus(\"loading\");\n try {\n const companies = await client.companies.listMine(auth.customer(token));\n setMyCompanies(companies);\n const persisted = initialActiveLegalEntityId ?? storage.getActiveLegalEntityId();\n const matched = persisted ? companies.find((c) => c.id === persisted) ?? null : null;\n if (matched) {\n setActive(matched);\n if (storage.getActiveLegalEntityId() !== matched.id) {\n storage.setActiveLegalEntityId(matched.id ?? null);\n }\n } else if (companies.length === 1) {\n await switchTo(companies[0] ?? null);\n } else {\n setActive(null);\n if (persisted && !matched) storage.setActiveLegalEntityId(null);\n }\n setStatus(\"idle\");\n } catch (e) {\n setError(e);\n setStatus(\"error\");\n }\n }, [client, storage, initialActiveLegalEntityId, switchTo]);\n\n useEffect(() => {\n void load();\n }, [load]);\n\n // Re-run bootstrap only on token-presence transitions (login/logout). A\n // mid-session token swap (e.g. switch-driven refresh) keeps prev/next both\n // truthy and is ignored — otherwise the auto-pick branch would clobber an\n // explicit B2C choice as soon as the new token is written.\n useEffect(() => {\n let prev = storage.getCustomerToken();\n return storage.subscribe?.((next) => {\n const becameAuth = !prev && next;\n const becameUnauth = prev && !next;\n prev = next;\n if (becameAuth || becameUnauth) void load();\n });\n }, [storage, load]);\n\n const setActiveCompany = useCallback(\n async (legalEntityId: string | null) => {\n setStatus(\"switching\");\n try {\n if (legalEntityId === null) {\n await switchTo(null);\n } else {\n const target = myCompanies.find((c) => c.id === legalEntityId) ?? null;\n if (!target) throw new Error(`setActiveCompany: unknown legalEntityId ${legalEntityId}`);\n await switchTo(target);\n }\n setStatus(\"idle\");\n } catch (e) {\n setError(e);\n setStatus(\"error\");\n throw e;\n }\n },\n [myCompanies, switchTo],\n );\n\n const value = useMemo<CompanyContextValue>(() => {\n const mode: CompanyMode = activeCompany\n ? \"b2b\"\n : myCompanies.length > 1\n ? \"unresolved\"\n : \"b2c\";\n return {\n activeCompany,\n myCompanies,\n mode,\n status,\n error,\n setActiveCompany,\n refetchMyCompanies: load,\n };\n }, [activeCompany, myCompanies, status, error, setActiveCompany, load]);\n\n return (\n <EmporixCompanyContext.Provider value={value}>{children}</EmporixCompanyContext.Provider>\n );\n}\n","import { createContext, useCallback, useContext, useEffect, useMemo, useState, type ReactNode } from \"react\";\nimport { QueryClient, QueryClientProvider, useQueryClient } from \"@tanstack/react-query\";\nimport { auth, type EmporixClient } from \"@viu/emporix-sdk\";\nimport type { EmporixStorage } from \"./storage/index\";\nimport { createMemoryStorage } from \"./storage/memory\";\nimport { EmporixTelemetryContext, type EmporixTelemetryEvent } from \"./telemetry\";\nimport { CompanyContextProvider } from \"./company-context\";\n\ninterface EmporixContextValue {\n client: EmporixClient;\n storage: EmporixStorage;\n}\n\nexport interface SiteContextValue {\n siteCode: string | null;\n /** MS-4 populates this from the active site's DTO. */\n currency: string | null;\n /** MS-4 populates this from the active site's DTO. */\n targetLocation: string | null;\n /**\n * Asynchronous site switch. Updates local state + storage immediately\n * (optimistic), then PATCHes `/session-context/{tenant}/me/context` so\n * the server sees the same site on the next request. When no session\n * context exists yet (first visit, before any cart), the PATCH is\n * skipped — local state still flips.\n *\n * `isSwitching` is `true` while the PATCH is in flight. `switchError`\n * surfaces a PATCH failure; the optimistic state is NOT rolled back\n * (the cache was already invalidated, the UI already moved on).\n */\n setSite: (code: string | null) => Promise<void>;\n isSwitching: boolean;\n switchError: Error | null;\n}\n\nconst EmporixContext = createContext<EmporixContextValue | null>(null);\nexport const EmporixSiteContext = createContext<SiteContextValue | null>(null);\n\n/**\n * Balanced React-Query defaults applied to the provider's fallback QueryClient\n * (only when no `queryClient` prop is passed). Keeps the Emporix API-quota in\n * check by suppressing window-focus refetches and capping retries.\n */\nconst DEFAULT_QUERY_OPTIONS = {\n staleTime: 30_000,\n refetchOnWindowFocus: false,\n retry: 1,\n} as const;\n\n/** Props for {@link EmporixProvider}. */\nexport interface EmporixProviderProps {\n client: EmporixClient;\n queryClient?: QueryClient;\n storage?: EmporixStorage;\n initialCustomerToken?: string;\n /**\n * Initial site code. Resolution order: this prop → `storage.getSiteCode()` →\n * `client.config.credentials.storefront.context.siteCode` → `null`.\n */\n initialSiteCode?: string;\n /**\n * Initial active legal-entity id (B2B). When set, the CompanyContext\n * provider tries to match it against `companies.listMine()` once the\n * customer is loaded; mismatches are dropped silently.\n */\n initialActiveLegalEntityId?: string | null;\n /**\n * Opt-in telemetry callback. Receives a typed event stream covering cache\n * hit/miss, refetches, errors, mutations, auth refreshes, storage writes,\n * and consumer-emitted custom events. Wire this to Datadog/Sentry/custom\n * analytics. The handler is wrapped in try/catch — a throwing handler\n * never breaks the provider.\n */\n onTelemetry?: (event: EmporixTelemetryEvent) => void;\n /**\n * Opt in to reactive customer-token auto-refresh: on a `customer`-kind 401,\n * the SDK refreshes once (via the stored refresh token + anonymous auth) and\n * retries. Default: false (the customer token stays caller-owned).\n */\n autoRefreshCustomerToken?: boolean;\n /**\n * Called when a customer-token refresh is needed but fails (refresh token\n * expired/revoked) or no refresh token is stored. Use to drive logout /\n * redirect to login.\n */\n onCustomerSessionExpired?: () => void;\n children: ReactNode;\n}\n\n/** Provides the SDK client, token storage, react-query client, and site context to the tree. */\nexport function EmporixProvider({\n client,\n queryClient,\n storage,\n initialCustomerToken,\n initialSiteCode,\n initialActiveLegalEntityId,\n onTelemetry,\n autoRefreshCustomerToken,\n onCustomerSessionExpired,\n children,\n}: EmporixProviderProps): React.JSX.Element {\n const value = useMemo<EmporixContextValue>(() => {\n const s =\n storage ??\n createMemoryStorage(\n initialCustomerToken !== undefined ? { initial: initialCustomerToken } : {},\n );\n if (initialCustomerToken && storage && storage.getCustomerToken() === null) {\n storage.setCustomerToken(initialCustomerToken);\n }\n return { client, storage: s };\n \n }, [client, storage, initialCustomerToken]);\n const qc = useMemo(\n () =>\n queryClient ??\n new QueryClient({ defaultOptions: { queries: DEFAULT_QUERY_OPTIONS } }),\n [queryClient],\n );\n\n // Idempotent one-time wiring: attaches a storage-backed adapter to the SDK's\n // token provider so anonymous sessions survive reloads. Runs once per\n // (client, storage) pair via useState's lazy initializer.\n useState(() => {\n client.tokenProvider.attachAnonymousStore?.({\n read: () => value.storage.getAnonymousSession(),\n write: (s) => value.storage.setAnonymousSession(s),\n });\n return null;\n });\n\n // Telemetry: stable safeEmit + context value. emit is no-op when no\n // onTelemetry callback was provided (no overhead).\n const safeEmit = useCallback(\n (event: EmporixTelemetryEvent) => {\n if (!onTelemetry) return;\n try {\n onTelemetry(event);\n } catch (err) {\n // eslint-disable-next-line no-console\n console.error(\"[emporix] telemetry handler threw:\", err);\n }\n },\n [onTelemetry],\n );\n const telemetryValue = useMemo(() => ({ emit: safeEmit }), [safeEmit]);\n\n // Source subscriptions: cache + mutation cache + token-provider + storage.\n // All only active when onTelemetry is provided.\n useEffect(() => {\n if (!onTelemetry) return;\n const startedAt = new Map<string, number>();\n\n const unsubQuery = qc.getQueryCache().subscribe((event) => {\n const key = event.query.queryKey;\n if (!Array.isArray(key) || key[0] !== \"emporix\") return;\n if (event.type === \"updated\") {\n const action = event.action as { type: string };\n if (action.type === \"fetch\") {\n const isRefetch = event.query.state.dataUpdateCount > 0;\n if (isRefetch) {\n safeEmit({\n type: \"query.refetch\",\n queryKey: key,\n tenant: client.tenant,\n reason: \"invalidate\",\n });\n }\n startedAt.set(event.query.queryHash, Date.now());\n } else if (action.type === \"success\") {\n const start = startedAt.get(event.query.queryHash);\n startedAt.delete(event.query.queryHash);\n safeEmit({\n type: \"cache.miss\",\n queryKey: key,\n tenant: client.tenant,\n durationMs: start ? Date.now() - start : 0,\n });\n } else if (action.type === \"error\") {\n startedAt.delete(event.query.queryHash);\n safeEmit({\n type: \"query.error\",\n queryKey: key,\n tenant: client.tenant,\n error: event.query.state.error,\n });\n }\n } else if (event.type === \"observerResultsUpdated\") {\n const s = event.query.state;\n if (s.status === \"success\" && s.fetchStatus === \"idle\" && s.dataUpdateCount > 0) {\n safeEmit({ type: \"cache.hit\", queryKey: key, tenant: client.tenant });\n }\n }\n });\n\n const unsubMut = qc.getMutationCache().subscribe((event) => {\n if (event.type !== \"updated\") return;\n const m = event.mutation;\n const dur = Date.now() - (m.state.submittedAt ?? Date.now());\n const mk = m.options.mutationKey;\n if (m.state.status === \"success\") {\n safeEmit({\n type: \"mutation.success\",\n ...(mk ? { mutationKey: mk as readonly unknown[] } : {}),\n tenant: client.tenant,\n durationMs: dur,\n });\n } else if (m.state.status === \"error\") {\n safeEmit({\n type: \"mutation.error\",\n ...(mk ? { mutationKey: mk as readonly unknown[] } : {}),\n tenant: client.tenant,\n error: m.state.error,\n durationMs: dur,\n });\n }\n });\n\n const unsubAuth = client.tokenProvider.onRefresh?.((evt) =>\n safeEmit({ type: \"auth.refresh\", ...evt, tenant: client.tenant }),\n );\n\n const unsubStorage = value.storage.subscribeAll?.((key) =>\n safeEmit({ type: \"storage.write\", key }),\n );\n\n return () => {\n unsubQuery();\n unsubMut();\n unsubAuth?.();\n unsubStorage?.();\n };\n }, [qc, onTelemetry, client, value.storage, safeEmit]);\n\n // Opt-in reactive customer-token auto-refresh. Registered on the client so\n // the core HttpClient can refresh-and-retry a customer 401. Single-flight is\n // handled in the core registry. Off unless `autoRefreshCustomerToken`.\n useEffect(() => {\n if (!autoRefreshCustomerToken) return;\n const storage = value.storage;\n client.setCustomerTokenRefresher({\n refresh: async () => {\n const refreshToken = storage.getRefreshToken();\n if (!refreshToken) {\n safeEmit({ type: \"auth.refresh\", kind: \"customer\", success: false, tenant: client.tenant });\n onCustomerSessionExpired?.();\n return null;\n }\n try {\n const legalEntityId = storage.getActiveLegalEntityId() ?? undefined;\n const s = await client.customers.refresh({\n refreshToken,\n ...(legalEntityId ? { legalEntityId } : {}),\n });\n storage.setCustomerToken(s.customerToken);\n if (s.refreshToken) storage.setRefreshToken(s.refreshToken);\n safeEmit({ type: \"auth.refresh\", kind: \"customer\", success: true, tenant: client.tenant });\n return s.customerToken;\n } catch {\n safeEmit({ type: \"auth.refresh\", kind: \"customer\", success: false, tenant: client.tenant });\n onCustomerSessionExpired?.();\n return null;\n }\n },\n });\n return () => client.setCustomerTokenRefresher(null);\n }, [autoRefreshCustomerToken, client, value.storage, safeEmit, onCustomerSessionExpired]);\n\n return (\n <EmporixContext.Provider value={value}>\n <EmporixTelemetryContext.Provider value={telemetryValue}>\n <QueryClientProvider client={qc}>\n <SiteContextProvider\n client={client}\n storage={value.storage}\n {...(initialSiteCode !== undefined ? { initialSiteCode } : {})}\n >\n <CompanyContextProvider\n client={client}\n storage={value.storage}\n {...(initialActiveLegalEntityId !== undefined\n ? { initialActiveLegalEntityId }\n : {})}\n >\n {children}\n </CompanyContextProvider>\n </SiteContextProvider>\n </QueryClientProvider>\n </EmporixTelemetryContext.Provider>\n </EmporixContext.Provider>\n );\n}\n\n/**\n * Manages the active-site state. Sits inside `QueryClientProvider` so\n * `setSite` can invalidate the React-Query cache on switch.\n */\nfunction SiteContextProvider({\n client,\n storage,\n initialSiteCode,\n children,\n}: {\n client: EmporixClient;\n storage: EmporixStorage;\n initialSiteCode?: string;\n children: ReactNode;\n}): React.JSX.Element {\n const qc = useQueryClient();\n const [siteCode, setSiteCodeState] = useState<string | null>(() => {\n if (initialSiteCode !== undefined) return initialSiteCode;\n const fromStorage = storage.getSiteCode();\n if (fromStorage !== null) return fromStorage;\n return client.config?.credentials?.storefront?.context?.siteCode ?? null;\n });\n const [currency, setCurrency] = useState<string | null>(null);\n const [targetLocation, setTargetLocation] = useState<string | null>(null);\n const [isSwitching, setIsSwitching] = useState(false);\n const [switchError, setSwitchError] = useState<Error | null>(null);\n\n // Mount-time derivation: if a siteCode is already resolved, fetch its DTO\n // once so currency + targetLocation populate without a user-driven switch.\n useEffect(() => {\n if (!siteCode || currency !== null) return;\n let cancelled = false;\n const token = storage.getCustomerToken();\n const authCtx = token ? auth.customer(token) : auth.anonymous();\n qc.fetchQuery({\n queryKey: [\n \"emporix\",\n \"site-by-code\",\n siteCode,\n { tenant: client.tenant, authKind: authCtx.kind },\n ],\n queryFn: () => client.sites.get(siteCode, authCtx),\n staleTime: 5 * 60_000,\n })\n .then((site) => {\n if (cancelled) return;\n setCurrency(site.currency);\n setTargetLocation(site.homeBase?.address?.country ?? null);\n })\n .catch(() => {\n // Best-effort — silent. setSite-driven derivation surfaces real errors.\n });\n return () => {\n cancelled = true;\n };\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [siteCode]);\n\n const setSite = useCallback(\n async (code: string | null) => {\n // 1) Optimistic flip — UI moves immediately.\n storage.setSiteCode(code);\n storage.setCartId(null);\n setSiteCodeState(code);\n setSwitchError(null);\n void qc.invalidateQueries({ queryKey: [\"emporix\"] });\n\n if (code === null) {\n setCurrency(null);\n setTargetLocation(null);\n return;\n }\n\n setIsSwitching(true);\n try {\n const token = storage.getCustomerToken();\n const authCtx = token ? auth.customer(token) : auth.anonymous();\n // 2) Derive currency + targetLocation from the site DTO (cached 5min).\n const site = await qc.fetchQuery({\n queryKey: [\n \"emporix\",\n \"site-by-code\",\n code,\n { tenant: client.tenant, authKind: authCtx.kind },\n ],\n queryFn: () => client.sites.get(code, authCtx),\n staleTime: 5 * 60_000,\n });\n const nextCurrency = site.currency;\n const nextTarget = site.homeBase?.address?.country ?? null;\n setCurrency(nextCurrency);\n setTargetLocation(nextTarget);\n // 3) Push everything into the session-context PATCH.\n await client.sessionContext.patch(\n {\n siteCode: code,\n ...(nextCurrency ? { currency: nextCurrency } : {}),\n ...(nextTarget ? { targetLocation: nextTarget } : {}),\n },\n authCtx,\n );\n } catch (e) {\n setSwitchError(e instanceof Error ? e : new Error(String(e)));\n } finally {\n setIsSwitching(false);\n }\n },\n [client, storage, qc],\n );\n\n const value = useMemo<SiteContextValue>(\n () => ({\n siteCode,\n currency,\n targetLocation,\n setSite,\n isSwitching,\n switchError,\n }),\n [siteCode, currency, targetLocation, setSite, isSwitching, switchError],\n );\n\n return <EmporixSiteContext.Provider value={value}>{children}</EmporixSiteContext.Provider>;\n}\n\n/** Returns the SDK client and token storage. Throws outside an {@link EmporixProvider}. */\nexport function useEmporix(): EmporixContextValue {\n const ctx = useContext(EmporixContext);\n if (!ctx) throw new Error(\"useEmporix must be used within an EmporixProvider\");\n return ctx;\n}\n"]}
package/dist/provider.js CHANGED
@@ -1,4 +1,4 @@
1
- export { EmporixProvider, EmporixSiteContext, useEmporix } from './chunk-SDRV73LG.js';
1
+ export { EmporixProvider, EmporixSiteContext, useEmporix } from './chunk-JZRSYM3W.js';
2
2
  import './chunk-FBQY2N7S.js';
3
3
  //# sourceMappingURL=provider.js.map
4
4
  //# sourceMappingURL=provider.js.map
@@ -1,4 +1,4 @@
1
- import { Customer, AuthContext, Product, PaginatedItems, ShoppingListItem, ShoppingListDraft, ShoppingList, Category, Cart, CartItemInput, CartItemUpdate, CartAddress, CartCreated, CreateCartInput, CheckoutResult, CheckoutInput, QuoteCheckoutInput, PaymentMode, PriceMatchByContextInput, PriceMatch, Media, SegmentCategoryTree, SegmentItem, Segment, PasswordChangeInput, CustomerUpdateInput, Address, AddressCreateInput, AddressUpdateInput, PasswordResetRequestInput, PasswordResetConfirmInput, Site, LegalEntity, ContactAssignment, Location, IamGroup, ContactAssignmentCreate, LegalEntityCreate, LocationCreate, LegalEntityUpdate, ContactAssignmentUpdate, LocationUpdate, OrderStatus, Order, SalesOrderPatch, Availability, RedemptionInput, RedemptionCreated, PointsSummary, RedeemOptionList, RedeemCouponResult, RedeemMyPointsInput, ReturnCreated, ReturnInput, ReturnList, Return } from '@viu/emporix-sdk';
1
+ import { Customer, AuthContext, Product, PaginatedItems, ShoppingListItem, ShoppingListDraft, ShoppingList, Category, Cart, CartItemInput, CartItemUpdate, CartAddress, CartCreated, CreateCartInput, CheckoutResult, CheckoutInput, QuoteCheckoutInput, PaymentMode, PriceMatchByContextInput, PriceMatch, Media, SegmentCategoryTree, SegmentItem, Segment, PasswordChangeInput, CustomerUpdateInput, Address, AddressCreateInput, AddressUpdateInput, PasswordResetRequestInput, PasswordResetConfirmInput, Site, LegalEntity, ContactAssignment, Location, IamGroup, IamGroupMemberAssignment, ContactAssignmentCreate, LegalEntityCreate, LocationCreate, LegalEntityUpdate, ContactAssignmentUpdate, LocationUpdate, OrderStatus, Order, SalesOrderPatch, Availability, RedemptionInput, RedemptionCreated, PointsSummary, RedeemOptionList, RedeemCouponResult, RedeemMyPointsInput, ReturnCreated, ReturnInput, ReturnList, Return } from '@viu/emporix-sdk';
2
2
  import * as _tanstack_react_query from '@tanstack/react-query';
3
3
  import { UseQueryResult, UseInfiniteQueryResult, UseMutationResult } from '@tanstack/react-query';
4
4
  import { S as SiteContextValue } from './provider-WHISqTG2.cjs';
@@ -11,6 +11,12 @@ interface CustomerSessionApi {
11
11
  isLoading: boolean;
12
12
  /** Current refresh token (in-session; set by `login`). */
13
13
  refreshToken: string | null;
14
+ /**
15
+ * Current SaaS token (in-session; set by `login`/`exchangeToken`). Pass it to
16
+ * `useCheckout().placeOrder({ ..., saasToken })` for customer checkout and to
17
+ * saas-token-gated order reads.
18
+ */
19
+ saasToken: string | null;
14
20
  login: (input: {
15
21
  email: string;
16
22
  password: string;
@@ -71,6 +77,11 @@ declare function useProductSearch(query: string | undefined, params?: {
71
77
  pageNumber?: number;
72
78
  pageSize?: number;
73
79
  }, options?: QueryOpts): UseQueryResult<PaginatedItems<Product>>;
80
+ /** Free-text product search by name (builds the Emporix `name:(~…)` filter). Disabled when empty/whitespace. */
81
+ declare function useProductNameSearch(term: string | undefined, params?: {
82
+ pageNumber?: number;
83
+ pageSize?: number;
84
+ }, options?: QueryOpts): UseQueryResult<PaginatedItems<Product>>;
74
85
  /**
75
86
  * Bulk-fetches products by `code`. Order is not guaranteed — re-index by
76
87
  * `code` if needed. Disabled when `codes` is empty.
@@ -167,6 +178,7 @@ interface CartMutationsApi {
167
178
  updateItem: Mut<{
168
179
  itemId: string;
169
180
  patch: CartItemUpdate;
181
+ partial?: boolean;
170
182
  }>;
171
183
  removeItem: Mut<{
172
184
  itemId: string;
@@ -479,7 +491,7 @@ declare function useCreateCompany(): UseMutationResult<{
479
491
  }, unknown, LegalEntityCreate>;
480
492
  declare function useUpdateCompany(): UseMutationResult<LegalEntity, unknown, {
481
493
  id: string;
482
- patch: LegalEntityUpdate;
494
+ patch: Partial<LegalEntityUpdate>;
483
495
  }>;
484
496
  declare function useDeleteCompany(): UseMutationResult<void, unknown, string>;
485
497
  declare function useAssignContact(): UseMutationResult<{
@@ -487,7 +499,7 @@ declare function useAssignContact(): UseMutationResult<{
487
499
  }, unknown, ContactAssignmentCreate>;
488
500
  declare function useUpdateContactAssignment(): UseMutationResult<ContactAssignment, unknown, {
489
501
  id: string;
490
- patch: ContactAssignmentUpdate;
502
+ patch: Partial<ContactAssignmentUpdate>;
491
503
  }>;
492
504
  declare function useUnassignContact(): UseMutationResult<void, unknown, string>;
493
505
  declare function useCreateLocation(): UseMutationResult<{
@@ -495,9 +507,19 @@ declare function useCreateLocation(): UseMutationResult<{
495
507
  }, unknown, LocationCreate>;
496
508
  declare function useUpdateLocation(): UseMutationResult<Location, unknown, {
497
509
  id: string;
498
- patch: LocationUpdate;
510
+ patch: Partial<LocationUpdate>;
499
511
  }>;
500
512
  declare function useDeleteLocation(): UseMutationResult<void, unknown, string>;
513
+ declare function useAddGroupMember(): UseMutationResult<{
514
+ id: string;
515
+ }, unknown, {
516
+ groupId: string;
517
+ member: IamGroupMemberAssignment;
518
+ }>;
519
+ declare function useRemoveGroupMember(): UseMutationResult<void, unknown, {
520
+ groupId: string;
521
+ userId: string;
522
+ }>;
501
523
 
502
524
  interface CompanySwitcherApi {
503
525
  companies: LegalEntity[];
@@ -651,4 +673,4 @@ declare function useReturn(returnId: string | undefined): UseQueryResult<Return>
651
673
  /** Create a return for the signed-in customer. Invalidates the returns list. */
652
674
  declare function useCreateReturn(): UseMutationResult<ReturnCreated, unknown, ReturnInput>;
653
675
 
654
- export { useMyOrdersInfinite as $, type AddressMutationsApi as A, useCategoryTree as B, type CartMutationsApi as C, useChangePassword as D, useCheckout as E, useCompany as F, useCompanyContacts as G, useCompanyGroups as H, useCompanyLocations as I, useCompanySwitcher as J, useCreateCart as K, useCreateCompany as L, useCreateLocation as M, useCreateReturn as N, useCreateShoppingList as O, type PasswordResetApi as P, useCustomerAddresses as Q, useCustomerSession as R, useDefaultSite as S, useDeleteCompany as T, type UseAvailabilitiesOptions as U, useDeleteLocation as V, useDeleteShoppingList as W, useMatchPrices as X, useMatchPricesChunked as Y, useMyCompanies as Z, useMyOrders as _, type CheckoutApi as a, useMyReturns as a0, useMyRewardPoints as a1, useMyRewardPointsSummary as a2, useMySegmentCategories as a3, useMySegmentCategoriesInfinite as a4, useMySegmentCategoryTree as a5, useMySegmentItems as a6, useMySegmentProducts as a7, useMySegmentProductsInfinite as a8, useMySegments as a9, useUpdateCompany as aA, useUpdateContactAssignment as aB, useUpdateCustomer as aC, useUpdateLocation as aD, useUpdateSalesOrder as aE, useValidateCoupon as aF, useVariantChildren as aG, useOrder as aa, useOrderTransition as ab, usePasswordReset as ac, usePaymentModes as ad, useProduct as ae, useProductByCode as af, useProductMedia as ag, useProductSearch as ah, useProducts as ai, useProductsByCodes as aj, useProductsInCategory as ak, useProductsInCategoryInfinite as al, useProductsInfinite as am, useRedeemCoupon as an, useRedeemOptions as ao, useRedeemRewardPoints as ap, useRemoveFromShoppingList as aq, useReorder as ar, useReturn as as, useSalesOrder as at, useSetShoppingListItemQuantity as au, useShoppingLists as av, useSiteContext as aw, useSites as ax, useSubcategories as ay, useUnassignContact as az, type CompanySwitcherApi as b, type CouponActionVars as c, type CustomerSessionApi as d, type UseAvailabilityOptions as e, type UseCancelOrderVars as f, type UseMyOrdersInfiniteOptions as g, type UseMyOrdersOptions as h, type UseOrderOptions as i, type UseOrderTransitionVars as j, type UseReorderResult as k, type UseReorderVars as l, type UseUpdateSalesOrderVars as m, type UseVariantChildrenOptions as n, useAddToShoppingList as o, useAddressMutations as p, useAssignContact as q, useAvailabilities as r, useAvailability as s, useCancelOrder as t, useActiveCart as u, useCart as v, useCartMutations as w, useCategories as x, useCategoriesInfinite as y, useCategory as z };
676
+ export { useMyOrders as $, type AddressMutationsApi as A, useCategory as B, type CartMutationsApi as C, useCategoryTree as D, useChangePassword as E, useCheckout as F, useCompany as G, useCompanyContacts as H, useCompanyGroups as I, useCompanyLocations as J, useCompanySwitcher as K, useCreateCart as L, useCreateCompany as M, useCreateLocation as N, useCreateReturn as O, type PasswordResetApi as P, useCreateShoppingList as Q, useCustomerAddresses as R, useCustomerSession as S, useDefaultSite as T, type UseAvailabilitiesOptions as U, useDeleteCompany as V, useDeleteLocation as W, useDeleteShoppingList as X, useMatchPrices as Y, useMatchPricesChunked as Z, useMyCompanies as _, type CheckoutApi as a, useMyOrdersInfinite as a0, useMyReturns as a1, useMyRewardPoints as a2, useMyRewardPointsSummary as a3, useMySegmentCategories as a4, useMySegmentCategoriesInfinite as a5, useMySegmentCategoryTree as a6, useMySegmentItems as a7, useMySegmentProducts as a8, useMySegmentProductsInfinite as a9, useSites as aA, useSubcategories as aB, useUnassignContact as aC, useUpdateCompany as aD, useUpdateContactAssignment as aE, useUpdateCustomer as aF, useUpdateLocation as aG, useUpdateSalesOrder as aH, useValidateCoupon as aI, useVariantChildren as aJ, useMySegments as aa, useOrder as ab, useOrderTransition as ac, usePasswordReset as ad, usePaymentModes as ae, useProduct as af, useProductByCode as ag, useProductMedia as ah, useProductNameSearch as ai, useProductSearch as aj, useProducts as ak, useProductsByCodes as al, useProductsInCategory as am, useProductsInCategoryInfinite as an, useProductsInfinite as ao, useRedeemCoupon as ap, useRedeemOptions as aq, useRedeemRewardPoints as ar, useRemoveFromShoppingList as as, useRemoveGroupMember as at, useReorder as au, useReturn as av, useSalesOrder as aw, useSetShoppingListItemQuantity as ax, useShoppingLists as ay, useSiteContext as az, type CompanySwitcherApi as b, type CouponActionVars as c, type CustomerSessionApi as d, type UseAvailabilityOptions as e, type UseCancelOrderVars as f, type UseMyOrdersInfiniteOptions as g, type UseMyOrdersOptions as h, type UseOrderOptions as i, type UseOrderTransitionVars as j, type UseReorderResult as k, type UseReorderVars as l, type UseUpdateSalesOrderVars as m, type UseVariantChildrenOptions as n, useAddGroupMember as o, useAddToShoppingList as p, useAddressMutations as q, useAssignContact as r, useAvailabilities as s, useAvailability as t, useActiveCart as u, useCancelOrder as v, useCart as w, useCartMutations as x, useCategories as y, useCategoriesInfinite as z };
@@ -1,4 +1,4 @@
1
- import { Customer, AuthContext, Product, PaginatedItems, ShoppingListItem, ShoppingListDraft, ShoppingList, Category, Cart, CartItemInput, CartItemUpdate, CartAddress, CartCreated, CreateCartInput, CheckoutResult, CheckoutInput, QuoteCheckoutInput, PaymentMode, PriceMatchByContextInput, PriceMatch, Media, SegmentCategoryTree, SegmentItem, Segment, PasswordChangeInput, CustomerUpdateInput, Address, AddressCreateInput, AddressUpdateInput, PasswordResetRequestInput, PasswordResetConfirmInput, Site, LegalEntity, ContactAssignment, Location, IamGroup, ContactAssignmentCreate, LegalEntityCreate, LocationCreate, LegalEntityUpdate, ContactAssignmentUpdate, LocationUpdate, OrderStatus, Order, SalesOrderPatch, Availability, RedemptionInput, RedemptionCreated, PointsSummary, RedeemOptionList, RedeemCouponResult, RedeemMyPointsInput, ReturnCreated, ReturnInput, ReturnList, Return } from '@viu/emporix-sdk';
1
+ import { Customer, AuthContext, Product, PaginatedItems, ShoppingListItem, ShoppingListDraft, ShoppingList, Category, Cart, CartItemInput, CartItemUpdate, CartAddress, CartCreated, CreateCartInput, CheckoutResult, CheckoutInput, QuoteCheckoutInput, PaymentMode, PriceMatchByContextInput, PriceMatch, Media, SegmentCategoryTree, SegmentItem, Segment, PasswordChangeInput, CustomerUpdateInput, Address, AddressCreateInput, AddressUpdateInput, PasswordResetRequestInput, PasswordResetConfirmInput, Site, LegalEntity, ContactAssignment, Location, IamGroup, IamGroupMemberAssignment, ContactAssignmentCreate, LegalEntityCreate, LocationCreate, LegalEntityUpdate, ContactAssignmentUpdate, LocationUpdate, OrderStatus, Order, SalesOrderPatch, Availability, RedemptionInput, RedemptionCreated, PointsSummary, RedeemOptionList, RedeemCouponResult, RedeemMyPointsInput, ReturnCreated, ReturnInput, ReturnList, Return } from '@viu/emporix-sdk';
2
2
  import * as _tanstack_react_query from '@tanstack/react-query';
3
3
  import { UseQueryResult, UseInfiniteQueryResult, UseMutationResult } from '@tanstack/react-query';
4
4
  import { S as SiteContextValue } from './provider-CLNEKOuu.js';
@@ -11,6 +11,12 @@ interface CustomerSessionApi {
11
11
  isLoading: boolean;
12
12
  /** Current refresh token (in-session; set by `login`). */
13
13
  refreshToken: string | null;
14
+ /**
15
+ * Current SaaS token (in-session; set by `login`/`exchangeToken`). Pass it to
16
+ * `useCheckout().placeOrder({ ..., saasToken })` for customer checkout and to
17
+ * saas-token-gated order reads.
18
+ */
19
+ saasToken: string | null;
14
20
  login: (input: {
15
21
  email: string;
16
22
  password: string;
@@ -71,6 +77,11 @@ declare function useProductSearch(query: string | undefined, params?: {
71
77
  pageNumber?: number;
72
78
  pageSize?: number;
73
79
  }, options?: QueryOpts): UseQueryResult<PaginatedItems<Product>>;
80
+ /** Free-text product search by name (builds the Emporix `name:(~…)` filter). Disabled when empty/whitespace. */
81
+ declare function useProductNameSearch(term: string | undefined, params?: {
82
+ pageNumber?: number;
83
+ pageSize?: number;
84
+ }, options?: QueryOpts): UseQueryResult<PaginatedItems<Product>>;
74
85
  /**
75
86
  * Bulk-fetches products by `code`. Order is not guaranteed — re-index by
76
87
  * `code` if needed. Disabled when `codes` is empty.
@@ -167,6 +178,7 @@ interface CartMutationsApi {
167
178
  updateItem: Mut<{
168
179
  itemId: string;
169
180
  patch: CartItemUpdate;
181
+ partial?: boolean;
170
182
  }>;
171
183
  removeItem: Mut<{
172
184
  itemId: string;
@@ -479,7 +491,7 @@ declare function useCreateCompany(): UseMutationResult<{
479
491
  }, unknown, LegalEntityCreate>;
480
492
  declare function useUpdateCompany(): UseMutationResult<LegalEntity, unknown, {
481
493
  id: string;
482
- patch: LegalEntityUpdate;
494
+ patch: Partial<LegalEntityUpdate>;
483
495
  }>;
484
496
  declare function useDeleteCompany(): UseMutationResult<void, unknown, string>;
485
497
  declare function useAssignContact(): UseMutationResult<{
@@ -487,7 +499,7 @@ declare function useAssignContact(): UseMutationResult<{
487
499
  }, unknown, ContactAssignmentCreate>;
488
500
  declare function useUpdateContactAssignment(): UseMutationResult<ContactAssignment, unknown, {
489
501
  id: string;
490
- patch: ContactAssignmentUpdate;
502
+ patch: Partial<ContactAssignmentUpdate>;
491
503
  }>;
492
504
  declare function useUnassignContact(): UseMutationResult<void, unknown, string>;
493
505
  declare function useCreateLocation(): UseMutationResult<{
@@ -495,9 +507,19 @@ declare function useCreateLocation(): UseMutationResult<{
495
507
  }, unknown, LocationCreate>;
496
508
  declare function useUpdateLocation(): UseMutationResult<Location, unknown, {
497
509
  id: string;
498
- patch: LocationUpdate;
510
+ patch: Partial<LocationUpdate>;
499
511
  }>;
500
512
  declare function useDeleteLocation(): UseMutationResult<void, unknown, string>;
513
+ declare function useAddGroupMember(): UseMutationResult<{
514
+ id: string;
515
+ }, unknown, {
516
+ groupId: string;
517
+ member: IamGroupMemberAssignment;
518
+ }>;
519
+ declare function useRemoveGroupMember(): UseMutationResult<void, unknown, {
520
+ groupId: string;
521
+ userId: string;
522
+ }>;
501
523
 
502
524
  interface CompanySwitcherApi {
503
525
  companies: LegalEntity[];
@@ -651,4 +673,4 @@ declare function useReturn(returnId: string | undefined): UseQueryResult<Return>
651
673
  /** Create a return for the signed-in customer. Invalidates the returns list. */
652
674
  declare function useCreateReturn(): UseMutationResult<ReturnCreated, unknown, ReturnInput>;
653
675
 
654
- export { useMyOrdersInfinite as $, type AddressMutationsApi as A, useCategoryTree as B, type CartMutationsApi as C, useChangePassword as D, useCheckout as E, useCompany as F, useCompanyContacts as G, useCompanyGroups as H, useCompanyLocations as I, useCompanySwitcher as J, useCreateCart as K, useCreateCompany as L, useCreateLocation as M, useCreateReturn as N, useCreateShoppingList as O, type PasswordResetApi as P, useCustomerAddresses as Q, useCustomerSession as R, useDefaultSite as S, useDeleteCompany as T, type UseAvailabilitiesOptions as U, useDeleteLocation as V, useDeleteShoppingList as W, useMatchPrices as X, useMatchPricesChunked as Y, useMyCompanies as Z, useMyOrders as _, type CheckoutApi as a, useMyReturns as a0, useMyRewardPoints as a1, useMyRewardPointsSummary as a2, useMySegmentCategories as a3, useMySegmentCategoriesInfinite as a4, useMySegmentCategoryTree as a5, useMySegmentItems as a6, useMySegmentProducts as a7, useMySegmentProductsInfinite as a8, useMySegments as a9, useUpdateCompany as aA, useUpdateContactAssignment as aB, useUpdateCustomer as aC, useUpdateLocation as aD, useUpdateSalesOrder as aE, useValidateCoupon as aF, useVariantChildren as aG, useOrder as aa, useOrderTransition as ab, usePasswordReset as ac, usePaymentModes as ad, useProduct as ae, useProductByCode as af, useProductMedia as ag, useProductSearch as ah, useProducts as ai, useProductsByCodes as aj, useProductsInCategory as ak, useProductsInCategoryInfinite as al, useProductsInfinite as am, useRedeemCoupon as an, useRedeemOptions as ao, useRedeemRewardPoints as ap, useRemoveFromShoppingList as aq, useReorder as ar, useReturn as as, useSalesOrder as at, useSetShoppingListItemQuantity as au, useShoppingLists as av, useSiteContext as aw, useSites as ax, useSubcategories as ay, useUnassignContact as az, type CompanySwitcherApi as b, type CouponActionVars as c, type CustomerSessionApi as d, type UseAvailabilityOptions as e, type UseCancelOrderVars as f, type UseMyOrdersInfiniteOptions as g, type UseMyOrdersOptions as h, type UseOrderOptions as i, type UseOrderTransitionVars as j, type UseReorderResult as k, type UseReorderVars as l, type UseUpdateSalesOrderVars as m, type UseVariantChildrenOptions as n, useAddToShoppingList as o, useAddressMutations as p, useAssignContact as q, useAvailabilities as r, useAvailability as s, useCancelOrder as t, useActiveCart as u, useCart as v, useCartMutations as w, useCategories as x, useCategoriesInfinite as y, useCategory as z };
676
+ export { useMyOrders as $, type AddressMutationsApi as A, useCategory as B, type CartMutationsApi as C, useCategoryTree as D, useChangePassword as E, useCheckout as F, useCompany as G, useCompanyContacts as H, useCompanyGroups as I, useCompanyLocations as J, useCompanySwitcher as K, useCreateCart as L, useCreateCompany as M, useCreateLocation as N, useCreateReturn as O, type PasswordResetApi as P, useCreateShoppingList as Q, useCustomerAddresses as R, useCustomerSession as S, useDefaultSite as T, type UseAvailabilitiesOptions as U, useDeleteCompany as V, useDeleteLocation as W, useDeleteShoppingList as X, useMatchPrices as Y, useMatchPricesChunked as Z, useMyCompanies as _, type CheckoutApi as a, useMyOrdersInfinite as a0, useMyReturns as a1, useMyRewardPoints as a2, useMyRewardPointsSummary as a3, useMySegmentCategories as a4, useMySegmentCategoriesInfinite as a5, useMySegmentCategoryTree as a6, useMySegmentItems as a7, useMySegmentProducts as a8, useMySegmentProductsInfinite as a9, useSites as aA, useSubcategories as aB, useUnassignContact as aC, useUpdateCompany as aD, useUpdateContactAssignment as aE, useUpdateCustomer as aF, useUpdateLocation as aG, useUpdateSalesOrder as aH, useValidateCoupon as aI, useVariantChildren as aJ, useMySegments as aa, useOrder as ab, useOrderTransition as ac, usePasswordReset as ad, usePaymentModes as ae, useProduct as af, useProductByCode as ag, useProductMedia as ah, useProductNameSearch as ai, useProductSearch as aj, useProducts as ak, useProductsByCodes as al, useProductsInCategory as am, useProductsInCategoryInfinite as an, useProductsInfinite as ao, useRedeemCoupon as ap, useRedeemOptions as aq, useRedeemRewardPoints as ar, useRemoveFromShoppingList as as, useRemoveGroupMember as at, useReorder as au, useReturn as av, useSalesOrder as aw, useSetShoppingListItemQuantity as ax, useShoppingLists as ay, useSiteContext as az, type CompanySwitcherApi as b, type CouponActionVars as c, type CustomerSessionApi as d, type UseAvailabilityOptions as e, type UseCancelOrderVars as f, type UseMyOrdersInfiniteOptions as g, type UseMyOrdersOptions as h, type UseOrderOptions as i, type UseOrderTransitionVars as j, type UseReorderResult as k, type UseReorderVars as l, type UseUpdateSalesOrderVars as m, type UseVariantChildrenOptions as n, useAddGroupMember as o, useAddToShoppingList as p, useAddressMutations as q, useAssignContact as r, useAvailabilities as s, useAvailability as t, useActiveCart as u, useCancelOrder as v, useCart as w, useCartMutations as x, useCategories as y, useCategoriesInfinite as z };
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@viu/emporix-sdk-react",
3
- "version": "2.7.0",
3
+ "version": "2.9.0",
4
4
  "description": "React bindings for the Emporix SDK",
5
5
  "license": "MIT",
6
6
  "author": {
@@ -71,7 +71,7 @@
71
71
  "peerDependencies": {
72
72
  "@tanstack/react-query": "^5.51.0",
73
73
  "react": "^18.0.0 || ^19.0.0",
74
- "@viu/emporix-sdk": "^2.7.0"
74
+ "@viu/emporix-sdk": "^2.9.0"
75
75
  },
76
76
  "devDependencies": {
77
77
  "@tanstack/react-query": "^5.51.0",
@@ -93,7 +93,7 @@
93
93
  "typescript": "^5.6.0",
94
94
  "undici": "^6.19.0",
95
95
  "vitest": "^2.0.0",
96
- "@viu/emporix-sdk": "2.7.0"
96
+ "@viu/emporix-sdk": "2.9.0"
97
97
  },
98
98
  "scripts": {
99
99
  "build": "tsup",