@pie-lib/controller-utils 0.2.24 → 0.2.27

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.
package/CHANGELOG.md CHANGED
@@ -3,7 +3,7 @@
3
3
  All notable changes to this project will be documented in this file.
4
4
  See [Conventional Commits](https://conventionalcommits.org) for commit guidelines.
5
5
 
6
- ## [0.2.24](https://github.com/pie-framework/pie-lib/compare/@pie-lib/controller-utils@0.2.23...@pie-lib/controller-utils@0.2.24) (2021-02-15)
6
+ ## [0.2.27](https://github.com/pie-framework/pie-lib/compare/@pie-lib/controller-utils@0.2.26...@pie-lib/controller-utils@0.2.27) (2022-11-23)
7
7
 
8
8
  **Note:** Version bump only for package @pie-lib/controller-utils
9
9
 
@@ -11,233 +11,132 @@ See [Conventional Commits](https://conventionalcommits.org) for commit guideline
11
11
 
12
12
 
13
13
 
14
- ## [0.2.23](https://github.com/pie-framework/pie-lib/compare/@pie-lib/controller-utils@0.2.21...@pie-lib/controller-utils@0.2.23) (2021-02-15)
14
+ ## [0.2.26](https://github.com/pie-framework/pie-lib/compare/@pie-lib/controller-utils@0.2.24...@pie-lib/controller-utils@0.2.26) (2021-06-25)
15
15
 
16
16
  **Note:** Version bump only for package @pie-lib/controller-utils
17
17
 
18
+ ## [0.2.24](https://github.com/pie-framework/pie-lib/compare/@pie-lib/controller-utils@0.2.23...@pie-lib/controller-utils@0.2.24) (2021-02-15)
18
19
 
20
+ **Note:** Version bump only for package @pie-lib/controller-utils
19
21
 
22
+ ## [0.2.23](https://github.com/pie-framework/pie-lib/compare/@pie-lib/controller-utils@0.2.21...@pie-lib/controller-utils@0.2.23) (2021-02-15)
20
23
 
24
+ **Note:** Version bump only for package @pie-lib/controller-utils
21
25
 
22
26
  ## [0.2.21](https://github.com/pie-framework/pie-lib/compare/@pie-lib/controller-utils@0.2.20...@pie-lib/controller-utils@0.2.21) (2020-08-25)
23
27
 
24
28
  **Note:** Version bump only for package @pie-lib/controller-utils
25
29
 
26
-
27
-
28
-
29
-
30
30
  ## [0.2.20](https://github.com/pie-framework/pie-lib/compare/@pie-lib/controller-utils@0.2.19...@pie-lib/controller-utils@0.2.20) (2020-08-25)
31
31
 
32
32
  **Note:** Version bump only for package @pie-lib/controller-utils
33
33
 
34
-
35
-
36
-
37
-
38
34
  ## [0.2.19](https://github.com/pie-framework/pie-lib/compare/@pie-lib/controller-utils@0.2.18...@pie-lib/controller-utils@0.2.19) (2020-08-11)
39
35
 
40
36
  **Note:** Version bump only for package @pie-lib/controller-utils
41
37
 
42
-
43
-
44
-
45
-
46
38
  ## [0.2.18](https://github.com/pie-framework/pie-lib/compare/@pie-lib/controller-utils@0.2.17...@pie-lib/controller-utils@0.2.18) (2020-04-14)
47
39
 
48
40
  **Note:** Version bump only for package @pie-lib/controller-utils
49
41
 
50
-
51
-
52
-
53
-
54
42
  ## [0.2.17](https://github.com/pie-framework/pie-lib/compare/@pie-lib/controller-utils@0.2.16...@pie-lib/controller-utils@0.2.17) (2020-04-08)
55
43
 
56
44
  **Note:** Version bump only for package @pie-lib/controller-utils
57
45
 
58
-
59
-
60
-
61
-
62
46
  ## [0.2.16](https://github.com/pie-framework/pie-lib/compare/@pie-lib/controller-utils@0.2.15...@pie-lib/controller-utils@0.2.16) (2020-03-31)
63
47
 
64
-
65
48
  ### Bug Fixes
66
49
 
67
- * rm ExportNamespaceSpecifier ([970e2ed](https://github.com/pie-framework/pie-lib/commit/970e2ed))
68
-
69
-
70
-
71
-
50
+ - rm ExportNamespaceSpecifier ([970e2ed](https://github.com/pie-framework/pie-lib/commit/970e2ed))
72
51
 
73
52
  ## [0.2.15](https://github.com/pie-framework/pie-lib/compare/@pie-lib/controller-utils@0.2.14...@pie-lib/controller-utils@0.2.15) (2020-03-31)
74
53
 
75
54
  **Note:** Version bump only for package @pie-lib/controller-utils
76
55
 
77
-
78
-
79
-
80
-
81
56
  ## [0.2.14](https://github.com/pie-framework/pie-lib/compare/@pie-lib/controller-utils@0.2.13...@pie-lib/controller-utils@0.2.14) (2020-03-31)
82
57
 
83
58
  **Note:** Version bump only for package @pie-lib/controller-utils
84
59
 
85
-
86
-
87
-
88
-
89
60
  ## [0.2.13](https://github.com/pie-framework/pie-lib/compare/@pie-lib/controller-utils@0.2.12...@pie-lib/controller-utils@0.2.13) (2020-03-30)
90
61
 
91
62
  **Note:** Version bump only for package @pie-lib/controller-utils
92
63
 
93
-
94
-
95
-
96
-
97
64
  ## [0.2.12](https://github.com/pie-framework/pie-lib/compare/@pie-lib/controller-utils@0.2.11...@pie-lib/controller-utils@0.2.12) (2020-03-30)
98
65
 
99
66
  **Note:** Version bump only for package @pie-lib/controller-utils
100
67
 
101
-
102
-
103
-
104
-
105
68
  ## [0.2.11](https://github.com/pie-framework/pie-lib/compare/@pie-lib/controller-utils@0.2.10...@pie-lib/controller-utils@0.2.11) (2020-03-30)
106
69
 
107
70
  **Note:** Version bump only for package @pie-lib/controller-utils
108
71
 
109
-
110
-
111
-
112
-
113
72
  ## [0.2.10](https://github.com/pie-framework/pie-lib/compare/@pie-lib/controller-utils@0.2.9...@pie-lib/controller-utils@0.2.10) (2020-03-30)
114
73
 
115
74
  **Note:** Version bump only for package @pie-lib/controller-utils
116
75
 
117
-
118
-
119
-
120
-
121
76
  ## [0.2.9](https://github.com/pie-framework/pie-lib/compare/@pie-lib/controller-utils@0.2.8...@pie-lib/controller-utils@0.2.9) (2020-03-30)
122
77
 
123
78
  **Note:** Version bump only for package @pie-lib/controller-utils
124
79
 
125
-
126
-
127
-
128
-
129
80
  ## [0.2.8](https://github.com/pie-framework/pie-lib/compare/@pie-lib/controller-utils@0.2.7...@pie-lib/controller-utils@0.2.8) (2020-03-30)
130
81
 
131
82
  **Note:** Version bump only for package @pie-lib/controller-utils
132
83
 
133
-
134
-
135
-
136
-
137
84
  ## [0.2.7](https://github.com/pie-framework/pie-lib/compare/@pie-lib/controller-utils@0.2.6...@pie-lib/controller-utils@0.2.7) (2020-03-30)
138
85
 
139
-
140
86
  ### Bug Fixes
141
87
 
142
- * add module prop to package.json ([694b106](https://github.com/pie-framework/pie-lib/commit/694b106))
143
-
144
-
145
-
146
-
88
+ - add module prop to package.json ([694b106](https://github.com/pie-framework/pie-lib/commit/694b106))
147
89
 
148
90
  ## [0.2.6](https://github.com/pie-framework/pie-lib/compare/@pie-lib/controller-utils@0.2.5...@pie-lib/controller-utils@0.2.6) (2020-03-29)
149
91
 
150
-
151
92
  ### Bug Fixes
152
93
 
153
- * add module prop to package.json ([8a1b445](https://github.com/pie-framework/pie-lib/commit/8a1b445))
154
-
155
-
156
-
157
-
94
+ - add module prop to package.json ([8a1b445](https://github.com/pie-framework/pie-lib/commit/8a1b445))
158
95
 
159
96
  ## [0.2.5](https://github.com/pie-framework/pie-lib/compare/@pie-lib/controller-utils@0.2.4...@pie-lib/controller-utils@0.2.5) (2020-01-27)
160
97
 
161
98
  **Note:** Version bump only for package @pie-lib/controller-utils
162
99
 
163
-
164
-
165
-
166
-
167
100
  ## [0.2.4](https://github.com/pie-framework/pie-lib/compare/@pie-lib/controller-utils@0.2.3...@pie-lib/controller-utils@0.2.4) (2020-01-16)
168
101
 
169
-
170
102
  ### Bug Fixes
171
103
 
172
- * Updated using the given documentation. ([14c7b98](https://github.com/pie-framework/pie-lib/commit/14c7b98))
173
-
174
-
175
-
176
-
104
+ - Updated using the given documentation. ([14c7b98](https://github.com/pie-framework/pie-lib/commit/14c7b98))
177
105
 
178
106
  ## [0.2.3](https://github.com/pie-framework/pie-lib/compare/@pie-lib/controller-utils@0.2.2...@pie-lib/controller-utils@0.2.3) (2019-11-18)
179
107
 
180
-
181
108
  ### Bug Fixes
182
109
 
183
- * allow number 0 to be used as value in shuffledValues ([874127c](https://github.com/pie-framework/pie-lib/commit/874127c))
184
-
185
-
186
-
187
-
110
+ - allow number 0 to be used as value in shuffledValues ([874127c](https://github.com/pie-framework/pie-lib/commit/874127c))
188
111
 
189
112
  ## [0.2.2](https://github.com/pie-framework/pie-lib/compare/@pie-lib/controller-utils@0.2.1...@pie-lib/controller-utils@0.2.2) (2019-10-15)
190
113
 
191
-
192
114
  ### Bug Fixes
193
115
 
194
- * rm async ([3e96db3](https://github.com/pie-framework/pie-lib/commit/3e96db3))
195
-
196
-
197
-
198
-
116
+ - rm async ([3e96db3](https://github.com/pie-framework/pie-lib/commit/3e96db3))
199
117
 
200
118
  ## [0.2.1](https://github.com/pie-framework/pie-lib/compare/@pie-lib/controller-utils@0.2.0...@pie-lib/controller-utils@0.2.1) (2019-10-10)
201
119
 
202
-
203
120
  ### Bug Fixes
204
121
 
205
- * fix handling and saving of bad shuffled values [ch4723] ([186ff87](https://github.com/pie-framework/pie-lib/commit/186ff87))
206
-
207
-
208
-
209
-
122
+ - fix handling and saving of bad shuffled values [ch4723](<[186ff87](https://github.com/pie-framework/pie-lib/commit/186ff87)>)
210
123
 
211
124
  # [0.2.0](https://github.com/pie-framework/pie-lib/compare/@pie-lib/controller-utils@0.1.2...@pie-lib/controller-utils@0.2.0) (2019-08-30)
212
125
 
213
-
214
126
  ### Features
215
127
 
216
- * implement a shuffle/persistence reusable method ([33cc7f3](https://github.com/pie-framework/pie-lib/commit/33cc7f3))
217
-
218
-
219
-
220
-
128
+ - implement a shuffle/persistence reusable method ([33cc7f3](https://github.com/pie-framework/pie-lib/commit/33cc7f3))
221
129
 
222
130
  ## [0.1.2](https://github.com/pie-framework/pie-lib/compare/@pie-lib/controller-utils@0.1.1...@pie-lib/controller-utils@0.1.2) (2019-04-05)
223
131
 
224
132
  **Note:** Version bump only for package @pie-lib/controller-utils
225
133
 
226
-
227
-
228
-
229
-
230
134
  ## [0.1.1](https://github.com/pie-framework/pie-lib/compare/@pie-lib/controller-utils@0.1.0...@pie-lib/controller-utils@0.1.1) (2019-04-04)
231
135
 
232
136
  **Note:** Version bump only for package @pie-lib/controller-utils
233
137
 
234
-
235
-
236
-
237
-
238
138
  # 0.1.0 (2019-04-02)
239
139
 
240
-
241
140
  ### Features
242
141
 
243
- * new package controller-utils ([0994a4b](https://github.com/pie-framework/pie-lib/commit/0994a4b))
142
+ - new package controller-utils ([0994a4b](https://github.com/pie-framework/pie-lib/commit/0994a4b))
package/lib/index.js CHANGED
@@ -1,18 +1,20 @@
1
1
  "use strict";
2
2
 
3
+ var _typeof = require("@babel/runtime/helpers/typeof");
4
+
3
5
  Object.defineProperty(exports, "__esModule", {
4
6
  value: true
5
7
  });
6
- Object.defineProperty(exports, "lockChoices", {
8
+ Object.defineProperty(exports, "getShuffledChoices", {
7
9
  enumerable: true,
8
10
  get: function get() {
9
- return _persistence.lockChoices;
11
+ return _persistence.getShuffledChoices;
10
12
  }
11
13
  });
12
- Object.defineProperty(exports, "getShuffledChoices", {
14
+ Object.defineProperty(exports, "lockChoices", {
13
15
  enumerable: true,
14
16
  get: function get() {
15
- return _persistence.getShuffledChoices;
17
+ return _persistence.lockChoices;
16
18
  }
17
19
  });
18
20
  exports.partialScoring = void 0;
@@ -23,5 +25,7 @@ exports.partialScoring = partialScoring;
23
25
 
24
26
  var _persistence = require("./persistence");
25
27
 
26
- function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } else { var newObj = {}; if (obj != null) { for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) { var desc = Object.defineProperty && Object.getOwnPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : {}; if (desc.get || desc.set) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } } newObj["default"] = obj; return newObj; } }
28
+ function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
29
+
30
+ function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== "object" && typeof obj !== "function") { return { "default": obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj["default"] = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
27
31
  //# sourceMappingURL=index.js.map
package/lib/index.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/index.js"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;AAAA;;;;AACA","sourcesContent":["import * as partialScoring from './partial-scoring';\nexport { lockChoices, getShuffledChoices } from './persistence';\nexport { partialScoring };\n"],"file":"index.js"}
1
+ {"version":3,"sources":["../src/index.js"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;AAAA;;;;AACA","sourcesContent":["import * as partialScoring from './partial-scoring';\nexport { lockChoices, getShuffledChoices } from './persistence';\nexport { partialScoring };\n"],"file":"index.js"}
@@ -1,5 +1,7 @@
1
1
  "use strict";
2
2
 
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+
3
5
  Object.defineProperty(exports, "__esModule", {
4
6
  value: true
5
7
  });
@@ -7,8 +9,6 @@ exports.enabled = void 0;
7
9
 
8
10
  var _lodash = _interopRequireDefault(require("lodash"));
9
11
 
10
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
11
-
12
12
  var enabled = function enabled(config, env, defaultValue) {
13
13
  // if model.partialScoring = false
14
14
  // - if env.partialScoring = false || env.partialScoring = true => use dichotomous scoring
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/partial-scoring.js"],"names":["enabled","config","env","defaultValue","partialScoring","_","isBoolean"],"mappings":";;;;;;;AAAA;;;;AAEO,IAAMA,OAAO,GAAG,SAAVA,OAAU,CAACC,MAAD,EAASC,GAAT,EAAcC,YAAd,EAA+B;AACpD;AACA;AACA;AACA;AACA;AACAF,EAAAA,MAAM,GAAGA,MAAM,IAAI,EAAnB;AACAC,EAAAA,GAAG,GAAGA,GAAG,IAAI,EAAb;;AAEA,MAAID,MAAM,CAACG,cAAP,KAA0B,KAA9B,EAAqC;AACnC,WAAO,KAAP;AACD;;AAED,MAAIF,GAAG,CAACE,cAAJ,KAAuB,KAA3B,EAAkC;AAChC,WAAO,KAAP;AACD;;AAED,SAAOC,mBAAEC,SAAF,CAAYH,YAAZ,IAA4BA,YAA5B,GAA2C,IAAlD;AACD,CAlBM","sourcesContent":["import _ from 'lodash';\n\nexport const enabled = (config, env, defaultValue) => {\n // if model.partialScoring = false\n // - if env.partialScoring = false || env.partialScoring = true => use dichotomous scoring\n // else if model.partialScoring = true || undefined\n // - if env.partialScoring = false, use dichotomous scoring\n // - else if env.partialScoring = true, use partial scoring\n config = config || {};\n env = env || {};\n\n if (config.partialScoring === false) {\n return false;\n }\n\n if (env.partialScoring === false) {\n return false;\n }\n\n return _.isBoolean(defaultValue) ? defaultValue : true;\n};\n"],"file":"partial-scoring.js"}
1
+ {"version":3,"sources":["../src/partial-scoring.js"],"names":["enabled","config","env","defaultValue","partialScoring","_","isBoolean"],"mappings":";;;;;;;;;AAAA;;AAEO,IAAMA,OAAO,GAAG,SAAVA,OAAU,CAACC,MAAD,EAASC,GAAT,EAAcC,YAAd,EAA+B;AACpD;AACA;AACA;AACA;AACA;AACAF,EAAAA,MAAM,GAAGA,MAAM,IAAI,EAAnB;AACAC,EAAAA,GAAG,GAAGA,GAAG,IAAI,EAAb;;AAEA,MAAID,MAAM,CAACG,cAAP,KAA0B,KAA9B,EAAqC;AACnC,WAAO,KAAP;AACD;;AAED,MAAIF,GAAG,CAACE,cAAJ,KAAuB,KAA3B,EAAkC;AAChC,WAAO,KAAP;AACD;;AAED,SAAOC,mBAAEC,SAAF,CAAYH,YAAZ,IAA4BA,YAA5B,GAA2C,IAAlD;AACD,CAlBM","sourcesContent":["import _ from 'lodash';\n\nexport const enabled = (config, env, defaultValue) => {\n // if model.partialScoring = false\n // - if env.partialScoring = false || env.partialScoring = true => use dichotomous scoring\n // else if model.partialScoring = true || undefined\n // - if env.partialScoring = false, use dichotomous scoring\n // - else if env.partialScoring = true, use partial scoring\n config = config || {};\n env = env || {};\n\n if (config.partialScoring === false) {\n return false;\n }\n\n if (env.partialScoring === false) {\n return false;\n }\n\n return _.isBoolean(defaultValue) ? defaultValue : true;\n};\n"],"file":"partial-scoring.js"}
@@ -1,10 +1,14 @@
1
1
  "use strict";
2
2
 
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+
3
5
  Object.defineProperty(exports, "__esModule", {
4
6
  value: true
5
7
  });
6
8
  exports.lockChoices = exports.getShuffledChoices = exports.compact = void 0;
7
9
 
10
+ var _typeof2 = _interopRequireDefault(require("@babel/runtime/helpers/typeof"));
11
+
8
12
  var _get = _interopRequireDefault(require("lodash/get"));
9
13
 
10
14
  var _shuffle = _interopRequireDefault(require("lodash/shuffle"));
@@ -15,10 +19,6 @@ var _isNull = _interopRequireDefault(require("lodash/isNull"));
15
19
 
16
20
  var _isUndefined = _interopRequireDefault(require("lodash/isUndefined"));
17
21
 
18
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
19
-
20
- function _typeof(obj) { if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof(obj); }
21
-
22
22
  // eslint-disable-next-line no-console
23
23
  var lg = function lg(n) {
24
24
  return console[n].bind(console, 'controller-utils:');
@@ -43,7 +43,7 @@ exports.compact = compact;
43
43
 
44
44
  var getShuffledChoices = function getShuffledChoices(choices, session, updateSession, choiceKey) {
45
45
  return new Promise(function (resolve) {
46
- log('updateSession type: ', _typeof(updateSession));
46
+ log('updateSession type: ', (0, _typeof2["default"])(updateSession));
47
47
  log('session: ', session);
48
48
  var currentShuffled = compact((session || {}).shuffledValues);
49
49
 
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/persistence.js"],"names":["lg","n","console","bind","debug","log","warn","error","compact","arr","Array","isArray","filter","v","getShuffledChoices","choices","session","updateSession","choiceKey","Promise","resolve","currentShuffled","shuffledValues","undefined","map","find","c","shuffledChoices","id","element","JSON","stringify","e","hasShuffledValues","s","lockChoices","model","env","lockChoiceOrder","role"],"mappings":"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","sourcesContent":["import get from 'lodash/get';\nimport shuffle from 'lodash/shuffle';\nimport isEmpty from 'lodash/isEmpty';\nimport isNull from 'lodash/isNull';\nimport isUndefined from 'lodash/isUndefined';\n\n// eslint-disable-next-line no-console\nconst lg = n => console[n].bind(console, 'controller-utils:');\nconst debug = lg('debug');\nconst log = lg('log');\nconst warn = lg('warn');\nconst error = lg('error');\n\nexport const compact = arr => {\n if (Array.isArray(arr)) {\n return arr.filter(v => !isNull(v) && !isUndefined(v));\n }\n return arr;\n};\n\nexport const getShuffledChoices = (choices, session, updateSession, choiceKey) =>\n new Promise(resolve => {\n log('updateSession type: ', typeof updateSession);\n log('session: ', session);\n\n const currentShuffled = compact((session || {}).shuffledValues);\n\n if (!session) {\n // eslint-disable-next-line quotes\n warn(\"unable to save shuffled choices because there's no session.\");\n resolve(undefined);\n } else if (!isEmpty(currentShuffled)) {\n debug('use shuffledValues to sort the choices...', session.shuffledValues);\n resolve(compact(currentShuffled.map(v => choices.find(c => c[choiceKey] === v))));\n } else {\n const shuffledChoices = shuffle(choices);\n\n if (updateSession && typeof updateSession === 'function') {\n try {\n //Note: session.id refers to the id of the element within a session\n const shuffledValues = compact(shuffledChoices.map(c => c[choiceKey]));\n log('try to save shuffledValues to session...', shuffledValues);\n log('call updateSession... ', session.id, session.element);\n if (isEmpty(shuffledValues)) {\n error(\n `shuffledValues is an empty array? - refusing to call updateSession: shuffledChoices: ${JSON.stringify(\n shuffledChoices\n )}, key: ${choiceKey}`\n );\n } else {\n updateSession(session.id, session.element, { shuffledValues }).catch(e =>\n // eslint-disable-next-line no-console\n console.error('update session failed for: ', session.id, e)\n );\n }\n } catch (e) {\n warn('unable to save shuffled order for choices');\n error(e);\n }\n } else {\n warn('unable to save shuffled choices, shuffle will happen every time.');\n }\n //save this shuffle to the session for later retrieval\n resolve(shuffledChoices);\n }\n });\n\nconst hasShuffledValues = s => !!(s || {}).shuffledValues;\n\n/**\n * If we return:\n * - true - that means that the order of the choices will be ordinal (as is created in the configure item)\n * - false - that means the getShuffledChoices above will be called and that in turn means that we either\n * return the shuffled values on the session (if any exists) or we shuffle the choices\n * @param model - model to check if we should lock order\n * @param session - session to check if we should lock order\n * @param env - env to check if we should lock order\n * @returns {boolean}\n */\nexport const lockChoices = (model, session, env) => {\n if (model.lockChoiceOrder) {\n return true;\n }\n\n log('lockChoiceOrder: ', get(env, ['@pie-element', 'lockChoiceOrder'], false));\n\n if (get(env, ['@pie-element', 'lockChoiceOrder'], false)) {\n return true;\n }\n\n const role = get(env, 'role', 'student');\n\n if (role === 'instructor') {\n // TODO: .. in the future the instructor can toggle between ordinal and shuffled here, so keeping this code until then\n /*const alreadyShuffled = hasShuffledValues(session);\n\n if (alreadyShuffled) {\n return false;\n }\n\n return true;*/\n return true;\n }\n\n // here it's a student, so don't lock and it will shuffle if needs be\n return false;\n};\n"],"file":"persistence.js"}
1
+ {"version":3,"sources":["../src/persistence.js"],"names":["lg","n","console","bind","debug","log","warn","error","compact","arr","Array","isArray","filter","v","getShuffledChoices","choices","session","updateSession","choiceKey","Promise","resolve","currentShuffled","shuffledValues","undefined","map","find","c","shuffledChoices","id","element","JSON","stringify","e","hasShuffledValues","s","lockChoices","model","env","lockChoiceOrder","role"],"mappings":"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","sourcesContent":["import get from 'lodash/get';\nimport shuffle from 'lodash/shuffle';\nimport isEmpty from 'lodash/isEmpty';\nimport isNull from 'lodash/isNull';\nimport isUndefined from 'lodash/isUndefined';\n\n// eslint-disable-next-line no-console\nconst lg = (n) => console[n].bind(console, 'controller-utils:');\nconst debug = lg('debug');\nconst log = lg('log');\nconst warn = lg('warn');\nconst error = lg('error');\n\nexport const compact = (arr) => {\n if (Array.isArray(arr)) {\n return arr.filter((v) => !isNull(v) && !isUndefined(v));\n }\n return arr;\n};\n\nexport const getShuffledChoices = (choices, session, updateSession, choiceKey) =>\n new Promise((resolve) => {\n log('updateSession type: ', typeof updateSession);\n log('session: ', session);\n\n const currentShuffled = compact((session || {}).shuffledValues);\n\n if (!session) {\n // eslint-disable-next-line quotes\n warn(\"unable to save shuffled choices because there's no session.\");\n resolve(undefined);\n } else if (!isEmpty(currentShuffled)) {\n debug('use shuffledValues to sort the choices...', session.shuffledValues);\n resolve(compact(currentShuffled.map((v) => choices.find((c) => c[choiceKey] === v))));\n } else {\n const shuffledChoices = shuffle(choices);\n\n if (updateSession && typeof updateSession === 'function') {\n try {\n //Note: session.id refers to the id of the element within a session\n const shuffledValues = compact(shuffledChoices.map((c) => c[choiceKey]));\n log('try to save shuffledValues to session...', shuffledValues);\n log('call updateSession... ', session.id, session.element);\n if (isEmpty(shuffledValues)) {\n error(\n `shuffledValues is an empty array? - refusing to call updateSession: shuffledChoices: ${JSON.stringify(\n shuffledChoices,\n )}, key: ${choiceKey}`,\n );\n } else {\n updateSession(session.id, session.element, { shuffledValues }).catch((e) =>\n // eslint-disable-next-line no-console\n console.error('update session failed for: ', session.id, e),\n );\n }\n } catch (e) {\n warn('unable to save shuffled order for choices');\n error(e);\n }\n } else {\n warn('unable to save shuffled choices, shuffle will happen every time.');\n }\n //save this shuffle to the session for later retrieval\n resolve(shuffledChoices);\n }\n });\n\nconst hasShuffledValues = (s) => !!(s || {}).shuffledValues;\n\n/**\n * If we return:\n * - true - that means that the order of the choices will be ordinal (as is created in the configure item)\n * - false - that means the getShuffledChoices above will be called and that in turn means that we either\n * return the shuffled values on the session (if any exists) or we shuffle the choices\n * @param model - model to check if we should lock order\n * @param session - session to check if we should lock order\n * @param env - env to check if we should lock order\n * @returns {boolean}\n */\nexport const lockChoices = (model, session, env) => {\n if (model.lockChoiceOrder) {\n return true;\n }\n\n log('lockChoiceOrder: ', get(env, ['@pie-element', 'lockChoiceOrder'], false));\n\n if (get(env, ['@pie-element', 'lockChoiceOrder'], false)) {\n return true;\n }\n\n const role = get(env, 'role', 'student');\n\n if (role === 'instructor') {\n // TODO: .. in the future the instructor can toggle between ordinal and shuffled here, so keeping this code until then\n /*const alreadyShuffled = hasShuffledValues(session);\n\n if (alreadyShuffled) {\n return false;\n }\n\n return true;*/\n return true;\n }\n\n // here it's a student, so don't lock and it will shuffle if needs be\n return false;\n};\n"],"file":"persistence.js"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@pie-lib/controller-utils",
3
- "version": "0.2.24",
3
+ "version": "0.2.27",
4
4
  "description": "",
5
5
  "main": "lib/index.js",
6
6
  "module": "src/index.js",
@@ -14,5 +14,5 @@
14
14
  "scripts": {},
15
15
  "author": "",
16
16
  "license": "ISC",
17
- "gitHead": "e6de0d62291ecfdeb3a62b988c526d97ee41eaa6"
17
+ "gitHead": "f81076118e63884db5f5d65a41cff9aad111137e"
18
18
  }
@@ -5,21 +5,21 @@ import isNull from 'lodash/isNull';
5
5
  import isUndefined from 'lodash/isUndefined';
6
6
 
7
7
  // eslint-disable-next-line no-console
8
- const lg = n => console[n].bind(console, 'controller-utils:');
8
+ const lg = (n) => console[n].bind(console, 'controller-utils:');
9
9
  const debug = lg('debug');
10
10
  const log = lg('log');
11
11
  const warn = lg('warn');
12
12
  const error = lg('error');
13
13
 
14
- export const compact = arr => {
14
+ export const compact = (arr) => {
15
15
  if (Array.isArray(arr)) {
16
- return arr.filter(v => !isNull(v) && !isUndefined(v));
16
+ return arr.filter((v) => !isNull(v) && !isUndefined(v));
17
17
  }
18
18
  return arr;
19
19
  };
20
20
 
21
21
  export const getShuffledChoices = (choices, session, updateSession, choiceKey) =>
22
- new Promise(resolve => {
22
+ new Promise((resolve) => {
23
23
  log('updateSession type: ', typeof updateSession);
24
24
  log('session: ', session);
25
25
 
@@ -31,26 +31,26 @@ export const getShuffledChoices = (choices, session, updateSession, choiceKey) =
31
31
  resolve(undefined);
32
32
  } else if (!isEmpty(currentShuffled)) {
33
33
  debug('use shuffledValues to sort the choices...', session.shuffledValues);
34
- resolve(compact(currentShuffled.map(v => choices.find(c => c[choiceKey] === v))));
34
+ resolve(compact(currentShuffled.map((v) => choices.find((c) => c[choiceKey] === v))));
35
35
  } else {
36
36
  const shuffledChoices = shuffle(choices);
37
37
 
38
38
  if (updateSession && typeof updateSession === 'function') {
39
39
  try {
40
40
  //Note: session.id refers to the id of the element within a session
41
- const shuffledValues = compact(shuffledChoices.map(c => c[choiceKey]));
41
+ const shuffledValues = compact(shuffledChoices.map((c) => c[choiceKey]));
42
42
  log('try to save shuffledValues to session...', shuffledValues);
43
43
  log('call updateSession... ', session.id, session.element);
44
44
  if (isEmpty(shuffledValues)) {
45
45
  error(
46
46
  `shuffledValues is an empty array? - refusing to call updateSession: shuffledChoices: ${JSON.stringify(
47
- shuffledChoices
48
- )}, key: ${choiceKey}`
47
+ shuffledChoices,
48
+ )}, key: ${choiceKey}`,
49
49
  );
50
50
  } else {
51
- updateSession(session.id, session.element, { shuffledValues }).catch(e =>
51
+ updateSession(session.id, session.element, { shuffledValues }).catch((e) =>
52
52
  // eslint-disable-next-line no-console
53
- console.error('update session failed for: ', session.id, e)
53
+ console.error('update session failed for: ', session.id, e),
54
54
  );
55
55
  }
56
56
  } catch (e) {
@@ -65,7 +65,7 @@ export const getShuffledChoices = (choices, session, updateSession, choiceKey) =
65
65
  }
66
66
  });
67
67
 
68
- const hasShuffledValues = s => !!(s || {}).shuffledValues;
68
+ const hasShuffledValues = (s) => !!(s || {}).shuffledValues;
69
69
 
70
70
  /**
71
71
  * If we return: