math.js 22 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271
  1. /**
  2. * @fileoverview added by tsickle
  3. * @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
  4. */
  5. import * as tslib_1 from "tslib";
  6. import { columnsByPin, columnsTotalWidth } from './column';
  7. /**
  8. * Calculates the Total Flex Grow
  9. * @param {?} columns
  10. * @return {?}
  11. */
  12. export function getTotalFlexGrow(columns) {
  13. var e_1, _a;
  14. /** @type {?} */
  15. var totalFlexGrow = 0;
  16. try {
  17. for (var columns_1 = tslib_1.__values(columns), columns_1_1 = columns_1.next(); !columns_1_1.done; columns_1_1 = columns_1.next()) {
  18. var c = columns_1_1.value;
  19. totalFlexGrow += c.flexGrow || 0;
  20. }
  21. }
  22. catch (e_1_1) { e_1 = { error: e_1_1 }; }
  23. finally {
  24. try {
  25. if (columns_1_1 && !columns_1_1.done && (_a = columns_1.return)) _a.call(columns_1);
  26. }
  27. finally { if (e_1) throw e_1.error; }
  28. }
  29. return totalFlexGrow;
  30. }
  31. /**
  32. * Adjusts the column widths.
  33. * Inspired by: https://github.com/facebook/fixed-data-table/blob/master/src/FixedDataTableWidthHelper.js
  34. * @param {?} allColumns
  35. * @param {?} expectedWidth
  36. * @return {?}
  37. */
  38. export function adjustColumnWidths(allColumns, expectedWidth) {
  39. /** @type {?} */
  40. var columnsWidth = columnsTotalWidth(allColumns);
  41. /** @type {?} */
  42. var totalFlexGrow = getTotalFlexGrow(allColumns);
  43. /** @type {?} */
  44. var colsByGroup = columnsByPin(allColumns);
  45. if (columnsWidth !== expectedWidth) {
  46. scaleColumns(colsByGroup, expectedWidth, totalFlexGrow);
  47. }
  48. }
  49. /**
  50. * Resizes columns based on the flexGrow property, while respecting manually set widths
  51. * @param {?} colsByGroup
  52. * @param {?} maxWidth
  53. * @param {?} totalFlexGrow
  54. * @return {?}
  55. */
  56. function scaleColumns(colsByGroup, maxWidth, totalFlexGrow) {
  57. var e_2, _a, e_3, _b;
  58. // calculate total width and flexgrow points for coulumns that can be resized
  59. for (var attr in colsByGroup) {
  60. try {
  61. for (var _c = (e_2 = void 0, tslib_1.__values(colsByGroup[attr])), _d = _c.next(); !_d.done; _d = _c.next()) {
  62. var column = _d.value;
  63. if (!column.canAutoResize) {
  64. maxWidth -= column.width;
  65. totalFlexGrow -= column.flexGrow ? column.flexGrow : 0;
  66. }
  67. else {
  68. column.width = 0;
  69. }
  70. }
  71. }
  72. catch (e_2_1) { e_2 = { error: e_2_1 }; }
  73. finally {
  74. try {
  75. if (_d && !_d.done && (_a = _c.return)) _a.call(_c);
  76. }
  77. finally { if (e_2) throw e_2.error; }
  78. }
  79. }
  80. /** @type {?} */
  81. var hasMinWidth = {};
  82. /** @type {?} */
  83. var remainingWidth = maxWidth;
  84. // resize columns until no width is left to be distributed
  85. do {
  86. /** @type {?} */
  87. var widthPerFlexPoint = remainingWidth / totalFlexGrow;
  88. remainingWidth = 0;
  89. for (var attr in colsByGroup) {
  90. try {
  91. for (var _e = (e_3 = void 0, tslib_1.__values(colsByGroup[attr])), _f = _e.next(); !_f.done; _f = _e.next()) {
  92. var column = _f.value;
  93. // if the column can be resize and it hasn't reached its minimum width yet
  94. if (column.canAutoResize && !hasMinWidth[column.prop]) {
  95. /** @type {?} */
  96. var newWidth = column.width + column.flexGrow * widthPerFlexPoint;
  97. if (column.minWidth !== undefined && newWidth < column.minWidth) {
  98. remainingWidth += newWidth - column.minWidth;
  99. column.width = column.minWidth;
  100. hasMinWidth[column.prop] = true;
  101. }
  102. else {
  103. column.width = newWidth;
  104. }
  105. }
  106. }
  107. }
  108. catch (e_3_1) { e_3 = { error: e_3_1 }; }
  109. finally {
  110. try {
  111. if (_f && !_f.done && (_b = _e.return)) _b.call(_e);
  112. }
  113. finally { if (e_3) throw e_3.error; }
  114. }
  115. }
  116. } while (remainingWidth !== 0);
  117. }
  118. /**
  119. * Forces the width of the columns to
  120. * distribute equally but overflowing when necessary
  121. *
  122. * Rules:
  123. *
  124. * - If combined withs are less than the total width of the grid,
  125. * proportion the widths given the min / max / normal widths to fill the width.
  126. *
  127. * - If the combined widths, exceed the total width of the grid,
  128. * use the standard widths.
  129. *
  130. * - If a column is resized, it should always use that width
  131. *
  132. * - The proportional widths should never fall below min size if specified.
  133. *
  134. * - If the grid starts off small but then becomes greater than the size ( + / - )
  135. * the width should use the original width; not the newly proportioned widths.
  136. * @param {?} allColumns
  137. * @param {?} expectedWidth
  138. * @param {?} startIdx
  139. * @param {?} allowBleed
  140. * @param {?=} defaultColWidth
  141. * @return {?}
  142. */
  143. export function forceFillColumnWidths(allColumns, expectedWidth, startIdx, allowBleed, defaultColWidth) {
  144. var e_4, _a, e_5, _b;
  145. if (defaultColWidth === void 0) { defaultColWidth = 300; }
  146. /** @type {?} */
  147. var columnsToResize = allColumns.slice(startIdx + 1, allColumns.length).filter((/**
  148. * @param {?} c
  149. * @return {?}
  150. */
  151. function (c) {
  152. return c.canAutoResize !== false;
  153. }));
  154. try {
  155. for (var columnsToResize_1 = tslib_1.__values(columnsToResize), columnsToResize_1_1 = columnsToResize_1.next(); !columnsToResize_1_1.done; columnsToResize_1_1 = columnsToResize_1.next()) {
  156. var column = columnsToResize_1_1.value;
  157. if (!column.$$oldWidth) {
  158. column.$$oldWidth = column.width;
  159. }
  160. }
  161. }
  162. catch (e_4_1) { e_4 = { error: e_4_1 }; }
  163. finally {
  164. try {
  165. if (columnsToResize_1_1 && !columnsToResize_1_1.done && (_a = columnsToResize_1.return)) _a.call(columnsToResize_1);
  166. }
  167. finally { if (e_4) throw e_4.error; }
  168. }
  169. /** @type {?} */
  170. var additionWidthPerColumn = 0;
  171. /** @type {?} */
  172. var exceedsWindow = false;
  173. /** @type {?} */
  174. var contentWidth = getContentWidth(allColumns, defaultColWidth);
  175. /** @type {?} */
  176. var remainingWidth = expectedWidth - contentWidth;
  177. /** @type {?} */
  178. var columnsProcessed = [];
  179. /** @type {?} */
  180. var remainingWidthLimit = 1;
  181. // This loop takes care of the
  182. do {
  183. additionWidthPerColumn = remainingWidth / columnsToResize.length;
  184. exceedsWindow = contentWidth >= expectedWidth;
  185. try {
  186. for (var columnsToResize_2 = (e_5 = void 0, tslib_1.__values(columnsToResize)), columnsToResize_2_1 = columnsToResize_2.next(); !columnsToResize_2_1.done; columnsToResize_2_1 = columnsToResize_2.next()) {
  187. var column = columnsToResize_2_1.value;
  188. if (exceedsWindow && allowBleed) {
  189. column.width = column.$$oldWidth || column.width || defaultColWidth;
  190. }
  191. else {
  192. /** @type {?} */
  193. var newSize = (column.width || defaultColWidth) + additionWidthPerColumn;
  194. if (column.minWidth && newSize < column.minWidth) {
  195. column.width = column.minWidth;
  196. columnsProcessed.push(column);
  197. }
  198. else if (column.maxWidth && newSize > column.maxWidth) {
  199. column.width = column.maxWidth;
  200. columnsProcessed.push(column);
  201. }
  202. else {
  203. column.width = newSize;
  204. }
  205. }
  206. column.width = Math.max(0, column.width);
  207. }
  208. }
  209. catch (e_5_1) { e_5 = { error: e_5_1 }; }
  210. finally {
  211. try {
  212. if (columnsToResize_2_1 && !columnsToResize_2_1.done && (_b = columnsToResize_2.return)) _b.call(columnsToResize_2);
  213. }
  214. finally { if (e_5) throw e_5.error; }
  215. }
  216. contentWidth = getContentWidth(allColumns);
  217. remainingWidth = expectedWidth - contentWidth;
  218. removeProcessedColumns(columnsToResize, columnsProcessed);
  219. } while (remainingWidth > remainingWidthLimit && columnsToResize.length !== 0);
  220. }
  221. /**
  222. * Remove the processed columns from the current active columns.
  223. * @param {?} columnsToResize
  224. * @param {?} columnsProcessed
  225. * @return {?}
  226. */
  227. function removeProcessedColumns(columnsToResize, columnsProcessed) {
  228. var e_6, _a;
  229. try {
  230. for (var columnsProcessed_1 = tslib_1.__values(columnsProcessed), columnsProcessed_1_1 = columnsProcessed_1.next(); !columnsProcessed_1_1.done; columnsProcessed_1_1 = columnsProcessed_1.next()) {
  231. var column = columnsProcessed_1_1.value;
  232. /** @type {?} */
  233. var index = columnsToResize.indexOf(column);
  234. columnsToResize.splice(index, 1);
  235. }
  236. }
  237. catch (e_6_1) { e_6 = { error: e_6_1 }; }
  238. finally {
  239. try {
  240. if (columnsProcessed_1_1 && !columnsProcessed_1_1.done && (_a = columnsProcessed_1.return)) _a.call(columnsProcessed_1);
  241. }
  242. finally { if (e_6) throw e_6.error; }
  243. }
  244. }
  245. /**
  246. * Gets the width of the columns
  247. * @param {?} allColumns
  248. * @param {?=} defaultColWidth
  249. * @return {?}
  250. */
  251. function getContentWidth(allColumns, defaultColWidth) {
  252. var e_7, _a;
  253. if (defaultColWidth === void 0) { defaultColWidth = 300; }
  254. /** @type {?} */
  255. var contentWidth = 0;
  256. try {
  257. for (var allColumns_1 = tslib_1.__values(allColumns), allColumns_1_1 = allColumns_1.next(); !allColumns_1_1.done; allColumns_1_1 = allColumns_1.next()) {
  258. var column = allColumns_1_1.value;
  259. contentWidth += column.width || defaultColWidth;
  260. }
  261. }
  262. catch (e_7_1) { e_7 = { error: e_7_1 }; }
  263. finally {
  264. try {
  265. if (allColumns_1_1 && !allColumns_1_1.done && (_a = allColumns_1.return)) _a.call(allColumns_1);
  266. }
  267. finally { if (e_7) throw e_7.error; }
  268. }
  269. return contentWidth;
  270. }
  271. //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"math.js","sourceRoot":"ng://@swimlane/ngx-datatable/","sources":["lib/utils/math.ts"],"names":[],"mappings":"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","sourcesContent":["import { columnsByPin, columnsTotalWidth } from './column';\n\n/**\n * Calculates the Total Flex Grow\n */\nexport function getTotalFlexGrow(columns: any[]) {\n  let totalFlexGrow = 0;\n\n  for (const c of columns) {\n    totalFlexGrow += c.flexGrow || 0;\n  }\n\n  return totalFlexGrow;\n}\n\n/**\n * Adjusts the column widths.\n * Inspired by: https://github.com/facebook/fixed-data-table/blob/master/src/FixedDataTableWidthHelper.js\n */\nexport function adjustColumnWidths(allColumns: any, expectedWidth: any) {\n  const columnsWidth = columnsTotalWidth(allColumns);\n  const totalFlexGrow = getTotalFlexGrow(allColumns);\n  const colsByGroup = columnsByPin(allColumns);\n\n  if (columnsWidth !== expectedWidth) {\n    scaleColumns(colsByGroup, expectedWidth, totalFlexGrow);\n  }\n}\n\n/**\n * Resizes columns based on the flexGrow property, while respecting manually set widths\n */\nfunction scaleColumns(colsByGroup: any, maxWidth: any, totalFlexGrow: any) {\n  // calculate total width and flexgrow points for coulumns that can be resized\n  for (const attr in colsByGroup) {\n    for (const column of colsByGroup[attr]) {\n      if (!column.canAutoResize) {\n        maxWidth -= column.width;\n        totalFlexGrow -= column.flexGrow ? column.flexGrow : 0;\n      } else {\n        column.width = 0;\n      }\n    }\n  }\n\n  const hasMinWidth = {};\n  let remainingWidth = maxWidth;\n\n  // resize columns until no width is left to be distributed\n  do {\n    const widthPerFlexPoint = remainingWidth / totalFlexGrow;\n    remainingWidth = 0;\n\n    for (const attr in colsByGroup) {\n      for (const column of colsByGroup[attr]) {\n        // if the column can be resize and it hasn't reached its minimum width yet\n        if (column.canAutoResize && !hasMinWidth[column.prop]) {\n          const newWidth = column.width + column.flexGrow * widthPerFlexPoint;\n          if (column.minWidth !== undefined && newWidth < column.minWidth) {\n            remainingWidth += newWidth - column.minWidth;\n            column.width = column.minWidth;\n            hasMinWidth[column.prop] = true;\n          } else {\n            column.width = newWidth;\n          }\n        }\n      }\n    }\n  } while (remainingWidth !== 0);\n}\n\n/**\n * Forces the width of the columns to\n * distribute equally but overflowing when necessary\n *\n * Rules:\n *\n *  - If combined withs are less than the total width of the grid,\n *    proportion the widths given the min / max / normal widths to fill the width.\n *\n *  - If the combined widths, exceed the total width of the grid,\n *    use the standard widths.\n *\n *  - If a column is resized, it should always use that width\n *\n *  - The proportional widths should never fall below min size if specified.\n *\n *  - If the grid starts off small but then becomes greater than the size ( + / - )\n *    the width should use the original width; not the newly proportioned widths.\n */\nexport function forceFillColumnWidths(\n  allColumns: any[],\n  expectedWidth: number,\n  startIdx: number,\n  allowBleed: boolean,\n  defaultColWidth: number = 300\n) {\n  const columnsToResize = allColumns.slice(startIdx + 1, allColumns.length).filter(c => {\n    return c.canAutoResize !== false;\n  });\n\n  for (const column of columnsToResize) {\n    if (!column.$$oldWidth) {\n      column.$$oldWidth = column.width;\n    }\n  }\n\n  let additionWidthPerColumn = 0;\n  let exceedsWindow = false;\n  let contentWidth = getContentWidth(allColumns, defaultColWidth);\n  let remainingWidth = expectedWidth - contentWidth;\n  const columnsProcessed: any[] = [];\n  const remainingWidthLimit = 1; // when to stop\n\n  // This loop takes care of the\n  do {\n    additionWidthPerColumn = remainingWidth / columnsToResize.length;\n    exceedsWindow = contentWidth >= expectedWidth;\n\n    for (const column of columnsToResize) {\n      if (exceedsWindow && allowBleed) {\n        column.width = column.$$oldWidth || column.width || defaultColWidth;\n      } else {\n        const newSize = (column.width || defaultColWidth) + additionWidthPerColumn;\n\n        if (column.minWidth && newSize < column.minWidth) {\n          column.width = column.minWidth;\n          columnsProcessed.push(column);\n        } else if (column.maxWidth && newSize > column.maxWidth) {\n          column.width = column.maxWidth;\n          columnsProcessed.push(column);\n        } else {\n          column.width = newSize;\n        }\n      }\n\n      column.width = Math.max(0, column.width);\n    }\n\n    contentWidth = getContentWidth(allColumns);\n    remainingWidth = expectedWidth - contentWidth;\n    removeProcessedColumns(columnsToResize, columnsProcessed);\n  } while (remainingWidth > remainingWidthLimit && columnsToResize.length !== 0);\n}\n\n/**\n * Remove the processed columns from the current active columns.\n */\nfunction removeProcessedColumns(columnsToResize: any[], columnsProcessed: any[]) {\n  for (const column of columnsProcessed) {\n    const index = columnsToResize.indexOf(column);\n    columnsToResize.splice(index, 1);\n  }\n}\n\n/**\n * Gets the width of the columns\n */\nfunction getContentWidth(allColumns: any, defaultColWidth: number = 300): number {\n  let contentWidth = 0;\n\n  for (const column of allColumns) {\n    contentWidth += column.width || defaultColWidth;\n  }\n\n  return contentWidth;\n}\n"]}