Fixed editing and navigation issues.

This commit is contained in:
Mike Cao 2025-07-13 00:37:43 -07:00
parent bf6c9395c6
commit 8c26e310f7
52 changed files with 118 additions and 122 deletions

View file

@ -21,7 +21,7 @@ export async function GET(
return unauthorized();
}
const filters = getQueryFilters({
const filters = await getQueryFilters({
...query,
websiteId,
startAt: subMinutes(startOfMinute(new Date()), REALTIME_RANGE).getTime(),

View file

@ -18,7 +18,7 @@ export async function POST(request: Request) {
}
const parameters = await setWebsiteDate(websiteId, body.parameters);
const filters = getQueryFilters(body.filters);
const filters = await getQueryFilters(body.filters);
const data = await getAttribution(websiteId, parameters as AttributionParameters, filters);

View file

@ -18,7 +18,7 @@ export async function POST(request: Request) {
}
const parameters = await setWebsiteDate(websiteId, body.parameters);
const filters = getQueryFilters(body.filters);
const filters = await getQueryFilters(body.filters);
const data = await getBreakdown(websiteId, parameters as BreakdownParameters, filters);

View file

@ -18,7 +18,7 @@ export async function POST(request: Request) {
}
const parameters = await setWebsiteDate(websiteId, body.parameters);
const filters = getQueryFilters(body.filters);
const filters = await getQueryFilters(body.filters);
const data = await getFunnel(websiteId, parameters as FunnelParameters, filters);

View file

@ -18,7 +18,7 @@ export async function POST(request: Request) {
}
const parameters = await setWebsiteDate(websiteId, body.parameters);
const filters = getQueryFilters(body.filters);
const filters = await getQueryFilters(body.filters);
const data = await getGoal(websiteId, parameters as GoalParameters, filters);

View file

@ -17,7 +17,7 @@ export async function POST(request: Request) {
return unauthorized();
}
const queryFilters = await setWebsiteDate(websiteId, getQueryFilters(filters));
const queryFilters = await setWebsiteDate(websiteId, await getQueryFilters(filters));
const data = await getJourney(websiteId, parameters, queryFilters);

View file

@ -17,7 +17,7 @@ export async function POST(request: Request) {
return unauthorized();
}
const filters = getQueryFilters(body.filters);
const filters = await getQueryFilters(body.filters);
const parameters = await setWebsiteDate(websiteId, body.parameters);
const data = await getRetention(websiteId, parameters as RetentionParameters, filters);

View file

@ -18,7 +18,7 @@ export async function POST(request: Request) {
}
const parameters = await setWebsiteDate(websiteId, body.parameters);
const filters = getQueryFilters(body.filters);
const filters = await getQueryFilters(body.filters);
const data = await getRevenue(websiteId, parameters as RevenuParameters, filters);

View file

@ -18,7 +18,7 @@ export async function POST(request: Request) {
}
const parameters = await setWebsiteDate(websiteId, body.parameters);
const filters = getQueryFilters(body.filters);
const filters = await getQueryFilters(body.filters);
const data = await getUTM(websiteId, parameters as UTMParameters, filters);

View file

@ -23,7 +23,7 @@ export async function GET(request: Request, { params }: { params: Promise<{ team
return unauthorized('You must be the owner of this team.');
}
const filters = getQueryFilters(query);
const filters = await getQueryFilters(query);
const users = await getTeamUsers(
{

View file

@ -22,7 +22,7 @@ export async function GET(request: Request, { params }: { params: Promise<{ user
}
const { userId } = await params;
const filters = getQueryFilters(query);
const filters = await getQueryFilters(query);
const websites = await getAllUserWebsitesIncludingTeamOwner(userId);

View file

@ -26,7 +26,7 @@ export async function GET(
}
const { event } = query;
const filters = getQueryFilters(query);
const filters = await getQueryFilters(query);
const data = await getEventDataEvents(websiteId, {
...filters,

View file

@ -25,7 +25,7 @@ export async function GET(
return unauthorized();
}
const filters = getQueryFilters(query);
const filters = await getQueryFilters(query);
const data = await getEventDataFields(websiteId, filters);

View file

@ -27,7 +27,7 @@ export async function GET(
}
const { propertyName } = query;
const filters = getQueryFilters(query);
const filters = await getQueryFilters(query);
const data = await getEventDataProperties(websiteId, { ...filters, propertyName });

View file

@ -26,7 +26,7 @@ export async function GET(
return unauthorized();
}
const filters = getQueryFilters(query);
const filters = await getQueryFilters(query);
const data = await getEventDataStats(websiteId, filters);

View file

@ -28,7 +28,7 @@ export async function GET(
}
const { eventName, propertyName } = query;
const filters = getQueryFilters(query);
const filters = await getQueryFilters(query);
const data = await getEventDataValues(websiteId, {
...filters,

View file

@ -27,7 +27,7 @@ export async function GET(
return unauthorized();
}
const filters = getQueryFilters(query);
const filters = await getQueryFilters(query);
const data = await getWebsiteEvents(websiteId, filters);

View file

@ -29,7 +29,7 @@ export async function GET(
return unauthorized();
}
const filters = await setWebsiteDate(websiteId, getQueryFilters(query));
const filters = await setWebsiteDate(websiteId, await getQueryFilters(query));
const data = await getEventMetrics(websiteId, filters);

View file

@ -11,10 +11,10 @@ import {
VIDEO_DOMAINS,
PAID_AD_PARAMS,
} from '@/lib/constants';
import { parseRequest, getQueryFilters, setWebsiteDate } from '@/lib/request';
import { parseRequest, getQueryFilters } from '@/lib/request';
import { json, unauthorized, badRequest } from '@/lib/response';
import { getPageviewMetrics, getSessionMetrics, getChannelMetrics } from '@/queries';
import { filterParams } from '@/lib/schema';
import { dateRangeParams, filterParams, searchParams } from '@/lib/schema';
export async function GET(
request: Request,
@ -22,11 +22,10 @@ export async function GET(
) {
const schema = z.object({
type: z.string(),
startAt: z.coerce.number().int(),
endAt: z.coerce.number().int(),
limit: z.coerce.number().optional(),
offset: z.coerce.number().optional(),
search: z.string().optional(),
...dateRangeParams,
...searchParams,
...filterParams,
});
@ -37,13 +36,13 @@ export async function GET(
}
const { websiteId } = await params;
const { type, limit, offset, search } = query;
if (!(await canViewWebsite(auth, websiteId))) {
return unauthorized();
}
const filters = await setWebsiteDate(websiteId, getQueryFilters(query));
const { type, limit, offset, search } = query;
const filters = await getQueryFilters(query, websiteId);
if (search) {
filters[type] = `c.${search}`;

View file

@ -1,6 +1,6 @@
import { z } from 'zod';
import { canViewWebsite } from '@/lib/auth';
import { getQueryFilters, parseRequest, setWebsiteDate } from '@/lib/request';
import { getQueryFilters, parseRequest } from '@/lib/request';
import { dateRangeParams, filterParams } from '@/lib/schema';
import { getCompareDate } from '@/lib/date';
import { unauthorized, json } from '@/lib/response';
@ -27,7 +27,7 @@ export async function GET(
return unauthorized();
}
const filters = await setWebsiteDate(websiteId, getQueryFilters(query));
const filters = await getQueryFilters(query, websiteId);
const [pageviews, sessions] = await Promise.all([
getPageviewStats(websiteId, filters),

View file

@ -22,7 +22,7 @@ export async function GET(
const { websiteId } = await params;
const { propertyName } = query;
const filters = getQueryFilters(query);
const filters = await getQueryFilters(query);
if (!(await canViewWebsite(auth, websiteId))) {
return unauthorized();

View file

@ -22,7 +22,7 @@ export async function GET(
const { propertyName } = query;
const { websiteId } = await params;
const filters = await setWebsiteDate(websiteId, getQueryFilters(query));
const filters = await setWebsiteDate(websiteId, await getQueryFilters(query));
if (!(await canViewWebsite(auth, websiteId))) {
return unauthorized();

View file

@ -25,7 +25,7 @@ export async function GET(
return unauthorized();
}
const filters = getQueryFilters(query);
const filters = await getQueryFilters(query);
const data = await getSessionActivity(websiteId, sessionId, filters);

View file

@ -27,7 +27,7 @@ export async function GET(
return unauthorized();
}
const filters = await setWebsiteDate(websiteId, getQueryFilters(query));
const filters = await setWebsiteDate(websiteId, await getQueryFilters(query));
const data = await getWebsiteSessions(websiteId, filters);

View file

@ -27,7 +27,7 @@ export async function GET(
return unauthorized();
}
const filters = await setWebsiteDate(websiteId, getQueryFilters(query));
const filters = await setWebsiteDate(websiteId, await getQueryFilters(query));
const metrics = await getWebsiteSessionStats(websiteId, filters);

View file

@ -28,7 +28,7 @@ export async function GET(
return unauthorized();
}
const filters = getQueryFilters(query);
const filters = await getQueryFilters(query);
const data = await getWebsiteSessionsWeekly(websiteId, filters);

View file

@ -1,8 +1,8 @@
import { z } from 'zod';
import { parseRequest, getQueryFilters, setWebsiteDate } from '@/lib/request';
import { parseRequest, getQueryFilters } from '@/lib/request';
import { unauthorized, json } from '@/lib/response';
import { canViewWebsite } from '@/lib/auth';
import { filterParams } from '@/lib/schema';
import { dateRangeParams, filterParams } from '@/lib/schema';
import { getWebsiteStats } from '@/queries';
import { getCompareDate } from '@/lib/date';
@ -11,9 +11,8 @@ export async function GET(
{ params }: { params: Promise<{ websiteId: string }> },
) {
const schema = z.object({
startAt: z.coerce.number().int(),
endAt: z.coerce.number().int(),
compare: z.string().optional(),
...dateRangeParams,
...filterParams,
});
@ -29,7 +28,7 @@ export async function GET(
return unauthorized();
}
const filters = await setWebsiteDate(websiteId, getQueryFilters(query));
const filters = await getQueryFilters(query, websiteId);
const data = await getWebsiteStats(websiteId, filters);

View file

@ -39,7 +39,7 @@ export async function GET(
if (FILTER_GROUPS[type]) {
values = (await getWebsiteSegments(websiteId, type)).map(segment => ({ value: segment.name }));
} else {
const filters = getQueryFilters(query);
const filters = await getQueryFilters(query);
values = await getValues(websiteId, FILTER_COLUMNS[type], filters);
}