fontdue-js 2.21.0 → 2.22.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 (468) hide show
  1. package/CHANGELOG.md +11 -0
  2. package/dist/components/ConfigContext.d.ts +3 -0
  3. package/dist/components/ConfigContext.js +2 -1
  4. package/dist/components/FontdueProvider/FontdueProviderClientComponent.js +2 -0
  5. package/dist/components/FontdueProvider/useAuxUIOwner.d.ts +1 -0
  6. package/dist/components/FontdueProvider/useAuxUIOwner.js +28 -0
  7. package/dist/components/TypeTester/TypeTesterFeatures.js +2 -1
  8. package/dist/components/TypeTester/TypeTesterFeaturesButton.js +5 -3
  9. package/dist/components/TypeTester/TypeTesterStandalone.d.ts +2 -2
  10. package/dist/components/TypeTester/TypeTesterStandalone.js +2 -1
  11. package/dist/components/TypeTester/TypeTesterStandalone.preload.d.ts +14 -0
  12. package/dist/components/TypeTester/TypeTesterStandalone.preload.js +19 -0
  13. package/dist/components/TypeTester/types.d.ts +2 -0
  14. package/dist/components/TypeTester/types.js +10 -1
  15. package/dist/components/TypeTesters/TypeTestersElement.d.ts +2 -1
  16. package/dist/components/TypeTesters/TypeTestersElement.js +3 -1
  17. package/dist/components/TypeTesters/index.d.ts +2 -0
  18. package/dist/components/TypeTesters/index.js +5 -2
  19. package/dist/config.d.ts +6 -0
  20. package/dist/config.js +20 -0
  21. package/dist/corsError.d.ts +1 -0
  22. package/dist/corsError.js +16 -9
  23. package/dist/global-shim.js +8 -0
  24. package/dist/index.d.ts +2 -0
  25. package/dist/index.js +1 -0
  26. package/dist/relay/environment.js +51 -42
  27. package/dist-cjs/__generated__/AddToCartBannerQuery.graphql.js +194 -0
  28. package/dist-cjs/__generated__/AddToCartBanner_item.graphql.js +107 -0
  29. package/dist-cjs/__generated__/AddToCartBanner_order.graphql.js +131 -0
  30. package/dist-cjs/__generated__/AddressFieldsRefetchQuery.graphql.js +170 -0
  31. package/dist-cjs/__generated__/AddressFields_viewer.graphql.js +125 -0
  32. package/dist-cjs/__generated__/BuyButtonIDQuery.graphql.js +121 -0
  33. package/dist-cjs/__generated__/BuyButtonSlugQuery.graphql.js +146 -0
  34. package/dist-cjs/__generated__/BuyButton_collection.graphql.js +56 -0
  35. package/dist-cjs/__generated__/CartButtonQuery.graphql.js +139 -0
  36. package/dist-cjs/__generated__/CartButton_order.graphql.js +71 -0
  37. package/dist-cjs/__generated__/CartItemAdditionalLicenses_licenses.graphql.js +42 -0
  38. package/dist-cjs/__generated__/CartItemAdditionalLicenses_orderItem.graphql.js +52 -0
  39. package/dist-cjs/__generated__/CartItemLicense_selection.graphql.js +80 -0
  40. package/{dist/__generated__/CartItem_product.graphql.js → dist-cjs/__generated__/CartItemProduct_product.graphql.js} +27 -38
  41. package/{dist/__generated__/CartItem_licenseSelection.graphql.js → dist-cjs/__generated__/CartItemVariable_selection.graphql.js} +32 -31
  42. package/dist-cjs/__generated__/CartItemVariable_variable.graphql.js +58 -0
  43. package/dist-cjs/__generated__/CartItem_node.graphql.js +166 -0
  44. package/dist-cjs/__generated__/CartOrderCompleteOrderMutation.graphql.js +783 -0
  45. package/dist-cjs/__generated__/CartOrderRemoveDiscountMutation.graphql.js +760 -0
  46. package/dist-cjs/__generated__/CartOrderUpdateMutation.graphql.js +795 -0
  47. package/{dist/__generated__/ThemeConfig_viewer.graphql.js → dist-cjs/__generated__/CartOrder_UpdateErrors.graphql.js} +8 -8
  48. package/{dist/__generated__/StoreModalReview_order.graphql.js → dist-cjs/__generated__/CartOrder_order.graphql.js} +125 -105
  49. package/{dist/__generated__/StoreModalReview_viewer.graphql.js → dist-cjs/__generated__/CartOrder_viewer.graphql.js} +7 -3
  50. package/dist-cjs/__generated__/CartQuery.graphql.js +887 -0
  51. package/{dist/__generated__/StoreModalReviewCompleteOrderMutation.graphql.js → dist-cjs/__generated__/CartStateRemoveDiscountMutation.graphql.js} +188 -208
  52. package/dist-cjs/__generated__/CartStateUpdateMutation.graphql.js +790 -0
  53. package/dist-cjs/__generated__/CartState_order.graphql.js +122 -0
  54. package/dist-cjs/__generated__/CartTotals_order.graphql.js +140 -0
  55. package/dist-cjs/__generated__/CharacterViewerIDQuery.graphql.js +332 -0
  56. package/dist-cjs/__generated__/CharacterViewerSlugQuery.graphql.js +362 -0
  57. package/dist-cjs/__generated__/CharacterViewerStyleRefetchQuery.graphql.js +226 -0
  58. package/dist-cjs/__generated__/CharacterViewer_collection.graphql.js +197 -0
  59. package/dist-cjs/__generated__/CharacterViewer_family.graphql.js +101 -0
  60. package/dist-cjs/__generated__/CharacterViewer_style.graphql.js +161 -0
  61. package/{dist/__generated__/CartOrderApplyCouponMutation.graphql.js → dist-cjs/__generated__/CheckoutUpdateCustomerMutation.graphql.js} +269 -418
  62. package/dist-cjs/__generated__/CheckoutUpdateOrderMutation.graphql.js +811 -0
  63. package/dist-cjs/__generated__/Checkout_UpdateOrderErrors.graphql.js +97 -0
  64. package/dist-cjs/__generated__/Checkout_identity.graphql.js +94 -0
  65. package/dist-cjs/__generated__/Checkout_order.graphql.js +144 -0
  66. package/{dist/__generated__/TestModeBanner_viewer.graphql.js → dist-cjs/__generated__/Checkout_viewer.graphql.js} +20 -10
  67. package/dist-cjs/__generated__/CollectionAa_Query.graphql.js +192 -0
  68. package/dist-cjs/__generated__/CollectionAa_product.graphql.js +69 -0
  69. package/{dist/__generated__/StoreModalReviewUpdateOrderMutation.graphql.js → dist-cjs/__generated__/CouponCodeInputApplyCouponMutation.graphql.js} +191 -204
  70. package/dist-cjs/__generated__/CouponText_coupon.graphql.js +73 -0
  71. package/dist-cjs/__generated__/CustomerLoginFormLoginMutation.graphql.js +72 -0
  72. package/dist-cjs/__generated__/CustomerLoginFormQuery.graphql.js +91 -0
  73. package/{dist/__generated__/SKUPrice_RefetchQuery.graphql.js → dist-cjs/__generated__/DownloadRefetchQuery.graphql.js} +38 -43
  74. package/dist-cjs/__generated__/Download_order.graphql.js +61 -0
  75. package/dist-cjs/__generated__/FamilyList_node.graphql.js +96 -0
  76. package/dist-cjs/__generated__/Family_node.graphql.js +160 -0
  77. package/dist-cjs/__generated__/FontFamiliesQuery.graphql.js +368 -0
  78. package/dist-cjs/__generated__/FontStyle_fontStyle.graphql.js +32 -0
  79. package/dist-cjs/__generated__/IdentityBox_identity.graphql.js +52 -0
  80. package/{dist/__generated__/CartItem_license.graphql.js → dist-cjs/__generated__/License_node.graphql.js} +29 -8
  81. package/{dist/__generated__/NewsletterSignup_Query.graphql.js → dist-cjs/__generated__/NewsletterSignupQuery.graphql.js} +19 -8
  82. package/dist-cjs/__generated__/NewsletterSignupUpdateCustomerMutation.graphql.js +81 -0
  83. package/dist-cjs/__generated__/NodePasswordFormAccessNodeMutation.graphql.js +72 -0
  84. package/dist-cjs/__generated__/NodePasswordFormIDQuery.graphql.js +93 -0
  85. package/dist-cjs/__generated__/NodePasswordFormSlugQuery.graphql.js +115 -0
  86. package/dist-cjs/__generated__/OrderVariableSelectionReduxRefetchQuery.graphql.js +154 -0
  87. package/dist-cjs/__generated__/OrderVariableSelectionRedux_viewer.graphql.js +75 -0
  88. package/dist-cjs/__generated__/OrderVariableSelection_variables.graphql.js +107 -0
  89. package/dist-cjs/__generated__/PrecartAddToCartMutation.graphql.js +793 -0
  90. package/dist-cjs/__generated__/PrecartClearCartMutation.graphql.js +81 -0
  91. package/dist-cjs/__generated__/PrecartQuery.graphql.js +308 -0
  92. package/{dist/__generated__/CartItem_viewer.graphql.js → dist-cjs/__generated__/Precart_collection.graphql.js} +22 -28
  93. package/dist-cjs/__generated__/Precart_license.graphql.js +67 -0
  94. package/dist-cjs/__generated__/Precart_viewer.graphql.js +161 -0
  95. package/{dist/__generated__/PriceBarSection_RefetchQuery.graphql.js → dist-cjs/__generated__/PriceBarSectionRefetchQuery.graphql.js} +51 -35
  96. package/dist-cjs/__generated__/PriceBarSection_node.graphql.js +121 -0
  97. package/dist-cjs/__generated__/PriceBar_node.graphql.js +60 -0
  98. package/dist-cjs/__generated__/Price_price.graphql.js +40 -0
  99. package/dist-cjs/__generated__/SKUPrice_sku.graphql.js +69 -0
  100. package/dist-cjs/__generated__/SelectButton_sku.graphql.js +54 -0
  101. package/dist-cjs/__generated__/ServerConfigProviderQuery.graphql.js +108 -0
  102. package/{dist/__generated__/CartTotalsCreateSnapshotMutation.graphql.js → dist-cjs/__generated__/ShareCartCreateSnapshotMutation.graphql.js} +7 -7
  103. package/dist-cjs/__generated__/SpecimenLinkQuery.graphql.js +120 -0
  104. package/dist-cjs/__generated__/StoreModalBundleButton_bundle.graphql.js +85 -0
  105. package/dist-cjs/__generated__/StoreModalCartQuery.graphql.js +1017 -0
  106. package/dist-cjs/__generated__/StoreModalCheckoutQuery.graphql.js +194 -0
  107. package/dist-cjs/__generated__/StoreModalContainerQuery.graphql.js +228 -0
  108. package/dist-cjs/__generated__/StoreModalDownloadRefetchQuery.graphql.js +102 -0
  109. package/dist-cjs/__generated__/StoreModalDownload_order.graphql.js +40 -0
  110. package/dist-cjs/__generated__/StoreModalFamilyButton_collection.graphql.js +135 -0
  111. package/dist-cjs/__generated__/StoreModalFamily_collection.graphql.js +130 -0
  112. package/dist-cjs/__generated__/StoreModalIndexItem_fontCollection.graphql.js +98 -0
  113. package/dist-cjs/__generated__/StoreModalIndexQuery.graphql.js +263 -0
  114. package/dist-cjs/__generated__/StoreModalOrderVariableSelection_order.graphql.js +98 -0
  115. package/dist-cjs/__generated__/StoreModalOrderVariableSelection_viewer.graphql.js +66 -0
  116. package/dist-cjs/__generated__/StoreModalProductContent_collection.graphql.js +92 -0
  117. package/{dist/__generated__/StoreModalProductLicenseSelection_viewer.graphql.js → dist-cjs/__generated__/StoreModalProductLicenseSelection_collection.graphql.js} +6 -10
  118. package/dist-cjs/__generated__/StoreModalProductLicense_license.graphql.js +104 -0
  119. package/dist-cjs/__generated__/StoreModalProductQuery.graphql.js +702 -0
  120. package/dist-cjs/__generated__/StoreModalProductRefetchQuery.graphql.js +433 -0
  121. package/dist-cjs/__generated__/StoreModalProductSummaryAddToCartMutation.graphql.js +149 -0
  122. package/dist-cjs/__generated__/StoreModalProductSummaryClearCartMutation.graphql.js +81 -0
  123. package/dist-cjs/__generated__/StoreModalProductSummaryRefetchQuery.graphql.js +281 -0
  124. package/dist-cjs/__generated__/StoreModalProductSummary_viewer.graphql.js +243 -0
  125. package/dist-cjs/__generated__/StoreModalReviewIdentity_identity.graphql.js +52 -0
  126. package/dist-cjs/__generated__/StoreModalStyleButton_fontStyle.graphql.js +113 -0
  127. package/dist-cjs/__generated__/StoreModalUnifiedCheckoutCompleteOrderMutation.graphql.js +302 -0
  128. package/dist-cjs/__generated__/StoreModalUnifiedCheckoutUpdateCustomerMutation.graphql.js +323 -0
  129. package/{dist/__generated__/StoreModalReviewQuery.graphql.js → dist-cjs/__generated__/StoreModalUnifiedCheckoutUpdateOrderMutation.graphql.js} +243 -261
  130. package/dist-cjs/__generated__/StoreModalUnifiedCheckout_order.graphql.js +237 -0
  131. package/{dist/__generated__/TestFontsForm_viewer.graphql.js → dist-cjs/__generated__/StoreModalUnifiedCheckout_viewer.graphql.js} +48 -32
  132. package/dist-cjs/__generated__/StripeProviderCreateCheckoutSessionMutation.graphql.js +105 -0
  133. package/dist-cjs/__generated__/StripeProvider_viewer.graphql.js +139 -0
  134. package/dist-cjs/__generated__/TestFontsFormUpdateCustomerMutation.graphql.js +770 -0
  135. package/dist-cjs/__generated__/TestFontsForm_Query.graphql.js +126 -0
  136. package/dist-cjs/__generated__/TestModeBannerQuery.graphql.js +87 -0
  137. package/dist-cjs/__generated__/ThemeConfigQuery.graphql.js +87 -0
  138. package/dist-cjs/__generated__/TypeTesterFeaturesButton_fontStyle.graphql.js +32 -0
  139. package/dist-cjs/__generated__/TypeTesterFeatures_fontStyle.graphql.js +36 -0
  140. package/{dist/__generated__/Cart_viewer.graphql.js → dist-cjs/__generated__/TypeTesterFloatingToolbar_testers.graphql.js} +18 -14
  141. package/{dist/__generated__/TypeTester_NewStyleQuery.graphql.js → dist-cjs/__generated__/TypeTesterStandaloneChangedStylesQuery.graphql.js} +125 -122
  142. package/dist-cjs/__generated__/TypeTesterStandaloneQuery.graphql.js +450 -0
  143. package/dist-cjs/__generated__/TypeTesterStyleSelectData_fontStyle.graphql.js +106 -0
  144. package/dist-cjs/__generated__/TypeTesterStyleSelectData_fontStyleData.graphql.js +88 -0
  145. package/dist-cjs/__generated__/TypeTesterStyleSelectData_viewer.graphql.js +166 -0
  146. package/dist-cjs/__generated__/TypeTesterToolbar_fontStyle.graphql.js +36 -0
  147. package/{dist/__generated__/SpecimenLink_node.graphql.js → dist-cjs/__generated__/TypeTesterVariableAxes_fontStyle.graphql.js} +14 -8
  148. package/dist-cjs/__generated__/TypeTester_fontStyle.graphql.js +106 -0
  149. package/dist-cjs/__generated__/TypeTester_viewer.graphql.js +40 -0
  150. package/dist-cjs/__generated__/TypeTestersChangedStylesQuery.graphql.js +347 -0
  151. package/dist-cjs/__generated__/TypeTestersIDQuery.graphql.js +637 -0
  152. package/dist-cjs/__generated__/TypeTestersRefetchQuery.graphql.js +554 -0
  153. package/dist-cjs/__generated__/TypeTestersSlugQuery.graphql.js +644 -0
  154. package/dist-cjs/__generated__/TypeTesters_collection.graphql.js +258 -0
  155. package/dist-cjs/__generated__/TypeTesters_viewer.graphql.js +40 -0
  156. package/{dist/__generated__/CouponCodeInput_order.graphql.js → dist-cjs/__generated__/VariableTableAmounts_option.graphql.js} +10 -4
  157. package/dist-cjs/__generated__/VariableTableAmounts_variable.graphql.js +34 -0
  158. package/dist-cjs/__generated__/productState_Query.graphql.js +184 -0
  159. package/{dist/__generated__/CartItem_variable.graphql.js → dist-cjs/__generated__/productState_bundle.graphql.js} +31 -19
  160. package/dist-cjs/__generated__/productState_collection.graphql.js +90 -0
  161. package/dist-cjs/__generated__/productState_collectionBundle.graphql.js +88 -0
  162. package/dist-cjs/__generated__/productState_node.graphql.js +122 -0
  163. package/{dist/__generated__/TypeTester_sku.graphql.js → dist-cjs/__generated__/productState_sku.graphql.js} +7 -13
  164. package/dist-cjs/__generated__/useFeaturesData_fontStyle.graphql.js +64 -0
  165. package/dist-cjs/__generated__/useFontStyle_fontStyle.graphql.js +94 -0
  166. package/{dist/__generated__/FontFamilies_node.graphql.js → dist-cjs/__generated__/useTotalStyles_fontCollection.graphql.js} +19 -11
  167. package/dist-cjs/__tests__/collectionBundleSelection.test.js +1630 -0
  168. package/dist-cjs/components/AddToCartBanner/index.js +75 -0
  169. package/dist-cjs/components/BuyButton/index.js +124 -0
  170. package/{dist/components/BuyButton/BuyButton.server.js → dist-cjs/components/BuyButton/index.server.js} +9 -12
  171. package/dist-cjs/components/BuyingOptions/index.js +23 -0
  172. package/dist-cjs/components/Cart/AddressFields.js +162 -0
  173. package/dist-cjs/components/Cart/CartItem/CartItemAdditionalLicenses.js +33 -0
  174. package/dist-cjs/components/Cart/CartItem/CartItemLicense.js +66 -0
  175. package/dist-cjs/components/Cart/CartItem/CartItemProduct.js +36 -0
  176. package/dist-cjs/components/Cart/CartItem/CartItemVariable.js +66 -0
  177. package/dist-cjs/components/Cart/CartItem/VariableTextInput.js +79 -0
  178. package/dist-cjs/components/Cart/CartItem/index.js +95 -0
  179. package/dist-cjs/components/Cart/CartOrder.js +314 -0
  180. package/dist-cjs/components/Cart/CartState.js +93 -0
  181. package/dist-cjs/components/Cart/CartTotals.js +97 -0
  182. package/dist-cjs/components/Cart/Checkout.js +473 -0
  183. package/dist-cjs/components/Cart/CheckoutSteps.js +15 -0
  184. package/dist-cjs/components/Cart/CouponCodeInput.js +90 -0
  185. package/dist-cjs/components/Cart/CustomerFields.js +80 -0
  186. package/dist-cjs/components/Cart/Download.js +62 -0
  187. package/dist-cjs/components/Cart/EmptyCart.js +42 -0
  188. package/dist-cjs/components/Cart/IdentityBox.js +37 -0
  189. package/dist-cjs/components/Cart/ShareCart.js +87 -0
  190. package/dist-cjs/components/Cart/index.js +36 -0
  191. package/dist-cjs/components/Cart/injectRelayEnvironment.js +21 -0
  192. package/dist-cjs/components/Cart/types.js +5 -0
  193. package/dist-cjs/components/Cart/utils.js +8 -0
  194. package/dist-cjs/components/CartButton/index.js +127 -0
  195. package/dist-cjs/components/CartButton/index.server.js +18 -0
  196. package/dist-cjs/components/CharacterViewer/StyleSelect.js +60 -0
  197. package/dist-cjs/components/CharacterViewer/index.js +441 -0
  198. package/dist-cjs/components/CharacterViewer/index.server.js +36 -0
  199. package/dist-cjs/components/Checkbox/index.js +27 -0
  200. package/dist-cjs/components/CollectionAa/index.js +38 -0
  201. package/dist-cjs/components/ComponentsContext.js +12 -0
  202. package/dist-cjs/components/ConfigContext.js +86 -0
  203. package/dist-cjs/components/ConsentBanner/consent.js +92 -0
  204. package/dist-cjs/components/ConsentBanner/index.js +84 -0
  205. package/dist-cjs/components/CookieNotification/index.js +83 -0
  206. package/dist-cjs/components/CorsErrorModal.js +98 -0
  207. package/dist-cjs/components/CouponText/index.js +38 -0
  208. package/dist-cjs/components/CustomerLoginForm/index.js +88 -0
  209. package/dist-cjs/components/Family/FamilyList.js +43 -0
  210. package/dist-cjs/components/Family/index.js +77 -0
  211. package/dist-cjs/components/FontFamilies/index.js +53 -0
  212. package/dist-cjs/components/FontStyle/index.js +37 -0
  213. package/dist-cjs/components/FontdueProvider/FontdueProviderClientComponent.js +74 -0
  214. package/dist-cjs/components/FontdueProvider/index.js +43 -0
  215. package/dist-cjs/components/FontdueProvider/index.server.js +35 -0
  216. package/dist-cjs/components/FontdueProvider/useAuxUIOwner.js +32 -0
  217. package/dist-cjs/components/Icons/Align.js +58 -0
  218. package/dist-cjs/components/Icons/ArrowDownRight.js +19 -0
  219. package/dist-cjs/components/Icons/ArrowLeft.js +22 -0
  220. package/dist-cjs/components/Icons/ArrowRight.js +19 -0
  221. package/dist-cjs/components/Icons/CarrotDown.js +19 -0
  222. package/dist-cjs/components/Icons/CarrotUp.js +19 -0
  223. package/dist-cjs/components/Icons/Cart.js +23 -0
  224. package/dist-cjs/components/Icons/CartNew.js +33 -0
  225. package/dist-cjs/components/Icons/Check.js +19 -0
  226. package/dist-cjs/components/Icons/Checkbox.js +24 -0
  227. package/dist-cjs/components/Icons/CheckboxChecked.js +24 -0
  228. package/dist-cjs/components/Icons/CheckboxCrossed.js +26 -0
  229. package/dist-cjs/components/Icons/CircledCheck.js +21 -0
  230. package/dist-cjs/components/Icons/CircledInfo.js +21 -0
  231. package/dist-cjs/components/Icons/CircledMinus.js +21 -0
  232. package/dist-cjs/components/Icons/ColorPicker.js +19 -0
  233. package/dist-cjs/components/Icons/CreditCard.js +21 -0
  234. package/dist-cjs/components/Icons/DownArrow.js +24 -0
  235. package/dist-cjs/components/Icons/DownloadFonts.js +25 -0
  236. package/dist-cjs/components/Icons/FrowningFace.js +25 -0
  237. package/dist-cjs/components/Icons/License.js +19 -0
  238. package/dist-cjs/components/Icons/Receipt.js +34 -0
  239. package/dist-cjs/components/Icons/User.js +19 -0
  240. package/dist-cjs/components/Icons/X.js +19 -0
  241. package/dist-cjs/components/Icons/index.js +167 -0
  242. package/dist-cjs/components/NewsletterSignup/NewsletterSignupElement.js +15 -0
  243. package/dist-cjs/components/NewsletterSignup/index.js +192 -0
  244. package/dist-cjs/components/NewsletterSignup/index.server.js +18 -0
  245. package/dist-cjs/components/NodePasswordForm/index.js +114 -0
  246. package/dist-cjs/components/OrderVariableSelection/OrderVariableSelectionRedux.js +66 -0
  247. package/dist-cjs/components/OrderVariableSelection/index.js +199 -0
  248. package/dist-cjs/components/Precart/License.js +70 -0
  249. package/dist-cjs/components/Precart/index.js +331 -0
  250. package/dist-cjs/components/Price/index.js +111 -0
  251. package/dist-cjs/components/PriceBar/PriceBarSection.js +61 -0
  252. package/dist-cjs/components/PriceBar/index.js +49 -0
  253. package/dist-cjs/components/Root/index.js +208 -0
  254. package/dist-cjs/components/Root/productState.js +143 -0
  255. package/dist-cjs/components/SKUPrice/index.js +46 -0
  256. package/dist-cjs/components/Select/index.js +36 -0
  257. package/dist-cjs/components/SelectButton/index.js +79 -0
  258. package/dist-cjs/components/ServerConfigProvider/index.js +39 -0
  259. package/dist-cjs/components/SpecimenLink/index.js +37 -0
  260. package/dist-cjs/components/StickyNav/index.js +80 -0
  261. package/dist-cjs/components/StoreModal/StoreModalBundleButton.js +47 -0
  262. package/dist-cjs/components/StoreModal/StoreModalCart.js +79 -0
  263. package/dist-cjs/components/StoreModal/StoreModalCheckout.js +24 -0
  264. package/dist-cjs/components/StoreModal/StoreModalCheckoutContext.js +14 -0
  265. package/dist-cjs/components/StoreModal/StoreModalContainer.js +117 -0
  266. package/dist-cjs/components/StoreModal/StoreModalDownload.js +38 -0
  267. package/dist-cjs/components/StoreModal/StoreModalFamily.js +58 -0
  268. package/dist-cjs/components/StoreModal/StoreModalFamilyButton.js +69 -0
  269. package/dist-cjs/components/StoreModal/StoreModalIndex.js +27 -0
  270. package/dist-cjs/components/StoreModal/StoreModalIndexItem.js +63 -0
  271. package/dist-cjs/components/StoreModal/StoreModalLicenseeIsBillingSelection.js +30 -0
  272. package/dist-cjs/components/StoreModal/StoreModalLoader.js +22 -0
  273. package/dist-cjs/components/StoreModal/StoreModalOrderVariableSelection.js +89 -0
  274. package/dist-cjs/components/StoreModal/StoreModalProduct.js +154 -0
  275. package/dist-cjs/components/StoreModal/StoreModalReviewIdentity.js +18 -0
  276. package/dist-cjs/components/StoreModal/StoreModalRouter.js +28 -0
  277. package/dist-cjs/components/StoreModal/StoreModalStyleButton.js +52 -0
  278. package/dist-cjs/components/StoreModal/index.js +39 -0
  279. package/dist-cjs/components/StoreModal/routes.js +51 -0
  280. package/dist-cjs/components/StoreModal/types.js +5 -0
  281. package/dist-cjs/components/StoreModalProductLicenseSelection/LicenseElement.js +46 -0
  282. package/dist-cjs/components/StoreModalProductLicenseSelection/LicenseVariableElement.js +35 -0
  283. package/dist-cjs/components/StoreModalProductLicenseSelection/LicenseVariableRadioElement.js +47 -0
  284. package/dist-cjs/components/StoreModalProductLicenseSelection/StoreModalProductLicense.js +133 -0
  285. package/dist-cjs/components/StoreModalProductLicenseSelection/index.js +31 -0
  286. package/dist-cjs/components/StoreModalProductSummary/index.js +219 -0
  287. package/dist-cjs/components/StripeLogo.js +17 -0
  288. package/dist-cjs/components/StripeProvider/index.js +172 -0
  289. package/dist-cjs/components/Switch/index.js +7 -0
  290. package/dist-cjs/components/TestFontsForm/TestFontsFormElement.js +15 -0
  291. package/dist-cjs/components/TestFontsForm/index.js +208 -0
  292. package/dist-cjs/components/TestFontsForm/index.server.js +18 -0
  293. package/dist-cjs/components/TestModeBanner/index.js +34 -0
  294. package/dist-cjs/components/TextField/index.js +42 -0
  295. package/dist-cjs/components/ThemeConfig/index.js +41 -0
  296. package/dist-cjs/components/ThemeConfig/index.server.js +17 -0
  297. package/dist-cjs/components/Tracking/index.js +164 -0
  298. package/dist-cjs/components/TypeTester/TypeTesterAlignButtons.js +34 -0
  299. package/dist-cjs/components/TypeTester/TypeTesterBullet.js +23 -0
  300. package/dist-cjs/components/TypeTester/TypeTesterContent.js +58 -0
  301. package/dist-cjs/components/TypeTester/TypeTesterContext.js +166 -0
  302. package/dist-cjs/components/TypeTester/TypeTesterEditAll.js +36 -0
  303. package/dist-cjs/components/TypeTester/TypeTesterFeatures.js +133 -0
  304. package/dist-cjs/components/TypeTester/TypeTesterFeaturesButton.js +82 -0
  305. package/dist-cjs/components/TypeTester/TypeTesterFitter.js +21 -0
  306. package/dist-cjs/components/TypeTester/TypeTesterFloatingToolbar.js +79 -0
  307. package/dist-cjs/components/TypeTester/TypeTesterInput.js +72 -0
  308. package/dist-cjs/components/TypeTester/TypeTesterSlider.js +76 -0
  309. package/dist-cjs/components/TypeTester/TypeTesterStandalone.js +137 -0
  310. package/dist-cjs/components/TypeTester/TypeTesterStandalone.preload.js +27 -0
  311. package/dist-cjs/components/TypeTester/TypeTesterStandalone.server.js +26 -0
  312. package/dist-cjs/components/TypeTester/TypeTesterStandaloneElement.js +65 -0
  313. package/dist-cjs/components/TypeTester/TypeTesterState.js +133 -0
  314. package/dist-cjs/components/TypeTester/TypeTesterStyleSelect.js +101 -0
  315. package/dist-cjs/components/TypeTester/TypeTesterStyleSelectData.js +102 -0
  316. package/dist-cjs/components/TypeTester/TypeTesterToolbar.js +94 -0
  317. package/dist-cjs/components/TypeTester/TypeTesterVariableAxes.js +65 -0
  318. package/dist-cjs/components/TypeTester/features.js +150 -0
  319. package/dist-cjs/components/TypeTester/index.js +169 -0
  320. package/dist-cjs/components/TypeTester/types.js +14 -0
  321. package/dist-cjs/components/TypeTester/useFeaturesData.js +36 -0
  322. package/dist-cjs/components/TypeTester/useTypeTesterStyler.js +83 -0
  323. package/dist-cjs/components/TypeTesters/TypeTestersElement.js +33 -0
  324. package/dist-cjs/components/TypeTesters/index.js +271 -0
  325. package/dist-cjs/components/TypeTesters/index.server.js +44 -0
  326. package/dist-cjs/components/UrlContext.js +16 -0
  327. package/dist-cjs/components/VariableTableAmounts/index.js +28 -0
  328. package/dist-cjs/components/elements/Button/index.js +21 -0
  329. package/dist-cjs/components/elements/EmptyCart/index.js +30 -0
  330. package/dist-cjs/components/elements/StoreModalCartLayout/index.js +38 -0
  331. package/dist-cjs/components/elements/StoreModalContainer/StoreModalContainerContext.js +11 -0
  332. package/dist-cjs/components/elements/StoreModalContainer/index.js +77 -0
  333. package/dist-cjs/components/elements/StoreModalDownloadLayout/index.js +25 -0
  334. package/dist-cjs/components/elements/StoreModalFamily/index.js +31 -0
  335. package/dist-cjs/components/elements/StoreModalFamilyButton/index.js +45 -0
  336. package/dist-cjs/components/elements/StoreModalIndexItem/index.js +35 -0
  337. package/dist-cjs/components/elements/StoreModalLicenseeIsBillingIdentityElement.js +59 -0
  338. package/dist-cjs/components/elements/StoreModalLoadingScreen/index.js +14 -0
  339. package/dist-cjs/components/elements/StoreModalPageContainer/index.js +22 -0
  340. package/dist-cjs/components/elements/StoreModalStyleButton/index.js +37 -0
  341. package/dist-cjs/components/elements/StoreModalUnifiedCheckout.js +753 -0
  342. package/dist-cjs/components/useConsent.js +26 -0
  343. package/dist-cjs/components/useFont.js +76 -0
  344. package/dist-cjs/components/useFontStyle.js +58 -0
  345. package/dist-cjs/components/useInterval.js +28 -0
  346. package/dist-cjs/components/useTotalStyles.js +26 -0
  347. package/dist-cjs/config.js +27 -0
  348. package/dist-cjs/corsError.js +89 -0
  349. package/dist-cjs/data/unicodeData.js +1 -0
  350. package/dist-cjs/fontLoader.js +55 -0
  351. package/dist-cjs/global-shim.js +12 -0
  352. package/dist-cjs/hooks/useAutofit.js +114 -0
  353. package/dist-cjs/hooks/useLicenseAndOrderVariables.js +25 -0
  354. package/dist-cjs/hooks/useRefetchOnLicenseChanges.js +60 -0
  355. package/dist-cjs/hooks.js +18 -0
  356. package/dist-cjs/index.js +18 -0
  357. package/dist-cjs/package.json +1 -0
  358. package/dist-cjs/react-ranger.d.js +1 -0
  359. package/dist-cjs/react-ranger.js +301 -0
  360. package/dist-cjs/reducer.js +291 -0
  361. package/dist-cjs/relay/environment.js +148 -0
  362. package/dist-cjs/relay/loadSerializableQuery.js +57 -0
  363. package/dist-cjs/relay/useSerializablePreloadedQuery.js +52 -0
  364. package/dist-cjs/retryImport.js +24 -0
  365. package/dist-cjs/scripts/updateUnicodeData.js +49 -0
  366. package/dist-cjs/utils.js +107 -0
  367. package/dist-cjs/vanilla/FontStyle.js +58 -0
  368. package/dist-cjs/vanilla/TruncatedMarkdown.js +28 -0
  369. package/package.json +1 -1
  370. package/dist/__generated__/CartItem_license.graphql.d.ts +0 -27
  371. package/dist/__generated__/CartItem_licenseSelection.graphql.d.ts +0 -34
  372. package/dist/__generated__/CartItem_product.graphql.d.ts +0 -32
  373. package/dist/__generated__/CartItem_variable.graphql.d.ts +0 -23
  374. package/dist/__generated__/CartItem_viewer.graphql.d.ts +0 -30
  375. package/dist/__generated__/CartOrderApplyCouponMutation.graphql.d.ts +0 -21
  376. package/dist/__generated__/CartStateApplyCouponMutation.graphql.d.ts +0 -21
  377. package/dist/__generated__/CartStateApplyCouponMutation.graphql.js +0 -274
  378. package/dist/__generated__/CartTotalsCreateSnapshotMutation.graphql.d.ts +0 -22
  379. package/dist/__generated__/Cart_viewer.graphql.d.ts +0 -20
  380. package/dist/__generated__/CharacterViewer_Query.graphql.d.ts +0 -21
  381. package/dist/__generated__/CharacterViewer_Query.graphql.js +0 -230
  382. package/dist/__generated__/CharacterViewer_SlugQuery.graphql.d.ts +0 -25
  383. package/dist/__generated__/CharacterViewer_SlugQuery.graphql.js +0 -257
  384. package/dist/__generated__/CouponCodeInput_Refetch_Query.graphql.d.ts +0 -17
  385. package/dist/__generated__/CouponCodeInput_Refetch_Query.graphql.js +0 -201
  386. package/dist/__generated__/CouponCodeInput_order.graphql.d.ts +0 -13
  387. package/dist/__generated__/CouponCodeInput_viewer.graphql.d.ts +0 -25
  388. package/dist/__generated__/CouponCodeInput_viewer.graphql.js +0 -88
  389. package/dist/__generated__/CouponCodeRefetchQuery.graphql.d.ts +0 -22
  390. package/dist/__generated__/CouponCodeRefetchQuery.graphql.js +0 -178
  391. package/dist/__generated__/Family_viewer.graphql.d.ts +0 -17
  392. package/dist/__generated__/FontFamilies_node.graphql.d.ts +0 -20
  393. package/dist/__generated__/NewsletterSignup_Query.graphql.d.ts +0 -21
  394. package/dist/__generated__/NewsletterSignup_viewer.graphql.d.ts +0 -20
  395. package/dist/__generated__/NewsletterSignup_viewer.graphql.js +0 -56
  396. package/dist/__generated__/OrderVariableSelectionMutation.graphql.d.ts +0 -69
  397. package/dist/__generated__/OrderVariableSelectionMutation_viewer.graphql.d.ts +0 -30
  398. package/dist/__generated__/PriceBarSection_RefetchQuery.graphql.d.ts +0 -26
  399. package/dist/__generated__/PriceBarSection_viewer.graphql.d.ts +0 -17
  400. package/dist/__generated__/PriceBar_viewer.graphql.d.ts +0 -17
  401. package/dist/__generated__/SKUPriceRefetchQuery.graphql.d.ts +0 -31
  402. package/dist/__generated__/SKUPriceRefetchQuery.graphql.js +0 -130
  403. package/dist/__generated__/SKUPriceUpdateQuery.graphql.d.ts +0 -29
  404. package/dist/__generated__/SKUPrice_RefetchQuery.graphql.d.ts +0 -26
  405. package/dist/__generated__/SKUPrice_viewer.graphql.d.ts +0 -19
  406. package/dist/__generated__/SelectButton_viewer.graphql.d.ts +0 -17
  407. package/dist/__generated__/SpecimenLink_node.graphql.d.ts +0 -21
  408. package/dist/__generated__/StoreModalBundleButton_viewer.graphql.d.ts +0 -17
  409. package/dist/__generated__/StoreModalFamilyButton_viewer.graphql.d.ts +0 -17
  410. package/dist/__generated__/StoreModalFamily_viewer.graphql.d.ts +0 -17
  411. package/dist/__generated__/StoreModalOrderVariableSelectionHookQuery.graphql.d.ts +0 -26
  412. package/dist/__generated__/StoreModalOrderVariableSelectionOrderUpdateMutation.graphql.d.ts +0 -60
  413. package/dist/__generated__/StoreModalOrderVariableSelectionRefetchQuery.graphql.d.ts +0 -26
  414. package/dist/__generated__/StoreModalOrderVariableSelectionVariable_order.graphql.d.ts +0 -27
  415. package/dist/__generated__/StoreModalOrderVariableSelectionVariable_variable.graphql.d.ts +0 -24
  416. package/dist/__generated__/StoreModalProductContent_viewer.graphql.d.ts +0 -30
  417. package/dist/__generated__/StoreModalProductLicenseSelection_viewer.graphql.d.ts +0 -20
  418. package/dist/__generated__/StoreModalProductViewerRefetchQuery.graphql.d.ts +0 -31
  419. package/dist/__generated__/StoreModalReviewCompleteOrderMutation.graphql.d.ts +0 -25
  420. package/dist/__generated__/StoreModalReviewQuery.graphql.d.ts +0 -22
  421. package/dist/__generated__/StoreModalReviewUpdateOrderMutation.graphql.d.ts +0 -63
  422. package/dist/__generated__/StoreModalReview_order.graphql.d.ts +0 -59
  423. package/dist/__generated__/StoreModalReview_viewer.graphql.d.ts +0 -19
  424. package/dist/__generated__/StoreModalStyleButton_viewer.graphql.d.ts +0 -17
  425. package/dist/__generated__/TestFontsForm_viewer.graphql.d.ts +0 -29
  426. package/dist/__generated__/TestModeBanner_viewer.graphql.d.ts +0 -23
  427. package/dist/__generated__/ThemeConfig_viewer.graphql.d.ts +0 -19
  428. package/dist/__generated__/TypeTesterStandalone_StyleQuery.graphql.d.ts +0 -32
  429. package/dist/__generated__/TypeTesterStandalone_StyleQuery.graphql.js +0 -385
  430. package/dist/__generated__/TypeTesterStyleSelect_family.graphql.d.ts +0 -33
  431. package/dist/__generated__/TypeTesterStyleSelect_fontStyle.graphql.d.ts +0 -27
  432. package/dist/__generated__/TypeTester_NewStyleQuery.graphql.d.ts +0 -41
  433. package/dist/__generated__/TypeTester_sku.graphql.d.ts +0 -21
  434. package/dist/__generated__/useOrderVariables_order.graphql.d.ts +0 -24
  435. package/dist/components/BuyButton/BuyButton.server.d.ts +0 -3
  436. package/dist/components/CartButton/index-server.d.ts +0 -3
  437. package/dist/components/CartButton/index-server.js +0 -18
  438. package/dist/components/OrderVariableSelection/OrderVariableSelectionMutation.d.ts +0 -7
  439. package/dist/components/SelectField/index.d.ts +0 -13
  440. package/dist/components/SelectField/index.js +0 -49
  441. package/dist/components/StoreModal/StoreModalReview.d.ts +0 -6
  442. package/dist/components/StoreModal/StoreModalReview.js +0 -221
  443. package/dist/components/StoreModal/StoreModalRouterContext.d.ts +0 -7
  444. package/dist/components/StoreModal/StoreModalRouterContext.js +0 -11
  445. package/dist/components/StoreModal/createRouter.d.ts +0 -41
  446. package/dist/components/StoreModal/createRouter.js +0 -48
  447. package/dist/components/StoreModalProductLicenseSelection/ContainerElement.d.ts +0 -9
  448. package/dist/components/StoreModalProductLicenseSelection/ContainerElement.js +0 -25
  449. package/dist/components/Stylesheet/index.d.ts +0 -7
  450. package/dist/components/Stylesheet/index.js +0 -43
  451. package/dist/components/TestModeBanner/index.server.d.ts +0 -2
  452. package/dist/components/TestModeBanner/index.server.js +0 -17
  453. package/dist/components/elements/StoreModalReviewConfirm/index.d.ts +0 -12
  454. package/dist/components/elements/StoreModalReviewConfirm/index.js +0 -50
  455. package/dist/components/elements/StoreModalReviewItem/index.d.ts +0 -9
  456. package/dist/components/elements/StoreModalReviewItem/index.js +0 -21
  457. package/dist/components/elements/StoreModalReviewLayout/index.d.ts +0 -17
  458. package/dist/components/elements/StoreModalReviewLayout/index.js +0 -59
  459. package/dist/components/useFontLoaded.d.ts +0 -24
  460. package/dist/components/useFontLoaded.js +0 -60
  461. package/dist/deepMerge.d.ts +0 -4
  462. package/dist/deepMerge.js +0 -24
  463. package/dist/hooks/useOrderVariables.d.ts +0 -5
  464. package/dist/relay-environment.d.ts +0 -7
  465. package/dist/relay-environment.js +0 -34
  466. package/dist/utils/interpolateOrderVariableDescription.d.ts +0 -36
  467. package/dist/utils/interpolateOrderVariableDescription.test.d.ts +0 -1
  468. /package/dist/{__tests__/collectionBundleSelection.test.d.ts → global-shim.d.ts} +0 -0
@@ -0,0 +1,208 @@
1
+ "use strict";
2
+ 'use client';
3
+
4
+ Object.defineProperty(exports, "__esModule", {
5
+ value: true
6
+ });
7
+ exports.TestFontsFormPreloadedQueryRenderer = TestFontsFormPreloadedQueryRenderer;
8
+ exports.default = TestFontsForm;
9
+ var _TestFontsForm_Query2 = _interopRequireDefault(require("../../__generated__/TestFontsForm_Query.graphql"));
10
+ var _TestFontsFormUpdateCustomerMutation2 = _interopRequireDefault(require("../../__generated__/TestFontsFormUpdateCustomerMutation.graphql"));
11
+ var _react = _interopRequireWildcard(require("react"));
12
+ var _reactRelay = require("react-relay");
13
+ var _reactGoogleRecaptcha = _interopRequireDefault(require("react-google-recaptcha"));
14
+ var _TextField = _interopRequireDefault(require("../TextField"));
15
+ var _Icons = require("../Icons");
16
+ var _Checkbox = _interopRequireDefault(require("../Checkbox"));
17
+ var _useSerializablePreloadedQuery = _interopRequireDefault(require("../../relay/useSerializablePreloadedQuery"));
18
+ function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function (e) { return e ? t : r; })(e); }
19
+ function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != typeof e && "function" != typeof e) return { default: e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && {}.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n.default = e, t && t.set(e, n), n; }
20
+ function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
21
+ function _extends() { return _extends = Object.assign ? Object.assign.bind() : function (n) { for (var e = 1; e < arguments.length; e++) { var t = arguments[e]; for (var r in t) ({}).hasOwnProperty.call(t, r) && (n[r] = t[r]); } return n; }, _extends.apply(null, arguments); }
22
+ const updateCustomerMutation = (_TestFontsFormUpdateCustomerMutation2.default.hash && _TestFontsFormUpdateCustomerMutation2.default.hash !== "ba56958399f0893bd667ff02c33a6975" && console.error("The definition of 'TestFontsFormUpdateCustomerMutation' appears to have changed. Run `relay-compiler` to update the generated files to receive the expected data."), _TestFontsFormUpdateCustomerMutation2.default);
23
+ const TestFontsDownloading = ({
24
+ archiveUrl
25
+ }) => /*#__PURE__*/_react.default.createElement("div", {
26
+ className: "test-fonts__downloading"
27
+ }, /*#__PURE__*/_react.default.createElement("div", {
28
+ className: "test-fonts__downloading__icon"
29
+ }, /*#__PURE__*/_react.default.createElement(_Icons.DownloadFonts, null)), /*#__PURE__*/_react.default.createElement("div", null, /*#__PURE__*/_react.default.createElement("p", null, "The download will start automatically."), /*#__PURE__*/_react.default.createElement("p", null, "If it didn\u2019t start, click ", /*#__PURE__*/_react.default.createElement("a", {
30
+ href: archiveUrl
31
+ }, "here"), ".")));
32
+ const TestFontsFormComponent = ({
33
+ data,
34
+ agreementLabel,
35
+ downloadLabel = 'Download test fonts',
36
+ newsletterCheckboxChecked = false
37
+ }) => {
38
+ const [email, setEmail] = (0, _react.useState)('');
39
+ const [name, setName] = (0, _react.useState)('');
40
+ const [newsletterOptIn, setNewsletterOptIn] = (0, _react.useState)(newsletterCheckboxChecked);
41
+ const [error, setError] = (0, _react.useState)(null);
42
+ const [eulaAgreed, setEulaAgreed] = (0, _react.useState)(false);
43
+ const [eulaFail, setEulaFail] = (0, _react.useState)(false);
44
+ const [submitting, setSubmitting] = (0, _react.useState)(false);
45
+ const [submitted, setSubmitted] = (0, _react.useState)(false);
46
+ const [recaptchaToken, setRecaptchaToken] = (0, _react.useState)(null);
47
+ const [pendingSubmit, setPendingSubmit] = (0, _react.useState)(false);
48
+ const downloadForm = (0, _react.useRef)(null);
49
+ const recaptchaRef = (0, _react.useRef)(null);
50
+ const environment = (0, _reactRelay.useRelayEnvironment)();
51
+ if (!data.viewer) return null;
52
+ const recaptchaEnabled = data.viewer.settings?.recaptchaEnabled ?? false;
53
+ const recaptchaSiteKey = data.viewer.settings?.recaptchaSiteKey;
54
+ const submitForm = (0, _react.useCallback)(token => {
55
+ setSubmitting(true);
56
+ setPendingSubmit(false);
57
+ setError(null);
58
+ (0, _reactRelay.commitMutation)(environment, {
59
+ mutation: updateCustomerMutation,
60
+ variables: {
61
+ input: {
62
+ name,
63
+ email,
64
+ newsletterOptIn,
65
+ recaptchaToken: token ?? undefined
66
+ }
67
+ },
68
+ onCompleted: (res, errors) => {
69
+ if (errors && errors.length > 0) {
70
+ setError(errors[0].message);
71
+ setSubmitting(false);
72
+ // Reset reCAPTCHA on error so user can retry
73
+ recaptchaRef.current?.reset();
74
+ setRecaptchaToken(null);
75
+ } else {
76
+ downloadForm.current?.submit();
77
+ setSubmitted(true);
78
+ setSubmitting(false);
79
+ setError(null);
80
+ }
81
+ },
82
+ onError: ({
83
+ message
84
+ }) => {
85
+ setError(message);
86
+ setSubmitting(false);
87
+ // Reset reCAPTCHA on error so user can retry
88
+ recaptchaRef.current?.reset();
89
+ setRecaptchaToken(null);
90
+ }
91
+ });
92
+ }, [environment, name, email, newsletterOptIn]);
93
+ const handleRecaptchaChange = (0, _react.useCallback)(token => {
94
+ setRecaptchaToken(token);
95
+ // If we were waiting for a token to submit, do it now
96
+ if (token && pendingSubmit) {
97
+ submitForm(token);
98
+ }
99
+ }, [pendingSubmit, submitForm]);
100
+ const handleRecaptchaExpired = (0, _react.useCallback)(() => {
101
+ setRecaptchaToken(null);
102
+ }, []);
103
+ const handleSubmit = e => {
104
+ e.preventDefault();
105
+ if (!eulaAgreed) {
106
+ setEulaFail(true);
107
+ return;
108
+ }
109
+
110
+ // If reCAPTCHA is enabled but no token, execute it and wait for callback
111
+ if (recaptchaEnabled && recaptchaSiteKey && !recaptchaToken) {
112
+ setPendingSubmit(true);
113
+ setError(null);
114
+ recaptchaRef.current?.execute();
115
+ return;
116
+ }
117
+ submitForm(recaptchaToken);
118
+ };
119
+
120
+ // Button is disabled only while actively submitting or waiting for reCAPTCHA
121
+ const disabled = !eulaAgreed || !email || !name;
122
+ const settings = data.viewer.settings;
123
+ const newsletterOptInLabel = settings?.newsletterOptInLabel;
124
+ const eulaAgreementLabel = settings?.eulaAgreementLabel;
125
+ const archiveUrl = data.viewer.testFonts?.archiveUrl;
126
+ return /*#__PURE__*/_react.default.createElement("div", {
127
+ className: "test-fonts"
128
+ }, error && /*#__PURE__*/_react.default.createElement("div", {
129
+ className: "test-fonts__errors"
130
+ }, error), submitted ? /*#__PURE__*/_react.default.createElement(TestFontsDownloading, {
131
+ archiveUrl: archiveUrl
132
+ }) : /*#__PURE__*/_react.default.createElement("form", {
133
+ className: "test-fonts__form",
134
+ onSubmit: handleSubmit
135
+ }, /*#__PURE__*/_react.default.createElement("div", {
136
+ className: "test-fonts__section"
137
+ }, /*#__PURE__*/_react.default.createElement(_TextField.default, {
138
+ label: "Name *",
139
+ value: name,
140
+ onChange: value => setName(value),
141
+ autocomplete: "name",
142
+ placeholder: "Your name"
143
+ })), /*#__PURE__*/_react.default.createElement("div", {
144
+ className: "test-fonts__section"
145
+ }, /*#__PURE__*/_react.default.createElement(_TextField.default, {
146
+ label: "Email *",
147
+ type: "email",
148
+ value: email,
149
+ onChange: value => setEmail(value),
150
+ autocomplete: "email",
151
+ placeholder: "Your email"
152
+ })), /*#__PURE__*/_react.default.createElement("div", {
153
+ className: "test-fonts__agreement test-fonts__checkbox-field",
154
+ "data-highlighted": eulaFail && !eulaAgreed
155
+ }, /*#__PURE__*/_react.default.createElement(_Checkbox.default, {
156
+ id: "test-fonts-eula-agreement",
157
+ checked: eulaAgreed,
158
+ onChange: event => setEulaAgreed(event.target.checked)
159
+ }), /*#__PURE__*/_react.default.createElement("label", {
160
+ htmlFor: "test-fonts-eula-agreement",
161
+ dangerouslySetInnerHTML: {
162
+ __html: (agreementLabel || eulaAgreementLabel) ?? ''
163
+ }
164
+ })), newsletterOptInLabel && /*#__PURE__*/_react.default.createElement("div", {
165
+ className: "test-fonts__newsletter-opt-in test-fonts__checkbox-field"
166
+ }, /*#__PURE__*/_react.default.createElement(_Checkbox.default, {
167
+ id: "newsletter-opt-in",
168
+ checked: newsletterOptIn,
169
+ onChange: event => setNewsletterOptIn(event.target.checked)
170
+ }), /*#__PURE__*/_react.default.createElement("label", {
171
+ htmlFor: "newsletter-opt-in",
172
+ dangerouslySetInnerHTML: {
173
+ __html: newsletterOptInLabel
174
+ }
175
+ })), recaptchaEnabled && recaptchaSiteKey && /*#__PURE__*/_react.default.createElement(_reactGoogleRecaptcha.default, {
176
+ ref: recaptchaRef,
177
+ sitekey: recaptchaSiteKey,
178
+ size: "invisible",
179
+ onChange: handleRecaptchaChange,
180
+ onExpired: handleRecaptchaExpired
181
+ }), /*#__PURE__*/_react.default.createElement("div", null, /*#__PURE__*/_react.default.createElement("button", {
182
+ className: "submit-button",
183
+ type: "submit",
184
+ disabled: submitting || pendingSubmit || disabled
185
+ }, submitting || pendingSubmit ? 'Submitting...' : downloadLabel, /*#__PURE__*/_react.default.createElement("span", {
186
+ className: "submit-button__arrow"
187
+ }, " \u2192")))), /*#__PURE__*/_react.default.createElement("form", {
188
+ action: archiveUrl ?? undefined,
189
+ ref: downloadForm
190
+ }));
191
+ };
192
+ const query = (_TestFontsForm_Query2.default.hash && _TestFontsForm_Query2.default.hash !== "cd43f0cacc4dcf01cf94fb1ff97197ca" && console.error("The definition of 'TestFontsForm_Query' appears to have changed. Run `relay-compiler` to update the generated files to receive the expected data."), _TestFontsForm_Query2.default);
193
+ function TestFontsFormPreloadedQueryRenderer({
194
+ preloadedQuery,
195
+ ...rest
196
+ }) {
197
+ const queryRef = (0, _useSerializablePreloadedQuery.default)(preloadedQuery);
198
+ const data = (0, _reactRelay.usePreloadedQuery)(query, queryRef);
199
+ return /*#__PURE__*/_react.default.createElement(TestFontsFormComponent, _extends({
200
+ data: data
201
+ }, rest));
202
+ }
203
+ function TestFontsForm(props) {
204
+ const data = (0, _reactRelay.useLazyLoadQuery)(query, {});
205
+ return /*#__PURE__*/_react.default.createElement(TestFontsFormComponent, _extends({
206
+ data: data
207
+ }, props));
208
+ }
@@ -0,0 +1,18 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.default = TestFontsForm;
7
+ var _react = _interopRequireDefault(require("react"));
8
+ var _loadSerializableQuery = _interopRequireDefault(require("../../relay/loadSerializableQuery"));
9
+ var _index = require("./index");
10
+ var _TestFontsForm_Query = _interopRequireDefault(require("../../__generated__/TestFontsForm_Query.graphql"));
11
+ function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
12
+ function _extends() { return _extends = Object.assign ? Object.assign.bind() : function (n) { for (var e = 1; e < arguments.length; e++) { var t = arguments[e]; for (var r in t) ({}).hasOwnProperty.call(t, r) && (n[r] = t[r]); } return n; }, _extends.apply(null, arguments); }
13
+ async function TestFontsForm(props) {
14
+ const preloadedQuery = await (0, _loadSerializableQuery.default)(_TestFontsForm_Query.default, {});
15
+ return /*#__PURE__*/_react.default.createElement(_index.TestFontsFormPreloadedQueryRenderer, _extends({
16
+ preloadedQuery: preloadedQuery
17
+ }, props));
18
+ }
@@ -0,0 +1,34 @@
1
+ "use strict";
2
+ 'use client';
3
+
4
+ Object.defineProperty(exports, "__esModule", {
5
+ value: true
6
+ });
7
+ exports.default = TestModeBanner;
8
+ var _TestModeBannerQuery2 = _interopRequireDefault(require("../../__generated__/TestModeBannerQuery.graphql"));
9
+ var _react = _interopRequireDefault(require("react"));
10
+ var _reactRelay = require("react-relay");
11
+ function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
12
+ function TestModeBannerComponent({
13
+ data
14
+ }) {
15
+ const isActive = data?.viewer?.testMode?.isActive;
16
+
17
+ // hide the banner completely if we're in live mode
18
+ if (!isActive) return null;
19
+ return /*#__PURE__*/_react.default.createElement("div", {
20
+ className: "test-mode-banner__banner",
21
+ "data-test-mode": isActive
22
+ }, /*#__PURE__*/_react.default.createElement("div", {
23
+ className: "test-mode-banner__content"
24
+ }, /*#__PURE__*/_react.default.createElement("div", {
25
+ className: "test-mode-banner__title"
26
+ }, "Viewing test data")));
27
+ }
28
+ const query = (_TestModeBannerQuery2.default.hash && _TestModeBannerQuery2.default.hash !== "60ad67ee88ec6b74dd04bdf5572e7faf" && console.error("The definition of 'TestModeBannerQuery' appears to have changed. Run `relay-compiler` to update the generated files to receive the expected data."), _TestModeBannerQuery2.default);
29
+ function TestModeBanner() {
30
+ const data = (0, _reactRelay.useLazyLoadQuery)(query, {});
31
+ return /*#__PURE__*/_react.default.createElement(TestModeBannerComponent, {
32
+ data: data
33
+ });
34
+ }
@@ -0,0 +1,42 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.default = void 0;
7
+ var _react = _interopRequireDefault(require("react"));
8
+ function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
9
+ function _extends() { return _extends = Object.assign ? Object.assign.bind() : function (n) { for (var e = 1; e < arguments.length; e++) { var t = arguments[e]; for (var r in t) ({}).hasOwnProperty.call(t, r) && (n[r] = t[r]); } return n; }, _extends.apply(null, arguments); }
10
+ const TextField = ({
11
+ Component = 'input',
12
+ autocomplete,
13
+ label,
14
+ type = 'text',
15
+ onChange,
16
+ errors,
17
+ // string[] | null
18
+ prefix,
19
+ ...rest
20
+ }) => /*#__PURE__*/_react.default.createElement("label", {
21
+ className: "text-field__label",
22
+ "data-has-error": errors ? true : undefined
23
+ }, /*#__PURE__*/_react.default.createElement("div", {
24
+ className: "text-field__label-wrapper"
25
+ }, label), /*#__PURE__*/_react.default.createElement("div", {
26
+ className: "text-field__input-wrapper"
27
+ }, /*#__PURE__*/_react.default.createElement("span", {
28
+ className: "text-field__prefix"
29
+ }, prefix), Component === 'input' && /*#__PURE__*/_react.default.createElement("input", _extends({}, rest, {
30
+ type: type,
31
+ onChange: e => onChange(e.target.value),
32
+ className: "text-field__input",
33
+ autoComplete: autocomplete
34
+ })), Component === 'textarea' && /*#__PURE__*/_react.default.createElement("textarea", _extends({}, rest, {
35
+ onChange: e => onChange(e.target.value),
36
+ className: "text-field__input",
37
+ autoComplete: autocomplete
38
+ }))), errors && errors.length > 0 && /*#__PURE__*/_react.default.createElement("p", {
39
+ className: "text-field__error"
40
+ }, errors[0]));
41
+ var _default = TextField;
42
+ exports.default = _default;
@@ -0,0 +1,41 @@
1
+ "use strict";
2
+ 'use client';
3
+
4
+ Object.defineProperty(exports, "__esModule", {
5
+ value: true
6
+ });
7
+ exports.ThemeConfigPreloadedQueryRenderer = ThemeConfigPreloadedQueryRenderer;
8
+ exports.default = ThemeConfig;
9
+ var _ThemeConfigQuery2 = _interopRequireDefault(require("../../__generated__/ThemeConfigQuery.graphql"));
10
+ var _react = _interopRequireDefault(require("react"));
11
+ var _reactRelay = require("react-relay");
12
+ var _useSerializablePreloadedQuery = _interopRequireDefault(require("../../relay/useSerializablePreloadedQuery"));
13
+ function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
14
+ // gets the custom properties entered by users in the admin panel,
15
+ // which also includes default values. we put the defaults there instead of
16
+ // every call to var() so that we have defaults all in one place
17
+
18
+ function ThemeConfigComponent({
19
+ data
20
+ }) {
21
+ const props = data.viewer.themeConfig?.customProperties ?? [];
22
+ return /*#__PURE__*/_react.default.createElement("style", {
23
+ type: "text/css"
24
+ }, `:root { ${props.join(';')} }`);
25
+ }
26
+ const query = (_ThemeConfigQuery2.default.hash && _ThemeConfigQuery2.default.hash !== "c259bee038c4d2ea14c758fba3381f57" && console.error("The definition of 'ThemeConfigQuery' appears to have changed. Run `relay-compiler` to update the generated files to receive the expected data."), _ThemeConfigQuery2.default);
27
+ function ThemeConfigPreloadedQueryRenderer({
28
+ preloadedQuery
29
+ }) {
30
+ const queryRef = (0, _useSerializablePreloadedQuery.default)(preloadedQuery);
31
+ const data = (0, _reactRelay.usePreloadedQuery)(query, queryRef);
32
+ return /*#__PURE__*/_react.default.createElement(ThemeConfigComponent, {
33
+ data: data
34
+ });
35
+ }
36
+ function ThemeConfig() {
37
+ const data = (0, _reactRelay.useLazyLoadQuery)(query, {});
38
+ return /*#__PURE__*/_react.default.createElement(ThemeConfigComponent, {
39
+ data: data
40
+ });
41
+ }
@@ -0,0 +1,17 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.default = ThemeConfig;
7
+ var _react = _interopRequireDefault(require("react"));
8
+ var _loadSerializableQuery = _interopRequireDefault(require("../../relay/loadSerializableQuery"));
9
+ var _index = require("./index");
10
+ var _ThemeConfigQuery = _interopRequireDefault(require("../../__generated__/ThemeConfigQuery.graphql"));
11
+ function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
12
+ async function ThemeConfig() {
13
+ const preloadedQuery = await (0, _loadSerializableQuery.default)(_ThemeConfigQuery.default, {});
14
+ return /*#__PURE__*/_react.default.createElement(_index.ThemeConfigPreloadedQueryRenderer, {
15
+ preloadedQuery: preloadedQuery
16
+ });
17
+ }
@@ -0,0 +1,164 @@
1
+ "use strict";
2
+ 'use client';
3
+
4
+ Object.defineProperty(exports, "__esModule", {
5
+ value: true
6
+ });
7
+ exports.default = void 0;
8
+ var _react = require("react");
9
+ var _ConfigContext = _interopRequireDefault(require("../ConfigContext"));
10
+ var _UrlContext = require("../UrlContext");
11
+ var _consent = require("../ConsentBanner/consent");
12
+ function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
13
+ function getCampaignDataFromUrl() {
14
+ const urlParams = new URLSearchParams(window.location.search);
15
+ const campaign = {};
16
+ const properties = {};
17
+ let hasCampaign = false;
18
+ let hasProperties = false;
19
+ const utmMapping = {
20
+ utm_source: 'source',
21
+ utm_medium: 'medium',
22
+ utm_campaign: 'name',
23
+ utm_term: 'term',
24
+ utm_content: 'content'
25
+ };
26
+ for (const [urlParam, campaignKey] of Object.entries(utmMapping)) {
27
+ const value = urlParams.get(urlParam);
28
+ if (value) {
29
+ campaign[campaignKey] = value;
30
+ hasCampaign = true;
31
+ }
32
+ }
33
+ const clickIds = ['gclid', 'fbclid'];
34
+ for (const param of clickIds) {
35
+ const value = urlParams.get(param);
36
+ if (value) {
37
+ properties[param] = value;
38
+ hasProperties = true;
39
+ }
40
+ }
41
+ return {
42
+ campaign: hasCampaign ? campaign : null,
43
+ properties: hasProperties ? properties : null
44
+ };
45
+ }
46
+ async function sendPageView(baseUrl, anonymousId) {
47
+ try {
48
+ const {
49
+ campaign,
50
+ properties: clickIdProperties
51
+ } = getCampaignDataFromUrl();
52
+ const properties = {
53
+ url: window.location.href,
54
+ path: window.location.pathname,
55
+ referrer: document.referrer,
56
+ title: document.title,
57
+ search: window.location.search,
58
+ ...clickIdProperties
59
+ };
60
+ const context = {
61
+ userAgent: navigator.userAgent
62
+ };
63
+ if (campaign) {
64
+ context.campaign = campaign;
65
+ }
66
+ const body = {
67
+ properties,
68
+ context
69
+ };
70
+ if (anonymousId) {
71
+ body.anonymous_id = anonymousId;
72
+ }
73
+ const response = await fetch(`${baseUrl}/api/track/page`, {
74
+ method: 'POST',
75
+ headers: {
76
+ 'Content-Type': 'application/json'
77
+ },
78
+ credentials: 'include',
79
+ body: JSON.stringify(body)
80
+ });
81
+ const data = await response.json();
82
+ return data.anonymous_id || null;
83
+ } catch (error) {
84
+ console.debug('Tracking error:', error);
85
+ return null;
86
+ }
87
+ }
88
+ const Tracking = () => {
89
+ const config = (0, _react.useContext)(_ConfigContext.default);
90
+ const url = (0, _UrlContext.useFontdueUrl)();
91
+ (0, _react.useEffect)(() => {
92
+ if (!config.tracking.enabled) return;
93
+
94
+ // Generate client-side anonymous ID for cookieless tracking when consent is required
95
+ const clientAnonymousId = config.tracking.consentRequired ? crypto.randomUUID() : undefined;
96
+ if (clientAnonymousId) {
97
+ (0, _consent.setClientAnonymousId)(clientAnonymousId);
98
+ }
99
+
100
+ // Only send the client ID when in cookieless mode (consent required but not yet granted)
101
+ const analyticsConsent = (0, _consent.hasConsent)('analytics');
102
+ const effectiveAnonymousId = clientAnonymousId && config.tracking.consentRequired && !analyticsConsent ? clientAnonymousId : undefined;
103
+
104
+ // Send initial page view
105
+ const pageViewPromise = sendPageView(url, effectiveAnonymousId);
106
+
107
+ // Segment SDK for device-mode integrations (e.g. Google Tag Manager)
108
+ // The analytics factory is provided by the entry point — it calls AnalyticsBrowser.load()
109
+ // when invoked. We defer calling it until after consent when consentRequired is true.
110
+ const loadAnalytics = config.tracking.segment?.analytics;
111
+ const integrations = config.tracking.segment?.integrations || {
112
+ All: false,
113
+ 'Google Tag Manager': true
114
+ };
115
+ let consentCleanup;
116
+ if (loadAnalytics) {
117
+ const fireSegmentPage = async () => {
118
+ try {
119
+ const analytics = loadAnalytics();
120
+ const anonymousId = await pageViewPromise;
121
+ if (anonymousId) {
122
+ await analytics.setAnonymousId(anonymousId);
123
+ }
124
+ await analytics.page(undefined, undefined, undefined, {
125
+ integrations
126
+ });
127
+ } catch (error) {
128
+ console.debug('Segment SDK error:', error);
129
+ }
130
+ };
131
+ if (config.tracking.consentRequired) {
132
+ consentCleanup = (0, _consent.onConsent)('analytics', fireSegmentPage);
133
+ } else {
134
+ fireSegmentPage();
135
+ }
136
+ }
137
+
138
+ // Track client-side route changes
139
+ const originalPushState = history.pushState.bind(history);
140
+ const originalReplaceState = history.replaceState.bind(history);
141
+ const handleRouteChange = () => {
142
+ // Defer slightly to let document.title update
143
+ setTimeout(() => sendPageView(url), 0);
144
+ };
145
+ history.pushState = function (...args) {
146
+ originalPushState(...args);
147
+ handleRouteChange();
148
+ };
149
+ history.replaceState = function (...args) {
150
+ originalReplaceState(...args);
151
+ handleRouteChange();
152
+ };
153
+ window.addEventListener('popstate', handleRouteChange);
154
+ return () => {
155
+ history.pushState = originalPushState;
156
+ history.replaceState = originalReplaceState;
157
+ window.removeEventListener('popstate', handleRouteChange);
158
+ consentCleanup?.();
159
+ };
160
+ }, []);
161
+ return null;
162
+ };
163
+ var _default = Tracking;
164
+ exports.default = _default;
@@ -0,0 +1,34 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.default = void 0;
7
+ var _react = _interopRequireDefault(require("react"));
8
+ var _Align = require("../Icons/Align");
9
+ function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
10
+ const TypeTesterAlignButtons = ({
11
+ alignment,
12
+ setAlignment
13
+ }) => {
14
+ return /*#__PURE__*/_react.default.createElement("div", {
15
+ className: "type-tester__align-buttons"
16
+ }, /*#__PURE__*/_react.default.createElement("button", {
17
+ type: "button",
18
+ className: "type-tester__align-buttons__button",
19
+ "data-active": alignment === 'left',
20
+ onClick: () => setAlignment('left')
21
+ }, /*#__PURE__*/_react.default.createElement(_Align.AlignLeft, null)), /*#__PURE__*/_react.default.createElement("button", {
22
+ type: "button",
23
+ className: "type-tester__align-buttons__button",
24
+ "data-active": alignment === 'center',
25
+ onClick: () => setAlignment('center')
26
+ }, /*#__PURE__*/_react.default.createElement(_Align.AlignCenter, null)), /*#__PURE__*/_react.default.createElement("button", {
27
+ type: "button",
28
+ className: "type-tester__align-buttons__button",
29
+ "data-active": alignment === 'right',
30
+ onClick: () => setAlignment('right')
31
+ }, /*#__PURE__*/_react.default.createElement(_Align.AlignRight, null)));
32
+ };
33
+ var _default = TypeTesterAlignButtons;
34
+ exports.default = _default;
@@ -0,0 +1,23 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.default = void 0;
7
+ var _react = _interopRequireDefault(require("react"));
8
+ function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
9
+ const Bullet = ({
10
+ checked,
11
+ config
12
+ }) => {
13
+ const props = {
14
+ className: 'type-tester__bullet',
15
+ 'data-checked': checked
16
+ };
17
+ if (config.bulletStyle === 'round') {
18
+ return /*#__PURE__*/_react.default.createElement("span", props, checked ? '●' : '○');
19
+ }
20
+ return /*#__PURE__*/_react.default.createElement("span", props, checked ? '■' : '□');
21
+ };
22
+ var _default = Bullet;
23
+ exports.default = _default;
@@ -0,0 +1,58 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.default = void 0;
7
+ var _react = _interopRequireWildcard(require("react"));
8
+ var _useTypeTesterStyler = _interopRequireDefault(require("./useTypeTesterStyler"));
9
+ var _draftJs = require("draft-js");
10
+ function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
11
+ function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function (e) { return e ? t : r; })(e); }
12
+ function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != typeof e && "function" != typeof e) return { default: e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && {}.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n.default = e, t && t.set(e, n), n; }
13
+ function _extends() { return _extends = Object.assign ? Object.assign.bind() : function (n) { for (var e = 1; e < arguments.length; e++) { var t = arguments[e]; for (var r in t) ({}).hasOwnProperty.call(t, r) && (n[r] = t[r]); } return n; }, _extends.apply(null, arguments); }
14
+ const TypeTesterContent = /*#__PURE__*/_react.default.forwardRef(({
15
+ content,
16
+ setContent,
17
+ setFocused,
18
+ direction,
19
+ alignment,
20
+ ...props
21
+ }, ref) => {
22
+ const editorRef = (0, _react.useRef)(null);
23
+ (0, _react.useImperativeHandle)(ref, () => ({
24
+ focus: () => {
25
+ editorRef.current?.focus();
26
+ }
27
+ }));
28
+ const style = (0, _useTypeTesterStyler.default)({
29
+ ...props,
30
+ content,
31
+ alignment
32
+ });
33
+
34
+ // draft-js's Editor produces different DOM than plain text on server (just
35
+ // the content string) vs client (full DraftEditor-* subtree). Hydrating
36
+ // that mismatch causes React to discard the SSR subtree and client-render
37
+ // the whole tester from scratch — visible as an unmount/remount flash.
38
+ // Defer Editor mount until after hydration so the initial client render
39
+ // matches the SSR output exactly.
40
+ const [mounted, setMounted] = (0, _react.useState)(false);
41
+ (0, _react.useEffect)(() => setMounted(true), []);
42
+ const plainText = content.getCurrentContent().getPlainText();
43
+ return /*#__PURE__*/_react.default.createElement("div", _extends({}, style, {
44
+ className: "type-tester__text__container"
45
+ }), mounted ? /*#__PURE__*/_react.default.createElement(_draftJs.Editor, {
46
+ ref: editorRef,
47
+ editorState: content,
48
+ onChange: value => setContent(value),
49
+ onBlur: () => setFocused(false),
50
+ onFocus: () => setFocused(true),
51
+ spellCheck: false,
52
+ stripPastedStyles: true,
53
+ textDirectionality: direction === 'rtl' ? 'RTL' : 'LTR',
54
+ textAlignment: alignment
55
+ }) : plainText);
56
+ });
57
+ var _default = TypeTesterContent;
58
+ exports.default = _default;