=== One Click Demo Import === Contributors: capuderg, cyman Tags: import, content, demo, data, widgets, settings Requires at least: 4.0.0 Tested up to: 4.5 Stable tag: 1.1.3 License: GPLv3 or later Import your demo content, widgets and theme settings with one click. Theme authors! Enable simple demo import for your theme demo data. == Description == This plugin will create a submenu page under Appearance with the title **Import demo data**. If the theme you are using does not have any predefined import files, then you will be presented with three file upload inputs. First one is required and you will have to upload a demo content XML file, for the actual demo import. The second one is optional and will ask you for a WIE or JSON file for widgets import. You create that file using the [Widget Importer & Exporter](https://wordpress.org/plugins/widget-importer-exporter/) plugin. The third one is also optional and will import the customizer settings, select the DAT file which you can generate from [Customizer Export/Import](https://wordpress.org/plugins/customizer-export-import/) plugin (the customizer settings will be imported only if the export file was created from the same theme). This plugin is using the improved WP import that you can find here: https://github.com/humanmade/WordPress-Importer. The best feature of this plugin is, that theme authors can define import files in their themes and so all you (the user of the theme) have to do is click on the "Import Demo Data" button. **How do theme author define these files?** The answer is in the FAQ section. All progress of this plugin's work is logged in a log file in the default WP upload directory, together with the demo content and widgets import files used in the importing process. NOTE: This plugin is still a work in progress! NOTE: There is no setting to "connect" authors from the demo import file to the existing users in your WP site (like there is in the original WP Importer plugin). **Do you want to contribute?** Please refer to the official [GitHub repository](https://github.com/proteusthemes/one-click-demo-import) of this plugin. == Installation == Upload the One Click Demo Import plugin to your WordPress site, Activate it, and that's it. Once the plugin is activated you will find the actual import setting page under *Appearance -> Import Demo Data*. == Frequently Asked Questions == = I have activated the plugin. Where is the "Import Demo Data" page? = You will find the import page in *wp-admin -> Appearance -> Import Demo Data*. = Where are the demo import files and the log files saved? = The files used in the demo import will be saved to the default WordPress uploads directory. An example of that directory would be: `../wp-content/uploads/2016/03/`. = How to predefine demo imports? = This question is for theme authors. To predefine demo imports, you just have to add the following code structure, with your own values to your theme (using the `pt-ocdi/import_files` filter): ` function ocdi_import_files(){ return array( array( 'import_file_name' => 'Demo Import 1', 'import_file_url' => 'http://www.your_domain.com/ocdi/demo-content.xml', 'import_widget_file_url' => 'http://www.your_domain.com/ocdi/widgets.json', 'import_customizer_file_url' => 'http://www.your_domain.com/ocdi/customizer.dat', 'import_preview_image_url' => 'http://www.your_domain.com/ocdi/preview_import_image1.json', 'import_notice' => __( 'After you import this demo, you will have to setup the slider separately.', 'your-textdomain' ), ), array( 'import_file_name' => 'Demo Import 2', 'import_file_url' => 'http://www.your_domain.com/ocdi/demo-content2.xml', 'import_widget_file_url' => 'http://www.your_domain.com/ocdi/widgets2.json', 'import_customizer_file_url' => 'http://www.your_domain.com/ocdi/customizer2.dat', 'import_preview_image_url' => 'http://www.your_domain.com/ocdi/preview_import_image2.json', 'import_notice' => __( 'A special note for this import.', 'your-textdomain' ), ), ); } add_filter( 'pt-ocdi/import_files', 'ocdi_import_files' ); ` You can set content import, widgets, and customizer import files. You can also define a preview image, which will be used only when multiple demo imports are defined, so that the user will see the difference between imports. = How to handle different "after import setups" depending on which predefined import was selected? = This question might be asked by a theme author wanting to implement different after import setups for multiple predefined demo imports. Lets say we have predefined two demo imports with the following names: 'Demo Import 1' and 'Demo Import 2', the code for after import setup would be (using the `pt-ocdi/after_import` filter): ` function ocdi_after_import( $selected_import ){ echo "This will be displayed on all after imports!"; if ( 'Demo Import 1' === $selected_import['import_file_name'] ){ echo "This will be displayed only on after import if user selects Demo Import 1"; // Set logo in customizer set_theme_mod( 'logo_img', get_template_directory_uri() . '/assets/images/logo1.png' ); } elseif ( 'Demo Import 2' === $selected_import['import_file_name'] ){ echo "This will be displayed only on after import if user selects Demo Import 2"; // Set logo in customizer set_theme_mod( 'logo_img', get_template_directory_uri() . '/assets/images/logo2.png' ); } } add_action( 'pt-ocdi/after_import', 'ocdi_after_import' ); ` = Can I add some code before the widgets get imported? = Of course you can, use the `pt-ocdi/before_widgets_import` action. You can also target different predefined demo imports like in the example above. Here is a simple example code of the `pt-ocdi/before_widgets_import` action: ` function ocdi_before_widgets_import( $selected_import ){ echo "Add your code here that will be executed before the widgets get imported!"; } add_action( 'pt-ocdi/before_widgets_import', 'ocdi_before_widgets_import' ); ` = I'm a theme author and I want to change the plugin intro text, how can I do that? = You can change the plugin intro text by using the `pt-ocdi/plugin_intro_text` filter: ` function ocdi_plugin_intro_text( $default_text ){ $default_text .= '
This is a custom text added to this plugin intro text.
'; return $default_text; } add_filter( 'pt-ocdi/plugin_intro_text', 'ocdi_plugin_intro_text' ); ` To add some text in a separate "box", you should wrap your text in a div with a class of 'ocdi__intro-text', like in the code example above. = How to disable generation of smaller images (thumbnails) during the content import = This will greatly improve the time needed to import the content (images), but only the original sized images will be imported. You can disable it with a filter, so just add this code to your theme function.php file: `add_filter( 'pt-ocdi/regenerate_thumbnails_in_content_import', '__return_false' );` = How to change the location, title and other parameters of the plugin page? = As a theme author you do not like the location of the "Import Demo Data" plugin page in *Appearance -> Import Demo Data*? You can change that with the filter below. Apart from the location, you can also change the title or the page/menu and some other parameters as well. ` function ocdi_plugin_page_setup( $default_settings ){ $default_settings['parent_slug'] = 'themes.php'; $default_settings['page_title'] = esc_html__( 'One Click Demo Import', 'pt-ocdi' ); $default_settings['menu_title'] = esc_html__( 'Import Demo Data', 'pt-ocdi' ); $default_settings['capability'] = 'import'; $default_settings['menu_slug'] = 'pt-one-click-demo-import'; return $default_settings; } add_filter( 'pt-ocdi/plugin_page_setup', 'ocdi_plugin_page_setup' ); ` = I can't activate the plugin, because of a fatal error, what can I do? = You want to activate the plugin, but this error shows up: *Plugin could not be activated because it triggered a fatal error* This happens, because your hosting server is using a very old version of PHP. This plugin requires PHP version of at least **5.3.x**, but we recommend version *5.6.x*. Please contact your hosting company and ask them to update the PHP version for your site. == Screenshots == 1. Example of multiple predefined demo imports, that a user can choose from. 2. How the import page looks like, when only one demo import is predefined. 3. Example of how the import page looks like, when no demo imports are predefined a.k.a manual import. == Changelog == = 1.1.3 = *Release Date - 17 June 2016* * Updated plugin design, * Changed the plugin page setup filter name from `pt-ocdi/plugin-page-setup` to `pt-ocdi/plugin_page_setup` (mind the underscore characters instead of dashes). = 1.1.2 = *Release Date - 12 June 2016* * An 'import notice' field has been added to the predefined demo import settings. This notice is displayed above the import button (it also accepts HTML), * Now displays proper error message, if the file-system method is not set to "direct", * This plugin is now compatible with the new [Humanmade content importer plugin](https://github.com/humanmade/WordPress-Importer), * Added a filter to the plugin page creation, so that theme authors can now change the location of the plugin page (Demo data import) and some other parameters as well. = 1.1.1 = *Release Date - 22 May 2016* * Preview import images can now be defined for multiple predefined import files (check FAQ "How to predefine demo imports?" for more info), * You can now also import customizer settings. = 1.1.0 = *Release Date - 14 May 2016* * Content import now imports in multiple AJAX calls, so there should be no more server timeout errors, * The setting for generation of multiple image sizes in the content import is again enabled by default, * Plugin textdomain was loaded, so that translations can be made. = 1.0.3 = *Release Date - 27 April 2016* * Added filter to enable image regeneration, * Added filter to change the plugin intro text, * Added action to execute custom code before widget import, * Disabled author imports. = 1.0.2 = *Release Date - 15 April 2016* * Monkey fix for WP version 4.5. - disabled generation of multiple image sizes in the content import. = 1.0.1 = *Release Date - 2 April 2016* Small code fixes: * Fixed undefined variable bug, * Fixed naming of downloaded files and their filters. = 1.0.0 = *Release Date - 25 March 2016* * Initial release!