UNPKG

kepler.gl

Version:

kepler.gl is a webgl based application to visualize large scale location data in the browser

84 lines (83 loc) 16.6 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); Object.defineProperty(exports, "__esModule", { value: true }); exports["default"] = exports.StyledDropdownSelect = exports.DropdownSelectValue = void 0; var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral")); var _react = _interopRequireDefault(require("react")); var _styledComponents = _interopRequireDefault(require("styled-components")); var _commonUtils = require("@kepler.gl/common-utils"); var _localization = require("@kepler.gl/localization"); var _icons = require("../icons"); var _dropdownList = require("./dropdown-list"); var _styledComponents2 = require("../styled-components"); var _templateObject, _templateObject2, _templateObject3; // SPDX-License-Identifier: MIT // Copyright contributors to the kepler.gl project var StyledDropdownSelect = exports.StyledDropdownSelect = _styledComponents["default"].div.withConfig({ shouldForwardProp: _styledComponents2.shouldForwardProp }).attrs({ className: 'item-selector__dropdown' })(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n ", ";\n\n height: ", ";\n\n .list__item__anchor {\n ", ";\n }\n"])), function (props) { return props.inputTheme === 'secondary' ? props.theme.secondaryInput : props.inputTheme === 'light' ? props.theme.inputLT : props.theme.input; }, function (props) { return props.size === 'small' ? props.theme.inputBoxHeightSmall : props.theme.inputBoxHeight; }, function (props) { return props.theme.dropdownListAnchor; }); var DropdownSelectValue = exports.DropdownSelectValue = _styledComponents["default"].span.withConfig({ shouldForwardProp: _styledComponents2.shouldForwardProp })(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n color: ", ";\n overflow: hidden;\n text-overflow: ellipsis;\n white-space: nowrap;\n\n .list__item {\n ", ";\n }\n\n .list__item__anchor {\n ", ";\n }\n"])), function (props) { return props.hasPlaceholder && props.inputTheme === 'light' ? props.theme.selectColorPlaceHolderLT : props.hasPlaceholder ? props.theme.selectColorPlaceHolder : props.inputTheme === 'light' ? props.theme.selectColorLT : props.theme.selectColor; }, function (props) { return props.inputTheme === 'light' ? props.theme.dropdownListItemLT : props.theme.dropdownListItem; }, function (props) { return props.inputTheme === 'light' ? props.theme.dropdownListAnchorLT : props.theme.dropdownListAnchor; }); var DropdownSelectActionRight = _styledComponents["default"].div(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n margin-right: 2px;\n display: flex;\n color: ", ";\n\n &:hover {\n color: ", ";\n }\n"])), function (props) { return props.theme.subtextColor; }, function (props) { return props.theme.textColor; }); function DropdownSelect(_ref) { var className = _ref.className, displayOption = _ref.displayOption, disabled = _ref.disabled, onClick = _ref.onClick, inputTheme = _ref.inputTheme, size = _ref.size, value = _ref.value, placeholder = _ref.placeholder, erasable = _ref.erasable, showArrow = _ref.showArrow, onErase = _ref.onErase, showDropdown = _ref.showDropdown, _ref$DropDownLineItem = _ref.DropDownLineItemRenderComponent, DropDownLineItemRenderComponent = _ref$DropDownLineItem === void 0 ? _dropdownList.ListItem : _ref$DropDownLineItem; var hasValue = (0, _commonUtils.notNullorUndefined)(value); return /*#__PURE__*/_react["default"].createElement(StyledDropdownSelect, { className: className, onClick: onClick, inputTheme: inputTheme, size: size }, /*#__PURE__*/_react["default"].createElement(DropdownSelectValue, { hasPlaceholder: !hasValue, inputTheme: inputTheme, className: "item-selector__dropdown__value" }, hasValue ? /*#__PURE__*/_react["default"].createElement(DropDownLineItemRenderComponent, { displayOption: displayOption, value: value, disabled: Boolean(disabled), light: inputTheme === 'light' }) : /*#__PURE__*/_react["default"].createElement(_localization.FormattedMessage, { id: placeholder || 'placeholder.selectValue' })), erasable && hasValue ? /*#__PURE__*/_react["default"].createElement(DropdownSelectActionRight, null, /*#__PURE__*/_react["default"].createElement(_icons.Delete, { height: "16px", onClick: onErase })) : showArrow ? /*#__PURE__*/_react["default"].createElement(DropdownSelectActionRight, null, /*#__PURE__*/_react["default"].createElement(_icons.ArrowDown, { height: "14px", onClick: showDropdown })) : null); } var _default = exports["default"] = DropdownSelect; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireDefault","require","_styledComponents","_commonUtils","_localization","_icons","_dropdownList","_styledComponents2","_templateObject","_templateObject2","_templateObject3","StyledDropdownSelect","exports","styled","div","withConfig","shouldForwardProp","attrs","className","_taggedTemplateLiteral2","props","inputTheme","theme","secondaryInput","inputLT","input","size","inputBoxHeightSmall","inputBoxHeight","dropdownListAnchor","DropdownSelectValue","span","hasPlaceholder","selectColorPlaceHolderLT","selectColorPlaceHolder","selectColorLT","selectColor","dropdownListItemLT","dropdownListItem","dropdownListAnchorLT","DropdownSelectActionRight","subtextColor","textColor","DropdownSelect","_ref","displayOption","disabled","onClick","value","placeholder","erasable","showArrow","onErase","showDropdown","_ref$DropDownLineItem","DropDownLineItemRenderComponent","ListItem","hasValue","notNullorUndefined","createElement","Boolean","light","FormattedMessage","id","Delete","height","ArrowDown","_default"],"sources":["../../../src/common/item-selector/dropdown-select.tsx"],"sourcesContent":["// SPDX-License-Identifier: MIT\n// Copyright contributors to the kepler.gl project\n\nimport React, {ComponentType} from 'react';\nimport styled from 'styled-components';\n\nimport {notNullorUndefined} from '@kepler.gl/common-utils';\nimport {FormattedMessage} from '@kepler.gl/localization';\n\nimport {ArrowDown, Delete} from '../icons';\nimport {ListItem} from './dropdown-list';\nimport {shouldForwardProp} from '../styled-components';\n\nexport type ListItemProps<Option> = {\n  value: Option;\n  displayOption: (opt: Option) => string;\n  light: boolean;\n  disabled: boolean;\n};\n\nexport type DropdownSelectProps<Option> = {\n  className?: string;\n  displayOption?: string | ((opt: Option) => string);\n  disabled?: boolean;\n  onClick: (e: React.MouseEvent) => void;\n  inputTheme?: string;\n  error?: boolean;\n  size?: string;\n  value: Option;\n  placeholder?: string;\n  erasable?: boolean;\n  showArrow?: boolean;\n  onErase?: (e: React.MouseEvent) => void;\n  showDropdown: (e: React.MouseEvent) => void;\n  DropDownLineItemRenderComponent?: ComponentType<ListItemProps<Option>>;\n};\n\nexport const StyledDropdownSelect = styled.div\n  .withConfig({shouldForwardProp})\n  .attrs<{className?: string}>({\n    className: 'item-selector__dropdown'\n  })<{\n  size: DropdownSelectProps<any>['size'];\n  inputTheme: DropdownSelectProps<any>['inputTheme'];\n}>`\n  ${props =>\n    props.inputTheme === 'secondary'\n      ? props.theme.secondaryInput\n      : props.inputTheme === 'light'\n      ? props.theme.inputLT\n      : props.theme.input};\n\n  height: ${props =>\n    props.size === 'small' ? props.theme.inputBoxHeightSmall : props.theme.inputBoxHeight};\n\n  .list__item__anchor {\n    ${props => props.theme.dropdownListAnchor};\n  }\n`;\n\nexport const DropdownSelectValue = styled.span.withConfig({shouldForwardProp})<{\n  inputTheme: DropdownSelectProps<any>['inputTheme'];\n  hasPlaceholder: boolean;\n}>`\n  color: ${props =>\n    props.hasPlaceholder && props.inputTheme === 'light'\n      ? props.theme.selectColorPlaceHolderLT\n      : props.hasPlaceholder\n      ? props.theme.selectColorPlaceHolder\n      : props.inputTheme === 'light'\n      ? props.theme.selectColorLT\n      : props.theme.selectColor};\n  overflow: hidden;\n  text-overflow: ellipsis;\n  white-space: nowrap;\n\n  .list__item {\n    ${props =>\n      props.inputTheme === 'light' ? props.theme.dropdownListItemLT : props.theme.dropdownListItem};\n  }\n\n  .list__item__anchor {\n    ${props =>\n      props.inputTheme === 'light'\n        ? props.theme.dropdownListAnchorLT\n        : props.theme.dropdownListAnchor};\n  }\n`;\n\nconst DropdownSelectActionRight = styled.div`\n  margin-right: 2px;\n  display: flex;\n  color: ${props => props.theme.subtextColor};\n\n  &:hover {\n    color: ${props => props.theme.textColor};\n  }\n`;\n\nfunction DropdownSelect<Option>({\n  // dropdownSelectProps,\n  className,\n  displayOption,\n  disabled,\n  onClick,\n  inputTheme,\n  size,\n  value,\n  placeholder,\n  erasable,\n  showArrow,\n  onErase,\n  showDropdown,\n  DropDownLineItemRenderComponent = ListItem\n}: DropdownSelectProps<Option>): JSX.Element {\n  const hasValue = notNullorUndefined(value);\n\n  return (\n    <StyledDropdownSelect\n      className={className}\n      onClick={onClick}\n      inputTheme={inputTheme}\n      size={size}\n    >\n      <DropdownSelectValue\n        hasPlaceholder={!hasValue}\n        inputTheme={inputTheme}\n        className=\"item-selector__dropdown__value\"\n      >\n        {hasValue ? (\n          <DropDownLineItemRenderComponent\n            displayOption={displayOption as ListItemProps<any>['displayOption']}\n            value={value}\n            disabled={Boolean(disabled)}\n            light={inputTheme === 'light'}\n          />\n        ) : (\n          <FormattedMessage id={placeholder || 'placeholder.selectValue'} />\n        )}\n      </DropdownSelectValue>\n      {erasable && hasValue ? (\n        <DropdownSelectActionRight>\n          <Delete height=\"16px\" onClick={onErase} />\n        </DropdownSelectActionRight>\n      ) : showArrow ? (\n        <DropdownSelectActionRight>\n          <ArrowDown height=\"14px\" onClick={showDropdown} />\n        </DropdownSelectActionRight>\n      ) : null}\n    </StyledDropdownSelect>\n  );\n}\n\nexport default DropdownSelect;\n"],"mappings":";;;;;;;;AAGA,IAAAA,MAAA,GAAAC,sBAAA,CAAAC,OAAA;AACA,IAAAC,iBAAA,GAAAF,sBAAA,CAAAC,OAAA;AAEA,IAAAE,YAAA,GAAAF,OAAA;AACA,IAAAG,aAAA,GAAAH,OAAA;AAEA,IAAAI,MAAA,GAAAJ,OAAA;AACA,IAAAK,aAAA,GAAAL,OAAA;AACA,IAAAM,kBAAA,GAAAN,OAAA;AAAuD,IAAAO,eAAA,EAAAC,gBAAA,EAAAC,gBAAA,EAXvD;AACA;AAoCO,IAAMC,oBAAoB,GAAAC,OAAA,CAAAD,oBAAA,GAAGE,4BAAM,CAACC,GAAG,CAC3CC,UAAU,CAAC;EAACC,iBAAiB,EAAjBA;AAAiB,CAAC,CAAC,CAC/BC,KAAK,CAAuB;EAC3BC,SAAS,EAAE;AACb,CAAC,CAAC,CAAAV,eAAA,KAAAA,eAAA,OAAAW,uBAAA,8FAIA,UAAAC,KAAK;EAAA,OACLA,KAAK,CAACC,UAAU,KAAK,WAAW,GAC5BD,KAAK,CAACE,KAAK,CAACC,cAAc,GAC1BH,KAAK,CAACC,UAAU,KAAK,OAAO,GAC5BD,KAAK,CAACE,KAAK,CAACE,OAAO,GACnBJ,KAAK,CAACE,KAAK,CAACG,KAAK;AAAA,GAEb,UAAAL,KAAK;EAAA,OACbA,KAAK,CAACM,IAAI,KAAK,OAAO,GAAGN,KAAK,CAACE,KAAK,CAACK,mBAAmB,GAAGP,KAAK,CAACE,KAAK,CAACM,cAAc;AAAA,GAGnF,UAAAR,KAAK;EAAA,OAAIA,KAAK,CAACE,KAAK,CAACO,kBAAkB;AAAA,EAE5C;AAEM,IAAMC,mBAAmB,GAAAlB,OAAA,CAAAkB,mBAAA,GAAGjB,4BAAM,CAACkB,IAAI,CAAChB,UAAU,CAAC;EAACC,iBAAiB,EAAjBA;AAAiB,CAAC,CAAC,CAAAP,gBAAA,KAAAA,gBAAA,OAAAU,uBAAA,8LAInE,UAAAC,KAAK;EAAA,OACZA,KAAK,CAACY,cAAc,IAAIZ,KAAK,CAACC,UAAU,KAAK,OAAO,GAChDD,KAAK,CAACE,KAAK,CAACW,wBAAwB,GACpCb,KAAK,CAACY,cAAc,GACpBZ,KAAK,CAACE,KAAK,CAACY,sBAAsB,GAClCd,KAAK,CAACC,UAAU,KAAK,OAAO,GAC5BD,KAAK,CAACE,KAAK,CAACa,aAAa,GACzBf,KAAK,CAACE,KAAK,CAACc,WAAW;AAAA,GAMzB,UAAAhB,KAAK;EAAA,OACLA,KAAK,CAACC,UAAU,KAAK,OAAO,GAAGD,KAAK,CAACE,KAAK,CAACe,kBAAkB,GAAGjB,KAAK,CAACE,KAAK,CAACgB,gBAAgB;AAAA,GAI5F,UAAAlB,KAAK;EAAA,OACLA,KAAK,CAACC,UAAU,KAAK,OAAO,GACxBD,KAAK,CAACE,KAAK,CAACiB,oBAAoB,GAChCnB,KAAK,CAACE,KAAK,CAACO,kBAAkB;AAAA,EAEvC;AAED,IAAMW,yBAAyB,GAAG3B,4BAAM,CAACC,GAAG,CAAAJ,gBAAA,KAAAA,gBAAA,OAAAS,uBAAA,qHAGjC,UAAAC,KAAK;EAAA,OAAIA,KAAK,CAACE,KAAK,CAACmB,YAAY;AAAA,GAG/B,UAAArB,KAAK;EAAA,OAAIA,KAAK,CAACE,KAAK,CAACoB,SAAS;AAAA,EAE1C;AAED,SAASC,cAAcA,CAAAC,IAAA,EAesB;EAAA,IAb3C1B,SAAS,GAAA0B,IAAA,CAAT1B,SAAS;IACT2B,aAAa,GAAAD,IAAA,CAAbC,aAAa;IACbC,QAAQ,GAAAF,IAAA,CAARE,QAAQ;IACRC,OAAO,GAAAH,IAAA,CAAPG,OAAO;IACP1B,UAAU,GAAAuB,IAAA,CAAVvB,UAAU;IACVK,IAAI,GAAAkB,IAAA,CAAJlB,IAAI;IACJsB,KAAK,GAAAJ,IAAA,CAALI,KAAK;IACLC,WAAW,GAAAL,IAAA,CAAXK,WAAW;IACXC,QAAQ,GAAAN,IAAA,CAARM,QAAQ;IACRC,SAAS,GAAAP,IAAA,CAATO,SAAS;IACTC,OAAO,GAAAR,IAAA,CAAPQ,OAAO;IACPC,YAAY,GAAAT,IAAA,CAAZS,YAAY;IAAAC,qBAAA,GAAAV,IAAA,CACZW,+BAA+B;IAA/BA,+BAA+B,GAAAD,qBAAA,cAAGE,sBAAQ,GAAAF,qBAAA;EAE1C,IAAMG,QAAQ,GAAG,IAAAC,+BAAkB,EAACV,KAAK,CAAC;EAE1C,oBACEjD,MAAA,YAAA4D,aAAA,CAAChD,oBAAoB;IACnBO,SAAS,EAAEA,SAAU;IACrB6B,OAAO,EAAEA,OAAQ;IACjB1B,UAAU,EAAEA,UAAW;IACvBK,IAAI,EAAEA;EAAK,gBAEX3B,MAAA,YAAA4D,aAAA,CAAC7B,mBAAmB;IAClBE,cAAc,EAAE,CAACyB,QAAS;IAC1BpC,UAAU,EAAEA,UAAW;IACvBH,SAAS,EAAC;EAAgC,GAEzCuC,QAAQ,gBACP1D,MAAA,YAAA4D,aAAA,CAACJ,+BAA+B;IAC9BV,aAAa,EAAEA,aAAqD;IACpEG,KAAK,EAAEA,KAAM;IACbF,QAAQ,EAAEc,OAAO,CAACd,QAAQ,CAAE;IAC5Be,KAAK,EAAExC,UAAU,KAAK;EAAQ,CAC/B,CAAC,gBAEFtB,MAAA,YAAA4D,aAAA,CAACvD,aAAA,CAAA0D,gBAAgB;IAACC,EAAE,EAAEd,WAAW,IAAI;EAA0B,CAAE,CAEhD,CAAC,EACrBC,QAAQ,IAAIO,QAAQ,gBACnB1D,MAAA,YAAA4D,aAAA,CAACnB,yBAAyB,qBACxBzC,MAAA,YAAA4D,aAAA,CAACtD,MAAA,CAAA2D,MAAM;IAACC,MAAM,EAAC,MAAM;IAAClB,OAAO,EAAEK;EAAQ,CAAE,CAChB,CAAC,GAC1BD,SAAS,gBACXpD,MAAA,YAAA4D,aAAA,CAACnB,yBAAyB,qBACxBzC,MAAA,YAAA4D,aAAA,CAACtD,MAAA,CAAA6D,SAAS;IAACD,MAAM,EAAC,MAAM;IAAClB,OAAO,EAAEM;EAAa,CAAE,CACxB,CAAC,GAC1B,IACgB,CAAC;AAE3B;AAAC,IAAAc,QAAA,GAAAvD,OAAA,cAEc+B,cAAc","ignoreList":[]}