UNPKG

kepler.gl

Version:

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

231 lines (188 loc) 22.4 kB
'use strict'; Object.defineProperty(exports, "__esModule", { value: true }); exports.ModalFooter = exports.ModalTitle = 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 _extends2 = require('babel-runtime/helpers/extends'); var _extends3 = _interopRequireDefault(_extends2); var _taggedTemplateLiteral2 = require('babel-runtime/helpers/taggedTemplateLiteral'); var _taggedTemplateLiteral3 = _interopRequireDefault(_taggedTemplateLiteral2); var _class, _temp; var _templateObject = (0, _taggedTemplateLiteral3.default)(['\n width: 60%;\n max-width: 960px;\n padding: 40px 96px;\n position: absolute;\n top: 92px;\n left: 0;\n right: 0;\n margin-left: auto;\n background-color: #ffffff;\n border-radius: 4px;\n transition: ', ';\n min-width: 600px;\n overflow: hidden;\n box-sizing: border-box;\n margin-right: auto;\n font-size: 12px;\n color: ', ';\n ', ';\n'], ['\n width: 60%;\n max-width: 960px;\n padding: 40px 96px;\n position: absolute;\n top: 92px;\n left: 0;\n right: 0;\n margin-left: auto;\n background-color: #ffffff;\n border-radius: 4px;\n transition: ', ';\n min-width: 600px;\n overflow: hidden;\n box-sizing: border-box;\n margin-right: auto;\n font-size: 12px;\n color: ', ';\n ', ';\n']), _templateObject2 = (0, _taggedTemplateLiteral3.default)(['\n color: ', ';\n display: flex;\n justify-content: flex-end;\n left: 0;\n padding: 24px;\n position: absolute;\n top: 0;\n width: 100%;\n z-index: 10005;\n\n :hover {\n cursor: pointer;\n }\n'], ['\n color: ', ';\n display: flex;\n justify-content: flex-end;\n left: 0;\n padding: 24px;\n position: absolute;\n top: 0;\n width: 100%;\n z-index: 10005;\n\n :hover {\n cursor: pointer;\n }\n']), _templateObject3 = (0, _taggedTemplateLiteral3.default)(['\n font-size: ', ';\n color: ', ';\n margin-bottom: 10px;\n position: relative;\n z-index: 10003;\n'], ['\n font-size: ', ';\n color: ', ';\n margin-bottom: 10px;\n position: relative;\n z-index: 10003;\n']), _templateObject4 = (0, _taggedTemplateLiteral3.default)(['\n width: 100%;\n left: 0;\n bottom: 0;\n display: flex;\n flex-direction: column;\n justify-content: flex-end;\n padding-top: 36px;\n z-index: 10001;\n'], ['\n width: 100%;\n left: 0;\n bottom: 0;\n display: flex;\n flex-direction: column;\n justify-content: flex-end;\n padding-top: 36px;\n z-index: 10001;\n']), _templateObject5 = (0, _taggedTemplateLiteral3.default)(['\n position: relative;\n z-index: 10002;\n'], ['\n position: relative;\n z-index: 10002;\n']), _templateObject6 = (0, _taggedTemplateLiteral3.default)(['\n display: flex;\n justify-content: flex-end;\n'], ['\n display: flex;\n justify-content: flex-end;\n']), _templateObject7 = (0, _taggedTemplateLiteral3.default)(['\n width: 100%;\n height: 100%;\n top: 0;\n left: 0;\n z-index: 10000;\n transition: ', ';\n\n :focus {\n outline: 0\n }\n'], ['\n width: 100%;\n height: 100%;\n top: 0;\n left: 0;\n z-index: 10000;\n transition: ', ';\n\n :focus {\n outline: 0\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 _styledComponents = require('styled-components'); var _styledComponents2 = _interopRequireDefault(_styledComponents); var _reactModal = require('react-modal'); var _reactModal2 = _interopRequireDefault(_reactModal); var _icons = require('./icons'); var _styledComponents3 = require('./styled-components'); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } var ModalContentWrapper = _styledComponents2.default.div(_templateObject, function (props) { return props.theme.transition; }, function (props) { return props.theme.labelColorLT; }, function (props) { return props.cssStyle || ''; }); var CloseButton = _styledComponents2.default.div(_templateObject2, function (props) { return props.theme.titleColorLT; }); var ModalTitle = exports.ModalTitle = _styledComponents2.default.div(_templateObject3, function (props) { return props.theme.modalTitleFontSize; }, function (props) { return props.theme.modalTitleColor; }); var StyledModalFooter = _styledComponents2.default.div(_templateObject4); var ModalContent = _styledComponents2.default.div(_templateObject5); var FooterActionWrapper = _styledComponents2.default.div(_templateObject6); var defaultCancelButton = { link: true, large: true, children: 'Cancel' }; var defaultConfirmButton = { large: true, width: '160px', children: 'Confirm' }; var ModalFooter = exports.ModalFooter = function ModalFooter(_ref) { var cancel = _ref.cancel, confirm = _ref.confirm, cancelButton = _ref.cancelButton, confirmButton = _ref.confirmButton; var cancelButtonProps = (0, _extends3.default)({}, defaultCancelButton, cancelButton); var confirmButtonProps = (0, _extends3.default)({}, defaultConfirmButton, confirmButton); return _react2.default.createElement( StyledModalFooter, { className: 'modal--footer' }, _react2.default.createElement( FooterActionWrapper, null, _react2.default.createElement( _styledComponents3.Button, (0, _extends3.default)({}, cancelButtonProps, { onClick: cancel }), cancelButtonProps.children ), _react2.default.createElement( _styledComponents3.Button, (0, _extends3.default)({}, confirmButtonProps, { onClick: confirm }), confirmButtonProps.children ) ) ); }; var ModalDialog = (_temp = _class = function (_Component) { (0, _inherits3.default)(ModalDialog, _Component); function ModalDialog() { (0, _classCallCheck3.default)(this, ModalDialog); return (0, _possibleConstructorReturn3.default)(this, (ModalDialog.__proto__ || Object.getPrototypeOf(ModalDialog)).apply(this, arguments)); } (0, _createClass3.default)(ModalDialog, [{ key: 'render', value: function render() { var props = this.props; return _react2.default.createElement( _reactModal2.default, (0, _extends3.default)({}, props, { ariaHideApp: false, style: { overlay: { backgroundColor: 'rgba(0, 0, 0, 0.5)', zIndex: 10000, overflowY: 'auto', position: 'absolute' } } }), _react2.default.createElement( ModalContentWrapper, { className: 'modal--content', cssStyle: props.cssStyle, footer: props.footer }, props.close ? _react2.default.createElement( CloseButton, { className: 'modal--close', onClick: props.close }, _react2.default.createElement(_icons.Delete, { height: '14px' }) ) : null, props.title ? _react2.default.createElement( ModalTitle, { className: 'modal--title' }, props.title ) : null, _react2.default.createElement( ModalContent, { className: 'content' }, props.children ), props.footer ? _react2.default.createElement(ModalFooter, { cancel: props.close, confirm: props.onConfirm, cancelButton: props.cancelButton, confirmButton: props.confirmButton }) : null ) ); } }]); return ModalDialog; }(_react.Component), _class.propTypes = { footer: _propTypes2.default.bool, close: _propTypes2.default.func.isRequired, onConfirm: _propTypes2.default.func, onCancel: _propTypes2.default.func, confirmButton: _propTypes2.default.object, confirmButtonLabel: _propTypes2.default.string, cancelButton: _propTypes2.default.object, cancelButtonLabel: _propTypes2.default.string, cssStyle: _propTypes2.default.arrayOf(_propTypes2.default.any) }, _class.defaultProps = { footer: false, close: function close() {}, onConfirm: function onConfirm() {}, onCancel: function onCancel() {}, cancelButton: defaultCancelButton, confirmButton: defaultConfirmButton, cssStyle: [] }, _temp); var StyledModal = (0, _styledComponents2.default)(ModalDialog)(_templateObject7, function (props) { return props.theme.transition; }); exports.default = StyledModal; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/components/common/modal.js"],"names":["ModalContentWrapper","styled","div","props","theme","transition","labelColorLT","cssStyle","CloseButton","titleColorLT","ModalTitle","modalTitleFontSize","modalTitleColor","StyledModalFooter","ModalContent","FooterActionWrapper","defaultCancelButton","link","large","children","defaultConfirmButton","width","ModalFooter","cancel","confirm","cancelButton","confirmButton","cancelButtonProps","confirmButtonProps","ModalDialog","overlay","backgroundColor","zIndex","overflowY","position","footer","close","title","onConfirm","Component","propTypes","PropTypes","bool","func","isRequired","onCancel","object","confirmButtonLabel","string","cancelButtonLabel","arrayOf","any","defaultProps","StyledModal"],"mappings":"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","file":"modal.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';\n\nimport styled from 'styled-components';\nimport Modal from 'react-modal';\nimport {Delete} from 'components/common/icons';\nimport {Button} from 'components/common/styled-components';\n\nconst ModalContentWrapper = styled.div`\n  width: 60%;\n  max-width: 960px;\n  padding: 40px 96px;\n  position: absolute;\n  top: 92px;\n  left: 0;\n  right: 0;\n  margin-left: auto;\n  background-color: #ffffff;\n  border-radius: 4px;\n  transition: ${props => props.theme.transition};\n  min-width: 600px;\n  overflow: hidden;\n  box-sizing: border-box;\n  margin-right: auto;\n  font-size: 12px;\n  color: ${props => props.theme.labelColorLT};\n  ${props => props.cssStyle || ''};\n`;\n\nconst CloseButton = styled.div`\n  color: ${props => props.theme.titleColorLT};\n  display: flex;\n  justify-content: flex-end;\n  left: 0;\n  padding: 24px;\n  position: absolute;\n  top: 0;\n  width: 100%;\n  z-index: 10005;\n\n  :hover {\n    cursor: pointer;\n  }\n`;\n\nexport const ModalTitle = styled.div`\n  font-size: ${props => props.theme.modalTitleFontSize};\n  color: ${props => props.theme.modalTitleColor};\n  margin-bottom: 10px;\n  position: relative;\n  z-index: 10003;\n`;\n\nconst StyledModalFooter = styled.div`\n  width: 100%;\n  left: 0;\n  bottom: 0;\n  display: flex;\n  flex-direction: column;\n  justify-content: flex-end;\n  padding-top: 36px;\n  z-index: 10001;\n`;\n\nconst ModalContent = styled.div`\n  position: relative;\n  z-index: 10002;\n`;\n\nconst FooterActionWrapper = styled.div`\n  display: flex;\n  justify-content: flex-end;\n`;\n\nconst defaultCancelButton = {\n  link: true,\n  large: true,\n  children: 'Cancel'\n};\n\nconst defaultConfirmButton = {\n  large: true,\n  width: '160px',\n  children: 'Confirm'\n};\n\nexport const ModalFooter = ({\n  cancel,\n  confirm,\n  cancelButton,\n  confirmButton\n}) => {\n  const cancelButtonProps = {...defaultCancelButton, ...cancelButton};\n  const confirmButtonProps = {...defaultConfirmButton, ...confirmButton};\n  return (\n    <StyledModalFooter className=\"modal--footer\">\n      <FooterActionWrapper>\n        <Button {...cancelButtonProps} onClick={cancel}>\n          {cancelButtonProps.children}\n        </Button>\n        <Button {...confirmButtonProps} onClick={confirm}>\n          {confirmButtonProps.children}\n        </Button>\n      </FooterActionWrapper>\n    </StyledModalFooter>\n  );\n}\n\nclass ModalDialog extends Component {\n  static propTypes = {\n    footer: PropTypes.bool,\n    close: PropTypes.func.isRequired,\n    onConfirm: PropTypes.func,\n    onCancel: PropTypes.func,\n    confirmButton: PropTypes.object,\n    confirmButtonLabel: PropTypes.string,\n    cancelButton: PropTypes.object,\n    cancelButtonLabel: PropTypes.string,\n    cssStyle: PropTypes.arrayOf(PropTypes.any)\n  };\n\n  static defaultProps = {\n    footer: false,\n    close: () => {},\n    onConfirm: () => {},\n    onCancel: () => {},\n    cancelButton: defaultCancelButton,\n    confirmButton: defaultConfirmButton,\n    cssStyle: []\n  };\n\n  render() {\n    const {props} = this;\n    return (\n      <Modal\n        {...props}\n        ariaHideApp={false}\n        style={{\n          overlay: {\n            backgroundColor: 'rgba(0, 0, 0, 0.5)',\n            zIndex: 10000,\n            overflowY: 'auto',\n            position: 'absolute'\n          }\n        }}\n      >\n        <ModalContentWrapper\n          className=\"modal--content\"\n          cssStyle={props.cssStyle}\n          footer={props.footer}\n        >\n          {props.close ? (\n            <CloseButton className=\"modal--close\" onClick={props.close}>\n              <Delete height=\"14px\" />\n            </CloseButton>\n          ) : null}\n          {props.title ? (\n            <ModalTitle className=\"modal--title\">{props.title}</ModalTitle>\n          ) : null}\n          <ModalContent className=\"content\">{props.children}</ModalContent>\n          {props.footer ? (\n            <ModalFooter\n              cancel={props.close}\n              confirm={props.onConfirm}\n              cancelButton={props.cancelButton}\n              confirmButton={props.confirmButton}\n            />\n          ) : null}\n        </ModalContentWrapper>\n      </Modal>\n    );\n  }\n}\n\nconst StyledModal = styled(ModalDialog)`\n  width: 100%;\n  height: 100%;\n  top: 0;\n  left: 0;\n  z-index: 10000;\n  transition: ${props => props.theme.transition};\n\n  :focus {\n    outline: 0\n  }\n`;\n\nexport default StyledModal;\n"]}