UNPKG

react-beautiful-dnd

Version:

Beautiful, accessible drag and drop for lists with React.js

41 lines (35 loc) 1.17 kB
// @flow import type { Position, Spacing, } from '../types'; // expands a spacing export const add = (spacing1: Spacing, spacing2: Spacing): Spacing => ({ top: spacing1.top + spacing2.top, left: spacing1.left + spacing2.left, right: spacing1.right + spacing2.right, bottom: spacing1.bottom + spacing2.bottom, }); export const addPosition = (spacing: Spacing, position: Position): Spacing => ({ ...spacing, right: spacing.right + position.x, bottom: spacing.bottom + position.y, }); export const isEqual = (spacing1: Spacing, spacing2: Spacing): boolean => ( spacing1.top === spacing2.top && spacing1.right === spacing2.right && spacing1.bottom === spacing2.bottom && spacing1.left === spacing2.left ); export const offset = (spacing: Spacing, point: Position): Spacing => ({ top: spacing.top + point.y, right: spacing.right + point.x, bottom: spacing.bottom + point.y, left: spacing.left + point.x, }); export const getCorners = (spacing: Spacing): Position[] => [ { x: spacing.left, y: spacing.top }, { x: spacing.right, y: spacing.top }, { x: spacing.left, y: spacing.bottom }, { x: spacing.right, y: spacing.bottom }, ];