from django.http import HttpResponse, HttpResponseRedirect from django.template import loader from django.conf import settings from django.urls import reverse from django.shortcuts import render, get_object_or_404 from rest_framework.views import APIView from rest_framework.response import Response from rest_framework import status from .models import Product,Database from .serializers import ProductSerializer,DatabaseSerializer from django.http import JsonResponse import os from config import BASE_PATH from api.module.product_description import get_details from django.views.decorators.http import require_http_methods from django.db.models import Q def catalouge_page(request): # Fetch all products from the database products = Product.objects.all() for product in products: if product.images_paths: # Split the images_paths string and get the URL of the first image image_urls = product.images_paths.split(',') product.first_image_url = image_urls[0] if image_urls else None else: product.first_image_url = None context = { 'products': products } return render(request, 'catalouge.html', context) def product_page(request, product_id): product = Product.objects.get(pk=product_id) if product.images_paths: product.images_paths = product.images_paths.split(",") return render(request, 'product_page.html', {'product': product}) def edit_product(request, product_id): product = get_object_or_404(Product, pk=product_id) if request.method == 'POST': # Update the product fields with the submitted data product = Product.objects.get(pk=product_id) product.barcode = request.POST.get('barcode') product.brand = request.POST.get('brand') product.sub_brand = request.POST.get('sub_brand') product.manufacturer = request.POST.get('manufacturer') product.save() # Redirect to the product page after saving return HttpResponseRedirect(reverse('product_detail', args=(product.id,))) return render(request, 'edit_product.html', {'product': product}) def catalouge_page(request): # Fetch all products from the database products = Product.objects.all() # Handle search functionality query = request.GET.get('q') if query: products = products.filter(product_name__icontains=query) for product in products: if product.images_paths: # Split the images_paths string and get the URL of the first image image_urls = product.images_paths.split(',') product.first_image_url = image_urls[0] if image_urls else None else: product.first_image_url = None context = { 'products': products, 'search_query': query # Pass the search query to display in the search bar } return render(request, 'catalouge.html', context) def upload_image_and_audio(request): if request.method == 'POST' and request.FILES.getlist('images'): images = request.FILES.getlist('images') image_path_list = [] static_img_path_list = [] for image in images: # Save the image locally in the static directory image_name = image.name image_path = os.path.join(BASE_PATH,'app','main',settings.MEDIA_ROOT, 'images', image_name) with open(image_path, 'wb') as f: for chunk in image.chunks(): f.write(chunk) image_path_list.append(image_path) static_img_path_list.append(("http://34.122.223.224:9002/media/images/" + image_name)) print('Image saved at:', image_path_list) input_data = get_details(image_path_list) static_img_path = "http://34.122.223.224:9002/media/images/" + image_name product_data = { 'brand': input_data.get('brand',None), 'mrp': input_data.get('mrp',None), 'quantity': 1, 'parent_category': input_data.get('parent_category',None), 'manufactured_by': input_data.get('manufactured_by', ''), 'product_name': input_data.get('type_of_product',None), 'images_paths': ",".join(static_img_path_list), # Save the image paths as a comma-separated string 'description': input_data.get('description',None) , 'price' : input_data.get('price',None), 'weight': input_data.get('weight',None), } # Create a new Product instance and save to database product = Product.objects.create(**product_data) return JsonResponse(product_data, safe=False) # Return product details as JSON response return render(request, 'upload_image.html') class ProductAPIView(APIView): def post(self, request, format=None): serializer = ProductSerializer(data=request.data) if serializer.is_valid(): serializer.save() return Response(serializer.data, status=status.HTTP_201_CREATED) return Response(serializer.errors, status=status.HTTP_400_BAD_REQUEST) def edit_voice_product(request,product_id): if request.method == 'POST': # Handle voice file submission here voice_file = request.FILES.get('voice_file') if voice_file: # Save the voice file to a specific location or process it as needed # For example, you can save it to the media directory # Assuming you have a media directory configured in your Django settings with open('media/voice_files/' + voice_file.name, 'wb') as f: for chunk in voice_file.chunks(): f.write(chunk) return JsonResponse({'message': 'Voice file submitted successfully.'}) else: return JsonResponse({'error': 'No voice file submitted.'}, status=400) else: return render(request, 'edit_voice_product.html') def delete_product_api(request, product_id): try: product = Product.objects.get(pk=product_id) product.delete() return HttpResponseRedirect(reverse('index')) except Product.DoesNotExist: return JsonResponse({'error': 'Product not found.'}, status=404) class SearchProducts(APIView): def get(self, request): name = request.query_params.get('name', '') products = Database.objects.filter(Q(product_name__icontains=name) & Q(description__icontains=name)) db_serializer = DatabaseSerializer(products, many=True) return Response(db_serializer.data) class TotalNumberOfProducts(APIView): def get(self, request): count = Database.objects.count() return Response({"total_number_of_products": count}) class ProductDetailsById(APIView): def get(self, request, pk): try: product = Product.objects.get(pk=pk) product_serializer = ProductSerializer(product) return Response(product_serializer.data) except Product.DoesNotExist: return Response({"error": "Product not found"}, status=404) class UpdateProduct(APIView): def put(self, request, pk): try: product = Product.objects.get(pk=pk) serializer = ProductSerializer(product, data=request.data) print(serializer.is_valid(), serializer.errors) if serializer.is_valid(): serializer.save() return Response(serializer.data) return Response(serializer.errors, status=400) except Product.DoesNotExist: return Response({"error": "Product not found"}, status=404)