codeinwp / ti-onboarding
Onboarding for themeisle themes.
Installs: 26 432
Dependents: 0
Suggesters: 0
Security: 0
Stars: 0
Watchers: 4
Forks: 5
Open Issues: 6
Requires (Dev)
- dealerdirect/phpcodesniffer-composer-installer: ^0.4.4 || ^0.5.0 || ^0.6.0
- squizlabs/php_codesniffer: ^3.1
- wp-coding-standards/wpcs: ^1.0.0 || ^2.0.0
- dev-master
- 1.8.3
- 1.8.2
- 1.8.1
- 1.8.0
- 1.7.12
- 1.7.11
- 1.7.10
- 1.7.9
- 1.7.8
- 1.7.7
- 1.7.6
- 1.7.5
- 1.7.4
- 1.7.3
- 1.7.2
- 1.7.1
- 1.7.0
- 1.6.3
- 1.6.2
- 1.6.1
- 1.6.0
- 1.5.1
- 1.5.0
- 1.4.2
- 1.4.1
- 1.4.0
- 1.3.6
- 1.3.5
- 1.3.4
- 1.3.3
- 1.3.2
- 1.3.1
- 1.3.0
- 1.2.1
- 1.2.0
- 1.1.1
- 1.1.0
- 1.0.0
- dev-dependabot/npm_and_yarn/eslint-plugin-vue-7.7.0
- dev-dependabot/npm_and_yarn/uglify-js-3.13.0
- dev-dependabot/npm_and_yarn/cypress-6.6.0
- dev-dependabot/npm_and_yarn/cypress-6.5.0
- dev-dependabot/npm_and_yarn/uglify-js-3.12.8
- dev-dependabot/npm_and_yarn/eslint-plugin-vue-7.6.0
- dev-dependabot/npm_and_yarn/elliptic-6.5.4
- dev-dependabot/npm_and_yarn/vuex-3.6.2
- dev-dependabot/npm_and_yarn/socket.io-2.4.1
- dev-dependabot/npm_and_yarn/npm-6.14.11
- dev-dependabot/npm_and_yarn/ini-1.3.8
- dev-dependabot/composer/dealerdirect/phpcodesniffer-composer-installer-0.7.1
- dev-dependabot/npm_and_yarn/cross-env-7.0.3
- dev-dependabot/npm_and_yarn/semantic-release-17.2.3
- dev-dependabot/npm_and_yarn/eslint-plugin-html-6.1.1
- dev-dependabot/composer/squizlabs/php_codesniffer-3.5.8
- dev-dependabot/npm_and_yarn/npm-user-validate-1.0.1
- dev-dependabot/npm_and_yarn/acorn-7.4.1
- dev-dependabot/npm_and_yarn/node-fetch-2.6.1
- dev-dependabot/npm_and_yarn/http-proxy-1.18.1
- dev-dependabot/npm_and_yarn/npm-registry-fetch-4.0.7
- dev-development
- dev-dependabot/npm_and_yarn/semantic-release/changelog-5.0.1
- dev-dependabot/npm_and_yarn/grunt-version-2.0.0
- dev-page-slugs
This package is auto-updated.
Last update: 2021-03-08 11:39:39 UTC
README
The ThemeIsle onboarding module serves as aid for theme authors to enable an easier onboarding UX, allowing to install and activate plugins, change theme mods, and import content with XML files.
How do I use this?
- Include the ThemeIsle Onboarding Module.
- Declare theme support in your theme.
- Add the import files in your theme folder.
- Render the onboarding application in your admin page
- Disable the ThemeIsle Onboarding Module.
1. Include the ThemeIsle Onboarding Module
There are two ways in which you can use the Onboarding Module:
- Include this repository directly in your project
- Include it as a composer dependency -
composer require "codeinwp/ti-onboarding"
2. Declare Theme Support
You have to declare theme support in order to make the Onboarding work. Here's an example:
add_theme_support( 'themeisle-demo-import', array(
'editors' => array(
'elementor',
'gutenberg',
),
'local' => array(
'elementor' => array(
'neve-main' => array(
'url' => 'https://demo.themeisle.com/neve',
'title' => 'Neve 2018',
),
),
'beaver_builder' => array(
'neve-main' => array(
'url' => 'https://demo.themeisle.com/neve',
'title' => 'Neve 2018',
),
),
),
'i18n' => array(
'templates_title' => __( 'Ready to use pre-built websites with 1-click installation', 'neve' ),
'templates_description' => __( 'With Neve, you can choose from multiple unique demos, specially designed for you, that can be installed with a single click. You just need to choose your favorite, and we will take care of everything else.', 'neve' ),
),
) );
3. Add Import Files to Your Theme Folder
There are three main files that must be added to your theme so that the demo import can work:
- An XML file containing the demo content - you can get that by using the WordPress exporter. It should be named
export.xml
; - A screenshot file that will be displayed for your demo instance. It should be named
screenshot.png
; - A
data.json
file containing other data. You can see the format in which it should be delivered here
4. Render the Onboarding in Your Admin Page
After everything is loaded, you should make sure that you render the onboarding application where you want it displayed. The snippet below should do this:
if ( class_exists( '\Themeisle_Onboarding' ) ) {
$onboarding = \Themeisle_Onboarding::instance();
$onboarding->render_onboarding();
}
5. Disable the ThemeIsle Onboarding Module
To disable the module, just add the snippet below:
define( 'TI_ONBOARDING_DISABLED', true );
NOTE: The styling of this might not work ideal everywhere, so you might have to tweak it with some of your own CSS magic.
Formatting the data.json
File
The data.json
file you deliver should respect the following format:
{
"theme_mods": {
"neve_navigation_layout": "left",
"neve_theme_color": "#00a4f7",
"__ti_import_menus_location": {
"primary": "main-menu"
}
},
"widgets": {
"blog-sidebar": {
"rss-1": {
"title": "",
"url": "https:\/\/www.themeisle.com\/blog\/feed\/",
"items": 5,
"show_summary": 0,
"show_author": 0,
"show_date": 0
},
},
"shop-sidebar": {
"woocommerce_product_search-9": [],
"woocommerce_widget_cart-5": []
}
},
"recommended_plugins": {
"woocommerce": "WooCommerce",
"themeisle-companion": "Orbit Fox by ThemeIsle"
},
"front_page": {
"front_page": "neve-home",
"blog_page": "blog"
},
"shop_pages": {
"woocommerce_shop_page_id": "shop",
"woocommerce_cart_page_id": "cart",
"woocommerce_checkout_page_id": "checkout",
"woocommerce_myaccount_page_id": "my-account"
}
}
There are 5 main things to define here:
The theme_mods
key:
This holds key:value
pairs of the theme mod key and the value that you want to set upon importing.
Also inside the theme_mods
key you have to define where the navigation menus are going to be placed (under the __ti_import_menus_location
key). In the example above, the primary
nav menu location is assigned the menu with the main-menu
slug.
The widgets
key:
This holds the widgets that you will import. You can get the content of this using the Widget Importer & Exporter Plugin. The .wie
file that it exports holds the data you need to add here in order to properly map the widgets.
The recommended_plugins
key:
This holds the plugins that you recommend. The format used is "plugin-slug":"Plugin Nicename"
.
The front_page
key:
This holds key value pairs for the static front page setup using the page slug (neve-home
/blog
). If you don't want to set anything, you should just send null
here.
The shop_pages
key:
This holds key value pairs for the shop pages that you want to set in case you're importing a WooCommerce shop. The logic is the same as in the case of the front page. You should use the page slug to set this up.
License
The ThemeIsle Onboarding Module is licensed under the GPLv2 or later.
Credits
- The XML importer is based on the HumanMade WordPress-Importer repository, licensed under GPLv2 or later.
- The widgets importer is based on the CrunchThemes Widget Importer & Exporter, licensed under GPLv2 or later.