UNPKG

kepler.gl

Version:

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

196 lines (173 loc) 20.2 kB
'use strict'; Object.defineProperty(exports, "__esModule", { value: true }); exports.DatasetTag = undefined; var _taggedTemplateLiteral2 = require('babel-runtime/helpers/taggedTemplateLiteral'); var _taggedTemplateLiteral3 = _interopRequireDefault(_taggedTemplateLiteral2); var _templateObject = (0, _taggedTemplateLiteral3.default)(['\n transition: ', ';\n'], ['\n transition: ', ';\n']), _templateObject2 = (0, _taggedTemplateLiteral3.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: white;\n }\n }\n'], ['\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: white;\n }\n }\n']), _templateObject3 = (0, _taggedTemplateLiteral3.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'], ['\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']), _templateObject4 = (0, _taggedTemplateLiteral3.default)(['\n margin-left: 12px;\n height: 16px;\n opacity: 0;\n'], ['\n margin-left: 12px;\n height: 16px;\n opacity: 0;\n']), _templateObject5 = (0, _taggedTemplateLiteral3.default)(['\n font-size: 11px;\n color: ', ';\n padding-left: 19px;\n'], ['\n font-size: 11px;\n color: ', ';\n padding-left: 19px;\n']); // Copyright (c) 2018 Uber Technologies, Inc. // // Permission is hereby granted, free of charge, to any person obtaining a copy // of this software and associated documentation files (the "Software"), to deal // in the Software without restriction, including without limitation the rights // to use, copy, modify, merge, publish, distribute, sublicense, and/or sell // copies of the Software, and to permit persons to whom the Software is // furnished to do so, subject to the following conditions: // // The above copyright notice and this permission notice shall be included in // all copies or substantial portions of the Software. // // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR // IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, // FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE // AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER // LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, // OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN // THE SOFTWARE. var _react = require('react'); var _react2 = _interopRequireDefault(_react); var _styledComponents = require('styled-components'); var _styledComponents2 = _interopRequireDefault(_styledComponents); var _d3Format = require('d3-format'); var _styledComponents3 = require('../common/styled-components'); var _icons = require('../common/icons'); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } var defaultRemoveDataset = function defaultRemoveDataset(datasetKey) {}; var numFormat = (0, _d3Format.format)(','); var SourceDataCatelog = _styledComponents2.default.div(_templateObject, function (props) { return props.theme.transition; }); var DatasetTitle = _styledComponents2.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 = _styledComponents2.default.div(_templateObject3, function (props) { return props.theme.textColor; }); var DataTagAction = _styledComponents2.default.div(_templateObject4); var DataRowCount = _styledComponents2.default.div(_templateObject5, function (props) { return props.theme.subtextColor; }); var DatasetTag = exports.DatasetTag = function DatasetTag(_ref) { var onClick = _ref.onClick, dataset = _ref.dataset; return _react2.default.createElement( DatasetTagWrapper, { className: 'source-data-tag', onClick: onClick }, _react2.default.createElement(_styledComponents3.DatasetSquare, { className: 'dataset-color', color: dataset.color }), _react2.default.createElement( 'div', { className: 'dataset-name' }, dataset.label ) ); }; var SourceDataCatalog = function SourceDataCatalog(_ref2) { var datasets = _ref2.datasets, showDatasetTable = _ref2.showDatasetTable, removeDataset = _ref2.removeDataset, _ref2$showDeleteDatas = _ref2.showDeleteDataset, showDeleteDataset = _ref2$showDeleteDatas === undefined ? false : _ref2$showDeleteDatas; return _react2.default.createElement( SourceDataCatelog, { className: 'source-data-catalog' }, Object.values(datasets).map(function (dataset, index) { return _react2.default.createElement( _styledComponents3.SidePanelSection, { key: dataset.id }, _react2.default.createElement( DatasetTitle, { className: 'source-data-title', clickable: Boolean(showDatasetTable) }, _react2.default.createElement(DatasetTag, { dataset: dataset, onClick: showDatasetTable ? function () { return showDatasetTable(dataset.id); } : null }), showDatasetTable ? _react2.default.createElement( _styledComponents3.CenterFlexbox, { className: 'source-data-arrow' }, _react2.default.createElement(_icons.ArrowRight, { height: '12px' }) ) : null, showDatasetTable ? _react2.default.createElement(ShowDataTable, { id: dataset.id, showDatasetTable: showDatasetTable }) : null, showDeleteDataset ? _react2.default.createElement(RemoveDataset, { datasetKey: dataset.id, removeDataset: removeDataset }) : null ), showDatasetTable ? _react2.default.createElement( DataRowCount, { className: 'source-data-rows' }, numFormat(dataset.allData.length) + ' rows' ) : null ); }) ); }; var ShowDataTable = function ShowDataTable(_ref3) { var id = _ref3.id, showDatasetTable = _ref3.showDatasetTable; return _react2.default.createElement( DataTagAction, { className: 'dataset-action show-data-table', 'data-tip': true, 'data-for': 'data-table-' + id }, _react2.default.createElement(_icons.Table, { height: '16px', onClick: function onClick() { return showDatasetTable(id); } }), _react2.default.createElement( _styledComponents3.Tooltip, { id: 'data-table-' + id, effect: 'solid' }, _react2.default.createElement( 'span', null, 'Show data table' ) ) ); }; var RemoveDataset = function RemoveDataset(_ref4) { var datasetKey = _ref4.datasetKey, _ref4$removeDataset = _ref4.removeDataset, removeDataset = _ref4$removeDataset === undefined ? defaultRemoveDataset : _ref4$removeDataset; return _react2.default.createElement( DataTagAction, { className: 'dataset-action remove-dataset', 'data-tip': true, 'data-for': 'delete-' + datasetKey }, _react2.default.createElement(_icons.Trash, { height: '16px', onClick: function onClick(e) { e.stopPropagation(); removeDataset(datasetKey); } }), _react2.default.createElement( _styledComponents3.Tooltip, { id: 'delete-' + datasetKey, effect: 'solid', type: 'error' }, _react2.default.createElement( 'span', null, 'Remove dataset' ) ) ); }; exports.default = SourceDataCatalog; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/components/side-panel/source-data-catalog.js"],"names":["defaultRemoveDataset","numFormat","SourceDataCatelog","styled","div","props","theme","transition","DatasetTitle","textColor","clickable","textColorHl","DatasetTagWrapper","DataTagAction","DataRowCount","subtextColor","DatasetTag","onClick","dataset","color","label","SourceDataCatalog","datasets","showDatasetTable","removeDataset","showDeleteDataset","Object","values","map","index","id","Boolean","allData","length","ShowDataTable","RemoveDataset","datasetKey","e","stopPropagation"],"mappings":"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","file":"source-data-catalog.js","sourcesContent":["// Copyright (c) 2018 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 {SidePanelSection, Tooltip, DatasetSquare, CenterFlexbox} from 'components/common/styled-components';\nimport {Table, Trash, ArrowRight} from 'components/common/icons';\n\nconst defaultRemoveDataset = datasetKey => {};\nconst numFormat = format(',');\n\nconst SourceDataCatelog = 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: white;\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 SourceDataCatalog = ({\n  datasets,\n  showDatasetTable,\n  removeDataset,\n  showDeleteDataset = false\n}) => (\n  <SourceDataCatelog className=\"source-data-catalog\">\n    {Object.values(datasets).map((dataset, index) => (\n      <SidePanelSection key={dataset.id}>\n        <DatasetTitle className=\"source-data-title\" clickable={Boolean(showDatasetTable)}>\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> : 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  </SourceDataCatelog>\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\nexport default SourceDataCatalog;\n"]}