react-mc-render

1.1.0-alpha.18 • Public • Published

react-mc-render

Render the value we got.

Installation

Using npm:

$ npm install --save react-mc-render

Usage

import React from 'react';

import ReactMCRender from 'react-mc-render';

/**
 * In this case,
 * will only render some "div" with different id.
 * Because we have not set up options.getComponentClass.
 */
const App = (props = {}) => {
  const { value = {} } = props;

  return (
    <ReactMCRender value={value} />
  );
};

export default App;

props.value: object

The value you can render.

Detail for value;

props.options: object

The parameters you need to configure to render value in the way you want.

const options = {
  getComponentClass: (component = {}) => 'div',
  getComponentRenderDependencies: (component = {}) => [],
  render: (ComponentClass, component = {}) => (props = {}, ref) => {
    return (
      <ComponentClass ref={ref} {...props} />
    );
  },
};

options.getComponentClass

Return the ComponentClass to render the component.

import React from 'react';

const Input = React.forwardRef((props, ref) => {
  return 
});

const Text = React.forwardRef((props, ref) => {
  return <span ref={ref} {...props} />
});

const Img = React.forwardRef((props, ref) => {
  return <img ref={ref} {...props} />
});

const getComponentClass = (component = {}) => {
  const { name } = component;

  switch (name) {
    case 'input':
      return Input;
    case 'span':
      return Text;
    case 'img':
      return Img;
    default:
      return 'div';
  }
};

options.getComponentRenderDependencies

Ruturn the dependencies for rendering.The ComponentClass will render only if dependencies change.component and relation are already in the dependencies by default.

const selectedComponent = {};
const { id: selectedComponentId } = selectedComponent;

// render when select the component
const getComponentRenderDependencies = (component = {}) => {
  const { id: componentId } = component;

  const selected = selectedComponentId === componentId;

  return [selected];
};

options.render

The final touch to render component correctly.This function is useful when you want to do something nasty.

import { findDOMNode } from 'react-dom';

/**
 * ComponentClass: elementType, is what getComponentClass return
 * props: object, base on component.props and relation.
 */
const render = (ComponentClass, component = {}) => (props = {}, ref) => {
  const { current } = ref;
  const dom = findDOMNode(current);

  return (
    <ComponentClass ref={ref} {...props} />
  );
};

Readme

Keywords

Package Sidebar

Install

npm i react-mc-render

Weekly Downloads

10

Version

1.1.0-alpha.18

License

MIT

Unpacked Size

17.7 kB

Total Files

4

Last publish

Collaborators

  • xiaoshuang