handsontable
Version:
Handsontable is a JavaScript Data Grid available for React, Angular and Vue.
66 lines (63 loc) • 2.52 kB
JavaScript
exports.__esModule = true;
require("core-js/modules/es.error.cause.js");
var _object = require("../../../helpers/object");
var _utils = require("../utils");
function _defineProperty(e, r, t) { return (r = _toPropertyKey(r)) in e ? Object.defineProperty(e, r, { value: t, enumerable: !0, configurable: !0, writable: !0 }) : e[r] = t, e; }
function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == typeof i ? i : i + ""; }
function _toPrimitive(t, r) { if ("object" != typeof t || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != typeof i) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); }
/**
* The table meta object is a layer that keeps all settings of the Handsontable that was passed in
* the constructor. That layer contains all default settings inherited from the GlobalMeta layer
* merged with settings passed by the developer. Adding, removing, or changing property in that
* object has no direct reflection on any other layers.
*
* +-------------+.
* │ GlobalMeta │
* │ (prototype) │
* +-------------+\
* │ \
* │ \
* \│/ _\|
* +-------------+ +-------------+.
* │ TableMeta │ │ ColumnMeta │
* │ (instance) │ │ (prototype) │
* +-------------+ +-------------+.
* │
* │
* \│/
* +-------------+.
* │ CellMeta │
* │ (instance) │
* +-------------+.
*/
class TableMeta {
constructor(globalMeta) {
/**
* Main object (instance of the internal TableMeta class from GlobalMeta), holder for all settings defined in the table scope.
*
* @type {TableMeta}
*/
_defineProperty(this, "meta", void 0);
const MetaCtor = globalMeta.getMetaConstructor();
this.meta = new MetaCtor();
}
/**
* Gets settings object for this layer.
*
* @returns {TableMeta}
*/
getMeta() {
return this.meta;
}
/**
* Updates table settings object by merging settings with the current state.
*
* @param {object} settings An object to merge with.
*/
updateMeta(settings) {
(0, _object.extend)(this.meta, settings);
(0, _utils.extendByMetaType)(this.meta, settings, settings);
}
}
exports.default = TableMeta;
;