mirror of
https://github.com/umami-software/umami.git
synced 2026-02-04 04:37:11 +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 (
|
||||
<Column gap>
|
||||
<WebsiteControls websiteId={websiteId} allowFilter={false} />
|
||||
<WebsiteControls websiteId={websiteId} />
|
||||
<Revenue websiteId={websiteId} startDate={startDate} endDate={endDate} />
|
||||
</Column>
|
||||
);
|
||||
|
|
|
|||
|
|
@ -19,7 +19,7 @@ export function CohortDeleteButton({
|
|||
const { formatMessage, labels } = useMessages();
|
||||
const { del, useMutation } = useApi();
|
||||
const { mutate, isPending, error } = useMutation({
|
||||
mutationFn: () => del(`/websites/${websiteId}/cohorts/${cohortId}`),
|
||||
mutationFn: () => del(`/websites/${websiteId}/segments/${cohortId}`),
|
||||
});
|
||||
const { touch } = useModified();
|
||||
|
||||
|
|
|
|||
|
|
@ -1,6 +1,6 @@
|
|||
import { canUpdateWebsite, canViewWebsite } from '@/validations';
|
||||
import { uuid } from '@/lib/crypto';
|
||||
import { parseRequest } from '@/lib/request';
|
||||
import { getQueryFilters, parseRequest } from '@/lib/request';
|
||||
import { json, unauthorized } from '@/lib/response';
|
||||
import { segmentTypeParam, searchParams } from '@/lib/schema';
|
||||
import { createSegment, getWebsiteSegments } from '@/queries';
|
||||
|
|
@ -28,7 +28,9 @@ export async function GET(
|
|||
return unauthorized();
|
||||
}
|
||||
|
||||
const segments = await getWebsiteSegments(websiteId, type);
|
||||
const filters = await getQueryFilters(query);
|
||||
|
||||
const segments = await getWebsiteSegments(websiteId, type, filters);
|
||||
|
||||
return json(segments);
|
||||
}
|
||||
|
|
|
|||
|
|
@ -16,7 +16,7 @@ export function useWebsiteCohortsQuery(
|
|||
return useQuery({
|
||||
queryKey: ['website:cohorts', { websiteId, modified, ...filters, ...params }],
|
||||
queryFn: pageParams => {
|
||||
return get(`/websites/${websiteId}/cohorts`, { ...pageParams, ...filters, ...params });
|
||||
return get(`/websites/${websiteId}/segments`, { ...pageParams, ...filters, ...params });
|
||||
},
|
||||
enabled: !!websiteId,
|
||||
placeholderData: keepPreviousData,
|
||||
|
|
|
|||
|
|
@ -15,7 +15,8 @@ export function useWebsiteSegmentsQuery(
|
|||
|
||||
return useQuery({
|
||||
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,
|
||||
placeholderData: keepPreviousData,
|
||||
...options,
|
||||
|
|
|
|||
|
|
@ -1,5 +1,6 @@
|
|||
import prisma from '@/lib/prisma';
|
||||
import { Prisma, Segment } from '@/generated/prisma/client';
|
||||
import { PageResult, QueryFilters } from '@/lib/types';
|
||||
|
||||
async function findSegment(criteria: Prisma.SegmentFindUniqueArgs): Promise<Segment> {
|
||||
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> {
|
||||
return prisma.client.Segment.findFirst({
|
||||
where: { id: segmentId, websiteId },
|
||||
});
|
||||
}
|
||||
|
||||
export async function getWebsiteSegments(websiteId: string, type: string): Promise<Segment[]> {
|
||||
return prisma.pagedQuery('segment', {
|
||||
where: { websiteId, type },
|
||||
});
|
||||
export async function getWebsiteSegments(
|
||||
websiteId: string,
|
||||
type: string,
|
||||
filters?: QueryFilters,
|
||||
): Promise<PageResult<Segment[]>> {
|
||||
return getSegments(
|
||||
{
|
||||
where: {
|
||||
websiteId,
|
||||
type,
|
||||
},
|
||||
},
|
||||
filters,
|
||||
);
|
||||
}
|
||||
|
||||
export async function createSegment(data: Prisma.SegmentUncheckedCreateInput): Promise<Segment> {
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue