@shopify/cli-kit 3.35.0 → 3.36.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 (184) hide show
  1. package/dist/content-tokens.js +1 -1
  2. package/dist/content-tokens.js.map +1 -1
  3. package/dist/error.js +2 -2
  4. package/dist/error.js.map +1 -1
  5. package/dist/index.d.ts +0 -3
  6. package/dist/index.js +0 -3
  7. package/dist/index.js.map +1 -1
  8. package/dist/metadata.d.ts +1 -1
  9. package/dist/metadata.js.map +1 -1
  10. package/dist/monorail.d.ts +1 -1
  11. package/dist/monorail.js +1 -1
  12. package/dist/monorail.js.map +1 -1
  13. package/dist/output.js +0 -4
  14. package/dist/output.js.map +1 -1
  15. package/dist/plugins.d.ts +1 -1
  16. package/dist/plugins.js.map +1 -1
  17. package/dist/{typing → private/common/ts}/deep-required.d.ts +3 -3
  18. package/dist/{typing → private/common/ts}/deep-required.js +0 -0
  19. package/dist/private/common/ts/deep-required.js.map +1 -0
  20. package/dist/{typing → private/common/ts}/overloaded-parameters.d.ts +0 -0
  21. package/dist/{typing → private/common/ts}/overloaded-parameters.js +0 -0
  22. package/dist/private/common/ts/overloaded-parameters.js.map +1 -0
  23. package/dist/private/node/api/graphql.js +1 -2
  24. package/dist/private/node/api/graphql.js.map +1 -1
  25. package/dist/private/node/api/headers.d.ts +9 -0
  26. package/dist/private/node/api/headers.js +26 -0
  27. package/dist/private/node/api/headers.js.map +1 -1
  28. package/dist/private/node/constants.js +3 -3
  29. package/dist/private/node/constants.js.map +1 -1
  30. package/dist/private/node/session/device-authorization.js +1 -1
  31. package/dist/private/node/session/device-authorization.js.map +1 -1
  32. package/dist/private/node/session/exchange.js +1 -1
  33. package/dist/private/node/session/exchange.js.map +1 -1
  34. package/dist/private/node/session/identity-token-validation.js +1 -1
  35. package/dist/private/node/session/identity-token-validation.js.map +1 -1
  36. package/dist/private/node/session/post-auth.js +3 -3
  37. package/dist/private/node/session/post-auth.js.map +1 -1
  38. package/dist/{typing → private/node}/simple-definitions.d.ts +0 -0
  39. package/dist/{typing → private/node}/simple-definitions.js +0 -0
  40. package/dist/private/node/simple-definitions.js.map +1 -0
  41. package/dist/private/node/ui/alert.d.ts +1 -1
  42. package/dist/private/node/ui/alert.js +2 -2
  43. package/dist/private/node/ui/alert.js.map +1 -1
  44. package/dist/private/node/ui/components/Alert.d.ts +5 -0
  45. package/dist/private/node/ui/components/Alert.js +9 -6
  46. package/dist/private/node/ui/components/Alert.js.map +1 -1
  47. package/dist/private/node/ui/components/Alert.test.js +30 -4
  48. package/dist/private/node/ui/components/Alert.test.js.map +1 -1
  49. package/dist/private/node/ui/components/AutocompletePrompt.d.ts +12 -0
  50. package/dist/private/node/ui/components/AutocompletePrompt.js +111 -0
  51. package/dist/private/node/ui/components/AutocompletePrompt.js.map +1 -0
  52. package/dist/private/node/ui/components/AutocompletePrompt.test.d.ts +1 -0
  53. package/dist/private/node/ui/components/AutocompletePrompt.test.js +473 -0
  54. package/dist/private/node/ui/components/AutocompletePrompt.test.js.map +1 -0
  55. package/dist/private/node/ui/components/Banner.d.ts +0 -1
  56. package/dist/private/node/ui/components/Banner.js +4 -4
  57. package/dist/private/node/ui/components/Banner.js.map +1 -1
  58. package/dist/private/node/ui/components/Banner.test.js +10 -5
  59. package/dist/private/node/ui/components/Banner.test.js.map +1 -1
  60. package/dist/private/node/ui/components/FatalError.js +1 -1
  61. package/dist/private/node/ui/components/FatalError.js.map +1 -1
  62. package/dist/private/node/ui/components/FatalError.test.js +4 -8
  63. package/dist/private/node/ui/components/FatalError.test.js.map +1 -1
  64. package/dist/private/node/ui/components/{Table.d.ts → Prompts/InfoTable.d.ts} +2 -2
  65. package/dist/private/node/ui/components/{Table.js → Prompts/InfoTable.js} +6 -6
  66. package/dist/private/node/ui/components/Prompts/InfoTable.js.map +1 -0
  67. package/dist/private/node/ui/components/SelectInput.d.ts +9 -2
  68. package/dist/private/node/ui/components/SelectInput.js +96 -52
  69. package/dist/private/node/ui/components/SelectInput.js.map +1 -1
  70. package/dist/private/node/ui/components/SelectInput.test.js +140 -54
  71. package/dist/private/node/ui/components/SelectInput.test.js.map +1 -1
  72. package/dist/private/node/ui/components/SelectPrompt.d.ts +4 -3
  73. package/dist/private/node/ui/components/SelectPrompt.js +17 -11
  74. package/dist/private/node/ui/components/SelectPrompt.js.map +1 -1
  75. package/dist/private/node/ui/components/SelectPrompt.test.js +113 -23
  76. package/dist/private/node/ui/components/SelectPrompt.test.js.map +1 -1
  77. package/dist/private/node/ui/components/Tasks.d.ts +6 -5
  78. package/dist/private/node/ui/components/Tasks.js +32 -11
  79. package/dist/private/node/ui/components/Tasks.js.map +1 -1
  80. package/dist/private/node/ui/components/Tasks.test.js +55 -9
  81. package/dist/private/node/ui/components/Tasks.test.js.map +1 -1
  82. package/dist/private/node/ui/components/TextInput.d.ts +4 -1
  83. package/dist/private/node/ui/components/TextInput.js +22 -13
  84. package/dist/private/node/ui/components/TextInput.js.map +1 -1
  85. package/dist/private/node/ui/components/TextInput.test.js +47 -40
  86. package/dist/private/node/ui/components/TextInput.test.js.map +1 -1
  87. package/dist/private/node/ui/components/TextPrompt.d.ts +3 -1
  88. package/dist/private/node/ui/components/TextPrompt.js +28 -15
  89. package/dist/private/node/ui/components/TextPrompt.js.map +1 -1
  90. package/dist/private/node/ui/components/TextPrompt.test.js +71 -15
  91. package/dist/private/node/ui/components/TextPrompt.test.js.map +1 -1
  92. package/dist/private/node/ui/components/TokenizedText.d.ts +3 -0
  93. package/dist/private/node/ui/components/TokenizedText.js +33 -1
  94. package/dist/private/node/ui/components/TokenizedText.js.map +1 -1
  95. package/dist/private/node/ui/utilities.d.ts +2 -0
  96. package/dist/private/node/ui/utilities.js +6 -0
  97. package/dist/private/node/ui/utilities.js.map +1 -0
  98. package/dist/{typing → public/common/ts}/pick-by-prefix.d.ts +4 -3
  99. package/dist/{typing → public/common/ts}/pick-by-prefix.js +0 -0
  100. package/dist/public/common/ts/pick-by-prefix.js.map +1 -0
  101. package/dist/public/common/version.d.ts +1 -1
  102. package/dist/public/common/version.js +1 -1
  103. package/dist/public/common/version.js.map +1 -1
  104. package/dist/public/node/api/admin.js +1 -1
  105. package/dist/public/node/api/admin.js.map +1 -1
  106. package/dist/public/node/api/http.d.ts +0 -0
  107. package/dist/public/node/api/http.js +2 -0
  108. package/dist/public/node/api/http.js.map +1 -0
  109. package/dist/public/node/api/oxygen.js +1 -1
  110. package/dist/public/node/api/oxygen.js.map +1 -1
  111. package/dist/public/node/archiver.js +2 -1
  112. package/dist/public/node/archiver.js.map +1 -1
  113. package/dist/public/node/cli.js +2 -2
  114. package/dist/public/node/cli.js.map +1 -1
  115. package/dist/public/node/environment/spin.js +2 -2
  116. package/dist/public/node/environment/spin.js.map +1 -1
  117. package/dist/public/node/error-handler.js +7 -5
  118. package/dist/public/node/error-handler.js.map +1 -1
  119. package/dist/public/node/framework.js +2 -2
  120. package/dist/public/node/framework.js.map +1 -1
  121. package/dist/public/node/fs.d.ts +22 -4
  122. package/dist/public/node/fs.js +34 -6
  123. package/dist/public/node/fs.js.map +1 -1
  124. package/dist/public/node/github.js +1 -1
  125. package/dist/public/node/github.js.map +1 -1
  126. package/dist/{http/fetch.d.ts → public/node/http.d.ts} +18 -7
  127. package/dist/{http/fetch.js → public/node/http.js} +22 -8
  128. package/dist/public/node/http.js.map +1 -0
  129. package/dist/public/node/liquid.js +4 -4
  130. package/dist/public/node/liquid.js.map +1 -1
  131. package/dist/public/node/node-package-manager.d.ts +22 -1
  132. package/dist/public/node/node-package-manager.js +22 -11
  133. package/dist/public/node/node-package-manager.js.map +1 -1
  134. package/dist/public/node/path.d.ts +22 -0
  135. package/dist/{path.js → public/node/path.js} +8 -20
  136. package/dist/public/node/path.js.map +1 -0
  137. package/dist/public/node/presets.js +4 -4
  138. package/dist/public/node/presets.js.map +1 -1
  139. package/dist/public/node/ruby.js +23 -27
  140. package/dist/public/node/ruby.js.map +1 -1
  141. package/dist/public/node/ui.d.ts +50 -9
  142. package/dist/public/node/ui.js +69 -8
  143. package/dist/public/node/ui.js.map +1 -1
  144. package/dist/public/node/vscode.js +4 -4
  145. package/dist/public/node/vscode.js.map +1 -1
  146. package/dist/testing/ui.d.ts +4 -1
  147. package/dist/testing/ui.js +24 -1
  148. package/dist/testing/ui.js.map +1 -1
  149. package/dist/tsconfig.tsbuildinfo +1 -1
  150. package/dist/ui/executor.d.ts +2 -14
  151. package/dist/ui/executor.js +38 -72
  152. package/dist/ui/executor.js.map +1 -1
  153. package/dist/ui.js +6 -23
  154. package/dist/ui.js.map +1 -1
  155. package/package.json +3 -5
  156. package/dist/http/fetch.js.map +0 -1
  157. package/dist/http/formdata.d.ts +0 -3
  158. package/dist/http/formdata.js +0 -6
  159. package/dist/http/formdata.js.map +0 -1
  160. package/dist/http.d.ts +0 -26
  161. package/dist/http.js +0 -31
  162. package/dist/http.js.map +0 -1
  163. package/dist/npm.d.ts +0 -27
  164. package/dist/npm.js +0 -20
  165. package/dist/npm.js.map +0 -1
  166. package/dist/path.d.ts +0 -25
  167. package/dist/path.js.map +0 -1
  168. package/dist/private/node/ui/components/Table.js.map +0 -1
  169. package/dist/typing/deep-required.js.map +0 -1
  170. package/dist/typing/overloaded-parameters.js.map +0 -1
  171. package/dist/typing/pick-by-prefix.js.map +0 -1
  172. package/dist/typing/simple-definitions.js.map +0 -1
  173. package/dist/ui/inquirer/autocomplete.d.ts +0 -11
  174. package/dist/ui/inquirer/autocomplete.js +0 -110
  175. package/dist/ui/inquirer/autocomplete.js.map +0 -1
  176. package/dist/ui/inquirer/input.d.ts +0 -16
  177. package/dist/ui/inquirer/input.js +0 -45
  178. package/dist/ui/inquirer/input.js.map +0 -1
  179. package/dist/ui/inquirer/password.d.ts +0 -7
  180. package/dist/ui/inquirer/password.js +0 -8
  181. package/dist/ui/inquirer/password.js.map +0 -1
  182. package/dist/ui/inquirer/select.d.ts +0 -14
  183. package/dist/ui/inquirer/select.js +0 -26
  184. package/dist/ui/inquirer/select.js.map +0 -1
@@ -14,8 +14,31 @@ export function waitForChange(func, getChangingValue) {
14
14
  }, 10);
15
15
  });
16
16
  }
17
- export async function sendInput(renderInstance, ...inputs) {
17
+ function waitFor(func, condition) {
18
+ return new Promise((resolve) => {
19
+ func();
20
+ const interval = setInterval(() => {
21
+ if (condition()) {
22
+ clearInterval(interval);
23
+ resolve();
24
+ }
25
+ }, 10);
26
+ });
27
+ }
28
+ export function waitForContent(renderInstance, content, func = () => { }) {
29
+ return waitFor(() => func(), () => renderInstance.lastFrame().includes(content));
30
+ }
31
+ export async function sendInputAndWaitForChange(renderInstance, ...inputs) {
18
32
  await waitForChange(() => inputs.forEach((input) => renderInstance.stdin.write(input)), renderInstance.lastFrame);
33
+ // wait for another tick so we give time to react to update caches
34
+ await new Promise((resolve) => setTimeout(resolve, 0));
35
+ }
36
+ export async function sendInputAndWait(renderInstance, waitTime, ...inputs) {
37
+ inputs.forEach((input) => renderInstance.stdin.write(input));
38
+ await new Promise((resolve) => setTimeout(resolve, waitTime));
39
+ }
40
+ export async function sendInputAndWaitForContent(renderInstance, content, ...inputs) {
41
+ await waitForContent(renderInstance, content, () => inputs.forEach((input) => renderInstance.stdin.write(input)));
19
42
  }
20
43
  export function getLastFrameAfterUnmount(renderInstance) {
21
44
  return isTruthy(process.env.CI) ? renderInstance.frames[renderInstance.frames.length - 2] : renderInstance.lastFrame();
@@ -1 +1 @@
1
- {"version":3,"file":"ui.js","sourceRoot":"","sources":["../../src/testing/ui.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,QAAQ,EAAC,MAAM,0CAA0C,CAAA;AAGjE,MAAM,UAAU,sBAAsB;IACpC,OAAO,IAAI,OAAO,CAAC,CAAC,OAAO,EAAE,EAAE,CAAC,UAAU,CAAC,OAAO,EAAE,GAAG,CAAC,CAAC,CAAA;AAC3D,CAAC;AAED,MAAM,UAAU,aAAa,CAAC,IAAgB,EAAE,gBAAmD;IACjG,OAAO,IAAI,OAAO,CAAO,CAAC,OAAO,EAAE,EAAE;QACnC,MAAM,YAAY,GAAG,gBAAgB,EAAE,CAAA;QAEvC,IAAI,EAAE,CAAA;QAEN,MAAM,QAAQ,GAAG,WAAW,CAAC,GAAG,EAAE;YAChC,IAAI,gBAAgB,EAAE,KAAK,YAAY,EAAE;gBACvC,aAAa,CAAC,QAAQ,CAAC,CAAA;gBACvB,OAAO,EAAE,CAAA;aACV;QACH,CAAC,EAAE,EAAE,CAAC,CAAA;IACR,CAAC,CAAC,CAAA;AACJ,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,SAAS,CAAC,cAAyC,EAAE,GAAG,MAAgB;IAC5F,MAAM,aAAa,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,cAAc,CAAC,KAAK,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,EAAE,cAAc,CAAC,SAAS,CAAC,CAAA;AACnH,CAAC;AAED,MAAM,UAAU,wBAAwB,CAAC,cAAyC;IAChF,OAAO,QAAQ,CAAC,OAAO,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,cAAc,CAAC,MAAM,CAAC,cAAc,CAAC,MAAM,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,cAAc,CAAC,SAAS,EAAE,CAAA;AACxH,CAAC","sourcesContent":["import {isTruthy} from '../private/node/environment/utilities.js'\nimport {render} from 'ink-testing-library'\n\nexport function waitForInputsToBeReady() {\n return new Promise((resolve) => setTimeout(resolve, 100))\n}\n\nexport function waitForChange(func: () => void, getChangingValue: () => string | number | undefined) {\n return new Promise<void>((resolve) => {\n const initialValue = getChangingValue()\n\n func()\n\n const interval = setInterval(() => {\n if (getChangingValue() !== initialValue) {\n clearInterval(interval)\n resolve()\n }\n }, 10)\n })\n}\n\nexport async function sendInput(renderInstance: ReturnType<typeof render>, ...inputs: string[]) {\n await waitForChange(() => inputs.forEach((input) => renderInstance.stdin.write(input)), renderInstance.lastFrame)\n}\n\nexport function getLastFrameAfterUnmount(renderInstance: ReturnType<typeof render>) {\n return isTruthy(process.env.CI) ? renderInstance.frames[renderInstance.frames.length - 2] : renderInstance.lastFrame()\n}\n"]}
1
+ {"version":3,"file":"ui.js","sourceRoot":"","sources":["../../src/testing/ui.ts"],"names":[],"mappings":"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","sourcesContent":["import {isTruthy} from '../private/node/environment/utilities.js'\nimport {render} from 'ink-testing-library'\n\nexport function waitForInputsToBeReady() {\n return new Promise((resolve) => setTimeout(resolve, 100))\n}\n\nexport function waitForChange(func: () => void, getChangingValue: () => string | number | undefined) {\n return new Promise<void>((resolve) => {\n const initialValue = getChangingValue()\n\n func()\n\n const interval = setInterval(() => {\n if (getChangingValue() !== initialValue) {\n clearInterval(interval)\n resolve()\n }\n }, 10)\n })\n}\n\nfunction waitFor(func: () => void, condition: () => boolean) {\n return new Promise<void>((resolve) => {\n func()\n\n const interval = setInterval(() => {\n if (condition()) {\n clearInterval(interval)\n resolve()\n }\n }, 10)\n })\n}\n\nexport function waitForContent(\n renderInstance: ReturnType<typeof render>,\n content: string,\n func: () => void = () => {},\n) {\n return waitFor(\n () => func(),\n () => renderInstance.lastFrame()!.includes(content),\n )\n}\n\nexport async function sendInputAndWaitForChange(renderInstance: ReturnType<typeof render>, ...inputs: string[]) {\n await waitForChange(() => inputs.forEach((input) => renderInstance.stdin.write(input)), renderInstance.lastFrame)\n // wait for another tick so we give time to react to update caches\n await new Promise((resolve) => setTimeout(resolve, 0))\n}\n\nexport async function sendInputAndWait(\n renderInstance: ReturnType<typeof render>,\n waitTime: number,\n ...inputs: string[]\n) {\n inputs.forEach((input) => renderInstance.stdin.write(input))\n await new Promise((resolve) => setTimeout(resolve, waitTime))\n}\n\nexport async function sendInputAndWaitForContent(\n renderInstance: ReturnType<typeof render>,\n content: string,\n ...inputs: string[]\n) {\n await waitForContent(renderInstance, content, () => inputs.forEach((input) => renderInstance.stdin.write(input)))\n}\n\nexport function getLastFrameAfterUnmount(renderInstance: ReturnType<typeof render>) {\n return isTruthy(process.env.CI) ? renderInstance.frames[renderInstance.frames.length - 2] : renderInstance.lastFrame()\n}\n"]}