@shopify/ui-extensions-server-kit 5.3.1 → 5.4.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 (244) hide show
  1. package/CHANGELOG.md +12 -0
  2. package/README.md +3 -2
  3. package/dist/ExtensionServerClient/ExtensionServerClient.d.ts +3 -5
  4. package/dist/ExtensionServerClient/server-types.d.ts +31 -7
  5. package/dist/_virtual/jsx-runtime.cjs.js +1 -0
  6. package/dist/_virtual/jsx-runtime.cjs2.js +1 -0
  7. package/dist/_virtual/jsx-runtime.es.js +5 -0
  8. package/dist/_virtual/jsx-runtime.es2.js +4 -0
  9. package/dist/_virtual/react-jsx-runtime.development.cjs.js +1 -0
  10. package/dist/_virtual/react-jsx-runtime.development.es.js +4 -0
  11. package/dist/_virtual/react-jsx-runtime.production.min.cjs.js +1 -0
  12. package/dist/_virtual/react-jsx-runtime.production.min.es.js +4 -0
  13. package/dist/context/ExtensionServerProvider.d.ts +2 -1
  14. package/dist/i18n.d.ts +2 -8
  15. package/dist/index.cjs.js +1 -1
  16. package/dist/index.cjs2.js +1 -1
  17. package/dist/index.es.js +18 -18
  18. package/dist/index.es2.js +3 -3
  19. package/dist/node_modules/.pnpm/react@18.3.1/node_modules/react/cjs/react-jsx-runtime.development.cjs.js +22 -0
  20. package/dist/node_modules/.pnpm/react@18.3.1/node_modules/react/cjs/react-jsx-runtime.development.es.js +604 -0
  21. package/dist/node_modules/.pnpm/react@18.3.1/node_modules/react/cjs/react-jsx-runtime.production.min.cjs.js +9 -0
  22. package/dist/node_modules/.pnpm/react@18.3.1/node_modules/react/cjs/react-jsx-runtime.production.min.es.js +28 -0
  23. package/dist/node_modules/.pnpm/react@18.3.1/node_modules/react/jsx-runtime.cjs.js +1 -0
  24. package/dist/node_modules/.pnpm/react@18.3.1/node_modules/react/jsx-runtime.es.js +10 -0
  25. package/dist/packages/ui-extensions-server-kit/src/ExtensionServerClient/ExtensionServerClient.cjs.js +1 -0
  26. package/dist/{ExtensionServerClient → packages/ui-extensions-server-kit/src/ExtensionServerClient}/ExtensionServerClient.es.js +21 -18
  27. package/dist/packages/ui-extensions-server-kit/src/context/ExtensionServerProvider.cjs.js +1 -0
  28. package/dist/packages/ui-extensions-server-kit/src/context/ExtensionServerProvider.es.js +30 -0
  29. package/dist/{context → packages/ui-extensions-server-kit/src/context}/constants.cjs.js +1 -1
  30. package/dist/packages/ui-extensions-server-kit/src/hooks/useExtensionServerContext.cjs.js +1 -0
  31. package/dist/{hooks → packages/ui-extensions-server-kit/src/hooks}/useExtensionServerContext.es.js +3 -2
  32. package/dist/packages/ui-extensions-server-kit/src/testing/MockExtensionServerProvider.cjs.js +1 -0
  33. package/dist/packages/ui-extensions-server-kit/src/testing/MockExtensionServerProvider.es.js +25 -0
  34. package/dist/{testing → packages/ui-extensions-server-kit/src/testing}/extensions.cjs.js +1 -1
  35. package/dist/{testing → packages/ui-extensions-server-kit/src/testing}/extensions.es.js +3 -2
  36. package/dist/packages/ui-extensions-server-kit/src/utilities/isUIExtension.cjs.js +1 -0
  37. package/dist/{utilities → packages/ui-extensions-server-kit/src/utilities}/isUIExtension.es.js +3 -2
  38. package/dist/{utilities → packages/ui-extensions-server-kit/src/utilities}/isValidSurface.cjs.js +1 -1
  39. package/dist/packages/ui-extensions-server-kit/src/utilities/isValidSurface.es.js +7 -0
  40. package/dist/testing/MockExtensionServerProvider.d.ts +2 -1
  41. package/dist/types.d.ts +14 -7
  42. package/dist/utilities/isUIExtension.d.ts +1 -1
  43. package/dist/utilities/isValidSurface.d.ts +1 -1
  44. package/dist/utilities/set.d.ts +1 -1
  45. package/node_modules/{@shopify/react-testing/LICENSE.md → @testing-library/react/LICENSE} +2 -3
  46. package/node_modules/@testing-library/react/README.md +692 -0
  47. package/node_modules/@testing-library/react/dist/@testing-library/react.cjs.js +537 -0
  48. package/node_modules/@testing-library/react/dist/@testing-library/react.esm.js +497 -0
  49. package/node_modules/@testing-library/react/dist/@testing-library/react.pure.cjs.js +501 -0
  50. package/node_modules/@testing-library/react/dist/@testing-library/react.pure.esm.js +461 -0
  51. package/node_modules/@testing-library/react/dist/@testing-library/react.pure.umd.js +502 -0
  52. package/node_modules/@testing-library/react/dist/@testing-library/react.pure.umd.js.map +1 -0
  53. package/node_modules/@testing-library/react/dist/@testing-library/react.pure.umd.min.js +2 -0
  54. package/node_modules/@testing-library/react/dist/@testing-library/react.pure.umd.min.js.map +1 -0
  55. package/node_modules/@testing-library/react/dist/@testing-library/react.umd.js +538 -0
  56. package/node_modules/@testing-library/react/dist/@testing-library/react.umd.js.map +1 -0
  57. package/node_modules/@testing-library/react/dist/@testing-library/react.umd.min.js +2 -0
  58. package/node_modules/@testing-library/react/dist/@testing-library/react.umd.min.js.map +1 -0
  59. package/node_modules/@testing-library/react/dist/act-compat.js +80 -0
  60. package/node_modules/@testing-library/react/dist/config.js +33 -0
  61. package/node_modules/@testing-library/react/dist/fire-event.js +70 -0
  62. package/node_modules/@testing-library/react/dist/index.js +52 -0
  63. package/node_modules/@testing-library/react/dist/pure.js +356 -0
  64. package/node_modules/@testing-library/react/dont-cleanup-after-each.js +1 -0
  65. package/node_modules/@testing-library/react/package.json +116 -0
  66. package/node_modules/@testing-library/react/pure.d.ts +1 -0
  67. package/node_modules/@testing-library/react/pure.js +2 -0
  68. package/node_modules/@testing-library/react/types/index.d.ts +287 -0
  69. package/node_modules/@testing-library/react/types/pure.d.ts +1 -0
  70. package/node_modules/@types/react/README.md +4 -5
  71. package/node_modules/@types/react/canary.d.ts +166 -0
  72. package/node_modules/@types/react/experimental.d.ts +21 -86
  73. package/node_modules/@types/react/global.d.ts +146 -137
  74. package/node_modules/@types/react/index.d.ts +2738 -1370
  75. package/node_modules/@types/react/jsx-dev-runtime.d.ts +45 -2
  76. package/node_modules/@types/react/jsx-runtime.d.ts +36 -2
  77. package/node_modules/@types/react/package.json +111 -54
  78. package/node_modules/@types/react/ts5.0/canary.d.ts +166 -0
  79. package/node_modules/@types/react/ts5.0/experimental.d.ts +127 -0
  80. package/node_modules/@types/react/ts5.0/global.d.ts +160 -0
  81. package/node_modules/@types/react/ts5.0/index.d.ts +4530 -0
  82. package/node_modules/@types/react/ts5.0/jsx-dev-runtime.d.ts +44 -0
  83. package/node_modules/@types/react/ts5.0/jsx-runtime.d.ts +35 -0
  84. package/node_modules/@vitejs/plugin-react/README.md +159 -0
  85. package/node_modules/@vitejs/plugin-react/dist/index.d.ts +75 -0
  86. package/node_modules/@vitejs/plugin-react/dist/index.js +401 -0
  87. package/node_modules/@vitejs/plugin-react/dist/refresh-runtime.js +663 -0
  88. package/node_modules/@vitejs/plugin-react/package.json +77 -0
  89. package/node_modules/@vitejs/plugin-react/types/preamble.d.ts +1 -0
  90. package/package.json +9 -10
  91. package/project.json +1 -1
  92. package/src/ExtensionServerClient/ExtensionServerClient.test.ts +6 -5
  93. package/src/ExtensionServerClient/ExtensionServerClient.ts +27 -19
  94. package/src/ExtensionServerClient/server-types.ts +17 -7
  95. package/src/ExtensionServerClient/types.ts +0 -2
  96. package/src/context/ExtensionServerProvider.test.tsx +55 -73
  97. package/src/context/ExtensionServerProvider.tsx +1 -0
  98. package/src/i18n.ts +2 -5
  99. package/src/state/reducers/extensionServerReducer.test.ts +2 -2
  100. package/src/testing/extensions.ts +1 -0
  101. package/src/types.ts +15 -5
  102. package/src/utilities/assetToString.ts +0 -1
  103. package/src/utilities/isUIExtension.ts +5 -4
  104. package/src/utilities/isValidSurface.ts +2 -3
  105. package/src/utilities/replaceUpdated.ts +0 -2
  106. package/src/utilities/set.ts +10 -5
  107. package/tests/setup.ts +1 -4
  108. package/vite.config.mts +57 -0
  109. package/dist/ExtensionServerClient/ExtensionServerClient.cjs.js +0 -1
  110. package/dist/context/ExtensionServerProvider.cjs.js +0 -1
  111. package/dist/context/ExtensionServerProvider.es.js +0 -29
  112. package/dist/hooks/useExtensionServerContext.cjs.js +0 -1
  113. package/dist/testing/MockExtensionServerProvider.cjs.js +0 -1
  114. package/dist/testing/MockExtensionServerProvider.es.js +0 -24
  115. package/dist/utilities/isUIExtension.cjs.js +0 -1
  116. package/dist/utilities/isValidSurface.es.js +0 -7
  117. package/node_modules/@shopify/react-testing/README.md +0 -711
  118. package/node_modules/@shopify/react-testing/build/cjs/TestWrapper.js +0 -52
  119. package/node_modules/@shopify/react-testing/build/cjs/_virtual/_rollupPluginBabelHelpers.js +0 -47
  120. package/node_modules/@shopify/react-testing/build/cjs/compat.js +0 -14
  121. package/node_modules/@shopify/react-testing/build/cjs/destroy.js +0 -13
  122. package/node_modules/@shopify/react-testing/build/cjs/element.js +0 -225
  123. package/node_modules/@shopify/react-testing/build/cjs/index.js +0 -21
  124. package/node_modules/@shopify/react-testing/build/cjs/matchers/components.js +0 -46
  125. package/node_modules/@shopify/react-testing/build/cjs/matchers/context.js +0 -25
  126. package/node_modules/@shopify/react-testing/build/cjs/matchers/index.js +0 -16
  127. package/node_modules/@shopify/react-testing/build/cjs/matchers/props.js +0 -38
  128. package/node_modules/@shopify/react-testing/build/cjs/matchers/strings.js +0 -42
  129. package/node_modules/@shopify/react-testing/build/cjs/matchers/utilities.js +0 -110
  130. package/node_modules/@shopify/react-testing/build/cjs/mount.js +0 -76
  131. package/node_modules/@shopify/react-testing/build/cjs/root.js +0 -284
  132. package/node_modules/@shopify/react-testing/build/cjs/toReactString.js +0 -86
  133. package/node_modules/@shopify/react-testing/build/cjs/types.js +0 -28
  134. package/node_modules/@shopify/react-testing/build/esm/TestWrapper.mjs +0 -44
  135. package/node_modules/@shopify/react-testing/build/esm/_virtual/_rollupPluginBabelHelpers.mjs +0 -42
  136. package/node_modules/@shopify/react-testing/build/esm/compat.mjs +0 -10
  137. package/node_modules/@shopify/react-testing/build/esm/destroy.mjs +0 -9
  138. package/node_modules/@shopify/react-testing/build/esm/element.mjs +0 -221
  139. package/node_modules/@shopify/react-testing/build/esm/index.mjs +0 -5
  140. package/node_modules/@shopify/react-testing/build/esm/matchers/components.mjs +0 -41
  141. package/node_modules/@shopify/react-testing/build/esm/matchers/context.mjs +0 -21
  142. package/node_modules/@shopify/react-testing/build/esm/matchers/index.mjs +0 -14
  143. package/node_modules/@shopify/react-testing/build/esm/matchers/props.mjs +0 -33
  144. package/node_modules/@shopify/react-testing/build/esm/matchers/strings.mjs +0 -37
  145. package/node_modules/@shopify/react-testing/build/esm/matchers/utilities.mjs +0 -101
  146. package/node_modules/@shopify/react-testing/build/esm/mount.mjs +0 -70
  147. package/node_modules/@shopify/react-testing/build/esm/root.mjs +0 -275
  148. package/node_modules/@shopify/react-testing/build/esm/toReactString.mjs +0 -80
  149. package/node_modules/@shopify/react-testing/build/esm/types.mjs +0 -26
  150. package/node_modules/@shopify/react-testing/build/esnext/TestWrapper.esnext +0 -44
  151. package/node_modules/@shopify/react-testing/build/esnext/compat.esnext +0 -10
  152. package/node_modules/@shopify/react-testing/build/esnext/destroy.esnext +0 -9
  153. package/node_modules/@shopify/react-testing/build/esnext/element.esnext +0 -221
  154. package/node_modules/@shopify/react-testing/build/esnext/index.esnext +0 -5
  155. package/node_modules/@shopify/react-testing/build/esnext/matchers/components.esnext +0 -41
  156. package/node_modules/@shopify/react-testing/build/esnext/matchers/context.esnext +0 -21
  157. package/node_modules/@shopify/react-testing/build/esnext/matchers/index.esnext +0 -14
  158. package/node_modules/@shopify/react-testing/build/esnext/matchers/props.esnext +0 -33
  159. package/node_modules/@shopify/react-testing/build/esnext/matchers/strings.esnext +0 -37
  160. package/node_modules/@shopify/react-testing/build/esnext/matchers/utilities.esnext +0 -99
  161. package/node_modules/@shopify/react-testing/build/esnext/mount.esnext +0 -71
  162. package/node_modules/@shopify/react-testing/build/esnext/root.esnext +0 -275
  163. package/node_modules/@shopify/react-testing/build/esnext/toReactString.esnext +0 -80
  164. package/node_modules/@shopify/react-testing/build/esnext/types.esnext +0 -26
  165. package/node_modules/@shopify/react-testing/build/ts/TestWrapper.d.ts +0 -17
  166. package/node_modules/@shopify/react-testing/build/ts/TestWrapper.d.ts.map +0 -1
  167. package/node_modules/@shopify/react-testing/build/ts/compat.d.ts +0 -3
  168. package/node_modules/@shopify/react-testing/build/ts/compat.d.ts.map +0 -1
  169. package/node_modules/@shopify/react-testing/build/ts/destroy.d.ts +0 -2
  170. package/node_modules/@shopify/react-testing/build/ts/destroy.d.ts.map +0 -1
  171. package/node_modules/@shopify/react-testing/build/ts/element.d.ts +0 -42
  172. package/node_modules/@shopify/react-testing/build/ts/element.d.ts.map +0 -1
  173. package/node_modules/@shopify/react-testing/build/ts/index.d.ts +0 -7
  174. package/node_modules/@shopify/react-testing/build/ts/index.d.ts.map +0 -1
  175. package/node_modules/@shopify/react-testing/build/ts/matchers/components.d.ts +0 -12
  176. package/node_modules/@shopify/react-testing/build/ts/matchers/components.d.ts.map +0 -1
  177. package/node_modules/@shopify/react-testing/build/ts/matchers/context.d.ts +0 -8
  178. package/node_modules/@shopify/react-testing/build/ts/matchers/context.d.ts.map +0 -1
  179. package/node_modules/@shopify/react-testing/build/ts/matchers/index.d.ts +0 -20
  180. package/node_modules/@shopify/react-testing/build/ts/matchers/index.d.ts.map +0 -1
  181. package/node_modules/@shopify/react-testing/build/ts/matchers/props.d.ts +0 -10
  182. package/node_modules/@shopify/react-testing/build/ts/matchers/props.d.ts.map +0 -1
  183. package/node_modules/@shopify/react-testing/build/ts/matchers/strings.d.ts +0 -11
  184. package/node_modules/@shopify/react-testing/build/ts/matchers/strings.d.ts.map +0 -1
  185. package/node_modules/@shopify/react-testing/build/ts/matchers/utilities.d.ts +0 -17
  186. package/node_modules/@shopify/react-testing/build/ts/matchers/utilities.d.ts.map +0 -1
  187. package/node_modules/@shopify/react-testing/build/ts/mount.d.ts +0 -39
  188. package/node_modules/@shopify/react-testing/build/ts/mount.d.ts.map +0 -1
  189. package/node_modules/@shopify/react-testing/build/ts/root.d.ts +0 -55
  190. package/node_modules/@shopify/react-testing/build/ts/root.d.ts.map +0 -1
  191. package/node_modules/@shopify/react-testing/build/ts/toReactString.d.ts +0 -5
  192. package/node_modules/@shopify/react-testing/build/ts/toReactString.d.ts.map +0 -1
  193. package/node_modules/@shopify/react-testing/build/ts/types.d.ts +0 -89
  194. package/node_modules/@shopify/react-testing/build/ts/types.d.ts.map +0 -1
  195. package/node_modules/@shopify/react-testing/index.esnext +0 -1
  196. package/node_modules/@shopify/react-testing/index.js +0 -1
  197. package/node_modules/@shopify/react-testing/index.mjs +0 -1
  198. package/node_modules/@shopify/react-testing/matchers.esnext +0 -1
  199. package/node_modules/@shopify/react-testing/matchers.js +0 -1
  200. package/node_modules/@shopify/react-testing/matchers.mjs +0 -1
  201. package/node_modules/@shopify/react-testing/package.json +0 -69
  202. package/node_modules/@shopify/ui-extensions-test-utils/CHANGELOG.md +0 -66
  203. package/node_modules/@shopify/ui-extensions-test-utils/dist/index.d.ts +0 -3
  204. package/node_modules/@shopify/ui-extensions-test-utils/dist/index.js +0 -3
  205. package/node_modules/@shopify/ui-extensions-test-utils/dist/render.d.ts +0 -2
  206. package/node_modules/@shopify/ui-extensions-test-utils/dist/render.js +0 -5
  207. package/node_modules/@shopify/ui-extensions-test-utils/dist/renderHook.d.ts +0 -17
  208. package/node_modules/@shopify/ui-extensions-test-utils/dist/renderHook.js +0 -20
  209. package/node_modules/@shopify/ui-extensions-test-utils/dist/withProviders.d.ts +0 -9
  210. package/node_modules/@shopify/ui-extensions-test-utils/dist/withProviders.js +0 -7
  211. package/node_modules/@shopify/ui-extensions-test-utils/package.json +0 -40
  212. package/node_modules/@shopify/ui-extensions-test-utils/project.json +0 -39
  213. package/node_modules/@vitejs/plugin-react-refresh/README.md +0 -73
  214. package/node_modules/@vitejs/plugin-react-refresh/index.d.ts +0 -14
  215. package/node_modules/@vitejs/plugin-react-refresh/index.js +0 -239
  216. package/node_modules/@vitejs/plugin-react-refresh/package.json +0 -35
  217. /package/dist/{ExtensionServerClient → packages/ui-extensions-server-kit/src/ExtensionServerClient}/types.cjs.js +0 -0
  218. /package/dist/{ExtensionServerClient → packages/ui-extensions-server-kit/src/ExtensionServerClient}/types.es.js +0 -0
  219. /package/dist/{context → packages/ui-extensions-server-kit/src/context}/constants.es.js +0 -0
  220. /package/dist/{hooks → packages/ui-extensions-server-kit/src/hooks}/useExtensionServerState.cjs.js +0 -0
  221. /package/dist/{hooks → packages/ui-extensions-server-kit/src/hooks}/useExtensionServerState.es.js +0 -0
  222. /package/dist/{hooks → packages/ui-extensions-server-kit/src/hooks}/useIsomorphicLayoutEffect.cjs.js +0 -0
  223. /package/dist/{hooks → packages/ui-extensions-server-kit/src/hooks}/useIsomorphicLayoutEffect.es.js +0 -0
  224. /package/dist/{i18n.cjs.js → packages/ui-extensions-server-kit/src/i18n.cjs.js} +0 -0
  225. /package/dist/{i18n.es.js → packages/ui-extensions-server-kit/src/i18n.es.js} +0 -0
  226. /package/dist/{state → packages/ui-extensions-server-kit/src/state}/actions/actions.cjs.js +0 -0
  227. /package/dist/{state → packages/ui-extensions-server-kit/src/state}/actions/actions.es.js +0 -0
  228. /package/dist/{state → packages/ui-extensions-server-kit/src/state}/reducers/constants.cjs.js +0 -0
  229. /package/dist/{state → packages/ui-extensions-server-kit/src/state}/reducers/constants.es.js +0 -0
  230. /package/dist/{state → packages/ui-extensions-server-kit/src/state}/reducers/extensionServerReducer.cjs.js +0 -0
  231. /package/dist/{state → packages/ui-extensions-server-kit/src/state}/reducers/extensionServerReducer.es.js +0 -0
  232. /package/dist/{testing → packages/ui-extensions-server-kit/src/testing}/app.cjs.js +0 -0
  233. /package/dist/{testing → packages/ui-extensions-server-kit/src/testing}/app.es.js +0 -0
  234. /package/dist/{types.cjs.js → packages/ui-extensions-server-kit/src/types.cjs.js} +0 -0
  235. /package/dist/{types.es.js → packages/ui-extensions-server-kit/src/types.es.js} +0 -0
  236. /package/dist/{utilities → packages/ui-extensions-server-kit/src/utilities}/assetToString.cjs.js +0 -0
  237. /package/dist/{utilities → packages/ui-extensions-server-kit/src/utilities}/assetToString.es.js +0 -0
  238. /package/dist/{utilities → packages/ui-extensions-server-kit/src/utilities}/noop.cjs.js +0 -0
  239. /package/dist/{utilities → packages/ui-extensions-server-kit/src/utilities}/noop.es.js +0 -0
  240. /package/dist/{utilities → packages/ui-extensions-server-kit/src/utilities}/replaceUpdated.cjs.js +0 -0
  241. /package/dist/{utilities → packages/ui-extensions-server-kit/src/utilities}/replaceUpdated.es.js +0 -0
  242. /package/dist/{utilities → packages/ui-extensions-server-kit/src/utilities}/set.cjs.js +0 -0
  243. /package/dist/{utilities → packages/ui-extensions-server-kit/src/utilities}/set.es.js +0 -0
  244. /package/node_modules/@vitejs/{plugin-react-refresh → plugin-react}/LICENSE +0 -0
@@ -3,7 +3,10 @@ import { isValidSurface as m } from "../utilities/isValidSurface.es.js";
3
3
  import { isUIExtension as f } from "../utilities/isUIExtension.es.js";
4
4
  class z {
5
5
  constructor(n = {}) {
6
- this.EVENT_THAT_WILL_MUTATE_THE_SERVER = ["update"], this.listeners = {}, this.connectionListeners = { close: /* @__PURE__ */ new Set(), open: /* @__PURE__ */ new Set() }, this.connected = !1, this.uiExtensionsByUuid = {}, this.id = (Math.random() + 1).toString(36).substring(7), this.options = p({
6
+ this.EVENT_THAT_WILL_MUTATE_THE_SERVER = ["update"], this.listeners = {}, this.connectionListeners = {
7
+ close: /* @__PURE__ */ new Set(),
8
+ open: /* @__PURE__ */ new Set()
9
+ }, this.connected = !1, this.uiExtensionsByUuid = {}, this.id = (Math.random() + 1).toString(36).substring(7), this.options = p({
7
10
  ...n,
8
11
  connection: {
9
12
  automaticConnect: !0,
@@ -24,19 +27,19 @@ class z {
24
27
  persist(n, t) {
25
28
  var s, e, i;
26
29
  if (this.EVENT_THAT_WILL_MUTATE_THE_SERVER.includes(n))
27
- return this.options.locales ? ((e = t.extensions) == null || e.forEach((o) => {
28
- E.forEach((a) => {
29
- var c;
30
- f(o) && ((c = o.extensionPoints) == null || c.forEach((h) => {
31
- delete h[a];
32
- })), delete o[a];
30
+ return this.options.locales ? ((e = t.extensions) == null || e.forEach((c) => {
31
+ E.forEach((o) => {
32
+ var h;
33
+ f(c) && ((h = c.extensionPoints) == null || h.forEach((a) => {
34
+ delete a[o];
35
+ })), delete c[o];
33
36
  });
34
37
  }), (i = this.connection) == null ? void 0 : i.send(JSON.stringify({ event: n, data: t }))) : (s = this.connection) == null ? void 0 : s.send(JSON.stringify({ event: n, data: t }));
35
38
  console.warn('You tried to use "persist" with a dispatch event. Please use the "emit" method instead.');
36
39
  }
37
40
  emit(...n) {
38
41
  var e;
39
- const [t, s] = n;
42
+ const t = n[0], s = n.length > 1 ? n[1] : void 0;
40
43
  if (this.EVENT_THAT_WILL_MUTATE_THE_SERVER.includes(t))
41
44
  return console.warn(
42
45
  `You tried to use "emit" with a the "${t}" event. Please use the "persist" method instead to persist changes to the server.`
@@ -55,15 +58,15 @@ class z {
55
58
  }), (n = this.connection) == null || n.addEventListener("message", (t) => {
56
59
  var s, e;
57
60
  try {
58
- const { event: i, data: o } = JSON.parse(t.data);
61
+ const { event: i, data: c } = JSON.parse(t.data), o = c;
59
62
  if (i === "dispatch") {
60
- const { type: c, payload: h } = o;
61
- (s = this.listeners[c]) == null || s.forEach((l) => l(h));
63
+ const { type: a, payload: l } = o;
64
+ (s = this.listeners[a]) == null || s.forEach((u) => u(l));
62
65
  return;
63
66
  }
64
- const a = o.extensions ? T(o.extensions, this.options.surface) : o.extensions;
65
- (e = this.listeners[i]) == null || e.forEach((c) => {
66
- c({ ...o, extensions: this._getLocalizedExtensions(a) });
67
+ const h = o.extensions ? T(o.extensions, this.options.surface) : o.extensions;
68
+ (e = this.listeners[i]) == null || e.forEach((a) => {
69
+ a({ ...o, extensions: this._getLocalizedExtensions(h) });
67
70
  });
68
71
  } catch (i) {
69
72
  console.error(
@@ -82,10 +85,10 @@ class z {
82
85
  }
83
86
  _getLocalizedExtensions(n) {
84
87
  return n == null ? void 0 : n.map((t) => {
85
- var a, c, h, l, u;
88
+ var o, h, a, l, u;
86
89
  if (!this.options.locales || !f(t))
87
90
  return t;
88
- const e = ((c = (a = this.uiExtensionsByUuid[t.uuid]) == null ? void 0 : a.localization) == null ? void 0 : c.lastUpdated) !== ((h = t.localization) == null ? void 0 : h.lastUpdated) ? g(t.localization, this.options.locales) : ((l = this.uiExtensionsByUuid[t.uuid]) == null ? void 0 : l.localization) ?? t.localization, i = e && d(e) ? JSON.parse(e.translations) : e, o = {
91
+ const e = ((h = (o = this.uiExtensionsByUuid[t.uuid]) == null ? void 0 : o.localization) == null ? void 0 : h.lastUpdated) !== ((a = t.localization) == null ? void 0 : a.lastUpdated) ? g(t.localization, this.options.locales) : ((l = this.uiExtensionsByUuid[t.uuid]) == null ? void 0 : l.localization) ?? t.localization, i = e && d(e) ? JSON.parse(e.translations) : e, c = {
89
92
  ...t,
90
93
  localization: e,
91
94
  name: i && t.name.startsWith("t:") ? this._getLocalizedValue(i, t.name) : t.name,
@@ -94,8 +97,8 @@ class z {
94
97
  }
95
98
  };
96
99
  return this.uiExtensionsByUuid[t.uuid] = {
97
- ...o,
98
- extensionPoints: this._getLocalizedExtensionPoints(e, o)
100
+ ...c,
101
+ extensionPoints: this._getLocalizedExtensionPoints(e, c)
99
102
  }, this.uiExtensionsByUuid[t.uuid];
100
103
  });
101
104
  }
@@ -0,0 +1 @@
1
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const p=require("../../../../_virtual/jsx-runtime.cjs.js"),E=require("./constants.cjs.js"),o=require("../state/actions/actions.cjs.js"),d=require("../ExtensionServerClient/ExtensionServerClient.cjs.js"),a=require("../hooks/useIsomorphicLayoutEffect.cjs.js"),l=require("../hooks/useExtensionServerState.cjs.js"),s=require("react");function q({children:f,options:x}){const[i,n]=l.useExtensionServerState(),[r,S]=s.useState(x),[t]=s.useState(()=>new d.ExtensionServerClient),u=s.useCallback((c=r)=>{S(c)},[r]);a.useIsomorphicLayoutEffect(()=>t.connect(r),[t,r]),a.useIsomorphicLayoutEffect(()=>{const c=[t.on("update",e=>n(o.createUpdateAction(e))),t.on("connected",e=>n(o.createConnectedAction(e))),t.on("refresh",e=>n(o.createRefreshAction(e))),t.on("focus",e=>n(o.createFocusAction(e))),t.on("unfocus",e=>n(o.createUnfocusAction(e)))];return()=>c.forEach(e=>e())},[n]);const v=s.useMemo(()=>({dispatch:n,state:i,connect:u,client:t}),[n,u,i,t]);return p.jsxRuntimeExports.jsx(E.extensionServerContext.Provider,{value:v,children:f})}exports.ExtensionServerProvider=q;
@@ -0,0 +1,30 @@
1
+ import { j as x } from "../../../../_virtual/jsx-runtime.es.js";
2
+ import { extensionServerContext as d } from "./constants.es.js";
3
+ import { createUpdateAction as v, createConnectedAction as l, createRefreshAction as E, createFocusAction as S, createUnfocusAction as h } from "../state/actions/actions.es.js";
4
+ import { ExtensionServerClient as A } from "../ExtensionServerClient/ExtensionServerClient.es.js";
5
+ import { useIsomorphicLayoutEffect as i } from "../hooks/useIsomorphicLayoutEffect.es.js";
6
+ import { useExtensionServerState as C } from "../hooks/useExtensionServerState.es.js";
7
+ import { useState as a, useCallback as j, useMemo as P } from "react";
8
+ function I({ children: m, options: u }) {
9
+ const [c, t] = C(), [n, f] = a(u), [o] = a(() => new A()), s = j(
10
+ (r = n) => {
11
+ f(r);
12
+ },
13
+ [n]
14
+ );
15
+ i(() => o.connect(n), [o, n]), i(() => {
16
+ const r = [
17
+ o.on("update", (e) => t(v(e))),
18
+ o.on("connected", (e) => t(l(e))),
19
+ o.on("refresh", (e) => t(E(e))),
20
+ o.on("focus", (e) => t(S(e))),
21
+ o.on("unfocus", (e) => t(h(e)))
22
+ ];
23
+ return () => r.forEach((e) => e());
24
+ }, [t]);
25
+ const p = P(() => ({ dispatch: t, state: c, connect: s, client: o }), [t, s, c, o]);
26
+ return /* @__PURE__ */ x.jsx(d.Provider, { value: p, children: m });
27
+ }
28
+ export {
29
+ I as ExtensionServerProvider
30
+ };
@@ -1 +1 @@
1
- "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const t=require("../ExtensionServerClient/ExtensionServerClient.cjs.js"),n=require("../state/reducers/constants.cjs.js"),e=require("../utilities/noop.cjs.js"),o=require("react"),r={connect:e.noop,dispatch:e.noop,state:n.INITIAL_STATE,client:new t.ExtensionServerClient},s=o.createContext(r);exports.extensionServerContext=s;
1
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const t=require("../ExtensionServerClient/ExtensionServerClient.cjs.js"),n=require("../state/reducers/constants.cjs.js"),e=require("../utilities/noop.cjs.js"),o=require("react"),r={connect:e.noop,dispatch:e.noop,state:n.INITIAL_STATE,client:new t.ExtensionServerClient},i=o.createContext(r);exports.extensionServerContext=i;
@@ -0,0 +1 @@
1
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});require("../../../../_virtual/jsx-runtime.cjs.js");const e=require("../context/constants.cjs.js"),t=require("react"),r=()=>t.useContext(e.extensionServerContext);exports.useExtensionServerContext=r;
@@ -1,6 +1,7 @@
1
+ import "../../../../_virtual/jsx-runtime.es.js";
1
2
  import { extensionServerContext as e } from "../context/constants.es.js";
2
3
  import { useContext as t } from "react";
3
- const n = () => t(e);
4
+ const x = () => t(e);
4
5
  export {
5
- n as useExtensionServerContext
6
+ x as useExtensionServerContext
6
7
  };
@@ -0,0 +1 @@
1
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const t=require("../../../../_virtual/jsx-runtime.cjs.js"),i=require("../context/ExtensionServerProvider.cjs.js"),s=require("../context/constants.cjs.js"),u=require("../hooks/useExtensionServerContext.cjs.js"),x=require("react");function c({children:n,...e}){const r=u.useExtensionServerContext(),o=x.useMemo(()=>({...r,...e}),[r,e]);return t.jsxRuntimeExports.jsx(s.extensionServerContext.Provider,{value:o,children:n})}function v({children:n,options:e={connection:{}},...r}){return t.jsxRuntimeExports.jsx(i.ExtensionServerProvider,{options:e,children:t.jsxRuntimeExports.jsx(c,{...r,children:n})})}exports.MockExtensionServerProvider=v;
@@ -0,0 +1,25 @@
1
+ import { j as t } from "../../../../_virtual/jsx-runtime.es.js";
2
+ import { ExtensionServerProvider as i } from "../context/ExtensionServerProvider.es.js";
3
+ import { extensionServerContext as s } from "../context/constants.es.js";
4
+ import { useExtensionServerContext as x } from "../hooks/useExtensionServerContext.es.js";
5
+ import { useMemo as m } from "react";
6
+ function c({ children: o, ...r }) {
7
+ const e = x(), n = m(
8
+ () => ({
9
+ ...e,
10
+ ...r
11
+ }),
12
+ [e, r]
13
+ );
14
+ return /* @__PURE__ */ t.jsx(s.Provider, { value: n, children: o });
15
+ }
16
+ function d({
17
+ children: o,
18
+ options: r = { connection: {} },
19
+ ...e
20
+ }) {
21
+ return /* @__PURE__ */ t.jsx(i, { options: r, children: /* @__PURE__ */ t.jsx(c, { ...e, children: o }) });
22
+ }
23
+ export {
24
+ d as MockExtensionServerProvider
25
+ };
@@ -1 +1 @@
1
- "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const s=require("../types.cjs.js");let i=0;function a(e){return`00000000000${e}`.slice(-12)}function r(e={}){const t=`00000000-0000-0000-0000-${a(i++)}`,n=Date.now();return{handle:"my-extension",name:"My extension",description:"My extension description",surface:"admin",type:"purchase_option",externalType:"external_type",uuid:t,version:"extension version",...e,assets:{main:{name:"main",url:`https://secure-link.com/extensions/${t}/assets/handle.js?lastUpdated=${n}`,lastUpdated:n},...e.assets??{}},development:{hidden:!1,status:s.Status.Success,resource:{url:"resourceUrl"},root:{url:`https://secure-link.com/extensions/${t}`},renderer:{name:"render name",version:"1.0.0"},...e.development??{}},extensionPoints:e.extensionPoints,capabilities:e.capabilities,localization:e.localization,authenticatedRedirectStartUrl:e.authenticatedRedirectStartUrl,authenticatedRedirectRedirectUrls:e.authenticatedRedirectRedirectUrls,settings:{fields:[{key:"sample-key",name:"sample_name",type:"sample_type"}]}}}exports.mockExtension=r;
1
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const s=require("../types.cjs.js");let i=0;function a(e){return`00000000000${e}`.slice(-12)}function r(e={}){const t=`00000000-0000-0000-0000-${a(i++)}`,n=Date.now();return{handle:"my-extension",name:"My extension",description:"My extension description",surface:"admin",type:"purchase_option",externalType:"external_type",uuid:t,version:"extension version",...e,assets:{main:{name:"main",url:`https://secure-link.com/extensions/${t}/assets/handle.js?lastUpdated=${n}`,lastUpdated:n},...e.assets??{}},development:{hidden:!1,status:s.Status.Success,resource:{url:"resourceUrl"},root:{url:`https://secure-link.com/extensions/${t}`},renderer:{name:"render name",version:"1.0.0"},...e.development??{}},extensionPoints:e.extensionPoints,capabilities:e.capabilities,supportedFeatures:e.supportedFeatures,localization:e.localization,authenticatedRedirectStartUrl:e.authenticatedRedirectStartUrl,authenticatedRedirectRedirectUrls:e.authenticatedRedirectRedirectUrls,settings:{fields:[{key:"sample-key",name:"sample_name",type:"sample_type"}]}}}exports.mockExtension=r;
@@ -3,7 +3,7 @@ let i = 0;
3
3
  function a(e) {
4
4
  return `00000000000${e}`.slice(-12);
5
5
  }
6
- function c(e = {}) {
6
+ function o(e = {}) {
7
7
  const t = `00000000-0000-0000-0000-${a(i++)}`, n = Date.now();
8
8
  return {
9
9
  handle: "my-extension",
@@ -46,6 +46,7 @@ function c(e = {}) {
46
46
  // in a generalized, non-surprising way
47
47
  extensionPoints: e.extensionPoints,
48
48
  capabilities: e.capabilities,
49
+ supportedFeatures: e.supportedFeatures,
49
50
  localization: e.localization,
50
51
  authenticatedRedirectStartUrl: e.authenticatedRedirectStartUrl,
51
52
  authenticatedRedirectRedirectUrls: e.authenticatedRedirectRedirectUrls,
@@ -61,5 +62,5 @@ function c(e = {}) {
61
62
  };
62
63
  }
63
64
  export {
64
- c as mockExtension
65
+ o as mockExtension
65
66
  };
@@ -0,0 +1 @@
1
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});function i(t){const e=t;return e.type==="ui_extension"&&Array.isArray(e.extensionPoints)&&e.extensionPoints.every(n=>typeof n=="object")}exports.isUIExtension=i;
@@ -1,6 +1,7 @@
1
- function n(e) {
1
+ function o(n) {
2
+ const e = n;
2
3
  return e.type === "ui_extension" && Array.isArray(e.extensionPoints) && e.extensionPoints.every((t) => typeof t == "object");
3
4
  }
4
5
  export {
5
- n as isUIExtension
6
+ o as isUIExtension
6
7
  };
@@ -1 +1 @@
1
- "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const i=require("../ExtensionServerClient/types.cjs.js");function t(e){return e&&i.AVAILABLE_SURFACES.includes(e)}exports.isValidSurface=t;
1
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const i=require("../ExtensionServerClient/types.cjs.js");function t(e){return!!e&&i.AVAILABLE_SURFACES.includes(e)}exports.isValidSurface=t;
@@ -0,0 +1,7 @@
1
+ import { AVAILABLE_SURFACES as i } from "../ExtensionServerClient/types.es.js";
2
+ function r(o) {
3
+ return !!o && i.includes(o);
4
+ }
5
+ export {
6
+ r as isValidSurface
7
+ };
@@ -1,7 +1,8 @@
1
+ import React from 'react';
1
2
  import type { ExtensionServerProviderProps, ExtensionServerContext } from '../context';
2
3
  interface InternalProviderProps extends Partial<ExtensionServerContext> {
3
4
  children?: ExtensionServerProviderProps['children'];
4
5
  }
5
6
  type MockExtensionServerProviderProps = Partial<ExtensionServerProviderProps> & InternalProviderProps;
6
- export declare function MockExtensionServerProvider({ children, options, ...props }: MockExtensionServerProviderProps): JSX.Element;
7
+ export declare function MockExtensionServerProvider({ children, options, ...props }: MockExtensionServerProviderProps): React.JSX.Element;
7
8
  export {};
package/dist/types.d.ts CHANGED
@@ -93,9 +93,7 @@ export interface ExtensionPoint {
93
93
  localization?: FlattenedLocalization | Localization | null;
94
94
  name: string;
95
95
  description?: string;
96
- assets?: {
97
- [name: string]: Asset;
98
- };
96
+ assets?: Record<string, Asset>;
99
97
  }
100
98
  type ExtensionPoints = string[] | ExtensionPoint[] | null;
101
99
  interface CollectBuyerConsentCapabilities {
@@ -115,9 +113,7 @@ interface Capabilities {
115
113
  export interface ExtensionPayload {
116
114
  type: string;
117
115
  externalType: string;
118
- assets: {
119
- [name: string]: Asset;
120
- };
116
+ assets: Record<string, Asset>;
121
117
  development: {
122
118
  hidden: boolean;
123
119
  status: Status;
@@ -141,6 +137,7 @@ export interface ExtensionPayload {
141
137
  handle: string;
142
138
  extensionPoints: ExtensionPoints;
143
139
  capabilities?: Capabilities;
140
+ supportedFeatures: ExtensionSupportedFeatures;
144
141
  authenticatedRedirectStartUrl?: string;
145
142
  authenticatedRedirectRedirectUrls?: string[];
146
143
  localization?: FlattenedLocalization | Localization | null;
@@ -151,10 +148,13 @@ export interface ExtensionPayload {
151
148
  name?: string;
152
149
  description?: string;
153
150
  required?: boolean;
154
- validations?: any[];
151
+ validations?: unknown[];
155
152
  }[];
156
153
  };
157
154
  }
155
+ export interface ExtensionSupportedFeatures {
156
+ runsOffline: boolean;
157
+ }
158
158
  export declare enum Status {
159
159
  Success = "success"
160
160
  }
@@ -175,5 +175,12 @@ export interface App {
175
175
  };
176
176
  supportEmail?: string;
177
177
  supportLocales?: string[];
178
+ allowedDomains?: string[];
179
+ assets?: {
180
+ [key: string]: {
181
+ url: string;
182
+ lastUpdated: number;
183
+ };
184
+ };
178
185
  }
179
186
  export {};
@@ -1 +1 @@
1
- export declare function isUIExtension(extension: any): extension is ExtensionServer.UIExtension;
1
+ export declare function isUIExtension(extension: unknown): extension is ExtensionServer.UIExtension;
@@ -1,2 +1,2 @@
1
1
  import type { Surface } from '../ExtensionServerClient/types';
2
- export declare function isValidSurface(surface: any): surface is Surface;
2
+ export declare function isValidSurface(surface: unknown): surface is Surface;
@@ -1,4 +1,4 @@
1
1
  /**
2
2
  * Deep sets an object in a type-safe way
3
3
  */
4
- export declare function set<TObject, TValue>(obj: TObject, pathFn: (o: TObject) => TValue, value: TValue): TObject;
4
+ export declare function set<TObject extends object, TValue>(obj: TObject, pathFn: (o: TObject) => TValue, value: TValue): TObject;
@@ -1,6 +1,5 @@
1
- MIT License
2
-
3
- Copyright (c) 2018-present Shopify
1
+ The MIT License (MIT)
2
+ Copyright (c) 2017-Present Kent C. Dodds
4
3
 
5
4
  Permission is hereby granted, free of charge, to any person obtaining a copy
6
5
  of this software and associated documentation files (the "Software"), to deal