Skip to content
Closed
Show file tree
Hide file tree
Changes from all commits
Commits
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
25 changes: 22 additions & 3 deletions docs/userGuide/puml.md
Original file line number Diff line number Diff line change
Expand Up @@ -34,12 +34,15 @@ Name | Type | Default | Description
--- | --- | --- | ---
alt | `string` | | **This must be specified.**<br>The alternative text of the diagram.
height | `string` | | The height of the diagram in pixels.
src | `string` | | **This must be specified.**<br>The URL of the diagram.<br>The URL can be specified as absolute or relative references. More info in: _[Intra-Site Links]({{baseUrl}}/userGuide/formattingContents.html#intraSiteLinks)_
src | `string` | | <br>The URL of the diagram if your PUML input is in another file.<br>The URL can be specified as absolute or relative references. More info in: _[Intra-Site Links]({{baseUrl}}/userGuide/formattingContents.html#intraSiteLinks)_
name | `string` | | The name of the output file.
width | `string` | | The width of the diagram in pixels.<br>If both width and height are specified, width takes priority over height. It is to maintain the diagram's aspect ratio.


### Example

You could have your PUML be written in a separate file or inline.

<include src="outputBox.md" boilerplate>
<span id="code">

Expand All @@ -57,17 +60,33 @@ return success
@enduml
```

_Markbind page_:
_Markbind page separate file_:
```
<puml src="diagrams/sequence.puml" width=300/>
```

_Markbind page inline_:
`````
<puml width=300/>

```puml
@startuml
alice -> bob ++ : hello
bob -> bob ++ : self call
bob -> bib ++ #005500 : hello
bob -> george ** : create
return done
return rc
bob -> george !! : delete
return success
@enduml
```
`````
</span>

<span id="output">
<pic src="diagrams/sequence.png" width="300" />
</span>

</include>

<box type="info">
Expand Down
46 changes: 16 additions & 30 deletions package-lock.json

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

1 change: 1 addition & 0 deletions package.json
Original file line number Diff line number Diff line change
Expand Up @@ -26,6 +26,7 @@
"cheerio": "^0.22.0",
"chokidar": "^3.3.0",
"commander": "^3.0.2",
"crypto-js": "^3.1.0",
"fastmatter": "^2.1.1",
"figlet": "^1.2.4",
"find-up": "^4.1.0",
Expand Down
1 change: 1 addition & 0 deletions src/Page.js
Original file line number Diff line number Diff line change
Expand Up @@ -761,6 +761,7 @@ class Page {
rootPath: this.rootPath,
userDefinedVariablesMap: this.userDefinedVariablesMap,
headerIdMap: this.headerIdMap,
resultPath: this.resultPath,
};
return new Promise((resolve, reject) => {
markbinder.includeFile(this.sourcePath, fileConfig)
Expand Down
1 change: 1 addition & 0 deletions src/lib/markbind/src/constants.js
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,7 @@ module.exports = {
// src/lib/markbind/src/parser.js
ATTRIB_INCLUDE_PATH: 'include-path',
ATTRIB_CWF: 'cwf',
ATTRIB_RESULT_PATH: 'resultPath',

BOILERPLATE_FOLDER_NAME: '_markbind/boilerplates',

Expand Down
25 changes: 25 additions & 0 deletions src/lib/markbind/src/lib/markdown-it/index.js
Original file line number Diff line number Diff line change
Expand Up @@ -42,6 +42,31 @@ markdownIt.renderer.rules.table_close = (tokens, idx) => {
return '</table></div>';
};

// rewritten markdown-it renderer.js rule to add a div containing the language of the code block
markdownIt.renderer.rules.fence = (tokens, idx, options, env, slf) => {
var token = tokens[idx],
info = token.info ? markdownIt.utils.unescapeAll(token.info).trim() : '',
langName = '',
highlighted;

if (info) {
langName = info.split(/\s+/g)[0];
}

const widgetHandler = env[langName];
if (widgetHandler !== undefined) {
return widgetHandler(token.content);
}

if (options.highlight) {
highlighted = options.highlight(token.content, langName) || escapeHtml(token.content);
} else {
highlighted = escapeHtml(token.content);
}

return highlighted + '\n';
}

// highlight inline code
markdownIt.renderer.rules.code_inline = (tokens, idx, options, env, slf) => {
const token = tokens[idx];
Expand Down
8 changes: 8 additions & 0 deletions src/lib/markbind/src/parser.js
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,7 @@ const url = require('url');
const pathIsInside = require('path-is-inside');
const slugify = require('@sindresorhus/slugify');
const componentParser = require('./parsers/componentParser');
const widget = require('../../../widgets/widgets');

const _ = {};
_.clone = require('lodash/clone');
Expand Down Expand Up @@ -383,6 +384,10 @@ class Parser {
element.children = element.children.map(e => self._preprocess(e, context, config));
}
}


widget.preprocessWidget(config, context, element);

return element;
}

Expand Down Expand Up @@ -512,6 +517,8 @@ class Parser {
break;
}

widget.parseWidget(config, context, element);

componentParser.parseComponents(element, this._onError);

if (element.children) {
Expand Down Expand Up @@ -568,6 +575,7 @@ class Parser {
}
return processed;
});

resolve(cheerio.html(nodes));
});

Expand Down
18 changes: 18 additions & 0 deletions src/lib/markbind/src/utils.js
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
const fs = require('fs');
const path = require('path');
const cheerio = require('cheerio');

const { markdownFileExts } = require('./constants');

Expand Down Expand Up @@ -100,4 +101,21 @@ module.exports = {

return text.join('').trim();
},

extractCodeElement(element, codeLanguage = '') {
let codeBlockElement = cheerio.parseHTML('<div></div>', true)[0];

element.children.forEach((child) => {
if (child.name === 'pre' && child.children.length >= 1) {
const [nestedChild] = child.children;
if (nestedChild.name !== 'code') {
return;
}
[codeBlockElement] = nestedChild.children;
codeBlockElement.data = `\`\`\`${codeLanguage}\n${codeBlockElement.data}\n\`\`\``;
}
});

return codeBlockElement;
},
};
Loading