mirror of
https://github.com/umami-software/umami.git
synced 2026-02-13 09:05:36 +01:00
fix search for segments, fix hooks endpoint for cohorts
This commit is contained in:
parent
2f1f704728
commit
65024d4bf7
6 changed files with 43 additions and 10 deletions
|
|
@ -11,7 +11,7 @@ export function RevenuePage({ websiteId }: { websiteId: string }) {
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<Column gap>
|
<Column gap>
|
||||||
<WebsiteControls websiteId={websiteId} allowFilter={false} />
|
<WebsiteControls websiteId={websiteId} />
|
||||||
<Revenue websiteId={websiteId} startDate={startDate} endDate={endDate} />
|
<Revenue websiteId={websiteId} startDate={startDate} endDate={endDate} />
|
||||||
</Column>
|
</Column>
|
||||||
);
|
);
|
||||||
|
|
|
||||||
|
|
@ -19,7 +19,7 @@ export function CohortDeleteButton({
|
||||||
const { formatMessage, labels } = useMessages();
|
const { formatMessage, labels } = useMessages();
|
||||||
const { del, useMutation } = useApi();
|
const { del, useMutation } = useApi();
|
||||||
const { mutate, isPending, error } = useMutation({
|
const { mutate, isPending, error } = useMutation({
|
||||||
mutationFn: () => del(`/websites/${websiteId}/cohorts/${cohortId}`),
|
mutationFn: () => del(`/websites/${websiteId}/segments/${cohortId}`),
|
||||||
});
|
});
|
||||||
const { touch } = useModified();
|
const { touch } = useModified();
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -1,6 +1,6 @@
|
||||||
import { canUpdateWebsite, canViewWebsite } from '@/validations';
|
import { canUpdateWebsite, canViewWebsite } from '@/validations';
|
||||||
import { uuid } from '@/lib/crypto';
|
import { uuid } from '@/lib/crypto';
|
||||||
import { parseRequest } from '@/lib/request';
|
import { getQueryFilters, parseRequest } from '@/lib/request';
|
||||||
import { json, unauthorized } from '@/lib/response';
|
import { json, unauthorized } from '@/lib/response';
|
||||||
import { segmentTypeParam, searchParams } from '@/lib/schema';
|
import { segmentTypeParam, searchParams } from '@/lib/schema';
|
||||||
import { createSegment, getWebsiteSegments } from '@/queries';
|
import { createSegment, getWebsiteSegments } from '@/queries';
|
||||||
|
|
@ -28,7 +28,9 @@ export async function GET(
|
||||||
return unauthorized();
|
return unauthorized();
|
||||||
}
|
}
|
||||||
|
|
||||||
const segments = await getWebsiteSegments(websiteId, type);
|
const filters = await getQueryFilters(query);
|
||||||
|
|
||||||
|
const segments = await getWebsiteSegments(websiteId, type, filters);
|
||||||
|
|
||||||
return json(segments);
|
return json(segments);
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -16,7 +16,7 @@ export function useWebsiteCohortsQuery(
|
||||||
return useQuery({
|
return useQuery({
|
||||||
queryKey: ['website:cohorts', { websiteId, modified, ...filters, ...params }],
|
queryKey: ['website:cohorts', { websiteId, modified, ...filters, ...params }],
|
||||||
queryFn: pageParams => {
|
queryFn: pageParams => {
|
||||||
return get(`/websites/${websiteId}/cohorts`, { ...pageParams, ...filters, ...params });
|
return get(`/websites/${websiteId}/segments`, { ...pageParams, ...filters, ...params });
|
||||||
},
|
},
|
||||||
enabled: !!websiteId,
|
enabled: !!websiteId,
|
||||||
placeholderData: keepPreviousData,
|
placeholderData: keepPreviousData,
|
||||||
|
|
|
||||||
|
|
@ -15,7 +15,8 @@ export function useWebsiteSegmentsQuery(
|
||||||
|
|
||||||
return useQuery({
|
return useQuery({
|
||||||
queryKey: ['website:segments', { websiteId, modified, ...filters, ...params }],
|
queryKey: ['website:segments', { websiteId, modified, ...filters, ...params }],
|
||||||
queryFn: () => get(`/websites/${websiteId}/segments`, { ...filters, ...params }),
|
queryFn: pageParams =>
|
||||||
|
get(`/websites/${websiteId}/segments`, { ...pageParams, ...filters, ...params }),
|
||||||
enabled: !!websiteId,
|
enabled: !!websiteId,
|
||||||
placeholderData: keepPreviousData,
|
placeholderData: keepPreviousData,
|
||||||
...options,
|
...options,
|
||||||
|
|
|
||||||
|
|
@ -1,5 +1,6 @@
|
||||||
import prisma from '@/lib/prisma';
|
import prisma from '@/lib/prisma';
|
||||||
import { Prisma, Segment } from '@/generated/prisma/client';
|
import { Prisma, Segment } from '@/generated/prisma/client';
|
||||||
|
import { PageResult, QueryFilters } from '@/lib/types';
|
||||||
|
|
||||||
async function findSegment(criteria: Prisma.SegmentFindUniqueArgs): Promise<Segment> {
|
async function findSegment(criteria: Prisma.SegmentFindUniqueArgs): Promise<Segment> {
|
||||||
return prisma.client.Segment.findUnique(criteria);
|
return prisma.client.Segment.findUnique(criteria);
|
||||||
|
|
@ -13,16 +14,45 @@ export async function getSegment(segmentId: string): Promise<Segment> {
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
export async function getSegments(
|
||||||
|
criteria: Prisma.SegmentFindManyArgs,
|
||||||
|
filters: QueryFilters,
|
||||||
|
): Promise<PageResult<Segment[]>> {
|
||||||
|
const { search } = filters;
|
||||||
|
const { getSearchParameters, pagedQuery } = prisma;
|
||||||
|
|
||||||
|
const where: Prisma.SegmentWhereInput = {
|
||||||
|
...criteria.where,
|
||||||
|
...getSearchParameters(search, [
|
||||||
|
{
|
||||||
|
name: 'contains',
|
||||||
|
},
|
||||||
|
]),
|
||||||
|
};
|
||||||
|
|
||||||
|
return pagedQuery('segment', { ...criteria, where }, filters);
|
||||||
|
}
|
||||||
|
|
||||||
export async function getWebsiteSegment(websiteId: string, segmentId: string): Promise<Segment> {
|
export async function getWebsiteSegment(websiteId: string, segmentId: string): Promise<Segment> {
|
||||||
return prisma.client.Segment.findFirst({
|
return prisma.client.Segment.findFirst({
|
||||||
where: { id: segmentId, websiteId },
|
where: { id: segmentId, websiteId },
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
export async function getWebsiteSegments(websiteId: string, type: string): Promise<Segment[]> {
|
export async function getWebsiteSegments(
|
||||||
return prisma.pagedQuery('segment', {
|
websiteId: string,
|
||||||
where: { websiteId, type },
|
type: string,
|
||||||
});
|
filters?: QueryFilters,
|
||||||
|
): Promise<PageResult<Segment[]>> {
|
||||||
|
return getSegments(
|
||||||
|
{
|
||||||
|
where: {
|
||||||
|
websiteId,
|
||||||
|
type,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
filters,
|
||||||
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
export async function createSegment(data: Prisma.SegmentUncheckedCreateInput): Promise<Segment> {
|
export async function createSegment(data: Prisma.SegmentUncheckedCreateInput): Promise<Segment> {
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue