2018-11-29 17:00:53 -05:00
import React from 'react' ;
2019-05-27 13:26:29 -04:00
import PropTypes from 'prop-types' ;
2018-09-10 07:41:00 -04:00
2018-10-02 16:47:59 -04:00
import './legend.css' ;
2019-09-05 08:33:20 -04:00
import { Logo } from '../components/logo' ;
2019-09-04 15:47:29 -04:00
import { DownIcon , UpIcon , BackIcon } from '../components/icons' ;
2018-09-11 15:59:37 -04:00
2018-10-04 17:50:33 -04:00
const LEGEND_CONFIG = {
2018-12-03 04:35:14 -05:00
location : {
2019-05-27 11:31:48 -04:00
title : 'Location' ,
description : '% data collected' ,
2018-12-03 04:35:14 -05:00
elements : [
2019-01-22 16:46:07 -05:00
{ color : '#084081' , text : '≥80%' } ,
{ color : '#0868ac' , text : '60– 80%' } ,
{ color : '#43a2ca' , text : '40– 60%' } ,
{ color : '#7bccc4' , text : '20– 40%' } ,
{ color : '#bae4bc' , text : '<20%' }
2018-12-03 04:35:14 -05:00
]
} ,
2019-07-07 14:21:08 -04:00
use : {
title : 'Use' ,
elements : [ ]
} ,
type : {
title : 'Type' ,
elements : [ ]
} ,
2018-12-03 04:35:14 -05:00
age : {
2019-05-27 11:31:48 -04:00
title : 'Age' ,
2018-12-03 04:35:14 -05:00
elements : [
2019-05-27 11:39:16 -04:00
{ color : '#f0eaba' , text : '≥2000' } ,
{ color : '#fae269' , text : '1980– 2000' } ,
{ color : '#fbaf27' , text : '1960– 1980' } ,
{ color : '#e6711d' , text : '1940– 1960' } ,
{ color : '#d73d3a' , text : '1920– 1940' } ,
{ color : '#ba221c' , text : '1900– 1920' } ,
{ color : '#bb859b' , text : '1880– 1900' } ,
{ color : '#8b3654' , text : '1860– 1880' } ,
{ color : '#8f5385' , text : '1840– 1860' } ,
{ color : '#56619b' , text : '1820– 1840' } ,
{ color : '#6793b2' , text : '1800– 1820' } ,
{ color : '#83c3b3' , text : '1780– 1800' } ,
{ color : '#adc88f' , text : '1760– 1780' } ,
{ color : '#83a663' , text : '1740– 1760' } ,
{ color : '#77852d' , text : '1720– 1740' } ,
{ color : '#69814e' , text : '1700– 1720' } ,
{ color : '#d0c291' , text : '1680– 1700' } ,
{ color : '#918158' , text : '1660– 1680' } ,
{ color : '#7a5732' , text : '<1660' } ,
2018-12-03 04:35:14 -05:00
]
} ,
size : {
2019-05-27 11:31:48 -04:00
title : 'Number of storeys' ,
2018-12-03 04:35:14 -05:00
elements : [
2019-05-27 11:39:16 -04:00
{ color : '#ffffcc' , text : '≥40' } ,
{ color : '#fed976' , text : '20– 39' } ,
{ color : '#fd8d3c' , text : '10– 19' } ,
{ color : '#e31a1c' , text : '6– 9' } ,
{ color : '#800026' , text : '1– 5' } ,
2018-12-03 04:35:14 -05:00
]
} ,
construction : {
2019-05-27 11:31:48 -04:00
title : 'Construction' ,
2018-12-03 04:35:14 -05:00
elements : [ ]
} ,
team : {
2019-05-27 11:31:48 -04:00
title : 'Team' ,
2018-12-03 04:35:14 -05:00
elements : [ ]
} ,
2019-08-12 12:57:01 -04:00
sustainability : {
title : 'Sustainability' ,
2019-10-02 08:32:00 -04:00
elements : [
{ color : "#007f3d" , text : 'A' } ,
{ color : "#2c9f29" , text : 'B' } ,
{ color : "#9dcb3c" , text : 'C' } ,
{ color : "#fff200" , text : 'D' } ,
{ color : "#f7af1d" , text : 'E' } ,
{ color : "#ed6823" , text : 'F' } ,
{ color : "#e31d23" , text : 'G' } ,
]
2018-12-03 04:35:14 -05:00
} ,
2019-09-10 10:05:35 -04:00
streetscape : {
title : 'Streetscape' ,
2018-12-03 04:35:14 -05:00
elements : [ ]
} ,
planning : {
2019-05-27 11:31:48 -04:00
title : 'Planning' ,
2019-01-19 11:56:03 -05:00
elements : [
2019-05-27 11:39:16 -04:00
{ color : '#73ebaf' , text : 'within conservation area' } ,
2019-01-19 11:56:03 -05:00
]
2018-12-03 04:35:14 -05:00
} ,
2019-07-07 14:21:08 -04:00
community : {
title : 'Community' ,
2018-12-03 04:35:14 -05:00
elements : [ ]
2019-07-07 14:21:08 -04:00
} ,
like : {
title : 'Like Me' ,
elements : [
{ color : '#bd0026' , text : '👍👍👍 ≥10' } ,
{ color : '#e31a1c' , text : '👍👍 5– 10' } ,
{ color : '#fc4e2a' , text : '👍 4' } ,
{ color : '#fd8d3c' , text : '👍 3' } ,
{ color : '#feb24c' , text : '👍 2' } ,
{ color : '#fed976' , text : '👍 1' } ,
]
2018-12-03 04:35:14 -05:00
}
2018-10-04 17:50:33 -04:00
} ;
2019-06-06 12:35:30 -04:00
2019-08-09 13:49:43 -04:00
class Legend extends React . Component < any , any > { // TODO: add proper types
static propTypes = { // TODO: generate propTypes from TS
slug : PropTypes.string ,
color : PropTypes.string ,
text : PropTypes.string
} ;
2019-06-06 12:35:30 -04:00
constructor ( props ) {
super ( props ) ;
this . state = { collapseList : false } ;
this . handleClick = this . handleClick . bind ( this ) ;
this . onResize = this . onResize . bind ( this ) ;
}
handleClick() {
this . setState ( state = > ( {
collapseList : ! state . collapseList
} ) ) ;
}
2019-07-07 14:21:08 -04:00
componentDidMount() {
2019-06-06 12:35:30 -04:00
window . addEventListener ( 'resize' , this . onResize ) ;
if ( window && window . outerHeight ) {
// if we're in the browser, pass in as though from event to initialise
this . onResize ( { target : window } ) ;
}
}
componentWillUnmount() {
window . removeEventListener ( 'resize' , this . onResize ) ;
}
onResize ( e ) {
2019-07-07 14:21:08 -04:00
this . setState ( { collapseList : ( e . target . outerHeight < 670 || e . target . outerWidth < 768 ) } ) ; // magic number needs to be consistent with CSS expander-button media query
2019-06-06 12:35:30 -04:00
}
2019-07-07 14:21:08 -04:00
render() {
const details = LEGEND_CONFIG [ this . props . slug ] || { } ;
const title = details . title || "" ;
const elements = details . elements || [ ] ;
2019-06-06 12:35:30 -04:00
return (
< div className = "map-legend" >
2019-09-05 08:33:20 -04:00
< Logo variant = 'gray' / >
2019-09-04 15:47:29 -04:00
< h4 className = "h4" >
{ title }
< / h4 >
{
elements . length > 0 ?
< button className = "expander-button btn btn-outline-secondary btn-sm" type = "button" onClick = { this . handleClick } >
{
this . state . collapseList ?
< UpIcon / > :
< DownIcon / >
}
< / button > :
null
}
2019-06-06 12:35:30 -04:00
{
details . description ?
< p > { details . description } < / p >
: null
}
{
elements . length ?
< ul className = { this . state . collapseList ? 'collapse data-legend' : 'data-legend' } >
{
elements . map ( ( item ) = > (
< li key = { item . color } >
< span className = "key" style = { { background : item.color } } > - < / span >
{ item . text }
2019-07-07 14:21:08 -04:00
< / li >
2019-06-06 12:35:30 -04:00
) )
}
< / ul >
: < p className = "data-intro" > Coming soon … < / p >
}
2019-01-22 16:23:35 -05:00
< / div >
2019-06-06 12:35:30 -04:00
) ;
}
2018-10-04 17:50:33 -04:00
2019-05-27 13:26:29 -04:00
}
2018-09-10 07:41:00 -04:00
export default Legend ;