kepler.gl
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
68 lines (67 loc) • 14.1 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.StyledFilterHeader = void 0;
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 _panelHeaderAction = _interopRequireDefault(require("../../side-panel/panel-header-action"));
var _icons = require("../../common/icons");
var _utils = require("@kepler.gl/utils");
var _styledComponents2 = require("../../common/styled-components");
var _templateObject, _templateObject2; // 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 StyledFilterHeader = exports.StyledFilterHeader = (0, _styledComponents["default"])(_styledComponents2.StyledPanelHeader)(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n cursor: pointer;\n padding: 10px 12px;\n\n .field-selector {\n width: 100%;\n flex: 2;\n }\n\n border-left: 3px solid;\n ", ";\n"])), function (props) {
return props.$labelRCGColorValues && props.$labelRCGColorValues.length > 0 ? "border-image: ".concat((0, _utils.createLinearGradient)('bottom', props.$labelRCGColorValues), " 3;") : 'border-color: transparent;';
});
var StyledChildrenContainer = _styledComponents["default"].div(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n flex: 1;\n overflow: hidden;\n"])));
FilterPanelHeaderFactory.deps = [_panelHeaderAction["default"]];
function FilterPanelHeaderFactory(PanelHeaderAction) {
var defaultActionIcons = {
"delete": _icons.Trash
};
var FilterPanelHeader = function FilterPanelHeader(_ref) {
var children = _ref.children,
_ref$className = _ref.className,
className = _ref$className === void 0 ? '' : _ref$className,
datasets = _ref.datasets,
filter = _ref.filter,
removeFilter = _ref.removeFilter,
actionItems = _ref.actionItems,
_ref$actionIcons = _ref.actionIcons,
actionIcons = _ref$actionIcons === void 0 ? defaultActionIcons : _ref$actionIcons;
var items = (0, _react.useMemo)(function () {
return actionItems !== null && actionItems !== void 0 ? actionItems : [{
key: 'delete',
tooltip: 'tooltip.delete',
onClick: removeFilter,
icon: actionIcons["delete"]
}];
}, [removeFilter, actionIcons, actionItems]);
return /*#__PURE__*/_react["default"].createElement(StyledFilterHeader, {
className: (0, _classnames["default"])('filter-panel__header', className),
$labelRCGColorValues: datasets.map(function (d) {
return d.color;
})
}, /*#__PURE__*/_react["default"].createElement(StyledChildrenContainer, null, children), items.map(function (item) {
return /*#__PURE__*/_react["default"].createElement(PanelHeaderAction, {
key: item.key,
id: filter.id,
tooltip: item.tooltip,
tooltipType: "error",
onClick: item.onClick,
hoverColor: 'errorColor',
IconComponent: item.icon
});
}));
};
return FilterPanelHeader;
}
var _default = exports["default"] = FilterPanelHeaderFactory;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_styledComponents","_interopRequireDefault","_classnames","_panelHeaderAction","_icons","_utils","_styledComponents2","_templateObject","_templateObject2","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","_typeof","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","StyledFilterHeader","exports","styled","StyledPanelHeader","_taggedTemplateLiteral2","props","$labelRCGColorValues","length","concat","createLinearGradient","StyledChildrenContainer","div","FilterPanelHeaderFactory","deps","PanelHeaderActionFactory","PanelHeaderAction","defaultActionIcons","Trash","FilterPanelHeader","_ref","children","_ref$className","className","datasets","filter","removeFilter","actionItems","_ref$actionIcons","actionIcons","items","useMemo","key","tooltip","onClick","icon","createElement","classnames","map","d","color","item","id","tooltipType","hoverColor","IconComponent","_default"],"sources":["../../../src/side-panel/filter-panel/filter-panel-header.tsx"],"sourcesContent":["// SPDX-License-Identifier: MIT\n// Copyright contributors to the kepler.gl project\n\nimport React, {ComponentType, useMemo} from 'react';\nimport styled from 'styled-components';\nimport classnames from 'classnames';\nimport PanelHeaderActionFactory from '../../side-panel/panel-header-action';\nimport {Trash} from '../../common/icons';\nimport {createLinearGradient} from '@kepler.gl/utils';\nimport {StyledPanelHeader, StyledPanelHeaderProps} from '../../common/styled-components';\nimport {RGBColor, Filter, Field} from '@kepler.gl/types';\nimport {KeplerTable} from '@kepler.gl/table';\n\ninterface StyledFilterHeaderProps extends StyledPanelHeaderProps {\n  $labelRCGColorValues: RGBColor[];\n}\n\nexport const StyledFilterHeader = styled(StyledPanelHeader)<StyledFilterHeaderProps>`\n  cursor: pointer;\n  padding: 10px 12px;\n\n  .field-selector {\n    width: 100%;\n    flex: 2;\n  }\n\n  border-left: 3px solid;\n  ${props =>\n    props.$labelRCGColorValues && props.$labelRCGColorValues.length > 0\n      ? `border-image: ${createLinearGradient('bottom', props.$labelRCGColorValues)} 3;`\n      : 'border-color: transparent;'};\n`;\n\nconst StyledChildrenContainer = styled.div`\n  display: flex;\n  flex: 1;\n  overflow: hidden;\n`;\n\nexport type FilterPanelHeaderProps = {\n  className?: string;\n  datasets: KeplerTable[];\n  filter: Filter;\n  removeFilter: () => void;\n  actionItems?: {\n    key: string;\n    tooltip: string;\n    onClick: () => void;\n    icon: React.ElementType;\n  }[];\n  actionIcons?: {\n    delete: ComponentType;\n  };\n  allAvailableFields?: Field[];\n  idx?: number;\n  children: React.ReactNode;\n};\n\nFilterPanelHeaderFactory.deps = [PanelHeaderActionFactory];\n\nfunction FilterPanelHeaderFactory(\n  PanelHeaderAction: ReturnType<typeof PanelHeaderActionFactory>\n): React.ComponentType<FilterPanelHeaderProps> {\n  const defaultActionIcons = {\n    delete: Trash\n  };\n  const FilterPanelHeader: React.FC<FilterPanelHeaderProps> = ({\n    children,\n    className = '',\n    datasets,\n    filter,\n    removeFilter,\n    actionItems,\n    actionIcons = defaultActionIcons\n  }: FilterPanelHeaderProps) => {\n    const items = useMemo(\n      () =>\n        actionItems ?? [\n          {\n            key: 'delete',\n            tooltip: 'tooltip.delete',\n            onClick: removeFilter,\n            icon: actionIcons.delete\n          }\n        ],\n      [removeFilter, actionIcons, actionItems]\n    );\n    return (\n      <StyledFilterHeader\n        className={classnames('filter-panel__header', className)}\n        $labelRCGColorValues={datasets.map((d: KeplerTable) => d.color)}\n      >\n        <StyledChildrenContainer>{children}</StyledChildrenContainer>\n        {items.map(item => (\n          <PanelHeaderAction\n            key={item.key}\n            id={filter.id}\n            tooltip={item.tooltip}\n            tooltipType=\"error\"\n            onClick={item.onClick}\n            hoverColor={'errorColor'}\n            IconComponent={item.icon}\n          />\n        ))}\n      </StyledFilterHeader>\n    );\n  };\n\n  return FilterPanelHeader;\n}\n\nexport default FilterPanelHeaderFactory;\n"],"mappings":"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","ignoreList":[]}
;