@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,22 @@
1
+ # Button
2
+
3
+ Buttons are used for actions, such as “Add”, “Continue”, “Pay now”, or “Save”.
4
+
5
+ ## Props
6
+
7
+ optional = ?
8
+
9
+ | Name | Type | Description |
10
+ | ------------------- | -------------------------------------------------------- | -------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
11
+ | kind? | <code>"primary" &#124; "secondary" &#124; "plain"</code> | The type of button that will be rendered. The visual presentation of the button type is controlled by merchants through the Branding API.<br /><br />`primary`: button used for main actions. For example: &#34;Continue to next step&#34;.<br /><br />`secondary`: button used for secondary actions not blocking user progress. For example: &#34;Download Shop app&#34;.<br /><br />`plain`: renders a button that visually looks like a link.<br /><br />Default value: <code>'primary'</code> |
12
+ | appearance? | <code>"critical" &#124; "monochrome"</code> | Specify the color treatment of the Button.<br /><br /><code>"critical"</code>: Use to convey a problem has arisen.<br /><br /><code>"monochrome"</code>: Will take the color of its parent |
13
+ | submit? | <code>boolean</code> | Allows the button to submit a form. |
14
+ | to? | <code>string</code> | Destination URL to link to. If this value is set, the button will render as a Link. |
15
+ | inlineAlignment? | <code>"start" &#124; "center" &#124; "end"</code> | Specifies the inline alignment of the content.<br /><br />Default value: <code>'center'</code> |
16
+ | loading? | <code>boolean</code> | Replaces content with a loading indicator.<br /><br />Default value: <code>false</code> |
17
+ | loadingLabel? | <code>string</code> | Accessible label for the loading indicator when user prefers reduced motion. This value is only used if `loading` is true. |
18
+ | accessibilityLabel? | <code>string</code> | A label used for buyers using assistive technologies. When set, any `children` supplied to this component are hidden from being seen for accessibility purposes to prevent duplicate content from being read. |
19
+ | accessibilityRole? | <code>"button" &#124; "submit"</code> | The role of the button that will be rendered.<br /><br />`button`: renders a regular button.<br /><br />`submit`: renders a button that submits a form.<br /><br />Default value: <code>'button'</code> |
20
+ | disabled? | <code>boolean</code> | Disables the button, disallowing any interaction.<br /><br />Default value: <code>false</code> |
21
+ | onPress? | <code>() => void</code> | Callback that is run when the button is pressed. |
22
+ | overlay? | <code>RemoteFragment</code> | An overlay component to render when the user interacts with the component. |
@@ -0,0 +1,10 @@
1
+ ## Best practices
2
+
3
+ - Make button labels clear, so that customers can predict the results of interacting with the button.
4
+ - Use primary buttons for actions that progress customers through checkout, such as **Continue to shipping** and **Pay now**.
5
+ - Use secondary buttons for actions that you want to draw attention to, but aren't primary, such as **Track your order**.
6
+ - Use plain buttons when you want the appearance of a text link with the hit area of a button. This works well alongside other buttons to create hierarchies such as **Continue** and **Return to cart**.
7
+
8
+ ## Related components
9
+
10
+ - [`Link`](https://github.com/Shopify/ui-extensions/tree/main/packages/checkout-ui-extensions/src/components/Link): Makes text interactive so that customers can perform an action, such as navigating to another location.
@@ -0,0 +1,11 @@
1
+ import {extend, Button} from '@shopify/checkout-ui-extensions';
2
+
3
+ extend('Checkout::Dynamic::Render', (root) => {
4
+ const button = root.createComponent(
5
+ Button,
6
+ {onPress: () => console.log('onPress event')},
7
+ 'Pay now',
8
+ );
9
+
10
+ root.appendChild(button);
11
+ });
@@ -1,6 +1,18 @@
1
1
  import {createRemoteComponent} from '@remote-ui/core';
2
2
 
3
3
  export interface CheckboxProps {
4
+ /**
5
+ * A unique identifier for the field. When no `id` is set,
6
+ * a globally unique value will be used instead.
7
+ */
8
+ id?: string;
9
+
10
+ /**
11
+ * An identifier for the field that is unique within the nearest
12
+ * containing `Form` component.
13
+ */
14
+ name?: string;
15
+
4
16
  /**
5
17
  * Whether the checkbox is active. This prop is an alias for `checked`,
6
18
  * and can be useful in form libraries that provide a normalized API for
@@ -14,6 +26,25 @@ export interface CheckboxProps {
14
26
  */
15
27
  checked?: boolean;
16
28
 
29
+ /**
30
+ * Whether the checkbox can be changed.
31
+ */
32
+ disabled?: boolean;
33
+
34
+ /**
35
+ * Indicate an error to the user. The field will be given a specific stylistic treatment
36
+ * to communicate problems that have to be resolved immediately.
37
+ */
38
+ error?: string;
39
+
40
+ /**
41
+ * A label to use for the field that will be used for buyers using
42
+ * assistive technologies. When set, any `children` supplied to
43
+ * this component are hidden from being seen for accessibility purposes
44
+ * to prevent duplicate content from being read.
45
+ */
46
+ accessibilityLabel?: string;
47
+
17
48
  /**
18
49
  * A callback that is run whenever the checkbox is changed. This callback
19
50
  * is called with a boolean indicating whether the checkbox should now be
@@ -25,7 +56,7 @@ export interface CheckboxProps {
25
56
  }
26
57
 
27
58
  /**
28
- * Use checkboxes to give users a single binary option, such as signing up for marketing, or agreeing to terms and conditions.
59
+ * Use checkboxes to give customers a single binary option, such as signing up for marketing, or agreeing to terms and conditions.
29
60
  */
30
61
  export const Checkbox = createRemoteComponent<'Checkbox', CheckboxProps>(
31
62
  'Checkbox',
@@ -0,0 +1,18 @@
1
+ # Checkbox
2
+
3
+ Use checkboxes to give customers a single binary option, such as signing up for marketing, or agreeing to terms and conditions.
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
+ | name? | <code>string</code> | An identifier for the field that is unique within the nearest containing `Form` component. |
13
+ | value? | <code>boolean</code> | Whether the checkbox is active. This prop is an alias for `checked`, and can be useful in form libraries that provide a normalized API for dealing with both `boolean` and `string` values. If both `value` and `checked` are set, `checked` takes precedence. |
14
+ | checked? | <code>boolean</code> | Whether the checkbox is active. |
15
+ | disabled? | <code>boolean</code> | Whether the checkbox can be changed. |
16
+ | 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. |
17
+ | accessibilityLabel? | <code>string</code> | A label to use for the field that will be used for buyers using assistive technologies. When set, any `children` supplied to this component are hidden from being seen for accessibility purposes to prevent duplicate content from being read. |
18
+ | onChange? | <code>(value: boolean) => void</code> | A callback that is run whenever the checkbox is changed. This callback is called with a boolean indicating whether the checkbox should now be active or inactive. This component is [controlled](https://reactjs.org/docs/forms.html#controlled-components), so you must store this value in state and reflect it back in the `checked` or `value` props. |
@@ -0,0 +1,9 @@
1
+ ## Best practices
2
+
3
+ - Frame labels positively. For example, use **Turn on notifications** instead of **Turn off notifications**.
4
+ - Be aware of any legal issues around checkboxes. For example, to comply with GDPR, marketing sign-up checkboxes should always be deselected by default.
5
+ - Link to more information or include a subtitle as required to provide more explanation. Don’t rely on tooltips to explain a checkbox.
6
+
7
+ ## Related components
8
+
9
+ - [`ChoiceList`](https://github.com/Shopify/checkout-web/tree/master/packages/checkout-ui-extensions/src/components/ChoiceList): Creates a group of related options for customers to choose from. `ChoiceList` can be made up of radio buttons or checkboxes.
@@ -0,0 +1,11 @@
1
+ import {extend, Checkbox} from '@shopify/checkout-ui-extensions';
2
+
3
+ extend('Checkout::Dynamic::Render', (root) => {
4
+ const checkbox = root.createComponent(
5
+ Checkbox,
6
+ {id: 'checkbox', name: 'checkbox'},
7
+ 'Save this information for next time',
8
+ );
9
+
10
+ root.appendChild(checkbox);
11
+ });
@@ -0,0 +1,25 @@
1
+ import {createRemoteComponent} from '@remote-ui/core';
2
+
3
+ export interface ChoiceProps {
4
+ /**
5
+ * A unique identifier for the choice.
6
+ */
7
+ id: string;
8
+ /**
9
+ * Whether the choice can be changed.
10
+ */
11
+ disabled?: boolean;
12
+ /**
13
+ * A label to use for the choice that will be used for buyers using
14
+ * assistive technologies. When set, any `children` supplied to
15
+ * this component are hidden from being seen for accessibility purposes
16
+ * to prevent duplicate content from being read.
17
+ */
18
+ accessibilityLabel?: string;
19
+ }
20
+
21
+ /**
22
+ * Options inside a `ChoiceList`.
23
+ * The wrapping `ChoiceList` component will dictate if the choice renders as radio buttons or checkboxes.
24
+ */
25
+ export const Choice = createRemoteComponent<'Choice', ChoiceProps>('Choice');
@@ -0,0 +1,14 @@
1
+ # Choice
2
+
3
+ Options inside a `ChoiceList`.
4
+ The wrapping `ChoiceList` component will dictate if the choice renders as radio buttons or checkboxes.
5
+
6
+ ## Props
7
+
8
+ optional = ?
9
+
10
+ | Name | Type | Description |
11
+ | ------------------- | -------------------- | ------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------ |
12
+ | id | <code>string</code> | A unique identifier for the choice. |
13
+ | disabled? | <code>boolean</code> | Whether the choice can be changed. |
14
+ | accessibilityLabel? | <code>string</code> | A label to use for the choice that will be used for buyers using assistive technologies. When set, any `children` supplied to this component are hidden from being seen for accessibility purposes to prevent duplicate content from being read. |
@@ -0,0 +1,9 @@
1
+ ## Best practices
2
+
3
+ - Include a title that either tells customers what to do or explains their available options.
4
+ - Label options clearly based on what the option will do.
5
+ - Avoid options that contradict each other when you're allowing for multiple selections.
6
+
7
+ ## Related components
8
+
9
+ - [`ChoiceList`](https://github.com/Shopify/ui-extensions/tree/main/packages/checkout-ui-extensions/src/components/ChoiceList): Use choice lists to present a list of choices where buyers can make a single selection or multiple selections.
@@ -0,0 +1,50 @@
1
+ import {
2
+ extend,
3
+ ChoiceList,
4
+ Choice,
5
+ BlockStack,
6
+ InlineStack,
7
+ } from '@shopify/checkout-ui-extensions';
8
+
9
+ extend('Checkout::Dynamic::Render', (root) => {
10
+ const choiceList = root.createComponent(
11
+ ChoiceList,
12
+ {
13
+ name: 'choice',
14
+ value: 'first',
15
+ onChange: (value) => {
16
+ console.log(`onChange event with value: ${value}`);
17
+ },
18
+ },
19
+ [
20
+ root.createComponent(BlockStack, undefined, [
21
+ root.createComponent(Choice, {id: 'first'}, 'Ship'),
22
+ root.createComponent(Choice, {id: 'second'}, 'Pickup'),
23
+ ]),
24
+ ],
25
+ );
26
+
27
+ const multipleChoiceList = root.createComponent(
28
+ ChoiceList,
29
+ {
30
+ name: 'multipleChoice',
31
+ value: ['multipleFirst'],
32
+ onChange: (value) => {
33
+ console.log(`onChange event with value: ${value}`);
34
+ },
35
+ },
36
+ [
37
+ root.createComponent(BlockStack, undefined, [
38
+ root.createComponent(Choice, {id: 'multipleFirst'}, 'Gift message'),
39
+ root.createComponent(Choice, {id: 'multipleSecond'}, 'Gift wrapping'),
40
+ ]),
41
+ ],
42
+ );
43
+
44
+ const layout = root.createComponent(InlineStack, undefined, [
45
+ choiceList,
46
+ multipleChoiceList,
47
+ ]);
48
+
49
+ root.appendChild(layout);
50
+ });
@@ -0,0 +1,33 @@
1
+ import {createRemoteComponent} from '@remote-ui/core';
2
+
3
+ export interface ChoiceListProps<T extends string | string[]> {
4
+ /**
5
+ * An identifier for the field that is unique within the nearest
6
+ * containing `Form` component.
7
+ */
8
+ name: string;
9
+ /**
10
+ * A `string` or `string[]` indicating the ids of selected choices. When
11
+ * a string is set, choices render as radios. When a string array is
12
+ * set, choices render as checkboxes.
13
+ */
14
+ value: T;
15
+ /**
16
+ * A callback that is run whenever the choice list is changed. This callback
17
+ * is called with a string or array of strings indicating the ids of choices
18
+ * that should now be selected. This component is
19
+ * [controlled](https://reactjs.org/docs/forms.html#controlled-components),
20
+ * so you must store this value in state and reflect it back in the
21
+ * `value` prop.
22
+ */
23
+ onChange(value: T): void;
24
+ }
25
+
26
+ /**
27
+ * Use choice lists to present a list of choices where buyers can make
28
+ * a single selection or multiple selections.
29
+ */
30
+ export const ChoiceList = createRemoteComponent<
31
+ 'ChoiceList',
32
+ ChoiceListProps<string | string[]>
33
+ >('ChoiceList');
@@ -0,0 +1,14 @@
1
+ # ChoiceList
2
+
3
+ Use choice lists to present a list of choices where buyers can make
4
+ a single selection or multiple selections.
5
+
6
+ ## Props
7
+
8
+ optional = ?
9
+
10
+ | Name | Type | Description |
11
+ | -------- | ---------------------------------------------------- | ---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
12
+ | name | <code>string</code> | An identifier for the field that is unique within the nearest containing `Form` component. |
13
+ | value | <code>string &#124; string[]</code> | A `string` or `string[]` indicating the ids of selected choices. When a string is set, choices render as radios. When a string array is set, choices render as checkboxes. |
14
+ | onChange | <code>(value: string &#124; string[]) => void</code> | A callback that is run whenever the choice list is changed. This callback is called with a string or array of strings indicating the ids of choices that should now be selected. This component is [controlled](https://reactjs.org/docs/forms.html#controlled-components), so you must store this value in state and reflect it back in the `value` prop. |
@@ -0,0 +1,10 @@
1
+ ## Best practices
2
+
3
+ - Include a title that either tells customers what to do or explains the available options.
4
+ - Label options clearly based on what the option will do.
5
+ - Avoid mutually exclusive options when you're allowing for multiple selections.
6
+
7
+ ## Related components
8
+
9
+ - [`Choice`](https://github.com/Shopify/checkout-web/tree/master/packages/checkout-ui-extensions/src/components/Choice): The options inside the `ChoiceList` component.
10
+ - [`Checkbox`](https://github.com/Shopify/checkout-web/tree/master/packages/checkout-ui-extensions/src/components/Checkbox): Gives customers a single binary option, such as signed up for marketing, or agreeing to terms and conditions.
@@ -0,0 +1,50 @@
1
+ import {
2
+ extend,
3
+ ChoiceList,
4
+ Choice,
5
+ BlockStack,
6
+ InlineStack,
7
+ } from '@shopify/checkout-ui-extensions';
8
+
9
+ extend('Checkout::Dynamic::Render', (root) => {
10
+ const choiceList = root.createComponent(
11
+ ChoiceList,
12
+ {
13
+ name: 'choice',
14
+ value: 'first',
15
+ onChange: (value) => {
16
+ console.log(`onChange event with value: ${value}`);
17
+ },
18
+ },
19
+ [
20
+ root.createComponent(BlockStack, undefined, [
21
+ root.createComponent(Choice, {id: 'first'}, 'Ship'),
22
+ root.createComponent(Choice, {id: 'second'}, 'Pickup'),
23
+ ]),
24
+ ],
25
+ );
26
+
27
+ const multipleChoiceList = root.createComponent(
28
+ ChoiceList,
29
+ {
30
+ name: 'multipleChoice',
31
+ value: ['multipleFirst'],
32
+ onChange: (value) => {
33
+ console.log(`onChange event with value: ${value}`);
34
+ },
35
+ },
36
+ [
37
+ root.createComponent(BlockStack, undefined, [
38
+ root.createComponent(Choice, {id: 'multipleFirst'}, 'Gift message'),
39
+ root.createComponent(Choice, {id: 'multipleSecond'}, 'Gift wrapping'),
40
+ ]),
41
+ ],
42
+ );
43
+
44
+ const layout = root.createComponent(InlineStack, undefined, [
45
+ choiceList,
46
+ multipleChoiceList,
47
+ ]);
48
+
49
+ root.appendChild(layout);
50
+ });
@@ -0,0 +1,33 @@
1
+ import {createRemoteComponent} from '@remote-ui/core';
2
+
3
+ import type {Size, Alignment, Direction} from '../shared';
4
+
5
+ export interface DividerProps {
6
+ /**
7
+ * Use to create dividers with varying widths.
8
+ *
9
+ * @defaultValue 'small'
10
+ */
11
+ size?: Extract<Size, 'small' | 'base' | 'large' | 'extraLarge'>;
12
+
13
+ /**
14
+ * Use to specify direction of divider.
15
+ *
16
+ * @defaultValue 'inline'
17
+ */
18
+ direction?: Direction;
19
+
20
+ /**
21
+ * Use to specify alignment of contents of divider.
22
+ *
23
+ * @defaultValue 'center'
24
+ */
25
+ alignment?: Alignment;
26
+ }
27
+
28
+ /**
29
+ * A divider separates content and represents a thematic break between elements.
30
+ */
31
+ export const Divider = createRemoteComponent<'Divider', DividerProps>(
32
+ 'Divider',
33
+ );
@@ -0,0 +1,13 @@
1
+ # Divider
2
+
3
+ A divider separates content and represents a thematic break between elements.
4
+
5
+ ## Props
6
+
7
+ optional = ?
8
+
9
+ | Name | Type | Description |
10
+ | ---------- | --------------------------------------------------------------------- | ------------------------------------------------------------------------------------------------ |
11
+ | size? | <code>"small" &#124; "base" &#124; "large" &#124; "extraLarge"</code> | Use to create dividers with varying widths.<br /><br />Default value: <code>'small'</code> |
12
+ | direction? | <code>"inline" &#124; "block"</code> | Use to specify direction of divider.<br /><br />Default value: <code>'inline'</code> |
13
+ | alignment? | <code>"start" &#124; "center" &#124; "end"</code> | Use to specify alignment of contents of divider.<br /><br />Default value: <code>'center'</code> |
@@ -0,0 +1,7 @@
1
+ import {extend, Divider} from '@shopify/checkout-ui-extensions';
2
+
3
+ extend('Checkout::Dynamic::Render', (root) => {
4
+ const divider = root.createComponent(Divider);
5
+
6
+ root.appendChild(divider);
7
+ });
@@ -0,0 +1,30 @@
1
+ import {createRemoteComponent} from '@remote-ui/core';
2
+
3
+ export interface FormProps {
4
+ /**
5
+ * Whether the form is able to be submitted. When set to `true`, this will
6
+ * disable the implicit submit behavior of the form.
7
+ */
8
+ disabled?: boolean;
9
+ /**
10
+ * A callback that is run when the form is submitted.
11
+ */
12
+ onSubmit(): void;
13
+ /**
14
+ * An optional override for the autogenerated form ID.
15
+ */
16
+ id?: string;
17
+ }
18
+
19
+ /**
20
+ * The form component should be used to wrap one or more form controls. This
21
+ * component provides an "implicit submit" behavior, where customers can submit
22
+ * the form from any input by pressing "Enter" on their keyboards. This
23
+ * behavior is widely expected, and should be respected as often as possible.
24
+ *
25
+ * Unlike an HTML `form` element, this component does not support configuring
26
+ * the descendant fields to be submitted via HTTP automatically. Instead, you
27
+ * must provide an `onSubmit` callback that will perform the necessary HTTP
28
+ * requests in JavaScript.
29
+ */
30
+ export const Form = createRemoteComponent<'Form', FormProps>('Form');
@@ -0,0 +1,21 @@
1
+ # Form
2
+
3
+ The form component should be used to wrap one or more form controls. This
4
+ component provides an &#34;implicit submit&#34; behavior, where customers can submit
5
+ the form from any input by pressing &#34;Enter&#34; on their keyboards. This
6
+ behavior is widely expected, and should be respected as often as possible.
7
+
8
+ Unlike an HTML `form` element, this component does not support configuring
9
+ the descendant fields to be submitted via HTTP automatically. Instead, you
10
+ must provide an `onSubmit` callback that will perform the necessary HTTP
11
+ requests in JavaScript.
12
+
13
+ ## Props
14
+
15
+ optional = ?
16
+
17
+ | Name | Type | Description |
18
+ | --------- | ----------------------- | ------------------------------------------------------------------------------------------------------------------------- |
19
+ | disabled? | <code>boolean</code> | Whether the form is able to be submitted. When set to `true`, this will disable the implicit submit behavior of the form. |
20
+ | onSubmit | <code>() => void</code> | A callback that is run when the form is submitted. |
21
+ | id? | <code>string</code> | An optional override for the autogenerated form ID. |
@@ -0,0 +1,4 @@
1
+ ## Best practices
2
+
3
+ - Wrap around all form input elements.
4
+ - Forms can have only one submit button and it must be at the end of the form.
@@ -0,0 +1,48 @@
1
+ import {
2
+ extend,
3
+ BlockSpacer,
4
+ Button,
5
+ Form,
6
+ Grid,
7
+ GridItem,
8
+ TextField,
9
+ View,
10
+ } from '@shopify/checkout-ui-extensions';
11
+
12
+ extend('Checkout::Dynamic::Render', (root) => {
13
+ const fields = root.createComponent(
14
+ Grid,
15
+ {columns: ['50%', '50%'], spacing: 'base'},
16
+ [
17
+ root.createComponent(
18
+ View,
19
+ undefined,
20
+ root.createComponent(TextField, {label: 'First name'}),
21
+ ),
22
+ root.createComponent(
23
+ View,
24
+ undefined,
25
+ root.createComponent(TextField, {label: 'Last name'}),
26
+ ),
27
+ root.createComponent(
28
+ GridItem,
29
+ {columnSpan: 2},
30
+ root.createComponent(TextField, {label: 'Company'}),
31
+ ),
32
+ ],
33
+ );
34
+ const spacer = root.createComponent(BlockSpacer, {spacing: 'base'});
35
+ const button = root.createComponent(
36
+ Button,
37
+ {accessibilityRole: 'submit'},
38
+ 'Submit',
39
+ );
40
+
41
+ const form = root.createComponent(
42
+ Form,
43
+ {onSubmit: () => console.log('onSubmit event')},
44
+ [fields, spacer, button],
45
+ );
46
+
47
+ root.appendChild(form);
48
+ });
@@ -0,0 +1,104 @@
1
+ import {createRemoteComponent} from '@remote-ui/core';
2
+
3
+ import type {MaybeResponsiveConditionalStyle} from '../../style';
4
+ import type {
5
+ BlockAlignment,
6
+ BorderProps,
7
+ Columns,
8
+ InlineAlignment,
9
+ Rows,
10
+ SizingProps,
11
+ Spacing,
12
+ SpacingProps,
13
+ ViewLikeAccessibilityRole,
14
+ } from '../shared';
15
+
16
+ export interface GridProps extends BorderProps, SizingProps, SpacingProps {
17
+ /**
18
+ * Sizes for each column of the layout.
19
+ *
20
+ *
21
+ * `auto`: intrinsic size of the content.
22
+ *
23
+ * `fill`: fills the remaining available space. When multiple columns are set to `fill`, the remaining space is shared equally.
24
+ *
25
+ * `` `${number}%` ``: size in percentages.
26
+ *
27
+ * `` `${number}fr` ``: size in fractions.
28
+ *
29
+ * `number`: size in pixels.
30
+ *
31
+ *
32
+ * - When the sum of the defined sizes is larger than the available space, elements will shrink to avoid overflow.
33
+ * - Except when in scrollview, where the grid will fill the space with the defined sizes.
34
+ *
35
+ * - When only one size is set and outside of an array, the grid will have one column of that size.
36
+ *
37
+ * @defaultValue 'fill'
38
+ */
39
+ columns?: MaybeResponsiveConditionalStyle<Columns>;
40
+ /**
41
+ * Sizes for each row of the layout.
42
+ *
43
+ *
44
+ * `auto`: intrinsic size of the content.
45
+ *
46
+ * `fill`: fills the remaining available space. When multiple rows are set to `fill`, the remaining space is shared equally.
47
+ *
48
+ * `` `${number}%` ``: size in percentages.
49
+ *
50
+ * `` `${number}fr` ``: size in fractions.
51
+ *
52
+ * `number`: size in pixels.
53
+ *
54
+ *
55
+ * - When the sum of the defined sizes is larger than the available space, elements will shrink to avoid overflow.
56
+ *
57
+ * - When only one size is set and outside of an array, the grid will have one row of that size.
58
+ *
59
+ * @defaultValue 'fill'
60
+ */
61
+ rows?: MaybeResponsiveConditionalStyle<Rows>;
62
+ /**
63
+ * Adjust spacing between children.
64
+ *
65
+ * - `base` means the space between rows and columns is `base`.
66
+ *
67
+ * - [`base`, `none`] means the space between rows is `base`, space between columns is `none`.
68
+ *
69
+ * @defaultValue 'none'
70
+ **/
71
+ spacing?: MaybeResponsiveConditionalStyle<Spacing | [Spacing, Spacing]>;
72
+ /**
73
+ * Position children along the cross axis.
74
+ */
75
+ blockAlignment?: MaybeResponsiveConditionalStyle<BlockAlignment>;
76
+ /**
77
+ * Position children along the main axis.
78
+ */
79
+ inlineAlignment?: MaybeResponsiveConditionalStyle<InlineAlignment>;
80
+ /**
81
+ * Sets the semantic meaning of the component’s content. When set,
82
+ * the role will be used by assistive technologies to help buyers
83
+ * navigate the page.
84
+ *
85
+ *
86
+ * For example:
87
+ *
88
+ * - In an HTML host a `['listItem', 'separator']` tuple will render: <li role='separator'>
89
+ *
90
+ * - In an HTML host a `listItem` string will render: <li>
91
+ */
92
+ accessibilityRole?: ViewLikeAccessibilityRole;
93
+ /**
94
+ * A label that describes the purpose or contents of the element. When set,
95
+ * it will be announced to buyers using assistive technologies and will
96
+ * provide them with more context.
97
+ */
98
+ accessibilityLabel?: string;
99
+ }
100
+
101
+ /**
102
+ * Grid is used to lay out content in a matrix of rows and columns.
103
+ */
104
+ export const Grid = createRemoteComponent<'Grid', GridProps>('Grid');