@khanacademy/perseus-editor 27.5.4 → 27.5.6
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.
|
@@ -87,7 +87,7 @@ declare const InteractiveGraph: {
|
|
|
87
87
|
hintProgressColor?: string;
|
|
88
88
|
canScrollPage?: boolean;
|
|
89
89
|
editorChangeDelay?: number;
|
|
90
|
-
flags?: Record<"new-radio-widget", boolean>;
|
|
90
|
+
flags?: Record<"new-radio-widget" | "image-widget-upgrade", boolean>;
|
|
91
91
|
}> & {
|
|
92
92
|
baseElements: NonNullable<Readonly<{
|
|
93
93
|
isArticle?: boolean;
|
|
@@ -122,7 +122,7 @@ declare const InteractiveGraph: {
|
|
|
122
122
|
hintProgressColor?: string;
|
|
123
123
|
canScrollPage?: boolean;
|
|
124
124
|
editorChangeDelay?: number;
|
|
125
|
-
flags?: Record<"new-radio-widget", boolean>;
|
|
125
|
+
flags?: Record<"new-radio-widget" | "image-widget-upgrade", boolean>;
|
|
126
126
|
}>["baseElements"]>;
|
|
127
127
|
canScrollPage: NonNullable<Readonly<{
|
|
128
128
|
isArticle?: boolean;
|
|
@@ -157,7 +157,7 @@ declare const InteractiveGraph: {
|
|
|
157
157
|
hintProgressColor?: string;
|
|
158
158
|
canScrollPage?: boolean;
|
|
159
159
|
editorChangeDelay?: number;
|
|
160
|
-
flags?: Record<"new-radio-widget", boolean>;
|
|
160
|
+
flags?: Record<"new-radio-widget" | "image-widget-upgrade", boolean>;
|
|
161
161
|
}>["canScrollPage"]>;
|
|
162
162
|
editorChangeDelay: NonNullable<Readonly<{
|
|
163
163
|
isArticle?: boolean;
|
|
@@ -192,7 +192,7 @@ declare const InteractiveGraph: {
|
|
|
192
192
|
hintProgressColor?: string;
|
|
193
193
|
canScrollPage?: boolean;
|
|
194
194
|
editorChangeDelay?: number;
|
|
195
|
-
flags?: Record<"new-radio-widget", boolean>;
|
|
195
|
+
flags?: Record<"new-radio-widget" | "image-widget-upgrade", boolean>;
|
|
196
196
|
}>["editorChangeDelay"]>;
|
|
197
197
|
groupAnnotator: NonNullable<Readonly<{
|
|
198
198
|
isArticle?: boolean;
|
|
@@ -227,7 +227,7 @@ declare const InteractiveGraph: {
|
|
|
227
227
|
hintProgressColor?: string;
|
|
228
228
|
canScrollPage?: boolean;
|
|
229
229
|
editorChangeDelay?: number;
|
|
230
|
-
flags?: Record<"new-radio-widget", boolean>;
|
|
230
|
+
flags?: Record<"new-radio-widget" | "image-widget-upgrade", boolean>;
|
|
231
231
|
}>["groupAnnotator"]>;
|
|
232
232
|
isArticle: NonNullable<Readonly<{
|
|
233
233
|
isArticle?: boolean;
|
|
@@ -262,7 +262,7 @@ declare const InteractiveGraph: {
|
|
|
262
262
|
hintProgressColor?: string;
|
|
263
263
|
canScrollPage?: boolean;
|
|
264
264
|
editorChangeDelay?: number;
|
|
265
|
-
flags?: Record<"new-radio-widget", boolean>;
|
|
265
|
+
flags?: Record<"new-radio-widget" | "image-widget-upgrade", boolean>;
|
|
266
266
|
}>["isArticle"]>;
|
|
267
267
|
isMobile: NonNullable<Readonly<{
|
|
268
268
|
isArticle?: boolean;
|
|
@@ -297,7 +297,7 @@ declare const InteractiveGraph: {
|
|
|
297
297
|
hintProgressColor?: string;
|
|
298
298
|
canScrollPage?: boolean;
|
|
299
299
|
editorChangeDelay?: number;
|
|
300
|
-
flags?: Record<"new-radio-widget", boolean>;
|
|
300
|
+
flags?: Record<"new-radio-widget" | "image-widget-upgrade", boolean>;
|
|
301
301
|
}>["isMobile"]>;
|
|
302
302
|
isMobileApp: NonNullable<Readonly<{
|
|
303
303
|
isArticle?: boolean;
|
|
@@ -332,7 +332,7 @@ declare const InteractiveGraph: {
|
|
|
332
332
|
hintProgressColor?: string;
|
|
333
333
|
canScrollPage?: boolean;
|
|
334
334
|
editorChangeDelay?: number;
|
|
335
|
-
flags?: Record<"new-radio-widget", boolean>;
|
|
335
|
+
flags?: Record<"new-radio-widget" | "image-widget-upgrade", boolean>;
|
|
336
336
|
}>["isMobileApp"]>;
|
|
337
337
|
onFocusChange: NonNullable<Readonly<{
|
|
338
338
|
isArticle?: boolean;
|
|
@@ -367,7 +367,7 @@ declare const InteractiveGraph: {
|
|
|
367
367
|
hintProgressColor?: string;
|
|
368
368
|
canScrollPage?: boolean;
|
|
369
369
|
editorChangeDelay?: number;
|
|
370
|
-
flags?: Record<"new-radio-widget", boolean>;
|
|
370
|
+
flags?: Record<"new-radio-widget" | "image-widget-upgrade", boolean>;
|
|
371
371
|
}>["onFocusChange"]>;
|
|
372
372
|
readOnly: NonNullable<Readonly<{
|
|
373
373
|
isArticle?: boolean;
|
|
@@ -402,7 +402,7 @@ declare const InteractiveGraph: {
|
|
|
402
402
|
hintProgressColor?: string;
|
|
403
403
|
canScrollPage?: boolean;
|
|
404
404
|
editorChangeDelay?: number;
|
|
405
|
-
flags?: Record<"new-radio-widget", boolean>;
|
|
405
|
+
flags?: Record<"new-radio-widget" | "image-widget-upgrade", boolean>;
|
|
406
406
|
}>["readOnly"]>;
|
|
407
407
|
setDrawingAreaAvailable: NonNullable<Readonly<{
|
|
408
408
|
isArticle?: boolean;
|
|
@@ -437,7 +437,7 @@ declare const InteractiveGraph: {
|
|
|
437
437
|
hintProgressColor?: string;
|
|
438
438
|
canScrollPage?: boolean;
|
|
439
439
|
editorChangeDelay?: number;
|
|
440
|
-
flags?: Record<"new-radio-widget", boolean>;
|
|
440
|
+
flags?: Record<"new-radio-widget" | "image-widget-upgrade", boolean>;
|
|
441
441
|
}>["setDrawingAreaAvailable"]>;
|
|
442
442
|
showAlignmentOptions: NonNullable<Readonly<{
|
|
443
443
|
isArticle?: boolean;
|
|
@@ -472,7 +472,7 @@ declare const InteractiveGraph: {
|
|
|
472
472
|
hintProgressColor?: string;
|
|
473
473
|
canScrollPage?: boolean;
|
|
474
474
|
editorChangeDelay?: number;
|
|
475
|
-
flags?: Record<"new-radio-widget", boolean>;
|
|
475
|
+
flags?: Record<"new-radio-widget" | "image-widget-upgrade", boolean>;
|
|
476
476
|
}>["showAlignmentOptions"]>;
|
|
477
477
|
}>;
|
|
478
478
|
keypadElement?: any;
|
|
@@ -754,7 +754,7 @@ declare const InteractiveGraph: {
|
|
|
754
754
|
hintProgressColor?: string;
|
|
755
755
|
canScrollPage?: boolean;
|
|
756
756
|
editorChangeDelay?: number;
|
|
757
|
-
flags?: Record<"new-radio-widget", boolean>;
|
|
757
|
+
flags?: Record<"new-radio-widget" | "image-widget-upgrade", boolean>;
|
|
758
758
|
}> & {
|
|
759
759
|
baseElements: NonNullable<Readonly<{
|
|
760
760
|
isArticle?: boolean;
|
|
@@ -789,7 +789,7 @@ declare const InteractiveGraph: {
|
|
|
789
789
|
hintProgressColor?: string;
|
|
790
790
|
canScrollPage?: boolean;
|
|
791
791
|
editorChangeDelay?: number;
|
|
792
|
-
flags?: Record<"new-radio-widget", boolean>;
|
|
792
|
+
flags?: Record<"new-radio-widget" | "image-widget-upgrade", boolean>;
|
|
793
793
|
}>["baseElements"]>;
|
|
794
794
|
canScrollPage: NonNullable<Readonly<{
|
|
795
795
|
isArticle?: boolean;
|
|
@@ -824,7 +824,7 @@ declare const InteractiveGraph: {
|
|
|
824
824
|
hintProgressColor?: string;
|
|
825
825
|
canScrollPage?: boolean;
|
|
826
826
|
editorChangeDelay?: number;
|
|
827
|
-
flags?: Record<"new-radio-widget", boolean>;
|
|
827
|
+
flags?: Record<"new-radio-widget" | "image-widget-upgrade", boolean>;
|
|
828
828
|
}>["canScrollPage"]>;
|
|
829
829
|
editorChangeDelay: NonNullable<Readonly<{
|
|
830
830
|
isArticle?: boolean;
|
|
@@ -859,7 +859,7 @@ declare const InteractiveGraph: {
|
|
|
859
859
|
hintProgressColor?: string;
|
|
860
860
|
canScrollPage?: boolean;
|
|
861
861
|
editorChangeDelay?: number;
|
|
862
|
-
flags?: Record<"new-radio-widget", boolean>;
|
|
862
|
+
flags?: Record<"new-radio-widget" | "image-widget-upgrade", boolean>;
|
|
863
863
|
}>["editorChangeDelay"]>;
|
|
864
864
|
groupAnnotator: NonNullable<Readonly<{
|
|
865
865
|
isArticle?: boolean;
|
|
@@ -894,7 +894,7 @@ declare const InteractiveGraph: {
|
|
|
894
894
|
hintProgressColor?: string;
|
|
895
895
|
canScrollPage?: boolean;
|
|
896
896
|
editorChangeDelay?: number;
|
|
897
|
-
flags?: Record<"new-radio-widget", boolean>;
|
|
897
|
+
flags?: Record<"new-radio-widget" | "image-widget-upgrade", boolean>;
|
|
898
898
|
}>["groupAnnotator"]>;
|
|
899
899
|
isArticle: NonNullable<Readonly<{
|
|
900
900
|
isArticle?: boolean;
|
|
@@ -929,7 +929,7 @@ declare const InteractiveGraph: {
|
|
|
929
929
|
hintProgressColor?: string;
|
|
930
930
|
canScrollPage?: boolean;
|
|
931
931
|
editorChangeDelay?: number;
|
|
932
|
-
flags?: Record<"new-radio-widget", boolean>;
|
|
932
|
+
flags?: Record<"new-radio-widget" | "image-widget-upgrade", boolean>;
|
|
933
933
|
}>["isArticle"]>;
|
|
934
934
|
isMobile: NonNullable<Readonly<{
|
|
935
935
|
isArticle?: boolean;
|
|
@@ -964,7 +964,7 @@ declare const InteractiveGraph: {
|
|
|
964
964
|
hintProgressColor?: string;
|
|
965
965
|
canScrollPage?: boolean;
|
|
966
966
|
editorChangeDelay?: number;
|
|
967
|
-
flags?: Record<"new-radio-widget", boolean>;
|
|
967
|
+
flags?: Record<"new-radio-widget" | "image-widget-upgrade", boolean>;
|
|
968
968
|
}>["isMobile"]>;
|
|
969
969
|
isMobileApp: NonNullable<Readonly<{
|
|
970
970
|
isArticle?: boolean;
|
|
@@ -999,7 +999,7 @@ declare const InteractiveGraph: {
|
|
|
999
999
|
hintProgressColor?: string;
|
|
1000
1000
|
canScrollPage?: boolean;
|
|
1001
1001
|
editorChangeDelay?: number;
|
|
1002
|
-
flags?: Record<"new-radio-widget", boolean>;
|
|
1002
|
+
flags?: Record<"new-radio-widget" | "image-widget-upgrade", boolean>;
|
|
1003
1003
|
}>["isMobileApp"]>;
|
|
1004
1004
|
onFocusChange: NonNullable<Readonly<{
|
|
1005
1005
|
isArticle?: boolean;
|
|
@@ -1034,7 +1034,7 @@ declare const InteractiveGraph: {
|
|
|
1034
1034
|
hintProgressColor?: string;
|
|
1035
1035
|
canScrollPage?: boolean;
|
|
1036
1036
|
editorChangeDelay?: number;
|
|
1037
|
-
flags?: Record<"new-radio-widget", boolean>;
|
|
1037
|
+
flags?: Record<"new-radio-widget" | "image-widget-upgrade", boolean>;
|
|
1038
1038
|
}>["onFocusChange"]>;
|
|
1039
1039
|
readOnly: NonNullable<Readonly<{
|
|
1040
1040
|
isArticle?: boolean;
|
|
@@ -1069,7 +1069,7 @@ declare const InteractiveGraph: {
|
|
|
1069
1069
|
hintProgressColor?: string;
|
|
1070
1070
|
canScrollPage?: boolean;
|
|
1071
1071
|
editorChangeDelay?: number;
|
|
1072
|
-
flags?: Record<"new-radio-widget", boolean>;
|
|
1072
|
+
flags?: Record<"new-radio-widget" | "image-widget-upgrade", boolean>;
|
|
1073
1073
|
}>["readOnly"]>;
|
|
1074
1074
|
setDrawingAreaAvailable: NonNullable<Readonly<{
|
|
1075
1075
|
isArticle?: boolean;
|
|
@@ -1104,7 +1104,7 @@ declare const InteractiveGraph: {
|
|
|
1104
1104
|
hintProgressColor?: string;
|
|
1105
1105
|
canScrollPage?: boolean;
|
|
1106
1106
|
editorChangeDelay?: number;
|
|
1107
|
-
flags?: Record<"new-radio-widget", boolean>;
|
|
1107
|
+
flags?: Record<"new-radio-widget" | "image-widget-upgrade", boolean>;
|
|
1108
1108
|
}>["setDrawingAreaAvailable"]>;
|
|
1109
1109
|
showAlignmentOptions: NonNullable<Readonly<{
|
|
1110
1110
|
isArticle?: boolean;
|
|
@@ -1139,7 +1139,7 @@ declare const InteractiveGraph: {
|
|
|
1139
1139
|
hintProgressColor?: string;
|
|
1140
1140
|
canScrollPage?: boolean;
|
|
1141
1141
|
editorChangeDelay?: number;
|
|
1142
|
-
flags?: Record<"new-radio-widget", boolean>;
|
|
1142
|
+
flags?: Record<"new-radio-widget" | "image-widget-upgrade", boolean>;
|
|
1143
1143
|
}>["showAlignmentOptions"]>;
|
|
1144
1144
|
}>;
|
|
1145
1145
|
keypadElement?: any;
|
|
@@ -18,8 +18,11 @@ export interface RadioEditorProps extends Changeable.ChangeableProps {
|
|
|
18
18
|
declare class RadioEditor extends React.Component<RadioEditorProps> {
|
|
19
19
|
static widgetName: "radio";
|
|
20
20
|
static defaultProps: RadioDefaultWidgetOptions;
|
|
21
|
+
componentDidMount(): void;
|
|
21
22
|
onMultipleSelectChange: (arg1: any) => any;
|
|
22
23
|
onCountChoicesChange: (arg1: any) => void;
|
|
24
|
+
generateChoiceId: (index: number) => string;
|
|
25
|
+
ensureValidIds: (choiceId: string, index: number) => string;
|
|
23
26
|
onChange: (arg1: any) => void;
|
|
24
27
|
onStatusChange: (choiceIndex: number, correct: boolean) => void;
|
|
25
28
|
onContentChange: (arg1: any, arg2: any) => void;
|
package/package.json
CHANGED
|
@@ -3,7 +3,7 @@
|
|
|
3
3
|
"description": "Perseus editors",
|
|
4
4
|
"author": "Khan Academy",
|
|
5
5
|
"license": "MIT",
|
|
6
|
-
"version": "27.5.
|
|
6
|
+
"version": "27.5.6",
|
|
7
7
|
"publishConfig": {
|
|
8
8
|
"access": "public"
|
|
9
9
|
},
|
|
@@ -35,36 +35,36 @@
|
|
|
35
35
|
"mafs": "^0.19.0",
|
|
36
36
|
"tiny-invariant": "1.3.1",
|
|
37
37
|
"@khanacademy/kas": "2.1.0",
|
|
38
|
-
"@khanacademy/
|
|
39
|
-
"@khanacademy/
|
|
40
|
-
"@khanacademy/math-input": "26.2.
|
|
41
|
-
"@khanacademy/perseus": "
|
|
42
|
-
"@khanacademy/perseus-core": "19.0.
|
|
43
|
-
"@khanacademy/perseus-linter": "4.3.
|
|
44
|
-
"@khanacademy/perseus-score": "7.7.
|
|
38
|
+
"@khanacademy/keypad-context": "3.2.5",
|
|
39
|
+
"@khanacademy/kmath": "2.2.5",
|
|
40
|
+
"@khanacademy/math-input": "26.2.5",
|
|
41
|
+
"@khanacademy/perseus": "69.0.1",
|
|
42
|
+
"@khanacademy/perseus-core": "19.0.3",
|
|
43
|
+
"@khanacademy/perseus-linter": "4.3.5",
|
|
44
|
+
"@khanacademy/perseus-score": "7.7.5",
|
|
45
45
|
"@khanacademy/perseus-utils": "2.1.0",
|
|
46
46
|
"@khanacademy/pure-markdown": "2.2.0"
|
|
47
47
|
},
|
|
48
48
|
"devDependencies": {
|
|
49
49
|
"@khanacademy/mathjax-renderer": "3.0.0",
|
|
50
|
-
"@khanacademy/wonder-blocks-accordion": "3.1.
|
|
51
|
-
"@khanacademy/wonder-blocks-banner": "4.
|
|
52
|
-
"@khanacademy/wonder-blocks-button": "11.
|
|
53
|
-
"@khanacademy/wonder-blocks-clickable": "7.1.
|
|
50
|
+
"@khanacademy/wonder-blocks-accordion": "3.1.39",
|
|
51
|
+
"@khanacademy/wonder-blocks-banner": "4.4.0",
|
|
52
|
+
"@khanacademy/wonder-blocks-button": "11.2.1",
|
|
53
|
+
"@khanacademy/wonder-blocks-clickable": "7.1.25",
|
|
54
54
|
"@khanacademy/wonder-blocks-core": "12.4.0",
|
|
55
|
-
"@khanacademy/wonder-blocks-dropdown": "10.3.
|
|
56
|
-
"@khanacademy/wonder-blocks-form": "7.3.
|
|
57
|
-
"@khanacademy/wonder-blocks-icon": "5.2.
|
|
58
|
-
"@khanacademy/wonder-blocks-icon-button": "10.
|
|
59
|
-
"@khanacademy/wonder-blocks-labeled-field": "4.0.
|
|
60
|
-
"@khanacademy/wonder-blocks-layout": "3.1.
|
|
61
|
-
"@khanacademy/wonder-blocks-link": "9.2.
|
|
62
|
-
"@khanacademy/wonder-blocks-pill": "3.1.
|
|
63
|
-
"@khanacademy/wonder-blocks-switch": "3.3.
|
|
55
|
+
"@khanacademy/wonder-blocks-dropdown": "10.3.11",
|
|
56
|
+
"@khanacademy/wonder-blocks-form": "7.3.7",
|
|
57
|
+
"@khanacademy/wonder-blocks-icon": "5.2.19",
|
|
58
|
+
"@khanacademy/wonder-blocks-icon-button": "10.5.0",
|
|
59
|
+
"@khanacademy/wonder-blocks-labeled-field": "4.0.5",
|
|
60
|
+
"@khanacademy/wonder-blocks-layout": "3.1.36",
|
|
61
|
+
"@khanacademy/wonder-blocks-link": "9.2.3",
|
|
62
|
+
"@khanacademy/wonder-blocks-pill": "3.1.40",
|
|
63
|
+
"@khanacademy/wonder-blocks-switch": "3.3.18",
|
|
64
64
|
"@khanacademy/wonder-blocks-timing": "7.0.2",
|
|
65
|
-
"@khanacademy/wonder-blocks-tokens": "
|
|
66
|
-
"@khanacademy/wonder-blocks-tooltip": "4.1.
|
|
67
|
-
"@khanacademy/wonder-blocks-typography": "4.2.
|
|
65
|
+
"@khanacademy/wonder-blocks-tokens": "13.0.0",
|
|
66
|
+
"@khanacademy/wonder-blocks-tooltip": "4.1.46",
|
|
67
|
+
"@khanacademy/wonder-blocks-typography": "4.2.21",
|
|
68
68
|
"@khanacademy/wonder-stuff-core": "1.5.5",
|
|
69
69
|
"@phosphor-icons/core": "2.0.2",
|
|
70
70
|
"aphrodite": "1.2.5",
|
|
@@ -79,24 +79,24 @@
|
|
|
79
79
|
},
|
|
80
80
|
"peerDependencies": {
|
|
81
81
|
"@khanacademy/mathjax-renderer": "^3.0.0",
|
|
82
|
-
"@khanacademy/wonder-blocks-accordion": "^3.1.
|
|
83
|
-
"@khanacademy/wonder-blocks-banner": "^4.
|
|
84
|
-
"@khanacademy/wonder-blocks-button": "^11.
|
|
85
|
-
"@khanacademy/wonder-blocks-clickable": "^7.1.
|
|
82
|
+
"@khanacademy/wonder-blocks-accordion": "^3.1.39",
|
|
83
|
+
"@khanacademy/wonder-blocks-banner": "^4.4.0",
|
|
84
|
+
"@khanacademy/wonder-blocks-button": "^11.2.1",
|
|
85
|
+
"@khanacademy/wonder-blocks-clickable": "^7.1.25",
|
|
86
86
|
"@khanacademy/wonder-blocks-core": "^12.4.0",
|
|
87
|
-
"@khanacademy/wonder-blocks-dropdown": "^10.3.
|
|
88
|
-
"@khanacademy/wonder-blocks-form": "^7.3.
|
|
89
|
-
"@khanacademy/wonder-blocks-icon": "^5.2.
|
|
90
|
-
"@khanacademy/wonder-blocks-icon-button": "^10.
|
|
91
|
-
"@khanacademy/wonder-blocks-labeled-field": "^4.0.
|
|
92
|
-
"@khanacademy/wonder-blocks-layout": "^3.1.
|
|
93
|
-
"@khanacademy/wonder-blocks-link": "^9.2.
|
|
94
|
-
"@khanacademy/wonder-blocks-pill": "^3.1.
|
|
95
|
-
"@khanacademy/wonder-blocks-switch": "^3.3.
|
|
87
|
+
"@khanacademy/wonder-blocks-dropdown": "^10.3.11",
|
|
88
|
+
"@khanacademy/wonder-blocks-form": "^7.3.7",
|
|
89
|
+
"@khanacademy/wonder-blocks-icon": "^5.2.19",
|
|
90
|
+
"@khanacademy/wonder-blocks-icon-button": "^10.5.0",
|
|
91
|
+
"@khanacademy/wonder-blocks-labeled-field": "^4.0.5",
|
|
92
|
+
"@khanacademy/wonder-blocks-layout": "^3.1.36",
|
|
93
|
+
"@khanacademy/wonder-blocks-link": "^9.2.3",
|
|
94
|
+
"@khanacademy/wonder-blocks-pill": "^3.1.40",
|
|
95
|
+
"@khanacademy/wonder-blocks-switch": "^3.3.18",
|
|
96
96
|
"@khanacademy/wonder-blocks-timing": "^7.0.2",
|
|
97
|
-
"@khanacademy/wonder-blocks-tokens": "^
|
|
98
|
-
"@khanacademy/wonder-blocks-tooltip": "^4.1.
|
|
99
|
-
"@khanacademy/wonder-blocks-typography": "^4.2.
|
|
97
|
+
"@khanacademy/wonder-blocks-tokens": "^13.0.0",
|
|
98
|
+
"@khanacademy/wonder-blocks-tooltip": "^4.1.46",
|
|
99
|
+
"@khanacademy/wonder-blocks-typography": "^4.2.21",
|
|
100
100
|
"@khanacademy/wonder-stuff-core": "^1.5.5",
|
|
101
101
|
"@phosphor-icons/core": "^2.0.2",
|
|
102
102
|
"aphrodite": "^1.2.5",
|