@selwise/widget 0.0.2 → 1.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +2 -1
- package/dist/npm/cjs/index.cjs +2 -0
- package/dist/npm/cjs/index.cjs.LICENSE.txt +1 -0
- package/dist/npm/cjs/index.d.ts +59 -0
- package/dist/npm/esm/index.d.ts +59 -4
- package/dist/npm/esm/index.mjs +2 -0
- package/dist/npm/esm/index.mjs.LICENSE.txt +1 -0
- package/package.json +14 -16
- package/dist/npm/cjs/constants.js +0 -167
- package/dist/npm/cjs/constants.js.map +0 -1
- package/dist/npm/cjs/core/conflict-resolver.js +0 -203
- package/dist/npm/cjs/core/conflict-resolver.js.map +0 -1
- package/dist/npm/cjs/core/event-batcher.js +0 -977
- package/dist/npm/cjs/core/event-batcher.js.map +0 -1
- package/dist/npm/cjs/core/experiment-overrides.js +0 -178
- package/dist/npm/cjs/core/experiment-overrides.js.map +0 -1
- package/dist/npm/cjs/core/experiments.js +0 -317
- package/dist/npm/cjs/core/experiments.js.map +0 -1
- package/dist/npm/cjs/core/frequency-caps.js +0 -297
- package/dist/npm/cjs/core/frequency-caps.js.map +0 -1
- package/dist/npm/cjs/core/index.js +0 -27
- package/dist/npm/cjs/core/index.js.map +0 -1
- package/dist/npm/cjs/core/indexeddb-queue.js +0 -333
- package/dist/npm/cjs/core/indexeddb-queue.js.map +0 -1
- package/dist/npm/cjs/core/journey-tracker.js +0 -243
- package/dist/npm/cjs/core/journey-tracker.js.map +0 -1
- package/dist/npm/cjs/core/page-targeting/index.js +0 -72
- package/dist/npm/cjs/core/page-targeting/index.js.map +0 -1
- package/dist/npm/cjs/core/script-executor.js +0 -80
- package/dist/npm/cjs/core/script-executor.js.map +0 -1
- package/dist/npm/cjs/core/segments.js +0 -172
- package/dist/npm/cjs/core/segments.js.map +0 -1
- package/dist/npm/cjs/core/tracker.js +0 -798
- package/dist/npm/cjs/core/tracker.js.map +0 -1
- package/dist/npm/cjs/datalayer/basket.js +0 -385
- package/dist/npm/cjs/datalayer/basket.js.map +0 -1
- package/dist/npm/cjs/datalayer/cart-association.js +0 -226
- package/dist/npm/cjs/datalayer/cart-association.js.map +0 -1
- package/dist/npm/cjs/datalayer/checkout.js +0 -382
- package/dist/npm/cjs/datalayer/checkout.js.map +0 -1
- package/dist/npm/cjs/datalayer/constants.js +0 -163
- package/dist/npm/cjs/datalayer/constants.js.map +0 -1
- package/dist/npm/cjs/datalayer/index.js +0 -1010
- package/dist/npm/cjs/datalayer/index.js.map +0 -1
- package/dist/npm/cjs/datalayer/listener.js +0 -416
- package/dist/npm/cjs/datalayer/listener.js.map +0 -1
- package/dist/npm/cjs/datalayer/page.js +0 -343
- package/dist/npm/cjs/datalayer/page.js.map +0 -1
- package/dist/npm/cjs/datalayer/product.js +0 -517
- package/dist/npm/cjs/datalayer/product.js.map +0 -1
- package/dist/npm/cjs/datalayer/reverse-mappings.js +0 -139
- package/dist/npm/cjs/datalayer/reverse-mappings.js.map +0 -1
- package/dist/npm/cjs/datalayer/search.js +0 -363
- package/dist/npm/cjs/datalayer/search.js.map +0 -1
- package/dist/npm/cjs/datalayer/types.js +0 -134
- package/dist/npm/cjs/datalayer/types.js.map +0 -1
- package/dist/npm/cjs/datalayer/user.js +0 -372
- package/dist/npm/cjs/datalayer/user.js.map +0 -1
- package/dist/npm/cjs/debug/index.js +0 -679
- package/dist/npm/cjs/debug/index.js.map +0 -1
- package/dist/npm/cjs/entries/cdn.js +0 -72
- package/dist/npm/cjs/entries/cdn.js.map +0 -1
- package/dist/npm/cjs/index.js +0 -10
- package/dist/npm/cjs/index.js.map +0 -1
- package/dist/npm/cjs/modules/contract/recommendation-contract.js +0 -119
- package/dist/npm/cjs/modules/contract/recommendation-contract.js.map +0 -1
- package/dist/npm/cjs/modules/contract/search-contract.js +0 -18
- package/dist/npm/cjs/modules/contract/search-contract.js.map +0 -1
- package/dist/npm/cjs/modules/contract/tracking-contract.js +0 -16
- package/dist/npm/cjs/modules/contract/tracking-contract.js.map +0 -1
- package/dist/npm/cjs/modules/contract/vendor/recommendation-contract/configs.js +0 -164
- package/dist/npm/cjs/modules/contract/vendor/recommendation-contract/configs.js.map +0 -1
- package/dist/npm/cjs/modules/contract/vendor/recommendation-contract/index.js +0 -21
- package/dist/npm/cjs/modules/contract/vendor/recommendation-contract/index.js.map +0 -1
- package/dist/npm/cjs/modules/contract/vendor/recommendation-contract/types.js +0 -3
- package/dist/npm/cjs/modules/contract/vendor/recommendation-contract/types.js.map +0 -1
- package/dist/npm/cjs/modules/contract/vendor/recommendation-contract/validators.js +0 -107
- package/dist/npm/cjs/modules/contract/vendor/recommendation-contract/validators.js.map +0 -1
- package/dist/npm/cjs/modules/contract/vendor/search-contract/configs.js +0 -404
- package/dist/npm/cjs/modules/contract/vendor/search-contract/configs.js.map +0 -1
- package/dist/npm/cjs/modules/contract/vendor/search-contract/index.js +0 -21
- package/dist/npm/cjs/modules/contract/vendor/search-contract/index.js.map +0 -1
- package/dist/npm/cjs/modules/contract/vendor/search-contract/types.js +0 -8
- package/dist/npm/cjs/modules/contract/vendor/search-contract/types.js.map +0 -1
- package/dist/npm/cjs/modules/contract/vendor/search-contract/validators.js +0 -126
- package/dist/npm/cjs/modules/contract/vendor/search-contract/validators.js.map +0 -1
- package/dist/npm/cjs/modules/contract/vendor/tracking-contract/configs.js +0 -133
- package/dist/npm/cjs/modules/contract/vendor/tracking-contract/configs.js.map +0 -1
- package/dist/npm/cjs/modules/contract/vendor/tracking-contract/index.js +0 -21
- package/dist/npm/cjs/modules/contract/vendor/tracking-contract/index.js.map +0 -1
- package/dist/npm/cjs/modules/contract/vendor/tracking-contract/types.js +0 -3
- package/dist/npm/cjs/modules/contract/vendor/tracking-contract/types.js.map +0 -1
- package/dist/npm/cjs/modules/contract/vendor/tracking-contract/validators.js +0 -154
- package/dist/npm/cjs/modules/contract/vendor/tracking-contract/validators.js.map +0 -1
- package/dist/npm/cjs/modules/contract/vendor/widget-contract/configs.js +0 -1481
- package/dist/npm/cjs/modules/contract/vendor/widget-contract/configs.js.map +0 -1
- package/dist/npm/cjs/modules/contract/vendor/widget-contract/index.js +0 -22
- package/dist/npm/cjs/modules/contract/vendor/widget-contract/index.js.map +0 -1
- package/dist/npm/cjs/modules/contract/vendor/widget-contract/layout.js +0 -21
- package/dist/npm/cjs/modules/contract/vendor/widget-contract/layout.js.map +0 -1
- package/dist/npm/cjs/modules/contract/vendor/widget-contract/types.js +0 -8
- package/dist/npm/cjs/modules/contract/vendor/widget-contract/types.js.map +0 -1
- package/dist/npm/cjs/modules/contract/vendor/widget-contract/validators.js +0 -139
- package/dist/npm/cjs/modules/contract/vendor/widget-contract/validators.js.map +0 -1
- package/dist/npm/cjs/modules/contract/widget-contract.js +0 -10
- package/dist/npm/cjs/modules/contract/widget-contract.js.map +0 -1
- package/dist/npm/cjs/modules/products/tracking.js +0 -214
- package/dist/npm/cjs/modules/products/tracking.js.map +0 -1
- package/dist/npm/cjs/modules/recommendation/cart-handlers.js +0 -52
- package/dist/npm/cjs/modules/recommendation/cart-handlers.js.map +0 -1
- package/dist/npm/cjs/modules/recommendation/components/product-card-renderer.js +0 -287
- package/dist/npm/cjs/modules/recommendation/components/product-card-renderer.js.map +0 -1
- package/dist/npm/cjs/modules/recommendation/index.js +0 -678
- package/dist/npm/cjs/modules/recommendation/index.js.map +0 -1
- package/dist/npm/cjs/modules/recommendation/renderers/grid.js +0 -21
- package/dist/npm/cjs/modules/recommendation/renderers/grid.js.map +0 -1
- package/dist/npm/cjs/modules/recommendation/renderers/list.js +0 -22
- package/dist/npm/cjs/modules/recommendation/renderers/list.js.map +0 -1
- package/dist/npm/cjs/modules/recommendation/renderers/masonry.js +0 -22
- package/dist/npm/cjs/modules/recommendation/renderers/masonry.js.map +0 -1
- package/dist/npm/cjs/modules/recommendation/renderers/slider-renderer.js +0 -145
- package/dist/npm/cjs/modules/recommendation/renderers/slider-renderer.js.map +0 -1
- package/dist/npm/cjs/modules/recommendation/slider-controls.js +0 -201
- package/dist/npm/cjs/modules/recommendation/slider-controls.js.map +0 -1
- package/dist/npm/cjs/modules/recommendation/tracking.js +0 -247
- package/dist/npm/cjs/modules/recommendation/tracking.js.map +0 -1
- package/dist/npm/cjs/modules/recommendation/utils/dom.js +0 -70
- package/dist/npm/cjs/modules/recommendation/utils/dom.js.map +0 -1
- package/dist/npm/cjs/modules/recommendation/utils/format.js +0 -13
- package/dist/npm/cjs/modules/recommendation/utils/format.js.map +0 -1
- package/dist/npm/cjs/modules/recommendation/utils/index.js +0 -22
- package/dist/npm/cjs/modules/recommendation/utils/index.js.map +0 -1
- package/dist/npm/cjs/modules/renderer/helpers.js +0 -16
- package/dist/npm/cjs/modules/renderer/helpers.js.map +0 -1
- package/dist/npm/cjs/modules/renderer/index.js +0 -52
- package/dist/npm/cjs/modules/renderer/index.js.map +0 -1
- package/dist/npm/cjs/modules/renderer/style-resolver.js +0 -11
- package/dist/npm/cjs/modules/renderer/style-resolver.js.map +0 -1
- package/dist/npm/cjs/modules/renderer/styles/index.js +0 -254
- package/dist/npm/cjs/modules/renderer/styles/index.js.map +0 -1
- package/dist/npm/cjs/modules/renderer/styles.js +0 -7
- package/dist/npm/cjs/modules/renderer/styles.js.map +0 -1
- package/dist/npm/cjs/modules/renderer/utils/helpers.js +0 -243
- package/dist/npm/cjs/modules/renderer/utils/helpers.js.map +0 -1
- package/dist/npm/cjs/modules/renderer/utils/image-renderer.js +0 -65
- package/dist/npm/cjs/modules/renderer/utils/image-renderer.js.map +0 -1
- package/dist/npm/cjs/modules/renderer/utils/placement.js +0 -34
- package/dist/npm/cjs/modules/renderer/utils/placement.js.map +0 -1
- package/dist/npm/cjs/modules/renderer/utils.js +0 -61
- package/dist/npm/cjs/modules/renderer/utils.js.map +0 -1
- package/dist/npm/cjs/modules/renderer/widgets/announcement-bar.js +0 -84
- package/dist/npm/cjs/modules/renderer/widgets/announcement-bar.js.map +0 -1
- package/dist/npm/cjs/modules/renderer/widgets/cart-count.js +0 -211
- package/dist/npm/cjs/modules/renderer/widgets/cart-count.js.map +0 -1
- package/dist/npm/cjs/modules/renderer/widgets/cookie-consent.js +0 -459
- package/dist/npm/cjs/modules/renderer/widgets/cookie-consent.js.map +0 -1
- package/dist/npm/cjs/modules/renderer/widgets/countdown-timer.js +0 -132
- package/dist/npm/cjs/modules/renderer/widgets/countdown-timer.js.map +0 -1
- package/dist/npm/cjs/modules/renderer/widgets/custom.js +0 -58
- package/dist/npm/cjs/modules/renderer/widgets/custom.js.map +0 -1
- package/dist/npm/cjs/modules/renderer/widgets/embedded-card.js +0 -97
- package/dist/npm/cjs/modules/renderer/widgets/embedded-card.js.map +0 -1
- package/dist/npm/cjs/modules/renderer/widgets/exit-intent-popup.js +0 -151
- package/dist/npm/cjs/modules/renderer/widgets/exit-intent-popup.js.map +0 -1
- package/dist/npm/cjs/modules/renderer/widgets/floating-button.js +0 -70
- package/dist/npm/cjs/modules/renderer/widgets/floating-button.js.map +0 -1
- package/dist/npm/cjs/modules/renderer/widgets/helpers.js +0 -87
- package/dist/npm/cjs/modules/renderer/widgets/helpers.js.map +0 -1
- package/dist/npm/cjs/modules/renderer/widgets/index.js +0 -39
- package/dist/npm/cjs/modules/renderer/widgets/index.js.map +0 -1
- package/dist/npm/cjs/modules/renderer/widgets/inline-banner.js +0 -124
- package/dist/npm/cjs/modules/renderer/widgets/inline-banner.js.map +0 -1
- package/dist/npm/cjs/modules/renderer/widgets/newsletter.js +0 -280
- package/dist/npm/cjs/modules/renderer/widgets/newsletter.js.map +0 -1
- package/dist/npm/cjs/modules/renderer/widgets/product-view-count.js +0 -197
- package/dist/npm/cjs/modules/renderer/widgets/product-view-count.js.map +0 -1
- package/dist/npm/cjs/modules/renderer/widgets/slide-in.js +0 -105
- package/dist/npm/cjs/modules/renderer/widgets/slide-in.js.map +0 -1
- package/dist/npm/cjs/modules/renderer/widgets/sticky-footer.js +0 -47
- package/dist/npm/cjs/modules/renderer/widgets/sticky-footer.js.map +0 -1
- package/dist/npm/cjs/modules/search/cart/index.js +0 -42
- package/dist/npm/cjs/modules/search/cart/index.js.map +0 -1
- package/dist/npm/cjs/modules/search/components/index.js +0 -13
- package/dist/npm/cjs/modules/search/components/index.js.map +0 -1
- package/dist/npm/cjs/modules/search/components/search-box.js +0 -28
- package/dist/npm/cjs/modules/search/components/search-box.js.map +0 -1
- package/dist/npm/cjs/modules/search/components/search-item.js +0 -197
- package/dist/npm/cjs/modules/search/components/search-item.js.map +0 -1
- package/dist/npm/cjs/modules/search/components/suggestions.js +0 -132
- package/dist/npm/cjs/modules/search/components/suggestions.js.map +0 -1
- package/dist/npm/cjs/modules/search/index.js +0 -646
- package/dist/npm/cjs/modules/search/index.js.map +0 -1
- package/dist/npm/cjs/modules/search/renderers/position-renderers.js +0 -229
- package/dist/npm/cjs/modules/search/renderers/position-renderers.js.map +0 -1
- package/dist/npm/cjs/modules/search/renderers/results-renderer.js +0 -180
- package/dist/npm/cjs/modules/search/renderers/results-renderer.js.map +0 -1
- package/dist/npm/cjs/modules/search/services/api-service.js +0 -121
- package/dist/npm/cjs/modules/search/services/api-service.js.map +0 -1
- package/dist/npm/cjs/modules/search/services/tracking-service.js +0 -263
- package/dist/npm/cjs/modules/search/services/tracking-service.js.map +0 -1
- package/dist/npm/cjs/modules/search/styles.js +0 -864
- package/dist/npm/cjs/modules/search/styles.js.map +0 -1
- package/dist/npm/cjs/modules/search/utils/helpers.js +0 -100
- package/dist/npm/cjs/modules/search/utils/helpers.js.map +0 -1
- package/dist/npm/cjs/modules/search/utils/icons.js +0 -41
- package/dist/npm/cjs/modules/search/utils/icons.js.map +0 -1
- package/dist/npm/cjs/modules/search/utils/index.js +0 -22
- package/dist/npm/cjs/modules/search/utils/index.js.map +0 -1
- package/dist/npm/cjs/modules/search/utils/storage.js +0 -58
- package/dist/npm/cjs/modules/search/utils/storage.js.map +0 -1
- package/dist/npm/cjs/selwise.js +0 -1160
- package/dist/npm/cjs/selwise.js.map +0 -1
- package/dist/npm/cjs/sentry-test.js +0 -118
- package/dist/npm/cjs/sentry-test.js.map +0 -1
- package/dist/npm/cjs/sentry.js +0 -451
- package/dist/npm/cjs/sentry.js.map +0 -1
- package/dist/npm/cjs/shared/cart/handlers.js +0 -259
- package/dist/npm/cjs/shared/cart/handlers.js.map +0 -1
- package/dist/npm/cjs/shared/cart/index.js +0 -23
- package/dist/npm/cjs/shared/cart/index.js.map +0 -1
- package/dist/npm/cjs/shared/cart/types.js +0 -7
- package/dist/npm/cjs/shared/cart/types.js.map +0 -1
- package/dist/npm/cjs/shared/product-card/index.js +0 -24
- package/dist/npm/cjs/shared/product-card/index.js.map +0 -1
- package/dist/npm/cjs/shared/product-card/renderer.js +0 -341
- package/dist/npm/cjs/shared/product-card/renderer.js.map +0 -1
- package/dist/npm/cjs/shared/product-card/styles.js +0 -195
- package/dist/npm/cjs/shared/product-card/styles.js.map +0 -1
- package/dist/npm/cjs/shared/product-card/types.js +0 -67
- package/dist/npm/cjs/shared/product-card/types.js.map +0 -1
- package/dist/npm/cjs/types/config.js +0 -6
- package/dist/npm/cjs/types/config.js.map +0 -1
- package/dist/npm/cjs/types/experiments.js +0 -17
- package/dist/npm/cjs/types/experiments.js.map +0 -1
- package/dist/npm/cjs/types/global-api.js +0 -3
- package/dist/npm/cjs/types/global-api.js.map +0 -1
- package/dist/npm/cjs/types/index.js +0 -27
- package/dist/npm/cjs/types/index.js.map +0 -1
- package/dist/npm/cjs/types/recommendation.js +0 -6
- package/dist/npm/cjs/types/recommendation.js.map +0 -1
- package/dist/npm/cjs/types/renderer.js +0 -6
- package/dist/npm/cjs/types/renderer.js.map +0 -1
- package/dist/npm/cjs/types/search.js +0 -6
- package/dist/npm/cjs/types/search.js.map +0 -1
- package/dist/npm/cjs/utils/api-url.js +0 -35
- package/dist/npm/cjs/utils/api-url.js.map +0 -1
- package/dist/npm/cjs/utils/debounce.js +0 -74
- package/dist/npm/cjs/utils/debounce.js.map +0 -1
- package/dist/npm/cjs/utils/event-id.js +0 -23
- package/dist/npm/cjs/utils/event-id.js.map +0 -1
- package/dist/npm/cjs/utils/index.js +0 -28
- package/dist/npm/cjs/utils/index.js.map +0 -1
- package/dist/npm/cjs/utils/logger.js +0 -74
- package/dist/npm/cjs/utils/logger.js.map +0 -1
- package/dist/npm/cjs/utils/sanitize.js +0 -159
- package/dist/npm/cjs/utils/sanitize.js.map +0 -1
- package/dist/npm/cjs/utils/storage.js +0 -285
- package/dist/npm/cjs/utils/storage.js.map +0 -1
- package/dist/npm/cjs/utils/tracking-metadata.js +0 -18
- package/dist/npm/cjs/utils/tracking-metadata.js.map +0 -1
- package/dist/npm/cjs/utils/url-matcher.js +0 -11
- package/dist/npm/cjs/utils/url-matcher.js.map +0 -1
- package/dist/npm/esm/constants.d.ts +0 -130
- package/dist/npm/esm/constants.js +0 -164
- package/dist/npm/esm/constants.js.map +0 -1
- package/dist/npm/esm/core/conflict-resolver.d.ts +0 -96
- package/dist/npm/esm/core/conflict-resolver.js +0 -198
- package/dist/npm/esm/core/conflict-resolver.js.map +0 -1
- package/dist/npm/esm/core/event-batcher.d.ts +0 -253
- package/dist/npm/esm/core/event-batcher.js +0 -973
- package/dist/npm/esm/core/event-batcher.js.map +0 -1
- package/dist/npm/esm/core/experiment-overrides.d.ts +0 -7
- package/dist/npm/esm/core/experiment-overrides.js +0 -172
- package/dist/npm/esm/core/experiment-overrides.js.map +0 -1
- package/dist/npm/esm/core/experiments.d.ts +0 -90
- package/dist/npm/esm/core/experiments.js +0 -313
- package/dist/npm/esm/core/experiments.js.map +0 -1
- package/dist/npm/esm/core/frequency-caps.d.ts +0 -124
- package/dist/npm/esm/core/frequency-caps.js +0 -292
- package/dist/npm/esm/core/frequency-caps.js.map +0 -1
- package/dist/npm/esm/core/index.d.ts +0 -10
- package/dist/npm/esm/core/index.js +0 -11
- package/dist/npm/esm/core/index.js.map +0 -1
- package/dist/npm/esm/core/indexeddb-queue.d.ts +0 -83
- package/dist/npm/esm/core/indexeddb-queue.js +0 -328
- package/dist/npm/esm/core/indexeddb-queue.js.map +0 -1
- package/dist/npm/esm/core/journey-tracker.d.ts +0 -102
- package/dist/npm/esm/core/journey-tracker.js +0 -237
- package/dist/npm/esm/core/journey-tracker.js.map +0 -1
- package/dist/npm/esm/core/page-targeting/index.d.ts +0 -8
- package/dist/npm/esm/core/page-targeting/index.js +0 -67
- package/dist/npm/esm/core/page-targeting/index.js.map +0 -1
- package/dist/npm/esm/core/script-executor.d.ts +0 -31
- package/dist/npm/esm/core/script-executor.js +0 -76
- package/dist/npm/esm/core/script-executor.js.map +0 -1
- package/dist/npm/esm/core/segments.d.ts +0 -39
- package/dist/npm/esm/core/segments.js +0 -168
- package/dist/npm/esm/core/segments.js.map +0 -1
- package/dist/npm/esm/core/tracker.d.ts +0 -182
- package/dist/npm/esm/core/tracker.js +0 -794
- package/dist/npm/esm/core/tracker.js.map +0 -1
- package/dist/npm/esm/datalayer/basket.d.ts +0 -104
- package/dist/npm/esm/datalayer/basket.js +0 -381
- package/dist/npm/esm/datalayer/basket.js.map +0 -1
- package/dist/npm/esm/datalayer/cart-association.d.ts +0 -65
- package/dist/npm/esm/datalayer/cart-association.js +0 -222
- package/dist/npm/esm/datalayer/cart-association.js.map +0 -1
- package/dist/npm/esm/datalayer/checkout.d.ts +0 -96
- package/dist/npm/esm/datalayer/checkout.js +0 -378
- package/dist/npm/esm/datalayer/checkout.js.map +0 -1
- package/dist/npm/esm/datalayer/constants.d.ts +0 -77
- package/dist/npm/esm/datalayer/constants.js +0 -160
- package/dist/npm/esm/datalayer/constants.js.map +0 -1
- package/dist/npm/esm/datalayer/index.d.ts +0 -212
- package/dist/npm/esm/datalayer/index.js +0 -991
- package/dist/npm/esm/datalayer/index.js.map +0 -1
- package/dist/npm/esm/datalayer/listener.d.ts +0 -108
- package/dist/npm/esm/datalayer/listener.js +0 -411
- package/dist/npm/esm/datalayer/listener.js.map +0 -1
- package/dist/npm/esm/datalayer/page.d.ts +0 -94
- package/dist/npm/esm/datalayer/page.js +0 -339
- package/dist/npm/esm/datalayer/page.js.map +0 -1
- package/dist/npm/esm/datalayer/product.d.ts +0 -133
- package/dist/npm/esm/datalayer/product.js +0 -513
- package/dist/npm/esm/datalayer/product.js.map +0 -1
- package/dist/npm/esm/datalayer/reverse-mappings.d.ts +0 -62
- package/dist/npm/esm/datalayer/reverse-mappings.js +0 -135
- package/dist/npm/esm/datalayer/reverse-mappings.js.map +0 -1
- package/dist/npm/esm/datalayer/search.d.ts +0 -108
- package/dist/npm/esm/datalayer/search.js +0 -359
- package/dist/npm/esm/datalayer/search.js.map +0 -1
- package/dist/npm/esm/datalayer/types.d.ts +0 -292
- package/dist/npm/esm/datalayer/types.js +0 -131
- package/dist/npm/esm/datalayer/types.js.map +0 -1
- package/dist/npm/esm/datalayer/user.d.ts +0 -104
- package/dist/npm/esm/datalayer/user.js +0 -368
- package/dist/npm/esm/datalayer/user.js.map +0 -1
- package/dist/npm/esm/debug/index.d.ts +0 -173
- package/dist/npm/esm/debug/index.js +0 -673
- package/dist/npm/esm/debug/index.js.map +0 -1
- package/dist/npm/esm/entries/cdn.d.ts +0 -1
- package/dist/npm/esm/entries/cdn.js +0 -35
- package/dist/npm/esm/entries/cdn.js.map +0 -1
- package/dist/npm/esm/index.js +0 -4
- package/dist/npm/esm/index.js.map +0 -1
- package/dist/npm/esm/modules/contract/recommendation-contract.d.ts +0 -5
- package/dist/npm/esm/modules/contract/recommendation-contract.js +0 -107
- package/dist/npm/esm/modules/contract/recommendation-contract.js.map +0 -1
- package/dist/npm/esm/modules/contract/search-contract.d.ts +0 -1
- package/dist/npm/esm/modules/contract/search-contract.js +0 -2
- package/dist/npm/esm/modules/contract/search-contract.js.map +0 -1
- package/dist/npm/esm/modules/contract/tracking-contract.d.ts +0 -1
- package/dist/npm/esm/modules/contract/tracking-contract.js +0 -2
- package/dist/npm/esm/modules/contract/tracking-contract.js.map +0 -1
- package/dist/npm/esm/modules/contract/vendor/recommendation-contract/configs.d.ts +0 -8
- package/dist/npm/esm/modules/contract/vendor/recommendation-contract/configs.js +0 -160
- package/dist/npm/esm/modules/contract/vendor/recommendation-contract/configs.js.map +0 -1
- package/dist/npm/esm/modules/contract/vendor/recommendation-contract/index.d.ts +0 -3
- package/dist/npm/esm/modules/contract/vendor/recommendation-contract/index.js +0 -5
- package/dist/npm/esm/modules/contract/vendor/recommendation-contract/index.js.map +0 -1
- package/dist/npm/esm/modules/contract/vendor/recommendation-contract/types.d.ts +0 -56
- package/dist/npm/esm/modules/contract/vendor/recommendation-contract/types.js +0 -2
- package/dist/npm/esm/modules/contract/vendor/recommendation-contract/types.js.map +0 -1
- package/dist/npm/esm/modules/contract/vendor/recommendation-contract/validators.d.ts +0 -3
- package/dist/npm/esm/modules/contract/vendor/recommendation-contract/validators.js +0 -103
- package/dist/npm/esm/modules/contract/vendor/recommendation-contract/validators.js.map +0 -1
- package/dist/npm/esm/modules/contract/vendor/search-contract/configs.d.ts +0 -35
- package/dist/npm/esm/modules/contract/vendor/search-contract/configs.js +0 -396
- package/dist/npm/esm/modules/contract/vendor/search-contract/configs.js.map +0 -1
- package/dist/npm/esm/modules/contract/vendor/search-contract/index.d.ts +0 -3
- package/dist/npm/esm/modules/contract/vendor/search-contract/index.js +0 -5
- package/dist/npm/esm/modules/contract/vendor/search-contract/index.js.map +0 -1
- package/dist/npm/esm/modules/contract/vendor/search-contract/types.d.ts +0 -119
- package/dist/npm/esm/modules/contract/vendor/search-contract/types.js +0 -7
- package/dist/npm/esm/modules/contract/vendor/search-contract/types.js.map +0 -1
- package/dist/npm/esm/modules/contract/vendor/search-contract/validators.d.ts +0 -22
- package/dist/npm/esm/modules/contract/vendor/search-contract/validators.js +0 -118
- package/dist/npm/esm/modules/contract/vendor/search-contract/validators.js.map +0 -1
- package/dist/npm/esm/modules/contract/vendor/tracking-contract/configs.d.ts +0 -7
- package/dist/npm/esm/modules/contract/vendor/tracking-contract/configs.js +0 -130
- package/dist/npm/esm/modules/contract/vendor/tracking-contract/configs.js.map +0 -1
- package/dist/npm/esm/modules/contract/vendor/tracking-contract/index.d.ts +0 -3
- package/dist/npm/esm/modules/contract/vendor/tracking-contract/index.js +0 -5
- package/dist/npm/esm/modules/contract/vendor/tracking-contract/index.js.map +0 -1
- package/dist/npm/esm/modules/contract/vendor/tracking-contract/types.d.ts +0 -37
- package/dist/npm/esm/modules/contract/vendor/tracking-contract/types.js +0 -2
- package/dist/npm/esm/modules/contract/vendor/tracking-contract/types.js.map +0 -1
- package/dist/npm/esm/modules/contract/vendor/tracking-contract/validators.d.ts +0 -6
- package/dist/npm/esm/modules/contract/vendor/tracking-contract/validators.js +0 -147
- package/dist/npm/esm/modules/contract/vendor/tracking-contract/validators.js.map +0 -1
- package/dist/npm/esm/modules/contract/vendor/widget-contract/configs.d.ts +0 -22
- package/dist/npm/esm/modules/contract/vendor/widget-contract/configs.js +0 -1472
- package/dist/npm/esm/modules/contract/vendor/widget-contract/configs.js.map +0 -1
- package/dist/npm/esm/modules/contract/vendor/widget-contract/index.d.ts +0 -4
- package/dist/npm/esm/modules/contract/vendor/widget-contract/index.js +0 -6
- package/dist/npm/esm/modules/contract/vendor/widget-contract/index.js.map +0 -1
- package/dist/npm/esm/modules/contract/vendor/widget-contract/layout.d.ts +0 -14
- package/dist/npm/esm/modules/contract/vendor/widget-contract/layout.js +0 -18
- package/dist/npm/esm/modules/contract/vendor/widget-contract/layout.js.map +0 -1
- package/dist/npm/esm/modules/contract/vendor/widget-contract/types.d.ts +0 -128
- package/dist/npm/esm/modules/contract/vendor/widget-contract/types.js +0 -7
- package/dist/npm/esm/modules/contract/vendor/widget-contract/types.js.map +0 -1
- package/dist/npm/esm/modules/contract/vendor/widget-contract/validators.d.ts +0 -11
- package/dist/npm/esm/modules/contract/vendor/widget-contract/validators.js +0 -132
- package/dist/npm/esm/modules/contract/vendor/widget-contract/validators.js.map +0 -1
- package/dist/npm/esm/modules/contract/widget-contract.d.ts +0 -1
- package/dist/npm/esm/modules/contract/widget-contract.js +0 -2
- package/dist/npm/esm/modules/contract/widget-contract.js.map +0 -1
- package/dist/npm/esm/modules/products/tracking.d.ts +0 -122
- package/dist/npm/esm/modules/products/tracking.js +0 -203
- package/dist/npm/esm/modules/products/tracking.js.map +0 -1
- package/dist/npm/esm/modules/recommendation/cart-handlers.d.ts +0 -10
- package/dist/npm/esm/modules/recommendation/cart-handlers.js +0 -49
- package/dist/npm/esm/modules/recommendation/cart-handlers.js.map +0 -1
- package/dist/npm/esm/modules/recommendation/components/product-card-renderer.d.ts +0 -37
- package/dist/npm/esm/modules/recommendation/components/product-card-renderer.js +0 -281
- package/dist/npm/esm/modules/recommendation/components/product-card-renderer.js.map +0 -1
- package/dist/npm/esm/modules/recommendation/index.d.ts +0 -11
- package/dist/npm/esm/modules/recommendation/index.js +0 -674
- package/dist/npm/esm/modules/recommendation/index.js.map +0 -1
- package/dist/npm/esm/modules/recommendation/renderers/grid.d.ts +0 -5
- package/dist/npm/esm/modules/recommendation/renderers/grid.js +0 -18
- package/dist/npm/esm/modules/recommendation/renderers/grid.js.map +0 -1
- package/dist/npm/esm/modules/recommendation/renderers/list.d.ts +0 -5
- package/dist/npm/esm/modules/recommendation/renderers/list.js +0 -19
- package/dist/npm/esm/modules/recommendation/renderers/list.js.map +0 -1
- package/dist/npm/esm/modules/recommendation/renderers/masonry.d.ts +0 -5
- package/dist/npm/esm/modules/recommendation/renderers/masonry.js +0 -19
- package/dist/npm/esm/modules/recommendation/renderers/masonry.js.map +0 -1
- package/dist/npm/esm/modules/recommendation/renderers/slider-renderer.d.ts +0 -10
- package/dist/npm/esm/modules/recommendation/renderers/slider-renderer.js +0 -140
- package/dist/npm/esm/modules/recommendation/renderers/slider-renderer.js.map +0 -1
- package/dist/npm/esm/modules/recommendation/slider-controls.d.ts +0 -17
- package/dist/npm/esm/modules/recommendation/slider-controls.js +0 -187
- package/dist/npm/esm/modules/recommendation/slider-controls.js.map +0 -1
- package/dist/npm/esm/modules/recommendation/tracking.d.ts +0 -28
- package/dist/npm/esm/modules/recommendation/tracking.js +0 -237
- package/dist/npm/esm/modules/recommendation/tracking.js.map +0 -1
- package/dist/npm/esm/modules/recommendation/utils/dom.d.ts +0 -10
- package/dist/npm/esm/modules/recommendation/utils/dom.js +0 -63
- package/dist/npm/esm/modules/recommendation/utils/dom.js.map +0 -1
- package/dist/npm/esm/modules/recommendation/utils/format.d.ts +0 -4
- package/dist/npm/esm/modules/recommendation/utils/format.js +0 -10
- package/dist/npm/esm/modules/recommendation/utils/format.js.map +0 -1
- package/dist/npm/esm/modules/recommendation/utils/index.d.ts +0 -5
- package/dist/npm/esm/modules/recommendation/utils/index.js +0 -6
- package/dist/npm/esm/modules/recommendation/utils/index.js.map +0 -1
- package/dist/npm/esm/modules/renderer/helpers.d.ts +0 -5
- package/dist/npm/esm/modules/renderer/helpers.js +0 -6
- package/dist/npm/esm/modules/renderer/helpers.js.map +0 -1
- package/dist/npm/esm/modules/renderer/index.d.ts +0 -8
- package/dist/npm/esm/modules/renderer/index.js +0 -48
- package/dist/npm/esm/modules/renderer/index.js.map +0 -1
- package/dist/npm/esm/modules/renderer/style-resolver.d.ts +0 -1
- package/dist/npm/esm/modules/renderer/style-resolver.js +0 -8
- package/dist/npm/esm/modules/renderer/style-resolver.js.map +0 -1
- package/dist/npm/esm/modules/renderer/styles/index.d.ts +0 -12
- package/dist/npm/esm/modules/renderer/styles/index.js +0 -250
- package/dist/npm/esm/modules/renderer/styles/index.js.map +0 -1
- package/dist/npm/esm/modules/renderer/styles.d.ts +0 -1
- package/dist/npm/esm/modules/renderer/styles.js +0 -2
- package/dist/npm/esm/modules/renderer/styles.js.map +0 -1
- package/dist/npm/esm/modules/renderer/utils/helpers.d.ts +0 -58
- package/dist/npm/esm/modules/renderer/utils/helpers.js +0 -225
- package/dist/npm/esm/modules/renderer/utils/helpers.js.map +0 -1
- package/dist/npm/esm/modules/renderer/utils/image-renderer.d.ts +0 -17
- package/dist/npm/esm/modules/renderer/utils/image-renderer.js +0 -60
- package/dist/npm/esm/modules/renderer/utils/image-renderer.js.map +0 -1
- package/dist/npm/esm/modules/renderer/utils/placement.d.ts +0 -6
- package/dist/npm/esm/modules/renderer/utils/placement.js +0 -31
- package/dist/npm/esm/modules/renderer/utils/placement.js.map +0 -1
- package/dist/npm/esm/modules/renderer/utils.d.ts +0 -11
- package/dist/npm/esm/modules/renderer/utils.js +0 -44
- package/dist/npm/esm/modules/renderer/utils.js.map +0 -1
- package/dist/npm/esm/modules/renderer/widgets/announcement-bar.d.ts +0 -5
- package/dist/npm/esm/modules/renderer/widgets/announcement-bar.js +0 -81
- package/dist/npm/esm/modules/renderer/widgets/announcement-bar.js.map +0 -1
- package/dist/npm/esm/modules/renderer/widgets/cart-count.d.ts +0 -6
- package/dist/npm/esm/modules/renderer/widgets/cart-count.js +0 -208
- package/dist/npm/esm/modules/renderer/widgets/cart-count.js.map +0 -1
- package/dist/npm/esm/modules/renderer/widgets/cookie-consent.d.ts +0 -18
- package/dist/npm/esm/modules/renderer/widgets/cookie-consent.js +0 -454
- package/dist/npm/esm/modules/renderer/widgets/cookie-consent.js.map +0 -1
- package/dist/npm/esm/modules/renderer/widgets/countdown-timer.d.ts +0 -5
- package/dist/npm/esm/modules/renderer/widgets/countdown-timer.js +0 -129
- package/dist/npm/esm/modules/renderer/widgets/countdown-timer.js.map +0 -1
- package/dist/npm/esm/modules/renderer/widgets/custom.d.ts +0 -5
- package/dist/npm/esm/modules/renderer/widgets/custom.js +0 -55
- package/dist/npm/esm/modules/renderer/widgets/custom.js.map +0 -1
- package/dist/npm/esm/modules/renderer/widgets/embedded-card.d.ts +0 -5
- package/dist/npm/esm/modules/renderer/widgets/embedded-card.js +0 -94
- package/dist/npm/esm/modules/renderer/widgets/embedded-card.js.map +0 -1
- package/dist/npm/esm/modules/renderer/widgets/exit-intent-popup.d.ts +0 -6
- package/dist/npm/esm/modules/renderer/widgets/exit-intent-popup.js +0 -147
- package/dist/npm/esm/modules/renderer/widgets/exit-intent-popup.js.map +0 -1
- package/dist/npm/esm/modules/renderer/widgets/floating-button.d.ts +0 -5
- package/dist/npm/esm/modules/renderer/widgets/floating-button.js +0 -67
- package/dist/npm/esm/modules/renderer/widgets/floating-button.js.map +0 -1
- package/dist/npm/esm/modules/renderer/widgets/helpers.d.ts +0 -29
- package/dist/npm/esm/modules/renderer/widgets/helpers.js +0 -82
- package/dist/npm/esm/modules/renderer/widgets/helpers.js.map +0 -1
- package/dist/npm/esm/modules/renderer/widgets/index.d.ts +0 -17
- package/dist/npm/esm/modules/renderer/widgets/index.js +0 -19
- package/dist/npm/esm/modules/renderer/widgets/index.js.map +0 -1
- package/dist/npm/esm/modules/renderer/widgets/inline-banner.d.ts +0 -5
- package/dist/npm/esm/modules/renderer/widgets/inline-banner.js +0 -121
- package/dist/npm/esm/modules/renderer/widgets/inline-banner.js.map +0 -1
- package/dist/npm/esm/modules/renderer/widgets/newsletter.d.ts +0 -6
- package/dist/npm/esm/modules/renderer/widgets/newsletter.js +0 -277
- package/dist/npm/esm/modules/renderer/widgets/newsletter.js.map +0 -1
- package/dist/npm/esm/modules/renderer/widgets/product-view-count.d.ts +0 -6
- package/dist/npm/esm/modules/renderer/widgets/product-view-count.js +0 -194
- package/dist/npm/esm/modules/renderer/widgets/product-view-count.js.map +0 -1
- package/dist/npm/esm/modules/renderer/widgets/slide-in.d.ts +0 -5
- package/dist/npm/esm/modules/renderer/widgets/slide-in.js +0 -102
- package/dist/npm/esm/modules/renderer/widgets/slide-in.js.map +0 -1
- package/dist/npm/esm/modules/renderer/widgets/sticky-footer.d.ts +0 -5
- package/dist/npm/esm/modules/renderer/widgets/sticky-footer.js +0 -44
- package/dist/npm/esm/modules/renderer/widgets/sticky-footer.js.map +0 -1
- package/dist/npm/esm/modules/search/cart/index.d.ts +0 -26
- package/dist/npm/esm/modules/search/cart/index.js +0 -39
- package/dist/npm/esm/modules/search/cart/index.js.map +0 -1
- package/dist/npm/esm/modules/search/components/index.d.ts +0 -6
- package/dist/npm/esm/modules/search/components/index.js +0 -7
- package/dist/npm/esm/modules/search/components/index.js.map +0 -1
- package/dist/npm/esm/modules/search/components/search-box.d.ts +0 -11
- package/dist/npm/esm/modules/search/components/search-box.js +0 -25
- package/dist/npm/esm/modules/search/components/search-box.js.map +0 -1
- package/dist/npm/esm/modules/search/components/search-item.d.ts +0 -20
- package/dist/npm/esm/modules/search/components/search-item.js +0 -193
- package/dist/npm/esm/modules/search/components/search-item.js.map +0 -1
- package/dist/npm/esm/modules/search/components/suggestions.d.ts +0 -10
- package/dist/npm/esm/modules/search/components/suggestions.js +0 -129
- package/dist/npm/esm/modules/search/components/suggestions.js.map +0 -1
- package/dist/npm/esm/modules/search/index.d.ts +0 -67
- package/dist/npm/esm/modules/search/index.js +0 -642
- package/dist/npm/esm/modules/search/index.js.map +0 -1
- package/dist/npm/esm/modules/search/renderers/position-renderers.d.ts +0 -23
- package/dist/npm/esm/modules/search/renderers/position-renderers.js +0 -221
- package/dist/npm/esm/modules/search/renderers/position-renderers.js.map +0 -1
- package/dist/npm/esm/modules/search/renderers/results-renderer.d.ts +0 -20
- package/dist/npm/esm/modules/search/renderers/results-renderer.js +0 -176
- package/dist/npm/esm/modules/search/renderers/results-renderer.js.map +0 -1
- package/dist/npm/esm/modules/search/services/api-service.d.ts +0 -18
- package/dist/npm/esm/modules/search/services/api-service.js +0 -115
- package/dist/npm/esm/modules/search/services/api-service.js.map +0 -1
- package/dist/npm/esm/modules/search/services/tracking-service.d.ts +0 -16
- package/dist/npm/esm/modules/search/services/tracking-service.js +0 -250
- package/dist/npm/esm/modules/search/services/tracking-service.js.map +0 -1
- package/dist/npm/esm/modules/search/styles.d.ts +0 -13
- package/dist/npm/esm/modules/search/styles.js +0 -860
- package/dist/npm/esm/modules/search/styles.js.map +0 -1
- package/dist/npm/esm/modules/search/utils/helpers.d.ts +0 -24
- package/dist/npm/esm/modules/search/utils/helpers.js +0 -93
- package/dist/npm/esm/modules/search/utils/helpers.js.map +0 -1
- package/dist/npm/esm/modules/search/utils/icons.d.ts +0 -16
- package/dist/npm/esm/modules/search/utils/icons.js +0 -36
- package/dist/npm/esm/modules/search/utils/icons.js.map +0 -1
- package/dist/npm/esm/modules/search/utils/index.d.ts +0 -6
- package/dist/npm/esm/modules/search/utils/index.js +0 -7
- package/dist/npm/esm/modules/search/utils/index.js.map +0 -1
- package/dist/npm/esm/modules/search/utils/storage.d.ts +0 -7
- package/dist/npm/esm/modules/search/utils/storage.js +0 -52
- package/dist/npm/esm/modules/search/utils/storage.js.map +0 -1
- package/dist/npm/esm/package.json +0 -1
- package/dist/npm/esm/selwise.d.ts +0 -209
- package/dist/npm/esm/selwise.js +0 -1123
- package/dist/npm/esm/selwise.js.map +0 -1
- package/dist/npm/esm/sentry-test.d.ts +0 -45
- package/dist/npm/esm/sentry-test.js +0 -109
- package/dist/npm/esm/sentry-test.js.map +0 -1
- package/dist/npm/esm/sentry.d.ts +0 -86
- package/dist/npm/esm/sentry.js +0 -441
- package/dist/npm/esm/sentry.js.map +0 -1
- package/dist/npm/esm/shared/cart/handlers.d.ts +0 -46
- package/dist/npm/esm/shared/cart/handlers.js +0 -249
- package/dist/npm/esm/shared/cart/handlers.js.map +0 -1
- package/dist/npm/esm/shared/cart/index.d.ts +0 -6
- package/dist/npm/esm/shared/cart/index.js +0 -7
- package/dist/npm/esm/shared/cart/index.js.map +0 -1
- package/dist/npm/esm/shared/cart/types.d.ts +0 -30
- package/dist/npm/esm/shared/cart/types.js +0 -6
- package/dist/npm/esm/shared/cart/types.js.map +0 -1
- package/dist/npm/esm/shared/product-card/index.d.ts +0 -7
- package/dist/npm/esm/shared/product-card/index.js +0 -8
- package/dist/npm/esm/shared/product-card/index.js.map +0 -1
- package/dist/npm/esm/shared/product-card/renderer.d.ts +0 -35
- package/dist/npm/esm/shared/product-card/renderer.js +0 -334
- package/dist/npm/esm/shared/product-card/renderer.js.map +0 -1
- package/dist/npm/esm/shared/product-card/styles.d.ts +0 -17
- package/dist/npm/esm/shared/product-card/styles.js +0 -190
- package/dist/npm/esm/shared/product-card/styles.js.map +0 -1
- package/dist/npm/esm/shared/product-card/types.d.ts +0 -84
- package/dist/npm/esm/shared/product-card/types.js +0 -63
- package/dist/npm/esm/shared/product-card/types.js.map +0 -1
- package/dist/npm/esm/types/config.d.ts +0 -26
- package/dist/npm/esm/types/config.js +0 -5
- package/dist/npm/esm/types/config.js.map +0 -1
- package/dist/npm/esm/types/experiments.d.ts +0 -47
- package/dist/npm/esm/types/experiments.js +0 -14
- package/dist/npm/esm/types/experiments.js.map +0 -1
- package/dist/npm/esm/types/global-api.d.ts +0 -40
- package/dist/npm/esm/types/global-api.js +0 -2
- package/dist/npm/esm/types/global-api.js.map +0 -1
- package/dist/npm/esm/types/index.d.ts +0 -9
- package/dist/npm/esm/types/index.js +0 -11
- package/dist/npm/esm/types/index.js.map +0 -1
- package/dist/npm/esm/types/recommendation.d.ts +0 -186
- package/dist/npm/esm/types/recommendation.js +0 -5
- package/dist/npm/esm/types/recommendation.js.map +0 -1
- package/dist/npm/esm/types/renderer.d.ts +0 -99
- package/dist/npm/esm/types/renderer.js +0 -5
- package/dist/npm/esm/types/renderer.js.map +0 -1
- package/dist/npm/esm/types/search.d.ts +0 -186
- package/dist/npm/esm/types/search.js +0 -5
- package/dist/npm/esm/types/search.js.map +0 -1
- package/dist/npm/esm/utils/api-url.d.ts +0 -1
- package/dist/npm/esm/utils/api-url.js +0 -32
- package/dist/npm/esm/utils/api-url.js.map +0 -1
- package/dist/npm/esm/utils/debounce.d.ts +0 -27
- package/dist/npm/esm/utils/debounce.js +0 -70
- package/dist/npm/esm/utils/debounce.js.map +0 -1
- package/dist/npm/esm/utils/event-id.d.ts +0 -5
- package/dist/npm/esm/utils/event-id.js +0 -20
- package/dist/npm/esm/utils/event-id.js.map +0 -1
- package/dist/npm/esm/utils/index.d.ts +0 -11
- package/dist/npm/esm/utils/index.js +0 -12
- package/dist/npm/esm/utils/index.js.map +0 -1
- package/dist/npm/esm/utils/logger.d.ts +0 -31
- package/dist/npm/esm/utils/logger.js +0 -66
- package/dist/npm/esm/utils/logger.js.map +0 -1
- package/dist/npm/esm/utils/sanitize.d.ts +0 -38
- package/dist/npm/esm/utils/sanitize.js +0 -148
- package/dist/npm/esm/utils/sanitize.js.map +0 -1
- package/dist/npm/esm/utils/storage.d.ts +0 -72
- package/dist/npm/esm/utils/storage.js +0 -271
- package/dist/npm/esm/utils/storage.js.map +0 -1
- package/dist/npm/esm/utils/tracking-metadata.d.ts +0 -1
- package/dist/npm/esm/utils/tracking-metadata.js +0 -15
- package/dist/npm/esm/utils/tracking-metadata.js.map +0 -1
- package/dist/npm/esm/utils/url-matcher.d.ts +0 -4
- package/dist/npm/esm/utils/url-matcher.js +0 -8
- package/dist/npm/esm/utils/url-matcher.js.map +0 -1
|
@@ -1,8 +0,0 @@
|
|
|
1
|
-
export interface PageTargetingConfig {
|
|
2
|
-
showOnAllPages: boolean;
|
|
3
|
-
includeUrls: string[];
|
|
4
|
-
excludeUrls: string[];
|
|
5
|
-
}
|
|
6
|
-
export declare function normalizePageTargeting(input: unknown): PageTargetingConfig;
|
|
7
|
-
export declare function matchUrlPattern(url: string, pattern: string): boolean;
|
|
8
|
-
export declare function evaluatePageTargeting(targetingInput: unknown, currentUrl: string): boolean;
|
|
@@ -1,67 +0,0 @@
|
|
|
1
|
-
const DEFAULT_PAGE_TARGETING = {
|
|
2
|
-
showOnAllPages: true,
|
|
3
|
-
includeUrls: [],
|
|
4
|
-
excludeUrls: [],
|
|
5
|
-
};
|
|
6
|
-
function normalizePatternList(value) {
|
|
7
|
-
if (!Array.isArray(value))
|
|
8
|
-
return [];
|
|
9
|
-
const seen = new Set();
|
|
10
|
-
const normalized = [];
|
|
11
|
-
for (const raw of value) {
|
|
12
|
-
if (typeof raw !== 'string')
|
|
13
|
-
continue;
|
|
14
|
-
const pattern = raw.trim();
|
|
15
|
-
if (!pattern)
|
|
16
|
-
continue;
|
|
17
|
-
if (seen.has(pattern))
|
|
18
|
-
continue;
|
|
19
|
-
seen.add(pattern);
|
|
20
|
-
normalized.push(pattern);
|
|
21
|
-
}
|
|
22
|
-
return normalized;
|
|
23
|
-
}
|
|
24
|
-
export function normalizePageTargeting(input) {
|
|
25
|
-
if (!input || typeof input !== 'object' || Array.isArray(input)) {
|
|
26
|
-
return { ...DEFAULT_PAGE_TARGETING };
|
|
27
|
-
}
|
|
28
|
-
const payload = input;
|
|
29
|
-
return {
|
|
30
|
-
showOnAllPages: Boolean(payload.showOnAllPages ?? DEFAULT_PAGE_TARGETING.showOnAllPages),
|
|
31
|
-
includeUrls: normalizePatternList(payload.includeUrls),
|
|
32
|
-
excludeUrls: normalizePatternList(payload.excludeUrls),
|
|
33
|
-
};
|
|
34
|
-
}
|
|
35
|
-
export function matchUrlPattern(url, pattern) {
|
|
36
|
-
const normalizedUrl = String(url || '').toLowerCase();
|
|
37
|
-
const normalizedPattern = String(pattern || '').toLowerCase().trim();
|
|
38
|
-
if (!normalizedPattern)
|
|
39
|
-
return false;
|
|
40
|
-
if (normalizedPattern.includes('*')) {
|
|
41
|
-
const regexPattern = normalizedPattern
|
|
42
|
-
.replace(/[.+?^${}()|[\]\\]/g, '\\$&')
|
|
43
|
-
.replace(/\*/g, '.*');
|
|
44
|
-
return new RegExp(`^${regexPattern}$`).test(normalizedUrl);
|
|
45
|
-
}
|
|
46
|
-
return normalizedUrl === normalizedPattern || normalizedUrl.includes(normalizedPattern);
|
|
47
|
-
}
|
|
48
|
-
export function evaluatePageTargeting(targetingInput, currentUrl) {
|
|
49
|
-
const targeting = normalizePageTargeting(targetingInput);
|
|
50
|
-
const normalizedCurrentUrl = String(currentUrl || '');
|
|
51
|
-
if (targeting.excludeUrls.length > 0) {
|
|
52
|
-
const excluded = targeting.excludeUrls.some((pattern) => matchUrlPattern(normalizedCurrentUrl, pattern));
|
|
53
|
-
if (excluded)
|
|
54
|
-
return false;
|
|
55
|
-
}
|
|
56
|
-
if (targeting.showOnAllPages === false) {
|
|
57
|
-
if (targeting.includeUrls.length === 0)
|
|
58
|
-
return false;
|
|
59
|
-
if (!normalizedCurrentUrl)
|
|
60
|
-
return false;
|
|
61
|
-
const included = targeting.includeUrls.some((pattern) => matchUrlPattern(normalizedCurrentUrl, pattern));
|
|
62
|
-
if (!included)
|
|
63
|
-
return false;
|
|
64
|
-
}
|
|
65
|
-
return true;
|
|
66
|
-
}
|
|
67
|
-
//# sourceMappingURL=index.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../src/core/page-targeting/index.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,31 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Script Execution Module
|
|
3
|
-
* Handles JavaScript execution for custom cards, widgets, campaigns
|
|
4
|
-
*/
|
|
5
|
-
export interface ScriptConfig {
|
|
6
|
-
code: string;
|
|
7
|
-
timing: 'immediate' | 'domReady' | 'customEvent';
|
|
8
|
-
eventName?: string;
|
|
9
|
-
container?: HTMLElement;
|
|
10
|
-
context?: Record<string, any>;
|
|
11
|
-
force?: boolean;
|
|
12
|
-
}
|
|
13
|
-
export declare class ScriptExecutor {
|
|
14
|
-
private pendingScripts;
|
|
15
|
-
/**
|
|
16
|
-
* Execute script based on timing configuration
|
|
17
|
-
*/
|
|
18
|
-
execute(config: ScriptConfig): void;
|
|
19
|
-
/**
|
|
20
|
-
* Execute script immediately with proper scoping
|
|
21
|
-
*/
|
|
22
|
-
private executeNow;
|
|
23
|
-
/**
|
|
24
|
-
* Trigger a custom event for pending scripts
|
|
25
|
-
*/
|
|
26
|
-
triggerCustomEvent(eventName: string): void;
|
|
27
|
-
/**
|
|
28
|
-
* Clean up pending scripts and executed scripts
|
|
29
|
-
*/
|
|
30
|
-
destroy(): void;
|
|
31
|
-
}
|
|
@@ -1,76 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Script Execution Module
|
|
3
|
-
* Handles JavaScript execution for custom cards, widgets, campaigns
|
|
4
|
-
*/
|
|
5
|
-
import { testModeError } from '../utils/logger.js';
|
|
6
|
-
export class ScriptExecutor {
|
|
7
|
-
constructor() {
|
|
8
|
-
this.pendingScripts = new Map();
|
|
9
|
-
}
|
|
10
|
-
/**
|
|
11
|
-
* Execute script based on timing configuration
|
|
12
|
-
*/
|
|
13
|
-
execute(config) {
|
|
14
|
-
if (!config.code?.trim())
|
|
15
|
-
return;
|
|
16
|
-
switch (config.timing) {
|
|
17
|
-
case 'immediate':
|
|
18
|
-
this.executeNow(config);
|
|
19
|
-
break;
|
|
20
|
-
case 'domReady':
|
|
21
|
-
if (document.readyState === 'loading') {
|
|
22
|
-
document.addEventListener('DOMContentLoaded', () => this.executeNow(config));
|
|
23
|
-
}
|
|
24
|
-
else {
|
|
25
|
-
this.executeNow(config);
|
|
26
|
-
}
|
|
27
|
-
break;
|
|
28
|
-
case 'customEvent':
|
|
29
|
-
if (config.eventName) {
|
|
30
|
-
this.pendingScripts.set(config.eventName, config);
|
|
31
|
-
document.addEventListener(config.eventName, () => {
|
|
32
|
-
this.executeNow(config);
|
|
33
|
-
}, { once: true });
|
|
34
|
-
}
|
|
35
|
-
break;
|
|
36
|
-
}
|
|
37
|
-
}
|
|
38
|
-
/**
|
|
39
|
-
* Execute script immediately with proper scoping
|
|
40
|
-
*/
|
|
41
|
-
executeNow(config) {
|
|
42
|
-
try {
|
|
43
|
-
const script = document.createElement('script');
|
|
44
|
-
script.setAttribute('data-selwise-custom-js', 'true');
|
|
45
|
-
// Wrap in IIFE with context available
|
|
46
|
-
const contextStr = config.context
|
|
47
|
-
? `const context = ${JSON.stringify(config.context)};`
|
|
48
|
-
: '';
|
|
49
|
-
script.textContent = `(function() { ${contextStr} ${config.code} }).call(window);`;
|
|
50
|
-
if (config.container) {
|
|
51
|
-
config.container.appendChild(script);
|
|
52
|
-
}
|
|
53
|
-
else {
|
|
54
|
-
document.body.appendChild(script);
|
|
55
|
-
}
|
|
56
|
-
}
|
|
57
|
-
catch (error) {
|
|
58
|
-
testModeError('Selwise', 'Script execution error:', error);
|
|
59
|
-
}
|
|
60
|
-
}
|
|
61
|
-
/**
|
|
62
|
-
* Trigger a custom event for pending scripts
|
|
63
|
-
*/
|
|
64
|
-
triggerCustomEvent(eventName) {
|
|
65
|
-
const event = new CustomEvent(eventName);
|
|
66
|
-
document.dispatchEvent(event);
|
|
67
|
-
}
|
|
68
|
-
/**
|
|
69
|
-
* Clean up pending scripts and executed scripts
|
|
70
|
-
*/
|
|
71
|
-
destroy() {
|
|
72
|
-
this.pendingScripts.clear();
|
|
73
|
-
document.querySelectorAll('script[data-selwise-custom-js]').forEach(el => el.remove());
|
|
74
|
-
}
|
|
75
|
-
}
|
|
76
|
-
//# sourceMappingURL=script-executor.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"script-executor.js","sourceRoot":"","sources":["../../../../src/core/script-executor.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,OAAO,EAAE,aAAa,EAAE,MAAM,iBAAiB,CAAC;AAYhD,MAAM,OAAO,cAAc;IAA3B;QACU,mBAAc,GAAG,IAAI,GAAG,EAAwB,CAAC;IAsE3D,CAAC;IApEC;;OAEG;IACH,OAAO,CAAC,MAAoB;QAC1B,IAAI,CAAC,MAAM,CAAC,IAAI,EAAE,IAAI,EAAE;YAAE,OAAO;QAEjC,QAAQ,MAAM,CAAC,MAAM,EAAE,CAAC;YACtB,KAAK,WAAW;gBACd,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC;gBACxB,MAAM;YACR,KAAK,UAAU;gBACb,IAAI,QAAQ,CAAC,UAAU,KAAK,SAAS,EAAE,CAAC;oBACtC,QAAQ,CAAC,gBAAgB,CAAC,kBAAkB,EAAE,GAAG,EAAE,CAAC,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC,CAAC;gBAC/E,CAAC;qBAAM,CAAC;oBACN,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC;gBAC1B,CAAC;gBACD,MAAM;YACR,KAAK,aAAa;gBAChB,IAAI,MAAM,CAAC,SAAS,EAAE,CAAC;oBACrB,IAAI,CAAC,cAAc,CAAC,GAAG,CAAC,MAAM,CAAC,SAAS,EAAE,MAAM,CAAC,CAAC;oBAClD,QAAQ,CAAC,gBAAgB,CAAC,MAAM,CAAC,SAAS,EAAE,GAAG,EAAE;wBAC/C,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC;oBAC1B,CAAC,EAAE,EAAE,IAAI,EAAE,IAAI,EAAE,CAAC,CAAC;gBACrB,CAAC;gBACD,MAAM;QACV,CAAC;IACH,CAAC;IAED;;OAEG;IACK,UAAU,CAAC,MAAoB;QACrC,IAAI,CAAC;YACH,MAAM,MAAM,GAAG,QAAQ,CAAC,aAAa,CAAC,QAAQ,CAAC,CAAC;YAChD,MAAM,CAAC,YAAY,CAAC,wBAAwB,EAAE,MAAM,CAAC,CAAC;YAEtD,sCAAsC;YACtC,MAAM,UAAU,GAAG,MAAM,CAAC,OAAO;gBAC/B,CAAC,CAAC,mBAAmB,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,OAAO,CAAC,GAAG;gBACtD,CAAC,CAAC,EAAE,CAAC;YAEP,MAAM,CAAC,WAAW,GAAG,iBAAiB,UAAU,IAAI,MAAM,CAAC,IAAI,mBAAmB,CAAC;YAEnF,IAAI,MAAM,CAAC,SAAS,EAAE,CAAC;gBACrB,MAAM,CAAC,SAAS,CAAC,WAAW,CAAC,MAAM,CAAC,CAAC;YACvC,CAAC;iBAAM,CAAC;gBACN,QAAQ,CAAC,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,CAAC;YACpC,CAAC;QACH,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,aAAa,CAAC,SAAS,EAAE,yBAAyB,EAAE,KAAK,CAAC,CAAC;QAC7D,CAAC;IACH,CAAC;IAED;;OAEG;IACH,kBAAkB,CAAC,SAAiB;QAClC,MAAM,KAAK,GAAG,IAAI,WAAW,CAAC,SAAS,CAAC,CAAC;QACzC,QAAQ,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;IAChC,CAAC;IAED;;OAEG;IACH,OAAO;QACL,IAAI,CAAC,cAAc,CAAC,KAAK,EAAE,CAAC;QAC5B,QAAQ,CAAC,gBAAgB,CAAC,gCAAgC,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,MAAM,EAAE,CAAC,CAAC;IACzF,CAAC;CACF"}
|
|
@@ -1,39 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Segment Evaluation for Client-Side Targeting
|
|
3
|
-
*/
|
|
4
|
-
export declare class SegmentManager {
|
|
5
|
-
private apiUrl;
|
|
6
|
-
private siteKey;
|
|
7
|
-
private segmentCache;
|
|
8
|
-
private segmentCacheTimestamps;
|
|
9
|
-
private visitorId;
|
|
10
|
-
private sessionId;
|
|
11
|
-
private siteUserId?;
|
|
12
|
-
private siteUserProfileId?;
|
|
13
|
-
constructor(apiUrl: string, siteKey: string, visitorId: string, sessionId: string, siteUserId?: string, siteUserProfileId?: string);
|
|
14
|
-
/**
|
|
15
|
-
* Update user identifiers (called after identify)
|
|
16
|
-
*/
|
|
17
|
-
updateUserIdentifiers(siteUserId?: string, siteUserProfileId?: string): void;
|
|
18
|
-
/**
|
|
19
|
-
* Evaluate if user matches segment targeting
|
|
20
|
-
*/
|
|
21
|
-
shouldShow(segmentTargetingMode: string, segmentIds: string[] | any): Promise<boolean>;
|
|
22
|
-
/**
|
|
23
|
-
* Evaluate multiple segments at once
|
|
24
|
-
*/
|
|
25
|
-
private evaluateSegments;
|
|
26
|
-
/**
|
|
27
|
-
* Get device type
|
|
28
|
-
*/
|
|
29
|
-
private getDeviceType;
|
|
30
|
-
/**
|
|
31
|
-
* Fallback results when API fails (show to everyone to avoid breaking site)
|
|
32
|
-
*/
|
|
33
|
-
private getFallbackResults;
|
|
34
|
-
private normalizeSegmentIds;
|
|
35
|
-
/**
|
|
36
|
-
* Clear segment cache
|
|
37
|
-
*/
|
|
38
|
-
clearCache(): void;
|
|
39
|
-
}
|
|
@@ -1,168 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Segment Evaluation for Client-Side Targeting
|
|
3
|
-
*/
|
|
4
|
-
import { testModeLog, testModeError } from '../utils/logger.js';
|
|
5
|
-
// Cache TTL: 5 minutes
|
|
6
|
-
const CACHE_TTL = 5 * 60 * 1000;
|
|
7
|
-
export class SegmentManager {
|
|
8
|
-
constructor(apiUrl, siteKey, visitorId, sessionId, siteUserId, siteUserProfileId) {
|
|
9
|
-
this.segmentCache = new Map();
|
|
10
|
-
this.segmentCacheTimestamps = new Map();
|
|
11
|
-
this.apiUrl = apiUrl;
|
|
12
|
-
this.siteKey = siteKey;
|
|
13
|
-
this.visitorId = visitorId;
|
|
14
|
-
this.sessionId = sessionId;
|
|
15
|
-
this.siteUserId = siteUserId;
|
|
16
|
-
this.siteUserProfileId = siteUserProfileId;
|
|
17
|
-
}
|
|
18
|
-
/**
|
|
19
|
-
* Update user identifiers (called after identify)
|
|
20
|
-
*/
|
|
21
|
-
updateUserIdentifiers(siteUserId, siteUserProfileId) {
|
|
22
|
-
this.siteUserId = siteUserId;
|
|
23
|
-
this.siteUserProfileId = siteUserProfileId;
|
|
24
|
-
}
|
|
25
|
-
/**
|
|
26
|
-
* Evaluate if user matches segment targeting
|
|
27
|
-
*/
|
|
28
|
-
async shouldShow(segmentTargetingMode, segmentIds) {
|
|
29
|
-
// Convert JSON field to array if needed
|
|
30
|
-
const ids = this.normalizeSegmentIds(segmentIds);
|
|
31
|
-
testModeLog('SegmentManager', 'Evaluating segment targeting:', {
|
|
32
|
-
mode: segmentTargetingMode,
|
|
33
|
-
segmentIds: ids,
|
|
34
|
-
visitorId: this.visitorId,
|
|
35
|
-
sessionId: this.sessionId
|
|
36
|
-
});
|
|
37
|
-
// If mode is 'all', show to everyone
|
|
38
|
-
if (segmentTargetingMode === 'all' || ids.length === 0) {
|
|
39
|
-
testModeLog('SegmentManager', 'Mode is "all" or no segments, showing content');
|
|
40
|
-
return true;
|
|
41
|
-
}
|
|
42
|
-
// Evaluate all segments
|
|
43
|
-
const results = await this.evaluateSegments(ids);
|
|
44
|
-
// Check if user matches any segment
|
|
45
|
-
const matchedSegmentIds = Object.keys(results).filter(id => results[id]);
|
|
46
|
-
testModeLog('SegmentManager', 'Evaluation results:', {
|
|
47
|
-
results,
|
|
48
|
-
matchedSegments: matchedSegmentIds,
|
|
49
|
-
mode: segmentTargetingMode
|
|
50
|
-
});
|
|
51
|
-
if (segmentTargetingMode === 'include') {
|
|
52
|
-
// User must be in at least one segment
|
|
53
|
-
const shouldShow = matchedSegmentIds.length > 0;
|
|
54
|
-
testModeLog('SegmentManager', `Include mode: ${shouldShow ? 'SHOW' : 'HIDE'}`);
|
|
55
|
-
return shouldShow;
|
|
56
|
-
}
|
|
57
|
-
if (segmentTargetingMode === 'exclude') {
|
|
58
|
-
// User must NOT be in any segment
|
|
59
|
-
const shouldShow = matchedSegmentIds.length === 0;
|
|
60
|
-
testModeLog('SegmentManager', `Exclude mode: ${shouldShow ? 'SHOW' : 'HIDE'}`);
|
|
61
|
-
return shouldShow;
|
|
62
|
-
}
|
|
63
|
-
return true;
|
|
64
|
-
}
|
|
65
|
-
/**
|
|
66
|
-
* Evaluate multiple segments at once
|
|
67
|
-
*/
|
|
68
|
-
async evaluateSegments(segmentIds) {
|
|
69
|
-
// Check cache first with TTL validation
|
|
70
|
-
const now = Date.now();
|
|
71
|
-
const uncachedIds = segmentIds.filter(id => {
|
|
72
|
-
if (!this.segmentCache.has(id))
|
|
73
|
-
return true;
|
|
74
|
-
const cachedTime = this.segmentCacheTimestamps.get(id);
|
|
75
|
-
if (!cachedTime)
|
|
76
|
-
return true;
|
|
77
|
-
// Cache entry is expired
|
|
78
|
-
return (now - cachedTime) > CACHE_TTL;
|
|
79
|
-
});
|
|
80
|
-
// If all segments are cached and valid, return cached results
|
|
81
|
-
if (uncachedIds.length === 0) {
|
|
82
|
-
const results = {};
|
|
83
|
-
segmentIds.forEach(id => {
|
|
84
|
-
results[id] = this.segmentCache.get(id) || false;
|
|
85
|
-
});
|
|
86
|
-
return results;
|
|
87
|
-
}
|
|
88
|
-
// Fetch segment evaluation from API
|
|
89
|
-
try {
|
|
90
|
-
const requestPayload = {
|
|
91
|
-
segmentIds: this.normalizeSegmentIds(segmentIds),
|
|
92
|
-
visitorId: this.visitorId,
|
|
93
|
-
siteUserId: this.siteUserId,
|
|
94
|
-
siteUserProfileId: this.siteUserProfileId,
|
|
95
|
-
sessionId: this.sessionId,
|
|
96
|
-
deviceType: this.getDeviceType(),
|
|
97
|
-
referrer: document.referrer,
|
|
98
|
-
pageUrl: window.location.href,
|
|
99
|
-
};
|
|
100
|
-
testModeLog('SegmentManager', 'Calling API to evaluate segments:', {
|
|
101
|
-
endpoint: `${this.apiUrl}/public/segments/evaluate?siteKey=${this.siteKey}`,
|
|
102
|
-
payload: requestPayload
|
|
103
|
-
});
|
|
104
|
-
const response = await fetch(`${this.apiUrl}/public/segments/evaluate?siteKey=${this.siteKey}`, {
|
|
105
|
-
method: 'POST',
|
|
106
|
-
headers: { 'Content-Type': 'application/json' },
|
|
107
|
-
body: JSON.stringify(requestPayload),
|
|
108
|
-
});
|
|
109
|
-
if (!response.ok) {
|
|
110
|
-
testModeError('SegmentManager', 'API returned error:', response.status, response.statusText);
|
|
111
|
-
return this.getFallbackResults(segmentIds);
|
|
112
|
-
}
|
|
113
|
-
const data = await response.json();
|
|
114
|
-
testModeLog('SegmentManager', 'API response:', data);
|
|
115
|
-
// Cache results with timestamps
|
|
116
|
-
const cacheTime = Date.now();
|
|
117
|
-
Object.keys(data.results).forEach(id => {
|
|
118
|
-
this.segmentCache.set(id, data.results[id]);
|
|
119
|
-
this.segmentCacheTimestamps.set(id, cacheTime);
|
|
120
|
-
});
|
|
121
|
-
return data.results;
|
|
122
|
-
}
|
|
123
|
-
catch (error) {
|
|
124
|
-
testModeError('SegmentManager', 'Error evaluating segments:', error);
|
|
125
|
-
return this.getFallbackResults(segmentIds);
|
|
126
|
-
}
|
|
127
|
-
}
|
|
128
|
-
/**
|
|
129
|
-
* Get device type
|
|
130
|
-
*/
|
|
131
|
-
getDeviceType() {
|
|
132
|
-
const ua = navigator.userAgent;
|
|
133
|
-
if (/(tablet|ipad|playbook|silk)|(android(?!.*mobi))/i.test(ua)) {
|
|
134
|
-
return 'tablet';
|
|
135
|
-
}
|
|
136
|
-
if (/Mobile|Android|iP(hone|od)|IEMobile|BlackBerry|Kindle|Silk-Accelerated|(hpw|web)OS|Opera M(obi|ini)/.test(ua)) {
|
|
137
|
-
return 'mobile';
|
|
138
|
-
}
|
|
139
|
-
return 'desktop';
|
|
140
|
-
}
|
|
141
|
-
/**
|
|
142
|
-
* Fallback results when API fails (show to everyone to avoid breaking site)
|
|
143
|
-
*/
|
|
144
|
-
getFallbackResults(segmentIds) {
|
|
145
|
-
const results = {};
|
|
146
|
-
segmentIds.forEach(id => {
|
|
147
|
-
results[id] = false;
|
|
148
|
-
});
|
|
149
|
-
return results;
|
|
150
|
-
}
|
|
151
|
-
normalizeSegmentIds(segmentIds) {
|
|
152
|
-
if (!Array.isArray(segmentIds)) {
|
|
153
|
-
return [];
|
|
154
|
-
}
|
|
155
|
-
return Array.from(new Set(segmentIds
|
|
156
|
-
.filter((segmentId) => typeof segmentId === 'string')
|
|
157
|
-
.map((segmentId) => segmentId.trim())
|
|
158
|
-
.filter((segmentId) => segmentId.length > 0))).sort();
|
|
159
|
-
}
|
|
160
|
-
/**
|
|
161
|
-
* Clear segment cache
|
|
162
|
-
*/
|
|
163
|
-
clearCache() {
|
|
164
|
-
this.segmentCache.clear();
|
|
165
|
-
this.segmentCacheTimestamps.clear();
|
|
166
|
-
}
|
|
167
|
-
}
|
|
168
|
-
//# sourceMappingURL=segments.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"segments.js","sourceRoot":"","sources":["../../../../src/core/segments.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,182 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Event Tracker
|
|
3
|
-
* Comprehensive tracking for impressions, clicks, views, and conversions
|
|
4
|
-
*
|
|
5
|
-
* Now with optional EventBatcher for advanced batching capabilities:
|
|
6
|
-
* - Configurable batch size (default: 50 events)
|
|
7
|
-
* - Configurable flush interval (default: 30 seconds)
|
|
8
|
-
* - Page hide/send beacon support
|
|
9
|
-
* - Offline persistence (localStorage)
|
|
10
|
-
* - Event deduplication
|
|
11
|
-
* - Retry logic with exponential backoff
|
|
12
|
-
*/
|
|
13
|
-
import { type EventBatcherConfig } from './event-batcher';
|
|
14
|
-
interface OrderData {
|
|
15
|
-
orderId?: string;
|
|
16
|
-
currency?: string;
|
|
17
|
-
total: number;
|
|
18
|
-
subtotal?: number;
|
|
19
|
-
discountTotal?: number;
|
|
20
|
-
shippingTotal?: number;
|
|
21
|
-
taxTotal?: number;
|
|
22
|
-
status?: string;
|
|
23
|
-
placedAt?: string;
|
|
24
|
-
visitorId?: string;
|
|
25
|
-
siteUserId?: string;
|
|
26
|
-
items?: Array<{
|
|
27
|
-
productItemCode?: string;
|
|
28
|
-
name?: string;
|
|
29
|
-
quantity?: number;
|
|
30
|
-
unitPrice?: number;
|
|
31
|
-
totalPrice?: number;
|
|
32
|
-
metadata?: Record<string, any>;
|
|
33
|
-
}>;
|
|
34
|
-
metadata?: Record<string, any>;
|
|
35
|
-
}
|
|
36
|
-
export declare class Tracker {
|
|
37
|
-
private apiUrl;
|
|
38
|
-
private siteKey;
|
|
39
|
-
private sessionId;
|
|
40
|
-
private visitorId;
|
|
41
|
-
private siteUserId?;
|
|
42
|
-
private queue;
|
|
43
|
-
private flushTimeout;
|
|
44
|
-
private viewObservers;
|
|
45
|
-
private viewedElements;
|
|
46
|
-
private hoverStartTimes;
|
|
47
|
-
private batcher?;
|
|
48
|
-
private useAdvancedBatching;
|
|
49
|
-
private spaCleanupSetup;
|
|
50
|
-
constructor(apiUrl?: string, siteKey?: string, batchingConfig?: EventBatcherConfig & {
|
|
51
|
-
enabled?: boolean;
|
|
52
|
-
});
|
|
53
|
-
/**
|
|
54
|
-
* Enable SPA cleanup (call this if your app uses client-side routing)
|
|
55
|
-
* This should be called once during initialization
|
|
56
|
-
*/
|
|
57
|
-
enableSPACleanup(): void;
|
|
58
|
-
setSiteKey(siteKey: string): void;
|
|
59
|
-
/**
|
|
60
|
-
* Configure or enable advanced batching
|
|
61
|
-
* Can be called to update configuration dynamically after fetching from server
|
|
62
|
-
*/
|
|
63
|
-
setBatcherConfig(config: EventBatcherConfig & {
|
|
64
|
-
enabled?: boolean;
|
|
65
|
-
}): void;
|
|
66
|
-
setSiteUserId(siteUserId?: string): void;
|
|
67
|
-
getSessionId(): string;
|
|
68
|
-
getVisitorId(): string;
|
|
69
|
-
getSiteUserId(): string | undefined;
|
|
70
|
-
/**
|
|
71
|
-
* Get the current journey ID
|
|
72
|
-
* Returns the active journey ID or null if no journey is active
|
|
73
|
-
*/
|
|
74
|
-
getJourneyId(): string | null;
|
|
75
|
-
/**
|
|
76
|
-
* End the current journey
|
|
77
|
-
* Clears the journey ID and starts a new one on next event
|
|
78
|
-
*/
|
|
79
|
-
endJourney(): void;
|
|
80
|
-
/**
|
|
81
|
-
* Get the journey state for debugging
|
|
82
|
-
*/
|
|
83
|
-
getJourneyState(): {
|
|
84
|
-
journeyId: string | null;
|
|
85
|
-
age: number | null;
|
|
86
|
-
isValid: boolean;
|
|
87
|
-
};
|
|
88
|
-
/**
|
|
89
|
-
* Get the internal SiteUser profile ID (UUID) for segment evaluation
|
|
90
|
-
* This is set after identify() and persists for merged behavior lookup
|
|
91
|
-
*/
|
|
92
|
-
getSiteUserProfileId(): string | undefined;
|
|
93
|
-
/**
|
|
94
|
-
* Identify a user and merge anonymous visitor data
|
|
95
|
-
* Calls the backend API to perform identity merge
|
|
96
|
-
*/
|
|
97
|
-
identify(userId: string, metadata?: Record<string, any>): Promise<{
|
|
98
|
-
success: boolean;
|
|
99
|
-
merged?: boolean;
|
|
100
|
-
}>;
|
|
101
|
-
/**
|
|
102
|
-
* Set user traits without changing identity
|
|
103
|
-
* Calls the backend API to update user attributes
|
|
104
|
-
*/
|
|
105
|
-
setTraits(traits: Record<string, any>): Promise<boolean>;
|
|
106
|
-
/**
|
|
107
|
-
* Track merged visitor IDs for cross-device reference
|
|
108
|
-
*/
|
|
109
|
-
private updateMergedVisitorIds;
|
|
110
|
-
/**
|
|
111
|
-
* Get all merged visitor IDs for this user
|
|
112
|
-
*/
|
|
113
|
-
getMergedVisitorIds(): string[];
|
|
114
|
-
track(name: string, args?: {
|
|
115
|
-
entityType?: string;
|
|
116
|
-
entityId?: string;
|
|
117
|
-
metadata?: Record<string, any>;
|
|
118
|
-
}): void;
|
|
119
|
-
trackView(element: HTMLElement, entityType: string, entityId: string, metadata?: Record<string, any>): void;
|
|
120
|
-
trackProductImpression(element: HTMLElement, widgetId: string, productItemCode: string, position: number): void;
|
|
121
|
-
trackHoverStart(entityType: string, entityId: string): void;
|
|
122
|
-
trackHoverEnd(entityType: string, entityId: string, metadata?: Record<string, any>): void;
|
|
123
|
-
trackScroll(entityType: string, entityId: string, scrollPercent: number): void;
|
|
124
|
-
trackSliderNavigate(widgetId: string, direction: 'prev' | 'next', fromSlide: number, toSlide: number): void;
|
|
125
|
-
trackSliderSwipe(widgetId: string, direction: 'left' | 'right'): void;
|
|
126
|
-
trackSearchOpen(trigger?: 'click' | 'hotkey' | 'auto'): void;
|
|
127
|
-
trackSearchClose(query: string, resultCount: number, dwellTime: number): void;
|
|
128
|
-
trackCategoryFilter(categoryName: string, resultCount: number): void;
|
|
129
|
-
trackRecentSearchClick(query: string): void;
|
|
130
|
-
trackPopularSearchClick(query: string): void;
|
|
131
|
-
trackPopularCategoryClick(categoryName: string): void;
|
|
132
|
-
trackPopularProductClick(productItemCode: string): void;
|
|
133
|
-
trackZeroResults(query: string): void;
|
|
134
|
-
trackOrder(order: OrderData): Promise<void>;
|
|
135
|
-
private scheduleFlush;
|
|
136
|
-
flush(): Promise<void>;
|
|
137
|
-
cleanup(): void;
|
|
138
|
-
/**
|
|
139
|
-
* Setup SPA navigation cleanup listener
|
|
140
|
-
* Automatically cleans up observers when page navigation is detected
|
|
141
|
-
* This prevents memory leaks in single-page applications
|
|
142
|
-
*/
|
|
143
|
-
setupSPACleanup(): void;
|
|
144
|
-
/**
|
|
145
|
-
* Schedule deferred cleanup with a small delay
|
|
146
|
-
* This allows the new page to settle before cleaning up
|
|
147
|
-
*/
|
|
148
|
-
private scheduleDeferredCleanup;
|
|
149
|
-
/**
|
|
150
|
-
* Manually flush pending events (useful for testing or before page unload)
|
|
151
|
-
*/
|
|
152
|
-
flushBatcher(): Promise<void>;
|
|
153
|
-
/**
|
|
154
|
-
* Get batcher stats (useful for debugging)
|
|
155
|
-
*/
|
|
156
|
-
getBatcherStats(): {
|
|
157
|
-
queueSize: number;
|
|
158
|
-
consentQueueSize: number;
|
|
159
|
-
processedCount: number;
|
|
160
|
-
enabled: boolean;
|
|
161
|
-
};
|
|
162
|
-
/**
|
|
163
|
-
* Initialize the batcher (must be called after construction)
|
|
164
|
-
* This loads overflow events from IndexedDB and flushes them immediately
|
|
165
|
-
*/
|
|
166
|
-
initialize(): Promise<void>;
|
|
167
|
-
/**
|
|
168
|
-
* Check if the batcher has been initialized
|
|
169
|
-
*/
|
|
170
|
-
isReady(): boolean;
|
|
171
|
-
/**
|
|
172
|
-
* Flush consent queue - called when user grants consent
|
|
173
|
-
* Re-evaluates all queued events and sends those that now have consent
|
|
174
|
-
*/
|
|
175
|
-
flushConsentQueue(): void;
|
|
176
|
-
/**
|
|
177
|
-
* Set up the global consent queue flush callback
|
|
178
|
-
* This allows the cookie consent widget to trigger queue flush when consent is granted
|
|
179
|
-
*/
|
|
180
|
-
setupConsentCallback(): void;
|
|
181
|
-
}
|
|
182
|
-
export {};
|