handsontable
Version:
Handsontable is a JavaScript Data Grid available for React, Angular and Vue.
48 lines (45 loc) • 1.85 kB
JavaScript
;
exports.__esModule = true;
exports.getClassesToAdd = getClassesToAdd;
exports.getClassesToRemove = getClassesToRemove;
require("core-js/modules/es.array.push.js");
var _mixed = require("../../helpers/mixed");
var _utils = require("./utils");
const HEADER_CLASS_ASC_SORT = 'ascending';
const HEADER_CLASS_DESC_SORT = 'descending';
const HEADER_CLASS_INDICATOR_DISABLED = 'indicatorDisabled';
const HEADER_SORT_CLASS = 'columnSorting';
const HEADER_ACTION_CLASS = 'sortAction';
const orderToCssClass = new Map([[_utils.ASC_SORT_STATE, HEADER_CLASS_ASC_SORT], [_utils.DESC_SORT_STATE, HEADER_CLASS_DESC_SORT]]);
/**
* Get CSS classes which should be added to particular column header.
*
* @param {object} columnStatesManager Instance of column state manager.
* @param {number} column Visual column index.
* @param {boolean} showSortIndicator Indicates if indicator should be shown for the particular column.
* @param {boolean} headerAction Indicates if header click to sort should be possible.
* @returns {Array} Array of CSS classes.
*/
function getClassesToAdd(columnStatesManager, column, showSortIndicator, headerAction) {
const cssClasses = [HEADER_SORT_CLASS];
if (headerAction) {
cssClasses.push(HEADER_ACTION_CLASS);
}
if (showSortIndicator === false) {
cssClasses.push(HEADER_CLASS_INDICATOR_DISABLED);
return cssClasses;
}
const columnOrder = columnStatesManager.getSortOrderOfColumn(column);
if ((0, _mixed.isDefined)(columnOrder)) {
cssClasses.push(orderToCssClass.get(columnOrder));
}
return cssClasses;
}
/**
* Get CSS classes which should be removed from column header.
*
* @returns {Array} Array of CSS classes.
*/
function getClassesToRemove() {
return Array.from(orderToCssClass.values()).concat(HEADER_ACTION_CLASS, HEADER_CLASS_INDICATOR_DISABLED, HEADER_SORT_CLASS);
}