Press n or j to go to the next uncovered block, b, p or k for the previous block.
| 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 | export const dynamic = "force-dynamic"; /** * Customer Segments API Route * * GET - Get customer segment analysis data */ import { NextResponse } from "next/server"; import { withAdmin, withErrorHandling, successResponse, ApiSuccessResponse, ApiErrorResponse, } from "@/lib/api"; import { getCustomerSegments } from "@/lib/analytics/services"; interface CustomerSegments { high: { count: number; revenue: number; avgOrderValue: number }; medium: { count: number; revenue: number; avgOrderValue: number }; low: { count: number; revenue: number; avgOrderValue: number }; dormant: { count: number; lastOrderDaysAgo: number }; } /** * GET /api/admin/analytics/segments * Get customer segments by value */ async function handleGet(): Promise<NextResponse<ApiSuccessResponse<CustomerSegments> | ApiErrorResponse>> { const segments = await getCustomerSegments(); return successResponse(segments); } export const GET = withErrorHandling(withAdmin(handleGet)); |