@beamimpact/web-sdk 1.39.0 → 1.39.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/chunks/_share-dialog-dependencies-K7WZWxUL.esm.js +2 -0
- package/dist/chunks/_share-dialog-dependencies-K7WZWxUL.esm.js.map +1 -0
- package/dist/chunks/_share-dialog-dependencies-VjhRF4_b.esm.js +2 -0
- package/dist/chunks/_share-dialog-dependencies-VjhRF4_b.esm.js.map +1 -0
- package/dist/chunks/{events-7W7i4aV5.esm.d.ts → events-7cGXyV7_.esm.d.ts} +2 -1
- package/dist/chunks/events-Y8fYvSqM.esm.js.map +1 -1
- package/dist/chunks/{index-Zk634mW7.esm.d.ts → index-0VcD5nhV.esm.d.ts} +1 -1
- package/dist/chunks/{index-YwDVLm67.esm.d.ts → index-8KzbQIsU.esm.d.ts} +1 -1
- package/dist/chunks/index-EUMlzqI-.esm.js +2 -0
- package/dist/chunks/index-EUMlzqI-.esm.js.map +1 -0
- package/dist/chunks/index-U5URUABu.esm.js +2 -0
- package/dist/chunks/index-U5URUABu.esm.js.map +1 -0
- package/dist/chunks/index-VELk9_yH.esm.js +2 -0
- package/dist/chunks/index-VELk9_yH.esm.js.map +1 -0
- package/dist/chunks/{index-sCYUc4NK.esm.js → index-XlnH7ARQ.esm.js} +2 -2
- package/dist/chunks/{index-sCYUc4NK.esm.js.map → index-XlnH7ARQ.esm.js.map} +1 -1
- package/dist/chunks/{index-82TLJN3M.esm.js → index-dsJIs5Sr.esm.js} +2 -2
- package/dist/chunks/{index-82TLJN3M.esm.js.map → index-dsJIs5Sr.esm.js.map} +1 -1
- package/dist/chunks/index-q_XLkvqc.esm.js +2 -0
- package/dist/chunks/index-q_XLkvqc.esm.js.map +1 -0
- package/dist/chunks/{index-b-AHDeDB.esm.d.ts → index-rFBYAk7m.esm.d.ts} +1 -1
- package/dist/chunks/index-xR738adx.esm.js +2 -0
- package/dist/chunks/index-xR738adx.esm.js.map +1 -0
- package/dist/chunks/index-xfPSpbUV.esm.js +2 -0
- package/dist/chunks/index-xfPSpbUV.esm.js.map +1 -0
- package/dist/chunks/order-page-6Q-6CHug.esm.js +2 -0
- package/dist/chunks/order-page-6Q-6CHug.esm.js.map +1 -0
- package/dist/chunks/order-page-mYYXHDVr.esm.js +2 -0
- package/dist/chunks/order-page-mYYXHDVr.esm.js.map +1 -0
- package/dist/chunks/routes-3jKReDai.esm.js +2 -0
- package/dist/chunks/routes-3jKReDai.esm.js.map +1 -0
- package/dist/chunks/routes-b8sncPq8.esm.js +2 -0
- package/dist/chunks/routes-b8sncPq8.esm.js.map +1 -0
- package/dist/chunks/{shoelace-components-7Bz0cgFm.esm.js → shoelace-components-7XWYNn-Z.esm.js} +2 -2
- package/dist/chunks/{shoelace-components-7Bz0cgFm.esm.js.map → shoelace-components-7XWYNn-Z.esm.js.map} +1 -1
- package/dist/chunks/{shoelace-components-R0WKZ63n.esm.js → shoelace-components-paAsUPkU.esm.js} +2 -2
- package/dist/chunks/{shoelace-components-R0WKZ63n.esm.js.map → shoelace-components-paAsUPkU.esm.js.map} +1 -1
- package/dist/chunks/types-CfbVJRfU.esm.d.ts +21 -0
- package/dist/chunks/{update-cart-KdiGuVzp.esm.js → update-cart-GaVMWI6J.esm.js} +2 -2
- package/dist/chunks/{update-cart-KdiGuVzp.esm.js.map → update-cart-GaVMWI6J.esm.js.map} +1 -1
- package/dist/chunks/{update-cart-147q_9OK.esm.js → update-cart-xW6a5_bz.esm.js} +2 -2
- package/dist/chunks/{update-cart-147q_9OK.esm.js.map → update-cart-xW6a5_bz.esm.js.map} +1 -1
- package/dist/components/community-impact.d.ts +2 -2
- package/dist/components/community-impact.esm.js +3 -3
- package/dist/components/community-impact.esm.js.map +1 -1
- package/dist/components/community-impact.js +3 -3
- package/dist/components/community-impact.js.map +1 -1
- package/dist/components/cumulative-impact.d.ts +1 -1
- package/dist/components/cumulative-impact.esm.js +1 -1
- package/dist/components/cumulative-impact.js +1 -1
- package/dist/components/impact-overview.d.ts +1 -1
- package/dist/components/impact-overview.esm.js +5 -5
- package/dist/components/impact-overview.esm.js.map +1 -1
- package/dist/components/impact-overview.js +5 -5
- package/dist/components/impact-overview.js.map +1 -1
- package/dist/components/index.d.ts +1 -1
- package/dist/components/index.esm.js +1 -1
- package/dist/components/index.js +1 -1
- package/dist/components/post-purchase.d.ts +2 -2
- package/dist/components/post-purchase.esm.js +1 -1
- package/dist/components/post-purchase.js +1 -1
- package/dist/components/product-details-page.d.ts +1 -1
- package/dist/components/product-details-page.esm.js +10 -14
- package/dist/components/product-details-page.esm.js.map +1 -1
- package/dist/components/product-details-page.js +10 -14
- package/dist/components/product-details-page.js.map +1 -1
- package/dist/components/redeem-transaction.d.ts +2 -2
- package/dist/components/redeem-transaction.esm.js +9 -9
- package/dist/components/redeem-transaction.esm.js.map +1 -1
- package/dist/components/redeem-transaction.js +9 -9
- package/dist/components/redeem-transaction.js.map +1 -1
- package/dist/components/select-nonprofit.d.ts +2 -2
- package/dist/components/select-nonprofit.esm.js +8 -8
- package/dist/components/select-nonprofit.esm.js.map +1 -1
- package/dist/components/select-nonprofit.js +8 -8
- package/dist/components/select-nonprofit.js.map +1 -1
- package/dist/components/shopify.d.ts +2 -2
- package/dist/components/shopify.esm.js +1 -1
- package/dist/components/shopify.js +1 -1
- package/dist/components/subscription-management.d.ts +2 -2
- package/dist/components/subscription-management.esm.js +6 -6
- package/dist/components/subscription-management.esm.js.map +1 -1
- package/dist/components/subscription-management.js +6 -6
- package/dist/components/subscription-management.js.map +1 -1
- package/dist/index.d.ts +5 -5
- package/dist/index.esm.js +1 -1
- package/dist/index.js +1 -1
- package/dist/integrations/beam.d.ts +1 -1
- package/dist/integrations/beam.esm.js +1 -1
- package/dist/integrations/beam.js +1 -1
- package/dist/integrations/cart.esm.js +1 -1
- package/dist/integrations/cart.js +1 -1
- package/dist/integrations/index.d.ts +3 -3
- package/dist/integrations/index.esm.js +1 -1
- package/dist/integrations/index.js +1 -1
- package/dist/integrations/logs.esm.js +1 -1
- package/dist/integrations/logs.js +1 -1
- package/dist/integrations/shopify.d.ts +1 -1
- package/dist/integrations/shopify.esm.js +1 -1
- package/dist/integrations/shopify.js +1 -1
- package/dist/integrations/statsig.d.ts +1 -1
- package/dist/integrations/statsig.esm.js +3 -2
- package/dist/integrations/statsig.esm.js.map +1 -1
- package/dist/integrations/statsig.js +3 -2
- package/dist/integrations/statsig.js.map +1 -1
- package/dist/integrations/utils.d.ts +2 -2
- package/dist/react/community-impact.d.ts +1 -1
- package/dist/react/community-impact.esm.js +1 -1
- package/dist/react/community-impact.js +1 -1
- package/dist/react/cumulative-impact.d.ts +1 -1
- package/dist/react/cumulative-impact.esm.js +1 -1
- package/dist/react/cumulative-impact.js +1 -1
- package/dist/react/impact-overview.d.ts +1 -1
- package/dist/react/impact-overview.esm.js +1 -1
- package/dist/react/impact-overview.js +1 -1
- package/dist/react/index.d.ts +2 -2
- package/dist/react/index.esm.js +1 -1
- package/dist/react/index.js +1 -1
- package/dist/react/post-purchase.d.ts +1 -1
- package/dist/react/post-purchase.esm.js +1 -1
- package/dist/react/post-purchase.js +1 -1
- package/dist/react/product-details-page.esm.js +1 -1
- package/dist/react/product-details-page.js +1 -1
- package/dist/react/redeem-transaction.d.ts +2 -2
- package/dist/react/redeem-transaction.esm.js +1 -1
- package/dist/react/redeem-transaction.js +1 -1
- package/dist/react/select-nonprofit.d.ts +2 -2
- package/dist/react/select-nonprofit.esm.js +1 -1
- package/dist/react/select-nonprofit.js +1 -1
- package/dist/react/subscription-management.d.ts +1 -1
- package/dist/react/subscription-management.esm.js +1 -1
- package/dist/react/subscription-management.js +1 -1
- package/dist/utils/events.d.ts +2 -2
- package/dist/utils/index.d.ts +2 -2
- package/package.json +1 -1
- package/dist/chunks/_share-dialog-dependencies-E9UC6rFe.esm.js +0 -2
- package/dist/chunks/_share-dialog-dependencies-E9UC6rFe.esm.js.map +0 -1
- package/dist/chunks/_share-dialog-dependencies-jT0LyIYZ.esm.js +0 -2
- package/dist/chunks/_share-dialog-dependencies-jT0LyIYZ.esm.js.map +0 -1
- package/dist/chunks/index-A4ADMGuS.esm.js +0 -2
- package/dist/chunks/index-A4ADMGuS.esm.js.map +0 -1
- package/dist/chunks/index-GxPqdIah.esm.js +0 -2
- package/dist/chunks/index-GxPqdIah.esm.js.map +0 -1
- package/dist/chunks/index-QNK0E7_-.esm.js +0 -2
- package/dist/chunks/index-QNK0E7_-.esm.js.map +0 -1
- package/dist/chunks/index-WeS36ABz.esm.js +0 -2
- package/dist/chunks/index-WeS36ABz.esm.js.map +0 -1
- package/dist/chunks/index-Y6-97c9H.esm.js +0 -2
- package/dist/chunks/index-Y6-97c9H.esm.js.map +0 -1
- package/dist/chunks/index-hEEPYOBy.esm.js +0 -2
- package/dist/chunks/index-hEEPYOBy.esm.js.map +0 -1
- package/dist/chunks/order-page--Z7oUbXx.esm.js +0 -2
- package/dist/chunks/order-page--Z7oUbXx.esm.js.map +0 -1
- package/dist/chunks/order-page-zVZsxnVd.esm.js +0 -2
- package/dist/chunks/order-page-zVZsxnVd.esm.js.map +0 -1
- package/dist/chunks/routes-2FqTWOCW.esm.js +0 -2
- package/dist/chunks/routes-2FqTWOCW.esm.js.map +0 -1
- package/dist/chunks/routes-OzJqNrBl.esm.js +0 -2
- package/dist/chunks/routes-OzJqNrBl.esm.js.map +0 -1
- package/dist/chunks/types-7kSi85Gv.esm.d.ts +0 -10
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"subscription-management.js","sources":["../../src/components/subscription-management/strings.ts","../../src/components/subscription-management/index.ts"],"sourcesContent":["export const strings = {\n en: {\n nonprofitSwapText: ({ brandName = \"\" }) => `Support a new nonprofit with your next ${brandName} recurring order`,\n },\n fr: {\n nonprofitSwapText: ({ brandName = \"\" }) =>\n `Soutenez une nouvelle organisation à but non lucratif avec votre prochaine commande récurrente ${brandName}`,\n },\n de: {\n nonprofitSwapText: ({ brandName = \"\" }) =>\n `Unterstützen Sie eine neue gemeinnützige Organisation mit Ihrer nächsten wiederkehrenden Bestellung bei ${brandName}`,\n },\n es: {\n nonprofitSwapText: ({ brandName = \"\" }) =>\n `Apoye a una nueva organización sin fines de lucro con su próximo pedido recurrente ${brandName}`,\n },\n it: {\n nonprofitSwapText: ({ brandName = \"\" }) =>\n `Sostieni una nuova organizzazione non profit con il tuo prossimo ordine ricorrente ${brandName}`,\n },\n pl: {\n nonprofitSwapText: ({ brandName = \"\" }) =>\n `Wesprzyj nową organizację non-profit przy kolejnym zamówieniu cyklicznym ${brandName}`,\n },\n};\n","import { css, html, LitElement } from \"lit\";\nimport { property } from \"lit/decorators/property.js\";\nimport { state } from \"lit/decorators/state.js\";\nimport { DEFAULT_BASE_URL } from \"../../api-sdk/constants\";\nimport { LANGUAGES } from \"../../api-sdk/types\";\nimport { TCart } from \"../../shared/cart-contents\";\nimport { enforceConfig } from \"../../shared/enforce-config\";\nimport { postFindOrCreateSubscription, postChainEligibleNonprofitsForCart } from \"../../api-sdk/v3/routes\";\nimport { AsyncController } from \"../../shared/controllers/async-controller\";\nimport { cssReset } from \"../../shared/css-reset\";\nimport { defineCustomElement } from \"../../shared/defineCustomElement\";\nimport { _errorMessage } from \"../../shared/fragments/error-message-template\";\nimport { _cssVariableMap } from \"../../shared/fragments/css-variable-map\";\nimport { BeamNonprofitSelectEvent } from \"../../utils/events\";\nimport { MissingConfig } from \"../../utils/beam-errors\";\nimport { strings } from \"./strings\";\nimport \"../redeem-transaction\";\nimport \"../impact-overview\";\n\ninterface RequiredDataPropsWithEmail {\n email: string;\n apiKey: string;\n subscriptionId: string;\n}\n\ninterface RequiredDataPropsWithPartnerUserId {\n partnerUserId: string;\n apiKey: string;\n subscriptionId: string;\n}\n\ntype TRequiredDataProps = RequiredDataPropsWithEmail | RequiredDataPropsWithPartnerUserId;\nexport class BeamSubscriptionManagement extends LitElement {\n static tagName = \"beam-subscription-management\";\n\n @property({ type: String })\n public baseUrl: string = DEFAULT_BASE_URL;\n\n @property({ type: String })\n public apiKey!: TRequiredDataProps[\"apiKey\"];\n\n @property({ type: String })\n public subscriptionId!: TRequiredDataProps[\"subscriptionId\"];\n\n @property({ type: Number, reflect: true })\n public storeId?: number; // Either storeId or postalCode, countryCode must be provided\n\n @property({ type: String })\n public email?: RequiredDataPropsWithEmail[\"email\"]; // Either email or partnerUserId must be provided\n\n @property({ type: String })\n public partnerUserId?: RequiredDataPropsWithPartnerUserId[\"partnerUserId\"]; // Either email or partnerUserId must be provided\n\n @property({ type: String })\n public postalCode?: string;\n\n @property({ type: String })\n public countryCode?: string;\n\n @property({ type: String })\n public lang: LANGUAGES = \"en\";\n\n @property({ type: Object })\n public cart?: TCart;\n\n @property({ type: Boolean })\n public debug = false;\n\n @state() private activeWidget: \"redeem-transaction\" | \"impact-overview\" | null = null; // Based on /findSubscriptionByRemoteId\n @state() private nonprofitId: number | null = null; // From /findSubscriptionByRemoteId response\n @state() private userId: string | null = null; // From findSubscriptionByRemoteId\n @state() private chainName: string | null = null; // From findEligibleNonprofitsForCart\n\n private subscriptionDataController = new AsyncController<typeof this.fetchSubscription>(this, this.fetchSubscription);\n private eligibleNonprofitsDataController = new AsyncController<typeof this.fetchEligibleNonprofits>(\n this,\n this.fetchEligibleNonprofits\n );\n\n async firstUpdated() {\n if (!this.email && !this.partnerUserId) {\n throw new MissingConfig(\n [\"email\", \"partnerUserId\"],\n \"One of the following properties needs to be specified: email, partnerUserId \"\n );\n }\n enforceConfig<TRequiredDataProps>([\"apiKey\", \"subscriptionId\"], this);\n await this.loadWidget();\n }\n\n async loadWidget() {\n // In parallel:\n // (1). Fetch eligible nonprofits [storeId and chainName]\n // (2). Fetch subscription [userId and nonprofitId]\n await Promise.all([this.fetchEligibleNonprofits(), this.fetchSubscription()]);\n this.activeWidget = this.nonprofitId ? \"impact-overview\" : \"redeem-transaction\";\n }\n\n async fetchEligibleNonprofits() {\n enforceConfig<TRequiredDataProps>([\"apiKey\", \"subscriptionId\"], this);\n const res = await postChainEligibleNonprofitsForCart({\n baseUrl: this.baseUrl,\n headers: {\n authorization: `Api-Key ${this.apiKey}`,\n },\n requestBody: {\n storeId: this.storeId || undefined,\n postalCode: this.postalCode || undefined,\n countryCode: this.countryCode || undefined,\n widgetName: \"subscription-management\",\n version: \"1.0.0\",\n },\n });\n this.chainName = res.chain.name;\n this.storeId = res.store.id;\n this.eligibleNonprofitsDataController.data = res;\n return res;\n }\n\n async fetchSubscription() {\n enforceConfig<TRequiredDataProps>([\"apiKey\", \"subscriptionId\"], this);\n const result = await postFindOrCreateSubscription({\n baseUrl: this.baseUrl,\n headers: {\n authorization: `Api-Key ${this.apiKey}`,\n },\n requestBody: {\n remoteSubscriptionId: this.subscriptionId,\n email: this.email,\n partnerUserId: this.partnerUserId,\n },\n });\n\n this.userId = result.beamUserId; // Returned in response regardless of subscription redemption\n this.nonprofitId = result.nonprofit?.id || null;\n return result;\n }\n\n handleSwapNonprofitButtonClick() {\n this.activeWidget = \"redeem-transaction\";\n }\n\n renderSwapNonprofitButton() {\n if (this.activeWidget === \"impact-overview\") {\n return html`<button class=\"swap-nonprofit-button\" @click=\"${this.handleSwapNonprofitButtonClick}\">\n ${strings[this.lang].nonprofitSwapText({ brandName: this.chainName || \"\" })}\n </button>`;\n } else {\n return \"\";\n }\n }\n\n public get cssVariables() {\n const defaults = {\n \"--beam-fontFamily\": \"inherit\",\n \"--beam-fontStyle\": \"inherit\",\n \"--beam-fontSize\": \"inherit\",\n \"--beam-textColor\": \"inherit\",\n \"--beam-backgroundColor\": \"inherit\",\n \"--beam-SubscriptionManagement-widgetContainer-borderColor\": \"#d5d5d5\",\n \"--beam-SubscriptionManagement-widgetContainer-borderRadius\": \"4px\",\n \"--beam-SubscriptionManagement-widgetContainer-padding\": \"15px\",\n \"--beam-SubscriptionManagement-widgetContainer-backgroundColor\": \"inherit\",\n \"--beam-SubscriptionManagement-widgetContainer-maxWidth\": \"800px\",\n \"--beam-SubscriptionManagement-swapNonprofitButtonText-textDecoration\": \"underline\",\n \"--beam-SubscriptionManagement-swapNonprofitButtonText-fontFamily\": \"inherit\",\n \"--beam-SubscriptionManagement-swapNonprofitButtonText-fontStyle\": \"inherit\",\n \"--beam-SubscriptionManagement-swapNonprofitButtonText-fontWeight\": \"inherit\",\n \"--beam-SubscriptionManagement-swapNonprofitButtonText-lineHeight\": \"inherit\",\n \"--beam-SubscriptionManagement-swapNonprofitButtonText-marginTop\": \"10px\",\n \"--beam-SubscriptionManagement-swapNonprofitButtonText-fontSize\": \"inherit\",\n \"--beam-SubscriptionManagement-swapNonprofitButtonText-color\": \"inherit\",\n };\n\n const remoteConfig = this.eligibleNonprofitsDataController?.data?.config?.web?.theme || {};\n\n const config = { ...defaults, ...remoteConfig };\n\n const serializable = Object.create({\n toCSS() {\n return _cssVariableMap(this as Record<string, string>);\n },\n });\n return Object.assign(serializable, config);\n }\n\n static styles = [\n cssReset,\n css`\n :host {\n display: block;\n font-family: var(--beam-fontFamily);\n font-style: var(--beam-fontStyle);\n font-size: var(--beam-fontSize);\n background-color: var(--beam-backgroundColor);\n color: var(--beam-textColor);\n word-break: normal;\n }\n .swap-nonprofit-button {\n margin-top: var(--beam-SubscriptionManagement-swapNonprofitButtonText-marginTop, 10px);\n color: var(--beam-SubscriptionManagement-swapNonprofitButtonText-color, inherit);\n font-size: var(--beam-SubscriptionManagement-swapNonprofitButtonText-fontSize, inherit);\n text-decoration: var(--beam-SubscriptionManagement-swapNonprofitButtonText-textDecoration, underline);\n font-family: var(--beam-SubscriptionManagement-swapNonprofitButtonText-fontFamily, inherit);\n font-style: var(--beam-SubscriptionManagement-swapNonprofitButtonText-fontStyle, inherit);\n font-weight: var(--beam-SubscriptionManagement-swapNonprofitButtonText-fontWeight, inherit);\n line-height: var(--beam-SubscriptionManagement-swapNonprofitButtonText-lineHeight, inherit);\n background: none;\n border: none;\n cursor: pointer;\n }\n .sub-widget-container {\n background-color: var(--beam-SubscriptionManagement-widgetContainer-backgroundColor, inherit);\n border: 1px solid var(--beam-SubscriptionManagement-widgetContainer-borderColor, #d5d5d5);\n border-radius: var(--beam-SubscriptionManagement-widgetContainer-borderRadius, 4px);\n overflow: hidden; /* maintain clean border-radius */\n padding: var(--beam-SubscriptionManagement-widgetContainer-padding, 15px);\n max-width: var(--beam-SubscriptionManagement-widgetContainer-maxWidth, 800px);\n }\n }`,\n ];\n\n render() {\n let content;\n\n if (this.subscriptionDataController.loading || this.eligibleNonprofitsDataController.loading) {\n content = \"\";\n }\n\n if ((this.subscriptionDataController.error || this.eligibleNonprofitsDataController.error) && this.debug) {\n if (this.subscriptionDataController.error !== null) {\n return _errorMessage({ error: this.subscriptionDataController.error });\n } else if (this.eligibleNonprofitsDataController.error !== null) {\n return _errorMessage({ error: this.eligibleNonprofitsDataController.error });\n }\n } else {\n content = \"\";\n }\n\n if (this.activeWidget === \"redeem-transaction\") {\n content = html` <beam-redeem-transaction\n part=\"redeem-transaction\"\n storeId=\"${this.storeId}\"\n subscriptionId=\"${this.subscriptionId}\"\n nonprofitId=${this.nonprofitId}\n baseUrl=\"${this.baseUrl}\"\n apiKey=\"${this.apiKey}\"\n postalCode=\"${this.postalCode}\"\n countryCode=\"${this.countryCode}\"\n lang=\"${this.lang}\"\n ?debug=\"${this.debug}\"\n @beamnonprofitselect=\"${(event: Event) => {\n if (!(event instanceof BeamNonprofitSelectEvent)) return; // TS guard\n const { selectedNonprofitId } = event.detail;\n this.nonprofitId = selectedNonprofitId ?? null;\n this.activeWidget = \"impact-overview\";\n }}\"\n ></beam-redeem-transaction>`;\n } else if (this.activeWidget === \"impact-overview\") {\n content = html`\n <beam-impact-overview\n part=\"impact-overview\"\n baseUrl=\"${this.baseUrl}\"\n apiKey=\"${this.apiKey}\"\n userId=\"${this.userId}\"\n nonprofitId=\"${this.nonprofitId}\"\n lang=\"${this.lang}\"\n ?debug=\"${this.debug}\"\n ></beam-impact-overview>\n `;\n }\n return html`\n <style>\n :host {\n ${this.cssVariables.toCSS()}\n }\n </style>\n <div class=\"sub-widget-container\">${content}</div>\n ${this.renderSwapNonprofitButton()}\n `;\n }\n}\n\ndefineCustomElement(BeamSubscriptionManagement);\n\ndeclare global {\n interface HTMLElementTagNameMap {\n \"beam-subscription-management\": BeamSubscriptionManagement;\n }\n}\n"],"names":["strings","brandName","m","h","e","l","n","t","o","i","a","d","BeamSubscriptionManagement","LitElement","DEFAULT_BASE_URL","AsyncController","MissingConfig","enforceConfig","res","postChainEligibleNonprofitsForCart","result","postFindOrCreateSubscription","html","defaults","remoteConfig","config","_cssVariableMap","content","_errorMessage","event","BeamNonprofitSelectEvent","selectedNonprofitId","cssReset","css","__decorateClass","property","state","defineCustomElement"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"subscription-management.js","sources":["../../src/components/subscription-management/strings.ts","../../src/components/subscription-management/index.ts"],"sourcesContent":["export const strings = {\n en: {\n nonprofitSwapText: ({ brandName = \"\" }) => `Support a new nonprofit with your next ${brandName} recurring order`,\n },\n fr: {\n nonprofitSwapText: ({ brandName = \"\" }) =>\n `Soutenez une nouvelle organisation à but non lucratif avec votre prochaine commande récurrente ${brandName}`,\n },\n de: {\n nonprofitSwapText: ({ brandName = \"\" }) =>\n `Unterstützen Sie eine neue gemeinnützige Organisation mit Ihrer nächsten wiederkehrenden Bestellung bei ${brandName}`,\n },\n es: {\n nonprofitSwapText: ({ brandName = \"\" }) =>\n `Apoye a una nueva organización sin fines de lucro con su próximo pedido recurrente ${brandName}`,\n },\n it: {\n nonprofitSwapText: ({ brandName = \"\" }) =>\n `Sostieni una nuova organizzazione non profit con il tuo prossimo ordine ricorrente ${brandName}`,\n },\n pl: {\n nonprofitSwapText: ({ brandName = \"\" }) =>\n `Wesprzyj nową organizację non-profit przy kolejnym zamówieniu cyklicznym ${brandName}`,\n },\n};\n","import { css, html, LitElement } from \"lit\";\nimport { property } from \"lit/decorators/property.js\";\nimport { state } from \"lit/decorators/state.js\";\nimport { DEFAULT_BASE_URL, WIDGET_NAMES } from \"../../api-sdk/constants\";\nimport { LANGUAGES } from \"../../api-sdk/types\";\nimport { TCart } from \"../../shared/cart-contents\";\nimport { enforceConfig } from \"../../shared/enforce-config\";\nimport { postFindOrCreateSubscription, postChainEligibleNonprofitsForCart } from \"../../api-sdk/v3/routes\";\nimport { AsyncController } from \"../../shared/controllers/async-controller\";\nimport { cssReset } from \"../../shared/css-reset\";\nimport { defineCustomElement } from \"../../shared/defineCustomElement\";\nimport { _errorMessage } from \"../../shared/fragments/error-message-template\";\nimport { _cssVariableMap } from \"../../shared/fragments/css-variable-map\";\nimport { BeamNonprofitSelectEvent } from \"../../utils/events\";\nimport { MissingConfig } from \"../../utils/beam-errors\";\nimport { strings } from \"./strings\";\nimport \"../redeem-transaction\";\nimport \"../impact-overview\";\n\ninterface RequiredDataPropsWithEmail {\n email: string;\n apiKey: string;\n subscriptionId: string;\n}\n\ninterface RequiredDataPropsWithPartnerUserId {\n partnerUserId: string;\n apiKey: string;\n subscriptionId: string;\n}\n\ntype TRequiredDataProps = RequiredDataPropsWithEmail | RequiredDataPropsWithPartnerUserId;\nexport class BeamSubscriptionManagement extends LitElement {\n static tagName = \"beam-subscription-management\";\n\n @property({ type: String })\n public baseUrl: string = DEFAULT_BASE_URL;\n\n @property({ type: String })\n public apiKey!: TRequiredDataProps[\"apiKey\"];\n\n @property({ type: String })\n public subscriptionId!: TRequiredDataProps[\"subscriptionId\"];\n\n @property({ type: Number, reflect: true })\n public storeId?: number; // Either storeId or postalCode, countryCode must be provided\n\n @property({ type: String })\n public email?: RequiredDataPropsWithEmail[\"email\"]; // Either email or partnerUserId must be provided\n\n @property({ type: String })\n public partnerUserId?: RequiredDataPropsWithPartnerUserId[\"partnerUserId\"]; // Either email or partnerUserId must be provided\n\n @property({ type: String })\n public postalCode?: string;\n\n @property({ type: String })\n public countryCode?: string;\n\n @property({ type: String })\n public lang: LANGUAGES = \"en\";\n\n @property({ type: Object })\n public cart?: TCart;\n\n @property({ type: Boolean })\n public debug = false;\n\n @state() private activeWidget: \"redeem-transaction\" | \"impact-overview\" | null = null; // Based on /findSubscriptionByRemoteId\n @state() private nonprofitId: number | null = null; // From /findSubscriptionByRemoteId response\n @state() private userId: string | null = null; // From findSubscriptionByRemoteId\n @state() private chainName: string | null = null; // From findEligibleNonprofitsForCart\n\n private subscriptionDataController = new AsyncController<typeof this.fetchSubscription>(this, this.fetchSubscription);\n private eligibleNonprofitsDataController = new AsyncController<typeof this.fetchEligibleNonprofits>(\n this,\n this.fetchEligibleNonprofits\n );\n\n async firstUpdated() {\n if (!this.email && !this.partnerUserId) {\n throw new MissingConfig(\n [\"email\", \"partnerUserId\"],\n \"One of the following properties needs to be specified: email, partnerUserId \"\n );\n }\n enforceConfig<TRequiredDataProps>([\"apiKey\", \"subscriptionId\"], this);\n await this.loadWidget();\n }\n\n async loadWidget() {\n // In parallel:\n // (1). Fetch eligible nonprofits [storeId and chainName]\n // (2). Fetch subscription [userId and nonprofitId]\n await Promise.all([this.fetchEligibleNonprofits(), this.fetchSubscription()]);\n this.activeWidget = this.nonprofitId ? \"impact-overview\" : \"redeem-transaction\";\n }\n\n async fetchEligibleNonprofits() {\n enforceConfig<TRequiredDataProps>([\"apiKey\", \"subscriptionId\"], this);\n const res = await postChainEligibleNonprofitsForCart({\n baseUrl: this.baseUrl,\n headers: {\n authorization: `Api-Key ${this.apiKey}`,\n },\n requestBody: {\n storeId: this.storeId || undefined,\n postalCode: this.postalCode || undefined,\n countryCode: this.countryCode || undefined,\n widgetName: WIDGET_NAMES.subscription_management,\n version: \"1.0.0\",\n },\n });\n this.chainName = res.chain.name;\n this.storeId = res.store.id;\n this.eligibleNonprofitsDataController.data = res;\n return res;\n }\n\n async fetchSubscription() {\n enforceConfig<TRequiredDataProps>([\"apiKey\", \"subscriptionId\"], this);\n const result = await postFindOrCreateSubscription({\n baseUrl: this.baseUrl,\n headers: {\n authorization: `Api-Key ${this.apiKey}`,\n },\n requestBody: {\n remoteSubscriptionId: this.subscriptionId,\n email: this.email,\n partnerUserId: this.partnerUserId,\n },\n });\n\n this.userId = result.beamUserId; // Returned in response regardless of subscription redemption\n this.nonprofitId = result.nonprofit?.id || null;\n return result;\n }\n\n handleSwapNonprofitButtonClick() {\n this.activeWidget = \"redeem-transaction\";\n }\n\n renderSwapNonprofitButton() {\n if (this.activeWidget === \"impact-overview\") {\n return html`<button class=\"swap-nonprofit-button\" @click=\"${this.handleSwapNonprofitButtonClick}\">\n ${strings[this.lang].nonprofitSwapText({ brandName: this.chainName || \"\" })}\n </button>`;\n } else {\n return \"\";\n }\n }\n\n public get cssVariables() {\n const defaults = {\n \"--beam-fontFamily\": \"inherit\",\n \"--beam-fontStyle\": \"inherit\",\n \"--beam-fontSize\": \"inherit\",\n \"--beam-textColor\": \"inherit\",\n \"--beam-backgroundColor\": \"inherit\",\n \"--beam-SubscriptionManagement-widgetContainer-borderColor\": \"#d5d5d5\",\n \"--beam-SubscriptionManagement-widgetContainer-borderRadius\": \"4px\",\n \"--beam-SubscriptionManagement-widgetContainer-padding\": \"15px\",\n \"--beam-SubscriptionManagement-widgetContainer-backgroundColor\": \"inherit\",\n \"--beam-SubscriptionManagement-widgetContainer-maxWidth\": \"800px\",\n \"--beam-SubscriptionManagement-swapNonprofitButtonText-textDecoration\": \"underline\",\n \"--beam-SubscriptionManagement-swapNonprofitButtonText-fontFamily\": \"inherit\",\n \"--beam-SubscriptionManagement-swapNonprofitButtonText-fontStyle\": \"inherit\",\n \"--beam-SubscriptionManagement-swapNonprofitButtonText-fontWeight\": \"inherit\",\n \"--beam-SubscriptionManagement-swapNonprofitButtonText-lineHeight\": \"inherit\",\n \"--beam-SubscriptionManagement-swapNonprofitButtonText-marginTop\": \"10px\",\n \"--beam-SubscriptionManagement-swapNonprofitButtonText-fontSize\": \"inherit\",\n \"--beam-SubscriptionManagement-swapNonprofitButtonText-color\": \"inherit\",\n };\n\n const remoteConfig = this.eligibleNonprofitsDataController?.data?.config?.web?.theme || {};\n\n const config = { ...defaults, ...remoteConfig };\n\n const serializable = Object.create({\n toCSS() {\n return _cssVariableMap(this as Record<string, string>);\n },\n });\n return Object.assign(serializable, config);\n }\n\n static styles = [\n cssReset,\n css`\n :host {\n display: block;\n font-family: var(--beam-fontFamily);\n font-style: var(--beam-fontStyle);\n font-size: var(--beam-fontSize);\n background-color: var(--beam-backgroundColor);\n color: var(--beam-textColor);\n word-break: normal;\n }\n .swap-nonprofit-button {\n margin-top: var(--beam-SubscriptionManagement-swapNonprofitButtonText-marginTop, 10px);\n color: var(--beam-SubscriptionManagement-swapNonprofitButtonText-color, inherit);\n font-size: var(--beam-SubscriptionManagement-swapNonprofitButtonText-fontSize, inherit);\n text-decoration: var(--beam-SubscriptionManagement-swapNonprofitButtonText-textDecoration, underline);\n font-family: var(--beam-SubscriptionManagement-swapNonprofitButtonText-fontFamily, inherit);\n font-style: var(--beam-SubscriptionManagement-swapNonprofitButtonText-fontStyle, inherit);\n font-weight: var(--beam-SubscriptionManagement-swapNonprofitButtonText-fontWeight, inherit);\n line-height: var(--beam-SubscriptionManagement-swapNonprofitButtonText-lineHeight, inherit);\n background: none;\n border: none;\n cursor: pointer;\n }\n .sub-widget-container {\n background-color: var(--beam-SubscriptionManagement-widgetContainer-backgroundColor, inherit);\n border: 1px solid var(--beam-SubscriptionManagement-widgetContainer-borderColor, #d5d5d5);\n border-radius: var(--beam-SubscriptionManagement-widgetContainer-borderRadius, 4px);\n overflow: hidden; /* maintain clean border-radius */\n padding: var(--beam-SubscriptionManagement-widgetContainer-padding, 15px);\n max-width: var(--beam-SubscriptionManagement-widgetContainer-maxWidth, 800px);\n }\n }`,\n ];\n\n render() {\n let content;\n\n if (this.subscriptionDataController.loading || this.eligibleNonprofitsDataController.loading) {\n content = \"\";\n }\n\n if ((this.subscriptionDataController.error || this.eligibleNonprofitsDataController.error) && this.debug) {\n if (this.subscriptionDataController.error !== null) {\n return _errorMessage({ error: this.subscriptionDataController.error });\n } else if (this.eligibleNonprofitsDataController.error !== null) {\n return _errorMessage({ error: this.eligibleNonprofitsDataController.error });\n }\n } else {\n content = \"\";\n }\n\n if (this.activeWidget === \"redeem-transaction\") {\n content = html` <beam-redeem-transaction\n part=\"redeem-transaction\"\n storeId=\"${this.storeId}\"\n subscriptionId=\"${this.subscriptionId}\"\n nonprofitId=${this.nonprofitId}\n baseUrl=\"${this.baseUrl}\"\n apiKey=\"${this.apiKey}\"\n postalCode=\"${this.postalCode}\"\n countryCode=\"${this.countryCode}\"\n lang=\"${this.lang}\"\n ?debug=\"${this.debug}\"\n @beamnonprofitselect=\"${(event: Event) => {\n if (!(event instanceof BeamNonprofitSelectEvent)) return; // TS guard\n const { selectedNonprofitId } = event.detail;\n this.nonprofitId = selectedNonprofitId ?? null;\n this.activeWidget = \"impact-overview\";\n }}\"\n ></beam-redeem-transaction>`;\n } else if (this.activeWidget === \"impact-overview\") {\n content = html`\n <beam-impact-overview\n part=\"impact-overview\"\n baseUrl=\"${this.baseUrl}\"\n apiKey=\"${this.apiKey}\"\n userId=\"${this.userId}\"\n nonprofitId=\"${this.nonprofitId}\"\n lang=\"${this.lang}\"\n ?debug=\"${this.debug}\"\n ></beam-impact-overview>\n `;\n }\n return html`\n <style>\n :host {\n ${this.cssVariables.toCSS()}\n }\n </style>\n <div class=\"sub-widget-container\">${content}</div>\n ${this.renderSwapNonprofitButton()}\n `;\n }\n}\n\ndefineCustomElement(BeamSubscriptionManagement);\n\ndeclare global {\n interface HTMLElementTagNameMap {\n \"beam-subscription-management\": BeamSubscriptionManagement;\n }\n}\n"],"names":["strings","brandName","m","h","e","l","n","t","o","i","a","d","BeamSubscriptionManagement","LitElement","DEFAULT_BASE_URL","AsyncController","MissingConfig","enforceConfig","res","postChainEligibleNonprofitsForCart","WIDGET_NAMES","result","postFindOrCreateSubscription","html","defaults","remoteConfig","config","_cssVariableMap","content","_errorMessage","event","BeamNonprofitSelectEvent","selectedNonprofitId","cssReset","css","__decorateClass","property","state","defineCustomElement"],"mappings":"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"}
|
package/dist/index.d.ts
CHANGED
|
@@ -1,14 +1,14 @@
|
|
|
1
1
|
export { i as WebComponents } from './chunks/index-Hb-jziQs.esm.js';
|
|
2
|
-
export { i as Integrations } from './chunks/index-
|
|
2
|
+
export { i as Integrations } from './chunks/index-0VcD5nhV.esm.js';
|
|
3
3
|
export { i as ReactComponents } from './chunks/index-6t9MtjyS.esm.js';
|
|
4
|
-
export { i as Utils } from './chunks/index-
|
|
4
|
+
export { i as Utils } from './chunks/index-rFBYAk7m.esm.js';
|
|
5
5
|
import './components/community-impact.js';
|
|
6
6
|
import 'lit';
|
|
7
7
|
import 'lit-html';
|
|
8
8
|
import './chunks/progress-bar-0VS_AmEf.esm.js';
|
|
9
9
|
import './components/beam-partner-logos.js';
|
|
10
10
|
import './chunks/types-aju0qrRe.esm.js';
|
|
11
|
-
import './chunks/types-
|
|
11
|
+
import './chunks/types-CfbVJRfU.esm.js';
|
|
12
12
|
import './components/cumulative-impact.js';
|
|
13
13
|
import 'lodash';
|
|
14
14
|
import './components/impact-overview.js';
|
|
@@ -20,9 +20,9 @@ import './components/redeem-transaction.js';
|
|
|
20
20
|
import './components/post-purchase.js';
|
|
21
21
|
import './components/subscription-management.js';
|
|
22
22
|
import './components/product-details-page.js';
|
|
23
|
-
import './chunks/index-
|
|
23
|
+
import './chunks/index-8KzbQIsU.esm.js';
|
|
24
24
|
import './chunks/beam-errors-fXDkG1zo.esm.js';
|
|
25
|
-
import './chunks/events-
|
|
25
|
+
import './chunks/events-7cGXyV7_.esm.js';
|
|
26
26
|
import './utils/logger.js';
|
|
27
27
|
import './utils/network-listeners.js';
|
|
28
28
|
import './utils/local-storage.js';
|
package/dist/index.esm.js
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import{i as X}from"./chunks/index-V-BsPYtl.esm.js";import{i as Z}from"./chunks/index-
|
|
1
|
+
import{i as X}from"./chunks/index-V-BsPYtl.esm.js";import{i as Z}from"./chunks/index-xR738adx.esm.js";import{i as $}from"./chunks/index-o7YiP4gC.esm.js";import{i as to}from"./chunks/index-8yrr7ZZv.esm.js";import"./components/community-impact.esm.js";import"./chunks/lit-qtGbjGnK.esm.js";import"./chunks/progress-bar-Sn2QspHy.esm.js";import"./components/beam-partner-logos.esm.js";import"./chunks/localize-F31ae3j6.esm.js";import"./chunks/beam-errors-P-Lu07Ce.esm.js";import"./utils/logger.esm.js";import"./chunks/routes-b8sncPq8.esm.js";import"./chunks/loading-template-Av0IUyKF.esm.js";import"./chunks/css-card-grid-7tObtoJx.esm.js";import"./components/cumulative-impact.esm.js";import"./chunks/lodash-P8OIs-at.esm.js";import"./chunks/is-all-html-elements-SdSkxirh.esm.js";import"./components/impact-overview.esm.js";import"./chunks/shoelace-components-7XWYNn-Z.esm.js";import"./chunks/vendor-jQ8cxMpw.esm.js";import"./chunks/responsive-aWj_7ZN_.esm.js";import"./components/select-nonprofit.esm.js";import"./chunks/promo-pill-label-j0A8qZ0c.esm.js";import"./chunks/events-Y8fYvSqM.esm.js";import"./utils/network-listeners.esm.js";import"./utils/local-storage.esm.js";import"./utils/cookies.esm.js";import"./chunks/cart-contents-h60geKWa.esm.js";import"./components/redeem-transaction.esm.js";import"./components/post-purchase.esm.js";import"./components/subscription-management.esm.js";import"./components/product-details-page.esm.js";import"./utils/makeApiKeyHeader.esm.js";import"./chunks/index-Lw32NXij.esm.js";import"./utils/wait-for-element.esm.js";import"./utils/remote-session.esm.js";import"./utils/memoize-last.esm.js";import"./chunks/index-VELk9_yH.esm.js";import"./chunks/order-page-6Q-6CHug.esm.js";import"./chunks/update-cart-xW6a5_bz.esm.js";import"./chunks/index-Q1vx4WtG.esm.js";import"./chunks/index-U5URUABu.esm.js";import"./chunks/index-dsJIs5Sr.esm.js";import"./react/community-impact.esm.js";import"react";import"./react/cumulative-impact.esm.js";import"./react/impact-overview.esm.js";import"./react/select-nonprofit.esm.js";import"./react/redeem-transaction.esm.js";import"./react/post-purchase.esm.js";import"./react/subscription-management.esm.js";export{Z as Integrations,$ as ReactComponents,to as Utils,X as WebComponents};
|
|
2
2
|
//# sourceMappingURL=index.esm.js.map
|
package/dist/index.js
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import{i as X}from"./chunks/index-cekgAcEE.esm.js";import{i as Z}from"./chunks/index-
|
|
1
|
+
import{i as X}from"./chunks/index-cekgAcEE.esm.js";import{i as Z}from"./chunks/index-q_XLkvqc.esm.js";import{i as $}from"./chunks/index-EHubF2KN.esm.js";import{i as to}from"./chunks/index-uF-Qtewb.esm.js";import"./components/community-impact.js";import"./chunks/lit-qtGbjGnK.esm.js";import"./chunks/progress-bar-Sn2QspHy.esm.js";import"./components/beam-partner-logos.js";import"./chunks/localize-fH8KOrMi.esm.js";import"./chunks/beam-errors-P-Lu07Ce.esm.js";import"./utils/logger.js";import"./chunks/routes-3jKReDai.esm.js";import"./chunks/loading-template-Av0IUyKF.esm.js";import"./chunks/css-card-grid-7tObtoJx.esm.js";import"./components/cumulative-impact.js";import"./chunks/lodash-P8OIs-at.esm.js";import"./chunks/is-all-html-elements-SdSkxirh.esm.js";import"./components/impact-overview.js";import"./chunks/shoelace-components-paAsUPkU.esm.js";import"./chunks/vendor-jQ8cxMpw.esm.js";import"./chunks/responsive-aWj_7ZN_.esm.js";import"./components/select-nonprofit.js";import"./chunks/promo-pill-label-j0A8qZ0c.esm.js";import"./chunks/events-Y8fYvSqM.esm.js";import"./utils/network-listeners.js";import"./utils/local-storage.js";import"./utils/cookies.js";import"./chunks/cart-contents-h60geKWa.esm.js";import"./components/redeem-transaction.js";import"./components/post-purchase.js";import"./components/subscription-management.js";import"./components/product-details-page.js";import"./utils/makeApiKeyHeader.js";import"./chunks/index-phDmC-TS.esm.js";import"./utils/wait-for-element.js";import"./utils/remote-session.js";import"./utils/memoize-last.js";import"./chunks/index-xfPSpbUV.esm.js";import"./chunks/order-page-mYYXHDVr.esm.js";import"./chunks/update-cart-GaVMWI6J.esm.js";import"./chunks/index-uCfdsWtt.esm.js";import"./chunks/index-EUMlzqI-.esm.js";import"./chunks/index-XlnH7ARQ.esm.js";import"./react/community-impact.js";import"react";import"./react/cumulative-impact.js";import"./react/impact-overview.js";import"./react/select-nonprofit.js";import"./react/redeem-transaction.js";import"./react/post-purchase.js";import"./react/subscription-management.js";export{Z as Integrations,$ as ReactComponents,to as Utils,X as WebComponents};
|
|
2
2
|
//# sourceMappingURL=index.js.map
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import{D as u,a as g}from"../chunks/routes-
|
|
1
|
+
import{D as u,a as g}from"../chunks/routes-b8sncPq8.esm.js";import{S as y}from"../chunks/beam-errors-P-Lu07Ce.esm.js";import{B as h}from"../chunks/events-Y8fYvSqM.esm.js";import{logger as w}from"../utils/logger.esm.js";import{s as f}from"../chunks/index-dsJIs5Sr.esm.js";var v=(t,s,a)=>{if(!s.has(t))throw TypeError("Cannot "+a)},c=(t,s,a)=>{if(s.has(t))throw TypeError("Cannot add the same private member more than once");s instanceof WeakSet?s.add(t):s.set(t,a)},i=(t,s,a)=>(v(t,s,"access private method"),a),r,n,o,m;let p,l;const E=new Promise((t,s)=>{p=t,l=s});class U extends EventTarget{constructor(s){super(),c(this,r),c(this,o),this.readyPromise=E,this.plugins={},this.status="pending",i(this,r,n).call(this,s)}async init(s){i(this,r,n).call(this,s);try{await i(this,o,m).call(this,s)}catch(a){const e=new y;throw e.cause=a,this.status="error",this.dispatchEvent(new h({status:"error",error:e})),l(e),w.error(e),this.apiKey&&await f({apiKey:this.apiKey,baseUrl:this.logUrl},{type:"error",code:e.name,metadata:{message:e.message,cause:a?.message}}),a}return this.status="ready",this.dispatchEvent(new h({status:"ready"})),p(!0),this}}r=new WeakSet,n=function(t){this.apiKey=t.apiKey,this.chainId=t.chainId,this.storeId=t.storeId,this.domain=t.domain,this.baseUrl=t.baseUrl||u,this.logUrl=t.logUrl||g},o=new WeakSet,m=async function(t){const s=(t.plugins||[]).map(async a=>(await a.init(t),this.plugins[a.name]=a,a));return Promise.all(s)};const d=new U({}),S=t=>d.init(t),L=()=>d;export{L as getConfig,S as init};
|
|
2
2
|
//# sourceMappingURL=beam.esm.js.map
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import{D as u,a as g}from"../chunks/routes-
|
|
1
|
+
import{D as u,a as g}from"../chunks/routes-3jKReDai.esm.js";import{S as y}from"../chunks/beam-errors-P-Lu07Ce.esm.js";import{B as h}from"../chunks/events-Y8fYvSqM.esm.js";import{logger as w}from"../utils/logger.js";import{s as f}from"../chunks/index-XlnH7ARQ.esm.js";var v=(t,s,a)=>{if(!s.has(t))throw TypeError("Cannot "+a)},c=(t,s,a)=>{if(s.has(t))throw TypeError("Cannot add the same private member more than once");s instanceof WeakSet?s.add(t):s.set(t,a)},i=(t,s,a)=>(v(t,s,"access private method"),a),r,n,o,m;let p,l;const E=new Promise((t,s)=>{p=t,l=s});class U extends EventTarget{constructor(s){super(),c(this,r),c(this,o),this.readyPromise=E,this.plugins={},this.status="pending",i(this,r,n).call(this,s)}async init(s){i(this,r,n).call(this,s);try{await i(this,o,m).call(this,s)}catch(a){const e=new y;throw e.cause=a,this.status="error",this.dispatchEvent(new h({status:"error",error:e})),l(e),w.error(e),this.apiKey&&await f({apiKey:this.apiKey,baseUrl:this.logUrl},{type:"error",code:e.name,metadata:{message:e.message,cause:a?.message}}),a}return this.status="ready",this.dispatchEvent(new h({status:"ready"})),p(!0),this}}r=new WeakSet,n=function(t){this.apiKey=t.apiKey,this.chainId=t.chainId,this.storeId=t.storeId,this.domain=t.domain,this.baseUrl=t.baseUrl||u,this.logUrl=t.logUrl||g},o=new WeakSet,m=async function(t){const s=(t.plugins||[]).map(async a=>(await a.init(t),this.plugins[a.name]=a,a));return Promise.all(s)};const d=new U({}),S=t=>d.init(t),L=()=>d;export{L as getConfig,S as init};
|
|
2
2
|
//# sourceMappingURL=beam.js.map
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import{x as C}from"../chunks/update-cart-
|
|
1
|
+
import{x as C}from"../chunks/update-cart-xW6a5_bz.esm.js";import"../chunks/lodash-P8OIs-at.esm.js";import"../chunks/routes-b8sncPq8.esm.js";import"../chunks/beam-errors-P-Lu07Ce.esm.js";import"../utils/logger.esm.js";import"../chunks/events-Y8fYvSqM.esm.js";import"../utils/network-listeners.esm.js";import"../utils/local-storage.esm.js";import"../utils/cookies.esm.js";import"../utils/remote-session.esm.js";import"../utils/memoize-last.esm.js";import"../chunks/cart-contents-h60geKWa.esm.js";export{C as updateCart};
|
|
2
2
|
//# sourceMappingURL=cart.esm.js.map
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import{x as C}from"../chunks/update-cart-
|
|
1
|
+
import{x as C}from"../chunks/update-cart-GaVMWI6J.esm.js";import"../chunks/lodash-P8OIs-at.esm.js";import"../chunks/routes-3jKReDai.esm.js";import"../chunks/beam-errors-P-Lu07Ce.esm.js";import"../utils/logger.js";import"../chunks/events-Y8fYvSqM.esm.js";import"../utils/network-listeners.js";import"../utils/local-storage.js";import"../utils/cookies.js";import"../utils/remote-session.js";import"../utils/memoize-last.js";import"../chunks/cart-contents-h60geKWa.esm.js";export{C as updateCart};
|
|
2
2
|
//# sourceMappingURL=cart.js.map
|
|
@@ -1,13 +1,13 @@
|
|
|
1
|
-
export { i as Utils } from '../chunks/index-
|
|
1
|
+
export { i as Utils } from '../chunks/index-8KzbQIsU.esm.js';
|
|
2
2
|
export { i as Shopify } from '../chunks/index-SxFKifVJ.esm.js';
|
|
3
3
|
export { i as Session } from '../chunks/index-EGiUuWe-.esm.js';
|
|
4
4
|
export { i as Cart } from '../chunks/index-HBDtoJlQ.esm.js';
|
|
5
5
|
export { i as Logs } from '../chunks/index-TOzSFOvI.esm.js';
|
|
6
6
|
import '../chunks/beam-errors-fXDkG1zo.esm.js';
|
|
7
|
-
import '../chunks/events-
|
|
7
|
+
import '../chunks/events-7cGXyV7_.esm.js';
|
|
8
8
|
import '../chunks/cart-contents-3-9fB-7m.esm.js';
|
|
9
9
|
import '../chunks/openapi-spec--MzXvfCC.esm.js';
|
|
10
|
-
import '../chunks/types-
|
|
10
|
+
import '../chunks/types-CfbVJRfU.esm.js';
|
|
11
11
|
import '../utils/logger.js';
|
|
12
12
|
import '../utils/network-listeners.js';
|
|
13
13
|
import '../utils/local-storage.js';
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import{i as A}from"../chunks/index-
|
|
1
|
+
import{i as A}from"../chunks/index-Lw32NXij.esm.js";import{i as D}from"../chunks/index-VELk9_yH.esm.js";import{i as F}from"../chunks/index-Q1vx4WtG.esm.js";import{i as H}from"../chunks/index-U5URUABu.esm.js";import{i as J}from"../chunks/index-dsJIs5Sr.esm.js";import"../chunks/beam-errors-P-Lu07Ce.esm.js";import"../chunks/events-Y8fYvSqM.esm.js";import"../utils/logger.esm.js";import"../utils/network-listeners.esm.js";import"../utils/local-storage.esm.js";import"../utils/wait-for-element.esm.js";import"../utils/cookies.esm.js";import"../utils/remote-session.esm.js";import"../utils/memoize-last.esm.js";import"../chunks/lodash-P8OIs-at.esm.js";import"../chunks/order-page-6Q-6CHug.esm.js";import"../chunks/cart-contents-h60geKWa.esm.js";import"../chunks/update-cart-xW6a5_bz.esm.js";import"../chunks/routes-b8sncPq8.esm.js";import"../components/post-purchase.esm.js";import"../chunks/lit-qtGbjGnK.esm.js";import"../chunks/localize-F31ae3j6.esm.js";import"../components/redeem-transaction.esm.js";import"../chunks/progress-bar-Sn2QspHy.esm.js";import"../chunks/promo-pill-label-j0A8qZ0c.esm.js";import"../chunks/vendor-jQ8cxMpw.esm.js";import"../components/beam-partner-logos.esm.js";import"../chunks/loading-template-Av0IUyKF.esm.js";import"../chunks/css-card-grid-7tObtoJx.esm.js";import"../components/impact-overview.esm.js";import"../chunks/shoelace-components-7XWYNn-Z.esm.js";import"../chunks/is-all-html-elements-SdSkxirh.esm.js";import"../chunks/responsive-aWj_7ZN_.esm.js";export{H as Cart,J as Logs,F as Session,D as Shopify,A as Utils};
|
|
2
2
|
//# sourceMappingURL=index.esm.js.map
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import{i as A}from"../chunks/index-phDmC-TS.esm.js";import{i as D}from"../chunks/index-
|
|
1
|
+
import{i as A}from"../chunks/index-phDmC-TS.esm.js";import{i as D}from"../chunks/index-xfPSpbUV.esm.js";import{i as F}from"../chunks/index-uCfdsWtt.esm.js";import{i as H}from"../chunks/index-EUMlzqI-.esm.js";import{i as J}from"../chunks/index-XlnH7ARQ.esm.js";import"../chunks/beam-errors-P-Lu07Ce.esm.js";import"../chunks/events-Y8fYvSqM.esm.js";import"../utils/logger.js";import"../utils/network-listeners.js";import"../utils/local-storage.js";import"../utils/wait-for-element.js";import"../utils/cookies.js";import"../utils/remote-session.js";import"../utils/memoize-last.js";import"../chunks/lodash-P8OIs-at.esm.js";import"../chunks/order-page-mYYXHDVr.esm.js";import"../chunks/cart-contents-h60geKWa.esm.js";import"../chunks/update-cart-GaVMWI6J.esm.js";import"../chunks/routes-3jKReDai.esm.js";import"../components/post-purchase.js";import"../chunks/lit-qtGbjGnK.esm.js";import"../chunks/localize-fH8KOrMi.esm.js";import"../components/redeem-transaction.js";import"../chunks/progress-bar-Sn2QspHy.esm.js";import"../chunks/promo-pill-label-j0A8qZ0c.esm.js";import"../chunks/vendor-jQ8cxMpw.esm.js";import"../components/beam-partner-logos.js";import"../chunks/loading-template-Av0IUyKF.esm.js";import"../chunks/css-card-grid-7tObtoJx.esm.js";import"../components/impact-overview.js";import"../chunks/shoelace-components-paAsUPkU.esm.js";import"../chunks/is-all-html-elements-SdSkxirh.esm.js";import"../chunks/responsive-aWj_7ZN_.esm.js";export{H as Cart,J as Logs,F as Session,D as Shopify,A as Utils};
|
|
2
2
|
//# sourceMappingURL=index.js.map
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import"../chunks/routes-
|
|
1
|
+
import"../chunks/routes-b8sncPq8.esm.js";import"../utils/logger.esm.js";import{s as i}from"../chunks/index-dsJIs5Sr.esm.js";import"../chunks/beam-errors-P-Lu07Ce.esm.js";export{i as sendLog};
|
|
2
2
|
//# sourceMappingURL=logs.esm.js.map
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import"../chunks/routes-
|
|
1
|
+
import"../chunks/routes-3jKReDai.esm.js";import"../utils/logger.js";import{s as i}from"../chunks/index-XlnH7ARQ.esm.js";import"../chunks/beam-errors-P-Lu07Ce.esm.js";export{i as sendLog};
|
|
2
2
|
//# sourceMappingURL=logs.js.map
|
|
@@ -11,5 +11,5 @@ import '../components/redeem-transaction.js';
|
|
|
11
11
|
import '../chunks/progress-bar-0VS_AmEf.esm.js';
|
|
12
12
|
import '../chunks/promo-pill-label-3bA1z-la.esm.js';
|
|
13
13
|
import '../components/beam-partner-logos.js';
|
|
14
|
-
import '../chunks/types-
|
|
14
|
+
import '../chunks/types-CfbVJRfU.esm.js';
|
|
15
15
|
import '../components/impact-overview.js';
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import{
|
|
1
|
+
import{I as j,f as l,R as q,s as v,k as y}from"../chunks/order-page-6Q-6CHug.esm.js";import"../chunks/lodash-P8OIs-at.esm.js";import"../chunks/events-Y8fYvSqM.esm.js";import"../utils/logger.esm.js";import"../utils/network-listeners.esm.js";import"../utils/local-storage.esm.js";import"../chunks/beam-errors-P-Lu07Ce.esm.js";import"../utils/cookies.esm.js";import"../utils/memoize-last.esm.js";import"../chunks/cart-contents-h60geKWa.esm.js";import"../chunks/update-cart-xW6a5_bz.esm.js";import"../chunks/routes-b8sncPq8.esm.js";import"../utils/remote-session.esm.js";import"../components/post-purchase.esm.js";import"../chunks/lit-qtGbjGnK.esm.js";import"../chunks/localize-F31ae3j6.esm.js";import"../components/redeem-transaction.esm.js";import"../chunks/progress-bar-Sn2QspHy.esm.js";import"../chunks/promo-pill-label-j0A8qZ0c.esm.js";import"../chunks/vendor-jQ8cxMpw.esm.js";import"../components/beam-partner-logos.esm.js";import"../chunks/loading-template-Av0IUyKF.esm.js";import"../chunks/css-card-grid-7tObtoJx.esm.js";import"../components/impact-overview.esm.js";import"../chunks/shoelace-components-7XWYNn-Z.esm.js";import"../chunks/is-all-html-elements-SdSkxirh.esm.js";import"../chunks/responsive-aWj_7ZN_.esm.js";import"../utils/wait-for-element.esm.js";export{j as addBeamAttributesToCart,l as getCurrentCart,q as registerCartIntegration,v as showBeamOrderPageWidgets,y as trackCart};
|
|
2
2
|
//# sourceMappingURL=shopify.esm.js.map
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import{
|
|
1
|
+
import{I as j,f as l,R as q,s as v,k as y}from"../chunks/order-page-mYYXHDVr.esm.js";import"../chunks/lodash-P8OIs-at.esm.js";import"../chunks/events-Y8fYvSqM.esm.js";import"../utils/logger.js";import"../utils/network-listeners.js";import"../utils/local-storage.js";import"../chunks/beam-errors-P-Lu07Ce.esm.js";import"../utils/cookies.js";import"../utils/memoize-last.js";import"../chunks/cart-contents-h60geKWa.esm.js";import"../chunks/update-cart-GaVMWI6J.esm.js";import"../chunks/routes-3jKReDai.esm.js";import"../utils/remote-session.js";import"../components/post-purchase.js";import"../chunks/lit-qtGbjGnK.esm.js";import"../chunks/localize-fH8KOrMi.esm.js";import"../components/redeem-transaction.js";import"../chunks/progress-bar-Sn2QspHy.esm.js";import"../chunks/promo-pill-label-j0A8qZ0c.esm.js";import"../chunks/vendor-jQ8cxMpw.esm.js";import"../components/beam-partner-logos.js";import"../chunks/loading-template-Av0IUyKF.esm.js";import"../chunks/css-card-grid-7tObtoJx.esm.js";import"../components/impact-overview.js";import"../chunks/shoelace-components-paAsUPkU.esm.js";import"../chunks/is-all-html-elements-SdSkxirh.esm.js";import"../chunks/responsive-aWj_7ZN_.esm.js";import"../utils/wait-for-element.js";export{j as addBeamAttributesToCart,l as getCurrentCart,q as registerCartIntegration,v as showBeamOrderPageWidgets,y as trackCart};
|
|
2
2
|
//# sourceMappingURL=shopify.js.map
|
|
@@ -1,12 +1,13 @@
|
|
|
1
|
-
import{p as R}from"../chunks/routes-
|
|
1
|
+
import{p as R}from"../chunks/routes-b8sncPq8.esm.js";import{B as M}from"../chunks/cart-contents-h60geKWa.esm.js";import{a as $,b as D,c as O}from"../chunks/events-Y8fYvSqM.esm.js";import{B as m}from"../chunks/beam-errors-P-Lu07Ce.esm.js";import{getCookieValue as f,setCookieValue as W}from"../utils/cookies.esm.js";import{logger as C}from"../utils/logger.esm.js";import{saveRemoteSession as K}from"../utils/remote-session.esm.js";import"../utils/local-storage.esm.js";var w=(e,t,i)=>{if(!t.has(e))throw TypeError("Cannot "+i)},d=(e,t,i)=>(w(e,t,"read from private field"),i?i.call(e):t.get(e)),n=(e,t,i)=>{if(t.has(e))throw TypeError("Cannot add the same private member more than once");t instanceof WeakSet?t.add(e):t.set(e,i)},_=(e,t,i,s)=>(w(e,t,"write to private field"),s?s.call(e,i):t.set(e,i),i),r=(e,t,i)=>(w(e,t,"access private method"),i),h,c,E,T,b,A,l,v,B,g,S,y,L,I,k;const P=4,j=`https://cdn.jsdelivr.net/npm/statsig-js@${P}/build/statsig-prod-web-sdk.min.js`,x="beam_statsig_session_id",o="data-beam-visibility",z="beam-sync-visibility",p={STATSIG_INIT:"statsig_init",CART_CREATED:"cart_created",ORDER_CREATED:"order_created",BEAM_SELECTION:"beam_selection"};class G{constructor(t){n(this,E),n(this,b),n(this,v),n(this,g),n(this,y),n(this,I),this.name="statsig",this.experiments={shouldShowBeam:!1,isLoggingEnabled:!0},n(this,h,void 0),n(this,c,void 0),n(this,l,[]),this.statsigApiKey=t.statsigApiKey}async init(t){_(this,h,t),r(this,E,T).call(this),r(this,g,S).call(this,"hide");const i=document.createElement("style");if(i.innerHTML=`
|
|
2
2
|
[${o}="hide"] beam-select-nonprofit,
|
|
3
3
|
[${o}="hide"] beam-post-purchase,
|
|
4
4
|
[${o}="hide"] beam-redeem-transaction,
|
|
5
5
|
[${o}="hide"] beam-impact-overview,
|
|
6
6
|
[${o}="hide"] beam-community-impact,
|
|
7
7
|
[${o}="hide"] beam-cumulative-impact,
|
|
8
|
+
[${o}="hide"] beam-product-details-page,
|
|
8
9
|
[${o}="hide"] .${z} {
|
|
9
10
|
display: none;
|
|
10
11
|
}
|
|
11
|
-
`,document.head.append(i),await r(this,b,A).call(this),this.stableId=this.statsig.getStableID(),!this.stableId)throw new m("Statsig failed to assign stableId",{name:"StatsigInitError"});r(this,v,B).call(this),K({remoteSessionId:this.stableId,apiKey:t.apiKey}),_(this,c,f(M))
|
|
12
|
+
`,document.head.append(i),await r(this,b,A).call(this),this.stableId=this.statsig.getStableID(),!this.stableId)throw new m("Statsig failed to assign stableId",{name:"StatsigInitError"});r(this,v,B).call(this),K({remoteSessionId:this.stableId,apiKey:t.apiKey}),_(this,c,f(M)),W({name:x,value:this.stableId,path:"/",domain:t.domain}),this.experiments={shouldShowBeam:this.statsig.getLayer("beam_trial_layer").get("show_beam",!1),isLoggingEnabled:this.statsig.getLayer("beam_trial_layer").get("enable_logging",!0)},await Promise.all([r(this,y,L).call(this),r(this,I,k).call(this)]),r(this,g,S).call(this,this.experiments.shouldShowBeam?"show":"hide"),C.debug("Statsig Experiment Assignments",this.experiments)}logEvent(t,i,s={}){if(!this.statsig){d(this,l).push([t,i,s]);return}const a=this.experiments.shouldShowBeam;this.experiments.isLoggingEnabled&&this.statsig.logEvent(t,i,{...s,withBeam:a}),C.debug(t,i,{...s,withBeam:a})}}h=new WeakMap,c=new WeakMap,E=new WeakSet,T=function(){window.addEventListener($.eventName,t=>{const i=t,{itemCount:s,cartId:a,subtotal:u,currencyCode:N}=i.detail;this.logEvent(p.CART_CREATED,!0,{itemCount:s,cartId:a,subtotal:u,currencyCode:N})}),window.addEventListener(D.eventName,t=>{const i=t,{orderId:s,cartTotal:a,currencyCode:u}=i.detail;this.logEvent(p.ORDER_CREATED,a,{orderId:s,cartTotal:a,currencyCode:u,hasCart:!!d(this,c)})});let e;window.addEventListener(O.eventName,t=>{const i=t,{selectedNonprofitId:s,selectionId:a}=i.detail;s!==e&&(this.logEvent(p.BEAM_SELECTION,!0,{nonprofitId:s,widget:"select-nonprofit",selectionId:a}),e=s)})},b=new WeakSet,A=async function(){const e=document.createElement("script");e.src=j,e.async=!1;const t=new Promise((s,a)=>{e.addEventListener("load",s),e.addEventListener("error",a)});document.head.append(e);try{await t}catch{throw new m("Failed to load Statsig script",{name:"StatsigInitError"})}if(this.statsig=window.statsig,!this.statsig)throw new m("Failed to detect Statsig",{name:"StatsigInitError"});const i={disableErrorLogging:!0,disableAutoMetricsLogging:!0,disableCurrentPageLogging:!0,loggingIntervalMillis:1e3,loggingBufferMaxSize:2,overrideStableID:f(x)??null};await this.statsig.initialize(this.statsigApiKey,{},i)},l=new WeakMap,v=new WeakSet,B=function(){for(;d(this,l).length>0;){const e=d(this,l).shift();e&&this.logEvent(...e)}},g=new WeakSet,S=function(e){document.body.setAttribute(o,e)},y=new WeakSet,L=async function(){const e="https://events.statsigapi.net/v1/log_event";try{await fetch(e,{method:"POST",headers:{"content-type":"application/json","statsig-api-key":this.statsigApiKey},body:JSON.stringify({eventName:p.STATSIG_INIT,value:"true",time:new Date().getTime()/1e3,metadata:{show_beam:this.experiments.shouldShowBeam.toString(),page:window.location.pathname},user:{userID:this.stableId}})})}catch(t){throw new m("Could not call Statsig API",{name:"StatsigInitError",cause:t})}},I=new WeakSet,k=async function(){return R({baseUrl:d(this,h)?.baseUrl,headers:{authorization:`Api-Key ${d(this,h)?.apiKey}`},requestBody:{remoteSessionId:this.stableId,experiments:{showBeam:this.experiments.shouldShowBeam}}})};export{G as StatsigPlugin};
|
|
12
13
|
//# sourceMappingURL=statsig.esm.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"statsig.esm.js","sources":["../../src/integrations/statsig/plugin.ts"],"sourcesContent":["import { postExperimentSession } from \"../../api-sdk/v3/routes\";\nimport { BEAM_CART_COOKIE_NAME } from \"../../shared/cart-contents\";\nimport { BeamCartCreatedEvent, BeamNonprofitSelectEvent, BeamOrderCreatedEvent } from \"../../utils/events\";\nimport { BeamPlugin, BeamConfigOptions } from \"../beam\";\nimport { BeamError } from \"../../utils/beam-errors\";\nimport { getCookieValue, setCookieValue } from \"../../utils/cookies\";\nimport { logger } from \"../../utils/logger\";\nimport { saveRemoteSession } from \"../../utils/remote-session\";\n\n/**\n * StatSig Docs: https://docs.statsig.com/client/jsClientSDK\n */\ntype StatsigPluginOptions = {\n statsigApiKey: string;\n};\n\ndeclare global {\n interface Window {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n statsig?: any; // attached by Statsig CDN script\n }\n}\n\nconst STATSIG_VERSION = 4;\n\nconst STATSIG_SCRIPT_URL = `https://cdn.jsdelivr.net/npm/statsig-js@${STATSIG_VERSION}/build/statsig-prod-web-sdk.min.js`;\n\nconst STATSIG_STABLE_ID_COOKIE = \"beam_statsig_session_id\";\n\nconst BEAM_VISIBILITY_DATA_ATTRIBUTE = \"data-beam-visibility\";\n\n// Add class to elements that should only show when Beam shows\nconst BEAM_VISIBILITY_SYNCED_CLASS = \"beam-sync-visibility\";\n\nconst BEAM_AB_TEST_EVENTS = {\n STATSIG_INIT: \"statsig_init\",\n CART_CREATED: \"cart_created\",\n ORDER_CREATED: \"order_created\",\n BEAM_SELECTION: \"beam_selection\",\n};\n\ntype Experiments = {\n /** Whether Beam widgets should be shown to users */\n shouldShowBeam: boolean;\n /** Whether events should be logged to Statsig */\n isLoggingEnabled: boolean;\n};\n\n/**\n * Sets up Statsig for A/B testing and shows/hides Beam based on default experiment rules.\n * @example\n * import { StatsigPlugin } from '@beamimpact/web-sdk/dist/integrations/statsig'\n * import { init } from '@beamimpact/web-sdk/dist/integrations/beam'\n *\n * const beam = await init({\n * apiKey: '',\n * chainId: 1,\n * storeId: 1,\n * domain: 'my-store.com' // in case site uses subdomains for different pages\n * plugins: [\n * new StatsigPlugin({ statsigApiKey: '' })\n * ]\n * })\n *\n * // Once initialized, all Beam widgets have display: none unless user is assigned to A/B test group that shows Beam\n * // To hide additional elements, add the CSS className \"beam-sync-visibility\" to them\n * // To programmatically access the experiment state: getConfig().plugins.statsig.experiments.shouldShowBeam\n */\nexport class StatsigPlugin implements BeamPlugin {\n name = \"statsig\";\n\n statsig: any; // Statsig SDK instance\n\n statsigApiKey: string;\n\n experiments: Experiments = {\n shouldShowBeam: false,\n isLoggingEnabled: true,\n };\n\n stableId?: string;\n\n #beamConfig?: BeamConfigOptions;\n\n // Checked at initialization so that we can tell if post-purchase events came from a session with a cart or not\n #beamCartCookie?: string;\n\n constructor(options: StatsigPluginOptions) {\n this.statsigApiKey = options.statsigApiKey;\n }\n\n async init(config: BeamConfigOptions) {\n this.#beamConfig = config;\n\n // Add event listeners for cart/order lifecycle events\n // This should happen as soon as possible to avoid missing events\n this.#attachEventListeners();\n\n // Attach beam-visibility data attribute to body\n this.#setBeamVisibilityValue(\"hide\");\n\n // Create beam a/b test stylesheet\n const beamVisibilityStylesheet = document.createElement(\"style\");\n beamVisibilityStylesheet.innerHTML = `\n [${BEAM_VISIBILITY_DATA_ATTRIBUTE}=\"hide\"] beam-select-nonprofit,\n [${BEAM_VISIBILITY_DATA_ATTRIBUTE}=\"hide\"] beam-post-purchase,\n [${BEAM_VISIBILITY_DATA_ATTRIBUTE}=\"hide\"] beam-redeem-transaction,\n [${BEAM_VISIBILITY_DATA_ATTRIBUTE}=\"hide\"] beam-impact-overview,\n [${BEAM_VISIBILITY_DATA_ATTRIBUTE}=\"hide\"] beam-community-impact,\n [${BEAM_VISIBILITY_DATA_ATTRIBUTE}=\"hide\"] beam-cumulative-impact,\n [${BEAM_VISIBILITY_DATA_ATTRIBUTE}=\"hide\"] .${BEAM_VISIBILITY_SYNCED_CLASS} {\n display: none;\n }\n `;\n document.head.append(beamVisibilityStylesheet);\n\n // Create statsig script\n await this.#initializeStatsig();\n this.stableId = this.statsig.getStableID();\n if (!this.stableId) {\n throw new BeamError(\"Statsig failed to assign stableId\", { name: \"StatsigInitError\" });\n }\n\n // Send events that happened before Statsig was ready\n this.#flushEventQueue();\n\n // Save Statsig ID in localStorage for linking to carts later\n saveRemoteSession({ remoteSessionId: this.stableId, apiKey: config.apiKey });\n\n // Save initial value of cart cookie so that post-purchase events can be filtered by if they had a cart or not\n this.#beamCartCookie = getCookieValue(BEAM_CART_COOKIE_NAME);\n\n // Cache ID in cookie to preserve ID across subdomains\n setCookieValue({\n name: STATSIG_STABLE_ID_COOKIE,\n value: this.stableId,\n path: \"/\",\n domain: config.domain,\n });\n\n // Evaluate Statsig experiment assignments\n this.experiments = {\n // Whether Beam widgets should be shown to users\n shouldShowBeam: this.statsig\n .getLayer(\"beam_trial_layer\")\n .get(\"show_beam\", false /* default to hide */) as boolean,\n // Whether events should be logged to Statsig\n isLoggingEnabled: this.statsig.getLayer(\"beam_trial_layer\").get(\"enable_logging\", true) as boolean,\n };\n\n // In parallel:\n // A) Make test call to Statsig\n // B) Save stable ID in Beam for attribution to carts/transactions\n await Promise.all([this.#testStatsigConnection(), this.#registerExperimentWithBeam()]);\n\n // Update beam visibility data attribute, which shows Beam to users in the experiment\n this.#setBeamVisibilityValue(this.experiments.shouldShowBeam ? \"show\" : \"hide\");\n\n // Log result\n logger.debug(\"Statsig Experiment Assignments\", this.experiments);\n }\n\n #attachEventListeners() {\n // Cart Created\n window.addEventListener(BeamCartCreatedEvent.eventName, (_event: Event) => {\n const event = _event as BeamCartCreatedEvent;\n const { itemCount, cartId, subtotal, currencyCode } = event.detail;\n this.logEvent(BEAM_AB_TEST_EVENTS.CART_CREATED, true, { itemCount, cartId, subtotal, currencyCode });\n });\n\n // Order Created\n window.addEventListener(BeamOrderCreatedEvent.eventName, (_event: Event) => {\n const event = _event as BeamOrderCreatedEvent;\n const { orderId, cartTotal, currencyCode } = event.detail;\n this.logEvent(BEAM_AB_TEST_EVENTS.ORDER_CREATED, cartTotal, {\n orderId,\n cartTotal,\n currencyCode,\n hasCart: !!this.#beamCartCookie,\n });\n });\n\n // Beam Selection\n // Store previous value in case widget is recreated and emits event again:\n let lastSelectedNonprofitId: number | null | undefined;\n window.addEventListener(BeamNonprofitSelectEvent.eventName, (_event: Event) => {\n const event = _event as BeamNonprofitSelectEvent;\n const { selectedNonprofitId, selectionId } = event.detail;\n if (selectedNonprofitId !== lastSelectedNonprofitId) {\n this.logEvent(BEAM_AB_TEST_EVENTS.BEAM_SELECTION, true, {\n nonprofitId: selectedNonprofitId,\n widget: \"select-nonprofit\",\n selectionId,\n });\n lastSelectedNonprofitId = selectedNonprofitId;\n }\n });\n }\n\n // https://docs.statsig.com/client/jsClientSDK#statsig-options\n async #initializeStatsig() {\n const statsigScript = document.createElement(\"script\");\n statsigScript.src = STATSIG_SCRIPT_URL;\n statsigScript.async = false;\n const statsigReadyPromise = new Promise((res, rej) => {\n statsigScript.addEventListener(\"load\", res);\n statsigScript.addEventListener(\"error\", rej);\n });\n document.head.append(statsigScript);\n try {\n await statsigReadyPromise;\n } catch (err) {\n throw new BeamError(\"Failed to load Statsig script\", { name: \"StatsigInitError\" });\n }\n this.statsig = window.statsig;\n if (!this.statsig) {\n throw new BeamError(\"Failed to detect Statsig\", { name: \"StatsigInitError\" });\n }\n // https://docs.statsig.com/client/jsClientSDK#statsig-options\n const statsigOptions = {\n disableErrorLogging: true,\n disableAutoMetricsLogging: true,\n disableCurrentPageLogging: true,\n loggingIntervalMillis: 1000,\n loggingBufferMaxSize: 2,\n overrideStableID: getCookieValue(STATSIG_STABLE_ID_COOKIE) ?? null,\n };\n await this.statsig.initialize(this.statsigApiKey, {}, statsigOptions);\n }\n\n #eventQueue: Parameters<typeof StatsigPlugin.prototype.logEvent>[] = [];\n\n #flushEventQueue() {\n while (this.#eventQueue.length > 0) {\n const eventParams = this.#eventQueue.shift();\n if (eventParams) {\n this.logEvent(...eventParams);\n }\n }\n }\n\n logEvent(name: string, value: string | number | boolean, metadata: Record<string, any> = {}) {\n if (!this.statsig) {\n this.#eventQueue.push([name, value, metadata]);\n return;\n }\n const withBeam = this.experiments.shouldShowBeam;\n if (this.experiments.isLoggingEnabled) {\n this.statsig.logEvent(name, value, { ...metadata, withBeam });\n }\n logger.debug(name, value, { ...metadata, withBeam });\n }\n\n #setBeamVisibilityValue(value: \"show\" | \"hide\") {\n document.body.setAttribute(BEAM_VISIBILITY_DATA_ATTRIBUTE, value);\n }\n\n async #testStatsigConnection() {\n // Use the HTTP API so we can synchronously detect if Statsig is reachable,\n // rather than pushing an event to the SDK's retryable queue.\n // https://docs.statsig.com/http-api\n const url = \"https://events.statsigapi.net/v1/log_event\";\n try {\n await fetch(url, {\n method: \"POST\",\n headers: {\n \"content-type\": \"application/json\",\n \"statsig-api-key\": this.statsigApiKey,\n },\n body: JSON.stringify({\n eventName: BEAM_AB_TEST_EVENTS.STATSIG_INIT,\n value: \"true\",\n time: new Date().getTime() / 1000, // unix timestamp (seconds not milliseconds)\n metadata: {\n show_beam: this.experiments.shouldShowBeam.toString(),\n page: window.location.pathname,\n },\n user: {\n userID: this.stableId,\n },\n }),\n });\n } catch (err) {\n throw new BeamError(\"Could not call Statsig API\", { name: \"StatsigInitError\", cause: err });\n // TODO: this will log failures to Beam's error tracking API in the future\n }\n }\n\n async #registerExperimentWithBeam() {\n return postExperimentSession({\n baseUrl: this.#beamConfig?.baseUrl,\n headers: {\n authorization: `Api-Key ${this.#beamConfig?.apiKey}`,\n },\n requestBody: {\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n remoteSessionId: this.stableId!,\n experiments: {\n showBeam: this.experiments.shouldShowBeam,\n },\n },\n });\n }\n}\n"],"names":["i","e","g","_beamConfig","_beamCartCookie","_attachEventListeners","attachEventListeners_fn","_initializeStatsig","initializeStatsig_fn","_eventQueue","_flushEventQueue","flushEventQueue_fn","_setBeamVisibilityValue","setBeamVisibilityValue_fn","_testStatsigConnection","testStatsigConnection_fn","_registerExperimentWithBeam","registerExperimentWithBeam_fn","STATSIG_VERSION","STATSIG_SCRIPT_URL","STATSIG_STABLE_ID_COOKIE","BEAM_VISIBILITY_DATA_ATTRIBUTE","BEAM_VISIBILITY_SYNCED_CLASS","BEAM_AB_TEST_EVENTS","StatsigPlugin","options","__privateAdd","config","__privateSet","__privateMethod","beamVisibilityStylesheet","BeamError","saveRemoteSession","getCookieValue","BEAM_CART_COOKIE_NAME","setCookieValue","logger","name","value","metadata","__privateGet","withBeam","BeamCartCreatedEvent","_event","event","itemCount","cartId","subtotal","currencyCode","BeamOrderCreatedEvent","orderId","cartTotal","lastSelectedNonprofitId","BeamNonprofitSelectEvent","selectedNonprofitId","selectionId","statsigScript","statsigReadyPromise","res","rej","statsigOptions","eventParams","url","err","postExperimentSession"],"mappings":"odAAA,IAAA,EAAA,CAAAA,EAAA,EAAAC,IAAA,CAAA,GAAA,CAAA,EAAA,IAAAD,CAAA,EAAA,MAAA,UAAA,UAAAC,CAAA,CAAA,EAAAC,EAAA,CAAAF,EAAA,EAAAC,KAAA,EAAAD,EAAA,EAAA,yBAAA,EAAAC,EAAAA,EAAA,KAAAD,CAAA,EAAA,EAAA,IAAAA,CAAA,GAAA,EAAA,CAAAA,EAAA,EAAAC,IAAA,CAAA,GAAA,EAAA,IAAAD,CAAA,EAAA,MAAA,UAAA,mDAAA,EAAA,aAAA,QAAA,EAAA,IAAAA,CAAA,EAAA,EAAA,IAAAA,EAAAC,CAAA,CAAA,EAAA,EAAA,CAAAD,EAAA,EAAAC,EAAA,KAAA,EAAAD,EAAA,EAAA,wBAAA,EAAA,EAAA,EAAA,KAAAA,EAAAC,CAAA,EAAA,EAAA,IAAAD,EAAAC,CAAA,EAAAA,GAAA,EAAA,CAAAD,EAAA,EAAAC,KAAA,EAAAD,EAAA,EAAA,uBAAA,EAAAC,GAAAE,EAAAC,EAAAC,EAAAC,EAAAC,EAAAC,EAAAC,EAAAC,EAAAC,EAAAC,EAAAC,EAAAC,EAAAC,EAAAC,EAAAC,EAuBA,MAAMC,EAAkB,EAElBC,EAAqB,2CAA2CD,CAAe,qCAE/EE,EAA2B,0BAE3BC,EAAiC,uBAGjCC,EAA+B,uBAE/BC,EAAsB,CAC1B,aAAc,eACd,aAAc,eACd,cAAe,gBACf,eAAgB,gBAClB,EA6Ba,MAAAC,CAAoC,CAmB/C,YAAYC,EAA+B,CA2E3CC,EAAA,KAAArB,GAsCAqB,EAAA,KAAMnB,CAgCNmB,EAAAA,EAAA,KAAAhB,CAqBAgB,EAAAA,EAAA,KAAAd,CAAAA,EAIAc,EAAA,KAAMZ,CAAAA,EA+BNY,EAAA,KAAMV,GA3NN,KAAO,KAAA,UAMP,KAA2B,YAAA,CACzB,eAAgB,GAChB,iBAAkB,EACpB,EAIAU,EAAA,KAAAvB,EAAA,MAGAuB,EAAAA,EAAA,KAAAtB,EAAA,MAAA,EAiJAsB,EAAA,KAAAjB,EAAqE,CAAA,CA9InE,EAAA,KAAK,cAAgBgB,EAAQ,aAC/B,CAEA,MAAM,KAAKE,EAA2B,CACpCC,EAAA,KAAKzB,EAAcwB,CAInBE,EAAAA,EAAA,KAAKxB,EAAAC,GAAL,KAGAuB,IAAAA,EAAAA,EAAA,KAAKjB,EAAAC,GAAL,KAA6B,KAAA,MAAA,EAG7B,MAAMiB,EAA2B,SAAS,cAAc,OAAO,EAiB/D,GAhBAA,EAAyB,UAAY;AAAA,SAChCT,CAA8B;AAAA,SAC9BA,CAA8B;AAAA,SAC9BA,CAA8B;AAAA,SAC9BA,CAA8B;AAAA,SAC9BA,CAA8B;AAAA,SAC9BA,CAA8B;AAAA,SAC9BA,CAA8B,aAAaC,CAA4B;AAAA;AAAA;AAAA,MAI5E,SAAS,KAAK,OAAOQ,CAAwB,EAG7C,MAAMD,EAAA,KAAKtB,EAAAC,CAAAA,EAAL,KACN,IAAA,EAAA,KAAK,SAAW,KAAK,QAAQ,YAAY,EACrC,CAAC,KAAK,SACR,MAAM,IAAIuB,EAAU,oCAAqC,CAAE,KAAM,kBAAmB,CAAC,EAIvFF,EAAA,KAAKnB,EAAAC,CAAAA,EAAL,KAGAqB,IAAAA,EAAAA,EAAkB,CAAE,gBAAiB,KAAK,SAAU,OAAQL,EAAO,MAAO,CAAC,EAG3EC,EAAA,KAAKxB,EAAkB6B,EAAeC,CAAqB,CAG3DC,EAAAA,EAAe,CACb,KAAMf,EACN,MAAO,KAAK,SACZ,KAAM,IACN,OAAQO,EAAO,MACjB,CAAC,EAGD,KAAK,YAAc,CAEjB,eAAgB,KAAK,QAClB,SAAS,kBAAkB,EAC3B,IAAI,YAAa,EAA2B,EAE/C,iBAAkB,KAAK,QAAQ,SAAS,kBAAkB,EAAE,IAAI,iBAAkB,EAAI,CACxF,EAKA,MAAM,QAAQ,IAAI,CAACE,EAAA,KAAKf,EAAAC,CAAAA,EAAL,KAA+Bc,IAAAA,EAAAA,EAAA,KAAKb,EAAAC,CAAL,EAAA,KAAA,IAAA,CAAkC,CAAC,EAGrFY,EAAA,KAAKjB,EAAAC,CAAL,EAAA,KAAA,KAA6B,KAAK,YAAY,eAAiB,OAAS,MAAA,EAGxEuB,EAAO,MAAM,iCAAkC,KAAK,WAAW,CACjE,CAiFA,SAASC,EAAcC,EAAkCC,EAAgC,CAAC,EAAG,CAC3F,GAAI,CAAC,KAAK,QAAS,CACjBC,EAAA,KAAK/B,CAAAA,EAAY,KAAK,CAAC4B,EAAMC,EAAOC,CAAQ,CAAC,EAC7C,MACF,CACA,MAAME,EAAW,KAAK,YAAY,eAC9B,KAAK,YAAY,kBACnB,KAAK,QAAQ,SAASJ,EAAMC,EAAO,CAAE,GAAGC,EAAU,SAAAE,CAAS,CAAC,EAE9DL,EAAO,MAAMC,EAAMC,EAAO,CAAE,GAAGC,EAAU,SAAAE,CAAS,CAAC,CACrD,CAoDF,CA7NEtC,EAAA,IAGAC,QAAAA,EAAA,IA6EAC,QAAAA,EAAA,YAAAC,EAAqB,UAAG,CAEtB,OAAO,iBAAiBoC,EAAqB,UAAYC,GAAkB,CACzE,MAAMC,EAAQD,EACR,CAAE,UAAAE,EAAW,OAAAC,EAAQ,SAAAC,EAAU,aAAAC,CAAa,EAAIJ,EAAM,OAC5D,KAAK,SAASrB,EAAoB,aAAc,GAAM,CAAE,UAAAsB,EAAW,OAAAC,EAAQ,SAAAC,EAAU,aAAAC,CAAa,CAAC,CACrG,CAAC,EAGD,OAAO,iBAAiBC,EAAsB,UAAYN,GAAkB,CAC1E,MAAMC,EAAQD,EACR,CAAE,QAAAO,EAAS,UAAAC,EAAW,aAAAH,CAAa,EAAIJ,EAAM,OACnD,KAAK,SAASrB,EAAoB,cAAe4B,EAAW,CAC1D,QAAAD,EACA,UAAAC,EACA,aAAAH,EACA,QAAS,CAAC,CAACR,EAAA,KAAKpC,CAClB,CAAA,CAAC,CACH,CAAC,EAID,IAAIgD,EACJ,OAAO,iBAAiBC,EAAyB,UAAYV,GAAkB,CAC7E,MAAMC,EAAQD,EACR,CAAE,oBAAAW,EAAqB,YAAAC,CAAY,EAAIX,EAAM,OAC/CU,IAAwBF,IAC1B,KAAK,SAAS7B,EAAoB,eAAgB,GAAM,CACtD,YAAa+B,EACb,OAAQ,mBACR,YAAAC,CACF,CAAC,EACDH,EAA0BE,EAE9B,CAAC,CACH,EAGM/C,EAAA,YAAAC,EAAkB,gBAAG,CACzB,MAAMgD,EAAgB,SAAS,cAAc,QAAQ,EACrDA,EAAc,IAAMrC,EACpBqC,EAAc,MAAQ,GACtB,MAAMC,EAAsB,IAAI,QAAQ,CAACC,EAAKC,IAAQ,CACpDH,EAAc,iBAAiB,OAAQE,CAAG,EAC1CF,EAAc,iBAAiB,QAASG,CAAG,CAC7C,CAAC,EACD,SAAS,KAAK,OAAOH,CAAa,EAClC,GAAI,CACF,MAAMC,CACR,MAAc,CACZ,MAAM,IAAI1B,EAAU,gCAAiC,CAAE,KAAM,kBAAmB,CAAC,CACnF,CAEA,GADA,KAAK,QAAU,OAAO,QAClB,CAAC,KAAK,QACR,MAAM,IAAIA,EAAU,2BAA4B,CAAE,KAAM,kBAAmB,CAAC,EAG9E,MAAM6B,EAAiB,CACrB,oBAAqB,GACrB,0BAA2B,GAC3B,0BAA2B,GAC3B,sBAAuB,IACvB,qBAAsB,EACtB,iBAAkB3B,EAAeb,CAAwB,GAAK,IAChE,EACA,MAAM,KAAK,QAAQ,WAAW,KAAK,cAAe,CAAA,EAAIwC,CAAc,CACtE,EAEAnD,EAAA,IAAA,QAEAC,EAAA,IAAA,QAAAC,EAAgB,UAAG,CACjB,KAAO6B,EAAA,KAAK/B,CAAAA,EAAY,OAAS,GAAG,CAClC,MAAMoD,EAAcrB,EAAA,KAAK/B,CAAY,EAAA,MACjCoD,EAAAA,GACF,KAAK,SAAS,GAAGA,CAAW,CAEhC,CACF,EAcAjD,EAAA,IAAA,QAAAC,EAAuB,SAACyB,EAAwB,CAC9C,SAAS,KAAK,aAAajB,EAAgCiB,CAAK,CAClE,EAEMxB,EAAA,IAAAC,QAAAA,EAAsB,gBAAG,CAI7B,MAAM+C,EAAM,6CACZ,GAAI,CACF,MAAM,MAAMA,EAAK,CACf,OAAQ,OACR,QAAS,CACP,eAAgB,mBAChB,kBAAmB,KAAK,aAC1B,EACA,KAAM,KAAK,UAAU,CACnB,UAAWvC,EAAoB,aAC/B,MAAO,OACP,KAAM,IAAI,KAAK,EAAE,QAAQ,EAAI,IAC7B,SAAU,CACR,UAAW,KAAK,YAAY,eAAe,SAAS,EACpD,KAAM,OAAO,SAAS,QACxB,EACA,KAAM,CACJ,OAAQ,KAAK,QACf,CACF,CAAC,CACH,CAAC,CACH,OAASwC,EAAK,CACZ,MAAM,IAAIhC,EAAU,6BAA8B,CAAE,KAAM,mBAAoB,MAAOgC,CAAI,CAAC,CAE5F,CACF,EAEM/C,EAAA,IAAAC,QAAAA,EAA2B,gBAAG,CAClC,OAAO+C,EAAsB,CAC3B,QAASxB,EAAA,KAAKrC,CAAAA,GAAa,QAC3B,QAAS,CACP,cAAe,WAAWqC,EAAA,KAAKrC,CAAa,GAAA,MAAM,EACpD,EACA,YAAa,CAEX,gBAAiB,KAAK,SACtB,YAAa,CACX,SAAU,KAAK,YAAY,cAC7B,CACF,CACF,CAAC,CACH"}
|
|
1
|
+
{"version":3,"file":"statsig.esm.js","sources":["../../src/integrations/statsig/plugin.ts"],"sourcesContent":["import { postExperimentSession } from \"../../api-sdk/v3/routes\";\nimport { BEAM_CART_COOKIE_NAME } from \"../../shared/cart-contents\";\nimport { BeamCartCreatedEvent, BeamNonprofitSelectEvent, BeamOrderCreatedEvent } from \"../../utils/events\";\nimport { BeamPlugin, BeamConfigOptions } from \"../beam\";\nimport { BeamError } from \"../../utils/beam-errors\";\nimport { getCookieValue, setCookieValue } from \"../../utils/cookies\";\nimport { logger } from \"../../utils/logger\";\nimport { saveRemoteSession } from \"../../utils/remote-session\";\n\n/**\n * StatSig Docs: https://docs.statsig.com/client/jsClientSDK\n */\ntype StatsigPluginOptions = {\n statsigApiKey: string;\n};\n\ndeclare global {\n interface Window {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n statsig?: any; // attached by Statsig CDN script\n }\n}\n\nconst STATSIG_VERSION = 4;\n\nconst STATSIG_SCRIPT_URL = `https://cdn.jsdelivr.net/npm/statsig-js@${STATSIG_VERSION}/build/statsig-prod-web-sdk.min.js`;\n\nconst STATSIG_STABLE_ID_COOKIE = \"beam_statsig_session_id\";\n\nconst BEAM_VISIBILITY_DATA_ATTRIBUTE = \"data-beam-visibility\";\n\n// Add class to elements that should only show when Beam shows\nconst BEAM_VISIBILITY_SYNCED_CLASS = \"beam-sync-visibility\";\n\nconst BEAM_AB_TEST_EVENTS = {\n STATSIG_INIT: \"statsig_init\",\n CART_CREATED: \"cart_created\",\n ORDER_CREATED: \"order_created\",\n BEAM_SELECTION: \"beam_selection\",\n};\n\ntype Experiments = {\n /** Whether Beam widgets should be shown to users */\n shouldShowBeam: boolean;\n /** Whether events should be logged to Statsig */\n isLoggingEnabled: boolean;\n};\n\n/**\n * Sets up Statsig for A/B testing and shows/hides Beam based on default experiment rules.\n * @example\n * import { StatsigPlugin } from '@beamimpact/web-sdk/dist/integrations/statsig'\n * import { init } from '@beamimpact/web-sdk/dist/integrations/beam'\n *\n * const beam = await init({\n * apiKey: '',\n * chainId: 1,\n * storeId: 1,\n * domain: 'my-store.com' // in case site uses subdomains for different pages\n * plugins: [\n * new StatsigPlugin({ statsigApiKey: '' })\n * ]\n * })\n *\n * // Once initialized, all Beam widgets have display: none unless user is assigned to A/B test group that shows Beam\n * // To hide additional elements, add the CSS className \"beam-sync-visibility\" to them\n * // To programmatically access the experiment state: getConfig().plugins.statsig.experiments.shouldShowBeam\n */\nexport class StatsigPlugin implements BeamPlugin {\n name = \"statsig\";\n\n statsig: any; // Statsig SDK instance\n\n statsigApiKey: string;\n\n experiments: Experiments = {\n shouldShowBeam: false,\n isLoggingEnabled: true,\n };\n\n stableId?: string;\n\n #beamConfig?: BeamConfigOptions;\n\n // Checked at initialization so that we can tell if post-purchase events came from a session with a cart or not\n #beamCartCookie?: string;\n\n constructor(options: StatsigPluginOptions) {\n this.statsigApiKey = options.statsigApiKey;\n }\n\n async init(config: BeamConfigOptions) {\n this.#beamConfig = config;\n\n // Add event listeners for cart/order lifecycle events\n // This should happen as soon as possible to avoid missing events\n this.#attachEventListeners();\n\n // Attach beam-visibility data attribute to body\n this.#setBeamVisibilityValue(\"hide\");\n\n // Create beam a/b test stylesheet\n const beamVisibilityStylesheet = document.createElement(\"style\");\n beamVisibilityStylesheet.innerHTML = `\n [${BEAM_VISIBILITY_DATA_ATTRIBUTE}=\"hide\"] beam-select-nonprofit,\n [${BEAM_VISIBILITY_DATA_ATTRIBUTE}=\"hide\"] beam-post-purchase,\n [${BEAM_VISIBILITY_DATA_ATTRIBUTE}=\"hide\"] beam-redeem-transaction,\n [${BEAM_VISIBILITY_DATA_ATTRIBUTE}=\"hide\"] beam-impact-overview,\n [${BEAM_VISIBILITY_DATA_ATTRIBUTE}=\"hide\"] beam-community-impact,\n [${BEAM_VISIBILITY_DATA_ATTRIBUTE}=\"hide\"] beam-cumulative-impact,\n [${BEAM_VISIBILITY_DATA_ATTRIBUTE}=\"hide\"] beam-product-details-page,\n [${BEAM_VISIBILITY_DATA_ATTRIBUTE}=\"hide\"] .${BEAM_VISIBILITY_SYNCED_CLASS} {\n display: none;\n }\n `;\n document.head.append(beamVisibilityStylesheet);\n\n // Create statsig script\n await this.#initializeStatsig();\n this.stableId = this.statsig.getStableID();\n if (!this.stableId) {\n throw new BeamError(\"Statsig failed to assign stableId\", { name: \"StatsigInitError\" });\n }\n\n // Send events that happened before Statsig was ready\n this.#flushEventQueue();\n\n // Save Statsig ID in localStorage for linking to carts later\n saveRemoteSession({ remoteSessionId: this.stableId, apiKey: config.apiKey });\n\n // Save initial value of cart cookie so that post-purchase events can be filtered by if they had a cart or not\n this.#beamCartCookie = getCookieValue(BEAM_CART_COOKIE_NAME);\n\n // Cache ID in cookie to preserve ID across subdomains\n setCookieValue({\n name: STATSIG_STABLE_ID_COOKIE,\n value: this.stableId,\n path: \"/\",\n domain: config.domain,\n });\n\n // Evaluate Statsig experiment assignments\n this.experiments = {\n // Whether Beam widgets should be shown to users\n shouldShowBeam: this.statsig\n .getLayer(\"beam_trial_layer\")\n .get(\"show_beam\", false /* default to hide */) as boolean,\n // Whether events should be logged to Statsig\n isLoggingEnabled: this.statsig.getLayer(\"beam_trial_layer\").get(\"enable_logging\", true) as boolean,\n };\n\n // In parallel:\n // A) Make test call to Statsig\n // B) Save stable ID in Beam for attribution to carts/transactions\n await Promise.all([this.#testStatsigConnection(), this.#registerExperimentWithBeam()]);\n\n // Update beam visibility data attribute, which shows Beam to users in the experiment\n this.#setBeamVisibilityValue(this.experiments.shouldShowBeam ? \"show\" : \"hide\");\n\n // Log result\n logger.debug(\"Statsig Experiment Assignments\", this.experiments);\n }\n\n #attachEventListeners() {\n // Cart Created\n window.addEventListener(BeamCartCreatedEvent.eventName, (_event: Event) => {\n const event = _event as BeamCartCreatedEvent;\n const { itemCount, cartId, subtotal, currencyCode } = event.detail;\n this.logEvent(BEAM_AB_TEST_EVENTS.CART_CREATED, true, { itemCount, cartId, subtotal, currencyCode });\n });\n\n // Order Created\n window.addEventListener(BeamOrderCreatedEvent.eventName, (_event: Event) => {\n const event = _event as BeamOrderCreatedEvent;\n const { orderId, cartTotal, currencyCode } = event.detail;\n this.logEvent(BEAM_AB_TEST_EVENTS.ORDER_CREATED, cartTotal, {\n orderId,\n cartTotal,\n currencyCode,\n hasCart: !!this.#beamCartCookie,\n });\n });\n\n // Beam Selection\n // Store previous value in case widget is recreated and emits event again:\n let lastSelectedNonprofitId: number | null | undefined;\n window.addEventListener(BeamNonprofitSelectEvent.eventName, (_event: Event) => {\n const event = _event as BeamNonprofitSelectEvent;\n const { selectedNonprofitId, selectionId } = event.detail;\n if (selectedNonprofitId !== lastSelectedNonprofitId) {\n this.logEvent(BEAM_AB_TEST_EVENTS.BEAM_SELECTION, true, {\n nonprofitId: selectedNonprofitId,\n widget: \"select-nonprofit\",\n selectionId,\n });\n lastSelectedNonprofitId = selectedNonprofitId;\n }\n });\n }\n\n // https://docs.statsig.com/client/jsClientSDK#statsig-options\n async #initializeStatsig() {\n const statsigScript = document.createElement(\"script\");\n statsigScript.src = STATSIG_SCRIPT_URL;\n statsigScript.async = false;\n const statsigReadyPromise = new Promise((res, rej) => {\n statsigScript.addEventListener(\"load\", res);\n statsigScript.addEventListener(\"error\", rej);\n });\n document.head.append(statsigScript);\n try {\n await statsigReadyPromise;\n } catch (err) {\n throw new BeamError(\"Failed to load Statsig script\", { name: \"StatsigInitError\" });\n }\n this.statsig = window.statsig;\n if (!this.statsig) {\n throw new BeamError(\"Failed to detect Statsig\", { name: \"StatsigInitError\" });\n }\n // https://docs.statsig.com/client/jsClientSDK#statsig-options\n const statsigOptions = {\n disableErrorLogging: true,\n disableAutoMetricsLogging: true,\n disableCurrentPageLogging: true,\n loggingIntervalMillis: 1000,\n loggingBufferMaxSize: 2,\n overrideStableID: getCookieValue(STATSIG_STABLE_ID_COOKIE) ?? null,\n };\n await this.statsig.initialize(this.statsigApiKey, {}, statsigOptions);\n }\n\n #eventQueue: Parameters<typeof StatsigPlugin.prototype.logEvent>[] = [];\n\n #flushEventQueue() {\n while (this.#eventQueue.length > 0) {\n const eventParams = this.#eventQueue.shift();\n if (eventParams) {\n this.logEvent(...eventParams);\n }\n }\n }\n\n logEvent(name: string, value: string | number | boolean, metadata: Record<string, any> = {}) {\n if (!this.statsig) {\n this.#eventQueue.push([name, value, metadata]);\n return;\n }\n const withBeam = this.experiments.shouldShowBeam;\n if (this.experiments.isLoggingEnabled) {\n this.statsig.logEvent(name, value, { ...metadata, withBeam });\n }\n logger.debug(name, value, { ...metadata, withBeam });\n }\n\n #setBeamVisibilityValue(value: \"show\" | \"hide\") {\n document.body.setAttribute(BEAM_VISIBILITY_DATA_ATTRIBUTE, value);\n }\n\n async #testStatsigConnection() {\n // Use the HTTP API so we can synchronously detect if Statsig is reachable,\n // rather than pushing an event to the SDK's retryable queue.\n // https://docs.statsig.com/http-api\n const url = \"https://events.statsigapi.net/v1/log_event\";\n try {\n await fetch(url, {\n method: \"POST\",\n headers: {\n \"content-type\": \"application/json\",\n \"statsig-api-key\": this.statsigApiKey,\n },\n body: JSON.stringify({\n eventName: BEAM_AB_TEST_EVENTS.STATSIG_INIT,\n value: \"true\",\n time: new Date().getTime() / 1000, // unix timestamp (seconds not milliseconds)\n metadata: {\n show_beam: this.experiments.shouldShowBeam.toString(),\n page: window.location.pathname,\n },\n user: {\n userID: this.stableId,\n },\n }),\n });\n } catch (err) {\n throw new BeamError(\"Could not call Statsig API\", { name: \"StatsigInitError\", cause: err });\n // TODO: this will log failures to Beam's error tracking API in the future\n }\n }\n\n async #registerExperimentWithBeam() {\n return postExperimentSession({\n baseUrl: this.#beamConfig?.baseUrl,\n headers: {\n authorization: `Api-Key ${this.#beamConfig?.apiKey}`,\n },\n requestBody: {\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n remoteSessionId: this.stableId!,\n experiments: {\n showBeam: this.experiments.shouldShowBeam,\n },\n },\n });\n }\n}\n"],"names":["i","e","l","_beamConfig","_beamCartCookie","_attachEventListeners","attachEventListeners_fn","_initializeStatsig","initializeStatsig_fn","_eventQueue","_flushEventQueue","flushEventQueue_fn","_setBeamVisibilityValue","setBeamVisibilityValue_fn","_testStatsigConnection","testStatsigConnection_fn","_registerExperimentWithBeam","registerExperimentWithBeam_fn","STATSIG_VERSION","STATSIG_SCRIPT_URL","STATSIG_STABLE_ID_COOKIE","BEAM_VISIBILITY_DATA_ATTRIBUTE","BEAM_VISIBILITY_SYNCED_CLASS","BEAM_AB_TEST_EVENTS","StatsigPlugin","options","__privateAdd","config","__privateSet","__privateMethod","beamVisibilityStylesheet","BeamError","saveRemoteSession","getCookieValue","BEAM_CART_COOKIE_NAME","setCookieValue","logger","name","value","metadata","__privateGet","withBeam","BeamCartCreatedEvent","_event","event","itemCount","cartId","subtotal","currencyCode","BeamOrderCreatedEvent","orderId","cartTotal","lastSelectedNonprofitId","BeamNonprofitSelectEvent","selectedNonprofitId","selectionId","statsigScript","statsigReadyPromise","res","rej","statsigOptions","eventParams","url","err","postExperimentSession"],"mappings":"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"}
|
|
@@ -1,12 +1,13 @@
|
|
|
1
|
-
import{p as R}from"../chunks/routes-
|
|
1
|
+
import{p as R}from"../chunks/routes-3jKReDai.esm.js";import{B as M}from"../chunks/cart-contents-h60geKWa.esm.js";import{a as $,b as D,c as O}from"../chunks/events-Y8fYvSqM.esm.js";import{B as m}from"../chunks/beam-errors-P-Lu07Ce.esm.js";import{getCookieValue as f,setCookieValue as W}from"../utils/cookies.js";import{logger as C}from"../utils/logger.js";import{saveRemoteSession as K}from"../utils/remote-session.js";import"../utils/local-storage.js";var w=(e,t,i)=>{if(!t.has(e))throw TypeError("Cannot "+i)},d=(e,t,i)=>(w(e,t,"read from private field"),i?i.call(e):t.get(e)),n=(e,t,i)=>{if(t.has(e))throw TypeError("Cannot add the same private member more than once");t instanceof WeakSet?t.add(e):t.set(e,i)},_=(e,t,i,s)=>(w(e,t,"write to private field"),s?s.call(e,i):t.set(e,i),i),r=(e,t,i)=>(w(e,t,"access private method"),i),h,c,E,T,b,A,l,v,B,g,S,y,L,I,k;const P=4,j=`https://cdn.jsdelivr.net/npm/statsig-js@${P}/build/statsig-prod-web-sdk.min.js`,x="beam_statsig_session_id",o="data-beam-visibility",z="beam-sync-visibility",p={STATSIG_INIT:"statsig_init",CART_CREATED:"cart_created",ORDER_CREATED:"order_created",BEAM_SELECTION:"beam_selection"};class G{constructor(t){n(this,E),n(this,b),n(this,v),n(this,g),n(this,y),n(this,I),this.name="statsig",this.experiments={shouldShowBeam:!1,isLoggingEnabled:!0},n(this,h,void 0),n(this,c,void 0),n(this,l,[]),this.statsigApiKey=t.statsigApiKey}async init(t){_(this,h,t),r(this,E,T).call(this),r(this,g,S).call(this,"hide");const i=document.createElement("style");if(i.innerHTML=`
|
|
2
2
|
[${o}="hide"] beam-select-nonprofit,
|
|
3
3
|
[${o}="hide"] beam-post-purchase,
|
|
4
4
|
[${o}="hide"] beam-redeem-transaction,
|
|
5
5
|
[${o}="hide"] beam-impact-overview,
|
|
6
6
|
[${o}="hide"] beam-community-impact,
|
|
7
7
|
[${o}="hide"] beam-cumulative-impact,
|
|
8
|
+
[${o}="hide"] beam-product-details-page,
|
|
8
9
|
[${o}="hide"] .${z} {
|
|
9
10
|
display: none;
|
|
10
11
|
}
|
|
11
|
-
`,document.head.append(i),await r(this,b,A).call(this),this.stableId=this.statsig.getStableID(),!this.stableId)throw new m("Statsig failed to assign stableId",{name:"StatsigInitError"});r(this,v,B).call(this),K({remoteSessionId:this.stableId,apiKey:t.apiKey}),_(this,c,f(M))
|
|
12
|
+
`,document.head.append(i),await r(this,b,A).call(this),this.stableId=this.statsig.getStableID(),!this.stableId)throw new m("Statsig failed to assign stableId",{name:"StatsigInitError"});r(this,v,B).call(this),K({remoteSessionId:this.stableId,apiKey:t.apiKey}),_(this,c,f(M)),W({name:x,value:this.stableId,path:"/",domain:t.domain}),this.experiments={shouldShowBeam:this.statsig.getLayer("beam_trial_layer").get("show_beam",!1),isLoggingEnabled:this.statsig.getLayer("beam_trial_layer").get("enable_logging",!0)},await Promise.all([r(this,y,L).call(this),r(this,I,k).call(this)]),r(this,g,S).call(this,this.experiments.shouldShowBeam?"show":"hide"),C.debug("Statsig Experiment Assignments",this.experiments)}logEvent(t,i,s={}){if(!this.statsig){d(this,l).push([t,i,s]);return}const a=this.experiments.shouldShowBeam;this.experiments.isLoggingEnabled&&this.statsig.logEvent(t,i,{...s,withBeam:a}),C.debug(t,i,{...s,withBeam:a})}}h=new WeakMap,c=new WeakMap,E=new WeakSet,T=function(){window.addEventListener($.eventName,t=>{const i=t,{itemCount:s,cartId:a,subtotal:u,currencyCode:N}=i.detail;this.logEvent(p.CART_CREATED,!0,{itemCount:s,cartId:a,subtotal:u,currencyCode:N})}),window.addEventListener(D.eventName,t=>{const i=t,{orderId:s,cartTotal:a,currencyCode:u}=i.detail;this.logEvent(p.ORDER_CREATED,a,{orderId:s,cartTotal:a,currencyCode:u,hasCart:!!d(this,c)})});let e;window.addEventListener(O.eventName,t=>{const i=t,{selectedNonprofitId:s,selectionId:a}=i.detail;s!==e&&(this.logEvent(p.BEAM_SELECTION,!0,{nonprofitId:s,widget:"select-nonprofit",selectionId:a}),e=s)})},b=new WeakSet,A=async function(){const e=document.createElement("script");e.src=j,e.async=!1;const t=new Promise((s,a)=>{e.addEventListener("load",s),e.addEventListener("error",a)});document.head.append(e);try{await t}catch{throw new m("Failed to load Statsig script",{name:"StatsigInitError"})}if(this.statsig=window.statsig,!this.statsig)throw new m("Failed to detect Statsig",{name:"StatsigInitError"});const i={disableErrorLogging:!0,disableAutoMetricsLogging:!0,disableCurrentPageLogging:!0,loggingIntervalMillis:1e3,loggingBufferMaxSize:2,overrideStableID:f(x)??null};await this.statsig.initialize(this.statsigApiKey,{},i)},l=new WeakMap,v=new WeakSet,B=function(){for(;d(this,l).length>0;){const e=d(this,l).shift();e&&this.logEvent(...e)}},g=new WeakSet,S=function(e){document.body.setAttribute(o,e)},y=new WeakSet,L=async function(){const e="https://events.statsigapi.net/v1/log_event";try{await fetch(e,{method:"POST",headers:{"content-type":"application/json","statsig-api-key":this.statsigApiKey},body:JSON.stringify({eventName:p.STATSIG_INIT,value:"true",time:new Date().getTime()/1e3,metadata:{show_beam:this.experiments.shouldShowBeam.toString(),page:window.location.pathname},user:{userID:this.stableId}})})}catch(t){throw new m("Could not call Statsig API",{name:"StatsigInitError",cause:t})}},I=new WeakSet,k=async function(){return R({baseUrl:d(this,h)?.baseUrl,headers:{authorization:`Api-Key ${d(this,h)?.apiKey}`},requestBody:{remoteSessionId:this.stableId,experiments:{showBeam:this.experiments.shouldShowBeam}}})};export{G as StatsigPlugin};
|
|
12
13
|
//# sourceMappingURL=statsig.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"statsig.js","sources":["../../src/integrations/statsig/plugin.ts"],"sourcesContent":["import { postExperimentSession } from \"../../api-sdk/v3/routes\";\nimport { BEAM_CART_COOKIE_NAME } from \"../../shared/cart-contents\";\nimport { BeamCartCreatedEvent, BeamNonprofitSelectEvent, BeamOrderCreatedEvent } from \"../../utils/events\";\nimport { BeamPlugin, BeamConfigOptions } from \"../beam\";\nimport { BeamError } from \"../../utils/beam-errors\";\nimport { getCookieValue, setCookieValue } from \"../../utils/cookies\";\nimport { logger } from \"../../utils/logger\";\nimport { saveRemoteSession } from \"../../utils/remote-session\";\n\n/**\n * StatSig Docs: https://docs.statsig.com/client/jsClientSDK\n */\ntype StatsigPluginOptions = {\n statsigApiKey: string;\n};\n\ndeclare global {\n interface Window {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n statsig?: any; // attached by Statsig CDN script\n }\n}\n\nconst STATSIG_VERSION = 4;\n\nconst STATSIG_SCRIPT_URL = `https://cdn.jsdelivr.net/npm/statsig-js@${STATSIG_VERSION}/build/statsig-prod-web-sdk.min.js`;\n\nconst STATSIG_STABLE_ID_COOKIE = \"beam_statsig_session_id\";\n\nconst BEAM_VISIBILITY_DATA_ATTRIBUTE = \"data-beam-visibility\";\n\n// Add class to elements that should only show when Beam shows\nconst BEAM_VISIBILITY_SYNCED_CLASS = \"beam-sync-visibility\";\n\nconst BEAM_AB_TEST_EVENTS = {\n STATSIG_INIT: \"statsig_init\",\n CART_CREATED: \"cart_created\",\n ORDER_CREATED: \"order_created\",\n BEAM_SELECTION: \"beam_selection\",\n};\n\ntype Experiments = {\n /** Whether Beam widgets should be shown to users */\n shouldShowBeam: boolean;\n /** Whether events should be logged to Statsig */\n isLoggingEnabled: boolean;\n};\n\n/**\n * Sets up Statsig for A/B testing and shows/hides Beam based on default experiment rules.\n * @example\n * import { StatsigPlugin } from '@beamimpact/web-sdk/dist/integrations/statsig'\n * import { init } from '@beamimpact/web-sdk/dist/integrations/beam'\n *\n * const beam = await init({\n * apiKey: '',\n * chainId: 1,\n * storeId: 1,\n * domain: 'my-store.com' // in case site uses subdomains for different pages\n * plugins: [\n * new StatsigPlugin({ statsigApiKey: '' })\n * ]\n * })\n *\n * // Once initialized, all Beam widgets have display: none unless user is assigned to A/B test group that shows Beam\n * // To hide additional elements, add the CSS className \"beam-sync-visibility\" to them\n * // To programmatically access the experiment state: getConfig().plugins.statsig.experiments.shouldShowBeam\n */\nexport class StatsigPlugin implements BeamPlugin {\n name = \"statsig\";\n\n statsig: any; // Statsig SDK instance\n\n statsigApiKey: string;\n\n experiments: Experiments = {\n shouldShowBeam: false,\n isLoggingEnabled: true,\n };\n\n stableId?: string;\n\n #beamConfig?: BeamConfigOptions;\n\n // Checked at initialization so that we can tell if post-purchase events came from a session with a cart or not\n #beamCartCookie?: string;\n\n constructor(options: StatsigPluginOptions) {\n this.statsigApiKey = options.statsigApiKey;\n }\n\n async init(config: BeamConfigOptions) {\n this.#beamConfig = config;\n\n // Add event listeners for cart/order lifecycle events\n // This should happen as soon as possible to avoid missing events\n this.#attachEventListeners();\n\n // Attach beam-visibility data attribute to body\n this.#setBeamVisibilityValue(\"hide\");\n\n // Create beam a/b test stylesheet\n const beamVisibilityStylesheet = document.createElement(\"style\");\n beamVisibilityStylesheet.innerHTML = `\n [${BEAM_VISIBILITY_DATA_ATTRIBUTE}=\"hide\"] beam-select-nonprofit,\n [${BEAM_VISIBILITY_DATA_ATTRIBUTE}=\"hide\"] beam-post-purchase,\n [${BEAM_VISIBILITY_DATA_ATTRIBUTE}=\"hide\"] beam-redeem-transaction,\n [${BEAM_VISIBILITY_DATA_ATTRIBUTE}=\"hide\"] beam-impact-overview,\n [${BEAM_VISIBILITY_DATA_ATTRIBUTE}=\"hide\"] beam-community-impact,\n [${BEAM_VISIBILITY_DATA_ATTRIBUTE}=\"hide\"] beam-cumulative-impact,\n [${BEAM_VISIBILITY_DATA_ATTRIBUTE}=\"hide\"] .${BEAM_VISIBILITY_SYNCED_CLASS} {\n display: none;\n }\n `;\n document.head.append(beamVisibilityStylesheet);\n\n // Create statsig script\n await this.#initializeStatsig();\n this.stableId = this.statsig.getStableID();\n if (!this.stableId) {\n throw new BeamError(\"Statsig failed to assign stableId\", { name: \"StatsigInitError\" });\n }\n\n // Send events that happened before Statsig was ready\n this.#flushEventQueue();\n\n // Save Statsig ID in localStorage for linking to carts later\n saveRemoteSession({ remoteSessionId: this.stableId, apiKey: config.apiKey });\n\n // Save initial value of cart cookie so that post-purchase events can be filtered by if they had a cart or not\n this.#beamCartCookie = getCookieValue(BEAM_CART_COOKIE_NAME);\n\n // Cache ID in cookie to preserve ID across subdomains\n setCookieValue({\n name: STATSIG_STABLE_ID_COOKIE,\n value: this.stableId,\n path: \"/\",\n domain: config.domain,\n });\n\n // Evaluate Statsig experiment assignments\n this.experiments = {\n // Whether Beam widgets should be shown to users\n shouldShowBeam: this.statsig\n .getLayer(\"beam_trial_layer\")\n .get(\"show_beam\", false /* default to hide */) as boolean,\n // Whether events should be logged to Statsig\n isLoggingEnabled: this.statsig.getLayer(\"beam_trial_layer\").get(\"enable_logging\", true) as boolean,\n };\n\n // In parallel:\n // A) Make test call to Statsig\n // B) Save stable ID in Beam for attribution to carts/transactions\n await Promise.all([this.#testStatsigConnection(), this.#registerExperimentWithBeam()]);\n\n // Update beam visibility data attribute, which shows Beam to users in the experiment\n this.#setBeamVisibilityValue(this.experiments.shouldShowBeam ? \"show\" : \"hide\");\n\n // Log result\n logger.debug(\"Statsig Experiment Assignments\", this.experiments);\n }\n\n #attachEventListeners() {\n // Cart Created\n window.addEventListener(BeamCartCreatedEvent.eventName, (_event: Event) => {\n const event = _event as BeamCartCreatedEvent;\n const { itemCount, cartId, subtotal, currencyCode } = event.detail;\n this.logEvent(BEAM_AB_TEST_EVENTS.CART_CREATED, true, { itemCount, cartId, subtotal, currencyCode });\n });\n\n // Order Created\n window.addEventListener(BeamOrderCreatedEvent.eventName, (_event: Event) => {\n const event = _event as BeamOrderCreatedEvent;\n const { orderId, cartTotal, currencyCode } = event.detail;\n this.logEvent(BEAM_AB_TEST_EVENTS.ORDER_CREATED, cartTotal, {\n orderId,\n cartTotal,\n currencyCode,\n hasCart: !!this.#beamCartCookie,\n });\n });\n\n // Beam Selection\n // Store previous value in case widget is recreated and emits event again:\n let lastSelectedNonprofitId: number | null | undefined;\n window.addEventListener(BeamNonprofitSelectEvent.eventName, (_event: Event) => {\n const event = _event as BeamNonprofitSelectEvent;\n const { selectedNonprofitId, selectionId } = event.detail;\n if (selectedNonprofitId !== lastSelectedNonprofitId) {\n this.logEvent(BEAM_AB_TEST_EVENTS.BEAM_SELECTION, true, {\n nonprofitId: selectedNonprofitId,\n widget: \"select-nonprofit\",\n selectionId,\n });\n lastSelectedNonprofitId = selectedNonprofitId;\n }\n });\n }\n\n // https://docs.statsig.com/client/jsClientSDK#statsig-options\n async #initializeStatsig() {\n const statsigScript = document.createElement(\"script\");\n statsigScript.src = STATSIG_SCRIPT_URL;\n statsigScript.async = false;\n const statsigReadyPromise = new Promise((res, rej) => {\n statsigScript.addEventListener(\"load\", res);\n statsigScript.addEventListener(\"error\", rej);\n });\n document.head.append(statsigScript);\n try {\n await statsigReadyPromise;\n } catch (err) {\n throw new BeamError(\"Failed to load Statsig script\", { name: \"StatsigInitError\" });\n }\n this.statsig = window.statsig;\n if (!this.statsig) {\n throw new BeamError(\"Failed to detect Statsig\", { name: \"StatsigInitError\" });\n }\n // https://docs.statsig.com/client/jsClientSDK#statsig-options\n const statsigOptions = {\n disableErrorLogging: true,\n disableAutoMetricsLogging: true,\n disableCurrentPageLogging: true,\n loggingIntervalMillis: 1000,\n loggingBufferMaxSize: 2,\n overrideStableID: getCookieValue(STATSIG_STABLE_ID_COOKIE) ?? null,\n };\n await this.statsig.initialize(this.statsigApiKey, {}, statsigOptions);\n }\n\n #eventQueue: Parameters<typeof StatsigPlugin.prototype.logEvent>[] = [];\n\n #flushEventQueue() {\n while (this.#eventQueue.length > 0) {\n const eventParams = this.#eventQueue.shift();\n if (eventParams) {\n this.logEvent(...eventParams);\n }\n }\n }\n\n logEvent(name: string, value: string | number | boolean, metadata: Record<string, any> = {}) {\n if (!this.statsig) {\n this.#eventQueue.push([name, value, metadata]);\n return;\n }\n const withBeam = this.experiments.shouldShowBeam;\n if (this.experiments.isLoggingEnabled) {\n this.statsig.logEvent(name, value, { ...metadata, withBeam });\n }\n logger.debug(name, value, { ...metadata, withBeam });\n }\n\n #setBeamVisibilityValue(value: \"show\" | \"hide\") {\n document.body.setAttribute(BEAM_VISIBILITY_DATA_ATTRIBUTE, value);\n }\n\n async #testStatsigConnection() {\n // Use the HTTP API so we can synchronously detect if Statsig is reachable,\n // rather than pushing an event to the SDK's retryable queue.\n // https://docs.statsig.com/http-api\n const url = \"https://events.statsigapi.net/v1/log_event\";\n try {\n await fetch(url, {\n method: \"POST\",\n headers: {\n \"content-type\": \"application/json\",\n \"statsig-api-key\": this.statsigApiKey,\n },\n body: JSON.stringify({\n eventName: BEAM_AB_TEST_EVENTS.STATSIG_INIT,\n value: \"true\",\n time: new Date().getTime() / 1000, // unix timestamp (seconds not milliseconds)\n metadata: {\n show_beam: this.experiments.shouldShowBeam.toString(),\n page: window.location.pathname,\n },\n user: {\n userID: this.stableId,\n },\n }),\n });\n } catch (err) {\n throw new BeamError(\"Could not call Statsig API\", { name: \"StatsigInitError\", cause: err });\n // TODO: this will log failures to Beam's error tracking API in the future\n }\n }\n\n async #registerExperimentWithBeam() {\n return postExperimentSession({\n baseUrl: this.#beamConfig?.baseUrl,\n headers: {\n authorization: `Api-Key ${this.#beamConfig?.apiKey}`,\n },\n requestBody: {\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n remoteSessionId: this.stableId!,\n experiments: {\n showBeam: this.experiments.shouldShowBeam,\n },\n },\n });\n }\n}\n"],"names":["i","e","g","_beamConfig","_beamCartCookie","_attachEventListeners","attachEventListeners_fn","_initializeStatsig","initializeStatsig_fn","_eventQueue","_flushEventQueue","flushEventQueue_fn","_setBeamVisibilityValue","setBeamVisibilityValue_fn","_testStatsigConnection","testStatsigConnection_fn","_registerExperimentWithBeam","registerExperimentWithBeam_fn","STATSIG_VERSION","STATSIG_SCRIPT_URL","STATSIG_STABLE_ID_COOKIE","BEAM_VISIBILITY_DATA_ATTRIBUTE","BEAM_VISIBILITY_SYNCED_CLASS","BEAM_AB_TEST_EVENTS","StatsigPlugin","options","__privateAdd","config","__privateSet","__privateMethod","beamVisibilityStylesheet","BeamError","saveRemoteSession","getCookieValue","BEAM_CART_COOKIE_NAME","setCookieValue","logger","name","value","metadata","__privateGet","withBeam","BeamCartCreatedEvent","_event","event","itemCount","cartId","subtotal","currencyCode","BeamOrderCreatedEvent","orderId","cartTotal","lastSelectedNonprofitId","BeamNonprofitSelectEvent","selectedNonprofitId","selectionId","statsigScript","statsigReadyPromise","res","rej","statsigOptions","eventParams","url","err","postExperimentSession"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"statsig.js","sources":["../../src/integrations/statsig/plugin.ts"],"sourcesContent":["import { postExperimentSession } from \"../../api-sdk/v3/routes\";\nimport { BEAM_CART_COOKIE_NAME } from \"../../shared/cart-contents\";\nimport { BeamCartCreatedEvent, BeamNonprofitSelectEvent, BeamOrderCreatedEvent } from \"../../utils/events\";\nimport { BeamPlugin, BeamConfigOptions } from \"../beam\";\nimport { BeamError } from \"../../utils/beam-errors\";\nimport { getCookieValue, setCookieValue } from \"../../utils/cookies\";\nimport { logger } from \"../../utils/logger\";\nimport { saveRemoteSession } from \"../../utils/remote-session\";\n\n/**\n * StatSig Docs: https://docs.statsig.com/client/jsClientSDK\n */\ntype StatsigPluginOptions = {\n statsigApiKey: string;\n};\n\ndeclare global {\n interface Window {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n statsig?: any; // attached by Statsig CDN script\n }\n}\n\nconst STATSIG_VERSION = 4;\n\nconst STATSIG_SCRIPT_URL = `https://cdn.jsdelivr.net/npm/statsig-js@${STATSIG_VERSION}/build/statsig-prod-web-sdk.min.js`;\n\nconst STATSIG_STABLE_ID_COOKIE = \"beam_statsig_session_id\";\n\nconst BEAM_VISIBILITY_DATA_ATTRIBUTE = \"data-beam-visibility\";\n\n// Add class to elements that should only show when Beam shows\nconst BEAM_VISIBILITY_SYNCED_CLASS = \"beam-sync-visibility\";\n\nconst BEAM_AB_TEST_EVENTS = {\n STATSIG_INIT: \"statsig_init\",\n CART_CREATED: \"cart_created\",\n ORDER_CREATED: \"order_created\",\n BEAM_SELECTION: \"beam_selection\",\n};\n\ntype Experiments = {\n /** Whether Beam widgets should be shown to users */\n shouldShowBeam: boolean;\n /** Whether events should be logged to Statsig */\n isLoggingEnabled: boolean;\n};\n\n/**\n * Sets up Statsig for A/B testing and shows/hides Beam based on default experiment rules.\n * @example\n * import { StatsigPlugin } from '@beamimpact/web-sdk/dist/integrations/statsig'\n * import { init } from '@beamimpact/web-sdk/dist/integrations/beam'\n *\n * const beam = await init({\n * apiKey: '',\n * chainId: 1,\n * storeId: 1,\n * domain: 'my-store.com' // in case site uses subdomains for different pages\n * plugins: [\n * new StatsigPlugin({ statsigApiKey: '' })\n * ]\n * })\n *\n * // Once initialized, all Beam widgets have display: none unless user is assigned to A/B test group that shows Beam\n * // To hide additional elements, add the CSS className \"beam-sync-visibility\" to them\n * // To programmatically access the experiment state: getConfig().plugins.statsig.experiments.shouldShowBeam\n */\nexport class StatsigPlugin implements BeamPlugin {\n name = \"statsig\";\n\n statsig: any; // Statsig SDK instance\n\n statsigApiKey: string;\n\n experiments: Experiments = {\n shouldShowBeam: false,\n isLoggingEnabled: true,\n };\n\n stableId?: string;\n\n #beamConfig?: BeamConfigOptions;\n\n // Checked at initialization so that we can tell if post-purchase events came from a session with a cart or not\n #beamCartCookie?: string;\n\n constructor(options: StatsigPluginOptions) {\n this.statsigApiKey = options.statsigApiKey;\n }\n\n async init(config: BeamConfigOptions) {\n this.#beamConfig = config;\n\n // Add event listeners for cart/order lifecycle events\n // This should happen as soon as possible to avoid missing events\n this.#attachEventListeners();\n\n // Attach beam-visibility data attribute to body\n this.#setBeamVisibilityValue(\"hide\");\n\n // Create beam a/b test stylesheet\n const beamVisibilityStylesheet = document.createElement(\"style\");\n beamVisibilityStylesheet.innerHTML = `\n [${BEAM_VISIBILITY_DATA_ATTRIBUTE}=\"hide\"] beam-select-nonprofit,\n [${BEAM_VISIBILITY_DATA_ATTRIBUTE}=\"hide\"] beam-post-purchase,\n [${BEAM_VISIBILITY_DATA_ATTRIBUTE}=\"hide\"] beam-redeem-transaction,\n [${BEAM_VISIBILITY_DATA_ATTRIBUTE}=\"hide\"] beam-impact-overview,\n [${BEAM_VISIBILITY_DATA_ATTRIBUTE}=\"hide\"] beam-community-impact,\n [${BEAM_VISIBILITY_DATA_ATTRIBUTE}=\"hide\"] beam-cumulative-impact,\n [${BEAM_VISIBILITY_DATA_ATTRIBUTE}=\"hide\"] beam-product-details-page,\n [${BEAM_VISIBILITY_DATA_ATTRIBUTE}=\"hide\"] .${BEAM_VISIBILITY_SYNCED_CLASS} {\n display: none;\n }\n `;\n document.head.append(beamVisibilityStylesheet);\n\n // Create statsig script\n await this.#initializeStatsig();\n this.stableId = this.statsig.getStableID();\n if (!this.stableId) {\n throw new BeamError(\"Statsig failed to assign stableId\", { name: \"StatsigInitError\" });\n }\n\n // Send events that happened before Statsig was ready\n this.#flushEventQueue();\n\n // Save Statsig ID in localStorage for linking to carts later\n saveRemoteSession({ remoteSessionId: this.stableId, apiKey: config.apiKey });\n\n // Save initial value of cart cookie so that post-purchase events can be filtered by if they had a cart or not\n this.#beamCartCookie = getCookieValue(BEAM_CART_COOKIE_NAME);\n\n // Cache ID in cookie to preserve ID across subdomains\n setCookieValue({\n name: STATSIG_STABLE_ID_COOKIE,\n value: this.stableId,\n path: \"/\",\n domain: config.domain,\n });\n\n // Evaluate Statsig experiment assignments\n this.experiments = {\n // Whether Beam widgets should be shown to users\n shouldShowBeam: this.statsig\n .getLayer(\"beam_trial_layer\")\n .get(\"show_beam\", false /* default to hide */) as boolean,\n // Whether events should be logged to Statsig\n isLoggingEnabled: this.statsig.getLayer(\"beam_trial_layer\").get(\"enable_logging\", true) as boolean,\n };\n\n // In parallel:\n // A) Make test call to Statsig\n // B) Save stable ID in Beam for attribution to carts/transactions\n await Promise.all([this.#testStatsigConnection(), this.#registerExperimentWithBeam()]);\n\n // Update beam visibility data attribute, which shows Beam to users in the experiment\n this.#setBeamVisibilityValue(this.experiments.shouldShowBeam ? \"show\" : \"hide\");\n\n // Log result\n logger.debug(\"Statsig Experiment Assignments\", this.experiments);\n }\n\n #attachEventListeners() {\n // Cart Created\n window.addEventListener(BeamCartCreatedEvent.eventName, (_event: Event) => {\n const event = _event as BeamCartCreatedEvent;\n const { itemCount, cartId, subtotal, currencyCode } = event.detail;\n this.logEvent(BEAM_AB_TEST_EVENTS.CART_CREATED, true, { itemCount, cartId, subtotal, currencyCode });\n });\n\n // Order Created\n window.addEventListener(BeamOrderCreatedEvent.eventName, (_event: Event) => {\n const event = _event as BeamOrderCreatedEvent;\n const { orderId, cartTotal, currencyCode } = event.detail;\n this.logEvent(BEAM_AB_TEST_EVENTS.ORDER_CREATED, cartTotal, {\n orderId,\n cartTotal,\n currencyCode,\n hasCart: !!this.#beamCartCookie,\n });\n });\n\n // Beam Selection\n // Store previous value in case widget is recreated and emits event again:\n let lastSelectedNonprofitId: number | null | undefined;\n window.addEventListener(BeamNonprofitSelectEvent.eventName, (_event: Event) => {\n const event = _event as BeamNonprofitSelectEvent;\n const { selectedNonprofitId, selectionId } = event.detail;\n if (selectedNonprofitId !== lastSelectedNonprofitId) {\n this.logEvent(BEAM_AB_TEST_EVENTS.BEAM_SELECTION, true, {\n nonprofitId: selectedNonprofitId,\n widget: \"select-nonprofit\",\n selectionId,\n });\n lastSelectedNonprofitId = selectedNonprofitId;\n }\n });\n }\n\n // https://docs.statsig.com/client/jsClientSDK#statsig-options\n async #initializeStatsig() {\n const statsigScript = document.createElement(\"script\");\n statsigScript.src = STATSIG_SCRIPT_URL;\n statsigScript.async = false;\n const statsigReadyPromise = new Promise((res, rej) => {\n statsigScript.addEventListener(\"load\", res);\n statsigScript.addEventListener(\"error\", rej);\n });\n document.head.append(statsigScript);\n try {\n await statsigReadyPromise;\n } catch (err) {\n throw new BeamError(\"Failed to load Statsig script\", { name: \"StatsigInitError\" });\n }\n this.statsig = window.statsig;\n if (!this.statsig) {\n throw new BeamError(\"Failed to detect Statsig\", { name: \"StatsigInitError\" });\n }\n // https://docs.statsig.com/client/jsClientSDK#statsig-options\n const statsigOptions = {\n disableErrorLogging: true,\n disableAutoMetricsLogging: true,\n disableCurrentPageLogging: true,\n loggingIntervalMillis: 1000,\n loggingBufferMaxSize: 2,\n overrideStableID: getCookieValue(STATSIG_STABLE_ID_COOKIE) ?? null,\n };\n await this.statsig.initialize(this.statsigApiKey, {}, statsigOptions);\n }\n\n #eventQueue: Parameters<typeof StatsigPlugin.prototype.logEvent>[] = [];\n\n #flushEventQueue() {\n while (this.#eventQueue.length > 0) {\n const eventParams = this.#eventQueue.shift();\n if (eventParams) {\n this.logEvent(...eventParams);\n }\n }\n }\n\n logEvent(name: string, value: string | number | boolean, metadata: Record<string, any> = {}) {\n if (!this.statsig) {\n this.#eventQueue.push([name, value, metadata]);\n return;\n }\n const withBeam = this.experiments.shouldShowBeam;\n if (this.experiments.isLoggingEnabled) {\n this.statsig.logEvent(name, value, { ...metadata, withBeam });\n }\n logger.debug(name, value, { ...metadata, withBeam });\n }\n\n #setBeamVisibilityValue(value: \"show\" | \"hide\") {\n document.body.setAttribute(BEAM_VISIBILITY_DATA_ATTRIBUTE, value);\n }\n\n async #testStatsigConnection() {\n // Use the HTTP API so we can synchronously detect if Statsig is reachable,\n // rather than pushing an event to the SDK's retryable queue.\n // https://docs.statsig.com/http-api\n const url = \"https://events.statsigapi.net/v1/log_event\";\n try {\n await fetch(url, {\n method: \"POST\",\n headers: {\n \"content-type\": \"application/json\",\n \"statsig-api-key\": this.statsigApiKey,\n },\n body: JSON.stringify({\n eventName: BEAM_AB_TEST_EVENTS.STATSIG_INIT,\n value: \"true\",\n time: new Date().getTime() / 1000, // unix timestamp (seconds not milliseconds)\n metadata: {\n show_beam: this.experiments.shouldShowBeam.toString(),\n page: window.location.pathname,\n },\n user: {\n userID: this.stableId,\n },\n }),\n });\n } catch (err) {\n throw new BeamError(\"Could not call Statsig API\", { name: \"StatsigInitError\", cause: err });\n // TODO: this will log failures to Beam's error tracking API in the future\n }\n }\n\n async #registerExperimentWithBeam() {\n return postExperimentSession({\n baseUrl: this.#beamConfig?.baseUrl,\n headers: {\n authorization: `Api-Key ${this.#beamConfig?.apiKey}`,\n },\n requestBody: {\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n remoteSessionId: this.stableId!,\n experiments: {\n showBeam: this.experiments.shouldShowBeam,\n },\n },\n });\n }\n}\n"],"names":["i","e","l","_beamConfig","_beamCartCookie","_attachEventListeners","attachEventListeners_fn","_initializeStatsig","initializeStatsig_fn","_eventQueue","_flushEventQueue","flushEventQueue_fn","_setBeamVisibilityValue","setBeamVisibilityValue_fn","_testStatsigConnection","testStatsigConnection_fn","_registerExperimentWithBeam","registerExperimentWithBeam_fn","STATSIG_VERSION","STATSIG_SCRIPT_URL","STATSIG_STABLE_ID_COOKIE","BEAM_VISIBILITY_DATA_ATTRIBUTE","BEAM_VISIBILITY_SYNCED_CLASS","BEAM_AB_TEST_EVENTS","StatsigPlugin","options","__privateAdd","config","__privateSet","__privateMethod","beamVisibilityStylesheet","BeamError","saveRemoteSession","getCookieValue","BEAM_CART_COOKIE_NAME","setCookieValue","logger","name","value","metadata","__privateGet","withBeam","BeamCartCreatedEvent","_event","event","itemCount","cartId","subtotal","currencyCode","BeamOrderCreatedEvent","orderId","cartTotal","lastSelectedNonprofitId","BeamNonprofitSelectEvent","selectedNonprofitId","selectionId","statsigScript","statsigReadyPromise","res","rej","statsigOptions","eventParams","url","err","postExperimentSession"],"mappings":"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"}
|