"""
Custom widgets for question forms.

Provides SimpleMDE editor widget for Markdown + LaTeX editing.
"""
from django import forms
from django.conf import settings
from django.urls import reverse


class SimpleMDEWidget(forms.Textarea):
    """
    SimpleMDE Markdown editor widget with LaTeX support.

    Features:
    - Clean Markdown editing interface
    - Live preview with MathJax rendering
    - Toolbar with common formatting options
    - LaTeX-friendly shortcuts
    - Auto-save support
    """

    template_name = 'widgets/simplemde.html'

    class Media:
        css = {
            'all': (
                'https://cdn.jsdelivr.net/simplemde/latest/simplemde.min.css',
            )
        }
        js = (
            'https://cdn.jsdelivr.net/simplemde/latest/simplemde.min.js',
        )

    def __init__(self, attrs=None, config=None):
        """
        Initialize SimpleMDE widget.

        Args:
            attrs: Standard widget attributes
            config: SimpleMDE-specific configuration dict
        """
        default_attrs = {
            'class': 'simplemde-editor',
            'rows': 15,
        }
        if attrs:
            default_attrs.update(attrs)

        super().__init__(attrs=default_attrs)

        # Default SimpleMDE configuration
        self.config = {
            'spellChecker': False,
            'status': ['lines', 'words', 'cursor'],
            'placeholder': 'Enter text using Markdown + LaTeX. Use $x^2$ for inline math and $$x^2 + y^2 = z^2$$ for display math.',
            'renderingConfig': {
                'singleLineBreaks': False,
            },
            'toolbar': [
                'bold', 'italic', 'heading', '|',
                'quote', 'unordered-list', 'ordered-list', '|',
                'link', 'image', '|',
                'preview', 'side-by-side', 'fullscreen', '|',
                'guide',
                {
                    'name': 'inline-math',
                    'action': self._get_inline_math_action(),
                    'className': 'fa fa-dollar',
                    'title': 'Insert Inline Math ($...$)',
                },
                {
                    'name': 'display-math',
                    'action': self._get_display_math_action(),
                    'className': 'fa fa-superscript',
                    'title': 'Insert Display Math ($$...$$)',
                },
            ],
            'previewRender': 'SimpleMDE.prototype.markdown',  # Will be customized in template
        }

        # Merge with custom config if provided
        if config:
            self.config.update(config)

    def _get_inline_math_action(self):
        """JavaScript function to insert inline math delimiters."""
        return '''function(editor) {
            var cm = editor.codemirror;
            var selection = cm.getSelection();
            cm.replaceSelection('$' + selection + '$');
            if (!selection) {
                var cursor = cm.getCursor();
                cursor.ch -= 1;
                cm.setCursor(cursor);
            }
        }'''

    def _get_display_math_action(self):
        """JavaScript function to insert display math delimiters."""
        return '''function(editor) {
            var cm = editor.codemirror;
            var selection = cm.getSelection();
            cm.replaceSelection('$$\\n' + selection + '\\n$$');
            if (!selection) {
                var cursor = cm.getCursor();
                cursor.line -= 1;
                cm.setCursor(cursor);
            }
        }'''

    def get_context(self, name, value, attrs):
        """Add configuration to widget context."""
        context = super().get_context(name, value, attrs)
        context['widget']['config'] = self.config
        context['widget']['config_json'] = self._get_config_json()
        context['widget']['field_id'] = attrs.get('id', name)
        return context

    def _get_config_json(self):
        """Convert config to JSON for JavaScript."""
        import json

        # Create a safe config dict for JSON serialization
        safe_config = self.config.copy()

        # Remove function definitions (they'll be added in template)
        toolbar = []
        for item in self.config.get('toolbar', []):
            if isinstance(item, dict):
                # Custom toolbar item with JavaScript function
                toolbar.append({
                    'name': item['name'],
                    'className': item.get('className', 'fa fa-star'),
                    'title': item.get('title', ''),
                    '_action_type': 'function',  # Marker for template
                })
            else:
                toolbar.append(item)

        safe_config['toolbar'] = toolbar

        return json.dumps(safe_config)
