kepler.gl
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
97 lines (83 loc) • 12.1 kB
JavaScript
;
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.getTextOffsetByRadius = getTextOffsetByRadius;
exports.formatTextLabelData = exports.textLabelAccessor = exports.defaultPadding = void 0;
var _viewportMercatorProject = require("viewport-mercator-project");
var _dataUtils = require("../utils/data-utils");
var _lodash = _interopRequireDefault(require("lodash.uniq"));
// Copyright (c) 2021 Uber Technologies, Inc.
//
// Permission is hereby granted, free of charge, to any person obtaining a copy
// of this software and associated documentation files (the "Software"), to deal
// in the Software without restriction, including without limitation the rights
// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
// copies of the Software, and to permit persons to whom the Software is
// furnished to do so, subject to the following conditions:
//
// The above copyright notice and this permission notice shall be included in
// all copies or substantial portions of the Software.
//
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
// THE SOFTWARE.
var defaultPadding = 20;
exports.defaultPadding = defaultPadding;
function getTextOffsetByRadius(radiusScale, getRadius, mapState) {
return function (textLabel) {
var distanceScale = (0, _viewportMercatorProject.getDistanceScales)(mapState);
var xMult = textLabel.anchor === 'middle' ? 0 : textLabel.anchor === 'start' ? 1 : -1;
var yMult = textLabel.alignment === 'center' ? 0 : textLabel.alignment === 'bottom' ? 1 : -1;
var sizeOffset = textLabel.alignment === 'center' ? 0 : textLabel.alignment === 'bottom' ? textLabel.size : textLabel.size;
var pixelRadius = radiusScale * distanceScale.pixelsPerMeter[0];
var padding = defaultPadding;
return typeof getRadius === 'function' ? function (d) {
return [xMult * (getRadius(d) * pixelRadius + padding), yMult * (getRadius(d) * pixelRadius + padding + sizeOffset)];
} : [xMult * (getRadius * pixelRadius + padding), yMult * (getRadius * pixelRadius + padding + sizeOffset)];
};
}
var textLabelAccessor = function textLabelAccessor(textLabel) {
return function (dc) {
return function (d) {
var val = textLabel.field.valueAccessor(d);
return (0, _dataUtils.notNullorUndefined)(val) ? String(val) : '';
};
};
};
exports.textLabelAccessor = textLabelAccessor;
var formatTextLabelData = function formatTextLabelData(_ref) {
var textLabel = _ref.textLabel,
triggerChanged = _ref.triggerChanged,
oldLayerData = _ref.oldLayerData,
data = _ref.data,
dataContainer = _ref.dataContainer;
return textLabel.map(function (tl, i) {
if (!tl.field) {
// if no field selected,
return {
getText: null,
characterSet: []
};
}
var getText = textLabelAccessor(tl)(dataContainer);
var characterSet;
if (!triggerChanged["getLabelCharacterSet-".concat(i)] && oldLayerData && oldLayerData.textLabels && oldLayerData.textLabels[i]) {
characterSet = oldLayerData.textLabels[i].characterSet;
} else {
var allLabels = tl.field ? data.map(getText) : [];
characterSet = (0, _lodash["default"])(allLabels.join(''));
}
return {
characterSet: characterSet,
getText: getText
};
});
};
exports.formatTextLabelData = formatTextLabelData;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/layers/layer-text-label.js"],"names":["defaultPadding","getTextOffsetByRadius","radiusScale","getRadius","mapState","textLabel","distanceScale","xMult","anchor","yMult","alignment","sizeOffset","size","pixelRadius","pixelsPerMeter","padding","d","textLabelAccessor","dc","val","field","valueAccessor","String","formatTextLabelData","triggerChanged","oldLayerData","data","dataContainer","map","tl","i","getText","characterSet","textLabels","allLabels","join"],"mappings":"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","sourcesContent":["// Copyright (c) 2021 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 {getDistanceScales} from 'viewport-mercator-project';\nimport {notNullorUndefined} from 'utils/data-utils';\nimport uniq from 'lodash.uniq';\n\nexport const defaultPadding = 20;\n\nexport function getTextOffsetByRadius(radiusScale, getRadius, mapState) {\n  return textLabel => {\n    const distanceScale = getDistanceScales(mapState);\n    const xMult = textLabel.anchor === 'middle' ? 0 : textLabel.anchor === 'start' ? 1 : -1;\n    const yMult = textLabel.alignment === 'center' ? 0 : textLabel.alignment === 'bottom' ? 1 : -1;\n\n    const sizeOffset =\n      textLabel.alignment === 'center'\n        ? 0\n        : textLabel.alignment === 'bottom'\n        ? textLabel.size\n        : textLabel.size;\n\n    const pixelRadius = radiusScale * distanceScale.pixelsPerMeter[0];\n    const padding = defaultPadding;\n\n    return typeof getRadius === 'function'\n      ? d => [\n          xMult * (getRadius(d) * pixelRadius + padding),\n          yMult * (getRadius(d) * pixelRadius + padding + sizeOffset)\n        ]\n      : [\n          xMult * (getRadius * pixelRadius + padding),\n          yMult * (getRadius * pixelRadius + padding + sizeOffset)\n        ];\n  };\n}\n\nexport const textLabelAccessor = textLabel => dc => d => {\n  const val = textLabel.field.valueAccessor(d);\n  return notNullorUndefined(val) ? String(val) : '';\n};\n\nexport const formatTextLabelData = ({\n  textLabel,\n  triggerChanged,\n  oldLayerData,\n  data,\n  dataContainer\n}) => {\n  return textLabel.map((tl, i) => {\n    if (!tl.field) {\n      // if no field selected,\n      return {\n        getText: null,\n        characterSet: []\n      };\n    }\n\n    const getText = textLabelAccessor(tl)(dataContainer);\n    let characterSet;\n\n    if (\n      !triggerChanged[`getLabelCharacterSet-${i}`] &&\n      oldLayerData &&\n      oldLayerData.textLabels &&\n      oldLayerData.textLabels[i]\n    ) {\n      characterSet = oldLayerData.textLabels[i].characterSet;\n    } else {\n      const allLabels = tl.field ? data.map(getText) : [];\n      characterSet = uniq(allLabels.join(''));\n    }\n\n    return {\n      characterSet,\n      getText\n    };\n  });\n};\n"]}