369 lines
		
	
	
	
		
			32 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			369 lines
		
	
	
	
		
			32 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
# Generated by Django 5.2.4 on 2025-09-07 07:35
 | 
						||
 | 
						||
import django.db.models.deletion
 | 
						||
import simple_history.models
 | 
						||
from django.conf import settings
 | 
						||
from django.db import migrations, models
 | 
						||
 | 
						||
 | 
						||
class Migration(migrations.Migration):
 | 
						||
 | 
						||
    initial = True
 | 
						||
 | 
						||
    dependencies = [
 | 
						||
        ('processes', '0001_initial'),
 | 
						||
        migrations.swappable_dependency(settings.AUTH_USER_MODEL),
 | 
						||
    ]
 | 
						||
 | 
						||
    operations = [
 | 
						||
        migrations.CreateModel(
 | 
						||
            name='HistoricalItem',
 | 
						||
            fields=[
 | 
						||
                ('id', models.BigIntegerField(auto_created=True, blank=True, db_index=True, verbose_name='ID')),
 | 
						||
                ('created', models.DateTimeField(blank=True, editable=False, verbose_name='تاریخ ایجاد')),
 | 
						||
                ('updated', models.DateTimeField(blank=True, editable=False, verbose_name='تاریخ بروزرسانی')),
 | 
						||
                ('is_active', models.BooleanField(default=True, verbose_name='فعال')),
 | 
						||
                ('is_deleted', models.BooleanField(default=False, verbose_name='حذف شده')),
 | 
						||
                ('deleted_at', models.DateTimeField(blank=True, null=True, verbose_name='تاریخ حذف')),
 | 
						||
                ('slug', models.SlugField(max_length=100, verbose_name='اسلاگ')),
 | 
						||
                ('name', models.CharField(max_length=100, verbose_name='نام')),
 | 
						||
                ('description', models.TextField(blank=True, verbose_name='توضیحات')),
 | 
						||
                ('unit_price', models.DecimalField(decimal_places=2, max_digits=15, verbose_name='قیمت واحد')),
 | 
						||
                ('is_special', models.BooleanField(default=False, verbose_name='ویژه برای فاکتور نهایی')),
 | 
						||
                ('default_quantity', models.PositiveIntegerField(default=1, verbose_name='تعداد پیش\u200cفرض')),
 | 
						||
                ('is_default_in_quotes', models.BooleanField(default=False, help_text='این آیتم به صورت پیش\u200cفرض در همه پیش\u200cفاکتورها قرار می\u200cگیرد', verbose_name='پیش\u200cفرض در پیش\u200cفاکتورها')),
 | 
						||
                ('history_id', models.AutoField(primary_key=True, serialize=False)),
 | 
						||
                ('history_date', models.DateTimeField(db_index=True)),
 | 
						||
                ('history_change_reason', models.CharField(max_length=100, null=True)),
 | 
						||
                ('history_type', models.CharField(choices=[('+', 'Created'), ('~', 'Changed'), ('-', 'Deleted')], max_length=1)),
 | 
						||
                ('created_by', models.ForeignKey(blank=True, db_constraint=False, null=True, on_delete=django.db.models.deletion.DO_NOTHING, related_name='+', to=settings.AUTH_USER_MODEL, verbose_name='ایجاد کننده')),
 | 
						||
                ('history_user', models.ForeignKey(null=True, on_delete=django.db.models.deletion.SET_NULL, related_name='+', to=settings.AUTH_USER_MODEL)),
 | 
						||
            ],
 | 
						||
            options={
 | 
						||
                'verbose_name': 'historical آیتم',
 | 
						||
                'verbose_name_plural': 'historical آیتم\u200cها',
 | 
						||
                'ordering': ('-history_date', '-history_id'),
 | 
						||
                'get_latest_by': ('history_date', 'history_id'),
 | 
						||
            },
 | 
						||
            bases=(simple_history.models.HistoricalChanges, models.Model),
 | 
						||
        ),
 | 
						||
        migrations.CreateModel(
 | 
						||
            name='HistoricalQuote',
 | 
						||
            fields=[
 | 
						||
                ('id', models.BigIntegerField(auto_created=True, blank=True, db_index=True, verbose_name='ID')),
 | 
						||
                ('created', models.DateTimeField(blank=True, editable=False, verbose_name='تاریخ ایجاد')),
 | 
						||
                ('updated', models.DateTimeField(blank=True, editable=False, verbose_name='تاریخ بروزرسانی')),
 | 
						||
                ('is_active', models.BooleanField(default=True, verbose_name='فعال')),
 | 
						||
                ('is_deleted', models.BooleanField(default=False, verbose_name='حذف شده')),
 | 
						||
                ('deleted_at', models.DateTimeField(blank=True, null=True, verbose_name='تاریخ حذف')),
 | 
						||
                ('slug', models.SlugField(max_length=100, verbose_name='اسلاگ')),
 | 
						||
                ('name', models.CharField(max_length=100, verbose_name='نام')),
 | 
						||
                ('status', models.CharField(choices=[('draft', 'پیش\u200cنویس'), ('sent', 'ارسال شده'), ('accepted', 'تایید شده'), ('rejected', 'رد شده'), ('expired', 'منقضی شده')], default='draft', max_length=20, verbose_name='وضعیت')),
 | 
						||
                ('total_amount', models.DecimalField(decimal_places=2, default=0, max_digits=15, verbose_name='مبلغ کل')),
 | 
						||
                ('discount_percent', models.DecimalField(decimal_places=2, default=0, max_digits=5, verbose_name='درصد تخفیف')),
 | 
						||
                ('discount_amount', models.DecimalField(decimal_places=2, default=0, max_digits=15, verbose_name='مبلغ تخفیف')),
 | 
						||
                ('final_amount', models.DecimalField(decimal_places=2, default=0, max_digits=15, verbose_name='مبلغ نهایی')),
 | 
						||
                ('notes', models.TextField(blank=True, verbose_name='یادداشت\u200cها')),
 | 
						||
                ('valid_until', models.DateField(verbose_name='معتبر تا')),
 | 
						||
                ('history_id', models.AutoField(primary_key=True, serialize=False)),
 | 
						||
                ('history_date', models.DateTimeField(db_index=True)),
 | 
						||
                ('history_change_reason', models.CharField(max_length=100, null=True)),
 | 
						||
                ('history_type', models.CharField(choices=[('+', 'Created'), ('~', 'Changed'), ('-', 'Deleted')], max_length=1)),
 | 
						||
                ('created_by', models.ForeignKey(blank=True, db_constraint=False, null=True, on_delete=django.db.models.deletion.DO_NOTHING, related_name='+', to=settings.AUTH_USER_MODEL, verbose_name='ایجاد کننده')),
 | 
						||
                ('customer', models.ForeignKey(blank=True, db_constraint=False, null=True, on_delete=django.db.models.deletion.DO_NOTHING, related_name='+', to=settings.AUTH_USER_MODEL, verbose_name='مشترک')),
 | 
						||
                ('history_user', models.ForeignKey(null=True, on_delete=django.db.models.deletion.SET_NULL, related_name='+', to=settings.AUTH_USER_MODEL)),
 | 
						||
                ('process_instance', models.ForeignKey(blank=True, db_constraint=False, null=True, on_delete=django.db.models.deletion.DO_NOTHING, related_name='+', to='processes.processinstance', verbose_name='نمونه فرآیند')),
 | 
						||
            ],
 | 
						||
            options={
 | 
						||
                'verbose_name': 'historical پیش\u200cفاکتور',
 | 
						||
                'verbose_name_plural': 'historical پیش\u200cفاکتورها',
 | 
						||
                'ordering': ('-history_date', '-history_id'),
 | 
						||
                'get_latest_by': ('history_date', 'history_id'),
 | 
						||
            },
 | 
						||
            bases=(simple_history.models.HistoricalChanges, models.Model),
 | 
						||
        ),
 | 
						||
        migrations.CreateModel(
 | 
						||
            name='Invoice',
 | 
						||
            fields=[
 | 
						||
                ('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
 | 
						||
                ('created', models.DateTimeField(auto_now_add=True, verbose_name='تاریخ ایجاد')),
 | 
						||
                ('updated', models.DateTimeField(auto_now=True, verbose_name='تاریخ بروزرسانی')),
 | 
						||
                ('is_active', models.BooleanField(default=True, verbose_name='فعال')),
 | 
						||
                ('is_deleted', models.BooleanField(default=False, verbose_name='حذف شده')),
 | 
						||
                ('deleted_at', models.DateTimeField(blank=True, null=True, verbose_name='تاریخ حذف')),
 | 
						||
                ('slug', models.SlugField(max_length=100, unique=True, verbose_name='اسلاگ')),
 | 
						||
                ('name', models.CharField(max_length=100, verbose_name='نام')),
 | 
						||
                ('status', models.CharField(choices=[('draft', 'پیش\u200cنویس'), ('sent', 'ارسال شده'), ('paid', 'پرداخت شده'), ('partially_paid', 'نیمه پرداخت شده'), ('overdue', 'معوق'), ('cancelled', 'لغو شده')], default='draft', max_length=20, verbose_name='وضعیت')),
 | 
						||
                ('total_amount', models.DecimalField(decimal_places=2, default=0, max_digits=15, verbose_name='مبلغ کل')),
 | 
						||
                ('discount_percent', models.DecimalField(decimal_places=2, default=0, max_digits=5, verbose_name='درصد تخفیف')),
 | 
						||
                ('discount_amount', models.DecimalField(decimal_places=2, default=0, max_digits=15, verbose_name='مبلغ تخفیف')),
 | 
						||
                ('final_amount', models.DecimalField(decimal_places=2, default=0, max_digits=15, verbose_name='مبلغ نهایی')),
 | 
						||
                ('paid_amount', models.DecimalField(decimal_places=2, default=0, max_digits=15, verbose_name='مبلغ پرداخت شده')),
 | 
						||
                ('remaining_amount', models.DecimalField(decimal_places=2, default=0, max_digits=15, verbose_name='مبلغ باقی\u200cمانده')),
 | 
						||
                ('due_date', models.DateField(verbose_name='تاریخ سررسید')),
 | 
						||
                ('notes', models.TextField(blank=True, verbose_name='یادداشت\u200cها')),
 | 
						||
                ('created_by', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, related_name='created_invoices', to=settings.AUTH_USER_MODEL, verbose_name='ایجاد کننده')),
 | 
						||
                ('customer', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to=settings.AUTH_USER_MODEL, verbose_name='مشترک')),
 | 
						||
                ('process_instance', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to='processes.processinstance', verbose_name='نمونه فرآیند')),
 | 
						||
            ],
 | 
						||
            options={
 | 
						||
                'verbose_name': 'فاکتور',
 | 
						||
                'verbose_name_plural': 'فاکتورها',
 | 
						||
                'ordering': ['-created'],
 | 
						||
            },
 | 
						||
        ),
 | 
						||
        migrations.CreateModel(
 | 
						||
            name='HistoricalPayment',
 | 
						||
            fields=[
 | 
						||
                ('id', models.BigIntegerField(auto_created=True, blank=True, db_index=True, verbose_name='ID')),
 | 
						||
                ('created', models.DateTimeField(blank=True, editable=False, verbose_name='تاریخ ایجاد')),
 | 
						||
                ('updated', models.DateTimeField(blank=True, editable=False, verbose_name='تاریخ بروزرسانی')),
 | 
						||
                ('is_active', models.BooleanField(default=True, verbose_name='فعال')),
 | 
						||
                ('is_deleted', models.BooleanField(default=False, verbose_name='حذف شده')),
 | 
						||
                ('deleted_at', models.DateTimeField(blank=True, null=True, verbose_name='تاریخ حذف')),
 | 
						||
                ('amount', models.DecimalField(decimal_places=2, max_digits=15, verbose_name='مبلغ پرداخت')),
 | 
						||
                ('direction', models.CharField(choices=[('in', 'دریافتی'), ('out', 'پرداختی')], default='in', max_length=3, verbose_name='نوع تراکنش')),
 | 
						||
                ('payment_method', models.CharField(choices=[('cash', 'نقدی'), ('bank_transfer', 'انتقال بانکی'), ('check', 'چک'), ('card', 'کارت بانکی'), ('other', 'سایر')], default='cash', max_length=20, verbose_name='روش پرداخت')),
 | 
						||
                ('reference_number', models.CharField(blank=True, db_index=True, max_length=100, verbose_name='شماره مرجع')),
 | 
						||
                ('payment_date', models.DateField(verbose_name='تاریخ پرداخت')),
 | 
						||
                ('notes', models.TextField(blank=True, verbose_name='یادداشت\u200cها')),
 | 
						||
                ('receipt_image', models.TextField(blank=True, max_length=100, null=True, verbose_name='تصویر فیش')),
 | 
						||
                ('history_id', models.AutoField(primary_key=True, serialize=False)),
 | 
						||
                ('history_date', models.DateTimeField(db_index=True)),
 | 
						||
                ('history_change_reason', models.CharField(max_length=100, null=True)),
 | 
						||
                ('history_type', models.CharField(choices=[('+', 'Created'), ('~', 'Changed'), ('-', 'Deleted')], max_length=1)),
 | 
						||
                ('created_by', models.ForeignKey(blank=True, db_constraint=False, null=True, on_delete=django.db.models.deletion.DO_NOTHING, related_name='+', to=settings.AUTH_USER_MODEL, verbose_name='ثبت کننده')),
 | 
						||
                ('history_user', models.ForeignKey(null=True, on_delete=django.db.models.deletion.SET_NULL, related_name='+', to=settings.AUTH_USER_MODEL)),
 | 
						||
                ('invoice', models.ForeignKey(blank=True, db_constraint=False, null=True, on_delete=django.db.models.deletion.DO_NOTHING, related_name='+', to='invoices.invoice', verbose_name='فاکتور')),
 | 
						||
            ],
 | 
						||
            options={
 | 
						||
                'verbose_name': 'historical پرداخت',
 | 
						||
                'verbose_name_plural': 'historical پرداخت\u200cها',
 | 
						||
                'ordering': ('-history_date', '-history_id'),
 | 
						||
                'get_latest_by': ('history_date', 'history_id'),
 | 
						||
            },
 | 
						||
            bases=(simple_history.models.HistoricalChanges, models.Model),
 | 
						||
        ),
 | 
						||
        migrations.CreateModel(
 | 
						||
            name='Item',
 | 
						||
            fields=[
 | 
						||
                ('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
 | 
						||
                ('created', models.DateTimeField(auto_now_add=True, verbose_name='تاریخ ایجاد')),
 | 
						||
                ('updated', models.DateTimeField(auto_now=True, verbose_name='تاریخ بروزرسانی')),
 | 
						||
                ('is_active', models.BooleanField(default=True, verbose_name='فعال')),
 | 
						||
                ('is_deleted', models.BooleanField(default=False, verbose_name='حذف شده')),
 | 
						||
                ('deleted_at', models.DateTimeField(blank=True, null=True, verbose_name='تاریخ حذف')),
 | 
						||
                ('slug', models.SlugField(max_length=100, unique=True, verbose_name='اسلاگ')),
 | 
						||
                ('name', models.CharField(max_length=100, verbose_name='نام')),
 | 
						||
                ('description', models.TextField(blank=True, verbose_name='توضیحات')),
 | 
						||
                ('unit_price', models.DecimalField(decimal_places=2, max_digits=15, verbose_name='قیمت واحد')),
 | 
						||
                ('is_special', models.BooleanField(default=False, verbose_name='ویژه برای فاکتور نهایی')),
 | 
						||
                ('default_quantity', models.PositiveIntegerField(default=1, verbose_name='تعداد پیش\u200cفرض')),
 | 
						||
                ('is_default_in_quotes', models.BooleanField(default=False, help_text='این آیتم به صورت پیش\u200cفرض در همه پیش\u200cفاکتورها قرار می\u200cگیرد', verbose_name='پیش\u200cفرض در پیش\u200cفاکتورها')),
 | 
						||
                ('created_by', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to=settings.AUTH_USER_MODEL, verbose_name='ایجاد کننده')),
 | 
						||
            ],
 | 
						||
            options={
 | 
						||
                'verbose_name': 'آیتم',
 | 
						||
                'verbose_name_plural': 'آیتم\u200cها',
 | 
						||
                'ordering': ['name'],
 | 
						||
            },
 | 
						||
        ),
 | 
						||
        migrations.CreateModel(
 | 
						||
            name='InvoiceItem',
 | 
						||
            fields=[
 | 
						||
                ('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
 | 
						||
                ('created', models.DateTimeField(auto_now_add=True, verbose_name='تاریخ ایجاد')),
 | 
						||
                ('updated', models.DateTimeField(auto_now=True, verbose_name='تاریخ بروزرسانی')),
 | 
						||
                ('is_active', models.BooleanField(default=True, verbose_name='فعال')),
 | 
						||
                ('is_deleted', models.BooleanField(default=False, verbose_name='حذف شده')),
 | 
						||
                ('deleted_at', models.DateTimeField(blank=True, null=True, verbose_name='تاریخ حذف')),
 | 
						||
                ('quantity', models.PositiveIntegerField(verbose_name='تعداد')),
 | 
						||
                ('unit_price', models.DecimalField(decimal_places=2, max_digits=15, verbose_name='قیمت واحد')),
 | 
						||
                ('total_price', models.DecimalField(decimal_places=2, max_digits=15, verbose_name='قیمت کل')),
 | 
						||
                ('notes', models.TextField(blank=True, verbose_name='یادداشت\u200cها')),
 | 
						||
                ('invoice', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, related_name='items', to='invoices.invoice', verbose_name='فاکتور')),
 | 
						||
                ('item', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to='invoices.item', verbose_name='آیتم')),
 | 
						||
            ],
 | 
						||
            options={
 | 
						||
                'verbose_name': 'آیتم فاکتور',
 | 
						||
                'verbose_name_plural': 'آیتم\u200cهای فاکتور',
 | 
						||
                'ordering': ['invoice', 'item__name'],
 | 
						||
            },
 | 
						||
        ),
 | 
						||
        migrations.CreateModel(
 | 
						||
            name='HistoricalInvoiceItem',
 | 
						||
            fields=[
 | 
						||
                ('id', models.BigIntegerField(auto_created=True, blank=True, db_index=True, verbose_name='ID')),
 | 
						||
                ('created', models.DateTimeField(blank=True, editable=False, verbose_name='تاریخ ایجاد')),
 | 
						||
                ('updated', models.DateTimeField(blank=True, editable=False, verbose_name='تاریخ بروزرسانی')),
 | 
						||
                ('is_active', models.BooleanField(default=True, verbose_name='فعال')),
 | 
						||
                ('is_deleted', models.BooleanField(default=False, verbose_name='حذف شده')),
 | 
						||
                ('deleted_at', models.DateTimeField(blank=True, null=True, verbose_name='تاریخ حذف')),
 | 
						||
                ('quantity', models.PositiveIntegerField(verbose_name='تعداد')),
 | 
						||
                ('unit_price', models.DecimalField(decimal_places=2, max_digits=15, verbose_name='قیمت واحد')),
 | 
						||
                ('total_price', models.DecimalField(decimal_places=2, max_digits=15, verbose_name='قیمت کل')),
 | 
						||
                ('notes', models.TextField(blank=True, verbose_name='یادداشت\u200cها')),
 | 
						||
                ('history_id', models.AutoField(primary_key=True, serialize=False)),
 | 
						||
                ('history_date', models.DateTimeField(db_index=True)),
 | 
						||
                ('history_change_reason', models.CharField(max_length=100, null=True)),
 | 
						||
                ('history_type', models.CharField(choices=[('+', 'Created'), ('~', 'Changed'), ('-', 'Deleted')], max_length=1)),
 | 
						||
                ('history_user', models.ForeignKey(null=True, on_delete=django.db.models.deletion.SET_NULL, related_name='+', to=settings.AUTH_USER_MODEL)),
 | 
						||
                ('invoice', models.ForeignKey(blank=True, db_constraint=False, null=True, on_delete=django.db.models.deletion.DO_NOTHING, related_name='+', to='invoices.invoice', verbose_name='فاکتور')),
 | 
						||
                ('item', models.ForeignKey(blank=True, db_constraint=False, null=True, on_delete=django.db.models.deletion.DO_NOTHING, related_name='+', to='invoices.item', verbose_name='آیتم')),
 | 
						||
            ],
 | 
						||
            options={
 | 
						||
                'verbose_name': 'historical آیتم فاکتور',
 | 
						||
                'verbose_name_plural': 'historical آیتم\u200cهای فاکتور',
 | 
						||
                'ordering': ('-history_date', '-history_id'),
 | 
						||
                'get_latest_by': ('history_date', 'history_id'),
 | 
						||
            },
 | 
						||
            bases=(simple_history.models.HistoricalChanges, models.Model),
 | 
						||
        ),
 | 
						||
        migrations.CreateModel(
 | 
						||
            name='Payment',
 | 
						||
            fields=[
 | 
						||
                ('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
 | 
						||
                ('created', models.DateTimeField(auto_now_add=True, verbose_name='تاریخ ایجاد')),
 | 
						||
                ('updated', models.DateTimeField(auto_now=True, verbose_name='تاریخ بروزرسانی')),
 | 
						||
                ('is_active', models.BooleanField(default=True, verbose_name='فعال')),
 | 
						||
                ('is_deleted', models.BooleanField(default=False, verbose_name='حذف شده')),
 | 
						||
                ('deleted_at', models.DateTimeField(blank=True, null=True, verbose_name='تاریخ حذف')),
 | 
						||
                ('amount', models.DecimalField(decimal_places=2, max_digits=15, verbose_name='مبلغ پرداخت')),
 | 
						||
                ('direction', models.CharField(choices=[('in', 'دریافتی'), ('out', 'پرداختی')], default='in', max_length=3, verbose_name='نوع تراکنش')),
 | 
						||
                ('payment_method', models.CharField(choices=[('cash', 'نقدی'), ('bank_transfer', 'انتقال بانکی'), ('check', 'چک'), ('card', 'کارت بانکی'), ('other', 'سایر')], default='cash', max_length=20, verbose_name='روش پرداخت')),
 | 
						||
                ('reference_number', models.CharField(blank=True, max_length=100, unique=True, verbose_name='شماره مرجع')),
 | 
						||
                ('payment_date', models.DateField(verbose_name='تاریخ پرداخت')),
 | 
						||
                ('notes', models.TextField(blank=True, verbose_name='یادداشت\u200cها')),
 | 
						||
                ('receipt_image', models.ImageField(blank=True, null=True, upload_to='payments/%Y/%m/%d/', verbose_name='تصویر فیش')),
 | 
						||
                ('created_by', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to=settings.AUTH_USER_MODEL, verbose_name='ثبت کننده')),
 | 
						||
                ('invoice', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, related_name='payments', to='invoices.invoice', verbose_name='فاکتور')),
 | 
						||
            ],
 | 
						||
            options={
 | 
						||
                'verbose_name': 'پرداخت',
 | 
						||
                'verbose_name_plural': 'پرداخت\u200cها',
 | 
						||
                'ordering': ['-payment_date'],
 | 
						||
            },
 | 
						||
        ),
 | 
						||
        migrations.CreateModel(
 | 
						||
            name='Quote',
 | 
						||
            fields=[
 | 
						||
                ('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
 | 
						||
                ('created', models.DateTimeField(auto_now_add=True, verbose_name='تاریخ ایجاد')),
 | 
						||
                ('updated', models.DateTimeField(auto_now=True, verbose_name='تاریخ بروزرسانی')),
 | 
						||
                ('is_active', models.BooleanField(default=True, verbose_name='فعال')),
 | 
						||
                ('is_deleted', models.BooleanField(default=False, verbose_name='حذف شده')),
 | 
						||
                ('deleted_at', models.DateTimeField(blank=True, null=True, verbose_name='تاریخ حذف')),
 | 
						||
                ('slug', models.SlugField(max_length=100, unique=True, verbose_name='اسلاگ')),
 | 
						||
                ('name', models.CharField(max_length=100, verbose_name='نام')),
 | 
						||
                ('status', models.CharField(choices=[('draft', 'پیش\u200cنویس'), ('sent', 'ارسال شده'), ('accepted', 'تایید شده'), ('rejected', 'رد شده'), ('expired', 'منقضی شده')], default='draft', max_length=20, verbose_name='وضعیت')),
 | 
						||
                ('total_amount', models.DecimalField(decimal_places=2, default=0, max_digits=15, verbose_name='مبلغ کل')),
 | 
						||
                ('discount_percent', models.DecimalField(decimal_places=2, default=0, max_digits=5, verbose_name='درصد تخفیف')),
 | 
						||
                ('discount_amount', models.DecimalField(decimal_places=2, default=0, max_digits=15, verbose_name='مبلغ تخفیف')),
 | 
						||
                ('final_amount', models.DecimalField(decimal_places=2, default=0, max_digits=15, verbose_name='مبلغ نهایی')),
 | 
						||
                ('notes', models.TextField(blank=True, verbose_name='یادداشت\u200cها')),
 | 
						||
                ('valid_until', models.DateField(verbose_name='معتبر تا')),
 | 
						||
                ('created_by', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, related_name='created_quotes', to=settings.AUTH_USER_MODEL, verbose_name='ایجاد کننده')),
 | 
						||
                ('customer', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to=settings.AUTH_USER_MODEL, verbose_name='مشترک')),
 | 
						||
                ('process_instance', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to='processes.processinstance', verbose_name='نمونه فرآیند')),
 | 
						||
            ],
 | 
						||
            options={
 | 
						||
                'verbose_name': 'پیش\u200cفاکتور',
 | 
						||
                'verbose_name_plural': 'پیش\u200cفاکتورها',
 | 
						||
                'ordering': ['-created'],
 | 
						||
            },
 | 
						||
        ),
 | 
						||
        migrations.AddField(
 | 
						||
            model_name='invoice',
 | 
						||
            name='quote',
 | 
						||
            field=models.ForeignKey(blank=True, null=True, on_delete=django.db.models.deletion.CASCADE, to='invoices.quote', verbose_name='پیش\u200cفاکتور مربوطه'),
 | 
						||
        ),
 | 
						||
        migrations.CreateModel(
 | 
						||
            name='HistoricalQuoteItem',
 | 
						||
            fields=[
 | 
						||
                ('id', models.BigIntegerField(auto_created=True, blank=True, db_index=True, verbose_name='ID')),
 | 
						||
                ('created', models.DateTimeField(blank=True, editable=False, verbose_name='تاریخ ایجاد')),
 | 
						||
                ('updated', models.DateTimeField(blank=True, editable=False, verbose_name='تاریخ بروزرسانی')),
 | 
						||
                ('is_active', models.BooleanField(default=True, verbose_name='فعال')),
 | 
						||
                ('is_deleted', models.BooleanField(default=False, verbose_name='حذف شده')),
 | 
						||
                ('deleted_at', models.DateTimeField(blank=True, null=True, verbose_name='تاریخ حذف')),
 | 
						||
                ('quantity', models.PositiveIntegerField(verbose_name='تعداد')),
 | 
						||
                ('unit_price', models.DecimalField(decimal_places=2, max_digits=15, verbose_name='قیمت واحد')),
 | 
						||
                ('total_price', models.DecimalField(decimal_places=2, max_digits=15, verbose_name='قیمت کل')),
 | 
						||
                ('notes', models.TextField(blank=True, verbose_name='یادداشت\u200cها')),
 | 
						||
                ('history_id', models.AutoField(primary_key=True, serialize=False)),
 | 
						||
                ('history_date', models.DateTimeField(db_index=True)),
 | 
						||
                ('history_change_reason', models.CharField(max_length=100, null=True)),
 | 
						||
                ('history_type', models.CharField(choices=[('+', 'Created'), ('~', 'Changed'), ('-', 'Deleted')], max_length=1)),
 | 
						||
                ('history_user', models.ForeignKey(null=True, on_delete=django.db.models.deletion.SET_NULL, related_name='+', to=settings.AUTH_USER_MODEL)),
 | 
						||
                ('item', models.ForeignKey(blank=True, db_constraint=False, null=True, on_delete=django.db.models.deletion.DO_NOTHING, related_name='+', to='invoices.item', verbose_name='آیتم')),
 | 
						||
                ('quote', models.ForeignKey(blank=True, db_constraint=False, null=True, on_delete=django.db.models.deletion.DO_NOTHING, related_name='+', to='invoices.quote', verbose_name='پیش\u200cفاکتور')),
 | 
						||
            ],
 | 
						||
            options={
 | 
						||
                'verbose_name': 'historical آیتم پیش\u200cفاکتور',
 | 
						||
                'verbose_name_plural': 'historical آیتم\u200cهای پیش\u200cفاکتور',
 | 
						||
                'ordering': ('-history_date', '-history_id'),
 | 
						||
                'get_latest_by': ('history_date', 'history_id'),
 | 
						||
            },
 | 
						||
            bases=(simple_history.models.HistoricalChanges, models.Model),
 | 
						||
        ),
 | 
						||
        migrations.CreateModel(
 | 
						||
            name='HistoricalInvoice',
 | 
						||
            fields=[
 | 
						||
                ('id', models.BigIntegerField(auto_created=True, blank=True, db_index=True, verbose_name='ID')),
 | 
						||
                ('created', models.DateTimeField(blank=True, editable=False, verbose_name='تاریخ ایجاد')),
 | 
						||
                ('updated', models.DateTimeField(blank=True, editable=False, verbose_name='تاریخ بروزرسانی')),
 | 
						||
                ('is_active', models.BooleanField(default=True, verbose_name='فعال')),
 | 
						||
                ('is_deleted', models.BooleanField(default=False, verbose_name='حذف شده')),
 | 
						||
                ('deleted_at', models.DateTimeField(blank=True, null=True, verbose_name='تاریخ حذف')),
 | 
						||
                ('slug', models.SlugField(max_length=100, verbose_name='اسلاگ')),
 | 
						||
                ('name', models.CharField(max_length=100, verbose_name='نام')),
 | 
						||
                ('status', models.CharField(choices=[('draft', 'پیش\u200cنویس'), ('sent', 'ارسال شده'), ('paid', 'پرداخت شده'), ('partially_paid', 'نیمه پرداخت شده'), ('overdue', 'معوق'), ('cancelled', 'لغو شده')], default='draft', max_length=20, verbose_name='وضعیت')),
 | 
						||
                ('total_amount', models.DecimalField(decimal_places=2, default=0, max_digits=15, verbose_name='مبلغ کل')),
 | 
						||
                ('discount_percent', models.DecimalField(decimal_places=2, default=0, max_digits=5, verbose_name='درصد تخفیف')),
 | 
						||
                ('discount_amount', models.DecimalField(decimal_places=2, default=0, max_digits=15, verbose_name='مبلغ تخفیف')),
 | 
						||
                ('final_amount', models.DecimalField(decimal_places=2, default=0, max_digits=15, verbose_name='مبلغ نهایی')),
 | 
						||
                ('paid_amount', models.DecimalField(decimal_places=2, default=0, max_digits=15, verbose_name='مبلغ پرداخت شده')),
 | 
						||
                ('remaining_amount', models.DecimalField(decimal_places=2, default=0, max_digits=15, verbose_name='مبلغ باقی\u200cمانده')),
 | 
						||
                ('due_date', models.DateField(verbose_name='تاریخ سررسید')),
 | 
						||
                ('notes', models.TextField(blank=True, verbose_name='یادداشت\u200cها')),
 | 
						||
                ('history_id', models.AutoField(primary_key=True, serialize=False)),
 | 
						||
                ('history_date', models.DateTimeField(db_index=True)),
 | 
						||
                ('history_change_reason', models.CharField(max_length=100, null=True)),
 | 
						||
                ('history_type', models.CharField(choices=[('+', 'Created'), ('~', 'Changed'), ('-', 'Deleted')], max_length=1)),
 | 
						||
                ('created_by', models.ForeignKey(blank=True, db_constraint=False, null=True, on_delete=django.db.models.deletion.DO_NOTHING, related_name='+', to=settings.AUTH_USER_MODEL, verbose_name='ایجاد کننده')),
 | 
						||
                ('customer', models.ForeignKey(blank=True, db_constraint=False, null=True, on_delete=django.db.models.deletion.DO_NOTHING, related_name='+', to=settings.AUTH_USER_MODEL, verbose_name='مشترک')),
 | 
						||
                ('history_user', models.ForeignKey(null=True, on_delete=django.db.models.deletion.SET_NULL, related_name='+', to=settings.AUTH_USER_MODEL)),
 | 
						||
                ('process_instance', models.ForeignKey(blank=True, db_constraint=False, null=True, on_delete=django.db.models.deletion.DO_NOTHING, related_name='+', to='processes.processinstance', verbose_name='نمونه فرآیند')),
 | 
						||
                ('quote', models.ForeignKey(blank=True, db_constraint=False, null=True, on_delete=django.db.models.deletion.DO_NOTHING, related_name='+', to='invoices.quote', verbose_name='پیش\u200cفاکتور مربوطه')),
 | 
						||
            ],
 | 
						||
            options={
 | 
						||
                'verbose_name': 'historical فاکتور',
 | 
						||
                'verbose_name_plural': 'historical فاکتورها',
 | 
						||
                'ordering': ('-history_date', '-history_id'),
 | 
						||
                'get_latest_by': ('history_date', 'history_id'),
 | 
						||
            },
 | 
						||
            bases=(simple_history.models.HistoricalChanges, models.Model),
 | 
						||
        ),
 | 
						||
        migrations.CreateModel(
 | 
						||
            name='QuoteItem',
 | 
						||
            fields=[
 | 
						||
                ('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
 | 
						||
                ('created', models.DateTimeField(auto_now_add=True, verbose_name='تاریخ ایجاد')),
 | 
						||
                ('updated', models.DateTimeField(auto_now=True, verbose_name='تاریخ بروزرسانی')),
 | 
						||
                ('is_active', models.BooleanField(default=True, verbose_name='فعال')),
 | 
						||
                ('is_deleted', models.BooleanField(default=False, verbose_name='حذف شده')),
 | 
						||
                ('deleted_at', models.DateTimeField(blank=True, null=True, verbose_name='تاریخ حذف')),
 | 
						||
                ('quantity', models.PositiveIntegerField(verbose_name='تعداد')),
 | 
						||
                ('unit_price', models.DecimalField(decimal_places=2, max_digits=15, verbose_name='قیمت واحد')),
 | 
						||
                ('total_price', models.DecimalField(decimal_places=2, max_digits=15, verbose_name='قیمت کل')),
 | 
						||
                ('notes', models.TextField(blank=True, verbose_name='یادداشت\u200cها')),
 | 
						||
                ('item', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to='invoices.item', verbose_name='آیتم')),
 | 
						||
                ('quote', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, related_name='items', to='invoices.quote', verbose_name='پیش\u200cفاکتور')),
 | 
						||
            ],
 | 
						||
            options={
 | 
						||
                'verbose_name': 'آیتم پیش\u200cفاکتور',
 | 
						||
                'verbose_name_plural': 'آیتم\u200cهای پیش\u200cفاکتور',
 | 
						||
                'ordering': ['quote', 'item__name'],
 | 
						||
            },
 | 
						||
        ),
 | 
						||
    ]
 |