Untitled

mail@pastecode.io avatar
unknown
javascript
a year ago
3.6 kB
7
Indexable
import React, { useState } from "react";
import EditableLine from "./EditableLine";

export default function EditableSheet(props) {


    const removeData = (index) => {
        console.log(data);
        setData(data.filter((item, i) => i !== index));
    }

    const [data, setData] = useState([]);

    const addRowRef = React.useRef(null);
    // add listeners to the form to submit it

    const addData = () => {
        let newData = [];
        let inputs = addRowRef.current.getElementsByTagName("input");
        for (let i = 0; i < inputs.length; i++) {
            newData.push(inputs[i].value);
        }
        setData([...data, <EditableLine data={newData} />]);
        console.log(data);

        // clear the inputs
        for (let i = 0; i < inputs.length; i++) {
            inputs[i].value = "";
        }
    }

    React.useEffect(() => {
        setData(
            props.data.map((item, index) => (
                // add index to the item
                item.index = index,

                <EditableLine
                    data={item}
                    rowClass={index % 2 === 0 ? "even" : "odd"}
                    removeData={removeData}
                />
            ))
        )
    }, []);

    return (
        <div className="relative overflow-x-auto shadow-md sm:rounded-lg">
            <table className="w-full text-sm text-left text-gray-500 dark:text-gray-400">
                <thead className="bg-gray-50 dark:bg-gray-800">
                    <EditableLine data={props.headers} header />
                </thead>
                <tbody className="bg-white divide-y dark:divide-gray-700 dark:bg-gray-800">
                    {data}
                    <tr className="bg-gray-50 dark:bg-gray-700" ref={addRowRef}>
                        {
                            props.headers.map((item, index) => (
                                <td className="px-6 py-4 whitespace-nowrap">
                                    <input
                                        type="text"
                                        name={item}
                                        id={item}
                                        className="border rounded-md px-3 py-2 w-full"
                                    />
                                </td>
                            ))
                        }
                        <td className="px-6 py-4 whitespace-nowrap text-right text-sm font-medium">
                            <button
                                type="button"
                                className="text-indigo-600 hover:text-indigo-900"
                                onClick={addData}
                            >
                                Add
                            </button>
                        </td>
                        {/* <td className="px-6 py-4 whitespace-nowrap text-right text-sm font-medium">
                            <button
                                type="button"
                                className="text-indigo-600 hover:text-indigo-900"
                                onClick={() => {
                                    setData(data.slice(0, data.length - 1));
                                }}
                            >
                                Remove
                            </button>
                        </td> */}
                    </tr>
                </tbody>
            </table>
        </div >
    )
}