JavaScript Data Grid DataMap
Description
Utility class that gets and saves data from/to the data source using mapping of columns numbers to object property names.
Members
colToPropCache
Source code (opens new window)dataMap.colToPropCache : Array
Cached array of properties to columns.
dataSource
Source code (opens new window)dataMap.dataSource : *
Reference to the original dataset.
DESTINATION_CLIPBOARD_GENERATOR
Source code (opens new window)DataMap.DESTINATION_CLIPBOARD_GENERATOR : number
DESTINATION_RENDERER
Source code (opens new window)DataMap.DESTINATION_RENDERER : number
duckSchema
Source code (opens new window)dataMap.duckSchema : object
Generated schema based on the first row from the source data.
propToColCache
Source code (opens new window)dataMap.propToColCache : Map
Cached map of properties to columns.
Methods
clear
Source code (opens new window)dataMap.clear()
Clears the data array.
colToProp
Source code (opens new window)dataMap.colToProp(column) ⇒ string | number
Returns property name that corresponds with the given column index.
Param | Type | Description |
---|---|---|
column | string number | Visual column index or another passed argument. |
Returns: string
| number
- Column property, physical column index or passed argument.
countCachedColumns
Source code (opens new window)dataMap.countCachedColumns() ⇒ number
Count the number of columns cached in the colToProp
cache.
Returns: number
- Amount of cached columns.
countFirstRowKeys
Source code (opens new window)dataMap.countFirstRowKeys() ⇒ number
Get the amount of physical columns in the first data row.
Returns: number
- Amount of physical columns in the first data row.
createCol
Source code (opens new window)dataMap.createCol([index], [amount], [options]) ⇒ number
Creates column at the right of the data array.
Emits: Hooks#event:afterCreateCol
Param | Type | Default | Description |
---|---|---|---|
[index] | number | optional Visual index of the column before which the new column will be inserted. | |
[amount] | number | 1 | optional An amount of columns to add. |
[options] | object | optional Additional options for created columns. | |
[options.source] | string | optional Source of method call. | |
[options.mode] | 'start' 'end' | optional Sets where the column is inserted: at the start (left in LTR, right in RTL) or at the end (right in LTR, left in LTR) the passed index. |
Returns: number
- Returns number of created columns.
createMap
Source code (opens new window)dataMap.createMap()
Generates cache for property to and from column addressation.
createRow
Source code (opens new window)dataMap.createRow([index], [amount], [options]) ⇒ number
Creates row at the bottom of the data array.
Emits: Hooks#event:afterCreateRow
Param | Type | Default | Description |
---|---|---|---|
[index] | number | optional Physical index of the row before which the new row will be inserted. | |
[amount] | number | 1 | optional An amount of rows to add. |
[options] | object | optional Additional options for created rows. | |
[options.source] | string | optional Source of method call. | |
[options.mode] | 'above' 'below' | optional Sets where the row is inserted: above or below the passed index. |
Returns: number
- Returns number of created rows.
destroy
Source code (opens new window)dataMap.destroy()
Destroy instance.
filterData
Source code (opens new window)dataMap.filterData(index, amount, physicalRows)
Filter unwanted data elements from the data source.
Param | Type | Description |
---|---|---|
index | number | Visual index of the element to remove. |
amount | number | Number of rows to add/remove. |
physicalRows | number | Physical row indexes. |
get
Source code (opens new window)dataMap.get(row, prop) ⇒ *
Returns single value from the data array.
Param | Type | Description |
---|---|---|
row | number | Visual row index. |
prop | number | The column property. |
getAll
Source code (opens new window)dataMap.getAll() ⇒ Array
Returns the data array.
getCopyable
Source code (opens new window)dataMap.getCopyable(row, prop) ⇒ string
Returns single value from the data array (intended for clipboard copy to an external application).
Param | Type | Description |
---|---|---|
row | number | Physical row index. |
prop | number | The column property. |
getCopyableText
Source code (opens new window)dataMap.getCopyableText([start], [end]) ⇒ string
Return data as copyable text (tab separated columns intended for clipboard copy to an external application).
Param | Type | Description |
---|---|---|
[start] | object | optional Start selection position. Visual indexes. |
[end] | object | optional End selection position. Visual indexes. |
getLength
Source code (opens new window)dataMap.getLength() ⇒ number
Get data length.
getRange
Source code (opens new window)dataMap.getRange([start], [end], destination) ⇒ Array
Returns data range as array.
Param | Type | Description |
---|---|---|
[start] | object | optional Start selection position. Visual indexes. |
[end] | object | optional End selection position. Visual indexes. |
destination | number | Destination of datamap.get. |
getSchema
Source code (opens new window)dataMap.getSchema() ⇒ object
Returns data's schema.
getText
Source code (opens new window)dataMap.getText([start], [end]) ⇒ string
Return data as text (tab separated columns).
Param | Type | Description |
---|---|---|
[start] | object | optional Start selection position. Visual indexes. |
[end] | object | optional End selection position. Visual indexes. |
propToCol
Source code (opens new window)dataMap.propToCol(prop) ⇒ string | number
Translates property into visual column index.
Param | Type | Description |
---|---|---|
prop | string number | Column property which may be also a physical column index. |
Returns: string
| number
- Visual column index or passed argument.
recursiveDuckColumns
Source code (opens new window)dataMap.recursiveDuckColumns(schema, lastCol, parent) ⇒ number
Generates columns' translation cache.
Param | Type | Description |
---|---|---|
schema | object | An object to generate schema from. |
lastCol | number | The column index. |
parent | number | The property cache for recursive calls. |
removeCol
Source code (opens new window)dataMap.removeCol([index], [amount], [source]) ⇒ boolean
Removes column from the data array.
Emits: Hooks#event:beforeRemoveCol
, Hooks#event:afterRemoveCol
Param | Type | Default | Description |
---|---|---|---|
[index] | number | optional Visual index of the column to be removed. If not provided, the last column will be removed. | |
[amount] | number | 1 | optional Amount of the columns to be removed. If not provided, one column will be removed. |
[source] | string | optional Source of method call. |
Returns: boolean
- Returns false
when action was cancelled, otherwise true
.
removeRow
Source code (opens new window)dataMap.removeRow([index], [amount], [source]) ⇒ boolean
Removes row from the data array.
Emits: Hooks#event:beforeRemoveRow
, Hooks#event:afterRemoveRow
Param | Type | Default | Description |
---|---|---|---|
[index] | number | optional Visual index of the row to be removed. If not provided, the last row will be removed. | |
[amount] | number | 1 | optional Amount of the rows to be removed. If not provided, one row will be removed. |
[source] | string | optional Source of method call. |
Returns: boolean
- Returns false
when action was cancelled, otherwise true
.
set
Source code (opens new window)dataMap.set(row, prop, value)
Saves single value to the data array.
Param | Type | Description |
---|---|---|
row | number | Visual row index. |
prop | number | The column property. |
value | string | The value to set. |
spliceCol
Source code (opens new window)dataMap.spliceCol(col, index, amount, [...elements]) ⇒ Array
Add/Removes data from the column.
Param | Type | Description |
---|---|---|
col | number | Physical index of column in which do you want to do splice. |
index | number | Index at which to start changing the array. If negative, will begin that many elements from the end. |
amount | number | An integer indicating the number of old array elements to remove. If amount is 0, no elements are removed. |
[...elements] | Array | optional The new columns to add. |
Returns: Array
- Returns removed portion of columns.
spliceData
Source code (opens new window)dataMap.spliceData(index, deleteCount, elements)
Add/remove row(s) to/from the data source.
Param | Type | Description |
---|---|---|
index | number | Physical index of the element to add/remove. |
deleteCount | number | Number of rows to remove. |
elements | Array<object> | Row elements to be added. |
spliceRow
Source code (opens new window)dataMap.spliceRow(row, index, amount, [...elements]) ⇒ Array
Add/Removes data from the row.
Param | Type | Description |
---|---|---|
row | number | Physical index of row in which do you want to do splice. |
index | number | Index at which to start changing the array. If negative, will begin that many elements from the end. |
amount | number | An integer indicating the number of old array elements to remove. If amount is 0, no elements are removed. |
[...elements] | Array | optional The new rows to add. |
Returns: Array
- Returns removed portion of rows.
visualColumnsToPhysical
Source code (opens new window)dataMap.visualColumnsToPhysical(index, amount) ⇒ Array
Param | Type | Description |
---|---|---|
index | number | Visual column index. |
amount | number | An amount of rows to translate. |
visualRowsToPhysical
Source code (opens new window)dataMap.visualRowsToPhysical(index, amount) ⇒ number
This ridiculous piece of code maps rows Id that are present in table data to those displayed for user. The trick is, the physical row id (stored in settings.data) is not necessary the same as the visual (displayed) row id (e.g. When sorting is applied).
Param | Type | Description |
---|---|---|
index | number | Visual row index. |
amount | number | An amount of rows to translate. |