@baseplate-dev/react-generators 0.1.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 (508) hide show
  1. package/LICENSE +390 -0
  2. package/dist/constants/index.d.ts +2 -0
  3. package/dist/constants/index.d.ts.map +1 -0
  4. package/dist/constants/index.js +2 -0
  5. package/dist/constants/index.js.map +1 -0
  6. package/dist/constants/react-packages.d.ts +42 -0
  7. package/dist/constants/react-packages.d.ts.map +1 -0
  8. package/dist/constants/react-packages.js +50 -0
  9. package/dist/constants/react-packages.js.map +1 -0
  10. package/dist/generators/admin/_providers/admin-crud-column-container.d.ts +12 -0
  11. package/dist/generators/admin/_providers/admin-crud-column-container.d.ts.map +1 -0
  12. package/dist/generators/admin/_providers/admin-crud-column-container.js +3 -0
  13. package/dist/generators/admin/_providers/admin-crud-column-container.js.map +1 -0
  14. package/dist/generators/admin/_providers/admin-crud-display-container.d.ts +7 -0
  15. package/dist/generators/admin/_providers/admin-crud-display-container.d.ts.map +1 -0
  16. package/dist/generators/admin/_providers/admin-crud-display-container.js +3 -0
  17. package/dist/generators/admin/_providers/admin-crud-display-container.js.map +1 -0
  18. package/dist/generators/admin/_providers/admin-crud-input-container.d.ts +22 -0
  19. package/dist/generators/admin/_providers/admin-crud-input-container.d.ts.map +1 -0
  20. package/dist/generators/admin/_providers/admin-crud-input-container.js +3 -0
  21. package/dist/generators/admin/_providers/admin-crud-input-container.js.map +1 -0
  22. package/dist/generators/admin/_providers/admin-loader.d.ts +14 -0
  23. package/dist/generators/admin/_providers/admin-loader.d.ts.map +1 -0
  24. package/dist/generators/admin/_providers/admin-loader.js +26 -0
  25. package/dist/generators/admin/_providers/admin-loader.js.map +1 -0
  26. package/dist/generators/admin/_providers/index.d.ts +5 -0
  27. package/dist/generators/admin/_providers/index.d.ts.map +1 -0
  28. package/dist/generators/admin/_providers/index.js +5 -0
  29. package/dist/generators/admin/_providers/index.js.map +1 -0
  30. package/dist/generators/admin/_utils/data-display.d.ts +10 -0
  31. package/dist/generators/admin/_utils/data-display.d.ts.map +1 -0
  32. package/dist/generators/admin/_utils/data-display.js +2 -0
  33. package/dist/generators/admin/_utils/data-display.js.map +1 -0
  34. package/dist/generators/admin/_utils/data-loaders.d.ts +23 -0
  35. package/dist/generators/admin/_utils/data-loaders.d.ts.map +1 -0
  36. package/dist/generators/admin/_utils/data-loaders.js +44 -0
  37. package/dist/generators/admin/_utils/data-loaders.js.map +1 -0
  38. package/dist/generators/admin/_utils/foreign-data-dependency.d.ts +15 -0
  39. package/dist/generators/admin/_utils/foreign-data-dependency.d.ts.map +1 -0
  40. package/dist/generators/admin/_utils/foreign-data-dependency.js +53 -0
  41. package/dist/generators/admin/_utils/foreign-data-dependency.js.map +1 -0
  42. package/dist/generators/admin/_utils/graphql.d.ts +3 -0
  43. package/dist/generators/admin/_utils/graphql.d.ts.map +1 -0
  44. package/dist/generators/admin/_utils/graphql.js +16 -0
  45. package/dist/generators/admin/_utils/graphql.js.map +1 -0
  46. package/dist/generators/admin/admin-bull-board/admin-bull-board.generator.d.ts +67 -0
  47. package/dist/generators/admin/admin-bull-board/admin-bull-board.generator.d.ts.map +1 -0
  48. package/dist/generators/admin/admin-bull-board/admin-bull-board.generator.js +70 -0
  49. package/dist/generators/admin/admin-bull-board/admin-bull-board.generator.js.map +1 -0
  50. package/dist/generators/admin/admin-bull-board/generated/text-templates.d.ts +4 -0
  51. package/dist/generators/admin/admin-bull-board/generated/text-templates.d.ts.map +1 -0
  52. package/dist/generators/admin/admin-bull-board/generated/text-templates.js +10 -0
  53. package/dist/generators/admin/admin-bull-board/generated/text-templates.js.map +1 -0
  54. package/dist/generators/admin/admin-bull-board/generated/ts-templates.d.ts +56 -0
  55. package/dist/generators/admin/admin-bull-board/generated/ts-templates.d.ts.map +1 -0
  56. package/dist/generators/admin/admin-bull-board/generated/ts-templates.js +19 -0
  57. package/dist/generators/admin/admin-bull-board/generated/ts-templates.js.map +1 -0
  58. package/dist/generators/admin/admin-bull-board/templates/bull-board.gql +5 -0
  59. package/dist/generators/admin/admin-bull-board/templates/bull-board.page.tsx +47 -0
  60. package/dist/generators/admin/admin-components/admin-components.generator.d.ts +71 -0
  61. package/dist/generators/admin/admin-components/admin-components.generator.d.ts.map +1 -0
  62. package/dist/generators/admin/admin-components/admin-components.generator.js +51 -0
  63. package/dist/generators/admin/admin-components/admin-components.generator.js.map +1 -0
  64. package/dist/generators/admin/admin-components/generated/ts-import-maps.d.ts +45 -0
  65. package/dist/generators/admin/admin-components/generated/ts-import-maps.d.ts.map +1 -0
  66. package/dist/generators/admin/admin-components/generated/ts-import-maps.js +26 -0
  67. package/dist/generators/admin/admin-components/generated/ts-import-maps.js.map +1 -0
  68. package/dist/generators/admin/admin-components/generated/ts-templates.d.ts +99 -0
  69. package/dist/generators/admin/admin-components/generated/ts-templates.d.ts.map +1 -0
  70. package/dist/generators/admin/admin-components/generated/ts-templates.js +54 -0
  71. package/dist/generators/admin/admin-components/generated/ts-templates.js.map +1 -0
  72. package/dist/generators/admin/admin-components/templates/DescriptionList/index.tsx +45 -0
  73. package/dist/generators/admin/admin-components/templates/EmbeddedListInput/index.tsx +213 -0
  74. package/dist/generators/admin/admin-components/templates/EmbeddedObjectInput/index.tsx +163 -0
  75. package/dist/generators/admin/admin-crud-column/admin-crud-column.generator.d.ts +12 -0
  76. package/dist/generators/admin/admin-crud-column/admin-crud-column.generator.d.ts.map +1 -0
  77. package/dist/generators/admin/admin-crud-column/admin-crud-column.generator.js +52 -0
  78. package/dist/generators/admin/admin-crud-column/admin-crud-column.generator.js.map +1 -0
  79. package/dist/generators/admin/admin-crud-edit/admin-crud-edit.generator.d.ts +69 -0
  80. package/dist/generators/admin/admin-crud-edit/admin-crud-edit.generator.d.ts.map +1 -0
  81. package/dist/generators/admin/admin-crud-edit/admin-crud-edit.generator.js +205 -0
  82. package/dist/generators/admin/admin-crud-edit/admin-crud-edit.generator.js.map +1 -0
  83. package/dist/generators/admin/admin-crud-edit/generated/ts-templates.d.ts +166 -0
  84. package/dist/generators/admin/admin-crud-edit/generated/ts-templates.d.ts.map +1 -0
  85. package/dist/generators/admin/admin-crud-edit/generated/ts-templates.js +75 -0
  86. package/dist/generators/admin/admin-crud-edit/generated/ts-templates.js.map +1 -0
  87. package/dist/generators/admin/admin-crud-edit/templates/EditForm.tsx +52 -0
  88. package/dist/generators/admin/admin-crud-edit/templates/create.page.tsx +45 -0
  89. package/dist/generators/admin/admin-crud-edit/templates/edit.page.tsx +38 -0
  90. package/dist/generators/admin/admin-crud-edit/templates/schema.ts +7 -0
  91. package/dist/generators/admin/admin-crud-embedded-form/admin-crud-embedded-form.generator.d.ts +119 -0
  92. package/dist/generators/admin/admin-crud-embedded-form/admin-crud-embedded-form.generator.d.ts.map +1 -0
  93. package/dist/generators/admin/admin-crud-embedded-form/admin-crud-embedded-form.generator.js +281 -0
  94. package/dist/generators/admin/admin-crud-embedded-form/admin-crud-embedded-form.generator.js.map +1 -0
  95. package/dist/generators/admin/admin-crud-embedded-form/generated/ts-templates.d.ts +59 -0
  96. package/dist/generators/admin/admin-crud-embedded-form/generated/ts-templates.d.ts.map +1 -0
  97. package/dist/generators/admin/admin-crud-embedded-form/generated/ts-templates.js +24 -0
  98. package/dist/generators/admin/admin-crud-embedded-form/generated/ts-templates.js.map +1 -0
  99. package/dist/generators/admin/admin-crud-embedded-form/templates/EmbeddedForm.tsx +38 -0
  100. package/dist/generators/admin/admin-crud-embedded-input/admin-crud-embedded-input.generator.d.ts +38 -0
  101. package/dist/generators/admin/admin-crud-embedded-input/admin-crud-embedded-input.generator.d.ts.map +1 -0
  102. package/dist/generators/admin/admin-crud-embedded-input/admin-crud-embedded-input.generator.js +88 -0
  103. package/dist/generators/admin/admin-crud-embedded-input/admin-crud-embedded-input.generator.js.map +1 -0
  104. package/dist/generators/admin/admin-crud-enum-input/admin-crud-enum-input.generator.d.ts +55 -0
  105. package/dist/generators/admin/admin-crud-enum-input/admin-crud-enum-input.generator.d.ts.map +1 -0
  106. package/dist/generators/admin/admin-crud-enum-input/admin-crud-enum-input.generator.js +58 -0
  107. package/dist/generators/admin/admin-crud-enum-input/admin-crud-enum-input.generator.js.map +1 -0
  108. package/dist/generators/admin/admin-crud-foreign-display/admin-crud-foreign-display.generator.d.ts +17 -0
  109. package/dist/generators/admin/admin-crud-foreign-display/admin-crud-foreign-display.generator.d.ts.map +1 -0
  110. package/dist/generators/admin/admin-crud-foreign-display/admin-crud-foreign-display.generator.js +60 -0
  111. package/dist/generators/admin/admin-crud-foreign-display/admin-crud-foreign-display.generator.js.map +1 -0
  112. package/dist/generators/admin/admin-crud-foreign-input/admin-crud-foreign-input.generator.d.ts +58 -0
  113. package/dist/generators/admin/admin-crud-foreign-input/admin-crud-foreign-input.generator.d.ts.map +1 -0
  114. package/dist/generators/admin/admin-crud-foreign-input/admin-crud-foreign-input.generator.js +79 -0
  115. package/dist/generators/admin/admin-crud-foreign-input/admin-crud-foreign-input.generator.js.map +1 -0
  116. package/dist/generators/admin/admin-crud-list/admin-crud-list.generator.d.ts +59 -0
  117. package/dist/generators/admin/admin-crud-list/admin-crud-list.generator.d.ts.map +1 -0
  118. package/dist/generators/admin/admin-crud-list/admin-crud-list.generator.js +152 -0
  119. package/dist/generators/admin/admin-crud-list/admin-crud-list.generator.js.map +1 -0
  120. package/dist/generators/admin/admin-crud-list/generated/ts-templates.d.ts +112 -0
  121. package/dist/generators/admin/admin-crud-list/generated/ts-templates.d.ts.map +1 -0
  122. package/dist/generators/admin/admin-crud-list/generated/ts-templates.js +44 -0
  123. package/dist/generators/admin/admin-crud-list/generated/ts-templates.js.map +1 -0
  124. package/dist/generators/admin/admin-crud-list/templates/Table.tsx +77 -0
  125. package/dist/generators/admin/admin-crud-list/templates/index.page.tsx +40 -0
  126. package/dist/generators/admin/admin-crud-password-input/admin-crud-password-input.generator.d.ts +50 -0
  127. package/dist/generators/admin/admin-crud-password-input/admin-crud-password-input.generator.d.ts.map +1 -0
  128. package/dist/generators/admin/admin-crud-password-input/admin-crud-password-input.generator.js +49 -0
  129. package/dist/generators/admin/admin-crud-password-input/admin-crud-password-input.generator.js.map +1 -0
  130. package/dist/generators/admin/admin-crud-queries/admin-crud-queries.generator.d.ts +34 -0
  131. package/dist/generators/admin/admin-crud-queries/admin-crud-queries.generator.d.ts.map +1 -0
  132. package/dist/generators/admin/admin-crud-queries/admin-crud-queries.generator.js +204 -0
  133. package/dist/generators/admin/admin-crud-queries/admin-crud-queries.generator.js.map +1 -0
  134. package/dist/generators/admin/admin-crud-section/admin-crud-section.generator.d.ts +5 -0
  135. package/dist/generators/admin/admin-crud-section/admin-crud-section.generator.d.ts.map +1 -0
  136. package/dist/generators/admin/admin-crud-section/admin-crud-section.generator.js +24 -0
  137. package/dist/generators/admin/admin-crud-section/admin-crud-section.generator.js.map +1 -0
  138. package/dist/generators/admin/admin-crud-text-display/admin-crud-text-display.generator.d.ts +8 -0
  139. package/dist/generators/admin/admin-crud-text-display/admin-crud-text-display.generator.d.ts.map +1 -0
  140. package/dist/generators/admin/admin-crud-text-display/admin-crud-text-display.generator.js +28 -0
  141. package/dist/generators/admin/admin-crud-text-display/admin-crud-text-display.generator.js.map +1 -0
  142. package/dist/generators/admin/admin-crud-text-input/admin-crud-text-input.generator.d.ts +52 -0
  143. package/dist/generators/admin/admin-crud-text-input/admin-crud-text-input.generator.d.ts.map +1 -0
  144. package/dist/generators/admin/admin-crud-text-input/admin-crud-text-input.generator.js +53 -0
  145. package/dist/generators/admin/admin-crud-text-input/admin-crud-text-input.generator.js.map +1 -0
  146. package/dist/generators/admin/admin-home/admin-home.generator.d.ts +56 -0
  147. package/dist/generators/admin/admin-home/admin-home.generator.d.ts.map +1 -0
  148. package/dist/generators/admin/admin-home/admin-home.generator.js +45 -0
  149. package/dist/generators/admin/admin-home/admin-home.generator.js.map +1 -0
  150. package/dist/generators/admin/admin-home/generated/ts-templates.d.ts +54 -0
  151. package/dist/generators/admin/admin-home/generated/ts-templates.d.ts.map +1 -0
  152. package/dist/generators/admin/admin-home/generated/ts-templates.js +15 -0
  153. package/dist/generators/admin/admin-home/generated/ts-templates.js.map +1 -0
  154. package/dist/generators/admin/admin-home/templates/Home.page.tsx +23 -0
  155. package/dist/generators/admin/admin-layout/admin-layout.generator.d.ts +91 -0
  156. package/dist/generators/admin/admin-layout/admin-layout.generator.d.ts.map +1 -0
  157. package/dist/generators/admin/admin-layout/admin-layout.generator.js +82 -0
  158. package/dist/generators/admin/admin-layout/admin-layout.generator.js.map +1 -0
  159. package/dist/generators/admin/admin-layout/generated/ts-templates.d.ts +56 -0
  160. package/dist/generators/admin/admin-layout/generated/ts-templates.d.ts.map +1 -0
  161. package/dist/generators/admin/admin-layout/generated/ts-templates.js +15 -0
  162. package/dist/generators/admin/admin-layout/generated/ts-templates.js.map +1 -0
  163. package/dist/generators/admin/admin-layout/templates/AdminLayout.tsx +43 -0
  164. package/dist/generators/admin/index.d.ts +19 -0
  165. package/dist/generators/admin/index.d.ts.map +1 -0
  166. package/dist/generators/admin/index.js +19 -0
  167. package/dist/generators/admin/index.js.map +1 -0
  168. package/dist/generators/apollo/apollo-error/apollo-error.generator.d.ts +11 -0
  169. package/dist/generators/apollo/apollo-error/apollo-error.generator.d.ts.map +1 -0
  170. package/dist/generators/apollo/apollo-error/apollo-error.generator.js +37 -0
  171. package/dist/generators/apollo/apollo-error/apollo-error.generator.js.map +1 -0
  172. package/dist/generators/apollo/apollo-error/generated/ts-import-maps.d.ts +11 -0
  173. package/dist/generators/apollo/apollo-error/generated/ts-import-maps.d.ts.map +1 -0
  174. package/dist/generators/apollo/apollo-error/generated/ts-import-maps.js +16 -0
  175. package/dist/generators/apollo/apollo-error/generated/ts-import-maps.js.map +1 -0
  176. package/dist/generators/apollo/apollo-error/generated/ts-templates.d.ts +4 -0
  177. package/dist/generators/apollo/apollo-error/generated/ts-templates.d.ts.map +1 -0
  178. package/dist/generators/apollo/apollo-error/generated/ts-templates.js +9 -0
  179. package/dist/generators/apollo/apollo-error/generated/ts-templates.js.map +1 -0
  180. package/dist/generators/apollo/apollo-error/templates/apollo-error.ts +19 -0
  181. package/dist/generators/apollo/apollo-error-link/apollo-error-link.generator.d.ts +25 -0
  182. package/dist/generators/apollo/apollo-error-link/apollo-error-link.generator.d.ts.map +1 -0
  183. package/dist/generators/apollo/apollo-error-link/apollo-error-link.generator.js +93 -0
  184. package/dist/generators/apollo/apollo-error-link/apollo-error-link.generator.js.map +1 -0
  185. package/dist/generators/apollo/apollo-sentry/apollo-sentry.generator.d.ts +30 -0
  186. package/dist/generators/apollo/apollo-sentry/apollo-sentry.generator.d.ts.map +1 -0
  187. package/dist/generators/apollo/apollo-sentry/apollo-sentry.generator.js +100 -0
  188. package/dist/generators/apollo/apollo-sentry/apollo-sentry.generator.js.map +1 -0
  189. package/dist/generators/apollo/apollo-sentry/generated/ts-templates.d.ts +14 -0
  190. package/dist/generators/apollo/apollo-sentry/generated/ts-templates.d.ts.map +1 -0
  191. package/dist/generators/apollo/apollo-sentry/generated/ts-templates.js +15 -0
  192. package/dist/generators/apollo/apollo-sentry/generated/ts-templates.js.map +1 -0
  193. package/dist/generators/apollo/apollo-sentry/templates/apollo-sentry-link.ts +56 -0
  194. package/dist/generators/apollo/index.d.ts +5 -0
  195. package/dist/generators/apollo/index.d.ts.map +1 -0
  196. package/dist/generators/apollo/index.js +5 -0
  197. package/dist/generators/apollo/index.js.map +1 -0
  198. package/dist/generators/apollo/react-apollo/generated/text-templates.d.ts +8 -0
  199. package/dist/generators/apollo/react-apollo/generated/text-templates.d.ts.map +1 -0
  200. package/dist/generators/apollo/react-apollo/generated/text-templates.js +10 -0
  201. package/dist/generators/apollo/react-apollo/generated/text-templates.js.map +1 -0
  202. package/dist/generators/apollo/react-apollo/generated/ts-import-maps.d.ts +21 -0
  203. package/dist/generators/apollo/react-apollo/generated/ts-import-maps.d.ts.map +1 -0
  204. package/dist/generators/apollo/react-apollo/generated/ts-import-maps.js +28 -0
  205. package/dist/generators/apollo/react-apollo/generated/ts-import-maps.js.map +1 -0
  206. package/dist/generators/apollo/react-apollo/generated/ts-templates.d.ts +14 -0
  207. package/dist/generators/apollo/react-apollo/generated/ts-templates.d.ts.map +1 -0
  208. package/dist/generators/apollo/react-apollo/generated/ts-templates.js +29 -0
  209. package/dist/generators/apollo/react-apollo/generated/ts-templates.js.map +1 -0
  210. package/dist/generators/apollo/react-apollo/react-apollo.generator.d.ts +172 -0
  211. package/dist/generators/apollo/react-apollo/react-apollo.generator.d.ts.map +1 -0
  212. package/dist/generators/apollo/react-apollo/react-apollo.generator.js +403 -0
  213. package/dist/generators/apollo/react-apollo/react-apollo.generator.js.map +1 -0
  214. package/dist/generators/apollo/react-apollo/templates/app/AppApolloProvider.tsx +25 -0
  215. package/dist/generators/apollo/react-apollo/templates/codegen.yml.tpl +16 -0
  216. package/dist/generators/apollo/react-apollo/templates/services/apollo/cache.ts +7 -0
  217. package/dist/generators/apollo/react-apollo/templates/services/apollo/index.ts +19 -0
  218. package/dist/generators/apollo/react-apollo/templates/websocket-links.ts +46 -0
  219. package/dist/generators/auth/_providers/auth-components.d.ts +13 -0
  220. package/dist/generators/auth/_providers/auth-components.d.ts.map +1 -0
  221. package/dist/generators/auth/_providers/auth-components.js +7 -0
  222. package/dist/generators/auth/_providers/auth-components.js.map +1 -0
  223. package/dist/generators/auth/_providers/auth-hooks.d.ts +21 -0
  224. package/dist/generators/auth/_providers/auth-hooks.d.ts.map +1 -0
  225. package/dist/generators/auth/_providers/auth-hooks.js +11 -0
  226. package/dist/generators/auth/_providers/auth-hooks.js.map +1 -0
  227. package/dist/generators/auth/_providers/index.d.ts +3 -0
  228. package/dist/generators/auth/_providers/index.d.ts.map +1 -0
  229. package/dist/generators/auth/_providers/index.js +3 -0
  230. package/dist/generators/auth/_providers/index.js.map +1 -0
  231. package/dist/generators/auth/auth-identify/auth-identify.generator.d.ts +32 -0
  232. package/dist/generators/auth/auth-identify/auth-identify.generator.d.ts.map +1 -0
  233. package/dist/generators/auth/auth-identify/auth-identify.generator.js +53 -0
  234. package/dist/generators/auth/auth-identify/auth-identify.generator.js.map +1 -0
  235. package/dist/generators/auth/index.d.ts +4 -0
  236. package/dist/generators/auth/index.d.ts.map +1 -0
  237. package/dist/generators/auth/index.js +4 -0
  238. package/dist/generators/auth/index.js.map +1 -0
  239. package/dist/generators/auth/placeholder-auth-hooks/generated/ts-import-maps.d.ts +3 -0
  240. package/dist/generators/auth/placeholder-auth-hooks/generated/ts-import-maps.d.ts.map +1 -0
  241. package/dist/generators/auth/placeholder-auth-hooks/generated/ts-import-maps.js +16 -0
  242. package/dist/generators/auth/placeholder-auth-hooks/generated/ts-import-maps.js.map +1 -0
  243. package/dist/generators/auth/placeholder-auth-hooks/generated/ts-templates.d.ts +21 -0
  244. package/dist/generators/auth/placeholder-auth-hooks/generated/ts-templates.d.ts.map +1 -0
  245. package/dist/generators/auth/placeholder-auth-hooks/generated/ts-templates.js +49 -0
  246. package/dist/generators/auth/placeholder-auth-hooks/generated/ts-templates.js.map +1 -0
  247. package/dist/generators/auth/placeholder-auth-hooks/placeholder-auth-hooks.generator.d.ts +22 -0
  248. package/dist/generators/auth/placeholder-auth-hooks/placeholder-auth-hooks.generator.d.ts.map +1 -0
  249. package/dist/generators/auth/placeholder-auth-hooks/placeholder-auth-hooks.generator.js +48 -0
  250. package/dist/generators/auth/placeholder-auth-hooks/placeholder-auth-hooks.generator.js.map +1 -0
  251. package/dist/generators/auth/placeholder-auth-hooks/templates/useCurrentUser.ts +9 -0
  252. package/dist/generators/auth/placeholder-auth-hooks/templates/useLogOut.ts +5 -0
  253. package/dist/generators/auth/placeholder-auth-hooks/templates/useRequiredUserId.ts +5 -0
  254. package/dist/generators/auth/placeholder-auth-hooks/templates/useSession.ts +8 -0
  255. package/dist/generators/core/_composers/index.d.ts +2 -0
  256. package/dist/generators/core/_composers/index.d.ts.map +1 -0
  257. package/dist/generators/core/_composers/index.js +2 -0
  258. package/dist/generators/core/_composers/index.js.map +1 -0
  259. package/dist/generators/core/_composers/react.composer.d.ts +6 -0
  260. package/dist/generators/core/_composers/react.composer.d.ts.map +1 -0
  261. package/dist/generators/core/_composers/react.composer.js +28 -0
  262. package/dist/generators/core/_composers/react.composer.js.map +1 -0
  263. package/dist/generators/core/_utils/index.d.ts +2 -0
  264. package/dist/generators/core/_utils/index.d.ts.map +1 -0
  265. package/dist/generators/core/_utils/index.js +2 -0
  266. package/dist/generators/core/_utils/index.js.map +1 -0
  267. package/dist/generators/core/_utils/render-routes.d.ts +4 -0
  268. package/dist/generators/core/_utils/render-routes.d.ts.map +1 -0
  269. package/dist/generators/core/_utils/render-routes.js +42 -0
  270. package/dist/generators/core/_utils/render-routes.js.map +1 -0
  271. package/dist/generators/core/index.d.ts +18 -0
  272. package/dist/generators/core/index.d.ts.map +1 -0
  273. package/dist/generators/core/index.js +18 -0
  274. package/dist/generators/core/index.js.map +1 -0
  275. package/dist/generators/core/react/generated/raw-templates.d.ts +4 -0
  276. package/dist/generators/core/react/generated/raw-templates.d.ts.map +1 -0
  277. package/dist/generators/core/react/generated/raw-templates.js +9 -0
  278. package/dist/generators/core/react/generated/raw-templates.js.map +1 -0
  279. package/dist/generators/core/react/generated/text-templates.d.ts +28 -0
  280. package/dist/generators/core/react/generated/text-templates.d.ts.map +1 -0
  281. package/dist/generators/core/react/generated/text-templates.js +42 -0
  282. package/dist/generators/core/react/generated/text-templates.js.map +1 -0
  283. package/dist/generators/core/react/generated/ts-templates.d.ts +10 -0
  284. package/dist/generators/core/react/generated/ts-templates.d.ts.map +1 -0
  285. package/dist/generators/core/react/generated/ts-templates.js +15 -0
  286. package/dist/generators/core/react/generated/ts-templates.js.map +1 -0
  287. package/dist/generators/core/react/node.d.ts +2 -0
  288. package/dist/generators/core/react/node.d.ts.map +1 -0
  289. package/dist/generators/core/react/node.js +32 -0
  290. package/dist/generators/core/react/node.js.map +1 -0
  291. package/dist/generators/core/react/react.generator.d.ts +53 -0
  292. package/dist/generators/core/react/react.generator.d.ts.map +1 -0
  293. package/dist/generators/core/react/react.generator.js +120 -0
  294. package/dist/generators/core/react/react.generator.js.map +1 -0
  295. package/dist/generators/core/react/templates/README.md +19 -0
  296. package/dist/generators/core/react/templates/index.html +15 -0
  297. package/dist/generators/core/react/templates/public/favicon.ico +0 -0
  298. package/dist/generators/core/react/templates/src/index.tsx +18 -0
  299. package/dist/generators/core/react/templates/src/vite-env.d.ts +2 -0
  300. package/dist/generators/core/react/templates/vite.config.ts +10 -0
  301. package/dist/generators/core/react-app/generated/ts-templates.d.ts +6 -0
  302. package/dist/generators/core/react-app/generated/ts-templates.d.ts.map +1 -0
  303. package/dist/generators/core/react-app/generated/ts-templates.js +9 -0
  304. package/dist/generators/core/react-app/generated/ts-templates.js.map +1 -0
  305. package/dist/generators/core/react-app/react-app.generator.d.ts +41 -0
  306. package/dist/generators/core/react-app/react-app.generator.d.ts.map +1 -0
  307. package/dist/generators/core/react-app/react-app.generator.js +70 -0
  308. package/dist/generators/core/react-app/react-app.generator.js.map +1 -0
  309. package/dist/generators/core/react-app/templates/App.tsx +9 -0
  310. package/dist/generators/core/react-components/generated/ts-import-maps.d.ts +85 -0
  311. package/dist/generators/core/react-components/generated/ts-import-maps.d.ts.map +1 -0
  312. package/dist/generators/core/react-components/generated/ts-import-maps.js +78 -0
  313. package/dist/generators/core/react-components/generated/ts-import-maps.js.map +1 -0
  314. package/dist/generators/core/react-components/generated/ts-templates.d.ts +119 -0
  315. package/dist/generators/core/react-components/generated/ts-templates.d.ts.map +1 -0
  316. package/dist/generators/core/react-components/generated/ts-templates.js +308 -0
  317. package/dist/generators/core/react-components/generated/ts-templates.js.map +1 -0
  318. package/dist/generators/core/react-components/react-components.generator.d.ts +75 -0
  319. package/dist/generators/core/react-components/react-components.generator.d.ts.map +1 -0
  320. package/dist/generators/core/react-components/react-components.generator.js +126 -0
  321. package/dist/generators/core/react-components/react-components.generator.js.map +1 -0
  322. package/dist/generators/core/react-components/templates/components/Alert/index.tsx +76 -0
  323. package/dist/generators/core/react-components/templates/components/AlertIcon/index.tsx +75 -0
  324. package/dist/generators/core/react-components/templates/components/BackButton/index.tsx +35 -0
  325. package/dist/generators/core/react-components/templates/components/Button/index.tsx +99 -0
  326. package/dist/generators/core/react-components/templates/components/ButtonGroup/index.tsx +52 -0
  327. package/dist/generators/core/react-components/templates/components/Card/index.tsx +27 -0
  328. package/dist/generators/core/react-components/templates/components/CheckedInput/index.tsx +130 -0
  329. package/dist/generators/core/react-components/templates/components/ConfirmDialog/index.tsx +88 -0
  330. package/dist/generators/core/react-components/templates/components/ErrorDisplay/index.tsx +52 -0
  331. package/dist/generators/core/react-components/templates/components/ErrorableLoader/index.tsx +31 -0
  332. package/dist/generators/core/react-components/templates/components/FormError/index.tsx +22 -0
  333. package/dist/generators/core/react-components/templates/components/FormLabel/index.tsx +25 -0
  334. package/dist/generators/core/react-components/templates/components/LinkButton/index.tsx +54 -0
  335. package/dist/generators/core/react-components/templates/components/ListGroup/index.tsx +48 -0
  336. package/dist/generators/core/react-components/templates/components/Modal/index.tsx +167 -0
  337. package/dist/generators/core/react-components/templates/components/NotFoundCard/index.tsx +32 -0
  338. package/dist/generators/core/react-components/templates/components/ReactDatePickerInput/index.tsx +162 -0
  339. package/dist/generators/core/react-components/templates/components/ReactSelectInput/index.tsx +137 -0
  340. package/dist/generators/core/react-components/templates/components/SelectInput/index.tsx +108 -0
  341. package/dist/generators/core/react-components/templates/components/Sidebar/index.tsx +216 -0
  342. package/dist/generators/core/react-components/templates/components/Spinner/index.tsx +70 -0
  343. package/dist/generators/core/react-components/templates/components/Table/index.tsx +132 -0
  344. package/dist/generators/core/react-components/templates/components/TextAreaInput/index.tsx +107 -0
  345. package/dist/generators/core/react-components/templates/components/TextInput/index.tsx +133 -0
  346. package/dist/generators/core/react-components/templates/components/Toast/index.tsx +68 -0
  347. package/dist/generators/core/react-components/templates/components/index.ts +3 -0
  348. package/dist/generators/core/react-components/templates/hooks/useConfirmDialog.ts +53 -0
  349. package/dist/generators/core/react-components/templates/hooks/useStatus.ts +44 -0
  350. package/dist/generators/core/react-components/templates/hooks/useToast.tsx +52 -0
  351. package/dist/generators/core/react-components/templates/index.ts +3 -0
  352. package/dist/generators/core/react-config/generated/ts-import-maps.d.ts +11 -0
  353. package/dist/generators/core/react-config/generated/ts-import-maps.d.ts.map +1 -0
  354. package/dist/generators/core/react-config/generated/ts-import-maps.js +14 -0
  355. package/dist/generators/core/react-config/generated/ts-import-maps.js.map +1 -0
  356. package/dist/generators/core/react-config/generated/ts-templates.d.ts +6 -0
  357. package/dist/generators/core/react-config/generated/ts-templates.d.ts.map +1 -0
  358. package/dist/generators/core/react-config/generated/ts-templates.js +9 -0
  359. package/dist/generators/core/react-config/generated/ts-templates.js.map +1 -0
  360. package/dist/generators/core/react-config/react-config.generator.d.ts +46 -0
  361. package/dist/generators/core/react-config/react-config.generator.d.ts.map +1 -0
  362. package/dist/generators/core/react-config/react-config.generator.js +84 -0
  363. package/dist/generators/core/react-config/react-config.generator.js.map +1 -0
  364. package/dist/generators/core/react-config/templates/config.ts +7 -0
  365. package/dist/generators/core/react-error/generated/ts-import-maps.d.ts +15 -0
  366. package/dist/generators/core/react-error/generated/ts-import-maps.d.ts.map +1 -0
  367. package/dist/generators/core/react-error/generated/ts-import-maps.js +20 -0
  368. package/dist/generators/core/react-error/generated/ts-import-maps.js.map +1 -0
  369. package/dist/generators/core/react-error/generated/ts-templates.d.ts +14 -0
  370. package/dist/generators/core/react-error/generated/ts-templates.d.ts.map +1 -0
  371. package/dist/generators/core/react-error/generated/ts-templates.js +17 -0
  372. package/dist/generators/core/react-error/generated/ts-templates.js.map +1 -0
  373. package/dist/generators/core/react-error/react-error.generator.d.ts +29 -0
  374. package/dist/generators/core/react-error/react-error.generator.d.ts.map +1 -0
  375. package/dist/generators/core/react-error/react-error.generator.js +63 -0
  376. package/dist/generators/core/react-error/react-error.generator.js.map +1 -0
  377. package/dist/generators/core/react-error/templates/error-formatter.ts +22 -0
  378. package/dist/generators/core/react-error/templates/error-logger.ts +32 -0
  379. package/dist/generators/core/react-error/templates/services/error-formatter.ts +23 -0
  380. package/dist/generators/core/react-error/templates/services/error-logger.ts +32 -0
  381. package/dist/generators/core/react-error-boundary/generated/ts-templates.d.ts +50 -0
  382. package/dist/generators/core/react-error-boundary/generated/ts-templates.d.ts.map +1 -0
  383. package/dist/generators/core/react-error-boundary/generated/ts-templates.js +15 -0
  384. package/dist/generators/core/react-error-boundary/generated/ts-templates.js.map +1 -0
  385. package/dist/generators/core/react-error-boundary/react-error-boundary.generator.d.ts +60 -0
  386. package/dist/generators/core/react-error-boundary/react-error-boundary.generator.d.ts.map +1 -0
  387. package/dist/generators/core/react-error-boundary/react-error-boundary.generator.js +46 -0
  388. package/dist/generators/core/react-error-boundary/react-error-boundary.generator.js.map +1 -0
  389. package/dist/generators/core/react-error-boundary/templates/error-boundary.tsx +78 -0
  390. package/dist/generators/core/react-logger/generated/ts-import-maps.d.ts +11 -0
  391. package/dist/generators/core/react-logger/generated/ts-import-maps.d.ts.map +1 -0
  392. package/dist/generators/core/react-logger/generated/ts-import-maps.js +14 -0
  393. package/dist/generators/core/react-logger/generated/ts-import-maps.js.map +1 -0
  394. package/dist/generators/core/react-logger/generated/ts-templates.d.ts +4 -0
  395. package/dist/generators/core/react-logger/generated/ts-templates.d.ts.map +1 -0
  396. package/dist/generators/core/react-logger/generated/ts-templates.js +9 -0
  397. package/dist/generators/core/react-logger/generated/ts-templates.js.map +1 -0
  398. package/dist/generators/core/react-logger/react-logger.generator.d.ts +12 -0
  399. package/dist/generators/core/react-logger/react-logger.generator.d.ts.map +1 -0
  400. package/dist/generators/core/react-logger/react-logger.generator.js +40 -0
  401. package/dist/generators/core/react-logger/react-logger.generator.js.map +1 -0
  402. package/dist/generators/core/react-logger/templates/logger.ts +7 -0
  403. package/dist/generators/core/react-not-found-handler/generated/ts-templates.d.ts +45 -0
  404. package/dist/generators/core/react-not-found-handler/generated/ts-templates.d.ts.map +1 -0
  405. package/dist/generators/core/react-not-found-handler/generated/ts-templates.js +13 -0
  406. package/dist/generators/core/react-not-found-handler/generated/ts-templates.js.map +1 -0
  407. package/dist/generators/core/react-not-found-handler/react-not-found-handler.generator.d.ts +56 -0
  408. package/dist/generators/core/react-not-found-handler/react-not-found-handler.generator.d.ts.map +1 -0
  409. package/dist/generators/core/react-not-found-handler/react-not-found-handler.generator.js +56 -0
  410. package/dist/generators/core/react-not-found-handler/react-not-found-handler.generator.js.map +1 -0
  411. package/dist/generators/core/react-not-found-handler/templates/NotFound.page.tsx +11 -0
  412. package/dist/generators/core/react-proxy/react-proxy.generator.d.ts +23 -0
  413. package/dist/generators/core/react-proxy/react-proxy.generator.d.ts.map +1 -0
  414. package/dist/generators/core/react-proxy/react-proxy.generator.js +51 -0
  415. package/dist/generators/core/react-proxy/react-proxy.generator.js.map +1 -0
  416. package/dist/generators/core/react-router/generated/ts-templates.d.ts +7 -0
  417. package/dist/generators/core/react-router/generated/ts-templates.d.ts.map +1 -0
  418. package/dist/generators/core/react-router/generated/ts-templates.js +9 -0
  419. package/dist/generators/core/react-router/generated/ts-templates.js.map +1 -0
  420. package/dist/generators/core/react-router/react-router.generator.d.ts +40 -0
  421. package/dist/generators/core/react-router/react-router.generator.d.ts.map +1 -0
  422. package/dist/generators/core/react-router/react-router.generator.js +99 -0
  423. package/dist/generators/core/react-router/react-router.generator.js.map +1 -0
  424. package/dist/generators/core/react-router/templates/index.tsx +11 -0
  425. package/dist/generators/core/react-router/templates/pages/index.tsx +14 -0
  426. package/dist/generators/core/react-routes/generated/ts-templates.d.ts +8 -0
  427. package/dist/generators/core/react-routes/generated/ts-templates.d.ts.map +1 -0
  428. package/dist/generators/core/react-routes/generated/ts-templates.js +9 -0
  429. package/dist/generators/core/react-routes/generated/ts-templates.js.map +1 -0
  430. package/dist/generators/core/react-routes/react-routes.generator.d.ts +16 -0
  431. package/dist/generators/core/react-routes/react-routes.generator.d.ts.map +1 -0
  432. package/dist/generators/core/react-routes/react-routes.generator.js +104 -0
  433. package/dist/generators/core/react-routes/react-routes.generator.js.map +1 -0
  434. package/dist/generators/core/react-routes/templates/index.tsx +15 -0
  435. package/dist/generators/core/react-routes/templates/routes.tsx +16 -0
  436. package/dist/generators/core/react-sentry/generated/ts-import-maps.d.ts +13 -0
  437. package/dist/generators/core/react-sentry/generated/ts-import-maps.d.ts.map +1 -0
  438. package/dist/generators/core/react-sentry/generated/ts-import-maps.js +18 -0
  439. package/dist/generators/core/react-sentry/generated/ts-import-maps.js.map +1 -0
  440. package/dist/generators/core/react-sentry/generated/ts-templates.d.ts +10 -0
  441. package/dist/generators/core/react-sentry/generated/ts-templates.d.ts.map +1 -0
  442. package/dist/generators/core/react-sentry/generated/ts-templates.js +11 -0
  443. package/dist/generators/core/react-sentry/generated/ts-templates.js.map +1 -0
  444. package/dist/generators/core/react-sentry/react-sentry.generator.d.ts +50 -0
  445. package/dist/generators/core/react-sentry/react-sentry.generator.d.ts.map +1 -0
  446. package/dist/generators/core/react-sentry/react-sentry.generator.js +100 -0
  447. package/dist/generators/core/react-sentry/react-sentry.generator.js.map +1 -0
  448. package/dist/generators/core/react-sentry/templates/sentry.ts +63 -0
  449. package/dist/generators/core/react-tailwind/generated/text-templates.d.ts +21 -0
  450. package/dist/generators/core/react-tailwind/generated/text-templates.d.ts.map +1 -0
  451. package/dist/generators/core/react-tailwind/generated/text-templates.js +41 -0
  452. package/dist/generators/core/react-tailwind/generated/text-templates.js.map +1 -0
  453. package/dist/generators/core/react-tailwind/react-tailwind.generator.d.ts +28 -0
  454. package/dist/generators/core/react-tailwind/react-tailwind.generator.d.ts.map +1 -0
  455. package/dist/generators/core/react-tailwind/react-tailwind.generator.js +75 -0
  456. package/dist/generators/core/react-tailwind/react-tailwind.generator.js.map +1 -0
  457. package/dist/generators/core/react-tailwind/templates/postcss.config.js +6 -0
  458. package/dist/generators/core/react-tailwind/templates/src/index.css +27 -0
  459. package/dist/generators/core/react-tailwind/templates/tpl.tailwind.config.js +10 -0
  460. package/dist/generators/core/react-typescript/react-typescript.generator.d.ts +12 -0
  461. package/dist/generators/core/react-typescript/react-typescript.generator.d.ts.map +1 -0
  462. package/dist/generators/core/react-typescript/react-typescript.generator.js +63 -0
  463. package/dist/generators/core/react-typescript/react-typescript.generator.js.map +1 -0
  464. package/dist/generators/core/react-utils/generated/ts-import-maps.d.ts +11 -0
  465. package/dist/generators/core/react-utils/generated/ts-import-maps.d.ts.map +1 -0
  466. package/dist/generators/core/react-utils/generated/ts-import-maps.js +16 -0
  467. package/dist/generators/core/react-utils/generated/ts-import-maps.js.map +1 -0
  468. package/dist/generators/core/react-utils/generated/ts-templates.d.ts +4 -0
  469. package/dist/generators/core/react-utils/generated/ts-templates.d.ts.map +1 -0
  470. package/dist/generators/core/react-utils/generated/ts-templates.js +11 -0
  471. package/dist/generators/core/react-utils/generated/ts-templates.js.map +1 -0
  472. package/dist/generators/core/react-utils/react-utils.generator.d.ts +11 -0
  473. package/dist/generators/core/react-utils/react-utils.generator.d.ts.map +1 -0
  474. package/dist/generators/core/react-utils/react-utils.generator.js +47 -0
  475. package/dist/generators/core/react-utils/react-utils.generator.js.map +1 -0
  476. package/dist/generators/core/react-utils/templates/safe-local-storage.ts +50 -0
  477. package/dist/generators/index.d.ts +5 -0
  478. package/dist/generators/index.d.ts.map +1 -0
  479. package/dist/generators/index.js +5 -0
  480. package/dist/generators/index.js.map +1 -0
  481. package/dist/index.d.ts +5 -0
  482. package/dist/index.js +5 -0
  483. package/dist/index.js.map +1 -0
  484. package/dist/providers/index.d.ts +2 -0
  485. package/dist/providers/index.d.ts.map +1 -0
  486. package/dist/providers/index.js +2 -0
  487. package/dist/providers/index.js.map +1 -0
  488. package/dist/providers/routes.d.ts +26 -0
  489. package/dist/providers/routes.d.ts.map +1 -0
  490. package/dist/providers/routes.js +6 -0
  491. package/dist/providers/routes.js.map +1 -0
  492. package/dist/utils/case.d.ts +5 -0
  493. package/dist/utils/case.d.ts.map +1 -0
  494. package/dist/utils/case.js +20 -0
  495. package/dist/utils/case.js.map +1 -0
  496. package/dist/utils/index.d.ts +2 -0
  497. package/dist/utils/index.d.ts.map +1 -0
  498. package/dist/utils/index.js +2 -0
  499. package/dist/utils/index.js.map +1 -0
  500. package/dist/utils/routes.d.ts +3 -0
  501. package/dist/utils/routes.d.ts.map +1 -0
  502. package/dist/utils/routes.js +5 -0
  503. package/dist/utils/routes.js.map +1 -0
  504. package/dist/writers/graphql/index.d.ts +66 -0
  505. package/dist/writers/graphql/index.d.ts.map +1 -0
  506. package/dist/writers/graphql/index.js +217 -0
  507. package/dist/writers/graphql/index.js.map +1 -0
  508. package/package.json +66 -0
@@ -0,0 +1,88 @@
1
+ // @ts-nocheck
2
+
3
+ import type { ReactElement } from 'react';
4
+
5
+ import * as React from 'react';
6
+
7
+ import type { UseConfirmDialogRequestOptions } from '../../hooks/useConfirmDialog.js';
8
+
9
+ import { useConfirmDialogState } from '../../hooks/useConfirmDialog.js';
10
+ import Button from '../Button/index.js';
11
+ import Modal from '../Modal/index.js';
12
+
13
+ /**
14
+ * A confirm dialog that is placed at the top level of the page
15
+ * enabling the use of the useConfirmDialog hook.
16
+ */
17
+ export function ConfirmDialog(): ReactElement {
18
+ const { confirmOptions, setConfirmOptions } = useConfirmDialogState();
19
+
20
+ // We need to store the text content in a ref because the Dialog component
21
+ // will transition to fade so we need to cache the text while we close.
22
+ const textOptionsCached =
23
+ React.useRef<
24
+ Omit<UseConfirmDialogRequestOptions, 'onConfirm' | 'onCancel'>
25
+ >(undefined);
26
+
27
+ React.useEffect(() => {
28
+ if (confirmOptions) {
29
+ textOptionsCached.current = {
30
+ title: confirmOptions.title,
31
+ content: confirmOptions.content,
32
+ buttonCancelText: confirmOptions.buttonCancelText,
33
+ buttonConfirmText: confirmOptions.buttonConfirmText,
34
+ buttonConfirmColor: confirmOptions.buttonConfirmColor,
35
+ };
36
+ }
37
+ }, [confirmOptions]);
38
+
39
+ const {
40
+ title,
41
+ content,
42
+ onCancel,
43
+ onConfirm,
44
+ buttonCancelText = 'Cancel',
45
+ buttonConfirmText = 'Confirm',
46
+ buttonConfirmColor,
47
+ } = {
48
+ ...textOptionsCached.current,
49
+ ...confirmOptions,
50
+ };
51
+
52
+ return (
53
+ <Modal
54
+ isOpen={!!confirmOptions}
55
+ onClose={() => {
56
+ setConfirmOptions(undefined);
57
+ }}
58
+ width="small"
59
+ >
60
+ <Modal.Header>{title}</Modal.Header>
61
+ <Modal.Body>{content}</Modal.Body>
62
+ <Modal.Footer>
63
+ <Button
64
+ color="light"
65
+ onClick={(e) => {
66
+ onCancel?.(e);
67
+ if (e.defaultPrevented) return;
68
+ setConfirmOptions(undefined);
69
+ }}
70
+ >
71
+ {buttonCancelText}
72
+ </Button>
73
+ <Button
74
+ onClick={(e) => {
75
+ onConfirm?.(e);
76
+ if (e.defaultPrevented) return;
77
+ setConfirmOptions(undefined);
78
+ }}
79
+ color={buttonConfirmColor}
80
+ >
81
+ {buttonConfirmText}
82
+ </Button>
83
+ </Modal.Footer>
84
+ </Modal>
85
+ );
86
+ }
87
+
88
+ export default ConfirmDialog;
@@ -0,0 +1,52 @@
1
+ // @ts-nocheck
2
+
3
+ import type { ReactElement } from 'react';
4
+
5
+ import clsx from 'clsx';
6
+ import React from 'react';
7
+ import { MdOutlineErrorOutline } from 'react-icons/md';
8
+
9
+ interface ErrorDisplayProps {
10
+ /**
11
+ * Optional class name to be applied to the loader or error div
12
+ */
13
+ className?: string;
14
+ /**
15
+ * Header to be displayed (if not passed, a generic error header will be displayed)
16
+ */
17
+ header?: string;
18
+ /**
19
+ * Error to be displayed (if a string is passed, it will be displayed as-is, otherwise a generic error message will be displayed)
20
+ */
21
+ error?: unknown;
22
+ /**
23
+ * Optional actions to be displayed below the error message
24
+ */
25
+ actions?: React.ReactNode;
26
+ }
27
+
28
+ function ErrorDisplay({
29
+ className,
30
+ header,
31
+ error,
32
+ actions,
33
+ }: ErrorDisplayProps): ReactElement {
34
+ return (
35
+ <div className={clsx('flex h-full items-center justify-center', className)}>
36
+ <div className="flex max-w-xl flex-col items-center space-y-4 text-center">
37
+ <div>
38
+ <MdOutlineErrorOutline className="text-foreground-300 dark:text-foreground-700 h-20 w-20" />
39
+ </div>
40
+ <h1>{header ?? 'Sorry, something went wrong'}</h1>
41
+ <p className="text-base">
42
+ {typeof error === 'string' || React.isValidElement(error)
43
+ ? error
44
+ : 'We encountered an error showing this page.'}
45
+ </p>
46
+ {actions}
47
+ </div>
48
+ </div>
49
+ );
50
+ }
51
+
52
+ export default ErrorDisplay;
@@ -0,0 +1,31 @@
1
+ // @ts-nocheck
2
+
3
+ import type { ReactElement } from 'react';
4
+
5
+ import Alert from '../Alert/index.js';
6
+ import Spinner from '../Spinner/index.js';
7
+
8
+ interface Props {
9
+ className?: string;
10
+ error?: Error | string | null;
11
+ }
12
+
13
+ function getErrorString(error: Error | string): string {
14
+ if (error instanceof Error) {
15
+ return 'Sorry, we could not load the data.';
16
+ }
17
+ return error;
18
+ }
19
+
20
+ function ErrorableLoader({ className, error }: Props): ReactElement {
21
+ if (!error) {
22
+ return <Spinner className={className} size="large" center />;
23
+ }
24
+ return (
25
+ <Alert type="error" className={className}>
26
+ {getErrorString(error)}
27
+ </Alert>
28
+ );
29
+ }
30
+
31
+ export default ErrorableLoader;
@@ -0,0 +1,22 @@
1
+ // @ts-nocheck
2
+
3
+ import type { ReactElement } from 'react';
4
+
5
+ import clsx from 'clsx';
6
+
7
+ interface Props {
8
+ className?: string;
9
+ children: React.ReactNode;
10
+ }
11
+
12
+ function FormError({ className, children }: Props): ReactElement {
13
+ return (
14
+ <div
15
+ className={clsx('mt-2 text-sm text-red-600 dark:text-red-500', className)}
16
+ >
17
+ {children}
18
+ </div>
19
+ );
20
+ }
21
+
22
+ export default FormError;
@@ -0,0 +1,25 @@
1
+ // @ts-nocheck
2
+
3
+ import type { ReactElement } from 'react';
4
+
5
+ import clsx from 'clsx';
6
+
7
+ interface Props {
8
+ className?: string;
9
+ children: React.ReactNode;
10
+ }
11
+
12
+ function FormLabel({ className, children }: Props): ReactElement {
13
+ return (
14
+ <div
15
+ className={clsx(
16
+ 'mb-2 text-sm font-semibold text-gray-900 dark:text-gray-300',
17
+ className,
18
+ )}
19
+ >
20
+ {children}
21
+ </div>
22
+ );
23
+ }
24
+
25
+ export default FormLabel;
@@ -0,0 +1,54 @@
1
+ // @ts-nocheck
2
+
3
+ import type React from 'react';
4
+ import type { ReactElement } from 'react';
5
+
6
+ import clsx from 'clsx';
7
+
8
+ interface Props {
9
+ className?: string;
10
+ children: React.ReactNode;
11
+ onClick?: React.MouseEventHandler;
12
+ type?: 'button' | 'submit' | 'reset';
13
+ negative?: boolean;
14
+ disabled?: boolean;
15
+ }
16
+
17
+ function LinkButton({
18
+ className,
19
+ children,
20
+ onClick,
21
+ type = 'button',
22
+ negative,
23
+ disabled,
24
+ }: Props): ReactElement {
25
+ const colorClass = (() => {
26
+ if (disabled) {
27
+ return 'text-gray-400 dark:text-gray-500';
28
+ }
29
+ if (negative) {
30
+ return 'text-red-600 dark:text-red-500';
31
+ }
32
+ return 'text-blue-600 dark:text-blue-500';
33
+ })();
34
+
35
+ return (
36
+ <button
37
+ className={clsx(
38
+ 'font-medium',
39
+ { 'hover:underline': !disabled },
40
+ colorClass,
41
+ className,
42
+ )}
43
+ // a type is being provided but eslint doesn't know
44
+
45
+ type={type}
46
+ onClick={onClick}
47
+ disabled={disabled}
48
+ >
49
+ {children}
50
+ </button>
51
+ );
52
+ }
53
+
54
+ export default LinkButton;
@@ -0,0 +1,48 @@
1
+ // @ts-nocheck
2
+
3
+ import type { ReactElement } from 'react';
4
+
5
+ import clsx from 'clsx';
6
+
7
+ interface Props {
8
+ className?: string;
9
+ children: React.ReactNode;
10
+ }
11
+
12
+ // based off https://flowbite.com/docs/components/list-group/
13
+
14
+ function ListGroup({ className, children }: Props): ReactElement {
15
+ return (
16
+ <ul
17
+ className={clsx(
18
+ 'rounded-lg border border-gray-200 bg-white text-sm font-medium text-gray-900 dark:border-gray-600 dark:bg-gray-700 dark:text-white',
19
+ className,
20
+ )}
21
+ >
22
+ {children}
23
+ </ul>
24
+ );
25
+ }
26
+
27
+ interface ListGroupItemProps {
28
+ className?: string;
29
+ children: React.ReactNode;
30
+ }
31
+
32
+ ListGroup.Item = function ListGroupItem({
33
+ className,
34
+ children,
35
+ }: ListGroupItemProps): ReactElement {
36
+ return (
37
+ <li
38
+ className={clsx(
39
+ 'w-full border-b border-gray-200 px-4 py-2 last:border-none dark:border-gray-600',
40
+ className,
41
+ )}
42
+ >
43
+ {children}
44
+ </li>
45
+ );
46
+ };
47
+
48
+ export default ListGroup;
@@ -0,0 +1,167 @@
1
+ // @ts-nocheck
2
+
3
+ import type { ReactElement } from 'react';
4
+
5
+ import {
6
+ Dialog,
7
+ DialogPanel,
8
+ DialogTitle,
9
+ Transition,
10
+ TransitionChild,
11
+ } from '@headlessui/react';
12
+ import clsx from 'clsx';
13
+ import { Fragment } from 'react';
14
+
15
+ type ModalWidth = 'small' | 'base' | 'large';
16
+
17
+ interface Props {
18
+ className?: string;
19
+ isOpen?: boolean;
20
+ onClose: () => void;
21
+ children: React.ReactNode;
22
+ width?: ModalWidth;
23
+ }
24
+
25
+ // Adapted from https://flowbite.com/docs/components/modal/
26
+
27
+ function getModalWidthClass(width: ModalWidth): string {
28
+ switch (width) {
29
+ case 'small': {
30
+ return 'w-72 md:w-72';
31
+ }
32
+ case 'base': {
33
+ return 'w-72 md:w-[50rem]';
34
+ }
35
+ case 'large': {
36
+ return 'w-72 md:w-[80rem]';
37
+ }
38
+ default: {
39
+ throw new Error(`Unknown modal width: ${width as string}`);
40
+ }
41
+ }
42
+ }
43
+
44
+ function Modal({
45
+ className,
46
+ isOpen,
47
+ onClose,
48
+ children,
49
+ width = 'base',
50
+ }: Props): ReactElement {
51
+ return (
52
+ <Transition show={isOpen} as={Fragment}>
53
+ <Dialog open={isOpen} onClose={onClose} className="relative z-50">
54
+ <TransitionChild
55
+ as={Fragment}
56
+ enter="ease-out duration-300"
57
+ enterFrom="opacity-0"
58
+ enterTo="opacity-100"
59
+ leave="ease-in duration-200"
60
+ leaveFrom="opacity-100"
61
+ leaveTo="opacity-0"
62
+ >
63
+ <div className="fixed inset-0 bg-black/30" aria-hidden="true" />
64
+ </TransitionChild>
65
+ <div className="fixed inset-0 flex items-center justify-center p-4">
66
+ <TransitionChild
67
+ as={Fragment}
68
+ enter="ease-out duration-300"
69
+ enterFrom="opacity-0 scale-95"
70
+ enterTo="opacity-100 scale-100"
71
+ leave="ease-in duration-200"
72
+ leaveFrom="opacity-100 scale-100"
73
+ leaveTo="opacity-0 scale-95"
74
+ >
75
+ <DialogPanel
76
+ className={clsx(
77
+ 'max-h-full overflow-y-auto rounded-lg bg-white shadow md:max-w-7xl',
78
+ getModalWidthClass(width),
79
+ className,
80
+ )}
81
+ >
82
+ {children}
83
+ </DialogPanel>
84
+ </TransitionChild>
85
+ </div>
86
+ </Dialog>
87
+ </Transition>
88
+ );
89
+ }
90
+
91
+ interface ModalHeaderProps {
92
+ className?: string;
93
+ children: React.ReactNode;
94
+ onClose?: () => void;
95
+ }
96
+
97
+ Modal.Header = function ModalHeader({
98
+ className,
99
+ children,
100
+ onClose,
101
+ }: ModalHeaderProps): ReactElement {
102
+ return (
103
+ <div
104
+ className={clsx(
105
+ 'flex items-start justify-between rounded-t px-4 pt-4',
106
+ className,
107
+ )}
108
+ >
109
+ <DialogTitle>{children}</DialogTitle>
110
+ {onClose && (
111
+ <button
112
+ type="button"
113
+ className="-m-1.5 ml-auto inline-flex items-center rounded-lg bg-transparent p-1.5 text-sm text-gray-400 hover:bg-gray-200 hover:text-gray-900"
114
+ onClick={onClose}
115
+ >
116
+ <svg
117
+ className="h-5 w-5"
118
+ fill="currentColor"
119
+ viewBox="0 0 20 20"
120
+ xmlns="http://www.w3.org/2000/svg"
121
+ >
122
+ <path
123
+ fillRule="evenodd"
124
+ d="M4.293 4.293a1 1 0 011.414 0L10 8.586l4.293-4.293a1 1 0 111.414 1.414L11.414 10l4.293 4.293a1 1 0 01-1.414 1.414L10 11.414l-4.293 4.293a1 1 0 01-1.414-1.414L8.586 10 4.293 5.707a1 1 0 010-1.414z"
125
+ clipRule="evenodd"
126
+ />
127
+ </svg>
128
+ </button>
129
+ )}
130
+ </div>
131
+ );
132
+ };
133
+
134
+ interface ModalBodyProps {
135
+ className?: string;
136
+ children: React.ReactNode;
137
+ }
138
+
139
+ Modal.Body = function ModalBody({
140
+ className,
141
+ children,
142
+ }: ModalBodyProps): ReactElement {
143
+ return <div className={clsx('p-4', className)}>{children}</div>;
144
+ };
145
+
146
+ interface ModalFooterProps {
147
+ className?: string;
148
+ children: React.ReactNode;
149
+ }
150
+
151
+ Modal.Footer = function ModalFooter({
152
+ className,
153
+ children,
154
+ }: ModalFooterProps): ReactElement {
155
+ return (
156
+ <div
157
+ className={clsx(
158
+ 'flex items-center justify-end space-x-2 rounded-b bg-gray-50 p-4',
159
+ className,
160
+ )}
161
+ >
162
+ {children}
163
+ </div>
164
+ );
165
+ };
166
+
167
+ export default Modal;
@@ -0,0 +1,32 @@
1
+ // @ts-nocheck
2
+
3
+ import type { ReactElement } from 'react';
4
+
5
+ import { useNavigate } from 'react-router-dom';
6
+
7
+ import Button from '../Button/index.js';
8
+ import Card from '../Card/index.js';
9
+
10
+ function NotFoundCard(): ReactElement {
11
+ const navigate = useNavigate();
12
+ return (
13
+ <div className="flex h-full items-center justify-center">
14
+ <Card padding className="flex flex-col items-center space-y-4">
15
+ <div className="text-8xl">404</div>
16
+ <div className="text-xl font-bold">Page Not Found</div>
17
+ <p className="text-center text-gray-600">
18
+ Sorry, we were unable to find the page you were looking for.
19
+ </p>
20
+ <Button
21
+ onClick={() => {
22
+ navigate('/');
23
+ }}
24
+ >
25
+ Back to Home
26
+ </Button>
27
+ </Card>
28
+ </div>
29
+ );
30
+ }
31
+
32
+ export default NotFoundCard;
@@ -0,0 +1,162 @@
1
+ // @ts-nocheck
2
+
3
+ import type {
4
+ FocusEventHandler,
5
+ KeyboardEventHandler,
6
+ ReactElement,
7
+ } from 'react';
8
+ import type {
9
+ ChangeHandler,
10
+ Control,
11
+ FieldPath,
12
+ FieldPathValue,
13
+ FieldValues,
14
+ RefCallBack,
15
+ UseFormRegisterReturn,
16
+ } from 'react-hook-form';
17
+
18
+ import { format, parseISO } from 'date-fns';
19
+ import { forwardRef, useMemo } from 'react';
20
+ import DatePicker from 'react-datepicker';
21
+ import { useController } from 'react-hook-form';
22
+
23
+ import FormError from '../FormError/index.js';
24
+ import FormLabel from '../FormLabel/index.js';
25
+ import TextInput from '../TextInput/index.js';
26
+
27
+ import 'react-datepicker/dist/react-datepicker.css';
28
+
29
+ interface Props {
30
+ className?: string;
31
+ onChange: (newValue?: string | null) => void;
32
+ onBlur?: () => void;
33
+ value: string | null;
34
+ showTimeSelect?: boolean;
35
+ isClearable?: boolean;
36
+ }
37
+
38
+ const DatePickerTextInput = forwardRef<
39
+ HTMLInputElement,
40
+ {
41
+ onChange?: ChangeHandler;
42
+ onClick?: () => void;
43
+ onBlur?: ChangeHandler;
44
+ onFocus?: FocusEventHandler<HTMLInputElement>;
45
+ onKeyDown?: KeyboardEventHandler<HTMLInputElement>;
46
+ value?: string;
47
+ placeholder?: string;
48
+ name?: string;
49
+ }
50
+ >(({ onChange, onBlur, name, ...rest }, ref) => (
51
+ <TextInput
52
+ register={
53
+ {
54
+ ref: ref as RefCallBack,
55
+ onChange,
56
+ onBlur,
57
+ name,
58
+ } as UseFormRegisterReturn
59
+ }
60
+ {...rest}
61
+ />
62
+ ));
63
+
64
+ DatePickerTextInput.displayName = 'DatePickerTextInput';
65
+
66
+ function ReactDatePickerInput({
67
+ className,
68
+ onChange,
69
+ onBlur,
70
+ value,
71
+ showTimeSelect,
72
+ isClearable,
73
+ }: Props): ReactElement {
74
+ const selectedDate = useMemo(() => (value ? parseISO(value) : null), [value]);
75
+ return (
76
+ <DatePicker
77
+ className={className}
78
+ onChange={(date) => {
79
+ onChange(
80
+ date &&
81
+ (showTimeSelect ? date.toISOString() : format(date, 'yyyy-MM-dd')),
82
+ );
83
+ }}
84
+ onBlur={onBlur}
85
+ selected={selectedDate}
86
+ customInput={<DatePickerTextInput />}
87
+ showTimeSelect={showTimeSelect}
88
+ timeFormat="HH:mm"
89
+ showPopperArrow
90
+ dateFormat={showTimeSelect ? 'yyyy-MM-dd HH:mm' : 'yyyy-MM-dd'}
91
+ isClearable={isClearable}
92
+ placeholderText="Select a date"
93
+ />
94
+ );
95
+ }
96
+
97
+ interface ReactDatePickerInputLabelledProps extends Props {
98
+ label?: React.ReactNode;
99
+ error?: React.ReactNode;
100
+ }
101
+
102
+ ReactDatePickerInput.Labelled = function ReactDatePickerInputLabelled({
103
+ label,
104
+ className,
105
+ error,
106
+ ...rest
107
+ }: ReactDatePickerInputLabelledProps): ReactElement {
108
+ return (
109
+ <div className={className}>
110
+ {label && <FormLabel>{label}</FormLabel>}
111
+ <ReactDatePickerInput {...rest} />
112
+ {error && <FormError>{error}</FormError>}
113
+ </div>
114
+ );
115
+ };
116
+
117
+ interface ReactDatePickerInputLabelledControllerProps<
118
+ TFieldValues extends FieldValues = FieldValues,
119
+ TFieldName extends FieldPath<TFieldValues> = FieldPath<TFieldValues>,
120
+ > extends Omit<
121
+ ReactDatePickerInputLabelledProps,
122
+ 'onChange' | 'onBlur' | 'value' | 'error'
123
+ > {
124
+ className?: string;
125
+ control: Control<TFieldValues>;
126
+ name: TFieldName;
127
+ }
128
+
129
+ ReactDatePickerInput.LabelledController =
130
+ function ReactDatePickerInputController<
131
+ TFieldValues extends FieldValues = FieldValues,
132
+ TFieldName extends FieldPath<TFieldValues> = FieldPath<TFieldValues>,
133
+ >({
134
+ name,
135
+ control,
136
+ ...rest
137
+ }: ReactDatePickerInputLabelledControllerProps<
138
+ TFieldValues,
139
+ TFieldName
140
+ >): ReactElement {
141
+ const {
142
+ field,
143
+ fieldState: { error },
144
+ } = useController({
145
+ name,
146
+ control,
147
+ });
148
+
149
+ return (
150
+ <ReactDatePickerInput.Labelled
151
+ {...rest}
152
+ error={error?.message}
153
+ onChange={(val) => {
154
+ field.onChange(val as FieldPathValue<TFieldValues, TFieldName>);
155
+ }}
156
+ onBlur={field.onBlur}
157
+ value={field.value as string}
158
+ />
159
+ );
160
+ };
161
+
162
+ export default ReactDatePickerInput;