mirror of
https://github.com/mermaid-js/mermaid.git
synced 2025-09-20 15:59:51 +02:00
trim state ids as they are processed by docTranslator
This commit is contained in:

parent
90d9724d1a
commit
e7b4f7f6ca
@@ -94,9 +94,14 @@ const docTranslator = (parent, node, first) => {
|
|||||||
docTranslator(parent, node.state1, true);
|
docTranslator(parent, node.state1, true);
|
||||||
docTranslator(parent, node.state2, false);
|
docTranslator(parent, node.state2, false);
|
||||||
} else {
|
} else {
|
||||||
if (node.stmt === STMT_STATE && node.id === '[*]') {
|
if (node.stmt === STMT_STATE) {
|
||||||
node.id = first ? parent.id + '_start' : parent.id + '_end';
|
if (node.id === '[*]') {
|
||||||
node.start = first;
|
node.id = first ? parent.id + '_start' : parent.id + '_end';
|
||||||
|
node.start = first;
|
||||||
|
} else {
|
||||||
|
// This is just a plain state, not a start or end
|
||||||
|
node.id = node.id.trim();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (node.doc) {
|
if (node.doc) {
|
||||||
@@ -170,7 +175,7 @@ const extract = (_doc) => {
|
|||||||
switch (item.stmt) {
|
switch (item.stmt) {
|
||||||
case STMT_STATE:
|
case STMT_STATE:
|
||||||
addState(
|
addState(
|
||||||
item.id,
|
item.id.trim(),
|
||||||
item.type,
|
item.type,
|
||||||
item.doc,
|
item.doc,
|
||||||
item.description,
|
item.description,
|
||||||
@@ -184,10 +189,10 @@ const extract = (_doc) => {
|
|||||||
addRelation(item.state1, item.state2, item.description);
|
addRelation(item.state1, item.state2, item.description);
|
||||||
break;
|
break;
|
||||||
case STMT_CLASSDEF:
|
case STMT_CLASSDEF:
|
||||||
addStyleClass(item.id, item.classes);
|
addStyleClass(item.id.trim(), item.classes);
|
||||||
break;
|
break;
|
||||||
case STMT_APPLYCLASS:
|
case STMT_APPLYCLASS:
|
||||||
setCssClass(item.id, item.styleClass);
|
setCssClass(item.id.trim(), item.styleClass);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
@@ -215,11 +220,12 @@ export const addState = function (
|
|||||||
styles = null,
|
styles = null,
|
||||||
textStyles = null
|
textStyles = null
|
||||||
) {
|
) {
|
||||||
|
const trimmedId = id?.trim();
|
||||||
// add the state if needed
|
// add the state if needed
|
||||||
if (currentDocument.states[id] === undefined) {
|
if (currentDocument.states[trimmedId] === undefined) {
|
||||||
log.info('Adding state ', id, descr);
|
log.info('Adding state ', trimmedId, descr);
|
||||||
currentDocument.states[id] = {
|
currentDocument.states[trimmedId] = {
|
||||||
id: id,
|
id: trimmedId,
|
||||||
descriptions: [],
|
descriptions: [],
|
||||||
type,
|
type,
|
||||||
doc,
|
doc,
|
||||||
@@ -229,49 +235,49 @@ export const addState = function (
|
|||||||
textStyles: [],
|
textStyles: [],
|
||||||
};
|
};
|
||||||
} else {
|
} else {
|
||||||
if (!currentDocument.states[id].doc) {
|
if (!currentDocument.states[trimmedId].doc) {
|
||||||
currentDocument.states[id].doc = doc;
|
currentDocument.states[trimmedId].doc = doc;
|
||||||
}
|
}
|
||||||
if (!currentDocument.states[id].type) {
|
if (!currentDocument.states[trimmedId].type) {
|
||||||
currentDocument.states[id].type = type;
|
currentDocument.states[trimmedId].type = type;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (descr) {
|
if (descr) {
|
||||||
log.info('Setting state description', id, descr);
|
log.info('Setting state description', trimmedId, descr);
|
||||||
if (typeof descr === 'string') {
|
if (typeof descr === 'string') {
|
||||||
addDescription(id, descr.trim());
|
addDescription(trimmedId, descr.trim());
|
||||||
}
|
}
|
||||||
|
|
||||||
if (typeof descr === 'object') {
|
if (typeof descr === 'object') {
|
||||||
descr.forEach((des) => addDescription(id, des.trim()));
|
descr.forEach((des) => addDescription(trimmedId, des.trim()));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (note) {
|
if (note) {
|
||||||
currentDocument.states[id].note = note;
|
currentDocument.states[trimmedId].note = note;
|
||||||
currentDocument.states[id].note.text = common.sanitizeText(
|
currentDocument.states[trimmedId].note.text = common.sanitizeText(
|
||||||
currentDocument.states[id].note.text,
|
currentDocument.states[trimmedId].note.text,
|
||||||
configApi.getConfig()
|
configApi.getConfig()
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (classes) {
|
if (classes) {
|
||||||
log.info('Setting state classes', id, classes);
|
log.info('Setting state classes', trimmedId, classes);
|
||||||
const classesList = typeof classes === 'string' ? [classes] : classes;
|
const classesList = typeof classes === 'string' ? [classes] : classes;
|
||||||
classesList.forEach((klass) => setCssClass(id, klass.trim()));
|
classesList.forEach((klass) => setCssClass(trimmedId, klass.trim()));
|
||||||
}
|
}
|
||||||
|
|
||||||
if (styles) {
|
if (styles) {
|
||||||
log.info('Setting state styles', id, styles);
|
log.info('Setting state styles', trimmedId, styles);
|
||||||
const stylesList = typeof styles === 'string' ? [styles] : styles;
|
const stylesList = typeof styles === 'string' ? [styles] : styles;
|
||||||
stylesList.forEach((style) => setStyle(id, style.trim()));
|
stylesList.forEach((style) => setStyle(trimmedId, style.trim()));
|
||||||
}
|
}
|
||||||
|
|
||||||
if (textStyles) {
|
if (textStyles) {
|
||||||
log.info('Setting state styles', id, styles);
|
log.info('Setting state styles', trimmedId, styles);
|
||||||
const textStylesList = typeof textStyles === 'string' ? [textStyles] : textStyles;
|
const textStylesList = typeof textStyles === 'string' ? [textStyles] : textStyles;
|
||||||
textStylesList.forEach((textStyle) => setTextStyle(id, textStyle.trim()));
|
textStylesList.forEach((textStyle) => setTextStyle(trimmedId, textStyle.trim()));
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
@@ -368,10 +374,10 @@ function endTypeIfNeeded(id = '', type = DEFAULT_STATE_TYPE) {
|
|||||||
* @param relationTitle
|
* @param relationTitle
|
||||||
*/
|
*/
|
||||||
export function addRelationObjs(item1, item2, relationTitle) {
|
export function addRelationObjs(item1, item2, relationTitle) {
|
||||||
let id1 = startIdIfNeeded(item1.id);
|
let id1 = startIdIfNeeded(item1.id.trim());
|
||||||
let type1 = startTypeIfNeeded(item1.id, item1.type);
|
let type1 = startTypeIfNeeded(item1.id.trim(), item1.type);
|
||||||
let id2 = startIdIfNeeded(item2.id);
|
let id2 = startIdIfNeeded(item2.id.trim());
|
||||||
let type2 = startTypeIfNeeded(item2.id, item2.type);
|
let type2 = startTypeIfNeeded(item2.id.trim(), item2.type);
|
||||||
|
|
||||||
addState(
|
addState(
|
||||||
id1,
|
id1,
|
||||||
@@ -412,9 +418,9 @@ export const addRelation = function (item1, item2, title) {
|
|||||||
if (typeof item1 === 'object') {
|
if (typeof item1 === 'object') {
|
||||||
addRelationObjs(item1, item2, title);
|
addRelationObjs(item1, item2, title);
|
||||||
} else {
|
} else {
|
||||||
const id1 = startIdIfNeeded(item1);
|
const id1 = startIdIfNeeded(item1.trim());
|
||||||
const type1 = startTypeIfNeeded(item1);
|
const type1 = startTypeIfNeeded(item1);
|
||||||
const id2 = endIdIfNeeded(item2);
|
const id2 = endIdIfNeeded(item2.trim());
|
||||||
const type2 = endTypeIfNeeded(item2);
|
const type2 = endTypeIfNeeded(item2);
|
||||||
|
|
||||||
addState(id1, type1);
|
addState(id1, type1);
|
||||||
|
Reference in New Issue
Block a user