kepler.gl
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
203 lines (202 loc) • 30.2 kB
JavaScript
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
var _typeof = require("@babel/runtime/helpers/typeof");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports["default"] = exports.StyledWarning = void 0;
var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator"));
var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator"));
var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
var _react = _interopRequireWildcard(require("react"));
var _styledComponents = _interopRequireDefault(require("styled-components"));
var _icons = require("../common/icons");
var _styledComponents2 = require("../common/styled-components");
var _useCloudListProvider2 = require("../hooks/use-cloud-list-provider");
var _templateObject, _templateObject2, _templateObject3, _templateObject4, _templateObject5, _templateObject6; // SPDX-License-Identifier: MIT
// Copyright contributors to the kepler.gl project
function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(e) { return e ? t : r; })(e); }
function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != _typeof(e) && "function" != typeof e) return { "default": e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && {}.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n["default"] = e, t && t.set(e, n), n; }
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 position: relative;\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 NewTag = _styledComponents["default"].div(_templateObject5 || (_templateObject5 = (0, _taggedTemplateLiteral2["default"])(["\n width: 37px;\n height: 19px;\n display: flex;\n align-content: center;\n justify-content: center;\n border-radius: 8px;\n padding: 4px 8px;\n background-color: #EDE9F9;\n color: #8863F8;\n position: absolute;\n left: 35%;\n top: -8px\n z-index: 500;\n font-size: 11px;\n line-height: 10px;\n"])));
var StyledWarning = exports.StyledWarning = _styledComponents["default"].span(_templateObject6 || (_templateObject6 = (0, _taggedTemplateLiteral2["default"])(["\n color: ", ";\n font-weight: ", ";\n"])), function (props) {
return props.theme.errorColor;
}, function (props) {
return props.theme.selectFontWeightBold;
});
/**
* this component display a provider and allows users to select and set the current provider
* @param provider
* @param actionName
* @constructor
*/
var CloudTile = function CloudTile(_ref3) {
var provider = _ref3.provider,
actionName = _ref3.actionName;
var _useState = (0, _react.useState)(null),
_useState2 = (0, _slicedToArray2["default"])(_useState, 2),
user = _useState2[0],
setUser = _useState2[1];
var _useState3 = (0, _react.useState)(null),
_useState4 = (0, _slicedToArray2["default"])(_useState3, 2),
error = _useState4[0],
setError = _useState4[1];
var _useState5 = (0, _react.useState)(false),
_useState6 = (0, _slicedToArray2["default"])(_useState5, 2),
isLoading = _useState6[0],
setIsLoading = _useState6[1];
var _useCloudListProvider = (0, _useCloudListProvider2.useCloudListProvider)(),
currentProvider = _useCloudListProvider.provider,
setProvider = _useCloudListProvider.setProvider;
var isSelected = provider === currentProvider;
(0, _react.useEffect)(function () {
if (!provider) {
return;
}
setError(null);
setIsLoading(true);
setError(null);
provider.getUser().then(setUser)["catch"](setError)["finally"](function () {
setError(null);
setIsLoading(false);
});
}, [provider]);
var onLogin = (0, _react.useCallback)( /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee() {
var _user;
return _regenerator["default"].wrap(function _callee$(_context) {
while (1) switch (_context.prev = _context.next) {
case 0:
setError(null);
setIsLoading(true);
_context.prev = 2;
_context.next = 5;
return provider.login();
case 5:
_user = _context.sent;
setUser(_user);
setProvider(provider);
_context.next = 13;
break;
case 10:
_context.prev = 10;
_context.t0 = _context["catch"](2);
setError(_context.t0);
case 13:
setIsLoading(false);
case 14:
case "end":
return _context.stop();
}
}, _callee, null, [[2, 10]]);
})), [provider, setProvider]);
var onSelect = (0, _react.useCallback)( /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee2() {
return _regenerator["default"].wrap(function _callee2$(_context2) {
while (1) switch (_context2.prev = _context2.next) {
case 0:
if (!isLoading) {
_context2.next = 2;
break;
}
return _context2.abrupt("return");
case 2:
if (!user) {
_context2.next = 5;
break;
}
setProvider(provider);
return _context2.abrupt("return");
case 5:
_context2.prev = 5;
_context2.next = 8;
return onLogin();
case 8:
setProvider(provider);
_context2.next = 15;
break;
case 11:
_context2.prev = 11;
_context2.t0 = _context2["catch"](5);
setError(_context2.t0);
setProvider(null);
case 15:
case "end":
return _context2.stop();
}
}, _callee2, null, [[5, 11]]);
})), [setProvider, provider, user, isLoading, onLogin]);
var onLogout = (0, _react.useCallback)( /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee3() {
return _regenerator["default"].wrap(function _callee3$(_context3) {
while (1) switch (_context3.prev = _context3.next) {
case 0:
setIsLoading(true);
_context3.prev = 1;
_context3.next = 4;
return provider.logout();
case 4:
_context3.next = 9;
break;
case 6:
_context3.prev = 6;
_context3.t0 = _context3["catch"](1);
setError(_context3.t0);
case 9:
setIsLoading(false);
setUser(null);
setProvider(null);
case 12:
case "end":
return _context3.stop();
}
}, _callee3, null, [[1, 6]]);
})), [provider, setProvider]);
var displayName = provider.displayName,
name = provider.name;
return /*#__PURE__*/_react["default"].createElement(StyledBox, null, provider.isNew ? /*#__PURE__*/_react["default"].createElement(NewTag, null, "New") : null, /*#__PURE__*/_react["default"].createElement("div", null), /*#__PURE__*/_react["default"].createElement(StyledTileWrapper, {
onClick: onSelect,
selected: isSelected
}, /*#__PURE__*/_react["default"].createElement(StyledCloudName, null, displayName || name), provider.icon ? /*#__PURE__*/_react["default"].createElement(provider.icon, {
height: "64px"
}) : null, isLoading ? /*#__PURE__*/_react["default"].createElement("div", null, "Loading ...") : /*#__PURE__*/_react["default"].createElement(_react["default"].Fragment, null, user ? /*#__PURE__*/_react["default"].createElement(StyledUserName, null, actionName || user.name) : null), isSelected ? /*#__PURE__*/_react["default"].createElement(_styledComponents2.CheckMark, null) : null), user || error ? /*#__PURE__*/_react["default"].createElement(LogoutButton, {
onClick: onLogout
}) : /*#__PURE__*/_react["default"].createElement(LoginButton, {
onClick: onLogin
}), error ? /*#__PURE__*/_react["default"].createElement(StyledWarning, null, error.message) : null);
};
var _default = exports["default"] = CloudTile;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_styledComponents","_interopRequireDefault","_icons","_styledComponents2","_useCloudListProvider2","_templateObject","_templateObject2","_templateObject3","_templateObject4","_templateObject5","_templateObject6","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","_typeof","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","StyledTileWrapper","styled","div","attrs","className","_taggedTemplateLiteral2","props","selected","theme","primaryBtnBgd","selectBorderColorLT","transition","StyledBox","CenterVerticalFlexbox","StyledCloudName","StyledUserName","primaryBtnActBgd","LoginButton","_ref","onClick","createElement","Button","link","small","Login","LogoutButton","_ref2","Logout","NewTag","StyledWarning","exports","span","errorColor","selectFontWeightBold","CloudTile","_ref3","provider","actionName","_useState","useState","_useState2","_slicedToArray2","user","setUser","_useState3","_useState4","error","setError","_useState5","_useState6","isLoading","setIsLoading","_useCloudListProvider","useCloudListProvider","currentProvider","setProvider","isSelected","useEffect","getUser","then","onLogin","useCallback","_asyncToGenerator2","_regenerator","mark","_callee","_user","wrap","_callee$","_context","prev","next","login","sent","t0","stop","onSelect","_callee2","_callee2$","_context2","abrupt","onLogout","_callee3","_callee3$","_context3","logout","displayName","name","isNew","icon","height","Fragment","CheckMark","message","_default"],"sources":["../../src/modals/cloud-tile.tsx"],"sourcesContent":["// SPDX-License-Identifier: MIT\n// Copyright contributors to the kepler.gl project\n\nimport React, {useCallback, useEffect, useState} from 'react';\nimport styled, {IStyledComponent} from 'styled-components';\nimport {Logout, Login} from '../common/icons';\nimport {CenterVerticalFlexbox, Button, CheckMark} from '../common/styled-components';\nimport {Provider, CloudUser} from '@kepler.gl/cloud-providers';\nimport {useCloudListProvider} from '../hooks/use-cloud-list-provider';\nimport {BaseComponentProps} from '../types';\n\nexport type StyledTileWrapperProps = BaseComponentProps & {\n  selected?: boolean;\n};\n\nconst StyledTileWrapper: IStyledComponent<'web', StyledTileWrapperProps> = styled.div.attrs({\n  className: 'provider-tile__wrapper'\n})<StyledTileWrapperProps>`\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  position: relative;\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\ninterface OnClickProps {\n  onClick?: React.MouseEventHandler<HTMLButtonElement>;\n}\n\nconst LoginButton = ({onClick}: OnClickProps) => (\n  <Button className=\"login-button\" link small onClick={onClick}>\n    <Login />\n    Login\n  </Button>\n);\n\nconst LogoutButton = ({onClick}: OnClickProps) => (\n  <Button className=\"logout-button\" link small onClick={onClick}>\n    <Logout />\n    Logout\n  </Button>\n);\n\nconst NewTag = styled.div`\n  width: 37px;\n  height: 19px;\n  display: flex;\n  align-content: center;\n  justify-content: center;\n  border-radius: 8px;\n  padding: 4px 8px;\n  background-color: #EDE9F9;\n  color: #8863F8;\n  position: absolute;\n  left: 35%;\n  top: -8px\n  z-index: 500;\n  font-size: 11px;\n  line-height: 10px;\n`;\n\nexport const StyledWarning = styled.span`\n  color: ${props => props.theme.errorColor};\n  font-weight: ${props => props.theme.selectFontWeightBold};\n`;\n\ninterface CloudTileProps {\n  actionName?: string | null;\n  // cloud provider class\n  provider: Provider;\n}\n\n/**\n * this component display a provider and allows users to select and set the current provider\n * @param provider\n * @param actionName\n * @constructor\n */\nconst CloudTile: React.FC<CloudTileProps> = ({provider, actionName}) => {\n  const [user, setUser] = useState<CloudUser | null>(null);\n  const [error, setError] = useState<Error | null>(null);\n  const [isLoading, setIsLoading] = useState(false);\n  const {provider: currentProvider, setProvider} = useCloudListProvider();\n  const isSelected = provider === currentProvider;\n\n  useEffect(() => {\n    if (!provider) {\n      return;\n    }\n    setError(null);\n    setIsLoading(true);\n    setError(null);\n    provider\n      .getUser()\n      .then(setUser)\n      .catch(setError)\n      .finally(() => {\n        setError(null);\n        setIsLoading(false);\n      });\n  }, [provider]);\n\n  const onLogin = useCallback(async () => {\n    setError(null);\n    setIsLoading(true);\n    try {\n      const user = await provider.login();\n      setUser(user);\n      setProvider(provider);\n    } catch (error) {\n      setError(error as Error);\n    }\n    setIsLoading(false);\n  }, [provider, setProvider]);\n\n  const onSelect = useCallback(async () => {\n    if (isLoading) {\n      return;\n    }\n    if (user) {\n      setProvider(provider);\n      return;\n    }\n    try {\n      await onLogin();\n      setProvider(provider);\n    } catch (err) {\n      setError(err as Error);\n      setProvider(null);\n    }\n  }, [setProvider, provider, user, isLoading, onLogin]);\n\n  const onLogout = useCallback(async () => {\n    setIsLoading(true);\n    try {\n      await provider.logout();\n    } catch (error) {\n      setError(error as Error);\n    }\n    setIsLoading(false);\n    setUser(null);\n    setProvider(null);\n  }, [provider, setProvider]);\n\n  const {displayName, name} = provider;\n\n  return (\n    <StyledBox>\n      {provider.isNew ? <NewTag>New</NewTag> : null}\n      <div />\n      <StyledTileWrapper onClick={onSelect} selected={isSelected}>\n        <StyledCloudName>{displayName || name}</StyledCloudName>\n        {provider.icon ? <provider.icon height=\"64px\" /> : null}\n        {isLoading ? (\n          <div>Loading ...</div>\n        ) : (\n          <>{user ? <StyledUserName>{actionName || user.name}</StyledUserName> : null}</>\n        )}\n        {isSelected ? <CheckMark /> : null}\n      </StyledTileWrapper>\n      {user || error ? <LogoutButton onClick={onLogout} /> : <LoginButton onClick={onLogin} />}\n      {error ? <StyledWarning>{error.message}</StyledWarning> : null}\n    </StyledBox>\n  );\n};\n\nexport default CloudTile;\n"],"mappings":"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","ignoreList":[]}
;