blob: e6810e4df47c78a94d2df501815144fc52e0c5e7 [file] [log] [blame]
/*
* 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.
*/
import { ElementEvent } from 'zrender/src/Element';
import ExtensionAPI from '../../core/ExtensionAPI';
import { CoordinateSystemHostModel } from '../../coord/CoordinateSystem';
import type Component from '../../model/Component';
import { retrieveZInfo } from '../../util/graphic';
const IRRELEVANT_EXCLUDES = {'axisPointer': 1, 'tooltip': 1, 'brush': 1};
/**
* Used on roam/brush triggering determination.
* This is to avoid that: mouse clicking on an elements that is over geo or graph,
* but roam is triggered unexpectedly.
*/
export function onIrrelevantElement(
e: ElementEvent,
api: ExtensionAPI,
targetComponent: Component
): boolean {
const eventElComponent = api.getComponentByElement(e.topTarget);
if (!eventElComponent
|| eventElComponent === targetComponent
|| IRRELEVANT_EXCLUDES.hasOwnProperty(eventElComponent.mainType)
) {
return false;
}
// At present the `true` return is conservative. That is, the caller, such as a RoamController,
// is more likely to get a `false` return and start a roam behavior, becuase even if the
// `model.coordinateSystem` does not exist, the `e.topTarget` may be also a relevant element,
// such as axis split line/area or series elements, where roam should be available. Otherwise,
// if a dataZoom-served cartesian is full of series elements, the dataZoom-roaming can hardly
// be triggered.
const eventElCoordSys = (eventElComponent as CoordinateSystemHostModel).coordinateSystem;
// If eventElComponent is axisModel, it works only if it is injected with coordinateSystem.
if (!eventElCoordSys || eventElCoordSys.model === targetComponent) {
return false;
}
// e.g., if a cartesian is covered by a graph, the graph has a higher presedence in roam.
// A potential bad case is that RoamController does not prevent the cartesian from handling zr
// event, such as click and hovering, but it's fine so far.
// Aslo be conservative, if equals, return false.
const eventElCmptZInfo = retrieveZInfo(eventElComponent);
const targetCmptZInfo = retrieveZInfo(targetComponent);
if ((
(eventElCmptZInfo.zlevel - targetCmptZInfo.zlevel)
|| (eventElCmptZInfo.z - targetCmptZInfo.z)
) <= 0
) {
return false;
}
return true;
}