import prismadb from "@/lib/prismadb"
import { auth } from '@clerk/nextjs/server'
import { NextResponse } from "next/server"

export async function GET (
    req: Request,
    { params }: {params: {itemId: string}}
) {
    try {
        if (!params.itemId) {
            return new NextResponse("Item id is required", {status: 400})
        }

        const item = await prismadb.items.findUnique({
            where: {
                id: params.itemId,
            },
            include: {
                category: true,
                size: true,
                variant: true
            }
        })
        console.log('items', item);

        return NextResponse.json(item)
    } catch (error) {
        console.log('[ITEM_GET', error)
        return new NextResponse("Internal error", {status: 500})
    }
}

export async function PATCH (
    req: Request,
    { params }: {params: {storeId: string, itemId: string}}
) {
    try {
        const { userId } = auth()
        const body = await req.json()

        const {
            name,
            price,
            priceDlr,
            categoryId,
            variantId,
            sizeId,
            quantity,
            itemCode,
            codeBars,
        } = body

        if (!userId) {
            return new NextResponse("Unauthenticated", {status: 401})
        }

        if (!name) {
            return new NextResponse("Name is required", {status: 400})
        }

        if (price == null) {
            return new NextResponse("Price IDR is required", {status: 400})
        }

        if (priceDlr == null) {
            return new NextResponse("Price IDR is required", {status: 400})
        }

        if (!categoryId) {
            return new NextResponse("Category is required", {status: 400})
        }

        if (!variantId) {
            return new NextResponse("Variant is required", {status: 400})
        }

        if (!sizeId) {
            return new NextResponse("Size is required", {status: 400})
        }

        if (!itemCode) {
            return new NextResponse("Item Code is required", {status: 400})
        }

        if (!quantity) {
            return new NextResponse("Item Code is required", {status: 400})
        }

        if (!codeBars) {
            return new NextResponse("Code Bars is required", {status: 400})
        }

        if (!params.storeId) {
            return new NextResponse("Store id is required", {status: 400})
        }

        if (!params.itemId) {
            return new NextResponse("Item id is required", {status: 400})
        }

        const storeByUserId = await prismadb.store.findFirst({
            where: {
                id: params.storeId,
                userId
            }
        })

        if (!storeByUserId) {
            return new NextResponse("Unauthorized", {status: 403})
        }

        const updatedItem = await prismadb.items.update({
            where: {
                id: params.itemId,
            },
            data: {
                name,
                price,
                priceDlr,
                categoryId,
                variantId,
                sizeId,
                quantity,
                itemCode,
                codeBars,
            }
        })

        return NextResponse.json(updatedItem)
    } catch (error) {
        console.log('[ITEMS_PATCH]', error)
        return new NextResponse("Internal error", {status: 500})
    }
}

export async function DELETE (
    req: Request,
    { params }: {params: {storeId: string, itemId: string}}
) {
    try {
        const {userId} = auth()

        if (!userId) {
            return new NextResponse("Unauthenticated", {status: 401})
        }

        if (!params.itemId) {
            return new NextResponse("Item id is required", {status: 400})
        }
        
        const storeByUserId = await prismadb.store.findFirst({
            where:{
                id: params.storeId,
                userId
            }
        })

        const item = await prismadb.items.deleteMany({
            where: {
                id: params.itemId,
            }
        })

        return NextResponse.json(item)
    } catch (error) {
        console.log('[ITEM_DELETE', error)
        return new NextResponse("Internal error", {status: 500})
    }
}