Skip to content

Commit

Permalink
Update README.md, comments, docstrs and style
Browse files Browse the repository at this point in the history
[skip ci]
  • Loading branch information
cslzchen committed Apr 17, 2018
1 parent 3250b3a commit 8a29a81
Show file tree
Hide file tree
Showing 6 changed files with 85 additions and 87 deletions.
72 changes: 31 additions & 41 deletions mfr/extensions/md/README.md
Original file line number Diff line number Diff line change
@@ -1,10 +1,6 @@
## Using Markdown-it with plugins

## Markdown plus Mathjax readme

Most of the packages are in there to try to match what the OSF wiki is doing. The two exceptions being markdown-it-highlightjs.js and markdown-it-mathjax.js. The highlighter matches the functionality of what is on the osf however, and the markdown-it-mathjax.js increases functionality with mathjax.

to get all the libraries needed:
Note: You do not need to use npm, you can easily get them off of github.
If we had `npm`, here were the would-be configuration.

```bash
npm [email protected]
Expand All @@ -15,38 +11,32 @@ npm install [email protected]
npm install [email protected]
```

github:

https://github.com/cos-forks/markdown-it-toc
https://github.com/valeriangalliat/markdown-it-highlightjs
https://github.com/brianjgeiger/markdown-it-ins-del
https://github.com/svbergerem/markdown-it-sanitizer
https://github.com/classeur/markdown-it-mathjax

To add a new library, you need to make sure its loadable in md.js somehow, either through exporting via `root.<name>` or some other means. Some of the markdown plugins added have custom code in them to load them into `root`.

Libraries should try to use the same version as the ones used on the OSF. The plugins do not matter as much, but `markdown-it` and `Mathjax` you should try to match exactly because styling can change between versions.

To add a new library that is not already set up to export to `root` can be a bit tricky but the gist of it is, wrap the plugin in this code:

```javascript
;(function (root, factory) {
if (typeof exports === 'object') {
module.exports = factory()
} else {
root.<PLUGIN_NAME> = factory()
}
})(this, function () {


return function(md){

.....
}

})
```

And then modify it to work in this context. See other plugins for examples.

Then in md.js, you can add a plugin to the markdown renderer by adding a `.use(window.<PLUGIN_NAME>)` after loading the file into `viewer.mako`.
For MFR, a customized local copy of each script is stored in the extension's static folder. There are a few issues:

* ES5 compatibility: use [Babel](https://babeljs.io/repl/) to convert ES6 `markdown-it-highlightjs` to ES5.

* `require` is NOT available. For `md.js` to be able to load these libraries, customization is necessary to export via `root.<PLUGIN_NAME>`.
* `markdown-it` and `markdown-it-sanitizer` are already set up to be exported code. We load the `min` version directly.
* `markdown-it-toc`, `markdown-it-highlightjs`, `markdown-it-ins-del` and `markdown-it-mathjax` are not. Here is the wrapper:
```javascript
(function (root, factory) {
if (typeof exports === "object") {
module.exports = factory();
} else {
root.<PLUGIN_NAME> = factory();
}
}) (this, function () {
return function(md/*, optional arguments*/) {
/* library code */
}
});
```

Here is a list of original copy of the scripts we use:

* [markdown-it@08.4.0](https://github.com/markdown-it/markdown-it/blob/8.4.0/bin/markdown-it.js)
* [markdown-it-sanitizer@0.4.3](https://github.com/svbergerem/markdown-it-sanitizer/blob/v0.4.3/dist/markdown-it-sanitizer.min.js)
* [markdown-it-mathjax@2.0.0](https://github.com/classeur/markdown-it-mathjax/blob/v2.0.0/markdown-it-mathjax.js)
* [markdown-it-toc@1.1.1](https://github.com/cos-forks/markdown-it-toc/blob/1.1.1/index.js)
* [markdown-it-ins-del@1.0.0](https://github.com/brianjgeiger/markdown-it-ins-del/blob/1.0.0/index.js)
* [markdown-it-higlightjs@3.0.0](https://github.com/cslzchen/markdown-it-highlightjs/blob/release/3.0.0/index.es5.js)
11 changes: 5 additions & 6 deletions mfr/extensions/md/render.py
Original file line number Diff line number Diff line change
Expand Up @@ -3,10 +3,11 @@
import bleach
from mako.lookup import TemplateLookup

from mfr.core import extension
from mfr.extensions.md.settings import BLEACH_WHITELIST
from mfr.core import extension as core_extension
from mfr.extensions.md import settings as md_settings

class MdRenderer(extension.BaseRenderer):

class MdRenderer(core_extension.BaseRenderer):

TEMPLATE = TemplateLookup(
directories=[
Expand All @@ -19,9 +20,7 @@ def __init__(self, *args, **kwargs):
def render(self):
"""Render a markdown file to html."""
with open(self.file_path, 'r') as fp:
# Bleach will bug out on unclosed tags. OSF wiki does not have this issue.
# This is due to versioning problems: https://github.com/mozilla/bleach/issues/271
body = bleach.clean(fp.read(), **BLEACH_WHITELIST)
body = bleach.clean(fp.read(), **md_settings.BLEACH_WHITELIST)
return self.TEMPLATE.render(base=self.assets_url, body=body)

@property
Expand Down
6 changes: 4 additions & 2 deletions mfr/extensions/md/settings.py
Original file line number Diff line number Diff line change
@@ -1,4 +1,6 @@
# This list comes from the OSF
# The bleach whitelist comes from OSF Wiki whitelist:
# https://github.com/CenterForOpenScience/osf.io/blob/develop/website/settings/defaults.py

BLEACH_WHITELIST = {
'tags': [
'a', 'abbr', 'acronym', 'b', 'bdo', 'big', 'blockquote', 'br',
Expand All @@ -13,7 +15,7 @@
'attributes': [
'align', 'alt', 'border', 'cite', 'class', 'dir',
'height', 'href', 'id', 'src', 'style', 'title', 'type', 'width',
'face', 'size', # font tags
'face', 'size',
'salign', 'align', 'wmode', 'target',
],
'styles': [
Expand Down
8 changes: 0 additions & 8 deletions mfr/extensions/md/static/css/default.css
Original file line number Diff line number Diff line change
@@ -1,17 +1,9 @@
@charset "utf-8";


/*Had quite a few css woes on this one
Chrome has some scroll bar issues. This is mostly due to
Iframe problems. There may be a better combination of CSS to get rid of this,
for now just going the best combination found.
*/
.mfrViewer {
font-family: 'Open Sans';
padding:1em;
background:#fefefe;
height: auto;
word-wrap: break-word;
}

44 changes: 22 additions & 22 deletions mfr/extensions/md/static/css/highlightjs-default.css
Original file line number Diff line number Diff line change
@@ -1,26 +1,26 @@
/*
Original highlight.js style (c) Ivan Sagalaev <[email protected]>
*/
/**
* Original highlight.js style (c) Ivan Sagalaev <[email protected]>
*
* https://github.com/isagalaev/highlight.js/blob/9.12.0/src/styles/default.css
*/

.hljs {
display: block;
overflow-x: auto;
padding: 0.5em;
background: #F0F0F0;
display: block;
overflow-x: auto;
padding: 0.5em;
background: #F0F0F0;
}


/* Base color: saturation 0; */

.hljs,
.hljs-subst {
color: #444;
color: #444;
}

.hljs-comment {
color: #888888;
color: #888888;
}

.hljs-keyword,
Expand All @@ -29,7 +29,7 @@ Original highlight.js style (c) Ivan Sagalaev <[email protected]>
.hljs-meta-keyword,
.hljs-doctag,
.hljs-name {
font-weight: bold;
font-weight: bold;
}


Expand All @@ -43,13 +43,13 @@ Original highlight.js style (c) Ivan Sagalaev <[email protected]>
.hljs-quote,
.hljs-template-tag,
.hljs-deletion {
color: #880000;
color: #880000;
}

.hljs-title,
.hljs-section {
color: #880000;
font-weight: bold;
color: #880000;
font-weight: bold;
}

.hljs-regexp,
Expand All @@ -59,41 +59,41 @@ Original highlight.js style (c) Ivan Sagalaev <[email protected]>
.hljs-link,
.hljs-selector-attr,
.hljs-selector-pseudo {
color: #BC6060;
color: #BC6060;
}


/* Language color: hue: 90; */

.hljs-literal {
color: #78A960;
color: #78A960;
}

.hljs-built_in,
.hljs-bullet,
.hljs-code,
.hljs-addition {
color: #397300;
color: #397300;
}


/* Meta color: hue: 200 */

.hljs-meta {
color: #1f7199;
color: #1f7199;
}

.hljs-meta-string {
color: #4d99bf;
color: #4d99bf;
}


/* Misc effects */

.hljs-emphasis {
font-style: italic;
font-style: italic;
}

.hljs-strong {
font-weight: bold;
font-weight: bold;
}
31 changes: 23 additions & 8 deletions tests/extensions/md/test_renderer.py
Original file line number Diff line number Diff line change
Expand Up @@ -20,6 +20,7 @@ def test_md_file_path():
def invalid_md_file_path():
return os.path.join(os.path.dirname(os.path.abspath(__file__)), 'files', 'invalid.md')


@pytest.fixture
def url():
return 'http://osf.io/file/test.md'
Expand Down Expand Up @@ -49,11 +50,25 @@ def test_render_md_cache_result(self, renderer):
assert renderer.cache_result is True

def test_render_md(self, test_md_file_path, assets_url, export_url):
metadata = ProviderMetadata('test', '.md', 'text/plain',
'1234', 'http://wb.osf.io/file/test.md?token=1234')
renderer = MdRenderer(metadata, test_md_file_path, url, assets_url, export_url)
body = renderer.render()
# Harder to test now that the markdown is parsed javascript side
inbody = 'The rain---not the reign---in\nSpain.'
'\n\n&lt;script&gt;\nalert("Hello world");\n&lt;/script&gt;'
assert inbody in body

metadata = ProviderMetadata(
'test',
'.md',
'text/plain',
'1234',
'http://wb.osf.io/file/test.md?token=1234'
)

md_renderer = MdRenderer(metadata, test_md_file_path, url, assets_url, export_url)
body = md_renderer.render()
in_body = 'The rain---not the reign---in\nSpain.\n\n&lt;script&gt;\nalert("Hello world");\n&lt;/script&gt;'
assert in_body in body

# TODO: it is hard to test since rendering is performed by front-end javascript, if possible test the following:
# TODO: test bleach (python)
# TODO: test invalid/corrupted file (e.g. when bleach fails parsing the file)
# TODO: test markdown-it
# TODO: test toc
# TODO: test highlight
# TODO: test mathjax
# TODO: test sanitizer

0 comments on commit 8a29a81

Please sign in to comment.