Disable Wordpress's native Gutenberg or TinyMCE editor in favor of a Markdown editor.
This plugin replaces the Gutenberg block editor (or the classic TinyMCE) on the edit screen with EasyMDE, a markdown editor based on CodeMirror.
The content is saved with the markdown syntax in the database and is rendered on the frontend via wordpress native filters thanks to the Parsedown PHP library.
This extension rocks:
– v3.4: Adding support for categories, tags and taxonomies description field (Woocommerce and REST API compatible)
– v3.3: Support for multiple html attributes, compatibility with acf_form added for the frontend, basic compatibility with block styles
– v3.2: Support to enable markdown only for custom fields
– v3.1: Side preview panel fixed
– v3.0: Choose and sort the default toolbar buttons
– v2.6: Sticky toolbar with the editor
– v2.6: Possible to disable OP Cache
– v2.5: Video playlist support added
– v2.3: New beta interface
– v2.2: Possible to enable or disable specific addons
– v2.1: Gallery shortcode support
– v2.0: ACF markdown field support
– v1.9: Multilingual spell checking support
– v1.7: Disable markdown for specific custom post type
– v1.4: Extra markdown syntax added
– v1.3: Static cache files with OP Cache enabled by default
– v1.2: Autoconvert Youtube & Vimeo links to iframes
– v1.1: Support with lightbox and masonry for the gallery layout
That’s pretty all you should know. It’s under active development, keep in touch and feel free to drop a line on the forum, to let a rating or even support me by buying a coffee!
The same as usual:
All done! That’s all you should do.
Yes but you can’t use both at the same time 😉
Data are saved as pure markdown code in the database, for the other builders on the market data are saved as HTML or custom markups like shortcodes. Currently data are still saved but won’t be converted or rendered correctly if you revert back or switch between editors.
Yes, please keep in mind it’s a global switch for every user. You need to stick to one editor with one post type.
Any block editor will be disabled for all the users of your WordPress instance. filters are available to disable the markdown editor for specific custom post types at a global level. For example you can do a setup to use Divi or Elementor to edit your pages and Markdown to edit your blog’posts. Please refer to the forum to know how to do it.
Sure, developers & designers can access the public properties & methods of the instance inside their templates through the global mmd function. For example let’s say you want to use it with a custom field called ‘foo_bar’. You can use something
like that:
<?php echo mmd()->markdown2html( get_post_meta( get_the_ID(), 'foo_bar' , true ) ); ?>
Disclaimer: with the plugin Advanced Custom Field (ACF), HTML content has been sanitized since v6.2.5.
If you need to render iframes or others elements, instead of using:
<?php the_field( 'my_custom_field' ); ?>
use
<?php echo mmd()->markdown2html( get_field( 'my_custom_field' ) ); ?>
The default editor is based on EasyMDE so you can write in markdown and use WordPress feature at the same time. The side panel preview mode has been fixed since 3.0.
The beta interface is based on SummerNote, a jQuery WYSIWYG Engine. The beta interface has been removed since 3.0 and will be available as a separate addon. It’s a custom version so you can get a live rendering when typing your content or adding medias. It’s not perfect, it’s still working well but for now you will have to modify the code on your own (builder or database) if something goes wrong. To find out more check my article here: https://www.markup-markdown.com/blog/wordpress-plugins/dynamic-input-method-markdown/
The current version is based on components that are not compatible with assistive devices like screen readers. Several available alternative plugins could cover the gap while I’m working on a new interface. Thank you for your patience and your understanding.
New feature:
– Adding buttons and support for RTL
Improvement:
– Better support with multisite
– Hooks more friendly with plugins like CPT UI (Custom Post Type) and ACF (Advanced Custom Field)
Improvement:
– Basic internationalization strings added
– French version released as local forn now
Bug fix:
– Adding css namespace for the toolbar buttons to avoid collision with Bootstrap on the frontend
Improvements:
– Adding missing filters in the REST Api
– Adding a plug for the description field with Woocommerce templates
Bug fix:
– Undefined variable in array with WP Geshi
Improvement:
– Adding markdown support by default for category, tags, and term descriptions
Bug fix:
– Activate markdown filters on the front page / home page as well
Bug fix:
– Patch a PHP warning if the align attribute was missing
Improvement
– Adding a few missing styles inside the preview panel
Bug fix:
– Fixing PHP error with undefined array key
Bug fix:
– Adding a whitelist on the REST hook to allow the rendering of markdown with REST content
Bug fixes:
– Removing blank icon in the toolbar when the spell checker addon was disabled
– Fixing the case when a custom image size was overriden by wordress predefined size
Bug fix:
– Patch a cache issue with (my) shared webhosting with the WP Geshi AutoPlug
Bug fix:
– Patch a javascript error with an undefined variable
Improvements:
– Markdown extra patches added to support HTML multi-attributes
## Headline {#h2 .short .great lang=en} => <h2 id="h2" lang="en" class="short great">Headline</h2>
– Basic block classnames added to headlines and images to avoid broken layout with themes built for Gutenberg
### H3 Tag => <h3 class="wp-block-heading">H3 Tag</h3>
– ACF Markup Markdown custom fields can now be used in the frontend with acf_form_head & acf_form
Bug fix:
– Static Cache is disabled by default to avoid side effects with a few cache engine
– Filters fixed: when cache was turned on, excerpt was returning the content value
New feature: AUTO PLUGS
Unlike Addons designed to add extra features to the editing experience, the Plugs will be designed to smooth the behavior of the rendering with existing WP plugins.
The first plug with WP Geshi Highlight has been added to allow the rendering of snippets on the frontend
Readme.txt Updated
Improvement:
– Patch to refresh the editor when the spell checker is disabled
Bug fix:
– Patch to refresh the view with frozen loader icons
Bug fix:
– Patch for markdown contents not rendered on archive templates and REST calls
Bug fix:
– Bug introduced with version 3 for the custom post type support filter has been fixed
Improvement:
– “ACF Markup Markdown” custom field with custom post type !
Improvements:
– The preview panel has a tiny cache feature to avoid flickering issue when using the side panel view
– Better support in responsive mode for the sticky toolbar and fullscreen mode
Hotfix:
– Namespace Patch for the Extra Parsedown
Refactored !
New feature:
– Possible to select and sort the buttons displayed from the toolbars
Bug fix:
– Forget to bump assets version number to avoid cache issues when upgrading
Improvement:
– Adding option to make the default EasyMDE toolbar sticky
Bug fixes:
– PHP: Addons config file not properly created with new installs & upgrades
– JS: Undefined variables when the spell checker was not activated
Improvement:
– Adding option to disable the static html cache
Improvements:
Possible to do the following actions from the media uploader
– Adding an audio file
– Adding a video file
– Creating an audio playlist
– Creating a video playlist
Bug fixes:
– Music or movies was not usable
– Inserting multiples images at once or creating a gallery should work properly
– Solve an issue to avoid duplicate ids with images when using custom fields
– Better performance with a unique media wizard per page instead of one media wizard per custom field
Improvements:
– New beta interface based on HTML markups for better accessibility
– A few dependencies are now loaded from the UNPKG CDN (https://unpkg.com/)
Bug fix:
– The parser has been patched to be compatible with PHP >= 8.X
Bug fix:
– Lightboxes working again with the gallery shortcode
Bug fixes:
– Adding missing 2 & 3 columns styles for the gallery in the preview rendered by EasyMDE
– Shortcodes now working in the preview page rendered by WordPress (The one with /?preview=true in the url)
Improvement:
– Enabling “Screen options” on the top right area of the settings page so you can activate or disable addons one by one
Bug fixes:
– Forcing WP medias tools to be available to avoid errors with some specific hosting
– CodeMirror instances now available from wp.pluginMarkupMarkdown.instances array for developers
Improvements:
– Better media support with native WordPress Modal UI for editor in the admin panel
– Tiny responsive features added for images uploaded via WordPress on the frontend (srcset)
– Alignment and caption now works, converted as
<
figure> on the frontend
– Default [gallery] shortcodes should support columns & size attributes as well
– Syntax highlighting enabled in the preview
Bug fixes:
– 404 with one single dictionary activated
– Styles broken in the preview (conflict with default admin panel style)
Bug fix:
– Make the [my_gallery] shortcodes rendered as thumbnail galleries in the preview
Bug fixes:
– Patched the error when the config file was not found after upgrading
Code refactoring. Addon framework created !
Please setup and save again your settings again if need be. Sorry for the inconvenience.
New feature:
– Advanced Custom Field (ACF) support added with a “Markup Markdown” content field
Improvement:
– Add Polylang compatibility by switching dictionaries order when editing a post in an alternative language
Bug fixes:
– Undefined variable with fresh install
– Editor was blocked in case one of the dictionary was not found
New features:
– Spell checking (experimental)
– Fresh settings panel
Bug fixes:
– Update EasyMDE version to 2.18.0 (Wrong version in previous commit, my bad)
Bug Fixes :
– Masonry setup fixed for the gallery layout
Improvements:
– New settings page with default layout options
Improvements:
– Adding feature to disable the editor for custom post types
In your child theme just turn off the markdown editor by adding the following snippet :
php
add_action(‘init’, function() {
remove_post_type_support(‘post_type_slug’, ‘markup_markdown’);
});
Bug Fixes:
– Remove debug lines
Improvements:
– Removing curl straight dependencies in favor of wp_remote_get functions
– Youtube oembed support added
– Remove unused files
Bug Fix:
– Public method mmd()->markdown2html fixed
Since the cache support from v1.3, the method was broken when used in templates.
The cache is only restricted to the post / page content.
Improvement:
– Vimeo arguments support added.
Please refer to the link below for the complete list :
https://developer.vimeo.com/api/oembed/videos#embedding-a-video-with-oembed-step-1
Ex: https://vimeo.com/30198629/&quality=360p
Bug Fixes:
– Space at the beginning of the file and other typo
– Unknown unused callback
Bug Fixes:
– Multiple Vimeo url not working
– Non existent minified related map files removed
Experimental UI:
– Headlines input fixed
– HTML tags sidebar’s prototype released
Experimental UI: Adding modern syntax via summernote wysiwyg
Find out more here: https://www.youtube.com/watch?v=cl2P5zUXAmU
Improvement: Parsedown extra plugins added so you use extra features
Bug Fixes:
– Site ID used for the static cache rules, now compatible with network sites
– Regexp updated for vimeo videos
– Espaced quotes fix and lower filter priorities so other shortcodes can be parsed properly
Bug Fix: adding rules if cache directory not available
Adding cache via static files in the mmd-cache directory.
Adding Vimeo support. Vimeo links will be converted to iframes.
Bug Fix: Enabling gallery with archive templates
Bug Fix: Editor styles adjusted with WordPress
Bug Fix: Single image button not working properly
New Feature: Image Gallery using Lightbox and Masonry for the image gallery post format
Bug fix: modal preloading (Double click was required to add an image from the library)
Adding Youtube support. Youtube links will be converted to iframes.
Updates to match the WordPress Plugin Directory requirements
First version ! ! ! Based on:
– Javascript easyMDE 2.15.0
– PHP Parsedown 1.7.4
Developers can access the instance instance through the mmd() global function