kepler.gl
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
153 lines (152 loc) • 27.7 kB
JavaScript
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
var _typeof = require("@babel/runtime/helpers/typeof");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports["default"] = exports.ChickletTag = exports.ChickletButton = void 0;
var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
var _react = _interopRequireWildcard(require("react"));
var _styledComponents = _interopRequireDefault(require("styled-components"));
var _core = require("@dnd-kit/core");
var _sortable = require("@dnd-kit/sortable");
var _modifiers = require("@dnd-kit/modifiers");
var _delete = _interopRequireDefault(require("../icons/delete"));
var _localization = require("@kepler.gl/localization");
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 ChickletButton = exports.ChickletButton = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n background: ", ";\n border-radius: 1px;\n color: ", ";\n font-size: 11px;\n line-height: 20px;\n margin: 4px 10px 4px 3px;\n padding: 2px 6px;\n display: flex;\n align-items: center;\n max-width: calc(100% - 8px);\n\n &:hover {\n color: ", ";\n }\n"])), function (props) {
return props.inputTheme === 'light' ? props.theme.chickletBgdLT : props.theme.chickletBgd;
}, function (props) {
return props.inputTheme === 'light' ? props.theme.textColorLT : props.theme.textColor;
}, function (props) {
return props.inputTheme === 'light' ? props.theme.textColorHlLT : props.theme.textColorHl;
});
var DND_MODIFIERS = [_modifiers.restrictToParentElement];
var ChickletTag = exports.ChickletTag = _styledComponents["default"].span(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n margin-right: 10px;\n text-overflow: ellipsis;\n width: 100%;\n overflow: hidden;\n\n &:hover {\n overflow: visible;\n }\n"])));
var Chicklet = function Chicklet(_ref) {
var disabled = _ref.disabled,
name = _ref.name,
remove = _ref.remove,
inputTheme = _ref.inputTheme;
return /*#__PURE__*/_react["default"].createElement(ChickletButton, {
inputTheme: inputTheme
}, /*#__PURE__*/_react["default"].createElement(ChickletTag, null, name), /*#__PURE__*/_react["default"].createElement(_delete["default"], {
onClick: disabled ? undefined : remove
}));
};
var ChickletedInputContainer = _styledComponents["default"].div(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n ", "\n\n color: ", ";\n overflow: hidden;\n"])), function (props) {
return props.inputTheme === 'secondary' ? props.theme.secondaryChickletedInput : props.inputTheme === 'light' ? props.theme.chickletedInputLT : props.theme.chickletedInput;
}, function (props) {
return props.hasPlaceholder ? props.theme.selectColorPlaceHolder : props.theme.selectColor;
});
var ChickletedItem = function ChickletedItem(_ref2) {
var item = _ref2.item,
removeItem = _ref2.removeItem,
displayOption = _ref2.displayOption,
CustomChickletComponent = _ref2.CustomChickletComponent,
inputTheme = _ref2.inputTheme,
disabled = _ref2.disabled,
itemId = _ref2.itemId;
var _useSortable = (0, _sortable.useSortable)({
id: itemId
}),
attributes = _useSortable.attributes,
listeners = _useSortable.listeners,
setNodeRef = _useSortable.setNodeRef,
transform = _useSortable.transform,
transition = _useSortable.transition,
isDragging = _useSortable.isDragging;
var chickletProps = (0, _react.useMemo)(function () {
return {
inputTheme: inputTheme,
disabled: disabled,
name: displayOption(item),
displayOption: displayOption,
item: item,
attributes: attributes,
listeners: listeners,
setNodeRef: setNodeRef,
transform: transform,
transition: transition,
isDragging: isDragging,
remove: function remove(e) {
return removeItem(item, e);
}
};
}, [item, removeItem, displayOption, inputTheme, disabled, attributes, listeners, setNodeRef, transform, transition, isDragging]);
return CustomChickletComponent ? /*#__PURE__*/_react["default"].createElement(CustomChickletComponent, chickletProps) : /*#__PURE__*/_react["default"].createElement(Chicklet, chickletProps);
};
var ChickletedInput = function ChickletedInput(_ref3) {
var disabled = _ref3.disabled,
onClick = _ref3.onClick,
className = _ref3.className,
_ref3$selectedItems = _ref3.selectedItems,
selectedItems = _ref3$selectedItems === void 0 ? [] : _ref3$selectedItems,
_ref3$placeholder = _ref3.placeholder,
placeholder = _ref3$placeholder === void 0 ? '' : _ref3$placeholder,
removeItem = _ref3.removeItem,
_ref3$reorderItems = _ref3.reorderItems,
reorderItems = _ref3$reorderItems === void 0 ? function (d) {
return d;
} : _ref3$reorderItems,
_ref3$displayOption = _ref3.displayOption,
displayOption = _ref3$displayOption === void 0 ? function (d) {
return String(d);
} : _ref3$displayOption,
inputTheme = _ref3.inputTheme,
CustomChickletComponent = _ref3.CustomChickletComponent;
var selectedItemIds = (0, _react.useMemo)(function () {
return selectedItems.map(function (item) {
return displayOption(item);
});
}, [displayOption, selectedItems]);
var handleDragEnd = (0, _react.useCallback)(function (_ref4) {
var active = _ref4.active,
over = _ref4.over;
if (!over) return;
if (active.id !== over.id) {
var oldIndex = selectedItemIds.findIndex(function (itemId) {
return itemId === active.id;
});
var newIndex = selectedItemIds.findIndex(function (itemId) {
return itemId === over.id;
});
reorderItems((0, _sortable.arrayMove)(selectedItems, oldIndex, newIndex));
}
}, [selectedItemIds, selectedItems, reorderItems]);
return /*#__PURE__*/_react["default"].createElement(ChickletedInputContainer, {
className: "".concat(className, " chickleted-input"),
onClick: onClick,
inputTheme: inputTheme,
hasPlaceholder: !selectedItems || !selectedItems.length
}, /*#__PURE__*/_react["default"].createElement(_core.DndContext, {
onDragEnd: handleDragEnd,
modifiers: DND_MODIFIERS,
collisionDetection: _core.pointerWithin,
autoScroll: false
}, /*#__PURE__*/_react["default"].createElement(_sortable.SortableContext, {
items: selectedItemIds
}, selectedItems.length > 0 ? selectedItems.map(function (item, index) {
return /*#__PURE__*/_react["default"].createElement(ChickletedItem, {
item: item,
itemId: displayOption(item),
removeItem: removeItem,
displayOption: displayOption,
CustomChickletComponent: CustomChickletComponent,
disabled: disabled,
inputTheme: inputTheme,
key: "".concat(displayOption(item), "_").concat(index)
});
}) : /*#__PURE__*/_react["default"].createElement("span", {
className: "".concat(className, " chickleted-input__placeholder")
}, /*#__PURE__*/_react["default"].createElement(_localization.FormattedMessage, {
id: placeholder || 'placeholder.enterValue'
}))), /*#__PURE__*/_react["default"].createElement(_core.DragOverlay, {
dropAnimation: null
})));
};
var _default = exports["default"] = ChickletedInput;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_styledComponents","_interopRequireDefault","_core","_sortable","_modifiers","_delete","_localization","_templateObject","_templateObject2","_templateObject3","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","_typeof","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","ChickletButton","exports","styled","div","_taggedTemplateLiteral2","props","inputTheme","theme","chickletBgdLT","chickletBgd","textColorLT","textColor","textColorHlLT","textColorHl","DND_MODIFIERS","restrictToParentElement","ChickletTag","span","Chicklet","_ref","disabled","name","remove","createElement","onClick","undefined","ChickletedInputContainer","secondaryChickletedInput","chickletedInputLT","chickletedInput","hasPlaceholder","selectColorPlaceHolder","selectColor","ChickletedItem","_ref2","item","removeItem","displayOption","CustomChickletComponent","itemId","_useSortable","useSortable","id","attributes","listeners","setNodeRef","transform","transition","isDragging","chickletProps","useMemo","ChickletedInput","_ref3","className","_ref3$selectedItems","selectedItems","_ref3$placeholder","placeholder","_ref3$reorderItems","reorderItems","d","_ref3$displayOption","String","selectedItemIds","map","handleDragEnd","useCallback","_ref4","active","over","oldIndex","findIndex","newIndex","arrayMove","concat","length","DndContext","onDragEnd","modifiers","collisionDetection","pointerWithin","autoScroll","SortableContext","items","index","key","FormattedMessage","DragOverlay","dropAnimation","_default"],"sources":["../../../src/common/item-selector/chickleted-input.tsx"],"sourcesContent":["// SPDX-License-Identifier: MIT\n// Copyright contributors to the kepler.gl project\n\nimport React, {MouseEventHandler, ReactNode, useMemo, useCallback} from 'react';\n\nimport styled, {IStyledComponent} from 'styled-components';\nimport {DndContext, DragOverlay, pointerWithin} from '@dnd-kit/core';\nimport {SortableContext, useSortable, arrayMove} from '@dnd-kit/sortable';\nimport {restrictToParentElement} from '@dnd-kit/modifiers';\n\nimport Delete from '../icons/delete';\nimport {FormattedMessage} from '@kepler.gl/localization';\nimport {BaseComponentProps} from '../../types';\n\nexport type ChickletButtonProps = BaseComponentProps & {\n  inputTheme?: string;\n  ref?: (node: HTMLElement | null) => void;\n};\n\nexport const ChickletButton: IStyledComponent<\n  'web',\n  ChickletButtonProps\n> = styled.div<ChickletButtonProps>`\n  background: ${props =>\n    props.inputTheme === 'light' ? props.theme.chickletBgdLT : props.theme.chickletBgd};\n  border-radius: 1px;\n  color: ${props =>\n    props.inputTheme === 'light' ? props.theme.textColorLT : props.theme.textColor};\n  font-size: 11px;\n  line-height: 20px;\n  margin: 4px 10px 4px 3px;\n  padding: 2px 6px;\n  display: flex;\n  align-items: center;\n  max-width: calc(100% - 8px);\n\n  &:hover {\n    color: ${props =>\n      props.inputTheme === 'light' ? props.theme.textColorHlLT : props.theme.textColorHl};\n  }\n`;\n\nconst DND_MODIFIERS = [restrictToParentElement];\nexport const ChickletTag: IStyledComponent<'web'> = styled.span`\n  margin-right: 10px;\n  text-overflow: ellipsis;\n  width: 100%;\n  overflow: hidden;\n\n  &:hover {\n    overflow: visible;\n  }\n`;\n\ninterface ChickletProps {\n  disabled?: boolean;\n  name: ReactNode;\n  remove?: MouseEventHandler<SVGSVGElement>;\n  inputTheme?: string;\n}\n\nconst Chicklet = ({disabled, name, remove, inputTheme}: ChickletProps) => (\n  <ChickletButton inputTheme={inputTheme}>\n    <ChickletTag>{name}</ChickletTag>\n    <Delete onClick={disabled ? undefined : remove} />\n  </ChickletButton>\n);\n\nexport type ChickletedInputContainerProps = BaseComponentProps & {\n  inputTheme?: string;\n  hasPlaceholder?: boolean;\n  focus?: HTMLInputElement['focus'];\n  disabled?: boolean;\n  onClick?: (e: React.MouseEvent) => void;\n};\n\nconst ChickletedInputContainer: IStyledComponent<\n  'web',\n  ChickletedInputContainerProps\n> = styled.div<ChickletedInputContainerProps>`\n  ${props =>\n    props.inputTheme === 'secondary'\n      ? props.theme.secondaryChickletedInput\n      : props.inputTheme === 'light'\n      ? props.theme.chickletedInputLT\n      : props.theme.chickletedInput}\n\n  color: ${props =>\n    props.hasPlaceholder ? props.theme.selectColorPlaceHolder : props.theme.selectColor};\n  overflow: hidden;\n`;\n\nconst ChickletedItem = ({\n  item,\n  removeItem,\n  displayOption,\n  CustomChickletComponent,\n  inputTheme,\n  disabled,\n  itemId\n}) => {\n  const {attributes, listeners, setNodeRef, transform, transition, isDragging} = useSortable({\n    id: itemId\n  });\n  const chickletProps = useMemo(\n    () => ({\n      inputTheme,\n      disabled,\n      name: displayOption(item),\n      displayOption,\n      item,\n      attributes,\n      listeners,\n      setNodeRef,\n      transform,\n      transition,\n      isDragging,\n      remove: e => removeItem(item, e)\n    }),\n    [\n      item,\n      removeItem,\n      displayOption,\n      inputTheme,\n      disabled,\n      attributes,\n      listeners,\n      setNodeRef,\n      transform,\n      transition,\n      isDragging\n    ]\n  );\n  return CustomChickletComponent ? (\n    <CustomChickletComponent {...chickletProps} />\n  ) : (\n    <Chicklet {...chickletProps} />\n  );\n};\n\ntype Item = string | number | boolean | object | undefined;\n\nexport type ChickletedInputProps = ChickletedInputContainerProps & {\n  selectedItems?: any[];\n  placeholder?: string;\n  CustomChickletComponent?: React.ComponentType<any> | null;\n  reorderItems?: (newOrder: any) => void;\n  displayOption?: (item: Item) => string;\n  removeItem: (item: Item, e: React.MouseEvent<SVGSVGElement, MouseEvent>) => void;\n};\n\nconst ChickletedInput: React.FC<ChickletedInputProps> = ({\n  disabled,\n  onClick,\n  className,\n  selectedItems = [],\n  placeholder = '',\n  removeItem,\n  reorderItems = d => d,\n  displayOption = d => String(d),\n  inputTheme,\n  CustomChickletComponent\n}) => {\n  const selectedItemIds = useMemo(\n    () => selectedItems.map(item => displayOption(item)),\n    [displayOption, selectedItems]\n  );\n  const handleDragEnd = useCallback(\n    ({active, over}) => {\n      if (!over) return;\n      if (active.id !== over.id) {\n        const oldIndex = selectedItemIds.findIndex(itemId => itemId === active.id);\n        const newIndex = selectedItemIds.findIndex(itemId => itemId === over.id);\n        reorderItems(arrayMove(selectedItems, oldIndex, newIndex));\n      }\n    },\n    [selectedItemIds, selectedItems, reorderItems]\n  );\n\n  return (\n    <ChickletedInputContainer\n      className={`${className} chickleted-input`}\n      onClick={onClick}\n      inputTheme={inputTheme}\n      hasPlaceholder={!selectedItems || !selectedItems.length}\n    >\n      <DndContext\n        onDragEnd={handleDragEnd}\n        modifiers={DND_MODIFIERS}\n        collisionDetection={pointerWithin}\n        autoScroll={false}\n      >\n        <SortableContext items={selectedItemIds}>\n          {selectedItems.length > 0 ? (\n            selectedItems.map((item, index) => (\n              <ChickletedItem\n                item={item}\n                itemId={displayOption(item)}\n                removeItem={removeItem}\n                displayOption={displayOption}\n                CustomChickletComponent={CustomChickletComponent}\n                disabled={disabled}\n                inputTheme={inputTheme}\n                key={`${displayOption(item)}_${index}`}\n              />\n            ))\n          ) : (\n            <span className={`${className} chickleted-input__placeholder`}>\n              <FormattedMessage id={placeholder || 'placeholder.enterValue'} />\n            </span>\n          )}\n        </SortableContext>\n        <DragOverlay dropAnimation={null} />\n      </DndContext>\n    </ChickletedInputContainer>\n  );\n};\n\nexport default ChickletedInput;\n"],"mappings":"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","ignoreList":[]}
;