Copied to clipboard

Flag this post as spam?

This post will be reported to the moderators as potential spam to be looked at


  • Julien Kulker 75 posts 427 karma points c-trib
    Aug 12, 2021 @ 09:23
    Julien Kulker
    0

    tinyMce.config Where to find it in Umbraco 9

    Hi all,

    I would like to add some custom configuration to the tinyMCe editor. In Umbraco 8 there is a file config file called tinyMCe. In Umbraco 9 this file doesn't exist.

    So how does it work now in Umbraco 9?

  • Sebastiaan Janssen 5060 posts 15522 karma points MVP admin hq
    Aug 12, 2021 @ 09:48
    Sebastiaan Janssen
    102

    You can explore the configuration options in your appsettings.json file, most IDEs (Rider, VS, VSCode) should give you autocomplete for all the settings like this:

    enter image description here

  • Julien Kulker 75 posts 427 karma points c-trib
    Aug 13, 2021 @ 11:25
    Julien Kulker
    1

    yeah problem is now i can't find the proper documentantion for the customconfig section

  • Sebastiaan Janssen 5060 posts 15522 karma points MVP admin hq
    Aug 13, 2021 @ 11:47
    Sebastiaan Janssen
    0

    Yeah, we never really had a lot of documentation for it to begin with! 😅

    https://our.umbraco.com/Documentation/Reference/Config/tinyMceConfig/index-v7#customconfig

    So only key/value pairs can be put in there.

    I assume it should look like this:

    "RichTextEditor": {
            "CustomConfig": {
              "entity_encoding": "raw",
              "something": "something"
            }
          }
    

    Once you have figured out the notation, it would be awesome if you could help update the docs, if you have some spare time! 🤞

  • ShannonC 9 posts 81 karma points
    Sep 03, 2021 @ 14:40
    ShannonC
    0

    Good morning, Is there some sort of caching that needs to be cleared out for making these settings changes in appsettings? I have yet to be successful with anything. Current code:

    "RichTextEditor": {
        "Plugins": ["textcolor"],
        "CustomConfig": {
          "cleanup ": "false"
        }
    
  • Julien Kulker 75 posts 427 karma points c-trib
    Aug 13, 2021 @ 11:57
    Julien Kulker
    0

    Hi Sebastiaan,

    thank you for your fast reply. Yeah that is what it says. Can only contain a key string value.

    but the old possibilities where like this:

    enter image description here

  • Sebastiaan Janssen 5060 posts 15522 karma points MVP admin hq
    Aug 13, 2021 @ 12:21
    Sebastiaan Janssen
    101

    Oh, nuts! I had forgotten about this.. It probably still works exactly like that but you will need to escape the inner json.

    [\r\n {\r\n \"title\": \"Checkmark List\",\r\n \"selector\": \"ul\",\r\n \"classes\": \"richt-text--checkmarks\"\r\n }\r\n]

    Not sure if the \r\n will work well, they're not really necessary anyway, so then it would become :

    [{ \"title\": \"Checkmark List\", \"selector\": \"ul\", \"classes\": \"richt-text--checkmarks\" }]

  • Sebastiaan Janssen 5060 posts 15522 karma points MVP admin hq
    Aug 17, 2021 @ 08:07
    Sebastiaan Janssen
    0

    Did that help at all Julien?

  • Mahdi Shahbazi 4 posts 79 karma points
    Oct 14, 2021 @ 12:00
    Mahdi Shahbazi
    4

    I configured it like this in appsettings.json and works fine:

    "Umbraco": {
            "CMS": {
               "RichTextEditor": {
                "CustomConfig": {
                  "style_formats": "[{\"title\":\"Headers\",\"items\":[{\"title\":\"Heading h1\",\"block\":\"h1\"},{\"title\":\"Heading h2\",\"block\":\"h2\"},{\"title\":\"Heading h3\",\"block\":\"h3\"},{\"title\":\"Heading h4\",\"block\":\"h4\"},{\"title\":\"Heading h5\",\"block\":\"h5\"},{\"title\":\"Heading h6\",\"block\":\"h6\"}]}]"
                }
              },
            }
          }
    
  • Alexander Wagner 36 posts 186 karma points
    Mar 10, 2022 @ 12:23
    Alexander Wagner
    3

    Is there a way to do this programmatically? The readability is awful if you have a more complex json-string.

  • Jesse Andrews 191 posts 716 karma points c-trib
    May 19, 2022 @ 18:08
    Jesse Andrews
    2

    I agree with Alexander that this configuration isn't as user friendly as it could be. One possible solution would be to move control of this to the Grid/Rich text editor data types. The settings wouldn't be global, which is a potential downside (though it could fall back to using the value from appsettings.json), but it would make it possible to have different format options for different instances of the rich text editor. I've posted a feature request for this change here.

  • Mark McDonald 2 posts 73 karma points
    Aug 05, 2022 @ 19:09
    Mark McDonald
    1

    Has anyone found a way to do this NOT in appsettings.json? That is just looking unmanageable.

  • Blake Watt (Clerke) 106 posts 351 karma points MVP 2x
    Sep 23, 2022 @ 08:29
    Blake Watt (Clerke)
    1

    The docs have been updated to show an example of creating custom formats for the dropdown list in v9+. Also added a tip for making it a bit easier to edit. :) https://our.umbraco.com/Documentation/Reference/Configuration/RichTextEditorSettings/#custom-config

  • Mark McDonald 2 posts 73 karma points
    Sep 23, 2022 @ 08:35
    Mark McDonald
    0

    I've managed to find a bit of a process which is helping reduce some of the pain for me (as we tend to have dozens of custom styles defined for editors).

    I've create a separate style_formats.json file in my solution where I can write the json normally, then I use a couple of online tools; one to remove extra spaces and put it on a single line, and one to encode it.

    https://codebeautify.org/remove-extra-spaces

    https://codebeautify.org/json-escape-unescape

    This then gives me the styles in a format I can add to the appsettings.json and also means I can keep the original format checked in to source control to edit and reapply the process as needed.

  • Huw Reddick 1932 posts 6722 karma points MVP 2x c-trib
    Sep 23, 2022 @ 11:29
    Huw Reddick
    0

    I use a similar approach but do the formatting etc in Notepad++

  • Huw Reddick 1932 posts 6722 karma points MVP 2x c-trib
    Sep 27, 2022 @ 09:16
    Huw Reddick
    1

    I found a new way of doing this in Visual studio

    using this extension https://github.com/SimpleSandman/JsonFormatter you can minify the json and then do a replace on the "

    I store my style_format in a json file enter image description here

    And use the extension to minfy it, enter image description here

    I then just do a replace on the " and paste the result into my appsettings file

  • Huw Reddick 1932 posts 6722 karma points MVP 2x c-trib
    Sep 27, 2022 @ 16:40
    Huw Reddick
    2

    I have now set mine to do this automatically, some instructions and code in the link below

    https://umbraco.themediawizards.co.uk/the-grimoire/formatting-for-richtexteditor-config/

  • Alexander Wagner 36 posts 186 karma points
    Oct 03, 2022 @ 10:31
    Alexander Wagner
    0

    Great work Huw! Works like a charm.

  • Chris Mahoney 242 posts 454 karma points
    Jun 09, 2023 @ 02:37
    Chris Mahoney
    0

    Sorry to resurrect this old thread, but I'm a little bit stuck. I'm trying to move two custom commands over from Umbraco 7:

    <command>
      <umbracoAlias>mceForeColor</umbracoAlias>
      <name>Text colour</name>
      <icon>images/editor/forecolor.gif</icon>
      <tinyMceCommand value="" userInterface="true" frontendCommand="forecolor">forecolor</tinyMceCommand>
      <priority>75</priority>
    </command>
    <command>
      <umbracoAlias>mceBackColor</umbracoAlias>
      <name>Background colour</name>
      <icon>images/editor/backcolor.gif</icon>
      <tinyMceCommand value="" userInterface="true" frontendCommand="backcolor">backcolor</tinyMceCommand>
      <priority>76</priority>
    </command>
    

    In Umbraco 10 I've put the following in appsettings.json:

    "Umbraco": {
      "CMS": {
        "RichTextEditor": {
          "Commands": [
            {
              "Alias": "mceForeColor",
              "Icon": "images/editor/forecolor.gif",
              "Mode": "All",
              "Name": "Text colour"
            },
            {
              "Alias": "mceBackColor",
              "Icon": "images/editor/ecolor.gif",
              "Mode": "All",
              "Name": "Background colour"
            }
          ]
        }
      }
    }
    

    Unfortunately the documentation doesn't mention the "Icon" property at all, and just transferring them across verbatim hasn't worked (when I go to the RTE data type the two new entries show up but don't have any icons and don't appear on the actual RTE toolbar).

    What's the process for configuring these icons? I haven't even been able to find the files for the default set, so I'm not sure whether the previous path is still current or not.

    Can anyone help?

  • Huw Reddick 1932 posts 6722 karma points MVP 2x c-trib
    Jun 09, 2023 @ 07:39
    Huw Reddick
    1

    you can add a command for text colour like this

      "Commands" : [{
        "Alias": "forecolor",
        "Name": "Change Colour",
        "mode": "Selection"
      }],
    "Plugins" : ["textcolor"],
    "CustomConfig": {
      "textcolor_map": "[ \"000000\", \"Black\", \"a4b69c\", \"Green\" ]"
    }
    

    Perhaps something similar for back colour

  • Chris Mahoney 242 posts 454 karma points
    Jun 11, 2023 @ 20:58
    Chris Mahoney
    1

    Thank you! :)

    For reference, here's the working code:

    "RichTextEditor": {
      "Commands": [
        {
          "Alias": "forecolor",
          "Mode": "Selection",
          "Name": "Text colour"
        },
        {
          "Alias": "backcolor",
          "Mode": "Selection",
          "Name": "Background colour"
        }
      ],
      "Plugins": [
        "textcolor"
      ]
    }
    

    Interestingly Visual Studio doesn't like the "Plugins" bit, but it works in Umbraco. The CustomConfig section isn't needed unless you want to customise the default list of colours.

  • Chris Clancy 65 posts 134 karma points
    Oct 06, 2023 @ 09:07
    Chris Clancy
    0

    Hi,

    Some useful info here. I have been trying to add additional list formatting so that we don't need to allow source code access. One nice thing would be to add additional options to the Bullet and Numbered List drop downs. I can add extra format options to do this using the above mentioned approach but I'd like to take it a step further. Struggling to do this from the docs, so has anyone managed this? Would also like to add some more RTE features to create advanced table options.

  • mauzilla 19 posts 90 karma points
    Oct 25, 2023 @ 12:51
    mauzilla
    0

    Also rehashing this one as this seems to be the most reliable source online for extending TinyMCE in Umbraco.

    I need to add a custom button which creates a

    • Item

    TinyMCE config would have looked like this (if we accessed it directly), but I am not sure how to convert my requirements into the required appsettings.json:

    setup: function (editor) {
        editor.ui.registry.addButton('customInsertButton', {
          text: 'Custom List',
          onAction: function (_) {
            editor.insertContent('&nbsp;<ul class="custom-list"><li>item</li></ul>&nbsp;');
          }
        });
    
  • Dan 1288 posts 3921 karma points c-trib
    Jul 26, 2024 @ 10:37
    Dan
    1

    Excuse the shameless self promotion, but I wrote a little tool to help with configuring TinyMCE styles for Umbraco which does all of the gnarly JSON string escaping for you: https://www.iomi.net/tinymce-umbraco/. I hope people find it useful.

Please Sign in or register to post replies

Write your reply to:

Draft