Почему реагирует перезагрузка приложения после сохранения файла в моем проекте? - PullRequest
0 голосов
/ 05 марта 2019

Здравствуйте, у меня есть проект в Reaction + GraphQl + узел и Mongod, и я попытался загрузить изображения в папку в моем приложении, и у меня возникла проблема с перезагрузкой приложения после сохранения файла. Я пытался управлять локальным состоянием в компоненте при выполнении процесса загрузки, но моя локальная переменная изменилась на исходное состояние из-за приложения перезагрузки, и не могу показать предварительный просмотр моего файла. Моя цель - показать превью img upload.

Я думаю, что моя проблема в резольвере, в функции storeUpload

код.

API ----------- Резольвер ------

const Product = require('../models/Product');
const { createWriteStream } = require("fs");

async function createProduct(root, args) {
  console.log(args.file)

  let product = await new Product(args)
  console.log(product);
  product.save()
  if(args.file){
  const { stream, filename, mimetype, encoding } = await args.file;

  await storeUpload({ stream, product });
  }

  return product
 }
 const storeUpload = ({ stream, product }) =>
 new Promise((resolve, reject) =>
  stream
  .pipe(createWriteStream("./images/" + product._id +".png"))
  .on("finish", () => resolve())
  .on("error", reject)
  );

 module.exports = {

 createProduct

 }

--- Реагировать --- Компонент ----

import React , { useState, useEffect } from 'react'
import {Grid} from '@material-ui/core'
import { Mutation } from "react-apollo"
import {PRODUCTOS} from './Productos'
import gql from "graphql-tag";
import {StyleStateConsumer} from '../../../Context/StylesStateContext'

/** @jsx jsx */
import { jsx, css } from '@emotion/core'

const borde = css({
  borderStyle: 'solid'
})
  const contendorForm = css({
  borderRadius: 15,
  backgroundColor: '#ffffe6'
  },borde)
  const itemsForm = css({
  padding: 15
  })
   const inputStyle = css({
  borderRadius: 5,
  padding: 3
})


const ADD_PRODUCT = gql`
   mutation CreateProduct($title: String, $price: Float, $file: Upload) {
  createProduct(title: $title, price: $price, file: $file) {
 _id
 title
 }
}
 `;

  const CrearProducto = props =>{
  const [titleInput, settitleInput] = useState('')
  const [priceInput, setpriceInput] = useState(0)
  const [fileInput, setfileInput] = useState('')
  const [imgName, setimgName] = useState('default')
  const handleChange = e =>{
        const {name, type, value} = e.target
        if(name === 'titleInput'){settitleInput(value)}
        if(name === 'priceInput'){setpriceInput(parseFloat(value))} 
  }
  const imgUpdate = (imgConxt) => {
        setimgName(imgConxt) 
  }
  useEffect( imgUpdate )
  const handleFile = (obj) =>{console.log(obj)}     
  return(
  <StyleStateConsumer>
        {({imagenID, updateHState})=>(
              <Grid container css={borde}
              direction="row"
              justify="center"
              alignItems="center">
              <Grid item css={contendorForm}>
              {imgUpdate(imagenID)}
                    <Grid container
                    direction="row"
                    justify="center"
                    alignItems="center"><Grid item >Crear Producto:</Grid> 
                    </Grid>
              <Grid container>
              <Mutation mutation={ADD_PRODUCT} refetchQueries={[{
                    query: PRODUCTOS
                    }]}>
                    {(createProduct, { data, loading })=>{
                     if (loading) return <div>Loading...</div>  
                     console.log(data)   
                    return(
                          <div>  
                                <form css={itemsForm} 
                                onSubmit={ (e) => {
                                      e.preventDefault()
                                       createProduct({
                                            variables: {
                                                  title: titleInput,
                                                  price: priceInput,
                                                  file: fileInput
                                            }
                                      })
                                     // 
                                    updateHState(res.data.createProduct._id 
                                     === undefined ? '' : 
                                    res.data.createProduct._id)    
                                      settitleInput('')
                                      setpriceInput(0)

                                     // 
                          console.log(res.data.createProduct._id)
                          }}>
                            <Grid item>
                                <input
                                    css={inputStyle}
                                    type="file"
                                      onChange={({ 
                                            target: { validity, files: 
                                   [file] } }) => validity.valid && 
                              setfileInput(file)
                                      }
                                />
                          </Grid>
                                <Grid item>
                                      <label>
                                            Titulo:
                                      </label>      
                                </Grid>
                                <Grid item>
                                      <input css={inputStyle} type="text" 
                                name="titleInput" 
                                      placeholder="Ingresar Título"
                                      value={titleInput}
                                      onChange={handleChange}
                                      />
                                </Grid>
                                <Grid item>
                                <label>
                                      Precio:
                                </label>      
                                </Grid>
                                <Grid item>
                                      <input css={inputStyle} type="number" 
                                name="priceInput"
                                      placeholder="Ingresar Precio"
                                      value={priceInput}
                                      onChange={handleChange}/>
                                </Grid>
                                <Grid item>
                                      <input type="submit" name="Crear"/>
                                </Grid>
                          </form>

                          </div>       
                    )

                    }}
                    </Mutation>
                    </Grid>

              </Grid>

              <Grid item css={[borde,
                    {
                    backgroundImage:  `url('${require('../../../../../back- 
                    end/images/' + imgName + '.png')}')`,
                    backgroundSize: 'contain',
                    backgroundRepeat: 'no-repeat',
                    height: 300,
                    width: 300}]}>

                    </Grid> 
        </Grid>
        )}
   </StyleStateConsumer>      
   )
   }
  export default CrearProducto

1 Ответ

0 голосов
/ 05 марта 2019

Ну, во-первых, функция imgUpdate, которую вы передаете useEffect , никогда не получит параметр imgConxt. Этот хук просто вызывает функцию с пустыми параметрами, чтобы выполнить связку кода после рендера.

Для вашей основной проблемы, есть ли у вас какие-либо предупреждения или ошибки в консоли? Одним из быстрых, но грязных решений было бы поменять <input type='submit'> на кнопку ввода и выполнить свою логику в обработчике onClick.

...