Skip to content

Latest commit

 

History

History
272 lines (232 loc) · 7.79 KB

MIGRATION.md

File metadata and controls

272 lines (232 loc) · 7.79 KB
Logo for Strapi preview button plugin

Strapi Preview Button Migration Guides

Follow our migration guides to keep your preview button plugin up-to-date.

Get Started


Migrate from v1 to v2

The breaking changes in this migration focus on improving plugin options and also a simple find and replace for a parameter name in the before-build-url hook.

injectListViewColumn

Previously, this config options was used alongside the rest of the config options in ./config/plugins.js but it has moved to the pluginOptions prop of a model schema and will need to be applied to each schema individually.

In addition to the new location, the injectListViewColumn option is renamed to listViewColumn and it is set to true by default. You can disable the extra column by setting this value to false like in the code below.

This change allows Strapi to inject a custom column into the content manager's list view without relying on fetching data, which solves issues that were related to this feature.

❌ Not correct

// ./config/plugins.js
'use strict';

module.exports = {
  'preview-button': {
    config: {
      injectListViewColumn: true,
      contentTypes: [
        // etc.
      ],
    },
  },
};

✅ Correct

// ./src/api/page/content-types/page/schema.js
{
  "kind": "collectionType",
  "collectionName": "pages",
  "info": {
    "singularName": "page",
    "pluralName": "pages",
    "displayName": "Page",
    "description": ""
  },
  "options": {
    "draftAndPublish": true
  },
  "pluginOptions": {
    "preview-button": {
      "listViewColumn": true
    }
  },
  "attributes": {
    // etc.
  }
}

openTarget

Previously, this config options was used alongside the rest of the config options in ./config/plugins.js but it has moved to the contentTypes[].draft and contentTypes[].published props of the plugin options and will need to be applied to each prop individually.

❌ Not correct

// ./config/plugins.js
'use strict';

module.exports = {
  'preview-button': {
    config: {
      openTarget: 'CustomName',
      contentTypes: [
        // etc.
      ],
    },
  },
};

✅ Correct

// ./config/plugins.js
'use strict';

module.exports = {
  'preview-button': {
    config: {
      contentTypes: [
        {
          uid: 'api::page.page',
          draft: {
            url: 'https://example.com/api/preview',
            query: {
              type: 'page',
              slug: '{slug}',
            },
            openTarget: 'CustomName',
          },
          published: {
            url: 'https://example.com/{slug}',
            openTarget: 'CustomName',
          },
        },
      ],
    },
  },
};

Parameters for the before-build-url custom hook have changed

Previously, the parameters for the custom hook before-build-url included a state prop which should be returned by your custom hook. This prop is now removed and in its place are the props draft to published.

The state prop always represented either the draft or published prop from the plugin config, but now the return value of your hook should return both props instead of just one.

❌ Not correct

// ./admin/src/index.js
export default {
  bootstrap(app) {
    app.registerHook('plugin/preview-button/before-build-url', ({ data, state }) => {
      const query = state?.query ?? {};

      // Return modified `state` object here using `data` however you like.
      return {
        state: {
          ...state,
          query: {
            ...query,
            foo: 'bar',
          },
        },
      };
    });
  },
};

✅ Correct

// ./admin/src/index.js
export default {
  bootstrap(app) {
    app.registerHook('plugin/preview-button/before-build-url', ({ data, draft, published }) => {
      const draftQuery = draft?.query ?? {};

      // Return an object with modified `draft` and `published` props using `data` however you like.
      return {
        draft: {
          ...draft,
          query: {
            ...draftQuery,
            foo: 'bar',
          },
        },
        published,
      };
    });
  },
};

Migrate from v0 to v1

The breaking changes in this migration are focused on configuration while simplifying code and requirements. As a result, much of the plugin configuration has changed.

Environment vars are no longer required

Previously, the plugin required the following env vars be configured in order to use the preview button.

STRAPI_PREVIEW_SECRET=YOURSECRET
STRAPI_PREVIEW_DRAFT_URL=https://example.com/api/preview
STRAPI_PREVIEW_PUBLISHED_URL=https://example.com

This is now optional and requires no extra handling from this plugin. To continue using these env vars, simply include them as you see below:

// ./config/plugins.js
module.exports = ({ env }) => {
  'preview-button': {
    config: {
      contentTypes: [
        {
          uid: 'api::page.page',
          draft: {
            url: env('STRAPI_PREVIEW_DRAFT_URL'),
            query: {
              type: 'page',
              slug: '{slug}',
              secret: env('STRAPI_PREVIEW_SECRET'),
            },
          },
          published: {
            url: `${env('STRAPI_PREVIEW_PUBLISHED_URL')}/{slug}`,
          },
        },
      ],
    },
  },
};

Deprecated basePath and targetField options

These options are no longer used. See the section in the README about mapping data into the URLs for customizing URLs.

New options

url

Both draft and published configurations now require a url prop which allows mapping data from the entry data into the URL with great ease. See the section in the README about mapping data into the URLs for customizing URLs.

copy

A "Copy Link" button has been added beneath the preview button in the content manager. This button is enabled by default.

If you wish to disable this button for the draft or published state (or both) then you need to use copy: false for draft and published configurations as you see below:

// ./config/plugins.js
{
  uid: 'api::page.page',
  draft: {
    url: 'https://example.com/api/preview',
    query: {
      type: 'page',
      slug: '{slug}',
    },
    copy: false,
  },
  published: {
    url: 'http://example.com/{slug}',
    copy: false,
  },
}

injectListViewColumn

An icon button for the preview and copy buttons have been added to a new column in the list view of the content manager.

If you wish to disable this, set it to false. This applies to all configured content types.

// ./config/plugins.js
module.exports = {
  'preview-button': {
    config: {
      injectListViewColumn: false,
      contentTypes: [
        // etc.
      ],
    },
  },
};

Other details

In case you have been extending the plugin yourself, it may be useful to know a few extra behind-the-scenes details.

No more re-fetching

The plugin no longer fetches the preview URLs on state change. Instead the plugin config is loaded when Strapi starts and is available on the frontend at all times.

Single and Collection types

The plugin no longer needs to differentiate between single types and collection types.

Localization

If you have localization enabled for a content type, the locale is now automatically parsed into the URLs as long as you include {locale} in your config. See the section in the README about Using with localization enabled with the preview button.