/* * Licensed to the Apache Software Foundation (ASF) under one * or more contributor license agreements. See the NOTICE file * distributed with this work for additional information * regarding copyright ownership. The ASF licenses this file * to you under the Apache License, Version 2.0 (the * "License"); you may not use this file except in compliance * with the License. You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, * software distributed under the License is distributed on an * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY * KIND, either express or implied. See the License for the * specific language governing permissions and limitations * under the License. */ // @ts-nocheck import * as echarts from 'echarts'; function isEmptyObject(obj) { for (const key in obj) { if (obj.hasOwnProperty(key)) { return false; } } return true; } export default echarts.extendComponentView({ type: 'bmap', render: function (bMapModel, ecModel, api) { let rendering = true; const bmap = bMapModel.getBMap(); const viewportRoot = api.getZr().painter.getViewportRoot(); const coordSys = bMapModel.coordinateSystem; const moveHandler = function (type, target) { if (rendering) { return; } const offsetEl = viewportRoot.parentNode.parentNode.parentNode; const mapOffset = [ -parseInt(offsetEl.style.left, 10) || 0, -parseInt(offsetEl.style.top, 10) || 0 ]; // only update style when map offset changed const viewportRootStyle = viewportRoot.style; const offsetLeft = mapOffset[0] + 'px'; const offsetTop = mapOffset[1] + 'px'; if (viewportRootStyle.left !== offsetLeft) { viewportRootStyle.left = offsetLeft; } if (viewportRootStyle.top !== offsetTop) { viewportRootStyle.top = offsetTop; } coordSys.setMapOffset(mapOffset); bMapModel.__mapOffset = mapOffset; api.dispatchAction({ type: 'bmapRoam', animation: { duration: 0 } }); }; function zoomEndHandler() { if (rendering) { return; } api.dispatchAction({ type: 'bmapRoam', animation: { duration: 0 } }); } bmap.removeEventListener('moving', this._oldMoveHandler); bmap.removeEventListener('moveend', this._oldMoveHandler); bmap.removeEventListener('zoomend', this._oldZoomEndHandler); bmap.addEventListener('moving', moveHandler); bmap.addEventListener('moveend', moveHandler); bmap.addEventListener('zoomend', zoomEndHandler); this._oldMoveHandler = moveHandler; this._oldZoomEndHandler = zoomEndHandler; const roam = bMapModel.get('roam'); if (roam && roam !== 'scale') { bmap.enableDragging(); } else { bmap.disableDragging(); } if (roam && roam !== 'move') { bmap.enableScrollWheelZoom(); bmap.enableDoubleClickZoom(); bmap.enablePinchToZoom(); } else { bmap.disableScrollWheelZoom(); bmap.disableDoubleClickZoom(); bmap.disablePinchToZoom(); } /* map 2.0 */ const originalStyle = bMapModel.__mapStyle; const newMapStyle = bMapModel.get('mapStyle') || {}; // FIXME, Not use JSON methods const mapStyleStr = JSON.stringify(newMapStyle); if (JSON.stringify(originalStyle) !== mapStyleStr) { // FIXME May have blank tile when dragging if setMapStyle if (!isEmptyObject(newMapStyle)) { bmap.setMapStyle(echarts.util.clone(newMapStyle)); } bMapModel.__mapStyle = JSON.parse(mapStyleStr); } /* map 3.0 */ const originalStyle2 = bMapModel.__mapStyle2; const newMapStyle2 = bMapModel.get('mapStyleV2') || {}; // FIXME, Not use JSON methods const mapStyleStr2 = JSON.stringify(newMapStyle2); if (JSON.stringify(originalStyle2) !== mapStyleStr2) { // FIXME May have blank tile when dragging if setMapStyle if (!isEmptyObject(newMapStyle2)) { bmap.setMapStyleV2(echarts.util.clone(newMapStyle2)); } bMapModel.__mapStyle2 = JSON.parse(mapStyleStr2); } rendering = false; } });