kepler.gl.geoiq
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
160 lines (138 loc) • 22 kB
JavaScript
"use strict";
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports["default"] = exports.DatasetTag = void 0;
var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
var _react = _interopRequireDefault(require("react"));
var _styledComponents = _interopRequireDefault(require("styled-components"));
var _d3Format = require("d3-format");
var _styledComponents2 = require("../common/styled-components");
var _icons = require("../common/icons");
var _templateObject, _templateObject2, _templateObject3, _templateObject4, _templateObject5;
var defaultRemoveDataset = function defaultRemoveDataset(datasetKey) {};
var numFormat = (0, _d3Format.format)(',');
var SourceDataCatelogWrapper = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n transition: ", ";\n"])), function (props) {
return props.theme.transition;
});
var DatasetTitle = _styledComponents["default"].div(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n color: ", ";\n display: flex;\n align-items: flex-start;\n\n .source-data-arrow {\n height: 16px;\n }\n :hover {\n color: ", ";\n cursor: ", ";\n\n .dataset-action {\n color: ", ";\n opacity: 1;\n }\n\n .dataset-action:hover {\n color: black;\n }\n }\n"])), function (props) {
return props.theme.textColor;
}, function (props) {
return props.clickable ? props.theme.textColorHl : props.theme.textColor;
}, function (props) {
return props.clickable ? 'pointer' : 'auto';
}, function (props) {
return props.theme.textColorHl;
});
var DatasetTagWrapper = _styledComponents["default"].div(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n color: ", ";\n font-size: 11px;\n letter-spacing: 0.2px;\n overflow: auto;\n\n .dataset-color {\n flex-shrink: 0;\n margin-top: 5px;\n }\n\n .dataset-name {\n white-space: nowrap;\n overflow: hidden;\n text-overflow: ellipsis;\n }\n"])), function (props) {
return props.theme.textColor;
});
var DataTagAction = _styledComponents["default"].div(_templateObject4 || (_templateObject4 = (0, _taggedTemplateLiteral2["default"])(["\n margin-left: 12px;\n height: 16px;\n opacity: 0;\n"])));
var DataRowCount = _styledComponents["default"].div(_templateObject5 || (_templateObject5 = (0, _taggedTemplateLiteral2["default"])(["\n font-size: 11px;\n color: ", ";\n padding-left: 19px;\n"])), function (props) {
return props.theme.subtextColor;
});
var DatasetTag = exports.DatasetTag = function DatasetTag(_ref) {
var onClick = _ref.onClick,
dataset = _ref.dataset;
return (/*#__PURE__*/_react["default"].createElement(DatasetTagWrapper, {
className: "source-data-tag",
onClick: onClick
}, /*#__PURE__*/_react["default"].createElement(_styledComponents2.DatasetSquare, {
className: "dataset-color",
color: dataset.color
}), /*#__PURE__*/_react["default"].createElement("div", {
className: "dataset-name"
}, dataset.label))
);
};
var ShowDataTable = function ShowDataTable(_ref2) {
var id = _ref2.id,
showDatasetTable = _ref2.showDatasetTable;
return (/*#__PURE__*/_react["default"].createElement(DataTagAction, {
className: "dataset-action show-data-table",
"data-tip": true,
"data-for": "data-table-".concat(id)
}, /*#__PURE__*/_react["default"].createElement(_icons.Table, {
height: "16px",
onClick: function onClick() {
return showDatasetTable(id);
}
}), /*#__PURE__*/_react["default"].createElement(_styledComponents2.Tooltip, {
id: "data-table-".concat(id),
effect: "solid"
}, /*#__PURE__*/_react["default"].createElement("span", null, "Show data table")))
);
};
var RemoveDataset = function RemoveDataset(_ref3) {
var datasetKey = _ref3.datasetKey,
_ref3$removeDataset = _ref3.removeDataset,
removeDataset = _ref3$removeDataset === void 0 ? defaultRemoveDataset : _ref3$removeDataset;
return (/*#__PURE__*/_react["default"].createElement(DataTagAction, {
className: "dataset-action remove-dataset",
"data-tip": true,
"data-for": "delete-".concat(datasetKey)
}, /*#__PURE__*/_react["default"].createElement(_icons.Trash, {
height: "16px",
onClick: function onClick(e) {
e.stopPropagation();
removeDataset(datasetKey);
}
}), /*#__PURE__*/_react["default"].createElement(_styledComponents2.Tooltip, {
id: "delete-".concat(datasetKey),
effect: "solid",
type: "error"
}, /*#__PURE__*/_react["default"].createElement("span", null, "Remove dataset")))
);
};
function SourceDataCatalogFactory() {
var SourceDataCatalog = function SourceDataCatalog(_ref4) {
var datasets = _ref4.datasets,
showDatasetTable = _ref4.showDatasetTable,
removeDataset = _ref4.removeDataset,
_ref4$showDeleteDatas = _ref4.showDeleteDataset,
showDeleteDataset = _ref4$showDeleteDatas === void 0 ? false : _ref4$showDeleteDatas;
return (/*#__PURE__*/_react["default"].createElement(SourceDataCatelogWrapper, {
className: "source-data-catalog"
}, Object.values(datasets).map(function (dataset, index) {
return dataset.externalData && dataset.externalData === true ? /*#__PURE__*/_react["default"].createElement(_styledComponents2.SidePanelSection, {
key: dataset.id
}, /*#__PURE__*/_react["default"].createElement(DatasetTitle, {
className: "source-data-title"
}, /*#__PURE__*/_react["default"].createElement(DatasetTag, {
dataset: dataset
}), showDatasetTable ? /*#__PURE__*/_react["default"].createElement(_styledComponents2.CenterFlexbox, {
className: "source-data-arrow"
}, /*#__PURE__*/_react["default"].createElement(_icons.ArrowRight, {
height: "12px"
})) : null, showDeleteDataset ? /*#__PURE__*/_react["default"].createElement(RemoveDataset, {
datasetKey: dataset.id,
removeDataset: removeDataset
}) : null)) : /*#__PURE__*/_react["default"].createElement(_styledComponents2.SidePanelSection, {
key: dataset.id
}, /*#__PURE__*/_react["default"].createElement(DatasetTitle, {
className: "source-data-title",
clickable: Boolean(showDatasetTable)
}, /*#__PURE__*/_react["default"].createElement(DatasetTag, {
dataset: dataset,
onClick: showDatasetTable ? function () {
return showDatasetTable(dataset.id);
} : null
}), showDatasetTable ? /*#__PURE__*/_react["default"].createElement(_styledComponents2.CenterFlexbox, {
className: "source-data-arrow"
}, /*#__PURE__*/_react["default"].createElement(_icons.ArrowRight, {
height: "12px"
})) : null, showDatasetTable ? /*#__PURE__*/_react["default"].createElement(ShowDataTable, {
id: dataset.id,
showDatasetTable: showDatasetTable
}) : null, showDeleteDataset ? /*#__PURE__*/_react["default"].createElement(RemoveDataset, {
datasetKey: dataset.id,
removeDataset: removeDataset
}) : null));
}))
);
};
return SourceDataCatalog;
}
var _default = exports["default"] = SourceDataCatalogFactory;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/components/side-panel/source-data-catalog.js"],"names":["defaultRemoveDataset","datasetKey","numFormat","SourceDataCatelogWrapper","styled","div","props","theme","transition","DatasetTitle","textColor","clickable","textColorHl","DatasetTagWrapper","DataTagAction","DataRowCount","subtextColor","DatasetTag","onClick","dataset","color","label","ShowDataTable","id","showDatasetTable","RemoveDataset","removeDataset","e","stopPropagation","SourceDataCatalogFactory","SourceDataCatalog","datasets","showDeleteDataset","Object","values","map","index","externalData","Boolean"],"mappings":"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","sourcesContent":["// Copyright (c) 2023 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 from 'react';\nimport styled from 'styled-components';\nimport {format} from 'd3-format';\n\nimport {\n  SidePanelSection,\n  Tooltip,\n  DatasetSquare,\n  CenterFlexbox\n} from 'components/common/styled-components';\nimport {Table, Trash, ArrowRight} from 'components/common/icons';\n\nconst defaultRemoveDataset = datasetKey => {};\nconst numFormat = format(',');\n\nconst SourceDataCatelogWrapper = styled.div`\n  transition: ${props => props.theme.transition};\n`;\n\nconst DatasetTitle = styled.div`\n  color: ${props => props.theme.textColor};\n  display: flex;\n  align-items: flex-start;\n\n  .source-data-arrow {\n    height: 16px;\n  }\n  :hover {\n    color: ${props =>\n      props.clickable ? props.theme.textColorHl : props.theme.textColor};\n    cursor: ${props => (props.clickable ? 'pointer' : 'auto')};\n\n    .dataset-action {\n      color: ${props => props.theme.textColorHl};\n      opacity: 1;\n    }\n\n    .dataset-action:hover {\n      color: black;\n    }\n  }\n`;\n\nconst DatasetTagWrapper = styled.div`\n  display: flex;\n  color: ${props => props.theme.textColor};\n  font-size: 11px;\n  letter-spacing: 0.2px;\n  overflow: auto;\n\n  .dataset-color {\n    flex-shrink: 0;\n    margin-top: 5px;\n  }\n\n  .dataset-name {\n    white-space: nowrap;\n    overflow: hidden;\n    text-overflow: ellipsis;\n  }\n`;\n\nconst DataTagAction = styled.div`\n  margin-left: 12px;\n  height: 16px;\n  opacity: 0;\n`;\n\nconst DataRowCount = styled.div`\n  font-size: 11px;\n  color: ${props => props.theme.subtextColor};\n  padding-left: 19px;\n`;\n\nexport const DatasetTag = ({onClick, dataset}) => (\n  <DatasetTagWrapper className=\"source-data-tag\" onClick={onClick}>\n    <DatasetSquare className=\"dataset-color\" color={dataset.color} />\n    <div className=\"dataset-name\">{dataset.label}</div>\n  </DatasetTagWrapper>\n);\n\nconst ShowDataTable = ({id, showDatasetTable}) => (\n  <DataTagAction\n    className=\"dataset-action show-data-table\"\n    data-tip\n    data-for={`data-table-${id}`}\n  >\n    <Table height=\"16px\" onClick={() => showDatasetTable(id)} />\n    <Tooltip id={`data-table-${id}`} effect=\"solid\">\n      <span>Show data table</span>\n    </Tooltip>\n  </DataTagAction>\n);\n\nconst RemoveDataset = ({datasetKey, removeDataset = defaultRemoveDataset}) => (\n  <DataTagAction\n    className=\"dataset-action remove-dataset\"\n    data-tip\n    data-for={`delete-${datasetKey}`}\n  >\n    <Trash\n      height=\"16px\"\n      onClick={e => {\n        e.stopPropagation();\n        removeDataset(datasetKey);\n      }}\n    />\n    <Tooltip id={`delete-${datasetKey}`} effect=\"solid\" type=\"error\">\n      <span>Remove dataset</span>\n    </Tooltip>\n  </DataTagAction>\n);\n\nfunction SourceDataCatalogFactory() {\n  const SourceDataCatalog = ({\n    datasets,\n    showDatasetTable,\n    removeDataset,\n    showDeleteDataset = false\n  }) => (\n    <SourceDataCatelogWrapper className=\"source-data-catalog\">\n      {Object.values(datasets).map((dataset, index) =>\n        dataset.externalData && dataset.externalData === true ? (\n          <SidePanelSection key={dataset.id}>\n            <DatasetTitle className=\"source-data-title\">\n              <DatasetTag dataset={dataset} />\n              {showDatasetTable ? (\n                <CenterFlexbox className=\"source-data-arrow\">\n                  <ArrowRight height=\"12px\" />\n                </CenterFlexbox>\n              ) : null}\n              {showDeleteDataset ? (\n                <RemoveDataset\n                  datasetKey={dataset.id}\n                  removeDataset={removeDataset}\n                />\n              ) : null}\n            </DatasetTitle>\n            {/* {showDatasetTable ? (\n              <DataRowCount className=\"source-data-rows\">{`${numFormat(\n                dataset.allData.length\n              )} rows`}</DataRowCount>\n            ) : null} */}\n          </SidePanelSection>\n        ) : (\n          <SidePanelSection key={dataset.id}>\n            <DatasetTitle\n              className=\"source-data-title\"\n              clickable={Boolean(showDatasetTable)}\n            >\n              <DatasetTag\n                dataset={dataset}\n                onClick={\n                  showDatasetTable ? () => showDatasetTable(dataset.id) : null\n                }\n              />\n              {showDatasetTable ? (\n                <CenterFlexbox className=\"source-data-arrow\">\n                  <ArrowRight height=\"12px\" />\n                </CenterFlexbox>\n              ) : null}\n              {showDatasetTable ? (\n                <ShowDataTable\n                  id={dataset.id}\n                  showDatasetTable={showDatasetTable}\n                />\n              ) : null}\n              {showDeleteDataset ? (\n                <RemoveDataset\n                  datasetKey={dataset.id}\n                  removeDataset={removeDataset}\n                />\n              ) : null}\n            </DatasetTitle>\n            {/* {showDatasetTable ? (\n              <DataRowCount className=\"source-data-rows\">{`${numFormat(\n                dataset.allData ? dataset.allData.length : null\n              )} rows`}</DataRowCount>\n            ) : null} */}\n          </SidePanelSection>\n        )\n      )}\n    </SourceDataCatelogWrapper>\n  );\n\n  return SourceDataCatalog;\n}\n\nexport default SourceDataCatalogFactory;\n"]}