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
JavaScript
'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"]}