@pie-lib/render-ui 4.15.9 → 4.15.10-next.1639

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 (58) hide show
  1. package/CHANGELOG.json +1 -937
  2. package/CHANGELOG.md +183 -21
  3. package/NEXT.CHANGELOG.json +1 -0
  4. package/lib/append-css-rules.js +88 -0
  5. package/lib/append-css-rules.js.map +1 -0
  6. package/lib/assets/enableAudioAutoplayImage.js +9 -0
  7. package/lib/assets/enableAudioAutoplayImage.js.map +1 -0
  8. package/lib/collapsible/index.js +2 -1
  9. package/lib/collapsible/index.js.map +1 -1
  10. package/lib/color.js +189 -2
  11. package/lib/color.js.map +1 -1
  12. package/lib/feedback.js +0 -1
  13. package/lib/feedback.js.map +1 -1
  14. package/lib/has-media.js +27 -0
  15. package/lib/has-media.js.map +1 -0
  16. package/lib/has-text.js +6 -2
  17. package/lib/has-text.js.map +1 -1
  18. package/lib/html-and-math.js +0 -16
  19. package/lib/html-and-math.js.map +1 -1
  20. package/lib/index.js +32 -0
  21. package/lib/index.js.map +1 -1
  22. package/lib/preview-layout.js +16 -4
  23. package/lib/preview-layout.js.map +1 -1
  24. package/lib/preview-prompt.js +156 -41
  25. package/lib/preview-prompt.js.map +1 -1
  26. package/lib/ui-layout.js +122 -0
  27. package/lib/ui-layout.js.map +1 -0
  28. package/package.json +7 -4
  29. package/src/__tests__/__snapshots__/html-and-math.test.js.snap +11 -0
  30. package/src/__tests__/__snapshots__/preview-prompt.test.jsx.snap +37 -0
  31. package/src/__tests__/__snapshots__/purpose.test.jsx.snap +42 -0
  32. package/src/__tests__/__snapshots__/readable.test.jsx.snap +64 -0
  33. package/src/__tests__/__snapshots__/response-indicators.test.jsx.snap +27 -0
  34. package/src/__tests__/color.test.js +12 -0
  35. package/src/__tests__/has-media.test.js +20 -0
  36. package/src/__tests__/has-text.test.js +21 -0
  37. package/src/__tests__/html-and-math.test.js +24 -0
  38. package/src/__tests__/preview-prompt.test.jsx +56 -0
  39. package/src/__tests__/purpose.test.jsx +47 -0
  40. package/src/__tests__/readable.test.jsx +64 -0
  41. package/src/__tests__/response-indicators.test.jsx +16 -0
  42. package/src/__tests__/ui-layout.test.jsx +34 -0
  43. package/src/__tests__/withUndoReset.test.jsx +254 -0
  44. package/src/append-css-rules.js +51 -0
  45. package/src/assets/enableAudioAutoplayImage.js +1 -0
  46. package/src/collapsible/__tests__/__snapshots__/index.test.jsx.snap +18 -0
  47. package/src/collapsible/__tests__/index.test.jsx +13 -0
  48. package/src/collapsible/index.jsx +1 -0
  49. package/src/color.js +66 -0
  50. package/src/feedback.jsx +0 -1
  51. package/src/has-media.js +16 -0
  52. package/src/has-text.js +6 -2
  53. package/src/html-and-math.js +0 -13
  54. package/src/index.js +8 -0
  55. package/src/preview-layout.jsx +14 -3
  56. package/src/preview-prompt.jsx +150 -26
  57. package/src/ui-layout.jsx +66 -0
  58. package/README.md +0 -33
@@ -0,0 +1 @@
1
+ export default '';
@@ -0,0 +1,18 @@
1
+ // Jest Snapshot v1, https://goo.gl/fbAQLP
2
+
3
+ exports[`collapsible snapshot renders 1`] = `
4
+ <div>
5
+ <div
6
+ onClick={[Function]}
7
+ >
8
+ <span>
9
+ Show
10
+ </span>
11
+ </div>
12
+ <WithStyles(Collapse)
13
+ in={false}
14
+ timeout="auto"
15
+ unmountOnExit={true}
16
+ />
17
+ </div>
18
+ `;
@@ -0,0 +1,13 @@
1
+ import toJson from 'enzyme-to-json';
2
+ import { shallow } from 'enzyme/build';
3
+ import { Collapsible } from '../index';
4
+ import React from 'react';
5
+
6
+ describe('collapsible', () => {
7
+ describe('snapshot', () => {
8
+ it('renders', () => {
9
+ const wrapper = shallow(<Collapsible classes={{}} />);
10
+ expect(toJson(wrapper)).toMatchSnapshot();
11
+ });
12
+ });
13
+ });
@@ -56,6 +56,7 @@ export default withStyles((theme) => ({
56
56
  title: {
57
57
  color: theme.palette.primary.light,
58
58
  borderBottom: `1px dotted ${theme.palette.primary.light}`,
59
+ cursor: 'pointer',
59
60
  },
60
61
  collapsible: {
61
62
  paddingTop: theme.spacing.unit * 2,
package/src/color.js CHANGED
@@ -7,19 +7,48 @@ import red from '@material-ui/core/colors/red';
7
7
  export const defaults = {
8
8
  TEXT: 'black',
9
9
  DISABLED: 'grey',
10
+ DISABLED_SECONDARY: '#ABABAB',
10
11
  CORRECT: green[500],
11
12
  CORRECT_SECONDARY: green[50],
13
+ CORRECT_TERTIARY: '#0EA449',
14
+ CORRECT_WITH_ICON: '#087D38',
12
15
  INCORRECT: orange[500],
13
16
  INCORRECT_SECONDARY: red[50],
17
+ INCORRECT_WITH_ICON: '#BF0D00',
14
18
  MISSING: red[700],
19
+ MISSING_WITH_ICON: '#6A78A1',
15
20
  PRIMARY: indigo[500],
16
21
  PRIMARY_LIGHT: indigo[200],
17
22
  PRIMARY_DARK: indigo[800],
18
23
  SECONDARY: pink.A400,
19
24
  SECONDARY_LIGHT: pink[200],
20
25
  SECONDARY_DARK: pink[900],
26
+ TERTIARY: '#146EB3',
27
+ TERTIARY_LIGHT: '#D0E2F0',
21
28
  BACKGROUND: 'rgba(255,255,255,0)',
29
+ BACKGROUND_DARK: '#ECEDF1',
30
+ DROPDOWN_BACKGROUND: '#E0E1E6', // this is used for inline-dropdown
31
+ // this is only used for multi-trait-rubric, we might want to use BACKGROUND_DARK instead
22
32
  SECONDARY_BACKGROUND: 'rgba(241,241,241,1)',
33
+ BORDER: '#9A9A9A',
34
+ BORDER_LIGHT: '#D1D1D1',
35
+ BORDER_DARK: '#646464',
36
+ BORDER_GRAY: '#7E8494',
37
+ BLACK: '#000000',
38
+ WHITE: '#ffffff',
39
+ TRANSPARENT: 'transparent',
40
+ // this is used for multiple-choice accessibility
41
+ FOCUS_CHECKED: '#BBDEFB',
42
+ FOCUS_CHECKED_BORDER: '#1565C0',
43
+ FOCUS_UNCHECKED: '#E0E0E0',
44
+ FOCUS_UNCHECKED_BORDER: '#757575',
45
+ // this is used for select text tokens
46
+ BLUE_GREY100: '#F3F5F7',
47
+ BLUE_GREY300: '#C0C3CF',
48
+ BLUE_GREY600: '#7E8494',
49
+ BLUE_GREY900: '#152452',
50
+ // this is used for charting
51
+ FADED_PRIMARY: '#DCDAFB',
23
52
  };
24
53
 
25
54
  Object.freeze(defaults);
@@ -35,16 +64,22 @@ const pv = v('pie');
35
64
 
36
65
  export const text = () => pv('text', defaults.TEXT);
37
66
  export const disabled = () => pv('disabled', defaults.DISABLED);
67
+ export const disabledSecondary = () => pv('disabled-secondary', defaults.DISABLED_SECONDARY);
38
68
  export const correct = () => pv('correct', defaults.CORRECT);
39
69
  export const correctSecondary = () => pv('correct-secondary', defaults.CORRECT_SECONDARY);
70
+ export const correctTertiary = () => pv('correct-tertiary', defaults.CORRECT_TERTIARY);
71
+ export const correctWithIcon = () => pv('correct-icon', defaults.CORRECT_WITH_ICON);
40
72
  export const incorrect = () => pv('incorrect', defaults.INCORRECT);
73
+ export const incorrectWithIcon = () => pv('incorrect-icon', defaults.INCORRECT_WITH_ICON);
41
74
  export const incorrectSecondary = () => pv('incorrect-secondary', defaults.INCORRECT_SECONDARY);
42
75
  export const missing = () => pv('missing', defaults.MISSING);
76
+ export const missingWithIcon = () => pv('missing-icon', defaults.MISSING_WITH_ICON);
43
77
 
44
78
  export const primary = () => pv('primary', defaults.PRIMARY);
45
79
  export const primaryLight = () => pv('primary-light', defaults.PRIMARY_LIGHT);
46
80
  export const primaryDark = () => pv('primary-dark', defaults.PRIMARY_DARK);
47
81
  export const primaryText = () => pv('primary-text', 'text', defaults.TEXT);
82
+ export const fadedPrimary = () => pv('faded-primary', defaults.FADED_PRIMARY);
48
83
 
49
84
  export const secondary = () => pv('secondary', defaults.SECONDARY);
50
85
  export const secondaryLight = () => pv('secondary-light', defaults.SECONDARY_LIGHT);
@@ -52,4 +87,35 @@ export const secondaryDark = () => pv('secondary-dark', defaults.SECONDARY_DARK)
52
87
 
53
88
  export const secondaryText = () => pv('secondary-text', 'text', defaults.TEXT);
54
89
  export const background = () => pv('background', defaults.BACKGROUND);
90
+ export const backgroundDark = () => pv('background-dark', defaults.BACKGROUND_DARK);
55
91
  export const secondaryBackground = () => pv('secondary-background', defaults.SECONDARY_BACKGROUND);
92
+ export const dropdownBackground = () => pv('dropdown-background', defaults.DROPDOWN_BACKGROUND);
93
+
94
+ export const tertiary = () => pv('tertiary', defaults.TERTIARY);
95
+ export const tertiaryLight = () => pv('tertiary-light', defaults.TERTIARY_LIGHT);
96
+
97
+ export const border = () => pv('border', defaults.BORDER);
98
+ export const borderLight = () => pv('border-light', defaults.BORDER_LIGHT);
99
+ export const borderDark = () => pv('border-dark', defaults.BORDER_DARK);
100
+ export const borderGray = () => pv('border-gray', defaults.BORDER_GRAY);
101
+
102
+ export const black = () => pv('black', defaults.BLACK);
103
+ export const white = () => pv('white', defaults.WHITE);
104
+ export const transparent = () => defaults.TRANSPARENT;
105
+
106
+ export const focusChecked = () => pv('focus-checked', defaults.FOCUS_CHECKED);
107
+ export const focusCheckedBorder = () => pv('focus-checked-border', defaults.FOCUS_CHECKED_BORDER);
108
+ export const focusUnchecked = () => pv('focus-unchecked', defaults.FOCUS_UNCHECKED);
109
+ export const focusUncheckedBorder = () => pv('focus-unchecked-border', defaults.FOCUS_UNCHECKED_BORDER);
110
+
111
+ export const blueGrey100 = () => pv('blue-grey-100', defaults.BLUE_GREY100);
112
+ export const blueGrey300 = () => pv('blue-grey-300', defaults.BLUE_GREY300);
113
+ export const blueGrey600 = () => pv('blue-grey-600', defaults.BLUE_GREY600);
114
+ export const blueGrey900 = () => pv('blue-grey-900', defaults.BLUE_GREY900);
115
+
116
+ export const visualElementsColors = {
117
+ AXIS_LINE_COLOR: '#5A53C9',
118
+ ROLLOVER_FILL_BAR_COLOR: '#050F2D',
119
+ GRIDLINES_COLOR: '#8E88EA',
120
+ PLOT_FILL_COLOR: '#1463B3',
121
+ };
package/src/feedback.jsx CHANGED
@@ -24,7 +24,6 @@ const styleSheet = {
24
24
  backgroundColor: `var(--feedback-bg-color, ${color.disabled()})`,
25
25
  borderRadius: '4px',
26
26
  fontFamily: '"Roboto", "Noto", sans-serif',
27
- fontSize: '12px',
28
27
  lineHeight: '25px',
29
28
  margin: '0px',
30
29
  padding: '10px',
@@ -0,0 +1,16 @@
1
+ let parser;
2
+
3
+ if (typeof window !== 'undefined') {
4
+ parser = new DOMParser();
5
+ }
6
+
7
+ /*
8
+ * Check if the string contains at least one media element.
9
+ */
10
+ export const hasMedia = (s) => {
11
+ if (!s) {
12
+ return false;
13
+ }
14
+ const root = parser.parseFromString(s, 'text/html');
15
+ return !!root.body.querySelector('img') || !!root.body.querySelector('video') || !!root.body.querySelector('audio');
16
+ };
package/src/has-text.js CHANGED
@@ -1,7 +1,11 @@
1
- const dp = new DOMParser();
1
+ let parser;
2
+
3
+ if (typeof window !== 'undefined') {
4
+ parser = new DOMParser();
5
+ }
2
6
 
3
7
  const markupToText = (s) => {
4
- const root = dp.parseFromString(s, 'text/html');
8
+ const root = parser.parseFromString(s, 'text/html');
5
9
  return root.body.textContent;
6
10
  };
7
11
 
@@ -1,5 +1,4 @@
1
1
  import React from 'react';
2
- import { renderMath } from '@pie-lib/math-rendering';
3
2
  import PropTypes from 'prop-types';
4
3
 
5
4
  export default class HtmlAndMath extends React.Component {
@@ -14,18 +13,6 @@ export default class HtmlAndMath extends React.Component {
14
13
  html: '',
15
14
  };
16
15
 
17
- componentDidMount() {
18
- if (this.node) {
19
- renderMath(this.node);
20
- }
21
- }
22
-
23
- componentDidUpdate() {
24
- if (this.node) {
25
- renderMath(this.node);
26
- }
27
- }
28
-
29
16
  render() {
30
17
  const { tag, className, html } = this.props;
31
18
  const Tag = tag || 'div';
package/src/index.js CHANGED
@@ -3,6 +3,7 @@ import Feedback from './feedback';
3
3
  import Collapsible from './collapsible';
4
4
  import withUndoReset from './withUndoReset';
5
5
  import PreviewLayout from './preview-layout';
6
+ import UiLayout from './ui-layout';
6
7
  import HtmlAndMath from './html-and-math';
7
8
  import InputContainer from './input-container';
8
9
  import PreviewPrompt from './preview-prompt';
@@ -10,12 +11,17 @@ import Readable from './readable';
10
11
  import Purpose from './purpose';
11
12
  import * as color from './color';
12
13
  import { hasText } from './has-text';
14
+ import { hasMedia } from './has-media';
15
+ import EnableAudioAutoplayImage from './assets/enableAudioAutoplayImage';
16
+ import AppendCSSRules from './append-css-rules';
13
17
 
14
18
  export {
19
+ AppendCSSRules,
15
20
  HtmlAndMath,
16
21
  indicators,
17
22
  withUndoReset,
18
23
  Feedback,
24
+ UiLayout,
19
25
  PreviewLayout,
20
26
  Collapsible,
21
27
  InputContainer,
@@ -24,4 +30,6 @@ export {
24
30
  Readable,
25
31
  Purpose,
26
32
  hasText,
33
+ hasMedia,
34
+ EnableAudioAutoplayImage,
27
35
  };
@@ -1,6 +1,7 @@
1
1
  import React from 'react';
2
2
  import { withStyles, createMuiTheme, MuiThemeProvider } from '@material-ui/core/styles';
3
3
  import PropTypes from 'prop-types';
4
+ import UiLayout from './ui-layout';
4
5
 
5
6
  class PreviewLayout extends React.Component {
6
7
  static propTypes = {
@@ -8,16 +9,26 @@ class PreviewLayout extends React.Component {
8
9
  children: PropTypes.oneOfType([PropTypes.arrayOf(PropTypes.node), PropTypes.node]).isRequired,
9
10
  classes: PropTypes.object,
10
11
  role: PropTypes.string,
12
+ extraCSSRules: PropTypes.shape({
13
+ names: PropTypes.arrayOf(PropTypes.string),
14
+ rules: PropTypes.string,
15
+ }),
16
+ fontSizeFactor: PropTypes.number,
11
17
  };
12
18
 
13
19
  render() {
14
- const { children, classes, ariaLabel, role } = this.props;
20
+ const { children, classes, ariaLabel, role, extraCSSRules, fontSizeFactor } = this.props;
15
21
  const accessibility = ariaLabel ? { 'aria-label': ariaLabel, role } : {};
16
22
 
17
23
  return (
18
- <div className={classes.container} {...accessibility}>
24
+ <UiLayout
25
+ className={classes.container}
26
+ {...accessibility}
27
+ extraCSSRules={extraCSSRules}
28
+ fontSizeFactor={fontSizeFactor}
29
+ >
19
30
  {children}
20
- </div>
31
+ </UiLayout>
21
32
  );
22
33
  }
23
34
  }
@@ -15,6 +15,11 @@ export class PreviewPrompt extends Component {
15
15
  className: PropTypes.string,
16
16
  onClick: PropTypes.func,
17
17
  defaultClassName: PropTypes.string,
18
+ autoplayAudioEnabled: PropTypes.bool,
19
+ customAudioButton: {
20
+ playImage: PropTypes.string,
21
+ pauseImage: PropTypes.string,
22
+ },
18
23
  };
19
24
 
20
25
  static defaultProps = {
@@ -22,7 +27,7 @@ export class PreviewPrompt extends Component {
22
27
  };
23
28
 
24
29
  parsedText = (text) => {
25
- // fix imported audio content for Safari PD-1419
30
+ const { customAudioButton } = this.props;
26
31
  const div = document.createElement('div');
27
32
  div.innerHTML = text;
28
33
 
@@ -34,38 +39,150 @@ export class PreviewPrompt extends Component {
34
39
  source.setAttribute('src', audio.getAttribute('src'));
35
40
 
36
41
  audio.removeAttribute('src');
42
+ audio.setAttribute('id', 'pie-prompt-audio-player');
43
+
37
44
  audio.appendChild(source);
45
+
46
+ if (customAudioButton) {
47
+ audio.style.display = 'none';
48
+
49
+ const playButton = document.createElement('div');
50
+ playButton.id = 'play-audio-button';
51
+
52
+ Object.assign(playButton.style, {
53
+ cursor: 'pointer',
54
+ display: 'block',
55
+ width: '128px',
56
+ height: '128px',
57
+ backgroundImage: `url(${customAudioButton.pauseImage})`,
58
+ backgroundSize: 'cover',
59
+ borderRadius: '50%',
60
+ border: '1px solid #326295',
61
+ });
62
+
63
+ audio.parentNode.insertBefore(playButton, audio);
64
+ }
38
65
  }
39
66
 
40
67
  return div.innerHTML;
41
68
  };
42
69
 
70
+ addCustomAudioButtonControls() {
71
+ const { autoplayAudioEnabled, customAudioButton } = this.props;
72
+ const playButton = document.getElementById('play-audio-button');
73
+ const audio = document.getElementById('pie-prompt-audio-player');
74
+
75
+ if (autoplayAudioEnabled && audio) {
76
+ audio
77
+ .play()
78
+ .then(() => {
79
+ if (playButton && customAudioButton) {
80
+ audio.addEventListener('ended', handleAudioEnded);
81
+ }
82
+ })
83
+ .catch((error) => {
84
+ console.error('Error playing audio', error);
85
+ });
86
+ }
87
+
88
+ if (!playButton || !audio || !customAudioButton) return;
89
+
90
+ const handlePlayClick = () => {
91
+ // if already playing, don't play again
92
+ if (!audio.paused) return;
93
+ if (playButton.style.backgroundImage.includes(customAudioButton.pauseImage)) return;
94
+
95
+ audio.play();
96
+ };
97
+
98
+ const handleAudioEnded = () => {
99
+ playButton.style.backgroundImage = `url(${customAudioButton.playImage})`;
100
+ };
101
+
102
+ const handleAudioPlay = () => {
103
+ Object.assign(playButton.style, {
104
+ backgroundImage: `url(${customAudioButton.pauseImage})`,
105
+ border: '1px solid #ccc',
106
+ });
107
+ };
108
+
109
+ const handleAudioPause = () => {
110
+ Object.assign(playButton.style, {
111
+ backgroundImage: `url(${customAudioButton.playImage})`,
112
+ border: '1px solid #326295',
113
+ });
114
+ };
115
+
116
+ playButton.addEventListener('click', handlePlayClick);
117
+ audio.addEventListener('play', handleAudioPlay);
118
+ audio.addEventListener('pause', handleAudioPause);
119
+ audio.addEventListener('ended', handleAudioEnded);
120
+
121
+ // store event handler references so they can be removed later
122
+ this._handlePlayClick = handlePlayClick;
123
+ this._handleAudioPlay = handleAudioPlay;
124
+ this._handleAudioPause = handleAudioPause;
125
+ this._handleAudioEnded = handleAudioEnded;
126
+ }
127
+
128
+ removeCustomAudioButtonListeners() {
129
+ const playButton = document.getElementById('play-audio-button');
130
+ const audio = document.querySelector('audio');
131
+
132
+ if (!playButton || !audio) return;
133
+
134
+ // remove event listeners using stored references
135
+ playButton.removeEventListener('click', this._handlePlayClick);
136
+ audio.removeEventListener('play', this._handleAudioPlay);
137
+ audio.removeEventListener('pause', this._handleAudioPause);
138
+ audio.removeEventListener('ended', this._handleAudioEnded);
139
+ }
140
+
141
+ componentDidMount() {
142
+ this.alignImages();
143
+ this.addCustomAudioButtonControls();
144
+ }
145
+
43
146
  componentDidUpdate() {
44
- // set image parent style so it can be horizontally aligned
45
- const previewPrompt = document.querySelector('#preview-prompt');
46
- const images = previewPrompt && previewPrompt.getElementsByTagName('img');
47
-
48
- if (images && images.length) {
49
- for (let image of images) {
50
- // check if alignment property was set
51
- if (image.attributes && image.attributes.alignment && image.attributes.alignment.value) {
52
- const parentNode = image.parentElement;
53
-
54
- // check if div is not already added to dom and replace current image with wrapped image
55
- if (
56
- !(parentNode.tagName === 'DIV' && parentNode.style.display === 'flex' && parentNode.style.width === '100%')
57
- ) {
58
- const div = document.createElement('div');
59
- div.style.display = 'flex';
60
- div.style.width = '100%';
61
-
62
- const copyImage = image.cloneNode(true);
63
- div.appendChild(copyImage);
64
- parentNode.replaceChild(div, image);
147
+ this.alignImages();
148
+ }
149
+
150
+ componentWillUnmount() {
151
+ this.removeCustomAudioButtonListeners();
152
+ }
153
+
154
+ alignImages() {
155
+ const previewPrompts = document.querySelectorAll('#preview-prompt');
156
+
157
+ previewPrompts.forEach((previewPrompt) => {
158
+ const images = previewPrompt.getElementsByTagName('img');
159
+
160
+ if (images && images.length) {
161
+ for (let image of images) {
162
+ // check if alignment property was set
163
+ if (image.attributes && image.attributes.alignment && image.attributes.alignment.value) {
164
+ const parentNode = image.parentElement;
165
+
166
+ // check if div is not already added to dom and replace current image with wrapped image
167
+ if (
168
+ !(
169
+ parentNode.tagName === 'DIV' &&
170
+ parentNode.style.display === 'flex' &&
171
+ parentNode.style.width === '100%'
172
+ )
173
+ ) {
174
+ const div = document.createElement('div');
175
+ div.style.display = 'flex';
176
+ div.style.width = '100%';
177
+
178
+ const copyImage = image.cloneNode(true);
179
+ div.appendChild(copyImage);
180
+ parentNode.replaceChild(div, image);
181
+ }
65
182
  }
66
183
  }
67
184
  }
68
- }
185
+ });
69
186
  }
70
187
 
71
188
  render() {
@@ -105,7 +222,8 @@ const styles = (theme) => ({
105
222
  },
106
223
  label: {
107
224
  color: `${color.text()} !important`, //'var(--choice-input-color, black)',
108
- display: 'inline-block',
225
+ display: 'flex',
226
+ flexDirection: 'column',
109
227
  verticalAlign: 'middle',
110
228
  cursor: 'pointer',
111
229
  '& > p': {
@@ -119,11 +237,17 @@ const styles = (theme) => ({
119
237
  '&:not(.MathJax) > table tr': {
120
238
  '&:nth-child(2n)': {
121
239
  backgroundColor: '#f6f8fa',
240
+ color: theme.palette.common.black,
122
241
  },
123
242
  },
124
- '&:not(.MathJax) > table td, &:not(.MathJax) > table th': {
243
+ // align table content to left as per STAR requirement PD-3687
244
+ '&:not(.MathJax) table td, &:not(.MathJax) table th': {
125
245
  padding: '.6em 1em',
126
- textAlign: 'center',
246
+ textAlign: 'left',
247
+ },
248
+ // added this to fix alignment of text in prompt imported from studio (PD-3423)
249
+ '&:not(.MathJax) > table td > p.kds-indent': {
250
+ textAlign: 'initial',
127
251
  },
128
252
  },
129
253
  });