fix routes models
This commit is contained in:
SDE
2023-08-29 18:34:11 +03:00
parent 1f3bb2dce9
commit 01863bcf38
6 changed files with 89 additions and 4 deletions

View File

@@ -6,4 +6,5 @@ from .views import *
urlpatterns = [ urlpatterns = [
path('', MainPage, name='main'), path('', MainPage, name='main'),
path('test_code', test_code, name='test_code'),
] ]

View File

@@ -7,6 +7,29 @@ from .models import *
from django.conf import settings from django.conf import settings
def test_code(request):
from RoutesApp.funcs import get_city_by_type_transport_and_address_point
from RoutesApp.models import Route
from ReferenceDataApp.models import Airport, City
routes = Route.objects.all()
for route in routes:
print(route.id)
required_save = False
if not route.from_address_point:
route.from_city = get_city_by_type_transport_and_address_point(route.type_transport, route.from_address_point)
required_save = True
if not route.to_address_point:
route.to_address_point = get_city_by_type_transport_and_address_point(route.type_transport,
route.to_address_point)
required_save = True
if required_save:
route.save()
return HttpResponse('finished')
def MainPage(request): def MainPage(request):

View File

@@ -1,4 +1,19 @@
from .models import * from .models import *
def get_city_by_type_transport_and_address_point(type_transport, address_point):
from ReferenceDataApp.models import Airport, City
try:
if type_transport == 'avia':
return Airport.objects.get(id=address_point).city
else:
return City.objects.get(id=address_point)
except Exception as e:
msg = f'get_city_by_type_transport_and_address_point Error = {str(e)}, type_transport = {type_transport}, address_point = {address_point}'
print(msg)
return None
def get_routes_Dict(user=None, data=None): def get_routes_Dict(user=None, data=None):
from ReferenceDataApp.models import Airport, Country, City from ReferenceDataApp.models import Airport, Country, City
@@ -29,10 +44,16 @@ def get_routes_Dict(user=None, data=None):
kwargs.update({f'{key}__lte': int(weight_list[1])}) kwargs.update({f'{key}__lte': int(weight_list[1])})
if key not in ( if key not in (
'from_address_point_txt', 'to_address_point_txt', 'csrfmiddlewaretoken', 'sort', 'weight', 'from_address_point_txt', 'to_address_point_txt', 'csrfmiddlewaretoken', 'sort', 'weight',
'from_el', 'to_el' 'from_el', 'to_el', 'from_address_point', 'to_address_point'
): ):
kwargs.update({key: val}) kwargs.update({key: val})
if key == 'from_address_point':
kwargs.update({f'from_city__id': val})
if key == 'to_address_point':
kwargs.update({f'to_city__id': val})
if key == 'from_el': if key == 'from_el':
from_el = int(val) from_el = int(val)
if key == 'to_el': if key == 'to_el':

View File

@@ -14,7 +14,7 @@ from datetime import datetime
from django.template.loader import render_to_string from django.template.loader import render_to_string
from django.urls import reverse from django.urls import reverse
from .forms import * from .forms import *
from .funcs import get_routes_Dict from .funcs import *
def edit_route_ajax(request): def edit_route_ajax(request):
@@ -217,6 +217,7 @@ def get_routes_ajax(request):
def create_or_change_route_ajax(request, route_id=None): def create_or_change_route_ajax(request, route_id=None):
from ReferenceDataApp.models import Airport, City
if request.method != 'POST': if request.method != 'POST':
raise Http404 raise Http404
@@ -249,6 +250,13 @@ def create_or_change_route_ajax(request, route_id=None):
obj = form.save(commit=False) obj = form.save(commit=False)
if 'owner_type' in data: if 'owner_type' in data:
obj.owner_type = data['owner_type'] obj.owner_type = data['owner_type']
if obj.from_address_point:
obj.from_city = get_city_by_type_transport_and_address_point(obj.type_transport, obj.from_address_point)
if obj.to_address_point:
obj.to_address_point = get_city_by_type_transport_and_address_point(obj.type_transport, obj.to_address_point)
obj.owner = request.user obj.owner = request.user
obj.save() obj.save()

View File

@@ -0,0 +1,25 @@
# Generated by Django 4.2.2 on 2023-08-29 18:02
from django.db import migrations, models
import django.db.models.deletion
class Migration(migrations.Migration):
dependencies = [
('ReferenceDataApp', '0005_remove_airport_parsing_finished_and_more'),
('RoutesApp', '0004_alter_route_type_transport'),
]
operations = [
migrations.AddField(
model_name='route',
name='from_city',
field=models.ForeignKey(blank=True, null=True, on_delete=django.db.models.deletion.SET_NULL, related_name='rel_routes_for_cityFrom', to='ReferenceDataApp.city', verbose_name='Город отправки'),
),
migrations.AddField(
model_name='route',
name='to_city',
field=models.ForeignKey(blank=True, null=True, on_delete=django.db.models.deletion.SET_NULL, related_name='rel_routes_for_cityTo', to='ReferenceDataApp.city', verbose_name='Город получения'),
),
]

View File

@@ -31,6 +31,7 @@ owner_type_choices = (
class Route(BaseModel): class Route(BaseModel):
from django.contrib.auth.models import User from django.contrib.auth.models import User
from ReferenceDataApp.models import City
owner_type = models.CharField( owner_type = models.CharField(
choices=owner_type_choices, default='customer', verbose_name=_('Тип опреации')) choices=owner_type_choices, default='customer', verbose_name=_('Тип опреации'))
@@ -41,8 +42,14 @@ class Route(BaseModel):
arrival_DT = models.DateTimeField(default=True, verbose_name=_('Дата и время прибытия')) arrival_DT = models.DateTimeField(default=True, verbose_name=_('Дата и время прибытия'))
from_address_point = models.IntegerField(verbose_name=_('Пункт выезда')) from_address_point = models.IntegerField(verbose_name=_('Пункт выезда'))
to_address_point = models.IntegerField(verbose_name=_('Пункт приезда')) to_address_point = models.IntegerField(verbose_name=_('Пункт приезда'))
# from_city = forms.CharField(required=True) from_city = models.ForeignKey(
# to_city = forms.CharField(required=True) City, verbose_name=_('Город отправки'), related_name='rel_routes_for_cityFrom', on_delete=models.SET_NULL,
null=True, blank=True
)
to_city = models.ForeignKey(
City, verbose_name=_('Город получения'), related_name='rel_routes_for_cityTo', on_delete=models.SET_NULL,
null=True, blank=True
)
from_place = models.CharField(choices=transfer_location_choices, default='other', from_place = models.CharField(choices=transfer_location_choices, default='other',
verbose_name=_('Откуда можете забрать?')) verbose_name=_('Откуда можете забрать?'))
to_place = models.CharField(choices=transfer_location_choices, default='other', to_place = models.CharField(choices=transfer_location_choices, default='other',