Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add recommendations block with ACDL #11

Merged
merged 25 commits into from
Mar 15, 2024
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
25 commits
Select commit Hold shift + click to select a range
bc902f8
Add recommendations block with ACDL2
herzog31 Nov 7, 2023
9f0553b
Fix array issue for product views
herzog31 Nov 7, 2023
c0223e8
Fix enrichment position
herzog31 Nov 7, 2023
1cf384c
Update recommendations context
herzog31 Nov 9, 2023
abd9fdc
Add schema validation for events
herzog31 Nov 9, 2023
b5f507a
Merge branch 'main' of github.com:hlxsites/aem-boilerplate-commerce i…
herzog31 Nov 20, 2023
769aa8c
Merge branch 'main' of github.com:hlxsites/aem-boilerplate-commerce i…
herzog31 Dec 6, 2023
c101adc
Merge branch 'main' of github.com:hlxsites/aem-boilerplate-commerce i…
herzog31 Jan 8, 2024
ae07731
Fix ACDL2 and product view history bugs
herzog31 Jan 8, 2024
774720f
Merge branch 'main' of github.com:hlxsites/aem-boilerplate-commerce i…
herzog31 Jan 8, 2024
f059e56
Fix CLS
herzog31 Jan 8, 2024
a2ca757
Merge branch 'main' of github.com:hlxsites/aem-boilerplate-commerce i…
herzog31 Jan 15, 2024
c6f2fb1
Use base design system
herzog31 Jan 15, 2024
671c4b4
Merge branch 'main' of github.com:hlxsites/aem-boilerplate-commerce i…
herzog31 Mar 5, 2024
a52c814
Update styles
herzog31 Mar 5, 2024
ec1f23b
Replace ACDL2 with mainline ACDL
herzog31 Mar 6, 2024
ac5c938
Add viewHistory and cartSkus
herzog31 Mar 6, 2024
d0554f4
Add storefront events to recommendations block
herzog31 Mar 7, 2024
9b97591
Optimize recommendations context
herzog31 Mar 7, 2024
5b50032
Merge branch 'main' of github.com:hlxsites/aem-boilerplate-commerce i…
herzog31 Mar 7, 2024
b47e843
Add PLP widget version that uses ACDL
herzog31 Mar 11, 2024
826d2ca
Add categoryContext to PLP
herzog31 Mar 14, 2024
3c33ebe
Remove optional category url path from PLP
herzog31 Mar 14, 2024
793494f
Add categoryIds filter
herzog31 Mar 14, 2024
3686f01
Update autocomplete widget
herzog31 Mar 15, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
3 changes: 2 additions & 1 deletion .eslintignore
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
helix-importer-ui
scripts/preact.js
scripts/htm.js
scripts/acdl
tools/picker
scripts/widgets
scripts/widgets
4 changes: 2 additions & 2 deletions blocks/header/searchbar.js
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,7 @@ import { getConfigValue } from '../../scripts/configs.js';

const storeDetails = {
environmentId: await getConfigValue('commerce-environment-id'),
environmentType: (await getConfigValue('commerce-environment-id')).includes('sandbox') ? 'testing' : '',
environmentType: (await getConfigValue('commerce-endpoint')).includes('sandbox') ? 'testing' : '',
apiKey: await getConfigValue('commerce-x-api-key'),
websiteCode: await getConfigValue('commerce-website-code'),
storeCode: await getConfigValue('commerce-store-code'),
Expand All @@ -27,7 +27,7 @@ import { getConfigValue } from '../../scripts/configs.js';
context: {
customerGroup: await getConfigValue('commerce-customer-group'),
},
route: ({ sku }) => `/products/missing-url-key/${sku}`, // TODO: We need urlKey as parameter as well!
route: ({ sku, urlKey }) => `/products/${urlKey}/${sku}`,
searchRoute: {
route: '/search',
query: 'q',
Expand Down
12 changes: 10 additions & 2 deletions blocks/product-details/product-details.js
Original file line number Diff line number Diff line change
Expand Up @@ -113,7 +113,7 @@
};

onAddToWishlist = async () => {
console.debug('onAddToWishlist', this.state.product.sku);

Check warning on line 116 in blocks/product-details/product-details.js

View workflow job for this annotation

GitHub Actions / build

Unexpected console statement
};

onQuantityChanged = (quantity) => {
Expand Down Expand Up @@ -148,8 +148,16 @@
if (!loading && product) {
setJsonLdProduct(product);
document.title = product.name;
// TODO: productId not exposed by catalog service as number
window.adobeDataLayer.push({ productContext: { productId: 0, ...product } }, { event: 'product-page-view' });
window.adobeDataLayer.push((dl) => {
dl.push({
productContext: {
productId: parseInt(product.externalId, 10) || 0,
...product,
},
});
// TODO: Remove eventInfo once collector is updated
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

If you already know what "updated" means, cool, but maybe you could add a specific version or ticket here.

dl.push({ event: 'product-page-view', eventInfo: { ...dl.getState() } });
});
}
}

Expand Down
5 changes: 4 additions & 1 deletion blocks/product-list-page-custom/ProductList.js
Original file line number Diff line number Diff line change
Expand Up @@ -47,7 +47,10 @@ class ProductCard extends Component {
}

onProductClick(product) {
window.adobeDataLayer.push({ event: 'search-product-click', eventInfo: { searchUnitId: 'searchUnitId', sku: product.sku } });
window.adobeDataLayer.push((dl) => {
// TODO: Remove eventInfo once collector is updated
dl.push({ event: 'search-product-click', eventInfo: { ...dl.getState(), searchUnitId: 'searchUnitId', sku: product.sku } });
});
}

render({ product, loading, index }) {
Expand Down
30 changes: 17 additions & 13 deletions blocks/product-list-page-custom/product-list-page-custom.js
Original file line number Diff line number Diff line change
Expand Up @@ -146,7 +146,9 @@
} else {
searchInputContext.units[index] = unit;
}
dl.push({ searchInputContext }, { event: 'search-request-sent', eventInfo: { searchUnitId } });
dl.push({ searchInputContext });
// TODO: Remove eventInfo once collector is updated
dl.push({ event: 'search-request-sent', eventInfo: { ...dl.getState(), searchUnitId } });
});

const response = await performCatalogServiceQuery(productSearchQuery(state.type === 'category'), variables);
Expand All @@ -164,7 +166,7 @@
facets: response.productSearch.facets.filter((facet) => facet.attribute !== 'categories'),
};
} catch (e) {
console.error('Error loading products', e);

Check warning on line 169 in blocks/product-list-page-custom/product-list-page-custom.js

View workflow job for this annotation

GitHub Actions / build

Unexpected console statement
return {
pages: 1,
products: {
Expand Down Expand Up @@ -389,22 +391,24 @@
} else {
searchResultsContext.units[index] = searchResultUnit;
}
dl.push({ searchResultsContext }, { event: 'search-response-received', eventInfo: { searchUnitId } });
dl.push({ searchResultsContext });
// TODO: Remove eventInfo once collector is updated
dl.push({ event: 'search-response-received', eventInfo: { ...dl.getState(), searchUnitId } });
if (this.props.type === 'search') {
dl.push({ event: 'search-results-view', eventInfo: { searchUnitId } });
// TODO: Remove eventInfo once collector is updated
dl.push({ event: 'search-results-view', eventInfo: { ...dl.getState(), searchUnitId } });
} else {
dl.push(
{ event: 'category-results-view', eventInfo: { searchUnitId } },
{
categoryContext: {
name: this.state.category.name,
urlKey: this.state.category.urlKey,
urlPath: this.state.category.urlPath,
},
dl.push({
categoryContext: {
name: this.state.category.name,
urlKey: this.state.category.urlKey,
urlPath: this.state.category.urlPath,
},
);
});
// TODO: Remove eventInfo once collector is updated
dl.push({ event: 'category-results-view', eventInfo: { ...dl.getState(), searchUnitId } });
}
dl.push({ event: 'page-view' });
dl.push({ event: 'page-view', eventInfo: { ...dl.getState() } });
});
}
};
Expand Down
4 changes: 2 additions & 2 deletions blocks/product-list-page/product-list-page.js
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@ import { loadScript, readBlockConfig } from '../../scripts/aem.js';
import { getConfigValue } from '../../scripts/configs.js';

export default async function decorate(block) {
const { urlpath, category, type } = readBlockConfig(block);
const { category, type } = readBlockConfig(block);
block.textContent = '';

const widgetProd = '/scripts/widgets/search.js';
Expand Down Expand Up @@ -44,7 +44,7 @@ export default async function decorate(block) {

if (type !== 'search') {
storeDetails.config.categoryName = document.querySelector('.default-content-wrapper > h1')?.innerText;
storeDetails.config.currentCategoryUrlPath = urlpath;
storeDetails.config.currentCategoryId = category;

// Enable enrichment
block.dataset.category = category;
Expand Down
80 changes: 80 additions & 0 deletions blocks/product-recommendations/product-recommendations.css
Original file line number Diff line number Diff line change
@@ -0,0 +1,80 @@
main .section>div.product-recommendations-wrapper {
max-width: 100%;
padding: 0;
text-align: left;
margin: 0 0 5rem;
}

.product-recommendations {
overflow: hidden;
min-height: 512px;
}

.product-recommendations .scrollable {
overflow-x: scroll;
scroll-snap-type: x mandatory;
padding-bottom: 1rem;
}

.product-recommendations .product-grid {
display: inline-flex;
flex-wrap: nowrap;
gap: 2rem;
margin: 0;
}

.product-recommendations .product-grid-item img {
width: 100%;
}

.product-recommendations .product-grid .product-grid-item a {
text-decoration: none;
}

.product-recommendations .product-grid .product-grid-item a:hover,
.product-recommendations .product-grid .product-grid-item a:focus {
text-decoration: underline;
}

.product-recommendations .product-grid .product-grid-item span {
overflow: hidden;
box-sizing: border-box;
margin: 0;
padding: .5rem 1rem 0 0;
display: inline-block;
}

.product-recommendations .product-grid picture {
background: none;
display: block;
width: 300px;
aspect-ratio: 1 / 1.25;
}

.product-recommendations .product-grid img {
display: inline-block;
vertical-align: middle;
width: 100%;
object-fit: contain;
background: none;
}

.product-recommendations .product-grid .placeholder {
background-color: var(--color-neutral-500);
scroll-snap-align: start;
}

.product-recommendations .product-grid .placeholder img {
display: none;
}

.product-recommendations .product-grid-item {
margin: 0;
scroll-snap-align: start;
}

@media (width >= 900px) {
.product-recommendations {
min-height: 534px;
}
}
Loading
Loading