@sdziadkowiec/react-datasheet-grid
Version:
An Excel-like React component to create beautiful spreadsheets.
61 lines • 4.07 kB
JavaScript
;
var __rest = (this && this.__rest) || function (s, e) {
var t = {};
for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)
t[p] = s[p];
if (s != null && typeof Object.getOwnPropertySymbols === "function")
for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))
t[p[i]] = s[p[i]];
}
return t;
};
Object.defineProperty(exports, "__esModule", { value: true });
exports.keyColumn = void 0;
const jsx_runtime_1 = require("react/jsx-runtime");
const react_1 = require("react");
const KeyComponent = (_a) => {
var { columnData: { key, original }, rowData, setRowData } = _a, rest = __rest(_a, ["columnData", "rowData", "setRowData"]);
// We use a ref so useCallback does not produce a new setKeyData function every time the rowData changes
const rowDataRef = (0, react_1.useRef)(rowData);
rowDataRef.current = rowData;
// We wrap the setRowData function to assign the value to the desired key
const setKeyData = (0, react_1.useCallback)((value) => {
setRowData(Object.assign(Object.assign({}, rowDataRef.current), { [key]: value }));
}, [key, setRowData]);
if (!original.component) {
return (0, jsx_runtime_1.jsx)(jsx_runtime_1.Fragment, {});
}
const Component = original.component;
return ((0, jsx_runtime_1.jsx)(Component, Object.assign({ columnData: original.columnData, setRowData: setKeyData,
// We only pass the value of the desired key, this is why each cell does not have to re-render everytime
// another cell in the same row changes!
rowData: rowData[key] }, rest)));
};
const keyColumn = (key, column) => (Object.assign(Object.assign({ id: key }, column), {
// We pass the key and the original column as columnData to be able to retrieve them in the cell component
columnData: { key: key, original: column }, component: KeyComponent,
// Here we simply wrap all functions to only pass the value of the desired key to the column, and not the entire row
copyValue: ({ rowData, rowIndex }) => { var _a, _b; return (_b = (_a = column.copyValue) === null || _a === void 0 ? void 0 : _a.call(column, { rowData: rowData[key], rowIndex })) !== null && _b !== void 0 ? _b : null; }, deleteValue: ({ rowData, rowIndex }) => {
var _a, _b;
return (Object.assign(Object.assign({}, rowData), { [key]: (_b = (_a = column.deleteValue) === null || _a === void 0 ? void 0 : _a.call(column, { rowData: rowData[key], rowIndex })) !== null && _b !== void 0 ? _b : null }));
}, pasteValue: ({ rowData, value, rowIndex }) => {
var _a, _b;
return (Object.assign(Object.assign({}, rowData), { [key]: (_b = (_a = column.pasteValue) === null || _a === void 0 ? void 0 : _a.call(column, { rowData: rowData[key], value, rowIndex })) !== null && _b !== void 0 ? _b : null }));
}, disabled: typeof column.disabled === 'function'
? ({ rowData, rowIndex }) => {
var _a;
return typeof column.disabled === 'function'
? column.disabled({ rowData: rowData[key], rowIndex })
: (_a = column.disabled) !== null && _a !== void 0 ? _a : false;
}
: column.disabled, cellClassName: typeof column.cellClassName === 'function'
? ({ rowData, rowIndex, columnId }) => {
var _a;
return typeof column.cellClassName === 'function'
? column.cellClassName({ rowData: rowData[key], rowIndex, columnId })
: (_a = column.cellClassName) !== null && _a !== void 0 ? _a : undefined;
}
: column.cellClassName, isCellEmpty: ({ rowData, rowIndex }) => { var _a, _b; return (_b = (_a = column.isCellEmpty) === null || _a === void 0 ? void 0 : _a.call(column, { rowData: rowData[key], rowIndex })) !== null && _b !== void 0 ? _b : false; } }));
exports.keyColumn = keyColumn;
//# sourceMappingURL=keyColumn.js.map