Version 11 to 12
This migration guide contains migration instructions for:
- eightshift/boilerplate - 11+ --> 12.0.0
- eightshift/boilerplate-plugin - 4+ --> 5.0.0
- eightshift/frontend-libs - 11+ --> 12.0.0
- eightshift/libs - 7+ --> 8.0.0
This release contains a couple of breaking changes! Check the list below for details about changes that will have to be made.
Also, a couple of changes are optional, but recommended.
The major update on this release is the "cache" loading functionality and refactoring of helpers.
Important changes
This version was focused on improving speed and performance of the project and we set the minimum PHP version to 8.2 so if you project is using older PHP version you should update it before updating the setup.
Setup scripts
We changed the setup script repository and flow so if you are creating a new project you should use the new setup script.
Theme:
// Old setup script
npx create-wp-project
// New setup script
npx eightshift-create theme
Plugin:
// Old setup script
npx create-wp-project plugin
// New setup script
npx eightshift-create plugin
Required changes
The following changes are required to update your project to the latest version.
Remove Manifest class
Migration time: ~1min.
The Manifest
class has been removed. If you are using this class in your project, please remove it.
Update Enqueue classes
Migration time: ~5min.
-
If you're using
EnqueueTheme
,EnqueueBlocks
orEnqueueAdmin
classes, remove the$this->manifest
dependency from the constructor. -
If you're using the
$this->manifest->getAssetsManifestItem
method in your project, replace it with the newHelpers::getAsset
method. -
If you're using the
getBlockFrontentScriptHandle
method, rename it togetBlockFrontendScriptHandle
. -
If you're using a custom
wp_register_script
, update the function to use the newHelpers::getAsset
method and update the script handle if using WordPress 6.3+.
Add the Cache
class
Migration time: ~5min.
-
Run the
wp boilerplate create manifest-cache
CLI command to add the cache functionality to your project. -
Open the
functions.php
(or<plugin-name>.php
) file and add the following code before theMain
class initialization:
if (\class_exists(ManifestCache::class)) {
(new ManifestCache())->setAllCache();
}
Replace the ManifestItem
filter with the Asset helper
Migration time: ~2min.
If you're using the apply_filters(Manifest::MANIFEST_ITEM, '<key>')
filter in your project, replace it with the Helpers::getAsset('<key>')
helper.
Update helpers
Migration time: ~5min.
-
Find all instances of the
outputCssVariablesGlobal(array $globalManifest = [])
function and remove the global settings variable, eg.outputCssVariablesGlobal()
. -
Find all instances of the
outputCssVariables(array $attributes, array $manifest, string $unique, array $globalManifest = [], string $customSelector = '')
function and remove the global settings variable, eg.outputCssVariables(array $attributes, array $manifest, string $unique, string $customSelector = '')
.
Replace all renderPartial
methods
Migration time: ~15min.
Find all instances of the renderPartial
method and replace it with the render
method.
Before:
echo Components::renderPartial(
'component',
'utils',
'debug-field-details',
[
'name' => Components::checkAttr('fieldName', $attributes, $manifest),
]
);
After:
echo Components::render(
'debug-field-details',
[
'name' => Components::checkAttr('fieldName', $attributes, $manifest),
],
'components',
false,
'utils/partials'
);
Update the render
method
Migration time: ~10min.
Find all instances of the render
method to which more than 2 arguments are passed and update the method call to match the new signature.
Before:
return Components::render(
'form',
Components::props('form', [], $formProps),
'',
true
);
After:
return Components::render(
'form',
Components::props('form', [], $formProps),
'components',
true
);
Update the wrapper and all blocks with innerBlockContent
Migration time: ~15min.
- Find all instances of the
$this->renderWrapperView
method in your project and replace it withecho $renderContent
method. - Find all instances of the
$innerBlockContent
variable and replace it withecho $renderContent
. (applies to the wrapper, and blocks using inner blocks, like Group, Columns, ...) - Remove the
wrapperManualContent
parameter from allwrapper
instances. For more details, check the example
Before:
$this->renderWrapperView(
$templatePath,
$attributes,
$innerBlockContent
);
After:
echo $renderContent;
Replace the Components
helper
Migration time: ~5min.
Helper functions from the Components
class are renamed, and will be deprecated in the next version. They are now located in the Helpers
class. Functions were not changed beyond the rename (except the ones mentioned above).
The fastest way to change them is to search and replace Components::
with Helpers::
, and eightshiftLibs\Helpers\Components
with eightshiftLibs\Helpers\Helpers
in the project.
Fix Custom Post Type or Taxonomy registration
Migration time: ~5min.
We removed getGeneratedLabels
helper so you should update your custom post type or taxonomy registration.
You can check the custom post type example or custom taxonomy example from the boilerplate.
Update webpack config
Migration time: ~2min.
We have removed BrowserSync
from the project so you should update your webpack config.
Before:
const projectConfig = {
config: {
projectDir: __dirname, // Current project directory absolute path.
projectUrl: 'eightshift.com', // Used for providing browsersync functionality.
projectPath: 'wp-content/plugins/eightshift-forms', // Project path relative to project root.
useSsl: true, // Whether to use https or http.
},
};
After:
const projectConfig = {
config: {
projectDir: __dirname, // Current project directory absolute path.
projectPath: 'wp-content/plugins/eightshift-forms', // Project path relative to project root.
},
};
Replace Imposter with Strauss
Migration time: ~10min.
We have removed Imposter and replaced it with Strauss for prefixing namespaces.
- Add
/vendor-prefixed
to your .gitignore file - Add strauss.phar to your theme root. You can get it here
- Make the following changes in your composer.json file:
- remove
typisttech/imposter-plugin
- add the following in the
scripts
section:
"prefix-namespaces": [
"@php strauss.phar",
"composer dump-autoload"
],
"post-install-cmd": [
"@php strauss.phar",
"composer dump-autoload"
],
"post-update-cmd": [
"@php strauss.phar",
"composer dump-autoload"
]
- remove
imposter
from theextra
section and add the following:
"strauss": {
"namespace_prefix": "ProjectNameVendor",
"exclude_from_prefix": {
"file_patterns": ["/Example.php$/"]
}
}
- Update functions.php file
/**
* Bailout, if the theme is not loaded via Composer.
*/
if (!\file_exists(__DIR__ . '/vendor/autoload.php')) {
return;
}
/**
* Require the Composer autoloader.
*/
$loader = require __DIR__ . '/vendor/autoload.php';
/**
* Require the Composer autoloader for the prefixed libraries.
*/
if (\file_exists(__DIR__ . '/vendor-prefixed/autoload.php')) {
require __DIR__ . '/vendor-prefixed/autoload.php';
}
- Add the following line in your phpcs.xml.dist:
<exclude-pattern>*/vendor-prefixed/*</exclude-pattern>
- Add the following line in your phpstan.neon.dist in
boostrapFiles
section:
- vendor-prefixed/autoload.php
Once you have made these changes, remove the vendor
folder and run composer install
.