forked from facebook/react-devtools
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathQuery.js
118 lines (102 loc) · 2.69 KB
/
Query.js
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
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
/**
* Copyright (c) 2015-present, Facebook, Inc.
* All rights reserved.
*
* This source code is licensed under the BSD-style license found in the
* LICENSE file in the root directory of this source tree. An additional grant
* of patent rights can be found in the PATENTS file in the same directory.
*
* @flow
*/
'use strict';
import type {Theme} from '../../frontend/types';
import type {Map} from 'immutable';
var {sansSerif} = require('../../frontend/Themes/Fonts');
var React = require('react');
class Query extends React.Component {
theme: {
theme: Theme,
};
props: {
data: Map,
oddRow: boolean,
onSelect: () => void,
};
render() {
var theme = this.context.theme;
var data = this.props.data;
var containerStyle = baseContainer;
if (this.props.isSelected) {
containerStyle = containerSelectedStyle(theme);
} else if (this.props.oddRow) {
containerStyle = containeroOddRowStyle(theme);
}
var status = data.get('status');
const start = data.get('start');
const end = data.get('end');
return (
<tr onClick={this.props.onSelect} style={containerStyle}>
<td style={tdFirstStyle(theme)}>
<span style={statusStyle(status, theme)} title={status} />
</td>
<td style={tdNameStyle(theme)}>
{data.get('name')}
</td>
<td style={baseTDStyle(theme)}>
{Math.round(start) / 1000}s
</td>
<td style={baseTDStyle(theme)}>
{Math.round(end - start)}ms
</td>
</tr>
);
}
}
Query.contextTypes = {
theme: React.PropTypes.object.isRequired,
};
const baseContainer = {
cursor: 'pointer',
fontSize: sansSerif.sizes.normal,
height: 21,
lineHeight: '21px',
fontFamily: sansSerif.family,
};
const baseTDStyle = (theme: Theme) => ({
whiteSpace: 'nowrap',
'padding': '1px 4px',
'lineHeight': '17px',
'borderLeft': `1px solid ${theme.base01}`,
});
const tdFirstStyle = (theme: Theme) => ({
...baseTDStyle(theme),
borderLeft: '',
});
const tdNameStyle = (theme: Theme) => ({
...baseTDStyle(theme),
width: '100%',
});
const containeroOddRowStyle = (theme: Theme) => ({
...baseContainer,
backgroundColor: theme.base01,
});
const containerSelectedStyle = (theme: Theme) => ({
...baseContainer,
backgroundColor: theme.state00,
color: theme.base04,
});
// Status colors not themed b'c the color choice is significant
const statusColors = {
pending: 'orange',
success: 'green',
failure: 'red',
error: '#aaa',
};
const statusStyle = (status: string) => ({
display: 'inline-block',
width: 11,
height: 11,
borderRadius: 6,
backgroundColor: statusColors[status] || statusColors.error,
});
module.exports = Query;