| /* | 
| * 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; | 
|     } | 
| }); |