zebpay-ui 0.0.44 → 0.0.46

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 (45) hide show
  1. package/package.json +1 -1
  2. package/.vscode/settings.json +0 -3
  3. package/coverage/clover.xml +0 -424
  4. package/coverage/coverage-final.json +0 -23
  5. package/coverage/lcov-report/base.css +0 -224
  6. package/coverage/lcov-report/block-navigation.js +0 -87
  7. package/coverage/lcov-report/components/Accordion/index.html +0 -131
  8. package/coverage/lcov-report/components/Accordion/index.tsx.html +0 -202
  9. package/coverage/lcov-report/components/Accordion/style.ts.html +0 -166
  10. package/coverage/lcov-report/components/Button/index.html +0 -131
  11. package/coverage/lcov-report/components/Button/index.tsx.html +0 -277
  12. package/coverage/lcov-report/components/Button/styles.ts.html +0 -532
  13. package/coverage/lcov-report/components/CircularLoader/index.html +0 -131
  14. package/coverage/lcov-report/components/CircularLoader/index.tsx.html +0 -286
  15. package/coverage/lcov-report/components/CircularLoader/style.ts.html +0 -148
  16. package/coverage/lcov-report/components/Input/index.html +0 -131
  17. package/coverage/lcov-report/components/Input/index.tsx.html +0 -409
  18. package/coverage/lcov-report/components/Input/styles.ts.html +0 -433
  19. package/coverage/lcov-report/components/PinInput/PinInputField.tsx.html +0 -517
  20. package/coverage/lcov-report/components/PinInput/index.html +0 -146
  21. package/coverage/lcov-report/components/PinInput/index.tsx.html +0 -268
  22. package/coverage/lcov-report/components/PinInput/style.ts.html +0 -247
  23. package/coverage/lcov-report/components/Popper/index.html +0 -131
  24. package/coverage/lcov-report/components/Popper/index.tsx.html +0 -346
  25. package/coverage/lcov-report/components/Popper/styles.ts.html +0 -205
  26. package/coverage/lcov-report/components/SidePanel/index.html +0 -131
  27. package/coverage/lcov-report/components/SidePanel/index.tsx.html +0 -343
  28. package/coverage/lcov-report/components/SidePanel/style.ts.html +0 -307
  29. package/coverage/lcov-report/components/Tooltip/index.html +0 -131
  30. package/coverage/lcov-report/components/Tooltip/index.tsx.html +0 -307
  31. package/coverage/lcov-report/components/Tooltip/styles.ts.html +0 -157
  32. package/coverage/lcov-report/favicon.png +0 -0
  33. package/coverage/lcov-report/index.html +0 -236
  34. package/coverage/lcov-report/prettify.css +0 -1
  35. package/coverage/lcov-report/prettify.js +0 -2
  36. package/coverage/lcov-report/sort-arrow-sprite.png +0 -0
  37. package/coverage/lcov-report/sorter.js +0 -196
  38. package/coverage/lcov-report/styles/colors.ts.html +0 -235
  39. package/coverage/lcov-report/styles/index.html +0 -176
  40. package/coverage/lcov-report/styles/index.ts.html +0 -103
  41. package/coverage/lcov-report/styles/mixins.ts.html +0 -355
  42. package/coverage/lcov-report/styles/typography.ts.html +0 -1105
  43. package/coverage/lcov-report/styles/utils.ts.html +0 -202
  44. package/coverage/lcov.info +0 -780
  45. package/jest.config.js +0 -15
@@ -1,517 +0,0 @@
1
-
2
- <!doctype html>
3
- <html lang="en">
4
-
5
- <head>
6
- <title>Code coverage report for components/PinInput/PinInputField.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/PinInput</a> PinInputField.tsx</h1>
23
- <div class='clearfix'>
24
-
25
- <div class='fl pad1y space-right2'>
26
- <span class="strong">79.22% </span>
27
- <span class="quiet">Statements</span>
28
- <span class='fraction'>61/77</span>
29
- </div>
30
-
31
-
32
- <div class='fl pad1y space-right2'>
33
- <span class="strong">55.81% </span>
34
- <span class="quiet">Branches</span>
35
- <span class='fraction'>24/43</span>
36
- </div>
37
-
38
-
39
- <div class='fl pad1y space-right2'>
40
- <span class="strong">77.77% </span>
41
- <span class="quiet">Functions</span>
42
- <span class='fraction'>7/9</span>
43
- </div>
44
-
45
-
46
- <div class='fl pad1y space-right2'>
47
- <span class="strong">78.37% </span>
48
- <span class="quiet">Lines</span>
49
- <span class='fraction'>58/74</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 oninput="onInput()" type="search" id="fileSearch">
61
- </div>
62
- </template>
63
- </div>
64
- <div class='status-line medium'></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></td><td class="line-coverage quiet"><span class="cline-any cline-neutral">&nbsp;</span>
211
- <span class="cline-any cline-yes">1x</span>
212
- <span class="cline-any cline-neutral">&nbsp;</span>
213
- <span class="cline-any cline-yes">1x</span>
214
- <span class="cline-any cline-yes">1x</span>
215
- <span class="cline-any cline-neutral">&nbsp;</span>
216
- <span class="cline-any cline-yes">1x</span>
217
- <span class="cline-any cline-yes">6x</span>
218
- <span class="cline-any cline-no">&nbsp;</span>
219
- <span class="cline-any cline-neutral">&nbsp;</span>
220
- <span class="cline-any cline-yes">6x</span>
221
- <span class="cline-any cline-no">&nbsp;</span>
222
- <span class="cline-any cline-neutral">&nbsp;</span>
223
- <span class="cline-any cline-yes">6x</span>
224
- <span class="cline-any cline-no">&nbsp;</span>
225
- <span class="cline-any cline-neutral">&nbsp;</span>
226
- <span class="cline-any cline-yes">6x</span>
227
- <span class="cline-any cline-no">&nbsp;</span>
228
- <span class="cline-any cline-neutral">&nbsp;</span>
229
- <span class="cline-any cline-yes">6x</span>
230
- <span class="cline-any cline-neutral">&nbsp;</span>
231
- <span class="cline-any cline-neutral">&nbsp;</span>
232
- <span class="cline-any cline-yes">1x</span>
233
- <span class="cline-any cline-yes">54x</span>
234
- <span class="cline-any cline-yes">54x</span>
235
- <span class="cline-any cline-yes">54x</span>
236
- <span class="cline-any cline-yes">54x</span>
237
- <span class="cline-any cline-yes">54x</span>
238
- <span class="cline-any cline-yes">54x</span>
239
- <span class="cline-any cline-yes">54x</span>
240
- <span class="cline-any cline-yes">54x</span>
241
- <span class="cline-any cline-yes">54x</span>
242
- <span class="cline-any cline-yes">54x</span>
243
- <span class="cline-any cline-yes">54x</span>
244
- <span class="cline-any cline-yes">54x</span>
245
- <span class="cline-any cline-yes">54x</span>
246
- <span class="cline-any cline-yes">54x</span>
247
- <span class="cline-any cline-yes">54x</span>
248
- <span class="cline-any cline-neutral">&nbsp;</span>
249
- <span class="cline-any cline-yes">54x</span>
250
- <span class="cline-any cline-neutral">&nbsp;</span>
251
- <span class="cline-any cline-yes">54x</span>
252
- <span class="cline-any cline-yes">6x</span>
253
- <span class="cline-any cline-yes">6x</span>
254
- <span class="cline-any cline-yes">6x</span>
255
- <span class="cline-any cline-yes">6x</span>
256
- <span class="cline-any cline-neutral">&nbsp;</span>
257
- <span class="cline-any cline-neutral">&nbsp;</span>
258
- <span class="cline-any cline-neutral">&nbsp;</span>
259
- <span class="cline-any cline-yes">6x</span>
260
- <span class="cline-any cline-yes">6x</span>
261
- <span class="cline-any cline-neutral">&nbsp;</span>
262
- <span class="cline-any cline-yes">6x</span>
263
- <span class="cline-any cline-no">&nbsp;</span>
264
- <span class="cline-any cline-neutral">&nbsp;</span>
265
- <span class="cline-any cline-neutral">&nbsp;</span>
266
- <span class="cline-any cline-neutral">&nbsp;</span>
267
- <span class="cline-any cline-yes">6x</span>
268
- <span class="cline-any cline-neutral">&nbsp;</span>
269
- <span class="cline-any cline-yes">6x</span>
270
- <span class="cline-any cline-yes">6x</span>
271
- <span class="cline-any cline-neutral">&nbsp;</span>
272
- <span class="cline-any cline-no">&nbsp;</span>
273
- <span class="cline-any cline-neutral">&nbsp;</span>
274
- <span class="cline-any cline-neutral">&nbsp;</span>
275
- <span class="cline-any cline-yes">6x</span>
276
- <span class="cline-any cline-no">&nbsp;</span>
277
- <span class="cline-any cline-neutral">&nbsp;</span>
278
- <span class="cline-any cline-neutral">&nbsp;</span>
279
- <span class="cline-any cline-yes">6x</span>
280
- <span class="cline-any cline-neutral">&nbsp;</span>
281
- <span class="cline-any cline-neutral">&nbsp;</span>
282
- <span class="cline-any cline-yes">6x</span>
283
- <span class="cline-any cline-yes">6x</span>
284
- <span class="cline-any cline-yes">6x</span>
285
- <span class="cline-any cline-yes">6x</span>
286
- <span class="cline-any cline-neutral">&nbsp;</span>
287
- <span class="cline-any cline-neutral">&nbsp;</span>
288
- <span class="cline-any cline-yes">6x</span>
289
- <span class="cline-any cline-yes">5x</span>
290
- <span class="cline-any cline-yes">1x</span>
291
- <span class="cline-any cline-yes">1x</span>
292
- <span class="cline-any cline-neutral">&nbsp;</span>
293
- <span class="cline-any cline-neutral">&nbsp;</span>
294
- <span class="cline-any cline-neutral">&nbsp;</span>
295
- <span class="cline-any cline-yes">54x</span>
296
- <span class="cline-any cline-no">&nbsp;</span>
297
- <span class="cline-any cline-neutral">&nbsp;</span>
298
- <span class="cline-any cline-neutral">&nbsp;</span>
299
- <span class="cline-any cline-neutral">&nbsp;</span>
300
- <span class="cline-any cline-neutral">&nbsp;</span>
301
- <span class="cline-any cline-neutral">&nbsp;</span>
302
- <span class="cline-any cline-no">&nbsp;</span>
303
- <span class="cline-any cline-neutral">&nbsp;</span>
304
- <span class="cline-any cline-no">&nbsp;</span>
305
- <span class="cline-any cline-no">&nbsp;</span>
306
- <span class="cline-any cline-neutral">&nbsp;</span>
307
- <span class="cline-any cline-neutral">&nbsp;</span>
308
- <span class="cline-any cline-no">&nbsp;</span>
309
- <span class="cline-any cline-no">&nbsp;</span>
310
- <span class="cline-any cline-neutral">&nbsp;</span>
311
- <span class="cline-any cline-neutral">&nbsp;</span>
312
- <span class="cline-any cline-neutral">&nbsp;</span>
313
- <span class="cline-any cline-yes">54x</span>
314
- <span class="cline-any cline-yes">1x</span>
315
- <span class="cline-any cline-yes">1x</span>
316
- <span class="cline-any cline-yes">1x</span>
317
- <span class="cline-any cline-neutral">&nbsp;</span>
318
- <span class="cline-any cline-neutral">&nbsp;</span>
319
- <span class="cline-any cline-neutral">&nbsp;</span>
320
- <span class="cline-any cline-yes">54x</span>
321
- <span class="cline-any cline-no">&nbsp;</span>
322
- <span class="cline-any cline-no">&nbsp;</span>
323
- <span class="cline-any cline-no">&nbsp;</span>
324
- <span class="cline-any cline-neutral">&nbsp;</span>
325
- <span class="cline-any cline-neutral">&nbsp;</span>
326
- <span class="cline-any cline-neutral">&nbsp;</span>
327
- <span class="cline-any cline-neutral">&nbsp;</span>
328
- <span class="cline-any cline-yes">54x</span>
329
- <span class="cline-any cline-yes">48x</span>
330
- <span class="cline-any cline-yes">1x</span>
331
- <span class="cline-any cline-neutral">&nbsp;</span>
332
- <span class="cline-any cline-neutral">&nbsp;</span>
333
- <span class="cline-any cline-neutral">&nbsp;</span>
334
- <span class="cline-any cline-yes">54x</span>
335
- <span class="cline-any cline-neutral">&nbsp;</span>
336
- <span class="cline-any cline-neutral">&nbsp;</span>
337
- <span class="cline-any cline-neutral">&nbsp;</span>
338
- <span class="cline-any cline-neutral">&nbsp;</span>
339
- <span class="cline-any cline-neutral">&nbsp;</span>
340
- <span class="cline-any cline-neutral">&nbsp;</span>
341
- <span class="cline-any cline-neutral">&nbsp;</span>
342
- <span class="cline-any cline-neutral">&nbsp;</span>
343
- <span class="cline-any cline-neutral">&nbsp;</span>
344
- <span class="cline-any cline-neutral">&nbsp;</span>
345
- <span class="cline-any cline-neutral">&nbsp;</span>
346
- <span class="cline-any cline-neutral">&nbsp;</span>
347
- <span class="cline-any cline-neutral">&nbsp;</span>
348
- <span class="cline-any cline-neutral">&nbsp;</span>
349
- <span class="cline-any cline-neutral">&nbsp;</span>
350
- <span class="cline-any cline-neutral">&nbsp;</span>
351
- <span class="cline-any cline-neutral">&nbsp;</span>
352
- <span class="cline-any cline-neutral">&nbsp;</span>
353
- <span class="cline-any cline-yes">1x</span>
354
- <span class="cline-any cline-neutral">&nbsp;</span></td><td class="text"><pre class="prettyprint lang-js">/** @jsxImportSource @emotion/react */
355
- import React, { useEffect, useRef, useState } from "react";
356
- import { PinInputFieldProps } from "./typing";
357
- import { input, invalidPins } from "./style";
358
- import { css } from "@emotion/react";
359
- &nbsp;
360
- const normalizeNewValue = (currentValue: string, eventValue: string) =&gt; {
361
- <span class="missing-if-branch" title="if path not taken" >I</span>if (!currentValue) {
362
- <span class="cstat-no" title="statement not covered" > return eventValue.split("");</span>
363
- }
364
- <span class="missing-if-branch" title="if path not taken" >I</span>if (eventValue.length &gt; 2) {
365
- <span class="cstat-no" title="statement not covered" > return eventValue.split("");</span>
366
- }
367
- <span class="missing-if-branch" title="if path not taken" >I</span>if (eventValue === "") {
368
- <span class="cstat-no" title="statement not covered" > return [];</span>
369
- }
370
- <span class="missing-if-branch" title="if path not taken" >I</span>if (currentValue[0] === eventValue[0]) {
371
- <span class="cstat-no" title="statement not covered" > return [eventValue[1]];</span>
372
- }
373
- return [eventValue[0]];
374
- };
375
- &nbsp;
376
- const PinInputField: React.FC&lt;PinInputFieldProps&gt; = ({
377
- index,
378
- value,
379
- values,
380
- mask,
381
- autoFocus,
382
- disabled,
383
- inputMode,
384
- id,
385
- placeholder,
386
- onChange,
387
- onBlur,
388
- onFocus,
389
- onKeyDown,
390
- invalid,
391
- inputFieldStyle,
392
- }) =&gt; {
393
- const inputRef = useRef&lt;HTMLInputElement&gt;(null);
394
- &nbsp;
395
- const handleInputChange: React.ChangeEventHandler&lt;HTMLInputElement&gt; = (e) =&gt; {
396
- const currentValue = values[index];
397
- const eventValue = e.target.value;
398
- const newValues = [...values];
399
- const rawValue: string[] = normalizeNewValue(
400
- currentValue,
401
- eventValue
402
- ).slice(0, newValues.length - index);
403
- const regex = /(^$)|(\d+)/;
404
- const shouldFireChange: boolean = rawValue.every((val) =&gt; regex.test(val));
405
- &nbsp;
406
- <span class="missing-if-branch" title="if path not taken" >I</span>if (!onChange) {
407
- <span class="cstat-no" title="statement not covered" > return;</span>
408
- }
409
- &nbsp;
410
- // apply formatter to transform
411
- const newValue = rawValue;
412
- &nbsp;
413
- if (newValue.length) {
414
- newValue.forEach((val, idx) =&gt; (newValues[index + idx] = val));
415
- } else <span class="missing-if-branch" title="else path not taken" >E</span>{
416
- <span class="cstat-no" title="statement not covered" > newValues[index] = "";</span>
417
- }
418
- &nbsp;
419
- <span class="missing-if-branch" title="if path not taken" >I</span>if (!shouldFireChange) {
420
- <span class="cstat-no" title="statement not covered" > return;</span>
421
- }
422
- &nbsp;
423
- onChange(newValue, index, newValues);
424
- &nbsp;
425
- // auto-tab to the specified pin input
426
- let inputEl: Element | HTMLInputElement | null = inputRef.current;
427
- for (let i = 0; i &lt; newValue.length; i++) {
428
- if (inputEl) {
429
- inputEl = inputEl.nextElementSibling;
430
- }
431
- }
432
- if (newValue &amp;&amp; inputEl instanceof HTMLInputElement) {
433
- inputEl.focus();
434
- } else if (inputRef.current) {
435
- (inputRef.current.parentNode<span class="branch-0 cbranch-no" title="branch not covered" >?.l</span>astChild as HTMLInputElement).focus();
436
- }
437
- };
438
- &nbsp;
439
- const handleKeyDown: React.KeyboardEventHandler&lt;HTMLInputElement&gt; = <span class="fstat-no" title="function not covered" >(e</span>) =&gt; {
440
- <span class="cstat-no" title="statement not covered" > <span class="missing-if-branch" title="if path not taken" >I</span>if (</span>
441
- e.key === "Backspace" &amp;&amp;
442
- values[index] === "" &amp;&amp;
443
- index &gt; 0 &amp;&amp;
444
- inputRef.current
445
- ) {
446
- const prevInput = <span class="cstat-no" title="statement not covered" >inputRef.current.previousElementSibling;</span>
447
- &nbsp;
448
- <span class="cstat-no" title="statement not covered" > <span class="missing-if-branch" title="if path not taken" >I</span>if (prevInput instanceof HTMLInputElement) {</span>
449
- <span class="cstat-no" title="statement not covered" > prevInput.focus();</span>
450
- }
451
- }
452
- <span class="cstat-no" title="statement not covered" > <span class="missing-if-branch" title="if path not taken" >I</span>if (onKeyDown) {</span>
453
- <span class="cstat-no" title="statement not covered" > onKeyDown(e);</span>
454
- }
455
- };
456
- &nbsp;
457
- const handleInputFocus: React.FocusEventHandler&lt;HTMLInputElement&gt; = (e) =&gt; {
458
- e.target.placeholder = "";
459
- if (onFocus) {
460
- onFocus(e);
461
- }
462
- };
463
- &nbsp;
464
- const handleInputBlur: React.FocusEventHandler&lt;HTMLInputElement&gt; = <span class="fstat-no" title="function not covered" >(e</span>) =&gt; {
465
- <span class="cstat-no" title="statement not covered" > e.target.placeholder = placeholder || "";</span>
466
- <span class="cstat-no" title="statement not covered" > <span class="missing-if-branch" title="if path not taken" >I</span>if (onBlur) {</span>
467
- <span class="cstat-no" title="statement not covered" > onBlur(e);</span>
468
- }
469
- };
470
- &nbsp;
471
- // auto-focus on mount
472
- useEffect(() =&gt; {
473
- if (autoFocus &amp;&amp; index === 0 &amp;&amp; inputRef.current) {
474
- inputRef.current.focus();
475
- }
476
- }, [autoFocus, index]);
477
- &nbsp;
478
- return (
479
- &lt;input
480
- data-testid={`pinInput${index}`}
481
- ref={inputRef}
482
- disabled={disabled}
483
- id={id &amp;&amp; <span class="branch-1 cbranch-no" title="branch not covered" >`${id}-${index}`}</span>
484
- inputMode={inputMode || "numeric"}
485
- placeholder={placeholder}
486
- value={mask &amp;&amp; value ? "*" : value}
487
- onChange={handleInputChange}
488
- onKeyDown={handleKeyDown}
489
- onFocus={handleInputFocus}
490
- onBlur={handleInputBlur}
491
- data-index={index}
492
- css={css([input, invalid &amp;&amp; invalidPins, inputFieldStyle])}
493
- /&gt;
494
- );
495
- };
496
- &nbsp;
497
- export default PinInputField;
498
- &nbsp;</pre></td></tr></table></pre>
499
-
500
- <div class='push'></div><!-- for sticky footer -->
501
- </div><!-- /wrapper -->
502
- <div class='footer quiet pad2 space-top1 center small'>
503
- Code coverage generated by
504
- <a href="https://istanbul.js.org/" target="_blank" rel="noopener noreferrer">istanbul</a>
505
- at 2023-05-16T09:28:42.970Z
506
- </div>
507
- <script src="../../prettify.js"></script>
508
- <script>
509
- window.onload = function () {
510
- prettyPrint();
511
- };
512
- </script>
513
- <script src="../../sorter.js"></script>
514
- <script src="../../block-navigation.js"></script>
515
- </body>
516
- </html>
517
-