hazo_auth 1.4.2 → 1.6.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 (320) hide show
  1. package/SETUP_CHECKLIST.md +708 -0
  2. package/dist/app/api/hazo_auth/change_password/route.d.ts +8 -0
  3. package/dist/app/api/hazo_auth/change_password/route.d.ts.map +1 -0
  4. package/dist/app/api/hazo_auth/change_password/route.js +98 -0
  5. package/dist/app/api/hazo_auth/forgot_password/route.d.ts +8 -0
  6. package/dist/app/api/hazo_auth/forgot_password/route.d.ts.map +1 -0
  7. package/dist/app/api/hazo_auth/forgot_password/route.js +78 -0
  8. package/dist/app/api/hazo_auth/get_auth/route.d.ts +10 -0
  9. package/dist/app/api/hazo_auth/get_auth/route.d.ts.map +1 -0
  10. package/dist/app/api/hazo_auth/get_auth/route.js +63 -0
  11. package/dist/app/api/hazo_auth/invalidate_cache/route.d.ts +14 -0
  12. package/dist/app/api/hazo_auth/invalidate_cache/route.d.ts.map +1 -0
  13. package/dist/app/api/hazo_auth/invalidate_cache/route.js +96 -0
  14. package/dist/app/api/hazo_auth/library_photos/route.d.ts +13 -0
  15. package/dist/app/api/hazo_auth/library_photos/route.d.ts.map +1 -0
  16. package/dist/app/api/hazo_auth/library_photos/route.js +55 -0
  17. package/dist/app/api/hazo_auth/login/route.d.ts +12 -0
  18. package/dist/app/api/hazo_auth/login/route.d.ts.map +1 -0
  19. package/dist/app/api/hazo_auth/login/route.js +140 -0
  20. package/dist/app/api/hazo_auth/logout/route.d.ts +8 -0
  21. package/dist/app/api/hazo_auth/logout/route.d.ts.map +1 -0
  22. package/dist/app/api/hazo_auth/logout/route.js +71 -0
  23. package/dist/app/api/hazo_auth/me/route.d.ts +3 -0
  24. package/dist/app/api/hazo_auth/me/route.d.ts.map +1 -0
  25. package/dist/app/api/hazo_auth/me/route.js +34 -0
  26. package/dist/app/api/hazo_auth/profile_picture/[filename]/route.d.ts +7 -0
  27. package/dist/app/api/hazo_auth/profile_picture/[filename]/route.d.ts.map +1 -0
  28. package/dist/app/api/hazo_auth/profile_picture/[filename]/route.js +43 -0
  29. package/dist/app/api/hazo_auth/register/route.d.ts +9 -0
  30. package/dist/app/api/hazo_auth/register/route.d.ts.map +1 -0
  31. package/dist/app/api/hazo_auth/register/route.js +80 -0
  32. package/dist/app/api/hazo_auth/remove_profile_picture/route.d.ts +8 -0
  33. package/dist/app/api/hazo_auth/remove_profile_picture/route.d.ts.map +1 -0
  34. package/dist/app/api/hazo_auth/remove_profile_picture/route.js +64 -0
  35. package/dist/app/api/hazo_auth/resend_verification/route.d.ts +8 -0
  36. package/dist/app/api/hazo_auth/resend_verification/route.d.ts.map +1 -0
  37. package/dist/app/api/hazo_auth/resend_verification/route.js +79 -0
  38. package/dist/app/api/hazo_auth/reset_password/route.d.ts +8 -0
  39. package/dist/app/api/hazo_auth/reset_password/route.d.ts.map +1 -0
  40. package/dist/app/api/hazo_auth/reset_password/route.js +76 -0
  41. package/dist/app/api/hazo_auth/update_user/route.d.ts +9 -0
  42. package/dist/app/api/hazo_auth/update_user/route.d.ts.map +1 -0
  43. package/dist/app/api/hazo_auth/update_user/route.js +95 -0
  44. package/dist/app/api/hazo_auth/upload_profile_picture/route.d.ts +9 -0
  45. package/dist/app/api/hazo_auth/upload_profile_picture/route.d.ts.map +1 -0
  46. package/dist/app/api/hazo_auth/upload_profile_picture/route.js +204 -0
  47. package/dist/app/api/hazo_auth/validate_reset_token/route.d.ts +6 -0
  48. package/dist/app/api/hazo_auth/validate_reset_token/route.d.ts.map +1 -0
  49. package/dist/app/api/hazo_auth/validate_reset_token/route.js +58 -0
  50. package/dist/app/api/hazo_auth/verify_email/route.d.ts +11 -0
  51. package/dist/app/api/hazo_auth/verify_email/route.d.ts.map +1 -0
  52. package/dist/app/api/hazo_auth/verify_email/route.js +63 -0
  53. package/dist/cli/generate.d.ts +2 -0
  54. package/dist/cli/generate.d.ts.map +1 -0
  55. package/dist/cli/generate.js +117 -0
  56. package/dist/cli/index.d.ts +3 -0
  57. package/dist/cli/index.d.ts.map +1 -0
  58. package/dist/cli/index.js +120 -0
  59. package/dist/cli/validate.d.ts +15 -0
  60. package/dist/cli/validate.d.ts.map +1 -0
  61. package/dist/cli/validate.js +509 -0
  62. package/dist/components/ui/card.d.ts +9 -0
  63. package/dist/components/ui/card.d.ts.map +1 -0
  64. package/dist/components/ui/card.js +45 -0
  65. package/dist/hooks/use-mobile.d.ts.map +1 -1
  66. package/dist/hooks/use-mobile.js +17 -3
  67. package/dist/server/routes/change_password.d.ts +2 -0
  68. package/dist/server/routes/change_password.d.ts.map +1 -0
  69. package/dist/server/routes/change_password.js +2 -0
  70. package/dist/server/routes/forgot_password.d.ts +2 -0
  71. package/dist/server/routes/forgot_password.d.ts.map +1 -0
  72. package/dist/server/routes/forgot_password.js +2 -0
  73. package/dist/server/routes/get_auth.d.ts +2 -0
  74. package/dist/server/routes/get_auth.d.ts.map +1 -0
  75. package/dist/server/routes/get_auth.js +2 -0
  76. package/dist/server/routes/index.d.ts +18 -0
  77. package/dist/server/routes/index.d.ts.map +1 -0
  78. package/dist/server/routes/index.js +24 -0
  79. package/dist/server/routes/invalidate_cache.d.ts +2 -0
  80. package/dist/server/routes/invalidate_cache.d.ts.map +1 -0
  81. package/dist/server/routes/invalidate_cache.js +2 -0
  82. package/dist/server/routes/library_photos.d.ts +2 -0
  83. package/dist/server/routes/library_photos.d.ts.map +1 -0
  84. package/dist/server/routes/library_photos.js +2 -0
  85. package/dist/server/routes/login.d.ts +2 -0
  86. package/dist/server/routes/login.d.ts.map +1 -0
  87. package/dist/server/routes/login.js +2 -0
  88. package/dist/server/routes/logout.d.ts +2 -0
  89. package/dist/server/routes/logout.d.ts.map +1 -0
  90. package/dist/server/routes/logout.js +2 -0
  91. package/dist/server/routes/me.d.ts +2 -0
  92. package/dist/server/routes/me.d.ts.map +1 -0
  93. package/dist/server/routes/me.js +2 -0
  94. package/dist/server/routes/profile_picture_filename.d.ts +2 -0
  95. package/dist/server/routes/profile_picture_filename.d.ts.map +1 -0
  96. package/dist/server/routes/profile_picture_filename.js +3 -0
  97. package/dist/server/routes/register.d.ts +2 -0
  98. package/dist/server/routes/register.d.ts.map +1 -0
  99. package/dist/server/routes/register.js +2 -0
  100. package/dist/server/routes/remove_profile_picture.d.ts +2 -0
  101. package/dist/server/routes/remove_profile_picture.d.ts.map +1 -0
  102. package/dist/server/routes/remove_profile_picture.js +2 -0
  103. package/dist/server/routes/resend_verification.d.ts +2 -0
  104. package/dist/server/routes/resend_verification.d.ts.map +1 -0
  105. package/dist/server/routes/resend_verification.js +2 -0
  106. package/dist/server/routes/reset_password.d.ts +2 -0
  107. package/dist/server/routes/reset_password.d.ts.map +1 -0
  108. package/dist/server/routes/reset_password.js +2 -0
  109. package/dist/server/routes/update_user.d.ts +2 -0
  110. package/dist/server/routes/update_user.d.ts.map +1 -0
  111. package/dist/server/routes/update_user.js +2 -0
  112. package/dist/server/routes/upload_profile_picture.d.ts +2 -0
  113. package/dist/server/routes/upload_profile_picture.d.ts.map +1 -0
  114. package/dist/server/routes/upload_profile_picture.js +2 -0
  115. package/dist/server/routes/validate_reset_token.d.ts +2 -0
  116. package/dist/server/routes/validate_reset_token.d.ts.map +1 -0
  117. package/dist/server/routes/validate_reset_token.js +2 -0
  118. package/dist/server/routes/verify_email.d.ts +2 -0
  119. package/dist/server/routes/verify_email.d.ts.map +1 -0
  120. package/dist/server/routes/verify_email.js +2 -0
  121. package/package.json +12 -17
  122. package/components.json +0 -22
  123. package/instrumentation.ts +0 -32
  124. package/migrations/001_add_token_type_to_refresh_tokens.sql +0 -14
  125. package/migrations/002_add_name_to_hazo_users.sql +0 -7
  126. package/migrations/003_add_url_on_logon_to_hazo_users.sql +0 -8
  127. package/next.config.mjs +0 -67
  128. package/postcss.config.mjs +0 -8
  129. package/public/file.svg +0 -1
  130. package/public/globe.svg +0 -1
  131. package/public/next.svg +0 -1
  132. package/public/vercel.svg +0 -1
  133. package/public/window.svg +0 -1
  134. package/scripts/apply_migration.ts +0 -118
  135. package/scripts/init_users.ts +0 -378
  136. package/src/app/api/hazo_auth/auth/upload_profile_picture/route.ts +0 -268
  137. package/src/app/api/hazo_auth/change_password/route.ts +0 -132
  138. package/src/app/api/hazo_auth/forgot_password/route.ts +0 -107
  139. package/src/app/api/hazo_auth/get_auth/route.ts +0 -89
  140. package/src/app/api/hazo_auth/invalidate_cache/route.ts +0 -139
  141. package/src/app/api/hazo_auth/library_photos/route.ts +0 -73
  142. package/src/app/api/hazo_auth/login/route.ts +0 -181
  143. package/src/app/api/hazo_auth/logout/route.ts +0 -89
  144. package/src/app/api/hazo_auth/me/route.ts +0 -47
  145. package/src/app/api/hazo_auth/profile_picture/[filename]/route.ts +0 -67
  146. package/src/app/api/hazo_auth/register/route.ts +0 -109
  147. package/src/app/api/hazo_auth/remove_profile_picture/route.ts +0 -86
  148. package/src/app/api/hazo_auth/resend_verification/route.ts +0 -108
  149. package/src/app/api/hazo_auth/reset_password/route.ts +0 -107
  150. package/src/app/api/hazo_auth/update_user/route.ts +0 -126
  151. package/src/app/api/hazo_auth/upload_profile_picture/route.ts +0 -268
  152. package/src/app/api/hazo_auth/user_management/permissions/route.ts +0 -367
  153. package/src/app/api/hazo_auth/user_management/roles/route.ts +0 -442
  154. package/src/app/api/hazo_auth/user_management/users/roles/route.ts +0 -367
  155. package/src/app/api/hazo_auth/user_management/users/route.ts +0 -239
  156. package/src/app/api/hazo_auth/validate_reset_token/route.ts +0 -83
  157. package/src/app/api/hazo_auth/verify_email/route.ts +0 -88
  158. package/src/app/api/migrations/apply/route.ts +0 -91
  159. package/src/app/favicon.ico +0 -0
  160. package/src/app/fonts/GeistMonoVF.woff +0 -0
  161. package/src/app/fonts/GeistVF.woff +0 -0
  162. package/src/app/globals.css +0 -89
  163. package/src/app/hazo_auth/forgot_password/forgot_password_page_client.tsx +0 -60
  164. package/src/app/hazo_auth/forgot_password/page.tsx +0 -24
  165. package/src/app/hazo_auth/login/login_page_client.tsx +0 -86
  166. package/src/app/hazo_auth/login/page.tsx +0 -38
  167. package/src/app/hazo_auth/my_settings/my_settings_page_client.tsx +0 -120
  168. package/src/app/hazo_auth/my_settings/page.tsx +0 -40
  169. package/src/app/hazo_auth/register/page.tsx +0 -36
  170. package/src/app/hazo_auth/register/register_page_client.tsx +0 -81
  171. package/src/app/hazo_auth/reset_password/page.tsx +0 -29
  172. package/src/app/hazo_auth/reset_password/reset_password_page_client.tsx +0 -81
  173. package/src/app/hazo_auth/user_management/page.tsx +0 -14
  174. package/src/app/hazo_auth/user_management/user_management_page_client.tsx +0 -16
  175. package/src/app/hazo_auth/verify_email/page.tsx +0 -24
  176. package/src/app/hazo_auth/verify_email/verify_email_page_client.tsx +0 -60
  177. package/src/app/hazo_connect/api/sqlite/data/route.ts +0 -203
  178. package/src/app/hazo_connect/api/sqlite/schema/route.ts +0 -45
  179. package/src/app/hazo_connect/api/sqlite/tables/route.ts +0 -36
  180. package/src/app/hazo_connect/sqlite_admin/page.tsx +0 -51
  181. package/src/app/hazo_connect/sqlite_admin/sqlite-admin-client.tsx +0 -984
  182. package/src/app/layout.tsx +0 -43
  183. package/src/app/page.tsx +0 -170
  184. package/src/components/index.ts +0 -7
  185. package/src/components/layouts/email_verification/config/email_verification_field_config.ts +0 -86
  186. package/src/components/layouts/email_verification/hooks/use_email_verification.ts +0 -297
  187. package/src/components/layouts/email_verification/index.tsx +0 -297
  188. package/src/components/layouts/forgot_password/config/forgot_password_field_config.ts +0 -58
  189. package/src/components/layouts/forgot_password/hooks/use_forgot_password_form.ts +0 -179
  190. package/src/components/layouts/forgot_password/index.tsx +0 -168
  191. package/src/components/layouts/index.ts +0 -26
  192. package/src/components/layouts/login/config/login_field_config.ts +0 -67
  193. package/src/components/layouts/login/hooks/use_login_form.ts +0 -286
  194. package/src/components/layouts/login/index.tsx +0 -252
  195. package/src/components/layouts/my_settings/components/editable_field.tsx +0 -177
  196. package/src/components/layouts/my_settings/components/password_change_dialog.tsx +0 -301
  197. package/src/components/layouts/my_settings/components/profile_picture_dialog.tsx +0 -385
  198. package/src/components/layouts/my_settings/components/profile_picture_display.tsx +0 -66
  199. package/src/components/layouts/my_settings/components/profile_picture_gravatar_tab.tsx +0 -143
  200. package/src/components/layouts/my_settings/components/profile_picture_library_tab.tsx +0 -311
  201. package/src/components/layouts/my_settings/components/profile_picture_upload_tab.tsx +0 -341
  202. package/src/components/layouts/my_settings/config/my_settings_field_config.ts +0 -61
  203. package/src/components/layouts/my_settings/hooks/use_my_settings.ts +0 -458
  204. package/src/components/layouts/my_settings/index.tsx +0 -351
  205. package/src/components/layouts/register/config/register_field_config.ts +0 -101
  206. package/src/components/layouts/register/hooks/use_register_form.ts +0 -275
  207. package/src/components/layouts/register/index.tsx +0 -226
  208. package/src/components/layouts/reset_password/config/reset_password_field_config.ts +0 -86
  209. package/src/components/layouts/reset_password/hooks/use_reset_password_form.ts +0 -276
  210. package/src/components/layouts/reset_password/index.tsx +0 -294
  211. package/src/components/layouts/shared/components/already_logged_in_guard.tsx +0 -95
  212. package/src/components/layouts/shared/components/auth_page_shell.tsx +0 -36
  213. package/src/components/layouts/shared/components/field_error_message.tsx +0 -29
  214. package/src/components/layouts/shared/components/form_action_buttons.tsx +0 -64
  215. package/src/components/layouts/shared/components/form_field_wrapper.tsx +0 -44
  216. package/src/components/layouts/shared/components/form_header.tsx +0 -36
  217. package/src/components/layouts/shared/components/logout_button.tsx +0 -76
  218. package/src/components/layouts/shared/components/password_field.tsx +0 -72
  219. package/src/components/layouts/shared/components/profile_pic_menu.tsx +0 -321
  220. package/src/components/layouts/shared/components/profile_pic_menu_wrapper.tsx +0 -40
  221. package/src/components/layouts/shared/components/sidebar_layout_wrapper.tsx +0 -214
  222. package/src/components/layouts/shared/components/standalone_layout_wrapper.tsx +0 -53
  223. package/src/components/layouts/shared/components/two_column_auth_layout.tsx +0 -44
  224. package/src/components/layouts/shared/components/unauthorized_guard.tsx +0 -78
  225. package/src/components/layouts/shared/components/visual_panel.tsx +0 -41
  226. package/src/components/layouts/shared/config/layout_customization.ts +0 -95
  227. package/src/components/layouts/shared/data/layout_data_client.ts +0 -19
  228. package/src/components/layouts/shared/hooks/use_auth_status.ts +0 -103
  229. package/src/components/layouts/shared/hooks/use_hazo_auth.ts +0 -158
  230. package/src/components/layouts/shared/index.ts +0 -34
  231. package/src/components/layouts/shared/utils/ip_address.ts +0 -37
  232. package/src/components/layouts/shared/utils/validation.ts +0 -66
  233. package/src/components/layouts/user_management/components/roles_matrix.tsx +0 -607
  234. package/src/components/layouts/user_management/index.tsx +0 -1295
  235. package/src/components/ui/alert-dialog.tsx +0 -141
  236. package/src/components/ui/avatar.tsx +0 -50
  237. package/src/components/ui/button.tsx +0 -57
  238. package/src/components/ui/checkbox.tsx +0 -30
  239. package/src/components/ui/dialog.tsx +0 -122
  240. package/src/components/ui/dropdown-menu.tsx +0 -201
  241. package/src/components/ui/hazo_ui_tooltip.tsx +0 -67
  242. package/src/components/ui/index.ts +0 -22
  243. package/src/components/ui/input.tsx +0 -22
  244. package/src/components/ui/label.tsx +0 -26
  245. package/src/components/ui/separator.tsx +0 -31
  246. package/src/components/ui/sheet.tsx +0 -139
  247. package/src/components/ui/sidebar.tsx +0 -773
  248. package/src/components/ui/skeleton.tsx +0 -15
  249. package/src/components/ui/sonner.tsx +0 -31
  250. package/src/components/ui/switch.tsx +0 -29
  251. package/src/components/ui/table.tsx +0 -120
  252. package/src/components/ui/tabs.tsx +0 -55
  253. package/src/components/ui/tooltip.tsx +0 -32
  254. package/src/components/ui/vertical-tabs.tsx +0 -59
  255. package/src/hooks/use-mobile.tsx +0 -19
  256. package/src/index.ts +0 -7
  257. package/src/lib/already_logged_in_config.server.ts +0 -46
  258. package/src/lib/app_logger.ts +0 -24
  259. package/src/lib/auth/auth_cache.ts +0 -220
  260. package/src/lib/auth/auth_rate_limiter.ts +0 -121
  261. package/src/lib/auth/auth_types.ts +0 -65
  262. package/src/lib/auth/auth_utils.server.ts +0 -196
  263. package/src/lib/auth/hazo_get_auth.server.ts +0 -333
  264. package/src/lib/auth/index.ts +0 -23
  265. package/src/lib/auth/server_auth.ts +0 -88
  266. package/src/lib/auth_utility_config.server.ts +0 -136
  267. package/src/lib/config/config_loader.server.ts +0 -164
  268. package/src/lib/email_verification_config.server.ts +0 -32
  269. package/src/lib/file_types_config.server.ts +0 -25
  270. package/src/lib/forgot_password_config.server.ts +0 -32
  271. package/src/lib/hazo_connect_instance.server.ts +0 -101
  272. package/src/lib/hazo_connect_setup.server.ts +0 -194
  273. package/src/lib/hazo_connect_setup.ts +0 -54
  274. package/src/lib/index.ts +0 -44
  275. package/src/lib/login_config.server.ts +0 -71
  276. package/src/lib/messages_config.server.ts +0 -45
  277. package/src/lib/migrations/apply_migration.ts +0 -105
  278. package/src/lib/my_settings_config.server.ts +0 -135
  279. package/src/lib/password_requirements_config.server.ts +0 -39
  280. package/src/lib/profile_pic_menu_config.server.ts +0 -138
  281. package/src/lib/profile_picture_config.server.ts +0 -56
  282. package/src/lib/register_config.server.ts +0 -73
  283. package/src/lib/reset_password_config.server.ts +0 -75
  284. package/src/lib/services/email_service.ts +0 -581
  285. package/src/lib/services/email_verification_service.ts +0 -270
  286. package/src/lib/services/index.ts +0 -15
  287. package/src/lib/services/login_service.ts +0 -134
  288. package/src/lib/services/password_change_service.ts +0 -154
  289. package/src/lib/services/password_reset_service.ts +0 -405
  290. package/src/lib/services/profile_picture_remove_service.ts +0 -120
  291. package/src/lib/services/profile_picture_service.ts +0 -215
  292. package/src/lib/services/profile_picture_source_mapper.ts +0 -62
  293. package/src/lib/services/registration_service.ts +0 -184
  294. package/src/lib/services/token_service.ts +0 -240
  295. package/src/lib/services/user_profiles_service.ts +0 -143
  296. package/src/lib/services/user_update_service.ts +0 -141
  297. package/src/lib/ui_shell_config.server.ts +0 -73
  298. package/src/lib/ui_sizes_config.server.ts +0 -37
  299. package/src/lib/user_fields_config.server.ts +0 -31
  300. package/src/lib/user_management_config.server.ts +0 -39
  301. package/src/lib/utils/api_route_helpers.ts +0 -60
  302. package/src/lib/utils/error_sanitizer.ts +0 -75
  303. package/src/lib/utils.ts +0 -11
  304. package/src/middleware.ts +0 -94
  305. package/src/routes/index.ts +0 -34
  306. package/src/server/config/config_loader.ts +0 -496
  307. package/src/server/index.ts +0 -38
  308. package/src/server/logging/logger_service.ts +0 -56
  309. package/src/server/routes/root_router.ts +0 -16
  310. package/src/server/server.ts +0 -28
  311. package/src/server/types/app_types.ts +0 -74
  312. package/src/server/types/express.d.ts +0 -16
  313. package/src/stories/email_verification_layout.stories.tsx +0 -137
  314. package/src/stories/forgot_password_layout.stories.tsx +0 -85
  315. package/src/stories/login_layout.stories.tsx +0 -85
  316. package/src/stories/project_overview.stories.tsx +0 -33
  317. package/src/stories/register_layout.stories.tsx +0 -107
  318. package/tailwind.config.ts +0 -77
  319. package/tsconfig.build.json +0 -36
  320. package/tsconfig.json +0 -28
@@ -1,351 +0,0 @@
1
- // file_description: my settings layout component with tabs for profile and security settings
2
- // section: client_directive
3
- "use client";
4
-
5
- // section: imports
6
- import { Button } from "../../ui/button";
7
- import { EditableField } from "./components/editable_field";
8
- import { ProfilePictureDisplay } from "./components/profile_picture_display";
9
- import { ProfilePictureDialog } from "./components/profile_picture_dialog";
10
- import { UnauthorizedGuard } from "../shared/components/unauthorized_guard";
11
- import { use_my_settings } from "./hooks/use_my_settings";
12
- import {
13
- resolveMySettingsLabels,
14
- resolveMySettingsButtonPalette,
15
- type MySettingsLabelOverrides,
16
- } from "./config/my_settings_field_config";
17
- import type {
18
- PasswordRequirementOptions,
19
- ButtonPaletteOverrides,
20
- } from "../shared/config/layout_customization";
21
- import { formatDistanceToNow } from "date-fns";
22
- import { PasswordField } from "../shared/components/password_field";
23
- import { FormFieldWrapper } from "../shared/components/form_field_wrapper";
24
- import { Pencil, Trash2 } from "lucide-react";
25
-
26
- // section: types
27
- export type MySettingsLayoutProps = {
28
- labels?: MySettingsLabelOverrides;
29
- button_colors?: ButtonPaletteOverrides;
30
- password_requirements: PasswordRequirementOptions;
31
- profilePicture: {
32
- allow_photo_upload: boolean;
33
- upload_photo_path?: string;
34
- max_photo_size: number;
35
- user_photo_default: boolean;
36
- user_photo_default_priority1: "gravatar" | "library";
37
- user_photo_default_priority2?: "library" | "gravatar";
38
- library_photo_path: string;
39
- };
40
- userFields: {
41
- show_name_field: boolean;
42
- show_email_field: boolean;
43
- show_password_field: boolean;
44
- };
45
- unauthorizedMessage?: string;
46
- loginButtonLabel?: string;
47
- loginPath?: string;
48
- heading?: string;
49
- subHeading?: string;
50
- profilePhotoLabel?: string;
51
- profilePhotoRecommendation?: string;
52
- uploadPhotoButtonLabel?: string;
53
- removePhotoButtonLabel?: string;
54
- profileInformationLabel?: string;
55
- passwordLabel?: string;
56
- currentPasswordLabel?: string;
57
- newPasswordLabel?: string;
58
- confirmPasswordLabel?: string;
59
- messages: {
60
- photo_upload_disabled_message: string;
61
- gravatar_setup_message: string;
62
- gravatar_no_account_message: string;
63
- library_tooltip_message: string;
64
- };
65
- uiSizes: {
66
- gravatar_size: number;
67
- profile_picture_size: number;
68
- tooltip_icon_size_default: number;
69
- tooltip_icon_size_small: number;
70
- library_photo_grid_columns: number;
71
- library_photo_preview_size: number;
72
- image_compression_max_dimension: number;
73
- upload_file_hard_limit_bytes: number;
74
- };
75
- fileTypes: {
76
- allowed_image_extensions: string[];
77
- allowed_image_mime_types: string[];
78
- };
79
- };
80
-
81
- // section: component
82
- /**
83
- * My Settings layout component with tabs for profile and security settings
84
- * Shows editable fields for name, email, and password change dialog
85
- * Displays profile picture and last logged in information
86
- * @param props - Component props including labels, button colors, password requirements, etc.
87
- * @returns My settings layout component
88
- */
89
- export default function my_settings_layout({
90
- labels,
91
- button_colors,
92
- password_requirements,
93
- profilePicture,
94
- userFields,
95
- unauthorizedMessage = "You must be logged in to access this page.",
96
- loginButtonLabel = "Go to login",
97
- loginPath = "/hazo_auth/login",
98
- heading = "Account Settings",
99
- subHeading = "Manage your profile, password, and email preferences.",
100
- profilePhotoLabel = "Profile Photo",
101
- profilePhotoRecommendation = "Recommended size: 200x200px. JPG, PNG.",
102
- uploadPhotoButtonLabel = "Upload New Photo",
103
- removePhotoButtonLabel = "Remove",
104
- profileInformationLabel = "Profile Information",
105
- passwordLabel = "Password",
106
- currentPasswordLabel = "Current Password",
107
- newPasswordLabel = "New Password",
108
- confirmPasswordLabel = "Confirm Password",
109
- messages,
110
- uiSizes,
111
- fileTypes,
112
- }: MySettingsLayoutProps) {
113
- const resolvedLabels = resolveMySettingsLabels(labels);
114
- const resolvedButtonPalette = resolveMySettingsButtonPalette(button_colors);
115
-
116
- const settings = use_my_settings({
117
- passwordRequirements: password_requirements,
118
- });
119
-
120
- return (
121
- <UnauthorizedGuard
122
- message={unauthorizedMessage}
123
- loginButtonLabel={loginButtonLabel}
124
- loginPath={loginPath}
125
- >
126
- <div className="cls_my_settings_layout flex flex-col gap-6 p-6 max-w-4xl mx-auto min-h-screen bg-slate-50">
127
- {/* Header Section */}
128
- <div className="cls_my_settings_layout_header flex flex-col gap-2">
129
- <h1 className="cls_my_settings_layout_heading text-3xl font-bold text-slate-900">
130
- {heading}
131
- </h1>
132
- <p className="cls_my_settings_layout_subheading text-slate-600">
133
- {subHeading}
134
- </p>
135
- </div>
136
-
137
- {/* Profile Photo Section */}
138
- <div className="cls_my_settings_layout_profile_photo_section bg-white rounded-lg border border-slate-200 p-6">
139
- <h2 className="cls_my_settings_layout_section_heading text-lg font-semibold text-slate-900 mb-4">
140
- {profilePhotoLabel}
141
- </h2>
142
- <div className="cls_my_settings_layout_profile_photo_content flex flex-col items-center">
143
- <div className="cls_my_settings_layout_profile_photo_display relative">
144
- <ProfilePictureDisplay
145
- profilePictureUrl={settings.profilePictureUrl}
146
- name={settings.name}
147
- email={settings.email}
148
- onEdit={settings.handleProfilePictureEdit}
149
- />
150
- <div className="cls_my_settings_layout_profile_photo_actions absolute left-0 right-0 flex items-center justify-between px-2" style={{ bottom: '-20px' }}>
151
- <Button
152
- type="button"
153
- onClick={settings.handleProfilePictureEdit}
154
- disabled={settings.loading}
155
- variant="ghost"
156
- size="icon"
157
- className="cls_my_settings_layout_upload_photo_button"
158
- aria-label={uploadPhotoButtonLabel}
159
- >
160
- <Pencil className="h-4 w-4" aria-hidden="true" />
161
- </Button>
162
- <Button
163
- type="button"
164
- onClick={settings.handleProfilePictureRemove}
165
- disabled={settings.loading || !settings.profilePictureUrl}
166
- variant="ghost"
167
- size="icon"
168
- className="cls_my_settings_layout_remove_photo_button text-red-600 hover:text-red-700 hover:bg-red-50"
169
- aria-label={removePhotoButtonLabel}
170
- >
171
- <Trash2 className="h-4 w-4" aria-hidden="true" />
172
- </Button>
173
- </div>
174
- </div>
175
- </div>
176
- </div>
177
-
178
- {/* Profile Information Section */}
179
- <div className="cls_my_settings_layout_profile_information_section bg-white rounded-lg border border-slate-200 p-6">
180
- <h2 className="cls_my_settings_layout_section_heading text-lg font-semibold text-slate-900 mb-4">
181
- {profileInformationLabel}
182
- </h2>
183
- <div className="cls_my_settings_layout_profile_information_fields grid grid-cols-1 md:grid-cols-2 gap-6">
184
- {/* Name Field */}
185
- {userFields.show_name_field && (
186
- <EditableField
187
- label="Full Name"
188
- value={settings.name}
189
- type="text"
190
- placeholder="Enter your full name"
191
- onSave={settings.handleNameSave}
192
- validation={validateName}
193
- disabled={settings.loading}
194
- ariaLabel="Full name input field"
195
- />
196
- )}
197
-
198
- {/* Email Field */}
199
- {userFields.show_email_field && (
200
- <EditableField
201
- label="Email Address"
202
- value={settings.email}
203
- type="email"
204
- placeholder="Enter your email address"
205
- onSave={settings.handleEmailSave}
206
- validation={validateEmail}
207
- disabled={settings.loading}
208
- ariaLabel="Email address input field"
209
- />
210
- )}
211
- </div>
212
- </div>
213
-
214
- {/* Password Section */}
215
- {userFields.show_password_field && (
216
- <div className="cls_my_settings_layout_password_section bg-white rounded-lg border border-slate-200 p-6">
217
- <h2 className="cls_my_settings_layout_section_heading text-lg font-semibold text-slate-900 mb-4">
218
- {passwordLabel}
219
- </h2>
220
- <div className="cls_my_settings_layout_password_fields flex flex-col gap-6">
221
- {/* Current Password Field - Full Width */}
222
- <FormFieldWrapper
223
- fieldId="current-password"
224
- label={currentPasswordLabel}
225
- input={
226
- <PasswordField
227
- inputId="current-password"
228
- ariaLabel={currentPasswordLabel}
229
- value={settings.passwordFields?.currentPassword || ""}
230
- placeholder="Enter your current password"
231
- autoComplete="current-password"
232
- isVisible={settings.passwordFields?.currentPasswordVisible || false}
233
- onChange={(value) => settings.handlePasswordFieldChange("currentPassword", value)}
234
- onToggleVisibility={() => settings.togglePasswordVisibility("currentPassword")}
235
- errorMessage={settings.passwordFields?.errors?.currentPassword}
236
- />
237
- }
238
- />
239
-
240
- {/* New Password and Confirm Password Fields - Side by Side */}
241
- <div className="cls_my_settings_layout_password_fields_row grid grid-cols-1 md:grid-cols-2 gap-6">
242
- {/* New Password Field */}
243
- <FormFieldWrapper
244
- fieldId="new-password"
245
- label={newPasswordLabel}
246
- input={
247
- <PasswordField
248
- inputId="new-password"
249
- ariaLabel={newPasswordLabel}
250
- value={settings.passwordFields?.newPassword || ""}
251
- placeholder="Enter your new password"
252
- autoComplete="new-password"
253
- isVisible={settings.passwordFields?.newPasswordVisible || false}
254
- onChange={(value) => settings.handlePasswordFieldChange("newPassword", value)}
255
- onToggleVisibility={() => settings.togglePasswordVisibility("newPassword")}
256
- errorMessage={settings.passwordFields?.errors?.newPassword}
257
- />
258
- }
259
- />
260
-
261
- {/* Confirm Password Field */}
262
- <FormFieldWrapper
263
- fieldId="confirm-password"
264
- label={confirmPasswordLabel}
265
- input={
266
- <PasswordField
267
- inputId="confirm-password"
268
- ariaLabel={confirmPasswordLabel}
269
- value={settings.passwordFields?.confirmPassword || ""}
270
- placeholder="Confirm your new password"
271
- autoComplete="new-password"
272
- isVisible={settings.passwordFields?.confirmPasswordVisible || false}
273
- onChange={(value) => settings.handlePasswordFieldChange("confirmPassword", value)}
274
- onToggleVisibility={() => settings.togglePasswordVisibility("confirmPassword")}
275
- errorMessage={settings.passwordFields?.errors?.confirmPassword}
276
- />
277
- }
278
- />
279
- </div>
280
- </div>
281
- {/* Save Password Button */}
282
- <div className="cls_my_settings_layout_password_actions flex justify-end mt-4">
283
- <Button
284
- type="button"
285
- onClick={settings.handlePasswordSave}
286
- disabled={settings.loading || settings.isPasswordSaveDisabled}
287
- className="cls_my_settings_layout_save_password_button"
288
- style={{
289
- backgroundColor: resolvedButtonPalette.submitBackground,
290
- color: resolvedButtonPalette.submitText,
291
- }}
292
- aria-label="Save password"
293
- >
294
- Save Password
295
- </Button>
296
- </div>
297
- </div>
298
- )}
299
-
300
- {/* Profile Picture Dialog */}
301
- <ProfilePictureDialog
302
- open={settings.profilePictureDialogOpen}
303
- onOpenChange={(open) => {
304
- if (open) {
305
- settings.handleProfilePictureEdit();
306
- } else {
307
- settings.handleProfilePictureDialogClose();
308
- }
309
- }}
310
- onSave={settings.handleProfilePictureSave}
311
- email={settings.email}
312
- allowPhotoUpload={profilePicture.allow_photo_upload}
313
- maxPhotoSize={profilePicture.max_photo_size}
314
- libraryPhotoPath={profilePicture.library_photo_path}
315
- currentProfilePictureUrl={settings.profilePictureUrl}
316
- currentProfileSource={settings.profileSource}
317
- disabled={settings.loading}
318
- messages={messages}
319
- uiSizes={uiSizes}
320
- fileTypes={fileTypes}
321
- />
322
- </div>
323
- </UnauthorizedGuard>
324
- );
325
- }
326
-
327
- // section: validation_helpers
328
- /**
329
- * Validates name (optional, but if provided should not be empty)
330
- */
331
- function validateName(name: string): string | null {
332
- if (name.trim() === "") {
333
- return "Name cannot be empty";
334
- }
335
- return null;
336
- }
337
-
338
- /**
339
- * Validates email format
340
- */
341
- function validateEmail(email: string): string | null {
342
- if (!email || email.trim() === "") {
343
- return "Email is required";
344
- }
345
- const emailRegex = /^[^\s@]+@[^\s@]+\.[^\s@]+$/;
346
- if (!emailRegex.test(email)) {
347
- return "Invalid email address format";
348
- }
349
- return null;
350
- }
351
-
@@ -1,101 +0,0 @@
1
- // file_description: register layout specific configuration helpers
2
- // section: imports
3
- import type { LayoutFieldMap, LayoutFieldMapOverrides } from "../../shared/config/layout_customization";
4
- import {
5
- resolveButtonPalette,
6
- resolveFieldDefinitions,
7
- resolveLabels,
8
- resolvePasswordRequirements,
9
- type ButtonPaletteDefaults,
10
- type ButtonPaletteOverrides,
11
- type LayoutLabelDefaults,
12
- type LayoutLabelOverrides,
13
- type PasswordRequirementOptions,
14
- type PasswordRequirementOverrides,
15
- } from "../../shared/config/layout_customization";
16
-
17
- // section: field_identifiers
18
- export const REGISTER_FIELD_IDS = {
19
- NAME: "name",
20
- EMAIL: "email_address",
21
- PASSWORD: "password",
22
- CONFIRM_PASSWORD: "confirm_password",
23
- } as const;
24
-
25
- export type RegisterFieldId = (typeof REGISTER_FIELD_IDS)[keyof typeof REGISTER_FIELD_IDS];
26
-
27
- // section: field_definitions
28
- const REGISTER_FIELD_DEFINITIONS: LayoutFieldMap = {
29
- [REGISTER_FIELD_IDS.NAME]: {
30
- id: REGISTER_FIELD_IDS.NAME,
31
- label: "Full name",
32
- type: "text",
33
- autoComplete: "name",
34
- placeholder: "Enter your full name",
35
- ariaLabel: "Full name input field",
36
- },
37
- [REGISTER_FIELD_IDS.EMAIL]: {
38
- id: REGISTER_FIELD_IDS.EMAIL,
39
- label: "Email address",
40
- type: "email",
41
- autoComplete: "email",
42
- placeholder: "Enter your email address",
43
- ariaLabel: "Email address input field",
44
- },
45
- [REGISTER_FIELD_IDS.PASSWORD]: {
46
- id: REGISTER_FIELD_IDS.PASSWORD,
47
- label: "Password",
48
- type: "password",
49
- autoComplete: "new-password",
50
- placeholder: "Enter your password",
51
- ariaLabel: "Password input field",
52
- },
53
- [REGISTER_FIELD_IDS.CONFIRM_PASSWORD]: {
54
- id: REGISTER_FIELD_IDS.CONFIRM_PASSWORD,
55
- label: "Re-enter password",
56
- type: "password",
57
- autoComplete: "new-password",
58
- placeholder: "Re-enter your password",
59
- ariaLabel: "Re-enter password input field",
60
- },
61
- };
62
-
63
- export const createRegisterFieldDefinitions = (
64
- overrides?: LayoutFieldMapOverrides,
65
- ) => resolveFieldDefinitions(REGISTER_FIELD_DEFINITIONS, overrides);
66
-
67
- // section: label_defaults
68
- const REGISTER_LABEL_DEFAULTS: LayoutLabelDefaults = {
69
- heading: "Create your hazo account",
70
- subHeading: "Secure your access with editable fields powered by shadcn components.",
71
- submitButton: "Register",
72
- cancelButton: "Cancel",
73
- };
74
-
75
- export const resolveRegisterLabels = (overrides?: LayoutLabelOverrides) =>
76
- resolveLabels(REGISTER_LABEL_DEFAULTS, overrides);
77
-
78
- // section: button_palette_defaults
79
- const REGISTER_BUTTON_PALETTE_DEFAULTS: ButtonPaletteDefaults = {
80
- submitBackground: "#0f172a",
81
- submitText: "#ffffff",
82
- cancelBorder: "#cbd5f5",
83
- cancelText: "#0f172a",
84
- };
85
-
86
- export const resolveRegisterButtonPalette = (overrides?: ButtonPaletteOverrides) =>
87
- resolveButtonPalette(REGISTER_BUTTON_PALETTE_DEFAULTS, overrides);
88
-
89
- // section: password_rules
90
- const REGISTER_PASSWORD_REQUIREMENTS: PasswordRequirementOptions = {
91
- minimum_length: 8,
92
- require_uppercase: true,
93
- require_lowercase: true,
94
- require_number: true,
95
- require_special: true,
96
- };
97
-
98
- export const resolveRegisterPasswordRequirements = (
99
- overrides?: PasswordRequirementOverrides,
100
- ) => resolvePasswordRequirements(REGISTER_PASSWORD_REQUIREMENTS, overrides);
101
-