UNPKG

kepler.gl

Version:

kepler.gl is a webgl based application to visualize large scale location data in the browser

165 lines (163 loc) 34.3 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); var _typeof3 = require("@babel/runtime/helpers/typeof"); Object.defineProperty(exports, "__esModule", { value: true }); exports["default"] = void 0; var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends")); var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray")); var _typeof2 = _interopRequireDefault(require("@babel/runtime/helpers/typeof")); var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral")); var _react = _interopRequireWildcard(require("react")); var _styledComponents = _interopRequireDefault(require("styled-components")); var _classnames = _interopRequireDefault(require("classnames")); var _utilities = require("@dnd-kit/utilities"); var _chickletedInput = require("../../../common/item-selector/chickleted-input"); var _icons = require("../../../common/icons"); var _dropdownList = _interopRequireDefault(require("../../../common/item-selector/dropdown-list")); var _localization = require("@kepler.gl/localization"); var _utils = require("@kepler.gl/utils"); var _tippyTooltip = _interopRequireDefault(require("../../../common/tippy-tooltip")); var _useOnClickOutside = _interopRequireDefault(require("../../../hooks/use-on-click-outside")); var _templateObject, _templateObject2, _templateObject3, _templateObject4, _templateObject5, _templateObject6, _templateObject7; // 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" != _typeof3(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; } function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; } function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { (0, _defineProperty2["default"])(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; } 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; }); var SortableStyledItem = _styledComponents["default"].div(_templateObject5 || (_templateObject5 = (0, _taggedTemplateLiteral2["default"])(["\n transition: ", ";\n transform: ", ";\n &.sorting {\n opacity: 0.3;\n pointer-events: none;\n }\n &:hover {\n .tooltip-chicklet__drag-handler {\n opacity: 1;\n }\n }\n"])), function (props) { return props.$transition; }, function (props) { return props.$transform; }); var StyledDragHandle = _styledComponents["default"].div.attrs({ className: 'tooltip-chicklet__drag-handler' })(_templateObject6 || (_templateObject6 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n align-items: center;\n z-index: 1000;\n opacity: 0;\n margin-left: -5px;\n &:hover {\n cursor: move;\n color: ", ";\n }\n"])), function (props) { return props.theme.tooltipVerticalLineColor; }); var StyledTag = _styledComponents["default"].span(_templateObject7 || (_templateObject7 = (0, _taggedTemplateLiteral2["default"])(["\n margin-right: 5px;\n text-overflow: ellipsis;\n width: 100%;\n overflow: hidden;\n max-width: 160px;\n"]))); function getFormatTooltip(formatLabels, format) { if (!format) { return null; } var formatLabel = formatLabels.find(function (fl) { return (0, _utils.getFormatValue)(fl) === format; }); if (formatLabel) { return formatLabel.label; } return (0, _typeof2["default"])(format) === 'object' ? JSON.stringify(format, null, 2) : String(format); } // TODO: a factory should take other factories as input function TooltipChickletFactory(dataId, config, onChange, fields, onDisplayFormatChange) { var TooltipChicklet = function TooltipChicklet(props) { var disabled = props.disabled, item = props.item, displayOption = props.displayOption, remove = props.remove, attributes = props.attributes, listeners = props.listeners, setNodeRef = props.setNodeRef, transform = props.transform, transition = props.transition, isDragging = props.isDragging; var _useState = (0, _react.useState)(false), _useState2 = (0, _slicedToArray2["default"])(_useState, 2), show = _useState2[0], setShow = _useState2[1]; var ref = (0, _useOnClickOutside["default"])(function () { return setShow(false); }); // const {show} = this.state; var tooltipField = config.fieldsToShow[dataId].find(function (fieldToShow) { return fieldToShow.name === item.name; }); if (!tooltipField) { return null; } var field = fields.find(function (f) { return f.name === tooltipField.name; }); if (!field) { return null; } var formatLabels = (0, _utils.getFormatLabels)(fields, tooltipField.name); var hasFormat = Boolean(field.displayFormat); var selectionIndex = formatLabels.findIndex(function (fl) { return (0, _utils.getFormatValue)(fl) === field.displayFormat; }); var hashStyle = show ? hashStyles.SHOW : hasFormat ? hashStyles.ACTIVE : null; return /*#__PURE__*/_react["default"].createElement(SortableStyledItem, (0, _extends2["default"])({ ref: setNodeRef, className: (0, _classnames["default"])('sortable-layer-items', { sorting: isDragging }), $transform: _utilities.CSS.Translate.toString(transform), $transition: transition || '' }, attributes), /*#__PURE__*/_react["default"].createElement(_chickletedInput.ChickletButton, null, /*#__PURE__*/_react["default"].createElement(StyledDragHandle, listeners, /*#__PURE__*/_react["default"].createElement(_icons.VertDots, { height: "12px" })), /*#__PURE__*/_react["default"].createElement(StyledTag, { title: displayOption(item) }, displayOption(item)), formatLabels.length > 1 && /*#__PURE__*/_react["default"].createElement(ChickletAddonWrapper, null, /*#__PURE__*/_react["default"].createElement(_tippyTooltip["default"], { placement: "top", render: function render() { return /*#__PURE__*/_react["default"].createElement("span", null, hasFormat ? getFormatTooltip(formatLabels, field.displayName) : /*#__PURE__*/_react["default"].createElement(_localization.FormattedMessage, { id: 'fieldSelector.formatting' })); } }, /*#__PURE__*/_react["default"].createElement(ChickletAddon, null, /*#__PURE__*/_react["default"].createElement(IconDiv, { $status: hashStyle }, /*#__PURE__*/_react["default"].createElement(_icons.Hash, { height: "8px", onClick: function onClick(e) { e.stopPropagation(); setShow(Boolean(!show)); } })))), show && /*#__PURE__*/_react["default"].createElement(StyledPopover, { ref: ref }, /*#__PURE__*/_react["default"].createElement(_dropdownList["default"], { options: formatLabels, selectionIndex: selectionIndex, displayOption: function displayOption(option) { return option.label; }, onOptionSelected: function onOptionSelected(result, e) { e.stopPropagation(); setShow(false); var displayFormat = (0, _utils.getFormatValue)(result); var oldFieldsToShow = config.fieldsToShow[dataId]; var fieldsToShow = oldFieldsToShow.map(function (fieldToShow) { return fieldToShow.name === tooltipField.name ? { name: tooltipField.name, format: displayFormat } : fieldToShow; }); var newConfig = _objectSpread(_objectSpread({}, config), {}, { fieldsToShow: _objectSpread(_objectSpread({}, config.fieldsToShow), {}, (0, _defineProperty2["default"])({}, dataId, fieldsToShow)) }); onChange(newConfig); onDisplayFormatChange(dataId, field.name, displayFormat); } }))), /*#__PURE__*/_react["default"].createElement(_icons.Delete, { height: "16px", onClick: disabled ? null : remove }))); }; return TooltipChicklet; } var _default = exports["default"] = TooltipChickletFactory; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_styledComponents","_interopRequireDefault","_classnames","_utilities","_chickletedInput","_icons","_dropdownList","_localization","_utils","_tippyTooltip","_useOnClickOutside","_templateObject","_templateObject2","_templateObject3","_templateObject4","_templateObject5","_templateObject6","_templateObject7","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","_typeof3","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","ownKeys","keys","getOwnPropertySymbols","o","filter","enumerable","push","apply","_objectSpread","arguments","length","forEach","_defineProperty2","getOwnPropertyDescriptors","defineProperties","ChickletAddonWrapper","styled","div","_taggedTemplateLiteral2","ChickletAddon","StyledPopover","hashStyles","SHOW","ACTIVE","IconDiv","attrs","className","props","$status","theme","subtextColorActive","activeColor","textColor","SortableStyledItem","$transition","$transform","StyledDragHandle","tooltipVerticalLineColor","StyledTag","span","getFormatTooltip","formatLabels","format","formatLabel","find","fl","getFormatValue","label","_typeof2","JSON","stringify","String","TooltipChickletFactory","dataId","config","onChange","fields","onDisplayFormatChange","TooltipChicklet","disabled","item","displayOption","remove","attributes","listeners","setNodeRef","transform","transition","isDragging","_useState","useState","_useState2","_slicedToArray2","show","setShow","ref","useOnClickOutside","tooltipField","fieldsToShow","fieldToShow","name","field","f","getFormatLabels","hasFormat","Boolean","displayFormat","selectionIndex","findIndex","hashStyle","createElement","_extends2","classnames","sorting","CSS","Translate","toString","ChickletButton","VertDots","height","title","placement","render","displayName","FormattedMessage","id","Hash","onClick","stopPropagation","options","option","onOptionSelected","result","oldFieldsToShow","map","newConfig","Delete","_default","exports"],"sources":["../../../../src/side-panel/interaction-panel/tooltip-config/tooltip-chicklet.tsx"],"sourcesContent":["// SPDX-License-Identifier: MIT\n// Copyright contributors to the kepler.gl project\n\nimport React, {useState, CSSProperties} from 'react';\nimport styled, {IStyledComponent} from 'styled-components';\nimport classnames from 'classnames';\nimport {DraggableAttributes} from '@dnd-kit/core';\nimport {CSS, Transform} from '@dnd-kit/utilities';\nimport {ChickletButton} from '../../../common/item-selector/chickleted-input';\nimport {Hash, Delete, VertDots} from '../../../common/icons';\nimport DropdownList from '../../../common/item-selector/dropdown-list';\nimport {FormattedMessage} from '@kepler.gl/localization';\nimport {TimeLabelFormat, TooltipFields} from '@kepler.gl/types';\nimport {getFormatValue, getFormatLabels} from '@kepler.gl/utils';\nimport TippyTooltip from '../../../common/tippy-tooltip';\nimport {TooltipFormat} from '@kepler.gl/constants';\nimport useOnClickOutside from '../../../hooks/use-on-click-outside';\nimport {BaseComponentProps} from '../../../types';\n\ninterface TooltipChickletProps {\n  disabled: boolean;\n  item: {name: string};\n  displayOption: (item: any) => string;\n  remove: any;\n\n  attributes: DraggableAttributes;\n  listeners: any;\n  setNodeRef: (node: HTMLElement | null) => void;\n  transform: Transform | null;\n  transition?: string;\n  isDragging: boolean;\n}\n\ntype TooltipConfig = {\n  fieldsToShow: {\n    [key: string]: {name: string; format: string | null}[];\n  };\n  compareMode: boolean;\n  compareType: string | null;\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' as const,\n  ACTIVE: 'ACTIVE' as const\n};\n\nexport type IconDivProps = BaseComponentProps & {\n  $status?: 'SHOW' | 'ACTIVE' | null;\n};\n\nconst IconDiv: IStyledComponent<'web', IconDivProps> = styled.div.attrs({\n  className: 'tooltip-chicklet__icon'\n})<IconDivProps>`\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\nexport type SortableStyledItemProps = BaseComponentProps & {\n  $transition?: CSSProperties['transition'];\n  $transform?: CSSProperties['transform'];\n  ref: (node: HTMLElement | null) => void;\n};\nconst SortableStyledItem: IStyledComponent<\n  'web',\n  SortableStyledItemProps\n> = styled.div<SortableStyledItemProps>`\n  transition: ${props => props.$transition};\n  transform: ${props => props.$transform};\n  &.sorting {\n    opacity: 0.3;\n    pointer-events: none;\n  }\n  &:hover {\n    .tooltip-chicklet__drag-handler {\n      opacity: 1;\n    }\n  }\n`;\n\nconst StyledDragHandle = styled.div.attrs({\n  className: 'tooltip-chicklet__drag-handler'\n})`\n  display: flex;\n  align-items: center;\n  z-index: 1000;\n  opacity: 0;\n  margin-left: -5px;\n  &:hover {\n    cursor: move;\n    color: ${props => props.theme.tooltipVerticalLineColor};\n  }\n`;\n\nconst StyledTag = styled.span`\n  margin-right: 5px;\n  text-overflow: ellipsis;\n  width: 100%;\n  overflow: hidden;\n  max-width: 160px;\n`;\n\nfunction getFormatTooltip(formatLabels: TimeLabelFormat[], format: string | null) {\n  if (!format) {\n    return null;\n  }\n  const formatLabel = formatLabels.find(fl => getFormatValue(fl) === format);\n  if (formatLabel) {\n    return formatLabel.label;\n  }\n  return typeof format === 'object' ? JSON.stringify(format, null, 2) : String(format);\n}\n\n// TODO: a factory should take other factories as input\nfunction TooltipChickletFactory(\n  dataId: string,\n  config: TooltipConfig,\n  onChange: (cfg: TooltipConfig) => void,\n  fields: TooltipFields[],\n  onDisplayFormatChange\n): React.FC<TooltipChickletProps> {\n  const TooltipChicklet: React.FC<TooltipChickletProps> = (props: TooltipChickletProps) => {\n    const {\n      disabled,\n      item,\n      displayOption,\n      remove,\n      attributes,\n      listeners,\n      setNodeRef,\n      transform,\n      transition,\n      isDragging\n    } = props;\n\n    const [show, setShow] = useState(false);\n    const ref = useOnClickOutside<HTMLDivElement>(() => setShow(false));\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 field = fields.find(f => f.name === tooltipField.name);\n    if (!field) {\n      return null;\n    }\n    const formatLabels = getFormatLabels(fields, tooltipField.name);\n    const hasFormat = Boolean(field.displayFormat);\n    const selectionIndex = formatLabels.findIndex(fl => getFormatValue(fl) === field.displayFormat);\n    const hashStyle = show ? hashStyles.SHOW : hasFormat ? hashStyles.ACTIVE : null;\n\n    return (\n      <SortableStyledItem\n        ref={setNodeRef}\n        className={classnames('sortable-layer-items', {sorting: isDragging})}\n        $transform={CSS.Translate.toString(transform)}\n        $transition={transition || ''}\n        {...attributes}\n      >\n        <ChickletButton>\n          <StyledDragHandle {...listeners}>\n            <VertDots height=\"12px\" />\n          </StyledDragHandle>\n          <StyledTag title={displayOption(item)}>{displayOption(item)}</StyledTag>\n          {formatLabels.length > 1 && (\n            <ChickletAddonWrapper>\n              <TippyTooltip\n                placement=\"top\"\n                render={() => (\n                  <span>\n                    {hasFormat ? (\n                      getFormatTooltip(formatLabels, field.displayName)\n                    ) : (\n                      <FormattedMessage id={'fieldSelector.formatting'} />\n                    )}\n                  </span>\n                )}\n              >\n                <ChickletAddon>\n                  <IconDiv $status={hashStyle}>\n                    <Hash\n                      height=\"8px\"\n                      onClick={e => {\n                        e.stopPropagation();\n                        setShow(Boolean(!show));\n                      }}\n                    />\n                  </IconDiv>\n                </ChickletAddon>\n              </TippyTooltip>\n              {show && (\n                <StyledPopover ref={ref}>\n                  <DropdownList\n                    options={formatLabels}\n                    selectionIndex={selectionIndex}\n                    displayOption={option => (option as TooltipFormat).label}\n                    onOptionSelected={(result, e) => {\n                      e.stopPropagation();\n                      setShow(false);\n\n                      const displayFormat = getFormatValue(result);\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: displayFormat\n                            }\n                          : fieldToShow;\n                      });\n                      const newConfig = {\n                        ...config,\n                        fieldsToShow: {\n                          ...config.fieldsToShow,\n                          [dataId]: fieldsToShow\n                        }\n                      };\n                      onChange(newConfig);\n                      onDisplayFormatChange(dataId, field.name, displayFormat);\n                    }}\n                  />\n                </StyledPopover>\n              )}\n            </ChickletAddonWrapper>\n          )}\n          <Delete height=\"16px\" onClick={disabled ? null : remove} />\n        </ChickletButton>\n      </SortableStyledItem>\n    );\n  };\n\n  return TooltipChicklet;\n}\n\nexport default TooltipChickletFactory;\n"],"mappings":"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","ignoreList":[]}