funnel fix (total sessions)

This commit is contained in:
Carl-Gerhard Lindesvärd
2024-08-21 00:11:00 +02:00
parent d5819c920a
commit 1edd63e01e

View File

@@ -292,7 +292,7 @@ export async function getFunnelData({
const innerSql = `SELECT const innerSql = `SELECT
session_id, session_id,
windowFunnel(${ONE_DAY_IN_SECONDS})(toUnixTimestamp(created_at), ${funnels.join(', ')}) AS level windowFunnel(${ONE_DAY_IN_SECONDS}, 'strict_order')(toUnixTimestamp(created_at), ${funnels.join(', ')}) AS level
FROM ${TABLE_NAMES.events} FROM ${TABLE_NAMES.events}
WHERE WHERE
project_id = ${escape(projectId)} AND project_id = ${escape(projectId)} AND
@@ -301,7 +301,7 @@ export async function getFunnelData({
name IN (${payload.events.map((event) => escape(event.name)).join(', ')}) name IN (${payload.events.map((event) => escape(event.name)).join(', ')})
GROUP BY session_id`; GROUP BY session_id`;
const sql = `SELECT level, count() AS count FROM (${innerSql}) GROUP BY level ORDER BY level DESC`; const sql = `SELECT level, count() AS count FROM (${innerSql}) WHERE level != 0 GROUP BY level ORDER BY level DESC`;
const funnelRes = await chQuery<{ level: number; count: number }>(sql); const funnelRes = await chQuery<{ level: number; count: number }>(sql);
@@ -340,9 +340,7 @@ export async function getFunnelData({
); );
const totalSessions = last(filledFunnelRes)?.count ?? 0; const totalSessions = last(filledFunnelRes)?.count ?? 0;
const steps = reverse(filledFunnelRes) const steps = reverse(filledFunnelRes).reduce(
.filter((item) => item.level !== 0)
.reduce(
(acc, item, index, list) => { (acc, item, index, list) => {
const prev = list[index - 1] ?? { count: totalSessions }; const prev = list[index - 1] ?? { count: totalSessions };
const event = payload.events[item.level - 1]!; const event = payload.events[item.level - 1]!;