2017-02-14 7 views
0

angularJsアプリでStormReactライブラリを使用しようとしています。私は単一bundle.jsAngularJsとngReactで反応レンダリングを使用する方法

window.HelloStormReact = React.createClass({ 

render: function() { 

var Engine = require("../src/Engine")(); 

var model = {links:[],nodes: []}; 

function generateSet(model,offsetX,offsetY){ 

        var node1 = Engine.UID(); 
    var node2 = Engine.UID(); 
    var node3 = Engine.UID(); 
    var node4 = Engine.UID(); 
    var node5 = Engine.UID(); 


    model.links = model.links.concat([ 
     { 
      id: Engine.UID(), 
      source: node1, 
      sourcePort: 'out', 
      target: node2, 
      targetPort: 'in', 
     }, 
     { 
      id: Engine.UID(), 
      source: node1, 
      sourcePort: 'out', 
      target: node3, 
      targetPort: 'in' 
     }, 
     { 
      id: Engine.UID(), 
      source: node2, 
      sourcePort: 'out', 
      target: node4, 
      targetPort: 'in' 
     }, 
     { 
      id: Engine.UID(), 
      source: node4, 
      sourcePort: 'out', 
      target: node5, 
      targetPort: 'in2' 
     }, 
     { 
      id: Engine.UID(), 
      source: node2, 
      sourcePort: 'out', 
      target: node5, 
      targetPort: 'in' 
     } 
    ]); 

    model.nodes = model.nodes.concat([ 
    { 
      id:node1, 
      type: 'action', 
      data: { 
       name: "Create User", 
       outVariables: ['out'] 
      }, 
      x:50 + offsetX, 
      y:50 + offsetY 
     }, 
     { 
      id:node2, 
      type: 'action', 
      data: { 
       name: "Add Card to User", 
       inVariables: ['in','in 2'], 
       outVariables: ['out'] 
      }, 
      x:250 +offsetX, 
      y:50 + offsetY 
     }, 
     { 
      id:node3, 
      type: 'action', 
      data: { 
       color: 'rgb(0,192,255)', 
       name: "Remove User", 
       inVariables: ['in'] 
      }, 
      x:250 + offsetX, 
      y:150 + offsetY 
     }, 
     { 
      id:node4, 
      type: 'action', 
      data: { 
       color: 'rgb(0,192,255)', 
       name: "Remove User", 
       inVariables: ['in'], 
       outVariables: ['out'] 
      }, 
      x:500 + offsetX, 
      y:150 + offsetY 
     }, 
     { 
      id:node5, 
      type: 'action', 
      data: { 
       color: 'rgb(192,255,0)', 
       name: "Complex Action 2", 
       inVariables: ['in','in2','in3'] 
      }, 
      x:800 + offsetX, 
      y:100 + offsetY 
     }, 
    ]); 
       } 

generateSet(model,0,0); 

Engine.registerNodeFactory({ 
    type:'action', 
    generateModel: function(model){ 
     return React.createElement(BasicNodeWidget,{ 
      removeAction: function(){ 
       Engine.removeNode(model); 
      }, 
      color: model.data.color, 
      node: model, 
      name: model.data.name, 
      inPorts: model.data.inVariables, 
      outPorts: model.data.outVariables 
     }); 
    } 
}); 

Engine.loadModel(model); 

return ReactDOM.render(React.createElement(Canvas,{engine: Engine}), document.getElementById("howdy"));; 
} 
}); 

のindex.htmlのようWebPACKのを使用してバンドルされているライブラリの内部クラスを作成した以下のコードで

、私は嵐で作成し、そのクラスライブラリモジュールを反応させました。

<div class="content"> 
    <react-component name="HelloStormReact" /> 
    <div class="storm-flow-canvas" id="howdy"> 
    </div> 
</div> 

私は

Constructor.render(): A valid React element (or null) must be returned. 
    You may have returned undefined, an array or some other invalid object. 

は私が返すようにオブジェクトをレンダリングする正しい書くために助けてエラーを取得しています。

答えて

1

renderの機能では、HelloStormReactは単なるコンポーネントであるため、再度レンダリングする必要はありません。render関数にはReact.createElement(Canvas,{engine: Engine})を返してください。

+0

ありがとうございます。問題を解決しました。 – Hukam

関連する問題