kepler.gl
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
250 lines (191 loc) • 29.1 kB
JavaScript
;
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports["default"] = void 0;
var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));
var _assertThisInitialized2 = _interopRequireDefault(require("@babel/runtime/helpers/assertThisInitialized"));
var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits"));
var _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime/helpers/possibleConstructorReturn"));
var _getPrototypeOf2 = _interopRequireDefault(require("@babel/runtime/helpers/getPrototypeOf"));
var _typeof2 = _interopRequireDefault(require("@babel/runtime/helpers/typeof"));
var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
var _react = _interopRequireWildcard(require("react"));
var _styledComponents = _interopRequireDefault(require("styled-components"));
var _chickletedInput = require("../../../common/item-selector/chickleted-input");
var _icons = require("../../../common/icons");
var _dropdownList = _interopRequireDefault(require("../../../common/item-selector/dropdown-list"));
var _styledComponents2 = require("../../../common/styled-components");
var _localization = require("../../../../localization");
var _reactOnclickoutside = _interopRequireDefault(require("react-onclickoutside"));
var _defaultSettings = require("../../../../constants/default-settings");
var _tooltip = require("../../../../constants/tooltip");
var _dataUtils = require("../../../../utils/data-utils");
var _templateObject, _templateObject2, _templateObject3, _templateObject4;
function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = (0, _getPrototypeOf2["default"])(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = (0, _getPrototypeOf2["default"])(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return (0, _possibleConstructorReturn2["default"])(this, result); }; }
function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); return true; } catch (e) { return false; } }
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 TIME_DISPLAY = '2020-05-11 14:00';
var getValue = function getValue(fmt) {
return fmt[_tooltip.TOOLTIP_KEY];
};
var addDTimeLabel = function addDTimeLabel(formats) {
return formats.map(function (f) {
return _objectSpread(_objectSpread({}, f), {}, {
label: f.type === _tooltip.TOOLTIP_FORMAT_TYPES.DATE_TIME || f.type === _tooltip.TOOLTIP_FORMAT_TYPES.DATE ? (0, _dataUtils.getFormatter)(getValue(f))(TIME_DISPLAY) : f.label
});
});
};
function getFormatLabels(fields, fieldName) {
var fieldType = fields.find(function (f) {
return f.name === fieldName;
}).type;
var tooltipTypes = fieldType && _defaultSettings.FIELD_OPTS[fieldType].format.tooltip || [];
var formatLabels = Object.values(_tooltip.TOOLTIP_FORMATS).filter(function (t) {
return tooltipTypes.includes(t.type);
});
return addDTimeLabel(formatLabels);
}
var ChickletAddonWrapper = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n position: relative;\n"])));
var ChickletAddon = _styledComponents["default"].div(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n margin-right: 4px;\n"])));
var StyledPopover = _styledComponents["default"].div(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n margin-left: -64px;\n position: absolute;\n top: 20px;\n width: 140px;\n z-index: 101;\n"])));
var hashStyles = {
SHOW: 'SHOW',
ACTIVE: 'ACTIVE'
};
var IconDiv = _styledComponents["default"].div.attrs({
className: 'tooltip-chicklet__icon'
})(_templateObject4 || (_templateObject4 = (0, _taggedTemplateLiteral2["default"])(["\n color: ", ";\n"])), function (props) {
return props.status === hashStyles.SHOW ? props.theme.subtextColorActive : props.status === hashStyles.ACTIVE ? props.theme.activeColor : props.theme.textColor;
});
function getFormatTooltip(formatLabels, format) {
if (!format) {
return null;
}
var formatLabel = formatLabels.find(function (fl) {
return getValue(fl) === format;
});
if (formatLabel) {
return formatLabel.label;
}
return (0, _typeof2["default"])(format) === 'object' ? JSON.stringify(format, null, 2) : String(format);
}
function TooltipChickletFactory(dataId, config, onChange, fields) {
var TooltipChicklet = /*#__PURE__*/function (_Component) {
(0, _inherits2["default"])(TooltipChicklet, _Component);
var _super = _createSuper(TooltipChicklet);
function TooltipChicklet() {
var _this;
(0, _classCallCheck2["default"])(this, TooltipChicklet);
for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {
args[_key] = arguments[_key];
}
_this = _super.call.apply(_super, [this].concat(args));
(0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "state", {
show: false
});
(0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "handleClickOutside", function (e) {
if (_this.node.contains(e.target)) {
return;
}
_this.setState({
show: false
});
});
return _this;
}
(0, _createClass2["default"])(TooltipChicklet, [{
key: "componentDidMount",
value: function componentDidMount() {
document.addEventListener('mousedown', this.handleClickOutside, false);
}
}, {
key: "componentWillUnmount",
value: function componentWillUnmount() {
document.removeEventListener('mousedown', this.handleClickOutside, false);
}
}, {
key: "render",
value: function render() {
var _this2 = this;
var _this$props = this.props,
disabled = _this$props.disabled,
item = _this$props.item,
displayOption = _this$props.displayOption,
remove = _this$props.remove;
var show = this.state.show;
var tooltipField = config.fieldsToShow[dataId].find(function (fieldToShow) {
return fieldToShow.name === item.name;
});
if (!tooltipField) {
return null;
}
var formatLabels = getFormatLabels(fields, tooltipField.name);
var hasFormat = Boolean(tooltipField.format);
var selectionIndex = formatLabels.findIndex(function (fl) {
return getValue(fl) === tooltipField.format;
});
var hashStyle = show ? hashStyles.SHOW : hasFormat ? hashStyles.ACTIVE : null;
return /*#__PURE__*/_react["default"].createElement(_chickletedInput.ChickletButton, {
ref: function ref(node) {
return _this2.node = node;
}
}, /*#__PURE__*/_react["default"].createElement(_chickletedInput.ChickletTag, null, displayOption(item)), formatLabels.length > 1 && /*#__PURE__*/_react["default"].createElement(ChickletAddonWrapper, null, /*#__PURE__*/_react["default"].createElement(ChickletAddon, {
"data-tip": true,
"data-for": "addon-".concat(tooltipField.name)
}, /*#__PURE__*/_react["default"].createElement(IconDiv, {
status: hashStyle
}, /*#__PURE__*/_react["default"].createElement(_icons.Hash, {
height: "8px",
onClick: function onClick(e) {
e.stopPropagation();
_this2.setState({
show: Boolean(!show)
});
}
})), /*#__PURE__*/_react["default"].createElement(_styledComponents2.Tooltip, {
id: "addon-".concat(tooltipField.name),
effect: "solid"
}, /*#__PURE__*/_react["default"].createElement("span", null, hasFormat ? getFormatTooltip(formatLabels, tooltipField.format) : /*#__PURE__*/_react["default"].createElement(_localization.FormattedMessage, {
id: 'fieldSelector.formatting'
})))), show && /*#__PURE__*/_react["default"].createElement(StyledPopover, null, /*#__PURE__*/_react["default"].createElement(_dropdownList["default"], {
options: formatLabels,
selectionIndex: selectionIndex,
displayOption: function displayOption(_ref) {
var label = _ref.label;
return label;
},
onOptionSelected: function onOptionSelected(result, e) {
e.stopPropagation();
_this2.setState({
show: false
});
var oldFieldsToShow = config.fieldsToShow[dataId];
var fieldsToShow = oldFieldsToShow.map(function (fieldToShow) {
return fieldToShow.name === tooltipField.name ? {
name: tooltipField.name,
format: getValue(result)
} : fieldToShow;
});
var newConfig = _objectSpread(_objectSpread({}, config), {}, {
fieldsToShow: _objectSpread(_objectSpread({}, config.fieldsToShow), {}, (0, _defineProperty2["default"])({}, dataId, fieldsToShow))
});
onChange(newConfig);
}
}))), /*#__PURE__*/_react["default"].createElement(_icons.Delete, {
onClick: disabled ? null : remove
}));
}
}]);
return TooltipChicklet;
}(_react.Component);
return (0, _reactOnclickoutside["default"])(TooltipChicklet);
}
var _default = TooltipChickletFactory;
exports["default"] = _default;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../../src/components/side-panel/interaction-panel/tooltip-config/tooltip-chicklet.js"],"names":["TIME_DISPLAY","getValue","fmt","TOOLTIP_KEY","addDTimeLabel","formats","map","f","label","type","TOOLTIP_FORMAT_TYPES","DATE_TIME","DATE","getFormatLabels","fields","fieldName","fieldType","find","name","tooltipTypes","FIELD_OPTS","format","tooltip","formatLabels","Object","values","TOOLTIP_FORMATS","filter","t","includes","ChickletAddonWrapper","styled","div","ChickletAddon","StyledPopover","hashStyles","SHOW","ACTIVE","IconDiv","attrs","className","props","status","theme","subtextColorActive","activeColor","textColor","getFormatTooltip","formatLabel","fl","JSON","stringify","String","TooltipChickletFactory","dataId","config","onChange","TooltipChicklet","show","e","node","contains","target","setState","document","addEventListener","handleClickOutside","removeEventListener","disabled","item","displayOption","remove","state","tooltipField","fieldsToShow","fieldToShow","hasFormat","Boolean","selectionIndex","findIndex","hashStyle","length","stopPropagation","result","oldFieldsToShow","newConfig","Component"],"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 React, {Component} from 'react';\nimport styled from 'styled-components';\nimport {ChickletButton, ChickletTag} from 'components/common/item-selector/chickleted-input';\nimport {Hash, Delete} from 'components/common/icons';\nimport DropdownList from 'components/common/item-selector/dropdown-list';\nimport {Tooltip} from 'components/common/styled-components';\nimport {FormattedMessage} from 'localization';\nimport onClickOutside from 'react-onclickoutside';\nimport {FIELD_OPTS} from 'constants/default-settings';\nimport {TOOLTIP_FORMATS, TOOLTIP_FORMAT_TYPES, TOOLTIP_KEY} from 'constants/tooltip';\nimport {getFormatter} from 'utils/data-utils';\n\nconst TIME_DISPLAY = '2020-05-11 14:00';\nconst getValue = fmt => fmt[TOOLTIP_KEY];\n\nconst addDTimeLabel = formats =>\n  formats.map(f => ({\n    ...f,\n    label:\n      f.type === TOOLTIP_FORMAT_TYPES.DATE_TIME || f.type === TOOLTIP_FORMAT_TYPES.DATE\n        ? getFormatter(getValue(f))(TIME_DISPLAY)\n        : f.label\n  }));\n\nfunction getFormatLabels(fields, fieldName) {\n  const fieldType = fields.find(f => f.name === fieldName).type;\n  const tooltipTypes = (fieldType && FIELD_OPTS[fieldType].format.tooltip) || [];\n  const formatLabels = Object.values(TOOLTIP_FORMATS).filter(t => tooltipTypes.includes(t.type));\n\n  return addDTimeLabel(formatLabels);\n}\n\nconst ChickletAddonWrapper = styled.div`\n  position: relative;\n`;\n\nconst ChickletAddon = styled.div`\n  margin-right: 4px;\n`;\n\nconst StyledPopover = styled.div`\n  margin-left: -64px;\n  position: absolute;\n  top: 20px;\n  width: 140px;\n  z-index: 101;\n`;\n\nconst hashStyles = {\n  SHOW: 'SHOW',\n  ACTIVE: 'ACTIVE'\n};\n\nconst IconDiv = styled.div.attrs({\n  className: 'tooltip-chicklet__icon'\n})`\n  color: ${props =>\n    props.status === hashStyles.SHOW\n      ? props.theme.subtextColorActive\n      : props.status === hashStyles.ACTIVE\n      ? props.theme.activeColor\n      : props.theme.textColor};\n`;\n\nfunction getFormatTooltip(formatLabels, format) {\n  if (!format) {\n    return null;\n  }\n  const formatLabel = formatLabels.find(fl => getValue(fl) === format);\n  if (formatLabel) {\n    return formatLabel.label;\n  }\n  return typeof format === 'object' ? JSON.stringify(format, null, 2) : String(format);\n}\n\nfunction TooltipChickletFactory(dataId, config, onChange, fields) {\n  class TooltipChicklet extends Component {\n    state = {\n      show: false\n    };\n\n    componentDidMount() {\n      document.addEventListener('mousedown', this.handleClickOutside, false);\n    }\n\n    componentWillUnmount() {\n      document.removeEventListener('mousedown', this.handleClickOutside, false);\n    }\n\n    handleClickOutside = e => {\n      if (this.node.contains(e.target)) {\n        return;\n      }\n      this.setState({show: false});\n    };\n\n    render() {\n      const {disabled, item, displayOption, remove} = this.props;\n      const {show} = this.state;\n      const tooltipField = config.fieldsToShow[dataId].find(\n        fieldToShow => fieldToShow.name === item.name\n      );\n      if (!tooltipField) {\n        return null;\n      }\n      const formatLabels = getFormatLabels(fields, tooltipField.name);\n      const hasFormat = Boolean(tooltipField.format);\n      const selectionIndex = formatLabels.findIndex(fl => getValue(fl) === tooltipField.format);\n      const hashStyle = show ? hashStyles.SHOW : hasFormat ? hashStyles.ACTIVE : null;\n\n      return (\n        <ChickletButton ref={node => (this.node = node)}>\n          <ChickletTag>{displayOption(item)}</ChickletTag>\n          {formatLabels.length > 1 && (\n            <ChickletAddonWrapper>\n              <ChickletAddon data-tip data-for={`addon-${tooltipField.name}`}>\n                <IconDiv status={hashStyle}>\n                  <Hash\n                    height=\"8px\"\n                    onClick={e => {\n                      e.stopPropagation();\n                      this.setState({show: Boolean(!show)});\n                    }}\n                  />\n                </IconDiv>\n                <Tooltip id={`addon-${tooltipField.name}`} effect=\"solid\">\n                  <span>\n                    {hasFormat ? (\n                      getFormatTooltip(formatLabels, tooltipField.format)\n                    ) : (\n                      <FormattedMessage id={'fieldSelector.formatting'} />\n                    )}\n                  </span>\n                </Tooltip>\n              </ChickletAddon>\n              {show && (\n                <StyledPopover>\n                  <DropdownList\n                    options={formatLabels}\n                    selectionIndex={selectionIndex}\n                    displayOption={({label}) => label}\n                    onOptionSelected={(result, e) => {\n                      e.stopPropagation();\n                      this.setState({\n                        show: false\n                      });\n\n                      const oldFieldsToShow = config.fieldsToShow[dataId];\n                      const fieldsToShow = oldFieldsToShow.map(fieldToShow => {\n                        return fieldToShow.name === tooltipField.name\n                          ? {\n                              name: tooltipField.name,\n                              format: getValue(result)\n                            }\n                          : fieldToShow;\n                      });\n                      const newConfig = {\n                        ...config,\n                        fieldsToShow: {\n                          ...config.fieldsToShow,\n                          [dataId]: fieldsToShow\n                        }\n                      };\n                      onChange(newConfig);\n                    }}\n                  />\n                </StyledPopover>\n              )}\n            </ChickletAddonWrapper>\n          )}\n          <Delete onClick={disabled ? null : remove} />\n        </ChickletButton>\n      );\n    }\n  }\n  return onClickOutside(TooltipChicklet);\n}\n\nexport default TooltipChickletFactory;\n"]}