I created a react app for a tutorial and it writes text over an uploaded image. The user after image upload types in Top Box
and Bottom Box
but when I try to save the image after the user has typed text, no text shows up. Can anyone please help as I want the image to be downloaded with text.
The files are Header.js
with code:
import React, {Component} from 'react';
import logo from './logo.svg';
import './App.css';
import CardMedia from '@material-ui/core/CardMedia';
import { withStyles } from '@material-ui/core/styles';
import CardActionArea from '@material-ui/core/CardActionArea';
import { Card, CardContent } from "@material-ui/core";
import IconButton from '@material-ui/core/IconButton';
import PhotoCamera from '@material-ui/icons/PhotoCamera';
const styles = theme => ({
media: {
display: 'flex',
height: 400,
objectFit: 'contain',
alignItems: 'center',
},
})
class Header extends Component {
render() {
const {classes} = this.props;
return(
<Card >
<CardContent >
<div style=>
<CardMedia
component="img"
image = {this.props.imageIn}
/>
<div style=>
{this.props.topText}
</div>
<div style=>
{this.props.bottomText}
</div>
</div>
</CardContent>
</Card>
);
}
}
export default withStyles(styles)(Header)
and App.js
as:
import React, {Component} from 'react';
import logo from './logo.svg';
import './App.css';
import CardMedia from '@material-ui/core/CardMedia';
import { withStyles } from '@material-ui/core/styles';
import CardActionArea from '@material-ui/core/CardActionArea';
import { Card, CardContent } from "@material-ui/core";
import Header from './Header';
import Grid from '@material-ui/core/Grid';
import TextField from '@material-ui/core/TextField';
import IconButton from '@material-ui/core/IconButton';
import PhotoCamera from '@material-ui/icons/PhotoCamera';
const styles = (theme) => ({
input: {
display: 'none'
}
});
class App extends Component{
state = {
topText: '',
bottomText: '',
randomImg: "http://i.imgflip.com/1bij.jpg",
allImages: [],
images: []
}
handleChange = (event) => {
const {name, value} = event.target
this.setState({ [name]: value })
}
handleCapture = ({ target }) => {
const fileReader = new FileReader();
const name = target.accept.includes('image') ? 'images' : 'videos';
fileReader.readAsDataURL(target.files[0]);
fileReader.onload = (e) => {
this.setState((prevState) => ({
[name]: [...prevState[name], e.target.result]
}));
};
};
render() {
return(
<div>
<input
accept="image/*"
style=
id="icon-button-photo"
onChange={this.handleCapture}
type="file"
/>
<label htmlFor="icon-button-photo">
<IconButton color="primary" component="span">
<PhotoCamera />
</IconButton>
</label>
<Grid container justify="left" spacing={8}>
<Grid item xs={12} sm={6}>
<TextField
id="standard-name"
label="Top Text"
name = "topText"
value={this.state.topText}
onChange={this.handleChange}
margin="normal"
variant="filled"
/>
</Grid>
<Grid item xs={12} sm={6}>
<TextField
id="standard-name"
label="Bottom Text"
name = "bottomText"
value={this.state.bottomText}
onChange={this.handleChange}
margin="normal"
variant="filled"
/>
</Grid>
<Header topText = {this.state.topText} bottomText = {this.state.bottomText} imageIn = {this.state.images}/>
</Grid>
</div>
)
}
}
export default App
from Downloading picture with text in ReactJS
No comments:
Post a Comment