UNPKG

handsontable

Version:

Handsontable is a JavaScript Data Grid available for React, Angular and Vue.

48 lines (45 loc) 1.85 kB
"use strict"; 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); }