UNPKG

kepler.gl

Version:

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

174 lines (141 loc) 19 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); Object.defineProperty(exports, "__esModule", { value: true }); exports["default"] = void 0; var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral")); var _react = _interopRequireDefault(require("react")); var _styledComponents = _interopRequireDefault(require("styled-components")); var _icons = require("../common/icons"); var _styledComponents2 = require("../common/styled-components"); var _loadingSpinner = _interopRequireDefault(require("../common/loading-spinner")); function _templateObject5() { var data = (0, _taggedTemplateLiteral2["default"])(["\n font-size: 11px;\n margin-top: 8px;\n text-align: center;\n color: ", ";\n overflow: hidden;\n width: 100px;\n text-overflow: ellipsis;\n"]); _templateObject5 = function _templateObject5() { return data; }; return data; } function _templateObject4() { var data = (0, _taggedTemplateLiteral2["default"])(["\n font-size: 12px;\n margin-top: 12px;\n margin-bottom: 4px;\n"]); _templateObject4 = function _templateObject4() { return data; }; return data; } function _templateObject3() { var data = (0, _taggedTemplateLiteral2["default"])(["\n margin-right: 12px;\n"]); _templateObject3 = function _templateObject3() { return data; }; return data; } function _templateObject2() { var data = (0, _taggedTemplateLiteral2["default"])(["\n background-color: ", ";\n position: absolute;\n bottom: 0;\n right: 0;\n display: block;\n width: 16px;\n height: 16px;\n border-top-left-radius: 2px;\n\n :after {\n position: absolute;\n display: table;\n border: 2px solid #fff;\n border-top: 0;\n border-left: 0;\n transform: rotate(45deg) scale(1) translate(-50%, -50%);\n opacity: 1;\n content: ' ';\n top: 50%;\n left: 25%;\n width: 5.7px;\n height: 9.1px;\n }\n"]); _templateObject2 = function _templateObject2() { return data; }; return data; } function _templateObject() { var data = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n flex-direction: column;\n align-items: center;\n justify-content: flex-start;\n border-radius: 2px;\n border: 1px solid\n ", ";\n color: ", ";\n cursor: pointer;\n font-weight: 500;\n width: 120px;\n height: 168px;\n background-color: #ffffff;\n transition: ", ";\n position: relative;\n :hover {\n border: 1px solid ", ";\n color: ", ";\n }\n\n .button {\n margin-top: 20px;\n }\n"]); _templateObject = function _templateObject() { return data; }; return data; } var StyledTileWrapper = _styledComponents["default"].div.attrs({ className: 'provider-tile__wrapper' })(_templateObject(), function (props) { return props.selected ? props.theme.primaryBtnBgd : props.theme.selectBorderColorLT; }, function (props) { return props.selected ? props.theme.primaryBtnBgd : props.theme.selectBorderColorLT; }, function (props) { return props.theme.transition; }, function (props) { return props.theme.primaryBtnBgd; }, function (props) { return props.theme.primaryBtnBgd; }); var CheckMark = _styledComponents["default"].span.attrs({ className: 'checkbox-inner' })(_templateObject2(), function (props) { return props.theme.primaryBtnBgd; }); var StyledBox = (0, _styledComponents["default"])(_styledComponents2.CenterVerticalFlexbox)(_templateObject3()); var StyledCloudName = _styledComponents["default"].div(_templateObject4()); var StyledUserName = _styledComponents["default"].div(_templateObject5(), function (props) { return props.theme.primaryBtnActBgd; }); var LoginButton = function LoginButton(_ref) { var onClick = _ref.onClick; return _react["default"].createElement(_styledComponents2.Button, { link: true, small: true, onClick: onClick }, _react["default"].createElement(_icons.Login, null), "Login"); }; var LogoutButton = function LogoutButton(_ref2) { var onClick = _ref2.onClick; return _react["default"].createElement(_styledComponents2.Button, { link: true, small: true, onClick: onClick }, _react["default"].createElement(_icons.Logout, null), "Logout"); }; var ActionButton = function ActionButton(_ref3) { var isConnected = _ref3.isConnected, actionName = _ref3.actionName, isReady = _ref3.isReady; return isConnected && actionName ? _react["default"].createElement(_styledComponents2.Button, { className: "cloud-tile__action", small: true, secondary: true, disabled: !isReady }, isReady ? actionName : _react["default"].createElement(_loadingSpinner["default"], { size: 12 })) : null; }; var CloudTile = function CloudTile(_ref4) { var onSelect = _ref4.onSelect, onConnect = _ref4.onConnect, onLogout = _ref4.onLogout, actionName = _ref4.actionName, cloudProvider = _ref4.cloudProvider, onSetCloudProvider = _ref4.onSetCloudProvider, isSelected = _ref4.isSelected, isConnected = _ref4.isConnected, _ref4$isReady = _ref4.isReady, isReady = _ref4$isReady === void 0 ? true : _ref4$isReady; var userName = typeof cloudProvider.getUserName === 'function' ? cloudProvider.getUserName() : null; var onClickConnect = typeof onConnect === 'function' ? onConnect : function () { return cloudProvider.login(function () { return onSetCloudProvider(cloudProvider.name); }); }; var onClickLogout = typeof onLogout === 'function' ? onLogout : function () { return cloudProvider.logout(function () { return isSelected ? onSetCloudProvider(null) : null; }); }; return _react["default"].createElement(StyledBox, null, _react["default"].createElement(StyledTileWrapper, { onClick: isConnected ? onSelect : onClickConnect, selected: isSelected }, _react["default"].createElement(StyledCloudName, null, cloudProvider.displayName || cloudProvider.name), cloudProvider.icon ? _react["default"].createElement(cloudProvider.icon, { height: "64px" }) : null, _react["default"].createElement(ActionButton, { isConnected: isConnected, actionName: actionName, isReady: isReady }), userName && _react["default"].createElement(StyledUserName, null, userName), isSelected && _react["default"].createElement(CheckMark, null)), isConnected ? _react["default"].createElement(LogoutButton, { className: "logout-button", onClick: onClickLogout }) : _react["default"].createElement(LoginButton, { className: "login-button", onClick: onClickConnect })); }; var _default = CloudTile; exports["default"] = _default; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/components/modals/cloud-tile.js"],"names":["StyledTileWrapper","styled","div","attrs","className","props","selected","theme","primaryBtnBgd","selectBorderColorLT","transition","CheckMark","span","StyledBox","CenterVerticalFlexbox","StyledCloudName","StyledUserName","primaryBtnActBgd","LoginButton","onClick","LogoutButton","ActionButton","isConnected","actionName","isReady","CloudTile","onSelect","onConnect","onLogout","cloudProvider","onSetCloudProvider","isSelected","userName","getUserName","onClickConnect","login","name","onClickLogout","logout","displayName","icon"],"mappings":"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","sourcesContent":["// Copyright (c) 2020 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 from 'react';\nimport styled from 'styled-components';\nimport {Logout, Login} from 'components/common/icons';\nimport {CenterVerticalFlexbox, Button} from 'components/common/styled-components';\nimport LoadingSpinner from 'components/common/loading-spinner';\n\nconst StyledTileWrapper = styled.div.attrs({\n  className: 'provider-tile__wrapper'\n})`\n  display: flex;\n  flex-direction: column;\n  align-items: center;\n  justify-content: flex-start;\n  border-radius: 2px;\n  border: 1px solid\n    ${props => (props.selected ? props.theme.primaryBtnBgd : props.theme.selectBorderColorLT)};\n  color: ${props => (props.selected ? props.theme.primaryBtnBgd : props.theme.selectBorderColorLT)};\n  cursor: pointer;\n  font-weight: 500;\n  width: 120px;\n  height: 168px;\n  background-color: #ffffff;\n  transition: ${props => props.theme.transition};\n  position: relative;\n  :hover {\n    border: 1px solid ${props => props.theme.primaryBtnBgd};\n    color: ${props => props.theme.primaryBtnBgd};\n  }\n\n  .button {\n    margin-top: 20px;\n  }\n`;\n\nconst CheckMark = styled.span.attrs({\n  className: 'checkbox-inner'\n})`\n  background-color: ${props => props.theme.primaryBtnBgd};\n  position: absolute;\n  bottom: 0;\n  right: 0;\n  display: block;\n  width: 16px;\n  height: 16px;\n  border-top-left-radius: 2px;\n\n  :after {\n    position: absolute;\n    display: table;\n    border: 2px solid #fff;\n    border-top: 0;\n    border-left: 0;\n    transform: rotate(45deg) scale(1) translate(-50%, -50%);\n    opacity: 1;\n    content: ' ';\n    top: 50%;\n    left: 25%;\n    width: 5.7px;\n    height: 9.1px;\n  }\n`;\nconst StyledBox = styled(CenterVerticalFlexbox)`\n  margin-right: 12px;\n`;\n\nconst StyledCloudName = styled.div`\n  font-size: 12px;\n  margin-top: 12px;\n  margin-bottom: 4px;\n`;\n\nconst StyledUserName = styled.div`\n  font-size: 11px;\n  margin-top: 8px;\n  text-align: center;\n  color: ${props => props.theme.primaryBtnActBgd};\n  overflow: hidden;\n  width: 100px;\n  text-overflow: ellipsis;\n`;\n\nconst LoginButton = ({onClick}) => (\n  <Button link small onClick={onClick}>\n    <Login />\n    Login\n  </Button>\n);\n\nconst LogoutButton = ({onClick}) => (\n  <Button link small onClick={onClick}>\n    <Logout />\n    Logout\n  </Button>\n);\n\nconst ActionButton = ({isConnected, actionName, isReady}) =>\n  isConnected && actionName ? (\n    <Button className=\"cloud-tile__action\" small secondary disabled={!isReady}>\n      {isReady ? actionName : <LoadingSpinner size={12} />}\n    </Button>\n  ) : null;\n\nconst CloudTile = ({\n  // action when click on the tile\n  onSelect,\n  // default to login\n  onConnect,\n  // default to logout\n  onLogout,\n  // action name\n  actionName,\n  // cloud provider class\n  cloudProvider,\n  // function to take after login or logout\n  onSetCloudProvider,\n  // whether provider is selected as currentProvider\n  isSelected,\n  // whether user has logged in\n  isConnected,\n\n  isReady = true\n}) => {\n  const userName =\n    typeof cloudProvider.getUserName === 'function' ? cloudProvider.getUserName() : null;\n\n  const onClickConnect =\n    typeof onConnect === 'function'\n      ? onConnect\n      : () => cloudProvider.login(() => onSetCloudProvider(cloudProvider.name));\n\n  const onClickLogout =\n    typeof onLogout === 'function'\n      ? onLogout\n      : () => cloudProvider.logout(() => (isSelected ? onSetCloudProvider(null) : null));\n\n  return (\n    <StyledBox>\n      <StyledTileWrapper onClick={isConnected ? onSelect : onClickConnect} selected={isSelected}>\n        <StyledCloudName>{cloudProvider.displayName || cloudProvider.name}</StyledCloudName>\n        {cloudProvider.icon ? <cloudProvider.icon height=\"64px\" /> : null}\n        <ActionButton isConnected={isConnected} actionName={actionName} isReady={isReady} />\n        {userName && <StyledUserName>{userName}</StyledUserName>}\n        {isSelected && <CheckMark />}\n      </StyledTileWrapper>\n      {isConnected ? (\n        <LogoutButton className=\"logout-button\" onClick={onClickLogout} />\n      ) : (\n        <LoginButton className=\"login-button\" onClick={onClickConnect} />\n      )}\n    </StyledBox>\n  );\n};\n\nexport default CloudTile;\n"]}