UNPKG

react-domify

Version:
127 lines (107 loc) 2.89 kB
var React = require('react'); var styles = { string: { color: '#0e4889', cursor: 'default', }, bool: { color: '#06624b', cursor: 'default', fontStyle: 'italic', }, number: { color: '#ca000a', cursor: 'default', }, date: { color: '#009f7b', cursor: 'default', }, empty: { color: '#999999', cursor: 'default', }, array: { color: '#666666', cursor: 'default', }, object: { color: '#0b89b6', cursor: 'default', }, comma: { color: '#999999', cursor: 'default', }, }; function transform (obj, fromRecur, comma) { var tag = (fromRecur) ? 'span' : 'div'; var nextLevel = (fromRecur || 0) + 1; var children = []; comma = comma ? <span style={styles.comma}>,</span> : null; // strings if (typeof obj === 'string') { return React.createElement(tag, { style: styles.string }, `"${obj}"`, comma); } // booleans, null and undefined else if (typeof obj === 'boolean' || obj === null || obj === undefined) { return React.createElement(tag, { style: styles.bool }, String(obj), comma); } // numbers else if (typeof obj === 'number') { return React.createElement(tag, { style: styles.number }, String(obj), comma); } // dates else if (Object.prototype.toString.call(obj) === '[object Date]') { return React.createElement(tag, { style: styles.date }, String(obj), comma); } // arrays else if (Array.isArray(obj)) { if (!obj.length) { return React.createElement(tag, { style: styles.empty }, 'Array: []'); } children.push(React.createElement(tag, { key: '__array:open__', style: styles.array }, 'Array: [')); for (var i = 0; i < obj.length; i++) { children.push( <div key={'i' + i} style={{ paddingLeft: '20px' }}> {transform(obj[i], nextLevel, i < obj.length - 1)} </div> ); } children.push(React.createElement(tag, { key: '__array:close__', style: styles.array }, ']')); } // objects else if (obj && typeof obj === 'object') { var len = Object.keys(obj).length; if (fromRecur && !len) { return React.createElement(tag, { style: styles.empty }, 'Object: {}'); } if (fromRecur) { children.push(React.createElement(tag, { key: '__object:open__', style: styles.object }, 'Object: {')); } for (var key in obj) { if (typeof obj[key] !== 'function') { children.push( <div key={key} style={{ paddingLeft: fromRecur ? '20px' : '0px' }}> <span style={{ paddingRight: '5px', cursor: 'default' }}>{key}:</span> {transform(obj[key], nextLevel)} </div> ); } } if (fromRecur) { children.push(React.createElement(tag, { key: '__object:close__', style: styles.object }, '}')); } } return <div>{children}{comma}</div>; } var DOMify = React.createClass({ render () { return ( <div className={this.props.className} style={this.props.style}> {transform(this.props.value)} </div> ); }, }); module.exports = DOMify;