| /* |
| * 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<ColorString> = {}; |
| ecModel.eachSeriesByType('graph', function (seriesModel: GraphSeriesModel) { |
| const categoriesData = seriesModel.getCategoriesData(); |
| const data = seriesModel.getData(); |
| |
| const categoryNameIdxMap: Dictionary<number> = {}; |
| |
| 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<GraphNodeItemOption>(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<GraphNodeItemOption>(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]) |
| ); |
| } |
| } |
| }); |
| } |
| }); |
| } |