kepler.gl.geoiq
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
211 lines (174 loc) • 22.8 kB
JavaScript
;
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");
function _templateObject5() {
var data = (0, _taggedTemplateLiteral2["default"])(["\n font-size: 11px;\n color: ", ";\n padding-left: 19px;\n"]);
_templateObject5 = function _templateObject5() {
return data;
};
return data;
}
function _templateObject4() {
var data = (0, _taggedTemplateLiteral2["default"])(["\n margin-left: 12px;\n height: 16px;\n opacity: 0;\n"]);
_templateObject4 = function _templateObject4() {
return data;
};
return data;
}
function _templateObject3() {
var data = (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"]);
_templateObject3 = function _templateObject3() {
return data;
};
return data;
}
function _templateObject2() {
var data = (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"]);
_templateObject2 = function _templateObject2() {
return data;
};
return data;
}
function _templateObject() {
var data = (0, _taggedTemplateLiteral2["default"])(["\n transition: ", ";\n"]);
_templateObject = function _templateObject() {
return data;
};
return data;
}
var defaultRemoveDataset = function defaultRemoveDataset(datasetKey) {};
var numFormat = (0, _d3Format.format)(',');
var SourceDataCatelogWrapper = _styledComponents["default"].div(_templateObject(), function (props) {
return props.theme.transition;
});
var DatasetTitle = _styledComponents["default"].div(_templateObject2(), 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(), function (props) {
return props.theme.textColor;
});
var DataTagAction = _styledComponents["default"].div(_templateObject4());
var DataRowCount = _styledComponents["default"].div(_templateObject5(), function (props) {
return props.theme.subtextColor;
});
var DatasetTag = function DatasetTag(_ref) {
var onClick = _ref.onClick,
dataset = _ref.dataset;
return _react["default"].createElement(DatasetTagWrapper, {
className: "source-data-tag",
onClick: onClick
}, _react["default"].createElement(_styledComponents2.DatasetSquare, {
className: "dataset-color",
color: dataset.color
}), _react["default"].createElement("div", {
className: "dataset-name"
}, dataset.label));
};
exports.DatasetTag = DatasetTag;
var ShowDataTable = function ShowDataTable(_ref2) {
var id = _ref2.id,
showDatasetTable = _ref2.showDatasetTable;
return _react["default"].createElement(DataTagAction, {
className: "dataset-action show-data-table",
"data-tip": true,
"data-for": "data-table-".concat(id)
}, _react["default"].createElement(_icons.Table, {
height: "16px",
onClick: function onClick() {
return showDatasetTable(id);
}
}), _react["default"].createElement(_styledComponents2.Tooltip, {
id: "data-table-".concat(id),
effect: "solid"
}, _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 _react["default"].createElement(DataTagAction, {
className: "dataset-action remove-dataset",
"data-tip": true,
"data-for": "delete-".concat(datasetKey)
}, _react["default"].createElement(_icons.Trash, {
height: "16px",
onClick: function onClick(e) {
e.stopPropagation();
removeDataset(datasetKey);
}
}), _react["default"].createElement(_styledComponents2.Tooltip, {
id: "delete-".concat(datasetKey),
effect: "solid",
type: "error"
}, _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 _react["default"].createElement(SourceDataCatelogWrapper, {
className: "source-data-catalog"
}, Object.values(datasets).map(function (dataset, index) {
return dataset.externalData && dataset.externalData === true ? _react["default"].createElement(_styledComponents2.SidePanelSection, {
key: dataset.id
}, _react["default"].createElement(DatasetTitle, {
className: "source-data-title"
}, _react["default"].createElement(DatasetTag, {
dataset: dataset
}), showDatasetTable ? _react["default"].createElement(_styledComponents2.CenterFlexbox, {
className: "source-data-arrow"
}, _react["default"].createElement(_icons.ArrowRight, {
height: "12px"
})) : null, showDeleteDataset ? _react["default"].createElement(RemoveDataset, {
datasetKey: dataset.id,
removeDataset: removeDataset
}) : null), showDatasetTable ? _react["default"].createElement(DataRowCount, {
className: "source-data-rows"
}, "".concat(numFormat(dataset.allData.length), " rows")) : null) : _react["default"].createElement(_styledComponents2.SidePanelSection, {
key: dataset.id
}, _react["default"].createElement(DatasetTitle, {
className: "source-data-title",
clickable: Boolean(showDatasetTable)
}, _react["default"].createElement(DatasetTag, {
dataset: dataset,
onClick: showDatasetTable ? function () {
return showDatasetTable(dataset.id);
} : null
}), showDatasetTable ? _react["default"].createElement(_styledComponents2.CenterFlexbox, {
className: "source-data-arrow"
}, _react["default"].createElement(_icons.ArrowRight, {
height: "12px"
})) : null, showDatasetTable ? _react["default"].createElement(ShowDataTable, {
id: dataset.id,
showDatasetTable: showDatasetTable
}) : null, showDeleteDataset ? _react["default"].createElement(RemoveDataset, {
datasetKey: dataset.id,
removeDataset: removeDataset
}) : null), showDatasetTable ? _react["default"].createElement(DataRowCount, {
className: "source-data-rows"
}, "".concat(numFormat(dataset.allData.length), " rows")) : null);
}));
};
return SourceDataCatalog;
}
var _default = SourceDataCatalogFactory;
exports["default"] = _default;
//# 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","allData","length","Boolean"],"mappings":"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","sourcesContent":["// Copyright (c) 2019 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.length\n              )} rows`}</DataRowCount>\n            ) : null}\n          </SidePanelSection>\n        )\n      )}\n    </SourceDataCatelogWrapper>\n  );\n\n  return SourceDataCatalog;\n}\n\nexport default SourceDataCatalogFactory;\n"]}