-
Notifications
You must be signed in to change notification settings - Fork 11
Expand file tree
/
Copy pathClassification.js
More file actions
82 lines (77 loc) · 2.36 KB
/
Classification.js
File metadata and controls
82 lines (77 loc) · 2.36 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
import i18n from '@dhis2/d2-i18n'
import { range } from 'lodash/fp'
import PropTypes from 'prop-types'
import React from 'react'
import { connect } from 'react-redux'
import { setClassification, setColorScale } from '../../actions/layerEdit.js'
import {
getClassificationTypes,
CLASSIFICATION_EQUAL_INTERVALS,
} from '../../constants/layers.js'
import {
defaultColorScaleName,
defaultClasses,
defaultColorScale,
getColorPalette,
getColorScale,
} from '../../util/colors.js'
import { SelectField, ColorScaleSelect } from '../core/index.js'
import styles from './styles/Classification.module.css'
const classRange = range(3, 10).map((num) => ({
id: num,
name: num.toString(),
})) // 3 - 9
const Classification = ({
method,
classes,
colorScale,
setClassification,
setColorScale,
}) => {
const colorScaleName = colorScale
? getColorScale(colorScale)
: defaultColorScaleName
return [
<SelectField
key="classification"
label={i18n.t('Classification')}
value={method || CLASSIFICATION_EQUAL_INTERVALS}
items={getClassificationTypes()}
onChange={(method) => setClassification(method.id)}
className={styles.select}
/>,
<div key="scale">
<SelectField
label={i18n.t('Classes')}
value={classes !== undefined ? classes : defaultClasses}
items={classRange}
onChange={(item) =>
setColorScale(getColorPalette(colorScaleName, item.id))
}
className={styles.classes}
/>
<ColorScaleSelect
palette={colorScale ? colorScale : defaultColorScale}
onChange={setColorScale}
width={190}
className={styles.scale}
/>
<div className={styles.clear} />
</div>,
]
}
Classification.propTypes = {
setClassification: PropTypes.func.isRequired,
setColorScale: PropTypes.func.isRequired,
classes: PropTypes.number,
colorScale: PropTypes.array,
method: PropTypes.number,
}
export default connect(
({ layerEdit }) => ({
method: layerEdit.method,
classes: layerEdit.classes,
colorScale: layerEdit.colorScale,
}),
{ setClassification, setColorScale }
)(Classification)