Add well and customer detail modal
This commit is contained in:
parent
4df61c8a01
commit
810c87e2e0
6 changed files with 668 additions and 5 deletions
|
@ -6,6 +6,7 @@ from django.views.decorators.http import require_POST, require_GET
|
|||
from django.views.decorators.csrf import csrf_exempt
|
||||
from django import forms
|
||||
from django.contrib.auth.decorators import login_required
|
||||
from django.urls import reverse
|
||||
from accounts.models import Profile
|
||||
from accounts.forms import CustomerForm
|
||||
from processes.utils import scope_customers_queryset
|
||||
|
@ -174,6 +175,128 @@ def get_customer_data(request, customer_id):
|
|||
})
|
||||
|
||||
|
||||
@require_GET
|
||||
@login_required
|
||||
@allowed_roles([UserRoles.ADMIN, UserRoles.BROKER, UserRoles.MANAGER, UserRoles.ACCOUNTANT])
|
||||
def get_customer_details(request, customer_id):
|
||||
"""جزئیات کامل مشترک برای نمایش در مدال"""
|
||||
customer = get_object_or_404(
|
||||
Profile.objects.select_related('user', 'affairs', 'county', 'broker'),
|
||||
id=customer_id
|
||||
)
|
||||
|
||||
data = {
|
||||
'id': customer.id,
|
||||
'user': {
|
||||
'username': customer.user.username,
|
||||
'first_name': customer.user.first_name or '',
|
||||
'last_name': customer.user.last_name or '',
|
||||
'full_name': customer.user.get_full_name() or customer.user.username,
|
||||
'email': customer.user.email or '',
|
||||
'date_joined': customer.jcreated_date() if customer.user.date_joined else '',
|
||||
},
|
||||
'national_code': customer.national_code or '',
|
||||
'phone_number_1': customer.phone_number_1 or '',
|
||||
'phone_number_2': customer.phone_number_2 or '',
|
||||
'card_number': customer.card_number or '',
|
||||
'account_number': customer.account_number or '',
|
||||
'bank_name': customer.get_bank_name_display() or '',
|
||||
'address': customer.address or '',
|
||||
'pic_url': customer.pic.url if customer.pic else '',
|
||||
'affairs': str(customer.affairs) if customer.affairs else '',
|
||||
'county': str(customer.county) if customer.county else '',
|
||||
'broker': str(customer.broker) if customer.broker else '',
|
||||
'is_completed': customer.is_completed,
|
||||
}
|
||||
|
||||
# تعداد چاهها و درخواستها برای نمایش سریع
|
||||
try:
|
||||
from wells.models import Well
|
||||
from processes.models import ProcessInstance
|
||||
total_wells = Well.objects.filter(representative=customer.user, is_deleted=False).count()
|
||||
total_requests = ProcessInstance.objects.filter(representative=customer.user, is_deleted=False).count()
|
||||
except Exception:
|
||||
total_wells = 0
|
||||
total_requests = 0
|
||||
|
||||
return JsonResponse({
|
||||
'success': True,
|
||||
'customer': data,
|
||||
'total_wells': total_wells,
|
||||
'total_requests': total_requests
|
||||
})
|
||||
|
||||
|
||||
@require_GET
|
||||
@login_required
|
||||
@allowed_roles([UserRoles.ADMIN, UserRoles.BROKER, UserRoles.MANAGER, UserRoles.ACCOUNTANT])
|
||||
def get_customer_wells(request, customer_id):
|
||||
"""چاههای مرتبط با یک مشترک"""
|
||||
customer = get_object_or_404(Profile, id=customer_id)
|
||||
|
||||
try:
|
||||
from wells.models import Well
|
||||
qs = Well.objects.select_related(
|
||||
'water_meter_manufacturer', 'affairs', 'county', 'broker'
|
||||
).filter(representative=customer.user, is_deleted=False).order_by('-created')
|
||||
|
||||
items = []
|
||||
for well in qs[:100]: # محدودسازی برای عملکرد
|
||||
items.append({
|
||||
'id': well.id,
|
||||
'water_subscription_number': well.water_subscription_number,
|
||||
'electricity_subscription_number': well.electricity_subscription_number or '',
|
||||
'water_meter_serial_number': well.water_meter_serial_number or '',
|
||||
'water_meter_manufacturer': str(well.water_meter_manufacturer) if well.water_meter_manufacturer else '',
|
||||
'well_power': well.well_power or '',
|
||||
'affairs': str(well.affairs) if well.affairs else '',
|
||||
'county': str(well.county) if well.county else '',
|
||||
'broker': str(well.broker) if well.broker else '',
|
||||
'created': well.jcreated_date() if hasattr(well, 'created') and well.created else '',
|
||||
})
|
||||
except Exception:
|
||||
items = []
|
||||
|
||||
return JsonResponse({'success': True, 'wells': items})
|
||||
|
||||
|
||||
@require_GET
|
||||
@login_required
|
||||
@allowed_roles([UserRoles.ADMIN, UserRoles.BROKER, UserRoles.MANAGER, UserRoles.ACCOUNTANT])
|
||||
def get_customer_requests(request, customer_id):
|
||||
"""درخواستهای مرتبط با یک مشترک"""
|
||||
customer = get_object_or_404(Profile, id=customer_id)
|
||||
|
||||
try:
|
||||
from processes.models import ProcessInstance
|
||||
qs = ProcessInstance.objects.select_related(
|
||||
'process', 'current_step', 'requester', 'well'
|
||||
).filter(representative=customer.user, is_deleted=False).order_by('-created')
|
||||
|
||||
items = []
|
||||
for inst in qs[:100]: # محدودسازی برای عملکرد
|
||||
try:
|
||||
url = reverse('processes:instance_summary', args=[inst.id]) if inst.status == 'completed' else reverse('processes:instance_steps', args=[inst.id])
|
||||
except Exception:
|
||||
url = ''
|
||||
items.append({
|
||||
'id': inst.id,
|
||||
'code': inst.code,
|
||||
'process': inst.process.name if inst.process else '',
|
||||
'status': inst.status,
|
||||
'status_display': inst.get_status_display(),
|
||||
'current_step': inst.current_step.name if inst.current_step else '',
|
||||
'requester': inst.requester.get_full_name() if inst.requester else '',
|
||||
'well_subscription': inst.well.water_subscription_number if inst.well else '',
|
||||
'created': inst.jcreated_date() if hasattr(inst, 'created') and inst.created else '',
|
||||
'url': url,
|
||||
})
|
||||
except Exception:
|
||||
items = []
|
||||
|
||||
return JsonResponse({'success': True, 'requests': items})
|
||||
|
||||
|
||||
@login_required
|
||||
def logout_view(request):
|
||||
"""Log out current user and redirect to login page."""
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue