* Remplacement de unzipit par zip.js * Générer un fichier qui est valide et s'ouvre dans LibreOffice * blip bloop, smaller browser bundle * uninstall xlsx
77 lines
1.8 KiB
JavaScript
77 lines
1.8 KiB
JavaScript
//@ts-check
|
|
|
|
import {DOMParser, DOMImplementation, XMLSerializer} from '@xmldom/xmldom'
|
|
|
|
import {
|
|
_getODSTableRawContent,
|
|
_getXLSXTableRawContent
|
|
} from './shared.js'
|
|
import { _createOdsFile } from './createOdsFile.js'
|
|
|
|
/** @import {SheetCellRawContent, SheetName, SheetRawContent} from './types.js' */
|
|
|
|
|
|
function parseXML(str){
|
|
return (new DOMParser()).parseFromString(str, 'application/xml');
|
|
}
|
|
|
|
|
|
/**
|
|
* @param {ArrayBuffer} odsArrBuff
|
|
* @returns {ReturnType<_getODSTableRawContent>}
|
|
*/
|
|
export function getODSTableRawContent(odsArrBuff){
|
|
return _getODSTableRawContent(odsArrBuff, parseXML)
|
|
}
|
|
|
|
/**
|
|
* @param {ArrayBuffer} xlsxArrBuff
|
|
* @returns {ReturnType<_getXLSXTableRawContent>}
|
|
*/
|
|
export function getXLSXTableRawContent(xlsxArrBuff){
|
|
return _getXLSXTableRawContent(xlsxArrBuff, parseXML)
|
|
}
|
|
|
|
const implementation = new DOMImplementation()
|
|
|
|
/** @type { typeof DOMImplementation.prototype.createDocument } */
|
|
const createDocument = function createDocument(...args){
|
|
// @ts-ignore
|
|
return implementation.createDocument(...args)
|
|
}
|
|
|
|
const serializer = new XMLSerializer()
|
|
|
|
/** @type { typeof XMLSerializer.prototype.serializeToString } */
|
|
const serializeToString = function serializeToString(node){
|
|
return serializer.serializeToString(node)
|
|
}
|
|
|
|
/**
|
|
* @param {Map<SheetName, SheetRawContent>} sheetsData
|
|
*/
|
|
export function createOdsFile(sheetsData){
|
|
return _createOdsFile(sheetsData, createDocument, serializeToString)
|
|
}
|
|
|
|
export {
|
|
// table-level exports
|
|
tableWithoutEmptyRows,
|
|
tableRawContentToValues,
|
|
tableRawContentToStrings,
|
|
tableRawContentToObjects,
|
|
|
|
// sheet-level exports
|
|
sheetRawContentToObjects,
|
|
sheetRawContentToStrings,
|
|
|
|
// row-level exports
|
|
rowRawContentToStrings,
|
|
isRowNotEmpty,
|
|
|
|
// cell-level exports
|
|
cellRawContentToStrings,
|
|
convertCellValue
|
|
} from './shared.js'
|
|
|