kepler.gl
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
178 lines (147 loc) • 21.3 kB
JavaScript
;
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports["default"] = exports.ListItem = exports.classList = void 0;
var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));
var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits"));
var _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime/helpers/possibleConstructorReturn"));
var _getPrototypeOf2 = _interopRequireDefault(require("@babel/runtime/helpers/getPrototypeOf"));
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
var _react = _interopRequireWildcard(require("react"));
var _propTypes = _interopRequireDefault(require("prop-types"));
var _classnames = _interopRequireDefault(require("classnames"));
var _styledComponents = _interopRequireDefault(require("styled-components"));
var _templateObject;
function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = (0, _getPrototypeOf2["default"])(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = (0, _getPrototypeOf2["default"])(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return (0, _possibleConstructorReturn2["default"])(this, result); }; }
function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); return true; } catch (e) { return false; } }
var classList = {
list: 'list-selector',
listHeader: 'list__header',
listSection: 'list__section',
listItem: 'list__item',
listItemAnchor: 'list__item__anchor'
};
exports.classList = classList;
var defaultDisplay = function defaultDisplay(d) {
return d;
};
var ListItem = function ListItem(_ref) {
var value = _ref.value,
_ref$displayOption = _ref.displayOption,
displayOption = _ref$displayOption === void 0 ? defaultDisplay : _ref$displayOption;
return /*#__PURE__*/_react["default"].createElement("span", {
className: classList.listItemAnchor
}, displayOption(value));
};
exports.ListItem = ListItem;
var DropdownListWrapper = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n background-color: ", ";\n border-top: 1px solid\n ", ";\n ", ";\n"])), function (props) {
return props.light ? props.theme.dropdownListBgdLT : props.theme.dropdownListBgd;
}, function (props) {
return props.light ? props.theme.dropdownListBorderTopLT : props.theme.dropdownListBorderTop;
}, function (props) {
return props.light ? props.theme.dropdownListLT : props.theme.dropdownList;
});
var DropdownList = /*#__PURE__*/function (_Component) {
(0, _inherits2["default"])(DropdownList, _Component);
var _super = _createSuper(DropdownList);
function DropdownList() {
(0, _classCallCheck2["default"])(this, DropdownList);
return _super.apply(this, arguments);
}
(0, _createClass2["default"])(DropdownList, [{
key: "_onClick",
value: function _onClick(result, event) {
event.preventDefault();
this.props.onOptionSelected(result, event);
}
}, {
key: "render",
value: function render() {
var _this = this;
var _this$props = this.props,
fixedOptions = _this$props.fixedOptions,
light = _this$props.light;
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 /*#__PURE__*/_react["default"].createElement(DropdownListWrapper, {
className: classList.list,
light: light
}, this.props.customListHeaderComponent ? /*#__PURE__*/_react["default"].createElement("div", {
className: classList.listHeader
}, /*#__PURE__*/_react["default"].createElement(this.props.customListHeaderComponent, null)) : null, valueOffset > 0 ? /*#__PURE__*/_react["default"].createElement("div", {
className: classList.listSection
}, fixedOptions.map(function (value, i) {
return /*#__PURE__*/_react["default"].createElement("div", {
className: (0, _classnames["default"])(classList.listItem, {
hover: _this.props.selectionIndex === i,
fixed: true
}),
key: "".concat(display(value), "_").concat(i),
onMouseDown: function onMouseDown(e) {
return _this._onClick(value, e);
},
onClick: function onClick(e) {
return _this._onClick(value, e);
}
}, /*#__PURE__*/_react["default"].createElement(_this.props.customListItemComponent, {
value: value,
displayOption: display
}));
})) : null, this.props.options.map(function (value, i) {
return /*#__PURE__*/_react["default"].createElement("div", {
className: (0, _classnames["default"])(classList.listItem, {
hover: _this.props.selectionIndex === i + valueOffset
}),
key: "".concat(display(value), "_").concat(i),
onMouseDown: function onMouseDown(e) {
return _this._onClick(value, e);
},
onClick: function onClick(e) {
return _this._onClick(value, e);
}
}, /*#__PURE__*/_react["default"].createElement(_this.props.customListItemComponent, {
value: value,
displayOption: display
}));
}));
}
}]);
return DropdownList;
}(_react.Component);
exports["default"] = DropdownList;
(0, _defineProperty2["default"])(DropdownList, "propTypes", {
options: _propTypes["default"].arrayOf(_propTypes["default"].any),
allowCustomValues: _propTypes["default"].number,
customClasses: _propTypes["default"].object,
customValues: _propTypes["default"].arrayOf(_propTypes["default"].any),
customListItemComponent: _propTypes["default"].oneOfType([_propTypes["default"].element, _propTypes["default"].func]),
customListHeaderComponent: _propTypes["default"].oneOfType([_propTypes["default"].element, _propTypes["default"].func]),
selectionIndex: _propTypes["default"].number,
onOptionSelected: _propTypes["default"].func,
displayOption: _propTypes["default"].func.isRequired,
defaultClassNames: _propTypes["default"].bool,
areResultsTruncated: _propTypes["default"].bool,
resultsTruncatedMessage: _propTypes["default"].string,
listItemComponent: _propTypes["default"].func
});
(0, _defineProperty2["default"])(DropdownList, "defaultProps", {
customClasses: {},
customListItemComponent: ListItem,
customListHeaderComponent: null,
allowCustomValues: 0,
customValues: [],
displayOption: defaultDisplay,
onOptionSelected: function onOptionSelected() {},
defaultClassNames: true,
selectionIndex: null
});
//# 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","light","theme","dropdownListBgdLT","dropdownListBgd","dropdownListBorderTopLT","dropdownListBorderTop","dropdownListLT","dropdownList","DropdownList","result","event","preventDefault","onOptionSelected","fixedOptions","display","options","length","allowCustomValues","valueOffset","Array","isArray","customListHeaderComponent","map","i","hover","selectionIndex","fixed","e","_onClick","Component","PropTypes","arrayOf","any","number","customClasses","object","customValues","customListItemComponent","oneOfType","element","func","isRequired","defaultClassNames","bool","areResultsTruncated","resultsTruncatedMessage","string","listItemComponent"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;AAoBA;;AACA;;AACA;;AACA;;;;;;;;AAEO,IAAMA,SAAS,GAAG;AACvBC,EAAAA,IAAI,EAAE,eADiB;AAEvBC,EAAAA,UAAU,EAAE,cAFW;AAGvBC,EAAAA,WAAW,EAAE,eAHU;AAIvBC,EAAAA,QAAQ,EAAE,YAJa;AAKvBC,EAAAA,cAAc,EAAE;AALO,CAAlB;;;AAQP,IAAMC,cAAc,GAAG,SAAjBA,cAAiB,CAAAC,CAAC;AAAA,SAAIA,CAAJ;AAAA,CAAxB;;AACO,IAAMC,QAAQ,GAAG,SAAXA,QAAW;AAAA,MAAEC,KAAF,QAAEA,KAAF;AAAA,gCAASC,aAAT;AAAA,MAASA,aAAT,mCAAyBJ,cAAzB;AAAA,sBACtB;AAAM,IAAA,SAAS,EAAEN,SAAS,CAACK;AAA3B,KAA4CK,aAAa,CAACD,KAAD,CAAzD,CADsB;AAAA,CAAjB;;;;AAIP,IAAME,mBAAmB,GAAGC,6BAAOC,GAAV,iKACH,UAAAC,KAAK;AAAA,SACvBA,KAAK,CAACC,KAAN,GAAcD,KAAK,CAACE,KAAN,CAAYC,iBAA1B,GAA8CH,KAAK,CAACE,KAAN,CAAYE,eADnC;AAAA,CADF,EAInB,UAAAJ,KAAK;AAAA,SACLA,KAAK,CAACC,KAAN,GAAcD,KAAK,CAACE,KAAN,CAAYG,uBAA1B,GAAoDL,KAAK,CAACE,KAAN,CAAYI,qBAD3D;AAAA,CAJc,EAMrB,UAAAN,KAAK;AAAA,SAAKA,KAAK,CAACC,KAAN,GAAcD,KAAK,CAACE,KAAN,CAAYK,cAA1B,GAA2CP,KAAK,CAACE,KAAN,CAAYM,YAA5D;AAAA,CANgB,CAAzB;;IASqBC,Y;;;;;;;;;;;;WA6BnB,kBAASC,MAAT,EAAiBC,KAAjB,EAAwB;AACtBA,MAAAA,KAAK,CAACC,cAAN;AACA,WAAKZ,KAAL,CAAWa,gBAAX,CAA4BH,MAA5B,EAAoCC,KAApC;AACD;;;WAED,kBAAS;AAAA;;AAAA,wBACuB,KAAKX,KAD5B;AAAA,UACAc,YADA,eACAA,YADA;AAAA,UACcb,KADd,eACcA,KADd;AAEP,UAAMc,OAAO,GAAG,KAAKf,KAAL,CAAWJ,aAA3B,CAFO,CAIP;;AACA,UAAI,CAAC,KAAKI,KAAL,CAAWgB,OAAX,CAAmBC,MAApB,IAA8B,KAAKjB,KAAL,CAAWkB,iBAAX,IAAgC,CAAlE,EAAqE;AACnE,eAAO,KAAP;AACD;;AAED,UAAMC,WAAW,GAAGC,KAAK,CAACC,OAAN,CAAcP,YAAd,IAA8BA,YAAY,CAACG,MAA3C,GAAoD,CAAxE,CATO,CAWP;AACA;;AACA,0BACE,gCAAC,mBAAD;AAAqB,QAAA,SAAS,EAAE/B,SAAS,CAACC,IAA1C;AAAgD,QAAA,KAAK,EAAEc;AAAvD,SACG,KAAKD,KAAL,CAAWsB,yBAAX,gBACC;AAAK,QAAA,SAAS,EAAEpC,SAAS,CAACE;AAA1B,sBACE,qCAAM,KAAN,CAAY,yBAAZ,OADF,CADD,GAIG,IALN,EAOG+B,WAAW,GAAG,CAAd,gBACC;AAAK,QAAA,SAAS,EAAEjC,SAAS,CAACG;AAA1B,SACGyB,YAAY,CAACS,GAAb,CAAiB,UAAC5B,KAAD,EAAQ6B,CAAR;AAAA,4BAChB;AACE,UAAA,SAAS,EAAE,4BAAWtC,SAAS,CAACI,QAArB,EAA+B;AACxCmC,YAAAA,KAAK,EAAE,KAAI,CAACzB,KAAL,CAAW0B,cAAX,KAA8BF,CADG;AAExCG,YAAAA,KAAK,EAAE;AAFiC,WAA/B,CADb;AAKE,UAAA,GAAG,YAAKZ,OAAO,CAACpB,KAAD,CAAZ,cAAuB6B,CAAvB,CALL;AAME,UAAA,WAAW,EAAE,qBAAAI,CAAC;AAAA,mBAAI,KAAI,CAACC,QAAL,CAAclC,KAAd,EAAqBiC,CAArB,CAAJ;AAAA,WANhB;AAOE,UAAA,OAAO,EAAE,iBAAAA,CAAC;AAAA,mBAAI,KAAI,CAACC,QAAL,CAAclC,KAAd,EAAqBiC,CAArB,CAAJ;AAAA;AAPZ,wBASE,gCAAC,KAAD,CAAM,KAAN,CAAY,uBAAZ;AAAoC,UAAA,KAAK,EAAEjC,KAA3C;AAAkD,UAAA,aAAa,EAAEoB;AAAjE,UATF,CADgB;AAAA,OAAjB,CADH,CADD,GAgBG,IAvBN,EAyBG,KAAKf,KAAL,CAAWgB,OAAX,CAAmBO,GAAnB,CAAuB,UAAC5B,KAAD,EAAQ6B,CAAR;AAAA,4BACtB;AACE,UAAA,SAAS,EAAE,4BAAWtC,SAAS,CAACI,QAArB,EAA+B;AACxCmC,YAAAA,KAAK,EAAE,KAAI,CAACzB,KAAL,CAAW0B,cAAX,KAA8BF,CAAC,GAAGL;AADD,WAA/B,CADb;AAIE,UAAA,GAAG,YAAKJ,OAAO,CAACpB,KAAD,CAAZ,cAAuB6B,CAAvB,CAJL;AAKE,UAAA,WAAW,EAAE,qBAAAI,CAAC;AAAA,mBAAI,KAAI,CAACC,QAAL,CAAclC,KAAd,EAAqBiC,CAArB,CAAJ;AAAA,WALhB;AAME,UAAA,OAAO,EAAE,iBAAAA,CAAC;AAAA,mBAAI,KAAI,CAACC,QAAL,CAAclC,KAAd,EAAqBiC,CAArB,CAAJ;AAAA;AANZ,wBAQE,gCAAC,KAAD,CAAM,KAAN,CAAY,uBAAZ;AAAoC,UAAA,KAAK,EAAEjC,KAA3C;AAAkD,UAAA,aAAa,EAAEoB;AAAjE,UARF,CADsB;AAAA,OAAvB,CAzBH,CADF;AAwCD;;;EAvFuCe,gB;;;iCAArBrB,Y,eACA;AACjBO,EAAAA,OAAO,EAAEe,sBAAUC,OAAV,CAAkBD,sBAAUE,GAA5B,CADQ;AAEjBf,EAAAA,iBAAiB,EAAEa,sBAAUG,MAFZ;AAGjBC,EAAAA,aAAa,EAAEJ,sBAAUK,MAHR;AAIjBC,EAAAA,YAAY,EAAEN,sBAAUC,OAAV,CAAkBD,sBAAUE,GAA5B,CAJG;AAKjBK,EAAAA,uBAAuB,EAAEP,sBAAUQ,SAAV,CAAoB,CAACR,sBAAUS,OAAX,EAAoBT,sBAAUU,IAA9B,CAApB,CALR;AAMjBnB,EAAAA,yBAAyB,EAAES,sBAAUQ,SAAV,CAAoB,CAACR,sBAAUS,OAAX,EAAoBT,sBAAUU,IAA9B,CAApB,CANV;AAOjBf,EAAAA,cAAc,EAAEK,sBAAUG,MAPT;AAQjBrB,EAAAA,gBAAgB,EAAEkB,sBAAUU,IARX;AASjB7C,EAAAA,aAAa,EAAEmC,sBAAUU,IAAV,CAAeC,UATb;AAUjBC,EAAAA,iBAAiB,EAAEZ,sBAAUa,IAVZ;AAWjBC,EAAAA,mBAAmB,EAAEd,sBAAUa,IAXd;AAYjBE,EAAAA,uBAAuB,EAAEf,sBAAUgB,MAZlB;AAajBC,EAAAA,iBAAiB,EAAEjB,sBAAUU;AAbZ,C;iCADAhC,Y,kBAiBG;AACpB0B,EAAAA,aAAa,EAAE,EADK;AAEpBG,EAAAA,uBAAuB,EAAE5C,QAFL;AAGpB4B,EAAAA,yBAAyB,EAAE,IAHP;AAIpBJ,EAAAA,iBAAiB,EAAE,CAJC;AAKpBmB,EAAAA,YAAY,EAAE,EALM;AAMpBzC,EAAAA,aAAa,EAAEJ,cANK;AAOpBqB,EAAAA,gBAAgB,EAAE,4BAAM,CAAE,CAPN;AAQpB8B,EAAAA,iBAAiB,EAAE,IARC;AASpBjB,EAAAA,cAAc,EAAE;AATI,C","sourcesContent":["// Copyright (c) 2021 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 =>\n    props.light ? props.theme.dropdownListBgdLT : props.theme.dropdownListBgd};\n  border-top: 1px solid\n    ${props =>\n      props.light ? props.theme.dropdownListBorderTopLT : props.theme.dropdownListBorderTop};\n  ${props => (props.light ? props.theme.dropdownListLT : 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([PropTypes.element, PropTypes.func]),\n    customListHeaderComponent: PropTypes.oneOfType([PropTypes.element, PropTypes.func]),\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, light} = 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} light={light}>\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 value={value} displayOption={display} />\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 value={value} displayOption={display} />\n          </div>\n        ))}\n      </DropdownListWrapper>\n    );\n  }\n}\n"]}