Storefront Application (RC)
1.0.0-rc.10
π₯ Highlights
π‘ HTTP Request tracing with OpenTelemetry
The Storefront Boilerplate now includes a built-in integration with OpenTelemetry. To enable the feature, set the environment variable OTEL_ENABLED
to true
. This will inject additional code into your application's entrypoint which will initialize the OpenTelemetry SDK. Automatic instrumentations as well as instrumentations from storefront-nuxt
will be captured and exported via the OTLP protocol.
Currently, Vercel and Node are the only supported platforms for the OpenTelemetry integration. Setting OTEL_ENABLED
to true
when building for other platforms will have no effect.
You should also set the runtime variable OTEL_SERVICE_NAME
to configure the service name used in traces. e.g. OTEL_SERVICE_NAME=storefront-boilerplate
Note: this variable is used directly by the OpenTelemetry libraries and is not available in the Nuxt runtimeConfiguration
.
ποΈ Improved UX / UI for Promotions
We've redesigned the promotion badges displayed on the Product Listing Page, the Wishlist, and the Basket page. The Badge text originates from Storefront APIs customData
, with headlineParts
in bold and badgeLabel
in regular font. We now implement ellipsis for long badgeLabel
texts.
Please Note: Due to space constraints, the basket page shows only badgeLabel
; if it is missing, it will fallback to headlineParts
.
We have also improved the user experience on the Product Detail page with free gift options. When the condition of a product, that has a free gift option configured, are met, a free gift option will be displayed on the page with a grayed-out overlay. Once conditions are met, a free gift option will be enabled and the user can add a free gift product to the cart.
π Improved linting setup with ESLint v9
The Storefront Boilerplate now includes an improved linting setup. Relying on the new ESLint 9 and @nuxt/eslint
module to provide more project-aware linting. To make configuration more easier the ESLint config has been updated to the new flat config format, allowing for simpler customization and overriding of rules. Additionally the default Storefront ESLint config @scayle/eslint-config-storefront
v4 is now using a subset of opinionated rules of @antfu/eslint-config
.
Minor Changes
- Added subscription cancellation page to the subscription module
- New Price adoptions for basket page for promotions
- Increased eslint
no-composable-after-await
rule error level and fix the issues - Fix caching for domain-based setups where we now consider the host for the SSR cache key.
Additionally, we now set anintegrity
value that invalidates the SSR cache automatically when a new build is deployed. You can control the value through theVERSION
environment variable, which should be set to your current Git short commit sha.
Either you can set this normally during your build processVERSION=147f33d yarn build
or when using the docker imagedocker build --build-arg VERSION=${GIT_SHORT_COMMIT_SHA} -f docker/node/Dockerfile .
Patch Changes
- Removed an unnecessary CSS property which caused a visual bug on basket page
- Resolved a bug that affected the fetching of
combineWith
products - Resolved the issue where the welcome login tab was displayed instead of the registration tab upon clicking the register link.
- Implemented a new utility function to format addresses dynamically. The function adjusts the address format according to the countryCode
π‘ Dependency Updates
ποΈ devDependencies
- Added
"@eslint/eslintrc@3.0.2",
- Added
@nuxt/eslint@0.3.10
- Updated to
@nuxt/test-utils@3.12.1
- Updated to
@nuxtjs/i18n@8.3.1
- Updated to
@nuxtjs/tailwindcss@6.12.0
- Updated to
@scayle/eslint-config-storefront@4.0.0
- Updated to
@upstash/redis@1.30.0
- Updated to
@vitest/coverage-v8@1.5.2
- Updated to
eslint@9.1.1
- Updated to
postcss-custom-properties@13.3.8
- Updated to
vitest@1.5.2
- Updated to
vue-tsc@2.0.15
π dependencies
- Added
@opentelemetry/api": "1.8.0
- Added
@opentelemetry/auto-instrumentations-node": "0.45.0
- Added
@opentelemetry/exporter-trace-otlp-proto": "0.51.0
- Added
@opentelemetry/instrumentation": "0.51.0
- Added
@opentelemetry/resources": "1.24.0
- Added
@opentelemetry/sdk-node": "0.51.0
- Added
@opentelemetry/semantic-conventions": "1.24.0
- Added
@vercel/otel": "1.8.2
- Added
knitwork": "1.1.0
- Updated to
@scayle/omnichannel-nuxt": "3.0.0
to be compatible with latest Omnichannel API - Updated to
@scayle/storefront-nuxt": "7.66.4
- Updated to
@storyblok/nuxt": "6.0.10
- Updated to
@storyblok/vue": "8.0.8
- Updated to
@tailwindcss/typography": "0.5.13
- Updated to
cf-content-types-generator": "2.15.1
- Updated to
contentful": "10.9.0
- Updated to
storyblok-js-client": "6.7.3
v1.0.0-rc.9
π₯ Highlights
π Introducing Contentful as the new CMS Provider for StorefrontCMS
We've added a Contentful integration as an alternative to using Storyblok as a CMS provider. This allows you to fetch data from Contentful and use it in your SFB. To use this feature, you need to provide your Contentful space ID and access token in the .env
file. You can find these values in your Contentful account settings.
NUXT_PUBLIC_CMS_ACCESS_TOKEN=your-access-token
NUXT_PUBLIC_CMS_SPACE=your-space-id
Once you have added these values, you can use Contentful by selecting the contentful
option in the cms.provider
field of the nuxt.config.ts
file.
export default defineNuxtConfig({
// ...
cms: {
provider: 'contentful',
},
// ...
})
Now you have access to useCMS
composables and fetch data from Contentful in your SFB. useCMS
accepts a string as an argument that will be used for caching purposes and returns a fetchBySlug
function that you can use to fetch data by slug. fetchBySlug
is a wrapper around Nuxt's useAsyncData
and accepts a generic type that you can use to define the shape of the data you are fetching. Here is an example of how you can use this feature:
import type { TypeListingPageSkeleton } from '~/modules/cms/providers/contentful/types/contentful-defs'
const props = defineProps<{
selectedCategory: number | undefined
}>()
const route = useRoute()
if (!props.selectedCategory) {
console.log('No category selected')
}
const { fetchBySlug } = useCMS(`ListingPage-${route.path}`)
const { data } = await fetchBySlug<TypeListingPageSkeleton>(
`categories/${props.selectedCategory}`,
)
π Introducing Search Engine v2
We've implemented and replaced the whole search flow based on the new Storefront API's Search Engine v2
. This includes:
- Overall UI and UX adaptations (header search input, suggestions dropdown, applicable filter indicator, search within the mobile sidebar, etc.)
- Category suggestions that can have filters applied
- Product suggestions that are resolved only by entering the exact ID
- Refined flow when resolving the search term
- Search page usage only as a fallback
Added Subscription Add-on
We've implemented the Subscription Add-ons as a local module. The subscription feature enables customers to subscribe to a specific variant of a product, which is then delivered at regular intervals on a chosen day. This convenience allows customers to make regular purchases effortlessly.
π Major Changes
- Fixed an issue where an empty IDP component was shown when no IDPs were enabled. The
useIDP
composable now returns an empty object when the IDP integration is not enabled. Ensure that the user is redirected to CO when entering the sign-in page with aredirectUrl
parameter. This is now possible with the@scayle/storefront-nuxt@{version}
. We refactored the IDP callback to have its page to ensure we only call the IDP login RPC once. - Improved Storyblok integration through the SCAYLE Panel Add-on and plugin
- Disabled caching for Vercel Deployments Vercel's CDN Caching works slightly differently from the default Nuxt Page caching, which is currently incompatible with our Session handling. To disable all caching for Vercel Deployments, remove any
routeRules
you have configured in yournuxt.config.ts
. - Added ability to scroll to anchor links on the same page. The
Paragraph
component now supports ananchor
prop that will be used to create an anchor target for that paragraph. If you have a Table of Contents and want to link to a specific paragraph, you can use the create links function on any text in your Content to create a link to it. When the user clicks on the link, he will scroll to the paragraph on the page. We also introduced a new component,NestedParagraph,
that allows adding nested paragraphs, for example, for ordered lists.
π Minor Changes
- Tweaked account index page to be visually consistent with other account page layouts
- Introduced a new feature for logging both build and runtime configurations Configuration logging can now be toggled on or off using the
ENABLE_CONFIG_LOG_BUILD
andENABLE_CONFIG_LOG_RUNTIME
environment variables. - Added
@scayle/eslint-plugin-vue-composable
This plugin includes three rules@scayle/vue-composable/no-composable-after-await
,@scayle/vue-composable/no-lifecycle-after-await
,@scayle/vue-composable/no-watch-after-await
which catches common errors in composables. You can read more about the plugin here. - The improved user experience of the time box element within the Promotion Banner. Adds a clear understanding of the time left for the promotion to end by providing indicators of the time unit in the time box element for countdowns. The format of the time box element is changed to be more user-friendly with
(D : H : M)
format, or(H : M : S)
format if the promotion lasts less than24H
.
Patch Changes
- Modified paddings of PromotionHurryToSaveBanners to have visual consistency with PromotionItemContent
- Fixed a German translation issue for "save_your_free_gift"
- Fixed promotion automatic discount price on PDP
- Removed full capitalization of PromotionHurryToSaveBanner label
- Handle possible
undefined
results fromuseRpc
calls - Add store address, phone, and open status to the map marker card
- Fixed StoreLocator map covering navigation flyout
- Fixed a z-index issue with the ToastContainer so that notifications are not partially displayed underneath the Promotion Banner
- Adds missing Promotion Banner Link to Promotion Category on mobile view
- Removed dummy non-functional shipment detail link from OrderStatusBar
- An error has been fixed where an attempt was made to access the "document" object during server-side rendering, resulting in an inaccessible Order Success Page (OSP).
- Added translatable string 'pdp.no_product_information_provided' for ProductDescription and ProductCompositionAndCare components instead of static string
π‘ Dependency Updates
ποΈ devDependencies
- Added
@scayle/eslint-plugin-vue-composable@0.1.1
- Updated to
@crowdin/cli@3.19.2"
- Updated to
@nuxt/test-utils@3.12.0
- Updated to
@nuxtjs/i18n@8.3.0
- Updated to
@scayle/eslint-config-storefront@3.2.7
- Updated to
@types/node@20.12.7
- Updated to
@typescript-eslint/eslint-plugin@7.7.0
- Updated to
@typescript-eslint/parser@7.7.0
- Updated to
@upstash/redis@1.29.0
- Updated to
@vitest/coverage-v8@1.5.0
- Updated to
autoprefixer@10.4.19
- Updated to
eslint-plugin-tailwindcss@3.15.1
- Updated to
nuxt@3.11.1
- Updated to
ofetch@1.3.4
- Updated to
postcss-custom-properties@13.3.7
- Updated to
postcss-import@16.1.0
- Updated to
postcss@8.4.38
- Updated to
prettier-plugin-tailwindcss@0.5.13
- Updated to
tailwindcss@3.4.3
- Updated to
vitest@1.5.0
- Updated to
vue-tsc@2.0.13
π dependencies
- Added
@contentful/rich-text-html-renderer@16.3.5
- Added
@storyblok/vue@8.0.7
- Added
axios@1.6.8
- Added
cf-content-types-generator@2.15.0
- Added
consola@3.2.3
- Added
contentful-export@7.19.144
- Added
contentful@10.8.7
- Added
globby@14.0.1
- Removed
prettier-plugin-tailwindcss@0.5.13
- Updated to
@scayle/omnichannel-nuxt@2.1.4
- Updated to
@scayle/storefront-nuxt@7.66.0
- Updated to
@tailwindcss/typography@0.5.12
- Updated to
@types/google.maps@3.55.7
- Updated to
nanoid@5.0.7
- Updated to
nuxi@3.11.1
- Updated to
storyblok-js-client@6.7.2
- Updated to
ufo@1.5.3
1.0.0-rc.08
This release focuses on stabilization and modularization, to improve the technical foundation and developer experience.
π₯ Highlights
β¨ Update to Nuxt 3.10.3 and Vue 3.4.21
Storefront Boilerplate now runs on both the latest Nuxt v3.10.3
and Vue v3.4.21
and benefits from a multitude of improvements. To get more details about all the changes see the Official Nuxt 3.10 Announcement Blog and the Official Vue 3.4.21 Changelogs.
π SCAYLE Omnichannel Add-on for Storefront
Storefront now supports the SCAYLE Omnichannel Add-on, which includes the StoreLocator
page and StoreAvailability
within the Product Detail Page.
π Additional Tracking Improvements
The included tracking implementation has been refactored and received various improvements to increase the tracking data quality, as well as tracking data reliability.
π Major Changes
- BREAKING: Refactored default
sameSite
cookie settings fromnone
tolax
inconfig/storefront.ts
- Added
StoreLocator
page based on Google Maps andSCAYLE Omnichannel
- Added
StoreAvailability
to Product Detail Page usingSCAYLE Omnichannel
- Added
patch-packages
for managing patches to third-party packages. SeeREADME.md
or thepatches/
directory for an up-to-date listing of currently applied patches.- Patched
unstorage
so the VercelKV driver is not logged asundefined
- Patched
- Removed
auth
config incomposables/useAuthentication.ts
anduseRuntimeConfig().public.storefront.auth
field inconfig/storefront.ts
- Changed public
runtimeConfig
type toModulePublicRuntimeConfig
π Minor Changes
- Fixed caching behaviour for account area via
routeRules
innuxt.config.ts
- Fixed wishlist toggle if wishlist data is being toggled and fetched in
components/product/WishlistToggle.vue
- Refactored error message handling during local development mode to show actual error with stack trace
- Fixed product detail page and product listing page (category page) behaviour if basket data is undefined
- Fixed Storyblok CMS data handling in
pages/s/[slug].vue
- Fixed Storyblok CMS components handling in
pages/c/[slug].vue
- Renamed
categoryNotFound
tofoundCategoryByPath
inpages/[...category].vue
- Fixed error handling for non-existing category slug by throwing a
404
error and removed error handling fromlayouts/defaults.vue
- Fixed redirection from the error page to the homepage
- Converted
routeChangeTrackingObserver
to the route middleware and added delayed execution - Fixed redirection behaviour on login from checkout, as it will now redirect after login back to checkout
- Used
onNuxtReady
instead oftryOnMounted
forcomposables/tracking/watchers/useCustomerDataChangeWatcher.ts
and removed user force refresh - Fixed links on Storyblok grid tile, clickable image and banner link
modules/cms/providers/storyblok/components/BannerLink.vue
modules/cms/providers/storyblok/components/ClickableImage.vue
modules/cms/providers/storyblok/components/GridTile.vue
modules/cms/providers/storyblok/components/StoryblokLink.vue
- Fixed category behaviour by using new composable
useCategoryByPath
to source category data inpages/[...category].vue
- Fixed category behaviour by using
stripShopLocaleFromPath
and remove the computed value inpages/[...category].vue
- Refactored root categories logic and implemented app navigation trees
- Added
composables/useCategory.ts
- Added
composables/useNavigationTreeItems.ts
- Added
composables/useRootCategories.ts
- Refactored
components/layout/footer/AppFooter.vue
- Refactored
components/layout/headers/AppHeader.vue
- Refactored
components/layout/headers/HeaderSubNavigation.vue
- Refactored
components/layout/navigation/MobileSidebar.vue
- Refactored
composables/useProductList.ts
- Refactored
pages/[...category].vue
- Added
- Improved tracking behaviour
- Refactored
composables/tracking/events/useUserActionEvents.ts
- Refactored
composables/tracking/watchers/useCustomerDataChangeWatcher.ts
- Refactored
composables/useWishlistPage.ts
- Refactored
nuxt.config.ts
- Refactored
- Fixed promotion handling and hides gifts if minimum order value (
mov
) is not satisfied- Refactored
composables/useBasketItemPromotion.ts
- Refactored
composables/useProductPromotions.ts
- Refactored
composables/usePromotionProgress.ts
- Refactored
utils/promotion.ts
- Refactored
- Adjusted promotion basket gift conditional banner labels
- Refactored
components/basket/promotion/BasketGiftConditionBanner.vue
- Refactored
composables/useBasketItemPromotion.ts
- Refactored
langs/de-DE.json
- Refactored
langs/en-GB.json
- Refactored
langs/en_origin.json
- Refactored
- Adjusted promotion conditional banner on the product detail page
components/basket/promotion/BasketGiftConditionBanner.vue
components/product/promotion/ProductPromotionGiftConditionBanner.vue
composables/useProductPromotions.ts
pages/p/[slug].vue
- Reduced duplicate promotion quantity and cost logic
- Added
composables/usePromotionConditionBanner.ts
- Refactored
components/basket/promotion/BasketGiftConditionBanner.vue
- Refactored
components/product/promotion/ProductPromotionGiftConditionBanner.vue
- Refactored
langs/de-DE.json
- Refactored
langs/en-GB.json
- Refactored
langs/en_origin.json
- Added
- Extracted promotion condition banner to unified component and reuse it
- Added
components/promotion/PromotionGiftConditionBanner.vue
- Refactored
components/basket/promotion/BasketGiftConditionBanner.vue
- Refactored
components/product/promotion/ProductPromotionGiftConditionBanner.vue
- Added
- Replaced used promotion
mov
abbreviation with full keywordminOrderValue
to reduce complexity- Refactored
components/basket/promotion/BasketGiftConditionBanner.vue
- Refactored
components/product/promotion/ProductPromotionGiftConditionBanner.vue
- Refactored
composables/useBasketItemPromotion.ts
- Refactored
composables/useProductPromotions.ts
- Refactored
composables/usePromotionConditionBanner.ts
- Refactored
langs/de-DE.json
- Refactored
langs/en-GB.json
- Refactored
langs/en_origin.json
- Refactored
- Extended End-to-End testing behaviour with promotion features
- Refactored
components/product/promotion/ProductPromotionSelectionModal.vue
- Refactored
components/promotion/PromotionHurryToSaveBanners.vue
- Refactored
composables/useBasketPromotions.ts
- Refactored
composables/useProductPromotions.ts
- Refactored
composables/usePromotionGifts.ts
- Refactored
pages/p/[slug].vue
- Refactored
- Fixed and refactored Identity Provider support
- Added
components/auth/IDPCallback.vue
- Refactored
components/auth/IDPForm.vue
- Refactored
components/auth/SignInForm.vue
- Refactored
components/auth/LoginForm.vue
- Refactored
composables/useAuthentication.ts
- Refactored
config/storefront.ts
- Added
π©Ή Patch Changes
- Aligned check icon within colour chip
- Fixed missing flyout close for sub-navigation in
components/layout/headers/AppHeader.vue
- Replaced default Nuxt favicon with SCAYLE favicon in
public/favicon.ico
- Added
immediate: true
to watcher and refactoredcomposables/tracking/watchers/useCustomerDataChangeWatcher.ts
to avoid delayed execution and wrongly reported tracking data - Fixed application crash during server-side rendering while trying to access
window.localStorage
incomposables/useLastLoggedInUser.ts
- Fixed rendering issues with product price by using optional chaining
basketData.value?.items
incomponents/product/ProductPrice.vue
- Set the default TTL of the cache storage provider with Redis to
10
minutes to avoid unlimited cache keys - Replaced translation
Sicht
withAnsehen
for notification CTA - Fixed the wrong config type for
gtm.debug
innuxt.config.ts
- Fixed incorrect triggering of
content_view
tracking event during server rendering inmiddleware/routeChangeTrackingObserver.global.ts
- Hide the scrollbar on the homepage collection content
π‘ Dependency Updates
ποΈ devDependencies
- Updated to
@types/node@30.11.25
- Updated to
@upstash/redis@1.28.4
- Updated to
@vitest/coverage-v8@1.3.1
- Updated to
autoprefixer@10.4.18
- Updated to
eslint@8.57.0
- Updated to
eslint-plugin-tailwindcss@3.15.0
- Updated to
happy-dom@13.7.3
- Updated to
nuxt@3.10.3
(βFor detailed changes see Release Notes for Nuxtβ) - Updated to
postcss-custom-properties@13.3.5
- Updated to
prettier-plugin-tailwindcss@0.5.12
- Updated to
storyblok@3.27.0
- Updated to
storyblok-generate-ts@2.0.2
- Updated to
typescript@5.4.2
- Updated to
vitest@1.3.1
- Updated to
vue-tsc@2.0.6
π dependencies
- Added
@googlemaps/js-api-loader@1.16.6
- Added
@scayle/omnichannel-nuxt@2.1.3
- Added
@types/google.maps@3.55.4
- Updated to
@scayle/storefront-nuxt@7.61.3
- Updated to
@storyblok/nuxt@6.0.6
- Updated to
@vueuse/core@10.9.0
- Updated to
@vueuse/nuxt@10.9.0
- Updated to
dotenv@16.4.5
- Updated to
nanoid@5.0.6
- Updated to
storyblok-js-client@6.7.1
- Updated to
vue@3.4.21
(βFor detailed changes see Changelog for Vueβ)
1.0.0-rc.07
This release focuses on stabilization and modularization, to improve the technical foundation and developer experience.
π₯ Highlights
β¨ Update to Nuxt 3.10.1 and Vue 3.4.19
Storefront Boilerplate now runs on both the latest Nuxt v3.10.1
and Vue v3.4.19
and benefits from a multitude of improvements. To get more details about all the changes see the Official Nuxt 3.10 Announcement Blog and the Official Vue 3.4.19 Changelogs.
π§ͺ Modularization: Extracting Cypress into a dedicated sub-package
The Cypress testing solution has been extracted into a dedicated child package located at cypress/
. This decouples the dependencies from the main Storefront application. To install all relevant Cypress dependencies, execute yarn install
within the cypress/
directory. By default, the current Cypress integration does not rely anymore on the commercial Cypress Dashboard integration. Please check the dedicated Readme file located at cypress/README.md
for more details.
The following dependencies have moved from package.json
to cypress/package.json
:
cypress
cypress-real-events
eslint-plugin-cypress
𧱠Modularization: Extracting Storyblok Integration into the local module
The Storyblok integration has been extracted into a dedicated local Nuxt module storefront-cms
. This allows to combine all CMS provider relevant functionalities within a central Nuxt module and allows for simple future inclusion of additional CMS providers.
The new local Nuxt module can be found under modules/cms/
and its path has been added to nuxt.config.ts
to the modules
list.
𧲠Tracking Refactoring and Improvements
The included tracking implementation has been refactored and received various improvements to increase the tracking data quality, as well as tracking data reliability.
π Major Changes
- BREAKING: Added support for runtimeConfig with
@nuxt/image
- Added patch files for automatic dependency patching with
patch-package
. The tool will run inpostinstall
and apply any patches present in thepatches/
directory to the respective dependency. - Extended
README.md
with a section regardingPatches
to explain the details and currently applied patches
- Added patch files for automatic dependency patching with
- Added full support for an easy way of running the application through docker compose
π Minor Changes
- Refactored Wishlist
- Added
WishlistCardSlideIn
,WishlistCardImage
andWishlistCardDescription
components - Added
useWishlistPage
,useWishlistItem
anduseWishlistItemActions
composables
- Added
- Fixed an issue with Guest User being able to access the Account page, even though it did not have any content
- Fixed an issue with the Order pages not properly displaying content due to page caching issues while using path-based routing
- Fixed various UX/UI issues for the new Promotion Engine feature
- Fixed hydration issues related to viewport-dependent font-size classes on PDP in
pages/p/[slug].vue
- Fixed hydration issues related to viewport-dependent font-size classes on PLP in
components/product/card/ProductCard.vue
- Refactored various components to use new Vue v3
defineEmits
syntax for eventscomponents/layout/headers/search/MobileSearchInput.vue
components/search/CategorySuggestions.vue
components/search/ProductSuggestions.vue
components/search/SearchResultItem.vue
components/search/SearchResults.vue
components/search/SearchResultsContainer.vue
- Fixed
DefaultLink
behaviour with path-based routing incomponents/ui/links/DefaultLink.vue
- Fixed client-side validation behaviour for login and registration forms
components/auth/GuestLoginForm.vue
components/auth/LoginForm.vue
components/auth/RegisterForm.vue
components/auth/SalutationSelect.vue
- Fixed the "Register" link to open the "Registration" tab within the
SignInForm
incomponents/auth/SignInForm.vue
π©Ή Patch Changes
- Added
hasOneSizeProductVariantOnly
helper withinsizes
util - Fixed UX / UI issues for the Order details page in
pages/account/orders.vue
- Fixed UX / UI issues with login and registration forms
- Fixed window scrolling on PLP pagination in
components/ui/pagination/PaginationButton.vue
π‘ Dependency Updates
ποΈ devDependencies
- Updated to
@crowdin/cli@3.18.0
- Updated to
@nuxt/test-utils@3.11.0
- Updated to
@nuxtjs/i18n@8.1.0
- Updated to
@nuxtjs/tailwindcss@6.11.4
- Updated to
@types/node@20.11.17
- Updated to
@upstash/redis@1.28.3
- Updated to
@vitest/coverage-v8@1.2.2
- Updated to
eslint-plugin-tailwindcss@3.14.2
- Updated to
happy-dom@13.3.8
- Updated to
lint-staged@15.2.2
- Updated to
nuxt@3.10.1
- Updated to
postcss@8.4.35
- Updated to
vitest@1.2.2
π dependencies
- Updated to
@scayle/storefront-nuxt@7.57.0
- Updated to
citty@0.1.5
- Updated to
dotenv@16.4.3
- Updated to
nanoid@5.0.5
- Updated to
redis@4.6.13
- Updated to
storyblok-js-client@6.6.7
- Updated to
ufo@1.4.0
- Updated to
vue@3.4.19
1.0.0-rc.06
This release focuses on stabilization and refactoring, to improve the technical foundation and developer experience.
π Major Changes
- BREAKING: Nest public Storefront-specific
runtimeConfig
properties under thestorefront
keyuseRuntimeConfig().public.log
anduseRuntimeConfig().public.auth
should be replaced byuseRuntimeConfig().public.storefront.log
anduseRuntimeConfig().public.storefront.log
(...storefrontRuntimeConfigPublic as any),
tostorefront: storefrontRuntimeConfigPublic as any,
innuxt.config.ts
π Minor Changes
- Extracted sorting and grouping basket helpers to
utils
- Properly resolve
basketGroup
RPC with params - Removed wishlist utils and moved them to the
useWishlistActions
composable - Replaced
validation
plugin withuseValidationRules
composable - Replaced
toast
plugin withuseNotification
composable - Replaces
tracking
plugin withuseTracking
composable - Renamed
divideWithHundred
price utility todivideByHundred
- Renamed
localeFormattedDate
date utility toformatLocaleDate
- Enforced using tracking sub-composables through the
useTrackingEvents
by turning off auto-import for sub-composables - Simplified
Countdown
component logic by usinguseIntervalFn
fromvueuse
- Changed
radash
utils prefix to be underscore (_
) instead ofuse
, to avoid confusion betweenradash
utilities and Vue composables. Resulting in e.g.useSleep
to become_sleep
. - Used radash
_sort
(useSort
) instead of nativesort
to avoid side effects - Export composables as named functions
- Refactored components to use
withDefaults
and type generics to define component properties - Refactored product and navigation components to reduce complexity
- Refactored account area component to reduce complexity and improve UI experience
components/account/AccountHeader.vue
components/account/AccountWrapper.vue
components/addOns/AddOnsSelector.vue
components/order/OrderHeader.vue
components/order/OrderItemCard.vue
components/order/OrderOverviewHeader.vue
components/order/OrderStatusBar.vue
pages/account/orders.vue
pages/account/user.vue
pages/account/orders/[id].vue
- Refactored account area orders components to reduce complexity and improve UI experience
components/account/AccountWrapper.vue
components/order/OrderHistoryItem.vue
components/order/OrderItems.vue
composables/useOrders.ts
- Refactored used Tailwind classes across the Storefront Boilerplate to comply with used Tailwind version
- Tweaked Promotion Engine implementation and UI experience across the Storefront Boilerplate
- Tweaked Order Success Page (OSP) complexity and UI experience
π©Ή Patch Changes
- Refactored
slicedOrders
to be acomputed
property incomponents/account/AccountWrapper.vue
- Refactored
_sizes
to be acomputed
property incomponents/product/ProductSizePicker.vue
- Refactored
components/addOns/AddOnsSelector.vue
to usecomputed
properties instead ofref
and dedicated update functions - Refactored
basketItems
to have an empty array as fallback incomponents/basket/popover/BasketPopoverItems.vue
- Added missing state key for
footerNavigationTrees
incomponents/layout/footer/AppFooter.vue
- Simplified watcher for
searchQuery
incomponents/layout/headers/search/HederSearch.vue
- Refactored Nuxt-specific imports to import from
#app
instead ofnuxt/app
- Added
collapsed
component property tocomponents/product/detail/ProductDetailAccordionEntry.vue
- Use object for lookup of headline sizes instead of
computed
property incomponents/ui/headlines/Headline.vue
- Fixed desktop sidebar overlapping navigation in
pages/[...category].vue
- Added
time
constants inconstants/time.ts
and used it incomponents/ui/Countdown.vue
- Refactored
PromotionBanner
to be displayed ononNuxtReady
instead ofonServerPrefetch
to avoid missing interactivity during page load and hydration - Removed
runtimeConfig.public.storyblok.webhookSecret
fromnuxt.config.ts
, as it is not supported by thestoryblok-nuxt
module - Use
yn
to typecast potential build value ofruntimeConfig.public.gtm.debug
viayn(process.env.NUXT_PUBLIC_GTM_DEBUG)
innuxt.config.ts
π‘ Dependency Updates
ποΈ devDependencies
- Updated to
@crowdin/cli@3.16.1
- Updated to
@nuxt/image@1.3.0
- Updated to
@nuxt/test-utils@3.10.0
- Updated to
@nuxtjs/tailwindcss@6.11.0
- Updated to
@types/node@20.11.5
- Updated to
@upstash/redis@1.28.2
- Updated to
@vitest/coverage-v8@1.2.1
- Updated to
autoprefixer@10.4.17
- Updated to
cypress@13.6.3
- Updated to
eslint-plugin-tailwindcss@3.14.0
- Updated to
happy-dom@13.2.1
- Updated to
nuxt@3.9.3
(βFor detailed changes see Release Notes for Nuxtβ) - Updated to
utility-types@3.11.0
- Updated to
vitest@1.2.1
π dependencies
- Updated to
@scayle/storefront-nuxt@7.52.0
- Updated to
@storyblok/nuxt@6.0.4
- Updated to
dotenv@16.3.2
- Updated to
storyblok-js-client@6.6.3
- Updated to
vue@3.4.15
(βFor detailed changes see Changelog for Vueβ)
1.0.0-rc.05
π₯ Highlights
β¨ Update to Nuxt 3.9 and Vue 3.4
Storefront Boilerplate now runs on both the latest Nuxt v3.9
and Vue v3.4
and benefits from a multitude of improvements. To get more details about all the changes see the Official Nuxt 3.9 Announcement Blog and the Official Vue 3.4 Announcement Blog.
π« Introducing Promotion Engine
The Promotion Engine presents the user with various promotions that have specific conditions for receiving the discount. The Storefront Boilerplate currently supports the two types Automatic discount
and Buy X get Y
by default as promotions.
- SCAYLE Resource Center - Storefront Boilerplate / Promotion Engine
π₯ Identity Provider support for Token-based Authentication
The Storefront Boilerplate now provides support for Single-Sign-On (SSO) via multiple Identity Providers (IDP) like Okta, KeyCloak, or Google. The IDP login / SSO flow integrates with the existing Token-based Authentication and can be used in parallel with the existing SCAYLE IDP.
- SCAYLE Resource Center - Storefront Core / Authentication
π Introducing Page Caching with unified cache handling
The distributed default configuration of the Storefront Boilerplate comes with page caching enabled and relies on the global storefront-cache
storage mountpoint available via Storefront Core - Caching and configured via Storefront Core - Storage via Module Configuration.
- SCAYLE Resource Center - Storefront Boilerplate / Page Caching
π« Introducing support for Vercel Edge deployment
Storefront Boilerplate does now support deployment to Vercel Edge, besides Docker-based deployments.
- SCAYLE Resource Center - Storefront Boilerplate / Vercel Edge
π Major Changes
- Updated Cypress E2E test suite
- Introduced new utility
formatCurrency()
inuseFormatHelpers
and refactored the usage ofgetCurrency()
&toCurrency()
- Removed
nuxt-viewport
and refactored the application to useuseDefaultBreakpoints
composable based onVueUse/useBreakpoints
(βFor details see VueUse Documentation) - Reduced the usage of viewport detection logic and refactored UI to rely on responsive layouts instead
- Extract and refactor Product Filter handling on the Category and Search page
- Refactored i18n integration and usage across applications due to the update of
@nuxt/i18n
tov1.0.0
stable release
π Minor Changes
- Removed
stylelint
, related dependencies, and package script commands - Replaced
nuxt-vitest
with@nuxt/test-utils@3.9.0
as the projects have been officially merged together (For detailed changes see Changelog of @nuxt/test-utils)- Introduced
vitest-environment-nuxt@1.0.0
- Introduced
- Remove unsupported
imageBaseUrl
option key fromstorefrontRuntimeConfigPublic
inconfig/storefront.ts
- Removed usage of
process.env
fromnuxt.config
andconfig/storefront.ts
, relying on using runtime environment variables instead (_For details see Nuxt Documentation - runtimeConfig / Environment Variables) - Allowing to use HTTP during local development mode
- Extend
.env.example
with updated environment variables for locale development purposes - Added documentation reference links into
nuxt.config.ts
- Added comments with environment variable names to override runtimeConfig keys into
nuxt.config.ts
andconfig/storefront.ts
- Removed unused
nuxt/utils/cms.ts
- Introduce
useOrders
composable to unify orders handling - Changed usage of
forgotPassword(data: SendResetPasswordEmailRequest)
toforgotPassword(email: string)
inuseAuthentication
composable, refactored occurrences accordingly - Introduce
@vercel/kv
and@upstash/redis
for VercelKV support - Extend
routeRules
innuxt.config.ts
to handle Vercel page caching - Extend
routeRules
innuxt.config.ts
to support multiple cache configurations - Extend
routeRules
innuxt.config.ts
to allow disabling SSR Page Caching via environment variables during build time withDISABLE_SSR_CACHE
- Extend
cache-test.mjs
- Set
differentDomains
based on the environment variableDOMAIN_PER_LOCALE
during build time innuxt.config.ts
- Enable
debug: true
innuxt.config.ts
to be able to pinpoint potential hydration mismatches or enumerating key issues - Various types tweaks and refinements
π©Ή Patch Changes
- Fixed Storyblok integration with the handling of invalid
product_ids
instoryblok/components/ProductSlider
- Fixed Storyblok integration on Category pages without defined Storyblok CMS category slug resulting in error pages in
pages/[...category].vue
- Fixed issue with unavailable product colors on the Product Detail Page in
pages/p/[slug].vue]
- Removed
version: getStoryblokContentVersion(),
fromcomposables/useCms.ts
- Fixed caching behaviour and incorrect product list layout in
components/productList/ProductList.vue
&pages/[...category].vue]
- Fixed Order types in
components/order/OrderHeader.vue
,components/order/OrderItems.vue
,components/order/summary/PaymentSummary.vue
,pages/account/orders/[id].vue
- Fixed computed property
orderItems
inpages/account/orders/[id].vue
- Fixed ProductBadge position in
components/product/ProductBadge.vue
andcomponents/productList/ProductList.vue
- Fixed user information disappearing after reloading by disabling
autoFetch
and fetching user data explicitlyonMounted
incomponents/layout/headers/user/UserPopover.vue
- Fixed re-fetching for product list in
pages/[...category].vue]
- Fixed mobile sidebar overlapping issue in
components/layout/navigation/MobileSidebar.vue
- Fixed-size picker overlapping issue in
components/wishlist/card/WishlistCard.vue
- Fixed SlideIn overlapping issue in
components/layout/SlideIn.vue
andcomposables/useSlideIn.ts
- Fixed the Wishlist and Basket page being incorrectly cached
- Fixed incorrect routing behaviour in the following files
components/layout/headers/search/HeaderSearch.vue
components/ui/links/DefaultLink.vue
composables/useRouteHelpers.ts
middleware/authGuard.global.ts
utils/route.ts
- Various other smaller fixes and improvements
π‘ Dependency Updates
ποΈ devDependencies
- Removed
@nuxt/devtools
from devDependencies, as it's now included withnuxt@3.8
or higher - Updated to
vue@3.4.10
(βFor detailed changes see Changelog for Vueβ) - Updated to
nuxt@3.9.1
(βFor detailed changes see Release Notes for Nuxtβ) - Updated to
@crowdin/cli@3.16.0
- Updated to
@nuxt/image@1.2.0
- Updated to
@nuxt/test-utils@3.9.0
- Updated to
@nuxtjs/i18n@8.0.0
- Updated to
@nuxtjs/tailwindcss@6.10.4
- Updated to
@scayle/eslint-config-storefront@3.2.6
- Updated to
@types/color@3.0.6
- Updated to
@types/node@20.11.1
- Updated to
cypress@13.6.2
- Updated to
eslint@8.56.0
- Updated to
eslint-plugin-tailwindcss@3.13.1
happy-dom@13.0.4
lint-staged@15.2.0
- Updated to
nuxt-svgo@4.0.0.
postcss@8.4.33
postcss-custom-properties@13.3.4
postcss-html@1.6.0
postcss-import@16.0.0
prettier-plugin-tailwindcss@0.5.11
storyblok@3.26.0
storyblok-generate-ts@2.0.1
- Updated to
tailwindcss@3.4.1
- Updated to
typescript@3.4.1
- Updated to
vitest@1.1.3
and@vitest/coverage-v8@1.2.0
- Updated to
vue-tsc@1.8.27
(NOTE: This dependency update is required for propervue@3.4
type checking!)
π dependencies
- Added
nuxi@3.10.0
as it is now a standalone project within the Nuxt ecosystem - Added
vue@3.4.10
as explicit dependency to avoid potential version mismatches - Updated to
@scayle/storefront-nuxt@7.50.1
(For detailed changes see SCAYLE Resources Center - Releases) - Updated to
@storyblok/nuxt@6.0.1
- Updated to
@tailwindcss/forms@0.5.7
- Updated to
@vueuse/core@10.7.1
and@vueuse/nuxt@10.7.1
- Updated to
global@4.4.0
- Updated to
maska@2.1.11
- Updated to
nanoid@5.0.4
- Updated to
redis@4.6.12
- Updated to
ufo@1.3.2
1.0.0-rc.04
π Major Changes
- Use public npmjs.org package registry for
@scayle
packages and remove the need for a local.npmrc
file - Use public
storyblok-generate-ts
package instead of a private fork
π Minor Changes
- Updated to latest
@scayle/storefront-nuxt
package usingv7.37.2
- Improved Dockerfiles for build and deployments
π©Ή Patch Changes
- Updated various dependencies to the latest versions
1.0.0-rc.03
π Major Changes
- Introduced
vitest
for unit testing and created dummy test files for most components - Introduced page caching using Route Rules
- Replacing AuthGuard component with router middleware
- Use
defineOptions
forvue
component naming
π Minor Changes
- Introduce
localizedNavigateTo
for the programmatic routing approach - Upgrade to Vue 3.3.7
- Replaced
useUiState
with smaller composables which are:useFlyouts
,useMobileSearch
,useModal
&useSideNavigation
. - Enable auto-import for the
constants
folder - Various dependency minor dependency
π©Ή Patch Changes
- Fixed session max-age
- Handle AddToWishlist errors
- Added missing Storyblok components
- Resolved Storyblok link
- Fixed broken links when path-based shops are enabled
- Various bug fixes
1.0.0-rc.02
π Minor Changes
- Upgrade to Nuxt 3.7.4
π©Ή Patch Changes
- Reduction of hydration errors
- Improved error handling for invalid products on PDP, as well as category and service pages
- Improved handling of displaying account related UI elements for guest user
- Improved order refresh behaviour on Order Success Page
- Various smaller bug fixes
1.0.0-rc.01
π Major Changes
- Introduce Nuxt 3
- Tracking of all relevant shop interactions with GTM
- Implemented Search Engine optimizations
- Provide more CMS content integrations (Storyblok) into all relevant pages
π Minor Changes
- Improved error handling and displaying of error pages
- Improvements to redirect handling
- Improved SVG icon handling
- Improvements to mobile styling and behaviour
π©Ή Patch Changes
- Various bug fixes