-
Notifications
You must be signed in to change notification settings - Fork 842
/
Copy pathutc.js
66 lines (56 loc) · 1.39 KB
/
utc.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
import React, { Component } from 'react';
import moment from 'moment';
import {
EuiDatePicker,
EuiFormRow,
EuiSelect,
} from '../../../../src/components';
export default class extends Component {
constructor(props) {
super(props);
this.options = [
{ value: -1, text: 'GMT -01:00' },
{ value: -2, text: 'GMT -02:00' },
{ value: -3, text: 'GMT -03:00' },
];
this.state = {
startDate: moment(),
utcOffset: this.options[1].value,
};
this.handleChange = this.handleChange.bind(this);
this.onSelectChange = this.onSelectChange.bind(this);
}
onSelectChange = e => {
this.setState({
utcOffset: parseInt(e.target.value, 10),
});
};
handleChange = date => {
this.setState({
startDate: date,
});
};
render() {
const selected =
this.state.startDate &&
this.state.startDate.clone().utcOffset(this.state.utcOffset);
return (
<div>
<EuiFormRow label="Select a date">
<EuiDatePicker
selected={selected}
onChange={this.handleChange}
utcOffset={this.state.utcOffset * 60}
/>
</EuiFormRow>
<EuiFormRow label="UTC offset">
<EuiSelect
options={this.options}
value={this.state.utcOffset}
onChange={this.onSelectChange}
/>
</EuiFormRow>
</div>
);
}
}