sort.js 946 B

123456789101112131415161718192021222324
  1. export function quickSort(a) {
  2. return a.length <= 1 ? a : quickSort(a.slice(1).filter(item => item <= a[0])).concat(a[0], quickSort(a.slice(1).filter(item => item > a[0])));
  3. }
  4. export const sortLayout = (layout) => {
  5. return [].concat(layout).sort((a, b) => {
  6. if (a.GridY > b.GridY || (a.GridY === b.GridY && a.GridX > b.GridX)) {
  7. if (a.static)
  8. return 0; //为了静态,排序的时候尽量把静态的放在前面
  9. return 1;
  10. }
  11. else if (a.GridY === b.GridY && a.GridX === b.GridX) {
  12. return 0;
  13. }
  14. return -1;
  15. });
  16. };
  17. export const getMaxContainerHeight = (layout, elementHeight = 30, elementMarginBottom = 10) => {
  18. const ar = layout.map((item) => {
  19. return item.GridY + item.h;
  20. });
  21. const h = quickSort(ar)[ar.length - 1];
  22. const height = h * (elementHeight + elementMarginBottom) + elementMarginBottom;
  23. return height;
  24. };