@nocios/crudify-components 2.0.38 → 2.0.44

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 (144) hide show
  1. package/coverage/coverage-final.json +88 -55
  2. package/coverage/index.html +360 -240
  3. package/dist/{CrudiaMarkdownField-CggOpcBM.d.ts → CrudiaMarkdownField-CXAuu-v2.d.ts} +6 -1
  4. package/dist/{CrudiaMarkdownField-BvJn2GL8.d.mts → CrudiaMarkdownField-TNyMLb-h.d.mts} +6 -1
  5. package/dist/chunk-2IOB6HHT.js +1 -0
  6. package/dist/chunk-2WHCDP7V.mjs +1 -0
  7. package/dist/chunk-37WOWEJG.js +1 -0
  8. package/dist/chunk-MFQKGZI4.js +1 -0
  9. package/dist/chunk-NJERBWND.mjs +1 -0
  10. package/dist/chunk-XMEZUDF6.mjs +1 -0
  11. package/dist/components.d.mts +1 -1
  12. package/dist/components.d.ts +1 -1
  13. package/dist/components.js +1 -1
  14. package/dist/components.mjs +1 -1
  15. package/dist/hooks.js +1 -1
  16. package/dist/hooks.mjs +1 -1
  17. package/dist/index.d.mts +5 -5
  18. package/dist/index.d.ts +5 -5
  19. package/dist/index.js +2 -2
  20. package/dist/index.mjs +2 -2
  21. package/package.json +2 -2
  22. package/coverage/components/CrudiaAutoGenerate.tsx.html +0 -583
  23. package/coverage/components/CrudiaFileField/CrudiaFileField.tsx.html +0 -1276
  24. package/coverage/components/CrudiaFileField/components/DeleteConfirmationDialog.tsx.html +0 -355
  25. package/coverage/components/CrudiaFileField/components/DropZone.tsx.html +0 -433
  26. package/coverage/components/CrudiaFileField/components/FileItemRow.tsx.html +0 -751
  27. package/coverage/components/CrudiaFileField/components/FileThumbnail.tsx.html +0 -1195
  28. package/coverage/components/CrudiaFileField/components/index.html +0 -176
  29. package/coverage/components/CrudiaFileField/components/index.ts.html +0 -115
  30. package/coverage/components/CrudiaFileField/hooks/index.html +0 -146
  31. package/coverage/components/CrudiaFileField/hooks/index.ts.html +0 -112
  32. package/coverage/components/CrudiaFileField/hooks/useDeleteConfirmation.ts.html +0 -421
  33. package/coverage/components/CrudiaFileField/hooks/useDragDrop.ts.html +0 -403
  34. package/coverage/components/CrudiaFileField/index.html +0 -131
  35. package/coverage/components/CrudiaFileField/index.ts.html +0 -112
  36. package/coverage/components/CrudiaFileField/utils/formatters.ts.html +0 -163
  37. package/coverage/components/CrudiaFileField/utils/icons.tsx.html +0 -253
  38. package/coverage/components/CrudiaFileField/utils/index.html +0 -131
  39. package/coverage/components/CrudiaMarkdownField.tsx.html +0 -619
  40. package/coverage/components/CrudifyLogin/Forms/CheckCodeForm.tsx.html +0 -586
  41. package/coverage/components/CrudifyLogin/Forms/ForgotPasswordForm.tsx.html +0 -694
  42. package/coverage/components/CrudifyLogin/Forms/LoginForm.tsx.html +0 -835
  43. package/coverage/components/CrudifyLogin/Forms/ResetPasswordForm.tsx.html +0 -1180
  44. package/coverage/components/CrudifyLogin/Forms/components/CodeInput.tsx.html +0 -283
  45. package/coverage/components/CrudifyLogin/Forms/components/FormAlert.tsx.html +0 -202
  46. package/coverage/components/CrudifyLogin/Forms/components/PasswordInput.tsx.html +0 -340
  47. package/coverage/components/CrudifyLogin/Forms/components/index.html +0 -161
  48. package/coverage/components/CrudifyLogin/Forms/components/index.ts.html +0 -106
  49. package/coverage/components/CrudifyLogin/Forms/index.html +0 -161
  50. package/coverage/components/CrudifyLogin/Forms/utils/errorTranslation.ts.html +0 -268
  51. package/coverage/components/CrudifyLogin/Forms/utils/index.html +0 -161
  52. package/coverage/components/CrudifyLogin/Forms/utils/index.ts.html +0 -106
  53. package/coverage/components/CrudifyLogin/Forms/utils/paramUtils.ts.html +0 -478
  54. package/coverage/components/CrudifyLogin/Forms/utils/validation.ts.html +0 -289
  55. package/coverage/components/CrudifyLogin/components/CrudifyInitializer.tsx.html +0 -262
  56. package/coverage/components/CrudifyLogin/components/index.html +0 -116
  57. package/coverage/components/CrudifyLogin/context/CrudifyProvider.tsx.html +0 -382
  58. package/coverage/components/CrudifyLogin/context/I18nProvider.tsx.html +0 -397
  59. package/coverage/components/CrudifyLogin/context/LoginStateProvider.tsx.html +0 -1249
  60. package/coverage/components/CrudifyLogin/context/index.html +0 -146
  61. package/coverage/components/CrudifyLogin/hooks/index.html +0 -116
  62. package/coverage/components/CrudifyLogin/hooks/useTranslationsFromUrl.ts.html +0 -292
  63. package/coverage/components/CrudifyLogin/index.html +0 -116
  64. package/coverage/components/CrudifyLogin/index.tsx.html +0 -475
  65. package/coverage/components/GlobalNotificationProvider.tsx.html +0 -781
  66. package/coverage/components/LoginComponent.tsx.html +0 -727
  67. package/coverage/components/PasswordRequirements/index.html +0 -116
  68. package/coverage/components/PasswordRequirements/index.tsx.html +0 -226
  69. package/coverage/components/PublicPolicies/FieldSelector/FieldSelector.tsx.html +0 -982
  70. package/coverage/components/PublicPolicies/FieldSelector/index.html +0 -131
  71. package/coverage/components/PublicPolicies/FieldSelector/index.ts.html +0 -85
  72. package/coverage/components/PublicPolicies/Policies.tsx.html +0 -610
  73. package/coverage/components/PublicPolicies/PolicyItem/PolicyItem.tsx.html +0 -856
  74. package/coverage/components/PublicPolicies/PolicyItem/index.html +0 -131
  75. package/coverage/components/PublicPolicies/PolicyItem/index.ts.html +0 -85
  76. package/coverage/components/PublicPolicies/constants.ts.html +0 -127
  77. package/coverage/components/PublicPolicies/index.html +0 -131
  78. package/coverage/components/SessionTimeIndicator/index.html +0 -116
  79. package/coverage/components/SessionTimeIndicator/index.tsx.html +0 -505
  80. package/coverage/components/UserProfile/UserProfileDisplay.tsx.html +0 -826
  81. package/coverage/components/UserProfile/index.html +0 -131
  82. package/coverage/components/UserProfile/index.ts.html +0 -85
  83. package/coverage/components/index.html +0 -176
  84. package/coverage/components/index.ts.html +0 -160
  85. package/coverage/core/CrossTabSyncManager.ts.html +0 -814
  86. package/coverage/core/CrudifyInitializationManager.ts.html +0 -1132
  87. package/coverage/core/SessionManager.ts.html +0 -2764
  88. package/coverage/core/index.html +0 -146
  89. package/coverage/hooks/index.html +0 -131
  90. package/coverage/hooks/useAutoGenerate.ts.html +0 -562
  91. package/coverage/hooks/useFileUpload/index.html +0 -131
  92. package/coverage/hooks/useFileUpload/index.ts.html +0 -112
  93. package/coverage/hooks/useFileUpload/services/index.html +0 -116
  94. package/coverage/hooks/useFileUpload/services/uploadService.ts.html +0 -610
  95. package/coverage/hooks/useFileUpload/useFileUpload.ts.html +0 -1870
  96. package/coverage/hooks/useFileUpload/utils/fileUtils.ts.html +0 -271
  97. package/coverage/hooks/useFileUpload/utils/index.html +0 -146
  98. package/coverage/hooks/useFileUpload/utils/mimeTypes.ts.html +0 -235
  99. package/coverage/hooks/useFileUpload/utils/validation.ts.html +0 -379
  100. package/coverage/hooks/useSession/constants.ts.html +0 -217
  101. package/coverage/hooks/useSession/hooks/index.html +0 -176
  102. package/coverage/hooks/useSession/hooks/useAuthEventSubscriber.ts.html +0 -331
  103. package/coverage/hooks/useSession/hooks/useCrossTabSync.ts.html +0 -433
  104. package/coverage/hooks/useSession/hooks/useSessionActions.ts.html +0 -664
  105. package/coverage/hooks/useSession/hooks/useSessionState.ts.html +0 -295
  106. package/coverage/hooks/useSession/hooks/useTokenRefreshScheduler.ts.html +0 -490
  107. package/coverage/hooks/useSession/index.html +0 -161
  108. package/coverage/hooks/useSession/index.ts.html +0 -127
  109. package/coverage/hooks/useSession/types.ts.html +0 -427
  110. package/coverage/hooks/useSession/useSession.ts.html +0 -526
  111. package/coverage/hooks/useSession/utils/index.html +0 -131
  112. package/coverage/hooks/useSession/utils/initializeSession.ts.html +0 -424
  113. package/coverage/hooks/useSession/utils/tokenUtils.ts.html +0 -280
  114. package/coverage/hooks/useUserProfile.ts.html +0 -658
  115. package/coverage/providers/SessionProvider.tsx.html +0 -1150
  116. package/coverage/providers/TranslationsProvider.tsx.html +0 -1450
  117. package/coverage/providers/index.html +0 -131
  118. package/coverage/services/credentialsEventBus.ts.html +0 -310
  119. package/coverage/services/index.html +0 -131
  120. package/coverage/services/translationService.ts.html +0 -1318
  121. package/coverage/translations/critical.ts.html +0 -1195
  122. package/coverage/translations/index.html +0 -116
  123. package/coverage/types/index.html +0 -116
  124. package/coverage/types/password.ts.html +0 -178
  125. package/coverage/utils/authEventBus.ts.html +0 -454
  126. package/coverage/utils/configResolver.ts.html +0 -460
  127. package/coverage/utils/cookieSync.ts.html +0 -580
  128. package/coverage/utils/errorHandler.ts.html +0 -1264
  129. package/coverage/utils/errorTranslation.ts.html +0 -862
  130. package/coverage/utils/index.html +0 -296
  131. package/coverage/utils/jwtUtils.ts.html +0 -301
  132. package/coverage/utils/logger.ts.html +0 -901
  133. package/coverage/utils/navigationTracker.ts.html +0 -565
  134. package/coverage/utils/passwordValidation.ts.html +0 -259
  135. package/coverage/utils/redirectSecurity.ts.html +0 -715
  136. package/coverage/utils/tenantConfig.ts.html +0 -700
  137. package/coverage/utils/tokenStorage.ts.html +0 -1768
  138. package/coverage/utils/webCrypto.ts.html +0 -472
  139. package/dist/chunk-77UKXG5L.mjs +0 -1
  140. package/dist/chunk-H6XXWDUT.js +0 -1
  141. package/dist/chunk-NIRLP2TC.js +0 -1
  142. package/dist/chunk-O4FUHIQG.mjs +0 -1
  143. package/dist/chunk-SYHNHKFA.mjs +0 -1
  144. package/dist/chunk-W4ZYKPOK.js +0 -1
@@ -1,835 +0,0 @@
1
-
2
- <!doctype html>
3
- <html lang="en">
4
-
5
- <head>
6
- <title>Code coverage report for components/CrudifyLogin/Forms/LoginForm.tsx</title>
7
- <meta charset="utf-8" />
8
- <link rel="stylesheet" href="../../../prettify.css" />
9
- <link rel="stylesheet" href="../../../base.css" />
10
- <link rel="shortcut icon" type="image/x-icon" href="../../../favicon.png" />
11
- <meta name="viewport" content="width=device-width, initial-scale=1" />
12
- <style type='text/css'>
13
- .coverage-summary .sorter {
14
- background-image: url(../../../sort-arrow-sprite.png);
15
- }
16
- </style>
17
- </head>
18
-
19
- <body>
20
- <div class='wrapper'>
21
- <div class='pad1'>
22
- <h1><a href="../../../index.html">All files</a> / <a href="index.html">components/CrudifyLogin/Forms</a> LoginForm.tsx</h1>
23
- <div class='clearfix'>
24
-
25
- <div class='fl pad1y space-right2'>
26
- <span class="strong">98.4% </span>
27
- <span class="quiet">Statements</span>
28
- <span class='fraction'>246/250</span>
29
- </div>
30
-
31
-
32
- <div class='fl pad1y space-right2'>
33
- <span class="strong">83.33% </span>
34
- <span class="quiet">Branches</span>
35
- <span class='fraction'>35/42</span>
36
- </div>
37
-
38
-
39
- <div class='fl pad1y space-right2'>
40
- <span class="strong">100% </span>
41
- <span class="quiet">Functions</span>
42
- <span class='fraction'>11/11</span>
43
- </div>
44
-
45
-
46
- <div class='fl pad1y space-right2'>
47
- <span class="strong">98.4% </span>
48
- <span class="quiet">Lines</span>
49
- <span class='fraction'>246/250</span>
50
- </div>
51
-
52
-
53
- </div>
54
- <p class="quiet">
55
- Press <em>n</em> or <em>j</em> to go to the next uncovered block, <em>b</em>, <em>p</em> or <em>k</em> for the previous block.
56
- </p>
57
- <template id="filterTemplate">
58
- <div class="quiet">
59
- Filter:
60
- <input type="search" id="fileSearch">
61
- </div>
62
- </template>
63
- </div>
64
- <div class='status-line high'></div>
65
- <pre><table class="coverage">
66
- <tr><td class="line-count quiet"><a name='L1'></a><a href='#L1'>1</a>
67
- <a name='L2'></a><a href='#L2'>2</a>
68
- <a name='L3'></a><a href='#L3'>3</a>
69
- <a name='L4'></a><a href='#L4'>4</a>
70
- <a name='L5'></a><a href='#L5'>5</a>
71
- <a name='L6'></a><a href='#L6'>6</a>
72
- <a name='L7'></a><a href='#L7'>7</a>
73
- <a name='L8'></a><a href='#L8'>8</a>
74
- <a name='L9'></a><a href='#L9'>9</a>
75
- <a name='L10'></a><a href='#L10'>10</a>
76
- <a name='L11'></a><a href='#L11'>11</a>
77
- <a name='L12'></a><a href='#L12'>12</a>
78
- <a name='L13'></a><a href='#L13'>13</a>
79
- <a name='L14'></a><a href='#L14'>14</a>
80
- <a name='L15'></a><a href='#L15'>15</a>
81
- <a name='L16'></a><a href='#L16'>16</a>
82
- <a name='L17'></a><a href='#L17'>17</a>
83
- <a name='L18'></a><a href='#L18'>18</a>
84
- <a name='L19'></a><a href='#L19'>19</a>
85
- <a name='L20'></a><a href='#L20'>20</a>
86
- <a name='L21'></a><a href='#L21'>21</a>
87
- <a name='L22'></a><a href='#L22'>22</a>
88
- <a name='L23'></a><a href='#L23'>23</a>
89
- <a name='L24'></a><a href='#L24'>24</a>
90
- <a name='L25'></a><a href='#L25'>25</a>
91
- <a name='L26'></a><a href='#L26'>26</a>
92
- <a name='L27'></a><a href='#L27'>27</a>
93
- <a name='L28'></a><a href='#L28'>28</a>
94
- <a name='L29'></a><a href='#L29'>29</a>
95
- <a name='L30'></a><a href='#L30'>30</a>
96
- <a name='L31'></a><a href='#L31'>31</a>
97
- <a name='L32'></a><a href='#L32'>32</a>
98
- <a name='L33'></a><a href='#L33'>33</a>
99
- <a name='L34'></a><a href='#L34'>34</a>
100
- <a name='L35'></a><a href='#L35'>35</a>
101
- <a name='L36'></a><a href='#L36'>36</a>
102
- <a name='L37'></a><a href='#L37'>37</a>
103
- <a name='L38'></a><a href='#L38'>38</a>
104
- <a name='L39'></a><a href='#L39'>39</a>
105
- <a name='L40'></a><a href='#L40'>40</a>
106
- <a name='L41'></a><a href='#L41'>41</a>
107
- <a name='L42'></a><a href='#L42'>42</a>
108
- <a name='L43'></a><a href='#L43'>43</a>
109
- <a name='L44'></a><a href='#L44'>44</a>
110
- <a name='L45'></a><a href='#L45'>45</a>
111
- <a name='L46'></a><a href='#L46'>46</a>
112
- <a name='L47'></a><a href='#L47'>47</a>
113
- <a name='L48'></a><a href='#L48'>48</a>
114
- <a name='L49'></a><a href='#L49'>49</a>
115
- <a name='L50'></a><a href='#L50'>50</a>
116
- <a name='L51'></a><a href='#L51'>51</a>
117
- <a name='L52'></a><a href='#L52'>52</a>
118
- <a name='L53'></a><a href='#L53'>53</a>
119
- <a name='L54'></a><a href='#L54'>54</a>
120
- <a name='L55'></a><a href='#L55'>55</a>
121
- <a name='L56'></a><a href='#L56'>56</a>
122
- <a name='L57'></a><a href='#L57'>57</a>
123
- <a name='L58'></a><a href='#L58'>58</a>
124
- <a name='L59'></a><a href='#L59'>59</a>
125
- <a name='L60'></a><a href='#L60'>60</a>
126
- <a name='L61'></a><a href='#L61'>61</a>
127
- <a name='L62'></a><a href='#L62'>62</a>
128
- <a name='L63'></a><a href='#L63'>63</a>
129
- <a name='L64'></a><a href='#L64'>64</a>
130
- <a name='L65'></a><a href='#L65'>65</a>
131
- <a name='L66'></a><a href='#L66'>66</a>
132
- <a name='L67'></a><a href='#L67'>67</a>
133
- <a name='L68'></a><a href='#L68'>68</a>
134
- <a name='L69'></a><a href='#L69'>69</a>
135
- <a name='L70'></a><a href='#L70'>70</a>
136
- <a name='L71'></a><a href='#L71'>71</a>
137
- <a name='L72'></a><a href='#L72'>72</a>
138
- <a name='L73'></a><a href='#L73'>73</a>
139
- <a name='L74'></a><a href='#L74'>74</a>
140
- <a name='L75'></a><a href='#L75'>75</a>
141
- <a name='L76'></a><a href='#L76'>76</a>
142
- <a name='L77'></a><a href='#L77'>77</a>
143
- <a name='L78'></a><a href='#L78'>78</a>
144
- <a name='L79'></a><a href='#L79'>79</a>
145
- <a name='L80'></a><a href='#L80'>80</a>
146
- <a name='L81'></a><a href='#L81'>81</a>
147
- <a name='L82'></a><a href='#L82'>82</a>
148
- <a name='L83'></a><a href='#L83'>83</a>
149
- <a name='L84'></a><a href='#L84'>84</a>
150
- <a name='L85'></a><a href='#L85'>85</a>
151
- <a name='L86'></a><a href='#L86'>86</a>
152
- <a name='L87'></a><a href='#L87'>87</a>
153
- <a name='L88'></a><a href='#L88'>88</a>
154
- <a name='L89'></a><a href='#L89'>89</a>
155
- <a name='L90'></a><a href='#L90'>90</a>
156
- <a name='L91'></a><a href='#L91'>91</a>
157
- <a name='L92'></a><a href='#L92'>92</a>
158
- <a name='L93'></a><a href='#L93'>93</a>
159
- <a name='L94'></a><a href='#L94'>94</a>
160
- <a name='L95'></a><a href='#L95'>95</a>
161
- <a name='L96'></a><a href='#L96'>96</a>
162
- <a name='L97'></a><a href='#L97'>97</a>
163
- <a name='L98'></a><a href='#L98'>98</a>
164
- <a name='L99'></a><a href='#L99'>99</a>
165
- <a name='L100'></a><a href='#L100'>100</a>
166
- <a name='L101'></a><a href='#L101'>101</a>
167
- <a name='L102'></a><a href='#L102'>102</a>
168
- <a name='L103'></a><a href='#L103'>103</a>
169
- <a name='L104'></a><a href='#L104'>104</a>
170
- <a name='L105'></a><a href='#L105'>105</a>
171
- <a name='L106'></a><a href='#L106'>106</a>
172
- <a name='L107'></a><a href='#L107'>107</a>
173
- <a name='L108'></a><a href='#L108'>108</a>
174
- <a name='L109'></a><a href='#L109'>109</a>
175
- <a name='L110'></a><a href='#L110'>110</a>
176
- <a name='L111'></a><a href='#L111'>111</a>
177
- <a name='L112'></a><a href='#L112'>112</a>
178
- <a name='L113'></a><a href='#L113'>113</a>
179
- <a name='L114'></a><a href='#L114'>114</a>
180
- <a name='L115'></a><a href='#L115'>115</a>
181
- <a name='L116'></a><a href='#L116'>116</a>
182
- <a name='L117'></a><a href='#L117'>117</a>
183
- <a name='L118'></a><a href='#L118'>118</a>
184
- <a name='L119'></a><a href='#L119'>119</a>
185
- <a name='L120'></a><a href='#L120'>120</a>
186
- <a name='L121'></a><a href='#L121'>121</a>
187
- <a name='L122'></a><a href='#L122'>122</a>
188
- <a name='L123'></a><a href='#L123'>123</a>
189
- <a name='L124'></a><a href='#L124'>124</a>
190
- <a name='L125'></a><a href='#L125'>125</a>
191
- <a name='L126'></a><a href='#L126'>126</a>
192
- <a name='L127'></a><a href='#L127'>127</a>
193
- <a name='L128'></a><a href='#L128'>128</a>
194
- <a name='L129'></a><a href='#L129'>129</a>
195
- <a name='L130'></a><a href='#L130'>130</a>
196
- <a name='L131'></a><a href='#L131'>131</a>
197
- <a name='L132'></a><a href='#L132'>132</a>
198
- <a name='L133'></a><a href='#L133'>133</a>
199
- <a name='L134'></a><a href='#L134'>134</a>
200
- <a name='L135'></a><a href='#L135'>135</a>
201
- <a name='L136'></a><a href='#L136'>136</a>
202
- <a name='L137'></a><a href='#L137'>137</a>
203
- <a name='L138'></a><a href='#L138'>138</a>
204
- <a name='L139'></a><a href='#L139'>139</a>
205
- <a name='L140'></a><a href='#L140'>140</a>
206
- <a name='L141'></a><a href='#L141'>141</a>
207
- <a name='L142'></a><a href='#L142'>142</a>
208
- <a name='L143'></a><a href='#L143'>143</a>
209
- <a name='L144'></a><a href='#L144'>144</a>
210
- <a name='L145'></a><a href='#L145'>145</a>
211
- <a name='L146'></a><a href='#L146'>146</a>
212
- <a name='L147'></a><a href='#L147'>147</a>
213
- <a name='L148'></a><a href='#L148'>148</a>
214
- <a name='L149'></a><a href='#L149'>149</a>
215
- <a name='L150'></a><a href='#L150'>150</a>
216
- <a name='L151'></a><a href='#L151'>151</a>
217
- <a name='L152'></a><a href='#L152'>152</a>
218
- <a name='L153'></a><a href='#L153'>153</a>
219
- <a name='L154'></a><a href='#L154'>154</a>
220
- <a name='L155'></a><a href='#L155'>155</a>
221
- <a name='L156'></a><a href='#L156'>156</a>
222
- <a name='L157'></a><a href='#L157'>157</a>
223
- <a name='L158'></a><a href='#L158'>158</a>
224
- <a name='L159'></a><a href='#L159'>159</a>
225
- <a name='L160'></a><a href='#L160'>160</a>
226
- <a name='L161'></a><a href='#L161'>161</a>
227
- <a name='L162'></a><a href='#L162'>162</a>
228
- <a name='L163'></a><a href='#L163'>163</a>
229
- <a name='L164'></a><a href='#L164'>164</a>
230
- <a name='L165'></a><a href='#L165'>165</a>
231
- <a name='L166'></a><a href='#L166'>166</a>
232
- <a name='L167'></a><a href='#L167'>167</a>
233
- <a name='L168'></a><a href='#L168'>168</a>
234
- <a name='L169'></a><a href='#L169'>169</a>
235
- <a name='L170'></a><a href='#L170'>170</a>
236
- <a name='L171'></a><a href='#L171'>171</a>
237
- <a name='L172'></a><a href='#L172'>172</a>
238
- <a name='L173'></a><a href='#L173'>173</a>
239
- <a name='L174'></a><a href='#L174'>174</a>
240
- <a name='L175'></a><a href='#L175'>175</a>
241
- <a name='L176'></a><a href='#L176'>176</a>
242
- <a name='L177'></a><a href='#L177'>177</a>
243
- <a name='L178'></a><a href='#L178'>178</a>
244
- <a name='L179'></a><a href='#L179'>179</a>
245
- <a name='L180'></a><a href='#L180'>180</a>
246
- <a name='L181'></a><a href='#L181'>181</a>
247
- <a name='L182'></a><a href='#L182'>182</a>
248
- <a name='L183'></a><a href='#L183'>183</a>
249
- <a name='L184'></a><a href='#L184'>184</a>
250
- <a name='L185'></a><a href='#L185'>185</a>
251
- <a name='L186'></a><a href='#L186'>186</a>
252
- <a name='L187'></a><a href='#L187'>187</a>
253
- <a name='L188'></a><a href='#L188'>188</a>
254
- <a name='L189'></a><a href='#L189'>189</a>
255
- <a name='L190'></a><a href='#L190'>190</a>
256
- <a name='L191'></a><a href='#L191'>191</a>
257
- <a name='L192'></a><a href='#L192'>192</a>
258
- <a name='L193'></a><a href='#L193'>193</a>
259
- <a name='L194'></a><a href='#L194'>194</a>
260
- <a name='L195'></a><a href='#L195'>195</a>
261
- <a name='L196'></a><a href='#L196'>196</a>
262
- <a name='L197'></a><a href='#L197'>197</a>
263
- <a name='L198'></a><a href='#L198'>198</a>
264
- <a name='L199'></a><a href='#L199'>199</a>
265
- <a name='L200'></a><a href='#L200'>200</a>
266
- <a name='L201'></a><a href='#L201'>201</a>
267
- <a name='L202'></a><a href='#L202'>202</a>
268
- <a name='L203'></a><a href='#L203'>203</a>
269
- <a name='L204'></a><a href='#L204'>204</a>
270
- <a name='L205'></a><a href='#L205'>205</a>
271
- <a name='L206'></a><a href='#L206'>206</a>
272
- <a name='L207'></a><a href='#L207'>207</a>
273
- <a name='L208'></a><a href='#L208'>208</a>
274
- <a name='L209'></a><a href='#L209'>209</a>
275
- <a name='L210'></a><a href='#L210'>210</a>
276
- <a name='L211'></a><a href='#L211'>211</a>
277
- <a name='L212'></a><a href='#L212'>212</a>
278
- <a name='L213'></a><a href='#L213'>213</a>
279
- <a name='L214'></a><a href='#L214'>214</a>
280
- <a name='L215'></a><a href='#L215'>215</a>
281
- <a name='L216'></a><a href='#L216'>216</a>
282
- <a name='L217'></a><a href='#L217'>217</a>
283
- <a name='L218'></a><a href='#L218'>218</a>
284
- <a name='L219'></a><a href='#L219'>219</a>
285
- <a name='L220'></a><a href='#L220'>220</a>
286
- <a name='L221'></a><a href='#L221'>221</a>
287
- <a name='L222'></a><a href='#L222'>222</a>
288
- <a name='L223'></a><a href='#L223'>223</a>
289
- <a name='L224'></a><a href='#L224'>224</a>
290
- <a name='L225'></a><a href='#L225'>225</a>
291
- <a name='L226'></a><a href='#L226'>226</a>
292
- <a name='L227'></a><a href='#L227'>227</a>
293
- <a name='L228'></a><a href='#L228'>228</a>
294
- <a name='L229'></a><a href='#L229'>229</a>
295
- <a name='L230'></a><a href='#L230'>230</a>
296
- <a name='L231'></a><a href='#L231'>231</a>
297
- <a name='L232'></a><a href='#L232'>232</a>
298
- <a name='L233'></a><a href='#L233'>233</a>
299
- <a name='L234'></a><a href='#L234'>234</a>
300
- <a name='L235'></a><a href='#L235'>235</a>
301
- <a name='L236'></a><a href='#L236'>236</a>
302
- <a name='L237'></a><a href='#L237'>237</a>
303
- <a name='L238'></a><a href='#L238'>238</a>
304
- <a name='L239'></a><a href='#L239'>239</a>
305
- <a name='L240'></a><a href='#L240'>240</a>
306
- <a name='L241'></a><a href='#L241'>241</a>
307
- <a name='L242'></a><a href='#L242'>242</a>
308
- <a name='L243'></a><a href='#L243'>243</a>
309
- <a name='L244'></a><a href='#L244'>244</a>
310
- <a name='L245'></a><a href='#L245'>245</a>
311
- <a name='L246'></a><a href='#L246'>246</a>
312
- <a name='L247'></a><a href='#L247'>247</a>
313
- <a name='L248'></a><a href='#L248'>248</a>
314
- <a name='L249'></a><a href='#L249'>249</a>
315
- <a name='L250'></a><a href='#L250'>250</a>
316
- <a name='L251'></a><a href='#L251'>251</a></td><td class="line-coverage quiet"><span class="cline-any cline-yes">1x</span>
317
- <span class="cline-any cline-yes">1x</span>
318
- <span class="cline-any cline-yes">1x</span>
319
- <span class="cline-any cline-yes">1x</span>
320
- <span class="cline-any cline-yes">1x</span>
321
- <span class="cline-any cline-yes">1x</span>
322
- <span class="cline-any cline-yes">1x</span>
323
- <span class="cline-any cline-yes">1x</span>
324
- <span class="cline-any cline-yes">1x</span>
325
- <span class="cline-any cline-yes">1x</span>
326
- <span class="cline-any cline-yes">1x</span>
327
- <span class="cline-any cline-yes">1x</span>
328
- <span class="cline-any cline-yes">29x</span>
329
- <span class="cline-any cline-yes">29x</span>
330
- <span class="cline-any cline-yes">29x</span>
331
- <span class="cline-any cline-yes">29x</span>
332
- <span class="cline-any cline-yes">29x</span>
333
- <span class="cline-any cline-yes">29x</span>
334
- <span class="cline-any cline-yes">29x</span>
335
- <span class="cline-any cline-yes">29x</span>
336
- <span class="cline-any cline-yes">29x</span>
337
- <span class="cline-any cline-yes">29x</span>
338
- <span class="cline-any cline-yes">29x</span>
339
- <span class="cline-any cline-yes">29x</span>
340
- <span class="cline-any cline-yes">29x</span>
341
- <span class="cline-any cline-yes">29x</span>
342
- <span class="cline-any cline-yes">29x</span>
343
- <span class="cline-any cline-yes">29x</span>
344
- <span class="cline-any cline-yes">29x</span>
345
- <span class="cline-any cline-yes">6x</span>
346
- <span class="cline-any cline-yes">1x</span>
347
- <span class="cline-any cline-yes">1x</span>
348
- <span class="cline-any cline-yes">1x</span>
349
- <span class="cline-any cline-yes">1x</span>
350
- <span class="cline-any cline-yes">1x</span>
351
- <span class="cline-any cline-no">&nbsp;</span>
352
- <span class="cline-any cline-no">&nbsp;</span>
353
- <span class="cline-any cline-yes">1x</span>
354
- <span class="cline-any cline-yes">5x</span>
355
- <span class="cline-any cline-yes">6x</span>
356
- <span class="cline-any cline-yes">6x</span>
357
- <span class="cline-any cline-yes">29x</span>
358
- <span class="cline-any cline-yes">29x</span>
359
- <span class="cline-any cline-yes">29x</span>
360
- <span class="cline-any cline-no">&nbsp;</span>
361
- <span class="cline-any cline-yes">29x</span>
362
- <span class="cline-any cline-yes">29x</span>
363
- <span class="cline-any cline-yes">29x</span>
364
- <span class="cline-any cline-yes">29x</span>
365
- <span class="cline-any cline-yes">29x</span>
366
- <span class="cline-any cline-yes">2x</span>
367
- <span class="cline-any cline-yes">2x</span>
368
- <span class="cline-any cline-yes">2x</span>
369
- <span class="cline-any cline-yes">2x</span>
370
- <span class="cline-any cline-yes">2x</span>
371
- <span class="cline-any cline-yes">2x</span>
372
- <span class="cline-any cline-yes">2x</span>
373
- <span class="cline-any cline-yes">29x</span>
374
- <span class="cline-any cline-yes">29x</span>
375
- <span class="cline-any cline-yes">10x</span>
376
- <span class="cline-any cline-yes">10x</span>
377
- <span class="cline-any cline-yes">10x</span>
378
- <span class="cline-any cline-yes">10x</span>
379
- <span class="cline-any cline-yes">1x</span>
380
- <span class="cline-any cline-yes">1x</span>
381
- <span class="cline-any cline-yes">1x</span>
382
- <span class="cline-any cline-yes">9x</span>
383
- <span class="cline-any cline-yes">10x</span>
384
- <span class="cline-any cline-yes">1x</span>
385
- <span class="cline-any cline-yes">1x</span>
386
- <span class="cline-any cline-yes">1x</span>
387
- <span class="cline-any cline-yes">8x</span>
388
- <span class="cline-any cline-yes">8x</span>
389
- <span class="cline-any cline-yes">8x</span>
390
- <span class="cline-any cline-yes">8x</span>
391
- <span class="cline-any cline-yes">8x</span>
392
- <span class="cline-any cline-yes">8x</span>
393
- <span class="cline-any cline-yes">8x</span>
394
- <span class="cline-any cline-yes">7x</span>
395
- <span class="cline-any cline-yes">7x</span>
396
- <span class="cline-any cline-yes">7x</span>
397
- <span class="cline-any cline-yes">10x</span>
398
- <span class="cline-any cline-yes">6x</span>
399
- <span class="cline-any cline-yes">6x</span>
400
- <span class="cline-any cline-yes">6x</span>
401
- <span class="cline-any cline-yes">6x</span>
402
- <span class="cline-any cline-yes">6x</span>
403
- <span class="cline-any cline-yes">6x</span>
404
- <span class="cline-any cline-yes">10x</span>
405
- <span class="cline-any cline-yes">1x</span>
406
- <span class="cline-any cline-yes">1x</span>
407
- <span class="cline-any cline-yes">1x</span>
408
- <span class="cline-any cline-yes">1x</span>
409
- <span class="cline-any cline-yes">10x</span>
410
- <span class="cline-any cline-yes">1x</span>
411
- <span class="cline-any cline-yes">1x</span>
412
- <span class="cline-any cline-yes">1x</span>
413
- <span class="cline-any cline-yes">1x</span>
414
- <span class="cline-any cline-yes">1x</span>
415
- <span class="cline-any cline-yes">1x</span>
416
- <span class="cline-any cline-yes">1x</span>
417
- <span class="cline-any cline-yes">1x</span>
418
- <span class="cline-any cline-yes">1x</span>
419
- <span class="cline-any cline-yes">10x</span>
420
- <span class="cline-any cline-yes">29x</span>
421
- <span class="cline-any cline-yes">29x</span>
422
- <span class="cline-any cline-yes">1x</span>
423
- <span class="cline-any cline-yes">1x</span>
424
- <span class="cline-any cline-yes">1x</span>
425
- <span class="cline-any cline-yes">1x</span>
426
- <span class="cline-any cline-yes">1x</span>
427
- <span class="cline-any cline-yes">1x</span>
428
- <span class="cline-any cline-yes">1x</span>
429
- <span class="cline-any cline-yes">1x</span>
430
- <span class="cline-any cline-no">&nbsp;</span>
431
- <span class="cline-any cline-yes">1x</span>
432
- <span class="cline-any cline-yes">1x</span>
433
- <span class="cline-any cline-yes">1x</span>
434
- <span class="cline-any cline-yes">1x</span>
435
- <span class="cline-any cline-yes">1x</span>
436
- <span class="cline-any cline-yes">1x</span>
437
- <span class="cline-any cline-yes">1x</span>
438
- <span class="cline-any cline-yes">1x</span>
439
- <span class="cline-any cline-yes">1x</span>
440
- <span class="cline-any cline-yes">1x</span>
441
- <span class="cline-any cline-yes">1x</span>
442
- <span class="cline-any cline-yes">29x</span>
443
- <span class="cline-any cline-yes">29x</span>
444
- <span class="cline-any cline-yes">9x</span>
445
- <span class="cline-any cline-yes">9x</span>
446
- <span class="cline-any cline-yes">9x</span>
447
- <span class="cline-any cline-yes">29x</span>
448
- <span class="cline-any cline-yes">29x</span>
449
- <span class="cline-any cline-yes">20x</span>
450
- <span class="cline-any cline-yes">1x</span>
451
- <span class="cline-any cline-yes">1x</span>
452
- <span class="cline-any cline-yes">1x</span>
453
- <span class="cline-any cline-yes">20x</span>
454
- <span class="cline-any cline-yes">29x</span>
455
- <span class="cline-any cline-yes">29x</span>
456
- <span class="cline-any cline-yes">29x</span>
457
- <span class="cline-any cline-yes">29x</span>
458
- <span class="cline-any cline-yes">29x</span>
459
- <span class="cline-any cline-yes">29x</span>
460
- <span class="cline-any cline-yes">29x</span>
461
- <span class="cline-any cline-yes">29x</span>
462
- <span class="cline-any cline-yes">29x</span>
463
- <span class="cline-any cline-yes">29x</span>
464
- <span class="cline-any cline-yes">29x</span>
465
- <span class="cline-any cline-yes">29x</span>
466
- <span class="cline-any cline-yes">29x</span>
467
- <span class="cline-any cline-yes">29x</span>
468
- <span class="cline-any cline-yes">29x</span>
469
- <span class="cline-any cline-yes">29x</span>
470
- <span class="cline-any cline-yes">29x</span>
471
- <span class="cline-any cline-yes">29x</span>
472
- <span class="cline-any cline-yes">29x</span>
473
- <span class="cline-any cline-yes">29x</span>
474
- <span class="cline-any cline-yes">29x</span>
475
- <span class="cline-any cline-yes">29x</span>
476
- <span class="cline-any cline-yes">29x</span>
477
- <span class="cline-any cline-yes">29x</span>
478
- <span class="cline-any cline-yes">29x</span>
479
- <span class="cline-any cline-yes">29x</span>
480
- <span class="cline-any cline-yes">29x</span>
481
- <span class="cline-any cline-yes">29x</span>
482
- <span class="cline-any cline-yes">29x</span>
483
- <span class="cline-any cline-yes">29x</span>
484
- <span class="cline-any cline-yes">29x</span>
485
- <span class="cline-any cline-yes">29x</span>
486
- <span class="cline-any cline-yes">29x</span>
487
- <span class="cline-any cline-yes">29x</span>
488
- <span class="cline-any cline-yes">29x</span>
489
- <span class="cline-any cline-yes">29x</span>
490
- <span class="cline-any cline-yes">29x</span>
491
- <span class="cline-any cline-yes">29x</span>
492
- <span class="cline-any cline-yes">29x</span>
493
- <span class="cline-any cline-yes">29x</span>
494
- <span class="cline-any cline-yes">29x</span>
495
- <span class="cline-any cline-yes">29x</span>
496
- <span class="cline-any cline-yes">29x</span>
497
- <span class="cline-any cline-yes">29x</span>
498
- <span class="cline-any cline-yes">29x</span>
499
- <span class="cline-any cline-yes">29x</span>
500
- <span class="cline-any cline-yes">29x</span>
501
- <span class="cline-any cline-yes">29x</span>
502
- <span class="cline-any cline-yes">29x</span>
503
- <span class="cline-any cline-yes">29x</span>
504
- <span class="cline-any cline-yes">29x</span>
505
- <span class="cline-any cline-yes">29x</span>
506
- <span class="cline-any cline-yes">29x</span>
507
- <span class="cline-any cline-yes">29x</span>
508
- <span class="cline-any cline-yes">29x</span>
509
- <span class="cline-any cline-yes">29x</span>
510
- <span class="cline-any cline-yes">29x</span>
511
- <span class="cline-any cline-yes">29x</span>
512
- <span class="cline-any cline-yes">29x</span>
513
- <span class="cline-any cline-yes">29x</span>
514
- <span class="cline-any cline-yes">29x</span>
515
- <span class="cline-any cline-yes">27x</span>
516
- <span class="cline-any cline-yes">27x</span>
517
- <span class="cline-any cline-yes">27x</span>
518
- <span class="cline-any cline-yes">27x</span>
519
- <span class="cline-any cline-yes">1x</span>
520
- <span class="cline-any cline-yes">1x</span>
521
- <span class="cline-any cline-yes">27x</span>
522
- <span class="cline-any cline-yes">27x</span>
523
- <span class="cline-any cline-yes">27x</span>
524
- <span class="cline-any cline-yes">27x</span>
525
- <span class="cline-any cline-yes">27x</span>
526
- <span class="cline-any cline-yes">27x</span>
527
- <span class="cline-any cline-yes">29x</span>
528
- <span class="cline-any cline-yes">29x</span>
529
- <span class="cline-any cline-yes">29x</span>
530
- <span class="cline-any cline-yes">29x</span>
531
- <span class="cline-any cline-yes">29x</span>
532
- <span class="cline-any cline-yes">29x</span>
533
- <span class="cline-any cline-yes">29x</span>
534
- <span class="cline-any cline-yes">29x</span>
535
- <span class="cline-any cline-yes">1x</span>
536
- <span class="cline-any cline-yes">1x</span>
537
- <span class="cline-any cline-yes">2x</span>
538
- <span class="cline-any cline-yes">2x</span>
539
- <span class="cline-any cline-yes">2x</span>
540
- <span class="cline-any cline-yes">1x</span>
541
- <span class="cline-any cline-yes">29x</span>
542
- <span class="cline-any cline-yes">29x</span>
543
- <span class="cline-any cline-yes">29x</span>
544
- <span class="cline-any cline-yes">27x</span>
545
- <span class="cline-any cline-yes">27x</span>
546
- <span class="cline-any cline-yes">27x</span>
547
- <span class="cline-any cline-yes">27x</span>
548
- <span class="cline-any cline-yes">27x</span>
549
- <span class="cline-any cline-yes">2x</span>
550
- <span class="cline-any cline-yes">2x</span>
551
- <span class="cline-any cline-yes">2x</span>
552
- <span class="cline-any cline-yes">2x</span>
553
- <span class="cline-any cline-yes">2x</span>
554
- <span class="cline-any cline-yes">27x</span>
555
- <span class="cline-any cline-yes">27x</span>
556
- <span class="cline-any cline-yes">27x</span>
557
- <span class="cline-any cline-yes">27x</span>
558
- <span class="cline-any cline-yes">27x</span>
559
- <span class="cline-any cline-yes">27x</span>
560
- <span class="cline-any cline-yes">29x</span>
561
- <span class="cline-any cline-yes">29x</span>
562
- <span class="cline-any cline-yes">29x</span>
563
- <span class="cline-any cline-yes">29x</span>
564
- <span class="cline-any cline-yes">1x</span>
565
- <span class="cline-any cline-yes">1x</span>
566
- <span class="cline-any cline-neutral">&nbsp;</span></td><td class="text"><pre class="prettyprint lang-js">import { useTranslation } from "../context/I18nProvider";
567
- import { useLoginState } from "../context/LoginStateProvider";
568
- import { useSessionContext } from "../../../providers/SessionProvider";
569
- import { useEffect, useRef } from "react";
570
- import { Typography, TextField, Button, Box, CircularProgress, Alert, Link } from "@mui/material";
571
- import { handleCrudifyError } from "../../../utils/errorHandler";
572
- import { createErrorTranslator } from "../../../utils/errorTranslation";
573
- import { validateTrustedRedirect } from "../../../utils/redirectSecurity";
574
- import type { LoginFormProps, UserLoginData } from "../types";
575
- import type { ParsedError } from "../../../utils/errorHandler";
576
- &nbsp;
577
- const LoginForm: React.FC&lt;LoginFormProps&gt; = ({ onScreenChange, onExternalNavigate, onLoginSuccess, onError, redirectUrl = "/" }) =&gt; {
578
- const { state, updateFormData, setFieldError, clearErrors, setLoading } = useLoginState();
579
- const { login: sessionLogin } = useSessionContext();
580
- &nbsp;
581
- const translationContext = useTranslation();
582
- const { t } = translationContext;
583
- const i18n = "i18n" in translationContext ? (translationContext as { i18n?: { language?: string } }).<span class="branch-0 cbranch-no" title="branch not covered" >i18n : undefined;</span>
584
- const usernameInputRef = useRef&lt;HTMLInputElement&gt;(null);
585
- &nbsp;
586
- // Crear traductor de errores robusto
587
- const errorTranslator = createErrorTranslator(t, {
588
- currentLanguage: i18n?.language,
589
- enableDebug: false,
590
- });
591
- &nbsp;
592
- // Extract and validate redirect URL for post-login navigation
593
- // Supports both relative paths and absolute URLs from trusted domains (files.nocios.link, etc.)
594
- const getRedirectUrl = () =&gt; {
595
- if (state.searchParams.redirect) {
596
- try {
597
- const decodedPath = decodeURIComponent(state.searchParams.redirect);
598
- // Use validateTrustedRedirect to support both relative paths and trusted absolute URLs
599
- return validateTrustedRedirect(decodedPath, <span class="branch-0 cbranch-no" title="branch not covered" >redirectUrl || "/")</span>;
600
- <span class="branch-0 cbranch-no" title="branch not covered" > } catch {</span>
601
- <span class="cstat-no" title="statement not covered" > // Invalid URL encoding, fallback to default</span>
602
- <span class="cstat-no" title="statement not covered" > }</span>
603
- }
604
- &nbsp;
605
- return <span class="branch-0 cbranch-no" title="branch not covered" >redirectUrl || "/";</span>
606
- };
607
- &nbsp;
608
- useEffect(() =&gt; {
609
- const timer = setTimeout(() =&gt; {
610
- <span class="cstat-no" title="statement not covered" > if (usernameInputRef.current) usernameInputRef.current.focus();</span>
611
- }, 100);
612
- return () =&gt; clearTimeout(timer);
613
- }, []);
614
- &nbsp;
615
- const translateError = (parsedError: ParsedError): string =&gt; {
616
- const result = errorTranslator.translateError({
617
- code: parsedError.code,
618
- message: parsedError.message,
619
- field: parsedError.field,
620
- });
621
- return result;
622
- };
623
- &nbsp;
624
- const handleLogin = async () =&gt; {
625
- if (state.loading) <span class="branch-0 cbranch-no" title="branch not covered" >return;</span>
626
- &nbsp;
627
- // Validaciones
628
- if (!state.formData.username.trim()) {
629
- setFieldError("username", t("login.usernameRequired"));
630
- return;
631
- }
632
- &nbsp;
633
- if (!state.formData.password.trim()) {
634
- setFieldError("password", t("login.passwordRequired"));
635
- return;
636
- }
637
- &nbsp;
638
- clearErrors();
639
- setLoading(true);
640
- &nbsp;
641
- try {
642
- // Use SessionProvider login method for proper token synchronization
643
- const response = await sessionLogin(state.formData.username, state.formData.password);
644
- &nbsp;
645
- setLoading(false);
646
- &nbsp;
647
- if (response.success) {
648
- const finalRedirectUrl = getRedirectUrl();
649
- &nbsp;
650
- if (onLoginSuccess) {
651
- // Pass the complete user data including tokens
652
- onLoginSuccess(response.data as UserLoginData, finalRedirectUrl);
653
- }
654
- } else {
655
- // Usar rawResponse si está disponible para mejor manejo de errores
656
- const errorToHandle = response.<span class="branch-0 cbranch-no" title="branch not covered" >rawResponse || response;</span>
657
- handleLoginError(errorToHandle);
658
- }
659
- } catch (error) {
660
- setLoading(false);
661
- const parsedErrors = handleCrudifyError(error);
662
- const translatedErrors = parsedErrors.map(translateError);
663
- setFieldError("global", translatedErrors);
664
- &nbsp;
665
- if (onError) {
666
- onError(translatedErrors.join(", "));
667
- }
668
- }
669
- };
670
- &nbsp;
671
- const handleLoginError = (response: unknown) =&gt; {
672
- const parsedErrors = handleCrudifyError(response);
673
- &nbsp;
674
- // Collect all global errors first
675
- const globalErrors: string[] = [];
676
- &nbsp;
677
- // Handle field-specific errors
678
- parsedErrors.forEach((error) =&gt; {
679
- if (error.field) <span class="branch-0 cbranch-no" title="branch not covered" >{</span>
680
- <span class="cstat-no" title="statement not covered" > setFieldError(error.field, translateError(error));</span>
681
- } else {
682
- // Collect global errors
683
- globalErrors.push(translateError(error));
684
- }
685
- });
686
- &nbsp;
687
- // Set all global errors at once (replaces previous errors)
688
- if (globalErrors.length &gt; 0) {
689
- setFieldError("global", globalErrors);
690
- }
691
- };
692
- &nbsp;
693
- const handleSubmit = (e: React.FormEvent) =&gt; {
694
- e.preventDefault();
695
- handleLogin();
696
- };
697
- &nbsp;
698
- const handleKeyDown = (e: React.KeyboardEvent) =&gt; {
699
- if (e.key === "Enter" &amp;&amp; !state.loading) {
700
- e.preventDefault();
701
- handleLogin();
702
- }
703
- };
704
- &nbsp;
705
- return (
706
- &lt;&gt;
707
- &lt;Box
708
- component="form"
709
- noValidate
710
- onSubmit={handleSubmit}
711
- onKeyDown={handleKeyDown}
712
- sx={{ width: "100%", display: "flex", flexDirection: "column", gap: 2 }}
713
- &gt;
714
- &lt;Box sx={{ mb: 1 }}&gt;
715
- &lt;Typography
716
- variant="body2"
717
- component="label"
718
- htmlFor="email"
719
- sx={{ display: "block", fontWeight: 500, color: "grey.700", mb: 0.5 }}
720
- &gt;
721
- {t("login.usernameOrEmailLabel")}
722
- &lt;/Typography&gt;
723
- &lt;TextField
724
- fullWidth
725
- id="email"
726
- name="email"
727
- type="email"
728
- value={state.formData.username}
729
- disabled={state.loading}
730
- onChange={(e) =&gt; updateFormData({ username: e.target.value })}
731
- error={!!state.errors.username}
732
- helperText={state.errors.username}
733
- autoComplete="email"
734
- placeholder={t("login.usernameOrEmailPlaceholder")}
735
- inputRef={usernameInputRef}
736
- required
737
- /&gt;
738
- &lt;/Box&gt;
739
- &lt;Box sx={{ mb: 1 }}&gt;
740
- &lt;Typography
741
- variant="body2"
742
- component="label"
743
- htmlFor="password"
744
- sx={{ display: "block", fontWeight: 500, color: "grey.700", mb: 0.5 }}
745
- &gt;
746
- {t("login.passwordLabel")}
747
- &lt;/Typography&gt;
748
- &lt;TextField
749
- fullWidth
750
- id="password"
751
- name="password"
752
- type="password"
753
- value={state.formData.password}
754
- disabled={state.loading}
755
- onChange={(e) =&gt; updateFormData({ password: e.target.value })}
756
- error={!!state.errors.password}
757
- helperText={state.errors.password}
758
- autoComplete="current-password"
759
- placeholder={t("login.passwordPlaceholder")}
760
- required
761
- /&gt;
762
- &lt;/Box&gt;
763
- &nbsp;
764
- {state.config.loginActions?.includes("forgotPassword") &amp;&amp; (
765
- &lt;Box sx={{ display: "flex", justifyContent: "flex-end", alignItems: "center" }}&gt;
766
- &lt;Link
767
- sx={{ cursor: "pointer" }}
768
- onClick={() =&gt; {
769
- onScreenChange?.("forgotPassword", state.searchParams);
770
- }}
771
- variant="body2"
772
- color="secondary"
773
- &gt;
774
- {t("login.forgotPasswordLink")}
775
- &lt;/Link&gt;
776
- &lt;/Box&gt;
777
- )}
778
- &nbsp;
779
- &lt;Button disabled={state.loading} type="submit" fullWidth variant="contained" color="primary" sx={{ mt: 1, mb: 2 }}&gt;
780
- {state.loading ? &lt;CircularProgress size={20} /&gt; : t("login.loginButton")}
781
- &lt;/Button&gt;
782
- &lt;/Box&gt;
783
- &lt;Box&gt;
784
- {state.errors.global &amp;&amp;
785
- state.errors.global.length &gt; 0 &amp;&amp;
786
- state.errors.global.map((error, index) =&gt; (
787
- &lt;Alert key={index} variant="filled" sx={{ mt: 2 }} severity="error"&gt;
788
- &lt;div&gt;{error}&lt;/div&gt;
789
- &lt;/Alert&gt;
790
- ))}
791
- &lt;/Box&gt;
792
- &nbsp;
793
- {state.config.loginActions?.includes("createUser") &amp;&amp; (
794
- &lt;Typography variant="body2" align="center" sx={{ color: "text.secondary", mt: 3 }}&gt;
795
- {t("login.noAccountPrompt")}{" "}
796
- &lt;Link
797
- sx={{ cursor: "pointer" }}
798
- onClick={() =&gt; {
799
- const searchString =
800
- Object.keys(state.searchParams).length &gt; 0 ? `?${new URLSearchParams(state.searchParams).toString()}` : "";
801
- const signupUrl = `/public/users/create${searchString}`;
802
- onExternalNavigate?.(signupUrl);
803
- }}
804
- fontWeight="medium"
805
- color="secondary"
806
- &gt;
807
- {t("login.signUpLink")}
808
- &lt;/Link&gt;
809
- &lt;/Typography&gt;
810
- )}
811
- &lt;/&gt;
812
- );
813
- };
814
- &nbsp;
815
- export default LoginForm;
816
- &nbsp;</pre></td></tr></table></pre>
817
-
818
- <div class='push'></div><!-- for sticky footer -->
819
- </div><!-- /wrapper -->
820
- <div class='footer quiet pad2 space-top1 center small'>
821
- Code coverage generated by
822
- <a href="https://istanbul.js.org/" target="_blank" rel="noopener noreferrer">istanbul</a>
823
- at 2026-01-28T06:22:15.683Z
824
- </div>
825
- <script src="../../../prettify.js"></script>
826
- <script>
827
- window.onload = function () {
828
- prettyPrint();
829
- };
830
- </script>
831
- <script src="../../../sorter.js"></script>
832
- <script src="../../../block-navigation.js"></script>
833
- </body>
834
- </html>
835
-