faq frontend typeguards
This commit is contained in:
@@ -9,6 +9,7 @@ djangorestframework = "*"
|
|||||||
python-dotenv = "*"
|
python-dotenv = "*"
|
||||||
psycopg2 = "*"
|
psycopg2 = "*"
|
||||||
pillow = "*"
|
pillow = "*"
|
||||||
|
transliterate = "*"
|
||||||
|
|
||||||
[dev-packages]
|
[dev-packages]
|
||||||
|
|
||||||
|
|||||||
18
backend/Pipfile.lock
generated
18
backend/Pipfile.lock
generated
@@ -1,7 +1,7 @@
|
|||||||
{
|
{
|
||||||
"_meta": {
|
"_meta": {
|
||||||
"hash": {
|
"hash": {
|
||||||
"sha256": "8058db5f6e1f333af30cffe6634e7d018110d8c2fc6601f3a9c84a72c2ac3110"
|
"sha256": "c254f2788ffdf030b1b0fbe90f05c0c47f93704170c42e2607f2a77b22f6ede2"
|
||||||
},
|
},
|
||||||
"pipfile-spec": 6,
|
"pipfile-spec": 6,
|
||||||
"requires": {
|
"requires": {
|
||||||
@@ -156,6 +156,14 @@
|
|||||||
"markers": "python_version >= '3.9'",
|
"markers": "python_version >= '3.9'",
|
||||||
"version": "==1.1.0"
|
"version": "==1.1.0"
|
||||||
},
|
},
|
||||||
|
"six": {
|
||||||
|
"hashes": [
|
||||||
|
"sha256:4721f391ed90541fddacab5acf947aa0d3dc7d27b2e1e8eda2be8970586c3274",
|
||||||
|
"sha256:ff70335d468e7eb6ec65b95b99d3a2836546063f63acc5171de367e834932a81"
|
||||||
|
],
|
||||||
|
"markers": "python_version >= '2.7' and python_version not in '3.0, 3.1, 3.2'",
|
||||||
|
"version": "==1.17.0"
|
||||||
|
},
|
||||||
"sqlparse": {
|
"sqlparse": {
|
||||||
"hashes": [
|
"hashes": [
|
||||||
"sha256:09f67787f56a0b16ecdbde1bfc7f5d9c3371ca683cfeaa8e6ff60b4807ec9272",
|
"sha256:09f67787f56a0b16ecdbde1bfc7f5d9c3371ca683cfeaa8e6ff60b4807ec9272",
|
||||||
@@ -163,6 +171,14 @@
|
|||||||
],
|
],
|
||||||
"markers": "python_version >= '3.8'",
|
"markers": "python_version >= '3.8'",
|
||||||
"version": "==0.5.3"
|
"version": "==0.5.3"
|
||||||
|
},
|
||||||
|
"transliterate": {
|
||||||
|
"hashes": [
|
||||||
|
"sha256:010a5021bf6021689c4fade0985f3f7b3db1f2f16a48a09a56797f171c08ed42",
|
||||||
|
"sha256:bc608e0d48e687db9c2b1d7ea7c381afe0d1849cad216087d8e03d8d06a57c85"
|
||||||
|
],
|
||||||
|
"index": "pypi",
|
||||||
|
"version": "==1.10.2"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"develop": {}
|
"develop": {}
|
||||||
|
|||||||
18
backend/routes/migrations/0003_alter_route_owner_type.py
Normal file
18
backend/routes/migrations/0003_alter_route_owner_type.py
Normal file
@@ -0,0 +1,18 @@
|
|||||||
|
# Generated by Django 5.2.1 on 2025-05-15 16:40
|
||||||
|
|
||||||
|
from django.db import migrations, models
|
||||||
|
|
||||||
|
|
||||||
|
class Migration(migrations.Migration):
|
||||||
|
|
||||||
|
dependencies = [
|
||||||
|
('routes', '0002_route'),
|
||||||
|
]
|
||||||
|
|
||||||
|
operations = [
|
||||||
|
migrations.AlterField(
|
||||||
|
model_name='route',
|
||||||
|
name='owner_type',
|
||||||
|
field=models.CharField(choices=[('customer', 'Заказчик'), ('mover', 'Перевозчик')], default='customer', verbose_name='Тип операции'),
|
||||||
|
),
|
||||||
|
]
|
||||||
@@ -64,7 +64,7 @@ class City(models.Model):
|
|||||||
|
|
||||||
class Route(models.Model):
|
class Route(models.Model):
|
||||||
owner_type = models.CharField(
|
owner_type = models.CharField(
|
||||||
choices=owner_type_choices, default='customer', verbose_name=('Тип опреации'))
|
choices=owner_type_choices, default='customer', verbose_name=('Тип операции'))
|
||||||
|
|
||||||
type_transport = models.CharField(
|
type_transport = models.CharField(
|
||||||
choices=type_transport_choices, default='', verbose_name=('Выберите способ перевозки'),
|
choices=type_transport_choices, default='', verbose_name=('Выберите способ перевозки'),
|
||||||
|
|||||||
@@ -1,4 +1,5 @@
|
|||||||
from django.contrib import admin
|
from django.contrib import admin
|
||||||
from .models import FAQ
|
from .models import *
|
||||||
|
|
||||||
admin.site.register(FAQ)
|
admin.site.register(FAQ)
|
||||||
|
admin.site.register(News)
|
||||||
|
|||||||
27
backend/sitemanagement/migrations/0002_news.py
Normal file
27
backend/sitemanagement/migrations/0002_news.py
Normal file
@@ -0,0 +1,27 @@
|
|||||||
|
# Generated by Django 5.2.1 on 2025-05-15 16:40
|
||||||
|
|
||||||
|
from django.db import migrations, models
|
||||||
|
|
||||||
|
|
||||||
|
class Migration(migrations.Migration):
|
||||||
|
|
||||||
|
dependencies = [
|
||||||
|
('sitemanagement', '0001_initial'),
|
||||||
|
]
|
||||||
|
|
||||||
|
operations = [
|
||||||
|
migrations.CreateModel(
|
||||||
|
name='News',
|
||||||
|
fields=[
|
||||||
|
('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
|
||||||
|
('titleImage', models.ImageField(upload_to='')),
|
||||||
|
('title', models.CharField(max_length=100)),
|
||||||
|
('content', models.CharField(max_length=1000)),
|
||||||
|
],
|
||||||
|
options={
|
||||||
|
'verbose_name': 'Новость',
|
||||||
|
'verbose_name_plural': 'Новости',
|
||||||
|
'ordering': ['id'],
|
||||||
|
},
|
||||||
|
),
|
||||||
|
]
|
||||||
@@ -0,0 +1,28 @@
|
|||||||
|
# Generated by Django 5.2.1 on 2025-05-15 16:41
|
||||||
|
|
||||||
|
from django.db import migrations, models
|
||||||
|
|
||||||
|
|
||||||
|
class Migration(migrations.Migration):
|
||||||
|
|
||||||
|
dependencies = [
|
||||||
|
('sitemanagement', '0002_news'),
|
||||||
|
]
|
||||||
|
|
||||||
|
operations = [
|
||||||
|
migrations.AlterField(
|
||||||
|
model_name='news',
|
||||||
|
name='content',
|
||||||
|
field=models.TextField(max_length=1000, verbose_name='Контент статьи'),
|
||||||
|
),
|
||||||
|
migrations.AlterField(
|
||||||
|
model_name='news',
|
||||||
|
name='title',
|
||||||
|
field=models.CharField(max_length=100, verbose_name='Заголовок'),
|
||||||
|
),
|
||||||
|
migrations.AlterField(
|
||||||
|
model_name='news',
|
||||||
|
name='titleImage',
|
||||||
|
field=models.ImageField(upload_to='', verbose_name='Главная картинка'),
|
||||||
|
),
|
||||||
|
]
|
||||||
18
backend/sitemanagement/migrations/0004_news_slug.py
Normal file
18
backend/sitemanagement/migrations/0004_news_slug.py
Normal file
@@ -0,0 +1,18 @@
|
|||||||
|
# Generated by Django 5.2.1 on 2025-05-15 16:45
|
||||||
|
|
||||||
|
from django.db import migrations, models
|
||||||
|
|
||||||
|
|
||||||
|
class Migration(migrations.Migration):
|
||||||
|
|
||||||
|
dependencies = [
|
||||||
|
('sitemanagement', '0003_alter_news_content_alter_news_title_and_more'),
|
||||||
|
]
|
||||||
|
|
||||||
|
operations = [
|
||||||
|
migrations.AddField(
|
||||||
|
model_name='news',
|
||||||
|
name='slug',
|
||||||
|
field=models.SlugField(blank=True, null=True),
|
||||||
|
),
|
||||||
|
]
|
||||||
@@ -0,0 +1,23 @@
|
|||||||
|
# Generated by Django 5.2.1 on 2025-05-15 16:49
|
||||||
|
|
||||||
|
from django.db import migrations, models
|
||||||
|
|
||||||
|
|
||||||
|
class Migration(migrations.Migration):
|
||||||
|
|
||||||
|
dependencies = [
|
||||||
|
('sitemanagement', '0004_news_slug'),
|
||||||
|
]
|
||||||
|
|
||||||
|
operations = [
|
||||||
|
migrations.AddField(
|
||||||
|
model_name='news',
|
||||||
|
name='created_at',
|
||||||
|
field=models.DateTimeField(auto_now_add=True, null=True),
|
||||||
|
),
|
||||||
|
migrations.AlterField(
|
||||||
|
model_name='news',
|
||||||
|
name='slug',
|
||||||
|
field=models.SlugField(blank=True, editable=False, null=True),
|
||||||
|
),
|
||||||
|
]
|
||||||
@@ -1,4 +1,8 @@
|
|||||||
from django.db import models
|
from django.db import models
|
||||||
|
from django.utils.text import slugify
|
||||||
|
from django.db.models.signals import pre_save
|
||||||
|
from django.dispatch import receiver
|
||||||
|
from transliterate import translit
|
||||||
|
|
||||||
class FAQ (models.Model):
|
class FAQ (models.Model):
|
||||||
title = models.CharField(max_length=250)
|
title = models.CharField(max_length=250)
|
||||||
@@ -12,3 +16,25 @@ class FAQ (models.Model):
|
|||||||
def __str__(self):
|
def __str__(self):
|
||||||
return self.title
|
return self.title
|
||||||
|
|
||||||
|
|
||||||
|
class News(models.Model):
|
||||||
|
titleImage = models.ImageField(verbose_name="Главная картинка")
|
||||||
|
title = models.CharField(max_length=100, verbose_name="Заголовок")
|
||||||
|
content = models.TextField(max_length=1000, verbose_name="Контент статьи")
|
||||||
|
slug = models.SlugField(null=True, blank=True, editable=False)
|
||||||
|
created_at = models.DateTimeField(auto_now_add=True, null=True, blank=True)
|
||||||
|
class Meta:
|
||||||
|
verbose_name = 'Новость'
|
||||||
|
verbose_name_plural = 'Новости'
|
||||||
|
ordering = ['id']
|
||||||
|
|
||||||
|
def __str__(self):
|
||||||
|
return self.title
|
||||||
|
|
||||||
|
@receiver(pre_save, sender=News)
|
||||||
|
def generate_slug(sender, instance, **kwargs):
|
||||||
|
if not instance.slug:
|
||||||
|
# транслит с русского на латиницу
|
||||||
|
transliterated_title = translit(instance.title, 'ru', reversed=True)
|
||||||
|
# создаем слаг и заменяем пробелы на дефисы
|
||||||
|
instance.slug = slugify(transliterated_title)
|
||||||
@@ -3,6 +3,10 @@ import Accordion from './ui/Accordion'
|
|||||||
import { FAQProps } from '@/app/types'
|
import { FAQProps } from '@/app/types'
|
||||||
|
|
||||||
const FAQ: React.FC<FAQProps> = ({ faqs }) => {
|
const FAQ: React.FC<FAQProps> = ({ faqs }) => {
|
||||||
|
if (!faqs || faqs.length === 0) {
|
||||||
|
return null
|
||||||
|
}
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<div className="w-full max-w-[1250px] mx-auto">
|
<div className="w-full max-w-[1250px] mx-auto">
|
||||||
<div className="pl-4 py-5 sticky">
|
<div className="pl-4 py-5 sticky">
|
||||||
|
|||||||
Reference in New Issue
Block a user