diff --git a/src/App.tsx b/src/App.tsx
index f819cbdb9..7e2f94d5b 100644
--- a/src/App.tsx
+++ b/src/App.tsx
@@ -1,7 +1,37 @@
import React from 'react';
-export const App: React.FC = () => (
-
-
The last pressed key is [Enter]
-
-);
+type State = {
+ pressedKey: string;
+};
+
+export class App extends React.Component {
+ state: Readonly = {
+ pressedKey: '',
+ };
+
+ componentDidMount(): void {
+ document.addEventListener('keyup', this.handleKeyUp);
+ }
+
+ componentWillUnmount(): void {
+ document.removeEventListener('keyup', this.handleKeyUp);
+ }
+
+ handleKeyUp = (event: KeyboardEvent) => {
+ this.setState({ pressedKey: event.key });
+ };
+
+ render() {
+ const { pressedKey } = this.state;
+
+ const message = pressedKey
+ ? `The last pressed key is [${pressedKey}]`
+ : 'Nothing was pressed yet';
+
+ return (
+
+ );
+ }
+}