kepler.gl
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
98 lines (97 loc) • 18.4 kB
JavaScript
"use strict";
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports["default"] = void 0;
var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));
var _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime/helpers/possibleConstructorReturn"));
var _getPrototypeOf2 = _interopRequireDefault(require("@babel/runtime/helpers/getPrototypeOf"));
var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits"));
var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
var _react = _interopRequireDefault(require("react"));
var _styledComponents = _interopRequireDefault(require("styled-components"));
var _moment = _interopRequireDefault(require("moment"));
var _icons = require("../common/icons");
var _localization = require("@kepler.gl/localization");
var _templateObject, _templateObject2, _templateObject3, _templateObject4; // SPDX-License-Identifier: MIT
// Copyright contributors to the kepler.gl project
function _callSuper(t, o, e) { return o = (0, _getPrototypeOf2["default"])(o), (0, _possibleConstructorReturn2["default"])(t, _isNativeReflectConstruct() ? Reflect.construct(o, e || [], (0, _getPrototypeOf2["default"])(t).constructor) : o.apply(t, e)); }
function _isNativeReflectConstruct() { try { var t = !Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); } catch (t) {} return (_isNativeReflectConstruct = function _isNativeReflectConstruct() { return !!t; })(); }
var imageH = 108;
var StyledAssetGallery = _styledComponents["default"].div.attrs({
className: 'storage-asset-gallery'
})(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n justify-content: flex-start;\n flex-wrap: wrap;\n"])));
var StyledAssetItem = _styledComponents["default"].div.attrs({
className: 'asset__item'
})(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n width: 23%;\n margin-right: 2%;\n max-width: 500px;\n margin-bottom: 40px;\n height: 245px;\n display: flex;\n flex-direction: column;\n justify-content: space-between;\n\n :last {\n margin-right: 0;\n }\n\n .asset__title {\n font-size: 12px;\n font-weight: 500;\n color: ", ";\n line-height: 18px;\n height: 32px;\n }\n\n .asset__image {\n border-radius: 4px;\n overflow: hidden;\n margin-bottom: 12px;\n opacity: 0.9;\n transition: opacity 0.4s ease;\n position: relative;\n line-height: 0;\n height: ", "px;\n flex-shrink: 0;\n\n img {\n max-width: 100%;\n }\n &:hover {\n cursor: pointer;\n opacity: 1;\n }\n }\n\n .asset__image__caption {\n font-size: 11px;\n font-weight: 400;\n line-height: 16px;\n margin-top: 10px;\n height: 48px;\n overflow: hidden;\n display: -webkit-box;\n text-overflow: ellipsis;\n -webkit-line-clamp: 3;\n -webkit-box-orient: vertical;\n }\n\n .asset__last-updated {\n font-size: 11px;\n color: ", ";\n }\n"])), function (props) {
return props.theme.textColorLT;
}, imageH, function (props) {
return props.theme.textColorLT;
});
var BackLink = _styledComponents["default"].div(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n font-size: 14px;\n align-items: center;\n color: ", ";\n cursor: pointer;\n margin-bottom: 40px;\n\n &:hover {\n font-weight: 500;\n }\n\n span {\n white-space: nowrap;\n }\n svg {\n margin-right: 10px;\n }\n"])), function (props) {
return props.theme.titleColorLT;
});
var StyledError = _styledComponents["default"].div(_templateObject4 || (_templateObject4 = (0, _taggedTemplateLiteral2["default"])(["\n color: red;\n font-size: 14px;\n margin-bottom: 16px;\n"])));
var getDuration = function getDuration() {
var last = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 0;
return _moment["default"].duration(new Date().valueOf() - last).humanize();
};
var AssetItem = function AssetItem(_ref) {
var asset = _ref.asset,
onClick = _ref.onClick;
return /*#__PURE__*/_react["default"].createElement(StyledAssetItem, null, /*#__PURE__*/_react["default"].createElement("div", {
className: "asset__image",
onClick: onClick
}, asset.imageUrl && /*#__PURE__*/_react["default"].createElement("img", {
src: asset.imageUrl
})), /*#__PURE__*/_react["default"].createElement("div", {
className: "asset__title"
}, asset.label || asset.title), /*#__PURE__*/_react["default"].createElement("div", {
className: "asset__image__caption"
}, asset.description), asset.lastUpdated ? /*#__PURE__*/_react["default"].createElement("div", {
className: "asset__last-updated"
}, /*#__PURE__*/_react["default"].createElement(_localization.FormattedMessage, {
id: 'modal.storageMapViewer.lastModified',
values: {
lastUpdated: getDuration(asset.lastUpdated)
}
})) : null);
};
var StorageAssetsViewer = /*#__PURE__*/function (_React$Component) {
function StorageAssetsViewer() {
(0, _classCallCheck2["default"])(this, StorageAssetsViewer);
return _callSuper(this, StorageAssetsViewer, arguments);
}
(0, _inherits2["default"])(StorageAssetsViewer, _React$Component);
return (0, _createClass2["default"])(StorageAssetsViewer, [{
key: "render",
value: function render() {
var _this$props = this.props,
assets = _this$props.assets,
onLoadAsset = _this$props.onLoadAsset,
back = _this$props.back,
error = _this$props.error;
return /*#__PURE__*/_react["default"].createElement("div", {
className: "storage-asset-viewer"
}, /*#__PURE__*/_react["default"].createElement(BackLink, {
onClick: back
}, /*#__PURE__*/_react["default"].createElement(_icons.LeftArrow, {
height: "12px"
}), /*#__PURE__*/_react["default"].createElement("span", null, /*#__PURE__*/_react["default"].createElement(_localization.FormattedMessage, {
id: 'modal.storageMapViewer.back'
}))), error && /*#__PURE__*/_react["default"].createElement(StyledError, null, error.message), /*#__PURE__*/_react["default"].createElement(StyledAssetGallery, null, assets.map(function (sp) {
return /*#__PURE__*/_react["default"].createElement(AssetItem, {
asset: sp,
key: sp.id,
onClick: function onClick() {
return onLoadAsset(sp);
}
});
})));
}
}]);
}(_react["default"].Component);
var _default = exports["default"] = StorageAssetsViewer;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireDefault","require","_styledComponents","_moment","_icons","_localization","_templateObject","_templateObject2","_templateObject3","_templateObject4","_callSuper","t","o","e","_getPrototypeOf2","_possibleConstructorReturn2","_isNativeReflectConstruct","Reflect","construct","constructor","apply","Boolean","prototype","valueOf","call","imageH","StyledAssetGallery","styled","div","attrs","className","_taggedTemplateLiteral2","StyledAssetItem","props","theme","textColorLT","BackLink","titleColorLT","StyledError","getDuration","last","arguments","length","undefined","moment","duration","Date","humanize","AssetItem","_ref","asset","onClick","createElement","imageUrl","src","label","title","description","lastUpdated","FormattedMessage","id","values","StorageAssetsViewer","_React$Component","_classCallCheck2","_inherits2","_createClass2","key","value","render","_this$props","assets","onLoadAsset","back","error","LeftArrow","height","message","map","sp","React","Component","_default","exports"],"sources":["../../src/modals/storage-map-viewer.tsx"],"sourcesContent":["// SPDX-License-Identifier: MIT\n// Copyright contributors to the kepler.gl project\n\nimport React from 'react';\nimport styled from 'styled-components';\nimport moment from 'moment';\nimport {LeftArrow} from '../common/icons';\nimport {FormattedMessage} from '@kepler.gl/localization';\n\nconst imageH = 108;\n\nconst StyledAssetGallery = styled.div.attrs({\n  className: 'storage-asset-gallery'\n})`\n  display: flex;\n  justify-content: flex-start;\n  flex-wrap: wrap;\n`;\n\nconst StyledAssetItem = styled.div.attrs({\n  className: 'asset__item'\n})`\n  width: 23%;\n  margin-right: 2%;\n  max-width: 500px;\n  margin-bottom: 40px;\n  height: 245px;\n  display: flex;\n  flex-direction: column;\n  justify-content: space-between;\n\n  :last {\n    margin-right: 0;\n  }\n\n  .asset__title {\n    font-size: 12px;\n    font-weight: 500;\n    color: ${props => props.theme.textColorLT};\n    line-height: 18px;\n    height: 32px;\n  }\n\n  .asset__image {\n    border-radius: 4px;\n    overflow: hidden;\n    margin-bottom: 12px;\n    opacity: 0.9;\n    transition: opacity 0.4s ease;\n    position: relative;\n    line-height: 0;\n    height: ${imageH}px;\n    flex-shrink: 0;\n\n    img {\n      max-width: 100%;\n    }\n    &:hover {\n      cursor: pointer;\n      opacity: 1;\n    }\n  }\n\n  .asset__image__caption {\n    font-size: 11px;\n    font-weight: 400;\n    line-height: 16px;\n    margin-top: 10px;\n    height: 48px;\n    overflow: hidden;\n    display: -webkit-box;\n    text-overflow: ellipsis;\n    -webkit-line-clamp: 3;\n    -webkit-box-orient: vertical;\n  }\n\n  .asset__last-updated {\n    font-size: 11px;\n    color: ${props => props.theme.textColorLT};\n  }\n`;\n\nconst BackLink = styled.div`\n  display: flex;\n  font-size: 14px;\n  align-items: center;\n  color: ${props => props.theme.titleColorLT};\n  cursor: pointer;\n  margin-bottom: 40px;\n\n  &:hover {\n    font-weight: 500;\n  }\n\n  span {\n    white-space: nowrap;\n  }\n  svg {\n    margin-right: 10px;\n  }\n`;\n\nconst StyledError = styled.div`\n  color: red;\n  font-size: 14px;\n  margin-bottom: 16px;\n`;\n\nconst getDuration = (last = 0) => moment.duration(new Date().valueOf() - last).humanize();\n\ninterface Asset {\n  imageUrl?: string;\n  label?: string;\n  title?: string;\n  description?: string;\n  lastUpdated?: number;\n  id?: string;\n}\n\ninterface AssetItemProps {\n  asset: Asset;\n  onClick: React.MouseEventHandler<HTMLDivElement>;\n}\n\nconst AssetItem: React.FC<AssetItemProps> = ({asset, onClick}) => (\n  <StyledAssetItem>\n    <div className=\"asset__image\" onClick={onClick}>\n      {asset.imageUrl && <img src={asset.imageUrl} />}\n    </div>\n    <div className=\"asset__title\">{asset.label || asset.title}</div>\n    <div className=\"asset__image__caption\">{asset.description}</div>\n    {asset.lastUpdated ? (\n      <div className=\"asset__last-updated\">\n        <FormattedMessage\n          id={'modal.storageMapViewer.lastModified'}\n          values={{lastUpdated: getDuration(asset.lastUpdated)}}\n        />\n      </div>\n    ) : null}\n  </StyledAssetItem>\n);\n\ninterface StorageAssetsViewerProps {\n  assets: Asset[];\n  onLoadAsset: (asset: Asset) => void;\n  back?: React.MouseEventHandler<HTMLDivElement>;\n  error?: {message?: string};\n}\n\nclass StorageAssetsViewer extends React.Component<StorageAssetsViewerProps> {\n  render() {\n    const {assets, onLoadAsset, back, error} = this.props;\n\n    return (\n      <div className=\"storage-asset-viewer\">\n        <BackLink onClick={back}>\n          <LeftArrow height=\"12px\" />\n          <span>\n            <FormattedMessage id={'modal.storageMapViewer.back'} />\n          </span>\n        </BackLink>\n        {error && <StyledError>{error.message}</StyledError>}\n        <StyledAssetGallery>\n          {assets.map(sp => (\n            <AssetItem asset={sp} key={sp.id} onClick={() => onLoadAsset(sp)} />\n          ))}\n        </StyledAssetGallery>\n      </div>\n    );\n  }\n}\n\nexport default StorageAssetsViewer;\n"],"mappings":"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","ignoreList":[]}