0
0
mirror of https://github.com/naturalcrit/homebrewery.git synced 2026-01-12 06:42:40 +00:00
Files
homebrewery/client/splatsheet/sheetRenderer/sheetRenderer.jsx
2016-04-06 00:45:58 -04:00

91 lines
1.6 KiB
JavaScript

var React = require('react');
var _ = require('lodash');
var cx = require('classnames');
var jsx2json = require('jsx-parser');
var Parts = require('./parts');
var SheetRenderer = React.createClass({
getDefaultProps: function() {
return {
code : '',
characterData : {},
onChange : function(){},
};
},
/*
augmentProps : function(props, key){
return _.extend({}, props, {
key : key,
data : this.props.characterData,
onChange :
})
},
*/
renderElement : function(node, key){
return React.createElement(
(Parts[node.tag] ? Parts[node.tag] : node.tag),
{key : key, ...node.props},
//this.augmentProps(node.props, key),
...this.renderChildren(node.children))
},
renderChildren : function(nodes){
return _.map(nodes, (node, index)=>{
if(_.isString(node)) return node;
return this.renderElement(node, index);
})
},
renderSheet : function(){
try{
var nodes = jsx2json(this.props.code);
nodes = _.map(nodes, (node)=>{
node.props.data = this.props.characterData;
node.props.onChange = (newData)=>{
this.props.onChange(_.extend(this.props.characterData, newData));
}
return node
})
return this.renderChildren(nodes);
}catch(e){
return <div>Error bruh {e.toString()}</div>
}
},
render : function(){
return <div className='sheetRenderer'>
<h2>Character Sheet</h2>
<div className='sheetContainer' ref='sheetContainer'>
{this.renderSheet()}
</div>
</div>
}
});
module.exports = SheetRenderer;
/*
<Temp text="cool">yo test <a href="google.com">link</a> </Temp>
*/