ink 4.4.1 → 5.0.1

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 (72) hide show
  1. package/build/apply-styles.js +175 -0
  2. package/build/build-layout.js +77 -0
  3. package/build/calculate-wrapped-text.js +53 -0
  4. package/build/colorize.js.map +1 -1
  5. package/build/components/App.d.ts +1 -1
  6. package/build/components/App.js +198 -296
  7. package/build/components/App.js.map +1 -1
  8. package/build/components/AppContext.js +1 -1
  9. package/build/components/Box.d.ts +51 -1
  10. package/build/components/Box.js +2 -2
  11. package/build/components/Color.js +62 -0
  12. package/build/components/ErrorOverview.js +1 -1
  13. package/build/components/ErrorOverview.js.map +1 -1
  14. package/build/components/FocusContext.js +1 -1
  15. package/build/components/Static.js +1 -1
  16. package/build/components/StderrContext.js +1 -1
  17. package/build/components/StdinContext.js +1 -1
  18. package/build/components/StdoutContext.js +1 -1
  19. package/build/components/Text.d.ts +1 -1
  20. package/build/components/Text.js +1 -1
  21. package/build/components/Text.js.map +1 -1
  22. package/build/components/Transform.js.map +1 -1
  23. package/build/devtools-window-polyfill.js +11 -17
  24. package/build/devtools-window-polyfill.js.map +1 -1
  25. package/build/dom.js +2 -3
  26. package/build/dom.js.map +1 -1
  27. package/build/experimental/apply-style.js +140 -0
  28. package/build/experimental/dom.js +123 -0
  29. package/build/experimental/output.js +91 -0
  30. package/build/experimental/reconciler.js +141 -0
  31. package/build/experimental/renderer.js +81 -0
  32. package/build/get-max-width.js +0 -1
  33. package/build/get-max-width.js.map +1 -1
  34. package/build/hooks/use-focus-manager.js +1 -1
  35. package/build/hooks/use-focus.d.ts +1 -1
  36. package/build/hooks/use-focus.js +2 -2
  37. package/build/hooks/use-focus.js.map +1 -1
  38. package/build/hooks/use-input.js +2 -3
  39. package/build/hooks/use-input.js.map +1 -1
  40. package/build/hooks/useInput.js +38 -0
  41. package/build/ink.js +81 -170
  42. package/build/ink.js.map +1 -1
  43. package/build/instance.js +205 -0
  44. package/build/log-update.d.ts +1 -0
  45. package/build/log-update.js.map +1 -1
  46. package/build/measure-element.js +1 -1
  47. package/build/measure-text.js +1 -1
  48. package/build/measure-text.js.map +1 -1
  49. package/build/output.js +11 -26
  50. package/build/output.js.map +1 -1
  51. package/build/parse-keypress.d.ts +1 -0
  52. package/build/parse-keypress.js +4 -4
  53. package/build/parse-keypress.js.map +1 -1
  54. package/build/reconciler.js +9 -7
  55. package/build/reconciler.js.map +1 -1
  56. package/build/render-border.js +1 -1
  57. package/build/render-border.js.map +1 -1
  58. package/build/render-node-to-output.js +2 -3
  59. package/build/render-node-to-output.js.map +1 -1
  60. package/build/render.d.ts +4 -0
  61. package/build/render.js +3 -3
  62. package/build/render.js.map +1 -1
  63. package/build/renderer.js +5 -5
  64. package/build/renderer.js.map +1 -1
  65. package/build/squash-text-nodes.js.map +1 -1
  66. package/build/styles.d.ts +1 -1
  67. package/build/styles.js +0 -1
  68. package/build/styles.js.map +1 -1
  69. package/build/wrap-text.js +1 -1
  70. package/build/wrap-text.js.map +1 -1
  71. package/package.json +35 -39
  72. package/readme.md +5 -18
@@ -0,0 +1,175 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.default = void 0;
7
+
8
+ var _yogaLayoutPrebuilt = _interopRequireDefault(require("yoga-layout-prebuilt"));
9
+
10
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
11
+
12
+ const applyMarginStyles = (node, style) => {
13
+ if (style.margin) {
14
+ node.setMargin(_yogaLayoutPrebuilt.default.EDGE_TOP, style.margin);
15
+ node.setMargin(_yogaLayoutPrebuilt.default.EDGE_BOTTOM, style.margin);
16
+ node.setMargin(_yogaLayoutPrebuilt.default.EDGE_START, style.margin);
17
+ node.setMargin(_yogaLayoutPrebuilt.default.EDGE_END, style.margin);
18
+ }
19
+
20
+ if (style.marginX) {
21
+ node.setMargin(_yogaLayoutPrebuilt.default.EDGE_START, style.marginX);
22
+ node.setMargin(_yogaLayoutPrebuilt.default.EDGE_END, style.marginX);
23
+ }
24
+
25
+ if (style.marginY) {
26
+ node.setMargin(_yogaLayoutPrebuilt.default.EDGE_TOP, style.marginY);
27
+ node.setMargin(_yogaLayoutPrebuilt.default.EDGE_BOTTOM, style.marginY);
28
+ }
29
+
30
+ if (style.marginTop) {
31
+ node.setMargin(_yogaLayoutPrebuilt.default.EDGE_TOP, style.marginTop);
32
+ }
33
+
34
+ if (style.marginBottom) {
35
+ node.setMargin(_yogaLayoutPrebuilt.default.EDGE_BOTTOM, style.marginBottom);
36
+ }
37
+
38
+ if (style.marginLeft) {
39
+ node.setMargin(_yogaLayoutPrebuilt.default.EDGE_START, style.marginLeft);
40
+ }
41
+
42
+ if (style.marginRight) {
43
+ node.setMargin(_yogaLayoutPrebuilt.default.EDGE_END, style.marginRight);
44
+ }
45
+ };
46
+
47
+ const applyPaddingStyles = (node, style) => {
48
+ if (style.padding) {
49
+ node.setPadding(_yogaLayoutPrebuilt.default.EDGE_TOP, style.padding);
50
+ node.setPadding(_yogaLayoutPrebuilt.default.EDGE_BOTTOM, style.padding);
51
+ node.setPadding(_yogaLayoutPrebuilt.default.EDGE_LEFT, style.padding);
52
+ node.setPadding(_yogaLayoutPrebuilt.default.EDGE_RIGHT, style.padding);
53
+ }
54
+
55
+ if (style.paddingX) {
56
+ node.setPadding(_yogaLayoutPrebuilt.default.EDGE_LEFT, style.paddingX);
57
+ node.setPadding(_yogaLayoutPrebuilt.default.EDGE_RIGHT, style.paddingX);
58
+ }
59
+
60
+ if (style.paddingY) {
61
+ node.setPadding(_yogaLayoutPrebuilt.default.EDGE_TOP, style.paddingY);
62
+ node.setPadding(_yogaLayoutPrebuilt.default.EDGE_BOTTOM, style.paddingY);
63
+ }
64
+
65
+ if (style.paddingTop) {
66
+ node.setPadding(_yogaLayoutPrebuilt.default.EDGE_TOP, style.paddingTop);
67
+ }
68
+
69
+ if (style.paddingBottom) {
70
+ node.setPadding(_yogaLayoutPrebuilt.default.EDGE_BOTTOM, style.paddingBottom);
71
+ }
72
+
73
+ if (style.paddingLeft) {
74
+ node.setPadding(_yogaLayoutPrebuilt.default.EDGE_LEFT, style.paddingLeft);
75
+ }
76
+
77
+ if (style.paddingRight) {
78
+ node.setPadding(_yogaLayoutPrebuilt.default.EDGE_RIGHT, style.paddingRight);
79
+ }
80
+ };
81
+
82
+ const applyFlexStyles = (node, style) => {
83
+ if (style.flexGrow) {
84
+ node.setFlexGrow(style.flexGrow);
85
+ }
86
+
87
+ if (style.flexShrink) {
88
+ node.setFlexShrink(style.flexShrink);
89
+ }
90
+
91
+ if (style.flexDirection) {
92
+ if (style.flexDirection === 'row') {
93
+ node.setFlexDirection(_yogaLayoutPrebuilt.default.FLEX_DIRECTION_ROW);
94
+ }
95
+
96
+ if (style.flexDirection === 'row-reverse') {
97
+ node.setFlexDirection(_yogaLayoutPrebuilt.default.FLEX_DIRECTION_ROW_REVERSE);
98
+ }
99
+
100
+ if (style.flexDirection === 'column') {
101
+ node.setFlexDirection(_yogaLayoutPrebuilt.default.FLEX_DIRECTION_COLUMN);
102
+ }
103
+
104
+ if (style.flexDirection === 'column-reverse') {
105
+ node.setFlexDirection(_yogaLayoutPrebuilt.default.FLEX_DIRECTION_COLUMN_REVERSE);
106
+ }
107
+ }
108
+
109
+ if (style.flexBasis !== undefined) {
110
+ node.setFlexBasis(style.flexBasis);
111
+ }
112
+
113
+ if (style.alignItems) {
114
+ if (style.alignItems === 'flex-start') {
115
+ node.setAlignItems(_yogaLayoutPrebuilt.default.ALIGN_FLEX_START);
116
+ }
117
+
118
+ if (style.alignItems === 'center') {
119
+ node.setAlignItems(_yogaLayoutPrebuilt.default.ALIGN_CENTER);
120
+ }
121
+
122
+ if (style.alignItems === 'flex-end') {
123
+ node.setAlignItems(_yogaLayoutPrebuilt.default.ALIGN_FLEX_END);
124
+ }
125
+ }
126
+
127
+ if (style.justifyContent) {
128
+ if (style.justifyContent === 'flex-start') {
129
+ node.setJustifyContent(_yogaLayoutPrebuilt.default.JUSTIFY_FLEX_START);
130
+ }
131
+
132
+ if (style.justifyContent === 'center') {
133
+ node.setJustifyContent(_yogaLayoutPrebuilt.default.JUSTIFY_CENTER);
134
+ }
135
+
136
+ if (style.justifyContent === 'flex-end') {
137
+ node.setJustifyContent(_yogaLayoutPrebuilt.default.JUSTIFY_FLEX_END);
138
+ }
139
+
140
+ if (style.justifyContent === 'space-between') {
141
+ node.setJustifyContent(_yogaLayoutPrebuilt.default.JUSTIFY_SPACE_BETWEEN);
142
+ }
143
+
144
+ if (style.justifyContent === 'space-around') {
145
+ node.setJustifyContent(_yogaLayoutPrebuilt.default.JUSTIFY_SPACE_AROUND);
146
+ }
147
+ }
148
+ };
149
+
150
+ const applyDimensionStyles = (node, style) => {
151
+ if (style.width !== undefined) {
152
+ node.setWidth(style.width);
153
+ }
154
+
155
+ if (style.height !== undefined) {
156
+ node.setHeight(style.height);
157
+ }
158
+
159
+ if (style.minWidth !== undefined) {
160
+ node.setMinWidth(style.minWidth);
161
+ }
162
+
163
+ if (style.minHeight !== undefined) {
164
+ node.setMinHeight(style.minHeight);
165
+ }
166
+ };
167
+
168
+ var _default = (node, style = {}) => {
169
+ applyMarginStyles(node, style);
170
+ applyPaddingStyles(node, style);
171
+ applyFlexStyles(node, style);
172
+ applyDimensionStyles(node, style);
173
+ };
174
+
175
+ exports.default = _default;
@@ -0,0 +1,77 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.default = void 0;
7
+
8
+ var _yogaLayoutPrebuilt = _interopRequireDefault(require("yoga-layout-prebuilt"));
9
+
10
+ var _applyStyles = _interopRequireDefault(require("./apply-styles"));
11
+
12
+ var _measureText = _interopRequireDefault(require("./measure-text"));
13
+
14
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
15
+
16
+ // Traverse the node tree, create Yoga nodes and assign styles to each Yoga node
17
+ const buildLayout = (node, options) => {
18
+ const {
19
+ config,
20
+ terminalWidth,
21
+ skipStaticElements
22
+ } = options;
23
+
24
+ const yogaNode = _yogaLayoutPrebuilt.default.Node.create(config);
25
+
26
+ node.yogaNode = yogaNode;
27
+ const style = node.style || {}; // Root node of the tree
28
+
29
+ if (node.nodeName === 'ROOT') {
30
+ // `terminalWidth` can be `undefined` if env isn't a TTY
31
+ yogaNode.setWidth(terminalWidth || 100);
32
+
33
+ if (node.childNodes.length > 0) {
34
+ const childNodes = node.childNodes.filter(childNode => {
35
+ return skipStaticElements ? !childNode.unstable__static : true;
36
+ });
37
+
38
+ for (const [index, childNode] of Object.entries(childNodes)) {
39
+ const childYogaNode = buildLayout(childNode, options).yogaNode;
40
+ yogaNode.insertChild(childYogaNode, index);
41
+ }
42
+ }
43
+
44
+ return node;
45
+ } // Apply margin, padding, flex, etc styles
46
+
47
+
48
+ (0, _applyStyles.default)(yogaNode, style); // Nodes with only text have a child Yoga node dedicated for that text
49
+
50
+ if (node.textContent || node.nodeValue) {
51
+ const {
52
+ width,
53
+ height
54
+ } = (0, _measureText.default)(node.textContent || node.nodeValue);
55
+ yogaNode.setWidth(style.width || width);
56
+ yogaNode.setHeight(style.height || height);
57
+ return node;
58
+ }
59
+
60
+ if (Array.isArray(node.childNodes) && node.childNodes.length > 0) {
61
+ const childNodes = node.childNodes.filter(childNode => {
62
+ return skipStaticElements ? !childNode.unstable__static : true;
63
+ });
64
+
65
+ for (const [index, childNode] of Object.entries(childNodes)) {
66
+ const {
67
+ yogaNode: childYogaNode
68
+ } = buildLayout(childNode, options);
69
+ yogaNode.insertChild(childYogaNode, index);
70
+ }
71
+ }
72
+
73
+ return node;
74
+ };
75
+
76
+ var _default = buildLayout;
77
+ exports.default = _default;
@@ -0,0 +1,53 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.default = void 0;
7
+
8
+ var _measureText = _interopRequireDefault(require("./measure-text"));
9
+
10
+ var _wrapText = _interopRequireDefault(require("./wrap-text"));
11
+
12
+ var _getMaxWidth = _interopRequireDefault(require("./get-max-width"));
13
+
14
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
15
+
16
+ // Since we need to know the width of text container to wrap text, we have to calculate layout twice
17
+ // This function is executed after first layout calculation to reassign width and height of text nodes
18
+ const calculateWrappedText = node => {
19
+ if (node.textContent && typeof node.parentNode.style.textWrap === 'string') {
20
+ const {
21
+ yogaNode
22
+ } = node;
23
+ const parentYogaNode = node.parentNode.yogaNode;
24
+ const maxWidth = (0, _getMaxWidth.default)(parentYogaNode);
25
+ const currentWidth = yogaNode.getComputedWidth();
26
+
27
+ if (currentWidth > maxWidth) {
28
+ const {
29
+ textWrap
30
+ } = node.parentNode.style;
31
+ const wrappedText = (0, _wrapText.default)(node.textContent, maxWidth, {
32
+ textWrap
33
+ });
34
+ const {
35
+ width,
36
+ height
37
+ } = (0, _measureText.default)(wrappedText);
38
+ yogaNode.setWidth(width);
39
+ yogaNode.setHeight(height);
40
+ }
41
+
42
+ return;
43
+ }
44
+
45
+ if (Array.isArray(node.childNodes) && node.childNodes.length > 0) {
46
+ for (const childNode of node.childNodes) {
47
+ calculateWrappedText(childNode);
48
+ }
49
+ }
50
+ };
51
+
52
+ var _default = calculateWrappedText;
53
+ exports.default = _default;
@@ -1 +1 @@
1
- {"version":3,"file":"colorize.js","sourceRoot":"","sources":["../src/colorize.ts"],"names":[],"mappings":"AAAA,OAAO,KAA2D,MAAM,OAAO,CAAC;AAIhF,MAAM,QAAQ,GAAG,wCAAwC,CAAC;AAC1D,MAAM,SAAS,GAAG,0BAA0B,CAAC;AAE7C,MAAM,YAAY,GAAG,CAAC,KAAa,EAAgC,EAAE;IACpE,OAAO,KAAK,IAAI,KAAK,CAAC;AACvB,CAAC,CAAC;AAEF,MAAM,QAAQ,GAAG,CAChB,GAAW,EACX,KAAyB,EACzB,IAAe,EACN,EAAE;IACX,IAAI,CAAC,KAAK,EAAE;QACX,OAAO,GAAG,CAAC;KACX;IAED,IAAI,YAAY,CAAC,KAAK,CAAC,EAAE;QACxB,IAAI,IAAI,KAAK,YAAY,EAAE;YAC1B,OAAO,KAAK,CAAC,KAAK,CAAC,CAAC,GAAG,CAAC,CAAC;SACzB;QAED,MAAM,UAAU,GAAG,KAClB,KAAK,CAAC,CAAC,CAAE,CAAC,WAAW,EAAE,GAAG,KAAK,CAAC,KAAK,CAAC,CAAC,CACxC,EAAyB,CAAC;QAE1B,OAAO,KAAK,CAAC,UAAU,CAAC,CAAC,GAAG,CAAC,CAAC;KAC9B;IAED,IAAI,KAAK,CAAC,UAAU,CAAC,GAAG,CAAC,EAAE;QAC1B,OAAO,IAAI,KAAK,YAAY;YAC3B,CAAC,CAAC,KAAK,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,GAAG,CAAC;YACvB,CAAC,CAAC,KAAK,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,GAAG,CAAC,CAAC;KAC3B;IAED,IAAI,KAAK,CAAC,UAAU,CAAC,SAAS,CAAC,EAAE;QAChC,MAAM,OAAO,GAAG,SAAS,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAEtC,IAAI,CAAC,OAAO,EAAE;YACb,OAAO,GAAG,CAAC;SACX;QAED,MAAM,KAAK,GAAG,MAAM,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC;QAEjC,OAAO,IAAI,KAAK,YAAY;YAC3B,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,GAAG,CAAC;YAC3B,CAAC,CAAC,KAAK,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,GAAG,CAAC,CAAC;KAC/B;IAED,IAAI,KAAK,CAAC,UAAU,CAAC,KAAK,CAAC,EAAE;QAC5B,MAAM,OAAO,GAAG,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAErC,IAAI,CAAC,OAAO,EAAE;YACb,OAAO,GAAG,CAAC;SACX;QAED,MAAM,UAAU,GAAG,MAAM,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC;QACtC,MAAM,WAAW,GAAG,MAAM,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC;QACvC,MAAM,UAAU,GAAG,MAAM,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC;QAEtC,OAAO,IAAI,KAAK,YAAY;YAC3B,CAAC,CAAC,KAAK,CAAC,GAAG,CAAC,UAAU,EAAE,WAAW,EAAE,UAAU,CAAC,CAAC,GAAG,CAAC;YACrD,CAAC,CAAC,KAAK,CAAC,KAAK,CAAC,UAAU,EAAE,WAAW,EAAE,UAAU,CAAC,CAAC,GAAG,CAAC,CAAC;KACzD;IAED,OAAO,GAAG,CAAC;AACZ,CAAC,CAAC;AAEF,eAAe,QAAQ,CAAC"}
1
+ {"version":3,"file":"colorize.js","sourceRoot":"","sources":["../src/colorize.ts"],"names":[],"mappings":"AAAA,OAAO,KAA2D,MAAM,OAAO,CAAC;AAIhF,MAAM,QAAQ,GAAG,wCAAwC,CAAC;AAC1D,MAAM,SAAS,GAAG,0BAA0B,CAAC;AAE7C,MAAM,YAAY,GAAG,CAAC,KAAa,EAAgC,EAAE;IACpE,OAAO,KAAK,IAAI,KAAK,CAAC;AACvB,CAAC,CAAC;AAEF,MAAM,QAAQ,GAAG,CAChB,GAAW,EACX,KAAyB,EACzB,IAAe,EACN,EAAE;IACX,IAAI,CAAC,KAAK,EAAE,CAAC;QACZ,OAAO,GAAG,CAAC;IACZ,CAAC;IAED,IAAI,YAAY,CAAC,KAAK,CAAC,EAAE,CAAC;QACzB,IAAI,IAAI,KAAK,YAAY,EAAE,CAAC;YAC3B,OAAO,KAAK,CAAC,KAAK,CAAC,CAAC,GAAG,CAAC,CAAC;QAC1B,CAAC;QAED,MAAM,UAAU,GAAG,KAClB,KAAK,CAAC,CAAC,CAAE,CAAC,WAAW,EAAE,GAAG,KAAK,CAAC,KAAK,CAAC,CAAC,CACxC,EAAyB,CAAC;QAE1B,OAAO,KAAK,CAAC,UAAU,CAAC,CAAC,GAAG,CAAC,CAAC;IAC/B,CAAC;IAED,IAAI,KAAK,CAAC,UAAU,CAAC,GAAG,CAAC,EAAE,CAAC;QAC3B,OAAO,IAAI,KAAK,YAAY;YAC3B,CAAC,CAAC,KAAK,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,GAAG,CAAC;YACvB,CAAC,CAAC,KAAK,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,GAAG,CAAC,CAAC;IAC5B,CAAC;IAED,IAAI,KAAK,CAAC,UAAU,CAAC,SAAS,CAAC,EAAE,CAAC;QACjC,MAAM,OAAO,GAAG,SAAS,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAEtC,IAAI,CAAC,OAAO,EAAE,CAAC;YACd,OAAO,GAAG,CAAC;QACZ,CAAC;QAED,MAAM,KAAK,GAAG,MAAM,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC;QAEjC,OAAO,IAAI,KAAK,YAAY;YAC3B,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,GAAG,CAAC;YAC3B,CAAC,CAAC,KAAK,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,GAAG,CAAC,CAAC;IAChC,CAAC;IAED,IAAI,KAAK,CAAC,UAAU,CAAC,KAAK,CAAC,EAAE,CAAC;QAC7B,MAAM,OAAO,GAAG,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAErC,IAAI,CAAC,OAAO,EAAE,CAAC;YACd,OAAO,GAAG,CAAC;QACZ,CAAC;QAED,MAAM,UAAU,GAAG,MAAM,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC;QACtC,MAAM,WAAW,GAAG,MAAM,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC;QACvC,MAAM,UAAU,GAAG,MAAM,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC;QAEtC,OAAO,IAAI,KAAK,YAAY;YAC3B,CAAC,CAAC,KAAK,CAAC,GAAG,CAAC,UAAU,EAAE,WAAW,EAAE,UAAU,CAAC,CAAC,GAAG,CAAC;YACrD,CAAC,CAAC,KAAK,CAAC,KAAK,CAAC,UAAU,EAAE,WAAW,EAAE,UAAU,CAAC,CAAC,GAAG,CAAC,CAAC;IAC1D,CAAC;IAED,OAAO,GAAG,CAAC;AACZ,CAAC,CAAC;AAEF,eAAe,QAAQ,CAAC"}
@@ -34,7 +34,7 @@ export default class App extends PureComponent<Props, State> {
34
34
  error: undefined;
35
35
  };
36
36
  rawModeEnabledCount: number;
37
- internal_eventEmitter: EventEmitter;
37
+ internal_eventEmitter: EventEmitter<[never]>;
38
38
  isRawModeSupported(): boolean;
39
39
  render(): React.JSX.Element;
40
40
  componentDidMount(): void;