Migration guide: from @elbwalker to @walkerOS
This guide helps you migrate from the old elbwalker packages to the new walkerOS packages.
Quick reference
Core package changes
@elbwalker/walker.js→@walkeros/collector+@walkeros/web-source-browser@elbwalker/types+@elbwalker/utils→@walkeros/core@elbwalker/destination-web-*→@walkeros/web-destination-*@elbwalker/destination-node-*→@walkeros/server-destination-*
Step-by-step migration
1. Update dependencies
Before:
After:
2. Update imports
Before:
After:
3. Update function calls
Before:
After:
Breaking changes
1. Unified collector
- Single
@walkeros/collectorpackage works across all platforms - Use
startFlow()instead ofWalkerjs()orcreateSourceNode()
2. Modular sources
- DOM tracking is now
@walkeros/web-source-browser - Import and initialize sources separately
3. Core package merger
- All types and utilities now come from
@walkeros/core - Update all import statements accordingly
4. Google destinations unified
- GA4, Google Ads, and GTM are now unified in
@walkeros/web-destination-gtag - Configure all Google services through a single destination
Destination configuration patterns
Unified configuration approach
Configure all sources and destinations in a single startFlow call:
Benefits:
- Single configuration describing entire tracking setup
- Full type safety with proper config linking
- No manual destination registration needed
- Clean separation between code and configuration
Migration checklist
Package dependencies
- [ ] Remove old
@elbwalker/*packages - [ ] Add
@walkeros/collector - [ ] Add required sources and destinations
- [ ] Add
@walkeros/corefor custom implementations
Code updates
- [ ] Update all imports to new packages
- [ ] Replace collector initialization with
startFlow() - [ ] Update type imports to use
@walkeros/core - [ ] Test functionality after migration
Common issues
"Cannot find module @walkeros/web-collector"
Solution: Use @walkeros/collector + @walkeros/web-source-browser
"elb is not defined"
Solution: elb is returned by startFlow() function
TypeScript cannot find types
Solution: Import types from @walkeros/core
data-elbaction vs data-elbactions
Breaking change in @walkeros packages
The behavior of data-elbaction has changed to improve performance and provide
more precise entity targeting:
- @elbwalker behavior:
data-elbactionapplied to all entities in the DOM hierarchy - @walkeros behavior:
data-elbactionapplies to nearest entity only
Migration strategy
Option 1: keep current behavior (recommended for migration)
Replace data-elbaction with data-elbactions to maintain the same behavior:
Option 2: use new behavior (recommended for new projects)
Use data-elbaction for more precise, performance-optimized tracking:
When to use each
Use data-elbaction (nearest entity) when:
- You want precise tracking of only the specific entity
- Performance is critical (fewer events)
- Implementing new features
Use data-elbactions (all entities) when:
- Migrating from @elbwalker and need same behavior
- You need context from parent entities
- Analytics requires full DOM hierarchy
Tagger API
The tagger also provides both methods:
visible vs impression triggers
Breaking change in @walkeros packages
The visibility trigger names have been updated to better reflect their behavior:
visibletrigger: Now fires multiple times when element re-enters viewport (wasvisibles)impressiontrigger: Fires once only when element first becomes visible (wasvisible)
Migration strategy
Option 1: update trigger names (recommended)
Update your HTML to use the new trigger names:
Option 2: understand the behavior change
If you keep using the old names, understand the behavior has changed:
- Old
visiblebehavior (single-fire) → Now useimpression - Old
visiblesbehavior (multiple-fire) → Now usevisible
When to use each
Use impression trigger when:
- You want to track when content is first seen
- Measuring ad impressions or content views
- One-time engagement metrics
Use visible trigger when:
- You want to track repeated interactions
- Measuring scroll behavior or re-engagement
- Analytics requires multiple visibility events
Tagger API
The tagger supports both trigger types: