kepler.gl
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
124 lines (106 loc) • 17.4 kB
JavaScript
"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"));
var _templateObject, _templateObject2, _templateObject3, _templateObject4;
var StyledTileWrapper = _styledComponents["default"].div.attrs({
className: 'provider-tile__wrapper'
})(_templateObject || (_templateObject = (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"])), 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 StyledBox = (0, _styledComponents["default"])(_styledComponents2.CenterVerticalFlexbox)(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n margin-right: 12px;\n"])));
var StyledCloudName = _styledComponents["default"].div(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n font-size: 12px;\n margin-top: 12px;\n margin-bottom: 4px;\n"])));
var StyledUserName = _styledComponents["default"].div(_templateObject4 || (_templateObject4 = (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"])), function (props) {
return props.theme.primaryBtnActBgd;
});
var LoginButton = function LoginButton(_ref) {
var onClick = _ref.onClick;
return /*#__PURE__*/_react["default"].createElement(_styledComponents2.Button, {
className: "login-button",
link: true,
small: true,
onClick: onClick
}, /*#__PURE__*/_react["default"].createElement(_icons.Login, null), "Login");
};
var LogoutButton = function LogoutButton(_ref2) {
var onClick = _ref2.onClick;
return /*#__PURE__*/_react["default"].createElement(_styledComponents2.Button, {
className: "logout-button",
link: true,
small: true,
onClick: onClick
}, /*#__PURE__*/_react["default"].createElement(_icons.Logout, null), "Logout");
};
var ActionButton = function ActionButton(_ref3) {
var isConnected = _ref3.isConnected,
_ref3$actionName = _ref3.actionName,
actionName = _ref3$actionName === void 0 ? null : _ref3$actionName,
isReady = _ref3.isReady;
return isConnected && actionName ? /*#__PURE__*/_react["default"].createElement(_styledComponents2.Button, {
className: "cloud-tile__action",
small: true,
secondary: true,
disabled: !isReady
}, isReady ? actionName : /*#__PURE__*/_react["default"].createElement(_loadingSpinner["default"], {
size: 12
})) : null;
};
var CloudTile = function CloudTile(_ref4) {
var onSelect = _ref4.onSelect,
_ref4$onConnect = _ref4.onConnect,
onConnect = _ref4$onConnect === void 0 ? null : _ref4$onConnect,
_ref4$onLogout = _ref4.onLogout,
onLogout = _ref4$onLogout === void 0 ? null : _ref4$onLogout,
_ref4$actionName = _ref4.actionName,
actionName = _ref4$actionName === void 0 ? null : _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 /*#__PURE__*/_react["default"].createElement(StyledBox, null, /*#__PURE__*/_react["default"].createElement(StyledTileWrapper, {
onClick: isConnected ? onSelect : onClickConnect,
selected: isSelected
}, /*#__PURE__*/_react["default"].createElement(StyledCloudName, null, cloudProvider.displayName || cloudProvider.name), cloudProvider.icon ? /*#__PURE__*/_react["default"].createElement(cloudProvider.icon, {
height: "64px"
}) : null, /*#__PURE__*/_react["default"].createElement(ActionButton, {
isConnected: isConnected,
actionName: actionName,
isReady: isReady
}), userName && /*#__PURE__*/_react["default"].createElement(StyledUserName, null, userName), isSelected && /*#__PURE__*/_react["default"].createElement(_styledComponents2.CheckMark, null)), isConnected ? /*#__PURE__*/_react["default"].createElement(LogoutButton, {
onClick: onClickLogout
}) : /*#__PURE__*/_react["default"].createElement(LoginButton, {
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","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) 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 from 'react';\nimport styled from 'styled-components';\nimport {Logout, Login} from 'components/common/icons';\nimport {CenterVerticalFlexbox, Button, CheckMark} 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 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 className=\"login-button\" link small onClick={onClick}>\n    <Login />\n    Login\n  </Button>\n);\n\nconst LogoutButton = ({onClick}) => (\n  <Button className=\"logout-button\" link small onClick={onClick}>\n    <Logout />\n    Logout\n  </Button>\n);\n\nconst ActionButton = ({isConnected, actionName = null, 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 = null,\n  // default to logout\n  onLogout = null,\n  // action name\n  actionName = null,\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 onClick={onClickLogout} />\n      ) : (\n        <LoginButton onClick={onClickConnect} />\n      )}\n    </StyledBox>\n  );\n};\n\nexport default CloudTile;\n"]}