197 lines
9.5 KiB
Python
197 lines
9.5 KiB
Python
# Generated by Django 5.0.14 on 2025-12-14 10:34
|
|
|
|
import django.db.models.deletion
|
|
import uuid
|
|
from django.db import migrations, models
|
|
|
|
|
|
class Migration(migrations.Migration):
|
|
|
|
dependencies = [
|
|
('journeys', '0002_initial'),
|
|
('organizations', '0001_initial'),
|
|
('surveys', '0001_initial'),
|
|
]
|
|
|
|
operations = [
|
|
migrations.CreateModel(
|
|
name='SurveyQuestion',
|
|
fields=[
|
|
('created_at', models.DateTimeField(auto_now_add=True, db_index=True)),
|
|
('updated_at', models.DateTimeField(auto_now=True)),
|
|
('id', models.UUIDField(default=uuid.uuid4, editable=False, primary_key=True, serialize=False)),
|
|
('text', models.TextField(verbose_name='Question Text (English)')),
|
|
('text_ar', models.TextField(blank=True, verbose_name='Question Text (Arabic)')),
|
|
('question_type', models.CharField(choices=[('rating', 'Rating (1-5 stars)'), ('nps', 'NPS (0-10)'), ('yes_no', 'Yes/No'), ('multiple_choice', 'Multiple Choice'), ('text', 'Text (Short Answer)'), ('textarea', 'Text Area (Long Answer)'), ('likert', 'Likert Scale (1-5)')], default='rating', max_length=20)),
|
|
('order', models.IntegerField(default=0, help_text='Display order')),
|
|
('is_required', models.BooleanField(default=True)),
|
|
('choices_json', models.JSONField(blank=True, default=list, help_text="Array of choice objects: [{'value': '1', 'label': 'Option 1', 'label_ar': 'خيار 1'}]")),
|
|
('weight', models.DecimalField(decimal_places=2, default=1.0, help_text='Weight for weighted average scoring', max_digits=3)),
|
|
('branch_logic', models.JSONField(blank=True, default=dict, help_text="Conditional display logic: {'show_if': {'question_id': 'value'}}")),
|
|
('help_text', models.TextField(blank=True)),
|
|
('help_text_ar', models.TextField(blank=True)),
|
|
],
|
|
options={
|
|
'ordering': ['survey_template', 'order'],
|
|
},
|
|
),
|
|
migrations.CreateModel(
|
|
name='SurveyResponse',
|
|
fields=[
|
|
('created_at', models.DateTimeField(auto_now_add=True, db_index=True)),
|
|
('updated_at', models.DateTimeField(auto_now=True)),
|
|
('id', models.UUIDField(default=uuid.uuid4, editable=False, primary_key=True, serialize=False)),
|
|
('numeric_value', models.DecimalField(blank=True, decimal_places=2, help_text='For rating, NPS, Likert questions', max_digits=10, null=True)),
|
|
('text_value', models.TextField(blank=True, help_text='For text, textarea questions')),
|
|
('choice_value', models.CharField(blank=True, help_text='For multiple choice questions', max_length=200)),
|
|
('response_time_seconds', models.IntegerField(blank=True, help_text='Time taken to answer this question', null=True)),
|
|
],
|
|
options={
|
|
'ordering': ['survey_instance', 'question__order'],
|
|
},
|
|
),
|
|
migrations.AlterModelOptions(
|
|
name='surveytemplate',
|
|
options={'ordering': ['hospital', 'name']},
|
|
),
|
|
migrations.AddField(
|
|
model_name='surveyinstance',
|
|
name='access_token',
|
|
field=models.CharField(blank=True, db_index=True, help_text='Secure token for survey access', max_length=100, unique=True),
|
|
),
|
|
migrations.AddField(
|
|
model_name='surveyinstance',
|
|
name='delivery_channel',
|
|
field=models.CharField(choices=[('sms', 'SMS'), ('whatsapp', 'WhatsApp'), ('email', 'Email')], default='sms', max_length=20),
|
|
),
|
|
migrations.AddField(
|
|
model_name='surveyinstance',
|
|
name='is_negative',
|
|
field=models.BooleanField(db_index=True, default=False, help_text='True if score below threshold'),
|
|
),
|
|
migrations.AddField(
|
|
model_name='surveyinstance',
|
|
name='journey_instance',
|
|
field=models.ForeignKey(blank=True, null=True, on_delete=django.db.models.deletion.CASCADE, related_name='surveys', to='journeys.patientjourneyinstance'),
|
|
),
|
|
migrations.AddField(
|
|
model_name='surveyinstance',
|
|
name='journey_stage_instance',
|
|
field=models.ForeignKey(blank=True, null=True, on_delete=django.db.models.deletion.CASCADE, related_name='surveys', to='journeys.patientjourneystageinstance'),
|
|
),
|
|
migrations.AddField(
|
|
model_name='surveyinstance',
|
|
name='metadata',
|
|
field=models.JSONField(blank=True, default=dict),
|
|
),
|
|
migrations.AddField(
|
|
model_name='surveyinstance',
|
|
name='opened_at',
|
|
field=models.DateTimeField(blank=True, null=True),
|
|
),
|
|
migrations.AddField(
|
|
model_name='surveyinstance',
|
|
name='recipient_email',
|
|
field=models.EmailField(blank=True, max_length=254),
|
|
),
|
|
migrations.AddField(
|
|
model_name='surveyinstance',
|
|
name='recipient_phone',
|
|
field=models.CharField(blank=True, max_length=20),
|
|
),
|
|
migrations.AddField(
|
|
model_name='surveyinstance',
|
|
name='token_expires_at',
|
|
field=models.DateTimeField(blank=True, help_text='Token expiration date', null=True),
|
|
),
|
|
migrations.AddField(
|
|
model_name='surveyinstance',
|
|
name='total_score',
|
|
field=models.DecimalField(blank=True, decimal_places=2, help_text='Calculated total score', max_digits=5, null=True),
|
|
),
|
|
migrations.AddField(
|
|
model_name='surveytemplate',
|
|
name='description_ar',
|
|
field=models.TextField(blank=True, verbose_name='Description (Arabic)'),
|
|
),
|
|
migrations.AddField(
|
|
model_name='surveytemplate',
|
|
name='negative_threshold',
|
|
field=models.DecimalField(decimal_places=1, default=3.0, help_text='Scores below this trigger PX actions (out of 5)', max_digits=3),
|
|
),
|
|
migrations.AddField(
|
|
model_name='surveytemplate',
|
|
name='scoring_method',
|
|
field=models.CharField(choices=[('average', 'Average Score'), ('weighted', 'Weighted Average'), ('nps', 'NPS Calculation')], default='average', max_length=20),
|
|
),
|
|
migrations.AddField(
|
|
model_name='surveytemplate',
|
|
name='survey_type',
|
|
field=models.CharField(choices=[('stage', 'Journey Stage Survey'), ('complaint_resolution', 'Complaint Resolution Satisfaction'), ('general', 'General Feedback'), ('nps', 'Net Promoter Score')], db_index=True, default='stage', max_length=50),
|
|
),
|
|
migrations.AddField(
|
|
model_name='surveytemplate',
|
|
name='version',
|
|
field=models.IntegerField(default=1),
|
|
),
|
|
migrations.AlterField(
|
|
model_name='surveyinstance',
|
|
name='sent_at',
|
|
field=models.DateTimeField(blank=True, db_index=True, null=True),
|
|
),
|
|
migrations.AlterField(
|
|
model_name='surveyinstance',
|
|
name='status',
|
|
field=models.CharField(choices=[('active', 'Active'), ('inactive', 'Inactive'), ('pending', 'Pending'), ('completed', 'Completed'), ('cancelled', 'Cancelled')], db_index=True, default='pending', max_length=20),
|
|
),
|
|
migrations.AlterField(
|
|
model_name='surveytemplate',
|
|
name='is_active',
|
|
field=models.BooleanField(db_index=True, default=True),
|
|
),
|
|
migrations.AlterField(
|
|
model_name='surveytemplate',
|
|
name='name_ar',
|
|
field=models.CharField(blank=True, max_length=200, verbose_name='Name (Arabic)'),
|
|
),
|
|
migrations.AddIndex(
|
|
model_name='surveyinstance',
|
|
index=models.Index(fields=['patient', '-created_at'], name='surveys_sur_patient_7e68b1_idx'),
|
|
),
|
|
migrations.AddIndex(
|
|
model_name='surveyinstance',
|
|
index=models.Index(fields=['status', '-sent_at'], name='surveys_sur_status_ce377b_idx'),
|
|
),
|
|
migrations.AddIndex(
|
|
model_name='surveyinstance',
|
|
index=models.Index(fields=['is_negative', '-completed_at'], name='surveys_sur_is_nega_46c933_idx'),
|
|
),
|
|
migrations.AddIndex(
|
|
model_name='surveytemplate',
|
|
index=models.Index(fields=['hospital', 'survey_type', 'is_active'], name='surveys_sur_hospita_0c8e30_idx'),
|
|
),
|
|
migrations.AddField(
|
|
model_name='surveyquestion',
|
|
name='survey_template',
|
|
field=models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, related_name='questions', to='surveys.surveytemplate'),
|
|
),
|
|
migrations.AddField(
|
|
model_name='surveyresponse',
|
|
name='question',
|
|
field=models.ForeignKey(on_delete=django.db.models.deletion.PROTECT, related_name='responses', to='surveys.surveyquestion'),
|
|
),
|
|
migrations.AddField(
|
|
model_name='surveyresponse',
|
|
name='survey_instance',
|
|
field=models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, related_name='responses', to='surveys.surveyinstance'),
|
|
),
|
|
migrations.AddIndex(
|
|
model_name='surveyquestion',
|
|
index=models.Index(fields=['survey_template', 'order'], name='surveys_sur_survey__d8acd5_idx'),
|
|
),
|
|
migrations.AlterUniqueTogether(
|
|
name='surveyresponse',
|
|
unique_together={('survey_instance', 'question')},
|
|
),
|
|
]
|