{"categories":[{"id":"267","name":"Inbouwdeel","required":true,"multiple":true,"expanded":true,"single_product":true,"products":[{"product_id":"59753","sku":"A00000000147453","name":"Grohe Eurostyle inbouwdeel voor 2-gats wastafelkraan","image":"https:\/\/media.saniweb.nl\/cdn-cgi\/image\/fit=pad,format=auto,width=240,height=240\/media\/catalog\/product\/2\/3\/23571000_P11_1.jpg","url":"https:\/\/www.saniweb.be\/grohe-eurostyle-inbouwdeel-voor-2-gats-wastafelkraan-23571000.html","price_final":216.68,"price_html":"<div class=\"price-box price-final_price\" data-role=\"priceBox\" data-product-id=\"59753\" data-price-box=\"product-id-59753\">    <span class=\"w-full advice-price block shrink-0 text-xs text-brand-gray-dark -mb-2 \">\n        Adviesprijs        <span\n    x-data x-id=\"['old\\u002Dprice\\u002D59753']\"    class=\"price-container line-through&#x20;currency-sign&#x20;tax&#x20;weee\"\n        >\n        <span  :id=\"$id('old\\u002Dprice\\u002D59753')\"                data-price-amount=\"404\"\n        data-price-type=\"originalPrice\"\n        class=\"price-wrapper \"\n    >404,00<\/span>\n        <\/span>\n    <\/span>\n<div class=\"current-price final flex relative\">\n    <span class=\"price-label sr-only\">Prijs<\/span>\n    <span\n    x-data x-id=\"['product\\u002Dprice\\u002D59753']\"    class=\"price-container font-extrabold&#x20;text-3xl&#x20;lg&#x3A;text-3.5xl&#x20;currency-sign&#x20;tax&#x20;weee\"\n        >\n        <span  :id=\"$id('product\\u002Dprice\\u002D59753')\"                data-price-amount=\"216.68\"\n        data-price-type=\"finalPrice\"\n        class=\"price-wrapper \"\n    >216,68<\/span>\n        <\/span>\n<\/div>\n<div class=\"hidden discount-price-label-wrapper ml-auto\">\n            <div class=\"discount-price discount-price-basic relative flex items-center ml-3.5 font-bold leading-3 bg-brand-blue px-2.5 text-white text-xs lg:text-sm rounded-r\n             \"\n         >\n            <span class=\"uppercase\">Je bespaart&nbsp;<\/span>\n            <span>46%<\/span>\n        <\/div>\n    <\/div>\n<\/div>","review_html":"    <a class=\"rating-summary cursor-pointer flex items-center\"\n       href=\"#pdp-reviews\"\n        >\n                    <span class=\"hidden\" itemprop=\"ratingValue\">4.8<\/span>\n            <span class=\"hidden\" itemprop=\"reviewCount\">30<\/span>\n                                                        <svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" class=\"fill-current w-6 h-6\" viewBox=\"3 0 20 20\"\n                     style=\"color: #FFCB01\"\n                     fill=\"currentColor\">\n                    <path\n                        d=\"M9.049 2.927c.3-.921 1.603-.921 1.902 0l1.07 3.292a1 1 0 00.95.69h3.462c.969 0 1.371\n                        1.24.588 1.81l-2.8 2.034a1 1 0 00-.364 1.118l1.07 3.292c.3.921-.755 1.688-1.54\n                        1.118l-2.8-2.034a1 1 0 00-1.175 0l-2.8 2.034c-.784.57-1.838-.197-1.539-1.118l1.07-3.292a1\n                        1 0 00-.364-1.118L2.98 8.72c-.783-.57-.38-1.81.588-1.81h3.461a1 1 0 00.951-.69l1.07-3.292z\"\/>\n                <\/svg>\n                                            <svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" class=\"fill-current w-6 h-6\" viewBox=\"3 0 20 20\"\n                     style=\"color: #FFCB01\"\n                     fill=\"currentColor\">\n                    <path\n                        d=\"M9.049 2.927c.3-.921 1.603-.921 1.902 0l1.07 3.292a1 1 0 00.95.69h3.462c.969 0 1.371\n                        1.24.588 1.81l-2.8 2.034a1 1 0 00-.364 1.118l1.07 3.292c.3.921-.755 1.688-1.54\n                        1.118l-2.8-2.034a1 1 0 00-1.175 0l-2.8 2.034c-.784.57-1.838-.197-1.539-1.118l1.07-3.292a1\n                        1 0 00-.364-1.118L2.98 8.72c-.783-.57-.38-1.81.588-1.81h3.461a1 1 0 00.951-.69l1.07-3.292z\"\/>\n                <\/svg>\n                                            <svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" class=\"fill-current w-6 h-6\" viewBox=\"3 0 20 20\"\n                     style=\"color: #FFCB01\"\n                     fill=\"currentColor\">\n                    <path\n                        d=\"M9.049 2.927c.3-.921 1.603-.921 1.902 0l1.07 3.292a1 1 0 00.95.69h3.462c.969 0 1.371\n                        1.24.588 1.81l-2.8 2.034a1 1 0 00-.364 1.118l1.07 3.292c.3.921-.755 1.688-1.54\n                        1.118l-2.8-2.034a1 1 0 00-1.175 0l-2.8 2.034c-.784.57-1.838-.197-1.539-1.118l1.07-3.292a1\n                        1 0 00-.364-1.118L2.98 8.72c-.783-.57-.38-1.81.588-1.81h3.461a1 1 0 00.951-.69l1.07-3.292z\"\/>\n                <\/svg>\n                                            <svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" class=\"fill-current w-6 h-6\" viewBox=\"3 0 20 20\"\n                     style=\"color: #FFCB01\"\n                     fill=\"currentColor\">\n                    <path\n                        d=\"M9.049 2.927c.3-.921 1.603-.921 1.902 0l1.07 3.292a1 1 0 00.95.69h3.462c.969 0 1.371\n                        1.24.588 1.81l-2.8 2.034a1 1 0 00-.364 1.118l1.07 3.292c.3.921-.755 1.688-1.54\n                        1.118l-2.8-2.034a1 1 0 00-1.175 0l-2.8 2.034c-.784.57-1.838-.197-1.539-1.118l1.07-3.292a1\n                        1 0 00-.364-1.118L2.98 8.72c-.783-.57-.38-1.81.588-1.81h3.461a1 1 0 00.951-.69l1.07-3.292z\"\/>\n                <\/svg>\n                                                        <svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" viewBox=\"3 0 20 20\" fill=\"currentColor\" class=\"w-6 h-6\">\n                    <defs>\n                        <linearGradient id=\"partialFill59753\">\n                            <stop offset=\"0%\" stop-color=\"#FFCB01\"\/>\n                            <stop offset=\"80%\" stop-color=\"#FFCB01\"\/>\n                            <stop offset=\"80%\" stop-color=\"#E6E6E6\"\/>\n                            <stop offset=\"100%\" stop-color=\"#E6E6E6\"\/>\n                        <\/linearGradient>\n                    <\/defs>\n                    <g fill=\"url(#partialFill59753)\">\n                        <path\n                            d=\"M9.049 2.927c.3-.921 1.603-.921 1.902 0l1.07 3.292a1 1 0 00.95.69h3.462c.969\n                            0 1.371 1.24.588 1.81l-2.8 2.034a1 1 0 00-.364 1.118l1.07 3.292c.3.921-.755 1.688-1.54\n                            1.118l-2.8-2.034a1 1 0 00-1.175 0l-2.8 2.034c-.784.57-1.838-.197-1.539-1.118l1.07-3.292a1 1\n                            0 00-.364-1.118L2.98 8.72c-.783-.57-.38-1.81.588-1.81h3.461a1 1 0 00.951-.69l1.07-3.292z\"\/>\n                    <\/g>\n                <\/svg>\n                                                \n        <span class=\"text-brand-blue ml-1 hidden sm:block\">\n                            30 reviews                    <\/span>\n        <span class=\"text-brand-blue ml-1 sm:hidden\">\n            (30)        <\/span>\n    <\/a>\n","review_summary":"96","review_count":"30","selected":true,"price_old":404,"price_discount":187.32}],"label":"noodzakelijk"},{"id":"515","name":"Afvoerplug","required":false,"multiple":true,"expanded":false,"single_product":false,"products":[{"product_id":"137081","sku":"A94833858269156","name":"Saqu Steady wastafelplug niet-afsluitbaar chroom","image":"https:\/\/media.saniweb.nl\/cdn-cgi\/image\/fit=pad,format=auto,width=240,height=240\/media\/catalog\/product\/3\/3\/334400.jpg","url":"https:\/\/www.saniweb.be\/saqu-steady-wastafelplug-niet-afsluitbaar-chroom-31211690.html","price_final":14.99,"price_html":"<div class=\"price-box price-final_price\" data-role=\"priceBox\" data-product-id=\"137081\" data-price-box=\"product-id-137081\">    <span class=\"w-full advice-price block shrink-0 text-xs text-brand-gray-dark -mb-2 \">\n        Adviesprijs        <span\n    x-data x-id=\"['old\\u002Dprice\\u002D137081']\"    class=\"price-container line-through&#x20;currency-sign&#x20;tax&#x20;weee\"\n        >\n        <span  :id=\"$id('old\\u002Dprice\\u002D137081')\"                data-price-amount=\"28\"\n        data-price-type=\"originalPrice\"\n        class=\"price-wrapper \"\n    >28,00<\/span>\n        <\/span>\n    <\/span>\n<div class=\"current-price final flex relative\">\n    <span class=\"price-label sr-only\">Prijs<\/span>\n    <span\n    x-data x-id=\"['product\\u002Dprice\\u002D137081']\"    class=\"price-container font-extrabold&#x20;text-3xl&#x20;lg&#x3A;text-3.5xl&#x20;currency-sign&#x20;tax&#x20;weee\"\n        >\n        <span  :id=\"$id('product\\u002Dprice\\u002D137081')\"                data-price-amount=\"14.99\"\n        data-price-type=\"finalPrice\"\n        class=\"price-wrapper \"\n    >14,99<\/span>\n        <\/span>\n<\/div>\n<div class=\"hidden discount-price-label-wrapper ml-auto\">\n            <div class=\"discount-price discount-price-basic relative flex items-center ml-3.5 font-bold leading-3 bg-brand-blue px-2.5 text-white text-xs lg:text-sm rounded-r\n             \"\n         >\n            <span class=\"uppercase\">Je bespaart&nbsp;<\/span>\n            <span>46%<\/span>\n        <\/div>\n    <\/div>\n<\/div>","review_html":"    <a class=\"rating-summary cursor-pointer flex items-center\"\n       href=\"#pdp-reviews\"\n        >\n                    <span class=\"hidden\" itemprop=\"ratingValue\">4.84<\/span>\n            <span class=\"hidden\" itemprop=\"reviewCount\">37<\/span>\n                                                        <svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" class=\"fill-current w-6 h-6\" viewBox=\"3 0 20 20\"\n                     style=\"color: #FFCB01\"\n                     fill=\"currentColor\">\n                    <path\n                        d=\"M9.049 2.927c.3-.921 1.603-.921 1.902 0l1.07 3.292a1 1 0 00.95.69h3.462c.969 0 1.371\n                        1.24.588 1.81l-2.8 2.034a1 1 0 00-.364 1.118l1.07 3.292c.3.921-.755 1.688-1.54\n                        1.118l-2.8-2.034a1 1 0 00-1.175 0l-2.8 2.034c-.784.57-1.838-.197-1.539-1.118l1.07-3.292a1\n                        1 0 00-.364-1.118L2.98 8.72c-.783-.57-.38-1.81.588-1.81h3.461a1 1 0 00.951-.69l1.07-3.292z\"\/>\n                <\/svg>\n                                            <svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" class=\"fill-current w-6 h-6\" viewBox=\"3 0 20 20\"\n                     style=\"color: #FFCB01\"\n                     fill=\"currentColor\">\n                    <path\n                        d=\"M9.049 2.927c.3-.921 1.603-.921 1.902 0l1.07 3.292a1 1 0 00.95.69h3.462c.969 0 1.371\n                        1.24.588 1.81l-2.8 2.034a1 1 0 00-.364 1.118l1.07 3.292c.3.921-.755 1.688-1.54\n                        1.118l-2.8-2.034a1 1 0 00-1.175 0l-2.8 2.034c-.784.57-1.838-.197-1.539-1.118l1.07-3.292a1\n                        1 0 00-.364-1.118L2.98 8.72c-.783-.57-.38-1.81.588-1.81h3.461a1 1 0 00.951-.69l1.07-3.292z\"\/>\n                <\/svg>\n                                            <svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" class=\"fill-current w-6 h-6\" viewBox=\"3 0 20 20\"\n                     style=\"color: #FFCB01\"\n                     fill=\"currentColor\">\n                    <path\n                        d=\"M9.049 2.927c.3-.921 1.603-.921 1.902 0l1.07 3.292a1 1 0 00.95.69h3.462c.969 0 1.371\n                        1.24.588 1.81l-2.8 2.034a1 1 0 00-.364 1.118l1.07 3.292c.3.921-.755 1.688-1.54\n                        1.118l-2.8-2.034a1 1 0 00-1.175 0l-2.8 2.034c-.784.57-1.838-.197-1.539-1.118l1.07-3.292a1\n                        1 0 00-.364-1.118L2.98 8.72c-.783-.57-.38-1.81.588-1.81h3.461a1 1 0 00.951-.69l1.07-3.292z\"\/>\n                <\/svg>\n                                            <svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" class=\"fill-current w-6 h-6\" viewBox=\"3 0 20 20\"\n                     style=\"color: #FFCB01\"\n                     fill=\"currentColor\">\n                    <path\n                        d=\"M9.049 2.927c.3-.921 1.603-.921 1.902 0l1.07 3.292a1 1 0 00.95.69h3.462c.969 0 1.371\n                        1.24.588 1.81l-2.8 2.034a1 1 0 00-.364 1.118l1.07 3.292c.3.921-.755 1.688-1.54\n                        1.118l-2.8-2.034a1 1 0 00-1.175 0l-2.8 2.034c-.784.57-1.838-.197-1.539-1.118l1.07-3.292a1\n                        1 0 00-.364-1.118L2.98 8.72c-.783-.57-.38-1.81.588-1.81h3.461a1 1 0 00.951-.69l1.07-3.292z\"\/>\n                <\/svg>\n                                                        <svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" viewBox=\"3 0 20 20\" fill=\"currentColor\" class=\"w-6 h-6\">\n                    <defs>\n                        <linearGradient id=\"partialFill137081\">\n                            <stop offset=\"0%\" stop-color=\"#FFCB01\"\/>\n                            <stop offset=\"84%\" stop-color=\"#FFCB01\"\/>\n                            <stop offset=\"84%\" stop-color=\"#E6E6E6\"\/>\n                            <stop offset=\"100%\" stop-color=\"#E6E6E6\"\/>\n                        <\/linearGradient>\n                    <\/defs>\n                    <g fill=\"url(#partialFill137081)\">\n                        <path\n                            d=\"M9.049 2.927c.3-.921 1.603-.921 1.902 0l1.07 3.292a1 1 0 00.95.69h3.462c.969\n                            0 1.371 1.24.588 1.81l-2.8 2.034a1 1 0 00-.364 1.118l1.07 3.292c.3.921-.755 1.688-1.54\n                            1.118l-2.8-2.034a1 1 0 00-1.175 0l-2.8 2.034c-.784.57-1.838-.197-1.539-1.118l1.07-3.292a1 1\n                            0 00-.364-1.118L2.98 8.72c-.783-.57-.38-1.81.588-1.81h3.461a1 1 0 00.951-.69l1.07-3.292z\"\/>\n                    <\/g>\n                <\/svg>\n                                                \n        <span class=\"text-brand-blue ml-1 hidden sm:block\">\n                            37 reviews                    <\/span>\n        <span class=\"text-brand-blue ml-1 sm:hidden\">\n            (37)        <\/span>\n    <\/a>\n","review_summary":"96.8000","review_count":"37","price_old":28,"price_discount":13.01}],"filter_id":161},{"id":"506","name":"Bekersifon","required":false,"multiple":true,"expanded":false,"single_product":false,"products":[{"product_id":"116559","sku":"A01476803338314","name":"Saqu Desire design sifon laag voor fontein chroom","image":"https:\/\/media.saniweb.nl\/cdn-cgi\/image\/fit=pad,format=auto,width=240,height=240\/media\/catalog\/product\/3\/1\/31203620_P2.jpg","url":"https:\/\/www.saniweb.be\/saqu-desire-design-sifon-laag-voor-fontein-chroom-31203620.html","price_final":31.99,"price_html":"<div class=\"price-box price-final_price\" data-role=\"priceBox\" data-product-id=\"116559\" data-price-box=\"product-id-116559\">    <span class=\"w-full advice-price block shrink-0 text-xs text-brand-gray-dark -mb-2 \">\n        Adviesprijs        <span\n    x-data x-id=\"['old\\u002Dprice\\u002D116559']\"    class=\"price-container line-through&#x20;currency-sign&#x20;tax&#x20;weee\"\n        >\n        <span  :id=\"$id('old\\u002Dprice\\u002D116559')\"                data-price-amount=\"56\"\n        data-price-type=\"originalPrice\"\n        class=\"price-wrapper \"\n    >56,00<\/span>\n        <\/span>\n    <\/span>\n<div class=\"current-price final flex relative\">\n    <span class=\"price-label sr-only\">Prijs<\/span>\n    <span\n    x-data x-id=\"['product\\u002Dprice\\u002D116559']\"    class=\"price-container font-extrabold&#x20;text-3xl&#x20;lg&#x3A;text-3.5xl&#x20;currency-sign&#x20;tax&#x20;weee\"\n        >\n        <span  :id=\"$id('product\\u002Dprice\\u002D116559')\"                data-price-amount=\"31.99\"\n        data-price-type=\"finalPrice\"\n        class=\"price-wrapper \"\n    >31,99<\/span>\n        <\/span>\n<\/div>\n<div class=\"hidden discount-price-label-wrapper ml-auto\">\n            <div class=\"discount-price discount-price-basic relative flex items-center ml-3.5 font-bold leading-3 bg-brand-blue px-2.5 text-white text-xs lg:text-sm rounded-r\n             \"\n         >\n            <span class=\"uppercase\">Je bespaart&nbsp;<\/span>\n            <span>43%<\/span>\n        <\/div>\n    <\/div>\n<\/div>","review_html":"    <a class=\"rating-summary cursor-pointer flex items-center\"\n       href=\"#pdp-reviews\"\n        >\n                    <span class=\"hidden\" itemprop=\"ratingValue\">4.508335<\/span>\n            <span class=\"hidden\" itemprop=\"reviewCount\">38<\/span>\n                                                        <svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" class=\"fill-current w-6 h-6\" viewBox=\"3 0 20 20\"\n                     style=\"color: #FFCB01\"\n                     fill=\"currentColor\">\n                    <path\n                        d=\"M9.049 2.927c.3-.921 1.603-.921 1.902 0l1.07 3.292a1 1 0 00.95.69h3.462c.969 0 1.371\n                        1.24.588 1.81l-2.8 2.034a1 1 0 00-.364 1.118l1.07 3.292c.3.921-.755 1.688-1.54\n                        1.118l-2.8-2.034a1 1 0 00-1.175 0l-2.8 2.034c-.784.57-1.838-.197-1.539-1.118l1.07-3.292a1\n                        1 0 00-.364-1.118L2.98 8.72c-.783-.57-.38-1.81.588-1.81h3.461a1 1 0 00.951-.69l1.07-3.292z\"\/>\n                <\/svg>\n                                            <svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" class=\"fill-current w-6 h-6\" viewBox=\"3 0 20 20\"\n                     style=\"color: #FFCB01\"\n                     fill=\"currentColor\">\n                    <path\n                        d=\"M9.049 2.927c.3-.921 1.603-.921 1.902 0l1.07 3.292a1 1 0 00.95.69h3.462c.969 0 1.371\n                        1.24.588 1.81l-2.8 2.034a1 1 0 00-.364 1.118l1.07 3.292c.3.921-.755 1.688-1.54\n                        1.118l-2.8-2.034a1 1 0 00-1.175 0l-2.8 2.034c-.784.57-1.838-.197-1.539-1.118l1.07-3.292a1\n                        1 0 00-.364-1.118L2.98 8.72c-.783-.57-.38-1.81.588-1.81h3.461a1 1 0 00.951-.69l1.07-3.292z\"\/>\n                <\/svg>\n                                            <svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" class=\"fill-current w-6 h-6\" viewBox=\"3 0 20 20\"\n                     style=\"color: #FFCB01\"\n                     fill=\"currentColor\">\n                    <path\n                        d=\"M9.049 2.927c.3-.921 1.603-.921 1.902 0l1.07 3.292a1 1 0 00.95.69h3.462c.969 0 1.371\n                        1.24.588 1.81l-2.8 2.034a1 1 0 00-.364 1.118l1.07 3.292c.3.921-.755 1.688-1.54\n                        1.118l-2.8-2.034a1 1 0 00-1.175 0l-2.8 2.034c-.784.57-1.838-.197-1.539-1.118l1.07-3.292a1\n                        1 0 00-.364-1.118L2.98 8.72c-.783-.57-.38-1.81.588-1.81h3.461a1 1 0 00.951-.69l1.07-3.292z\"\/>\n                <\/svg>\n                                            <svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" class=\"fill-current w-6 h-6\" viewBox=\"3 0 20 20\"\n                     style=\"color: #FFCB01\"\n                     fill=\"currentColor\">\n                    <path\n                        d=\"M9.049 2.927c.3-.921 1.603-.921 1.902 0l1.07 3.292a1 1 0 00.95.69h3.462c.969 0 1.371\n                        1.24.588 1.81l-2.8 2.034a1 1 0 00-.364 1.118l1.07 3.292c.3.921-.755 1.688-1.54\n                        1.118l-2.8-2.034a1 1 0 00-1.175 0l-2.8 2.034c-.784.57-1.838-.197-1.539-1.118l1.07-3.292a1\n                        1 0 00-.364-1.118L2.98 8.72c-.783-.57-.38-1.81.588-1.81h3.461a1 1 0 00.951-.69l1.07-3.292z\"\/>\n                <\/svg>\n                                                        <svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" viewBox=\"3 0 20 20\" fill=\"currentColor\" class=\"w-6 h-6\">\n                    <defs>\n                        <linearGradient id=\"partialFill116559\">\n                            <stop offset=\"0%\" stop-color=\"#FFCB01\"\/>\n                            <stop offset=\"50.8335%\" stop-color=\"#FFCB01\"\/>\n                            <stop offset=\"50.8335%\" stop-color=\"#E6E6E6\"\/>\n                            <stop offset=\"100%\" stop-color=\"#E6E6E6\"\/>\n                        <\/linearGradient>\n                    <\/defs>\n                    <g fill=\"url(#partialFill116559)\">\n                        <path\n                            d=\"M9.049 2.927c.3-.921 1.603-.921 1.902 0l1.07 3.292a1 1 0 00.95.69h3.462c.969\n                            0 1.371 1.24.588 1.81l-2.8 2.034a1 1 0 00-.364 1.118l1.07 3.292c.3.921-.755 1.688-1.54\n                            1.118l-2.8-2.034a1 1 0 00-1.175 0l-2.8 2.034c-.784.57-1.838-.197-1.539-1.118l1.07-3.292a1 1\n                            0 00-.364-1.118L2.98 8.72c-.783-.57-.38-1.81.588-1.81h3.461a1 1 0 00.951-.69l1.07-3.292z\"\/>\n                    <\/g>\n                <\/svg>\n                                                \n        <span class=\"text-brand-blue ml-1 hidden sm:block\">\n                            38 reviews                    <\/span>\n        <span class=\"text-brand-blue ml-1 sm:hidden\">\n            (38)        <\/span>\n    <\/a>\n","review_summary":"90.1667","review_count":"38","price_old":56,"price_discount":24.01}],"filter_id":2466}],"html":"\n<!-- Start Google Analytics 4 for Google Tag Manager by MagePal -->\n<script type=\"text\/javascript\">\n    (function () {\n        let globalDatalayer = window.dataLayer = window.dataLayer || [];\n\n        function init() {\n            const data = [{\"event\":\"view_item_list\",\"ecommerce\":{\"items\":[{\"item_name\":\"Grohe Eurostyle inbouwdeel voor 2-gats wastafelkraan\",\"item_id\":\"A00000000147453\",\"price\":216.68,\"item_list_name\":\"Advanced Crosssells\",\"item_list_id\":\"advanced_crosssells\",\"index\":1,\"currency\":\"EUR\",\"quantity\":1,\"p_id\":59753,\"original_price\":404,\"item_category\":\"Inbouwdeel\"},{\"item_name\":\"Saqu Steady wastafelplug niet-afsluitbaar chroom\",\"item_id\":\"A94833858269156\",\"price\":14.99,\"item_list_name\":\"Advanced Crosssells\",\"item_list_id\":\"advanced_crosssells\",\"index\":2,\"currency\":\"EUR\",\"quantity\":1,\"p_id\":137081,\"original_price\":28,\"item_category\":\"Afvoerplug\"},{\"item_name\":\"Saqu Desire design sifon laag voor fontein chroom\",\"item_id\":\"A01476803338314\",\"price\":31.99,\"item_list_name\":\"Advanced Crosssells\",\"item_list_id\":\"advanced_crosssells\",\"index\":3,\"currency\":\"EUR\",\"quantity\":1,\"p_id\":116559,\"original_price\":56,\"item_category\":\"Bekersifon\"}],\"currency\":\"EUR\",\"item_list_name\":\"Advanced Crosssells\",\"item_list_id\":\"advanced_crosssells\"},\"_clear\":true}];\n\n            const processedProductElements = [];\n            const viewItemListEvents = data.filter(item => item?.event === 'view_item_list');\n            const throttle = (callback, threshold = 200) => {\n                let last;\n                let deferTimer;\n                return (...args) => {\n                    const now = new Date().valueOf();\n                    if (last && now < last + threshold) {\n                        clearTimeout(deferTimer);\n                        deferTimer = setTimeout(() => {\n                            last = now;\n                            callback(args);\n                        }, threshold);\n                    } else {\n                        last = now;\n                        callback(args);\n                    }\n                };\n            }\n            const isElementInViewport = (el) => {\n                const rect = el.getBoundingClientRect();\n                const center = {\n                    x: (rect.right + rect.left) \/ 2,\n                    y: (rect.bottom + rect.top) \/ 2,\n                }\n                return (\n                    center.x >= 0 &&\n                    center.y >= 0 &&\n                    center.x <= (window.innerWidth || document.documentElement.clientWidth) &&\n                    center.y <= (window.innerHeight || document.documentElement.clientHeight)\n                );\n            }\n            const pushProductElements = (productElements) => {\n                const events = [];\n                const skus = productElements.map(productElement => productElement.dataset.listProductSku);\n                viewItemListEvents.forEach(viewItemsListEvent => {\n                    const eventItems = viewItemsListEvent?.ecommerce?.items?.filter(item => {\n                        return skus.includes(item.item_id)\n                    });\n                    if (eventItems && eventItems.length > 0) {\n                        const event = JSON.parse(JSON.stringify(viewItemsListEvent));\n                        event.ecommerce.items = eventItems;\n                        events.push(event);\n                    }\n                });\n\n                if (events.length) {\n                    events.forEach(event => {\n                        globalDatalayer.push(event);\n                    });\n                }\n            }\n            const checkNewProductsInViewport = () => {\n                const newProductElementsInViewport = [];\n                document.querySelectorAll(['[data-list-product-sku]']).forEach(productElement => {\n                    if (!processedProductElements.includes(productElement) && isElementInViewport(productElement)) {\n                        newProductElementsInViewport.push(productElement);\n                    }\n                });\n\n                if (newProductElementsInViewport.length) {\n                    processedProductElements.push(...newProductElementsInViewport);\n                    pushProductElements(newProductElementsInViewport);\n                }\n            };\n            if (viewItemListEvents.length > 0) {\n                window.addEventListener('DOMContentLoaded', checkNewProductsInViewport);\n                window.addEventListener('scroll', throttle(checkNewProductsInViewport));\n                window.addEventListener('resize', throttle(checkNewProductsInViewport));\n            }\n\n            if (data) {\n                let storedData = null\n\n                data.forEach((item) => {\n                    \/\/ Set category data on product detail page\n                    if (item?.event === 'view_item') {\n                        if (storedData === null) {\n                            storedData = JSON.parse(window.localStorage.getItem(\"product-click-ga4\"));\n                        }\n\n                        item?.ecommerce?.items?.forEach((product) => {\n                            if (storedData?.index) {\n                                product.index = storedData.index\n                            }\n\n                            if (storedData?.item_list_name) {\n                                product.item_list_name = storedData.item_list_name;\n                                product.item_list_id = storedData.item_list_id;\n                            }\n                        })\n                    }\n\n                    if (item?.event !== 'view_item_list') {\n                        globalDatalayer.push(item);\n                    }\n                })\n            }\n        }\n\n        init();\n\n                \/\/ Track product clicks\n        const productsList = [{\"item_list_name\":\"Advanced Crosssells\",\"item_list_id\":\"advanced_crosssells\",\"class_name\":\"[data-upsell-tool-category] a.product-item-link\",\"container_class\":\"[data-list-product-sku]\"}]\n        document.body.addEventListener('click', (event) => {\n            productsList.forEach((list) => {\n                if (list?.class_name) {\n                    const clickTarget = event.target;\n                    const productLink = clickTarget.closest(list?.class_name);\n                    if (productLink) {\n                        productClick(productLink, list)\n                    }\n                }\n            });\n            return;\n        });\n\n        function productClick(element, list) {\n            const container = element.closest(list?.container_class)\n\n            \/\/ Find product url\n            let productUrl = null\n            if (container && container.querySelector('a.product-item-link')) {\n                productUrl = container.querySelector('a.product-item-link').href\n            } else if (container && container.querySelector('a.product-item-photo')) {\n                productUrl = container.querySelector('a.product-item-photo').href\n            } else {\n                productUrl = element.href\n            }\n\n            const priceBox = container.querySelector(\"[data-product-id]\")\n            if (priceBox) {\n                const productId = priceBox.dataset.productId\n\n                const productCollection = globalDatalayer.filter((layer) => layer?.ecommerce?.items).reduce((collection, layer) => collection.concat(...layer.ecommerce.items), [])\n                const product = productCollection.find((product) => product.p_id == productId)\n\n                const productClickData = {\n                    pid: productId,\n                    item_id: product.item_id,\n                    item_list_name: list.item_list_name,\n                    item_list_id: list.item_list_id,\n                    index: product.index\n                }\n                window.localStorage.setItem(\"product-click-ga4\", JSON.stringify(productClickData))\n\n                globalDatalayer.push({\n                    'event': 'select_item',\n                    'ecommerce': {\n                        'items': [product]\n                    },\n                    '_clear': true\n                });\n            }\n        }\n            })();\n<\/script>\n<!-- End Google Analytics 4 for Google Tag Manager by MagePal -->\n"}