create sitemanagement project and dynamic faqs
This commit is contained in:
@@ -1,3 +1,6 @@
|
||||
from django.contrib import admin
|
||||
from .models import *
|
||||
|
||||
# Register your models here.
|
||||
admin.site.register(Country)
|
||||
admin.site.register(City)
|
||||
admin.site.register(Route)
|
||||
|
||||
6
backend/routes/constants/__init__.py
Normal file
6
backend/routes/constants/__init__.py
Normal file
@@ -0,0 +1,6 @@
|
||||
from .routeChoices import (
|
||||
type_transport_choices,
|
||||
transfer_location_choices,
|
||||
cargo_type_choices,
|
||||
owner_type_choices
|
||||
)
|
||||
56
backend/routes/migrations/0001_initial.py
Normal file
56
backend/routes/migrations/0001_initial.py
Normal file
@@ -0,0 +1,56 @@
|
||||
# Generated by Django 5.2.1 on 2025-05-15 15:57
|
||||
|
||||
import django.db.models.deletion
|
||||
from django.db import migrations, models
|
||||
|
||||
|
||||
class Migration(migrations.Migration):
|
||||
|
||||
initial = True
|
||||
|
||||
dependencies = [
|
||||
]
|
||||
|
||||
operations = [
|
||||
migrations.CreateModel(
|
||||
name='Country',
|
||||
fields=[
|
||||
('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
|
||||
('international_name', models.CharField(blank=True, max_length=250, null=True, verbose_name='Международное название')),
|
||||
('official_name', models.CharField(blank=True, max_length=250, null=True, verbose_name='Официальное название')),
|
||||
('short_code', models.CharField(max_length=2, verbose_name='Код страны по ISO3166-1:alpha2')),
|
||||
('code', models.CharField(max_length=3, verbose_name='Код страны по ISO3166-1:alpha3')),
|
||||
('num_code', models.CharField(blank=True, max_length=3, null=True, verbose_name='Код страны по ISO3166-1:numeric')),
|
||||
('flag_img_url', models.URLField(blank=True, null=True, verbose_name='Ссылка на изображение флага')),
|
||||
('geo_lat', models.CharField(blank=True, max_length=20, null=True, verbose_name='GPS широта')),
|
||||
('geo_lon', models.CharField(blank=True, max_length=20, null=True, verbose_name='GPS долгота')),
|
||||
('timezone', models.CharField(blank=True, max_length=250, null=True, verbose_name='Часовая зона')),
|
||||
('area_id', models.BigIntegerField(blank=True, null=True)),
|
||||
('parsing_finished_DT', models.DateTimeField(blank=True, null=True, verbose_name='Дата и время завершения парсинга')),
|
||||
('flag', models.ImageField(blank=True, null=True, upload_to='uploads/flags/', verbose_name='Флаг')),
|
||||
],
|
||||
options={
|
||||
'verbose_name': 'Страна',
|
||||
'verbose_name_plural': 'Страны',
|
||||
'ordering': ('international_name', 'code'),
|
||||
},
|
||||
),
|
||||
migrations.CreateModel(
|
||||
name='City',
|
||||
fields=[
|
||||
('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
|
||||
('name', models.CharField(blank=True, max_length=30, null=True, verbose_name='Название города')),
|
||||
('geo_lat', models.CharField(blank=True, max_length=20, null=True, verbose_name='GPS широта')),
|
||||
('geo_lon', models.CharField(blank=True, max_length=20, null=True, verbose_name='GPS долгота')),
|
||||
('area_id', models.BigIntegerField(blank=True, null=True)),
|
||||
('timezone', models.CharField(blank=True, max_length=250, null=True, verbose_name='Часовая зона')),
|
||||
('parsing_finished_DT', models.DateTimeField(blank=True, null=True, verbose_name='Дата и время завершения парсинга')),
|
||||
('country', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, related_name='rel_cities_for_country', to='routes.country', verbose_name='Страна')),
|
||||
],
|
||||
options={
|
||||
'verbose_name': 'Город',
|
||||
'verbose_name_plural': 'Города',
|
||||
'ordering': ('name',),
|
||||
},
|
||||
),
|
||||
]
|
||||
39
backend/routes/migrations/0002_route.py
Normal file
39
backend/routes/migrations/0002_route.py
Normal file
@@ -0,0 +1,39 @@
|
||||
# Generated by Django 5.2.1 on 2025-05-15 16:09
|
||||
|
||||
import django.db.models.deletion
|
||||
from django.conf import settings
|
||||
from django.db import migrations, models
|
||||
|
||||
|
||||
class Migration(migrations.Migration):
|
||||
|
||||
dependencies = [
|
||||
('routes', '0001_initial'),
|
||||
migrations.swappable_dependency(settings.AUTH_USER_MODEL),
|
||||
]
|
||||
|
||||
operations = [
|
||||
migrations.CreateModel(
|
||||
name='Route',
|
||||
fields=[
|
||||
('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
|
||||
('owner_type', models.CharField(choices=[('customer', 'Заказчик'), ('mover', 'Перевозчик')], default='customer', verbose_name='Тип опреации')),
|
||||
('type_transport', models.CharField(blank=True, choices=[('road', 'Авто'), ('avia', 'Авиа'), ('both', 'Любой')], default='', verbose_name='Выберите способ перевозки')),
|
||||
('departure_DT', models.DateTimeField(blank=True, null=True, verbose_name='Дата и время выезда')),
|
||||
('arrival_DT', models.DateTimeField(verbose_name='Дата и время прибытия')),
|
||||
('cargo_type', models.CharField(choices=[('letter', 'Письмо или Документы'), ('package', 'Посылка (до 30кг)'), ('passenger', 'Попутчик'), ('parcel', 'Бандероль (до 5кг)'), ('cargo', 'Груз (свыше 30 кг)')], default='letter', verbose_name='Могу перевезти')),
|
||||
('receive_msg_by_email', models.BooleanField(default=False, verbose_name='Получать уведомления по E-mail')),
|
||||
('comment', models.TextField(blank=True, null=True, verbose_name='Примечания')),
|
||||
('rising_DT', models.DateTimeField(blank=True, null=True, verbose_name='Дата и время последнего поднятия')),
|
||||
('highlight_end_DT', models.DateTimeField(blank=True, null=True, verbose_name='Дата и время окончания выделения')),
|
||||
('from_city', models.ForeignKey(blank=True, null=True, on_delete=django.db.models.deletion.SET_NULL, related_name='rel_routes_for_cityFrom', to='routes.city', verbose_name='Город отправки')),
|
||||
('owner', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, related_name='rel_routes_for_owner', to=settings.AUTH_USER_MODEL, verbose_name='Владелец')),
|
||||
('to_city', models.ForeignKey(blank=True, null=True, on_delete=django.db.models.deletion.SET_NULL, related_name='rel_routes_for_cityTo', to='routes.city', verbose_name='Город получения')),
|
||||
],
|
||||
options={
|
||||
'verbose_name': 'Маршрут',
|
||||
'verbose_name_plural': 'Маршруты',
|
||||
'ordering': ('id',),
|
||||
},
|
||||
),
|
||||
]
|
||||
@@ -1,3 +1,114 @@
|
||||
from django.db import models
|
||||
from django.contrib.auth.models import User
|
||||
from routes.constants.routeChoices import owner_type_choices, type_transport_choices, cargo_type_choices
|
||||
|
||||
# Create your models here.
|
||||
class Country(models.Model):
|
||||
international_name = models.CharField(max_length=250, verbose_name=('Международное название'), blank=True, null=True)
|
||||
official_name = models.CharField(max_length=250, verbose_name=('Официальное название'), blank=True, null=True)
|
||||
|
||||
short_code = models.CharField(max_length=2, verbose_name=('Код страны по ISO3166-1:alpha2'))
|
||||
code = models.CharField(max_length=3, verbose_name=('Код страны по ISO3166-1:alpha3'))
|
||||
num_code = models.CharField(max_length=3, verbose_name=('Код страны по ISO3166-1:numeric'), blank=True, null=True)
|
||||
|
||||
flag_img_url = models.URLField(verbose_name=('Ссылка на изображение флага'), blank=True, null=True)
|
||||
|
||||
geo_lat = models.CharField(max_length=20, verbose_name=('GPS широта'), blank=True, null=True)
|
||||
geo_lon = models.CharField(max_length=20, verbose_name=('GPS долгота'), blank=True, null=True)
|
||||
|
||||
timezone = models.CharField(max_length=250, verbose_name=('Часовая зона'), blank=True, null=True)
|
||||
|
||||
area_id = models.BigIntegerField(blank=True, null=True)
|
||||
|
||||
parsing_finished_DT = models.DateTimeField(verbose_name=('Дата и время завершения парсинга'), blank=True, null=True)
|
||||
|
||||
flag = models.ImageField(
|
||||
upload_to='uploads/flags/', verbose_name=('Флаг'),
|
||||
null=True, blank=True, help_text=u'')
|
||||
|
||||
def __str__(self):
|
||||
if self.international_name:
|
||||
return f'{self.international_name}'
|
||||
elif self.official_name:
|
||||
return f'{self.official_name}'
|
||||
elif self.code:
|
||||
return f'{self.code}'
|
||||
|
||||
class Meta:
|
||||
verbose_name = ('Страна')
|
||||
verbose_name_plural = ('Страны')
|
||||
ordering = ('international_name', 'code')
|
||||
|
||||
|
||||
class City(models.Model):
|
||||
|
||||
country = models.ForeignKey(
|
||||
Country, verbose_name=('Страна'), related_name='rel_cities_for_country', on_delete=models.CASCADE)
|
||||
|
||||
name = models.CharField(max_length=30, verbose_name=('Название города'), blank=True, null=True)
|
||||
geo_lat = models.CharField(max_length=20, verbose_name=('GPS широта'), blank=True, null=True)
|
||||
geo_lon = models.CharField(max_length=20, verbose_name=('GPS долгота'), blank=True, null=True)
|
||||
|
||||
area_id = models.BigIntegerField(blank=True, null=True)
|
||||
|
||||
timezone = models.CharField(max_length=250, verbose_name=('Часовая зона'), blank=True, null=True)
|
||||
|
||||
parsing_finished_DT = models.DateTimeField(verbose_name=('Дата и время завершения парсинга'), blank=True, null=True)
|
||||
|
||||
def __str__(self):
|
||||
return f'{self.name}'
|
||||
|
||||
class Meta:
|
||||
verbose_name = ('Город')
|
||||
verbose_name_plural = ('Города')
|
||||
ordering = ('name',)
|
||||
|
||||
class Route(models.Model):
|
||||
owner_type = models.CharField(
|
||||
choices=owner_type_choices, default='customer', verbose_name=('Тип опреации'))
|
||||
|
||||
type_transport = models.CharField(
|
||||
choices=type_transport_choices, default='', verbose_name=('Выберите способ перевозки'),
|
||||
blank=True
|
||||
)
|
||||
departure_DT = models.DateTimeField(
|
||||
verbose_name=('Дата и время выезда'), null=True, blank=True
|
||||
)
|
||||
arrival_DT = models.DateTimeField(verbose_name=('Дата и время прибытия'))
|
||||
|
||||
from_city = models.ForeignKey(
|
||||
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
|
||||
)
|
||||
cargo_type = models.CharField(
|
||||
choices=cargo_type_choices, default='letter', verbose_name=('Могу перевезти')
|
||||
)
|
||||
receive_msg_by_email = models.BooleanField(default=False, verbose_name=('Получать уведомления по E-mail'))
|
||||
|
||||
owner = models.ForeignKey(User, verbose_name=('Владелец'), related_name='rel_routes_for_owner', on_delete=models.CASCADE)
|
||||
|
||||
comment = models.TextField(verbose_name='Примечания', null=True, blank=True)
|
||||
|
||||
rising_DT = models.DateTimeField(
|
||||
verbose_name=('Дата и время последнего поднятия'),
|
||||
blank=True, null=True
|
||||
)
|
||||
|
||||
highlight_end_DT = models.DateTimeField(
|
||||
verbose_name=('Дата и время окончания выделения'),
|
||||
blank=True, null=True
|
||||
)
|
||||
|
||||
def __str__(self):
|
||||
if self.owner:
|
||||
return f'{self.owner}'
|
||||
else:
|
||||
return str(self.owner_type)
|
||||
|
||||
class Meta:
|
||||
verbose_name = (u'Маршрут')
|
||||
verbose_name_plural = (u'Маршруты')
|
||||
ordering = ('id',)
|
||||
|
||||
Reference in New Issue
Block a user