acinguiux-preact-components 0.0.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/package.json +56 -0
- package/src/content/themes/theme-acinguiux-amg/theme-acinguiux-amg.css +23 -0
- package/src/content/themes/theme-acinguiux-cafe/theme-acinguiux-cafe.css +47 -0
- package/src/content/themes/theme-acinguiux-energy/theme-acinguiux-energy.css +45 -0
- package/src/content/themes/theme-acinguiux-livewire/theme-acinguiux-livewire.css +22 -0
- package/src/content/themes/theme-acinguiux-livewire-italy/theme-acinguiux-livewire-italy.css +22 -0
- package/src/content/themes/theme-acinguiux-recharge/theme-acinguiux-recharge.css +49 -0
- package/src/content/themes/theme-allon/theme-allon.css +25 -0
- package/src/content/themes/theme-atlas/theme-atlas.css +31 -0
- package/src/content/themes/theme-aurvana/resources/favicon/apple-touch-icon.png +0 -0
- package/src/content/themes/theme-aurvana/resources/favicon/favico.ico +0 -0
- package/src/content/themes/theme-aurvana/resources/favicon/favicon-96x96.png +0 -0
- package/src/content/themes/theme-aurvana/resources/favicon/favicon.ico +0 -0
- package/src/content/themes/theme-aurvana/resources/favicon/favicon.png +0 -0
- package/src/content/themes/theme-aurvana/resources/favicon/favicon.svg +13 -0
- package/src/content/themes/theme-aurvana/resources/favicon/google-touch-icon.png +0 -0
- package/src/content/themes/theme-aurvana/resources/favicon/manifest.json +14 -0
- package/src/content/themes/theme-aurvana/resources/favicon/site.webmanifest +21 -0
- package/src/content/themes/theme-aurvana/resources/favicon/web-app-manifest-192x192.png +0 -0
- package/src/content/themes/theme-aurvana/resources/favicon/web-app-manifest-512x512.png +0 -0
- package/src/content/themes/theme-aurvana/theme-aurvana.css +49 -0
- package/src/content/themes/theme-base/theme-base.css +49 -0
- package/src/content/themes/theme-base2/resources/favicon/android-chrome-192x192.png +0 -0
- package/src/content/themes/theme-base2/resources/favicon/android-chrome-512x512.png +0 -0
- package/src/content/themes/theme-base2/resources/favicon/apple-touch-icon.png +0 -0
- package/src/content/themes/theme-base2/resources/favicon/favico.ico +0 -0
- package/src/content/themes/theme-base2/resources/favicon/favicon-16x16.png +0 -0
- package/src/content/themes/theme-base2/resources/favicon/favicon-32x32.png +0 -0
- package/src/content/themes/theme-base2/resources/favicon/favicon-96x96.png +0 -0
- package/src/content/themes/theme-base2/resources/favicon/favicon.ico +0 -0
- package/src/content/themes/theme-base2/resources/favicon/favicon.png +0 -0
- package/src/content/themes/theme-base2/resources/favicon/favicon.svg +9 -0
- package/src/content/themes/theme-base2/resources/favicon/google-touch-icon.png +0 -0
- package/src/content/themes/theme-base2/resources/favicon/manifest.json +14 -0
- package/src/content/themes/theme-base2/resources/favicon/site.webmanifest +1 -0
- package/src/content/themes/theme-base2/resources/favicon/web-app-manifest-192x192.png +0 -0
- package/src/content/themes/theme-base2/resources/favicon/web-app-manifest-512x512.png +0 -0
- package/src/content/themes/theme-base2/resources/fonts/acinguiux-typeface-la-heavy-221208.woff2 +0 -0
- package/src/content/themes/theme-base2/theme-base2.css +47 -0
- package/src/content/themes/theme-eco-marathon/theme-eco-marathon.css +22 -0
- package/src/content/themes/theme-energy-transition-campus-amsterdam/theme-energy-transition-campus-amsterdam.css +26 -0
- package/src/content/themes/theme-evpass/theme-evpass.css +46 -0
- package/src/content/themes/theme-nam-2025/resources/favicon/apple-touch-icon.png +0 -0
- package/src/content/themes/theme-nam-2025/resources/favicon/favico.ico +0 -0
- package/src/content/themes/theme-nam-2025/resources/favicon/favicon-96x96.png +0 -0
- package/src/content/themes/theme-nam-2025/resources/favicon/favicon.ico +0 -0
- package/src/content/themes/theme-nam-2025/resources/favicon/favicon.png +0 -0
- package/src/content/themes/theme-nam-2025/resources/favicon/favicon.svg +9 -0
- package/src/content/themes/theme-nam-2025/resources/favicon/google-touch-icon.png +0 -0
- package/src/content/themes/theme-nam-2025/resources/favicon/manifest.json +14 -0
- package/src/content/themes/theme-nam-2025/resources/favicon/site.webmanifest +21 -0
- package/src/content/themes/theme-nam-2025/resources/favicon/web-app-manifest-192x192.png +0 -0
- package/src/content/themes/theme-nam-2025/resources/favicon/web-app-manifest-512x512.png +0 -0
- package/src/content/themes/theme-nam-2025/theme-nam-2025.css +47 -0
- package/src/content/themes/theme-pennzoil/theme-pennzoil.css +36 -0
- package/src/content/themes/theme-quaker-state/theme-quaker-state.css +63 -0
- package/src/content/themes/theme-tafawoq/theme-tafawoq.css +26 -0
- package/src/content/themes/theme-vegetable/resources/favicon/apple-touch-icon.png +0 -0
- package/src/content/themes/theme-vegetable/resources/favicon/favico.ico +0 -0
- package/src/content/themes/theme-vegetable/resources/favicon/favicon-96x96.png +0 -0
- package/src/content/themes/theme-vegetable/resources/favicon/favicon.ico +0 -0
- package/src/content/themes/theme-vegetable/resources/favicon/favicon.png +0 -0
- package/src/content/themes/theme-vegetable/resources/favicon/favicon.svg +13 -0
- package/src/content/themes/theme-vegetable/resources/favicon/google-touch-icon.png +0 -0
- package/src/content/themes/theme-vegetable/resources/favicon/manifest.json +14 -0
- package/src/content/themes/theme-vegetable/resources/favicon/site.webmanifest +21 -0
- package/src/content/themes/theme-vegetable/resources/favicon/web-app-manifest-192x192.png +0 -0
- package/src/content/themes/theme-vegetable/resources/favicon/web-app-manifest-512x512.png +0 -0
- package/src/content/themes/theme-vegetable/theme-vegetable.css +49 -0
- package/src/content/themes/theme-zeolyst/resources/fonts/type-ar-medium.woff2 +0 -0
- package/src/content/themes/theme-zeolyst/theme-zeolyst.css +29 -0
- package/src/main/atoms/audio.js +16 -0
- package/src/main/atoms/box.js +5 -0
- package/src/main/atoms/button.js +40 -0
- package/src/main/atoms/card.js +22 -0
- package/src/main/atoms/form.js +30 -0
- package/src/main/atoms/heading.js +17 -0
- package/src/main/atoms/icon.js +24 -0
- package/src/main/atoms/img.js +131 -0
- package/src/main/atoms/input.js +55 -0
- package/src/main/atoms/link-text.js +21 -0
- package/src/main/atoms/link.js +60 -0
- package/src/main/atoms/list.js +12 -0
- package/src/main/atoms/logo.js +9 -0
- package/src/main/atoms/menu.js +10 -0
- package/src/main/atoms/message.js +5 -0
- package/src/main/atoms/nav-link.js +49 -0
- package/src/main/atoms/popup.js +47 -0
- package/src/main/atoms/rich-text.js +128 -0
- package/src/main/atoms/scroller.js +224 -0
- package/src/main/atoms/svg.js +65 -0
- package/src/main/atoms/table.js +32 -0
- package/src/main/atoms/textarea.js +10 -0
- package/src/main/atoms/time.js +12 -0
- package/src/main/atoms/video.js +100 -0
- package/src/main/export-main.js +12 -0
- package/src/main/export-matter.js +86 -0
- package/src/main/export-preact-hooks.js +1 -0
- package/src/main/export-preact.js +1 -0
- package/src/main/index.js +13 -0
- package/src/main/molecules/asset.js +23 -0
- package/src/main/molecules/glossary.js +44 -0
- package/src/main/molecules/links.js +23 -0
- package/src/main/molecules/promo-text.js +27 -0
- package/src/main/molecules/tags.js +15 -0
- package/src/main/molecules/tree.js +51 -0
- package/src/main/organisms/accordion-item.js +106 -0
- package/src/main/organisms/author.js +29 -0
- package/src/main/organisms/breadcrumb.js +69 -0
- package/src/main/organisms/call-to-action.js +24 -0
- package/src/main/organisms/carousel.js +178 -0
- package/src/main/organisms/cart-item.js +156 -0
- package/src/main/organisms/cart.js +162 -0
- package/src/main/organisms/contact-form.js +141 -0
- package/src/main/organisms/container/ab-test.js +47 -0
- package/src/main/organisms/container/default.js +6 -0
- package/src/main/organisms/container/filtered-section.js +293 -0
- package/src/main/organisms/container/footer.js +12 -0
- package/src/main/organisms/container/grid.js +44 -0
- package/src/main/organisms/container/header.js +13 -0
- package/src/main/organisms/container/list.js +7 -0
- package/src/main/organisms/container/main.js +6 -0
- package/src/main/organisms/container/raw.js +7 -0
- package/src/main/organisms/container/section.js +28 -0
- package/src/main/organisms/container.js +29 -0
- package/src/main/organisms/content-owner.js +15 -0
- package/src/main/organisms/date-entry.js +56 -0
- package/src/main/organisms/external-search.js +73 -0
- package/src/main/organisms/filtered-item.js +163 -0
- package/src/main/organisms/footer-item.js +17 -0
- package/src/main/organisms/image-gallery.js +164 -0
- package/src/main/organisms/last-modified.js +20 -0
- package/src/main/organisms/legal-footer.js +16 -0
- package/src/main/organisms/list-item.js +48 -0
- package/src/main/organisms/metadata.js +11 -0
- package/src/main/organisms/navigation.js +232 -0
- package/src/main/organisms/notification.js +87 -0
- package/src/main/organisms/order-tracker.js +203 -0
- package/src/main/organisms/page-header-banner.js +26 -0
- package/src/main/organisms/page-header.js +33 -0
- package/src/main/organisms/page-tags.js +14 -0
- package/src/main/organisms/page.js +260 -0
- package/src/main/organisms/press-release.js +24 -0
- package/src/main/organisms/product-admin.js +204 -0
- package/src/main/organisms/promo-banner.js +28 -0
- package/src/main/organisms/promo-bottom.js +23 -0
- package/src/main/organisms/promo-button.js +8 -0
- package/src/main/organisms/promo-card-cover.js +35 -0
- package/src/main/organisms/promo-card.js +33 -0
- package/src/main/organisms/promo-full.js +20 -0
- package/src/main/organisms/promo-image.js +22 -0
- package/src/main/organisms/promo-lure.js +22 -0
- package/src/main/organisms/promo-product-card.js +187 -0
- package/src/main/organisms/promo-product-full.js +293 -0
- package/src/main/organisms/promo-simple.js +23 -0
- package/src/main/organisms/quote.js +21 -0
- package/src/main/organisms/search-form.js +42 -0
- package/src/main/organisms/search-nav.js +66 -0
- package/src/main/organisms/search-result.js +53 -0
- package/src/main/organisms/slider.js +26 -0
- package/src/main/organisms/standalone-asset.js +22 -0
- package/src/main/organisms/tabs.js +277 -0
- package/src/main/organisms/topbar.js +83 -0
- package/src/main/organisms/web-component.js +53 -0
- package/src/main/routing/annotation.js +9 -0
- package/src/main/routing/component.js +138 -0
- package/src/main/routing/empty.js +5 -0
- package/src/main/routing/error-handler.js +64 -0
- package/src/main/routing/placeholder-image.svg +5 -0
- package/src/main/routing/router.js +219 -0
- package/src/main/shared/analytics.js +677 -0
- package/src/main/shared/bubble-event.js +11 -0
- package/src/main/shared/custom-element.js +21 -0
- package/src/main/shared/deep-selector.js +28 -0
- package/src/main/shared/disable-transparency.js +10 -0
- package/src/main/shared/format-time.js +8 -0
- package/src/main/shared/get-id.js +5 -0
- package/src/main/shared/get-meta.js +3 -0
- package/src/main/shared/get-size-class.js +3 -0
- package/src/main/shared/get-size.js +11 -0
- package/src/main/shared/h.js +88 -0
- package/src/main/shared/hash-jump.js +33 -0
- package/src/main/shared/icons/arrow-back.svg +1 -0
- package/src/main/shared/icons/arrow-down.svg +1 -0
- package/src/main/shared/icons/arrow-next.svg +1 -0
- package/src/main/shared/icons/arrow-tail-right.svg +1 -0
- package/src/main/shared/icons/arrow-tail-up.svg +1 -0
- package/src/main/shared/icons/arrow-up.svg +1 -0
- package/src/main/shared/icons/asset-download.svg +1 -0
- package/src/main/shared/icons/logo.svg +5 -0
- package/src/main/shared/icons/low-carbon-placeholder.svg +9 -0
- package/src/main/shared/icons/media-pause.svg +1 -0
- package/src/main/shared/icons/media-play.svg +1 -0
- package/src/main/shared/icons/navigation-burger.svg +1 -0
- package/src/main/shared/icons/navigation-close.svg +1 -0
- package/src/main/shared/icons/navigation-link.svg +1 -0
- package/src/main/shared/icons/navigation-refresh.svg +1 -0
- package/src/main/shared/icons/navigation-search.svg +1 -0
- package/src/main/shared/icons/navigation-share.svg +1 -0
- package/src/main/shared/icons/toggle-newwindow.svg +1 -0
- package/src/main/shared/icons.js +18 -0
- package/src/main/shared/id-from-string.js +5 -0
- package/src/main/shared/mark-selection.js +19 -0
- package/src/main/shared/register.js +26 -0
- package/src/main/shared/renderer.js +43 -0
- package/src/main/shared/simple-consent-api.js +70 -0
- package/src/main/shared/split-links.js +11 -0
- package/src/main/shared/t.js +60 -0
- package/src/main/shared/twind.js +837 -0
- package/src/main/shared/update-head.js +34 -0
- package/src/main/shared/update-scrollbar-width.js +30 -0
- package/src/main/shared/use-link.js +151 -0
- package/src/main/shared/use-persistent-state.js +42 -0
- package/src/main/shared/wait-for-dom-ready.js +6 -0
- package/src/main/shared/wcm-mode.js +4 -0
- package/src/wcs/components/acinguiux-preact-doc/acinguiux-preact-doc.js +207 -0
- package/src/wcs/components/admin-dashboard/admin-dashboard.js +487 -0
- package/src/wcs/components/admin-login/admin-login.js +91 -0
- package/src/wcs/components/bazaar-voice/bazaar-voice.js +56 -0
- package/src/wcs/components/chatbot-koreai/chatbot-koreai.js +176 -0
- package/src/wcs/components/chatbot-koreai/koreai-transport.js +217 -0
- package/src/wcs/components/chatbot-ms/chatbot-ms.js +210 -0
- package/src/wcs/components/chatbot-test/chatbot-test.js +44 -0
- package/src/wcs/components/comparison-chart/comparison-chart.js +111 -0
- package/src/wcs/components/consent-banner/consent-banner.js +248 -0
- package/src/wcs/components/consent-banner/icons/ccpa.svg +6 -0
- package/src/wcs/components/consent-banner/icons/info.svg +1 -0
- package/src/wcs/components/consent-banner/provider-onetrust.js +131 -0
- package/src/wcs/components/decision-tree/arrow-back.svg +3 -0
- package/src/wcs/components/decision-tree/badges.js +37 -0
- package/src/wcs/components/decision-tree/decision-tree.js +162 -0
- package/src/wcs/components/dynamic-contact-details/dynamic-contact-details.js +111 -0
- package/src/wcs/components/example-accordion/example-accordion.js +10 -0
- package/src/wcs/components/example-asset/example-asset.js +12 -0
- package/src/wcs/components/example-form/example-form.js +59 -0
- package/src/wcs/components/example-nested/example-nested.js +10 -0
- package/src/wcs/components/example-routing/example-routing.js +51 -0
- package/src/wcs/components/example-rtl/example-rtl.js +28 -0
- package/src/wcs/components/example-tabs/example-tabs.js +12 -0
- package/src/wcs/components/example-web-component/example-web-component.js +34 -0
- package/src/wcs/components/floating-button/floating-button.js +17 -0
- package/src/wcs/components/formstack-form/fields/address.js +38 -0
- package/src/wcs/components/formstack-form/fields/checkbox.js +42 -0
- package/src/wcs/components/formstack-form/fields/date.js +22 -0
- package/src/wcs/components/formstack-form/fields/description.js +8 -0
- package/src/wcs/components/formstack-form/fields/input.js +8 -0
- package/src/wcs/components/formstack-form/fields/name.js +39 -0
- package/src/wcs/components/formstack-form/fields/radio.js +24 -0
- package/src/wcs/components/formstack-form/fields/rating.js +53 -0
- package/src/wcs/components/formstack-form/fields/section.js +8 -0
- package/src/wcs/components/formstack-form/fields/select.js +10 -0
- package/src/wcs/components/formstack-form/fields/textarea.js +8 -0
- package/src/wcs/components/formstack-form/fields/wrapper.js +11 -0
- package/src/wcs/components/formstack-form/formstack-form.js +280 -0
- package/src/wcs/components/fuel-prices/fuel-prices.js +45 -0
- package/src/wcs/components/furniture-overview/furniture-overview.js +115 -0
- package/src/wcs/components/gauge-value/gauge-value.js +65 -0
- package/src/wcs/components/help-centre/api.js +150 -0
- package/src/wcs/components/help-centre/help-centre.js +400 -0
- package/src/wcs/components/help-centre/icon-search.svg +1 -0
- package/src/wcs/components/image-gen/admin-panel.js +248 -0
- package/src/wcs/components/image-gen/image-gen.js +385 -0
- package/src/wcs/components/image-gen/labels.js +37 -0
- package/src/wcs/components/image-gen/use-api.js +392 -0
- package/src/wcs/components/inspired-gallery/inspired-gallery.js +118 -0
- package/src/wcs/components/launch-container/launch-container.js +95 -0
- package/src/wcs/components/launch-container/ledger.js +140 -0
- package/src/wcs/components/lng-map/lng-map.js +44 -0
- package/src/wcs/components/mouseflow-analytics/mouseflow-analytics.js +39 -0
- package/src/wcs/components/msds-search/msds-search.js +127 -0
- package/src/wcs/components/msds-search/navigation-search.svg +3 -0
- package/src/wcs/components/product-catalogue/icon-back.svg +3 -0
- package/src/wcs/components/product-catalogue/icon-cart.svg +3 -0
- package/src/wcs/components/product-catalogue/icon-close.svg +3 -0
- package/src/wcs/components/product-catalogue/product-catalogue.js +215 -0
- package/src/wcs/components/product-links/icon-cart.svg +3 -0
- package/src/wcs/components/product-links/product-links.js +43 -0
- package/src/wcs/components/rio-iframe/rio-iframe.js +137 -0
- package/src/wcs/components/salsify-products/filter-tools.js +60 -0
- package/src/wcs/components/salsify-products/icon-cart.svg +3 -0
- package/src/wcs/components/salsify-products/process-products.js +53 -0
- package/src/wcs/components/salsify-products/route-tools.js +54 -0
- package/src/wcs/components/salsify-products/salsify-products.js +281 -0
- package/src/wcs/components/shout-out/shout-out.js +51 -0
- package/src/wcs/components/simple-chart/simple-chart.js +53 -0
- package/src/wcs/components/single-stat/single-stat.js +85 -0
- package/src/wcs/components/site-feedback/site-feedback.js +56 -0
- package/src/wcs/components/skds-search/navigation-search.svg +3 -0
- package/src/wcs/components/skds-search/skds-search.js +103 -0
- package/src/wcs/components/smart-banner/smart-banner.js +104 -0
- package/src/wcs/components/standalone-table/arrow-up-down.svg +3 -0
- package/src/wcs/components/standalone-table/arrow-up.svg +3 -0
- package/src/wcs/components/standalone-table/standalone-table.js +440 -0
- package/src/wcs/components/station-locator/station-locator.js +49 -0
- package/src/wcs/components/store-badges/badges.js +60 -0
- package/src/wcs/components/store-badges/store-badges.js +93 -0
- package/src/wcs/components/topbar-button/person.svg +1 -0
- package/src/wcs/components/topbar-button/topbar-button.js +22 -0
- package/src/wcs/components/universal-gallery/universal-gallery.js +308 -0
- package/src/wcs/components/zendesk-chat/zendesk-chat.js +133 -0
- package/src/wcs/shared/chat-bot/README.md +61 -0
- package/src/wcs/shared/chat-bot/chat-bot.js +216 -0
- package/src/wcs/shared/chat-bot/resources/arrow-next.svg +1 -0
- package/src/wcs/shared/chat-bot/resources/navigation-close.svg +1 -0
- package/src/wcs/shared/chat-bot/resources/person.svg +1 -0
- package/src/wcs/shared/chat-bot/resources/upload.svg +1 -0
- package/src/wcs/shared/filtered-data/README.md +52 -0
- package/src/wcs/shared/filtered-data/fetch-data.js +33 -0
- package/src/wcs/shared/filtered-data/filtered-data.js +337 -0
- package/src/wcs/shared/promo-with-popup/icon-close.svg +3 -0
- package/src/wcs/shared/promo-with-popup/icon-next.svg +3 -0
- package/src/wcs/shared/promo-with-popup/icon-prev.svg +3 -0
- package/src/wcs/shared/promo-with-popup/promo-with-popup.js +93 -0
|
@@ -0,0 +1,111 @@
|
|
|
1
|
+
const { h, register, matter, preactHooks } = globalThis.ami
|
|
2
|
+
const { Box, Table, Link, Asset } = matter
|
|
3
|
+
const { useState, useEffect, useMemo } = preactHooks
|
|
4
|
+
|
|
5
|
+
function ComparisonChart ({ src, highlight }) {
|
|
6
|
+
const [products, setProducts] = useState()
|
|
7
|
+
|
|
8
|
+
if (!src) {
|
|
9
|
+
console.error('Missing data source.')
|
|
10
|
+
return null
|
|
11
|
+
}
|
|
12
|
+
|
|
13
|
+
useEffect(() => {
|
|
14
|
+
(async () => {
|
|
15
|
+
const res = await fetch(src)
|
|
16
|
+
setProducts(await res.json())
|
|
17
|
+
})().catch(console.error)
|
|
18
|
+
}, [src])
|
|
19
|
+
|
|
20
|
+
if (!Array.isArray(products) || products.length === 0) {
|
|
21
|
+
return null
|
|
22
|
+
}
|
|
23
|
+
|
|
24
|
+
const rows = useMemo(() => Object.keys(products[0]), [products])
|
|
25
|
+
const columnCount = useMemo(() => products.length + 1, [products])
|
|
26
|
+
const highlightIndex = useMemo(() => Number.parseInt(highlight, 10) + 1, [highlight])
|
|
27
|
+
|
|
28
|
+
return h(Box, { className: 'rounded-2xl bg-bga text-txa h-full p-6' },
|
|
29
|
+
h(Table, {
|
|
30
|
+
// Override styles to achieve custom look and feel of the table whilst retaining the basic table structure.
|
|
31
|
+
_style: id => `
|
|
32
|
+
${id} tr > th, ${id} tr > td {
|
|
33
|
+
vertical-align: middle;
|
|
34
|
+
}
|
|
35
|
+
${id} tr > th[scope=col], ${id} tr > td {
|
|
36
|
+
text-align: center
|
|
37
|
+
}
|
|
38
|
+
${id} tr > th[scope=row], ${id} tr > td {
|
|
39
|
+
width: calc(100% / ${columnCount});
|
|
40
|
+
}
|
|
41
|
+
${id} tr:nth-child(2) > * {
|
|
42
|
+
background-color: hsl(var(--color-txa));
|
|
43
|
+
color: hsl(var(--color-bga));
|
|
44
|
+
border-right: 1px solid hsla(var(--color-bga), 0.2);
|
|
45
|
+
}
|
|
46
|
+
${id} tr:nth-child(3) > * {
|
|
47
|
+
background-color: hsl(var(--color-bgb));
|
|
48
|
+
color: hsl(var(--color-txb));
|
|
49
|
+
border-right: 1px solid hsla(var(--color-txb), 0.2);
|
|
50
|
+
}
|
|
51
|
+
${id} tr:nth-child(n + 4) > td {
|
|
52
|
+
font-size: calc(20px * var(--font-scale));
|
|
53
|
+
font-weight: 700;
|
|
54
|
+
}
|
|
55
|
+
${id} tr > td:nth-child(${highlightIndex}) {
|
|
56
|
+
border-right: 4px solid hsl(var(--color-txa));
|
|
57
|
+
border-left: 4px solid hsl(var(--color-txa));
|
|
58
|
+
}
|
|
59
|
+
${id} tr:first-child > td:nth-child(${highlightIndex}) {
|
|
60
|
+
border-top: 4px solid hsl(var(--color-txa));
|
|
61
|
+
}
|
|
62
|
+
${id} tr:last-child > td:nth-child(${highlightIndex}) {
|
|
63
|
+
border-bottom: 4px solid hsl(var(--color-txa));
|
|
64
|
+
}
|
|
65
|
+
`,
|
|
66
|
+
children: [
|
|
67
|
+
h(ImageRow, { products }),
|
|
68
|
+
h(Row, { products, index: 2, colScope: true }), // Name
|
|
69
|
+
h(Row, { products, index: 3 }), // Type
|
|
70
|
+
rows.slice(4).map((_name, ii) => h(Row, { products, index: ii + 4 }))
|
|
71
|
+
]
|
|
72
|
+
})
|
|
73
|
+
)
|
|
74
|
+
}
|
|
75
|
+
|
|
76
|
+
function ImageRow ({ products }) {
|
|
77
|
+
return h('tr',
|
|
78
|
+
h('td', ''),
|
|
79
|
+
products.map(p => {
|
|
80
|
+
const link = p['Product Link']
|
|
81
|
+
return h('td',
|
|
82
|
+
h(link ? Link : 'div', { className: 'block', _model: { value: link } },
|
|
83
|
+
h(Asset, {
|
|
84
|
+
_tall: true,
|
|
85
|
+
_fit: 'contain',
|
|
86
|
+
_model: {
|
|
87
|
+
image: { src: p['Product Image'], alt: p['Product Name'] }
|
|
88
|
+
}
|
|
89
|
+
})
|
|
90
|
+
)
|
|
91
|
+
)
|
|
92
|
+
})
|
|
93
|
+
)
|
|
94
|
+
}
|
|
95
|
+
|
|
96
|
+
function Row ({ products, index, colScope = false }) {
|
|
97
|
+
const rows = Object.keys(products[0])
|
|
98
|
+
const name = rows[index]
|
|
99
|
+
|
|
100
|
+
return colScope
|
|
101
|
+
? h('tr',
|
|
102
|
+
h('th', { scope: 'row' }, name),
|
|
103
|
+
products.map(p => h('th', { scope: 'col' }, p[name]))
|
|
104
|
+
)
|
|
105
|
+
: h('tr',
|
|
106
|
+
h('th', { scope: 'row' }, name),
|
|
107
|
+
products.map(p => h('td', p[name]))
|
|
108
|
+
)
|
|
109
|
+
}
|
|
110
|
+
|
|
111
|
+
register(ComparisonChart, 'comparison-chart')
|
|
@@ -0,0 +1,248 @@
|
|
|
1
|
+
import { NAVIGATION_CLOSE } from '#acinguiux-preact/main/shared/icons.js'
|
|
2
|
+
import { isPublish } from '#acinguiux-preact/main/shared/wcm-mode.js'
|
|
3
|
+
import CCPA_ICON from './icons/ccpa.svg'
|
|
4
|
+
import INFO_ICON from './icons/info.svg'
|
|
5
|
+
import { getProviderData, notifyProvider } from './provider-onetrust.js'
|
|
6
|
+
|
|
7
|
+
const { h, preactHooks, matter, register, setConsent, getConsent } = globalThis.ami
|
|
8
|
+
const { Box, Link, Heading, Button, Logo, Popup, Input, Table, RichText, SVG, Icon } = matter
|
|
9
|
+
const { useState, useLayoutEffect } = preactHooks
|
|
10
|
+
|
|
11
|
+
function ConsentBanner ({ src, 'link-text': linkText, 'ccpa-icon': ccpaIcon, 'disable-list': disableList }) {
|
|
12
|
+
if (!src || !linkText) {
|
|
13
|
+
return null
|
|
14
|
+
}
|
|
15
|
+
|
|
16
|
+
const consent = getConsent()
|
|
17
|
+
const [state, setState] = useState({ popup: !consent && isPublish ? 'banner' : null, data: null })
|
|
18
|
+
|
|
19
|
+
// Load consent data - only if needed.
|
|
20
|
+
useLayoutEffect(() => {
|
|
21
|
+
if (state.popup && !state.data) {
|
|
22
|
+
getProviderData(src, disableList)
|
|
23
|
+
.then(data => setState(prevState => ({ ...prevState, data })))
|
|
24
|
+
.catch(console.error)
|
|
25
|
+
}
|
|
26
|
+
}, [state.popup])
|
|
27
|
+
|
|
28
|
+
return [
|
|
29
|
+
// Modify cookie preferences link.
|
|
30
|
+
h(Box,
|
|
31
|
+
h(Link, {
|
|
32
|
+
onClick: () => {
|
|
33
|
+
setState({ ...state, popup: 'settings' })
|
|
34
|
+
},
|
|
35
|
+
_model: { name: linkText, value: '#' },
|
|
36
|
+
_variant: 'simple',
|
|
37
|
+
className: 'text-sm',
|
|
38
|
+
children: h('span', { className: 'flex items-center gap-1' },
|
|
39
|
+
ccpaIcon && h('span',
|
|
40
|
+
h(SVG, { _model: { src: CCPA_ICON } })
|
|
41
|
+
),
|
|
42
|
+
h('span', linkText)
|
|
43
|
+
)
|
|
44
|
+
})
|
|
45
|
+
),
|
|
46
|
+
state.data && [
|
|
47
|
+
// Banner.
|
|
48
|
+
h(Popup, { _modal: false, _show: state.popup === 'banner', _layout: 'toast', 'aria-label': state.data.title },
|
|
49
|
+
h(Banner, {
|
|
50
|
+
data: state.data,
|
|
51
|
+
async onAccept () {
|
|
52
|
+
await setConsentAndNotifyProvider({ functional: true, statistics: true, preferences: true, marketing: true })
|
|
53
|
+
setState({ ...state, popup: null })
|
|
54
|
+
},
|
|
55
|
+
async onReject () {
|
|
56
|
+
await setConsentAndNotifyProvider({})
|
|
57
|
+
setState({ ...state, popup: null })
|
|
58
|
+
},
|
|
59
|
+
onSettings () {
|
|
60
|
+
setState({ ...state, popup: 'settings' })
|
|
61
|
+
}
|
|
62
|
+
|
|
63
|
+
})
|
|
64
|
+
),
|
|
65
|
+
// Settings
|
|
66
|
+
h(Popup, { _modal: true, _show: state.popup === 'settings', 'aria-label': state.data.title },
|
|
67
|
+
h(Settings, {
|
|
68
|
+
data: state.data,
|
|
69
|
+
onClose () {
|
|
70
|
+
setState({ ...state, popup: consent ? null : 'banner' })
|
|
71
|
+
},
|
|
72
|
+
async onReject () {
|
|
73
|
+
await setConsentAndNotifyProvider({})
|
|
74
|
+
setState({ ...state, popup: null })
|
|
75
|
+
},
|
|
76
|
+
onCookies () {
|
|
77
|
+
setState({ ...state, popup: 'cookies' })
|
|
78
|
+
},
|
|
79
|
+
async onSave (userConsent) {
|
|
80
|
+
await setConsentAndNotifyProvider(userConsent)
|
|
81
|
+
setState({ ...state, popup: null })
|
|
82
|
+
}
|
|
83
|
+
})
|
|
84
|
+
),
|
|
85
|
+
// Cookies
|
|
86
|
+
h(Popup, { _modal: true, _show: state.popup === 'cookies', 'aria-label': state.data.title },
|
|
87
|
+
h(Cookies, {
|
|
88
|
+
data: state.data,
|
|
89
|
+
onSettings () {
|
|
90
|
+
setState({ ...state, popup: 'settings' })
|
|
91
|
+
}
|
|
92
|
+
})
|
|
93
|
+
)
|
|
94
|
+
]
|
|
95
|
+
]
|
|
96
|
+
}
|
|
97
|
+
|
|
98
|
+
function Banner ({ data, onAccept, onReject, onSettings }) {
|
|
99
|
+
return [
|
|
100
|
+
h(Logo),
|
|
101
|
+
data.banner.title && h(Heading, { _level: 3 }, data.banner.title),
|
|
102
|
+
h(RichText, data.banner.text),
|
|
103
|
+
h('div', { className: 'flex justify-end lg:space-x-5 md:space-x-5 sm:flex-col sm:space-y-5' },
|
|
104
|
+
// Manage cookies.
|
|
105
|
+
h('div', { classList: 'flex justify-center items-center' },
|
|
106
|
+
h(Link, {
|
|
107
|
+
_variant: 'underline',
|
|
108
|
+
_model: { name: data.banner.buttonSettings, value: '#' },
|
|
109
|
+
onClick: event => {
|
|
110
|
+
event.preventDefault()
|
|
111
|
+
onSettings()
|
|
112
|
+
}
|
|
113
|
+
})
|
|
114
|
+
),
|
|
115
|
+
h('div', { className: 'flex gap-5 justify-end lg:flex-row-reverse md:flex-row-reverse sm:flex-col ' },
|
|
116
|
+
// Accept optional cookies.
|
|
117
|
+
h(Button, {
|
|
118
|
+
_model: { name: data.banner.buttonAccept },
|
|
119
|
+
className: 'sm:w-full',
|
|
120
|
+
onClick: event => {
|
|
121
|
+
event.preventDefault()
|
|
122
|
+
onAccept()
|
|
123
|
+
}
|
|
124
|
+
}),
|
|
125
|
+
// Reject optional cookies.
|
|
126
|
+
data.banner.buttonReject && h(Button, {
|
|
127
|
+
_model: { name: data.banner.buttonReject },
|
|
128
|
+
className: 'sm:w-full',
|
|
129
|
+
onClick: event => {
|
|
130
|
+
event.preventDefault()
|
|
131
|
+
onReject()
|
|
132
|
+
}
|
|
133
|
+
})
|
|
134
|
+
)
|
|
135
|
+
)
|
|
136
|
+
]
|
|
137
|
+
}
|
|
138
|
+
|
|
139
|
+
function Settings ({ data, onSave, onReject, onCookies, onClose }) {
|
|
140
|
+
const consent = getConsent() ?? {}
|
|
141
|
+
return [
|
|
142
|
+
h(LogoHeading, { closeLabel: data.settings.buttonClose, onClose }),
|
|
143
|
+
navigator.globalPrivacyControl && h('div', { className: 'flex items-center gap-2' },
|
|
144
|
+
h('span', { className: 'grow-0 shrink-0' },
|
|
145
|
+
h(Icon, INFO_ICON)
|
|
146
|
+
),
|
|
147
|
+
h('p', data.settings.gcpText)
|
|
148
|
+
),
|
|
149
|
+
data.settings.title && h(Heading, { _level: 3 }, data.settings.title),
|
|
150
|
+
h(RichText, data.settings.text),
|
|
151
|
+
h(Heading, { _level: 3 }, data.settings.categories),
|
|
152
|
+
h('div', { className: 'space-y-4', 'data-form': '' },
|
|
153
|
+
Object.values(data.groups).map(g => h('div',
|
|
154
|
+
h('label', { className: 'space-x-2 inline-flex items-center font-bold cursor-pointer' },
|
|
155
|
+
h(Input, { type: 'checkbox', name: g.name, checked: consent[g.name] ?? g.alwaysActive, value: true, disabled: g.alwaysActive }),
|
|
156
|
+
h('span', g.title)
|
|
157
|
+
),
|
|
158
|
+
h('p', g.text)
|
|
159
|
+
)),
|
|
160
|
+
h('div', { className: 'flex justify-end lg:space-x-5 md:space-x-5 sm:flex-col sm:space-y-5' },
|
|
161
|
+
// Cookie list.
|
|
162
|
+
data.cookies.length > 0 && h('div', { classList: 'flex justify-center items-center' },
|
|
163
|
+
h(Link, {
|
|
164
|
+
_variant: 'underline',
|
|
165
|
+
_model: { name: data.list.title, value: '#' },
|
|
166
|
+
onClick: event => {
|
|
167
|
+
event.preventDefault()
|
|
168
|
+
onCookies()
|
|
169
|
+
}
|
|
170
|
+
})
|
|
171
|
+
),
|
|
172
|
+
// Save preferences.
|
|
173
|
+
h(Button, {
|
|
174
|
+
_model: { name: data.settings.buttonConfirm },
|
|
175
|
+
className: 'sm:w-full',
|
|
176
|
+
onClick: event => {
|
|
177
|
+
event.preventDefault()
|
|
178
|
+
const inputs = [...event.currentTarget.closest('[data-form]').querySelectorAll('input')]
|
|
179
|
+
const userConsent = inputs.reduce((obj, input) => {
|
|
180
|
+
obj[input.name] = input.checked
|
|
181
|
+
return obj
|
|
182
|
+
}, {})
|
|
183
|
+
onSave(userConsent)
|
|
184
|
+
}
|
|
185
|
+
}),
|
|
186
|
+
// Reject optional cookies.
|
|
187
|
+
data.banner.buttonReject && h(Button, {
|
|
188
|
+
_model: { name: data.settings.buttonReject },
|
|
189
|
+
className: 'sm:w-full',
|
|
190
|
+
onClick: event => {
|
|
191
|
+
event.preventDefault()
|
|
192
|
+
onReject()
|
|
193
|
+
}
|
|
194
|
+
})
|
|
195
|
+
)
|
|
196
|
+
)
|
|
197
|
+
]
|
|
198
|
+
}
|
|
199
|
+
|
|
200
|
+
function Cookies ({ data, onSettings }) {
|
|
201
|
+
return data.cookies.length > 0 && [
|
|
202
|
+
h(LogoHeading, { closeLabel: data.banner.buttonSettings, onClose: onSettings }),
|
|
203
|
+
h(Heading, { _level: 3 }, data.list.title),
|
|
204
|
+
h(RichText, data.list.text),
|
|
205
|
+
h(Table,
|
|
206
|
+
// Headers
|
|
207
|
+
h('tr', Object.keys(data.cookies[0]).map(k => h('th', k))),
|
|
208
|
+
data.groups.map(g => [
|
|
209
|
+
// Group section
|
|
210
|
+
h('tr',
|
|
211
|
+
h('td', { className: 'font-bold', colspan: Object.keys(data.cookies[0]).length }, g.title)
|
|
212
|
+
),
|
|
213
|
+
g.cookies.map(c => h('tr',
|
|
214
|
+
Object.values(c).map(v => h('td', v))
|
|
215
|
+
))
|
|
216
|
+
])
|
|
217
|
+
)
|
|
218
|
+
]
|
|
219
|
+
}
|
|
220
|
+
|
|
221
|
+
function LogoHeading ({ closeLabel, onClose }) {
|
|
222
|
+
return h('div', { className: 'flex gap-2' },
|
|
223
|
+
h('div', { className: 'grow' },
|
|
224
|
+
h(Logo)
|
|
225
|
+
),
|
|
226
|
+
onClose && h('div', { className: 'shrink' },
|
|
227
|
+
h(Button, {
|
|
228
|
+
_variant: 'plain',
|
|
229
|
+
_textless: true,
|
|
230
|
+
_size: 'sm',
|
|
231
|
+
_model: { name: closeLabel, icon: NAVIGATION_CLOSE },
|
|
232
|
+
onClick: onClose
|
|
233
|
+
})
|
|
234
|
+
)
|
|
235
|
+
)
|
|
236
|
+
}
|
|
237
|
+
|
|
238
|
+
async function setConsentAndNotifyProvider (consent) {
|
|
239
|
+
const hasConsentedBefore = getConsent() !== null
|
|
240
|
+
setConsent(consent)
|
|
241
|
+
await notifyProvider(consent)
|
|
242
|
+
|
|
243
|
+
if (hasConsentedBefore) {
|
|
244
|
+
location.reload()
|
|
245
|
+
}
|
|
246
|
+
}
|
|
247
|
+
|
|
248
|
+
register(ConsentBanner, 'consent-banner')
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
<svg style="overflow: visible" width="48" height="24" version="1.1" xmlns="http://www.w3.org/2000/svg">
|
|
2
|
+
<path d="m13.586 20.286h9.3143l4.2572-16.571h-13.571c-4.3857 0-7.9428 3.7143-7.9428 8.2857 0 4.5715 3.5571 8.2857 7.9428 8.2857z" style="fill-rule:evenodd;fill:#fff;stroke-width:1.4284"/>
|
|
3
|
+
<path d="m34.414 2h-20.829c-5.3429 0-9.5857 4.4286-9.5857 10 0 5.5715 4.2428 10 9.5857 10h20.829c5.3428 0 9.5857-4.4285 9.5857-10 0-5.5714-4.3857-10-9.5857-10zm-28.771 10c0-4.5714 3.5571-8.2857 7.9428-8.2857h13.571l-4.2428 16.571h-9.3286c-4.3857 0-7.9428-3.7142-7.9428-8.2857z" style="fill-rule:evenodd;fill:#06f;stroke-width:1.4284"/>
|
|
4
|
+
<path d="m37.157 7.7143c0.27137 0.28572 0.27137 0.85717 0 1.1429l-2.8715 3.1428 3.0143 3.1428c0.27147 0.28569 0.27147 0.85716 0 1.1428-0.27147 0.28578-0.82853 0.28578-1.1 0l-3.0143-3.1428-3.0142 3.1428c-0.27147 0.28578-0.82863 0.28578-1.1 0-0.27147-0.28569-0.27147-0.85716 0-1.1428l2.8714-3.1428-3.0143-3.1428c-0.27137-0.2857-0.27137-0.85715 0-1.1429 0.27147-0.28571 0.82863-0.28571 1.1 0l3.0143 3.1429 3.0143-3.1429c0.27137-0.28571 0.82853-0.28571 1.1 0z" style="fill:#fff;stroke-width:1.4284"/>
|
|
5
|
+
<path d="m20.843 7.8459c0.27147 0.28572 0.41431 0.85716 0.14285 1.1429l-5.7571 7c-0.14285 0.14284-0.2714 0.28568-0.41425 0.28568-0.27145 0.14285-0.68575 0.14285-0.95715-0.14284l-3.0143-3.1428c-0.2714-0.28569-0.2714-0.85716 0-1.1428 0.27145-0.28569 0.8286-0.28569 1.1 0l2.4715 2.4285 5.2-6.4285c0.2714-0.2857 0.82855-0.2857 1.2285 0z" style="fill:#06f;stroke-width:1.4284"/>
|
|
6
|
+
</svg>
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="#404040"><path fill-rule="evenodd" d="M20 12a8 8 0 1 1-16 0 8 8 0 0 1 16 0m2 0c0 5.523-4.477 10-10 10S2 17.523 2 12 6.477 2 12 2s10 4.477 10 10M11.5 9a.5.5 0 0 1-.5-.5v-1a.5.5 0 0 1 .5-.5h1a.5.5 0 0 1 .5.5v1a.5.5 0 0 1-.5.5zm0 8a.5.5 0 0 1-.5-.5v-5a.5.5 0 0 1 .5-.5h1a.5.5 0 0 1 .5.5v5a.5.5 0 0 1-.5.5z" clip-rule="evenodd"/></svg>
|
|
@@ -0,0 +1,131 @@
|
|
|
1
|
+
const { getUserId } = globalThis.ami
|
|
2
|
+
|
|
3
|
+
const instance = {
|
|
4
|
+
consentApi: null,
|
|
5
|
+
requestInformation: null,
|
|
6
|
+
consentGroups: {
|
|
7
|
+
C0001: { name: 'functional', id: null },
|
|
8
|
+
C0002: { name: 'statistics', id: null },
|
|
9
|
+
C0004: { name: 'preferences', id: null },
|
|
10
|
+
C0005: { name: 'marketing', id: null }
|
|
11
|
+
}
|
|
12
|
+
}
|
|
13
|
+
|
|
14
|
+
export async function getProviderData (src, disableList) {
|
|
15
|
+
let res = await fetch(src)
|
|
16
|
+
const otConfig = await res.json()
|
|
17
|
+
|
|
18
|
+
const ruleset = otConfig.RuleSet[0]
|
|
19
|
+
const rulesetId = ruleset.Id
|
|
20
|
+
const pageLocale = document.documentElement.lang.toLowerCase()
|
|
21
|
+
const pageLanguage = pageLocale.substring(0, pageLocale.lastIndexOf('-'))
|
|
22
|
+
const availableLocales = ruleset.LanguageSwitcherPlaceholder
|
|
23
|
+
const language = availableLocales[pageLocale] ?? availableLocales[pageLanguage] ?? availableLocales.default
|
|
24
|
+
const configSrc = src.replace(/^(.*)\/([a-z0-9-]+)\.json$/, `$1/${rulesetId}/${language}.json`)
|
|
25
|
+
|
|
26
|
+
res = await fetch(configSrc)
|
|
27
|
+
const otData = await res.json()
|
|
28
|
+
|
|
29
|
+
instance.consentApi = otData.CommonData.ConsentIntegration.ConsentApi
|
|
30
|
+
instance.requestInformation = otData.CommonData.ConsentIntegration.RequestInformation
|
|
31
|
+
|
|
32
|
+
const domainData = otData.DomainData
|
|
33
|
+
const groups = []
|
|
34
|
+
|
|
35
|
+
for (const group of domainData.Groups) {
|
|
36
|
+
if (!group.ShowInPopup) {
|
|
37
|
+
continue
|
|
38
|
+
}
|
|
39
|
+
|
|
40
|
+
const name = instance.consentGroups[group.OptanonGroupId]?.name
|
|
41
|
+
if (!name) {
|
|
42
|
+
console.warn(`Unsupported group: [${group.OptanonGroupId}] ${group.GroupName}.`)
|
|
43
|
+
continue
|
|
44
|
+
}
|
|
45
|
+
|
|
46
|
+
instance.consentGroups[group.OptanonGroupId].id = group.PurposeId
|
|
47
|
+
|
|
48
|
+
groups.push({
|
|
49
|
+
name,
|
|
50
|
+
title: group.GroupName,
|
|
51
|
+
text: group.GroupDescription,
|
|
52
|
+
alwaysActive: group.Status === 'always active',
|
|
53
|
+
cookies: [
|
|
54
|
+
// First party cookies.
|
|
55
|
+
...group.FirstPartyCookies.map(c => ({
|
|
56
|
+
[domainData.CategoriesText]: c.Host,
|
|
57
|
+
[domainData.CookiesText]: c.Name,
|
|
58
|
+
[domainData.CookiesUsedText]: domainData.CookieFirstPartyText,
|
|
59
|
+
[domainData.CookiesDescText]: c.description
|
|
60
|
+
})),
|
|
61
|
+
// Third party cookies.
|
|
62
|
+
...group.Hosts.reduce((acc, host) => {
|
|
63
|
+
acc.push(...host.Cookies.map(c => ({
|
|
64
|
+
[domainData.CategoriesText]: c.Host,
|
|
65
|
+
[domainData.CookiesText]: c.Name,
|
|
66
|
+
[domainData.CookiesUsedText]: domainData.CookieThirdPartyText,
|
|
67
|
+
[domainData.CookiesDescText]: c.description
|
|
68
|
+
})))
|
|
69
|
+
return acc
|
|
70
|
+
}, [])
|
|
71
|
+
]
|
|
72
|
+
})
|
|
73
|
+
}
|
|
74
|
+
|
|
75
|
+
const cookies = disableList ? [] : groups.reduce((acc, group) => [...acc, ...group.cookies], [])
|
|
76
|
+
|
|
77
|
+
return {
|
|
78
|
+
banner: {
|
|
79
|
+
title: domainData.BannerTitle,
|
|
80
|
+
text: domainData.AlertNoticeText,
|
|
81
|
+
buttonAccept: domainData.AlertAllowCookiesText,
|
|
82
|
+
buttonReject: domainData.BannerShowRejectAllButton ? domainData.BannerRejectAllButtonText : null,
|
|
83
|
+
buttonSettings: domainData.AlertMoreInfoText
|
|
84
|
+
},
|
|
85
|
+
settings: {
|
|
86
|
+
title: domainData.MainText,
|
|
87
|
+
categories: domainData.PreferenceCenterManagePreferencesText,
|
|
88
|
+
text: domainData.MainInfoText,
|
|
89
|
+
buttonConfirm: domainData.PreferenceCenterConfirmText,
|
|
90
|
+
buttonReject: domainData.BannerRejectAllButtonText,
|
|
91
|
+
buttonClose: domainData.AlertCloseText,
|
|
92
|
+
buttonCookies: domainData.CookieListTitle,
|
|
93
|
+
gcpText: domainData.PCOptOutSignalText
|
|
94
|
+
},
|
|
95
|
+
list: {
|
|
96
|
+
title: domainData.CookieListTitle,
|
|
97
|
+
text: domainData.CookieListDescription
|
|
98
|
+
},
|
|
99
|
+
groups,
|
|
100
|
+
cookies
|
|
101
|
+
}
|
|
102
|
+
}
|
|
103
|
+
|
|
104
|
+
export async function notifyProvider (consent = {}) {
|
|
105
|
+
if (!instance.requestInformation) {
|
|
106
|
+
return null
|
|
107
|
+
}
|
|
108
|
+
|
|
109
|
+
const [userId] = getUserId()
|
|
110
|
+
const payload = {
|
|
111
|
+
customPayload: { Interaction: 1, AddDefaultInteraction: true },
|
|
112
|
+
dsDataElements: { UserAgent: navigator.userAgent },
|
|
113
|
+
identifier: userId,
|
|
114
|
+
identifierType: 'User ID',
|
|
115
|
+
isAnonymous: true,
|
|
116
|
+
purposes: Object.values(instance.consentGroups).map(g => {
|
|
117
|
+
let choice = 'OPT_OUT'
|
|
118
|
+
if (g.name === 'functional') {
|
|
119
|
+
choice = 'NO_CHOICE'
|
|
120
|
+
} else if (consent[g.name]) {
|
|
121
|
+
choice = 'CONFIRMED'
|
|
122
|
+
}
|
|
123
|
+
|
|
124
|
+
return { Id: g.id, TransactionType: choice }
|
|
125
|
+
}),
|
|
126
|
+
requestInformation: instance.requestInformation,
|
|
127
|
+
test: false
|
|
128
|
+
}
|
|
129
|
+
|
|
130
|
+
return fetch(instance.consentApi, { method: 'POST', body: JSON.stringify(payload) })
|
|
131
|
+
}
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
export const google = text => `<?xml version="1.0" encoding="UTF-8"?>
|
|
2
|
+
<svg width="200" version="1.1" viewBox="0 0 180 53.333" xmlns="http://www.w3.org/2000/svg">
|
|
3
|
+
<g>
|
|
4
|
+
<path transform="matrix(1.3333 0 0 -1.3333 173.33 53.333)" d="m0 0h-125c-2.75 0-5 2.25-5 5v30c0 2.75 2.25 5 5 5h125c2.75 0 5-2.25 5-5v-30c0-2.75-2.25-5-5-5"/>
|
|
5
|
+
<path transform="matrix(1.3333 0 0 -1.3333 173.33 .000266)" d="m0 0h-125c-2.75 0-5-2.25-5-5v-30c0-2.75 2.25-5 5-5h125c2.75 0 5 2.25 5 5v30c0 2.75-2.25 5-5 5m0-0.8c2.316 0 4.2-1.884 4.2-4.2v-30c0-2.316-1.884-4.2-4.2-4.2h-125c-2.316 0-4.2 1.884-4.2 4.2v30c0 2.316 1.884 4.2 4.2 4.2z" fill="#a6a6a6"/>
|
|
6
|
+
<path transform="matrix(1.3333 0 0 -1.3333 -13.333 66.667)" d="m116.94 20h1.866v12.501h-1.866zm16.807 7.998-2.139-5.42h-0.064l-2.22 5.42h-2.01l3.329-7.575-1.897-4.214h1.945l5.131 11.789zm-10.582-6.578c-0.612 0-1.464 0.305-1.464 1.062 0 0.964 1.061 1.334 1.978 1.334 0.82 0 1.207-0.177 1.705-0.418-0.145-1.158-1.142-1.978-2.219-1.978m0.225 6.851c-1.351 0-2.751-0.595-3.329-1.914l1.656-0.691c0.354 0.691 1.013 0.917 1.705 0.917 0.965 0 1.946-0.579 1.962-1.609v-0.128c-0.338 0.193-1.061 0.482-1.946 0.482-1.785 0-3.603-0.981-3.603-2.814 0-1.673 1.464-2.751 3.104-2.751 1.255 0 1.947 0.563 2.381 1.223h0.064v-0.965h1.801v4.793c0 2.219-1.656 3.457-3.795 3.457m-11.532-1.795h-2.654v4.285h2.654c1.395 0 2.187-1.155 2.187-2.142 0-0.969-0.792-2.143-2.187-2.143m-0.048 6.025h-4.471v-12.501h1.865v4.736h2.606c2.068 0 4.101 1.498 4.101 3.883s-2.033 3.882-4.101 3.882m-24.381-11.083c-1.289 0-2.368 1.079-2.368 2.561 0 1.498 1.079 2.594 2.368 2.594 1.273 0 2.271-1.096 2.271-2.594 0-1.482-0.998-2.561-2.271-2.561m2.143 5.88h-0.065c-0.419 0.499-1.224 0.95-2.239 0.95-2.127 0-4.076-1.868-4.076-4.269 0-2.384 1.949-4.237 4.076-4.237 1.015 0 1.82 0.451 2.239 0.967h0.065v-0.613c0-1.627-0.87-2.497-2.272-2.497-1.144 0-1.853 0.822-2.143 1.515l-1.627-0.677c0.467-1.128 1.708-2.513 3.77-2.513 2.191 0 4.044 1.289 4.044 4.43v7.637h-1.772zm3.061-7.298h1.869v12.502h-1.869zm4.623 4.124c-0.048 1.643 1.273 2.481 2.223 2.481 0.742 0 1.37-0.37 1.579-0.902zm5.8 1.418c-0.354 0.95-1.434 2.706-3.641 2.706-2.191 0-4.011-1.723-4.011-4.253 0-2.384 1.804-4.253 4.22-4.253 1.95 0 3.078 1.192 3.545 1.885l-1.45 0.967c-0.483-0.709-1.144-1.176-2.095-1.176-0.95 0-1.627 0.435-2.062 1.288l5.687 2.353zm-45.308 1.401v-1.804h4.317c-0.129-1.015-0.467-1.756-0.982-2.271-0.629-0.629-1.612-1.322-3.335-1.322-2.659 0-4.737 2.143-4.737 4.801 0 2.659 2.078 4.801 4.737 4.801 1.434 0 2.481-0.564 3.254-1.289l1.273 1.273c-1.08 1.031-2.513 1.821-4.527 1.821-3.641 0-6.702-2.965-6.702-6.606s3.061-6.605 6.702-6.605c1.965 0 3.447 0.645 4.607 1.853 1.193 1.192 1.563 2.867 1.563 4.221 0 0.419-0.032 0.805-0.097 1.127zm11.079-5.525c-1.289 0-2.401 1.063-2.401 2.577 0 1.531 1.112 2.578 2.401 2.578 1.288 0 2.4-1.047 2.4-2.578 0-1.514-1.112-2.577-2.4-2.577m0 6.83c-2.353 0-4.27-1.788-4.27-4.253 0-2.449 1.917-4.253 4.27-4.253 2.352 0 4.269 1.804 4.269 4.253 0 2.465-1.917 4.253-4.269 4.253m9.313-6.83c-1.289 0-2.401 1.063-2.401 2.577 0 1.531 1.112 2.578 2.401 2.578s2.4-1.047 2.4-2.578c0-1.514-1.111-2.577-2.4-2.577m0 6.83c-2.352 0-4.269-1.788-4.269-4.253 0-2.449 1.917-4.253 4.269-4.253s4.269 1.804 4.269 4.253c0 2.465-1.917 4.253-4.269 4.253" fill="#fff"/>
|
|
7
|
+
<path transform="matrix(1.3333 0 0 -1.3333 27.623 25.899)" d="m0 0-10.647-11.3c1e-3 -2e-3 1e-3 -5e-3 2e-3 -7e-3 0.327-1.227 1.447-2.13 2.777-2.13 0.532 0 1.031 0.144 1.459 0.396l0.034 0.02 11.984 6.915z" fill="#ea4335"/>
|
|
8
|
+
<path transform="matrix(1.3333 0 0 -1.3333 41.984 23.333)" d="m0 0-0.01 7e-3 -5.174 2.999-5.829-5.187 5.85-5.848 5.146 2.969c0.902 0.488 1.515 1.439 1.515 2.535 0 1.09-0.604 2.036-1.498 2.525" fill="#fbbc04"/>
|
|
9
|
+
<path transform="matrix(1.3333 0 0 -1.3333 13.427 12.37)" d="m0 0c-0.064-0.236-0.098-0.484-0.098-0.74v-19.968c0-0.256 0.034-0.504 0.099-0.739l11.012 11.011z" fill="#4285f4"/>
|
|
10
|
+
<path transform="matrix(1.3333 0 0 -1.3333 27.728 26.668)" d="m0 0 5.51 5.509-11.97 6.94c-0.435 0.261-0.943 0.411-1.486 0.411-1.33 0-2.452-0.905-2.779-2.133 0-1e-3 -1e-3 -2e-3 -1e-3 -3e-3z" fill="#34a853"/>
|
|
11
|
+
</g>
|
|
12
|
+
<text x="54.212109" y="17.529634" fill="#f9f9f9" font-family="Arial" font-size="11px" font-weight="bold" letter-spacing=".2px" xml:space="preserve"><tspan x="54.212109" y="17.529634" font-family="Arial" font-size="11px" font-weight="bold" letter-spacing=".2px">${text.toUpperCase()}</tspan></text>
|
|
13
|
+
</svg>
|
|
14
|
+
`
|
|
15
|
+
|
|
16
|
+
export const apple = text => `<?xml version="1.0" encoding="UTF-8"?>
|
|
17
|
+
<svg id="livetype" width="200" version="1.1" viewBox="0 0 119.66 40" xmlns="http://www.w3.org/2000/svg">
|
|
18
|
+
<path d="m110.13 0h-100.6c-0.3667 0-0.729 0-1.0947 2e-3 -0.30615 2e-3 -0.60986 0.00781-0.91895 0.0127a13.215 13.215 0 0 0-2.0039 0.17671 6.6651 6.6651 0 0 0-1.9009 0.627 6.4378 6.4378 0 0 0-1.6186 1.1787 6.2584 6.2584 0 0 0-1.1782 1.6211 6.6012 6.6012 0 0 0-0.625 1.9033 12.993 12.993 0 0 0-0.1792 2.002c-0.00928 0.3066-0.01026 0.61422-0.01515 0.92086v23.114c0.00489 0.3105 0.00587 0.6113 0.01515 0.9219a12.992 12.992 0 0 0 0.1792 2.0019 6.5876 6.5876 0 0 0 0.625 1.9043 6.2078 6.2078 0 0 0 1.1782 1.6143 6.2744 6.2744 0 0 0 1.6186 1.1787 6.7008 6.7008 0 0 0 1.9009 0.6308 13.455 13.455 0 0 0 2.0039 0.1768c0.30909 0.0068 0.6128 0.0107 0.91895 0.0107 0.36572 2e-3 0.72805 2e-3 1.0947 2e-3h100.6c0.3594 0 0.7246 0 1.084-2e-3 0.3047 0 0.6172-0.0039 0.9219-0.0107a13.279 13.279 0 0 0 2-0.1768 6.8043 6.8043 0 0 0 1.9082-0.6308 6.2774 6.2774 0 0 0 1.6172-1.1787 6.3948 6.3948 0 0 0 1.1816-1.6143 6.6041 6.6041 0 0 0 0.6191-1.9043 13.506 13.506 0 0 0 0.1856-2.0019c4e-3 -0.3106 4e-3 -0.6114 4e-3 -0.9219 8e-3 -0.3633 8e-3 -0.7246 8e-3 -1.0938v-20.929c0-0.36621 0-0.72949-8e-3 -1.0918 0-0.30664 0-0.61426-4e-3 -0.9209a13.507 13.507 0 0 0-0.1856-2.002 6.6177 6.6177 0 0 0-0.6191-1.9033 6.4662 6.4662 0 0 0-2.7988-2.7998 6.7675 6.7675 0 0 0-1.9082-0.627 13.044 13.044 0 0 0-2-0.17676c-0.3047-0.00488-0.6172-0.01074-0.9219-0.01269-0.3594-2e-3 -0.7246-2e-3 -1.084-2e-3z" fill="#a6a6a6"/>
|
|
19
|
+
<path d="m8.4448 39.125c-0.30468 0-0.602-0.0039-0.90429-0.0107a12.687 12.687 0 0 1-1.8691-0.1631 5.8838 5.8838 0 0 1-1.6567-0.5479 5.4057 5.4057 0 0 1-1.397-1.0166 5.3208 5.3208 0 0 1-1.0205-1.3965 5.7219 5.7219 0 0 1-0.543-1.6572 12.414 12.414 0 0 1-0.1665-1.875c-0.00634-0.2109-0.01464-0.9131-0.01464-0.9131v-23.101s0.00884-0.69141 0.01469-0.89454a12.37 12.37 0 0 1 0.16553-1.8721 5.7555 5.7555 0 0 1 0.54346-1.6621 5.3735 5.3735 0 0 1 1.0151-1.398 5.5654 5.5654 0 0 1 1.4023-1.0225 5.8231 5.8231 0 0 1 1.6533-0.54394 12.586 12.586 0 0 1 1.8755-0.16406l0.90232-0.01221h102.77l0.9131 0.0127a12.385 12.385 0 0 1 1.8584 0.16259 5.9383 5.9383 0 0 1 1.6709 0.54785 5.5937 5.5937 0 0 1 2.415 2.4199 5.7627 5.7627 0 0 1 0.5352 1.6489 12.995 12.995 0 0 1 0.1738 1.8872c3e-3 0.2832 3e-3 0.5874 3e-3 0.89014 8e-3 0.375 8e-3 0.73193 8e-3 1.0918v20.929c0 0.3633 0 0.7178-8e-3 1.0752 0 0.3252 0 0.6231-4e-3 0.9297a12.731 12.731 0 0 1-0.1709 1.8535 5.739 5.739 0 0 1-0.54 1.67 5.4803 5.4803 0 0 1-1.0156 1.3857 5.4129 5.4129 0 0 1-1.3994 1.0225 5.8617 5.8617 0 0 1-1.668 0.5498 12.542 12.542 0 0 1-1.8692 0.1631c-0.2929 0.0068-0.5996 0.0107-0.8974 0.0107l-1.084 2e-3z"/>
|
|
20
|
+
<g data-name="<Group>">
|
|
21
|
+
<g fill="#fff" data-name="<Group>">
|
|
22
|
+
<path id="_Path_" d="m24.769 20.301a4.9488 4.9488 0 0 1 2.3566-4.1521 5.0657 5.0657 0 0 0-3.9912-2.1577c-1.6792-0.17626-3.3072 1.0048-4.1629 1.0048-0.87227 0-2.1898-0.98733-3.6085-0.95814a5.3153 5.3153 0 0 0-4.4729 2.7279c-1.934 3.3484-0.49141 8.2695 1.3612 10.976 0.9269 1.3254 2.0102 2.8058 3.4276 2.7533 1.3871-0.05753 1.9051-0.88448 3.5794-0.88448 1.6588 0 2.1448 0.88448 3.591 0.8511 1.4884-0.02416 2.4261-1.3312 3.3205-2.6691a10.962 10.962 0 0 0 1.5184-3.0925 4.782 4.782 0 0 1-2.9192-4.3992z" data-name="<Path>"/>
|
|
23
|
+
<path d="m22.037 12.211a4.8725 4.8725 0 0 0 1.1145-3.4906 4.9575 4.9575 0 0 0-3.2076 1.6596 4.6363 4.6363 0 0 0-1.1437 3.3614 4.099 4.099 0 0 0 3.2368-1.5304z" data-name="<Path>"/>
|
|
24
|
+
</g>
|
|
25
|
+
</g>
|
|
26
|
+
<g fill="#fff">
|
|
27
|
+
<path d="m42.302 27.14h-4.7334l-1.1367 3.3564h-2.0049l4.4834-12.418h2.083l4.4834 12.418h-2.0391zm-4.2432-1.5488h3.752l-1.8496-5.4473h-0.05176z"/>
|
|
28
|
+
<path d="m55.16 25.97c0 2.8135-1.5059 4.6211-3.7783 4.6211a3.0693 3.0693 0 0 1-2.8486-1.584h-0.043v4.4844h-1.8584v-12.049h1.7989v1.5059h0.03418a3.2116 3.2116 0 0 1 2.8828-1.6006c2.2978 1e-5 3.8125 1.8164 3.8125 4.6221zm-1.9102 0c0-1.833-0.94727-3.0381-2.3926-3.0381-1.4199 0-2.375 1.2305-2.375 3.0381 0 1.8242 0.95508 3.0459 2.375 3.0459 1.4453 0 2.3926-1.1963 2.3926-3.0459z"/>
|
|
29
|
+
<path d="m65.125 25.97c0 2.8135-1.5059 4.6211-3.7783 4.6211a3.0693 3.0693 0 0 1-2.8486-1.584h-0.043v4.4844h-1.8584v-12.049h1.7988v1.5059h0.03418a3.2116 3.2116 0 0 1 2.8828-1.6006c2.2979 0 3.8125 1.8164 3.8125 4.6221zm-1.9102 0c0-1.833-0.94727-3.0381-2.3926-3.0381-1.4199 0-2.375 1.2305-2.375 3.0381 0 1.8242 0.95508 3.0459 2.375 3.0459 1.4453 0 2.3926-1.1963 2.3926-3.0459z"/>
|
|
30
|
+
<path d="m71.71 27.036c0.1377 1.2314 1.334 2.04 2.9688 2.04 1.5664 0 2.6934-0.80859 2.6934-1.919 0-0.96387-0.67969-1.541-2.2891-1.9365l-1.6094-0.3877c-2.2803-0.55078-3.3389-1.6172-3.3389-3.3477 0-2.1426 1.8672-3.6143 4.5186-3.6143 2.624 0 4.4228 1.4717 4.4834 3.6143h-1.876c-0.1123-1.2393-1.1367-1.9873-2.6338-1.9873s-2.5215 0.75684-2.5215 1.8584c0 0.87793 0.6543 1.3945 2.2549 1.79l1.3682 0.33594c2.5478 0.60254 3.6064 1.626 3.6064 3.4424 0 2.3232-1.8506 3.7783-4.794 3.7783-2.7539 0-4.6133-1.4209-4.7334-3.667z"/>
|
|
31
|
+
<path d="m83.346 19.3v2.1426h1.7217v1.4717h-1.7217v4.9912c0 0.77539 0.34473 1.1367 1.1016 1.1367a5.8075 5.8075 0 0 0 0.61133-0.043v1.4629a5.1035 5.1035 0 0 1-1.0322 0.08594c-1.833 0-2.5478-0.68848-2.5478-2.4443v-5.1894h-1.3164v-1.4717h1.3164v-2.1426z"/>
|
|
32
|
+
<path d="m86.065 25.97c0-2.8486 1.6777-4.6387 4.294-4.6387 2.625 0 4.2949 1.79 4.2949 4.6387 0 2.8564-1.6611 4.6387-4.2949 4.6387-2.6329 0-4.294-1.7822-4.294-4.6387zm6.6953 0c0-1.9541-0.89551-3.1074-2.4014-3.1074s-2.4004 1.1621-2.4004 3.1074c0 1.9619 0.89453 3.1064 2.4004 3.1064s2.4013-1.1445 2.4013-3.1064z"/>
|
|
33
|
+
<path d="m96.186 21.442h1.7725v1.541h0.043a2.1594 2.1594 0 0 1 2.1777-1.6357 2.8662 2.8662 0 0 1 0.63672 0.06934v1.7383a2.5979 2.5979 0 0 0-0.835-0.1123 1.8726 1.8726 0 0 0-1.9365 2.083v5.3701h-1.8584z"/>
|
|
34
|
+
<path d="m109.38 27.837c-0.25 1.6436-1.8506 2.7715-3.8984 2.7715-2.6338 0-4.2686-1.7646-4.2686-4.5957 0-2.8398 1.6436-4.6816 4.1904-4.6816 2.5049 0 4.0801 1.7207 4.0801 4.4658v0.63672h-6.3945v0.1123a2.358 2.358 0 0 0 2.4356 2.5644 2.0483 2.0483 0 0 0 2.0908-1.2734zm-6.2822-2.7022h4.5264a2.1773 2.1773 0 0 0-2.2207-2.2978 2.292 2.292 0 0 0-2.3057 2.2979z"/>
|
|
35
|
+
</g>
|
|
36
|
+
<text x="33.771507" y="14.804743" fill="#ffffff" font-family="Arial" font-size="8.5px" letter-spacing=".5px" xml:space="preserve"><tspan x="33.771507" y="14.804743">${text}</tspan></text>
|
|
37
|
+
</svg>`
|