@pie-lib/render-ui 4.15.9 → 4.17.0-beta.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.
Files changed (73) hide show
  1. package/CHANGELOG.md +16 -0
  2. package/NEXT.CHANGELOG.json +1 -0
  3. package/lib/__tests__/color.test.js +20 -0
  4. package/lib/__tests__/has-media.test.js +28 -0
  5. package/lib/__tests__/has-text.test.js +27 -0
  6. package/lib/__tests__/html-and-math.test.js +64 -0
  7. package/lib/__tests__/preview-prompt.test.js +66 -0
  8. package/lib/__tests__/purpose.test.js +42 -0
  9. package/lib/__tests__/readable.test.js +49 -0
  10. package/lib/__tests__/response-indicators.test.js +27 -0
  11. package/lib/__tests__/ui-layout.test.js +43 -0
  12. package/lib/__tests__/withUndoReset.test.js +223 -0
  13. package/lib/append-css-rules.js +88 -0
  14. package/lib/assets/enableAudioAutoplayImage.js +9 -0
  15. package/lib/collapsible/__tests__/index.test.js +23 -0
  16. package/lib/collapsible/index.js +3 -2
  17. package/lib/color.js +124 -3
  18. package/lib/feedback.js +1 -2
  19. package/lib/has-media.js +27 -0
  20. package/lib/has-text.js +6 -2
  21. package/lib/html-and-math.js +1 -1
  22. package/lib/index.js +33 -1
  23. package/lib/input-container.js +1 -1
  24. package/lib/preview-layout.js +17 -5
  25. package/lib/preview-prompt.js +157 -42
  26. package/lib/purpose.js +1 -1
  27. package/lib/readable.js +1 -1
  28. package/lib/response-indicators.js +1 -1
  29. package/lib/ui-layout.js +122 -0
  30. package/lib/withUndoReset.js +1 -1
  31. package/package.json +4 -4
  32. package/src/__tests__/__snapshots__/html-and-math.test.js.snap +11 -0
  33. package/src/__tests__/__snapshots__/preview-prompt.test.jsx.snap +37 -0
  34. package/src/__tests__/__snapshots__/purpose.test.jsx.snap +42 -0
  35. package/src/__tests__/__snapshots__/readable.test.jsx.snap +64 -0
  36. package/src/__tests__/__snapshots__/response-indicators.test.jsx.snap +95 -0
  37. package/src/__tests__/color.test.js +12 -0
  38. package/src/__tests__/has-media.test.js +20 -0
  39. package/src/__tests__/has-text.test.js +21 -0
  40. package/src/__tests__/html-and-math.test.js +46 -0
  41. package/src/__tests__/preview-prompt.test.jsx +56 -0
  42. package/src/__tests__/purpose.test.jsx +47 -0
  43. package/src/__tests__/readable.test.jsx +64 -0
  44. package/src/__tests__/response-indicators.test.jsx +16 -0
  45. package/src/__tests__/ui-layout.test.jsx +34 -0
  46. package/src/__tests__/withUndoReset.test.jsx +254 -0
  47. package/src/append-css-rules.js +51 -0
  48. package/src/assets/enableAudioAutoplayImage.js +1 -0
  49. package/src/collapsible/__tests__/__snapshots__/index.test.jsx.snap +18 -0
  50. package/src/collapsible/__tests__/index.test.jsx +13 -0
  51. package/src/collapsible/index.jsx +1 -0
  52. package/src/color.js +40 -0
  53. package/src/feedback.jsx +0 -1
  54. package/src/has-media.js +16 -0
  55. package/src/has-text.js +5 -1
  56. package/src/index.js +8 -0
  57. package/src/preview-layout.jsx +14 -3
  58. package/src/preview-prompt.jsx +150 -26
  59. package/src/ui-layout.jsx +66 -0
  60. package/README.md +0 -33
  61. package/lib/collapsible/index.js.map +0 -1
  62. package/lib/color.js.map +0 -1
  63. package/lib/feedback.js.map +0 -1
  64. package/lib/has-text.js.map +0 -1
  65. package/lib/html-and-math.js.map +0 -1
  66. package/lib/index.js.map +0 -1
  67. package/lib/input-container.js.map +0 -1
  68. package/lib/preview-layout.js.map +0 -1
  69. package/lib/preview-prompt.js.map +0 -1
  70. package/lib/purpose.js.map +0 -1
  71. package/lib/readable.js.map +0 -1
  72. package/lib/response-indicators.js.map +0 -1
  73. package/lib/withUndoReset.js.map +0 -1
@@ -65,7 +65,7 @@ var PreviewPrompt = /*#__PURE__*/function (_Component) {
65
65
 
66
66
  _this = _super.call.apply(_super, [this].concat(args));
67
67
  (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "parsedText", function (text) {
68
- // fix imported audio content for Safari PD-1419
68
+ var customAudioButton = _this.props.customAudioButton;
69
69
  var div = document.createElement('div');
70
70
  div.innerHTML = text;
71
71
  var audio = div.querySelector('audio');
@@ -75,7 +75,25 @@ var PreviewPrompt = /*#__PURE__*/function (_Component) {
75
75
  source.setAttribute('type', 'audio/mp3');
76
76
  source.setAttribute('src', audio.getAttribute('src'));
77
77
  audio.removeAttribute('src');
78
+ audio.setAttribute('id', 'pie-prompt-audio-player');
78
79
  audio.appendChild(source);
80
+
81
+ if (customAudioButton) {
82
+ audio.style.display = 'none';
83
+ var playButton = document.createElement('div');
84
+ playButton.id = 'play-audio-button';
85
+ Object.assign(playButton.style, {
86
+ cursor: 'pointer',
87
+ display: 'block',
88
+ width: '128px',
89
+ height: '128px',
90
+ backgroundImage: "url(".concat(customAudioButton.pauseImage, ")"),
91
+ backgroundSize: 'cover',
92
+ borderRadius: '50%',
93
+ border: '1px solid #326295'
94
+ });
95
+ audio.parentNode.insertBefore(playButton, audio);
96
+ }
79
97
  }
80
98
 
81
99
  return div.innerHTML;
@@ -84,51 +102,136 @@ var PreviewPrompt = /*#__PURE__*/function (_Component) {
84
102
  }
85
103
 
86
104
  (0, _createClass2["default"])(PreviewPrompt, [{
105
+ key: "addCustomAudioButtonControls",
106
+ value: function addCustomAudioButtonControls() {
107
+ var _this$props = this.props,
108
+ autoplayAudioEnabled = _this$props.autoplayAudioEnabled,
109
+ customAudioButton = _this$props.customAudioButton;
110
+ var playButton = document.getElementById('play-audio-button');
111
+ var audio = document.getElementById('pie-prompt-audio-player');
112
+
113
+ if (autoplayAudioEnabled && audio) {
114
+ audio.play().then(function () {
115
+ if (playButton && customAudioButton) {
116
+ audio.addEventListener('ended', handleAudioEnded);
117
+ }
118
+ })["catch"](function (error) {
119
+ console.error('Error playing audio', error);
120
+ });
121
+ }
122
+
123
+ if (!playButton || !audio || !customAudioButton) return;
124
+
125
+ var handlePlayClick = function handlePlayClick() {
126
+ // if already playing, don't play again
127
+ if (!audio.paused) return;
128
+ if (playButton.style.backgroundImage.includes(customAudioButton.pauseImage)) return;
129
+ audio.play();
130
+ };
131
+
132
+ var handleAudioEnded = function handleAudioEnded() {
133
+ playButton.style.backgroundImage = "url(".concat(customAudioButton.playImage, ")");
134
+ };
135
+
136
+ var handleAudioPlay = function handleAudioPlay() {
137
+ Object.assign(playButton.style, {
138
+ backgroundImage: "url(".concat(customAudioButton.pauseImage, ")"),
139
+ border: '1px solid #ccc'
140
+ });
141
+ };
142
+
143
+ var handleAudioPause = function handleAudioPause() {
144
+ Object.assign(playButton.style, {
145
+ backgroundImage: "url(".concat(customAudioButton.playImage, ")"),
146
+ border: '1px solid #326295'
147
+ });
148
+ };
149
+
150
+ playButton.addEventListener('click', handlePlayClick);
151
+ audio.addEventListener('play', handleAudioPlay);
152
+ audio.addEventListener('pause', handleAudioPause);
153
+ audio.addEventListener('ended', handleAudioEnded); // store event handler references so they can be removed later
154
+
155
+ this._handlePlayClick = handlePlayClick;
156
+ this._handleAudioPlay = handleAudioPlay;
157
+ this._handleAudioPause = handleAudioPause;
158
+ this._handleAudioEnded = handleAudioEnded;
159
+ }
160
+ }, {
161
+ key: "removeCustomAudioButtonListeners",
162
+ value: function removeCustomAudioButtonListeners() {
163
+ var playButton = document.getElementById('play-audio-button');
164
+ var audio = document.querySelector('audio');
165
+ if (!playButton || !audio) return; // remove event listeners using stored references
166
+
167
+ playButton.removeEventListener('click', this._handlePlayClick);
168
+ audio.removeEventListener('play', this._handleAudioPlay);
169
+ audio.removeEventListener('pause', this._handleAudioPause);
170
+ audio.removeEventListener('ended', this._handleAudioEnded);
171
+ }
172
+ }, {
173
+ key: "componentDidMount",
174
+ value: function componentDidMount() {
175
+ this.alignImages();
176
+ this.addCustomAudioButtonControls();
177
+ }
178
+ }, {
87
179
  key: "componentDidUpdate",
88
180
  value: function componentDidUpdate() {
89
- // set image parent style so it can be horizontally aligned
90
- var previewPrompt = document.querySelector('#preview-prompt');
91
- var images = previewPrompt && previewPrompt.getElementsByTagName('img');
92
-
93
- if (images && images.length) {
94
- var _iterator = _createForOfIteratorHelper(images),
95
- _step;
96
-
97
- try {
98
- for (_iterator.s(); !(_step = _iterator.n()).done;) {
99
- var image = _step.value;
100
-
101
- // check if alignment property was set
102
- if (image.attributes && image.attributes.alignment && image.attributes.alignment.value) {
103
- var parentNode = image.parentElement; // check if div is not already added to dom and replace current image with wrapped image
104
-
105
- if (!(parentNode.tagName === 'DIV' && parentNode.style.display === 'flex' && parentNode.style.width === '100%')) {
106
- var div = document.createElement('div');
107
- div.style.display = 'flex';
108
- div.style.width = '100%';
109
- var copyImage = image.cloneNode(true);
110
- div.appendChild(copyImage);
111
- parentNode.replaceChild(div, image);
181
+ this.alignImages();
182
+ }
183
+ }, {
184
+ key: "componentWillUnmount",
185
+ value: function componentWillUnmount() {
186
+ this.removeCustomAudioButtonListeners();
187
+ }
188
+ }, {
189
+ key: "alignImages",
190
+ value: function alignImages() {
191
+ var previewPrompts = document.querySelectorAll('#preview-prompt');
192
+ previewPrompts.forEach(function (previewPrompt) {
193
+ var images = previewPrompt.getElementsByTagName('img');
194
+
195
+ if (images && images.length) {
196
+ var _iterator = _createForOfIteratorHelper(images),
197
+ _step;
198
+
199
+ try {
200
+ for (_iterator.s(); !(_step = _iterator.n()).done;) {
201
+ var image = _step.value;
202
+
203
+ // check if alignment property was set
204
+ if (image.attributes && image.attributes.alignment && image.attributes.alignment.value) {
205
+ var parentNode = image.parentElement; // check if div is not already added to dom and replace current image with wrapped image
206
+
207
+ if (!(parentNode.tagName === 'DIV' && parentNode.style.display === 'flex' && parentNode.style.width === '100%')) {
208
+ var div = document.createElement('div');
209
+ div.style.display = 'flex';
210
+ div.style.width = '100%';
211
+ var copyImage = image.cloneNode(true);
212
+ div.appendChild(copyImage);
213
+ parentNode.replaceChild(div, image);
214
+ }
112
215
  }
113
216
  }
217
+ } catch (err) {
218
+ _iterator.e(err);
219
+ } finally {
220
+ _iterator.f();
114
221
  }
115
- } catch (err) {
116
- _iterator.e(err);
117
- } finally {
118
- _iterator.f();
119
222
  }
120
- }
223
+ });
121
224
  }
122
225
  }, {
123
226
  key: "render",
124
227
  value: function render() {
125
- var _this$props = this.props,
126
- prompt = _this$props.prompt,
127
- classes = _this$props.classes,
128
- tagName = _this$props.tagName,
129
- className = _this$props.className,
130
- onClick = _this$props.onClick,
131
- defaultClassName = _this$props.defaultClassName;
228
+ var _this$props2 = this.props,
229
+ prompt = _this$props2.prompt,
230
+ classes = _this$props2.classes,
231
+ tagName = _this$props2.tagName,
232
+ className = _this$props2.className,
233
+ onClick = _this$props2.onClick,
234
+ defaultClassName = _this$props2.defaultClassName;
132
235
  var CustomTag = tagName || 'div'; // legend tag was added once with accessibility tasks, wee need extra style to make it work with images alignment
133
236
 
134
237
  var legendClass = tagName === 'legend' ? 'legend' : '';
@@ -153,7 +256,12 @@ exports.PreviewPrompt = PreviewPrompt;
153
256
  tagName: _propTypes["default"].string,
154
257
  className: _propTypes["default"].string,
155
258
  onClick: _propTypes["default"].func,
156
- defaultClassName: _propTypes["default"].string
259
+ defaultClassName: _propTypes["default"].string,
260
+ autoplayAudioEnabled: _propTypes["default"].bool,
261
+ customAudioButton: {
262
+ playImage: _propTypes["default"].string,
263
+ pauseImage: _propTypes["default"].string
264
+ }
157
265
  });
158
266
  (0, _defineProperty2["default"])(PreviewPrompt, "defaultProps", {
159
267
  onClick: function onClick() {}
@@ -176,7 +284,8 @@ var styles = function styles(theme) {
176
284
  label: {
177
285
  color: "".concat(color.text(), " !important"),
178
286
  //'var(--choice-input-color, black)',
179
- display: 'inline-block',
287
+ display: 'flex',
288
+ flexDirection: 'column',
180
289
  verticalAlign: 'middle',
181
290
  cursor: 'pointer',
182
291
  '& > p': {
@@ -189,12 +298,18 @@ var styles = function styles(theme) {
189
298
  },
190
299
  '&:not(.MathJax) > table tr': {
191
300
  '&:nth-child(2n)': {
192
- backgroundColor: '#f6f8fa'
301
+ backgroundColor: '#f6f8fa',
302
+ color: theme.palette.common.black
193
303
  }
194
304
  },
195
- '&:not(.MathJax) > table td, &:not(.MathJax) > table th': {
305
+ // align table content to left as per STAR requirement PD-3687
306
+ '&:not(.MathJax) table td, &:not(.MathJax) table th': {
196
307
  padding: '.6em 1em',
197
- textAlign: 'center'
308
+ textAlign: 'left'
309
+ },
310
+ // added this to fix alignment of text in prompt imported from studio (PD-3423)
311
+ '&:not(.MathJax) > table td > p.kds-indent': {
312
+ textAlign: 'initial'
198
313
  }
199
314
  }
200
315
  };
@@ -203,4 +318,4 @@ var styles = function styles(theme) {
203
318
  var _default = (0, _styles.withStyles)(styles)(PreviewPrompt);
204
319
 
205
320
  exports["default"] = _default;
206
- //# sourceMappingURL=preview-prompt.js.map
321
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/preview-prompt.jsx"],"names":["NEWLINE_BLOCK_REGEX","NEWLINE_LATEX","PreviewPrompt","text","customAudioButton","props","div","document","createElement","innerHTML","audio","querySelector","source","setAttribute","getAttribute","removeAttribute","appendChild","style","display","playButton","id","Object","assign","cursor","width","height","backgroundImage","pauseImage","backgroundSize","borderRadius","border","parentNode","insertBefore","autoplayAudioEnabled","getElementById","play","then","addEventListener","handleAudioEnded","error","console","handlePlayClick","paused","includes","playImage","handleAudioPlay","handleAudioPause","_handlePlayClick","_handleAudioPlay","_handleAudioPause","_handleAudioEnded","removeEventListener","alignImages","addCustomAudioButtonControls","removeCustomAudioButtonListeners","previewPrompts","querySelectorAll","forEach","previewPrompt","images","getElementsByTagName","length","image","attributes","alignment","value","parentElement","tagName","copyImage","cloneNode","replaceChild","prompt","classes","className","onClick","defaultClassName","CustomTag","legendClass","customClasses","promptTable","__html","parsedText","replace","Component","PropTypes","object","string","func","bool","styles","theme","verticalAlign","color","legend","fontSize","rationale","paddingLeft","spacing","unit","paddingBottom","label","flexDirection","margin","borderCollapse","backgroundColor","palette","common","black","padding","textAlign"],"mappings":"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","sourcesContent":["import React, { Component } from 'react';\nimport { withStyles } from '@material-ui/core/styles';\nimport PropTypes from 'prop-types';\nimport * as color from './color';\n\n//Used these below to replace \\\\embed{newLine} with \\\\newline from prompt which will get parsed in MathJax\nconst NEWLINE_BLOCK_REGEX = /\\\\embed\\{newLine\\}\\[\\]/g;\nconst NEWLINE_LATEX = '\\\\newline ';\n\nexport class PreviewPrompt extends Component {\n  static propTypes = {\n    classes: PropTypes.object,\n    prompt: PropTypes.string,\n    tagName: PropTypes.string,\n    className: PropTypes.string,\n    onClick: PropTypes.func,\n    defaultClassName: PropTypes.string,\n    autoplayAudioEnabled: PropTypes.bool,\n    customAudioButton: {\n      playImage: PropTypes.string,\n      pauseImage: PropTypes.string,\n    },\n  };\n\n  static defaultProps = {\n    onClick: () => {},\n  };\n\n  parsedText = (text) => {\n    const { customAudioButton } = this.props;\n    const div = document.createElement('div');\n    div.innerHTML = text;\n\n    const audio = div.querySelector('audio');\n    if (audio) {\n      const source = document.createElement('source');\n\n      source.setAttribute('type', 'audio/mp3');\n      source.setAttribute('src', audio.getAttribute('src'));\n\n      audio.removeAttribute('src');\n      audio.setAttribute('id', 'pie-prompt-audio-player');\n\n      audio.appendChild(source);\n\n      if (customAudioButton) {\n        audio.style.display = 'none';\n\n        const playButton = document.createElement('div');\n        playButton.id = 'play-audio-button';\n\n        Object.assign(playButton.style, {\n          cursor: 'pointer',\n          display: 'block',\n          width: '128px',\n          height: '128px',\n          backgroundImage: `url(${customAudioButton.pauseImage})`,\n          backgroundSize: 'cover',\n          borderRadius: '50%',\n          border: '1px solid #326295',\n        });\n\n        audio.parentNode.insertBefore(playButton, audio);\n      }\n    }\n\n    return div.innerHTML;\n  };\n\n  addCustomAudioButtonControls() {\n    const { autoplayAudioEnabled, customAudioButton } = this.props;\n    const playButton = document.getElementById('play-audio-button');\n    const audio = document.getElementById('pie-prompt-audio-player');\n\n    if (autoplayAudioEnabled && audio) {\n      audio\n        .play()\n        .then(() => {\n          if (playButton && customAudioButton) {\n            audio.addEventListener('ended', handleAudioEnded);\n          }\n        })\n        .catch((error) => {\n          console.error('Error playing audio', error);\n        });\n    }\n\n    if (!playButton || !audio || !customAudioButton) return;\n\n    const handlePlayClick = () => {\n      // if already playing, don't play again\n      if (!audio.paused) return;\n      if (playButton.style.backgroundImage.includes(customAudioButton.pauseImage)) return;\n\n      audio.play();\n    };\n\n    const handleAudioEnded = () => {\n      playButton.style.backgroundImage = `url(${customAudioButton.playImage})`;\n    };\n\n    const handleAudioPlay = () => {\n      Object.assign(playButton.style, {\n        backgroundImage: `url(${customAudioButton.pauseImage})`,\n        border: '1px solid #ccc',\n      });\n    };\n\n    const handleAudioPause = () => {\n      Object.assign(playButton.style, {\n        backgroundImage: `url(${customAudioButton.playImage})`,\n        border: '1px solid #326295',\n      });\n    };\n\n    playButton.addEventListener('click', handlePlayClick);\n    audio.addEventListener('play', handleAudioPlay);\n    audio.addEventListener('pause', handleAudioPause);\n    audio.addEventListener('ended', handleAudioEnded);\n\n    // store event handler references so they can be removed later\n    this._handlePlayClick = handlePlayClick;\n    this._handleAudioPlay = handleAudioPlay;\n    this._handleAudioPause = handleAudioPause;\n    this._handleAudioEnded = handleAudioEnded;\n  }\n\n  removeCustomAudioButtonListeners() {\n    const playButton = document.getElementById('play-audio-button');\n    const audio = document.querySelector('audio');\n\n    if (!playButton || !audio) return;\n\n    // remove event listeners using stored references\n    playButton.removeEventListener('click', this._handlePlayClick);\n    audio.removeEventListener('play', this._handleAudioPlay);\n    audio.removeEventListener('pause', this._handleAudioPause);\n    audio.removeEventListener('ended', this._handleAudioEnded);\n  }\n\n  componentDidMount() {\n    this.alignImages();\n    this.addCustomAudioButtonControls();\n  }\n\n  componentDidUpdate() {\n    this.alignImages();\n  }\n\n  componentWillUnmount() {\n    this.removeCustomAudioButtonListeners();\n  }\n\n  alignImages() {\n    const previewPrompts = document.querySelectorAll('#preview-prompt');\n\n    previewPrompts.forEach((previewPrompt) => {\n      const images = previewPrompt.getElementsByTagName('img');\n\n      if (images && images.length) {\n        for (let image of images) {\n          // check if alignment property was set\n          if (image.attributes && image.attributes.alignment && image.attributes.alignment.value) {\n            const parentNode = image.parentElement;\n\n            // check if div is not already added to dom and replace current image with wrapped image\n            if (\n              !(\n                parentNode.tagName === 'DIV' &&\n                parentNode.style.display === 'flex' &&\n                parentNode.style.width === '100%'\n              )\n            ) {\n              const div = document.createElement('div');\n              div.style.display = 'flex';\n              div.style.width = '100%';\n\n              const copyImage = image.cloneNode(true);\n              div.appendChild(copyImage);\n              parentNode.replaceChild(div, image);\n            }\n          }\n        }\n      }\n    });\n  }\n\n  render() {\n    const { prompt, classes, tagName, className, onClick, defaultClassName } = this.props;\n    const CustomTag = tagName || 'div';\n    // legend tag was added once with accessibility tasks, wee need extra style to make it work with images alignment\n    const legendClass = tagName === 'legend' ? 'legend' : '';\n    const customClasses = `${classes.promptTable} ${classes[className] || ''} ${defaultClassName || ''} ${classes[\n      legendClass\n    ] || ''}`;\n\n    return (\n      <CustomTag\n        id={'preview-prompt'}\n        onClick={onClick}\n        className={customClasses}\n        dangerouslySetInnerHTML={{\n          __html: this.parsedText(prompt || '').replace(NEWLINE_BLOCK_REGEX, NEWLINE_LATEX),\n        }}\n      />\n    );\n  }\n}\n\nconst styles = (theme) => ({\n  prompt: {\n    verticalAlign: 'middle',\n    color: color.text(),\n  },\n  legend: {\n    width: '100%',\n    fontSize: 'inherit  !important',\n  },\n  rationale: {\n    paddingLeft: theme.spacing.unit * 4,\n    paddingBottom: theme.spacing.unit,\n  },\n  label: {\n    color: `${color.text()} !important`, //'var(--choice-input-color, black)',\n    display: 'flex',\n    flexDirection: 'column',\n    verticalAlign: 'middle',\n    cursor: 'pointer',\n    '& > p': {\n      margin: '0 0 0 0 !important',\n    },\n  },\n  promptTable: {\n    '&:not(.MathJax) > table': {\n      borderCollapse: 'collapse',\n    },\n    '&:not(.MathJax) > table tr': {\n      '&:nth-child(2n)': {\n        backgroundColor: '#f6f8fa',\n        color: theme.palette.common.black,\n      },\n    },\n    // align table content to left as per STAR requirement PD-3687\n    '&:not(.MathJax) table td, &:not(.MathJax) table th': {\n      padding: '.6em 1em',\n      textAlign: 'left',\n    },\n    // added this to fix alignment of text in prompt imported from studio (PD-3423)\n    '&:not(.MathJax) > table td > p.kds-indent': {\n      textAlign: 'initial',\n    },\n  },\n});\nexport default withStyles(styles)(PreviewPrompt);\n"]}
package/lib/purpose.js CHANGED
@@ -25,4 +25,4 @@ Purpose.propTypes = {
25
25
  };
26
26
  var _default = Purpose;
27
27
  exports["default"] = _default;
28
- //# sourceMappingURL=purpose.js.map
28
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9wdXJwb3NlLmpzeCJdLCJuYW1lcyI6WyJQdXJwb3NlIiwicHJvcHMiLCJSZWFjdCIsIkNoaWxkcmVuIiwibWFwIiwiY2hpbGRyZW4iLCJjaGlsZCIsImNsb25lRWxlbWVudCIsInB1cnBvc2UiLCJwcm9wVHlwZXMiLCJQcm9wVHlwZXMiLCJub2RlIiwic3RyaW5nIl0sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7QUFBQTs7QUFDQTs7QUFFQSxJQUFNQSxPQUFPLEdBQUcsU0FBVkEsT0FBVSxDQUFDQyxLQUFELEVBQVc7QUFDekIsc0JBQ0Usa0VBQ0dDLGtCQUFNQyxRQUFOLENBQWVDLEdBQWYsQ0FBbUJILEtBQUssQ0FBQ0ksUUFBekIsRUFBbUMsVUFBQ0MsS0FBRDtBQUFBLHdCQUFXSixrQkFBTUssWUFBTixDQUFtQkQsS0FBbkIsRUFBMEI7QUFBRSwwQkFBb0JMLEtBQUssQ0FBQ087QUFBNUIsS0FBMUIsQ0FBWDtBQUFBLEdBQW5DLENBREgsQ0FERjtBQUtELENBTkQ7O0FBUUFSLE9BQU8sQ0FBQ1MsU0FBUixHQUFvQjtBQUNsQkosRUFBQUEsUUFBUSxFQUFFSyxzQkFBVUMsSUFERjtBQUVsQkgsRUFBQUEsT0FBTyxFQUFFRSxzQkFBVUU7QUFGRCxDQUFwQjtlQUtlWixPIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFByb3BUeXBlcyBmcm9tICdwcm9wLXR5cGVzJztcbmltcG9ydCBSZWFjdCBmcm9tICdyZWFjdCc7XG5cbmNvbnN0IFB1cnBvc2UgPSAocHJvcHMpID0+IHtcbiAgcmV0dXJuIChcbiAgICA8PlxuICAgICAge1JlYWN0LkNoaWxkcmVuLm1hcChwcm9wcy5jaGlsZHJlbiwgKGNoaWxkKSA9PiBSZWFjdC5jbG9uZUVsZW1lbnQoY2hpbGQsIHsgJ2RhdGEtcGllLXB1cnBvc2UnOiBwcm9wcy5wdXJwb3NlIH0pKX1cbiAgICA8Lz5cbiAgKTtcbn07XG5cblB1cnBvc2UucHJvcFR5cGVzID0ge1xuICBjaGlsZHJlbjogUHJvcFR5cGVzLm5vZGUsXG4gIHB1cnBvc2U6IFByb3BUeXBlcy5zdHJpbmcsXG59O1xuXG5leHBvcnQgZGVmYXVsdCBQdXJwb3NlO1xuIl19
package/lib/readable.js CHANGED
@@ -25,4 +25,4 @@ Readable.propTypes = {
25
25
  };
26
26
  var _default = Readable;
27
27
  exports["default"] = _default;
28
- //# sourceMappingURL=readable.js.map
28
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9yZWFkYWJsZS5qc3giXSwibmFtZXMiOlsiUmVhZGFibGUiLCJwcm9wcyIsIlJlYWN0IiwiQ2hpbGRyZW4iLCJtYXAiLCJjaGlsZHJlbiIsImNoaWxkIiwiY2xvbmVFbGVtZW50IiwidW5kZWZpbmVkIiwicHJvcFR5cGVzIiwiUHJvcFR5cGVzIiwibm9kZSIsImJvb2wiXSwibWFwcGluZ3MiOiI7Ozs7Ozs7OztBQUFBOztBQUNBOztBQUVBLElBQU1BLFFBQVEsR0FBRyxTQUFYQSxRQUFXLENBQUNDLEtBQUQsRUFBVztBQUMxQixzQkFDRSxrRUFDR0Msa0JBQU1DLFFBQU4sQ0FBZUMsR0FBZixDQUFtQkgsS0FBSyxDQUFDSSxRQUF6QixFQUFtQyxVQUFDQyxLQUFEO0FBQUEsd0JBQ2xDSixrQkFBTUssWUFBTixDQUFtQkQsS0FBbkIsRUFBMEI7QUFBRSwyQkFBcUJMLEtBQUssU0FBTCxLQUFnQk87QUFBdkMsS0FBMUIsQ0FEa0M7QUFBQSxHQUFuQyxDQURILENBREY7QUFPRCxDQVJEOztBQVVBUixRQUFRLENBQUNTLFNBQVQsR0FBcUI7QUFDbkJKLEVBQUFBLFFBQVEsRUFBRUssc0JBQVVDLElBREQ7QUFFbkIsV0FBT0Qsc0JBQVVFO0FBRkUsQ0FBckI7ZUFLZVosUSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBQcm9wVHlwZXMgZnJvbSAncHJvcC10eXBlcyc7XG5pbXBvcnQgUmVhY3QgZnJvbSAncmVhY3QnO1xuXG5jb25zdCBSZWFkYWJsZSA9IChwcm9wcykgPT4ge1xuICByZXR1cm4gKFxuICAgIDw+XG4gICAgICB7UmVhY3QuQ2hpbGRyZW4ubWFwKHByb3BzLmNoaWxkcmVuLCAoY2hpbGQpID0+XG4gICAgICAgIFJlYWN0LmNsb25lRWxlbWVudChjaGlsZCwgeyAnZGF0YS1waWUtcmVhZGFibGUnOiBwcm9wcy5mYWxzZSA9PT0gdW5kZWZpbmVkIH0pLFxuICAgICAgKX1cbiAgICA8Lz5cbiAgKTtcbn07XG5cblJlYWRhYmxlLnByb3BUeXBlcyA9IHtcbiAgY2hpbGRyZW46IFByb3BUeXBlcy5ub2RlLFxuICBmYWxzZTogUHJvcFR5cGVzLmJvb2wsXG59O1xuXG5leHBvcnQgZGVmYXVsdCBSZWFkYWJsZTtcbiJdfQ==
@@ -148,4 +148,4 @@ var PartiallyCorrect = BuildIndicator(icons.PartiallyCorrect, 'partially-correct
148
148
  exports.PartiallyCorrect = PartiallyCorrect;
149
149
  var NothingSubmitted = BuildIndicator(icons.NothingSubmitted, 'nothing-submitted');
150
150
  exports.NothingSubmitted = NothingSubmitted;
151
- //# sourceMappingURL=response-indicators.js.map
151
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9yZXNwb25zZS1pbmRpY2F0b3JzLmpzeCJdLCJuYW1lcyI6WyJsb2ciLCJzdHlsZXMiLCJyZXNwb25zZUluZGljYXRvciIsImN1cnNvciIsInBhcGVyIiwicGFkZGluZyIsImJvcmRlclJhZGl1cyIsInBvcG92ZXIiLCJwb3BwZXJDbG9zZSIsIkJ1aWxkSW5kaWNhdG9yIiwiSWNvbiIsImNvcnJlY3RuZXNzIiwiUmF3SW5kaWNhdG9yIiwicHJvcHMiLCJldmVudCIsInRhcmdldCIsInNldFN0YXRlIiwiYW5jaG9yRWwiLCJzdGF0ZSIsImZlZWRiYWNrIiwiY2xhc3NlcyIsInIiLCJpY29uIiwiaGFuZGxlUG9wb3Zlck9wZW4iLCJ2ZXJ0aWNhbCIsImhvcml6b250YWwiLCJoYW5kbGVQb3BvdmVyQ2xvc2UiLCJSZWFjdCIsIkNvbXBvbmVudCIsInByb3BUeXBlcyIsIlByb3BUeXBlcyIsInN0cmluZyIsIm9iamVjdCIsImlzUmVxdWlyZWQiLCJDb3JyZWN0IiwiaWNvbnMiLCJJbmNvcnJlY3QiLCJQYXJ0aWFsbHlDb3JyZWN0IiwiTm90aGluZ1N1Ym1pdHRlZCJdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQUFBOztBQUNBOztBQUNBOztBQUNBOztBQUNBOztBQUNBOztBQUNBOzs7Ozs7Ozs7O0FBRUEsSUFBTUEsR0FBRyxHQUFHLHVCQUFNLHdDQUFOLENBQVo7O0FBRUEsSUFBTUMsTUFBTSxHQUFHLFNBQVRBLE1BQVM7QUFBQSxTQUFPO0FBQ3BCQyxJQUFBQSxpQkFBaUIsRUFBRTtBQUNqQkMsTUFBQUEsTUFBTSxFQUFFO0FBRFMsS0FEQztBQUlwQkMsSUFBQUEsS0FBSyxFQUFFO0FBQ0xDLE1BQUFBLE9BQU8sRUFBRSxHQURKO0FBRUxDLE1BQUFBLFlBQVksRUFBRTtBQUZULEtBSmE7QUFRcEJDLElBQUFBLE9BQU8sRUFBRTtBQUNQSixNQUFBQSxNQUFNLEVBQUU7QUFERCxLQVJXO0FBV3BCSyxJQUFBQSxXQUFXLEVB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Q0FBQzBCLEtBQUssQ0FBQ0csZ0JBQVAsRUFBeUIsbUJBQXpCLENBQXZDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0IGZyb20gJ3JlYWN0JztcbmltcG9ydCBQcm9wVHlwZXMgZnJvbSAncHJvcC10eXBlcyc7XG5pbXBvcnQgKiBhcyBpY29ucyBmcm9tICdAcGllLWxpYi9pY29ucyc7XG5pbXBvcnQgUG9wb3ZlciBmcm9tICdAbWF0ZXJpYWwtdWkvY29yZS9Qb3BvdmVyJztcbmltcG9ydCB7IHdpdGhTdHlsZXMgfSBmcm9tICdAbWF0ZXJpYWwtdWkvY29yZS9zdHlsZXMnO1xuaW1wb3J0IEZlZWRiYWNrIGZyb20gJy4vZmVlZGJhY2snO1xuaW1wb3J0IGRlYnVnIGZyb20gJ2RlYnVnJztcblxuY29uc3QgbG9nID0gZGVidWcoJ3BpZS1saWJzOnJlbmRlci11aTpyZXNwb25zZS1pbmRpY2F0b3JzJyk7XG5cbmNvbnN0IHN0eWxlcyA9ICgpID0+ICh7XG4gIHJlc3BvbnNlSW5kaWNhdG9yOiB7XG4gICAgY3Vyc29yOiAncG9pbnRlcicsXG4gIH0sXG4gIHBhcGVyOiB7XG4gICAgcGFkZGluZzogJzAnLFxuICAgIGJvcmRlclJhZGl1czogJzRweCcsXG4gIH0sXG4gIHBvcG92ZXI6IHtcbiAgICBjdXJzb3I6ICdwb2ludGVyJyxcbiAgfSxcbiAgcG9wcGVyQ2xvc2U6IHtcbiAgICBjdXJzb3I6ICdwb2ludGVyJyxcbiAgfSxcbn0pO1xuXG5jb25zdCBCdWlsZEluZGljYXRvciA9IChJY29uLCBjb3JyZWN0bmVzcykgPT4ge1xuICBjbGFzcyBSYXdJbmRpY2F0b3IgZXh0ZW5kcyBSZWFjdC5Db21wb25lbnQge1xuICAgIGNvbnN0cnVjdG9yKHByb3BzKSB7XG4gICAgICBzdXBlcihwcm9wcyk7XG4gICAgICB0aGlzLnN0YXRlID0ge307XG4gICAgfVxuXG4gICAgaGFuZGxlUG9wb3Zlck9wZW4gPSAoZXZlbnQpID0+IHtcbiAgICAgIGxvZygnW2hhbmRsZVBvcG92ZXJPcGVuXScsIGV2ZW50LnRhcmdldCk7XG4gICAgICB0aGlzLnNldFN0YXRlKHsgYW5jaG9yRWw6IGV2ZW50LnRhcmdldCB9KTtcbiAgICB9O1xuXG4gICAgaGFuZGxlUG9wb3ZlckNsb3NlID0gKCkgPT4ge1xuICAgICAgdGhpcy5zZXRTdGF0ZSh7IGFuY2hvckVsOiBudWxsIH0pO1xuICAgIH07XG5cbiAgICByZW5kZXIoKSB7XG4gICAgICBjb25zdCB7IGZlZWRiYWNrLCBjbGFzc2VzIH0gPSB0aGlzLnByb3BzO1xuICAgICAgY29uc3QgeyBhbmNob3JFbCB9ID0gdGhpcy5zdGF0ZTtcbiAgICAgIHJldHVybiAoXG4gICAgICAgIDxkaXYgY2xhc3NOYW1lPXtmZWVkYmFjayAmJiBjbGFzc2VzLnJlc3BvbnNlSW5kaWNhdG9yfT5cbiAgICAgICAgICA8c3BhbiByZWY9eyhyKSA9PiAodGhpcy5pY29uID0gcil9IG9uQ2xpY2s9e3RoaXMuaGFuZGxlUG9wb3Zlck9wZW59PlxuICAgICAgICAgICAgPEljb24gLz5cbiAgICAgICAgICA8L3NwYW4+XG5cbiAgICAgICAgICB7ZmVlZGJhY2sgJiYgKFxuICAgICAgICAgICAgPFBvcG92ZXJcbiAgICAgICAgICAgICAgY2xhc3NOYW1lPXtjbGFzc2VzLnBvcG92ZXJ9XG4gICAgICAgICAgICAgIGNsYXNzZXM9e3tcbiAgICAgICAgICAgICAgICBwYXBlcjogY2xhc3Nlcy5wYXBlcixcbiAgICAgICAgICAgICAgfX1cbiAgICAgICAgICAgICAgb3Blbj17ISFhbmNob3JFbH1cbiAgICAgICAgICAgICAgYW5jaG9yRWw9e2FuY2hvckVsfVxuICAgICAgICAgICAgICBhbmNob3JPcmlnaW49e3tcbiAgICAgICAgICAgICAgICB2ZXJ0aWNhbDogJ2JvdHRvbScsXG4gICAgICAgICAgICAgICAgaG9yaXpvbnRhbDogJ2xlZnQnLFxuICAgICAgICAgICAgICB9fVxuICAgICAgICAgICAgICB0cmFuc2Zvcm1PcmlnaW49e3tcbiAgICAgICAgICAgICAgICB2ZXJ0aWNhbDogJ3RvcCcsXG4gICAgICAgICAgICAgICAgaG9yaXpvbnRhbDogJ2xlZnQnLFxuICAgICAgICAgICAgICB9fVxuICAgICAgICAgICAgICBvbkNsb3NlPXt0aGlzLmhhbmRsZVBvcG92ZXJDbG9zZX1cbiAgICAgICAgICAgID5cbiAgICAgICAgICAgICAgPEZlZWRiYWNrIGZlZWRiYWNrPXtmZWVkYmFja30gY29ycmVjdG5lc3M9e2NvcnJlY3RuZXNzfSAvPlxuICAgICAgICAgICAgPC9Qb3BvdmVyPlxuICAgICAgICAgICl9XG4gICAgICAgIDwvZGl2PlxuICAgICAgKTtcbiAgICB9XG4gIH1cblxuICBSYXdJbmRpY2F0b3IucHJvcFR5cGVzID0ge1xuICAgIGZlZWRiYWNrOiBQcm9wVHlwZXMuc3RyaW5nLFxuICAgIGNsYXNzZXM6IFByb3BUeXBlcy5vYmplY3QuaXNSZXF1aXJlZCxcbiAgfTtcblxuICByZXR1cm4gd2l0aFN0eWxlcyhzdHlsZXMpKFJhd0luZGljYXRvcik7XG59O1xuXG5leHBvcnQgY29uc3QgQ29ycmVjdCA9IEJ1aWxkSW5kaWNhdG9yKGljb25zLkNvcnJlY3QsICdjb3JyZWN0Jyk7XG5leHBvcnQgY29uc3QgSW5jb3JyZWN0ID0gQnVpbGRJbmRpY2F0b3IoaWNvbnMuSW5jb3JyZWN0LCAnaW5jb3JyZWN0Jyk7XG5leHBvcnQgY29uc3QgUGFydGlhbGx5Q29ycmVjdCA9IEJ1aWxkSW5kaWNhdG9yKGljb25zLlBhcnRpYWxseUNvcnJlY3QsICdwYXJ0aWFsbHktY29ycmVjdCcpO1xuZXhwb3J0IGNvbnN0IE5vdGhpbmdTdWJtaXR0ZWQgPSBCdWlsZEluZGljYXRvcihpY29ucy5Ob3RoaW5nU3VibWl0dGVkLCAnbm90aGluZy1zdWJtaXR0ZWQnKTtcbiJdfQ==
@@ -0,0 +1,122 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+
5
+ Object.defineProperty(exports, "__esModule", {
6
+ value: true
7
+ });
8
+ exports["default"] = void 0;
9
+
10
+ var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
11
+
12
+ var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties"));
13
+
14
+ var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
15
+
16
+ var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));
17
+
18
+ var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits"));
19
+
20
+ var _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime/helpers/possibleConstructorReturn"));
21
+
22
+ var _getPrototypeOf2 = _interopRequireDefault(require("@babel/runtime/helpers/getPrototypeOf"));
23
+
24
+ var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
25
+
26
+ var _react = _interopRequireDefault(require("react"));
27
+
28
+ var _styles = require("@material-ui/core/styles");
29
+
30
+ var _propTypes = _interopRequireDefault(require("prop-types"));
31
+
32
+ var _classnames = _interopRequireDefault(require("classnames"));
33
+
34
+ var _appendCssRules = _interopRequireDefault(require("./append-css-rules"));
35
+
36
+ var _excluded = ["children", "className", "classes", "fontSizeFactor"],
37
+ _excluded2 = ["extraCSSRules"];
38
+
39
+ function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = (0, _getPrototypeOf2["default"])(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = (0, _getPrototypeOf2["default"])(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return (0, _possibleConstructorReturn2["default"])(this, result); }; }
40
+
41
+ function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); return true; } catch (e) { return false; } }
42
+
43
+ var UiLayout = /*#__PURE__*/function (_AppendCSSRules) {
44
+ (0, _inherits2["default"])(UiLayout, _AppendCSSRules);
45
+
46
+ var _super = _createSuper(UiLayout);
47
+
48
+ function UiLayout(props) {
49
+ var _this;
50
+
51
+ (0, _classCallCheck2["default"])(this, UiLayout);
52
+ _this = _super.call(this, props);
53
+ _this.classesSheet = document.createElement('style');
54
+ return _this;
55
+ }
56
+
57
+ (0, _createClass2["default"])(UiLayout, [{
58
+ key: "computeStyle",
59
+ value: function computeStyle(fontSizeFactor) {
60
+ var getFontSize = function getFontSize(element) {
61
+ return parseFloat(getComputedStyle(element).fontSize);
62
+ };
63
+
64
+ var rootFontSize = getFontSize(document.documentElement);
65
+ var bodyFontSize = getFontSize(document.body);
66
+ var effectiveFontSize = Math.max(rootFontSize, bodyFontSize);
67
+ return fontSizeFactor !== 1 ? {
68
+ fontSize: "".concat(effectiveFontSize * fontSizeFactor, "px")
69
+ } : null;
70
+ }
71
+ }, {
72
+ key: "render",
73
+ value: function render() {
74
+ var _this$props = this.props,
75
+ children = _this$props.children,
76
+ className = _this$props.className,
77
+ classes = _this$props.classes,
78
+ fontSizeFactor = _this$props.fontSizeFactor,
79
+ rest = (0, _objectWithoutProperties2["default"])(_this$props, _excluded);
80
+ var finalClass = (0, _classnames["default"])(className, classes.extraCSSRules, classes.uiLayoutContainer);
81
+ var extraCSSRules = rest.extraCSSRules,
82
+ restProps = (0, _objectWithoutProperties2["default"])(rest, _excluded2);
83
+ var style = this.computeStyle(fontSizeFactor);
84
+ return /*#__PURE__*/_react["default"].createElement("div", (0, _extends2["default"])({
85
+ className: finalClass
86
+ }, restProps, style && {
87
+ style: style
88
+ }), children);
89
+ }
90
+ }]);
91
+ return UiLayout;
92
+ }(_appendCssRules["default"]);
93
+
94
+ (0, _defineProperty2["default"])(UiLayout, "propTypes", {
95
+ classes: _propTypes["default"].object,
96
+ className: _propTypes["default"].string,
97
+ children: _propTypes["default"].array,
98
+ extraCSSRules: _propTypes["default"].shape({
99
+ names: _propTypes["default"].arrayOf(_propTypes["default"].string),
100
+ rules: _propTypes["default"].string
101
+ }),
102
+ fontSizeFactor: _propTypes["default"].number
103
+ });
104
+ (0, _defineProperty2["default"])(UiLayout, "defaultProps", {
105
+ extraCSSRules: {},
106
+ fontSizeFactor: 1
107
+ });
108
+ var styles = {
109
+ extraCSSRules: {},
110
+ // need this because some browsers set their own style on table
111
+ uiLayoutContainer: {
112
+ '& table, th, td': {
113
+ fontSize: 'inherit'
114
+ /* Ensure table elements inherit font size */
115
+
116
+ }
117
+ }
118
+ };
119
+ var Styled = (0, _styles.withStyles)(styles)(UiLayout);
120
+ var _default = Styled;
121
+ exports["default"] = _default;
122
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy91aS1sYXlvdXQuanN4Il0sIm5hbWVzIjpbIlVpTGF5b3V0IiwicHJvcHMiLCJjbGFzc2VzU2hlZXQiLCJkb2N1bWVudCIsImNyZWF0ZUVsZW1lbnQiLCJmb250U2l6ZUZhY3RvciIsImdldEZvbnRTaXplIiwiZWxlbWVudCIsInBhcnNlRmxvYXQiLCJnZXRDb21wdXRlZFN0eWxlIiwiZm9udFNpemUiLCJyb290Rm9udFNpemUiLCJkb2N1bWVudEVsZW1lbnQiLCJib2R5Rm9udFNpemUiLCJib2R5IiwiZWZmZWN0aXZlRm9udFNpemUiLCJNYXRoIiwibWF4IiwiY2hpbGRyZW4iLCJjbGFzc05hbWUiLCJjbGFzc2VzIiwicmVzdCIsImZpbmFsQ2xhc3MiLCJleHRyYUNTU1J1bGVzIiwidWlMYXlvdXRDb250YWluZXIiLCJyZXN0UHJvcHMiLCJzdHlsZSIsImNvbXB1dGVTdHlsZSIsIkFwcGVuZENTU1J1bGVzIiwiUHJvcFR5cGVzIiwib2JqZWN0Iiwic3RyaW5nIiwiYXJyYXkiLCJzaGFwZSIsIm5hbWVzIiwiYXJyYXlPZiIsInJ1bGVzIiwibnVtYmVyIiwic3R5bGVzIiwiU3R5bGVkIl0sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBQUE7O0FBQ0E7O0FBQ0E7O0FBQ0E7O0FBQ0E7Ozs7Ozs7OztJQUVNQSxROzs7OztBQWlCSixvQkFBWUMsS0FBWixFQUFtQjtBQUFBOztBQUFBO0FBQ2pCLDhCQUFNQSxLQUFOO0FBQ0EsVUFBS0MsWUFBTCxHQUFvQkMsUUFBUSxDQUFDQyxhQUFULENBQXVCLE9BQXZCLENBQXBCO0FBRmlCO0FBR2xCOzs7O1dBRUQsc0JBQWFDLGNBQWIsRUFBNkI7QUFDM0IsVUFBTUMsV0FBVyxHQUFHLFNBQWRBLFdBQWMsQ0FBQ0MsT0FBRDtBQUFBLGVBQWFDLFVBQVUsQ0FBQ0MsZ0JBQWdCLENBQUNGLE9BQUQsQ0FBaEIsQ0FBMEJHLFFBQTNCLENBQXZCO0FBQUEsT0FBcEI7O0FBRUEsVUFBTUMsWUFBWSxHQUFHTCxXQUFXLENBQUNILFFBQVEsQ0FBQ1MsZUFBVixDQUFoQztBQUNBLFVBQU1DLFlBQVksR0FBR1AsV0FBVyxDQUFDSCxRQUFRLENBQUNXLElBQVYsQ0FBaEM7QUFDQSxVQUFNQyxpQkFBaUIsR0FBR0MsSUFBSSxDQUFDQyxHQUFMLENBQVNOLFlBQVQsRUFBdUJFLFlBQXZCLENBQTFCO0FBRUEsYUFBT1IsY0FBYyxLQUFLLENBQW5CLEdBQXVCO0FBQUVLLFFBQUFBLFFBQVEsWUFBS0ssaUJBQWlCLEdBQUdWLGNBQXpCO0FBQVYsT0FBdkIsR0FBaUYsSUFBeEY7QUFDRDs7O1dBRUQsa0JBQVM7QUFDUCx3QkFBa0UsS0FBS0osS0FBdkU7QUFBQSxVQUFRaUIsUUFBUixlQUFRQSxRQUFSO0FBQUEsVUFBa0JDLFNBQWxCLGVBQWtCQSxTQUFsQjtBQUFBLFVBQTZCQyxPQUE3QixlQUE2QkEsT0FBN0I7QUFBQSxVQUFzQ2YsY0FBdEMsZUFBc0NBLGNBQXRDO0FBQUEsVUFBeURnQixJQUF6RDtBQUVBLFVBQU1DLFVBQVUsR0FBRyw0QkFBV0gsU0FBWCxFQUFzQkMsT0FBTyxDQUFDRyxhQUE5QixFQUE2Q0gsT0FBTyxDQUFDSSxpQkFBckQsQ0FBbkI7QUFDQSxVQUFRRCxhQUFSLEdBQXdDRixJQUF4QyxDQUFRRSxhQUFSO0FBQUEsVUFBMEJFLFNBQTFCLDZDQUF3Q0osSUFBeEM7QUFDQSxVQUFNSyxLQUFLLEdBQUcsS0FBS0MsWUFBTCxDQUFrQnRCLGNBQWxCLENBQWQ7QUFFQSwwQkFDRTtBQUFLLFFBQUEsU0FBUyxFQUFFaUI7QUFBaEIsU0FBZ0NHLFNBQWhDLEVBQWdEQyxLQUFLLElBQUk7QUFBRUEsUUFBQUEsS0FBSyxFQUFMQTtBQUFGLE9BQXpELEdBQ0dSLFFBREgsQ0FERjtBQUtEOzs7RUE1Q29CVSwwQjs7aUNBQWpCNUIsUSxlQUNlO0FBQ2pCb0IsRUFBQUEsT0FBTyxFQUFFUyxzQkFBVUMsTUFERjtBQUVqQlgsRUFBQUEsU0FBUyxFQUFFVSxzQkFBVUUsTUFGSjtBQUdqQmIsRUFBQUEsUUFBUSxFQUFFVyxzQkFBVUcsS0FISDtBQUlqQlQsRUFBQUEsYUFBYSxFQUFFTSxzQkFBVUksS0FBVixDQUFnQjtBQUM3QkMsSUFBQUEsS0FBSyxFQUFFTCxzQkFBVU0sT0FBVixDQUFrQk4sc0JBQVVFLE1BQTVCLENBRHNCO0FBRTdCSyxJQUFBQSxLQUFLLEVBQUVQLHNCQUFVRTtBQUZZLEdBQWhCLENBSkU7QUFRakIxQixFQUFBQSxjQUFjLEVBQUV3QixzQkFBVVE7QUFSVCxDO2lDQURmckMsUSxrQkFZa0I7QUFDcEJ1QixFQUFBQSxhQUFhLEVBQUUsRUFESztBQUVwQmxCLEVBQUFBLGNBQWMsRUFBRTtBQUZJLEM7QUFtQ3hCLElBQU1pQyxNQUFNLEdBQUc7QUFDYmYsRUFBQUEsYUFBYSxFQUFFLEVBREY7QUFFYjtBQUNBQyxFQUFBQSxpQkFBaUIsRUFBRTtBQUNqQix1QkFBbUI7QUFDakJkLE1BQUFBLFFBQVEsRUFBRTtBQUFVOztBQURIO0FBREY7QUFITixDQUFmO0FBVUEsSUFBTTZCLE1BQU0sR0FBRyx3QkFBV0QsTUFBWCxFQUFtQnRDLFFBQW5CLENBQWY7ZUFFZXVDLE0iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QgZnJvbSAncmVhY3QnO1xuaW1wb3J0IHsgd2l0aFN0eWxlcyB9IGZyb20gJ0BtYXRlcmlhbC11aS9jb3JlL3N0eWxlcyc7XG5pbXBvcnQgUHJvcFR5cGVzIGZyb20gJ3Byb3AtdHlwZXMnO1xuaW1wb3J0IGNsYXNzTmFtZXMgZnJvbSAnY2xhc3NuYW1lcyc7XG5pbXBvcnQgQXBwZW5kQ1NTUnVsZXMgZnJvbSAnLi9hcHBlbmQtY3NzLXJ1bGVzJztcblxuY2xhc3MgVWlMYXlvdXQgZXh0ZW5kcyBBcHBlbmRDU1NSdWxlcyB7XG4gIHN0YXRpYyBwcm9wVHlwZXMgPSB7XG4gICAgY2xhc3NlczogUHJvcFR5cGVzLm9iamVjdCxcbiAgICBjbGFzc05hbWU6IFByb3BUeXBlcy5zdHJpbmcsXG4gICAgY2hpbGRyZW46IFByb3BUeXBlcy5hcnJheSxcbiAgICBleHRyYUNTU1J1bGVzOiBQcm9wVHlwZXMuc2hhcGUoe1xuICAgICAgbmFtZXM6IFByb3BUeXBlcy5hcnJheU9mKFByb3BUeXBlcy5zdHJpbmcpLFxuICAgICAgcnVsZXM6IFByb3BUeXBlcy5zdHJpbmcsXG4gICAgfSksXG4gICAgZm9udFNpemVGYWN0b3I6IFByb3BUeXBlcy5udW1iZXIsXG4gIH07XG5cbiAgc3RhdGljIGRlZmF1bHRQcm9wcyA9IHtcbiAgICBleHRyYUNTU1J1bGVzOiB7fSxcbiAgICBmb250U2l6ZUZhY3RvcjogMSxcbiAgfTtcblxuICBjb25zdHJ1Y3Rvcihwcm9wcykge1xuICAgIHN1cGVyKHByb3BzKTtcbiAgICB0aGlzLmNsYXNzZXNTaGVldCA9IGRvY3VtZW50LmNyZWF0ZUVsZW1lbnQoJ3N0eWxlJyk7XG4gIH1cblxuICBjb21wdXRlU3R5bGUoZm9udFNpemVGYWN0b3IpIHtcbiAgICBjb25zdCBnZXRGb250U2l6ZSA9IChlbGVtZW50KSA9PiBwYXJzZUZsb2F0KGdldENvbXB1dGVkU3R5bGUoZWxlbWVudCkuZm9udFNpemUpO1xuXG4gICAgY29uc3Qgcm9vdEZvbnRTaXplID0gZ2V0Rm9udFNpemUoZG9jdW1lbnQuZG9jdW1lbnRFbGVtZW50KTtcbiAgICBjb25zdCBib2R5Rm9udFNpemUgPSBnZXRGb250U2l6ZShkb2N1bWVudC5ib2R5KTtcbiAgICBjb25zdCBlZmZlY3RpdmVGb250U2l6ZSA9IE1hdGgubWF4KHJvb3RGb250U2l6ZSwgYm9keUZvbnRTaXplKTtcblxuICAgIHJldHVybiBmb250U2l6ZUZhY3RvciAhPT0gMSA/IHsgZm9udFNpemU6IGAke2VmZmVjdGl2ZUZvbnRTaXplICogZm9udFNpemVGYWN0b3J9cHhgIH0gOiBudWxsO1xuICB9XG5cbiAgcmVuZGVyKCkge1xuICAgIGNvbnN0IHsgY2hpbGRyZW4sIGNsYXNzTmFtZSwgY2xhc3NlcywgZm9udFNpemVGYWN0b3IsIC4uLnJlc3QgfSA9IHRoaXMucHJvcHM7XG5cbiAgICBjb25zdCBmaW5hbENsYXNzID0gY2xhc3NOYW1lcyhjbGFzc05hbWUsIGNsYXNzZXMuZXh0cmFDU1NSdWxlcywgY2xhc3Nlcy51aUxheW91dENvbnRhaW5lcik7XG4gICAgY29uc3QgeyBleHRyYUNTU1J1bGVzLCAuLi5yZXN0UHJvcHMgfSA9IHJlc3Q7XG4gICAgY29uc3Qgc3R5bGUgPSB0aGlzLmNvbXB1dGVTdHlsZShmb250U2l6ZUZhY3Rvcik7XG5cbiAgICByZXR1cm4gKFxuICAgICAgPGRpdiBjbGFzc05hbWU9e2ZpbmFsQ2xhc3N9IHsuLi5yZXN0UHJvcHN9IHsuLi4oc3R5bGUgJiYgeyBzdHlsZSB9KX0+XG4gICAgICAgIHtjaGlsZHJlbn1cbiAgICAgIDwvZGl2PlxuICAgICk7XG4gIH1cbn1cblxuY29uc3Qgc3R5bGVzID0ge1xuICBleHRyYUNTU1J1bGVzOiB7fSxcbiAgLy8gbmVlZCB0aGlzIGJlY2F1c2Ugc29tZSBicm93c2VycyBzZXQgdGhlaXIgb3duIHN0eWxlIG9uIHRhYmxlXG4gIHVpTGF5b3V0Q29udGFpbmVyOiB7XG4gICAgJyYgdGFibGUsIHRoLCB0ZCc6IHtcbiAgICAgIGZvbnRTaXplOiAnaW5oZXJpdCcgLyogRW5zdXJlIHRhYmxlIGVsZW1lbnRzIGluaGVyaXQgZm9udCBzaXplICovLFxuICAgIH0sXG4gIH0sXG59O1xuXG5jb25zdCBTdHlsZWQgPSB3aXRoU3R5bGVzKHN0eWxlcykoVWlMYXlvdXQpO1xuXG5leHBvcnQgZGVmYXVsdCBTdHlsZWQ7XG4iXX0=
@@ -178,4 +178,4 @@ var withUndoReset = function withUndoReset(WrappedComponent) {
178
178
 
179
179
  var _default = withUndoReset;
180
180
  exports["default"] = _default;
181
- //# sourceMappingURL=withUndoReset.js.map
181
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/withUndoReset.jsx"],"names":["styles","theme","wrapper","display","flexDirection","resetUndoContainer","alignItems","justifyContent","icon","width","height","color","marginRight","spacing","unit","buttonContainer","marginLeft","withUndoReset","WrappedComponent","WithUndoReset","props","session","setState","state","changes","onSessionChange","newChanges","pop","length","sessionInitialValues","JSON","parse","stringify","classes","rest","onUndo","onReset","React","Component","PropTypes","object","func"],"mappings":"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","sourcesContent":["import * as React from 'react';\nimport PropTypes from 'prop-types';\nimport Button from '@material-ui/core/Button';\nimport { withStyles } from '@material-ui/core/styles';\nimport Restore from '@material-ui/icons/Restore';\nimport Undo from '@material-ui/icons/Undo';\n\nconst styles = (theme) => ({\n  wrapper: {\n    display: 'flex',\n    flexDirection: 'column',\n  },\n  resetUndoContainer: {\n    display: 'flex',\n    alignItems: 'center',\n    justifyContent: 'center',\n  },\n  icon: {\n    width: '24px',\n    height: '24px',\n    color: 'gray',\n    marginRight: theme.spacing.unit,\n  },\n  buttonContainer: {\n    display: 'flex',\n    alignItems: 'center',\n    marginLeft: theme.spacing.unit * 3,\n    marginRight: theme.spacing.unit * 3,\n  },\n});\n\n/**\n * HOC that adds undo and reset functionality for session values\n */\nconst withUndoReset = (WrappedComponent) => {\n  class WithUndoReset extends React.Component {\n    static propTypes = {\n      classes: PropTypes.object,\n      session: PropTypes.object,\n      onSessionChange: PropTypes.func,\n    };\n\n    constructor(props) {\n      super(props);\n\n      this.state = {\n        sessionInitialValues: JSON.parse(JSON.stringify(props.session)),\n        session: props.session,\n        changes: [],\n      };\n    }\n\n    onSessionChange = (session) => {\n      this.setState(\n        (state) => ({ session, changes: [...state.changes, session] }),\n        () => this.props.onSessionChange(session),\n      );\n    };\n\n    onUndo = () => {\n      this.setState(\n        (state) => {\n          const newChanges = [...state.changes];\n\n          newChanges.pop();\n\n          return {\n            changes: newChanges,\n            session: newChanges.length ? newChanges[newChanges.length - 1] : state.sessionInitialValues,\n          };\n        },\n        () => this.props.onSessionChange(this.state.session),\n      );\n    };\n\n    onReset = () => {\n      this.setState(\n        (state) => ({ session: state.sessionInitialValues, changes: [] }),\n        () => this.props.onSessionChange(this.state.sessionInitialValues),\n      );\n    };\n\n    render() {\n      const { classes, ...rest } = this.props;\n      const { changes, session } = this.state;\n\n      return (\n        <div className={classes.wrapper}>\n          <div className={classes.resetUndoContainer}>\n            <Button\n              className={classes.buttonContainer}\n              color=\"primary\"\n              disabled={changes.length === 0}\n              onClick={this.onUndo}\n            >\n              <Undo className={classes.icon} /> Undo\n            </Button>\n            <Button\n              className={classes.buttonContainer}\n              color=\"primary\"\n              disabled={changes.length === 0}\n              onClick={this.onReset}\n            >\n              <Restore className={classes.icon} /> Start Over\n            </Button>\n          </div>\n          <WrappedComponent {...rest} session={session} onSessionChange={this.onSessionChange} />\n        </div>\n      );\n    }\n  }\n\n  return withStyles(styles)(WithUndoReset);\n};\n\nexport default withUndoReset;\n"]}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@pie-lib/render-ui",
3
- "version": "4.15.9",
3
+ "version": "4.17.0-beta.0",
4
4
  "description": "Some shared ui elements when rendering - but not worthy of their own package yet.",
5
5
  "module": "src/index.js",
6
6
  "main": "lib/index.js",
@@ -11,8 +11,8 @@
11
11
  "dependencies": {
12
12
  "@material-ui/core": "^3.8.3",
13
13
  "@material-ui/icons": "^3.0.2",
14
- "@pie-lib/icons": "^2.4.43",
15
- "@pie-lib/math-rendering": "2.5.18",
14
+ "@pie-lib/icons": "^2.6.0-beta.0",
15
+ "@pie-lib/math-rendering": "^3.4.0-beta.0",
16
16
  "classnames": "^2.2.6",
17
17
  "debug": "^4.1.1",
18
18
  "prop-types": "^15.7.2",
@@ -26,5 +26,5 @@
26
26
  "react": "^16.8.1",
27
27
  "react-dom": "^16.8.1"
28
28
  },
29
- "gitHead": "9c15e6c0aa4c83e1018b9b1070c8dec4294e6ffe"
29
+ "gitHead": "3818c24530f62b5bb9be7a2c6aa5428f13a17e0a"
30
30
  }
@@ -0,0 +1,11 @@
1
+ // Jest Snapshot v1, https://goo.gl/fbAQLP
2
+
3
+ exports[`html-and-math render renders 1`] = `
4
+ <div
5
+ dangerouslySetInnerHTML={
6
+ Object {
7
+ "__html": "<p>hi</p>",
8
+ }
9
+ }
10
+ />
11
+ `;
@@ -0,0 +1,37 @@
1
+ // Jest Snapshot v1, https://goo.gl/fbAQLP
2
+
3
+ exports[`Prompt with Custom tag renders with custom tag "span" correctly renders 1`] = `
4
+ <PreviewPrompt
5
+ className="prompt"
6
+ classes={
7
+ Object {
8
+ "label": "PreviewPrompt-label-4",
9
+ "legend": "PreviewPrompt-legend-2",
10
+ "prompt": "PreviewPrompt-prompt-1",
11
+ "promptTable": "PreviewPrompt-promptTable-5",
12
+ "rationale": "PreviewPrompt-rationale-3",
13
+ }
14
+ }
15
+ onClick={[Function]}
16
+ prompt="Which of these northern European countries are EU members? <math><mstack><msrow><mn>111</mn></msrow><msline/></mstack></math>"
17
+ tagName="span"
18
+ />
19
+ `;
20
+
21
+ exports[`Prompt without Custom tag default class with markup renders 1`] = `
22
+ <PreviewPrompt
23
+ className=""
24
+ classes={
25
+ Object {
26
+ "label": "PreviewPrompt-label-4",
27
+ "legend": "PreviewPrompt-legend-2",
28
+ "prompt": "PreviewPrompt-prompt-1",
29
+ "promptTable": "PreviewPrompt-promptTable-5",
30
+ "rationale": "PreviewPrompt-rationale-3",
31
+ }
32
+ }
33
+ onClick={[Function]}
34
+ prompt="Which of these northern European countries are EU members? <math><mstack><msrow><mn>111</mn></msrow><msline/></mstack></math>"
35
+ tagName=""
36
+ />
37
+ `;
@@ -0,0 +1,42 @@
1
+ // Jest Snapshot v1, https://goo.gl/fbAQLP
2
+
3
+ exports[`Purpose renders fine renders child unaltered 1`] = `
4
+ <Purpose
5
+ purpose="passage"
6
+ >
7
+ <div
8
+ data-pie-purpose="passage"
9
+ key=".0"
10
+ >
11
+ text
12
+ </div>
13
+ </Purpose>
14
+ `;
15
+
16
+ exports[`Purpose renders fine renders child unaltered without purpose prop 1`] = `
17
+ <Purpose>
18
+ <div
19
+ key=".0"
20
+ >
21
+ text
22
+ </div>
23
+ </Purpose>
24
+ `;
25
+
26
+ exports[`Purpose renders fine renders children unaltered 1`] = `
27
+ <Purpose
28
+ purpose="something"
29
+ >
30
+ <div
31
+ data-pie-purpose="something"
32
+ key=".0"
33
+ >
34
+ <div>
35
+ text1
36
+ </div>
37
+ <div>
38
+ text2
39
+ </div>
40
+ </div>
41
+ </Purpose>
42
+ `;