tekkenot95
@tekkenot95

Как правильно сделать кнопку «Select all» для чекбоксов в React?

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

60eed60e71fb5598458457.png

import React from 'react';
import {Field, Form, Formik} from 'formik';

const CheckBoxes = () => {
    const mockSkills = [
        {
            id: 1,
            name: 'Skill 1'
        },
        {
            id: 2,
            name: 'Skill 2'
        },
        {
            id: 3,
            name: 'Skill 3'
        },
    ]

    return (
        <div className="app-content">
            <Formik
                initialValues={{eventSkills: []}}
                onSubmit={() => null}>
                {({values, handleChange, handleSubmit}) => (
                    <Form onSubmit={handleSubmit}>
                        <div className="form-group">
                            <div className="form-row mr-4 w-100">
                                <pre className="d-flex">
                                    eventSkills: {values.eventSkills.map(el => (
                                    <div className="mr-3">
                                        id: {el}
                                    </div>
                                ))}
                                </pre>
                                <label className="mb-2">Required skills</label>
                                <div className="required-skills-column" role="group"
                                     aria-labelledby="checkbox-group">
                                    <label className="d-block mb-1 select-all custom-checkbox">
                                        <Field
                                            type="checkbox"
                                            name="eventSkills"
                                            value={mockSkills}
                                            onChange={handleChange}
                                        />
                                        <span className="ml-2">Select all</span>
                                    </label>
                                    {
                                        mockSkills?.map((el) => (
                                            <label key={el.id}
                                                   className="d-block mb-1 custom-checkbox">
                                                <Field
                                                    type="checkbox"
                                                    name="eventSkills"
                                                    value={`${el.id}`}/>
                                                <span className="ml-2">{el.name}</span>
                                            </label>
                                        ))
                                    }
                                </div>
                            </div>
                        </div>
                    </Form>
                )}
            </Formik>
        </div>
    )
}

export default CheckBoxes;
  • Вопрос задан
  • 88 просмотров
Пригласить эксперта
Ответы на вопрос 1
vmakhnyuk
@vmakhnyuk
Frontend developer
<Field
  type="checkbox"
  name="selectAll"
/>
<span className="ml-2">Select all</span>


<Formik ... initialValues={{eventSkills: [], selectAll: false}}>
{({values, handleChange,  setFieldValue, handleSubmit}) => 
  React.useEffect(() => {
    if (values.selectAll) {
        setFieldValue('eventSkills',  mockSkills.map(({ id }) => id));
    } else {
        setFieldValue('eventSkills',  []);
    }
  }, [values.selectAll])
  return (
    <Form ... />
    .....
  )
}}
Ответ написан
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Войти через центр авторизации
Похожие вопросы