mod: изменение роутинга для страницы ценовых предложений

This commit is contained in:
2026-04-30 23:20:34 +03:00
parent a84e780710
commit 61f69c21f7
7 changed files with 114 additions and 37 deletions

View File

@@ -101,7 +101,7 @@ def catalog_seria_info(
is_hard_template = True
else:
# В PROD используем существующий pre-render include при наличии на диске.
light_template = f"{PATH_FOR_SERIA_INFO_HTML_INCLUDE}{seria_id}_id.html"
light_template = f"seria_info/prepared/{seria_id}_id.html"
light_template_w_path = f"{TEMPLATES[0]['DIRS'][0]}/{light_template}"
is_hard_template = not os.path.isfile(light_template_w_path)
@@ -125,10 +125,6 @@ def catalog_seria_info(
.distinct()
)
if is_hard_template:
# Для "тяжелого" шаблона нужны большие картинки схем окон.
to_template.update(get_flaps_for_big_pictures(list_win_in_seria))
window_ids = [win.id for win in list_win_in_seria]
apartments_in_seria = list(
Apartment_Type.objects.filter(kSeria_id=seria_id)
@@ -209,16 +205,26 @@ def catalog_seria_info(
# Для "тяжелого" шаблона получаем навигацию, карту и график, затем кэшируем pre-render.
if is_hard_template:
to_template.update(get_flaps_for_big_pictures(list_win_in_seria))
seria_id, for_seria_nav = seria_nav(seria_id)
to_template.update(for_seria_nav)
to_template.update(seria_info_year(seria_id))
to_template.update(seria_info_geo_code(seria_id))
if not DEBUG:
string_prerender = render_to_string("seria_info/all_seria_info_pre_light.html", to_template)
# Пре-рендер происходит только для "включаемого" шаблона,
# чтобы избежать дублирования базовой разметки.
string_prerender = render_to_string("seria_info/all_seria_info_pre_light_include.html", to_template)
with open(light_template_w_path, "w", encoding="utf-8") as file:
file.write(string_prerender)
# Основной шаблон будет просто включать в себя уже готовый HTML
light_template = "seria_info/all_seria_info_pre_light.html"
else:
to_template.update({"THIS_SERIA_NAME": q_seria.sName})
# Указываем путь к кешированному файлу для include
to_template.update({"PRE_RENDERED_INCLUDE_PATH": light_template})
# Основной шаблон должен быть один и тот же
light_template = "seria_info/all_seria_info_pre_light.html"
_append_visit_context(to_template, request, time_start)
return render(request, light_template, to_template)

View File

@@ -141,8 +141,18 @@ class BuildingOffersSitemap(Sitemap):
yield (building.id, apart_id, pytils.translit.slugify(building.sAddress))
def location(self, item: tuple[int, int, str]) -> str:
build_id, apart_id, slug = item
return f"/{build_id}/{apart_id}/{slug}"
build_id, apart_id, address_slug = item
# Получаем объект здания и серию для формирования нового роутинга
try:
building = Building_Info.objects.select_related('kSeria_Link__kRoot').get(id=build_id)
seria = building.kSeria_Link.kRoot
seria_id = seria.id
seria_slug = pytils.translit.slugify((seria.sName or "").strip()).lower()
except Exception:
# fallback на старый роутинг, если что-то пошло не так
return f"/{build_id}/{apart_id}/{address_slug}"
# Новый формат: /price/seriaID<seria_id>--<seria_slug>/appartID<apart_id>/addressID<address_id>--<address_slug>/
return f"/price/seriaID{seria_id}--{seria_slug}/appartID{apart_id}/addressID{build_id}--{address_slug}/"
def lastmod(self, item: tuple[int, int, str]) -> datetime:
return self.lastmod_value

View File

@@ -1009,3 +1009,54 @@ def next_price_frame(request: HttpRequest, apart_id: str = "1", mount_dim_per_o
'ADDRESS_LON': address_longitude,
'ticks': float(time.perf_counter() - time_start)})
return render(request, "price/price_list_frame.html", to_template)
def report_price_new(request, seria_id, seria_slug, apart_id, address_id, address_slug):
"""
Новый view для ценовой выдачи по новому роутингу.
:param seria_id: ID серии (Seria_Info)
:param seria_slug: slug серии (транслит)
:param apart_id: ID типа квартиры (Apartment_Type)
:param address_id: ID адреса (Building_Info)
:param address_slug: slug адреса (транслит)
"""
from oknardia.models import Building_Info, Apartment_Type, Seria_Info
from django.shortcuts import redirect
# Проверяем, что все объекты существуют
try:
print(f"seria_id: {seria_id}, seria_slug: {seria_slug}, apart_id: {apart_id}, address_id: {address_id}, address_slug: {address_slug}")
seria = Seria_Info.objects.get(id=seria_id)
building = Building_Info.objects.get(id=address_id)
# apartment = Apartment_Type.objects.get(id=apart_id)
except Exception:
return redirect("/")
# Проверяем slug'и, если не совпадает — делаем 301 на канонический URL (новый формат)
seria_slug_real = pytils.translit.slugify((seria.sName or "").strip()).lower()
address_slug_real = pytils.translit.slugify((building.sAddress or "").strip()).lower()
if seria_slug != seria_slug_real or address_slug != address_slug_real:
# Новый формат: /price/seriaID<seria_id>--<seria_slug>/appartAD<apart_id>/addressID<address_id>--<address_slug>/
return redirect(f"/price/seriaID{seria_id}--{seria_slug_real}/appartID{apart_id}/addressID{address_id}--{address_slug_real}/", permanent=True)
# Вызываем старую логику выдачи (используем report_price)
# В старом view: build_id = address_id, apart_id = apart_id, slug = address_slug
return report_price(request, build_id=address_id, apart_id=apart_id, slug=address_slug)
def report_price_legacy_redirect(request, build_id, apart_id, slug):
try:
building = Building_Info.objects.select_related('kSeria_Link__kRoot').get(id=build_id)
seria = building.kSeria_Link.kRoot
# Если apart_id == 0, ищем минимальный валидный ID квартиры для этой серии
if int(apart_id) == 0:
min_apart = Apartment_Type.objects.filter(kSeria_id=seria.id).order_by('id').first()
if min_apart:
apart_id = min_apart.id
except Exception:
return redirect("/")
import pytils
seria_slug = pytils.translit.slugify((seria.sName or "").strip()).lower()
address_slug = pytils.translit.slugify((building.sAddress or "").strip()).lower()
# Новый формат: /price/seriaID<seria_id>--<seria_slug>/appartID<apart_id>/addressID<build_id>--<address_slug>/
return redirect(f"/price/seriaID{seria.id}--{seria_slug}/appartID{apart_id}/addressID{build_id}--{address_slug}/", permanent=True)
seria_slug = pytils.translit.slugify((seria.sName or "").strip()).lower()
address_slug = pytils.translit.slugify((building.sAddress or "").strip()).lower()
return redirect(f"/price/seriaID{seria.id}--{seria_slug}/appartID{apart_id}/addressID{build_id}--{address_slug}/", permanent=True)