@decidables/accumulable-elements 0.1.2 → 0.2.0

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.
@@ -10,20 +10,20 @@
10
10
  * SPDX-License-Identifier: BSD-3-Clause
11
11
  */
12
12
  const t$1 = globalThis,
13
- e$2 = t$1.ShadowRoot && (void 0 === t$1.ShadyCSS || t$1.ShadyCSS.nativeShadow) && "adoptedStyleSheets" in Document.prototype && "replace" in CSSStyleSheet.prototype,
14
- s$2 = Symbol(),
13
+ e$2 = t$1.ShadowRoot && (undefined === t$1.ShadyCSS || t$1.ShadyCSS.nativeShadow) && "adoptedStyleSheets" in Document.prototype && "replace" in CSSStyleSheet.prototype,
14
+ s$1 = Symbol(),
15
15
  o$3 = new WeakMap();
16
16
  let n$2 = class n {
17
17
  constructor(t, e, o) {
18
- if (this._$cssResult$ = !0, o !== s$2) throw Error("CSSResult is not constructable. Use `unsafeCSS` or `css` instead.");
18
+ if (this._$cssResult$ = true, o !== s$1) throw Error("CSSResult is not constructable. Use `unsafeCSS` or `css` instead.");
19
19
  this.cssText = t, this.t = e;
20
20
  }
21
21
  get styleSheet() {
22
22
  let t = this.o;
23
23
  const s = this.t;
24
- if (e$2 && void 0 === t) {
25
- const e = void 0 !== s && 1 === s.length;
26
- e && (t = o$3.get(s)), void 0 === t && ((this.o = t = new CSSStyleSheet()).replaceSync(this.cssText), e && o$3.set(s, t));
24
+ if (e$2 && undefined === t) {
25
+ const e = undefined !== s && 1 === s.length;
26
+ e && (t = o$3.get(s)), undefined === t && ((this.o = t = new CSSStyleSheet()).replaceSync(this.cssText), e && o$3.set(s, t));
27
27
  }
28
28
  return t;
29
29
  }
@@ -31,20 +31,20 @@
31
31
  return this.cssText;
32
32
  }
33
33
  };
34
- const r$3 = t => new n$2("string" == typeof t ? t : t + "", void 0, s$2),
35
- i$2 = (t, ...e) => {
34
+ const r$3 = t => new n$2("string" == typeof t ? t : t + "", undefined, s$1),
35
+ i$3 = (t, ...e) => {
36
36
  const o = 1 === t.length ? t[0] : e.reduce((e, s, o) => e + (t => {
37
- if (!0 === t._$cssResult$) return t.cssText;
37
+ if (true === t._$cssResult$) return t.cssText;
38
38
  if ("number" == typeof t) return t;
39
39
  throw Error("Value passed to 'css' function must be a 'css' function result: " + t + ". Use 'unsafeCSS' to pass non-literal values, but take care to ensure page security.");
40
40
  })(s) + t[o + 1], t[0]);
41
- return new n$2(o, t, s$2);
41
+ return new n$2(o, t, s$1);
42
42
  },
43
43
  S$1 = (s, o) => {
44
44
  if (e$2) s.adoptedStyleSheets = o.map(t => t instanceof CSSStyleSheet ? t : t.styleSheet);else for (const e of o) {
45
45
  const o = document.createElement("style"),
46
46
  n = t$1.litNonce;
47
- void 0 !== n && o.setAttribute("nonce", n), o.textContent = e.cssText, s.appendChild(o);
47
+ undefined !== n && o.setAttribute("nonce", n), o.textContent = e.cssText, s.appendChild(o);
48
48
  }
49
49
  },
50
50
  c$2 = e$2 ? t => t : t => t instanceof CSSStyleSheet ? (t => {
@@ -59,7 +59,7 @@
59
59
  * SPDX-License-Identifier: BSD-3-Clause
60
60
  */
61
61
  const {
62
- is: i$1,
62
+ is: i$2,
63
63
  defineProperty: e$1,
64
64
  getOwnPropertyDescriptor: r$2,
65
65
  getOwnPropertyNames: h$1,
@@ -103,12 +103,12 @@
103
103
  return i;
104
104
  }
105
105
  },
106
- f$1 = (t, s) => !i$1(t, s),
106
+ f$1 = (t, s) => !i$2(t, s),
107
107
  y$2 = {
108
- attribute: !0,
108
+ attribute: true,
109
109
  type: String,
110
110
  converter: u$1,
111
- reflect: !1,
111
+ reflect: false,
112
112
  hasChanged: f$1
113
113
  };
114
114
  Symbol.metadata ??= Symbol("metadata"), a$1.litPropertyMetadata ??= new WeakMap();
@@ -120,10 +120,10 @@
120
120
  return this.finalize(), this._$Eh && [...this._$Eh.keys()];
121
121
  }
122
122
  static createProperty(t, s = y$2) {
123
- if (s.state && (s.attribute = !1), this._$Ei(), this.elementProperties.set(t, s), !s.noAccessor) {
123
+ if (s.state && (s.attribute = false), this._$Ei(), this.elementProperties.set(t, s), !s.noAccessor) {
124
124
  const i = Symbol(),
125
125
  r = this.getPropertyDescriptor(t, i, s);
126
- void 0 !== r && e$1(this.prototype, t, r);
126
+ undefined !== r && e$1(this.prototype, t, r);
127
127
  }
128
128
  }
129
129
  static getPropertyDescriptor(t, s, i) {
@@ -146,8 +146,8 @@
146
146
  const r = e?.call(this);
147
147
  h.call(this, s), this.requestUpdate(t, r, i);
148
148
  },
149
- configurable: !0,
150
- enumerable: !0
149
+ configurable: true,
150
+ enumerable: true
151
151
  };
152
152
  }
153
153
  static getPropertyOptions(t) {
@@ -156,11 +156,11 @@
156
156
  static _$Ei() {
157
157
  if (this.hasOwnProperty(d$1("elementProperties"))) return;
158
158
  const t = n$1(this);
159
- t.finalize(), void 0 !== t.l && (this.l = [...t.l]), this.elementProperties = new Map(t.elementProperties);
159
+ t.finalize(), undefined !== t.l && (this.l = [...t.l]), this.elementProperties = new Map(t.elementProperties);
160
160
  }
161
161
  static finalize() {
162
162
  if (this.hasOwnProperty(d$1("finalized"))) return;
163
- if (this.finalized = !0, this._$Ei(), this.hasOwnProperty(d$1("properties"))) {
163
+ if (this.finalized = true, this._$Ei(), this.hasOwnProperty(d$1("properties"))) {
164
164
  const t = this.properties,
165
165
  s = [...h$1(t), ...o$2(t)];
166
166
  for (const i of s) this.createProperty(i, t[i]);
@@ -168,12 +168,12 @@
168
168
  const t = this[Symbol.metadata];
169
169
  if (null !== t) {
170
170
  const s = litPropertyMetadata.get(t);
171
- if (void 0 !== s) for (const [t, i] of s) this.elementProperties.set(t, i);
171
+ if (undefined !== s) for (const [t, i] of s) this.elementProperties.set(t, i);
172
172
  }
173
173
  this._$Eh = new Map();
174
174
  for (const [t, s] of this.elementProperties) {
175
175
  const i = this._$Eu(t, s);
176
- void 0 !== i && this._$Eh.set(i, t);
176
+ undefined !== i && this._$Eh.set(i, t);
177
177
  }
178
178
  this.elementStyles = this.finalizeStyles(this.styles);
179
179
  }
@@ -182,21 +182,21 @@
182
182
  if (Array.isArray(s)) {
183
183
  const e = new Set(s.flat(1 / 0).reverse());
184
184
  for (const s of e) i.unshift(c$2(s));
185
- } else void 0 !== s && i.push(c$2(s));
185
+ } else undefined !== s && i.push(c$2(s));
186
186
  return i;
187
187
  }
188
188
  static _$Eu(t, s) {
189
189
  const i = s.attribute;
190
- return !1 === i ? void 0 : "string" == typeof i ? i : "string" == typeof t ? t.toLowerCase() : void 0;
190
+ return false === i ? undefined : "string" == typeof i ? i : "string" == typeof t ? t.toLowerCase() : undefined;
191
191
  }
192
192
  constructor() {
193
- super(), this._$Ep = void 0, this.isUpdatePending = !1, this.hasUpdated = !1, this._$Em = null, this._$Ev();
193
+ super(), this._$Ep = undefined, this.isUpdatePending = false, this.hasUpdated = false, this._$Em = null, this._$Ev();
194
194
  }
195
195
  _$Ev() {
196
196
  this._$ES = new Promise(t => this.enableUpdating = t), this._$AL = new Map(), this._$E_(), this.requestUpdate(), this.constructor.l?.forEach(t => t(this));
197
197
  }
198
198
  addController(t) {
199
- (this._$EO ??= new Set()).add(t), void 0 !== this.renderRoot && this.isConnected && t.hostConnected?.();
199
+ (this._$EO ??= new Set()).add(t), undefined !== this.renderRoot && this.isConnected && t.hostConnected?.();
200
200
  }
201
201
  removeController(t) {
202
202
  this._$EO?.delete(t);
@@ -212,7 +212,7 @@
212
212
  return S$1(t, this.constructor.elementStyles), t;
213
213
  }
214
214
  connectedCallback() {
215
- this.renderRoot ??= this.createRenderRoot(), this.enableUpdating(!0), this._$EO?.forEach(t => t.hostConnected?.());
215
+ this.renderRoot ??= this.createRenderRoot(), this.enableUpdating(true), this._$EO?.forEach(t => t.hostConnected?.());
216
216
  }
217
217
  enableUpdating(t) {}
218
218
  disconnectedCallback() {
@@ -224,34 +224,34 @@
224
224
  _$EC(t, s) {
225
225
  const i = this.constructor.elementProperties.get(t),
226
226
  e = this.constructor._$Eu(t, i);
227
- if (void 0 !== e && !0 === i.reflect) {
228
- const r = (void 0 !== i.converter?.toAttribute ? i.converter : u$1).toAttribute(s, i.type);
227
+ if (undefined !== e && true === i.reflect) {
228
+ const r = (undefined !== i.converter?.toAttribute ? i.converter : u$1).toAttribute(s, i.type);
229
229
  this._$Em = t, null == r ? this.removeAttribute(e) : this.setAttribute(e, r), this._$Em = null;
230
230
  }
231
231
  }
232
232
  _$AK(t, s) {
233
233
  const i = this.constructor,
234
234
  e = i._$Eh.get(t);
235
- if (void 0 !== e && this._$Em !== e) {
235
+ if (undefined !== e && this._$Em !== e) {
236
236
  const t = i.getPropertyOptions(e),
237
237
  r = "function" == typeof t.converter ? {
238
238
  fromAttribute: t.converter
239
- } : void 0 !== t.converter?.fromAttribute ? t.converter : u$1;
239
+ } : undefined !== t.converter?.fromAttribute ? t.converter : u$1;
240
240
  this._$Em = e, this[e] = r.fromAttribute(s, t.type), this._$Em = null;
241
241
  }
242
242
  }
243
243
  requestUpdate(t, s, i) {
244
- if (void 0 !== t) {
244
+ if (undefined !== t) {
245
245
  if (i ??= this.constructor.getPropertyOptions(t), !(i.hasChanged ?? f$1)(this[t], s)) return;
246
246
  this.P(t, s, i);
247
247
  }
248
- !1 === this.isUpdatePending && (this._$ES = this._$ET());
248
+ false === this.isUpdatePending && (this._$ES = this._$ET());
249
249
  }
250
250
  P(t, s, i) {
251
- this._$AL.has(t) || this._$AL.set(t, s), !0 === i.reflect && this._$Em !== t && (this._$Ej ??= new Set()).add(t);
251
+ this._$AL.has(t) || this._$AL.set(t, s), true === i.reflect && this._$Em !== t && (this._$Ej ??= new Set()).add(t);
252
252
  }
253
253
  async _$ET() {
254
- this.isUpdatePending = !0;
254
+ this.isUpdatePending = true;
255
255
  try {
256
256
  await this._$ES;
257
257
  } catch (t) {
@@ -268,26 +268,26 @@
268
268
  if (!this.hasUpdated) {
269
269
  if (this.renderRoot ??= this.createRenderRoot(), this._$Ep) {
270
270
  for (const [t, s] of this._$Ep) this[t] = s;
271
- this._$Ep = void 0;
271
+ this._$Ep = undefined;
272
272
  }
273
273
  const t = this.constructor.elementProperties;
274
- if (t.size > 0) for (const [s, i] of t) !0 !== i.wrapped || this._$AL.has(s) || void 0 === this[s] || this.P(s, this[s], i);
274
+ if (t.size > 0) for (const [s, i] of t) true !== i.wrapped || this._$AL.has(s) || undefined === this[s] || this.P(s, this[s], i);
275
275
  }
276
- let t = !1;
276
+ let t = false;
277
277
  const s = this._$AL;
278
278
  try {
279
279
  t = this.shouldUpdate(s), t ? (this.willUpdate(s), this._$EO?.forEach(t => t.hostUpdate?.()), this.update(s)) : this._$EU();
280
280
  } catch (s) {
281
- throw t = !1, this._$EU(), s;
281
+ throw t = false, this._$EU(), s;
282
282
  }
283
283
  t && this._$AE(s);
284
284
  }
285
285
  willUpdate(t) {}
286
286
  _$AE(t) {
287
- this._$EO?.forEach(t => t.hostUpdated?.()), this.hasUpdated || (this.hasUpdated = !0, this.firstUpdated(t)), this.updated(t);
287
+ this._$EO?.forEach(t => t.hostUpdated?.()), this.hasUpdated || (this.hasUpdated = true, this.firstUpdated(t)), this.updated(t);
288
288
  }
289
289
  _$EU() {
290
- this._$AL = new Map(), this.isUpdatePending = !1;
290
+ this._$AL = new Map(), this.isUpdatePending = false;
291
291
  }
292
292
  get updateComplete() {
293
293
  return this.getUpdateComplete();
@@ -296,7 +296,7 @@
296
296
  return this._$ES;
297
297
  }
298
298
  shouldUpdate(t) {
299
- return !0;
299
+ return true;
300
300
  }
301
301
  update(t) {
302
302
  this._$Ej &&= this._$Ej.forEach(t => this._$EC(t, this[t])), this._$EU();
@@ -316,10 +316,10 @@
316
316
  * SPDX-License-Identifier: BSD-3-Clause
317
317
  */
318
318
  const t = globalThis,
319
- i = t.trustedTypes,
320
- s$1 = i ? i.createPolicy("lit-html", {
319
+ i$1 = t.trustedTypes,
320
+ s = i$1 ? i$1.createPolicy("lit-html", {
321
321
  createHTML: t => t
322
- }) : void 0,
322
+ }) : undefined,
323
323
  e = "$lit$",
324
324
  h = `lit$${Math.random().toFixed(9).slice(2)}$`,
325
325
  o$1 = "?" + h,
@@ -344,19 +344,19 @@
344
344
  }),
345
345
  x$1 = y$1(1),
346
346
  b = y$1(2),
347
- w = Symbol.for("lit-noChange"),
348
- T = Symbol.for("lit-nothing"),
347
+ T = Symbol.for("lit-noChange"),
348
+ E = Symbol.for("lit-nothing"),
349
349
  A = new WeakMap(),
350
- E = r$1.createTreeWalker(r$1, 129);
351
- function C(t, i) {
352
- if (!Array.isArray(t) || !t.hasOwnProperty("raw")) throw Error("invalid template strings array");
353
- return void 0 !== s$1 ? s$1.createHTML(i) : i;
350
+ C = r$1.createTreeWalker(r$1, 129);
351
+ function P(t, i) {
352
+ if (!a(t) || !t.hasOwnProperty("raw")) throw Error("invalid template strings array");
353
+ return undefined !== s ? s.createHTML(i) : i;
354
354
  }
355
- const P = (t, i) => {
355
+ const V = (t, i) => {
356
356
  const s = t.length - 1,
357
357
  o = [];
358
358
  let r,
359
- l = 2 === i ? "<svg>" : "",
359
+ l = 2 === i ? "<svg>" : 3 === i ? "<math>" : "",
360
360
  c = f;
361
361
  for (let i = 0; i < s; i++) {
362
362
  const s = t[i];
@@ -364,13 +364,13 @@
364
364
  u,
365
365
  d = -1,
366
366
  y = 0;
367
- for (; y < s.length && (c.lastIndex = y, u = c.exec(s), null !== u);) y = c.lastIndex, c === f ? "!--" === u[1] ? c = v : void 0 !== u[1] ? c = _ : void 0 !== u[2] ? ($.test(u[2]) && (r = RegExp("</" + u[2], "g")), c = m) : void 0 !== u[3] && (c = m) : c === m ? ">" === u[0] ? (c = r ?? f, d = -1) : void 0 === u[1] ? d = -2 : (d = c.lastIndex - u[2].length, a = u[1], c = void 0 === u[3] ? m : '"' === u[3] ? g : p) : c === g || c === p ? c = m : c === v || c === _ ? c = f : (c = m, r = void 0);
367
+ for (; y < s.length && (c.lastIndex = y, u = c.exec(s), null !== u);) y = c.lastIndex, c === f ? "!--" === u[1] ? c = v : undefined !== u[1] ? c = _ : undefined !== u[2] ? ($.test(u[2]) && (r = RegExp("</" + u[2], "g")), c = m) : undefined !== u[3] && (c = m) : c === m ? ">" === u[0] ? (c = r ?? f, d = -1) : undefined === u[1] ? d = -2 : (d = c.lastIndex - u[2].length, a = u[1], c = undefined === u[3] ? m : '"' === u[3] ? g : p) : c === g || c === p ? c = m : c === v || c === _ ? c = f : (c = m, r = undefined);
368
368
  const x = c === m && t[i + 1].startsWith("/>") ? " " : "";
369
369
  l += c === f ? s + n : d >= 0 ? (o.push(a), s.slice(0, d) + e + s.slice(d) + h + x) : s + h + (-2 === d ? i : x);
370
370
  }
371
- return [C(t, l + (t[s] || "<?>") + (2 === i ? "</svg>" : "")), o];
371
+ return [P(t, l + (t[s] || "<?>") + (2 === i ? "</svg>" : 3 === i ? "</math>" : "")), o];
372
372
  };
373
- class V {
373
+ class N {
374
374
  constructor({
375
375
  strings: t,
376
376
  _$litType$: s
@@ -381,12 +381,12 @@
381
381
  a = 0;
382
382
  const u = t.length - 1,
383
383
  d = this.parts,
384
- [f, v] = P(t, s);
385
- if (this.el = V.createElement(f, n), E.currentNode = this.el.content, 2 === s) {
384
+ [f, v] = V(t, s);
385
+ if (this.el = N.createElement(f, n), C.currentNode = this.el.content, 2 === s || 3 === s) {
386
386
  const t = this.el.content.firstChild;
387
387
  t.replaceWith(...t.childNodes);
388
388
  }
389
- for (; null !== (r = E.nextNode()) && d.length < u;) {
389
+ for (; null !== (r = C.nextNode()) && d.length < u;) {
390
390
  if (1 === r.nodeType) {
391
391
  if (r.hasAttributes()) for (const t of r.getAttributeNames()) if (t.endsWith(e)) {
392
392
  const i = v[a++],
@@ -397,7 +397,7 @@
397
397
  index: c,
398
398
  name: e[2],
399
399
  strings: s,
400
- ctor: "." === e[1] ? k : "?" === e[1] ? H : "@" === e[1] ? I : R
400
+ ctor: "." === e[1] ? H : "?" === e[1] ? I : "@" === e[1] ? L : k
401
401
  }), r.removeAttribute(t);
402
402
  } else t.startsWith(h) && (d.push({
403
403
  type: 6,
@@ -407,8 +407,8 @@
407
407
  const t = r.textContent.split(h),
408
408
  s = t.length - 1;
409
409
  if (s > 0) {
410
- r.textContent = i ? i.emptyScript : "";
411
- for (let i = 0; i < s; i++) r.append(t[i], l()), E.nextNode(), d.push({
410
+ r.textContent = i$1 ? i$1.emptyScript : "";
411
+ for (let i = 0; i < s; i++) r.append(t[i], l()), C.nextNode(), d.push({
412
412
  type: 2,
413
413
  index: ++c
414
414
  });
@@ -433,15 +433,15 @@
433
433
  return s.innerHTML = t, s;
434
434
  }
435
435
  }
436
- function N(t, i, s = t, e) {
437
- if (i === w) return i;
438
- let h = void 0 !== e ? s._$Co?.[e] : s._$Cl;
439
- const o = c(i) ? void 0 : i._$litDirective$;
440
- return h?.constructor !== o && (h?._$AO?.(!1), void 0 === o ? h = void 0 : (h = new o(t), h._$AT(t, s, e)), void 0 !== e ? (s._$Co ??= [])[e] = h : s._$Cl = h), void 0 !== h && (i = N(t, h._$AS(t, i.values), h, e)), i;
436
+ function S(t, i, s = t, e) {
437
+ if (i === T) return i;
438
+ let h = undefined !== e ? s._$Co?.[e] : s._$Cl;
439
+ const o = c(i) ? undefined : i._$litDirective$;
440
+ return h?.constructor !== o && (h?._$AO?.(false), undefined === o ? h = undefined : (h = new o(t), h._$AT(t, s, e)), undefined !== e ? (s._$Co ??= [])[e] = h : s._$Cl = h), undefined !== h && (i = S(t, h._$AS(t, i.values), h, e)), i;
441
441
  }
442
- class S {
442
+ class M {
443
443
  constructor(t, i) {
444
- this._$AV = [], this._$AN = void 0, this._$AD = t, this._$AM = i;
444
+ this._$AV = [], this._$AN = undefined, this._$AD = t, this._$AM = i;
445
445
  }
446
446
  get parentNode() {
447
447
  return this._$AM.parentNode;
@@ -456,37 +456,37 @@
456
456
  },
457
457
  parts: s
458
458
  } = this._$AD,
459
- e = (t?.creationScope ?? r$1).importNode(i, !0);
460
- E.currentNode = e;
461
- let h = E.nextNode(),
459
+ e = (t?.creationScope ?? r$1).importNode(i, true);
460
+ C.currentNode = e;
461
+ let h = C.nextNode(),
462
462
  o = 0,
463
463
  n = 0,
464
464
  l = s[0];
465
- for (; void 0 !== l;) {
465
+ for (; undefined !== l;) {
466
466
  if (o === l.index) {
467
467
  let i;
468
- 2 === l.type ? i = new M(h, h.nextSibling, this, t) : 1 === l.type ? i = new l.ctor(h, l.name, l.strings, this, t) : 6 === l.type && (i = new L(h, this, t)), this._$AV.push(i), l = s[++n];
468
+ 2 === l.type ? i = new R(h, h.nextSibling, this, t) : 1 === l.type ? i = new l.ctor(h, l.name, l.strings, this, t) : 6 === l.type && (i = new z(h, this, t)), this._$AV.push(i), l = s[++n];
469
469
  }
470
- o !== l?.index && (h = E.nextNode(), o++);
470
+ o !== l?.index && (h = C.nextNode(), o++);
471
471
  }
472
- return E.currentNode = r$1, e;
472
+ return C.currentNode = r$1, e;
473
473
  }
474
474
  p(t) {
475
475
  let i = 0;
476
- for (const s of this._$AV) void 0 !== s && (void 0 !== s.strings ? (s._$AI(t, s, i), i += s.strings.length - 2) : s._$AI(t[i])), i++;
476
+ for (const s of this._$AV) undefined !== s && (undefined !== s.strings ? (s._$AI(t, s, i), i += s.strings.length - 2) : s._$AI(t[i])), i++;
477
477
  }
478
478
  }
479
- class M {
479
+ class R {
480
480
  get _$AU() {
481
481
  return this._$AM?._$AU ?? this._$Cv;
482
482
  }
483
483
  constructor(t, i, s, e) {
484
- this.type = 2, this._$AH = T, this._$AN = void 0, this._$AA = t, this._$AB = i, this._$AM = s, this.options = e, this._$Cv = e?.isConnected ?? !0;
484
+ this.type = 2, this._$AH = E, this._$AN = undefined, this._$AA = t, this._$AB = i, this._$AM = s, this.options = e, this._$Cv = e?.isConnected ?? true;
485
485
  }
486
486
  get parentNode() {
487
487
  let t = this._$AA.parentNode;
488
488
  const i = this._$AM;
489
- return void 0 !== i && 11 === t?.nodeType && (t = i.parentNode), t;
489
+ return undefined !== i && 11 === t?.nodeType && (t = i.parentNode), t;
490
490
  }
491
491
  get startNode() {
492
492
  return this._$AA;
@@ -495,52 +495,52 @@
495
495
  return this._$AB;
496
496
  }
497
497
  _$AI(t, i = this) {
498
- t = N(this, t, i), c(t) ? t === T || null == t || "" === t ? (this._$AH !== T && this._$AR(), this._$AH = T) : t !== this._$AH && t !== w && this._(t) : void 0 !== t._$litType$ ? this.$(t) : void 0 !== t.nodeType ? this.T(t) : u(t) ? this.k(t) : this._(t);
498
+ t = S(this, t, i), c(t) ? t === E || null == t || "" === t ? (this._$AH !== E && this._$AR(), this._$AH = E) : t !== this._$AH && t !== T && this._(t) : undefined !== t._$litType$ ? this.$(t) : undefined !== t.nodeType ? this.T(t) : u(t) ? this.k(t) : this._(t);
499
499
  }
500
- S(t) {
500
+ O(t) {
501
501
  return this._$AA.parentNode.insertBefore(t, this._$AB);
502
502
  }
503
503
  T(t) {
504
- this._$AH !== t && (this._$AR(), this._$AH = this.S(t));
504
+ this._$AH !== t && (this._$AR(), this._$AH = this.O(t));
505
505
  }
506
506
  _(t) {
507
- this._$AH !== T && c(this._$AH) ? this._$AA.nextSibling.data = t : this.T(r$1.createTextNode(t)), this._$AH = t;
507
+ this._$AH !== E && c(this._$AH) ? this._$AA.nextSibling.data = t : this.T(r$1.createTextNode(t)), this._$AH = t;
508
508
  }
509
509
  $(t) {
510
510
  const {
511
511
  values: i,
512
512
  _$litType$: s
513
513
  } = t,
514
- e = "number" == typeof s ? this._$AC(t) : (void 0 === s.el && (s.el = V.createElement(C(s.h, s.h[0]), this.options)), s);
514
+ e = "number" == typeof s ? this._$AC(t) : (undefined === s.el && (s.el = N.createElement(P(s.h, s.h[0]), this.options)), s);
515
515
  if (this._$AH?._$AD === e) this._$AH.p(i);else {
516
- const t = new S(e, this),
516
+ const t = new M(e, this),
517
517
  s = t.u(this.options);
518
518
  t.p(i), this.T(s), this._$AH = t;
519
519
  }
520
520
  }
521
521
  _$AC(t) {
522
522
  let i = A.get(t.strings);
523
- return void 0 === i && A.set(t.strings, i = new V(t)), i;
523
+ return undefined === i && A.set(t.strings, i = new N(t)), i;
524
524
  }
525
525
  k(t) {
526
526
  a(this._$AH) || (this._$AH = [], this._$AR());
527
527
  const i = this._$AH;
528
528
  let s,
529
529
  e = 0;
530
- for (const h of t) e === i.length ? i.push(s = new M(this.S(l()), this.S(l()), this, this.options)) : s = i[e], s._$AI(h), e++;
530
+ for (const h of t) e === i.length ? i.push(s = new R(this.O(l()), this.O(l()), this, this.options)) : s = i[e], s._$AI(h), e++;
531
531
  e < i.length && (this._$AR(s && s._$AB.nextSibling, e), i.length = e);
532
532
  }
533
533
  _$AR(t = this._$AA.nextSibling, i) {
534
- for (this._$AP?.(!1, !0, i); t && t !== this._$AB;) {
534
+ for (this._$AP?.(false, true, i); t && t !== this._$AB;) {
535
535
  const i = t.nextSibling;
536
536
  t.remove(), t = i;
537
537
  }
538
538
  }
539
539
  setConnected(t) {
540
- void 0 === this._$AM && (this._$Cv = t, this._$AP?.(t));
540
+ undefined === this._$AM && (this._$Cv = t, this._$AP?.(t));
541
541
  }
542
542
  }
543
- class R {
543
+ class k {
544
544
  get tagName() {
545
545
  return this.element.tagName;
546
546
  }
@@ -548,72 +548,72 @@
548
548
  return this._$AM._$AU;
549
549
  }
550
550
  constructor(t, i, s, e, h) {
551
- this.type = 1, this._$AH = T, this._$AN = void 0, this.element = t, this.name = i, this._$AM = e, this.options = h, s.length > 2 || "" !== s[0] || "" !== s[1] ? (this._$AH = Array(s.length - 1).fill(new String()), this.strings = s) : this._$AH = T;
551
+ this.type = 1, this._$AH = E, this._$AN = undefined, this.element = t, this.name = i, this._$AM = e, this.options = h, s.length > 2 || "" !== s[0] || "" !== s[1] ? (this._$AH = Array(s.length - 1).fill(new String()), this.strings = s) : this._$AH = E;
552
552
  }
553
553
  _$AI(t, i = this, s, e) {
554
554
  const h = this.strings;
555
- let o = !1;
556
- if (void 0 === h) t = N(this, t, i, 0), o = !c(t) || t !== this._$AH && t !== w, o && (this._$AH = t);else {
555
+ let o = false;
556
+ if (undefined === h) t = S(this, t, i, 0), o = !c(t) || t !== this._$AH && t !== T, o && (this._$AH = t);else {
557
557
  const e = t;
558
558
  let n, r;
559
- for (t = h[0], n = 0; n < h.length - 1; n++) r = N(this, e[s + n], i, n), r === w && (r = this._$AH[n]), o ||= !c(r) || r !== this._$AH[n], r === T ? t = T : t !== T && (t += (r ?? "") + h[n + 1]), this._$AH[n] = r;
559
+ for (t = h[0], n = 0; n < h.length - 1; n++) r = S(this, e[s + n], i, n), r === T && (r = this._$AH[n]), o ||= !c(r) || r !== this._$AH[n], r === E ? t = E : t !== E && (t += (r ?? "") + h[n + 1]), this._$AH[n] = r;
560
560
  }
561
561
  o && !e && this.j(t);
562
562
  }
563
563
  j(t) {
564
- t === T ? this.element.removeAttribute(this.name) : this.element.setAttribute(this.name, t ?? "");
564
+ t === E ? this.element.removeAttribute(this.name) : this.element.setAttribute(this.name, t ?? "");
565
565
  }
566
566
  }
567
- class k extends R {
567
+ class H extends k {
568
568
  constructor() {
569
569
  super(...arguments), this.type = 3;
570
570
  }
571
571
  j(t) {
572
- this.element[this.name] = t === T ? void 0 : t;
572
+ this.element[this.name] = t === E ? undefined : t;
573
573
  }
574
574
  }
575
- class H extends R {
575
+ class I extends k {
576
576
  constructor() {
577
577
  super(...arguments), this.type = 4;
578
578
  }
579
579
  j(t) {
580
- this.element.toggleAttribute(this.name, !!t && t !== T);
580
+ this.element.toggleAttribute(this.name, !!t && t !== E);
581
581
  }
582
582
  }
583
- class I extends R {
583
+ class L extends k {
584
584
  constructor(t, i, s, e, h) {
585
585
  super(t, i, s, e, h), this.type = 5;
586
586
  }
587
587
  _$AI(t, i = this) {
588
- if ((t = N(this, t, i, 0) ?? T) === w) return;
588
+ if ((t = S(this, t, i, 0) ?? E) === T) return;
589
589
  const s = this._$AH,
590
- e = t === T && s !== T || t.capture !== s.capture || t.once !== s.once || t.passive !== s.passive,
591
- h = t !== T && (s === T || e);
590
+ e = t === E && s !== E || t.capture !== s.capture || t.once !== s.once || t.passive !== s.passive,
591
+ h = t !== E && (s === E || e);
592
592
  e && this.element.removeEventListener(this.name, this, s), h && this.element.addEventListener(this.name, this, t), this._$AH = t;
593
593
  }
594
594
  handleEvent(t) {
595
595
  "function" == typeof this._$AH ? this._$AH.call(this.options?.host ?? this.element, t) : this._$AH.handleEvent(t);
596
596
  }
597
597
  }
598
- class L {
598
+ class z {
599
599
  constructor(t, i, s) {
600
- this.element = t, this.type = 6, this._$AN = void 0, this._$AM = i, this.options = s;
600
+ this.element = t, this.type = 6, this._$AN = undefined, this._$AM = i, this.options = s;
601
601
  }
602
602
  get _$AU() {
603
603
  return this._$AM._$AU;
604
604
  }
605
605
  _$AI(t) {
606
- N(this, t);
606
+ S(this, t);
607
607
  }
608
608
  }
609
- const Z = t.litHtmlPolyfillSupport;
610
- Z?.(V, M), (t.litHtmlVersions ??= []).push("3.1.3");
611
- const j = (t, i, s) => {
609
+ const j = t.litHtmlPolyfillSupport;
610
+ j?.(N, R), (t.litHtmlVersions ??= []).push("3.2.1");
611
+ const B = (t, i, s) => {
612
612
  const e = s?.renderBefore ?? i;
613
613
  let h = e._$litPart$;
614
- if (void 0 === h) {
614
+ if (undefined === h) {
615
615
  const t = s?.renderBefore ?? null;
616
- e._$litPart$ = h = new M(i.insertBefore(l(), t), t, void 0, s ?? {});
616
+ e._$litPart$ = h = new R(i.insertBefore(l(), t), t, undefined, s ?? {});
617
617
  }
618
618
  return h._$AI(t), h;
619
619
  };
@@ -623,38 +623,38 @@
623
623
  * Copyright 2017 Google LLC
624
624
  * SPDX-License-Identifier: BSD-3-Clause
625
625
  */
626
- class s extends b$1 {
626
+ class r extends b$1 {
627
627
  constructor() {
628
628
  super(...arguments), this.renderOptions = {
629
629
  host: this
630
- }, this._$Do = void 0;
630
+ }, this._$Do = undefined;
631
631
  }
632
632
  createRenderRoot() {
633
633
  const t = super.createRenderRoot();
634
634
  return this.renderOptions.renderBefore ??= t.firstChild, t;
635
635
  }
636
636
  update(t) {
637
- const i = this.render();
638
- this.hasUpdated || (this.renderOptions.isConnected = this.isConnected), super.update(t), this._$Do = j(i, this.renderRoot, this.renderOptions);
637
+ const s = this.render();
638
+ this.hasUpdated || (this.renderOptions.isConnected = this.isConnected), super.update(t), this._$Do = B(s, this.renderRoot, this.renderOptions);
639
639
  }
640
640
  connectedCallback() {
641
- super.connectedCallback(), this._$Do?.setConnected(!0);
641
+ super.connectedCallback(), this._$Do?.setConnected(true);
642
642
  }
643
643
  disconnectedCallback() {
644
- super.disconnectedCallback(), this._$Do?.setConnected(!1);
644
+ super.disconnectedCallback(), this._$Do?.setConnected(false);
645
645
  }
646
646
  render() {
647
- return w;
647
+ return T;
648
648
  }
649
649
  }
650
- s._$litElement$ = !0, s[("finalized")] = !0, globalThis.litElementHydrateSupport?.({
651
- LitElement: s
650
+ r._$litElement$ = true, r["finalized"] = true, globalThis.litElementHydrateSupport?.({
651
+ LitElement: r
652
652
  });
653
- const r = globalThis.litElementPolyfillSupport;
654
- r?.({
655
- LitElement: s
653
+ const i = globalThis.litElementPolyfillSupport;
654
+ i?.({
655
+ LitElement: r
656
656
  });
657
- (globalThis.litElementVersions ??= []).push("4.0.5");
657
+ (globalThis.litElementVersions ??= []).push("4.1.1");
658
658
 
659
659
  function ascending$1(a, b) {
660
660
  return a == null || b == null ? NaN : a < b ? -1 : a > b ? 1 : a >= b ? 0 : NaN;
@@ -1894,7 +1894,7 @@
1894
1894
  }
1895
1895
  }
1896
1896
 
1897
- var constant$2 = (x => () => x);
1897
+ var constant$2 = x => () => x;
1898
1898
 
1899
1899
  function DragEvent(type, {
1900
1900
  sourceEvent,
@@ -2500,7 +2500,7 @@
2500
2500
  return (h < 60 ? m1 + (m2 - m1) * h / 60 : h < 180 ? m2 : h < 240 ? m1 + (m2 - m1) * (240 - h) / 60 : m1) * 255;
2501
2501
  }
2502
2502
 
2503
- var constant$1 = (x => () => x);
2503
+ var constant$1 = x => () => x;
2504
2504
 
2505
2505
  function linear$2(a, d) {
2506
2506
  return function (t) {
@@ -4572,7 +4572,7 @@
4572
4572
  DecidablesElement Base Class - Not intended for instantiation!
4573
4573
  <decidables-element>
4574
4574
  */
4575
- class DecidablesElement extends s {
4575
+ class DecidablesElement extends r {
4576
4576
  getComputedStyleValue(property) {
4577
4577
  return getComputedStyle(this).getPropertyValue(property).trim();
4578
4578
  }
@@ -4825,7 +4825,7 @@
4825
4825
  `;
4826
4826
  }
4827
4827
  static get styles() {
4828
- return i$2`
4828
+ return i$3`
4829
4829
  :host {
4830
4830
  ---shadow-0: var(--shadow-0, ${r$3(this.cssBoxShadow(0))});
4831
4831
  ---shadow-2: var(--shadow-2, ${r$3(this.cssBoxShadow(2))});
@@ -4903,8 +4903,11 @@
4903
4903
  this.disabled = false;
4904
4904
  }
4905
4905
  static get styles() {
4906
- return [super.styles, i$2`
4906
+ return [super.styles, i$3`
4907
4907
  :host {
4908
+ ---decidables-button-background-color-disabled: var(--decidables-button-background-color, var(---color-element-disabled));
4909
+ ---decidables-button-background-color-enabled: var(--decidables-button-background-color, var(---color-element-enabled));
4910
+
4908
4911
  margin: 0.25rem;
4909
4912
  }
4910
4913
 
@@ -4924,7 +4927,7 @@
4924
4927
  }
4925
4928
 
4926
4929
  button:disabled {
4927
- background-color: var(--decidables-button-background-color, var(---color-element-disabled));
4930
+ background-color: var(---decidables-button-background-color-disabled);
4928
4931
  outline: none;
4929
4932
  box-shadow: none;
4930
4933
  }
@@ -4932,7 +4935,7 @@
4932
4935
  button:enabled {
4933
4936
  cursor: pointer;
4934
4937
 
4935
- background-color: var(--decidables-button-background-color, var(---color-element-enabled));
4938
+ background-color: var(---decidables-button-background-color-enabled);
4936
4939
  outline: none;
4937
4940
  box-shadow: var(---shadow-2);
4938
4941
  }
@@ -4973,7 +4976,7 @@
4973
4976
  * Copyright 2018 Google LLC
4974
4977
  * SPDX-License-Identifier: BSD-3-Clause
4975
4978
  */
4976
- const o = o => o ?? T;
4979
+ const o = o => o ?? E;
4977
4980
 
4978
4981
  class DecidablesSlider extends DecidablesElement {
4979
4982
  static get properties() {
@@ -4983,6 +4986,11 @@
4983
4986
  type: Boolean,
4984
4987
  reflect: true
4985
4988
  },
4989
+ scale: {
4990
+ attribute: 'scale',
4991
+ type: Boolean,
4992
+ reflect: true
4993
+ },
4986
4994
  max: {
4987
4995
  attribute: 'max',
4988
4996
  type: Number,
@@ -5002,6 +5010,11 @@
5002
5010
  attribute: 'value',
5003
5011
  type: Number,
5004
5012
  reflect: true
5013
+ },
5014
+ nonlinear: {
5015
+ attribute: false,
5016
+ type: Boolean,
5017
+ reflect: false
5005
5018
  }
5006
5019
  };
5007
5020
  }
@@ -5010,13 +5023,30 @@
5010
5023
 
5011
5024
  // Attributes
5012
5025
  this.disabled = false;
5026
+ this.scale = false;
5013
5027
  this.max = undefined;
5014
5028
  this.min = undefined;
5015
5029
  this.step = undefined;
5016
5030
  this.value = undefined;
5017
- }
5018
- changed(event) {
5019
- this.value = event.target.value;
5031
+ this.nonlinear = false;
5032
+
5033
+ // Properties
5034
+ this.rangeMax = undefined;
5035
+ this.rangeMin = undefined;
5036
+ this.rangeStep = undefined;
5037
+ this.rangeValue = undefined;
5038
+
5039
+ // Transform
5040
+ this.toRange = undefined;
5041
+ this.fromRange = undefined;
5042
+ }
5043
+ nonlinearRange(nonlinear, toRange, fromRange) {
5044
+ this.nonlinear = nonlinear;
5045
+ this.toRange = nonlinear ? toRange : undefined;
5046
+ this.fromRange = nonlinear ? fromRange : undefined;
5047
+ }
5048
+ rangeChanged(event) {
5049
+ this.value = this.nonlinear ? this.fromRange(event.target.value) : event.target.value;
5020
5050
  this.dispatchEvent(new CustomEvent('change', {
5021
5051
  detail: {
5022
5052
  value: this.value
@@ -5024,12 +5054,25 @@
5024
5054
  bubbles: true
5025
5055
  }));
5026
5056
  }
5027
- inputted(event) {
5057
+ rangeInputted(event) {
5058
+ this.value = this.nonlinear ? this.fromRange(event.target.value) : event.target.value;
5059
+ }
5060
+ spinnerInputted(event) {
5028
5061
  this.value = event.target.value;
5029
5062
  }
5063
+ willUpdate() {
5064
+ this.rangeMax = this.max === undefined ? undefined : this.nonlinear ? this.toRange(this.max) : this.max;
5065
+ this.rangeMin = this.min === undefined ? undefined : this.nonlinear ? this.toRange(this.min) : this.min;
5066
+ this.rangeStep = this.step === undefined ? undefined : this.nonlinear ? 'any' : this.step;
5067
+ this.rangeValue = this.value === undefined ? undefined : this.nonlinear ? this.toRange(this.value) : this.value;
5068
+ }
5030
5069
  static get styles() {
5031
- return [super.styles, i$2`
5070
+ return [super.styles, i$3`
5032
5071
  :host {
5072
+ ---decidables-slider-background-color: var(--decidables-slider-background-color, var(---color-element-disabled));
5073
+ ---decidables-slider-color: var(--decidables-slider-color, var(---color-element-enabled));
5074
+ ---decidables-spinner-background-color: var(--decidables-slider-background-color, none);
5075
+
5033
5076
  ---shadow-2-rotate: var(--shadow-2-rotate, ${r$3(this.cssBoxShadow(2, true, false))});
5034
5077
  ---shadow-4-rotate: var(--shadow-4-rotate, ${r$3(this.cssBoxShadow(4, true, false))});
5035
5078
  ---shadow-8-rotate: var(--shadow-8-rotate, ${r$3(this.cssBoxShadow(8, true, false))});
@@ -5047,7 +5090,10 @@
5047
5090
  }
5048
5091
 
5049
5092
  .range {
5050
- display: inline-block;
5093
+ position: relative;
5094
+ display: flex;
5095
+
5096
+ flex-direction: row;
5051
5097
 
5052
5098
  width: 3.5rem;
5053
5099
  height: 4.75rem;
@@ -5058,6 +5104,8 @@
5058
5104
  --decidables-spinner-input-width: 3.5rem;
5059
5105
 
5060
5106
  margin: 0 0.25rem 0.25rem;
5107
+
5108
+ background: var(---decidables-spinner-background-color);
5061
5109
  }
5062
5110
 
5063
5111
  /* Adapted from http://danielstern.ca/range.css/#/ */
@@ -5096,14 +5144,14 @@
5096
5144
  width: 100%;
5097
5145
  height: 4px;
5098
5146
 
5099
- background: var(---color-element-disabled);
5147
+ background: var(---decidables-slider-background-color);
5100
5148
  border: 0;
5101
5149
  border-radius: 2px;
5102
5150
  box-shadow: none;
5103
5151
  }
5104
5152
 
5105
5153
  input[type=range]:focus::-webkit-slider-runnable-track {
5106
- background: var(---color-element-disabled);
5154
+ background: var(---decidables-slider-background-color);
5107
5155
  }
5108
5156
 
5109
5157
  /* stylelint-disable-next-line no-descending-specificity */ /* stylelint ERROR */
@@ -5111,7 +5159,7 @@
5111
5159
  width: 100%;
5112
5160
  height: 4px;
5113
5161
 
5114
- background: var(---color-element-disabled);
5162
+ background: var(---decidables-slider-background-color);
5115
5163
  border: 0;
5116
5164
  border-radius: 2px;
5117
5165
  box-shadow: none;
@@ -5131,7 +5179,7 @@
5131
5179
  /* stylelint-disable-next-line no-descending-specificity */ /* stylelint ERROR */
5132
5180
  input[type=range]::-ms-fill-lower {
5133
5181
  background: #cccccc;
5134
- /* background: var(---color-element-disabled); */
5182
+ /* background: var(---decidables-slider-background-color); */
5135
5183
  border: 0;
5136
5184
  border-radius: 2px;
5137
5185
  box-shadow: none;
@@ -5140,7 +5188,7 @@
5140
5188
  /* stylelint-disable-next-line no-descending-specificity */ /* stylelint ERROR */
5141
5189
  input[type=range]::-ms-fill-upper {
5142
5190
  background: #cccccc;
5143
- /* background: var(---color-element-disabled); */
5191
+ /* background: var(---decidables-slider-background-color); */
5144
5192
  border: 0;
5145
5193
  border-radius: 2px;
5146
5194
  box-shadow: none;
@@ -5148,12 +5196,12 @@
5148
5196
 
5149
5197
  /* stylelint-disable-next-line no-descending-specificity */ /* stylelint ERROR */
5150
5198
  input[type=range]:focus::-ms-fill-lower {
5151
- background: var(---color-element-disabled);
5199
+ background: var(---decidables-slider-background-color);
5152
5200
  }
5153
5201
 
5154
5202
  /* stylelint-disable-next-line no-descending-specificity */ /* stylelint ERROR */
5155
5203
  input[type=range]:focus::-ms-fill-upper {
5156
- background: var(---color-element-disabled);
5204
+ background: var(---decidables-slider-background-color);
5157
5205
  }
5158
5206
 
5159
5207
  /* Thumb */
@@ -5171,12 +5219,12 @@
5171
5219
  }
5172
5220
 
5173
5221
  input[type=range]:disabled::-webkit-slider-thumb {
5174
- background: var(---color-element-disabled);
5222
+ background: var(---decidables-slider-background-color);
5175
5223
  box-shadow: none;
5176
5224
  }
5177
5225
 
5178
5226
  input[type=range]:enabled::-webkit-slider-thumb {
5179
- background: var(---color-element-enabled);
5227
+ background: var(---decidables-slider-color);
5180
5228
  box-shadow: var(---shadow-2-rotate);
5181
5229
  }
5182
5230
 
@@ -5207,13 +5255,13 @@
5207
5255
 
5208
5256
  /* stylelint-disable-next-line no-descending-specificity */ /* stylelint ERROR */
5209
5257
  input[type=range]:disabled::-moz-range-thumb {
5210
- background: var(---color-element-disabled);
5258
+ background: var(---decidables-slider-background-color);
5211
5259
  box-shadow: none;
5212
5260
  }
5213
5261
 
5214
5262
  /* stylelint-disable-next-line no-descending-specificity */ /* stylelint ERROR */
5215
5263
  input[type=range]:enabled::-moz-range-thumb {
5216
- background: var(---color-element-enabled);
5264
+ background: var(---decidables-slider-color);
5217
5265
  box-shadow: var(---shadow-2-rotate);
5218
5266
  }
5219
5267
 
@@ -5250,13 +5298,13 @@
5250
5298
 
5251
5299
  /* stylelint-disable-next-line no-descending-specificity */ /* stylelint ERROR */
5252
5300
  input[type=range]:disabled::-ms-thumb {
5253
- background: var(---color-element-disabled);
5301
+ background: var(---decidables-slider-background-color);
5254
5302
  box-shadow: none;
5255
5303
  }
5256
5304
 
5257
5305
  /* stylelint-disable-next-line no-descending-specificity */ /* stylelint ERROR */
5258
5306
  input[type=range]:enabled::-ms-thumb {
5259
- background: var(---color-element-enabled);
5307
+ background: var(---decidables-slider-color);
5260
5308
  box-shadow: var(---shadow-2-rotate);
5261
5309
  }
5262
5310
 
@@ -5278,6 +5326,33 @@
5278
5326
  :host(.keyboard) input[type=range]:enabled:focus:active::-ms-thumb {
5279
5327
  box-shadow: var(---shadow-8-rotate);
5280
5328
  }
5329
+
5330
+ datalist {
5331
+ position: absolute;
5332
+ left: 2rem;
5333
+ z-index: -1;
5334
+ display: flex;
5335
+
5336
+ flex-direction: column;
5337
+
5338
+ align-items: flex-start;
5339
+ justify-content: space-between;
5340
+
5341
+ height: 4.75rem;
5342
+
5343
+ font-size: 0.75rem;
5344
+ }
5345
+
5346
+ option {
5347
+ padding: 0;
5348
+
5349
+ line-height: 0.8;
5350
+ min-block-size: 0;
5351
+ }
5352
+
5353
+ option::before {
5354
+ content: "– ";
5355
+ }
5281
5356
  `];
5282
5357
  }
5283
5358
  render() {
@@ -5286,9 +5361,15 @@
5286
5361
  <slot></slot>
5287
5362
  </label>
5288
5363
  <div class="range">
5289
- <input ?disabled=${this.disabled} type="range" id="slider" min=${o(this.min)} max=${o(this.max)} step=${o(this.step)} .value=${this.value} @change=${this.changed.bind(this)} @input=${this.inputted.bind(this)}>
5364
+ <input ?disabled=${this.disabled} type="range" id="slider" min=${o(this.rangeMin)} max=${o(this.rangeMax)} step=${o(this.rangeStep)} .value=${this.rangeValue} @change=${this.rangeChanged.bind(this)} @input=${this.rangeInputted.bind(this)}>
5365
+ ${this.scale ? x$1`
5366
+ <datalist id="ticks">
5367
+ <option value=${o(this.rangeMax)} label=${o(this.max)}></option>
5368
+ <option value=${o(this.rangeMin)} label=${o(this.min)}></option>
5369
+ </datalist>
5370
+ ` : x$1``}
5290
5371
  </div>
5291
- <decidables-spinner ?disabled=${this.disabled} min=${o(this.min)} max=${o(this.max)} step=${o(this.step)} .value=${this.value} @input=${this.inputted.bind(this)}></decidables-spinner>
5372
+ <decidables-spinner ?disabled=${this.disabled} min=${o(this.min)} max=${o(this.max)} step=${o(this.step)} .value=${this.value} @input=${this.spinnerInputted.bind(this)}></decidables-spinner>
5292
5373
  `;
5293
5374
  }
5294
5375
  }
@@ -5338,7 +5419,7 @@
5338
5419
  this.value = event.target.value;
5339
5420
  }
5340
5421
  static get styles() {
5341
- return [super.styles, i$2`
5422
+ return [super.styles, i$3`
5342
5423
  :host {
5343
5424
  ---decidables-spinner-font-size: var(--decidables-spinner-font-size, 1.125rem);
5344
5425
  ---decidables-spinner-input-width: var(--decidables-spinner-input-width, 4rem);
@@ -5477,7 +5558,7 @@
5477
5558
  }));
5478
5559
  }
5479
5560
  static get styles() {
5480
- return [super.styles, i$2`
5561
+ return [super.styles, i$3`
5481
5562
  :host {
5482
5563
  display: flex;
5483
5564
 
@@ -5630,7 +5711,7 @@
5630
5711
  this.disabled = false;
5631
5712
  }
5632
5713
  static get styles() {
5633
- return [super.styles, i$2`
5714
+ return [super.styles, i$3`
5634
5715
  fieldset {
5635
5716
  display: flex;
5636
5717
 
@@ -5705,7 +5786,7 @@
5705
5786
  }));
5706
5787
  }
5707
5788
  static get styles() {
5708
- return [super.styles, i$2`
5789
+ return [super.styles, i$3`
5709
5790
  :host {
5710
5791
  display: flex;
5711
5792
  }
@@ -5899,7 +5980,7 @@
5899
5980
  }, {});
5900
5981
  }
5901
5982
  static get styles() {
5902
- return [super.styles, i$2`
5983
+ return [super.styles, i$3`
5903
5984
  :host {
5904
5985
  /* Declare base colors */
5905
5986
  ${r$3(Object.keys(AccumulableElement.colors).map(color => {
@@ -6062,7 +6143,7 @@
6062
6143
  this.state = 'ended';
6063
6144
  }
6064
6145
  static get styles() {
6065
- return [super.styles, i$2`
6146
+ return [super.styles, i$3`
6066
6147
  :host {
6067
6148
  display: inline-block;
6068
6149
  }
@@ -6089,15 +6170,15 @@
6089
6170
  render() {
6090
6171
  return x$1`
6091
6172
  <div class="holder">
6092
- ${this.trials ? x$1`<decidables-slider class="trials" min="1" max="100" step="1" .value=${this.trials} @change=${this.setTrials.bind(this)} @input=${this.setTrials.bind(this)}>Trials</decidables-slider>` : x$1``}
6173
+ ${this.trials != null ? x$1`<decidables-slider class="trials" min="1" max="100" step="1" .value=${this.trials} @change=${this.setTrials.bind(this)} @input=${this.setTrials.bind(this)}>Trials</decidables-slider>` : x$1``}
6093
6174
  ${this.resample ? x$1`
6094
6175
  <div class="buttons">
6095
6176
  ${this.resample ? x$1`<decidables-button name="resample" @click=${this.doResample.bind(this)}>Resample</decidables-button>` : x$1``}
6096
6177
  </div>
6097
6178
  ` : x$1``}
6098
- ${this.duration ? x$1`<decidables-slider class="duration" min="10" max="2000" step="10" .value=${this.duration} @change=${this.setDuration.bind(this)} @input=${this.setDuration.bind(this)}>Duration</decidables-slider>` : x$1``}
6099
- ${this.coherence ? x$1`<decidables-slider class="coherence" min="0" max="1" step=".01" .value=${this.coherence} @change=${this.setCoherence.bind(this)} @input=${this.setCoherence.bind(this)}>Coherence</decidables-slider>` : x$1``}
6100
- ${this.color !== undefined ? x$1`
6179
+ ${this.duration != null ? x$1`<decidables-slider class="duration" min="10" max="2000" step="10" .value=${this.duration} @change=${this.setDuration.bind(this)} @input=${this.setDuration.bind(this)}>Duration</decidables-slider>` : x$1``}
6180
+ ${this.coherence != null ? x$1`<decidables-slider class="coherence" min="0" max="1" step=".01" .value=${this.coherence} @change=${this.setCoherence.bind(this)} @input=${this.setCoherence.bind(this)}>Coherence</decidables-slider>` : x$1``}
6181
+ ${this.color != null ? x$1`
6101
6182
  <decidables-toggle class="color" @change=${this.chooseColor.bind(this)}>
6102
6183
  <span slot="label">Emphasis</span>
6103
6184
  <decidables-toggle-option name="toggle" value="none" ?checked=${this.color === 'none'}>None</decidables-toggle-option>
@@ -6122,13 +6203,13 @@
6122
6203
  DDMMath Static Class - Not intended for instantiation!
6123
6204
 
6124
6205
  Model parameters:
6125
- a = boundary separation
6126
- z = starting point as a proportion of a
6127
- v = drift rate (per second)
6128
- t0 = non-decision time (in milliseconds)
6129
- s = within-trial variability in drift rate (s^2 = infinitesimal variance)
6206
+ a = boundary separation [0, Infinity)
6207
+ z = starting point as a proportion of a (0, 1)
6208
+ v = drift rate (per second) (-Infinity, Infinity)
6209
+ t0 = non-decision time (in milliseconds) (0, Infinity)
6210
+ s = within-trial variability in drift rate (s^2 = infinitesimal variance) [0, Infinity)
6130
6211
 
6131
- zPrime = starting point on a 0-to-a scale (typically used in published equations)
6212
+ zPrime = starting point on a 0-to-a scale (typically used in published equations) [0, Infinity)
6132
6213
 
6133
6214
  Behavioral variables:
6134
6215
  pE = proportion of error trials
@@ -6148,7 +6229,37 @@
6148
6229
  EZ-diffusion model (Wagenmakers et al., 2007)
6149
6230
  */
6150
6231
  class DDMMath {
6151
- static s = 1;
6232
+ static s = {
6233
+ DEFAULT: 1
6234
+ };
6235
+ static a = {
6236
+ DEFAULT: 1.2,
6237
+ MIN: 0.01,
6238
+ MAX: 2.0,
6239
+ STEP: 0.01,
6240
+ JUMP: 0.1
6241
+ };
6242
+ static z = {
6243
+ DEFAULT: 0.55,
6244
+ MIN: 0.01,
6245
+ MAX: 0.99,
6246
+ STEP: 0.01,
6247
+ JUMP: 0.1
6248
+ };
6249
+ static v = {
6250
+ DEFAULT: 1.5,
6251
+ MIN: 0.01,
6252
+ MAX: 5.0,
6253
+ STEP: 0.01,
6254
+ JUMP: 0.1
6255
+ };
6256
+ static t0 = {
6257
+ DEFAULT: 150,
6258
+ MIN: 0,
6259
+ MAX: 500,
6260
+ STEP: 1,
6261
+ JUMP: 10
6262
+ };
6152
6263
 
6153
6264
  // Calculate a bunch of statistics for an array of trials
6154
6265
  static trials2stats(trials) {
@@ -6216,7 +6327,7 @@
6216
6327
  }
6217
6328
 
6218
6329
  // Probability of an Error Response
6219
- static azv2pE(a, z, v, s = DDMMath.s) {
6330
+ static azv2pE(a, z, v, s = DDMMath.s.DEFAULT) {
6220
6331
  const zPrime = a * z;
6221
6332
  const A = Math.exp(-2 * v * a / s ** 2);
6222
6333
  const Z = Math.exp(-2 * v * zPrime / s ** 2);
@@ -6224,13 +6335,13 @@
6224
6335
  }
6225
6336
 
6226
6337
  // Probability of a Correct Response
6227
- static azv2pC(a, z, v, s = DDMMath.s) {
6338
+ static azv2pC(a, z, v, s = DDMMath.s.DEFAULT) {
6228
6339
  return DDMMath.azv2pE(a, 1 - z, -v, s);
6229
6340
  }
6230
6341
 
6231
6342
  // Mean Overall RT
6232
6343
  // Equation 5 (Grasman et al., 2009)
6233
- static azvt02m(a, z, v, t0, s = DDMMath.s) {
6344
+ static azvt02m(a, z, v, t0, s = DDMMath.s.DEFAULT) {
6234
6345
  const zPrime = a * z;
6235
6346
  const A = Math.exp(-2 * v * a / s ** 2) - 1;
6236
6347
  const Z = Math.exp(-2 * v * zPrime / s ** 2) - 1;
@@ -6240,7 +6351,7 @@
6240
6351
 
6241
6352
  // SD Overall RT
6242
6353
  // Equation 6 (Grasman et al., 2009)
6243
- static azv2sd(a, z, v, s = DDMMath.s) {
6354
+ static azv2sd(a, z, v, s = DDMMath.s.DEFAULT) {
6244
6355
  const zPrime = a * z;
6245
6356
  const A = Math.exp(-2 * v * a / s ** 2) - 1;
6246
6357
  const Z = Math.exp(-2 * v * zPrime / s ** 2) - 1;
@@ -6250,7 +6361,7 @@
6250
6361
 
6251
6362
  // Mean Error RT
6252
6363
  // Equation 13 (Grasman et al., 2009)
6253
- static azvt02mE(a, z, v, t0, s = DDMMath.s) {
6364
+ static azvt02mE(a, z, v, t0, s = DDMMath.s.DEFAULT) {
6254
6365
  function phi(x, y) {
6255
6366
  return Math.exp(2 * v * y / s ** 2) - Math.exp(2 * v * x / s ** 2);
6256
6367
  }
@@ -6261,7 +6372,7 @@
6261
6372
 
6262
6373
  // SD Error RT
6263
6374
  // Equation 14 (Grasman et al., 2009)
6264
- static azv2sdE(a, z, v, s = DDMMath.s) {
6375
+ static azv2sdE(a, z, v, s = DDMMath.s.DEFAULT) {
6265
6376
  function phi(x, y) {
6266
6377
  return Math.exp(2 * v * y / s ** 2) - Math.exp(2 * v * x / s ** 2);
6267
6378
  }
@@ -6271,17 +6382,17 @@
6271
6382
  }
6272
6383
 
6273
6384
  // Mean Correct RT
6274
- static azvt02mC(a, z, v, t0, s = DDMMath.s) {
6385
+ static azvt02mC(a, z, v, t0, s = DDMMath.s.DEFAULT) {
6275
6386
  return DDMMath.azvt02mE(a, 1 - z, -v, t0, s);
6276
6387
  }
6277
6388
 
6278
6389
  // SD Correct RT
6279
- static azv2sdC(a, z, v, s = DDMMath.s) {
6390
+ static azv2sdC(a, z, v, s = DDMMath.s.DEFAULT) {
6280
6391
  return DDMMath.azv2sdE(a, 1 - z, -v, s);
6281
6392
  }
6282
6393
 
6283
6394
  // Density of Error RT
6284
- static tazv2gE(t, a, z, v, s = DDMMath.s) {
6395
+ static tazv2gE(t, a, z, v, s = DDMMath.s.DEFAULT) {
6285
6396
  if (!t) return 0;
6286
6397
  const zPrime = a * z;
6287
6398
  const base = Math.PI * s ** 2 / a ** 2 * Math.exp(-zPrime * v / s ** 2);
@@ -6298,7 +6409,7 @@
6298
6409
  }
6299
6410
 
6300
6411
  // Density of Correct RT
6301
- static tazv2gC(t, a, z, v, s = DDMMath.s) {
6412
+ static tazv2gC(t, a, z, v, s = DDMMath.s.DEFAULT) {
6302
6413
  return DDMMath.tazv2gE(t, a, 1 - z, -v, s);
6303
6414
  }
6304
6415
 
@@ -6433,10 +6544,7 @@
6433
6544
  this.startTime = undefined; // Start time of current trial
6434
6545
  this.rt = undefined; // RT for current trial
6435
6546
 
6436
- this.correctCount = 0; // Count of Correct Trials
6437
- this.errorCount = 0; // Count of Error Trials
6438
- this.nrCount = 0; // Count of No Response trials
6439
-
6547
+ this.data = {};
6440
6548
  this.trials = []; // Record of trials in block
6441
6549
  this.alignState();
6442
6550
  }
@@ -6453,11 +6561,10 @@
6453
6561
  }
6454
6562
  }
6455
6563
  get totalPayoff() {
6456
- return this.correctCount * this.correctPayoff + this.errorCount * this.errorPayoff + this.nrCount * this.nrPayoff;
6564
+ return this.data.correctCount * this.correctPayoff + this.data.errorCount * this.errorPayoff + this.data.nrCount * this.nrPayoff;
6457
6565
  }
6458
6566
  alignState() {
6459
- const stats = DDMMath.trials2stats(this.trials);
6460
- Object.assign(this, stats);
6567
+ this.data = DDMMath.trials2stats(this.trials);
6461
6568
  }
6462
6569
  start(signal, trial) {
6463
6570
  this.startTime = Date.now();
@@ -6472,7 +6579,6 @@
6472
6579
  this.state = 'feedback';
6473
6580
  if (this.response === undefined) {
6474
6581
  this.outcome = 'nr';
6475
- this.nrCount += 1;
6476
6582
  this.rt = undefined;
6477
6583
  this.trials.push({
6478
6584
  trial: this.trialCount,
@@ -6497,10 +6603,8 @@
6497
6603
  this.response = response;
6498
6604
  if (this.signal === this.response) {
6499
6605
  this.outcome = 'correct';
6500
- this.correctCount += 1;
6501
6606
  } else if (this.signal !== this.response) {
6502
6607
  this.outcome = 'error';
6503
- this.errorCount += 1;
6504
6608
  }
6505
6609
  this.trials.push({
6506
6610
  trial: this.trialCount,
@@ -6519,16 +6623,7 @@
6519
6623
  response: this.response,
6520
6624
  outcome: this.outcome,
6521
6625
  payoff: this.trialPayoff,
6522
- correctCount: this.correctCount,
6523
- errorCount: this.errorCount,
6524
- nrCount: this.nrCount,
6525
- accuracy: this.accuracy,
6526
- meanRT: this.meanRT,
6527
- correctMeanRT: this.correctMeanRT,
6528
- errorMeanRT: this.errorMeanRT,
6529
- sdRT: this.sdRT,
6530
- correctSDRT: this.correctSDRT,
6531
- errorSDRT: this.errorSDRT,
6626
+ data: this.data,
6532
6627
  totalPayoff: this.totalPayoff
6533
6628
  },
6534
6629
  bubbles: true
@@ -6541,9 +6636,6 @@
6541
6636
  this.signal = undefined;
6542
6637
  this.response = undefined;
6543
6638
  this.outcome = undefined;
6544
- this.correctCount = 0;
6545
- this.errorCount = 0;
6546
- this.nrCount = 0;
6547
6639
  this.trials = [];
6548
6640
  this.alignState();
6549
6641
  }
@@ -6567,7 +6659,7 @@
6567
6659
  super.disconnectedCallback();
6568
6660
  }
6569
6661
  static get styles() {
6570
- return [super.styles, i$2`
6662
+ return [super.styles, i$3`
6571
6663
  :host {
6572
6664
  display: inline-block;
6573
6665
  }
@@ -6897,7 +6989,7 @@
6897
6989
  this.sendEvent();
6898
6990
  }
6899
6991
  static get styles() {
6900
- return [super.styles, i$2`
6992
+ return [super.styles, i$3`
6901
6993
  :host {
6902
6994
  display: inline-block;
6903
6995
  }
@@ -7234,7 +7326,7 @@
7234
7326
  };
7235
7327
  }
7236
7328
 
7237
- var WorkerFactory = createBase64WorkerFactory('/* rollup-plugin-web-worker-loader */
(function () {
  'use strict';

  /*
    DDMMath Static Class - Not intended for instantiation!

    Model parameters:
      a = boundary separation
      z = starting point as a proportion of a
      v = drift rate (per second)
      t0 = non-decision time (in milliseconds)
      s = within-trial variability in drift rate (s^2 = infinitesimal variance)

      zPrime = starting point on a 0-to-a scale (typically used in published equations)

    Behavioral variables:
      pE = proportion of error trials
      pC = proportion of correct trials
      m = mean of overall RTs (in milliseconds)
      mE = mean of error RTs (in milliseconds)
      mC = mean correct RTs (in milliseconds)
      sd = standard deviation of overall RTs (in milliseconds)
      sdE = standard deviation of error RTs (in milliseconds)
      sdC = standard deviation of correct RTs (in milliseconds)

    Equations:
      Probability of correct and error responses (Alexandrowicz, 2020)
      Mean of overall, error, and correct RTs (Grasman et al., 2009)
      Standard deviation of overall, error, and correct RTs (Grasman et al., 2009)
      Density of error and correct RT distributions (Alexandrowicz, 2020)
      EZ-diffusion model (Wagenmakers et al., 2007)
  */
  class DDMMath {
    static s = 1;

    // Calculate a bunch of statistics for an array of trials
    static trials2stats(trials) {
      const stats = {};

      // First-order sums
      const sums = trials.reduce((accumulator, trial) => {
        switch (trial.outcome) {
          case 'correct':
            accumulator.correctCount += 1;
            accumulator.correctRTSum += trial.rt;
            break;
          case 'error':
            accumulator.errorCount += 1;
            accumulator.errorRTSum += trial.rt;
            break;
          case 'nr':
            accumulator.nrCount += 1;
            break;
          // No-op
        }
        return accumulator;
      }, {
        correctCount: 0,
        errorCount: 0,
        nrCount: 0,
        correctRTSum: 0,
        errorRTSum: 0
      });

      // First-order stats
      stats.correctCount = sums.correctCount;
      stats.errorCount = sums.errorCount;
      stats.nrCount = sums.nrCount;
      stats.accuracy = sums.correctCount / (sums.correctCount + sums.errorCount + sums.nrCount);
      stats.correctMeanRT = sums.correctRTSum / sums.correctCount;
      stats.errorMeanRT = sums.errorRTSum / sums.errorCount;
      stats.meanRT = (sums.correctRTSum + sums.errorRTSum) / (sums.correctCount + sums.errorCount);

      // Second-order sums
      const sums2 = trials.reduce((accumulator, trial) => {
        switch (trial.outcome) {
          case 'correct':
            accumulator.ss += (trial.rt - stats.meanRT) ** 2;
            accumulator.correctSS += (trial.rt - stats.correctMeanRT) ** 2;
            break;
          case 'error':
            accumulator.ss += (trial.rt - stats.meanRT) ** 2;
            accumulator.errorSS += (trial.rt - stats.errorMeanRT) ** 2;
            break;
          // No-op
        }
        return accumulator;
      }, {
        ss: 0,
        correctSS: 0,
        errorSS: 0
      });

      // Second-order stats
      stats.correctSDRT = stats.correctCount > 1 ? Math.sqrt(sums2.correctSS / (stats.correctCount - 1)) : NaN;
      stats.errorSDRT = stats.errorCount > 1 ? Math.sqrt(sums2.errorSS / (stats.errorCount - 1)) : NaN;
      stats.sdRT = stats.correctCount + stats.errorCount > 1 ? Math.sqrt(sums2.ss / (stats.correctCount + stats.errorCount - 1)) : NaN;
      return stats;
    }

    // Probability of an Error Response
    static azv2pE(a, z, v, s = DDMMath.s) {
      const zPrime = a * z;
      const A = Math.exp(-2 * v * a / s ** 2);
      const Z = Math.exp(-2 * v * zPrime / s ** 2);
      return (A - Z) / (A - 1);
    }

    // Probability of a Correct Response
    static azv2pC(a, z, v, s = DDMMath.s) {
      return DDMMath.azv2pE(a, 1 - z, -v, s);
    }

    // Mean Overall RT
    // Equation 5 (Grasman et al., 2009)
    static azvt02m(a, z, v, t0, s = DDMMath.s) {
      const zPrime = a * z;
      const A = Math.exp(-2 * v * a / s ** 2) - 1;
      const Z = Math.exp(-2 * v * zPrime / s ** 2) - 1;
      const mean = -(zPrime / v) + a / v * (Z / A);
      return t0 + mean * 1000;
    }

    // SD Overall RT
    // Equation 6 (Grasman et al., 2009)
    static azv2sd(a, z, v, s = DDMMath.s) {
      const zPrime = a * z;
      const A = Math.exp(-2 * v * a / s ** 2) - 1;
      const Z = Math.exp(-2 * v * zPrime / s ** 2) - 1;
      const variance = (-v * a ** 2 * (Z + 4) * Z / A ** 2 + ((-3 * v * a ** 2 + 4 * v * zPrime * a + s ** 2 * a) * Z + 4 * v * zPrime * a) / A - s ** 2 * zPrime) / v ** 3;
      return Math.sqrt(variance) * 1000;
    }

    // Mean Error RT
    // Equation 13 (Grasman et al., 2009)
    static azvt02mE(a, z, v, t0, s = DDMMath.s) {
      function phi(x, y) {
        return Math.exp(2 * v * y / s ** 2) - Math.exp(2 * v * x / s ** 2);
      }
      const zPrime = a * z;
      const mean = (zPrime * (phi(zPrime - a, a) + phi(0, zPrime)) + 2 * a * phi(zPrime, 0)) / (v * phi(zPrime, a) * phi(-a, 0));
      return t0 + mean * 1000;
    }

    // SD Error RT
    // Equation 14 (Grasman et al., 2009)
    static azv2sdE(a, z, v, s = DDMMath.s) {
      function phi(x, y) {
        return Math.exp(2 * v * y / s ** 2) - Math.exp(2 * v * x / s ** 2);
      }
      const zPrime = a * z;
      const variance = -2 * a * phi(0, zPrime) * (2 * v * a * phi(zPrime, 2 * a) + s ** 2 * phi(0, a) * phi(zPrime, a)) * Math.exp(2 * v * a / s ** 2) / (v ** 3 * phi(0, a) ** 2 * phi(zPrime, a) ** 2) + (4 * v * zPrime * (2 * a - zPrime) * Math.exp(2 * v * (zPrime + a) / s ** 2) + zPrime * s ** 2 * phi(2 * zPrime, 2 * a)) / (v ** 3 * phi(zPrime, a) ** 2);
      return Math.sqrt(variance) * 1000;
    }

    // Mean Correct RT
    static azvt02mC(a, z, v, t0, s = DDMMath.s) {
      return DDMMath.azvt02mE(a, 1 - z, -v, t0, s);
    }

    // SD Correct RT
    static azv2sdC(a, z, v, s = DDMMath.s) {
      return DDMMath.azv2sdE(a, 1 - z, -v, s);
    }

    // Density of Error RT
    static tazv2gE(t, a, z, v, s = DDMMath.s) {
      if (!t) return 0;
      const zPrime = a * z;
      const base = Math.PI * s ** 2 / a ** 2 * Math.exp(-zPrime * v / s ** 2);
      let k = 0;
      let term = 0;
      let sum = 0;
      do {
        k += 1;
        term = k * Math.sin(Math.PI * zPrime * k / a) * Math.exp(-0.5 * (v ** 2 / s ** 2 + Math.PI ** 2 * k ** 2 * s ** 2 / a ** 2) * t);
        sum += term;
      } while (k < 200); // ?? HACK

      return base * sum;
    }

    // Density of Correct RT
    static tazv2gC(t, a, z, v, s = DDMMath.s) {
      return DDMMath.tazv2gE(t, a, 1 - z, -v, s);
    }

    // Adapted from https://raoul.socsci.uva.nl/EZ2/EZ2_new.html
    // EZ-function for starting values
    // input: obj - Object with properties
    //    pC - Proportion correct
    //    sd - sample standard deviation of the RT's in ms
    //    m - sample mean of the RT's in ms
    //    s - diffusion standard deviation
    // returns: Object with properties v, a, and t0, containing EZ-estimates of these parameters
    static data2ez({
      accuracy: pC,
      sdRT: sd,
      meanRT: m,
      s
    }) {
      function sign(r) {
        return r > 0 ? 1 : r === 0 ? 0 : -1;
      }
      function logit(p) {
        return Math.log(p / (1 - p));
      }
      const vrt = (sd / 1000) ** 2;
      const mrt = m / 1000;
      const s2 = s ** 2;
      const l = logit(pC);
      const x = l * (l * pC ** 2 - l * pC + pC - 0.5) / vrt;
      const v = sign(pC - 0.5) * s * x ** (1 / 4);
      const a = s2 * logit(pC) / v;
      const y = -v * a / s2;
      const mdt = a / (2 * v) * (1 - Math.exp(y)) / (1 + Math.exp(y));
      const t0 = mrt ? mrt - mdt : null; // compute Ter only if MRT was provided

      const t0Prime = t0 * 1000;
      return {
        v,
        a,
        t0: t0Prime,
        s
      };
    }
    static data2ez2() {
      throw new Error('data2ez2 is not implemented!');
    }
  }

  // Internal dependencies

  /* eslint no-restricted-globals: ["off", "self"] */

  self.onmessage = event => {
    const params = DDMMath.data2ez({
      ...event.data,
      s: DDMMath.s
    });

    // ##### Arbitrary default values!!!
    const a = !isNaN(params.a) ? params.a : 1.5;
    const z = !isNaN(params.z) ? params.z : 0.5;
    const v = !isNaN(params.v) ? params.v : 0.1;
    const t0 = !isNaN(params.t0) ? params.t0 : 100;
    const s = !isNaN(params.s) ? params.s : DDMMath.s;
    const predicted = {
      accuracy: DDMMath.azv2pC(a, z, v),
      correctMeanRT: DDMMath.azvt02mC(a, z, v, t0),
      errorMeanRT: DDMMath.azvt02mE(a, z, v, t0),
      meanRT: DDMMath.azvt02m(a, z, v, t0),
      correctSDRT: DDMMath.azv2sdC(a, z, v),
      errorSDRT: DDMMath.azv2sdE(a, z, v),
      sdRT: DDMMath.azv2sd(a, z, v)
    };
    self.postMessage({
      params: {
        a,
        z,
        v,
        t0,
        s
      },
      predicted
    });
  };

})();
//# sourceMappingURL=ddm-fit-worker.js.map

', 'data:application/json;charset=utf-8;base64,{"version":3,"file":"ddm-fit-worker.js","sources":["../accumulable-math/src/ddm-math.js","../accumulable-math/src/index.js","src/components/ddm-fit-worker.js"],"sourcesContent":["\n/*\n  DDMMath Static Class - Not intended for instantiation!\n\n  Model parameters:\n    a = boundary separation\n    z = starting point as a proportion of a\n    v = drift rate (per second)\n    t0 = non-decision time (in milliseconds)\n    s = within-trial variability in drift rate (s^2 = infinitesimal variance)\n\n    zPrime = starting point on a 0-to-a scale (typically used in published equations)\n\n  Behavioral variables:\n    pE = proportion of error trials\n    pC = proportion of correct trials\n    m = mean of overall RTs (in milliseconds)\n    mE = mean of error RTs (in milliseconds)\n    mC = mean correct RTs (in milliseconds)\n    sd = standard deviation of overall RTs (in milliseconds)\n    sdE = standard deviation of error RTs (in milliseconds)\n    sdC = standard deviation of correct RTs (in milliseconds)\n\n  Equations:\n    Probability of correct and error responses (Alexandrowicz, 2020)\n    Mean of overall, error, and correct RTs (Grasman et al., 2009)\n    Standard deviation of overall, error, and correct RTs (Grasman et al., 2009)\n    Density of error and correct RT distributions (Alexandrowicz, 2020)\n    EZ-diffusion model (Wagenmakers et al., 2007)\n*/\nexport default class DDMMath {\n  static s = 1;\n\n  // Calculate a bunch of statistics for an array of trials\n  static trials2stats(trials) {\n    const stats = {};\n\n    // First-order sums\n    const sums = trials.reduce(\n      (accumulator, trial) => {\n        switch (trial.outcome) {\n          case 'correct':\n            accumulator.correctCount += 1;\n            accumulator.correctRTSum += trial.rt;\n            break;\n          case 'error':\n            accumulator.errorCount += 1;\n            accumulator.errorRTSum += trial.rt;\n            break;\n          case 'nr':\n            accumulator.nrCount += 1;\n            break;\n          default:\n            // No-op\n        }\n        return accumulator;\n      },\n      {\n        correctCount: 0,\n        errorCount: 0,\n        nrCount: 0,\n\n        correctRTSum: 0,\n        errorRTSum: 0,\n      },\n    );\n\n    // First-order stats\n    stats.correctCount = sums.correctCount;\n    stats.errorCount = sums.errorCount;\n    stats.nrCount = sums.nrCount;\n    stats.accuracy = sums.correctCount / (sums.correctCount + sums.errorCount + sums.nrCount);\n\n    stats.correctMeanRT = sums.correctRTSum / sums.correctCount;\n    stats.errorMeanRT = sums.errorRTSum / sums.errorCount;\n    stats.meanRT = (sums.correctRTSum + sums.errorRTSum) / (sums.correctCount + sums.errorCount);\n\n    // Second-order sums\n    const sums2 = trials.reduce(\n      (accumulator, trial) => {\n        switch (trial.outcome) {\n          case 'correct':\n            accumulator.ss += (trial.rt - stats.meanRT) ** 2;\n            accumulator.correctSS += (trial.rt - stats.correctMeanRT) ** 2;\n            break;\n          case 'error':\n            accumulator.ss += (trial.rt - stats.meanRT) ** 2;\n            accumulator.errorSS += (trial.rt - stats.errorMeanRT) ** 2;\n            break;\n          default:\n            // No-op\n        }\n        return accumulator;\n      },\n      {\n        ss: 0,\n        correctSS: 0,\n        errorSS: 0,\n      },\n    );\n\n    // Second-order stats\n    stats.correctSDRT = (stats.correctCount > 1)\n      ? Math.sqrt(sums2.correctSS / (stats.correctCount - 1))\n      : NaN;\n    stats.errorSDRT = (stats.errorCount > 1)\n      ? Math.sqrt(sums2.errorSS / (stats.errorCount - 1))\n      : NaN;\n    stats.sdRT = (stats.correctCount + stats.errorCount > 1)\n      ? Math.sqrt(sums2.ss / (stats.correctCount + stats.errorCount - 1))\n      : NaN;\n\n    return stats;\n  }\n\n  // Probability of an Error Response\n  static azv2pE(a, z, v, s = DDMMath.s) {\n    const zPrime = a * z;\n\n    const A = Math.exp((-2 * v * a) / s ** 2);\n    const Z = Math.exp((-2 * v * zPrime) / s ** 2);\n\n    return (A - Z) / (A - 1);\n  }\n\n  // Probability of a Correct Response\n  static azv2pC(a, z, v, s = DDMMath.s) {\n    return DDMMath.azv2pE(a, 1 - z, -v, s);\n  }\n\n  // Mean Overall RT\n  // Equation 5 (Grasman et al., 2009)\n  static azvt02m(a, z, v, t0, s = DDMMath.s) {\n    const zPrime = a * z;\n    const A = Math.exp((-2 * v * a) / s ** 2) - 1;\n    const Z = Math.exp((-2 * v * zPrime) / s ** 2) - 1;\n\n    const mean = -(zPrime / v) + (a / v) * (Z / A);\n    return t0 + mean * 1000;\n  }\n\n  // SD Overall RT\n  // Equation 6 (Grasman et al., 2009)\n  static azv2sd(a, z, v, s = DDMMath.s) {\n    const zPrime = a * z;\n    const A = Math.exp((-2 * v * a) / s ** 2) - 1;\n    const Z = Math.exp((-2 * v * zPrime) / s ** 2) - 1;\n\n    const variance = (\n      (\n        (-v * a ** 2 * (Z + 4) * Z) / A ** 2\n      ) + (\n        ((-3 * v * a ** 2 + 4 * v * zPrime * a + s ** 2 * a) * Z + 4 * v * zPrime * a) / A\n      ) - (\n        s ** 2 * zPrime\n      )\n    ) / v ** 3;\n\n    return Math.sqrt(variance) * 1000;\n  }\n\n  // Mean Error RT\n  // Equation 13 (Grasman et al., 2009)\n  static azvt02mE(a, z, v, t0, s = DDMMath.s) {\n    function phi(x, y) {\n      return Math.exp((2 * v * y) / (s ** 2)) - Math.exp((2 * v * x) / (s ** 2));\n    }\n    const zPrime = a * z;\n\n    const mean = (zPrime * (phi(zPrime - a, a) + phi(0, zPrime)) + 2 * a * phi(zPrime, 0))\n      / (v * phi(zPrime, a) * phi(-a, 0));\n    return t0 + mean * 1000;\n  }\n\n  // SD Error RT\n  // Equation 14 (Grasman et al., 2009)\n  static azv2sdE(a, z, v, s = DDMMath.s) {\n    function phi(x, y) {\n      return Math.exp((2 * v * y) / (s ** 2)) - Math.exp((2 * v * x) / (s ** 2));\n    }\n    const zPrime = a * z;\n\n    const variance = (\n      (\n        -2 * a * phi(0, zPrime)\n        * ((2 * v * a * phi(zPrime, 2 * a)) + (s ** 2 * phi(0, a) * phi(zPrime, a)))\n        * Math.exp((2 * v * a) / s ** 2)\n      ) / (\n        v ** 3 * phi(0, a) ** 2 * phi(zPrime, a) ** 2\n      )\n    ) + (\n      (\n        4 * v * zPrime * (2 * a - zPrime) * Math.exp((2 * v * (zPrime + a)) / s ** 2)\n        + zPrime * s ** 2 * phi(2 * zPrime, 2 * a)\n      ) / (\n        v ** 3 * phi(zPrime, a) ** 2\n      )\n    );\n\n    return Math.sqrt(variance) * 1000;\n  }\n\n  // Mean Correct RT\n  static azvt02mC(a, z, v, t0, s = DDMMath.s) {\n    return DDMMath.azvt02mE(a, 1 - z, -v, t0, s);\n  }\n\n  // SD Correct RT\n  static azv2sdC(a, z, v, s = DDMMath.s) {\n    return DDMMath.azv2sdE(a, 1 - z, -v, s);\n  }\n\n  // Density of Error RT\n  static tazv2gE(t, a, z, v, s = DDMMath.s) {\n    if (!t) return 0;\n\n    const zPrime = a * z;\n    const base = ((Math.PI * s ** 2) / a ** 2) * Math.exp((-zPrime * v) / s ** 2);\n\n    let k = 0;\n    let term = 0;\n    let sum = 0;\n    do {\n      k += 1;\n\n      term = k\n        * Math.sin((Math.PI * zPrime * k) / a)\n        * Math.exp(-0.5 * ((v ** 2 / s ** 2) + ((Math.PI ** 2 * k ** 2 * s ** 2) / a ** 2)) * t);\n\n      sum += term;\n    } while (k < 200); // ?? HACK\n\n    return base * sum;\n  }\n\n  // Density of Correct RT\n  static tazv2gC(t, a, z, v, s = DDMMath.s) {\n    return DDMMath.tazv2gE(t, a, 1 - z, -v, s);\n  }\n\n  // Adapted from https://raoul.socsci.uva.nl/EZ2/EZ2_new.html\n  // EZ-function for starting values\n  // input: obj - Object with properties\n  //    pC - Proportion correct\n  //    sd - sample standard deviation of the RT's in ms\n  //    m - sample mean of the RT's in ms\n  //    s - diffusion standard deviation\n  // returns: Object with properties v, a, and t0, containing EZ-estimates of these parameters\n  static data2ez({\n    accuracy: pC,\n    sdRT: sd,\n    meanRT: m,\n    s,\n  }) {\n    function sign(r) {\n      return ((r > 0) ? 1 : ((r === 0) ? 0 : -1));\n    }\n\n    function logit(p) {\n      return Math.log(p / (1 - p));\n    }\n\n    const vrt = (sd / 1000) ** 2;\n    const mrt = m / 1000;\n\n    const s2 = s ** 2;\n    const l = logit(pC);\n    const x = (l * (l * pC ** 2 - l * pC + pC - 0.5)) / vrt;\n    const v = sign(pC - 0.5) * s * x ** (1 / 4);\n    const a = (s2 * logit(pC)) / v;\n    const y = (-v * a) / s2;\n    const mdt = ((a / (2 * v)) * (1 - Math.exp(y))) / (1 + Math.exp(y));\n    const t0 = (mrt ? mrt - mdt : null); // compute Ter only if MRT was provided\n\n    const t0Prime = t0 * 1000;\n    return {\n      v,\n      a,\n      t0: t0Prime,\n      s,\n    };\n  }\n\n  static data2ez2() {\n    throw new Error('data2ez2 is not implemented!');\n  }\n}\n","\n// Internal dependencies\nimport DDMMath from './ddm-math';\n\nexport default DDMMath;\n","/* eslint no-restricted-globals: [\"off\", \"self\"] */\n\nimport DDMMath from '@decidables/accumulable-math';\n\nself.onmessage = (event) => {\n  const params = DDMMath.data2ez({...event.data, s: DDMMath.s});\n\n  // ##### Arbitrary default values!!!\n  const a = !isNaN(params.a) ? params.a : 1.5;\n  const z = !isNaN(params.z) ? params.z : 0.5;\n  const v = !isNaN(params.v) ? params.v : 0.1;\n  const t0 = !isNaN(params.t0) ? params.t0 : 100;\n  const s = !isNaN(params.s) ? params.s : DDMMath.s;\n\n  const predicted = {\n    accuracy: DDMMath.azv2pC(a, z, v),\n    correctMeanRT: DDMMath.azvt02mC(a, z, v, t0),\n    errorMeanRT: DDMMath.azvt02mE(a, z, v, t0),\n    meanRT: DDMMath.azvt02m(a, z, v, t0),\n    correctSDRT: DDMMath.azv2sdC(a, z, v),\n    errorSDRT: DDMMath.azv2sdE(a, z, v),\n    sdRT: DDMMath.azv2sd(a, z, v),\n  };\n\n  self.postMessage({\n    params: {\n      a, z, v, t0, s,\n    },\n    predicted,\n  });\n};\n"],"names":["DDMMath","s","trials2stats","trials","stats","sums","reduce","accumulator","trial","outcome","correctCount","correctRTSum","rt","errorCount","errorRTSum","nrCount","accuracy","correctMeanRT","errorMeanRT","meanRT","sums2","ss","correctSS","errorSS","correctSDRT","Math","sqrt","NaN","errorSDRT","sdRT","azv2pE","a","z","v","zPrime","A","exp","Z","azv2pC","azvt02m","t0","mean","azv2sd","variance","azvt02mE","phi","x","y","azv2sdE","azvt02mC","azv2sdC","tazv2gE","t","base","PI","k","term","sum","sin","tazv2gC","data2ez","pC","sd","m","sign","r","logit","p","log","vrt","mrt","s2","l","mdt","t0Prime","data2ez2","Error","self","onmessage","event","params","data","isNaN","predicted","postMessage"],"mappings":"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"}');
7329
+ var WorkerFactory = /*#__PURE__*/createBase64WorkerFactory('/* rollup-plugin-web-worker-loader */
(function () {
  'use strict';

  /*
    DDMMath Static Class - Not intended for instantiation!

    Model parameters:
      a = boundary separation [0, Infinity)
      z = starting point as a proportion of a (0, 1)
      v = drift rate (per second) (-Infinity, Infinity)
      t0 = non-decision time (in milliseconds) (0, Infinity)
      s = within-trial variability in drift rate (s^2 = infinitesimal variance) [0, Infinity)

      zPrime = starting point on a 0-to-a scale (typically used in published equations) [0, Infinity)

    Behavioral variables:
      pE = proportion of error trials
      pC = proportion of correct trials
      m = mean of overall RTs (in milliseconds)
      mE = mean of error RTs (in milliseconds)
      mC = mean correct RTs (in milliseconds)
      sd = standard deviation of overall RTs (in milliseconds)
      sdE = standard deviation of error RTs (in milliseconds)
      sdC = standard deviation of correct RTs (in milliseconds)

    Equations:
      Probability of correct and error responses (Alexandrowicz, 2020)
      Mean of overall, error, and correct RTs (Grasman et al., 2009)
      Standard deviation of overall, error, and correct RTs (Grasman et al., 2009)
      Density of error and correct RT distributions (Alexandrowicz, 2020)
      EZ-diffusion model (Wagenmakers et al., 2007)
  */
  class DDMMath {
    static s = {
      DEFAULT: 1
    };
    static a = {
      DEFAULT: 1.2,
      MIN: 0.01,
      MAX: 2.0,
      STEP: 0.01,
      JUMP: 0.1
    };
    static z = {
      DEFAULT: 0.55,
      MIN: 0.01,
      MAX: 0.99,
      STEP: 0.01,
      JUMP: 0.1
    };
    static v = {
      DEFAULT: 1.5,
      MIN: 0.01,
      MAX: 5.0,
      STEP: 0.01,
      JUMP: 0.1
    };
    static t0 = {
      DEFAULT: 150,
      MIN: 0,
      MAX: 500,
      STEP: 1,
      JUMP: 10
    };

    // Calculate a bunch of statistics for an array of trials
    static trials2stats(trials) {
      const stats = {};

      // First-order sums
      const sums = trials.reduce((accumulator, trial) => {
        switch (trial.outcome) {
          case 'correct':
            accumulator.correctCount += 1;
            accumulator.correctRTSum += trial.rt;
            break;
          case 'error':
            accumulator.errorCount += 1;
            accumulator.errorRTSum += trial.rt;
            break;
          case 'nr':
            accumulator.nrCount += 1;
            break;
          // No-op
        }
        return accumulator;
      }, {
        correctCount: 0,
        errorCount: 0,
        nrCount: 0,
        correctRTSum: 0,
        errorRTSum: 0
      });

      // First-order stats
      stats.correctCount = sums.correctCount;
      stats.errorCount = sums.errorCount;
      stats.nrCount = sums.nrCount;
      stats.accuracy = sums.correctCount / (sums.correctCount + sums.errorCount + sums.nrCount);
      stats.correctMeanRT = sums.correctRTSum / sums.correctCount;
      stats.errorMeanRT = sums.errorRTSum / sums.errorCount;
      stats.meanRT = (sums.correctRTSum + sums.errorRTSum) / (sums.correctCount + sums.errorCount);

      // Second-order sums
      const sums2 = trials.reduce((accumulator, trial) => {
        switch (trial.outcome) {
          case 'correct':
            accumulator.ss += (trial.rt - stats.meanRT) ** 2;
            accumulator.correctSS += (trial.rt - stats.correctMeanRT) ** 2;
            break;
          case 'error':
            accumulator.ss += (trial.rt - stats.meanRT) ** 2;
            accumulator.errorSS += (trial.rt - stats.errorMeanRT) ** 2;
            break;
          // No-op
        }
        return accumulator;
      }, {
        ss: 0,
        correctSS: 0,
        errorSS: 0
      });

      // Second-order stats
      stats.correctSDRT = stats.correctCount > 1 ? Math.sqrt(sums2.correctSS / (stats.correctCount - 1)) : NaN;
      stats.errorSDRT = stats.errorCount > 1 ? Math.sqrt(sums2.errorSS / (stats.errorCount - 1)) : NaN;
      stats.sdRT = stats.correctCount + stats.errorCount > 1 ? Math.sqrt(sums2.ss / (stats.correctCount + stats.errorCount - 1)) : NaN;
      return stats;
    }

    // Probability of an Error Response
    static azv2pE(a, z, v, s = DDMMath.s.DEFAULT) {
      const zPrime = a * z;
      const A = Math.exp(-2 * v * a / s ** 2);
      const Z = Math.exp(-2 * v * zPrime / s ** 2);
      return (A - Z) / (A - 1);
    }

    // Probability of a Correct Response
    static azv2pC(a, z, v, s = DDMMath.s.DEFAULT) {
      return DDMMath.azv2pE(a, 1 - z, -v, s);
    }

    // Mean Overall RT
    // Equation 5 (Grasman et al., 2009)
    static azvt02m(a, z, v, t0, s = DDMMath.s.DEFAULT) {
      const zPrime = a * z;
      const A = Math.exp(-2 * v * a / s ** 2) - 1;
      const Z = Math.exp(-2 * v * zPrime / s ** 2) - 1;
      const mean = -(zPrime / v) + a / v * (Z / A);
      return t0 + mean * 1000;
    }

    // SD Overall RT
    // Equation 6 (Grasman et al., 2009)
    static azv2sd(a, z, v, s = DDMMath.s.DEFAULT) {
      const zPrime = a * z;
      const A = Math.exp(-2 * v * a / s ** 2) - 1;
      const Z = Math.exp(-2 * v * zPrime / s ** 2) - 1;
      const variance = (-v * a ** 2 * (Z + 4) * Z / A ** 2 + ((-3 * v * a ** 2 + 4 * v * zPrime * a + s ** 2 * a) * Z + 4 * v * zPrime * a) / A - s ** 2 * zPrime) / v ** 3;
      return Math.sqrt(variance) * 1000;
    }

    // Mean Error RT
    // Equation 13 (Grasman et al., 2009)
    static azvt02mE(a, z, v, t0, s = DDMMath.s.DEFAULT) {
      function phi(x, y) {
        return Math.exp(2 * v * y / s ** 2) - Math.exp(2 * v * x / s ** 2);
      }
      const zPrime = a * z;
      const mean = (zPrime * (phi(zPrime - a, a) + phi(0, zPrime)) + 2 * a * phi(zPrime, 0)) / (v * phi(zPrime, a) * phi(-a, 0));
      return t0 + mean * 1000;
    }

    // SD Error RT
    // Equation 14 (Grasman et al., 2009)
    static azv2sdE(a, z, v, s = DDMMath.s.DEFAULT) {
      function phi(x, y) {
        return Math.exp(2 * v * y / s ** 2) - Math.exp(2 * v * x / s ** 2);
      }
      const zPrime = a * z;
      const variance = -2 * a * phi(0, zPrime) * (2 * v * a * phi(zPrime, 2 * a) + s ** 2 * phi(0, a) * phi(zPrime, a)) * Math.exp(2 * v * a / s ** 2) / (v ** 3 * phi(0, a) ** 2 * phi(zPrime, a) ** 2) + (4 * v * zPrime * (2 * a - zPrime) * Math.exp(2 * v * (zPrime + a) / s ** 2) + zPrime * s ** 2 * phi(2 * zPrime, 2 * a)) / (v ** 3 * phi(zPrime, a) ** 2);
      return Math.sqrt(variance) * 1000;
    }

    // Mean Correct RT
    static azvt02mC(a, z, v, t0, s = DDMMath.s.DEFAULT) {
      return DDMMath.azvt02mE(a, 1 - z, -v, t0, s);
    }

    // SD Correct RT
    static azv2sdC(a, z, v, s = DDMMath.s.DEFAULT) {
      return DDMMath.azv2sdE(a, 1 - z, -v, s);
    }

    // Density of Error RT
    static tazv2gE(t, a, z, v, s = DDMMath.s.DEFAULT) {
      if (!t) return 0;
      const zPrime = a * z;
      const base = Math.PI * s ** 2 / a ** 2 * Math.exp(-zPrime * v / s ** 2);
      let k = 0;
      let term = 0;
      let sum = 0;
      do {
        k += 1;
        term = k * Math.sin(Math.PI * zPrime * k / a) * Math.exp(-0.5 * (v ** 2 / s ** 2 + Math.PI ** 2 * k ** 2 * s ** 2 / a ** 2) * t);
        sum += term;
      } while (k < 200); // ?? HACK

      return base * sum;
    }

    // Density of Correct RT
    static tazv2gC(t, a, z, v, s = DDMMath.s.DEFAULT) {
      return DDMMath.tazv2gE(t, a, 1 - z, -v, s);
    }

    // Adapted from https://raoul.socsci.uva.nl/EZ2/EZ2_new.html
    // EZ-function for starting values
    // input: obj - Object with properties
    //    pC - Proportion correct
    //    sd - sample standard deviation of the RT's in ms
    //    m - sample mean of the RT's in ms
    //    s - diffusion standard deviation
    // returns: Object with properties v, a, and t0, containing EZ-estimates of these parameters
    static data2ez({
      accuracy: pC,
      sdRT: sd,
      meanRT: m,
      s
    }) {
      function sign(r) {
        return r > 0 ? 1 : r === 0 ? 0 : -1;
      }
      function logit(p) {
        return Math.log(p / (1 - p));
      }
      const vrt = (sd / 1000) ** 2;
      const mrt = m / 1000;
      const s2 = s ** 2;
      const l = logit(pC);
      const x = l * (l * pC ** 2 - l * pC + pC - 0.5) / vrt;
      const v = sign(pC - 0.5) * s * x ** (1 / 4);
      const a = s2 * logit(pC) / v;
      const y = -v * a / s2;
      const mdt = a / (2 * v) * (1 - Math.exp(y)) / (1 + Math.exp(y));
      const t0 = mrt ? mrt - mdt : null; // compute Ter only if MRT was provided

      const t0Prime = t0 * 1000;
      return {
        v,
        a,
        t0: t0Prime,
        s
      };
    }
    static data2ez2() {
      throw new Error('data2ez2 is not implemented!');
    }
  }

  // Internal dependencies

  /* eslint no-restricted-globals: ["off", "self"] */

  self.onmessage = event => {
    const params = DDMMath.data2ez({
      ...event.data,
      s: DDMMath.s.DEFAULT
    });

    // ##### Arbitrary default values!!!
    const a = !isNaN(params.a) ? params.a : 1.5;
    const z = !isNaN(params.z) ? params.z : 0.5;
    const v = !isNaN(params.v) ? params.v : 0.1;
    const t0 = !isNaN(params.t0) ? params.t0 : 100;
    const s = !isNaN(params.s) ? params.s : DDMMath.s.DEFAULT;
    const predicted = {
      accuracy: DDMMath.azv2pC(a, z, v),
      correctMeanRT: DDMMath.azvt02mC(a, z, v, t0),
      errorMeanRT: DDMMath.azvt02mE(a, z, v, t0),
      meanRT: DDMMath.azvt02m(a, z, v, t0),
      correctSDRT: DDMMath.azv2sdC(a, z, v),
      errorSDRT: DDMMath.azv2sdE(a, z, v),
      sdRT: DDMMath.azv2sd(a, z, v)
    };
    self.postMessage({
      params: {
        a,
        z,
        v,
        t0,
        s
      },
      predicted
    });
  };

})();
//# sourceMappingURL=ddm-fit-worker.js.map

', 'data:application/json;charset=utf-8;base64,{"version":3,"file":"ddm-fit-worker.js","sources":["../accumulable-math/src/ddm-math.js","../accumulable-math/src/index.js","src/components/ddm-fit-worker.js"],"sourcesContent":["\n/*\n  DDMMath Static Class - Not intended for instantiation!\n\n  Model parameters:\n    a = boundary separation [0, Infinity)\n    z = starting point as a proportion of a (0, 1)\n    v = drift rate (per second) (-Infinity, Infinity)\n    t0 = non-decision time (in milliseconds) (0, Infinity)\n    s = within-trial variability in drift rate (s^2 = infinitesimal variance) [0, Infinity)\n\n    zPrime = starting point on a 0-to-a scale (typically used in published equations) [0, Infinity)\n\n  Behavioral variables:\n    pE = proportion of error trials\n    pC = proportion of correct trials\n    m = mean of overall RTs (in milliseconds)\n    mE = mean of error RTs (in milliseconds)\n    mC = mean correct RTs (in milliseconds)\n    sd = standard deviation of overall RTs (in milliseconds)\n    sdE = standard deviation of error RTs (in milliseconds)\n    sdC = standard deviation of correct RTs (in milliseconds)\n\n  Equations:\n    Probability of correct and error responses (Alexandrowicz, 2020)\n    Mean of overall, error, and correct RTs (Grasman et al., 2009)\n    Standard deviation of overall, error, and correct RTs (Grasman et al., 2009)\n    Density of error and correct RT distributions (Alexandrowicz, 2020)\n    EZ-diffusion model (Wagenmakers et al., 2007)\n*/\nexport default class DDMMath {\n  static s = {\n    DEFAULT: 1,\n  };\n\n  static a = {\n    DEFAULT: 1.2,\n    MIN: 0.01,\n    MAX: 2.0,\n    STEP: 0.01,\n    JUMP: 0.1,\n  };\n\n  static z = {\n    DEFAULT: 0.55,\n    MIN: 0.01,\n    MAX: 0.99,\n    STEP: 0.01,\n    JUMP: 0.1,\n  };\n\n  static v = {\n    DEFAULT: 1.5,\n    MIN: 0.01,\n    MAX: 5.0,\n    STEP: 0.01,\n    JUMP: 0.1,\n  };\n\n  static t0 = {\n    DEFAULT: 150,\n    MIN: 0,\n    MAX: 500,\n    STEP: 1,\n    JUMP: 10,\n  };\n\n  // Calculate a bunch of statistics for an array of trials\n  static trials2stats(trials) {\n    const stats = {};\n\n    // First-order sums\n    const sums = trials.reduce(\n      (accumulator, trial) => {\n        switch (trial.outcome) {\n          case 'correct':\n            accumulator.correctCount += 1;\n            accumulator.correctRTSum += trial.rt;\n            break;\n          case 'error':\n            accumulator.errorCount += 1;\n            accumulator.errorRTSum += trial.rt;\n            break;\n          case 'nr':\n            accumulator.nrCount += 1;\n            break;\n          default:\n            // No-op\n        }\n        return accumulator;\n      },\n      {\n        correctCount: 0,\n        errorCount: 0,\n        nrCount: 0,\n\n        correctRTSum: 0,\n        errorRTSum: 0,\n      },\n    );\n\n    // First-order stats\n    stats.correctCount = sums.correctCount;\n    stats.errorCount = sums.errorCount;\n    stats.nrCount = sums.nrCount;\n    stats.accuracy = sums.correctCount / (sums.correctCount + sums.errorCount + sums.nrCount);\n\n    stats.correctMeanRT = sums.correctRTSum / sums.correctCount;\n    stats.errorMeanRT = sums.errorRTSum / sums.errorCount;\n    stats.meanRT = (sums.correctRTSum + sums.errorRTSum) / (sums.correctCount + sums.errorCount);\n\n    // Second-order sums\n    const sums2 = trials.reduce(\n      (accumulator, trial) => {\n        switch (trial.outcome) {\n          case 'correct':\n            accumulator.ss += (trial.rt - stats.meanRT) ** 2;\n            accumulator.correctSS += (trial.rt - stats.correctMeanRT) ** 2;\n            break;\n          case 'error':\n            accumulator.ss += (trial.rt - stats.meanRT) ** 2;\n            accumulator.errorSS += (trial.rt - stats.errorMeanRT) ** 2;\n            break;\n          default:\n            // No-op\n        }\n        return accumulator;\n      },\n      {\n        ss: 0,\n        correctSS: 0,\n        errorSS: 0,\n      },\n    );\n\n    // Second-order stats\n    stats.correctSDRT = (stats.correctCount > 1)\n      ? Math.sqrt(sums2.correctSS / (stats.correctCount - 1))\n      : NaN;\n    stats.errorSDRT = (stats.errorCount > 1)\n      ? Math.sqrt(sums2.errorSS / (stats.errorCount - 1))\n      : NaN;\n    stats.sdRT = (stats.correctCount + stats.errorCount > 1)\n      ? Math.sqrt(sums2.ss / (stats.correctCount + stats.errorCount - 1))\n      : NaN;\n\n    return stats;\n  }\n\n  // Probability of an Error Response\n  static azv2pE(a, z, v, s = DDMMath.s.DEFAULT) {\n    const zPrime = a * z;\n\n    const A = Math.exp((-2 * v * a) / s ** 2);\n    const Z = Math.exp((-2 * v * zPrime) / s ** 2);\n\n    return (A - Z) / (A - 1);\n  }\n\n  // Probability of a Correct Response\n  static azv2pC(a, z, v, s = DDMMath.s.DEFAULT) {\n    return DDMMath.azv2pE(a, 1 - z, -v, s);\n  }\n\n  // Mean Overall RT\n  // Equation 5 (Grasman et al., 2009)\n  static azvt02m(a, z, v, t0, s = DDMMath.s.DEFAULT) {\n    const zPrime = a * z;\n    const A = Math.exp((-2 * v * a) / s ** 2) - 1;\n    const Z = Math.exp((-2 * v * zPrime) / s ** 2) - 1;\n\n    const mean = -(zPrime / v) + (a / v) * (Z / A);\n    return t0 + mean * 1000;\n  }\n\n  // SD Overall RT\n  // Equation 6 (Grasman et al., 2009)\n  static azv2sd(a, z, v, s = DDMMath.s.DEFAULT) {\n    const zPrime = a * z;\n    const A = Math.exp((-2 * v * a) / s ** 2) - 1;\n    const Z = Math.exp((-2 * v * zPrime) / s ** 2) - 1;\n\n    const variance = (\n      (\n        (-v * a ** 2 * (Z + 4) * Z) / A ** 2\n      ) + (\n        ((-3 * v * a ** 2 + 4 * v * zPrime * a + s ** 2 * a) * Z + 4 * v * zPrime * a) / A\n      ) - (\n        s ** 2 * zPrime\n      )\n    ) / v ** 3;\n\n    return Math.sqrt(variance) * 1000;\n  }\n\n  // Mean Error RT\n  // Equation 13 (Grasman et al., 2009)\n  static azvt02mE(a, z, v, t0, s = DDMMath.s.DEFAULT) {\n    function phi(x, y) {\n      return Math.exp((2 * v * y) / (s ** 2)) - Math.exp((2 * v * x) / (s ** 2));\n    }\n    const zPrime = a * z;\n\n    const mean = (zPrime * (phi(zPrime - a, a) + phi(0, zPrime)) + 2 * a * phi(zPrime, 0))\n      / (v * phi(zPrime, a) * phi(-a, 0));\n    return t0 + mean * 1000;\n  }\n\n  // SD Error RT\n  // Equation 14 (Grasman et al., 2009)\n  static azv2sdE(a, z, v, s = DDMMath.s.DEFAULT) {\n    function phi(x, y) {\n      return Math.exp((2 * v * y) / (s ** 2)) - Math.exp((2 * v * x) / (s ** 2));\n    }\n    const zPrime = a * z;\n\n    const variance = (\n      (\n        -2 * a * phi(0, zPrime)\n        * ((2 * v * a * phi(zPrime, 2 * a)) + (s ** 2 * phi(0, a) * phi(zPrime, a)))\n        * Math.exp((2 * v * a) / s ** 2)\n      ) / (\n        v ** 3 * phi(0, a) ** 2 * phi(zPrime, a) ** 2\n      )\n    ) + (\n      (\n        4 * v * zPrime * (2 * a - zPrime) * Math.exp((2 * v * (zPrime + a)) / s ** 2)\n        + zPrime * s ** 2 * phi(2 * zPrime, 2 * a)\n      ) / (\n        v ** 3 * phi(zPrime, a) ** 2\n      )\n    );\n\n    return Math.sqrt(variance) * 1000;\n  }\n\n  // Mean Correct RT\n  static azvt02mC(a, z, v, t0, s = DDMMath.s.DEFAULT) {\n    return DDMMath.azvt02mE(a, 1 - z, -v, t0, s);\n  }\n\n  // SD Correct RT\n  static azv2sdC(a, z, v, s = DDMMath.s.DEFAULT) {\n    return DDMMath.azv2sdE(a, 1 - z, -v, s);\n  }\n\n  // Density of Error RT\n  static tazv2gE(t, a, z, v, s = DDMMath.s.DEFAULT) {\n    if (!t) return 0;\n\n    const zPrime = a * z;\n    const base = ((Math.PI * s ** 2) / a ** 2) * Math.exp((-zPrime * v) / s ** 2);\n\n    let k = 0;\n    let term = 0;\n    let sum = 0;\n    do {\n      k += 1;\n\n      term = k\n        * Math.sin((Math.PI * zPrime * k) / a)\n        * Math.exp(-0.5 * ((v ** 2 / s ** 2) + ((Math.PI ** 2 * k ** 2 * s ** 2) / a ** 2)) * t);\n\n      sum += term;\n    } while (k < 200); // ?? HACK\n\n    return base * sum;\n  }\n\n  // Density of Correct RT\n  static tazv2gC(t, a, z, v, s = DDMMath.s.DEFAULT) {\n    return DDMMath.tazv2gE(t, a, 1 - z, -v, s);\n  }\n\n  // Adapted from https://raoul.socsci.uva.nl/EZ2/EZ2_new.html\n  // EZ-function for starting values\n  // input: obj - Object with properties\n  //    pC - Proportion correct\n  //    sd - sample standard deviation of the RT's in ms\n  //    m - sample mean of the RT's in ms\n  //    s - diffusion standard deviation\n  // returns: Object with properties v, a, and t0, containing EZ-estimates of these parameters\n  static data2ez({\n    accuracy: pC,\n    sdRT: sd,\n    meanRT: m,\n    s,\n  }) {\n    function sign(r) {\n      return ((r > 0) ? 1 : ((r === 0) ? 0 : -1));\n    }\n\n    function logit(p) {\n      return Math.log(p / (1 - p));\n    }\n\n    const vrt = (sd / 1000) ** 2;\n    const mrt = m / 1000;\n\n    const s2 = s ** 2;\n    const l = logit(pC);\n    const x = (l * (l * pC ** 2 - l * pC + pC - 0.5)) / vrt;\n    const v = sign(pC - 0.5) * s * x ** (1 / 4);\n    const a = (s2 * logit(pC)) / v;\n    const y = (-v * a) / s2;\n    const mdt = ((a / (2 * v)) * (1 - Math.exp(y))) / (1 + Math.exp(y));\n    const t0 = (mrt ? mrt - mdt : null); // compute Ter only if MRT was provided\n\n    const t0Prime = t0 * 1000;\n    return {\n      v,\n      a,\n      t0: t0Prime,\n      s,\n    };\n  }\n\n  static data2ez2() {\n    throw new Error('data2ez2 is not implemented!');\n  }\n}\n","\n// Internal dependencies\nimport DDMMath from './ddm-math';\n\nexport default DDMMath;\n","/* eslint no-restricted-globals: [\"off\", \"self\"] */\n\nimport DDMMath from '@decidables/accumulable-math';\n\nself.onmessage = (event) => {\n  const params = DDMMath.data2ez({...event.data, s: DDMMath.s.DEFAULT});\n\n  // ##### Arbitrary default values!!!\n  const a = !isNaN(params.a) ? params.a : 1.5;\n  const z = !isNaN(params.z) ? params.z : 0.5;\n  const v = !isNaN(params.v) ? params.v : 0.1;\n  const t0 = !isNaN(params.t0) ? params.t0 : 100;\n  const s = !isNaN(params.s) ? params.s : DDMMath.s.DEFAULT;\n\n  const predicted = {\n    accuracy: DDMMath.azv2pC(a, z, v),\n    correctMeanRT: DDMMath.azvt02mC(a, z, v, t0),\n    errorMeanRT: DDMMath.azvt02mE(a, z, v, t0),\n    meanRT: DDMMath.azvt02m(a, z, v, t0),\n    correctSDRT: DDMMath.azv2sdC(a, z, v),\n    errorSDRT: DDMMath.azv2sdE(a, z, v),\n    sdRT: DDMMath.azv2sd(a, z, v),\n  };\n\n  self.postMessage({\n    params: {\n      a, z, v, t0, s,\n    },\n    predicted,\n  });\n};\n"],"names":["DDMMath","s","DEFAULT","a","MIN","MAX","STEP","JUMP","z","v","t0","trials2stats","trials","stats","sums","reduce","accumulator","trial","outcome","correctCount","correctRTSum","rt","errorCount","errorRTSum","nrCount","accuracy","correctMeanRT","errorMeanRT","meanRT","sums2","ss","correctSS","errorSS","correctSDRT","Math","sqrt","NaN","errorSDRT","sdRT","azv2pE","zPrime","A","exp","Z","azv2pC","azvt02m","mean","azv2sd","variance","azvt02mE","phi","x","y","azv2sdE","azvt02mC","azv2sdC","tazv2gE","t","base","PI","k","term","sum","sin","tazv2gC","data2ez","pC","sd","m","sign","r","logit","p","log","vrt","mrt","s2","l","mdt","t0Prime","data2ez2","Error","self","onmessage","event","params","data","isNaN","predicted","postMessage"],"mappings":"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"}');
7238
7330
  /* eslint-enable */
7239
7331
 
7240
7332
  /*
@@ -7250,10 +7342,10 @@
7250
7342
  }
7251
7343
  constructor() {
7252
7344
  super();
7253
- this.a = 1.2;
7254
- this.z = 0.35;
7255
- this.v = 1.5;
7256
- this.t0 = 150;
7345
+ this.a = DDMMath.a.DEFAULT;
7346
+ this.z = DDMMath.z.DEFAULT;
7347
+ this.v = DDMMath.v.DEFAULT;
7348
+ this.t0 = DDMMath.t0.DEFAULT;
7257
7349
  this.observed = {};
7258
7350
  this.predicted = {};
7259
7351
  this.working = false;
@@ -7301,7 +7393,7 @@
7301
7393
  this.fit();
7302
7394
  }
7303
7395
  static get styles() {
7304
- return [super.styles, i$2`
7396
+ return [super.styles, i$3`
7305
7397
  :host {
7306
7398
  display: inline-block;
7307
7399
  }
@@ -7418,7 +7510,7 @@
7418
7510
  }));
7419
7511
  }
7420
7512
  static get styles() {
7421
- return [super.styles, i$2`
7513
+ return [super.styles, i$3`
7422
7514
  :host {
7423
7515
  display: inline-block;
7424
7516
  }
@@ -7440,15 +7532,71 @@
7440
7532
  decidables-slider div {
7441
7533
  margin-bottom: 0.25rem;
7442
7534
  }
7535
+
7536
+ .a {
7537
+ --decidables-slider-background-color: var(---color-a-light);
7538
+ --decidables-slider-color: var(---color-a);
7539
+ }
7540
+
7541
+ .z {
7542
+ --decidables-slider-background-color: var(---color-z-light);
7543
+ --decidables-slider-color: var(---color-z);
7544
+ }
7545
+
7546
+ .v {
7547
+ --decidables-slider-background-color: var(---color-v-light);
7548
+ --decidables-slider-color: var(---color-v);
7549
+ }
7550
+
7551
+ .t0 {
7552
+ --decidables-slider-background-color: var(---color-t0-light);
7553
+ --decidables-slider-color: var(---color-t0);
7554
+ }
7443
7555
  `];
7444
7556
  }
7445
7557
  render() {
7446
7558
  return x$1`
7447
7559
  <div class="holder">
7448
- ${this.a != null ? x$1`<decidables-slider class="a" ?disabled=${!this.interactive} min="0.01" max="2" step="0.01" .value=${+this.a.toFixed(2)} @change=${this.setBoundarySeparation.bind(this)} @input=${this.setBoundarySeparation.bind(this)}><div>Boundary Separation<br><span class="math-var">a</span></div></decidables-slider>` : x$1``}
7449
- ${this.z != null ? x$1`<decidables-slider class="z" ?disabled=${!this.interactive} min="0.01" max="0.99" step="0.01" .value=${+this.z.toFixed(2)} @change=${this.setStartingPoint.bind(this)} @input=${this.setStartingPoint.bind(this)}><div>Starting Point<br><span class="math-var">z</span></div></decidables-slider>` : x$1``}
7450
- ${this.v != null ? x$1`<decidables-slider class="v" ?disabled=${!this.interactive} min="0.01" max="5" step="0.01" .value=${+this.v.toFixed(2)} @change=${this.setDriftRate.bind(this)} @input=${this.setDriftRate.bind(this)}><div>Drift Rate<br><span class="math-var">v</span></div></decidables-slider>` : x$1``}
7451
- ${this.t0 != null ? x$1`<decidables-slider class="t0" ?disabled=${!this.interactive} min="0" max="500" step="1" .value=${+this.t0.toFixed(0)} @change=${this.setNondecisionTime.bind(this)} @input=${this.setNondecisionTime.bind(this)}><div>Nondecision Time<br><span class="math-var">t₀</span></div></decidables-slider>` : x$1``}
7560
+ ${this.a != null ? x$1`<decidables-slider class="a"
7561
+ ?disabled=${!this.interactive}
7562
+ scale
7563
+ min=${DDMMath.a.MIN}
7564
+ max=${DDMMath.a.MAX}
7565
+ step=${DDMMath.a.STEP}
7566
+ .value=${+this.a.toFixed(2)}
7567
+ @change=${this.setBoundarySeparation.bind(this)}
7568
+ @input=${this.setBoundarySeparation.bind(this)}
7569
+ ><div>Boundary Separation<br><span class="math-var">a</span></div></decidables-slider>` : x$1``}
7570
+ ${this.z != null ? x$1`<decidables-slider class="z"
7571
+ ?disabled=${!this.interactive}
7572
+ scale
7573
+ min=${DDMMath.z.MIN}
7574
+ max=${DDMMath.z.MAX}
7575
+ step=${DDMMath.z.STEP}
7576
+ .value=${+this.z.toFixed(2)}
7577
+ @change=${this.setStartingPoint.bind(this)}
7578
+ @input=${this.setStartingPoint.bind(this)}
7579
+ ><div>Starting Point<br><span class="math-var">z</span></div></decidables-slider>` : x$1``}
7580
+ ${this.v != null ? x$1`<decidables-slider class="v"
7581
+ ?disabled=${!this.interactive}
7582
+ scale
7583
+ min=${DDMMath.v.MIN}
7584
+ max=${DDMMath.v.MAX}
7585
+ step=${DDMMath.v.STEP}
7586
+ .value=${+this.v.toFixed(2)}
7587
+ @change=${this.setDriftRate.bind(this)}
7588
+ @input=${this.setDriftRate.bind(this)}
7589
+ ><div>Drift Rate<br><span class="math-var">v</span></div></decidables-slider>` : x$1``}
7590
+ ${this.t0 != null ? x$1`<decidables-slider class="t0"
7591
+ ?disabled=${!this.interactive}
7592
+ scale
7593
+ min=${DDMMath.t0.MIN}
7594
+ max=${DDMMath.t0.MAX}
7595
+ step=${DDMMath.t0.STEP}
7596
+ .value=${+this.t0.toFixed(0)}
7597
+ @change=${this.setNondecisionTime.bind(this)}
7598
+ @input=${this.setNondecisionTime.bind(this)}
7599
+ ><div>Nondecision Time<br><span class="math-var">t₀</span></div></decidables-slider>` : x$1``}
7452
7600
  </div>`;
7453
7601
  }
7454
7602
  }
@@ -7586,10 +7734,10 @@
7586
7734
  this.resample();
7587
7735
  this.human = false;
7588
7736
  this.trials = 10;
7589
- this.a = 1.2;
7590
- this.z = 0.35;
7591
- this.v = 1.5;
7592
- this.t0 = 150;
7737
+ this.a = DDMMath.a.DEFAULT;
7738
+ this.z = DDMMath.z.DEFAULT;
7739
+ this.v = DDMMath.v.DEFAULT;
7740
+ this.t0 = DDMMath.t0.DEFAULT;
7593
7741
 
7594
7742
  // this.s = null;
7595
7743
  // this.sz = null;
@@ -7650,7 +7798,7 @@
7650
7798
  while (path.at(-1).e > bounds.lower && path.at(-1).e < bounds.upper) {
7651
7799
  path.push({
7652
7800
  t: path.at(-1).t + this.precision * 1000,
7653
- e: path.at(-1).e + drift + DDMMath.s * random()
7801
+ e: path.at(-1).e + drift + DDMMath.s.DEFAULT * random()
7654
7802
  });
7655
7803
  }
7656
7804
  return path;
@@ -7754,7 +7902,7 @@
7754
7902
  }));
7755
7903
  }
7756
7904
  static get styles() {
7757
- return [super.styles, i$2`
7905
+ return [super.styles, i$3`
7758
7906
  :host {
7759
7907
  display: inline-block;
7760
7908
 
@@ -7940,10 +8088,25 @@
7940
8088
 
7941
8089
  .t0z .point {
7942
8090
  fill: var(---color-element-emphasis);
8091
+ stroke-width: 0;
7943
8092
 
7944
8093
  r: 6px;
7945
8094
  }
7946
8095
 
8096
+ /* Make larger targets for touch users */
8097
+ .interactive .touch {
8098
+ stroke: #000000;
8099
+ stroke-dasharray: none;
8100
+ stroke-opacity: 0;
8101
+ }
8102
+
8103
+ @media (pointer: coarse) {
8104
+ .interactive .touch {
8105
+ stroke-linecap: round;
8106
+ stroke-width: 12;
8107
+ }
8108
+ }
8109
+
7947
8110
  .measure {
7948
8111
  stroke-width: 2;
7949
8112
  }
@@ -8118,9 +8281,9 @@
8118
8281
  let t0 = timeScale.invert(event.x);
8119
8282
  let z = (evidenceScale.invert(event.y) + this.a / 2) / this.a;
8120
8283
  // Clamp t0
8121
- t0 = shift === 'z' ? timeScale.invert(event.subject.x) : t0 < 0 ? 0 : t0 > 500 ? 500 : t0;
8284
+ t0 = shift === 'z' ? timeScale.invert(event.subject.x) : t0 < DDMMath.t0.MIN ? DDMMath.t0.MIN : t0 > DDMMath.t0.MAX ? DDMMath.t0.MAX : t0;
8122
8285
  // Clamp z
8123
- z = shift === 't0' ? (evidenceScale.invert(event.subject.y) + this.a / 2) / this.a : z < 0.01 ? 0.01 : z > 0.99 ? 0.99 : z;
8286
+ z = shift === 't0' ? (evidenceScale.invert(event.subject.y) + this.a / 2) / this.a : z < DDMMath.z.MIN ? DDMMath.z.MIN : z > DDMMath.z.MAX ? DDMMath.z.MAX : z;
8124
8287
  this.t0 = t0;
8125
8288
  this.z = z;
8126
8289
  this.alignState();
@@ -8150,7 +8313,7 @@
8150
8313
  this.drag = true;
8151
8314
  let v = (evidenceScale.invert(event.y) - this.startingPoint) / (timeScale.invert(event.x) - this.t0) * 1000;
8152
8315
  // Clamp drift rate
8153
- v = v < 0.01 ? 0.01 : v > 5 ? 5 : v;
8316
+ v = v < DDMMath.v.MIN ? DDMMath.v.MIN : v > DDMMath.v.MAX ? DDMMath.v.MAX : v;
8154
8317
  this.v = v;
8155
8318
  this.alignState();
8156
8319
  this.dispatchEvent(new CustomEvent('ddm-model-v', {
@@ -8174,12 +8337,13 @@
8174
8337
  }).on('start', event => {
8175
8338
  const element = event.currentTarget;
8176
8339
  select(element).classed('dragging', true);
8177
- }).on('drag', (event, datum) => {
8340
+ }).on('drag', event => {
8178
8341
  this.drag = true;
8179
- let boundary = evidenceScale.invert(event.y);
8180
- // Clamp boundaries to visible evidence
8181
- boundary = boundary < this.scale.evidence.min ? this.scale.evidence.min : boundary > this.scale.evidence.max ? this.scale.evidence.max : datum.bound === 'upper' && boundary < 0.005 ? 0.005 : datum.bound === 'lower' && boundary > -0.005 ? -0.005 : boundary;
8182
- this.a = Math.abs(boundary * 2);
8342
+ const boundary = evidenceScale.invert(event.y);
8343
+ let a = Math.abs(boundary * 2);
8344
+ // Clamp a
8345
+ a = a < DDMMath.a.MIN ? DDMMath.a.MIN : a > DDMMath.a.MAX ? DDMMath.a.MAX : a;
8346
+ this.a = a;
8183
8347
  this.alignState();
8184
8348
  this.dispatchEvent(new CustomEvent('ddm-model-a', {
8185
8349
  detail: {
@@ -8370,8 +8534,8 @@
8370
8534
  });
8371
8535
  accuracyUnderlayerEnter.append('g').classed('axis accuracy', true);
8372
8536
  // MERGE
8373
- const evidenceScaleMerge = evidenceUnderlayerMerge.select('.axis.evidence').attr('transform', `translate(${-0.25 * this.rem}, 0)`);
8374
- const densityScaleMerge = densityUnderlayerMerge.select('.axis.density').attr('transform', `translate(${-0.25 * this.rem}, 0)`);
8537
+ const evidenceScaleMerge = evidenceUnderlayerMerge.select('.axis.evidence').attr('transform', `translate(${ -0.25 * this.rem}, 0)`);
8538
+ const densityScaleMerge = densityUnderlayerMerge.select('.axis.density').attr('transform', `translate(${ -0.25 * this.rem}, 0)`);
8375
8539
  const accuracyScaleMerge = accuracyUnderlayerMerge.select('.axis.accuracy').attr('transform', `translate(${accuracyWidth + 0.25 * this.rem}, 0)`);
8376
8540
  const evidenceScaleTransition = evidenceScaleMerge.transition().duration(transitionDuration).ease(cubicOut).call(axisLeft(evidenceScale)).attr('font-size', null).attr('font-family', null);
8377
8541
  const densityScaleTransition = densityScaleMerge.transition().duration(transitionDuration).ease(cubicOut).each((datum, index, elements) => {
@@ -8393,8 +8557,8 @@
8393
8557
  densityTitleEnter.append('tspan').classed('name', true).text('Density');
8394
8558
  accuracyTitleEnter.append('tspan').classed('name', true).text('Accuracy');
8395
8559
  // MERGE
8396
- evidenceUnderlayerMerge.select('.title.evidence').transition().duration(transitionDuration).ease(cubicOut).attr('transform', `translate(${-2.5 * this.rem}, ${evidenceHeight / 2})rotate(-90)`);
8397
- densityUnderlayerMerge.select('.title.density').transition().duration(transitionDuration).ease(cubicOut).attr('transform', `translate(${-2.5 * this.rem}, ${densityHeight / 2})rotate(-90)`);
8560
+ evidenceUnderlayerMerge.select('.title.evidence').transition().duration(transitionDuration).ease(cubicOut).attr('transform', `translate(${ -2.5 * this.rem}, ${evidenceHeight / 2})rotate(-90)`);
8561
+ densityUnderlayerMerge.select('.title.density').transition().duration(transitionDuration).ease(cubicOut).attr('transform', `translate(${ -2.5 * this.rem}, ${densityHeight / 2})rotate(-90)`);
8398
8562
  accuracyUnderlayerMerge.select('.title.accuracy').transition().duration(transitionDuration).ease(cubicOut).attr('transform', `translate(${accuracyWidth + 2.25 * this.rem}, ${height / 2})rotate(90)`);
8399
8563
 
8400
8564
  //
@@ -8620,20 +8784,23 @@
8620
8784
  return `boundary ${index === 0 ? 'correct' : 'error'}`;
8621
8785
  });
8622
8786
  boundaryEnter.append('line').classed('line', true);
8787
+ boundaryEnter.append('line').classed('line touch', true);
8623
8788
  // MERGE
8624
8789
  const boundaryMerge = boundaryEnter.merge(boundaryUpdate).attr('tabindex', this.interactive ? 0 : null).classed('interactive', this.interactive).on('keydown', this.interactive ? (event, datum) => {
8625
8790
  if (['ArrowUp', 'ArrowDown'].includes(event.key)) {
8626
- let a = this.a; /* eslint-disable-line prefer-destructuring */
8791
+ let {
8792
+ a
8793
+ } = this;
8627
8794
  switch (event.key) {
8628
8795
  case 'ArrowUp':
8629
- a += datum.bound === 'upper' ? event.shiftKey ? 0.01 : 0.1 : event.shiftKey ? -0.01 : -0.1;
8796
+ a += datum.bound === 'upper' ? event.shiftKey ? DDMMath.a.STEP : DDMMath.a.JUMP : event.shiftKey ? -0.01 : -0.1;
8630
8797
  break;
8631
8798
  case 'ArrowDown':
8632
- a += datum.bound === 'upper' ? event.shiftKey ? -0.01 : -0.1 : event.shiftKey ? 0.01 : 0.1;
8799
+ a += datum.bound === 'upper' ? event.shiftKey ? -0.01 : -0.1 : event.shiftKey ? DDMMath.a.STEP : DDMMath.a.JUMP;
8633
8800
  break;
8634
8801
  }
8635
- // Clamp boundaries to visible evidence
8636
- a = a < 0.01 ? 0.01 : a > this.scale.evidence.max * 2 ? this.scale.evidence.max * 2 : a;
8802
+ // Clamp a
8803
+ a = a < DDMMath.a.MIN ? DDMMath.a.MIN : a > DDMMath.a.MAX ? DDMMath.a.MAX : a;
8637
8804
  this.a = a;
8638
8805
  this.alignState();
8639
8806
  this.dispatchEvent(new CustomEvent('ddm-model-a', {
@@ -8657,6 +8824,11 @@
8657
8824
  }).attr('y2', datum => {
8658
8825
  return evidenceScale(datum.value);
8659
8826
  });
8827
+ boundaryMerge.select('.line.touch').transition().duration(this.drag ? 0 : transitionDuration).ease(cubicOut).attr('x1', timeScale(this.scale.time.min)).attr('x2', timeScale(this.scale.time.max)).attr('y1', datum => {
8828
+ return evidenceScale(datum.value);
8829
+ }).attr('y2', datum => {
8830
+ return evidenceScale(datum.value);
8831
+ });
8660
8832
  // EXIT
8661
8833
  boundaryUpdate.exit().remove();
8662
8834
 
@@ -8670,21 +8842,25 @@
8670
8842
  // ENTER
8671
8843
  const driftEnter = driftUpdate.enter().append('g').classed('drift', true);
8672
8844
  driftEnter.append('line').classed('line', true);
8845
+ driftEnter.append('line').classed('line touch', true);
8673
8846
  driftEnter.append('path').classed('arrow', true);
8847
+ driftEnter.append('path').classed('arrow touch', true);
8674
8848
  // MERGE
8675
8849
  const driftMerge = driftEnter.merge(driftUpdate).attr('tabindex', this.interactive ? 0 : null).classed('interactive', this.interactive).on('keydown', this.interactive ? event => {
8676
8850
  if (['ArrowUp', 'ArrowDown'].includes(event.key)) {
8677
- let v = this.v; /* eslint-disable-line prefer-destructuring */
8851
+ let {
8852
+ v
8853
+ } = this;
8678
8854
  switch (event.key) {
8679
8855
  case 'ArrowUp':
8680
- v += event.shiftKey ? 0.01 : 0.1;
8856
+ v += event.shiftKey ? DDMMath.v.STEP : DDMMath.v.JUMP;
8681
8857
  break;
8682
8858
  case 'ArrowDown':
8683
- v -= event.shiftKey ? 0.01 : 0.1;
8859
+ v -= event.shiftKey ? DDMMath.v.STEP : DDMMath.v.JUMP;
8684
8860
  break;
8685
8861
  }
8686
8862
  // Clamp z
8687
- v = v < 0.01 ? 0.01 : v > 5 ? 5 : v;
8863
+ v = v < DDMMath.v.MIN ? DDMMath.v.MIN : v > DDMMath.v.MAX ? DDMMath.v.MAX : v;
8688
8864
  this.v = v;
8689
8865
  this.alignState();
8690
8866
  this.dispatchEvent(new CustomEvent('ddm-model-v', {
@@ -8709,11 +8885,17 @@
8709
8885
  rotate(${-Math.atan(datum.v / 1000 * scaleRatio) * (180 / Math.PI)})`;
8710
8886
  });
8711
8887
  driftMerge.select('.line').attr('x2', timeScale(200));
8888
+ driftMerge.select('.line.touch').attr('x2', timeScale(200));
8712
8889
  driftMerge.select('.arrow').attr('d', `
8713
8890
  M ${timeScale(200) - this.rem * 0.5},${-this.rem * 0.5}
8714
8891
  l ${this.rem * 0.5},${this.rem * 0.5}
8715
8892
  l ${-this.rem * 0.5},${this.rem * 0.5}
8716
8893
  `);
8894
+ driftMerge.select('.arrow.touch').attr('d', `
8895
+ M ${timeScale(200) - this.rem * 0.5},${-this.rem * 0.5}
8896
+ l ${this.rem * 0.5},${this.rem * 0.5}
8897
+ l ${-this.rem * 0.5},${this.rem * 0.5}
8898
+ `);
8717
8899
  // EXIT
8718
8900
  driftUpdate.exit().remove();
8719
8901
 
@@ -8726,21 +8908,24 @@
8726
8908
  // ENTER
8727
8909
  const t0zEnter = t0zUpdate.enter().append('g').classed('t0z', true);
8728
8910
  t0zEnter.append('line').classed('line', true);
8729
- t0zEnter.append('circle').classed('point', true);
8911
+ t0zEnter.append('line').classed('line touch', true);
8912
+ t0zEnter.append('circle').classed('point touch', true);
8730
8913
  // MERGE
8731
8914
  const t0zMerge = t0zEnter.merge(t0zUpdate).attr('tabindex', this.interactive ? 0 : null).classed('interactive', this.interactive).on('keydown', this.interactive ? event => {
8732
8915
  if (['ArrowUp', 'ArrowDown'].includes(event.key)) {
8733
- let z = this.z; /* eslint-disable-line prefer-destructuring */
8916
+ let {
8917
+ z
8918
+ } = this;
8734
8919
  switch (event.key) {
8735
8920
  case 'ArrowUp':
8736
- z += event.shiftKey ? 0.01 : 0.1;
8921
+ z += event.shiftKey ? DDMMath.z.STEP : DDMMath.z.JUMP;
8737
8922
  break;
8738
8923
  case 'ArrowDown':
8739
- z -= event.shiftKey ? 0.01 : 0.1;
8924
+ z -= event.shiftKey ? DDMMath.z.STEP : DDMMath.z.JUMP;
8740
8925
  break;
8741
8926
  }
8742
8927
  // Clamp z
8743
- z = z < 0.01 ? 0.01 : z > 0.99 ? 0.99 : z;
8928
+ z = z < DDMMath.z.MIN ? DDMMath.z.MIN : z > DDMMath.z.MAX ? DDMMath.z.MAX : z;
8744
8929
  this.z = z;
8745
8930
  this.alignState();
8746
8931
  this.dispatchEvent(new CustomEvent('ddm-model-z', {
@@ -8755,14 +8940,14 @@
8755
8940
  let t0 = this.t0; /* eslint-disable-line prefer-destructuring */
8756
8941
  switch (event.key) {
8757
8942
  case 'ArrowRight':
8758
- t0 += event.shiftKey ? 1 : 10;
8943
+ t0 += event.shiftKey ? DDMMath.t0.STEP : DDMMath.t0.JUMP;
8759
8944
  break;
8760
8945
  case 'ArrowLeft':
8761
- t0 -= event.shiftKey ? 1 : 10;
8946
+ t0 -= event.shiftKey ? DDMMath.t0.STEP : DDMMath.t0.JUMP;
8762
8947
  break;
8763
8948
  }
8764
8949
  // Clamp t0
8765
- t0 = t0 < 0 ? 0 : t0 > 500 ? 500 : t0;
8950
+ t0 = t0 < DDMMath.t0.MIN ? DDMMath.t0.MIN : t0 > DDMMath.t0.MAX ? DDMMath.t0.MAX : t0;
8766
8951
  this.t0 = t0;
8767
8952
  this.alignState();
8768
8953
  this.dispatchEvent(new CustomEvent('ddm-model-t0', {
@@ -8788,6 +8973,13 @@
8788
8973
  }).attr('y2', datum => {
8789
8974
  return evidenceScale(datum.startingPoint);
8790
8975
  });
8976
+ t0zMerge.select('.line.touch').transition().duration(this.drag ? 0 : transitionDuration).ease(cubicOut).attr('x1', timeScale(0)).attr('x2', datum => {
8977
+ return timeScale(datum.t0);
8978
+ }).attr('y1', datum => {
8979
+ return evidenceScale(datum.startingPoint);
8980
+ }).attr('y2', datum => {
8981
+ return evidenceScale(datum.startingPoint);
8982
+ });
8791
8983
  t0zMerge.select('.point').transition().duration(this.drag ? 0 : transitionDuration).ease(cubicOut).attr('cx', datum => {
8792
8984
  return timeScale(datum.t0);
8793
8985
  }).attr('cy', datum => {
@@ -9094,7 +9286,7 @@
9094
9286
  this.yScale = undefined; // D3 Scale for y-axis
9095
9287
  }
9096
9288
  static get styles() {
9097
- return [super.styles, i$2`
9289
+ return [super.styles, i$3`
9098
9290
  :host {
9099
9291
  display: inline-block;
9100
9292
 
@@ -9275,7 +9467,7 @@
9275
9467
  const queryUpdate = select(this.renderRoot).select('.content').selectAll('.query').data([]);
9276
9468
  queryUpdate.exit().remove();
9277
9469
  }
9278
- run( /* elapsed */
9470
+ run(/* elapsed */
9279
9471
  ) {
9280
9472
  const realTime = now();
9281
9473
  const currentTime = this.baseTime ? realTime - this.baseTime : 0;
@@ -9471,7 +9663,7 @@
9471
9663
  this.numeric = false;
9472
9664
  }
9473
9665
  static get styles() {
9474
- return [super.styles, i$2`
9666
+ return [super.styles, i$3`
9475
9667
  :host {
9476
9668
  display: block;
9477
9669
 
@@ -9670,9 +9862,9 @@
9670
9862
  }
9671
9863
  constructor() {
9672
9864
  super();
9673
- this.a = 1.5;
9674
- this.z = 0.5;
9675
- this.v = 0.1;
9865
+ this.a = DDMMath.a.DEFAULT;
9866
+ this.z = DDMMath.z.DEFAULT;
9867
+ this.v = DDMMath.v.DEFAULT;
9676
9868
  this.alignState();
9677
9869
  }
9678
9870
  alignState() {
@@ -9714,19 +9906,46 @@
9714
9906
  let s;
9715
9907
  let accuracy;
9716
9908
  if (this.numeric) {
9717
- a = x$1`<decidables-spinner class="a bottom" ?disabled=${!this.interactive} min="0.1" max="2" step="0.01" .value="${this.a}" @input=${this.aInput.bind(this)}>
9909
+ a = x$1`<decidables-spinner class="a bottom"
9910
+ ?disabled=${!this.interactive}
9911
+ min=${DDMMath.a.MIN}
9912
+ max=${DDMMath.a.MAX}
9913
+ step=${DDMMath.a.STEP}
9914
+ .value=${this.a}
9915
+ @input=${this.aInput.bind(this)}
9916
+ >
9718
9917
  <var class="math-var">a</var>
9719
9918
  </decidables-spinner>`;
9720
- z = x$1`<decidables-spinner class="z bottom" ?disabled=${!this.interactive} min="0.01" max="0.99" step="0.01" .value="${this.z}" @input=${this.zInput.bind(this)}>
9919
+ z = x$1`<decidables-spinner class="z bottom"
9920
+ ?disabled=${!this.interactive}
9921
+ min=${DDMMath.z.MIN}
9922
+ max=${DDMMath.z.MAX}
9923
+ step=${DDMMath.z.STEP}
9924
+ .value=${this.z}
9925
+ @input=${this.zInput.bind(this)}
9926
+ >
9721
9927
  <var class="math-var">z</var>
9722
9928
  </decidables-spinner>`;
9723
- v = x$1`<decidables-spinner class="v bottom" ?disabled=${!this.interactive} min="0.01" max="5" step="0.01" .value="${this.v}" @input=${this.vInput.bind(this)}>
9929
+ v = x$1`<decidables-spinner class="v bottom"
9930
+ ?disabled=${!this.interactive}
9931
+ min=${DDMMath.v.MIN}
9932
+ max=${DDMMath.v.MAX}
9933
+ step=${DDMMath.v.STEP}
9934
+ .value=${this.v}
9935
+ @input=${this.vInput.bind(this)}
9936
+ >
9724
9937
  <var class="math-var">v</var>
9725
9938
  </decidables-spinner>`;
9726
- s = x$1`<decidables-spinner class="s bottom" disabled min="0.01" max="1" step="0.01" .value="${DDMMath.s}">
9939
+ s = x$1`<decidables-spinner class="s bottom"
9940
+ disabled
9941
+ .value=${DDMMath.s.DEFAULT}
9942
+ >
9727
9943
  <var class="math-var">s</var>
9728
9944
  </decidables-spinner>`;
9729
- accuracy = x$1`<decidables-spinner class="accuracy bottom" disabled min="0" max="1" step="0.01" .value="${+this.accuracy.toFixed(2)}">
9945
+ accuracy = x$1`<decidables-spinner class="accuracy bottom"
9946
+ disabled
9947
+ .value=${+this.accuracy.toFixed(2)}
9948
+ >
9730
9949
  <var>Accuracy</var>
9731
9950
  </decidables-spinner>`;
9732
9951
  } else {
@@ -9804,10 +10023,10 @@
9804
10023
  }
9805
10024
  constructor() {
9806
10025
  super();
9807
- this.a = 1.5;
9808
- this.z = 0.5;
9809
- this.v = 0.1;
9810
- this.t0 = 200;
10026
+ this.a = DDMMath.a.DEFAULT;
10027
+ this.z = DDMMath.z.DEFAULT;
10028
+ this.v = DDMMath.v.DEFAULT;
10029
+ this.t0 = DDMMath.t0.DEFAULT;
9811
10030
  this.alignState();
9812
10031
  }
9813
10032
  alignState() {
@@ -9856,22 +10075,56 @@
9856
10075
  let s;
9857
10076
  let meanRT;
9858
10077
  if (this.numeric) {
9859
- a = x$1`<decidables-spinner class="a bottom" ?disabled=${!this.interactive} min="0.1" max="2" step="0.01" .value="${this.a}" @input=${this.aInput.bind(this)}>
10078
+ a = x$1`<decidables-spinner class="a bottom"
10079
+ ?disabled=${!this.interactive}
10080
+ min=${DDMMath.a.MIN}
10081
+ max=${DDMMath.a.MAX}
10082
+ step=${DDMMath.a.STEP}
10083
+ .value=${this.a}
10084
+ @input=${this.aInput.bind(this)}
10085
+ >
9860
10086
  <var class="math-var">a</var>
9861
10087
  </decidables-spinner>`;
9862
- z = x$1`<decidables-spinner class="z bottom" ?disabled=${!this.interactive} min="0.01" max="0.99" step="0.01" .value="${this.z}" @input=${this.zInput.bind(this)}>
10088
+ z = x$1`<decidables-spinner class="z bottom"
10089
+ ?disabled=${!this.interactive}
10090
+ min=${DDMMath.z.MIN}
10091
+ max=${DDMMath.z.MAX}
10092
+ step=${DDMMath.z.STEP}
10093
+ .value=${this.z}
10094
+ @input=${this.zInput.bind(this)}
10095
+ >
9863
10096
  <var class="math-var">z</var>
9864
10097
  </decidables-spinner>`;
9865
- v = x$1`<decidables-spinner class="v bottom" ?disabled=${!this.interactive} min="0.01" max="5" step="0.01" .value="${this.v}" @input=${this.vInput.bind(this)}>
10098
+ v = x$1`<decidables-spinner class="v bottom"
10099
+ ?disabled=${!this.interactive}
10100
+ min=${DDMMath.v.MIN}
10101
+ max=${DDMMath.v.MAX}
10102
+ step=${DDMMath.v.STEP}
10103
+ .value=${this.v}
10104
+ @input=${this.vInput.bind(this)}
10105
+ >
9866
10106
  <var class="math-var">v</var>
9867
10107
  </decidables-spinner>`;
9868
- t0 = x$1`<decidables-spinner class="t0 bottom" ?disabled=${!this.interactive} min="0" max="500" step="1" .value="${this.t0}" @input=${this.t0Input.bind(this)}>
10108
+ t0 = x$1`<decidables-spinner class="t0 bottom"
10109
+ ?disabled=${!this.interactive}
10110
+ min=${DDMMath.t0.MIN}
10111
+ max=${DDMMath.t0.MAX}
10112
+ step=${DDMMath.t0.STEP}
10113
+ .value=${this.t0}
10114
+ @input=${this.t0Input.bind(this)}
10115
+ >
9869
10116
  <var class="math-var">t<sub>0</sub></var>
9870
10117
  </decidables-spinner>`;
9871
- s = x$1`<decidables-spinner class="s bottom" disabled min="0.01" max="1" step="0.01" .value="${DDMMath.s}">
10118
+ s = x$1`<decidables-spinner class="s bottom"
10119
+ disabled
10120
+ .value=${DDMMath.s.DEFAULT}
10121
+ >
9872
10122
  <var class="math-var">s</var>
9873
10123
  </decidables-spinner>`;
9874
- meanRT = x$1`<decidables-spinner class="mean-rt bottom" disabled min="0" max="1" step="0.01" .value="${+this.meanRT.toFixed(0)}">
10124
+ meanRT = x$1`<decidables-spinner class="mean-rt bottom"
10125
+ disabled
10126
+ .value=${+this.meanRT.toFixed(0)}
10127
+ >
9875
10128
  <var>Mean RT</var>
9876
10129
  </decidables-spinner>`;
9877
10130
  } else {
@@ -9935,7 +10188,7 @@
9935
10188
  */
9936
10189
  class DDMExample extends AccumulableElement {
9937
10190
  static get styles() {
9938
- return [super.styles, i$2`
10191
+ return [super.styles, i$3`
9939
10192
  :host {
9940
10193
  ---border: var(--border, 1px solid var(---color-border));
9941
10194
  display: inline-block;
@@ -9994,17 +10247,74 @@
9994
10247
  }
9995
10248
  customElements.define('ddm-example', DDMExample);
9996
10249
 
9997
- // import DDMMath from '@decidables/accumulable-math';
9998
-
9999
-
10000
10250
  /*
10001
10251
  DDMExampleHuman element
10002
10252
  <ddm-example-human>
10003
10253
  */
10004
10254
  class DDMExampleHuman extends DDMExample {
10255
+ static get properties() {
10256
+ return {
10257
+ trials: {
10258
+ attribute: 'trials',
10259
+ type: Number,
10260
+ reflect: true
10261
+ },
10262
+ duration: {
10263
+ attribute: 'duration',
10264
+ type: Number,
10265
+ reflect: true
10266
+ },
10267
+ coherence: {
10268
+ attribute: 'coherence',
10269
+ type: Number,
10270
+ reflect: true
10271
+ },
10272
+ color: {
10273
+ attribute: 'color',
10274
+ type: String,
10275
+ reflect: true
10276
+ },
10277
+ a: {
10278
+ attribute: false,
10279
+ type: Number,
10280
+ reflect: false
10281
+ },
10282
+ z: {
10283
+ attribute: false,
10284
+ type: Number,
10285
+ reflect: false
10286
+ },
10287
+ v: {
10288
+ attribute: false,
10289
+ type: Number,
10290
+ reflect: false
10291
+ },
10292
+ t0: {
10293
+ attribute: false,
10294
+ type: Number,
10295
+ reflect: false
10296
+ }
10297
+ };
10298
+ }
10005
10299
  constructor() {
10006
10300
  super();
10007
- this.trialCount = 0;
10301
+ this.trials = 10;
10302
+ this.duration = 2000;
10303
+ this.coherence = 0.5;
10304
+ this.colors = ['none', 'measure', 'outcome', 'all'];
10305
+ this.color = 'outcome';
10306
+ this.a = DDMMath.a.DEFAULT;
10307
+ this.z = DDMMath.z.DEFAULT;
10308
+ this.v = DDMMath.v.DEFAULT;
10309
+ this.t0 = DDMMath.t0.DEFAULT;
10310
+ this.accumulableControl = null;
10311
+ this.rdkTask = null;
10312
+ this.accumulableResponse = null;
10313
+ this.accumulableTable = null;
10314
+ this.ddmParameters = null;
10315
+ this.ddmModel = null;
10316
+ this.ddmFit = null;
10317
+ this.data = undefined;
10008
10318
  }
10009
10319
  connectedCallback() {
10010
10320
  super.connectedCallback();
@@ -10018,57 +10328,32 @@
10018
10328
 
10019
10329
  // Initialize
10020
10330
  this.ddmModel.clear();
10021
- if (this.accumulableControl && this.accumulableControl.hasAttribute('trials')) {
10331
+ if (this.accumulableControl) {
10022
10332
  this.accumulableControl.addEventListener('accumulable-control-trials', event => {
10023
- if (this.rdkTask) {
10024
- this.rdkTask.trials = event.detail.trials;
10025
- }
10026
- if (this.accumulableResponse) {
10027
- this.accumulableResponse.trialTotal = event.detail.trials;
10028
- }
10333
+ this.trials = event.detail.trials;
10029
10334
  });
10030
- }
10031
- if (this.accumulableControl && this.accumulableControl.hasAttribute('duration')) {
10032
10335
  this.accumulableControl.addEventListener('accumulable-control-duration', event => {
10033
- if (this.rdkTask) {
10034
- this.rdkTask.duration = event.detail.duration;
10035
- this.rdkTask.wait = event.detail.duration;
10036
- this.rdkTask.iti = event.detail.duration;
10037
- }
10336
+ this.duration = event.detail.duration;
10038
10337
  });
10039
- }
10040
- if (this.accumulableControl && this.accumulableControl.hasAttribute('coherence')) {
10041
10338
  this.accumulableControl.addEventListener('accumulable-control-coherence', event => {
10042
- if (this.rdkTask) {
10043
- this.rdkTask.coherence = event.detail.coherence;
10044
- }
10339
+ this.coherence = event.detail.coherence;
10045
10340
  });
10046
- }
10047
- if (this.accumulableControl && this.accumulableControl.hasAttribute('color')) {
10048
10341
  this.accumulableControl.addEventListener('accumulable-control-color', event => {
10049
- if (this.accumulableTable) {
10050
- this.accumulableTable.color = event.detail.color;
10051
- }
10342
+ this.color = event.detail.color;
10052
10343
  });
10053
- }
10054
- if (this.accumulableControl && this.accumulableControl.hasAttribute('run')) {
10055
- this.accumulableControl.addEventListener('accumulable-control-run', ( /* event */
10344
+ this.accumulableControl.addEventListener('accumulable-control-run', (/* event */
10056
10345
  ) => {
10057
10346
  if (this.rdkTask) {
10058
10347
  this.rdkTask.running = true;
10059
10348
  }
10060
10349
  });
10061
- }
10062
- if (this.accumulableControl && this.accumulableControl.hasAttribute('pause')) {
10063
- this.accumulableControl.addEventListener('accumulable-control-pause', ( /* event */
10350
+ this.accumulableControl.addEventListener('accumulable-control-pause', (/* event */
10064
10351
  ) => {
10065
10352
  if (this.rdkTask) {
10066
10353
  this.rdkTask.running = false;
10067
10354
  }
10068
10355
  });
10069
- }
10070
- if (this.accumulableControl && this.accumulableControl.hasAttribute('reset')) {
10071
- this.accumulableControl.addEventListener('accumulable-control-reset', ( /* event */
10356
+ this.accumulableControl.addEventListener('accumulable-control-reset', (/* event */
10072
10357
  ) => {
10073
10358
  if (this.rdkTask) {
10074
10359
  this.rdkTask.reset();
@@ -10100,11 +10385,6 @@
10100
10385
  }
10101
10386
  });
10102
10387
  }
10103
- if (this.rdkTask) {
10104
- if (this.accumulableResponse) {
10105
- this.accumulableResponse.trialTotal = this.rdkTask.trials;
10106
- }
10107
- }
10108
10388
  if (this.rdkTask) {
10109
10389
  this.rdkTask.addEventListener('rdk-trial-start', event => {
10110
10390
  if (this.accumulableResponse) {
@@ -10113,7 +10393,7 @@
10113
10393
  });
10114
10394
  }
10115
10395
  if (this.rdkTask) {
10116
- this.rdkTask.addEventListener('rdk-trial-end', ( /* event */
10396
+ this.rdkTask.addEventListener('rdk-trial-end', (/* event */
10117
10397
  ) => {
10118
10398
  if (this.accumulableResponse) {
10119
10399
  this.accumulableResponse.stop();
@@ -10121,7 +10401,7 @@
10121
10401
  });
10122
10402
  }
10123
10403
  if (this.rdkTask) {
10124
- this.rdkTask.addEventListener('rdk-block-end', ( /* event */
10404
+ this.rdkTask.addEventListener('rdk-block-end', (/* event */
10125
10405
  ) => {
10126
10406
  if (this.accumulableControl) {
10127
10407
  this.accumulableControl.complete();
@@ -10130,18 +10410,7 @@
10130
10410
  }
10131
10411
  if (this.accumulableResponse) {
10132
10412
  this.accumulableResponse.addEventListener('accumulable-response', event => {
10133
- if (this.accumulableTable) {
10134
- this.accumulableTable.correctCount = event.detail.correctCount;
10135
- this.accumulableTable.errorCount = event.detail.errorCount;
10136
- this.accumulableTable.nrCount = event.detail.nrCount;
10137
- this.accumulableTable.accuracy = event.detail.accuracy;
10138
- this.accumulableTable.correctMeanRT = event.detail.correctMeanRT;
10139
- this.accumulableTable.errorMeanRT = event.detail.errorMeanRT;
10140
- this.accumulableTable.meanRT = event.detail.meanRT;
10141
- this.accumulableTable.correctSDRT = event.detail.correctSDRT;
10142
- this.accumulableTable.errorSDRT = event.detail.errorSDRT;
10143
- this.accumulableTable.sdRT = event.detail.sdRT;
10144
- }
10413
+ this.data = event.detail.data;
10145
10414
  if (this.ddmModel) {
10146
10415
  this.ddmModel.trial({
10147
10416
  index: event.detail.trial,
@@ -10151,34 +10420,73 @@
10151
10420
  }
10152
10421
  if (this.ddmFit) {
10153
10422
  this.ddmFit.set({
10154
- accuracy: event.detail.accuracy,
10155
- correctMeanRT: event.detail.correctMeanRT,
10156
- errorMeanRT: event.detail.errorMeanRT,
10157
- meanRT: event.detail.meanRT,
10158
- correctSDRT: event.detail.correctSDRT,
10159
- errorSDRT: event.detail.errorSDRT,
10160
- sdRT: event.detail.sdRT
10423
+ accuracy: event.detail.data.accuracy,
10424
+ correctMeanRT: event.detail.data.correctMeanRT,
10425
+ errorMeanRT: event.detail.data.errorMeanRT,
10426
+ meanRT: event.detail.data.meanRT,
10427
+ correctSDRT: event.detail.data.correctSDRT,
10428
+ errorSDRT: event.detail.data.errorSDRT,
10429
+ sdRT: event.detail.data.sdRT
10161
10430
  });
10162
10431
  }
10432
+ this.requestUpdate();
10163
10433
  });
10164
10434
  }
10165
10435
  if (this.ddmFit) {
10166
10436
  this.ddmFit.addEventListener('ddm-fit-update', event => {
10167
- if (this.ddmParameters) {
10168
- this.ddmParameters.a = event.detail.a;
10169
- this.ddmParameters.z = 0.5; // event.detail.z;
10170
- this.ddmParameters.v = event.detail.v;
10171
- this.ddmParameters.t0 = event.detail.t0;
10172
- }
10173
- if (this.ddmModel) {
10174
- this.ddmModel.a = event.detail.a;
10175
- this.ddmModel.z = 0.5; // event.detail.z;
10176
- this.ddmModel.v = event.detail.v;
10177
- this.ddmModel.t0 = event.detail.t0;
10178
- }
10437
+ this.a = event.detail.a;
10438
+ this.z = 0.5; // event.detail.z;
10439
+ this.v = event.detail.v;
10440
+ this.t0 = event.detail.t0;
10179
10441
  });
10180
10442
  }
10181
10443
  }
10444
+ update(changedProperties) {
10445
+ super.update(changedProperties);
10446
+ if (this.accumulableControl) {
10447
+ this.accumulableControl.trials = this.accumulableControl.trials != null ? this.trials : undefined;
10448
+ this.accumulableControl.duration = this.accumulableControl.duration != null ? this.duration : undefined;
10449
+ this.accumulableControl.coherence = this.accumulableControl.coherence != null ? this.coherence : undefined;
10450
+ this.accumulableControl.color = this.accumulableControl.color != null ? this.color : undefined;
10451
+ }
10452
+ if (this.rdkTask) {
10453
+ this.rdkTask.trials = this.trials;
10454
+ this.rdkTask.duration = this.duration;
10455
+ this.rdkTask.wait = this.duration;
10456
+ this.rdkTask.iti = this.duration;
10457
+ this.rdkTask.coherence = this.coherence;
10458
+ }
10459
+ if (this.ddmParameters) {
10460
+ this.ddmParameters.a = this.ddmParameters.a != null ? this.a : undefined;
10461
+ this.ddmParameters.z = this.ddmParameters.z != null ? this.z : undefined;
10462
+ this.ddmParameters.v = this.ddmParameters.a != null ? this.v : undefined;
10463
+ this.ddmParameters.t0 = this.ddmParameters.t0 != null ? this.t0 : undefined;
10464
+ }
10465
+ if (this.ddmModel) {
10466
+ this.ddmModel.a = +this.a;
10467
+ this.ddmModel.z = +this.z;
10468
+ this.ddmModel.v = +this.v;
10469
+ this.ddmModel.t0 = +this.t0;
10470
+ }
10471
+ if (this.accumulableResponse) {
10472
+ this.accumulableResponse.trialTotal = this.trials;
10473
+ }
10474
+ if (this.accumulableTable) {
10475
+ this.accumulableTable.color = this.color;
10476
+ }
10477
+ if (this.accumulableTable && this.data) {
10478
+ this.accumulableTable.correctCount = this.data.correctCount;
10479
+ this.accumulableTable.errorCount = this.data.errorCount;
10480
+ this.accumulableTable.nrCount = this.data.nrCount;
10481
+ this.accumulableTable.accuracy = this.data.accuracy;
10482
+ this.accumulableTable.correctMeanRT = this.data.correctMeanRT;
10483
+ this.accumulableTable.errorMeanRT = this.data.errorMeanRT;
10484
+ this.accumulableTable.meanRT = this.data.meanRT;
10485
+ this.accumulableTable.correctSDRT = this.data.correctSDRT;
10486
+ this.accumulableTable.errorSDRT = this.data.errorSDRT;
10487
+ this.accumulableTable.sdRT = this.data.sdRT;
10488
+ }
10489
+ }
10182
10490
  }
10183
10491
  customElements.define('ddm-example-human', DDMExampleHuman);
10184
10492
 
@@ -10194,6 +10502,11 @@
10194
10502
  type: Number,
10195
10503
  reflect: true
10196
10504
  },
10505
+ color: {
10506
+ attribute: 'color',
10507
+ type: String,
10508
+ reflect: true
10509
+ },
10197
10510
  a: {
10198
10511
  attribute: 'boundary-separation',
10199
10512
  type: Number,
@@ -10219,10 +10532,12 @@
10219
10532
  constructor() {
10220
10533
  super();
10221
10534
  this.trials = 10;
10222
- this.a = 1.2;
10223
- this.z = 0.35;
10224
- this.v = 1.5;
10225
- this.t0 = 150;
10535
+ this.colors = ['none', 'measure', 'outcome', 'all'];
10536
+ this.color = 'outcome';
10537
+ this.a = DDMMath.a.DEFAULT;
10538
+ this.z = DDMMath.z.DEFAULT;
10539
+ this.v = DDMMath.v.DEFAULT;
10540
+ this.t0 = DDMMath.t0.DEFAULT;
10226
10541
  this.accumulableControl = null;
10227
10542
  this.accumulableTable = null;
10228
10543
  this.ddmParameters = null;
@@ -10237,7 +10552,7 @@
10237
10552
  this.ddmParameters = this.querySelector('ddm-parameters');
10238
10553
  this.ddmModel = this.querySelector('ddm-model');
10239
10554
  if (this.accumulableControl) {
10240
- this.accumulableControl.addEventListener('accumulable-control-resample', ( /* event */
10555
+ this.accumulableControl.addEventListener('accumulable-control-resample', (/* event */
10241
10556
  ) => {
10242
10557
  this.ddmModel?.resample();
10243
10558
  this.requestUpdate();
@@ -10245,6 +10560,9 @@
10245
10560
  this.accumulableControl.addEventListener('accumulable-control-trials', event => {
10246
10561
  this.trials = event.detail.trials;
10247
10562
  });
10563
+ this.accumulableControl.addEventListener('accumulable-control-color', event => {
10564
+ this.color = event.detail.color;
10565
+ });
10248
10566
  }
10249
10567
  if (this.ddmParameters) {
10250
10568
  this.ddmParameters.addEventListener('ddm-parameters-a', event => {
@@ -10284,7 +10602,11 @@
10284
10602
  update(changedProperties) {
10285
10603
  super.update(changedProperties);
10286
10604
  if (this.accumulableControl) {
10287
- this.accumulableControl.trials = this.trials;
10605
+ this.accumulableControl.trials = this.accumulableControl.trials != null ? this.trials : undefined;
10606
+ this.accumulableControl.color = this.accumulableControl.color != null ? this.color : undefined;
10607
+ }
10608
+ if (this.accumulableTable) {
10609
+ this.accumulableTable.color = this.color;
10288
10610
  }
10289
10611
  if (this.accumulableTable && this.data) {
10290
10612
  this.accumulableTable.correctCount = this.data.correctCount;
@@ -10299,10 +10621,10 @@
10299
10621
  this.accumulableTable.sdRT = this.data.sdRT;
10300
10622
  }
10301
10623
  if (this.ddmParameters) {
10302
- this.ddmParameters.a = this.a;
10303
- this.ddmParameters.z = this.z;
10304
- this.ddmParameters.v = this.v;
10305
- this.ddmParameters.t0 = this.t0;
10624
+ this.ddmParameters.a = this.ddmParameters.a != null ? this.a : undefined;
10625
+ this.ddmParameters.z = this.ddmParameters.z != null ? this.z : undefined;
10626
+ this.ddmParameters.v = this.ddmParameters.a != null ? this.v : undefined;
10627
+ this.ddmParameters.t0 = this.ddmParameters.t0 != null ? this.t0 : undefined;
10306
10628
  }
10307
10629
  if (this.ddmModel) {
10308
10630
  this.ddmModel.trials = this.trials;
@@ -10315,9 +10637,6 @@
10315
10637
  }
10316
10638
  customElements.define('ddm-example-interactive', DDMExampleInteractive);
10317
10639
 
10318
- // import DDMMath from '@decidables/accumulable-math';
10319
-
10320
-
10321
10640
  /*
10322
10641
  DDMExampleModel element
10323
10642
  <ddm-example-model>
@@ -10374,10 +10693,10 @@
10374
10693
  this.coherence = 0.5;
10375
10694
  this.colors = ['none', 'measure', 'outcome', 'all'];
10376
10695
  this.color = 'outcome';
10377
- this.a = 1.2;
10378
- this.z = 0.35;
10379
- this.v = 1.5;
10380
- this.t0 = 150;
10696
+ this.a = DDMMath.a.DEFAULT;
10697
+ this.z = DDMMath.z.DEFAULT;
10698
+ this.v = DDMMath.v.DEFAULT;
10699
+ this.t0 = DDMMath.t0.DEFAULT;
10381
10700
  this.accumulableControl = null;
10382
10701
  this.rdkTask = null;
10383
10702
  this.ddmParameters = null;
@@ -10399,60 +10718,48 @@
10399
10718
  this.accumulableResponse = this.querySelector('accumulable-response');
10400
10719
  this.accumulableTable = this.querySelector('accumulable-table');
10401
10720
  if (this.accumulableControl) {
10402
- if (this.accumulableControl.hasAttribute('trials')) {
10403
- this.accumulableControl.addEventListener('accumulable-control-trials', event => {
10404
- this.trials = event.detail.trials;
10405
- });
10406
- }
10407
- if (this.accumulableControl.hasAttribute('duration')) {
10408
- this.accumulableControl.addEventListener('accumulable-control-duration', event => {
10409
- this.duration = event.detail.duration;
10410
- });
10411
- }
10412
- if (this.accumulableControl.hasAttribute('color')) {
10413
- this.accumulableControl.addEventListener('accumulable-control-color', event => {
10414
- this.color = event.detail.color;
10415
- });
10416
- }
10417
- if (this.accumulableControl.hasAttribute('run')) {
10418
- this.accumulableControl.addEventListener('accumulable-control-run', ( /* event */
10419
- ) => {
10420
- if (this.rdkTask) {
10421
- this.rdkTask.running = true;
10422
- }
10423
- if (this.ddmModel) {
10424
- this.ddmModel.resumeTrial();
10425
- }
10426
- });
10427
- }
10428
- if (this.accumulableControl.hasAttribute('pause')) {
10429
- this.accumulableControl.addEventListener('accumulable-control-pause', ( /* event */
10430
- ) => {
10431
- if (this.rdkTask) {
10432
- this.rdkTask.running = false;
10433
- }
10434
- if (this.ddmModel) {
10435
- this.ddmModel.pauseTrial();
10436
- }
10437
- });
10438
- }
10439
- if (this.accumulableControl.hasAttribute('reset')) {
10440
- this.accumulableControl.addEventListener('accumulable-control-reset', ( /* event */
10441
- ) => {
10442
- this.trialCount = 0;
10443
- this.signal = undefined;
10444
- if (this.rdkTask) {
10445
- this.rdkTask.reset();
10446
- }
10447
- if (this.ddmModel) {
10448
- this.ddmModel.trials = this.trialCount;
10449
- }
10450
- if (this.accumulableResponse) {
10451
- this.accumulableResponse.reset();
10452
- }
10453
- if (this.accumulableTable) ;
10454
- });
10455
- }
10721
+ this.accumulableControl.addEventListener('accumulable-control-trials', event => {
10722
+ this.trials = event.detail.trials;
10723
+ });
10724
+ this.accumulableControl.addEventListener('accumulable-control-duration', event => {
10725
+ this.duration = event.detail.duration;
10726
+ });
10727
+ this.accumulableControl.addEventListener('accumulable-control-color', event => {
10728
+ this.color = event.detail.color;
10729
+ });
10730
+ this.accumulableControl.addEventListener('accumulable-control-run', (/* event */
10731
+ ) => {
10732
+ if (this.rdkTask) {
10733
+ this.rdkTask.running = true;
10734
+ }
10735
+ if (this.ddmModel) {
10736
+ this.ddmModel.resumeTrial();
10737
+ }
10738
+ });
10739
+ this.accumulableControl.addEventListener('accumulable-control-pause', (/* event */
10740
+ ) => {
10741
+ if (this.rdkTask) {
10742
+ this.rdkTask.running = false;
10743
+ }
10744
+ if (this.ddmModel) {
10745
+ this.ddmModel.pauseTrial();
10746
+ }
10747
+ });
10748
+ this.accumulableControl.addEventListener('accumulable-control-reset', (/* event */
10749
+ ) => {
10750
+ this.trialCount = 0;
10751
+ this.signal = undefined;
10752
+ if (this.rdkTask) {
10753
+ this.rdkTask.reset();
10754
+ }
10755
+ if (this.ddmModel) {
10756
+ this.ddmModel.trials = this.trialCount;
10757
+ }
10758
+ if (this.accumulableResponse) {
10759
+ this.accumulableResponse.reset();
10760
+ }
10761
+ if (this.accumulableTable) ;
10762
+ });
10456
10763
  }
10457
10764
  if (this.rdkTask) {
10458
10765
  this.rdkTask.addEventListener('rdk-trial-start', event => {
@@ -10465,14 +10772,14 @@
10465
10772
  this.ddmModel.trial();
10466
10773
  }
10467
10774
  });
10468
- this.rdkTask.addEventListener('rdk-trial-end', ( /* event */
10775
+ this.rdkTask.addEventListener('rdk-trial-end', (/* event */
10469
10776
  ) => {
10470
10777
  this.signal = undefined;
10471
10778
  if (this.accumulableResponse) {
10472
10779
  this.accumulableResponse.stop();
10473
10780
  }
10474
10781
  });
10475
- this.rdkTask.addEventListener('rdk-block-end', ( /* event */
10782
+ this.rdkTask.addEventListener('rdk-block-end', (/* event */
10476
10783
  ) => {
10477
10784
  if (this.accumulableControl) {
10478
10785
  this.accumulableControl.complete();
@@ -10511,17 +10818,15 @@
10511
10818
  this.model = event.detail.model;
10512
10819
  this.requestUpdate();
10513
10820
  });
10514
- if (this.ddmModel) {
10515
- this.ddmModel.addEventListener('accumulable-response', event => {
10516
- if (this.accumulableResponse) {
10517
- const response = event.detail.outcome === 'correct' ? this.signal : this.signal === 'left' ? 'right' : 'left';
10518
- this.accumulableResponse.responded(response);
10519
- }
10520
- this.data = event.detail.data;
10521
- this.model = event.detail.model;
10522
- this.requestUpdate();
10523
- });
10524
- }
10821
+ this.ddmModel.addEventListener('accumulable-response', event => {
10822
+ if (this.accumulableResponse) {
10823
+ const response = event.detail.outcome === 'correct' ? this.signal : this.signal === 'left' ? 'right' : 'left';
10824
+ this.accumulableResponse.responded(response);
10825
+ }
10826
+ this.data = event.detail.data;
10827
+ this.model = event.detail.model;
10828
+ this.requestUpdate();
10829
+ });
10525
10830
  }
10526
10831
  this.requestUpdate();
10527
10832
  }
@@ -10531,10 +10836,10 @@
10531
10836
  this.trialCount = this.trials;
10532
10837
  }
10533
10838
  if (this.accumulableControl) {
10534
- this.accumulableControl.trials = this.trials;
10535
- this.accumulableControl.duration = this.duration;
10536
- this.accumulableControl.coherence = this.coherence;
10537
- this.accumulableControl.color = this.color;
10839
+ this.accumulableControl.trials = this.accumulableControl.trials != null ? this.trials : undefined;
10840
+ this.accumulableControl.duration = this.accumulableControl.duration != null ? this.duration : undefined;
10841
+ this.accumulableControl.coherence = this.accumulableControl.coherence != null ? this.coherence : undefined;
10842
+ this.accumulableControl.color = this.accumulableControl.color != null ? this.color : undefined;
10538
10843
  }
10539
10844
  if (this.rdkTask) {
10540
10845
  this.rdkTask.trials = this.trials;
@@ -10542,10 +10847,10 @@
10542
10847
  this.rdkTask.coherence = this.coherence;
10543
10848
  }
10544
10849
  if (this.ddmParameters) {
10545
- this.ddmParameters.a = this.a;
10546
- this.ddmParameters.z = this.z;
10547
- this.ddmParameters.v = this.v;
10548
- this.ddmParameters.t0 = this.t0;
10850
+ this.ddmParameters.a = this.ddmParameters.a != null ? this.a : undefined;
10851
+ this.ddmParameters.z = this.ddmParameters.z != null ? this.z : undefined;
10852
+ this.ddmParameters.v = this.ddmParameters.a != null ? this.v : undefined;
10853
+ this.ddmParameters.t0 = this.ddmParameters.t0 != null ? this.t0 : undefined;
10549
10854
  }
10550
10855
  if (this.ddmModel) {
10551
10856
  this.ddmModel.trials = this.trialCount;