This plugin adds a simple post-type drop-down to the post editor interface, allowing you to reassign any post to a new post type. It allows you to switch post’s type while editing your post.
The plugin can convert nearly every combination of posts, pages, and even custom post types:
- Page to Post
- Post to Page
- Post to Custom
- Custom to Custom
As of 3.0.0, support for switching to or from Attachments was removed. This may come back in a subsequent version.
Invisible post types, such as revisions, menus, etc., are purposely excluded. But, if you need to access invisible post types, you can adjust the boundaries using the ‘pts_post_type_filter’ filter.
With bulk editing (thanks to Matthew Gerring) you can select all the posts in a certain type and convert them to a new type with one quick action.
With block-editor (aka Gutenberg) support (thanks to Daniel Bachhuber) you can switch between post-types that use either the Block Editor and the Classic one, without losing any of your embedded content.
- In your WordPress Dashboard go to «Plugins» -> «Add Plugin».
- Search for «Post Type Switcher».
- Install the plugin by pressing the «Install» button.
- Activate the plugin by pressing the «Activate» button.
- From the post edit screen, above the «Publish» button is the «Post Type» interface.
- Change post types as needed.
- WordPress version 5.0 or greater.
- PHP version 7.0.0 or greater.
- MySQL version 5.7 or greater.
- Latest WordPress version.
- PHP version 8.0 or greater.
- MySQL version 8.0 or greater, or MariaDB 10.5 or greater.
Why would I need this?
You need to selectively change a posts type from one to another.
Does this ruin my taxonomy associations?
It should not. This plugin only changes the ‘post_type’ property of a post.
Does this ruin block-editor content?
It should not. Be careful when editing HTML content while switching between editor types!
Will this delete my content?
No. This plugin does not include any code capable of deleting anything.
Plugin conflicts are not unheard of and can be difficult to troubleshoot.
If you’re worried, backup your database and deactivate all other plugins before using this tool.
If you’re still worried, ask for help in the WordPress.org support forums.
Colaboradores y desarrolladores
«Post Type Switcher» es un software de código abierto. Las siguientes personas han colaborado con este plugin.Colaboradores
Registro de cambios
- Update author
- Add sponsor link
- Block editor support
- Fix post targeting when called recursively
- Improved Quick-Edit and Bulk-Edit support
attachmenttype support for now, as there is no way to switch back
- Fix bug causing some post-types to switch unexpectedly
- Ensure quick-edit works with new procedure
- Quick-edit «Type» column works again!
- Improved plugin compatibility with WooThemes Sensei
- Filter post arguments vs. hook to save_post
- Add «post_type_switcher» action
- Add support for network activation
- Add textdomains for localization
- Load translation strings using load_plugin_textdomain()
- Before saving data chack if it’s not an autosave using wp_is_post_autosave()
- Before saving data chack if it’s not a revision using wp_is_post_revision()
- Security: Prevent direct access to directories
- Security: Translation strings escaping
- Add screenshots
1.5.0 – norcross
- Fix multiple quickedit dropdowns
- Improve handling of non-public post types
- Fix saving of autodrafts
- Improved WordPress 3.9 integration (added dashicon to publish metabox)
- Add bulk editing to supported post types
- Props Matthew Gerring for bulk edit contribution
- Add is_admin() check to prevent theme-side interference
- Change save_post priority to 999 to avoid plugin compatibility issues
- Remove ending closing php tag
- HTML and PHPDoc improvements
- Fix revisions being nooped
- Fix malformed HTML for some user roles
- Make a singleton (meh…)
- Fix JS bugs
- Audit post save bail conditions
- Tweak UI for WordPress 3.3
- Use the API to change the post type, fixing a conflict with persistent object caches
- Disallow post types that are not public and do not have a visible UI