@pie-element/multiple-choice 11.2.0-mui-update.2 → 11.2.0-mui-update.4
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/lib/__tests__/root.test.js +248 -0
- package/configure/lib/defaults.js +1 -1
- package/configure/lib/index.js +62 -23
- package/configure/lib/index.js.map +1 -1
- package/configure/lib/main.js +1 -1
- package/configure/lib/utils.js +1 -1
- package/configure/package.json +3 -3
- package/controller/lib/__tests__/index.test.js +520 -0
- package/controller/lib/__tests__/utils.test.js +8 -0
- package/controller/lib/defaults.js +1 -1
- package/controller/lib/index.js +1 -1
- package/controller/lib/utils.js +1 -1
- package/controller/package.json +1 -1
- package/docs/demo/pie.manifest.json +11 -0
- package/lib/__tests__/choice-input-test.js +117 -0
- package/lib/__tests__/index-test.js +151 -0
- package/lib/__tests__/key-events-test.js +95 -0
- package/lib/__tests__/multiple-choice-test.js +223 -0
- package/lib/__tests__/session-updater-test.js +70 -0
- package/lib/choice-input.js +1 -1
- package/lib/choice.js +1 -1
- package/lib/feedback-tick.js +1 -1
- package/lib/index.js +1 -1
- package/lib/main.js +1 -1
- package/lib/multiple-choice.js +1 -1
- package/lib/print.js +1 -1
- package/lib/session-updater.js +1 -1
- package/package.json +7 -6
|
@@ -0,0 +1,248 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
+
var _enzyme = require("enzyme");
|
|
5
|
+
var _react = _interopRequireDefault(require("react"));
|
|
6
|
+
var _main = require("../main");
|
|
7
|
+
var _defaults = _interopRequireDefault(require("../defaults"));
|
|
8
|
+
var _configUi = require("@pie-lib/config-ui");
|
|
9
|
+
var _index = _interopRequireDefault(require("../index"));
|
|
10
|
+
jest.mock('@pie-lib/config-ui', () => ({
|
|
11
|
+
choiceUtils: {
|
|
12
|
+
firstAvailableIndex: jest.fn(),
|
|
13
|
+
normalizeChoices: jest.fn(model => model)
|
|
14
|
+
},
|
|
15
|
+
settings: {
|
|
16
|
+
Panel: props => /*#__PURE__*/_react.default.createElement("div", props),
|
|
17
|
+
toggle: jest.fn(),
|
|
18
|
+
radio: jest.fn()
|
|
19
|
+
}
|
|
20
|
+
}));
|
|
21
|
+
const model = extras => ({
|
|
22
|
+
..._defaults.default.model,
|
|
23
|
+
prompt: 'Which of these northern European countries are EU members?',
|
|
24
|
+
choiceMode: 'checkbox',
|
|
25
|
+
choices: [{
|
|
26
|
+
correct: true,
|
|
27
|
+
value: 'sweden',
|
|
28
|
+
label: 'Sweden',
|
|
29
|
+
feedback: {
|
|
30
|
+
type: 'none',
|
|
31
|
+
value: ''
|
|
32
|
+
}
|
|
33
|
+
}, {
|
|
34
|
+
value: 'iceland',
|
|
35
|
+
label: 'Iceland',
|
|
36
|
+
feedback: {
|
|
37
|
+
type: 'none',
|
|
38
|
+
value: ''
|
|
39
|
+
}
|
|
40
|
+
}, {
|
|
41
|
+
value: 'norway',
|
|
42
|
+
label: 'Norway',
|
|
43
|
+
feedback: {
|
|
44
|
+
type: 'none',
|
|
45
|
+
value: ''
|
|
46
|
+
}
|
|
47
|
+
}, {
|
|
48
|
+
correct: true,
|
|
49
|
+
value: 'finland',
|
|
50
|
+
label: 'Finland',
|
|
51
|
+
feedback: {
|
|
52
|
+
type: 'none',
|
|
53
|
+
value: ''
|
|
54
|
+
}
|
|
55
|
+
}],
|
|
56
|
+
partialScoring: false,
|
|
57
|
+
configure: {},
|
|
58
|
+
...extras
|
|
59
|
+
});
|
|
60
|
+
describe('Main', () => {
|
|
61
|
+
let w;
|
|
62
|
+
let onModelChanged = jest.fn();
|
|
63
|
+
let onConfigurationChanged = jest.fn();
|
|
64
|
+
let initialModel = model();
|
|
65
|
+
const wrapper = extras => {
|
|
66
|
+
const defaults = {
|
|
67
|
+
onModelChanged,
|
|
68
|
+
onConfigurationChanged,
|
|
69
|
+
classes: {},
|
|
70
|
+
model: model()
|
|
71
|
+
};
|
|
72
|
+
const props = {
|
|
73
|
+
...defaults,
|
|
74
|
+
...extras
|
|
75
|
+
};
|
|
76
|
+
return (0, _enzyme.shallow)(/*#__PURE__*/_react.default.createElement(_main.Main, props));
|
|
77
|
+
};
|
|
78
|
+
describe('snapshot', () => {
|
|
79
|
+
it('renders with choicePrefix="numbers"', () => {
|
|
80
|
+
w = wrapper({
|
|
81
|
+
model: model({
|
|
82
|
+
choicePrefix: 'numbers'
|
|
83
|
+
})
|
|
84
|
+
});
|
|
85
|
+
expect(w).toMatchSnapshot();
|
|
86
|
+
});
|
|
87
|
+
it('renders with choicePrefix="letters" as default', () => {
|
|
88
|
+
w = wrapper();
|
|
89
|
+
expect(w).toMatchSnapshot();
|
|
90
|
+
});
|
|
91
|
+
});
|
|
92
|
+
describe('logic', () => {
|
|
93
|
+
beforeEach(() => {
|
|
94
|
+
w = wrapper();
|
|
95
|
+
});
|
|
96
|
+
describe('onRemoveChoice', () => {
|
|
97
|
+
it('removes choice', () => {
|
|
98
|
+
w.instance().onRemoveChoice(0);
|
|
99
|
+
expect(onModelChanged).toBeCalledWith({
|
|
100
|
+
...initialModel,
|
|
101
|
+
choices: initialModel.choices.slice(1)
|
|
102
|
+
});
|
|
103
|
+
});
|
|
104
|
+
});
|
|
105
|
+
describe('createDefaultModel', () => {
|
|
106
|
+
it('sets choicesLayout: horizontal if verticalMode: false', () => {
|
|
107
|
+
const m = _index.default.createDefaultModel(model({
|
|
108
|
+
verticalMode: false,
|
|
109
|
+
choicesLayout: undefined
|
|
110
|
+
}));
|
|
111
|
+
expect(m.choicesLayout).toEqual('horizontal');
|
|
112
|
+
});
|
|
113
|
+
it('sets choicesLayout: vertical if verticalMode: true', () => {
|
|
114
|
+
const m = _index.default.createDefaultModel(model({
|
|
115
|
+
verticalMode: true,
|
|
116
|
+
choicesLayout: undefined
|
|
117
|
+
}));
|
|
118
|
+
expect(m.choicesLayout).toEqual('vertical');
|
|
119
|
+
});
|
|
120
|
+
it('sets choicesLayout: grid if verticalMode: true && choicesLayout: grid', () => {
|
|
121
|
+
const m = _index.default.createDefaultModel(model({
|
|
122
|
+
verticalMode: true,
|
|
123
|
+
choicesLayout: 'grid'
|
|
124
|
+
}));
|
|
125
|
+
expect(m.choicesLayout).toEqual('grid');
|
|
126
|
+
});
|
|
127
|
+
it('sets choicesLayout: vertical', () => {
|
|
128
|
+
const m = _index.default.createDefaultModel(model());
|
|
129
|
+
expect(m.choicesLayout).toEqual('vertical');
|
|
130
|
+
});
|
|
131
|
+
});
|
|
132
|
+
describe('onAddChoice', () => {
|
|
133
|
+
it('adds a choice', () => {
|
|
134
|
+
w.instance().onAddChoice();
|
|
135
|
+
expect(onModelChanged).toBeCalledWith({
|
|
136
|
+
...initialModel,
|
|
137
|
+
choices: [...initialModel.choices, {
|
|
138
|
+
label: '',
|
|
139
|
+
value: _configUi.choiceUtils.firstAvailableIndex(initialModel.choices.map(c => c.value), 0),
|
|
140
|
+
feedback: {
|
|
141
|
+
type: 'none'
|
|
142
|
+
}
|
|
143
|
+
}]
|
|
144
|
+
});
|
|
145
|
+
});
|
|
146
|
+
});
|
|
147
|
+
describe('onChoiceChanged', () => {
|
|
148
|
+
describe('checkbox', () => {
|
|
149
|
+
it('changes choice (there are 2 true values)', () => {
|
|
150
|
+
const newChoices = [...model().choices];
|
|
151
|
+
let choice = {
|
|
152
|
+
correct: true,
|
|
153
|
+
value: 'iceland',
|
|
154
|
+
label: 'Iceland',
|
|
155
|
+
feedback: {
|
|
156
|
+
type: 'none',
|
|
157
|
+
value: ''
|
|
158
|
+
}
|
|
159
|
+
};
|
|
160
|
+
w.instance().onChoiceChanged(1, choice);
|
|
161
|
+
newChoices[1].correct = true;
|
|
162
|
+
expect(onModelChanged).toBeCalledWith({
|
|
163
|
+
...initialModel,
|
|
164
|
+
choices: newChoices
|
|
165
|
+
});
|
|
166
|
+
});
|
|
167
|
+
});
|
|
168
|
+
describe('radio', () => {
|
|
169
|
+
it('changes choice (there is only one true value)', () => {
|
|
170
|
+
let choice = {
|
|
171
|
+
correct: true,
|
|
172
|
+
value: 'iceland',
|
|
173
|
+
label: 'Iceland',
|
|
174
|
+
feedback: {
|
|
175
|
+
type: 'none',
|
|
176
|
+
value: ''
|
|
177
|
+
}
|
|
178
|
+
};
|
|
179
|
+
const newModel = {
|
|
180
|
+
...initialModel,
|
|
181
|
+
choiceMode: 'radio',
|
|
182
|
+
choices: initialModel.choices.slice(0, 2)
|
|
183
|
+
};
|
|
184
|
+
w = wrapper({
|
|
185
|
+
model: newModel
|
|
186
|
+
});
|
|
187
|
+
w.instance().onChoiceChanged(1, choice);
|
|
188
|
+
expect(onModelChanged).toBeCalledWith({
|
|
189
|
+
...newModel,
|
|
190
|
+
choices: [{
|
|
191
|
+
correct: false,
|
|
192
|
+
value: 'sweden',
|
|
193
|
+
label: 'Sweden',
|
|
194
|
+
feedback: {
|
|
195
|
+
type: 'none',
|
|
196
|
+
value: ''
|
|
197
|
+
}
|
|
198
|
+
}, {
|
|
199
|
+
correct: true,
|
|
200
|
+
value: 'iceland',
|
|
201
|
+
label: 'Iceland',
|
|
202
|
+
feedback: {
|
|
203
|
+
type: 'none',
|
|
204
|
+
value: ''
|
|
205
|
+
}
|
|
206
|
+
}]
|
|
207
|
+
});
|
|
208
|
+
});
|
|
209
|
+
});
|
|
210
|
+
});
|
|
211
|
+
describe('onPromptChanged', () => {
|
|
212
|
+
it('changes prompt', () => {
|
|
213
|
+
w.instance().onPromptChanged('New Prompt');
|
|
214
|
+
expect(onModelChanged).toBeCalledWith({
|
|
215
|
+
...initialModel,
|
|
216
|
+
prompt: 'New Prompt'
|
|
217
|
+
});
|
|
218
|
+
});
|
|
219
|
+
});
|
|
220
|
+
describe('onTeacherInstructionsChanged', () => {
|
|
221
|
+
it('changes teacher instructions', () => {
|
|
222
|
+
w.instance().onTeacherInstructionsChanged('New Teacher Instructions');
|
|
223
|
+
expect(onModelChanged).toBeCalledWith({
|
|
224
|
+
...initialModel,
|
|
225
|
+
teacherInstructions: 'New Teacher Instructions'
|
|
226
|
+
});
|
|
227
|
+
});
|
|
228
|
+
});
|
|
229
|
+
describe('onModelChanged', () => {
|
|
230
|
+
it('changes choice and makes incorrect all other choices', () => {
|
|
231
|
+
w.instance().onModelChanged({
|
|
232
|
+
...initialModel,
|
|
233
|
+
choiceMode: 'radio'
|
|
234
|
+
}, 'choiceMode');
|
|
235
|
+
const expectedChoices = model().choices;
|
|
236
|
+
expectedChoices.forEach((eC, index) => {
|
|
237
|
+
eC.correct = index === 0;
|
|
238
|
+
});
|
|
239
|
+
expect(onModelChanged).toBeCalledWith({
|
|
240
|
+
...initialModel,
|
|
241
|
+
choiceMode: 'radio',
|
|
242
|
+
choices: expectedChoices
|
|
243
|
+
}, true);
|
|
244
|
+
});
|
|
245
|
+
});
|
|
246
|
+
});
|
|
247
|
+
});
|
|
248
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_enzyme","require","_react","_interopRequireDefault","_main","_defaults","_configUi","_index","jest","mock","choiceUtils","firstAvailableIndex","fn","normalizeChoices","model","settings","Panel","props","default","createElement","toggle","radio","extras","defaults","prompt","choiceMode","choices","correct","value","label","feedback","type","partialScoring","configure","describe","w","onModelChanged","onConfigurationChanged","initialModel","wrapper","classes","shallow","Main","it","choicePrefix","expect","toMatchSnapshot","beforeEach","instance","onRemoveChoice","toBeCalledWith","slice","m","MultipleChoice","createDefaultModel","verticalMode","choicesLayout","undefined","toEqual","onAddChoice","utils","map","c","newChoices","choice","onChoiceChanged","newModel","onPromptChanged","onTeacherInstructionsChanged","teacherInstructions","expectedChoices","forEach","eC","index"],"sources":["../../src/__tests__/root.test.jsx"],"sourcesContent":["import { shallow } from 'enzyme';\nimport React from 'react';\n\nimport { Main } from '../main';\nimport defaults from '../defaults';\nimport { choiceUtils as utils } from '@pie-lib/config-ui';\nimport MultipleChoice from '../index';\n\njest.mock('@pie-lib/config-ui', () => ({\n  choiceUtils: {\n    firstAvailableIndex: jest.fn(),\n    normalizeChoices: jest.fn((model) => model),\n  },\n  settings: {\n    Panel: (props) => <div {...props} />,\n    toggle: jest.fn(),\n    radio: jest.fn(),\n  },\n}));\n\nconst model = (extras) => ({\n  ...defaults.model,\n  prompt: 'Which of these northern European countries are EU members?',\n  choiceMode: 'checkbox',\n  choices: [\n    {\n      correct: true,\n      value: 'sweden',\n      label: 'Sweden',\n      feedback: {\n        type: 'none',\n        value: '',\n      },\n    },\n    {\n      value: 'iceland',\n      label: 'Iceland',\n      feedback: {\n        type: 'none',\n        value: '',\n      },\n    },\n    {\n      value: 'norway',\n      label: 'Norway',\n      feedback: {\n        type: 'none',\n        value: '',\n      },\n    },\n    {\n      correct: true,\n      value: 'finland',\n      label: 'Finland',\n      feedback: {\n        type: 'none',\n        value: '',\n      },\n    },\n  ],\n  partialScoring: false,\n  configure: {},\n  ...extras,\n});\n\ndescribe('Main', () => {\n  let w;\n  let onModelChanged = jest.fn();\n  let onConfigurationChanged = jest.fn();\n  let initialModel = model();\n\n  const wrapper = (extras) => {\n    const defaults = {\n      onModelChanged,\n      onConfigurationChanged,\n      classes: {},\n      model: model(),\n    };\n    const props = { ...defaults, ...extras };\n\n    return shallow(<Main {...props} />);\n  };\n\n  describe('snapshot', () => {\n    it('renders with choicePrefix=\"numbers\"', () => {\n      w = wrapper({ model: model({ choicePrefix: 'numbers' }) });\n      expect(w).toMatchSnapshot();\n    });\n\n    it('renders with choicePrefix=\"letters\" as default', () => {\n      w = wrapper();\n      expect(w).toMatchSnapshot();\n    });\n  });\n\n  describe('logic', () => {\n    beforeEach(() => {\n      w = wrapper();\n    });\n    describe('onRemoveChoice', () => {\n      it('removes choice', () => {\n        w.instance().onRemoveChoice(0);\n\n        expect(onModelChanged).toBeCalledWith({\n          ...initialModel,\n          choices: initialModel.choices.slice(1),\n        });\n      });\n    });\n\n    describe('createDefaultModel', () => {\n      it('sets choicesLayout: horizontal if verticalMode: false', () => {\n        const m = MultipleChoice.createDefaultModel(model({ verticalMode: false, choicesLayout: undefined }));\n\n        expect(m.choicesLayout).toEqual('horizontal');\n      });\n\n      it('sets choicesLayout: vertical if verticalMode: true', () => {\n        const m = MultipleChoice.createDefaultModel(model({ verticalMode: true, choicesLayout: undefined }));\n\n        expect(m.choicesLayout).toEqual('vertical');\n      });\n\n      it('sets choicesLayout: grid if verticalMode: true && choicesLayout: grid', () => {\n        const m = MultipleChoice.createDefaultModel(model({ verticalMode: true, choicesLayout: 'grid' }));\n\n        expect(m.choicesLayout).toEqual('grid');\n      });\n\n      it('sets choicesLayout: vertical', () => {\n        const m = MultipleChoice.createDefaultModel(model());\n\n        expect(m.choicesLayout).toEqual('vertical');\n      });\n    });\n\n    describe('onAddChoice', () => {\n      it('adds a choice', () => {\n        w.instance().onAddChoice();\n\n        expect(onModelChanged).toBeCalledWith({\n          ...initialModel,\n          choices: [\n            ...initialModel.choices,\n            {\n              label: '',\n              value: utils.firstAvailableIndex(\n                initialModel.choices.map((c) => c.value),\n                0,\n              ),\n              feedback: {\n                type: 'none',\n              },\n            },\n          ],\n        });\n      });\n    });\n\n    describe('onChoiceChanged', () => {\n      describe('checkbox', () => {\n        it('changes choice (there are 2 true values)', () => {\n          const newChoices = [...model().choices];\n          let choice = {\n            correct: true,\n            value: 'iceland',\n            label: 'Iceland',\n            feedback: {\n              type: 'none',\n              value: '',\n            },\n          };\n\n          w.instance().onChoiceChanged(1, choice);\n\n          newChoices[1].correct = true;\n\n          expect(onModelChanged).toBeCalledWith({\n            ...initialModel,\n            choices: newChoices,\n          });\n        });\n      });\n\n      describe('radio', () => {\n        it('changes choice (there is only one true value)', () => {\n          let choice = {\n            correct: true,\n            value: 'iceland',\n            label: 'Iceland',\n            feedback: {\n              type: 'none',\n              value: '',\n            },\n          };\n\n          const newModel = { ...initialModel, choiceMode: 'radio', choices: initialModel.choices.slice(0, 2) };\n          w = wrapper({ model: newModel });\n\n          w.instance().onChoiceChanged(1, choice);\n\n          expect(onModelChanged).toBeCalledWith({\n            ...newModel,\n            choices: [\n              {\n                correct: false,\n                value: 'sweden',\n                label: 'Sweden',\n                feedback: {\n                  type: 'none',\n                  value: '',\n                },\n              },\n              {\n                correct: true,\n                value: 'iceland',\n                label: 'Iceland',\n                feedback: {\n                  type: 'none',\n                  value: '',\n                },\n              },\n            ],\n          });\n        });\n      });\n    });\n\n    describe('onPromptChanged', () => {\n      it('changes prompt', () => {\n        w.instance().onPromptChanged('New Prompt');\n\n        expect(onModelChanged).toBeCalledWith({\n          ...initialModel,\n          prompt: 'New Prompt',\n        });\n      });\n    });\n\n    describe('onTeacherInstructionsChanged', () => {\n      it('changes teacher instructions', () => {\n        w.instance().onTeacherInstructionsChanged('New Teacher Instructions');\n\n        expect(onModelChanged).toBeCalledWith({\n          ...initialModel,\n          teacherInstructions: 'New Teacher Instructions',\n        });\n      });\n    });\n\n    describe('onModelChanged', () => {\n      it('changes choice and makes incorrect all other choices', () => {\n        w.instance().onModelChanged(\n          {\n            ...initialModel,\n            choiceMode: 'radio',\n          },\n          'choiceMode',\n        );\n\n        const expectedChoices = model().choices;\n\n        expectedChoices.forEach((eC, index) => {\n          eC.correct = index === 0;\n        });\n\n        expect(onModelChanged).toBeCalledWith(\n          {\n            ...initialModel,\n            choiceMode: 'radio',\n            choices: expectedChoices,\n          },\n          true,\n        );\n      });\n    });\n  });\n});\n"],"mappings":"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","ignoreList":[]}
|
|
@@ -197,4 +197,4 @@ var _default = exports.default = {
|
|
|
197
197
|
}
|
|
198
198
|
}
|
|
199
199
|
};
|
|
200
|
-
//# sourceMappingURL=defaults.js.map
|
|
200
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_default","exports","default","model","choiceMode","choicePrefix","choices","choicesLayout","feedbackEnabled","gridColumns","lockChoiceOrder","partialScoring","prompt","promptEnabled","rationale","rationaleEnabled","scoringType","studentInstructionsEnabled","teacherInstructions","teacherInstructionsEnabled","toolbarEditorPosition","selectedAnswerBackgroundColor","keyboardEventsEnabled","configuration","baseInputConfiguration","audio","disabled","video","image","textAlign","showParagraphs","separateParagraphs","inputConfiguration","spellCheck","label","settings","enabled","answerChoiceCount","addChoiceButton","deleteChoice","feedback","required","studentInstructions","minAnswerChoices","maxAnswerChoices","maxImageWidth","maxImageHeight","withRubric","mathMlOptions","mmlOutput","mmlEditing","language","languageChoices","options"],"sources":["../src/defaults.js"],"sourcesContent":["/** NOTE: teacherInstructions, studentInstructions, rationale & scoringType\n * functionalities are not defined yet - the value for those can belong to\n * model or to configure\n */\nexport default {\n  model: {\n    choiceMode: 'checkbox',\n    choicePrefix: 'letters',\n    choices: [],\n    choicesLayout: 'vertical',\n    feedbackEnabled: false,\n    gridColumns: 2,\n    lockChoiceOrder: true,\n    partialScoring: true,\n    prompt: '',\n    promptEnabled: true,\n    rationale: '',\n    rationaleEnabled: true,\n    scoringType: 'auto',\n    studentInstructionsEnabled: true,\n    teacherInstructions: '',\n    teacherInstructionsEnabled: true,\n    toolbarEditorPosition: 'bottom',\n    selectedAnswerBackgroundColor: 'initial',\n    keyboardEventsEnabled: false,\n  },\n  configuration: {\n    baseInputConfiguration: {\n      audio: { disabled: false },\n      video: { disabled: false },\n      image: { disabled: false },\n      textAlign: { disabled: true },\n      showParagraphs: { disabled: false },\n      separateParagraphs: { disabled: true },\n    },\n    choices: {\n      inputConfiguration: {\n        audio: { disabled: false },\n        video: { disabled: false },\n        image: { disabled: false },\n      },\n    },\n    spellCheck: {\n      label: 'Spellcheck',\n      settings: false,\n      enabled: true,\n    },\n    choicesLayout: {\n      settings: false,\n      label: 'Choices Layout',\n    },\n    gridColumns: {\n      label: 'Grid columns',\n    },\n    answerChoiceCount: 0,\n    addChoiceButton: {\n      settings: true,\n      label: 'Add a Choice',\n    },\n    choiceMode: {\n      settings: true,\n      label: 'Response Type',\n    },\n    choicePrefix: {\n      settings: true,\n      label: 'Choice Labels',\n    },\n    deleteChoice: {\n      settings: true,\n    },\n    feedback: {\n      settings: true,\n      label: 'Feedback',\n    },\n    prompt: {\n      settings: true,\n      label: 'Prompt',\n      inputConfiguration: {\n        audio: { disabled: false },\n        video: { disabled: false },\n        image: { disabled: false },\n      },\n      required: false,\n    },\n    lockChoiceOrder: {\n      settings: true,\n      label: 'Lock Choice Order',\n    },\n    partialScoring: {\n      settings: false,\n      label: 'Allow Partial Scoring',\n    },\n    rationale: {\n      settings: true,\n      label: 'Rationale',\n      inputConfiguration: {\n        audio: { disabled: true },\n        video: { disabled: true },\n        image: { disabled: false },\n      },\n      required: false,\n    },\n    scoringType: {\n      settings: false,\n      label: 'Scoring Type',\n    },\n    studentInstructions: {\n      settings: false,\n      label: 'Student Instructions',\n    },\n    teacherInstructions: {\n      settings: true,\n      label: 'Teacher Instructions',\n      inputConfiguration: {\n        audio: { disabled: false },\n        video: { disabled: false },\n        image: { disabled: false },\n      },\n      required: false,\n    },\n    toolbarEditorPosition: {\n      settings: false,\n      label: 'Toolbar Editor Position',\n    },\n    minAnswerChoices: 2,\n    maxAnswerChoices: 5,\n    maxImageWidth: {\n      teacherInstructions: 300,\n      prompt: 300,\n      rationale: 636,\n      choices: 900,\n    },\n    maxImageHeight: {\n      teacherInstructions: 300,\n      prompt: 300,\n      rationale: 300,\n      choices: 300,\n    },\n    withRubric: {\n      settings: false,\n      label: 'Add Rubric',\n    },\n    mathMlOptions: {\n      mmlOutput: false,\n      mmlEditing: false,\n    },\n    language: {\n      settings: false,\n      label: 'Specify Language',\n      enabled: false,\n    },\n    languageChoices: {\n      label: 'Language Choices',\n      options: [],\n    },\n  },\n};\n"],"mappings":"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","ignoreList":[]}
|
package/configure/lib/index.js
CHANGED
|
@@ -8,14 +8,12 @@ exports.default = void 0;
|
|
|
8
8
|
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
|
|
9
9
|
var _react = _interopRequireDefault(require("react"));
|
|
10
10
|
var _client = require("react-dom/client");
|
|
11
|
-
var _styles = require("@mui/material/styles");
|
|
12
11
|
var _debug = _interopRequireDefault(require("debug"));
|
|
13
12
|
var _pieConfigureEvents = require("@pie-framework/pie-configure-events");
|
|
14
13
|
var _main = _interopRequireDefault(require("./main"));
|
|
15
14
|
var _configUi = require("@pie-lib/config-ui");
|
|
16
15
|
var _defaults = _interopRequireDefault(require("lodash/defaults"));
|
|
17
16
|
var _defaults2 = _interopRequireDefault(require("./defaults"));
|
|
18
|
-
const theme = (0, _styles.createTheme)();
|
|
19
17
|
const log = (0, _debug.default)('multiple-choice:configure');
|
|
20
18
|
const generateFormattedChoices = (choices, choiceCount = 0) => {
|
|
21
19
|
if (!choices || choices.length === 0) {
|
|
@@ -48,6 +46,7 @@ class MultipleChoice extends HTMLElement {
|
|
|
48
46
|
constructor() {
|
|
49
47
|
super();
|
|
50
48
|
this._root = null;
|
|
49
|
+
this._reactContainer = null;
|
|
51
50
|
this._model = MultipleChoice.createDefaultModel();
|
|
52
51
|
this._configuration = _defaults2.default.configuration;
|
|
53
52
|
this.onModelChanged = this.onModelChanged.bind(this);
|
|
@@ -128,32 +127,72 @@ class MultipleChoice extends HTMLElement {
|
|
|
128
127
|
this.dispatchEvent(new _pieConfigureEvents.DeleteSoundEvent(src, done));
|
|
129
128
|
}
|
|
130
129
|
_render() {
|
|
131
|
-
log('_render');
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
|
|
130
|
+
console.log('🔧 [multiple-choice-configure] _render - Starting render');
|
|
131
|
+
console.log('🔧 [multiple-choice-configure] _render - Model:', this._model ? 'present' : 'missing');
|
|
132
|
+
console.log('🔧 [multiple-choice-configure] _render - Configuration:', this._configuration ? 'present' : 'missing');
|
|
133
|
+
console.log('🔧 [multiple-choice-configure] _render - Root exists:', !!this._root);
|
|
134
|
+
log('_render - Starting render');
|
|
135
|
+
log('_render - Model:', this._model ? 'present' : 'missing');
|
|
136
|
+
log('_render - Configuration:', this._configuration ? 'present' : 'missing');
|
|
137
|
+
log('_render - Root exists:', !!this._root);
|
|
138
|
+
try {
|
|
139
|
+
let element = /*#__PURE__*/_react.default.createElement(_main.default, {
|
|
140
|
+
model: this._model,
|
|
141
|
+
configuration: this._configuration,
|
|
142
|
+
onModelChanged: this.onModelChanged,
|
|
143
|
+
onConfigurationChanged: this.onConfigurationChanged,
|
|
144
|
+
disableSidePanel: this._disableSidePanel,
|
|
145
|
+
imageSupport: {
|
|
146
|
+
add: this.insertImage.bind(this),
|
|
147
|
+
delete: this.onDeleteImage.bind(this)
|
|
148
|
+
},
|
|
149
|
+
uploadSoundSupport: {
|
|
150
|
+
add: this.insertSound.bind(this),
|
|
151
|
+
delete: this.onDeleteSound.bind(this)
|
|
152
|
+
}
|
|
153
|
+
});
|
|
154
|
+
if (!this._root) {
|
|
155
|
+
console.log('🔧 [multiple-choice-configure] _render - Creating React container');
|
|
156
|
+
log('_render - Creating React container');
|
|
157
|
+
|
|
158
|
+
// Create a container div for React to render into
|
|
159
|
+
this._reactContainer = document.createElement('div');
|
|
160
|
+
this._reactContainer.className = 'pie-configure-wrapper';
|
|
161
|
+
this.appendChild(this._reactContainer);
|
|
162
|
+
console.log('🔧 [multiple-choice-configure] _render - Creating new React root');
|
|
163
|
+
log('_render - Creating new React root');
|
|
164
|
+
this._root = (0, _client.createRoot)(this._reactContainer);
|
|
165
|
+
console.log('✅ [multiple-choice-configure] _render - React root created successfully');
|
|
166
|
+
log('_render - React root created successfully');
|
|
147
167
|
}
|
|
148
|
-
|
|
149
|
-
|
|
150
|
-
this._root
|
|
168
|
+
console.log('🔧 [multiple-choice-configure] _render - Calling root.render()');
|
|
169
|
+
log('_render - Calling root.render()');
|
|
170
|
+
this._root.render(element);
|
|
171
|
+
console.log('✅ [multiple-choice-configure] _render - Render completed successfully');
|
|
172
|
+
log('_render - Render completed successfully');
|
|
173
|
+
} catch (error) {
|
|
174
|
+
console.error('❌ [multiple-choice-configure] Render error:', error);
|
|
175
|
+
console.error('Error stack:', error.stack);
|
|
176
|
+
throw error;
|
|
151
177
|
}
|
|
152
|
-
|
|
178
|
+
}
|
|
179
|
+
connectedCallback() {
|
|
180
|
+
console.log('🔧 [multiple-choice-configure] connectedCallback - Component connected to DOM');
|
|
181
|
+
log('connectedCallback - Component connected to DOM');
|
|
182
|
+
log('connectedCallback - Model:', this._model ? 'present' : 'missing');
|
|
183
|
+
log('connectedCallback - Configuration:', this._configuration ? 'present' : 'missing');
|
|
153
184
|
}
|
|
154
185
|
disconnectedCallback() {
|
|
186
|
+
console.log('🔧 [multiple-choice-configure] disconnectedCallback - Component disconnected from DOM');
|
|
187
|
+
log('disconnectedCallback - Component disconnected from DOM');
|
|
155
188
|
if (this._root) {
|
|
189
|
+
console.log('🔧 [multiple-choice-configure] disconnectedCallback - Unmounting React root');
|
|
190
|
+
log('disconnectedCallback - Unmounting React root');
|
|
156
191
|
this._root.unmount();
|
|
192
|
+
this._root = null;
|
|
193
|
+
}
|
|
194
|
+
if (this._reactContainer) {
|
|
195
|
+
this._reactContainer = null;
|
|
157
196
|
}
|
|
158
197
|
}
|
|
159
198
|
}
|
|
@@ -169,4 +208,4 @@ exports.default = MultipleChoice;
|
|
|
169
208
|
normalizedModel.choicesLayout = model.choicesLayout || model.verticalMode === false && 'horizontal' || _defaults2.default.model.choicesLayout;
|
|
170
209
|
return normalizedModel;
|
|
171
210
|
});
|
|
172
|
-
//# sourceMappingURL=index.js.map
|
|
211
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireDefault","require","_client","_debug","_pieConfigureEvents","_main","_configUi","_defaults","_defaults2","log","debug","generateFormattedChoices","choices","choiceCount","length","formattedChoices","i","push","value","label","feedback","type","prepareCustomizationObject","config","model","configuration","defaults","sensibleDefaults","answerChoiceCount","MultipleChoice","HTMLElement","constructor","_root","_reactContainer","_model","createDefaultModel","_configuration","onModelChanged","bind","onConfigurationChanged","s","_render","c","info","newConfiguration","language","enabled","languageChoices","options","settings","find","option","disableSidePanel","_disableSidePanel","dispatchModelUpdated","reset","resetValue","dispatchEvent","ModelUpdatedEvent","m","insertImage","handler","InsertImageEvent","onDeleteImage","src","done","DeleteImageEvent","insertSound","InsertSoundEvent","onDeleteSound","DeleteSoundEvent","console","element","React","createElement","Main","imageSupport","add","delete","uploadSoundSupport","document","className","appendChild","createRoot","render","error","stack","connectedCallback","disconnectedCallback","unmount","exports","default","_defineProperty2","normalizedModel","utils","normalizeChoices","choicesLayout","verticalMode"],"sources":["../src/index.js"],"sourcesContent":["import React from 'react';\nimport { createRoot } from 'react-dom/client';\nimport debug from 'debug';\nimport {\n  DeleteImageEvent,\n  InsertImageEvent,\n  ModelUpdatedEvent,\n  InsertSoundEvent,\n  DeleteSoundEvent,\n} from '@pie-framework/pie-configure-events';\n\nimport Main from './main';\nimport { choiceUtils as utils } from '@pie-lib/config-ui';\nimport defaults from 'lodash/defaults';\n\nimport sensibleDefaults from './defaults';\n\nconst log = debug('multiple-choice:configure');\n\nconst generateFormattedChoices = (choices, choiceCount = 0) => {\n  if (!choices || choices.length === 0) {\n    let formattedChoices = [];\n\n    for (let i = 0; i < choiceCount; i++) {\n      formattedChoices.push({\n        value: `${i}`,\n        label: '',\n        feedback: {\n          type: 'none',\n          value: '',\n        },\n      });\n    }\n\n    return formattedChoices;\n  }\n\n  return choices;\n};\n\nconst prepareCustomizationObject = (config, model) => {\n  const configuration = defaults(config, sensibleDefaults.configuration);\n\n  return {\n    configuration,\n    model: {\n      ...model,\n      choices: generateFormattedChoices(\n        (model && model.choices) || [],\n        configuration && configuration.answerChoiceCount,\n      ),\n    },\n  };\n};\n\nexport default class MultipleChoice extends HTMLElement {\n  static createDefaultModel = (model = {}) => {\n    const normalizedModel = utils.normalizeChoices({\n      ...sensibleDefaults.model,\n      ...model,\n      choices: generateFormattedChoices((model && model.choices) || []),\n    });\n\n    // This is used for offering support for old models which have the property \"verticalMode\"\n    normalizedModel.choicesLayout =\n      model.choicesLayout || (model.verticalMode === false && 'horizontal') || sensibleDefaults.model.choicesLayout;\n\n    return normalizedModel;\n  };\n\n  constructor() {\n    super();\n    this._root = null;\n    this._reactContainer = null;\n    this._model = MultipleChoice.createDefaultModel();\n    this._configuration = sensibleDefaults.configuration;\n    this.onModelChanged = this.onModelChanged.bind(this);\n    this.onConfigurationChanged = this.onConfigurationChanged.bind(this);\n  }\n\n  set model(s) {\n    this._model = MultipleChoice.createDefaultModel(s);\n\n    this._render();\n  }\n\n  set configuration(c) {\n    const info = prepareCustomizationObject(c, this._model);\n\n    this.onModelChanged(info.model);\n\n    const newConfiguration = {\n      ...sensibleDefaults.configuration,\n      ...info.configuration,\n    };\n    this._configuration = newConfiguration;\n\n    // if language:enabled is true, then the corresponding default item model should include a language value;\n    // if it is false, then the language field should be omitted from the item model.\n    // if a default item model includes a language value (e.g., en_US) and the corresponding authoring view settings have language:settings = true,\n    // then (a) language:enabled should also be true, and (b) that default language value should be represented in languageChoices[] (as a key).\n    if (newConfiguration?.language?.enabled) {\n      if (newConfiguration?.languageChoices?.options?.length) {\n        this._model.language = newConfiguration?.languageChoices.options[0].value;\n      }\n    } else if (newConfiguration.language.settings && this._model.language) {\n      this._configuration.language.enabled = true;\n\n      if (!this._configuration.languageChoices.options || !this._configuration.languageChoices.options.length) {\n        this._configuration.languageChoices.options = [];\n      }\n\n      // check if the language is already included in the languageChoices.options array\n      // and if not, then add it.\n      if (!this._configuration.languageChoices.options.find((option) => option.value === this._model.language)) {\n        this._configuration.languageChoices.options.push({\n          value: this._model.language,\n          label: this._model.language,\n        });\n      }\n    } else {\n      delete this._model.language;\n    }\n\n    this._render();\n  }\n\n  set disableSidePanel(s) {\n    this._disableSidePanel = s;\n    this._render();\n  }\n\n  dispatchModelUpdated(reset) {\n    const resetValue = !!reset;\n\n    this.dispatchEvent(new ModelUpdatedEvent(this._model, resetValue));\n  }\n\n  onModelChanged(m, reset) {\n    this._model = m;\n    this._render();\n\n    this.dispatchModelUpdated(reset);\n  }\n\n  onConfigurationChanged(c) {\n    this._configuration = prepareCustomizationObject(c, this._model).configuration;\n\n    if (this._model) {\n      this.onModelChanged(this._model);\n    }\n\n    this._render();\n  }\n\n  /** @param {done, progress, file} handler */\n  insertImage(handler) {\n    this.dispatchEvent(new InsertImageEvent(handler));\n  }\n\n  onDeleteImage(src, done) {\n    this.dispatchEvent(new DeleteImageEvent(src, done));\n  }\n\n  insertSound(handler) {\n    this.dispatchEvent(new InsertSoundEvent(handler));\n  }\n\n  onDeleteSound(src, done) {\n    this.dispatchEvent(new DeleteSoundEvent(src, done));\n  }\n\n  _render() {\n    console.log('🔧 [multiple-choice-configure] _render - Starting render');\n    console.log('🔧 [multiple-choice-configure] _render - Model:', this._model ? 'present' : 'missing');\n    console.log('🔧 [multiple-choice-configure] _render - Configuration:', this._configuration ? 'present' : 'missing');\n    console.log('🔧 [multiple-choice-configure] _render - Root exists:', !!this._root);\n    log('_render - Starting render');\n    log('_render - Model:', this._model ? 'present' : 'missing');\n    log('_render - Configuration:', this._configuration ? 'present' : 'missing');\n    log('_render - Root exists:', !!this._root);\n    \n    try {\n      let element = React.createElement(Main, {\n        model: this._model,\n        configuration: this._configuration,\n        onModelChanged: this.onModelChanged,\n        onConfigurationChanged: this.onConfigurationChanged,\n        disableSidePanel: this._disableSidePanel,\n        imageSupport: {\n          add: this.insertImage.bind(this),\n          delete: this.onDeleteImage.bind(this),\n        },\n        uploadSoundSupport: {\n          add: this.insertSound.bind(this),\n          delete: this.onDeleteSound.bind(this),\n        },\n      });\n\n      if (!this._root) {\n        console.log('🔧 [multiple-choice-configure] _render - Creating React container');\n        log('_render - Creating React container');\n        \n        // Create a container div for React to render into\n        this._reactContainer = document.createElement('div');\n        this._reactContainer.className = 'pie-configure-wrapper';\n        this.appendChild(this._reactContainer);\n        \n        console.log('🔧 [multiple-choice-configure] _render - Creating new React root');\n        log('_render - Creating new React root');\n        this._root = createRoot(this._reactContainer);\n        console.log('✅ [multiple-choice-configure] _render - React root created successfully');\n        log('_render - React root created successfully');\n      }\n      \n      console.log('🔧 [multiple-choice-configure] _render - Calling root.render()');\n      log('_render - Calling root.render()');\n      this._root.render(element);\n      console.log('✅ [multiple-choice-configure] _render - Render completed successfully');\n      log('_render - Render completed successfully');\n    } catch (error) {\n      console.error('❌ [multiple-choice-configure] Render error:', error);\n      console.error('Error stack:', error.stack);\n      throw error;\n    }\n  }\n\n  connectedCallback() {\n    console.log('🔧 [multiple-choice-configure] connectedCallback - Component connected to DOM');\n    log('connectedCallback - Component connected to DOM');\n    log('connectedCallback - Model:', this._model ? 'present' : 'missing');\n    log('connectedCallback - Configuration:', this._configuration ? 'present' : 'missing');\n  }\n\n  disconnectedCallback() {\n    console.log('🔧 [multiple-choice-configure] disconnectedCallback - Component disconnected from DOM');\n    log('disconnectedCallback - Component disconnected from DOM');\n    if (this._root) {\n      console.log('🔧 [multiple-choice-configure] disconnectedCallback - Unmounting React root');\n      log('disconnectedCallback - Unmounting React root');\n      this._root.unmount();\n      this._root = null;\n    }\n    if (this._reactContainer) {\n      this._reactContainer = null;\n    }\n  }\n}\n"],"mappings":"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","ignoreList":[]}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","names":["_react","_interopRequireDefault","require","_client","_styles","_debug","_pieConfigureEvents","_main","_configUi","_defaults","_defaults2","theme","createTheme","log","debug","generateFormattedChoices","choices","choiceCount","length","formattedChoices","i","push","value","label","feedback","type","prepareCustomizationObject","config","model","configuration","defaults","sensibleDefaults","answerChoiceCount","MultipleChoice","HTMLElement","constructor","_root","_model","createDefaultModel","_configuration","onModelChanged","bind","onConfigurationChanged","s","_render","c","info","newConfiguration","language","enabled","languageChoices","options","settings","find","option","disableSidePanel","_disableSidePanel","dispatchModelUpdated","reset","resetValue","dispatchEvent","ModelUpdatedEvent","m","insertImage","handler","InsertImageEvent","onDeleteImage","src","done","DeleteImageEvent","insertSound","InsertSoundEvent","onDeleteSound","DeleteSoundEvent","element","React","createElement","ThemeProvider","Main","imageSupport","add","delete","uploadSoundSupport","createRoot","render","disconnectedCallback","unmount","exports","default","_defineProperty2","normalizedModel","utils","normalizeChoices","choicesLayout","verticalMode"],"sources":["../src/index.js"],"sourcesContent":["import React from 'react';\nimport { createRoot } from 'react-dom/client';\nimport { ThemeProvider, createTheme } from '@mui/material/styles';\nimport debug from 'debug';\nimport {\n DeleteImageEvent,\n InsertImageEvent,\n ModelUpdatedEvent,\n InsertSoundEvent,\n DeleteSoundEvent,\n} from '@pie-framework/pie-configure-events';\n\nimport Main from './main';\nimport { choiceUtils as utils } from '@pie-lib/config-ui';\nimport defaults from 'lodash/defaults';\n\nimport sensibleDefaults from './defaults';\n\nconst theme = createTheme();\n\nconst log = debug('multiple-choice:configure');\n\nconst generateFormattedChoices = (choices, choiceCount = 0) => {\n if (!choices || choices.length === 0) {\n let formattedChoices = [];\n\n for (let i = 0; i < choiceCount; i++) {\n formattedChoices.push({\n value: `${i}`,\n label: '',\n feedback: {\n type: 'none',\n value: '',\n },\n });\n }\n\n return formattedChoices;\n }\n\n return choices;\n};\n\nconst prepareCustomizationObject = (config, model) => {\n const configuration = defaults(config, sensibleDefaults.configuration);\n\n return {\n configuration,\n model: {\n ...model,\n choices: generateFormattedChoices(\n (model && model.choices) || [],\n configuration && configuration.answerChoiceCount,\n ),\n },\n };\n};\n\nexport default class MultipleChoice extends HTMLElement {\n static createDefaultModel = (model = {}) => {\n const normalizedModel = utils.normalizeChoices({\n ...sensibleDefaults.model,\n ...model,\n choices: generateFormattedChoices((model && model.choices) || []),\n });\n\n // This is used for offering support for old models which have the property \"verticalMode\"\n normalizedModel.choicesLayout =\n model.choicesLayout || (model.verticalMode === false && 'horizontal') || sensibleDefaults.model.choicesLayout;\n\n return normalizedModel;\n };\n\n constructor() {\n super();\n this._root = null;\n this._model = MultipleChoice.createDefaultModel();\n this._configuration = sensibleDefaults.configuration;\n this.onModelChanged = this.onModelChanged.bind(this);\n this.onConfigurationChanged = this.onConfigurationChanged.bind(this);\n }\n\n set model(s) {\n this._model = MultipleChoice.createDefaultModel(s);\n\n this._render();\n }\n\n set configuration(c) {\n const info = prepareCustomizationObject(c, this._model);\n\n this.onModelChanged(info.model);\n\n const newConfiguration = {\n ...sensibleDefaults.configuration,\n ...info.configuration,\n };\n this._configuration = newConfiguration;\n\n // if language:enabled is true, then the corresponding default item model should include a language value;\n // if it is false, then the language field should be omitted from the item model.\n // if a default item model includes a language value (e.g., en_US) and the corresponding authoring view settings have language:settings = true,\n // then (a) language:enabled should also be true, and (b) that default language value should be represented in languageChoices[] (as a key).\n if (newConfiguration?.language?.enabled) {\n if (newConfiguration?.languageChoices?.options?.length) {\n this._model.language = newConfiguration?.languageChoices.options[0].value;\n }\n } else if (newConfiguration.language.settings && this._model.language) {\n this._configuration.language.enabled = true;\n\n if (!this._configuration.languageChoices.options || !this._configuration.languageChoices.options.length) {\n this._configuration.languageChoices.options = [];\n }\n\n // check if the language is already included in the languageChoices.options array\n // and if not, then add it.\n if (!this._configuration.languageChoices.options.find((option) => option.value === this._model.language)) {\n this._configuration.languageChoices.options.push({\n value: this._model.language,\n label: this._model.language,\n });\n }\n } else {\n delete this._model.language;\n }\n\n this._render();\n }\n\n set disableSidePanel(s) {\n this._disableSidePanel = s;\n this._render();\n }\n\n dispatchModelUpdated(reset) {\n const resetValue = !!reset;\n\n this.dispatchEvent(new ModelUpdatedEvent(this._model, resetValue));\n }\n\n onModelChanged(m, reset) {\n this._model = m;\n this._render();\n\n this.dispatchModelUpdated(reset);\n }\n\n onConfigurationChanged(c) {\n this._configuration = prepareCustomizationObject(c, this._model).configuration;\n\n if (this._model) {\n this.onModelChanged(this._model);\n }\n\n this._render();\n }\n\n /** @param {done, progress, file} handler */\n insertImage(handler) {\n this.dispatchEvent(new InsertImageEvent(handler));\n }\n\n onDeleteImage(src, done) {\n this.dispatchEvent(new DeleteImageEvent(src, done));\n }\n\n insertSound(handler) {\n this.dispatchEvent(new InsertSoundEvent(handler));\n }\n\n onDeleteSound(src, done) {\n this.dispatchEvent(new DeleteSoundEvent(src, done));\n }\n\n _render() {\n log('_render');\n let element = React.createElement(\n ThemeProvider,\n { theme },\n React.createElement(Main, {\n model: this._model,\n configuration: this._configuration,\n onModelChanged: this.onModelChanged,\n onConfigurationChanged: this.onConfigurationChanged,\n disableSidePanel: this._disableSidePanel,\n imageSupport: {\n add: this.insertImage.bind(this),\n delete: this.onDeleteImage.bind(this),\n },\n uploadSoundSupport: {\n add: this.insertSound.bind(this),\n delete: this.onDeleteSound.bind(this),\n },\n })\n );\n\n if (!this._root) {\n this._root = createRoot(this);\n }\n this._root.render(element);\n }\n\n disconnectedCallback() {\n if (this._root) {\n this._root.unmount();\n }\n }\n}\n"],"mappings":"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","ignoreList":[]}
|
|
1
|
+
{"version":3,"file":"index.js","names":["_react","_interopRequireDefault","require","_client","_debug","_pieConfigureEvents","_main","_configUi","_defaults","_defaults2","log","debug","generateFormattedChoices","choices","choiceCount","length","formattedChoices","i","push","value","label","feedback","type","prepareCustomizationObject","config","model","configuration","defaults","sensibleDefaults","answerChoiceCount","MultipleChoice","HTMLElement","constructor","_root","_reactContainer","_model","createDefaultModel","_configuration","onModelChanged","bind","onConfigurationChanged","s","_render","c","info","newConfiguration","language","enabled","languageChoices","options","settings","find","option","disableSidePanel","_disableSidePanel","dispatchModelUpdated","reset","resetValue","dispatchEvent","ModelUpdatedEvent","m","insertImage","handler","InsertImageEvent","onDeleteImage","src","done","DeleteImageEvent","insertSound","InsertSoundEvent","onDeleteSound","DeleteSoundEvent","console","element","React","createElement","Main","imageSupport","add","delete","uploadSoundSupport","document","className","appendChild","createRoot","render","error","stack","connectedCallback","disconnectedCallback","unmount","exports","default","_defineProperty2","normalizedModel","utils","normalizeChoices","choicesLayout","verticalMode"],"sources":["../src/index.js"],"sourcesContent":["import React from 'react';\nimport { createRoot } from 'react-dom/client';\nimport debug from 'debug';\nimport {\n DeleteImageEvent,\n InsertImageEvent,\n ModelUpdatedEvent,\n InsertSoundEvent,\n DeleteSoundEvent,\n} from '@pie-framework/pie-configure-events';\n\nimport Main from './main';\nimport { choiceUtils as utils } from '@pie-lib/config-ui';\nimport defaults from 'lodash/defaults';\n\nimport sensibleDefaults from './defaults';\n\nconst log = debug('multiple-choice:configure');\n\nconst generateFormattedChoices = (choices, choiceCount = 0) => {\n if (!choices || choices.length === 0) {\n let formattedChoices = [];\n\n for (let i = 0; i < choiceCount; i++) {\n formattedChoices.push({\n value: `${i}`,\n label: '',\n feedback: {\n type: 'none',\n value: '',\n },\n });\n }\n\n return formattedChoices;\n }\n\n return choices;\n};\n\nconst prepareCustomizationObject = (config, model) => {\n const configuration = defaults(config, sensibleDefaults.configuration);\n\n return {\n configuration,\n model: {\n ...model,\n choices: generateFormattedChoices(\n (model && model.choices) || [],\n configuration && configuration.answerChoiceCount,\n ),\n },\n };\n};\n\nexport default class MultipleChoice extends HTMLElement {\n static createDefaultModel = (model = {}) => {\n const normalizedModel = utils.normalizeChoices({\n ...sensibleDefaults.model,\n ...model,\n choices: generateFormattedChoices((model && model.choices) || []),\n });\n\n // This is used for offering support for old models which have the property \"verticalMode\"\n normalizedModel.choicesLayout =\n model.choicesLayout || (model.verticalMode === false && 'horizontal') || sensibleDefaults.model.choicesLayout;\n\n return normalizedModel;\n };\n\n constructor() {\n super();\n this._root = null;\n this._reactContainer = null;\n this._model = MultipleChoice.createDefaultModel();\n this._configuration = sensibleDefaults.configuration;\n this.onModelChanged = this.onModelChanged.bind(this);\n this.onConfigurationChanged = this.onConfigurationChanged.bind(this);\n }\n\n set model(s) {\n this._model = MultipleChoice.createDefaultModel(s);\n\n this._render();\n }\n\n set configuration(c) {\n const info = prepareCustomizationObject(c, this._model);\n\n this.onModelChanged(info.model);\n\n const newConfiguration = {\n ...sensibleDefaults.configuration,\n ...info.configuration,\n };\n this._configuration = newConfiguration;\n\n // if language:enabled is true, then the corresponding default item model should include a language value;\n // if it is false, then the language field should be omitted from the item model.\n // if a default item model includes a language value (e.g., en_US) and the corresponding authoring view settings have language:settings = true,\n // then (a) language:enabled should also be true, and (b) that default language value should be represented in languageChoices[] (as a key).\n if (newConfiguration?.language?.enabled) {\n if (newConfiguration?.languageChoices?.options?.length) {\n this._model.language = newConfiguration?.languageChoices.options[0].value;\n }\n } else if (newConfiguration.language.settings && this._model.language) {\n this._configuration.language.enabled = true;\n\n if (!this._configuration.languageChoices.options || !this._configuration.languageChoices.options.length) {\n this._configuration.languageChoices.options = [];\n }\n\n // check if the language is already included in the languageChoices.options array\n // and if not, then add it.\n if (!this._configuration.languageChoices.options.find((option) => option.value === this._model.language)) {\n this._configuration.languageChoices.options.push({\n value: this._model.language,\n label: this._model.language,\n });\n }\n } else {\n delete this._model.language;\n }\n\n this._render();\n }\n\n set disableSidePanel(s) {\n this._disableSidePanel = s;\n this._render();\n }\n\n dispatchModelUpdated(reset) {\n const resetValue = !!reset;\n\n this.dispatchEvent(new ModelUpdatedEvent(this._model, resetValue));\n }\n\n onModelChanged(m, reset) {\n this._model = m;\n this._render();\n\n this.dispatchModelUpdated(reset);\n }\n\n onConfigurationChanged(c) {\n this._configuration = prepareCustomizationObject(c, this._model).configuration;\n\n if (this._model) {\n this.onModelChanged(this._model);\n }\n\n this._render();\n }\n\n /** @param {done, progress, file} handler */\n insertImage(handler) {\n this.dispatchEvent(new InsertImageEvent(handler));\n }\n\n onDeleteImage(src, done) {\n this.dispatchEvent(new DeleteImageEvent(src, done));\n }\n\n insertSound(handler) {\n this.dispatchEvent(new InsertSoundEvent(handler));\n }\n\n onDeleteSound(src, done) {\n this.dispatchEvent(new DeleteSoundEvent(src, done));\n }\n\n _render() {\n console.log('🔧 [multiple-choice-configure] _render - Starting render');\n console.log('🔧 [multiple-choice-configure] _render - Model:', this._model ? 'present' : 'missing');\n console.log('🔧 [multiple-choice-configure] _render - Configuration:', this._configuration ? 'present' : 'missing');\n console.log('🔧 [multiple-choice-configure] _render - Root exists:', !!this._root);\n log('_render - Starting render');\n log('_render - Model:', this._model ? 'present' : 'missing');\n log('_render - Configuration:', this._configuration ? 'present' : 'missing');\n log('_render - Root exists:', !!this._root);\n \n try {\n let element = React.createElement(Main, {\n model: this._model,\n configuration: this._configuration,\n onModelChanged: this.onModelChanged,\n onConfigurationChanged: this.onConfigurationChanged,\n disableSidePanel: this._disableSidePanel,\n imageSupport: {\n add: this.insertImage.bind(this),\n delete: this.onDeleteImage.bind(this),\n },\n uploadSoundSupport: {\n add: this.insertSound.bind(this),\n delete: this.onDeleteSound.bind(this),\n },\n });\n\n if (!this._root) {\n console.log('🔧 [multiple-choice-configure] _render - Creating React container');\n log('_render - Creating React container');\n \n // Create a container div for React to render into\n this._reactContainer = document.createElement('div');\n this._reactContainer.className = 'pie-configure-wrapper';\n this.appendChild(this._reactContainer);\n \n console.log('🔧 [multiple-choice-configure] _render - Creating new React root');\n log('_render - Creating new React root');\n this._root = createRoot(this._reactContainer);\n console.log('✅ [multiple-choice-configure] _render - React root created successfully');\n log('_render - React root created successfully');\n }\n \n console.log('🔧 [multiple-choice-configure] _render - Calling root.render()');\n log('_render - Calling root.render()');\n this._root.render(element);\n console.log('✅ [multiple-choice-configure] _render - Render completed successfully');\n log('_render - Render completed successfully');\n } catch (error) {\n console.error('❌ [multiple-choice-configure] Render error:', error);\n console.error('Error stack:', error.stack);\n throw error;\n }\n }\n\n connectedCallback() {\n console.log('🔧 [multiple-choice-configure] connectedCallback - Component connected to DOM');\n log('connectedCallback - Component connected to DOM');\n log('connectedCallback - Model:', this._model ? 'present' : 'missing');\n log('connectedCallback - Configuration:', this._configuration ? 'present' : 'missing');\n }\n\n disconnectedCallback() {\n console.log('🔧 [multiple-choice-configure] disconnectedCallback - Component disconnected from DOM');\n log('disconnectedCallback - Component disconnected from DOM');\n if (this._root) {\n console.log('🔧 [multiple-choice-configure] disconnectedCallback - Unmounting React root');\n log('disconnectedCallback - Unmounting React root');\n this._root.unmount();\n this._root = null;\n }\n if (this._reactContainer) {\n this._reactContainer = null;\n }\n }\n}\n"],"mappings":"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","ignoreList":[]}
|