UNPKG

custom-app

Version:

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

213 lines (177 loc) 18.1 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; }; import { useMemo, useState } from "react"; import PropTypes from "prop-types"; import { getFirstDefined, sum } from "../utils"; var propTypes = { defaultFlex: PropTypes.number }; export var actions = {}; export var useFlexLayout = function useFlexLayout(props) { // Validate props PropTypes.checkPropTypes(propTypes, props, "property", "useFlexLayout"); var _props$defaultFlex = props.defaultFlex, defaultFlex = _props$defaultFlex === undefined ? 1 : _props$defaultFlex, _props$hooks = props.hooks, columnsHooks = _props$hooks.columns, getRowProps = _props$hooks.getRowProps, getHeaderRowProps = _props$hooks.getHeaderRowProps, getHeaderProps = _props$hooks.getHeaderProps, getCellProps = _props$hooks.getCellProps; columnsHooks.push(function (columns, api) { var visibleColumns = columns.filter(function (column) { column.visible = typeof column.show === "function" ? column.show(api) : !!column.show; return column.visible; }); var columnMeasurements = {}; var sumWidth = 0; visibleColumns.forEach(function (column) { var _getSizesForColumn = getSizesForColumn(column, defaultFlex, undefined, undefined, api), width = _getSizesForColumn.width, minWidth = _getSizesForColumn.minWidth; if (width) { sumWidth += width; } else if (minWidth) { sumWidth += minWidth; } else { sumWidth += defaultFlex; } }); var rowStyles = { style: { display: "flex", minWidth: sumWidth + "px" } }; api.rowStyles = rowStyles; getRowProps.push(function () { return rowStyles; }); getHeaderRowProps.push(function () { return rowStyles; }); getHeaderProps.push(function (column) { return { style: _extends({ boxSizing: "border-box" }, getStylesForColumn(column, columnMeasurements, defaultFlex, api)) // [refKey]: el => { // renderedCellInfoRef.current[key] = { // column, // el // }; // }, }; }); getCellProps.push(function (cell) { return { style: _extends({ display: "block", boxSizing: "border-box" }, getStylesForColumn(cell.column, columnMeasurements, defaultFlex, undefined, api)) // [refKey]: el => { // renderedCellInfoRef.current[columnPathStr] = { // column, // el // }; // } }; }); return columns; }); return props; }; // Utils function getStylesForColumn(column, columnMeasurements, defaultFlex, api) { var _getSizesForColumn2 = getSizesForColumn(column, columnMeasurements, defaultFlex, api), flex = _getSizesForColumn2.flex, width = _getSizesForColumn2.width, maxWidth = _getSizesForColumn2.maxWidth; return { flex: flex + " 0 auto", width: width + "px", maxWidth: maxWidth + "px" }; } function getSizesForColumn(_ref, columnMeasurements, defaultFlex, api) { var columns = _ref.columns, id = _ref.id, width = _ref.width, minWidth = _ref.minWidth, maxWidth = _ref.maxWidth; if (columns) { columns = columns.map(function (column) { return getSizesForColumn(column, columnMeasurements, defaultFlex, api); }).filter(Boolean); if (!columns.length) { return false; } var flex = sum(columns.map(function (col) { return col.flex; })); var _width = sum(columns.map(function (col) { return col.width; })); var _maxWidth = sum(columns.map(function (col) { return col.maxWidth; })); return { flex: flex, width: _width, maxWidth: _maxWidth }; } return { flex: width ? 0 : defaultFlex, width: width === "auto" ? columnMeasurements[id] || defaultFlex : getFirstDefined(width, minWidth, defaultFlex), maxWidth: maxWidth }; } // const resetRefs = () => { // if (debug) console.info("resetRefs"); // renderedCellInfoRef.current = {}; // }; // const calculateAutoWidths = () => { // RAF(() => { // const newColumnMeasurements = {}; // Object.values(renderedCellInfoRef.current).forEach(({ column, el }) => { // if (!el) { // return; // } // let measurement = 0; // const measureChildren = children => { // if (children) { // [].slice.call(children).forEach(child => { // measurement = Math.max( // measurement, // Math.ceil(child.offsetWidth) || 0 // ); // measureChildren(child.children); // }); // } // return measurement; // }; // const parentDims = getElementDimensions(el); // measureChildren(el.children); // newColumnMeasurements[column.id] = Math.max( // newColumnMeasurements[column.id] || 0, // measurement + parentDims.paddingLeft + parentDims.paddingRight // ); // }); // const oldKeys = Object.keys(columnMeasurements); // const newKeys = Object.keys(newColumnMeasurements); // const needsUpdate = // oldKeys.length !== newKeys.length || // oldKeys.some(key => { // return columnMeasurements[key] !== newColumnMeasurements[key]; // }); // if (needsUpdate) { // setState(old => { // return { // ...old, // columnMeasurements: newColumnMeasurements // }; // }, actions.updateAutoWidth); // } // }); // }; //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/hooks/useFlexLayout.js"],"names":["useMemo","useState","PropTypes","getFirstDefined","sum","propTypes","defaultFlex","number","actions","useFlexLayout","checkPropTypes","props","hooks","columnsHooks","columns","getRowProps","getHeaderRowProps","getHeaderProps","getCellProps","push","api","visibleColumns","filter","column","visible","show","columnMeasurements","sumWidth","forEach","getSizesForColumn","undefined","width","minWidth","rowStyles","style","display","boxSizing","getStylesForColumn","cell","flex","maxWidth","id","map","Boolean","length","col"],"mappings":"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","file":"useFlexLayout.js","sourcesContent":["import { useMemo, useState } from \"react\";\nimport PropTypes from \"prop-types\";\n\nimport { getFirstDefined, sum } from \"../utils\";\n\nconst propTypes = {\n  defaultFlex: PropTypes.number\n};\n\nexport const actions = {};\n\nexport const useFlexLayout = props => {\n  // Validate props\n  PropTypes.checkPropTypes(propTypes, props, \"property\", \"useFlexLayout\");\n\n  const {\n    defaultFlex = 1,\n    hooks: {\n      columns: columnsHooks,\n      getRowProps,\n      getHeaderRowProps,\n      getHeaderProps,\n      getCellProps\n    }\n  } = props;\n\n  columnsHooks.push((columns, api) => {\n    const visibleColumns = columns.filter(column => {\n      column.visible =\n        typeof column.show === \"function\" ? column.show(api) : !!column.show;\n      return column.visible;\n    });\n\n    const columnMeasurements = {};\n\n    let sumWidth = 0;\n    visibleColumns.forEach(column => {\n      const { width, minWidth } = getSizesForColumn(\n        column,\n        defaultFlex,\n        undefined,\n        undefined,\n        api\n      );\n      if (width) {\n        sumWidth += width;\n      } else if (minWidth) {\n        sumWidth += minWidth;\n      } else {\n        sumWidth += defaultFlex;\n      }\n    });\n\n    const rowStyles = {\n      style: {\n        display: \"flex\",\n        minWidth: `${sumWidth}px`\n      }\n    };\n\n    api.rowStyles = rowStyles;\n\n    getRowProps.push(() => rowStyles);\n    getHeaderRowProps.push(() => rowStyles);\n\n    getHeaderProps.push(column => ({\n      style: {\n        boxSizing: \"border-box\",\n        ...getStylesForColumn(column, columnMeasurements, defaultFlex, api)\n      }\n      // [refKey]: el => {\n      //   renderedCellInfoRef.current[key] = {\n      //     column,\n      //     el\n      //   };\n      // },\n    }));\n\n    getCellProps.push(cell => {\n      return {\n        style: {\n          display: \"block\",\n          boxSizing: \"border-box\",\n          ...getStylesForColumn(\n            cell.column,\n            columnMeasurements,\n            defaultFlex,\n            undefined,\n            api\n          )\n        }\n        // [refKey]: el => {\n        //   renderedCellInfoRef.current[columnPathStr] = {\n        //     column,\n        //     el\n        //   };\n        // }\n      };\n    });\n\n    return columns;\n  });\n\n  return props;\n};\n\n// Utils\n\nfunction getStylesForColumn(column, columnMeasurements, defaultFlex, api) {\n  const { flex, width, maxWidth } = getSizesForColumn(\n    column,\n    columnMeasurements,\n    defaultFlex,\n    api\n  );\n\n  return {\n    flex: `${flex} 0 auto`,\n    width: `${width}px`,\n    maxWidth: `${maxWidth}px`\n  };\n}\n\nfunction getSizesForColumn(\n  { columns, id, width, minWidth, maxWidth },\n  columnMeasurements,\n  defaultFlex,\n  api\n) {\n  if (columns) {\n    columns = columns\n      .map(column =>\n        getSizesForColumn(column, columnMeasurements, defaultFlex, api)\n      )\n      .filter(Boolean);\n\n    if (!columns.length) {\n      return false;\n    }\n\n    const flex = sum(columns.map(col => col.flex));\n    const width = sum(columns.map(col => col.width));\n    const maxWidth = sum(columns.map(col => col.maxWidth));\n\n    return {\n      flex,\n      width,\n      maxWidth\n    };\n  }\n\n  return {\n    flex: width ? 0 : defaultFlex,\n    width:\n      width === \"auto\"\n        ? columnMeasurements[id] || defaultFlex\n        : getFirstDefined(width, minWidth, defaultFlex),\n    maxWidth\n  };\n}\n\n// const resetRefs = () => {\n//   if (debug) console.info(\"resetRefs\");\n//   renderedCellInfoRef.current = {};\n// };\n\n// const calculateAutoWidths = () => {\n//   RAF(() => {\n//     const newColumnMeasurements = {};\n//     Object.values(renderedCellInfoRef.current).forEach(({ column, el }) => {\n//       if (!el) {\n//         return;\n//       }\n\n//       let measurement = 0;\n\n//       const measureChildren = children => {\n//         if (children) {\n//           [].slice.call(children).forEach(child => {\n//             measurement = Math.max(\n//               measurement,\n//               Math.ceil(child.offsetWidth) || 0\n//             );\n//             measureChildren(child.children);\n//           });\n//         }\n//         return measurement;\n//       };\n\n//       const parentDims = getElementDimensions(el);\n//       measureChildren(el.children);\n\n//       newColumnMeasurements[column.id] = Math.max(\n//         newColumnMeasurements[column.id] || 0,\n//         measurement + parentDims.paddingLeft + parentDims.paddingRight\n//       );\n//     });\n\n//     const oldKeys = Object.keys(columnMeasurements);\n//     const newKeys = Object.keys(newColumnMeasurements);\n\n//     const needsUpdate =\n//       oldKeys.length !== newKeys.length ||\n//       oldKeys.some(key => {\n//         return columnMeasurements[key] !== newColumnMeasurements[key];\n//       });\n\n//     if (needsUpdate) {\n//       setState(old => {\n//         return {\n//           ...old,\n//           columnMeasurements: newColumnMeasurements\n//         };\n//       }, actions.updateAutoWidth);\n//     }\n//   });\n// };\n"]}