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
|
|
|
)
|