<aside> ✅ Upgrade a custom ScandiPWA module in Magento theme mode to the newer version

</aside>

There may be an issue when the composer is installing a newer package version than it’s required. The newer package can contain the breaking changes that cause project crashes.

In order to prevent this, the ScandiPWA theme should be up to date. But for some cases, this is not possible.

Thus ScandiPWA has strict composer versions for the scandipwa/* modules.

<aside> 🚨 Heads up!

Updating all ScandiPWA modules using composer update "scandipwa/*" may lead to the issue described above. Use it at your own risk!

</aside>

The following steps must be completed to update a custom ScandiPWA module to the specific version:

  1. Edit composer.json
  2. Update ScandiPWA composer dependencies

1. Edit composer.json

Open a composer.json file in your theme directory and set desired version for packages you need. You might want to update multiple packages at once.

2. Update ScandiPWA composer dependencies

In order to update ScandiPWA composer dependencies you have to run the composer update command with all packages you trying to update.

For example, if you edited composer.json and set new versions to scandipwa/catalog-graphql and scandipwa/compare-graphql, the command would be the following:

composer update scandipwa/catalog-graphql scandipwa/compare-graphql

<aside> 🚨 Heads up!

You cannot update a ScandiPWA composer dependency directly, without modifying the composer.json file.

If you try this, you will get the error like this:

</aside>

Only root package requirements can receive temporary constraintsand scandipwa/quote-graphql is not one

<aside> 🚨 Heads up!

If you don’t mention all updated packages in the update command, you will get the following error:

</aside>

Your requirements could not be resolved to an installable set of packages.