from django import forms
from crispy_forms.helper import FormHelper
from crispy_forms.layout import Layout, Submit, Row, Column, HTML, Field
from crispy_forms.bootstrap import Alert
from .models import Question, QuestionState, Subquestion, EvaluationType, QuestionReview
from participants.models import Participant
from .widgets import SimpleMDEWidget


class SubquestionForm(forms.ModelForm):
    """
    Form for creating and editing individual subquestions.
    
    Subquestions are automatically-gradable components with unique answers.
    Uses string-based ordering for flexible insertion (a, b, c, etc.).
    """
    
    # Required: Subquestion text
    text = forms.CharField(
        label='Question Text *',
        widget=forms.Textarea(attrs={
            'rows': 3,
            'placeholder': 'Enter the subquestion text...',
            'class': 'form-control'
        }),
        help_text='Required: The subquestion text (supports basic Markdown)'
    )
    
    # Required: Expected answer
    answer = forms.CharField(
        label='Expected Answer *',
        widget=forms.TextInput(attrs={
            'placeholder': 'Expected answer for automatic checking',
            'class': 'form-control'
        }),
        help_text='Required: The exact answer expected (case-sensitive for exact_match)'
    )
    
    # Optional: Rationale
    rationale = forms.CharField(
        required=False,
        label='Rationale (Optional)',
        widget=forms.Textarea(attrs={
            'rows': 2,
            'placeholder': 'Explanation of why this is the correct answer...',
            'class': 'form-control'
        }),
        help_text='Optional: Explanation of the correct answer'
    )
    
    # Optional: Points (defaults to 1)
    points = forms.IntegerField(
        required=False,
        label='Points (Optional)',
        min_value=1,
        widget=forms.NumberInput(attrs={
            'placeholder': '1',
            'class': 'form-control',
            'min': '1'
        }),
        help_text='Optional: Point value (defaults to 1 if not specified)'
    )
    
    class Meta:
        model = Subquestion
        fields = ['text', 'answer', 'rationale', 'points', 'evaluation_type']  # subquestion_order is auto-generated
        labels = {
            'evaluation_type': 'Evaluation Method *',
        }
        widgets = {
            'evaluation_type': forms.Select(attrs={'class': 'form-select'}),
        }
    
    def __init__(self, *args, **kwargs):
        super().__init__(*args, **kwargs)
        
        # Configure evaluation type field
        self.fields['evaluation_type'].queryset = EvaluationType.objects.all()
        self.fields['evaluation_type'].help_text = 'Required: How answers will be evaluated automatically'
        
        # Set default values for new subquestions
        if not self.instance.pk:
            self.fields['points'].initial = 1
            # Set default evaluation type if available
            try:
                default_eval = EvaluationType.objects.get(evaluation_type='exact_match')
                self.fields['evaluation_type'].initial = default_eval.pk
            except EvaluationType.DoesNotExist:
                pass
    
    def clean_points(self):
        """Ensure points are positive."""
        points = self.cleaned_data.get('points')
        if points is not None and points <= 0:
            raise forms.ValidationError("Points must be positive.")
        return points or 1  # Default to 1 if not specified


class SubquestionFormSet(forms.BaseFormSet):
    """
    Formset for managing multiple subquestions within a question.
    
    Handles dynamic addition/removal of subquestions with automatic ordering.
    """
    
    def __init__(self, *args, **kwargs):
        super().__init__(*args, **kwargs)
        
    def clean(self):
        """Validate the formset as a whole."""
        if any(self.errors):
            return
            
        # Auto-generate subquestion_order for valid forms
        valid_forms = [form for form in self.forms if form.is_valid() and not form.cleaned_data.get('DELETE', False)]
        
        for i, form in enumerate(valid_forms):
            if form.cleaned_data:  # Only process forms with data
                # Auto-generate order using letters: a, b, c, etc.
                form.cleaned_data['subquestion_order'] = chr(ord('a') + i)


# Create the formset class
SubquestionFormSet = forms.formset_factory(
    SubquestionForm,
    formset=SubquestionFormSet,
    extra=0,  # Don't show extra forms by default
    can_delete=True,  # Allow deletion
    can_order=False,  # We handle ordering automatically
)


class QuestionForm(forms.ModelForm):
    """
    Form for creating and editing questions with LaTeX + Markdown support.

    Uses SimpleMDE for rich text editing with live preview.
    Features professional two-column layout and comprehensive validation.
    """
    
    # Use SimpleMDE editor for Markdown + LaTeX
    text = forms.CharField(
        required=True,
        widget=SimpleMDEWidget(),
        help_text='Question content using Markdown + LaTeX. Use $x^2$ for inline math and $$x^2 + y^2 = z^2$$ for display math.'
    )

    solution = forms.CharField(
        required=False,
        widget=SimpleMDEWidget(),
        help_text='Complete solution with proof (optional). Use same Markdown + LaTeX syntax.'
    )
    
    class Meta:
        model = Question
        fields = [
            'title', 'author', 'status', 'text', 'solution',
            'difficulty_background', 'difficulty_reasoning', 
            'difficulty_insight', 'difficulty_compute', 'tags'
        ]
        widgets = {
            'title': forms.TextInput(attrs={
                'placeholder': 'Enter a descriptive title for the question...',
                'class': 'form-control-lg'
            }),
            'tags': forms.TextInput(attrs={
                'placeholder': 'Comma-separated tags (e.g., group theory, algebra, topology)',
                'class': 'form-control'
            }),
            'difficulty_background': forms.Select(attrs={'class': 'form-select'}),
            'difficulty_reasoning': forms.Select(attrs={'class': 'form-select'}),
            'difficulty_insight': forms.Select(attrs={'class': 'form-select'}),
            'difficulty_compute': forms.Select(attrs={'class': 'form-select'}),
        }
    
    def __init__(self, *args, **kwargs):
        # Extract user from kwargs if provided
        self.user = kwargs.pop('user', None)
        super().__init__(*args, **kwargs)
        
        # Configure crispy forms helper
        self.helper = FormHelper()
        self.helper.form_method = 'post'
        self.helper.form_class = 'question-form'
        
        # Configure field properties and choices
        self._setup_field_configurations()
        
        # Determine if this is an edit (existing instance)
        is_edit = bool(self.instance and self.instance.pk)
        
        # Build layout components
        layout_components = [
            # Form header
            HTML('''
                <div class="text-center mb-4">
                    <div class="bg-primary bg-gradient rounded-circle d-inline-flex align-items-center justify-content-center mb-3" 
                         style="width: 60px; height: 60px;">
                        <i class="bi bi-file-earmark-text text-white fs-3"></i>
                    </div>
                    <h3 class="mb-1">{}</h3>
                    <p class="text-muted">{}</p>'''.format(
                        'Edit Question' if is_edit else 'Create New Question',
                        'Update question content and metadata' if is_edit else 'Add a new mathematical proof question to the benchmark'
                    ) + '''
                </div>
            '''),
            
            # Basic Information Section
            HTML('<div class="card mb-4"><div class="card-header"><h5 class="mb-0"><i class="bi bi-info-circle me-2"></i>Basic Information</h5></div><div class="card-body">'),
        ]
        
        # Add title and status row based on user role
        if self.user and hasattr(self.user, 'participant') and self.user.participant.is_admin:
            # Admin sees status dropdown
            layout_components.append(
                Row(
                    Column('title', css_class='form-group col-md-8'),
                    Column('status', css_class='form-group col-md-4'),
                )
            )
        else:
            # Non-admin has hidden status field
            layout_components.extend([
                Field('status'),  # Hidden field
                Row(
                    Column('title', css_class='form-group col-md-12'),
                )
            ])
        
        # Add author row - different layouts for admin vs non-admin
        show_author_field = (
            self.user and 
            hasattr(self.user, 'participant') and 
            self.user.participant.is_admin
        )
        
        if show_author_field:
            # Admin sees author dropdown
            layout_components.append(
                Row(
                    Column('author', css_class='form-group col-md-6'),
                    Column('tags', css_class='form-group col-md-6'),
                )
            )
        else:
            # Non-admin has hidden author field, tags get full width
            layout_components.extend([
                Field('author'),  # Hidden field
                Row(
                    Column('tags', css_class='form-group col-md-12'),
                )
            ])
        
        layout_components.append(HTML('</div></div>'))
        
        # Continue with rest of layout
        layout_components.extend([
            
            # Question Content Section
            HTML('<div class="card mb-4"><div class="card-header"><h5 class="mb-0"><i class="bi bi-question-circle me-2"></i>Question Content</h5></div><div class="card-body">'),
            Field('text', css_class='simplemde-field'),
            HTML('</div></div>'),
            
            # AI Testing Section
            HTML('''
                <div class="card mb-4" id="ai-testing-section">
                    <div class="card-header d-flex justify-content-between align-items-center">
                        <h5 class="mb-0"><i class="bi bi-robot me-2"></i>AI Solution Attempt</h5>
                        <small class="text-muted">Test with GPT-5</small>
                    </div>
                    <div class="card-body text-center">
                        <div class="mb-3">
                            <p class="text-muted mb-3">
                                <i class="bi bi-info-circle me-1"></i>
                                Test your question with GPT-5, OpenAI's most advanced model. The AI will use web search and code interpreter
                                to provide a comprehensive step-by-step solution, without seeing your provided answer.
                            </p>
                            <button type="button" class="btn btn-outline-primary btn-lg px-4" id="test-question-btn">
                                <i class="bi bi-cpu me-2"></i>Get AI Solution Attempt
                            </button>
                            <div class="mt-2">
                                <small class="text-muted" id="rate-limit-info">
                                    Loading limits...
                                </small>
                            </div>
                        </div>
                        
                        <!-- Previous AI Test Result (for editing) -->
                        {% if latest_ai_test %}
                        {% load question_extras %}
                        <div class="mt-4">
                            <div class="alert alert-light border-info">
                                <div class="d-flex justify-content-between align-items-center mb-2">
                                    <h6 class="mb-0"><i class="bi bi-history me-1"></i>Previous AI Solution</h6>
                                    <small class="text-muted">{{ latest_ai_test.created_at|date:"M j, Y g:i A" }}</small>
                                </div>
                                {% include 'includes/model_answer_display.html' with answer_text=latest_ai_test.response show_toggle=True title="" %}
                                <div class="mt-2 pt-2 border-top">
                                    <small class="text-muted">
                                        <i class="bi bi-clock me-1"></i>{{ latest_ai_test.response_time_ms }}ms |
                                        ${{ latest_ai_test.cost_estimate|floatformat:4 }} |
                                        {{ latest_ai_test.model_name }} with web search and code interpreter
                                    </small>
                                </div>
                            </div>
                        </div>
                        {% endif %}
                        
                        <!-- AI Response Display Area -->
                        <div id="ai-response-area" class="mt-4" style="display: none;">
                            <div class="alert alert-info">
                                <div class="d-flex justify-content-between align-items-center mb-2">
                                    <h6 class="mb-0"><i class="bi bi-robot me-1"></i>AI Solution Attempt</h6>
                                    <small class="text-muted" id="response-metadata"></small>
                                </div>
                                <!-- Toggle buttons -->
                                <div class="d-flex justify-content-end mb-2">
                                    <div class="btn-group" role="group">
                                        <button type="button" class="btn btn-sm btn-outline-secondary active" 
                                                onclick="showAIRenderedContent(this)">
                                            <i class="bi bi-eye"></i> Rendered
                                        </button>
                                        <button type="button" class="btn btn-sm btn-outline-secondary" 
                                                onclick="showAIRawContent(this)">
                                            <i class="bi bi-code-slash"></i> Raw
                                        </button>
                                    </div>
                                </div>
                                <div id="ai-response-content" class="mt-3 text-start">
                                    <!-- AI response will be inserted here (rendered) -->
                                </div>
                                <div id="ai-response-raw" class="mt-3 text-start border rounded p-3 bg-light" style="display: none;">
                                    <pre id="ai-response-raw-content" style="white-space: pre-wrap; word-wrap: break-word; margin: 0;">
                                        <!-- AI response raw text will be inserted here -->
                                    </pre>
                                </div>
                                <div class="mt-3 pt-2 border-top">
                                    <small class="text-muted">
                                        <i class="bi bi-clock me-1"></i><span id="response-time"></span> |
                                        <span id="response-cost"></span> |
                                        <span id="remaining-tests"></span>
                                    </small>
                                </div>
                            </div>
                        </div>
                        
                        <!-- Loading State -->
                        <div id="ai-loading" class="mt-4" style="display: none;">
                            <div>
                                <div class="d-flex align-items-center mb-2">
                                    <div class="spinner-border text-primary me-3" role="status">
                                        <span class="visually-hidden">Loading...</span>
                                    </div>
                                    <div class="flex-grow-1">
                                        <div class="fw-bold">AI is solving your question...</div>
                                        <small class="text-muted">This may take up to 30 minutes for complex mathematical reasoning</small>
                                    </div>
                                </div>
                                <div class="text-center mt-3">
                                    <button type="button" class="btn btn-danger btn-sm" id="cancel-ai-test">
                                        <i class="bi bi-x-circle me-1"></i>Cancel Test
                                    </button>
                                </div>
                            </div>
                        </div>
                        
                        <!-- Error Display -->
                        <div id="ai-error" class="mt-4" style="display: none;">
                            <div class="alert alert-danger">
                                <h6 class="mb-2"><i class="bi bi-exclamation-triangle me-1"></i>Error</h6>
                                <div id="ai-error-content"></div>
                            </div>
                        </div>
                    </div>
                </div>
            '''),
            
            # Solution Section
            HTML('<div class="card mb-4"><div class="card-header"><h5 class="mb-0"><i class="bi bi-lightbulb me-2"></i>Solution</h5></div><div class="card-body">'),
            Field('solution', css_class='simplemde-field'),
            HTML('</div></div>'),
            
            # Difficulty Ratings Section
            HTML('<div class="card mb-4"><div class="card-header"><h5 class="mb-0"><i class="bi bi-speedometer2 me-2"></i>Difficulty Ratings</h5></div><div class="card-body">'),
            HTML('<p class="text-muted mb-3">Rate each aspect from 1 (Easy) to 5 (Very Hard), or leave blank if not applicable.</p>'),
            Row(
                Column('difficulty_background', css_class='form-group col-md-3'),
                Column('difficulty_reasoning', css_class='form-group col-md-3'),
                Column('difficulty_insight', css_class='form-group col-md-3'),
                Column('difficulty_compute', css_class='form-group col-md-3'),
            ),
            HTML('</div></div>'),
            
            # Subquestions Section (optional auto-gradable components)
            HTML('''
                <div class="card mb-4">
                    <div class="card-header d-flex justify-content-between align-items-center">
                        <h5 class="mb-0"><i class="bi bi-list-ol me-2"></i>Subquestions</h5>
                        <small class="text-muted">Optional: Auto-gradable components</small>
                    </div>
                    <div class="card-body">
                        <div class="mb-3">
                            <p class="text-muted mb-2">
                                <i class="bi bi-info-circle me-1"></i>
                                Subquestions are automatically gradable components with specific expected answers.
                                They're completely optional - you can create a question without any subquestions.
                            </p>
                            <div class="d-flex align-items-center gap-2">
                                <button type="button" class="btn btn-outline-primary btn-sm" id="add-subquestion">
                                    <i class="bi bi-plus-circle me-1"></i>Add Subquestion
                                </button>
                                <small class="text-muted">Fields marked with * are required</small>
                            </div>
                        </div>
                        
                        <div id="subquestions-container">
                            <!-- Subquestion forms will be dynamically added here -->
                        </div>
                        
                        <div id="no-subquestions" class="text-center py-3 text-muted" style="display: none;">
                            <i class="bi bi-list-ol" style="font-size: 1.5rem;"></i>
                            <p class="mb-0 mt-2">No subquestions added yet</p>
                            <small>Click "Add Subquestion" above to create auto-gradable components</small>
                        </div>
                    </div>
                </div>
            '''),
            
            # Form actions
            HTML('<div class="d-flex justify-content-between align-items-center">'),
            HTML('''
                <a href="{% url 'questions:list' %}" class="btn btn-outline-secondary">
                    <i class="bi bi-arrow-left me-1"></i>
                    Back to Questions
                </a>
            '''),
            HTML('<div>'),
            HTML('<button type="button" id="save-current-draft" class="btn btn-outline-primary me-2 btn-lg px-4" title="Save current state without leaving the page"><i class="bi bi-floppy me-1"></i>Save</button>'),
            Submit('save', 'Save and Exit' if is_edit else 'Save Question', css_class='btn btn-primary btn-lg px-4'),
            HTML('</div>'),
            HTML('</div>'),
        ])
        
        # Set the complete layout
        self.helper.layout = Layout(*layout_components)
    
    def _setup_field_configurations(self):
        """Configure field properties, choices, and validation."""
        
        # Difficulty rating choices
        DIFFICULTY_CHOICES = [
            ('', 'Not Rated'),
            (1, '1 - Very Easy'),
            (2, '2 - Easy'), 
            (3, '3 - Moderate'),
            (4, '4 - Hard'),
            (5, '5 - Very Hard'),
        ]
        
        # Configure difficulty fields - replace widgets with choice fields
        for field_name in ['difficulty_background', 'difficulty_reasoning', 'difficulty_insight', 'difficulty_compute']:
            self.fields[field_name] = forms.ChoiceField(
                choices=DIFFICULTY_CHOICES,
                required=False,
                widget=forms.Select(attrs={'class': 'form-select'}),
                initial=''
            )
        
        # Configure field labels and help text
        self.fields['title'].required = True
        self.fields['title'].help_text = 'A concise, descriptive title for the question'
        
        # Configure author field based on user role
        if self.user and hasattr(self.user, 'participant'):
            participant = self.user.participant
            if participant.is_admin:
                # Admins can select any participant as author
                self.fields['author'].queryset = Participant.objects.all().order_by('name')
                self.fields['author'].help_text = 'Question author/creator (admin can select any participant)'
            else:
                # Contributors/Reviewers can only select themselves
                self.fields['author'].queryset = Participant.objects.filter(id=participant.id)
                self.fields['author'].help_text = 'Question author (you)'
                # Set the current user as default
                self.fields['author'].initial = participant
                # Make it read-only by using a hidden field for non-admins
                self.fields['author'].widget = forms.HiddenInput()
        else:
            # Fallback: show all participants if no user context
            self.fields['author'].queryset = Participant.objects.all().order_by('name')
            self.fields['author'].help_text = 'Question author/creator'
        
        self.fields['author'].required = True
        
        # Configure status field based on user role
        self.fields['status'].queryset = QuestionState.objects.all().order_by('status')
        self.fields['status'].required = True
        
        if self.user and hasattr(self.user, 'participant'):
            if not self.user.participant.is_admin:
                # Non-admins cannot change status
                if self.instance.pk:
                    # For existing questions, keep current status
                    self.fields['status'].initial = self.instance.status
                else:
                    # For new questions, set to draft
                    try:
                        draft_status = QuestionState.objects.get(status='draft')
                        self.fields['status'].initial = draft_status.pk
                    except QuestionState.DoesNotExist:
                        pass
                
                # Make field read-only by using a hidden field
                self.fields['status'].widget = forms.HiddenInput()
                self.fields['status'].help_text = 'Status is managed through the review workflow'
            else:
                # Admins can change status
                self.fields['status'].help_text = 'Current status in the review workflow (admin only)'
        else:
            # Fallback for no user context
            self.fields['status'].help_text = 'Current status in the review workflow'
            # Set default status to draft for new questions
            if not self.instance.pk:
                try:
                    draft_status = QuestionState.objects.get(status='draft')
                    self.fields['status'].initial = draft_status.pk
                except QuestionState.DoesNotExist:
                    pass
        
        self.fields['tags'].required = False
        self.fields['tags'].help_text = 'Keywords for categorization (comma-separated)'
        
        # Configure difficulty field labels
        self.fields['difficulty_background'].label = 'Background Knowledge'
        self.fields['difficulty_reasoning'].label = 'Reasoning Complexity' 
        self.fields['difficulty_insight'].label = 'Mathematical Insight'
        self.fields['difficulty_compute'].label = 'Computational Requirements'
        
        # Set required fields
        self.fields['text'].required = True
        self.fields['solution'].required = False
        
        # Add CSS classes for styling
        for field_name, field in self.fields.items():
            if field_name not in ['text', 'solution']:  # Martor fields have their own styling
                field.widget.attrs.update({
                    'class': field.widget.attrs.get('class', '') + ' form-control'
                })
    
    def clean_title(self):
        """Validate question title."""
        title = self.cleaned_data.get('title', '').strip()
        
        if not title:
            raise forms.ValidationError("Question title is required.")
        
        if len(title) < 1:
            raise forms.ValidationError("Title must be at least 1 character long.")
        
        if len(title) > 200:
            raise forms.ValidationError("Title must be 200 characters or less.")
        
        return title
    
    def clean_text(self):
        """Validate question text content."""
        text = self.cleaned_data.get('text', '').strip()
        
        if not text:
            raise forms.ValidationError("Question text is required.")
        
        if len(text) < 1:
            raise forms.ValidationError("Question text must be at least 1 character long.")
        
        return text
    
    def clean_tags(self):
        """Clean and validate tags."""
        tags = self.cleaned_data.get('tags', '').strip()
        
        if tags:
            # Clean up tag formatting
            tag_list = [tag.strip() for tag in tags.split(',') if tag.strip()]
            if len(tag_list) > 10:
                raise forms.ValidationError("Maximum 10 tags allowed.")
            
            # Rejoin cleaned tags
            tags = ', '.join(tag_list)
        
        return tags
    
    def clean(self):
        """Custom validation for the entire form."""
        cleaned_data = super().clean()
        
        # Convert difficulty values to integers (or None for empty)
        # Database allows NULL or values 1-5 (enforced by CHECK constraints)
        for field_name in ['difficulty_background', 'difficulty_reasoning', 'difficulty_insight', 'difficulty_compute']:
            value = cleaned_data.get(field_name)
            if value == '' or value is None:
                cleaned_data[field_name] = None
            else:
                try:
                    int_value = int(value)
                    if 1 <= int_value <= 5:
                        cleaned_data[field_name] = int_value
                    else:
                        # Invalid range - set to None and add form error
                        cleaned_data[field_name] = None
                        self.add_error(field_name, f'Value must be between 1 and 5.')
                except (ValueError, TypeError):
                    # Invalid value - set to None and add form error
                    cleaned_data[field_name] = None
                    self.add_error(field_name, f'Please select a valid difficulty rating.')
        
        return cleaned_data
    
    def save(self, commit=True):
        """Save question with proper handling of difficulty constraints."""
        question = super().save(commit=False)
        
        # Handle difficulty values according to database CHECK constraints
        # Database allows NULL or values 1-5 (enforced by CHECK constraints)
        for field_name in ['difficulty_background', 'difficulty_reasoning', 'difficulty_insight', 'difficulty_compute']:
            value = self.cleaned_data.get(field_name)
            if value == '' or value is None:
                # Set to None (NULL in database) - this is allowed
                setattr(question, field_name, None)
            else:
                try:
                    int_value = int(value)
                    if 1 <= int_value <= 5:
                        setattr(question, field_name, int_value)
                    else:
                        # Invalid range - set to None
                        setattr(question, field_name, None)
                except (ValueError, TypeError):
                    # Invalid value - set to None
                    setattr(question, field_name, None)
        
        # Django now handles creation_time and last_modified with auto_now fields
        if commit:
            question.save()
        
        return question


class QuestionReviewForm(forms.ModelForm):
    """
    Form for submitting reviews of questions.
    
    Supports Markdown + LaTeX for review comments and includes
    decision choices and anonymity options.
    """
    
    comment = forms.CharField(
        required=True,
        widget=forms.Textarea(attrs={
            'rows': 8,
            'placeholder': 'Enter your review feedback here. You can use Markdown syntax for formatting.\n\nExample:\n**Issue**: The notation in line 3 is unclear\n**Suggestion**: Consider using $f: \\mathbb{R} \\to \\mathbb{R}$ instead',
            'class': 'form-control'
        }),
        help_text='Your review feedback using Markdown + LaTeX. Be constructive and specific about issues or improvements needed.'
    )
    
    decision = forms.ChoiceField(
        required=True,
        choices=[('', 'Please select a decision...')] + QuestionReview.DECISION_CHOICES,
        widget=forms.Select(attrs={'class': 'form-select'}),
        help_text='You must select a decision for your review.'
    )
    
    class Meta:
        model = QuestionReview
        fields = ['comment', 'decision', 'is_anonymous']
        widgets = {
            'is_anonymous': forms.CheckboxInput(attrs={'class': 'form-check-input'}),
        }
    
    def __init__(self, *args, **kwargs):
        show_decline = kwargs.pop('show_decline', False)
        super().__init__(*args, **kwargs)
        
        # Configure crispy forms helper
        self.helper = FormHelper()
        self.helper.form_method = 'post'
        self.helper.form_class = 'review-form'
        
        # Configure field properties (decision help text set in field definition)
        self.fields['is_anonymous'].help_text = 'Check to submit review anonymously (your name will not be shown to the author)'
        self.fields['is_anonymous'].label = 'Submit anonymously'
        
        # Set up layout
        self.helper.layout = Layout(
            HTML('''
                <div class="card">
                    <div class="card-header bg-primary text-white">
                        <h5 class="mb-0">
                            <i class="bi bi-chat-left-text me-2"></i>
                            Submit Review
                        </h5>
                    </div>
                    <div class="card-body">
            '''),
            
            # Decision field
            Row(
                Column('decision', css_class='form-group col-md-8'),
                Column('is_anonymous', css_class='form-group col-md-4 d-flex align-items-center'),
            ),
            
            # Review comment
            HTML('<div class="mt-3">'),
            Field('comment'),
            HTML('</div>'),
            
            # Guidelines collapsible
            HTML('''
                <div class="mt-3">
                    <div class="card">
                        <div class="card-header p-0">
                            <button class="btn btn-link w-100 text-start" type="button" onclick="toggleGuidelines()">
                                <i class="bi bi-lightbulb me-2"></i>
                                Review Guidelines
                                <i class="bi bi-chevron-down float-end" id="guidelinesChevron"></i>
                            </button>
                        </div>
                        <div id="guidelinesCollapse" class="collapse" style="transition: none;">
                            <div class="card-body">
                                <h6>What makes a good benchmark question?</h6>
                                <ul class="mb-3">
                                    <li><strong>Clear problem statement:</strong> Unambiguous mathematical notation and well-defined objectives</li>
                                    <li><strong>Appropriate difficulty:</strong> Challenging but solvable within the target domain</li>
                                    <li><strong>Complete solution:</strong> Author should provide a correct, detailed solution</li>
                                    <li><strong>Proper formatting:</strong> Good use of LaTeX and clear mathematical presentation</li>
                                </ul>
                                
                                <h6>Common issues to look for:</h6>
                                <ul class="mb-3">
                                    <li>Typos or grammatical errors</li>
                                    <li>Unclear or ambiguous wording</li>
                                    <li>Missing or incorrect mathematical notation</li>
                                    <li>Solution errors or incomplete reasoning</li>
                                    <li>Inappropriate difficulty rating</li>
                                </ul>
                                
                                <h6>Decision guidelines:</h6>
                                <ul>
                                    <li><strong>Accept:</strong> Ready for benchmark inclusion with minimal or no changes</li>
                                    <li><strong>Needs revision:</strong> Good question but requires specific improvements</li>
                                    <li><strong>Not suitable:</strong> Fundamental issues that make it inappropriate for the benchmark</li>
                                </ul>
                                
                                <div class="mt-3">
                                    <a href="{% url 'questions:review_guidelines' %}" target="_blank" class="btn btn-outline-info btn-sm">
                                        <i class="bi bi-book me-1"></i>
                                        View Full Guidelines
                                    </a>
                                </div>
                            </div>
                        </div>
                    </div>
                </div>
            '''),
            
            # Submit buttons (conditionally include decline button)
            HTML('''
                    <div class="d-flex justify-content-''' + ('between' if show_decline else 'end') + ''' mt-4">
                        ''' + ('''<button type="button" class="btn btn-outline-danger" onclick="confirmDeclineReview()">
                            <i class="bi bi-x-circle me-1"></i>
                            Decline Review Request
                        </button>''' if show_decline else '') + '''
                        <div>
                            <button type="button" class="btn btn-outline-secondary me-2" onclick="window.location.reload()">
                                Cancel
                            </button>
                            <button type="submit" class="btn btn-primary">
                                <i class="bi bi-send me-1"></i>
                                Submit Review
                            </button>
                        </div>
                    </div>
                </div>
                </div>
            '''),
        )
    
    def clean_comment(self):
        """Validate review comment."""
        comment = self.cleaned_data.get('comment', '').strip()
        
        if not comment:
            raise forms.ValidationError("Review comment is required.")
        
        if len(comment) < 10:
            raise forms.ValidationError("Please provide a more detailed review (at least 10 characters).")
        
        return comment
    
    def clean_decision(self):
        """Validate that a decision is selected."""
        decision = self.cleaned_data.get('decision')
        
        if not decision:
            raise forms.ValidationError("Please select a decision for your review.")
        
        return decision