/*! * * @supermap/vue-iclient.(https://iclient.supermap.io) * Copyright© 2000 - 2020 SuperMap Software Co.Ltd * license: Apache-2.0 * version: v10.1.0 * */ (function webpackUniversalModuleDefinition(root, factory) { if(typeof exports === 'object' && typeof module === 'object') module.exports = factory(require("xlsx"), require("../static/libs/mapboxgl/mapbox-gl-enhance.js"), require("vue"), require("three/examples/jsm/loaders/GLTFLoader"), require("vue-echarts"), require("three"), require("ant-design-vue"), require("echarts-liquidfill"), require("three/examples/jsm/loaders/OBJLoader2"), require("vue-cesium"), require("video.js"), require("../static/libs/deckgl/deck.gl.min.js"), require("../static/libs/echarts-layer/EchartsLayer.js"), require("../static/libs/iclient-mapboxgl/iclient-mapboxgl.min.js"), require("echarts"), require("../static/libs/mapbox-gl-draw/mapbox-gl-draw.js"), require("shapefile")); else if(typeof define === 'function' && define.amd) define(["xlsx", "../static/libs/mapboxgl/mapbox-gl-enhance.js", "vue", "three/examples/jsm/loaders/GLTFLoader", "vue-echarts", "three", "ant-design-vue", "echarts-liquidfill", "three/examples/jsm/loaders/OBJLoader2", "vue-cesium", "video.js", "../static/libs/deckgl/deck.gl.min.js", "../static/libs/echarts-layer/EchartsLayer.js", "../static/libs/iclient-mapboxgl/iclient-mapboxgl.min.js", "echarts", "../static/libs/mapbox-gl-draw/mapbox-gl-draw.js", "shapefile"], factory); else if(typeof exports === 'object') exports["Components"] = factory(require("xlsx"), require("../static/libs/mapboxgl/mapbox-gl-enhance.js"), require("vue"), require("three/examples/jsm/loaders/GLTFLoader"), require("vue-echarts"), require("three"), require("ant-design-vue"), require("echarts-liquidfill"), require("three/examples/jsm/loaders/OBJLoader2"), require("vue-cesium"), require("video.js"), require("../static/libs/deckgl/deck.gl.min.js"), require("../static/libs/echarts-layer/EchartsLayer.js"), require("../static/libs/iclient-mapboxgl/iclient-mapboxgl.min.js"), require("echarts"), require("../static/libs/mapbox-gl-draw/mapbox-gl-draw.js"), require("shapefile")); else root["SuperMap"] = root["SuperMap"] || {}, root["SuperMap"]["Components"] = factory(root["XLSX"], root["mapboxgl"], root["Vue"], root["THREE.GLTFLoader"], root["VueECharts"], root["THREE"], root["antd"], root["echarts-liquidfill"], root["THREE.OBJLoader2"], root["VueCesium"], root["_videojs"], root["DeckGL"], root["EchartsLayer"], root["SuperMap"], root["echarts"], root["MapboxDraw"], root["shapefile"]); })(window, function(__WEBPACK_EXTERNAL_MODULE__1c98__, __WEBPACK_EXTERNAL_MODULE__3d57__, __WEBPACK_EXTERNAL_MODULE__5643__, __WEBPACK_EXTERNAL_MODULE__6d09__, __WEBPACK_EXTERNAL_MODULE__8275__, __WEBPACK_EXTERNAL_MODULE__8b5b__, __WEBPACK_EXTERNAL_MODULE_a587__, __WEBPACK_EXTERNAL_MODULE_acbb__, __WEBPACK_EXTERNAL_MODULE_b9f8__, __WEBPACK_EXTERNAL_MODULE_be1f__, __WEBPACK_EXTERNAL_MODULE_be3f__, __WEBPACK_EXTERNAL_MODULE_ca40__, __WEBPACK_EXTERNAL_MODULE_e76e__, __WEBPACK_EXTERNAL_MODULE_f240__, __WEBPACK_EXTERNAL_MODULE_f840__, __WEBPACK_EXTERNAL_MODULE_fc22__, __WEBPACK_EXTERNAL_MODULE_ffd5__) { return /******/ (function(modules) { // webpackBootstrap /******/ // The module cache /******/ var installedModules = {}; /******/ /******/ // The require function /******/ function __webpack_require__(moduleId) { /******/ /******/ // Check if module is in cache /******/ if(installedModules[moduleId]) { /******/ return installedModules[moduleId].exports; /******/ } /******/ // Create a new module (and put it into the cache) /******/ var module = installedModules[moduleId] = { /******/ i: moduleId, /******/ l: false, /******/ exports: {} /******/ }; /******/ /******/ // Execute the module function /******/ modules[moduleId].call(module.exports, module, module.exports, __webpack_require__); /******/ /******/ // Flag the module as loaded /******/ module.l = true; /******/ /******/ // Return the exports of the module /******/ return module.exports; /******/ } /******/ /******/ /******/ // expose the modules object (__webpack_modules__) /******/ __webpack_require__.m = modules; /******/ /******/ // expose the module cache /******/ __webpack_require__.c = installedModules; /******/ /******/ // define getter function for harmony exports /******/ __webpack_require__.d = function(exports, name, getter) { /******/ if(!__webpack_require__.o(exports, name)) { /******/ Object.defineProperty(exports, name, { enumerable: true, get: getter }); /******/ } /******/ }; /******/ /******/ // define __esModule on exports /******/ __webpack_require__.r = function(exports) { /******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) { /******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' }); /******/ } /******/ Object.defineProperty(exports, '__esModule', { value: true }); /******/ }; /******/ /******/ // create a fake namespace object /******/ // mode & 1: value is a module id, require it /******/ // mode & 2: merge all properties of value into the ns /******/ // mode & 4: return value when already ns object /******/ // mode & 8|1: behave like require /******/ __webpack_require__.t = function(value, mode) { /******/ if(mode & 1) value = __webpack_require__(value); /******/ if(mode & 8) return value; /******/ if((mode & 4) && typeof value === 'object' && value && value.__esModule) return value; /******/ var ns = Object.create(null); /******/ __webpack_require__.r(ns); /******/ Object.defineProperty(ns, 'default', { enumerable: true, value: value }); /******/ if(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key)); /******/ return ns; /******/ }; /******/ /******/ // getDefaultExport function for compatibility with non-harmony modules /******/ __webpack_require__.n = function(module) { /******/ var getter = module && module.__esModule ? /******/ function getDefault() { return module['default']; } : /******/ function getModuleExports() { return module; }; /******/ __webpack_require__.d(getter, 'a', getter); /******/ return getter; /******/ }; /******/ /******/ // Object.prototype.hasOwnProperty.call /******/ __webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); }; /******/ /******/ // __webpack_public_path__ /******/ __webpack_require__.p = "/"; /******/ /******/ /******/ // Load entry module and return exports /******/ return __webpack_require__(__webpack_require__.s = 0); /******/ }) /************************************************************************/ /******/ ({ /***/ 0: /***/ (function(module, exports, __webpack_require__) { module.exports = __webpack_require__("5c15"); /***/ }), /***/ "022b": /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./src/common/indicator/Indicator.vue?vue&type=template&id=39b17318& var render = function () {var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;return _c('div',{staticClass:"sm-component-indicator",style:(_vm.getBackgroundStyle)},[_c('div',{class:("sm-component-indicator__content sm-component-indicator__content-" + _vm.mode)},[_c('span',{directives:[{name:"show",rawName:"v-show",value:(_vm.showTitleUnit),expression:"showTitleUnit"}],staticClass:"sm-component-indicator__title",style:([_vm.unit_titleStyle, _vm.getTextColorStyle])},[_vm._v(_vm._s(_vm.titleData))]),_vm._v(" "),_c('div',[_c('span',{staticClass:"sm-component-indicator__num",style:(_vm.indicatorStyle)},[(_vm.isNumber(_vm.indicatorNum))?_c('countTo',{attrs:{"decimals":_vm.calDecimals,"startVal":_vm.startData,"endVal":_vm.numData,"duration":Number(_vm.duration) || 1000,"separator":_vm.separator,"numBackground":_vm.numBackground,"numSpacing":_vm.numSpacing,"separatorBackground":_vm.separatorBackground,"fontSize":parseFloat(_vm.fontSize) + _vm.fontUnit}}):_vm._e(),_vm._v("\n "+_vm._s(_vm.isNumber(_vm.indicatorNum) ? '' : _vm.indicatorNum)+"\n ")],1),_vm._v(" "),_c('span',{directives:[{name:"show",rawName:"v-show",value:(_vm.showTitleUnit),expression:"showTitleUnit"}],staticClass:"sm-component-indicator__unit",style:([_vm.unit_titleStyle, _vm.getTextColorStyle])},[_vm._v(_vm._s(_vm.unitData))])])])])} var staticRenderFns = [] // CONCATENATED MODULE: ./src/common/indicator/Indicator.vue?vue&type=template&id=39b17318& /* concated harmony reexport render */__webpack_require__.d(__webpack_exports__, "a", function() { return render; }); /* concated harmony reexport staticRenderFns */__webpack_require__.d(__webpack_exports__, "b", function() { return staticRenderFns; }); /***/ }), /***/ "027a": /***/ (function(module, exports, __webpack_require__) { "use strict"; var _interopRequireDefault = __webpack_require__("8e6d"); Object.defineProperty(exports, "__esModule", { value: true }); exports.request = request; exports.generatePointsFeatures = exports.clearSearchResultLayer = exports.resetSearchSourceData = exports.addPoints = exports.toBBoxString = exports.tdtSetHighlightIcon = exports.getStatisticsResult = exports.sourceNames = exports.tiandituTransit = exports.tiandituSearch = exports.config = void 0; var _axios = _interopRequireDefault(__webpack_require__("bd18")); var _bbox = _interopRequireDefault(__webpack_require__("1164")); var _transformScale = _interopRequireDefault(__webpack_require__("f052")); var _envelope = _interopRequireDefault(__webpack_require__("0c08")); var _helpers = __webpack_require__("38ce"); var _sprite = _interopRequireDefault(__webpack_require__("090e")); var _sprite2 = _interopRequireDefault(__webpack_require__("074d")); var CancelToken = _axios.default.CancelToken; var axiosService = _axios.default.create(); var cancelSourceList = {}; axiosService.interceptors.request.use( // 请求拦截 function (config) { cancelRequest(config.url); config.cancelToken = new CancelToken(function executor(c) { // An executor function receives a cancel function as a parameter cancelSourceList[config.url] = c; }); return config; }, function (error) { return Promise.reject(error); }); axiosService.interceptors.response.use(function (response) { cancelRequest(response.config.url); return response; }, function (error) { var isCancel = _axios.default.isCancel(error); if (isCancel) { var cancelError = { isCancel: isCancel }; return Promise.reject(cancelError); } else { return Promise.reject(error.response && error.response.data); // 返回接口返回的错误信息 } }); function request(_ref) { var url = _ref.url, _ref$params = _ref.params, params = _ref$params === void 0 ? {} : _ref$params, _ref$method = _ref.method, method = _ref$method === void 0 ? 'get' : _ref$method; var options = { url: url, method: method }; if (method.toLowerCase() === 'get') { options.params = params; } else { options.data = params; } return axiosService(options).then(function (res) { return res.data; }).catch(function (error) { return Promise.reject(error); }); } function cancelRequest(sourceName) { var source = cancelSourceList[sourceName]; if (typeof source === 'function') { source('取消重复请求'); delete cancelSourceList[sourceName]; } } var config = { HOME_URL: 'https://www.tianditu.gov.cn', feedbackIp: 'https://www.tianditu.gov.cn/feedback', T_URL: 'https://map.tianditu.gov.cn', T_SSO_URL: 'https://sso.tianditu.gov.cn', T_UMS_URL: 'https://uums.tianditu.gov.cn', SEARCH_URL: 'https://api.tianditu.gov.cn/search', DRIVE_URL: 'https://api.tianditu.gov.cn/drive', BUS_URL: 'https://api.tianditu.gov.cn/transit', GEOCODE_URL: 'https://api.tianditu.gov.cn/geocoder', API_URL: 'https://lbs.tianditu.gov.cn/' }; exports.config = config; var tiandituSearch = function tiandituSearch(url, params) { return request({ url: url, params: params }); }; exports.tiandituSearch = tiandituSearch; var tiandituTransit = function tiandituTransit(url, params) { return request({ url: url, params: params }); }; exports.tiandituTransit = tiandituTransit; var sourceNames = { // tdtSearch-xxxx searchResultPoints: 'tdt-search-searchResultPoints', searchResultLine: 'tdt-search-searchResultLine', searchResultPolygon: 'tdt-search-searchResultPolygon', searchResultPointsOfLine: 'tdt-search-searchResultPointsOfLine' }; // search和route共用的方法 exports.sourceNames = sourceNames; var getStatisticsResult = function getStatisticsResult(data) { var result = { priorityCitys: data.priorityCitys, allAdmins: data.allAdmins.map(function (parent, index) { var parentKey = "0-".concat(index); var item = { key: parentKey, title: parent.name, info: parent, children: [], scopedSlots: { title: 'title', info: 'info' } }; parent.childAdmins && parent.childAdmins.forEach(function (child, key) { var childKey = "".concat(parentKey, "-").concat(key); var subItem = { key: childKey, title: child.name, info: child, children: [], scopedSlots: { title: 'title', info: 'info' } }; child.childAdmins && child.childAdmins.forEach(function (grandSon, subKey) { var grandKey = "".concat(childKey, "-").concat(subKey); var grandItem = { key: grandKey, title: grandSon.name, info: grandSon, scopedSlots: { title: 'title', info: 'info' } }; subItem.children.push(grandItem); }); item.children.push(subItem); }); return item; }) }; return result; }; // 点设置高亮 exports.getStatisticsResult = getStatisticsResult; var tdtSetHighlightIcon = function tdtSetHighlightIcon(map, sourceName, hotPointID) { if (map.getLayer("".concat(sourceName, "-highlight"))) { if (hotPointID) { map.setFilter("".concat(sourceName, "-highlight"), ['==', 'hotPointID', hotPointID]); return; } map.setFilter("".concat(sourceName, "-highlight"), ['==', 'hotPointID', '']); } }; // bounds转换成string exports.tdtSetHighlightIcon = tdtSetHighlightIcon; var toBBoxString = function toBBoxString(map) { var bounds = map.getBounds(); return bounds.getWest().toFixed(5) + ',' + bounds.getSouth().toFixed(5) + ',' + bounds.getEast().toFixed(5) + ',' + bounds.getNorth().toFixed(5); }; // 添加点图层 exports.toBBoxString = toBBoxString; var addPoints = function addPoints(map, sourceName, features) { if (features && map) { var source = map.getSource(sourceName); var sourceData = features; if (source) { source.setData(sourceData); } else { map.addSource(sourceName, { type: 'geojson', data: sourceData }); var image = new Image(); image.src = _sprite2.default; image.onload = function () { map.style.addSpriteObject(sourceName, image, _sprite.default); map.addLayer({ id: sourceName, type: 'symbol', source: sourceName, layout: { 'icon-image': 'buoy-icon-{serialNum}', 'icon-allow-overlap': true } }); map.addLayer({ id: "".concat(sourceName, "-highlight"), type: 'symbol', source: sourceName, layout: { 'icon-image': 'buoy-icon-active-{serialNum}', 'icon-allow-overlap': true }, filter: ['==', 'hotPointID', ''] }); }; } var bounds = (0, _bbox.default)((0, _transformScale.default)((0, _envelope.default)(features), 1.7)); map.fitBounds([[bounds[0], bounds[1]], [bounds[2], bounds[3]]], { maxZoom: 17 }); } }; // 清空search, route图层 exports.addPoints = addPoints; var resetSearchSourceData = function resetSearchSourceData(map, searchRoutePoints) { if (!map) return; // 清除route if (searchRoutePoints && map.getSource(searchRoutePoints)) { map.getSource(searchRoutePoints).setData({ type: 'FeatureCollection', features: [] }); return; } // 清除search for (var sourceName in sourceNames) { if (map.getSource(sourceName)) { map.getSource(sourceName).setData({ type: 'FeatureCollection', features: [] }); } } }; // 移除search, route图层 exports.resetSearchSourceData = resetSearchSourceData; var clearSearchResultLayer = function clearSearchResultLayer(map, searchRoutePoints) { if (!map) return; for (var sourceName in sourceNames) { if (searchRoutePoints && map.getSource(searchRoutePoints)) { map.getLayer(searchRoutePoints) && map.removeLayer(searchRoutePoints); map.getLayer("".concat(searchRoutePoints, "-highlight")) && map.removeLayer("".concat(searchRoutePoints, "-highlight")); map.removeSource(searchRoutePoints); break; } if (map.getSource(sourceNames[sourceName])) { map.getLayer(sourceNames[sourceName]) && map.removeLayer(sourceNames[sourceName]); switch (sourceNames[sourceName]) { case 'tdt-search-searchResultPoints': map.removeLayer("".concat(sourceNames[sourceName], "-highlight")); break; case 'tdt-search-searchResultPointsOfLine': map.removeLayer("".concat(sourceNames[sourceName], "-fill")); map.removeLayer("".concat(sourceNames[sourceName], "-stroke")); break; case 'tdt-search-searchResultPolygon': map.removeLayer("".concat(sourceNames[sourceName], "-stroke")); break; default: break; } map.removeSource(sourceNames[sourceName]); } } }; // 构造点数据 exports.clearSearchResultLayer = clearSearchResultLayer; var generatePointsFeatures = function generatePointsFeatures(data) { var splitFlag = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : ' '; var result = []; for (var index = data.length - 1; index >= 0; index--) { var item = data[index]; var feature = { type: 'Feature', geometry: { type: 'Point' }, properties: {} }; var center = (item.lonlat || '').split(splitFlag); feature.geometry.coordinates = [+center[0], +center[1]]; feature.properties = Object.assign(item, { serialNum: index + 1 }); result.push(feature); } var featureList = (0, _helpers.featureCollection)(result); return featureList; }; exports.generatePointsFeatures = generatePointsFeatures; /***/ }), /***/ "0284": /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); /* harmony import */ var _TdtMapSwitcher_vue_vue_type_template_id_7115d558___WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__("9482"); /* harmony import */ var _TdtMapSwitcher_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__("a440"); /* harmony reexport (unknown) */ for(var __WEBPACK_IMPORT_KEY__ in _TdtMapSwitcher_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_1__) if(__WEBPACK_IMPORT_KEY__ !== 'default') (function(key) { __webpack_require__.d(__webpack_exports__, key, function() { return _TdtMapSwitcher_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_1__[key]; }) }(__WEBPACK_IMPORT_KEY__)); /* harmony import */ var _node_modules_vue_loader_lib_runtime_componentNormalizer_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__("b429"); /* normalize component */ var component = Object(_node_modules_vue_loader_lib_runtime_componentNormalizer_js__WEBPACK_IMPORTED_MODULE_2__[/* default */ "a"])( _TdtMapSwitcher_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_1__["default"], _TdtMapSwitcher_vue_vue_type_template_id_7115d558___WEBPACK_IMPORTED_MODULE_0__[/* render */ "a"], _TdtMapSwitcher_vue_vue_type_template_id_7115d558___WEBPACK_IMPORTED_MODULE_0__[/* staticRenderFns */ "b"], false, null, null, null ) /* harmony default export */ __webpack_exports__["default"] = (component.exports); /***/ }), /***/ "0318": /***/ (function(module, exports, __webpack_require__) { /* eslint-disable node/no-deprecated-api */ var buffer = __webpack_require__("3be6") var Buffer = buffer.Buffer // alternative to using Object.keys for old browsers function copyProps (src, dst) { for (var key in src) { dst[key] = src[key] } } if (Buffer.from && Buffer.alloc && Buffer.allocUnsafe && Buffer.allocUnsafeSlow) { module.exports = buffer } else { // Copy properties from require('buffer') copyProps(buffer, exports) exports.Buffer = SafeBuffer } function SafeBuffer (arg, encodingOrOffset, length) { return Buffer(arg, encodingOrOffset, length) } // Copy static methods from Buffer copyProps(Buffer, SafeBuffer) SafeBuffer.from = function (arg, encodingOrOffset, length) { if (typeof arg === 'number') { throw new TypeError('Argument must not be a number') } return Buffer(arg, encodingOrOffset, length) } SafeBuffer.alloc = function (size, fill, encoding) { if (typeof size !== 'number') { throw new TypeError('Argument must be a number') } var buf = Buffer(size) if (fill !== undefined) { if (typeof encoding === 'string') { buf.fill(fill, encoding) } else { buf.fill(fill) } } else { buf.fill(0) } return buf } SafeBuffer.allocUnsafe = function (size) { if (typeof size !== 'number') { throw new TypeError('Argument must be a number') } return Buffer(size) } SafeBuffer.allocUnsafeSlow = function (size) { if (typeof size !== 'number') { throw new TypeError('Argument must be a number') } return buffer.SlowBuffer(size) } /***/ }), /***/ "035a": /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./src/mapboxgl/text-list/TextList.vue?vue&type=template&id=73b23a1f& var render = function () {var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;return _c('div',{staticClass:"sm-component-text-list",style:(_vm.getBackgroundStyle),on:{"mouseleave":function($event){return _vm.handleMouseLeaveFn({}, null, $event)}}},[(_vm.headerStyleData.show)?_c('div',{staticClass:"sm-component-text-list__header",style:([_vm.listStyle.headerHeight, { background: _vm.headerStyleData.background, color: _vm.headerStyleData.color }])},[_c('div',{staticClass:"sm-component-text-list__header-content"},[(_vm.animateContent && _vm.animateContent.length > 0)?[_vm._l(((_vm.getColumns && _vm.getColumns.length > 0 && _vm.getColumns) || Object.keys(_vm.animateContent[0])),function(item,index){return [_c('div',{key:index,staticClass:"sm-component-text-list__header-title",style:([_vm.fontSizeStyle, { flex: _vm.getColumnWidth(index) }]),attrs:{"title":item.header}},[_c('div',{on:{"click":function($event){_vm.sortByField( _vm.getColumns[index].field + '-' + index, index, !Number.isNaN(+_vm.listData[0][_vm.getColumns[index].field + '-' + index]) && _vm.getColumns[index].sort )}}},[_vm._v("\n "+_vm._s(_vm.getColumns[index].header)+"\n "),(!Number.isNaN(+_vm.listData[0][_vm.getColumns[index].field + '-' + index]) && _vm.getColumns[index].sort)?_c('div',{staticClass:"arrow-wrap",style:({ borderColor: _vm.headerStyleData.sortBtnColor })},[_c('i',{class:['up-triangle'],style:([ { borderBottomColor: _vm.headerStyleData.sortBtnColor }, _vm.sortType === 'ascend' && _vm.sortIndex === index && { borderBottomColor: _vm.headerStyleData.sortBtnSelectColor } ])}),_vm._v(" "),_c('i',{class:['down-triangle'],style:([ { borderTopColor: _vm.headerStyleData.sortBtnColor }, _vm.sortType === 'descend' && _vm.sortIndex === index && { borderTopColor: _vm.headerStyleData.sortBtnSelectColor } ])})]):_vm._e()])])]})]:_vm._e()],2)]):_vm._e(),_vm._v(" "),_c('div',{ref:"animate",staticClass:"sm-component-text-list__animate",style:([ _vm.listStyle.contentHeight, _vm.getTextColorStyle, _vm.fontSizeStyle, { 'overflow-y': _vm.autoRolling ? 'hidden' : 'auto' } ])},[_c('div',{ref:"listContent",class:['sm-component-text-list__body-content', _vm.animate && 'sm-component-text-list__body-content--anim']},[(_vm.animateContent && _vm.animateContent.length > 0)?_vm._l((_vm.animateContent),function(rowData,index){return _c('div',{key:index,staticClass:"sm-component-text-list__list",style:(_vm.getRowStyle(rowData['idx'], index)),attrs:{"data-index":rowData['idx']},on:{"click":function($event){return _vm.handleClick(rowData, rowData['idx'], $event)},"mouseenter":function($event){return _vm.handleMouseEnterFn(rowData, rowData['idx'], $event)},"mouseleave":function($event){return _vm.handleMouseLeaveFn(rowData, rowData['idx'], $event)}}},_vm._l((_vm.filterProperty(rowData, 'idx')),function(items,key,itemIndex){return _c('div',{key:key,style:([_vm.listStyle.rowStyle, { flex: _vm.getColumnWidth(itemIndex) }, _vm.getCellStyle(items, itemIndex)]),attrs:{"title":items}},[(_vm.getColumns[itemIndex])?_c('span',[_vm._v(_vm._s(_vm.getColumns[itemIndex].fixInfo.prefix))]):_vm._e(),_vm._v("\n "+_vm._s(items)+"\n "),(_vm.getColumns[itemIndex])?_c('span',[_vm._v(_vm._s(_vm.getColumns[itemIndex].fixInfo.suffix))]):_vm._e()])}),0)}):_vm._e()],2)]),_vm._v(" "),(_vm.spinning)?_c('a-spin',{attrs:{"size":"large","tip":_vm.$t('info.loading'),"spinning":_vm.spinning}}):_vm._e()],1)} var staticRenderFns = [] // CONCATENATED MODULE: ./src/mapboxgl/text-list/TextList.vue?vue&type=template&id=73b23a1f& /* concated harmony reexport render */__webpack_require__.d(__webpack_exports__, "a", function() { return render; }); /* concated harmony reexport staticRenderFns */__webpack_require__.d(__webpack_exports__, "b", function() { return staticRenderFns; }); /***/ }), /***/ "035f": /***/ (function(module, exports, __webpack_require__) { "use strict"; var _interopRequireWildcard = __webpack_require__("16ed"); var _interopRequireDefault = __webpack_require__("8e6d"); Object.defineProperty(exports, "__esModule", { value: true }); exports.default = void 0; var _toConsumableArray2 = _interopRequireDefault(__webpack_require__("4066")); var _classCallCheck2 = _interopRequireDefault(__webpack_require__("19e1")); var _createClass2 = _interopRequireDefault(__webpack_require__("66f6")); var _possibleConstructorReturn2 = _interopRequireDefault(__webpack_require__("8377")); var _getPrototypeOf2 = _interopRequireDefault(__webpack_require__("c031")); var _inherits2 = _interopRequireDefault(__webpack_require__("6b51")); var THREE = _interopRequireWildcard(__webpack_require__("8b5b")); var _mapboxGlEnhance = _interopRequireDefault(__webpack_require__("3d57")); var _tendrils = _interopRequireDefault(__webpack_require__("dea1")); var FireLayerViewModel = /*#__PURE__*/ function (_mapboxgl$Evented) { (0, _inherits2.default)(FireLayerViewModel, _mapboxgl$Evented); function FireLayerViewModel(features) { var _this; var modelScale = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 5.41843220338983e-6; var layerId = arguments.length > 2 ? arguments[2] : undefined; (0, _classCallCheck2.default)(this, FireLayerViewModel); _this = (0, _possibleConstructorReturn2.default)(this, (0, _getPrototypeOf2.default)(FireLayerViewModel).call(this)); _this.layerId = layerId; _this.features = features; _this.modelScale = modelScale; return _this; } (0, _createClass2.default)(FireLayerViewModel, [{ key: "setMap", value: function setMap(mapInfo) { var map = mapInfo.map; if (!map) { throw new Error('map is requierd'); } this.map = map; this._addFireLayer(); } }, { key: "setFeatures", value: function setFeatures(features) { this.features = features; this._addFireLayer(); } }, { key: "setModelScale", value: function setModelScale(modelScale) { this.modelScale = modelScale; this._addFireLayer(); } }, { key: "_addFireLayer", value: function _addFireLayer() { var _this2 = this; var feature = this.features.features[0]; if (feature.geometry.type !== 'Point') { throw new Error("Feature's type must be point"); } if (this.features.features.length > 50) { throw new Error('The maximum number of features is 50'); } this.features.features.forEach(function (feature, index) { var geometry = feature.geometry; if (geometry.type === 'Point') { _this2._initializeFireLayer(geometry.coordinates, index); } }); } }, { key: "_initializeFireLayer", value: function _initializeFireLayer(originCoordinate, index) { var _this3 = this; var modelTransform = this._getModelTransform(originCoordinate); var layerId = this.layerId && this.layerId + '-' + index || "threeLayerFire-".concat(new Date()); this.map.getLayer(layerId) && this.map.removeLayer(layerId); var customLayer = { id: layerId, type: 'custom', renderingMode: '3d', onAdd: function onAdd(map, gl) { _this3.camera = new THREE.PerspectiveCamera(45, map.getCanvas().width / map.getCanvas().height, 0.1, 2000); _this3.scene = new THREE.Scene(); _this3.renderer = new THREE.WebGLRenderer({ canvas: map.getCanvas(), context: gl, antialias: true }); _this3.renderer.autoClear = false; var rig = new THREE.Group(); rig.add(_this3.camera); _this3.scene.add(rig); _this3._fire(); _this3.scene.add(_this3._object); var light = new THREE.PointLight(0xffffff, 1, 100); light.position.set(10, 10, 20); _this3.scene.add(light); _this3.map = map; }, render: function render(gl, matrix) { var rotationX = new THREE.Matrix4().makeRotationAxis(new THREE.Vector3(1, 0, 0), modelTransform.rotateX); var rotationY = new THREE.Matrix4().makeRotationAxis(new THREE.Vector3(0, 1, 0), modelTransform.rotateY); var rotationZ = new THREE.Matrix4().makeRotationAxis(new THREE.Vector3(0, 0, 1), modelTransform.rotateZ); var m = new THREE.Matrix4().fromArray(matrix); var l = new THREE.Matrix4().makeTranslation(modelTransform.translateX, modelTransform.translateY, modelTransform.translateZ).scale(new THREE.Vector3(modelTransform.scale, -modelTransform.scale, modelTransform.scale)).multiply(rotationX).multiply(rotationY).multiply(rotationZ); _this3.camera.projectionMatrix.elements = matrix; _this3.camera.projectionMatrix = m.multiply(l); _this3.renderer.state.reset(); _this3._update(); _this3.renderer.render(_this3.scene, _this3.camera); _this3.map.triggerRepaint(); } }; this.map.addLayer(customLayer); } }, { key: "_getModelTransform", value: function _getModelTransform(originCoordinate) { var modelOrigin = originCoordinate; var modelAltitude = 0; var modelRotate = [Math.PI / 2, 0, 0]; var modelTransform = { translateX: _mapboxGlEnhance.default.MercatorCoordinate.fromLngLat(modelOrigin, modelAltitude).x, translateY: _mapboxGlEnhance.default.MercatorCoordinate.fromLngLat(modelOrigin, modelAltitude).y, translateZ: _mapboxGlEnhance.default.MercatorCoordinate.fromLngLat(modelOrigin, modelAltitude).z, rotateX: modelRotate[0], rotateY: modelRotate[1], rotateZ: modelRotate[2], scale: this.modelScale }; return modelTransform; } }, { key: "_fire", value: function _fire() { var _this$_object; var density = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 150; var height = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 8; var r = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 0.2; this._object = new THREE.Group(); this._fireballs = []; this._height = height; this._radius = r; var texture = new THREE.TextureLoader().load(_tendrils.default, function () { console.log('loaded'); }, undefined, function (e) { console.log('error', e); }); texture.crossOrigin = ''; this._fireMaterial = new THREE.ShaderMaterial({ uniforms: { time: { value: 1.0 }, blend: { value: 1.0 }, blendPattern: { type: 't', value: texture } }, vertexShader: "precision mediump float;\n precision mediump int;\n attribute vec4 color;\n varying vec2 vUv;\n varying float vFade;\n void main()\t{\n vUv = uv;\n vec4 localPosition = vec4( position, 1);\n vFade = clamp((localPosition.y + 3.0) / 6.0, 0.0, 1.0);\n gl_Position = projectionMatrix * modelViewMatrix * localPosition;\n }", fragmentShader: "precision mediump float;\n precision mediump int;\n uniform float time;\n uniform float blend;\n uniform sampler2D blendPattern;\n varying float vFade;\n varying vec2 vUv;\n\n\n void main()\t{\n\n vec4 startColor = vec4(1., 0.5, 0.1, 1.0);\n vec4 endColor = vec4(0.2, 0.2, 0.2, 1.0);\n\n float dissolve = texture2D(blendPattern, vUv).r * 0.5;\n\n float spread = 0.4;\n\n float fadeAmount = smoothstep(\n max(0.0, vFade - spread),\n min(1.0, vFade + spread),\n blend + dissolve\n );\n\n vec4 color = mix(\n startColor, endColor,\n smoothstep(0.1,1., fadeAmount)\n );\n\n gl_FragColor = vec4(color.rgb, 1.-fadeAmount);\n }", transparent: true, side: THREE.DoubleSide, blending: THREE.AdditiveBlending }); this._light = new THREE.PointLight(0xff5500, 1, 100); this._light.position.set(0, 0.4, 0); this._lightIntensity = Math.random() * 5; this._object.add(this._light); for (var i = 0; i < density; i++) { var geometry = new THREE.SphereGeometry(1, 32, 32); var mat = this._fireMaterial.clone(); mat.uniforms.blendPattern.value = texture; mat.needsUpdate = true; var sphere = new THREE.Mesh(geometry, mat); sphere.position.y = Math.random() * height; sphere.position.x = (0.5 - Math.random()) * this._radius; sphere.position.z = (0.5 - Math.random()) * this._radius; sphere.rotateX(Math.random() * 5); sphere.rotateZ(Math.random() * 5); sphere.rotateY(Math.random() * 5); sphere.dirX = (0.5 - Math.random()) * 0.006; sphere.dirY = 0.006; sphere.dirZ = (0.5 - Math.random()) * 0.006; this._fireballs.push(sphere); } (_this$_object = this._object).add.apply(_this$_object, (0, _toConsumableArray2.default)(this._fireballs)); } }, { key: "_update", value: function _update() { var _this4 = this; this._fireballs.forEach(function (ball) { ball.position.y += ball.dirY; ball.position.x += Math.sin(ball.position.y) * ball.dirX; ball.position.z += Math.cos(ball.position.y) * ball.dirZ; if (ball.position.y > _this4._height) { ball.position.y = Math.random() * 0.1; ball.position.x = (0.5 - Math.random()) * _this4._radius; ball.position.z = (0.5 - Math.random()) * _this4._radius; } var p = 0.1 + ball.position.y / _this4._height; ball.rotateX((1.2 - p) * 0.01); ball.rotateZ((1.2 - p) * 0.01); ball.rotateY((1.2 - p) * 0.01); ball.scale.set(p, p, p); ball.material.uniforms.blend.value = p; }); this._light.intensity += (this._lightIntensity - this._light.intensity) * 0.006; if (Math.random() > 0.8) { this._lightIntensity = Math.random() * 5; } } }, { key: "removed", value: function removed() { var map = this.map, layerId = this.layerId, features = this.features.features; if (map && layerId && features.length) { features.forEach(function (feature, index) { var geometry = feature.geometry; if (geometry.type === 'Point') { var featureLayerId = "".concat(layerId, "-").concat(index); map.getLayer(featureLayerId) && map.removeLayer(featureLayerId); } }); } } }]); return FireLayerViewModel; }(_mapboxGlEnhance.default.Evented); exports.default = FireLayerViewModel; /***/ }), /***/ "03b3": /***/ (function(module, exports, __webpack_require__) { "use strict"; var _interopRequireDefault = __webpack_require__("8e6d"); Object.defineProperty(exports, "__esModule", { value: true }); exports.default = void 0; var _classCallCheck2 = _interopRequireDefault(__webpack_require__("19e1")); var HeatMapStyle = function HeatMapStyle() { var paint = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; var layout = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {}; (0, _classCallCheck2.default)(this, HeatMapStyle); this.paint = { 'heatmap-radius': 30, 'heatmap-weight': 1, 'heatmap-intensity': 1, 'heatmap-color': ['interpolate', ['linear'], ['heatmap-density'], 0, 'rgba(0, 0, 255, 0)', 0.1, 'royalblue', 0.3, 'cyan', 0.5, 'lime', 0.7, 'yellow', 1, 'red'], 'heatmap-opacity': 1 }; this.layout = { visibility: 'visible' }; Object.assign(this.paint, paint); Object.assign(this.layout, layout); }; exports.default = HeatMapStyle; /***/ }), /***/ "03e1": /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); /* harmony import */ var _node_modules_babel_loader_lib_index_js_node_modules_vue_loader_lib_index_js_vue_loader_options_Pagination_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__("399a"); /* harmony import */ var _node_modules_babel_loader_lib_index_js_node_modules_vue_loader_lib_index_js_vue_loader_options_Pagination_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_node_modules_babel_loader_lib_index_js_node_modules_vue_loader_lib_index_js_vue_loader_options_Pagination_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_0__); /* harmony reexport (unknown) */ for(var __WEBPACK_IMPORT_KEY__ in _node_modules_babel_loader_lib_index_js_node_modules_vue_loader_lib_index_js_vue_loader_options_Pagination_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_0__) if(__WEBPACK_IMPORT_KEY__ !== 'default') (function(key) { __webpack_require__.d(__webpack_exports__, key, function() { return _node_modules_babel_loader_lib_index_js_node_modules_vue_loader_lib_index_js_vue_loader_options_Pagination_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_0__[key]; }) }(__WEBPACK_IMPORT_KEY__)); /* harmony default export */ __webpack_exports__["default"] = (_node_modules_babel_loader_lib_index_js_node_modules_vue_loader_lib_index_js_vue_loader_options_Pagination_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_0___default.a); /***/ }), /***/ "0467": /***/ (function(module, exports, __webpack_require__) { "use strict"; var _interopRequireDefault = __webpack_require__("8e6d"); Object.defineProperty(exports, "__esModule", { value: true }); exports.default = void 0; var _classCallCheck2 = _interopRequireDefault(__webpack_require__("19e1")); var _createClass2 = _interopRequireDefault(__webpack_require__("66f6")); var _possibleConstructorReturn2 = _interopRequireDefault(__webpack_require__("8377")); var _getPrototypeOf2 = _interopRequireDefault(__webpack_require__("c031")); var _inherits2 = _interopRequireDefault(__webpack_require__("6b51")); var _colorcolor = _interopRequireDefault(__webpack_require__("4552")); var _Marker2 = _interopRequireDefault(__webpack_require__("4361")); var HaloRingMarker = /*#__PURE__*/ function (_Marker) { (0, _inherits2.default)(HaloRingMarker, _Marker); function HaloRingMarker(features) { var _this; var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {}; (0, _classCallCheck2.default)(this, HaloRingMarker); _this = (0, _possibleConstructorReturn2.default)(this, (0, _getPrototypeOf2.default)(HaloRingMarker).call(this, features, options)); _this.features && _this._createMarker(); return _this; } (0, _createClass2.default)(HaloRingMarker, [{ key: "setMarkersWidth", value: function setMarkersWidth(width) { this.options.width = width; var markerContainer = document.getElementsByClassName('sm-component-animate-marker--halo-ring'); for (var i = 0; i < markerContainer.length; i++) { var style = markerContainer[i].style; style.setProperty('--halo-width', this.options.width + 'px'); style.setProperty('--halo-left', -this.options.width / 2 + 'px'); style.setProperty('--box-shadow-width-1', this.options.width / 10 + 'px'); style.setProperty('--box-shadow-width-2', this.options.width / 4 + 'px'); } } }, { key: "setMarkersColors", value: function setMarkersColors(colors) { this.options.colors = colors; if (colors && colors.length && colors.length > 0) { var markerContainer = document.getElementsByClassName('sm-component-animate-marker--halo-ring'); for (var i = 0; i < markerContainer.length; i++) { var style = markerContainer[i].style; style.setProperty('--color-1', this._getColorWithOpacity(this.options.colors[0], 0.3)); style.setProperty('--color-1-transparent', this._getColorWithOpacity(this.options.colors[0], 0.1)); style.setProperty('--color-2', this._getColorWithOpacity(this.options.colors[1], 0.3)); style.setProperty('--color-2-transparent', this._getColorWithOpacity(this.options.colors[1], 0.1)); } } } }, { key: "_createMarker", value: function _createMarker() { var _this2 = this; this.features.features.forEach(function (point) { var markerContainer = document.createElement('div'); markerContainer.className = 'sm-component-animate-marker--halo-ring'; var childElements = _this2._createMakerElement(8, 'div', ['sm-component-animate-marker__ring', 'sm-component-animate-marker__halo']); childElements.forEach(function (element) { markerContainer.appendChild(element); }); var nameContainer = _this2._getTextContainer(point, 'halo-ring-name'); markerContainer.appendChild(nameContainer); if (_this2.options.width) { markerContainer.style.setProperty('--halo-width', _this2.options.width + 'px'); markerContainer.style.setProperty('--halo-left', -_this2.options.width / 2 + 'px'); markerContainer.style.setProperty('--box-shadow-width-1', _this2.options.width / 10 + 'px'); markerContainer.style.setProperty('--box-shadow-width-2', _this2.options.width / 4 + 'px'); } if (_this2.options.colors && _this2.options.colors.length && _this2.options.colors.length > 0) { markerContainer.style.setProperty('--color-1', _this2._getColorWithOpacity((0, _colorcolor.default)(_this2.options.colors[0], 'rgba', true), 0.3)); markerContainer.style.setProperty('--color-1-transparent', _this2._getColorWithOpacity((0, _colorcolor.default)(_this2.options.colors[0], 'rgba', true), 0.1)); markerContainer.style.setProperty('--color-2', _this2._getColorWithOpacity((0, _colorcolor.default)(_this2.options.colors[1], 'rgba', true), 0.3)); markerContainer.style.setProperty('--color-2-transparent', _this2._getColorWithOpacity((0, _colorcolor.default)(_this2.options.colors[1], 'rgba', true), 0.1)); } _this2.markersElement.push(markerContainer); }, this); } }, { key: "_createMakerElement", value: function _createMakerElement(length, type, classNames) { var markerElements = []; for (var i = 1; i < length + 1; i++) { var element = document.createElement(type); element.className = "".concat(classNames[0], "-0").concat(i, " ").concat(classNames[1]); markerElements.push(element); } return markerElements; } }]); return HaloRingMarker; }(_Marker2.default); exports.default = HaloRingMarker; /***/ }), /***/ "05d2": /***/ (function(module, exports) { module.exports = "" /***/ }), /***/ "0601": /***/ (function(module, exports, __webpack_require__) { "use strict"; var _interopRequireDefault = __webpack_require__("8e6d"); Object.defineProperty(exports, "__esModule", { value: true }); exports.default = void 0; var _classCallCheck2 = _interopRequireDefault(__webpack_require__("19e1")); var _createClass2 = _interopRequireDefault(__webpack_require__("66f6")); var _possibleConstructorReturn2 = _interopRequireDefault(__webpack_require__("8377")); var _getPrototypeOf2 = _interopRequireDefault(__webpack_require__("c031")); var _inherits2 = _interopRequireDefault(__webpack_require__("6b51")); var _mapboxGlEnhance = _interopRequireDefault(__webpack_require__("3d57")); __webpack_require__("f240"); var UniqueThemeLayerViewModel = /*#__PURE__*/ function (_mapboxgl$Evented) { (0, _inherits2.default)(UniqueThemeLayerViewModel, _mapboxgl$Evented); function UniqueThemeLayerViewModel(themeProps) { var _this; (0, _classCallCheck2.default)(this, UniqueThemeLayerViewModel); _this = (0, _possibleConstructorReturn2.default)(this, (0, _getPrototypeOf2.default)(UniqueThemeLayerViewModel).call(this)); var layerName = themeProps.layerName, options = themeProps.options, layerId = themeProps.layerId, data = themeProps.data; _this.layerName = layerName || layerId; options.id = options.id || layerId; _this.options = options; _this.layerId = layerId; _this.data = data || []; return _this; } (0, _createClass2.default)(UniqueThemeLayerViewModel, [{ key: "setMap", value: function setMap(mapInfo) { var map = mapInfo.map; this.map = map; this._init(); } }, { key: "_init", value: function _init() { this.themeLayer = new _mapboxGlEnhance.default.supermap.UniqueThemeLayer(this.layerName, this.options); this.map.addLayer(this.themeLayer); this.themeLayer.addFeatures(this.data); } }, { key: "setOptions", value: function setOptions(options) { this.options = options; this.removed(); this._init(); } }, { key: "setData", value: function setData(data) { this.data = data; this.removed(); this._init(); } }, { key: "removed", value: function removed() { var map = this.map, options = this.options; var layerId = options.id; if (map && layerId && map.getLayer(layerId)) { map.removeLayer(layerId); } } }]); return UniqueThemeLayerViewModel; }(_mapboxGlEnhance.default.Evented); exports.default = UniqueThemeLayerViewModel; /***/ }), /***/ "0625": /***/ (function(module, exports, __webpack_require__) { "use strict"; var _interopRequireDefault = __webpack_require__("8e6d"); Object.defineProperty(exports, "__esModule", { value: true }); exports.default = void 0; var _PanViewModel = _interopRequireDefault(__webpack_require__("3850")); var _mapGetter = _interopRequireDefault(__webpack_require__("b761")); var _control = _interopRequireDefault(__webpack_require__("2c56")); // // // // // // // // // // // // // // // // // // // // // // // // // // // // // var _default = { name: 'SmPan', mixins: [_mapGetter.default, _control.default], props: { panLength: { type: Number, default: 200 } }, data: function data() { return { center: null, panImgClass: 'sm-component-pan--default', mapboxglClass: '' }; }, created: function created() { this.viewModel = new _PanViewModel.default(); }, methods: { panToCenter: function panToCenter() { this.lnglat = this.center; this.panTo(this.lnglat); }, panToLeft: function panToLeft() { // this.lnglat.lng -= this.panLength; // this.panTo(this.lnglat); this.panBy([-this.panLength, 0]); }, panToRight: function panToRight() { // this.lnglat.lng += this.panLength; // this.panTo(this.lnglat); this.panBy([this.panLength, 0]); }, panToTop: function panToTop() { // this.lnglat.lat -= this.panLength; // this.panTo(this.lnglat); this.panBy([0, -this.panLength]); }, panToBottom: function panToBottom() { // this.lnglat.lat += this.panLength; // this.panTo(this.lnglat); this.panBy([0, this.panLength]); }, panTo: function panTo(lnglat) { var mapNotLoaded = this.mapNotLoadedTip(); if (mapNotLoaded) { return; } this.viewModel.panTo(lnglat); }, panBy: function panBy(point) { var mapNotLoaded = this.mapNotLoadedTip(); if (mapNotLoaded) { return; } this.viewModel.panBy(point); }, setPanImg: function setPanImg() { this.panImgClass = 'sm-component-pan--default'; }, setPanWestImg: function setPanWestImg() { this.panImgClass = 'sm-component-pan--west'; }, setPanEastImg: function setPanEastImg() { this.panImgClass = 'sm-component-pan--east'; }, setPanNorthImg: function setPanNorthImg() { this.panImgClass = 'sm-component-pan--north'; }, setPanSouthImg: function setPanSouthImg() { this.panImgClass = 'sm-component-pan--south'; } }, loaded: function loaded() { this.parentIsWebMapOrMap && (this.mapboxglClass = 'mapboxgl-ctrl'); this.center = this.map.getCenter(); this.lnglat = this.center; } }; exports.default = _default; /***/ }), /***/ "0640": /***/ (function(module, exports, __webpack_require__) { module.exports = __webpack_require__("bbe9").PassThrough /***/ }), /***/ "0650": /***/ (function(module, exports, __webpack_require__) { "use strict"; Object.defineProperty(exports, "__esModule", { value: true }); var meta_1 = __webpack_require__("49c0"); // Note: change RADIUS => earthRadius var RADIUS = 6378137; /** * Takes one or more features and returns their area in square meters. * * @name area * @param {GeoJSON} geojson input GeoJSON feature(s) * @returns {number} area in square meters * @example * var polygon = turf.polygon([[[125, -15], [113, -22], [154, -27], [144, -15], [125, -15]]]); * * var area = turf.area(polygon); * * //addToMap * var addToMap = [polygon] * polygon.properties.area = area */ function area(geojson) { return meta_1.geomReduce(geojson, function (value, geom) { return value + calculateArea(geom); }, 0); } exports.default = area; /** * Calculate Area * * @private * @param {Geometry} geom GeoJSON Geometries * @returns {number} area */ function calculateArea(geom) { var total = 0; var i; switch (geom.type) { case "Polygon": return polygonArea(geom.coordinates); case "MultiPolygon": for (i = 0; i < geom.coordinates.length; i++) { total += polygonArea(geom.coordinates[i]); } return total; case "Point": case "MultiPoint": case "LineString": case "MultiLineString": return 0; } return 0; } function polygonArea(coords) { var total = 0; if (coords && coords.length > 0) { total += Math.abs(ringArea(coords[0])); for (var i = 1; i < coords.length; i++) { total -= Math.abs(ringArea(coords[i])); } } return total; } /** * @private * Calculate the approximate area of the polygon were it projected onto the earth. * Note that this area will be positive if ring is oriented clockwise, otherwise it will be negative. * * Reference: * Robert. G. Chamberlain and William H. Duquette, "Some Algorithms for Polygons on a Sphere", * JPL Publication 07-03, Jet Propulsion * Laboratory, Pasadena, CA, June 2007 http://trs-new.jpl.nasa.gov/dspace/handle/2014/40409 * * @param {Array>} coords Ring Coordinates * @returns {number} The approximate signed geodesic area of the polygon in square meters. */ function ringArea(coords) { var p1; var p2; var p3; var lowerIndex; var middleIndex; var upperIndex; var i; var total = 0; var coordsLength = coords.length; if (coordsLength > 2) { for (i = 0; i < coordsLength; i++) { if (i === coordsLength - 2) { lowerIndex = coordsLength - 2; middleIndex = coordsLength - 1; upperIndex = 0; } else if (i === coordsLength - 1) { lowerIndex = coordsLength - 1; middleIndex = 0; upperIndex = 1; } else { lowerIndex = i; middleIndex = i + 1; upperIndex = i + 2; } p1 = coords[lowerIndex]; p2 = coords[middleIndex]; p3 = coords[upperIndex]; total += (rad(p3[0]) - rad(p1[0])) * Math.sin(rad(p2[1])); } total = total * RADIUS * RADIUS / 2; } return total; } function rad(num) { return num * Math.PI / 180; } /***/ }), /***/ "074d": /***/ (function(module, exports) { module.exports = "" /***/ }), /***/ "089f": /***/ (function(module, exports) { /** Used for built-in method references. */ var objectProto = Object.prototype; /** * Used to resolve the * [`toStringTag`](http://ecma-international.org/ecma-262/7.0/#sec-object.prototype.tostring) * of values. */ var nativeObjectToString = objectProto.toString; /** * Converts `value` to a string using `Object.prototype.toString`. * * @private * @param {*} value The value to convert. * @returns {string} Returns the converted string. */ function objectToString(value) { return nativeObjectToString.call(value); } module.exports = objectToString; /***/ }), /***/ "08d1": /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); /* harmony import */ var _Indicator_vue_vue_type_template_id_39b17318___WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__("022b"); /* harmony import */ var _Indicator_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__("13f5"); /* harmony reexport (unknown) */ for(var __WEBPACK_IMPORT_KEY__ in _Indicator_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_1__) if(__WEBPACK_IMPORT_KEY__ !== 'default') (function(key) { __webpack_require__.d(__webpack_exports__, key, function() { return _Indicator_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_1__[key]; }) }(__WEBPACK_IMPORT_KEY__)); /* harmony import */ var _node_modules_vue_loader_lib_runtime_componentNormalizer_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__("b429"); /* normalize component */ var component = Object(_node_modules_vue_loader_lib_runtime_componentNormalizer_js__WEBPACK_IMPORTED_MODULE_2__[/* default */ "a"])( _Indicator_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_1__["default"], _Indicator_vue_vue_type_template_id_39b17318___WEBPACK_IMPORTED_MODULE_0__[/* render */ "a"], _Indicator_vue_vue_type_template_id_39b17318___WEBPACK_IMPORTED_MODULE_0__[/* staticRenderFns */ "b"], false, null, null, null ) /* harmony default export */ __webpack_exports__["default"] = (component.exports); /***/ }), /***/ "090e": /***/ (function(module) { module.exports = JSON.parse("{\"buoy-icon-1\":{\"width\":26,\"height\":30,\"x\":318,\"y\":117,\"pixelRatio\":1,\"visible\":true},\"buoy-icon-2\":{\"width\":26,\"height\":30,\"x\":348,\"y\":117,\"pixelRatio\":1,\"visible\":true},\"buoy-icon-3\":{\"width\":26,\"height\":30,\"x\":378,\"y\":117,\"pixelRatio\":1,\"visible\":true},\"buoy-icon-4\":{\"width\":26,\"height\":30,\"x\":408,\"y\":117,\"pixelRatio\":1,\"visible\":true},\"buoy-icon-5\":{\"width\":26,\"height\":30,\"x\":438,\"y\":117,\"pixelRatio\":1,\"visible\":true},\"buoy-icon-6\":{\"width\":26,\"height\":30,\"x\":468,\"y\":117,\"pixelRatio\":1,\"visible\":true},\"buoy-icon-7\":{\"width\":26,\"height\":30,\"x\":498,\"y\":117,\"pixelRatio\":1,\"visible\":true},\"buoy-icon-8\":{\"width\":26,\"height\":30,\"x\":528,\"y\":117,\"pixelRatio\":1,\"visible\":true},\"buoy-icon-9\":{\"width\":26,\"height\":30,\"x\":558,\"y\":117,\"pixelRatio\":1,\"visible\":true},\"buoy-icon-10\":{\"width\":26,\"height\":30,\"x\":588,\"y\":117,\"pixelRatio\":1,\"visible\":true},\"buoy-icon-active-1\":{\"width\":26,\"height\":30,\"x\":316,\"y\":77,\"pixelRatio\":1,\"visible\":true},\"buoy-icon-active-2\":{\"width\":26,\"height\":30,\"x\":346,\"y\":77,\"pixelRatio\":1,\"visible\":true},\"buoy-icon-active-3\":{\"width\":26,\"height\":30,\"x\":376,\"y\":77,\"pixelRatio\":1,\"visible\":true},\"buoy-icon-active-4\":{\"width\":26,\"height\":30,\"x\":406,\"y\":77,\"pixelRatio\":1,\"visible\":true},\"buoy-icon-active-5\":{\"width\":26,\"height\":30,\"x\":436,\"y\":77,\"pixelRatio\":1,\"visible\":true},\"buoy-icon-active-6\":{\"width\":26,\"height\":30,\"x\":466,\"y\":77,\"pixelRatio\":1,\"visible\":true},\"buoy-icon-active-7\":{\"width\":26,\"height\":30,\"x\":496,\"y\":77,\"pixelRatio\":1,\"visible\":true},\"buoy-icon-active-8\":{\"width\":26,\"height\":30,\"x\":526,\"y\":77,\"pixelRatio\":1,\"visible\":true},\"buoy-icon-active-9\":{\"width\":26,\"height\":30,\"x\":556,\"y\":77,\"pixelRatio\":1,\"visible\":true},\"buoy-icon-active-10\":{\"width\":26,\"height\":30,\"x\":586,\"y\":77,\"pixelRatio\":1,\"visible\":true}}"); /***/ }), /***/ "0956": /***/ (function(module, exports, __webpack_require__) { "use strict"; // Copyright Joyent, Inc. and other Node contributors. // // Permission is hereby granted, free of charge, to any person obtaining a // copy of this software and associated documentation files (the // "Software"), to deal in the Software without restriction, including // without limitation the rights to use, copy, modify, merge, publish, // distribute, sublicense, and/or sell copies of the Software, and to permit // persons to whom the Software is furnished to do so, subject to the // following conditions: // // The above copyright notice and this permission notice shall be included // in all copies or substantial portions of the Software. // // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS // OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF // MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN // NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, // DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR // OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE // USE OR OTHER DEALINGS IN THE SOFTWARE. var R = typeof Reflect === 'object' ? Reflect : null var ReflectApply = R && typeof R.apply === 'function' ? R.apply : function ReflectApply(target, receiver, args) { return Function.prototype.apply.call(target, receiver, args); } var ReflectOwnKeys if (R && typeof R.ownKeys === 'function') { ReflectOwnKeys = R.ownKeys } else if (Object.getOwnPropertySymbols) { ReflectOwnKeys = function ReflectOwnKeys(target) { return Object.getOwnPropertyNames(target) .concat(Object.getOwnPropertySymbols(target)); }; } else { ReflectOwnKeys = function ReflectOwnKeys(target) { return Object.getOwnPropertyNames(target); }; } function ProcessEmitWarning(warning) { if (console && console.warn) console.warn(warning); } var NumberIsNaN = Number.isNaN || function NumberIsNaN(value) { return value !== value; } function EventEmitter() { EventEmitter.init.call(this); } module.exports = EventEmitter; // Backwards-compat with node 0.10.x EventEmitter.EventEmitter = EventEmitter; EventEmitter.prototype._events = undefined; EventEmitter.prototype._eventsCount = 0; EventEmitter.prototype._maxListeners = undefined; // By default EventEmitters will print a warning if more than 10 listeners are // added to it. This is a useful default which helps finding memory leaks. var defaultMaxListeners = 10; Object.defineProperty(EventEmitter, 'defaultMaxListeners', { enumerable: true, get: function() { return defaultMaxListeners; }, set: function(arg) { if (typeof arg !== 'number' || arg < 0 || NumberIsNaN(arg)) { throw new RangeError('The value of "defaultMaxListeners" is out of range. It must be a non-negative number. Received ' + arg + '.'); } defaultMaxListeners = arg; } }); EventEmitter.init = function() { if (this._events === undefined || this._events === Object.getPrototypeOf(this)._events) { this._events = Object.create(null); this._eventsCount = 0; } this._maxListeners = this._maxListeners || undefined; }; // Obviously not all Emitters should be limited to 10. This function allows // that to be increased. Set to zero for unlimited. EventEmitter.prototype.setMaxListeners = function setMaxListeners(n) { if (typeof n !== 'number' || n < 0 || NumberIsNaN(n)) { throw new RangeError('The value of "n" is out of range. It must be a non-negative number. Received ' + n + '.'); } this._maxListeners = n; return this; }; function $getMaxListeners(that) { if (that._maxListeners === undefined) return EventEmitter.defaultMaxListeners; return that._maxListeners; } EventEmitter.prototype.getMaxListeners = function getMaxListeners() { return $getMaxListeners(this); }; EventEmitter.prototype.emit = function emit(type) { var args = []; for (var i = 1; i < arguments.length; i++) args.push(arguments[i]); var doError = (type === 'error'); var events = this._events; if (events !== undefined) doError = (doError && events.error === undefined); else if (!doError) return false; // If there is no 'error' event listener then throw. if (doError) { var er; if (args.length > 0) er = args[0]; if (er instanceof Error) { // Note: The comments on the `throw` lines are intentional, they show // up in Node's output if this results in an unhandled exception. throw er; // Unhandled 'error' event } // At least give some kind of context to the user var err = new Error('Unhandled error.' + (er ? ' (' + er.message + ')' : '')); err.context = er; throw err; // Unhandled 'error' event } var handler = events[type]; if (handler === undefined) return false; if (typeof handler === 'function') { ReflectApply(handler, this, args); } else { var len = handler.length; var listeners = arrayClone(handler, len); for (var i = 0; i < len; ++i) ReflectApply(listeners[i], this, args); } return true; }; function _addListener(target, type, listener, prepend) { var m; var events; var existing; if (typeof listener !== 'function') { throw new TypeError('The "listener" argument must be of type Function. Received type ' + typeof listener); } events = target._events; if (events === undefined) { events = target._events = Object.create(null); target._eventsCount = 0; } else { // To avoid recursion in the case that type === "newListener"! Before // adding it to the listeners, first emit "newListener". if (events.newListener !== undefined) { target.emit('newListener', type, listener.listener ? listener.listener : listener); // Re-assign `events` because a newListener handler could have caused the // this._events to be assigned to a new object events = target._events; } existing = events[type]; } if (existing === undefined) { // Optimize the case of one listener. Don't need the extra array object. existing = events[type] = listener; ++target._eventsCount; } else { if (typeof existing === 'function') { // Adding the second element, need to change to array. existing = events[type] = prepend ? [listener, existing] : [existing, listener]; // If we've already got an array, just append. } else if (prepend) { existing.unshift(listener); } else { existing.push(listener); } // Check for listener leak m = $getMaxListeners(target); if (m > 0 && existing.length > m && !existing.warned) { existing.warned = true; // No error code for this since it is a Warning // eslint-disable-next-line no-restricted-syntax var w = new Error('Possible EventEmitter memory leak detected. ' + existing.length + ' ' + String(type) + ' listeners ' + 'added. Use emitter.setMaxListeners() to ' + 'increase limit'); w.name = 'MaxListenersExceededWarning'; w.emitter = target; w.type = type; w.count = existing.length; ProcessEmitWarning(w); } } return target; } EventEmitter.prototype.addListener = function addListener(type, listener) { return _addListener(this, type, listener, false); }; EventEmitter.prototype.on = EventEmitter.prototype.addListener; EventEmitter.prototype.prependListener = function prependListener(type, listener) { return _addListener(this, type, listener, true); }; function onceWrapper() { var args = []; for (var i = 0; i < arguments.length; i++) args.push(arguments[i]); if (!this.fired) { this.target.removeListener(this.type, this.wrapFn); this.fired = true; ReflectApply(this.listener, this.target, args); } } function _onceWrap(target, type, listener) { var state = { fired: false, wrapFn: undefined, target: target, type: type, listener: listener }; var wrapped = onceWrapper.bind(state); wrapped.listener = listener; state.wrapFn = wrapped; return wrapped; } EventEmitter.prototype.once = function once(type, listener) { if (typeof listener !== 'function') { throw new TypeError('The "listener" argument must be of type Function. Received type ' + typeof listener); } this.on(type, _onceWrap(this, type, listener)); return this; }; EventEmitter.prototype.prependOnceListener = function prependOnceListener(type, listener) { if (typeof listener !== 'function') { throw new TypeError('The "listener" argument must be of type Function. Received type ' + typeof listener); } this.prependListener(type, _onceWrap(this, type, listener)); return this; }; // Emits a 'removeListener' event if and only if the listener was removed. EventEmitter.prototype.removeListener = function removeListener(type, listener) { var list, events, position, i, originalListener; if (typeof listener !== 'function') { throw new TypeError('The "listener" argument must be of type Function. Received type ' + typeof listener); } events = this._events; if (events === undefined) return this; list = events[type]; if (list === undefined) return this; if (list === listener || list.listener === listener) { if (--this._eventsCount === 0) this._events = Object.create(null); else { delete events[type]; if (events.removeListener) this.emit('removeListener', type, list.listener || listener); } } else if (typeof list !== 'function') { position = -1; for (i = list.length - 1; i >= 0; i--) { if (list[i] === listener || list[i].listener === listener) { originalListener = list[i].listener; position = i; break; } } if (position < 0) return this; if (position === 0) list.shift(); else { spliceOne(list, position); } if (list.length === 1) events[type] = list[0]; if (events.removeListener !== undefined) this.emit('removeListener', type, originalListener || listener); } return this; }; EventEmitter.prototype.off = EventEmitter.prototype.removeListener; EventEmitter.prototype.removeAllListeners = function removeAllListeners(type) { var listeners, events, i; events = this._events; if (events === undefined) return this; // not listening for removeListener, no need to emit if (events.removeListener === undefined) { if (arguments.length === 0) { this._events = Object.create(null); this._eventsCount = 0; } else if (events[type] !== undefined) { if (--this._eventsCount === 0) this._events = Object.create(null); else delete events[type]; } return this; } // emit removeListener for all listeners on all events if (arguments.length === 0) { var keys = Object.keys(events); var key; for (i = 0; i < keys.length; ++i) { key = keys[i]; if (key === 'removeListener') continue; this.removeAllListeners(key); } this.removeAllListeners('removeListener'); this._events = Object.create(null); this._eventsCount = 0; return this; } listeners = events[type]; if (typeof listeners === 'function') { this.removeListener(type, listeners); } else if (listeners !== undefined) { // LIFO order for (i = listeners.length - 1; i >= 0; i--) { this.removeListener(type, listeners[i]); } } return this; }; function _listeners(target, type, unwrap) { var events = target._events; if (events === undefined) return []; var evlistener = events[type]; if (evlistener === undefined) return []; if (typeof evlistener === 'function') return unwrap ? [evlistener.listener || evlistener] : [evlistener]; return unwrap ? unwrapListeners(evlistener) : arrayClone(evlistener, evlistener.length); } EventEmitter.prototype.listeners = function listeners(type) { return _listeners(this, type, true); }; EventEmitter.prototype.rawListeners = function rawListeners(type) { return _listeners(this, type, false); }; EventEmitter.listenerCount = function(emitter, type) { if (typeof emitter.listenerCount === 'function') { return emitter.listenerCount(type); } else { return listenerCount.call(emitter, type); } }; EventEmitter.prototype.listenerCount = listenerCount; function listenerCount(type) { var events = this._events; if (events !== undefined) { var evlistener = events[type]; if (typeof evlistener === 'function') { return 1; } else if (evlistener !== undefined) { return evlistener.length; } } return 0; } EventEmitter.prototype.eventNames = function eventNames() { return this._eventsCount > 0 ? ReflectOwnKeys(this._events) : []; }; function arrayClone(arr, n) { var copy = new Array(n); for (var i = 0; i < n; ++i) copy[i] = arr[i]; return copy; } function spliceOne(list, index) { for (; index + 1 < list.length; index++) list[index] = list[index + 1]; list.pop(); } function unwrapListeners(arr) { var ret = new Array(arr.length); for (var i = 0; i < ret.length; ++i) { ret[i] = arr[i].listener || arr[i]; } return ret; } /***/ }), /***/ "0a75": /***/ (function(module, exports, __webpack_require__) { "use strict"; Object.defineProperty(exports, "__esModule", { value: true }); // https://en.wikipedia.org/wiki/Rhumb_line var helpers_1 = __webpack_require__("38ce"); var invariant_1 = __webpack_require__("144a"); /** * Takes two {@link Point|points} and finds the bearing angle between them along a Rhumb line * i.e. the angle measured in degrees start the north line (0 degrees) * * @name rhumbBearing * @param {Coord} start starting Point * @param {Coord} end ending Point * @param {Object} [options] Optional parameters * @param {boolean} [options.final=false] calculates the final bearing if true * @returns {number} bearing from north in decimal degrees, between -180 and 180 degrees (positive clockwise) * @example * var point1 = turf.point([-75.343, 39.984], {"marker-color": "#F00"}); * var point2 = turf.point([-75.534, 39.123], {"marker-color": "#00F"}); * * var bearing = turf.rhumbBearing(point1, point2); * * //addToMap * var addToMap = [point1, point2]; * point1.properties.bearing = bearing; * point2.properties.bearing = bearing; */ function rhumbBearing(start, end, options) { if (options === void 0) { options = {}; } var bear360; if (options.final) { bear360 = calculateRhumbBearing(invariant_1.getCoord(end), invariant_1.getCoord(start)); } else { bear360 = calculateRhumbBearing(invariant_1.getCoord(start), invariant_1.getCoord(end)); } var bear180 = (bear360 > 180) ? -(360 - bear360) : bear360; return bear180; } /** * Returns the bearing from ‘this’ point to destination point along a rhumb line. * Adapted from Geodesy: https://github.com/chrisveness/geodesy/blob/master/latlon-spherical.js * * @private * @param {Array} from - origin point. * @param {Array} to - destination point. * @returns {number} Bearing in degrees from north. * @example * var p1 = new LatLon(51.127, 1.338); * var p2 = new LatLon(50.964, 1.853); * var d = p1.rhumbBearingTo(p2); // 116.7 m */ function calculateRhumbBearing(from, to) { // φ => phi // Δλ => deltaLambda // Δψ => deltaPsi // θ => theta var phi1 = helpers_1.degreesToRadians(from[1]); var phi2 = helpers_1.degreesToRadians(to[1]); var deltaLambda = helpers_1.degreesToRadians((to[0] - from[0])); // if deltaLambdaon over 180° take shorter rhumb line across the anti-meridian: if (deltaLambda > Math.PI) { deltaLambda -= 2 * Math.PI; } if (deltaLambda < -Math.PI) { deltaLambda += 2 * Math.PI; } var deltaPsi = Math.log(Math.tan(phi2 / 2 + Math.PI / 4) / Math.tan(phi1 / 2 + Math.PI / 4)); var theta = Math.atan2(deltaLambda, deltaPsi); return (helpers_1.radiansToDegrees(theta) + 360) % 360; } exports.default = rhumbBearing; /***/ }), /***/ "0b0f": /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); /* harmony import */ var _TimeText_vue_vue_type_template_id_6da009bc___WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__("827d"); /* harmony import */ var _TimeText_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__("d5f4"); /* harmony reexport (unknown) */ for(var __WEBPACK_IMPORT_KEY__ in _TimeText_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_1__) if(__WEBPACK_IMPORT_KEY__ !== 'default') (function(key) { __webpack_require__.d(__webpack_exports__, key, function() { return _TimeText_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_1__[key]; }) }(__WEBPACK_IMPORT_KEY__)); /* harmony import */ var _node_modules_vue_loader_lib_runtime_componentNormalizer_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__("b429"); /* normalize component */ var component = Object(_node_modules_vue_loader_lib_runtime_componentNormalizer_js__WEBPACK_IMPORTED_MODULE_2__[/* default */ "a"])( _TimeText_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_1__["default"], _TimeText_vue_vue_type_template_id_6da009bc___WEBPACK_IMPORTED_MODULE_0__[/* render */ "a"], _TimeText_vue_vue_type_template_id_6da009bc___WEBPACK_IMPORTED_MODULE_0__[/* staticRenderFns */ "b"], false, null, null, null ) /* harmony default export */ __webpack_exports__["default"] = (component.exports); /***/ }), /***/ "0b11": /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./src/common/chart/ChartMixin.vue?vue&type=template&id=1f1efe10& var render = function () {var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;return _c('sm-card',{directives:[{name:"show",rawName:"v-show",value:(_vm.isShow),expression:"isShow"}],staticClass:"sm-component-chart",attrs:{"icon-class":_vm.iconClass,"icon-position":_vm.position,"header-name":_vm.headerName,"auto-rotate":_vm.autoRotate,"collapsed":_vm.collapsed}},[_c('v-chart',{ref:_vm.chartId,style:(_vm._chartStyle),attrs:{"id":_vm.chartId,"options":_vm._chartOptions,"initOptions":_vm.initOptions,"group":_vm.group,"manual-update":_vm.manualUpdate,"theme":_vm.theme || _vm.chartTheme},on:{"datazoom":_vm.dataZoomHandler}}),_vm._v(" "),_c('TablePopup',_vm._b({directives:[{name:"show",rawName:"v-show",value:(false),expression:"false"}],ref:"chartTablePopup",attrs:{"text-color":_vm.textColor,"background":_vm.background}},'TablePopup',_vm.tablePopupProps,false))],1)} var staticRenderFns = [] // CONCATENATED MODULE: ./src/common/chart/ChartMixin.vue?vue&type=template&id=1f1efe10& /* concated harmony reexport render */__webpack_require__.d(__webpack_exports__, "a", function() { return render; }); /* concated harmony reexport staticRenderFns */__webpack_require__.d(__webpack_exports__, "b", function() { return staticRenderFns; }); /***/ }), /***/ "0c08": /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); // CONCATENATED MODULE: ./node_modules/@turf/envelope/node_modules/@turf/helpers/main.es.js /** * Earth Radius used with the Harvesine formula and approximates using a spherical (non-ellipsoid) Earth. */ var earthRadius = 6371008.8; /** * Unit of measurement factors using a spherical (non-ellipsoid) earth radius. */ var factors = { meters: earthRadius, metres: earthRadius, millimeters: earthRadius * 1000, millimetres: earthRadius * 1000, centimeters: earthRadius * 100, centimetres: earthRadius * 100, kilometers: earthRadius / 1000, kilometres: earthRadius / 1000, miles: earthRadius / 1609.344, nauticalmiles: earthRadius / 1852, inches: earthRadius * 39.370, yards: earthRadius / 1.0936, feet: earthRadius * 3.28084, radians: 1, degrees: earthRadius / 111325, }; /** * Units of measurement factors based on 1 meter. */ var unitsFactors = { meters: 1, metres: 1, millimeters: 1000, millimetres: 1000, centimeters: 100, centimetres: 100, kilometers: 1 / 1000, kilometres: 1 / 1000, miles: 1 / 1609.344, nauticalmiles: 1 / 1852, inches: 39.370, yards: 1 / 1.0936, feet: 3.28084, radians: 1 / earthRadius, degrees: 1 / 111325, }; /** * Area of measurement factors based on 1 square meter. */ var areaFactors = { meters: 1, metres: 1, millimeters: 1000000, millimetres: 1000000, centimeters: 10000, centimetres: 10000, kilometers: 0.000001, kilometres: 0.000001, acres: 0.000247105, miles: 3.86e-7, yards: 1.195990046, feet: 10.763910417, inches: 1550.003100006 }; /** * Wraps a GeoJSON {@link Geometry} in a GeoJSON {@link Feature}. * * @name feature * @param {Geometry} geometry input geometry * @param {Object} [properties={}] an Object of key-value pairs to add as properties * @param {Object} [options={}] Optional Parameters * @param {Array} [options.bbox] Bounding Box Array [west, south, east, north] associated with the Feature * @param {string|number} [options.id] Identifier associated with the Feature * @returns {Feature} a GeoJSON Feature * @example * var geometry = { * "type": "Point", * "coordinates": [110, 50] * }; * * var feature = turf.feature(geometry); * * //=feature */ function feature(geometry, properties, options) { // Optional Parameters options = options || {}; if (!isObject(options)) throw new Error('options is invalid'); var bbox = options.bbox; var id = options.id; // Validation if (geometry === undefined) throw new Error('geometry is required'); if (properties && properties.constructor !== Object) throw new Error('properties must be an Object'); if (bbox) validateBBox(bbox); if (id) validateId(id); // Main var feat = {type: 'Feature'}; if (id) feat.id = id; if (bbox) feat.bbox = bbox; feat.properties = properties || {}; feat.geometry = geometry; return feat; } /** * Creates a GeoJSON {@link Geometry} from a Geometry string type & coordinates. * For GeometryCollection type use `helpers.geometryCollection` * * @name geometry * @param {string} type Geometry Type * @param {Array} coordinates Coordinates * @param {Object} [options={}] Optional Parameters * @param {Array} [options.bbox] Bounding Box Array [west, south, east, north] associated with the Geometry * @returns {Geometry} a GeoJSON Geometry * @example * var type = 'Point'; * var coordinates = [110, 50]; * * var geometry = turf.geometry(type, coordinates); * * //=geometry */ function main_es_geometry(type, coordinates, options) { // Optional Parameters options = options || {}; if (!isObject(options)) throw new Error('options is invalid'); var bbox = options.bbox; // Validation if (!type) throw new Error('type is required'); if (!coordinates) throw new Error('coordinates is required'); if (!Array.isArray(coordinates)) throw new Error('coordinates must be an Array'); if (bbox) validateBBox(bbox); // Main var geom; switch (type) { case 'Point': geom = point(coordinates).geometry; break; case 'LineString': geom = lineString(coordinates).geometry; break; case 'Polygon': geom = polygon(coordinates).geometry; break; case 'MultiPoint': geom = multiPoint(coordinates).geometry; break; case 'MultiLineString': geom = multiLineString(coordinates).geometry; break; case 'MultiPolygon': geom = multiPolygon(coordinates).geometry; break; default: throw new Error(type + ' is invalid'); } if (bbox) geom.bbox = bbox; return geom; } /** * Creates a {@link Point} {@link Feature} from a Position. * * @name point * @param {Array} coordinates longitude, latitude position (each in decimal degrees) * @param {Object} [properties={}] an Object of key-value pairs to add as properties * @param {Object} [options={}] Optional Parameters * @param {Array} [options.bbox] Bounding Box Array [west, south, east, north] associated with the Feature * @param {string|number} [options.id] Identifier associated with the Feature * @returns {Feature} a Point feature * @example * var point = turf.point([-75.343, 39.984]); * * //=point */ function point(coordinates, properties, options) { if (!coordinates) throw new Error('coordinates is required'); if (!Array.isArray(coordinates)) throw new Error('coordinates must be an Array'); if (coordinates.length < 2) throw new Error('coordinates must be at least 2 numbers long'); if (!isNumber(coordinates[0]) || !isNumber(coordinates[1])) throw new Error('coordinates must contain numbers'); return feature({ type: 'Point', coordinates: coordinates }, properties, options); } /** * Creates a {@link Point} {@link FeatureCollection} from an Array of Point coordinates. * * @name points * @param {Array>} coordinates an array of Points * @param {Object} [properties={}] Translate these properties to each Feature * @param {Object} [options={}] Optional Parameters * @param {Array} [options.bbox] Bounding Box Array [west, south, east, north] associated with the FeatureCollection * @param {string|number} [options.id] Identifier associated with the FeatureCollection * @returns {FeatureCollection} Point Feature * @example * var points = turf.points([ * [-75, 39], * [-80, 45], * [-78, 50] * ]); * * //=points */ function points(coordinates, properties, options) { if (!coordinates) throw new Error('coordinates is required'); if (!Array.isArray(coordinates)) throw new Error('coordinates must be an Array'); return featureCollection(coordinates.map(function (coords) { return point(coords, properties); }), options); } /** * Creates a {@link Polygon} {@link Feature} from an Array of LinearRings. * * @name polygon * @param {Array>>} coordinates an array of LinearRings * @param {Object} [properties={}] an Object of key-value pairs to add as properties * @param {Object} [options={}] Optional Parameters * @param {Array} [options.bbox] Bounding Box Array [west, south, east, north] associated with the Feature * @param {string|number} [options.id] Identifier associated with the Feature * @returns {Feature} Polygon Feature * @example * var polygon = turf.polygon([[[-5, 52], [-4, 56], [-2, 51], [-7, 54], [-5, 52]]], { name: 'poly1' }); * * //=polygon */ function polygon(coordinates, properties, options) { if (!coordinates) throw new Error('coordinates is required'); for (var i = 0; i < coordinates.length; i++) { var ring = coordinates[i]; if (ring.length < 4) { throw new Error('Each LinearRing of a Polygon must have 4 or more Positions.'); } for (var j = 0; j < ring[ring.length - 1].length; j++) { // Check if first point of Polygon contains two numbers if (i === 0 && j === 0 && !isNumber(ring[0][0]) || !isNumber(ring[0][1])) throw new Error('coordinates must contain numbers'); if (ring[ring.length - 1][j] !== ring[0][j]) { throw new Error('First and last Position are not equivalent.'); } } } return feature({ type: 'Polygon', coordinates: coordinates }, properties, options); } /** * Creates a {@link Polygon} {@link FeatureCollection} from an Array of Polygon coordinates. * * @name polygons * @param {Array>>>} coordinates an array of Polygon coordinates * @param {Object} [properties={}] an Object of key-value pairs to add as properties * @param {Object} [options={}] Optional Parameters * @param {Array} [options.bbox] Bounding Box Array [west, south, east, north] associated with the Feature * @param {string|number} [options.id] Identifier associated with the FeatureCollection * @returns {FeatureCollection} Polygon FeatureCollection * @example * var polygons = turf.polygons([ * [[[-5, 52], [-4, 56], [-2, 51], [-7, 54], [-5, 52]]], * [[[-15, 42], [-14, 46], [-12, 41], [-17, 44], [-15, 42]]], * ]); * * //=polygons */ function polygons(coordinates, properties, options) { if (!coordinates) throw new Error('coordinates is required'); if (!Array.isArray(coordinates)) throw new Error('coordinates must be an Array'); return featureCollection(coordinates.map(function (coords) { return polygon(coords, properties); }), options); } /** * Creates a {@link LineString} {@link Feature} from an Array of Positions. * * @name lineString * @param {Array>} coordinates an array of Positions * @param {Object} [properties={}] an Object of key-value pairs to add as properties * @param {Object} [options={}] Optional Parameters * @param {Array} [options.bbox] Bounding Box Array [west, south, east, north] associated with the Feature * @param {string|number} [options.id] Identifier associated with the Feature * @returns {Feature} LineString Feature * @example * var linestring1 = turf.lineString([[-24, 63], [-23, 60], [-25, 65], [-20, 69]], {name: 'line 1'}); * var linestring2 = turf.lineString([[-14, 43], [-13, 40], [-15, 45], [-10, 49]], {name: 'line 2'}); * * //=linestring1 * //=linestring2 */ function lineString(coordinates, properties, options) { if (!coordinates) throw new Error('coordinates is required'); if (coordinates.length < 2) throw new Error('coordinates must be an array of two or more positions'); // Check if first point of LineString contains two numbers if (!isNumber(coordinates[0][1]) || !isNumber(coordinates[0][1])) throw new Error('coordinates must contain numbers'); return feature({ type: 'LineString', coordinates: coordinates }, properties, options); } /** * Creates a {@link LineString} {@link FeatureCollection} from an Array of LineString coordinates. * * @name lineStrings * @param {Array>} coordinates an array of LinearRings * @param {Object} [properties={}] an Object of key-value pairs to add as properties * @param {Object} [options={}] Optional Parameters * @param {Array} [options.bbox] Bounding Box Array [west, south, east, north] associated with the FeatureCollection * @param {string|number} [options.id] Identifier associated with the FeatureCollection * @returns {FeatureCollection} LineString FeatureCollection * @example * var linestrings = turf.lineStrings([ * [[-24, 63], [-23, 60], [-25, 65], [-20, 69]], * [[-14, 43], [-13, 40], [-15, 45], [-10, 49]] * ]); * * //=linestrings */ function lineStrings(coordinates, properties, options) { if (!coordinates) throw new Error('coordinates is required'); if (!Array.isArray(coordinates)) throw new Error('coordinates must be an Array'); return featureCollection(coordinates.map(function (coords) { return lineString(coords, properties); }), options); } /** * Takes one or more {@link Feature|Features} and creates a {@link FeatureCollection}. * * @name featureCollection * @param {Feature[]} features input features * @param {Object} [options={}] Optional Parameters * @param {Array} [options.bbox] Bounding Box Array [west, south, east, north] associated with the Feature * @param {string|number} [options.id] Identifier associated with the Feature * @returns {FeatureCollection} FeatureCollection of Features * @example * var locationA = turf.point([-75.343, 39.984], {name: 'Location A'}); * var locationB = turf.point([-75.833, 39.284], {name: 'Location B'}); * var locationC = turf.point([-75.534, 39.123], {name: 'Location C'}); * * var collection = turf.featureCollection([ * locationA, * locationB, * locationC * ]); * * //=collection */ function featureCollection(features, options) { // Optional Parameters options = options || {}; if (!isObject(options)) throw new Error('options is invalid'); var bbox = options.bbox; var id = options.id; // Validation if (!features) throw new Error('No features passed'); if (!Array.isArray(features)) throw new Error('features must be an Array'); if (bbox) validateBBox(bbox); if (id) validateId(id); // Main var fc = {type: 'FeatureCollection'}; if (id) fc.id = id; if (bbox) fc.bbox = bbox; fc.features = features; return fc; } /** * Creates a {@link Feature} based on a * coordinate array. Properties can be added optionally. * * @name multiLineString * @param {Array>>} coordinates an array of LineStrings * @param {Object} [properties={}] an Object of key-value pairs to add as properties * @param {Object} [options={}] Optional Parameters * @param {Array} [options.bbox] Bounding Box Array [west, south, east, north] associated with the Feature * @param {string|number} [options.id] Identifier associated with the Feature * @returns {Feature} a MultiLineString feature * @throws {Error} if no coordinates are passed * @example * var multiLine = turf.multiLineString([[[0,0],[10,10]]]); * * //=multiLine */ function multiLineString(coordinates, properties, options) { if (!coordinates) throw new Error('coordinates is required'); return feature({ type: 'MultiLineString', coordinates: coordinates }, properties, options); } /** * Creates a {@link Feature} based on a * coordinate array. Properties can be added optionally. * * @name multiPoint * @param {Array>} coordinates an array of Positions * @param {Object} [properties={}] an Object of key-value pairs to add as properties * @param {Object} [options={}] Optional Parameters * @param {Array} [options.bbox] Bounding Box Array [west, south, east, north] associated with the Feature * @param {string|number} [options.id] Identifier associated with the Feature * @returns {Feature} a MultiPoint feature * @throws {Error} if no coordinates are passed * @example * var multiPt = turf.multiPoint([[0,0],[10,10]]); * * //=multiPt */ function multiPoint(coordinates, properties, options) { if (!coordinates) throw new Error('coordinates is required'); return feature({ type: 'MultiPoint', coordinates: coordinates }, properties, options); } /** * Creates a {@link Feature} based on a * coordinate array. Properties can be added optionally. * * @name multiPolygon * @param {Array>>>} coordinates an array of Polygons * @param {Object} [properties={}] an Object of key-value pairs to add as properties * @param {Object} [options={}] Optional Parameters * @param {Array} [options.bbox] Bounding Box Array [west, south, east, north] associated with the Feature * @param {string|number} [options.id] Identifier associated with the Feature * @returns {Feature} a multipolygon feature * @throws {Error} if no coordinates are passed * @example * var multiPoly = turf.multiPolygon([[[[0,0],[0,10],[10,10],[10,0],[0,0]]]]); * * //=multiPoly * */ function multiPolygon(coordinates, properties, options) { if (!coordinates) throw new Error('coordinates is required'); return feature({ type: 'MultiPolygon', coordinates: coordinates }, properties, options); } /** * Creates a {@link Feature} based on a * coordinate array. Properties can be added optionally. * * @name geometryCollection * @param {Array} geometries an array of GeoJSON Geometries * @param {Object} [properties={}] an Object of key-value pairs to add as properties * @param {Object} [options={}] Optional Parameters * @param {Array} [options.bbox] Bounding Box Array [west, south, east, north] associated with the Feature * @param {string|number} [options.id] Identifier associated with the Feature * @returns {Feature} a GeoJSON GeometryCollection Feature * @example * var pt = { * "type": "Point", * "coordinates": [100, 0] * }; * var line = { * "type": "LineString", * "coordinates": [ [101, 0], [102, 1] ] * }; * var collection = turf.geometryCollection([pt, line]); * * //=collection */ function geometryCollection(geometries, properties, options) { if (!geometries) throw new Error('geometries is required'); if (!Array.isArray(geometries)) throw new Error('geometries must be an Array'); return feature({ type: 'GeometryCollection', geometries: geometries }, properties, options); } /** * Round number to precision * * @param {number} num Number * @param {number} [precision=0] Precision * @returns {number} rounded number * @example * turf.round(120.4321) * //=120 * * turf.round(120.4321, 2) * //=120.43 */ function round(num, precision) { if (num === undefined || num === null || isNaN(num)) throw new Error('num is required'); if (precision && !(precision >= 0)) throw new Error('precision must be a positive number'); var multiplier = Math.pow(10, precision || 0); return Math.round(num * multiplier) / multiplier; } /** * Convert a distance measurement (assuming a spherical Earth) from radians to a more friendly unit. * Valid units: miles, nauticalmiles, inches, yards, meters, metres, kilometers, centimeters, feet * * @name radiansToLength * @param {number} radians in radians across the sphere * @param {string} [units='kilometers'] can be degrees, radians, miles, or kilometers inches, yards, metres, meters, kilometres, kilometers. * @returns {number} distance */ function radiansToLength(radians, units) { if (radians === undefined || radians === null) throw new Error('radians is required'); if (units && typeof units !== 'string') throw new Error('units must be a string'); var factor = factors[units || 'kilometers']; if (!factor) throw new Error(units + ' units is invalid'); return radians * factor; } /** * Convert a distance measurement (assuming a spherical Earth) from a real-world unit into radians * Valid units: miles, nauticalmiles, inches, yards, meters, metres, kilometers, centimeters, feet * * @name lengthToRadians * @param {number} distance in real units * @param {string} [units='kilometers'] can be degrees, radians, miles, or kilometers inches, yards, metres, meters, kilometres, kilometers. * @returns {number} radians */ function lengthToRadians(distance, units) { if (distance === undefined || distance === null) throw new Error('distance is required'); if (units && typeof units !== 'string') throw new Error('units must be a string'); var factor = factors[units || 'kilometers']; if (!factor) throw new Error(units + ' units is invalid'); return distance / factor; } /** * Convert a distance measurement (assuming a spherical Earth) from a real-world unit into degrees * Valid units: miles, nauticalmiles, inches, yards, meters, metres, centimeters, kilometres, feet * * @name lengthToDegrees * @param {number} distance in real units * @param {string} [units='kilometers'] can be degrees, radians, miles, or kilometers inches, yards, metres, meters, kilometres, kilometers. * @returns {number} degrees */ function lengthToDegrees(distance, units) { return radiansToDegrees(lengthToRadians(distance, units)); } /** * Converts any bearing angle from the north line direction (positive clockwise) * and returns an angle between 0-360 degrees (positive clockwise), 0 being the north line * * @name bearingToAzimuth * @param {number} bearing angle, between -180 and +180 degrees * @returns {number} angle between 0 and 360 degrees */ function bearingToAzimuth(bearing) { if (bearing === null || bearing === undefined) throw new Error('bearing is required'); var angle = bearing % 360; if (angle < 0) angle += 360; return angle; } /** * Converts an angle in radians to degrees * * @name radiansToDegrees * @param {number} radians angle in radians * @returns {number} degrees between 0 and 360 degrees */ function radiansToDegrees(radians) { if (radians === null || radians === undefined) throw new Error('radians is required'); var degrees = radians % (2 * Math.PI); return degrees * 180 / Math.PI; } /** * Converts an angle in degrees to radians * * @name degreesToRadians * @param {number} degrees angle between 0 and 360 degrees * @returns {number} angle in radians */ function degreesToRadians(degrees) { if (degrees === null || degrees === undefined) throw new Error('degrees is required'); var radians = degrees % 360; return radians * Math.PI / 180; } /** * Converts a length to the requested unit. * Valid units: miles, nauticalmiles, inches, yards, meters, metres, kilometers, centimeters, feet * * @param {number} length to be converted * @param {string} originalUnit of the length * @param {string} [finalUnit='kilometers'] returned unit * @returns {number} the converted length */ function convertLength(length, originalUnit, finalUnit) { if (length === null || length === undefined) throw new Error('length is required'); if (!(length >= 0)) throw new Error('length must be a positive number'); return radiansToLength(lengthToRadians(length, originalUnit), finalUnit || 'kilometers'); } /** * Converts a area to the requested unit. * Valid units: kilometers, kilometres, meters, metres, centimetres, millimeters, acres, miles, yards, feet, inches * @param {number} area to be converted * @param {string} [originalUnit='meters'] of the distance * @param {string} [finalUnit='kilometers'] returned unit * @returns {number} the converted distance */ function convertArea(area, originalUnit, finalUnit) { if (area === null || area === undefined) throw new Error('area is required'); if (!(area >= 0)) throw new Error('area must be a positive number'); var startFactor = areaFactors[originalUnit || 'meters']; if (!startFactor) throw new Error('invalid original units'); var finalFactor = areaFactors[finalUnit || 'kilometers']; if (!finalFactor) throw new Error('invalid final units'); return (area / startFactor) * finalFactor; } /** * isNumber * * @param {*} num Number to validate * @returns {boolean} true/false * @example * turf.isNumber(123) * //=true * turf.isNumber('foo') * //=false */ function isNumber(num) { return !isNaN(num) && num !== null && !Array.isArray(num); } /** * isObject * * @param {*} input variable to validate * @returns {boolean} true/false * @example * turf.isObject({elevation: 10}) * //=true * turf.isObject('foo') * //=false */ function isObject(input) { return (!!input) && (input.constructor === Object); } /** * Validate BBox * * @private * @param {Array} bbox BBox to validate * @returns {void} * @throws Error if BBox is not valid * @example * validateBBox([-180, -40, 110, 50]) * //=OK * validateBBox([-180, -40]) * //=Error * validateBBox('Foo') * //=Error * validateBBox(5) * //=Error * validateBBox(null) * //=Error * validateBBox(undefined) * //=Error */ function validateBBox(bbox) { if (!bbox) throw new Error('bbox is required'); if (!Array.isArray(bbox)) throw new Error('bbox must be an Array'); if (bbox.length !== 4 && bbox.length !== 6) throw new Error('bbox must be an Array of 4 or 6 numbers'); bbox.forEach(function (num) { if (!isNumber(num)) throw new Error('bbox must only contain numbers'); }); } /** * Validate Id * * @private * @param {string|number} id Id to validate * @returns {void} * @throws Error if Id is not valid * @example * validateId([-180, -40, 110, 50]) * //=Error * validateId([-180, -40]) * //=Error * validateId('Foo') * //=OK * validateId(5) * //=OK * validateId(null) * //=Error * validateId(undefined) * //=Error */ function validateId(id) { if (!id) throw new Error('id is required'); if (['string', 'number'].indexOf(typeof id) === -1) throw new Error('id must be a number or a string'); } // Deprecated methods function radians2degrees() { throw new Error('method has been renamed to `radiansToDegrees`'); } function degrees2radians() { throw new Error('method has been renamed to `degreesToRadians`'); } function distanceToDegrees() { throw new Error('method has been renamed to `lengthToDegrees`'); } function distanceToRadians() { throw new Error('method has been renamed to `lengthToRadians`'); } function radiansToDistance() { throw new Error('method has been renamed to `radiansToLength`'); } function bearingToAngle() { throw new Error('method has been renamed to `bearingToAzimuth`'); } function convertDistance() { throw new Error('method has been renamed to `convertLength`'); } // CONCATENATED MODULE: ./node_modules/@turf/envelope/node_modules/@turf/meta/main.es.js /** * Callback for coordEach * * @callback coordEachCallback * @param {Array} currentCoord The current coordinate being processed. * @param {number} coordIndex The current index of the coordinate being processed. * @param {number} featureIndex The current index of the Feature being processed. * @param {number} multiFeatureIndex The current index of the Multi-Feature being processed. * @param {number} geometryIndex The current index of the Geometry being processed. */ /** * Iterate over coordinates in any GeoJSON object, similar to Array.forEach() * * @name coordEach * @param {FeatureCollection|Feature|Geometry} geojson any GeoJSON object * @param {Function} callback a method that takes (currentCoord, coordIndex, featureIndex, multiFeatureIndex) * @param {boolean} [excludeWrapCoord=false] whether or not to include the final coordinate of LinearRings that wraps the ring in its iteration. * @returns {void} * @example * var features = turf.featureCollection([ * turf.point([26, 37], {"foo": "bar"}), * turf.point([36, 53], {"hello": "world"}) * ]); * * turf.coordEach(features, function (currentCoord, coordIndex, featureIndex, multiFeatureIndex, geometryIndex) { * //=currentCoord * //=coordIndex * //=featureIndex * //=multiFeatureIndex * //=geometryIndex * }); */ function coordEach(geojson, callback, excludeWrapCoord) { // Handles null Geometry -- Skips this GeoJSON if (geojson === null) return; var j, k, l, geometry, stopG, coords, geometryMaybeCollection, wrapShrink = 0, coordIndex = 0, isGeometryCollection, type = geojson.type, isFeatureCollection = type === 'FeatureCollection', isFeature = type === 'Feature', stop = isFeatureCollection ? geojson.features.length : 1; // This logic may look a little weird. The reason why it is that way // is because it's trying to be fast. GeoJSON supports multiple kinds // of objects at its root: FeatureCollection, Features, Geometries. // This function has the responsibility of handling all of them, and that // means that some of the `for` loops you see below actually just don't apply // to certain inputs. For instance, if you give this just a // Point geometry, then both loops are short-circuited and all we do // is gradually rename the input until it's called 'geometry'. // // This also aims to allocate as few resources as possible: just a // few numbers and booleans, rather than any temporary arrays as would // be required with the normalization approach. for (var featureIndex = 0; featureIndex < stop; featureIndex++) { geometryMaybeCollection = (isFeatureCollection ? geojson.features[featureIndex].geometry : (isFeature ? geojson.geometry : geojson)); isGeometryCollection = (geometryMaybeCollection) ? geometryMaybeCollection.type === 'GeometryCollection' : false; stopG = isGeometryCollection ? geometryMaybeCollection.geometries.length : 1; for (var geomIndex = 0; geomIndex < stopG; geomIndex++) { var multiFeatureIndex = 0; var geometryIndex = 0; geometry = isGeometryCollection ? geometryMaybeCollection.geometries[geomIndex] : geometryMaybeCollection; // Handles null Geometry -- Skips this geometry if (geometry === null) continue; coords = geometry.coordinates; var geomType = geometry.type; wrapShrink = (excludeWrapCoord && (geomType === 'Polygon' || geomType === 'MultiPolygon')) ? 1 : 0; switch (geomType) { case null: break; case 'Point': if (callback(coords, coordIndex, featureIndex, multiFeatureIndex, geometryIndex) === false) return false; coordIndex++; multiFeatureIndex++; break; case 'LineString': case 'MultiPoint': for (j = 0; j < coords.length; j++) { if (callback(coords[j], coordIndex, featureIndex, multiFeatureIndex, geometryIndex) === false) return false; coordIndex++; if (geomType === 'MultiPoint') multiFeatureIndex++; } if (geomType === 'LineString') multiFeatureIndex++; break; case 'Polygon': case 'MultiLineString': for (j = 0; j < coords.length; j++) { for (k = 0; k < coords[j].length - wrapShrink; k++) { if (callback(coords[j][k], coordIndex, featureIndex, multiFeatureIndex, geometryIndex) === false) return false; coordIndex++; } if (geomType === 'MultiLineString') multiFeatureIndex++; if (geomType === 'Polygon') geometryIndex++; } if (geomType === 'Polygon') multiFeatureIndex++; break; case 'MultiPolygon': for (j = 0; j < coords.length; j++) { if (geomType === 'MultiPolygon') geometryIndex = 0; for (k = 0; k < coords[j].length; k++) { for (l = 0; l < coords[j][k].length - wrapShrink; l++) { if (callback(coords[j][k][l], coordIndex, featureIndex, multiFeatureIndex, geometryIndex) === false) return false; coordIndex++; } geometryIndex++; } multiFeatureIndex++; } break; case 'GeometryCollection': for (j = 0; j < geometry.geometries.length; j++) if (coordEach(geometry.geometries[j], callback, excludeWrapCoord) === false) return false; break; default: throw new Error('Unknown Geometry Type'); } } } } /** * Callback for coordReduce * * The first time the callback function is called, the values provided as arguments depend * on whether the reduce method has an initialValue argument. * * If an initialValue is provided to the reduce method: * - The previousValue argument is initialValue. * - The currentValue argument is the value of the first element present in the array. * * If an initialValue is not provided: * - The previousValue argument is the value of the first element present in the array. * - The currentValue argument is the value of the second element present in the array. * * @callback coordReduceCallback * @param {*} previousValue The accumulated value previously returned in the last invocation * of the callback, or initialValue, if supplied. * @param {Array} currentCoord The current coordinate being processed. * @param {number} coordIndex The current index of the coordinate being processed. * Starts at index 0, if an initialValue is provided, and at index 1 otherwise. * @param {number} featureIndex The current index of the Feature being processed. * @param {number} multiFeatureIndex The current index of the Multi-Feature being processed. * @param {number} geometryIndex The current index of the Geometry being processed. */ /** * Reduce coordinates in any GeoJSON object, similar to Array.reduce() * * @name coordReduce * @param {FeatureCollection|Geometry|Feature} geojson any GeoJSON object * @param {Function} callback a method that takes (previousValue, currentCoord, coordIndex) * @param {*} [initialValue] Value to use as the first argument to the first call of the callback. * @param {boolean} [excludeWrapCoord=false] whether or not to include the final coordinate of LinearRings that wraps the ring in its iteration. * @returns {*} The value that results from the reduction. * @example * var features = turf.featureCollection([ * turf.point([26, 37], {"foo": "bar"}), * turf.point([36, 53], {"hello": "world"}) * ]); * * turf.coordReduce(features, function (previousValue, currentCoord, coordIndex, featureIndex, multiFeatureIndex, geometryIndex) { * //=previousValue * //=currentCoord * //=coordIndex * //=featureIndex * //=multiFeatureIndex * //=geometryIndex * return currentCoord; * }); */ function coordReduce(geojson, callback, initialValue, excludeWrapCoord) { var previousValue = initialValue; coordEach(geojson, function (currentCoord, coordIndex, featureIndex, multiFeatureIndex, geometryIndex) { if (coordIndex === 0 && initialValue === undefined) previousValue = currentCoord; else previousValue = callback(previousValue, currentCoord, coordIndex, featureIndex, multiFeatureIndex, geometryIndex); }, excludeWrapCoord); return previousValue; } /** * Callback for propEach * * @callback propEachCallback * @param {Object} currentProperties The current Properties being processed. * @param {number} featureIndex The current index of the Feature being processed. */ /** * Iterate over properties in any GeoJSON object, similar to Array.forEach() * * @name propEach * @param {FeatureCollection|Feature} geojson any GeoJSON object * @param {Function} callback a method that takes (currentProperties, featureIndex) * @returns {void} * @example * var features = turf.featureCollection([ * turf.point([26, 37], {foo: 'bar'}), * turf.point([36, 53], {hello: 'world'}) * ]); * * turf.propEach(features, function (currentProperties, featureIndex) { * //=currentProperties * //=featureIndex * }); */ function propEach(geojson, callback) { var i; switch (geojson.type) { case 'FeatureCollection': for (i = 0; i < geojson.features.length; i++) { if (callback(geojson.features[i].properties, i) === false) break; } break; case 'Feature': callback(geojson.properties, 0); break; } } /** * Callback for propReduce * * The first time the callback function is called, the values provided as arguments depend * on whether the reduce method has an initialValue argument. * * If an initialValue is provided to the reduce method: * - The previousValue argument is initialValue. * - The currentValue argument is the value of the first element present in the array. * * If an initialValue is not provided: * - The previousValue argument is the value of the first element present in the array. * - The currentValue argument is the value of the second element present in the array. * * @callback propReduceCallback * @param {*} previousValue The accumulated value previously returned in the last invocation * of the callback, or initialValue, if supplied. * @param {*} currentProperties The current Properties being processed. * @param {number} featureIndex The current index of the Feature being processed. */ /** * Reduce properties in any GeoJSON object into a single value, * similar to how Array.reduce works. However, in this case we lazily run * the reduction, so an array of all properties is unnecessary. * * @name propReduce * @param {FeatureCollection|Feature} geojson any GeoJSON object * @param {Function} callback a method that takes (previousValue, currentProperties, featureIndex) * @param {*} [initialValue] Value to use as the first argument to the first call of the callback. * @returns {*} The value that results from the reduction. * @example * var features = turf.featureCollection([ * turf.point([26, 37], {foo: 'bar'}), * turf.point([36, 53], {hello: 'world'}) * ]); * * turf.propReduce(features, function (previousValue, currentProperties, featureIndex) { * //=previousValue * //=currentProperties * //=featureIndex * return currentProperties * }); */ function propReduce(geojson, callback, initialValue) { var previousValue = initialValue; propEach(geojson, function (currentProperties, featureIndex) { if (featureIndex === 0 && initialValue === undefined) previousValue = currentProperties; else previousValue = callback(previousValue, currentProperties, featureIndex); }); return previousValue; } /** * Callback for featureEach * * @callback featureEachCallback * @param {Feature} currentFeature The current Feature being processed. * @param {number} featureIndex The current index of the Feature being processed. */ /** * Iterate over features in any GeoJSON object, similar to * Array.forEach. * * @name featureEach * @param {FeatureCollection|Feature|Geometry} geojson any GeoJSON object * @param {Function} callback a method that takes (currentFeature, featureIndex) * @returns {void} * @example * var features = turf.featureCollection([ * turf.point([26, 37], {foo: 'bar'}), * turf.point([36, 53], {hello: 'world'}) * ]); * * turf.featureEach(features, function (currentFeature, featureIndex) { * //=currentFeature * //=featureIndex * }); */ function featureEach(geojson, callback) { if (geojson.type === 'Feature') { callback(geojson, 0); } else if (geojson.type === 'FeatureCollection') { for (var i = 0; i < geojson.features.length; i++) { if (callback(geojson.features[i], i) === false) break; } } } /** * Callback for featureReduce * * The first time the callback function is called, the values provided as arguments depend * on whether the reduce method has an initialValue argument. * * If an initialValue is provided to the reduce method: * - The previousValue argument is initialValue. * - The currentValue argument is the value of the first element present in the array. * * If an initialValue is not provided: * - The previousValue argument is the value of the first element present in the array. * - The currentValue argument is the value of the second element present in the array. * * @callback featureReduceCallback * @param {*} previousValue The accumulated value previously returned in the last invocation * of the callback, or initialValue, if supplied. * @param {Feature} currentFeature The current Feature being processed. * @param {number} featureIndex The current index of the Feature being processed. */ /** * Reduce features in any GeoJSON object, similar to Array.reduce(). * * @name featureReduce * @param {FeatureCollection|Feature|Geometry} geojson any GeoJSON object * @param {Function} callback a method that takes (previousValue, currentFeature, featureIndex) * @param {*} [initialValue] Value to use as the first argument to the first call of the callback. * @returns {*} The value that results from the reduction. * @example * var features = turf.featureCollection([ * turf.point([26, 37], {"foo": "bar"}), * turf.point([36, 53], {"hello": "world"}) * ]); * * turf.featureReduce(features, function (previousValue, currentFeature, featureIndex) { * //=previousValue * //=currentFeature * //=featureIndex * return currentFeature * }); */ function featureReduce(geojson, callback, initialValue) { var previousValue = initialValue; featureEach(geojson, function (currentFeature, featureIndex) { if (featureIndex === 0 && initialValue === undefined) previousValue = currentFeature; else previousValue = callback(previousValue, currentFeature, featureIndex); }); return previousValue; } /** * Get all coordinates from any GeoJSON object. * * @name coordAll * @param {FeatureCollection|Feature|Geometry} geojson any GeoJSON object * @returns {Array>} coordinate position array * @example * var features = turf.featureCollection([ * turf.point([26, 37], {foo: 'bar'}), * turf.point([36, 53], {hello: 'world'}) * ]); * * var coords = turf.coordAll(features); * //= [[26, 37], [36, 53]] */ function coordAll(geojson) { var coords = []; coordEach(geojson, function (coord) { coords.push(coord); }); return coords; } /** * Callback for geomEach * * @callback geomEachCallback * @param {Geometry} currentGeometry The current Geometry being processed. * @param {number} featureIndex The current index of the Feature being processed. * @param {Object} featureProperties The current Feature Properties being processed. * @param {Array} featureBBox The current Feature BBox being processed. * @param {number|string} featureId The current Feature Id being processed. */ /** * Iterate over each geometry in any GeoJSON object, similar to Array.forEach() * * @name geomEach * @param {FeatureCollection|Feature|Geometry} geojson any GeoJSON object * @param {Function} callback a method that takes (currentGeometry, featureIndex, featureProperties, featureBBox, featureId) * @returns {void} * @example * var features = turf.featureCollection([ * turf.point([26, 37], {foo: 'bar'}), * turf.point([36, 53], {hello: 'world'}) * ]); * * turf.geomEach(features, function (currentGeometry, featureIndex, featureProperties, featureBBox, featureId) { * //=currentGeometry * //=featureIndex * //=featureProperties * //=featureBBox * //=featureId * }); */ function geomEach(geojson, callback) { var i, j, g, geometry, stopG, geometryMaybeCollection, isGeometryCollection, featureProperties, featureBBox, featureId, featureIndex = 0, isFeatureCollection = geojson.type === 'FeatureCollection', isFeature = geojson.type === 'Feature', stop = isFeatureCollection ? geojson.features.length : 1; // This logic may look a little weird. The reason why it is that way // is because it's trying to be fast. GeoJSON supports multiple kinds // of objects at its root: FeatureCollection, Features, Geometries. // This function has the responsibility of handling all of them, and that // means that some of the `for` loops you see below actually just don't apply // to certain inputs. For instance, if you give this just a // Point geometry, then both loops are short-circuited and all we do // is gradually rename the input until it's called 'geometry'. // // This also aims to allocate as few resources as possible: just a // few numbers and booleans, rather than any temporary arrays as would // be required with the normalization approach. for (i = 0; i < stop; i++) { geometryMaybeCollection = (isFeatureCollection ? geojson.features[i].geometry : (isFeature ? geojson.geometry : geojson)); featureProperties = (isFeatureCollection ? geojson.features[i].properties : (isFeature ? geojson.properties : {})); featureBBox = (isFeatureCollection ? geojson.features[i].bbox : (isFeature ? geojson.bbox : undefined)); featureId = (isFeatureCollection ? geojson.features[i].id : (isFeature ? geojson.id : undefined)); isGeometryCollection = (geometryMaybeCollection) ? geometryMaybeCollection.type === 'GeometryCollection' : false; stopG = isGeometryCollection ? geometryMaybeCollection.geometries.length : 1; for (g = 0; g < stopG; g++) { geometry = isGeometryCollection ? geometryMaybeCollection.geometries[g] : geometryMaybeCollection; // Handle null Geometry if (geometry === null) { if (callback(null, featureIndex, featureProperties, featureBBox, featureId) === false) return false; continue; } switch (geometry.type) { case 'Point': case 'LineString': case 'MultiPoint': case 'Polygon': case 'MultiLineString': case 'MultiPolygon': { if (callback(geometry, featureIndex, featureProperties, featureBBox, featureId) === false) return false; break; } case 'GeometryCollection': { for (j = 0; j < geometry.geometries.length; j++) { if (callback(geometry.geometries[j], featureIndex, featureProperties, featureBBox, featureId) === false) return false; } break; } default: throw new Error('Unknown Geometry Type'); } } // Only increase `featureIndex` per each feature featureIndex++; } } /** * Callback for geomReduce * * The first time the callback function is called, the values provided as arguments depend * on whether the reduce method has an initialValue argument. * * If an initialValue is provided to the reduce method: * - The previousValue argument is initialValue. * - The currentValue argument is the value of the first element present in the array. * * If an initialValue is not provided: * - The previousValue argument is the value of the first element present in the array. * - The currentValue argument is the value of the second element present in the array. * * @callback geomReduceCallback * @param {*} previousValue The accumulated value previously returned in the last invocation * of the callback, or initialValue, if supplied. * @param {Geometry} currentGeometry The current Geometry being processed. * @param {number} featureIndex The current index of the Feature being processed. * @param {Object} featureProperties The current Feature Properties being processed. * @param {Array} featureBBox The current Feature BBox being processed. * @param {number|string} featureId The current Feature Id being processed. */ /** * Reduce geometry in any GeoJSON object, similar to Array.reduce(). * * @name geomReduce * @param {FeatureCollection|Feature|Geometry} geojson any GeoJSON object * @param {Function} callback a method that takes (previousValue, currentGeometry, featureIndex, featureProperties, featureBBox, featureId) * @param {*} [initialValue] Value to use as the first argument to the first call of the callback. * @returns {*} The value that results from the reduction. * @example * var features = turf.featureCollection([ * turf.point([26, 37], {foo: 'bar'}), * turf.point([36, 53], {hello: 'world'}) * ]); * * turf.geomReduce(features, function (previousValue, currentGeometry, featureIndex, featureProperties, featureBBox, featureId) { * //=previousValue * //=currentGeometry * //=featureIndex * //=featureProperties * //=featureBBox * //=featureId * return currentGeometry * }); */ function geomReduce(geojson, callback, initialValue) { var previousValue = initialValue; geomEach(geojson, function (currentGeometry, featureIndex, featureProperties, featureBBox, featureId) { if (featureIndex === 0 && initialValue === undefined) previousValue = currentGeometry; else previousValue = callback(previousValue, currentGeometry, featureIndex, featureProperties, featureBBox, featureId); }); return previousValue; } /** * Callback for flattenEach * * @callback flattenEachCallback * @param {Feature} currentFeature The current flattened feature being processed. * @param {number} featureIndex The current index of the Feature being processed. * @param {number} multiFeatureIndex The current index of the Multi-Feature being processed. */ /** * Iterate over flattened features in any GeoJSON object, similar to * Array.forEach. * * @name flattenEach * @param {FeatureCollection|Feature|Geometry} geojson any GeoJSON object * @param {Function} callback a method that takes (currentFeature, featureIndex, multiFeatureIndex) * @example * var features = turf.featureCollection([ * turf.point([26, 37], {foo: 'bar'}), * turf.multiPoint([[40, 30], [36, 53]], {hello: 'world'}) * ]); * * turf.flattenEach(features, function (currentFeature, featureIndex, multiFeatureIndex) { * //=currentFeature * //=featureIndex * //=multiFeatureIndex * }); */ function flattenEach(geojson, callback) { geomEach(geojson, function (geometry, featureIndex, properties, bbox, id) { // Callback for single geometry var type = (geometry === null) ? null : geometry.type; switch (type) { case null: case 'Point': case 'LineString': case 'Polygon': if (callback(feature(geometry, properties, {bbox: bbox, id: id}), featureIndex, 0) === false) return false; return; } var geomType; // Callback for multi-geometry switch (type) { case 'MultiPoint': geomType = 'Point'; break; case 'MultiLineString': geomType = 'LineString'; break; case 'MultiPolygon': geomType = 'Polygon'; break; } for (var multiFeatureIndex = 0; multiFeatureIndex < geometry.coordinates.length; multiFeatureIndex++) { var coordinate = geometry.coordinates[multiFeatureIndex]; var geom = { type: geomType, coordinates: coordinate }; if (callback(feature(geom, properties), featureIndex, multiFeatureIndex) === false) return false; } }); } /** * Callback for flattenReduce * * The first time the callback function is called, the values provided as arguments depend * on whether the reduce method has an initialValue argument. * * If an initialValue is provided to the reduce method: * - The previousValue argument is initialValue. * - The currentValue argument is the value of the first element present in the array. * * If an initialValue is not provided: * - The previousValue argument is the value of the first element present in the array. * - The currentValue argument is the value of the second element present in the array. * * @callback flattenReduceCallback * @param {*} previousValue The accumulated value previously returned in the last invocation * of the callback, or initialValue, if supplied. * @param {Feature} currentFeature The current Feature being processed. * @param {number} featureIndex The current index of the Feature being processed. * @param {number} multiFeatureIndex The current index of the Multi-Feature being processed. */ /** * Reduce flattened features in any GeoJSON object, similar to Array.reduce(). * * @name flattenReduce * @param {FeatureCollection|Feature|Geometry} geojson any GeoJSON object * @param {Function} callback a method that takes (previousValue, currentFeature, featureIndex, multiFeatureIndex) * @param {*} [initialValue] Value to use as the first argument to the first call of the callback. * @returns {*} The value that results from the reduction. * @example * var features = turf.featureCollection([ * turf.point([26, 37], {foo: 'bar'}), * turf.multiPoint([[40, 30], [36, 53]], {hello: 'world'}) * ]); * * turf.flattenReduce(features, function (previousValue, currentFeature, featureIndex, multiFeatureIndex) { * //=previousValue * //=currentFeature * //=featureIndex * //=multiFeatureIndex * return currentFeature * }); */ function flattenReduce(geojson, callback, initialValue) { var previousValue = initialValue; flattenEach(geojson, function (currentFeature, featureIndex, multiFeatureIndex) { if (featureIndex === 0 && multiFeatureIndex === 0 && initialValue === undefined) previousValue = currentFeature; else previousValue = callback(previousValue, currentFeature, featureIndex, multiFeatureIndex); }); return previousValue; } /** * Callback for segmentEach * * @callback segmentEachCallback * @param {Feature} currentSegment The current Segment being processed. * @param {number} featureIndex The current index of the Feature being processed. * @param {number} multiFeatureIndex The current index of the Multi-Feature being processed. * @param {number} geometryIndex The current index of the Geometry being processed. * @param {number} segmentIndex The current index of the Segment being processed. * @returns {void} */ /** * Iterate over 2-vertex line segment in any GeoJSON object, similar to Array.forEach() * (Multi)Point geometries do not contain segments therefore they are ignored during this operation. * * @param {FeatureCollection|Feature|Geometry} geojson any GeoJSON * @param {Function} callback a method that takes (currentSegment, featureIndex, multiFeatureIndex, geometryIndex, segmentIndex) * @returns {void} * @example * var polygon = turf.polygon([[[-50, 5], [-40, -10], [-50, -10], [-40, 5], [-50, 5]]]); * * // Iterate over GeoJSON by 2-vertex segments * turf.segmentEach(polygon, function (currentSegment, featureIndex, multiFeatureIndex, geometryIndex, segmentIndex) { * //=currentSegment * //=featureIndex * //=multiFeatureIndex * //=geometryIndex * //=segmentIndex * }); * * // Calculate the total number of segments * var total = 0; * turf.segmentEach(polygon, function () { * total++; * }); */ function segmentEach(geojson, callback) { flattenEach(geojson, function (feature$$1, featureIndex, multiFeatureIndex) { var segmentIndex = 0; // Exclude null Geometries if (!feature$$1.geometry) return; // (Multi)Point geometries do not contain segments therefore they are ignored during this operation. var type = feature$$1.geometry.type; if (type === 'Point' || type === 'MultiPoint') return; // Generate 2-vertex line segments var previousCoords; if (coordEach(feature$$1, function (currentCoord, coordIndex, featureIndexCoord, mutliPartIndexCoord, geometryIndex) { // Simulating a meta.coordReduce() since `reduce` operations cannot be stopped by returning `false` if (previousCoords === undefined) { previousCoords = currentCoord; return; } var currentSegment = lineString([previousCoords, currentCoord], feature$$1.properties); if (callback(currentSegment, featureIndex, multiFeatureIndex, geometryIndex, segmentIndex) === false) return false; segmentIndex++; previousCoords = currentCoord; }) === false) return false; }); } /** * Callback for segmentReduce * * The first time the callback function is called, the values provided as arguments depend * on whether the reduce method has an initialValue argument. * * If an initialValue is provided to the reduce method: * - The previousValue argument is initialValue. * - The currentValue argument is the value of the first element present in the array. * * If an initialValue is not provided: * - The previousValue argument is the value of the first element present in the array. * - The currentValue argument is the value of the second element present in the array. * * @callback segmentReduceCallback * @param {*} previousValue The accumulated value previously returned in the last invocation * of the callback, or initialValue, if supplied. * @param {Feature} currentSegment The current Segment being processed. * @param {number} featureIndex The current index of the Feature being processed. * @param {number} multiFeatureIndex The current index of the Multi-Feature being processed. * @param {number} geometryIndex The current index of the Geometry being processed. * @param {number} segmentIndex The current index of the Segment being processed. */ /** * Reduce 2-vertex line segment in any GeoJSON object, similar to Array.reduce() * (Multi)Point geometries do not contain segments therefore they are ignored during this operation. * * @param {FeatureCollection|Feature|Geometry} geojson any GeoJSON * @param {Function} callback a method that takes (previousValue, currentSegment, currentIndex) * @param {*} [initialValue] Value to use as the first argument to the first call of the callback. * @returns {void} * @example * var polygon = turf.polygon([[[-50, 5], [-40, -10], [-50, -10], [-40, 5], [-50, 5]]]); * * // Iterate over GeoJSON by 2-vertex segments * turf.segmentReduce(polygon, function (previousSegment, currentSegment, featureIndex, multiFeatureIndex, geometryIndex, segmentIndex) { * //= previousSegment * //= currentSegment * //= featureIndex * //= multiFeatureIndex * //= geometryIndex * //= segmentInex * return currentSegment * }); * * // Calculate the total number of segments * var initialValue = 0 * var total = turf.segmentReduce(polygon, function (previousValue) { * previousValue++; * return previousValue; * }, initialValue); */ function segmentReduce(geojson, callback, initialValue) { var previousValue = initialValue; var started = false; segmentEach(geojson, function (currentSegment, featureIndex, multiFeatureIndex, geometryIndex, segmentIndex) { if (started === false && initialValue === undefined) previousValue = currentSegment; else previousValue = callback(previousValue, currentSegment, featureIndex, multiFeatureIndex, geometryIndex, segmentIndex); started = true; }); return previousValue; } /** * Callback for lineEach * * @callback lineEachCallback * @param {Feature} currentLine The current LineString|LinearRing being processed * @param {number} featureIndex The current index of the Feature being processed * @param {number} multiFeatureIndex The current index of the Multi-Feature being processed * @param {number} geometryIndex The current index of the Geometry being processed */ /** * Iterate over line or ring coordinates in LineString, Polygon, MultiLineString, MultiPolygon Features or Geometries, * similar to Array.forEach. * * @name lineEach * @param {Geometry|Feature} geojson object * @param {Function} callback a method that takes (currentLine, featureIndex, multiFeatureIndex, geometryIndex) * @example * var multiLine = turf.multiLineString([ * [[26, 37], [35, 45]], * [[36, 53], [38, 50], [41, 55]] * ]); * * turf.lineEach(multiLine, function (currentLine, featureIndex, multiFeatureIndex, geometryIndex) { * //=currentLine * //=featureIndex * //=multiFeatureIndex * //=geometryIndex * }); */ function lineEach(geojson, callback) { // validation if (!geojson) throw new Error('geojson is required'); flattenEach(geojson, function (feature$$1, featureIndex, multiFeatureIndex) { if (feature$$1.geometry === null) return; var type = feature$$1.geometry.type; var coords = feature$$1.geometry.coordinates; switch (type) { case 'LineString': if (callback(feature$$1, featureIndex, multiFeatureIndex, 0, 0) === false) return false; break; case 'Polygon': for (var geometryIndex = 0; geometryIndex < coords.length; geometryIndex++) { if (callback(lineString(coords[geometryIndex], feature$$1.properties), featureIndex, multiFeatureIndex, geometryIndex) === false) return false; } break; } }); } /** * Callback for lineReduce * * The first time the callback function is called, the values provided as arguments depend * on whether the reduce method has an initialValue argument. * * If an initialValue is provided to the reduce method: * - The previousValue argument is initialValue. * - The currentValue argument is the value of the first element present in the array. * * If an initialValue is not provided: * - The previousValue argument is the value of the first element present in the array. * - The currentValue argument is the value of the second element present in the array. * * @callback lineReduceCallback * @param {*} previousValue The accumulated value previously returned in the last invocation * of the callback, or initialValue, if supplied. * @param {Feature} currentLine The current LineString|LinearRing being processed. * @param {number} featureIndex The current index of the Feature being processed * @param {number} multiFeatureIndex The current index of the Multi-Feature being processed * @param {number} geometryIndex The current index of the Geometry being processed */ /** * Reduce features in any GeoJSON object, similar to Array.reduce(). * * @name lineReduce * @param {Geometry|Feature} geojson object * @param {Function} callback a method that takes (previousValue, currentLine, featureIndex, multiFeatureIndex, geometryIndex) * @param {*} [initialValue] Value to use as the first argument to the first call of the callback. * @returns {*} The value that results from the reduction. * @example * var multiPoly = turf.multiPolygon([ * turf.polygon([[[12,48],[2,41],[24,38],[12,48]], [[9,44],[13,41],[13,45],[9,44]]]), * turf.polygon([[[5, 5], [0, 0], [2, 2], [4, 4], [5, 5]]]) * ]); * * turf.lineReduce(multiPoly, function (previousValue, currentLine, featureIndex, multiFeatureIndex, geometryIndex) { * //=previousValue * //=currentLine * //=featureIndex * //=multiFeatureIndex * //=geometryIndex * return currentLine * }); */ function lineReduce(geojson, callback, initialValue) { var previousValue = initialValue; lineEach(geojson, function (currentLine, featureIndex, multiFeatureIndex, geometryIndex) { if (featureIndex === 0 && initialValue === undefined) previousValue = currentLine; else previousValue = callback(previousValue, currentLine, featureIndex, multiFeatureIndex, geometryIndex); }); return previousValue; } /** * Finds a particular 2-vertex LineString Segment from a GeoJSON using `@turf/meta` indexes. * * Negative indexes are permitted. * Point & MultiPoint will always return null. * * @param {FeatureCollection|Feature|Geometry} geojson Any GeoJSON Feature or Geometry * @param {Object} [options={}] Optional parameters * @param {number} [options.featureIndex=0] Feature Index * @param {number} [options.multiFeatureIndex=0] Multi-Feature Index * @param {number} [options.geometryIndex=0] Geometry Index * @param {number} [options.segmentIndex=0] Segment Index * @param {Object} [options.properties={}] Translate Properties to output LineString * @param {BBox} [options.bbox={}] Translate BBox to output LineString * @param {number|string} [options.id={}] Translate Id to output LineString * @returns {Feature} 2-vertex GeoJSON Feature LineString * @example * var multiLine = turf.multiLineString([ * [[10, 10], [50, 30], [30, 40]], * [[-10, -10], [-50, -30], [-30, -40]] * ]); * * // First Segment (defaults are 0) * turf.findSegment(multiLine); * // => Feature> * * // First Segment of 2nd Multi Feature * turf.findSegment(multiLine, {multiFeatureIndex: 1}); * // => Feature> * * // Last Segment of Last Multi Feature * turf.findSegment(multiLine, {multiFeatureIndex: -1, segmentIndex: -1}); * // => Feature> */ function findSegment(geojson, options) { // Optional Parameters options = options || {}; if (!isObject(options)) throw new Error('options is invalid'); var featureIndex = options.featureIndex || 0; var multiFeatureIndex = options.multiFeatureIndex || 0; var geometryIndex = options.geometryIndex || 0; var segmentIndex = options.segmentIndex || 0; // Find FeatureIndex var properties = options.properties; var geometry; switch (geojson.type) { case 'FeatureCollection': if (featureIndex < 0) featureIndex = geojson.features.length + featureIndex; properties = properties || geojson.features[featureIndex].properties; geometry = geojson.features[featureIndex].geometry; break; case 'Feature': properties = properties || geojson.properties; geometry = geojson.geometry; break; case 'Point': case 'MultiPoint': return null; case 'LineString': case 'Polygon': case 'MultiLineString': case 'MultiPolygon': geometry = geojson; break; default: throw new Error('geojson is invalid'); } // Find SegmentIndex if (geometry === null) return null; var coords = geometry.coordinates; switch (geometry.type) { case 'Point': case 'MultiPoint': return null; case 'LineString': if (segmentIndex < 0) segmentIndex = coords.length + segmentIndex - 1; return lineString([coords[segmentIndex], coords[segmentIndex + 1]], properties, options); case 'Polygon': if (geometryIndex < 0) geometryIndex = coords.length + geometryIndex; if (segmentIndex < 0) segmentIndex = coords[geometryIndex].length + segmentIndex - 1; return lineString([coords[geometryIndex][segmentIndex], coords[geometryIndex][segmentIndex + 1]], properties, options); case 'MultiLineString': if (multiFeatureIndex < 0) multiFeatureIndex = coords.length + multiFeatureIndex; if (segmentIndex < 0) segmentIndex = coords[multiFeatureIndex].length + segmentIndex - 1; return lineString([coords[multiFeatureIndex][segmentIndex], coords[multiFeatureIndex][segmentIndex + 1]], properties, options); case 'MultiPolygon': if (multiFeatureIndex < 0) multiFeatureIndex = coords.length + multiFeatureIndex; if (geometryIndex < 0) geometryIndex = coords[multiFeatureIndex].length + geometryIndex; if (segmentIndex < 0) segmentIndex = coords[multiFeatureIndex][geometryIndex].length - segmentIndex - 1; return lineString([coords[multiFeatureIndex][geometryIndex][segmentIndex], coords[multiFeatureIndex][geometryIndex][segmentIndex + 1]], properties, options); } throw new Error('geojson is invalid'); } /** * Finds a particular Point from a GeoJSON using `@turf/meta` indexes. * * Negative indexes are permitted. * * @param {FeatureCollection|Feature|Geometry} geojson Any GeoJSON Feature or Geometry * @param {Object} [options={}] Optional parameters * @param {number} [options.featureIndex=0] Feature Index * @param {number} [options.multiFeatureIndex=0] Multi-Feature Index * @param {number} [options.geometryIndex=0] Geometry Index * @param {number} [options.coordIndex=0] Coord Index * @param {Object} [options.properties={}] Translate Properties to output Point * @param {BBox} [options.bbox={}] Translate BBox to output Point * @param {number|string} [options.id={}] Translate Id to output Point * @returns {Feature} 2-vertex GeoJSON Feature Point * @example * var multiLine = turf.multiLineString([ * [[10, 10], [50, 30], [30, 40]], * [[-10, -10], [-50, -30], [-30, -40]] * ]); * * // First Segment (defaults are 0) * turf.findPoint(multiLine); * // => Feature> * * // First Segment of the 2nd Multi-Feature * turf.findPoint(multiLine, {multiFeatureIndex: 1}); * // => Feature> * * // Last Segment of last Multi-Feature * turf.findPoint(multiLine, {multiFeatureIndex: -1, coordIndex: -1}); * // => Feature> */ function findPoint(geojson, options) { // Optional Parameters options = options || {}; if (!isObject(options)) throw new Error('options is invalid'); var featureIndex = options.featureIndex || 0; var multiFeatureIndex = options.multiFeatureIndex || 0; var geometryIndex = options.geometryIndex || 0; var coordIndex = options.coordIndex || 0; // Find FeatureIndex var properties = options.properties; var geometry; switch (geojson.type) { case 'FeatureCollection': if (featureIndex < 0) featureIndex = geojson.features.length + featureIndex; properties = properties || geojson.features[featureIndex].properties; geometry = geojson.features[featureIndex].geometry; break; case 'Feature': properties = properties || geojson.properties; geometry = geojson.geometry; break; case 'Point': case 'MultiPoint': return null; case 'LineString': case 'Polygon': case 'MultiLineString': case 'MultiPolygon': geometry = geojson; break; default: throw new Error('geojson is invalid'); } // Find Coord Index if (geometry === null) return null; var coords = geometry.coordinates; switch (geometry.type) { case 'Point': return point(coords, properties, options); case 'MultiPoint': if (multiFeatureIndex < 0) multiFeatureIndex = coords.length + multiFeatureIndex; return point(coords[multiFeatureIndex], properties, options); case 'LineString': if (coordIndex < 0) coordIndex = coords.length + coordIndex; return point(coords[coordIndex], properties, options); case 'Polygon': if (geometryIndex < 0) geometryIndex = coords.length + geometryIndex; if (coordIndex < 0) coordIndex = coords[geometryIndex].length + coordIndex; return point(coords[geometryIndex][coordIndex], properties, options); case 'MultiLineString': if (multiFeatureIndex < 0) multiFeatureIndex = coords.length + multiFeatureIndex; if (coordIndex < 0) coordIndex = coords[multiFeatureIndex].length + coordIndex; return point(coords[multiFeatureIndex][coordIndex], properties, options); case 'MultiPolygon': if (multiFeatureIndex < 0) multiFeatureIndex = coords.length + multiFeatureIndex; if (geometryIndex < 0) geometryIndex = coords[multiFeatureIndex].length + geometryIndex; if (coordIndex < 0) coordIndex = coords[multiFeatureIndex][geometryIndex].length - coordIndex; return point(coords[multiFeatureIndex][geometryIndex][coordIndex], properties, options); } throw new Error('geojson is invalid'); } // CONCATENATED MODULE: ./node_modules/@turf/envelope/node_modules/@turf/bbox/main.es.js /** * Takes a set of features, calculates the bbox of all input features, and returns a bounding box. * * @name bbox * @param {GeoJSON} geojson any GeoJSON object * @returns {BBox} bbox extent in [minX, minY, maxX, maxY] order * @example * var line = turf.lineString([[-74, 40], [-78, 42], [-82, 35]]); * var bbox = turf.bbox(line); * var bboxPolygon = turf.bboxPolygon(bbox); * * //addToMap * var addToMap = [line, bboxPolygon] */ function main_es_bbox(geojson) { var BBox = [Infinity, Infinity, -Infinity, -Infinity]; coordEach(geojson, function (coord) { if (BBox[0] > coord[0]) BBox[0] = coord[0]; if (BBox[1] > coord[1]) BBox[1] = coord[1]; if (BBox[2] < coord[0]) BBox[2] = coord[0]; if (BBox[3] < coord[1]) BBox[3] = coord[1]; }); return BBox; } /* harmony default export */ var main_es = (main_es_bbox); // CONCATENATED MODULE: ./node_modules/@turf/bbox-polygon/node_modules/@turf/helpers/main.es.js /** * Earth Radius used with the Harvesine formula and approximates using a spherical (non-ellipsoid) Earth. */ var main_es_earthRadius = 6371008.8; /** * Unit of measurement factors using a spherical (non-ellipsoid) earth radius. */ var main_es_factors = { meters: main_es_earthRadius, metres: main_es_earthRadius, millimeters: main_es_earthRadius * 1000, millimetres: main_es_earthRadius * 1000, centimeters: main_es_earthRadius * 100, centimetres: main_es_earthRadius * 100, kilometers: main_es_earthRadius / 1000, kilometres: main_es_earthRadius / 1000, miles: main_es_earthRadius / 1609.344, nauticalmiles: main_es_earthRadius / 1852, inches: main_es_earthRadius * 39.370, yards: main_es_earthRadius / 1.0936, feet: main_es_earthRadius * 3.28084, radians: 1, degrees: main_es_earthRadius / 111325, }; /** * Units of measurement factors based on 1 meter. */ var main_es_unitsFactors = { meters: 1, metres: 1, millimeters: 1000, millimetres: 1000, centimeters: 100, centimetres: 100, kilometers: 1 / 1000, kilometres: 1 / 1000, miles: 1 / 1609.344, nauticalmiles: 1 / 1852, inches: 39.370, yards: 1 / 1.0936, feet: 3.28084, radians: 1 / main_es_earthRadius, degrees: 1 / 111325, }; /** * Area of measurement factors based on 1 square meter. */ var main_es_areaFactors = { meters: 1, metres: 1, millimeters: 1000000, millimetres: 1000000, centimeters: 10000, centimetres: 10000, kilometers: 0.000001, kilometres: 0.000001, acres: 0.000247105, miles: 3.86e-7, yards: 1.195990046, feet: 10.763910417, inches: 1550.003100006 }; /** * Wraps a GeoJSON {@link Geometry} in a GeoJSON {@link Feature}. * * @name feature * @param {Geometry} geometry input geometry * @param {Object} [properties={}] an Object of key-value pairs to add as properties * @param {Object} [options={}] Optional Parameters * @param {Array} [options.bbox] Bounding Box Array [west, south, east, north] associated with the Feature * @param {string|number} [options.id] Identifier associated with the Feature * @returns {Feature} a GeoJSON Feature * @example * var geometry = { * "type": "Point", * "coordinates": [110, 50] * }; * * var feature = turf.feature(geometry); * * //=feature */ function main_es_feature(geometry, properties, options) { // Optional Parameters options = options || {}; if (!main_es_isObject(options)) throw new Error('options is invalid'); var bbox = options.bbox; var id = options.id; // Validation if (geometry === undefined) throw new Error('geometry is required'); if (properties && properties.constructor !== Object) throw new Error('properties must be an Object'); if (bbox) main_es_validateBBox(bbox); if (id) main_es_validateId(id); // Main var feat = {type: 'Feature'}; if (id) feat.id = id; if (bbox) feat.bbox = bbox; feat.properties = properties || {}; feat.geometry = geometry; return feat; } /** * Creates a GeoJSON {@link Geometry} from a Geometry string type & coordinates. * For GeometryCollection type use `helpers.geometryCollection` * * @name geometry * @param {string} type Geometry Type * @param {Array} coordinates Coordinates * @param {Object} [options={}] Optional Parameters * @param {Array} [options.bbox] Bounding Box Array [west, south, east, north] associated with the Geometry * @returns {Geometry} a GeoJSON Geometry * @example * var type = 'Point'; * var coordinates = [110, 50]; * * var geometry = turf.geometry(type, coordinates); * * //=geometry */ function helpers_main_es_geometry(type, coordinates, options) { // Optional Parameters options = options || {}; if (!main_es_isObject(options)) throw new Error('options is invalid'); var bbox = options.bbox; // Validation if (!type) throw new Error('type is required'); if (!coordinates) throw new Error('coordinates is required'); if (!Array.isArray(coordinates)) throw new Error('coordinates must be an Array'); if (bbox) main_es_validateBBox(bbox); // Main var geom; switch (type) { case 'Point': geom = main_es_point(coordinates).geometry; break; case 'LineString': geom = main_es_lineString(coordinates).geometry; break; case 'Polygon': geom = main_es_polygon(coordinates).geometry; break; case 'MultiPoint': geom = main_es_multiPoint(coordinates).geometry; break; case 'MultiLineString': geom = main_es_multiLineString(coordinates).geometry; break; case 'MultiPolygon': geom = main_es_multiPolygon(coordinates).geometry; break; default: throw new Error(type + ' is invalid'); } if (bbox) geom.bbox = bbox; return geom; } /** * Creates a {@link Point} {@link Feature} from a Position. * * @name point * @param {Array} coordinates longitude, latitude position (each in decimal degrees) * @param {Object} [properties={}] an Object of key-value pairs to add as properties * @param {Object} [options={}] Optional Parameters * @param {Array} [options.bbox] Bounding Box Array [west, south, east, north] associated with the Feature * @param {string|number} [options.id] Identifier associated with the Feature * @returns {Feature} a Point feature * @example * var point = turf.point([-75.343, 39.984]); * * //=point */ function main_es_point(coordinates, properties, options) { if (!coordinates) throw new Error('coordinates is required'); if (!Array.isArray(coordinates)) throw new Error('coordinates must be an Array'); if (coordinates.length < 2) throw new Error('coordinates must be at least 2 numbers long'); if (!main_es_isNumber(coordinates[0]) || !main_es_isNumber(coordinates[1])) throw new Error('coordinates must contain numbers'); return main_es_feature({ type: 'Point', coordinates: coordinates }, properties, options); } /** * Creates a {@link Point} {@link FeatureCollection} from an Array of Point coordinates. * * @name points * @param {Array>} coordinates an array of Points * @param {Object} [properties={}] Translate these properties to each Feature * @param {Object} [options={}] Optional Parameters * @param {Array} [options.bbox] Bounding Box Array [west, south, east, north] associated with the FeatureCollection * @param {string|number} [options.id] Identifier associated with the FeatureCollection * @returns {FeatureCollection} Point Feature * @example * var points = turf.points([ * [-75, 39], * [-80, 45], * [-78, 50] * ]); * * //=points */ function main_es_points(coordinates, properties, options) { if (!coordinates) throw new Error('coordinates is required'); if (!Array.isArray(coordinates)) throw new Error('coordinates must be an Array'); return main_es_featureCollection(coordinates.map(function (coords) { return main_es_point(coords, properties); }), options); } /** * Creates a {@link Polygon} {@link Feature} from an Array of LinearRings. * * @name polygon * @param {Array>>} coordinates an array of LinearRings * @param {Object} [properties={}] an Object of key-value pairs to add as properties * @param {Object} [options={}] Optional Parameters * @param {Array} [options.bbox] Bounding Box Array [west, south, east, north] associated with the Feature * @param {string|number} [options.id] Identifier associated with the Feature * @returns {Feature} Polygon Feature * @example * var polygon = turf.polygon([[[-5, 52], [-4, 56], [-2, 51], [-7, 54], [-5, 52]]], { name: 'poly1' }); * * //=polygon */ function main_es_polygon(coordinates, properties, options) { if (!coordinates) throw new Error('coordinates is required'); for (var i = 0; i < coordinates.length; i++) { var ring = coordinates[i]; if (ring.length < 4) { throw new Error('Each LinearRing of a Polygon must have 4 or more Positions.'); } for (var j = 0; j < ring[ring.length - 1].length; j++) { // Check if first point of Polygon contains two numbers if (i === 0 && j === 0 && !main_es_isNumber(ring[0][0]) || !main_es_isNumber(ring[0][1])) throw new Error('coordinates must contain numbers'); if (ring[ring.length - 1][j] !== ring[0][j]) { throw new Error('First and last Position are not equivalent.'); } } } return main_es_feature({ type: 'Polygon', coordinates: coordinates }, properties, options); } /** * Creates a {@link Polygon} {@link FeatureCollection} from an Array of Polygon coordinates. * * @name polygons * @param {Array>>>} coordinates an array of Polygon coordinates * @param {Object} [properties={}] an Object of key-value pairs to add as properties * @param {Object} [options={}] Optional Parameters * @param {Array} [options.bbox] Bounding Box Array [west, south, east, north] associated with the Feature * @param {string|number} [options.id] Identifier associated with the FeatureCollection * @returns {FeatureCollection} Polygon FeatureCollection * @example * var polygons = turf.polygons([ * [[[-5, 52], [-4, 56], [-2, 51], [-7, 54], [-5, 52]]], * [[[-15, 42], [-14, 46], [-12, 41], [-17, 44], [-15, 42]]], * ]); * * //=polygons */ function main_es_polygons(coordinates, properties, options) { if (!coordinates) throw new Error('coordinates is required'); if (!Array.isArray(coordinates)) throw new Error('coordinates must be an Array'); return main_es_featureCollection(coordinates.map(function (coords) { return main_es_polygon(coords, properties); }), options); } /** * Creates a {@link LineString} {@link Feature} from an Array of Positions. * * @name lineString * @param {Array>} coordinates an array of Positions * @param {Object} [properties={}] an Object of key-value pairs to add as properties * @param {Object} [options={}] Optional Parameters * @param {Array} [options.bbox] Bounding Box Array [west, south, east, north] associated with the Feature * @param {string|number} [options.id] Identifier associated with the Feature * @returns {Feature} LineString Feature * @example * var linestring1 = turf.lineString([[-24, 63], [-23, 60], [-25, 65], [-20, 69]], {name: 'line 1'}); * var linestring2 = turf.lineString([[-14, 43], [-13, 40], [-15, 45], [-10, 49]], {name: 'line 2'}); * * //=linestring1 * //=linestring2 */ function main_es_lineString(coordinates, properties, options) { if (!coordinates) throw new Error('coordinates is required'); if (coordinates.length < 2) throw new Error('coordinates must be an array of two or more positions'); // Check if first point of LineString contains two numbers if (!main_es_isNumber(coordinates[0][1]) || !main_es_isNumber(coordinates[0][1])) throw new Error('coordinates must contain numbers'); return main_es_feature({ type: 'LineString', coordinates: coordinates }, properties, options); } /** * Creates a {@link LineString} {@link FeatureCollection} from an Array of LineString coordinates. * * @name lineStrings * @param {Array>} coordinates an array of LinearRings * @param {Object} [properties={}] an Object of key-value pairs to add as properties * @param {Object} [options={}] Optional Parameters * @param {Array} [options.bbox] Bounding Box Array [west, south, east, north] associated with the FeatureCollection * @param {string|number} [options.id] Identifier associated with the FeatureCollection * @returns {FeatureCollection} LineString FeatureCollection * @example * var linestrings = turf.lineStrings([ * [[-24, 63], [-23, 60], [-25, 65], [-20, 69]], * [[-14, 43], [-13, 40], [-15, 45], [-10, 49]] * ]); * * //=linestrings */ function main_es_lineStrings(coordinates, properties, options) { if (!coordinates) throw new Error('coordinates is required'); if (!Array.isArray(coordinates)) throw new Error('coordinates must be an Array'); return main_es_featureCollection(coordinates.map(function (coords) { return main_es_lineString(coords, properties); }), options); } /** * Takes one or more {@link Feature|Features} and creates a {@link FeatureCollection}. * * @name featureCollection * @param {Feature[]} features input features * @param {Object} [options={}] Optional Parameters * @param {Array} [options.bbox] Bounding Box Array [west, south, east, north] associated with the Feature * @param {string|number} [options.id] Identifier associated with the Feature * @returns {FeatureCollection} FeatureCollection of Features * @example * var locationA = turf.point([-75.343, 39.984], {name: 'Location A'}); * var locationB = turf.point([-75.833, 39.284], {name: 'Location B'}); * var locationC = turf.point([-75.534, 39.123], {name: 'Location C'}); * * var collection = turf.featureCollection([ * locationA, * locationB, * locationC * ]); * * //=collection */ function main_es_featureCollection(features, options) { // Optional Parameters options = options || {}; if (!main_es_isObject(options)) throw new Error('options is invalid'); var bbox = options.bbox; var id = options.id; // Validation if (!features) throw new Error('No features passed'); if (!Array.isArray(features)) throw new Error('features must be an Array'); if (bbox) main_es_validateBBox(bbox); if (id) main_es_validateId(id); // Main var fc = {type: 'FeatureCollection'}; if (id) fc.id = id; if (bbox) fc.bbox = bbox; fc.features = features; return fc; } /** * Creates a {@link Feature} based on a * coordinate array. Properties can be added optionally. * * @name multiLineString * @param {Array>>} coordinates an array of LineStrings * @param {Object} [properties={}] an Object of key-value pairs to add as properties * @param {Object} [options={}] Optional Parameters * @param {Array} [options.bbox] Bounding Box Array [west, south, east, north] associated with the Feature * @param {string|number} [options.id] Identifier associated with the Feature * @returns {Feature} a MultiLineString feature * @throws {Error} if no coordinates are passed * @example * var multiLine = turf.multiLineString([[[0,0],[10,10]]]); * * //=multiLine */ function main_es_multiLineString(coordinates, properties, options) { if (!coordinates) throw new Error('coordinates is required'); return main_es_feature({ type: 'MultiLineString', coordinates: coordinates }, properties, options); } /** * Creates a {@link Feature} based on a * coordinate array. Properties can be added optionally. * * @name multiPoint * @param {Array>} coordinates an array of Positions * @param {Object} [properties={}] an Object of key-value pairs to add as properties * @param {Object} [options={}] Optional Parameters * @param {Array} [options.bbox] Bounding Box Array [west, south, east, north] associated with the Feature * @param {string|number} [options.id] Identifier associated with the Feature * @returns {Feature} a MultiPoint feature * @throws {Error} if no coordinates are passed * @example * var multiPt = turf.multiPoint([[0,0],[10,10]]); * * //=multiPt */ function main_es_multiPoint(coordinates, properties, options) { if (!coordinates) throw new Error('coordinates is required'); return main_es_feature({ type: 'MultiPoint', coordinates: coordinates }, properties, options); } /** * Creates a {@link Feature} based on a * coordinate array. Properties can be added optionally. * * @name multiPolygon * @param {Array>>>} coordinates an array of Polygons * @param {Object} [properties={}] an Object of key-value pairs to add as properties * @param {Object} [options={}] Optional Parameters * @param {Array} [options.bbox] Bounding Box Array [west, south, east, north] associated with the Feature * @param {string|number} [options.id] Identifier associated with the Feature * @returns {Feature} a multipolygon feature * @throws {Error} if no coordinates are passed * @example * var multiPoly = turf.multiPolygon([[[[0,0],[0,10],[10,10],[10,0],[0,0]]]]); * * //=multiPoly * */ function main_es_multiPolygon(coordinates, properties, options) { if (!coordinates) throw new Error('coordinates is required'); return main_es_feature({ type: 'MultiPolygon', coordinates: coordinates }, properties, options); } /** * Creates a {@link Feature} based on a * coordinate array. Properties can be added optionally. * * @name geometryCollection * @param {Array} geometries an array of GeoJSON Geometries * @param {Object} [properties={}] an Object of key-value pairs to add as properties * @param {Object} [options={}] Optional Parameters * @param {Array} [options.bbox] Bounding Box Array [west, south, east, north] associated with the Feature * @param {string|number} [options.id] Identifier associated with the Feature * @returns {Feature} a GeoJSON GeometryCollection Feature * @example * var pt = { * "type": "Point", * "coordinates": [100, 0] * }; * var line = { * "type": "LineString", * "coordinates": [ [101, 0], [102, 1] ] * }; * var collection = turf.geometryCollection([pt, line]); * * //=collection */ function main_es_geometryCollection(geometries, properties, options) { if (!geometries) throw new Error('geometries is required'); if (!Array.isArray(geometries)) throw new Error('geometries must be an Array'); return main_es_feature({ type: 'GeometryCollection', geometries: geometries }, properties, options); } /** * Round number to precision * * @param {number} num Number * @param {number} [precision=0] Precision * @returns {number} rounded number * @example * turf.round(120.4321) * //=120 * * turf.round(120.4321, 2) * //=120.43 */ function main_es_round(num, precision) { if (num === undefined || num === null || isNaN(num)) throw new Error('num is required'); if (precision && !(precision >= 0)) throw new Error('precision must be a positive number'); var multiplier = Math.pow(10, precision || 0); return Math.round(num * multiplier) / multiplier; } /** * Convert a distance measurement (assuming a spherical Earth) from radians to a more friendly unit. * Valid units: miles, nauticalmiles, inches, yards, meters, metres, kilometers, centimeters, feet * * @name radiansToLength * @param {number} radians in radians across the sphere * @param {string} [units='kilometers'] can be degrees, radians, miles, or kilometers inches, yards, metres, meters, kilometres, kilometers. * @returns {number} distance */ function main_es_radiansToLength(radians, units) { if (radians === undefined || radians === null) throw new Error('radians is required'); if (units && typeof units !== 'string') throw new Error('units must be a string'); var factor = main_es_factors[units || 'kilometers']; if (!factor) throw new Error(units + ' units is invalid'); return radians * factor; } /** * Convert a distance measurement (assuming a spherical Earth) from a real-world unit into radians * Valid units: miles, nauticalmiles, inches, yards, meters, metres, kilometers, centimeters, feet * * @name lengthToRadians * @param {number} distance in real units * @param {string} [units='kilometers'] can be degrees, radians, miles, or kilometers inches, yards, metres, meters, kilometres, kilometers. * @returns {number} radians */ function main_es_lengthToRadians(distance, units) { if (distance === undefined || distance === null) throw new Error('distance is required'); if (units && typeof units !== 'string') throw new Error('units must be a string'); var factor = main_es_factors[units || 'kilometers']; if (!factor) throw new Error(units + ' units is invalid'); return distance / factor; } /** * Convert a distance measurement (assuming a spherical Earth) from a real-world unit into degrees * Valid units: miles, nauticalmiles, inches, yards, meters, metres, centimeters, kilometres, feet * * @name lengthToDegrees * @param {number} distance in real units * @param {string} [units='kilometers'] can be degrees, radians, miles, or kilometers inches, yards, metres, meters, kilometres, kilometers. * @returns {number} degrees */ function main_es_lengthToDegrees(distance, units) { return main_es_radiansToDegrees(main_es_lengthToRadians(distance, units)); } /** * Converts any bearing angle from the north line direction (positive clockwise) * and returns an angle between 0-360 degrees (positive clockwise), 0 being the north line * * @name bearingToAzimuth * @param {number} bearing angle, between -180 and +180 degrees * @returns {number} angle between 0 and 360 degrees */ function main_es_bearingToAzimuth(bearing) { if (bearing === null || bearing === undefined) throw new Error('bearing is required'); var angle = bearing % 360; if (angle < 0) angle += 360; return angle; } /** * Converts an angle in radians to degrees * * @name radiansToDegrees * @param {number} radians angle in radians * @returns {number} degrees between 0 and 360 degrees */ function main_es_radiansToDegrees(radians) { if (radians === null || radians === undefined) throw new Error('radians is required'); var degrees = radians % (2 * Math.PI); return degrees * 180 / Math.PI; } /** * Converts an angle in degrees to radians * * @name degreesToRadians * @param {number} degrees angle between 0 and 360 degrees * @returns {number} angle in radians */ function main_es_degreesToRadians(degrees) { if (degrees === null || degrees === undefined) throw new Error('degrees is required'); var radians = degrees % 360; return radians * Math.PI / 180; } /** * Converts a length to the requested unit. * Valid units: miles, nauticalmiles, inches, yards, meters, metres, kilometers, centimeters, feet * * @param {number} length to be converted * @param {string} originalUnit of the length * @param {string} [finalUnit='kilometers'] returned unit * @returns {number} the converted length */ function main_es_convertLength(length, originalUnit, finalUnit) { if (length === null || length === undefined) throw new Error('length is required'); if (!(length >= 0)) throw new Error('length must be a positive number'); return main_es_radiansToLength(main_es_lengthToRadians(length, originalUnit), finalUnit || 'kilometers'); } /** * Converts a area to the requested unit. * Valid units: kilometers, kilometres, meters, metres, centimetres, millimeters, acres, miles, yards, feet, inches * @param {number} area to be converted * @param {string} [originalUnit='meters'] of the distance * @param {string} [finalUnit='kilometers'] returned unit * @returns {number} the converted distance */ function main_es_convertArea(area, originalUnit, finalUnit) { if (area === null || area === undefined) throw new Error('area is required'); if (!(area >= 0)) throw new Error('area must be a positive number'); var startFactor = main_es_areaFactors[originalUnit || 'meters']; if (!startFactor) throw new Error('invalid original units'); var finalFactor = main_es_areaFactors[finalUnit || 'kilometers']; if (!finalFactor) throw new Error('invalid final units'); return (area / startFactor) * finalFactor; } /** * isNumber * * @param {*} num Number to validate * @returns {boolean} true/false * @example * turf.isNumber(123) * //=true * turf.isNumber('foo') * //=false */ function main_es_isNumber(num) { return !isNaN(num) && num !== null && !Array.isArray(num); } /** * isObject * * @param {*} input variable to validate * @returns {boolean} true/false * @example * turf.isObject({elevation: 10}) * //=true * turf.isObject('foo') * //=false */ function main_es_isObject(input) { return (!!input) && (input.constructor === Object); } /** * Validate BBox * * @private * @param {Array} bbox BBox to validate * @returns {void} * @throws Error if BBox is not valid * @example * validateBBox([-180, -40, 110, 50]) * //=OK * validateBBox([-180, -40]) * //=Error * validateBBox('Foo') * //=Error * validateBBox(5) * //=Error * validateBBox(null) * //=Error * validateBBox(undefined) * //=Error */ function main_es_validateBBox(bbox) { if (!bbox) throw new Error('bbox is required'); if (!Array.isArray(bbox)) throw new Error('bbox must be an Array'); if (bbox.length !== 4 && bbox.length !== 6) throw new Error('bbox must be an Array of 4 or 6 numbers'); bbox.forEach(function (num) { if (!main_es_isNumber(num)) throw new Error('bbox must only contain numbers'); }); } /** * Validate Id * * @private * @param {string|number} id Id to validate * @returns {void} * @throws Error if Id is not valid * @example * validateId([-180, -40, 110, 50]) * //=Error * validateId([-180, -40]) * //=Error * validateId('Foo') * //=OK * validateId(5) * //=OK * validateId(null) * //=Error * validateId(undefined) * //=Error */ function main_es_validateId(id) { if (!id) throw new Error('id is required'); if (['string', 'number'].indexOf(typeof id) === -1) throw new Error('id must be a number or a string'); } // Deprecated methods function main_es_radians2degrees() { throw new Error('method has been renamed to `radiansToDegrees`'); } function main_es_degrees2radians() { throw new Error('method has been renamed to `degreesToRadians`'); } function main_es_distanceToDegrees() { throw new Error('method has been renamed to `lengthToDegrees`'); } function main_es_distanceToRadians() { throw new Error('method has been renamed to `lengthToRadians`'); } function main_es_radiansToDistance() { throw new Error('method has been renamed to `radiansToLength`'); } function main_es_bearingToAngle() { throw new Error('method has been renamed to `bearingToAzimuth`'); } function main_es_convertDistance() { throw new Error('method has been renamed to `convertLength`'); } // CONCATENATED MODULE: ./node_modules/@turf/bbox-polygon/main.es.js /** * Takes a bbox and returns an equivalent {@link Polygon|polygon}. * * @name bboxPolygon * @param {BBox} bbox extent in [minX, minY, maxX, maxY] order * @returns {Feature} a Polygon representation of the bounding box * @example * var bbox = [0, 0, 10, 10]; * * var poly = turf.bboxPolygon(bbox); * * //addToMap * var addToMap = [poly] */ function bboxPolygon(bbox) { main_es_validateBBox(bbox); // Convert BBox positions to Numbers // No performance loss for including Number() // https://github.com/Turfjs/turf/issues/1119 var west = Number(bbox[0]); var south = Number(bbox[1]); var east = Number(bbox[2]); var north = Number(bbox[3]); if (bbox.length === 6) throw new Error('@turf/bbox-polygon does not support BBox with 6 positions'); var lowLeft = [west, south]; var topLeft = [west, north]; var topRight = [east, north]; var lowRight = [east, south]; return main_es_polygon([[ lowLeft, lowRight, topRight, topLeft, lowLeft ]]); } /* harmony default export */ var bbox_polygon_main_es = (bboxPolygon); // CONCATENATED MODULE: ./node_modules/@turf/envelope/main.es.js /** * Takes any number of features and returns a rectangular {@link Polygon} that encompasses all vertices. * * @name envelope * @param {GeoJSON} geojson input features * @returns {Feature} a rectangular Polygon feature that encompasses all vertices * @example * var features = turf.featureCollection([ * turf.point([-75.343, 39.984], {"name": "Location A"}), * turf.point([-75.833, 39.284], {"name": "Location B"}), * turf.point([-75.534, 39.123], {"name": "Location C"}) * ]); * * var enveloped = turf.envelope(features); * * //addToMap * var addToMap = [features, enveloped]; */ function envelope(geojson) { return bbox_polygon_main_es(main_es(geojson)); } /* harmony default export */ var envelope_main_es = __webpack_exports__["default"] = (envelope); /***/ }), /***/ "0c17": /***/ (function(module, exports, __webpack_require__) { "use strict"; var utils = __webpack_require__("d691"); /** * Transform the data for a request or a response * * @param {Object|String} data The data to be transformed * @param {Array} headers The headers for the request or response * @param {Array|Function} fns A single function or Array of functions * @returns {*} The resulting transformed data */ module.exports = function transformData(data, headers, fns) { /*eslint no-param-reassign:0*/ utils.forEach(fns, function transform(fn) { data = fn(data, headers); }); return data; }; /***/ }), /***/ "0c2c": /***/ (function(module, exports, __webpack_require__) { "use strict"; var _interopRequireDefault = __webpack_require__("8e6d"); Object.defineProperty(exports, "__esModule", { value: true }); exports.default = void 0; var _theme = _interopRequireDefault(__webpack_require__("9259")); // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // var _default2 = { name: 'LinedataResult', mixins: [_theme.default], props: { keyWord: { type: String }, count: { type: Number, default: 0 }, data: { type: Array }, busData: { type: Object, default: function _default() { return {}; } }, prompt: { type: Object } }, data: function data() { return { detailVisibles: [true] }; }, methods: { generatePopup: function generatePopup(pointInfo) { var coordinate = pointInfo.lonlat.split(','); this.$emit('show-point-popup', { coordinates: [+coordinate[0], +coordinate[1]], data: pointInfo, from: 'LineString' }); }, searchPointsResult: function searchPointsResult() { var params = { queryType: '7', queryTerminal: 10000, specifyAdminCode: this.prompt.adminCode }; this.$emit('search-points-result', this.keyWord, params, true); }, showLineDetail: function showLineDetail(uuid, groupIndex) { var detailVisibles = new Array(this.data.length).fill(false); detailVisibles[groupIndex] = !this.detailVisibles[groupIndex]; this.detailVisibles = detailVisibles; detailVisibles[groupIndex] ? this.$emit('show-line-detail', uuid) : this.$emit('reset-line-source'); } } }; exports.default = _default2; /***/ }), /***/ "0f59": /***/ (function(module, exports, __webpack_require__) { "use strict"; var _interopRequireDefault = __webpack_require__("8e6d"); Object.defineProperty(exports, "__esModule", { value: true }); exports.default = void 0; var _theme = _interopRequireDefault(__webpack_require__("9259")); var _control = _interopRequireDefault(__webpack_require__("2c56")); var _mapGetter = _interopRequireDefault(__webpack_require__("b761")); var _card = _interopRequireDefault(__webpack_require__("333c")); var _MeasureViewModel = _interopRequireDefault(__webpack_require__("4c06")); var _drawEvent = _interopRequireDefault(__webpack_require__("9104")); var _lodash = _interopRequireDefault(__webpack_require__("f344")); __webpack_require__("fc22"); // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // var _default = { name: 'SmMeasure', mixins: [_mapGetter.default, _control.default, _theme.default, _card.default], props: { collapsed: { type: Boolean, // 是否折叠 default: true }, iconClass: { type: String, default: 'sm-components-icons-measure' }, headerName: { type: String // default: geti18n().t('commontypes.iportalData') // '量算' }, showUnitSelect: { // 配置单位选择框是否显示,若不显示,则显示对应的默认单位 type: Boolean, default: true }, distanceDefaultUnit: { // 距离默认单位 type: String, default: 'kilometers' }, areaDefaultUnit: { // 面积默认单位 type: String, default: 'kilometers' }, continueDraw: { // 是否开启多绘制 type: Boolean, default: true } }, data: function data() { var unitOptions = { draw_line_string: { kilometers: this.$t('unit.kilometers'), miles: this.$t('unit.miles'), meters: this.$t('unit.meters'), feet: this.$t('unit.feet'), yards: this.$t('unit.yards') }, draw_polygon: { kilometers: this.$t('unit.squarekilometers'), miles: this.$t('unit.squaremiles'), meters: this.$t('unit.squaremeters'), feet: this.$t('unit.squarefeet'), yards: this.$t('unit.squareyards') } }; return { unitOptions: unitOptions, modeGroups: [{ mode: 'draw_line_string', title: this.$t('measure.distance'), iconClass: 'sm-components-icons-line-layer' }, { mode: 'draw_polygon', title: this.$t('measure.area'), iconClass: 'sm-components-icons-polygon-layer' }, { mode: 'delete', title: this.$t('measure.delete'), iconClass: 'sm-components-icons-delete' }], activeMode: '', result: '', activeDistanceUnit: this.distanceDefaultUnit, activeAreaUnit: this.areaDefaultUnit, modeUnitMap: { draw_line_string: 'activeDistanceUnit', draw_polygon: 'activeAreaUnit' }, layerId: '' }; }, computed: { getUnitOptions: function getUnitOptions() { return this.unitOptions[this.activeMode] || []; }, getResult: function getResult() { if (this.result && this.measureFinished) { var result = "".concat(this.result, " ").concat(this.getUnitLabel); this.resetActiveMode(); return result; } return ''; }, getUnitLabel: function getUnitLabel() { var units = this.getUnitOptions; var modeUnitKey = this.modeUnitMap[this.activeMode]; var label = units[this[modeUnitKey]]; return label; }, getAreaSelect: function getAreaSelect() { return this.activeMode === 'draw_polygon' && this.showUnitSelect; }, getDistanceSelect: function getDistanceSelect() { return this.activeMode === 'draw_line_string' && this.showUnitSelect; } }, watch: { distanceDefaultUnit: function distanceDefaultUnit(newVal) { this.activeDistanceUnit = newVal; this.updateUnit(newVal); }, areaDefaultUnit: function areaDefaultUnit(newVal) { this.activeAreaUnit = newVal; this.updateUnit(newVal); }, textColorsData: { handler: function handler() { this.changeSelectInputStyle(); } }, backgroundData: { handler: function handler() { this.changeSelectInputStyle(); } } }, created: function created() { this.componentName = (0, _lodash.default)(this.$options.name); this.viewModel = new _MeasureViewModel.default({ continueDraw: this.continueDraw, componentName: this.componentName }); this.viewModel.on('measure-finished', this.measureFinishedFn); this.viewModel.on('measure-start', this.measureStartFn); this.viewModel.on('update-unit', this.updateUnitFn); }, mounted: function mounted() { this.changeSelectInputStyle(); _drawEvent.default.$on('draw-reset', this.drawResetFn); }, beforeDestroy: function beforeDestroy() { this.viewModel.off('measure-finished', this.measureFinishedFn); this.viewModel.off('measure-start', this.measureStartFn); this.viewModel.off('update-unit', this.updateUnitFn); _drawEvent.default.$off('draw-reset', this.drawResetFn); }, removed: function removed(map, target) { _drawEvent.default.$options.deleteDrawingState(target, this.componentName); this.resetData(target); }, methods: { measureFinishedFn: function measureFinishedFn(e) { this.result = e.result; this.measureFinished = true; }, measureStartFn: function measureStartFn(e) { this.result = ''; this.measureFinished = false; }, updateUnitFn: function updateUnitFn(e) { this.result = e.result; }, drawResetFn: function drawResetFn(_ref) { var componentName = _ref.componentName; if (componentName !== this.componentName) { this.activeMode = null; this.result = ''; } }, changeSelectInputStyle: function changeSelectInputStyle() { var selectDoms = this.$el.querySelectorAll('.ant-select-selection'); var _iteratorNormalCompletion = true; var _didIteratorError = false; var _iteratorError = undefined; try { for (var _iterator = selectDoms[Symbol.iterator](), _step; !(_iteratorNormalCompletion = (_step = _iterator.next()).done); _iteratorNormalCompletion = true) { var selectDom = _step.value; if (selectDom) { selectDom.style.borderColor = this.getTextColor; selectDom.style.color = this.getTextColor; selectDom.style.backgroundColor = this.getBackground; } } } catch (err) { _didIteratorError = true; _iteratorError = err; } finally { try { if (!_iteratorNormalCompletion && _iterator.return != null) { _iterator.return(); } } finally { if (_didIteratorError) { throw _iteratorError; } } } }, changeChosenStyle: function changeChosenStyle(visible) { var _this = this; setTimeout(function () { var optionList = _this.$el.querySelectorAll('.ant-select-dropdown-menu-item'); var dropdownDoms = _this.$el.querySelectorAll('.ant-select-dropdown'); var _iteratorNormalCompletion2 = true; var _didIteratorError2 = false; var _iteratorError2 = undefined; try { for (var _iterator2 = optionList[Symbol.iterator](), _step2; !(_iteratorNormalCompletion2 = (_step2 = _iterator2.next()).done); _iteratorNormalCompletion2 = true) { var item = _step2.value; if (item.classList.contains('ant-select-dropdown-menu-item-selected')) { item.style.color = _this.getColorStyle(0).color; item.style.backgroundColor = _this.getBackground; } else { item.style.color = _this.getTextColor; item.style.backgroundColor = 'transparent'; } } } catch (err) { _didIteratorError2 = true; _iteratorError2 = err; } finally { try { if (!_iteratorNormalCompletion2 && _iterator2.return != null) { _iterator2.return(); } } finally { if (_didIteratorError2) { throw _iteratorError2; } } } var _iteratorNormalCompletion3 = true; var _didIteratorError3 = false; var _iteratorError3 = undefined; try { for (var _iterator3 = dropdownDoms[Symbol.iterator](), _step3; !(_iteratorNormalCompletion3 = (_step3 = _iterator3.next()).done); _iteratorNormalCompletion3 = true) { var dropdownDom = _step3.value; if (dropdownDom) { dropdownDom.style.backgroundColor = _this.getBackground; } } } catch (err) { _didIteratorError3 = true; _iteratorError3 = err; } finally { try { if (!_iteratorNormalCompletion3 && _iterator3.return != null) { _iterator3.return(); } } finally { if (_didIteratorError3) { throw _iteratorError3; } } } }, 0); }, // 切换量算模式 changeMeasureMode: function changeMeasureMode(mode) { var _this2 = this; setTimeout(function () { var mapNotLoaded = _this2.mapNotLoadedTip(); if (mapNotLoaded) { return; } if (!_this2.map.loaded()) { _this2.$message.destroy(); _this2.$message.warning(_this2.$t('warning.mapNotLoaded')); } else { var modeUnitKey = _this2.modeUnitMap[mode]; var activeUnit = _this2[modeUnitKey]; if (mode === 'delete') { _this2.viewModel.trash(); _this2.activeMode = null; _this2.result = ''; return; } if (_this2.activeMode !== mode || !_this2.continueDraw) { _this2.viewModel.openDraw(mode, activeUnit); _this2.activeMode = mode; _this2.continueDraw && _drawEvent.default.$emit('draw-reset', { componentName: _this2.componentName }); } else { _this2.viewModel.removeDraw(_this2.continueDraw); _this2.activeMode = null; } } }, 0); }, updateUnit: function updateUnit(unit) { this.viewModel && this.viewModel.updateUnit(unit); }, getPopupContainer: function getPopupContainer() { return this.$el.querySelector('.sm-component-measure__panelContent'); }, resetActiveMode: function resetActiveMode() { !this.activeModeCache && (this.activeModeCache = this.activeMode); this.measureFinished && !this.continueDraw && (this.activeMode = null); if (!this.measureFinished && this.continueDraw) { this.activeMode = this.activeModeCache; } }, resetData: function resetData(mapTarget) { this.activeMode = null; this.result = ''; this.continueDraw && _drawEvent.default.$emit('draw-reset', { componentName: this.componentName }); }, // 提供对外方法:清空features clear: function clear() { this.activeMode = null; this.result = ''; this.viewModel && this.viewModel.clearAllFeatures(); } } }; exports.default = _default; /***/ }), /***/ "0f9e": /***/ (function(module, exports, __webpack_require__) { "use strict"; var _interopRequireDefault = __webpack_require__("8e6d"); Object.defineProperty(exports, "__esModule", { value: true }); exports.default = void 0; var _typeof2 = _interopRequireDefault(__webpack_require__("7ae5")); var _toConsumableArray2 = _interopRequireDefault(__webpack_require__("4066")); var _defineProperty2 = _interopRequireDefault(__webpack_require__("279f")); __webpack_require__("f840"); var _vueEcharts = _interopRequireDefault(__webpack_require__("8275")); var _lodash = _interopRequireDefault(__webpack_require__("f344")); var _lodash2 = _interopRequireDefault(__webpack_require__("6e63")); var _lodash3 = _interopRequireDefault(__webpack_require__("5f9f")); var _debounce = _interopRequireDefault(__webpack_require__("331f")); var _lodash4 = _interopRequireDefault(__webpack_require__("25a2")); var _card = _interopRequireDefault(__webpack_require__("333c")); var _theme = _interopRequireDefault(__webpack_require__("9259")); var _timer = _interopRequireDefault(__webpack_require__("8156")); var _chart = __webpack_require__("33aa"); var _EchartsDataService = _interopRequireDefault(__webpack_require__("50c6")); var _TablePopup = _interopRequireDefault(__webpack_require__("b397")); var _util = __webpack_require__("1448"); var _resizeDetector = __webpack_require__("e0f2"); 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; } // 枚举事件类型 var EVENTS = ['legendselectchanged', 'legendselected', 'legendunselected', 'legendscroll', 'datazoom', 'datarangeselected', 'timelinechanged', 'timelineplaychanged', 'restore', 'dataviewchanged', 'magictypechanged', 'geoselectchanged', 'geoselected', 'geounselected', 'pieselectchanged', 'pieselected', 'pieunselected', 'mapselectchanged', 'mapselected', 'mapunselected', 'axisareaselected', 'focusnodeadjacency', 'unfocusnodeadjacency', 'brush', 'brushselected', 'rendered', 'finished', 'click', 'dblclick', 'mouseover', 'mouseout', 'mousemove', 'mousedown', 'mouseup', 'globalout', 'contextmenu']; var _default2 = { components: { 'v-chart': _vueEcharts.default, TablePopup: _TablePopup.default }, mixins: [_theme.default, _card.default, _timer.default], props: { iconClass: { type: String, default: 'sm-components-icons-attribute' }, dataset: { type: Object, default: function _default() { return null; } }, datasetOptions: { type: Array, default: function _default() { return null; } }, colorGroup: { type: Array }, options: { type: Object, default: function _default() { return {}; } }, autoresize: { type: Boolean, default: true }, theme: { type: [Object, String] }, initOptions: { type: Object }, group: { type: String }, manualUpdate: { type: Boolean, default: false }, autoPlay: { type: Boolean, default: false }, associatedMap: { type: Boolean, default: false }, highlightOptions: { type: Array, default: function _default() { return []; } }, highlightColor: { type: String, default: '#01ffff' } }, data: function data() { return { chartId: (0, _lodash.default)("".concat(this.$options.name.toLowerCase(), "-")), chartTheme: {}, // 图表的主题 echartOptions: {}, // 最后生成的echart数据 datasetChange: false, // dataset是否改变 dataSeriesCache: {}, tablePopupProps: {}, startSpin: null, customSeries: [], dataZoomHandler: function dataZoomHandler() {} }; }, computed: { width: function width() { return this.smChart && this.smChart.width; }, height: function height() { return this.smChart && this.smChart.height; }, computedOptions: function computedOptions() { return this.smChart && this.smChart.computedOptions; }, _chartStyle: function _chartStyle() { return { width: '100%', height: this.headerName ? 'calc(100% - 30px)' : '100%' }; }, parseOptions: function parseOptions() { var _this2 = this; if (!this.options.series) { return this.options; } if (this.options.series.find(function (item) { return item.type === '2.5Bar'; })) { return _objectSpread({}, this.options, { series: [] }); } if (this.options.series[0] && this.options.series[0].customType === 'customRingsSeries') { return _objectSpread({}, this.options, { series: [].concat((0, _toConsumableArray2.default)(this.options.series), (0, _toConsumableArray2.default)(this.customSeries)) }); } var series = this.options.series.map(function (serie, index) { if (serie.label) { var cloneSerie = (0, _lodash4.default)(serie); cloneSerie.label.normal = _this2._controlLabel(cloneSerie.label.normal, cloneSerie.maxLabels); return cloneSerie; } return serie; }); return _objectSpread({}, this.options, { series: series }); }, _chartOptions: function _chartOptions() { return this._isRequestData && this.echartOptions || this.parseOptions; }, // 是否传入dataset和datasetOptions _isRequestData: function _isRequestData() { return this.dataset && Object.keys(this.dataset).length > 0 && (this.dataset.url || this.dataset.geoJSON) && this.datasetOptions && this.datasetOptions.length > 0; }, xBar: function xBar() { return this.options && this.options.yAxis && this.options.yAxis.type === 'category'; }, popupBackground: function popupBackground() { return this.backgroundData ? (0, _util.getColorWithOpacity)(this.backgroundData, 0.5) : this.backgroundData; }, colorNumber: function colorNumber() { var length = this.datasetOptions && this.datasetOptions.length || this.echartOptions.series && this.echartOptions.series.length; var colorNumber = this.colorGroupsData.length; if (length && length > colorNumber) { colorNumber = length; } return colorNumber; } }, watch: { theme: function theme() { this.chartTheme = null; }, colorGroupsData: function colorGroupsData(newVal, oldVal) { if (!(0, _lodash3.default)(newVal, oldVal)) { this._setChartTheme(); } }, textColorsData: function textColorsData(newVal, oldVal) { if (!(0, _lodash3.default)(newVal, oldVal)) { this._setChartTheme(); } }, backgroundData: function backgroundData(newVal, oldVal) { if (!(0, _lodash3.default)(newVal, oldVal)) { this._setChartTheme(); this.changePopupArrowStyle(); } }, dataset: { handler: function handler(newVal, oldVal) { this._isRequestData && this._setEchartOptions(this.dataset, this.datasetOptions, this.options); this.datasetChange = true; }, deep: true }, datasetOptions: { handler: function handler(newVal, oldVal) { if (!(0, _lodash3.default)(newVal, oldVal)) { this._setChartTheme(); this.registerShape(); } !this.echartsDataService && this._isRequestData && this._setEchartOptions(this.dataset, this.datasetOptions, this.options); this.echartsDataService && this.echartsDataService.setDatasetOptions(this.datasetOptions); this.echartsDataService && this.dataSeriesCache && this._changeChartData(this.echartsDataService, this.datasetOptions, this.options); } }, options: { handler: function handler(newVal, oldVal) { if (this.datasetChange && !this.dataSeriesCache) { return; } if (this.dataSeriesCache && JSON.stringify(this.dataSeriesCache) !== '{}') { this.echartOptions = this._optionsHandler(this.options, this.dataSeriesCache); } else { this.echartOptions = Object.assign({}, this.options); } }, deep: true }, autoresize: function autoresize() { if (this.autoresize) { (0, _resizeDetector.addListener)(this.$el, this.__resizeHandler); } else { (0, _resizeDetector.removeListener)(this.$el, this.__resizeHandler); } }, // 以下为echart的配置参数 width: function width() { return this.smChart && this.smChart.width; }, height: function height() { return this.smChart && this.smChart.height; }, computedOptions: function computedOptions() { return this.smChart && this.smChart.computedOptions; }, autoPlay: function autoPlay() { this._handlePieAutoPlay(); }, associatedMap: function associatedMap() { if (!this.associatedMap) { this.clearPopup && this.clearPopup(); } }, highlightOptions: { handler: function handler(newVal, oldVal) { this.setItemStyleColor(); }, deep: true } }, created: function created() { this._setChartTheme(); // // 切换主题 // this.$on('theme-style-changed', () => { // this._setChartTheme(); // }); this.registerShape(); }, mounted: function mounted() { // 设置echarts实例 this.smChart = this.$refs[this.chartId]; // 派发echart所有事件 var smChart = this._getEchart(); var self = this; EVENTS.forEach(function (event) { smChart.$on(event, function (params) { if (event === 'click') { self.handleChartClick(params); } self.$emit(event, params); }); }); this._initAutoResize(); this._initDataZoom(); if (this.options.series && this.options.series[0] && this.options.series[0].customType === 'customRingsSeries') { this.startEffect(); } !this._isRequestData && this.autoPlay && this._handlePieAutoPlay(); // 请求数据, 合并echartopiton, 设置echartOptions this._isRequestData && this._setEchartOptions(this.dataset, this.datasetOptions, this.options); }, updated: function updated() { this._handlePieAutoPlay(); // 更新自动播放 }, beforeDestroy: function beforeDestroy() { clearInterval(this.pieAutoPlay); // clear 自动播放 clearInterval(this.startAngle); if (this.autoresize) { (0, _resizeDetector.removeListener)(this.$el, this.__resizeHandler); } }, methods: { _initAutoResize: function _initAutoResize() { var _this3 = this; this.__resizeHandler = (0, _debounce.default)(function () { _this3.resize(); }, 100, { leading: true }); if (this.autoresize) { // @ts-ignore (0, _resizeDetector.addListener)(this.$el, this.__resizeHandler); } }, _initDataZoom: function _initDataZoom() { var _this4 = this; this.dataZoomHandler = (0, _debounce.default)(function () { _this4._dataZoomChanged(); }, 500, { leading: true }); }, getStringColor: function getStringColor(color) { if (color instanceof Object) { return ((color.colorStops || [])[0] || {}).color; } return color; }, setGradientColor: function setGradientColor(color, nextColor) { if (typeof color === 'string') { return new this.$options.graphic.LinearGradient(0, 0, 0, 1, [{ offset: 0, color: color }, { offset: 1, color: nextColor || color }]); } return color; }, _initAxisLabel: function _initAxisLabel(axisLabel, data, visualMap, series) { if (!this.xBar) { return; } var sortSeriesIndex = this.datasetOptions.findIndex(function (item) { return item.sort !== 'unsort' && item.rankLabel; }); if (sortSeriesIndex > -1 && axisLabel && data) { for (var index = 0, len = data.length, rankIndex = len - 1; index < len; index++, rankIndex--) { data[index] = rankIndex < 10 ? "0".concat(rankIndex).concat(data[index]) : "".concat(rankIndex).concat(data[index]); } var firstVisualMap = visualMap && visualMap.find(function (item) { return item.seriesIndex === sortSeriesIndex; }); axisLabel.rich = axisLabel.rich || {}; axisLabel.rich.default = { backgroundColor: this.getStringColor(this.colorGroup[sortSeriesIndex]), width: 20, height: 20, align: 'center', borderRadius: 2 }; firstVisualMap && firstVisualMap.pieces.map(function (item) { axisLabel.rich["".concat(parseInt(item.min), "_").concat(parseInt(item.max))] = { backgroundColor: item.color, width: 20, height: 20, align: 'center', borderRadius: 2 }; }); var serieData = series && series[sortSeriesIndex].data; axisLabel.formatter = function (label, index) { var orderNum = parseInt(label.slice(0, 2)) + 1; var leftLabel = label.slice(2); var labelValue = serieData && +serieData[index]; if (firstVisualMap) { var matchItem = firstVisualMap.pieces.find(function (item) { return labelValue >= item.min && labelValue <= item.max; }); if (matchItem) { return ["{".concat(parseInt(matchItem.min), "_").concat(parseInt(matchItem.max), "|").concat(orderNum, "} ").concat(leftLabel)].join('\n'); } } return ["{default|".concat(orderNum, "} ").concat(leftLabel)].join('\n'); }; } }, setItemStyleColor: function setItemStyleColor() { var _this5 = this; var isSet = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : true; var series = arguments.length > 1 ? arguments[1] : undefined; var highlightOptions = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : this.highlightOptions; var color = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : this.highlightColor; series = series || (0, _lodash4.default)(this.echartOptions && this.echartOptions.series) || []; series.forEach(function (serie, seriesIndex) { var dataIndexs = highlightOptions.map(function (item) { if (item.seriesIndex.includes(seriesIndex)) { return item.dataIndex; } }); var colors = highlightOptions.map(function (item) { if (item.seriesIndex.includes(seriesIndex)) { return item.color || color; } }); var serieColor = _this5.options.series && _this5.options.series[seriesIndex] && _this5.options.series[seriesIndex].itemStyle && _this5.options.series[seriesIndex].itemStyle.color; serie.itemStyle = serie.itemStyle || { color: '' }; serie.itemStyle.color = function (_ref) { var dataIndex = _ref.dataIndex; var index = dataIndexs.indexOf(dataIndex); if (index > -1) { return colors[index]; } else if (serie.type === 'pie') { var colorGroup = _this5._handlerColorGroup(serie.data.length); return colorGroup[dataIndex]; } else { return serieColor; } }; }); isSet && this.$set(this.echartOptions, 'series', series); }, _handlePieAutoPlay: function _handlePieAutoPlay() { var seriesType = this._chartOptions.series && this._chartOptions.series[0] && this._chartOptions.series[0].type; var echartsNode = this.smChart.chart; if (this._chartOptions.legend && this._chartOptions.legend.data && this._chartOptions.legend.data.length && echartsNode && seriesType === 'pie') { this.clearPieAutoPlay(echartsNode); if (this.autoPlay) { this.setPieAutoPlay(echartsNode); } } }, setPieAutoPlay: function setPieAutoPlay(echartsNode) { var _this6 = this; var i = -1; this.pieAutoPlay = setInterval(function () { echartsNode.dispatchAction({ type: 'downplay', seriesIndex: 0, dataIndex: i }); i++; if (i >= _this6._chartOptions.legend.data.length) { i = 0; } echartsNode.dispatchAction({ type: 'highlight', seriesIndex: 0, dataIndex: i }); }, 2000); }, clearPieAutoPlay: function clearPieAutoPlay(echartsNode) { clearInterval(this.pieAutoPlay); for (var i = 0; i < this._chartOptions.legend.data.length; i++) { echartsNode.dispatchAction({ type: 'downplay', seriesIndex: 0, dataIndex: i }); } }, timing: function timing() { var _this7 = this; this.echartsDataService && this.echartsDataService.getDataOption(this.dataset, this.xBar).then(function (options) { _this7.hideLoading(); // 缓存dataSeriesCache,请求后格式化成echart的数据 _this7.dataSeriesCache = Object.assign({}, options); _this7.datasetChange = false; // 设置echartOptions _this7.echartOptions = _this7._optionsHandler(_this7.options, options); }); }, // 请求数据,设置echartOptions _setEchartOptions: function _setEchartOptions(dataset, datasetOptions, echartOptions) { var _this8 = this; this.echartsDataService = null; this.dataSeriesCache = null; if (this.dataset.type !== 'geoJSON') { this.showLoading('default', { text: this.$t('info.loading'), color: this.colorGroupsData[0], textColor: this.textColorsData, maskColor: 'rgba(0,0,0,0.8)', zlevel: 0 }); } this.echartsDataService = new _EchartsDataService.default(dataset, datasetOptions); this.echartsDataService.getDataOption(dataset, this.xBar).then(function (options) { _this8.hideLoading(); // 缓存dataSeriesCache,请求后格式化成echart的数据 _this8.dataSeriesCache = Object.assign({}, options); _this8.datasetChange = false; // 设置echartOptions _this8.echartOptions = _this8._optionsHandler(echartOptions, options); }); }, _optionsHandler: function _optionsHandler(options, dataOptions, dataZoomChanged) { var _this9 = this; dataOptions = dataOptions && (0, _lodash4.default)(dataOptions); // clone 避免引起重复刷新 options = options && (0, _lodash4.default)(options); // clone 避免引起重复刷新 var extraSeries = []; if (options && options.legend && !options.legend.type) { options.legend.type = 'scroll'; } var yAxis = options.yAxis; var xAxis = options.xAxis; if (xAxis && dataOptions.xAxis) { var axis = xAxis; var axisData = dataOptions.xAxis[0]; var type = 'xAxis'; if (yAxis && yAxis.type === 'category') { // 处理条形图 type = 'yAxis'; axis = yAxis; dataOptions.yAxis = dataOptions.xAxis; delete dataOptions.xAxis; this._initAxisLabel(yAxis.axisLabel, dataOptions.yAxis[0].data, options.visualMap, dataOptions.series); } if (dataOptions.series.length === 0) { axis = [{}]; } else if (!Array.isArray(axis)) { if (axisData.data && axisData.data.length) { axis.data = []; } axis = [Object.assign({}, axisData, axis)]; } options[type] = axis; } if (options && options.series && dataOptions.series) { if (dataOptions.series.length === 0) { options.series = []; } else { options.series = options.series.map(function (element, index) { return Object.assign({}, element, dataOptions.series[index] || {}); }); var dataZoom = options.dataZoom && options.dataZoom[0]; options.series = options.series.map(function (serie, index) { var label = serie.label && serie.label.normal; if (serie.label) { serie.label.normal = _this9._controlLabel(label, serie.maxLabels); } if (label && label.show && label.smart) { label.position = label.position || 'top'; var data = serie.data; var startDataIndex = 0; var endDataIndex = data.length - 1; if (dataZoom && dataZoom.show !== false) { if (dataZoom.start > dataZoom.end) { var oldStart = dataZoom.start; dataZoom.start = dataZoom.end; dataZoom.end = oldStart; } if (dataZoomChanged) { var _ref2 = _this9.smChart.chart.getOption().dataZoom[0] || {}, startValue = _ref2.startValue, endValue = _ref2.endValue; startDataIndex = startValue; endDataIndex = endValue; options.dataZoom = options.dataZoom.map(function (val) { if (startValue >= 0 && endValue >= 0) { val.startValue = startValue; val.endValue = endValue; delete val.start; delete val.end; return val; } return val; }); } else { startDataIndex = Math.floor(dataZoom.start / 100 * data.length); endDataIndex = Math.ceil(dataZoom.end / 100 * data.length); } data = serie.data.slice(startDataIndex, endDataIndex + 1); } label.formatter = function (_ref3) { var dataIndex = _ref3.dataIndex, value = _ref3.value; var result = ''; if (dataIndex === startDataIndex || dataIndex === endDataIndex || Math.max.apply(null, data) + '' === value + '') { result = value; } return result; }; } else if (serie && serie.type !== 'pie' && serie.type !== 'radar') { var colorGroup = (0, _chart.getMultiColorGroup)(_this9.colorGroupsData, _this9.colorNumber); if (serie.type === '2.5Bar') { var shape = serie.shape; var defaultColor = serie.itemStyle && serie.itemStyle.color; if (['square', 'rectangle'].includes(shape)) { var cubeType = shape; serie.type = 'custom'; dataOptions.series[index] && (dataOptions.series[index].type = 'custom'); var _this = _this9; serie.renderItem = function (params, api) { var location = api.coord([api.value(0), api.value(1)]); var fillColor = defaultColor || colorGroup[params.seriesIndex]; if (_this.highlightOptions) { var matchData = _this.highlightOptions.find(function (item) { return item.seriesIndex.includes(params.seriesIndex) && item.dataIndex === params.dataIndex; }); if (matchData && (matchData.color || _this.highlightColor)) { fillColor = matchData.color || _this.highlightColor; } } var leftColor, rightColor, topColor; if ((0, _typeof2.default)(fillColor) === 'object') { var copyLeftColor = (0, _lodash4.default)(fillColor); var copyRightColor = (0, _lodash4.default)(fillColor); var copyTopColor = (0, _lodash4.default)(fillColor); copyLeftColor.colorStops[0].color = (0, _util.getColorWithOpacity)(copyLeftColor.colorStops[0].color, 0.4); copyLeftColor.colorStops[1].color = (0, _util.getColorWithOpacity)(copyLeftColor.colorStops[1].color, 0.4); copyRightColor.colorStops[0].color = (0, _util.getColorWithOpacity)(copyRightColor.colorStops[0].color, 0.7); copyRightColor.colorStops[1].color = (0, _util.getColorWithOpacity)(copyRightColor.colorStops[1].color, 0.7); copyTopColor.colorStops[0].color = (0, _util.getColorWithOpacity)(copyTopColor.colorStops[0].color, 0.85); copyTopColor.colorStops[1].color = (0, _util.getColorWithOpacity)(copyTopColor.colorStops[1].color, 0.85); leftColor = copyLeftColor; rightColor = copyRightColor; topColor = copyTopColor; } else { leftColor = (0, _util.getColorWithOpacity)(fillColor, 0.4); rightColor = (0, _util.getColorWithOpacity)(fillColor, 0.7); topColor = (0, _util.getColorWithOpacity)(fillColor, 0.85); } return { type: 'group', children: [{ type: "Cube".concat(cubeType, "Left"), shape: { api: api, xValue: api.value(0), yValue: api.value(1), x: location[0], y: location[1], xAxisPoint: api.coord([api.value(0), 0]) }, style: { fill: leftColor } }, { type: "Cube".concat(cubeType, "Right"), shape: { api: api, xValue: api.value(0), yValue: api.value(1), x: location[0], y: location[1], xAxisPoint: api.coord([api.value(0), 0]) }, style: { fill: rightColor } }, { type: "Cube".concat(cubeType, "Top"), shape: { api: api, xValue: api.value(0), yValue: api.value(1), x: location[0], y: location[1], xAxisPoint: api.coord([api.value(0), 0]) }, style: { fill: topColor } }] }; }; } else if (shape === 'cylinder') { var baseWidth = '100%'; var nextSerieDatas = dataOptions.series[index + 1] && dataOptions.series[index + 1].data; serie.type = 'bar'; serie.barGap = '-100%'; options.tooltip.trigger === 'axis' && (options.tooltip.trigger = 'item'); dataOptions.series[index] && (dataOptions.series[index].type = 'bar'); var cirCleColor = defaultColor || colorGroup[index]; if (typeof cirCleColor === 'string') { cirCleColor = _this9.setGradientColor(cirCleColor, '#fff'); } extraSeries.push( // 头部的圆片 { name: '', type: 'pictorialBar', symbolOffset: [0, -8], symbolPosition: 'end', z: 12, itemStyle: { normal: { color: cirCleColor } }, data: dataOptions.series[index].data.map(function (item, dataIndex) { return { value: item, symbolSize: !nextSerieDatas || nextSerieDatas[dataIndex] && +item >= +nextSerieDatas[dataIndex] ? [baseWidth, 15] : [0, 15] }; }) }, { // 底部的圆片 name: '', type: 'pictorialBar', symbolSize: [baseWidth, 10], symbolOffset: [0, 5], z: 12, itemStyle: { normal: { color: cirCleColor } }, data: dataOptions.series[index].data }); } delete serie.shape; } } return serie; }); // 玫瑰图多个选中 if (options.series[0].type === 'pie' && options.series[0].roseType) { options.series = options.series.map(function (serie) { if (!serie.roseType) { serie.roseType = options.series[0].roseType; } return serie; }); } // pie的图例需要一个扇形是一个图例 if (options.legend && options.series.length > 0 && options.series[0].type === 'pie') { options.legend.data = []; options.series.forEach(function (element) { if (element.data) { var _options$legend$data; (_options$legend$data = options.legend.data).push.apply(_options$legend$data, (0, _toConsumableArray2.default)(element.data.map(function (item) { return item.name; }))); } }); } } } if (options && options.radar && dataOptions.radar) { options.radar.indicator = Object.assign({}, dataOptions.radar.indicator || {}); } var series = dataOptions.series; if (series && series.length && series[0].type === 'pie') { this.setItemStyleColor(false, series); } if (this.highlightOptions && this.highlightOptions.length > 0) { this.setItemStyleColor(true, series); } dataOptions.series = this._createRingShineSeries(series, options.series); var mergeOptions = (0, _lodash2.default)(options, dataOptions); if (extraSeries.length > 0) { var _mergeOptions$series; (_mergeOptions$series = mergeOptions.series).push.apply(_mergeOptions$series, extraSeries); } return mergeOptions; }, _createRingShineSeries: function _createRingShineSeries(series, optionsSeries) { var _this10 = this; if (optionsSeries) { this.datasetOptions.forEach(function (datasetOption, index) { var _ref4 = optionsSeries[index] || {}, type = _ref4.type, outerGap = _ref4.outerGap, isShine = _ref4.isShine; if (type === 'pie' && outerGap >= 0) { var data = series[index].data.map(function (val) { return val.value; }); outerGap = outerGap || Math.min.apply(null, data) / 5; series[index].data = _this10._createRingShineDataOption(series[index].data, outerGap, isShine); delete optionsSeries[index].outerGap; delete optionsSeries[index].isShine; } }); } return series; }, _createRingShineDataOption: function _createRingShineDataOption(data, outerGap, isShine) { if (!data) { return; } var colors = this._handlerColorGroup(data.length); var gapItem = { value: outerGap, name: '', itemStyle: { normal: { label: { show: false }, labelLine: { show: false }, color: 'rgba(0, 0, 0, 0)', borderColor: 'rgba(0, 0, 0, 0)', borderWidth: 0 } } }; var result = []; for (var i = 0; i < data.length; i++) { var dataItem = { value: data[i].value, name: data[i].name }; if (isShine) { dataItem.itemStyle = { normal: { borderWidth: 5, shadowBlur: 10, color: colors[i], borderColor: colors[i], shadowColor: colors[i] } }; } result.push(dataItem); if (data.length > 1) { result.push(gapItem); } } return result; }, _handlerColorGroup: function _handlerColorGroup(serielDataLength) { if ((0, _typeof2.default)(this.colorGroupsData[0]) === 'object') { return (0, _chart.handleMultiGradient)(this.colorGroupsData, serielDataLength); } else { return SuperMap.ColorsPickerUtil.getGradientColors(this.colorGroupsData, serielDataLength, 'RANGE'); } }, // 控制label显示条数 _controlLabel: function _controlLabel(normalLabel, maxLabels) { if (normalLabel && normalLabel.show && maxLabels) { var endNormalLabel = (0, _lodash4.default)(normalLabel); var formatMode; if (endNormalLabel.formatter && typeof endNormalLabel.formatter === 'string') { formatMode = endNormalLabel.formatter; } endNormalLabel.formatter = function (_ref5) { var dataIndex = _ref5.dataIndex, value = _ref5.value, name = _ref5.name, percent = _ref5.percent; var FORMATTER_MAP = { '{b}: {c}': "".concat(name, ": ").concat(value), '{b}': "".concat(name), '{c}': "".concat(value), '{d}%': "".concat(percent, "%") }; var result = ''; if (dataIndex < maxLabels) { result = FORMATTER_MAP[formatMode || '{c}']; } return result; }; return endNormalLabel; } return normalLabel; }, // 当datasetUrl不变,datasetOptions改变时 _changeChartData: function _changeChartData(echartsDataService, datasetOptions, echartOptions) { var options; options = echartsDataService.formatChartData(datasetOptions, this.xBar); // 缓存dataSeriesCache,格式化成echart的数据 this.dataSeriesCache = Object.assign({}, options); // 设置echartOptions this.echartOptions = this._optionsHandler(echartOptions, options); }, _setChartTheme: function _setChartTheme() { if (!this.theme) { var colorNumber = this.colorNumber; this.chartTheme = (0, _chart.chartThemeUtil)(this.backgroundData, this.textColorsData, this.colorGroupsData, colorNumber); } }, // 获取echart实例 _getEchart: function _getEchart() { return this.smChart; }, // 以下全是同名调用echart的方法 /** * 提供了一个更贴切的名称来描述 setOption 方法的实际行为。 * @param {Object} options - 图表的配置项和数据 * @param {Boolean} [notMerge = false] - 可选,是否不跟之前设置的 option 进行合并,默认为 false,即合并 * @param {Boolean} [lazyUpdate = false] - 可选,阻止调用 setOption 时抛出事件,默认为 false,即抛出事件 */ mergeOptions: function mergeOptions(options, notMerge, lazyUpdate) { this._delegateMethod('mergeOptions', options, notMerge, lazyUpdate); }, /** * 此接口用于,在大数据量(百万以上)的渲染场景,分片加载数据和增量渲染。 * @param {Object} params - 数据配置 */ appendData: function appendData(params) { this._delegateMethod('appendData', params); }, /** * 此接口用于,改变图表尺寸,在容器大小发生改变时需要手动调用。 * @param {Object} [options] - options可缺省。有下面几个可选项:width, height, silent */ resize: function resize(options) { this._delegateMethod('resize', options); }, /** * 此接口用于,触发图表行为。 * @param {Object} payload - 参数可以通过batch属性同时触发多个行为。 */ dispatchAction: function dispatchAction(payload) { this._delegateMethod('dispatchAction', payload); }, /** * 此接口用于,转换坐标系上的点到像素坐标值。 * @param {Object} finder - 用于指示『在哪个坐标系或者系列上判断』。 * @param {Array|string} value - 要被转换的值。 */ convertToPixel: function convertToPixel(finder, value) { return this._delegateMethod('convertToPixel', finder, value); }, /** * 此接口用于,转换像素坐标值到逻辑坐标系上的点。是 convertToPixel 的逆运算。 * @param {Object} finder - 用于指示『在哪个坐标系或者系列上判断』。 * @param {Array|string} value - 要被转换的值。 */ convertFromPixel: function convertFromPixel(finder, value) { return this._delegateMethod('convertFromPixel', finder, value); }, /** * 此接口用于,判断给定的点是否在指定的坐标系或者系列上。 * @param {Object} finder - 用于指示『在哪个坐标系或者系列上判断』。 * @param {Array} value - 要被判断的点。 */ containPixel: function containPixel(finder, value) { return this._delegateMethod('containPixel', finder, value); }, /** * 此接口用于,显示加载动画效果。可以在加载数据前手动调用该接口显示加载动画,在数据加载完成后调用 hideLoading 隐藏加载动画。 * @param {Object} [type] - 可选,加载动画类型,目前只有一种'default'。 * @param {Object} [options] - 可选,加载动画配置项,跟type有关。 */ showLoading: function showLoading(type, options) { this._delegateMethod('showLoading', type, options); }, /** * 此接口用于,隐藏动画加载效果。 */ hideLoading: function hideLoading() { this._delegateMethod('hideLoading'); }, /** * 此接口用于,导出图表图片,返回一个 base64 的 URL,可以设置为Image的src。 * @param {Object} options - 导出配置 */ getDataURL: function getDataURL(options) { return this._delegateMethod('getDataURL', options); }, /** * 此接口用于,导出联动的图表图片,返回一个 base64 的 url,可以设置为Image的src。导出图片中每个图表的相对位置跟容器的相对位置有关。 * @param {Object} options - 导出配置 */ getConnectedDataURL: function getConnectedDataURL(options) { return this._delegateMethod('getConnectedDataURL', options); }, /** * 此接口用于,清空当前实例,会移除实例中所有的组件和图表。清空后调用 getOption 方法返回一个{}空对象。 */ clear: function clear() { this._delegateMethod('clear'); }, /** * 此接口用于,销毁实例,销毁后实例无法再被使用。 */ dispose: function dispose() { this._delegateMethod('dispose'); }, // 内部调用的方法 _delegateMethod: function _delegateMethod(name) { var _this$smChart; for (var _len = arguments.length, args = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) { args[_key - 1] = arguments[_key]; } return (_this$smChart = this.smChart)[name].apply(_this$smChart, args); }, unSupportedFeatureTip: function unSupportedFeatureTip() { this.$message.destroy(); this.$message.warning(this.$t('chart.unSupportedData')); }, handleChartClick: function handleChartClick(params) { if (this.associatedMap) { var dataIndex = params.dataIndex; var features = []; if (this.echartsDataService && this.echartsDataService.sortDataCache) { features = this.echartsDataService.sortDataCache.features || features; } var selectedFeature = features[dataIndex]; this.showDetailInfo(selectedFeature); } }, showDetailInfo: function showDetailInfo(feature) { var _this11 = this; var coordinates = ((feature || {}).geometry || {}).coordinates; var hasCoordinates = coordinates && !!coordinates.length; if (hasCoordinates && this.viewModel) { var properties = feature.properties || {}; var _coordinates = (0, _util.getFeatureCenter)(feature); var propsData = this.generateTableData(properties); this.tablePopupProps = _objectSpread({}, propsData); this.$nextTick(function () { _this11.viewModel.setPopupContent(_coordinates, _this11.$refs.chartTablePopup.$el, _this11.changePopupArrowStyle); }); } else { var mapNotLoaded = this.mapNotLoadedTip(); if (mapNotLoaded) { return; } if (!hasCoordinates) { this.unSupportedFeatureTip(); } } }, generateTableData: function generateTableData(properties) { var propsData = { columns: [{ title: this.$t('search.attribute'), dataIndex: 'attribute', width: 120 }, { title: this.$t('search.attributeValue'), dataIndex: 'attributeValue', width: 150 }], data: [] }; for (var key in properties) { if (key && properties[key]) { var dataItem = {}; dataItem.attribute = key; dataItem.attributeValue = properties[key]; propsData.data.push(dataItem); } } return propsData; }, changePopupArrowStyle: function changePopupArrowStyle() {}, mapNotLoadedTip: function mapNotLoadedTip() {}, _dataZoomChanged: function _dataZoomChanged() { var flag = false; this.options.series && this.options.series.forEach(function (serie, index) { var labelConfig = serie.label && serie.label.normal; flag = labelConfig.show && labelConfig.smart; }); if (flag) { this.echartOptions = this._optionsHandler(this.options, this.dataSeriesCache, true); } }, registerShape: function registerShape() { var _this12 = this; this.datasetOptions && this.options.series && this.datasetOptions.forEach(function (item, index) { var graphicIntance = _this12.$options.graphic; if (item.seriesType === '2.5Bar') { var cubeType = _this12.options.series[index].shape; if (graphicIntance.getShapeClass("Cube".concat(cubeType, "Left"))) { return; } var CubeLeft, CubeRight, CubeTop; switch (cubeType) { case 'square': // 绘制左侧面 CubeLeft = graphicIntance.extendShape({ shape: { x: 0, y: 0 }, buildPath: function buildPath(ctx, shape) { // 会canvas的应该都能看得懂,shape是从custom传入的 var xAxisPoint = shape.xAxisPoint; var c0 = [shape.x, shape.y]; var c1 = [shape.x - 13, shape.y - 13]; var c2 = [xAxisPoint[0] - 13, xAxisPoint[1] - 13]; var c3 = [xAxisPoint[0], xAxisPoint[1]]; ctx.moveTo(c0[0], c0[1]).lineTo(c1[0], c1[1]).lineTo(c2[0], c2[1]).lineTo(c3[0], c3[1]).closePath(); } }); // 绘制右侧面 CubeRight = graphicIntance.extendShape({ shape: { x: 0, y: 0 }, buildPath: function buildPath(ctx, shape) { var xAxisPoint = shape.xAxisPoint; var c1 = [shape.x, shape.y]; var c2 = [xAxisPoint[0], xAxisPoint[1]]; var c3 = [xAxisPoint[0] + 18, xAxisPoint[1] - 9]; var c4 = [shape.x + 18, shape.y - 9]; ctx.moveTo(c1[0], c1[1]).lineTo(c2[0], c2[1]).lineTo(c3[0], c3[1]).lineTo(c4[0], c4[1]).closePath(); } }); // 绘制顶面 CubeTop = graphicIntance.extendShape({ shape: { x: 0, y: 0 }, buildPath: function buildPath(ctx, shape) { var c1 = [shape.x, shape.y]; var c2 = [shape.x + 18, shape.y - 9]; var c3 = [shape.x + 5, shape.y - 22]; var c4 = [shape.x - 13, shape.y - 13]; ctx.moveTo(c1[0], c1[1]).lineTo(c2[0], c2[1]).lineTo(c3[0], c3[1]).lineTo(c4[0], c4[1]).closePath(); } }); break; case 'rectangle': // 绘制左侧面 CubeLeft = graphicIntance.extendShape({ shape: { x: 0, y: 0 }, buildPath: function buildPath(ctx, shape) { var xAxisPoint = shape.xAxisPoint; var c0 = [shape.x, shape.y]; var c1 = [shape.x - 9, shape.y - 9]; var c2 = [xAxisPoint[0] - 9, xAxisPoint[1] - 9]; var c3 = [xAxisPoint[0], xAxisPoint[1]]; ctx.moveTo(c0[0], c0[1]).lineTo(c1[0], c1[1]).lineTo(c2[0], c2[1]).lineTo(c3[0], c3[1]).closePath(); } }); CubeRight = graphicIntance.extendShape({ shape: { x: 0, y: 0 }, buildPath: function buildPath(ctx, shape) { var xAxisPoint = shape.xAxisPoint; var c1 = [shape.x, shape.y]; var c2 = [xAxisPoint[0], xAxisPoint[1]]; var c3 = [xAxisPoint[0] + 18, xAxisPoint[1] - 9]; var c4 = [shape.x + 18, shape.y - 9]; ctx.moveTo(c1[0], c1[1]).lineTo(c2[0], c2[1]).lineTo(c3[0], c3[1]).lineTo(c4[0], c4[1]).closePath(); } }); CubeTop = graphicIntance.extendShape({ shape: { x: 0, y: 0 }, buildPath: function buildPath(ctx, shape) { var c1 = [shape.x, shape.y]; var c2 = [shape.x + 18, shape.y - 9]; var c3 = [shape.x + 9, shape.y - 18]; var c4 = [shape.x - 9, shape.y - 9]; ctx.moveTo(c1[0], c1[1]).lineTo(c2[0], c2[1]).lineTo(c3[0], c3[1]).lineTo(c4[0], c4[1]).closePath(); } }); break; } CubeLeft && graphicIntance.registerShape("Cube".concat(cubeType, "Left"), CubeLeft); CubeRight && graphicIntance.registerShape("Cube".concat(cubeType, "Right"), CubeRight); CubeTop && graphicIntance.registerShape("Cube".concat(cubeType, "Top"), CubeTop); } }); }, getCirlPoint: function getCirlPoint(x0, y0, r, angle) { var x1 = x0 + r * Math.cos(angle * Math.PI / 180); var y1 = y0 + r * Math.sin(angle * Math.PI / 180); return { x: x1, y: y1 }; }, spinLine: function spinLine(startAngle, endAngle, angle, effectColor, radius) { return function (params, api) { return { type: 'arc', shape: { cx: api.getWidth() / 2, cy: api.getHeight() / 2, r: Math.min(api.getWidth(), api.getHeight()) / 2 * radius, startAngle: (startAngle + angle) * Math.PI / 180, endAngle: (endAngle + angle) * Math.PI / 180 }, style: { stroke: effectColor, fill: 'transparent', lineWidth: 1.5 }, silent: true }; }; }, spinPoint: function spinPoint(angle, spinAngle, effectColor, radius) { var _this13 = this; return function (params, api) { var x0 = api.getWidth() / 2; var y0 = api.getHeight() / 2; var r = Math.min(api.getWidth(), api.getHeight()) / 2 * radius; var point = _this13.getCirlPoint(x0, y0, r, angle + spinAngle); return { type: 'circle', shape: { cx: point.x, cy: point.y, r: 4 }, style: { stroke: effectColor, fill: effectColor }, silent: true }; }; }, customRingsLine: function customRingsLine(startAngle, endAngle, angle, effectColor, effectRadius) { var series = { name: 'ring0', type: 'custom', coordinateSystem: 'none', renderItem: null, data: [0] }; series.renderItem = this.spinLine(startAngle, endAngle, angle, effectColor, effectRadius); return series; }, customRingsPoint: function customRingsPoint(startAngle, angle, effectColor, outEffectRadius) { var series = { name: 'ring4', type: 'custom', coordinateSystem: 'none', renderItem: null, data: [0] }; series.renderItem = this.spinPoint(startAngle, angle, effectColor, outEffectRadius); return series; }, addEffect: function addEffect(angle) { angle = angle || 0; var effectColor = this.options.series[0].customOptions.color; var effectRadius = this.options.series[0].customOptions.radius; var outEffectRadius = effectRadius + 0.1; // customRightBottomLine this.customSeries.push(this.customRingsLine(0, 90, angle, effectColor, effectRadius)); // customRightTopLine this.customSeries.push(this.customRingsLine(270, 40, -angle, effectColor, outEffectRadius)); // customLeftTopLine this.customSeries.push(this.customRingsLine(180, 270, angle, effectColor, effectRadius)); // customLeftBottomLine this.customSeries.push(this.customRingsLine(90, 220, -angle, effectColor, outEffectRadius)); if (this.options.series[0].customOptions.pointState === 'startPoint') { this.customSeries.push(this.customRingsPoint(270, -angle, effectColor, outEffectRadius)); this.customSeries.push(this.customRingsPoint(90, -angle, effectColor, outEffectRadius)); } }, startEffect: function startEffect() { var _this14 = this; var angle = 0; this.startSpin = setInterval(function () { if (!_this14.options.series) { return; } if (_this14.options.series[0].customType === 'customRingsSeries') { _this14.customSeries = []; angle += 3; _this14.addEffect(angle); } }, 100); }, customRenderItem: function customRenderItem() {} }, // echarts所有静态方法 /** * @function connect * 多个图表实例实现联动。 * @param {string|Array} group - group的id,或者图表实例的数组。 */ connect: function connect(group) { _vueEcharts.default && _vueEcharts.default.connect(group); }, /** * 解除图表实例的联动,如果只需要移除单个实例,可以将通过将该图表实例 group 设为空。 * @param {string} group - group的id。 */ disconnect: function disconnect(group) { _vueEcharts.default && _vueEcharts.default.disConnect(group); }, /** * 注册可用的地图,必须在包括 geo 组件或者 map 图表类型的时候才能使用。 * @param {string} mapName - 地图名称,在 geo 组件或者 map 图表类型中设置的 map 对应的就是该值。 * @param {Object} geoJSON - GeoJson 格式的数据,具体格式见 http://geojson.org/。 * @param {Object} [specialAreas] - 可选。将地图中的部分区域缩放到合适的位置,可以使得整个地图的显示更加好看。 */ registerMap: function registerMap(mapName, geoJSON, specialAreas) { _vueEcharts.default && _vueEcharts.default.registerMap(mapName, geoJSON, specialAreas); }, /** * 注册主题,用于初始化实例的时候指定。 * @param {string} name - 主题命名。 * @param {Object} theme - 主题配置。 */ registerTheme: function registerTheme(name, theme) { _vueEcharts.default && _vueEcharts.default.registerTheme(name, theme); }, /** * @desc 图形相关帮助方法。 */ graphic: _vueEcharts.default && _vueEcharts.default.graphic }; exports.default = _default2; /***/ }), /***/ "0fd2": /***/ (function(module, exports, __webpack_require__) { "use strict"; var _interopRequireDefault = __webpack_require__("8e6d"); Object.defineProperty(exports, "__esModule", { value: true }); exports.default = void 0; var _classCallCheck2 = _interopRequireDefault(__webpack_require__("19e1")); var _createClass2 = _interopRequireDefault(__webpack_require__("66f6")); var _possibleConstructorReturn2 = _interopRequireDefault(__webpack_require__("8377")); var _getPrototypeOf2 = _interopRequireDefault(__webpack_require__("c031")); var _inherits2 = _interopRequireDefault(__webpack_require__("6b51")); var _typeof2 = _interopRequireDefault(__webpack_require__("7ae5")); var _WebMapViewModel = _interopRequireDefault(__webpack_require__("6e42")); var _mapEvent = _interopRequireDefault(__webpack_require__("d3e9")); var _vmUpdater = _interopRequireDefault(__webpack_require__("3a49")); var _mapEvents = _interopRequireDefault(__webpack_require__("9f21")); var _vuePropertyDecorator = __webpack_require__("e22c"); var _resizeDetector = __webpack_require__("e0f2"); var _debounce = _interopRequireDefault(__webpack_require__("331f")); var __decorate = void 0 && (void 0).__decorate || function (decorators, target, key, desc) { var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; if ((typeof Reflect === "undefined" ? "undefined" : (0, _typeof2.default)(Reflect)) === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);else for (var i = decorators.length - 1; i >= 0; i--) { if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; } return c > 3 && r && Object.defineProperty(target, key, r), r; }; var SmWebMap = /*#__PURE__*/ function (_Mixins) { (0, _inherits2.default)(SmWebMap, _Mixins); function SmWebMap() { var _this; (0, _classCallCheck2.default)(this, SmWebMap); _this = (0, _possibleConstructorReturn2.default)(this, (0, _getPrototypeOf2.default)(SmWebMap).apply(this, arguments)); _this.spinning = true; return _this; } (0, _createClass2.default)(SmWebMap, [{ key: "mapIdChanged", value: function mapIdChanged() { if (this.defaultLoading) { this.spinning = true; } } }, { key: "loadingChanged", value: function loadingChanged(newVal) { this.spinning = newVal; } }, { key: "created", value: function created() { if (!this.defaultLoading) { this.spinning = false; } } }, { key: "mounted", value: function mounted() { this.initializeWebMap(); this.registerEvents(); } }, { key: "beforeDestroy", value: function beforeDestroy() { this.destory(); } }, { key: "destroyed", value: function destroyed() { _mapEvent.default.$options.deleteMap(this.target); _mapEvent.default.$options.deleteWebMap(this.target); this.viewModel.cleanWebMap(); } }, { key: "load", value: function load(value) { return value; } }, { key: "getMapFailed", value: function getMapFailed(value) { return value; } }, { key: "getLayerDatasourceFailed", value: function getLayerDatasourceFailed(value) { return value; } }, { key: "initializeWebMap", value: function initializeWebMap() { var _this2 = this; var _this$$props = this.$props, target = _this$$props.target, serverUrl = _this$$props.serverUrl, accessToken = _this$$props.accessToken, accessKey = _this$$props.accessKey, tiandituKey = _this$$props.tiandituKey, withCredentials = _this$$props.withCredentials, excludePortalProxyUrl = _this$$props.excludePortalProxyUrl, isSuperMapOnline = _this$$props.isSuperMapOnline, proxy = _this$$props.proxy, mapOptions = _this$$props.mapOptions, iportalServiceProxyUrlPrefix = _this$$props.iportalServiceProxyUrlPrefix; this.viewModel = new _WebMapViewModel.default(this.mapId, { target: target, serverUrl: serverUrl, accessToken: accessToken, accessKey: accessKey, tiandituKey: tiandituKey, withCredentials: withCredentials, excludePortalProxyUrl: excludePortalProxyUrl, isSuperMapOnline: isSuperMapOnline, proxy: proxy, iportalServiceProxyUrlPrefix: iportalServiceProxyUrlPrefix }, mapOptions); if (this.autoresize) { this.__resizeHandler = (0, _debounce.default)(function () { _this2.resize(); }, 100, { leading: true }); (0, _resizeDetector.addListener)(this.$el, this.__resizeHandler); } } }, { key: "resize", value: function resize() { if (this.viewModel && this.viewModel.resize) { this.viewModel.resize(this.keepBounds); } } }, { key: "registerEvents", value: function registerEvents() { var _this3 = this; this.viewModel.on({ addlayerssucceeded: function addlayerssucceeded(e) { _this3.spinning = false; _mapEvent.default.$options.setMap(_this3.target, e.map); _this3.viewModel && _mapEvent.default.$options.setWebMap(_this3.target, _this3.viewModel); _mapEvent.default.$emit('load-map', e.map, _this3.target); e.map.resize(); _this3.map = e.map; _this3.bindMapEvents(); _this3.load({ map: e.map }); }, getmapinfofailed: function getmapinfofailed(e) { _this3.getMapFailed({ error: e.error }); _this3.$message.error(e.error.message); _this3.spinning = false; }, getlayerdatasourcefailed: function getlayerdatasourcefailed(e) { _this3.getLayerDatasourceFailed({ error: e.error, layer: e.layer, map: e.map }); if (e.error === 'SAMPLE DATA is not supported') { _this3.$message.error(_this3.$t('webmap.sampleDataNotSupport')); } else { _this3.$message.error(_this3.$t('webmap.getLayerInfoFailed')); } }, notsupportbaidumap: function notsupportbaidumap() { _this3.$message.error(_this3.$t('webmap.baiduMapNotSupport')); }, beforeremovemap: function beforeremovemap() { _mapEvent.default.$options.deleteMap(_this3.target); _mapEvent.default.$options.deleteWebMap(_this3.target); } }); } }, { key: "destory", value: function destory() { if (this.autoresize) { (0, _resizeDetector.removeListener)(this.$el, this.__resizeHandler); } } }, { key: "getMapTarget", get: function get() { return this.target; } }, { key: "controlComponents", get: function get() { var controls = {}; for (var key in this.$props) { if (key.includes('Control') && this.$props[key].show) { var controlName = key.replace('Control', ''); var firstLetter = controlName[0]; controls["Sm".concat(controlName.replace(firstLetter, firstLetter.toUpperCase()))] = this.$props[key]; } } return controls; } }]); return SmWebMap; }((0, _vuePropertyDecorator.Mixins)(_vmUpdater.default, _mapEvents.default)); __decorate([(0, _vuePropertyDecorator.Provide)()], SmWebMap.prototype, "__resizeHandler", void 0); __decorate([(0, _vuePropertyDecorator.Prop)()], SmWebMap.prototype, "mapId", void 0); __decorate([(0, _vuePropertyDecorator.Prop)({ default: 'map' })], SmWebMap.prototype, "target", void 0); __decorate([(0, _vuePropertyDecorator.Prop)({ default: 'https://www.supermapol.com' })], SmWebMap.prototype, "serverUrl", void 0); __decorate([(0, _vuePropertyDecorator.Prop)()], SmWebMap.prototype, "accessToken", void 0); __decorate([(0, _vuePropertyDecorator.Prop)()], SmWebMap.prototype, "accessKey", void 0); __decorate([(0, _vuePropertyDecorator.Prop)()], SmWebMap.prototype, "tiandituKey", void 0); __decorate([(0, _vuePropertyDecorator.Prop)({ default: false })], SmWebMap.prototype, "withCredentials", void 0); __decorate([(0, _vuePropertyDecorator.Prop)()], SmWebMap.prototype, "excludePortalProxyUrl", void 0); __decorate([(0, _vuePropertyDecorator.Prop)()], SmWebMap.prototype, "isSuperMapOnline", void 0); __decorate([(0, _vuePropertyDecorator.Prop)()], SmWebMap.prototype, "proxy", void 0); __decorate([(0, _vuePropertyDecorator.Prop)({ default: true })], SmWebMap.prototype, "defaultLoading", void 0); __decorate([(0, _vuePropertyDecorator.Prop)({ default: false })], SmWebMap.prototype, "loading", void 0); __decorate([(0, _vuePropertyDecorator.Prop)()], SmWebMap.prototype, "background", void 0); __decorate([(0, _vuePropertyDecorator.Prop)()], SmWebMap.prototype, "iportalServiceProxyUrlPrefix", void 0); __decorate([(0, _vuePropertyDecorator.Prop)()], SmWebMap.prototype, "mapOptions", void 0); __decorate([(0, _vuePropertyDecorator.Prop)({ default: true })], SmWebMap.prototype, "autoresize", void 0); __decorate([(0, _vuePropertyDecorator.Prop)({ default: false })], SmWebMap.prototype, "keepBounds", void 0); __decorate([(0, _vuePropertyDecorator.Prop)({ default: function _default() { return { show: false, position: 'top-left' }; } })], SmWebMap.prototype, "panControl", void 0); __decorate([(0, _vuePropertyDecorator.Prop)({ default: function _default() { return { show: false, position: 'bottom-left' }; } })], SmWebMap.prototype, "scaleControl", void 0); __decorate([(0, _vuePropertyDecorator.Prop)({ default: function _default() { return { show: false, position: 'top-left' }; } })], SmWebMap.prototype, "zoomControl", void 0); __decorate([(0, _vuePropertyDecorator.Prop)({ default: function _default() { return { show: false, position: 'bottom-right' }; } })], SmWebMap.prototype, "miniMapControl", void 0); __decorate([(0, _vuePropertyDecorator.Prop)({ default: function _default() { return { show: false, position: 'top-right' }; } })], SmWebMap.prototype, "layerListControl", void 0); __decorate([(0, _vuePropertyDecorator.Prop)({ default: function _default() { return { show: false, position: 'top-right', showUnitSelect: true, distanceDefaultUnit: 'kilometers', areaDefaultUnit: 'kilometers' }; } })], SmWebMap.prototype, "measureControl", void 0); __decorate([(0, _vuePropertyDecorator.Prop)({ default: function _default() { return { show: false, position: 'bottom-left', layerNames: [], isShowTitle: false, isShowField: false, mode: 'simple' }; } })], SmWebMap.prototype, "legendControl", void 0); __decorate([(0, _vuePropertyDecorator.Prop)({ default: function _default() { return { show: false, position: 'top-right' }; } })], SmWebMap.prototype, "queryControl", void 0); __decorate([(0, _vuePropertyDecorator.Prop)({ default: function _default() { return { show: false, position: 'top-right' }; } })], SmWebMap.prototype, "searchControl", void 0); __decorate([(0, _vuePropertyDecorator.Prop)({ default: function _default() { return { show: false, layers: [], fields: [], layerStyle: {}, clickAreaAround: 5 }; } })], SmWebMap.prototype, "identifyControl", void 0); __decorate([(0, _vuePropertyDecorator.Prop)({ default: function _default() { return { show: false, layers: [] }; } })], SmWebMap.prototype, "layerManagerControl", void 0); __decorate([(0, _vuePropertyDecorator.Watch)('mapId')], SmWebMap.prototype, "mapIdChanged", null); __decorate([(0, _vuePropertyDecorator.Watch)('loading')], SmWebMap.prototype, "loadingChanged", null); __decorate([(0, _vuePropertyDecorator.Emit)()], SmWebMap.prototype, "load", null); __decorate([(0, _vuePropertyDecorator.Emit)()], SmWebMap.prototype, "getMapFailed", null); __decorate([(0, _vuePropertyDecorator.Emit)()], SmWebMap.prototype, "getLayerDatasourceFailed", null); SmWebMap = __decorate([(0, _vuePropertyDecorator.Component)({ name: 'SmWebMap', viewModelProps: ['mapId', 'serverUrl', 'mapOptions.center', 'mapOptions.zoom', 'mapOptions.style', 'mapOptions.crs', 'mapOptions.minZoom', 'mapOptions.maxZoom', 'mapOptions.maxBounds', 'mapOptions.renderWorldCopies', 'mapOptions.bearing', 'mapOptions.pitch', 'mapOptions.rasterTileSize', 'withCredentials', 'proxy'] })], SmWebMap); var _default2 = SmWebMap; exports.default = _default2; /***/ }), /***/ 1: /***/ (function(module, exports) { /* (ignored) */ /***/ }), /***/ "10ba": /***/ (function(module, exports, __webpack_require__) { "use strict"; var _interopRequireDefault = __webpack_require__("8e6d"); Object.defineProperty(exports, "__esModule", { value: true }); exports.default = void 0; var _theme = _interopRequireDefault(__webpack_require__("9259")); var _util = __webpack_require__("1448"); // // // // // // // // // // // // // var _default2 = { name: 'SmTablePopup', mixins: [_theme.default], props: { data: { type: Array, default: function _default() { return []; } }, columns: { type: Array, default: function _default() { return []; } } }, computed: { styleObject: function styleObject() { return { '--table-popup-active-color--text': this.colorGroupsData[0] }; }, backgroundStyle: function backgroundStyle() { return { background: this.backgroundData ? (0, _util.getColorWithOpacity)(this.backgroundData, 0.5) : this.backgroundData }; } } }; exports.default = _default2; /***/ }), /***/ "10d6": /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); /* harmony import */ var _node_modules_babel_loader_lib_index_js_node_modules_vue_loader_lib_index_js_vue_loader_options_VectorTileLayer_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__("ac9e"); /* harmony import */ var _node_modules_babel_loader_lib_index_js_node_modules_vue_loader_lib_index_js_vue_loader_options_VectorTileLayer_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_node_modules_babel_loader_lib_index_js_node_modules_vue_loader_lib_index_js_vue_loader_options_VectorTileLayer_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_0__); /* harmony reexport (unknown) */ for(var __WEBPACK_IMPORT_KEY__ in _node_modules_babel_loader_lib_index_js_node_modules_vue_loader_lib_index_js_vue_loader_options_VectorTileLayer_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_0__) if(__WEBPACK_IMPORT_KEY__ !== 'default') (function(key) { __webpack_require__.d(__webpack_exports__, key, function() { return _node_modules_babel_loader_lib_index_js_node_modules_vue_loader_lib_index_js_vue_loader_options_VectorTileLayer_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_0__[key]; }) }(__WEBPACK_IMPORT_KEY__)); /* harmony default export */ __webpack_exports__["default"] = (_node_modules_babel_loader_lib_index_js_node_modules_vue_loader_lib_index_js_vue_loader_options_VectorTileLayer_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_0___default.a); /***/ }), /***/ "10d7": /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); /* harmony import */ var _RangeThemeLayer_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__("ba96"); /* harmony reexport (unknown) */ for(var __WEBPACK_IMPORT_KEY__ in _RangeThemeLayer_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_0__) if(__WEBPACK_IMPORT_KEY__ !== 'default') (function(key) { __webpack_require__.d(__webpack_exports__, key, function() { return _RangeThemeLayer_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_0__[key]; }) }(__WEBPACK_IMPORT_KEY__)); /* harmony import */ var _node_modules_vue_loader_lib_runtime_componentNormalizer_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__("b429"); var render, staticRenderFns /* normalize component */ var component = Object(_node_modules_vue_loader_lib_runtime_componentNormalizer_js__WEBPACK_IMPORTED_MODULE_1__[/* default */ "a"])( _RangeThemeLayer_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_0__["default"], render, staticRenderFns, false, null, null, null ) /* harmony default export */ __webpack_exports__["default"] = (component.exports); /***/ }), /***/ "1164": /***/ (function(module, exports, __webpack_require__) { "use strict"; Object.defineProperty(exports, "__esModule", { value: true }); var meta_1 = __webpack_require__("49c0"); /** * Takes a set of features, calculates the bbox of all input features, and returns a bounding box. * * @name bbox * @param {GeoJSON} geojson any GeoJSON object * @returns {BBox} bbox extent in [minX, minY, maxX, maxY] order * @example * var line = turf.lineString([[-74, 40], [-78, 42], [-82, 35]]); * var bbox = turf.bbox(line); * var bboxPolygon = turf.bboxPolygon(bbox); * * //addToMap * var addToMap = [line, bboxPolygon] */ function bbox(geojson) { var result = [Infinity, Infinity, -Infinity, -Infinity]; meta_1.coordEach(geojson, function (coord) { if (result[0] > coord[0]) { result[0] = coord[0]; } if (result[1] > coord[1]) { result[1] = coord[1]; } if (result[2] < coord[0]) { result[2] = coord[0]; } if (result[3] < coord[1]) { result[3] = coord[1]; } }); return result; } exports.default = bbox; /***/ }), /***/ "1171": /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); /* harmony import */ var _node_modules_babel_loader_lib_index_js_node_modules_ts_loader_index_js_ref_1_1_node_modules_vue_loader_lib_index_js_vue_loader_options_TrackLayer_vue_vue_type_script_lang_ts___WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__("ab53"); /* harmony import */ var _node_modules_babel_loader_lib_index_js_node_modules_ts_loader_index_js_ref_1_1_node_modules_vue_loader_lib_index_js_vue_loader_options_TrackLayer_vue_vue_type_script_lang_ts___WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_node_modules_babel_loader_lib_index_js_node_modules_ts_loader_index_js_ref_1_1_node_modules_vue_loader_lib_index_js_vue_loader_options_TrackLayer_vue_vue_type_script_lang_ts___WEBPACK_IMPORTED_MODULE_0__); /* harmony reexport (unknown) */ for(var __WEBPACK_IMPORT_KEY__ in _node_modules_babel_loader_lib_index_js_node_modules_ts_loader_index_js_ref_1_1_node_modules_vue_loader_lib_index_js_vue_loader_options_TrackLayer_vue_vue_type_script_lang_ts___WEBPACK_IMPORTED_MODULE_0__) if(__WEBPACK_IMPORT_KEY__ !== 'default') (function(key) { __webpack_require__.d(__webpack_exports__, key, function() { return _node_modules_babel_loader_lib_index_js_node_modules_ts_loader_index_js_ref_1_1_node_modules_vue_loader_lib_index_js_vue_loader_options_TrackLayer_vue_vue_type_script_lang_ts___WEBPACK_IMPORTED_MODULE_0__[key]; }) }(__WEBPACK_IMPORT_KEY__)); /* harmony default export */ __webpack_exports__["default"] = (_node_modules_babel_loader_lib_index_js_node_modules_ts_loader_index_js_ref_1_1_node_modules_vue_loader_lib_index_js_vue_loader_options_TrackLayer_vue_vue_type_script_lang_ts___WEBPACK_IMPORTED_MODULE_0___default.a); /***/ }), /***/ "11f8": /***/ (function(module, exports, __webpack_require__) { "use strict"; var __WEBPACK_AMD_DEFINE_FACTORY__, __WEBPACK_AMD_DEFINE_ARRAY__, __WEBPACK_AMD_DEFINE_RESULT__; /** * Copyright Marc J. Schmidt. See the LICENSE file at the top-level * directory of this distribution and at * https://github.com/marcj/css-element-queries/blob/master/LICENSE. */ (function (root, factory) { if (true) { !(__WEBPACK_AMD_DEFINE_ARRAY__ = [__webpack_require__("76b8")], __WEBPACK_AMD_DEFINE_FACTORY__ = (factory), __WEBPACK_AMD_DEFINE_RESULT__ = (typeof __WEBPACK_AMD_DEFINE_FACTORY__ === 'function' ? (__WEBPACK_AMD_DEFINE_FACTORY__.apply(exports, __WEBPACK_AMD_DEFINE_ARRAY__)) : __WEBPACK_AMD_DEFINE_FACTORY__), __WEBPACK_AMD_DEFINE_RESULT__ !== undefined && (module.exports = __WEBPACK_AMD_DEFINE_RESULT__)); } else {} }(typeof window !== 'undefined' ? window : this, function (ResizeSensor) { /** * * @type {Function} * @constructor */ var ElementQueries = function () { //