kepler.gl
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
132 lines (131 loc) • 21.5 kB
JavaScript
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
var _typeof = require("@babel/runtime/helpers/typeof");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports["default"] = void 0;
var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
var _react = _interopRequireWildcard(require("react"));
var _styledComponents = _interopRequireDefault(require("styled-components"));
var _d3Scale = require("d3-scale");
var _constants = require("@kepler.gl/constants");
var _utils = require("@kepler.gl/utils");
var _d3Array = require("d3-array");
var _window = require("global/window");
var _templateObject, _templateObject2, _templateObject3; // SPDX-License-Identifier: MIT
// Copyright contributors to the kepler.gl project
function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(e) { return e ? t : r; })(e); }
function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != _typeof(e) && "function" != typeof e) return { "default": e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && {}.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n["default"] = e, t && t.set(e, n), n; }
var StyledLegend = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n width: ", "px;\n height: ", "px;\n position: relative;\n svg {\n circle {\n stroke: ", ";\n fill: none;\n }\n line {\n stroke: ", ";\n stroke-dasharray: 2, 1;\n }\n }\n"])), function (props) {
return props.width;
}, function (props) {
return props.height;
}, function (props) {
return props.theme.borderColorLT;
}, function (props) {
return props.theme.borderColor;
});
var LabelsOuter = _styledComponents["default"].div(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n text-align: right;\n position: absolute;\n left: 0;\n top: 0;\n width: ", "px;\n height: ", "px;\n"])), function (props) {
return props.width;
}, function (props) {
return props.height;
});
var tickHeight = 9;
var ValueLabel = _styledComponents["default"].div(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n position: absolute;\n font-size: ", "px;\n height: ", "px;\n line-height: ", "px;\n margin-top: -", "px;\n color: ", ";\n background-color: ", ";\n padding: 0 2px;\n border-radius: 2px;\n"])), tickHeight, tickHeight, tickHeight, tickHeight / 2, function (props) {
return props.theme.textColor;
}, function (props) {
return props.theme.mapPanelBackgroundColor;
});
var margin = {
left: 1,
top: 5,
right: 2,
bottom: 5
};
var RadiusLegend = function RadiusLegend(_ref) {
var scaleType = _ref.scaleType,
width = _ref.width,
domain = _ref.domain,
range = _ref.range,
fieldType = _ref.fieldType;
var radiusScale = (0, _react.useMemo)(function () {
if (scaleType !== _constants.SCALE_TYPES.sqrt) {
_window.console.warn("Unsupported radius scale type: ".concat(scaleType));
return undefined;
}
if (!Array.isArray(domain) || !domain.every(Number.isFinite)) {
return undefined;
}
return (0, _d3Scale.scaleSqrt)().domain(domain).range(range);
}, [domain, range, scaleType]);
var radiusTicks = (0, _react.useMemo)(function () {
if (radiusScale === undefined) return [];
var numTicksToFit = Math.min(10, (range[1] - range[0]) * 2 / tickHeight);
var ticks = radiusScale.ticks(numTicksToFit);
// Add min and max values
if (ticks[0] > domain[0]) {
ticks.unshift(domain[0]);
}
if (ticks[ticks.length - 1] < domain[1]) {
ticks.push(domain[1]);
}
// Make sure there is no overlap
return ticks.reduceRight(function (acc, v) {
if (acc.length === 0 || Math.abs(radiusScale(acc[0]) - radiusScale(v)) * 2 > tickHeight) {
// @ts-ignore
acc.unshift(v);
}
return acc;
}, new Array());
}, [radiusScale, domain, range]);
if (!radiusScale || !radiusTicks.length) {
return null;
}
var maxR = Math.ceil(radiusScale((0, _d3Array.max)(radiusTicks) || 0));
var w = width - margin.left - margin.right;
var h = maxR * 2;
var height = h + margin.top + margin.bottom;
return /*#__PURE__*/_react["default"].createElement(StyledLegend, {
width: width,
height: height
}, /*#__PURE__*/_react["default"].createElement("svg", {
width: width,
height: height
}, /*#__PURE__*/_react["default"].createElement("g", {
transform: "translate(".concat(margin.left, ",").concat(margin.top, ")")
}, /*#__PURE__*/_react["default"].createElement("g", null, radiusTicks.map(function (v, i) {
return /*#__PURE__*/_react["default"].createElement("g", {
key: i
}, /*#__PURE__*/_react["default"].createElement("g", {
transform: "translate(".concat(w, ",").concat(h - radiusScale(v) * 2, ")")
}, /*#__PURE__*/_react["default"].createElement("line", {
x1: 0,
x2: maxR - w
})));
})), /*#__PURE__*/_react["default"].createElement("g", null, radiusTicks.map(function (v, i) {
var r = radiusScale(v);
return /*#__PURE__*/_react["default"].createElement("g", {
key: i
}, /*#__PURE__*/_react["default"].createElement("g", {
transform: "translate(0,".concat(h - r * 2, ")")
}, /*#__PURE__*/_react["default"].createElement("circle", {
cx: maxR,
cy: r,
r: Math.max(0, r - 1) /* stroke is drawn outside, hence r-1 */
})));
})))), /*#__PURE__*/_react["default"].createElement(LabelsOuter, {
width: width,
height: height
}, radiusTicks.map(function (v, i) {
return /*#__PURE__*/_react["default"].createElement(ValueLabel, {
key: i,
style: {
right: margin.right,
top: margin.top + h - radiusScale(v) * 2
}
}, (0, _utils.formatNumber)(v, fieldType));
})));
};
var _default = exports["default"] = RadiusLegend;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_styledComponents","_interopRequireDefault","_d3Scale","_constants","_utils","_d3Array","_window","_templateObject","_templateObject2","_templateObject3","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","_typeof","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","StyledLegend","styled","div","_taggedTemplateLiteral2","props","width","height","theme","borderColorLT","borderColor","LabelsOuter","tickHeight","ValueLabel","textColor","mapPanelBackgroundColor","margin","left","top","right","bottom","RadiusLegend","_ref","scaleType","domain","range","fieldType","radiusScale","useMemo","SCALE_TYPES","sqrt","Console","warn","concat","undefined","Array","isArray","every","Number","isFinite","scaleSqrt","radiusTicks","numTicksToFit","Math","min","ticks","unshift","length","push","reduceRight","acc","v","abs","maxR","ceil","max","w","h","createElement","transform","map","key","x1","x2","cx","cy","style","formatNumber","_default","exports"],"sources":["../../src/common/radius-legend.tsx"],"sourcesContent":["// SPDX-License-Identifier: MIT\n// Copyright contributors to the kepler.gl project\n\nimport React, {useMemo, FC} from 'react';\nimport styled from 'styled-components';\nimport {scaleSqrt} from 'd3-scale';\nimport {SCALE_TYPES} from '@kepler.gl/constants';\nimport {formatNumber} from '@kepler.gl/utils';\nimport {max} from 'd3-array';\nimport {console as Console} from 'global/window';\n\nconst StyledLegend = styled.div<{width: number; height: number}>`\n  width: ${props => props.width}px;\n  height: ${props => props.height}px;\n  position: relative;\n  svg {\n    circle {\n      stroke: ${props => props.theme.borderColorLT};\n      fill: none;\n    }\n    line {\n      stroke: ${props => props.theme.borderColor};\n      stroke-dasharray: 2, 1;\n    }\n  }\n`;\n\nconst LabelsOuter = styled.div<{width: number; height: number}>`\n  text-align: right;\n  position: absolute;\n  left: 0;\n  top: 0;\n  width: ${props => props.width}px;\n  height: ${props => props.height}px;\n`;\n\nconst tickHeight = 9;\n\nconst ValueLabel = styled.div`\n  position: absolute;\n  font-size: ${tickHeight}px;\n  height: ${tickHeight}px;\n  line-height: ${tickHeight}px;\n  margin-top: -${tickHeight / 2}px;\n  color: ${props => props.theme.textColor};\n  background-color: ${props => props.theme.mapPanelBackgroundColor};\n  padding: 0 2px;\n  border-radius: 2px;\n`;\n\nconst margin = {left: 1, top: 5, right: 2, bottom: 5};\n\ntype Props = {\n  width: number;\n  scaleType: string;\n  domain: [number, number];\n  fieldType: string;\n  range: [number, number];\n};\n\nconst RadiusLegend: FC<Props> = ({scaleType, width, domain, range, fieldType}) => {\n  const radiusScale = useMemo(() => {\n    if (scaleType !== SCALE_TYPES.sqrt) {\n      Console.warn(`Unsupported radius scale type: ${scaleType}`);\n      return undefined;\n    }\n    if (!Array.isArray(domain) || !domain.every(Number.isFinite)) {\n      return undefined;\n    }\n    return scaleSqrt().domain(domain).range(range);\n  }, [domain, range, scaleType]);\n\n  const radiusTicks = useMemo(() => {\n    if (radiusScale === undefined) return [];\n    const numTicksToFit = Math.min(10, ((range[1] - range[0]) * 2) / tickHeight);\n    const ticks = radiusScale.ticks(numTicksToFit);\n    // Add min and max values\n    if (ticks[0] > domain[0]) {\n      ticks.unshift(domain[0]);\n    }\n    if (ticks[ticks.length - 1] < domain[1]) {\n      ticks.push(domain[1]);\n    }\n    // Make sure there is no overlap\n    return ticks.reduceRight((acc, v) => {\n      if (acc.length === 0 || Math.abs(radiusScale(acc[0]) - radiusScale(v)) * 2 > tickHeight) {\n        // @ts-ignore\n        acc.unshift(v);\n      }\n      return acc;\n    }, new Array<number>());\n  }, [radiusScale, domain, range]);\n\n  if (!radiusScale || !radiusTicks.length) {\n    return null;\n  }\n  const maxR = Math.ceil(radiusScale(max(radiusTicks) || 0));\n  const w = width - margin.left - margin.right;\n  const h = maxR * 2;\n  const height = h + margin.top + margin.bottom;\n\n  return (\n    <StyledLegend width={width} height={height}>\n      <svg width={width} height={height}>\n        <g transform={`translate(${margin.left},${margin.top})`}>\n          <g>\n            {radiusTicks.map((v, i) => (\n              <g key={i}>\n                <g transform={`translate(${w},${h - radiusScale(v) * 2})`}>\n                  <line x1={0} x2={maxR - w} />\n                </g>\n              </g>\n            ))}\n          </g>\n          <g>\n            {radiusTicks.map((v, i) => {\n              const r = radiusScale(v);\n              return (\n                <g key={i}>\n                  <g transform={`translate(0,${h - r * 2})`}>\n                    <circle\n                      cx={maxR}\n                      cy={r}\n                      r={Math.max(0, r - 1)} /* stroke is drawn outside, hence r-1 */\n                    />\n                  </g>\n                </g>\n              );\n            })}\n          </g>\n        </g>\n      </svg>\n      <LabelsOuter width={width} height={height}>\n        {radiusTicks.map((v, i) => (\n          <ValueLabel\n            key={i}\n            style={{\n              right: margin.right,\n              top: margin.top + h - radiusScale(v) * 2\n            }}\n          >\n            {formatNumber(v, fieldType)}\n          </ValueLabel>\n        ))}\n      </LabelsOuter>\n    </StyledLegend>\n  );\n};\n\nexport default RadiusLegend;\n"],"mappings":"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","ignoreList":[]}
;