UNPKG

handsontable

Version:

Handsontable is a JavaScript Spreadsheet Component available for React, Angular and Vue.

61 lines (49 loc) 1.85 kB
import staticRegister from "../utils/staticRegister.mjs"; import { registerEditor } from "../editors/registry.mjs"; import { registerRenderer } from "../renderers/registry.mjs"; import { registerValidator } from "../validators/registry.mjs"; var _staticRegister = staticRegister('cellTypes'), register = _staticRegister.register, getItem = _staticRegister.getItem, hasItem = _staticRegister.hasItem, getNames = _staticRegister.getNames, getValues = _staticRegister.getValues; /** * Retrieve cell type object. * * @param {string} name Cell type identification. * @returns {object} Returns cell type object. */ function _getItem(name) { if (!hasItem(name)) { throw Error("You declared cell type \"".concat(name, "\" as a string that is not mapped to a known object.\n Cell type must be an object or a string mapped to an object registered by\n \"Handsontable.cellTypes.registerCellType\" method")); } return getItem(name); } /** * Register cell type under specified name. * * @param {string} name Cell type identification. * @param {object} type An object with contains keys (eq: `editor`, `renderer`, `validator`) which describes specified behaviour of the cell. */ function _register(name, type) { if (typeof name !== 'string') { type = name; name = type.CELL_TYPE; } var _type = type, editor = _type.editor, renderer = _type.renderer, validator = _type.validator; if (editor) { registerEditor(name, editor); } if (renderer) { registerRenderer(name, renderer); } if (validator) { registerValidator(name, validator); } register(name, type); } export { _register as registerCellType, _getItem as getCellType, hasItem as hasCellType, getNames as getRegisteredCellTypeNames, getValues as getRegisteredCellTypes };