kepler.gl
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
252 lines (250 loc) • 47.1 kB
JavaScript
"use strict";
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
var _typeof = require("@babel/runtime/helpers/typeof");
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 _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime/helpers/possibleConstructorReturn"));
var _getPrototypeOf2 = _interopRequireDefault(require("@babel/runtime/helpers/getPrototypeOf"));
var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits"));
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 _classnames = _interopRequireDefault(require("classnames"));
var _styledComponents = _interopRequireDefault(require("styled-components"));
var _reactMapGl = require("react-map-gl");
var _styledComponents2 = require("../common/styled-components");
var _styles = require("@kepler.gl/styles");
var _utils = require("@kepler.gl/utils");
var _reactIntl = require("react-intl");
var _localization = require("@kepler.gl/localization");
var _constants = require("@kepler.gl/constants");
var _templateObject, _templateObject2, _templateObject3, _templateObject4, _templateObject5; // SPDX-License-Identifier: MIT
// Copyright contributors to the kepler.gl project
// Utils
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; }
function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { (0, _defineProperty2["default"])(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
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 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 max-width: 250px;\n }\n\n ", ";\n\n ", ";\n"])), function (props) {
return props.theme.errorColor;
}, _styles.media.portable(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n margin-left: 32px;\n "]))), _styles.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"])));
var nop = function nop() {
return;
};
function AddMapStyleModalFactory() {
var AddMapStyleModal = /*#__PURE__*/function (_Component) {
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 = _callSuper(this, AddMapStyleModal, [].concat(args));
(0, _defineProperty2["default"])(_this, "state", {
reRenderKey: 0,
previousToken: null
});
(0, _defineProperty2["default"])(_this, "_map", void 0);
(0, _defineProperty2["default"])(_this, "_setMapRef", function (mapRef) {
// Handle change of the basemap library
if (_this._map && mapRef) {
var _map = mapRef.getMap();
if (_map && _this._map !== _map) {
_this._map.off('style.load', nop);
_this._map.off('error', nop);
_this._map = null;
}
}
var map = mapRef && mapRef.getMap();
if (map && _this._map !== map) {
_this._map = map;
map.on('style.load', function () {
var style = map.getStyle();
_this.loadMapStyleJson(style);
});
map.on('error', function () {
_this.loadMapStyleError();
});
}
});
(0, _defineProperty2["default"])(_this, "loadMapStyleJson", function (style) {
_this.props.loadCustomMapStyle({
style: style,
error: false
});
});
(0, _defineProperty2["default"])(_this, "loadMapStyleError", function () {
_this.props.loadCustomMapStyle({
error: true
});
});
return _this;
}
(0, _inherits2["default"])(AddMapStyleModal, _Component);
return (0, _createClass2["default"])(AddMapStyleModal, [{
key: "render",
value: function render() {
var _this$props$transform,
_this$props2,
_this2 = this;
var _this$props = this.props,
inputStyle = _this$props.inputStyle,
mapState = _this$props.mapState,
intl = _this$props.intl;
var baseMapLibraryName = (0, _utils.getBaseMapLibrary)(inputStyle);
var baseMapLibraryConfig = (0, _utils.getApplicationConfig)().baseMapLibraryConfig[baseMapLibraryName];
var mapboxApiAccessToken = inputStyle.accessToken || this.props.mapboxApiAccessToken;
var mapProps = _objectSpread(_objectSpread({}, mapState), {}, {
// TODO baseApiUrl should be taken into account in transformRequest as we use dynamic mapLib import
// baseApiUrl: mapboxApiUrl,
mapboxAccessToken: mapboxApiAccessToken,
mapLib: baseMapLibraryConfig.getMapLib(),
preserveDrawingBuffer: true,
transformRequest: ((_this$props$transform = (_this$props2 = this.props).transformRequest) === null || _this$props$transform === void 0 ? void 0 : _this$props$transform.call(_this$props2, mapboxApiAccessToken)) || (0, _utils.transformRequest)(mapboxApiAccessToken)
});
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 _this2.props.inputMapStyle({
url: value,
id: 'Custom Style',
icon: "".concat((0, _utils.getApplicationConfig)().cdnUrl, "/").concat(_constants.NO_BASEMAP_ICON)
});
},
placeholder: "e.g. https://basemaps.cartocdn.com/gl/positron-gl-style/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 _this2.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 _this2.props.inputMapStyle({
label: value
});
},
placeholder: "Name your style"
}))), /*#__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.Map, (0, _extends2["default"])({}, mapProps, {
ref: this._setMapRef,
key: "".concat(baseMapLibraryName, "-").concat(this.state.reRenderKey, "-").concat(inputStyle.url, "-").concat(mapboxApiAccessToken),
style: {
width: MapW,
height: MapH
},
mapStyle: inputStyle.url === null ? undefined : 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;
}
}]);
}(_react.Component);
return (0, _reactIntl.injectIntl)((0, _reactLifecyclesCompat.polyfill)(AddMapStyleModal));
}
var _default = exports["default"] = AddMapStyleModalFactory;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_reactLifecyclesCompat","_classnames","_interopRequireDefault","_styledComponents","_reactMapGl","_styledComponents2","_styles","_utils","_reactIntl","_localization","_constants","_templateObject","_templateObject2","_templateObject3","_templateObject4","_templateObject5","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","_typeof","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","ownKeys","keys","getOwnPropertySymbols","o","filter","enumerable","push","apply","_objectSpread","arguments","length","forEach","_defineProperty2","getOwnPropertyDescriptors","defineProperties","_callSuper","_getPrototypeOf2","_possibleConstructorReturn2","_isNativeReflectConstruct","Reflect","construct","constructor","Boolean","prototype","valueOf","MapH","MapW","ErrorMsg","styleError","PreviewMap","styled","div","_taggedTemplateLiteral2","props","theme","errorColor","media","portable","palm","StyledPreviewImage","modalImagePlaceHolder","InlineLink","nop","AddMapStyleModalFactory","AddMapStyleModal","_Component","_this","_classCallCheck2","_len","args","Array","_key","concat","reRenderKey","previousToken","mapRef","_map","map","getMap","off","on","style","getStyle","loadMapStyleJson","loadMapStyleError","loadCustomMapStyle","error","_inherits2","_createClass2","key","value","render","_this$props$transform","_this$props2","_this2","_this$props","inputStyle","mapState","intl","baseMapLibraryName","getBaseMapLibrary","baseMapLibraryConfig","getApplicationConfig","mapboxApiAccessToken","accessToken","mapProps","mapboxAccessToken","mapLib","getMapLib","preserveDrawingBuffer","transformRequest","createElement","className","StyledModalContent","StyledModalVerticalPanel","StyledModalSection","FormattedMessage","id","formatMessage","target","href","InputLight","type","url","onChange","_ref","inputMapStyle","icon","cdnUrl","NO_BASEMAP_ICON","placeholder","_ref2","label","_ref3","classnames","name","isValid","StyledMapContainer","Map","_extends2","ref","_setMapRef","state","width","height","mapStyle","undefined","getDerivedStateFromProps","Component","injectIntl","polyfill","_default","exports"],"sources":["../../src/modals/add-map-style-modal.tsx"],"sourcesContent":["// SPDX-License-Identifier: MIT\n// Copyright contributors to the kepler.gl project\n\nimport React, {Component} from 'react';\nimport {polyfill} from 'react-lifecycles-compat';\nimport classnames from 'classnames';\nimport styled from 'styled-components';\nimport {Map, MapboxMap, MapRef} from 'react-map-gl';\nimport {\n  StyledModalContent,\n  InputLight,\n  StyledMapContainer,\n  StyledModalVerticalPanel,\n  StyledModalSection\n} from '../common/styled-components';\nimport {media} from '@kepler.gl/styles';\n\n// Utils\nimport {getApplicationConfig, getBaseMapLibrary, transformRequest} from '@kepler.gl/utils';\nimport {injectIntl, IntlShape} from 'react-intl';\nimport {FormattedMessage} from '@kepler.gl/localization';\nimport {NO_BASEMAP_ICON} from '@kepler.gl/constants';\nimport {InputStyle, MapState} from '@kepler.gl/types';\nimport {ActionHandler, inputMapStyle, loadCustomMapStyle} from '@kepler.gl/actions';\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    max-width: 250px;\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\nconst nop = () => {\n  return;\n};\n\ninterface AddMapStyleModalProps {\n  inputMapStyle: ActionHandler<typeof inputMapStyle>;\n  inputStyle: InputStyle;\n  loadCustomMapStyle: ActionHandler<typeof loadCustomMapStyle>;\n  mapboxApiAccessToken: string;\n  mapboxApiUrl?: string;\n  transformRequest?: (mapboxKey: string) => (\n    url: string,\n    resourceType: string\n  ) => {\n    url: string;\n  };\n  mapState: MapState;\n  intl: IntlShape;\n}\n\nfunction AddMapStyleModalFactory() {\n  class AddMapStyleModal extends Component<AddMapStyleModalProps> {\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    _map: MapboxMap | undefined | null;\n\n    _setMapRef = (mapRef: MapRef) => {\n      // Handle change of the basemap library\n      if (this._map && mapRef) {\n        const map = mapRef.getMap();\n        if (map && this._map !== map) {\n          this._map.off('style.load', nop);\n          this._map.off('error', nop);\n          this._map = null;\n        }\n      }\n\n      const map = mapRef && 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, intl} = this.props;\n\n      const baseMapLibraryName = getBaseMapLibrary(inputStyle);\n      const baseMapLibraryConfig = getApplicationConfig().baseMapLibraryConfig[baseMapLibraryName];\n\n      const mapboxApiAccessToken = inputStyle.accessToken || this.props.mapboxApiAccessToken;\n      const mapProps = {\n        ...mapState,\n        // TODO baseApiUrl should be taken into account in transformRequest as we use dynamic mapLib import\n        // baseApiUrl: mapboxApiUrl,\n        mapboxAccessToken: mapboxApiAccessToken,\n        mapLib: baseMapLibraryConfig.getMapLib(),\n        preserveDrawingBuffer: true,\n        transformRequest:\n          this.props.transformRequest?.(mapboxApiAccessToken) ||\n          transformRequest(mapboxApiAccessToken)\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}}) =>\n                    this.props.inputMapStyle({\n                      url: value,\n                      id: 'Custom Style',\n                      icon: `${getApplicationConfig().cdnUrl}/${NO_BASEMAP_ICON}`\n                    })\n                  }\n                  placeholder=\"e.g. https://basemaps.cartocdn.com/gl/positron-gl-style/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                  placeholder=\"Name your style\"\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                {/** Note, we need the Map to render with errored params to get style.error messages */}\n                {!inputStyle.isValid ? (\n                  <div className=\"preview-image-spinner\" />\n                ) : (\n                  <StyledMapContainer>\n                    <Map\n                      {...mapProps}\n                      ref={this._setMapRef}\n                      key={`${baseMapLibraryName}-${this.state.reRenderKey}-${inputStyle.url}-${mapboxApiAccessToken}`}\n                      style={{\n                        width: MapW,\n                        height: MapH\n                      }}\n                      mapStyle={inputStyle.url === null ? undefined : 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"],"mappings":";;;;;;;;;;;;;;;;AAGA,IAAAA,MAAA,GAAAC,uBAAA,CAAAC,OAAA;AACA,IAAAC,sBAAA,GAAAD,OAAA;AACA,IAAAE,WAAA,GAAAC,sBAAA,CAAAH,OAAA;AACA,IAAAI,iBAAA,GAAAD,sBAAA,CAAAH,OAAA;AACA,IAAAK,WAAA,GAAAL,OAAA;AACA,IAAAM,kBAAA,GAAAN,OAAA;AAOA,IAAAO,OAAA,GAAAP,OAAA;AAGA,IAAAQ,MAAA,GAAAR,OAAA;AACA,IAAAS,UAAA,GAAAT,OAAA;AACA,IAAAU,aAAA,GAAAV,OAAA;AACA,IAAAW,UAAA,GAAAX,OAAA;AAAqD,IAAAY,eAAA,EAAAC,gBAAA,EAAAC,gBAAA,EAAAC,gBAAA,EAAAC,gBAAA,EArBrD;AACA;AAgBA;AAAA,SAAAC,yBAAAC,CAAA,6BAAAC,OAAA,mBAAAC,CAAA,OAAAD,OAAA,IAAAE,CAAA,OAAAF,OAAA,YAAAF,wBAAA,YAAAA,yBAAAC,CAAA,WAAAA,CAAA,GAAAG,CAAA,GAAAD,CAAA,KAAAF,CAAA;AAAA,SAAAnB,wBAAAmB,CAAA,EAAAE,CAAA,SAAAA,CAAA,IAAAF,CAAA,IAAAA,CAAA,CAAAI,UAAA,SAAAJ,CAAA,eAAAA,CAAA,gBAAAK,OAAA,CAAAL,CAAA,0BAAAA,CAAA,sBAAAA,CAAA,QAAAG,CAAA,GAAAJ,wBAAA,CAAAG,CAAA,OAAAC,CAAA,IAAAA,CAAA,CAAAG,GAAA,CAAAN,CAAA,UAAAG,CAAA,CAAAI,GAAA,CAAAP,CAAA,OAAAQ,CAAA,KAAAC,SAAA,UAAAC,CAAA,GAAAC,MAAA,CAAAC,cAAA,IAAAD,MAAA,CAAAE,wBAAA,WAAAC,CAAA,IAAAd,CAAA,oBAAAc,CAAA,OAAAC,cAAA,CAAAC,IAAA,CAAAhB,CAAA,EAAAc,CAAA,SAAAG,CAAA,GAAAP,CAAA,GAAAC,MAAA,CAAAE,wBAAA,CAAAb,CAAA,EAAAc,CAAA,UAAAG,CAAA,KAAAA,CAAA,CAAAV,GAAA,IAAAU,CAAA,CAAAC,GAAA,IAAAP,MAAA,CAAAC,cAAA,CAAAJ,CAAA,EAAAM,CAAA,EAAAG,CAAA,IAAAT,CAAA,CAAAM,CAAA,IAAAd,CAAA,CAAAc,CAAA,YAAAN,CAAA,cAAAR,CAAA,EAAAG,CAAA,IAAAA,CAAA,CAAAe,GAAA,CAAAlB,CAAA,EAAAQ,CAAA,GAAAA,CAAA;AAAA,SAAAW,QAAAnB,CAAA,EAAAE,CAAA,QAAAC,CAAA,GAAAQ,MAAA,CAAAS,IAAA,CAAApB,CAAA,OAAAW,MAAA,CAAAU,qBAAA,QAAAC,CAAA,GAAAX,MAAA,CAAAU,qBAAA,CAAArB,CAAA,GAAAE,CAAA,KAAAoB,CAAA,GAAAA,CAAA,CAAAC,MAAA,WAAArB,CAAA,WAAAS,MAAA,CAAAE,wBAAA,CAAAb,CAAA,EAAAE,CAAA,EAAAsB,UAAA,OAAArB,CAAA,CAAAsB,IAAA,CAAAC,KAAA,CAAAvB,CAAA,EAAAmB,CAAA,YAAAnB,CAAA;AAAA,SAAAwB,cAAA3B,CAAA,aAAAE,CAAA,MAAAA,CAAA,GAAA0B,SAAA,CAAAC,MAAA,EAAA3B,CAAA,UAAAC,CAAA,WAAAyB,SAAA,CAAA1B,CAAA,IAAA0B,SAAA,CAAA1B,CAAA,QAAAA,CAAA,OAAAiB,OAAA,CAAAR,MAAA,CAAAR,CAAA,OAAA2B,OAAA,WAAA5B,CAAA,QAAA6B,gBAAA,aAAA/B,CAAA,EAAAE,CAAA,EAAAC,CAAA,CAAAD,CAAA,SAAAS,MAAA,CAAAqB,yBAAA,GAAArB,MAAA,CAAAsB,gBAAA,CAAAjC,CAAA,EAAAW,MAAA,CAAAqB,yBAAA,CAAA7B,CAAA,KAAAgB,OAAA,CAAAR,MAAA,CAAAR,CAAA,GAAA2B,OAAA,WAAA5B,CAAA,IAAAS,MAAA,CAAAC,cAAA,CAAAZ,CAAA,EAAAE,CAAA,EAAAS,MAAA,CAAAE,wBAAA,CAAAV,CAAA,EAAAD,CAAA,iBAAAF,CAAA;AAAA,SAAAkC,WAAA/B,CAAA,EAAAmB,CAAA,EAAAtB,CAAA,WAAAsB,CAAA,OAAAa,gBAAA,aAAAb,CAAA,OAAAc,2BAAA,aAAAjC,CAAA,EAAAkC,yBAAA,KAAAC,OAAA,CAAAC,SAAA,CAAAjB,CAAA,EAAAtB,CAAA,YAAAmC,gBAAA,aAAAhC,CAAA,EAAAqC,WAAA,IAAAlB,CAAA,CAAAI,KAAA,CAAAvB,CAAA,EAAAH,CAAA;AAAA,SAAAqC,0BAAA,cAAAlC,CAAA,IAAAsC,OAAA,CAAAC,SAAA,CAAAC,OAAA,CAAA3B,IAAA,CAAAsB,OAAA,CAAAC,SAAA,CAAAE,OAAA,iCAAAtC,CAAA,aAAAkC,yBAAA,YAAAA,0BAAA,aAAAlC,CAAA;AAQA,IAAMyC,IAAI,GAAG,GAAG;AAChB,IAAMC,IAAI,GAAG,GAAG;AAChB,IAAMC,QAAQ,GAAG;EACfC,UAAU,EACR;AACJ,CAAC;AAED,IAAMC,UAAU,GAAGC,4BAAM,CAACC,GAAG,CAAAxD,eAAA,KAAAA,eAAA,OAAAyD,uBAAA,iWAehB,UAAAC,KAAK;EAAA,OAAIA,KAAK,CAACC,KAAK,CAACC,UAAU;AAAA,GAIxCC,aAAK,CAACC,QAAQ,CAAA7D,gBAAA,KAAAA,gBAAA,OAAAwD,uBAAA,kDAIdI,aAAK,CAACE,IAAI,CAAA7D,gBAAA,KAAAA,gBAAA,OAAAuD,uBAAA,uGAMb;AAED,IAAMO,kBAAkB,GAAGT,4BAAM,CAACC,GAAG,CAAArD,gBAAA,KAAAA,gBAAA,OAAAsD,uBAAA,gYACrB,UAAAC,KAAK;EAAA,OAAIA,KAAK,CAACC,KAAK,CAACM,qBAAqB;AAAA,GAG/Cd,IAAI,EACHD,IAAI,CAcf;AAED,IAAMgB,UAAU,GAAGX,4BAAM,CAACvC,CAAC,CAAAZ,gBAAA,KAAAA,gBAAA,OAAAqD,uBAAA,qFAM1B;AAED,IAAMU,GAAG,GAAG,SAANA,GAAGA,CAAA,EAAS;EAChB;AACF,CAAC;AAkBD,SAASC,uBAAuBA,CAAA,EAAG;EAAA,IAC3BC,gBAAgB,0BAAAC,UAAA;IAAA,SAAAD,iBAAA;MAAA,IAAAE,KAAA;MAAA,IAAAC,gBAAA,mBAAAH,gBAAA;MAAA,SAAAI,IAAA,GAAAvC,SAAA,CAAAC,MAAA,EAAAuC,IAAA,OAAAC,KAAA,CAAAF,IAAA,GAAAG,IAAA,MAAAA,IAAA,GAAAH,IAAA,EAAAG,IAAA;QAAAF,IAAA,CAAAE,IAAA,IAAA1C,SAAA,CAAA0C,IAAA;MAAA;MAAAL,KAAA,GAAA/B,UAAA,OAAA6B,gBAAA,KAAAQ,MAAA,CAAAH,IAAA;MAAA,IAAArC,gBAAA,aAAAkC,KAAA,WACZ;QACNO,WAAW,EAAE,CAAC;QACdC,aAAa,EAAE;MACjB,CAAC;MAAA,IAAA1C,gBAAA,aAAAkC,KAAA;MAAA,IAAAlC,gBAAA,aAAAkC,KAAA,gBAuBY,UAACS,MAAc,EAAK;QAC/B;QACA,IAAIT,KAAA,CAAKU,IAAI,IAAID,MAAM,EAAE;UACvB,IAAME,IAAG,GAAGF,MAAM,CAACG,MAAM,CAAC,CAAC;UAC3B,IAAID,IAAG,IAAIX,KAAA,CAAKU,IAAI,KAAKC,IAAG,EAAE;YAC5BX,KAAA,CAAKU,IAAI,CAACG,GAAG,CAAC,YAAY,EAAEjB,GAAG,CAAC;YAChCI,KAAA,CAAKU,IAAI,CAACG,GAAG,CAAC,OAAO,EAAEjB,GAAG,CAAC;YAC3BI,KAAA,CAAKU,IAAI,GAAG,IAAI;UAClB;QACF;QAEA,IAAMC,GAAG,GAAGF,MAAM,IAAIA,MAAM,CAACG,MAAM,CAAC,CAAC;QACrC,IAAID,GAAG,IAAIX,KAAA,CAAKU,IAAI,KAAKC,GAAG,EAAE;UAC5BX,KAAA,CAAKU,IAAI,GAAGC,GAAG;UAEfA,GAAG,CAACG,EAAE,CAAC,YAAY,EAAE,YAAM;YACzB,IAAMC,KAAK,GAAGJ,GAAG,CAACK,QAAQ,CAAC,CAAC;YAC5BhB,KAAA,CAAKiB,gBAAgB,CAACF,KAAK,CAAC;UAC9B,CAAC,CAAC;UAEFJ,GAAG,CAACG,EAAE,CAAC,OAAO,EAAE,YAAM;YACpBd,KAAA,CAAKkB,iBAAiB,CAAC,CAAC;UAC1B,CAAC,CAAC;QACJ;MACF,CAAC;MAAA,IAAApD,gBAAA,aAAAkC,KAAA,sBAEkB,UAAAe,KAAK,EAAI;QAC1Bf,KAAA,CAAKb,KAAK,CAACgC,kBAAkB,CAAC;UAACJ,KAAK,EAALA,KAAK;UAAEK,KAAK,EAAE;QAAK,CAAC,CAAC;MACtD,CAAC;MAAA,IAAAtD,gBAAA,aAAAkC,KAAA,uBAEmB,YAAM;QACxBA,KAAA,CAAKb,KAAK,CAACgC,kBAAkB,CAAC;UAACC,KAAK,EAAE;QAAI,CAAC,CAAC;MAC9C,CAAC;MAAA,OAAApB,KAAA;IAAA;IAAA,IAAAqB,UAAA,aAAAvB,gBAAA,EAAAC,UAAA;IAAA,WAAAuB,aAAA,aAAAxB,gBAAA;MAAAyB,GAAA;MAAAC,KAAA,EAED,SAAAC,MAAMA,CAAA,EAAG;QAAA,IAAAC,qBAAA;UAAAC,YAAA;UAAAC,MAAA;QACP,IAAAC,WAAA,GAAqC,IAAI,CAAC1C,KAAK;UAAxC2C,UAAU,GAAAD,WAAA,CAAVC,UAAU;UAAEC,QAAQ,GAAAF,WAAA,CAARE,QAAQ;UAAEC,IAAI,GAAAH,WAAA,CAAJG,IAAI;QAEjC,IAAMC,kBAAkB,GAAG,IAAAC,wBAAiB,EAACJ,UAAU,CAAC;QACxD,IAAMK,oBAAoB,GAAG,IAAAC,2BAAoB,EAAC,CAAC,CAACD,oBAAoB,CAACF,kBAAkB,CAAC;QAE5F,IAAMI,oBAAoB,GAAGP,UAAU,CAACQ,WAAW,IAAI,IAAI,CAACnD,KAAK,CAACkD,oBAAoB;QACtF,IAAME,QAAQ,GAAA7E,aAAA,CAAAA,aAAA,KACTqE,QAAQ;UACX;UACA;UACAS,iBAAiB,EAAEH,oBAAoB;UACvCI,MAAM,EAAEN,oBAAoB,CAACO,SAAS,CAAC,CAAC;UACxCC,qBAAqB,EAAE,IAAI;UAC3BC,gBAAgB,EACd,EAAAlB,qBAAA,IAAAC,YAAA,OAAI,CAACxC,KAAK,EAACyD,gBAAgB,cAAAlB,qBAAA,uBAA3BA,qBAAA,CAAA3E,IAAA,CAAA4E,YAAA,EAA8BU,oBAAoB,CAAC,KACnD,IAAAO,uBAAgB,EAACP,oBAAoB;QAAC,EACzC;QAED,oBACE1H,MAAA,YAAAkI,aAAA;UAAKC,SAAS,EAAC;QAAqB,gBAClCnI,MAAA,YAAAkI,aAAA,CAAC1H,kBAAA,CAAA4H,kBAAkB,qBACjBpI,MAAA,YAAAkI,aAAA,CAAC1H,kBAAA,CAAA6H,wBAAwB,qBACvBrI,MAAA,YAAAkI,aAAA,CAAC1H,kBAAA,CAAA8H,kBAAkB,qBACjBtI,MAAA,YAAAkI,aAAA;UAAKC,SAAS,EAAC;QAAqB,gBAClCnI,MAAA,YAAAkI,aAAA,CAACtH,aAAA,CAAA2H,gBAAgB;UAACC,EAAE,EAAE;QAA4B,CAAE,CACjD,CAAC,eACNxI,MAAA,YAAAkI,aAAA;UAAKC,SAAS,EAAC;QAAwB,GACpCd,IAAI,CAACoB,aAAa,CAAC;UAACD,EAAE,EAAE;QAA+B,CAAC,CAAC,eAC1DxI,MAAA,YAAAkI,aAAA,CAAClD,UAAU;UACT0D,MAAM,EAAC,QAAQ;UACfC,IAAI,EAAC;QAA8D,GAElE,GAAG,EACHtB,IAAI,CAACoB,aAAa,CAAC;UAACD,EAAE,EAAE;QAA+B,CAAC,CAC/C,CAAC,EAAC,GAAG,EAChBnB,IAAI,CAACoB,aAAa,CAAC;UAACD,EAAE,EAAE;QAA+B,CAAC,CAAC,eAC1DxI,MAAA,YAAAkI,aAAA,CAAClD,UAAU;UACT0D,MAAM,EAAC,QAAQ;UACfC,IAAI,EAAC;QAAiD,GAErD,GAAG,EACHtB,IAAI,CAACoB,aAAa,CAAC;UAACD,EAAE,EAAE;QAA+B,CAAC,CAC/C,CACT,CAAC,eACNxI,MAAA,YAAAkI,aAAA,CAAC1H,kBAAA,CAAAoI,UAAU;UACTC,IAAI,EAAC,MAAM;UACXhC,KAAK,EAAEM,UAAU,CAAC2B,GAAG,IAAI,EAAG;UAC5BC,QAAQ,EAAE,SAAVA,QAAQA,CAAAC,IAAA;YAAA,IAAanC,KAAK,GAAAmC,IAAA,CAAdN,MAAM,CAAG7B,KAAK;YAAA,OACxBI,MAAI,CAACzC,KAAK,CAACyE,aAAa,CAAC;cACvBH,GAAG,EAAEjC,KAAK;cACV2B,EAAE,EAAE,cAAc;cAClBU,IAAI,KAAAvD,MAAA,CAAK,IAAA8B,2BAAoB,EAAC,CAAC,CAAC0B,MAAM,OAAAxD,MAAA,CAAIyD,0BAAe;YAC3D,CAAC,CAAC;UAAA,CACH;UACDC,WAAW,EAAC;QAAoE,CACjF,CACiB,CAAC,eAErBrJ,MAAA,YAAAkI,aAAA,CAAC1H,kBAAA,CAAA8H,kBAAkB,qBACjBtI,MAAA,YAAAkI,aAAA;UAAKC,SAAS,EAAC;QAAqB,gBAClCnI,MAAA,YAAAkI,aAAA,CAACtH,aAAA,CAAA2H,gBAAgB;UAACC,EAAE,EAAE;QAA8B,CAAE,CACnD,CAAC,eACNxI,MAAA,YAAAkI,aAAA;UAAKC,SAAS,EAAC;QAAwB,GACpCd,IAAI,CAACoB,aAAa,CAAC;UAACD,EAAE,EAAE;QAAiC,CAAC,CAAC,eAC5DxI,MAAA,YAAAkI,aAAA,CAAClD,UAAU;UAAC0D,MAAM,EAAC,QAAQ;UAACC,IAAI,EAAC;QAAuC,GACrE,GAAG,EAAC,QAEK,CAAC,EAAC,GAAG,EAChBtB,IAAI,CAACoB,aAAa,CAAC;UAACD,EAAE,EAAE;QAAiC,CAAC,CAAC,eAC5DxI,MAAA,YAAAkI,aAAA,CAAClD,UAAU;UACT0D,MAAM,EAAC,QAAQ;UACfC,IAAI,EAAC;QAAoD,GAExD,GAAG,EACHtB,IAAI,CAACoB,aAAa,CAAC;UAACD,EAAE,EAAE;QAAiC,CAAC,CACjD,CAAC,EAAC,GAAG,EAChBnB,IAAI,CAACoB,aAAa,CAAC;UAACD,EAAE,EAAE;QAAiC,CAAC,CACxD,CAAC,eAENxI,MAAA,YAAAkI,aAAA;UAAKC,SAAS,EAAC;QAAwB,GACpCd,IAAI,CAACoB,aAAa,CAAC;UAACD,EAAE,EAAE;QAAiC,CAAC,CAAC,eAC5DxI,MAAA,YAAAkI,aAAA,CAAClD,UAAU;UACT0D,MAAM,EAAC,QAAQ;UACfC,IAAI,EAAC;QAAqD,GAEzD,GAAG,EACHtB,IAAI,CAACoB,aAAa,CAAC;UAACD,EAAE,EAAE;QAAiC,CAAC,CACjD,CAAC,EAAC,GAAG,EAChBnB,IAAI,CAACoB,aAAa,CAAC;UAACD,EAAE,EAAE;QAAiC,CAAC,CACxD,CAAC,eACNxI,MAAA,YAAAkI,aAAA,CAAC1H,kBAAA,CAAAoI,UAAU;UACTC,IAAI,EAAC,MAAM;UACXhC,KAAK,EAAEM,UAAU,CAACQ,WAAW,IAAI,EAAG;UACpCoB,QAAQ,EAAE,SAAVA,QAAQA,CAAAO,KAAA;YAAA,IAAazC,KAAK,GAAAyC,KAAA,CAAdZ,MAAM,CAAG7B,KAAK;YAAA,OAAOI,MAAI,CAACzC,KAAK,CAACyE,aAAa,CAAC;cAACtB,WAAW,EAAEd;YAAK,CAAC,CAAC;UAAA,CAAC;UAChFwC,WAAW,EAAEhC,IAAI,CAACoB,aAAa,CAAC;YAACD,EAAE,EAAE;UAA6B,CAAC;QAAE,CACtE,CACiB,CAAC,eAErBxI,MAAA,YAAAkI,aAAA,CAAC1H,kBAAA,CAAA8H,kBAAkB,qBACjBtI,MAAA,YAAAkI,aAAA;UAAKC,SAAS,EAAC;QAAqB,gBAClCnI,MAAA,YAAAkI,aAAA,CAACtH,aAAA,CAAA2H,gBAAgB;UAACC,EAAE,EAAE;QAA6B,CAAE,CAClD,CAAC,eACNxI,MAAA,YAAAkI,aAAA,CAAC1H,kBAAA,CAAAoI,UAAU;UACTC,IAAI,EAAC,MAAM;UACXhC,KAAK,EAAEM,UAAU,CAACoC,KAAK,IAAI,EAAG;UAC9BR,QAAQ,EAAE,SAAVA,QAAQA,CAAAS,KAAA;YAAA,IAAa3C,KAAK,GAAA2C,KAAA,CAAdd,MAAM,CAAG7B,KAAK;YAAA,OAAOI,MAAI,CAACzC,KAAK,CAACyE,aAAa,CAAC;cAACM,KAAK,EAAE1C;YAAK,CAAC,CAAC;UAAA,CAAC;UAC1EwC,WAAW,EAAC;QAAiB,CAC9B,CACiB,CACI,CAAC,eAC3BrJ,MAAA,YAAAkI,aAAA,CAAC9D,UAAU,qBACTpE,MAAA,YAAAkI,aAAA;UACEC,SAAS,EAAE,IAAAsB,sBAAU,EAAC,eAAe,EAAE;YACrChD,KAAK,EAAEU,UAAU,CAACV;UACpB,CAAC;QAAE,GAEFU,UAAU,CAACV,KAAK,GACbvC,QAAQ,CAACC,UAAU,GAClBgD,UAAU,CAACf,KAAK,IAAIe,UAAU,CAACf,KAAK,CAACsD,IAAI,IAAK,EAChD,CAAC,eACN1J,MAAA,YAAAkI,aAAA,CAACpD,kBAAkB;UAACqD,SAAS,EAAC;QAAe,GAE1C,CAAChB,UAAU,CAACwC,OAAO,gBAClB3J,MAAA,YAAAkI,aAAA;UAAKC,SAAS,EAAC;QAAuB,CAAE,CAAC,gBAEzCnI,MAAA,YAAAkI,aAAA,CAAC1H,kBAAA,CAAAoJ,kBAAkB,qBACjB5J,MAAA,YAAAkI,aAAA,CAAC3H,WAAA,CAAAsJ,GAAG,MAAAC,SAAA,iBACElC,QAAQ;UACZmC,GAAG,EAAE,IAAI,CAACC,UAAW;UACrBpD,GAAG,KAAAjB,MAAA,CAAK2B,kBAAkB,OAAA3B,MAAA,CAAI,IAAI,CAACsE,KAAK,CAACrE,WAAW,OAAAD,MAAA,CAAIwB,UAAU,CAAC2B,GAAG,OAAAnD,MAAA,CAAI+B,oBAAoB,CAAG;UACjGtB,KAAK,EAAE;YACL8D,KAAK,EAAEjG,IAAI;YACXkG,MAAM,EAAEnG;UACV,CAAE;UACFoG,QAAQ,EAAEjD,UAAU,CAAC2B,GAAG,KAAK,IAAI,GAAGuB,SAAS,GAAGlD,UAAU,CAAC2B;QAAI,EAChE,CACiB,CAEJ,CACV,CACM,CACjB,CAAC;MAEV;IAAC;MAAAlC,GAAA;MAAAC,KAAA,EAvMD,SAAOyD,wBAAwBA,CAAC9F,KAAK,EAAEyF,KAAK,EAAE;QAC5C,IACEzF,KAAK,CAAC2C,UAAU,IAChB3C,KAAK,CAAC2C,UAAU,CAACQ,WAAW,IAC5BnD,KAAK,CAAC2C,UAAU,CAACQ,WAAW,KAAKsC,KAAK,CAACpE,aAAa,EACpD;UACA;UACA;UACA;;UAEA,OAAO;YACLD,WAAW,EAAEqE,KAAK,CAACrE,WAAW,GAAG,CAAC;YAClCC,aAAa,EAAErB,KAAK,CAAC2C,UAAU,CAACQ;UAClC,CAAC;QACH;QAEA,OAAO,IAAI;MACb;IAAC;EAAA,EAvB4B4C,gBAAS;EAgNxC,OAAO,IAAAC,qBAAU,EAAC,IAAAC,+BAAQ,EAACtF,gBAAgB,CAAC,CAAC;AAC/C;AAAC,IAAAuF,QAAA,GAAAC,OAAA,cAEczF,uBAAuB","ignoreList":[]}