@kitware/vtk.js
Version:
Visualization Toolkit for the Web
110 lines (82 loc) • 4.1 kB
JavaScript
import _slicedToArray from '@babel/runtime/helpers/slicedToArray';
import { unzipSync, strFromU8 } from 'fflate';
import DataAccessHelper from './DataAccessHelper.js';
import macro from '../../macros.js';
import './DataAccessHelper/HttpDataAccessHelper.js';
// import 'vtk.js/Sources/IO/Core/DataAccessHelper/HtmlDataAccessHelper'; // html + base64 + zip
// import 'vtk.js/Sources/IO/Core/DataAccessHelper/JSZipDataAccessHelper'; // zip
// ----------------------------------------------------------------------------
// vtkAppendPolyData methods
// ----------------------------------------------------------------------------
function vtkZipMultiDataSetReader(publicAPI, model) {
// Set our classname
model.classHierarchy.push('vtkZipMultiDataSetReader'); // Create default dataAccessHelper if not available
if (!model.dataAccessHelper) {
model.dataAccessHelper = DataAccessHelper.get('http');
} // Internal method to fetch Array
function fetchData(url) {
var option = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
return model.dataAccessHelper.fetchBinary(url, option);
} // Set DataSet url
publicAPI.setUrl = function (url) {
var option = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
model.url = url; // Remove the file in the URL
var path = url.split('/');
path.pop();
model.baseURL = path.join('/'); // Fetch metadata
return publicAPI.loadData(option);
}; // Fetch the actual data arrays
publicAPI.loadData = function () {
var option = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
return fetchData(model.url, option).then(publicAPI.parseAsArrayBuffer);
};
publicAPI.parseAsArrayBuffer = function (arrayBuffer) {
if (!arrayBuffer) {
return Promise.reject(new Error('No ArrayBuffer to parse'));
}
return new Promise(function (resolve, reject) {
model.arrays = [];
var decompressedFiles = unzipSync(new Uint8Array(arrayBuffer));
try {
Object.entries(decompressedFiles).forEach(function (_ref) {
var _ref2 = _slicedToArray(_ref, 2),
relativePath = _ref2[0],
fileData = _ref2[1];
if (relativePath.match(/datasets\.json$/i)) {
model.datasets = JSON.parse(strFromU8(fileData));
}
if (relativePath.match(/array_[a-zA-Z]+_[0-9]+/)) {
var _relativePath$split$s = relativePath.split('_').slice(-2),
_relativePath$split$s2 = _slicedToArray(_relativePath$split$s, 2),
type = _relativePath$split$s2[0],
id = _relativePath$split$s2[1];
model.arrays[id] = macro.newTypedArray(type, fileData.buffer);
}
});
resolve();
} catch (err) {
reject(err);
}
});
};
publicAPI.requestData = function (inData, outData) {// perform deserialization
};
} // ----------------------------------------------------------------------------
// Object factory
// ----------------------------------------------------------------------------
var DEFAULT_VALUES = {}; // ----------------------------------------------------------------------------
function extend(publicAPI, model) {
var initialValues = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {};
Object.assign(model, DEFAULT_VALUES, initialValues); // Make this a VTK object
macro.obj(publicAPI, model); // Also make it an algorithm with one input and one output
macro.algo(publicAPI, model, 0, 0);
macro.get(publicAPI, model, ['url', 'baseURL']);
macro.setGet(publicAPI, model, ['dataAccessHelper']); // Object specific methods
vtkZipMultiDataSetReader(publicAPI, model);
} // ----------------------------------------------------------------------------
var newInstance = macro.newInstance(extend, 'vtkZipMultiDataSetReader'); // ----------------------------------------------------------------------------
var index = {
newInstance: newInstance,
extend: extend
};
export { index as default, extend, newInstance };