UNPKG

kepler.gl

Version:

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

91 lines (89 loc) 15.4 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); var _typeof = require("@babel/runtime/helpers/typeof"); Object.defineProperty(exports, "__esModule", { value: true }); exports.DatasetNode = exports.ColumnNode = void 0; exports.Tree = Tree; var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray")); var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral")); var _reactCollapsible = require("@radix-ui/react-collapsible"); var _styledComponents = _interopRequireDefault(require("styled-components")); var _react = _interopRequireWildcard(require("react")); var _classnames = _interopRequireDefault(require("classnames")); var _components = require("@kepler.gl/components"); 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; } // TODO: consider using react-vtree/react-window for virtualization /** * Component that renders a generic tree. * @param treeData - The tree data. * @param renderNode - A function that renders a tree node. */ function Tree(props) { var treeData = props.treeData, renderNode = props.renderNode; return /*#__PURE__*/_react["default"].createElement("div", { className: "flex flex-col" }, /*#__PURE__*/_react["default"].createElement(TreeNode, { treeData: treeData, renderNode: renderNode })); } var StyledCollapsibleTriggerContent = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n width: 100%;\n cursor: pointer;\n align-items: center;\n"]))); /** * Component that renders a tree node. */ function TreeNode(props) { var treeData = props.treeData, renderNode = props.renderNode; var children = treeData.children; var _useState = (0, _react.useState)(Boolean(treeData.isOpen)), _useState2 = (0, _slicedToArray2["default"])(_useState, 2), isOpen = _useState2[0], setIsOpen = _useState2[1]; (0, _react.useEffect)(function () { setIsOpen(Boolean(treeData.isOpen)); }, [treeData.isOpen]); if (!children) { return renderNode(treeData, isOpen); } return /*#__PURE__*/_react["default"].createElement(_reactCollapsible.Collapsible, { open: isOpen, onOpenChange: setIsOpen }, /*#__PURE__*/_react["default"].createElement(_reactCollapsible.CollapsibleTrigger, { className: "w-full", asChild: true }, /*#__PURE__*/_react["default"].createElement(StyledCollapsibleTriggerContent, null, /*#__PURE__*/_react["default"].createElement(_components.Icons.ArrowRight, { className: (0, _classnames["default"])('flex-shrink-0 text-gray-500', { 'rotate-90 transform': isOpen }), height: "18px" }), renderNode(treeData, isOpen))), /*#__PURE__*/_react["default"].createElement(_reactCollapsible.CollapsibleContent, { className: "pl-4" }, isOpen ? children.map(function (child) { return /*#__PURE__*/_react["default"].createElement(TreeNode, { key: child.key, treeData: child, renderNode: renderNode }); }) : null)); } var StyledDatasetNode = _styledComponents["default"].div(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n font-weight: bold;\n"]))); var DatasetNode = exports.DatasetNode = function DatasetNode(_ref) { var node = _ref.node; return /*#__PURE__*/_react["default"].createElement(StyledDatasetNode, null, node.object.tableName); }; var StyledColumnNode = _styledComponents["default"].div(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n align-items: center;\n padding: 4px 0;\n margin-left: 16px;\n\n .column-name {\n margin-left: 8px;\n }\n"]))); var ColumnNode = exports.ColumnNode = function ColumnNode(_ref2) { var node = _ref2.node; return /*#__PURE__*/_react["default"].createElement(StyledColumnNode, null, /*#__PURE__*/_react["default"].createElement(_components.FieldToken, { type: node.object.fieldType }), /*#__PURE__*/_react["default"].createElement("div", { className: "column-name" }, node.object.name)); }; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_reactCollapsible","require","_styledComponents","_interopRequireDefault","_react","_interopRequireWildcard","_classnames","_components","_templateObject","_templateObject2","_templateObject3","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","_typeof","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","Tree","props","treeData","renderNode","createElement","className","TreeNode","StyledCollapsibleTriggerContent","styled","div","_taggedTemplateLiteral2","children","_useState","useState","Boolean","isOpen","_useState2","_slicedToArray2","setIsOpen","useEffect","Collapsible","open","onOpenChange","CollapsibleTrigger","asChild","Icons","ArrowRight","classNames","height","CollapsibleContent","map","child","key","StyledDatasetNode","DatasetNode","exports","_ref","node","object","tableName","StyledColumnNode","ColumnNode","_ref2","FieldToken","type","fieldType","name"],"sources":["../../src/components/tree.tsx"],"sourcesContent":["// SPDX-License-Identifier: MIT\n// Copyright contributors to the kepler.gl project\n\nimport {Collapsible, CollapsibleTrigger, CollapsibleContent} from '@radix-ui/react-collapsible';\nimport styled from 'styled-components';\nimport React, {useEffect, useState} from 'react';\nimport classNames from 'classnames';\n\nimport {Icons, FieldToken} from '@kepler.gl/components';\n\nexport type TreeNodeData<T> = {\n  key: string;\n  object: T;\n  children?: TreeNodeData<T>[];\n  isOpen?: boolean;\n};\n\nexport type TreeProps<T> = {\n  className?: string;\n  treeData: TreeNodeData<T>;\n  renderNode: TreeNodeProps<T>['renderNode'];\n};\n\n// TODO: consider using react-vtree/react-window for virtualization\n\n/**\n * Component that renders a generic tree.\n * @param treeData - The tree data.\n * @param renderNode - A function that renders a tree node.\n */\nexport function Tree<T>(props: TreeProps<T>): React.ReactElement {\n  const {treeData, renderNode} = props;\n  return (\n    <div className=\"flex flex-col\">\n      <TreeNode<T> treeData={treeData} renderNode={renderNode} />\n    </div>\n  );\n}\n\nexport type TreeNodeProps<T> = {\n  treeData: TreeNodeData<T>;\n  renderNode: (node: TreeNodeData<T>, isOpen: boolean) => JSX.Element | null;\n};\n\nconst StyledCollapsibleTriggerContent = styled.div`\n  display: flex;\n  width: 100%;\n  cursor: pointer;\n  align-items: center;\n`;\n/**\n * Component that renders a tree node.\n */\nfunction TreeNode<T>(props: TreeNodeProps<T>): JSX.Element | null {\n  const {treeData, renderNode} = props;\n  const {children} = treeData;\n  const [isOpen, setIsOpen] = useState(Boolean(treeData.isOpen));\n  useEffect(() => {\n    setIsOpen(Boolean(treeData.isOpen));\n  }, [treeData.isOpen]);\n  if (!children) {\n    return renderNode(treeData, isOpen);\n  }\n  return (\n    <Collapsible open={isOpen} onOpenChange={setIsOpen}>\n      <CollapsibleTrigger className=\"w-full\" asChild>\n        <StyledCollapsibleTriggerContent>\n          <Icons.ArrowRight\n            className={classNames('flex-shrink-0 text-gray-500', {'rotate-90 transform': isOpen})}\n            height=\"18px\"\n          />\n          {renderNode(treeData, isOpen)}\n        </StyledCollapsibleTriggerContent>\n      </CollapsibleTrigger>\n      <CollapsibleContent className=\"pl-4\">\n        {isOpen\n          ? children.map(child => (\n              <TreeNode<T> key={child.key} treeData={child} renderNode={renderNode} />\n            ))\n          : null}\n      </CollapsibleContent>\n    </Collapsible>\n  );\n}\n\nconst StyledDatasetNode = styled.div`\n  font-weight: bold;\n`;\n\nexport const DatasetNode = ({node}) => {\n  return <StyledDatasetNode>{node.object.tableName}</StyledDatasetNode>;\n};\n\nconst StyledColumnNode = styled.div`\n  display: flex;\n  align-items: center;\n  padding: 4px 0;\n  margin-left: 16px;\n\n  .column-name {\n    margin-left: 8px;\n  }\n`;\nexport const ColumnNode = ({node}) => {\n  return (\n    <StyledColumnNode>\n      <FieldToken type={node.object.fieldType} />\n      <div className=\"column-name\">{node.object.name}</div>\n    </StyledColumnNode>\n  );\n};\n"],"mappings":";;;;;;;;;;;AAGA,IAAAA,iBAAA,GAAAC,OAAA;AACA,IAAAC,iBAAA,GAAAC,sBAAA,CAAAF,OAAA;AACA,IAAAG,MAAA,GAAAC,uBAAA,CAAAJ,OAAA;AACA,IAAAK,WAAA,GAAAH,sBAAA,CAAAF,OAAA;AAEA,IAAAM,WAAA,GAAAN,OAAA;AAAwD,IAAAO,eAAA,EAAAC,gBAAA,EAAAC,gBAAA,EARxD;AACA;AAAA,SAAAC,yBAAAC,CAAA,6BAAAC,OAAA,mBAAAC,CAAA,OAAAD,OAAA,IAAAE,CAAA,OAAAF,OAAA,YAAAF,wBAAA,YAAAA,yBAAAC,CAAA,WAAAA,CAAA,GAAAG,CAAA,GAAAD,CAAA,KAAAF,CAAA;AAAA,SAAAP,wBAAAO,CAAA,EAAAE,CAAA,SAAAA,CAAA,IAAAF,CAAA,IAAAA,CAAA,CAAAI,UAAA,SAAAJ,CAAA,eAAAA,CAAA,gBAAAK,OAAA,CAAAL,CAAA,0BAAAA,CAAA,sBAAAA,CAAA,QAAAG,CAAA,GAAAJ,wBAAA,CAAAG,CAAA,OAAAC,CAAA,IAAAA,CAAA,CAAAG,GAAA,CAAAN,CAAA,UAAAG,CAAA,CAAAI,GAAA,CAAAP,CAAA,OAAAQ,CAAA,KAAAC,SAAA,UAAAC,CAAA,GAAAC,MAAA,CAAAC,cAAA,IAAAD,MAAA,CAAAE,wBAAA,WAAAC,CAAA,IAAAd,CAAA,oBAAAc,CAAA,OAAAC,cAAA,CAAAC,IAAA,CAAAhB,CAAA,EAAAc,CAAA,SAAAG,CAAA,GAAAP,CAAA,GAAAC,MAAA,CAAAE,wBAAA,CAAAb,CAAA,EAAAc,CAAA,UAAAG,CAAA,KAAAA,CAAA,CAAAV,GAAA,IAAAU,CAAA,CAAAC,GAAA,IAAAP,MAAA,CAAAC,cAAA,CAAAJ,CAAA,EAAAM,CAAA,EAAAG,CAAA,IAAAT,CAAA,CAAAM,CAAA,IAAAd,CAAA,CAAAc,CAAA,YAAAN,CAAA,cAAAR,CAAA,EAAAG,CAAA,IAAAA,CAAA,CAAAe,GAAA,CAAAlB,CAAA,EAAAQ,CAAA,GAAAA,CAAA;AAsBA;;AAEA;AACA;AACA;AACA;AACA;AACO,SAASW,IAAIA,CAAIC,KAAmB,EAAsB;EAC/D,IAAOC,QAAQ,GAAgBD,KAAK,CAA7BC,QAAQ;IAAEC,UAAU,GAAIF,KAAK,CAAnBE,UAAU;EAC3B,oBACE9B,MAAA,YAAA+B,aAAA;IAAKC,SAAS,EAAC;EAAe,gBAC5BhC,MAAA,YAAA+B,aAAA,CAACE,QAAQ;IAAIJ,QAAQ,EAAEA,QAAS;IAACC,UAAU,EAAEA;EAAW,CAAE,CACvD,CAAC;AAEV;AAOA,IAAMI,+BAA+B,GAAGC,4BAAM,CAACC,GAAG,CAAAhC,eAAA,KAAAA,eAAA,OAAAiC,uBAAA,oGAKjD;AACD;AACA;AACA;AACA,SAASJ,QAAQA,CAAIL,KAAuB,EAAsB;EAChE,IAAOC,QAAQ,GAAgBD,KAAK,CAA7BC,QAAQ;IAAEC,UAAU,GAAIF,KAAK,CAAnBE,UAAU;EAC3B,IAAOQ,QAAQ,GAAIT,QAAQ,CAApBS,QAAQ;EACf,IAAAC,SAAA,GAA4B,IAAAC,eAAQ,EAACC,OAAO,CAACZ,QAAQ,CAACa,MAAM,CAAC,CAAC;IAAAC,UAAA,OAAAC,eAAA,aAAAL,SAAA;IAAvDG,MAAM,GAAAC,UAAA;IAAEE,SAAS,GAAAF,UAAA;EACxB,IAAAG,gBAAS,EAAC,YAAM;IACdD,SAAS,CAACJ,OAAO,CAACZ,QAAQ,CAACa,MAAM,CAAC,CAAC;EACrC,CAAC,EAAE,CAACb,QAAQ,CAACa,MAAM,CAAC,CAAC;EACrB,IAAI,CAACJ,QAAQ,EAAE;IACb,OAAOR,UAAU,CAACD,QAAQ,EAAEa,MAAM,CAAC;EACrC;EACA,oBACE1C,MAAA,YAAA+B,aAAA,CAACnC,iBAAA,CAAAmD,WAAW;IAACC,IAAI,EAAEN,MAAO;IAACO,YAAY,EAAEJ;EAAU,gBACjD7C,MAAA,YAAA+B,aAAA,CAACnC,iBAAA,CAAAsD,kBAAkB;IAAClB,SAAS,EAAC,QAAQ;IAACmB,OAAO;EAAA,gBAC5CnD,MAAA,YAAA+B,aAAA,CAACG,+BAA+B,qBAC9BlC,MAAA,YAAA+B,aAAA,CAAC5B,WAAA,CAAAiD,KAAK,CAACC,UAAU;IACfrB,SAAS,EAAE,IAAAsB,sBAAU,EAAC,6BAA6B,EAAE;MAAC,qBAAqB,EAAEZ;IAAM,CAAC,CAAE;IACtFa,MAAM,EAAC;EAAM,CACd,CAAC,EACDzB,UAAU,CAACD,QAAQ,EAAEa,MAAM,CACG,CACf,CAAC,eACrB1C,MAAA,YAAA+B,aAAA,CAACnC,iBAAA,CAAA4D,kBAAkB;IAACxB,SAAS,EAAC;EAAM,GACjCU,MAAM,GACHJ,QAAQ,CAACmB,GAAG,CAAC,UAAAC,KAAK;IAAA,oBAChB1D,MAAA,YAAA+B,aAAA,CAACE,QAAQ;MAAI0B,GAAG,EAAED,KAAK,CAACC,GAAI;MAAC9B,QAAQ,EAAE6B,KAAM;MAAC5B,UAAU,EAAEA;IAAW,CAAE,CAAC;EAAA,CACzE,CAAC,GACF,IACc,CACT,CAAC;AAElB;AAEA,IAAM8B,iBAAiB,GAAGzB,4BAAM,CAACC,GAAG,CAAA/B,gBAAA,KAAAA,gBAAA,OAAAgC,uBAAA,4CAEnC;AAEM,IAAMwB,WAAW,GAAAC,OAAA,CAAAD,WAAA,GAAG,SAAdA,WAAWA,CAAAE,IAAA,EAAe;EAAA,IAAVC,IAAI,GAAAD,IAAA,CAAJC,IAAI;EAC/B,oBAAOhE,MAAA,YAAA+B,aAAA,CAAC6B,iBAAiB,QAAEI,IAAI,CAACC,MAAM,CAACC,SAA6B,CAAC;AACvE,CAAC;AAED,IAAMC,gBAAgB,GAAGhC,4BAAM,CAACC,GAAG,CAAA9B,gBAAA,KAAAA,gBAAA,OAAA+B,uBAAA,yJASlC;AACM,IAAM+B,UAAU,GAAAN,OAAA,CAAAM,UAAA,GAAG,SAAbA,UAAUA,CAAAC,KAAA,EAAe;EAAA,IAAVL,IAAI,GAAAK,KAAA,CAAJL,IAAI;EAC9B,oBACEhE,MAAA,YAAA+B,aAAA,CAACoC,gBAAgB,qBACfnE,MAAA,YAAA+B,aAAA,CAAC5B,WAAA,CAAAmE,UAAU;IAACC,IAAI,EAAEP,IAAI,CAACC,MAAM,CAACO;EAAU,CAAE,CAAC,eAC3CxE,MAAA,YAAA+B,aAAA;IAAKC,SAAS,EAAC;EAAa,GAAEgC,IAAI,CAACC,MAAM,CAACQ,IAAU,CACpC,CAAC;AAEvB,CAAC","ignoreList":[]}