@fluentui/chart-web-components 0.0.1-0 → 0.0.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +15 -7
- package/dist/chart-web-components.d.ts +213 -0
- package/dist/chart-web-components.js +7087 -0
- package/dist/chart-web-components.min.js +106 -0
- package/dist/dts/donut-chart/define.d.ts +1 -0
- package/dist/dts/donut-chart/donut-chart.bench.d.ts +3 -0
- package/dist/dts/donut-chart/donut-chart.d.ts +40 -0
- package/dist/dts/donut-chart/donut-chart.definition.d.ts +7 -0
- package/dist/dts/donut-chart/donut-chart.options.d.ts +38 -0
- package/dist/dts/donut-chart/donut-chart.styles.d.ts +6 -0
- package/dist/dts/donut-chart/donut-chart.template.d.ts +12 -0
- package/dist/dts/donut-chart/index.d.ts +4 -0
- package/dist/dts/helpers.tests.d.ts +30 -0
- package/dist/dts/horizontal-bar-chart/define.d.ts +1 -0
- package/dist/dts/horizontal-bar-chart/horizontal-bar-chart.bench.d.ts +3 -0
- package/dist/dts/horizontal-bar-chart/horizontal-bar-chart.d.ts +46 -0
- package/dist/dts/horizontal-bar-chart/horizontal-bar-chart.definition.d.ts +9 -0
- package/dist/dts/horizontal-bar-chart/horizontal-bar-chart.options.d.ts +40 -0
- package/dist/dts/horizontal-bar-chart/horizontal-bar-chart.styles.d.ts +7 -0
- package/dist/dts/horizontal-bar-chart/horizontal-bar-chart.template.d.ts +12 -0
- package/dist/dts/horizontal-bar-chart/index.d.ts +4 -0
- package/dist/dts/index-rollup.d.ts +2 -0
- package/dist/dts/index.d.ts +2 -0
- package/dist/dts/utils/benchmark-wrapper.d.ts +2 -0
- package/dist/dts/utils/chart-helpers.d.ts +37 -0
- package/dist/esm/donut-chart/define.js +4 -0
- package/dist/esm/donut-chart/define.js.map +1 -0
- package/dist/esm/donut-chart/donut-chart.bench.js +10 -0
- package/dist/esm/donut-chart/donut-chart.bench.js.map +1 -0
- package/dist/esm/donut-chart/donut-chart.definition.js +18 -0
- package/dist/esm/donut-chart/donut-chart.definition.js.map +1 -0
- package/dist/esm/donut-chart/donut-chart.js +227 -0
- package/dist/esm/donut-chart/donut-chart.js.map +1 -0
- package/dist/esm/donut-chart/donut-chart.options.js +2 -0
- package/dist/esm/donut-chart/donut-chart.options.js.map +1 -0
- package/dist/esm/donut-chart/donut-chart.styles.js +133 -0
- package/dist/esm/donut-chart/donut-chart.styles.js.map +1 -0
- package/dist/esm/donut-chart/donut-chart.template.js +57 -0
- package/dist/esm/donut-chart/donut-chart.template.js.map +1 -0
- package/dist/esm/donut-chart/index.js +5 -0
- package/dist/esm/donut-chart/index.js.map +1 -0
- package/dist/esm/helpers.tests.js +73 -0
- package/dist/esm/helpers.tests.js.map +1 -0
- package/dist/esm/horizontal-bar-chart/define.js +4 -0
- package/dist/esm/horizontal-bar-chart/define.js.map +1 -0
- package/dist/esm/horizontal-bar-chart/horizontal-bar-chart.bench.js +10 -0
- package/dist/esm/horizontal-bar-chart/horizontal-bar-chart.bench.js.map +1 -0
- package/dist/esm/horizontal-bar-chart/horizontal-bar-chart.definition.js +20 -0
- package/dist/esm/horizontal-bar-chart/horizontal-bar-chart.definition.js.map +1 -0
- package/dist/esm/horizontal-bar-chart/horizontal-bar-chart.js +412 -0
- package/dist/esm/horizontal-bar-chart/horizontal-bar-chart.js.map +1 -0
- package/dist/esm/horizontal-bar-chart/horizontal-bar-chart.options.js +7 -0
- package/dist/esm/horizontal-bar-chart/horizontal-bar-chart.options.js.map +1 -0
- package/dist/esm/horizontal-bar-chart/horizontal-bar-chart.styles.js +163 -0
- package/dist/esm/horizontal-bar-chart/horizontal-bar-chart.styles.js.map +1 -0
- package/dist/esm/horizontal-bar-chart/horizontal-bar-chart.template.js +53 -0
- package/dist/esm/horizontal-bar-chart/horizontal-bar-chart.template.js.map +1 -0
- package/dist/esm/horizontal-bar-chart/index.js +5 -0
- package/dist/esm/horizontal-bar-chart/index.js.map +1 -0
- package/dist/esm/index-rollup.js +3 -0
- package/dist/esm/index-rollup.js.map +1 -0
- package/dist/esm/index.js +3 -0
- package/dist/esm/index.js.map +1 -0
- package/dist/esm/utils/benchmark-wrapper.js +18 -0
- package/dist/esm/utils/benchmark-wrapper.js.map +1 -0
- package/dist/esm/utils/chart-helpers.js +160 -0
- package/dist/esm/utils/chart-helpers.js.map +1 -0
- package/package.json +3 -3
|
@@ -0,0 +1,53 @@
|
|
|
1
|
+
import { html, ref, repeat, when } from '@microsoft/fast-element';
|
|
2
|
+
/**
|
|
3
|
+
* Generates a template for the HorizontalBarChart component.
|
|
4
|
+
*
|
|
5
|
+
* @public
|
|
6
|
+
*/
|
|
7
|
+
export function horizontalbarchartTemplate() {
|
|
8
|
+
return html `
|
|
9
|
+
<template>
|
|
10
|
+
<div ${ref('chartContainer')}></div>
|
|
11
|
+
${when(x => !x.hideLegends, html `
|
|
12
|
+
<div class="legendcontainer" role="listbox" aria-label="${x => x.legendListLabel}">
|
|
13
|
+
${repeat(x => x.uniqueLegends, html ` <button
|
|
14
|
+
class="legend${(x, c) => c.parent.activeLegend === '' || c.parent.activeLegend === x.legend ? '' : ' inactive'}"
|
|
15
|
+
role="option"
|
|
16
|
+
aria-setsize="${(x, c) => c.length}"
|
|
17
|
+
aria-posinset="${(x, c) => c.index + 1}"
|
|
18
|
+
aria-selected="${(x, c) => x.legend === c.parent.activeLegend}"
|
|
19
|
+
@mouseover="${(x, c) => c.parent.handleLegendMouseoverAndFocus(x.legend)}"
|
|
20
|
+
@mouseout="${(x, c) => c.parent.handleLegendMouseoutAndBlur()}"
|
|
21
|
+
@focus="${(x, c) => c.parent.handleLegendMouseoverAndFocus(x.legend)}"
|
|
22
|
+
@blur="${(x, c) => c.parent.handleLegendMouseoutAndBlur()}"
|
|
23
|
+
@click="${(x, c) => c.parent.handleLegendClick(x.legend)}"
|
|
24
|
+
>
|
|
25
|
+
<div
|
|
26
|
+
class="legend-rect"
|
|
27
|
+
style="background-color: ${x => x.color}; border-color: ${x => x.color};"
|
|
28
|
+
></div>
|
|
29
|
+
<div class="legend-text">${x => x.legend}</div>
|
|
30
|
+
</button>`)}
|
|
31
|
+
</div>
|
|
32
|
+
`)}
|
|
33
|
+
${when(x => !x.hideTooltip && x.tooltipProps.isVisible, html `
|
|
34
|
+
<div
|
|
35
|
+
class="tooltip"
|
|
36
|
+
style="inset-inline-start: ${x => x.tooltipProps.xPos}px; top: ${x => x.tooltipProps.yPos}px"
|
|
37
|
+
>
|
|
38
|
+
<div class="tooltip-line" style="border-color: ${x => x.tooltipProps.color};">
|
|
39
|
+
<div class="tooltip-legend-text">${x => x.tooltipProps.legend}</div>
|
|
40
|
+
<div class="tooltip-data-y" style="color: ${x => x.tooltipProps.color};">
|
|
41
|
+
${x => x.tooltipProps.yValue}
|
|
42
|
+
</div>
|
|
43
|
+
</div>
|
|
44
|
+
</div>
|
|
45
|
+
`)}
|
|
46
|
+
</template>
|
|
47
|
+
`;
|
|
48
|
+
}
|
|
49
|
+
/**
|
|
50
|
+
* @internal
|
|
51
|
+
*/
|
|
52
|
+
export const template = horizontalbarchartTemplate();
|
|
53
|
+
//# sourceMappingURL=horizontal-bar-chart.template.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"horizontal-bar-chart.template.js","sourceRoot":"","sources":["../../../src/horizontal-bar-chart/horizontal-bar-chart.template.ts"],"names":[],"mappings":"AAAA,OAAO,EAAuB,IAAI,EAAE,GAAG,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,yBAAyB,CAAC;AAIvF;;;;GAIG;AACH,MAAM,UAAU,0BAA0B;IACxC,OAAO,IAAI,CAAG;;aAEH,GAAG,CAAC,gBAAgB,CAAC;QAC1B,IAAI,CACJ,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,WAAW,EACnB,IAAI,CAAG;oEACqD,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,eAAe;cAC5E,MAAM,CACN,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,aAAa,EACpB,IAAI,CAAmB;+BACN,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CACtB,CAAC,CAAC,MAAM,CAAC,YAAY,KAAK,EAAE,IAAI,CAAC,CAAC,MAAM,CAAC,YAAY,KAAK,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,WAAW;;gCAEvE,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,MAAM;iCACjB,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,KAAK,GAAG,CAAC;iCACrB,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,MAAM,KAAK,CAAC,CAAC,MAAM,CAAC,YAAY;8BAC/C,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,6BAA6B,CAAC,CAAC,CAAC,MAAM,CAAC;6BAC3D,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,2BAA2B,EAAE;0BACnD,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,6BAA6B,CAAC,CAAC,CAAC,MAAM,CAAC;yBAC3D,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,2BAA2B,EAAE;0BAC/C,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,iBAAiB,CAAC,CAAC,CAAC,MAAM,CAAC;;;;6CAI3B,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,KAAK,mBAAmB,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,KAAK;;2CAE7C,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM;wBAChC,CACX;;SAEJ,CACF;QACC,IAAI,CACJ,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,WAAW,IAAI,CAAC,CAAC,YAAY,CAAC,SAAS,EAC/C,IAAI,CAAG;;;yCAG0B,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,YAAY,CAAC,IAAI,YAAY,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,YAAY,CAAC,IAAI;;6DAExC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,YAAY,CAAC,KAAK;iDACrC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,YAAY,CAAC,MAAM;0DACjB,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,YAAY,CAAC,KAAK;kBACjE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,YAAY,CAAC,MAAM;;;;SAInC,CACF;;GAEJ,CAAC;AACJ,CAAC;AAED;;GAEG;AACH,MAAM,CAAC,MAAM,QAAQ,GAA4C,0BAA0B,EAAE,CAAC"}
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
export { definition as HorizontalBarChartDefinition } from './horizontal-bar-chart.definition.js';
|
|
2
|
+
export { HorizontalBarChart } from './horizontal-bar-chart.js';
|
|
3
|
+
export { styles as HorizontalBarChartStyles } from './horizontal-bar-chart.styles.js';
|
|
4
|
+
export { template as HorizontalBarChartTemplate } from './horizontal-bar-chart.template.js';
|
|
5
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/horizontal-bar-chart/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,IAAI,4BAA4B,EAAE,MAAM,sCAAsC,CAAC;AAClG,OAAO,EAAE,kBAAkB,EAAE,MAAM,2BAA2B,CAAC;AAC/D,OAAO,EAAE,MAAM,IAAI,wBAAwB,EAAE,MAAM,kCAAkC,CAAC;AACtF,OAAO,EAAE,QAAQ,IAAI,0BAA0B,EAAE,MAAM,oCAAoC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index-rollup.js","sourceRoot":"","sources":["../../src/index-rollup.ts"],"names":[],"mappings":"AAAA,OAAO,kCAAkC,CAAC;AAC1C,OAAO,yBAAyB,CAAC"}
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
export { HorizontalBarChart, HorizontalBarChartDefinition, HorizontalBarChartStyles, HorizontalBarChartTemplate, } from './horizontal-bar-chart/index.js';
|
|
2
|
+
export { DonutChart, DonutChartDefinition, DonutChartStyles, DonutChartTemplate } from './donut-chart/index.js';
|
|
3
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,kBAAkB,EAClB,4BAA4B,EAC5B,wBAAwB,EACxB,0BAA0B,GAC3B,MAAM,iCAAiC,CAAC;AACzC,OAAO,EAAE,UAAU,EAAE,oBAAoB,EAAE,gBAAgB,EAAE,kBAAkB,EAAE,MAAM,wBAAwB,CAAC"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
// eslint-disable-next-line
|
|
2
|
+
// @ts-nocheck
|
|
3
|
+
import { tests } from '@tensile-perf/web-components';
|
|
4
|
+
import { webLightTheme } from '@fluentui/tokens';
|
|
5
|
+
import { setTheme } from '@fluentui/web-components';
|
|
6
|
+
const testWrapper = (test, args) => {
|
|
7
|
+
setTheme(webLightTheme);
|
|
8
|
+
return test(args);
|
|
9
|
+
};
|
|
10
|
+
const wrappedTests = {};
|
|
11
|
+
for (const testName of Object.keys(tests)) {
|
|
12
|
+
const test = tests[testName];
|
|
13
|
+
wrappedTests[testName] = (args) => {
|
|
14
|
+
return testWrapper(test, args);
|
|
15
|
+
};
|
|
16
|
+
}
|
|
17
|
+
export { wrappedTests as tests };
|
|
18
|
+
//# sourceMappingURL=benchmark-wrapper.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"benchmark-wrapper.js","sourceRoot":"","sources":["../../../src/utils/benchmark-wrapper.ts"],"names":[],"mappings":"AAAA,2BAA2B;AAC3B,cAAc;AACd,OAAO,EAAE,KAAK,EAAE,MAAM,8BAA8B,CAAC;AACrD,OAAO,EAAE,aAAa,EAAE,MAAM,kBAAkB,CAAC;AACjD,OAAO,EAAE,QAAQ,EAAE,MAAM,0BAA0B,CAAC;AAEpD,MAAM,WAAW,GAAG,CAAC,IAAS,EAAE,IAAS,EAAE,EAAE;IAC3C,QAAQ,CAAC,aAAa,CAAC,CAAC;IACxB,OAAO,IAAI,CAAC,IAAI,CAAC,CAAC;AACpB,CAAC,CAAC;AAEF,MAAM,YAAY,GAAG,EAAE,CAAC;AAExB,KAAK,MAAM,QAAQ,IAAI,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC;IAC1C,MAAM,IAAI,GAAG,KAAK,CAAC,QAAQ,CAAC,CAAC;IAE7B,YAAY,CAAC,QAAQ,CAAC,GAAG,CAAC,IAAS,EAAE,EAAE;QACrC,OAAO,WAAW,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC;IACjC,CAAC,CAAC;AACJ,CAAC;AAED,OAAO,EAAE,YAAY,IAAI,KAAK,EAAE,CAAC"}
|
|
@@ -0,0 +1,160 @@
|
|
|
1
|
+
import { Direction } from '@microsoft/fast-web-utilities';
|
|
2
|
+
import { getDirection } from '@fluentui/web-components';
|
|
3
|
+
export const jsonConverter = {
|
|
4
|
+
toView(value) {
|
|
5
|
+
return JSON.stringify(value);
|
|
6
|
+
},
|
|
7
|
+
fromView(value) {
|
|
8
|
+
return JSON.parse(value);
|
|
9
|
+
},
|
|
10
|
+
};
|
|
11
|
+
export const validateChartPropsArray = (obj, objName) => {
|
|
12
|
+
if (!Array.isArray(obj)) {
|
|
13
|
+
throw TypeError(`Invalid ${objName}: Expected an array.`);
|
|
14
|
+
}
|
|
15
|
+
obj.forEach((item, idx) => {
|
|
16
|
+
validateChartProps(item, `${objName}[${idx}]`);
|
|
17
|
+
});
|
|
18
|
+
};
|
|
19
|
+
export const validateChartProps = (obj, objName) => {
|
|
20
|
+
if (obj === null || typeof obj !== 'object' || Array.isArray(obj)) {
|
|
21
|
+
throw TypeError(`Invalid ${objName}: Expected an object.`);
|
|
22
|
+
}
|
|
23
|
+
if (!Array.isArray(obj.chartData)) {
|
|
24
|
+
throw TypeError(`Invalid ${objName}.chartData: Expected an array.`);
|
|
25
|
+
}
|
|
26
|
+
obj.chartData.forEach((item, idx) => {
|
|
27
|
+
if (item === null || typeof item !== 'object' || Array.isArray(item)) {
|
|
28
|
+
throw TypeError(`Invalid ${objName}.chartData[${idx}]: Expected an object.`);
|
|
29
|
+
}
|
|
30
|
+
if (typeof item.legend !== 'string') {
|
|
31
|
+
throw TypeError(`Invalid ${objName}.chartData[${idx}].legend: Expected a string.`);
|
|
32
|
+
}
|
|
33
|
+
if (typeof item.data !== 'number') {
|
|
34
|
+
throw TypeError(`Invalid ${objName}.chartData[${idx}].data: Expected a number.`);
|
|
35
|
+
}
|
|
36
|
+
});
|
|
37
|
+
};
|
|
38
|
+
export const DataVizPalette = {
|
|
39
|
+
color1: 'qualitative.1',
|
|
40
|
+
color2: 'qualitative.2',
|
|
41
|
+
color3: 'qualitative.3',
|
|
42
|
+
color4: 'qualitative.4',
|
|
43
|
+
color5: 'qualitative.5',
|
|
44
|
+
color6: 'qualitative.6',
|
|
45
|
+
color7: 'qualitative.7',
|
|
46
|
+
color8: 'qualitative.8',
|
|
47
|
+
color9: 'qualitative.9',
|
|
48
|
+
color10: 'qualitative.10',
|
|
49
|
+
color11: 'qualitative.21',
|
|
50
|
+
color12: 'qualitative.22',
|
|
51
|
+
color13: 'qualitative.23',
|
|
52
|
+
color14: 'qualitative.24',
|
|
53
|
+
color15: 'qualitative.25',
|
|
54
|
+
color16: 'qualitative.26',
|
|
55
|
+
color17: 'qualitative.27',
|
|
56
|
+
color18: 'qualitative.28',
|
|
57
|
+
color19: 'qualitative.29',
|
|
58
|
+
info: 'semantic.info',
|
|
59
|
+
disabled: 'semantic.disabled',
|
|
60
|
+
highError: 'semantic.highError',
|
|
61
|
+
error: 'semantic.error',
|
|
62
|
+
warning: 'semantic.warning',
|
|
63
|
+
success: 'semantic.success',
|
|
64
|
+
highSuccess: 'semantic.highSuccess',
|
|
65
|
+
};
|
|
66
|
+
const QualitativePalette = {
|
|
67
|
+
'1': ['#637cef'], // [cornflower.tint10],
|
|
68
|
+
'2': ['#e3008c'], // [hotPink.primary],
|
|
69
|
+
'3': ['#2aa0a4'], // [teal.tint20],
|
|
70
|
+
'4': ['#9373c0'], // [orchid.tint10],
|
|
71
|
+
'5': ['#13a10e'], // [lightGreen.primary],
|
|
72
|
+
'6': ['#3a96dd'], // [lightBlue.primary],
|
|
73
|
+
'7': ['#ca5010'], // [pumpkin.primary],
|
|
74
|
+
'8': ['#57811b'], // [lime.shade20],
|
|
75
|
+
'9': ['#b146c2'], // [lilac.primary],
|
|
76
|
+
'10': ['#ae8c00'], // [gold.shade10],
|
|
77
|
+
'21': ['#4f6bed'], // [cornflower.primary],
|
|
78
|
+
'22': ['#ea38a6'], // [hotPink.tint20],
|
|
79
|
+
'23': ['#038387'], // [teal.primary],
|
|
80
|
+
'24': ['#8764b8'], // [orchid.primary],
|
|
81
|
+
'25': ['#11910d'], // [lightGreen.shade10],
|
|
82
|
+
'26': ['#3487c7'], // [lightBlue.shade10],
|
|
83
|
+
'27': ['#d06228'], // [pumpkin.tint10],
|
|
84
|
+
'28': ['#689920'], // [lime.shade10],
|
|
85
|
+
'29': ['#ba58c9'], // [lilac.tint10],
|
|
86
|
+
};
|
|
87
|
+
const SemanticPalette = {
|
|
88
|
+
info: ['#015cda'],
|
|
89
|
+
disabled: ['#dbdbdb', '#4d4d4d'], // [grey[86], grey[30]]
|
|
90
|
+
highError: ['#6e0811', '#cc2635'], // [cranberry.shade30, cranberry.tint10],
|
|
91
|
+
error: ['#c50f1f', '#dc626d'], // [cranberry.primary, cranberry.tint30],
|
|
92
|
+
warning: ['#f7630c', '#f87528'], // [orange.primary, orange.tint10],
|
|
93
|
+
success: ['#107c10', '#54b054'], // [green.primary, green.tint30],
|
|
94
|
+
highSuccess: ['#094509', '#218c21'], // [green.shade30, green.tint10],
|
|
95
|
+
};
|
|
96
|
+
const Colors = {
|
|
97
|
+
qualitative: QualitativePalette,
|
|
98
|
+
semantic: SemanticPalette,
|
|
99
|
+
};
|
|
100
|
+
const QUALITATIVE_COLORS = Object.values(QualitativePalette);
|
|
101
|
+
const TOKENS = Object.values(DataVizPalette);
|
|
102
|
+
const getThemeSpecificColor = (colors, isDarkTheme) => {
|
|
103
|
+
if (colors.length === 0) {
|
|
104
|
+
return '';
|
|
105
|
+
}
|
|
106
|
+
const colorIdx = Number(isDarkTheme);
|
|
107
|
+
if (colorIdx < colors.length) {
|
|
108
|
+
return colors[colorIdx];
|
|
109
|
+
}
|
|
110
|
+
return colors[0];
|
|
111
|
+
};
|
|
112
|
+
export const getNextColor = (index, offset = 0, isDarkTheme = false) => {
|
|
113
|
+
const colors = QUALITATIVE_COLORS[(index + offset) % QUALITATIVE_COLORS.length];
|
|
114
|
+
return getThemeSpecificColor(colors, isDarkTheme);
|
|
115
|
+
};
|
|
116
|
+
export const getColorFromToken = (token, isDarkTheme = false) => {
|
|
117
|
+
if (TOKENS.indexOf(token) >= 0) {
|
|
118
|
+
const [paletteName, colorCode] = token.split('.');
|
|
119
|
+
const colors = Colors[paletteName][colorCode];
|
|
120
|
+
return getThemeSpecificColor(colors, isDarkTheme);
|
|
121
|
+
}
|
|
122
|
+
return token;
|
|
123
|
+
};
|
|
124
|
+
export const getRTL = (rootNode) => {
|
|
125
|
+
return getDirection(rootNode) === Direction.rtl;
|
|
126
|
+
};
|
|
127
|
+
export const SVG_NAMESPACE_URI = 'http://www.w3.org/2000/svg';
|
|
128
|
+
export const wrapText = (text, width) => {
|
|
129
|
+
if (!text.textContent) {
|
|
130
|
+
return;
|
|
131
|
+
}
|
|
132
|
+
const words = text.textContent.split(/\s+/).reverse();
|
|
133
|
+
let word;
|
|
134
|
+
let line = [];
|
|
135
|
+
let lineNumber = 0;
|
|
136
|
+
const lineHeight = text.getBoundingClientRect().height;
|
|
137
|
+
const y = text.getAttribute('y') || '0';
|
|
138
|
+
text.textContent = null;
|
|
139
|
+
let tspan = document.createElementNS(SVG_NAMESPACE_URI, 'tspan');
|
|
140
|
+
text.appendChild(tspan);
|
|
141
|
+
tspan.setAttribute('x', '0');
|
|
142
|
+
tspan.setAttribute('y', y);
|
|
143
|
+
tspan.setAttribute('dy', `${lineNumber++ * lineHeight}`);
|
|
144
|
+
while ((word = words.pop())) {
|
|
145
|
+
line.push(word);
|
|
146
|
+
tspan.textContent = line.join(' ') + ' ';
|
|
147
|
+
if (tspan.getComputedTextLength() > width && line.length > 1) {
|
|
148
|
+
line.pop();
|
|
149
|
+
tspan.textContent = line.join(' ') + ' ';
|
|
150
|
+
line = [word];
|
|
151
|
+
tspan = document.createElementNS(SVG_NAMESPACE_URI, 'tspan');
|
|
152
|
+
text.appendChild(tspan);
|
|
153
|
+
tspan.setAttribute('x', '0');
|
|
154
|
+
tspan.setAttribute('y', y);
|
|
155
|
+
tspan.setAttribute('dy', `${lineNumber++ * lineHeight}`);
|
|
156
|
+
tspan.textContent = word;
|
|
157
|
+
}
|
|
158
|
+
}
|
|
159
|
+
};
|
|
160
|
+
//# sourceMappingURL=chart-helpers.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"chart-helpers.js","sourceRoot":"","sources":["../../../src/utils/chart-helpers.ts"],"names":[],"mappings":"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"}
|
package/package.json
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@fluentui/chart-web-components",
|
|
3
3
|
"description": "A library of Fluent Chart Web Components",
|
|
4
|
-
"version": "0.0.
|
|
4
|
+
"version": "0.0.2",
|
|
5
5
|
"author": {
|
|
6
6
|
"name": "Microsoft"
|
|
7
7
|
},
|
|
@@ -97,8 +97,8 @@
|
|
|
97
97
|
},
|
|
98
98
|
"dependencies": {
|
|
99
99
|
"@microsoft/fast-web-utilities": "^6.0.0",
|
|
100
|
-
"@fluentui/tokens": "
|
|
101
|
-
"@fluentui/web-components": "^3.0.0-beta.
|
|
100
|
+
"@fluentui/tokens": "^1.0.0-alpha.21",
|
|
101
|
+
"@fluentui/web-components": "^3.0.0-beta.79",
|
|
102
102
|
"@types/d3-selection": "^3.0.0",
|
|
103
103
|
"@types/d3-shape": "^3.0.0",
|
|
104
104
|
"d3-selection": "^3.0.0",
|