-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathcomponents.jsx
More file actions
86 lines (71 loc) · 2.1 KB
/
components.jsx
File metadata and controls
86 lines (71 loc) · 2.1 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
/// Common components ///
var React = require('react');
var ReactDOM = require('react-dom');
var DataSource = require('./models/dataSourceModel.js');
var AnswerModule = require('./models/answerModuleModel.js');
var CollapsibleHeader = React.createClass({
render: function () {
return (
<div className="collapsible-header">
<span className="title">{this.props.title}</span>
</div>
)
}
});
var CollapsibleBody = React.createClass({
render: function () {
var pairs = this.props.pairs.map(function (pair) {
return ([<strong>{pair.name}: </strong>, pair.value, <br/>]);
});
return (
<div className="collapsible-body">
<p>{pairs}</p>
</div>
)
}
});
var CollapsibleListElement = React.createClass({
render: function () {
return (
<li>
<CollapsibleHeader title={this.props.name}/>
<CollapsibleBody pairs={this.props.pairs}/>
</li>
)
}
});
var CollapsibleList = React.createClass({
componentDidMount: function () {
$('.collapsible').collapsible();
},
componentDidUpdate: function () {
$('.collapsible').collapsible();
},
render: function () {
var serialize = this.props.model.serialize;
var listElements = this.props.model.elements.map(function(object) {
console.log(object);
return (
<CollapsibleListElement
name={object.name}
pairs={serialize(object)}
/>
)
});
return (
<ul className="collapsible">
{listElements}
</ul>
)
}
});
dataSourceModel = new DataSource();
ReactDOM.render(
<CollapsibleList model={dataSourceModel}/>,
document.getElementById('dataSourcesContainer')
);
answerModelModule = new AnswerModule();
ReactDOM.render(
<CollapsibleList model={answerModelModule}/>,
document.getElementById('answerModulesContainer')
);