Spaces:
Running
Running
| /* | |
| * 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]) | |
| ); | |
| } | |
| } | |
| }); | |
| } | |
| }); | |
| } | |