handsontable
Version:
Handsontable is a JavaScript Data Grid available for React, Angular and Vue.
35 lines • 1.78 kB
JavaScript
import "core-js/modules/es.error.cause.js";
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); }
import Event from "../event.mjs";
import CoreAbstract from "./_base.mjs";
/**
* @class Walkontable
*/
export default class Clone extends CoreAbstract {
/**
* @param {HTMLTableElement} table Main table.
* @param {SettingsPure|Settings} settings The Walkontable settings.
* @param {WalkontableCloneOptions} clone Clone data.
*/
constructor(table, settings, clone) {
super(table, settings);
/**
* @type {Walkontable}
*/
_defineProperty(this, "cloneSource", void 0);
/**
* @type {Overlay}
*/
_defineProperty(this, "cloneOverlay", void 0);
const facadeGetter = this.wtSettings.getSetting('facade', this);
this.cloneSource = clone.source;
this.cloneOverlay = clone.overlay;
this.wtTable = this.cloneOverlay.createTable(this.getTableDao(), facadeGetter, this.domBindings, this.wtSettings);
this.wtViewport = clone.viewport;
this.selectionManager = clone.selectionManager;
this.wtEvent = new Event(facadeGetter, this.domBindings, this.wtSettings, this.eventManager, this.wtTable, this.selectionManager, clone.event);
this.findOriginalHeaders();
}
}