UNPKG

custom-app

Version:

ITIMS��Ʒ�鿪��ר��React���,�Dz��ý��ּ�dhcc-app���������

210 lines (169 loc) 20.6 kB
var _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; var _slicedToArray = function () { function sliceIterator(arr, i) { var _arr = []; var _n = true; var _d = false; var _e = undefined; try { for (var _i = arr[Symbol.iterator](), _s; !(_n = (_s = _i.next()).done); _n = true) { _arr.push(_s.value); if (i && _arr.length === i) break; } } catch (err) { _d = true; _e = err; } finally { try { if (!_n && _i["return"]) _i["return"](); } finally { if (_d) throw _e; } } return _arr; } return function (arr, i) { if (Array.isArray(arr)) { return arr; } else if (Symbol.iterator in Object(arr)) { return sliceIterator(arr, i); } else { throw new TypeError("Invalid attempt to destructure non-iterable instance"); } }; }(); function _toConsumableArray(arr) { if (Array.isArray(arr)) { for (var i = 0, arr2 = Array(arr.length); i < arr.length; i++) { arr2[i] = arr[i]; } return arr2; } else { return Array.from(arr); } } import { useMemo } from "react"; import { getFirstDefined, getBy } from "../utils"; export var useColumns = function useColumns(props) { var debug = props.debug, userColumns = props.columns, _props$state = _slicedToArray(props.state, 1), groupBy = _props$state[0].groupBy; var _useMemo = useMemo(function () { if (debug) console.info("getColumns"); // Decorate All the columns var columnTree = decorateColumnTree(userColumns); // Get the flat list of all columns var columns = flattenBy(columnTree, "columns"); columns = [].concat(_toConsumableArray(groupBy.map(function (g) { return columns.find(function (col) { return col.id === g; }); })), _toConsumableArray(columns.filter(function (col) { return !groupBy.includes(col.id); }))); // Get headerGroups var headerGroups = makeHeaderGroups(columns, findMaxDepth(columnTree)); var headers = flattenBy(headerGroups, "headers"); return { columns: columns, headerGroups: headerGroups, headers: headers }; }, [groupBy, userColumns]), columns = _useMemo.columns, headerGroups = _useMemo.headerGroups, headers = _useMemo.headers; return _extends({}, props, { columns: columns, headerGroups: headerGroups, headers: headers }); // Find the depth of the columns function findMaxDepth(columns) { var depth = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 0; return columns.reduce(function (prev, curr) { if (curr.columns) { return Math.max(prev, findMaxDepth(curr.columns, depth + 1)); } return depth; }, 0); } function decorateColumn(column, parent) { // First check for string accessor var _column = column, id = _column.id, accessor = _column.accessor, Header = _column.Header; if (typeof accessor === "string") { id = id || accessor; var accessorString = accessor; accessor = function accessor(row) { return getBy(row, accessorString); }; } if (!id && typeof Header === "string") { id = Header; } if (!id) { // Accessor, but no column id? This is bad. console.error(column); throw new Error("A column id is required!"); } column = _extends({ Header: "", Cell: function Cell(cell) { return cell.value; }, show: true }, column, { id: id, accessor: accessor, parent: parent }); return column; } // Build the visible columns, headers and flat column list function decorateColumnTree(columns, parent) { var depth = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 0; return columns.map(function (column) { column = decorateColumn(column, parent); if (column.columns) { column.columns = decorateColumnTree(column.columns, column, depth + 1); } return column; }); } function flattenBy(columns, childKey) { var flatColumns = []; var recurse = function recurse(columns) { columns.forEach(function (d) { if (!d[childKey]) { flatColumns.push(d); } else { recurse(d[childKey]); } }); }; recurse(columns); return flatColumns; } // Build the header groups from the bottom up function makeHeaderGroups(columns, maxDepth) { var headerGroups = []; var removeChildColumns = function removeChildColumns(column) { delete column.columns; if (column.parent) { removeChildColumns(column.parent); } }; columns.forEach(removeChildColumns); var buildGroup = function buildGroup(columns) { var depth = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 0; var headerGroup = { headers: [] }; var parentColumns = []; var hasParents = columns.some(function (col) { return col.parent; }); columns.forEach(function (column) { var isFirst = !parentColumns.length; var latestParentColumn = [].concat(parentColumns).reverse()[0]; // If the column has a parent, add it if necessary if (column.parent) { if (isFirst || latestParentColumn.originalID !== column.parent.id) { parentColumns.push(_extends({}, column.parent, { originalID: column.parent.id, id: [column.parent.id, parentColumns.length].join("_") })); } } else if (hasParents) { // If other columns have parents, add a place holder if necessary var placeholderColumn = decorateColumn({ originalID: [column.id, "placeholder", maxDepth - depth].join("_"), id: [column.id, "placeholder", maxDepth - depth, parentColumns.length].join("_") }); if (isFirst || latestParentColumn.originalID !== placeholderColumn.originalID) { parentColumns.push(placeholderColumn); } } // Establish the new columns[] relationship on the parent if (column.parent || hasParents) { latestParentColumn = [].concat(parentColumns).reverse()[0]; latestParentColumn.columns = latestParentColumn.columns || []; if (!latestParentColumn.columns.includes(column)) { latestParentColumn.columns.push(column); } } headerGroup.headers.push(column); }); headerGroups.push(headerGroup); if (parentColumns.length) { buildGroup(parentColumns); } }; buildGroup(columns); return headerGroups.reverse(); } }; //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/hooks/useColumns.js"],"names":["useMemo","getFirstDefined","getBy","useColumns","debug","props","userColumns","columns","state","groupBy","console","info","columnTree","decorateColumnTree","flattenBy","map","find","col","id","g","filter","includes","headerGroups","makeHeaderGroups","findMaxDepth","headers","depth","reduce","prev","curr","Math","max","decorateColumn","column","parent","accessor","Header","accessorString","row","error","Error","Cell","cell","value","show","childKey","flatColumns","recurse","forEach","d","push","maxDepth","removeChildColumns","buildGroup","headerGroup","parentColumns","hasParents","some","isFirst","length","latestParentColumn","reverse","originalID","join","placeholderColumn"],"mappings":"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","file":"useColumns.js","sourcesContent":["import { useMemo } from \"react\";\n\nimport { getFirstDefined, getBy } from \"../utils\";\n\nexport const useColumns = props => {\n  const {\n    debug,\n    columns: userColumns,\n    state: [{ groupBy }]\n  } = props;\n\n  const { columns, headerGroups, headers } = useMemo(\n    () => {\n      if (debug) console.info(\"getColumns\");\n\n      // Decorate All the columns\n      let columnTree = decorateColumnTree(userColumns);\n\n      // Get the flat list of all columns\n      let columns = flattenBy(columnTree, \"columns\");\n\n      columns = [\n        ...groupBy.map(g => columns.find(col => col.id === g)),\n        ...columns.filter(col => !groupBy.includes(col.id))\n      ];\n\n      // Get headerGroups\n      const headerGroups = makeHeaderGroups(columns, findMaxDepth(columnTree));\n      const headers = flattenBy(headerGroups, \"headers\");\n\n      return {\n        columns,\n        headerGroups,\n        headers\n      };\n    },\n    [groupBy, userColumns]\n  );\n\n  return {\n    ...props,\n    columns,\n    headerGroups,\n    headers\n  };\n\n  // Find the depth of the columns\n  function findMaxDepth(columns, depth = 0) {\n    return columns.reduce((prev, curr) => {\n      if (curr.columns) {\n        return Math.max(prev, findMaxDepth(curr.columns, depth + 1));\n      }\n      return depth;\n    }, 0);\n  }\n\n  function decorateColumn(column, parent) {\n    // First check for string accessor\n    let { id, accessor, Header } = column;\n\n    if (typeof accessor === \"string\") {\n      id = id || accessor;\n      const accessorString = accessor;\n      accessor = row => getBy(row, accessorString);\n    }\n\n    if (!id && typeof Header === \"string\") {\n      id = Header;\n    }\n\n    if (!id) {\n      // Accessor, but no column id? This is bad.\n      console.error(column);\n      throw new Error(\"A column id is required!\");\n    }\n\n    column = {\n      Header: \"\",\n      Cell: cell => cell.value,\n      show: true,\n      ...column,\n      id,\n      accessor,\n      parent\n    };\n\n    return column;\n  }\n\n  // Build the visible columns, headers and flat column list\n  function decorateColumnTree(columns, parent, depth = 0) {\n    return columns.map(column => {\n      column = decorateColumn(column, parent);\n      if (column.columns) {\n        column.columns = decorateColumnTree(column.columns, column, depth + 1);\n      }\n      return column;\n    });\n  }\n\n  function flattenBy(columns, childKey) {\n    const flatColumns = [];\n\n    const recurse = columns => {\n      columns.forEach(d => {\n        if (!d[childKey]) {\n          flatColumns.push(d);\n        } else {\n          recurse(d[childKey]);\n        }\n      });\n    };\n\n    recurse(columns);\n\n    return flatColumns;\n  }\n\n  // Build the header groups from the bottom up\n  function makeHeaderGroups(columns, maxDepth) {\n    const headerGroups = [];\n\n    const removeChildColumns = column => {\n      delete column.columns;\n      if (column.parent) {\n        removeChildColumns(column.parent);\n      }\n    };\n    columns.forEach(removeChildColumns);\n\n    const buildGroup = (columns, depth = 0) => {\n      const headerGroup = {\n        headers: []\n      };\n\n      const parentColumns = [];\n\n      const hasParents = columns.some(col => col.parent);\n\n      columns.forEach(column => {\n        const isFirst = !parentColumns.length;\n        let latestParentColumn = [...parentColumns].reverse()[0];\n\n        // If the column has a parent, add it if necessary\n        if (column.parent) {\n          if (isFirst || latestParentColumn.originalID !== column.parent.id) {\n            parentColumns.push({\n              ...column.parent,\n              originalID: column.parent.id,\n              id: [column.parent.id, parentColumns.length].join(\"_\")\n            });\n          }\n        } else if (hasParents) {\n          // If other columns have parents, add a place holder if necessary\n          const placeholderColumn = decorateColumn({\n            originalID: [column.id, \"placeholder\", maxDepth - depth].join(\"_\"),\n            id: [\n              column.id,\n              \"placeholder\",\n              maxDepth - depth,\n              parentColumns.length\n            ].join(\"_\")\n          });\n          if (\n            isFirst ||\n            latestParentColumn.originalID !== placeholderColumn.originalID\n          ) {\n            parentColumns.push(placeholderColumn);\n          }\n        }\n\n        // Establish the new columns[] relationship on the parent\n        if (column.parent || hasParents) {\n          latestParentColumn = [...parentColumns].reverse()[0];\n          latestParentColumn.columns = latestParentColumn.columns || [];\n          if (!latestParentColumn.columns.includes(column)) {\n            latestParentColumn.columns.push(column);\n          }\n        }\n\n        headerGroup.headers.push(column);\n      });\n\n      headerGroups.push(headerGroup);\n\n      if (parentColumns.length) {\n        buildGroup(parentColumns);\n      }\n    };\n\n    buildGroup(columns);\n\n    return headerGroups.reverse();\n  }\n};\n"]}