UNPKG

kepler.gl

Version:

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

135 lines (105 loc) 17.5 kB
"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 _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits")); var _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime/helpers/possibleConstructorReturn")); var _getPrototypeOf2 = _interopRequireDefault(require("@babel/runtime/helpers/getPrototypeOf")); var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral")); var _react = _interopRequireDefault(require("react")); var _propTypes = _interopRequireDefault(require("prop-types")); var _styledComponents = _interopRequireDefault(require("styled-components")); var _moment = _interopRequireDefault(require("moment")); var _icons = require("../common/icons"); var _localization = require("../../localization"); var _templateObject, _templateObject2, _templateObject3, _templateObject4; function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = (0, _getPrototypeOf2["default"])(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = (0, _getPrototypeOf2["default"])(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return (0, _possibleConstructorReturn2["default"])(this, result); }; } function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); return true; } catch (e) { return false; } } var imageH = 108; var propTypes = { onLoadAsset: _propTypes["default"].func.isRequired, back: _propTypes["default"].func.isRequired }; 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(last) { 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) { (0, _inherits2["default"])(StorageAssetsViewer, _React$Component); var _super = _createSuper(StorageAssetsViewer); function StorageAssetsViewer() { (0, _classCallCheck2["default"])(this, StorageAssetsViewer); return _super.apply(this, arguments); } (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); } }); }))); } }]); return StorageAssetsViewer; }(_react["default"].Component); (0, _defineProperty2["default"])(StorageAssetsViewer, "propTypes", propTypes); var _default = StorageAssetsViewer; exports["default"] = _default; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/components/modals/storage-map-viewer.js"],"names":["imageH","propTypes","onLoadAsset","PropTypes","func","isRequired","back","StyledAssetGallery","styled","div","attrs","className","StyledAssetItem","props","theme","textColorLT","BackLink","titleColorLT","StyledError","getDuration","last","moment","duration","Date","valueOf","humanize","AssetItem","asset","onClick","imageUrl","label","title","description","lastUpdated","StorageAssetsViewer","assets","error","message","map","sp","id","React","Component"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;AAoBA;;AACA;;AACA;;AACA;;AACA;;AACA;;;;;;;;AAEA,IAAMA,MAAM,GAAG,GAAf;AAEA,IAAMC,SAAS,GAAG;AAChBC,EAAAA,WAAW,EAAEC,sBAAUC,IAAV,CAAeC,UADZ;AAEhBC,EAAAA,IAAI,EAAEH,sBAAUC,IAAV,CAAeC;AAFL,CAAlB;;AAKA,IAAME,kBAAkB,GAAGC,6BAAOC,GAAP,CAAWC,KAAX,CAAiB;AAC1CC,EAAAA,SAAS,EAAE;AAD+B,CAAjB,CAAH,8JAAxB;;AAQA,IAAMC,eAAe,GAAGJ,6BAAOC,GAAP,CAAWC,KAAX,CAAiB;AACvCC,EAAAA,SAAS,EAAE;AAD4B,CAAjB,CAAH,moCAmBR,UAAAE,KAAK;AAAA,SAAIA,KAAK,CAACC,KAAN,CAAYC,WAAhB;AAAA,CAnBG,EAgCPf,MAhCO,EA2DR,UAAAa,KAAK;AAAA,SAAIA,KAAK,CAACC,KAAN,CAAYC,WAAhB;AAAA,CA3DG,CAArB;;AA+DA,IAAMC,QAAQ,GAAGR,6BAAOC,GAAV,iVAIH,UAAAI,KAAK;AAAA,SAAIA,KAAK,CAACC,KAAN,CAAYG,YAAhB;AAAA,CAJF,CAAd;;AAoBA,IAAMC,WAAW,GAAGV,6BAAOC,GAAV,qJAAjB;;AAMA,IAAMU,WAAW,GAAG,SAAdA,WAAc,CAAAC,IAAI;AAAA,SAAIC,mBAAOC,QAAP,CAAgB,IAAIC,IAAJ,GAAWC,OAAX,KAAuBJ,IAAvC,EAA6CK,QAA7C,EAAJ;AAAA,CAAxB;;AAEA,IAAMC,SAAS,GAAG,SAAZA,SAAY;AAAA,MAAEC,KAAF,QAAEA,KAAF;AAAA,MAASC,OAAT,QAASA,OAAT;AAAA,sBAChB,gCAAC,eAAD,qBACE;AAAK,IAAA,SAAS,EAAC,cAAf;AAA8B,IAAA,OAAO,EAAEA;AAAvC,KACGD,KAAK,CAACE,QAAN,iBAAkB;AAAK,IAAA,GAAG,EAAEF,KAAK,CAACE;AAAhB,IADrB,CADF,eAIE;AAAK,IAAA,SAAS,EAAC;AAAf,KAA+BF,KAAK,CAACG,KAAN,IAAeH,KAAK,CAACI,KAApD,CAJF,eAKE;AAAK,IAAA,SAAS,EAAC;AAAf,KAAwCJ,KAAK,CAACK,WAA9C,CALF,EAMGL,KAAK,CAACM,WAAN,gBACC;AAAK,IAAA,SAAS,EAAC;AAAf,kBACE,gCAAC,8BAAD;AACE,IAAA,EAAE,EAAE,qCADN;AAEE,IAAA,MAAM,EAAE;AAACA,MAAAA,WAAW,EAAEd,WAAW,CAACQ,KAAK,CAACM,WAAP;AAAzB;AAFV,IADF,CADD,GAOG,IAbN,CADgB;AAAA,CAAlB;;IAkBMC,mB;;;;;;;;;;;;WAGJ,kBAAS;AAAA,wBACoC,KAAKrB,KADzC;AAAA,UACAsB,MADA,eACAA,MADA;AAAA,UACQjC,WADR,eACQA,WADR;AAAA,UACqBI,IADrB,eACqBA,IADrB;AAAA,UAC2B8B,KAD3B,eAC2BA,KAD3B;AAGP,0BACE;AAAK,QAAA,SAAS,EAAC;AAAf,sBACE,gCAAC,QAAD;AAAU,QAAA,OAAO,EAAE9B;AAAnB,sBACE,gCAAC,gBAAD;AAAW,QAAA,MAAM,EAAC;AAAlB,QADF,eAEE,2DACE,gCAAC,8BAAD;AAAkB,QAAA,EAAE,EAAE;AAAtB,QADF,CAFF,CADF,EAOG8B,KAAK,iBAAI,gCAAC,WAAD,QAAcA,KAAK,CAACC,OAApB,CAPZ,eAQE,gCAAC,kBAAD,QACGF,MAAM,CAACG,GAAP,CAAW,UAAAC,EAAE;AAAA,4BACZ,gCAAC,SAAD;AAAW,UAAA,KAAK,EAAEA,EAAlB;AAAsB,UAAA,GAAG,EAAEA,EAAE,CAACC,EAA9B;AAAkC,UAAA,OAAO,EAAE;AAAA,mBAAMtC,WAAW,CAACqC,EAAD,CAAjB;AAAA;AAA3C,UADY;AAAA,OAAb,CADH,CARF,CADF;AAgBD;;;EAtB+BE,kBAAMC,S;;iCAAlCR,mB,eACejC,S;eAwBNiC,mB","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 PropTypes from 'prop-types';\nimport styled from 'styled-components';\nimport moment from 'moment';\nimport {LeftArrow} from 'components/common/icons';\nimport {FormattedMessage} from 'localization';\n\nconst imageH = 108;\n\nconst propTypes = {\n  onLoadAsset: PropTypes.func.isRequired,\n  back: PropTypes.func.isRequired\n};\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 => moment.duration(new Date().valueOf() - last).humanize();\n\nconst AssetItem = ({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\nclass StorageAssetsViewer extends React.Component {\n  static propTypes = propTypes;\n\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"]}