Modellar tayyor

This commit is contained in:
2025-11-24 11:46:23 +05:00
parent 3da10c2a7f
commit 5632e0c484
48 changed files with 877 additions and 33 deletions

View File

View File

6
core/apps/api/apps.py Normal file
View File

@@ -0,0 +1,6 @@
from django.apps import AppConfig
class ModuleConfig(AppConfig):
default_auto_field = "django.db.models.BigAutoField"
name = "core.apps.api"

View File

@@ -0,0 +1,3 @@
from .ad_type import * # noqa
from .ad_variant_type import * # noqa
from .order_status import * # noqa

View File

@@ -0,0 +1,22 @@
from django.utils.translation import gettext_lazy as _
from django.db import models
class AdType(models.TextChoices):
"""
Ad type choices.
"""
BUY = "Buy", _("Buy")
SELL = "Sell", _("Sell")
class AdCategoryType(models.TextChoices):
"""
Ad category type choices.
"""
PRODUCT = "Product", _("Product")
SERVICE = "Service", _("Service")
AUTO = "Auto", _("Auto")
HOME = "Home", _("Home")

View File

@@ -0,0 +1,11 @@
from django.utils.translation import gettext_lazy as _
from django.db import models
class AdVariantType(models.TextChoices):
"""
Ad variant type choices.
"""
COLOR = "Color", _("Color")
SIZE = "Size", _("Size")

View File

@@ -0,0 +1,12 @@
from django.utils.translation import gettext_lazy as _
from django.db import models
class OrderStatus(models.TextChoices):
"""
Order Status choices.
"""
PENDING = "Pending", _("Pending")
CANCEL = "Cancel", _("Cancel")
DONE = "Done", _("Done")

View File

View File

@@ -0,0 +1,34 @@
# Generated by Django 5.2.7 on 2025-11-22 11:39
from django.db import migrations, models
class Migration(migrations.Migration):
initial = True
dependencies = [
]
operations = [
migrations.CreateModel(
name='Banner',
fields=[
('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
('created_at', models.DateTimeField(auto_now_add=True)),
('updated_at', models.DateTimeField(auto_now=True)),
('title', models.CharField(max_length=255, verbose_name='Title')),
('description', models.TextField(verbose_name='Description')),
('mobile_image', models.ImageField(upload_to='banner/mobile_image/', verbose_name='Mobile Image')),
('desktop_image', models.ImageField(upload_to='banner/desktop_image/', verbose_name='Desktop Image')),
('link', models.URLField(verbose_name='Link')),
('bg_color', models.CharField(max_length=255, verbose_name='BG Color')),
('text_color', models.CharField(max_length=255, verbose_name='Text Color')),
],
options={
'verbose_name': 'Banner',
'verbose_name_plural': 'Banners',
'db_table': 'banner',
},
),
]

View File

@@ -0,0 +1,240 @@
# Generated by Django 5.2.7 on 2025-11-24 06:45
import django.db.models.deletion
from django.conf import settings
from django.db import migrations, models
class Migration(migrations.Migration):
dependencies = [
('accounts', '0004_business_searchhistory'),
('api', '0001_initial'),
migrations.swappable_dependency(settings.AUTH_USER_MODEL),
]
operations = [
migrations.CreateModel(
name='AdTopPlan',
fields=[
('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
('created_at', models.DateTimeField(auto_now_add=True)),
('updated_at', models.DateTimeField(auto_now=True)),
('name', models.CharField(max_length=255, verbose_name='Name')),
('price', models.DecimalField(decimal_places=2, max_digits=10, verbose_name='Price')),
('duration', models.IntegerField(verbose_name='Duration')),
],
options={
'verbose_name': 'AdTop Plan',
'verbose_name_plural': 'AdTop Plan',
'db_table': 'ad_top_plan',
},
),
migrations.CreateModel(
name='Color',
fields=[
('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
('created_at', models.DateTimeField(auto_now_add=True)),
('updated_at', models.DateTimeField(auto_now=True)),
('name', models.CharField(max_length=255, verbose_name='Name')),
],
options={
'verbose_name': 'Color',
'verbose_name_plural': 'Colors',
'db_table': 'color',
},
),
migrations.CreateModel(
name='Tags',
fields=[
('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
('created_at', models.DateTimeField(auto_now_add=True)),
('updated_at', models.DateTimeField(auto_now=True)),
('name', models.CharField(max_length=255, verbose_name='Name')),
],
options={
'verbose_name': 'Tags',
'verbose_name_plural': 'Tags',
'db_table': 'tags',
},
),
migrations.CreateModel(
name='AdModel',
fields=[
('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
('created_at', models.DateTimeField(auto_now_add=True)),
('updated_at', models.DateTimeField(auto_now=True)),
('name', models.CharField(max_length=255, verbose_name='Name')),
('ad_type', models.CharField(choices=[('Buy', 'Buy'), ('Sell', 'Sell')], max_length=255, verbose_name='Type')),
('ad_category_type', models.CharField(choices=[('Product', 'Product'), ('Service', 'Service'), ('Auto', 'Auto'), ('Home', 'Home')], max_length=255, verbose_name='Type')),
('price', models.DecimalField(blank=True, decimal_places=2, max_digits=10, null=True, verbose_name='Price')),
('is_available', models.BooleanField(blank=True, default=True, null=True, verbose_name='Is available')),
('physical_product', models.BooleanField(default=False, verbose_name='Physical product')),
('user', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, related_name='ad', to=settings.AUTH_USER_MODEL, verbose_name='User')),
('plan', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to='api.adtopplan', verbose_name='Plan')),
],
options={
'verbose_name': 'Ad',
'verbose_name_plural': 'Ads',
'db_table': 'ad',
},
),
migrations.CreateModel(
name='AdImage',
fields=[
('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
('created_at', models.DateTimeField(auto_now_add=True)),
('updated_at', models.DateTimeField(auto_now=True)),
('image', models.ImageField(upload_to='ads/images/', verbose_name='Image')),
('ad', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to='api.admodel', verbose_name='Ad')),
],
options={
'verbose_name': 'Ad_Image',
'verbose_name_plural': 'Ad_Images',
'db_table': 'ad_images',
},
),
migrations.CreateModel(
name='AdOption',
fields=[
('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
('created_at', models.DateTimeField(auto_now_add=True)),
('updated_at', models.DateTimeField(auto_now=True)),
('name', models.CharField(max_length=255, verbose_name='Name')),
('value', models.CharField(max_length=255, verbose_name='Value')),
('ad', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to='api.admodel')),
],
options={
'verbose_name': 'Ad_Option',
'verbose_name_plural': 'Ad_Options',
'db_table': 'ad_option',
},
),
migrations.CreateModel(
name='AdSize',
fields=[
('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
('created_at', models.DateTimeField(auto_now_add=True)),
('updated_at', models.DateTimeField(auto_now=True)),
('weight', models.PositiveIntegerField(verbose_name='Weight')),
('width', models.PositiveIntegerField(verbose_name='Width')),
('height', models.PositiveIntegerField(verbose_name='Height')),
('length', models.PositiveIntegerField(verbose_name='Length')),
('ad', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to='api.admodel')),
],
options={
'verbose_name': 'AdSize',
'verbose_name_plural': 'AdSizes',
'db_table': 'ad_size',
},
),
migrations.CreateModel(
name='AdVariant',
fields=[
('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
('created_at', models.DateTimeField(auto_now_add=True)),
('updated_at', models.DateTimeField(auto_now=True)),
('variant', models.CharField(choices=[('Color', 'Color'), ('Size', 'Size')], db_index=True, max_length=255)),
('value', models.CharField(max_length=255)),
('is_available', models.CharField(max_length=255)),
('price', models.DecimalField(decimal_places=2, max_digits=10)),
('discount', models.DecimalField(decimal_places=2, default=-1, max_digits=10)),
('ad', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to='api.admodel')),
],
options={
'verbose_name': 'Ad_Variant',
'verbose_name_plural': 'Ad_Variants',
'db_table': 'ad_variant',
},
),
migrations.CreateModel(
name='Category',
fields=[
('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
('created_at', models.DateTimeField(auto_now_add=True)),
('updated_at', models.DateTimeField(auto_now=True)),
('name', models.CharField(max_length=255, verbose_name='Category Name')),
('show_home', models.BooleanField(default=False, verbose_name='Show Home')),
('level', models.IntegerField(default=0, verbose_name='Level')),
('parent', models.ForeignKey(blank=True, null=True, on_delete=django.db.models.deletion.CASCADE, related_name='children', to='api.category')),
],
options={
'verbose_name': 'Category',
'verbose_name_plural': 'Categories',
'db_table': 'category',
},
),
migrations.AddField(
model_name='admodel',
name='category',
field=models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to='api.category', verbose_name='Category'),
),
migrations.CreateModel(
name='Feedback',
fields=[
('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
('created_at', models.DateTimeField(auto_now_add=True)),
('updated_at', models.DateTimeField(auto_now=True)),
('star', models.IntegerField(default=0, verbose_name='Star')),
('command', models.CharField(max_length=255, verbose_name='Command')),
('ad', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to='api.admodel', verbose_name='Ad')),
('user', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to=settings.AUTH_USER_MODEL, verbose_name='User')),
],
options={
'verbose_name': 'Feedback',
'verbose_name_plural': 'Feedbacks',
'db_table': 'feedback',
},
),
migrations.CreateModel(
name='FeedbackImages',
fields=[
('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
('created_at', models.DateTimeField(auto_now_add=True)),
('updated_at', models.DateTimeField(auto_now=True)),
('image', models.ImageField(upload_to='feedback/images/', verbose_name='Image')),
('feedback', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to='api.feedback', verbose_name='Feedback')),
],
options={
'verbose_name': 'Feedback Images',
'verbose_name_plural': 'Feedback Images',
'db_table': 'feedback_images',
},
),
migrations.CreateModel(
name='Order',
fields=[
('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
('created_at', models.DateTimeField(auto_now_add=True)),
('updated_at', models.DateTimeField(auto_now=True)),
('status', models.CharField(choices=[('Pending', 'Pending'), ('Cancel', 'Cancel'), ('Done', 'Done')], max_length=255)),
('address', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to='accounts.address', verbose_name='Address')),
('user', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to=settings.AUTH_USER_MODEL, verbose_name='User')),
],
options={
'verbose_name': 'Order',
'verbose_name_plural': 'Orders',
'db_table': 'order',
},
),
migrations.CreateModel(
name='OrderItem',
fields=[
('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
('price', models.DecimalField(decimal_places=2, max_digits=10, verbose_name='Price')),
('count', models.PositiveIntegerField(default=0, verbose_name='Count')),
('ad', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to='api.admodel', verbose_name='Ad')),
('order', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to='api.order', verbose_name='Order')),
],
options={
'verbose_name': 'Order Item',
'verbose_name_plural': 'Order Items',
'db_table': 'order_item',
},
),
migrations.AddField(
model_name='admodel',
name='tags',
field=models.ManyToManyField(to='api.tags', verbose_name='Tags'),
),
]

View File

View File

@@ -0,0 +1,5 @@
from .banner import * # noqa
from .feedback import * # noqa
from .ad import * # noqa
from .ad_items import * # noqa
from .order import * # noqa

View File

@@ -0,0 +1,2 @@
from .ad import * # noqa
from .category import * # noqa

View File

@@ -0,0 +1,38 @@
from django.db import models
from django_core.models.base import AbstractBaseModel
from django.utils.translation import gettext_lazy as _
from django.contrib.auth import get_user_model
from core.apps.api.choices.ad_type import AdType, AdCategoryType
class AdModel(AbstractBaseModel):
user = models.ForeignKey(get_user_model(), on_delete=models.CASCADE, verbose_name=_("User"), related_name="ad")
name = models.CharField(verbose_name=_("Name"), max_length=255)
ad_type = models.CharField(verbose_name=_("Type"), max_length=255, choices=AdType)
category = models.ForeignKey("api.Category", on_delete=models.CASCADE, verbose_name=_("Category"))
ad_category_type = models.CharField(verbose_name=_("Type"), max_length=255, choices=AdCategoryType)
price = models.DecimalField(verbose_name=_("Price"), max_digits=10, decimal_places=2, null=True, blank=True)
is_available = models.BooleanField(verbose_name=_("Is available"), default=True, blank=True, null=True)
physical_product = models.BooleanField(verbose_name=_("Physical product"), default=False)
plan = models.ForeignKey("api.AdTopPlan", on_delete=models.CASCADE, verbose_name=_("Plan"))
tags = models.ManyToManyField("api.Tags", verbose_name=_("Tags"))
def __str__(self):
return str(self.pk)
class Meta:
db_table = "ad"
verbose_name = _("Ad")
verbose_name_plural = _("Ads")
class Color(AbstractBaseModel):
name = models.CharField(verbose_name=_("Name"), max_length=255)
def __str__(self):
return str(self.pk)
class Meta:
db_table = "color"
verbose_name = _("Color")
verbose_name_plural = _("Colors")

View File

@@ -0,0 +1,18 @@
from django.db import models
from django_core.models.base import AbstractBaseModel
from django.utils.translation import gettext_lazy as _
class Category(AbstractBaseModel):
name = models.CharField(max_length=255, verbose_name=_('Category Name'))
parent = models.ForeignKey('self', null=True, blank=True, related_name='children', on_delete=models.CASCADE)
show_home = models.BooleanField(default=False, verbose_name=_('Show Home'))
level = models.IntegerField(default=0, verbose_name=_('Level'))
def __str__(self):
return str(self.pk)
class Meta:
db_table = 'category'
verbose_name = _('Category')
verbose_name_plural = _('Categories')

View File

@@ -0,0 +1,6 @@
from .ad_top_plan import * # noqa
from .tags import * # noqa
from .ad_images import * # noqa
from .ad_option import * # noqa
from .ad_size import * # noqa
from .ad_variant import * # noqa

View File

@@ -0,0 +1,17 @@
from django.db import models
from django_core.models.base import AbstractBaseModel
from django.utils.translation import gettext_lazy as _
from core.apps.api.models.ad.ad import AdModel
class AdImage(AbstractBaseModel):
image = models.ImageField(verbose_name=_("Image"), upload_to="ads/images/")
ad = models.ForeignKey(AdModel, verbose_name=_("Ad"), on_delete=models.CASCADE)
def __str__(self):
return str(self.pk)
class Meta:
db_table = "ad_images"
verbose_name = _("Ad_Image")
verbose_name_plural = _("Ad_Images")

View File

@@ -0,0 +1,18 @@
from django.db import models
from django_core.models.base import AbstractBaseModel
from django.utils.translation import gettext_lazy as _
from core.apps.api.models import AdModel
class AdOption(AbstractBaseModel):
name = models.CharField(_("Name"), max_length=255)
value = models.CharField(_("Value"), max_length=255)
ad = models.ForeignKey(AdModel, on_delete=models.CASCADE)
def __str__(self):
return str(self.pk)
class Meta:
db_table = "ad_option"
verbose_name = _("Ad_Option")
verbose_name_plural = _("Ad_Options")

View File

@@ -0,0 +1,20 @@
from django.db import models
from django_core.models.base import AbstractBaseModel
from django.utils.translation import gettext_lazy as _
from core.apps.api.models import AdModel
class AdSize(AbstractBaseModel):
ad = models.ForeignKey(AdModel, on_delete=models.CASCADE)
weight = models.PositiveIntegerField(verbose_name=_("Weight"))
width = models.PositiveIntegerField(verbose_name=_("Width"))
height = models.PositiveIntegerField(verbose_name=_("Height"))
length = models.PositiveIntegerField(verbose_name=_("Length"))
def __str__(self):
return str(self.pk)
class Meta:
db_table = "ad_size"
verbose_name = _("AdSize")
verbose_name_plural = _("AdSizes")

View File

@@ -0,0 +1,16 @@
from django.db import models
from django_core.models.base import AbstractBaseModel
from django.utils.translation import gettext_lazy as _
class AdTopPlan(AbstractBaseModel):
name = models.CharField(verbose_name=_('Name'), max_length=255)
price = models.DecimalField(verbose_name=_('Price'), max_digits=10, decimal_places=2)
duration = models.IntegerField(verbose_name=_('Duration'))
def __str__(self):
return str(self.pk)
class Meta:
db_table = 'ad_top_plan'
verbose_name = _('AdTop Plan')
verbose_name_plural = _('AdTop Plan')

View File

@@ -0,0 +1,22 @@
from django.db import models
from django_core.models.base import AbstractBaseModel
from django.utils.translation import gettext_lazy as _
from core.apps.api.models import AdModel
from core.apps.api.choices.ad_variant_type import AdVariantType
class AdVariant(AbstractBaseModel):
ad = models.ForeignKey(AdModel, on_delete=models.CASCADE)
variant = models.CharField(max_length=255, choices=AdVariantType, db_index=True)
value = models.CharField(max_length=255)
is_available = models.CharField(max_length=255)
price = models.DecimalField(max_digits=10, decimal_places=2)
discount = models.DecimalField(max_digits=10, decimal_places=2, default=-1)
def __str__(self):
return str(self.pk)
class Meta:
db_table = "ad_variant"
verbose_name = _("Ad_Variant")
verbose_name_plural = _("Ad_Variants")

View File

@@ -0,0 +1,15 @@
from django.db import models
from django_core.models.base import AbstractBaseModel
from django.utils.translation import gettext_lazy as _
class Tags(AbstractBaseModel):
name = models.CharField(verbose_name=_("Name"), max_length=255)
def __str__(self):
return str(self.pk)
class Meta:
db_table = 'tags'
verbose_name = _("Tags")
verbose_name_plural = _("Tags")

View File

@@ -0,0 +1 @@
from .banner import * # noqa

View File

@@ -0,0 +1,21 @@
from django.db import models
from django.utils.translation import gettext_lazy as _
from django_core.models.base import AbstractBaseModel
class Banner(AbstractBaseModel):
title = models.CharField(max_length=255, verbose_name=_("Title"))
description = models.TextField(verbose_name=_("Description"))
mobile_image = models.ImageField(verbose_name=_("Mobile Image"), upload_to="banner/mobile_image/")
desktop_image = models.ImageField(verbose_name=_("Desktop Image"), upload_to="banner/desktop_image/")
link = models.URLField(verbose_name=_("Link"))
bg_color = models.CharField(verbose_name=_("BG Color"), max_length=255)
text_color = models.CharField(verbose_name=_("Text Color"), max_length=255)
def __str__(self):
return str(self.pk)
class Meta:
db_table = "banner"
verbose_name = _("Banner")
verbose_name_plural = _("Banners")

View File

@@ -0,0 +1 @@
from .feedback import * # noqa

View File

@@ -0,0 +1,34 @@
from django.db import models
from django_core.models.base import AbstractBaseModel
from django.utils.translation import gettext_lazy as _
from django.contrib.auth import get_user_model
from core.apps.api.models.ad import AdModel
class Feedback(AbstractBaseModel):
star = models.IntegerField(default=0, verbose_name=_("Star"))
user = models.ForeignKey(get_user_model(), on_delete=models.CASCADE, verbose_name=_("User"))
ad = models.ForeignKey(AdModel, on_delete=models.CASCADE, verbose_name=_("Ad"))
command = models.CharField(max_length=255, verbose_name=_("Command"))
def __str__(self):
return str(self.pk)
class Meta:
db_table = "feedback"
verbose_name = _("Feedback")
verbose_name_plural = _("Feedbacks")
class FeedbackImages(AbstractBaseModel):
feedback = models.ForeignKey(Feedback, on_delete=models.CASCADE, verbose_name=_("Feedback"))
image = models.ImageField(verbose_name=_("Image"), upload_to="feedback/"
"images/")
def __str__(self):
return str(self.pk)
class Meta:
db_table = "feedback_images"
verbose_name = _("Feedback Images")
verbose_name_plural = _("Feedback Images")

View File

@@ -0,0 +1 @@
from .order import * # noqa

View File

@@ -0,0 +1,36 @@
from django.db import models
from django_core.models.base import AbstractBaseModel
from django.utils.translation import gettext_lazy as _
from django.contrib.auth import get_user_model
from core.apps.api.choices import OrderStatus
from core.apps.accounts.models import Address
from core.apps.api.models import AdModel
class Order(AbstractBaseModel):
user = models.ForeignKey(get_user_model(), on_delete=models.CASCADE, verbose_name=_("User"))
status = models.CharField(max_length=255, choices=OrderStatus)
address = models.ForeignKey(Address, on_delete=models.CASCADE, verbose_name=_("Address"))
def __str__(self):
return str(self.pk)
class Meta:
db_table = "order"
verbose_name = _("Order")
verbose_name_plural = _("Orders")
class OrderItem(models.Model):
order = models.ForeignKey(Order, on_delete=models.CASCADE, verbose_name=_("Order"))
price = models.DecimalField(max_digits=10, decimal_places=2, verbose_name=_("Price"))
ad = models.ForeignKey(AdModel, on_delete=models.CASCADE, verbose_name=_("Ad"))
count = models.PositiveIntegerField(default=0, verbose_name=_("Count"))
def __str__(self):
return str(self.pk)
class Meta:
db_table = "order_item"
verbose_name = _("Order Item")
verbose_name_plural = _("Order Items")

View File

View File

9
core/apps/api/urls.py Normal file
View File

@@ -0,0 +1,9 @@
from django.urls import path, include
from rest_framework.routers import DefaultRouter
router = DefaultRouter()
urlpatterns = [
path("", include(router.urls)),
]

View File