Реагировать на рендеринг нового компонента нажатием кнопки - PullRequest
0 голосов
/ 21 марта 2020

Поэтому я пытаюсь визуализировать компонент при каждом нажатии кнопки. Например, отображение текста при каждом нажатии кнопки или отображение нового поля ввода при каждом нажатии кнопки. В приведенном ниже коде я просто пытаюсь отображать текст в пользовательском интерфейсе при каждом нажатии кнопки. Я следовал за другими сообщениями переполнения стека без удачи. Я что-то упустил?

export default function InputData() {
  const categories = useSelector(state => state.data.retailCategoriesSelected);

 function addition(event, category) {
      categories['retail'].push({value: category, label: category});
      return(
        <div>
          <p>hey</p>
        </div>
      )
      console.log(categories);
  }

const dataForms = categoriesSelected ? (
    categories['retail'].map((d, idx) => {
      return (
        <div key={idx}>
          {idx === 0 && (
            <h2 className="text-center mb-3" id="header">
              Input Data For Selected Categories
            </h2>
          )}
          <div key={idx} className="input-data-select-container mb-4">
            <Row>
              <Col xs="8">
                <h3 className="font-weight-light">{d.value}</h3>
              </Col>
              <Col xs="4">
                <Button
                  onClick={(e) => addition(e, d.value)}
                >
                  Add
                </Button>
              </Col>
              </Row>
            <Row>
              <Col xs="4">
                <Label>Recommended Size:</Label>
                <Input
                  type="number"
                  min="0"
                  placeholder="0"
                  name="recommendedSize"
                  onChange={(e) => handleInputChange(e, d.value)}
                />
              </Col>
              <Col xs="4">
                <Label>
                  First-Year {new Date().getFullYear()} Sales Per Sq Ft:
                </Label>
                <Input
                  type="number"
                  min="0"
                  placeholder="0"
                  name="firstYearSalesPerSqFt"
                  onChange={(e) => handleInputChange(e, d.value)}
                />
              </Col>
              <Col xs="4">
                <Label>
                  Fifth-Year {new Date().getFullYear() + 5} Sales Per Sq Ft:
                </Label>
                <Input
                  type="number"
                  min="0"
                  placeholder="0"
                  name="fifthYearSalesPerSqFt"
                  onChange={(e) => handleInputChange(e, d.value)}
                />
              </Col>
            </Row>
            <FormGroup className="mt-2">
              <Label>Select Recommended Vendors:</Label>
              <Select
                closeMenuOnSelect={false}
                options={options}
                isMulti
                placeholder="Select all the recommended vendors for the report. "
                maxMenuHeight="270px"
              />
            </FormGroup>
          </div>
        </div>
      );
    })) : (
    <h2 className="text-center">No Categories Selected</h2>
  );


 return (
    <Container className="container-width text-secondary">
      <Form className="text-left">
        {dataForms}
      </Form>
    </Container>)
}
...