A Storyblok Field-Type Plugin to fetch products, categories, storyblok pages and set an external link.
- Node 14.x.x
npm install
npm run serve
npm run build
npm run lint
Every Storyblok space should have a basic config for the linkPlugin to work (see image below). You can copy the examples for Paagman / TZO and add them to the switch case. Your spaceId is logged to your console or you can find it next to the space in the field type editor. These setting are the default and can be overwritten in every component where you use the plugin.
Property | Description |
---|---|
magentoUrl | The URL that will be used to fetch the products & categories |
productsLimit | The maximum amount of products that can be selected. |
contentTypes | The contentTypes that can be fetched from the Storyblok API (e.g. CmsPage, BlogPost) |
selectionOptions | The options the user can select from the dropdown. |
primaryColor | The primaryColor so the linkPlugin has the some colors as the website |
Once you've added your configuration you should push it to the git repositiory so we all have the latest version of the plugin. After that you can use npm run build
and paste the code from /dist/export.js in the field-type-plugin editor. Once you've done that and select products from the dropdown you should see some products like below.
Whenever you want to use the linkPlugin in a component add a field to the schema and select Plugin.
Under "Custom Type" dropdown select "ecommerce-link-plugin".
Under that you can add options. these options will overwrite the config in the plugin code. For example :
This will let the user of the component select a maximum of 3 items and it will only show the option to select products. You can see the options you can overwrite in your console :
Either click on a already selected item in the modal or click the trashcan next to the image
You can drag and drop the items to reposition them
If you select multiple products the products will be added to the items
property
Property | type | Description |
---|---|---|
id | string | Attribute uid in the query |
name | string | Attribute name in the query |
url | string | Attribute url_key in the query |
sku | string | The sku of the product |
typename | string | Attribute __typename in the query (e.g.) Configurable product / SimpleProduct |
type | "product" | The type to determine the what the item is in this case product |
If you select a single product it will be added to the item
property
Property | type | Description |
---|---|---|
id | string | Attribute uid in the query |
name | string | Attribute name in the query |
url | string | Attribute url_key in the query |
sku | string | The sku of the product |
typename | string | Attribute __typename in the query (e.g.) Configurable product / SimpleProduct |
type | "product" | The type to determine the what the item is in this case product |
If you select a category it will be added to the item
property
Property | type | Description |
---|---|---|
id | string | Attribute uid in the query |
name | string | Attribute name in the query |
url | string | Attribute url_key in the query |
type | "category" | The type to determine the what the item is in this case category |
If you select a page it will be added to the item
property
Property | type | Description |
---|---|---|
id | string | Attribute uuid in the query |
name | string | Attribute name in the query |
url | string | Attribute full_slug in the query |
type | "page" | The type to determine the what the item is in this case page |
If you select a external link it will be added to the item
property
Property | type | Description |
---|---|---|
url | string | The url you input from the input field |
openInNewTab | boolean | The value from the radio input |
type | "link" | The type to determine the what the item is in this case link |