Skip to content

Commit

Permalink
Added support for entity codes so that it for instance is possible to…
Browse files Browse the repository at this point in the history
… represent a " with #quot; and a heart with #9829; This differs from the regular html codes in that the leading & isreplaced with a dsh and for dec codes dropped. This as referenced in issue #219.
  • Loading branch information
knsv committed Oct 3, 2015
1 parent cb5e88c commit a2b6bc5
Show file tree
Hide file tree
Showing 12 changed files with 129 additions and 46 deletions.
29 changes: 25 additions & 4 deletions dist/mermaid.js
Original file line number Diff line number Diff line change
Expand Up @@ -32727,11 +32727,10 @@ var setupToolTips = function(element){

tooltipElem.transition()
.duration(200)
.style("opacity", .9);
.style("opacity", '.9');
tooltipElem.html(el.attr('title'))
.style("left", (rect.left+(rect.right-rect.left)/2) + "px")
.style("top", (rect.top-14+document.body.scrollTop) + "px");
var el = d3.select(this);
el.classed('hover',true);

})
Expand Down Expand Up @@ -37427,6 +37426,7 @@ exports.getNoteRect = function(){
var mermaidAPI = _dereq_('./mermaidAPI');
var nextId = 0;
var log = _dereq_('./logger').create();
var utils = _dereq_('./utils');

module.exports.mermaidAPI = mermaidAPI;
/**
Expand Down Expand Up @@ -37529,12 +37529,33 @@ var init = function () {
txt = txt.replace(/>/g,'>');
txt = txt.replace(/</g,'&lt;');
txt = he.decode(txt).trim();

txt = exports.encodeEntities(txt);
if( utils.detectType(txt) === 'sequenceDiagram'){
txt = he.decode(txt).trim();
}
mermaidAPI.render(id,txt,insertSvg, element);
}

};

exports.encodeEntities = function(text){
var txt = text;

txt = txt.replace(/#\w*;?/g,function(s,t,u){
var innerTxt = s.substring(1,s.length-1);

var isInt = /^\+?\d+$/.test(innerTxt);
if(isInt){
return '&#'+innerTxt+';';
}else{
return '&'+innerTxt+';';
}

});

return txt;
};

exports.init = init;
exports.parse = mermaidAPI.parse;
/**
Expand Down Expand Up @@ -37678,7 +37699,7 @@ if(typeof document !== 'undefined'){
//}));

}).call(this,typeof self !== "undefined" ? self : typeof window !== "undefined" ? window : {})
},{"../package.json":86,"./logger":104,"./mermaidAPI":105,"he":84}],104:[function(_dereq_,module,exports){
},{"../package.json":86,"./logger":104,"./mermaidAPI":105,"./utils":106,"he":84}],104:[function(_dereq_,module,exports){
(function (process){
/**
* #logger
Expand Down
26 changes: 13 additions & 13 deletions dist/mermaid.min.js

Large diffs are not rendered by default.

29 changes: 25 additions & 4 deletions dist/mermaid.slim.js
Original file line number Diff line number Diff line change
Expand Up @@ -23511,11 +23511,10 @@ var setupToolTips = function(element){

tooltipElem.transition()
.duration(200)
.style("opacity", .9);
.style("opacity", '.9');
tooltipElem.html(el.attr('title'))
.style("left", (rect.left+(rect.right-rect.left)/2) + "px")
.style("top", (rect.top-14+document.body.scrollTop) + "px");
var el = d3.select(this);
el.classed('hover',true);

})
Expand Down Expand Up @@ -28211,6 +28210,7 @@ exports.getNoteRect = function(){
var mermaidAPI = _dereq_('./mermaidAPI');
var nextId = 0;
var log = _dereq_('./logger').create();
var utils = _dereq_('./utils');

module.exports.mermaidAPI = mermaidAPI;
/**
Expand Down Expand Up @@ -28313,12 +28313,33 @@ var init = function () {
txt = txt.replace(/>/g,'&gt;');
txt = txt.replace(/</g,'&lt;');
txt = he.decode(txt).trim();

txt = exports.encodeEntities(txt);
if( utils.detectType(txt) === 'sequenceDiagram'){
txt = he.decode(txt).trim();
}
mermaidAPI.render(id,txt,insertSvg, element);
}

};

exports.encodeEntities = function(text){
var txt = text;

txt = txt.replace(/#\w*;?/g,function(s,t,u){
var innerTxt = s.substring(1,s.length-1);

var isInt = /^\+?\d+$/.test(innerTxt);
if(isInt){
return '&#'+innerTxt+';';
}else{
return '&'+innerTxt+';';
}

});

return txt;
};

exports.init = init;
exports.parse = mermaidAPI.parse;
/**
Expand Down Expand Up @@ -28462,7 +28483,7 @@ if(typeof document !== 'undefined'){
//}));

}).call(this,typeof self !== "undefined" ? self : typeof window !== "undefined" ? window : {})
},{"../package.json":85,"./logger":103,"./mermaidAPI":104,"he":83}],103:[function(_dereq_,module,exports){
},{"../package.json":85,"./logger":103,"./mermaidAPI":104,"./utils":105,"he":83}],103:[function(_dereq_,module,exports){
(function (process){
/**
* #logger
Expand Down
6 changes: 3 additions & 3 deletions dist/mermaid.slim.min.js

Large diffs are not rendered by default.

3 changes: 1 addition & 2 deletions dist/mermaidAPI.js
Original file line number Diff line number Diff line change
Expand Up @@ -32394,11 +32394,10 @@ var setupToolTips = function(element){

tooltipElem.transition()
.duration(200)
.style("opacity", .9);
.style("opacity", '.9');
tooltipElem.html(el.attr('title'))
.style("left", (rect.left+(rect.right-rect.left)/2) + "px")
.style("top", (rect.top-14+document.body.scrollTop) + "px");
var el = d3.select(this);
el.classed('hover',true);

})
Expand Down
5 changes: 2 additions & 3 deletions dist/mermaidAPI.slim.js

Large diffs are not rendered by default.

2 changes: 1 addition & 1 deletion dist/mermaidAPI.slim.min.js

Large diffs are not rendered by default.

2 changes: 2 additions & 0 deletions docs/content/flowchart.md
Original file line number Diff line number Diff line change
Expand Up @@ -211,6 +211,8 @@ graph LR
graph LR
id1["This is the (text) in the box"]
```

### Another possibility is to use the entity codes
## Subgraphs

```
Expand Down
3 changes: 1 addition & 2 deletions src/diagrams/flowchart/graphDb.js
Original file line number Diff line number Diff line change
Expand Up @@ -254,11 +254,10 @@ var setupToolTips = function(element){

tooltipElem.transition()
.duration(200)
.style("opacity", .9);
.style("opacity", '.9');
tooltipElem.html(el.attr('title'))
.style("left", (rect.left+(rect.right-rect.left)/2) + "px")
.style("top", (rect.top-14+document.body.scrollTop) + "px");
var el = d3.select(this);
el.classed('hover',true);

})
Expand Down
24 changes: 23 additions & 1 deletion src/mermaid.js
Original file line number Diff line number Diff line change
Expand Up @@ -20,6 +20,7 @@
var mermaidAPI = require('./mermaidAPI');
var nextId = 0;
var log = require('./logger').create();
var utils = require('./utils');

module.exports.mermaidAPI = mermaidAPI;
/**
Expand Down Expand Up @@ -122,12 +123,33 @@ var init = function () {
txt = txt.replace(/>/g,'&gt;');
txt = txt.replace(/</g,'&lt;');
txt = he.decode(txt).trim();

txt = exports.encodeEntities(txt);
if( utils.detectType(txt) === 'sequenceDiagram'){
txt = he.decode(txt).trim();
}
mermaidAPI.render(id,txt,insertSvg, element);
}

};

exports.encodeEntities = function(text){
var txt = text;

txt = txt.replace(/#\w*;?/g,function(s,t,u){
var innerTxt = s.substring(1,s.length-1);

var isInt = /^\+?\d+$/.test(innerTxt);
if(isInt){
return '&#'+innerTxt+';';
}else{
return '&'+innerTxt+';';
}

});

return txt;
};

exports.init = init;
exports.parse = mermaidAPI.parse;
/**
Expand Down
29 changes: 29 additions & 0 deletions test/examples/entityCodes.html
Original file line number Diff line number Diff line change
@@ -0,0 +1,29 @@
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">

<link rel="stylesheet" href="../../dist/mermaid.css"/>
<script src="../../dist/mermaid.js"></script>
<style>
body{
background-color: #89896f;
}

</style>

</head>
<body>
<h1>Qutotes to callbacks</h1>
<div class="mermaid" id="i211">
graph LR
A["A double quote:#quot;"] -->B["A dec char:#9829;"]
B -->C["#9829; ;^; #9829;"]
</div>
<div class="mermaid" id="i211">
sequenceDiagram
Alice->>John: Hello John, how are you?&#9829;
John-->>Alice: Great!&quot;
</div>
</body>
</html>
17 changes: 4 additions & 13 deletions test/examples/interactionAndTooltips.html
Original file line number Diff line number Diff line change
Expand Up @@ -23,7 +23,9 @@
</head>
<body>
<h1>Links to callbacks</h1>
A has a tooltip
A has a tooltip and a callback <br/>
B has a link and a tooltip <br/>
C has a long tooltip <br/>
<div class="mermaid" id="i211">
graph LR;
A-->B;
Expand All @@ -34,23 +36,12 @@ <h1>Links to callbacks</h1>
</div>

<h1>Links to urls</h1>
A second diagram that should have its own callback on A even though the node has the same id.
<div class="mermaid" id="i213">
graph LR;
A-->B
B-->C
click A callback2 "Tooltip3"
</div>
<div class="mermaid" id="i213">
graph LR;
subgraph S1
a-->b
end
subgraph S2
c-->d
c-->d
end

</div>

</body>
</html>

0 comments on commit a2b6bc5

Please sign in to comment.