custom-app
Version:
ITIMS��Ʒ�鿪��ר��React���,�Dz��ý��ּ�dhcc-app���������
225 lines (184 loc) • 18.3 kB
JavaScript
;
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.useFlexLayout = exports.actions = undefined;
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 _react = require("react");
var _propTypes = require("prop-types");
var _propTypes2 = _interopRequireDefault(_propTypes);
var _utils = require("../utils");
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
var propTypes = {
defaultFlex: _propTypes2.default.number
};
var actions = exports.actions = {};
var useFlexLayout = exports.useFlexLayout = function useFlexLayout(props) {
// Validate props
_propTypes2.default.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 = (0, _utils.sum)(columns.map(function (col) {
return col.flex;
}));
var _width = (0, _utils.sum)(columns.map(function (col) {
return col.width;
}));
var _maxWidth = (0, _utils.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 : (0, _utils.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":["propTypes","defaultFlex","PropTypes","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"]}