website/hub/services/views.py

132 lines
4.1 KiB
Python
Raw Normal View History

2025-01-27 16:51:23 +01:00
import logging
from django.conf import settings
from django.shortcuts import render, get_object_or_404, redirect
from django.contrib import messages
2025-01-27 14:58:23 +01:00
from django.db.models import Q
2025-01-28 08:53:00 +01:00
from .models import (
Service,
CloudProvider,
ConsultingPartner,
Category,
2025-01-28 10:41:39 +01:00
Plan,
2025-01-28 08:53:00 +01:00
)
2025-01-27 14:58:23 +01:00
2025-01-27 16:51:23 +01:00
from .forms import LeadForm
from .odoo import OdooAPI
logger = logging.getLogger(__name__)
2025-01-27 14:58:23 +01:00
def service_list(request):
services = Service.objects.all()
cloud_providers = CloudProvider.objects.all()
2025-01-28 08:53:00 +01:00
categories = Category.objects.filter(parent=None)
consulting_partners = ConsultingPartner.objects.all()
2025-01-27 14:58:23 +01:00
if request.GET.get("cloud_provider"):
services = services.filter(cloud_provider_id=request.GET.get("cloud_provider"))
2025-01-27 15:23:50 +01:00
if request.GET.get("category"):
category_id = request.GET.get("category")
category = Category.objects.get(id=category_id)
subcategories = Category.objects.filter(parent=category)
services = services.filter(
Q(categories=category) | Q(categories__in=subcategories)
).distinct()
2025-01-28 08:53:00 +01:00
if request.GET.get("consulting_partner"):
services = services.filter(
consulting_partners__id=request.GET.get("consulting_partner")
)
2025-01-27 14:58:23 +01:00
if request.GET.get("search"):
query = request.GET.get("search")
services = services.filter(
Q(name__icontains=query) | Q(description__icontains=query)
)
context = {
"services": services,
"cloud_providers": cloud_providers,
2025-01-27 15:23:50 +01:00
"categories": categories,
2025-01-28 08:53:00 +01:00
"consulting_partners": consulting_partners,
2025-01-27 14:58:23 +01:00
}
return render(request, "services/service_list.html", context)
2025-01-27 17:00:56 +01:00
def service_detail(request, slug):
service = get_object_or_404(Service, slug=slug)
2025-01-27 14:58:23 +01:00
return render(request, "services/service_detail.html", {"service": service})
2025-01-27 15:54:37 +01:00
def provider_detail(request, slug):
provider = get_object_or_404(CloudProvider, slug=slug)
services = Service.objects.filter(cloud_provider=provider)
context = {
"provider": provider,
"services": services,
}
return render(request, "services/provider_detail.html", context)
2025-01-27 16:51:23 +01:00
2025-01-28 08:53:00 +01:00
def partner_detail(request, slug):
partner = get_object_or_404(ConsultingPartner, slug=slug)
services = Service.objects.filter(consulting_partners=partner)
return render(
request,
"services/partner_detail.html",
{"partner": partner, "services": services},
)
2025-01-27 17:00:56 +01:00
def thank_you(request, slug):
service = get_object_or_404(Service, slug=slug)
2025-01-27 16:51:23 +01:00
return render(request, "services/thank_you.html", {"service": service})
2025-01-27 17:00:56 +01:00
def create_lead(request, slug):
service = get_object_or_404(Service, slug=slug)
2025-01-28 10:41:39 +01:00
selected_plan = None
if request.GET.get("plan"):
selected_plan = get_object_or_404(
Plan, id=request.GET.get("plan"), service=service
)
else:
selected_plan = service.get_default_plan()
2025-01-27 16:51:23 +01:00
if request.method == "POST":
form = LeadForm(request.POST)
if form.is_valid():
lead = form.save(commit=False)
lead.service = service
2025-01-28 10:41:39 +01:00
lead.plan = selected_plan
2025-01-27 16:51:23 +01:00
try:
logger.info(f"Attempting to create lead for service: {service.name}")
odoo = OdooAPI()
odoo_lead_id = odoo.create_lead(lead)
lead.odoo_lead_id = odoo_lead_id
lead.save()
logger.info(f"Successfully created lead with Odoo ID: {odoo_lead_id}")
2025-01-27 17:00:56 +01:00
return redirect("services:thank_you", slug=service.slug)
2025-01-27 16:51:23 +01:00
except Exception as e:
logger.error(f"Failed to create lead: {str(e)}", exc_info=True)
error_message = "Sorry, there was an error processing your request. Please try again later."
if settings.DEBUG:
error_message += f" Error: {str(e)}"
messages.error(request, error_message)
else:
form = LeadForm()
return render(
2025-01-28 10:41:39 +01:00
request,
"services/lead_form.html",
{"form": form, "service": service, "selected_plan": selected_plan},
2025-01-27 16:51:23 +01:00
)