import * as React from "react";
import Button from "@material-ui/core/Button";
import * as propTypes from "prop-types";
import { withStyles } from "@material-ui/core/styles";
import "./App.css";
import PageTwo from "./components/PageTwo";
const styles = theme => ({
container: {
display: "flex",
flexWrap: "wrap"
},
textField: {
marginLeft: theme.spacing.unit,
marginRight: theme.spacing.unit,
width: 200
},
menu: {
width: 200
}
});
export interface Items {
objectID?: string;
URL?: string;
}
export interface IPropsk {
data?: Array<Items>;
fetchData?(value: string): void;
}
export interface IState {
isLoaded: boolean;
hits: Array<Items>;
value: string;
}
const API = "https://hn.algolia.com/api/v1/search?query=";
export class App extends React.Component<IPropsk, IState> {
constructor(props: IPropsk) {
super(props);
this.state = {
isLoaded: false,
hits: [],
value: ""
};
render() {
return (
<div>
<div>
<TextField
id="required"
label="Required"
defaultValue="Hello World"
margin="dense"
value={this.state.value}
onChange={this.handleChange}
/>
<Button
variant="contained"
color="primary"
onClick={() => this.fetchData(this.state.value)}
>
Search
</Button>
</div>
<div>
<PageTwo data={this.state.hits} />
</div>
</div>
);
}
}
export default withStyles(styles)(App);
Я написал приведенный выше фрагмент кода для вызова метода fetchData. При нажатии кнопки. Он работает без ошибок. Но когда я применяю MateriaUI для изменения стиля компонентов (я просто хочу изменить размер текстового поля и кнопки t), я хочу получить доступ к классам в компоненте стиля. Как я могу получить к нему доступ из текстового поля