✨ Добавлена ContactInfo модель с красивой страницей О нас
Some checks failed
continuous-integration/drone/push Build is failing
Some checks failed
continuous-integration/drone/push Build is failing
- 📊 Создана ContactInfo модель с полями компании, контактов и описания - 🎨 Полностью переработана страница about.html с современными карточками - 🔗 Админ-панель для управления контактной информацией - 💎 CSS анимации и градиенты для улучшения UI/UX - 🗄️ Миграция 0012_contactinfo.py для создания таблицы - 🔧 Обновлены views для использования данных из БД
This commit is contained in:
@@ -3,6 +3,31 @@ from django.contrib.auth.models import AbstractUser, User
|
||||
import uuid
|
||||
from django.urls import reverse
|
||||
|
||||
class ContactInfo(models.Model):
|
||||
"""Модель для контактной информации компании"""
|
||||
company_name = models.CharField(max_length=200, default="SmartSolTech", verbose_name="Название компании")
|
||||
email = models.EmailField(default="info@smartsoltech.kr", verbose_name="Email")
|
||||
phone = models.CharField(max_length=20, default="+82-10-5693-6103", verbose_name="Телефон")
|
||||
telegram = models.CharField(max_length=100, default="@smartsoltech", verbose_name="Telegram")
|
||||
address = models.TextField(default="Чолланамдо, Кванджу", verbose_name="Адрес")
|
||||
working_hours = models.CharField(max_length=100, default="Пн-Пт 9:00-18:00", verbose_name="Часы работы")
|
||||
description = models.TextField(default="Мы - команда профессионалов в сфере IT-решений", verbose_name="Описание")
|
||||
call_to_action = models.CharField(max_length=200, default="Начнем сотрудничество?", verbose_name="Призыв к действию")
|
||||
subtitle = models.CharField(max_length=200, default="Свяжитесь с нами для обсуждения вашего проекта", verbose_name="Подзаголовок")
|
||||
is_active = models.BooleanField(default=True, verbose_name="Активно")
|
||||
|
||||
class Meta:
|
||||
verbose_name = 'Контактная информация'
|
||||
verbose_name_plural = 'Контактная информация'
|
||||
|
||||
def __str__(self):
|
||||
return f"Контакты - {self.company_name}"
|
||||
|
||||
@classmethod
|
||||
def get_active(cls):
|
||||
"""Получить активную контактную информацию"""
|
||||
return cls.objects.filter(is_active=True).first() or cls.objects.create()
|
||||
|
||||
class HeroBanner(models.Model):
|
||||
"""Модель для главного баннера на сайте"""
|
||||
title = models.CharField(max_length=200, verbose_name="Заголовок")
|
||||
|
||||
Reference in New Issue
Block a user