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.
Files changed (313) hide show
  1. package/package.json +56 -0
  2. package/src/content/themes/theme-acinguiux-amg/theme-acinguiux-amg.css +23 -0
  3. package/src/content/themes/theme-acinguiux-cafe/theme-acinguiux-cafe.css +47 -0
  4. package/src/content/themes/theme-acinguiux-energy/theme-acinguiux-energy.css +45 -0
  5. package/src/content/themes/theme-acinguiux-livewire/theme-acinguiux-livewire.css +22 -0
  6. package/src/content/themes/theme-acinguiux-livewire-italy/theme-acinguiux-livewire-italy.css +22 -0
  7. package/src/content/themes/theme-acinguiux-recharge/theme-acinguiux-recharge.css +49 -0
  8. package/src/content/themes/theme-allon/theme-allon.css +25 -0
  9. package/src/content/themes/theme-atlas/theme-atlas.css +31 -0
  10. package/src/content/themes/theme-aurvana/resources/favicon/apple-touch-icon.png +0 -0
  11. package/src/content/themes/theme-aurvana/resources/favicon/favico.ico +0 -0
  12. package/src/content/themes/theme-aurvana/resources/favicon/favicon-96x96.png +0 -0
  13. package/src/content/themes/theme-aurvana/resources/favicon/favicon.ico +0 -0
  14. package/src/content/themes/theme-aurvana/resources/favicon/favicon.png +0 -0
  15. package/src/content/themes/theme-aurvana/resources/favicon/favicon.svg +13 -0
  16. package/src/content/themes/theme-aurvana/resources/favicon/google-touch-icon.png +0 -0
  17. package/src/content/themes/theme-aurvana/resources/favicon/manifest.json +14 -0
  18. package/src/content/themes/theme-aurvana/resources/favicon/site.webmanifest +21 -0
  19. package/src/content/themes/theme-aurvana/resources/favicon/web-app-manifest-192x192.png +0 -0
  20. package/src/content/themes/theme-aurvana/resources/favicon/web-app-manifest-512x512.png +0 -0
  21. package/src/content/themes/theme-aurvana/theme-aurvana.css +49 -0
  22. package/src/content/themes/theme-base/theme-base.css +49 -0
  23. package/src/content/themes/theme-base2/resources/favicon/android-chrome-192x192.png +0 -0
  24. package/src/content/themes/theme-base2/resources/favicon/android-chrome-512x512.png +0 -0
  25. package/src/content/themes/theme-base2/resources/favicon/apple-touch-icon.png +0 -0
  26. package/src/content/themes/theme-base2/resources/favicon/favico.ico +0 -0
  27. package/src/content/themes/theme-base2/resources/favicon/favicon-16x16.png +0 -0
  28. package/src/content/themes/theme-base2/resources/favicon/favicon-32x32.png +0 -0
  29. package/src/content/themes/theme-base2/resources/favicon/favicon-96x96.png +0 -0
  30. package/src/content/themes/theme-base2/resources/favicon/favicon.ico +0 -0
  31. package/src/content/themes/theme-base2/resources/favicon/favicon.png +0 -0
  32. package/src/content/themes/theme-base2/resources/favicon/favicon.svg +9 -0
  33. package/src/content/themes/theme-base2/resources/favicon/google-touch-icon.png +0 -0
  34. package/src/content/themes/theme-base2/resources/favicon/manifest.json +14 -0
  35. package/src/content/themes/theme-base2/resources/favicon/site.webmanifest +1 -0
  36. package/src/content/themes/theme-base2/resources/favicon/web-app-manifest-192x192.png +0 -0
  37. package/src/content/themes/theme-base2/resources/favicon/web-app-manifest-512x512.png +0 -0
  38. package/src/content/themes/theme-base2/resources/fonts/acinguiux-typeface-la-heavy-221208.woff2 +0 -0
  39. package/src/content/themes/theme-base2/theme-base2.css +47 -0
  40. package/src/content/themes/theme-eco-marathon/theme-eco-marathon.css +22 -0
  41. package/src/content/themes/theme-energy-transition-campus-amsterdam/theme-energy-transition-campus-amsterdam.css +26 -0
  42. package/src/content/themes/theme-evpass/theme-evpass.css +46 -0
  43. package/src/content/themes/theme-nam-2025/resources/favicon/apple-touch-icon.png +0 -0
  44. package/src/content/themes/theme-nam-2025/resources/favicon/favico.ico +0 -0
  45. package/src/content/themes/theme-nam-2025/resources/favicon/favicon-96x96.png +0 -0
  46. package/src/content/themes/theme-nam-2025/resources/favicon/favicon.ico +0 -0
  47. package/src/content/themes/theme-nam-2025/resources/favicon/favicon.png +0 -0
  48. package/src/content/themes/theme-nam-2025/resources/favicon/favicon.svg +9 -0
  49. package/src/content/themes/theme-nam-2025/resources/favicon/google-touch-icon.png +0 -0
  50. package/src/content/themes/theme-nam-2025/resources/favicon/manifest.json +14 -0
  51. package/src/content/themes/theme-nam-2025/resources/favicon/site.webmanifest +21 -0
  52. package/src/content/themes/theme-nam-2025/resources/favicon/web-app-manifest-192x192.png +0 -0
  53. package/src/content/themes/theme-nam-2025/resources/favicon/web-app-manifest-512x512.png +0 -0
  54. package/src/content/themes/theme-nam-2025/theme-nam-2025.css +47 -0
  55. package/src/content/themes/theme-pennzoil/theme-pennzoil.css +36 -0
  56. package/src/content/themes/theme-quaker-state/theme-quaker-state.css +63 -0
  57. package/src/content/themes/theme-tafawoq/theme-tafawoq.css +26 -0
  58. package/src/content/themes/theme-vegetable/resources/favicon/apple-touch-icon.png +0 -0
  59. package/src/content/themes/theme-vegetable/resources/favicon/favico.ico +0 -0
  60. package/src/content/themes/theme-vegetable/resources/favicon/favicon-96x96.png +0 -0
  61. package/src/content/themes/theme-vegetable/resources/favicon/favicon.ico +0 -0
  62. package/src/content/themes/theme-vegetable/resources/favicon/favicon.png +0 -0
  63. package/src/content/themes/theme-vegetable/resources/favicon/favicon.svg +13 -0
  64. package/src/content/themes/theme-vegetable/resources/favicon/google-touch-icon.png +0 -0
  65. package/src/content/themes/theme-vegetable/resources/favicon/manifest.json +14 -0
  66. package/src/content/themes/theme-vegetable/resources/favicon/site.webmanifest +21 -0
  67. package/src/content/themes/theme-vegetable/resources/favicon/web-app-manifest-192x192.png +0 -0
  68. package/src/content/themes/theme-vegetable/resources/favicon/web-app-manifest-512x512.png +0 -0
  69. package/src/content/themes/theme-vegetable/theme-vegetable.css +49 -0
  70. package/src/content/themes/theme-zeolyst/resources/fonts/type-ar-medium.woff2 +0 -0
  71. package/src/content/themes/theme-zeolyst/theme-zeolyst.css +29 -0
  72. package/src/main/atoms/audio.js +16 -0
  73. package/src/main/atoms/box.js +5 -0
  74. package/src/main/atoms/button.js +40 -0
  75. package/src/main/atoms/card.js +22 -0
  76. package/src/main/atoms/form.js +30 -0
  77. package/src/main/atoms/heading.js +17 -0
  78. package/src/main/atoms/icon.js +24 -0
  79. package/src/main/atoms/img.js +131 -0
  80. package/src/main/atoms/input.js +55 -0
  81. package/src/main/atoms/link-text.js +21 -0
  82. package/src/main/atoms/link.js +60 -0
  83. package/src/main/atoms/list.js +12 -0
  84. package/src/main/atoms/logo.js +9 -0
  85. package/src/main/atoms/menu.js +10 -0
  86. package/src/main/atoms/message.js +5 -0
  87. package/src/main/atoms/nav-link.js +49 -0
  88. package/src/main/atoms/popup.js +47 -0
  89. package/src/main/atoms/rich-text.js +128 -0
  90. package/src/main/atoms/scroller.js +224 -0
  91. package/src/main/atoms/svg.js +65 -0
  92. package/src/main/atoms/table.js +32 -0
  93. package/src/main/atoms/textarea.js +10 -0
  94. package/src/main/atoms/time.js +12 -0
  95. package/src/main/atoms/video.js +100 -0
  96. package/src/main/export-main.js +12 -0
  97. package/src/main/export-matter.js +86 -0
  98. package/src/main/export-preact-hooks.js +1 -0
  99. package/src/main/export-preact.js +1 -0
  100. package/src/main/index.js +13 -0
  101. package/src/main/molecules/asset.js +23 -0
  102. package/src/main/molecules/glossary.js +44 -0
  103. package/src/main/molecules/links.js +23 -0
  104. package/src/main/molecules/promo-text.js +27 -0
  105. package/src/main/molecules/tags.js +15 -0
  106. package/src/main/molecules/tree.js +51 -0
  107. package/src/main/organisms/accordion-item.js +106 -0
  108. package/src/main/organisms/author.js +29 -0
  109. package/src/main/organisms/breadcrumb.js +69 -0
  110. package/src/main/organisms/call-to-action.js +24 -0
  111. package/src/main/organisms/carousel.js +178 -0
  112. package/src/main/organisms/cart-item.js +156 -0
  113. package/src/main/organisms/cart.js +162 -0
  114. package/src/main/organisms/contact-form.js +141 -0
  115. package/src/main/organisms/container/ab-test.js +47 -0
  116. package/src/main/organisms/container/default.js +6 -0
  117. package/src/main/organisms/container/filtered-section.js +293 -0
  118. package/src/main/organisms/container/footer.js +12 -0
  119. package/src/main/organisms/container/grid.js +44 -0
  120. package/src/main/organisms/container/header.js +13 -0
  121. package/src/main/organisms/container/list.js +7 -0
  122. package/src/main/organisms/container/main.js +6 -0
  123. package/src/main/organisms/container/raw.js +7 -0
  124. package/src/main/organisms/container/section.js +28 -0
  125. package/src/main/organisms/container.js +29 -0
  126. package/src/main/organisms/content-owner.js +15 -0
  127. package/src/main/organisms/date-entry.js +56 -0
  128. package/src/main/organisms/external-search.js +73 -0
  129. package/src/main/organisms/filtered-item.js +163 -0
  130. package/src/main/organisms/footer-item.js +17 -0
  131. package/src/main/organisms/image-gallery.js +164 -0
  132. package/src/main/organisms/last-modified.js +20 -0
  133. package/src/main/organisms/legal-footer.js +16 -0
  134. package/src/main/organisms/list-item.js +48 -0
  135. package/src/main/organisms/metadata.js +11 -0
  136. package/src/main/organisms/navigation.js +232 -0
  137. package/src/main/organisms/notification.js +87 -0
  138. package/src/main/organisms/order-tracker.js +203 -0
  139. package/src/main/organisms/page-header-banner.js +26 -0
  140. package/src/main/organisms/page-header.js +33 -0
  141. package/src/main/organisms/page-tags.js +14 -0
  142. package/src/main/organisms/page.js +260 -0
  143. package/src/main/organisms/press-release.js +24 -0
  144. package/src/main/organisms/product-admin.js +204 -0
  145. package/src/main/organisms/promo-banner.js +28 -0
  146. package/src/main/organisms/promo-bottom.js +23 -0
  147. package/src/main/organisms/promo-button.js +8 -0
  148. package/src/main/organisms/promo-card-cover.js +35 -0
  149. package/src/main/organisms/promo-card.js +33 -0
  150. package/src/main/organisms/promo-full.js +20 -0
  151. package/src/main/organisms/promo-image.js +22 -0
  152. package/src/main/organisms/promo-lure.js +22 -0
  153. package/src/main/organisms/promo-product-card.js +187 -0
  154. package/src/main/organisms/promo-product-full.js +293 -0
  155. package/src/main/organisms/promo-simple.js +23 -0
  156. package/src/main/organisms/quote.js +21 -0
  157. package/src/main/organisms/search-form.js +42 -0
  158. package/src/main/organisms/search-nav.js +66 -0
  159. package/src/main/organisms/search-result.js +53 -0
  160. package/src/main/organisms/slider.js +26 -0
  161. package/src/main/organisms/standalone-asset.js +22 -0
  162. package/src/main/organisms/tabs.js +277 -0
  163. package/src/main/organisms/topbar.js +83 -0
  164. package/src/main/organisms/web-component.js +53 -0
  165. package/src/main/routing/annotation.js +9 -0
  166. package/src/main/routing/component.js +138 -0
  167. package/src/main/routing/empty.js +5 -0
  168. package/src/main/routing/error-handler.js +64 -0
  169. package/src/main/routing/placeholder-image.svg +5 -0
  170. package/src/main/routing/router.js +219 -0
  171. package/src/main/shared/analytics.js +677 -0
  172. package/src/main/shared/bubble-event.js +11 -0
  173. package/src/main/shared/custom-element.js +21 -0
  174. package/src/main/shared/deep-selector.js +28 -0
  175. package/src/main/shared/disable-transparency.js +10 -0
  176. package/src/main/shared/format-time.js +8 -0
  177. package/src/main/shared/get-id.js +5 -0
  178. package/src/main/shared/get-meta.js +3 -0
  179. package/src/main/shared/get-size-class.js +3 -0
  180. package/src/main/shared/get-size.js +11 -0
  181. package/src/main/shared/h.js +88 -0
  182. package/src/main/shared/hash-jump.js +33 -0
  183. package/src/main/shared/icons/arrow-back.svg +1 -0
  184. package/src/main/shared/icons/arrow-down.svg +1 -0
  185. package/src/main/shared/icons/arrow-next.svg +1 -0
  186. package/src/main/shared/icons/arrow-tail-right.svg +1 -0
  187. package/src/main/shared/icons/arrow-tail-up.svg +1 -0
  188. package/src/main/shared/icons/arrow-up.svg +1 -0
  189. package/src/main/shared/icons/asset-download.svg +1 -0
  190. package/src/main/shared/icons/logo.svg +5 -0
  191. package/src/main/shared/icons/low-carbon-placeholder.svg +9 -0
  192. package/src/main/shared/icons/media-pause.svg +1 -0
  193. package/src/main/shared/icons/media-play.svg +1 -0
  194. package/src/main/shared/icons/navigation-burger.svg +1 -0
  195. package/src/main/shared/icons/navigation-close.svg +1 -0
  196. package/src/main/shared/icons/navigation-link.svg +1 -0
  197. package/src/main/shared/icons/navigation-refresh.svg +1 -0
  198. package/src/main/shared/icons/navigation-search.svg +1 -0
  199. package/src/main/shared/icons/navigation-share.svg +1 -0
  200. package/src/main/shared/icons/toggle-newwindow.svg +1 -0
  201. package/src/main/shared/icons.js +18 -0
  202. package/src/main/shared/id-from-string.js +5 -0
  203. package/src/main/shared/mark-selection.js +19 -0
  204. package/src/main/shared/register.js +26 -0
  205. package/src/main/shared/renderer.js +43 -0
  206. package/src/main/shared/simple-consent-api.js +70 -0
  207. package/src/main/shared/split-links.js +11 -0
  208. package/src/main/shared/t.js +60 -0
  209. package/src/main/shared/twind.js +837 -0
  210. package/src/main/shared/update-head.js +34 -0
  211. package/src/main/shared/update-scrollbar-width.js +30 -0
  212. package/src/main/shared/use-link.js +151 -0
  213. package/src/main/shared/use-persistent-state.js +42 -0
  214. package/src/main/shared/wait-for-dom-ready.js +6 -0
  215. package/src/main/shared/wcm-mode.js +4 -0
  216. package/src/wcs/components/acinguiux-preact-doc/acinguiux-preact-doc.js +207 -0
  217. package/src/wcs/components/admin-dashboard/admin-dashboard.js +487 -0
  218. package/src/wcs/components/admin-login/admin-login.js +91 -0
  219. package/src/wcs/components/bazaar-voice/bazaar-voice.js +56 -0
  220. package/src/wcs/components/chatbot-koreai/chatbot-koreai.js +176 -0
  221. package/src/wcs/components/chatbot-koreai/koreai-transport.js +217 -0
  222. package/src/wcs/components/chatbot-ms/chatbot-ms.js +210 -0
  223. package/src/wcs/components/chatbot-test/chatbot-test.js +44 -0
  224. package/src/wcs/components/comparison-chart/comparison-chart.js +111 -0
  225. package/src/wcs/components/consent-banner/consent-banner.js +248 -0
  226. package/src/wcs/components/consent-banner/icons/ccpa.svg +6 -0
  227. package/src/wcs/components/consent-banner/icons/info.svg +1 -0
  228. package/src/wcs/components/consent-banner/provider-onetrust.js +131 -0
  229. package/src/wcs/components/decision-tree/arrow-back.svg +3 -0
  230. package/src/wcs/components/decision-tree/badges.js +37 -0
  231. package/src/wcs/components/decision-tree/decision-tree.js +162 -0
  232. package/src/wcs/components/dynamic-contact-details/dynamic-contact-details.js +111 -0
  233. package/src/wcs/components/example-accordion/example-accordion.js +10 -0
  234. package/src/wcs/components/example-asset/example-asset.js +12 -0
  235. package/src/wcs/components/example-form/example-form.js +59 -0
  236. package/src/wcs/components/example-nested/example-nested.js +10 -0
  237. package/src/wcs/components/example-routing/example-routing.js +51 -0
  238. package/src/wcs/components/example-rtl/example-rtl.js +28 -0
  239. package/src/wcs/components/example-tabs/example-tabs.js +12 -0
  240. package/src/wcs/components/example-web-component/example-web-component.js +34 -0
  241. package/src/wcs/components/floating-button/floating-button.js +17 -0
  242. package/src/wcs/components/formstack-form/fields/address.js +38 -0
  243. package/src/wcs/components/formstack-form/fields/checkbox.js +42 -0
  244. package/src/wcs/components/formstack-form/fields/date.js +22 -0
  245. package/src/wcs/components/formstack-form/fields/description.js +8 -0
  246. package/src/wcs/components/formstack-form/fields/input.js +8 -0
  247. package/src/wcs/components/formstack-form/fields/name.js +39 -0
  248. package/src/wcs/components/formstack-form/fields/radio.js +24 -0
  249. package/src/wcs/components/formstack-form/fields/rating.js +53 -0
  250. package/src/wcs/components/formstack-form/fields/section.js +8 -0
  251. package/src/wcs/components/formstack-form/fields/select.js +10 -0
  252. package/src/wcs/components/formstack-form/fields/textarea.js +8 -0
  253. package/src/wcs/components/formstack-form/fields/wrapper.js +11 -0
  254. package/src/wcs/components/formstack-form/formstack-form.js +280 -0
  255. package/src/wcs/components/fuel-prices/fuel-prices.js +45 -0
  256. package/src/wcs/components/furniture-overview/furniture-overview.js +115 -0
  257. package/src/wcs/components/gauge-value/gauge-value.js +65 -0
  258. package/src/wcs/components/help-centre/api.js +150 -0
  259. package/src/wcs/components/help-centre/help-centre.js +400 -0
  260. package/src/wcs/components/help-centre/icon-search.svg +1 -0
  261. package/src/wcs/components/image-gen/admin-panel.js +248 -0
  262. package/src/wcs/components/image-gen/image-gen.js +385 -0
  263. package/src/wcs/components/image-gen/labels.js +37 -0
  264. package/src/wcs/components/image-gen/use-api.js +392 -0
  265. package/src/wcs/components/inspired-gallery/inspired-gallery.js +118 -0
  266. package/src/wcs/components/launch-container/launch-container.js +95 -0
  267. package/src/wcs/components/launch-container/ledger.js +140 -0
  268. package/src/wcs/components/lng-map/lng-map.js +44 -0
  269. package/src/wcs/components/mouseflow-analytics/mouseflow-analytics.js +39 -0
  270. package/src/wcs/components/msds-search/msds-search.js +127 -0
  271. package/src/wcs/components/msds-search/navigation-search.svg +3 -0
  272. package/src/wcs/components/product-catalogue/icon-back.svg +3 -0
  273. package/src/wcs/components/product-catalogue/icon-cart.svg +3 -0
  274. package/src/wcs/components/product-catalogue/icon-close.svg +3 -0
  275. package/src/wcs/components/product-catalogue/product-catalogue.js +215 -0
  276. package/src/wcs/components/product-links/icon-cart.svg +3 -0
  277. package/src/wcs/components/product-links/product-links.js +43 -0
  278. package/src/wcs/components/rio-iframe/rio-iframe.js +137 -0
  279. package/src/wcs/components/salsify-products/filter-tools.js +60 -0
  280. package/src/wcs/components/salsify-products/icon-cart.svg +3 -0
  281. package/src/wcs/components/salsify-products/process-products.js +53 -0
  282. package/src/wcs/components/salsify-products/route-tools.js +54 -0
  283. package/src/wcs/components/salsify-products/salsify-products.js +281 -0
  284. package/src/wcs/components/shout-out/shout-out.js +51 -0
  285. package/src/wcs/components/simple-chart/simple-chart.js +53 -0
  286. package/src/wcs/components/single-stat/single-stat.js +85 -0
  287. package/src/wcs/components/site-feedback/site-feedback.js +56 -0
  288. package/src/wcs/components/skds-search/navigation-search.svg +3 -0
  289. package/src/wcs/components/skds-search/skds-search.js +103 -0
  290. package/src/wcs/components/smart-banner/smart-banner.js +104 -0
  291. package/src/wcs/components/standalone-table/arrow-up-down.svg +3 -0
  292. package/src/wcs/components/standalone-table/arrow-up.svg +3 -0
  293. package/src/wcs/components/standalone-table/standalone-table.js +440 -0
  294. package/src/wcs/components/station-locator/station-locator.js +49 -0
  295. package/src/wcs/components/store-badges/badges.js +60 -0
  296. package/src/wcs/components/store-badges/store-badges.js +93 -0
  297. package/src/wcs/components/topbar-button/person.svg +1 -0
  298. package/src/wcs/components/topbar-button/topbar-button.js +22 -0
  299. package/src/wcs/components/universal-gallery/universal-gallery.js +308 -0
  300. package/src/wcs/components/zendesk-chat/zendesk-chat.js +133 -0
  301. package/src/wcs/shared/chat-bot/README.md +61 -0
  302. package/src/wcs/shared/chat-bot/chat-bot.js +216 -0
  303. package/src/wcs/shared/chat-bot/resources/arrow-next.svg +1 -0
  304. package/src/wcs/shared/chat-bot/resources/navigation-close.svg +1 -0
  305. package/src/wcs/shared/chat-bot/resources/person.svg +1 -0
  306. package/src/wcs/shared/chat-bot/resources/upload.svg +1 -0
  307. package/src/wcs/shared/filtered-data/README.md +52 -0
  308. package/src/wcs/shared/filtered-data/fetch-data.js +33 -0
  309. package/src/wcs/shared/filtered-data/filtered-data.js +337 -0
  310. package/src/wcs/shared/promo-with-popup/icon-close.svg +3 -0
  311. package/src/wcs/shared/promo-with-popup/icon-next.svg +3 -0
  312. package/src/wcs/shared/promo-with-popup/icon-prev.svg +3 -0
  313. 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,3 @@
1
+ <svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24">
2
+ <polygon fill="#595959" points="15.543 4.294 7.699 12.922 15.51 20.743 14.095 22.156 4.937 12.987 14.063 2.949"/>
3
+ </svg>
@@ -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="&lt;Group&gt;">
21
+ <g fill="#fff" data-name="&lt;Group&gt;">
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="&lt;Path&gt;"/>
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="&lt;Path&gt;"/>
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>`