2014-12-21 20:22:01 +00:00
|
|
|
import Snap from 'snapsvg';
|
2014-12-30 02:31:36 +00:00
|
|
|
import _ from 'lodash';
|
2014-12-18 16:13:15 +00:00
|
|
|
|
2015-03-14 21:27:59 +00:00
|
|
|
import util from '../util.js';
|
2014-12-20 01:41:02 +00:00
|
|
|
import javascript from './javascript/parser.js';
|
2015-03-14 18:01:25 +00:00
|
|
|
import ParserState from './javascript/parser_state.js';
|
2014-11-26 23:24:40 +00:00
|
|
|
|
2014-12-18 16:13:15 +00:00
|
|
|
export default class Parser {
|
2014-12-30 02:31:36 +00:00
|
|
|
constructor(container, options) {
|
|
|
|
this.options = options || {};
|
|
|
|
_.defaults(this.options, {
|
|
|
|
keepContent: false
|
|
|
|
});
|
|
|
|
|
|
|
|
this.container = container;
|
2015-03-14 18:01:25 +00:00
|
|
|
|
|
|
|
this.state = new ParserState(this.container.querySelector('.progress div'));
|
2014-12-30 02:31:36 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
set container(cont) {
|
|
|
|
this._container = cont;
|
|
|
|
this._container.innerHTML = [
|
|
|
|
document.querySelector('#svg-container-base').innerHTML,
|
|
|
|
this.options.keepContent ? this.container.innerHTML : ''
|
|
|
|
].join('');
|
2014-12-30 15:17:55 +00:00
|
|
|
this._addClass('svg-container');
|
2014-12-30 02:31:36 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
get container() {
|
|
|
|
return this._container;
|
|
|
|
}
|
|
|
|
|
|
|
|
_addClass(className) {
|
2014-12-30 15:17:55 +00:00
|
|
|
this.container.className = _(this.container.className.split(' '))
|
|
|
|
.union([className])
|
|
|
|
.value()
|
|
|
|
.join(' ');
|
2014-12-30 02:31:36 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
_removeClass(className) {
|
2014-12-30 15:17:55 +00:00
|
|
|
this.container.className = _(this.container.className.split(' '))
|
|
|
|
.without(className)
|
|
|
|
.value()
|
|
|
|
.join(' ');
|
2014-12-18 16:13:15 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
parse(expression) {
|
2014-12-30 02:31:36 +00:00
|
|
|
this._addClass('loading');
|
|
|
|
|
2015-03-14 21:27:59 +00:00
|
|
|
return util.tick().then(() => {
|
|
|
|
javascript.Parser.SyntaxNode.state = this.state;
|
|
|
|
|
|
|
|
this.parsed = javascript.parse(expression.replace(/\n/g, '\\n'));
|
|
|
|
return this;
|
2014-12-18 16:13:15 +00:00
|
|
|
});
|
|
|
|
}
|
|
|
|
|
2014-12-30 02:31:36 +00:00
|
|
|
render() {
|
2015-03-14 18:01:25 +00:00
|
|
|
var svg = Snap(this.container.querySelector('svg'));
|
2014-12-25 04:01:32 +00:00
|
|
|
|
2014-12-18 16:13:15 +00:00
|
|
|
return this.parsed.render(svg.group())
|
2015-03-14 18:01:25 +00:00
|
|
|
.then(result => {
|
|
|
|
var box = result.getBBox();
|
|
|
|
|
|
|
|
result.transform(Snap.matrix()
|
|
|
|
.translate(10 - box.x, 10 - box.y));
|
|
|
|
svg.attr({
|
|
|
|
width: box.width + 20,
|
|
|
|
height: box.height + 20
|
|
|
|
});
|
|
|
|
})
|
2015-03-14 21:11:14 +00:00
|
|
|
.then(() => {
|
2014-12-30 02:31:36 +00:00
|
|
|
this._removeClass('loading');
|
|
|
|
this.container.removeChild(this.container.querySelector('.progress'));
|
2014-12-18 16:13:15 +00:00
|
|
|
});
|
|
|
|
}
|
2014-12-18 00:24:33 +00:00
|
|
|
|
2014-12-18 16:13:15 +00:00
|
|
|
cancel() {
|
|
|
|
this.state.cancelRender = true;
|
|
|
|
}
|
2014-12-22 21:57:30 +00:00
|
|
|
|
|
|
|
get warnings() {
|
|
|
|
return this.state.warnings;
|
|
|
|
}
|
2014-12-18 16:13:15 +00:00
|
|
|
}
|