@automattic/onboarding 1.0.0

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 (383) hide show
  1. package/README.md +20 -0
  2. package/dist/cjs/action-buttons/index.js +50 -0
  3. package/dist/cjs/action-buttons/index.js.map +1 -0
  4. package/dist/cjs/action-buttons/style.scss +108 -0
  5. package/dist/cjs/cart/create-cart-manager-client.js +30 -0
  6. package/dist/cjs/cart/create-cart-manager-client.js.map +1 -0
  7. package/dist/cjs/cart/index.js +239 -0
  8. package/dist/cjs/cart/index.js.map +1 -0
  9. package/dist/cjs/confetti/index.js +8 -0
  10. package/dist/cjs/confetti/index.js.map +1 -0
  11. package/dist/cjs/feature-icon/index.js +19 -0
  12. package/dist/cjs/feature-icon/index.js.map +1 -0
  13. package/dist/cjs/flow-progress/index.js +14 -0
  14. package/dist/cjs/flow-progress/index.js.map +1 -0
  15. package/dist/cjs/flow-progress/style.scss +5 -0
  16. package/dist/cjs/flow-progress/use-flow-progress.js +92 -0
  17. package/dist/cjs/flow-progress/use-flow-progress.js.map +1 -0
  18. package/dist/cjs/hooray/index.js +12 -0
  19. package/dist/cjs/hooray/index.js.map +1 -0
  20. package/dist/cjs/hooray/style.scss +66 -0
  21. package/dist/cjs/index.js +54 -0
  22. package/dist/cjs/index.js.map +1 -0
  23. package/dist/cjs/intent-screen/index.js +11 -0
  24. package/dist/cjs/intent-screen/index.js.map +1 -0
  25. package/dist/cjs/mshots-image/index.js +234 -0
  26. package/dist/cjs/mshots-image/index.js.map +1 -0
  27. package/dist/cjs/mshots-image/style.scss +43 -0
  28. package/dist/cjs/navigator/hooks/index.js +6 -0
  29. package/dist/cjs/navigator/hooks/index.js.map +1 -0
  30. package/dist/cjs/navigator/hooks/use-navigator-listener.js +16 -0
  31. package/dist/cjs/navigator/hooks/use-navigator-listener.js.map +1 -0
  32. package/dist/cjs/navigator/index.js +18 -0
  33. package/dist/cjs/navigator/index.js.map +1 -0
  34. package/dist/cjs/navigator/navigator-buttons/index.js +23 -0
  35. package/dist/cjs/navigator/navigator-buttons/index.js.map +1 -0
  36. package/dist/cjs/navigator/navigator-buttons/style.scss +47 -0
  37. package/dist/cjs/navigator/navigator-header/index.js +13 -0
  38. package/dist/cjs/navigator/navigator-header/index.js.map +1 -0
  39. package/dist/cjs/navigator/navigator-header/style.scss +45 -0
  40. package/dist/cjs/navigator/navigator-item-group/index.js +10 -0
  41. package/dist/cjs/navigator/navigator-item-group/index.js.map +1 -0
  42. package/dist/cjs/navigator/navigator-item-group/style.scss +28 -0
  43. package/dist/cjs/navigator/navigator-listener/index.js +9 -0
  44. package/dist/cjs/navigator/navigator-listener/index.js.map +1 -0
  45. package/dist/cjs/navigator/navigator-screen/index.js +16 -0
  46. package/dist/cjs/navigator/navigator-screen/index.js.map +1 -0
  47. package/dist/cjs/navigator/navigator-screens/hooks/index.js +8 -0
  48. package/dist/cjs/navigator/navigator-screens/hooks/index.js.map +1 -0
  49. package/dist/cjs/navigator/navigator-screens/hooks/use-navigator-buttons.js +17 -0
  50. package/dist/cjs/navigator/navigator-screens/hooks/use-navigator-buttons.js.map +1 -0
  51. package/dist/cjs/navigator/navigator-screens/hooks/use-navigator-screens.js +14 -0
  52. package/dist/cjs/navigator/navigator-screens/hooks/use-navigator-screens.js.map +1 -0
  53. package/dist/cjs/navigator/navigator-screens/index.js +9 -0
  54. package/dist/cjs/navigator/navigator-screens/index.js.map +1 -0
  55. package/dist/cjs/navigator/navigator-screens/navigator-screens.js +18 -0
  56. package/dist/cjs/navigator/navigator-screens/navigator-screens.js.map +1 -0
  57. package/dist/cjs/navigator/navigator-screens/navigator-screens.scss +60 -0
  58. package/dist/cjs/navigator/navigator-screens/types.js +3 -0
  59. package/dist/cjs/navigator/navigator-screens/types.js.map +1 -0
  60. package/dist/cjs/notice/index.js +12 -0
  61. package/dist/cjs/notice/index.js.map +1 -0
  62. package/dist/cjs/notice/style.scss +19 -0
  63. package/dist/cjs/progress/index.js +11 -0
  64. package/dist/cjs/progress/index.js.map +1 -0
  65. package/dist/cjs/progress/style.scss +34 -0
  66. package/dist/cjs/select-card-checkbox/index.js +17 -0
  67. package/dist/cjs/select-card-checkbox/index.js.map +1 -0
  68. package/dist/cjs/select-card-checkbox/style.scss +30 -0
  69. package/dist/cjs/select-card-radio/index.js +21 -0
  70. package/dist/cjs/select-card-radio/index.js.map +1 -0
  71. package/dist/cjs/select-card-radio/style.scss +44 -0
  72. package/dist/cjs/select-items/index.js +13 -0
  73. package/dist/cjs/select-items/index.js.map +1 -0
  74. package/dist/cjs/select-items/style.scss +96 -0
  75. package/dist/cjs/select-items-alt/index.js +14 -0
  76. package/dist/cjs/select-items-alt/index.js.map +1 -0
  77. package/dist/cjs/select-items-alt/style.scss +72 -0
  78. package/dist/cjs/sensei-logo/index.js +8 -0
  79. package/dist/cjs/sensei-logo/index.js.map +1 -0
  80. package/dist/cjs/setup-tailored-site-after-creation.js +109 -0
  81. package/dist/cjs/setup-tailored-site-after-creation.js.map +1 -0
  82. package/dist/cjs/step-container/index.js +65 -0
  83. package/dist/cjs/step-container/index.js.map +1 -0
  84. package/dist/cjs/step-container/style.scss +304 -0
  85. package/dist/cjs/step-navigation-link/index.js +35 -0
  86. package/dist/cjs/step-navigation-link/index.js.map +1 -0
  87. package/dist/cjs/step-navigation-link/style.scss +42 -0
  88. package/dist/cjs/titles/index.js +13 -0
  89. package/dist/cjs/titles/index.js.map +1 -0
  90. package/dist/cjs/titles/styles.scss +29 -0
  91. package/dist/cjs/upload-and-set-site-logo.js +32 -0
  92. package/dist/cjs/upload-and-set-site-logo.js.map +1 -0
  93. package/dist/cjs/utils/contrastChecker.js +38 -0
  94. package/dist/cjs/utils/contrastChecker.js.map +1 -0
  95. package/dist/cjs/utils/domain-suggester.js +113 -0
  96. package/dist/cjs/utils/domain-suggester.js.map +1 -0
  97. package/dist/cjs/utils/flows.js +218 -0
  98. package/dist/cjs/utils/flows.js.map +1 -0
  99. package/dist/cjs/utils/index.js +13 -0
  100. package/dist/cjs/utils/index.js.map +1 -0
  101. package/dist/cjs/utils/is-domain.js +22 -0
  102. package/dist/cjs/utils/is-domain.js.map +1 -0
  103. package/dist/cjs/utils/use-data-loss-warning.js +20 -0
  104. package/dist/cjs/utils/use-data-loss-warning.js.map +1 -0
  105. package/dist/cjs/videopress-logo/index.js +8 -0
  106. package/dist/cjs/videopress-logo/index.js.map +1 -0
  107. package/dist/esm/action-buttons/index.js +42 -0
  108. package/dist/esm/action-buttons/index.js.map +1 -0
  109. package/dist/esm/action-buttons/style.scss +108 -0
  110. package/dist/esm/cart/create-cart-manager-client.js +27 -0
  111. package/dist/esm/cart/create-cart-manager-client.js.map +1 -0
  112. package/dist/esm/cart/index.js +229 -0
  113. package/dist/esm/cart/index.js.map +1 -0
  114. package/dist/esm/confetti/index.js +6 -0
  115. package/dist/esm/confetti/index.js.map +1 -0
  116. package/dist/esm/feature-icon/index.js +16 -0
  117. package/dist/esm/feature-icon/index.js.map +1 -0
  118. package/dist/esm/flow-progress/index.js +12 -0
  119. package/dist/esm/flow-progress/index.js.map +1 -0
  120. package/dist/esm/flow-progress/style.scss +5 -0
  121. package/dist/esm/flow-progress/use-flow-progress.js +88 -0
  122. package/dist/esm/flow-progress/use-flow-progress.js.map +1 -0
  123. package/dist/esm/hooray/index.js +9 -0
  124. package/dist/esm/hooray/index.js.map +1 -0
  125. package/dist/esm/hooray/style.scss +66 -0
  126. package/dist/esm/index.js +22 -0
  127. package/dist/esm/index.js.map +1 -0
  128. package/dist/esm/intent-screen/index.js +8 -0
  129. package/dist/esm/intent-screen/index.js.map +1 -0
  130. package/dist/esm/mshots-image/index.js +229 -0
  131. package/dist/esm/mshots-image/index.js.map +1 -0
  132. package/dist/esm/mshots-image/style.scss +43 -0
  133. package/dist/esm/navigator/hooks/index.js +2 -0
  134. package/dist/esm/navigator/hooks/index.js.map +1 -0
  135. package/dist/esm/navigator/hooks/use-navigator-listener.js +14 -0
  136. package/dist/esm/navigator/hooks/use-navigator-listener.js.map +1 -0
  137. package/dist/esm/navigator/index.js +8 -0
  138. package/dist/esm/navigator/index.js.map +1 -0
  139. package/dist/esm/navigator/navigator-buttons/index.js +17 -0
  140. package/dist/esm/navigator/navigator-buttons/index.js.map +1 -0
  141. package/dist/esm/navigator/navigator-buttons/style.scss +47 -0
  142. package/dist/esm/navigator/navigator-header/index.js +11 -0
  143. package/dist/esm/navigator/navigator-header/index.js.map +1 -0
  144. package/dist/esm/navigator/navigator-header/style.scss +45 -0
  145. package/dist/esm/navigator/navigator-item-group/index.js +8 -0
  146. package/dist/esm/navigator/navigator-item-group/index.js.map +1 -0
  147. package/dist/esm/navigator/navigator-item-group/style.scss +28 -0
  148. package/dist/esm/navigator/navigator-listener/index.js +7 -0
  149. package/dist/esm/navigator/navigator-listener/index.js.map +1 -0
  150. package/dist/esm/navigator/navigator-screen/index.js +14 -0
  151. package/dist/esm/navigator/navigator-screen/index.js.map +1 -0
  152. package/dist/esm/navigator/navigator-screens/hooks/index.js +3 -0
  153. package/dist/esm/navigator/navigator-screens/hooks/index.js.map +1 -0
  154. package/dist/esm/navigator/navigator-screens/hooks/use-navigator-buttons.js +14 -0
  155. package/dist/esm/navigator/navigator-screens/hooks/use-navigator-buttons.js.map +1 -0
  156. package/dist/esm/navigator/navigator-screens/hooks/use-navigator-screens.js +11 -0
  157. package/dist/esm/navigator/navigator-screens/hooks/use-navigator-screens.js.map +1 -0
  158. package/dist/esm/navigator/navigator-screens/index.js +4 -0
  159. package/dist/esm/navigator/navigator-screens/index.js.map +1 -0
  160. package/dist/esm/navigator/navigator-screens/navigator-screens.js +15 -0
  161. package/dist/esm/navigator/navigator-screens/navigator-screens.js.map +1 -0
  162. package/dist/esm/navigator/navigator-screens/navigator-screens.scss +60 -0
  163. package/dist/esm/navigator/navigator-screens/types.js +2 -0
  164. package/dist/esm/navigator/navigator-screens/types.js.map +1 -0
  165. package/dist/esm/notice/index.js +9 -0
  166. package/dist/esm/notice/index.js.map +1 -0
  167. package/dist/esm/notice/style.scss +19 -0
  168. package/dist/esm/progress/index.js +8 -0
  169. package/dist/esm/progress/index.js.map +1 -0
  170. package/dist/esm/progress/style.scss +34 -0
  171. package/dist/esm/select-card-checkbox/index.js +14 -0
  172. package/dist/esm/select-card-checkbox/index.js.map +1 -0
  173. package/dist/esm/select-card-checkbox/style.scss +30 -0
  174. package/dist/esm/select-card-radio/index.js +15 -0
  175. package/dist/esm/select-card-radio/index.js.map +1 -0
  176. package/dist/esm/select-card-radio/style.scss +44 -0
  177. package/dist/esm/select-items/index.js +10 -0
  178. package/dist/esm/select-items/index.js.map +1 -0
  179. package/dist/esm/select-items/style.scss +96 -0
  180. package/dist/esm/select-items-alt/index.js +11 -0
  181. package/dist/esm/select-items-alt/index.js.map +1 -0
  182. package/dist/esm/select-items-alt/style.scss +72 -0
  183. package/dist/esm/sensei-logo/index.js +6 -0
  184. package/dist/esm/sensei-logo/index.js.map +1 -0
  185. package/dist/esm/setup-tailored-site-after-creation.js +103 -0
  186. package/dist/esm/setup-tailored-site-after-creation.js.map +1 -0
  187. package/dist/esm/step-container/index.js +62 -0
  188. package/dist/esm/step-container/index.js.map +1 -0
  189. package/dist/esm/step-container/style.scss +304 -0
  190. package/dist/esm/step-navigation-link/index.js +32 -0
  191. package/dist/esm/step-navigation-link/index.js.map +1 -0
  192. package/dist/esm/step-navigation-link/style.scss +42 -0
  193. package/dist/esm/titles/index.js +7 -0
  194. package/dist/esm/titles/index.js.map +1 -0
  195. package/dist/esm/titles/styles.scss +29 -0
  196. package/dist/esm/upload-and-set-site-logo.js +27 -0
  197. package/dist/esm/upload-and-set-site-logo.js.map +1 -0
  198. package/dist/esm/utils/contrastChecker.js +33 -0
  199. package/dist/esm/utils/contrastChecker.js.map +1 -0
  200. package/dist/esm/utils/domain-suggester.js +108 -0
  201. package/dist/esm/utils/domain-suggester.js.map +1 -0
  202. package/dist/esm/utils/flows.js +179 -0
  203. package/dist/esm/utils/flows.js.map +1 -0
  204. package/dist/esm/utils/index.js +6 -0
  205. package/dist/esm/utils/index.js.map +1 -0
  206. package/dist/esm/utils/is-domain.js +18 -0
  207. package/dist/esm/utils/is-domain.js.map +1 -0
  208. package/dist/esm/utils/use-data-loss-warning.js +16 -0
  209. package/dist/esm/utils/use-data-loss-warning.js.map +1 -0
  210. package/dist/esm/videopress-logo/index.js +6 -0
  211. package/dist/esm/videopress-logo/index.js.map +1 -0
  212. package/dist/styles/base-styles.scss +7 -0
  213. package/dist/styles/mixins.scss +262 -0
  214. package/dist/styles/variables.scss +26 -0
  215. package/dist/styles/z-index.scss +41 -0
  216. package/dist/tsconfig-cjs.tsbuildinfo +1 -0
  217. package/dist/tsconfig.tsbuildinfo +1 -0
  218. package/dist/types/action-buttons/index.d.ts +17 -0
  219. package/dist/types/action-buttons/index.d.ts.map +1 -0
  220. package/dist/types/cart/create-cart-manager-client.d.ts +3 -0
  221. package/dist/types/cart/create-cart-manager-client.d.ts.map +1 -0
  222. package/dist/types/cart/index.d.ts +47 -0
  223. package/dist/types/cart/index.d.ts.map +1 -0
  224. package/dist/types/confetti/index.d.ts +6 -0
  225. package/dist/types/confetti/index.d.ts.map +1 -0
  226. package/dist/types/feature-icon/index.d.ts +9 -0
  227. package/dist/types/feature-icon/index.d.ts.map +1 -0
  228. package/dist/types/flow-progress/index.d.ts +9 -0
  229. package/dist/types/flow-progress/index.d.ts.map +1 -0
  230. package/dist/types/flow-progress/use-flow-progress.d.ts +11 -0
  231. package/dist/types/flow-progress/use-flow-progress.d.ts.map +1 -0
  232. package/dist/types/hooray/index.d.ts +10 -0
  233. package/dist/types/hooray/index.d.ts.map +1 -0
  234. package/dist/types/index.d.ts +25 -0
  235. package/dist/types/index.d.ts.map +1 -0
  236. package/dist/types/intent-screen/index.d.ts +12 -0
  237. package/dist/types/intent-screen/index.d.ts.map +1 -0
  238. package/dist/types/mshots-image/index.d.ts +21 -0
  239. package/dist/types/mshots-image/index.d.ts.map +1 -0
  240. package/dist/types/navigator/hooks/index.d.ts +3 -0
  241. package/dist/types/navigator/hooks/index.d.ts.map +1 -0
  242. package/dist/types/navigator/hooks/use-navigator-listener.d.ts +4 -0
  243. package/dist/types/navigator/hooks/use-navigator-listener.d.ts.map +1 -0
  244. package/dist/types/navigator/index.d.ts +8 -0
  245. package/dist/types/navigator/index.d.ts.map +1 -0
  246. package/dist/types/navigator/navigator-buttons/index.d.ts +17 -0
  247. package/dist/types/navigator/navigator-buttons/index.d.ts.map +1 -0
  248. package/dist/types/navigator/navigator-header/index.d.ts +12 -0
  249. package/dist/types/navigator/navigator-header/index.d.ts.map +1 -0
  250. package/dist/types/navigator/navigator-item-group/index.d.ts +9 -0
  251. package/dist/types/navigator/navigator-item-group/index.d.ts.map +1 -0
  252. package/dist/types/navigator/navigator-listener/index.d.ts +7 -0
  253. package/dist/types/navigator/navigator-listener/index.d.ts.map +1 -0
  254. package/dist/types/navigator/navigator-screen/index.d.ts +11 -0
  255. package/dist/types/navigator/navigator-screen/index.d.ts.map +1 -0
  256. package/dist/types/navigator/navigator-screens/hooks/index.d.ts +3 -0
  257. package/dist/types/navigator/navigator-screens/hooks/index.d.ts.map +1 -0
  258. package/dist/types/navigator/navigator-screens/hooks/use-navigator-buttons.d.ts +4 -0
  259. package/dist/types/navigator/navigator-screens/hooks/use-navigator-buttons.d.ts.map +1 -0
  260. package/dist/types/navigator/navigator-screens/hooks/use-navigator-screens.d.ts +4 -0
  261. package/dist/types/navigator/navigator-screens/hooks/use-navigator-screens.d.ts.map +1 -0
  262. package/dist/types/navigator/navigator-screens/index.d.ts +4 -0
  263. package/dist/types/navigator/navigator-screens/index.d.ts.map +1 -0
  264. package/dist/types/navigator/navigator-screens/navigator-screens.d.ts +12 -0
  265. package/dist/types/navigator/navigator-screens/navigator-screens.d.ts.map +1 -0
  266. package/dist/types/navigator/navigator-screens/types.d.ts +17 -0
  267. package/dist/types/navigator/navigator-screens/types.d.ts.map +1 -0
  268. package/dist/types/notice/index.d.ts +7 -0
  269. package/dist/types/notice/index.d.ts.map +1 -0
  270. package/dist/types/progress/index.d.ts +10 -0
  271. package/dist/types/progress/index.d.ts.map +1 -0
  272. package/dist/types/select-card-checkbox/index.d.ts +11 -0
  273. package/dist/types/select-card-checkbox/index.d.ts.map +1 -0
  274. package/dist/types/select-card-radio/index.d.ts +22 -0
  275. package/dist/types/select-card-radio/index.d.ts.map +1 -0
  276. package/dist/types/select-items/index.d.ts +25 -0
  277. package/dist/types/select-items/index.d.ts.map +1 -0
  278. package/dist/types/select-items-alt/index.d.ts +19 -0
  279. package/dist/types/select-items-alt/index.d.ts.map +1 -0
  280. package/dist/types/sensei-logo/index.d.ts +8 -0
  281. package/dist/types/sensei-logo/index.d.ts.map +1 -0
  282. package/dist/types/setup-tailored-site-after-creation.d.ts +8 -0
  283. package/dist/types/setup-tailored-site-after-creation.d.ts.map +1 -0
  284. package/dist/types/step-container/index.d.ts +45 -0
  285. package/dist/types/step-container/index.d.ts.map +1 -0
  286. package/dist/types/step-navigation-link/index.d.ts +18 -0
  287. package/dist/types/step-navigation-link/index.d.ts.map +1 -0
  288. package/dist/types/titles/index.d.ts +12 -0
  289. package/dist/types/titles/index.d.ts.map +1 -0
  290. package/dist/types/upload-and-set-site-logo.d.ts +13 -0
  291. package/dist/types/upload-and-set-site-logo.d.ts.map +1 -0
  292. package/dist/types/utils/contrastChecker.d.ts +17 -0
  293. package/dist/types/utils/contrastChecker.d.ts.map +1 -0
  294. package/dist/types/utils/domain-suggester.d.ts +15 -0
  295. package/dist/types/utils/domain-suggester.d.ts.map +1 -0
  296. package/dist/types/utils/flows.d.ts +89 -0
  297. package/dist/types/utils/flows.d.ts.map +1 -0
  298. package/dist/types/utils/index.d.ts +6 -0
  299. package/dist/types/utils/index.d.ts.map +1 -0
  300. package/dist/types/utils/is-domain.d.ts +2 -0
  301. package/dist/types/utils/is-domain.d.ts.map +1 -0
  302. package/dist/types/utils/use-data-loss-warning.d.ts +2 -0
  303. package/dist/types/utils/use-data-loss-warning.d.ts.map +1 -0
  304. package/dist/types/videopress-logo/index.d.ts +8 -0
  305. package/dist/types/videopress-logo/index.d.ts.map +1 -0
  306. package/jest.config.js +5 -0
  307. package/package.json +63 -0
  308. package/src/action-buttons/index.tsx +113 -0
  309. package/src/action-buttons/style.scss +108 -0
  310. package/src/cart/create-cart-manager-client.ts +34 -0
  311. package/src/cart/index.tsx +375 -0
  312. package/src/cart/test/index.ts +172 -0
  313. package/src/confetti/index.tsx +95 -0
  314. package/src/feature-icon/index.tsx +102 -0
  315. package/src/flow-progress/index.tsx +22 -0
  316. package/src/flow-progress/style.scss +5 -0
  317. package/src/flow-progress/use-flow-progress.ts +108 -0
  318. package/src/hooray/index.tsx +34 -0
  319. package/src/hooray/style.scss +66 -0
  320. package/src/index.ts +36 -0
  321. package/src/intent-screen/README.md +12 -0
  322. package/src/intent-screen/index.tsx +26 -0
  323. package/src/intent-screen/test/index.tsx +197 -0
  324. package/src/mshots-image/index.tsx +368 -0
  325. package/src/mshots-image/style.scss +43 -0
  326. package/src/mshots-image/test/mshots-image.tsx +5 -0
  327. package/src/navigator/hooks/index.tsx +2 -0
  328. package/src/navigator/hooks/use-navigator-listener.tsx +18 -0
  329. package/src/navigator/index.ts +7 -0
  330. package/src/navigator/navigator-buttons/index.tsx +58 -0
  331. package/src/navigator/navigator-buttons/style.scss +47 -0
  332. package/src/navigator/navigator-header/index.tsx +40 -0
  333. package/src/navigator/navigator-header/style.scss +45 -0
  334. package/src/navigator/navigator-item-group/index.tsx +23 -0
  335. package/src/navigator/navigator-item-group/style.scss +28 -0
  336. package/src/navigator/navigator-listener/index.tsx +12 -0
  337. package/src/navigator/navigator-screen/index.tsx +24 -0
  338. package/src/navigator/navigator-screens/hooks/index.tsx +2 -0
  339. package/src/navigator/navigator-screens/hooks/use-navigator-buttons.tsx +32 -0
  340. package/src/navigator/navigator-screens/hooks/use-navigator-screens.tsx +57 -0
  341. package/src/navigator/navigator-screens/index.ts +3 -0
  342. package/src/navigator/navigator-screens/navigator-screens.scss +60 -0
  343. package/src/navigator/navigator-screens/navigator-screens.tsx +41 -0
  344. package/src/navigator/navigator-screens/types.ts +15 -0
  345. package/src/notice/index.tsx +16 -0
  346. package/src/notice/style.scss +19 -0
  347. package/src/progress/index.tsx +23 -0
  348. package/src/progress/style.scss +34 -0
  349. package/src/select-card-checkbox/index.tsx +38 -0
  350. package/src/select-card-checkbox/style.scss +30 -0
  351. package/src/select-card-radio/index.tsx +64 -0
  352. package/src/select-card-radio/style.scss +44 -0
  353. package/src/select-card-radio/test/index.tsx +50 -0
  354. package/src/select-items/README.md +13 -0
  355. package/src/select-items/index.tsx +90 -0
  356. package/src/select-items/style.scss +96 -0
  357. package/src/select-items-alt/README.md +13 -0
  358. package/src/select-items-alt/index.tsx +61 -0
  359. package/src/select-items-alt/style.scss +72 -0
  360. package/src/sensei-logo/index.tsx +30 -0
  361. package/src/setup-tailored-site-after-creation.ts +149 -0
  362. package/src/step-container/index.tsx +251 -0
  363. package/src/step-container/style.scss +304 -0
  364. package/src/step-navigation-link/index.tsx +71 -0
  365. package/src/step-navigation-link/style.scss +42 -0
  366. package/src/titles/index.tsx +36 -0
  367. package/src/titles/styles.scss +29 -0
  368. package/src/types.d.ts +1 -0
  369. package/src/upload-and-set-site-logo.ts +38 -0
  370. package/src/utils/contrastChecker.ts +52 -0
  371. package/src/utils/domain-suggester.ts +126 -0
  372. package/src/utils/flows.ts +232 -0
  373. package/src/utils/index.ts +5 -0
  374. package/src/utils/is-domain.ts +18 -0
  375. package/src/utils/test/domain-suggester.ts +87 -0
  376. package/src/utils/use-data-loss-warning.ts +17 -0
  377. package/src/videopress-logo/index.tsx +36 -0
  378. package/styles/base-styles.scss +7 -0
  379. package/styles/mixins.scss +262 -0
  380. package/styles/variables.scss +26 -0
  381. package/styles/z-index.scss +41 -0
  382. package/tsconfig-cjs.json +7 -0
  383. package/tsconfig.json +15 -0
@@ -0,0 +1,12 @@
1
+ import { useNavigatorListener, OnNavigatorPathChange } from '../hooks';
2
+
3
+ interface Props {
4
+ onNavigatorPathChange?: OnNavigatorPathChange;
5
+ }
6
+
7
+ const NavigatorListener = ( { onNavigatorPathChange }: Props ) => {
8
+ useNavigatorListener( onNavigatorPathChange );
9
+ return null;
10
+ };
11
+
12
+ export default NavigatorListener;
@@ -0,0 +1,24 @@
1
+ import {
2
+ __experimentalNavigatorScreen as BaseNavigatorScreen,
3
+ __experimentalUseNavigator as useNavigator,
4
+ } from '@wordpress/components';
5
+ import type { ComponentProps } from 'react';
6
+
7
+ type Props = ComponentProps< typeof BaseNavigatorScreen > & {
8
+ partialMatch?: boolean;
9
+ };
10
+
11
+ /**
12
+ * A wrapper of the NavigatorScreen to support matching the path partially.
13
+ */
14
+ const NavigatorScreen = ( { partialMatch, ...props }: Props ) => {
15
+ const { location } = useNavigator();
16
+
17
+ if ( partialMatch && location.path?.startsWith( props.path ) ) {
18
+ return props.children;
19
+ }
20
+
21
+ return <BaseNavigatorScreen { ...props } />;
22
+ };
23
+
24
+ export default NavigatorScreen;
@@ -0,0 +1,2 @@
1
+ export { default as useNavigatorButtons } from './use-navigator-buttons';
2
+ export { default as useNavigatorScreens } from './use-navigator-screens';
@@ -0,0 +1,32 @@
1
+ import { NavigatorButtonAsItem } from '../../navigator-buttons';
2
+ import NavigatorItemGroup from '../../navigator-item-group';
3
+ import type { NavigatorScreenObject } from '../types';
4
+
5
+ const useNavigatorButtons = ( screens: NavigatorScreenObject[] ) => {
6
+ if ( screens.length === 0 ) {
7
+ return null;
8
+ }
9
+
10
+ if ( screens.length === 1 ) {
11
+ return screens[ 0 ].content;
12
+ }
13
+
14
+ return (
15
+ <NavigatorItemGroup>
16
+ { screens.map( ( { slug, checked, icon, label, path, onSelect } ) => (
17
+ <NavigatorButtonAsItem
18
+ key={ path }
19
+ checked={ checked }
20
+ icon={ icon }
21
+ path={ path }
22
+ aria-label={ label }
23
+ onClick={ () => onSelect?.( slug ) }
24
+ >
25
+ { label }
26
+ </NavigatorButtonAsItem>
27
+ ) ) }
28
+ </NavigatorItemGroup>
29
+ );
30
+ };
31
+
32
+ export default useNavigatorButtons;
@@ -0,0 +1,57 @@
1
+ import { Button, Gridicon } from '@automattic/components';
2
+ import {
3
+ __experimentalNavigatorBackButton as NavigatorBackButton,
4
+ __experimentalNavigatorScreen as NavigatorScreen,
5
+ } from '@wordpress/components';
6
+ import { useTranslate } from 'i18n-calypso';
7
+ import NavigatorHeader from '../../navigator-header';
8
+ import type { NavigatorScreenObject } from '../types';
9
+
10
+ const useNavigatorScreens = ( screens: NavigatorScreenObject[] ) => {
11
+ const translate = useTranslate();
12
+
13
+ return screens.map(
14
+ ( {
15
+ slug,
16
+ path,
17
+ label,
18
+ title,
19
+ description,
20
+ hideBack,
21
+ content,
22
+ actionText,
23
+ onSubmit,
24
+ onBack,
25
+ } ) => (
26
+ <NavigatorScreen key={ path } path={ path } style={ { animationDuration: '0s' } }>
27
+ <>
28
+ <NavigatorHeader
29
+ title={ <>{ title ?? label }</> }
30
+ description={ description }
31
+ hideBack={ hideBack }
32
+ onBack={ () => onBack?.( slug ) }
33
+ />
34
+ { content }
35
+ <div className="navigator-screen__footer">
36
+ <NavigatorBackButton
37
+ className="navigator-screen__footer-back-button"
38
+ as={ Button }
39
+ title={ translate( 'Back' ) }
40
+ borderless
41
+ aria-label={ translate( 'Navigate to the previous view' ) }
42
+ onClick={ () => onBack?.( slug ) }
43
+ >
44
+ <Gridicon icon="chevron-left" size={ 18 } />
45
+ { translate( 'Back' ) }
46
+ </NavigatorBackButton>
47
+ <NavigatorBackButton as={ Button } primary onClick={ () => onSubmit?.( slug ) }>
48
+ { actionText }
49
+ </NavigatorBackButton>
50
+ </div>
51
+ </>
52
+ </NavigatorScreen>
53
+ )
54
+ );
55
+ };
56
+
57
+ export default useNavigatorScreens;
@@ -0,0 +1,3 @@
1
+ export * from './hooks';
2
+ export { default as NavigatorScreens } from './navigator-screens';
3
+ export * from './types';
@@ -0,0 +1,60 @@
1
+ @import "@automattic/typography/styles/variables";
2
+ @import "@wordpress/base-styles/breakpoints";
3
+ @import "@wordpress/base-styles/mixins";
4
+
5
+ .navigator-screen__footer {
6
+ display: flex;
7
+ position: fixed;
8
+ align-items: center;
9
+ justify-content: space-between;
10
+ left: 0;
11
+ right: 0;
12
+ bottom: 0;
13
+ width: 100%;
14
+ height: 60px;
15
+ padding: 0 20px;
16
+ box-shadow: inset 0 1px 0 #e2e4e7;
17
+ box-sizing: border-box;
18
+ background-color: var(--studio-white);
19
+
20
+ a,
21
+ button {
22
+ border-radius: 4px;
23
+ box-shadow: 0 1px 2px rgb(0 0 0 / 5%);
24
+ }
25
+
26
+ .navigator-screen__footer-back-button {
27
+ display: block;
28
+ color: #101517;
29
+ font-size: $font-body-small;
30
+ font-weight: 600;
31
+
32
+ svg.gridicon {
33
+ width: 20px;
34
+ height: 20px;
35
+ top: 5px;
36
+ margin-right: 2px;
37
+
38
+ .rtl & {
39
+ transform: scaleX(-1);
40
+ }
41
+ }
42
+ }
43
+
44
+ @include break-large {
45
+ display: flex;
46
+ flex-direction: column;
47
+ align-items: initial;
48
+ position: sticky;
49
+ height: auto;
50
+ gap: 8px;
51
+ padding: 32px 16px;
52
+ margin: 0 -16px;
53
+ box-shadow: none;
54
+ box-sizing: content-box;
55
+
56
+ .navigator-screen__footer-back-button {
57
+ display: none;
58
+ }
59
+ }
60
+ }
@@ -0,0 +1,41 @@
1
+ import {
2
+ __experimentalNavigatorProvider as NavigatorProvider,
3
+ __experimentalNavigatorScreen as NavigatorScreen,
4
+ } from '@wordpress/components';
5
+ import NavigatorListener from '../navigator-listener';
6
+ import { useNavigatorScreens } from './hooks';
7
+ import type { NavigatorScreenObject } from './types';
8
+ import './navigator-screens.scss';
9
+
10
+ interface Props {
11
+ children: JSX.Element;
12
+ screens: NavigatorScreenObject[];
13
+ initialPath?: string;
14
+ onNavigatorPathChange?: ( path?: string ) => void;
15
+ }
16
+
17
+ const NavigatorScreens = ( {
18
+ children,
19
+ screens,
20
+ initialPath = '/',
21
+ onNavigatorPathChange,
22
+ }: Props ) => {
23
+ const navigatorScreens = useNavigatorScreens( screens );
24
+
25
+ // We don't need navigator if there is only one screen
26
+ if ( screens.length === 1 ) {
27
+ return children;
28
+ }
29
+
30
+ return (
31
+ <NavigatorProvider initialPath={ initialPath }>
32
+ <NavigatorScreen path={ initialPath }>{ children }</NavigatorScreen>
33
+ { navigatorScreens }
34
+ { onNavigatorPathChange && (
35
+ <NavigatorListener onNavigatorPathChange={ onNavigatorPathChange } />
36
+ ) }
37
+ </NavigatorProvider>
38
+ );
39
+ };
40
+
41
+ export default NavigatorScreens;
@@ -0,0 +1,15 @@
1
+ export type NavigatorScreenObject = {
2
+ slug: string;
3
+ checked?: boolean;
4
+ icon?: JSX.Element;
5
+ label: string;
6
+ path: string;
7
+ title?: string;
8
+ description?: string;
9
+ hideBack?: boolean;
10
+ content: JSX.Element;
11
+ actionText: string;
12
+ onSelect?: ( slug: string ) => void;
13
+ onSubmit?: ( slug: string ) => void;
14
+ onBack?: ( slug: string ) => void;
15
+ };
@@ -0,0 +1,16 @@
1
+ import { Icon, info } from '@wordpress/icons';
2
+ import clsx from 'clsx';
3
+ import * as React from 'react';
4
+
5
+ import './style.scss';
6
+
7
+ const Notice: React.FunctionComponent< { children: React.ReactNode } > = ( { children } ) => {
8
+ return (
9
+ <div className={ clsx( 'onboarding-notice' ) }>
10
+ <Icon icon={ info } size={ 28 } />
11
+ <p>{ children }</p>
12
+ </div>
13
+ );
14
+ };
15
+
16
+ export default Notice;
@@ -0,0 +1,19 @@
1
+ .onboarding-notice {
2
+ display: flex;
3
+ color: var(--studio-gray-50);
4
+ font-size: 0.875em; /* stylelint-disable-line declaration-property-unit-allowed-list */
5
+ margin-bottom: 1.5em;
6
+
7
+ svg {
8
+ align-self: center;
9
+ fill: var(--color-warning-30);
10
+ flex-shrink: 0;
11
+ margin-inline-end: 1em;
12
+ transform: rotate(180deg);
13
+ }
14
+
15
+ p {
16
+ margin-bottom: 0;
17
+ line-height: 28px;
18
+ }
19
+ }
@@ -0,0 +1,23 @@
1
+ import clsx from 'clsx';
2
+ import * as React from 'react';
3
+
4
+ import './style.scss';
5
+
6
+ interface Props {
7
+ align?: 'center' | 'left' | 'right';
8
+ className?: string;
9
+ children: React.ReactNode;
10
+ }
11
+
12
+ const Progress = ( { className, align = 'center', children, ...additionalProps }: Props ) => {
13
+ return (
14
+ <div
15
+ className={ clsx( `onboarding-progress onboarding-progress__align-${ align }`, className ) }
16
+ { ...additionalProps }
17
+ >
18
+ { children }
19
+ </div>
20
+ );
21
+ };
22
+
23
+ export default Progress;
@@ -0,0 +1,34 @@
1
+ .onboarding-progress {
2
+
3
+ &__align-center {
4
+ text-align: center;
5
+ }
6
+
7
+ &__align-right {
8
+ text-align: right;
9
+ }
10
+
11
+ &__align-left {
12
+ text-align: left;
13
+ }
14
+
15
+ .onboarding-title {
16
+ /* stylelint-disable-next-line scales/font-sizes */
17
+ font-size: 1.625rem; // 26px
18
+ margin-bottom: 2rem;
19
+ }
20
+
21
+ .onboarding-subtitle {
22
+ font-size: 0.875rem;
23
+ line-height: 1.5;
24
+
25
+ span {
26
+ color: var(--studio-gray-100);
27
+ }
28
+ }
29
+
30
+ .progress-bar {
31
+ margin-bottom: 1.5rem;
32
+ background: var(--studio-gray-10);
33
+ }
34
+ }
@@ -0,0 +1,38 @@
1
+ import { CheckboxControl } from '@wordpress/components';
2
+ import { useInstanceId } from '@wordpress/compose';
3
+ import clsx from 'clsx';
4
+ import './style.scss';
5
+
6
+ type SelectCardCheckboxProps = {
7
+ children: React.ReactNode;
8
+ className?: string;
9
+ onChange: ( checked: boolean ) => void;
10
+ checked: boolean;
11
+ };
12
+
13
+ const SelectCardCheckbox = ( {
14
+ children,
15
+ className,
16
+ onChange,
17
+ checked,
18
+ }: SelectCardCheckboxProps ) => {
19
+ const instanceId = useInstanceId( CheckboxControl );
20
+ const id = `select-card-checkbox-${ instanceId }`;
21
+
22
+ return (
23
+ <div
24
+ className={ clsx( 'select-card-checkbox__container', className, {
25
+ 'is-checked': checked,
26
+ } ) }
27
+ onClick={ () => onChange( ! checked ) }
28
+ role="presentation"
29
+ >
30
+ <CheckboxControl checked={ checked } id={ id } onChange={ onChange } />
31
+ <label className="select-card-checkbox__label" htmlFor={ id }>
32
+ { children }
33
+ </label>
34
+ </div>
35
+ );
36
+ };
37
+
38
+ export default SelectCardCheckbox;
@@ -0,0 +1,30 @@
1
+ .select-card-checkbox__container {
2
+ border: 1px solid #dcdcde;
3
+ border-radius: 4px;
4
+ padding: 17px 25px;
5
+ font-size: 0.875rem;
6
+ cursor: pointer;
7
+ display: flex;
8
+ align-items: center;
9
+
10
+ .select-card-checkbox__label {
11
+ pointer-events: none;
12
+ user-select: none;
13
+ display: flex;
14
+ align-items: center;
15
+ }
16
+
17
+ &.is-checked {
18
+ border: 2px solid #0675c4;
19
+ background: #f9fbfd;
20
+ padding: 16px 24px;
21
+ }
22
+
23
+ .components-base-control__field {
24
+ margin-bottom: 0;
25
+ }
26
+
27
+ .components-checkbox-control__input[type="checkbox"] {
28
+ border-color: #a7aaad;
29
+ }
30
+ }
@@ -0,0 +1,64 @@
1
+ import clsx from 'clsx';
2
+ import { useId, type FC, type ReactNode, ReactElement, useCallback } from 'react';
3
+ import './style.scss';
4
+
5
+ interface Option {
6
+ label: ReactNode;
7
+ description?: ReactNode;
8
+ value: string;
9
+ selected?: boolean;
10
+ }
11
+
12
+ interface SelectCardRadioProps {
13
+ option: Option;
14
+ onChange: ( value: Option[ 'value' ] ) => void;
15
+ name: string;
16
+ className?: string;
17
+ }
18
+
19
+ export const SelectCardRadio: FC< SelectCardRadioProps > = ( {
20
+ option,
21
+ onChange,
22
+ name,
23
+ className,
24
+ } ) => {
25
+ const id = useId();
26
+
27
+ const handleChange = useCallback(
28
+ ( event: React.ChangeEvent< HTMLInputElement > ) => {
29
+ onChange?.( event.target.value );
30
+ },
31
+ [ onChange ]
32
+ );
33
+
34
+ return (
35
+ <label
36
+ htmlFor={ `${ id }-radio` }
37
+ aria-labelledby={ `${ id }-info` }
38
+ className={ clsx( 'select-card-radio', className ) }
39
+ >
40
+ <input
41
+ type="radio"
42
+ className="select-card-radio__input"
43
+ id={ `${ id }-radio` }
44
+ value={ option.value }
45
+ defaultChecked={ option.selected }
46
+ onChange={ handleChange }
47
+ name={ name }
48
+ />
49
+ <div className="select-card-radio__info" id={ `${ id }-info` }>
50
+ <span>{ option.label }</span>
51
+ <span className="select-card-radio__description">{ option.description }</span>
52
+ </div>
53
+ </label>
54
+ );
55
+ };
56
+
57
+ interface SelectCardRadioListProps {
58
+ className?: string;
59
+ children: ReactElement< typeof SelectCardRadio > | ReactElement< typeof SelectCardRadio >[];
60
+ }
61
+
62
+ export const SelectCardRadioList: FC< SelectCardRadioListProps > = ( { children, className } ) => {
63
+ return <div className={ clsx( 'select-card-radio__list', className ) }>{ children }</div>;
64
+ };
@@ -0,0 +1,44 @@
1
+
2
+ .select-card-radio {
3
+ border-radius: 4px;
4
+ border: 1px solid #dcdcde;
5
+ display: flex;
6
+ transition: all 0.15s ease-in-out;
7
+ padding: 24px 16px;
8
+ align-items: baseline;
9
+ font-weight: 500;
10
+ cursor: pointer;
11
+
12
+ &:hover {
13
+ border-color: var(--color-primary);
14
+ }
15
+
16
+ &:has(input:checked) {
17
+ border-color: var(--color-primary);
18
+ box-shadow: 0 0 0 2px var(--color-primary-10);
19
+ background-color: #f9fbfd;
20
+ }
21
+
22
+ .select-card-radio__info {
23
+ display: flex;
24
+ gap: 8px;
25
+ flex-direction: column;
26
+ }
27
+
28
+ .select-card-radio__description {
29
+ font-weight: normal;
30
+ text-wrap: pretty;
31
+ }
32
+
33
+ .select-card-radio__input {
34
+ margin-right: 16px;
35
+ appearance: auto;
36
+ }
37
+
38
+ }
39
+
40
+ .select-card-radio__list {
41
+ display: flex;
42
+ flex-direction: column;
43
+ gap: 16px;
44
+ }
@@ -0,0 +1,50 @@
1
+ /**
2
+ * @jest-environment jsdom
3
+ */
4
+ import { render, screen } from '@testing-library/react';
5
+ import userEvent from '@testing-library/user-event';
6
+ import React from 'react';
7
+ import { SelectCardRadio } from '../';
8
+
9
+ describe( 'SelectCardRadio', () => {
10
+ const option = {
11
+ label: 'Some label',
12
+ description: 'Some description',
13
+ value: 'some-value',
14
+ };
15
+
16
+ const defaultProps = {
17
+ option: option,
18
+ onChange: jest.fn(),
19
+ name: 'radio-name',
20
+ };
21
+
22
+ it( 'shows all available options', () => {
23
+ render( <SelectCardRadio { ...defaultProps } /> );
24
+
25
+ expect( screen.getByText( /Some label/ ) ).toBeVisible();
26
+ expect( screen.getByText( /Some description/ ) ).toBeVisible();
27
+ } );
28
+
29
+ it( 'starts with an option selected by default', () => {
30
+ const selectedOption = {
31
+ label: 'Selected',
32
+ description: 'Some description',
33
+ value: 'some-value',
34
+ selected: true,
35
+ };
36
+
37
+ render( <SelectCardRadio { ...defaultProps } option={ selectedOption } /> );
38
+
39
+ expect( screen.getByRole( 'radio', { name: /Selected/ } ) ).toBeChecked();
40
+ } );
41
+
42
+ it( 'trigges the onChange event when an option is selected', async () => {
43
+ const onChange = jest.fn();
44
+ render( <SelectCardRadio { ...defaultProps } onChange={ onChange } /> );
45
+
46
+ await userEvent.click( screen.getByRole( 'radio' ) );
47
+
48
+ expect( onChange ).toHaveBeenCalledWith( option.value );
49
+ } );
50
+ } );
@@ -0,0 +1,13 @@
1
+ # SelectItems
2
+
3
+ Items used in the IntentScreen. They consist of a title, description, and icon.
4
+
5
+ ## Props
6
+
7
+ - **key** _string_ - unique identifier for the item.
8
+ - **title** _string_ - text to use as the header for the item.
9
+ - **description** _string_ - text explaining the item, not translated or wrapped.
10
+ - **icon**: _ReactElement_ - uses WordPress _Icon_ component and sets it to 24px
11
+ - **value**: _string_ - passed to onClick/onSelect handler to identify the item.
12
+ - **actionText**: _sring_ - text for the button.
13
+ - **hidden**: _boolean_ - if true, item is hidden.
@@ -0,0 +1,90 @@
1
+ import { Badge, Button } from '@automattic/components';
2
+ import { Icon } from '@wordpress/icons';
3
+ import clsx from 'clsx';
4
+ import './style.scss';
5
+ import { TranslateResult } from 'i18n-calypso';
6
+
7
+ export interface SelectItem< T > {
8
+ key: string;
9
+ title: TranslateResult;
10
+ badge?: TranslateResult;
11
+ description: TranslateResult;
12
+ icon: React.ReactElement;
13
+ titleIcon?: React.ReactElement; // If titleIcon is set, it will show on the same line of title and, icon will be ignored
14
+ value: T;
15
+ actionText: TranslateResult | null;
16
+ hidden?: boolean;
17
+ isPrimary?: boolean;
18
+ allItemClickable?: boolean;
19
+ }
20
+
21
+ interface Props< T > {
22
+ className?: string;
23
+ items: SelectItem< T >[];
24
+ onSelect: ( value: T ) => void;
25
+ preventWidows: ( text: TranslateResult, wordsToKeep?: number ) => string;
26
+ }
27
+
28
+ function SelectItems< T >( { className, items, onSelect, preventWidows }: Props< T > ) {
29
+ return (
30
+ <div className={ clsx( 'select-items', className ) }>
31
+ { items.map(
32
+ ( {
33
+ key,
34
+ title,
35
+ badge,
36
+ description,
37
+ icon,
38
+ titleIcon,
39
+ actionText,
40
+ value,
41
+ isPrimary,
42
+ allItemClickable,
43
+ } ) => (
44
+ <div key={ key } className="select-items__item">
45
+ { ! titleIcon && (
46
+ <Icon className="select-items__item-icon" icon={ icon } size={ 24 } />
47
+ ) }
48
+ <div className="select-items__item-info-wrapper">
49
+ <div className="select-items__item-info">
50
+ <h2 className="select-items__item-title">
51
+ { titleIcon && (
52
+ <Icon className="select-items__item-icon" icon={ titleIcon } size={ 24 } />
53
+ ) }
54
+ <span className="select-items__item-title-text">{ preventWidows( title ) }</span>
55
+ { badge && (
56
+ <span className="select-items__item-title-badge">
57
+ <Badge className="free-domain__primary-badge" type="info-green">
58
+ { preventWidows( badge ) }
59
+ </Badge>
60
+ </span>
61
+ ) }
62
+ </h2>
63
+ <div className="select-items__item-description">
64
+ { preventWidows( description ) }
65
+ </div>
66
+ </div>
67
+ { actionText && (
68
+ <Button
69
+ primary={ isPrimary }
70
+ className="select-items__item-button"
71
+ onClick={ () => onSelect( value ) }
72
+ >
73
+ { actionText }
74
+ </Button>
75
+ ) }
76
+ </div>
77
+ { allItemClickable && (
78
+ <button
79
+ className="select-items__item-clickable"
80
+ onClick={ () => onSelect( value ) }
81
+ />
82
+ ) }
83
+ </div>
84
+ )
85
+ ) }
86
+ </div>
87
+ );
88
+ }
89
+
90
+ export default SelectItems;