kepler.gl
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
244 lines (199 loc) • 23.7 kB
JavaScript
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.readFile = readFile;
exports.getFileHandler = getFileHandler;
exports.getFileType = getFileType;
exports.loadCsv = loadCsv;
exports.loadJSON = loadJSON;
exports.readJSONFile = readJSONFile;
exports.isGeoJson = isGeoJson;
exports.isFeature = isFeature;
exports.isFeatureCollection = isFeatureCollection;
exports.isRowObject = isRowObject;
exports.isKeplerGlMap = isKeplerGlMap;
exports.determineJsonProcess = determineJsonProcess;
exports.filesToDataPayload = filesToDataPayload;
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray"));
var _window = require("global/window");
var _console = _interopRequireDefault(require("global/console"));
var _dataProcessor = require("./data-processor");
var _utils = require("../utils/utils");
var _defaultSettings = require("../constants/default-settings");
function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; }
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { (0, _defineProperty2["default"])(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
var FILE_HANDLERS = {
csv: loadCsv,
json: loadJSON
};
function readFile(_ref) {
var file = _ref.file,
_ref$fileCache = _ref.fileCache,
fileCache = _ref$fileCache === void 0 ? [] : _ref$fileCache;
return new Promise(function (resolve, reject) {
var _getFileHandler = getFileHandler(file),
handler = _getFileHandler.handler,
format = _getFileHandler.format;
if (!handler) {
_console["default"].warn("Canont determine file handler for file ".concat(file.name, ". It must have a valid file extension"));
resolve(fileCache);
}
handler({
file: file,
format: format
}).then(function (result) {
if (!result || !result.data) {
// return fileCache, to keep process other files
resolve(fileCache);
}
resolve([].concat((0, _toConsumableArray2["default"])(fileCache), [{
data: result.data,
info: {
label: file.name,
format: result.format
}
}]));
});
});
}
function getFileHandler(fileBlob) {
var type = getFileType(fileBlob.name);
return {
handler: FILE_HANDLERS[type],
format: type
};
}
function getFileType(filename) {
if (filename.endsWith('csv')) {
return 'csv';
} else if (filename.endsWith('json') || filename.endsWith('geojson')) {
// Read GeoJson from browser
return 'json';
} // Wait to add other file type handler
return 'other';
}
function readCSVFile(fileBlob) {
return new Promise(function (resolve, reject) {
var fileReader = new _window.FileReader();
fileReader.onload = function (_ref2) {
var result = _ref2.target.result;
resolve(result);
};
fileReader.readAsText(fileBlob);
});
}
function loadCsv(_ref3) {
var file = _ref3.file,
format = _ref3.format,
_ref3$processor = _ref3.processor,
processor = _ref3$processor === void 0 ? _dataProcessor.processCsvData : _ref3$processor;
return readCSVFile(file).then(function (rawData) {
return rawData ? {
data: processor(rawData),
format: format
} : null;
});
}
function loadJSON(_ref4) {
var file = _ref4.file,
_ref4$processor = _ref4.processor,
processor = _ref4$processor === void 0 ? _dataProcessor.processGeojson : _ref4$processor;
return readJSONFile(file).then(function (content) {
if (isKeplerGlMap(content)) {
return {
format: _defaultSettings.DATASET_FORMATS.keplergl,
data: (0, _dataProcessor.processKeplerglJSON)(content)
};
} else if (isRowObject(content)) {
return {
format: _defaultSettings.DATASET_FORMATS.row,
data: (0, _dataProcessor.processRowObject)(content)
};
} else if (isGeoJson(content)) {
return {
format: _defaultSettings.DATASET_FORMATS.geojson,
data: (0, _dataProcessor.processGeojson)(content)
};
} // unsupported json format
_console["default"].warn("unsupported Json format ".concat(file.name));
return null;
});
}
function readJSONFile(fileBlob) {
return new Promise(function (resolve, reject) {
var fileReader = new _window.FileReader();
fileReader.onload = function (_ref5) {
var result = _ref5.target.result;
try {
var json = JSON.parse(result);
resolve(json);
} catch (err) {
reject(null);
}
};
fileReader.readAsText(fileBlob, 'UTF-8');
});
}
function isGeoJson(json) {
// json can be feature collection
// or simgle feature
return (0, _utils.isPlainObject)(json) && (isFeature(json) || isFeatureCollection(json));
}
function isFeature(json) {
return json.type === 'Feature' && json.geometry;
}
function isFeatureCollection(json) {
return json.type === 'FeatureCollection' && json.features;
}
function isRowObject(json) {
return Array.isArray(json) && (0, _utils.isPlainObject)(json[0]);
}
function isKeplerGlMap(json) {
return (0, _utils.isPlainObject)(json) && json.datasets && json.config && json.info && json.info.app === 'kepler.gl';
}
function determineJsonProcess(_ref6, defaultProcessor) {
var dataset = _ref6.dataset,
format = _ref6.format;
if (isKeplerGlMap(dataset)) {
return _dataProcessor.processKeplerglJSON;
}
return defaultProcessor;
}
function filesToDataPayload(fileCache) {
// seperate out files which could be a single datasets. or a keplergl map json
var collection = fileCache.reduce(function (accu, file) {
var data = file.data,
_file$info = file.info,
info = _file$info === void 0 ? {} : _file$info;
var format = info.format;
if (format === _defaultSettings.DATASET_FORMATS.keplergl) {
// if file contains a single kepler map dataset & config
accu.keplerMaps.push(_objectSpread({}, data, {
options: {
centerMap: !(data.config && data.config.mapState)
}
}));
} else if (_defaultSettings.DATASET_FORMATS[format]) {
// if file contains only data
var newDataset = {
data: data,
info: _objectSpread({
id: info.id || (0, _utils.generateHashId)(4)
}, info)
};
accu.datasets.push(newDataset);
}
return accu;
}, {
datasets: [],
keplerMaps: []
}); // add kepler map first with config
// add datasets later in one add data call
return collection.keplerMaps.concat({
datasets: collection.datasets
});
}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/processors/file-handler.js"],"names":["FILE_HANDLERS","csv","loadCsv","json","loadJSON","readFile","file","fileCache","Promise","resolve","reject","getFileHandler","handler","format","Console","warn","name","then","result","data","info","label","fileBlob","type","getFileType","filename","endsWith","readCSVFile","fileReader","FileReader","onload","target","readAsText","processor","processCsvData","rawData","processGeojson","readJSONFile","content","isKeplerGlMap","DATASET_FORMATS","keplergl","isRowObject","row","isGeoJson","geojson","JSON","parse","err","isFeature","isFeatureCollection","geometry","features","Array","isArray","datasets","config","app","determineJsonProcess","defaultProcessor","dataset","processKeplerglJSON","filesToDataPayload","collection","reduce","accu","keplerMaps","push","options","centerMap","mapState","newDataset","id","concat"],"mappings":"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","sourcesContent":["// Copyright (c) 2020 Uber Technologies, Inc.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a copy\n// of this software and associated documentation files (the \"Software\"), to deal\n// in the Software without restriction, including without limitation the rights\n// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n// copies of the Software, and to permit persons to whom the Software is\n// furnished to do so, subject to the following conditions:\n//\n// The above copyright notice and this permission notice shall be included in\n// all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n// THE SOFTWARE.\n\nimport {FileReader} from 'global/window';\nimport Console from 'global/console';\nimport {\n  processCsvData,\n  processGeojson,\n  processKeplerglJSON,\n  processRowObject\n} from './data-processor';\nimport {isPlainObject, generateHashId} from 'utils/utils';\nimport {DATASET_FORMATS} from 'constants/default-settings';\n\nconst FILE_HANDLERS = {\n  csv: loadCsv,\n  json: loadJSON\n};\n\nexport function readFile({file, fileCache = []}) {\n  return new Promise((resolve, reject) => {\n    const {handler, format} = getFileHandler(file);\n    if (!handler) {\n      Console.warn(\n        `Canont determine file handler for file ${file.name}. It must have a valid file extension`\n      );\n      resolve(fileCache);\n    }\n\n    handler({file, format}).then(result => {\n      if (!result || !result.data) {\n        // return fileCache, to keep process other files\n        resolve(fileCache);\n      }\n      resolve([\n        ...fileCache,\n        {\n          data: result.data,\n          info: {\n            label: file.name,\n            format: result.format\n          }\n        }\n      ]);\n    });\n  });\n}\n\nexport function getFileHandler(fileBlob) {\n  const type = getFileType(fileBlob.name);\n\n  return {handler: FILE_HANDLERS[type], format: type};\n}\n\nexport function getFileType(filename) {\n  if (filename.endsWith('csv')) {\n    return 'csv';\n  } else if (filename.endsWith('json') || filename.endsWith('geojson')) {\n    // Read GeoJson from browser\n    return 'json';\n  }\n\n  // Wait to add other file type handler\n  return 'other';\n}\n\nfunction readCSVFile(fileBlob) {\n  return new Promise((resolve, reject) => {\n    const fileReader = new FileReader();\n    fileReader.onload = ({target: {result}}) => {\n      resolve(result);\n    };\n\n    fileReader.readAsText(fileBlob);\n  });\n}\n\nexport function loadCsv({file, format, processor = processCsvData}) {\n  return readCSVFile(file).then(rawData => (rawData ? {data: processor(rawData), format} : null));\n}\n\nexport function loadJSON({file, processor = processGeojson}) {\n  return readJSONFile(file).then(content => {\n    if (isKeplerGlMap(content)) {\n      return {\n        format: DATASET_FORMATS.keplergl,\n        data: processKeplerglJSON(content)\n      };\n    } else if (isRowObject(content)) {\n      return {\n        format: DATASET_FORMATS.row,\n        data: processRowObject(content)\n      };\n    } else if (isGeoJson(content)) {\n      return {\n        format: DATASET_FORMATS.geojson,\n        data: processGeojson(content)\n      };\n    }\n    // unsupported json format\n    Console.warn(`unsupported Json format ${file.name}`);\n    return null;\n  });\n}\n\nexport function readJSONFile(fileBlob) {\n  return new Promise((resolve, reject) => {\n    const fileReader = new FileReader();\n    fileReader.onload = ({target: {result}}) => {\n      try {\n        const json = JSON.parse(result);\n        resolve(json);\n      } catch (err) {\n        reject(null);\n      }\n    };\n\n    fileReader.readAsText(fileBlob, 'UTF-8');\n  });\n}\n\nexport function isGeoJson(json) {\n  // json can be feature collection\n  // or simgle feature\n  return isPlainObject(json) && (isFeature(json) || isFeatureCollection(json));\n}\n\nexport function isFeature(json) {\n  return json.type === 'Feature' && json.geometry;\n}\n\nexport function isFeatureCollection(json) {\n  return json.type === 'FeatureCollection' && json.features;\n}\n\nexport function isRowObject(json) {\n  return Array.isArray(json) && isPlainObject(json[0]);\n}\n\nexport function isKeplerGlMap(json) {\n  return (\n    isPlainObject(json) &&\n    json.datasets &&\n    json.config &&\n    json.info &&\n    json.info.app === 'kepler.gl'\n  );\n}\n\nexport function determineJsonProcess({dataset, format}, defaultProcessor) {\n  if (isKeplerGlMap(dataset)) {\n    return processKeplerglJSON;\n  }\n\n  return defaultProcessor;\n}\n\nexport function filesToDataPayload(fileCache) {\n  // seperate out files which could be a single datasets. or a keplergl map json\n  const collection = fileCache.reduce(\n    (accu, file) => {\n      const {data, info = {}} = file;\n      const {format} = info;\n      if (format === DATASET_FORMATS.keplergl) {\n        // if file contains a single kepler map dataset & config\n        accu.keplerMaps.push({\n          ...data,\n          options: {\n            centerMap: !(data.config && data.config.mapState)\n          }\n        });\n      } else if (DATASET_FORMATS[format]) {\n        // if file contains only data\n        const newDataset = {\n          data,\n          info: {\n            id: info.id || generateHashId(4),\n            ...info\n          }\n        };\n        accu.datasets.push(newDataset);\n      }\n      return accu;\n    },\n    {datasets: [], keplerMaps: []}\n  );\n\n  // add kepler map first with config\n  // add datasets later in one add data call\n  return collection.keplerMaps.concat({datasets: collection.datasets});\n}\n"]}
;