@zajno/common 1.3.2 → 1.3.6

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 (93) hide show
  1. package/.github/workflows/CI.yml +8 -0
  2. package/coverage/clover.xml +195 -141
  3. package/coverage/coverage-final.json +40 -39
  4. package/coverage/lcov-report/index.html +39 -24
  5. package/coverage/lcov-report/src/__tests__/helpers/index.html +1 -1
  6. package/coverage/lcov-report/src/__tests__/helpers/main.ts.html +1 -1
  7. package/coverage/lcov-report/src/async/arrays.ts.html +1 -1
  8. package/coverage/lcov-report/src/async/index.html +1 -1
  9. package/coverage/lcov-report/src/dates/calc.ts.html +1 -1
  10. package/coverage/lcov-report/src/dates/convert.ts.html +1 -1
  11. package/coverage/lcov-report/src/dates/datex.ts.html +1 -1
  12. package/coverage/lcov-report/src/dates/format.ts.html +1 -1
  13. package/coverage/lcov-report/src/dates/index.html +1 -1
  14. package/coverage/lcov-report/src/dates/index.ts.html +1 -1
  15. package/coverage/lcov-report/src/dates/parse.ts.html +1 -1
  16. package/coverage/lcov-report/src/dates/period.ts.html +1 -1
  17. package/coverage/lcov-report/src/dates/shift.ts.html +1 -1
  18. package/coverage/lcov-report/src/dates/types.ts.html +1 -1
  19. package/coverage/lcov-report/src/dates/yearDate.ts.html +1 -1
  20. package/coverage/lcov-report/src/enumHelper.ts.html +1 -1
  21. package/coverage/lcov-report/src/event.ts.html +1 -1
  22. package/coverage/lcov-report/src/fields/index.html +111 -0
  23. package/coverage/lcov-report/src/{viewModels/SelectViewModel.ts.html → fields/update.ts.html} +119 -182
  24. package/coverage/lcov-report/src/index.html +1 -1
  25. package/coverage/lcov-report/src/lazy.light.ts.html +3 -3
  26. package/coverage/lcov-report/src/logger/batch.ts.html +1 -1
  27. package/coverage/lcov-report/src/logger/console.ts.html +1 -1
  28. package/coverage/lcov-report/src/logger/index.html +1 -1
  29. package/coverage/lcov-report/src/logger/index.ts.html +1 -1
  30. package/coverage/lcov-report/src/logger/named.ts.html +1 -1
  31. package/coverage/lcov-report/src/logger/proxy.ts.html +1 -1
  32. package/coverage/lcov-report/src/math/arrays.ts.html +32 -8
  33. package/coverage/lcov-report/src/math/calc.ts.html +1 -1
  34. package/coverage/lcov-report/src/math/distribution.ts.html +1 -1
  35. package/coverage/lcov-report/src/math/index.html +11 -11
  36. package/coverage/lcov-report/src/math/index.ts.html +1 -1
  37. package/coverage/lcov-report/src/transitionObserver.ts.html +1 -1
  38. package/coverage/lcov-report/src/types.ts.html +4 -4
  39. package/coverage/lcov-report/src/validation/ValidationErrors.ts.html +1 -1
  40. package/coverage/lcov-report/src/validation/creditCard.ts.html +1 -1
  41. package/coverage/lcov-report/src/validation/helpers.ts.html +1 -1
  42. package/coverage/lcov-report/src/validation/index.html +1 -1
  43. package/coverage/lcov-report/src/validation/index.ts.html +1 -1
  44. package/coverage/lcov-report/src/validation/types.ts.html +1 -1
  45. package/coverage/lcov-report/src/validation/validators.ts.html +1 -1
  46. package/coverage/lcov-report/src/validation/wrappers.ts.html +1 -1
  47. package/coverage/lcov-report/src/viewModels/FlagModel.ts.html +6 -6
  48. package/coverage/lcov-report/src/viewModels/MultiSelectModel.ts.html +104 -95
  49. package/coverage/lcov-report/src/viewModels/NumberModel.ts.html +1 -1
  50. package/coverage/lcov-report/src/viewModels/SelectModel.ts.html +1 -1
  51. package/coverage/lcov-report/src/viewModels/Validatable.ts.html +45 -21
  52. package/coverage/lcov-report/src/viewModels/index.html +30 -30
  53. package/coverage/lcov-report/src/viewModels/wrappers.ts.html +1 -1
  54. package/coverage/lcov-report/{enumHelper.ts.html → update.ts.html} +118 -193
  55. package/coverage/lcov.info +347 -207
  56. package/lib/fields/update.d.ts +17 -6
  57. package/lib/fields/update.d.ts.map +1 -1
  58. package/lib/fields/update.js +29 -13
  59. package/lib/fields/update.js.map +1 -1
  60. package/lib/ident.d.ts +6 -0
  61. package/lib/ident.d.ts.map +1 -0
  62. package/lib/ident.js +3 -0
  63. package/lib/ident.js.map +1 -0
  64. package/lib/math/arrays.d.ts +2 -1
  65. package/lib/math/arrays.d.ts.map +1 -1
  66. package/lib/math/arrays.js +9 -1
  67. package/lib/math/arrays.js.map +1 -1
  68. package/lib/viewModels/MultiSelectModel.d.ts +2 -0
  69. package/lib/viewModels/MultiSelectModel.d.ts.map +1 -1
  70. package/lib/viewModels/MultiSelectModel.js +3 -1
  71. package/lib/viewModels/MultiSelectModel.js.map +1 -1
  72. package/lib/viewModels/PromptModal.d.ts.map +1 -1
  73. package/lib/viewModels/PromptModal.js +1 -1
  74. package/lib/viewModels/PromptModal.js.map +1 -1
  75. package/lib/viewModels/Validatable.d.ts +2 -1
  76. package/lib/viewModels/Validatable.d.ts.map +1 -1
  77. package/lib/viewModels/Validatable.js +7 -0
  78. package/lib/viewModels/Validatable.js.map +1 -1
  79. package/package.json +1 -1
  80. package/src/fields/__tests__/fields.update.test.ts +73 -0
  81. package/src/fields/update.ts +54 -20
  82. package/src/ident.ts +8 -0
  83. package/src/math/arrays.ts +9 -1
  84. package/src/viewModels/MultiSelectModel.ts +4 -1
  85. package/src/viewModels/PromptModal.ts +1 -1
  86. package/src/viewModels/Validatable.ts +8 -0
  87. package/src/viewModels/__tests__/multiSelect.test.ts +127 -12
  88. package/coverage/lcov-report/NumberModel.ts.html +0 -188
  89. package/coverage/lcov-report/arrays.ts.html +0 -602
  90. package/coverage/lcov-report/calc.ts.html +0 -278
  91. package/coverage/lcov-report/src/viewModels/LabeledFlagModel.ts.html +0 -137
  92. package/coverage/lcov-report/src/viewModels/labeled.ts.html +0 -128
  93. package/coverage/lcov-report/transitionObserver.ts.html +0 -536
@@ -38,6 +38,14 @@ export abstract class ValidatableModel<T = string> {
38
38
  return this;
39
39
  }
40
40
 
41
+ public async testValidate(value: T) {
42
+ if (this._validator) {
43
+ const res = await this._validator(value);
44
+ return res;
45
+ }
46
+ return null;
47
+ }
48
+
41
49
  async validate() {
42
50
  if (!this._validator) {
43
51
  return true;
@@ -1,23 +1,138 @@
1
- import { MultiSelect } from '../MultiSelectModel';
1
+ import { reaction, toJS } from 'mobx';
2
+ import { arrayRepeat } from '../../math';
3
+ import { MultiSelect, MultiSelectString } from '../MultiSelectModel';
4
+
5
+ type SetType<T> = { items: T[], selected: number[], accessor: (item: T) => string };
2
6
 
3
7
  describe('MultiSelectModel', () => {
4
- it('consistent', () => {
8
+ it('creates', () => {
5
9
  expect(() => new MultiSelect(null, null).values).toThrow();
6
10
  expect(() => new MultiSelect([1], null).values).toThrow();
11
+ });
12
+
13
+ const sets: SetType<any>[] = [
14
+ { items: [1, 2, 3], selected: [1], accessor: i => `_${i}_` },
15
+ { items: [1, 2, 3], selected: [], accessor: i => `_${i}_` },
16
+ { items: ['a', 'b', 'c'], selected: [2], accessor: i => i },
17
+ ];
18
+
19
+ describe('consistent', () => {
20
+ sets.forEach((set, setIndex) => {
21
+ it(`variant ${setIndex + 1}`, () => {
22
+ const items = set.items; // [1, 2, 3];
23
+ const accessor = set.accessor; // (i: number) => `_${i}_`;
24
+ const initialSelected = set.selected; // [1];
25
+ const values = items.map(accessor);
26
+ const selectedValues = initialSelected.map(i => accessor(items[i]));
7
27
 
8
- const items = [1, 2, 3];
9
- const accessor = (i: number) => `_${i}_`;
10
- const values = items.map(accessor);
11
- const initialSelected = [1];
28
+ const vm = new MultiSelect(items, accessor, ...initialSelected);
12
29
 
13
- const vm = new MultiSelect(items, accessor, ...initialSelected);
30
+ expect(vm.items).toStrictEqual(items);
31
+ expect(vm.values).toStrictEqual(values);
32
+ expect(vm.count).toBe(items.length);
33
+ expect(vm.selectedCount).toBe(initialSelected.length);
34
+ expect(vm.selectedIndexes).toStrictEqual(initialSelected);
35
+ expect(vm.selectedValues).toStrictEqual(selectedValues);
14
36
 
15
- expect(vm.items).toStrictEqual(items);
16
- expect(vm.values).toStrictEqual(values);
17
- expect(vm.selectedIndexes).toStrictEqual(initialSelected);
37
+ initialSelected.forEach(index => {
38
+ expect(vm.isIndexSelected(index)).toBe(initialSelected.includes(index));
39
+ });
18
40
 
19
- initialSelected.forEach(index => {
20
- expect(vm.isIndexSelected(index)).toBe(initialSelected.includes(index));
41
+ values.forEach((value) => {
42
+ expect(vm.isValueSelected(value)).toBe(selectedValues.includes(value));
43
+ });
44
+ });
21
45
  });
46
+
47
+ });
48
+
49
+ it('reacts', () => {
50
+ const vm = new MultiSelectString(['a', 'b', 'c']);
51
+
52
+ expect(vm.count).toBe(3);
53
+ expect(vm.selectedCount).toBe(0);
54
+ expect(vm.selectedIndexes).toHaveLength(0);
55
+
56
+ const mocks = arrayRepeat(() => jest.fn().mockImplementation(null), 5);
57
+ const [
58
+ onSelectedIndexes,
59
+ onSelectedItems,
60
+ onSelectedValues,
61
+ onIsIndexSelected,
62
+ onIsValueSelected,
63
+ ] = mocks;
64
+
65
+ const wrapMock = mock => ((a: any) => mock(toJS(a)));
66
+
67
+ const expectEmptyCalls = () => {
68
+ expect(onSelectedIndexes).toHaveBeenCalledWith([]);
69
+ expect(onSelectedItems).toHaveBeenCalledWith([]);
70
+ expect(onSelectedValues).toHaveBeenCalledWith([]);
71
+ mocks.forEach(m => m.mockClear());
72
+ };
73
+
74
+ reaction(() => vm.selectedIndexes, wrapMock(onSelectedIndexes));
75
+ reaction(() => vm.selectedItems, wrapMock(onSelectedItems));
76
+ reaction(() => vm.selectedValues, wrapMock(onSelectedValues));
77
+
78
+ // initially – 'false', so expect only when 'true' should be passed
79
+ reaction(() => vm.isIndexSelected(0), wrapMock(onIsIndexSelected));
80
+ reaction(() => vm.isValueSelected('a'), wrapMock(onIsValueSelected));
81
+
82
+ vm.selectIndex(1);
83
+
84
+ expect(onSelectedIndexes).toHaveBeenCalledWith([1]);
85
+ expect(onSelectedItems).toHaveBeenCalledWith(['b']);
86
+ expect(onSelectedValues).toHaveBeenCalledWith(['b']);
87
+ expect(onIsIndexSelected).not.toHaveBeenCalled();
88
+ expect(onIsValueSelected).not.toHaveBeenCalled();
89
+ mocks.forEach(m => m.mockClear());
90
+
91
+ vm.deSelectIndex(1);
92
+ expect(onIsIndexSelected).not.toHaveBeenCalled();
93
+ expect(onIsValueSelected).not.toHaveBeenCalled();
94
+ expectEmptyCalls();
95
+
96
+ vm.selectItem('c');
97
+
98
+ expect(onSelectedIndexes).toHaveBeenCalledWith([2]);
99
+ expect(onSelectedItems).toHaveBeenCalledWith(['c']);
100
+ expect(onSelectedValues).toHaveBeenCalledWith(['c']);
101
+ expect(onIsIndexSelected).not.toHaveBeenCalled();
102
+ expect(onIsValueSelected).not.toHaveBeenCalled();
103
+ mocks.forEach(m => m.mockClear());
104
+
105
+ vm.deSelectItem('c');
106
+ expect(onIsIndexSelected).not.toHaveBeenCalled();
107
+ expect(onIsValueSelected).not.toHaveBeenCalled();
108
+ expectEmptyCalls();
109
+
110
+ vm.selectValue('a');
111
+
112
+ expect(onSelectedIndexes).toHaveBeenCalledWith([0]);
113
+ expect(onSelectedItems).toHaveBeenCalledWith(['a']);
114
+ expect(onSelectedValues).toHaveBeenCalledWith(['a']);
115
+ expect(onIsIndexSelected).toHaveBeenCalledWith(true);
116
+ expect(onIsValueSelected).toHaveBeenCalledWith(true);
117
+ mocks.forEach(m => m.mockClear());
118
+
119
+ vm.deSelectValue('a');
120
+ expect(onIsIndexSelected).toHaveBeenCalledWith(false);
121
+ expect(onIsValueSelected).toHaveBeenCalledWith(false);
122
+ expectEmptyCalls();
123
+
124
+ vm.selectItems(['a', 'b']);
125
+
126
+ expect(onSelectedIndexes).toHaveBeenCalledWith([0, 1]);
127
+ expect(onSelectedItems).toHaveBeenCalledWith(['a', 'b']);
128
+ expect(onSelectedValues).toHaveBeenCalledWith(['a', 'b']);
129
+ expect(onIsIndexSelected).toHaveBeenCalledWith(true);
130
+ expect(onIsValueSelected).toHaveBeenCalledWith(true);
131
+ mocks.forEach(m => m.mockClear());
132
+
133
+ vm.reset();
134
+ expect(onIsIndexSelected).toHaveBeenCalledWith(false);
135
+ expect(onIsValueSelected).toHaveBeenCalledWith(false);
136
+ expectEmptyCalls();
22
137
  });
23
138
  });
@@ -1,188 +0,0 @@
1
-
2
- <!doctype html>
3
- <html lang="en">
4
-
5
- <head>
6
- <title>Code coverage report for NumberModel.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> NumberModel.ts</h1>
23
- <div class='clearfix'>
24
-
25
- <div class='fl pad1y space-right2'>
26
- <span class="strong">80% </span>
27
- <span class="quiet">Statements</span>
28
- <span class='fraction'>16/20</span>
29
- </div>
30
-
31
-
32
- <div class='fl pad1y space-right2'>
33
- <span class="strong">0% </span>
34
- <span class="quiet">Branches</span>
35
- <span class='fraction'>0/3</span>
36
- </div>
37
-
38
-
39
- <div class='fl pad1y space-right2'>
40
- <span class="strong">33.33% </span>
41
- <span class="quiet">Functions</span>
42
- <span class='fraction'>2/6</span>
43
- </div>
44
-
45
-
46
- <div class='fl pad1y space-right2'>
47
- <span class="strong">85.71% </span>
48
- <span class="quiet">Lines</span>
49
- <span class='fraction'>12/14</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 high'></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></td><td class="line-coverage quiet"><span class="cline-any cline-yes">1x</span>
97
- <span class="cline-any cline-neutral">&nbsp;</span>
98
- <span class="cline-any cline-neutral">&nbsp;</span>
99
- <span class="cline-any cline-neutral">&nbsp;</span>
100
- <span class="cline-any cline-neutral">&nbsp;</span>
101
- <span class="cline-any cline-neutral">&nbsp;</span>
102
- <span class="cline-any cline-neutral">&nbsp;</span>
103
- <span class="cline-any cline-yes">1x</span>
104
- <span class="cline-any cline-neutral">&nbsp;</span>
105
- <span class="cline-any cline-neutral">&nbsp;</span>
106
- <span class="cline-any cline-yes">1x</span>
107
- <span class="cline-any cline-neutral">&nbsp;</span>
108
- <span class="cline-any cline-yes">1x</span>
109
- <span class="cline-any cline-neutral">&nbsp;</span>
110
- <span class="cline-any cline-neutral">&nbsp;</span>
111
- <span class="cline-any cline-yes">1x</span>
112
- <span class="cline-any cline-yes">1x</span>
113
- <span class="cline-any cline-yes">1x</span>
114
- <span class="cline-any cline-neutral">&nbsp;</span>
115
- <span class="cline-any cline-neutral">&nbsp;</span>
116
- <span class="cline-any cline-yes">1x</span>
117
- <span class="cline-any cline-no">&nbsp;</span>
118
- <span class="cline-any cline-neutral">&nbsp;</span>
119
- <span class="cline-any cline-neutral">&nbsp;</span>
120
- <span class="cline-any cline-yes">1x</span>
121
- <span class="cline-any cline-no">&nbsp;</span>
122
- <span class="cline-any cline-neutral">&nbsp;</span>
123
- <span class="cline-any cline-neutral">&nbsp;</span>
124
- <span class="cline-any cline-neutral">&nbsp;</span>
125
- <span class="cline-any cline-yes">1x</span>
126
- <span class="cline-any cline-neutral">&nbsp;</span>
127
- <span class="cline-any cline-neutral">&nbsp;</span>
128
- <span class="cline-any cline-yes">1x</span>
129
- <span class="cline-any cline-neutral">&nbsp;</span>
130
- <span class="cline-any cline-neutral">&nbsp;</span>
131
- <span class="cline-any cline-yes">1x</span>
132
- <span class="cline-any cline-neutral">&nbsp;</span></td><td class="text"><pre class="prettyprint lang-js">import { action, makeObservable, observable } from 'mobx';
133
- import { IValueModel } from './ValuesCollector';
134
- &nbsp;
135
- export interface INumberModel {
136
- value: number;
137
- }
138
- &nbsp;
139
- export class NumberModel implements INumberModel, IValueModel&lt;number&gt; {
140
- &nbsp;
141
- @observable
142
- private _value: number = 0;
143
- &nbsp;
144
- private _initial: number = 0;
145
- &nbsp;
146
- constructor(initial: number = <span class="branch-0 cbranch-no" title="branch not covered" >0)</span> {
147
- makeObservable(this);
148
- this._initial = initial;
149
- this._value = this._initial;
150
- }
151
- &nbsp;
152
- get value() { return this._value; }
153
- <span class="fstat-no" title="function not covered" > set v</span>alue(v: number) { <span class="cstat-no" title="statement not covered" >this._value = v; </span>}
154
- &nbsp;
155
- @action
156
- reset = <span class="fstat-no" title="function not covered" >() =</span>&gt; {
157
- <span class="cstat-no" title="statement not covered" > this._value = this._initial;</span>
158
- };
159
- &nbsp;
160
- @action
161
- increment = <span class="fstat-no" title="function not covered" >(d</span> = <span class="branch-0 cbranch-no" title="branch not covered" >1)</span> =&gt; <span class="cstat-no" title="statement not covered" >this.value += d;</span>
162
- &nbsp;
163
- @action
164
- decrement = <span class="fstat-no" title="function not covered" >(d</span> = <span class="branch-0 cbranch-no" title="branch not covered" >1)</span> =&gt; <span class="cstat-no" title="statement not covered" >this.value -= d;</span>
165
- }
166
- &nbsp;
167
- export default NumberModel;
168
- &nbsp;</pre></td></tr></table></pre>
169
-
170
- <div class='push'></div><!-- for sticky footer -->
171
- </div><!-- /wrapper -->
172
- <div class='footer quiet pad2 space-top1 center small'>
173
- Code coverage generated by
174
- <a href="https://istanbul.js.org/" target="_blank">istanbul</a>
175
- at Sun Nov 21 2021 10:42:03 GMT+0000 (Coordinated Universal Time)
176
- </div>
177
- </div>
178
- <script src="prettify.js"></script>
179
- <script>
180
- window.onload = function () {
181
- prettyPrint();
182
- };
183
- </script>
184
- <script src="sorter.js"></script>
185
- <script src="block-navigation.js"></script>
186
- </body>
187
- </html>
188
-