Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

fix(word-cloud): fix tooltip and add demo for custom tooltip #1762

Merged
merged 9 commits into from
Oct 22, 2020
35 changes: 35 additions & 0 deletions __tests__/bugs/issue-1754-spec.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,35 @@
import { TooltipCfg } from '@antv/g2/lib/interface';
import { WordCloud } from '../../src';
import { CountryEconomy } from '../data/country-economy';
import { createDiv } from '../utils/dom';

describe('issue 1754', () => {
it('customContent', () => {
const cloud = new WordCloud(createDiv(), {
width: 400,
height: 300,
data: CountryEconomy,
wordField: 'Country',
weightField: 'GDP',
});

const data = [
{
data: { text: 'name', value: 'weight' },
mappingData: { color: 'red' },
},
];
const result =
'<li class="g2-tooltip-list-item" style="margin-bottom:4px;display:flex;align-items:center;">' +
'<span style="background-color:red;" class="g2-tooltip-marker"></span>' +
'<span style="display:inline-flex;flex:1;justify-content:space-between">' +
'<span style="margin-right: 16px;">name:</span><span>weight</span>' +
'</span>' +
'</li>';

cloud.render();

const customContent = (cloud.chart.getOptions().tooltip as TooltipCfg).customContent;
expect(customContent(undefined, data)).toBe(result);
});
});
68 changes: 68 additions & 0 deletions __tests__/unit/plots/word-cloud/color-spec.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,68 @@
import { WordCloud } from '../../../../src';
import { CountryEconomy } from '../../../data/country-economy';
import { createDiv } from '../../../utils/dom';

describe('word-cloud color option', () => {
it('default', () => {
const cloud = new WordCloud(createDiv(), {
width: 400,
height: 300,
data: CountryEconomy,
wordField: 'Country',
weightField: 'GDP',
});

cloud.render();

const field = cloud.chart.geometries[0].getGroupFields()[0];
expect(field).toBe('text');
});

it('wordField', () => {
const cloud = new WordCloud(createDiv(), {
width: 400,
height: 300,
data: CountryEconomy,
wordField: 'Country',
weightField: 'GDP',
colorField: 'Country', // wordField 字段值
});

cloud.render();

const field = cloud.chart.geometries[0].getGroupFields()[0];
expect(field).toBe('color');
});

it('weightField', () => {
const cloud = new WordCloud(createDiv(), {
width: 400,
height: 300,
data: CountryEconomy,
wordField: 'Country',
weightField: 'GDP',
colorField: 'GDP', // weightField 字段值
});

cloud.render();

const field = cloud.chart.geometries[0].getGroupFields()[0];
expect(field).toBe('color');
});

it('x', () => {
const cloud = new WordCloud(createDiv(), {
width: 400,
height: 300,
data: CountryEconomy,
wordField: 'Country',
weightField: 'GDP',
colorField: 'x',
});

cloud.render();

const field = cloud.chart.geometries[0].getGroupFields()[0];
expect(field).toBe('color');
});
});
4 changes: 2 additions & 2 deletions __tests__/unit/plots/word-cloud/style-spec.ts
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
import { WordCloud } from '../../../../src';
import { CountryEconomy } from '../../../data/country-economy';
import { createDiv } from '../../../utils/dom';
import { DataItem } from '../../../../src/plots/word-cloud/types';
import { Tag } from '../../../../src/plots/word-cloud/types';

describe('word-cloud', () => {
it('style', () => {
Expand All @@ -22,7 +22,7 @@ describe('word-cloud', () => {

const { data } = cloud.chart.getOptions();

data.forEach((item: DataItem) => {
data.forEach((item: Tag) => {
// DataSet 处理之后会多出两个无用的数据
if (!item.hasText) return;

Expand Down
63 changes: 18 additions & 45 deletions __tests__/unit/utils/transform/word-cloud-spec.ts
Original file line number Diff line number Diff line change
@@ -1,10 +1,8 @@
import DataSet from '@antv/data-set';
import { DataItem } from '../../../../src/plots/word-cloud/types';
import { Tag, Word } from '../../../../src/plots/word-cloud/types';
import { processImageMask } from '../../../../src/plots/word-cloud/utils';
import { wordCloud, transform } from '../../../../src/utils/transform/word-cloud';

type Row = Pick<DataItem, 'text' | 'value'>;

const { View } = DataSet;
const options = {
type: 'tag-cloud',
Expand All @@ -22,11 +20,10 @@ const data = ['Hello', 'world', 'normally', 'you', 'want', 'more', 'words', 'tha
return {
text: d,
value: 5 + Math.random() * 10,
test: 'haha',
};
});

function basicCommon(v: DataItem) {
function basicCommon(v: Tag) {
expect(v.hasText).toBe(true);
expect(typeof v.text).toBe('string');
expect(typeof v.value).toBe('number');
Expand All @@ -52,7 +49,7 @@ describe('word-cloud', () => {
delete v.x;
delete v.y;
}
const result1 = wordCloud(data, options as any);
const result1 = wordCloud(data as Word[], options as any);
const result2 = dv.rows;

result1.forEach(removeXY);
Expand All @@ -62,32 +59,32 @@ describe('word-cloud', () => {
});

it('default', () => {
const result = wordCloud(data);
const result = wordCloud(data as Word[]);
basicCommon(result[0]);
});

it('callback', () => {
const common = (row: Row) => {
const common = (row: Word) => {
expect(typeof row.text).toBe('string');
expect(typeof row.value).toBe('number');
};
const font = (row: Row) => {
const font = (row: Word) => {
common(row);
return 'font-test';
};
const fontWeight = (row: Row): any => {
const fontWeight = (row: Word): any => {
common(row);
return 'fontWeight-test';
};
const fontSize = (row: Row) => {
const fontSize = (row: Word) => {
common(row);
return 11;
};
const rotate = (row: Row) => {
const rotate = (row: Word) => {
common(row);
return 22;
};
const padding = (row: Row) => {
const padding = (row: Word) => {
common(row);
return 33;
};
Expand All @@ -100,7 +97,7 @@ describe('word-cloud', () => {
};
};

const result = wordCloud(data, {
const result = wordCloud(data as Word[], {
font,
fontWeight,
fontSize,
Expand All @@ -127,51 +124,30 @@ describe('word-cloud', () => {
'';

const img = await processImageMask(base64);
const result = wordCloud(data, { imageMask: img });
const result = wordCloud(data as Word[], { imageMask: img });
basicCommon(result[0]);
});

it('spiral is rectangular', () => {
const result = wordCloud(data, { spiral: 'rectangular' });
const result = wordCloud(data as Word[], { spiral: 'rectangular' });
basicCommon(result[0]);
});
});

describe('transform', () => {
it('default', () => {
const result = transform(data, {
fields: ['text', 'value'],
const result = transform(data as Word[], {
size: [800, 800],
});
basicCommon(result[0]);
});

it('error of fields', () => {
expect(() => {
transform(data, {
fields: [null, null],
size: [800, 800],
});
}).toThrow();
});

it('fields is not exit', () => {
const result = transform(data, {
fields: ['a', 'b'],
size: [800, 800],
});

expect(result[0].text).toBe(undefined);
expect(result[0].value).toBe(undefined);
});

it('image mask with size is 0', async () => {
const base64 =
'';

const img = await processImageMask(base64);
const result = transform(data, {
fields: ['text', 'value'],
const result = transform(data as Word[], {
size: [0, 0],
imageMask: img,
});
Expand All @@ -182,8 +158,7 @@ describe('transform', () => {
});

it('timeInterval is 0', () => {
const result = transform(data, {
fields: ['text', 'value'],
const result = transform(data as Word[], {
size: [800, 800],
timeInterval: 0,
});
Expand All @@ -194,17 +169,15 @@ describe('transform', () => {
});

it('padding is 0', () => {
const result = transform(data, {
fields: ['text', 'value'],
const result = transform(data as Word[], {
size: [800, 800],
padding: 0,
});
basicCommon(result[0]);
});

it('rotate is 0', () => {
const result = transform(data, {
fields: ['text', 'value'],
const result = transform(data as Word[], {
size: [800, 800],
rotate: 0,
});
Expand Down
8 changes: 8 additions & 0 deletions docs/manual/plots/word-cloud.en.md
Original file line number Diff line number Diff line change
Expand Up @@ -37,6 +37,14 @@ order: 0

默认配置: 无

#### colorField

**可选**, _string_

功能描述: 根据该字段进行颜色映射

默认配置: wordField 字段的值
zhangzhonghe marked this conversation as resolved.
Show resolved Hide resolved
hustcc marked this conversation as resolved.
Show resolved Hide resolved

#### timeInterval

**可选**, _number_
Expand Down
10 changes: 9 additions & 1 deletion docs/manual/plots/word-cloud.zh.md
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@
title: 词云图
order: 0
---

## 配置属性

### 图表容器
Expand Down Expand Up @@ -37,6 +37,14 @@ order: 0

默认配置: 无

#### colorField

**可选**, _string_

功能描述: 根据该字段进行颜色映射

默认配置: wordField 字段的值

#### timeInterval

**可选**, _number_
Expand Down
21 changes: 21 additions & 0 deletions examples/word-cloud/basic/demo/color-field.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,21 @@
import { WordCloud } from '@antv/g2plot';

fetch('https://gw.alipayobjects.com/os/antvdemo/assets/data/antv-keywords.json')
.then((res) => res.json())
.then((data) => {
const wordCloud = new WordCloud('container', {
data,
width: 600,
height: 400,
wordField: 'name',
weightField: 'value',
colorField: 'value',
zhangzhonghe marked this conversation as resolved.
Show resolved Hide resolved
imageMask: 'https://gw.alipayobjects.com/mdn/rms_2274c3/afts/img/A*07tdTIOmvlYAAAAAAAAAAABkARQnAQ',
wordStyle: {
fontFamily: 'Verdana',
fontSize: [8, 32],
},
});

wordCloud.render();
});
Loading