| 
/* 
 | 
* 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. 
 | 
*/ 
 | 
  
 | 
  
 | 
/** 
 | 
 * AUTO-GENERATED FILE. DO NOT MODIFY. 
 | 
 */ 
 | 
  
 | 
/* 
 | 
* 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 * as numberUtil from '../../util/number.js'; 
 | 
import { isDimensionStacked } from '../../data/helper/dataStackHelper.js'; 
 | 
import { indexOf, curry, clone, isArray } from 'zrender/lib/core/util.js'; 
 | 
import { parseDataValue } from '../../data/helper/dataValueHelper.js'; 
 | 
function hasXOrY(item) { 
 | 
  return !(isNaN(parseFloat(item.x)) && isNaN(parseFloat(item.y))); 
 | 
} 
 | 
function hasXAndY(item) { 
 | 
  return !isNaN(parseFloat(item.x)) && !isNaN(parseFloat(item.y)); 
 | 
} 
 | 
function markerTypeCalculatorWithExtent(markerType, data, otherDataDim, targetDataDim, otherCoordIndex, targetCoordIndex) { 
 | 
  var coordArr = []; 
 | 
  var stacked = isDimensionStacked(data, targetDataDim /* , otherDataDim */); 
 | 
  var calcDataDim = stacked ? data.getCalculationInfo('stackResultDimension') : targetDataDim; 
 | 
  var value = numCalculate(data, calcDataDim, markerType); 
 | 
  var dataIndex = data.indicesOfNearest(calcDataDim, value)[0]; 
 | 
  coordArr[otherCoordIndex] = data.get(otherDataDim, dataIndex); 
 | 
  coordArr[targetCoordIndex] = data.get(calcDataDim, dataIndex); 
 | 
  var coordArrValue = data.get(targetDataDim, dataIndex); 
 | 
  // Make it simple, do not visit all stacked value to count precision. 
 | 
  var precision = numberUtil.getPrecision(data.get(targetDataDim, dataIndex)); 
 | 
  precision = Math.min(precision, 20); 
 | 
  if (precision >= 0) { 
 | 
    coordArr[targetCoordIndex] = +coordArr[targetCoordIndex].toFixed(precision); 
 | 
  } 
 | 
  return [coordArr, coordArrValue]; 
 | 
} 
 | 
// TODO Specified percent 
 | 
var markerTypeCalculator = { 
 | 
  min: curry(markerTypeCalculatorWithExtent, 'min'), 
 | 
  max: curry(markerTypeCalculatorWithExtent, 'max'), 
 | 
  average: curry(markerTypeCalculatorWithExtent, 'average'), 
 | 
  median: curry(markerTypeCalculatorWithExtent, 'median') 
 | 
}; 
 | 
/** 
 | 
 * Transform markPoint data item to format used in List by do the following 
 | 
 * 1. Calculate statistic like `max`, `min`, `average` 
 | 
 * 2. Convert `item.xAxis`, `item.yAxis` to `item.coord` array 
 | 
 */ 
 | 
export function dataTransform(seriesModel, item) { 
 | 
  if (!item) { 
 | 
    return; 
 | 
  } 
 | 
  var data = seriesModel.getData(); 
 | 
  var coordSys = seriesModel.coordinateSystem; 
 | 
  var dims = coordSys && coordSys.dimensions; 
 | 
  // 1. If not specify the position with pixel directly 
 | 
  // 2. If `coord` is not a data array. Which uses `xAxis`, 
 | 
  // `yAxis` to specify the coord on each dimension 
 | 
  // parseFloat first because item.x and item.y can be percent string like '20%' 
 | 
  if (!hasXAndY(item) && !isArray(item.coord) && isArray(dims)) { 
 | 
    var axisInfo = getAxisInfo(item, data, coordSys, seriesModel); 
 | 
    // Clone the option 
 | 
    // Transform the properties xAxis, yAxis, radiusAxis, angleAxis, geoCoord to value 
 | 
    item = clone(item); 
 | 
    if (item.type && markerTypeCalculator[item.type] && axisInfo.baseAxis && axisInfo.valueAxis) { 
 | 
      var otherCoordIndex = indexOf(dims, axisInfo.baseAxis.dim); 
 | 
      var targetCoordIndex = indexOf(dims, axisInfo.valueAxis.dim); 
 | 
      var coordInfo = markerTypeCalculator[item.type](data, axisInfo.baseDataDim, axisInfo.valueDataDim, otherCoordIndex, targetCoordIndex); 
 | 
      item.coord = coordInfo[0]; 
 | 
      // Force to use the value of calculated value. 
 | 
      // let item use the value without stack. 
 | 
      item.value = coordInfo[1]; 
 | 
    } else { 
 | 
      // FIXME Only has one of xAxis and yAxis. 
 | 
      item.coord = [item.xAxis != null ? item.xAxis : item.radiusAxis, item.yAxis != null ? item.yAxis : item.angleAxis]; 
 | 
    } 
 | 
  } 
 | 
  // x y is provided 
 | 
  if (item.coord == null || !isArray(dims)) { 
 | 
    item.coord = []; 
 | 
  } else { 
 | 
    // Each coord support max, min, average 
 | 
    var coord = item.coord; 
 | 
    for (var i = 0; i < 2; i++) { 
 | 
      if (markerTypeCalculator[coord[i]]) { 
 | 
        coord[i] = numCalculate(data, data.mapDimension(dims[i]), coord[i]); 
 | 
      } 
 | 
    } 
 | 
  } 
 | 
  return item; 
 | 
} 
 | 
export function getAxisInfo(item, data, coordSys, seriesModel) { 
 | 
  var ret = {}; 
 | 
  if (item.valueIndex != null || item.valueDim != null) { 
 | 
    ret.valueDataDim = item.valueIndex != null ? data.getDimension(item.valueIndex) : item.valueDim; 
 | 
    ret.valueAxis = coordSys.getAxis(dataDimToCoordDim(seriesModel, ret.valueDataDim)); 
 | 
    ret.baseAxis = coordSys.getOtherAxis(ret.valueAxis); 
 | 
    ret.baseDataDim = data.mapDimension(ret.baseAxis.dim); 
 | 
  } else { 
 | 
    ret.baseAxis = seriesModel.getBaseAxis(); 
 | 
    ret.valueAxis = coordSys.getOtherAxis(ret.baseAxis); 
 | 
    ret.baseDataDim = data.mapDimension(ret.baseAxis.dim); 
 | 
    ret.valueDataDim = data.mapDimension(ret.valueAxis.dim); 
 | 
  } 
 | 
  return ret; 
 | 
} 
 | 
function dataDimToCoordDim(seriesModel, dataDim) { 
 | 
  var dimItem = seriesModel.getData().getDimensionInfo(dataDim); 
 | 
  return dimItem && dimItem.coordDim; 
 | 
} 
 | 
/** 
 | 
 * Filter data which is out of coordinateSystem range 
 | 
 * [dataFilter description] 
 | 
 */ 
 | 
export function dataFilter( 
 | 
// Currently only polar and cartesian has containData. 
 | 
coordSys, item) { 
 | 
  // Always return true if there is no coordSys 
 | 
  return coordSys && coordSys.containData && item.coord && !hasXOrY(item) ? coordSys.containData(item.coord) : true; 
 | 
} 
 | 
export function zoneFilter( 
 | 
// Currently only polar and cartesian has containData. 
 | 
coordSys, item1, item2) { 
 | 
  // Always return true if there is no coordSys 
 | 
  return coordSys && coordSys.containZone && item1.coord && item2.coord && !hasXOrY(item1) && !hasXOrY(item2) ? coordSys.containZone(item1.coord, item2.coord) : true; 
 | 
} 
 | 
export function createMarkerDimValueGetter(inCoordSys, dims) { 
 | 
  return inCoordSys ? function (item, dimName, dataIndex, dimIndex) { 
 | 
    var rawVal = dimIndex < 2 
 | 
    // x, y, radius, angle 
 | 
    ? item.coord && item.coord[dimIndex] : item.value; 
 | 
    return parseDataValue(rawVal, dims[dimIndex]); 
 | 
  } : function (item, dimName, dataIndex, dimIndex) { 
 | 
    return parseDataValue(item.value, dims[dimIndex]); 
 | 
  }; 
 | 
} 
 | 
export function numCalculate(data, valueDataDim, type) { 
 | 
  if (type === 'average') { 
 | 
    var sum_1 = 0; 
 | 
    var count_1 = 0; 
 | 
    data.each(valueDataDim, function (val, idx) { 
 | 
      if (!isNaN(val)) { 
 | 
        sum_1 += val; 
 | 
        count_1++; 
 | 
      } 
 | 
    }); 
 | 
    return sum_1 / count_1; 
 | 
  } else if (type === 'median') { 
 | 
    return data.getMedian(valueDataDim); 
 | 
  } else { 
 | 
    // max & min 
 | 
    return data.getDataExtent(valueDataDim)[type === 'max' ? 1 : 0]; 
 | 
  } 
 | 
} 
 |