@shopify/ui-extensions 2.0.0-alpha.2 → 2022.10.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 (713) hide show
  1. package/build/cjs/index.js +1 -43
  2. package/build/cjs/surfaces/checkout/components/Banner/Banner.js +12 -0
  3. package/build/cjs/surfaces/checkout/components/BlockLayout/BlockLayout.js +14 -0
  4. package/build/cjs/surfaces/checkout/components/BlockSpacer/BlockSpacer.js +15 -0
  5. package/build/cjs/surfaces/checkout/components/BlockStack/BlockStack.js +12 -0
  6. package/build/cjs/surfaces/checkout/components/Button/Button.js +12 -0
  7. package/build/cjs/surfaces/checkout/components/Checkbox/Checkbox.js +12 -0
  8. package/build/cjs/surfaces/checkout/components/Choice/Choice.js +13 -0
  9. package/build/cjs/surfaces/checkout/components/ChoiceList/ChoiceList.js +13 -0
  10. package/build/cjs/surfaces/checkout/components/Divider/Divider.js +12 -0
  11. package/build/cjs/surfaces/checkout/components/Form/Form.js +20 -0
  12. package/build/cjs/surfaces/checkout/components/Grid/Grid.js +12 -0
  13. package/build/cjs/surfaces/checkout/components/GridItem/GridItem.js +14 -0
  14. package/build/cjs/surfaces/checkout/components/Heading/Heading.js +17 -0
  15. package/build/cjs/surfaces/checkout/components/HeadingGroup/HeadingGroup.js +16 -0
  16. package/build/cjs/surfaces/checkout/components/Icon/Icon.js +13 -0
  17. package/build/cjs/surfaces/checkout/components/Image/Image.js +12 -0
  18. package/build/cjs/surfaces/checkout/components/InlineLayout/InlineLayout.js +16 -0
  19. package/build/cjs/surfaces/checkout/components/InlineSpacer/InlineSpacer.js +15 -0
  20. package/build/cjs/surfaces/checkout/components/InlineStack/InlineStack.js +12 -0
  21. package/build/cjs/surfaces/checkout/components/Link/Link.js +12 -0
  22. package/build/cjs/surfaces/checkout/components/List/List.js +12 -0
  23. package/build/cjs/surfaces/checkout/components/ListItem/ListItem.js +14 -0
  24. package/build/cjs/surfaces/checkout/components/PhoneField/PhoneField.js +17 -0
  25. package/build/cjs/surfaces/checkout/components/Pressable/Pressable.js +14 -0
  26. package/build/cjs/surfaces/checkout/components/ScrollView/ScrollView.js +13 -0
  27. package/build/cjs/surfaces/checkout/components/Select/Select.js +13 -0
  28. package/build/cjs/surfaces/checkout/components/SkeletonImage/SkeletonImage.js +12 -0
  29. package/build/cjs/surfaces/checkout/components/SkeletonText/SkeletonText.js +12 -0
  30. package/build/cjs/surfaces/checkout/components/SkeletonTextBlock/SkeletonTextBlock.js +12 -0
  31. package/build/cjs/surfaces/checkout/components/Spinner/Spinner.js +13 -0
  32. package/build/cjs/surfaces/checkout/components/Stepper/Stepper.js +12 -0
  33. package/build/cjs/surfaces/checkout/components/Tag/Tag.js +12 -0
  34. package/build/cjs/surfaces/checkout/components/Text/Text.js +13 -0
  35. package/build/cjs/surfaces/checkout/components/TextBlock/TextBlock.js +12 -0
  36. package/build/cjs/surfaces/checkout/components/TextField/TextField.js +12 -0
  37. package/build/cjs/surfaces/checkout/components/Tooltip/Tooltip.js +17 -0
  38. package/build/cjs/surfaces/checkout/components/View/View.js +17 -0
  39. package/build/cjs/surfaces/checkout/extension.js +5 -23
  40. package/build/cjs/surfaces/checkout/index.js +82 -65
  41. package/build/cjs/surfaces/checkout/style/isEqual.js +29 -0
  42. package/build/cjs/surfaces/checkout/style/memoize.js +138 -0
  43. package/build/cjs/surfaces/checkout/style/style.js +74 -0
  44. package/build/cjs/utilities/registration.js +8 -98
  45. package/build/esm/index.mjs +1 -3
  46. package/build/esm/surfaces/checkout/components/Banner/Banner.mjs +8 -0
  47. package/build/esm/surfaces/checkout/components/BlockLayout/BlockLayout.mjs +10 -0
  48. package/build/esm/surfaces/checkout/components/BlockSpacer/BlockSpacer.mjs +11 -0
  49. package/build/esm/surfaces/checkout/components/BlockStack/BlockStack.mjs +8 -0
  50. package/build/esm/surfaces/checkout/components/Button/Button.mjs +8 -0
  51. package/build/esm/surfaces/checkout/components/Checkbox/Checkbox.mjs +8 -0
  52. package/build/esm/surfaces/checkout/components/Choice/Choice.mjs +9 -0
  53. package/build/esm/surfaces/checkout/components/ChoiceList/ChoiceList.mjs +9 -0
  54. package/build/esm/surfaces/checkout/components/Divider/Divider.mjs +8 -0
  55. package/build/esm/surfaces/checkout/components/Form/Form.mjs +16 -0
  56. package/build/esm/surfaces/checkout/components/Grid/Grid.mjs +8 -0
  57. package/build/esm/surfaces/checkout/components/GridItem/GridItem.mjs +10 -0
  58. package/build/esm/surfaces/checkout/components/Heading/Heading.mjs +13 -0
  59. package/build/esm/surfaces/checkout/components/HeadingGroup/HeadingGroup.mjs +12 -0
  60. package/build/esm/surfaces/checkout/components/Icon/Icon.mjs +9 -0
  61. package/build/esm/surfaces/checkout/components/Image/Image.mjs +8 -0
  62. package/build/esm/surfaces/checkout/components/InlineLayout/InlineLayout.mjs +12 -0
  63. package/build/esm/surfaces/checkout/components/InlineSpacer/InlineSpacer.mjs +11 -0
  64. package/build/esm/surfaces/checkout/components/InlineStack/InlineStack.mjs +8 -0
  65. package/build/esm/surfaces/checkout/components/Link/Link.mjs +8 -0
  66. package/build/esm/surfaces/checkout/components/List/List.mjs +8 -0
  67. package/build/esm/surfaces/checkout/components/ListItem/ListItem.mjs +10 -0
  68. package/build/esm/surfaces/checkout/components/PhoneField/PhoneField.mjs +13 -0
  69. package/build/esm/surfaces/checkout/components/Pressable/Pressable.mjs +10 -0
  70. package/build/esm/surfaces/checkout/components/ScrollView/ScrollView.mjs +9 -0
  71. package/build/esm/surfaces/checkout/components/Select/Select.mjs +9 -0
  72. package/build/esm/surfaces/checkout/components/SkeletonImage/SkeletonImage.mjs +8 -0
  73. package/build/esm/surfaces/checkout/components/SkeletonText/SkeletonText.mjs +8 -0
  74. package/build/esm/surfaces/checkout/components/SkeletonTextBlock/SkeletonTextBlock.mjs +8 -0
  75. package/build/esm/surfaces/checkout/components/Spinner/Spinner.mjs +9 -0
  76. package/build/esm/surfaces/checkout/components/Stepper/Stepper.mjs +8 -0
  77. package/build/esm/surfaces/checkout/components/Tag/Tag.mjs +8 -0
  78. package/build/esm/surfaces/checkout/components/Text/Text.mjs +9 -0
  79. package/build/esm/surfaces/checkout/components/TextBlock/TextBlock.mjs +8 -0
  80. package/build/esm/surfaces/checkout/components/TextField/TextField.mjs +8 -0
  81. package/build/esm/surfaces/checkout/components/Tooltip/Tooltip.mjs +13 -0
  82. package/build/esm/surfaces/checkout/components/View/View.mjs +13 -0
  83. package/build/esm/surfaces/checkout/extension.mjs +5 -3
  84. package/build/esm/surfaces/checkout/index.mjs +39 -5
  85. package/build/esm/surfaces/checkout/style/isEqual.mjs +25 -0
  86. package/build/esm/surfaces/checkout/style/memoize.mjs +132 -0
  87. package/build/esm/surfaces/checkout/style/style.mjs +68 -0
  88. package/build/esm/utilities/registration.mjs +7 -92
  89. package/build/esnext/index.esnext +1 -3
  90. package/build/esnext/surfaces/checkout/components/Banner/Banner.esnext +8 -0
  91. package/build/esnext/surfaces/checkout/components/BlockLayout/BlockLayout.esnext +10 -0
  92. package/build/esnext/surfaces/checkout/components/BlockSpacer/BlockSpacer.esnext +11 -0
  93. package/build/esnext/surfaces/checkout/components/BlockStack/BlockStack.esnext +8 -0
  94. package/build/esnext/surfaces/checkout/components/Button/Button.esnext +8 -0
  95. package/build/esnext/surfaces/checkout/components/Checkbox/Checkbox.esnext +8 -0
  96. package/build/esnext/surfaces/checkout/components/Choice/Choice.esnext +9 -0
  97. package/build/esnext/surfaces/checkout/components/ChoiceList/ChoiceList.esnext +9 -0
  98. package/build/esnext/surfaces/checkout/components/Divider/Divider.esnext +8 -0
  99. package/build/esnext/surfaces/checkout/components/Form/Form.esnext +16 -0
  100. package/build/esnext/surfaces/checkout/components/Grid/Grid.esnext +8 -0
  101. package/build/esnext/surfaces/checkout/components/GridItem/GridItem.esnext +10 -0
  102. package/build/esnext/surfaces/checkout/components/Heading/Heading.esnext +13 -0
  103. package/build/esnext/surfaces/checkout/components/HeadingGroup/HeadingGroup.esnext +12 -0
  104. package/build/esnext/surfaces/checkout/components/Icon/Icon.esnext +9 -0
  105. package/build/esnext/surfaces/checkout/components/Image/Image.esnext +8 -0
  106. package/build/esnext/surfaces/checkout/components/InlineLayout/InlineLayout.esnext +12 -0
  107. package/build/esnext/surfaces/checkout/components/InlineSpacer/InlineSpacer.esnext +11 -0
  108. package/build/esnext/surfaces/checkout/components/InlineStack/InlineStack.esnext +8 -0
  109. package/build/esnext/surfaces/checkout/components/Link/Link.esnext +8 -0
  110. package/build/esnext/surfaces/checkout/components/List/List.esnext +8 -0
  111. package/build/esnext/surfaces/checkout/components/ListItem/ListItem.esnext +10 -0
  112. package/build/esnext/surfaces/checkout/components/PhoneField/PhoneField.esnext +13 -0
  113. package/build/esnext/surfaces/checkout/components/Pressable/Pressable.esnext +10 -0
  114. package/build/esnext/surfaces/checkout/components/ScrollView/ScrollView.esnext +9 -0
  115. package/build/esnext/surfaces/checkout/components/Select/Select.esnext +9 -0
  116. package/build/esnext/surfaces/checkout/components/SkeletonImage/SkeletonImage.esnext +8 -0
  117. package/build/esnext/surfaces/checkout/components/SkeletonText/SkeletonText.esnext +8 -0
  118. package/build/esnext/surfaces/checkout/components/SkeletonTextBlock/SkeletonTextBlock.esnext +8 -0
  119. package/build/esnext/surfaces/checkout/components/Spinner/Spinner.esnext +9 -0
  120. package/build/esnext/surfaces/checkout/components/Stepper/Stepper.esnext +8 -0
  121. package/build/esnext/surfaces/checkout/components/Tag/Tag.esnext +8 -0
  122. package/build/esnext/surfaces/checkout/components/Text/Text.esnext +9 -0
  123. package/build/esnext/surfaces/checkout/components/TextBlock/TextBlock.esnext +8 -0
  124. package/build/esnext/surfaces/checkout/components/TextField/TextField.esnext +8 -0
  125. package/build/esnext/surfaces/checkout/components/Tooltip/Tooltip.esnext +13 -0
  126. package/build/esnext/surfaces/checkout/components/View/View.esnext +13 -0
  127. package/build/esnext/surfaces/checkout/extension.esnext +5 -3
  128. package/build/esnext/surfaces/checkout/index.esnext +39 -5
  129. package/build/esnext/surfaces/checkout/style/isEqual.esnext +25 -0
  130. package/build/esnext/surfaces/checkout/style/memoize.esnext +132 -0
  131. package/build/esnext/surfaces/checkout/style/style.esnext +68 -0
  132. package/build/esnext/utilities/registration.esnext +7 -28
  133. package/build/ts/api.d.ts +0 -4
  134. package/build/ts/api.d.ts.map +1 -1
  135. package/build/ts/extension.d.ts +2 -9
  136. package/build/ts/extension.d.ts.map +1 -1
  137. package/build/ts/index.d.ts +1 -1
  138. package/build/ts/index.d.ts.map +1 -1
  139. package/build/ts/surfaces/checkout/api/cart-line-details/render-after.d.ts +6 -3
  140. package/build/ts/surfaces/checkout/api/cart-line-details/render-after.d.ts.map +1 -1
  141. package/build/ts/surfaces/checkout/api/shared.d.ts +4 -3
  142. package/build/ts/surfaces/checkout/api/shared.d.ts.map +1 -1
  143. package/build/ts/surfaces/checkout/api/standard/standard.d.ts +1046 -2
  144. package/build/ts/surfaces/checkout/api/standard/standard.d.ts.map +1 -1
  145. package/build/ts/surfaces/checkout/components/Banner/Banner.d.ts +38 -0
  146. package/build/ts/surfaces/checkout/components/Banner/Banner.d.ts.map +1 -0
  147. package/build/ts/surfaces/checkout/components/Banner/examples/basic-banner.example.d.ts +2 -0
  148. package/build/ts/surfaces/checkout/components/Banner/examples/basic-banner.example.d.ts.map +1 -0
  149. package/build/ts/surfaces/checkout/components/BlockLayout/BlockLayout.d.ts +41 -0
  150. package/build/ts/surfaces/checkout/components/BlockLayout/BlockLayout.d.ts.map +1 -0
  151. package/build/ts/surfaces/checkout/components/BlockLayout/examples/basic-blockLayout.example.d.ts +2 -0
  152. package/build/ts/surfaces/checkout/components/BlockLayout/examples/basic-blockLayout.example.d.ts.map +1 -0
  153. package/build/ts/surfaces/checkout/components/BlockSpacer/BlockSpacer.d.ts +22 -0
  154. package/build/ts/surfaces/checkout/components/BlockSpacer/BlockSpacer.d.ts.map +1 -0
  155. package/build/ts/surfaces/checkout/components/BlockSpacer/examples/basic-blockspacer.example.d.ts +2 -0
  156. package/build/ts/surfaces/checkout/components/BlockSpacer/examples/basic-blockspacer.example.d.ts.map +1 -0
  157. package/build/ts/surfaces/checkout/components/BlockStack/BlockStack.d.ts +42 -0
  158. package/build/ts/surfaces/checkout/components/BlockStack/BlockStack.d.ts.map +1 -0
  159. package/build/ts/surfaces/checkout/components/BlockStack/examples/basic-blockstack.example.d.ts +2 -0
  160. package/build/ts/surfaces/checkout/components/BlockStack/examples/basic-blockstack.example.d.ts.map +1 -0
  161. package/build/ts/surfaces/checkout/components/Button/Button.d.ts +83 -0
  162. package/build/ts/surfaces/checkout/components/Button/Button.d.ts.map +1 -0
  163. package/build/ts/surfaces/checkout/components/Button/examples/basic-button.example.d.ts +2 -0
  164. package/build/ts/surfaces/checkout/components/Button/examples/basic-button.example.d.ts.map +1 -0
  165. package/build/ts/surfaces/checkout/components/Checkbox/Checkbox.d.ts +59 -0
  166. package/build/ts/surfaces/checkout/components/Checkbox/Checkbox.d.ts.map +1 -0
  167. package/build/ts/surfaces/checkout/components/Checkbox/examples/basic-checkbox.example.d.ts +2 -0
  168. package/build/ts/surfaces/checkout/components/Checkbox/examples/basic-checkbox.example.d.ts.map +1 -0
  169. package/build/ts/surfaces/checkout/components/Choice/Choice.d.ts +27 -0
  170. package/build/ts/surfaces/checkout/components/Choice/Choice.d.ts.map +1 -0
  171. package/build/ts/surfaces/checkout/components/Choice/examples/basic-choice.example.d.ts +2 -0
  172. package/build/ts/surfaces/checkout/components/Choice/examples/basic-choice.example.d.ts.map +1 -0
  173. package/build/ts/surfaces/checkout/components/ChoiceList/ChoiceList.d.ts +32 -0
  174. package/build/ts/surfaces/checkout/components/ChoiceList/ChoiceList.d.ts.map +1 -0
  175. package/build/ts/surfaces/checkout/components/ChoiceList/examples/basic-choicelist.example.d.ts +2 -0
  176. package/build/ts/surfaces/checkout/components/ChoiceList/examples/basic-choicelist.example.d.ts.map +1 -0
  177. package/build/ts/surfaces/checkout/components/Divider/Divider.d.ts +30 -0
  178. package/build/ts/surfaces/checkout/components/Divider/Divider.d.ts.map +1 -0
  179. package/build/ts/surfaces/checkout/components/Divider/examples/basic-divider.example.d.ts +2 -0
  180. package/build/ts/surfaces/checkout/components/Divider/examples/basic-divider.example.d.ts.map +1 -0
  181. package/build/ts/surfaces/checkout/components/Form/Form.d.ts +32 -0
  182. package/build/ts/surfaces/checkout/components/Form/Form.d.ts.map +1 -0
  183. package/build/ts/surfaces/checkout/components/Form/examples/basic-form.example.d.ts +2 -0
  184. package/build/ts/surfaces/checkout/components/Form/examples/basic-form.example.d.ts.map +1 -0
  185. package/build/ts/surfaces/checkout/components/Grid/Grid.d.ts +95 -0
  186. package/build/ts/surfaces/checkout/components/Grid/Grid.d.ts.map +1 -0
  187. package/build/ts/surfaces/checkout/components/Grid/examples/basic-grid.example.d.ts +2 -0
  188. package/build/ts/surfaces/checkout/components/Grid/examples/basic-grid.example.d.ts.map +1 -0
  189. package/build/ts/surfaces/checkout/components/GridItem/GridItem.d.ts +36 -0
  190. package/build/ts/surfaces/checkout/components/GridItem/GridItem.d.ts.map +1 -0
  191. package/build/ts/surfaces/checkout/components/GridItem/examples/basic-griditem.example.d.ts +2 -0
  192. package/build/ts/surfaces/checkout/components/GridItem/examples/basic-griditem.example.d.ts.map +1 -0
  193. package/build/ts/surfaces/checkout/components/Heading/Heading.d.ts +43 -0
  194. package/build/ts/surfaces/checkout/components/Heading/Heading.d.ts.map +1 -0
  195. package/build/ts/surfaces/checkout/components/Heading/examples/basic-heading.example.d.ts +2 -0
  196. package/build/ts/surfaces/checkout/components/Heading/examples/basic-heading.example.d.ts.map +1 -0
  197. package/build/ts/surfaces/checkout/components/HeadingGroup/HeadingGroup.d.ts +15 -0
  198. package/build/ts/surfaces/checkout/components/HeadingGroup/HeadingGroup.d.ts.map +1 -0
  199. package/build/ts/surfaces/checkout/components/HeadingGroup/examples/basic-headinggroup.example.d.ts +2 -0
  200. package/build/ts/surfaces/checkout/components/HeadingGroup/examples/basic-headinggroup.example.d.ts.map +1 -0
  201. package/build/ts/surfaces/checkout/components/Icon/Icon.d.ts +38 -0
  202. package/build/ts/surfaces/checkout/components/Icon/Icon.d.ts.map +1 -0
  203. package/build/ts/surfaces/checkout/components/Icon/examples/basic-icon.example.d.ts +2 -0
  204. package/build/ts/surfaces/checkout/components/Icon/examples/basic-icon.example.d.ts.map +1 -0
  205. package/build/ts/surfaces/checkout/components/Image/Image.d.ts +73 -0
  206. package/build/ts/surfaces/checkout/components/Image/Image.d.ts.map +1 -0
  207. package/build/ts/surfaces/checkout/components/Image/examples/basic-image.example.d.ts +2 -0
  208. package/build/ts/surfaces/checkout/components/Image/examples/basic-image.example.d.ts.map +1 -0
  209. package/build/ts/surfaces/checkout/components/InlineLayout/InlineLayout.d.ts +43 -0
  210. package/build/ts/surfaces/checkout/components/InlineLayout/InlineLayout.d.ts.map +1 -0
  211. package/build/ts/surfaces/checkout/components/InlineLayout/examples/basic-inlineLayout.example.d.ts +2 -0
  212. package/build/ts/surfaces/checkout/components/InlineLayout/examples/basic-inlineLayout.example.d.ts.map +1 -0
  213. package/build/ts/surfaces/checkout/components/InlineSpacer/InlineSpacer.d.ts +22 -0
  214. package/build/ts/surfaces/checkout/components/InlineSpacer/InlineSpacer.d.ts.map +1 -0
  215. package/build/ts/surfaces/checkout/components/InlineSpacer/examples/basic-inlinespacer.example.d.ts +2 -0
  216. package/build/ts/surfaces/checkout/components/InlineSpacer/examples/basic-inlinespacer.example.d.ts.map +1 -0
  217. package/build/ts/surfaces/checkout/components/InlineStack/InlineStack.d.ts +50 -0
  218. package/build/ts/surfaces/checkout/components/InlineStack/InlineStack.d.ts.map +1 -0
  219. package/build/ts/surfaces/checkout/components/InlineStack/examples/basic-inlinestack.example.d.ts +2 -0
  220. package/build/ts/surfaces/checkout/components/InlineStack/examples/basic-inlinestack.example.d.ts.map +1 -0
  221. package/build/ts/surfaces/checkout/components/Link/Link.d.ts +50 -0
  222. package/build/ts/surfaces/checkout/components/Link/Link.d.ts.map +1 -0
  223. package/build/ts/surfaces/checkout/components/Link/examples/basic-link.example.d.ts +2 -0
  224. package/build/ts/surfaces/checkout/components/Link/examples/basic-link.example.d.ts.map +1 -0
  225. package/build/ts/surfaces/checkout/components/List/List.d.ts +32 -0
  226. package/build/ts/surfaces/checkout/components/List/List.d.ts.map +1 -0
  227. package/build/ts/surfaces/checkout/components/List/examples/basic-list.example.d.ts +2 -0
  228. package/build/ts/surfaces/checkout/components/List/examples/basic-list.example.d.ts.map +1 -0
  229. package/build/ts/surfaces/checkout/components/ListItem/ListItem.d.ts +13 -0
  230. package/build/ts/surfaces/checkout/components/ListItem/ListItem.d.ts.map +1 -0
  231. package/build/ts/surfaces/checkout/components/ListItem/examples/basic-listitem.example.d.ts +2 -0
  232. package/build/ts/surfaces/checkout/components/ListItem/examples/basic-listitem.example.d.ts.map +1 -0
  233. package/build/ts/surfaces/checkout/components/PhoneField/PhoneField.d.ts +58 -0
  234. package/build/ts/surfaces/checkout/components/PhoneField/PhoneField.d.ts.map +1 -0
  235. package/build/ts/surfaces/checkout/components/PhoneField/examples/basic-phonefield.example.d.ts +2 -0
  236. package/build/ts/surfaces/checkout/components/PhoneField/examples/basic-phonefield.example.d.ts.map +1 -0
  237. package/build/ts/surfaces/checkout/components/Pressable/Pressable.d.ts +96 -0
  238. package/build/ts/surfaces/checkout/components/Pressable/Pressable.d.ts.map +1 -0
  239. package/build/ts/surfaces/checkout/components/Pressable/examples/basic-pressable.example.d.ts +2 -0
  240. package/build/ts/surfaces/checkout/components/Pressable/examples/basic-pressable.example.d.ts.map +1 -0
  241. package/build/ts/surfaces/checkout/components/ScrollView/ScrollView.d.ts +74 -0
  242. package/build/ts/surfaces/checkout/components/ScrollView/ScrollView.d.ts.map +1 -0
  243. package/build/ts/surfaces/checkout/components/ScrollView/examples/basic-scrollview.example.d.ts +2 -0
  244. package/build/ts/surfaces/checkout/components/ScrollView/examples/basic-scrollview.example.d.ts.map +1 -0
  245. package/build/ts/surfaces/checkout/components/Select/Select.d.ts +98 -0
  246. package/build/ts/surfaces/checkout/components/Select/Select.d.ts.map +1 -0
  247. package/build/ts/surfaces/checkout/components/Select/examples/basic-select.example.d.ts +2 -0
  248. package/build/ts/surfaces/checkout/components/Select/examples/basic-select.example.d.ts.map +1 -0
  249. package/build/ts/surfaces/checkout/components/SkeletonImage/SkeletonImage.d.ts +25 -0
  250. package/build/ts/surfaces/checkout/components/SkeletonImage/SkeletonImage.d.ts.map +1 -0
  251. package/build/ts/surfaces/checkout/components/SkeletonImage/examples/basic-skeletonimage.example.d.ts +2 -0
  252. package/build/ts/surfaces/checkout/components/SkeletonImage/examples/basic-skeletonimage.example.d.ts.map +1 -0
  253. package/build/ts/surfaces/checkout/components/SkeletonText/SkeletonText.d.ts +21 -0
  254. package/build/ts/surfaces/checkout/components/SkeletonText/SkeletonText.d.ts.map +1 -0
  255. package/build/ts/surfaces/checkout/components/SkeletonText/examples/basic-skeletontext.example.d.ts +2 -0
  256. package/build/ts/surfaces/checkout/components/SkeletonText/examples/basic-skeletontext.example.d.ts.map +1 -0
  257. package/build/ts/surfaces/checkout/components/SkeletonTextBlock/SkeletonTextBlock.d.ts +22 -0
  258. package/build/ts/surfaces/checkout/components/SkeletonTextBlock/SkeletonTextBlock.d.ts.map +1 -0
  259. package/build/ts/surfaces/checkout/components/SkeletonTextBlock/examples/basic-skeletontextblock.example.d.ts +2 -0
  260. package/build/ts/surfaces/checkout/components/SkeletonTextBlock/examples/basic-skeletontextblock.example.d.ts.map +1 -0
  261. package/build/ts/surfaces/checkout/components/Spinner/Spinner.d.ts +32 -0
  262. package/build/ts/surfaces/checkout/components/Spinner/Spinner.d.ts.map +1 -0
  263. package/build/ts/surfaces/checkout/components/Spinner/examples/basic-spinner.example.d.ts +2 -0
  264. package/build/ts/surfaces/checkout/components/Spinner/examples/basic-spinner.example.d.ts.map +1 -0
  265. package/build/ts/surfaces/checkout/components/Stepper/Stepper.d.ts +42 -0
  266. package/build/ts/surfaces/checkout/components/Stepper/Stepper.d.ts.map +1 -0
  267. package/build/ts/surfaces/checkout/components/Stepper/examples/basic-stepper.example.d.ts +2 -0
  268. package/build/ts/surfaces/checkout/components/Stepper/examples/basic-stepper.example.d.ts.map +1 -0
  269. package/build/ts/surfaces/checkout/components/Tag/Tag.d.ts +31 -0
  270. package/build/ts/surfaces/checkout/components/Tag/Tag.d.ts.map +1 -0
  271. package/build/ts/surfaces/checkout/components/Tag/examples/basic-tag.example.d.ts +2 -0
  272. package/build/ts/surfaces/checkout/components/Tag/examples/basic-tag.example.d.ts.map +1 -0
  273. package/build/ts/surfaces/checkout/components/Text/Text.d.ts +34 -0
  274. package/build/ts/surfaces/checkout/components/Text/Text.d.ts.map +1 -0
  275. package/build/ts/surfaces/checkout/components/Text/examples/basic-text.example.d.ts +2 -0
  276. package/build/ts/surfaces/checkout/components/Text/examples/basic-text.example.d.ts.map +1 -0
  277. package/build/ts/surfaces/checkout/components/TextBlock/TextBlock.d.ts +32 -0
  278. package/build/ts/surfaces/checkout/components/TextBlock/TextBlock.d.ts.map +1 -0
  279. package/build/ts/surfaces/checkout/components/TextBlock/examples/basic-textblock.example.d.ts +2 -0
  280. package/build/ts/surfaces/checkout/components/TextBlock/examples/basic-textblock.example.d.ts.map +1 -0
  281. package/build/ts/surfaces/checkout/components/TextField/TextField.d.ts +175 -0
  282. package/build/ts/surfaces/checkout/components/TextField/TextField.d.ts.map +1 -0
  283. package/build/ts/surfaces/checkout/components/TextField/examples/basic-textfield.example.d.ts +2 -0
  284. package/build/ts/surfaces/checkout/components/TextField/examples/basic-textfield.example.d.ts.map +1 -0
  285. package/build/ts/surfaces/checkout/components/Tooltip/Tooltip.d.ts +16 -0
  286. package/build/ts/surfaces/checkout/components/Tooltip/Tooltip.d.ts.map +1 -0
  287. package/build/ts/surfaces/checkout/components/Tooltip/examples/basic-tooltip.example.d.ts +2 -0
  288. package/build/ts/surfaces/checkout/components/Tooltip/examples/basic-tooltip.example.d.ts.map +1 -0
  289. package/build/ts/surfaces/checkout/components/View/View.d.ts +169 -0
  290. package/build/ts/surfaces/checkout/components/View/View.d.ts.map +1 -0
  291. package/build/ts/surfaces/checkout/components/View/examples/basic-view.example.d.ts +2 -0
  292. package/build/ts/surfaces/checkout/components/View/examples/basic-view.example.d.ts.map +1 -0
  293. package/build/ts/surfaces/checkout/components/shared.d.ts +388 -0
  294. package/build/ts/surfaces/checkout/components/shared.d.ts.map +1 -0
  295. package/build/ts/surfaces/checkout/components.d.ts +75 -1
  296. package/build/ts/surfaces/checkout/components.d.ts.map +1 -1
  297. package/build/ts/surfaces/checkout/extension-points.d.ts +50 -2
  298. package/build/ts/surfaces/checkout/extension-points.d.ts.map +1 -1
  299. package/build/ts/surfaces/checkout/globals.d.ts +11 -0
  300. package/build/ts/surfaces/checkout/globals.d.ts.map +1 -0
  301. package/build/ts/surfaces/checkout/index.d.ts +2 -0
  302. package/build/ts/surfaces/checkout/index.d.ts.map +1 -1
  303. package/build/ts/surfaces/checkout/shared.d.ts +3 -3
  304. package/build/ts/surfaces/checkout/shared.d.ts.map +1 -1
  305. package/build/ts/surfaces/checkout/style/isEqual.d.ts +8 -0
  306. package/build/ts/surfaces/checkout/style/isEqual.d.ts.map +1 -0
  307. package/build/ts/surfaces/checkout/style/isEqual.test.d.ts +2 -0
  308. package/build/ts/surfaces/checkout/style/isEqual.test.d.ts.map +1 -0
  309. package/build/ts/surfaces/checkout/style/memoize.d.ts +13 -0
  310. package/build/ts/surfaces/checkout/style/memoize.d.ts.map +1 -0
  311. package/build/ts/surfaces/checkout/style/style.d.ts +70 -0
  312. package/build/ts/surfaces/checkout/style/style.d.ts.map +1 -0
  313. package/build/ts/surfaces/checkout/style/style.test.d.ts +2 -0
  314. package/build/ts/surfaces/checkout/style/style.test.d.ts.map +1 -0
  315. package/build/ts/surfaces/checkout/style/types.d.ts +46 -0
  316. package/build/ts/surfaces/checkout/style/types.d.ts.map +1 -0
  317. package/build/ts/surfaces/checkout/style.d.ts +3 -0
  318. package/build/ts/surfaces/checkout/style.d.ts.map +1 -0
  319. package/build/ts/utilities/registration.d.ts +1 -2
  320. package/build/ts/utilities/registration.d.ts.map +1 -1
  321. package/checkout.esnext +1 -1
  322. package/checkout.js +1 -1
  323. package/checkout.mjs +1 -1
  324. package/index.esnext +1 -1
  325. package/index.js +1 -1
  326. package/index.mjs +1 -1
  327. package/package.json +17 -11
  328. package/src/api.ts +0 -5
  329. package/src/extension.ts +3 -29
  330. package/src/index.ts +1 -1
  331. package/src/surfaces/checkout/api/cart-line-details/render-after.ts +7 -3
  332. package/src/surfaces/checkout/api/shared.ts +810 -3
  333. package/src/surfaces/checkout/api/standard/standard.ts +1240 -2
  334. package/src/surfaces/checkout/components/Banner/Banner.ts +37 -0
  335. package/src/surfaces/checkout/components/Banner/README.md +14 -0
  336. package/src/surfaces/checkout/components/Banner/content/guidelines.md +9 -0
  337. package/src/surfaces/checkout/components/Banner/examples/basic-banner.example.ts +11 -0
  338. package/src/surfaces/checkout/components/BlockLayout/BlockLayout.ts +43 -0
  339. package/src/surfaces/checkout/components/BlockLayout/README.md +101 -0
  340. package/src/surfaces/checkout/components/BlockLayout/examples/basic-blockLayout.example.ts +16 -0
  341. package/src/surfaces/checkout/components/BlockSpacer/BlockSpacer.ts +25 -0
  342. package/src/surfaces/checkout/components/BlockSpacer/README.md +14 -0
  343. package/src/surfaces/checkout/components/BlockSpacer/examples/basic-blockspacer.example.ts +11 -0
  344. package/src/surfaces/checkout/components/BlockStack/BlockStack.ts +53 -0
  345. package/src/surfaces/checkout/components/BlockStack/README.md +77 -0
  346. package/src/surfaces/checkout/components/BlockStack/examples/basic-blockstack.example.ts +11 -0
  347. package/src/surfaces/checkout/components/Button/Button.ts +87 -0
  348. package/src/surfaces/checkout/components/Button/README.md +22 -0
  349. package/src/surfaces/checkout/components/Button/content/guidelines.md +10 -0
  350. package/src/surfaces/checkout/components/Button/examples/basic-button.example.ts +11 -0
  351. package/src/{components → surfaces/checkout/components}/Checkbox/Checkbox.ts +32 -1
  352. package/src/surfaces/checkout/components/Checkbox/README.md +18 -0
  353. package/src/surfaces/checkout/components/Checkbox/content/guidelines.md +9 -0
  354. package/src/surfaces/checkout/components/Checkbox/examples/basic-checkbox.example.ts +11 -0
  355. package/src/surfaces/checkout/components/Choice/Choice.ts +25 -0
  356. package/src/surfaces/checkout/components/Choice/README.md +14 -0
  357. package/src/surfaces/checkout/components/Choice/content/guidelines.md +9 -0
  358. package/src/surfaces/checkout/components/Choice/examples/basic-choice.example.ts +50 -0
  359. package/src/surfaces/checkout/components/ChoiceList/ChoiceList.ts +33 -0
  360. package/src/surfaces/checkout/components/ChoiceList/README.md +14 -0
  361. package/src/surfaces/checkout/components/ChoiceList/content/guidelines.md +10 -0
  362. package/src/surfaces/checkout/components/ChoiceList/examples/basic-choicelist.example.ts +50 -0
  363. package/src/surfaces/checkout/components/Divider/Divider.ts +33 -0
  364. package/src/surfaces/checkout/components/Divider/README.md +13 -0
  365. package/src/surfaces/checkout/components/Divider/examples/basic-divider.example.ts +7 -0
  366. package/src/surfaces/checkout/components/Form/Form.ts +30 -0
  367. package/src/surfaces/checkout/components/Form/README.md +21 -0
  368. package/src/surfaces/checkout/components/Form/content/guidelines.md +4 -0
  369. package/src/surfaces/checkout/components/Form/examples/basic-form.example.ts +48 -0
  370. package/src/surfaces/checkout/components/Grid/Grid.ts +104 -0
  371. package/src/surfaces/checkout/components/Grid/README.md +105 -0
  372. package/src/surfaces/checkout/components/Grid/content/guidelines.md +3 -0
  373. package/src/surfaces/checkout/components/Grid/examples/basic-grid.example.ts +45 -0
  374. package/src/surfaces/checkout/components/GridItem/GridItem.ts +42 -0
  375. package/src/surfaces/checkout/components/GridItem/README.md +72 -0
  376. package/src/surfaces/checkout/components/GridItem/content/guidelines.md +3 -0
  377. package/src/surfaces/checkout/components/GridItem/examples/basic-griditem.example.ts +42 -0
  378. package/src/surfaces/checkout/components/Heading/Heading.ts +44 -0
  379. package/src/surfaces/checkout/components/Heading/README.md +19 -0
  380. package/src/surfaces/checkout/components/Heading/content/guidelines.md +10 -0
  381. package/src/surfaces/checkout/components/Heading/examples/basic-heading.example.ts +7 -0
  382. package/src/surfaces/checkout/components/HeadingGroup/HeadingGroup.ts +15 -0
  383. package/src/surfaces/checkout/components/HeadingGroup/README.md +7 -0
  384. package/src/surfaces/checkout/components/HeadingGroup/content/guidelines.md +9 -0
  385. package/src/surfaces/checkout/components/HeadingGroup/examples/basic-headinggroup.example.ts +20 -0
  386. package/src/surfaces/checkout/components/Icon/Icon.ts +91 -0
  387. package/src/surfaces/checkout/components/Icon/README.md +15 -0
  388. package/src/surfaces/checkout/components/Icon/examples/basic-icon.example.ts +7 -0
  389. package/src/surfaces/checkout/components/Image/Image.ts +83 -0
  390. package/src/surfaces/checkout/components/Image/README.md +53 -0
  391. package/src/surfaces/checkout/components/Image/examples/basic-image.example.ts +10 -0
  392. package/src/surfaces/checkout/components/InlineLayout/InlineLayout.ts +49 -0
  393. package/src/surfaces/checkout/components/InlineLayout/README.md +103 -0
  394. package/src/surfaces/checkout/components/InlineLayout/examples/basic-inlineLayout.example.ts +16 -0
  395. package/src/surfaces/checkout/components/InlineSpacer/InlineSpacer.ts +24 -0
  396. package/src/surfaces/checkout/components/InlineSpacer/README.md +14 -0
  397. package/src/surfaces/checkout/components/InlineSpacer/examples/basic-inlinespacer.example.ts +16 -0
  398. package/src/surfaces/checkout/components/InlineStack/InlineStack.ts +63 -0
  399. package/src/surfaces/checkout/components/InlineStack/README.md +87 -0
  400. package/src/surfaces/checkout/components/InlineStack/examples/basic-inlinestack.example.ts +18 -0
  401. package/src/surfaces/checkout/components/Link/Link.ts +49 -0
  402. package/src/surfaces/checkout/components/Link/README.md +18 -0
  403. package/src/surfaces/checkout/components/Link/content/guidelines.md +9 -0
  404. package/src/surfaces/checkout/components/Link/examples/basic-link.example.ts +11 -0
  405. package/src/surfaces/checkout/components/List/List.ts +32 -0
  406. package/src/surfaces/checkout/components/List/README.md +19 -0
  407. package/src/surfaces/checkout/components/List/content/guidelines.md +11 -0
  408. package/src/surfaces/checkout/components/List/examples/basic-list.example.ts +11 -0
  409. package/src/surfaces/checkout/components/ListItem/ListItem.ts +12 -0
  410. package/src/surfaces/checkout/components/ListItem/README.md +5 -0
  411. package/src/surfaces/checkout/components/ListItem/content/guidelines.md +3 -0
  412. package/src/surfaces/checkout/components/ListItem/examples/basic-listitem.example.ts +9 -0
  413. package/src/surfaces/checkout/components/PhoneField/PhoneField.ts +77 -0
  414. package/src/surfaces/checkout/components/PhoneField/README.md +49 -0
  415. package/src/surfaces/checkout/components/PhoneField/examples/basic-phonefield.example.ts +10 -0
  416. package/src/surfaces/checkout/components/Pressable/Pressable.ts +128 -0
  417. package/src/surfaces/checkout/components/Pressable/README.md +74 -0
  418. package/src/surfaces/checkout/components/Pressable/examples/basic-pressable.example.ts +27 -0
  419. package/src/surfaces/checkout/components/ScrollView/README.md +62 -0
  420. package/src/surfaces/checkout/components/ScrollView/ScrollView.ts +76 -0
  421. package/src/surfaces/checkout/components/ScrollView/examples/basic-scrollview.example.ts +38 -0
  422. package/src/surfaces/checkout/components/Select/README.md +41 -0
  423. package/src/surfaces/checkout/components/Select/Select.ts +97 -0
  424. package/src/surfaces/checkout/components/Select/content/guidelines.md +4 -0
  425. package/src/surfaces/checkout/components/Select/examples/basic-select.example.ts +36 -0
  426. package/src/surfaces/checkout/components/SkeletonImage/README.md +13 -0
  427. package/src/surfaces/checkout/components/SkeletonImage/SkeletonImage.ts +27 -0
  428. package/src/surfaces/checkout/components/SkeletonImage/examples/basic-skeletonimage.example.ts +10 -0
  429. package/src/surfaces/checkout/components/SkeletonText/README.md +13 -0
  430. package/src/surfaces/checkout/components/SkeletonText/SkeletonText.ts +23 -0
  431. package/src/surfaces/checkout/components/SkeletonText/examples/basic-skeletontext.example.ts +7 -0
  432. package/src/surfaces/checkout/components/SkeletonTextBlock/README.md +13 -0
  433. package/src/surfaces/checkout/components/SkeletonTextBlock/SkeletonTextBlock.ts +24 -0
  434. package/src/surfaces/checkout/components/SkeletonTextBlock/examples/basic-skeletontextblock.example.ts +7 -0
  435. package/src/surfaces/checkout/components/Spinner/README.md +14 -0
  436. package/src/surfaces/checkout/components/Spinner/Spinner.ts +35 -0
  437. package/src/surfaces/checkout/components/Spinner/examples/basic-spinner.example.ts +7 -0
  438. package/src/surfaces/checkout/components/Stepper/README.md +28 -0
  439. package/src/surfaces/checkout/components/Stepper/Stepper.ts +63 -0
  440. package/src/surfaces/checkout/components/Stepper/content/guidelines.md +4 -0
  441. package/src/surfaces/checkout/components/Stepper/examples/basic-stepper.example.ts +10 -0
  442. package/src/surfaces/checkout/components/Tag/README.md +14 -0
  443. package/src/surfaces/checkout/components/Tag/Tag.ts +26 -0
  444. package/src/surfaces/checkout/components/Tag/examples/basic-tag.example.ts +7 -0
  445. package/src/surfaces/checkout/components/Text/README.md +17 -0
  446. package/src/surfaces/checkout/components/Text/Text.ts +44 -0
  447. package/src/surfaces/checkout/components/Text/content/guidelines.md +10 -0
  448. package/src/surfaces/checkout/components/Text/examples/basic-text.example.ts +14 -0
  449. package/src/surfaces/checkout/components/TextBlock/README.md +15 -0
  450. package/src/surfaces/checkout/components/TextBlock/TextBlock.ts +38 -0
  451. package/src/surfaces/checkout/components/TextBlock/content/guidelines.md +9 -0
  452. package/src/surfaces/checkout/components/TextBlock/examples/basic-textblock.example.ts +18 -0
  453. package/src/surfaces/checkout/components/TextField/README.md +49 -0
  454. package/src/surfaces/checkout/components/TextField/TextField.ts +173 -0
  455. package/src/surfaces/checkout/components/TextField/content/guidelines.md +5 -0
  456. package/src/surfaces/checkout/components/TextField/examples/basic-textfield.example.ts +9 -0
  457. package/src/surfaces/checkout/components/Tooltip/README.md +8 -0
  458. package/src/surfaces/checkout/components/Tooltip/Tooltip.ts +15 -0
  459. package/src/surfaces/checkout/components/Tooltip/examples/basic-tooltip.example.ts +23 -0
  460. package/src/surfaces/checkout/components/View/README.md +97 -0
  461. package/src/surfaces/checkout/components/View/View.ts +196 -0
  462. package/src/surfaces/checkout/components/View/examples/basic-view.example.ts +11 -0
  463. package/src/surfaces/checkout/components/shared.ts +560 -0
  464. package/src/surfaces/checkout/components.ts +155 -1
  465. package/src/surfaces/checkout/extension-points.ts +83 -3
  466. package/src/surfaces/checkout/globals.ts +15 -0
  467. package/src/surfaces/checkout/index.ts +2 -0
  468. package/src/surfaces/checkout/style/isEqual.test.ts +67 -0
  469. package/src/surfaces/checkout/style/isEqual.ts +41 -0
  470. package/src/surfaces/checkout/style/memoize.ts +176 -0
  471. package/src/surfaces/checkout/style/style.test.ts +131 -0
  472. package/src/surfaces/checkout/style/style.ts +161 -0
  473. package/src/surfaces/checkout/style/types.ts +67 -0
  474. package/src/surfaces/checkout/style.ts +16 -0
  475. package/src/utilities/registration.ts +9 -42
  476. package/LICENSE.md +0 -7
  477. package/admin.d.ts +0 -1
  478. package/admin.esnext +0 -1
  479. package/admin.js +0 -1
  480. package/admin.mjs +0 -1
  481. package/build/cjs/api.js +0 -1
  482. package/build/cjs/components/BlockStack/BlockStack.js +0 -11
  483. package/build/cjs/components/BlockStack/README.md +0 -1
  484. package/build/cjs/components/Button/Button.js +0 -11
  485. package/build/cjs/components/Button/README.md +0 -1
  486. package/build/cjs/components/Checkbox/Checkbox.js +0 -14
  487. package/build/cjs/components/Checkbox/README.md +0 -1
  488. package/build/cjs/components/Text/README.md +0 -1
  489. package/build/cjs/components/Text/Text.js +0 -11
  490. package/build/cjs/components/TextField/README.md +0 -1
  491. package/build/cjs/components/TextField/TextField.js +0 -11
  492. package/build/cjs/components/View/README.md +0 -1
  493. package/build/cjs/components/View/View.js +0 -11
  494. package/build/cjs/components.js +0 -53
  495. package/build/cjs/extension.js +0 -1
  496. package/build/cjs/surfaces/admin/api/checkout-editor/README.md +0 -1
  497. package/build/cjs/surfaces/admin/api/checkout-editor/render-settings.js +0 -1
  498. package/build/cjs/surfaces/admin/api/standard/README.md +0 -1
  499. package/build/cjs/surfaces/admin/api/standard/standard.js +0 -1
  500. package/build/cjs/surfaces/admin/api.js +0 -1
  501. package/build/cjs/surfaces/admin/components/TextField/TextField.js +0 -11
  502. package/build/cjs/surfaces/admin/components.js +0 -30
  503. package/build/cjs/surfaces/admin/extension-points.js +0 -1
  504. package/build/cjs/surfaces/admin/extension.js +0 -27
  505. package/build/cjs/surfaces/admin/index.js +0 -70
  506. package/build/cjs/surfaces/admin/shared.js +0 -1
  507. package/build/cjs/surfaces/checkout/api/cart-line-details/README.md +0 -1
  508. package/build/cjs/surfaces/checkout/api/cart-line-details/render-after.js +0 -1
  509. package/build/cjs/surfaces/checkout/api/shared.js +0 -1
  510. package/build/cjs/surfaces/checkout/api/standard/README.md +0 -1
  511. package/build/cjs/surfaces/checkout/api/standard/standard.js +0 -1
  512. package/build/cjs/surfaces/checkout/api.js +0 -1
  513. package/build/cjs/surfaces/checkout/components.js +0 -18
  514. package/build/cjs/surfaces/checkout/extension-points.js +0 -1
  515. package/build/cjs/surfaces/checkout/shared.js +0 -1
  516. package/build/esm/api.mjs +0 -0
  517. package/build/esm/components/BlockStack/BlockStack.mjs +0 -2
  518. package/build/esm/components/BlockStack/README.md +0 -1
  519. package/build/esm/components/Button/Button.mjs +0 -2
  520. package/build/esm/components/Button/README.md +0 -1
  521. package/build/esm/components/Checkbox/Checkbox.mjs +0 -6
  522. package/build/esm/components/Checkbox/README.md +0 -1
  523. package/build/esm/components/Text/README.md +0 -1
  524. package/build/esm/components/Text/Text.mjs +0 -2
  525. package/build/esm/components/TextField/README.md +0 -1
  526. package/build/esm/components/TextField/TextField.mjs +0 -2
  527. package/build/esm/components/View/README.md +0 -1
  528. package/build/esm/components/View/View.mjs +0 -2
  529. package/build/esm/components.mjs +0 -6
  530. package/build/esm/extension.mjs +0 -0
  531. package/build/esm/surfaces/admin/api/checkout-editor/README.md +0 -1
  532. package/build/esm/surfaces/admin/api/checkout-editor/render-settings.mjs +0 -0
  533. package/build/esm/surfaces/admin/api/standard/README.md +0 -1
  534. package/build/esm/surfaces/admin/api/standard/standard.mjs +0 -0
  535. package/build/esm/surfaces/admin/api.mjs +0 -0
  536. package/build/esm/surfaces/admin/components/TextField/TextField.mjs +0 -2
  537. package/build/esm/surfaces/admin/components.mjs +0 -2
  538. package/build/esm/surfaces/admin/extension-points.mjs +0 -0
  539. package/build/esm/surfaces/admin/extension.mjs +0 -3
  540. package/build/esm/surfaces/admin/index.mjs +0 -5
  541. package/build/esm/surfaces/admin/shared.mjs +0 -0
  542. package/build/esm/surfaces/checkout/api/cart-line-details/README.md +0 -1
  543. package/build/esm/surfaces/checkout/api/cart-line-details/render-after.mjs +0 -0
  544. package/build/esm/surfaces/checkout/api/shared.mjs +0 -0
  545. package/build/esm/surfaces/checkout/api/standard/README.md +0 -1
  546. package/build/esm/surfaces/checkout/api/standard/standard.mjs +0 -0
  547. package/build/esm/surfaces/checkout/api.mjs +0 -0
  548. package/build/esm/surfaces/checkout/components.mjs +0 -1
  549. package/build/esm/surfaces/checkout/extension-points.mjs +0 -0
  550. package/build/esm/surfaces/checkout/shared.mjs +0 -0
  551. package/build/esnext/api.esnext +0 -0
  552. package/build/esnext/components/BlockStack/BlockStack.esnext +0 -2
  553. package/build/esnext/components/BlockStack/README.md +0 -1
  554. package/build/esnext/components/Button/Button.esnext +0 -2
  555. package/build/esnext/components/Button/README.md +0 -1
  556. package/build/esnext/components/Checkbox/Checkbox.esnext +0 -6
  557. package/build/esnext/components/Checkbox/README.md +0 -1
  558. package/build/esnext/components/Text/README.md +0 -1
  559. package/build/esnext/components/Text/Text.esnext +0 -2
  560. package/build/esnext/components/TextField/README.md +0 -1
  561. package/build/esnext/components/TextField/TextField.esnext +0 -2
  562. package/build/esnext/components/View/README.md +0 -1
  563. package/build/esnext/components/View/View.esnext +0 -2
  564. package/build/esnext/components.esnext +0 -6
  565. package/build/esnext/extension.esnext +0 -0
  566. package/build/esnext/surfaces/admin/api/checkout-editor/README.md +0 -1
  567. package/build/esnext/surfaces/admin/api/checkout-editor/render-settings.esnext +0 -0
  568. package/build/esnext/surfaces/admin/api/standard/README.md +0 -1
  569. package/build/esnext/surfaces/admin/api/standard/standard.esnext +0 -0
  570. package/build/esnext/surfaces/admin/api.esnext +0 -0
  571. package/build/esnext/surfaces/admin/components/TextField/TextField.esnext +0 -2
  572. package/build/esnext/surfaces/admin/components.esnext +0 -2
  573. package/build/esnext/surfaces/admin/extension-points.esnext +0 -0
  574. package/build/esnext/surfaces/admin/extension.esnext +0 -3
  575. package/build/esnext/surfaces/admin/index.esnext +0 -5
  576. package/build/esnext/surfaces/admin/shared.esnext +0 -0
  577. package/build/esnext/surfaces/checkout/api/cart-line-details/README.md +0 -1
  578. package/build/esnext/surfaces/checkout/api/cart-line-details/render-after.esnext +0 -0
  579. package/build/esnext/surfaces/checkout/api/shared.esnext +0 -0
  580. package/build/esnext/surfaces/checkout/api/standard/README.md +0 -1
  581. package/build/esnext/surfaces/checkout/api/standard/standard.esnext +0 -0
  582. package/build/esnext/surfaces/checkout/api.esnext +0 -0
  583. package/build/esnext/surfaces/checkout/components.esnext +0 -1
  584. package/build/esnext/surfaces/checkout/extension-points.esnext +0 -0
  585. package/build/esnext/surfaces/checkout/shared.esnext +0 -0
  586. package/build/node/api.js +0 -1
  587. package/build/node/components/BlockStack/BlockStack.js +0 -11
  588. package/build/node/components/BlockStack/README.md +0 -1
  589. package/build/node/components/Button/Button.js +0 -11
  590. package/build/node/components/Button/README.md +0 -1
  591. package/build/node/components/Checkbox/Checkbox.js +0 -14
  592. package/build/node/components/Checkbox/README.md +0 -1
  593. package/build/node/components/Text/README.md +0 -1
  594. package/build/node/components/Text/Text.js +0 -11
  595. package/build/node/components/TextField/README.md +0 -1
  596. package/build/node/components/TextField/TextField.js +0 -11
  597. package/build/node/components/View/README.md +0 -1
  598. package/build/node/components/View/View.js +0 -11
  599. package/build/node/components.js +0 -53
  600. package/build/node/extension.js +0 -1
  601. package/build/node/index.js +0 -44
  602. package/build/node/surfaces/admin/api/checkout-editor/README.md +0 -1
  603. package/build/node/surfaces/admin/api/checkout-editor/render-settings.js +0 -1
  604. package/build/node/surfaces/admin/api/standard/README.md +0 -1
  605. package/build/node/surfaces/admin/api/standard/standard.js +0 -1
  606. package/build/node/surfaces/admin/api.js +0 -1
  607. package/build/node/surfaces/admin/components/TextField/TextField.js +0 -11
  608. package/build/node/surfaces/admin/components.js +0 -30
  609. package/build/node/surfaces/admin/extension-points.js +0 -1
  610. package/build/node/surfaces/admin/extension.js +0 -27
  611. package/build/node/surfaces/admin/index.js +0 -70
  612. package/build/node/surfaces/admin/shared.js +0 -1
  613. package/build/node/surfaces/checkout/api/cart-line-details/README.md +0 -1
  614. package/build/node/surfaces/checkout/api/cart-line-details/render-after.js +0 -1
  615. package/build/node/surfaces/checkout/api/shared.js +0 -1
  616. package/build/node/surfaces/checkout/api/standard/README.md +0 -1
  617. package/build/node/surfaces/checkout/api/standard/standard.js +0 -1
  618. package/build/node/surfaces/checkout/api.js +0 -1
  619. package/build/node/surfaces/checkout/components.js +0 -18
  620. package/build/node/surfaces/checkout/extension-points.js +0 -1
  621. package/build/node/surfaces/checkout/extension.js +0 -27
  622. package/build/node/surfaces/checkout/index.js +0 -70
  623. package/build/node/surfaces/checkout/shared.js +0 -1
  624. package/build/node/utilities/registration.js +0 -44
  625. package/build/ts/api.js +0 -2
  626. package/build/ts/components/BlockStack/BlockStack.d.ts +0 -8
  627. package/build/ts/components/BlockStack/BlockStack.d.ts.map +0 -1
  628. package/build/ts/components/BlockStack/BlockStack.js +0 -5
  629. package/build/ts/components/Button/Button.d.ts +0 -12
  630. package/build/ts/components/Button/Button.d.ts.map +0 -1
  631. package/build/ts/components/Button/Button.js +0 -5
  632. package/build/ts/components/Checkbox/Checkbox.d.ts +0 -30
  633. package/build/ts/components/Checkbox/Checkbox.d.ts.map +0 -1
  634. package/build/ts/components/Checkbox/Checkbox.js +0 -8
  635. package/build/ts/components/Text/Text.d.ts +0 -8
  636. package/build/ts/components/Text/Text.d.ts.map +0 -1
  637. package/build/ts/components/Text/Text.js +0 -5
  638. package/build/ts/components/TextField/TextField.d.ts +0 -53
  639. package/build/ts/components/TextField/TextField.d.ts.map +0 -1
  640. package/build/ts/components/TextField/TextField.js +0 -5
  641. package/build/ts/components/View/View.d.ts +0 -8
  642. package/build/ts/components/View/View.d.ts.map +0 -1
  643. package/build/ts/components/View/View.js +0 -5
  644. package/build/ts/components.d.ts +0 -13
  645. package/build/ts/components.d.ts.map +0 -1
  646. package/build/ts/components.js +0 -15
  647. package/build/ts/extension.js +0 -2
  648. package/build/ts/index.js +0 -19
  649. package/build/ts/surfaces/admin/api/checkout-editor/render-settings.d.ts +0 -19
  650. package/build/ts/surfaces/admin/api/checkout-editor/render-settings.d.ts.map +0 -1
  651. package/build/ts/surfaces/admin/api/checkout-editor/render-settings.js +0 -2
  652. package/build/ts/surfaces/admin/api/standard/standard.d.ts +0 -7
  653. package/build/ts/surfaces/admin/api/standard/standard.d.ts.map +0 -1
  654. package/build/ts/surfaces/admin/api/standard/standard.js +0 -2
  655. package/build/ts/surfaces/admin/api.d.ts +0 -3
  656. package/build/ts/surfaces/admin/api.d.ts.map +0 -1
  657. package/build/ts/surfaces/admin/api.js +0 -2
  658. package/build/ts/surfaces/admin/components/TextField/TextField.d.ts +0 -15
  659. package/build/ts/surfaces/admin/components/TextField/TextField.d.ts.map +0 -1
  660. package/build/ts/surfaces/admin/components/TextField/TextField.js +0 -5
  661. package/build/ts/surfaces/admin/components.d.ts +0 -4
  662. package/build/ts/surfaces/admin/components.d.ts.map +0 -1
  663. package/build/ts/surfaces/admin/components.js +0 -20
  664. package/build/ts/surfaces/admin/extension-points.d.ts +0 -9
  665. package/build/ts/surfaces/admin/extension-points.d.ts.map +0 -1
  666. package/build/ts/surfaces/admin/extension-points.js +0 -2
  667. package/build/ts/surfaces/admin/extension.d.ts +0 -4
  668. package/build/ts/surfaces/admin/extension.d.ts.map +0 -1
  669. package/build/ts/surfaces/admin/extension.js +0 -20
  670. package/build/ts/surfaces/admin/index.d.ts +0 -6
  671. package/build/ts/surfaces/admin/index.d.ts.map +0 -1
  672. package/build/ts/surfaces/admin/index.js +0 -21
  673. package/build/ts/surfaces/admin/shared.d.ts +0 -8
  674. package/build/ts/surfaces/admin/shared.d.ts.map +0 -1
  675. package/build/ts/surfaces/admin/shared.js +0 -2
  676. package/build/ts/surfaces/checkout/api/cart-line-details/render-after.js +0 -2
  677. package/build/ts/surfaces/checkout/api/shared.js +0 -2
  678. package/build/ts/surfaces/checkout/api/standard/standard.js +0 -2
  679. package/build/ts/surfaces/checkout/api.js +0 -2
  680. package/build/ts/surfaces/checkout/components.js +0 -17
  681. package/build/ts/surfaces/checkout/extension-points.js +0 -2
  682. package/build/ts/surfaces/checkout/extension.js +0 -20
  683. package/build/ts/surfaces/checkout/index.js +0 -21
  684. package/build/ts/surfaces/checkout/shared.js +0 -2
  685. package/build/ts/utilities/registration.js +0 -111
  686. package/build/tsconfig.tsbuildinfo +0 -1
  687. package/checkout.d.ts +0 -1
  688. package/index.d.ts +0 -1
  689. package/sewing-kit.config.ts +0 -9
  690. package/src/components/BlockStack/BlockStack.ts +0 -7
  691. package/src/components/BlockStack/README.md +0 -1
  692. package/src/components/Button/Button.ts +0 -10
  693. package/src/components/Button/README.md +0 -1
  694. package/src/components/Checkbox/README.md +0 -1
  695. package/src/components/Text/README.md +0 -1
  696. package/src/components/Text/Text.ts +0 -5
  697. package/src/components/TextField/README.md +0 -1
  698. package/src/components/TextField/TextField.ts +0 -56
  699. package/src/components/View/README.md +0 -1
  700. package/src/components/View/View.ts +0 -5
  701. package/src/components.ts +0 -17
  702. package/src/surfaces/admin/api/checkout-editor/README.md +0 -1
  703. package/src/surfaces/admin/api/checkout-editor/render-settings.ts +0 -26
  704. package/src/surfaces/admin/api/standard/README.md +0 -1
  705. package/src/surfaces/admin/api/standard/standard.ts +0 -8
  706. package/src/surfaces/admin/api.ts +0 -2
  707. package/src/surfaces/admin/components/TextField/TextField.ts +0 -16
  708. package/src/surfaces/admin/components.ts +0 -4
  709. package/src/surfaces/admin/extension-points.ts +0 -17
  710. package/src/surfaces/admin/extension.ts +0 -7
  711. package/src/surfaces/admin/index.ts +0 -5
  712. package/src/surfaces/admin/shared.ts +0 -14
  713. package/tsconfig.json +0 -9
@@ -0,0 +1,26 @@
1
+ import {createRemoteComponent} from '@remote-ui/core';
2
+
3
+ import type {IconSource} from '../Icon/Icon';
4
+
5
+ export interface TagProps {
6
+ children?: string;
7
+ /**
8
+ * Icon source
9
+ */
10
+ icon?: IconSource;
11
+ /**
12
+ * A label used for buyers using assistive technologies. When set, any
13
+ * `children` supplied to this component are hidden from being seen for
14
+ * accessibility purposes to prevent duplicate content from being read.
15
+ */
16
+ accessibilityLabel?: string;
17
+ /**
18
+ * Callback when tag is removed
19
+ */
20
+ onRemove?(): void;
21
+ }
22
+
23
+ /**
24
+ * A Tag is used to help label, organize or categorize objects. It is commonly used in Checkout to display the discounts applied to a cart.
25
+ */
26
+ export const Tag = createRemoteComponent<'Tag', TagProps>('Tag');
@@ -0,0 +1,7 @@
1
+ import {extend, Tag} from '@shopify/checkout-ui-extensions';
2
+
3
+ extend('Checkout::Dynamic::Render', (root) => {
4
+ const tag = root.createComponent(Tag, {icon: 'discount'}, 'SPRING');
5
+
6
+ root.appendChild(tag);
7
+ });
@@ -0,0 +1,17 @@
1
+ # Text
2
+
3
+ Text is used to visually style and provide semantic value for a small piece of text
4
+ content.
5
+
6
+ ## Props
7
+
8
+ optional = ?
9
+
10
+ | Name | Type | Description |
11
+ | ------------------ | ------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------ | ---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
12
+ | size? | <code>"extraSmall" &#124; "small" &#124; "base" &#124; "large" &#124; "extraLarge" &#124; "medium"</code> | Size of the text |
13
+ | emphasis? | <code>"italic" &#124; "bold"</code> | Use to emphasize a word or a group of words.<br /><br /><code>"italic"</code>: Set the text in italic. Combine with an `accessibilityRole` of `offset` or `stress` to add more meaning to the text.<br /><br /><code>"bold"</code>: Set the text in bold. Combine with an `accessibilityRole` of `strong` to add more meaning to the text. |
14
+ | accessibilityRole? | <code>"address" &#124; "deletion" &#124; "marking" &#124; {type: "abbreviation", for?: string} &#124; {type: "directional-override", direction: "ltr" &#124; "rtl"} &#124; {type: "datetime", machineReadable?: string} &#124; "stress" &#124; "offset" &#124; "strong"</code> | Set the semantic of the component’s content<br /><br /><code>"address"</code>: Indicate the text is contact information. Typically used for addresses.<br /><br /><code>"deletion"</code>: Indicate the text has been deleted. Typically used for discounted prices.<br /><br /><code>"marking"</code>: Indicate the text is marked or highlighted and relevant to the buyer’s current action. Typically used to indicate the characters that matched a search query.<br /><br /><code>{type: "abbreviation", for?: string}</code>: Indicate the text is an abbreviation or acronym. Use the `for` option to provide a description of the abbreviation.<br /><br /><code>{type: "directional-override", direction: "ltr" &#124; "rtl"}</code>: Override the text directionality. Typically used for email and phone numbers.<br /><br /><code>{type: "datetime", machineReadable?: string}</code>: Indicate the text is a date, a time or a duration. Use the `machineReadable` option to help browsers, tools or software understand the human-readable date. The valid format for `machineReadable` can be found here: https://developer.mozilla.org/en-US/docs/Web/HTML/Element/time#Valid_datetime_Values<br /><br /><code>"stress"</code>: Indicate emphatic stress. Typically for words that have a stressed emphasis compared to surrounding text. In an HTML host, the text will be rendered in a `<em>` tag.<br /><br /><code>"offset"</code>: Indicate an offset from the normal prose of the text. Typically used to indicate a foreign word, fictional character thoughts, or when the text refers to the definition of a word instead of representing its semantic meaning. In an HTML host, the text will be rendered in a `<i>` tag.<br /><br /><code>"strong"</code>: Indicate strong importance, seriousness, or urgency. In an HTML host, the text will be rendered in a `<strong>` tag. |
15
+ | id? | <code>string</code> | Unique identifier. Typically used as a target for another component’s controls to associate an accessible label with an action. |
16
+ | appearance? | <code>"accent" &#124; "subdued" &#124; "info" &#124; "success" &#124; "warning" &#124; "critical"</code> | Changes the visual appearance<br /><br /><code>"accent"</code>: Use to convey emphasis and draw attention to the icon.<br /><br /><code>"subdued"</code>: Use to convey a subdued or disabled state for the icon.<br /><br /><code>"info"</code>: Use to convey icon is informative or has information.<br /><br /><code>"success"</code>: Use to convey a successful interaction.<br /><br /><code>"warning"</code>: Use to convey something needs attention or an action needs to be taken.<br /><br /><code>"critical"</code>: Use to convey a problem has arisen. |
17
+ | visibility? | <code>"hidden"</code> | Changes the visibility of the element.<br /><br />`hidden` visually hides the component while keeping it accessible to assistive technology, such as screen readers. Hidden elements don't take any visual space contrary to CSS visibility: hidden; |
@@ -0,0 +1,44 @@
1
+ import {createRemoteComponent} from '@remote-ui/core';
2
+
3
+ import type {
4
+ TextAccessibilityRole,
5
+ Emphasis,
6
+ Size,
7
+ Appearance,
8
+ VisibilityProps,
9
+ } from '../shared';
10
+
11
+ export interface TextProps extends VisibilityProps {
12
+ /**
13
+ * Size of the text
14
+ */
15
+ size?:
16
+ | Extract<Size, 'extraSmall' | 'small' | 'base' | 'large' | 'extraLarge'>
17
+ | 'medium';
18
+ /**
19
+ * Use to emphasize a word or a group of words.
20
+ */
21
+ emphasis?: Emphasis;
22
+ /**
23
+ * Set the semantic of the component’s content
24
+ */
25
+ accessibilityRole?: TextAccessibilityRole;
26
+ /**
27
+ * Unique identifier. Typically used as a target for another component’s controls
28
+ * to associate an accessible label with an action.
29
+ */
30
+ id?: string;
31
+ /**
32
+ * Changes the visual appearance
33
+ */
34
+ appearance?: Extract<
35
+ Appearance,
36
+ 'accent' | 'subdued' | 'info' | 'success' | 'warning' | 'critical'
37
+ >;
38
+ }
39
+
40
+ /**
41
+ * Text is used to visually style and provide semantic value for a small piece of text
42
+ * content.
43
+ */
44
+ export const Text = createRemoteComponent<'Text', TextProps>('Text');
@@ -0,0 +1,10 @@
1
+ ## Best practices
2
+
3
+ - Use larger text to emphasize content that’s not a heading, such as a price total.
4
+ - Create contrast between more and less important text with properties such as `size`, `emphasized`, and `subdued`.
5
+
6
+ ## Related components
7
+
8
+ - [`Heading`](https://github.com/Shopify/ui-extensions/tree/main/packages/checkout-ui-extensions/src/components/Heading): Controls the visual style of headings. Use headings to introduce major sections, like **Contact information**, **Shipping address**, and **Shipping method**.
9
+ - [`HeadingGroup`](https://github.com/Shopify/ui-extensions/tree/main/packages/checkout-ui-extensions/src/components/HeadingGroup): Controls the H level of headings when nested within the group, like H1, H2, and H3.
10
+ - [`TextBlock`](https://github.com/Shopify/ui-extensions/tree/main/packages/checkout-ui-extensions/src/components/TextBlock): Renders a block of text that occupies the full width available, like a paragraph.
@@ -0,0 +1,14 @@
1
+ import {extend, Text, BlockStack} from '@shopify/checkout-ui-extensions';
2
+
3
+ extend('Checkout::Dynamic::Render', (root) => {
4
+ const text = root.createComponent(BlockStack, undefined, [
5
+ root.createComponent(Text, {size: 'extraSmall'}, 'Total'),
6
+ root.createComponent(Text, {size: 'small'}, 'Total'),
7
+ root.createComponent(Text, {size: 'base'}, 'Total'),
8
+ root.createComponent(Text, {size: 'medium'}, 'Total'),
9
+ root.createComponent(Text, {size: 'large'}, 'Total'),
10
+ root.createComponent(Text, {size: 'extraLarge'}, 'Total'),
11
+ ]);
12
+
13
+ root.appendChild(text);
14
+ });
@@ -0,0 +1,15 @@
1
+ # TextBlock
2
+
3
+ Text block is used to render a block of text that occupies the full width available, like a paragraph.
4
+
5
+ ## Props
6
+
7
+ optional = ?
8
+
9
+ | Name | Type | Description |
10
+ | ---------------- | --------------------------------------------------------------------------------------------------------- | --------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
11
+ | size? | <code>"extraSmall" &#124; "small" &#124; "base" &#124; "large" &#124; "extraLarge" &#124; "medium"</code> | Size of the text |
12
+ | emphasis? | <code>"italic" &#124; "bold"</code> | Use to emphasize a word or a group of words.<br /><br /><code>"italic"</code>: Set the text in italic. Combine with an `accessibilityRole` of `offset` or `stress` to add more meaning to the text.<br /><br /><code>"bold"</code>: Set the text in bold. Combine with an `accessibilityRole` of `strong` to add more meaning to the text. |
13
+ | id? | <code>string</code> | Unique identifier |
14
+ | appearance? | <code>"accent" &#124; "subdued" &#124; "info" &#124; "success" &#124; "warning" &#124; "critical"</code> | Changes the visual appearance<br /><br /><code>"accent"</code>: Use to convey emphasis and draw attention to the icon.<br /><br /><code>"subdued"</code>: Use to convey a subdued or disabled state for the icon.<br /><br /><code>"info"</code>: Use to convey icon is informative or has information.<br /><br /><code>"success"</code>: Use to convey a successful interaction.<br /><br /><code>"warning"</code>: Use to convey something needs attention or an action needs to be taken.<br /><br /><code>"critical"</code>: Use to convey a problem has arisen. |
15
+ | inlineAlignment? | <code>"start" &#124; "center" &#124; "end"</code> | Align text along the main axis. |
@@ -0,0 +1,38 @@
1
+ import {createRemoteComponent} from '@remote-ui/core';
2
+
3
+ import type {InlineAlignment, Emphasis, Size, Appearance} from '../shared';
4
+
5
+ export interface TextBlockProps {
6
+ /**
7
+ * Size of the text
8
+ */
9
+ size?:
10
+ | Extract<Size, 'extraSmall' | 'small' | 'base' | 'large' | 'extraLarge'>
11
+ | 'medium';
12
+ /**
13
+ * Use to emphasize a word or a group of words.
14
+ */
15
+ emphasis?: Emphasis;
16
+ /**
17
+ * Unique identifier
18
+ */
19
+ id?: string;
20
+ /**
21
+ * Changes the visual appearance
22
+ */
23
+ appearance?: Extract<
24
+ Appearance,
25
+ 'accent' | 'subdued' | 'info' | 'success' | 'warning' | 'critical'
26
+ >;
27
+ /**
28
+ * Align text along the main axis.
29
+ */
30
+ inlineAlignment?: InlineAlignment;
31
+ }
32
+
33
+ /**
34
+ * Text block is used to render a block of text that occupies the full width available, like a paragraph.
35
+ */
36
+ export const TextBlock = createRemoteComponent<'TextBlock', TextBlockProps>(
37
+ 'TextBlock',
38
+ );
@@ -0,0 +1,9 @@
1
+ ## Best practices
2
+
3
+ - Create contrast between more and less important text with properties such as `size`, `emphasized`, and `subdued`.
4
+
5
+ ## Related components
6
+
7
+ - [`Heading`](https://github.com/Shopify/ui-extensions/tree/main/packages/checkout-ui-extensions/src/components/Heading): Controls the visual style of headings. Use headings to introduce major sections, like **Contact information**, **Shipping address**, or **Shipping method**.
8
+ - [`HeadingGroup`](https://github.com/Shopify/ui-extensions/tree/main/packages/checkout-ui-extensions/src/components/HeadingGroup): Controls the H level of headings when nested within the group, like H1, H2, and H3.
9
+ - [`Text`](https://github.com/Shopify/ui-extensions/tree/main/packages/checkout-ui-extensions/src/components/Text): Styles and provides semantic value for a specific piece of text content.
@@ -0,0 +1,18 @@
1
+ import {extend, TextBlock, BlockStack} from '@shopify/checkout-ui-extensions';
2
+
3
+ extend('Checkout::Dynamic::Render', (root) => {
4
+ const textBlock = root.createComponent(BlockStack, undefined, [
5
+ root.createComponent(
6
+ TextBlock,
7
+ undefined,
8
+ 'We have a 30-day return policy, which means you have 30 days after receiving your item to request a return.',
9
+ ),
10
+ root.createComponent(
11
+ TextBlock,
12
+ undefined,
13
+ 'To be eligible for a return, your item must be in the same condition that you received it, unworn or unused, with tags, and in its original packaging. You’ll also need the receipt or proof of purchase.',
14
+ ),
15
+ ]);
16
+
17
+ root.appendChild(textBlock);
18
+ });
@@ -0,0 +1,49 @@
1
+ # TextField
2
+
3
+ Use a text field to get text input from a customer.
4
+
5
+ ## Props
6
+
7
+ optional = ?
8
+
9
+ | Name | Type | Description |
10
+ | ------------------------- | ---------------------------------------------------------------------------------------------------------------------------------------- | ----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | --------------------------- |
11
+ | id? | <code>string</code> | A unique identifier for the field. When no `id` is set, a globally unique value will be used instead. |
12
+ | icon? | <code><a href="#iconsource">IconSource</a> &#124; {source: <a href="#iconsource">IconSource</a>, position?: "start" &#124; "end"}</code> | An icon to render at the start or end of the field. It will render at the start by default. |
13
+ | name? | <code>string</code> | An identifier for the field that is unique within the nearest containing `Form` component. |
14
+ | label | <code>string</code> | Content to use as the field label. This value is also used as the placeholder when the field is empty. |
15
+ | prefix? | <code>string</code> | Text content to render before the value. |
16
+ | suffix? | <code>string</code> | Text content to render at the end of the text field. |
17
+ | accessory? | <code>string &#124; RemoteFragment</code> | Any content to render at the end of the text field. Commonly used to display an icon that opens a tooltip providing more information about the field. |
18
+ | accessibilityDescription? | <code>string</code> | A detailed description for screen readers. |
19
+ | value? | <code>string &#124; number &#124; undefined</code> | The current value for the field. If omitted, the field will be empty. You should update this value in response to the `onChange` callback. |
20
+ | controlledValue? | <code>string &#124; number &#124; undefined</code> | In rare cases, like the PhoneField component, we completely control state. In those cases, there is never a difference between the `value` prop of the field and the current value in the field, and so this component never considers the field to have changed. Use the `controlledValue` prop to provide the value that should be shown to the buyer in those circumstances, but where the `value` prop will continue to be used as the comparison value to determine whether the field has changed. This value will usually be set to the last committed, unformatted value for the controlled input. |
21
+ | type? | <code>"text" &#124; "email" &#124; "number" &#124; "telephone"</code> | The content type a buyer will enter into the field. This type is used to provide semantic value to the field and, where possible, will provide the buyer with a better editing experience for the content type.<br /><br />Note that the type property does not change the way the text field’s value will be provided in `onChange` or `onInput`; a text field with a type of `'number'` will still provide the exact user entry, as a string, to those callbacks. The type also does not perform any form of automatic validation. If you want to perform validation, use the `error` property. |
22
+ | required? | <code>boolean</code> | Whether the field needs a value. This requirement adds semantic value to the field, but it will not cause an error to appear automatically. If you want to present an error when this field is empty, you can do so with the `error` prop. |
23
+ | error? | <code>string</code> | Indicate an error to the user. The field will be given a specific stylistic treatment to communicate problems that have to be resolved immediately. |
24
+ | multiline? | <code>boolean &#124; number</code> | Whether the field supports multiple lines of input. Set a `number` to define the default lines of the input. |
25
+ | autocomplete? | <code><a href="#autocomplete">Autocomplete</a> &#124; boolean</code> | A hint as to the intended content of the field.<br /><br />When set to `true`, this property indicates that the field should support autofill, but you do not have any more semantic information on the intended contents.<br /><br />When set to `false`, you are indicating that this field contains sensitive information, or contents that are never saved, like one-time codes.<br /><br />Alternatively, you can provide an `Autocomplete` object, which describes the specific data you would like to be entered into this field during autofill. |
26
+ | disabled? | <code>boolean</code> | Whether the field can be modified. |
27
+ | readonly? | <code>boolean</code> | Whether the field is read-only. |
28
+ | maxLength? | <code>number</code> | Specifies the maximum number of characters allowed. |
29
+ | onFocus? | <code>() => void</code> | Callback when input is focused. |
30
+ | onBlur? | <code>() => void</code> | Callback when focus is removed. |
31
+ | onChange? | <code>(value: string &#124; number &#124; undefined) => void</code> | Callback when the buyer has **finished editing** a field. Unlike `onChange` callbacks you may be familiar with from Polaris or other React component libraries, this callback is **not** run on every change to the input. Text fields are “partially controlled” components, which means that while the buyer edits the field, its state is controlled by the component. Once the buyer has signalled that they have finished editing the field (typically, by blurring the field), `onChange` is called if the input actually changed from the most recent `value` property. At that point, you are expected to store this “committed value” in state, and reflect it in the text field’s `value` property.<br /><br />This state management model is important given how UI Extensions are rendered. UI Extension components run on a separate thread from the UI, so they can’t respond to input synchronously. A pattern popularized by [controlled React components](https://reactjs.org/docs/forms.html#controlled-components) is to have the component be the source of truth for the input `value`, and update the `value` on every user input. The delay in responding to events from a UI extension is only a few milliseconds, but attempting to strictly store state with this delay can cause issues if a user types quickly, or if the buyer is using a lower-powered device. Having the UI thread take ownership for “in progress” input, and only synchronizing when the user is finished with a field, avoids this risk.<br /><br />It can still sometimes be useful to be notified when the user makes any input in the field. If you need this capability, you can use the `onInput` prop. However, never use that property to create tightly controlled state for the `value`.<br /><br />This callback is called with the current value of the field. If the value of a field is the same as the current `value` prop provided to the field, the `onChange` callback will not be run. |
32
+ | onInput? | <code>(value: string &#124; number &#124; undefined) => void</code> | Callback when the user makes any changes in the field. As noted in the documentation for `onChange`, you **must not** use this to update `state` — use the `onChange` callback for that purpose. Use the `onInput` prop when you need to do something as soon as the buyer makes a change, like clearing validation errors that apply to the field as soon as the user begins making the necessary adjustments.<br /><br />This callback is called with the current value of the field. | <a name="Autocomplete"></a> |
33
+
34
+ ### Autocomplete
35
+
36
+ A descriptor for selecting the data a field would like to receive during
37
+ autocomplete. This attribute is modeled off of a limited set of the autocomplete
38
+ values supported in browsers.
39
+
40
+ | Name | Type | Description |
41
+ | ------ | --------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | ------------------------------------------------------------------------------ |
42
+ | group? | <code>"shipping" &#124; "billing" &#124; "location"</code> | The contact information “group” the autocomplete data should be sourced from. |
43
+ | field | <code>"name" &#124; "honorific-prefix" &#124; "given-name" &#124; "additional-name" &#124; "family-name" &#124; "honorific-suffix" &#124; "nickname" &#124; "username" &#124; "new-password" &#124; "current-password" &#124; "one-time-code" &#124; "organization-title" &#124; "organization" &#124; "street-address" &#124; "address-line1" &#124; "address-line2" &#124; "address-line3" &#124; "address-level4" &#124; "address-level3" &#124; "address-level2" &#124; "address-level1" &#124; "country" &#124; "country-name" &#124; "postal-code" &#124; "credit-card-name" &#124; "credit-card-given-name" &#124; "credit-card-additional-name" &#124; "credit-card-family-name" &#124; "credit-card-number" &#124; "credit-card-expiry" &#124; "credit-card-expiry-month" &#124; "credit-card-expiry-year" &#124; "credit-card-security-code" &#124; "credit-card-type" &#124; "transaction-currency" &#124; "transaction-amount" &#124; "language" &#124; "birthday" &#124; "birthday-day" &#124; "birthday-month" &#124; "birthday-year" &#124; "sex" &#124; "url" &#124; "photo" &#124; "telephone" &#124; "telephone-country-code" &#124; "telephone-national" &#124; "telephone-area-code" &#124; "telephone-local" &#124; "telephone-local-prefix" &#124; "telephone-local-suffix" &#124; "telephone-extension" &#124; "email" &#124; "instant-message" &#124; "home telephone" &#124; "home telephone-country-code" &#124; "home telephone-national" &#124; "home telephone-area-code" &#124; "home telephone-local" &#124; "home telephone-local-prefix" &#124; "home telephone-local-suffix" &#124; "home telephone-extension" &#124; "home email" &#124; "home instant-message" &#124; "work telephone" &#124; "work telephone-country-code" &#124; "work telephone-national" &#124; "work telephone-area-code" &#124; "work telephone-local" &#124; "work telephone-local-prefix" &#124; "work telephone-local-suffix" &#124; "work telephone-extension" &#124; "work email" &#124; "work instant-message" &#124; "mobile telephone" &#124; "mobile telephone-country-code" &#124; "mobile telephone-national" &#124; "mobile telephone-area-code" &#124; "mobile telephone-local" &#124; "mobile telephone-local-prefix" &#124; "mobile telephone-local-suffix" &#124; "mobile telephone-extension" &#124; "mobile email" &#124; "mobile instant-message" &#124; "fax telephone" &#124; "fax telephone-country-code" &#124; "fax telephone-national" &#124; "fax telephone-area-code" &#124; "fax telephone-local" &#124; "fax telephone-local-prefix" &#124; "fax telephone-local-suffix" &#124; "fax telephone-extension" &#124; "fax email" &#124; "fax instant-message" &#124; "pager telephone" &#124; "pager telephone-country-code" &#124; "pager telephone-national" &#124; "pager telephone-area-code" &#124; "pager telephone-local" &#124; "pager telephone-local-prefix" &#124; "pager telephone-local-suffix" &#124; "pager telephone-extension" &#124; "pager email" &#124; "pager instant-message"</code> | The type of data that should be inserted into a field supporting autocomplete. |
44
+
45
+ <a name="IconSource"></a>
46
+
47
+ ### IconSource
48
+
49
+ <code>"arrowLeft" &#124; "arrowRight" &#124; "arrowUp" &#124; "arrowUpRight" &#124; "arrowDown" &#124; "bag" &#124; "calendar" &#124; "camera" &#124; "caretDown" &#124; "cart" &#124; "checkmark" &#124; "chevronDown" &#124; "chevronUp" &#124; "chevronRight" &#124; "chevronLeft" &#124; "close" &#124; "critical" &#124; "discount" &#124; "delivered" &#124; "delivery" &#124; "disabled" &#124; "email" &#124; "errorFill" &#124; "geolocation" &#124; "grid" &#124; "hamburger" &#124; "horizontalDots" &#124; "info" &#124; "infoFill" &#124; "list" &#124; "lock" &#124; "magnify" &#124; "map" &#124; "marker" &#124; "minus" &#124; "mobile" &#124; "note" &#124; "pen" &#124; "verticalDots" &#124; "plus" &#124; "questionFill" &#124; "reorder" &#124; "store" &#124; "success" &#124; "truck" &#124; "warning" &#124; "warningFill" &#124; "giftFill" &#124; "external" &#124; "profile"</code>
@@ -0,0 +1,173 @@
1
+ import {createRemoteComponent, RemoteFragment} from '@remote-ui/core';
2
+
3
+ import type {Autocomplete} from '../shared';
4
+ import type {IconSource} from '../Icon/Icon';
5
+
6
+ type Type = 'text' | 'email' | 'number' | 'telephone';
7
+
8
+ export interface TextFieldProps<T extends string | number | undefined> {
9
+ /**
10
+ * A unique identifier for the field. When no `id` is set,
11
+ * a globally unique value will be used instead.
12
+ */
13
+ id?: string;
14
+ /**
15
+ * An icon to render at the start or end of the field.
16
+ * It will render at the start by default.
17
+ */
18
+ icon?: IconSource | {source: IconSource; position?: 'start' | 'end'};
19
+ /**
20
+ * An identifier for the field that is unique within the nearest
21
+ * containing `Form` component.
22
+ */
23
+ name?: string;
24
+ /**
25
+ * Content to use as the field label. This value is also used as the placeholder
26
+ * when the field is empty.
27
+ */
28
+ label: string;
29
+ /**
30
+ * Text content to render before the value.
31
+ */
32
+ prefix?: string;
33
+ /**
34
+ * Text content to render at the end of the text field.
35
+ */
36
+ suffix?: string;
37
+ /**
38
+ * Any content to render at the end of the text field. Commonly used
39
+ * to display an icon that opens a tooltip providing more information about the field.
40
+ */
41
+ accessory?: string | RemoteFragment;
42
+ /**
43
+ * A detailed description for screen readers.
44
+ */
45
+ accessibilityDescription?: string;
46
+ /**
47
+ * The current value for the field. If omitted, the field will be empty. You should
48
+ * update this value in response to the `onChange` callback.
49
+ */
50
+ value?: T;
51
+ /**
52
+ * In rare cases, like the PhoneField component, we completely control state.
53
+ * In those cases, there is never a difference between the `value` prop of the field
54
+ * and the current value in the field, and so this component never considers the
55
+ * field to have changed. Use the `controlledValue` prop to provide the value that
56
+ * should be shown to the buyer in those circumstances, but where the `value` prop
57
+ * will continue to be used as the comparison value to determine whether the field
58
+ * has changed. This value will usually be set to the last committed, unformatted value
59
+ * for the controlled input.
60
+ */
61
+ controlledValue?: T;
62
+ /**
63
+ * The content type a buyer will enter into the field. This type is used to provide
64
+ * semantic value to the field and, where possible, will provide the buyer with
65
+ * a better editing experience for the content type.
66
+ *
67
+ * Note that the type property does not change the way the text field’s value will
68
+ * be provided in `onChange` or `onInput`; a text field with a type of `'number'`
69
+ * will still provide the exact user entry, as a string, to those callbacks. The
70
+ * type also does not perform any form of automatic validation. If you want to
71
+ * perform validation, use the `error` property.
72
+ */
73
+ type?: Type;
74
+ /**
75
+ * Whether the field needs a value. This requirement adds semantic value
76
+ * to the field, but it will not cause an error to appear automatically.
77
+ * If you want to present an error when this field is empty, you can do
78
+ * so with the `error` prop.
79
+ */
80
+ required?: boolean;
81
+ /**
82
+ * Indicate an error to the user. The field will be given a specific stylistic treatment
83
+ * to communicate problems that have to be resolved immediately.
84
+ */
85
+ error?: string;
86
+ /**
87
+ * Whether the field supports multiple lines of input.
88
+ * Set a `number` to define the default lines of the input.
89
+ */
90
+ multiline?: boolean | number;
91
+ /**
92
+ * A hint as to the intended content of the field.
93
+ *
94
+ * When set to `true`, this property indicates that the field should support
95
+ * autofill, but you do not have any more semantic information on the intended
96
+ * contents.
97
+ *
98
+ * When set to `false`, you are indicating that this field contains sensitive
99
+ * information, or contents that are never saved, like one-time codes.
100
+ *
101
+ * Alternatively, you can provide an `Autocomplete` object, which describes the
102
+ * specific data you would like to be entered into this field during autofill.
103
+ */
104
+ autocomplete?: Autocomplete | boolean;
105
+ /**
106
+ * Whether the field can be modified.
107
+ */
108
+ disabled?: boolean;
109
+ /**
110
+ * Whether the field is read-only.
111
+ */
112
+ readonly?: boolean;
113
+ /**
114
+ * Specifies the maximum number of characters allowed.
115
+ */
116
+ maxLength?: number;
117
+ /**
118
+ * Callback when input is focused.
119
+ */
120
+ onFocus?(): void;
121
+ /**
122
+ * Callback when focus is removed.
123
+ */
124
+ onBlur?(): void;
125
+ /**
126
+ * Callback when the buyer has **finished editing** a field. Unlike `onChange`
127
+ * callbacks you may be familiar with from Polaris or other React component libraries,
128
+ * this callback is **not** run on every change to the input. Text fields are
129
+ * “partially controlled” components, which means that while the buyer edits the
130
+ * field, its state is controlled by the component. Once the buyer has signalled that
131
+ * they have finished editing the field (typically, by blurring the field), `onChange`
132
+ * is called if the input actually changed from the most recent `value` property. At
133
+ * that point, you are expected to store this “committed value” in state, and reflect
134
+ * it in the text field’s `value` property.
135
+ *
136
+ * This state management model is important given how UI Extensions are rendered. UI Extension components
137
+ * run on a separate thread from the UI, so they can’t respond to input synchronously.
138
+ * A pattern popularized by [controlled React components](https://reactjs.org/docs/forms.html#controlled-components)
139
+ * is to have the component be the source of truth for the input `value`, and update
140
+ * the `value` on every user input. The delay in responding to events from a UI
141
+ * extension is only a few milliseconds, but attempting to strictly store state with
142
+ * this delay can cause issues if a user types quickly, or if the buyer is using a
143
+ * lower-powered device. Having the UI thread take ownership for “in progress” input,
144
+ * and only synchronizing when the user is finished with a field, avoids this risk.
145
+ *
146
+ * It can still sometimes be useful to be notified when the user makes any input in
147
+ * the field. If you need this capability, you can use the `onInput` prop. However,
148
+ * never use that property to create tightly controlled state for the `value`.
149
+ *
150
+ * This callback is called with the current value of the field. If the value of a field
151
+ * is the same as the current `value` prop provided to the field, the `onChange` callback
152
+ * will not be run.
153
+ */
154
+ onChange?(value: T): void;
155
+ /**
156
+ * Callback when the user makes any changes in the field. As noted in the documentation
157
+ * for `onChange`, you **must not** use this to update `state` — use the `onChange`
158
+ * callback for that purpose. Use the `onInput` prop when you need to do something
159
+ * as soon as the buyer makes a change, like clearing validation errors that apply to
160
+ * the field as soon as the user begins making the necessary adjustments.
161
+ *
162
+ * This callback is called with the current value of the field.
163
+ */
164
+ onInput?(value: T): void;
165
+ }
166
+
167
+ /**
168
+ * Use a text field to get text input from a customer.
169
+ */
170
+ export const TextField = createRemoteComponent<
171
+ 'TextField',
172
+ TextFieldProps<string>
173
+ >('TextField');
@@ -0,0 +1,5 @@
1
+ ## Best practices
2
+
3
+ - Clearly label text fields so that it's obvious what customers should enter.
4
+ - Label text fields as **Optional** when input isn’t required. For example, use the label **First name (optional)**.
5
+ - Don't have optional fields pass `true` to the `required` property.