/*
|
* 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 } 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 (typeof categoryIdx === 'string') {
|
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])
|
);
|
}
|
}
|
});
|
}
|
});
|
}
|