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

standardized pie definitions #4501

Merged
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
78 commits
Select commit Hold shift + click to select a range
a3901f6
add `@types/d3-scale` and @types/d3-shape` to mermaid dev deps
Yokozuna59 Jun 16, 2023
4e7dbf7
add SVG type in `configureSvgSize` function
Yokozuna59 Jun 16, 2023
afea3e8
clean up demos/pie.html
Yokozuna59 Jun 16, 2023
ea3fbbd
initial converting pie files
Yokozuna59 Jun 16, 2023
bdb967e
fix renderer import in pieDiagram
Yokozuna59 Jun 16, 2023
231a963
do deep cloning on section field in pie clear
Yokozuna59 Jun 16, 2023
c17b723
convert pie.spec.js to ts, remove cy.get and useless comment, add sho…
Yokozuna59 Jun 16, 2023
bd67950
return pieRender back to original and update it partially
Yokozuna59 Jun 16, 2023
5aba2fe
remove cy.get of info diagram
Yokozuna59 Jun 16, 2023
f2338f5
remove vanilla-extract from dev dependencies
Yokozuna59 Jun 16, 2023
8794fa0
clean up pieRenderer.ts
Yokozuna59 Jun 17, 2023
23a5832
add null safety in pieRenderer
Yokozuna59 Jun 17, 2023
452e543
Merge branch 'develop' into standardized-pie-definitions
Yokozuna59 Jun 17, 2023
32d3001
Merge branch 'develop' into standardized-pie-definitions
Yokozuna59 Jun 17, 2023
6941814
update pnpm-lock.yaml
Yokozuna59 Jun 17, 2023
9145a9e
Merge branch 'mermaid-js:develop' into standardized-pie-definitions
Yokozuna59 Jun 17, 2023
95e01b4
move `PieDiagramConfig` into pieTypes
Yokozuna59 Jun 17, 2023
f6dc089
add D3Sections type with variable renaming
Yokozuna59 Jun 18, 2023
1d0aa76
document pie useWidth and update other pie config attributes
Yokozuna59 Jun 18, 2023
906d909
Merge branch develop into standardized-pie-definitions
Yokozuna59 Jun 19, 2023
34a4770
update pnpm-lock.yaml
Yokozuna59 Jun 19, 2023
a92571d
add type-fest to mermaid dev deps
Yokozuna59 Jun 19, 2023
c894c1f
add `Required` and `RequiredDeep` to pieDb, add config functions
Yokozuna59 Jun 19, 2023
35c6b67
add config unit test cases for pie chart
Yokozuna59 Jun 19, 2023
cecf759
add showData unit test case
Yokozuna59 Jun 19, 2023
3a22d4a
shorten vitest pie.spec.ts by removing one time use variables
Yokozuna59 Jun 19, 2023
9c2b95f
add config functions to DiagramDB interface
Yokozuna59 Jun 19, 2023
67d287f
use local config instead of glolal one in pieRenderer
Yokozuna59 Jun 19, 2023
ae8860e
add `undefined` to getConfig return type until handle other diagrams
Yokozuna59 Jun 19, 2023
ce9d0e2
use global useMaxWidth until making setConfig updates pie setConfig
Yokozuna59 Jun 19, 2023
09c4a26
rename PieDb interface and more types with null sefety
Yokozuna59 Jun 20, 2023
796a761
remove unnecessary types in pieRenderer
Yokozuna59 Jun 20, 2023
41c5152
Merge branch 'mermaid-js:develop' into standardized-pie-definitions
Yokozuna59 Jun 21, 2023
7605483
Merge branch 'develop' into standardized-pie-definitions
Yokozuna59 Jun 26, 2023
e333403
add type-fest to mermaid dev deps
Yokozuna59 Aug 2, 2023
74fa995
run pnpm lint:fix
Yokozuna59 Aug 2, 2023
7d69ad2
Merge remote-tracking branch upstream/develop into standardized-pie-d…
Yokozuna59 Aug 2, 2023
aecf451
update pnpm-lock.yaml
Yokozuna59 Aug 2, 2023
bdfd897
change default `useWidth` in pie to 984
Yokozuna59 Aug 3, 2023
de37efe
add `type` for `PieStyleOptions`
Yokozuna59 Aug 3, 2023
c954e0e
rename `styles.ts` into `pieStyles.ts`
Yokozuna59 Aug 3, 2023
f4671e4
Merge branch 'mermaid-js:develop' into standardized-pie-definitions
Yokozuna59 Aug 3, 2023
23b6d53
Merge branch 'standardized-pie-definitions' of https://github.com/Yok…
Yokozuna59 Aug 3, 2023
71205f5
Merge branch 'mermaid-js:develop' into standardized-pie-definitions
Yokozuna59 Aug 5, 2023
e6a18ee
Merge remote-tracking branch upstream/develop into standardized-pie-d…
Yokozuna59 Aug 6, 2023
9563b22
refactor `pieRenderer`
Yokozuna59 Aug 6, 2023
9638060
Merge remote-tracking branch 'upstream/develop' into standardized-pie…
Yokozuna59 Aug 8, 2023
5485517
remove SVG import logs in `setupGraphViewbox`
Yokozuna59 Aug 8, 2023
ca1cdb1
remove unused `HTML` import in pieRenderer
Yokozuna59 Aug 8, 2023
820cc48
Merge remote-tracking branch 'upstream/develop' into standardized-pie…
Yokozuna59 Aug 9, 2023
a69a97f
remove unnecessary lines in pie files
Yokozuna59 Aug 9, 2023
453c67e
remove `PieDiagramConfig` and import generated one
Yokozuna59 Aug 9, 2023
38dc17f
use `structedClone` in `pieDb`
Yokozuna59 Aug 9, 2023
545d361
rename `reset` to `resetConfig`
Yokozuna59 Aug 10, 2023
a9681d1
add `resetConfig` to `clear` in pieDb
Yokozuna59 Aug 10, 2023
fb49f25
add more types to pieRenderer
Yokozuna59 Aug 10, 2023
c411354
Merge remote-tracking branch 'upstream/develop' into standardized-pie…
Yokozuna59 Aug 10, 2023
be106be
create `structuredCleanClone` helper function
Yokozuna59 Aug 10, 2023
3f5da06
move db assignment from `beforeEach` to `beforeAll`
Yokozuna59 Aug 10, 2023
cc70d37
chore: Rename utils.spec.ts
sidharthv96 Aug 10, 2023
396bda8
feat: Add cleanAndMerge and tests
sidharthv96 Aug 10, 2023
dfeb251
remove cleanClone
sidharthv96 Aug 10, 2023
a5a3ffc
Merge pull request #2 from mermaid-js/sidv/cleanMerge
Yokozuna59 Aug 10, 2023
120bdab
Merge branch 'develop' into standardized-pie-definitions
Yokozuna59 Aug 10, 2023
1721282
Merge branch 'develop' into standardized-pie-definitions
Yokozuna59 Aug 10, 2023
8a8e062
cleanAndMerge pieConfig
Yokozuna59 Aug 11, 2023
f9d9788
Merge branch 'develop' into standardized-pie-definitions
Yokozuna59 Aug 11, 2023
f01ad64
Merge remote-tracking branch 'upstream/develop' into standardized-pie…
Yokozuna59 Aug 11, 2023
cb5f70c
add `structuredClone` in pie `getConfig`
Yokozuna59 Aug 12, 2023
3f3a734
remove `setConfig` and `resetConfig` in pie
Yokozuna59 Aug 12, 2023
0d179c5
Merge branch 'develop' into standardized-pie-definitions
Yokozuna59 Aug 15, 2023
c1b9c54
use `DiagramStylesProvider` in `pieStyles.ts`
Yokozuna59 Aug 15, 2023
744cc79
Merge branch 'develop' into standardized-pie-definitions
Yokozuna59 Aug 15, 2023
defe406
change `defaultConfig` type to `RequiredDeep` and use it in `pieDb`
Yokozuna59 Aug 16, 2023
6214208
Update docs
Yokozuna59 Aug 16, 2023
77d8e15
remove `chart` from `pie.spec.ts` description
Yokozuna59 Aug 16, 2023
02daf54
Merge branch 'standardized-pie-definitions' of https://github.com/Yok…
Yokozuna59 Aug 16, 2023
e7ee3eb
Merge branch 'develop' into standardized-pie-definitions
Yokozuna59 Aug 18, 2023
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
13 changes: 0 additions & 13 deletions __mocks__/pieRenderer.js

This file was deleted.

8 changes: 8 additions & 0 deletions __mocks__/pieRenderer.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,8 @@
/**
* Mocked pie (picChart) diagram renderer
*/
import { vi } from 'vitest';

const draw = vi.fn().mockImplementation(() => '');

export const renderer = { draw };
Original file line number Diff line number Diff line change
@@ -1,89 +1,85 @@
import { imgSnapshotTest, renderGraph } from '../../helpers/util.ts';

describe('Pie Chart', () => {
describe('pie chart', () => {
Yokozuna59 marked this conversation as resolved.
Show resolved Hide resolved
it('should render a simple pie diagram', () => {
imgSnapshotTest(
`pie title Sports in Sweden
"Bandy": 40
"Ice-Hockey": 80
"Football": 90
`
pie title Sports in Sweden
"Bandy" : 40
"Ice-Hockey" : 80
"Football" : 90
`,
{}
);
cy.get('svg');
});

it('should render a simple pie diagram with long labels', () => {
imgSnapshotTest(
`pie title NETFLIX
"Time spent looking for movie": 90
"Time spent watching it": 10
`
pie title NETFLIX
"Time spent looking for movie" : 90
"Time spent watching it" : 10
`,
{}
);
cy.get('svg');
});

it('should render a simple pie diagram with capital letters for labels', () => {
imgSnapshotTest(
`pie title What Voldemort doesn't have?
"FRIENDS": 2
"FAMILY": 3
"NOSE": 45
`
pie title What Voldemort doesn't have?
"FRIENDS" : 2
"FAMILY" : 3
"NOSE" : 45
`,
{}
Yokozuna59 marked this conversation as resolved.
Show resolved Hide resolved
);
cy.get('svg');
});

it('should render a pie diagram when useMaxWidth is true (default)', () => {
renderGraph(
`
pie title Sports in Sweden
"Bandy" : 40
"Ice-Hockey" : 80
"Football" : 90
`pie title Sports in Sweden
"Bandy": 40
"Ice-Hockey": 80
"Football": 90
`,
{ pie: { useMaxWidth: true } }
);
cy.get('svg').should((svg) => {
expect(svg).to.have.attr('width', '100%');
// expect(svg).to.have.attr('height');
// const height = parseFloat(svg.attr('height'));
// expect(height).to.eq(450);
const style = svg.attr('style');
expect(style).to.match(/^max-width: [\d.]+px;$/);
const maxWidthValue = parseFloat(style.match(/[\d.]+/g).join(''));
expect(maxWidthValue).to.eq(984);
});
});

it('should render a pie diagram when useMaxWidth is false', () => {
renderGraph(
`
pie title Sports in Sweden
"Bandy" : 40
"Ice-Hockey" : 80
"Football" : 90
`pie title Sports in Sweden
"Bandy": 40
"Ice-Hockey": 80
"Football": 90
`,
{ pie: { useMaxWidth: false } }
);
cy.get('svg').should((svg) => {
// const height = parseFloat(svg.attr('height'));
const width = parseFloat(svg.attr('width'));
// expect(height).to.eq(450);
expect(width).to.eq(984);
expect(svg).to.not.have.attr('style');
});
});
it('should render a pie diagram when textPosition is set', () => {

it('should render a pie diagram when textPosition is setted', () => {
imgSnapshotTest(
`
pie
"Dogs": 50
"Cats": 25
`,
`pie
"Dogs": 50
"Cats": 25
`,
{ logLevel: 1, pie: { textPosition: 0.9 } }
);
cy.get('svg');
});

it('should render a pie diagram with showData', () => {
imgSnapshotTest(
`pie showData
"Dogs": 50
"Cats": 25
`
);
});
});
32 changes: 13 additions & 19 deletions demos/pie.html
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,6 @@
<link rel="icon" type="image/png" href="" />
<style>
div.mermaid {
/* font-family: 'trebuchet ms', verdana, arial; */
font-family: 'Courier New', Courier, monospace !important;
}
</style>
Expand All @@ -17,37 +16,32 @@
<h1>Pie chart demos</h1>
<pre class="mermaid">
pie title Pets adopted by volunteers
accTitle: simple pie char demo
accDescr: pie chart with 3 sections: dogs, cats, rats. Most are dogs.
"Dogs" : 386
"Cats" : 85
"Rats" : 15
accTitle: simple pie char demo
accDescr: pie chart with 3 sections: dogs, cats, rats. Most are dogs.
"Dogs": 386
"Cats": 85
"Rats": 15
</pre>

<hr />
<pre class="mermaid">
%%{init: {"pie": {"textPosition": 0.9}, "themeVariables": {"pieOuterStrokeWidth": "5px"}} }%%
pie
title Key elements in Product X
%%{init: {"pie": {"textPosition": 0.9}, "themeVariables": {"pieOuterStrokeWidth": "5px"}}}%%
pie
title Key elements in Product X
accTitle: Key elements in Product X
accDescr: This is a pie chart showing the key elements in Product X.
"Calcium" : 42.96
"Potassium" : 50.05
"Magnesium" : 10.01
"Iron" : 5
accDescr: This is a pie chart showing the key elements in Product X.
"Calcium": 42.96
"Potassium": 50.05
"Magnesium": 10.01
"Iron": 5
</pre>

<script type="module">
import mermaid from './mermaid.esm.mjs';
mermaid.initialize({
theme: 'forest',
// themeCSS: '.node rect { fill: red; }',
logLevel: 3,
securityLevel: 'loose',
// flowchart: { curve: 'basis' },
// gantt: { axisFormat: '%m/%d/%Y' },
sequence: { actorMargin: 50 },
// sequenceDiagram: { actorMargin: 300 } // deprecated
});
</script>
</body>
Expand Down
6 changes: 3 additions & 3 deletions docs/config/setup/modules/defaultConfig.md
Original file line number Diff line number Diff line change
Expand Up @@ -14,13 +14,13 @@

#### Defined in

[defaultConfig.ts:266](https://github.com/mermaid-js/mermaid/blob/master/packages/mermaid/src/defaultConfig.ts#L266)
[defaultConfig.ts:268](https://github.com/mermaid-js/mermaid/blob/master/packages/mermaid/src/defaultConfig.ts#L268)

---

### default

• `Const` **default**: `Partial`<`MermaidConfig`>
• `Const` **default**: `RequiredDeep`<`MermaidConfig`>

Default mermaid configuration options.

Expand All @@ -30,4 +30,4 @@ Non-JSON JS default values are listed in this file, e.g. functions, or

#### Defined in

[defaultConfig.ts:16](https://github.com/mermaid-js/mermaid/blob/master/packages/mermaid/src/defaultConfig.ts#L16)
[defaultConfig.ts:18](https://github.com/mermaid-js/mermaid/blob/master/packages/mermaid/src/defaultConfig.ts#L18)
3 changes: 3 additions & 0 deletions packages/mermaid/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -84,7 +84,9 @@
"@types/cytoscape": "^3.19.9",
"@types/d3": "^7.4.0",
"@types/d3-sankey": "^0.12.1",
"@types/d3-scale": "^4.0.3",
"@types/d3-selection": "^3.0.5",
"@types/d3-shape": "^3.1.1",
"@types/dompurify": "^3.0.2",
"@types/jsdom": "^21.1.1",
"@types/lodash-es": "^4.17.7",
Expand Down Expand Up @@ -113,6 +115,7 @@
"remark-gfm": "^3.0.1",
"rimraf": "^5.0.0",
"start-server-and-test": "^2.0.0",
"type-fest": "^4.1.0",
"typedoc": "^0.24.5",
"typedoc-plugin-markdown": "^3.15.2",
"typescript": "^5.0.4",
Expand Down
8 changes: 5 additions & 3 deletions packages/mermaid/src/defaultConfig.ts
Original file line number Diff line number Diff line change
@@ -1,5 +1,7 @@
import type { RequiredDeep } from 'type-fest';

import theme from './themes/index.js';
import { type MermaidConfig } from './config.type.js';
import type { MermaidConfig } from './config.type.js';

// Uses our custom Vite jsonSchemaPlugin to load only the default values from
// our JSON Schema
Expand All @@ -13,7 +15,7 @@ import defaultConfigJson from './schemas/config.schema.yaml?only-defaults=true';
* Non-JSON JS default values are listed in this file, e.g. functions, or
* `undefined` (explicitly set so that `configKeys` finds them).
*/
const config: Partial<MermaidConfig> = {
const config: RequiredDeep<MermaidConfig> = {
...defaultConfigJson,
// Set, even though they're `undefined` so that `configKeys` finds these keys
// TODO: Should we replace these with `null` so that they can go in the JSON Schema?
Expand Down Expand Up @@ -232,7 +234,7 @@ const config: Partial<MermaidConfig> = {
},
pie: {
...defaultConfigJson.pie,
useWidth: undefined,
useWidth: 984,
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Why do we switch to exact width and to this strange value? I needed exact width only once, when I failed to calculate this properly...

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

It's not strange, it's the default one expected in cypress.

The width defined in pie is possibly undefined, so we use this value if it doesn't exists.

See #4501 (comment)

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@Yokozuna59 please don't self-resolve comments like this one. Resolving this comment is fine, as you did an action that the reviewer was asking, and it was straightforward.

In this case, the comment was a question, which you answered correctly. But you don't know if @nirname has seen the answer, or has any follow-up questions. The only way for @nirname to see your answer would be to click on each resolved comment to see which one it was. As you know, some PRs have many comments, and it would not be practical to go through each. :)

Leaving the comments unresolved makes the life of the reviewer easy. In case comments are left unresolved for a long time, other maintainers will handle it (By resolving it, or merging without resolving).

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@sidharthv96 Okay.

GitHub sends emails to subscribers when new actions occurs, so they'll be notified by an email.
And GitHub would also mark the PR/issue with blue circle showing that it has new actions.

:)

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

GitHub sends emails to subscribers when new actions occurs, so they'll be notified by an email.

Yeah, and in active PRs, there are many comments and emails going out. And Gmail sometimes collapses the thread. So I, personally, rarely check email for PR comments.

And GitHub would also mark the PR/issue with blue circle showing that it has new actions.

But we won't know which comments were resolved recently when opening the PR. Everything would just be resolved and collapsed.

},
requirement: {
...defaultConfigJson.requirement,
Expand Down
2 changes: 1 addition & 1 deletion packages/mermaid/src/diagram-api/diagram-orchestration.ts
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,7 @@ import er from '../diagrams/er/erDetector.js';
import git from '../diagrams/git/gitGraphDetector.js';
import gantt from '../diagrams/gantt/ganttDetector.js';
import { info } from '../diagrams/info/infoDetector.js';
import pie from '../diagrams/pie/pieDetector.js';
import { pie } from '../diagrams/pie/pieDetector.js';
import quadrantChart from '../diagrams/quadrant-chart/quadrantDetector.js';
import requirement from '../diagrams/requirement/requirementDetector.js';
import sequence from '../diagrams/sequence/sequenceDetector.js';
Expand Down
12 changes: 10 additions & 2 deletions packages/mermaid/src/diagram-api/types.ts
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
import { Diagram } from '../Diagram.js';
import type { MermaidConfig } from '../config.type.js';
import type { BaseDiagramConfig, MermaidConfig } from '../config.type.js';
import type * as d3 from 'd3';

export interface InjectUtils {
Expand All @@ -16,11 +16,19 @@ export interface InjectUtils {
* Generic Diagram DB that may apply to any diagram type.
*/
export interface DiagramDB {
// config
getConfig?: () => BaseDiagramConfig | undefined;

// db
clear?: () => void;
setDiagramTitle?: (title: string) => void;
setDisplayMode?: (title: string) => void;
getDiagramTitle?: () => string;
setAccTitle?: (title: string) => void;
getAccTitle?: () => string;
setAccDescription?: (describetion: string) => void;
getAccDescription?: () => string;

setDisplayMode?: (title: string) => void;
bindFunctions?: (element: Element) => void;
}

Expand Down
10 changes: 0 additions & 10 deletions packages/mermaid/src/diagrams/pie/amonts.csv

This file was deleted.

Loading