@codecademy/codebytes 0.7.3 → 0.7.4-alpha.1a54e4.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.
- package/CHANGELOG.md +243 -0
- package/dist/MonacoEditor/colorsDark.d.ts +32 -0
- package/dist/MonacoEditor/index.d.ts +7 -0
- package/dist/MonacoEditor/index.js +21 -36
- package/dist/MonacoEditor/theme.d.ts +2 -0
- package/dist/MonacoEditor/types.d.ts +1 -0
- package/dist/MonacoEditor/types.js +0 -1
- package/dist/__tests__/codebyte-test.d.ts +1 -0
- package/dist/__tests__/codebyte-test.js +155 -0
- package/dist/__tests__/editor-test.d.ts +1 -0
- package/dist/__tests__/editor-test.js +133 -0
- package/dist/__tests__/helpers-test.d.ts +1 -0
- package/dist/__tests__/{helpers.test.tsx → helpers-test.js} +16 -19
- package/dist/__tests__/language-selection-test.d.ts +1 -0
- package/dist/__tests__/language-selection-test.js +15 -0
- package/dist/__tests__/mocks.d.ts +0 -0
- package/dist/__tests__/mocks.js +13 -0
- package/dist/api.d.ts +12 -0
- package/dist/api.js +7 -5
- package/dist/codeByteEditor.d.ts +4 -0
- package/dist/codeByteEditor.js +73 -81
- package/dist/consts.d.ts +23 -0
- package/dist/consts.js +0 -3
- package/dist/drawers.d.ts +6 -0
- package/dist/drawers.js +81 -124
- package/dist/editor.d.ts +15 -0
- package/dist/editor.js +66 -107
- package/dist/helpers/index.d.ts +2 -0
- package/dist/helpers/index.js +7 -2
- package/dist/index.d.ts +3 -0
- package/dist/languageSelection.d.ts +6 -0
- package/dist/languageSelection.js +12 -30
- package/dist/libs/eventTracking.d.ts +1 -0
- package/dist/libs/eventTracking.js +1 -1
- package/dist/theme.d.ts +4 -0
- package/dist/types.d.ts +22 -0
- package/dist/types.js +0 -1
- package/package.json +48 -22
- package/dist/__tests__/codebyte.test.tsx +0 -179
- package/dist/__tests__/editor.test.tsx +0 -108
- package/dist/__tests__/language-selection.test.tsx +0 -14
- package/dist/theme.d.js +0 -1
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { createTracker } from '@codecademy/tracking';
|
|
2
|
-
var IS_DEV = process.env
|
|
2
|
+
var IS_DEV = process.env.NODE_ENV === 'development'; // TODO: confirm tracking details and implementation DISC-447
|
|
3
3
|
|
|
4
4
|
var tracker = createTracker({
|
|
5
5
|
apiBaseUrl: typeof window === 'undefined' ? 'https://www.codecademy.com' : window.location.origin,
|
package/dist/theme.d.ts
ADDED
package/dist/types.d.ts
ADDED
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import { BackgroundProps } from '@codecademy/gamut-styles';
|
|
2
|
+
import { UserClickData } from '@codecademy/tracking';
|
|
3
|
+
import { LanguageOption } from './consts';
|
|
4
|
+
export interface CodebytesChangeHandler {
|
|
5
|
+
(text: string, language: LanguageOption): void;
|
|
6
|
+
}
|
|
7
|
+
export interface CodebytesCopyFormatterParams {
|
|
8
|
+
text: string;
|
|
9
|
+
language: LanguageOption;
|
|
10
|
+
}
|
|
11
|
+
export declare type CodebytesCopyFormatter = ({ text, language, }: CodebytesCopyFormatterParams) => string;
|
|
12
|
+
export interface CodeByteEditorProps extends Omit<BackgroundProps, 'bg'> {
|
|
13
|
+
text?: string;
|
|
14
|
+
language?: LanguageOption;
|
|
15
|
+
hideCopyButton?: boolean;
|
|
16
|
+
copyFormatter?: CodebytesCopyFormatter;
|
|
17
|
+
snippetsBaseUrl?: string;
|
|
18
|
+
onEdit?: CodebytesChangeHandler;
|
|
19
|
+
onLanguageChange?: CodebytesChangeHandler;
|
|
20
|
+
trackingData?: Omit<UserClickData, 'target'>;
|
|
21
|
+
trackFirstEdit?: boolean;
|
|
22
|
+
}
|
package/dist/types.js
CHANGED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export {};
|
package/package.json
CHANGED
|
@@ -1,21 +1,20 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@codecademy/codebytes",
|
|
3
3
|
"description": "Codebytes Code Editor",
|
|
4
|
-
"version": "0.7.
|
|
4
|
+
"version": "0.7.4-alpha.1a54e4.0",
|
|
5
5
|
"author": "Codecademy Engineering <dev@codecademy.com>",
|
|
6
|
-
"
|
|
7
|
-
"
|
|
8
|
-
"
|
|
9
|
-
"
|
|
10
|
-
"
|
|
11
|
-
"jsuri": "^1.3.1"
|
|
12
|
-
},
|
|
13
|
-
"files": [
|
|
14
|
-
"dist/**"
|
|
6
|
+
"sideEffects": [
|
|
7
|
+
"**/*.css",
|
|
8
|
+
"**/*.scss",
|
|
9
|
+
"dist/**/[A-Z]**/[A-Z]*.js",
|
|
10
|
+
"dist/**/[A-Z]**/index.js"
|
|
15
11
|
],
|
|
16
|
-
"license": "MIT",
|
|
17
|
-
"main": "./dist/index.js",
|
|
18
12
|
"module": "./dist/index.js",
|
|
13
|
+
"main": "./dist/index.js",
|
|
14
|
+
"repository": {
|
|
15
|
+
"type": "git",
|
|
16
|
+
"url": "git@github.com:Codecademy/client-modules.git"
|
|
17
|
+
},
|
|
19
18
|
"peerDependencies": {
|
|
20
19
|
"@codecademy/gamut": "*",
|
|
21
20
|
"@codecademy/gamut-icons": "*",
|
|
@@ -25,18 +24,45 @@
|
|
|
25
24
|
"react": ">=16.8.1",
|
|
26
25
|
"react-dom": ">=16.8.1"
|
|
27
26
|
},
|
|
28
|
-
"
|
|
29
|
-
"
|
|
27
|
+
"dependencies": {
|
|
28
|
+
"@emotion/react": "^11.4.0",
|
|
29
|
+
"@emotion/styled": "^11.3.0",
|
|
30
|
+
"@monaco-editor/react": "4.3.1",
|
|
31
|
+
"js-base64": "^3.6.0",
|
|
32
|
+
"jsuri": "^1.3.1",
|
|
33
|
+
"monaco-editor": ">= 0.25.0 < 1",
|
|
34
|
+
"react-resize-observer": "^1.1.1"
|
|
30
35
|
},
|
|
31
|
-
"repository": "git@github.com:Codecademy/client-modules.git",
|
|
32
36
|
"scripts": {
|
|
33
|
-
"
|
|
37
|
+
"verify": "tsc --noEmit",
|
|
38
|
+
"build:compile": "babel ./src --out-dir ./dist --copy-files --extensions \".ts,.tsx\"",
|
|
39
|
+
"build:clean": "rm -rf dist",
|
|
40
|
+
"build:types": "tsc --emitDeclarationOnly",
|
|
41
|
+
"build": "yarn build:clean && yarn build:compile && yarn build:types",
|
|
42
|
+
"build:watch": "yarn build && onchange ./src -- yarn build:compile && yarn build:types"
|
|
34
43
|
},
|
|
35
|
-
"
|
|
36
|
-
|
|
37
|
-
"
|
|
38
|
-
"
|
|
39
|
-
"
|
|
44
|
+
"license": "MIT",
|
|
45
|
+
"devDependencies": {
|
|
46
|
+
"@codecademy/gamut": "*",
|
|
47
|
+
"@codecademy/gamut-icons": "*",
|
|
48
|
+
"@codecademy/gamut-styles": "*",
|
|
49
|
+
"@codecademy/gamut-tests": "*",
|
|
50
|
+
"@codecademy/tracking": "0.25.1-alpha.1a54e4.0",
|
|
51
|
+
"@codecademy/variance": "*",
|
|
52
|
+
"@emotion/jest": "^11.3.0",
|
|
53
|
+
"@testing-library/dom": "^7.31.2",
|
|
54
|
+
"@testing-library/react": "^11.0.4",
|
|
55
|
+
"@testing-library/react-hooks": "3.2.1",
|
|
56
|
+
"@testing-library/user-event": "13.1.1",
|
|
57
|
+
"@types/jsuri": "^1.3.30",
|
|
58
|
+
"@types/loadable__component": "^5.13.2",
|
|
59
|
+
"monaco-editor-webpack-plugin": "1.9.1"
|
|
60
|
+
},
|
|
61
|
+
"publishConfig": {
|
|
62
|
+
"access": "public"
|
|
63
|
+
},
|
|
64
|
+
"files": [
|
|
65
|
+
"dist/**"
|
|
40
66
|
],
|
|
41
|
-
"gitHead": "
|
|
67
|
+
"gitHead": "4a0521b0b5a28071423bb6f61f2f14ac1a8da09c"
|
|
42
68
|
}
|
|
@@ -1,179 +0,0 @@
|
|
|
1
|
-
import { setupRtl } from '@codecademy/gamut-tests';
|
|
2
|
-
import { act } from '@testing-library/react';
|
|
3
|
-
import userEvent from '@testing-library/user-event';
|
|
4
|
-
|
|
5
|
-
import { CodeByteEditor } from '..';
|
|
6
|
-
import { helloWorld, validLanguages } from '../consts';
|
|
7
|
-
import { trackClick } from '../helpers';
|
|
8
|
-
import { trackUserImpression } from '../libs/eventTracking';
|
|
9
|
-
|
|
10
|
-
const mockEditorTestId = 'mock-editor-test-id';
|
|
11
|
-
|
|
12
|
-
jest.mock('react-resize-observer');
|
|
13
|
-
jest.mock('../libs/eventTracking');
|
|
14
|
-
jest.mock('../helpers', () => ({
|
|
15
|
-
// eslint-disable-next-line @typescript-eslint/ban-ts-comment
|
|
16
|
-
// @ts-ignore
|
|
17
|
-
...jest.requireActual('../helpers'),
|
|
18
|
-
trackClick: jest.fn(),
|
|
19
|
-
}));
|
|
20
|
-
|
|
21
|
-
// This is a super simplified mock capable of render value and trigger onChange.
|
|
22
|
-
jest.mock('../MonacoEditor', () => ({
|
|
23
|
-
SimpleMonacoEditor: ({
|
|
24
|
-
value,
|
|
25
|
-
onChange,
|
|
26
|
-
}: {
|
|
27
|
-
value: string;
|
|
28
|
-
onChange?: (value: string) => void;
|
|
29
|
-
}) => (
|
|
30
|
-
<>
|
|
31
|
-
{value}
|
|
32
|
-
<input
|
|
33
|
-
data-testid={mockEditorTestId}
|
|
34
|
-
type="text"
|
|
35
|
-
onChange={(e) => {
|
|
36
|
-
onChange?.(e.target.value);
|
|
37
|
-
}}
|
|
38
|
-
value={value}
|
|
39
|
-
/>
|
|
40
|
-
</>
|
|
41
|
-
),
|
|
42
|
-
}));
|
|
43
|
-
|
|
44
|
-
const renderWrapper = setupRtl(CodeByteEditor, {});
|
|
45
|
-
|
|
46
|
-
describe('CodeBytes', () => {
|
|
47
|
-
const initialUrl = window.location.href;
|
|
48
|
-
|
|
49
|
-
afterEach(() => {
|
|
50
|
-
window.history.replaceState(null, '', initialUrl);
|
|
51
|
-
(trackClick as any).mockReset();
|
|
52
|
-
(trackUserImpression as any).mockReset();
|
|
53
|
-
});
|
|
54
|
-
|
|
55
|
-
it('has a language-specific "hello world" program defined for each language', () => {
|
|
56
|
-
validLanguages.forEach((language) => {
|
|
57
|
-
expect(helloWorld[language]).toBeDefined();
|
|
58
|
-
});
|
|
59
|
-
});
|
|
60
|
-
|
|
61
|
-
it('initializes with a language-specific "hello world" program when there is no language prop', async () => {
|
|
62
|
-
const { view } = renderWrapper();
|
|
63
|
-
const selectedLanguage = view.getByRole('combobox') as Element;
|
|
64
|
-
await act(async () => {
|
|
65
|
-
userEvent.selectOptions(selectedLanguage, ['javascript']);
|
|
66
|
-
});
|
|
67
|
-
view.getByText(helloWorld.javascript);
|
|
68
|
-
});
|
|
69
|
-
|
|
70
|
-
it('initializes with a language-specific "hello world" program when there is a language prop but no text prop', () => {
|
|
71
|
-
const { view } = renderWrapper({ language: 'javascript' });
|
|
72
|
-
view.getByText(helloWorld.javascript);
|
|
73
|
-
});
|
|
74
|
-
|
|
75
|
-
it('initializes with deserialized text when there is a text prop but no language prop', async () => {
|
|
76
|
-
const testString = 'yes hello';
|
|
77
|
-
const { view } = renderWrapper({ text: testString });
|
|
78
|
-
const selectedLanguage = view.getByRole('combobox') as Element;
|
|
79
|
-
await act(async () => {
|
|
80
|
-
userEvent.selectOptions(selectedLanguage, ['javascript']);
|
|
81
|
-
});
|
|
82
|
-
view.getByText(testString);
|
|
83
|
-
});
|
|
84
|
-
|
|
85
|
-
it('initializes with deserialized text when there is both a language and text prop', () => {
|
|
86
|
-
const testString = 'yes hello';
|
|
87
|
-
const { view } = renderWrapper({
|
|
88
|
-
text: testString,
|
|
89
|
-
language: 'javascript',
|
|
90
|
-
});
|
|
91
|
-
view.getByText(testString);
|
|
92
|
-
});
|
|
93
|
-
|
|
94
|
-
describe('Change Handlers', () => {
|
|
95
|
-
it('triggers onEdit on text edit', async () => {
|
|
96
|
-
const onEdit = jest.fn();
|
|
97
|
-
const { view } = renderWrapper({
|
|
98
|
-
text: '',
|
|
99
|
-
language: 'javascript',
|
|
100
|
-
onEdit,
|
|
101
|
-
});
|
|
102
|
-
|
|
103
|
-
const editor = view.getByTestId(mockEditorTestId);
|
|
104
|
-
await act(async () => {
|
|
105
|
-
userEvent.type(editor, 'dog');
|
|
106
|
-
});
|
|
107
|
-
expect(onEdit).toHaveBeenCalledTimes(3);
|
|
108
|
-
expect(onEdit).toHaveBeenLastCalledWith('dog', 'javascript');
|
|
109
|
-
});
|
|
110
|
-
|
|
111
|
-
it('triggers onLanguageChange on language selection', async () => {
|
|
112
|
-
const onLanguageChange = jest.fn();
|
|
113
|
-
const { view } = renderWrapper({
|
|
114
|
-
onLanguageChange,
|
|
115
|
-
});
|
|
116
|
-
|
|
117
|
-
const selectedLanguage = view.getByRole('combobox') as Element;
|
|
118
|
-
await act(async () => {
|
|
119
|
-
userEvent.selectOptions(selectedLanguage, ['javascript']);
|
|
120
|
-
});
|
|
121
|
-
expect(onLanguageChange).toHaveBeenCalledWith(
|
|
122
|
-
"console.log('Hello world!');",
|
|
123
|
-
'javascript'
|
|
124
|
-
);
|
|
125
|
-
});
|
|
126
|
-
});
|
|
127
|
-
|
|
128
|
-
describe('Tracking', () => {
|
|
129
|
-
it('triggers trackClick on clicking the logo', async () => {
|
|
130
|
-
const { view } = renderWrapper({});
|
|
131
|
-
const logo = view.getByLabelText('visit codecademy.com');
|
|
132
|
-
await act(async () => {
|
|
133
|
-
userEvent.click(logo);
|
|
134
|
-
});
|
|
135
|
-
expect(trackClick).toHaveBeenCalledWith('logo', undefined);
|
|
136
|
-
});
|
|
137
|
-
|
|
138
|
-
it('triggers trackClick on language selection', async () => {
|
|
139
|
-
const { view } = renderWrapper();
|
|
140
|
-
const selectedLanguage = view.getByRole('combobox') as Element;
|
|
141
|
-
await act(async () => {
|
|
142
|
-
userEvent.selectOptions(selectedLanguage, ['javascript']);
|
|
143
|
-
});
|
|
144
|
-
expect(trackClick).toHaveBeenCalledWith('lang_select', undefined);
|
|
145
|
-
});
|
|
146
|
-
|
|
147
|
-
it('triggers trackClick for the first edit', async () => {
|
|
148
|
-
const testString = 'original-value';
|
|
149
|
-
const { view } = renderWrapper({
|
|
150
|
-
text: testString,
|
|
151
|
-
language: 'javascript',
|
|
152
|
-
trackFirstEdit: true,
|
|
153
|
-
});
|
|
154
|
-
|
|
155
|
-
const editor = view.getByTestId(mockEditorTestId);
|
|
156
|
-
await act(async () => {
|
|
157
|
-
userEvent.type(editor, 'd');
|
|
158
|
-
});
|
|
159
|
-
expect(trackClick).toHaveBeenCalledWith('edit', undefined);
|
|
160
|
-
});
|
|
161
|
-
|
|
162
|
-
it('triggers trackUserImpression', () => {
|
|
163
|
-
renderWrapper({
|
|
164
|
-
text: 'some-value',
|
|
165
|
-
language: 'javascript',
|
|
166
|
-
trackingData: {
|
|
167
|
-
page_name: 'forum_compose',
|
|
168
|
-
context: 'https://discuss.codecademy.com/some-interesting/post',
|
|
169
|
-
},
|
|
170
|
-
});
|
|
171
|
-
|
|
172
|
-
expect(trackUserImpression).toHaveBeenCalledWith({
|
|
173
|
-
page_name: 'forum_compose',
|
|
174
|
-
context: 'https://discuss.codecademy.com/some-interesting/post',
|
|
175
|
-
target: 'codebyte',
|
|
176
|
-
});
|
|
177
|
-
});
|
|
178
|
-
});
|
|
179
|
-
});
|
|
@@ -1,108 +0,0 @@
|
|
|
1
|
-
import { setupRtl } from '@codecademy/gamut-tests';
|
|
2
|
-
import { act } from '@testing-library/react';
|
|
3
|
-
import userEvent from '@testing-library/user-event';
|
|
4
|
-
|
|
5
|
-
import { Editor } from '../editor';
|
|
6
|
-
import { trackClick } from '../helpers';
|
|
7
|
-
|
|
8
|
-
jest.mock('react-resize-observer');
|
|
9
|
-
jest.mock('../libs/eventTracking');
|
|
10
|
-
jest.mock('../helpers', () => ({
|
|
11
|
-
// eslint-disable-next-line @typescript-eslint/ban-ts-comment
|
|
12
|
-
// @ts-ignore
|
|
13
|
-
...jest.requireActual('../helpers'),
|
|
14
|
-
trackClick: jest.fn(),
|
|
15
|
-
}));
|
|
16
|
-
|
|
17
|
-
jest.mock('../MonacoEditor', () => ({
|
|
18
|
-
SimpleMonacoEditor: ({ value }: { value: string }) => value,
|
|
19
|
-
}));
|
|
20
|
-
|
|
21
|
-
const renderWrapper = setupRtl(Editor, {
|
|
22
|
-
hideCopyButton: false,
|
|
23
|
-
language: 'javascript',
|
|
24
|
-
text: 'hello world',
|
|
25
|
-
onChange: jest.fn(),
|
|
26
|
-
snippetsBaseUrl: '',
|
|
27
|
-
});
|
|
28
|
-
|
|
29
|
-
Object.defineProperty(navigator, 'clipboard', {
|
|
30
|
-
value: {
|
|
31
|
-
writeText: jest.fn().mockImplementation(() => Promise.resolve()),
|
|
32
|
-
},
|
|
33
|
-
});
|
|
34
|
-
|
|
35
|
-
describe('Editor', () => {
|
|
36
|
-
(global as any).fetch = jest.fn();
|
|
37
|
-
afterEach(() => {
|
|
38
|
-
(global as any).fetch.mockClear();
|
|
39
|
-
});
|
|
40
|
-
|
|
41
|
-
it('shows a prompt tooltip when the CodeByte has __not__ been copied via the button', () => {
|
|
42
|
-
const { view } = renderWrapper();
|
|
43
|
-
expect(view.queryByTestId('copy-confirmation-tooltip')).toBeFalsy();
|
|
44
|
-
view.getByTestId('copy-prompt-tooltip');
|
|
45
|
-
});
|
|
46
|
-
|
|
47
|
-
it('shows a confirmation tooltip when the CodeByte has been copied via the button', async () => {
|
|
48
|
-
const { view } = renderWrapper();
|
|
49
|
-
const copyBtn = view.getByTestId('copy-codebyte-btn');
|
|
50
|
-
await act(async () => {
|
|
51
|
-
userEvent.click(copyBtn as HTMLButtonElement);
|
|
52
|
-
});
|
|
53
|
-
expect(view.queryByTestId('copy-prompt-tooltip')).toBeFalsy();
|
|
54
|
-
view.getByTestId('copy-confirmation-tooltip');
|
|
55
|
-
});
|
|
56
|
-
|
|
57
|
-
it('hides the copy codebyte button if hideCopyButton prop is true"', () => {
|
|
58
|
-
const { view } = renderWrapper({
|
|
59
|
-
hideCopyButton: true,
|
|
60
|
-
});
|
|
61
|
-
expect(view.queryByTestId('copy-codebyte-btn')).toBeNull();
|
|
62
|
-
});
|
|
63
|
-
|
|
64
|
-
it('shows the copy codebyte button if hideCopyButton prop is not set', () => {
|
|
65
|
-
const { view } = renderWrapper();
|
|
66
|
-
|
|
67
|
-
view.getByTestId('copy-codebyte-btn');
|
|
68
|
-
});
|
|
69
|
-
|
|
70
|
-
describe('Tracking', () => {
|
|
71
|
-
it('tracks clicks on the run button', async () => {
|
|
72
|
-
(global as any).fetch.mockResolvedValue({
|
|
73
|
-
json: () =>
|
|
74
|
-
Promise.resolve({
|
|
75
|
-
stderr: [],
|
|
76
|
-
exit_code: 0,
|
|
77
|
-
stdout: '',
|
|
78
|
-
}),
|
|
79
|
-
});
|
|
80
|
-
const { view } = renderWrapper({
|
|
81
|
-
onChange: jest.fn(),
|
|
82
|
-
text: 'test',
|
|
83
|
-
language: 'javascript',
|
|
84
|
-
});
|
|
85
|
-
|
|
86
|
-
const runButton = view.getByText('Run');
|
|
87
|
-
await act(async () => {
|
|
88
|
-
userEvent.click(runButton);
|
|
89
|
-
});
|
|
90
|
-
|
|
91
|
-
expect(trackClick).toHaveBeenCalledWith('run', undefined);
|
|
92
|
-
});
|
|
93
|
-
|
|
94
|
-
it('tracks clicks on the copy codebyte button', async () => {
|
|
95
|
-
const { view } = renderWrapper({
|
|
96
|
-
onChange: jest.fn(),
|
|
97
|
-
text: 'test',
|
|
98
|
-
language: 'javascript',
|
|
99
|
-
});
|
|
100
|
-
|
|
101
|
-
const copyButton = view.getByTestId('copy-codebyte-btn');
|
|
102
|
-
await act(async () => {
|
|
103
|
-
userEvent.click(copyButton);
|
|
104
|
-
});
|
|
105
|
-
expect(trackClick).toHaveBeenCalledWith('copy', undefined);
|
|
106
|
-
});
|
|
107
|
-
});
|
|
108
|
-
});
|
|
@@ -1,14 +0,0 @@
|
|
|
1
|
-
import { setupRtl } from '@codecademy/gamut-tests';
|
|
2
|
-
|
|
3
|
-
import { LanguageSelection } from '../languageSelection';
|
|
4
|
-
|
|
5
|
-
const renderWrapper = setupRtl(LanguageSelection, {
|
|
6
|
-
onChange: () => null,
|
|
7
|
-
});
|
|
8
|
-
|
|
9
|
-
describe('LanguageSelection', () => {
|
|
10
|
-
it('has placeholder text', () => {
|
|
11
|
-
const { view } = renderWrapper();
|
|
12
|
-
view.getByText('Which language do you want to code in?');
|
|
13
|
-
});
|
|
14
|
-
});
|
package/dist/theme.d.js
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export {};
|