mirror of
https://github.com/mermaid-js/mermaid.git
synced 2025-09-08 18:16:44 +02:00
Merge branch 'bug/3011_multiline_alignment' of github.com:hype09/mermaid into hype09-bug/3011_multiline_alignment
This commit is contained in:
@@ -126,6 +126,17 @@ context('Sequence diagram', () => {
|
|||||||
{ sequence: { noteAlign: 'left' } }
|
{ sequence: { noteAlign: 'left' } }
|
||||||
);
|
);
|
||||||
});
|
});
|
||||||
|
it('should render multi-line notes aligned to the left when configured', () => {
|
||||||
|
imgSnapshotTest(
|
||||||
|
`
|
||||||
|
sequenceDiagram
|
||||||
|
Alice->>Bob: I'm short
|
||||||
|
note left of Alice: I am left aligned<br>but also<br>multiline
|
||||||
|
Bob->>Alice: Short as well
|
||||||
|
`,
|
||||||
|
{ sequence: { noteAlign: 'left' } }
|
||||||
|
);
|
||||||
|
});
|
||||||
it('should render notes aligned to the right when configured', () => {
|
it('should render notes aligned to the right when configured', () => {
|
||||||
imgSnapshotTest(
|
imgSnapshotTest(
|
||||||
`
|
`
|
||||||
@@ -137,6 +148,37 @@ context('Sequence diagram', () => {
|
|||||||
{ sequence: { noteAlign: 'right' } }
|
{ sequence: { noteAlign: 'right' } }
|
||||||
);
|
);
|
||||||
});
|
});
|
||||||
|
it('should render multi-line notes aligned to the right when configured', () => {
|
||||||
|
imgSnapshotTest(
|
||||||
|
`
|
||||||
|
sequenceDiagram
|
||||||
|
Alice->>Bob: I'm short
|
||||||
|
note left of Alice: I am right aligned<br>but also<br>multiline
|
||||||
|
Bob->>Alice: Short as well
|
||||||
|
`,
|
||||||
|
{ sequence: { noteAlign: 'right' } }
|
||||||
|
);
|
||||||
|
});
|
||||||
|
it('should render multi-line messages aligned to the left when configured', () => {
|
||||||
|
imgSnapshotTest(
|
||||||
|
`
|
||||||
|
sequenceDiagram
|
||||||
|
Alice->>Bob: I'm short<br>but also<br>multiline
|
||||||
|
Bob->>Alice: Short as well<br>and also<br>multiline
|
||||||
|
`,
|
||||||
|
{ sequence: { messageAlign: 'left' } }
|
||||||
|
);
|
||||||
|
});
|
||||||
|
it('should render multi-line messages aligned to the right when configured', () => {
|
||||||
|
imgSnapshotTest(
|
||||||
|
`
|
||||||
|
sequenceDiagram
|
||||||
|
Alice->>Bob: I'm short<br>but also<br>multiline
|
||||||
|
Bob->>Alice: Short as well<br>and also<br>multiline
|
||||||
|
`,
|
||||||
|
{ sequence: { messageAlign: 'right' } }
|
||||||
|
);
|
||||||
|
});
|
||||||
});
|
});
|
||||||
context('auth width scaling', () => {
|
context('auth width scaling', () => {
|
||||||
it('should render long actor descriptions', () => {
|
it('should render long actor descriptions', () => {
|
||||||
|
@@ -229,7 +229,7 @@ const drawNote = function (elem, noteModel) {
|
|||||||
textObj.fontWeight = conf.noteFontWeight;
|
textObj.fontWeight = conf.noteFontWeight;
|
||||||
textObj.anchor = conf.noteAlign;
|
textObj.anchor = conf.noteAlign;
|
||||||
textObj.textMargin = conf.noteMargin;
|
textObj.textMargin = conf.noteMargin;
|
||||||
textObj.valign = conf.noteAlign;
|
textObj.valign = 'center';
|
||||||
|
|
||||||
let textElem = drawText(g, textObj);
|
let textElem = drawText(g, textObj);
|
||||||
|
|
||||||
@@ -342,7 +342,7 @@ const drawMessage = function (diagram, msgModel, lineStarty, diagObj) {
|
|||||||
textObj.fontSize = conf.messageFontSize;
|
textObj.fontSize = conf.messageFontSize;
|
||||||
textObj.fontWeight = conf.messageFontWeight;
|
textObj.fontWeight = conf.messageFontWeight;
|
||||||
textObj.anchor = conf.messageAlign;
|
textObj.anchor = conf.messageAlign;
|
||||||
textObj.valign = conf.messageAlign;
|
textObj.valign = 'center';
|
||||||
textObj.textMargin = conf.wrapPadding;
|
textObj.textMargin = conf.wrapPadding;
|
||||||
textObj.tspan = false;
|
textObj.tspan = false;
|
||||||
|
|
||||||
|
@@ -193,7 +193,7 @@ export const drawText = function (elem, textData) {
|
|||||||
case 'start':
|
case 'start':
|
||||||
textData.x = Math.round(textData.x + textData.textMargin);
|
textData.x = Math.round(textData.x + textData.textMargin);
|
||||||
textData.anchor = 'start';
|
textData.anchor = 'start';
|
||||||
textData.dominantBaseline = 'text-after-edge';
|
textData.dominantBaseline = 'middle';
|
||||||
textData.alignmentBaseline = 'middle';
|
textData.alignmentBaseline = 'middle';
|
||||||
break;
|
break;
|
||||||
case 'middle':
|
case 'middle':
|
||||||
@@ -207,7 +207,7 @@ export const drawText = function (elem, textData) {
|
|||||||
case 'end':
|
case 'end':
|
||||||
textData.x = Math.round(textData.x + textData.width - textData.textMargin);
|
textData.x = Math.round(textData.x + textData.width - textData.textMargin);
|
||||||
textData.anchor = 'end';
|
textData.anchor = 'end';
|
||||||
textData.dominantBaseline = 'text-before-edge';
|
textData.dominantBaseline = 'middle';
|
||||||
textData.alignmentBaseline = 'middle';
|
textData.alignmentBaseline = 'middle';
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user