/* * 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 GlobalModel from '../../model/Global'; import GraphSeriesModel, { GraphNodeItemOption } from './GraphSeries'; import { Dictionary, ColorString } from '../../util/types'; import { extend, isString } from 'zrender/src/core/util'; export default function categoryVisual(ecModel: GlobalModel) { const paletteScope: Dictionary = {}; ecModel.eachSeriesByType('graph', function (seriesModel: GraphSeriesModel) { const categoriesData = seriesModel.getCategoriesData(); const data = seriesModel.getData(); const categoryNameIdxMap: Dictionary = {}; categoriesData.each(function (idx) { const name = categoriesData.getName(idx); // Add prefix to avoid conflict with Object.prototype. categoryNameIdxMap['ec-' + name] = idx; const itemModel = categoriesData.getItemModel(idx); const style = itemModel.getModel('itemStyle').getItemStyle(); if (!style.fill) { // Get color from palette. style.fill = seriesModel.getColorFromPalette(name, paletteScope); } categoriesData.setItemVisual(idx, 'style', style); const symbolVisualList = ['symbol', 'symbolSize', 'symbolKeepAspect'] as const; for (let i = 0; i < symbolVisualList.length; i++) { const symbolVisual = itemModel.getShallow(symbolVisualList[i], true); if (symbolVisual != null) { categoriesData.setItemVisual(idx, symbolVisualList[i], symbolVisual); } } }); // Assign category color to visual if (categoriesData.count()) { data.each(function (idx) { const model = data.getItemModel(idx); let categoryIdx = model.getShallow('category'); if (categoryIdx != null) { if (isString(categoryIdx)) { categoryIdx = categoryNameIdxMap['ec-' + categoryIdx]; } const categoryStyle = categoriesData.getItemVisual(categoryIdx, 'style'); const style = data.ensureUniqueItemVisual(idx, 'style'); extend(style, categoryStyle); const visualList = ['symbol', 'symbolSize', 'symbolKeepAspect'] as const; for (let i = 0; i < visualList.length; i++) { data.setItemVisual( idx, visualList[i], categoriesData.getItemVisual(categoryIdx, visualList[i]) ); } } }); } }); }