{% load static %}
<textarea name="{{ widget.name }}" id="{{ widget.field_id }}"{% if widget.is_required %} required{% endif %}{% for name, value in widget.attrs.items %} {{ name }}="{{ value }}"{% endfor %}>{{ widget.value|default:"" }}</textarea>
<script>
(function() {
    var fieldId = '{{ widget.field_id }}';
    var maxRetries = 50;  // Wait up to 5 seconds (50 * 100ms)
    var retryCount = 0;

    function tryInitEditor() {
        // Wait for SimpleMDE library to be loaded
        if (typeof SimpleMDE === 'undefined') {
            retryCount++;
            if (retryCount < maxRetries) {
                setTimeout(tryInitEditor, 100);
            } else {
                console.error('SimpleMDE library failed to load after ' + maxRetries + ' retries');
            }
            return;
        }
        initEditor();
    }

    // Start trying to initialize after DOM is ready
    if (document.readyState === 'loading') {
        document.addEventListener('DOMContentLoaded', tryInitEditor);
    } else {
        tryInitEditor();
    }

    function initEditor() {
        // Initialize SimpleMDE for this textarea
        var textarea = document.getElementById(fieldId);
        if (!textarea) {
            console.error('Textarea not found: ' + fieldId);
            return;
        }

        // Skip if already initialized
        if (textarea.simplemde) {
            console.log('SimpleMDE already initialized for:', fieldId);
            return;
        }

        // Parse configuration
        var config = {{ widget.config_json|safe }};

        // Add element reference
        config.element = textarea;

        // Custom preview renderer with MathJax support
        config.previewRender = function(plainText, preview) {
            // Send to server for Markdown + LaTeX rendering
            fetch('{% url "questions:preview_markdown" %}', {
                method: 'POST',
                headers: {
                    'Content-Type': 'application/json',
                    'X-CSRFToken': document.querySelector('[name=csrfmiddlewaretoken]').value,
                    'X-Requested-With': 'XMLHttpRequest'
                },
                body: JSON.stringify({ text: plainText })
            })
            .then(response => response.json())
            .then(data => {
                if (data.html) {
                    preview.innerHTML = data.html;
                    // Render MathJax in preview
                    if (typeof MathJax !== 'undefined' && MathJax.typesetPromise) {
                        MathJax.typesetPromise([preview]).catch(function(err) {
                            console.log('MathJax error:', err);
                        });
                    }
                }
            })
            .catch(error => {
                console.error('Preview error:', error);
                preview.innerHTML = '<div class="alert alert-warning">Preview temporarily unavailable</div>';
            });

            return '<div class="text-muted">Loading preview...</div>';
        };

        // Rebuild toolbar with custom math buttons
        var toolbar = [];
        config.toolbar.forEach(function(item) {
            if (typeof item === 'object' && item._action_type === 'function') {
                // Custom toolbar item with JavaScript action
                var customItem = {
                    name: item.name,
                    className: item.className,
                    title: item.title
                };

                // Add action based on name
                if (item.name === 'inline-math') {
                    customItem.action = 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);
                        }
                    };
                } else if (item.name === 'display-math') {
                    customItem.action = 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);
                        }
                    };
                }

                toolbar.push(customItem);
            } else {
                toolbar.push(item);
            }
        });
        config.toolbar = toolbar;

        // Initialize editor
        var simplemde = new SimpleMDE(config);

        // Store reference for later access
        textarea.simplemde = simplemde;

        console.log('SimpleMDE initialized for:', fieldId);
    }
})();
</script>
