From 825d86bb50f48f9a21d740d474c0dddee858dffb Mon Sep 17 00:00:00 2001 From: FIN-IT_AndriFP Date: Mon, 1 Dec 2025 11:31:30 +0700 Subject: (andri) show upsells product from magento in similarbottom product --- src-migrate/services/product.ts | 38 ++++++++++++++++++++++++++++++++++++++ 1 file changed, 38 insertions(+) (limited to 'src-migrate/services') diff --git a/src-migrate/services/product.ts b/src-migrate/services/product.ts index 77b645f0..f77fc3ec 100644 --- a/src-migrate/services/product.ts +++ b/src-migrate/services/product.ts @@ -64,3 +64,41 @@ export const getProductCategoryBreadcrumb = async ( ): Promise => { return await odooApi('GET', `/api/v1/product/${id}/category-breadcrumb`); }; + +// ================================================================= +// TAMBAHAN BARU: SERVICE FETCH BY LIST ID (UNTUK UPSELL/RELATED) +// ================================================================= + +export interface GetProductsByIdsProps { + ids: number[]; +} + +export const getProductsByIds = async ({ + ids, +}: GetProductsByIdsProps): Promise => { + // Jika array ID kosong, kembalikan object kosong agar tidak error + if (!ids || ids.length === 0) { + return { + products: [], + num_found: 0, + num_found_exact: true, + start: 0 + }; + } + + // Buat query Solr format: product_id_i:(224102 OR 88019 OR ...) + const idQuery = ids.join(' OR '); + + const query = [ + `q=*`, // Query wildcard (ambil semua) + `fq=product_id_i:(${idQuery})`, // TAPI difilter hanya ID yang ada di list upsell + 'rows=20', + `source=upsell`, + ]; + + const url = `${SELF_HOST}/api/shop/search?${query.join('&')}`; + + return await fetch(url) + .then((res) => res.json()) + .then((res) => snakeCase(res.response)); +}; \ No newline at end of file -- cgit v1.2.3