Integration Field-Type
In many cases, you will want to have more space for selecting content from a different API similar to how you can select different products in the image below. For this use case, we created an integration field-type starter kit: github.com/storyblok/storyblok-integration-field-starter
data:image/s3,"s3://crabby-images/06afe/06afec3d596ac1d42349b95b556d7a064090cf38" alt="Integration Selection")
Getting Started
Start by cloning the repository and installing the dependencies.
$ git clone https://github.com/storyblok/storyblok-integration-field-starter.git
$ cd storyblok-integration-field-starter
$ npm i
Next, we need to create a new custom field-type in the Partner Portal. Click on Field-types {1} and the New button {2} and enter the name for your integration field-type {3}.
data:image/s3,"s3://crabby-images/95ac1/95ac18881eb5a9df66593286e15a9eb0a21c331d" alt="")
Next, we need to add the name of our new plugin to the src/Plugin.vue
file.
src/Plugin.vue
initWith() {
return {
// needs to be equal to your storyblok plugin name
plugin: 'my-integration',
item: null
}
},
Then start the development server.
npm run dev
To preview the field-type open the field-type in Storyblok, change the URL from https to http {1} and click the Enable local dev mode {2}. If your localhost is running, you should see the Open Selection Button {3}.
data:image/s3,"s3://crabby-images/0922e/0922e3bb532e52c79aa135e9b7a2108b6f710231" alt="Integration Starter in Storyblok")
Now if you click Open Selection {3}, you should get a full window with a spinning loader, where you will be able to load your integration logic.
data:image/s3,"s3://crabby-images/05062/05062d0e1f22f5cd38fec3802f4bb6b1fb4c7974" alt="")
Integration Logic
The integration field-type makes use of field-type API events to open and close a modal within Storyblok. These events can be used in any field-type.
src/Plugin.vue
openSelection() {
this.modalIsOpen = true
this.$emit('toggle-modal', true)
},
closeSelection() {
this.modalIsOpen = false
this.$emit('toggle-modal', false)
},