Warning
You're browsing the documentation for an old version of Webiny. Consider upgrading your project to Webiny 5.35.x.

Changes

Code Upgrades
anchor

Turned on Strict TypeScript (#2235 external link)
anchor

With this release, we turned on strict Typescript in our repository and increased TS to version to 4.5.5. This was a really large rewrite of our code (~1500 files updated). We still have some TODOs left in the code, but the main part of the work is done.

Existing user projects are not upgraded, because it would most certainly cause a lot of failed builds. Users can upgrade TS version themselves, and fix their local code in their projects. New user projects will be created with strict Typescript and the 4.5.5 version.

We will upgrade to the latest Typescript (4.6.3, at the time of writing) as soon as eslint resolves some compatibility problems with it.

Switched to React Router V6 (#2277 external link)
anchor

Due to some 3rd part dependency issues with TS types, we were forced to upgrade to React Router v6. User projects should not be affected, because we created wrappers around React Router v6 components and hooks, to make it work with our existing user project code without any changes to it.

New Features
anchor

Block Navigation From the CMS Entry Form on Unsaved Changes (#2285 external link)
anchor

Prior to this release, while editing a CMS content entry, your changes would be lost if you navigated away from the form. With this release, you will no longer be able to accidentally navigate away, and you’ll get a prompt to confirm or cancel navigation to another route.

Added GraphQL Methods to Fetch the Latest or Published CMS Entries via the Manage API (#2266 external link)
anchor

Some users asked us to provide a way to query for latest and published entries via the Headless CMS manage API. By default, manage API is loading the latest content entry revisions. This PR adds an extra parameter to control the type of revision that will be returned. We also added status icons for the reference and multi-reference fields for each of the referenced entries.

# get latest revision
query GetArticle {
  getArticle(entryId: "abc", status: latest) {
    # ...
  }
}

# get latest revision (`status` parameter defaults to "latest")
query GetArticle {
  getArticle(entryId: "abc") {
    #...
  }
}

# get published revision
query GetArticle {
  getArticle(entryId: "abc", status: published) {
    # ...
  }
}

Bugfixes
anchor

Fixed Error When Storing Multiple Reference Field in CMS Entry (#2264 external link)
anchor

Prior to this release, if a new, optional multi-reference field was added to an existing content model, which already had content entries, and tried to save the existing entry without adding entries to this new ref field, a validation error was thrown. This is now fixed. This PR also includes a stricter CMS Entry GraphQL input check on array inputs. To turn this check off, set the HEADLESS_CMS_GRAPHQL_INPUT_REQUIRE_ARRAY_ITEM environmental variable to false.

Clear the GraphQL Scheme Cache After CMS Model Was Cloned (#2288 external link)
anchor

This PR fixes an issue with schema cache invalidation when an existing content model is cloned.

Fix Debug Logging From Lambda to Browser Console (#2301 external link)
anchor

This PR fixes the @webiny/handler-graphql package and its debug logging capabilities, so console.logs get properly forwarded to the browser’s console. This means that every time you do a console.log somewhere in your GraphQL API, those logs will be grouped per GraphQL operation, and printed in your browser’s dev tools.

Other
anchor

Source Map Support
anchor

All of our packages will now have source maps generated. That will greatly help in debugging issues. We have also added source map support for all lambda functions. It’s enabled by default, but you can disable it by adding sourceMaps: false to createBuildFunction inside your lambdas’ webiny.config.ts files.

GraphQL Errors Include Stacktrace
anchor

We’ve added a new stacktrace field (namely stack) to errors returned from GraphQL API for a better debugging experience. This behavior is optional and needs to be enabled by passing DEBUG=true environmental variable (for example to your .env file). For best experience it requires source maps to be enabled.