kepler.gl
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
74 lines (73 loc) • 12.6 kB
JavaScript
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.AddDataButtonFactory = AddDataButtonFactory;
exports["default"] = void 0;
var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
var _react = _interopRequireDefault(require("react"));
var _styledComponents = _interopRequireDefault(require("styled-components"));
var _localization = require("@kepler.gl/localization");
var _icons = require("../../common/icons");
var _styledComponents2 = require("../../common/styled-components");
var _sourceDataCatalog = _interopRequireDefault(require("../common/source-data-catalog"));
var _templateObject, _templateObject2; // SPDX-License-Identifier: MIT
// Copyright contributors to the kepler.gl project
var StyledDatasetTitle = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n line-height: ", ";\n font-weight: 400;\n letter-spacing: 1.25px;\n color: ", ";\n font-size: 11px;\n display: flex;\n justify-content: space-between;\n align-items: center;\n margin-bottom: ", ";\n"])), function (props) {
return props.theme.sidePanelTitleLineHeight;
}, function (props) {
return props.theme.subtextColor;
}, function (props) {
return props.showDatasetList ? '16px' : '4px';
});
var StyledDatasetSection = _styledComponents["default"].div(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n border-bottom: 1px solid ", ";\n"])), function (props) {
return props.theme.sidePanelBorderColor;
});
function AddDataButtonFactory() {
var AddDataButton = /*#__PURE__*/_react["default"].memo(function (_ref) {
var onClick = _ref.onClick,
isInactive = _ref.isInactive;
return /*#__PURE__*/_react["default"].createElement(_styledComponents2.Button, {
className: "add-data-button",
onClick: onClick,
inactive: !isInactive,
width: "105px",
secondary: true
}, /*#__PURE__*/_react["default"].createElement(_icons.Add, {
height: "12px"
}), /*#__PURE__*/_react["default"].createElement(_localization.FormattedMessage, {
id: 'layerManager.addData'
}));
});
AddDataButton.displayName = 'AddDataButton';
return AddDataButton;
}
DatasetSectionFactory.deps = [_sourceDataCatalog["default"], AddDataButtonFactory];
function DatasetSectionFactory(SourceDataCatalog, AddDataButton) {
var DatasetSection = function DatasetSection(props) {
var datasets = props.datasets,
showDatasetTable = props.showDatasetTable,
updateTableColor = props.updateTableColor,
showDeleteDataset = props.showDeleteDataset,
removeDataset = props.removeDataset,
showDatasetList = props.showDatasetList,
showAddDataModal = props.showAddDataModal;
var datasetCount = Object.keys(datasets).length;
return /*#__PURE__*/_react["default"].createElement(StyledDatasetSection, null, /*#__PURE__*/_react["default"].createElement(StyledDatasetTitle, {
showDatasetList: showDatasetList
}, /*#__PURE__*/_react["default"].createElement("span", null, "Datasets", datasetCount ? "(".concat(datasetCount, ")") : ''), /*#__PURE__*/_react["default"].createElement(AddDataButton, {
onClick: showAddDataModal,
isInactive: !datasetCount
})), showDatasetList && /*#__PURE__*/_react["default"].createElement(SourceDataCatalog, {
datasets: datasets,
showDatasetTable: showDatasetTable,
updateTableColor: updateTableColor,
removeDataset: removeDataset,
showDeleteDataset: showDeleteDataset
}));
};
return DatasetSection;
}
var _default = exports["default"] = DatasetSectionFactory;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireDefault","require","_styledComponents","_localization","_icons","_styledComponents2","_sourceDataCatalog","_templateObject","_templateObject2","StyledDatasetTitle","styled","div","_taggedTemplateLiteral2","props","theme","sidePanelTitleLineHeight","subtextColor","showDatasetList","StyledDatasetSection","sidePanelBorderColor","AddDataButtonFactory","AddDataButton","React","memo","_ref","onClick","isInactive","createElement","Button","className","inactive","width","secondary","Add","height","FormattedMessage","id","displayName","DatasetSectionFactory","deps","SourceDataCatalogFactory","SourceDataCatalog","DatasetSection","datasets","showDatasetTable","updateTableColor","showDeleteDataset","removeDataset","showAddDataModal","datasetCount","Object","keys","length","concat","_default","exports"],"sources":["../../../src/side-panel/layer-panel/dataset-section.tsx"],"sourcesContent":["// SPDX-License-Identifier: MIT\n// Copyright contributors to the kepler.gl project\n\nimport React from 'react';\nimport styled from 'styled-components';\nimport {FormattedMessage} from '@kepler.gl/localization';\nimport {Add} from '../../common/icons';\nimport {Button} from '../../common/styled-components';\n\nimport SourceDataCatalogFactory from '../common/source-data-catalog';\nimport {UIStateActions, VisStateActions, ActionHandler} from '@kepler.gl/actions';\nimport {Datasets} from '@kepler.gl/table';\n\ntype AddDataButtonProps = {\n  onClick: () => void;\n  isInactive: boolean;\n};\n\ntype DatasetSectionProps = {\n  datasets: Datasets;\n  showDatasetList?: boolean;\n  showDeleteDataset?: boolean;\n  showDatasetTable: ActionHandler<typeof VisStateActions.showDatasetTable>;\n  updateTableColor: ActionHandler<typeof VisStateActions.updateTableColor>;\n  removeDataset: ActionHandler<typeof UIStateActions.openDeleteModal>;\n  showAddDataModal: () => void;\n};\n\nconst StyledDatasetTitle = styled.div<{showDatasetList?: boolean}>`\n  line-height: ${props => props.theme.sidePanelTitleLineHeight};\n  font-weight: 400;\n  letter-spacing: 1.25px;\n  color: ${props => props.theme.subtextColor};\n  font-size: 11px;\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  margin-bottom: ${props => (props.showDatasetList ? '16px' : '4px')};\n`;\n\nconst StyledDatasetSection = styled.div`\n  border-bottom: 1px solid ${props => props.theme.sidePanelBorderColor};\n`;\n\nexport function AddDataButtonFactory() {\n  const AddDataButton: React.FC<AddDataButtonProps> = React.memo(({onClick, isInactive}) => (\n    <Button\n      className=\"add-data-button\"\n      onClick={onClick}\n      inactive={!isInactive}\n      width=\"105px\"\n      secondary\n    >\n      <Add height=\"12px\" />\n      <FormattedMessage id={'layerManager.addData'} />\n    </Button>\n  ));\n  AddDataButton.displayName = 'AddDataButton';\n  return AddDataButton;\n}\n\nDatasetSectionFactory.deps = [SourceDataCatalogFactory, AddDataButtonFactory];\n\nfunction DatasetSectionFactory(\n  SourceDataCatalog: ReturnType<typeof SourceDataCatalogFactory>,\n  AddDataButton: ReturnType<typeof AddDataButtonFactory>\n) {\n  const DatasetSection: React.FC<DatasetSectionProps> = props => {\n    const {\n      datasets,\n      showDatasetTable,\n      updateTableColor,\n      showDeleteDataset,\n      removeDataset,\n      showDatasetList,\n      showAddDataModal\n    } = props;\n    const datasetCount = Object.keys(datasets).length;\n\n    return (\n      <StyledDatasetSection>\n        <StyledDatasetTitle showDatasetList={showDatasetList}>\n          <span>Datasets{datasetCount ? `(${datasetCount})` : ''}</span>\n          <AddDataButton onClick={showAddDataModal} isInactive={!datasetCount} />\n        </StyledDatasetTitle>\n        {showDatasetList && (\n          <SourceDataCatalog\n            datasets={datasets}\n            showDatasetTable={showDatasetTable}\n            updateTableColor={updateTableColor}\n            removeDataset={removeDataset}\n            showDeleteDataset={showDeleteDataset}\n          />\n        )}\n      </StyledDatasetSection>\n    );\n  };\n\n  return DatasetSection;\n}\n\nexport default DatasetSectionFactory;\n"],"mappings":"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","ignoreList":[]}
;