refactor all the things
This commit is contained in:
parent
8ed39690f1
commit
bb5cb708bd
36 changed files with 1563 additions and 931 deletions
|
@ -1,9 +1,43 @@
|
|||
# Generated by Django 5.1.5 on 2025-01-27 12:25
|
||||
# Generated by Django 5.1.5 on 2025-01-29 08:34
|
||||
|
||||
import django.db.models.deletion
|
||||
import services.models
|
||||
from django.db import migrations, models
|
||||
|
||||
|
||||
def create_initial_currencies(apps, schema_editor):
|
||||
Currency = apps.get_model("services", "Currency")
|
||||
currencies = [
|
||||
{"code": "USD", "name": "US Dollar", "symbol": "$"},
|
||||
{"code": "CHF", "name": "Swiss Franc", "symbol": "CHF"},
|
||||
{"code": "EUR", "name": "Euro", "symbol": "€"},
|
||||
]
|
||||
for currency_data in currencies:
|
||||
Currency.objects.create(**currency_data)
|
||||
|
||||
|
||||
def create_initial_terms(apps, schema_editor):
|
||||
Term = apps.get_model("services", "Term")
|
||||
terms = [
|
||||
{"name": "Monthly (30d)", "order": 1},
|
||||
{"name": "Yearly", "order": 2},
|
||||
{"name": "One-time", "order": 3},
|
||||
]
|
||||
for term_data in terms:
|
||||
Term.objects.create(**term_data)
|
||||
|
||||
|
||||
def create_initial_categories(apps, schema_editor):
|
||||
Category = apps.get_model("services", "Category")
|
||||
categories = [
|
||||
{"name": "Database", "slug": "database", "order": 1},
|
||||
{"name": "Cache", "slug": "cache", "order": 2},
|
||||
{"name": "SaaS", "slug": "saas", "order": 3},
|
||||
]
|
||||
for category_data in categories:
|
||||
Category.objects.create(**category_data)
|
||||
|
||||
|
||||
class Migration(migrations.Migration):
|
||||
|
||||
initial = True
|
||||
|
@ -24,11 +58,22 @@ class Migration(migrations.Migration):
|
|||
),
|
||||
),
|
||||
("name", models.CharField(max_length=100)),
|
||||
("description", models.TextField(blank=True)),
|
||||
("slug", models.SlugField(unique=True)),
|
||||
("description", models.TextField()),
|
||||
("website", models.URLField()),
|
||||
(
|
||||
"logo",
|
||||
models.ImageField(
|
||||
blank=True,
|
||||
null=True,
|
||||
upload_to="cloud_provider_logos/",
|
||||
validators=[services.models.validate_image_size],
|
||||
),
|
||||
),
|
||||
],
|
||||
),
|
||||
migrations.CreateModel(
|
||||
name="Country",
|
||||
name="Currency",
|
||||
fields=[
|
||||
(
|
||||
"id",
|
||||
|
@ -39,15 +84,17 @@ class Migration(migrations.Migration):
|
|||
verbose_name="ID",
|
||||
),
|
||||
),
|
||||
("name", models.CharField(max_length=100)),
|
||||
("code", models.CharField(max_length=2)),
|
||||
("code", models.CharField(max_length=3, unique=True)),
|
||||
("name", models.CharField(max_length=50)),
|
||||
("symbol", models.CharField(max_length=5)),
|
||||
],
|
||||
options={
|
||||
"verbose_name_plural": "Countries",
|
||||
"verbose_name_plural": "Currencies",
|
||||
"ordering": ["code"],
|
||||
},
|
||||
),
|
||||
migrations.CreateModel(
|
||||
name="ServiceLevel",
|
||||
name="Plan",
|
||||
fields=[
|
||||
(
|
||||
"id",
|
||||
|
@ -60,8 +107,67 @@ class Migration(migrations.Migration):
|
|||
),
|
||||
("name", models.CharField(max_length=100)),
|
||||
("description", models.TextField()),
|
||||
("response_time", models.CharField(max_length=50)),
|
||||
("is_default", models.BooleanField(default=False)),
|
||||
("features", models.TextField(blank=True)),
|
||||
("order", models.IntegerField(default=0)),
|
||||
("created_at", models.DateTimeField(auto_now_add=True)),
|
||||
("updated_at", models.DateTimeField(auto_now=True)),
|
||||
],
|
||||
options={
|
||||
"ordering": ["order", "name"],
|
||||
},
|
||||
),
|
||||
migrations.CreateModel(
|
||||
name="Term",
|
||||
fields=[
|
||||
(
|
||||
"id",
|
||||
models.BigAutoField(
|
||||
auto_created=True,
|
||||
primary_key=True,
|
||||
serialize=False,
|
||||
verbose_name="ID",
|
||||
),
|
||||
),
|
||||
("name", models.CharField(max_length=100)),
|
||||
("description", models.TextField(blank=True)),
|
||||
("order", models.IntegerField(default=0)),
|
||||
],
|
||||
options={
|
||||
"ordering": ["order", "name"],
|
||||
},
|
||||
),
|
||||
migrations.CreateModel(
|
||||
name="Category",
|
||||
fields=[
|
||||
(
|
||||
"id",
|
||||
models.BigAutoField(
|
||||
auto_created=True,
|
||||
primary_key=True,
|
||||
serialize=False,
|
||||
verbose_name="ID",
|
||||
),
|
||||
),
|
||||
("name", models.CharField(max_length=100)),
|
||||
("slug", models.SlugField(unique=True)),
|
||||
("description", models.TextField(blank=True)),
|
||||
("order", models.IntegerField(default=0)),
|
||||
(
|
||||
"parent",
|
||||
models.ForeignKey(
|
||||
blank=True,
|
||||
null=True,
|
||||
on_delete=django.db.models.deletion.CASCADE,
|
||||
related_name="children",
|
||||
to="services.category",
|
||||
),
|
||||
),
|
||||
],
|
||||
options={
|
||||
"verbose_name_plural": "Categories",
|
||||
"ordering": ["order", "name"],
|
||||
},
|
||||
),
|
||||
migrations.CreateModel(
|
||||
name="Service",
|
||||
|
@ -76,26 +182,235 @@ class Migration(migrations.Migration):
|
|||
),
|
||||
),
|
||||
("name", models.CharField(max_length=200)),
|
||||
("slug", models.SlugField(max_length=250, unique=True)),
|
||||
("description", models.TextField()),
|
||||
("price", models.DecimalField(decimal_places=2, max_digits=10)),
|
||||
(
|
||||
"logo",
|
||||
models.ImageField(
|
||||
blank=True,
|
||||
null=True,
|
||||
upload_to="service_logos/",
|
||||
validators=[services.models.validate_image_size],
|
||||
),
|
||||
),
|
||||
("features", models.TextField()),
|
||||
("created_at", models.DateTimeField(auto_now_add=True)),
|
||||
("updated_at", models.DateTimeField(auto_now=True)),
|
||||
(
|
||||
"categories",
|
||||
models.ManyToManyField(
|
||||
related_name="services", to="services.category"
|
||||
),
|
||||
),
|
||||
],
|
||||
),
|
||||
migrations.CreateModel(
|
||||
name="Lead",
|
||||
fields=[
|
||||
(
|
||||
"id",
|
||||
models.BigAutoField(
|
||||
auto_created=True,
|
||||
primary_key=True,
|
||||
serialize=False,
|
||||
verbose_name="ID",
|
||||
),
|
||||
),
|
||||
("name", models.CharField(max_length=200)),
|
||||
("company", models.CharField(max_length=200)),
|
||||
("email", models.EmailField(max_length=254)),
|
||||
("phone", models.CharField(max_length=50)),
|
||||
("created_at", models.DateTimeField(auto_now_add=True)),
|
||||
("odoo_lead_id", models.IntegerField(blank=True, null=True)),
|
||||
(
|
||||
"plan",
|
||||
models.ForeignKey(
|
||||
blank=True,
|
||||
null=True,
|
||||
on_delete=django.db.models.deletion.SET_NULL,
|
||||
to="services.plan",
|
||||
),
|
||||
),
|
||||
(
|
||||
"service",
|
||||
models.ForeignKey(
|
||||
on_delete=django.db.models.deletion.CASCADE,
|
||||
to="services.service",
|
||||
),
|
||||
),
|
||||
],
|
||||
),
|
||||
migrations.CreateModel(
|
||||
name="ExternalLink",
|
||||
fields=[
|
||||
(
|
||||
"id",
|
||||
models.BigAutoField(
|
||||
auto_created=True,
|
||||
primary_key=True,
|
||||
serialize=False,
|
||||
verbose_name="ID",
|
||||
),
|
||||
),
|
||||
("url", models.URLField()),
|
||||
("description", models.CharField(max_length=200)),
|
||||
("order", models.IntegerField(default=0)),
|
||||
("created_at", models.DateTimeField(auto_now_add=True)),
|
||||
("updated_at", models.DateTimeField(auto_now=True)),
|
||||
(
|
||||
"service",
|
||||
models.ForeignKey(
|
||||
on_delete=django.db.models.deletion.CASCADE,
|
||||
related_name="external_links",
|
||||
to="services.service",
|
||||
),
|
||||
),
|
||||
],
|
||||
options={
|
||||
"verbose_name": "External Link",
|
||||
"verbose_name_plural": "External Links",
|
||||
"ordering": ["order", "description"],
|
||||
},
|
||||
),
|
||||
migrations.CreateModel(
|
||||
name="ConsultingPartner",
|
||||
fields=[
|
||||
(
|
||||
"id",
|
||||
models.BigAutoField(
|
||||
auto_created=True,
|
||||
primary_key=True,
|
||||
serialize=False,
|
||||
verbose_name="ID",
|
||||
),
|
||||
),
|
||||
("name", models.CharField(max_length=200)),
|
||||
("slug", models.SlugField(unique=True)),
|
||||
("description", models.TextField()),
|
||||
(
|
||||
"logo",
|
||||
models.ImageField(
|
||||
blank=True,
|
||||
null=True,
|
||||
upload_to="partner_logos/",
|
||||
validators=[services.models.validate_image_size],
|
||||
),
|
||||
),
|
||||
("website", models.URLField(blank=True)),
|
||||
("created_at", models.DateTimeField(auto_now_add=True)),
|
||||
("updated_at", models.DateTimeField(auto_now=True)),
|
||||
(
|
||||
"cloud_providers",
|
||||
models.ManyToManyField(
|
||||
blank=True,
|
||||
related_name="consulting_partners",
|
||||
to="services.cloudprovider",
|
||||
),
|
||||
),
|
||||
(
|
||||
"services",
|
||||
models.ManyToManyField(
|
||||
related_name="consulting_partners", to="services.service"
|
||||
),
|
||||
),
|
||||
],
|
||||
),
|
||||
migrations.CreateModel(
|
||||
name="ServiceOffering",
|
||||
fields=[
|
||||
(
|
||||
"id",
|
||||
models.BigAutoField(
|
||||
auto_created=True,
|
||||
primary_key=True,
|
||||
serialize=False,
|
||||
verbose_name="ID",
|
||||
),
|
||||
),
|
||||
("slug", models.SlugField(max_length=250, unique=True)),
|
||||
(
|
||||
"description",
|
||||
models.TextField(
|
||||
help_text="Provider-specific details and features"
|
||||
),
|
||||
),
|
||||
("created_at", models.DateTimeField(auto_now_add=True)),
|
||||
("updated_at", models.DateTimeField(auto_now=True)),
|
||||
(
|
||||
"cloud_provider",
|
||||
models.ForeignKey(
|
||||
on_delete=django.db.models.deletion.CASCADE,
|
||||
related_name="offerings",
|
||||
to="services.cloudprovider",
|
||||
),
|
||||
),
|
||||
("countries", models.ManyToManyField(to="services.country")),
|
||||
(
|
||||
"service_level",
|
||||
"service",
|
||||
models.ForeignKey(
|
||||
on_delete=django.db.models.deletion.CASCADE,
|
||||
to="services.servicelevel",
|
||||
related_name="offerings",
|
||||
to="services.service",
|
||||
),
|
||||
),
|
||||
],
|
||||
options={
|
||||
"ordering": ["service__name", "cloud_provider__name"],
|
||||
"unique_together": {("service", "cloud_provider")},
|
||||
},
|
||||
),
|
||||
migrations.AddField(
|
||||
model_name="plan",
|
||||
name="offering",
|
||||
field=models.ForeignKey(
|
||||
on_delete=django.db.models.deletion.CASCADE,
|
||||
related_name="plans",
|
||||
to="services.serviceoffering",
|
||||
),
|
||||
),
|
||||
migrations.AlterUniqueTogether(
|
||||
name="plan",
|
||||
unique_together={("offering", "name")},
|
||||
),
|
||||
migrations.CreateModel(
|
||||
name="PlanPrice",
|
||||
fields=[
|
||||
(
|
||||
"id",
|
||||
models.BigAutoField(
|
||||
auto_created=True,
|
||||
primary_key=True,
|
||||
serialize=False,
|
||||
verbose_name="ID",
|
||||
),
|
||||
),
|
||||
("price", models.DecimalField(decimal_places=2, max_digits=10)),
|
||||
(
|
||||
"currency",
|
||||
models.ForeignKey(
|
||||
on_delete=django.db.models.deletion.PROTECT,
|
||||
to="services.currency",
|
||||
),
|
||||
),
|
||||
(
|
||||
"plan",
|
||||
models.ForeignKey(
|
||||
on_delete=django.db.models.deletion.CASCADE,
|
||||
related_name="prices",
|
||||
to="services.plan",
|
||||
),
|
||||
),
|
||||
(
|
||||
"term",
|
||||
models.ForeignKey(
|
||||
on_delete=django.db.models.deletion.PROTECT, to="services.term"
|
||||
),
|
||||
),
|
||||
],
|
||||
options={
|
||||
"unique_together": {("plan", "currency", "term")},
|
||||
},
|
||||
),
|
||||
migrations.RunPython(create_initial_currencies),
|
||||
migrations.RunPython(create_initial_terms),
|
||||
migrations.RunPython(create_initial_categories),
|
||||
]
|
||||
|
|
|
@ -1,34 +0,0 @@
|
|||
# Generated by Django 5.1.5 on 2025-01-27 14:10
|
||||
|
||||
import services.models
|
||||
from django.db import migrations, models
|
||||
|
||||
|
||||
class Migration(migrations.Migration):
|
||||
|
||||
dependencies = [
|
||||
("services", "0001_initial"),
|
||||
]
|
||||
|
||||
operations = [
|
||||
migrations.AddField(
|
||||
model_name="cloudprovider",
|
||||
name="logo",
|
||||
field=models.ImageField(
|
||||
blank=True,
|
||||
null=True,
|
||||
upload_to="cloud_provider_logos/",
|
||||
validators=[services.models.validate_image_size],
|
||||
),
|
||||
),
|
||||
migrations.AddField(
|
||||
model_name="service",
|
||||
name="logo",
|
||||
field=models.ImageField(
|
||||
blank=True,
|
||||
null=True,
|
||||
upload_to="service_logos/",
|
||||
validators=[services.models.validate_image_size],
|
||||
),
|
||||
),
|
||||
]
|
|
@ -1,4 +1,4 @@
|
|||
# Generated by Django 5.1.5 on 2025-01-28 09:48
|
||||
# Generated by Django 5.1.5 on 2025-01-29 16:11
|
||||
|
||||
import django.db.models.deletion
|
||||
from django.db import migrations, models
|
||||
|
@ -7,18 +7,18 @@ from django.db import migrations, models
|
|||
class Migration(migrations.Migration):
|
||||
|
||||
dependencies = [
|
||||
("services", "0010_remove_service_price"),
|
||||
("services", "0001_initial"),
|
||||
]
|
||||
|
||||
operations = [
|
||||
migrations.AddField(
|
||||
model_name="lead",
|
||||
name="plan",
|
||||
name="offering",
|
||||
field=models.ForeignKey(
|
||||
blank=True,
|
||||
null=True,
|
||||
on_delete=django.db.models.deletion.SET_NULL,
|
||||
to="services.plan",
|
||||
to="services.serviceoffering",
|
||||
),
|
||||
),
|
||||
]
|
|
@ -1,53 +0,0 @@
|
|||
# Generated by Django 5.1.5 on 2025-01-27 14:19
|
||||
|
||||
import django.db.models.deletion
|
||||
from django.db import migrations, models
|
||||
|
||||
|
||||
class Migration(migrations.Migration):
|
||||
|
||||
dependencies = [
|
||||
("services", "0002_cloudprovider_logo_service_logo"),
|
||||
]
|
||||
|
||||
operations = [
|
||||
migrations.CreateModel(
|
||||
name="Category",
|
||||
fields=[
|
||||
(
|
||||
"id",
|
||||
models.BigAutoField(
|
||||
auto_created=True,
|
||||
primary_key=True,
|
||||
serialize=False,
|
||||
verbose_name="ID",
|
||||
),
|
||||
),
|
||||
("name", models.CharField(max_length=100)),
|
||||
("slug", models.SlugField(unique=True)),
|
||||
("description", models.TextField(blank=True)),
|
||||
("order", models.IntegerField(default=0)),
|
||||
(
|
||||
"parent",
|
||||
models.ForeignKey(
|
||||
blank=True,
|
||||
null=True,
|
||||
on_delete=django.db.models.deletion.CASCADE,
|
||||
related_name="children",
|
||||
to="services.category",
|
||||
),
|
||||
),
|
||||
],
|
||||
options={
|
||||
"verbose_name_plural": "Categories",
|
||||
"ordering": ["order", "name"],
|
||||
},
|
||||
),
|
||||
migrations.AddField(
|
||||
model_name="service",
|
||||
name="categories",
|
||||
field=models.ManyToManyField(
|
||||
related_name="services", to="services.category"
|
||||
),
|
||||
),
|
||||
]
|
|
@ -1,40 +0,0 @@
|
|||
# Generated by Django 5.1.5 on 2025-01-27 14:49
|
||||
|
||||
from django.db import migrations, models
|
||||
from django.utils.text import slugify
|
||||
|
||||
|
||||
def generate_provider_slugs(apps, schema_editor):
|
||||
CloudProvider = apps.get_model("services", "CloudProvider")
|
||||
for provider in CloudProvider.objects.all():
|
||||
provider.slug = slugify(provider.name)
|
||||
counter = 1
|
||||
while CloudProvider.objects.filter(slug=provider.slug).exists():
|
||||
provider.slug = f"{slugify(provider.name)}-{counter}"
|
||||
counter += 1
|
||||
provider.save()
|
||||
|
||||
|
||||
class Migration(migrations.Migration):
|
||||
|
||||
dependencies = [
|
||||
("services", "0003_category_service_categories"),
|
||||
]
|
||||
|
||||
operations = [
|
||||
migrations.AddField(
|
||||
model_name="cloudprovider",
|
||||
name="slug",
|
||||
field=models.SlugField(unique=True, null=True),
|
||||
preserve_default=False,
|
||||
),
|
||||
migrations.RunPython(
|
||||
generate_provider_slugs, reverse_code=migrations.RunPython.noop
|
||||
),
|
||||
migrations.AlterField(
|
||||
model_name="cloudprovider",
|
||||
name="slug",
|
||||
field=models.SlugField(unique=True),
|
||||
preserve_default=False,
|
||||
),
|
||||
]
|
|
@ -1,41 +0,0 @@
|
|||
# Generated by Django 5.1.5 on 2025-01-27 15:21
|
||||
|
||||
import django.db.models.deletion
|
||||
from django.db import migrations, models
|
||||
|
||||
|
||||
class Migration(migrations.Migration):
|
||||
|
||||
dependencies = [
|
||||
("services", "0004_cloudprovider_slug"),
|
||||
]
|
||||
|
||||
operations = [
|
||||
migrations.CreateModel(
|
||||
name="Lead",
|
||||
fields=[
|
||||
(
|
||||
"id",
|
||||
models.BigAutoField(
|
||||
auto_created=True,
|
||||
primary_key=True,
|
||||
serialize=False,
|
||||
verbose_name="ID",
|
||||
),
|
||||
),
|
||||
("name", models.CharField(max_length=200)),
|
||||
("company", models.CharField(max_length=200)),
|
||||
("email", models.EmailField(max_length=254)),
|
||||
("phone", models.CharField(max_length=50)),
|
||||
("created_at", models.DateTimeField(auto_now_add=True)),
|
||||
("odoo_lead_id", models.IntegerField(blank=True, null=True)),
|
||||
(
|
||||
"service",
|
||||
models.ForeignKey(
|
||||
on_delete=django.db.models.deletion.CASCADE,
|
||||
to="services.service",
|
||||
),
|
||||
),
|
||||
],
|
||||
),
|
||||
]
|
|
@ -1,44 +0,0 @@
|
|||
# Generated by Django 5.1.5 on 2025-01-27 15:57
|
||||
|
||||
from django.db import migrations, models
|
||||
from django.utils.text import slugify
|
||||
|
||||
|
||||
def generate_service_slugs(apps, schema_editor):
|
||||
Service = apps.get_model("services", "Service")
|
||||
|
||||
for service in Service.objects.all():
|
||||
base_slug = f"{service.name}-{service.cloud_provider.name}"
|
||||
slug = slugify(base_slug)
|
||||
|
||||
counter = 1
|
||||
while Service.objects.filter(slug=slug).exists():
|
||||
slug = f"{slugify(base_slug)}-{counter}"
|
||||
counter += 1
|
||||
|
||||
service.slug = slug
|
||||
service.save()
|
||||
|
||||
|
||||
class Migration(migrations.Migration):
|
||||
|
||||
dependencies = [
|
||||
("services", "0005_lead"),
|
||||
]
|
||||
|
||||
operations = [
|
||||
migrations.AddField(
|
||||
model_name="service",
|
||||
name="slug",
|
||||
field=models.SlugField(max_length=250, blank=True),
|
||||
preserve_default=False,
|
||||
),
|
||||
migrations.RunPython(
|
||||
generate_service_slugs, reverse_code=migrations.RunPython.noop
|
||||
),
|
||||
migrations.AlterField(
|
||||
model_name="service",
|
||||
name="slug",
|
||||
field=models.SlugField(max_length=250, unique=True),
|
||||
),
|
||||
]
|
|
@ -1,50 +0,0 @@
|
|||
# Generated by Django 5.1.5 on 2025-01-28 07:49
|
||||
|
||||
import services.models
|
||||
from django.db import migrations, models
|
||||
|
||||
|
||||
class Migration(migrations.Migration):
|
||||
|
||||
dependencies = [
|
||||
("services", "0006_service_slug"),
|
||||
]
|
||||
|
||||
operations = [
|
||||
migrations.CreateModel(
|
||||
name="ConsultingPartner",
|
||||
fields=[
|
||||
(
|
||||
"id",
|
||||
models.BigAutoField(
|
||||
auto_created=True,
|
||||
primary_key=True,
|
||||
serialize=False,
|
||||
verbose_name="ID",
|
||||
),
|
||||
),
|
||||
("name", models.CharField(max_length=200)),
|
||||
("slug", models.SlugField(unique=True)),
|
||||
("description", models.TextField(blank=True)),
|
||||
(
|
||||
"logo",
|
||||
models.ImageField(
|
||||
blank=True,
|
||||
null=True,
|
||||
upload_to="partner_logos/",
|
||||
validators=[services.models.validate_image_size],
|
||||
),
|
||||
),
|
||||
("website", models.URLField(blank=True)),
|
||||
("created_at", models.DateTimeField(auto_now_add=True)),
|
||||
("updated_at", models.DateTimeField(auto_now=True)),
|
||||
],
|
||||
),
|
||||
migrations.AddField(
|
||||
model_name="service",
|
||||
name="consulting_partners",
|
||||
field=models.ManyToManyField(
|
||||
blank=True, related_name="services", to="services.consultingpartner"
|
||||
),
|
||||
),
|
||||
]
|
|
@ -1,27 +0,0 @@
|
|||
# Generated by Django 5.1.5 on 2025-01-28 09:03
|
||||
|
||||
from django.db import migrations
|
||||
|
||||
|
||||
class Migration(migrations.Migration):
|
||||
|
||||
dependencies = [
|
||||
("services", "0007_consultingpartner_service_consulting_partners"),
|
||||
]
|
||||
|
||||
operations = [
|
||||
migrations.RemoveField(
|
||||
model_name="service",
|
||||
name="countries",
|
||||
),
|
||||
migrations.RemoveField(
|
||||
model_name="service",
|
||||
name="service_level",
|
||||
),
|
||||
migrations.DeleteModel(
|
||||
name="Country",
|
||||
),
|
||||
migrations.DeleteModel(
|
||||
name="ServiceLevel",
|
||||
),
|
||||
]
|
|
@ -1,118 +0,0 @@
|
|||
# Generated by Django 5.1.5 on 2025-01-28 09:19
|
||||
|
||||
import django.db.models.deletion
|
||||
from django.db import migrations, models
|
||||
|
||||
|
||||
def create_initial_currencies(apps, schema_editor):
|
||||
Currency = apps.get_model("services", "Currency")
|
||||
currencies = [
|
||||
{"code": "USD", "name": "US Dollar", "symbol": "$"},
|
||||
{"code": "CHF", "name": "Swiss Franc", "symbol": "CHF"},
|
||||
{"code": "EUR", "name": "Euro", "symbol": "€"},
|
||||
]
|
||||
for currency_data in currencies:
|
||||
Currency.objects.create(**currency_data)
|
||||
|
||||
|
||||
def remove_initial_currencies(apps, schema_editor):
|
||||
Currency = apps.get_model("services", "Currency")
|
||||
Currency.objects.all().delete()
|
||||
|
||||
|
||||
class Migration(migrations.Migration):
|
||||
|
||||
dependencies = [
|
||||
("services", "0008_remove_service_countries_and_more"),
|
||||
]
|
||||
|
||||
operations = [
|
||||
migrations.CreateModel(
|
||||
name="Currency",
|
||||
fields=[
|
||||
(
|
||||
"id",
|
||||
models.BigAutoField(
|
||||
auto_created=True,
|
||||
primary_key=True,
|
||||
serialize=False,
|
||||
verbose_name="ID",
|
||||
),
|
||||
),
|
||||
("code", models.CharField(max_length=3, unique=True)),
|
||||
("name", models.CharField(max_length=50)),
|
||||
("symbol", models.CharField(max_length=5)),
|
||||
],
|
||||
options={
|
||||
"verbose_name_plural": "Currencies",
|
||||
"ordering": ["code"],
|
||||
},
|
||||
),
|
||||
migrations.CreateModel(
|
||||
name="Plan",
|
||||
fields=[
|
||||
(
|
||||
"id",
|
||||
models.BigAutoField(
|
||||
auto_created=True,
|
||||
primary_key=True,
|
||||
serialize=False,
|
||||
verbose_name="ID",
|
||||
),
|
||||
),
|
||||
("name", models.CharField(max_length=100)),
|
||||
("description", models.TextField()),
|
||||
("is_default", models.BooleanField(default=False)),
|
||||
("features", models.TextField(blank=True)),
|
||||
("order", models.IntegerField(default=0)),
|
||||
("created_at", models.DateTimeField(auto_now_add=True)),
|
||||
("updated_at", models.DateTimeField(auto_now=True)),
|
||||
(
|
||||
"service",
|
||||
models.ForeignKey(
|
||||
on_delete=django.db.models.deletion.CASCADE,
|
||||
related_name="plans",
|
||||
to="services.service",
|
||||
),
|
||||
),
|
||||
],
|
||||
options={
|
||||
"ordering": ["order", "name"],
|
||||
"unique_together": {("service", "name")},
|
||||
},
|
||||
),
|
||||
migrations.CreateModel(
|
||||
name="PlanPrice",
|
||||
fields=[
|
||||
(
|
||||
"id",
|
||||
models.BigAutoField(
|
||||
auto_created=True,
|
||||
primary_key=True,
|
||||
serialize=False,
|
||||
verbose_name="ID",
|
||||
),
|
||||
),
|
||||
("price", models.DecimalField(decimal_places=2, max_digits=10)),
|
||||
(
|
||||
"currency",
|
||||
models.ForeignKey(
|
||||
on_delete=django.db.models.deletion.PROTECT,
|
||||
to="services.currency",
|
||||
),
|
||||
),
|
||||
(
|
||||
"plan",
|
||||
models.ForeignKey(
|
||||
on_delete=django.db.models.deletion.CASCADE,
|
||||
related_name="prices",
|
||||
to="services.plan",
|
||||
),
|
||||
),
|
||||
],
|
||||
options={
|
||||
"unique_together": {("plan", "currency")},
|
||||
},
|
||||
),
|
||||
migrations.RunPython(create_initial_currencies, remove_initial_currencies),
|
||||
]
|
|
@ -1,17 +0,0 @@
|
|||
# Generated by Django 5.1.5 on 2025-01-28 09:28
|
||||
|
||||
from django.db import migrations
|
||||
|
||||
|
||||
class Migration(migrations.Migration):
|
||||
|
||||
dependencies = [
|
||||
("services", "0009_currency_plan_planprice"),
|
||||
]
|
||||
|
||||
operations = [
|
||||
migrations.RemoveField(
|
||||
model_name="service",
|
||||
name="price",
|
||||
),
|
||||
]
|
|
@ -1,46 +0,0 @@
|
|||
# Generated by Django 5.1.5 on 2025-01-28 09:58
|
||||
|
||||
import django.db.models.deletion
|
||||
from django.db import migrations, models
|
||||
|
||||
|
||||
class Migration(migrations.Migration):
|
||||
|
||||
dependencies = [
|
||||
("services", "0011_lead_plan"),
|
||||
]
|
||||
|
||||
operations = [
|
||||
migrations.CreateModel(
|
||||
name="ExternalLink",
|
||||
fields=[
|
||||
(
|
||||
"id",
|
||||
models.BigAutoField(
|
||||
auto_created=True,
|
||||
primary_key=True,
|
||||
serialize=False,
|
||||
verbose_name="ID",
|
||||
),
|
||||
),
|
||||
("url", models.URLField()),
|
||||
("description", models.CharField(max_length=200)),
|
||||
("order", models.IntegerField(default=0)),
|
||||
("created_at", models.DateTimeField(auto_now_add=True)),
|
||||
("updated_at", models.DateTimeField(auto_now=True)),
|
||||
(
|
||||
"service",
|
||||
models.ForeignKey(
|
||||
on_delete=django.db.models.deletion.CASCADE,
|
||||
related_name="external_links",
|
||||
to="services.service",
|
||||
),
|
||||
),
|
||||
],
|
||||
options={
|
||||
"verbose_name": "External Link",
|
||||
"verbose_name_plural": "External Links",
|
||||
"ordering": ["order", "description"],
|
||||
},
|
||||
),
|
||||
]
|
Loading…
Add table
Add a link
Reference in a new issue