1.0.1 • Published 2 years ago
dd-elements v1.0.1
Data-driven Elements 
A d3-style alternative to JSX for writing React elements. Tiny (less then 2kb), zero runtime dependencies.
npm i dd-elementsyarn add dd-elementsIf you're not familiar with d3 workflow there're two core ideas to grasp:
- DOM tree is constructed via Collection interface. Various chaining methods can be used to add children and specify their attributes.
- Every element has a bit of data (called "datum") assigned to itself. It can be accessed via a callback, which will recieve datum as argument.
Basic usage:
import e from "dd-elements"
function yourReactComponent(props){
  let container = e("div")        //Get container element of given type.
      .classed("container primary")              //Assign classes,
      .prop("id","_id_")                         //attributes or props
  
  /*Now cool stuff*/
  container                                      //Add child for every element in an Array.
    .children("span",props.arr)                  //Pass a callback to access every child's
	  .prop("key", d=>d.id)                        //datum (respective array element).
	  .classed( d=>d.type+"_class" )               //And specify attrs based on their datums.
	  .text( d=>d.content )                        //As well as add text content
  
  return container.toReact()	                   //Convert to valid React Elements.
}Note that type can be React Component:
import {Card, Button} from "myComponents.js"
/*...*/
e(Card)
  .child(Button)
    .prop("text","Push me!")Fucntional components can be wrapped, so Collection can be returned directly, without call to toReact():
import e, {withData} from "dd-elements"
const MyWrappedComponent = withData(props=>{
  return e('div')
    .classed('container')
	//etc
})Complete API can be found here.
If your are looking for a way to use D3 with React do have a look here.