META-INF.resources.frontend.vaadin-spreadsheet.vaadin-spreadsheet.js Maven / Gradle / Ivy
/**
* @license
* Copyright 2000-2024 Vaadin Ltd.
*
* This program is available under Vaadin Commercial License and Service Terms.
*
* See for the full
* license.
*/
import { LitElement, html } from 'lit';
import { Spreadsheet } from './spreadsheet-export.js';
import { spreadsheetStyles, spreadsheetOverlayStyles } from './vaadin-spreadsheet-styles.js';
const spreadsheetResizeObserver = new ResizeObserver((entries) => {
entries.forEach((entry) => entry.target.api.resize());
});
const overlayStyles = (() => {
const $tpl = document.createElement('template');
$tpl.innerHTML = ``;
return $tpl.content;
})();
export class VaadinSpreadsheet extends LitElement {
static get styles() {
return spreadsheetStyles;
}
static get properties() {
return {
api: { type: Object },
dirty: { type: Number },
id: { type: String },
class: { type: String },
resources: { type: String },
popupbuttons: { type: String },
rowBufferSize: { type: Number },
columnBufferSize: { type: Number },
rows: { type: Number },
cols: { type: Number },
colGroupingData: { type: Object },
rowGroupingData: { type: Object },
colGroupingMax: { type: Number },
rowGroupingMax: { type: Number },
colGroupingInversed: { type: Boolean },
rowGroupingInversed: { type: Boolean },
defRowH: { type: Number },
defColW: { type: Number },
rowH: { type: Object },
colW: { type: Object },
reload: { type: Number },
sheetIndex: { type: Number },
sheetNames: { type: Object },
cellStyleToCSSStyle: { type: Object },
rowIndexToStyleIndex: { type: Object },
columnIndexToStyleIndex: { type: Object },
lockedColumnIndexes: { type: Object },
lockedRowIndexes: { type: Object },
shiftedCellBorderStyles: { type: Object },
conditionalFormattingStyles: { type: Object },
hiddenColumnIndexes: { type: Object },
hiddenRowIndexes: { type: Object },
verticalScrollPositions: { type: Object },
horizontalScrollPositions: { type: Object },
sheetProtected: { type: Boolean },
workbookProtected: { type: Boolean },
cellKeysToEditorIdMap: { type: Object },
componentIDtoCellKeysMap: { type: Object },
hyperlinksTooltips: { type: Object },
cellComments: { type: Object },
cellCommentAuthors: { type: Object },
visibleCellComments: { type: Object },
invalidFormulaCells: { type: Object },
hasActions: { type: Boolean },
overlays: { type: Object },
mergedRegions: { type: Object },
displayGridlines: { type: Boolean },
displayRowColHeadings: { type: Boolean },
verticalSplitPosition: { type: Number },
horizontalSplitPosition: { type: Number },
infoLabelValue: { type: String },
workbookChangeToggle: { type: Boolean },
invalidFormulaErrorMessage: { type: String },
lockFormatColumns: { type: Boolean },
lockFormatRows: { type: Boolean },
namedRanges: { type: String },
theme: { type: String, reflectToAttribute: true }
};
}
constructor() {
super();
if (!overlayStyles.parentElement) {
// Append spreadsheet overlay styles to the document head
document.head.appendChild(overlayStyles);
}
}
render() {
return html``;
}
connectedCallback() {
super.connectedCallback();
spreadsheetResizeObserver.observe(this);
}
disconnectedCallback() {
super.disconnectedCallback();
spreadsheetResizeObserver.unobserve(this);
}
updated(_changedProperties) {
super.updated(_changedProperties);
let initial = false;
let overlays = document.getElementById('spreadsheet-overlays');
if (!this.api) {
if (!overlays) {
overlays = document.createElement('div');
overlays.id = 'spreadsheet-overlays';
document.body.appendChild(overlays);
}
this.api = new Spreadsheet(this, this.renderRoot);
this.api.setHeight('100%');
this.api.setWidth('100%');
this.createCallbacks();
initial = true;
}
overlays.setAttribute('theme', this.getAttribute('theme'));
let propNames = [];
let dirty = false;
_changedProperties.forEach((oldValue, name) => {
let newVal = this[name];
if ('dirty' == name) {
dirty = true;
} else if ('rowBufferSize' == name) {
this.api.setRowBufferSize(newVal);
} else if ('columnBufferSize' == name) {
this.api.setColumnBufferSize(newVal);
} else if ('rows' == name) {
this.api.setRows(newVal);
} else if ('cols' == name) {
this.api.setCols(newVal);
} else if ('colGroupingData' == name) {
this.api.setColGroupingData(newVal);
} else if ('rowGroupingData' == name) {
this.api.setRowGroupingData(newVal);
} else if ('colGroupingMax' == name) {
this.api.setColGroupingMax(newVal);
} else if ('rowGroupingMax' == name) {
this.api.setRowGroupingMax(newVal);
} else if ('colGroupingInversed' == name) {
this.api.setColGroupingInversed(newVal);
} else if ('rowGroupingInversed' == name) {
this.api.setRowGroupingInversed(newVal);
} else if ('defRowH' == name) {
this.api.setDefRowH(newVal);
} else if ('defColW' == name) {
this.api.setDefColW(newVal);
} else if ('rowH' == name) {
this.api.setRowH(newVal);
} else if ('colW' == name) {
this.api.setColW(newVal);
} else if ('reload' == name) {
this.api.setReload(true);
} else if ('sheetIndex' == name) {
this.api.setSheetIndex(newVal);
} else if ('sheetNames' == name) {
this.api.setSheetNames(newVal);
} else if ('cellStyleToCSSStyle' == name) {
this.api.setCellStyleToCSSStyle(newVal);
} else if ('rowIndexToStyleIndex' == name) {
this.api.setRowIndexToStyleIndex(newVal);
} else if ('columnIndexToStyleIndex' == name) {
this.api.setColumnIndexToStyleIndex(newVal);
} else if ('lockedColumnIndexes' == name) {
this.api.setLockedColumnIndexes(newVal);
} else if ('lockedRowIndexes' == name) {
this.api.setLockedRowIndexes(newVal);
} else if ('shiftedCellBorderStyles' == name) {
this.api.setShiftedCellBorderStyles(newVal);
} else if ('conditionalFormattingStyles' == name) {
this.api.setConditionalFormattingStyles(newVal);
} else if ('hiddenColumnIndexes' == name) {
this.api.setHiddenColumnIndexes(newVal);
} else if ('hiddenRowIndexes' == name) {
this.api.setHiddenRowIndexes(newVal);
} else if ('verticalScrollPositions' == name) {
this.api.setVerticalScrollPositions(newVal);
} else if ('horizontalScrollPositions' == name) {
this.api.setHorizontalScrollPositions(newVal);
} else if ('sheetProtected' == name) {
this.api.setSheetProtected(newVal);
} else if ('workbookProtected' == name) {
this.api.setWorkbookProtected(newVal);
} else if ('cellKeysToEditorIdMap' == name) {
this.api.setCellKeysToEditorIdMap(newVal);
} else if ('componentIDtoCellKeysMap' == name) {
this.api.setComponentIDtoCellKeysMap(newVal);
} else if ('hyperlinksTooltips' == name) {
this.api.setHyperlinksTooltips(newVal);
} else if ('cellComments' == name) {
this.api.setCellComments(newVal);
} else if ('cellCommentAuthors' == name) {
this.api.setCellCommentAuthors(newVal);
} else if ('visibleCellComments' == name) {
this.api.setVisibleCellComments(newVal);
} else if ('invalidFormulaCells' == name) {
this.api.setInvalidFormulaCells(newVal);
} else if ('hasActions' == name) {
this.api.setHasActions(newVal);
} else if ('overlays' == name) {
this.api.setOverlays(newVal);
} else if ('mergedRegions' == name) {
this.api.setMergedRegions(newVal);
} else if ('displayGridlines' == name) {
this.api.setDisplayGridlines(newVal);
} else if ('displayRowColHeadings' == name) {
this.api.setDisplayRowColHeadings(newVal);
} else if ('verticalSplitPosition' == name) {
this.api.setVerticalSplitPosition(newVal);
} else if ('horizontalSplitPosition' == name) {
this.api.setHorizontalSplitPosition(newVal);
} else if ('infoLabelValue' == name) {
this.api.setInfoLabelValue(newVal);
} else if ('workbookChangeToggle' == name) {
this.api.setWorkbookChangeToggle(newVal);
} else if ('invalidFormulaErrorMessage' == name) {
this.api.setInvalidFormulaErrorMessage(newVal);
} else if ('lockFormatColumns' == name) {
this.api.setLockFormatColumns(newVal);
} else if ('lockFormatRows' == name) {
this.api.setLockFormatRows(newVal);
} else if ('namedRanges' == name) {
this.api.setNamedRanges(newVal);
} else if ('id' == name) {
this.api.setId(newVal);
} else if ('class' == name) {
this.api.setClass(newVal);
} else if ('resources' == name) {
this.api.setResources(this, newVal);
} else if ('api' == name) {
} else if ('theme' == name) {
} else {
console.error(' unsupported property received from server: property=' + name);
}
propNames.push(name);
});
this.api.notifyStateChanges(propNames, initial);
if (initial) {
this.api.relayout();
}
}
/* CLIENT SIDE RPC METHODS */
updateBottomRightCellValues(cellData) {
this.api.updateBottomRightCellValues(cellData);
}
updateTopLeftCellValues(cellData) {
this.api.updateTopLeftCellValues(cellData);
}
updateTopRightCellValues(cellData) {
this.api.updateTopRightCellValues(cellData);
}
updateBottomLeftCellValues(cellData) {
this.api.updateBottomLeftCellValues(cellData);
}
updateFormulaBar(possibleName, col, row) {
this.api.updateFormulaBar(possibleName, col, row);
}
invalidCellAddress() {
this.api.invalidCellAddress();
}
showSelectedCell(name, col, row, cellValue, formula, locked, initialSelection) {
this.api.showSelectedCell(name, col, row, cellValue, formula, locked, initialSelection);
}
showActions(actionDetails) {
this.api.showActions(actionDetails);
}
setSelectedCellAndRange(name, col, row, c1, c2, r1, r2, scroll) {
this.api.setSelectedCellAndRange(name, col, row, c1, c2, r1, r2, scroll);
}
cellsUpdated(updatedCellData) {
if (this.api) this.api.cellsUpdated(updatedCellData);
}
refreshCellStyles() {
if (this.api) this.api.refreshCellStyles();
}
editCellComment(col, row) {
this.api.editCellComment(col, row);
}
onPopupButtonOpen(row, column, contentId, appId) {
this.api.onPopupButtonOpened(row, column, contentId, appId);
}
closePopup(row, column) {
this.api.closePopup(row, column);
}
addPopupButton(rawState) {
this.api.addPopupButton(rawState);
}
removePopupButton(rawState) {
this.api.removePopupButton(rawState);
}
/* SERVER RPC METHOD CALLBACKS */
createCallbacks() {
this.api.setGroupingCollapsedCallback((e) => {
this.dispatchEvent(this.createEvent('groupingCollapsed', e));
});
this.api.setLevelHeaderClickedCallback((e) => {
this.dispatchEvent(this.createEvent('levelHeaderClicked', e));
});
this.api.setOnSheetScrollCallback((e) => {
this.dispatchEvent(this.createEvent('onSheetScroll', e));
});
this.api.setSheetAddressChangedCallback((e) => {
this.dispatchEvent(this.createEvent('sheetAddressChanged', e));
});
this.api.setCellSelectedCallback((e) => {
this.dispatchEvent(this.createEvent('cellSelected', e));
});
this.api.setCellRangeSelectedCallback((e) => {
this.dispatchEvent(this.createEvent('cellRangeSelected', e));
});
this.api.setCellAddedToSelectionAndSelectedCallback((e) => {
this.dispatchEvent(this.createEvent('cellAddedToSelectionAndSelected', e));
});
this.api.setCellsAddedToRangeSelectionCallback((e) => {
this.dispatchEvent(this.createEvent('cellsAddedToRangeSelection', e));
});
this.api.setRowSelectedCallback((e) => {
this.dispatchEvent(this.createEvent('rowSelected', e));
});
this.api.setRowAddedToRangeSelectionCallback((e) => {
this.dispatchEvent(this.createEvent('rowAddedToRangeSelection', e));
});
this.api.setColumnSelectedCallback((e) => {
this.dispatchEvent(this.createEvent('columnSelected', e));
});
this.api.setColumnAddedToSelectionCallback((e) => {
this.dispatchEvent(this.createEvent('columnAddedToSelection', e));
});
this.api.setSelectionIncreasePaintedCallback((e) => {
this.dispatchEvent(this.createEvent('selectionIncreasePainted', e));
});
this.api.setSelectionDecreasePaintedCallback((e) => {
this.dispatchEvent(this.createEvent('selectionDecreasePainted', e));
});
this.api.setCellValueEditedCallback((e) => {
this.dispatchEvent(this.createEvent('cellValueEdited', e));
});
this.api.setSheetSelectedCallback((e) => {
this.dispatchEvent(this.createEvent('sheetSelected', e));
});
this.api.setSheetRenamedCallback((e) => {
this.dispatchEvent(this.createEvent('sheetRenamed', e));
});
this.api.setSheetCreatedCallback((e) => {
this.dispatchEvent(this.createEvent('sheetCreated', e));
});
this.api.setCellRangePaintedCallback((e) => {
this.dispatchEvent(this.createEvent('cellRangePainted', e));
});
this.api.setDeleteSelectedCellsCallback((e) => {
this.dispatchEvent(this.createEvent('deleteSelectedCells', e));
});
this.api.setLinkCellClickedCallback((e) => {
this.dispatchEvent(this.createEvent('linkCellClicked', e));
});
this.api.setRowsResizedCallback((e) => {
this.dispatchEvent(this.createEvent('rowsResized', e));
});
this.api.setColumnResizedCallback((e) => {
this.dispatchEvent(this.createEvent('columnResized', e));
});
this.api.setOnRowAutofitCallback((e) => {
this.dispatchEvent(this.createEvent('onRowAutofit', e));
});
this.api.setOnColumnAutofitCallback((e) => {
this.dispatchEvent(this.createEvent('onColumnAutofit', e));
});
this.api.setOnUndoCallback((e) => {
this.dispatchEvent(this.createEvent('onUndo', e));
});
this.api.setOnRedoCallback((e) => {
this.dispatchEvent(this.createEvent('onRedo', e));
});
this.api.setSetCellStyleWidthRatiosCallback((e) => {
this.dispatchEvent(this.createEvent('setCellStyleWidthRatios', e));
});
this.api.setProtectedCellWriteAttemptedCallback((e) => {
this.dispatchEvent(this.createEvent('protectedCellWriteAttempted', e));
});
this.api.setOnPasteCallback((e) => {
this.dispatchEvent(this.createEvent('onPaste', e));
});
this.api.setClearSelectedCellsOnCutCallback((e) => {
this.dispatchEvent(this.createEvent('clearSelectedCellsOnCut', e));
});
this.api.setUpdateCellCommentCallback((e) => {
this.dispatchEvent(this.createEvent('updateCellComment', e));
});
this.api.setOnConnectorInitCallback((e) => {
this.dispatchEvent(this.createEvent('onConnectorInit', e));
});
this.api.setContextMenuOpenOnSelectionCallback((e) => {
this.dispatchEvent(this.createEvent('contextMenuOpenOnSelection', e));
});
this.api.setActionOnCurrentSelectionCallback((e) => {
this.dispatchEvent(this.createEvent('actionOnCurrentSelection', e));
});
this.api.setRowHeaderContextMenuOpenCallback((e) => {
this.dispatchEvent(this.createEvent('rowHeaderContextMenuOpen', e));
});
this.api.setActionOnRowHeaderCallback((e) => {
this.dispatchEvent(this.createEvent('actionOnRowHeader', e));
});
this.api.setColumnHeaderContextMenuOpenCallback((e) => {
this.dispatchEvent(this.createEvent('columnHeaderContextMenuOpen', e));
});
this.api.setActionOnColumnHeaderCallback((e) => {
this.dispatchEvent(this.createEvent('actionOnColumnHeader', e));
});
this.api.setPopupButtonClickCallback((e) => {
this.dispatchEvent(this.createEvent('popupButtonClick', e));
});
this.api.setPopupCloseCallback((e) => {
this.dispatchEvent(this.createEvent('popupClose', e));
});
this.dispatchEvent(this.createEvent('onConnectorInit'), []);
}
createEvent(type, data) {
return new CustomEvent('spreadsheet-event', {
detail: { type, data }
});
}
}
window.customElements.define('vaadin-spreadsheet', VaadinSpreadsheet);
© 2015 - 2025 Weber Informatics LLC | Privacy Policy