@zajno/common 1.2.7 → 1.3.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (142) hide show
  1. package/coverage/clover.xml +357 -97
  2. package/coverage/coverage-final.json +19 -11
  3. package/coverage/lcov-report/index.html +34 -19
  4. package/coverage/lcov-report/src/__tests__/helpers/index.html +1 -1
  5. package/coverage/lcov-report/src/__tests__/helpers/main.ts.html +1 -1
  6. package/coverage/lcov-report/src/async/arrays.ts.html +5 -5
  7. package/coverage/lcov-report/src/async/index.html +1 -1
  8. package/coverage/lcov-report/src/dates/calc.ts.html +1 -1
  9. package/coverage/lcov-report/src/dates/convert.ts.html +1 -1
  10. package/coverage/lcov-report/src/dates/datex.ts.html +1 -1
  11. package/coverage/lcov-report/src/dates/format.ts.html +1 -1
  12. package/coverage/lcov-report/src/dates/index.html +1 -1
  13. package/coverage/lcov-report/src/dates/index.ts.html +1 -1
  14. package/coverage/lcov-report/src/dates/parse.ts.html +1 -1
  15. package/coverage/lcov-report/src/dates/period.ts.html +1 -1
  16. package/coverage/lcov-report/src/dates/shift.ts.html +1 -1
  17. package/coverage/lcov-report/src/dates/types.ts.html +1 -1
  18. package/coverage/lcov-report/src/dates/yearDate.ts.html +1 -1
  19. package/coverage/lcov-report/src/enumHelper.ts.html +11 -11
  20. package/coverage/lcov-report/src/event.ts.html +1 -1
  21. package/coverage/lcov-report/src/index.html +49 -19
  22. package/coverage/lcov-report/src/lazy.light.ts.html +155 -0
  23. package/coverage/lcov-report/src/logger/console.ts.html +1 -1
  24. package/coverage/lcov-report/src/logger/index.html +1 -1
  25. package/coverage/lcov-report/src/logger/index.ts.html +1 -1
  26. package/coverage/lcov-report/src/logger/named.ts.html +1 -1
  27. package/coverage/lcov-report/src/logger/proxy.ts.html +1 -1
  28. package/coverage/lcov-report/src/math/arrays.ts.html +1 -1
  29. package/coverage/lcov-report/src/math/calc.ts.html +1 -1
  30. package/coverage/lcov-report/src/math/distribution.ts.html +1 -1
  31. package/coverage/lcov-report/src/math/index.html +1 -1
  32. package/coverage/lcov-report/src/math/index.ts.html +1 -1
  33. package/coverage/lcov-report/src/transitionObserver.ts.html +57 -21
  34. package/coverage/lcov-report/src/types.ts.html +143 -0
  35. package/coverage/lcov-report/src/validation/ValidationErrors.ts.html +22 -22
  36. package/coverage/lcov-report/src/validation/creditCard.ts.html +4 -4
  37. package/coverage/lcov-report/src/validation/helpers.ts.html +6 -6
  38. package/coverage/lcov-report/src/validation/index.html +1 -1
  39. package/coverage/lcov-report/src/validation/index.ts.html +6 -6
  40. package/coverage/lcov-report/src/validation/types.ts.html +2 -2
  41. package/coverage/lcov-report/src/validation/validators.ts.html +5 -5
  42. package/coverage/lcov-report/src/validation/wrappers.ts.html +5 -5
  43. package/coverage/lcov-report/src/viewModels/FlagModel.ts.html +209 -0
  44. package/coverage/lcov-report/src/viewModels/LabeledFlagModel.ts.html +146 -0
  45. package/coverage/lcov-report/src/viewModels/MultiSelectModel.ts.html +542 -0
  46. package/coverage/lcov-report/src/viewModels/NumberModel.ts.html +188 -0
  47. package/coverage/lcov-report/src/viewModels/SelectModel.ts.html +455 -0
  48. package/coverage/lcov-report/src/viewModels/SelectViewModel.ts.html +434 -0
  49. package/coverage/lcov-report/src/viewModels/Validatable.ts.html +329 -0
  50. package/coverage/lcov-report/src/viewModels/index.html +186 -0
  51. package/coverage/lcov-report/src/viewModels/wrappers.ts.html +239 -0
  52. package/coverage/lcov.info +718 -147
  53. package/lib/timeHelper.d.ts +3 -0
  54. package/lib/timeHelper.d.ts.map +1 -1
  55. package/lib/timeHelper.js +3 -0
  56. package/lib/timeHelper.js.map +1 -1
  57. package/lib/transitionObserver.d.ts +1 -1
  58. package/lib/transitionObserver.d.ts.map +1 -1
  59. package/lib/transitionObserver.js +12 -2
  60. package/lib/transitionObserver.js.map +1 -1
  61. package/lib/types.d.ts +5 -0
  62. package/lib/types.d.ts.map +1 -1
  63. package/lib/types.js +14 -0
  64. package/lib/types.js.map +1 -1
  65. package/lib/viewModels/FlagModel.d.ts +19 -0
  66. package/lib/viewModels/FlagModel.d.ts.map +1 -0
  67. package/lib/viewModels/FlagModel.js +38 -0
  68. package/lib/viewModels/FlagModel.js.map +1 -0
  69. package/lib/viewModels/MultiSelectModel.d.ts +41 -0
  70. package/lib/viewModels/MultiSelectModel.d.ts.map +1 -0
  71. package/lib/viewModels/MultiSelectModel.js +153 -0
  72. package/lib/viewModels/MultiSelectModel.js.map +1 -0
  73. package/lib/viewModels/NumberModel.d.ts +16 -0
  74. package/lib/viewModels/NumberModel.d.ts.map +1 -0
  75. package/lib/viewModels/NumberModel.js +40 -0
  76. package/lib/viewModels/NumberModel.js.map +1 -0
  77. package/lib/viewModels/PromptModal.d.ts +31 -0
  78. package/lib/viewModels/PromptModal.d.ts.map +1 -0
  79. package/lib/viewModels/PromptModal.js +57 -0
  80. package/lib/viewModels/PromptModal.js.map +1 -0
  81. package/lib/viewModels/{SelectViewModel.d.ts → SelectModel.d.ts} +14 -8
  82. package/lib/viewModels/SelectModel.d.ts.map +1 -0
  83. package/lib/viewModels/SelectModel.js +109 -0
  84. package/lib/viewModels/SelectModel.js.map +1 -0
  85. package/lib/viewModels/{TextInputViewModel.d.ts → TextModel.d.ts} +10 -9
  86. package/lib/viewModels/TextModel.d.ts.map +1 -0
  87. package/lib/viewModels/{TextInputViewModel.js → TextModel.js} +8 -23
  88. package/lib/viewModels/TextModel.js.map +1 -0
  89. package/lib/viewModels/Validatable.d.ts +9 -7
  90. package/lib/viewModels/Validatable.d.ts.map +1 -1
  91. package/lib/viewModels/Validatable.js +22 -8
  92. package/lib/viewModels/Validatable.js.map +1 -1
  93. package/lib/viewModels/ValuesCollector.d.ts +28 -0
  94. package/lib/viewModels/ValuesCollector.d.ts.map +1 -0
  95. package/lib/viewModels/ValuesCollector.js +51 -0
  96. package/lib/viewModels/ValuesCollector.js.map +1 -0
  97. package/lib/viewModels/index.d.ts +7 -5
  98. package/lib/viewModels/index.d.ts.map +1 -1
  99. package/lib/viewModels/index.js +7 -5
  100. package/lib/viewModels/index.js.map +1 -1
  101. package/lib/viewModels/wrappers.d.ts +15 -0
  102. package/lib/viewModels/wrappers.d.ts.map +1 -0
  103. package/lib/viewModels/wrappers.js +43 -0
  104. package/lib/viewModels/wrappers.js.map +1 -0
  105. package/package.json +1 -1
  106. package/src/timeHelper.ts +3 -0
  107. package/src/transitionObserver.ts +14 -2
  108. package/src/types.ts +16 -0
  109. package/src/viewModels/FlagModel.ts +43 -0
  110. package/src/viewModels/MultiSelectModel.ts +154 -0
  111. package/src/viewModels/NumberModel.ts +36 -0
  112. package/src/viewModels/PromptModal.ts +65 -0
  113. package/src/viewModels/SelectModel.ts +125 -0
  114. package/src/viewModels/{TextInputViewModel.ts → TextModel.ts} +22 -26
  115. package/src/viewModels/Validatable.ts +26 -11
  116. package/src/viewModels/ValuesCollector.ts +84 -0
  117. package/src/viewModels/__tests__/multiSelect.test.ts +23 -0
  118. package/src/viewModels/__tests__/select.test.ts +71 -0
  119. package/src/viewModels/__tests__/wrappers.test.ts +79 -0
  120. package/src/viewModels/index.ts +9 -5
  121. package/src/viewModels/wrappers.ts +53 -0
  122. package/lib/viewModels/PromptModalViewModel.d.ts +0 -27
  123. package/lib/viewModels/PromptModalViewModel.d.ts.map +0 -1
  124. package/lib/viewModels/PromptModalViewModel.js +0 -56
  125. package/lib/viewModels/PromptModalViewModel.js.map +0 -1
  126. package/lib/viewModels/RadioButtonGroupViewModel.d.ts +0 -11
  127. package/lib/viewModels/RadioButtonGroupViewModel.d.ts.map +0 -1
  128. package/lib/viewModels/RadioButtonGroupViewModel.js +0 -51
  129. package/lib/viewModels/RadioButtonGroupViewModel.js.map +0 -1
  130. package/lib/viewModels/RadioButtonViewModel.d.ts +0 -9
  131. package/lib/viewModels/RadioButtonViewModel.d.ts.map +0 -1
  132. package/lib/viewModels/RadioButtonViewModel.js +0 -32
  133. package/lib/viewModels/RadioButtonViewModel.js.map +0 -1
  134. package/lib/viewModels/SelectViewModel.d.ts.map +0 -1
  135. package/lib/viewModels/SelectViewModel.js +0 -88
  136. package/lib/viewModels/SelectViewModel.js.map +0 -1
  137. package/lib/viewModels/TextInputViewModel.d.ts.map +0 -1
  138. package/lib/viewModels/TextInputViewModel.js.map +0 -1
  139. package/src/viewModels/PromptModalViewModel.ts +0 -71
  140. package/src/viewModels/RadioButtonGroupViewModel.ts +0 -47
  141. package/src/viewModels/RadioButtonViewModel.ts +0 -26
  142. package/src/viewModels/SelectViewModel.ts +0 -88
@@ -0,0 +1,542 @@
1
+
2
+ <!doctype html>
3
+ <html lang="en">
4
+
5
+ <head>
6
+ <title>Code coverage report for src/viewModels/MultiSelectModel.ts</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">src/viewModels</a> MultiSelectModel.ts</h1>
23
+ <div class='clearfix'>
24
+
25
+ <div class='fl pad1y space-right2'>
26
+ <span class="strong">47.87% </span>
27
+ <span class="quiet">Statements</span>
28
+ <span class='fraction'>45/94</span>
29
+ </div>
30
+
31
+
32
+ <div class='fl pad1y space-right2'>
33
+ <span class="strong">8.33% </span>
34
+ <span class="quiet">Branches</span>
35
+ <span class='fraction'>1/12</span>
36
+ </div>
37
+
38
+
39
+ <div class='fl pad1y space-right2'>
40
+ <span class="strong">21.62% </span>
41
+ <span class="quiet">Functions</span>
42
+ <span class='fraction'>8/37</span>
43
+ </div>
44
+
45
+
46
+ <div class='fl pad1y space-right2'>
47
+ <span class="strong">49.35% </span>
48
+ <span class="quiet">Lines</span>
49
+ <span class='fraction'>38/77</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
+ </div>
58
+ <div class='status-line low'></div>
59
+ <pre><table class="coverage">
60
+ <tr><td class="line-count quiet"><a name='L1'></a><a href='#L1'>1</a>
61
+ <a name='L2'></a><a href='#L2'>2</a>
62
+ <a name='L3'></a><a href='#L3'>3</a>
63
+ <a name='L4'></a><a href='#L4'>4</a>
64
+ <a name='L5'></a><a href='#L5'>5</a>
65
+ <a name='L6'></a><a href='#L6'>6</a>
66
+ <a name='L7'></a><a href='#L7'>7</a>
67
+ <a name='L8'></a><a href='#L8'>8</a>
68
+ <a name='L9'></a><a href='#L9'>9</a>
69
+ <a name='L10'></a><a href='#L10'>10</a>
70
+ <a name='L11'></a><a href='#L11'>11</a>
71
+ <a name='L12'></a><a href='#L12'>12</a>
72
+ <a name='L13'></a><a href='#L13'>13</a>
73
+ <a name='L14'></a><a href='#L14'>14</a>
74
+ <a name='L15'></a><a href='#L15'>15</a>
75
+ <a name='L16'></a><a href='#L16'>16</a>
76
+ <a name='L17'></a><a href='#L17'>17</a>
77
+ <a name='L18'></a><a href='#L18'>18</a>
78
+ <a name='L19'></a><a href='#L19'>19</a>
79
+ <a name='L20'></a><a href='#L20'>20</a>
80
+ <a name='L21'></a><a href='#L21'>21</a>
81
+ <a name='L22'></a><a href='#L22'>22</a>
82
+ <a name='L23'></a><a href='#L23'>23</a>
83
+ <a name='L24'></a><a href='#L24'>24</a>
84
+ <a name='L25'></a><a href='#L25'>25</a>
85
+ <a name='L26'></a><a href='#L26'>26</a>
86
+ <a name='L27'></a><a href='#L27'>27</a>
87
+ <a name='L28'></a><a href='#L28'>28</a>
88
+ <a name='L29'></a><a href='#L29'>29</a>
89
+ <a name='L30'></a><a href='#L30'>30</a>
90
+ <a name='L31'></a><a href='#L31'>31</a>
91
+ <a name='L32'></a><a href='#L32'>32</a>
92
+ <a name='L33'></a><a href='#L33'>33</a>
93
+ <a name='L34'></a><a href='#L34'>34</a>
94
+ <a name='L35'></a><a href='#L35'>35</a>
95
+ <a name='L36'></a><a href='#L36'>36</a>
96
+ <a name='L37'></a><a href='#L37'>37</a>
97
+ <a name='L38'></a><a href='#L38'>38</a>
98
+ <a name='L39'></a><a href='#L39'>39</a>
99
+ <a name='L40'></a><a href='#L40'>40</a>
100
+ <a name='L41'></a><a href='#L41'>41</a>
101
+ <a name='L42'></a><a href='#L42'>42</a>
102
+ <a name='L43'></a><a href='#L43'>43</a>
103
+ <a name='L44'></a><a href='#L44'>44</a>
104
+ <a name='L45'></a><a href='#L45'>45</a>
105
+ <a name='L46'></a><a href='#L46'>46</a>
106
+ <a name='L47'></a><a href='#L47'>47</a>
107
+ <a name='L48'></a><a href='#L48'>48</a>
108
+ <a name='L49'></a><a href='#L49'>49</a>
109
+ <a name='L50'></a><a href='#L50'>50</a>
110
+ <a name='L51'></a><a href='#L51'>51</a>
111
+ <a name='L52'></a><a href='#L52'>52</a>
112
+ <a name='L53'></a><a href='#L53'>53</a>
113
+ <a name='L54'></a><a href='#L54'>54</a>
114
+ <a name='L55'></a><a href='#L55'>55</a>
115
+ <a name='L56'></a><a href='#L56'>56</a>
116
+ <a name='L57'></a><a href='#L57'>57</a>
117
+ <a name='L58'></a><a href='#L58'>58</a>
118
+ <a name='L59'></a><a href='#L59'>59</a>
119
+ <a name='L60'></a><a href='#L60'>60</a>
120
+ <a name='L61'></a><a href='#L61'>61</a>
121
+ <a name='L62'></a><a href='#L62'>62</a>
122
+ <a name='L63'></a><a href='#L63'>63</a>
123
+ <a name='L64'></a><a href='#L64'>64</a>
124
+ <a name='L65'></a><a href='#L65'>65</a>
125
+ <a name='L66'></a><a href='#L66'>66</a>
126
+ <a name='L67'></a><a href='#L67'>67</a>
127
+ <a name='L68'></a><a href='#L68'>68</a>
128
+ <a name='L69'></a><a href='#L69'>69</a>
129
+ <a name='L70'></a><a href='#L70'>70</a>
130
+ <a name='L71'></a><a href='#L71'>71</a>
131
+ <a name='L72'></a><a href='#L72'>72</a>
132
+ <a name='L73'></a><a href='#L73'>73</a>
133
+ <a name='L74'></a><a href='#L74'>74</a>
134
+ <a name='L75'></a><a href='#L75'>75</a>
135
+ <a name='L76'></a><a href='#L76'>76</a>
136
+ <a name='L77'></a><a href='#L77'>77</a>
137
+ <a name='L78'></a><a href='#L78'>78</a>
138
+ <a name='L79'></a><a href='#L79'>79</a>
139
+ <a name='L80'></a><a href='#L80'>80</a>
140
+ <a name='L81'></a><a href='#L81'>81</a>
141
+ <a name='L82'></a><a href='#L82'>82</a>
142
+ <a name='L83'></a><a href='#L83'>83</a>
143
+ <a name='L84'></a><a href='#L84'>84</a>
144
+ <a name='L85'></a><a href='#L85'>85</a>
145
+ <a name='L86'></a><a href='#L86'>86</a>
146
+ <a name='L87'></a><a href='#L87'>87</a>
147
+ <a name='L88'></a><a href='#L88'>88</a>
148
+ <a name='L89'></a><a href='#L89'>89</a>
149
+ <a name='L90'></a><a href='#L90'>90</a>
150
+ <a name='L91'></a><a href='#L91'>91</a>
151
+ <a name='L92'></a><a href='#L92'>92</a>
152
+ <a name='L93'></a><a href='#L93'>93</a>
153
+ <a name='L94'></a><a href='#L94'>94</a>
154
+ <a name='L95'></a><a href='#L95'>95</a>
155
+ <a name='L96'></a><a href='#L96'>96</a>
156
+ <a name='L97'></a><a href='#L97'>97</a>
157
+ <a name='L98'></a><a href='#L98'>98</a>
158
+ <a name='L99'></a><a href='#L99'>99</a>
159
+ <a name='L100'></a><a href='#L100'>100</a>
160
+ <a name='L101'></a><a href='#L101'>101</a>
161
+ <a name='L102'></a><a href='#L102'>102</a>
162
+ <a name='L103'></a><a href='#L103'>103</a>
163
+ <a name='L104'></a><a href='#L104'>104</a>
164
+ <a name='L105'></a><a href='#L105'>105</a>
165
+ <a name='L106'></a><a href='#L106'>106</a>
166
+ <a name='L107'></a><a href='#L107'>107</a>
167
+ <a name='L108'></a><a href='#L108'>108</a>
168
+ <a name='L109'></a><a href='#L109'>109</a>
169
+ <a name='L110'></a><a href='#L110'>110</a>
170
+ <a name='L111'></a><a href='#L111'>111</a>
171
+ <a name='L112'></a><a href='#L112'>112</a>
172
+ <a name='L113'></a><a href='#L113'>113</a>
173
+ <a name='L114'></a><a href='#L114'>114</a>
174
+ <a name='L115'></a><a href='#L115'>115</a>
175
+ <a name='L116'></a><a href='#L116'>116</a>
176
+ <a name='L117'></a><a href='#L117'>117</a>
177
+ <a name='L118'></a><a href='#L118'>118</a>
178
+ <a name='L119'></a><a href='#L119'>119</a>
179
+ <a name='L120'></a><a href='#L120'>120</a>
180
+ <a name='L121'></a><a href='#L121'>121</a>
181
+ <a name='L122'></a><a href='#L122'>122</a>
182
+ <a name='L123'></a><a href='#L123'>123</a>
183
+ <a name='L124'></a><a href='#L124'>124</a>
184
+ <a name='L125'></a><a href='#L125'>125</a>
185
+ <a name='L126'></a><a href='#L126'>126</a>
186
+ <a name='L127'></a><a href='#L127'>127</a>
187
+ <a name='L128'></a><a href='#L128'>128</a>
188
+ <a name='L129'></a><a href='#L129'>129</a>
189
+ <a name='L130'></a><a href='#L130'>130</a>
190
+ <a name='L131'></a><a href='#L131'>131</a>
191
+ <a name='L132'></a><a href='#L132'>132</a>
192
+ <a name='L133'></a><a href='#L133'>133</a>
193
+ <a name='L134'></a><a href='#L134'>134</a>
194
+ <a name='L135'></a><a href='#L135'>135</a>
195
+ <a name='L136'></a><a href='#L136'>136</a>
196
+ <a name='L137'></a><a href='#L137'>137</a>
197
+ <a name='L138'></a><a href='#L138'>138</a>
198
+ <a name='L139'></a><a href='#L139'>139</a>
199
+ <a name='L140'></a><a href='#L140'>140</a>
200
+ <a name='L141'></a><a href='#L141'>141</a>
201
+ <a name='L142'></a><a href='#L142'>142</a>
202
+ <a name='L143'></a><a href='#L143'>143</a>
203
+ <a name='L144'></a><a href='#L144'>144</a>
204
+ <a name='L145'></a><a href='#L145'>145</a>
205
+ <a name='L146'></a><a href='#L146'>146</a>
206
+ <a name='L147'></a><a href='#L147'>147</a>
207
+ <a name='L148'></a><a href='#L148'>148</a>
208
+ <a name='L149'></a><a href='#L149'>149</a>
209
+ <a name='L150'></a><a href='#L150'>150</a>
210
+ <a name='L151'></a><a href='#L151'>151</a>
211
+ <a name='L152'></a><a href='#L152'>152</a>
212
+ <a name='L153'></a><a href='#L153'>153</a>
213
+ <a name='L154'></a><a href='#L154'>154</a>
214
+ <a name='L155'></a><a href='#L155'>155</a></td><td class="line-coverage quiet"><span class="cline-any cline-yes">1x</span>
215
+ <span class="cline-any cline-yes">1x</span>
216
+ <span class="cline-any cline-yes">1x</span>
217
+ <span class="cline-any cline-yes">1x</span>
218
+ <span class="cline-any cline-neutral">&nbsp;</span>
219
+ <span class="cline-any cline-yes">1x</span>
220
+ <span class="cline-any cline-neutral">&nbsp;</span>
221
+ <span class="cline-any cline-yes">1x</span>
222
+ <span class="cline-any cline-neutral">&nbsp;</span>
223
+ <span class="cline-any cline-neutral">&nbsp;</span>
224
+ <span class="cline-any cline-yes">3x</span>
225
+ <span class="cline-any cline-neutral">&nbsp;</span>
226
+ <span class="cline-any cline-yes">3x</span>
227
+ <span class="cline-any cline-yes">3x</span>
228
+ <span class="cline-any cline-neutral">&nbsp;</span>
229
+ <span class="cline-any cline-yes">3x</span>
230
+ <span class="cline-any cline-yes">3x</span>
231
+ <span class="cline-any cline-neutral">&nbsp;</span>
232
+ <span class="cline-any cline-neutral">&nbsp;</span>
233
+ <span class="cline-any cline-yes">3x</span>
234
+ <span class="cline-any cline-yes">3x</span>
235
+ <span class="cline-any cline-neutral">&nbsp;</span>
236
+ <span class="cline-any cline-neutral">&nbsp;</span>
237
+ <span class="cline-any cline-yes">3x</span>
238
+ <span class="cline-any cline-yes">3x</span>
239
+ <span class="cline-any cline-yes">3x</span>
240
+ <span class="cline-any cline-yes">3x</span>
241
+ <span class="cline-any cline-neutral">&nbsp;</span>
242
+ <span class="cline-any cline-neutral">&nbsp;</span>
243
+ <span class="cline-any cline-neutral">&nbsp;</span>
244
+ <span class="cline-any cline-yes">1x</span>
245
+ <span class="cline-any cline-neutral">&nbsp;</span>
246
+ <span class="cline-any cline-yes">1x</span>
247
+ <span class="cline-any cline-neutral">&nbsp;</span>
248
+ <span class="cline-any cline-no">&nbsp;</span>
249
+ <span class="cline-any cline-neutral">&nbsp;</span>
250
+ <span class="cline-any cline-neutral">&nbsp;</span>
251
+ <span class="cline-any cline-yes">1x</span>
252
+ <span class="cline-any cline-yes">4x</span>
253
+ <span class="cline-any cline-neutral">&nbsp;</span>
254
+ <span class="cline-any cline-neutral">&nbsp;</span>
255
+ <span class="cline-any cline-neutral">&nbsp;</span>
256
+ <span class="cline-any cline-yes">1x</span>
257
+ <span class="cline-any cline-no">&nbsp;</span>
258
+ <span class="cline-any cline-neutral">&nbsp;</span>
259
+ <span class="cline-any cline-neutral">&nbsp;</span>
260
+ <span class="cline-any cline-neutral">&nbsp;</span>
261
+ <span class="cline-any cline-yes">1x</span>
262
+ <span class="cline-any cline-no">&nbsp;</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-no">&nbsp;</span>
267
+ <span class="cline-any cline-no">&nbsp;</span>
268
+ <span class="cline-any cline-neutral">&nbsp;</span>
269
+ <span class="cline-any cline-yes">1x</span>
270
+ <span class="cline-any cline-no">&nbsp;</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-no">&nbsp;</span>
275
+ <span class="cline-any cline-neutral">&nbsp;</span>
276
+ <span class="cline-any cline-yes">3x</span>
277
+ <span class="cline-any cline-no">&nbsp;</span>
278
+ <span class="cline-any cline-no">&nbsp;</span>
279
+ <span class="cline-any cline-no">&nbsp;</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-neutral">&nbsp;</span>
283
+ <span class="cline-any cline-yes">3x</span>
284
+ <span class="cline-any cline-yes">3x</span>
285
+ <span class="cline-any cline-neutral">&nbsp;</span>
286
+ <span class="cline-any cline-neutral">&nbsp;</span>
287
+ <span class="cline-any cline-yes">3x</span>
288
+ <span class="cline-any cline-no">&nbsp;</span>
289
+ <span class="cline-any cline-neutral">&nbsp;</span>
290
+ <span class="cline-any cline-neutral">&nbsp;</span>
291
+ <span class="cline-any cline-yes">3x</span>
292
+ <span class="cline-any cline-no">&nbsp;</span>
293
+ <span class="cline-any cline-no">&nbsp;</span>
294
+ <span class="cline-any cline-no">&nbsp;</span>
295
+ <span class="cline-any cline-neutral">&nbsp;</span>
296
+ <span class="cline-any cline-neutral">&nbsp;</span>
297
+ <span class="cline-any cline-neutral">&nbsp;</span>
298
+ <span class="cline-any cline-yes">3x</span>
299
+ <span class="cline-any cline-yes">3x</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-yes">3x</span>
303
+ <span class="cline-any cline-no">&nbsp;</span>
304
+ <span class="cline-any cline-neutral">&nbsp;</span>
305
+ <span class="cline-any cline-neutral">&nbsp;</span>
306
+ <span class="cline-any cline-neutral">&nbsp;</span>
307
+ <span class="cline-any cline-yes">3x</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-no">&nbsp;</span>
313
+ <span class="cline-any cline-no">&nbsp;</span>
314
+ <span class="cline-any cline-neutral">&nbsp;</span>
315
+ <span class="cline-any cline-no">&nbsp;</span>
316
+ <span class="cline-any cline-neutral">&nbsp;</span>
317
+ <span class="cline-any cline-neutral">&nbsp;</span>
318
+ <span class="cline-any cline-no">&nbsp;</span>
319
+ <span class="cline-any cline-no">&nbsp;</span>
320
+ <span class="cline-any cline-neutral">&nbsp;</span>
321
+ <span class="cline-any cline-neutral">&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-no">&nbsp;</span>
325
+ <span class="cline-any cline-neutral">&nbsp;</span>
326
+ <span class="cline-any cline-no">&nbsp;</span>
327
+ <span class="cline-any cline-neutral">&nbsp;</span>
328
+ <span class="cline-any cline-neutral">&nbsp;</span>
329
+ <span class="cline-any cline-neutral">&nbsp;</span>
330
+ <span class="cline-any cline-yes">3x</span>
331
+ <span class="cline-any cline-no">&nbsp;</span>
332
+ <span class="cline-any cline-no">&nbsp;</span>
333
+ <span class="cline-any cline-neutral">&nbsp;</span>
334
+ <span class="cline-any cline-neutral">&nbsp;</span>
335
+ <span class="cline-any cline-neutral">&nbsp;</span>
336
+ <span class="cline-any cline-yes">3x</span>
337
+ <span class="cline-any cline-yes">3x</span>
338
+ <span class="cline-any cline-neutral">&nbsp;</span>
339
+ <span class="cline-any cline-yes">3x</span>
340
+ <span class="cline-any cline-no">&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-no">&nbsp;</span>
346
+ <span class="cline-any cline-neutral">&nbsp;</span>
347
+ <span class="cline-any cline-no">&nbsp;</span>
348
+ <span class="cline-any cline-neutral">&nbsp;</span>
349
+ <span class="cline-any cline-no">&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-no">&nbsp;</span>
354
+ <span class="cline-any cline-no">&nbsp;</span>
355
+ <span class="cline-any cline-neutral">&nbsp;</span>
356
+ <span class="cline-any cline-no">&nbsp;</span>
357
+ <span class="cline-any cline-neutral">&nbsp;</span>
358
+ <span class="cline-any cline-no">&nbsp;</span>
359
+ <span class="cline-any cline-neutral">&nbsp;</span>
360
+ <span class="cline-any cline-neutral">&nbsp;</span>
361
+ <span class="cline-any cline-neutral">&nbsp;</span>
362
+ <span class="cline-any cline-yes">1x</span>
363
+ <span class="cline-any cline-neutral">&nbsp;</span>
364
+ <span class="cline-any cline-neutral">&nbsp;</span>
365
+ <span class="cline-any cline-no">&nbsp;</span>
366
+ <span class="cline-any cline-neutral">&nbsp;</span>
367
+ <span class="cline-any cline-neutral">&nbsp;</span>
368
+ <span class="cline-any cline-neutral">&nbsp;</span></td><td class="text"><pre class="prettyprint lang-js">import { createLazy } from '../lazy.light';
369
+ import { action, computed, makeObservable, observable, reaction } from 'mobx';
370
+ import { FlagModel, ILabeledFlagModel } from './FlagModel';
371
+ import { ValidatableModel } from './Validatable';
372
+ import { IValueModel } from './ValuesCollector';
373
+ import { withLabel } from './wrappers';
374
+ &nbsp;
375
+ export class MultiSelect&lt;T = any&gt; extends ValidatableModel&lt;ReadonlyArray&lt;T&gt;&gt; implements IValueModel&lt;readonly string[]&gt; {
376
+ &nbsp;
377
+ @observable
378
+ private readonly _indexes = new Set&lt;number&gt;();
379
+ &nbsp;
380
+ public readonly opened = new FlagModel();
381
+ private readonly _initial: number[] = null;
382
+ &nbsp;
383
+ private readonly _flags = createLazy(<span class="fstat-no" title="function not covered" >() =</span>&gt; <span class="cstat-no" title="statement not covered" >this.createFlags())</span>;
384
+ private _indexesLocked = false;
385
+ &nbsp;
386
+ constructor(
387
+ private readonly _items: readonly T[],
388
+ private readonly _accessor: (item: T) =&gt; string,
389
+ ...selected: number[]
390
+ ) {
391
+ super();
392
+ makeObservable(this);
393
+ this._initial = selected;
394
+ this.setInitialIndexes();
395
+ }
396
+ &nbsp;
397
+ @computed
398
+ get selectedIndexes(): ReadonlyArray&lt;number&gt; { return Array.from(this._indexes); }
399
+ &nbsp;
400
+ get items(): ReadonlyArray&lt;T&gt; { return this._items; }
401
+ &nbsp;
402
+ <span class="fstat-no" title="function not covered" > get f</span>lags() { <span class="cstat-no" title="statement not covered" >return this._flags.value; </span>}
403
+ &nbsp;
404
+ @computed
405
+ get values(): ReadonlyArray&lt;string&gt; {
406
+ return this._items.map(i =&gt; this._accessor(i));
407
+ }
408
+ &nbsp;
409
+ @computed
410
+ <span class="fstat-no" title="function not covered" > get s</span>electedItems(): ReadonlyArray&lt;T&gt; {
411
+ <span class="cstat-no" title="statement not covered" > return this.selectedIndexes.map(<span class="fstat-no" title="function not covered" >i </span>=&gt; <span class="cstat-no" title="statement not covered" >this._items[i])</span>;</span>
412
+ }
413
+ &nbsp;
414
+ @computed
415
+ <span class="fstat-no" title="function not covered" > get s</span>electedValues(): ReadonlyArray&lt;string&gt; {
416
+ const values = <span class="cstat-no" title="statement not covered" >this.values;</span>
417
+ <span class="cstat-no" title="statement not covered" > return this.selectedIndexes.map(<span class="fstat-no" title="function not covered" >i </span>=&gt; <span class="cstat-no" title="statement not covered" >values[i])</span>;</span>
418
+ }
419
+ &nbsp;
420
+ <span class="fstat-no" title="function not covered" > get v</span>alue() { <span class="cstat-no" title="statement not covered" >return this.selectedValues; </span>}
421
+ <span class="fstat-no" title="function not covered" > set v</span>alue(v: readonly string[]) { <span class="cstat-no" title="statement not covered" >this.selectValues(v); </span>}
422
+ &nbsp;
423
+ isIndexSelected(index: number) { return this._indexes.has(index); }
424
+ <span class="fstat-no" title="function not covered" > isValueSelected(</span>value: string) { <span class="cstat-no" title="statement not covered" >return this.values.includes(value); </span>}
425
+ &nbsp;
426
+ <span class="fstat-no" title="function not covered" > get i</span>sEmpty() { <span class="cstat-no" title="statement not covered" >return this._indexes.size === 0; </span>}
427
+ &nbsp;
428
+ <span class="fstat-no" title="function not covered" > protected get v</span>alueToValidate() { <span class="cstat-no" title="statement not covered" >return this.selectedItems; </span>}
429
+ &nbsp;
430
+ setItemSelected = <span class="fstat-no" title="function not covered" >(i</span>tem: T, selected: boolean) =&gt; {
431
+ const i = <span class="cstat-no" title="statement not covered" >this.items.indexOf(item);</span>
432
+ <span class="cstat-no" title="statement not covered" > if (i &gt;= 0) {</span>
433
+ <span class="cstat-no" title="statement not covered" > this.setIndexSelected(i, selected);</span>
434
+ }
435
+ };
436
+ &nbsp;
437
+ selectItem = <span class="fstat-no" title="function not covered" >(i</span>tem: T) =&gt; <span class="cstat-no" title="statement not covered" >this.setItemSelected(item, true);</span>
438
+ deSelectItem = <span class="fstat-no" title="function not covered" >(i</span>tem: T) =&gt; <span class="cstat-no" title="statement not covered" >this.setItemSelected(item, false);</span>
439
+ &nbsp;
440
+ @action
441
+ selectItems = <span class="fstat-no" title="function not covered" >(i</span>tems: readonly T[]) =&gt; {
442
+ <span class="cstat-no" title="statement not covered" > items.forEach(this.selectItem);</span>
443
+ };
444
+ &nbsp;
445
+ setValueSelected = <span class="fstat-no" title="function not covered" >(v</span>alue: string, selected: boolean) =&gt; {
446
+ const i = <span class="cstat-no" title="statement not covered" >this.values.indexOf(value);</span>
447
+ <span class="cstat-no" title="statement not covered" > if (i &gt;= 0) {</span>
448
+ <span class="cstat-no" title="statement not covered" > this.setIndexSelected(i, selected);</span>
449
+ }
450
+ };
451
+ &nbsp;
452
+ selectValue = <span class="fstat-no" title="function not covered" >(v</span>alue: string) =&gt; <span class="cstat-no" title="statement not covered" >this.setValueSelected(value, true);</span>
453
+ deSelectValue = <span class="fstat-no" title="function not covered" >(v</span>alue: string) =&gt; <span class="cstat-no" title="statement not covered" >this.setValueSelected(value, false);</span>
454
+ &nbsp;
455
+ @action
456
+ selectValues = <span class="fstat-no" title="function not covered" >(v</span>alues: readonly string[]) =&gt; {
457
+ <span class="cstat-no" title="statement not covered" > values.forEach(this.selectValue);</span>
458
+ };
459
+ &nbsp;
460
+ @action
461
+ setIndexSelected = <span class="fstat-no" title="function not covered" >(i</span>ndex: number, selected: boolean) =&gt; {
462
+ <span class="cstat-no" title="statement not covered" > if (this._indexesLocked) {</span>
463
+ <span class="cstat-no" title="statement not covered" > return;</span>
464
+ }
465
+ &nbsp;
466
+ <span class="cstat-no" title="statement not covered" > if (selected) {</span>
467
+ <span class="cstat-no" title="statement not covered" > this._indexes.add(index);</span>
468
+ } else {
469
+ <span class="cstat-no" title="statement not covered" > this._indexes.delete(index);</span>
470
+ }
471
+ &nbsp;
472
+ <span class="cstat-no" title="statement not covered" > if (!this._flags.hasValue) {</span>
473
+ <span class="cstat-no" title="statement not covered" > return;</span>
474
+ }
475
+ &nbsp;
476
+ <span class="cstat-no" title="statement not covered" > try {</span>
477
+ <span class="cstat-no" title="statement not covered" > this._indexesLocked = true;</span>
478
+ <span class="cstat-no" title="statement not covered" > this._flags.value[index].value = selected;</span>
479
+ } finally {
480
+ <span class="cstat-no" title="statement not covered" > this._indexesLocked = false;</span>
481
+ }
482
+ };
483
+ &nbsp;
484
+ reset = <span class="fstat-no" title="function not covered" >() =</span>&gt; {
485
+ <span class="cstat-no" title="statement not covered" > super.reset();</span>
486
+ <span class="cstat-no" title="statement not covered" > this.setInitialIndexes();</span>
487
+ };
488
+ &nbsp;
489
+ private setInitialIndexes() {
490
+ this._indexes.clear();
491
+ this._initial.forEach(i =&gt; this._indexes.add(i));
492
+ &nbsp;
493
+ <span class="missing-if-branch" title="if path not taken" >I</span>if (this._flags.hasValue) {
494
+ <span class="cstat-no" title="statement not covered" > this._flags.value.forEach(<span class="fstat-no" title="function not covered" >(f</span>lag, index) =&gt; <span class="cstat-no" title="statement not covered" >flag.value = this._indexes.has(index))</span>;</span>
495
+ }
496
+ }
497
+ &nbsp;
498
+ private <span class="fstat-no" title="function not covered" >createFlags(</span>) {
499
+ const flags: ReadonlyArray&lt;ILabeledFlagModel&gt; = <span class="cstat-no" title="statement not covered" >this._items</span>
500
+ .map(<span class="fstat-no" title="function not covered" >(i</span>tem, index) =&gt; {
501
+ const flag = <span class="cstat-no" title="statement not covered" >withLabel(</span>
502
+ new FlagModel(this._indexes.has(index)),
503
+ <span class="fstat-no" title="function not covered" > () =</span>&gt; <span class="cstat-no" title="statement not covered" >this._accessor(item),</span>
504
+ );
505
+ &nbsp;
506
+ // react on every flag is changed directly
507
+ <span class="cstat-no" title="statement not covered" > reaction(<span class="fstat-no" title="function not covered" >() =</span>&gt; <span class="cstat-no" title="statement not covered" >flag.value,</span> <span class="fstat-no" title="function not covered" >isSelected </span>=&gt; {</span>
508
+ <span class="cstat-no" title="statement not covered" > this.setIndexSelected(index, isSelected);</span>
509
+ });
510
+ <span class="cstat-no" title="statement not covered" > return flag;</span>
511
+ });
512
+ <span class="cstat-no" title="statement not covered" > return flags;</span>
513
+ }
514
+ }
515
+ &nbsp;
516
+ export class MultiSelectString&lt;T extends string = string&gt; extends MultiSelect&lt;T&gt; {
517
+ &nbsp;
518
+ <span class="fstat-no" title="function not covered" > constructor(i</span>tems: ReadonlyArray&lt;T&gt;, ...selected: number[]) {
519
+ <span class="cstat-no" title="statement not covered" > super(items, <span class="fstat-no" title="function not covered" >v </span>=&gt; <span class="cstat-no" title="statement not covered" >v,</span> ...selected);</span>
520
+ }
521
+ }
522
+ &nbsp;</pre></td></tr></table></pre>
523
+
524
+ <div class='push'></div><!-- for sticky footer -->
525
+ </div><!-- /wrapper -->
526
+ <div class='footer quiet pad2 space-top1 center small'>
527
+ Code coverage generated by
528
+ <a href="https://istanbul.js.org/" target="_blank">istanbul</a>
529
+ at Tue Nov 23 2021 22:28:10 GMT+0000 (Coordinated Universal Time)
530
+ </div>
531
+ </div>
532
+ <script src="../../prettify.js"></script>
533
+ <script>
534
+ window.onload = function () {
535
+ prettyPrint();
536
+ };
537
+ </script>
538
+ <script src="../../sorter.js"></script>
539
+ <script src="../../block-navigation.js"></script>
540
+ </body>
541
+ </html>
542
+