kepler.gl
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
216 lines (183 loc) • 20.4 kB
JavaScript
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.default = exports.ListItem = exports.classList = undefined;
var _classCallCheck2 = require('babel-runtime/helpers/classCallCheck');
var _classCallCheck3 = _interopRequireDefault(_classCallCheck2);
var _createClass2 = require('babel-runtime/helpers/createClass');
var _createClass3 = _interopRequireDefault(_createClass2);
var _possibleConstructorReturn2 = require('babel-runtime/helpers/possibleConstructorReturn');
var _possibleConstructorReturn3 = _interopRequireDefault(_possibleConstructorReturn2);
var _inherits2 = require('babel-runtime/helpers/inherits');
var _inherits3 = _interopRequireDefault(_inherits2);
var _taggedTemplateLiteral2 = require('babel-runtime/helpers/taggedTemplateLiteral');
var _taggedTemplateLiteral3 = _interopRequireDefault(_taggedTemplateLiteral2);
var _class, _temp;
var _templateObject = (0, _taggedTemplateLiteral3.default)(['\n background-color: ', ';\n border-top: 1px solid ', ';\n ', ';\n'], ['\n background-color: ', ';\n border-top: 1px solid ', ';\n ', ';\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 _propTypes = require('prop-types');
var _propTypes2 = _interopRequireDefault(_propTypes);
var _classnames = require('classnames');
var _classnames2 = _interopRequireDefault(_classnames);
var _styledComponents = require('styled-components');
var _styledComponents2 = _interopRequireDefault(_styledComponents);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
var classList = exports.classList = {
list: 'list-selector',
listHeader: 'list__header',
listSection: 'list__section',
listItem: 'list__item',
listItemAnchor: 'list__item__anchor'
};
var defaultDisplay = function defaultDisplay(d) {
return d;
};
var ListItem = exports.ListItem = function ListItem(_ref) {
var value = _ref.value,
_ref$displayOption = _ref.displayOption,
displayOption = _ref$displayOption === undefined ? defaultDisplay : _ref$displayOption;
return _react2.default.createElement(
'span',
{ className: classList.listItemAnchor },
displayOption(value)
);
};
var DropdownListWrapper = _styledComponents2.default.div(_templateObject, function (props) {
return props.theme.dropdownListBgd;
}, function (props) {
return props.theme.dropdownListBorderTop;
}, function (props) {
return props.theme.dropdownList;
});
var DropdownList = (_temp = _class = function (_Component) {
(0, _inherits3.default)(DropdownList, _Component);
function DropdownList() {
(0, _classCallCheck3.default)(this, DropdownList);
return (0, _possibleConstructorReturn3.default)(this, (DropdownList.__proto__ || Object.getPrototypeOf(DropdownList)).apply(this, arguments));
}
(0, _createClass3.default)(DropdownList, [{
key: '_onClick',
value: function _onClick(result, event) {
event.preventDefault();
this.props.onOptionSelected(result, event);
}
}, {
key: 'render',
value: function render() {
var _this2 = this;
var fixedOptions = this.props.fixedOptions;
var display = this.props.displayOption;
// Don't render if there are no options to display
if (!this.props.options.length && this.props.allowCustomValues <= 0) {
return false;
}
var valueOffset = Array.isArray(fixedOptions) ? fixedOptions.length : 0;
// For some reason onClick is not fired when clicked on an option
// onMouseDown is used here as a workaround of #205 and other
return _react2.default.createElement(
DropdownListWrapper,
{ className: classList.list },
this.props.customListHeaderComponent ? _react2.default.createElement(
'div',
{ className: classList.listHeader },
_react2.default.createElement(this.props.customListHeaderComponent, null)
) : null,
valueOffset > 0 ? _react2.default.createElement(
'div',
{ className: classList.listSection },
fixedOptions.map(function (value, i) {
return _react2.default.createElement(
'div',
{
className: (0, _classnames2.default)(classList.listItem, {
hover: _this2.props.selectionIndex === i,
fixed: true
}),
key: display(value) + '_' + i,
onMouseDown: function onMouseDown(e) {
return _this2._onClick(value, e);
},
onClick: function onClick(e) {
return _this2._onClick(value, e);
}
},
_react2.default.createElement(_this2.props.customListItemComponent, {
value: value,
displayOption: display
})
);
})
) : null,
this.props.options.map(function (value, i) {
return _react2.default.createElement(
'div',
{
className: (0, _classnames2.default)(classList.listItem, {
hover: _this2.props.selectionIndex === i + valueOffset
}),
key: display(value) + '_' + i,
onMouseDown: function onMouseDown(e) {
return _this2._onClick(value, e);
},
onClick: function onClick(e) {
return _this2._onClick(value, e);
}
},
_react2.default.createElement(_this2.props.customListItemComponent, {
value: value,
displayOption: display
})
);
})
);
}
}]);
return DropdownList;
}(_react.Component), _class.propTypes = {
options: _propTypes2.default.arrayOf(_propTypes2.default.any),
allowCustomValues: _propTypes2.default.number,
customClasses: _propTypes2.default.object,
customValues: _propTypes2.default.arrayOf(_propTypes2.default.any),
customListItemComponent: _propTypes2.default.oneOfType([_propTypes2.default.element, _propTypes2.default.func]),
customListHeaderComponent: _propTypes2.default.oneOfType([_propTypes2.default.element, _propTypes2.default.func]),
selectionIndex: _propTypes2.default.number,
onOptionSelected: _propTypes2.default.func,
displayOption: _propTypes2.default.func.isRequired,
defaultClassNames: _propTypes2.default.bool,
areResultsTruncated: _propTypes2.default.bool,
resultsTruncatedMessage: _propTypes2.default.string,
listItemComponent: _propTypes2.default.func
}, _class.defaultProps = {
customClasses: {},
customListItemComponent: ListItem,
customListHeaderComponent: null,
allowCustomValues: 0,
customValues: [],
displayOption: defaultDisplay,
onOptionSelected: function onOptionSelected() {},
defaultClassNames: true,
selectionIndex: null
}, _temp);
exports.default = DropdownList;
;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/common/item-selector/dropdown-list.js"],"names":["classList","list","listHeader","listSection","listItem","listItemAnchor","defaultDisplay","d","ListItem","value","displayOption","DropdownListWrapper","styled","div","props","theme","dropdownListBgd","dropdownListBorderTop","dropdownList","DropdownList","result","event","preventDefault","onOptionSelected","fixedOptions","display","options","length","allowCustomValues","valueOffset","Array","isArray","customListHeaderComponent","map","i","hover","selectionIndex","fixed","_onClick","e","Component","propTypes","PropTypes","arrayOf","any","number","customClasses","object","customValues","customListItemComponent","oneOfType","element","func","isRequired","defaultClassNames","bool","areResultsTruncated","resultsTruncatedMessage","string","listItemComponent","defaultProps"],"mappings":"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","file":"dropdown-list.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, {Component} from 'react';\nimport PropTypes from 'prop-types';\nimport classNames from 'classnames';\nimport styled from 'styled-components';\n\nexport const classList = {\n  list: 'list-selector',\n  listHeader: 'list__header',\n  listSection: 'list__section',\n  listItem: 'list__item',\n  listItemAnchor: 'list__item__anchor'\n};\n\nconst defaultDisplay = d => d;\nexport const ListItem = ({value, displayOption = defaultDisplay}) => (\n  <span className={classList.listItemAnchor}>{displayOption(value)}</span>\n);\n\nconst DropdownListWrapper = styled.div`\n  background-color: ${props => props.theme.dropdownListBgd};\n  border-top: 1px solid ${props => props.theme.dropdownListBorderTop};\n  ${props => props.theme.dropdownList};\n`;\n\nexport default class DropdownList extends Component {\n  static propTypes = {\n    options: PropTypes.arrayOf(PropTypes.any),\n    allowCustomValues: PropTypes.number,\n    customClasses: PropTypes.object,\n    customValues: PropTypes.arrayOf(PropTypes.any),\n    customListItemComponent: PropTypes.oneOfType([\n      PropTypes.element,\n      PropTypes.func\n    ]),\n    customListHeaderComponent: PropTypes.oneOfType([\n      PropTypes.element,\n      PropTypes.func\n    ]),\n    selectionIndex: PropTypes.number,\n    onOptionSelected: PropTypes.func,\n    displayOption: PropTypes.func.isRequired,\n    defaultClassNames: PropTypes.bool,\n    areResultsTruncated: PropTypes.bool,\n    resultsTruncatedMessage: PropTypes.string,\n    listItemComponent: PropTypes.func\n  };\n\n  static defaultProps = {\n    customClasses: {},\n    customListItemComponent: ListItem,\n    customListHeaderComponent: null,\n    allowCustomValues: 0,\n    customValues: [],\n    displayOption: defaultDisplay,\n    onOptionSelected: () => {},\n    defaultClassNames: true,\n    selectionIndex: null\n  };\n\n  _onClick(result, event) {\n    event.preventDefault();\n    this.props.onOptionSelected(result, event);\n  }\n\n  render() {\n    const {fixedOptions} = this.props;\n    const display = this.props.displayOption;\n\n    // Don't render if there are no options to display\n    if (!this.props.options.length && this.props.allowCustomValues <= 0) {\n      return false;\n    }\n\n    const valueOffset = Array.isArray(fixedOptions) ? fixedOptions.length : 0;\n\n    // For some reason onClick is not fired when clicked on an option\n    // onMouseDown is used here as a workaround of #205 and other\n    return (\n      <DropdownListWrapper className={classList.list}>\n        {this.props.customListHeaderComponent ? (\n          <div className={classList.listHeader}>\n            <this.props.customListHeaderComponent />\n          </div>\n        ) : null}\n\n        {valueOffset > 0 ? (\n          <div className={classList.listSection}>\n            {fixedOptions.map((value, i) => (\n              <div\n                className={classNames(classList.listItem, {\n                  hover: this.props.selectionIndex === i,\n                  fixed: true\n                })}\n                key={`${display(value)}_${i}`}\n                onMouseDown={e => this._onClick(value, e)}\n                onClick={e => this._onClick(value, e)}\n              >\n                <this.props.customListItemComponent\n                  value={value}\n                  displayOption={display}\n                />\n              </div>\n            ))}\n          </div>\n        ) : null}\n\n        {this.props.options.map((value, i) => (\n          <div\n            className={classNames(classList.listItem, {\n              hover: this.props.selectionIndex === i + valueOffset\n            })}\n            key={`${display(value)}_${i}`}\n            onMouseDown={e => this._onClick(value, e)}\n            onClick={e => this._onClick(value, e)}\n          >\n            <this.props.customListItemComponent\n              value={value}\n              displayOption={display}\n            />\n          </div>\n        ))}\n      </DropdownListWrapper>\n    );\n  }\n};\n"]}
;