flip.js 14 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889
  1. /**
  2. * @fileoverview added by tsickle
  3. * @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
  4. */
  5. import { computeAutoPlacement, getBoundaries, getClientRect, getOppositeVariation, getTargetOffsets, isModifierEnabled } from '../utils';
  6. /**
  7. * @param {?} data
  8. * @return {?}
  9. */
  10. export function flip(data) {
  11. data.offsets.target = getClientRect(data.offsets.target);
  12. if (!isModifierEnabled(data.options, 'flip')) {
  13. data.offsets.target = Object.assign({}, data.offsets.target, getTargetOffsets(data.instance.target, data.offsets.host, data.placement));
  14. return data;
  15. }
  16. /** @type {?} */
  17. const boundaries = getBoundaries(data.instance.target, data.instance.host, 0, // padding
  18. 'viewport', false // positionFixed
  19. );
  20. /** @type {?} */
  21. let placement = data.placement.split(' ')[0];
  22. /** @type {?} */
  23. let variation = data.placement.split(' ')[1] || '';
  24. /** @type {?} */
  25. const offsetsHost = data.offsets.host;
  26. /** @type {?} */
  27. const target = data.instance.target;
  28. /** @type {?} */
  29. const host = data.instance.host;
  30. /** @type {?} */
  31. const adaptivePosition = computeAutoPlacement('auto', offsetsHost, target, host, data.options.allowedPositions);
  32. /** @type {?} */
  33. const flipOrder = [placement, adaptivePosition];
  34. /* tslint:disable-next-line: cyclomatic-complexity */
  35. flipOrder.forEach((/**
  36. * @param {?} step
  37. * @param {?} index
  38. * @return {?}
  39. */
  40. (step, index) => {
  41. if (placement !== step || flipOrder.length === index + 1) {
  42. return data;
  43. }
  44. placement = data.placement.split(' ')[0];
  45. // using floor because the host offsets may contain decimals we are not going to consider here
  46. /** @type {?} */
  47. const overlapsRef = (placement === 'left' &&
  48. Math.floor(data.offsets.target.right) > Math.floor(data.offsets.host.left)) ||
  49. (placement === 'right' &&
  50. Math.floor(data.offsets.target.left) < Math.floor(data.offsets.host.right)) ||
  51. (placement === 'top' &&
  52. Math.floor(data.offsets.target.bottom) > Math.floor(data.offsets.host.top)) ||
  53. (placement === 'bottom' &&
  54. Math.floor(data.offsets.target.top) < Math.floor(data.offsets.host.bottom));
  55. /** @type {?} */
  56. const overflowsLeft = Math.floor(data.offsets.target.left) < Math.floor(boundaries.left);
  57. /** @type {?} */
  58. const overflowsRight = Math.floor(data.offsets.target.right) > Math.floor(boundaries.right);
  59. /** @type {?} */
  60. const overflowsTop = Math.floor(data.offsets.target.top) < Math.floor(boundaries.top);
  61. /** @type {?} */
  62. const overflowsBottom = Math.floor(data.offsets.target.bottom) > Math.floor(boundaries.bottom);
  63. /** @type {?} */
  64. const overflowsBoundaries = (placement === 'left' && overflowsLeft) ||
  65. (placement === 'right' && overflowsRight) ||
  66. (placement === 'top' && overflowsTop) ||
  67. (placement === 'bottom' && overflowsBottom);
  68. // flip the variation if required
  69. /** @type {?} */
  70. const isVertical = ['top', 'bottom'].indexOf(placement) !== -1;
  71. /** @type {?} */
  72. const flippedVariation = ((isVertical && variation === 'left' && overflowsLeft) ||
  73. (isVertical && variation === 'right' && overflowsRight) ||
  74. (!isVertical && variation === 'left' && overflowsTop) ||
  75. (!isVertical && variation === 'right' && overflowsBottom));
  76. if (overlapsRef || overflowsBoundaries || flippedVariation) {
  77. if (overlapsRef || overflowsBoundaries) {
  78. placement = flipOrder[index + 1];
  79. }
  80. if (flippedVariation) {
  81. variation = getOppositeVariation(variation);
  82. }
  83. data.placement = placement + (variation ? ` ${variation}` : '');
  84. data.offsets.target = Object.assign({}, data.offsets.target, getTargetOffsets(data.instance.target, data.offsets.host, data.placement));
  85. }
  86. }));
  87. return data;
  88. }
  89. //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"flip.js","sourceRoot":"ng://ngx-bootstrap/positioning/","sources":["modifiers/flip.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  computeAutoPlacement,\n  getBoundaries,\n  getClientRect,\n  getOppositeVariation,\n  getTargetOffsets,\n  isModifierEnabled\n} from '../utils';\n\nimport { Data } from '../models';\n\nexport function flip(data: Data): Data {\n  data.offsets.target = getClientRect(data.offsets.target);\n\n  if (!isModifierEnabled(data.options, 'flip')) {\n\n    data.offsets.target = {\n      ...data.offsets.target,\n      ...getTargetOffsets(\n        data.instance.target,\n        data.offsets.host,\n        data.placement\n      )\n    };\n\n    return data;\n  }\n\n  const boundaries = getBoundaries(\n    data.instance.target,\n    data.instance.host,\n    0, // padding\n    'viewport',\n    false // positionFixed\n  );\n\n  let placement = data.placement.split(' ')[0];\n  let variation = data.placement.split(' ')[1] || '';\n\n  const offsetsHost = data.offsets.host;\n  const target = data.instance.target;\n  const host = data.instance.host;\n\n  const adaptivePosition = computeAutoPlacement('auto', offsetsHost, target, host, data.options.allowedPositions);\n  const flipOrder = [placement, adaptivePosition];\n\n  /* tslint:disable-next-line: cyclomatic-complexity */\n  flipOrder.forEach((step, index) => {\n    if (placement !== step || flipOrder.length === index + 1) {\n      return data;\n    }\n\n    placement = data.placement.split(' ')[0];\n\n    // using floor because the host offsets may contain decimals we are not going to consider here\n    const overlapsRef =\n      (placement === 'left' &&\n        Math.floor(data.offsets.target.right) > Math.floor(data.offsets.host.left)) ||\n      (placement === 'right' &&\n        Math.floor(data.offsets.target.left) < Math.floor(data.offsets.host.right)) ||\n      (placement === 'top' &&\n        Math.floor(data.offsets.target.bottom) > Math.floor(data.offsets.host.top)) ||\n      (placement === 'bottom' &&\n        Math.floor(data.offsets.target.top) < Math.floor(data.offsets.host.bottom));\n\n    const overflowsLeft = Math.floor(data.offsets.target.left) < Math.floor(boundaries.left);\n    const overflowsRight = Math.floor(data.offsets.target.right) > Math.floor(boundaries.right);\n    const overflowsTop = Math.floor(data.offsets.target.top) < Math.floor(boundaries.top);\n    const overflowsBottom = Math.floor(data.offsets.target.bottom) > Math.floor(boundaries.bottom);\n\n    const overflowsBoundaries =\n      (placement === 'left' && overflowsLeft) ||\n      (placement === 'right' && overflowsRight) ||\n      (placement === 'top' && overflowsTop) ||\n      (placement === 'bottom' && overflowsBottom);\n\n    // flip the variation if required\n    const isVertical = ['top', 'bottom'].indexOf(placement) !== -1;\n    const flippedVariation =\n      ((isVertical && variation === 'left' && overflowsLeft) ||\n        (isVertical && variation === 'right' && overflowsRight) ||\n        (!isVertical && variation === 'left' && overflowsTop) ||\n        (!isVertical && variation === 'right' && overflowsBottom));\n\n    if (overlapsRef || overflowsBoundaries || flippedVariation) {\n      if (overlapsRef || overflowsBoundaries) {\n        placement = flipOrder[index + 1];\n      }\n\n      if (flippedVariation) {\n        variation = getOppositeVariation(variation);\n      }\n\n      data.placement = placement + (variation ? ` ${variation}` : '');\n\n      data.offsets.target = {\n        ...data.offsets.target,\n        ...getTargetOffsets(\n          data.instance.target,\n          data.offsets.host,\n          data.placement\n        )\n      };\n    }\n  });\n\n  return data;\n}\n"]}