Strange problem with quill field

Strange problem with quill field

GargiucnGargiucn Posts: 120Questions: 33Answers: 0

Good morning,
I have a problem with quill.
It has always worked very well, but now it has a problem that I cannot solve.
I should mention that I am using the latest version of Datables and Editor.
Quill works normally with different font sizes, bold and italics, but it no longer works with colours (both font and background colours). When I use colours, it adds the <span></span> tag.

<p><strong>Bold font</strong></p>
<p><em>Italic font</em></p>
<p><u>Underlined font</u></p>
<p><span>Red font</span></p>
<p><span>Font with red background</span></p>

Can anyone help me?
Thank you,
Giuseppe

This question has an accepted answers - jump to answer

Answers

  • kthorngrenkthorngren Posts: 22,299Questions: 26Answers: 5,127
    edited September 4

    It seems that is the way Quill works. Go to the Quill format example and change the text and background colors. Use the browser's inspect tool to see the generated HTML. For example:

    Datatables doesn't control the HTML generated by Quill.

    Does this answer your questions?

    Does the span cause issues?

    Kevin

  • GargiucnGargiucn Posts: 120Questions: 33Answers: 0

    Thank you for your reply.
    The problem is that quill should not put only the <span></span> tags for colours but should generate something like this:

    <p><strong>Bold font</strong></p>
    <p><em>Italic font</em></p>
    <p><u>Underlined font</u></p>
    <p><span style="color: rgb(230, 0, 0);">Red font</span></p>
    <p><span style="background-color: rgb(230, 0, 0);">Font with red background</span></p>
    

    Instead, he writes <span></span> for colours!!!!
    Giuseppe

  • kthorngrenkthorngren Posts: 22,299Questions: 26Answers: 5,127
    edited September 4

    Instead, he writes <span></span> for colours!!!!

    Do you mean the DB is missing the styles in the span?

    I built this simple test case:
    https://live.datatables.net/guwafemu/646/edit

    Edit any of the Position fields and set the color of some or all the text. The console output shows the style remains and the field shows the updated styles.

    I would start by using the browser's network inspector tool to see the request and response data when performing an edit. What do you see? Post both the request and response data.

    Kevin

  • allanallan Posts: 65,256Questions: 1Answers: 10,817 Site admin

    Is this a problem with the Editor integration with Quill, or is it a problem with the HTML that Quill generates? If you use Quill standalone, I believe it will generate the same HTML with a span, that's just how it works. You'd need to take that up with the Quill developers if you need it to work differently.

    Allan

  • GargiucnGargiucn Posts: 120Questions: 33Answers: 0

    I'm going crazy trying to figure out what the problem is.
    I have another application that uses exactly the same libraries and works perfectly.
    In this one, however, in the quill edit mask, I see all the lines with colours, but when I save to the database, all the other control characters remain, while those relating to colours are saved as <span></span>.
    Unbelievable...

  • GargiucnGargiucn Posts: 120Questions: 33Answers: 0

    Edit row

    Show row

    Alert added in edit

  • kthorngrenkthorngren Posts: 22,299Questions: 26Answers: 5,127

    Have you tried my debugging suggestion above:

    I would start by using the browser's network inspector tool to see the request and response data when performing an edit. What do you see? Post both the request and response data.

    If you see the styles in the span in the request data but not in the JSON response then something is happening in the server to remove the styles.

    Kevin

  • allanallan Posts: 65,256Questions: 1Answers: 10,817 Site admin

    Are you using the PHP Editor libraries? Try adding ->xss(false) to the Field in question. Possibly the XSS protection might be stripping out the style attribute.

    Allan

  • GargiucnGargiucn Posts: 120Questions: 33Answers: 0

    Do I need to write:
    Field::inst( “help_text” ) -> xss(false)
    in the PHP file?
    I'll try that.
    In the meantime, I'm attaching images of the edit sequence.

    Thank you both,
    Giuseppe!

  • allanallan Posts: 65,256Questions: 1Answers: 10,817 Site admin
    Answer ✓

    Yes, where you define the Field instance in the PHP, add ->xss(false) to it.

    Allan

  • GargiucnGargiucn Posts: 120Questions: 33Answers: 0

    It works!
    I know I won't understand anything, but would you mind trying to explain it to me even though I'm sure I won't understand a thing?

    Thanks again,
    Giuseppe

  • allanallan Posts: 65,256Questions: 1Answers: 10,817 Site admin

    Sure thing - Editor uses the htmLawed libraries in its PHP libraries to try and help prevent XSS attacks. Unfortunately, part of the way htmLawed works is to strip parts of HTML that it doesn't know about. Normally it isn't an issue since HTML isn't submitted, but obviously in the case of a WYSIWYG editor such as Quill, that becomes important, and in this case results in the need to disable the XSS protection.

    Allan

  • GargiucnGargiucn Posts: 120Questions: 33Answers: 0

    Incredible, I UNDERSTAND!

    Thanks again,
    Giuseppe

  • Stacey1134Stacey1134 Posts: 119Questions: 22Answers: 0

    It can also be done client-side like this, it's what I chose to do as the new version of editor started replacing all of my QUILL with flat text. Hope this helps.

    /**
     * dataTable_quill_fix.js
     * 
     * Fix for DataTables Editor Quill fields to return HTML content instead of plain text.
     * This addresses the issue where Quill editors in DataTables save plain text instead of HTML formatting.
     * 
     * Usage:
     * Call applyQuillHtmlFix(editor, fieldNames) after creating your DataTables Editor
     * 
     * @param {DataTable.Editor} editor - The DataTables Editor instance
     * @param {string|array} fieldNames - Single field name or array of field names that use Quill
     * 
     * Example:
     * var myEditor = new DataTable.Editor({...});
     * applyQuillHtmlFix(myEditor, 'description'); // Single field
     * applyQuillHtmlFix(myEditor, ['description', 'notes']); // Multiple fields
     */
    
    window.applyQuillHtmlFix = function(editor, fieldNames) {
        // Ensure fieldNames is always an array
        if (typeof fieldNames === 'string') {
            fieldNames = [fieldNames];
        }
        
        // Apply fix when editor opens
        editor.on('open', function () {
            fieldNames.forEach(function(fieldName) {
                var quillField = editor.field(fieldName);
                if (quillField && quillField.quill && !quillField._quillHtmlFixed) {
                    var quillInstance = quillField.quill();
                    if (quillInstance) {
                        // Override the field's val method to return HTML
                        var originalVal = quillField.val;
                        quillField.val = function(val) {
                            if (arguments.length === 0) {
                                // Getting value - return HTML instead of plain text
                                return quillInstance.root.innerHTML;
                            } else {
                                // Setting value - use original method
                                return originalVal.call(this, val);
                            }
                        };
                        
                        // Mark this field as fixed to avoid double-processing
                        quillField._quillHtmlFixed = true;
                    }
                }
            });
        });
        
        // Apply fix for initEdit to properly display HTML content when editing
        editor.on('initEdit', function (e, node, data) {
            setTimeout(function () {
                fieldNames.forEach(function(fieldName) {
                    var quillField = editor.field(fieldName);
                    if (quillField && quillField.quill) {
                        var quillInstance = quillField.quill();
                        if (quillInstance && data[fieldName]) {
                            quillInstance.clipboard.dangerouslyPasteHTML(data[fieldName]);
                        }
                    }
                });
            }, 0);
        });
    };
    
    console.log('dataTable_quill_fix.js loaded - applyQuillHtmlFix() function available');
    
Sign In or Register to comment.