UNPKG

kepler.gl

Version:

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

176 lines (134 loc) 14.6 kB
'use strict'; Object.defineProperty(exports, "__esModule", { value: true }); exports.default = undefined; var _extends2 = require('babel-runtime/helpers/extends'); var _extends3 = _interopRequireDefault(_extends2); 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, _temp2, _initialiseProps; var _templateObject = (0, _taggedTemplateLiteral3.default)(['\n ', ';\n'], ['\n ', ';\n']), _templateObject2 = (0, _taggedTemplateLiteral3.default)(['\n ', '\n'], ['\n ', '\n']), _templateObject3 = (0, _taggedTemplateLiteral3.default)(['\n position: absolute;\n display: none;\n'], ['\n position: absolute;\n display: none;\n']), _templateObject4 = (0, _taggedTemplateLiteral3.default)(['\n line-height: 0;\n height: ', ';\n margin-left: ', 'px;\n'], ['\n line-height: 0;\n height: ', ';\n margin-left: ', 'px;\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 _styledComponents = require('styled-components'); var _styledComponents2 = _interopRequireDefault(_styledComponents); var _lodash = require('lodash.pick'); var _lodash2 = _interopRequireDefault(_lodash); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } function noop() {} var StyledSwitchInput = _styledComponents2.default.label(_templateObject, function (props) { return props.secondary ? props.theme.secondarySwitch : props.theme.inputSwitch; }); var StyledCheckboxInput = _styledComponents2.default.label(_templateObject2, function (props) { return props.theme.inputCheckbox; }); var HiddenInput = _styledComponents2.default.input(_templateObject3); var StyledCheckbox = _styledComponents2.default.div(_templateObject4, function (props) { return props.theme.switchBtnHeight; }, function (props) { return props.theme.switchLabelMargin; }); var Checkbox = (_temp2 = _class = function (_Component) { (0, _inherits3.default)(Checkbox, _Component); function Checkbox() { var _ref; var _temp, _this, _ret; (0, _classCallCheck3.default)(this, Checkbox); for (var _len = arguments.length, args = Array(_len), _key = 0; _key < _len; _key++) { args[_key] = arguments[_key]; } return _ret = (_temp = (_this = (0, _possibleConstructorReturn3.default)(this, (_ref = Checkbox.__proto__ || Object.getPrototypeOf(Checkbox)).call.apply(_ref, [this].concat(args))), _this), _initialiseProps.call(_this), _temp), (0, _possibleConstructorReturn3.default)(_this, _ret); } (0, _createClass3.default)(Checkbox, [{ key: 'render', value: function render() { var inputProps = (0, _extends3.default)({}, (0, _lodash2.default)(this.props, ['checked', 'disabled', 'id', 'onChange', 'value']), { type: 'checkbox', onFocus: this.handleFocus, onBlur: this.handleBlur }); var labelProps = (0, _extends3.default)({}, (0, _lodash2.default)(this.props, ['checked', 'disabled', 'secondary']), { htmlFor: this.props.id }); var LabelElement = this.props.type === 'checkbox' ? StyledCheckboxInput : StyledSwitchInput; return _react2.default.createElement( StyledCheckbox, { className: 'kg-checkbox' }, _react2.default.createElement(HiddenInput, inputProps), _react2.default.createElement( LabelElement, (0, _extends3.default)({ className: 'kg-checkbox__label' }, labelProps), this.props.label ) ); } }]); return Checkbox; }(_react.Component), _class.propTypes = { id: _propTypes2.default.string.isRequired, label: _propTypes2.default.node, value: _propTypes2.default.oneOf([true, false, 'indeterminate']), checked: _propTypes2.default.bool, disabled: _propTypes2.default.bool, error: _propTypes2.default.string, switch: _propTypes2.default.bool, activeColor: _propTypes2.default.string, secondary: _propTypes2.default.bool, onBlur: _propTypes2.default.func, onChange: _propTypes2.default.func, onFocus: _propTypes2.default.func }, _class.defaultProps = { disabled: false, checked: false, onBlur: noop, onChange: noop, onFocus: noop, label: '' }, _initialiseProps = function _initialiseProps() { var _this2 = this; this.state = { focused: false }; this.handleFocus = function (args) { _this2.setState({ focused: true }); _this2.props.onFocus(args); }; this.handleBlur = function (args) { _this2.setState({ focused: false }); _this2.props.onBlur(args); }; }, _temp2); exports.default = Checkbox; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/components/common/checkbox.js"],"names":["noop","StyledSwitchInput","styled","label","props","secondary","theme","secondarySwitch","inputSwitch","StyledCheckboxInput","inputCheckbox","HiddenInput","input","StyledCheckbox","div","switchBtnHeight","switchLabelMargin","Checkbox","inputProps","type","onFocus","handleFocus","onBlur","handleBlur","labelProps","htmlFor","id","LabelElement","Component","propTypes","PropTypes","string","isRequired","node","value","oneOf","checked","bool","disabled","error","switch","activeColor","func","onChange","defaultProps","state","focused","setState","args"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;qMAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;AACA;;;;AACA;;;;AACA;;;;;;AAEA,SAASA,IAAT,GAAgB,CAAE;;AAElB,IAAMC,oBAAoBC,2BAAOC,KAA3B,kBACF;AAAA,SACAC,MAAMC,SAAN,GAAkBD,MAAME,KAAN,CAAYC,eAA9B,GAAgDH,MAAME,KAAN,CAAYE,WAD5D;AAAA,CADE,CAAN;;AAKA,IAAMC,sBAAsBP,2BAAOC,KAA7B,mBACF;AAAA,SAASC,MAAME,KAAN,CAAYI,aAArB;AAAA,CADE,CAAN;;AAIA,IAAMC,cAAcT,2BAAOU,KAArB,kBAAN;;AAKA,IAAMC,iBAAiBX,2BAAOY,GAAxB,mBAEM;AAAA,SAASV,MAAME,KAAN,CAAYS,eAArB;AAAA,CAFN,EAGW;AAAA,SAASX,MAAME,KAAN,CAAYU,iBAArB;AAAA,CAHX,CAAN;;IAMqBC,Q;;;;;;;;;;;;;;;;;;;6BAwCV;AACP,UAAMC,wCACD,sBAAK,KAAKd,KAAV,EAAiB,CAAC,SAAD,EAAY,UAAZ,EAAwB,IAAxB,EAA8B,UAA9B,EAA0C,OAA1C,CAAjB,CADC;AAEJe,cAAM,UAFF;AAGJC,iBAAS,KAAKC,WAHV;AAIJC,gBAAQ,KAAKC;AAJT,QAAN;;AAOA,UAAMC,wCACD,sBAAK,KAAKpB,KAAV,EAAiB,CAAC,SAAD,EAAY,UAAZ,EAAwB,WAAxB,CAAjB,CADC;AAEJqB,iBAAS,KAAKrB,KAAL,CAAWsB;AAFhB,QAAN;;AAKA,UAAMC,eAAe,KAAKvB,KAAL,CAAWe,IAAX,KAAoB,UAApB,GAAiCV,mBAAjC,GAAuDR,iBAA5E;AACA,aACE;AAAC,sBAAD;AAAA,UAAgB,WAAU,aAA1B;AACE,sCAAC,WAAD,EAAiBiB,UAAjB,CADF;AAEE;AAAC,sBAAD;AAAA,mCAAc,WAAU,oBAAxB,IAAiDM,UAAjD;AACG,eAAKpB,KAAL,CAAWD;AADd;AAFF,OADF;AAQD;;;EA9DmCyB,gB,UAC7BC,S,GAAY;AACjBH,MAAII,oBAAUC,MAAV,CAAiBC,UADJ;AAEjB7B,SAAO2B,oBAAUG,IAFA;AAGjBC,SAAOJ,oBAAUK,KAAV,CAAgB,CAAC,IAAD,EAAO,KAAP,EAAc,eAAd,CAAhB,CAHU;AAIjBC,WAASN,oBAAUO,IAJF;AAKjBC,YAAUR,oBAAUO,IALH;;AAOjBE,SAAOT,oBAAUC,MAPA;AAQjBS,UAAQV,oBAAUO,IARD;AASjBI,eAAaX,oBAAUC,MATN;AAUjB1B,aAAWyB,oBAAUO,IAVJ;AAWjBf,UAAQQ,oBAAUY,IAXD;AAYjBC,YAAUb,oBAAUY,IAZH;AAajBtB,WAASU,oBAAUY;AAbF,C,SAgBZE,Y,GAAe;AACpBN,YAAU,KADU;AAEpBF,WAAS,KAFW;AAGpBd,UAAQtB,IAHY;AAIpB2C,YAAU3C,IAJU;AAKpBoB,WAASpB,IALW;AAMpBG,SAAO;AANa,C;;;OAStB0C,K,GAAQ;AACNC,aAAS;AADH,G;;OAIRzB,W,GAAc,gBAAQ;AACpB,WAAK0B,QAAL,CAAc,EAACD,SAAS,IAAV,EAAd;AACA,WAAK1C,KAAL,CAAWgB,OAAX,CAAmB4B,IAAnB;AACD,G;;OAEDzB,U,GAAa,gBAAQ;AACnB,WAAKwB,QAAL,CAAc,EAACD,SAAS,KAAV,EAAd;AACA,WAAK1C,KAAL,CAAWkB,MAAX,CAAkB0B,IAAlB;AACD,G;;kBAtCkB/B,Q","file":"checkbox.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 styled from 'styled-components';\nimport pick from 'lodash.pick';\n\nfunction noop() {}\n\nconst StyledSwitchInput = styled.label`\n  ${props =>\n    props.secondary ? props.theme.secondarySwitch : props.theme.inputSwitch};\n`;\n\nconst StyledCheckboxInput = styled.label`\n  ${props => props.theme.inputCheckbox}\n`;\n\nconst HiddenInput = styled.input`\n  position: absolute;\n  display: none;\n`;\n\nconst StyledCheckbox = styled.div`\n  line-height: 0;\n  height: ${props => props.theme.switchBtnHeight};\n  margin-left: ${props => props.theme.switchLabelMargin}px;\n`;\n\nexport default class Checkbox extends Component {\n  static propTypes = {\n    id: PropTypes.string.isRequired,\n    label: PropTypes.node,\n    value: PropTypes.oneOf([true, false, 'indeterminate']),\n    checked: PropTypes.bool,\n    disabled: PropTypes.bool,\n\n    error: PropTypes.string,\n    switch: PropTypes.bool,\n    activeColor: PropTypes.string,\n    secondary: PropTypes.bool,\n    onBlur: PropTypes.func,\n    onChange: PropTypes.func,\n    onFocus: PropTypes.func\n  };\n\n  static defaultProps = {\n    disabled: false,\n    checked: false,\n    onBlur: noop,\n    onChange: noop,\n    onFocus: noop,\n    label: ''\n  };\n\n  state = {\n    focused: false\n  };\n\n  handleFocus = args => {\n    this.setState({focused: true});\n    this.props.onFocus(args);\n  };\n\n  handleBlur = args => {\n    this.setState({focused: false});\n    this.props.onBlur(args);\n  };\n\n  render() {\n    const inputProps = {\n      ...pick(this.props, ['checked', 'disabled', 'id', 'onChange', 'value']),\n      type: 'checkbox',\n      onFocus: this.handleFocus,\n      onBlur: this.handleBlur\n    };\n\n    const labelProps = {\n      ...pick(this.props, ['checked', 'disabled', 'secondary']),\n      htmlFor: this.props.id\n    };\n\n    const LabelElement = this.props.type === 'checkbox' ? StyledCheckboxInput : StyledSwitchInput;\n    return (\n      <StyledCheckbox className=\"kg-checkbox\">\n        <HiddenInput {...inputProps} />\n        <LabelElement className=\"kg-checkbox__label\" {...labelProps}>\n          {this.props.label}\n        </LabelElement>\n      </StyledCheckbox>\n    );\n  }\n}\n"]}