Skip to content

pavloDeshko/dd-elements

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

41 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Data-driven Elements Build Status

A d3-style alternative to JSX for writing React elements. Tiny (less then 2kb), zero runtime dependencies.

npm i dd-elements
yarn add dd-elements

If 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.

MIT

About

No description, website, or topics provided.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published