@scayle/storefront-core
8.1.2
Patch Changes
- RPC Methods: When propagating the status code from a SAPI error, only include the statusCode and statusText. Previously the headers and body were included as well which could cause content decoding issues.
8.1.1
Patch Changes
- Make the
sort
parameter optional for theFetchProductsByCategoryParams
8.1.0
Minor Changes
- RPC Methods: Propagate SAPI response codes through RPC methods. This addresses an issue introduced in Storefront Core v8 where specific status codes were incorrectly reported as generic 500 errors. The following RPC methods are impacted:
getBrands
getBrandById
getCategoryByPath
getCategoryById
getProductById
getProductsByIds
getProductsByReferenceKeys
getPromotions
getCurrentPromotions
getPromotionsByIds
getSearchSuggestions
getShopConfiguration
getVariantById
getWishlist
removeItemFromWishlist
8.0.0
Major Changes
- [💥 BREAKING] The
getBadgeLabel
helper function has been removed, giving you more control over badge label display.- Note: This change doesn't affect projects using SCAYLE Storefront Boilerplate v1.0 or later.
- For applications based on older versions or using
getBadgeLabel
, you can refer to the previous implementation below:const BadgeLabel = { NEW: 'new', SOLD_OUT: 'sold_out', ONLINE_EXCLUSIVE: 'online_exclusive', SUSTAINABLE: 'sustainable', PREMIUM: 'premium', DEFAULT: '', } as const type BadgeLabelParamsKeys = | 'isNew' | 'isSoldOut' | 'isOnlineOnly' | 'isSustainable' | 'isPremium' type BadgeLabelParams = Partial<Record<BadgeLabelParamsKeys, boolean>> const getBadgeLabel = (params: BadgeLabelParams = {}): string => { if (!params) { return BadgeLabel.DEFAULT } const { isNew, isSoldOut, isOnlineOnly, isSustainable, isPremium } = params if (isNew) { return BadgeLabel.NEW } else if (isSoldOut) { return BadgeLabel.SOLD_OUT } else if (isOnlineOnly) { return BadgeLabel.ONLINE_EXCLUSIVE } else if (isSustainable) { return BadgeLabel.SUSTAINABLE } else if (isPremium) { return BadgeLabel.PREMIUM } else { return BadgeLabel.DEFAULT } }
- [💥 BREAKING] We've standardized our configuration to use
sapi
(Storefront API) throughout the codebase, replacing the deprecatedbapi
keyword. This change improves clarity and consistency by removing theinitBapi
function, replacing thebapiClient
property withsapiClient
within theRPCContext
, and updating all code references accordingly.BapiConfig
is not exported anymore and has been superseded bySapiConfig
.- NOTE: These changes impact your environment variables used for deployments. Please check your infrastructure and deployment setup and adapt accordingly!
- Previous
bapi
Configuration innuxt.config.ts
export default { // ... runtimeConfig: { // ... storefront: { // ... bapi: { host: '...', token: '...', }, // ... }, // ... }, // ... }
- Legacy Environment Variables:
NUXT_STOREFRONT_BAPI_HOST='...' NUXT_STOREFRONT_BAPI_TOKEN='...'
- Current
sapi
Configuration innuxt.config.ts
export default { // ... runtimeConfig: { // ... storefront: { // ... sapi: { host: '...', token: '...', }, // ... }, // ... }, // ... }
- New Environment Variables:
NUXT_STOREFRONT_SAPI_HOST='...' NUXT_STOREFRONT_SAPI_TOKEN='...'
- [💥 BREAKING] We've streamlined cache management by replacing the outdated
AY_CACHE_DISABLED
environment variable. Now, you can effortlessly control caching using either theNUXT_STOREFRONT_CACHE_ENABLED
environment variable or thestorefront.cache.enabled
option within yournuxt.config.ts
file, providing a more user-friendly experience. - [💥 BREAKING] This release removes the
RedisCache
provider. We now useUnstorageCache
which also supports Redis as a backing store. - [💥 BREAKING] To improve security and streamline token management, we've updated how you access user
accessToken
. Instead of directly accessing thestorefrontAccessToken
field on theUserAuthentication
interface, you'll now use the dedicatedgetAccessToken
RPC. This change ensures a more secure and controlled method for handling sensitive user data within your application.- Previous Usage of
user.authentication.storefrontAccessToken
:const { data, fetching, fetch, error, status } = useUser( 'getUser', // ... ) data.value.user.authentication.storefrontAccessToken
- Current Usage of dedicated
getAccessToken
RPC method:const { data: accessToken } = useRpc( 'getAccessToken', // ... )
- Previous Usage of
- [💥 BREAKING] We've enhanced security for basket and wishlist keys by switching the default hashing algorithm from MD5 to the more robust SHA256.
- Overriding default
hashAlgorithm
innuxt.config.ts
:export default defineNuxtConfig({ // ... runtimeConfig: { // ... storefront: { // ... appKeys: { // ... hashAlgorithm: HashAlgorithm.MD5, // HashAlgorithm.SHA256 }, // ... }, // ... }, // ... })
- Overriding default
- [💥 BREAKING] The attribute
loginShopId
is removed from theShopUser
interface as the shop now uses session cookies. - [💥 BREAKING] We're streamlining the search experience as we transition to SCAYLE Search v2, focusing on a category-centric approach. To achieve this, we're consolidating search functionality. This means we're replacing the
searchProducts
RPC method withgetSearchSuggestions
, which provides both product suggestions (triggered by product IDs) and category suggestions (triggered by category-like terms, leading to filtered category pages).- Previous Usage of
searchProducts
RPC method:const getSearchSuggestionsRpc = useRpcCall('searchProducts') data.value = await searchProducts({ term: String(searchQuery.value), ...params, })
- Current Usage of
getSearchSuggestions
RPC method:const getSearchSuggestionsRpc = useRpcCall('getSearchSuggestions') data.value = await getSearchSuggestionsRpc({ term: String(searchQuery.value), ...params, })
- Previous Usage of
- [💥 BREAKING] Improved basket updating: Adding an item to your basket with a reduced quantity will now correctly update the basket contents.
- [💥 BREAKING] The methods
getBasket
,removeItemFromBasket
,addItemsToBasket
, andaddItemToBasket
have been updated. Instead of returning the basket object directly, the basket will now be accessible as a property within the response body. Furthermore, errors occurring duringaddItemToBasket
andaddItemsToBasket
will from now on return HTTP 400. The error kind can be identified by checking theerror
property of the response.
Patch Changes
- Default
forceTokenRefresh
tofalse
when no payload is passed togetAccessToken
7.69.3
Patch Changes
Dependencies
- Updated dependency to @scayle/[email protected]
7.69.2
Patch Changes
Dependencies
- Updated dependency to @scayle/[email protected]
7.69.1
Patch Changes
- Extend
FetchProductsByCategoryParams
type to supporttrackSearchAnalyticsEvent?: boolean
- Allow passing of the
trackSearchAnalyticsEvent
parameter into thegetProductsByCategory
RPC method. NOTE: To prevent logging the search term on every page request when when paginating with thepage
parameter, thetrackSearchAnalyticsEvent
parameter is only passed on the first page (page === 1
). For more details on how to utilize this, check the SCAYLE Search Analytics section in the SCAYLE Resource Center.
7.69.0
Minor Changes
- Move test factories to separate entry point. They are now available via
@scayle/storefront-core/dist/test/factories
(or@scayle/storefront-core/test/factories
whenmoduleResolution
is set toBundler
.
Patch Changes
Dependencies
- Updated dependency to @scayle/[email protected]
7.68.0
Minor Changes
- Set
sapiClient
inRpcContext
as required to improve the updatability of RPC methods.
7.67.1
Patch Changes
Dependencies
- Updated dependency to @scayle/[email protected]
7.67.0
Minor Changes
- Expose SAPI test factories externally
7.66.7
Patch Changes
- Updated dependency
@scayle/[email protected]
to@scayle/[email protected]
7.66.6
Patch Changes
Dependencies
- Updated dependency to @scayle/[email protected]
7.66.5
Patch Changes
- Merging wishlists now retains the
variantId
,itemGroup
andcustomData
when present on the source wishlist item.
7.66.4
Patch Changes
Dependencies
- Updated dependency to @scayle/[email protected]
7.66.3
Patch Changes
- Response objects with an error status code should not be cached
7.66.2
Patch Changes
Dependencies
- Updated dependency to @scayle/[email protected]
7.66.1
Patch Changes
Dependencies
- Updated dependency to @scayle/[email protected]
7.66.0
Minor Changes
- Add
fetchNavigationTreeByName
rpc.
Patch Changes
Dependencies
- Updated dependency to @scayle/[email protected]
7.65.11
Patch Changes
- Export
NavigationItemSuggestion
type
Dependencies
- Updated dependency to @scayle/[email protected]
7.65.10
Patch Changes
Dependencies
- Updated dependency to @scayle/[email protected]
7.65.9
Patch Changes
Dependencies
- Updated dependency to @scayle/[email protected]
7.65.8
Patch Changes
- Fixed an issue with handling the deprecated MD5 hash support, e.g. used for generating a user-specific basket hash, resulting in a potential application crash
7.65.7
Patch Changes
- Delete
refreshToken
if it fails to refresh the access token
7.65.6
Patch Changes
- Resolved an issue where the
cache
value from parameters was being unintentionally overwritten by the default value forgetProductsByCategory
rpc.
7.65.5
Patch Changes
- Support passing an internal access header
- Make
getProductsCount
,getFilters
andgetProductsByCategory
RPC methods handle their parameters consistently
Dependencies
- Updated dependency to @scayle/[email protected]
7.65.4
Patch Changes
- Restored filtered list of error status codes in
oauthLogin
(400, 404)oauthRegister
(400, 409, 422) andoauthGuestLogin
(400, 409)
7.65.3
Patch Changes
- Fixed the
getFilters
RPC method not consideringincludeSellableForFree
when calculating the product count
7.65.2
Patch Changes
Dependencies
- Updated dependency to @scayle/[email protected]
7.65.1
Patch Changes
- Fixed regression in product RPC methods where the categoryId may not be resolved from the category path
7.65.0
Minor Changes
- Improved the handling of
getOrderDataByCbd
RPC to return descriptive errors in case the validation of the token fails.
In case the token can't be validated using the Checkout Secret, this is now returned and a warning on the server is logged.
If the token has expired, this is now also returned and logged on the server. - Support passing
categoryId
as an alternative to the category path ingetProductsByCategory
andgetFilters
Patch Changes
- Fixed cached fallback ttl to be used only if passed
option.ttl
is undefined
7.64.4
Patch Changes
- Replaced
radash
utils with custom native implementations
7.64.3
Patch Changes
- Add support for
orderCustomData
on the basket endpoints - Updated dependencies
- @scayle/[email protected]
7.64.2
Patch Changes
- Add more specific return type for
getFlattenedMaterialComposition
7.64.1
Patch Changes
- Updated dependencies
- @scayle/[email protected]
7.64.0
Minor Changes
- Resolve a issue that prevents filters from working as expected on the search page
Patch Changes
- Updated dependencies
- @scayle/[email protected]
7.63.1
Patch Changes
- Updated dependencies
- @scayle/[email protected]
7.63.0
Minor Changes
- Deprecate
RpcContext.storeCampaignKeyword
7.62.0
Minor Changes
- Return
ErrorResponse
from RPC when Session is missing
7.61.0
Minor Changes
- Add
sapiClient: StorefrontAPIClient
toRpcContext
DeprecatebapiClient
in favour ofsapiClient
7.60.1
Patch Changes
- Updated dependencies
- @scayle/[email protected]
7.60.0
Minor Changes
- Instead of throwing errors, RPCs will now return an
ErrorResponse
object conforming to RFC9457.
In addition to this change, existing RPCs have been reviewed and updated to return more accurate and descriptive HTTP status codes.
This change allows us to provide more informative error messages and utilize standardized HTTP status codes for better context. TheErrorResponse
object can include additional details about the error, making it easier to identify and address root causes.\
Action Required:
Code that previously made direct RPC calls (calling the function directly instead of viauseRpc
orrpcCall
) and relied ontry {} catch {}
blocks for error handling needs to be updated. Moving forward, please check the status of the RPC response directly.
Patch Changes
- Updated dependencies
- @scayle/[email protected]
7.59.2
Patch Changes
- Resolved a memory leak within the
timeout
util wheresetTimeout
might not have been garbage collected if the promise had been resolved/rejected before the timeout itself
7.59.1
Patch Changes
- Updated dependencies
- @scayle/[email protected]
7.59.0
Minor Changes
- Add
storefront:afterLogin
andstorefront:afterLogout
hooks to the respective RPC.
AddcallHook
,callHookParallel
andcallHookWith
types toRpcContext
7.58.3
Patch Changes
- Upgrades to the new Wishlist from @scayle/storefront-api
getDefaultFractionDigits
will return 2 ifmaximumFractionDigits
is not defined- Updated dependencies
- @scayle/[email protected]
7.58.2
Patch Changes
- Adds the
X-Shop-Id
header to the request when revoking an access token.
7.58.1
Patch Changes
- Fixed an issue by respecting
forceTokenRefresh
flag when calling thegetAccessToken
RPC
7.58.0
Minor Changes
- Deprecate
storefrontAccessToken
ofUserAuthentication
. UsegetAccessToken
RPC to get a valid access token instead. DeprecatedloginShopId
.loginShopId
is no longer needed, because each shop now has its own session cookie. - Add
getAccessToken
RPC to retrieve refreshed access tokens
7.57.0
Minor Changes
- Expose
properties
with option for each category RPC method payload
7.56.0
Minor Changes
- Add refresh token logic to customer API client
Patch Changes
- Ensure
user.storefrontAccessToken
is up to date when calling thegetUser
RPC
7.55.0
Minor Changes
- Allow disabling the
HashAlgorithm
by setting its value tonone
within a shop config. - Added exports for
ProductSortConfig
type and enumsAPISortOption
andAPISortOrder
.
7.54.0
Minor Changes
- Add new function
purifySensitiveValue
tosanitizationHelpers
to purify specific value. - Introduced a new parameter
showFirstAndLastChar
to bothpurifySensitiveValue
andpurifySensitiveData
.
7.53.0
Minor Changes
- Deprecate
isCmsPreview
flag inRpcContext
. This flag indicated that the current session is or has been inside of a CMS editor. With the the introduction of 'Live Preview' for the cms provider 'contentful' and 'storyblok' this flag is no longer necessary.
Patch Changes
- Removes option
considerItemGroupForUniqueness
fromaddItemsToBasket
since this is now enabled by default. - Updated dependencies
- @scayle/[email protected]
7.52.1
Patch Changes
- Fix
getWishlist
falling back to basketwithParams
instead of wishlistwithParams
7.52.0
Minor Changes
- Add
getCheckoutToken
RPC, which provides access token and checkout JWT needed by the checkout Webcomponent.
7.51.1
Patch Changes
- Update ShopConfiguration types
- Updated dependencies
- @scayle/[email protected]
7.51.0
Minor Changes
- Allow extending the
RpcContext
type by augmenting theAdditionalRpcContext
interface.
7.50.1
Patch Changes
- Add missing
BuyXGetYEffect
andAutomaticDiscountEffect
exports - Updated dependencies
- @scayle/[email protected]
7.50.0
Minor Changes
- Upgraded to
@scayle/[email protected]
and replaced@aboutyou/backbone
Noticeable changes are:- Rename
BapiClient
toStorefrontAPIClient
- Removed basic auth support from
initBapi
- Rename
7.49.4
Patch Changes
- Deprecate the
getBadgeLabel
function since this is application specific code and translations should be handled per project
7.49.3
Patch Changes
- Updated dependencies
- @aboutyou/[email protected]
7.49.2
Patch Changes
- Fixed a bug where the
addItemToWishlist
RPC method returned an empty response upon failure. - Updated dependencies
- @aboutyou/[email protected]
7.49.1
Patch Changes
- Fix accidental rename of
getFlattenedVariantCrosssellings
in the previous release
7.49.0
Minor Changes
- Add optional
state
attribute to order address for US addresses
Patch Changes
- Add better type support for
getFlattenedVariantCrosssellings
with generic type
7.48.2
Patch Changes
- Fixes an issue where the
refreshToken
was not exposed on theRPCContext
even if the user is logged in.
7.48.1
Patch Changes
- Updated
purifySensitiveData
to ensure that empty secrets are logged as empty strings, enhancing clarity in logged configurations.
7.48.0
Minor Changes
- Add support for dynamically adding query parameters to the IDP redirect callback URLs to be read back when the user returns from the IDP.
const { data: externalIDPRedirects } = await useIDP({ queryParams: { redirectTo: '/account' }, })
Please note thatcode
andstate
are not supported as these are used by the SCAYLE Authentication API.
Patch Changes
- Added merge basket and merge wishlist functionality after login with IDP
- Updated dependencies
- @aboutyou/[email protected]
7.47.0
Minor Changes
- Add
resolveSearch
andgetSearchSuggestions
RPC methods
7.46.1
Patch Changes
- Revert breaking change in
handleIDPLoginCallback
signature
7.46.0
Minor Changes
- Add new RPC method
getProductsByReferenceKeys
7.45.0
Minor Changes
- Improve typing of RPC methods by using
satisfies
instead of assertions. Thesatisfies
operator validates that an expression matches a type without changing the type of that expression. For RPC methods it can be used to enforce that a function conforms to the spec of an RPC method, without affecting the more specific inferred type of the function.
You can use this pattern in your own custom RPC methods as well.
For example:export const custom: RpcHandler<{ shop: number }> = ( context: RpcContext, ) => { return { shop: context.shopId, } }
export const custom = ( context: RpcContext, ) => { return { shop: context.shopId, } } satisfies RpcHandler<{ shop: number }>
In the first case,custom
will be typed asRpcHandler<{shop: number}>
or essentially a function takes no parameters and returns{ shop: number } | Response<{shop: number}>
. In the second case, it will be typed as a function which takes no parameters and returns{ shop: number }
which is more specific. The more specific typing may be useful if you are calling the custom RPC function as both a registered RPC method and regular function.
7.44.1
Patch Changes
- Updated dependencies
- @aboutyou/[email protected]
7.44.0
Minor Changes
- Expose the
loginWithIDP
function from theuseSession
composable. - Changes the signature of
handleIDPLoginCallback
to receive an object with the code inside instead of just the code for improved logging behavior.
7.43.0
Minor Changes
- Add
createAndPurifyHeaders
sanitization helper
7.42.1
Patch Changes
- Fix usage of the same cache key prefix for
getCategoryByPath
7.42.0
Minor Changes
- Add
getCategoryByPath
RPC method
7.41.3
Patch Changes
- Fix lost session if user refresh is called while not logged in
7.41.2
Patch Changes
- Updated dependencies
- @aboutyou/[email protected]
7.41.1
Patch Changes
- Fixes an issue where we were trying to read siblings information from a product where the data was not available
7.41.0
Minor Changes
- Add
purifySensitiveData
sanitization helper
7.40.1
Patch Changes
- Patch
accessToken
onrefreshUser
RPC Method
7.40.0
Minor Changes
- Export Campaign types from
@aboutyou/backbone
7.39.1
Patch Changes
- Persist
accessToken
touser.authentication
7.39.0
Minor Changes
- Add
sortable
option togroupFilterableValuesByKey
filter helper - Add
sortable
option togetGroupedFilterableValues
to provide the ability for custom sorting implementation for specific filtersGroups - Authentication RPC methods include status codes in error cases
7.38.1
Patch Changes
- Fix potential empty user after login
7.38.0
Minor Changes
- Allow the session of an
RpcContext
to be undefined
BREAKING: This changes the structure of theRpcContext
, so it may be a breaking change if you have written custom RPC methods.
The affected properties on theRpcContext
aresessionId
,wishlistKey
andbasketKey
and the affected methods aredestroySession
,createUserBoundSession
,updateUser
, andupdateTokens
. If you use these methods or properties in a custom RPC method, make sure that you handle the case where they might be undefined. TypeScript will also catch these cases if you havestrictNullChecks
enabled.
You can checkcontext.sessionId
(or another session-dependent property) to determine if the session is present. If one of these properties is present, all will be. Alternatively, you can callassertSession(context)
before referencing any properties in the context. If the session is not present, an error will be thrown. For any usagecontext
afterassertSession
is called, TypeScript will understand that the session properties are present.
7.37.0
Minor Changes
- Update dependency
jose
to the latest5.2.0
version
7.36.0
Minor Changes
- Support
Response
returns in RPC methods - Handle 401 from CO and delete session
7.35.0
Minor Changes
- Change
oauthForgetPassword
payload signature to acceptemail
only
7.34.1
Patch Changes
- Fix type errors
7.34.0
Minor Changes
- We added support for Identity Provider (IDP), enhancing our authentication and identity management capabilities.
7.33.0
Minor Changes
- Previously the caching time for product RPCs was one hour which could easily lead to outdated product information for a long time.
ThegetProductById
andgetProductsByIds
RPCs are now cached for 5 Minutes andgetProductsByCategory
is now cached for 15 Minutes.
7.32.0
Minor Changes
- Use new password change API when oauth is enabled
7.31.0
Minor Changes
- Update SAPI SDK to v16
Patch Changes
- Fix filter helper to not return null values
7.30.0
Minor Changes
- Allow
null
values forpromotionId
within the basket payload
7.29.0
Minor Changes
- Remove basic
gzip
compression in customunstorage
caching interface in favor of custom@scayle/unstorage-compression-driver
7.28.2
Patch Changes
fetchUser
andrefreshUser
are now proper RPC methods- Fix parsing error from authentication service
- Use a common API client for interacting with Checkout Customer API
7.28.1
Patch Changes
- Types: shop_id should be optional in updatePasswordByHash
7.28.0
Minor Changes
- Use native fetch instead of axios
7.27.0
Minor Changes
- Introduce gzip-based compression for unstorage cache interface
- Upgrade package
@aboutyou/backbone
tov15.14.3
7.26.0
Minor Changes
- Don't return oauth tokens from RPC methods
7.25.1
Patch Changes
- Cache purging should not remove unrelated keys
7.25.0
Minor Changes
- Add
PromotionEffectType
constant and type
7.24.1
Patch Changes
- Forbid saving
null
andundefined
results to the cache
7.24.0
Minor Changes
- Remove
sanitize
helper function and jsdom dependency
7.23.0
Minor Changes
- Add
runtimeConfiguration
property to theRPCContext
7.22.1
Patch Changes
- Add license file
7.22.0
Minor Changes
- Upgrade package
@aboutyou/backbone
tov15.14.1
7.21.0
Minor Changes
- Add
promotion
RPC methods and types - Add promotion data within the basket payloads
Patch Changes
- Fix product URL generation, remove additional special characters that can break routing
7.20.0
Minor Changes
- Upgrade backbone to the
v15.12.1
7.19.1
Patch Changes
- The
auth
config is optional
7.19.0
Minor Changes
- Support setting default
with
params in the module options
7.18.0
Minor Changes
- Expose error codes from BAPI for the basket rpc methods
7.17.0
Minor Changes
- Limit perPage for getBrands and getProductsByCategory to 100
7.16.0
Minor Changes
- Support expiring CBD tokens
7.15.1
Patch Changes
- Remove unnecessary dependencies
7.15.0
Minor Changes
- Support importing all dist/ files directly
7.14.3
Patch Changes
- Import fix
7.14.2
Patch Changes
- Make Redis an optional dependency
7.14.1
Patch Changes
- Remove unused body-parser dependency
7.14.0
Minor Changes
- Read OAuth settings from the RpcContext
7.13.0
Minor Changes
- Save user to session during login/register process. This will fix wrong wishlist/basket keys, in the RpcContext, after the login/registering.
- Safe user to session during login process. This will fix wrong wishlist/basket keys , in the RpcContext, after the login.
7.12.2
Patch Changes
- Replace crypto with uncrypto
7.12.1
Patch Changes
- Export BapiClient and Redirect from BAPI
7.12.0
Minor Changes
to
prop ofBreadcrumbItem
returned fromgetBreadcrumbsFromPath
now start with/
7.11.0
Minor Changes
- Move
deserializeFilters
andserializeFilters
to@scayle/storefront-core
7.10.2
Patch Changes
- encodeBase64 and decodeBase64 should be able to be run in browser environments
7.10.1
Patch Changes
- Get accessToken from getUserRequest on the client side. Merge basket and wishlist after login/register to logged-in user.
7.10.0
Minor Changes
- Add the possibility of using Token based authentication.
7.9.0
Minor Changes
- Add unstorage cache provider
Patch Changes
- Fix crypto-js imports needed for basked/wishlist key generation.
7.8.0
Minor Changes
- provide exports of package as ESM and CJS format
- Migrate helpers to core package
Patch Changes
- Add
initBapi
function to initialize a BapiClient
7.7.1
Patch Changes
- orFiltersOperator should be optional in FetchProductsByCategoryParams and FetchProductsCountParams
7.7.0
Minor Changes
- Update @aboutyou/backbone package and add support for
onFiltersOperator
BAPI parameter
7.6.1
Patch Changes
- Move keys utils to the core package
7.6.0
Minor Changes
- Set the domain property in the rpc context
7.5.0
Minor Changes
refresh()
ofuseUser()
anduseUserFacet()
will now clear the session and user state if the checkout returnsHTTP 403 Forbidden
.- Breaking
destroySession
is now async.
7.4.0
Minor Changes
- Add option
includeSellableForFree
touseFacet
anduseProducts
to include free products.
7.3.1
Patch Changes
- Move RpcMethodsStorefront type to the nuxt2 package so it's accessible to shops
7.3.0
Minor Changes
- Add rpcMethods
getBrand
andgetBrands
& corresponding composables, to make bapi-sdk brand endpoints available.
7.2.1
Patch Changes
- Added ability to add basket groups by accepting
itemGroup
in the payload for the rpc methodaddItemsToBasket
7.2.0
Minor Changes
- Replaced
enums
with the companion object pattern approach. - Replaced
HttpStatusMessage
number values with the actual message
7.1.0
Minor Changes
- Fix
fetchAllFiltersForCategory
caching issue by returning the cached value. - Fix
fetchAllFiltersForCategory
caching issue by returning the cached value.
7.0.0
Major Changes
- Changes to basket and wishlist functions
- Going forward, the only way to specify
with
andpricePromotionKey
for the basket is by passing them touseBasketWithParams()
. They can no longer be overridden when callingbasket.addItem()
,basket.removeItem()
orbasket.fetch()
. - The only way to specify
pricePromotionKey
for the wishlist is by to passing them touseWishlistWithParams()
. They can no longer be overridden when callingwishlist.addItem()
,wishlist.removeItem()
,wishlist.toggleItem()
orwishlist.fetch()
.
- Going forward, the only way to specify
- Removed deprecated functions and values
- Removal:
user.fetch()
- user is fetched automatically. If you want to refresh the user, use
user.refresh()
- user is fetched automatically. If you want to refresh the user, use
- Removal:
user.forceRefreshUser()
- instead use
user.refresh()
- instead use
- Removal:
useUser()
- instead use
useUserWithParams()
- instead use
- Removal:
useBasket()
- instead use
useBasketWithParams()
- instead use
- Removal:
useWishlist()
- instead use
useWishlistWithParams()
- instead use
- Removal:
ShopUser.emailHash
- instead hash the email address on shop side
- Removal:
wishlist.contains()
- instead use
wishlist.findItem()
- instead use
- Removal:
applyFilter()
- instead use
applyFilters()
- instead use
- Removal:
Log.attachToNuxtContext()
- instead use
inject('log', log)
in your plugin
- instead use
- Removal:
Log.attachToWindow()
- instead use
Log.default = log
- instead use
- Removal:
sortingValues
- instead use
getSortingValues()
- instead use
- Removal:
- Changed NPM package names
- Breaking: Change package scope and name of
@aboutyou/scayle-sfc-nuxt
to@scayle/storefront-nuxt2
- Breaking: Change package scope and name of
@aboutyou/sfc-nuxt3
to@scayle/storefront-nuxt
- Breaking: Change package scope and name of
@aboutyou/scayle-sfc-lib
to@scayle/storefront-core
- Breaking: Change package scope and name of
@aboutyou/eslint-config-sfc
to@scayle/eslint-config-storefront
- Breaking: Change package scope and name of
@aboutyou/prettier-config-sfc
to@scayle/prettier-config-storefront
NOTE: Due to the changes of the NPM package scope from@aboutyou
to@scayle
, it is required to change the consuming projects local.npmrc
file as follows:- Before:
Copy@aboutyou:registry=https://gitlab.com/api/v4/packages/npm/
- After:
Copy@aboutyou:registry=https://gitlab.com/api/v4/projects/29746107/packages/npm/ @scayle:registry=https://gitlab.com/api/v4/projects/29746107/packages/npm/
- Breaking: Change package scope and name of
- Removal:
isEmpty
,isEqual
,pluck
andcopyTo
object helpers are removed. NOTE: We recommend to use native utilities orradash
within your project! - Removal: Remove the deprecated pino-based logger. NOTE: For more information, please check out the "Logging"-section in
README.md
. - Changes to hash utils:
hmac
,verifyToken
,buildSignature
functions are now async- hash functions are no longer exported from
utils/index
. They must be imported fromutils/hash
sha256
function added
- Breaking: Minimum
node
version raised to18.15.0
sha256
is used for default cache keys instead ofmd5
- Breaking: Remove the BasicAuth module
- Support sha256 for basket and wishlist keys
TheappKeys.isHashed
config option has been renamed toappKeys.hashAlgorithm
. Instead of a boolean, there are now three options.'sha256'
Use thesha256
function for hashing basket and wishlist keys'md5'
Use themd5
function for hashing basket and wishlist keys (Equivalent toisHashed: true
in v6)null
Do not hash basket and wishlist keys (Equivalent toisHashed: false
in v6)
- Redis optimizations Reduce memory usage by replacing
with parameters
from fetching all attributes and fetching minimum attributes required to run the demo shop. NOTE: As this is a breaking change, to upgrade you will need to pass thewith parameters
required by the shop to function correctly!
Minor Changes
- Support optionally dropping MD5 and the crypto-js dependency When
process.env.SFC_OMIT_MD5
istrue
, the md5 function will be replaced with an empty stub. If you do not use the MD5 hash at all this can be used to reduce bundle sizes.
Innuxt.config.js
addenv: { SFC_OMIT_MD5: true }
or if you want to control it from a.env
env: { SFC_OMIT_MD5: process.env.SFC_OMIT_MD5 }
- Improvement: Overall code enhancement within
storefront-core
package in favor of reducing cognitive complexity and increasing maintainability- Introduce
autobind
helper - Refactor
cached
file
- Introduce
Patch Changes
- Bugfix: Resolve incompatibility with Webpack 4-based build processes
7.0.0-alpha.3
Major Changes
- Changes to hash utils:
hmac
,verifyToken
,buildSignature
functions are now async- hash functions are no longer exported from
utils/index
. They must be imported fromutils/hash
sha256
function added
sha256
is used for default cache keys instead ofmd5
- Support sha256 for basket and wishlist keys
TheappKeys.isHashed
config option has been renamed toappKeys.hashAlgorithm
. Instead of a boolean, there are now three options.'sha256'
Use thesha256
function for hashing basket and wishlist keys'md5'
Use themd5
function for hashing basket and wishlist keys (Equivalent toisHashed: true
in v6)null
Do not hash basket and wishlist keys (Equivalent toisHashed: false
in v6)
Minor Changes
- Support optionally dropping MD5 and the crypto-js dependency When
process.env.SFC_OMIT_MD5
istrue
, the md5 function will be replaced with an empty stub. If you do not use the MD5 hash at all this can be used to reduce bundle sizes.
Innuxt.config.js
add
Copyenv: { SFC_OMIT_MD5: true }
or if you want to control it from a.env
Copyenv: { SFC_OMIT_MD5: process.env.SFC_OMIT_MD5 }
7.0.0-alpha.2
Patch Changes
- Bugfix: Resolve incompatibility with Webpack 4-based build processes
7.0.0-alpha.1
Major Changes
- Redis optimizations Reduce memory usage by replacing
with parameters
fetching all attributes and fetching minimum attributes required to run the demo shop. NOTE: As this is a breaking change, to upgrade you will need to pass thewith parameters
required by the shop to function correctly!
Minor Changes
- Improvement: Overall code enhancement within
storefront-core
package in favor of reducing cognitive complexity and increasing maintainability- Introduce
autobind
helper - Refactor
cached
file
- Introduce
7.0.0-alpha.0
Major Changes
- Changes to basket and wishlist functions
Going forward, the only way to specifywith
andpricePromotionKey
for the basket is pass them touseBasketWithParams()
. They can no longer be overridden when callingbasket.addItem()
,basket.removeItem()
andbasket.fetch()
.
The only way to specifypricePromotionKey
for the wishlist is to pass them touseWishlistWithParams()
. They can no longer be overridden when callingwishlist.addItem()
,wishlist.removeItem()
,wishlist.toggleItem()
andwishlist.fetch()
. - Removed deprecated functions and values
user.fetch()
User is fetched automatically. If you want to refresh the user, useuser.refresh()
user.forceRefreshUser()
Useuser.refresh()
instead.useUser()
UseuseUserWithParams()
instead.useBasket()
UseuseBasketWithParams()
instead.useWishlist()
UseuseWishlistWithParams()
instead.ShopUser.emailHash
Hash the email on shop side instead.wishlist.contains()
Usewishlist.findItem()
instead.applyFilter()
UseapplyFilters()
instead.Log.attachToNuxtContext()
Useinject('log', log)
in your plugin instead.Log.attachToWindow()
UseLog.default = log
instead.sortingValues
UsegetSortingValues()
instead.
- Changed NPM package names
- Breaking: Change package scope and name of
@aboutyou/scayle-sfc-nuxt
to@scayle/storefront-nuxt2
- Breaking: Change package scope and name of
@aboutyou/sfc-nuxt3
to@scayle/storefront-nuxt
- Breaking: Change package scope and name of
@aboutyou/scayle-sfc-lib
to `@scayle/storefront-core - Breaking: Change package scope and name of
@aboutyou/eslint-config-sfc
to@scayle/eslint-config-storefront
- Breaking: Change package scope and name of
@aboutyou/prettier-config-sfc
to@scayle/prettier-config-storefront
Due to the changes of the NPM package scope from@aboutyou
to@scayle
, it is required to change the consuming projects local.npmrc
file as follows:- Before:
@aboutyou:registry=https://gitlab.com/api/v4/packages/npm/
- After:
@scayle:registry=https://gitlab.com/api/v4/packages/npm/
- Breaking: Change package scope and name of
isEmpty
,isEqual
,pluck
andcopyTo
object helpers are removed. (Recommendation: It would be good to use native utils orradash
within the project locally)- Remove the deprecated pino-based logger. For more information, please check out the "Logging"-section in README.md.
- Minimum node version is 18.15.0
- Remove the basic auth module
6.8.0
Minor Changes
- Adds the ability to ignore shop locale if passed to the breadcrumb helper. The shop needs to provide its locale using
$currentShop.locale
6.7.1
Patch Changes
- Bugfix: move
CACHE_TIMEOUT
to a dedicated file for reexport, instead ofcache/providers/redis.ts
, to avoid buildtime errors in the nuxt2 package.
6.7.0
Minor Changes
- Deps: updated
@aboutyou/backbone
tov15.3.0
6.6.16
Patch Changes
- Cache: reduce redis cache timeout from 5000ms to 500ms
6.6.15
Patch Changes
- Cache: introduce shared Redis
CACHE_TIMEOUT
constant across shared packages - Cache: Increase Redis
get
timeout from300ms
to5000ms
to account for longer Redis responses