TinyMCE API v4 windowManager.open - What widgets can I configure for the body option?

后端 未结 3 627
太阳男子
太阳男子 2020-12-22 22:51

I would like to fill the body of a modal dialog with custom HTML, generated by Javascript.

The documentation for this method is mostly empty.

I have only fo

相关标签:
3条回答
  • 2020-12-22 23:12

    After I beautified the minified version of tinymce, i found that these may be some of the body types for windowManager.open. I'm not sure how to use them all, as all this info was gathered through trial and fail. Since the documentation is really bad, no real info can be gathered. Also here's a link which includes some good info on checkbox.

    https://wordpress.stackexchange.com/questions/172853/how-disable-checkbox-when-listbox-value-changes-in-tinymce

    It took me an hour or so to check and test all so I really hope this will save you the trouble of doing it yourself.

    LE: textbox params: textbox settings table

    https://www.tiny.cloud/docs-4x/api/tinymce.ui/tinymce.ui.textbox/

    LE2: you can try and browse all the tinymce.ui.* elements mentioned down and check if it has a settings table, I think it may be used as a valid parameter for body if they have it

    LE3: this is the old documentation http://archive.tinymce.com/wiki.php/api4:index, since it's more useful than the new one it's the only documentation available now https://www.tinymce.com/docs/api/

                    {
                        type   : 'listbox',
                        name   : 'listbox',
                        label  : 'listbox',
                        values : [
                            { text: 'Test1', value: 'test1' },
                            { text: 'Test2', value: 'test2' },
                            { text: 'Test3', value: 'test3' }
                        ],
                        value : 'test2' // Sets the default
                    },
                    {
                        type   : 'combobox',
                        name   : 'combobox',
                        label  : 'combobox',
                        values : [
                            { text: 'Test', value: 'test' },
                            { text: 'Test2', value: 'test2' }
                        ]
                    },
                    {
                        type   : 'textbox',
                        name   : 'textbox',
                        label  : 'textbox',
                        tooltip: 'Some nice tooltip to use',
                        value  : 'default value'
                    },
                    {
                        type   : 'container',
                        name   : 'container',
                        label  : 'container',
                        html   : '<h1>container<h1> is <i>ANY</i> html i guess...<br/><br/><pre>but needs some styling?!?</pre>'
                    },
                    {
                        type   : 'tooltip',
                        name   : 'tooltip',
                        label  : 'tooltip ( you dont use it like this check textbox params )'
                    },
                    {
                        type   : 'button',
                        name   : 'button',
                        label  : 'button ( i dont know the other params )',
                        text   : 'My Button'
                    },
                    {
                        type   : 'buttongroup',
                        name   : 'buttongroup',
                        label  : 'buttongroup ( i dont know the other params )',
                        items  : [
                            { text: 'Button 1', value: 'button1' },
                            { text: 'Button 2', value: 'button2' }
                        ]
                    },
                    {
                        type   : 'checkbox',
                        name   : 'checkbox',
                        label  : 'checkbox ( it doesn`t seem to accept more than 1 )',
                        text   : 'My Checkbox',
                        checked : true
                    },
                    {
                        type   : 'colorbox',
                        name   : 'colorbox',
                        label  : 'colorbox ( i have no idea how it works )',
                        // text   : '#fff',
                        values : [
                            { text: 'White', value: '#fff' },
                            { text: 'Black', value: '#000' }
                        ]
                    },
                    {
                        type   : 'panelbutton',
                        name   : 'panelbutton',
                        label  : 'panelbutton ( adds active state class to it,visible only on hover )',
                        text   : 'My Panel Button'
                    },
                    {
                        type   : 'colorbutton',
                        name   : 'colorbutton',
                        label  : 'colorbutton ( no idea... )',
                        // text   : 'My colorbutton'
                    },
                    {
                        type   : 'colorpicker',
                        name   : 'colorpicker',
                        label  : 'colorpicker'
                    },
                    {
                        type   : 'radio',
                        name   : 'radio',
                        label  : 'radio ( defaults to checkbox, or i`m missing something )',
                        text   : 'My Radio Button'
                    }
    

    Tinymce Body Types Displayed

    0 讨论(0)
  • 2020-12-22 23:12

    I've found this way of specifying modal dialog body:

    var dialogBody = '<p>Whatever you want here</p>';
    
    editor.windowManager.open({
        title: 'Dialog Title',
        html: dialogBody,
        buttons: [{
            text: 'Do Action',
            subtype: 'primary',
            onclick: function() {
                // TODO: handle primary button click
                (this).parent().parent().close();
            }
        },
        {
            text: 'Close',
            onclick: function() {
                (this).parent().parent().close();
            }
        }]
    });
    
    0 讨论(0)
  • 2020-12-22 23:15

    Googling for this question I found an answer:

    editor.windowManager.open({
        title: 'My dialog',
        body: [{
            type: 'container',
            html: "Hello world!"
        }]
    });
    
    0 讨论(0)
提交回复
热议问题