57 lines
3.0 KiB
Python
57 lines
3.0 KiB
Python
# Generated by Django 5.2.7 on 2026-02-03 03:14
|
|
|
|
import django.db.models.deletion
|
|
import django.utils.timezone
|
|
from django.db import migrations, models
|
|
|
|
|
|
class Migration(migrations.Migration):
|
|
|
|
initial = True
|
|
|
|
dependencies = [
|
|
('contenttypes', '0002_remove_content_type_name'),
|
|
]
|
|
|
|
operations = [
|
|
migrations.CreateModel(
|
|
name='Account',
|
|
fields=[
|
|
('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
|
|
('code', models.CharField(max_length=20, unique=True, verbose_name='Account Code')),
|
|
('name_en', models.CharField(max_length=100, verbose_name='Name (English)')),
|
|
('name_ar', models.CharField(max_length=100, verbose_name='Name (Arabic)')),
|
|
('account_type', models.CharField(choices=[('asset', 'Asset'), ('liability', 'Liability'), ('equity', 'Equity'), ('income', 'Income'), ('expense', 'Expense')], max_length=20, verbose_name='Account Type')),
|
|
('description', models.TextField(blank=True, verbose_name='Description')),
|
|
('is_active', models.BooleanField(default=True, verbose_name='Is Active')),
|
|
('created_at', models.DateTimeField(auto_now_add=True)),
|
|
],
|
|
),
|
|
migrations.CreateModel(
|
|
name='JournalEntry',
|
|
fields=[
|
|
('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
|
|
('date', models.DateField(default=django.utils.timezone.now, verbose_name='Date')),
|
|
('description', models.TextField(verbose_name='Description')),
|
|
('reference', models.CharField(blank=True, max_length=100, verbose_name='Reference')),
|
|
('object_id', models.PositiveIntegerField(blank=True, null=True)),
|
|
('created_at', models.DateTimeField(auto_now_add=True)),
|
|
('content_type', models.ForeignKey(blank=True, null=True, on_delete=django.db.models.deletion.CASCADE, to='contenttypes.contenttype')),
|
|
],
|
|
options={
|
|
'verbose_name_plural': 'Journal Entries',
|
|
},
|
|
),
|
|
migrations.CreateModel(
|
|
name='JournalItem',
|
|
fields=[
|
|
('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
|
|
('type', models.CharField(choices=[('debit', 'Debit'), ('credit', 'Credit')], max_length=10, verbose_name='Type')),
|
|
('amount', models.DecimalField(decimal_places=3, max_digits=15, verbose_name='Amount')),
|
|
('notes', models.CharField(blank=True, max_length=255, verbose_name='Notes')),
|
|
('account', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, related_name='journal_items', to='accounting.account')),
|
|
('entry', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, related_name='items', to='accounting.journalentry')),
|
|
],
|
|
),
|
|
]
|