zebpay-ui 0.0.41 → 0.0.43

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 (94) hide show
  1. package/.vscode/settings.json +3 -0
  2. package/coverage/clover.xml +424 -0
  3. package/coverage/coverage-final.json +23 -0
  4. package/coverage/lcov-report/base.css +224 -0
  5. package/coverage/lcov-report/block-navigation.js +87 -0
  6. package/coverage/lcov-report/components/Accordion/index.html +131 -0
  7. package/coverage/lcov-report/components/Accordion/index.tsx.html +202 -0
  8. package/coverage/lcov-report/components/Accordion/style.ts.html +166 -0
  9. package/coverage/lcov-report/components/Button/index.html +131 -0
  10. package/coverage/lcov-report/components/Button/index.tsx.html +277 -0
  11. package/coverage/lcov-report/components/Button/styles.ts.html +532 -0
  12. package/coverage/lcov-report/components/CircularLoader/index.html +131 -0
  13. package/coverage/lcov-report/components/CircularLoader/index.tsx.html +286 -0
  14. package/coverage/lcov-report/components/CircularLoader/style.ts.html +148 -0
  15. package/coverage/lcov-report/components/Input/index.html +131 -0
  16. package/coverage/lcov-report/components/Input/index.tsx.html +409 -0
  17. package/coverage/lcov-report/components/Input/styles.ts.html +433 -0
  18. package/coverage/lcov-report/components/PinInput/PinInputField.tsx.html +517 -0
  19. package/coverage/lcov-report/components/PinInput/index.html +146 -0
  20. package/coverage/lcov-report/components/PinInput/index.tsx.html +268 -0
  21. package/coverage/lcov-report/components/PinInput/style.ts.html +247 -0
  22. package/coverage/lcov-report/components/Popper/index.html +131 -0
  23. package/coverage/lcov-report/components/Popper/index.tsx.html +346 -0
  24. package/coverage/lcov-report/components/Popper/styles.ts.html +205 -0
  25. package/coverage/lcov-report/components/SidePanel/index.html +131 -0
  26. package/coverage/lcov-report/components/SidePanel/index.tsx.html +343 -0
  27. package/coverage/lcov-report/components/SidePanel/style.ts.html +307 -0
  28. package/coverage/lcov-report/components/Tooltip/index.html +131 -0
  29. package/coverage/lcov-report/components/Tooltip/index.tsx.html +307 -0
  30. package/coverage/lcov-report/components/Tooltip/styles.ts.html +157 -0
  31. package/coverage/lcov-report/favicon.png +0 -0
  32. package/coverage/lcov-report/index.html +236 -0
  33. package/coverage/lcov-report/prettify.css +1 -0
  34. package/coverage/lcov-report/prettify.js +2 -0
  35. package/coverage/lcov-report/sort-arrow-sprite.png +0 -0
  36. package/coverage/lcov-report/sorter.js +196 -0
  37. package/coverage/lcov-report/styles/colors.ts.html +235 -0
  38. package/coverage/lcov-report/styles/index.html +176 -0
  39. package/coverage/lcov-report/styles/index.ts.html +103 -0
  40. package/coverage/lcov-report/styles/mixins.ts.html +355 -0
  41. package/coverage/lcov-report/styles/typography.ts.html +1105 -0
  42. package/coverage/lcov-report/styles/utils.ts.html +202 -0
  43. package/coverage/lcov.info +780 -0
  44. package/dist/cjs/components/Avatar/index.d.ts +5 -0
  45. package/dist/cjs/components/Avatar/styles.d.ts +4 -0
  46. package/dist/cjs/components/Avatar/typings.d.ts +19 -0
  47. package/dist/cjs/components/AvatarGroup/index.d.ts +5 -0
  48. package/dist/cjs/components/AvatarGroup/styles.d.ts +1 -0
  49. package/dist/cjs/components/AvatarGroup/typings.d.ts +19 -0
  50. package/dist/cjs/components/RewardOMeter/index.d.ts +5 -0
  51. package/dist/cjs/components/RewardOMeter/styles.d.ts +3 -0
  52. package/dist/cjs/components/RewardOMeter/typings.d.ts +22 -0
  53. package/dist/cjs/components/index.d.ts +4 -1
  54. package/dist/cjs/index.js +2 -2
  55. package/dist/cjs/index.js.map +1 -1
  56. package/dist/cjs/styles/colors.d.ts +5 -0
  57. package/dist/esm/components/Avatar/index.d.ts +5 -0
  58. package/dist/esm/components/Avatar/styles.d.ts +4 -0
  59. package/dist/esm/components/Avatar/typings.d.ts +19 -0
  60. package/dist/esm/components/AvatarGroup/index.d.ts +5 -0
  61. package/dist/esm/components/AvatarGroup/styles.d.ts +1 -0
  62. package/dist/esm/components/AvatarGroup/typings.d.ts +19 -0
  63. package/dist/esm/components/RewardOMeter/index.d.ts +5 -0
  64. package/dist/esm/components/RewardOMeter/styles.d.ts +3 -0
  65. package/dist/esm/components/RewardOMeter/typings.d.ts +22 -0
  66. package/dist/esm/components/index.d.ts +4 -1
  67. package/dist/esm/index.js +3 -3
  68. package/dist/esm/index.js.map +1 -1
  69. package/dist/esm/styles/colors.d.ts +5 -0
  70. package/dist/icons/icons.css +191 -185
  71. package/dist/icons/icons.eot +0 -0
  72. package/dist/icons/icons.html +18 -0
  73. package/dist/icons/icons.json +184 -182
  74. package/dist/icons/icons.ts +190 -182
  75. package/dist/icons/icons.woff +0 -0
  76. package/dist/icons/icons.woff2 +0 -0
  77. package/jest.config.js +15 -0
  78. package/package.json +21 -6
  79. package/tests/Accordion.test.tsx +40 -0
  80. package/tests/Avatar.test.tsx +76 -0
  81. package/tests/Button.test.tsx +35 -0
  82. package/tests/Input.test.tsx +39 -0
  83. package/tests/PinInput.test.tsx +89 -0
  84. package/tests/Popper.test.tsx +50 -0
  85. package/tests/RewardOMeter.test.tsx +73 -0
  86. package/tests/SearchInput.test.tsx +34 -0
  87. package/tests/Select.test.tsx +74 -0
  88. package/tests/SidePanel.test.tsx +74 -0
  89. package/tests/Tooltip.test.tsx +36 -0
  90. package/tests/__snapshots__/Accordion.test.tsx.snap +11 -0
  91. package/tests/__snapshots__/Button.test.tsx.snap +10 -0
  92. package/tests/__snapshots__/PinInput.test.tsx.snap +18 -0
  93. package/tests/__snapshots__/Popper.test.tsx.snap +15 -0
  94. package/tests/__snapshots__/SidePanel.test.tsx.snap +10 -0
@@ -0,0 +1,517 @@
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
+