kepler.gl
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
126 lines (125 loc) • 20.8 kB
JavaScript
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
var _typeof = require("@babel/runtime/helpers/typeof");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports["default"] = exports.NumberFormatConfig = void 0;
var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
var _react = _interopRequireWildcard(require("react"));
var _styledComponents = _interopRequireDefault(require("styled-components"));
var _utils = require("@kepler.gl/utils");
var _constants = require("@kepler.gl/constants");
var _styledComponents2 = require("../../common/styled-components");
var _optionDropdown = require("./option-dropdown");
var _templateObject, _templateObject2, _templateObject3; // SPDX-License-Identifier: MIT
// Copyright contributors to the kepler.gl project
function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(e) { return e ? t : r; })(e); }
function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != _typeof(e) && "function" != typeof e) return { "default": e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && {}.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n["default"] = e, t && t.set(e, n), n; }
var StyledConfigPanel = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n background-color: ", ";\n box-shadow: 0 10px 18px 0 rgb(0 0 0 / 36%);\n flex-grow: 1;\n"])), function (props) {
return props.theme.headerCellBackground;
});
var StyledConfigPanelContent = _styledComponents["default"].div(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n padding: 20px;\n min-width: 230px;\n max-height: 400px;\n overflow: overlay;\n"])));
var StyledTableConfigGroup = _styledComponents["default"].div(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n margin-bottom: 10px;\n display: flex;\n align-items: center;\n\n input {\n cursor: pointer !important;\n width: 184px;\n height: 22px;\n }\n"])));
var NumberFormatConfig = exports.NumberFormatConfig = function NumberFormatConfig(_ref) {
var title = _ref.title,
id = _ref.id,
defaultFormat = _ref.defaultFormat,
options = _ref.options,
columns = _ref.columns,
setColumnDisplayFormat = _ref.setColumnDisplayFormat,
onClose = _ref.onClose;
var _useState = (0, _react.useState)(false),
_useState2 = (0, _slicedToArray2["default"])(_useState, 2),
showFormatter = _useState2[0],
setShowFormatter = _useState2[1];
var _useState3 = (0, _react.useState)(defaultFormat),
_useState4 = (0, _slicedToArray2["default"])(_useState3, 2),
format = _useState4[0],
setFormat = _useState4[1];
var onSetDisplayFormat = (0, _react.useCallback)(function (option) {
setFormat(option.label);
var formats = columns.reduce(function (prev, col) {
prev[col.name] = option.format;
return prev;
}, {});
setColumnDisplayFormat(formats);
onClose();
}, [columns, setColumnDisplayFormat, onClose]);
return /*#__PURE__*/_react["default"].createElement(StyledTableConfigGroup, null, /*#__PURE__*/_react["default"].createElement(_styledComponents2.InputLight, {
id: id,
type: "text",
value: title,
"data-tip": format,
readOnly: true,
onClick: function onClick() {
return setShowFormatter(true);
}
}), /*#__PURE__*/_react["default"].createElement(_optionDropdown.FormatterDropdown, {
left: -185,
top: 10,
isOpened: showFormatter,
displayFormat: format,
setDisplayFormat: onSetDisplayFormat,
onClose: function onClose() {
return setShowFormatter(false);
},
formatLabels: options
}));
};
function DataTableConfigFactory() {
var getColumnsByFieldType = function getColumnsByFieldType(columns, colMeta, fieldType) {
var result = [];
columns.forEach(function (colName) {
var _colMeta$colName;
if (((_colMeta$colName = colMeta[colName]) === null || _colMeta$colName === void 0 ? void 0 : _colMeta$colName.type) === fieldType) {
result.push(colMeta[colName]);
}
});
return result;
};
var DataTableConfig = function DataTableConfig(_ref2) {
var columns = _ref2.columns,
colMeta = _ref2.colMeta,
setColumnDisplayFormat = _ref2.setColumnDisplayFormat,
onClose = _ref2.onClose;
var formatConfigs = [{
title: '# Set Integer Number Format',
id: 'input-iteger-format',
displayType: _constants.ALL_FIELD_TYPES.integer
}, {
title: '# Set Float Number Format',
id: 'input-float-format',
displayType: _constants.ALL_FIELD_TYPES.real
}, {
title: '# Set Timestamp Format',
id: 'input-datetime-format',
displayType: _constants.ALL_FIELD_TYPES.timestamp
}, {
title: '# Set Date Format',
id: 'input-date-format',
displayType: _constants.ALL_FIELD_TYPES.date
}, {
title: '# Set Boolean Format',
id: 'input-bool-format',
displayType: _constants.ALL_FIELD_TYPES["boolean"]
}];
return /*#__PURE__*/_react["default"].createElement(StyledConfigPanel, null, /*#__PURE__*/_react["default"].createElement(StyledConfigPanelContent, null, formatConfigs.map(function (config, index) {
return /*#__PURE__*/_react["default"].createElement(NumberFormatConfig, {
title: "".concat(config.title),
key: index,
id: config.id,
defaultFormat: 'None',
colMeta: colMeta,
options: (0, _utils.getFieldFormatLabels)("".concat(config.displayType)),
columns: getColumnsByFieldType(columns, colMeta, "".concat(config.displayType)),
setColumnDisplayFormat: setColumnDisplayFormat,
onClose: onClose
});
})));
};
return DataTableConfig;
}
var _default = exports["default"] = DataTableConfigFactory;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_styledComponents","_interopRequireDefault","_utils","_constants","_styledComponents2","_optionDropdown","_templateObject","_templateObject2","_templateObject3","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","_typeof","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","StyledConfigPanel","styled","div","_taggedTemplateLiteral2","props","theme","headerCellBackground","StyledConfigPanelContent","StyledTableConfigGroup","NumberFormatConfig","exports","_ref","title","id","defaultFormat","options","columns","setColumnDisplayFormat","onClose","_useState","useState","_useState2","_slicedToArray2","showFormatter","setShowFormatter","_useState3","_useState4","format","setFormat","onSetDisplayFormat","useCallback","option","label","formats","reduce","prev","col","name","createElement","InputLight","type","value","readOnly","onClick","FormatterDropdown","left","top","isOpened","displayFormat","setDisplayFormat","formatLabels","DataTableConfigFactory","getColumnsByFieldType","colMeta","fieldType","result","forEach","colName","_colMeta$colName","push","DataTableConfig","_ref2","formatConfigs","displayType","ALL_FIELD_TYPES","integer","real","timestamp","date","map","config","index","concat","key","getFieldFormatLabels","_default"],"sources":["../../../src/common/data-table/display-format.tsx"],"sourcesContent":["// SPDX-License-Identifier: MIT\n// Copyright contributors to the kepler.gl project\n\nimport React, {useCallback, useState} from 'react';\nimport styled from 'styled-components';\n\nimport {getFieldFormatLabels} from '@kepler.gl/utils';\nimport {ALL_FIELD_TYPES, TooltipFormat} from '@kepler.gl/constants';\nimport {ColMeta, ColMetaProps} from '@kepler.gl/types';\n\nimport {InputLight} from '../../common/styled-components';\nimport {FormatterDropdown} from './option-dropdown';\n\nconst StyledConfigPanel = styled.div`\n  background-color: ${props => props.theme.headerCellBackground};\n  box-shadow: 0 10px 18px 0 rgb(0 0 0 / 36%);\n  flex-grow: 1;\n`;\nconst StyledConfigPanelContent = styled.div`\n  padding: 20px;\n  min-width: 230px;\n  max-height: 400px;\n  overflow: overlay;\n`;\n\nconst StyledTableConfigGroup = styled.div`\n  margin-bottom: 10px;\n  display: flex;\n  align-items: center;\n\n  input {\n    cursor: pointer !important;\n    width: 184px;\n    height: 22px;\n  }\n`;\n\nexport type DataTableConfigProps = {\n  title: string;\n  id: string;\n  defaultFormat: string;\n  options: TooltipFormat[];\n  columns: {name: string}[];\n  colMeta: ColMeta;\n  setColumnDisplayFormat: (formats: {[key: string]: string}) => void;\n  onClose: () => void;\n};\n\nexport const NumberFormatConfig: React.FC<DataTableConfigProps> = ({\n  title,\n  id,\n  defaultFormat,\n  options,\n  columns,\n  setColumnDisplayFormat,\n  onClose\n}: DataTableConfigProps) => {\n  const [showFormatter, setShowFormatter] = useState(false);\n  const [format, setFormat] = useState(defaultFormat);\n\n  const onSetDisplayFormat = useCallback(\n    (option: TooltipFormat) => {\n      setFormat(option.label);\n      const formats: {[key: string]: string} = columns.reduce((prev, col) => {\n        prev[col.name] = option.format;\n        return prev;\n      }, {});\n      setColumnDisplayFormat(formats);\n      onClose();\n    },\n    [columns, setColumnDisplayFormat, onClose]\n  );\n\n  return (\n    <StyledTableConfigGroup>\n      <InputLight\n        id={id}\n        type=\"text\"\n        value={title}\n        data-tip={format}\n        readOnly\n        onClick={() => setShowFormatter(true)}\n      />\n      <FormatterDropdown\n        left={-185}\n        top={10}\n        isOpened={showFormatter}\n        displayFormat={format}\n        setDisplayFormat={onSetDisplayFormat}\n        onClose={() => setShowFormatter(false)}\n        formatLabels={options}\n      />\n    </StyledTableConfigGroup>\n  );\n};\n\nfunction DataTableConfigFactory() {\n  const getColumnsByFieldType = (columns: string[], colMeta: ColMeta, fieldType: string) => {\n    const result: ColMetaProps[] = [];\n    columns.forEach(colName => {\n      if (colMeta[colName]?.type === fieldType) {\n        result.push(colMeta[colName]);\n      }\n    });\n    return result;\n  };\n\n  const DataTableConfig = ({columns, colMeta, setColumnDisplayFormat, onClose}) => {\n    const formatConfigs = [\n      {\n        title: '# Set Integer Number Format',\n        id: 'input-iteger-format',\n        displayType: ALL_FIELD_TYPES.integer\n      },\n      {\n        title: '# Set Float Number Format',\n        id: 'input-float-format',\n        displayType: ALL_FIELD_TYPES.real\n      },\n      {\n        title: '# Set Timestamp Format',\n        id: 'input-datetime-format',\n        displayType: ALL_FIELD_TYPES.timestamp\n      },\n      {\n        title: '# Set Date Format',\n        id: 'input-date-format',\n        displayType: ALL_FIELD_TYPES.date\n      },\n      {\n        title: '# Set Boolean Format',\n        id: 'input-bool-format',\n        displayType: ALL_FIELD_TYPES.boolean\n      }\n    ];\n\n    return (\n      <StyledConfigPanel>\n        <StyledConfigPanelContent>\n          {formatConfigs.map((config, index) => (\n            <NumberFormatConfig\n              title={`${config.title}`}\n              key={index}\n              id={config.id}\n              defaultFormat={'None'}\n              colMeta={colMeta}\n              options={getFieldFormatLabels(`${config.displayType}`)}\n              columns={getColumnsByFieldType(columns, colMeta, `${config.displayType}`)}\n              setColumnDisplayFormat={setColumnDisplayFormat}\n              onClose={onClose}\n            />\n          ))}\n        </StyledConfigPanelContent>\n      </StyledConfigPanel>\n    );\n  };\n  return DataTableConfig;\n}\n\nexport default DataTableConfigFactory;\n"],"mappings":"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","ignoreList":[]}
;