UNPKG

@trail-ui/react

Version:
200 lines (194 loc) 8.54 kB
"use strict"; var __create = Object.create; var __defProp = Object.defineProperty; var __getOwnPropDesc = Object.getOwnPropertyDescriptor; var __getOwnPropNames = Object.getOwnPropertyNames; var __getProtoOf = Object.getPrototypeOf; var __hasOwnProp = Object.prototype.hasOwnProperty; var __export = (target, all) => { for (var name in all) __defProp(target, name, { get: all[name], enumerable: true }); }; var __copyProps = (to, from, except, desc) => { if (from && typeof from === "object" || typeof from === "function") { for (let key of __getOwnPropNames(from)) if (!__hasOwnProp.call(to, key) && key !== except) __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable }); } return to; }; var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps( // If the importer is in node compatibility mode or this is not an ESM // file that has been converted to a CommonJS file using a Babel- // compatible transform (i.e. "__esModule" has not been set), then set // "default" to the CommonJS "module.exports" for node compatibility. isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target, mod )); var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod); // src/editable-table/editable-table-header.tsx var editable_table_header_exports = {}; __export(editable_table_header_exports, { default: () => EditableTableHeader }); module.exports = __toCommonJS(editable_table_header_exports); var import_react_table = require("@tanstack/react-table"); var import_icons = require("@trail-ui/icons"); // src/editable-table/focus-handler/focus-handler-provider.tsx var import_react2 = __toESM(require("react")); // src/editable-table/table-context/table-context-provider.tsx var import_react = require("react"); var import_jsx_runtime = require("react/jsx-runtime"); var EditableTableContext = (0, import_react.createContext)({ handleSaveData: () => { }, idSelector: () => { }, table: {} }); function useTableContext(cell) { const { handleSaveData, idSelector, table } = (0, import_react.useContext)( EditableTableContext ); function updateData(value) { var _a; const accessorKey = cell.column.columnDef.accessorKey; handleSaveData({ accessorKey, columnId: cell.column.id, rowId: idSelector(cell.row.original), value }); (_a = table.options.meta) == null ? void 0 : _a.updateData(cell.row.id, cell.column.id, value); } return { updateData, idSelector, table }; } // src/editable-table/focus-handler/focus-handler-provider.tsx var import_jsx_runtime2 = require("react/jsx-runtime"); var FocusHandlerContext = (0, import_react2.createContext)({ tableRef: import_react2.default.createRef(), focusedCell: { columnIndex: 0, rowIndex: 0, isHeader: true }, setFocusedCell: () => { } }); function useFocusHandler(cell, isHeader) { var _a, _b; const { focusedCell, setFocusedCell, tableRef } = (0, import_react2.useContext)(FocusHandlerContext); const { table } = useTableContext(cell); const pageIndex = (_a = table == null ? void 0 : table.getState().pagination.pageIndex) != null ? _a : 0; const pageSize = (_b = table == null ? void 0 : table.getState().pagination.pageSize) != null ? _b : 10; const localRowIndex = cell ? cell.row.index - pageIndex * pageSize : 0; const isCurrentCellFocused = focusedCell.isHeader === isHeader && focusedCell.rowIndex === localRowIndex && focusedCell.columnIndex === (cell == null ? void 0 : cell.column.getIndex()); function focusCurrentCell() { if (!cell) return; setFocusedCell({ columnIndex: cell.column.getIndex(), rowIndex: localRowIndex, // 👈 Should be page-local isHeader: isHeader != null ? isHeader : false }); } return { focusedCell, setFocusedCell, tableRef, isCurrentCellFocused, focusCurrentCell }; } // src/editable-table/editable-table-header.tsx var import_jsx_runtime3 = require("react/jsx-runtime"); function EditableTableHeader({ table, selectAllCheckBoxName, tableName }) { const { focusedCell, setFocusedCell } = useFocusHandler(); const focusHeader = (columnIndex) => setFocusedCell({ rowIndex: 0, columnIndex, isHeader: true }); const renderSortIcon = (sorted) => { switch (sorted) { case "asc": return /* @__PURE__ */ (0, import_jsx_runtime3.jsx)(import_icons.ArrowUpIcon, { className: "h-4 w-4 text-purple-600" }); case "desc": return /* @__PURE__ */ (0, import_jsx_runtime3.jsx)(import_icons.ArrowDownIcon, { className: "h-4 w-4 text-purple-600" }); default: return /* @__PURE__ */ (0, import_jsx_runtime3.jsx)(import_icons.CaretUpDownIcon, { className: "h-4 w-4 text-neutral-600" }); } }; const toggleCheckbox = (elem) => { const checkbox = elem.querySelector('input[type="checkbox"]'); checkbox == null ? void 0 : checkbox.click(); }; return /* @__PURE__ */ (0, import_jsx_runtime3.jsx)("thead", { className: "sticky top-0 z-10", children: table.getHeaderGroups().map((group) => /* @__PURE__ */ (0, import_jsx_runtime3.jsx)("tr", { children: group.headers.map((header, columnIndex) => { var _a; const isFocused = focusedCell.isHeader && focusedCell.columnIndex === columnIndex; const canSort = header.column.getCanSort(); const isCheckbox = ((_a = header.column.columnDef.meta) == null ? void 0 : _a.type) === "checkbox"; if (isCheckbox) { return /* @__PURE__ */ (0, import_jsx_runtime3.jsx)( "th", { colSpan: header.colSpan, className: "border-b border-r bg-neutral-100 px-2 py-2 text-left text-center text-sm font-normal last:border-r-0", children: /* @__PURE__ */ (0, import_jsx_runtime3.jsx)( "div", { role: "checkbox", "data-row": "header", "data-col": columnIndex, "aria-label": selectAllCheckBoxName != null ? selectAllCheckBoxName : `Select all ${tableName}`, "aria-checked": table.getIsAllRowsSelected() ? "true" : table.getIsSomeRowsSelected() ? "mixed" : "false", className: "th-content flex h-[18px] w-[18px] cursor-pointer items-center justify-center p-[10px] outline-purple-600", onClick: (e) => toggleCheckbox(e.currentTarget), onKeyDown: (e) => { if (e.key === "Enter" || e.key === " ") { e.preventDefault(); toggleCheckbox(e.currentTarget); } }, tabIndex: isFocused ? 0 : -1, onFocus: () => focusHeader(columnIndex), children: (0, import_react_table.flexRender)(header.column.columnDef.header, header.getContext()) } ) }, header.id ); } return /* @__PURE__ */ (0, import_jsx_runtime3.jsx)( "th", { scope: "col", className: "border-b border-r bg-neutral-100 last:border-r-0", style: { width: header.column.columnDef.size === 100 ? "auto" : header.column.columnDef.size }, colSpan: header.colSpan, ...canSort && { "aria-sort": header.column.getIsSorted() === "asc" ? "ascending" : header.column.getIsSorted() === "desc" ? "descending" : "none" }, children: /* @__PURE__ */ (0, import_jsx_runtime3.jsxs)( "div", { className: `th-content flex items-center justify-between px-2 text-sm font-semibold outline-purple-600 ${canSort ? "cursor-pointer select-none" : ""} ${isFocused ? "focused" : ""}`, "data-row": "header", "data-col": columnIndex, onClick: () => { if (canSort) header.column.toggleSorting(); focusHeader(columnIndex); }, onKeyDown: (e) => { if (e.key === " " && canSort) { e.preventDefault(); header.column.toggleSorting(); } }, tabIndex: isFocused ? 0 : -1, onFocus: () => focusHeader(columnIndex), children: [ (0, import_react_table.flexRender)(header.column.columnDef.header, header.getContext()), canSort && renderSortIcon(header.column.getIsSorted()) ] } ) }, header.id ); }) }, group.id)) }); }