UNPKG

kepler.gl

Version:

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

288 lines (240 loc) 37.3 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard"); Object.defineProperty(exports, "__esModule", { value: true }); exports["default"] = void 0; var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends")); var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck")); var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass")); var _assertThisInitialized2 = _interopRequireDefault(require("@babel/runtime/helpers/assertThisInitialized")); 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 = _interopRequireWildcard(require("react")); var _reactLifecyclesCompat = require("react-lifecycles-compat"); var _propTypes = _interopRequireDefault(require("prop-types")); var _classnames = _interopRequireDefault(require("classnames")); var _styledComponents = _interopRequireDefault(require("styled-components")); var _reactMapGl = _interopRequireDefault(require("react-map-gl")); var _styledComponents2 = require("../common/styled-components"); var _mediaBreakpoints = require("../../styles/media-breakpoints"); var _mapboxUtils = require("../../utils/map-style-utils/mapbox-utils"); var _reactIntl = require("react-intl"); var _localization = require("../../localization"); var _templateObject, _templateObject2, _templateObject3, _templateObject4, _templateObject5; function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; } function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { (0, _defineProperty2["default"])(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; } 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 MapH = 190; var MapW = 264; var ErrorMsg = { styleError: 'Failed to load map style, make sure it is published. For private style, paste in your access token.' }; var PreviewMap = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n align-items: center;\n display: flex;\n flex-direction: column;\n justify-content: center;\n margin-left: 116px;\n flex-shrink: 0;\n\n .preview-title {\n font-weight: 500;\n font-size: 10px;\n padding: 8px 0px;\n }\n\n .preview-title.error {\n color: ", ";\n }\n\n ", ";\n\n ", ";\n"])), function (props) { return props.theme.errorColor; }, _mediaBreakpoints.media.portable(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n margin-left: 32px;\n "]))), _mediaBreakpoints.media.palm(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n margin-left: unset;\n .preview-title {\n margin-top: 0px;\n }\n "])))); var StyledPreviewImage = _styledComponents["default"].div(_templateObject4 || (_templateObject4 = (0, _taggedTemplateLiteral2["default"])(["\n background: ", ";\n border-radius: 4px;\n box-shadow: 0 8px 16px 0 rgba(0, 0, 0, 0.18);\n width: ", "px;\n height: ", "px;\n position: relative;\n\n .preview-image-placeholder {\n position: absolute;\n top: 0;\n left: 0;\n }\n\n .preview-image-spinner {\n position: absolute;\n left: calc(50% - 25px);\n top: calc(50% - 25px);\n }\n"])), function (props) { return props.theme.modalImagePlaceHolder; }, MapW, MapH); var InlineLink = _styledComponents["default"].a(_templateObject5 || (_templateObject5 = (0, _taggedTemplateLiteral2["default"])(["\n font-weight: 500;\n\n :hover {\n cursor: pointer;\n }\n"]))); function AddMapStyleModalFactory() { var AddMapStyleModal = /*#__PURE__*/function (_Component) { (0, _inherits2["default"])(AddMapStyleModal, _Component); var _super = _createSuper(AddMapStyleModal); function AddMapStyleModal() { var _this; (0, _classCallCheck2["default"])(this, AddMapStyleModal); for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) { args[_key] = arguments[_key]; } _this = _super.call.apply(_super, [this].concat(args)); (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "state", { reRenderKey: 0, previousToken: null }); (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "loadMapStyleJson", function (style) { _this.props.loadCustomMapStyle({ style: style, error: false }); }); (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "loadMapStyleError", function () { _this.props.loadCustomMapStyle({ error: true }); }); return _this; } (0, _createClass2["default"])(AddMapStyleModal, [{ key: "componentDidUpdate", value: function componentDidUpdate() { var _this2 = this; var map = this.mapRef && this.mapRef.getMap(); if (map && this._map !== map) { this._map = map; map.on('style.load', function () { var style = map.getStyle(); _this2.loadMapStyleJson(style); }); map.on('error', function () { _this2.loadMapStyleError(); }); } } }, { key: "render", value: function render() { var _this3 = this; var _this$props = this.props, inputStyle = _this$props.inputStyle, mapState = _this$props.mapState, mapboxApiUrl = _this$props.mapboxApiUrl, intl = _this$props.intl; var mapboxApiAccessToken = inputStyle.accessToken || this.props.mapboxApiAccessToken; var mapProps = _objectSpread(_objectSpread({}, mapState), {}, { mapboxApiUrl: mapboxApiUrl, mapboxApiAccessToken: mapboxApiAccessToken, preserveDrawingBuffer: true, transformRequest: _mapboxUtils.transformRequest }); return /*#__PURE__*/_react["default"].createElement("div", { className: "add-map-style-modal" }, /*#__PURE__*/_react["default"].createElement(_styledComponents2.StyledModalContent, null, /*#__PURE__*/_react["default"].createElement(_styledComponents2.StyledModalVerticalPanel, null, /*#__PURE__*/_react["default"].createElement(_styledComponents2.StyledModalSection, null, /*#__PURE__*/_react["default"].createElement("div", { className: "modal-section-title" }, /*#__PURE__*/_react["default"].createElement(_localization.FormattedMessage, { id: 'modal.addStyle.pasteTitle' })), /*#__PURE__*/_react["default"].createElement("div", { className: "modal-section-subtitle" }, intl.formatMessage({ id: 'modal.addStyle.pasteSubtitle0' }), /*#__PURE__*/_react["default"].createElement(InlineLink, { target: "_blank", href: "https://www.mapbox.com/help/studio-manual-publish/#style-url" }, ' ', intl.formatMessage({ id: 'modal.addStyle.pasteSubtitle2' })), ' ', intl.formatMessage({ id: 'modal.addStyle.pasteSubtitle3' }), /*#__PURE__*/_react["default"].createElement(InlineLink, { target: "_blank", href: "https://docs.mapbox.com/mapbox-gl-js/style-spec" }, ' ', intl.formatMessage({ id: 'modal.addStyle.pasteSubtitle4' }))), /*#__PURE__*/_react["default"].createElement(_styledComponents2.InputLight, { type: "text", value: inputStyle.url || '', onChange: function onChange(_ref) { var value = _ref.target.value; return _this3.props.inputMapStyle({ url: value }); }, placeholder: "e.g. mapbox://styles/username/style, http://my.stles.com/xxx/style.json " })), /*#__PURE__*/_react["default"].createElement(_styledComponents2.StyledModalSection, null, /*#__PURE__*/_react["default"].createElement("div", { className: "modal-section-title" }, /*#__PURE__*/_react["default"].createElement(_localization.FormattedMessage, { id: 'modal.addStyle.publishTitle' })), /*#__PURE__*/_react["default"].createElement("div", { className: "modal-section-subtitle" }, intl.formatMessage({ id: 'modal.addStyle.publishSubtitle1' }), /*#__PURE__*/_react["default"].createElement(InlineLink, { target: "_blank", href: "https://www.mapbox.com/studio/styles/" }, ' ', "mapbox"), ' ', intl.formatMessage({ id: 'modal.addStyle.publishSubtitle2' }), /*#__PURE__*/_react["default"].createElement(InlineLink, { target: "_blank", href: "https://www.mapbox.com/help/studio-manual-publish/" }, ' ', intl.formatMessage({ id: 'modal.addStyle.publishSubtitle3' })), ' ', intl.formatMessage({ id: 'modal.addStyle.publishSubtitle4' })), /*#__PURE__*/_react["default"].createElement("div", { className: "modal-section-subtitle" }, intl.formatMessage({ id: 'modal.addStyle.publishSubtitle5' }), /*#__PURE__*/_react["default"].createElement(InlineLink, { target: "_blank", href: "https://www.mapbox.com/help/how-access-tokens-work/" }, ' ', intl.formatMessage({ id: 'modal.addStyle.publishSubtitle6' })), ' ', intl.formatMessage({ id: 'modal.addStyle.publishSubtitle7' })), /*#__PURE__*/_react["default"].createElement(_styledComponents2.InputLight, { type: "text", value: inputStyle.accessToken || '', onChange: function onChange(_ref2) { var value = _ref2.target.value; return _this3.props.inputMapStyle({ accessToken: value }); }, placeholder: intl.formatMessage({ id: 'modal.addStyle.exampleToken' }) })), /*#__PURE__*/_react["default"].createElement(_styledComponents2.StyledModalSection, null, /*#__PURE__*/_react["default"].createElement("div", { className: "modal-section-title" }, /*#__PURE__*/_react["default"].createElement(_localization.FormattedMessage, { id: 'modal.addStyle.namingTitle' })), /*#__PURE__*/_react["default"].createElement(_styledComponents2.InputLight, { type: "text", value: inputStyle.label || '', onChange: function onChange(_ref3) { var value = _ref3.target.value; return _this3.props.inputMapStyle({ label: value }); } }))), /*#__PURE__*/_react["default"].createElement(PreviewMap, null, /*#__PURE__*/_react["default"].createElement("div", { className: (0, _classnames["default"])('preview-title', { error: inputStyle.error }) }, inputStyle.error ? ErrorMsg.styleError : inputStyle.style && inputStyle.style.name || ''), /*#__PURE__*/_react["default"].createElement(StyledPreviewImage, { className: "preview-image" }, !inputStyle.isValid ? /*#__PURE__*/_react["default"].createElement("div", { className: "preview-image-spinner" }) : /*#__PURE__*/_react["default"].createElement(_styledComponents2.StyledMapContainer, null, /*#__PURE__*/_react["default"].createElement(_reactMapGl["default"], (0, _extends2["default"])({}, mapProps, { ref: function ref(el) { _this3.mapRef = el; }, key: this.state.reRenderKey, width: MapW, height: MapH, mapStyle: inputStyle.url }))))))); } }], [{ key: "getDerivedStateFromProps", value: function getDerivedStateFromProps(props, state) { if (props.inputStyle && props.inputStyle.accessToken && props.inputStyle.accessToken !== state.previousToken) { // toke has changed // ReactMapGl doesn't re-create map when token has changed // here we force the map to update return { reRenderKey: state.reRenderKey + 1, previousToken: props.inputStyle.accessToken }; } return null; } }]); return AddMapStyleModal; }(_react.Component); (0, _defineProperty2["default"])(AddMapStyleModal, "propTypes", { inputMapStyle: _propTypes["default"].func.isRequired, inputStyle: _propTypes["default"].object.isRequired, loadCustomMapStyle: _propTypes["default"].func.isRequired, mapboxApiAccessToken: _propTypes["default"].string.isRequired, mapboxApiUrl: _propTypes["default"].string.isRequired, mapState: _propTypes["default"].object.isRequired }); return (0, _reactIntl.injectIntl)((0, _reactLifecyclesCompat.polyfill)(AddMapStyleModal)); } var _default = AddMapStyleModalFactory; exports["default"] = _default; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/components/modals/add-map-style-modal.js"],"names":["MapH","MapW","ErrorMsg","styleError","PreviewMap","styled","div","props","theme","errorColor","media","portable","palm","StyledPreviewImage","modalImagePlaceHolder","InlineLink","a","AddMapStyleModalFactory","AddMapStyleModal","reRenderKey","previousToken","style","loadCustomMapStyle","error","map","mapRef","getMap","_map","on","getStyle","loadMapStyleJson","loadMapStyleError","inputStyle","mapState","mapboxApiUrl","intl","mapboxApiAccessToken","accessToken","mapProps","preserveDrawingBuffer","transformRequest","formatMessage","id","url","value","target","inputMapStyle","label","name","isValid","el","state","Component","PropTypes","func","isRequired","object","string"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAoBA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AAOA;;AAGA;;AACA;;AACA;;;;;;;;;;;;AAEA,IAAMA,IAAI,GAAG,GAAb;AACA,IAAMC,IAAI,GAAG,GAAb;AACA,IAAMC,QAAQ,GAAG;AACfC,EAAAA,UAAU,EACR;AAFa,CAAjB;;AAKA,IAAMC,UAAU,GAAGC,6BAAOC,GAAV,4YAeH,UAAAC,KAAK;AAAA,SAAIA,KAAK,CAACC,KAAN,CAAYC,UAAhB;AAAA,CAfF,EAkBZC,wBAAMC,QAlBM,sHAsBZD,wBAAME,IAtBM,2KAAhB;;AA8BA,IAAMC,kBAAkB,GAAGR,6BAAOC,GAAV,ocACR,UAAAC,KAAK;AAAA,SAAIA,KAAK,CAACC,KAAN,CAAYM,qBAAhB;AAAA,CADG,EAIbb,IAJa,EAKZD,IALY,CAAxB;;AAqBA,IAAMe,UAAU,GAAGV,6BAAOW,CAAV,wJAAhB;;AAQA,SAASC,uBAAT,GAAmC;AAAA,MAC3BC,gBAD2B;AAAA;;AAAA;;AAAA;AAAA;;AAAA;;AAAA;AAAA;AAAA;;AAAA;AAAA,gGAWvB;AACNC,QAAAA,WAAW,EAAE,CADP;AAENC,QAAAA,aAAa,EAAE;AAFT,OAXuB;AAAA,2GAmDZ,UAAAC,KAAK,EAAI;AAC1B,cAAKd,KAAL,CAAWe,kBAAX,CAA8B;AAACD,UAAAA,KAAK,EAALA,KAAD;AAAQE,UAAAA,KAAK,EAAE;AAAf,SAA9B;AACD,OArD8B;AAAA,4GAuDX,YAAM;AACxB,cAAKhB,KAAL,CAAWe,kBAAX,CAA8B;AAACC,UAAAA,KAAK,EAAE;AAAR,SAA9B;AACD,OAzD8B;AAAA;AAAA;;AAAA;AAAA;AAAA,aAmC/B,8BAAqB;AAAA;;AACnB,YAAMC,GAAG,GAAG,KAAKC,MAAL,IAAe,KAAKA,MAAL,CAAYC,MAAZ,EAA3B;;AACA,YAAIF,GAAG,IAAI,KAAKG,IAAL,KAAcH,GAAzB,EAA8B;AAC5B,eAAKG,IAAL,GAAYH,GAAZ;AAEAA,UAAAA,GAAG,CAACI,EAAJ,CAAO,YAAP,EAAqB,YAAM;AACzB,gBAAMP,KAAK,GAAGG,GAAG,CAACK,QAAJ,EAAd;;AACA,YAAA,MAAI,CAACC,gBAAL,CAAsBT,KAAtB;AACD,WAHD;AAKAG,UAAAA,GAAG,CAACI,EAAJ,CAAO,OAAP,EAAgB,YAAM;AACpB,YAAA,MAAI,CAACG,iBAAL;AACD,WAFD;AAGD;AACF;AAjD8B;AAAA;AAAA,aA2D/B,kBAAS;AAAA;;AAAA,0BAC4C,KAAKxB,KADjD;AAAA,YACAyB,UADA,eACAA,UADA;AAAA,YACYC,QADZ,eACYA,QADZ;AAAA,YACsBC,YADtB,eACsBA,YADtB;AAAA,YACoCC,IADpC,eACoCA,IADpC;AAGP,YAAMC,oBAAoB,GAAGJ,UAAU,CAACK,WAAX,IAA0B,KAAK9B,KAAL,CAAW6B,oBAAlE;;AACA,YAAME,QAAQ,mCACTL,QADS;AAEZC,UAAAA,YAAY,EAAZA,YAFY;AAGZE,UAAAA,oBAAoB,EAApBA,oBAHY;AAIZG,UAAAA,qBAAqB,EAAE,IAJX;AAKZC,UAAAA,gBAAgB,EAAhBA;AALY,UAAd;;AAQA,4BACE;AAAK,UAAA,SAAS,EAAC;AAAf,wBACE,gCAAC,qCAAD,qBACE,gCAAC,2CAAD,qBACE,gCAAC,qCAAD,qBACE;AAAK,UAAA,SAAS,EAAC;AAAf,wBACE,gCAAC,8BAAD;AAAkB,UAAA,EAAE,EAAE;AAAtB,UADF,CADF,eAIE;AAAK,UAAA,SAAS,EAAC;AAAf,WACGL,IAAI,CAACM,aAAL,CAAmB;AAACC,UAAAA,EAAE,EAAE;AAAL,SAAnB,CADH,eAEE,gCAAC,UAAD;AACE,UAAA,MAAM,EAAC,QADT;AAEE,UAAA,IAAI,EAAC;AAFP,WAIG,GAJH,EAKGP,IAAI,CAACM,aAAL,CAAmB;AAACC,UAAAA,EAAE,EAAE;AAAL,SAAnB,CALH,CAFF,EAQgB,GARhB,EASGP,IAAI,CAACM,aAAL,CAAmB;AAACC,UAAAA,EAAE,EAAE;AAAL,SAAnB,CATH,eAUE,gCAAC,UAAD;AACE,UAAA,MAAM,EAAC,QADT;AAEE,UAAA,IAAI,EAAC;AAFP,WAIG,GAJH,EAKGP,IAAI,CAACM,aAAL,CAAmB;AAACC,UAAAA,EAAE,EAAE;AAAL,SAAnB,CALH,CAVF,CAJF,eAsBE,gCAAC,6BAAD;AACE,UAAA,IAAI,EAAC,MADP;AAEE,UAAA,KAAK,EAAEV,UAAU,CAACW,GAAX,IAAkB,EAF3B;AAGE,UAAA,QAAQ,EAAE;AAAA,gBAAWC,KAAX,QAAEC,MAAF,CAAWD,KAAX;AAAA,mBAAuB,MAAI,CAACrC,KAAL,CAAWuC,aAAX,CAAyB;AAACH,cAAAA,GAAG,EAAEC;AAAN,aAAzB,CAAvB;AAAA,WAHZ;AAIE,UAAA,WAAW,EAAC;AAJd,UAtBF,CADF,eA+BE,gCAAC,qCAAD,qBACE;AAAK,UAAA,SAAS,EAAC;AAAf,wBACE,gCAAC,8BAAD;AAAkB,UAAA,EAAE,EAAE;AAAtB,UADF,CADF,eAIE;AAAK,UAAA,SAAS,EAAC;AAAf,WACGT,IAAI,CAACM,aAAL,CAAmB;AAACC,UAAAA,EAAE,EAAE;AAAL,SAAnB,CADH,eAEE,gCAAC,UAAD;AAAY,UAAA,MAAM,EAAC,QAAnB;AAA4B,UAAA,IAAI,EAAC;AAAjC,WACG,GADH,WAFF,EAKgB,GALhB,EAMGP,IAAI,CAACM,aAAL,CAAmB;AAACC,UAAAA,EAAE,EAAE;AAAL,SAAnB,CANH,eAOE,gCAAC,UAAD;AACE,UAAA,MAAM,EAAC,QADT;AAEE,UAAA,IAAI,EAAC;AAFP,WAIG,GAJH,EAKGP,IAAI,CAACM,aAAL,CAAmB;AAACC,UAAAA,EAAE,EAAE;AAAL,SAAnB,CALH,CAPF,EAagB,GAbhB,EAcGP,IAAI,CAACM,aAAL,CAAmB;AAACC,UAAAA,EAAE,EAAE;AAAL,SAAnB,CAdH,CAJF,eAqBE;AAAK,UAAA,SAAS,EAAC;AAAf,WACGP,IAAI,CAACM,aAAL,CAAmB;AAACC,UAAAA,EAAE,EAAE;AAAL,SAAnB,CADH,eAEE,gCAAC,UAAD;AACE,UAAA,MAAM,EAAC,QADT;AAEE,UAAA,IAAI,EAAC;AAFP,WAIG,GAJH,EAKGP,IAAI,CAACM,aAAL,CAAmB;AAACC,UAAAA,EAAE,EAAE;AAAL,SAAnB,CALH,CAFF,EAQgB,GARhB,EASGP,IAAI,CAACM,aAAL,CAAmB;AAACC,UAAAA,EAAE,EAAE;AAAL,SAAnB,CATH,CArBF,eAgCE,gCAAC,6BAAD;AACE,UAAA,IAAI,EAAC,MADP;AAEE,UAAA,KAAK,EAAEV,UAAU,CAACK,WAAX,IAA0B,EAFnC;AAGE,UAAA,QAAQ,EAAE;AAAA,gBAAWO,KAAX,SAAEC,MAAF,CAAWD,KAAX;AAAA,mBAAuB,MAAI,CAACrC,KAAL,CAAWuC,aAAX,CAAyB;AAACT,cAAAA,WAAW,EAAEO;AAAd,aAAzB,CAAvB;AAAA,WAHZ;AAIE,UAAA,WAAW,EAAET,IAAI,CAACM,aAAL,CAAmB;AAACC,YAAAA,EAAE,EAAE;AAAL,WAAnB;AAJf,UAhCF,CA/BF,eAuEE,gCAAC,qCAAD,qBACE;AAAK,UAAA,SAAS,EAAC;AAAf,wBACE,gCAAC,8BAAD;AAAkB,UAAA,EAAE,EAAE;AAAtB,UADF,CADF,eAIE,gCAAC,6BAAD;AACE,UAAA,IAAI,EAAC,MADP;AAEE,UAAA,KAAK,EAAEV,UAAU,CAACe,KAAX,IAAoB,EAF7B;AAGE,UAAA,QAAQ,EAAE;AAAA,gBAAWH,KAAX,SAAEC,MAAF,CAAWD,KAAX;AAAA,mBAAuB,MAAI,CAACrC,KAAL,CAAWuC,aAAX,CAAyB;AAACC,cAAAA,KAAK,EAAEH;AAAR,aAAzB,CAAvB;AAAA;AAHZ,UAJF,CAvEF,CADF,eAmFE,gCAAC,UAAD,qBACE;AACE,UAAA,SAAS,EAAE,4BAAW,eAAX,EAA4B;AACrCrB,YAAAA,KAAK,EAAES,UAAU,CAACT;AADmB,WAA5B;AADb,WAKGS,UAAU,CAACT,KAAX,GACGrB,QAAQ,CAACC,UADZ,GAEI6B,UAAU,CAACX,KAAX,IAAoBW,UAAU,CAACX,KAAX,CAAiB2B,IAAtC,IAA+C,EAPrD,CADF,eAUE,gCAAC,kBAAD;AAAoB,UAAA,SAAS,EAAC;AAA9B,WACG,CAAChB,UAAU,CAACiB,OAAZ,gBACC;AAAK,UAAA,SAAS,EAAC;AAAf,UADD,gBAGC,gCAAC,qCAAD,qBACE,gCAAC,sBAAD,gCACMX,QADN;AAEE,UAAA,GAAG,EAAE,aAAAY,EAAE,EAAI;AACT,YAAA,MAAI,CAACzB,MAAL,GAAcyB,EAAd;AACD,WAJH;AAKE,UAAA,GAAG,EAAE,KAAKC,KAAL,CAAWhC,WALlB;AAME,UAAA,KAAK,EAAElB,IANT;AAOE,UAAA,MAAM,EAAED,IAPV;AAQE,UAAA,QAAQ,EAAEgC,UAAU,CAACW;AARvB,WADF,CAJJ,CAVF,CAnFF,CADF,CADF;AAqHD;AA5L8B;AAAA;AAAA,aAgB/B,kCAAgCpC,KAAhC,EAAuC4C,KAAvC,EAA8C;AAC5C,YACE5C,KAAK,CAACyB,UAAN,IACAzB,KAAK,CAACyB,UAAN,CAAiBK,WADjB,IAEA9B,KAAK,CAACyB,UAAN,CAAiBK,WAAjB,KAAiCc,KAAK,CAAC/B,aAHzC,EAIE;AACA;AACA;AACA;AAEA,iBAAO;AACLD,YAAAA,WAAW,EAAEgC,KAAK,CAAChC,WAAN,GAAoB,CAD5B;AAELC,YAAAA,aAAa,EAAEb,KAAK,CAACyB,UAAN,CAAiBK;AAF3B,WAAP;AAID;;AAED,eAAO,IAAP;AACD;AAjC8B;AAAA;AAAA,IACFe,gBADE;;AAAA,mCAC3BlC,gBAD2B,eAEZ;AACjB4B,IAAAA,aAAa,EAAEO,sBAAUC,IAAV,CAAeC,UADb;AAEjBvB,IAAAA,UAAU,EAAEqB,sBAAUG,MAAV,CAAiBD,UAFZ;AAGjBjC,IAAAA,kBAAkB,EAAE+B,sBAAUC,IAAV,CAAeC,UAHlB;AAIjBnB,IAAAA,oBAAoB,EAAEiB,sBAAUI,MAAV,CAAiBF,UAJtB;AAKjBrB,IAAAA,YAAY,EAAEmB,sBAAUI,MAAV,CAAiBF,UALd;AAMjBtB,IAAAA,QAAQ,EAAEoB,sBAAUG,MAAV,CAAiBD;AANV,GAFY;AA+LjC,SAAO,2BAAW,qCAASrC,gBAAT,CAAX,CAAP;AACD;;eAEcD,uB","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, {Component} from 'react';\nimport {polyfill} from 'react-lifecycles-compat';\nimport PropTypes from 'prop-types';\nimport classnames from 'classnames';\nimport styled from 'styled-components';\nimport MapboxGLMap from 'react-map-gl';\nimport {\n  StyledModalContent,\n  InputLight,\n  StyledMapContainer,\n  StyledModalVerticalPanel,\n  StyledModalSection\n} from 'components/common/styled-components';\nimport {media} from 'styles/media-breakpoints';\n\n// Utils\nimport {transformRequest} from 'utils/map-style-utils/mapbox-utils';\nimport {injectIntl} from 'react-intl';\nimport {FormattedMessage} from 'localization';\n\nconst MapH = 190;\nconst MapW = 264;\nconst ErrorMsg = {\n  styleError:\n    'Failed to load map style, make sure it is published. For private style, paste in your access token.'\n};\n\nconst PreviewMap = styled.div`\n  align-items: center;\n  display: flex;\n  flex-direction: column;\n  justify-content: center;\n  margin-left: 116px;\n  flex-shrink: 0;\n\n  .preview-title {\n    font-weight: 500;\n    font-size: 10px;\n    padding: 8px 0px;\n  }\n\n  .preview-title.error {\n    color: ${props => props.theme.errorColor};\n  }\n\n  ${media.portable`\n    margin-left: 32px;\n  `};\n\n  ${media.palm`\n    margin-left: unset;\n    .preview-title {\n      margin-top: 0px;\n    }\n  `};\n`;\n\nconst StyledPreviewImage = styled.div`\n  background: ${props => props.theme.modalImagePlaceHolder};\n  border-radius: 4px;\n  box-shadow: 0 8px 16px 0 rgba(0, 0, 0, 0.18);\n  width: ${MapW}px;\n  height: ${MapH}px;\n  position: relative;\n\n  .preview-image-placeholder {\n    position: absolute;\n    top: 0;\n    left: 0;\n  }\n\n  .preview-image-spinner {\n    position: absolute;\n    left: calc(50% - 25px);\n    top: calc(50% - 25px);\n  }\n`;\n\nconst InlineLink = styled.a`\n  font-weight: 500;\n\n  :hover {\n    cursor: pointer;\n  }\n`;\n\nfunction AddMapStyleModalFactory() {\n  class AddMapStyleModal extends Component {\n    static propTypes = {\n      inputMapStyle: PropTypes.func.isRequired,\n      inputStyle: PropTypes.object.isRequired,\n      loadCustomMapStyle: PropTypes.func.isRequired,\n      mapboxApiAccessToken: PropTypes.string.isRequired,\n      mapboxApiUrl: PropTypes.string.isRequired,\n      mapState: PropTypes.object.isRequired\n    };\n\n    state = {\n      reRenderKey: 0,\n      previousToken: null\n    };\n\n    static getDerivedStateFromProps(props, state) {\n      if (\n        props.inputStyle &&\n        props.inputStyle.accessToken &&\n        props.inputStyle.accessToken !== state.previousToken\n      ) {\n        // toke has changed\n        // ReactMapGl doesn't re-create map when token has changed\n        // here we force the map to update\n\n        return {\n          reRenderKey: state.reRenderKey + 1,\n          previousToken: props.inputStyle.accessToken\n        };\n      }\n\n      return null;\n    }\n\n    componentDidUpdate() {\n      const map = this.mapRef && this.mapRef.getMap();\n      if (map && this._map !== map) {\n        this._map = map;\n\n        map.on('style.load', () => {\n          const style = map.getStyle();\n          this.loadMapStyleJson(style);\n        });\n\n        map.on('error', () => {\n          this.loadMapStyleError();\n        });\n      }\n    }\n\n    loadMapStyleJson = style => {\n      this.props.loadCustomMapStyle({style, error: false});\n    };\n\n    loadMapStyleError = () => {\n      this.props.loadCustomMapStyle({error: true});\n    };\n\n    render() {\n      const {inputStyle, mapState, mapboxApiUrl, intl} = this.props;\n\n      const mapboxApiAccessToken = inputStyle.accessToken || this.props.mapboxApiAccessToken;\n      const mapProps = {\n        ...mapState,\n        mapboxApiUrl,\n        mapboxApiAccessToken,\n        preserveDrawingBuffer: true,\n        transformRequest\n      };\n\n      return (\n        <div className=\"add-map-style-modal\">\n          <StyledModalContent>\n            <StyledModalVerticalPanel>\n              <StyledModalSection>\n                <div className=\"modal-section-title\">\n                  <FormattedMessage id={'modal.addStyle.pasteTitle'} />\n                </div>\n                <div className=\"modal-section-subtitle\">\n                  {intl.formatMessage({id: 'modal.addStyle.pasteSubtitle0'})}\n                  <InlineLink\n                    target=\"_blank\"\n                    href=\"https://www.mapbox.com/help/studio-manual-publish/#style-url\"\n                  >\n                    {' '}\n                    {intl.formatMessage({id: 'modal.addStyle.pasteSubtitle2'})}\n                  </InlineLink>{' '}\n                  {intl.formatMessage({id: 'modal.addStyle.pasteSubtitle3'})}\n                  <InlineLink\n                    target=\"_blank\"\n                    href=\"https://docs.mapbox.com/mapbox-gl-js/style-spec\"\n                  >\n                    {' '}\n                    {intl.formatMessage({id: 'modal.addStyle.pasteSubtitle4'})}\n                  </InlineLink>\n                </div>\n                <InputLight\n                  type=\"text\"\n                  value={inputStyle.url || ''}\n                  onChange={({target: {value}}) => this.props.inputMapStyle({url: value})}\n                  placeholder=\"e.g. mapbox://styles/username/style, http://my.stles.com/xxx/style.json \"\n                />\n              </StyledModalSection>\n\n              <StyledModalSection>\n                <div className=\"modal-section-title\">\n                  <FormattedMessage id={'modal.addStyle.publishTitle'} />\n                </div>\n                <div className=\"modal-section-subtitle\">\n                  {intl.formatMessage({id: 'modal.addStyle.publishSubtitle1'})}\n                  <InlineLink target=\"_blank\" href=\"https://www.mapbox.com/studio/styles/\">\n                    {' '}\n                    mapbox\n                  </InlineLink>{' '}\n                  {intl.formatMessage({id: 'modal.addStyle.publishSubtitle2'})}\n                  <InlineLink\n                    target=\"_blank\"\n                    href=\"https://www.mapbox.com/help/studio-manual-publish/\"\n                  >\n                    {' '}\n                    {intl.formatMessage({id: 'modal.addStyle.publishSubtitle3'})}\n                  </InlineLink>{' '}\n                  {intl.formatMessage({id: 'modal.addStyle.publishSubtitle4'})}\n                </div>\n\n                <div className=\"modal-section-subtitle\">\n                  {intl.formatMessage({id: 'modal.addStyle.publishSubtitle5'})}\n                  <InlineLink\n                    target=\"_blank\"\n                    href=\"https://www.mapbox.com/help/how-access-tokens-work/\"\n                  >\n                    {' '}\n                    {intl.formatMessage({id: 'modal.addStyle.publishSubtitle6'})}\n                  </InlineLink>{' '}\n                  {intl.formatMessage({id: 'modal.addStyle.publishSubtitle7'})}\n                </div>\n                <InputLight\n                  type=\"text\"\n                  value={inputStyle.accessToken || ''}\n                  onChange={({target: {value}}) => this.props.inputMapStyle({accessToken: value})}\n                  placeholder={intl.formatMessage({id: 'modal.addStyle.exampleToken'})}\n                />\n              </StyledModalSection>\n\n              <StyledModalSection>\n                <div className=\"modal-section-title\">\n                  <FormattedMessage id={'modal.addStyle.namingTitle'} />\n                </div>\n                <InputLight\n                  type=\"text\"\n                  value={inputStyle.label || ''}\n                  onChange={({target: {value}}) => this.props.inputMapStyle({label: value})}\n                />\n              </StyledModalSection>\n            </StyledModalVerticalPanel>\n            <PreviewMap>\n              <div\n                className={classnames('preview-title', {\n                  error: inputStyle.error\n                })}\n              >\n                {inputStyle.error\n                  ? ErrorMsg.styleError\n                  : (inputStyle.style && inputStyle.style.name) || ''}\n              </div>\n              <StyledPreviewImage className=\"preview-image\">\n                {!inputStyle.isValid ? (\n                  <div className=\"preview-image-spinner\" />\n                ) : (\n                  <StyledMapContainer>\n                    <MapboxGLMap\n                      {...mapProps}\n                      ref={el => {\n                        this.mapRef = el;\n                      }}\n                      key={this.state.reRenderKey}\n                      width={MapW}\n                      height={MapH}\n                      mapStyle={inputStyle.url}\n                    />\n                  </StyledMapContainer>\n                )}\n              </StyledPreviewImage>\n            </PreviewMap>\n          </StyledModalContent>\n        </div>\n      );\n    }\n  }\n\n  return injectIntl(polyfill(AddMapStyleModal));\n}\n\nexport default AddMapStyleModalFactory;\n"]}