Class ACellRenderer<T>Abstract

a

ARowRenderer which manages multiple columns per row

Type Parameters

Hierarchy (View Summary)

Constructors

Properties

body: HTMLElement
lastScrollInfo: null | IScrollInfo = null
options: Readonly<IRowRendererOptions> = ...
root: HTMLElement
visible: {
    first: number;
    forcedFirst: number;
    forcedLast: number;
    last: number;
} = ...

currently visible slice

visibleFirstRowPos: number = 0

position of the first visible row in pixel

Accessors

  • get bodyScroller(): HTMLElement
  • get the scrolling container i.e. parent of the body element

    Returns HTMLElement

  • get bodySizer(): HTMLElement
  • Returns HTMLElement

  • get headerScroller(): HTMLElement
  • get the header scrolling element, i.e its parent

    Returns HTMLElement

Methods

  • add another column mixin

    Parameters

    • mixinClass: IMixinClass

      mixing class to instantiate

    • Optionaloptions: unknown

      optional options

    Returns void

  • create a new cell node fo the given row index and column

    Parameters

    • document: Document

      document the create nodes of

    • index: number

      the current row index

    • column: T

      the current column

    Returns HTMLElement | IAsyncUpdate<HTMLElement>

    the node representing the cell

  • create a new header node for the given column

    Parameters

    • document: Document

      document to create nodes of

    • column: T

      the column to create the header for

    Returns HTMLElement | IAsyncUpdate<HTMLElement>

    the node representing the header

  • creates a new row

    Parameters

    • node: HTMLElement

      the node of the row

    • rowIndex: number

    Returns void

    either an abortable or nothing

  • utility to execute a function for each visible row

    Parameters

    • callback: (row: HTMLElement, rowIndex: number) => void

      callback to execute

    • inPlace: boolean = false

      whether the DOM changes should be performed in place instead of in a fragment

    Returns void

  • will be called when scrolled horizontally

    Parameters

    • scrollLeft: number
    • clientWidth: number
    • isGoingRight: boolean

    Returns EScrollResult

  • scrolling vertically

    Parameters

    • scrollTop: number

      top scrolling

    • clientHeight: number

      visible height

    • isGoingDown: boolean

      hint whether the scrollTop increases

    Returns EScrollResult

    full in case of a full rebuild or partial update

  • Parameters

    • item: HTMLElement
    • column: number = -1

    Returns void

  • updates the given cell node with the given row index and column

    Parameters

    • node: HTMLElement

      node to update

    • index: number

      row index to use

    • column: T

      column to use

    Returns void | HTMLElement | IAsyncUpdate<HTMLElement>

    an optional new replacement node for the header

  • updates the given header node with the given column

    Parameters

    • node: HTMLElement

      node to update

    • column: T

      the column to represents

    Returns void | HTMLElement | IAsyncUpdate<HTMLElement>

    an optional new replacement node for the header

  • updates a row

    Parameters

    • node: HTMLElement

      the node of the row

    • rowIndex: number

    Returns void

    either an abortable or nothing

  • Parameters

    • top: number
    • _left: number

    Returns void