@pie-element/ebsr 14.2.1 → 14.2.2-next.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/configure.js +2 -0
- package/controller.js +1 -0
- package/dist/author/defaults.d.ts +348 -0
- package/dist/author/defaults.js +161 -0
- package/dist/author/index.d.ts +34 -0
- package/dist/author/index.js +78 -0
- package/dist/author/main.d.ts +22 -0
- package/dist/author/main.js +121 -0
- package/dist/browser/author/index.js +13940 -0
- package/dist/browser/author/index.js.map +1 -0
- package/dist/browser/browser-CdX8WGiZ.js +207 -0
- package/dist/browser/browser-CdX8WGiZ.js.map +1 -0
- package/dist/browser/controller/index.js +257 -0
- package/dist/browser/controller/index.js.map +1 -0
- package/dist/browser/delivery/index.js +133 -0
- package/dist/browser/delivery/index.js.map +1 -0
- package/dist/browser/dist-CaWRqnXk.js +62 -0
- package/dist/browser/dist-CaWRqnXk.js.map +1 -0
- package/dist/browser/dist-D9ARZhQk.js +1426 -0
- package/dist/browser/dist-D9ARZhQk.js.map +1 -0
- package/dist/browser/dist-DQkngCcw.js +36 -0
- package/dist/browser/dist-DQkngCcw.js.map +1 -0
- package/dist/browser/print/index.js +107 -0
- package/dist/browser/print/index.js.map +1 -0
- package/dist/controller/defaults.d.ts +15 -0
- package/dist/controller/defaults.js +26 -0
- package/dist/controller/index.d.ts +42 -0
- package/dist/controller/index.js +185 -0
- package/dist/controller/utils.d.ts +10 -0
- package/dist/controller/utils.js +8 -0
- package/dist/delivery/index.d.ts +26 -0
- package/dist/delivery/index.js +132 -0
- package/dist/index.d.ts +1 -0
- package/dist/index.iife.d.ts +8 -0
- package/dist/index.iife.js +165 -0
- package/dist/index.js +2 -0
- package/dist/print/index.d.ts +25 -0
- package/dist/print/index.js +106 -0
- package/dist/runtime-support.d.ts +12 -0
- package/dist/runtime-support.js +12 -0
- package/package.json +88 -19
- package/CHANGELOG.json +0 -1547
- package/CHANGELOG.md +0 -2285
- package/LICENSE.md +0 -5
- package/README.md +0 -62
- package/configure/CHANGELOG.json +0 -992
- package/configure/CHANGELOG.md +0 -2148
- package/configure/lib/defaults.js +0 -229
- package/configure/lib/defaults.js.map +0 -1
- package/configure/lib/index.js +0 -154
- package/configure/lib/index.js.map +0 -1
- package/configure/lib/main.js +0 -222
- package/configure/lib/main.js.map +0 -1
- package/configure/package.json +0 -23
- package/configure/src/__tests__/index.test.js +0 -492
- package/configure/src/defaults.js +0 -173
- package/configure/src/index.js +0 -174
- package/configure/src/main.jsx +0 -235
- package/controller/CHANGELOG.json +0 -552
- package/controller/CHANGELOG.md +0 -1286
- package/controller/lib/defaults.js +0 -31
- package/controller/lib/defaults.js.map +0 -1
- package/controller/lib/index.js +0 -448
- package/controller/lib/index.js.map +0 -1
- package/controller/lib/utils.js +0 -18
- package/controller/lib/utils.js.map +0 -1
- package/controller/package.json +0 -18
- package/controller/src/__tests__/index.test.js +0 -591
- package/controller/src/__tests__/utils.test.js +0 -48
- package/controller/src/defaults.js +0 -25
- package/controller/src/index.js +0 -442
- package/controller/src/utils.js +0 -18
- package/docs/config-schema.json +0 -5787
- package/docs/config-schema.json.md +0 -4278
- package/docs/demo/config.js +0 -8
- package/docs/demo/generate.js +0 -52
- package/docs/demo/index.html +0 -2
- package/docs/demo/session.js +0 -14
- package/docs/pie-schema.json +0 -2911
- package/docs/pie-schema.json.md +0 -2142
- package/ebsr.png +0 -0
- package/lib/index.js +0 -207
- package/lib/index.js.map +0 -1
- package/lib/print.js +0 -186
- package/lib/print.js.map +0 -1
- package/module/configure.js +0 -1
- package/module/controller.js +0 -5664
- package/module/demo.js +0 -77
- package/module/element.js +0 -1
- package/module/index.html +0 -21
- package/module/manifest.json +0 -14
- package/module/print-demo.js +0 -115
- package/module/print.html +0 -18
- package/module/print.js +0 -1
- package/src/__tests__/index.test.js +0 -129
- package/src/index.js +0 -222
- package/src/print.js +0 -207
|
@@ -0,0 +1,121 @@
|
|
|
1
|
+
import e from "react";
|
|
2
|
+
import t from "prop-types";
|
|
3
|
+
import { layout as n, settings as r } from "@pie-lib/config-ui";
|
|
4
|
+
import { styled as i } from "@mui/material/styles";
|
|
5
|
+
import { jsx as a, jsxs as o } from "react/jsx-runtime";
|
|
6
|
+
//#region src/author/main.tsx
|
|
7
|
+
var { Panel: s, toggle: c, radio: l, dropdown: u } = r, d = i("div")(({ theme: e }) => ({ paddingBottom: e.spacing(2) })), f = i("div")(({ theme: e }) => ({
|
|
8
|
+
flex: 1,
|
|
9
|
+
height: e.spacing(2.5)
|
|
10
|
+
})), p = class extends e.Component {
|
|
11
|
+
static propTypes = {
|
|
12
|
+
configuration: t.object,
|
|
13
|
+
model: t.object,
|
|
14
|
+
onModelChanged: t.func,
|
|
15
|
+
onConfigurationChanged: t.func
|
|
16
|
+
};
|
|
17
|
+
removeExtraChoices = (e) => {
|
|
18
|
+
let t = !1;
|
|
19
|
+
return (e || []).map((e) => t ? (e.correct = !1, e) : (e.correct && (t = !0), e));
|
|
20
|
+
};
|
|
21
|
+
onModelChanged = (e, t) => {
|
|
22
|
+
let { onModelChanged: n } = this.props;
|
|
23
|
+
return t === "partA.choiceMode" && e.partA.choiceMode === "radio" ? (e.partA.choices = this.removeExtraChoices(e.partA.choices), n(e, !0)) : t === "partB.choiceMode" && e.partB.choiceMode === "radio" ? (e.partB.choices = this.removeExtraChoices(e.partB.choices), n(e, !0)) : n(e);
|
|
24
|
+
};
|
|
25
|
+
render() {
|
|
26
|
+
let { model: e, configuration: t, onConfigurationChanged: r } = this.props, { partLabelType: i, partA: p, partB: m, extraCSSRules: h } = e, { contentDimensions: g = {}, partA: _ = {}, partB: v = {}, partialScoring: y = {}, settingsPanelDisabled: b, scoringType: x = {}, language: S = {}, languageChoices: C = {}, ...w } = t, { feedback: T = {}, choiceMode: E = {}, choicePrefix: D = {}, lockChoiceOrder: O = {}, prompt: k = {}, teacherInstructions: A = {}, studentInstructions: j = {}, choicesLayout: M = {}, gridColumns: N = {}, rationale: P = {}, spellCheck: F = {} } = _ || {}, { feedback: I = {}, choiceMode: L = {}, choicePrefix: R = {}, lockChoiceOrder: z = {}, prompt: B = {}, teacherInstructions: V = {}, studentInstructions: H = {}, choicesLayout: U = {}, gridColumns: W = {}, rationale: G = {}, spellCheck: K = {} } = v || {}, q = (i || "Numbers") === "Numbers", J = `Part ${q ? "1" : "A"}`, Y = `Part ${q ? "2" : "B"}`, X = {
|
|
27
|
+
partA: p.choices && p.choices.length ? Array.from({ length: p.choices.length }, (e, t) => `${t + 1}`) : [],
|
|
28
|
+
partB: m.choices && m.choices.length ? Array.from({ length: m.choices.length }, (e, t) => `${t + 1}`) : []
|
|
29
|
+
}, Z = {
|
|
30
|
+
partLabels: w.partLabels.settings && c(w.partLabels.label),
|
|
31
|
+
partLabelType: e.partLabels && u("", ["Numbers", "Letters"]),
|
|
32
|
+
partialScoring: y.settings && c(y.label),
|
|
33
|
+
scoringType: x.settings && l(x.label, ["auto", "rubric"]),
|
|
34
|
+
"language.enabled": S.settings && c(S.label, !0),
|
|
35
|
+
language: S.settings && S.enabled && u(C.label, C.options)
|
|
36
|
+
}, Q = {
|
|
37
|
+
"partA.choiceMode": E.settings && l(E.label, ["checkbox", "radio"]),
|
|
38
|
+
"partA.choicePrefix": D.settings && l(D.label, ["numbers", "letters"]),
|
|
39
|
+
"partA.lockChoiceOrder": O.settings && c(O.label),
|
|
40
|
+
"partA.choicesLayout": M.settings && u(M.label, [
|
|
41
|
+
"vertical",
|
|
42
|
+
"grid",
|
|
43
|
+
"horizontal"
|
|
44
|
+
]),
|
|
45
|
+
"partA.gridColumns": M.settings && p.choicesLayout === "grid" && X.partA.length > 0 && u(N.label, X.partA)
|
|
46
|
+
}, $ = {
|
|
47
|
+
"partA.feedbackEnabled": T.settings && c(T.label),
|
|
48
|
+
"partA.promptEnabled": k.settings && c(k.label),
|
|
49
|
+
"partA.teacherInstructionsEnabled": A.settings && c(A.label),
|
|
50
|
+
"partA.studentInstructionsEnabled": j.settings && c(j.label),
|
|
51
|
+
"partA.rationaleEnabled": P.settings && c(P.label),
|
|
52
|
+
"partA.spellCheckEnabled": F.settings && c(F.label)
|
|
53
|
+
}, ee = {
|
|
54
|
+
"partB.choiceMode": L.settings && l(L.label, ["checkbox", "radio"]),
|
|
55
|
+
"partB.choicePrefix": R.settings && l(R.label, ["numbers", "letters"]),
|
|
56
|
+
"partB.lockChoiceOrder": z.settings && c(z.label),
|
|
57
|
+
"partB.choicesLayout": U.settings && u(U.label, [
|
|
58
|
+
"vertical",
|
|
59
|
+
"grid",
|
|
60
|
+
"horizontal"
|
|
61
|
+
]),
|
|
62
|
+
"partB.gridColumns": U.settings && m.choicesLayout === "grid" && X.partB.length > 0 && u(W.label, X.partB)
|
|
63
|
+
}, te = {
|
|
64
|
+
"partB.feedbackEnabled": I.settings && c(I.label),
|
|
65
|
+
"partB.promptEnabled": B.settings && c(B.label),
|
|
66
|
+
"partB.teacherInstructionsEnabled": V.settings && c(V.label),
|
|
67
|
+
"partB.studentInstructionsEnabled": H.settings && c(H.label),
|
|
68
|
+
"partB.rationaleEnabled": G.settings && c(G.label),
|
|
69
|
+
"partB.spellCheckEnabled": K.settings && c(K.label)
|
|
70
|
+
};
|
|
71
|
+
return /* @__PURE__ */ o(n.ConfigLayout, {
|
|
72
|
+
extraCSSRules: h,
|
|
73
|
+
dimensions: g,
|
|
74
|
+
hideSettings: b,
|
|
75
|
+
settings: /* @__PURE__ */ a(s, {
|
|
76
|
+
model: e,
|
|
77
|
+
onChangeModel: this.onModelChanged,
|
|
78
|
+
configuration: t,
|
|
79
|
+
onChangeConfiguration: r,
|
|
80
|
+
groups: {
|
|
81
|
+
"Settings for both": Z,
|
|
82
|
+
[`Settings ${J}`]: Q,
|
|
83
|
+
[`Properties ${J}`]: $,
|
|
84
|
+
[`Settings ${Y}`]: ee,
|
|
85
|
+
[`Properties ${Y}`]: te
|
|
86
|
+
}
|
|
87
|
+
}),
|
|
88
|
+
children: [
|
|
89
|
+
e.partLabels && /* @__PURE__ */ a(d, { children: J }),
|
|
90
|
+
/* @__PURE__ */ a("ebsr-multiple-choice-configure", {
|
|
91
|
+
id: "A",
|
|
92
|
+
ref: (e) => {
|
|
93
|
+
e && (this.partA = e, this.partA._model = {
|
|
94
|
+
...this.props.model.partA,
|
|
95
|
+
errors: this.props.model.errors && this.props.model.errors.partA || {}
|
|
96
|
+
}, this.partA.configuration = {
|
|
97
|
+
..._,
|
|
98
|
+
...w
|
|
99
|
+
});
|
|
100
|
+
}
|
|
101
|
+
}, "partA"),
|
|
102
|
+
/* @__PURE__ */ a(f, {}),
|
|
103
|
+
e.partLabels && /* @__PURE__ */ a(d, { children: Y }),
|
|
104
|
+
/* @__PURE__ */ a("ebsr-multiple-choice-configure", {
|
|
105
|
+
id: "B",
|
|
106
|
+
ref: (e) => {
|
|
107
|
+
e && (this.partB = e, this.partB._model = {
|
|
108
|
+
...this.props.model.partB,
|
|
109
|
+
errors: this.props.model.errors && this.props.model.errors.partB || {}
|
|
110
|
+
}, this.partB.configuration = {
|
|
111
|
+
...v,
|
|
112
|
+
...w
|
|
113
|
+
});
|
|
114
|
+
}
|
|
115
|
+
}, "partB")
|
|
116
|
+
]
|
|
117
|
+
});
|
|
118
|
+
}
|
|
119
|
+
};
|
|
120
|
+
//#endregion
|
|
121
|
+
export { p as default };
|