diff --git a/frontend/src/lib/utils/semver.test.ts b/frontend/src/lib/utils/semver.test.ts index 31bcc58cdf5c9e..67ee07860fc7f8 100644 --- a/frontend/src/lib/utils/semver.test.ts +++ b/frontend/src/lib/utils/semver.test.ts @@ -1,4 +1,4 @@ -import { highestVersion, lowestVersion, parseVersion, versionToString } from './semver' +import { createVersionChecker, highestVersion, lowestVersion, parseVersion, versionToString } from './semver' describe('semver', () => { describe('parseVersion', () => { @@ -52,4 +52,14 @@ describe('semver', () => { expect(versionToString({ major: 1 })).toEqual('1') }) }) + describe('createVersionChecker', () => { + it('should create a version checker that checks that a version is above or equal to a specified version', () => { + const isSupportedVersion = createVersionChecker('4.5.6') + expect(isSupportedVersion('1.2.3')).toEqual(false) + expect(isSupportedVersion('4.5.6')).toEqual(true) + expect(isSupportedVersion('4.5.7')).toEqual(true) + expect(isSupportedVersion('7.8.9')).toEqual(true) + expect(isSupportedVersion('4.5.6-alpha')).toEqual(false) + }) + }) }) diff --git a/frontend/src/lib/utils/semver.ts b/frontend/src/lib/utils/semver.ts index 5a8f4606d7247f..79cf377c515841 100644 --- a/frontend/src/lib/utils/semver.ts +++ b/frontend/src/lib/utils/semver.ts @@ -106,3 +106,10 @@ export function versionToString(version: SemanticVersion): string { } return versionPart } + +export function createVersionChecker(requiredVersion: string | SemanticVersion) { + return (version: string | SemanticVersion): boolean => { + const diff = diffVersions(version, requiredVersion) + return !diff || diff.diff > 0 + } +} diff --git a/frontend/src/toolbar/elements/heatmapLogic.ts b/frontend/src/toolbar/elements/heatmapLogic.ts index 948b51b9439be9..57d854924fafaa 100644 --- a/frontend/src/toolbar/elements/heatmapLogic.ts +++ b/frontend/src/toolbar/elements/heatmapLogic.ts @@ -16,6 +16,7 @@ import { } from 'lib/components/heatmaps/types' import { calculateViewportRange, DEFAULT_HEATMAP_FILTERS } from 'lib/components/heatmaps/utils' import { dateFilterToText } from 'lib/utils' +import { createVersionChecker } from 'lib/utils/semver' import { PostHog } from 'posthog-js' import { collectAllElementsDeep, querySelectorAllDeep } from 'query-selector-shadow-dom' @@ -28,7 +29,7 @@ import { FilterType, PropertyFilterType, PropertyOperator } from '~/types' import type { heatmapLogicType } from './heatmapLogicType' -export const SCROLL_DEPTH_JS_VERSION = [1, 99] +export const doesSupportScrollDepth = createVersionChecker('1.99') const emptyElementsStatsPages: PaginatedResponse = { next: undefined, @@ -439,20 +440,13 @@ export const heatmapLogic = kea([ (posthog: PostHog): 'version' | 'disabled' | null => { // Later SDKs have the version in the posthog object, but we need to check for the old way of doing it too const posthogVersion: string = - posthog.version ?? - (posthog as any)?._calculate_event_properties?.('test', {}, new Date())?.['$lib_version'] ?? - '0.0.0' - const majorMinorVersion = posthogVersion.split('.') - const majorVersion = parseInt(majorMinorVersion[0], 10) - const minorVersion = parseInt(majorMinorVersion[1], 10) + posthog?.version ?? posthog?._calculate_event_properties?.('test', {})?.['$lib_version'] ?? '0.0.0' if (!(posthog as any)?.scrollManager?.scrollY) { return 'version' } - const isSupported = - majorVersion > SCROLL_DEPTH_JS_VERSION[0] || - (majorVersion === SCROLL_DEPTH_JS_VERSION[0] && minorVersion >= SCROLL_DEPTH_JS_VERSION[1]) + const isSupported = doesSupportScrollDepth(posthogVersion) const isDisabled = posthog?.config.disable_scroll_properties return !isSupported ? 'version' : isDisabled ? 'disabled' : null