@deephaven/grid 1.4.1-beta.2 → 1.4.1-react19.43
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/CellInputField.d.ts +0 -27
- package/dist/CellInputField.d.ts.map +1 -1
- package/dist/CellInputField.js +7 -31
- package/dist/CellInputField.js.map +1 -1
- package/dist/CellRenderer.js.map +1 -1
- package/dist/ColumnHeaderGroup.js.map +1 -1
- package/dist/DataBarCellRenderer.js +3 -5
- package/dist/DataBarCellRenderer.js.map +1 -1
- package/dist/DataBarGridModel.js.map +1 -1
- package/dist/DeletableGridModel.js.map +1 -1
- package/dist/EditableGridModel.js.map +1 -1
- package/dist/EventHandlerResult.js.map +1 -1
- package/dist/ExpandableGridModel.js.map +1 -1
- package/dist/Grid.d.ts +2 -0
- package/dist/Grid.d.ts.map +1 -1
- package/dist/Grid.js +28 -27
- package/dist/Grid.js.map +1 -1
- package/dist/GridAxisRange.js.map +1 -1
- package/dist/GridColorUtils.js.map +1 -1
- package/dist/GridMetricCalculator.js +20 -21
- package/dist/GridMetricCalculator.js.map +1 -1
- package/dist/GridMetrics.js.map +1 -1
- package/dist/GridModel.js.map +1 -1
- package/dist/GridMouseHandler.js +1 -3
- package/dist/GridMouseHandler.js.map +1 -1
- package/dist/GridRange.js +8 -9
- package/dist/GridRange.js.map +1 -1
- package/dist/GridRenderer.js +11 -12
- package/dist/GridRenderer.js.map +1 -1
- package/dist/GridRendererTypes.js.map +1 -1
- package/dist/GridTestUtils.js.map +1 -1
- package/dist/GridTheme.js.map +1 -1
- package/dist/GridUtils.d.ts +1 -2
- package/dist/GridUtils.d.ts.map +1 -1
- package/dist/GridUtils.js +2 -3
- package/dist/GridUtils.js.map +1 -1
- package/dist/KeyHandler.js +1 -3
- package/dist/KeyHandler.js.map +1 -1
- package/dist/MockDataBarGridModel.js +1 -2
- package/dist/MockDataBarGridModel.js.map +1 -1
- package/dist/MockGridData.js.map +1 -1
- package/dist/MockGridModel.js.map +1 -1
- package/dist/MockTreeGridModel.js +6 -8
- package/dist/MockTreeGridModel.js.map +1 -1
- package/dist/StaticDataGridModel.js.map +1 -1
- package/dist/TextCellRenderer.js +3 -5
- package/dist/TextCellRenderer.js.map +1 -1
- package/dist/ThemeContext.js.map +1 -1
- package/dist/TokenBoxCellRenderer.js.map +1 -1
- package/dist/ViewportDataGridModel.js +2 -2
- package/dist/ViewportDataGridModel.js.map +1 -1
- package/dist/errors/AssertionError.js.map +1 -1
- package/dist/errors/PasteError.js.map +1 -1
- package/dist/errors/assertIsDefined.js.map +1 -1
- package/dist/errors/index.js.map +1 -1
- package/dist/index.js.map +1 -1
- package/dist/key-handlers/EditKeyHandler.js.map +1 -1
- package/dist/key-handlers/PasteKeyHandler.js.map +1 -1
- package/dist/key-handlers/SelectionKeyHandler.js.map +1 -1
- package/dist/key-handlers/TreeKeyHandler.js.map +1 -1
- package/dist/key-handlers/index.js.map +1 -1
- package/dist/memoizeClear.js.map +1 -1
- package/dist/mouse-handlers/EditMouseHandler.js.map +1 -1
- package/dist/mouse-handlers/GridColumnMoveMouseHandler.js.map +1 -1
- package/dist/mouse-handlers/GridColumnSeparatorMouseHandler.js.map +1 -1
- package/dist/mouse-handlers/GridHorizontalScrollBarMouseHandler.js +1 -3
- package/dist/mouse-handlers/GridHorizontalScrollBarMouseHandler.js.map +1 -1
- package/dist/mouse-handlers/GridRowMoveMouseHandler.js.map +1 -1
- package/dist/mouse-handlers/GridRowSeparatorMouseHandler.js.map +1 -1
- package/dist/mouse-handlers/GridRowTreeMouseHandler.js.map +1 -1
- package/dist/mouse-handlers/GridScrollBarCornerMouseHandler.js.map +1 -1
- package/dist/mouse-handlers/GridSelectionMouseHandler.js +1 -3
- package/dist/mouse-handlers/GridSelectionMouseHandler.js.map +1 -1
- package/dist/mouse-handlers/GridSeparatorMouseHandler.js +5 -5
- package/dist/mouse-handlers/GridSeparatorMouseHandler.js.map +1 -1
- package/dist/mouse-handlers/GridTokenMouseHandler.js +2 -1
- package/dist/mouse-handlers/GridTokenMouseHandler.js.map +1 -1
- package/dist/mouse-handlers/GridVerticalScrollBarMouseHandler.js +1 -3
- package/dist/mouse-handlers/GridVerticalScrollBarMouseHandler.js.map +1 -1
- package/dist/mouse-handlers/index.js.map +1 -1
- package/package.json +4 -5
    
        package/dist/GridModel.js.map
    CHANGED
    
    | @@ -1 +1 @@ | |
| 1 | 
            -
            {"version":3,"file":"GridModel.js","names":["EventTarget","memoizeClear","GridUtils","LINK_TRUNCATION_LENGTH","GridModel","constructor","arguments","_defineProperty","text","visibleLength","length","findTokensWithProtocolInText","indexOfProceedingWhitespace","slice","search","lengthOfContent","Math","min","contentToCheckForLinks","substring","max","floatingTopRowCount","floatingBottomRowCount","floatingLeftColumnCount","floatingRightColumnCount","columnHeaderMaxDepth","truncationCharForCell","column","row","undefined","textAlignForCell","colorForCell","theme","textColor","backgroundColorForCell","colorForColumnHeader","depth","textForRowHeader","textForRowFooter","isColumnMovable","isRowMovable","getColumnHeaderGroup","modelIndex","getColumnHeaderParentGroup","tokensForCell","textForCell","getCachedTokensInText","renderTypeForCell"],"sources":["../src/GridModel.ts"],"sourcesContent":["import { EventTarget, type Event } from 'event-target-shim';\nimport type { IColumnHeaderGroup } from './ColumnHeaderGroup';\nimport { type ModelIndex } from './GridMetrics';\nimport {\n  type GridColor,\n  type GridTheme,\n  type NullableGridColor,\n} from './GridTheme';\nimport memoizeClear from './memoizeClear';\nimport GridUtils, { type Token } from './GridUtils';\nimport { type CellRenderType } from './CellRenderer';\n\nconst LINK_TRUNCATION_LENGTH = 5000;\n\n/* eslint class-methods-use-this: \"off\" */\n/* eslint no-unused-vars: \"off\" */\n/**\n * Model for a Grid\n * All of these methods should return very quickly, as they will be called many times in the render cycle.\n * If data needs to be loaded asynchronously, return something immediately, then trigger an event for the table to refresh (Not yet implemented).\n */\nabstract class GridModel<\n  TEventMap extends Record<string, Event<string>> = Record<\n    string,\n    Event<string>\n  >,\n  TMode extends 'standard' | 'strict' = 'standard',\n> extends EventTarget<TEventMap, TMode> {\n  /** Count of rows in the grid */\n  abstract get rowCount(): number;\n\n  /** Count of columns in the grid */\n  abstract get columnCount(): number;\n\n  /** Count of rows that are frozen (or 'floating') at the top */\n  get floatingTopRowCount(): number {\n    return 0;\n  }\n\n  /** Count of rows that are frozen at the bottom */\n  get floatingBottomRowCount(): number {\n    return 0;\n  }\n\n  /** Count of columns that are frozen (or 'floating') at the left */\n  get floatingLeftColumnCount(): number {\n    return 0;\n  }\n\n  /** Count of columns that are frozen (or 'floating') at the right */\n  get floatingRightColumnCount(): number {\n    return 0;\n  }\n\n  /**\n   * How many columns header levels are in the grid\n   * Used for column grouping where columns at depth 0 are the base columns\n   *\n   * A grid with 1-level grouping would have a columnHeaderDepth of 2\n   * and column headers at depths 0 and 1\n   */\n  get columnHeaderMaxDepth(): number {\n    return 1;\n  }\n\n  /**\n   * Get the text for the specified cell\n   * @param column Column to get the text for\n   * @param row Row to get the text for\n   * @returns Text for the specified cell\n   */\n  abstract textForCell(column: ModelIndex, row: ModelIndex): string;\n\n  /**\n   * Get the character to replace text when truncated for a specific cell.\n   * Leave undefined to show text truncated with ellipsis\n   * @param column Column to get the truncation character for\n   * @param row Row to get the truncation character for\n   * @returns Truncation character for the specified cell\n   */\n  truncationCharForCell(\n    column: ModelIndex,\n    row: ModelIndex\n  ): string | undefined {\n    return undefined;\n  }\n\n  /**\n   * Get the text alignment for the specified cell\n   * @param column Column to get the alignment for\n   * @param row Row to get the alignment for\n   * @returns Text alignment for the specified cell\n   */\n  textAlignForCell(column: ModelIndex, row: ModelIndex): CanvasTextAlign {\n    return 'left';\n  }\n\n  /**\n   * Get the color for the text in the specified cell\n   * @param column Column to get the color for\n   * @param row Row to get the color for\n   * @param theme Theme applied to the grid\n   * @returns Color for the text in the cell\n   */\n  colorForCell(\n    column: ModelIndex,\n    row: ModelIndex,\n    theme: GridTheme\n  ): GridColor {\n    return theme.textColor;\n  }\n\n  /**\n   * Get the background color for the cell\n   * @param column Column to get the background color for\n   * @param row Row to get the background color for\n   * @param theme Theme applied to the grid\n   * @returns Background color for the cell\n   */\n  backgroundColorForCell(\n    column: ModelIndex,\n    row: ModelIndex,\n    theme: GridTheme\n  ): NullableGridColor {\n    return null;\n  }\n\n  /**\n   * Text for the column header\n   * @param column Column to get the header for\n   * @param depth Depth to get the header text for. 0 is base columns\n   * @returns Text to put in the column header\n   */\n  abstract textForColumnHeader(\n    column: ModelIndex,\n    depth?: number\n  ): string | undefined;\n\n  /** Color for column header\n   * @param column Column to get the color for\n   * @param depth Header depth to get the color for\n   * @returns Color for the header at the depth or null\n   */\n  colorForColumnHeader(column: ModelIndex, depth = 0): string | null {\n    return null;\n  }\n\n  /**\n   * Text for the row header\n   * @param row Row to get the header for\n   * @returns Text to put in the row header\n   */\n  textForRowHeader(row: ModelIndex): string {\n    return '';\n  }\n\n  /**\n   * Text for the row footer\n   * @param row Row to get the footer for\n   * @returns Text to put in the row footer\n   */\n  textForRowFooter(row: ModelIndex): string {\n    return '';\n  }\n\n  /**\n   * @param column Column to check\n   * @returns True if the column is movable\n   */\n  isColumnMovable(column: ModelIndex, depth = 0): boolean {\n    return true;\n  }\n\n  /**\n   * @param row Row to check\n   * @returns True if the row is movable\n   */\n  isRowMovable(row: ModelIndex): boolean {\n    return true;\n  }\n\n  getColumnHeaderGroup(\n    modelIndex: ModelIndex,\n    depth: number\n  ): IColumnHeaderGroup | undefined {\n    return undefined;\n  }\n\n  getColumnHeaderParentGroup(\n    modelIndex: ModelIndex,\n    depth: number\n  ): IColumnHeaderGroup | undefined {\n    return undefined;\n  }\n\n  /**\n   * Gets the tokens in the cell at column and row, based on the visible text\n   * @param column The model column\n   * @param row The model row\n   * @param visibleLength The length of the visible text\n   * @returns An array of Tokens in the cell\n   */\n  tokensForCell(\n    column: ModelIndex,\n    row: ModelIndex,\n    visibleLength: number = LINK_TRUNCATION_LENGTH\n  ): Token[] {\n    const text = this.textForCell(column, row);\n    return this.getCachedTokensInText(text, visibleLength);\n  }\n\n  getCachedTokensInText = memoizeClear(\n    (text: string, visibleLength: number): Token[] => {\n      // If no text is truncated, then directly search in text\n      if (visibleLength >= text.length) {\n        return GridUtils.findTokensWithProtocolInText(text);\n      }\n\n      // To check for links, we should check to the first space after the truncatedText length\n      const indexOfProceedingWhitespace = text\n        .slice(visibleLength - 1, LINK_TRUNCATION_LENGTH)\n        .search(/\\s/); // index or -1 if not found\n\n      let lengthOfContent = visibleLength + indexOfProceedingWhitespace;\n      // If it doesn't exist, set lengthOfContent to the minimum between length of the original text and 5000\n      if (indexOfProceedingWhitespace === -1) {\n        lengthOfContent = Math.min(LINK_TRUNCATION_LENGTH, text.length);\n      }\n      const contentToCheckForLinks = text.substring(0, lengthOfContent);\n\n      return GridUtils.findTokensWithProtocolInText(contentToCheckForLinks);\n    },\n    { max: 10000 }\n  );\n\n  renderTypeForCell(column: ModelIndex, row: ModelIndex): CellRenderType {\n    return 'text';\n  }\n}\n\nexport default GridModel;\n"],"mappings":"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"}
         | 
| 1 | 
            +
            {"version":3,"file":"GridModel.js","names":["EventTarget","memoizeClear","GridUtils","LINK_TRUNCATION_LENGTH","GridModel","constructor","arguments","_defineProperty","text","visibleLength","length","findTokensWithProtocolInText","indexOfProceedingWhitespace","slice","search","lengthOfContent","Math","min","contentToCheckForLinks","substring","max","floatingTopRowCount","floatingBottomRowCount","floatingLeftColumnCount","floatingRightColumnCount","columnHeaderMaxDepth","truncationCharForCell","column","row","undefined","textAlignForCell","colorForCell","theme","textColor","backgroundColorForCell","colorForColumnHeader","depth","textForRowHeader","textForRowFooter","isColumnMovable","isRowMovable","getColumnHeaderGroup","modelIndex","getColumnHeaderParentGroup","tokensForCell","textForCell","getCachedTokensInText","renderTypeForCell"],"sources":["../src/GridModel.ts"],"sourcesContent":["import { EventTarget, type Event } from 'event-target-shim';\nimport type { IColumnHeaderGroup } from './ColumnHeaderGroup';\nimport { type ModelIndex } from './GridMetrics';\nimport {\n  type GridColor,\n  type GridTheme,\n  type NullableGridColor,\n} from './GridTheme';\nimport memoizeClear from './memoizeClear';\nimport GridUtils, { type Token } from './GridUtils';\nimport { type CellRenderType } from './CellRenderer';\n\nconst LINK_TRUNCATION_LENGTH = 5000;\n\n/* eslint class-methods-use-this: \"off\" */\n/* eslint no-unused-vars: \"off\" */\n/**\n * Model for a Grid\n * All of these methods should return very quickly, as they will be called many times in the render cycle.\n * If data needs to be loaded asynchronously, return something immediately, then trigger an event for the table to refresh (Not yet implemented).\n */\nabstract class GridModel<\n  TEventMap extends Record<string, Event<string>> = Record<\n    string,\n    Event<string>\n  >,\n  TMode extends 'standard' | 'strict' = 'standard',\n> extends EventTarget<TEventMap, TMode> {\n  /** Count of rows in the grid */\n  abstract get rowCount(): number;\n\n  /** Count of columns in the grid */\n  abstract get columnCount(): number;\n\n  /** Count of rows that are frozen (or 'floating') at the top */\n  get floatingTopRowCount(): number {\n    return 0;\n  }\n\n  /** Count of rows that are frozen at the bottom */\n  get floatingBottomRowCount(): number {\n    return 0;\n  }\n\n  /** Count of columns that are frozen (or 'floating') at the left */\n  get floatingLeftColumnCount(): number {\n    return 0;\n  }\n\n  /** Count of columns that are frozen (or 'floating') at the right */\n  get floatingRightColumnCount(): number {\n    return 0;\n  }\n\n  /**\n   * How many columns header levels are in the grid\n   * Used for column grouping where columns at depth 0 are the base columns\n   *\n   * A grid with 1-level grouping would have a columnHeaderDepth of 2\n   * and column headers at depths 0 and 1\n   */\n  get columnHeaderMaxDepth(): number {\n    return 1;\n  }\n\n  /**\n   * Get the text for the specified cell\n   * @param column Column to get the text for\n   * @param row Row to get the text for\n   * @returns Text for the specified cell\n   */\n  abstract textForCell(column: ModelIndex, row: ModelIndex): string;\n\n  /**\n   * Get the character to replace text when truncated for a specific cell.\n   * Leave undefined to show text truncated with ellipsis\n   * @param column Column to get the truncation character for\n   * @param row Row to get the truncation character for\n   * @returns Truncation character for the specified cell\n   */\n  truncationCharForCell(\n    column: ModelIndex,\n    row: ModelIndex\n  ): string | undefined {\n    return undefined;\n  }\n\n  /**\n   * Get the text alignment for the specified cell\n   * @param column Column to get the alignment for\n   * @param row Row to get the alignment for\n   * @returns Text alignment for the specified cell\n   */\n  textAlignForCell(column: ModelIndex, row: ModelIndex): CanvasTextAlign {\n    return 'left';\n  }\n\n  /**\n   * Get the color for the text in the specified cell\n   * @param column Column to get the color for\n   * @param row Row to get the color for\n   * @param theme Theme applied to the grid\n   * @returns Color for the text in the cell\n   */\n  colorForCell(\n    column: ModelIndex,\n    row: ModelIndex,\n    theme: GridTheme\n  ): GridColor {\n    return theme.textColor;\n  }\n\n  /**\n   * Get the background color for the cell\n   * @param column Column to get the background color for\n   * @param row Row to get the background color for\n   * @param theme Theme applied to the grid\n   * @returns Background color for the cell\n   */\n  backgroundColorForCell(\n    column: ModelIndex,\n    row: ModelIndex,\n    theme: GridTheme\n  ): NullableGridColor {\n    return null;\n  }\n\n  /**\n   * Text for the column header\n   * @param column Column to get the header for\n   * @param depth Depth to get the header text for. 0 is base columns\n   * @returns Text to put in the column header\n   */\n  abstract textForColumnHeader(\n    column: ModelIndex,\n    depth?: number\n  ): string | undefined;\n\n  /** Color for column header\n   * @param column Column to get the color for\n   * @param depth Header depth to get the color for\n   * @returns Color for the header at the depth or null\n   */\n  colorForColumnHeader(column: ModelIndex, depth = 0): string | null {\n    return null;\n  }\n\n  /**\n   * Text for the row header\n   * @param row Row to get the header for\n   * @returns Text to put in the row header\n   */\n  textForRowHeader(row: ModelIndex): string {\n    return '';\n  }\n\n  /**\n   * Text for the row footer\n   * @param row Row to get the footer for\n   * @returns Text to put in the row footer\n   */\n  textForRowFooter(row: ModelIndex): string {\n    return '';\n  }\n\n  /**\n   * @param column Column to check\n   * @returns True if the column is movable\n   */\n  isColumnMovable(column: ModelIndex, depth = 0): boolean {\n    return true;\n  }\n\n  /**\n   * @param row Row to check\n   * @returns True if the row is movable\n   */\n  isRowMovable(row: ModelIndex): boolean {\n    return true;\n  }\n\n  getColumnHeaderGroup(\n    modelIndex: ModelIndex,\n    depth: number\n  ): IColumnHeaderGroup | undefined {\n    return undefined;\n  }\n\n  getColumnHeaderParentGroup(\n    modelIndex: ModelIndex,\n    depth: number\n  ): IColumnHeaderGroup | undefined {\n    return undefined;\n  }\n\n  /**\n   * Gets the tokens in the cell at column and row, based on the visible text\n   * @param column The model column\n   * @param row The model row\n   * @param visibleLength The length of the visible text\n   * @returns An array of Tokens in the cell\n   */\n  tokensForCell(\n    column: ModelIndex,\n    row: ModelIndex,\n    visibleLength: number = LINK_TRUNCATION_LENGTH\n  ): Token[] {\n    const text = this.textForCell(column, row);\n    return this.getCachedTokensInText(text, visibleLength);\n  }\n\n  getCachedTokensInText = memoizeClear(\n    (text: string, visibleLength: number): Token[] => {\n      // If no text is truncated, then directly search in text\n      if (visibleLength >= text.length) {\n        return GridUtils.findTokensWithProtocolInText(text);\n      }\n\n      // To check for links, we should check to the first space after the truncatedText length\n      const indexOfProceedingWhitespace = text\n        .slice(visibleLength - 1, LINK_TRUNCATION_LENGTH)\n        .search(/\\s/); // index or -1 if not found\n\n      let lengthOfContent = visibleLength + indexOfProceedingWhitespace;\n      // If it doesn't exist, set lengthOfContent to the minimum between length of the original text and 5000\n      if (indexOfProceedingWhitespace === -1) {\n        lengthOfContent = Math.min(LINK_TRUNCATION_LENGTH, text.length);\n      }\n      const contentToCheckForLinks = text.substring(0, lengthOfContent);\n\n      return GridUtils.findTokensWithProtocolInText(contentToCheckForLinks);\n    },\n    { max: 10000 }\n  );\n\n  renderTypeForCell(column: ModelIndex, row: ModelIndex): CellRenderType {\n    return 'text';\n  }\n}\n\nexport default GridModel;\n"],"mappings":"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","ignoreList":[]}
         | 
    
        package/dist/GridMouseHandler.js
    CHANGED
    
    | @@ -19,12 +19,10 @@ export class GridMouseHandler { | |
| 19 19 | 
             
              constructor() {
         | 
| 20 20 | 
             
                var order = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 5000;
         | 
| 21 21 | 
             
                _defineProperty(this, "order", void 0);
         | 
| 22 | 
            +
                // Cursor to use if this returns any truthy value including { stopPropagation: false, preventDefault: false }
         | 
| 22 23 | 
             
                _defineProperty(this, "cursor", null);
         | 
| 23 24 | 
             
                this.order = order;
         | 
| 24 25 | 
             
              }
         | 
| 25 | 
            -
             | 
| 26 | 
            -
              // Cursor to use if this returns any truthy value including { stopPropagation: false, preventDefault: false }
         | 
| 27 | 
            -
             | 
| 28 26 | 
             
              onDown(gridPoint, grid, event) {
         | 
| 29 27 | 
             
                return false;
         | 
| 30 28 | 
             
              }
         | 
| @@ -1 +1 @@ | |
| 1 | 
            -
            {"version":3,"file":"GridMouseHandler.js","names":["GridMouseHandler","constructor","order","arguments","length","undefined","_defineProperty","onDown","gridPoint","grid","event","onMove","onDrag","onLeave","onClick","onContextMenu","onDoubleClick","onUp","onWheel"],"sources":["../src/GridMouseHandler.ts"],"sourcesContent":["/* eslint class-methods-use-this: \"off\" */\n/* eslint no-unused-vars: \"off\" */\nimport { type EventHandlerResult } from './EventHandlerResult';\nimport type Grid from './Grid';\nimport { type GridPoint } from './GridUtils';\n\n/**\n * Some events we listen to are a native mouse event, and others are wrapped with React's SyntheticEvent.\n * The GridMouseHandler shouldn't care though - the properties it accesses should be common on both types of events.\n */\nexport type GridMouseEvent = MouseEvent | React.MouseEvent;\n\nexport type GridWheelEvent = WheelEvent | React.WheelEvent;\n\nexport type GridMouseHandlerFunctionName =\n  | 'onDown'\n  | 'onMove'\n  | 'onDrag'\n  | 'onLeave'\n  | 'onClick'\n  | 'onContextMenu'\n  | 'onDoubleClick'\n  | 'onUp'\n  | 'onWheel';\n\n/**\n * Define a region in the grid that interacts with the mouse on a grid.\n * Return true from any of the events to indicate they're consumed, and stopPropagation/preventDefault will be called.\n */\nexport class GridMouseHandler {\n  order: number;\n\n  // What order this mouse handler should trigger in. Smaller numbers trigger first\n  // Default to well below any of the GRID mouse handlers 100-1000+\n  constructor(order = 5000) {\n    this.order = order;\n  }\n\n  // Cursor to use if this returns any truthy value including { stopPropagation: false, preventDefault: false }\n  cursor: string | null = null;\n\n  onDown(\n    gridPoint: GridPoint,\n    grid: Grid,\n    event: GridMouseEvent\n  ): EventHandlerResult {\n    return false;\n  }\n\n  onMove(\n    gridPoint: GridPoint,\n    grid: Grid,\n    event: GridMouseEvent\n  ): EventHandlerResult {\n    return false;\n  }\n\n  onDrag(\n    gridPoint: GridPoint,\n    grid: Grid,\n    event: GridMouseEvent\n  ): EventHandlerResult {\n    return false;\n  }\n\n  onLeave(\n    gridPoint: GridPoint,\n    grid: Grid,\n    event: GridMouseEvent\n  ): EventHandlerResult {\n    return false;\n  }\n\n  onClick(\n    gridPoint: GridPoint,\n    grid: Grid,\n    event: GridMouseEvent\n  ): EventHandlerResult {\n    return false;\n  }\n\n  onContextMenu(\n    gridPoint: GridPoint,\n    grid: Grid,\n    event: GridMouseEvent\n  ): EventHandlerResult {\n    return false;\n  }\n\n  onDoubleClick(\n    gridPoint: GridPoint,\n    grid: Grid,\n    event: GridMouseEvent\n  ): EventHandlerResult {\n    return false;\n  }\n\n  onUp(\n    gridPoint: GridPoint,\n    grid: Grid,\n    event: GridMouseEvent\n  ): EventHandlerResult {\n    return false;\n  }\n\n  onWheel(\n    gridPoint: GridPoint,\n    grid: Grid,\n    event: GridMouseEvent\n  ): EventHandlerResult {\n    return false;\n  }\n}\n\nexport default GridMouseHandler;\n"],"mappings":";;;AAAA;AACA;;AAKA;AACA;AACA;AACA;;AAgBA;AACA;AACA;AACA;AACA,OAAO,MAAMA,gBAAgB,CAAC;EAG5B;EACA;EACAC,WAAWA,CAAA,EAAe;IAAA,IAAdC,KAAK,GAAAC,SAAA,CAAAC,MAAA,QAAAD,SAAA,QAAAE,SAAA,GAAAF,SAAA,MAAG,IAAI;IAAAG,eAAA;IAAAA,eAAA, | 
| 1 | 
            +
            {"version":3,"file":"GridMouseHandler.js","names":["GridMouseHandler","constructor","order","arguments","length","undefined","_defineProperty","onDown","gridPoint","grid","event","onMove","onDrag","onLeave","onClick","onContextMenu","onDoubleClick","onUp","onWheel"],"sources":["../src/GridMouseHandler.ts"],"sourcesContent":["/* eslint class-methods-use-this: \"off\" */\n/* eslint no-unused-vars: \"off\" */\nimport { type EventHandlerResult } from './EventHandlerResult';\nimport type Grid from './Grid';\nimport { type GridPoint } from './GridUtils';\n\n/**\n * Some events we listen to are a native mouse event, and others are wrapped with React's SyntheticEvent.\n * The GridMouseHandler shouldn't care though - the properties it accesses should be common on both types of events.\n */\nexport type GridMouseEvent = MouseEvent | React.MouseEvent;\n\nexport type GridWheelEvent = WheelEvent | React.WheelEvent;\n\nexport type GridMouseHandlerFunctionName =\n  | 'onDown'\n  | 'onMove'\n  | 'onDrag'\n  | 'onLeave'\n  | 'onClick'\n  | 'onContextMenu'\n  | 'onDoubleClick'\n  | 'onUp'\n  | 'onWheel';\n\n/**\n * Define a region in the grid that interacts with the mouse on a grid.\n * Return true from any of the events to indicate they're consumed, and stopPropagation/preventDefault will be called.\n */\nexport class GridMouseHandler {\n  order: number;\n\n  // What order this mouse handler should trigger in. Smaller numbers trigger first\n  // Default to well below any of the GRID mouse handlers 100-1000+\n  constructor(order = 5000) {\n    this.order = order;\n  }\n\n  // Cursor to use if this returns any truthy value including { stopPropagation: false, preventDefault: false }\n  cursor: string | null = null;\n\n  onDown(\n    gridPoint: GridPoint,\n    grid: Grid,\n    event: GridMouseEvent\n  ): EventHandlerResult {\n    return false;\n  }\n\n  onMove(\n    gridPoint: GridPoint,\n    grid: Grid,\n    event: GridMouseEvent\n  ): EventHandlerResult {\n    return false;\n  }\n\n  onDrag(\n    gridPoint: GridPoint,\n    grid: Grid,\n    event: GridMouseEvent\n  ): EventHandlerResult {\n    return false;\n  }\n\n  onLeave(\n    gridPoint: GridPoint,\n    grid: Grid,\n    event: GridMouseEvent\n  ): EventHandlerResult {\n    return false;\n  }\n\n  onClick(\n    gridPoint: GridPoint,\n    grid: Grid,\n    event: GridMouseEvent\n  ): EventHandlerResult {\n    return false;\n  }\n\n  onContextMenu(\n    gridPoint: GridPoint,\n    grid: Grid,\n    event: GridMouseEvent\n  ): EventHandlerResult {\n    return false;\n  }\n\n  onDoubleClick(\n    gridPoint: GridPoint,\n    grid: Grid,\n    event: GridMouseEvent\n  ): EventHandlerResult {\n    return false;\n  }\n\n  onUp(\n    gridPoint: GridPoint,\n    grid: Grid,\n    event: GridMouseEvent\n  ): EventHandlerResult {\n    return false;\n  }\n\n  onWheel(\n    gridPoint: GridPoint,\n    grid: Grid,\n    event: GridMouseEvent\n  ): EventHandlerResult {\n    return false;\n  }\n}\n\nexport default GridMouseHandler;\n"],"mappings":";;;AAAA;AACA;;AAKA;AACA;AACA;AACA;;AAgBA;AACA;AACA;AACA;AACA,OAAO,MAAMA,gBAAgB,CAAC;EAG5B;EACA;EACAC,WAAWA,CAAA,EAAe;IAAA,IAAdC,KAAK,GAAAC,SAAA,CAAAC,MAAA,QAAAD,SAAA,QAAAE,SAAA,GAAAF,SAAA,MAAG,IAAI;IAAAG,eAAA;IAIxB;IAAAA,eAAA,iBACwB,IAAI;IAJ1B,IAAI,CAACJ,KAAK,GAAGA,KAAK;EACpB;EAKAK,MAAMA,CACJC,SAAoB,EACpBC,IAAU,EACVC,KAAqB,EACD;IACpB,OAAO,KAAK;EACd;EAEAC,MAAMA,CACJH,SAAoB,EACpBC,IAAU,EACVC,KAAqB,EACD;IACpB,OAAO,KAAK;EACd;EAEAE,MAAMA,CACJJ,SAAoB,EACpBC,IAAU,EACVC,KAAqB,EACD;IACpB,OAAO,KAAK;EACd;EAEAG,OAAOA,CACLL,SAAoB,EACpBC,IAAU,EACVC,KAAqB,EACD;IACpB,OAAO,KAAK;EACd;EAEAI,OAAOA,CACLN,SAAoB,EACpBC,IAAU,EACVC,KAAqB,EACD;IACpB,OAAO,KAAK;EACd;EAEAK,aAAaA,CACXP,SAAoB,EACpBC,IAAU,EACVC,KAAqB,EACD;IACpB,OAAO,KAAK;EACd;EAEAM,aAAaA,CACXR,SAAoB,EACpBC,IAAU,EACVC,KAAqB,EACD;IACpB,OAAO,KAAK;EACd;EAEAO,IAAIA,CACFT,SAAoB,EACpBC,IAAU,EACVC,KAAqB,EACD;IACpB,OAAO,KAAK;EACd;EAEAQ,OAAOA,CACLV,SAAoB,EACpBC,IAAU,EACVC,KAAqB,EACD;IACpB,OAAO,KAAK;EACd;AACF;AAEA,eAAeV,gBAAgB","ignoreList":[]}
         | 
    
        package/dist/GridRange.js
    CHANGED
    
    | @@ -2,13 +2,13 @@ function _defineProperty(e, r, t) { return (r = _toPropertyKey(r)) in e ? Object | |
| 2 2 | 
             
            function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == typeof i ? i : i + ""; }
         | 
| 3 3 | 
             
            function _toPrimitive(t, r) { if ("object" != typeof t || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != typeof i) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); }
         | 
| 4 4 | 
             
            // Also exported via GridRange.SELECTION_DIRECTION
         | 
| 5 | 
            -
            export var SELECTION_DIRECTION | 
| 6 | 
            -
            (function (SELECTION_DIRECTION) {
         | 
| 5 | 
            +
            export var SELECTION_DIRECTION = /*#__PURE__*/function (SELECTION_DIRECTION) {
         | 
| 7 6 | 
             
              SELECTION_DIRECTION["DOWN"] = "DOWN";
         | 
| 8 7 | 
             
              SELECTION_DIRECTION["UP"] = "UP";
         | 
| 9 8 | 
             
              SELECTION_DIRECTION["LEFT"] = "LEFT";
         | 
| 10 9 | 
             
              SELECTION_DIRECTION["RIGHT"] = "RIGHT";
         | 
| 11 | 
            -
             | 
| 10 | 
            +
              return SELECTION_DIRECTION;
         | 
| 11 | 
            +
            }({});
         | 
| 12 12 | 
             
            export class GridRange {
         | 
| 13 13 | 
             
              /**
         | 
| 14 14 | 
             
               * Returns a normalized array of indexes ensuring left <= right and top <= bottom
         | 
| @@ -228,7 +228,6 @@ export class GridRange { | |
| 228 228 | 
             
               * @returns Intersection of the two ranges. If they do not intersect, returns `null`.
         | 
| 229 229 | 
             
               */
         | 
| 230 230 | 
             
              static intersection(range, otherRange) {
         | 
| 231 | 
            -
                var _startColumn2, _endColumn2, _startRow2, _endRow2, _endColumn3, _endRow3;
         | 
| 232 231 | 
             
                if (range.equals(otherRange)) {
         | 
| 233 232 | 
             
                  return range;
         | 
| 234 233 | 
             
                }
         | 
| @@ -238,11 +237,11 @@ export class GridRange { | |
| 238 237 | 
             
                  endColumn,
         | 
| 239 238 | 
             
                  endRow
         | 
| 240 239 | 
             
                } = range;
         | 
| 241 | 
            -
                startColumn = startColumn != null && otherRange.startColumn != null ? Math.max(startColumn, otherRange.startColumn) :  | 
| 242 | 
            -
                endColumn = endColumn != null && otherRange.endColumn != null ? Math.min(endColumn, otherRange.endColumn) :  | 
| 243 | 
            -
                startRow = startRow != null && otherRange.startRow != null ? Math.max(startRow, otherRange.startRow) :  | 
| 244 | 
            -
                endRow = endRow != null && otherRange.endRow != null ? Math.min(endRow, otherRange.endRow) :  | 
| 245 | 
            -
                if (startColumn != null && startColumn > ( | 
| 240 | 
            +
                startColumn = startColumn != null && otherRange.startColumn != null ? Math.max(startColumn, otherRange.startColumn) : startColumn !== null && startColumn !== void 0 ? startColumn : otherRange.startColumn;
         | 
| 241 | 
            +
                endColumn = endColumn != null && otherRange.endColumn != null ? Math.min(endColumn, otherRange.endColumn) : endColumn !== null && endColumn !== void 0 ? endColumn : otherRange.endColumn;
         | 
| 242 | 
            +
                startRow = startRow != null && otherRange.startRow != null ? Math.max(startRow, otherRange.startRow) : startRow !== null && startRow !== void 0 ? startRow : otherRange.startRow;
         | 
| 243 | 
            +
                endRow = endRow != null && otherRange.endRow != null ? Math.min(endRow, otherRange.endRow) : endRow !== null && endRow !== void 0 ? endRow : otherRange.endRow;
         | 
| 244 | 
            +
                if (startColumn != null && startColumn > (endColumn !== null && endColumn !== void 0 ? endColumn : -1) || startRow != null && startRow > (endRow !== null && endRow !== void 0 ? endRow : -1)) {
         | 
| 246 245 | 
             
                  return null;
         | 
| 247 246 | 
             
                }
         | 
| 248 247 | 
             
                return new GridRange(startColumn, startRow, endColumn, endRow);
         | 
    
        package/dist/GridRange.js.map
    CHANGED
    
    | @@ -1 +1 @@ | |
| 1 | 
            -
            {"version":3,"file":"GridRange.js","names":["SELECTION_DIRECTION","GridRange","normalize","startColumn","startRow","endColumn","endRow","left","top","right","bottom","makeNormalized","makeCell","column","row","makeColumn","makeRow","minOrNull","index1","index2","Math","min","maxOrNull","max","consolidate","ranges","result","slice","wasModified","i","length","range","j","other","contains","splice","touches","isAxisRangeTouching","start1","end1","start2","end2","rangeArraysEqual","ranges1","ranges2","equals","intersection","otherRange","_startColumn2","_endColumn2","_startRow2","_endRow2","_endColumn3","_endRow3","subtractFromRange","subtractRange","subtract","push","subtractFromRanges","subtractRangesFromRanges","subtractRanges","isBounded","boundedRange","columnCount","rowCount","_range$startColumn","_range$startRow","_range$endColumn","_range$endRow","boundedRanges","map","r","offset","columnOffset","rowOffset","nextCell","arguments","undefined","direction","DOWN","rangeIndex","findIndex","containsCell","RIGHT","nextRangeIndex","nextRange","startCell","LEFT","UP","Error","concat","cellCount","reduce","_range$endRow2","_range$startRow2","_range$endColumn2","_range$startColumn2","NaN","_range$endRow3","_range$startRow3","_range$endColumn3","_range$startColumn3","forEachCell","callback","forEach","constructor","_defineProperty","c","_this$nextCell"],"sources":["../src/GridRange.ts"],"sourcesContent":["export type GridRangeIndex = number | null;\nexport type RequiredGridRangeIndex = number;\ntype LeftIndex = GridRangeIndex;\ntype RightIndex = GridRangeIndex;\ntype TopIndex = GridRangeIndex;\ntype BottomIndex = GridRangeIndex;\n\nexport type GridCell = {\n  column: RequiredGridRangeIndex;\n  row: RequiredGridRangeIndex;\n};\n\nexport interface BoundedGridRange extends GridRange {\n  startColumn: RequiredGridRangeIndex;\n  startRow: RequiredGridRangeIndex;\n  endColumn: RequiredGridRangeIndex;\n  endRow: RequiredGridRangeIndex;\n}\n\n// Also exported via GridRange.SELECTION_DIRECTION\nexport enum SELECTION_DIRECTION {\n  DOWN = 'DOWN',\n  UP = 'UP',\n  LEFT = 'LEFT',\n  RIGHT = 'RIGHT',\n}\n\nexport class GridRange {\n  startColumn: GridRangeIndex;\n\n  startRow: GridRangeIndex;\n\n  endColumn: GridRangeIndex;\n\n  endRow: GridRangeIndex;\n\n  static SELECTION_DIRECTION = SELECTION_DIRECTION;\n\n  /**\n   * Returns a normalized array of indexes ensuring left <= right and top <= bottom\n   * @param startColumn Start column index\n   * @param startRow Start row index\n   * @param endColumn End column index\n   * @param endRow End row index\n   * @returns Array containing normalized indexes [left, top, right, bottom]\n   */\n  static normalize(\n    startColumn: GridRangeIndex,\n    startRow: GridRangeIndex,\n    endColumn: GridRangeIndex,\n    endRow: GridRangeIndex\n  ): [LeftIndex, TopIndex, RightIndex, BottomIndex] {\n    let left = startColumn;\n    let top = startRow;\n    let right = endColumn;\n    let bottom = endRow;\n\n    if (left != null && right != null && right < left) {\n      left = right;\n      right = startColumn;\n    }\n\n    if (top != null && bottom != null && bottom < top) {\n      top = bottom;\n      bottom = startRow;\n    }\n\n    return [left, top, right, bottom];\n  }\n\n  /**\n   * Makes a GridRange ensuring startColumn <= endColumn, startRow <= endRow\n   * @param startColumn Start column index\n   * @param startRow Start row index\n   * @param endColumn End column index\n   * @param endRow End row index\n   * @returns Normalized GridRange\n   */\n  static makeNormalized(\n    startColumn: GridRangeIndex,\n    startRow: GridRangeIndex,\n    endColumn: GridRangeIndex,\n    endRow: GridRangeIndex\n  ): GridRange {\n    return new GridRange(\n      ...GridRange.normalize(startColumn, startRow, endColumn, endRow)\n    );\n  }\n\n  /**\n   * Creates a GridRange representing a single cell\n   * @param column Column index\n   * @param row Row index\n   * @returns GridRange representing the cell\n   */\n  static makeCell(column: GridRangeIndex, row: GridRangeIndex): GridRange {\n    return new GridRange(column, row, column, row);\n  }\n\n  /**\n   * Creates a GridRange representing an infinite length column\n   * @param column Column index\n   * @returns GridRange representing the column\n   */\n  static makeColumn(column: GridRangeIndex): GridRange {\n    return new GridRange(column, null, column, null);\n  }\n\n  /**\n   * Creates a GridRange representing an infinite length row\n   * @param row Row index\n   * @returns GridRange representing the row\n   */\n  static makeRow(row: GridRangeIndex): GridRange {\n    return new GridRange(null, row, null, row);\n  }\n\n  /**\n   * Returns the minimum value between 2 range indexes or null if at least 1 is null\n   * @param index1 First grid range index\n   * @param index2 Second grid range index\n   * @returns Minimum index or null if either index is null\n   */\n  static minOrNull(\n    index1: GridRangeIndex,\n    index2: GridRangeIndex\n  ): number | null {\n    if (index1 == null || index2 == null) {\n      return null;\n    }\n\n    return Math.min(index1, index2);\n  }\n\n  /**\n   * Returns the maximum value between 2 range indexes or null if at least 1 is null\n   * @param index1 First grid range index\n   * @param index2 Second grid range index\n   * @returns Maximum index or null if either index is null\n   */\n  static maxOrNull(\n    index1: GridRangeIndex,\n    index2: GridRangeIndex\n  ): number | null {\n    if (index1 == null || index2 == null) {\n      return null;\n    }\n\n    return Math.max(index1, index2);\n  }\n\n  /**\n   * Consolidate the passed in ranges to the minimum set, merging overlapping ranges.\n   * @param ranges The ranges to consolidate\n   * @returns Consolidated ranges\n   */\n  static consolidate(ranges: readonly GridRange[]): GridRange[] {\n    const result = ranges.slice();\n\n    let wasModified = true;\n    while (wasModified) {\n      wasModified = false;\n      for (let i = 0; i < result.length && !wasModified; i += 1) {\n        const range = result[i];\n        for (let j = result.length - 1; j > i; j -= 1) {\n          const other = result[j];\n\n          // If one contains the other, we can just keep the bigger one\n          if (range.contains(other)) {\n            result.splice(j, 1);\n          } else if (other.contains(range)) {\n            wasModified = true;\n            result[i] = other;\n            result.splice(j, 1);\n            break;\n          } else if (\n            range.startRow === other.startRow &&\n            range.endRow === other.endRow\n          ) {\n            if (range.touches(other)) {\n              // If the start/end rows match, and columns touch, consolidate\n              const { startRow, endRow } = range;\n              const startColumn = GridRange.minOrNull(\n                range.startColumn,\n                other.startColumn\n              );\n              const endColumn = GridRange.maxOrNull(\n                range.endColumn,\n                other.endColumn\n              );\n\n              wasModified = true;\n              result[i] = new GridRange(\n                startColumn,\n                startRow,\n                endColumn,\n                endRow\n              );\n              result.splice(j, 1);\n              break;\n            }\n          } else if (\n            range.startColumn === other.startColumn &&\n            range.endColumn === other.endColumn\n          ) {\n            if (range.touches(other)) {\n              // If the start/end rows match, and columns touch, consolidate\n              const { startColumn, endColumn } = range;\n              const startRow = GridRange.minOrNull(\n                range.startRow,\n                other.startRow\n              );\n              const endRow = GridRange.maxOrNull(range.endRow, other.endRow);\n\n              wasModified = true;\n              result[i] = new GridRange(\n                startColumn,\n                startRow,\n                endColumn,\n                endRow\n              );\n              result.splice(j, 1);\n              break;\n            }\n          }\n        }\n      }\n    }\n\n    return result;\n  }\n\n  /**\n   * Checks if the 1-D ranges between 2 index pairs overlap or are continuous.\n   * For example ranges [0, 1] and [2, 3] are continuous and will return true.\n   * [0, 1] and [1, 3] overlap and return true.\n   * [0, 1] and [3, 4] do not overlap and have a gap so this will return false.\n   * @param start1 Start of 1st range\n   * @param end1 End of 1st range\n   * @param start2 Start of 2nd range\n   * @param end2 End of 2nd range\n   * @returns True if the ranges overlap or touch, else false\n   */\n  static isAxisRangeTouching(\n    start1: GridRangeIndex,\n    end1: GridRangeIndex,\n    start2: GridRangeIndex,\n    end2: GridRangeIndex\n  ): boolean {\n    if (start1 == null) {\n      if (end1 == null) {\n        return true;\n      }\n\n      if (start2 == null) {\n        return true;\n      }\n\n      return start2 <= end1 + 1;\n    }\n\n    if (end1 == null) {\n      if (end2 == null) {\n        return true;\n      }\n\n      return end2 >= start1 - 1;\n    }\n\n    if (start2 == null) {\n      if (end2 == null) {\n        return true;\n      }\n\n      return start1 <= end2 + 1;\n    }\n\n    if (end2 == null) {\n      return end1 >= start2 - 1;\n    }\n\n    if (start2 >= start1 - 1) {\n      return start2 <= end1 + 1;\n    }\n\n    return end2 >= start1 - 1;\n  }\n\n  /**\n   * Checks if 2 arrays of ranges are the same ranges\n   * @param ranges1 First array of ranges\n   * @param ranges2 Second array of ranges\n   * @returns True if the arrays contain the same ranges in the same order\n   */\n  static rangeArraysEqual(\n    ranges1: readonly GridRange[],\n    ranges2: readonly GridRange[]\n  ): boolean {\n    if (ranges1 === ranges2) {\n      return true;\n    }\n\n    if (\n      ranges1 == null ||\n      ranges2 == null ||\n      ranges1.length !== ranges2.length\n    ) {\n      return false;\n    }\n\n    for (let i = 0; i < ranges1.length; i += 1) {\n      if (!ranges1[i].equals(ranges2[i])) {\n        return false;\n      }\n    }\n\n    return true;\n  }\n\n  /**\n   * Get the intersection (overlapping area) of two ranges\n   * @param range One range to check for the intersection\n   * @param otherRange The other range to check for the intersection\n   * @returns Intersection of the two ranges. If they do not intersect, returns `null`.\n   */\n  static intersection(\n    range: GridRange,\n    otherRange: GridRange\n  ): GridRange | null {\n    if (range.equals(otherRange)) {\n      return range;\n    }\n\n    let { startColumn, startRow, endColumn, endRow } = range;\n    startColumn =\n      startColumn != null && otherRange.startColumn != null\n        ? Math.max(startColumn, otherRange.startColumn)\n        : startColumn ?? otherRange.startColumn;\n    endColumn =\n      endColumn != null && otherRange.endColumn != null\n        ? Math.min(endColumn, otherRange.endColumn)\n        : endColumn ?? otherRange.endColumn;\n    startRow =\n      startRow != null && otherRange.startRow != null\n        ? Math.max(startRow, otherRange.startRow)\n        : startRow ?? otherRange.startRow;\n    endRow =\n      endRow != null && otherRange.endRow != null\n        ? Math.min(endRow, otherRange.endRow)\n        : endRow ?? otherRange.endRow;\n\n    if (\n      (startColumn != null && startColumn > (endColumn ?? -1)) ||\n      (startRow != null && startRow > (endRow ?? -1))\n    ) {\n      return null;\n    }\n\n    return new GridRange(startColumn, startRow, endColumn, endRow);\n  }\n\n  /**\n   * Subtracts 1 range from another\n   * @param range The range to be subtracted from\n   * @param subtractRange The range to subtract from within this range\n   * @returns The ranges needed to represent the remaining\n   */\n  static subtractFromRange(\n    range: GridRange,\n    subtractRange: GridRange\n  ): GridRange[] {\n    const result = [];\n\n    // Make it a little easier by finding only the part the subtraction range intersects\n    const subtract = GridRange.intersection(range, subtractRange);\n    if (subtract == null) {\n      return [range];\n    }\n\n    // Go through each of the quadrants for deselection, there can be up to 4\n    // Top quadrant (above the subtracted area)\n    if (\n      subtract.startRow != null &&\n      (range.startRow == null || range.startRow < subtract.startRow)\n    ) {\n      result.push(\n        new GridRange(\n          range.startColumn,\n          range.startRow,\n          range.endColumn,\n          subtract.startRow - 1\n        )\n      );\n    }\n\n    // middle left\n    if (\n      subtract.startColumn != null &&\n      (range.startColumn == null || range.startColumn < subtract.startColumn)\n    ) {\n      result.push(\n        new GridRange(\n          range.startColumn,\n          subtract.startRow,\n          subtract.startColumn - 1,\n          subtract.endRow\n        )\n      );\n    }\n\n    // middle right\n    if (\n      subtract.endColumn != null &&\n      (range.endColumn == null || range.endColumn > subtract.endColumn)\n    ) {\n      result.push(\n        new GridRange(\n          subtract.endColumn + 1,\n          subtract.startRow,\n          range.endColumn,\n          subtract.endRow\n        )\n      );\n    }\n\n    // Bottom quadrant\n    if (\n      subtract.endRow != null &&\n      (range.endRow == null || range.endRow > subtract.endRow)\n    ) {\n      result.push(\n        new GridRange(\n          range.startColumn,\n          subtract.endRow + 1,\n          range.endColumn,\n          range.endRow\n        )\n      );\n    }\n\n    return result;\n  }\n\n  /**\n   * Subtract a range from multiple ranges\n   * @param ranges The ranges to be subtracted from\n   * @param subtractRange The range to subtract from within these ranges\n   * @returns The ranges needed to represent the remaining\n   */\n  static subtractFromRanges(\n    ranges: readonly GridRange[],\n    subtractRange: GridRange\n  ): GridRange[] {\n    const result: GridRange[] = [];\n    for (let i = 0; i < ranges.length; i += 1) {\n      result.push(...GridRange.subtractFromRange(ranges[i], subtractRange));\n    }\n\n    return result;\n  }\n\n  /**\n   * Subtract multiple ranges from multiple ranges\n   * @param ranges The ranges to be subtracted from\n   * @param subtractRanges The ranges to subtract from within these ranges\n   * @returns The ranges needed to represent the remaining\n   */\n  static subtractRangesFromRanges(\n    ranges: readonly GridRange[],\n    subtractRanges: readonly GridRange[]\n  ): GridRange[] {\n    let result = [...ranges];\n    for (let i = 0; i < subtractRanges.length; i += 1) {\n      result = GridRange.subtractFromRanges(result, subtractRanges[i]);\n    }\n\n    return result;\n  }\n\n  /**\n   * Test if a given range is bounded (all values are non-null)\n   * @param range The range to test\n   * @returns True if this range is bounded, false otherwise\n   */\n  static isBounded(range: GridRange): range is BoundedGridRange {\n    return (\n      range.startRow != null &&\n      range.startColumn != null &&\n      range.endRow != null &&\n      range.endColumn != null\n    );\n  }\n\n  /**\n   * Converts any GridRange passed in that is a full row or column selection to be bound\n   * to the `columnCount` and `rowCount` passed in\n   *\n   * @param range The range to get the bounded range of\n   * @param columnCount The number of columns\n   * @param rowCount The number of rows\n   * @returns The passed in GridRange with any null values filled in\n   */\n  static boundedRange(\n    range: GridRange,\n    columnCount: number,\n    rowCount: number\n  ): BoundedGridRange {\n    if (GridRange.isBounded(range)) {\n      return range;\n    }\n\n    return new GridRange(\n      range.startColumn ?? 0,\n      range.startRow ?? 0,\n      range.endColumn ?? columnCount - 1,\n      range.endRow ?? rowCount - 1\n    ) as BoundedGridRange;\n  }\n\n  /**\n   * Converts the GridRanges passed in to be bound to the `columnCount` and `rowCount` passed in\n   *\n   * @param ranges The ranges to get the bounded ranges of\n   * @param columnCount The number of columns\n   * @param rowCount The number of rows\n   * @returns The passed in GridRange with any null values filled in\n   */\n  static boundedRanges(\n    ranges: readonly GridRange[],\n    columnCount: number,\n    rowCount: number\n  ): BoundedGridRange[] {\n    return ranges.map(r => GridRange.boundedRange(r, columnCount, rowCount));\n  }\n\n  /**\n   * Offsets a GridRange by the specified amount in the x and y directions\n   *\n   * @param range The range to offset\n   * @param columnOffset The number of columns to offset\n   * @param rowOffset The number of rows to offset\n   * @returns The new grid range offset from the original\n   */\n  static offset(\n    range: GridRange,\n    columnOffset: number,\n    rowOffset: number\n  ): GridRange {\n    return new GridRange(\n      range.startColumn != null ? range.startColumn + columnOffset : null,\n      range.startRow != null ? range.startRow + rowOffset : null,\n      range.endColumn != null ? range.endColumn + columnOffset : null,\n      range.endRow != null ? range.endRow + rowOffset : null\n    );\n  }\n\n  /**\n   * Get the next cell given the selected ranges and the current cell\n   * @param ranges The selected bounded ranges within the grid\n   * @param column The cursor column, or null if none focused\n   * @param row The cursor row, or null if none focused\n   * @param direction The direction in which to select next\n   * @returns The next cell to focus, or null if there should be no more focus\n   */\n  static nextCell(\n    ranges: readonly GridRange[],\n    column: GridRangeIndex = null,\n    row: GridRangeIndex = null,\n    direction = GridRange.SELECTION_DIRECTION.DOWN\n  ): GridCell | null {\n    if (ranges.length === 0) {\n      return null;\n    }\n\n    let rangeIndex = -1;\n    if (column != null && row != null) {\n      rangeIndex = ranges.findIndex(r => r.containsCell(column, row));\n\n      if (rangeIndex >= 0) {\n        const range = ranges[rangeIndex];\n        const nextCell = range.nextCell(column, row, direction);\n        if (nextCell != null) {\n          return nextCell;\n        }\n      }\n    }\n\n    // Otherwise go to the start of the next range (could be same range if only one range)\n    switch (direction) {\n      case GridRange.SELECTION_DIRECTION.DOWN:\n      case GridRange.SELECTION_DIRECTION.RIGHT: {\n        const nextRangeIndex =\n          rangeIndex < ranges.length - 1 ? rangeIndex + 1 : 0;\n        const nextRange = ranges[nextRangeIndex];\n        return nextRange.startCell(direction);\n      }\n      case GridRange.SELECTION_DIRECTION.LEFT:\n      case GridRange.SELECTION_DIRECTION.UP: {\n        const nextRangeIndex =\n          rangeIndex > 0 ? rangeIndex - 1 : ranges.length - 1;\n        const nextRange = ranges[nextRangeIndex];\n        return nextRange.startCell(direction);\n      }\n      default:\n        throw new Error(`Invalid direction: ${direction}`);\n    }\n  }\n\n  /**\n   * Count the number of cells in the provided grid ranges\n   * @param ranges The ranges to count the rows of\n   * @returns The number of cells in the ranges, or `NaN` if any of the ranges were unbounded\n   */\n  static cellCount(ranges: readonly GridRange[]): number {\n    return ranges.reduce(\n      (cellCount, range) =>\n        cellCount +\n        ((range.endRow ?? NaN) - (range.startRow ?? NaN) + 1) *\n          ((range.endColumn ?? NaN) - (range.startColumn ?? NaN) + 1),\n      0\n    );\n  }\n\n  /**\n   * Count the number of rows in the provided grid ranges\n   * @param ranges The ranges to count the rows of\n   * @returns The number of rows in the ranges, or `NaN` if any of the ranges were unbounded\n   */\n  static rowCount(ranges: readonly GridRange[]): number {\n    return ranges.reduce(\n      (rowCount, range) =>\n        rowCount + (range.endRow ?? NaN) - (range.startRow ?? NaN) + 1,\n      0\n    );\n  }\n\n  /**\n   * Count the number of columns in the provided grid ranges\n   * @param ranges The ranges to count the columns of\n   * @returns The number of columns in the ranges, or `NaN` if any of the ranges were unbounded\n   */\n  static columnCount(ranges: readonly GridRange[]): number {\n    return ranges.reduce(\n      (columnCount, range) =>\n        columnCount + (range.endColumn ?? NaN) - (range.startColumn ?? NaN) + 1,\n      0\n    );\n  }\n\n  /**\n   * Check if the provided ranges contain the provided cell\n   * @param ranges The ranges to check\n   * @param column The column index\n   * @param row The row index\n   * @returns True if the cell is within the provided ranges, false otherwise.\n   */\n  static containsCell(\n    ranges: readonly GridRange[],\n    column: GridRangeIndex,\n    row: GridRangeIndex\n  ): boolean {\n    for (let i = 0; i < ranges.length; i += 1) {\n      const range = ranges[i];\n      if (range.containsCell(column, row)) {\n        return true;\n      }\n    }\n    return false;\n  }\n\n  /**\n   * Iterate through each cell in the provided ranges\n   * @param ranges The ranges to iterate through\n   * @param callback The callback to execute. `index` is the index within that range\n   * @param direction The direction to iterate in\n   */\n  static forEachCell(\n    ranges: readonly GridRange[],\n    callback: (column: number, row: number, index: number) => void,\n    direction = GridRange.SELECTION_DIRECTION.RIGHT\n  ): void {\n    for (let i = 0; i < ranges.length; i += 1) {\n      ranges[i].forEach(callback, direction);\n    }\n  }\n\n  constructor(\n    startColumn: GridRangeIndex,\n    startRow: GridRangeIndex,\n    endColumn: GridRangeIndex,\n    endRow: GridRangeIndex\n  ) {\n    this.startColumn = startColumn;\n    this.startRow = startRow;\n    this.endColumn = endColumn;\n    this.endRow = endRow;\n  }\n\n  /**\n   * Checks if the provided range is equivalent to this range (same start and end column/row indexes)\n   * @param other Grid range to check against\n   * @returns True if the ranges cover the same area\n   */\n  equals(other: GridRange): boolean {\n    return (\n      this.startColumn === other.startColumn &&\n      this.startRow === other.startRow &&\n      this.endColumn === other.endColumn &&\n      this.endRow === other.endRow\n    );\n  }\n\n  /**\n   * Checks if this GridRange contains another range\n   * @param other The range to check\n   * @returns True if this GridRange completely contains `other`\n   * */\n  contains(other: GridRange): boolean {\n    return (\n      (this.startColumn == null ||\n        (other.startColumn != null && this.startColumn <= other.startColumn)) &&\n      (this.startRow == null ||\n        (other.startRow != null && this.startRow <= other.startRow)) &&\n      (this.endColumn == null ||\n        (other.endColumn != null && this.endColumn >= other.endColumn)) &&\n      (this.endRow == null ||\n        (other.endRow != null && this.endRow >= other.endRow))\n    );\n  }\n\n  /**\n   * Check if the provided cell is in this range\n   * @param column The column to check\n   * @param row The row to check\n   * @returns True if this cell is within this range\n   */\n  containsCell(column: GridRangeIndex, row: GridRangeIndex): boolean {\n    if (column == null || row == null) {\n      return false;\n    }\n\n    return (\n      (this.startColumn == null || this.startColumn <= column) &&\n      (this.endColumn == null || this.endColumn >= column) &&\n      (this.startRow == null || this.startRow <= row) &&\n      (this.endRow == null || this.endRow >= row)\n    );\n  }\n\n  /**\n   * Check if the provided range touches (or overlaps) this GridRange\n   * Effectively checks if the 2 ranges could be represented by 1 continuous range\n   * @param other The range to check\n   * @returns True if this GridRange touches `other`\n   * */\n  touches(other: GridRange): boolean {\n    return (\n      GridRange.isAxisRangeTouching(\n        this.startRow,\n        this.endRow,\n        other.startRow,\n        other.endRow\n      ) &&\n      GridRange.isAxisRangeTouching(\n        this.startColumn,\n        this.endColumn,\n        other.startColumn,\n        other.endColumn\n      )\n    );\n  }\n\n  /**\n   * Subtracts a range from this range\n   * @param other The range to deselect from within this range\n   * @returns The ranges needed to represent the remaining\n   */\n  subtract(other: GridRange): GridRange[] {\n    return GridRange.subtractFromRange(this, other);\n  }\n\n  /**\n   * Get the first cell in this range. Throws if this range is unbounded.\n   *\n   * @param direction The direction to get the starting cell in. Defaults to DOWN\n   * @returns The first cell in this range in the direction specified\n   */\n  startCell(direction = GridRange.SELECTION_DIRECTION.DOWN): GridCell {\n    if (!GridRange.isBounded(this)) {\n      throw new Error('Cannot get the startCell of an unbounded range');\n    }\n\n    switch (direction) {\n      case GridRange.SELECTION_DIRECTION.DOWN:\n      case GridRange.SELECTION_DIRECTION.RIGHT:\n        return { column: this.startColumn, row: this.startRow };\n      case GridRange.SELECTION_DIRECTION.LEFT:\n      case GridRange.SELECTION_DIRECTION.UP: {\n        return { column: this.endColumn, row: this.endRow };\n      }\n      default:\n        throw new Error(`Invalid direction: ${direction}`);\n    }\n  }\n\n  /**\n   * Get the next cell in the direction specified. Throws if this range is unbounded.\n   * If already at the bounds of the range in that direction, wrap to the next column or row\n   * If at the end of the entire range, return null\n   * If outside of the range, returns the next cell closest within this range.\n   *\n   * @param column The cursor column\n   * @param row The cursor row\n   * @param direction The direction to go in\n   * @returns The next cell in the direction specified, or `null` if at the end of the range\n   */\n  nextCell(\n    column: GridRangeIndex,\n    row: GridRangeIndex,\n    direction: SELECTION_DIRECTION\n  ): GridCell | null {\n    if (!GridRange.isBounded(this)) {\n      throw new Error('Bounded range required');\n    }\n    if (column == null || row == null) {\n      throw new Error('Require a non-null cursor');\n    }\n\n    const { startColumn, endColumn, startRow, endRow } = this;\n\n    switch (direction) {\n      case GridRange.SELECTION_DIRECTION.DOWN:\n        if (row < endRow) {\n          return { column, row: Math.max(row + 1, startRow) };\n        }\n\n        if (column < endColumn) {\n          return { column: Math.max(column + 1, startColumn), row: startRow };\n        }\n        break;\n      case GridRange.SELECTION_DIRECTION.UP:\n        if (row > startRow) {\n          return { column, row: Math.min(row - 1, endRow) };\n        }\n\n        if (column > startColumn) {\n          return { column: Math.min(column - 1, endColumn), row: endRow };\n        }\n        break;\n      case GridRange.SELECTION_DIRECTION.RIGHT:\n        if (column < endColumn) {\n          return { column: Math.max(column + 1, startColumn), row };\n        }\n\n        if (row < endRow) {\n          return { column: startColumn, row: Math.max(row + 1, startRow) };\n        }\n        break;\n      case GridRange.SELECTION_DIRECTION.LEFT:\n        if (column > startColumn) {\n          return { column: Math.min(column - 1, endColumn), row };\n        }\n\n        if (row > startRow) {\n          return { column: endColumn, row: Math.min(row - 1, endRow) };\n        }\n        break;\n      default:\n        throw new Error(`Invalid direction: ${direction}`);\n    }\n\n    return null;\n  }\n\n  /**\n   * Iterate through each cell in the range\n   * @param callback Callback to execute. `index` is the index within this range\n   * @param direction The direction to iterate in\n   */\n  forEach(\n    callback: (column: number, row: number, index: number) => void,\n    direction = GridRange.SELECTION_DIRECTION.RIGHT\n  ): void {\n    let i = 0;\n    let { column: c, row: r }: { column?: number; row?: number } =\n      this.startCell(direction);\n    while (c != null && r != null) {\n      callback(c, r, i);\n      i += 1;\n\n      ({ column: c, row: r } = this.nextCell(c, r, direction) ?? {});\n    }\n  }\n}\n\nexport default GridRange;\n"],"mappings":"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"}
         | 
| 1 | 
            +
            {"version":3,"file":"GridRange.js","names":["SELECTION_DIRECTION","GridRange","normalize","startColumn","startRow","endColumn","endRow","left","top","right","bottom","makeNormalized","makeCell","column","row","makeColumn","makeRow","minOrNull","index1","index2","Math","min","maxOrNull","max","consolidate","ranges","result","slice","wasModified","i","length","range","j","other","contains","splice","touches","isAxisRangeTouching","start1","end1","start2","end2","rangeArraysEqual","ranges1","ranges2","equals","intersection","otherRange","subtractFromRange","subtractRange","subtract","push","subtractFromRanges","subtractRangesFromRanges","subtractRanges","isBounded","boundedRange","columnCount","rowCount","_range$startColumn","_range$startRow","_range$endColumn","_range$endRow","boundedRanges","map","r","offset","columnOffset","rowOffset","nextCell","arguments","undefined","direction","DOWN","rangeIndex","findIndex","containsCell","RIGHT","nextRangeIndex","nextRange","startCell","LEFT","UP","Error","concat","cellCount","reduce","_range$endRow2","_range$startRow2","_range$endColumn2","_range$startColumn2","NaN","_range$endRow3","_range$startRow3","_range$endColumn3","_range$startColumn3","forEachCell","callback","forEach","constructor","_defineProperty","c","_this$nextCell"],"sources":["../src/GridRange.ts"],"sourcesContent":["export type GridRangeIndex = number | null;\nexport type RequiredGridRangeIndex = number;\ntype LeftIndex = GridRangeIndex;\ntype RightIndex = GridRangeIndex;\ntype TopIndex = GridRangeIndex;\ntype BottomIndex = GridRangeIndex;\n\nexport type GridCell = {\n  column: RequiredGridRangeIndex;\n  row: RequiredGridRangeIndex;\n};\n\nexport interface BoundedGridRange extends GridRange {\n  startColumn: RequiredGridRangeIndex;\n  startRow: RequiredGridRangeIndex;\n  endColumn: RequiredGridRangeIndex;\n  endRow: RequiredGridRangeIndex;\n}\n\n// Also exported via GridRange.SELECTION_DIRECTION\nexport enum SELECTION_DIRECTION {\n  DOWN = 'DOWN',\n  UP = 'UP',\n  LEFT = 'LEFT',\n  RIGHT = 'RIGHT',\n}\n\nexport class GridRange {\n  startColumn: GridRangeIndex;\n\n  startRow: GridRangeIndex;\n\n  endColumn: GridRangeIndex;\n\n  endRow: GridRangeIndex;\n\n  static SELECTION_DIRECTION = SELECTION_DIRECTION;\n\n  /**\n   * Returns a normalized array of indexes ensuring left <= right and top <= bottom\n   * @param startColumn Start column index\n   * @param startRow Start row index\n   * @param endColumn End column index\n   * @param endRow End row index\n   * @returns Array containing normalized indexes [left, top, right, bottom]\n   */\n  static normalize(\n    startColumn: GridRangeIndex,\n    startRow: GridRangeIndex,\n    endColumn: GridRangeIndex,\n    endRow: GridRangeIndex\n  ): [LeftIndex, TopIndex, RightIndex, BottomIndex] {\n    let left = startColumn;\n    let top = startRow;\n    let right = endColumn;\n    let bottom = endRow;\n\n    if (left != null && right != null && right < left) {\n      left = right;\n      right = startColumn;\n    }\n\n    if (top != null && bottom != null && bottom < top) {\n      top = bottom;\n      bottom = startRow;\n    }\n\n    return [left, top, right, bottom];\n  }\n\n  /**\n   * Makes a GridRange ensuring startColumn <= endColumn, startRow <= endRow\n   * @param startColumn Start column index\n   * @param startRow Start row index\n   * @param endColumn End column index\n   * @param endRow End row index\n   * @returns Normalized GridRange\n   */\n  static makeNormalized(\n    startColumn: GridRangeIndex,\n    startRow: GridRangeIndex,\n    endColumn: GridRangeIndex,\n    endRow: GridRangeIndex\n  ): GridRange {\n    return new GridRange(\n      ...GridRange.normalize(startColumn, startRow, endColumn, endRow)\n    );\n  }\n\n  /**\n   * Creates a GridRange representing a single cell\n   * @param column Column index\n   * @param row Row index\n   * @returns GridRange representing the cell\n   */\n  static makeCell(column: GridRangeIndex, row: GridRangeIndex): GridRange {\n    return new GridRange(column, row, column, row);\n  }\n\n  /**\n   * Creates a GridRange representing an infinite length column\n   * @param column Column index\n   * @returns GridRange representing the column\n   */\n  static makeColumn(column: GridRangeIndex): GridRange {\n    return new GridRange(column, null, column, null);\n  }\n\n  /**\n   * Creates a GridRange representing an infinite length row\n   * @param row Row index\n   * @returns GridRange representing the row\n   */\n  static makeRow(row: GridRangeIndex): GridRange {\n    return new GridRange(null, row, null, row);\n  }\n\n  /**\n   * Returns the minimum value between 2 range indexes or null if at least 1 is null\n   * @param index1 First grid range index\n   * @param index2 Second grid range index\n   * @returns Minimum index or null if either index is null\n   */\n  static minOrNull(\n    index1: GridRangeIndex,\n    index2: GridRangeIndex\n  ): number | null {\n    if (index1 == null || index2 == null) {\n      return null;\n    }\n\n    return Math.min(index1, index2);\n  }\n\n  /**\n   * Returns the maximum value between 2 range indexes or null if at least 1 is null\n   * @param index1 First grid range index\n   * @param index2 Second grid range index\n   * @returns Maximum index or null if either index is null\n   */\n  static maxOrNull(\n    index1: GridRangeIndex,\n    index2: GridRangeIndex\n  ): number | null {\n    if (index1 == null || index2 == null) {\n      return null;\n    }\n\n    return Math.max(index1, index2);\n  }\n\n  /**\n   * Consolidate the passed in ranges to the minimum set, merging overlapping ranges.\n   * @param ranges The ranges to consolidate\n   * @returns Consolidated ranges\n   */\n  static consolidate(ranges: readonly GridRange[]): GridRange[] {\n    const result = ranges.slice();\n\n    let wasModified = true;\n    while (wasModified) {\n      wasModified = false;\n      for (let i = 0; i < result.length && !wasModified; i += 1) {\n        const range = result[i];\n        for (let j = result.length - 1; j > i; j -= 1) {\n          const other = result[j];\n\n          // If one contains the other, we can just keep the bigger one\n          if (range.contains(other)) {\n            result.splice(j, 1);\n          } else if (other.contains(range)) {\n            wasModified = true;\n            result[i] = other;\n            result.splice(j, 1);\n            break;\n          } else if (\n            range.startRow === other.startRow &&\n            range.endRow === other.endRow\n          ) {\n            if (range.touches(other)) {\n              // If the start/end rows match, and columns touch, consolidate\n              const { startRow, endRow } = range;\n              const startColumn = GridRange.minOrNull(\n                range.startColumn,\n                other.startColumn\n              );\n              const endColumn = GridRange.maxOrNull(\n                range.endColumn,\n                other.endColumn\n              );\n\n              wasModified = true;\n              result[i] = new GridRange(\n                startColumn,\n                startRow,\n                endColumn,\n                endRow\n              );\n              result.splice(j, 1);\n              break;\n            }\n          } else if (\n            range.startColumn === other.startColumn &&\n            range.endColumn === other.endColumn\n          ) {\n            if (range.touches(other)) {\n              // If the start/end rows match, and columns touch, consolidate\n              const { startColumn, endColumn } = range;\n              const startRow = GridRange.minOrNull(\n                range.startRow,\n                other.startRow\n              );\n              const endRow = GridRange.maxOrNull(range.endRow, other.endRow);\n\n              wasModified = true;\n              result[i] = new GridRange(\n                startColumn,\n                startRow,\n                endColumn,\n                endRow\n              );\n              result.splice(j, 1);\n              break;\n            }\n          }\n        }\n      }\n    }\n\n    return result;\n  }\n\n  /**\n   * Checks if the 1-D ranges between 2 index pairs overlap or are continuous.\n   * For example ranges [0, 1] and [2, 3] are continuous and will return true.\n   * [0, 1] and [1, 3] overlap and return true.\n   * [0, 1] and [3, 4] do not overlap and have a gap so this will return false.\n   * @param start1 Start of 1st range\n   * @param end1 End of 1st range\n   * @param start2 Start of 2nd range\n   * @param end2 End of 2nd range\n   * @returns True if the ranges overlap or touch, else false\n   */\n  static isAxisRangeTouching(\n    start1: GridRangeIndex,\n    end1: GridRangeIndex,\n    start2: GridRangeIndex,\n    end2: GridRangeIndex\n  ): boolean {\n    if (start1 == null) {\n      if (end1 == null) {\n        return true;\n      }\n\n      if (start2 == null) {\n        return true;\n      }\n\n      return start2 <= end1 + 1;\n    }\n\n    if (end1 == null) {\n      if (end2 == null) {\n        return true;\n      }\n\n      return end2 >= start1 - 1;\n    }\n\n    if (start2 == null) {\n      if (end2 == null) {\n        return true;\n      }\n\n      return start1 <= end2 + 1;\n    }\n\n    if (end2 == null) {\n      return end1 >= start2 - 1;\n    }\n\n    if (start2 >= start1 - 1) {\n      return start2 <= end1 + 1;\n    }\n\n    return end2 >= start1 - 1;\n  }\n\n  /**\n   * Checks if 2 arrays of ranges are the same ranges\n   * @param ranges1 First array of ranges\n   * @param ranges2 Second array of ranges\n   * @returns True if the arrays contain the same ranges in the same order\n   */\n  static rangeArraysEqual(\n    ranges1: readonly GridRange[],\n    ranges2: readonly GridRange[]\n  ): boolean {\n    if (ranges1 === ranges2) {\n      return true;\n    }\n\n    if (\n      ranges1 == null ||\n      ranges2 == null ||\n      ranges1.length !== ranges2.length\n    ) {\n      return false;\n    }\n\n    for (let i = 0; i < ranges1.length; i += 1) {\n      if (!ranges1[i].equals(ranges2[i])) {\n        return false;\n      }\n    }\n\n    return true;\n  }\n\n  /**\n   * Get the intersection (overlapping area) of two ranges\n   * @param range One range to check for the intersection\n   * @param otherRange The other range to check for the intersection\n   * @returns Intersection of the two ranges. If they do not intersect, returns `null`.\n   */\n  static intersection(\n    range: GridRange,\n    otherRange: GridRange\n  ): GridRange | null {\n    if (range.equals(otherRange)) {\n      return range;\n    }\n\n    let { startColumn, startRow, endColumn, endRow } = range;\n    startColumn =\n      startColumn != null && otherRange.startColumn != null\n        ? Math.max(startColumn, otherRange.startColumn)\n        : startColumn ?? otherRange.startColumn;\n    endColumn =\n      endColumn != null && otherRange.endColumn != null\n        ? Math.min(endColumn, otherRange.endColumn)\n        : endColumn ?? otherRange.endColumn;\n    startRow =\n      startRow != null && otherRange.startRow != null\n        ? Math.max(startRow, otherRange.startRow)\n        : startRow ?? otherRange.startRow;\n    endRow =\n      endRow != null && otherRange.endRow != null\n        ? Math.min(endRow, otherRange.endRow)\n        : endRow ?? otherRange.endRow;\n\n    if (\n      (startColumn != null && startColumn > (endColumn ?? -1)) ||\n      (startRow != null && startRow > (endRow ?? -1))\n    ) {\n      return null;\n    }\n\n    return new GridRange(startColumn, startRow, endColumn, endRow);\n  }\n\n  /**\n   * Subtracts 1 range from another\n   * @param range The range to be subtracted from\n   * @param subtractRange The range to subtract from within this range\n   * @returns The ranges needed to represent the remaining\n   */\n  static subtractFromRange(\n    range: GridRange,\n    subtractRange: GridRange\n  ): GridRange[] {\n    const result = [];\n\n    // Make it a little easier by finding only the part the subtraction range intersects\n    const subtract = GridRange.intersection(range, subtractRange);\n    if (subtract == null) {\n      return [range];\n    }\n\n    // Go through each of the quadrants for deselection, there can be up to 4\n    // Top quadrant (above the subtracted area)\n    if (\n      subtract.startRow != null &&\n      (range.startRow == null || range.startRow < subtract.startRow)\n    ) {\n      result.push(\n        new GridRange(\n          range.startColumn,\n          range.startRow,\n          range.endColumn,\n          subtract.startRow - 1\n        )\n      );\n    }\n\n    // middle left\n    if (\n      subtract.startColumn != null &&\n      (range.startColumn == null || range.startColumn < subtract.startColumn)\n    ) {\n      result.push(\n        new GridRange(\n          range.startColumn,\n          subtract.startRow,\n          subtract.startColumn - 1,\n          subtract.endRow\n        )\n      );\n    }\n\n    // middle right\n    if (\n      subtract.endColumn != null &&\n      (range.endColumn == null || range.endColumn > subtract.endColumn)\n    ) {\n      result.push(\n        new GridRange(\n          subtract.endColumn + 1,\n          subtract.startRow,\n          range.endColumn,\n          subtract.endRow\n        )\n      );\n    }\n\n    // Bottom quadrant\n    if (\n      subtract.endRow != null &&\n      (range.endRow == null || range.endRow > subtract.endRow)\n    ) {\n      result.push(\n        new GridRange(\n          range.startColumn,\n          subtract.endRow + 1,\n          range.endColumn,\n          range.endRow\n        )\n      );\n    }\n\n    return result;\n  }\n\n  /**\n   * Subtract a range from multiple ranges\n   * @param ranges The ranges to be subtracted from\n   * @param subtractRange The range to subtract from within these ranges\n   * @returns The ranges needed to represent the remaining\n   */\n  static subtractFromRanges(\n    ranges: readonly GridRange[],\n    subtractRange: GridRange\n  ): GridRange[] {\n    const result: GridRange[] = [];\n    for (let i = 0; i < ranges.length; i += 1) {\n      result.push(...GridRange.subtractFromRange(ranges[i], subtractRange));\n    }\n\n    return result;\n  }\n\n  /**\n   * Subtract multiple ranges from multiple ranges\n   * @param ranges The ranges to be subtracted from\n   * @param subtractRanges The ranges to subtract from within these ranges\n   * @returns The ranges needed to represent the remaining\n   */\n  static subtractRangesFromRanges(\n    ranges: readonly GridRange[],\n    subtractRanges: readonly GridRange[]\n  ): GridRange[] {\n    let result = [...ranges];\n    for (let i = 0; i < subtractRanges.length; i += 1) {\n      result = GridRange.subtractFromRanges(result, subtractRanges[i]);\n    }\n\n    return result;\n  }\n\n  /**\n   * Test if a given range is bounded (all values are non-null)\n   * @param range The range to test\n   * @returns True if this range is bounded, false otherwise\n   */\n  static isBounded(range: GridRange): range is BoundedGridRange {\n    return (\n      range.startRow != null &&\n      range.startColumn != null &&\n      range.endRow != null &&\n      range.endColumn != null\n    );\n  }\n\n  /**\n   * Converts any GridRange passed in that is a full row or column selection to be bound\n   * to the `columnCount` and `rowCount` passed in\n   *\n   * @param range The range to get the bounded range of\n   * @param columnCount The number of columns\n   * @param rowCount The number of rows\n   * @returns The passed in GridRange with any null values filled in\n   */\n  static boundedRange(\n    range: GridRange,\n    columnCount: number,\n    rowCount: number\n  ): BoundedGridRange {\n    if (GridRange.isBounded(range)) {\n      return range;\n    }\n\n    return new GridRange(\n      range.startColumn ?? 0,\n      range.startRow ?? 0,\n      range.endColumn ?? columnCount - 1,\n      range.endRow ?? rowCount - 1\n    ) as BoundedGridRange;\n  }\n\n  /**\n   * Converts the GridRanges passed in to be bound to the `columnCount` and `rowCount` passed in\n   *\n   * @param ranges The ranges to get the bounded ranges of\n   * @param columnCount The number of columns\n   * @param rowCount The number of rows\n   * @returns The passed in GridRange with any null values filled in\n   */\n  static boundedRanges(\n    ranges: readonly GridRange[],\n    columnCount: number,\n    rowCount: number\n  ): BoundedGridRange[] {\n    return ranges.map(r => GridRange.boundedRange(r, columnCount, rowCount));\n  }\n\n  /**\n   * Offsets a GridRange by the specified amount in the x and y directions\n   *\n   * @param range The range to offset\n   * @param columnOffset The number of columns to offset\n   * @param rowOffset The number of rows to offset\n   * @returns The new grid range offset from the original\n   */\n  static offset(\n    range: GridRange,\n    columnOffset: number,\n    rowOffset: number\n  ): GridRange {\n    return new GridRange(\n      range.startColumn != null ? range.startColumn + columnOffset : null,\n      range.startRow != null ? range.startRow + rowOffset : null,\n      range.endColumn != null ? range.endColumn + columnOffset : null,\n      range.endRow != null ? range.endRow + rowOffset : null\n    );\n  }\n\n  /**\n   * Get the next cell given the selected ranges and the current cell\n   * @param ranges The selected bounded ranges within the grid\n   * @param column The cursor column, or null if none focused\n   * @param row The cursor row, or null if none focused\n   * @param direction The direction in which to select next\n   * @returns The next cell to focus, or null if there should be no more focus\n   */\n  static nextCell(\n    ranges: readonly GridRange[],\n    column: GridRangeIndex = null,\n    row: GridRangeIndex = null,\n    direction = GridRange.SELECTION_DIRECTION.DOWN\n  ): GridCell | null {\n    if (ranges.length === 0) {\n      return null;\n    }\n\n    let rangeIndex = -1;\n    if (column != null && row != null) {\n      rangeIndex = ranges.findIndex(r => r.containsCell(column, row));\n\n      if (rangeIndex >= 0) {\n        const range = ranges[rangeIndex];\n        const nextCell = range.nextCell(column, row, direction);\n        if (nextCell != null) {\n          return nextCell;\n        }\n      }\n    }\n\n    // Otherwise go to the start of the next range (could be same range if only one range)\n    switch (direction) {\n      case GridRange.SELECTION_DIRECTION.DOWN:\n      case GridRange.SELECTION_DIRECTION.RIGHT: {\n        const nextRangeIndex =\n          rangeIndex < ranges.length - 1 ? rangeIndex + 1 : 0;\n        const nextRange = ranges[nextRangeIndex];\n        return nextRange.startCell(direction);\n      }\n      case GridRange.SELECTION_DIRECTION.LEFT:\n      case GridRange.SELECTION_DIRECTION.UP: {\n        const nextRangeIndex =\n          rangeIndex > 0 ? rangeIndex - 1 : ranges.length - 1;\n        const nextRange = ranges[nextRangeIndex];\n        return nextRange.startCell(direction);\n      }\n      default:\n        throw new Error(`Invalid direction: ${direction}`);\n    }\n  }\n\n  /**\n   * Count the number of cells in the provided grid ranges\n   * @param ranges The ranges to count the rows of\n   * @returns The number of cells in the ranges, or `NaN` if any of the ranges were unbounded\n   */\n  static cellCount(ranges: readonly GridRange[]): number {\n    return ranges.reduce(\n      (cellCount, range) =>\n        cellCount +\n        ((range.endRow ?? NaN) - (range.startRow ?? NaN) + 1) *\n          ((range.endColumn ?? NaN) - (range.startColumn ?? NaN) + 1),\n      0\n    );\n  }\n\n  /**\n   * Count the number of rows in the provided grid ranges\n   * @param ranges The ranges to count the rows of\n   * @returns The number of rows in the ranges, or `NaN` if any of the ranges were unbounded\n   */\n  static rowCount(ranges: readonly GridRange[]): number {\n    return ranges.reduce(\n      (rowCount, range) =>\n        rowCount + (range.endRow ?? NaN) - (range.startRow ?? NaN) + 1,\n      0\n    );\n  }\n\n  /**\n   * Count the number of columns in the provided grid ranges\n   * @param ranges The ranges to count the columns of\n   * @returns The number of columns in the ranges, or `NaN` if any of the ranges were unbounded\n   */\n  static columnCount(ranges: readonly GridRange[]): number {\n    return ranges.reduce(\n      (columnCount, range) =>\n        columnCount + (range.endColumn ?? NaN) - (range.startColumn ?? NaN) + 1,\n      0\n    );\n  }\n\n  /**\n   * Check if the provided ranges contain the provided cell\n   * @param ranges The ranges to check\n   * @param column The column index\n   * @param row The row index\n   * @returns True if the cell is within the provided ranges, false otherwise.\n   */\n  static containsCell(\n    ranges: readonly GridRange[],\n    column: GridRangeIndex,\n    row: GridRangeIndex\n  ): boolean {\n    for (let i = 0; i < ranges.length; i += 1) {\n      const range = ranges[i];\n      if (range.containsCell(column, row)) {\n        return true;\n      }\n    }\n    return false;\n  }\n\n  /**\n   * Iterate through each cell in the provided ranges\n   * @param ranges The ranges to iterate through\n   * @param callback The callback to execute. `index` is the index within that range\n   * @param direction The direction to iterate in\n   */\n  static forEachCell(\n    ranges: readonly GridRange[],\n    callback: (column: number, row: number, index: number) => void,\n    direction = GridRange.SELECTION_DIRECTION.RIGHT\n  ): void {\n    for (let i = 0; i < ranges.length; i += 1) {\n      ranges[i].forEach(callback, direction);\n    }\n  }\n\n  constructor(\n    startColumn: GridRangeIndex,\n    startRow: GridRangeIndex,\n    endColumn: GridRangeIndex,\n    endRow: GridRangeIndex\n  ) {\n    this.startColumn = startColumn;\n    this.startRow = startRow;\n    this.endColumn = endColumn;\n    this.endRow = endRow;\n  }\n\n  /**\n   * Checks if the provided range is equivalent to this range (same start and end column/row indexes)\n   * @param other Grid range to check against\n   * @returns True if the ranges cover the same area\n   */\n  equals(other: GridRange): boolean {\n    return (\n      this.startColumn === other.startColumn &&\n      this.startRow === other.startRow &&\n      this.endColumn === other.endColumn &&\n      this.endRow === other.endRow\n    );\n  }\n\n  /**\n   * Checks if this GridRange contains another range\n   * @param other The range to check\n   * @returns True if this GridRange completely contains `other`\n   * */\n  contains(other: GridRange): boolean {\n    return (\n      (this.startColumn == null ||\n        (other.startColumn != null && this.startColumn <= other.startColumn)) &&\n      (this.startRow == null ||\n        (other.startRow != null && this.startRow <= other.startRow)) &&\n      (this.endColumn == null ||\n        (other.endColumn != null && this.endColumn >= other.endColumn)) &&\n      (this.endRow == null ||\n        (other.endRow != null && this.endRow >= other.endRow))\n    );\n  }\n\n  /**\n   * Check if the provided cell is in this range\n   * @param column The column to check\n   * @param row The row to check\n   * @returns True if this cell is within this range\n   */\n  containsCell(column: GridRangeIndex, row: GridRangeIndex): boolean {\n    if (column == null || row == null) {\n      return false;\n    }\n\n    return (\n      (this.startColumn == null || this.startColumn <= column) &&\n      (this.endColumn == null || this.endColumn >= column) &&\n      (this.startRow == null || this.startRow <= row) &&\n      (this.endRow == null || this.endRow >= row)\n    );\n  }\n\n  /**\n   * Check if the provided range touches (or overlaps) this GridRange\n   * Effectively checks if the 2 ranges could be represented by 1 continuous range\n   * @param other The range to check\n   * @returns True if this GridRange touches `other`\n   * */\n  touches(other: GridRange): boolean {\n    return (\n      GridRange.isAxisRangeTouching(\n        this.startRow,\n        this.endRow,\n        other.startRow,\n        other.endRow\n      ) &&\n      GridRange.isAxisRangeTouching(\n        this.startColumn,\n        this.endColumn,\n        other.startColumn,\n        other.endColumn\n      )\n    );\n  }\n\n  /**\n   * Subtracts a range from this range\n   * @param other The range to deselect from within this range\n   * @returns The ranges needed to represent the remaining\n   */\n  subtract(other: GridRange): GridRange[] {\n    return GridRange.subtractFromRange(this, other);\n  }\n\n  /**\n   * Get the first cell in this range. Throws if this range is unbounded.\n   *\n   * @param direction The direction to get the starting cell in. Defaults to DOWN\n   * @returns The first cell in this range in the direction specified\n   */\n  startCell(direction = GridRange.SELECTION_DIRECTION.DOWN): GridCell {\n    if (!GridRange.isBounded(this)) {\n      throw new Error('Cannot get the startCell of an unbounded range');\n    }\n\n    switch (direction) {\n      case GridRange.SELECTION_DIRECTION.DOWN:\n      case GridRange.SELECTION_DIRECTION.RIGHT:\n        return { column: this.startColumn, row: this.startRow };\n      case GridRange.SELECTION_DIRECTION.LEFT:\n      case GridRange.SELECTION_DIRECTION.UP: {\n        return { column: this.endColumn, row: this.endRow };\n      }\n      default:\n        throw new Error(`Invalid direction: ${direction}`);\n    }\n  }\n\n  /**\n   * Get the next cell in the direction specified. Throws if this range is unbounded.\n   * If already at the bounds of the range in that direction, wrap to the next column or row\n   * If at the end of the entire range, return null\n   * If outside of the range, returns the next cell closest within this range.\n   *\n   * @param column The cursor column\n   * @param row The cursor row\n   * @param direction The direction to go in\n   * @returns The next cell in the direction specified, or `null` if at the end of the range\n   */\n  nextCell(\n    column: GridRangeIndex,\n    row: GridRangeIndex,\n    direction: SELECTION_DIRECTION\n  ): GridCell | null {\n    if (!GridRange.isBounded(this)) {\n      throw new Error('Bounded range required');\n    }\n    if (column == null || row == null) {\n      throw new Error('Require a non-null cursor');\n    }\n\n    const { startColumn, endColumn, startRow, endRow } = this;\n\n    switch (direction) {\n      case GridRange.SELECTION_DIRECTION.DOWN:\n        if (row < endRow) {\n          return { column, row: Math.max(row + 1, startRow) };\n        }\n\n        if (column < endColumn) {\n          return { column: Math.max(column + 1, startColumn), row: startRow };\n        }\n        break;\n      case GridRange.SELECTION_DIRECTION.UP:\n        if (row > startRow) {\n          return { column, row: Math.min(row - 1, endRow) };\n        }\n\n        if (column > startColumn) {\n          return { column: Math.min(column - 1, endColumn), row: endRow };\n        }\n        break;\n      case GridRange.SELECTION_DIRECTION.RIGHT:\n        if (column < endColumn) {\n          return { column: Math.max(column + 1, startColumn), row };\n        }\n\n        if (row < endRow) {\n          return { column: startColumn, row: Math.max(row + 1, startRow) };\n        }\n        break;\n      case GridRange.SELECTION_DIRECTION.LEFT:\n        if (column > startColumn) {\n          return { column: Math.min(column - 1, endColumn), row };\n        }\n\n        if (row > startRow) {\n          return { column: endColumn, row: Math.min(row - 1, endRow) };\n        }\n        break;\n      default:\n        throw new Error(`Invalid direction: ${direction}`);\n    }\n\n    return null;\n  }\n\n  /**\n   * Iterate through each cell in the range\n   * @param callback Callback to execute. `index` is the index within this range\n   * @param direction The direction to iterate in\n   */\n  forEach(\n    callback: (column: number, row: number, index: number) => void,\n    direction = GridRange.SELECTION_DIRECTION.RIGHT\n  ): void {\n    let i = 0;\n    let { column: c, row: r }: { column?: number; row?: number } =\n      this.startCell(direction);\n    while (c != null && r != null) {\n      callback(c, r, i);\n      i += 1;\n\n      ({ column: c, row: r } = this.nextCell(c, r, direction) ?? {});\n    }\n  }\n}\n\nexport default GridRange;\n"],"mappings":"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","ignoreList":[]}
         | 
    
        package/dist/GridRenderer.js
    CHANGED
    
    | @@ -27,7 +27,7 @@ export class GridRenderer { | |
| 27 27 | 
             
                _defineProperty(this, "getCachedHeaderWidth", memoizeClear((context, text) => context.measureText(text).width, {
         | 
| 28 28 | 
             
                  max: 1000
         | 
| 29 29 | 
             
                }));
         | 
| 30 | 
            -
              } | 
| 30 | 
            +
              }
         | 
| 31 31 | 
             
              /**
         | 
| 32 32 | 
             
               * Truncate a string to the specified length and add ellipses if necessary
         | 
| 33 33 | 
             
               * @param str The string to truncate
         | 
| @@ -122,15 +122,6 @@ export class GridRenderer { | |
| 122 122 | 
             
               * Cache shared between all grids. Often grids will have the same theme/colors, so we should share the cache.
         | 
| 123 123 | 
             
               */
         | 
| 124 124 |  | 
| 125 | 
            -
              /**
         | 
| 126 | 
            -
               * A memoized version of the GridColorUtils.colorWithAlpha function.
         | 
| 127 | 
            -
               */
         | 
| 128 | 
            -
             | 
| 129 | 
            -
              /**
         | 
| 130 | 
            -
               * A memoized version of the ColorUtils.isDark function.
         | 
| 131 | 
            -
               * ColorUtils.isDark is a very expensive function, and having a shared cache between all grids is a good idea.
         | 
| 132 | 
            -
               */
         | 
| 133 | 
            -
             | 
| 134 125 | 
             
              /**
         | 
| 135 126 | 
             
               * Draw the grid canvas with the state provided
         | 
| 136 127 | 
             
               * @param state The state of the grid
         | 
| @@ -2023,8 +2014,8 @@ export class GridRenderer { | |
| 2023 2014 | 
             
                    var _filteredRanges = [..._selectedRanges].filter(value => value.startRow != null && value.endRow != null);
         | 
| 2024 2015 | 
             
                    var _sortedRanges = _filteredRanges.map(value => [value.startRow, value.endRow]).sort(GridUtils.compareRanges);
         | 
| 2025 2016 | 
             
                    var _mergedRanges = GridUtils.mergeSortedRanges(_sortedRanges);
         | 
| 2026 | 
            -
                    for (var  | 
| 2027 | 
            -
                      var _range = _mergedRanges[ | 
| 2017 | 
            +
                    for (var _i0 = 0; _i0 < _mergedRanges.length; _i0 += 1) {
         | 
| 2018 | 
            +
                      var _range = _mergedRanges[_i0];
         | 
| 2028 2019 | 
             
                      var startRow = _range[0];
         | 
| 2029 2020 | 
             
                      var endRow = _range[1];
         | 
| 2030 2021 | 
             
                      if (startRow != null && endRow != null && (startRow !== cursorRow || endRow !== cursorRow)) {
         | 
| @@ -2048,6 +2039,7 @@ export class GridRenderer { | |
| 2048 2039 | 
             
                context.translate(-barLeft, -barTop);
         | 
| 2049 2040 | 
             
              }
         | 
| 2050 2041 | 
             
            }
         | 
| 2042 | 
            +
            // Default radius in pixels for corners for some elements (like the active cell)
         | 
| 2051 2043 | 
             
            _defineProperty(GridRenderer, "DEFAULT_EDGE_RADIUS", 2);
         | 
| 2052 2044 | 
             
            _defineProperty(GridRenderer, "getCachedBackgroundColors", memoizeClear((backgroundColors, maxDepth) => backgroundColors.split(' ').map(color => {
         | 
| 2053 2045 | 
             
              var colors = [];
         | 
| @@ -2058,9 +2050,16 @@ _defineProperty(GridRenderer, "getCachedBackgroundColors", memoizeClear((backgro | |
| 2058 2050 | 
             
            }), {
         | 
| 2059 2051 | 
             
              max: 1000
         | 
| 2060 2052 | 
             
            }));
         | 
| 2053 | 
            +
            /**
         | 
| 2054 | 
            +
             * A memoized version of the GridColorUtils.colorWithAlpha function.
         | 
| 2055 | 
            +
             */
         | 
| 2061 2056 | 
             
            _defineProperty(GridRenderer, "getCachedColorWithAlpha", memoizeClear(GridColorUtils.colorWithAlpha, {
         | 
| 2062 2057 | 
             
              max: 1000
         | 
| 2063 2058 | 
             
            }));
         | 
| 2059 | 
            +
            /**
         | 
| 2060 | 
            +
             * A memoized version of the ColorUtils.isDark function.
         | 
| 2061 | 
            +
             * ColorUtils.isDark is a very expensive function, and having a shared cache between all grids is a good idea.
         | 
| 2062 | 
            +
             */
         | 
| 2064 2063 | 
             
            _defineProperty(GridRenderer, "getCachedColorIsDark", memoizeClear(ColorUtils.isDark, {
         | 
| 2065 2064 | 
             
              max: 1000
         | 
| 2066 2065 | 
             
            }));
         |