2020-06-23 08:45:38 +00:00
|
|
|
import _ from 'lodash'
|
2019-10-14 13:17:30 +00:00
|
|
|
/* global MathJax */
|
2018-11-05 10:06:39 +00:00
|
|
|
|
2020-05-19 09:02:56 +00:00
|
|
|
import App from '../base'
|
2019-03-18 10:24:54 +00:00
|
|
|
|
2020-05-19 09:02:56 +00:00
|
|
|
export default App.directive('mathjax', function($compile, $parse) {
|
|
|
|
return {
|
|
|
|
link(scope, element, attrs) {
|
|
|
|
if (!(MathJax && MathJax.Hub)) return
|
2019-03-18 10:24:54 +00:00
|
|
|
|
2020-05-19 09:02:56 +00:00
|
|
|
// Allowing HTML can be unsafe unless using something like
|
|
|
|
// `ng-bind-html` because of potential Angular XSS via {{/}}
|
|
|
|
if (!$parse(attrs.mathjaxAllowHtml)(scope)) {
|
|
|
|
const mathJaxContents = element.html()
|
|
|
|
const nonBindableEl = $compile('<span ng-non-bindable></span>')({})
|
|
|
|
element.html('').append(nonBindableEl)
|
|
|
|
nonBindableEl.html(mathJaxContents)
|
|
|
|
}
|
2019-03-18 10:24:54 +00:00
|
|
|
|
2020-05-19 09:02:56 +00:00
|
|
|
if (attrs.delimiter !== 'no-single-dollar') {
|
|
|
|
const inlineMathConfig =
|
|
|
|
MathJax.Hub.config && MathJax.Hub.config.tex2jax.inlineMath
|
|
|
|
const alreadyConfigured = _.find(
|
|
|
|
inlineMathConfig,
|
|
|
|
c => c[0] === '$' && c[1] === '$'
|
|
|
|
)
|
2018-11-05 10:06:39 +00:00
|
|
|
|
2020-05-19 09:02:56 +00:00
|
|
|
if (!alreadyConfigured) {
|
|
|
|
MathJax.Hub.Config({
|
|
|
|
tex2jax: {
|
|
|
|
inlineMath: inlineMathConfig.concat([['$', '$']])
|
|
|
|
}
|
|
|
|
})
|
|
|
|
}
|
2019-03-18 10:24:54 +00:00
|
|
|
}
|
2020-05-19 09:02:56 +00:00
|
|
|
|
|
|
|
setTimeout(() => {
|
|
|
|
MathJax.Hub.Queue(['Typeset', MathJax.Hub, element.get(0)])
|
|
|
|
}, 0)
|
2018-11-05 10:06:39 +00:00
|
|
|
}
|
2020-05-19 09:02:56 +00:00
|
|
|
}
|
2019-03-18 10:24:54 +00:00
|
|
|
})
|