{"version":3,"sources":["webpack:///./src/images/aerial/2013.jpg","webpack:///./src/images/aerial/3010.jpg","webpack:///./src/images/aerial/1063.jpg","webpack:///./src/images/aerial/3038.jpg","webpack:///./src/images/aerial/2084.jpg","webpack:///./src/images/aerial/1129.jpg","webpack:///./src/images/aerial/2052.jpg","webpack:///./src/images/aerial/4048.jpg","webpack:///./src/images/aerial/2048.jpg","webpack:///./src/images/aerial/1110.jpg","webpack:///./src/images/aerial/1088.jpg","webpack:///./src/images/aerial/1047.jpg","webpack:///./src/images/aerial/4007.jpg","webpack:///./src/images/aerial/3098.jpg","webpack:///./src/images/aerial/1026.jpg","webpack:///./src/images/aerial sync ^\\.\\/.*\\.jpg$","webpack:///./src/images/aerial/3058.jpg","webpack:///./src/images/aerial/4008.jpg","webpack:///./src/images/aerial/1118.jpg","webpack:///./node_modules/gatsby/node_modules/core-js/internals/object-keys.js","webpack:///./src/images/aerial/3076.jpg","webpack:///./src/images/aerial/4042.jpg","webpack:///./src/images/aerial/2019.jpg","webpack:///./src/images/aerial/2087.jpg","webpack:///./src/images/aerial/1073.jpg","webpack:///./src/images/aerial/1156.jpg","webpack:///./src/images/aerial/2080.jpg","webpack:///./src/images/aerial/1150.jpg","webpack:///./src/images/aerial/1082.jpg","webpack:///./src/images/aerial/3083.jpg","webpack:///./src/images/aerial/1018.jpg","webpack:///./src/images/aerial/3019.jpg","webpack:///./src/images/aerial/2073.jpg","webpack:///./src/images/aerial/1116.jpg","webpack:///./src/images/aerial/1013.jpg","webpack:///./node_modules/gatsby/node_modules/core-js/internals/is-array.js","webpack:///./src/images/aerial/2002.jpg","webpack:///./src/images/aerial/1096.jpg","webpack:///./src/images/aerial/2000.jpg","webpack:///./src/images/aerial/1130.jpg","webpack:///./src/images/aerial/1100.jpg","webpack:///./src/images/aerial/3049.jpg","webpack:///./src/images/aerial/3064.jpg","webpack:///./src/images/aerial/4049.jpg","webpack:///./src/images/aerial/2079.jpg","webpack:///./src/images/aerial/3036.jpg","webpack:///./src/images/aerial/3037.jpg","webpack:///./src/images/aerial/1057.jpg","webpack:///./src/images/aerial/1051.jpg","webpack:///./src/images/aerial/1055.jpg","webpack:///./src/images/aerial/1119.jpg","webpack:///./src/images/aerial/2044.jpg","webpack:///./src/images/aerial/4044.jpg","webpack:///./src/images/aerial/3023.jpg","webpack:///./src/images/aerial/1132.jpg","webpack:///./src/images/aerial/4055.jpg","webpack:///./src/images/aerial/2069.jpg","webpack:///./src/images/aerial/1142.jpg","webpack:///./src/images/light-v9.png","webpack:///./src/images/aerial/3086.jpg","webpack:///./src/images/aerial/1137.jpg","webpack:///./src/images/aerial/2094.jpg","webpack:///./src/images/aerial/4035.jpg","webpack:///./src/images/aerial/4057.jpg","webpack:///./src/images/aerial/4054.jpg","webpack:///./src/images/aerial/4011.jpg","webpack:///./src/images/aerial/2065.jpg","webpack:///./src/images/aerial/2082.jpg","webpack:///./src/images/aerial/4033.jpg","webpack:///./src/images/aerial/3026.jpg","webpack:///./src/images/aerial/3097.jpg","webpack:///./src/images/aerial/1014.jpg","webpack:///./src/images/aerial/2028.jpg","webpack:///./node_modules/gatsby/node_modules/core-js/internals/array-species-create.js","webpack:///./src/images/aerial/2074.jpg","webpack:///./src/images/aerial/1112.jpg","webpack:///./src/images/aerial/1019.jpg","webpack:///./src/images/aerial/1022.jpg","webpack:///./src/images/aerial/1099.jpg","webpack:///./src/images/aerial/3009.jpg","webpack:///./src/images/aerial/1140.jpg","webpack:///./src/images/aerial/1074.jpg","webpack:///./src/images/aerial/1115.jpg","webpack:///./src/images/aerial/2049.jpg","webpack:///./src/images/aerial/2109.jpg","webpack:///./src/images/aerial/1020.jpg","webpack:///./src/images/aerial/1086.jpg","webpack:///./src/images/aerial/2033.jpg","webpack:///./src/images/aerial/1030.jpg","webpack:///./src/images/aerial/2037.jpg","webpack:///./src/images/aerial/3051.jpg","webpack:///./src/images/aerial/4037.jpg","webpack:///./src/images/aerial/3040.jpg","webpack:///./node_modules/gatsby/node_modules/core-js/internals/flatten-into-array.js","webpack:///./src/images/aerial/3055.jpg","webpack:///./src/images/aerial/1079.jpg","webpack:///./src/images/aerial/3071.jpg","webpack:///./src/images/aerial/1050.jpg","webpack:///./src/images/aerial/1141.jpg","webpack:///./src/images/aerial/1052.jpg","webpack:///./src/images/delta.svg","webpack:///./src/images/aerial/1054.jpg","webpack:///./src/images/aerial/1078.jpg","webpack:///./src/images/aerial/2058.jpg","webpack:///./src/images/aerial/1065.jpg","webpack:///./src/images/aerial/4021.jpg","webpack:///./src/images/aerial/2050.jpg","webpack:///./src/images/aerial/4034.jpg","webpack:///./src/images/aerial/1165.jpg","webpack:///./src/images/aerial/4009.jpg","webpack:///./src/images/aerial/3046.jpg","webpack:///./src/images/aerial/1076.jpg","webpack:///./src/images/aerial/2106.jpg","webpack:///./src/images/aerial/2004.jpg","webpack:///./src/images/aerial/2025.jpg","webpack:///./src/images/aerial/2101.jpg","webpack:///./src/images/aerial/1058.jpg","webpack:///./src/images/aerial/1162.jpg","webpack:///./src/images/bay.svg","webpack:///./src/images/aerial/3029.jpg","webpack:///./src/images/aerial/3070.jpg","webpack:///./src/images/aerial/3011.jpg","webpack:///./src/images/aerial/3096.jpg","webpack:///./src/images/aerial/3027.jpg","webpack:///./src/images/aerial/3054.jpg","webpack:///./src/images/aerial/2008.jpg","webpack:///./src/images/aerial/3045.jpg","webpack:///./src/images/aerial/2015.jpg","webpack:///./src/images/aerial/4016.jpg","webpack:///./src/images/aerial/3056.jpg","webpack:///./src/images/aerial/2026.jpg","webpack:///./src/images/aerial/2091.jpg","webpack:///./src/images/aerial/3057.jpg","webpack:///./src/images/aerial/4002.jpg","webpack:///./src/images/aerial/4038.jpg","webpack:///./src/images/aerial/1147.jpg","webpack:///./src/images/aerial/1015.jpg","webpack:///./src/images/aerial/2070.jpg","webpack:///./src/images/aerial/1031.jpg","webpack:///./src/images/aerial/2089.jpg","webpack:///./src/images/aerial/1087.jpg","webpack:///./src/images/aerial/1010.jpg","webpack:///./src/images/aerial/1037.jpg","webpack:///./src/images/aerial/3053.jpg","webpack:///./src/images/aerial/2029.jpg","webpack:///./src/images/aerial/1023.jpg","webpack:///./src/components/elements/HelpText.jsx","webpack:///./src/images/aerial/2097.jpg","webpack:///./src/images/aerial/2014.jpg","webpack:///./src/images/aerial/1121.jpg","webpack:///./src/images/aerial/3012.jpg","webpack:///./src/images/aerial/3082.jpg","webpack:///./src/images/aerial/3006.jpg","webpack:///./src/images/aerial/4018.jpg","webpack:///./src/images/aerial/1027.jpg","webpack:///./src/images/aerial/3069.jpg","webpack:///./src/images/aerial/4045.jpg","webpack:///./src/images/aerial/1038.jpg","webpack:///./src/images/aerial/3032.jpg","webpack:///./src/images/aerial/2006.jpg","webpack:///./src/images/aerial/2024.jpg","webpack:///./src/images/aerial/1117.jpg","webpack:///./src/images/aerial/1149.jpg","webpack:///./src/images/aerial/3004.jpg","webpack:///./src/images/aerial/3048.jpg","webpack:///./src/images/aerial/4059.jpg","webpack:///./src/images/aerial/1067.jpg","webpack:///./src/components/elements/ExpandableParagraph.jsx","webpack:///./src/images/aerial/1123.jpg","webpack:///./node_modules/gatsby/node_modules/core-js/internals/object-create.js","webpack:///./src/util/map.js","webpack:///./src/images/aerial/3077.jpg","webpack:///./src/images/aerial/3015.jpg","webpack:///./src/images/aerial/4039.jpg","webpack:///./src/images/aerial/1103.jpg","webpack:///./src/images/aerial/2061.jpg","webpack:///./src/images/aerial/1040.jpg","webpack:///./src/images/aerial/1152.jpg","webpack:///./src/images/aerial/4050.jpg","webpack:///./src/images/aerial/2054.jpg","webpack:///./src/images/aerial/3043.jpg","webpack:///./src/images/aerial/2027.jpg","webpack:///./src/images/aerial/1042.jpg","webpack:///./src/images/aerial/2012.jpg","webpack:///./src/images/aerial/2107.jpg","webpack:///./src/images/aerial/3090.jpg","webpack:///./src/images/aerial/1145.jpg","webpack:///./src/images/aerial/3041.jpg","webpack:///./src/images/aerial/1085.jpg","webpack:///./node_modules/immutable/dist/immutable.es.js","webpack:///./src/images/aerial/3099.jpg","webpack:///./src/images/aerial/3094.jpg","webpack:///./src/images/aerial/3050.jpg","webpack:///./src/images/aerial/1135.jpg","webpack:///./config/filters.js","webpack:///./src/images/aerial/1070.jpg","webpack:///./src/images/aerial/3035.jpg","webpack:///./src/images/aerial/4040.jpg","webpack:///./src/images/aerial/1035.jpg","webpack:///./src/images/aerial/1154.jpg","webpack:///./src/images/aerial/1033.jpg","webpack:///./src/images/aerial/1091.jpg","webpack:///./src/images/aerial/1164.jpg","webpack:///./src/images/aerial/1160.jpg","webpack:///./src/images/aerial/2010.jpg","webpack:///./src/images/lagoonal.svg","webpack:///./node_modules/gatsby/node_modules/core-js/internals/object-define-properties.js","webpack:///./src/images/aerial/1075.jpg","webpack:///./src/images/aerial/1084.jpg","webpack:///./src/images/aerial/2063.jpg","webpack:///./src/images/aerial/1109.jpg","webpack:///./src/images/aerial/1106.jpg","webpack:///./src/images/aerial/4006.jpg","webpack:///./src/images/aerial/4012.jpg","webpack:///./src/images/aerial/1011.jpg","webpack:///./src/images/aerial/1053.jpg","webpack:///./src/images/aerial/4056.jpg","webpack:///./src/images/aerial/3087.jpg","webpack:///./src/images/aerial/4020.jpg","webpack:///./src/images/aerial/3024.jpg","webpack:///./src/images/aerial/2064.jpg","webpack:///./src/images/aerial/4027.jpg","webpack:///./src/images/aerial/3034.jpg","webpack:///./src/images/aerial/3052.jpg","webpack:///./src/images/aerial/1039.jpg","webpack:///./src/images/aerial/2096.jpg","webpack:///./src/images/aerial/3100.jpg","webpack:///./src/images/aerial/1034.jpg","webpack:///./src/images/aerial/1001.jpg","webpack:///./src/images/aerial/1104.jpg","webpack:///./src/images/aerial/2047.jpg","webpack:///./src/images/aerial/2083.jpg","webpack:///./src/images/aerial/3061.jpg","webpack:///./src/images/aerial/3020.jpg","webpack:///./src/images/aerial/1163.jpg","webpack:///./src/images/aerial/1049.jpg","webpack:///./src/images/aerial/3080.jpg","webpack:///./src/images/aerial/3088.jpg","webpack:///./src/images/aerial/2076.jpg","webpack:///./src/images/aerial/2041.jpg","webpack:///./src/images/aerial/2060.jpg","webpack:///./src/components/elements/FaIcon.jsx","webpack:///./src/images/aerial/4019.jpg","webpack:///./src/images/aerial/2066.jpg","webpack:///./src/images/aerial/4058.jpg","webpack:///./src/components/Button/Button.jsx","webpack:///./src/components/Button/ButtonGroup.jsx","webpack:///./src/components/Button/ToggleButton.jsx","webpack:///./src/images/aerial/2095.jpg","webpack:///./src/images/aerial/4014.jpg","webpack:///./src/images/aerial/1093.jpg","webpack:///./src/images/aerial/3001.jpg","webpack:///./src/images/aerial/3072.jpg","webpack:///./src/images/aerial/2021.jpg","webpack:///./src/images/aerial/1043.jpg","webpack:///./src/images/aerial/2031.jpg","webpack:///./src/images/aerial/1006.jpg","webpack:///./src/images/aerial/1045.jpg","webpack:///./src/images/aerial/2038.jpg","webpack:///./src/components/Tabs/Button.jsx","webpack:///./src/components/Tabs/TabBar.jsx","webpack:///./src/components/Tabs/TabContainer.jsx","webpack:///./src/components/Tabs/Tab.jsx","webpack:///./src/components/Tabs/index.jsx","webpack:///./src/components/EstuaryDetails/SpeciesList.jsx","webpack:///./src/components/EstuaryDetails/BioticListItem.jsx","webpack:///./src/components/EstuaryDetails/BioticList.jsx","webpack:///./src/components/Donut/SingleValue.jsx","webpack:///./src/components/Donut/MultiValue.jsx","webpack:///./src/components/EstuaryDetails/TidalWetlandLoss.jsx","webpack:///./src/components/EstuaryDetails/ThreatChart.jsx","webpack:///./src/components/EstuaryDetails/NFHP.jsx","webpack:///./src/components/EstuaryDetails/EstuaryType.jsx","webpack:///./src/components/EstuaryDetails/index.jsx","webpack:///./src/images/aerial/4036.jpg","webpack:///./src/images/aerial/1090.jpg","webpack:///./src/images/aerial/1080.jpg","webpack:///./src/images/aerial/1158.jpg","webpack:///./src/images/aerial/2032.jpg","webpack:///./src/images/aerial/1024.jpg","webpack:///./src/images/aerial/1060.jpg","webpack:///./src/images/aerial/3030.jpg","webpack:///./src/images/aerial/3008.jpg","webpack:///./src/images/aerial/2059.jpg","webpack:///./src/images/aerial/2078.jpg","webpack:///./src/components/Data/index.jsx","webpack:///./src/images/aerial/1066.jpg","webpack:///./src/images/aerial/1105.jpg","webpack:///./src/images/aerial/1056.jpg","webpack:///./src/images/aerial/2042.jpg","webpack:///./src/images/aerial/1009.jpg","webpack:///./src/images/satellite-streets-v11.jpg","webpack:///./src/images/aerial/1071.jpg","webpack:///./src/images/aerial/2108.jpg","webpack:///./src/images/aerial/2100.jpg","webpack:///./src/images/aerial/4041.jpg","webpack:///./src/images/aerial/3022.jpg","webpack:///./src/images/aerial/2092.jpg","webpack:///./src/images/aerial/3101.jpg","webpack:///./src/images/aerial/4051.jpg","webpack:///./src/images/aerial/3017.jpg","webpack:///./src/images/aerial/2022.jpg","webpack:///./src/images/aerial/3105.jpg","webpack:///./src/images/aerial/3085.jpg","webpack:///./src/images/aerial/3068.jpg","webpack:///./src/images/aerial/2001.jpg","webpack:///./src/images/aerial/3084.jpg","webpack:///./src/images/aerial/3033.jpg","webpack:///./node_modules/gatsby/node_modules/core-js/modules/es.array.flat-map.js","webpack:///./src/images/aerial/1153.jpg","webpack:///./src/images/aerial/2018.jpg","webpack:///./src/images/aerial/3059.jpg","webpack:///./src/images/aerial/2086.jpg","webpack:///./src/images/aerial/1111.jpg","webpack:///./src/images/aerial/4000.jpg","webpack:///./src/images/aerial/1144.jpg","webpack:///./src/images/aerial/2009.jpg","webpack:///./src/images/aerial/1064.jpg","webpack:///./node_modules/gatsby/node_modules/core-js/modules/es.array.unscopables.flat-map.js","webpack:///./src/images/aerial/1017.jpg","webpack:///./src/images/aerial/3079.jpg","webpack:///./src/images/aerial/1036.jpg","webpack:///./src/images/aerial/3089.jpg","webpack:///./src/images/aerial/4028.jpg","webpack:///./src/images/aerial/2081.jpg","webpack:///./src/images/aerial/1077.jpg","webpack:///./src/images/aerial/3002.jpg","webpack:///./src/images/aerial/4023.jpg","webpack:///./src/images/aerial/1004.jpg","webpack:///./src/images/aerial/1061.jpg","webpack:///./src/images/aerial/1097.jpg","webpack:///./src/images/aerial/3081.jpg","webpack:///./src/images/aerial/4025.jpg","webpack:///./src/images/aerial/1131.jpg","webpack:///./src/images/aerial/4046.jpg","webpack:///./src/images/aerial/1025.jpg","webpack:///./src/images/aerial/2104.jpg","webpack:///./src/images/aerial/3106.jpg","webpack:///./src/images/aerial/2093.jpg","webpack:///./src/images/aerial/2067.jpg","webpack:///./src/images/aerial/3007.jpg","webpack:///./src/images/aerial/3074.jpg","webpack:///./src/images/aerial/2090.jpg","webpack:///./src/images/aerial/2023.jpg","webpack:///./src/images/aerial/2068.jpg","webpack:///./src/images/aerial/1089.jpg","webpack:///./src/images/aerial/1138.jpg","webpack:///./src/images/aerial/2102.jpg","webpack:///./src/images/aerial/1008.jpg","webpack:///./src/images/aerial/3063.jpg","webpack:///./src/images/streets-v11.png","webpack:///./src/images/aerial/2030.jpg","webpack:///./src/images/aerial/1094.jpg","webpack:///./src/images/aerial/2005.jpg","webpack:///./src/images/aerial/2020.jpg","webpack:///./src/images/aerial/1113.jpg","webpack:///./src/images/aerial/4015.jpg","webpack:///./src/images/aerial/2051.jpg","webpack:///./src/images/aerial/1107.jpg","webpack:///./src/images/aerial/4032.jpg","webpack:///./src/images/aerial/1159.jpg","webpack:///./node_modules/gatsby/node_modules/core-js/internals/function-bind-context.js","webpack:///./src/images/aerial/4026.jpg","webpack:///./src/images/aerial/2088.jpg","webpack:///./src/images/aerial/3067.jpg","webpack:///./src/images/aerial/3075.jpg","webpack:///./src/images/aerial/2036.jpg","webpack:///./src/util/format.js","webpack:///./src/images/aerial/1005.jpg","webpack:///./src/images/aerial/3102.jpg","webpack:///./src/images/aerial/2105.jpg","webpack:///./src/images/aerial/2016.jpg","webpack:///./src/images/aerial/2053.jpg","webpack:///./src/images/aerial/2039.jpg","webpack:///./src/images/aerial/3104.jpg","webpack:///./node_modules/gatsby/node_modules/core-js/internals/html.js","webpack:///./src/images/aerial/2017.jpg","webpack:///./src/images/aerial/2035.jpg","webpack:///./node_modules/gatsby/node_modules/core-js/modules/es.array.reduce-right.js","webpack:///./src/images/aerial/1136.jpg","webpack:///./src/images/aerial/1124.jpg","webpack:///./src/images/aerial/1081.jpg","webpack:///./src/images/aerial/3021.jpg","webpack:///./src/images/aerial/1126.jpg","webpack:///./src/images/aerial/2011.jpg","webpack:///./src/images/aerial/1122.jpg","webpack:///./src/images/aerial/1125.jpg","webpack:///./src/images/aerial/1016.jpg","webpack:///./src/images/aerial/3065.jpg","webpack:///./src/images/aerial/3066.jpg","webpack:///./src/images/aerial/1029.jpg","webpack:///./src/images/aerial/3039.jpg","webpack:///./node_modules/@mapbox/sphericalmercator/sphericalmercator.js","webpack:///./src/images/aerial/1128.jpg","webpack:///./src/images/aerial/1114.jpg","webpack:///./src/images/aerial/1000.jpg","webpack:///./src/images/aerial/1041.jpg","webpack:///./src/images/aerial/1108.jpg","webpack:///./src/images/aerial/1148.jpg","webpack:///./node_modules/crossfilter2/src/array.js","webpack:///./node_modules/crossfilter2/src/filter.js","webpack:///./node_modules/crossfilter2/src/identity.js","webpack:///./node_modules/crossfilter2/src/null.js","webpack:///./node_modules/crossfilter2/src/zero.js","webpack:///./node_modules/crossfilter2/src/heap.js","webpack:///./node_modules/crossfilter2/src/heapselect.js","webpack:///./node_modules/crossfilter2/src/bisect.js","webpack:///./node_modules/crossfilter2/src/permute.js","webpack:///./node_modules/crossfilter2/src/reduce.js","webpack:///./node_modules/crossfilter2/src/result.js","webpack:///./node_modules/@ranfdev/deepobj/dist/deepobj.m.js","webpack:///./node_modules/crossfilter2/src/index.js","webpack:///./src/components/Crossfilter/util.js","webpack:///./src/components/Crossfilter/Crossfilter.jsx","webpack:///./src/components/Crossfilter/Context.jsx","webpack:///./src/components/Map/Legend.jsx","webpack:///./src/components/Map/StyleSelector.jsx","webpack:///./src/components/Map/LayerToggle.jsx","webpack:///./src/components/Map/FullExtentButton.jsx","webpack:///./config/map.js","webpack:///./src/components/Map/index.jsx","webpack:///./src/components/Crossfilter/FilteredMap.jsx","webpack:///./src/images/aerial/2098.jpg","webpack:///./src/images/aerial/3093.jpg","webpack:///./src/images/aerial/4047.jpg","webpack:///./src/images/aerial/1003.jpg","webpack:///./src/components/Sidebar/Header.jsx","webpack:///./src/components/Sidebar/index.jsx","webpack:///./src/images/aerial/1062.jpg","webpack:///./src/images/aerial/2103.jpg","webpack:///./src/images/aerial/3047.jpg","webpack:///./src/images/aerial/1021.jpg","webpack:///./src/images/aerial/2034.jpg","webpack:///./src/images/aerial/2040.jpg","webpack:///./src/images/aerial/2007.jpg","webpack:///./src/images/aerial/1072.jpg","webpack:///./node_modules/gatsby/node_modules/core-js/modules/es.math.hypot.js","webpack:///./src/images/aerial/1098.jpg","webpack:///./src/images/aerial/2057.jpg","webpack:///./src/images/aerial/3014.jpg","webpack:///./src/images/aerial/4024.jpg","webpack:///./src/images/aerial/3028.jpg","webpack:///./src/images/aerial/2099.jpg","webpack:///./src/images/aerial/1120.jpg","webpack:///./src/images/aerial/1048.jpg","webpack:///./src/images/aerial/1069.jpg","webpack:///./src/images/aerial/4060.jpg","webpack:///./src/images/aerial/4053.jpg","webpack:///./src/images/aerial/3000.jpg","webpack:///./src/util/data.js","webpack:///./src/images/aerial/3042.jpg","webpack:///./src/images/aerial/1002.jpg","webpack:///./src/images/aerial/2062.jpg","webpack:///./src/images/aerial/3016.jpg","webpack:///./src/images/aerial/2056.jpg","webpack:///./src/images/aerial/3078.jpg","webpack:///./src/images/aerial/4030.jpg","webpack:///./src/images/aerial/1012.jpg","webpack:///./src/images/aerial/2071.jpg","webpack:///./src/images/aerial/2072.jpg","webpack:///./src/images/aerial/2046.jpg","webpack:///./src/images/aerial/3003.jpg","webpack:///./src/images/aerial/1134.jpg","webpack:///./src/images/aerial/4010.jpg","webpack:///./src/images/aerial/1139.jpg","webpack:///./src/images/aerial/4017.jpg","webpack:///./src/images/aerial/1032.jpg","webpack:///./src/images/aerial/1095.jpg","webpack:///./src/images/aerial/1044.jpg","webpack:///./src/images/aerial/2003.jpg","webpack:///./src/images/aerial/4031.jpg","webpack:///./src/images/aerial/3062.jpg","webpack:///./src/images/aerial/4001.jpg","webpack:///./src/images/aerial/3091.jpg","webpack:///./src/images/aerial/4052.jpg","webpack:///./src/images/riverine.svg","webpack:///./src/images/aerial/1092.jpg","webpack:///./src/images/aerial/1146.jpg","webpack:///./src/images/aerial/2045.jpg","webpack:///./src/images/aerial/3031.jpg","webpack:///./src/images/aerial/2055.jpg","webpack:///./node_modules/@mapbox/geo-viewport/index.js","webpack:///./node_modules/gatsby/node_modules/core-js/internals/add-to-unscopables.js","webpack:///./src/images/aerial/1101.jpg","webpack:///./src/images/aerial/1161.jpg","webpack:///./src/images/aerial/4043.jpg","webpack:///./src/images/aerial/1102.jpg","webpack:///./src/images/aerial/2085.jpg","webpack:///./src/images/aerial/1127.jpg","webpack:///./config/constants.js","webpack:///./src/images/aerial/4029.jpg","webpack:///./src/images/aerial/1028.jpg","webpack:///./src/images/aerial/3044.jpg","webpack:///./src/images/aerial/1083.jpg","webpack:///./src/images/aerial/3073.jpg","webpack:///./src/images/aerial/1046.jpg","webpack:///./src/images/aerial/3018.jpg","webpack:///./src/images/aerial/1007.jpg","webpack:///./src/images/aerial/4003.jpg","webpack:///./src/images/aerial/2077.jpg","webpack:///./src/images/aerial/2075.jpg","webpack:///./src/images/aerial/3092.jpg","webpack:///./src/images/aerial/1151.jpg","webpack:///./src/images/aerial/4022.jpg","webpack:///./src/images/aerial/3025.jpg","webpack:///./src/images/aerial/4005.jpg","webpack:///./src/images/aerial/3103.jpg","webpack:///./src/images/aerial/2043.jpg","webpack:///./node_modules/react-immutable-proptypes/dist/ImmutablePropTypes.js","webpack:///./src/images/aerial/1155.jpg","webpack:///./src/images/aerial/3060.jpg","webpack:///./src/images/aerial/1059.jpg","webpack:///./src/images/aerial/4013.jpg","webpack:///./src/images/aerial/1143.jpg","webpack:///./src/images/aerial/3013.jpg","webpack:///./src/images/aerial/4004.jpg","webpack:///./src/images/aerial/3095.jpg","webpack:///./src/images/aerial/1133.jpg","webpack:///./src/images/aerial/1157.jpg","webpack:///./src/images/aerial/3005.jpg","webpack:///./src/images/aerial/1068.jpg"],"names":["module","exports","map","webpackContext","req","id","webpackContextResolve","__webpack_require__","o","e","Error","code","keys","Object","resolve","internalObjectKeys","enumBugKeys","O","classof","Array","isArray","arg","isObject","SPECIES","wellKnownSymbol","originalArray","length","C","constructor","prototype","undefined","toLength","bind","flattenIntoArray","target","original","source","sourceLen","start","depth","mapper","thisArg","element","targetIndex","sourceIndex","mapFn","TypeError","HelpText","styled","Text","themeGet","Wrapper","div","Snippet","p","PseudoLink","span","ExpandableParagraph","snippet","children","props","useState","isOpen","setIsOpen","onClick","prevIsOpen","activeXDocument","anObject","defineProperties","hiddenKeys","html","documentCreateElement","sharedKey","IE_PROTO","EmptyConstructor","scriptTag","content","LT","NullProtoObject","document","domain","ActiveXObject","error","iframeDocument","iframe","write","close","temp","parentWindow","NullProtoObjectViaActiveX","style","display","appendChild","src","String","contentWindow","open","F","create","Properties","result","getCenterAndZoom","bounds","width","height","padding","viewport","geoViewport","zoom","Math","max","center","boundsOverlap","xmin","ymin","xmax","ymax","xmin2","ymin2","xmax2","toGeoJSONPoints","records","type","features","r","record","x","y","properties","filter","f","forEach","feature","geometry","coordinates","toGeoJSONPoint","groupByLayer","results","layer","push","createSteps","entries","property","steps","i","threshold","entry","NOT_SET","SetRef","ref","value","OwnerID","ensureSize","iter","size","__iterate","returnTrue","wrapIndex","index","uint32Index","NaN","wholeSlice","begin","end","isNeg","resolveBegin","resolveIndex","resolveEnd","defaultIndex","Infinity","min","isCollection","maybeCollection","Boolean","isKeyed","maybeKeyed","isIndexed","maybeIndexed","isAssociative","maybeAssociative","Collection","Seq","KeyedCollection","KeyedSeq","__proto__","IndexedCollection","IndexedSeq","SetCollection","SetSeq","Keyed","Indexed","Set","isSeq","maybeSeq","isRecord","maybeRecord","isImmutable","maybeImmutable","IS_ORDERED_SYMBOL","isOrdered","maybeOrdered","REAL_ITERATOR_SYMBOL","Symbol","iterator","ITERATOR_SYMBOL","Iterator","next","this","iteratorValue","k","v","iteratorResult","done","iteratorDone","hasIterator","maybeIterable","getIteratorFn","isIterator","maybeIterator","getIterator","iterable","iteratorFn","call","toString","KEYS","VALUES","ENTRIES","inspect","toSource","hasOwnProperty","isArrayLike","Number","isInteger","Collection$$1","emptySequence","toSeq","seq","maybeIndexedSeqFromValue","ObjectSeq","seqFromValue","__toString","cacheResult","_cache","__iterateUncached","entrySeq","toArray","fn","reverse","cache","__iterator","__iteratorUncached","toKeyedSeq","fromEntrySeq","keyedSeqFromValue","toIndexedSeq","indexedSeqFromValue","of","arguments","toSetSeq","ArraySeq","array","_array","get","notSetValue","has","ii","object","_object","_keys","key","EMPTY_SEQ","CollectionSeq","collection","_collection","iterations","step","isMap","maybeMap","isOrderedMap","maybeOrderedMap","isValueObject","maybeValue","equals","hashCode","is","valueA","valueB","valueOf","imul","a","b","c","d","smi","i32","defaultValueOf","hash","n","hashNumber","STRING_HASH_CACHE_MIN_STRLEN","string","hashed","stringHashCache","hashString","STRING_HASH_CACHE_SIZE","STRING_HASH_CACHE_MAX_SIZE","cachedHashString","obj","usingWeakMap","weakMap","UID_HASH_KEY","canDefineProperty","propertyIsEnumerable","node","nodeType","uniqueID","documentElement","getIENodeHash","objHashUID","set","isExtensible","defineProperty","enumerable","configurable","writable","apply","hashJSObj","charCodeAt","WeakMap","ToKeyedSequence","KeyedSeq$$1","indexed","useKeys","_iter","_useKeys","valueSeq","this$1","reversedSequence","reverseFactory","context","mappedSequence","mapFactory","ToIndexedSequence","IndexedSeq$$1","includes","ToSetSequence","SetSeq$$1","FromEntriesSequence","validateEntry","indexedCollection","flipFactory","flipSequence","makeSequence","flip","cacheResultThrough","filterFactory","predicate","filterSequence","sliceFactory","originalSize","resolvedBegin","resolvedEnd","sliceSize","resolvedSize","sliceSeq","skipped","isSkipping","skipWhileFactory","skipSequence","skipping","concatFactory","values","isKeyedCollection","iters","concat","singleton","concatSeq","flatten","reduce","sum","flattenFactory","flatSequence","stopped","flatDeep","currentDepth","stack","pop","sortFactory","comparator","defaultComparator","sort","maxFactory","maxCompare","comp","zipWithFactory","keyIter","zipper","zipAll","zipSequence","sizes","iterators","isDone","every","s","some","reify","collectionClass","arrCopy","arr","offset","len","newArr","invariant","condition","assertNotInfinite","coerceKeyPath","keyPath","isPlainObj","name","isDataStructure","quoteString","JSON","stringify","_ignoreError","shallowCopy","from","to","remove","collectionCopy","splice","updateIn","updater","updatedValue","updateInDeeply","inImmutable","existing","wasNotSet","existingValue","newValue","slice","nextExisting","nextUpdated","emptyMap","setIn","setIn$1","removeIn","deleteIn","update","update$1","updateIn$1","merge","mergeIntoKeyedWith","mergeWith","merger","collections","collection$1","__ownerID","withMutations","mergeIntoCollection","oldVal","merge$1","sources","mergeWithSources","mergeWith$1","mergeDeep","mergeDeepWithSources","mergeDeepWith","deepMerger","oldValue","deepMergerWith","merged","mergeItem","hasVal","nextVal","mergeDeep$1","mergeDeepWith$1","mergeIn","m","mergeDeepIn","mutable","asMutable","wasAltered","__ensureOwner","asImmutable","__altered","Map","KeyedCollection$$1","keyValues","_root","updateMap","deleteAll","clear","__hash","OrderedMap","sortBy","MapIterator","iterate","ownerID","makeMap","MapPrototype","removeAll","ArrayMapNode","shift","keyHash","didChangeSize","didAlter","removed","idx","exists","MAX_ARRAY_MAP_SIZE","ValueNode","createNodes","isEditable","newEntries","BitmapIndexedNode","bitmap","nodes","bit","SIZE","popCount","keyHashFrag","newNode","updateNode","MAX_BITMAP_INDEXED_SIZE","including","count","expandedNodes","HashArrayMapNode","expandNodes","isLeafNode","newBitmap","newNodes","setAt","canEdit","newLen","newArray","after","spliceOut","val","spliceIn","newCount","MIN_HASH_ARRAY_MAP_SIZE","excluding","packedII","packedNodes","packNodes","HashCollisionNode","mergeIntoNode","keyMatch","maxIndex","EMPTY_MAP","Iterator$$1","_type","_reverse","_stack","mapIteratorFrame","mapIteratorValue","subNode","__prev","prev","root","hash$$1","newRoot","newSize","idx1","idx2","isList","maybeList","List","IndexedCollection$$1","empty","emptyList","makeList","VNode","list","setSize","listNodeFor","_origin","setListBounds","newTail","_tail","getTailOffset","_capacity","updateVNode","_level","updateList","insert","oldSize","unshift","arguments$1","seqs","argument","iterateList","DONE","ListPrototype","removeBefore","level","originIndex","newChild","removingFirst","oldChild","editable","editableVNode","removeAfter","sizeIndex","EMPTY_LIST","left","right","tailPos","tail","iterateNodeOrLeaf","iterateLeaf","iterateNode","origin","capacity","nodeHas","lowerNode","newLowerNode","rawIndex","owner","oldOrigin","oldCapacity","newOrigin","newCapacity","newLevel","offsetShift","oldTailOffset","newTailOffset","oldTail","beginIndex","EMPTY_ORDERED_MAP","Map$$1","emptyOrderedMap","_map","_list","updateOrderedMap","newMap","newList","makeOrderedMap","omap","toMap","isStack","maybeStack","Stack","emptyStack","pushAll","head","_head","peek","makeStack","EMPTY_STACK","StackPrototype","unshiftAll","isSet","maybeSet","isOrderedSet","maybeOrderedSet","deepEqual","notAssociative","flipped","_","allEqual","bSize","mixin","ctor","methods","keyCopier","getOwnPropertySymbols","toJS","result$1","SetCollection$$1","emptySet","add","fromKeys","keySeq","intersect","sets","SetPrototype","union","updateSet","removes","adds","mapped","toRemove","subtract","OrderedSet","__make","__empty","EMPTY_SET","makeSet","EMPTY_RANGE","Range","abs","_start","_end","_step","ceil","searchValue","possibleIndex","floor","indexOf","offsetValue","lastIndexOf","other","getIn","searchKeyPath","getIn$1","hasIn","toObject","isIterable","useTuples","toOrderedMap","toOrderedSet","toSet","toStack","toList","__toStringMapper","join","returnValue","find","findEntry","sideEffect","separator","joined","isFirst","reducer","initialReduction","reduceRight","not","butLast","isEmpty","countBy","grouper","groups","countByFactory","entriesSequence","entryMapper","filterNot","found","findKey","findLast","findLastEntry","findLastKey","first","flatMap","coerce","flatMapFactory","searchKey","groupBy","isKeyedIter","groupByFactory","isSubset","isSuperset","keyOf","keyMapper","last","lastKeyOf","maxBy","neg","defaultNegComparator","minBy","rest","skip","amount","skipLast","skipWhile","skipUntil","take","takeLast","takeWhile","takeSequence","iterating","takeWhileFactory","takeUntil","ordered","keyed","h","murmurHashOfSize","hashMerge","hashCollection","CollectionPrototype","toJSON","chain","contains","mapEntries","mapKeys","KeyedCollectionPrototype","findIndex","removeNum","numArgs","spliced","findLastIndex","interpose","interposedSequence","interposeFactory","interleave","zipped","interleaved","zip","defaultZipper","zipWith","IndexedCollectionPrototype","reduction","useFirst","Set$$1","emptyOrderedSet","EMPTY_ORDERED_SET","OrderedSetPrototype","makeOrderedSet","Record","defaultValues","hasInitialized","RecordType","indices","RecordTypePrototype","_indices","_name","_defaultValues","propName","console","warn","recordName","setProp","_values","l","RecordPrototype","displayName","str","recordSeq","newValues","makeRecord","getDescriptiveName","likeRecord","getPrototypeOf","EMPTY_REPEAT","Repeat","times","_value","fromJS","converter","fromJSWith","parentValue","converted","defaultConverter","version","Immutable","Iterable","hasValue","filterValues","filters","field","internal","getValue","toLowerCase","filterFunc","mapBounds","estuaryBounds","title","estuaryTypes","parseInt","labels","label","sizeClasses","sizeClassLabels","classify","description","moreInfoURL","species","splitWords","sppCountClasses","sppCountClassLabels","regions","states","state","stateNames","split","bioticTypes","bioticInfo","twAcres","twlAcres","percent","twlBins","bin","twlBinLabels","nfhpCodes","nfhpLabels","DESCRIPTORS","definePropertyModule","objectKeys","FaIcon","iconName","toUpperCase","Icon","require","defaultProps","DefaultButton","BaseButton","attrs","variant","PrimaryButton","SecondaryButton","WarningButton","Button","primary","secondary","disabled","warning","StyledButton","ButtonGroup","Flex","alignItems","InactiveButton","ToggleButton","options","onChange","handleClick","memo","ActiveButton","active","prevId","prevActive","nextId","nextActive","alignItem","justifyContent","flex","TabBar","tabs","activeTab","tab","prevTabs","prevTab","nextTabs","nextTab","TabContainer","Children","propTypes","PropTypes","arrayOf","isRequired","Tab","flexDirection","Tabs","firstTab","setTab","Header","ul","Stage","Section","section","SoKLink","rel","SpeciesList","data","status","stage","juvenileCount","statusNote","sppEOLIDs","Title","Bar","color","Acres","Content","expandoColor","theme","colors","grey","CaretDown","FaCaretDown","CaretRight","FaCaretRight","BioticListItem","acres","maxAcres","toggle","link","position","formatNumber","BioticList","biotic","totalAcres","Circle","circle","PercentLabel","tspan","fontSize","Percent","Label","Donut","percentLabel","percentSize","backgroundColor","donutWidth","halfsize","radius","circumference","PI","rotateval","cx","cy","stroke","strokeWidth","transform","strokeDasharray","className","textAnchor","dominantBaseline","isActive","calculateRotation","offsets","mt","StyledDonut","MultiValueDonut","Note","Patch","Legend","assign","twInfo","TidalWetlandLoss","area","lost","restored","retained","percentLost","percentRestored","percentRetained","donutEntries","my","number","Box","mx","nfhpColors","Labels","ItemContainer","borderColor","Level","isLower","isUpper","borderRadius","css","levels","ThreatChart","BaseHelpText","NFHPLink","NFHAPAbout","NFHP","StatusNote","Graphic","img","graphics","0","bay","1","delta","2","riverine","3","lagoonal","EstuaryType","graphic","alt","Subtitle","BackIcon","FaRegTimesCircle","Image","ImageCredits","textAlign","ZoomButton","TabHeader","Value","BaseTab","getImage","EstuaryDetails","imageURL","imageCredits","region","SoKJoin","nfhp2015","NFHPJoin","twrAcres","showZoom","onBack","onZoomTo","countSpecies","countBiotic","areaBiotic","url","credits","useData","useStaticQuery","allEstuariesJson","edges","imageRoot","packedToObject","parseFloat","item","isDebug","window","$","aFunction","arraySpeciesCreate","proto","callbackfn","A","addToUnscopables","that","decimals","absNumber","targetDecimals","round","factor","toLocaleString","minimumFractionDigits","maximumFractionDigits","text","newText","getBuiltIn","$reduceRight","arrayMethodIsStrict","arrayMethodUsesToLength","CHROME_VERSION","IS_NODE","STRICT_METHOD","USES_TO_LENGTH","forced","SphericalMercator","D2R","R2D","MAXEXTENT","isFloat","Bc","Cc","zc","Ac","px","ll","pow","bc","cc","ac","sin","log","g","atan","exp","bbox","tms_style","srs","ur","convert","xyz","px_ll","px_ur","minX","minY","maxX","maxY","tms","forward","inverse","xy","tan","array8","arrayUntyped","array16","array32","arrayLengthen","arrayLengthenUntyped","arrayWiden","arrayWidenUntyped","bitarray","subarrays","masks","Uint8Array","Uint16Array","Uint32Array","copy","lengthen","w","one","dest","truncate","j","zero","zeroExcept","zeroExceptMask","mask","only","onlyExcept","onlyOffset","onlyOne","bisect","range","heap_by","heap","lo","hi","sift","child","t","identity","by","heapselect_by","queue","bisect_by","bisectRight","mid","deep","parse","prop","reg","path","replace","heapselect","permute","crossfilter","removeData","dimension","groupAll","all","allFiltered","isElementFiltered","filterListeners","dataListeners","removeDataListeners","callbacks","newData","n0","n1","triggerOnChange","newIndex","usePred","index1","index2","index3","index4","maskForDimensions","dimensions","ignore_dimensions","accessorPath","_id","iterablesIndexCount","iterablesIndexFilterStatus","refilterFunction","filterValue","filterValuePresent","filterAll","filterRange","filterFunction","filterExact","currentFilter","hasCurrentFilter","top","top_offset","hi0","toSkip","lo0","iterablesEmptyRows","bottom","bottom_offset","group","order","orderNatural","dispose","accessor","sortRange","cr_range","B","refilter","indexListeners","dimensionGroups","preAdd","postAdd","tmp","newIterablesIndexCount","newIterablesIndexFilterStatus","i0","cr_index","unsortedIndex","sortMap","lo1","hi1","old_n0","oldValues","oldIndex","oldIterablesIndexFilterStatus","i1","oldiiclength","index5","reIndex","oldDataIndex","filterIndexBounds","filterIndexFunction","added","valueIndexAdded","valueIndexRemoved","newAdded","newRemoved","indexLength","reduceCount","reduceSum","groupIndex","select","reduceAdd","reduceRemove","reduceInitial","n0old","groupWidth","groupCapacity","reset","resetNeeded","g0","x0","x1","oldGroups","initial","k0","groupIncrement","updateMany","resetMany","updateOne","resetOne","oldK","seenGroups","filterOne","filterOffset","notFilter","reduceValue","cb","eventName","countByDimension","dimCounts","config","counts","countFiltered","cf","RESET_FILTERS","SET_FILTER","Context","createContext","Provider","crossfilterRef","useRef","dimensionsRef","useReducer","payload","current","newState","dimensionCounts","filteredCount","fields","newFilters","Crossfilter","dimensionFunction","total","useCrossfilter","dispatch","Column","BaseColumn","borderWidth","scale","fill","EntryWrapper","Entry","isClosed","setIsClosed","cols","prevIsClosed","colEntries","Basemap","icons","LightIcon","SatelliteIcon","StreetsIcon","StyleSelector","styles","basemap","setBasemap","handleBasemapClick","newBasemap","toggleOpen","nextBasemap","onMouseEnter","onMouseLeave","styleID","TopBarToggle","LayerToggle","FaExternalLinkAlt","FullExtentButton","boundaryLayer","bioticLayer","tileURL","sourceLayer","idProperty","twLayer","clusters","clusterRadii","bioticStyle","twStyle","accessToken","siteMetadata","mapboxToken","PNWBounds","minZoom","boundaries","tiles","minzoom","maxzoom","tileSize","biotics","tidalWetlands","points","cluster","clusterMaxZoom","clusterRadius","layers","paint","stops","base","layout","visibility","legends","getLegend","clusterThresholds","point_count","boundaryColor","Relative","renderTooltipContent","selectedFeature","location","onSelectFeature","onBoundsChange","hasWindow","mapNode","mapRef","baseStyleRef","indexRef","fullDataCount","selectedFeatureRef","locationMarkerRef","legendEntries","setLegendEntries","activeLayer","setActiveLayer","useEffect","initBounds","targetBounds","offsetWidth","offsetHeight","mapboxgl","container","addControl","NavigationControl","indexBy","on","getStyle","baseStyle","addSource","addLayer","queryRenderedFeatures","point","layerId","getSource","getClusterExpansionZoom","cluster_id","err","targetZoom","easeTo","tooltip","Popup","closeButton","closeOnClick","anchor","getCanvas","cursor","clusterId","setFilter","getClusterLeaves","names","setLngLat","setHTML","addTo","getZoom","PMEP_EstuaryID","unproject","CMECS_BC_Code","TWL_Type","getBounds","lowerLeft","upperRight","getLegendEntries","removeLocationMarker","isStyleLoaded","geoJSON","setData","filterLayers","filterExpr","lon","lat","Marker","fitBounds","maxZoom","duration","panTo","queryLayers","layerIndex","visibleFeatures","grouped","leftLayer","rightLayer","newLayer","isBiotics","setLayoutProperty","token","snapshot","baseSources","baseLayers","userSources","userLayers","setStyle","once","FilteredMap","useContext","flexWrap","as","icon","InnerWrapper","allowScroll","Sidebar","$hypot","hypot","sqrt","stat","value1","value2","aLen","larg","ranges","modifier","part","arrays","indexField","smCache","fetchMerc","allowFloat","merc","bl","tr","centerPixelX","centerPixelY","ratios","adjusted","getAdjusted","tl","br","UNSCOPABLES","ArrayPrototype","WA","OR","ORWA","CA","BatRay","BayShrimp","BrownRockfish","CaliforniaHalibut","ChinookSalmon","CohoSalmon","DungenessCrab","EnglishSole","GreenSturgeon","LeopardShark","PacificHerring","ShinerPerch","StaghornSculpin","StarryFlounder","Steelhead","5","4","GE","ImmutablePropTypes","productionTypeChecker","getProductionTypeChecker","getPropType","propValue","propType","RegExp","createChainableTypeChecker","validate","checkType","componentName","propFullName","_len","_key","locationName","chainedCheckType","createIterableSubclassTypeChecker","subclassName","validator","immutableClassName","immutableClassTypeValidator","listOf","mapOf","orderedMapOf","setOf","orderedSetOf","stackOf","iterableOf","recordOf","shape","mapContains","orderedMapContains","orderedMap","orderedSet"],"mappings":"gFAAAA,EAAOC,QAAU,IAA0B,oD,uBCA3CD,EAAOC,QAAU,IAA0B,oD,uBCA3CD,EAAOC,QAAU,IAA0B,oD,uBCA3CD,EAAOC,QAAU,IAA0B,oD,uBCA3CD,EAAOC,QAAU,IAA0B,oD,uBCA3CD,EAAOC,QAAU,IAA0B,oD,uBCA3CD,EAAOC,QAAU,IAA0B,oD,uBCA3CD,EAAOC,QAAU,IAA0B,oD,uBCA3CD,EAAOC,QAAU,IAA0B,oD,uBCA3CD,EAAOC,QAAU,IAA0B,oD,uBCA3CD,EAAOC,QAAU,IAA0B,oD,uBCA3CD,EAAOC,QAAU,IAA0B,oD,uBCA3CD,EAAOC,QAAU,IAA0B,oD,uBCA3CD,EAAOC,QAAU,IAA0B,oD,uBCA3CD,EAAOC,QAAU,IAA0B,oD,uBCA3C,IAAIC,EAAM,CACT,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OACd,aAAc,OAC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,EAAOC,QAAU,IAA0B,oD,qBCA3CD,EAAOC,QAAU,IAA0B,qD,qBCA3CD,EAAOC,QAAU,IAA0B,oD,qBCA3CD,EAAOC,QAAU,IAA0B,oD,qBCA3CD,EAAOC,QAAU,IAA0B,oD,qBCA3CD,EAAOC,QAAU,IAA0B,oD,qBCA3CD,EAAOC,QAAU,IAA0B,oD,qBCA3CD,EAAOC,QAAU,IAA0B,oD,qBCA3CD,EAAOC,QAAU,IAA0B,oD,qBCA3CD,EAAOC,QAAU,IAA0B,oD,qBCA3CD,EAAOC,QAAU,IAA0B,oD,qBCA3CD,EAAOC,QAAU,IAA0B,oD,qBCA3CD,EAAOC,QAAU,IAA0B,oD,uBCA3CD,EAAOC,QAAU,IAA0B,oD,qBCA3CD,EAAOC,QAAU,IAA0B,oD,uBCA3CD,EAAOC,QAAU,IAA0B,oD,qBCA3CD,EAAOC,QAAU,IAA0B,oD,qBCA3CD,EAAOC,QAAU,IAA0B,oD,uBCA3CD,EAAOC,QAAU,IAA0B,oD,qBCA3CD,EAAOC,QAAU,IAA0B,mD,qBCA3CD,EAAOC,QAAU,IAA0B,oD,qBCA3CD,EAAOC,QAAU,IAA0B,oD,qBCA3CD,EAAOC,QAAU,IAA0B,oD,qBCA3CD,EAAOC,QAAU,IAA0B,oD,qBCA3CD,EAAOC,QAAU,IAA0B,oD,qBCA3CD,EAAOC,QAAU,IAA0B,oD,uBCA3CD,EAAOC,QAAU,IAA0B,oD,qBCA3CD,EAAOC,QAAU,IAA0B,oD,qBCA3CD,EAAOC,QAAU,IAA0B,oD,qBCA3CD,EAAOC,QAAU,IAA0B,oD,qBCA3CD,EAAOC,QAAU,IAA0B,oD,qBCA3CD,EAAOC,QAAU,IAA0B,oD,qBCA3CD,EAAOC,QAAU,IAA0B,oD,qBCA3CD,EAAOC,QAAU,IAA0B,oD,qBCA3CD,EAAOC,QAAU,IAA0B,oD,qBCA3CD,EAAOC,QAAU,IAA0B,oD,qBCA3CD,EAAOC,QAAU,IAA0B,oD,qBCA3CD,EAAOC,QAAU,IAA0B,oD,qBCA3CD,EAAOC,QAAU,IAA0B,oD,qBCA3CD,EAAOC,QAAU,IAA0B,oD,qBCA3CD,EAAOC,QAAU,IAA0B,oD,qBCA3CD,EAAOC,QAAU,IAA0B,oD,uBCA3CD,EAAOC,QAAU,IAA0B,oD,qBC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,uBCA3CD,EAAOC,QAAU,IAA0B,oD,qBCA3CD,EAAOC,QAAU,IAA0B,oD,qBCA3CD,EAAOC,QAAU,IAA0B,oD,qBCEpB,EAAQ,OAE/BglC,CAAiB,Y,qBCJjBjlC,EAAOC,QAAU,IAA0B,oD,qBCA3CD,EAAOC,QAAU,IAA0B,oD,qBCA3CD,EAAOC,QAAU,IAA0B,oD,qBCA3CD,EAAOC,QAAU,IAA0B,oD,qBCA3CD,EAAOC,QAAU,IAA0B,oD,qBCA3CD,EAAOC,QAAU,IAA0B,oD,qBCA3CD,EAAOC,QAAU,IAA0B,oD,qBCA3CD,EAAOC,QAAU,IAA0B,oD,qBCA3CD,EAAOC,QAAU,IAA0B,oD,qBCA3CD,EAAOC,QAAU,IAA0B,oD,qBCA3CD,EAAOC,QAAU,IAA0B,oD,qBCA3CD,EAAOC,QAAU,IAA0B,oD,qBCA3CD,EAAOC,QAAU,IAA0B,oD,qBCA3CD,EAAOC,QAAU,IAA0B,oD,qBCA3CD,EAAOC,QAAU,IAA0B,oD,qBCA3CD,EAAOC,QAAU,IAA0B,oD,qBCA3CD,EAAOC,QAAU,IAA0B,oD,qBCA3CD,EAAOC,QAAU,IAA0B,oD,qBCA3CD,EAAOC,QAAU,IAA0B,oD,qBCA3CD,EAAOC,QAAU,IAA0B,oD,qBCA3CD,EAAOC,QAAU,IAA0B,oD,qBCA3CD,EAAOC,QAAU,IAA0B,oD,qBCA3CD,EAAOC,QAAU,IAA0B,oD,qBCA3CD,EAAOC,QAAU,IAA0B,oD,qBCA3CD,EAAOC,QAAU,IAA0B,oD,qBCA3CD,EAAOC,QAAU,IAA0B,oD,qBCA3CD,EAAOC,QAAU,IAA0B,oD,qBCA3CD,EAAOC,QAAU,IAA0B,oD,qBCA3CD,EAAOC,QAAU,IAA0B,oD,qBCA3CD,EAAOC,QAAU,IAA0B,oD,qBCA3CD,EAAOC,QAAU,IAA0B,oD,mBCA3CD,EAAOC,QAAU,s5T,uBCAjBD,EAAOC,QAAU,IAA0B,oD,qBCA3CD,EAAOC,QAAU,IAA0B,oD,qBCA3CD,EAAOC,QAAU,IAA0B,oD,qBCA3CD,EAAOC,QAAU,IAA0B,oD,qBCA3CD,EAAOC,QAAU,IAA0B,oD,qBCA3CD,EAAOC,QAAU,IAA0B,oD,qBCA3CD,EAAOC,QAAU,IAA0B,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AC,GAAI,EAAG,EAAG,GAAI,GACjCC,EAAsB,CACjC,wBACA,sBACA,sBACA,mBACA,+BAGWM,EAAc,CACzB,IACA,MACA,MACA,QACA,QACA,UACA,aACA,MACA,QACA,UACA,MACA,QACA,UACA,MACA,QACA,WAIWC,EAAa,CACxB,EAAK,CACHhB,MAAO,yBACPI,YACE,0OACFgG,MAAO,UACPe,KAAM,mEAER,IAAO,CACLnH,MAAO,aACPI,YACE,6QACFgG,MAAO,UACPe,KAAM,mEAER,IAAO,CACLnH,MAAO,yBACPI,YACE,wOACFgG,MAAO,UACPe,KAAM,mEAER,QAAS,CACPnH,MAAO,qBACPI,YACE,kRACFgG,MAAO,UACPe,KAAM,mEAER,QAAS,CACPnH,MAAO,8BACPI,YACE,4LACFgG,MAAO,UACPe,KAAM,mEAER,UAAW,CACTnH,MAAO,eACPI,YACE,6NACFgG,MAAO,UACPe,KAAM,mEAER,aAAc,CACZnH,MAAO,WACPI,YACE,kRACFgG,MAAO,WAGT,IAAO,CACLpG,MAAO,mBACPI,YACE,+WACFgG,MAAO,UACPe,KAAM,mEAER,QAAS,CACPnH,MAAO,uBACPI,YACE,gLACFgG,MAAO,UACPe,KAAM,mEAER,UAAW,CACTnH,MAAO,gCACPI,YACE,yKACFgG,MAAO,UACPe,KAAM,mEAER,IAAO,CACLnH,MAAO,sBACPI,YACE,+VACFgG,MAAO,UACPe,KAAM,mEAER,QAAS,CACPnH,MAAO,4BACPI,YACE,qGACFgG,MAAO,UACPe,KAAM,mEAER,UAAW,CACTnH,MAAO,qCACPI,YACE,+HACFgG,MAAO,UACPe,KAAM,mEAER,IAAO,CACLnH,MAAO,mBACPI,YACE,sNACFgG,MAAO,UACPe,KAAM,mEAER,QAAS,CACPnH,MAAO,yBACPI,YACE,qEACFgG,MAAO,UACPe,KAAM,mEAER,UAAW,CACTnH,MAAO,iCACPI,YACE,kJACFgG,MAAO,UACPe,KAAM,oEAIG0C,EAAS,CACpBG,KAAM,CACJhK,MAAO,OACPoG,MAAO,WAET6D,SAAU,CACRjK,MAAO,WACPoG,MAAO,WAET8D,SAAU,CAAE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","file":"097a6631cebf5178e58eacc8dba4c6921e7fc0b7-6b568a00bd08ca6bd032.js","sourcesContent":["module.exports = __webpack_public_path__ + \"static/2013-82cbb4a49e5741b1e91187e142797bd6.jpg\";","module.exports = __webpack_public_path__ + \"static/3010-c598ef2de4a4fbd9946689c7d614e772.jpg\";","module.exports = __webpack_public_path__ + \"static/1063-3eb38d65fb9b1b0df914bb63016c75f3.jpg\";","module.exports = __webpack_public_path__ + \"static/3038-a9a0db83a65f284fd8d223cd3f465d09.jpg\";","module.exports = __webpack_public_path__ + \"static/2084-0f66674e0554d18ece32c0a8b1c48efd.jpg\";","module.exports = __webpack_public_path__ + \"static/1129-8d39f3141b564198165447aa24df1dd2.jpg\";","module.exports = __webpack_public_path__ + \"static/2052-fd90ff2e757536bbd95bed11891ec878.jpg\";","module.exports = __webpack_public_path__ + \"static/4048-96a214f2d1e53befab4137be8d01be32.jpg\";","module.exports = __webpack_public_path__ + \"static/2048-d60c3bf007d51e737ad163cf09cb6003.jpg\";","module.exports = __webpack_public_path__ + \"static/1110-1c3a649cf4e0da5f5231809b4e24e47d.jpg\";","module.exports = __webpack_public_path__ + \"static/1088-cbc973f02b7160536e3d913043f31b31.jpg\";","module.exports = __webpack_public_path__ + \"static/1047-81e27563dcb343ab3a6c21bb15c14bb7.jpg\";","module.exports = __webpack_public_path__ + \"static/4007-e4a073e0df6663b2d5955d5bea6dd3ba.jpg\";","module.exports = __webpack_public_path__ + \"static/3098-9ec118842701647f9ff4b9416dbfa089.jpg\";","module.exports = __webpack_public_path__ + \"static/1026-26a86de99462092d9f355d1864a0eb6a.jpg\";","var map = {\n\t\"./1000.jpg\": \"jII8\",\n\t\"./1001.jpg\": \"Qv/A\",\n\t\"./1002.jpg\": \"p1I2\",\n\t\"./1003.jpg\": \"kYnL\",\n\t\"./1004.jpg\": \"aL2g\",\n\t\"./1005.jpg\": \"fxkU\",\n\t\"./1006.jpg\": \"U9va\",\n\t\"./1007.jpg\": \"xa5I\",\n\t\"./1008.jpg\": \"ctIa\",\n\t\"./1009.jpg\": \"Wmdx\",\n\t\"./1010.jpg\": \"Fp+w\",\n\t\"./1011.jpg\": \"PM1k\",\n\t\"./1012.jpg\": \"qKkD\",\n\t\"./1013.jpg\": \"43lW\",\n\t\"./1014.jpg\": \"7rPu\",\n\t\"./1015.jpg\": \"FMm8\",\n\t\"./1016.jpg\": \"iKq0\",\n\t\"./1017.jpg\": \"ZC14\",\n\t\"./1018.jpg\": \"3NPa\",\n\t\"./1019.jpg\": \"8X5R\",\n\t\"./1020.jpg\": \"9TnG\",\n\t\"./1021.jpg\": \"l/35\",\n\t\"./1022.jpg\": \"8bLS\",\n\t\"./1023.jpg\": \"GQJ0\",\n\t\"./1024.jpg\": \"Vpap\",\n\t\"./1025.jpg\": \"bGUu\",\n\t\"./1026.jpg\": \"0dsC\",\n\t\"./1027.jpg\": \"IAp4\",\n\t\"./1028.jpg\": \"wX49\",\n\t\"./1029.jpg\": \"iZ+k\",\n\t\"./1030.jpg\": \"9tTL\",\n\t\"./1031.jpg\": \"FUke\",\n\t\"./1032.jpg\": \"s4FJ\",\n\t\"./1033.jpg\": \"NpWX\",\n\t\"./1034.jpg\": \"Qsnh\",\n\t\"./1035.jpg\": \"NZbH\",\n\t\"./1036.jpg\": \"Zdh8\",\n\t\"./1037.jpg\": \"GJgO\",\n\t\"./1038.jpg\": \"J5VS\",\n\t\"./1039.jpg\": \"Qj+8\",\n\t\"./1040.jpg\": \"LlbK\",\n\t\"./1041.jpg\": \"jJ1N\",\n\t\"./1042.jpg\": \"MEIe\",\n\t\"./1043.jpg\": \"TKfw\",\n\t\"./1044.jpg\": \"sEA0\",\n\t\"./1045.jpg\": \"UeKG\",\n\t\"./1046.jpg\": \"xONX\",\n\t\"./1047.jpg\": \"0R/+\",\n\t\"./1048.jpg\": \"nfuO\",\n\t\"./1049.jpg\": \"RoVl\",\n\t\"./1050.jpg\": \"AHe1\",\n\t\"./1051.jpg\": \"5gc2\",\n\t\"./1052.jpg\": \"AcjS\",\n\t\"./1053.jpg\": \"PPn4\",\n\t\"./1054.jpg\": \"Aic6\",\n\t\"./1055.jpg\": \"5hoK\",\n\t\"./1056.jpg\": \"WjQt\",\n\t\"./1057.jpg\": \"5SB9\",\n\t\"./1058.jpg\": \"CtDA\",\n\t\"./1059.jpg\": \"z8jd\",\n\t\"./1060.jpg\": \"W5H4\",\n\t\"./1061.jpg\": \"aMil\",\n\t\"./1062.jpg\": \"kl6B\",\n\t\"./1063.jpg\": \"+xny\",\n\t\"./1064.jpg\": \"YuAU\",\n\t\"./1065.jpg\": \"B4EF\",\n\t\"./1066.jpg\": \"Wbzj\",\n\t\"./1067.jpg\": \"KRBM\",\n\t\"./1068.jpg\": \"zxmn\",\n\t\"./1069.jpg\": \"o3CR\",\n\t\"./1070.jpg\": \"NVfi\",\n\t\"./1071.jpg\": \"WoSK\",\n\t\"./1072.jpg\": \"mZHL\",\n\t\"./1073.jpg\": \"28Ug\",\n\t\"./1074.jpg\": \"932B\",\n\t\"./1075.jpg\": \"OolA\",\n\t\"./1076.jpg\": \"BxgO\",\n\t\"./1077.jpg\": \"a7vl\",\n\t\"./1078.jpg\": \"AzdD\",\n\t\"./1079.jpg\": \"ADBZ\",\n\t\"./1080.jpg\": \"VKGI\",\n\t\"./1081.jpg\": \"heNl\",\n\t\"./1082.jpg\": \"31XN\",\n\t\"./1083.jpg\": \"wwH2\",\n\t\"./1084.jpg\": \"Opll\",\n\t\"./1085.jpg\": \"MmmH\",\n\t\"./1086.jpg\": \"9bEX\",\n\t\"./1087.jpg\": \"Fb6K\",\n\t\"./1088.jpg\": \"0PJv\",\n\t\"./1089.jpg\": \"ce0f\",\n\t\"./1090.jpg\": \"VJV0\",\n\t\"./1091.jpg\": \"NsLm\",\n\t\"./1092.jpg\": \"tMJp\",\n\t\"./1093.jpg\": \"T6my\",\n\t\"./1094.jpg\": \"dP7I\",\n\t\"./1095.jpg\": \"s8yh\",\n\t\"./1096.jpg\": \"4DiS\",\n\t\"./1097.jpg\": \"agjM\",\n\t\"./1098.jpg\": \"mc44\",\n\t\"./1099.jpg\": \"8jmw\",\n\t\"./1100.jpg\": \"4RgZ\",\n\t\"./1101.jpg\": \"ud5N\",\n\t\"./1102.jpg\": \"v9sg\",\n\t\"./1103.jpg\": \"L25c\",\n\t\"./1104.jpg\": \"RBRJ\",\n\t\"./1105.jpg\": \"Wd2f\",\n\t\"./1106.jpg\": \"P4+Z\",\n\t\"./1107.jpg\": \"e1PQ\",\n\t\"./1108.jpg\": \"jNc7\",\n\t\"./1109.jpg\": \"P2el\",\n\t\"./1110.jpg\": \"0Ou2\",\n\t\"./1111.jpg\": \"YUOv\",\n\t\"./1112.jpg\": \"8M/O\",\n\t\"./1113.jpg\": \"dgwX\",\n\t\"./1114.jpg\": \"jETt\",\n\t\"./1115.jpg\": \"9FWj\",\n\t\"./1116.jpg\": \"3xoo\",\n\t\"./1117.jpg\": \"JjMl\",\n\t\"./1118.jpg\": \"1PU2\",\n\t\"./1119.jpg\": \"5kFX\",\n\t\"./1120.jpg\": \"nbWR\",\n\t\"./1121.jpg\": \"Glfx\",\n\t\"./1122.jpg\": \"iEwU\",\n\t\"./1123.jpg\": \"Khvi\",\n\t\"./1124.jpg\": \"heDb\",\n\t\"./1125.jpg\": \"iILc\",\n\t\"./1126.jpg\": \"hw+Z\",\n\t\"./1127.jpg\": \"wG5I\",\n\t\"./1128.jpg\": \"jD2D\",\n\t\"./1129.jpg\": \"/xog\",\n\t\"./1130.jpg\": \"4RI1\",\n\t\"./1131.jpg\": \"b5bp\",\n\t\"./1132.jpg\": \"6Qe0\",\n\t\"./1133.jpg\": \"zgkc\",\n\t\"./1134.jpg\": \"rTeG\",\n\t\"./1135.jpg\": \"NOTD\",\n\t\"./1136.jpg\": \"he3I\",\n\t\"./1137.jpg\": \"6nKo\",\n\t\"./1138.jpg\": \"ciGU\",\n\t\"./1139.jpg\": \"rdpn\",\n\t\"./1140.jpg\": \"9/zC\",\n\t\"./1141.jpg\": \"AWge\",\n\t\"./1142.jpg\": \"6izq\",\n\t\"./1143.jpg\": \"zGIQ\",\n\t\"./1144.jpg\": \"Ylp+\",\n\t\"./1145.jpg\": \"MkQI\",\n\t\"./1146.jpg\": \"taJW\",\n\t\"./1147.jpg\": \"FIsx\",\n\t\"./1148.jpg\": \"jj8m\",\n\t\"./1149.jpg\": \"JneB\",\n\t\"./1150.jpg\": \"2w9j\",\n\t\"./1151.jpg\": \"xvhe\",\n\t\"./1152.jpg\": \"LrQs\",\n\t\"./1153.jpg\": \"Y0C/\",\n\t\"./1154.jpg\": \"Ndzo\",\n\t\"./1155.jpg\": \"yl1U\",\n\t\"./1156.jpg\": \"2a0Q\",\n\t\"./1157.jpg\": \"zjUY\",\n\t\"./1158.jpg\": \"VM68\",\n\t\"./1159.jpg\": \"eLSb\",\n\t\"./1160.jpg\": \"NswR\",\n\t\"./1161.jpg\": \"v+6l\",\n\t\"./1162.jpg\": \"Cw+i\",\n\t\"./1163.jpg\": \"RVOn\",\n\t\"./1164.jpg\": \"NskN\",\n\t\"./1165.jpg\": \"BkIK\",\n\t\"./2000.jpg\": \"4GsB\",\n\t\"./2001.jpg\": \"XahP\",\n\t\"./2002.jpg\": \"48rD\",\n\t\"./2003.jpg\": \"sTP1\",\n\t\"./2004.jpg\": \"CFAJ\",\n\t\"./2005.jpg\": \"dS8P\",\n\t\"./2006.jpg\": \"JZAJ\",\n\t\"./2007.jpg\": \"m5no\",\n\t\"./2008.jpg\": \"E/Gz\",\n\t\"./2009.jpg\": \"YoTB\",\n\t\"./2010.jpg\": \"O26Z\",\n\t\"./2011.jpg\": \"iB3Y\",\n\t\"./2012.jpg\": \"MFcL\",\n\t\"./2013.jpg\": \"+L8G\",\n\t\"./2014.jpg\": \"GhrV\",\n\t\"./2015.jpg\": \"EOLO\",\n\t\"./2016.jpg\": \"g3rm\",\n\t\"./2017.jpg\": \"gi6r\",\n\t\"./2018.jpg\": \"Y948\",\n\t\"./2019.jpg\": \"21TF\",\n\t\"./2020.jpg\": \"dX7e\",\n\t\"./2021.jpg\": \"TK0K\",\n\t\"./2022.jpg\": \"XPy+\",\n\t\"./2023.jpg\": \"cP11\",\n\t\"./2024.jpg\": \"JfWV\",\n\t\"./2025.jpg\": \"CQ+8\",\n\t\"./2026.jpg\": \"Ebhk\",\n\t\"./2027.jpg\": \"M7xl\",\n\t\"./2028.jpg\": \"84AA\",\n\t\"./2029.jpg\": \"GPva\",\n\t\"./2030.jpg\": \"dL+m\",\n\t\"./2031.jpg\": \"U5F+\",\n\t\"./2032.jpg\": \"Vk33\",\n\t\"./2033.jpg\": \"9frp\",\n\t\"./2034.jpg\": \"lQ14\",\n\t\"./2035.jpg\": \"hG+e\",\n\t\"./2036.jpg\": \"fLR1\",\n\t\"./2037.jpg\": \"9uz3\",\n\t\"./2038.jpg\": \"V+jX\",\n\t\"./2039.jpg\": \"gQ45\",\n\t\"./2040.jpg\": \"lsoU\",\n\t\"./2041.jpg\": \"SNuJ\",\n\t\"./2042.jpg\": \"WlMz\",\n\t\"./2043.jpg\": \"yXsK\",\n\t\"./2044.jpg\": \"5oyb\",\n\t\"./2045.jpg\": \"tfnm\",\n\t\"./2046.jpg\": \"rE3p\",\n\t\"./2047.jpg\": \"RGqr\",\n\t\"./2048.jpg\": \"0Hqx\",\n\t\"./2049.jpg\": \"9G8X\",\n\t\"./2050.jpg\": \"BPQE\",\n\t\"./2051.jpg\": \"dwZg\",\n\t\"./2052.jpg\": \"011i\",\n\t\"./2053.jpg\": \"g6lQ\",\n\t\"./2054.jpg\": \"Lu+3\",\n\t\"./2055.jpg\": \"u5UG\",\n\t\"./2056.jpg\": \"pTd8\",\n\t\"./2057.jpg\": \"mo1k\",\n\t\"./2058.jpg\": \"B06u\",\n\t\"./2059.jpg\": \"WUmz\",\n\t\"./2060.jpg\": \"SUZs\",\n\t\"./2061.jpg\": \"LGEN\",\n\t\"./2062.jpg\": \"pDsC\",\n\t\"./2063.jpg\": \"OtBC\",\n\t\"./2064.jpg\": \"Q84A\",\n\t\"./2065.jpg\": \"7a9T\",\n\t\"./2066.jpg\": \"SaAr\",\n\t\"./2067.jpg\": \"bhNi\",\n\t\"./2068.jpg\": \"cbQT\",\n\t\"./2069.jpg\": \"6dJ9\",\n\t\"./2070.jpg\": \"FN7y\",\n\t\"./2071.jpg\": \"qOy0\",\n\t\"./2072.jpg\": \"qPaE\",\n\t\"./2073.jpg\": \"3q/S\",\n\t\"./2074.jpg\": \"87Rs\",\n\t\"./2075.jpg\": \"xuAq\",\n\t\"./2076.jpg\": \"SH9V\",\n\t\"./2077.jpg\": \"xfgg\",\n\t\"./2078.jpg\": \"WYDb\",\n\t\"./2079.jpg\": \"4oEJ\",\n\t\"./2080.jpg\": \"2kK7\",\n\t\"./2081.jpg\": \"a7Ea\",\n\t\"./2082.jpg\": \"7ahu\",\n\t\"./2083.jpg\": \"ROjB\",\n\t\"./2084.jpg\": \"/xKF\",\n\t\"./2085.jpg\": \"w4yb\",\n\t\"./2086.jpg\": \"YLP9\",\n\t\"./2087.jpg\": \"21tC\",\n\t\"./2088.jpg\": \"eoSF\",\n\t\"./2089.jpg\": \"FZPh\",\n\t\"./2090.jpg\": \"cKd3\",\n\t\"./2091.jpg\": \"EfhC\",\n\t\"./2092.jpg\": \"X3IW\",\n\t\"./2093.jpg\": \"bR8T\",\n\t\"./2094.jpg\": \"6vW5\",\n\t\"./2095.jpg\": \"T/26\",\n\t\"./2096.jpg\": \"Qj1a\",\n\t\"./2097.jpg\": \"GZk8\",\n\t\"./2098.jpg\": \"ju2s\",\n\t\"./2099.jpg\": \"nXxW\",\n\t\"./2100.jpg\": \"X/eJ\",\n\t\"./2101.jpg\": \"Clh9\",\n\t\"./2102.jpg\": \"cr8m\",\n\t\"./2103.jpg\": \"km/r\",\n\t\"./2104.jpg\": \"bNbD\",\n\t\"./2105.jpg\": \"fzyv\",\n\t\"./2106.jpg\": \"C/0D\",\n\t\"./2107.jpg\": \"MKeP\",\n\t\"./2108.jpg\": \"Wr0T\",\n\t\"./2109.jpg\": \"9Kat\",\n\t\"./3000.jpg\": \"oD7F\",\n\t\"./3001.jpg\": \"T9Ma\",\n\t\"./3002.jpg\": \"a8MH\",\n\t\"./3003.jpg\": \"rH3r\",\n\t\"./3004.jpg\": \"Jw71\",\n\t\"./3005.jpg\": \"zofp\",\n\t\"./3006.jpg\": \"HfAM\",\n\t\"./3007.jpg\": \"bmdk\",\n\t\"./3008.jpg\": \"WQrS\",\n\t\"./3009.jpg\": \"8wQO\",\n\t\"./3010.jpg\": \"+ngP\",\n\t\"./3011.jpg\": \"DHix\",\n\t\"./3012.jpg\": \"HRhT\",\n\t\"./3013.jpg\": \"zK0X\",\n\t\"./3014.jpg\": \"n3hf\",\n\t\"./3015.jpg\": \"Kz+D\",\n\t\"./3016.jpg\": \"pEe2\",\n\t\"./3017.jpg\": \"XL/I\",\n\t\"./3018.jpg\": \"xVjt\",\n\t\"./3019.jpg\": \"3Yoq\",\n\t\"./3020.jpg\": \"RQ+y\",\n\t\"./3021.jpg\": \"hoyV\",\n\t\"./3022.jpg\": \"X0Y+\",\n\t\"./3023.jpg\": \"6KLy\",\n\t\"./3024.jpg\": \"Q6Q9\",\n\t\"./3025.jpg\": \"yCSK\",\n\t\"./3026.jpg\": \"7nsj\",\n\t\"./3027.jpg\": \"DWbX\",\n\t\"./3028.jpg\": \"nMNX\",\n\t\"./3029.jpg\": \"D2LS\",\n\t\"./3030.jpg\": \"WCcg\",\n\t\"./3031.jpg\": \"toio\",\n\t\"./3032.jpg\": \"JTyK\",\n\t\"./3033.jpg\": \"XpUS\",\n\t\"./3034.jpg\": \"QHnF\",\n\t\"./3035.jpg\": \"NWMG\",\n\t\"./3036.jpg\": \"4ueU\",\n\t\"./3037.jpg\": \"5OAS\",\n\t\"./3038.jpg\": \"/N45\",\n\t\"./3039.jpg\": \"j3YL\",\n\t\"./3040.jpg\": \"A7EY\",\n\t\"./3041.jpg\": \"Mlw9\",\n\t\"./3042.jpg\": \"ozWn\",\n\t\"./3043.jpg\": \"M5w2\",\n\t\"./3044.jpg\": \"wmKp\",\n\t\"./3045.jpg\": \"EEu4\",\n\t\"./3046.jpg\": \"BmHt\",\n\t\"./3047.jpg\": \"kwCI\",\n\t\"./3048.jpg\": \"K7Xa\",\n\t\"./3049.jpg\": \"4Vq5\",\n\t\"./3050.jpg\": \"NC9Z\",\n\t\"./3051.jpg\": \"9zVb\",\n\t\"./3052.jpg\": \"QL0l\",\n\t\"./3053.jpg\": \"GNub\",\n\t\"./3054.jpg\": \"DyzR\",\n\t\"./3055.jpg\": \"AAvt\",\n\t\"./3056.jpg\": \"EU6N\",\n\t\"./3057.jpg\": \"EnD2\",\n\t\"./3058.jpg\": \"0txj\",\n\t\"./3059.jpg\": \"YGzK\",\n\t\"./3060.jpg\": \"z5Id\",\n\t\"./3061.jpg\": \"ROm/\",\n\t\"./3062.jpg\": \"sZhn\",\n\t\"./3063.jpg\": \"cxrW\",\n\t\"./3064.jpg\": \"4bWd\",\n\t\"./3065.jpg\": \"iSEm\",\n\t\"./3066.jpg\": \"iTDl\",\n\t\"./3067.jpg\": \"fI9H\",\n\t\"./3068.jpg\": \"XYfC\",\n\t\"./3069.jpg\": \"ISoD\",\n\t\"./3070.jpg\": \"DHJV\",\n\t\"./3071.jpg\": \"AFmi\",\n\t\"./3072.jpg\": \"TBYr\",\n\t\"./3073.jpg\": \"wzXp\",\n\t\"./3074.jpg\": \"bvah\",\n\t\"./3075.jpg\": \"fJR+\",\n\t\"./3076.jpg\": \"1WSy\",\n\t\"./3077.jpg\": \"KsOj\",\n\t\"./3078.jpg\": \"phII\",\n\t\"./3079.jpg\": \"ZaCl\",\n\t\"./3080.jpg\": \"S3Da\",\n\t\"./3081.jpg\": \"apGO\",\n\t\"./3082.jpg\": \"HUTO\",\n\t\"./3083.jpg\": \"39AC\",\n\t\"./3084.jpg\": \"Xm7A\",\n\t\"./3085.jpg\": \"XVk+\",\n\t\"./3086.jpg\": \"6mFn\",\n\t\"./3087.jpg\": \"PWUJ\",\n\t\"./3088.jpg\": \"S78b\",\n\t\"./3089.jpg\": \"ZfYT\",\n\t\"./3090.jpg\": \"MO5s\",\n\t\"./3091.jpg\": \"smIR\",\n\t\"./3092.jpg\": \"xvSL\",\n\t\"./3093.jpg\": \"kC2r\",\n\t\"./3094.jpg\": \"N3/Z\",\n\t\"./3095.jpg\": \"zUpW\",\n\t\"./3096.jpg\": \"DILH\",\n\t\"./3097.jpg\": \"7ptw\",\n\t\"./3098.jpg\": \"0VIG\",\n\t\"./3099.jpg\": \"N+EW\",\n\t\"./3100.jpg\": \"QkTz\",\n\t\"./3101.jpg\": \"XDfj\",\n\t\"./3102.jpg\": \"fzU0\",\n\t\"./3103.jpg\": \"yLsg\",\n\t\"./3104.jpg\": \"gUvo\",\n\t\"./3105.jpg\": \"XQQE\",\n\t\"./3106.jpg\": \"bPdP\",\n\t\"./4000.jpg\": \"YcZn\",\n\t\"./4001.jpg\": \"si6Z\",\n\t\"./4002.jpg\": \"Eu7i\",\n\t\"./4003.jpg\": \"xfd0\",\n\t\"./4004.jpg\": \"zLUP\",\n\t\"./4005.jpg\": \"yHJh\",\n\t\"./4006.jpg\": \"P6o/\",\n\t\"./4007.jpg\": \"0RNu\",\n\t\"./4008.jpg\": \"1Kmc\",\n\t\"./4009.jpg\": \"BkLs\",\n\t\"./4010.jpg\": \"rVLm\",\n\t\"./4011.jpg\": \"7W5p\",\n\t\"./4012.jpg\": \"P7wt\",\n\t\"./4013.jpg\": \"zFEp\",\n\t\"./4014.jpg\": \"T44J\",\n\t\"./4015.jpg\": \"dlv2\",\n\t\"./4016.jpg\": \"EOfY\",\n\t\"./4017.jpg\": \"rlFt\",\n\t\"./4018.jpg\": \"I661\",\n\t\"./4019.jpg\": \"SXgj\",\n\t\"./4020.jpg\": \"Pl4y\",\n\t\"./4021.jpg\": \"B4dg\",\n\t\"./4022.jpg\": \"yBo9\",\n\t\"./4023.jpg\": \"aD9x\",\n\t\"./4024.jpg\": \"nK7e\",\n\t\"./4025.jpg\": \"axPn\",\n\t\"./4026.jpg\": \"enfH\",\n\t\"./4027.jpg\": \"QBsK\",\n\t\"./4028.jpg\": \"Zyqy\",\n\t\"./4029.jpg\": \"wT4Q\",\n\t\"./4030.jpg\": \"qG98\",\n\t\"./4031.jpg\": \"sZ00\",\n\t\"./4032.jpg\": \"eA4k\",\n\t\"./4033.jpg\": \"7j1q\",\n\t\"./4034.jpg\": \"BahN\",\n\t\"./4035.jpg\": \"6zJ7\",\n\t\"./4036.jpg\": \"V4GL\",\n\t\"./4037.jpg\": \"A0TU\",\n\t\"./4038.jpg\": \"EvIL\",\n\t\"./4039.jpg\": \"L0yk\",\n\t\"./4040.jpg\": \"NZKg\",\n\t\"./4041.jpg\": \"X0Iu\",\n\t\"./4042.jpg\": \"1hrs\",\n\t\"./4043.jpg\": \"v+XN\",\n\t\"./4044.jpg\": \"67QE\",\n\t\"./4045.jpg\": \"J0AL\",\n\t\"./4046.jpg\": \"b9k7\",\n\t\"./4047.jpg\": \"kUMr\",\n\t\"./4048.jpg\": \"0EoD\",\n\t\"./4049.jpg\": \"4em2\",\n\t\"./4050.jpg\": \"LrXF\",\n\t\"./4051.jpg\": \"XJjN\",\n\t\"./4052.jpg\": \"smKP\",\n\t\"./4053.jpg\": \"o8Nw\",\n\t\"./4054.jpg\": \"7SvK\",\n\t\"./4055.jpg\": \"6a6q\",\n\t\"./4056.jpg\": \"PRLM\",\n\t\"./4057.jpg\": \"7Cp+\",\n\t\"./4058.jpg\": \"SeIg\",\n\t\"./4059.jpg\": \"K9dh\",\n\t\"./4060.jpg\": \"o5Ij\"\n};\n\n\nfunction webpackContext(req) {\n\tvar id = webpackContextResolve(req);\n\treturn __webpack_require__(id);\n}\nfunction webpackContextResolve(req) {\n\tif(!__webpack_require__.o(map, req)) {\n\t\tvar e = new Error(\"Cannot find module '\" + req + \"'\");\n\t\te.code = 'MODULE_NOT_FOUND';\n\t\tthrow e;\n\t}\n\treturn map[req];\n}\nwebpackContext.keys = function webpackContextKeys() {\n\treturn Object.keys(map);\n};\nwebpackContext.resolve = webpackContextResolve;\nmodule.exports = webpackContext;\nwebpackContext.id = \"0sVJ\";","module.exports = __webpack_public_path__ + \"static/3058-3a5476adcde436df8a09a5480c534b03.jpg\";","module.exports = __webpack_public_path__ + \"static/4008-fb181acd86c7d77ca091c8b8387f350f.jpg\";","module.exports = __webpack_public_path__ + \"static/1118-ff980d280a22c050dd0284e98e4bbdd9.jpg\";","var internalObjectKeys = require('../internals/object-keys-internal');\nvar enumBugKeys = require('../internals/enum-bug-keys');\n\n// `Object.keys` method\n// https://tc39.github.io/ecma262/#sec-object.keys\nmodule.exports = Object.keys || function keys(O) {\n return internalObjectKeys(O, enumBugKeys);\n};\n","module.exports = __webpack_public_path__ + \"static/3076-5b7261e4b4c55b1fec89774dfef8b8c8.jpg\";","module.exports = __webpack_public_path__ + \"static/4042-88fe9f819b5e5c92c65f4f818d8a485d.jpg\";","module.exports = __webpack_public_path__ + \"static/2019-8293941758cd25428a507918ed56a934.jpg\";","module.exports = __webpack_public_path__ + \"static/2087-80adb2f721ffafda1fd7e1f6fed01295.jpg\";","module.exports = __webpack_public_path__ + \"static/1073-517ae1d64c458f7f2ebd33da8987b166.jpg\";","module.exports = __webpack_public_path__ + \"static/1156-1fac3f4664b8167dc4d0bc629ad30fda.jpg\";","module.exports = __webpack_public_path__ + \"static/2080-69f8bb308aa35555b337523db093266e.jpg\";","module.exports = __webpack_public_path__ + \"static/1150-7b1f1d6c8f31a5937eae1f4588073eef.jpg\";","module.exports = __webpack_public_path__ + \"static/1082-51f385d84211d07ea2332d47fbcca00f.jpg\";","module.exports = __webpack_public_path__ + \"static/3083-1824235393502210e07be2bb36c8c615.jpg\";","module.exports = __webpack_public_path__ + \"static/1018-6f590d0d251c5fb823ba03e5cd04406a.jpg\";","module.exports = __webpack_public_path__ + \"static/3019-fe3da18ba1c986955f6441d9b6366cfe.jpg\";","module.exports = __webpack_public_path__ + \"static/2073-4839a660957ae51af63d8862dcda3cc9.jpg\";","module.exports = __webpack_public_path__ + \"static/1116-397174fb0ff8b85ebf83b918c873df52.jpg\";","module.exports = __webpack_public_path__ + \"static/1013-9ea8e20d5e873697f6ffb067280e50e3.jpg\";","var classof = require('../internals/classof-raw');\n\n// `IsArray` abstract operation\n// https://tc39.github.io/ecma262/#sec-isarray\nmodule.exports = Array.isArray || function isArray(arg) {\n return classof(arg) == 'Array';\n};\n","module.exports = __webpack_public_path__ + \"static/2002-2d09d03fc87a698768d8384538427459.jpg\";","module.exports = __webpack_public_path__ + \"static/1096-db3ec13a734b66c90cd3c8f0cc778fbe.jpg\";","module.exports = __webpack_public_path__ + \"static/2000-b194bac58fab40a690f158ae53b97b22.jpg\";","module.exports = __webpack_public_path__ + \"static/1130-2dbfc24f0d6fb5834842eb89f284e910.jpg\";","module.exports = __webpack_public_path__ + \"static/1100-c790f8751cb1695b91903ffb9ab641f0.jpg\";","module.exports = __webpack_public_path__ + \"static/3049-091c04012ccb56f5786416dbf63ee2db.jpg\";","module.exports = __webpack_public_path__ + \"static/3064-1efccaf7306c05a2f374498dfc64b7cf.jpg\";","module.exports = __webpack_public_path__ + \"static/4049-93fa73f1ad987e0da0926d26e219a6c8.jpg\";","module.exports = __webpack_public_path__ + \"static/2079-4a1ec240175a3ab63a09b260fbbb145b.jpg\";","module.exports = __webpack_public_path__ + \"static/3036-91f45ad0004741a9ef3a60b8de86de19.jpg\";","module.exports = __webpack_public_path__ + \"static/3037-216286d7840c0163a5b28c3ff09f33c3.jpg\";","module.exports = __webpack_public_path__ + \"static/1057-ebe45c2ca1d7f4318529f428dbcf9da2.jpg\";","module.exports = __webpack_public_path__ + \"static/1051-bbf040c15a5cbfdb6816c49ec21d8d37.jpg\";","module.exports = __webpack_public_path__ + \"static/1055-678c3ec2daa660e5f7f6b922a737cb23.jpg\";","module.exports = __webpack_public_path__ + \"static/1119-5dff493bee603a0c58b0580c68b2a479.jpg\";","module.exports = __webpack_public_path__ + \"static/2044-7af66c26c1007ffdabfebd4fa6cea9b6.jpg\";","module.exports = __webpack_public_path__ + \"static/4044-083bc6ae73a220c7364f3577129b378a.jpg\";","module.exports = __webpack_public_path__ + \"static/3023-3af2013c356116706e6cc5ee02889871.jpg\";","module.exports = __webpack_public_path__ + \"static/1132-a4b68075581646fb2793f6d77b25c06f.jpg\";","module.exports = __webpack_public_path__ + \"static/4055-6db89962d6e16aadd91f7782ded79dfc.jpg\";","module.exports = __webpack_public_path__ + \"static/2069-4cd38e26c16f762cb9e419cd66dc9844.jpg\";","module.exports = __webpack_public_path__ + \"static/1142-58c6dfef18d33407550c79ee070b3a34.jpg\";","module.exports = \"\"","module.exports = __webpack_public_path__ + \"static/3086-d423afc6db09202bf24bedcff33b7a54.jpg\";","module.exports = __webpack_public_path__ + \"static/1137-6c99dc96eaac47dc5d7e45f214076596.jpg\";","module.exports = __webpack_public_path__ + \"static/2094-b9b31c0b0a8d36bc0fc45f50b96effd0.jpg\";","module.exports = __webpack_public_path__ + \"static/4035-543f4469abf8ea94ed24347fee6620d7.jpg\";","module.exports = __webpack_public_path__ + \"static/4057-c83f9952e8eb1a4b7a90a3ec973da5fd.jpg\";","module.exports = __webpack_public_path__ + \"static/4054-3e6d680ccb1077ecef16f6db7f98d566.jpg\";","module.exports = __webpack_public_path__ + \"static/4011-d1543d4e3c624ed8c97355126f306d2e.jpg\";","module.exports = __webpack_public_path__ + \"static/2065-d9f60b6d35e720477dcecff292948c38.jpg\";","module.exports = __webpack_public_path__ + \"static/2082-d9cd02d6e6bdb313f5efda815599c4b7.jpg\";","module.exports = __webpack_public_path__ + \"static/4033-7f27cdd8ad5e96749d636fd59a58aa16.jpg\";","module.exports = __webpack_public_path__ + \"static/3026-657a534b0dbd621383712f320a860503.jpg\";","module.exports = __webpack_public_path__ + \"static/3097-ef42d2971ef88aee3b7245befa330ee0.jpg\";","module.exports = __webpack_public_path__ + \"static/1014-151b7152f4cfefc6df4bf9d5cb59f102.jpg\";","module.exports = __webpack_public_path__ + \"static/2028-157ea8b3f2af55855f124512469d578b.jpg\";","var isObject = require('../internals/is-object');\nvar isArray = require('../internals/is-array');\nvar wellKnownSymbol = require('../internals/well-known-symbol');\n\nvar SPECIES = wellKnownSymbol('species');\n\n// `ArraySpeciesCreate` abstract operation\n// https://tc39.github.io/ecma262/#sec-arrayspeciescreate\nmodule.exports = function (originalArray, length) {\n var C;\n if (isArray(originalArray)) {\n C = originalArray.constructor;\n // cross-realm fallback\n if (typeof C == 'function' && (C === Array || isArray(C.prototype))) C = undefined;\n else if (isObject(C)) {\n C = C[SPECIES];\n if (C === null) C = undefined;\n }\n } return new (C === undefined ? Array : C)(length === 0 ? 0 : length);\n};\n","module.exports = __webpack_public_path__ + \"static/2074-bc786cb15af4024ab664bae3ea81d2fa.jpg\";","module.exports = __webpack_public_path__ + \"static/1112-745512a1c14b56e247a667f1c1919752.jpg\";","module.exports = __webpack_public_path__ + \"static/1019-75d0cef022be2353927b538dbe5fbbe0.jpg\";","module.exports = __webpack_public_path__ + \"static/1022-a4e619cfdc4c19ef030cb39a1b555426.jpg\";","module.exports = __webpack_public_path__ + \"static/1099-8f87b5da326de3ce0713256d2401929a.jpg\";","module.exports = __webpack_public_path__ + \"static/3009-dc84bfc56f94aa27f6cd9f341e1f1979.jpg\";","module.exports = __webpack_public_path__ + \"static/1140-c09963e56eeab3367318ab2362ca3cbf.jpg\";","module.exports = __webpack_public_path__ + \"static/1074-a15a1074d0d928d35d6e33c27f345e7f.jpg\";","module.exports = __webpack_public_path__ + \"static/1115-234cb28f6f14e71122ff68e4c7fcdf05.jpg\";","module.exports = __webpack_public_path__ + \"static/2049-8f4ce32289c636a3a81f719a3a490224.jpg\";","module.exports = __webpack_public_path__ + \"static/2109-08b2e9a47d3e33ac713ceed172f947f0.jpg\";","module.exports = __webpack_public_path__ + \"static/1020-7e11ae8f958300ea997bf67e2943cc17.jpg\";","module.exports = __webpack_public_path__ + \"static/1086-8cad32604b42e996ae0f70ce2a001095.jpg\";","module.exports = __webpack_public_path__ + \"static/2033-174d2f317fb35de6529c0ff5bb6ac896.jpg\";","module.exports = __webpack_public_path__ + \"static/1030-7a38c23d35bb5ac68348610c2c830599.jpg\";","module.exports = __webpack_public_path__ + \"static/2037-fc624d1041c63922e7cb9172db6347c1.jpg\";","module.exports = __webpack_public_path__ + \"static/3051-73ccde671305c241b539a27872c63782.jpg\";","module.exports = __webpack_public_path__ + \"static/4037-cd14f655f863bc7e7cad2568f38f8030.jpg\";","module.exports = __webpack_public_path__ + \"static/3040-b4c04660e8900c415de441eb7e9148ef.jpg\";","'use strict';\nvar isArray = require('../internals/is-array');\nvar toLength = require('../internals/to-length');\nvar bind = require('../internals/function-bind-context');\n\n// `FlattenIntoArray` abstract operation\n// https://tc39.github.io/proposal-flatMap/#sec-FlattenIntoArray\nvar flattenIntoArray = function (target, original, source, sourceLen, start, depth, mapper, thisArg) {\n var targetIndex = start;\n var sourceIndex = 0;\n var mapFn = mapper ? bind(mapper, thisArg, 3) : false;\n var element;\n\n while (sourceIndex < sourceLen) {\n if (sourceIndex in source) {\n element = mapFn ? mapFn(source[sourceIndex], sourceIndex, original) : source[sourceIndex];\n\n if (depth > 0 && isArray(element)) {\n targetIndex = flattenIntoArray(target, original, element, toLength(element.length), targetIndex, depth - 1) - 1;\n } else {\n if (targetIndex >= 0x1FFFFFFFFFFFFF) throw TypeError('Exceed the acceptable array length');\n target[targetIndex] = element;\n }\n\n targetIndex++;\n }\n sourceIndex++;\n }\n return targetIndex;\n};\n\nmodule.exports = flattenIntoArray;\n","module.exports = __webpack_public_path__ + \"static/3055-037ab668651712e198d17a5c96a3721b.jpg\";","module.exports = __webpack_public_path__ + \"static/1079-a1aa08351438d97097d85c8d39e0e3ce.jpg\";","module.exports = __webpack_public_path__ + \"static/3071-a198ce8a368f16ddf3a85e3ac27af687.jpg\";","module.exports = __webpack_public_path__ + \"static/1050-32b546d5e45682e36804a1b3af95e911.jpg\";","module.exports = __webpack_public_path__ + \"static/1141-b267960a51752c413e85ac9c9411e332.jpg\";","module.exports = __webpack_public_path__ + \"static/1052-fa76bcc92e9f5f6a2163bff95908c76c.jpg\";","module.exports = __webpack_public_path__ + \"static/delta-0fd67101c52d82debbf955642598845e.svg\";","module.exports = __webpack_public_path__ + \"static/1054-60985f075b0e5c38995e0d033695b0e3.jpg\";","module.exports = __webpack_public_path__ + \"static/1078-0b55961f9604a72e4dd874a4959f32ff.jpg\";","module.exports = __webpack_public_path__ + \"static/2058-f2fe21e46cac87126ce1324c7a7c2521.jpg\";","module.exports = __webpack_public_path__ + \"static/1065-c601a84fa27ed063bbb3cb6ba1648b77.jpg\";","module.exports = __webpack_public_path__ + \"static/4021-e0defefba68af1dbbf521404f00b5747.jpg\";","module.exports = __webpack_public_path__ + \"static/2050-a033d34e73342c1c2f71b3934012dc73.jpg\";","module.exports = __webpack_public_path__ + \"static/4034-de4d7cf6c41def0b08a87a933601c661.jpg\";","module.exports = __webpack_public_path__ + \"static/1165-3bea4e0a5d7dd5a48e826bbc2764c647.jpg\";","module.exports = __webpack_public_path__ + \"static/4009-5972db30d3188f46ee591b329459a453.jpg\";","module.exports = __webpack_public_path__ + \"static/3046-363ceebb2c7b81f4aaeccdf7ee2701c6.jpg\";","module.exports = __webpack_public_path__ + \"static/1076-78cf21659ebebcd5243d4e5f2ae24091.jpg\";","module.exports = __webpack_public_path__ + \"static/2106-eadc507a0f1706254cb4f38691844ab5.jpg\";","module.exports = __webpack_public_path__ + \"static/2004-375bbc15ab84c2a2252886bc57ac61e9.jpg\";","module.exports = __webpack_public_path__ + \"static/2025-d11824a6216916e543278c4cbcb725cc.jpg\";","module.exports = __webpack_public_path__ + \"static/2101-57238a338aef472805b887552a761bc7.jpg\";","module.exports = __webpack_public_path__ + \"static/1058-e9167882dce325914bb9bfffacecd0d5.jpg\";","module.exports = __webpack_public_path__ + \"static/1162-303d23f69db3584e1cad713f67da957c.jpg\";","module.exports = __webpack_public_path__ + \"static/bay-e473c222708f646ea32088e6b4297401.svg\";","module.exports = __webpack_public_path__ + \"static/3029-63fea29a4f380be07fd152ba4b800c46.jpg\";","module.exports = __webpack_public_path__ + \"static/3070-97b00b39f9e59795ba1c920310008276.jpg\";","module.exports = __webpack_public_path__ + \"static/3011-98990b5126e01056dd15e264a6d218d8.jpg\";","module.exports = __webpack_public_path__ + \"static/3096-8c639f836b9e07a1eca1a2ad8d487d86.jpg\";","module.exports = __webpack_public_path__ + \"static/3027-9f0c5d1244beb064fee20b2331917725.jpg\";","module.exports = __webpack_public_path__ + \"static/3054-298c8fc010b9979ca57dcabb019bd28e.jpg\";","module.exports = __webpack_public_path__ + \"static/2008-e9b3ae367f4af5604848f96dcb19ff36.jpg\";","module.exports = __webpack_public_path__ + \"static/3045-389c71c8eba35ed98ae4a3cd292a8463.jpg\";","module.exports = __webpack_public_path__ + \"static/2015-fbe429eff8a9f2f5415fcbd2d262c18f.jpg\";","module.exports = __webpack_public_path__ + \"static/4016-4d38ce2345088f16053002884263e697.jpg\";","module.exports = __webpack_public_path__ + \"static/3056-9c21d42ca7ede2098e6b92cdbbca6296.jpg\";","module.exports = __webpack_public_path__ + \"static/2026-4755289fcaea571a46b289bdd92c4694.jpg\";","module.exports = __webpack_public_path__ + \"static/2091-05eece95ff55d0d4f83d3273320af9ba.jpg\";","module.exports = __webpack_public_path__ + \"static/3057-c39fd6485c3a6c3609504527ae9bfa8f.jpg\";","module.exports = __webpack_public_path__ + \"static/4002-5891d57757d12c7819c0da07e307d5ae.jpg\";","module.exports = __webpack_public_path__ + \"static/4038-ded6e08791f83d014bd6b0cf3fe7c869.jpg\";","module.exports = __webpack_public_path__ + \"static/1147-195217adfef23cc22ef08a05f531a707.jpg\";","module.exports = __webpack_public_path__ + \"static/1015-10133c7cf4dd2d02a854d2c367bee1c9.jpg\";","module.exports = __webpack_public_path__ + \"static/2070-7736a5fe2f1f72c707e00dd5661d7637.jpg\";","module.exports = __webpack_public_path__ + \"static/1031-b507396144f88e4e574bb68541e34a70.jpg\";","module.exports = __webpack_public_path__ + \"static/2089-ac221d90aed0e73cddec145a50b16496.jpg\";","module.exports = __webpack_public_path__ + \"static/1087-b414f07d57fa18b9b2ec91944321482a.jpg\";","module.exports = __webpack_public_path__ + \"static/1010-785d2100edbf8b7d301fbfb69e582944.jpg\";","module.exports = __webpack_public_path__ + \"static/1037-9c6a2662bed28186eeaaecf8fae598a7.jpg\";","module.exports = __webpack_public_path__ + \"static/3053-063c84b1ec83b0628632bf3be6141c9c.jpg\";","module.exports = __webpack_public_path__ + \"static/2029-208839c012663efcdfe26fe7046f5544.jpg\";","module.exports = __webpack_public_path__ + \"static/1023-57d32fce3893db0f07c9715c1b1bce81.jpg\";","import { Text } from 'rebass'\r\n\r\nimport styled, { themeGet } from 'util/style'\r\n\r\nconst HelpText = styled(Text)`\r\n line-height: 1.4;\r\n color: ${themeGet('colors.grey.700')};\r\n`\r\n\r\nexport default HelpText\r\n","module.exports = __webpack_public_path__ + \"static/2097-7595a595490e44d192bda38f780685d4.jpg\";","module.exports = __webpack_public_path__ + \"static/2014-161e7239c19b7fbb0b4a58720aced88a.jpg\";","module.exports = __webpack_public_path__ + \"static/1121-a86f24fee040e06617bba72908bf0972.jpg\";","module.exports = __webpack_public_path__ + \"static/3012-63224964cc05c42607ba83507c95b70c.jpg\";","module.exports = __webpack_public_path__ + \"static/3082-e222553cdb5cb036a39ccea903e561d6.jpg\";","module.exports = __webpack_public_path__ + \"static/3006-d5c932dff63cccff3cb86297449d2054.jpg\";","module.exports = __webpack_public_path__ + \"static/4018-482caaf9cda2e0b0b983e24abd763531.jpg\";","module.exports = __webpack_public_path__ + \"static/1027-21976974bbef61ce5f8e7513d82584ea.jpg\";","module.exports = __webpack_public_path__ + \"static/3069-4ce1d5ca943e2f77d68ccc33829fea40.jpg\";","module.exports = __webpack_public_path__ + \"static/4045-264d95d945c6f52b35d440bf8be0a2c3.jpg\";","module.exports = __webpack_public_path__ + \"static/1038-06f20b53ed076aae7c0610bff7f9bd99.jpg\";","module.exports = __webpack_public_path__ + \"static/3032-ed782ba2b461a73e687d2da8657b49b7.jpg\";","module.exports = __webpack_public_path__ + \"static/2006-998af5854e40ba751964e534c1797dd0.jpg\";","module.exports = __webpack_public_path__ + \"static/2024-e7fb584421cc8e94b6623fceda6428ef.jpg\";","module.exports = __webpack_public_path__ + \"static/1117-19ffac7338cd29630d72bf5d2f7906fd.jpg\";","module.exports = __webpack_public_path__ + \"static/1149-c9c4868e885ac15a7e35c5ec1e2f029e.jpg\";","module.exports = __webpack_public_path__ + \"static/3004-6628dac53b84e33edd4374783d88b682.jpg\";","module.exports = __webpack_public_path__ + \"static/3048-a906569ad466882210167959a831b52e.jpg\";","module.exports = __webpack_public_path__ + \"static/4059-b53b785ad907254502c1398130c0fe81.jpg\";","module.exports = __webpack_public_path__ + \"static/1067-cf7b08fefed0950268ef9c90464dda3a.jpg\";","import React, { useState } from 'react'\r\nimport PropTypes from 'prop-types'\r\n\r\nimport styled, { themeGet } from 'util/style'\r\n\r\nconst Wrapper = styled.div`\r\n cursor: pointer;\r\n line-height: 1.2;\r\n`\r\n\r\nconst Snippet = styled.p``\r\n\r\nconst PseudoLink = styled.span`\r\n color: ${themeGet('colors.primary.500')};\r\n\r\n &:hover {\r\n text-decoration: underline;\r\n }\r\n`\r\n\r\nconst ExpandableParagraph = ({ snippet, children, ...props }) => {\r\n const [isOpen, setIsOpen] = useState(false)\r\n\r\n const toggle = () => {\r\n setIsOpen(prevIsOpen => !prevIsOpen)\r\n }\r\n return (\r\n \r\n {isOpen ? (\r\n

\r\n {children}\r\n
\r\n Show less...\r\n

\r\n ) : (\r\n \r\n {snippet} Show more...\r\n \r\n )}\r\n
\r\n )\r\n}\r\n\r\nExpandableParagraph.propTypes = {\r\n snippet: PropTypes.string.isRequired,\r\n children: PropTypes.oneOfType([PropTypes.node, PropTypes.element]).isRequired,\r\n}\r\n\r\nexport default ExpandableParagraph\r\n","module.exports = __webpack_public_path__ + \"static/1123-9d576641fc78d44d5f5bbbb6fd1ec152.jpg\";","var anObject = require('../internals/an-object');\nvar defineProperties = require('../internals/object-define-properties');\nvar enumBugKeys = require('../internals/enum-bug-keys');\nvar hiddenKeys = require('../internals/hidden-keys');\nvar html = require('../internals/html');\nvar documentCreateElement = require('../internals/document-create-element');\nvar sharedKey = require('../internals/shared-key');\n\nvar GT = '>';\nvar LT = '<';\nvar PROTOTYPE = 'prototype';\nvar SCRIPT = 'script';\nvar IE_PROTO = sharedKey('IE_PROTO');\n\nvar EmptyConstructor = function () { /* empty */ };\n\nvar scriptTag = function (content) {\n return LT + SCRIPT + GT + content + LT + '/' + SCRIPT + GT;\n};\n\n// Create object with fake `null` prototype: use ActiveX Object with cleared prototype\nvar NullProtoObjectViaActiveX = function (activeXDocument) {\n activeXDocument.write(scriptTag(''));\n activeXDocument.close();\n var temp = activeXDocument.parentWindow.Object;\n activeXDocument = null; // avoid memory leak\n return temp;\n};\n\n// Create object with fake `null` prototype: use iframe Object with cleared prototype\nvar NullProtoObjectViaIFrame = function () {\n // Thrash, waste and sodomy: IE GC bug\n var iframe = documentCreateElement('iframe');\n var JS = 'java' + SCRIPT + ':';\n var iframeDocument;\n iframe.style.display = 'none';\n html.appendChild(iframe);\n // https://github.com/zloirock/core-js/issues/475\n iframe.src = String(JS);\n iframeDocument = iframe.contentWindow.document;\n iframeDocument.open();\n iframeDocument.write(scriptTag('document.F=Object'));\n iframeDocument.close();\n return iframeDocument.F;\n};\n\n// Check for document.domain and active x support\n// No need to use active x approach when document.domain is not set\n// see https://github.com/es-shims/es5-shim/issues/150\n// variation of https://github.com/kitcambridge/es5-shim/commit/4f738ac066346\n// avoid IE GC bug\nvar activeXDocument;\nvar NullProtoObject = function () {\n try {\n /* global ActiveXObject */\n activeXDocument = document.domain && new ActiveXObject('htmlfile');\n } catch (error) { /* ignore */ }\n NullProtoObject = activeXDocument ? NullProtoObjectViaActiveX(activeXDocument) : NullProtoObjectViaIFrame();\n var length = enumBugKeys.length;\n while (length--) delete NullProtoObject[PROTOTYPE][enumBugKeys[length]];\n return NullProtoObject();\n};\n\nhiddenKeys[IE_PROTO] = true;\n\n// `Object.create` method\n// https://tc39.github.io/ecma262/#sec-object.create\nmodule.exports = Object.create || function create(O, Properties) {\n var result;\n if (O !== null) {\n EmptyConstructor[PROTOTYPE] = anObject(O);\n result = new EmptyConstructor();\n EmptyConstructor[PROTOTYPE] = null;\n // add \"__proto__\" for Object.getPrototypeOf polyfill\n result[IE_PROTO] = O;\n } else result = NullProtoObject();\n return Properties === undefined ? result : defineProperties(result, Properties);\n};\n","import geoViewport from '@mapbox/geo-viewport'\r\n\r\n/**\r\n * Calculate the appropriate center and zoom to fit the bounds, given padding.\r\n * @param {Array(number)} bounds - [xmin, ymin, xmax, ymax]\r\n * @param {int} width - width of the map node in pixels\r\n * @param {int} height - height of the map node in pixels\r\n * @param {float} padding - proportion of calculated zoom level to zoom out by, to pad the bounds\r\n */\r\nexport const getCenterAndZoom = (bounds, width, height, padding = 0) => {\r\n const viewport = geoViewport.viewport(\r\n bounds,\r\n [width, height],\r\n undefined,\r\n undefined,\r\n undefined,\r\n true\r\n )\r\n\r\n // Zoom out slightly to pad around bounds\r\n\r\n const zoom = Math.max(viewport.zoom - 1, 0) * (1 - padding)\r\n\r\n return { center: viewport.center, zoom }\r\n}\r\n\r\nexport const boundsOverlap = (\r\n [xmin, ymin, xmax, ymax],\r\n [xmin2, ymin2, xmax2, ymax2]\r\n) => ymax2 >= ymin && ymin2 <= ymax && xmax2 >= xmin && xmin2 <= xmax\r\n\r\nexport const toGeoJSONPoint = (record, x = 'lon', y = 'lat') => {\r\n const properties = {}\r\n Object.keys(record)\r\n .filter(f => f !== x && f !== y)\r\n .forEach(f => {\r\n properties[f] = record[f]\r\n })\r\n\r\n const feature = {\r\n type: 'Feature',\r\n geometry: {\r\n type: 'Point',\r\n coordinates: [record[x], record[y]],\r\n },\r\n properties,\r\n }\r\n\r\n const { id } = record\r\n if (id !== undefined && id !== null) {\r\n feature.id = id\r\n }\r\n\r\n return feature\r\n}\r\n\r\nexport const toGeoJSONPoints = records => ({\r\n type: 'FeatureCollection',\r\n features: records.map(r => toGeoJSONPoint(r)),\r\n})\r\n\r\n/**\r\n * Group features from map by layer ID returning array of features for each.\r\n */\r\nexport const groupByLayer = features => {\r\n const results = {}\r\n features.forEach(feature => {\r\n const {\r\n layer: { id },\r\n } = feature\r\n if (!results[id]) {\r\n results[id] = []\r\n }\r\n results[id].push(feature)\r\n })\r\n\r\n return results\r\n}\r\n\r\n// property, threshold, ... property (omit last threshold)\r\n\r\n/**\r\n * Convert a list of objects into mapbox step expression\r\n * @param {Array of objects} entries - list of objects to map to steps, each must have {threshold, property}\r\n * @param {string} property - property to assign to each step, e.g., radius\r\n */\r\nexport const createSteps = (entries, property) => {\r\n const steps = []\r\n entries.forEach(({ threshold, ...entry }, i) => {\r\n steps.push(entry[property])\r\n\r\n // omit the last threshold\r\n if (i < entries.length - 1) {\r\n steps.push(threshold)\r\n }\r\n })\r\n return steps\r\n}\r\n","module.exports = __webpack_public_path__ + \"static/3077-ea119370c307972af8b451a80a46d955.jpg\";","module.exports = __webpack_public_path__ + \"static/3015-1190cd8115ae23a4775a015cbc855a87.jpg\";","module.exports = __webpack_public_path__ + \"static/4039-096758e87cfbbd7460e2eb05093d8453.jpg\";","module.exports = __webpack_public_path__ + \"static/1103-84bfa7f782ec815c5e981edf9abedb23.jpg\";","module.exports = __webpack_public_path__ + \"static/2061-9eed52d9c2eeecf1b453267e61c323ba.jpg\";","module.exports = __webpack_public_path__ + \"static/1040-b67035d2f823ec1031b1331e9b9db1c5.jpg\";","module.exports = __webpack_public_path__ + \"static/1152-6cb10305b6465632d4e0a39dc48148a4.jpg\";","module.exports = __webpack_public_path__ + \"static/4050-d0fde5c899b93f2488678112043ed273.jpg\";","module.exports = __webpack_public_path__ + \"static/2054-f29b80757cc4a64d2462443bdb4ce489.jpg\";","module.exports = __webpack_public_path__ + \"static/3043-d2c53ddc5bc938bc20b29acfc374d0e2.jpg\";","module.exports = __webpack_public_path__ + \"static/2027-d5191dcacd5790eabe410ac75926198c.jpg\";","module.exports = __webpack_public_path__ + \"static/1042-bf5ca204def0c112528fc21a802aa0ca.jpg\";","module.exports = __webpack_public_path__ + \"static/2012-2968fd13aab2cccbef03cffab0f8273b.jpg\";","module.exports = __webpack_public_path__ + \"static/2107-132a9aff8e4afc2f24f81d9c43bbc368.jpg\";","module.exports = __webpack_public_path__ + \"static/3090-b82b5f8d318d5f8f0e6804096bf36d72.jpg\";","module.exports = __webpack_public_path__ + \"static/1145-a4b64210d4813c1e505999c6e7ec2b80.jpg\";","module.exports = __webpack_public_path__ + \"static/3041-eb1eba2f75c4de6bcc2e102b8fef1335.jpg\";","module.exports = __webpack_public_path__ + \"static/1085-fcd0b14b70e116bfe5ae978b1c64d23f.jpg\";","import \"core-js/modules/es.array.flat-map.js\";\nimport \"core-js/modules/es.array.reduce.js\";\nimport \"core-js/modules/es.array.unscopables.flat-map.js\";\n\n/**\n * Copyright (c) 2014-present, Facebook, Inc.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n// Used for setting prototype methods that IE8 chokes on.\nvar DELETE = 'delete'; // Constants describing the size of trie nodes.\n\nvar SHIFT = 5; // Resulted in best performance after ______?\n\nvar SIZE = 1 << SHIFT;\nvar MASK = SIZE - 1; // A consistent shared value representing \"not set\" which equals nothing other\n// than itself, and nothing that could be provided externally.\n\nvar NOT_SET = {}; // Boolean references, Rough equivalent of `bool &`.\n\nfunction MakeRef() {\n return {\n value: false\n };\n}\n\nfunction SetRef(ref) {\n if (ref) {\n ref.value = true;\n }\n} // A function which returns a value representing an \"owner\" for transient writes\n// to tries. The return value will only ever equal itself, and will not equal\n// the return of any subsequent call of this function.\n\n\nfunction OwnerID() {}\n\nfunction ensureSize(iter) {\n if (iter.size === undefined) {\n iter.size = iter.__iterate(returnTrue);\n }\n\n return iter.size;\n}\n\nfunction wrapIndex(iter, index) {\n // This implements \"is array index\" which the ECMAString spec defines as:\n //\n // A String property name P is an array index if and only if\n // ToString(ToUint32(P)) is equal to P and ToUint32(P) is not equal\n // to 2^32−1.\n //\n // http://www.ecma-international.org/ecma-262/6.0/#sec-array-exotic-objects\n if (typeof index !== 'number') {\n var uint32Index = index >>> 0; // N >>> 0 is shorthand for ToUint32\n\n if ('' + uint32Index !== index || uint32Index === 4294967295) {\n return NaN;\n }\n\n index = uint32Index;\n }\n\n return index < 0 ? ensureSize(iter) + index : index;\n}\n\nfunction returnTrue() {\n return true;\n}\n\nfunction wholeSlice(begin, end, size) {\n return (begin === 0 && !isNeg(begin) || size !== undefined && begin <= -size) && (end === undefined || size !== undefined && end >= size);\n}\n\nfunction resolveBegin(begin, size) {\n return resolveIndex(begin, size, 0);\n}\n\nfunction resolveEnd(end, size) {\n return resolveIndex(end, size, size);\n}\n\nfunction resolveIndex(index, size, defaultIndex) {\n // Sanitize indices using this shorthand for ToInt32(argument)\n // http://www.ecma-international.org/ecma-262/6.0/#sec-toint32\n return index === undefined ? defaultIndex : isNeg(index) ? size === Infinity ? size : Math.max(0, size + index) | 0 : size === undefined || size === index ? index : Math.min(size, index) | 0;\n}\n\nfunction isNeg(value) {\n // Account for -0 which is negative, but not less than 0.\n return value < 0 || value === 0 && 1 / value === -Infinity;\n} // Note: value is unchanged to not break immutable-devtools.\n\n\nvar IS_COLLECTION_SYMBOL = '@@__IMMUTABLE_ITERABLE__@@';\n\nfunction isCollection(maybeCollection) {\n return Boolean(maybeCollection && maybeCollection[IS_COLLECTION_SYMBOL]);\n}\n\nvar IS_KEYED_SYMBOL = '@@__IMMUTABLE_KEYED__@@';\n\nfunction isKeyed(maybeKeyed) {\n return Boolean(maybeKeyed && maybeKeyed[IS_KEYED_SYMBOL]);\n}\n\nvar IS_INDEXED_SYMBOL = '@@__IMMUTABLE_INDEXED__@@';\n\nfunction isIndexed(maybeIndexed) {\n return Boolean(maybeIndexed && maybeIndexed[IS_INDEXED_SYMBOL]);\n}\n\nfunction isAssociative(maybeAssociative) {\n return isKeyed(maybeAssociative) || isIndexed(maybeAssociative);\n}\n\nvar Collection = function Collection(value) {\n return isCollection(value) ? value : Seq(value);\n};\n\nvar KeyedCollection =\n/*@__PURE__*/\nfunction (Collection) {\n function KeyedCollection(value) {\n return isKeyed(value) ? value : KeyedSeq(value);\n }\n\n if (Collection) KeyedCollection.__proto__ = Collection;\n KeyedCollection.prototype = Object.create(Collection && Collection.prototype);\n KeyedCollection.prototype.constructor = KeyedCollection;\n return KeyedCollection;\n}(Collection);\n\nvar IndexedCollection =\n/*@__PURE__*/\nfunction (Collection) {\n function IndexedCollection(value) {\n return isIndexed(value) ? value : IndexedSeq(value);\n }\n\n if (Collection) IndexedCollection.__proto__ = Collection;\n IndexedCollection.prototype = Object.create(Collection && Collection.prototype);\n IndexedCollection.prototype.constructor = IndexedCollection;\n return IndexedCollection;\n}(Collection);\n\nvar SetCollection =\n/*@__PURE__*/\nfunction (Collection) {\n function SetCollection(value) {\n return isCollection(value) && !isAssociative(value) ? value : SetSeq(value);\n }\n\n if (Collection) SetCollection.__proto__ = Collection;\n SetCollection.prototype = Object.create(Collection && Collection.prototype);\n SetCollection.prototype.constructor = SetCollection;\n return SetCollection;\n}(Collection);\n\nCollection.Keyed = KeyedCollection;\nCollection.Indexed = IndexedCollection;\nCollection.Set = SetCollection;\nvar IS_SEQ_SYMBOL = '@@__IMMUTABLE_SEQ__@@';\n\nfunction isSeq(maybeSeq) {\n return Boolean(maybeSeq && maybeSeq[IS_SEQ_SYMBOL]);\n}\n\nvar IS_RECORD_SYMBOL = '@@__IMMUTABLE_RECORD__@@';\n\nfunction isRecord(maybeRecord) {\n return Boolean(maybeRecord && maybeRecord[IS_RECORD_SYMBOL]);\n}\n\nfunction isImmutable(maybeImmutable) {\n return isCollection(maybeImmutable) || isRecord(maybeImmutable);\n}\n\nvar IS_ORDERED_SYMBOL = '@@__IMMUTABLE_ORDERED__@@';\n\nfunction isOrdered(maybeOrdered) {\n return Boolean(maybeOrdered && maybeOrdered[IS_ORDERED_SYMBOL]);\n}\n\nvar ITERATE_KEYS = 0;\nvar ITERATE_VALUES = 1;\nvar ITERATE_ENTRIES = 2;\nvar REAL_ITERATOR_SYMBOL = typeof Symbol === 'function' && Symbol.iterator;\nvar FAUX_ITERATOR_SYMBOL = '@@iterator';\nvar ITERATOR_SYMBOL = REAL_ITERATOR_SYMBOL || FAUX_ITERATOR_SYMBOL;\n\nvar Iterator = function Iterator(next) {\n this.next = next;\n};\n\nIterator.prototype.toString = function toString() {\n return '[Iterator]';\n};\n\nIterator.KEYS = ITERATE_KEYS;\nIterator.VALUES = ITERATE_VALUES;\nIterator.ENTRIES = ITERATE_ENTRIES;\n\nIterator.prototype.inspect = Iterator.prototype.toSource = function () {\n return this.toString();\n};\n\nIterator.prototype[ITERATOR_SYMBOL] = function () {\n return this;\n};\n\nfunction iteratorValue(type, k, v, iteratorResult) {\n var value = type === 0 ? k : type === 1 ? v : [k, v];\n iteratorResult ? iteratorResult.value = value : iteratorResult = {\n value: value,\n done: false\n };\n return iteratorResult;\n}\n\nfunction iteratorDone() {\n return {\n value: undefined,\n done: true\n };\n}\n\nfunction hasIterator(maybeIterable) {\n return !!getIteratorFn(maybeIterable);\n}\n\nfunction isIterator(maybeIterator) {\n return maybeIterator && typeof maybeIterator.next === 'function';\n}\n\nfunction getIterator(iterable) {\n var iteratorFn = getIteratorFn(iterable);\n return iteratorFn && iteratorFn.call(iterable);\n}\n\nfunction getIteratorFn(iterable) {\n var iteratorFn = iterable && (REAL_ITERATOR_SYMBOL && iterable[REAL_ITERATOR_SYMBOL] || iterable[FAUX_ITERATOR_SYMBOL]);\n\n if (typeof iteratorFn === 'function') {\n return iteratorFn;\n }\n}\n\nvar hasOwnProperty = Object.prototype.hasOwnProperty;\n\nfunction isArrayLike(value) {\n if (Array.isArray(value) || typeof value === 'string') {\n return true;\n }\n\n return value && typeof value === 'object' && Number.isInteger(value.length) && value.length >= 0 && (value.length === 0 ? // Only {length: 0} is considered Array-like.\n Object.keys(value).length === 1 : // An object is only Array-like if it has a property where the last value\n // in the array-like may be found (which could be undefined).\n value.hasOwnProperty(value.length - 1));\n}\n\nvar Seq =\n/*@__PURE__*/\nfunction (Collection$$1) {\n function Seq(value) {\n return value === null || value === undefined ? emptySequence() : isImmutable(value) ? value.toSeq() : seqFromValue(value);\n }\n\n if (Collection$$1) Seq.__proto__ = Collection$$1;\n Seq.prototype = Object.create(Collection$$1 && Collection$$1.prototype);\n Seq.prototype.constructor = Seq;\n\n Seq.prototype.toSeq = function toSeq() {\n return this;\n };\n\n Seq.prototype.toString = function toString() {\n return this.__toString('Seq {', '}');\n };\n\n Seq.prototype.cacheResult = function cacheResult() {\n if (!this._cache && this.__iterateUncached) {\n this._cache = this.entrySeq().toArray();\n this.size = this._cache.length;\n }\n\n return this;\n }; // abstract __iterateUncached(fn, reverse)\n\n\n Seq.prototype.__iterate = function __iterate(fn, reverse) {\n var cache = this._cache;\n\n if (cache) {\n var size = cache.length;\n var i = 0;\n\n while (i !== size) {\n var entry = cache[reverse ? size - ++i : i++];\n\n if (fn(entry[1], entry[0], this) === false) {\n break;\n }\n }\n\n return i;\n }\n\n return this.__iterateUncached(fn, reverse);\n }; // abstract __iteratorUncached(type, reverse)\n\n\n Seq.prototype.__iterator = function __iterator(type, reverse) {\n var cache = this._cache;\n\n if (cache) {\n var size = cache.length;\n var i = 0;\n return new Iterator(function () {\n if (i === size) {\n return iteratorDone();\n }\n\n var entry = cache[reverse ? size - ++i : i++];\n return iteratorValue(type, entry[0], entry[1]);\n });\n }\n\n return this.__iteratorUncached(type, reverse);\n };\n\n return Seq;\n}(Collection);\n\nvar KeyedSeq =\n/*@__PURE__*/\nfunction (Seq) {\n function KeyedSeq(value) {\n return value === null || value === undefined ? emptySequence().toKeyedSeq() : isCollection(value) ? isKeyed(value) ? value.toSeq() : value.fromEntrySeq() : isRecord(value) ? value.toSeq() : keyedSeqFromValue(value);\n }\n\n if (Seq) KeyedSeq.__proto__ = Seq;\n KeyedSeq.prototype = Object.create(Seq && Seq.prototype);\n KeyedSeq.prototype.constructor = KeyedSeq;\n\n KeyedSeq.prototype.toKeyedSeq = function toKeyedSeq() {\n return this;\n };\n\n return KeyedSeq;\n}(Seq);\n\nvar IndexedSeq =\n/*@__PURE__*/\nfunction (Seq) {\n function IndexedSeq(value) {\n return value === null || value === undefined ? emptySequence() : isCollection(value) ? isKeyed(value) ? value.entrySeq() : value.toIndexedSeq() : isRecord(value) ? value.toSeq().entrySeq() : indexedSeqFromValue(value);\n }\n\n if (Seq) IndexedSeq.__proto__ = Seq;\n IndexedSeq.prototype = Object.create(Seq && Seq.prototype);\n IndexedSeq.prototype.constructor = IndexedSeq;\n\n IndexedSeq.of = function of()\n /*...values*/\n {\n return IndexedSeq(arguments);\n };\n\n IndexedSeq.prototype.toIndexedSeq = function toIndexedSeq() {\n return this;\n };\n\n IndexedSeq.prototype.toString = function toString() {\n return this.__toString('Seq [', ']');\n };\n\n return IndexedSeq;\n}(Seq);\n\nvar SetSeq =\n/*@__PURE__*/\nfunction (Seq) {\n function SetSeq(value) {\n return (isCollection(value) && !isAssociative(value) ? value : IndexedSeq(value)).toSetSeq();\n }\n\n if (Seq) SetSeq.__proto__ = Seq;\n SetSeq.prototype = Object.create(Seq && Seq.prototype);\n SetSeq.prototype.constructor = SetSeq;\n\n SetSeq.of = function of()\n /*...values*/\n {\n return SetSeq(arguments);\n };\n\n SetSeq.prototype.toSetSeq = function toSetSeq() {\n return this;\n };\n\n return SetSeq;\n}(Seq);\n\nSeq.isSeq = isSeq;\nSeq.Keyed = KeyedSeq;\nSeq.Set = SetSeq;\nSeq.Indexed = IndexedSeq;\nSeq.prototype[IS_SEQ_SYMBOL] = true; // #pragma Root Sequences\n\nvar ArraySeq =\n/*@__PURE__*/\nfunction (IndexedSeq) {\n function ArraySeq(array) {\n this._array = array;\n this.size = array.length;\n }\n\n if (IndexedSeq) ArraySeq.__proto__ = IndexedSeq;\n ArraySeq.prototype = Object.create(IndexedSeq && IndexedSeq.prototype);\n ArraySeq.prototype.constructor = ArraySeq;\n\n ArraySeq.prototype.get = function get(index, notSetValue) {\n return this.has(index) ? this._array[wrapIndex(this, index)] : notSetValue;\n };\n\n ArraySeq.prototype.__iterate = function __iterate(fn, reverse) {\n var array = this._array;\n var size = array.length;\n var i = 0;\n\n while (i !== size) {\n var ii = reverse ? size - ++i : i++;\n\n if (fn(array[ii], ii, this) === false) {\n break;\n }\n }\n\n return i;\n };\n\n ArraySeq.prototype.__iterator = function __iterator(type, reverse) {\n var array = this._array;\n var size = array.length;\n var i = 0;\n return new Iterator(function () {\n if (i === size) {\n return iteratorDone();\n }\n\n var ii = reverse ? size - ++i : i++;\n return iteratorValue(type, ii, array[ii]);\n });\n };\n\n return ArraySeq;\n}(IndexedSeq);\n\nvar ObjectSeq =\n/*@__PURE__*/\nfunction (KeyedSeq) {\n function ObjectSeq(object) {\n var keys = Object.keys(object);\n this._object = object;\n this._keys = keys;\n this.size = keys.length;\n }\n\n if (KeyedSeq) ObjectSeq.__proto__ = KeyedSeq;\n ObjectSeq.prototype = Object.create(KeyedSeq && KeyedSeq.prototype);\n ObjectSeq.prototype.constructor = ObjectSeq;\n\n ObjectSeq.prototype.get = function get(key, notSetValue) {\n if (notSetValue !== undefined && !this.has(key)) {\n return notSetValue;\n }\n\n return this._object[key];\n };\n\n ObjectSeq.prototype.has = function has(key) {\n return hasOwnProperty.call(this._object, key);\n };\n\n ObjectSeq.prototype.__iterate = function __iterate(fn, reverse) {\n var object = this._object;\n var keys = this._keys;\n var size = keys.length;\n var i = 0;\n\n while (i !== size) {\n var key = keys[reverse ? size - ++i : i++];\n\n if (fn(object[key], key, this) === false) {\n break;\n }\n }\n\n return i;\n };\n\n ObjectSeq.prototype.__iterator = function __iterator(type, reverse) {\n var object = this._object;\n var keys = this._keys;\n var size = keys.length;\n var i = 0;\n return new Iterator(function () {\n if (i === size) {\n return iteratorDone();\n }\n\n var key = keys[reverse ? size - ++i : i++];\n return iteratorValue(type, key, object[key]);\n });\n };\n\n return ObjectSeq;\n}(KeyedSeq);\n\nObjectSeq.prototype[IS_ORDERED_SYMBOL] = true;\n\nvar CollectionSeq =\n/*@__PURE__*/\nfunction (IndexedSeq) {\n function CollectionSeq(collection) {\n this._collection = collection;\n this.size = collection.length || collection.size;\n }\n\n if (IndexedSeq) CollectionSeq.__proto__ = IndexedSeq;\n CollectionSeq.prototype = Object.create(IndexedSeq && IndexedSeq.prototype);\n CollectionSeq.prototype.constructor = CollectionSeq;\n\n CollectionSeq.prototype.__iterateUncached = function __iterateUncached(fn, reverse) {\n if (reverse) {\n return this.cacheResult().__iterate(fn, reverse);\n }\n\n var collection = this._collection;\n var iterator = getIterator(collection);\n var iterations = 0;\n\n if (isIterator(iterator)) {\n var step;\n\n while (!(step = iterator.next()).done) {\n if (fn(step.value, iterations++, this) === false) {\n break;\n }\n }\n }\n\n return iterations;\n };\n\n CollectionSeq.prototype.__iteratorUncached = function __iteratorUncached(type, reverse) {\n if (reverse) {\n return this.cacheResult().__iterator(type, reverse);\n }\n\n var collection = this._collection;\n var iterator = getIterator(collection);\n\n if (!isIterator(iterator)) {\n return new Iterator(iteratorDone);\n }\n\n var iterations = 0;\n return new Iterator(function () {\n var step = iterator.next();\n return step.done ? step : iteratorValue(type, iterations++, step.value);\n });\n };\n\n return CollectionSeq;\n}(IndexedSeq); // # pragma Helper functions\n\n\nvar EMPTY_SEQ;\n\nfunction emptySequence() {\n return EMPTY_SEQ || (EMPTY_SEQ = new ArraySeq([]));\n}\n\nfunction keyedSeqFromValue(value) {\n var seq = Array.isArray(value) ? new ArraySeq(value) : hasIterator(value) ? new CollectionSeq(value) : undefined;\n\n if (seq) {\n return seq.fromEntrySeq();\n }\n\n if (typeof value === 'object') {\n return new ObjectSeq(value);\n }\n\n throw new TypeError('Expected Array or collection object of [k, v] entries, or keyed object: ' + value);\n}\n\nfunction indexedSeqFromValue(value) {\n var seq = maybeIndexedSeqFromValue(value);\n\n if (seq) {\n return seq;\n }\n\n throw new TypeError('Expected Array or collection object of values: ' + value);\n}\n\nfunction seqFromValue(value) {\n var seq = maybeIndexedSeqFromValue(value);\n\n if (seq) {\n return seq;\n }\n\n if (typeof value === 'object') {\n return new ObjectSeq(value);\n }\n\n throw new TypeError('Expected Array or collection object of values, or keyed object: ' + value);\n}\n\nfunction maybeIndexedSeqFromValue(value) {\n return isArrayLike(value) ? new ArraySeq(value) : hasIterator(value) ? new CollectionSeq(value) : undefined;\n}\n\nvar IS_MAP_SYMBOL = '@@__IMMUTABLE_MAP__@@';\n\nfunction isMap(maybeMap) {\n return Boolean(maybeMap && maybeMap[IS_MAP_SYMBOL]);\n}\n\nfunction isOrderedMap(maybeOrderedMap) {\n return isMap(maybeOrderedMap) && isOrdered(maybeOrderedMap);\n}\n\nfunction isValueObject(maybeValue) {\n return Boolean(maybeValue && typeof maybeValue.equals === 'function' && typeof maybeValue.hashCode === 'function');\n}\n/**\n * An extension of the \"same-value\" algorithm as [described for use by ES6 Map\n * and Set](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Map#Key_equality)\n *\n * NaN is considered the same as NaN, however -0 and 0 are considered the same\n * value, which is different from the algorithm described by\n * [`Object.is`](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Object/is).\n *\n * This is extended further to allow Objects to describe the values they\n * represent, by way of `valueOf` or `equals` (and `hashCode`).\n *\n * Note: because of this extension, the key equality of Immutable.Map and the\n * value equality of Immutable.Set will differ from ES6 Map and Set.\n *\n * ### Defining custom values\n *\n * The easiest way to describe the value an object represents is by implementing\n * `valueOf`. For example, `Date` represents a value by returning a unix\n * timestamp for `valueOf`:\n *\n * var date1 = new Date(1234567890000); // Fri Feb 13 2009 ...\n * var date2 = new Date(1234567890000);\n * date1.valueOf(); // 1234567890000\n * assert( date1 !== date2 );\n * assert( Immutable.is( date1, date2 ) );\n *\n * Note: overriding `valueOf` may have other implications if you use this object\n * where JavaScript expects a primitive, such as implicit string coercion.\n *\n * For more complex types, especially collections, implementing `valueOf` may\n * not be performant. An alternative is to implement `equals` and `hashCode`.\n *\n * `equals` takes another object, presumably of similar type, and returns true\n * if it is equal. Equality is symmetrical, so the same result should be\n * returned if this and the argument are flipped.\n *\n * assert( a.equals(b) === b.equals(a) );\n *\n * `hashCode` returns a 32bit integer number representing the object which will\n * be used to determine how to store the value object in a Map or Set. You must\n * provide both or neither methods, one must not exist without the other.\n *\n * Also, an important relationship between these methods must be upheld: if two\n * values are equal, they *must* return the same hashCode. If the values are not\n * equal, they might have the same hashCode; this is called a hash collision,\n * and while undesirable for performance reasons, it is acceptable.\n *\n * if (a.equals(b)) {\n * assert( a.hashCode() === b.hashCode() );\n * }\n *\n * All Immutable collections are Value Objects: they implement `equals()`\n * and `hashCode()`.\n */\n\n\nfunction is(valueA, valueB) {\n if (valueA === valueB || valueA !== valueA && valueB !== valueB) {\n return true;\n }\n\n if (!valueA || !valueB) {\n return false;\n }\n\n if (typeof valueA.valueOf === 'function' && typeof valueB.valueOf === 'function') {\n valueA = valueA.valueOf();\n valueB = valueB.valueOf();\n\n if (valueA === valueB || valueA !== valueA && valueB !== valueB) {\n return true;\n }\n\n if (!valueA || !valueB) {\n return false;\n }\n }\n\n return !!(isValueObject(valueA) && isValueObject(valueB) && valueA.equals(valueB));\n}\n\nvar imul = typeof Math.imul === 'function' && Math.imul(0xffffffff, 2) === -2 ? Math.imul : function imul(a, b) {\n a |= 0; // int\n\n b |= 0; // int\n\n var c = a & 0xffff;\n var d = b & 0xffff; // Shift by 0 fixes the sign on the high part.\n\n return c * d + ((a >>> 16) * d + c * (b >>> 16) << 16 >>> 0) | 0; // int\n}; // v8 has an optimization for storing 31-bit signed numbers.\n// Values which have either 00 or 11 as the high order bits qualify.\n// This function drops the highest order bit in a signed number, maintaining\n// the sign bit.\n\nfunction smi(i32) {\n return i32 >>> 1 & 0x40000000 | i32 & 0xbfffffff;\n}\n\nvar defaultValueOf = Object.prototype.valueOf;\n\nfunction hash(o) {\n switch (typeof o) {\n case 'boolean':\n // The hash values for built-in constants are a 1 value for each 5-byte\n // shift region expect for the first, which encodes the value. This\n // reduces the odds of a hash collision for these common values.\n return o ? 0x42108421 : 0x42108420;\n\n case 'number':\n return hashNumber(o);\n\n case 'string':\n return o.length > STRING_HASH_CACHE_MIN_STRLEN ? cachedHashString(o) : hashString(o);\n\n case 'object':\n case 'function':\n if (o === null) {\n return 0x42108422;\n }\n\n if (typeof o.hashCode === 'function') {\n // Drop any high bits from accidentally long hash codes.\n return smi(o.hashCode(o));\n }\n\n if (o.valueOf !== defaultValueOf && typeof o.valueOf === 'function') {\n o = o.valueOf(o);\n }\n\n return hashJSObj(o);\n\n case 'undefined':\n return 0x42108423;\n\n default:\n if (typeof o.toString === 'function') {\n return hashString(o.toString());\n }\n\n throw new Error('Value type ' + typeof o + ' cannot be hashed.');\n }\n} // Compress arbitrarily large numbers into smi hashes.\n\n\nfunction hashNumber(n) {\n if (n !== n || n === Infinity) {\n return 0;\n }\n\n var hash = n | 0;\n\n if (hash !== n) {\n hash ^= n * 0xffffffff;\n }\n\n while (n > 0xffffffff) {\n n /= 0xffffffff;\n hash ^= n;\n }\n\n return smi(hash);\n}\n\nfunction cachedHashString(string) {\n var hashed = stringHashCache[string];\n\n if (hashed === undefined) {\n hashed = hashString(string);\n\n if (STRING_HASH_CACHE_SIZE === STRING_HASH_CACHE_MAX_SIZE) {\n STRING_HASH_CACHE_SIZE = 0;\n stringHashCache = {};\n }\n\n STRING_HASH_CACHE_SIZE++;\n stringHashCache[string] = hashed;\n }\n\n return hashed;\n} // http://jsperf.com/hashing-strings\n\n\nfunction hashString(string) {\n // This is the hash from JVM\n // The hash code for a string is computed as\n // s[0] * 31 ^ (n - 1) + s[1] * 31 ^ (n - 2) + ... + s[n - 1],\n // where s[i] is the ith character of the string and n is the length of\n // the string. We \"mod\" the result to make it between 0 (inclusive) and 2^31\n // (exclusive) by dropping high bits.\n var hashed = 0;\n\n for (var ii = 0; ii < string.length; ii++) {\n hashed = 31 * hashed + string.charCodeAt(ii) | 0;\n }\n\n return smi(hashed);\n}\n\nfunction hashJSObj(obj) {\n var hashed;\n\n if (usingWeakMap) {\n hashed = weakMap.get(obj);\n\n if (hashed !== undefined) {\n return hashed;\n }\n }\n\n hashed = obj[UID_HASH_KEY];\n\n if (hashed !== undefined) {\n return hashed;\n }\n\n if (!canDefineProperty) {\n hashed = obj.propertyIsEnumerable && obj.propertyIsEnumerable[UID_HASH_KEY];\n\n if (hashed !== undefined) {\n return hashed;\n }\n\n hashed = getIENodeHash(obj);\n\n if (hashed !== undefined) {\n return hashed;\n }\n }\n\n hashed = ++objHashUID;\n\n if (objHashUID & 0x40000000) {\n objHashUID = 0;\n }\n\n if (usingWeakMap) {\n weakMap.set(obj, hashed);\n } else if (isExtensible !== undefined && isExtensible(obj) === false) {\n throw new Error('Non-extensible objects are not allowed as keys.');\n } else if (canDefineProperty) {\n Object.defineProperty(obj, UID_HASH_KEY, {\n enumerable: false,\n configurable: false,\n writable: false,\n value: hashed\n });\n } else if (obj.propertyIsEnumerable !== undefined && obj.propertyIsEnumerable === obj.constructor.prototype.propertyIsEnumerable) {\n // Since we can't define a non-enumerable property on the object\n // we'll hijack one of the less-used non-enumerable properties to\n // save our hash on it. Since this is a function it will not show up in\n // `JSON.stringify` which is what we want.\n obj.propertyIsEnumerable = function () {\n return this.constructor.prototype.propertyIsEnumerable.apply(this, arguments);\n };\n\n obj.propertyIsEnumerable[UID_HASH_KEY] = hashed;\n } else if (obj.nodeType !== undefined) {\n // At this point we couldn't get the IE `uniqueID` to use as a hash\n // and we couldn't use a non-enumerable property to exploit the\n // dontEnum bug so we simply add the `UID_HASH_KEY` on the node\n // itself.\n obj[UID_HASH_KEY] = hashed;\n } else {\n throw new Error('Unable to set a non-enumerable property on object.');\n }\n\n return hashed;\n} // Get references to ES5 object methods.\n\n\nvar isExtensible = Object.isExtensible; // True if Object.defineProperty works as expected. IE8 fails this test.\n\nvar canDefineProperty = function () {\n try {\n Object.defineProperty({}, '@', {});\n return true;\n } catch (e) {\n return false;\n }\n}(); // IE has a `uniqueID` property on DOM nodes. We can construct the hash from it\n// and avoid memory leaks from the IE cloneNode bug.\n\n\nfunction getIENodeHash(node) {\n if (node && node.nodeType > 0) {\n switch (node.nodeType) {\n case 1:\n // Element\n return node.uniqueID;\n\n case 9:\n // Document\n return node.documentElement && node.documentElement.uniqueID;\n }\n }\n} // If possible, use a WeakMap.\n\n\nvar usingWeakMap = typeof WeakMap === 'function';\nvar weakMap;\n\nif (usingWeakMap) {\n weakMap = new WeakMap();\n}\n\nvar objHashUID = 0;\nvar UID_HASH_KEY = '__immutablehash__';\n\nif (typeof Symbol === 'function') {\n UID_HASH_KEY = Symbol(UID_HASH_KEY);\n}\n\nvar STRING_HASH_CACHE_MIN_STRLEN = 16;\nvar STRING_HASH_CACHE_MAX_SIZE = 255;\nvar STRING_HASH_CACHE_SIZE = 0;\nvar stringHashCache = {};\n\nvar ToKeyedSequence =\n/*@__PURE__*/\nfunction (KeyedSeq$$1) {\n function ToKeyedSequence(indexed, useKeys) {\n this._iter = indexed;\n this._useKeys = useKeys;\n this.size = indexed.size;\n }\n\n if (KeyedSeq$$1) ToKeyedSequence.__proto__ = KeyedSeq$$1;\n ToKeyedSequence.prototype = Object.create(KeyedSeq$$1 && KeyedSeq$$1.prototype);\n ToKeyedSequence.prototype.constructor = ToKeyedSequence;\n\n ToKeyedSequence.prototype.get = function get(key, notSetValue) {\n return this._iter.get(key, notSetValue);\n };\n\n ToKeyedSequence.prototype.has = function has(key) {\n return this._iter.has(key);\n };\n\n ToKeyedSequence.prototype.valueSeq = function valueSeq() {\n return this._iter.valueSeq();\n };\n\n ToKeyedSequence.prototype.reverse = function reverse() {\n var this$1 = this;\n var reversedSequence = reverseFactory(this, true);\n\n if (!this._useKeys) {\n reversedSequence.valueSeq = function () {\n return this$1._iter.toSeq().reverse();\n };\n }\n\n return reversedSequence;\n };\n\n ToKeyedSequence.prototype.map = function map(mapper, context) {\n var this$1 = this;\n var mappedSequence = mapFactory(this, mapper, context);\n\n if (!this._useKeys) {\n mappedSequence.valueSeq = function () {\n return this$1._iter.toSeq().map(mapper, context);\n };\n }\n\n return mappedSequence;\n };\n\n ToKeyedSequence.prototype.__iterate = function __iterate(fn, reverse) {\n var this$1 = this;\n return this._iter.__iterate(function (v, k) {\n return fn(v, k, this$1);\n }, reverse);\n };\n\n ToKeyedSequence.prototype.__iterator = function __iterator(type, reverse) {\n return this._iter.__iterator(type, reverse);\n };\n\n return ToKeyedSequence;\n}(KeyedSeq);\n\nToKeyedSequence.prototype[IS_ORDERED_SYMBOL] = true;\n\nvar ToIndexedSequence =\n/*@__PURE__*/\nfunction (IndexedSeq$$1) {\n function ToIndexedSequence(iter) {\n this._iter = iter;\n this.size = iter.size;\n }\n\n if (IndexedSeq$$1) ToIndexedSequence.__proto__ = IndexedSeq$$1;\n ToIndexedSequence.prototype = Object.create(IndexedSeq$$1 && IndexedSeq$$1.prototype);\n ToIndexedSequence.prototype.constructor = ToIndexedSequence;\n\n ToIndexedSequence.prototype.includes = function includes(value) {\n return this._iter.includes(value);\n };\n\n ToIndexedSequence.prototype.__iterate = function __iterate(fn, reverse) {\n var this$1 = this;\n var i = 0;\n reverse && ensureSize(this);\n return this._iter.__iterate(function (v) {\n return fn(v, reverse ? this$1.size - ++i : i++, this$1);\n }, reverse);\n };\n\n ToIndexedSequence.prototype.__iterator = function __iterator(type, reverse) {\n var this$1 = this;\n\n var iterator = this._iter.__iterator(ITERATE_VALUES, reverse);\n\n var i = 0;\n reverse && ensureSize(this);\n return new Iterator(function () {\n var step = iterator.next();\n return step.done ? step : iteratorValue(type, reverse ? this$1.size - ++i : i++, step.value, step);\n });\n };\n\n return ToIndexedSequence;\n}(IndexedSeq);\n\nvar ToSetSequence =\n/*@__PURE__*/\nfunction (SetSeq$$1) {\n function ToSetSequence(iter) {\n this._iter = iter;\n this.size = iter.size;\n }\n\n if (SetSeq$$1) ToSetSequence.__proto__ = SetSeq$$1;\n ToSetSequence.prototype = Object.create(SetSeq$$1 && SetSeq$$1.prototype);\n ToSetSequence.prototype.constructor = ToSetSequence;\n\n ToSetSequence.prototype.has = function has(key) {\n return this._iter.includes(key);\n };\n\n ToSetSequence.prototype.__iterate = function __iterate(fn, reverse) {\n var this$1 = this;\n return this._iter.__iterate(function (v) {\n return fn(v, v, this$1);\n }, reverse);\n };\n\n ToSetSequence.prototype.__iterator = function __iterator(type, reverse) {\n var iterator = this._iter.__iterator(ITERATE_VALUES, reverse);\n\n return new Iterator(function () {\n var step = iterator.next();\n return step.done ? step : iteratorValue(type, step.value, step.value, step);\n });\n };\n\n return ToSetSequence;\n}(SetSeq);\n\nvar FromEntriesSequence =\n/*@__PURE__*/\nfunction (KeyedSeq$$1) {\n function FromEntriesSequence(entries) {\n this._iter = entries;\n this.size = entries.size;\n }\n\n if (KeyedSeq$$1) FromEntriesSequence.__proto__ = KeyedSeq$$1;\n FromEntriesSequence.prototype = Object.create(KeyedSeq$$1 && KeyedSeq$$1.prototype);\n FromEntriesSequence.prototype.constructor = FromEntriesSequence;\n\n FromEntriesSequence.prototype.entrySeq = function entrySeq() {\n return this._iter.toSeq();\n };\n\n FromEntriesSequence.prototype.__iterate = function __iterate(fn, reverse) {\n var this$1 = this;\n return this._iter.__iterate(function (entry) {\n // Check if entry exists first so array access doesn't throw for holes\n // in the parent iteration.\n if (entry) {\n validateEntry(entry);\n var indexedCollection = isCollection(entry);\n return fn(indexedCollection ? entry.get(1) : entry[1], indexedCollection ? entry.get(0) : entry[0], this$1);\n }\n }, reverse);\n };\n\n FromEntriesSequence.prototype.__iterator = function __iterator(type, reverse) {\n var iterator = this._iter.__iterator(ITERATE_VALUES, reverse);\n\n return new Iterator(function () {\n while (true) {\n var step = iterator.next();\n\n if (step.done) {\n return step;\n }\n\n var entry = step.value; // Check if entry exists first so array access doesn't throw for holes\n // in the parent iteration.\n\n if (entry) {\n validateEntry(entry);\n var indexedCollection = isCollection(entry);\n return iteratorValue(type, indexedCollection ? entry.get(0) : entry[0], indexedCollection ? entry.get(1) : entry[1], step);\n }\n }\n });\n };\n\n return FromEntriesSequence;\n}(KeyedSeq);\n\nToIndexedSequence.prototype.cacheResult = ToKeyedSequence.prototype.cacheResult = ToSetSequence.prototype.cacheResult = FromEntriesSequence.prototype.cacheResult = cacheResultThrough;\n\nfunction flipFactory(collection) {\n var flipSequence = makeSequence(collection);\n flipSequence._iter = collection;\n flipSequence.size = collection.size;\n\n flipSequence.flip = function () {\n return collection;\n };\n\n flipSequence.reverse = function () {\n var reversedSequence = collection.reverse.apply(this); // super.reverse()\n\n reversedSequence.flip = function () {\n return collection.reverse();\n };\n\n return reversedSequence;\n };\n\n flipSequence.has = function (key) {\n return collection.includes(key);\n };\n\n flipSequence.includes = function (key) {\n return collection.has(key);\n };\n\n flipSequence.cacheResult = cacheResultThrough;\n\n flipSequence.__iterateUncached = function (fn, reverse) {\n var this$1 = this;\n return collection.__iterate(function (v, k) {\n return fn(k, v, this$1) !== false;\n }, reverse);\n };\n\n flipSequence.__iteratorUncached = function (type, reverse) {\n if (type === ITERATE_ENTRIES) {\n var iterator = collection.__iterator(type, reverse);\n\n return new Iterator(function () {\n var step = iterator.next();\n\n if (!step.done) {\n var k = step.value[0];\n step.value[0] = step.value[1];\n step.value[1] = k;\n }\n\n return step;\n });\n }\n\n return collection.__iterator(type === ITERATE_VALUES ? ITERATE_KEYS : ITERATE_VALUES, reverse);\n };\n\n return flipSequence;\n}\n\nfunction mapFactory(collection, mapper, context) {\n var mappedSequence = makeSequence(collection);\n mappedSequence.size = collection.size;\n\n mappedSequence.has = function (key) {\n return collection.has(key);\n };\n\n mappedSequence.get = function (key, notSetValue) {\n var v = collection.get(key, NOT_SET);\n return v === NOT_SET ? notSetValue : mapper.call(context, v, key, collection);\n };\n\n mappedSequence.__iterateUncached = function (fn, reverse) {\n var this$1 = this;\n return collection.__iterate(function (v, k, c) {\n return fn(mapper.call(context, v, k, c), k, this$1) !== false;\n }, reverse);\n };\n\n mappedSequence.__iteratorUncached = function (type, reverse) {\n var iterator = collection.__iterator(ITERATE_ENTRIES, reverse);\n\n return new Iterator(function () {\n var step = iterator.next();\n\n if (step.done) {\n return step;\n }\n\n var entry = step.value;\n var key = entry[0];\n return iteratorValue(type, key, mapper.call(context, entry[1], key, collection), step);\n });\n };\n\n return mappedSequence;\n}\n\nfunction reverseFactory(collection, useKeys) {\n var this$1 = this;\n var reversedSequence = makeSequence(collection);\n reversedSequence._iter = collection;\n reversedSequence.size = collection.size;\n\n reversedSequence.reverse = function () {\n return collection;\n };\n\n if (collection.flip) {\n reversedSequence.flip = function () {\n var flipSequence = flipFactory(collection);\n\n flipSequence.reverse = function () {\n return collection.flip();\n };\n\n return flipSequence;\n };\n }\n\n reversedSequence.get = function (key, notSetValue) {\n return collection.get(useKeys ? key : -1 - key, notSetValue);\n };\n\n reversedSequence.has = function (key) {\n return collection.has(useKeys ? key : -1 - key);\n };\n\n reversedSequence.includes = function (value) {\n return collection.includes(value);\n };\n\n reversedSequence.cacheResult = cacheResultThrough;\n\n reversedSequence.__iterate = function (fn, reverse) {\n var this$1 = this;\n var i = 0;\n reverse && ensureSize(collection);\n return collection.__iterate(function (v, k) {\n return fn(v, useKeys ? k : reverse ? this$1.size - ++i : i++, this$1);\n }, !reverse);\n };\n\n reversedSequence.__iterator = function (type, reverse) {\n var i = 0;\n reverse && ensureSize(collection);\n\n var iterator = collection.__iterator(ITERATE_ENTRIES, !reverse);\n\n return new Iterator(function () {\n var step = iterator.next();\n\n if (step.done) {\n return step;\n }\n\n var entry = step.value;\n return iteratorValue(type, useKeys ? entry[0] : reverse ? this$1.size - ++i : i++, entry[1], step);\n });\n };\n\n return reversedSequence;\n}\n\nfunction filterFactory(collection, predicate, context, useKeys) {\n var filterSequence = makeSequence(collection);\n\n if (useKeys) {\n filterSequence.has = function (key) {\n var v = collection.get(key, NOT_SET);\n return v !== NOT_SET && !!predicate.call(context, v, key, collection);\n };\n\n filterSequence.get = function (key, notSetValue) {\n var v = collection.get(key, NOT_SET);\n return v !== NOT_SET && predicate.call(context, v, key, collection) ? v : notSetValue;\n };\n }\n\n filterSequence.__iterateUncached = function (fn, reverse) {\n var this$1 = this;\n var iterations = 0;\n\n collection.__iterate(function (v, k, c) {\n if (predicate.call(context, v, k, c)) {\n iterations++;\n return fn(v, useKeys ? k : iterations - 1, this$1);\n }\n }, reverse);\n\n return iterations;\n };\n\n filterSequence.__iteratorUncached = function (type, reverse) {\n var iterator = collection.__iterator(ITERATE_ENTRIES, reverse);\n\n var iterations = 0;\n return new Iterator(function () {\n while (true) {\n var step = iterator.next();\n\n if (step.done) {\n return step;\n }\n\n var entry = step.value;\n var key = entry[0];\n var value = entry[1];\n\n if (predicate.call(context, value, key, collection)) {\n return iteratorValue(type, useKeys ? key : iterations++, value, step);\n }\n }\n });\n };\n\n return filterSequence;\n}\n\nfunction countByFactory(collection, grouper, context) {\n var groups = Map().asMutable();\n\n collection.__iterate(function (v, k) {\n groups.update(grouper.call(context, v, k, collection), 0, function (a) {\n return a + 1;\n });\n });\n\n return groups.asImmutable();\n}\n\nfunction groupByFactory(collection, grouper, context) {\n var isKeyedIter = isKeyed(collection);\n var groups = (isOrdered(collection) ? OrderedMap() : Map()).asMutable();\n\n collection.__iterate(function (v, k) {\n groups.update(grouper.call(context, v, k, collection), function (a) {\n return a = a || [], a.push(isKeyedIter ? [k, v] : v), a;\n });\n });\n\n var coerce = collectionClass(collection);\n return groups.map(function (arr) {\n return reify(collection, coerce(arr));\n }).asImmutable();\n}\n\nfunction sliceFactory(collection, begin, end, useKeys) {\n var originalSize = collection.size;\n\n if (wholeSlice(begin, end, originalSize)) {\n return collection;\n }\n\n var resolvedBegin = resolveBegin(begin, originalSize);\n var resolvedEnd = resolveEnd(end, originalSize); // begin or end will be NaN if they were provided as negative numbers and\n // this collection's size is unknown. In that case, cache first so there is\n // a known size and these do not resolve to NaN.\n\n if (resolvedBegin !== resolvedBegin || resolvedEnd !== resolvedEnd) {\n return sliceFactory(collection.toSeq().cacheResult(), begin, end, useKeys);\n } // Note: resolvedEnd is undefined when the original sequence's length is\n // unknown and this slice did not supply an end and should contain all\n // elements after resolvedBegin.\n // In that case, resolvedSize will be NaN and sliceSize will remain undefined.\n\n\n var resolvedSize = resolvedEnd - resolvedBegin;\n var sliceSize;\n\n if (resolvedSize === resolvedSize) {\n sliceSize = resolvedSize < 0 ? 0 : resolvedSize;\n }\n\n var sliceSeq = makeSequence(collection); // If collection.size is undefined, the size of the realized sliceSeq is\n // unknown at this point unless the number of items to slice is 0\n\n sliceSeq.size = sliceSize === 0 ? sliceSize : collection.size && sliceSize || undefined;\n\n if (!useKeys && isSeq(collection) && sliceSize >= 0) {\n sliceSeq.get = function (index, notSetValue) {\n index = wrapIndex(this, index);\n return index >= 0 && index < sliceSize ? collection.get(index + resolvedBegin, notSetValue) : notSetValue;\n };\n }\n\n sliceSeq.__iterateUncached = function (fn, reverse) {\n var this$1 = this;\n\n if (sliceSize === 0) {\n return 0;\n }\n\n if (reverse) {\n return this.cacheResult().__iterate(fn, reverse);\n }\n\n var skipped = 0;\n var isSkipping = true;\n var iterations = 0;\n\n collection.__iterate(function (v, k) {\n if (!(isSkipping && (isSkipping = skipped++ < resolvedBegin))) {\n iterations++;\n return fn(v, useKeys ? k : iterations - 1, this$1) !== false && iterations !== sliceSize;\n }\n });\n\n return iterations;\n };\n\n sliceSeq.__iteratorUncached = function (type, reverse) {\n if (sliceSize !== 0 && reverse) {\n return this.cacheResult().__iterator(type, reverse);\n } // Don't bother instantiating parent iterator if taking 0.\n\n\n if (sliceSize === 0) {\n return new Iterator(iteratorDone);\n }\n\n var iterator = collection.__iterator(type, reverse);\n\n var skipped = 0;\n var iterations = 0;\n return new Iterator(function () {\n while (skipped++ < resolvedBegin) {\n iterator.next();\n }\n\n if (++iterations > sliceSize) {\n return iteratorDone();\n }\n\n var step = iterator.next();\n\n if (useKeys || type === ITERATE_VALUES || step.done) {\n return step;\n }\n\n if (type === ITERATE_KEYS) {\n return iteratorValue(type, iterations - 1, undefined, step);\n }\n\n return iteratorValue(type, iterations - 1, step.value[1], step);\n });\n };\n\n return sliceSeq;\n}\n\nfunction takeWhileFactory(collection, predicate, context) {\n var takeSequence = makeSequence(collection);\n\n takeSequence.__iterateUncached = function (fn, reverse) {\n var this$1 = this;\n\n if (reverse) {\n return this.cacheResult().__iterate(fn, reverse);\n }\n\n var iterations = 0;\n\n collection.__iterate(function (v, k, c) {\n return predicate.call(context, v, k, c) && ++iterations && fn(v, k, this$1);\n });\n\n return iterations;\n };\n\n takeSequence.__iteratorUncached = function (type, reverse) {\n var this$1 = this;\n\n if (reverse) {\n return this.cacheResult().__iterator(type, reverse);\n }\n\n var iterator = collection.__iterator(ITERATE_ENTRIES, reverse);\n\n var iterating = true;\n return new Iterator(function () {\n if (!iterating) {\n return iteratorDone();\n }\n\n var step = iterator.next();\n\n if (step.done) {\n return step;\n }\n\n var entry = step.value;\n var k = entry[0];\n var v = entry[1];\n\n if (!predicate.call(context, v, k, this$1)) {\n iterating = false;\n return iteratorDone();\n }\n\n return type === ITERATE_ENTRIES ? step : iteratorValue(type, k, v, step);\n });\n };\n\n return takeSequence;\n}\n\nfunction skipWhileFactory(collection, predicate, context, useKeys) {\n var skipSequence = makeSequence(collection);\n\n skipSequence.__iterateUncached = function (fn, reverse) {\n var this$1 = this;\n\n if (reverse) {\n return this.cacheResult().__iterate(fn, reverse);\n }\n\n var isSkipping = true;\n var iterations = 0;\n\n collection.__iterate(function (v, k, c) {\n if (!(isSkipping && (isSkipping = predicate.call(context, v, k, c)))) {\n iterations++;\n return fn(v, useKeys ? k : iterations - 1, this$1);\n }\n });\n\n return iterations;\n };\n\n skipSequence.__iteratorUncached = function (type, reverse) {\n var this$1 = this;\n\n if (reverse) {\n return this.cacheResult().__iterator(type, reverse);\n }\n\n var iterator = collection.__iterator(ITERATE_ENTRIES, reverse);\n\n var skipping = true;\n var iterations = 0;\n return new Iterator(function () {\n var step;\n var k;\n var v;\n\n do {\n step = iterator.next();\n\n if (step.done) {\n if (useKeys || type === ITERATE_VALUES) {\n return step;\n }\n\n if (type === ITERATE_KEYS) {\n return iteratorValue(type, iterations++, undefined, step);\n }\n\n return iteratorValue(type, iterations++, step.value[1], step);\n }\n\n var entry = step.value;\n k = entry[0];\n v = entry[1];\n skipping && (skipping = predicate.call(context, v, k, this$1));\n } while (skipping);\n\n return type === ITERATE_ENTRIES ? step : iteratorValue(type, k, v, step);\n });\n };\n\n return skipSequence;\n}\n\nfunction concatFactory(collection, values) {\n var isKeyedCollection = isKeyed(collection);\n var iters = [collection].concat(values).map(function (v) {\n if (!isCollection(v)) {\n v = isKeyedCollection ? keyedSeqFromValue(v) : indexedSeqFromValue(Array.isArray(v) ? v : [v]);\n } else if (isKeyedCollection) {\n v = KeyedCollection(v);\n }\n\n return v;\n }).filter(function (v) {\n return v.size !== 0;\n });\n\n if (iters.length === 0) {\n return collection;\n }\n\n if (iters.length === 1) {\n var singleton = iters[0];\n\n if (singleton === collection || isKeyedCollection && isKeyed(singleton) || isIndexed(collection) && isIndexed(singleton)) {\n return singleton;\n }\n }\n\n var concatSeq = new ArraySeq(iters);\n\n if (isKeyedCollection) {\n concatSeq = concatSeq.toKeyedSeq();\n } else if (!isIndexed(collection)) {\n concatSeq = concatSeq.toSetSeq();\n }\n\n concatSeq = concatSeq.flatten(true);\n concatSeq.size = iters.reduce(function (sum, seq) {\n if (sum !== undefined) {\n var size = seq.size;\n\n if (size !== undefined) {\n return sum + size;\n }\n }\n }, 0);\n return concatSeq;\n}\n\nfunction flattenFactory(collection, depth, useKeys) {\n var flatSequence = makeSequence(collection);\n\n flatSequence.__iterateUncached = function (fn, reverse) {\n if (reverse) {\n return this.cacheResult().__iterate(fn, reverse);\n }\n\n var iterations = 0;\n var stopped = false;\n\n function flatDeep(iter, currentDepth) {\n iter.__iterate(function (v, k) {\n if ((!depth || currentDepth < depth) && isCollection(v)) {\n flatDeep(v, currentDepth + 1);\n } else {\n iterations++;\n\n if (fn(v, useKeys ? k : iterations - 1, flatSequence) === false) {\n stopped = true;\n }\n }\n\n return !stopped;\n }, reverse);\n }\n\n flatDeep(collection, 0);\n return iterations;\n };\n\n flatSequence.__iteratorUncached = function (type, reverse) {\n if (reverse) {\n return this.cacheResult().__iterator(type, reverse);\n }\n\n var iterator = collection.__iterator(type, reverse);\n\n var stack = [];\n var iterations = 0;\n return new Iterator(function () {\n while (iterator) {\n var step = iterator.next();\n\n if (step.done !== false) {\n iterator = stack.pop();\n continue;\n }\n\n var v = step.value;\n\n if (type === ITERATE_ENTRIES) {\n v = v[1];\n }\n\n if ((!depth || stack.length < depth) && isCollection(v)) {\n stack.push(iterator);\n iterator = v.__iterator(type, reverse);\n } else {\n return useKeys ? step : iteratorValue(type, iterations++, v, step);\n }\n }\n\n return iteratorDone();\n });\n };\n\n return flatSequence;\n}\n\nfunction flatMapFactory(collection, mapper, context) {\n var coerce = collectionClass(collection);\n return collection.toSeq().map(function (v, k) {\n return coerce(mapper.call(context, v, k, collection));\n }).flatten(true);\n}\n\nfunction interposeFactory(collection, separator) {\n var interposedSequence = makeSequence(collection);\n interposedSequence.size = collection.size && collection.size * 2 - 1;\n\n interposedSequence.__iterateUncached = function (fn, reverse) {\n var this$1 = this;\n var iterations = 0;\n\n collection.__iterate(function (v) {\n return (!iterations || fn(separator, iterations++, this$1) !== false) && fn(v, iterations++, this$1) !== false;\n }, reverse);\n\n return iterations;\n };\n\n interposedSequence.__iteratorUncached = function (type, reverse) {\n var iterator = collection.__iterator(ITERATE_VALUES, reverse);\n\n var iterations = 0;\n var step;\n return new Iterator(function () {\n if (!step || iterations % 2) {\n step = iterator.next();\n\n if (step.done) {\n return step;\n }\n }\n\n return iterations % 2 ? iteratorValue(type, iterations++, separator) : iteratorValue(type, iterations++, step.value, step);\n });\n };\n\n return interposedSequence;\n}\n\nfunction sortFactory(collection, comparator, mapper) {\n if (!comparator) {\n comparator = defaultComparator;\n }\n\n var isKeyedCollection = isKeyed(collection);\n var index = 0;\n var entries = collection.toSeq().map(function (v, k) {\n return [k, v, index++, mapper ? mapper(v, k, collection) : v];\n }).valueSeq().toArray();\n entries.sort(function (a, b) {\n return comparator(a[3], b[3]) || a[2] - b[2];\n }).forEach(isKeyedCollection ? function (v, i) {\n entries[i].length = 2;\n } : function (v, i) {\n entries[i] = v[1];\n });\n return isKeyedCollection ? KeyedSeq(entries) : isIndexed(collection) ? IndexedSeq(entries) : SetSeq(entries);\n}\n\nfunction maxFactory(collection, comparator, mapper) {\n if (!comparator) {\n comparator = defaultComparator;\n }\n\n if (mapper) {\n var entry = collection.toSeq().map(function (v, k) {\n return [v, mapper(v, k, collection)];\n }).reduce(function (a, b) {\n return maxCompare(comparator, a[1], b[1]) ? b : a;\n });\n return entry && entry[0];\n }\n\n return collection.reduce(function (a, b) {\n return maxCompare(comparator, a, b) ? b : a;\n });\n}\n\nfunction maxCompare(comparator, a, b) {\n var comp = comparator(b, a); // b is considered the new max if the comparator declares them equal, but\n // they are not equal and b is in fact a nullish value.\n\n return comp === 0 && b !== a && (b === undefined || b === null || b !== b) || comp > 0;\n}\n\nfunction zipWithFactory(keyIter, zipper, iters, zipAll) {\n var zipSequence = makeSequence(keyIter);\n var sizes = new ArraySeq(iters).map(function (i) {\n return i.size;\n });\n zipSequence.size = zipAll ? sizes.max() : sizes.min(); // Note: this a generic base implementation of __iterate in terms of\n // __iterator which may be more generically useful in the future.\n\n zipSequence.__iterate = function (fn, reverse) {\n /* generic:\n var iterator = this.__iterator(ITERATE_ENTRIES, reverse);\n var step;\n var iterations = 0;\n while (!(step = iterator.next()).done) {\n iterations++;\n if (fn(step.value[1], step.value[0], this) === false) {\n break;\n }\n }\n return iterations;\n */\n // indexed:\n var iterator = this.__iterator(ITERATE_VALUES, reverse);\n\n var step;\n var iterations = 0;\n\n while (!(step = iterator.next()).done) {\n if (fn(step.value, iterations++, this) === false) {\n break;\n }\n }\n\n return iterations;\n };\n\n zipSequence.__iteratorUncached = function (type, reverse) {\n var iterators = iters.map(function (i) {\n return i = Collection(i), getIterator(reverse ? i.reverse() : i);\n });\n var iterations = 0;\n var isDone = false;\n return new Iterator(function () {\n var steps;\n\n if (!isDone) {\n steps = iterators.map(function (i) {\n return i.next();\n });\n isDone = zipAll ? steps.every(function (s) {\n return s.done;\n }) : steps.some(function (s) {\n return s.done;\n });\n }\n\n if (isDone) {\n return iteratorDone();\n }\n\n return iteratorValue(type, iterations++, zipper.apply(null, steps.map(function (s) {\n return s.value;\n })));\n });\n };\n\n return zipSequence;\n} // #pragma Helper Functions\n\n\nfunction reify(iter, seq) {\n return iter === seq ? iter : isSeq(iter) ? seq : iter.constructor(seq);\n}\n\nfunction validateEntry(entry) {\n if (entry !== Object(entry)) {\n throw new TypeError('Expected [K, V] tuple: ' + entry);\n }\n}\n\nfunction collectionClass(collection) {\n return isKeyed(collection) ? KeyedCollection : isIndexed(collection) ? IndexedCollection : SetCollection;\n}\n\nfunction makeSequence(collection) {\n return Object.create((isKeyed(collection) ? KeyedSeq : isIndexed(collection) ? IndexedSeq : SetSeq).prototype);\n}\n\nfunction cacheResultThrough() {\n if (this._iter.cacheResult) {\n this._iter.cacheResult();\n\n this.size = this._iter.size;\n return this;\n }\n\n return Seq.prototype.cacheResult.call(this);\n}\n\nfunction defaultComparator(a, b) {\n if (a === undefined && b === undefined) {\n return 0;\n }\n\n if (a === undefined) {\n return 1;\n }\n\n if (b === undefined) {\n return -1;\n }\n\n return a > b ? 1 : a < b ? -1 : 0;\n} // http://jsperf.com/copy-array-inline\n\n\nfunction arrCopy(arr, offset) {\n offset = offset || 0;\n var len = Math.max(0, arr.length - offset);\n var newArr = new Array(len);\n\n for (var ii = 0; ii < len; ii++) {\n newArr[ii] = arr[ii + offset];\n }\n\n return newArr;\n}\n\nfunction invariant(condition, error) {\n if (!condition) {\n throw new Error(error);\n }\n}\n\nfunction assertNotInfinite(size) {\n invariant(size !== Infinity, 'Cannot perform this action with an infinite size.');\n}\n\nfunction coerceKeyPath(keyPath) {\n if (isArrayLike(keyPath) && typeof keyPath !== 'string') {\n return keyPath;\n }\n\n if (isOrdered(keyPath)) {\n return keyPath.toArray();\n }\n\n throw new TypeError('Invalid keyPath: expected Ordered Collection or Array: ' + keyPath);\n}\n\nfunction isPlainObj(value) {\n return value && (typeof value.constructor !== 'function' || value.constructor.name === 'Object');\n}\n/**\n * Returns true if the value is a potentially-persistent data structure, either\n * provided by Immutable.js or a plain Array or Object.\n */\n\n\nfunction isDataStructure(value) {\n return typeof value === 'object' && (isImmutable(value) || Array.isArray(value) || isPlainObj(value));\n}\n/**\n * Converts a value to a string, adding quotes if a string was provided.\n */\n\n\nfunction quoteString(value) {\n try {\n return typeof value === 'string' ? JSON.stringify(value) : String(value);\n } catch (_ignoreError) {\n return JSON.stringify(value);\n }\n}\n\nfunction has(collection, key) {\n return isImmutable(collection) ? collection.has(key) : isDataStructure(collection) && hasOwnProperty.call(collection, key);\n}\n\nfunction get(collection, key, notSetValue) {\n return isImmutable(collection) ? collection.get(key, notSetValue) : !has(collection, key) ? notSetValue : typeof collection.get === 'function' ? collection.get(key) : collection[key];\n}\n\nfunction shallowCopy(from) {\n if (Array.isArray(from)) {\n return arrCopy(from);\n }\n\n var to = {};\n\n for (var key in from) {\n if (hasOwnProperty.call(from, key)) {\n to[key] = from[key];\n }\n }\n\n return to;\n}\n\nfunction remove(collection, key) {\n if (!isDataStructure(collection)) {\n throw new TypeError('Cannot update non-data-structure value: ' + collection);\n }\n\n if (isImmutable(collection)) {\n if (!collection.remove) {\n throw new TypeError('Cannot update immutable value without .remove() method: ' + collection);\n }\n\n return collection.remove(key);\n }\n\n if (!hasOwnProperty.call(collection, key)) {\n return collection;\n }\n\n var collectionCopy = shallowCopy(collection);\n\n if (Array.isArray(collectionCopy)) {\n collectionCopy.splice(key, 1);\n } else {\n delete collectionCopy[key];\n }\n\n return collectionCopy;\n}\n\nfunction set(collection, key, value) {\n if (!isDataStructure(collection)) {\n throw new TypeError('Cannot update non-data-structure value: ' + collection);\n }\n\n if (isImmutable(collection)) {\n if (!collection.set) {\n throw new TypeError('Cannot update immutable value without .set() method: ' + collection);\n }\n\n return collection.set(key, value);\n }\n\n if (hasOwnProperty.call(collection, key) && value === collection[key]) {\n return collection;\n }\n\n var collectionCopy = shallowCopy(collection);\n collectionCopy[key] = value;\n return collectionCopy;\n}\n\nfunction updateIn(collection, keyPath, notSetValue, updater) {\n if (!updater) {\n updater = notSetValue;\n notSetValue = undefined;\n }\n\n var updatedValue = updateInDeeply(isImmutable(collection), collection, coerceKeyPath(keyPath), 0, notSetValue, updater);\n return updatedValue === NOT_SET ? notSetValue : updatedValue;\n}\n\nfunction updateInDeeply(inImmutable, existing, keyPath, i, notSetValue, updater) {\n var wasNotSet = existing === NOT_SET;\n\n if (i === keyPath.length) {\n var existingValue = wasNotSet ? notSetValue : existing;\n var newValue = updater(existingValue);\n return newValue === existingValue ? existing : newValue;\n }\n\n if (!wasNotSet && !isDataStructure(existing)) {\n throw new TypeError('Cannot update within non-data-structure value in path [' + keyPath.slice(0, i).map(quoteString) + ']: ' + existing);\n }\n\n var key = keyPath[i];\n var nextExisting = wasNotSet ? NOT_SET : get(existing, key, NOT_SET);\n var nextUpdated = updateInDeeply(nextExisting === NOT_SET ? inImmutable : isImmutable(nextExisting), nextExisting, keyPath, i + 1, notSetValue, updater);\n return nextUpdated === nextExisting ? existing : nextUpdated === NOT_SET ? remove(existing, key) : set(wasNotSet ? inImmutable ? emptyMap() : {} : existing, key, nextUpdated);\n}\n\nfunction setIn(collection, keyPath, value) {\n return updateIn(collection, keyPath, NOT_SET, function () {\n return value;\n });\n}\n\nfunction setIn$1(keyPath, v) {\n return setIn(this, keyPath, v);\n}\n\nfunction removeIn(collection, keyPath) {\n return updateIn(collection, keyPath, function () {\n return NOT_SET;\n });\n}\n\nfunction deleteIn(keyPath) {\n return removeIn(this, keyPath);\n}\n\nfunction update(collection, key, notSetValue, updater) {\n return updateIn(collection, [key], notSetValue, updater);\n}\n\nfunction update$1(key, notSetValue, updater) {\n return arguments.length === 1 ? key(this) : update(this, key, notSetValue, updater);\n}\n\nfunction updateIn$1(keyPath, notSetValue, updater) {\n return updateIn(this, keyPath, notSetValue, updater);\n}\n\nfunction merge() {\n var iters = [],\n len = arguments.length;\n\n while (len--) {\n iters[len] = arguments[len];\n }\n\n return mergeIntoKeyedWith(this, iters);\n}\n\nfunction mergeWith(merger) {\n var iters = [],\n len = arguments.length - 1;\n\n while (len-- > 0) {\n iters[len] = arguments[len + 1];\n }\n\n if (typeof merger !== 'function') {\n throw new TypeError('Invalid merger function: ' + merger);\n }\n\n return mergeIntoKeyedWith(this, iters, merger);\n}\n\nfunction mergeIntoKeyedWith(collection, collections, merger) {\n var iters = [];\n\n for (var ii = 0; ii < collections.length; ii++) {\n var collection$1 = KeyedCollection(collections[ii]);\n\n if (collection$1.size !== 0) {\n iters.push(collection$1);\n }\n }\n\n if (iters.length === 0) {\n return collection;\n }\n\n if (collection.toSeq().size === 0 && !collection.__ownerID && iters.length === 1) {\n return collection.constructor(iters[0]);\n }\n\n return collection.withMutations(function (collection) {\n var mergeIntoCollection = merger ? function (value, key) {\n update(collection, key, NOT_SET, function (oldVal) {\n return oldVal === NOT_SET ? value : merger(oldVal, value, key);\n });\n } : function (value, key) {\n collection.set(key, value);\n };\n\n for (var ii = 0; ii < iters.length; ii++) {\n iters[ii].forEach(mergeIntoCollection);\n }\n });\n}\n\nfunction merge$1(collection) {\n var sources = [],\n len = arguments.length - 1;\n\n while (len-- > 0) {\n sources[len] = arguments[len + 1];\n }\n\n return mergeWithSources(collection, sources);\n}\n\nfunction mergeWith$1(merger, collection) {\n var sources = [],\n len = arguments.length - 2;\n\n while (len-- > 0) {\n sources[len] = arguments[len + 2];\n }\n\n return mergeWithSources(collection, sources, merger);\n}\n\nfunction mergeDeep(collection) {\n var sources = [],\n len = arguments.length - 1;\n\n while (len-- > 0) {\n sources[len] = arguments[len + 1];\n }\n\n return mergeDeepWithSources(collection, sources);\n}\n\nfunction mergeDeepWith(merger, collection) {\n var sources = [],\n len = arguments.length - 2;\n\n while (len-- > 0) {\n sources[len] = arguments[len + 2];\n }\n\n return mergeDeepWithSources(collection, sources, merger);\n}\n\nfunction mergeDeepWithSources(collection, sources, merger) {\n return mergeWithSources(collection, sources, deepMergerWith(merger));\n}\n\nfunction mergeWithSources(collection, sources, merger) {\n if (!isDataStructure(collection)) {\n throw new TypeError('Cannot merge into non-data-structure value: ' + collection);\n }\n\n if (isImmutable(collection)) {\n return typeof merger === 'function' && collection.mergeWith ? collection.mergeWith.apply(collection, [merger].concat(sources)) : collection.merge ? collection.merge.apply(collection, sources) : collection.concat.apply(collection, sources);\n }\n\n var isArray = Array.isArray(collection);\n var merged = collection;\n var Collection$$1 = isArray ? IndexedCollection : KeyedCollection;\n var mergeItem = isArray ? function (value) {\n // Copy on write\n if (merged === collection) {\n merged = shallowCopy(merged);\n }\n\n merged.push(value);\n } : function (value, key) {\n var hasVal = hasOwnProperty.call(merged, key);\n var nextVal = hasVal && merger ? merger(merged[key], value, key) : value;\n\n if (!hasVal || nextVal !== merged[key]) {\n // Copy on write\n if (merged === collection) {\n merged = shallowCopy(merged);\n }\n\n merged[key] = nextVal;\n }\n };\n\n for (var i = 0; i < sources.length; i++) {\n Collection$$1(sources[i]).forEach(mergeItem);\n }\n\n return merged;\n}\n\nfunction deepMergerWith(merger) {\n function deepMerger(oldValue, newValue, key) {\n return isDataStructure(oldValue) && isDataStructure(newValue) ? mergeWithSources(oldValue, [newValue], deepMerger) : merger ? merger(oldValue, newValue, key) : newValue;\n }\n\n return deepMerger;\n}\n\nfunction mergeDeep$1() {\n var iters = [],\n len = arguments.length;\n\n while (len--) {\n iters[len] = arguments[len];\n }\n\n return mergeDeepWithSources(this, iters);\n}\n\nfunction mergeDeepWith$1(merger) {\n var iters = [],\n len = arguments.length - 1;\n\n while (len-- > 0) {\n iters[len] = arguments[len + 1];\n }\n\n return mergeDeepWithSources(this, iters, merger);\n}\n\nfunction mergeIn(keyPath) {\n var iters = [],\n len = arguments.length - 1;\n\n while (len-- > 0) {\n iters[len] = arguments[len + 1];\n }\n\n return updateIn(this, keyPath, emptyMap(), function (m) {\n return mergeWithSources(m, iters);\n });\n}\n\nfunction mergeDeepIn(keyPath) {\n var iters = [],\n len = arguments.length - 1;\n\n while (len-- > 0) {\n iters[len] = arguments[len + 1];\n }\n\n return updateIn(this, keyPath, emptyMap(), function (m) {\n return mergeDeepWithSources(m, iters);\n });\n}\n\nfunction withMutations(fn) {\n var mutable = this.asMutable();\n fn(mutable);\n return mutable.wasAltered() ? mutable.__ensureOwner(this.__ownerID) : this;\n}\n\nfunction asMutable() {\n return this.__ownerID ? this : this.__ensureOwner(new OwnerID());\n}\n\nfunction asImmutable() {\n return this.__ensureOwner();\n}\n\nfunction wasAltered() {\n return this.__altered;\n}\n\nvar Map =\n/*@__PURE__*/\nfunction (KeyedCollection$$1) {\n function Map(value) {\n return value === null || value === undefined ? emptyMap() : isMap(value) && !isOrdered(value) ? value : emptyMap().withMutations(function (map) {\n var iter = KeyedCollection$$1(value);\n assertNotInfinite(iter.size);\n iter.forEach(function (v, k) {\n return map.set(k, v);\n });\n });\n }\n\n if (KeyedCollection$$1) Map.__proto__ = KeyedCollection$$1;\n Map.prototype = Object.create(KeyedCollection$$1 && KeyedCollection$$1.prototype);\n Map.prototype.constructor = Map;\n\n Map.of = function of() {\n var keyValues = [],\n len = arguments.length;\n\n while (len--) {\n keyValues[len] = arguments[len];\n }\n\n return emptyMap().withMutations(function (map) {\n for (var i = 0; i < keyValues.length; i += 2) {\n if (i + 1 >= keyValues.length) {\n throw new Error('Missing value for key: ' + keyValues[i]);\n }\n\n map.set(keyValues[i], keyValues[i + 1]);\n }\n });\n };\n\n Map.prototype.toString = function toString() {\n return this.__toString('Map {', '}');\n }; // @pragma Access\n\n\n Map.prototype.get = function get(k, notSetValue) {\n return this._root ? this._root.get(0, undefined, k, notSetValue) : notSetValue;\n }; // @pragma Modification\n\n\n Map.prototype.set = function set(k, v) {\n return updateMap(this, k, v);\n };\n\n Map.prototype.remove = function remove(k) {\n return updateMap(this, k, NOT_SET);\n };\n\n Map.prototype.deleteAll = function deleteAll(keys) {\n var collection = Collection(keys);\n\n if (collection.size === 0) {\n return this;\n }\n\n return this.withMutations(function (map) {\n collection.forEach(function (key) {\n return map.remove(key);\n });\n });\n };\n\n Map.prototype.clear = function clear() {\n if (this.size === 0) {\n return this;\n }\n\n if (this.__ownerID) {\n this.size = 0;\n this._root = null;\n this.__hash = undefined;\n this.__altered = true;\n return this;\n }\n\n return emptyMap();\n }; // @pragma Composition\n\n\n Map.prototype.sort = function sort(comparator) {\n // Late binding\n return OrderedMap(sortFactory(this, comparator));\n };\n\n Map.prototype.sortBy = function sortBy(mapper, comparator) {\n // Late binding\n return OrderedMap(sortFactory(this, comparator, mapper));\n };\n\n Map.prototype.map = function map(mapper, context) {\n return this.withMutations(function (map) {\n map.forEach(function (value, key) {\n map.set(key, mapper.call(context, value, key, map));\n });\n });\n }; // @pragma Mutability\n\n\n Map.prototype.__iterator = function __iterator(type, reverse) {\n return new MapIterator(this, type, reverse);\n };\n\n Map.prototype.__iterate = function __iterate(fn, reverse) {\n var this$1 = this;\n var iterations = 0;\n this._root && this._root.iterate(function (entry) {\n iterations++;\n return fn(entry[1], entry[0], this$1);\n }, reverse);\n return iterations;\n };\n\n Map.prototype.__ensureOwner = function __ensureOwner(ownerID) {\n if (ownerID === this.__ownerID) {\n return this;\n }\n\n if (!ownerID) {\n if (this.size === 0) {\n return emptyMap();\n }\n\n this.__ownerID = ownerID;\n this.__altered = false;\n return this;\n }\n\n return makeMap(this.size, this._root, ownerID, this.__hash);\n };\n\n return Map;\n}(KeyedCollection);\n\nMap.isMap = isMap;\nvar MapPrototype = Map.prototype;\nMapPrototype[IS_MAP_SYMBOL] = true;\nMapPrototype[DELETE] = MapPrototype.remove;\nMapPrototype.removeAll = MapPrototype.deleteAll;\nMapPrototype.setIn = setIn$1;\nMapPrototype.removeIn = MapPrototype.deleteIn = deleteIn;\nMapPrototype.update = update$1;\nMapPrototype.updateIn = updateIn$1;\nMapPrototype.merge = MapPrototype.concat = merge;\nMapPrototype.mergeWith = mergeWith;\nMapPrototype.mergeDeep = mergeDeep$1;\nMapPrototype.mergeDeepWith = mergeDeepWith$1;\nMapPrototype.mergeIn = mergeIn;\nMapPrototype.mergeDeepIn = mergeDeepIn;\nMapPrototype.withMutations = withMutations;\nMapPrototype.wasAltered = wasAltered;\nMapPrototype.asImmutable = asImmutable;\nMapPrototype['@@transducer/init'] = MapPrototype.asMutable = asMutable;\n\nMapPrototype['@@transducer/step'] = function (result, arr) {\n return result.set(arr[0], arr[1]);\n};\n\nMapPrototype['@@transducer/result'] = function (obj) {\n return obj.asImmutable();\n}; // #pragma Trie Nodes\n\n\nvar ArrayMapNode = function ArrayMapNode(ownerID, entries) {\n this.ownerID = ownerID;\n this.entries = entries;\n};\n\nArrayMapNode.prototype.get = function get(shift, keyHash, key, notSetValue) {\n var entries = this.entries;\n\n for (var ii = 0, len = entries.length; ii < len; ii++) {\n if (is(key, entries[ii][0])) {\n return entries[ii][1];\n }\n }\n\n return notSetValue;\n};\n\nArrayMapNode.prototype.update = function update(ownerID, shift, keyHash, key, value, didChangeSize, didAlter) {\n var removed = value === NOT_SET;\n var entries = this.entries;\n var idx = 0;\n var len = entries.length;\n\n for (; idx < len; idx++) {\n if (is(key, entries[idx][0])) {\n break;\n }\n }\n\n var exists = idx < len;\n\n if (exists ? entries[idx][1] === value : removed) {\n return this;\n }\n\n SetRef(didAlter);\n (removed || !exists) && SetRef(didChangeSize);\n\n if (removed && entries.length === 1) {\n return; // undefined\n }\n\n if (!exists && !removed && entries.length >= MAX_ARRAY_MAP_SIZE) {\n return createNodes(ownerID, entries, key, value);\n }\n\n var isEditable = ownerID && ownerID === this.ownerID;\n var newEntries = isEditable ? entries : arrCopy(entries);\n\n if (exists) {\n if (removed) {\n idx === len - 1 ? newEntries.pop() : newEntries[idx] = newEntries.pop();\n } else {\n newEntries[idx] = [key, value];\n }\n } else {\n newEntries.push([key, value]);\n }\n\n if (isEditable) {\n this.entries = newEntries;\n return this;\n }\n\n return new ArrayMapNode(ownerID, newEntries);\n};\n\nvar BitmapIndexedNode = function BitmapIndexedNode(ownerID, bitmap, nodes) {\n this.ownerID = ownerID;\n this.bitmap = bitmap;\n this.nodes = nodes;\n};\n\nBitmapIndexedNode.prototype.get = function get(shift, keyHash, key, notSetValue) {\n if (keyHash === undefined) {\n keyHash = hash(key);\n }\n\n var bit = 1 << ((shift === 0 ? keyHash : keyHash >>> shift) & MASK);\n var bitmap = this.bitmap;\n return (bitmap & bit) === 0 ? notSetValue : this.nodes[popCount(bitmap & bit - 1)].get(shift + SHIFT, keyHash, key, notSetValue);\n};\n\nBitmapIndexedNode.prototype.update = function update(ownerID, shift, keyHash, key, value, didChangeSize, didAlter) {\n if (keyHash === undefined) {\n keyHash = hash(key);\n }\n\n var keyHashFrag = (shift === 0 ? keyHash : keyHash >>> shift) & MASK;\n var bit = 1 << keyHashFrag;\n var bitmap = this.bitmap;\n var exists = (bitmap & bit) !== 0;\n\n if (!exists && value === NOT_SET) {\n return this;\n }\n\n var idx = popCount(bitmap & bit - 1);\n var nodes = this.nodes;\n var node = exists ? nodes[idx] : undefined;\n var newNode = updateNode(node, ownerID, shift + SHIFT, keyHash, key, value, didChangeSize, didAlter);\n\n if (newNode === node) {\n return this;\n }\n\n if (!exists && newNode && nodes.length >= MAX_BITMAP_INDEXED_SIZE) {\n return expandNodes(ownerID, nodes, bitmap, keyHashFrag, newNode);\n }\n\n if (exists && !newNode && nodes.length === 2 && isLeafNode(nodes[idx ^ 1])) {\n return nodes[idx ^ 1];\n }\n\n if (exists && newNode && nodes.length === 1 && isLeafNode(newNode)) {\n return newNode;\n }\n\n var isEditable = ownerID && ownerID === this.ownerID;\n var newBitmap = exists ? newNode ? bitmap : bitmap ^ bit : bitmap | bit;\n var newNodes = exists ? newNode ? setAt(nodes, idx, newNode, isEditable) : spliceOut(nodes, idx, isEditable) : spliceIn(nodes, idx, newNode, isEditable);\n\n if (isEditable) {\n this.bitmap = newBitmap;\n this.nodes = newNodes;\n return this;\n }\n\n return new BitmapIndexedNode(ownerID, newBitmap, newNodes);\n};\n\nvar HashArrayMapNode = function HashArrayMapNode(ownerID, count, nodes) {\n this.ownerID = ownerID;\n this.count = count;\n this.nodes = nodes;\n};\n\nHashArrayMapNode.prototype.get = function get(shift, keyHash, key, notSetValue) {\n if (keyHash === undefined) {\n keyHash = hash(key);\n }\n\n var idx = (shift === 0 ? keyHash : keyHash >>> shift) & MASK;\n var node = this.nodes[idx];\n return node ? node.get(shift + SHIFT, keyHash, key, notSetValue) : notSetValue;\n};\n\nHashArrayMapNode.prototype.update = function update(ownerID, shift, keyHash, key, value, didChangeSize, didAlter) {\n if (keyHash === undefined) {\n keyHash = hash(key);\n }\n\n var idx = (shift === 0 ? keyHash : keyHash >>> shift) & MASK;\n var removed = value === NOT_SET;\n var nodes = this.nodes;\n var node = nodes[idx];\n\n if (removed && !node) {\n return this;\n }\n\n var newNode = updateNode(node, ownerID, shift + SHIFT, keyHash, key, value, didChangeSize, didAlter);\n\n if (newNode === node) {\n return this;\n }\n\n var newCount = this.count;\n\n if (!node) {\n newCount++;\n } else if (!newNode) {\n newCount--;\n\n if (newCount < MIN_HASH_ARRAY_MAP_SIZE) {\n return packNodes(ownerID, nodes, newCount, idx);\n }\n }\n\n var isEditable = ownerID && ownerID === this.ownerID;\n var newNodes = setAt(nodes, idx, newNode, isEditable);\n\n if (isEditable) {\n this.count = newCount;\n this.nodes = newNodes;\n return this;\n }\n\n return new HashArrayMapNode(ownerID, newCount, newNodes);\n};\n\nvar HashCollisionNode = function HashCollisionNode(ownerID, keyHash, entries) {\n this.ownerID = ownerID;\n this.keyHash = keyHash;\n this.entries = entries;\n};\n\nHashCollisionNode.prototype.get = function get(shift, keyHash, key, notSetValue) {\n var entries = this.entries;\n\n for (var ii = 0, len = entries.length; ii < len; ii++) {\n if (is(key, entries[ii][0])) {\n return entries[ii][1];\n }\n }\n\n return notSetValue;\n};\n\nHashCollisionNode.prototype.update = function update(ownerID, shift, keyHash, key, value, didChangeSize, didAlter) {\n if (keyHash === undefined) {\n keyHash = hash(key);\n }\n\n var removed = value === NOT_SET;\n\n if (keyHash !== this.keyHash) {\n if (removed) {\n return this;\n }\n\n SetRef(didAlter);\n SetRef(didChangeSize);\n return mergeIntoNode(this, ownerID, shift, keyHash, [key, value]);\n }\n\n var entries = this.entries;\n var idx = 0;\n var len = entries.length;\n\n for (; idx < len; idx++) {\n if (is(key, entries[idx][0])) {\n break;\n }\n }\n\n var exists = idx < len;\n\n if (exists ? entries[idx][1] === value : removed) {\n return this;\n }\n\n SetRef(didAlter);\n (removed || !exists) && SetRef(didChangeSize);\n\n if (removed && len === 2) {\n return new ValueNode(ownerID, this.keyHash, entries[idx ^ 1]);\n }\n\n var isEditable = ownerID && ownerID === this.ownerID;\n var newEntries = isEditable ? entries : arrCopy(entries);\n\n if (exists) {\n if (removed) {\n idx === len - 1 ? newEntries.pop() : newEntries[idx] = newEntries.pop();\n } else {\n newEntries[idx] = [key, value];\n }\n } else {\n newEntries.push([key, value]);\n }\n\n if (isEditable) {\n this.entries = newEntries;\n return this;\n }\n\n return new HashCollisionNode(ownerID, this.keyHash, newEntries);\n};\n\nvar ValueNode = function ValueNode(ownerID, keyHash, entry) {\n this.ownerID = ownerID;\n this.keyHash = keyHash;\n this.entry = entry;\n};\n\nValueNode.prototype.get = function get(shift, keyHash, key, notSetValue) {\n return is(key, this.entry[0]) ? this.entry[1] : notSetValue;\n};\n\nValueNode.prototype.update = function update(ownerID, shift, keyHash, key, value, didChangeSize, didAlter) {\n var removed = value === NOT_SET;\n var keyMatch = is(key, this.entry[0]);\n\n if (keyMatch ? value === this.entry[1] : removed) {\n return this;\n }\n\n SetRef(didAlter);\n\n if (removed) {\n SetRef(didChangeSize);\n return; // undefined\n }\n\n if (keyMatch) {\n if (ownerID && ownerID === this.ownerID) {\n this.entry[1] = value;\n return this;\n }\n\n return new ValueNode(ownerID, this.keyHash, [key, value]);\n }\n\n SetRef(didChangeSize);\n return mergeIntoNode(this, ownerID, shift, hash(key), [key, value]);\n}; // #pragma Iterators\n\n\nArrayMapNode.prototype.iterate = HashCollisionNode.prototype.iterate = function (fn, reverse) {\n var entries = this.entries;\n\n for (var ii = 0, maxIndex = entries.length - 1; ii <= maxIndex; ii++) {\n if (fn(entries[reverse ? maxIndex - ii : ii]) === false) {\n return false;\n }\n }\n};\n\nBitmapIndexedNode.prototype.iterate = HashArrayMapNode.prototype.iterate = function (fn, reverse) {\n var nodes = this.nodes;\n\n for (var ii = 0, maxIndex = nodes.length - 1; ii <= maxIndex; ii++) {\n var node = nodes[reverse ? maxIndex - ii : ii];\n\n if (node && node.iterate(fn, reverse) === false) {\n return false;\n }\n }\n}; // eslint-disable-next-line no-unused-vars\n\n\nValueNode.prototype.iterate = function (fn, reverse) {\n return fn(this.entry);\n};\n\nvar MapIterator =\n/*@__PURE__*/\nfunction (Iterator$$1) {\n function MapIterator(map, type, reverse) {\n this._type = type;\n this._reverse = reverse;\n this._stack = map._root && mapIteratorFrame(map._root);\n }\n\n if (Iterator$$1) MapIterator.__proto__ = Iterator$$1;\n MapIterator.prototype = Object.create(Iterator$$1 && Iterator$$1.prototype);\n MapIterator.prototype.constructor = MapIterator;\n\n MapIterator.prototype.next = function next() {\n var type = this._type;\n var stack = this._stack;\n\n while (stack) {\n var node = stack.node;\n var index = stack.index++;\n var maxIndex = void 0;\n\n if (node.entry) {\n if (index === 0) {\n return mapIteratorValue(type, node.entry);\n }\n } else if (node.entries) {\n maxIndex = node.entries.length - 1;\n\n if (index <= maxIndex) {\n return mapIteratorValue(type, node.entries[this._reverse ? maxIndex - index : index]);\n }\n } else {\n maxIndex = node.nodes.length - 1;\n\n if (index <= maxIndex) {\n var subNode = node.nodes[this._reverse ? maxIndex - index : index];\n\n if (subNode) {\n if (subNode.entry) {\n return mapIteratorValue(type, subNode.entry);\n }\n\n stack = this._stack = mapIteratorFrame(subNode, stack);\n }\n\n continue;\n }\n }\n\n stack = this._stack = this._stack.__prev;\n }\n\n return iteratorDone();\n };\n\n return MapIterator;\n}(Iterator);\n\nfunction mapIteratorValue(type, entry) {\n return iteratorValue(type, entry[0], entry[1]);\n}\n\nfunction mapIteratorFrame(node, prev) {\n return {\n node: node,\n index: 0,\n __prev: prev\n };\n}\n\nfunction makeMap(size, root, ownerID, hash$$1) {\n var map = Object.create(MapPrototype);\n map.size = size;\n map._root = root;\n map.__ownerID = ownerID;\n map.__hash = hash$$1;\n map.__altered = false;\n return map;\n}\n\nvar EMPTY_MAP;\n\nfunction emptyMap() {\n return EMPTY_MAP || (EMPTY_MAP = makeMap(0));\n}\n\nfunction updateMap(map, k, v) {\n var newRoot;\n var newSize;\n\n if (!map._root) {\n if (v === NOT_SET) {\n return map;\n }\n\n newSize = 1;\n newRoot = new ArrayMapNode(map.__ownerID, [[k, v]]);\n } else {\n var didChangeSize = MakeRef();\n var didAlter = MakeRef();\n newRoot = updateNode(map._root, map.__ownerID, 0, undefined, k, v, didChangeSize, didAlter);\n\n if (!didAlter.value) {\n return map;\n }\n\n newSize = map.size + (didChangeSize.value ? v === NOT_SET ? -1 : 1 : 0);\n }\n\n if (map.__ownerID) {\n map.size = newSize;\n map._root = newRoot;\n map.__hash = undefined;\n map.__altered = true;\n return map;\n }\n\n return newRoot ? makeMap(newSize, newRoot) : emptyMap();\n}\n\nfunction updateNode(node, ownerID, shift, keyHash, key, value, didChangeSize, didAlter) {\n if (!node) {\n if (value === NOT_SET) {\n return node;\n }\n\n SetRef(didAlter);\n SetRef(didChangeSize);\n return new ValueNode(ownerID, keyHash, [key, value]);\n }\n\n return node.update(ownerID, shift, keyHash, key, value, didChangeSize, didAlter);\n}\n\nfunction isLeafNode(node) {\n return node.constructor === ValueNode || node.constructor === HashCollisionNode;\n}\n\nfunction mergeIntoNode(node, ownerID, shift, keyHash, entry) {\n if (node.keyHash === keyHash) {\n return new HashCollisionNode(ownerID, keyHash, [node.entry, entry]);\n }\n\n var idx1 = (shift === 0 ? node.keyHash : node.keyHash >>> shift) & MASK;\n var idx2 = (shift === 0 ? keyHash : keyHash >>> shift) & MASK;\n var newNode;\n var nodes = idx1 === idx2 ? [mergeIntoNode(node, ownerID, shift + SHIFT, keyHash, entry)] : (newNode = new ValueNode(ownerID, keyHash, entry), idx1 < idx2 ? [node, newNode] : [newNode, node]);\n return new BitmapIndexedNode(ownerID, 1 << idx1 | 1 << idx2, nodes);\n}\n\nfunction createNodes(ownerID, entries, key, value) {\n if (!ownerID) {\n ownerID = new OwnerID();\n }\n\n var node = new ValueNode(ownerID, hash(key), [key, value]);\n\n for (var ii = 0; ii < entries.length; ii++) {\n var entry = entries[ii];\n node = node.update(ownerID, 0, undefined, entry[0], entry[1]);\n }\n\n return node;\n}\n\nfunction packNodes(ownerID, nodes, count, excluding) {\n var bitmap = 0;\n var packedII = 0;\n var packedNodes = new Array(count);\n\n for (var ii = 0, bit = 1, len = nodes.length; ii < len; ii++, bit <<= 1) {\n var node = nodes[ii];\n\n if (node !== undefined && ii !== excluding) {\n bitmap |= bit;\n packedNodes[packedII++] = node;\n }\n }\n\n return new BitmapIndexedNode(ownerID, bitmap, packedNodes);\n}\n\nfunction expandNodes(ownerID, nodes, bitmap, including, node) {\n var count = 0;\n var expandedNodes = new Array(SIZE);\n\n for (var ii = 0; bitmap !== 0; ii++, bitmap >>>= 1) {\n expandedNodes[ii] = bitmap & 1 ? nodes[count++] : undefined;\n }\n\n expandedNodes[including] = node;\n return new HashArrayMapNode(ownerID, count + 1, expandedNodes);\n}\n\nfunction popCount(x) {\n x -= x >> 1 & 0x55555555;\n x = (x & 0x33333333) + (x >> 2 & 0x33333333);\n x = x + (x >> 4) & 0x0f0f0f0f;\n x += x >> 8;\n x += x >> 16;\n return x & 0x7f;\n}\n\nfunction setAt(array, idx, val, canEdit) {\n var newArray = canEdit ? array : arrCopy(array);\n newArray[idx] = val;\n return newArray;\n}\n\nfunction spliceIn(array, idx, val, canEdit) {\n var newLen = array.length + 1;\n\n if (canEdit && idx + 1 === newLen) {\n array[idx] = val;\n return array;\n }\n\n var newArray = new Array(newLen);\n var after = 0;\n\n for (var ii = 0; ii < newLen; ii++) {\n if (ii === idx) {\n newArray[ii] = val;\n after = -1;\n } else {\n newArray[ii] = array[ii + after];\n }\n }\n\n return newArray;\n}\n\nfunction spliceOut(array, idx, canEdit) {\n var newLen = array.length - 1;\n\n if (canEdit && idx === newLen) {\n array.pop();\n return array;\n }\n\n var newArray = new Array(newLen);\n var after = 0;\n\n for (var ii = 0; ii < newLen; ii++) {\n if (ii === idx) {\n after = 1;\n }\n\n newArray[ii] = array[ii + after];\n }\n\n return newArray;\n}\n\nvar MAX_ARRAY_MAP_SIZE = SIZE / 4;\nvar MAX_BITMAP_INDEXED_SIZE = SIZE / 2;\nvar MIN_HASH_ARRAY_MAP_SIZE = SIZE / 4;\nvar IS_LIST_SYMBOL = '@@__IMMUTABLE_LIST__@@';\n\nfunction isList(maybeList) {\n return Boolean(maybeList && maybeList[IS_LIST_SYMBOL]);\n}\n\nvar List =\n/*@__PURE__*/\nfunction (IndexedCollection$$1) {\n function List(value) {\n var empty = emptyList();\n\n if (value === null || value === undefined) {\n return empty;\n }\n\n if (isList(value)) {\n return value;\n }\n\n var iter = IndexedCollection$$1(value);\n var size = iter.size;\n\n if (size === 0) {\n return empty;\n }\n\n assertNotInfinite(size);\n\n if (size > 0 && size < SIZE) {\n return makeList(0, size, SHIFT, null, new VNode(iter.toArray()));\n }\n\n return empty.withMutations(function (list) {\n list.setSize(size);\n iter.forEach(function (v, i) {\n return list.set(i, v);\n });\n });\n }\n\n if (IndexedCollection$$1) List.__proto__ = IndexedCollection$$1;\n List.prototype = Object.create(IndexedCollection$$1 && IndexedCollection$$1.prototype);\n List.prototype.constructor = List;\n\n List.of = function of()\n /*...values*/\n {\n return this(arguments);\n };\n\n List.prototype.toString = function toString() {\n return this.__toString('List [', ']');\n }; // @pragma Access\n\n\n List.prototype.get = function get(index, notSetValue) {\n index = wrapIndex(this, index);\n\n if (index >= 0 && index < this.size) {\n index += this._origin;\n var node = listNodeFor(this, index);\n return node && node.array[index & MASK];\n }\n\n return notSetValue;\n }; // @pragma Modification\n\n\n List.prototype.set = function set(index, value) {\n return updateList(this, index, value);\n };\n\n List.prototype.remove = function remove(index) {\n return !this.has(index) ? this : index === 0 ? this.shift() : index === this.size - 1 ? this.pop() : this.splice(index, 1);\n };\n\n List.prototype.insert = function insert(index, value) {\n return this.splice(index, 0, value);\n };\n\n List.prototype.clear = function clear() {\n if (this.size === 0) {\n return this;\n }\n\n if (this.__ownerID) {\n this.size = this._origin = this._capacity = 0;\n this._level = SHIFT;\n this._root = this._tail = null;\n this.__hash = undefined;\n this.__altered = true;\n return this;\n }\n\n return emptyList();\n };\n\n List.prototype.push = function push()\n /*...values*/\n {\n var values = arguments;\n var oldSize = this.size;\n return this.withMutations(function (list) {\n setListBounds(list, 0, oldSize + values.length);\n\n for (var ii = 0; ii < values.length; ii++) {\n list.set(oldSize + ii, values[ii]);\n }\n });\n };\n\n List.prototype.pop = function pop() {\n return setListBounds(this, 0, -1);\n };\n\n List.prototype.unshift = function unshift()\n /*...values*/\n {\n var values = arguments;\n return this.withMutations(function (list) {\n setListBounds(list, -values.length);\n\n for (var ii = 0; ii < values.length; ii++) {\n list.set(ii, values[ii]);\n }\n });\n };\n\n List.prototype.shift = function shift() {\n return setListBounds(this, 1);\n }; // @pragma Composition\n\n\n List.prototype.concat = function concat()\n /*...collections*/\n {\n var arguments$1 = arguments;\n var seqs = [];\n\n for (var i = 0; i < arguments.length; i++) {\n var argument = arguments$1[i];\n var seq = IndexedCollection$$1(typeof argument !== 'string' && hasIterator(argument) ? argument : [argument]);\n\n if (seq.size !== 0) {\n seqs.push(seq);\n }\n }\n\n if (seqs.length === 0) {\n return this;\n }\n\n if (this.size === 0 && !this.__ownerID && seqs.length === 1) {\n return this.constructor(seqs[0]);\n }\n\n return this.withMutations(function (list) {\n seqs.forEach(function (seq) {\n return seq.forEach(function (value) {\n return list.push(value);\n });\n });\n });\n };\n\n List.prototype.setSize = function setSize(size) {\n return setListBounds(this, 0, size);\n };\n\n List.prototype.map = function map(mapper, context) {\n var this$1 = this;\n return this.withMutations(function (list) {\n for (var i = 0; i < this$1.size; i++) {\n list.set(i, mapper.call(context, list.get(i), i, list));\n }\n });\n }; // @pragma Iteration\n\n\n List.prototype.slice = function slice(begin, end) {\n var size = this.size;\n\n if (wholeSlice(begin, end, size)) {\n return this;\n }\n\n return setListBounds(this, resolveBegin(begin, size), resolveEnd(end, size));\n };\n\n List.prototype.__iterator = function __iterator(type, reverse) {\n var index = reverse ? this.size : 0;\n var values = iterateList(this, reverse);\n return new Iterator(function () {\n var value = values();\n return value === DONE ? iteratorDone() : iteratorValue(type, reverse ? --index : index++, value);\n });\n };\n\n List.prototype.__iterate = function __iterate(fn, reverse) {\n var index = reverse ? this.size : 0;\n var values = iterateList(this, reverse);\n var value;\n\n while ((value = values()) !== DONE) {\n if (fn(value, reverse ? --index : index++, this) === false) {\n break;\n }\n }\n\n return index;\n };\n\n List.prototype.__ensureOwner = function __ensureOwner(ownerID) {\n if (ownerID === this.__ownerID) {\n return this;\n }\n\n if (!ownerID) {\n if (this.size === 0) {\n return emptyList();\n }\n\n this.__ownerID = ownerID;\n this.__altered = false;\n return this;\n }\n\n return makeList(this._origin, this._capacity, this._level, this._root, this._tail, ownerID, this.__hash);\n };\n\n return List;\n}(IndexedCollection);\n\nList.isList = isList;\nvar ListPrototype = List.prototype;\nListPrototype[IS_LIST_SYMBOL] = true;\nListPrototype[DELETE] = ListPrototype.remove;\nListPrototype.merge = ListPrototype.concat;\nListPrototype.setIn = setIn$1;\nListPrototype.deleteIn = ListPrototype.removeIn = deleteIn;\nListPrototype.update = update$1;\nListPrototype.updateIn = updateIn$1;\nListPrototype.mergeIn = mergeIn;\nListPrototype.mergeDeepIn = mergeDeepIn;\nListPrototype.withMutations = withMutations;\nListPrototype.wasAltered = wasAltered;\nListPrototype.asImmutable = asImmutable;\nListPrototype['@@transducer/init'] = ListPrototype.asMutable = asMutable;\n\nListPrototype['@@transducer/step'] = function (result, arr) {\n return result.push(arr);\n};\n\nListPrototype['@@transducer/result'] = function (obj) {\n return obj.asImmutable();\n};\n\nvar VNode = function VNode(array, ownerID) {\n this.array = array;\n this.ownerID = ownerID;\n}; // TODO: seems like these methods are very similar\n\n\nVNode.prototype.removeBefore = function removeBefore(ownerID, level, index) {\n if (index === level ? 1 << level : this.array.length === 0) {\n return this;\n }\n\n var originIndex = index >>> level & MASK;\n\n if (originIndex >= this.array.length) {\n return new VNode([], ownerID);\n }\n\n var removingFirst = originIndex === 0;\n var newChild;\n\n if (level > 0) {\n var oldChild = this.array[originIndex];\n newChild = oldChild && oldChild.removeBefore(ownerID, level - SHIFT, index);\n\n if (newChild === oldChild && removingFirst) {\n return this;\n }\n }\n\n if (removingFirst && !newChild) {\n return this;\n }\n\n var editable = editableVNode(this, ownerID);\n\n if (!removingFirst) {\n for (var ii = 0; ii < originIndex; ii++) {\n editable.array[ii] = undefined;\n }\n }\n\n if (newChild) {\n editable.array[originIndex] = newChild;\n }\n\n return editable;\n};\n\nVNode.prototype.removeAfter = function removeAfter(ownerID, level, index) {\n if (index === (level ? 1 << level : 0) || this.array.length === 0) {\n return this;\n }\n\n var sizeIndex = index - 1 >>> level & MASK;\n\n if (sizeIndex >= this.array.length) {\n return this;\n }\n\n var newChild;\n\n if (level > 0) {\n var oldChild = this.array[sizeIndex];\n newChild = oldChild && oldChild.removeAfter(ownerID, level - SHIFT, index);\n\n if (newChild === oldChild && sizeIndex === this.array.length - 1) {\n return this;\n }\n }\n\n var editable = editableVNode(this, ownerID);\n editable.array.splice(sizeIndex + 1);\n\n if (newChild) {\n editable.array[sizeIndex] = newChild;\n }\n\n return editable;\n};\n\nvar DONE = {};\n\nfunction iterateList(list, reverse) {\n var left = list._origin;\n var right = list._capacity;\n var tailPos = getTailOffset(right);\n var tail = list._tail;\n return iterateNodeOrLeaf(list._root, list._level, 0);\n\n function iterateNodeOrLeaf(node, level, offset) {\n return level === 0 ? iterateLeaf(node, offset) : iterateNode(node, level, offset);\n }\n\n function iterateLeaf(node, offset) {\n var array = offset === tailPos ? tail && tail.array : node && node.array;\n var from = offset > left ? 0 : left - offset;\n var to = right - offset;\n\n if (to > SIZE) {\n to = SIZE;\n }\n\n return function () {\n if (from === to) {\n return DONE;\n }\n\n var idx = reverse ? --to : from++;\n return array && array[idx];\n };\n }\n\n function iterateNode(node, level, offset) {\n var values;\n var array = node && node.array;\n var from = offset > left ? 0 : left - offset >> level;\n var to = (right - offset >> level) + 1;\n\n if (to > SIZE) {\n to = SIZE;\n }\n\n return function () {\n while (true) {\n if (values) {\n var value = values();\n\n if (value !== DONE) {\n return value;\n }\n\n values = null;\n }\n\n if (from === to) {\n return DONE;\n }\n\n var idx = reverse ? --to : from++;\n values = iterateNodeOrLeaf(array && array[idx], level - SHIFT, offset + (idx << level));\n }\n };\n }\n}\n\nfunction makeList(origin, capacity, level, root, tail, ownerID, hash) {\n var list = Object.create(ListPrototype);\n list.size = capacity - origin;\n list._origin = origin;\n list._capacity = capacity;\n list._level = level;\n list._root = root;\n list._tail = tail;\n list.__ownerID = ownerID;\n list.__hash = hash;\n list.__altered = false;\n return list;\n}\n\nvar EMPTY_LIST;\n\nfunction emptyList() {\n return EMPTY_LIST || (EMPTY_LIST = makeList(0, 0, SHIFT));\n}\n\nfunction updateList(list, index, value) {\n index = wrapIndex(list, index);\n\n if (index !== index) {\n return list;\n }\n\n if (index >= list.size || index < 0) {\n return list.withMutations(function (list) {\n index < 0 ? setListBounds(list, index).set(0, value) : setListBounds(list, 0, index + 1).set(index, value);\n });\n }\n\n index += list._origin;\n var newTail = list._tail;\n var newRoot = list._root;\n var didAlter = MakeRef();\n\n if (index >= getTailOffset(list._capacity)) {\n newTail = updateVNode(newTail, list.__ownerID, 0, index, value, didAlter);\n } else {\n newRoot = updateVNode(newRoot, list.__ownerID, list._level, index, value, didAlter);\n }\n\n if (!didAlter.value) {\n return list;\n }\n\n if (list.__ownerID) {\n list._root = newRoot;\n list._tail = newTail;\n list.__hash = undefined;\n list.__altered = true;\n return list;\n }\n\n return makeList(list._origin, list._capacity, list._level, newRoot, newTail);\n}\n\nfunction updateVNode(node, ownerID, level, index, value, didAlter) {\n var idx = index >>> level & MASK;\n var nodeHas = node && idx < node.array.length;\n\n if (!nodeHas && value === undefined) {\n return node;\n }\n\n var newNode;\n\n if (level > 0) {\n var lowerNode = node && node.array[idx];\n var newLowerNode = updateVNode(lowerNode, ownerID, level - SHIFT, index, value, didAlter);\n\n if (newLowerNode === lowerNode) {\n return node;\n }\n\n newNode = editableVNode(node, ownerID);\n newNode.array[idx] = newLowerNode;\n return newNode;\n }\n\n if (nodeHas && node.array[idx] === value) {\n return node;\n }\n\n if (didAlter) {\n SetRef(didAlter);\n }\n\n newNode = editableVNode(node, ownerID);\n\n if (value === undefined && idx === newNode.array.length - 1) {\n newNode.array.pop();\n } else {\n newNode.array[idx] = value;\n }\n\n return newNode;\n}\n\nfunction editableVNode(node, ownerID) {\n if (ownerID && node && ownerID === node.ownerID) {\n return node;\n }\n\n return new VNode(node ? node.array.slice() : [], ownerID);\n}\n\nfunction listNodeFor(list, rawIndex) {\n if (rawIndex >= getTailOffset(list._capacity)) {\n return list._tail;\n }\n\n if (rawIndex < 1 << list._level + SHIFT) {\n var node = list._root;\n var level = list._level;\n\n while (node && level > 0) {\n node = node.array[rawIndex >>> level & MASK];\n level -= SHIFT;\n }\n\n return node;\n }\n}\n\nfunction setListBounds(list, begin, end) {\n // Sanitize begin & end using this shorthand for ToInt32(argument)\n // http://www.ecma-international.org/ecma-262/6.0/#sec-toint32\n if (begin !== undefined) {\n begin |= 0;\n }\n\n if (end !== undefined) {\n end |= 0;\n }\n\n var owner = list.__ownerID || new OwnerID();\n var oldOrigin = list._origin;\n var oldCapacity = list._capacity;\n var newOrigin = oldOrigin + begin;\n var newCapacity = end === undefined ? oldCapacity : end < 0 ? oldCapacity + end : oldOrigin + end;\n\n if (newOrigin === oldOrigin && newCapacity === oldCapacity) {\n return list;\n } // If it's going to end after it starts, it's empty.\n\n\n if (newOrigin >= newCapacity) {\n return list.clear();\n }\n\n var newLevel = list._level;\n var newRoot = list._root; // New origin might need creating a higher root.\n\n var offsetShift = 0;\n\n while (newOrigin + offsetShift < 0) {\n newRoot = new VNode(newRoot && newRoot.array.length ? [undefined, newRoot] : [], owner);\n newLevel += SHIFT;\n offsetShift += 1 << newLevel;\n }\n\n if (offsetShift) {\n newOrigin += offsetShift;\n oldOrigin += offsetShift;\n newCapacity += offsetShift;\n oldCapacity += offsetShift;\n }\n\n var oldTailOffset = getTailOffset(oldCapacity);\n var newTailOffset = getTailOffset(newCapacity); // New size might need creating a higher root.\n\n while (newTailOffset >= 1 << newLevel + SHIFT) {\n newRoot = new VNode(newRoot && newRoot.array.length ? [newRoot] : [], owner);\n newLevel += SHIFT;\n } // Locate or create the new tail.\n\n\n var oldTail = list._tail;\n var newTail = newTailOffset < oldTailOffset ? listNodeFor(list, newCapacity - 1) : newTailOffset > oldTailOffset ? new VNode([], owner) : oldTail; // Merge Tail into tree.\n\n if (oldTail && newTailOffset > oldTailOffset && newOrigin < oldCapacity && oldTail.array.length) {\n newRoot = editableVNode(newRoot, owner);\n var node = newRoot;\n\n for (var level = newLevel; level > SHIFT; level -= SHIFT) {\n var idx = oldTailOffset >>> level & MASK;\n node = node.array[idx] = editableVNode(node.array[idx], owner);\n }\n\n node.array[oldTailOffset >>> SHIFT & MASK] = oldTail;\n } // If the size has been reduced, there's a chance the tail needs to be trimmed.\n\n\n if (newCapacity < oldCapacity) {\n newTail = newTail && newTail.removeAfter(owner, 0, newCapacity);\n } // If the new origin is within the tail, then we do not need a root.\n\n\n if (newOrigin >= newTailOffset) {\n newOrigin -= newTailOffset;\n newCapacity -= newTailOffset;\n newLevel = SHIFT;\n newRoot = null;\n newTail = newTail && newTail.removeBefore(owner, 0, newOrigin); // Otherwise, if the root has been trimmed, garbage collect.\n } else if (newOrigin > oldOrigin || newTailOffset < oldTailOffset) {\n offsetShift = 0; // Identify the new top root node of the subtree of the old root.\n\n while (newRoot) {\n var beginIndex = newOrigin >>> newLevel & MASK;\n\n if (beginIndex !== newTailOffset >>> newLevel & MASK) {\n break;\n }\n\n if (beginIndex) {\n offsetShift += (1 << newLevel) * beginIndex;\n }\n\n newLevel -= SHIFT;\n newRoot = newRoot.array[beginIndex];\n } // Trim the new sides of the new root.\n\n\n if (newRoot && newOrigin > oldOrigin) {\n newRoot = newRoot.removeBefore(owner, newLevel, newOrigin - offsetShift);\n }\n\n if (newRoot && newTailOffset < oldTailOffset) {\n newRoot = newRoot.removeAfter(owner, newLevel, newTailOffset - offsetShift);\n }\n\n if (offsetShift) {\n newOrigin -= offsetShift;\n newCapacity -= offsetShift;\n }\n }\n\n if (list.__ownerID) {\n list.size = newCapacity - newOrigin;\n list._origin = newOrigin;\n list._capacity = newCapacity;\n list._level = newLevel;\n list._root = newRoot;\n list._tail = newTail;\n list.__hash = undefined;\n list.__altered = true;\n return list;\n }\n\n return makeList(newOrigin, newCapacity, newLevel, newRoot, newTail);\n}\n\nfunction getTailOffset(size) {\n return size < SIZE ? 0 : size - 1 >>> SHIFT << SHIFT;\n}\n\nvar OrderedMap =\n/*@__PURE__*/\nfunction (Map$$1) {\n function OrderedMap(value) {\n return value === null || value === undefined ? emptyOrderedMap() : isOrderedMap(value) ? value : emptyOrderedMap().withMutations(function (map) {\n var iter = KeyedCollection(value);\n assertNotInfinite(iter.size);\n iter.forEach(function (v, k) {\n return map.set(k, v);\n });\n });\n }\n\n if (Map$$1) OrderedMap.__proto__ = Map$$1;\n OrderedMap.prototype = Object.create(Map$$1 && Map$$1.prototype);\n OrderedMap.prototype.constructor = OrderedMap;\n\n OrderedMap.of = function of()\n /*...values*/\n {\n return this(arguments);\n };\n\n OrderedMap.prototype.toString = function toString() {\n return this.__toString('OrderedMap {', '}');\n }; // @pragma Access\n\n\n OrderedMap.prototype.get = function get(k, notSetValue) {\n var index = this._map.get(k);\n\n return index !== undefined ? this._list.get(index)[1] : notSetValue;\n }; // @pragma Modification\n\n\n OrderedMap.prototype.clear = function clear() {\n if (this.size === 0) {\n return this;\n }\n\n if (this.__ownerID) {\n this.size = 0;\n\n this._map.clear();\n\n this._list.clear();\n\n return this;\n }\n\n return emptyOrderedMap();\n };\n\n OrderedMap.prototype.set = function set(k, v) {\n return updateOrderedMap(this, k, v);\n };\n\n OrderedMap.prototype.remove = function remove(k) {\n return updateOrderedMap(this, k, NOT_SET);\n };\n\n OrderedMap.prototype.wasAltered = function wasAltered() {\n return this._map.wasAltered() || this._list.wasAltered();\n };\n\n OrderedMap.prototype.__iterate = function __iterate(fn, reverse) {\n var this$1 = this;\n return this._list.__iterate(function (entry) {\n return entry && fn(entry[1], entry[0], this$1);\n }, reverse);\n };\n\n OrderedMap.prototype.__iterator = function __iterator(type, reverse) {\n return this._list.fromEntrySeq().__iterator(type, reverse);\n };\n\n OrderedMap.prototype.__ensureOwner = function __ensureOwner(ownerID) {\n if (ownerID === this.__ownerID) {\n return this;\n }\n\n var newMap = this._map.__ensureOwner(ownerID);\n\n var newList = this._list.__ensureOwner(ownerID);\n\n if (!ownerID) {\n if (this.size === 0) {\n return emptyOrderedMap();\n }\n\n this.__ownerID = ownerID;\n this._map = newMap;\n this._list = newList;\n return this;\n }\n\n return makeOrderedMap(newMap, newList, ownerID, this.__hash);\n };\n\n return OrderedMap;\n}(Map);\n\nOrderedMap.isOrderedMap = isOrderedMap;\nOrderedMap.prototype[IS_ORDERED_SYMBOL] = true;\nOrderedMap.prototype[DELETE] = OrderedMap.prototype.remove;\n\nfunction makeOrderedMap(map, list, ownerID, hash) {\n var omap = Object.create(OrderedMap.prototype);\n omap.size = map ? map.size : 0;\n omap._map = map;\n omap._list = list;\n omap.__ownerID = ownerID;\n omap.__hash = hash;\n return omap;\n}\n\nvar EMPTY_ORDERED_MAP;\n\nfunction emptyOrderedMap() {\n return EMPTY_ORDERED_MAP || (EMPTY_ORDERED_MAP = makeOrderedMap(emptyMap(), emptyList()));\n}\n\nfunction updateOrderedMap(omap, k, v) {\n var map = omap._map;\n var list = omap._list;\n var i = map.get(k);\n var has = i !== undefined;\n var newMap;\n var newList;\n\n if (v === NOT_SET) {\n // removed\n if (!has) {\n return omap;\n }\n\n if (list.size >= SIZE && list.size >= map.size * 2) {\n newList = list.filter(function (entry, idx) {\n return entry !== undefined && i !== idx;\n });\n newMap = newList.toKeyedSeq().map(function (entry) {\n return entry[0];\n }).flip().toMap();\n\n if (omap.__ownerID) {\n newMap.__ownerID = newList.__ownerID = omap.__ownerID;\n }\n } else {\n newMap = map.remove(k);\n newList = i === list.size - 1 ? list.pop() : list.set(i, undefined);\n }\n } else if (has) {\n if (v === list.get(i)[1]) {\n return omap;\n }\n\n newMap = map;\n newList = list.set(i, [k, v]);\n } else {\n newMap = map.set(k, list.size);\n newList = list.set(list.size, [k, v]);\n }\n\n if (omap.__ownerID) {\n omap.size = newMap.size;\n omap._map = newMap;\n omap._list = newList;\n omap.__hash = undefined;\n return omap;\n }\n\n return makeOrderedMap(newMap, newList);\n}\n\nvar IS_STACK_SYMBOL = '@@__IMMUTABLE_STACK__@@';\n\nfunction isStack(maybeStack) {\n return Boolean(maybeStack && maybeStack[IS_STACK_SYMBOL]);\n}\n\nvar Stack =\n/*@__PURE__*/\nfunction (IndexedCollection$$1) {\n function Stack(value) {\n return value === null || value === undefined ? emptyStack() : isStack(value) ? value : emptyStack().pushAll(value);\n }\n\n if (IndexedCollection$$1) Stack.__proto__ = IndexedCollection$$1;\n Stack.prototype = Object.create(IndexedCollection$$1 && IndexedCollection$$1.prototype);\n Stack.prototype.constructor = Stack;\n\n Stack.of = function of()\n /*...values*/\n {\n return this(arguments);\n };\n\n Stack.prototype.toString = function toString() {\n return this.__toString('Stack [', ']');\n }; // @pragma Access\n\n\n Stack.prototype.get = function get(index, notSetValue) {\n var head = this._head;\n index = wrapIndex(this, index);\n\n while (head && index--) {\n head = head.next;\n }\n\n return head ? head.value : notSetValue;\n };\n\n Stack.prototype.peek = function peek() {\n return this._head && this._head.value;\n }; // @pragma Modification\n\n\n Stack.prototype.push = function push()\n /*...values*/\n {\n var arguments$1 = arguments;\n\n if (arguments.length === 0) {\n return this;\n }\n\n var newSize = this.size + arguments.length;\n var head = this._head;\n\n for (var ii = arguments.length - 1; ii >= 0; ii--) {\n head = {\n value: arguments$1[ii],\n next: head\n };\n }\n\n if (this.__ownerID) {\n this.size = newSize;\n this._head = head;\n this.__hash = undefined;\n this.__altered = true;\n return this;\n }\n\n return makeStack(newSize, head);\n };\n\n Stack.prototype.pushAll = function pushAll(iter) {\n iter = IndexedCollection$$1(iter);\n\n if (iter.size === 0) {\n return this;\n }\n\n if (this.size === 0 && isStack(iter)) {\n return iter;\n }\n\n assertNotInfinite(iter.size);\n var newSize = this.size;\n var head = this._head;\n\n iter.__iterate(function (value) {\n newSize++;\n head = {\n value: value,\n next: head\n };\n },\n /* reverse */\n true);\n\n if (this.__ownerID) {\n this.size = newSize;\n this._head = head;\n this.__hash = undefined;\n this.__altered = true;\n return this;\n }\n\n return makeStack(newSize, head);\n };\n\n Stack.prototype.pop = function pop() {\n return this.slice(1);\n };\n\n Stack.prototype.clear = function clear() {\n if (this.size === 0) {\n return this;\n }\n\n if (this.__ownerID) {\n this.size = 0;\n this._head = undefined;\n this.__hash = undefined;\n this.__altered = true;\n return this;\n }\n\n return emptyStack();\n };\n\n Stack.prototype.slice = function slice(begin, end) {\n if (wholeSlice(begin, end, this.size)) {\n return this;\n }\n\n var resolvedBegin = resolveBegin(begin, this.size);\n var resolvedEnd = resolveEnd(end, this.size);\n\n if (resolvedEnd !== this.size) {\n // super.slice(begin, end);\n return IndexedCollection$$1.prototype.slice.call(this, begin, end);\n }\n\n var newSize = this.size - resolvedBegin;\n var head = this._head;\n\n while (resolvedBegin--) {\n head = head.next;\n }\n\n if (this.__ownerID) {\n this.size = newSize;\n this._head = head;\n this.__hash = undefined;\n this.__altered = true;\n return this;\n }\n\n return makeStack(newSize, head);\n }; // @pragma Mutability\n\n\n Stack.prototype.__ensureOwner = function __ensureOwner(ownerID) {\n if (ownerID === this.__ownerID) {\n return this;\n }\n\n if (!ownerID) {\n if (this.size === 0) {\n return emptyStack();\n }\n\n this.__ownerID = ownerID;\n this.__altered = false;\n return this;\n }\n\n return makeStack(this.size, this._head, ownerID, this.__hash);\n }; // @pragma Iteration\n\n\n Stack.prototype.__iterate = function __iterate(fn, reverse) {\n var this$1 = this;\n\n if (reverse) {\n return new ArraySeq(this.toArray()).__iterate(function (v, k) {\n return fn(v, k, this$1);\n }, reverse);\n }\n\n var iterations = 0;\n var node = this._head;\n\n while (node) {\n if (fn(node.value, iterations++, this) === false) {\n break;\n }\n\n node = node.next;\n }\n\n return iterations;\n };\n\n Stack.prototype.__iterator = function __iterator(type, reverse) {\n if (reverse) {\n return new ArraySeq(this.toArray()).__iterator(type, reverse);\n }\n\n var iterations = 0;\n var node = this._head;\n return new Iterator(function () {\n if (node) {\n var value = node.value;\n node = node.next;\n return iteratorValue(type, iterations++, value);\n }\n\n return iteratorDone();\n });\n };\n\n return Stack;\n}(IndexedCollection);\n\nStack.isStack = isStack;\nvar StackPrototype = Stack.prototype;\nStackPrototype[IS_STACK_SYMBOL] = true;\nStackPrototype.shift = StackPrototype.pop;\nStackPrototype.unshift = StackPrototype.push;\nStackPrototype.unshiftAll = StackPrototype.pushAll;\nStackPrototype.withMutations = withMutations;\nStackPrototype.wasAltered = wasAltered;\nStackPrototype.asImmutable = asImmutable;\nStackPrototype['@@transducer/init'] = StackPrototype.asMutable = asMutable;\n\nStackPrototype['@@transducer/step'] = function (result, arr) {\n return result.unshift(arr);\n};\n\nStackPrototype['@@transducer/result'] = function (obj) {\n return obj.asImmutable();\n};\n\nfunction makeStack(size, head, ownerID, hash) {\n var map = Object.create(StackPrototype);\n map.size = size;\n map._head = head;\n map.__ownerID = ownerID;\n map.__hash = hash;\n map.__altered = false;\n return map;\n}\n\nvar EMPTY_STACK;\n\nfunction emptyStack() {\n return EMPTY_STACK || (EMPTY_STACK = makeStack(0));\n}\n\nvar IS_SET_SYMBOL = '@@__IMMUTABLE_SET__@@';\n\nfunction isSet(maybeSet) {\n return Boolean(maybeSet && maybeSet[IS_SET_SYMBOL]);\n}\n\nfunction isOrderedSet(maybeOrderedSet) {\n return isSet(maybeOrderedSet) && isOrdered(maybeOrderedSet);\n}\n\nfunction deepEqual(a, b) {\n if (a === b) {\n return true;\n }\n\n if (!isCollection(b) || a.size !== undefined && b.size !== undefined && a.size !== b.size || a.__hash !== undefined && b.__hash !== undefined && a.__hash !== b.__hash || isKeyed(a) !== isKeyed(b) || isIndexed(a) !== isIndexed(b) || isOrdered(a) !== isOrdered(b)) {\n return false;\n }\n\n if (a.size === 0 && b.size === 0) {\n return true;\n }\n\n var notAssociative = !isAssociative(a);\n\n if (isOrdered(a)) {\n var entries = a.entries();\n return b.every(function (v, k) {\n var entry = entries.next().value;\n return entry && is(entry[1], v) && (notAssociative || is(entry[0], k));\n }) && entries.next().done;\n }\n\n var flipped = false;\n\n if (a.size === undefined) {\n if (b.size === undefined) {\n if (typeof a.cacheResult === 'function') {\n a.cacheResult();\n }\n } else {\n flipped = true;\n var _ = a;\n a = b;\n b = _;\n }\n }\n\n var allEqual = true;\n\n var bSize = b.__iterate(function (v, k) {\n if (notAssociative ? !a.has(v) : flipped ? !is(v, a.get(k, NOT_SET)) : !is(a.get(k, NOT_SET), v)) {\n allEqual = false;\n return false;\n }\n });\n\n return allEqual && a.size === bSize;\n}\n/**\n * Contributes additional methods to a constructor\n */\n\n\nfunction mixin(ctor, methods) {\n var keyCopier = function keyCopier(key) {\n ctor.prototype[key] = methods[key];\n };\n\n Object.keys(methods).forEach(keyCopier);\n Object.getOwnPropertySymbols && Object.getOwnPropertySymbols(methods).forEach(keyCopier);\n return ctor;\n}\n\nfunction toJS(value) {\n if (!value || typeof value !== 'object') {\n return value;\n }\n\n if (!isCollection(value)) {\n if (!isDataStructure(value)) {\n return value;\n }\n\n value = Seq(value);\n }\n\n if (isKeyed(value)) {\n var result$1 = {};\n\n value.__iterate(function (v, k) {\n result$1[k] = toJS(v);\n });\n\n return result$1;\n }\n\n var result = [];\n\n value.__iterate(function (v) {\n result.push(toJS(v));\n });\n\n return result;\n}\n\nvar Set =\n/*@__PURE__*/\nfunction (SetCollection$$1) {\n function Set(value) {\n return value === null || value === undefined ? emptySet() : isSet(value) && !isOrdered(value) ? value : emptySet().withMutations(function (set) {\n var iter = SetCollection$$1(value);\n assertNotInfinite(iter.size);\n iter.forEach(function (v) {\n return set.add(v);\n });\n });\n }\n\n if (SetCollection$$1) Set.__proto__ = SetCollection$$1;\n Set.prototype = Object.create(SetCollection$$1 && SetCollection$$1.prototype);\n Set.prototype.constructor = Set;\n\n Set.of = function of()\n /*...values*/\n {\n return this(arguments);\n };\n\n Set.fromKeys = function fromKeys(value) {\n return this(KeyedCollection(value).keySeq());\n };\n\n Set.intersect = function intersect(sets) {\n sets = Collection(sets).toArray();\n return sets.length ? SetPrototype.intersect.apply(Set(sets.pop()), sets) : emptySet();\n };\n\n Set.union = function union(sets) {\n sets = Collection(sets).toArray();\n return sets.length ? SetPrototype.union.apply(Set(sets.pop()), sets) : emptySet();\n };\n\n Set.prototype.toString = function toString() {\n return this.__toString('Set {', '}');\n }; // @pragma Access\n\n\n Set.prototype.has = function has(value) {\n return this._map.has(value);\n }; // @pragma Modification\n\n\n Set.prototype.add = function add(value) {\n return updateSet(this, this._map.set(value, value));\n };\n\n Set.prototype.remove = function remove(value) {\n return updateSet(this, this._map.remove(value));\n };\n\n Set.prototype.clear = function clear() {\n return updateSet(this, this._map.clear());\n }; // @pragma Composition\n\n\n Set.prototype.map = function map(mapper, context) {\n var this$1 = this;\n var removes = [];\n var adds = [];\n this.forEach(function (value) {\n var mapped = mapper.call(context, value, value, this$1);\n\n if (mapped !== value) {\n removes.push(value);\n adds.push(mapped);\n }\n });\n return this.withMutations(function (set) {\n removes.forEach(function (value) {\n return set.remove(value);\n });\n adds.forEach(function (value) {\n return set.add(value);\n });\n });\n };\n\n Set.prototype.union = function union() {\n var iters = [],\n len = arguments.length;\n\n while (len--) {\n iters[len] = arguments[len];\n }\n\n iters = iters.filter(function (x) {\n return x.size !== 0;\n });\n\n if (iters.length === 0) {\n return this;\n }\n\n if (this.size === 0 && !this.__ownerID && iters.length === 1) {\n return this.constructor(iters[0]);\n }\n\n return this.withMutations(function (set) {\n for (var ii = 0; ii < iters.length; ii++) {\n SetCollection$$1(iters[ii]).forEach(function (value) {\n return set.add(value);\n });\n }\n });\n };\n\n Set.prototype.intersect = function intersect() {\n var iters = [],\n len = arguments.length;\n\n while (len--) {\n iters[len] = arguments[len];\n }\n\n if (iters.length === 0) {\n return this;\n }\n\n iters = iters.map(function (iter) {\n return SetCollection$$1(iter);\n });\n var toRemove = [];\n this.forEach(function (value) {\n if (!iters.every(function (iter) {\n return iter.includes(value);\n })) {\n toRemove.push(value);\n }\n });\n return this.withMutations(function (set) {\n toRemove.forEach(function (value) {\n set.remove(value);\n });\n });\n };\n\n Set.prototype.subtract = function subtract() {\n var iters = [],\n len = arguments.length;\n\n while (len--) {\n iters[len] = arguments[len];\n }\n\n if (iters.length === 0) {\n return this;\n }\n\n iters = iters.map(function (iter) {\n return SetCollection$$1(iter);\n });\n var toRemove = [];\n this.forEach(function (value) {\n if (iters.some(function (iter) {\n return iter.includes(value);\n })) {\n toRemove.push(value);\n }\n });\n return this.withMutations(function (set) {\n toRemove.forEach(function (value) {\n set.remove(value);\n });\n });\n };\n\n Set.prototype.sort = function sort(comparator) {\n // Late binding\n return OrderedSet(sortFactory(this, comparator));\n };\n\n Set.prototype.sortBy = function sortBy(mapper, comparator) {\n // Late binding\n return OrderedSet(sortFactory(this, comparator, mapper));\n };\n\n Set.prototype.wasAltered = function wasAltered() {\n return this._map.wasAltered();\n };\n\n Set.prototype.__iterate = function __iterate(fn, reverse) {\n var this$1 = this;\n return this._map.__iterate(function (k) {\n return fn(k, k, this$1);\n }, reverse);\n };\n\n Set.prototype.__iterator = function __iterator(type, reverse) {\n return this._map.__iterator(type, reverse);\n };\n\n Set.prototype.__ensureOwner = function __ensureOwner(ownerID) {\n if (ownerID === this.__ownerID) {\n return this;\n }\n\n var newMap = this._map.__ensureOwner(ownerID);\n\n if (!ownerID) {\n if (this.size === 0) {\n return this.__empty();\n }\n\n this.__ownerID = ownerID;\n this._map = newMap;\n return this;\n }\n\n return this.__make(newMap, ownerID);\n };\n\n return Set;\n}(SetCollection);\n\nSet.isSet = isSet;\nvar SetPrototype = Set.prototype;\nSetPrototype[IS_SET_SYMBOL] = true;\nSetPrototype[DELETE] = SetPrototype.remove;\nSetPrototype.merge = SetPrototype.concat = SetPrototype.union;\nSetPrototype.withMutations = withMutations;\nSetPrototype.asImmutable = asImmutable;\nSetPrototype['@@transducer/init'] = SetPrototype.asMutable = asMutable;\n\nSetPrototype['@@transducer/step'] = function (result, arr) {\n return result.add(arr);\n};\n\nSetPrototype['@@transducer/result'] = function (obj) {\n return obj.asImmutable();\n};\n\nSetPrototype.__empty = emptySet;\nSetPrototype.__make = makeSet;\n\nfunction updateSet(set, newMap) {\n if (set.__ownerID) {\n set.size = newMap.size;\n set._map = newMap;\n return set;\n }\n\n return newMap === set._map ? set : newMap.size === 0 ? set.__empty() : set.__make(newMap);\n}\n\nfunction makeSet(map, ownerID) {\n var set = Object.create(SetPrototype);\n set.size = map ? map.size : 0;\n set._map = map;\n set.__ownerID = ownerID;\n return set;\n}\n\nvar EMPTY_SET;\n\nfunction emptySet() {\n return EMPTY_SET || (EMPTY_SET = makeSet(emptyMap()));\n}\n/**\n * Returns a lazy seq of nums from start (inclusive) to end\n * (exclusive), by step, where start defaults to 0, step to 1, and end to\n * infinity. When start is equal to end, returns empty list.\n */\n\n\nvar Range =\n/*@__PURE__*/\nfunction (IndexedSeq$$1) {\n function Range(start, end, step) {\n if (!(this instanceof Range)) {\n return new Range(start, end, step);\n }\n\n invariant(step !== 0, 'Cannot step a Range by 0');\n start = start || 0;\n\n if (end === undefined) {\n end = Infinity;\n }\n\n step = step === undefined ? 1 : Math.abs(step);\n\n if (end < start) {\n step = -step;\n }\n\n this._start = start;\n this._end = end;\n this._step = step;\n this.size = Math.max(0, Math.ceil((end - start) / step - 1) + 1);\n\n if (this.size === 0) {\n if (EMPTY_RANGE) {\n return EMPTY_RANGE;\n }\n\n EMPTY_RANGE = this;\n }\n }\n\n if (IndexedSeq$$1) Range.__proto__ = IndexedSeq$$1;\n Range.prototype = Object.create(IndexedSeq$$1 && IndexedSeq$$1.prototype);\n Range.prototype.constructor = Range;\n\n Range.prototype.toString = function toString() {\n if (this.size === 0) {\n return 'Range []';\n }\n\n return 'Range [ ' + this._start + '...' + this._end + (this._step !== 1 ? ' by ' + this._step : '') + ' ]';\n };\n\n Range.prototype.get = function get(index, notSetValue) {\n return this.has(index) ? this._start + wrapIndex(this, index) * this._step : notSetValue;\n };\n\n Range.prototype.includes = function includes(searchValue) {\n var possibleIndex = (searchValue - this._start) / this._step;\n return possibleIndex >= 0 && possibleIndex < this.size && possibleIndex === Math.floor(possibleIndex);\n };\n\n Range.prototype.slice = function slice(begin, end) {\n if (wholeSlice(begin, end, this.size)) {\n return this;\n }\n\n begin = resolveBegin(begin, this.size);\n end = resolveEnd(end, this.size);\n\n if (end <= begin) {\n return new Range(0, 0);\n }\n\n return new Range(this.get(begin, this._end), this.get(end, this._end), this._step);\n };\n\n Range.prototype.indexOf = function indexOf(searchValue) {\n var offsetValue = searchValue - this._start;\n\n if (offsetValue % this._step === 0) {\n var index = offsetValue / this._step;\n\n if (index >= 0 && index < this.size) {\n return index;\n }\n }\n\n return -1;\n };\n\n Range.prototype.lastIndexOf = function lastIndexOf(searchValue) {\n return this.indexOf(searchValue);\n };\n\n Range.prototype.__iterate = function __iterate(fn, reverse) {\n var size = this.size;\n var step = this._step;\n var value = reverse ? this._start + (size - 1) * step : this._start;\n var i = 0;\n\n while (i !== size) {\n if (fn(value, reverse ? size - ++i : i++, this) === false) {\n break;\n }\n\n value += reverse ? -step : step;\n }\n\n return i;\n };\n\n Range.prototype.__iterator = function __iterator(type, reverse) {\n var size = this.size;\n var step = this._step;\n var value = reverse ? this._start + (size - 1) * step : this._start;\n var i = 0;\n return new Iterator(function () {\n if (i === size) {\n return iteratorDone();\n }\n\n var v = value;\n value += reverse ? -step : step;\n return iteratorValue(type, reverse ? size - ++i : i++, v);\n });\n };\n\n Range.prototype.equals = function equals(other) {\n return other instanceof Range ? this._start === other._start && this._end === other._end && this._step === other._step : deepEqual(this, other);\n };\n\n return Range;\n}(IndexedSeq);\n\nvar EMPTY_RANGE;\n\nfunction getIn(collection, searchKeyPath, notSetValue) {\n var keyPath = coerceKeyPath(searchKeyPath);\n var i = 0;\n\n while (i !== keyPath.length) {\n collection = get(collection, keyPath[i++], NOT_SET);\n\n if (collection === NOT_SET) {\n return notSetValue;\n }\n }\n\n return collection;\n}\n\nfunction getIn$1(searchKeyPath, notSetValue) {\n return getIn(this, searchKeyPath, notSetValue);\n}\n\nfunction hasIn(collection, keyPath) {\n return getIn(collection, keyPath, NOT_SET) !== NOT_SET;\n}\n\nfunction hasIn$1(searchKeyPath) {\n return hasIn(this, searchKeyPath);\n}\n\nfunction toObject() {\n assertNotInfinite(this.size);\n var object = {};\n\n this.__iterate(function (v, k) {\n object[k] = v;\n });\n\n return object;\n} // Note: all of these methods are deprecated.\n\n\nCollection.isIterable = isCollection;\nCollection.isKeyed = isKeyed;\nCollection.isIndexed = isIndexed;\nCollection.isAssociative = isAssociative;\nCollection.isOrdered = isOrdered;\nCollection.Iterator = Iterator;\nmixin(Collection, {\n // ### Conversion to other types\n toArray: function toArray() {\n assertNotInfinite(this.size);\n var array = new Array(this.size || 0);\n var useTuples = isKeyed(this);\n var i = 0;\n\n this.__iterate(function (v, k) {\n // Keyed collections produce an array of tuples.\n array[i++] = useTuples ? [k, v] : v;\n });\n\n return array;\n },\n toIndexedSeq: function toIndexedSeq() {\n return new ToIndexedSequence(this);\n },\n toJS: function toJS$1() {\n return toJS(this);\n },\n toKeyedSeq: function toKeyedSeq() {\n return new ToKeyedSequence(this, true);\n },\n toMap: function toMap() {\n // Use Late Binding here to solve the circular dependency.\n return Map(this.toKeyedSeq());\n },\n toObject: toObject,\n toOrderedMap: function toOrderedMap() {\n // Use Late Binding here to solve the circular dependency.\n return OrderedMap(this.toKeyedSeq());\n },\n toOrderedSet: function toOrderedSet() {\n // Use Late Binding here to solve the circular dependency.\n return OrderedSet(isKeyed(this) ? this.valueSeq() : this);\n },\n toSet: function toSet() {\n // Use Late Binding here to solve the circular dependency.\n return Set(isKeyed(this) ? this.valueSeq() : this);\n },\n toSetSeq: function toSetSeq() {\n return new ToSetSequence(this);\n },\n toSeq: function toSeq() {\n return isIndexed(this) ? this.toIndexedSeq() : isKeyed(this) ? this.toKeyedSeq() : this.toSetSeq();\n },\n toStack: function toStack() {\n // Use Late Binding here to solve the circular dependency.\n return Stack(isKeyed(this) ? this.valueSeq() : this);\n },\n toList: function toList() {\n // Use Late Binding here to solve the circular dependency.\n return List(isKeyed(this) ? this.valueSeq() : this);\n },\n // ### Common JavaScript methods and properties\n toString: function toString() {\n return '[Collection]';\n },\n __toString: function __toString(head, tail) {\n if (this.size === 0) {\n return head + tail;\n }\n\n return head + ' ' + this.toSeq().map(this.__toStringMapper).join(', ') + ' ' + tail;\n },\n // ### ES6 Collection methods (ES6 Array and Map)\n concat: function concat() {\n var values = [],\n len = arguments.length;\n\n while (len--) {\n values[len] = arguments[len];\n }\n\n return reify(this, concatFactory(this, values));\n },\n includes: function includes(searchValue) {\n return this.some(function (value) {\n return is(value, searchValue);\n });\n },\n entries: function entries() {\n return this.__iterator(ITERATE_ENTRIES);\n },\n every: function every(predicate, context) {\n assertNotInfinite(this.size);\n var returnValue = true;\n\n this.__iterate(function (v, k, c) {\n if (!predicate.call(context, v, k, c)) {\n returnValue = false;\n return false;\n }\n });\n\n return returnValue;\n },\n filter: function filter(predicate, context) {\n return reify(this, filterFactory(this, predicate, context, true));\n },\n find: function find(predicate, context, notSetValue) {\n var entry = this.findEntry(predicate, context);\n return entry ? entry[1] : notSetValue;\n },\n forEach: function forEach(sideEffect, context) {\n assertNotInfinite(this.size);\n return this.__iterate(context ? sideEffect.bind(context) : sideEffect);\n },\n join: function join(separator) {\n assertNotInfinite(this.size);\n separator = separator !== undefined ? '' + separator : ',';\n var joined = '';\n var isFirst = true;\n\n this.__iterate(function (v) {\n isFirst ? isFirst = false : joined += separator;\n joined += v !== null && v !== undefined ? v.toString() : '';\n });\n\n return joined;\n },\n keys: function keys() {\n return this.__iterator(ITERATE_KEYS);\n },\n map: function map(mapper, context) {\n return reify(this, mapFactory(this, mapper, context));\n },\n reduce: function reduce$1(reducer, initialReduction, context) {\n return reduce(this, reducer, initialReduction, context, arguments.length < 2, false);\n },\n reduceRight: function reduceRight(reducer, initialReduction, context) {\n return reduce(this, reducer, initialReduction, context, arguments.length < 2, true);\n },\n reverse: function reverse() {\n return reify(this, reverseFactory(this, true));\n },\n slice: function slice(begin, end) {\n return reify(this, sliceFactory(this, begin, end, true));\n },\n some: function some(predicate, context) {\n return !this.every(not(predicate), context);\n },\n sort: function sort(comparator) {\n return reify(this, sortFactory(this, comparator));\n },\n values: function values() {\n return this.__iterator(ITERATE_VALUES);\n },\n // ### More sequential methods\n butLast: function butLast() {\n return this.slice(0, -1);\n },\n isEmpty: function isEmpty() {\n return this.size !== undefined ? this.size === 0 : !this.some(function () {\n return true;\n });\n },\n count: function count(predicate, context) {\n return ensureSize(predicate ? this.toSeq().filter(predicate, context) : this);\n },\n countBy: function countBy(grouper, context) {\n return countByFactory(this, grouper, context);\n },\n equals: function equals(other) {\n return deepEqual(this, other);\n },\n entrySeq: function entrySeq() {\n var collection = this;\n\n if (collection._cache) {\n // We cache as an entries array, so we can just return the cache!\n return new ArraySeq(collection._cache);\n }\n\n var entriesSequence = collection.toSeq().map(entryMapper).toIndexedSeq();\n\n entriesSequence.fromEntrySeq = function () {\n return collection.toSeq();\n };\n\n return entriesSequence;\n },\n filterNot: function filterNot(predicate, context) {\n return this.filter(not(predicate), context);\n },\n findEntry: function findEntry(predicate, context, notSetValue) {\n var found = notSetValue;\n\n this.__iterate(function (v, k, c) {\n if (predicate.call(context, v, k, c)) {\n found = [k, v];\n return false;\n }\n });\n\n return found;\n },\n findKey: function findKey(predicate, context) {\n var entry = this.findEntry(predicate, context);\n return entry && entry[0];\n },\n findLast: function findLast(predicate, context, notSetValue) {\n return this.toKeyedSeq().reverse().find(predicate, context, notSetValue);\n },\n findLastEntry: function findLastEntry(predicate, context, notSetValue) {\n return this.toKeyedSeq().reverse().findEntry(predicate, context, notSetValue);\n },\n findLastKey: function findLastKey(predicate, context) {\n return this.toKeyedSeq().reverse().findKey(predicate, context);\n },\n first: function first(notSetValue) {\n return this.find(returnTrue, null, notSetValue);\n },\n flatMap: function flatMap(mapper, context) {\n return reify(this, flatMapFactory(this, mapper, context));\n },\n flatten: function flatten(depth) {\n return reify(this, flattenFactory(this, depth, true));\n },\n fromEntrySeq: function fromEntrySeq() {\n return new FromEntriesSequence(this);\n },\n get: function get(searchKey, notSetValue) {\n return this.find(function (_, key) {\n return is(key, searchKey);\n }, undefined, notSetValue);\n },\n getIn: getIn$1,\n groupBy: function groupBy(grouper, context) {\n return groupByFactory(this, grouper, context);\n },\n has: function has(searchKey) {\n return this.get(searchKey, NOT_SET) !== NOT_SET;\n },\n hasIn: hasIn$1,\n isSubset: function isSubset(iter) {\n iter = typeof iter.includes === 'function' ? iter : Collection(iter);\n return this.every(function (value) {\n return iter.includes(value);\n });\n },\n isSuperset: function isSuperset(iter) {\n iter = typeof iter.isSubset === 'function' ? iter : Collection(iter);\n return iter.isSubset(this);\n },\n keyOf: function keyOf(searchValue) {\n return this.findKey(function (value) {\n return is(value, searchValue);\n });\n },\n keySeq: function keySeq() {\n return this.toSeq().map(keyMapper).toIndexedSeq();\n },\n last: function last(notSetValue) {\n return this.toSeq().reverse().first(notSetValue);\n },\n lastKeyOf: function lastKeyOf(searchValue) {\n return this.toKeyedSeq().reverse().keyOf(searchValue);\n },\n max: function max(comparator) {\n return maxFactory(this, comparator);\n },\n maxBy: function maxBy(mapper, comparator) {\n return maxFactory(this, comparator, mapper);\n },\n min: function min(comparator) {\n return maxFactory(this, comparator ? neg(comparator) : defaultNegComparator);\n },\n minBy: function minBy(mapper, comparator) {\n return maxFactory(this, comparator ? neg(comparator) : defaultNegComparator, mapper);\n },\n rest: function rest() {\n return this.slice(1);\n },\n skip: function skip(amount) {\n return amount === 0 ? this : this.slice(Math.max(0, amount));\n },\n skipLast: function skipLast(amount) {\n return amount === 0 ? this : this.slice(0, -Math.max(0, amount));\n },\n skipWhile: function skipWhile(predicate, context) {\n return reify(this, skipWhileFactory(this, predicate, context, true));\n },\n skipUntil: function skipUntil(predicate, context) {\n return this.skipWhile(not(predicate), context);\n },\n sortBy: function sortBy(mapper, comparator) {\n return reify(this, sortFactory(this, comparator, mapper));\n },\n take: function take(amount) {\n return this.slice(0, Math.max(0, amount));\n },\n takeLast: function takeLast(amount) {\n return this.slice(-Math.max(0, amount));\n },\n takeWhile: function takeWhile(predicate, context) {\n return reify(this, takeWhileFactory(this, predicate, context));\n },\n takeUntil: function takeUntil(predicate, context) {\n return this.takeWhile(not(predicate), context);\n },\n update: function update(fn) {\n return fn(this);\n },\n valueSeq: function valueSeq() {\n return this.toIndexedSeq();\n },\n // ### Hashable Object\n hashCode: function hashCode() {\n return this.__hash || (this.__hash = hashCollection(this));\n } // ### Internal\n // abstract __iterate(fn, reverse)\n // abstract __iterator(type, reverse)\n\n});\nvar CollectionPrototype = Collection.prototype;\nCollectionPrototype[IS_COLLECTION_SYMBOL] = true;\nCollectionPrototype[ITERATOR_SYMBOL] = CollectionPrototype.values;\nCollectionPrototype.toJSON = CollectionPrototype.toArray;\nCollectionPrototype.__toStringMapper = quoteString;\n\nCollectionPrototype.inspect = CollectionPrototype.toSource = function () {\n return this.toString();\n};\n\nCollectionPrototype.chain = CollectionPrototype.flatMap;\nCollectionPrototype.contains = CollectionPrototype.includes;\nmixin(KeyedCollection, {\n // ### More sequential methods\n flip: function flip() {\n return reify(this, flipFactory(this));\n },\n mapEntries: function mapEntries(mapper, context) {\n var this$1 = this;\n var iterations = 0;\n return reify(this, this.toSeq().map(function (v, k) {\n return mapper.call(context, [k, v], iterations++, this$1);\n }).fromEntrySeq());\n },\n mapKeys: function mapKeys(mapper, context) {\n var this$1 = this;\n return reify(this, this.toSeq().flip().map(function (k, v) {\n return mapper.call(context, k, v, this$1);\n }).flip());\n }\n});\nvar KeyedCollectionPrototype = KeyedCollection.prototype;\nKeyedCollectionPrototype[IS_KEYED_SYMBOL] = true;\nKeyedCollectionPrototype[ITERATOR_SYMBOL] = CollectionPrototype.entries;\nKeyedCollectionPrototype.toJSON = toObject;\n\nKeyedCollectionPrototype.__toStringMapper = function (v, k) {\n return quoteString(k) + ': ' + quoteString(v);\n};\n\nmixin(IndexedCollection, {\n // ### Conversion to other types\n toKeyedSeq: function toKeyedSeq() {\n return new ToKeyedSequence(this, false);\n },\n // ### ES6 Collection methods (ES6 Array and Map)\n filter: function filter(predicate, context) {\n return reify(this, filterFactory(this, predicate, context, false));\n },\n findIndex: function findIndex(predicate, context) {\n var entry = this.findEntry(predicate, context);\n return entry ? entry[0] : -1;\n },\n indexOf: function indexOf(searchValue) {\n var key = this.keyOf(searchValue);\n return key === undefined ? -1 : key;\n },\n lastIndexOf: function lastIndexOf(searchValue) {\n var key = this.lastKeyOf(searchValue);\n return key === undefined ? -1 : key;\n },\n reverse: function reverse() {\n return reify(this, reverseFactory(this, false));\n },\n slice: function slice(begin, end) {\n return reify(this, sliceFactory(this, begin, end, false));\n },\n splice: function splice(index, removeNum\n /*, ...values*/\n ) {\n var numArgs = arguments.length;\n removeNum = Math.max(removeNum || 0, 0);\n\n if (numArgs === 0 || numArgs === 2 && !removeNum) {\n return this;\n } // If index is negative, it should resolve relative to the size of the\n // collection. However size may be expensive to compute if not cached, so\n // only call count() if the number is in fact negative.\n\n\n index = resolveBegin(index, index < 0 ? this.count() : this.size);\n var spliced = this.slice(0, index);\n return reify(this, numArgs === 1 ? spliced : spliced.concat(arrCopy(arguments, 2), this.slice(index + removeNum)));\n },\n // ### More collection methods\n findLastIndex: function findLastIndex(predicate, context) {\n var entry = this.findLastEntry(predicate, context);\n return entry ? entry[0] : -1;\n },\n first: function first(notSetValue) {\n return this.get(0, notSetValue);\n },\n flatten: function flatten(depth) {\n return reify(this, flattenFactory(this, depth, false));\n },\n get: function get(index, notSetValue) {\n index = wrapIndex(this, index);\n return index < 0 || this.size === Infinity || this.size !== undefined && index > this.size ? notSetValue : this.find(function (_, key) {\n return key === index;\n }, undefined, notSetValue);\n },\n has: function has(index) {\n index = wrapIndex(this, index);\n return index >= 0 && (this.size !== undefined ? this.size === Infinity || index < this.size : this.indexOf(index) !== -1);\n },\n interpose: function interpose(separator) {\n return reify(this, interposeFactory(this, separator));\n },\n interleave: function interleave()\n /*...collections*/\n {\n var collections = [this].concat(arrCopy(arguments));\n var zipped = zipWithFactory(this.toSeq(), IndexedSeq.of, collections);\n var interleaved = zipped.flatten(true);\n\n if (zipped.size) {\n interleaved.size = zipped.size * collections.length;\n }\n\n return reify(this, interleaved);\n },\n keySeq: function keySeq() {\n return Range(0, this.size);\n },\n last: function last(notSetValue) {\n return this.get(-1, notSetValue);\n },\n skipWhile: function skipWhile(predicate, context) {\n return reify(this, skipWhileFactory(this, predicate, context, false));\n },\n zip: function zip()\n /*, ...collections */\n {\n var collections = [this].concat(arrCopy(arguments));\n return reify(this, zipWithFactory(this, defaultZipper, collections));\n },\n zipAll: function zipAll()\n /*, ...collections */\n {\n var collections = [this].concat(arrCopy(arguments));\n return reify(this, zipWithFactory(this, defaultZipper, collections, true));\n },\n zipWith: function zipWith(zipper\n /*, ...collections */\n ) {\n var collections = arrCopy(arguments);\n collections[0] = this;\n return reify(this, zipWithFactory(this, zipper, collections));\n }\n});\nvar IndexedCollectionPrototype = IndexedCollection.prototype;\nIndexedCollectionPrototype[IS_INDEXED_SYMBOL] = true;\nIndexedCollectionPrototype[IS_ORDERED_SYMBOL] = true;\nmixin(SetCollection, {\n // ### ES6 Collection methods (ES6 Array and Map)\n get: function get(value, notSetValue) {\n return this.has(value) ? value : notSetValue;\n },\n includes: function includes(value) {\n return this.has(value);\n },\n // ### More sequential methods\n keySeq: function keySeq() {\n return this.valueSeq();\n }\n});\nSetCollection.prototype.has = CollectionPrototype.includes;\nSetCollection.prototype.contains = SetCollection.prototype.includes; // Mixin subclasses\n\nmixin(KeyedSeq, KeyedCollection.prototype);\nmixin(IndexedSeq, IndexedCollection.prototype);\nmixin(SetSeq, SetCollection.prototype); // #pragma Helper functions\n\nfunction reduce(collection, reducer, reduction, context, useFirst, reverse) {\n assertNotInfinite(collection.size);\n\n collection.__iterate(function (v, k, c) {\n if (useFirst) {\n useFirst = false;\n reduction = v;\n } else {\n reduction = reducer.call(context, reduction, v, k, c);\n }\n }, reverse);\n\n return reduction;\n}\n\nfunction keyMapper(v, k) {\n return k;\n}\n\nfunction entryMapper(v, k) {\n return [k, v];\n}\n\nfunction not(predicate) {\n return function () {\n return !predicate.apply(this, arguments);\n };\n}\n\nfunction neg(predicate) {\n return function () {\n return -predicate.apply(this, arguments);\n };\n}\n\nfunction defaultZipper() {\n return arrCopy(arguments);\n}\n\nfunction defaultNegComparator(a, b) {\n return a < b ? 1 : a > b ? -1 : 0;\n}\n\nfunction hashCollection(collection) {\n if (collection.size === Infinity) {\n return 0;\n }\n\n var ordered = isOrdered(collection);\n var keyed = isKeyed(collection);\n var h = ordered ? 1 : 0;\n\n var size = collection.__iterate(keyed ? ordered ? function (v, k) {\n h = 31 * h + hashMerge(hash(v), hash(k)) | 0;\n } : function (v, k) {\n h = h + hashMerge(hash(v), hash(k)) | 0;\n } : ordered ? function (v) {\n h = 31 * h + hash(v) | 0;\n } : function (v) {\n h = h + hash(v) | 0;\n });\n\n return murmurHashOfSize(size, h);\n}\n\nfunction murmurHashOfSize(size, h) {\n h = imul(h, 0xcc9e2d51);\n h = imul(h << 15 | h >>> -15, 0x1b873593);\n h = imul(h << 13 | h >>> -13, 5);\n h = (h + 0xe6546b64 | 0) ^ size;\n h = imul(h ^ h >>> 16, 0x85ebca6b);\n h = imul(h ^ h >>> 13, 0xc2b2ae35);\n h = smi(h ^ h >>> 16);\n return h;\n}\n\nfunction hashMerge(a, b) {\n return a ^ b + 0x9e3779b9 + (a << 6) + (a >> 2) | 0; // int\n}\n\nvar OrderedSet =\n/*@__PURE__*/\nfunction (Set$$1) {\n function OrderedSet(value) {\n return value === null || value === undefined ? emptyOrderedSet() : isOrderedSet(value) ? value : emptyOrderedSet().withMutations(function (set) {\n var iter = SetCollection(value);\n assertNotInfinite(iter.size);\n iter.forEach(function (v) {\n return set.add(v);\n });\n });\n }\n\n if (Set$$1) OrderedSet.__proto__ = Set$$1;\n OrderedSet.prototype = Object.create(Set$$1 && Set$$1.prototype);\n OrderedSet.prototype.constructor = OrderedSet;\n\n OrderedSet.of = function of()\n /*...values*/\n {\n return this(arguments);\n };\n\n OrderedSet.fromKeys = function fromKeys(value) {\n return this(KeyedCollection(value).keySeq());\n };\n\n OrderedSet.prototype.toString = function toString() {\n return this.__toString('OrderedSet {', '}');\n };\n\n return OrderedSet;\n}(Set);\n\nOrderedSet.isOrderedSet = isOrderedSet;\nvar OrderedSetPrototype = OrderedSet.prototype;\nOrderedSetPrototype[IS_ORDERED_SYMBOL] = true;\nOrderedSetPrototype.zip = IndexedCollectionPrototype.zip;\nOrderedSetPrototype.zipWith = IndexedCollectionPrototype.zipWith;\nOrderedSetPrototype.__empty = emptyOrderedSet;\nOrderedSetPrototype.__make = makeOrderedSet;\n\nfunction makeOrderedSet(map, ownerID) {\n var set = Object.create(OrderedSetPrototype);\n set.size = map ? map.size : 0;\n set._map = map;\n set.__ownerID = ownerID;\n return set;\n}\n\nvar EMPTY_ORDERED_SET;\n\nfunction emptyOrderedSet() {\n return EMPTY_ORDERED_SET || (EMPTY_ORDERED_SET = makeOrderedSet(emptyOrderedMap()));\n}\n\nvar Record = function Record(defaultValues, name) {\n var hasInitialized;\n\n var RecordType = function Record(values) {\n var this$1 = this;\n\n if (values instanceof RecordType) {\n return values;\n }\n\n if (!(this instanceof RecordType)) {\n return new RecordType(values);\n }\n\n if (!hasInitialized) {\n hasInitialized = true;\n var keys = Object.keys(defaultValues);\n var indices = RecordTypePrototype._indices = {}; // Deprecated: left to attempt not to break any external code which\n // relies on a ._name property existing on record instances.\n // Use Record.getDescriptiveName() instead\n\n RecordTypePrototype._name = name;\n RecordTypePrototype._keys = keys;\n RecordTypePrototype._defaultValues = defaultValues;\n\n for (var i = 0; i < keys.length; i++) {\n var propName = keys[i];\n indices[propName] = i;\n\n if (RecordTypePrototype[propName]) {\n /* eslint-disable no-console */\n typeof console === 'object' && console.warn && console.warn('Cannot define ' + recordName(this) + ' with property \"' + propName + '\" since that property name is part of the Record API.');\n /* eslint-enable no-console */\n } else {\n setProp(RecordTypePrototype, propName);\n }\n }\n }\n\n this.__ownerID = undefined;\n this._values = List().withMutations(function (l) {\n l.setSize(this$1._keys.length);\n KeyedCollection(values).forEach(function (v, k) {\n l.set(this$1._indices[k], v === this$1._defaultValues[k] ? undefined : v);\n });\n });\n };\n\n var RecordTypePrototype = RecordType.prototype = Object.create(RecordPrototype);\n RecordTypePrototype.constructor = RecordType;\n\n if (name) {\n RecordType.displayName = name;\n }\n\n return RecordType;\n};\n\nRecord.prototype.toString = function toString() {\n var str = recordName(this) + ' { ';\n var keys = this._keys;\n var k;\n\n for (var i = 0, l = keys.length; i !== l; i++) {\n k = keys[i];\n str += (i ? ', ' : '') + k + ': ' + quoteString(this.get(k));\n }\n\n return str + ' }';\n};\n\nRecord.prototype.equals = function equals(other) {\n return this === other || other && this._keys === other._keys && recordSeq(this).equals(recordSeq(other));\n};\n\nRecord.prototype.hashCode = function hashCode() {\n return recordSeq(this).hashCode();\n}; // @pragma Access\n\n\nRecord.prototype.has = function has(k) {\n return this._indices.hasOwnProperty(k);\n};\n\nRecord.prototype.get = function get(k, notSetValue) {\n if (!this.has(k)) {\n return notSetValue;\n }\n\n var index = this._indices[k];\n\n var value = this._values.get(index);\n\n return value === undefined ? this._defaultValues[k] : value;\n}; // @pragma Modification\n\n\nRecord.prototype.set = function set(k, v) {\n if (this.has(k)) {\n var newValues = this._values.set(this._indices[k], v === this._defaultValues[k] ? undefined : v);\n\n if (newValues !== this._values && !this.__ownerID) {\n return makeRecord(this, newValues);\n }\n }\n\n return this;\n};\n\nRecord.prototype.remove = function remove(k) {\n return this.set(k);\n};\n\nRecord.prototype.clear = function clear() {\n var newValues = this._values.clear().setSize(this._keys.length);\n\n return this.__ownerID ? this : makeRecord(this, newValues);\n};\n\nRecord.prototype.wasAltered = function wasAltered() {\n return this._values.wasAltered();\n};\n\nRecord.prototype.toSeq = function toSeq() {\n return recordSeq(this);\n};\n\nRecord.prototype.toJS = function toJS$1() {\n return toJS(this);\n};\n\nRecord.prototype.entries = function entries() {\n return this.__iterator(ITERATE_ENTRIES);\n};\n\nRecord.prototype.__iterator = function __iterator(type, reverse) {\n return recordSeq(this).__iterator(type, reverse);\n};\n\nRecord.prototype.__iterate = function __iterate(fn, reverse) {\n return recordSeq(this).__iterate(fn, reverse);\n};\n\nRecord.prototype.__ensureOwner = function __ensureOwner(ownerID) {\n if (ownerID === this.__ownerID) {\n return this;\n }\n\n var newValues = this._values.__ensureOwner(ownerID);\n\n if (!ownerID) {\n this.__ownerID = ownerID;\n this._values = newValues;\n return this;\n }\n\n return makeRecord(this, newValues, ownerID);\n};\n\nRecord.isRecord = isRecord;\nRecord.getDescriptiveName = recordName;\nvar RecordPrototype = Record.prototype;\nRecordPrototype[IS_RECORD_SYMBOL] = true;\nRecordPrototype[DELETE] = RecordPrototype.remove;\nRecordPrototype.deleteIn = RecordPrototype.removeIn = deleteIn;\nRecordPrototype.getIn = getIn$1;\nRecordPrototype.hasIn = CollectionPrototype.hasIn;\nRecordPrototype.merge = merge;\nRecordPrototype.mergeWith = mergeWith;\nRecordPrototype.mergeIn = mergeIn;\nRecordPrototype.mergeDeep = mergeDeep$1;\nRecordPrototype.mergeDeepWith = mergeDeepWith$1;\nRecordPrototype.mergeDeepIn = mergeDeepIn;\nRecordPrototype.setIn = setIn$1;\nRecordPrototype.update = update$1;\nRecordPrototype.updateIn = updateIn$1;\nRecordPrototype.withMutations = withMutations;\nRecordPrototype.asMutable = asMutable;\nRecordPrototype.asImmutable = asImmutable;\nRecordPrototype[ITERATOR_SYMBOL] = RecordPrototype.entries;\nRecordPrototype.toJSON = RecordPrototype.toObject = CollectionPrototype.toObject;\n\nRecordPrototype.inspect = RecordPrototype.toSource = function () {\n return this.toString();\n};\n\nfunction makeRecord(likeRecord, values, ownerID) {\n var record = Object.create(Object.getPrototypeOf(likeRecord));\n record._values = values;\n record.__ownerID = ownerID;\n return record;\n}\n\nfunction recordName(record) {\n return record.constructor.displayName || record.constructor.name || 'Record';\n}\n\nfunction recordSeq(record) {\n return keyedSeqFromValue(record._keys.map(function (k) {\n return [k, record.get(k)];\n }));\n}\n\nfunction setProp(prototype, name) {\n try {\n Object.defineProperty(prototype, name, {\n get: function get() {\n return this.get(name);\n },\n set: function set(value) {\n invariant(this.__ownerID, 'Cannot set on an immutable record.');\n this.set(name, value);\n }\n });\n } catch (error) {// Object.defineProperty failed. Probably IE8.\n }\n}\n/**\n * Returns a lazy Seq of `value` repeated `times` times. When `times` is\n * undefined, returns an infinite sequence of `value`.\n */\n\n\nvar Repeat =\n/*@__PURE__*/\nfunction (IndexedSeq$$1) {\n function Repeat(value, times) {\n if (!(this instanceof Repeat)) {\n return new Repeat(value, times);\n }\n\n this._value = value;\n this.size = times === undefined ? Infinity : Math.max(0, times);\n\n if (this.size === 0) {\n if (EMPTY_REPEAT) {\n return EMPTY_REPEAT;\n }\n\n EMPTY_REPEAT = this;\n }\n }\n\n if (IndexedSeq$$1) Repeat.__proto__ = IndexedSeq$$1;\n Repeat.prototype = Object.create(IndexedSeq$$1 && IndexedSeq$$1.prototype);\n Repeat.prototype.constructor = Repeat;\n\n Repeat.prototype.toString = function toString() {\n if (this.size === 0) {\n return 'Repeat []';\n }\n\n return 'Repeat [ ' + this._value + ' ' + this.size + ' times ]';\n };\n\n Repeat.prototype.get = function get(index, notSetValue) {\n return this.has(index) ? this._value : notSetValue;\n };\n\n Repeat.prototype.includes = function includes(searchValue) {\n return is(this._value, searchValue);\n };\n\n Repeat.prototype.slice = function slice(begin, end) {\n var size = this.size;\n return wholeSlice(begin, end, size) ? this : new Repeat(this._value, resolveEnd(end, size) - resolveBegin(begin, size));\n };\n\n Repeat.prototype.reverse = function reverse() {\n return this;\n };\n\n Repeat.prototype.indexOf = function indexOf(searchValue) {\n if (is(this._value, searchValue)) {\n return 0;\n }\n\n return -1;\n };\n\n Repeat.prototype.lastIndexOf = function lastIndexOf(searchValue) {\n if (is(this._value, searchValue)) {\n return this.size;\n }\n\n return -1;\n };\n\n Repeat.prototype.__iterate = function __iterate(fn, reverse) {\n var size = this.size;\n var i = 0;\n\n while (i !== size) {\n if (fn(this._value, reverse ? size - ++i : i++, this) === false) {\n break;\n }\n }\n\n return i;\n };\n\n Repeat.prototype.__iterator = function __iterator(type, reverse) {\n var this$1 = this;\n var size = this.size;\n var i = 0;\n return new Iterator(function () {\n return i === size ? iteratorDone() : iteratorValue(type, reverse ? size - ++i : i++, this$1._value);\n });\n };\n\n Repeat.prototype.equals = function equals(other) {\n return other instanceof Repeat ? is(this._value, other._value) : deepEqual(other);\n };\n\n return Repeat;\n}(IndexedSeq);\n\nvar EMPTY_REPEAT;\n\nfunction fromJS(value, converter) {\n return fromJSWith([], converter || defaultConverter, value, '', converter && converter.length > 2 ? [] : undefined, {\n '': value\n });\n}\n\nfunction fromJSWith(stack, converter, value, key, keyPath, parentValue) {\n var toSeq = Array.isArray(value) ? IndexedSeq : isPlainObj(value) ? KeyedSeq : null;\n\n if (toSeq) {\n if (~stack.indexOf(value)) {\n throw new TypeError('Cannot convert circular structure to Immutable');\n }\n\n stack.push(value);\n keyPath && key !== '' && keyPath.push(key);\n var converted = converter.call(parentValue, key, toSeq(value).map(function (v, k) {\n return fromJSWith(stack, converter, v, k, keyPath, value);\n }), keyPath && keyPath.slice());\n stack.pop();\n keyPath && keyPath.pop();\n return converted;\n }\n\n return value;\n}\n\nfunction defaultConverter(k, v) {\n return isKeyed(v) ? v.toMap() : v.toList();\n}\n\nvar version = \"4.0.0-rc.11\";\nvar Immutable = {\n version: version,\n Collection: Collection,\n // Note: Iterable is deprecated\n Iterable: Collection,\n Seq: Seq,\n Map: Map,\n OrderedMap: OrderedMap,\n List: List,\n Stack: Stack,\n Set: Set,\n OrderedSet: OrderedSet,\n Record: Record,\n Range: Range,\n Repeat: Repeat,\n is: is,\n fromJS: fromJS,\n hash: hash,\n isImmutable: isImmutable,\n isCollection: isCollection,\n isKeyed: isKeyed,\n isIndexed: isIndexed,\n isAssociative: isAssociative,\n isOrdered: isOrdered,\n isValueObject: isValueObject,\n isSeq: isSeq,\n isList: isList,\n isMap: isMap,\n isOrderedMap: isOrderedMap,\n isStack: isStack,\n isSet: isSet,\n isOrderedSet: isOrderedSet,\n isRecord: isRecord,\n get: get,\n getIn: getIn,\n has: has,\n hasIn: hasIn,\n merge: merge$1,\n mergeDeep: mergeDeep,\n mergeWith: mergeWith$1,\n mergeDeepWith: mergeDeepWith,\n remove: remove,\n removeIn: removeIn,\n set: set,\n setIn: setIn,\n update: update,\n updateIn: updateIn\n}; // Note: Iterable is deprecated\n\nvar Iterable = Collection;\nexport default Immutable;\nexport { version, Collection, Iterable, Seq, Map, OrderedMap, List, Stack, Set, OrderedSet, Record, Range, Repeat, is, fromJS, hash, isImmutable, isCollection, isKeyed, isIndexed, isAssociative, isOrdered, isValueObject, get, getIn, has, hasIn, merge$1 as merge, mergeDeep, mergeWith$1 as mergeWith, mergeDeepWith, remove, removeIn, set, setIn, update, updateIn };","module.exports = __webpack_public_path__ + \"static/3099-106ad650051d8e7257944f3f88941e85.jpg\";","module.exports = __webpack_public_path__ + \"static/3094-39055759ed313b0ef0fe8d6cc3bde027.jpg\";","module.exports = __webpack_public_path__ + \"static/3050-6d4c4d3b22afb002b1d26ae7e961889a.jpg\";","module.exports = __webpack_public_path__ + \"static/1135-65d29beea47c971e2e2cb828c562ede1.jpg\";","import { Map } from 'immutable'\r\n\r\nimport { boundsOverlap } from 'util/map'\r\nimport { splitWords } from 'util/format'\r\nimport { classify } from 'util/data'\r\nimport {\r\n estuaryTypes,\r\n sizeClasses,\r\n sizeClassLabels,\r\n regions,\r\n states,\r\n stateNames,\r\n nfhpCodes,\r\n nfhpLabels,\r\n species,\r\n bioticTypes,\r\n bioticInfo,\r\n sppCountClasses,\r\n sppCountClassLabels,\r\n twlBins,\r\n twlBinLabels,\r\n twrLabels,\r\n} from './constants'\r\n\r\n/**\r\n * Filter configuration.\r\n * Each non-internal field is shown to the user in the order defined below.\r\n *\r\n * IMPORTANT: each record is an `immutableJS` `Map` object - you must use `Map`\r\n * methods for retrieving field values.\r\n * See: https://immutable-js.github.io/immutable-js/docs/#/Map\r\n *\r\n *\r\n * Each filter must have: `{field, filterFunc}`\r\n *\r\n * `field` - the name of the field in the record.\r\n *\r\n * `filterFunc` (function) - a function that takes as input a list of filter\r\n * values selected by the user, and returns a function that\r\n * takes a value from each record in the data and returns true\r\n * if the value is included in the filter and false otherwise.\r\n *\r\n *\r\n * Each filter that is displayed using filter bars (`internal: false`)\r\n * must have: `{values, labels}` as well.\r\n *\r\n * Optional properties:\r\n * `isOpen` (bool) - if `true` show the filter in expanded state by default. (default: `false`)\r\n *\r\n * `getValue` (function) - takes a record as input and returns\r\n * the value for that field. It can transform the value as needed.\r\n * (default: returns the value for the `field`)\r\n * NOTE: `getValue` MUST return a native JS type, NOT an `immutableJS` type.\r\n *\r\n * `internal` (bool) - if `true` will not be displayed in the list\r\n * of filters shown to the user, but will still be added as a\r\n * filter (e.g., map bounds for filtering records). (default: `false`)\r\n *\r\n * `isArray` - if `true`, the record has an array of values for that field\r\n * instead of a single value. Crossfilter will index that record on each of those\r\n * values, so you can test the record to determine if it is in the filter in\r\n * the same way that you would test a field with a singular value.\r\n * See: https://github.com/crossfilter/crossfilter/wiki/API-Reference#dimension_with_arrays\r\n *\r\n * NOTE: `List` objects for this field will be automatically converted to native `Array`s by default unless\r\n * you provide your own `getValue` function. If so, you MUST return a native `Array`.\r\n */\r\n\r\n// TODO: migrate this into crossfilter reducer as the default\r\n// returns true if passed in values contains the value\r\n// values must be a Set\r\nconst hasValue = filterValues => value => filterValues.has(value)\r\n\r\nexport const filters = [\r\n {\r\n field: 'name',\r\n internal: true,\r\n getValue: record => record.get('name').toLowerCase(),\r\n filterFunc: value => name => name.includes(value.toLowerCase()),\r\n },\r\n {\r\n field: 'bounds',\r\n internal: true,\r\n filterFunc: mapBounds => estuaryBounds =>\r\n boundsOverlap(mapBounds, estuaryBounds),\r\n },\r\n {\r\n field: 'type',\r\n title: 'Estuary Type',\r\n values: Object.keys(estuaryTypes).map(type => parseInt(type, 10)),\r\n labels: Object.values(estuaryTypes).map(({ label }) => label),\r\n filterFunc: hasValue,\r\n },\r\n {\r\n field: 'sizeClass',\r\n title: 'Estuary Size Class',\r\n values: sizeClasses.map((_, idx) => idx), // store the index of the size class for filtering\r\n labels: sizeClassLabels,\r\n getValue: record => classify(record.get('acres'), sizeClasses),\r\n filterFunc: hasValue,\r\n },\r\n {\r\n field: 'species',\r\n title: 'Focal Species Present',\r\n description:\r\n 'These ecologically and economically important fish and invertebrate species were selected to encompass the diversity of life histories, habitat use, and ecological roles of species found in estuaries along the West Coast.',\r\n moreInfoURL:\r\n 'http://www.pacificfishhabitat.org/wp-content/uploads/2017/09/tnc_ca_fishnurseries_lowres_min.pdf',\r\n values: species,\r\n labels: species.map(splitWords),\r\n // getValue: record => record.get('species').map(spp => spp.split(':')[0]),\r\n getValue: record =>\r\n record\r\n .get('species', Map())\r\n .keySeq()\r\n .toArray(),\r\n filterFunc: hasValue,\r\n isArray: true,\r\n },\r\n {\r\n field: 'numSpps',\r\n title: 'Number of Focal Species Present',\r\n values: sppCountClasses,\r\n labels: sppCountClassLabels,\r\n getValue: record => {\r\n // if SoKJoin == 3, this is not inventoried\r\n if (record.get('SoKJoin') === 3) return -1\r\n\r\n const count = record.get('species', Map()).size\r\n if (count >= 10) return 10\r\n if (count >= 6) return 6\r\n if (count > 0) return 1\r\n return 0\r\n },\r\n filterFunc: hasValue,\r\n },\r\n {\r\n field: 'region',\r\n title: 'PMEP Region',\r\n values: regions,\r\n labels: regions,\r\n filterFunc: hasValue,\r\n },\r\n {\r\n field: 'state',\r\n title: 'State',\r\n values: states.map(state => stateNames[state]),\r\n labels: states.map(state => stateNames[state]),\r\n // index the estuaries that cross state boundaries in each state\r\n getValue: record => stateNames[record.get('state')].split(' / '),\r\n filterFunc: hasValue,\r\n isArray: true,\r\n },\r\n\r\n {\r\n field: 'biotic',\r\n title: 'Estuarine Biotic Habitats Present',\r\n values: bioticTypes,\r\n labels: bioticTypes.map(b => bioticInfo[b].label),\r\n // flatten the keys of the biotic types present into an Array\r\n getValue: record =>\r\n record\r\n .get('biotic', Map())\r\n .keySeq()\r\n .toArray(),\r\n filterFunc: hasValue,\r\n isArray: true,\r\n },\r\n {\r\n field: 'twl',\r\n title: 'Tidal Wetland Loss',\r\n description:\r\n 'Vegetated tidal wetland loss was assessed by comparing the current extent of tidal wetlands in the National Wetland Inventory to the historical estuary extent shown in this tool. The latest version of this assessment also includes identification of restored tidal wetlands.',\r\n moreInfoURL:\r\n 'http://www.pacificfishhabitat.org/data/tidal-wetlands-loss-assessment',\r\n getValue: record => {\r\n const twAcres = record.get('twAcres')\r\n const twlAcres = record.get('twlAcres')\r\n\r\n // 999 means not assessed\r\n const percent = twAcres ? Math.min(100, (100 * twlAcres) / twAcres) : 999\r\n return twlBins.findIndex(bin => percent < bin)\r\n },\r\n // store the index of the bin\r\n values: twlBins.map((_, i) => i),\r\n labels: twlBinLabels,\r\n filterFunc: hasValue,\r\n },\r\n {\r\n field: 'nfhp2015',\r\n title: 'Risk of Fish Habitat Degradation (2015)',\r\n description:\r\n 'This assessment used a cumulative disturbance index to estimate risk of fish habitat degradation in estuarine habitats.',\r\n moreInfoURL: 'http://assessment.fishhabitat.org/',\r\n values: nfhpCodes,\r\n labels: nfhpLabels,\r\n filterFunc: hasValue,\r\n },\r\n]\r\n","module.exports = __webpack_public_path__ + \"static/1070-1c960a172120e2dafe0a9f3b9c45ff38.jpg\";","module.exports = __webpack_public_path__ + \"static/3035-01d60120660e7bd971c26082ecfa2a36.jpg\";","module.exports = __webpack_public_path__ + \"static/4040-a59d716b6f822e309cd238a1cb304cd4.jpg\";","module.exports = __webpack_public_path__ + \"static/1035-228ba42524d33a5c29bbc73338e701a1.jpg\";","module.exports = __webpack_public_path__ + \"static/1154-e0ba8b070f014618773511b80198480b.jpg\";","module.exports = __webpack_public_path__ + \"static/1033-dc65a2751c80b60dc263e04af6628aec.jpg\";","module.exports = __webpack_public_path__ + \"static/1091-1159f9b672d66a6340100735743a391e.jpg\";","module.exports = __webpack_public_path__ + \"static/1164-2b3182fa3b90cc2a763412df4cc78037.jpg\";","module.exports = __webpack_public_path__ + \"static/1160-9ba8522c3300bee21e97546040b13b60.jpg\";","module.exports = __webpack_public_path__ + \"static/2010-c6322c2f5d0d12dc749f466f7f7c39aa.jpg\";","module.exports = __webpack_public_path__ + \"static/lagoonal-9aaa0b105b16c068a86c95b188c1d7a9.svg\";","var DESCRIPTORS = require('../internals/descriptors');\nvar definePropertyModule = require('../internals/object-define-property');\nvar anObject = require('../internals/an-object');\nvar objectKeys = require('../internals/object-keys');\n\n// `Object.defineProperties` method\n// https://tc39.github.io/ecma262/#sec-object.defineproperties\nmodule.exports = DESCRIPTORS ? Object.defineProperties : function defineProperties(O, Properties) {\n anObject(O);\n var keys = objectKeys(Properties);\n var length = keys.length;\n var index = 0;\n var key;\n while (length > index) definePropertyModule.f(O, key = keys[index++], Properties[key]);\n return O;\n};\n","module.exports = __webpack_public_path__ + \"static/1075-8585994f4cf2c03f1877ae7cd9d81a6a.jpg\";","module.exports = __webpack_public_path__ + \"static/1084-59252cd7d5dbf765211e8d2a2e319a11.jpg\";","module.exports = __webpack_public_path__ + \"static/2063-b1aa9a086579f07cd403c7654c7fa441.jpg\";","module.exports = __webpack_public_path__ + \"static/1109-aa638d1b377df454007efc59a70b42bc.jpg\";","module.exports = __webpack_public_path__ + \"static/1106-52792497f2d408d8a88eeb114a654d16.jpg\";","module.exports = __webpack_public_path__ + \"static/4006-ac1d6214a3b6d2ea32fc8709fe9cb7b0.jpg\";","module.exports = __webpack_public_path__ + \"static/4012-5443a127c21fe6fb4894c2f63ae77c1b.jpg\";","module.exports = __webpack_public_path__ + \"static/1011-105581d3cc4ef47636de4fb107ec6bbd.jpg\";","module.exports = __webpack_public_path__ + \"static/1053-06a3273715dd6d82005a59899b1eeee6.jpg\";","module.exports = __webpack_public_path__ + \"static/4056-33be3669dc316d58f5fc91fd63af492c.jpg\";","module.exports = __webpack_public_path__ + \"static/3087-ef9c30f47f4cdc1532aee73f05a1ddc2.jpg\";","module.exports = __webpack_public_path__ + \"static/4020-66a1c7331930548db11aaec570f07302.jpg\";","module.exports = __webpack_public_path__ + \"static/3024-458f0738f9f3518bc1b229f26e38f4c0.jpg\";","module.exports = __webpack_public_path__ + \"static/2064-985da16d587e55d4088eb989d7350822.jpg\";","module.exports = __webpack_public_path__ + \"static/4027-5c86093199097533494a49252f5881b7.jpg\";","module.exports = __webpack_public_path__ + \"static/3034-f8442734170d6dc58570522a77828e52.jpg\";","module.exports = __webpack_public_path__ + \"static/3052-cd6bed6a8a4bc4b346f0027bd1db060d.jpg\";","module.exports = __webpack_public_path__ + \"static/1039-77d0f4be47a84f23817aa4241d04347e.jpg\";","module.exports = __webpack_public_path__ + \"static/2096-c220a2f1953837c1d67bea1600840e78.jpg\";","module.exports = __webpack_public_path__ + \"static/3100-bb5d9eb2b4530e5c0e61cacac4f0b864.jpg\";","module.exports = __webpack_public_path__ + \"static/1034-059256fec7de884fc5bbce55398d7463.jpg\";","module.exports = __webpack_public_path__ + \"static/1001-3bdb2e28ceefcdec970e1efe4eaed589.jpg\";","module.exports = __webpack_public_path__ + \"static/1104-66676a564d3b49565a85299aa4192fd5.jpg\";","module.exports = __webpack_public_path__ + \"static/2047-905f34cb86c8947b9ffe84949ef2f5c7.jpg\";","module.exports = __webpack_public_path__ + \"static/2083-f294e4b5f3866c0fea3f2aa8dc9d5ed3.jpg\";","module.exports = __webpack_public_path__ + \"static/3061-c22c0bcd52caeedf62eda9966f9809e0.jpg\";","module.exports = __webpack_public_path__ + \"static/3020-edaf47330692fc981d138ad3672ef622.jpg\";","module.exports = __webpack_public_path__ + \"static/1163-347122e9f71420509cfa8e9b5e34120f.jpg\";","module.exports = __webpack_public_path__ + \"static/1049-82b92ed0bea4fc0c2eeac987ef95cc94.jpg\";","module.exports = __webpack_public_path__ + \"static/3080-9c320451e1d1deedd515efce988d4a6e.jpg\";","module.exports = __webpack_public_path__ + \"static/3088-ccb0dcb8093f2701952d87ac0c06d95e.jpg\";","module.exports = __webpack_public_path__ + \"static/2076-0df7e4133d736b17ac99e08962db51d9.jpg\";","module.exports = __webpack_public_path__ + \"static/2041-e8d5ee3d56bec14ed4b9105a0bf3155a.jpg\";","module.exports = __webpack_public_path__ + \"static/2060-df76dc0915a26c8c21523b3e6b93405d.jpg\";","import React from 'react'\r\nimport PropTypes from 'prop-types'\r\n\r\nconst FaIcon = ({ name, size, ...props }) => {\r\n const iconName = `Fa${name.slice(0, 1).toUpperCase()}${name.slice(1)}`\r\n const Icon = require('react-icons/fa')[iconName]\r\n\r\n if (!Icon) return null\r\n\r\n return \r\n}\r\n\r\nFaIcon.propTypes = {\r\n name: PropTypes.string.isRequired,\r\n size: PropTypes.string,\r\n}\r\n\r\nFaIcon.defaultProps = {\r\n size: null,\r\n}\r\n\r\nexport default FaIcon\r\n","module.exports = __webpack_public_path__ + \"static/4019-c2faa1ea3d83de05eb6688d80a1eb701.jpg\";","module.exports = __webpack_public_path__ + \"static/2066-bac8dccab9120a3cd7b5cb86a3b884b7.jpg\";","module.exports = __webpack_public_path__ + \"static/4058-57ce8f9762915b907ba6786edf22af74.jpg\";","import React from 'react'\r\nimport PropTypes from 'prop-types'\r\nimport { Button as BaseButton } from 'rebass'\r\n\r\nimport styled from 'util/style'\r\n\r\nexport const DefaultButton = styled(BaseButton).attrs({\r\n variant: 'default',\r\n})`\r\n opacity: 1;\r\n transition: opacity 0.25s linear;\r\n border-radius: 0.25em;\r\n font-weight: normal;\r\n\r\n &:hover {\r\n opacity: 0.8;\r\n }\r\n\r\n &:disabled {\r\n opacity: 0.3 !important;\r\n cursor: not-allowed;\r\n }\r\n`\r\n\r\nexport const PrimaryButton = styled(DefaultButton).attrs({\r\n variant: 'primary',\r\n})``\r\n\r\nexport const SecondaryButton = styled(DefaultButton).attrs({\r\n variant: 'secondary',\r\n})``\r\n\r\nexport const WarningButton = styled(DefaultButton).attrs({\r\n variant: 'warning',\r\n})``\r\n\r\nexport const Button = ({\r\n children,\r\n primary,\r\n secondary,\r\n disabled,\r\n warning,\r\n onClick,\r\n ...props\r\n}) => {\r\n let StyledButton = null\r\n if (primary) {\r\n StyledButton = PrimaryButton\r\n } else if (secondary) {\r\n StyledButton = SecondaryButton\r\n } else if (warning) {\r\n StyledButton = WarningButton\r\n } else {\r\n StyledButton = DefaultButton\r\n }\r\n\r\n return (\r\n \r\n {children}\r\n \r\n )\r\n}\r\n\r\nButton.propTypes = {\r\n children: PropTypes.node.isRequired,\r\n primary: PropTypes.bool,\r\n secondary: PropTypes.bool,\r\n disabled: PropTypes.bool,\r\n warning: PropTypes.bool,\r\n onClick: PropTypes.func,\r\n}\r\n\r\nButton.defaultProps = {\r\n primary: false,\r\n secondary: false,\r\n disabled: false,\r\n warning: false,\r\n onClick: () => {},\r\n}\r\n\r\nexport default Button\r\n","import { Flex } from 'components/Grid'\r\nimport styled from 'util/style'\r\n\r\nconst ButtonGroup = styled(Flex).attrs({ alignItems: 'center' })`\r\n button:first-child {\r\n border-radius: 6px 0 0 6px;\r\n }\r\n button:last-child {\r\n border-radius: 0 6px 6px 0;\r\n }\r\n button:not(:first-child):not(:last-child) {\r\n border-radius: 0;\r\n }\r\n button + button {\r\n border-left: 1px solid #fff;\r\n }\r\n`\r\n\r\nexport default ButtonGroup\r\n","import React, { memo } from 'react'\r\nimport PropTypes from 'prop-types'\r\n\r\nimport styled, { themeGet } from 'util/style'\r\nimport { DefaultButton, PrimaryButton } from './Button'\r\nimport ButtonGroup from './ButtonGroup'\r\n\r\nconst Button = styled(PrimaryButton)`\r\n flex: 1 1 auto;\r\n`\r\n\r\nconst InactiveButton = styled(DefaultButton)`\r\n background-color: ${themeGet('colors.primary.100')};\r\n color: ${themeGet('colors.grey.900')};\r\n flex: 1 1 auto;\r\n`\r\n\r\nconst ToggleButton = ({ value, options, onChange, ...props }) => {\r\n const handleClick = newValue => {\r\n if (newValue === value) return\r\n\r\n onChange(newValue)\r\n }\r\n\r\n if (value === null)\r\n return (\r\n \r\n {options.map(({ value: v, label }) => (\r\n handleClick(v)}>\r\n {label}\r\n \r\n ))}\r\n \r\n )\r\n\r\n return (\r\n \r\n {options.map(({ value: v, label }) =>\r\n v === value ? (\r\n \r\n ) : (\r\n handleClick(v)}>\r\n {label}\r\n \r\n )\r\n )}\r\n \r\n )\r\n}\r\n\r\nToggleButton.propTypes = {\r\n value: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),\r\n options: PropTypes.arrayOf(\r\n PropTypes.shape({\r\n value: PropTypes.oneOfType([PropTypes.string, PropTypes.number])\r\n .isRequired,\r\n label: PropTypes.string.isRequired,\r\n })\r\n ).isRequired,\r\n onChange: PropTypes.func.isRequired,\r\n}\r\n\r\nToggleButton.defaultProps = {\r\n value: null,\r\n}\r\n\r\nexport default memo(\r\n ToggleButton,\r\n ({ value: prevValue }, { value: nextValue }) => prevValue === nextValue\r\n)\r\n","module.exports = __webpack_public_path__ + \"static/2095-cd14fe56ba1a4a7a129eed0698ac01a3.jpg\";","module.exports = __webpack_public_path__ + \"static/4014-3ab3d06d2c6d5ca9bfca02e2667487df.jpg\";","module.exports = __webpack_public_path__ + \"static/1093-9e678176e3abb1a711bb67de16994b3e.jpg\";","module.exports = __webpack_public_path__ + \"static/3001-9ede0258a35f646f4506eac49441f98e.jpg\";","module.exports = __webpack_public_path__ + \"static/3072-240ac6bccfcec34da2bb5aeca0ad948c.jpg\";","module.exports = __webpack_public_path__ + \"static/2021-ae588930eadcc46be6ca4795d9fa144f.jpg\";","module.exports = __webpack_public_path__ + \"static/1043-edbfa19cda4d7aaaaa709b3b05b54144.jpg\";","module.exports = __webpack_public_path__ + \"static/2031-0e9512f0f2b4cd661a97d368fb058216.jpg\";","module.exports = __webpack_public_path__ + \"static/1006-d82318c84f29b5cfe166320ee8618464.jpg\";","module.exports = __webpack_public_path__ + \"static/1045-4efd3437a2ae4433ed3299a713d3b920.jpg\";","module.exports = __webpack_public_path__ + \"static/2038-a1213d10acb6a4f095652754ebdacf32.jpg\";","import React, { memo } from 'react'\r\nimport PropTypes from 'prop-types'\r\n\r\nimport styled, { themeGet } from 'util/style'\r\n\r\nconst InactiveButton = styled.div`\r\n text-align: center;\r\n cursor: pointer;\r\n flex-grow: 1;\r\n padding: 0.25rem 0.5rem;\r\n color: ${themeGet('colors.grey.700')};\r\n border-bottom: 1px solid ${themeGet('colors.grey.200')};\r\n &:hover {\r\n background-color: ${themeGet('colors.grey.200')};\r\n }\r\n`\r\n\r\nconst ActiveButton = styled(InactiveButton)`\r\n font-weight: bold;\r\n color: ${themeGet('colors.grey.900')};\r\n border-bottom-color: transparent;\r\n background-color: #fff !important;\r\n &:not(:first-child) {\r\n border-left: 1px solid ${themeGet('colors.grey.200')};\r\n }\r\n &:not(:last-child) {\r\n border-right: 1px solid ${themeGet('colors.grey.200')};\r\n }\r\n`\r\n\r\nconst Button = ({ id, label, active, onClick }) => {\r\n const handleClick = () => {\r\n onClick(id)\r\n }\r\n return active ? (\r\n {label}\r\n ) : (\r\n {label}\r\n )\r\n}\r\n\r\nButton.propTypes = {\r\n id: PropTypes.string.isRequired,\r\n label: PropTypes.string.isRequired,\r\n active: PropTypes.bool,\r\n onClick: PropTypes.func.isRequired,\r\n}\r\n\r\nButton.defaultProps = {\r\n active: false,\r\n}\r\n\r\nexport default memo(\r\n Button,\r\n ({ id: prevId, active: prevActive }, { id: nextId, active: nextActive }) =>\r\n prevId === nextId && prevActive === nextActive\r\n)\r\n","import React, { useState, memo } from 'react'\r\nimport PropTypes from 'prop-types'\r\n\r\nimport { Flex } from 'components/Grid'\r\nimport styled, { themeGet } from 'util/style'\r\nimport Button from './Button'\r\n\r\nconst Wrapper = styled(Flex).attrs({\r\n alignItem: 'center',\r\n justifyContent: 'space-between',\r\n flex: 0,\r\n})`\r\n /* border-top: 1px solid ${themeGet('colors.grey.200')}; */\r\n background-color: ${themeGet('colors.grey.100')};\r\n`\r\n\r\nconst TabBar = ({ tabs, activeTab, onChange }) => {\r\n const handleClick = id => {\r\n if (id !== activeTab) {\r\n onChange(id)\r\n }\r\n }\r\n return (\r\n \r\n {tabs.map(tab => (\r\n \r\n ))}\r\n \r\n )\r\n}\r\n\r\nTabBar.propTypes = {\r\n tabs: PropTypes.arrayOf(\r\n PropTypes.shape({\r\n id: PropTypes.string.isRequired,\r\n label: PropTypes.string.isRequired,\r\n })\r\n ).isRequired,\r\n activeTab: PropTypes.string.isRequired,\r\n onChange: PropTypes.func,\r\n}\r\n\r\nTabBar.defaultProps = {\r\n onChange: () => {},\r\n}\r\n\r\nexport default memo(\r\n TabBar,\r\n (\r\n { tabs: prevTabs, activeTab: prevTab },\r\n { tabs: nextTabs, activeTab: nextTab }\r\n ) => prevTabs === nextTabs && prevTab === nextTab\r\n)\r\n","import { Children } from 'react'\r\nimport PropTypes from 'prop-types'\r\n\r\n/**\r\n * Wrapper around tabs to return the tab that is active.\r\n *\r\n * @param {Array of nodes} children - child nodes, each must have an `id` prop\r\n * @param {String} activeTab - `id` of the active tab\r\n */\r\nconst TabContainer = ({ children, activeTab }) => {\r\n const [activeChild] = Children.toArray(children).filter(\r\n ({ props: { id } }) => id === activeTab\r\n )\r\n return activeChild || null\r\n}\r\n\r\nTabContainer.propTypes = {\r\n children: PropTypes.arrayOf(PropTypes.node).isRequired,\r\n activeTab: PropTypes.string.isRequired,\r\n}\r\n\r\nexport default TabContainer\r\n","import React from 'react'\r\nimport PropTypes from 'prop-types'\r\n\r\nconst Tab = ({ id, children, ...props }) =>
{children}
\r\n\r\nTab.propTypes = {\r\n id: PropTypes.string.isRequired,\r\n children: PropTypes.oneOfType([\r\n PropTypes.node,\r\n PropTypes.element,\r\n PropTypes.array,\r\n ]).isRequired,\r\n}\r\n\r\nexport default Tab\r\n","import React, { useState } from 'react'\r\nimport PropTypes from 'prop-types'\r\n\r\nimport { Flex } from 'components/Grid'\r\nimport styled from 'util/style'\r\n\r\nimport TabBar from './TabBar'\r\nimport TabContainer from './TabContainer'\r\nimport Tab from './Tab'\r\n\r\nconst Wrapper = styled(Flex).attrs({\r\n flexDirection: 'column',\r\n})``\r\n\r\nconst Tabs = ({ children, ...props }) => {\r\n const tabs = children.map(({ props: { id, label } }) => ({ id, label }))\r\n const firstTab = tabs[0].id\r\n\r\n const [tab, setTab] = useState(firstTab)\r\n\r\n const handleTabChange = id => {\r\n setTab(id)\r\n }\r\n\r\n return (\r\n \r\n \r\n {children}\r\n \r\n )\r\n}\r\n\r\nTabs.propTypes = {\r\n children: PropTypes.arrayOf(PropTypes.node).isRequired,\r\n}\r\n\r\nexport { Tab, TabBar, TabContainer }\r\n\r\nexport default Tabs\r\n","import React from 'react'\r\nimport PropTypes from 'prop-types'\r\n\r\nimport { OutboundLink } from 'components/Link'\r\nimport HelpText from 'components/elements/HelpText'\r\nimport styled, { themeGet } from 'util/style'\r\nimport { splitWords } from 'util/format'\r\nimport { sppEOLIDs } from '../../../config/constants'\r\n\r\nconst Header = styled(HelpText)`\r\n margin-bottom: 2rem;\r\n`\r\n\r\nconst List = styled.ul`\r\n line-height: 1.2;\r\n li {\r\n margin: 0;\r\n\r\n & + li {\r\n margin-top: 0.5rem;\r\n }\r\n }\r\n`\r\n\r\nconst Stage = styled.span`\r\n margin-left: 0.5em;\r\n font-size: 0.9rem;\r\n font-style: italic;\r\n color: ${themeGet('colors.grey.700')};\r\n`\r\n\r\nconst Section = styled.section`\r\n margin-top: 1rem;\r\n padding-top: 1rem;\r\n border-top: 1px solid ${themeGet('colors.grey.200')};\r\n`\r\n\r\nconst SoKLink = () => (\r\n \r\n 2014 State of the Knowledge Report.\r\n \r\n)\r\n\r\nconst SpeciesList = ({ species: data, status }) => {\r\n // not inventoried\r\n if (status === 3) {\r\n return (\r\n \r\n This estuary was not inventoried for species in the \r\n \r\n )\r\n }\r\n\r\n const entries = Object.entries(data).map(([species, stage]) => ({\r\n species,\r\n stage,\r\n }))\r\n\r\n // sort by name\r\n entries.sort((a, b) => (a.species > b.species ? 1 : -1))\r\n\r\n const juvenileCount = entries.filter(({ stage }) => stage === 'JP').length\r\n\r\n let statusNote = null\r\n\r\n if (status === 1) {\r\n statusNote = (\r\n \r\n This estuary was inventoried for species in the \r\n \r\n )\r\n } else {\r\n statusNote = (\r\n \r\n This estuary was inventoried as part of a larger estuary system or\r\n sub-basin containing this particular estuary for the \r\n \r\n )\r\n }\r\n\r\n return (\r\n <>\r\n {entries.length > 0 ? (\r\n <>\r\n
\r\n There are {entries.length} focal species that have been\r\n inventoried in this estuary. {juvenileCount} use the estuary\r\n mostly in their juvenile stage.\r\n
\r\n \r\n {entries.map(({ species, stage }) => (\r\n
  • \r\n \r\n {splitWords(species)}\r\n {stage === 'JP' && (juvenile)}\r\n \r\n
  • \r\n ))}\r\n
    \r\n \r\n ) : (\r\n No focal species present\r\n )}\r\n\r\n
    {statusNote}
    \r\n \r\n )\r\n}\r\n\r\nSpeciesList.propTypes = {\r\n species: PropTypes.objectOf(PropTypes.string).isRequired,\r\n status: PropTypes.number.isRequired,\r\n}\r\n\r\nexport default SpeciesList\r\n","import React, { useState } from 'react'\r\nimport PropTypes from 'prop-types'\r\nimport { FaCaretDown, FaCaretRight } from 'react-icons/fa'\r\n\r\nimport { OutboundLink } from 'components/Link'\r\nimport { Flex } from 'components/Grid'\r\nimport HelpText from 'components/elements/HelpText'\r\nimport styled, { themeGet, theme } from 'util/style'\r\nimport { formatNumber } from 'util/format'\r\nimport { bioticInfo } from '../../../config/constants'\r\n\r\nconst Wrapper = styled.div`\r\n margin-bottom: 1rem;\r\n`\r\n\r\nconst Header = styled(Flex).attrs({\r\n justifyContent: 'space-between',\r\n})`\r\n cursor: pointer;\r\n`\r\n\r\nconst Title = styled(Flex).attrs({ alignItems: 'center', flex: 1 })`\r\n cursor: pointer;\r\n`\r\n\r\nconst Bar = styled.div`\r\n background-color: ${({ color }) => color};\r\n width: ${({ width }) => width * 100}%;\r\n height: 1.25rem;\r\n line-height: 1;\r\n border-radius: 0 0.5rem 0.5rem 0;\r\n padding: 0.25rem 1rem 0;\r\n margin-bottom: 0.5rem;\r\n box-sizing: border-box;\r\n cursor: pointer;\r\n`\r\n\r\nconst Acres = styled.div`\r\n font-size: 0.8rem;\r\n margin-left: 0.5rem;\r\n color: ${themeGet('colors.grey.700')};\r\n text-align: right;\r\n`\r\n\r\nconst Content = styled.div`\r\n margin-left: 1.5rem;\r\n`\r\n\r\nconst expandoColor = theme.colors.grey[800]\r\nconst expandoSize = '1.5rem'\r\n\r\nconst CaretDown = styled(FaCaretDown).attrs({\r\n color: expandoColor,\r\n size: expandoSize,\r\n})`\r\n width: ${expandoSize};\r\n height: ${expandoSize};\r\n`\r\n\r\nconst CaretRight = styled(FaCaretRight).attrs({\r\n color: expandoColor,\r\n size: expandoSize,\r\n})`\r\n width: ${expandoSize};\r\n height: ${expandoSize};\r\n`\r\n\r\nconst BioticListItem = ({ type, acres, maxAcres }) => {\r\n const [isOpen, setIsOpen] = useState(false)\r\n const toggle = () => setIsOpen(prevIsOpen => !prevIsOpen)\r\n\r\n const { label, color, description, link } = bioticInfo[type]\r\n const position = acres / maxAcres\r\n\r\n return (\r\n \r\n
    \r\n \r\n {isOpen ? <CaretDown /> : <CaretRight />}\r\n <div>{label}</div>\r\n \r\n {formatNumber(acres)} acres\r\n
    \r\n \r\n {position > 0 && (\r\n \r\n )}\r\n {isOpen && (\r\n \r\n {description}\r\n\r\n {link && (\r\n <>\r\n
    \r\n \r\n More information.\r\n \r\n \r\n )}\r\n
    \r\n )}\r\n
    \r\n
    \r\n )\r\n}\r\n\r\nBioticListItem.propTypes = {\r\n type: PropTypes.string.isRequired,\r\n acres: PropTypes.number.isRequired,\r\n maxAcres: PropTypes.number.isRequired,\r\n}\r\n\r\nexport default BioticListItem\r\n","import React from 'react'\r\nimport PropTypes from 'prop-types'\r\n\r\nimport { OutboundLink } from 'components/Link'\r\nimport { Flex } from 'components/Grid'\r\nimport HelpText from 'components/elements/HelpText'\r\nimport styled, { themeGet } from 'util/style'\r\nimport { formatNumber } from 'util/format'\r\nimport BioticListItem from './BioticListItem'\r\n\r\nconst Header = styled(HelpText)`\r\n margin-bottom: 2rem;\r\n`\r\n\r\nconst Section = styled.section`\r\n margin-top: 1rem;\r\n padding-top: 1rem;\r\n border-top: 1px solid ${themeGet('colors.grey.200')};\r\n`\r\n\r\nconst BioticList = ({ biotic }) => {\r\n // convert to array: [{type: , acres: }...]\r\n const entries = Object.entries(biotic).map(([type, acres]) => ({\r\n type,\r\n acres,\r\n }))\r\n\r\n // sort by decreasing size\r\n entries.sort((a, b) => (a.acres < b.acres ? 1 : -1))\r\n\r\n const totalAcres = Object.values(biotic).reduce(\r\n (sum, acres) => sum + acres,\r\n 0\r\n )\r\n const maxAcres = Math.max(...Object.values(biotic))\r\n\r\n if (entries.length === 0 || totalAcres === 0) {\r\n return (\r\n No biotic habitats have been mapped for this estuary.\r\n )\r\n }\r\n\r\n return (\r\n <>\r\n
    \r\n There are {entries.length} biotic habitats mapped in this\r\n estuary, occupying a total of {formatNumber(totalAcres)} acres.\r\n Click the name below for more information.\r\n
    \r\n\r\n {entries.map(entry => (\r\n \r\n ))}\r\n
    \r\n \r\n These habitats represent the Biotic Component (BC) of the{' '}\r\n \r\n Coastal and Marine Ecological Classification Standard\r\n {' '}\r\n (CMECS) for estuaries of the West Coast of the contiguous United\r\n States.\r\n
    \r\n
    \r\n These habitats were derived using information from the National\r\n Wetlands Inventory (NWI), NOAA’s Coastal Change Analysis Program\r\n (C-CAP), and Oregon Coastal Management Program.\r\n
    \r\n
    \r\n For more information and data access,{' '}\r\n \r\n click here\r\n \r\n .\r\n
    \r\n
    \r\n \r\n )\r\n}\r\n\r\nBioticList.propTypes = {\r\n biotic: PropTypes.objectOf(PropTypes.number).isRequired,\r\n}\r\n\r\nexport default BioticList\r\n","// derived from: https://codepen.io/zeroskillz/pen/mPmENy\r\n\r\nimport React from 'react'\r\nimport PropTypes from 'prop-types'\r\n\r\nimport styled, { theme, themeGet } from 'util/style'\r\nimport { formatNumber } from 'util/format'\r\n\r\nconst Circle = styled.circle`\r\n fill: transparent;\r\n transition: stroke-dasharray 0.5s;\r\n`\r\n\r\nconst PercentLabel = styled.tspan`\r\n font-size: ${({ fontSize }) => fontSize}px;\r\n fill: ${themeGet('colors.grey.900')};\r\n font-weight: bold;\r\n`\r\n\r\nconst Percent = styled.tspan`\r\n font-size: ${({ fontSize }) => fontSize}px;\r\n fill: ${themeGet('colors.grey.900')};\r\n`\r\n\r\nconst Label = styled.tspan`\r\n font-size: ${({ fontSize }) => fontSize}px;\r\n fill: ${themeGet('colors.grey.900')};\r\n text-shadow: 0px 0px 2px #fff;\r\n`\r\n\r\nconst Donut = ({\r\n percent,\r\n percentLabel,\r\n percentSize,\r\n label,\r\n color,\r\n backgroundColor,\r\n size,\r\n donutWidth,\r\n offset,\r\n active,\r\n ...props\r\n}) => {\r\n const halfsize = size * 0.5\r\n const radius = halfsize - donutWidth * 0.5\r\n const circumference = 2 * Math.PI * radius\r\n const rotateval = `rotate(${(offset / 100) * 365 -\r\n 90} ${halfsize},${halfsize})`\r\n\r\n return (\r\n \r\n \r\n \r\n \r\n \r\n {percentLabel !== null\r\n ? percentLabel\r\n : formatNumber(percent, percent < 1 ? 1 : 0)}\r\n \r\n\r\n %\r\n\r\n {label && (\r\n \r\n {label}\r\n \r\n )}\r\n \r\n\r\n {active ? (\r\n \r\n ) : null}\r\n \r\n )\r\n}\r\n\r\nDonut.propTypes = {\r\n percent: PropTypes.number.isRequired, // percent, preferably integer\r\n percentLabel: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),\r\n percentSize: PropTypes.number,\r\n label: PropTypes.string, // label placed below percent in middle of donut\r\n donutWidth: PropTypes.number, // width of donut\r\n color: PropTypes.string, // color of the indicator on the donut\r\n backgroundColor: PropTypes.string,\r\n size: PropTypes.number, // width of the chart\r\n offset: PropTypes.number, // additional percentage to rotate the indicator (e.g., sum of percents of preceding charts in a series)\r\n active: PropTypes.bool,\r\n}\r\n\r\nDonut.defaultProps = {\r\n percentLabel: null,\r\n label: null,\r\n donutWidth: 26,\r\n color: theme.colors.primary[300],\r\n backgroundColor: theme.colors.grey[200],\r\n size: 200,\r\n percentSize: 30,\r\n offset: 0,\r\n active: false,\r\n}\r\n\r\nexport default Donut\r\n","// derived from: https://codepen.io/zeroskillz/pen/mPmENy\r\n\r\nimport React from 'react'\r\nimport PropTypes from 'prop-types'\r\n\r\nimport styled, { theme } from 'util/style'\r\n\r\nconst Circle = styled.circle`\r\n fill: transparent;\r\n transition: stroke-dasharray 0.5s;\r\n`\r\n\r\nconst calculateRotation = (halfsize, offset) =>\r\n `rotate(${(offset / 100) * 360 - 90} ${halfsize},${halfsize})`\r\n\r\nconst Donut = ({ entries, backgroundColor, size, donutWidth, ...props }) => {\r\n const halfsize = size * 0.5\r\n const radius = halfsize - donutWidth * 0.5\r\n const circumference = 2 * Math.PI * radius\r\n\r\n const offsets = entries.reduce(\r\n (prev, { percent }) => prev.concat([percent + prev[prev.length - 1]]),\r\n [0]\r\n )\r\n\r\n return (\r\n \r\n \r\n\r\n {entries.map(({ percent, color }, i) => (\r\n \r\n ))}\r\n \r\n )\r\n}\r\n\r\nDonut.propTypes = {\r\n entries: PropTypes.arrayOf(\r\n PropTypes.shape({\r\n percent: PropTypes.number.isRequired, // percent, preferably integer\r\n color: PropTypes.string, // color of the indicator on the donut\r\n })\r\n ).isRequired,\r\n\r\n donutWidth: PropTypes.number, // width of donut\r\n\r\n backgroundColor: PropTypes.string,\r\n size: PropTypes.number, // width of the chart\r\n offset: PropTypes.number, // additional percentage to rotate the indicator (e.g., sum of percents of preceding charts in a series)\r\n}\r\n\r\nDonut.defaultProps = {\r\n donutWidth: 26,\r\n backgroundColor: theme.colors.grey[200],\r\n size: 200,\r\n offset: 0,\r\n}\r\n\r\nexport default Donut\r\n","import React from 'react'\r\nimport PropTypes from 'prop-types'\r\n\r\nimport { OutboundLink } from 'components/Link'\r\nimport { Flex } from 'components/Grid'\r\nimport HelpText from 'components/elements/HelpText'\r\nimport { MultiValueDonut } from 'components/Donut'\r\nimport { formatNumber } from 'util/format'\r\nimport styled from 'util/style'\r\nimport { twInfo } from '../../../config/constants'\r\n\r\nconst Section = styled(Flex).attrs({ alignItems: 'center', mt: '1rem' })``\r\nconst StyledDonut = styled(MultiValueDonut)`\r\n flex: 0 0 auto;\r\n margin-right: 1rem;\r\n`\r\n\r\nconst Note = styled(HelpText).attrs({ fontSize: '0.8rem' })``\r\n\r\nconst Patch = styled.div`\r\n width: 1rem;\r\n height: 1rem;\r\n background: ${({ color }) => color};\r\n margin-right: 0.5rem;\r\n`\r\n\r\nconst Legend = styled(Flex).attrs({ alignItems: 'center' })`\r\n &:not(:first-child) {\r\n margin-top: 0.25rem;\r\n }\r\n`\r\n\r\n// add a bit of transparency to mute colors, and transform to a simpler object\r\nconst colors = Object.assign(\r\n {},\r\n ...Object.entries(twInfo).map(([key, { color }]) => ({ [key]: `${color}99` }))\r\n)\r\n\r\nconst TidalWetlandLoss = ({ area, lost, restored }) => {\r\n if (!area) {\r\n return (\r\n Tidal wetland loss was not assessed for this estuary.\r\n )\r\n }\r\n\r\n const retained = area - lost - restored\r\n const percentLost = Math.min(100, (100 * lost) / area)\r\n const percentRestored = Math.min(100, (100 * restored) / area)\r\n const percentRetained = Math.max(0, (100 * retained) / area)\r\n\r\n const donutEntries = [\r\n {\r\n percent: percentLost,\r\n color: colors.lost,\r\n },\r\n {\r\n percent: percentRestored,\r\n color: colors.restored,\r\n },\r\n {\r\n percent: percentRetained,\r\n color: colors.retained,\r\n },\r\n ]\r\n\r\n return (\r\n <>\r\n \r\n Vegetated tidal wetlands historically occupied approximately{' '}\r\n {formatNumber(area, 0)} acres.\r\n \r\n\r\n {/* Experimental, pending review */}\r\n
    \r\n \r\n\r\n
    \r\n \r\n \r\n \r\n {formatNumber(lost, 0)} acres (\r\n {formatNumber(percentLost, 0)}%) lost\r\n \r\n \r\n\r\n {percentRestored > 0 ? (\r\n \r\n \r\n \r\n {formatNumber(restored, 0)} acres (\r\n {formatNumber(percentRestored, 0)}%) restored\r\n \r\n \r\n ) : null}\r\n\r\n \r\n \r\n \r\n {formatNumber(retained, 0)} acres (\r\n {formatNumber(percentRetained, 0)}%) retained\r\n \r\n \r\n
    \r\n
    \r\n\r\n \r\n Vegetated tidal wetland loss was assessed by comparing the current\r\n extent of tidal wetlands in the{' '}\r\n \r\n National Wetland Inventory\r\n {' '}\r\n (NWI) to the historical estuary extent shown in this tool (open water\r\n and aquatic vegetated areas were excluded from the analysis). This\r\n approach worked best for larger estuaries. Changes in estuary topography\r\n due to fill, outdated information from the NWI, and incomplete\r\n information on restored tidal wetlands may result in errors in these\r\n estimates of tidal wetland loss.{' '}\r\n \r\n Read more...\r\n \r\n \r\n \r\n )\r\n}\r\n\r\nTidalWetlandLoss.propTypes = {\r\n area: PropTypes.number,\r\n lost: PropTypes.number,\r\n restored: PropTypes.number,\r\n}\r\n\r\nTidalWetlandLoss.defaultProps = {\r\n area: 0,\r\n lost: 0,\r\n restored: PropTypes.number,\r\n}\r\n\r\nexport default TidalWetlandLoss\r\n","import React from 'react'\r\nimport PropTypes from 'prop-types'\r\nimport { css } from 'styled-components'\r\n\r\nimport { Box, Flex } from 'components/Grid'\r\nimport styled, { theme, themeGet } from 'util/style'\r\nimport { nfhpCodes, nfhpLabels, nfhpColors } from '../../../config/constants'\r\n\r\nconst Wrapper = styled(Box).attrs({ mx: [0, 0, '1rem'], my: '1rem' })``\r\n\r\nconst Header = styled.div`\r\n padding: 0.5em 1em;\r\n border-radius: 0.5em;\r\n margin-bottom: 1em;\r\n\r\n text-align: center;\r\n letter-spacing: 0.05em;\r\n font-weight: bold;\r\n color: ${({ level }) => (level < 3 ? '#FFF' : themeGet('colors.black'))};\r\n background-color: ${({ level }) => nfhpColors[level]};\r\n`\r\n\r\nconst Labels = styled(Flex)`\r\n margin-top: 0.25em;\r\n font-size: 0.7em;\r\n color: ${themeGet('colors.grey.700')};\r\n`\r\n\r\nconst ItemContainer = styled(Flex)`\r\n margin: 0 0.5em;\r\n`\r\n\r\nconst borderColor = theme.colors.primary[900]\r\n\r\nconst borderRadius = (isLower, isUpper) => {\r\n if (!(isLower || isUpper)) return '0'\r\n\r\n if (isLower && isUpper) {\r\n return '0.5em'\r\n }\r\n return isLower ? '0.5em 0 0 0.5em' : '0 0.5em 0.5em 0'\r\n}\r\n\r\nconst Level = styled.div`\r\n flex: 1 0 auto;\r\n height: ${({ isActive }) => (isActive ? '2rem' : '1.5em')};\r\n background-color: ${({ color }) => color};\r\n border-radius: ${({ isLower, isUpper }) => borderRadius(isLower, isUpper)};\r\n z-index: ${({ isLower, isUpper }) => (isLower || isUpper ? 10 : 0)};\r\n\r\n ${({ isLower }) =>\r\n isLower &&\r\n css`\r\n border-left: 4px solid ${borderColor}};\r\n margin-left: -4px;\r\n `}\r\n\r\n ${({ isUpper }) =>\r\n isUpper &&\r\n css`\r\n border-right: 4px solid ${borderColor}};\r\n margin-right: -4px;\r\n position: relative;\r\n\r\n &:after,\r\n &:before {\r\n bottom: 100%;\r\n left: 50%;\r\n border: solid transparent;\r\n content: ' ';\r\n height: 0;\r\n width: 0;\r\n position: absolute;\r\n pointer-events: none;\r\n }\r\n\r\n &:after {\r\n border-color: transparent;\r\n border-bottom-color: ${borderColor};\r\n border-width: 16px;\r\n margin-left: -16px;\r\n }\r\n &:before {\r\n border-color: transparent;\r\n border-bottom-color: ${borderColor};\r\n border-width: 16px;\r\n margin-left: -16px;\r\n }\r\n `}\r\n\r\n ${({ isActive }) =>\r\n isActive &&\r\n css`\r\n border-top: 4px solid ${borderColor};\r\n border-bottom: 4px solid ${borderColor};\r\n `}\r\n`\r\n\r\nconst levels = nfhpCodes.slice(0, nfhpCodes.length - 1).reverse()\r\n\r\nconst ThreatChart = ({ level }) => (\r\n \r\n
    {nfhpLabels[level]}
    \r\n \r\n {levels.map(l => (\r\n = level && l <= level}\r\n isLower={l === level}\r\n isUpper={l === level}\r\n />\r\n ))}\r\n \r\n \r\n
    lower threat
    \r\n
    higher threat
    \r\n
    \r\n
    \r\n)\r\n\r\nThreatChart.propTypes = {\r\n level: PropTypes.number.isRequired,\r\n}\r\n\r\nexport default ThreatChart\r\n","import React from 'react'\r\nimport PropTypes from 'prop-types'\r\n\r\nimport { OutboundLink } from 'components/Link'\r\nimport BaseHelpText from 'components/elements/HelpText'\r\nimport styled from 'util/style'\r\nimport ThreatChart from './ThreatChart'\r\n\r\nconst HelpText = styled(BaseHelpText)`\r\n font-size: 0.8rem;\r\n`\r\n\r\nconst NFHPLink = () => (\r\n \r\n 2015 National Fish Habitat Assessment\r\n \r\n)\r\n\r\nconst NFHAPAbout =\r\n 'This assessment used a cumulative disturbance index to estimate risk of fish habitat degradation in estuarine habitats. The index used twenty-eight variables across four types of disturbance, which included (1) land use and land cover change, (2) alteration of river flows, (3) pollution sources, and (4) estuary eutrophication.'\r\n\r\nconst NFHP = ({ level, status }) => {\r\n let StatusNote = ''\r\n\r\n switch (status) {\r\n case 1: {\r\n StatusNote = (\r\n \r\n This estuary was assessed as part of the . {NFHAPAbout}\r\n \r\n )\r\n break\r\n }\r\n case 2: {\r\n StatusNote = (\r\n \r\n This estuary was assessed as part of a larger estuary system or\r\n sub-basin within the . {NFHAPAbout}\r\n
    \r\n
    \r\n Note: this assessment may not accurately represent this specific\r\n estuary.\r\n
    \r\n )\r\n break\r\n }\r\n default: // status === 3 or status === 999\r\n {\r\n StatusNote = (\r\n \r\n This estuary was not assessed as part of the .\r\n \r\n )\r\n break\r\n }\r\n }\r\n\r\n if (level === 5) {\r\n StatusNote = (\r\n \r\n This estuary was not assessed as part of the .\r\n \r\n )\r\n }\r\n\r\n return (\r\n <>\r\n \r\n {StatusNote}\r\n \r\n )\r\n}\r\n\r\nNFHP.propTypes = {\r\n level: PropTypes.number.isRequired,\r\n status: PropTypes.number.isRequired,\r\n}\r\n\r\nexport default NFHP\r\n","import React from 'react'\r\nimport PropTypes from 'prop-types'\r\n\r\nimport HelpText from 'components/elements/HelpText'\r\nimport styled, { themeGet } from 'util/style'\r\nimport riverine from 'images/riverine.svg'\r\nimport delta from 'images/delta.svg'\r\nimport lagoonal from 'images/lagoonal.svg'\r\nimport bay from 'images/bay.svg'\r\nimport { estuaryTypes } from '../../../config/constants'\r\n\r\nconst Graphic = styled.img`\r\n border: 1px solid ${themeGet('colors.grey.400')};\r\n margin: 0;\r\n`\r\n// in same order as estuaryType in constants\r\nconst graphics = {\r\n 0: bay,\r\n 1: delta,\r\n 2: riverine,\r\n 3: lagoonal,\r\n}\r\n\r\nconst EstuaryType = ({ type }) => {\r\n const graphic = graphics[type]\r\n\r\n return (\r\n <>\r\n {graphic && }\r\n\r\n {estuaryTypes[type].description}\r\n \r\n )\r\n}\r\n\r\nEstuaryType.propTypes = {\r\n type: PropTypes.number.isRequired,\r\n}\r\n\r\nexport default EstuaryType\r\n","import React from 'react'\r\nimport PropTypes from 'prop-types'\r\nimport { Text } from 'rebass'\r\nimport { FaRegTimesCircle } from 'react-icons/fa'\r\n\r\nimport { Button } from 'components/Button'\r\nimport { Columns, Column } from 'components/Grid'\r\nimport ExpandableParagraph from 'components/elements/ExpandableParagraph'\r\nimport Tabs, { Tab as BaseTab } from 'components/Tabs'\r\nimport { OutboundLink } from 'components/Link'\r\nimport styled, { themeGet } from 'util/style'\r\nimport { formatNumber } from 'util/format'\r\n\r\nimport SpeciesList from './SpeciesList'\r\nimport BioticList from './BioticList'\r\nimport TidalWetlandLoss from './TidalWetlandLoss'\r\nimport NFHP from './NFHP'\r\nimport EstuaryType from './EstuaryType'\r\nimport { stateNames, estuaryTypes } from '../../../config/constants'\r\n\r\nconst Header = styled.div`\r\n padding: 0.5rem 1rem;\r\n background-color: ${themeGet('colors.primary.100')};\r\n border-bottom: 1px solid ${themeGet('colors.grey.200')};\r\n line-height: 1.2;\r\n`\r\n\r\nconst Title = styled(Text).attrs({\r\n fontSize: ['1rem', '1rem', '1.5rem'],\r\n})``\r\n\r\nconst Subtitle = styled(Text).attrs({\r\n fontSize: ['0.8rem', '0.8rem', '1rem'],\r\n})``\r\n\r\nconst BackIcon = styled(FaRegTimesCircle).attrs({ size: '1.5rem' })`\r\n height: 1.5rem;\r\n width: 1.5rem;\r\n cursor: pointer;\r\n color: ${themeGet('colors.grey.600')};\r\n &:hover {\r\n color: ${themeGet('colors.grey.900')};\r\n }\r\n`\r\n\r\nconst Image = styled.img`\r\n margin: 0;\r\n`\r\n\r\nconst ImageCredits = styled.div`\r\n font-size: 0.7rem;\r\n color: ${themeGet('colors.grey.500')};\r\n`\r\n\r\nconst Acres = styled(Text).attrs({ textAlign: 'right' })`\r\n color: ${themeGet('colors.grey.700')};\r\n font-size: 0.8rem;\r\n`\r\n\r\nconst ZoomButton = styled(Button)`\r\n font-size: 0.8rem;\r\n margin-bottom: 1rem;\r\n padding: 0.1rem 0.5rem;\r\n`\r\n\r\nconst TabHeader = styled.div`\r\n font-size: 1.25rem;\r\n`\r\nconst Value = styled.div`\r\n padding-left: 1rem;\r\n color: ${themeGet('colors.grey.900')};\r\n`\r\n\r\nconst Section = styled.section`\r\n &:not(:first-child) {\r\n padding-top: 0.5rem;\r\n margin-top: 0.5rem;\r\n border-top: 1px solid ${themeGet('colors.grey.200')};\r\n }\r\n`\r\n\r\nconst TabContainer = styled(Tabs)`\r\n height: 100%;\r\n`\r\n\r\nconst Tab = styled(BaseTab)`\r\n padding: 1rem;\r\n overflow-y: auto;\r\n flex: 1 1 auto;\r\n`\r\n\r\nconst getImage = id =>\r\n /* eslint-disable-next-line */\r\n require(`images/aerial/${id}.jpg`)\r\n\r\nconst EstuaryDetails = ({\r\n id,\r\n name,\r\n imageURL,\r\n imageCredits,\r\n state,\r\n acres,\r\n type,\r\n region,\r\n species,\r\n biotic,\r\n SoKJoin,\r\n nfhp2015,\r\n NFHPJoin,\r\n twAcres,\r\n twlAcres,\r\n twrAcres,\r\n showZoom,\r\n onBack,\r\n onZoomTo,\r\n}) => {\r\n const countSpecies = Object.entries(species).length\r\n const countBiotic = Object.entries(biotic).length\r\n const areaBiotic = Object.values(biotic).reduce((sum, area) => sum + area, 0)\r\n\r\n const handleZoom = () => {\r\n onZoomTo()\r\n }\r\n\r\n return (\r\n <>\r\n
    \r\n \r\n \r\n {name}\r\n \r\n \r\n \r\n \r\n \r\n \r\n \r\n {stateNames[state]}\r\n \r\n {formatNumber(acres, 0)} acres\r\n \r\n \r\n \r\n
    \r\n\r\n \r\n \r\n {showZoom && (\r\n \r\n \r\n Zoom To Estuary\r\n \r\n \r\n )}\r\n\r\n {imageURL !== null && (\r\n
    \r\n \r\n \r\n \r\n {imageCredits && (\r\n \r\n Photo:{' '}\r\n {imageCredits.url ? (\r\n \r\n {imageCredits.credits}\r\n \r\n ) : (\r\n imageCredits.credits\r\n )}\r\n \r\n )}\r\n
    \r\n )}\r\n\r\n
    \r\n Estuary Type:\r\n \r\n {estuaryTypes[type].label}\r\n
    \r\n
    \r\n \r\n \r\n \r\n
    \r\n
    \r\n\r\n
    \r\n Region:\r\n {region}\r\n
    \r\n\r\n
    \r\n Focal species:\r\n \r\n {countSpecies || 'No'} focal species are found in this estuary.\r\n \r\n
    \r\n\r\n
    \r\n Biotic habitats:\r\n \r\n {countBiotic || 'No'} biotic habitats{' '}\r\n {countBiotic && `(${formatNumber(areaBiotic)} acres)`} have been\r\n mapped in this estuary.\r\n \r\n
    \r\n
    \r\n
    \r\n \r\n Focal species present:\r\n \r\n \r\n \r\n Biotic habitats:\r\n \r\n \r\n \r\n
    \r\n Tidal wetland loss:\r\n \r\n
    \r\n\r\n
    \r\n Risk of fish habitat degradation:\r\n \r\n
    \r\n
    \r\n
    \r\n \r\n )\r\n}\r\n\r\nEstuaryDetails.propTypes = {\r\n id: PropTypes.number.isRequired,\r\n name: PropTypes.string.isRequired,\r\n imageURL: PropTypes.string,\r\n imageCredits: PropTypes.object,\r\n state: PropTypes.string.isRequired,\r\n type: PropTypes.number.isRequired,\r\n acres: PropTypes.number.isRequired,\r\n region: PropTypes.string.isRequired,\r\n species: PropTypes.object.isRequired,\r\n biotic: PropTypes.object.isRequired,\r\n SoKJoin: PropTypes.number.isRequired,\r\n nfhp2015: PropTypes.number.isRequired,\r\n NFHPJoin: PropTypes.number.isRequired,\r\n twAcres: PropTypes.number,\r\n twlAcres: PropTypes.number,\r\n twrAcres: PropTypes.number,\r\n showZoom: PropTypes.bool,\r\n onBack: PropTypes.func,\r\n onZoomTo: PropTypes.func,\r\n}\r\n\r\nEstuaryDetails.defaultProps = {\r\n twAcres: null,\r\n twlAcres: null,\r\n twrAcres: null,\r\n imageURL: null,\r\n imageCredits: null,\r\n showZoom: true,\r\n onBack: () => {},\r\n onZoomTo: () => {},\r\n}\r\n\r\nexport default EstuaryDetails\r\n","module.exports = __webpack_public_path__ + \"static/4036-364172fd51cc517eea61f1f2ff96880c.jpg\";","module.exports = __webpack_public_path__ + \"static/1090-ce9e42c5dff15637574f873825495b53.jpg\";","module.exports = __webpack_public_path__ + \"static/1080-b07019cd44159c22376825b926e6ef3a.jpg\";","module.exports = __webpack_public_path__ + \"static/1158-c0a6c9090581c672c7ca12274da0854a.jpg\";","module.exports = __webpack_public_path__ + \"static/2032-56bb2e7e49f3df05cf59f0dae0b6cbbf.jpg\";","module.exports = __webpack_public_path__ + \"static/1024-07a9b90997bc85374944b9ab88fe4304.jpg\";","module.exports = __webpack_public_path__ + \"static/1060-11a53dc8c1e1d2cd82182f05757f710e.jpg\";","module.exports = __webpack_public_path__ + \"static/3030-6250a1a2f96f4c3191adbf02e055ac0e.jpg\";","module.exports = __webpack_public_path__ + \"static/3008-5f18a80e0c3e4bcb0a8ee3ee6a5ffd90.jpg\";","module.exports = __webpack_public_path__ + \"static/2059-d951c5b5d786eb664367eae155b15194.jpg\";","module.exports = __webpack_public_path__ + \"static/2078-0af3c2283444fd7eac497d981c9db402.jpg\";","// import React from 'react'\r\nimport { graphql, useStaticQuery } from 'gatsby'\r\nimport { fromJS } from 'immutable'\r\n\r\nimport { isDebug } from 'util/dom'\r\nimport { packedToObject } from 'util/data'\r\nimport { regions, imageCredits, imageRoot } from '../../../config/constants'\r\n\r\n/**\r\n * Custom react hook to wrap getting data using GraphQL in gatsby\r\n * Returns [data, index]\r\n */\r\nexport const useData = () => {\r\n const data = useStaticQuery(graphql`\r\n query EstuariesDataQuery {\r\n allEstuariesJson {\r\n edges {\r\n node {\r\n id\r\n name\r\n type: estuaryType\r\n region\r\n state\r\n lat\r\n lon\r\n bounds\r\n acres\r\n nfhp2015\r\n SoKJoin\r\n NFHPJoin\r\n biotic\r\n species\r\n twAcres\r\n twlAcres\r\n twrAcres\r\n imageURL\r\n imageCredits\r\n }\r\n }\r\n }\r\n }\r\n `).allEstuariesJson.edges.map(({ node }) => {\r\n // parse data types as needed\r\n const {\r\n id,\r\n region,\r\n species,\r\n biotic,\r\n imageURL,\r\n imageCredits: credits,\r\n } = node\r\n\r\n return {\r\n ...node,\r\n\r\n // convert id back to integer\r\n id: parseInt(id, 10),\r\n\r\n // convert codes back to labels\r\n region: regions[region],\r\n imageCredits: imageCredits ? imageCredits[credits] : null,\r\n\r\n // expand URL\r\n imageURL: imageURL ? `${imageRoot}${imageURL}` : null,\r\n\r\n // unpack species and biotic fields\r\n species: species ? packedToObject(species) : {},\r\n biotic: biotic ? packedToObject(biotic, value => parseFloat(value)) : {},\r\n }\r\n })\r\n\r\n // Create index of data by ID\r\n const index = data.reduce((result, item) => {\r\n /* eslint-disable no-param-reassign */\r\n result[item.id] = item\r\n return result\r\n }, {})\r\n\r\n if (isDebug) {\r\n window.data = data\r\n window.index = index\r\n }\r\n\r\n // return data as immutable objects\r\n return [fromJS(data), fromJS(index)]\r\n}\r\n","module.exports = __webpack_public_path__ + \"static/1066-37c03df873a3195bda6e83305c32aeda.jpg\";","module.exports = __webpack_public_path__ + \"static/1105-0723ced650f05058f35c4e5f08d4bb72.jpg\";","module.exports = __webpack_public_path__ + \"static/1056-e36f8f5f17cb1c9e5a5925bebd7b28d9.jpg\";","module.exports = __webpack_public_path__ + \"static/2042-3cd31bd80b5b576cbc887ec287650928.jpg\";","module.exports = __webpack_public_path__ + \"static/1009-04927ab4156941b3f8528eea1614ef8f.jpg\";","module.exports = \"\"","module.exports = __webpack_public_path__ + \"static/1071-de38d2bd1d7aaf1579908496a87e17e4.jpg\";","module.exports = __webpack_public_path__ + \"static/2108-29e2a37599c8674c3f749c86d5884e42.jpg\";","module.exports = __webpack_public_path__ + \"static/2100-d211d8100b30e8983b06ec46b26fe11b.jpg\";","module.exports = __webpack_public_path__ + \"static/4041-3c11a223e0c85f4ac24db75e22b608f0.jpg\";","module.exports = __webpack_public_path__ + \"static/3022-1c8cf2a9af5ef4927ba16b8421ae5ccc.jpg\";","module.exports = __webpack_public_path__ + \"static/2092-d06225685563c25f9283c332d942caf2.jpg\";","module.exports = __webpack_public_path__ + \"static/3101-25fe4494d9228c7669a78c078ab48928.jpg\";","module.exports = __webpack_public_path__ + \"static/4051-057424a73ee9c996a2826bcbdec30ff9.jpg\";","module.exports = __webpack_public_path__ + \"static/3017-26c8f783a822ce0468ed0539f48e51f2.jpg\";","module.exports = __webpack_public_path__ + \"static/2022-cd3204d1ff705e885fc308f1668921d3.jpg\";","module.exports = __webpack_public_path__ + \"static/3105-7c0691f7dcdfa7caf9d9cff7559e5f14.jpg\";","module.exports = __webpack_public_path__ + \"static/3085-359ced194224d6bca2f836943ec6df1b.jpg\";","module.exports = __webpack_public_path__ + \"static/3068-d5f78aba7dbf0c907428480314fc5c75.jpg\";","module.exports = __webpack_public_path__ + \"static/2001-e0d89214f6d196fc464c8b99053f78c2.jpg\";","module.exports = __webpack_public_path__ + \"static/3084-0e5d3aa884b9dc4f5510e8f7cb3bcccd.jpg\";","module.exports = __webpack_public_path__ + \"static/3033-65a6a35849d86e183ec1f45ac74c3c0f.jpg\";","'use strict';\nvar $ = require('../internals/export');\nvar flattenIntoArray = require('../internals/flatten-into-array');\nvar toObject = require('../internals/to-object');\nvar toLength = require('../internals/to-length');\nvar aFunction = require('../internals/a-function');\nvar arraySpeciesCreate = require('../internals/array-species-create');\n\n// `Array.prototype.flatMap` method\n// https://github.com/tc39/proposal-flatMap\n$({ target: 'Array', proto: true }, {\n flatMap: function flatMap(callbackfn /* , thisArg */) {\n var O = toObject(this);\n var sourceLen = toLength(O.length);\n var A;\n aFunction(callbackfn);\n A = arraySpeciesCreate(O, 0);\n A.length = flattenIntoArray(A, O, O, sourceLen, 0, 1, callbackfn, arguments.length > 1 ? arguments[1] : undefined);\n return A;\n }\n});\n","module.exports = __webpack_public_path__ + \"static/1153-194734b97785741066aa4047561e2921.jpg\";","module.exports = __webpack_public_path__ + \"static/2018-abd0a63dc33a6bff46b7888f63ea5468.jpg\";","module.exports = __webpack_public_path__ + \"static/3059-44a18ca9c76b740f84c9d7d613d0de26.jpg\";","module.exports = __webpack_public_path__ + \"static/2086-533cc4406644fd07f22f5d3a85f22d33.jpg\";","module.exports = __webpack_public_path__ + \"static/1111-d28c25e1e7f6222517974f9ac44bf756.jpg\";","module.exports = __webpack_public_path__ + \"static/4000-612623d25faa0ced86b6521a62812d46.jpg\";","module.exports = __webpack_public_path__ + \"static/1144-345d4fbe80b6de1ffb3b2904a5f2e7ac.jpg\";","module.exports = __webpack_public_path__ + \"static/2009-79e6ffdc9fac0e079a37e3ba2e7b14d1.jpg\";","module.exports = __webpack_public_path__ + \"static/1064-1e85cf03f09cb0cf64e2767d427386a6.jpg\";","// this method was added to unscopables after implementation\n// in popular engines, so it's moved to a separate module\nvar addToUnscopables = require('../internals/add-to-unscopables');\n\naddToUnscopables('flatMap');\n","module.exports = __webpack_public_path__ + \"static/1017-e7af122053050593cfe6836ca916b59f.jpg\";","module.exports = __webpack_public_path__ + \"static/3079-8bf731ce0fc0b66854759cfc5ed7b87d.jpg\";","module.exports = __webpack_public_path__ + \"static/1036-b38c31ea712926435e98da7be596c49c.jpg\";","module.exports = __webpack_public_path__ + \"static/3089-c9a54796e9f707ec8bed97e88c701708.jpg\";","module.exports = __webpack_public_path__ + \"static/4028-0ab703346f6d808003c513532b29117d.jpg\";","module.exports = __webpack_public_path__ + \"static/2081-a6525b642122c42384cf7f9da23144da.jpg\";","module.exports = __webpack_public_path__ + \"static/1077-ecbc6bbb03391eb9afe0dc3982a64231.jpg\";","module.exports = __webpack_public_path__ + \"static/3002-e40e3311d0d132c765e76f8d1d8e826c.jpg\";","module.exports = __webpack_public_path__ + \"static/4023-5aa6220dc3181896ecfc766a2a1943da.jpg\";","module.exports = __webpack_public_path__ + \"static/1004-94b1c996ab365a9d2ec626f2df1d16f2.jpg\";","module.exports = __webpack_public_path__ + \"static/1061-f8f6338f0bb51581cbf5043f3afaadd9.jpg\";","module.exports = __webpack_public_path__ + \"static/1097-8a22ded88e6952a5380c999502f0cd90.jpg\";","module.exports = __webpack_public_path__ + \"static/3081-8f99c7511ae1255950e31dda88860732.jpg\";","module.exports = __webpack_public_path__ + \"static/4025-77dc7ad92e626902be8ea3e90ef37c68.jpg\";","module.exports = __webpack_public_path__ + \"static/1131-d21a847d1ceb58d0702577a8981a466f.jpg\";","module.exports = __webpack_public_path__ + \"static/4046-21d315548b688a1175becccc9fd33011.jpg\";","module.exports = __webpack_public_path__ + \"static/1025-c8a7ab7246223a726040d5809a427e1b.jpg\";","module.exports = __webpack_public_path__ + \"static/2104-d15ec700b3d3cfb2fbdbc8a3efe417eb.jpg\";","module.exports = __webpack_public_path__ + \"static/3106-1c1f9f12bb2077b27881b846e9e0ede5.jpg\";","module.exports = __webpack_public_path__ + \"static/2093-16fed97121a5c352b862751e47aed7fa.jpg\";","module.exports = __webpack_public_path__ + \"static/2067-37f660109e3acb932dc531feb6aebfd2.jpg\";","module.exports = __webpack_public_path__ + \"static/3007-a07093e1506c7ff44143ce2e8bf29c3b.jpg\";","module.exports = __webpack_public_path__ + \"static/3074-ad66054dca89b8f6ee4e4b9000d7ef4d.jpg\";","module.exports = __webpack_public_path__ + \"static/2090-4257e0ed2762be1923205a5cf3e7bcc8.jpg\";","module.exports = __webpack_public_path__ + \"static/2023-2bf479c80666ab8729c3afca82cc78b8.jpg\";","module.exports = __webpack_public_path__ + \"static/2068-5a6e2d5cf262e96e4cd8b151eeab8a4e.jpg\";","module.exports = __webpack_public_path__ + \"static/1089-a736ca306fc4bbdd5b61b92938f8cf51.jpg\";","module.exports = __webpack_public_path__ + \"static/1138-4e27fa0c3907f5897eba0db47dd11a6d.jpg\";","module.exports = __webpack_public_path__ + \"static/2102-3c72c3c2e7ac7065595df719c85b361f.jpg\";","module.exports = __webpack_public_path__ + \"static/1008-a1f47c9fe192159ee2948f71ac77039b.jpg\";","module.exports = __webpack_public_path__ + \"static/3063-6d854a69d4f79c0670d07cee9e31f3d4.jpg\";","module.exports = \"\"","module.exports = __webpack_public_path__ + \"static/2030-3bc74d3515f660ff2cfe4aca93d0b655.jpg\";","module.exports = __webpack_public_path__ + \"static/1094-982715ef94302fcdc55c96aa1ce69cf1.jpg\";","module.exports = __webpack_public_path__ + \"static/2005-1c4633920a1432a66245f7c6c08e65e7.jpg\";","module.exports = __webpack_public_path__ + \"static/2020-5ba4fa0574e3608df78c9ec58f030c28.jpg\";","module.exports = __webpack_public_path__ + \"static/1113-191e56699433eb4c3de0a938c969e194.jpg\";","module.exports = __webpack_public_path__ + \"static/4015-18f2c50059b61565fcce4a25ab4a544c.jpg\";","module.exports = __webpack_public_path__ + \"static/2051-b505e3ff5b98b5ad1e4275698a189cce.jpg\";","module.exports = __webpack_public_path__ + \"static/1107-cdae68934d43f557cfb4f4e4b76df683.jpg\";","module.exports = __webpack_public_path__ + \"static/4032-4165e566ade14f5e2bf4de117a25d71d.jpg\";","module.exports = __webpack_public_path__ + \"static/1159-2b43d848c24e54006ade6f0c373355a1.jpg\";","var aFunction = require('../internals/a-function');\n\n// optional / simple context binding\nmodule.exports = function (fn, that, length) {\n aFunction(fn);\n if (that === undefined) return fn;\n switch (length) {\n case 0: return function () {\n return fn.call(that);\n };\n case 1: return function (a) {\n return fn.call(that, a);\n };\n case 2: return function (a, b) {\n return fn.call(that, a, b);\n };\n case 3: return function (a, b, c) {\n return fn.call(that, a, b, c);\n };\n }\n return function (/* ...args */) {\n return fn.apply(that, arguments);\n };\n};\n","module.exports = __webpack_public_path__ + \"static/4026-a9d6ce1ce37278e8dcacd4cc57f51035.jpg\";","module.exports = __webpack_public_path__ + \"static/2088-bc91efc168aedf4dce883906b3dfbc60.jpg\";","module.exports = __webpack_public_path__ + \"static/3067-20765ef4251c782b1e92bbe659e85ee4.jpg\";","module.exports = __webpack_public_path__ + \"static/3075-f67e9cebf6a4a70ced839b3d8f556879.jpg\";","module.exports = __webpack_public_path__ + \"static/2036-2c9412325a62055b1211d361f20bdc32.jpg\";","export const formatNumber = (number, decimals = null) => {\r\n const absNumber = Math.abs(number)\r\n let targetDecimals = decimals\r\n if (targetDecimals === null) {\r\n // guess number of decimals based on magnitude\r\n if (absNumber > 10 || Math.round(absNumber) === absNumber) {\r\n targetDecimals = 0\r\n } else if (absNumber > 1) {\r\n targetDecimals = 1\r\n } else {\r\n targetDecimals = 2\r\n }\r\n }\r\n // override targetDecimals for integer values\r\n if (Math.round(absNumber) === absNumber) {\r\n targetDecimals = 0\r\n }\r\n\r\n const factor = 10 ** targetDecimals\r\n\r\n // format to localeString, and manually set the desired number of decimal places\r\n return (Math.round(number * factor) / factor).toLocaleString(undefined, {\r\n minimumFractionDigits: targetDecimals,\r\n maximumFractionDigits: targetDecimals,\r\n })\r\n}\r\n\r\n// CohoSalmon -> Coho Salmon\r\nexport function splitWords(text) {\r\n let newText = ''\r\n for (let i = 0; i < text.length; i += 1) {\r\n if (i > 0 && text[i] === text[i].toUpperCase()) {\r\n newText += ` ${text[i]}`\r\n } else {\r\n newText += text[i]\r\n }\r\n }\r\n return newText\r\n}\r\n","module.exports = __webpack_public_path__ + \"static/1005-e364a6ef02e4d3744f98d4222dc51de4.jpg\";","module.exports = __webpack_public_path__ + \"static/3102-8755bfae42ce778e3e93a67fa6edd420.jpg\";","module.exports = __webpack_public_path__ + \"static/2105-6a6017ef8125916f60ddcd18c77c9b80.jpg\";","module.exports = __webpack_public_path__ + \"static/2016-01011b03b9bc199ae5e576e887e18741.jpg\";","module.exports = __webpack_public_path__ + \"static/2053-15d1e5267f158c89445b29686da3a737.jpg\";","module.exports = __webpack_public_path__ + \"static/2039-0ec1471eda45c654441ab982d6abc152.jpg\";","module.exports = __webpack_public_path__ + \"static/3104-a3e483ad941ab9420455b5b90b2391af.jpg\";","var getBuiltIn = require('../internals/get-built-in');\n\nmodule.exports = getBuiltIn('document', 'documentElement');\n","module.exports = __webpack_public_path__ + \"static/2017-275e7ad835c75d0362faeccf247a378e.jpg\";","module.exports = __webpack_public_path__ + \"static/2035-18ad2b206dd07d9f358d0ace56d81ef4.jpg\";","'use strict';\nvar $ = require('../internals/export');\nvar $reduceRight = require('../internals/array-reduce').right;\nvar arrayMethodIsStrict = require('../internals/array-method-is-strict');\nvar arrayMethodUsesToLength = require('../internals/array-method-uses-to-length');\nvar CHROME_VERSION = require('../internals/engine-v8-version');\nvar IS_NODE = require('../internals/engine-is-node');\n\nvar STRICT_METHOD = arrayMethodIsStrict('reduceRight');\n// For preventing possible almost infinite loop in non-standard implementations, test the forward version of the method\nvar USES_TO_LENGTH = arrayMethodUsesToLength('reduce', { 1: 0 });\n// Chrome 80-82 has a critical bug\n// https://bugs.chromium.org/p/chromium/issues/detail?id=1049982\nvar CHROME_BUG = !IS_NODE && CHROME_VERSION > 79 && CHROME_VERSION < 83;\n\n// `Array.prototype.reduceRight` method\n// https://tc39.github.io/ecma262/#sec-array.prototype.reduceright\n$({ target: 'Array', proto: true, forced: !STRICT_METHOD || !USES_TO_LENGTH || CHROME_BUG }, {\n reduceRight: function reduceRight(callbackfn /* , initialValue */) {\n return $reduceRight(this, callbackfn, arguments.length, arguments.length > 1 ? arguments[1] : undefined);\n }\n});\n","module.exports = __webpack_public_path__ + \"static/1136-47a2b8a55908c1f04c560a8d116961b2.jpg\";","module.exports = __webpack_public_path__ + \"static/1124-722d72286fee5d7a6e6586dede19a096.jpg\";","module.exports = __webpack_public_path__ + \"static/1081-e349be06ddb7a584c102578d7ace3682.jpg\";","module.exports = __webpack_public_path__ + \"static/3021-fa4964419e78ecc20d34452466a7b803.jpg\";","module.exports = __webpack_public_path__ + \"static/1126-8f342f09783e8d43a87cdb914ed93356.jpg\";","module.exports = __webpack_public_path__ + \"static/2011-a356c284ad139d5e0bd11d21571ccb74.jpg\";","module.exports = __webpack_public_path__ + \"static/1122-a0796641c38f55c9088531785aed3d28.jpg\";","module.exports = __webpack_public_path__ + \"static/1125-096e70e1a0405d56552705d184181de2.jpg\";","module.exports = __webpack_public_path__ + \"static/1016-90ee8dc5df77b4a4ba4e47d792053fb1.jpg\";","module.exports = __webpack_public_path__ + \"static/3065-7f40b2a3d08561705e2cb68ce7c8be85.jpg\";","module.exports = __webpack_public_path__ + \"static/3066-3e40d929c763ae686b47403add523343.jpg\";","module.exports = __webpack_public_path__ + \"static/1029-83cd4374ef07ab98723a4be6f9613c1c.jpg\";","module.exports = __webpack_public_path__ + \"static/3039-e82e32eec53373f5362372064d4c71d2.jpg\";","var SphericalMercator = function () {\n // Closures including constants and other precalculated values.\n var cache = {},\n EPSLN = 1.0e-10,\n D2R = Math.PI / 180,\n R2D = 180 / Math.PI,\n // 900913 properties.\n A = 6378137.0,\n MAXEXTENT = 20037508.342789244;\n\n function isFloat(n) {\n return Number(n) === n && n % 1 !== 0;\n } // SphericalMercator constructor: precaches calculations\n // for fast tile lookups.\n\n\n function SphericalMercator(options) {\n options = options || {};\n this.size = options.size || 256;\n\n if (!cache[this.size]) {\n var size = this.size;\n var c = cache[this.size] = {};\n c.Bc = [];\n c.Cc = [];\n c.zc = [];\n c.Ac = [];\n\n for (var d = 0; d < 30; d++) {\n c.Bc.push(size / 360);\n c.Cc.push(size / (2 * Math.PI));\n c.zc.push(size / 2);\n c.Ac.push(size);\n size *= 2;\n }\n }\n\n this.Bc = cache[this.size].Bc;\n this.Cc = cache[this.size].Cc;\n this.zc = cache[this.size].zc;\n this.Ac = cache[this.size].Ac;\n }\n\n ; // Convert lon lat to screen pixel value\n //\n // - `ll` {Array} `[lon, lat]` array of geographic coordinates.\n // - `zoom` {Number} zoom level.\n\n SphericalMercator.prototype.px = function (ll, zoom) {\n if (isFloat(zoom)) {\n var size = this.size * Math.pow(2, zoom);\n var d = size / 2;\n var bc = size / 360;\n var cc = size / (2 * Math.PI);\n var ac = size;\n var f = Math.min(Math.max(Math.sin(D2R * ll[1]), -0.9999), 0.9999);\n var x = d + ll[0] * bc;\n var y = d + 0.5 * Math.log((1 + f) / (1 - f)) * -cc;\n x > ac && (x = ac);\n y > ac && (y = ac); //(x < 0) && (x = 0);\n //(y < 0) && (y = 0);\n\n return [x, y];\n } else {\n var d = this.zc[zoom];\n var f = Math.min(Math.max(Math.sin(D2R * ll[1]), -0.9999), 0.9999);\n var x = Math.round(d + ll[0] * this.Bc[zoom]);\n var y = Math.round(d + 0.5 * Math.log((1 + f) / (1 - f)) * -this.Cc[zoom]);\n x > this.Ac[zoom] && (x = this.Ac[zoom]);\n y > this.Ac[zoom] && (y = this.Ac[zoom]); //(x < 0) && (x = 0);\n //(y < 0) && (y = 0);\n\n return [x, y];\n }\n }; // Convert screen pixel value to lon lat\n //\n // - `px` {Array} `[x, y]` array of geographic coordinates.\n // - `zoom` {Number} zoom level.\n\n\n SphericalMercator.prototype.ll = function (px, zoom) {\n if (isFloat(zoom)) {\n var size = this.size * Math.pow(2, zoom);\n var bc = size / 360;\n var cc = size / (2 * Math.PI);\n var zc = size / 2;\n var g = (px[1] - zc) / -cc;\n var lon = (px[0] - zc) / bc;\n var lat = R2D * (2 * Math.atan(Math.exp(g)) - 0.5 * Math.PI);\n return [lon, lat];\n } else {\n var g = (px[1] - this.zc[zoom]) / -this.Cc[zoom];\n var lon = (px[0] - this.zc[zoom]) / this.Bc[zoom];\n var lat = R2D * (2 * Math.atan(Math.exp(g)) - 0.5 * Math.PI);\n return [lon, lat];\n }\n }; // Convert tile xyz value to bbox of the form `[w, s, e, n]`\n //\n // - `x` {Number} x (longitude) number.\n // - `y` {Number} y (latitude) number.\n // - `zoom` {Number} zoom.\n // - `tms_style` {Boolean} whether to compute using tms-style.\n // - `srs` {String} projection for resulting bbox (WGS84|900913).\n // - `return` {Array} bbox array of values in form `[w, s, e, n]`.\n\n\n SphericalMercator.prototype.bbox = function (x, y, zoom, tms_style, srs) {\n // Convert xyz into bbox with srs WGS84\n if (tms_style) {\n y = Math.pow(2, zoom) - 1 - y;\n } // Use +y to make sure it's a number to avoid inadvertent concatenation.\n\n\n var ll = [x * this.size, (+y + 1) * this.size]; // lower left\n // Use +x to make sure it's a number to avoid inadvertent concatenation.\n\n var ur = [(+x + 1) * this.size, y * this.size]; // upper right\n\n var bbox = this.ll(ll, zoom).concat(this.ll(ur, zoom)); // If web mercator requested reproject to 900913.\n\n if (srs === '900913') {\n return this.convert(bbox, '900913');\n } else {\n return bbox;\n }\n }; // Convert bbox to xyx bounds\n //\n // - `bbox` {Number} bbox in the form `[w, s, e, n]`.\n // - `zoom` {Number} zoom.\n // - `tms_style` {Boolean} whether to compute using tms-style.\n // - `srs` {String} projection of input bbox (WGS84|900913).\n // - `@return` {Object} XYZ bounds containing minX, maxX, minY, maxY properties.\n\n\n SphericalMercator.prototype.xyz = function (bbox, zoom, tms_style, srs) {\n // If web mercator provided reproject to WGS84.\n if (srs === '900913') {\n bbox = this.convert(bbox, 'WGS84');\n }\n\n var ll = [bbox[0], bbox[1]]; // lower left\n\n var ur = [bbox[2], bbox[3]]; // upper right\n\n var px_ll = this.px(ll, zoom);\n var px_ur = this.px(ur, zoom); // Y = 0 for XYZ is the top hence minY uses px_ur[1].\n\n var x = [Math.floor(px_ll[0] / this.size), Math.floor((px_ur[0] - 1) / this.size)];\n var y = [Math.floor(px_ur[1] / this.size), Math.floor((px_ll[1] - 1) / this.size)];\n var bounds = {\n minX: Math.min.apply(Math, x) < 0 ? 0 : Math.min.apply(Math, x),\n minY: Math.min.apply(Math, y) < 0 ? 0 : Math.min.apply(Math, y),\n maxX: Math.max.apply(Math, x),\n maxY: Math.max.apply(Math, y)\n };\n\n if (tms_style) {\n var tms = {\n minY: Math.pow(2, zoom) - 1 - bounds.maxY,\n maxY: Math.pow(2, zoom) - 1 - bounds.minY\n };\n bounds.minY = tms.minY;\n bounds.maxY = tms.maxY;\n }\n\n return bounds;\n }; // Convert projection of given bbox.\n //\n // - `bbox` {Number} bbox in the form `[w, s, e, n]`.\n // - `to` {String} projection of output bbox (WGS84|900913). Input bbox\n // assumed to be the \"other\" projection.\n // - `@return` {Object} bbox with reprojected coordinates.\n\n\n SphericalMercator.prototype.convert = function (bbox, to) {\n if (to === '900913') {\n return this.forward(bbox.slice(0, 2)).concat(this.forward(bbox.slice(2, 4)));\n } else {\n return this.inverse(bbox.slice(0, 2)).concat(this.inverse(bbox.slice(2, 4)));\n }\n }; // Convert lon/lat values to 900913 x/y.\n\n\n SphericalMercator.prototype.forward = function (ll) {\n var xy = [A * ll[0] * D2R, A * Math.log(Math.tan(Math.PI * 0.25 + 0.5 * ll[1] * D2R))]; // if xy value is beyond maxextent (e.g. poles), return maxextent.\n\n xy[0] > MAXEXTENT && (xy[0] = MAXEXTENT);\n xy[0] < -MAXEXTENT && (xy[0] = -MAXEXTENT);\n xy[1] > MAXEXTENT && (xy[1] = MAXEXTENT);\n xy[1] < -MAXEXTENT && (xy[1] = -MAXEXTENT);\n return xy;\n }; // Convert 900913 x/y values to lon/lat.\n\n\n SphericalMercator.prototype.inverse = function (xy) {\n return [xy[0] * R2D / A, (Math.PI * 0.5 - 2.0 * Math.atan(Math.exp(-xy[1] / A))) * R2D];\n };\n\n return SphericalMercator;\n}();\n\nif (typeof module !== 'undefined' && typeof exports !== 'undefined') {\n module.exports = exports = SphericalMercator;\n}","module.exports = __webpack_public_path__ + \"static/1128-015aa1107cc80bf9e57e55299a77027d.jpg\";","module.exports = __webpack_public_path__ + \"static/1114-2040fdbaf6a4eb59a93a511123195a8c.jpg\";","module.exports = __webpack_public_path__ + \"static/1000-8e5e98cd09477adfd4abb62b9b3b7b86.jpg\";","module.exports = __webpack_public_path__ + \"static/1041-6aadfc41920e4d5f0c42e3a6677dd878.jpg\";","module.exports = __webpack_public_path__ + \"static/1108-95eedffb836d5d8fdb569ae42de7af7c.jpg\";","module.exports = __webpack_public_path__ + \"static/1148-dc39198a04cfc1b8f7dc3c31cbfd6b3b.jpg\";","var array8 = arrayUntyped,\n array16 = arrayUntyped,\n array32 = arrayUntyped,\n arrayLengthen = arrayLengthenUntyped,\n arrayWiden = arrayWidenUntyped;\n\nif (typeof Uint8Array !== \"undefined\") {\n array8 = function array8(n) {\n return new Uint8Array(n);\n };\n\n array16 = function array16(n) {\n return new Uint16Array(n);\n };\n\n array32 = function array32(n) {\n return new Uint32Array(n);\n };\n\n arrayLengthen = function arrayLengthen(array, length) {\n if (array.length >= length) return array;\n var copy = new array.constructor(length);\n copy.set(array);\n return copy;\n };\n\n arrayWiden = function arrayWiden(array, width) {\n var copy;\n\n switch (width) {\n case 16:\n copy = array16(array.length);\n break;\n\n case 32:\n copy = array32(array.length);\n break;\n\n default:\n throw new Error(\"invalid array width!\");\n }\n\n copy.set(array);\n return copy;\n };\n}\n\nfunction arrayUntyped(n) {\n var array = new Array(n),\n i = -1;\n\n while (++i < n) {\n array[i] = 0;\n }\n\n return array;\n}\n\nfunction arrayLengthenUntyped(array, length) {\n var n = array.length;\n\n while (n < length) {\n array[n++] = 0;\n }\n\n return array;\n}\n\nfunction arrayWidenUntyped(array, width) {\n if (width > 32) throw new Error(\"invalid array width!\");\n return array;\n} // An arbitrarily-wide array of bitmasks\n\n\nfunction bitarray(n) {\n this.length = n;\n this.subarrays = 1;\n this.width = 8;\n this.masks = {\n 0: 0\n };\n this[0] = array8(n);\n}\n\nbitarray.prototype.lengthen = function (n) {\n var i, len;\n\n for (i = 0, len = this.subarrays; i < len; ++i) {\n this[i] = arrayLengthen(this[i], n);\n }\n\n this.length = n;\n}; // Reserve a new bit index in the array, returns {offset, one}\n\n\nbitarray.prototype.add = function () {\n var m, w, one, i, len;\n\n for (i = 0, len = this.subarrays; i < len; ++i) {\n m = this.masks[i];\n w = this.width - 32 * i; // isolate the rightmost zero bit and return it as an unsigned int of 32 bits, if NaN or -1, return a 0 \n\n one = (~m & m + 1) >>> 0;\n\n if (w >= 32 && !one) {\n continue;\n }\n\n if (w < 32 && one & 1 << w) {\n // widen this subarray\n this[i] = arrayWiden(this[i], w <<= 1);\n this.width = 32 * i + w;\n }\n\n this.masks[i] |= one;\n return {\n offset: i,\n one: one\n };\n } // add a new subarray\n\n\n this[this.subarrays] = array8(this.length);\n this.masks[this.subarrays] = 1;\n this.width += 8;\n return {\n offset: this.subarrays++,\n one: 1\n };\n}; // Copy record from index src to index dest\n\n\nbitarray.prototype.copy = function (dest, src) {\n var i, len;\n\n for (i = 0, len = this.subarrays; i < len; ++i) {\n this[i][dest] = this[i][src];\n }\n}; // Truncate the array to the given length\n\n\nbitarray.prototype.truncate = function (n) {\n var i, len;\n\n for (i = 0, len = this.subarrays; i < len; ++i) {\n for (var j = this.length - 1; j >= n; j--) {\n this[i][j] = 0;\n }\n }\n\n this.length = n;\n}; // Checks that all bits for the given index are 0\n\n\nbitarray.prototype.zero = function (n) {\n var i, len;\n\n for (i = 0, len = this.subarrays; i < len; ++i) {\n if (this[i][n]) {\n return false;\n }\n }\n\n return true;\n}; // Checks that all bits for the given index are 0 except for possibly one\n\n\nbitarray.prototype.zeroExcept = function (n, offset, zero) {\n var i, len;\n\n for (i = 0, len = this.subarrays; i < len; ++i) {\n if (i === offset ? this[i][n] & zero : this[i][n]) {\n return false;\n }\n }\n\n return true;\n}; // Checks that all bits for the given index are 0 except for the specified mask.\n// The mask should be an array of the same size as the filter subarrays width.\n\n\nbitarray.prototype.zeroExceptMask = function (n, mask) {\n var i, len;\n\n for (i = 0, len = this.subarrays; i < len; ++i) {\n if (this[i][n] & mask[i]) {\n return false;\n }\n }\n\n return true;\n}; // Checks that only the specified bit is set for the given index\n\n\nbitarray.prototype.only = function (n, offset, one) {\n var i, len;\n\n for (i = 0, len = this.subarrays; i < len; ++i) {\n if (this[i][n] != (i === offset ? one : 0)) {\n return false;\n }\n }\n\n return true;\n}; // Checks that only the specified bit is set for the given index except for possibly one other\n\n\nbitarray.prototype.onlyExcept = function (n, offset, zero, onlyOffset, onlyOne) {\n var mask;\n var i, len;\n\n for (i = 0, len = this.subarrays; i < len; ++i) {\n mask = this[i][n];\n if (i === offset) mask = (mask & zero) >>> 0;\n\n if (mask != (i === onlyOffset ? onlyOne : 0)) {\n return false;\n }\n }\n\n return true;\n};\n\nexport default {\n array8: arrayUntyped,\n array16: arrayUntyped,\n array32: arrayUntyped,\n arrayLengthen: arrayLengthenUntyped,\n arrayWiden: arrayWidenUntyped,\n bitarray: bitarray\n};","var filterExact = function filterExact(bisect, value) {\n return function (values) {\n var n = values.length;\n return [bisect.left(values, value, 0, n), bisect.right(values, value, 0, n)];\n };\n};\n\nvar filterRange = function filterRange(bisect, range) {\n var min = range[0],\n max = range[1];\n return function (values) {\n var n = values.length;\n return [bisect.left(values, min, 0, n), bisect.left(values, max, 0, n)];\n };\n};\n\nvar filterAll = function filterAll(values) {\n return [0, values.length];\n};\n\nexport default {\n filterExact: filterExact,\n filterRange: filterRange,\n filterAll: filterAll\n};","export default (function (d) {\n return d;\n});","export default (function () {\n return null;\n});","export default (function () {\n return 0;\n});","import identity from './identity';\n\nfunction heap_by(f) {\n // Builds a binary heap within the specified array a[lo:hi]. The heap has the\n // property such that the parent a[lo+i] is always less than or equal to its\n // two children: a[lo+2*i+1] and a[lo+2*i+2].\n function heap(a, lo, hi) {\n var n = hi - lo,\n i = (n >>> 1) + 1;\n\n while (--i > 0) {\n sift(a, i, n, lo);\n }\n\n return a;\n } // Sorts the specified array a[lo:hi] in descending order, assuming it is\n // already a heap.\n\n\n function sort(a, lo, hi) {\n var n = hi - lo,\n t;\n\n while (--n > 0) {\n t = a[lo], a[lo] = a[lo + n], a[lo + n] = t, sift(a, 1, n, lo);\n }\n\n return a;\n } // Sifts the element a[lo+i-1] down the heap, where the heap is the contiguous\n // slice of array a[lo:lo+n]. This method can also be used to update the heap\n // incrementally, without incurring the full cost of reconstructing the heap.\n\n\n function sift(a, i, n, lo) {\n var d = a[--lo + i],\n x = f(d),\n child;\n\n while ((child = i << 1) <= n) {\n if (child < n && f(a[lo + child]) > f(a[lo + child + 1])) child++;\n if (x <= f(a[lo + child])) break;\n a[lo + i] = a[lo + child];\n i = child;\n }\n\n a[lo + i] = d;\n }\n\n heap.sort = sort;\n return heap;\n}\n\nvar h = heap_by(identity);\nh.by = heap_by;\nexport default h;","import identity from './identity';\nimport xFilterHeap from './heap';\n\nfunction heapselect_by(f) {\n var heap = xFilterHeap.by(f); // Returns a new array containing the top k elements in the array a[lo:hi].\n // The returned array is not sorted, but maintains the heap property. If k is\n // greater than hi - lo, then fewer than k elements will be returned. The\n // order of elements in a is unchanged by this operation.\n\n function heapselect(a, lo, hi, k) {\n var queue = new Array(k = Math.min(hi - lo, k)),\n min,\n i,\n d;\n\n for (i = 0; i < k; ++i) {\n queue[i] = a[lo++];\n }\n\n heap(queue, 0, k);\n\n if (lo < hi) {\n min = f(queue[0]);\n\n do {\n if (f(d = a[lo]) > min) {\n queue[0] = d;\n min = f(heap(queue, 0, k)[0]);\n }\n } while (++lo < hi);\n }\n\n return queue;\n }\n\n return heapselect;\n}\n\nvar h = heapselect_by(identity);\nh.by = heapselect_by; // assign the raw function to the export as well\n\nexport default h;","import identity from './identity';\n\nfunction bisect_by(f) {\n // Locate the insertion point for x in a to maintain sorted order. The\n // arguments lo and hi may be used to specify a subset of the array which\n // should be considered; by default the entire array is used. If x is already\n // present in a, the insertion point will be before (to the left of) any\n // existing entries. The return value is suitable for use as the first\n // argument to `array.splice` assuming that a is already sorted.\n //\n // The returned insertion point i partitions the array a into two halves so\n // that all v < x for v in a[lo:i] for the left side and all v >= x for v in\n // a[i:hi] for the right side.\n function bisectLeft(a, x, lo, hi) {\n while (lo < hi) {\n var mid = lo + hi >>> 1;\n if (f(a[mid]) < x) lo = mid + 1;else hi = mid;\n }\n\n return lo;\n } // Similar to bisectLeft, but returns an insertion point which comes after (to\n // the right of) any existing entries of x in a.\n //\n // The returned insertion point i partitions the array into two halves so that\n // all v <= x for v in a[lo:i] for the left side and all v > x for v in\n // a[i:hi] for the right side.\n\n\n function bisectRight(a, x, lo, hi) {\n while (lo < hi) {\n var mid = lo + hi >>> 1;\n if (x < f(a[mid])) hi = mid;else lo = mid + 1;\n }\n\n return lo;\n }\n\n bisectRight.right = bisectRight;\n bisectRight.left = bisectLeft;\n return bisectRight;\n}\n\nvar bisect = bisect_by(identity);\nbisect.by = bisect_by; // assign the raw function to the export as well\n\nexport default bisect;","export default (function (array, index, deep) {\n for (var i = 0, n = index.length, copy = deep ? JSON.parse(JSON.stringify(array)) : new Array(n); i < n; ++i) {\n copy[i] = array[index[i]];\n }\n\n return copy;\n});","var reduceIncrement = function reduceIncrement(p) {\n return p + 1;\n};\n\nvar reduceDecrement = function reduceDecrement(p) {\n return p - 1;\n};\n\nvar reduceAdd = function reduceAdd(f) {\n return function (p, v) {\n return p + +f(v);\n };\n};\n\nvar reduceSubtract = function reduceSubtract(f) {\n return function (p, v) {\n return p - f(v);\n };\n};\n\nexport default {\n reduceIncrement: reduceIncrement,\n reduceDecrement: reduceDecrement,\n reduceAdd: reduceAdd,\n reduceSubtract: reduceSubtract\n};","import deep from \"@ranfdev/deepobj\"; // Note(cg): result was previsouly using lodash.result, not ESM compatible.\n\nvar get = function get(obj, prop) {\n var value = obj[prop];\n return typeof value === 'function' ? value.call(obj) : value;\n};\n/**\n * get value of object at a deep path.\n * if the resolved value is a function,\n * it's invoked with the `this` binding of \n * its parent object and its result is returned. \n * \n * @param {Object} obj the object (e.g. { 'a': [{ 'b': { 'c1': 3, 'c2': 4} }], 'd': {e:1} }; )\n * @param {String} path deep path (e.g. `d.e`` or `a[0].b.c1`. Dot notation (a.0.b)is also supported)\n * @return {Any} the resolved value\n */\n\n\nvar reg = /\\[([\\w\\d]+)\\]/g;\nexport default (function (obj, path) {\n return deep(get, obj, path.replace(reg, '.$1'));\n});","export default function (t, e, i, n, r) {\n for (r in n = (i = i.split(\".\")).splice(-1, 1), i) {\n e = e[i[r]] = e[i[r]] || {};\n }\n\n return t(e, n);\n}\n;","import xfilterArray from './array';\nimport xfilterFilter from './filter';\nimport cr_identity from './identity';\nimport cr_null from './null';\nimport cr_zero from './zero';\nimport xfilterHeapselect from './heapselect';\nimport xfilterHeap from './heap';\nimport bisect from './bisect';\nimport permute from './permute';\nimport xfilterReduce from './reduce';\nimport result from './result'; // constants\n\nvar REMOVED_INDEX = -1;\ncrossfilter.heap = xfilterHeap;\ncrossfilter.heapselect = xfilterHeapselect;\ncrossfilter.bisect = bisect;\ncrossfilter.permute = permute;\nexport default crossfilter;\n\nfunction crossfilter() {\n var crossfilter = {\n add: add,\n remove: removeData,\n dimension: dimension,\n groupAll: groupAll,\n size: size,\n all: all,\n allFiltered: allFiltered,\n onChange: onChange,\n isElementFiltered: isElementFiltered\n };\n var data = [],\n // the records\n n = 0,\n // the number of records; data.length\n filters,\n // 1 is filtered out\n filterListeners = [],\n // when the filters change\n dataListeners = [],\n // when data is added\n removeDataListeners = [],\n // when data is removed\n callbacks = [];\n filters = new xfilterArray.bitarray(0); // Adds the specified new records to this crossfilter.\n\n function add(newData) {\n var n0 = n,\n n1 = newData.length; // If there's actually new data to add…\n // Merge the new data into the existing data.\n // Lengthen the filter bitset to handle the new records.\n // Notify listeners (dimensions and groups) that new data is available.\n\n if (n1) {\n data = data.concat(newData);\n filters.lengthen(n += n1);\n dataListeners.forEach(function (l) {\n l(newData, n0, n1);\n });\n triggerOnChange('dataAdded');\n }\n\n return crossfilter;\n } // Removes all records that match the current filters, or if a predicate function is passed,\n // removes all records matching the predicate (ignoring filters).\n\n\n function removeData(predicate) {\n var // Mapping from old record indexes to new indexes (after records removed)\n newIndex = new Array(n),\n removed = [],\n usePred = typeof predicate === 'function',\n shouldRemove = function shouldRemove(i) {\n return usePred ? predicate(data[i], i) : filters.zero(i);\n };\n\n for (var index1 = 0, index2 = 0; index1 < n; ++index1) {\n if (shouldRemove(index1)) {\n removed.push(index1);\n newIndex[index1] = REMOVED_INDEX;\n } else {\n newIndex[index1] = index2++;\n }\n } // Remove all matching records from groups.\n\n\n filterListeners.forEach(function (l) {\n l(-1, -1, [], removed, true);\n }); // Update indexes.\n\n removeDataListeners.forEach(function (l) {\n l(newIndex);\n }); // Remove old filters and data by overwriting.\n\n for (var index3 = 0, index4 = 0; index3 < n; ++index3) {\n if (newIndex[index3] !== REMOVED_INDEX) {\n if (index3 !== index4) filters.copy(index4, index3), data[index4] = data[index3];\n ++index4;\n }\n }\n\n data.length = n = index4;\n filters.truncate(index4);\n triggerOnChange('dataRemoved');\n }\n\n function maskForDimensions(dimensions) {\n var n,\n d,\n len,\n id,\n mask = Array(filters.subarrays);\n\n for (n = 0; n < filters.subarrays; n++) {\n mask[n] = ~0;\n }\n\n for (d = 0, len = dimensions.length; d < len; d++) {\n // The top bits of the ID are the subarray offset and the lower bits are the bit\n // offset of the \"one\" mask.\n id = dimensions[d].id();\n mask[id >> 7] &= ~(0x1 << (id & 0x3f));\n }\n\n return mask;\n } // Return true if the data element at index i is filtered IN.\n // Optionally, ignore the filters of any dimensions in the ignore_dimensions list.\n\n\n function isElementFiltered(i, ignore_dimensions) {\n var mask = maskForDimensions(ignore_dimensions || []);\n return filters.zeroExceptMask(i, mask);\n } // Adds a new dimension with the specified value accessor function.\n\n\n function dimension(value, iterable) {\n if (typeof value === 'string') {\n var accessorPath = value;\n\n value = function value(d) {\n return result(d, accessorPath);\n };\n }\n\n var dimension = {\n filter: filter,\n filterExact: filterExact,\n filterRange: filterRange,\n filterFunction: filterFunction,\n filterAll: filterAll,\n currentFilter: currentFilter,\n hasCurrentFilter: hasCurrentFilter,\n top: top,\n bottom: bottom,\n group: group,\n groupAll: groupAll,\n dispose: dispose,\n remove: dispose,\n // for backwards-compatibility\n accessor: value,\n id: function id() {\n return _id;\n }\n };\n\n var one,\n // lowest unset bit as mask, e.g., 00001000\n zero,\n // inverted one, e.g., 11110111\n offset,\n // offset into the filters arrays\n _id,\n // unique ID for this dimension (reused when dimensions are disposed)\n values,\n // sorted, cached array\n index,\n // maps sorted value index -> record index (in data)\n newValues,\n // temporary array storing newly-added values\n newIndex,\n // temporary array storing newly-added index\n iterablesIndexCount,\n iterablesIndexFilterStatus,\n iterablesEmptyRows = [],\n sortRange = function sortRange(n) {\n return cr_range(n).sort(function (A, B) {\n var a = newValues[A],\n b = newValues[B];\n return a < b ? -1 : a > b ? 1 : A - B;\n });\n },\n refilter = xfilterFilter.filterAll,\n // for recomputing filter\n refilterFunction,\n // the custom filter function in use\n filterValue,\n // the value used for filtering (value, array, function or undefined)\n filterValuePresent,\n // true if filterValue contains something\n indexListeners = [],\n // when data is added\n dimensionGroups = [],\n lo0 = 0,\n hi0 = 0,\n t = 0,\n k; // Updating a dimension is a two-stage process. First, we must update the\n // associated filters for the newly-added records. Once all dimensions have\n // updated their filters, the groups are notified to update.\n\n\n dataListeners.unshift(preAdd);\n dataListeners.push(postAdd);\n removeDataListeners.push(removeData); // Add a new dimension in the filter bitmap and store the offset and bitmask.\n\n var tmp = filters.add();\n offset = tmp.offset;\n one = tmp.one;\n zero = ~one; // Create a unique ID for the dimension\n // IDs will be re-used if dimensions are disposed.\n // For internal use the ID is the subarray offset shifted left 7 bits or'd with the\n // bit offset of the set bit in the dimension's \"one\" mask.\n\n _id = offset << 7 | Math.log(one) / Math.log(2);\n preAdd(data, 0, n);\n postAdd(data, 0, n); // Incorporates the specified new records into this dimension.\n // This function is responsible for updating filters, values, and index.\n\n function preAdd(newData, n0, n1) {\n var newIterablesIndexCount, newIterablesIndexFilterStatus;\n\n if (iterable) {\n // Count all the values\n t = 0;\n j = 0;\n k = [];\n\n for (var i0 = 0; i0 < newData.length; i0++) {\n for (j = 0, k = value(newData[i0]); j < k.length; j++) {\n t++;\n }\n }\n\n newValues = [];\n newIterablesIndexCount = cr_range(newData.length);\n newIterablesIndexFilterStatus = cr_index(t, 1);\n var unsortedIndex = cr_range(t);\n\n for (var l = 0, index1 = 0; index1 < newData.length; index1++) {\n k = value(newData[index1]); //\n\n if (!k.length) {\n newIterablesIndexCount[index1] = 0;\n iterablesEmptyRows.push(index1 + n0);\n continue;\n }\n\n newIterablesIndexCount[index1] = k.length;\n\n for (j = 0; j < k.length; j++) {\n newValues.push(k[j]);\n unsortedIndex[l] = index1;\n l++;\n }\n } // Create the Sort map used to sort both the values and the valueToData indices\n\n\n var sortMap = sortRange(t); // Use the sortMap to sort the newValues\n\n newValues = permute(newValues, sortMap); // Use the sortMap to sort the unsortedIndex map\n // newIndex should be a map of sortedValue -> crossfilterData\n\n newIndex = permute(unsortedIndex, sortMap);\n } else {\n // Permute new values into natural order using a standard sorted index.\n newValues = newData.map(value);\n newIndex = sortRange(n1);\n newValues = permute(newValues, newIndex);\n } // Bisect newValues to determine which new records are selected.\n\n\n var bounds = refilter(newValues),\n lo1 = bounds[0],\n hi1 = bounds[1];\n var index2, index3, index4;\n\n if (iterable) {\n n1 = t;\n\n if (refilterFunction) {\n for (index2 = 0; index2 < n1; ++index2) {\n if (!refilterFunction(newValues[index2], index2)) {\n if (--newIterablesIndexCount[newIndex[index2]] === 0) {\n filters[offset][newIndex[index2] + n0] |= one;\n }\n\n newIterablesIndexFilterStatus[index2] = 1;\n }\n }\n } else {\n for (index3 = 0; index3 < lo1; ++index3) {\n if (--newIterablesIndexCount[newIndex[index3]] === 0) {\n filters[offset][newIndex[index3] + n0] |= one;\n }\n\n newIterablesIndexFilterStatus[index3] = 1;\n }\n\n for (index4 = hi1; index4 < n1; ++index4) {\n if (--newIterablesIndexCount[newIndex[index4]] === 0) {\n filters[offset][newIndex[index4] + n0] |= one;\n }\n\n newIterablesIndexFilterStatus[index4] = 1;\n }\n }\n } else {\n if (refilterFunction) {\n for (index2 = 0; index2 < n1; ++index2) {\n if (!refilterFunction(newValues[index2], index2)) {\n filters[offset][newIndex[index2] + n0] |= one;\n }\n }\n } else {\n for (index3 = 0; index3 < lo1; ++index3) {\n filters[offset][newIndex[index3] + n0] |= one;\n }\n\n for (index4 = hi1; index4 < n1; ++index4) {\n filters[offset][newIndex[index4] + n0] |= one;\n }\n }\n } // If this dimension previously had no data, then we don't need to do the\n // more expensive merge operation; use the new values and index as-is.\n\n\n if (!n0) {\n values = newValues;\n index = newIndex;\n iterablesIndexCount = newIterablesIndexCount;\n iterablesIndexFilterStatus = newIterablesIndexFilterStatus;\n lo0 = lo1;\n hi0 = hi1;\n return;\n }\n\n var oldValues = values,\n oldIndex = index,\n oldIterablesIndexFilterStatus = iterablesIndexFilterStatus,\n old_n0,\n i1 = 0;\n i0 = 0;\n\n if (iterable) {\n old_n0 = n0;\n n0 = oldValues.length;\n n1 = t;\n } // Otherwise, create new arrays into which to merge new and old.\n\n\n values = iterable ? new Array(n0 + n1) : new Array(n);\n index = iterable ? new Array(n0 + n1) : cr_index(n, n);\n if (iterable) iterablesIndexFilterStatus = cr_index(n0 + n1, 1); // Concatenate the newIterablesIndexCount onto the old one.\n\n if (iterable) {\n var oldiiclength = iterablesIndexCount.length;\n iterablesIndexCount = xfilterArray.arrayLengthen(iterablesIndexCount, n);\n\n for (var j = 0; j + oldiiclength < n; j++) {\n iterablesIndexCount[j + oldiiclength] = newIterablesIndexCount[j];\n }\n } // Merge the old and new sorted values, and old and new index.\n\n\n var index5 = 0;\n\n for (; i0 < n0 && i1 < n1; ++index5) {\n if (oldValues[i0] < newValues[i1]) {\n values[index5] = oldValues[i0];\n if (iterable) iterablesIndexFilterStatus[index5] = oldIterablesIndexFilterStatus[i0];\n index[index5] = oldIndex[i0++];\n } else {\n values[index5] = newValues[i1];\n if (iterable) iterablesIndexFilterStatus[index5] = newIterablesIndexFilterStatus[i1];\n index[index5] = newIndex[i1++] + (iterable ? old_n0 : n0);\n }\n } // Add any remaining old values.\n\n\n for (; i0 < n0; ++i0, ++index5) {\n values[index5] = oldValues[i0];\n if (iterable) iterablesIndexFilterStatus[index5] = oldIterablesIndexFilterStatus[i0];\n index[index5] = oldIndex[i0];\n } // Add any remaining new values.\n\n\n for (; i1 < n1; ++i1, ++index5) {\n values[index5] = newValues[i1];\n if (iterable) iterablesIndexFilterStatus[index5] = newIterablesIndexFilterStatus[i1];\n index[index5] = newIndex[i1] + (iterable ? old_n0 : n0);\n } // Bisect again to recompute lo0 and hi0.\n\n\n bounds = refilter(values), lo0 = bounds[0], hi0 = bounds[1];\n } // When all filters have updated, notify index listeners of the new values.\n\n\n function postAdd(newData, n0, n1) {\n indexListeners.forEach(function (l) {\n l(newValues, newIndex, n0, n1);\n });\n newValues = newIndex = null;\n }\n\n function removeData(reIndex) {\n if (iterable) {\n for (var i0 = 0, i1 = 0; i0 < iterablesEmptyRows.length; i0++) {\n if (reIndex[iterablesEmptyRows[i0]] !== REMOVED_INDEX) {\n iterablesEmptyRows[i1] = reIndex[iterablesEmptyRows[i0]];\n i1++;\n }\n }\n\n iterablesEmptyRows.length = i1;\n\n for (i0 = 0, i1 = 0; i0 < n; i0++) {\n if (reIndex[i0] !== REMOVED_INDEX) {\n if (i1 !== i0) iterablesIndexCount[i1] = iterablesIndexCount[i0];\n i1++;\n }\n }\n\n iterablesIndexCount = iterablesIndexCount.slice(0, i1);\n } // Rewrite our index, overwriting removed values\n\n\n var n0 = values.length;\n\n for (var i = 0, j = 0, oldDataIndex; i < n0; ++i) {\n oldDataIndex = index[i];\n\n if (reIndex[oldDataIndex] !== REMOVED_INDEX) {\n if (i !== j) values[j] = values[i];\n index[j] = reIndex[oldDataIndex];\n\n if (iterable) {\n iterablesIndexFilterStatus[j] = iterablesIndexFilterStatus[i];\n }\n\n ++j;\n }\n }\n\n values.length = j;\n if (iterable) iterablesIndexFilterStatus = iterablesIndexFilterStatus.slice(0, j);\n\n while (j < n0) {\n index[j++] = 0;\n } // Bisect again to recompute lo0 and hi0.\n\n\n var bounds = refilter(values);\n lo0 = bounds[0], hi0 = bounds[1];\n } // Updates the selected values based on the specified bounds [lo, hi].\n // This implementation is used by all the public filter methods.\n\n\n function filterIndexBounds(bounds) {\n var lo1 = bounds[0],\n hi1 = bounds[1];\n\n if (refilterFunction) {\n refilterFunction = null;\n filterIndexFunction(function (d, i) {\n return lo1 <= i && i < hi1;\n }, bounds[0] === 0 && bounds[1] === values.length);\n lo0 = lo1;\n hi0 = hi1;\n return dimension;\n }\n\n var i,\n j,\n k,\n added = [],\n removed = [],\n valueIndexAdded = [],\n valueIndexRemoved = []; // Fast incremental update based on previous lo index.\n\n if (lo1 < lo0) {\n for (i = lo1, j = Math.min(lo0, hi1); i < j; ++i) {\n added.push(index[i]);\n valueIndexAdded.push(i);\n }\n } else if (lo1 > lo0) {\n for (i = lo0, j = Math.min(lo1, hi0); i < j; ++i) {\n removed.push(index[i]);\n valueIndexRemoved.push(i);\n }\n } // Fast incremental update based on previous hi index.\n\n\n if (hi1 > hi0) {\n for (i = Math.max(lo1, hi0), j = hi1; i < j; ++i) {\n added.push(index[i]);\n valueIndexAdded.push(i);\n }\n } else if (hi1 < hi0) {\n for (i = Math.max(lo0, hi1), j = hi0; i < j; ++i) {\n removed.push(index[i]);\n valueIndexRemoved.push(i);\n }\n }\n\n if (!iterable) {\n // Flip filters normally.\n for (i = 0; i < added.length; i++) {\n filters[offset][added[i]] ^= one;\n }\n\n for (i = 0; i < removed.length; i++) {\n filters[offset][removed[i]] ^= one;\n }\n } else {\n // For iterables, we need to figure out if the row has been completely removed vs partially included\n // Only count a row as added if it is not already being aggregated. Only count a row\n // as removed if the last element being aggregated is removed.\n var newAdded = [];\n var newRemoved = [];\n\n for (i = 0; i < added.length; i++) {\n iterablesIndexCount[added[i]]++;\n iterablesIndexFilterStatus[valueIndexAdded[i]] = 0;\n\n if (iterablesIndexCount[added[i]] === 1) {\n filters[offset][added[i]] ^= one;\n newAdded.push(added[i]);\n }\n }\n\n for (i = 0; i < removed.length; i++) {\n iterablesIndexCount[removed[i]]--;\n iterablesIndexFilterStatus[valueIndexRemoved[i]] = 1;\n\n if (iterablesIndexCount[removed[i]] === 0) {\n filters[offset][removed[i]] ^= one;\n newRemoved.push(removed[i]);\n }\n }\n\n added = newAdded;\n removed = newRemoved; // Now handle empty rows.\n\n if (refilter === xfilterFilter.filterAll) {\n for (i = 0; i < iterablesEmptyRows.length; i++) {\n if (filters[offset][k = iterablesEmptyRows[i]] & one) {\n // Was not in the filter, so set the filter and add\n filters[offset][k] ^= one;\n added.push(k);\n }\n }\n } else {\n // filter in place - remove empty rows if necessary\n for (i = 0; i < iterablesEmptyRows.length; i++) {\n if (!(filters[offset][k = iterablesEmptyRows[i]] & one)) {\n // Was in the filter, so set the filter and remove\n filters[offset][k] ^= one;\n removed.push(k);\n }\n }\n }\n }\n\n lo0 = lo1;\n hi0 = hi1;\n filterListeners.forEach(function (l) {\n l(one, offset, added, removed);\n });\n triggerOnChange('filtered');\n return dimension;\n } // Filters this dimension using the specified range, value, or null.\n // If the range is null, this is equivalent to filterAll.\n // If the range is an array, this is equivalent to filterRange.\n // Otherwise, this is equivalent to filterExact.\n\n\n function filter(range) {\n return range == null ? filterAll() : Array.isArray(range) ? filterRange(range) : typeof range === \"function\" ? filterFunction(range) : filterExact(range);\n } // Filters this dimension to select the exact value.\n\n\n function filterExact(value) {\n filterValue = value;\n filterValuePresent = true;\n return filterIndexBounds((refilter = xfilterFilter.filterExact(bisect, value))(values));\n } // Filters this dimension to select the specified range [lo, hi].\n // The lower bound is inclusive, and the upper bound is exclusive.\n\n\n function filterRange(range) {\n filterValue = range;\n filterValuePresent = true;\n return filterIndexBounds((refilter = xfilterFilter.filterRange(bisect, range))(values));\n } // Clears any filters on this dimension.\n\n\n function filterAll() {\n filterValue = undefined;\n filterValuePresent = false;\n return filterIndexBounds((refilter = xfilterFilter.filterAll)(values));\n } // Filters this dimension using an arbitrary function.\n\n\n function filterFunction(f) {\n filterValue = f;\n filterValuePresent = true;\n refilterFunction = f;\n refilter = xfilterFilter.filterAll;\n filterIndexFunction(f, false);\n var bounds = refilter(values);\n lo0 = bounds[0], hi0 = bounds[1];\n return dimension;\n }\n\n function filterIndexFunction(f, filterAll) {\n var i,\n k,\n x,\n added = [],\n removed = [],\n valueIndexAdded = [],\n valueIndexRemoved = [],\n indexLength = values.length;\n\n if (!iterable) {\n for (i = 0; i < indexLength; ++i) {\n if (!(filters[offset][k = index[i]] & one) ^ !!(x = f(values[i], i))) {\n if (x) added.push(k);else removed.push(k);\n }\n }\n }\n\n if (iterable) {\n for (i = 0; i < indexLength; ++i) {\n if (f(values[i], i)) {\n added.push(index[i]);\n valueIndexAdded.push(i);\n } else {\n removed.push(index[i]);\n valueIndexRemoved.push(i);\n }\n }\n }\n\n if (!iterable) {\n for (i = 0; i < added.length; i++) {\n if (filters[offset][added[i]] & one) filters[offset][added[i]] &= zero;\n }\n\n for (i = 0; i < removed.length; i++) {\n if (!(filters[offset][removed[i]] & one)) filters[offset][removed[i]] |= one;\n }\n } else {\n var newAdded = [];\n var newRemoved = [];\n\n for (i = 0; i < added.length; i++) {\n // First check this particular value needs to be added\n if (iterablesIndexFilterStatus[valueIndexAdded[i]] === 1) {\n iterablesIndexCount[added[i]]++;\n iterablesIndexFilterStatus[valueIndexAdded[i]] = 0;\n\n if (iterablesIndexCount[added[i]] === 1) {\n filters[offset][added[i]] ^= one;\n newAdded.push(added[i]);\n }\n }\n }\n\n for (i = 0; i < removed.length; i++) {\n // First check this particular value needs to be removed\n if (iterablesIndexFilterStatus[valueIndexRemoved[i]] === 0) {\n iterablesIndexCount[removed[i]]--;\n iterablesIndexFilterStatus[valueIndexRemoved[i]] = 1;\n\n if (iterablesIndexCount[removed[i]] === 0) {\n filters[offset][removed[i]] ^= one;\n newRemoved.push(removed[i]);\n }\n }\n }\n\n added = newAdded;\n removed = newRemoved; // Now handle empty rows.\n\n if (filterAll) {\n for (i = 0; i < iterablesEmptyRows.length; i++) {\n if (filters[offset][k = iterablesEmptyRows[i]] & one) {\n // Was not in the filter, so set the filter and add\n filters[offset][k] ^= one;\n added.push(k);\n }\n }\n } else {\n // filter in place - remove empty rows if necessary\n for (i = 0; i < iterablesEmptyRows.length; i++) {\n if (!(filters[offset][k = iterablesEmptyRows[i]] & one)) {\n // Was in the filter, so set the filter and remove\n filters[offset][k] ^= one;\n removed.push(k);\n }\n }\n }\n }\n\n filterListeners.forEach(function (l) {\n l(one, offset, added, removed);\n });\n triggerOnChange('filtered');\n }\n\n function currentFilter() {\n return filterValue;\n }\n\n function hasCurrentFilter() {\n return filterValuePresent;\n } // Returns the top K selected records based on this dimension's order.\n // Note: observes this dimension's filter, unlike group and groupAll.\n\n\n function top(k, top_offset) {\n var array = [],\n i = hi0,\n j,\n toSkip = 0;\n if (top_offset && top_offset > 0) toSkip = top_offset;\n\n while (--i >= lo0 && k > 0) {\n if (filters.zero(j = index[i])) {\n if (toSkip > 0) {\n //skip matching row\n --toSkip;\n } else {\n array.push(data[j]);\n --k;\n }\n }\n }\n\n if (iterable) {\n for (i = 0; i < iterablesEmptyRows.length && k > 0; i++) {\n // Add row with empty iterable column at the end\n if (filters.zero(j = iterablesEmptyRows[i])) {\n if (toSkip > 0) {\n //skip matching row\n --toSkip;\n } else {\n array.push(data[j]);\n --k;\n }\n }\n }\n }\n\n return array;\n } // Returns the bottom K selected records based on this dimension's order.\n // Note: observes this dimension's filter, unlike group and groupAll.\n\n\n function bottom(k, bottom_offset) {\n var array = [],\n i,\n j,\n toSkip = 0;\n if (bottom_offset && bottom_offset > 0) toSkip = bottom_offset;\n\n if (iterable) {\n // Add row with empty iterable column at the top\n for (i = 0; i < iterablesEmptyRows.length && k > 0; i++) {\n if (filters.zero(j = iterablesEmptyRows[i])) {\n if (toSkip > 0) {\n //skip matching row\n --toSkip;\n } else {\n array.push(data[j]);\n --k;\n }\n }\n }\n }\n\n i = lo0;\n\n while (i < hi0 && k > 0) {\n if (filters.zero(j = index[i])) {\n if (toSkip > 0) {\n //skip matching row\n --toSkip;\n } else {\n array.push(data[j]);\n --k;\n }\n }\n\n i++;\n }\n\n return array;\n } // Adds a new group to this dimension, using the specified key function.\n\n\n function group(key) {\n var group = {\n top: top,\n all: all,\n reduce: reduce,\n reduceCount: reduceCount,\n reduceSum: reduceSum,\n order: order,\n orderNatural: orderNatural,\n size: size,\n dispose: dispose,\n remove: dispose // for backwards-compatibility\n\n }; // Ensure that this group will be removed when the dimension is removed.\n\n dimensionGroups.push(group);\n var groups,\n // array of {key, value}\n groupIndex,\n // object id ↦ group id\n groupWidth = 8,\n groupCapacity = capacity(groupWidth),\n k = 0,\n // cardinality\n select,\n heap,\n reduceAdd,\n reduceRemove,\n reduceInitial,\n update = cr_null,\n reset = cr_null,\n resetNeeded = true,\n groupAll = key === cr_null,\n n0old;\n if (arguments.length < 1) key = cr_identity; // The group listens to the crossfilter for when any dimension changes, so\n // that it can update the associated reduce values. It must also listen to\n // the parent dimension for when data is added, and compute new keys.\n\n filterListeners.push(update);\n indexListeners.push(add);\n removeDataListeners.push(removeData); // Incorporate any existing data into the grouping.\n\n add(values, index, 0, n); // Incorporates the specified new values into this group.\n // This function is responsible for updating groups and groupIndex.\n\n function add(newValues, newIndex, n0, n1) {\n if (iterable) {\n n0old = n0;\n n0 = values.length - newValues.length;\n n1 = newValues.length;\n }\n\n var oldGroups = groups,\n reIndex = iterable ? [] : cr_index(k, groupCapacity),\n add = reduceAdd,\n remove = reduceRemove,\n initial = reduceInitial,\n k0 = k,\n // old cardinality\n i0 = 0,\n // index of old group\n i1 = 0,\n // index of new record\n j,\n // object id\n g0,\n // old group\n x0,\n // old key\n x1,\n // new key\n g,\n // group to add\n x; // key of group to add\n // If a reset is needed, we don't need to update the reduce values.\n\n if (resetNeeded) add = initial = cr_null;\n if (resetNeeded) remove = initial = cr_null; // Reset the new groups (k is a lower bound).\n // Also, make sure that groupIndex exists and is long enough.\n\n groups = new Array(k), k = 0;\n\n if (iterable) {\n groupIndex = k0 ? groupIndex : [];\n } else {\n groupIndex = k0 > 1 ? xfilterArray.arrayLengthen(groupIndex, n) : cr_index(n, groupCapacity);\n } // Get the first old key (x0 of g0), if it exists.\n\n\n if (k0) x0 = (g0 = oldGroups[0]).key; // Find the first new key (x1), skipping NaN keys.\n\n while (i1 < n1 && !((x1 = key(newValues[i1])) >= x1)) {\n ++i1;\n } // While new keys remain…\n\n\n while (i1 < n1) {\n // Determine the lesser of the two current keys; new and old.\n // If there are no old keys remaining, then always add the new key.\n if (g0 && x0 <= x1) {\n g = g0, x = x0; // Record the new index of the old group.\n\n reIndex[i0] = k; // Retrieve the next old key.\n\n g0 = oldGroups[++i0];\n if (g0) x0 = g0.key;\n } else {\n g = {\n key: x1,\n value: initial()\n }, x = x1;\n } // Add the lesser group.\n\n\n groups[k] = g; // Add any selected records belonging to the added group, while\n // advancing the new key and populating the associated group index.\n\n while (x1 <= x) {\n j = newIndex[i1] + (iterable ? n0old : n0);\n\n if (iterable) {\n if (groupIndex[j]) {\n groupIndex[j].push(k);\n } else {\n groupIndex[j] = [k];\n }\n } else {\n groupIndex[j] = k;\n } // Always add new values to groups. Only remove when not in filter.\n // This gives groups full information on data life-cycle.\n\n\n g.value = add(g.value, data[j], true);\n if (!filters.zeroExcept(j, offset, zero)) g.value = remove(g.value, data[j], false);\n if (++i1 >= n1) break;\n x1 = key(newValues[i1]);\n }\n\n groupIncrement();\n } // Add any remaining old groups that were greater th1an all new keys.\n // No incremental reduce is needed; these groups have no new records.\n // Also record the new index of the old group.\n\n\n while (i0 < k0) {\n groups[reIndex[i0] = k] = oldGroups[i0++];\n groupIncrement();\n } // Fill in gaps with empty arrays where there may have been rows with empty iterables\n\n\n if (iterable) {\n for (var index1 = 0; index1 < n; index1++) {\n if (!groupIndex[index1]) {\n groupIndex[index1] = [];\n }\n }\n } // If we added any new groups before any old groups,\n // update the group index of all the old records.\n\n\n if (k > i0) {\n if (iterable) {\n for (i0 = 0; i0 < n0old; ++i0) {\n for (index1 = 0; index1 < groupIndex[i0].length; index1++) {\n groupIndex[i0][index1] = reIndex[groupIndex[i0][index1]];\n }\n }\n } else {\n for (i0 = 0; i0 < n0; ++i0) {\n groupIndex[i0] = reIndex[groupIndex[i0]];\n }\n }\n } // Modify the update and reset behavior based on the cardinality.\n // If the cardinality is less than or equal to one, then the groupIndex\n // is not needed. If the cardinality is zero, then there are no records\n // and therefore no groups to update or reset. Note that we also must\n // change the registered listener to point to the new method.\n\n\n j = filterListeners.indexOf(update);\n\n if (k > 1 || iterable) {\n update = updateMany;\n reset = resetMany;\n } else {\n if (!k && groupAll) {\n k = 1;\n groups = [{\n key: null,\n value: initial()\n }];\n }\n\n if (k === 1) {\n update = updateOne;\n reset = resetOne;\n } else {\n update = cr_null;\n reset = cr_null;\n }\n\n groupIndex = null;\n }\n\n filterListeners[j] = update; // Count the number of added groups,\n // and widen the group index as needed.\n\n function groupIncrement() {\n if (iterable) {\n k++;\n return;\n }\n\n if (++k === groupCapacity) {\n reIndex = xfilterArray.arrayWiden(reIndex, groupWidth <<= 1);\n groupIndex = xfilterArray.arrayWiden(groupIndex, groupWidth);\n groupCapacity = capacity(groupWidth);\n }\n }\n }\n\n function removeData(reIndex) {\n if (k > 1 || iterable) {\n var oldK = k,\n oldGroups = groups,\n seenGroups = cr_index(oldK, oldK),\n i,\n i0,\n j; // Filter out non-matches by copying matching group index entries to\n // the beginning of the array.\n\n if (!iterable) {\n for (i = 0, j = 0; i < n; ++i) {\n if (reIndex[i] !== REMOVED_INDEX) {\n seenGroups[groupIndex[j] = groupIndex[i]] = 1;\n ++j;\n }\n }\n } else {\n for (i = 0, j = 0; i < n; ++i) {\n if (reIndex[i] !== REMOVED_INDEX) {\n groupIndex[j] = groupIndex[i];\n\n for (i0 = 0; i0 < groupIndex[j].length; i0++) {\n seenGroups[groupIndex[j][i0]] = 1;\n }\n\n ++j;\n }\n }\n\n groupIndex = groupIndex.slice(0, j);\n } // Reassemble groups including only those groups that were referred\n // to by matching group index entries. Note the new group index in\n // seenGroups.\n\n\n groups = [], k = 0;\n\n for (i = 0; i < oldK; ++i) {\n if (seenGroups[i]) {\n seenGroups[i] = k++;\n groups.push(oldGroups[i]);\n }\n }\n\n if (k > 1 || iterable) {\n // Reindex the group index using seenGroups to find the new index.\n if (!iterable) {\n for (i = 0; i < j; ++i) {\n groupIndex[i] = seenGroups[groupIndex[i]];\n }\n } else {\n for (i = 0; i < j; ++i) {\n for (i0 = 0; i0 < groupIndex[i].length; ++i0) {\n groupIndex[i][i0] = seenGroups[groupIndex[i][i0]];\n }\n }\n }\n } else {\n groupIndex = null;\n }\n\n filterListeners[filterListeners.indexOf(update)] = k > 1 || iterable ? (reset = resetMany, update = updateMany) : k === 1 ? (reset = resetOne, update = updateOne) : reset = update = cr_null;\n } else if (k === 1) {\n if (groupAll) return;\n\n for (var index3 = 0; index3 < n; ++index3) {\n if (reIndex[index3] !== REMOVED_INDEX) return;\n }\n\n groups = [], k = 0;\n filterListeners[filterListeners.indexOf(update)] = update = reset = cr_null;\n }\n } // Reduces the specified selected or deselected records.\n // This function is only used when the cardinality is greater than 1.\n // notFilter indicates a crossfilter.add/remove operation.\n\n\n function updateMany(filterOne, filterOffset, added, removed, notFilter) {\n if (filterOne === one && filterOffset === offset || resetNeeded) return;\n var i, j, k, n, g;\n\n if (iterable) {\n // Add the added values.\n for (i = 0, n = added.length; i < n; ++i) {\n if (filters.zeroExcept(k = added[i], offset, zero)) {\n for (j = 0; j < groupIndex[k].length; j++) {\n g = groups[groupIndex[k][j]];\n g.value = reduceAdd(g.value, data[k], false, j);\n }\n }\n } // Remove the removed values.\n\n\n for (i = 0, n = removed.length; i < n; ++i) {\n if (filters.onlyExcept(k = removed[i], offset, zero, filterOffset, filterOne)) {\n for (j = 0; j < groupIndex[k].length; j++) {\n g = groups[groupIndex[k][j]];\n g.value = reduceRemove(g.value, data[k], notFilter, j);\n }\n }\n }\n\n return;\n } // Add the added values.\n\n\n for (i = 0, n = added.length; i < n; ++i) {\n if (filters.zeroExcept(k = added[i], offset, zero)) {\n g = groups[groupIndex[k]];\n g.value = reduceAdd(g.value, data[k], false);\n }\n } // Remove the removed values.\n\n\n for (i = 0, n = removed.length; i < n; ++i) {\n if (filters.onlyExcept(k = removed[i], offset, zero, filterOffset, filterOne)) {\n g = groups[groupIndex[k]];\n g.value = reduceRemove(g.value, data[k], notFilter);\n }\n }\n } // Reduces the specified selected or deselected records.\n // This function is only used when the cardinality is 1.\n // notFilter indicates a crossfilter.add/remove operation.\n\n\n function updateOne(filterOne, filterOffset, added, removed, notFilter) {\n if (filterOne === one && filterOffset === offset || resetNeeded) return;\n var i,\n k,\n n,\n g = groups[0]; // Add the added values.\n\n for (i = 0, n = added.length; i < n; ++i) {\n if (filters.zeroExcept(k = added[i], offset, zero)) {\n g.value = reduceAdd(g.value, data[k], false);\n }\n } // Remove the removed values.\n\n\n for (i = 0, n = removed.length; i < n; ++i) {\n if (filters.onlyExcept(k = removed[i], offset, zero, filterOffset, filterOne)) {\n g.value = reduceRemove(g.value, data[k], notFilter);\n }\n }\n } // Recomputes the group reduce values from scratch.\n // This function is only used when the cardinality is greater than 1.\n\n\n function resetMany() {\n var i, j, g; // Reset all group values.\n\n for (i = 0; i < k; ++i) {\n groups[i].value = reduceInitial();\n } // We add all records and then remove filtered records so that reducers\n // can build an 'unfiltered' view even if there are already filters in\n // place on other dimensions.\n\n\n if (iterable) {\n for (i = 0; i < n; ++i) {\n for (j = 0; j < groupIndex[i].length; j++) {\n g = groups[groupIndex[i][j]];\n g.value = reduceAdd(g.value, data[i], true, j);\n }\n }\n\n for (i = 0; i < n; ++i) {\n if (!filters.zeroExcept(i, offset, zero)) {\n for (j = 0; j < groupIndex[i].length; j++) {\n g = groups[groupIndex[i][j]];\n g.value = reduceRemove(g.value, data[i], false, j);\n }\n }\n }\n\n return;\n }\n\n for (i = 0; i < n; ++i) {\n g = groups[groupIndex[i]];\n g.value = reduceAdd(g.value, data[i], true);\n }\n\n for (i = 0; i < n; ++i) {\n if (!filters.zeroExcept(i, offset, zero)) {\n g = groups[groupIndex[i]];\n g.value = reduceRemove(g.value, data[i], false);\n }\n }\n } // Recomputes the group reduce values from scratch.\n // This function is only used when the cardinality is 1.\n\n\n function resetOne() {\n var i,\n g = groups[0]; // Reset the singleton group values.\n\n g.value = reduceInitial(); // We add all records and then remove filtered records so that reducers\n // can build an 'unfiltered' view even if there are already filters in\n // place on other dimensions.\n\n for (i = 0; i < n; ++i) {\n g.value = reduceAdd(g.value, data[i], true);\n }\n\n for (i = 0; i < n; ++i) {\n if (!filters.zeroExcept(i, offset, zero)) {\n g.value = reduceRemove(g.value, data[i], false);\n }\n }\n } // Returns the array of group values, in the dimension's natural order.\n\n\n function all() {\n if (resetNeeded) reset(), resetNeeded = false;\n return groups;\n } // Returns a new array containing the top K group values, in reduce order.\n\n\n function top(k) {\n var top = select(all(), 0, groups.length, k);\n return heap.sort(top, 0, top.length);\n } // Sets the reduce behavior for this group to use the specified functions.\n // This method lazily recomputes the reduce values, waiting until needed.\n\n\n function reduce(add, remove, initial) {\n reduceAdd = add;\n reduceRemove = remove;\n reduceInitial = initial;\n resetNeeded = true;\n return group;\n } // A convenience method for reducing by count.\n\n\n function reduceCount() {\n return reduce(xfilterReduce.reduceIncrement, xfilterReduce.reduceDecrement, cr_zero);\n } // A convenience method for reducing by sum(value).\n\n\n function reduceSum(value) {\n return reduce(xfilterReduce.reduceAdd(value), xfilterReduce.reduceSubtract(value), cr_zero);\n } // Sets the reduce order, using the specified accessor.\n\n\n function order(value) {\n select = xfilterHeapselect.by(valueOf);\n heap = xfilterHeap.by(valueOf);\n\n function valueOf(d) {\n return value(d.value);\n }\n\n return group;\n } // A convenience method for natural ordering by reduce value.\n\n\n function orderNatural() {\n return order(cr_identity);\n } // Returns the cardinality of this group, irrespective of any filters.\n\n\n function size() {\n return k;\n } // Removes this group and associated event listeners.\n\n\n function dispose() {\n var i = filterListeners.indexOf(update);\n if (i >= 0) filterListeners.splice(i, 1);\n i = indexListeners.indexOf(add);\n if (i >= 0) indexListeners.splice(i, 1);\n i = removeDataListeners.indexOf(removeData);\n if (i >= 0) removeDataListeners.splice(i, 1);\n i = dimensionGroups.indexOf(group);\n if (i >= 0) dimensionGroups.splice(i, 1);\n return group;\n }\n\n return reduceCount().orderNatural();\n } // A convenience function for generating a singleton group.\n\n\n function groupAll() {\n var g = group(cr_null),\n all = g.all;\n delete g.all;\n delete g.top;\n delete g.order;\n delete g.orderNatural;\n delete g.size;\n\n g.value = function () {\n return all()[0].value;\n };\n\n return g;\n } // Removes this dimension and associated groups and event listeners.\n\n\n function dispose() {\n dimensionGroups.forEach(function (group) {\n group.dispose();\n });\n var i = dataListeners.indexOf(preAdd);\n if (i >= 0) dataListeners.splice(i, 1);\n i = dataListeners.indexOf(postAdd);\n if (i >= 0) dataListeners.splice(i, 1);\n i = removeDataListeners.indexOf(removeData);\n if (i >= 0) removeDataListeners.splice(i, 1);\n filters.masks[offset] &= zero;\n return filterAll();\n }\n\n return dimension;\n } // A convenience method for groupAll on a dummy dimension.\n // This implementation can be optimized since it always has cardinality 1.\n\n\n function groupAll() {\n var group = {\n reduce: reduce,\n reduceCount: reduceCount,\n reduceSum: reduceSum,\n value: value,\n dispose: dispose,\n remove: dispose // for backwards-compatibility\n\n };\n var reduceValue,\n reduceAdd,\n reduceRemove,\n reduceInitial,\n resetNeeded = true; // The group listens to the crossfilter for when any dimension changes, so\n // that it can update the reduce value. It must also listen to the parent\n // dimension for when data is added.\n\n filterListeners.push(update);\n dataListeners.push(add); // For consistency; actually a no-op since resetNeeded is true.\n\n add(data, 0, n); // Incorporates the specified new values into this group.\n\n function add(newData, n0) {\n var i;\n if (resetNeeded) return; // Cycle through all the values.\n\n for (i = n0; i < n; ++i) {\n // Add all values all the time.\n reduceValue = reduceAdd(reduceValue, data[i], true); // Remove the value if filtered.\n\n if (!filters.zero(i)) {\n reduceValue = reduceRemove(reduceValue, data[i], false);\n }\n }\n } // Reduces the specified selected or deselected records.\n\n\n function update(filterOne, filterOffset, added, removed, notFilter) {\n var i, k, n;\n if (resetNeeded) return; // Add the added values.\n\n for (i = 0, n = added.length; i < n; ++i) {\n if (filters.zero(k = added[i])) {\n reduceValue = reduceAdd(reduceValue, data[k], notFilter);\n }\n } // Remove the removed values.\n\n\n for (i = 0, n = removed.length; i < n; ++i) {\n if (filters.only(k = removed[i], filterOffset, filterOne)) {\n reduceValue = reduceRemove(reduceValue, data[k], notFilter);\n }\n }\n } // Recomputes the group reduce value from scratch.\n\n\n function reset() {\n var i;\n reduceValue = reduceInitial(); // Cycle through all the values.\n\n for (i = 0; i < n; ++i) {\n // Add all values all the time.\n reduceValue = reduceAdd(reduceValue, data[i], true); // Remove the value if it is filtered.\n\n if (!filters.zero(i)) {\n reduceValue = reduceRemove(reduceValue, data[i], false);\n }\n }\n } // Sets the reduce behavior for this group to use the specified functions.\n // This method lazily recomputes the reduce value, waiting until needed.\n\n\n function reduce(add, remove, initial) {\n reduceAdd = add;\n reduceRemove = remove;\n reduceInitial = initial;\n resetNeeded = true;\n return group;\n } // A convenience method for reducing by count.\n\n\n function reduceCount() {\n return reduce(xfilterReduce.reduceIncrement, xfilterReduce.reduceDecrement, cr_zero);\n } // A convenience method for reducing by sum(value).\n\n\n function reduceSum(value) {\n return reduce(xfilterReduce.reduceAdd(value), xfilterReduce.reduceSubtract(value), cr_zero);\n } // Returns the computed reduce value.\n\n\n function value() {\n if (resetNeeded) reset(), resetNeeded = false;\n return reduceValue;\n } // Removes this group and associated event listeners.\n\n\n function dispose() {\n var i = filterListeners.indexOf(update);\n if (i >= 0) filterListeners.splice(i, 1);\n i = dataListeners.indexOf(add);\n if (i >= 0) dataListeners.splice(i, 1);\n return group;\n }\n\n return reduceCount();\n } // Returns the number of records in this crossfilter, irrespective of any filters.\n\n\n function size() {\n return n;\n } // Returns the raw row data contained in this crossfilter\n\n\n function all() {\n return data;\n } // Returns row data with all dimension filters applied, except for filters in ignore_dimensions\n\n\n function allFiltered(ignore_dimensions) {\n var array = [],\n i = 0,\n mask = maskForDimensions(ignore_dimensions || []);\n\n for (i = 0; i < n; i++) {\n if (filters.zeroExceptMask(i, mask)) {\n array.push(data[i]);\n }\n }\n\n return array;\n }\n\n function onChange(cb) {\n if (typeof cb !== 'function') {\n /* eslint no-console: 0 */\n console.warn('onChange callback parameter must be a function!');\n return;\n }\n\n callbacks.push(cb);\n return function () {\n callbacks.splice(callbacks.indexOf(cb), 1);\n };\n }\n\n function triggerOnChange(eventName) {\n for (var i = 0; i < callbacks.length; i++) {\n callbacks[i](eventName);\n }\n }\n\n return arguments.length ? add(arguments[0]) : crossfilter;\n} // Returns an array of size n, big enough to store ids up to m.\n\n\nfunction cr_index(n, m) {\n return (m < 0x101 ? xfilterArray.array8 : m < 0x10001 ? xfilterArray.array16 : xfilterArray.array32)(n);\n} // Constructs a new array of size n, with sequential values from 0 to n - 1.\n\n\nfunction cr_range(n) {\n var range = cr_index(n, n);\n\n for (var i = -1; ++i < n;) {\n range[i] = i;\n }\n\n return range;\n}\n\nfunction capacity(w) {\n return w === 8 ? 0x100 : w === 16 ? 0x10000 : 0x100000000;\n}","import { Map } from 'immutable'\r\n\r\n// Get counts based on current filters\r\nexport const countByDimension = dimensions => {\r\n let dimCounts = Map()\r\n\r\n // only generate counts for the non-internal filters\r\n Object.values(dimensions)\r\n .filter(({ config: { internal } }) => !internal)\r\n .forEach(dimension => {\r\n const grouped = dimension.group().all()\r\n\r\n // Convert the array of key:count returned by crossfilter to a Map\r\n const counts = grouped.reduce((result, item) => {\r\n if (item) {\r\n return result.set(item.key, item.value)\r\n }\r\n return result\r\n }, Map())\r\n\r\n dimCounts = dimCounts.set(dimension.config.field, counts)\r\n })\r\n return dimCounts\r\n}\r\n\r\nexport const countFiltered = cf =>\r\n cf\r\n .groupAll()\r\n .reduceCount()\r\n .value()\r\n","import { useReducer, useRef } from 'react'\r\n\r\nimport { Map, List, Set } from 'immutable'\r\n\r\nimport Crossfilter from 'crossfilter2'\r\nimport { isDebug } from 'util/dom'\r\nimport { countByDimension, countFiltered } from './util'\r\n\r\n// Actions\r\nexport const RESET_FILTERS = 'RESET_FILTERS'\r\nexport const SET_FILTER = 'SET_FILTER' // payload is {field, filterValue}\r\n\r\n// Incoming data is an immutableJS List of Maps\r\nexport const useCrossfilter = (data, filters) => {\r\n const crossfilterRef = useRef(null)\r\n const dimensionsRef = useRef(null)\r\n\r\n // payload: {type: \"SOME_TYPE\", payload: }\r\n const reducer = (state, { type, payload }) => {\r\n const { current: crossfilter } = crossfilterRef\r\n const { current: dimensions } = dimensionsRef\r\n\r\n if (isDebug) {\r\n console.log(`Handling ${type}`, payload)\r\n console.log('Prev state', state.toJS())\r\n }\r\n\r\n let newState = state\r\n\r\n switch (type) {\r\n case SET_FILTER: {\r\n const { field, filterValue } = payload\r\n const dimension = dimensions[field]\r\n\r\n if (!filterValue || filterValue.size === 0) {\r\n // there are no filter values, so clear filter on this field\r\n dimension.filterAll()\r\n } else {\r\n const filterFunc = dimension.config.filterFunc(filterValue)\r\n dimension.filterFunction(filterFunc)\r\n }\r\n\r\n newState = state.merge({\r\n // convert Array from crossfilter back to an immutable List\r\n data: List(crossfilter.allFiltered()),\r\n dimensionCounts: countByDimension(dimensions),\r\n filteredCount: countFiltered(crossfilter),\r\n filters: state.get('filters').set(field, filterValue),\r\n })\r\n break\r\n }\r\n\r\n case RESET_FILTERS: {\r\n const { fields } = payload\r\n\r\n let newFilters = state.get('filters')\r\n\r\n fields.forEach(field => {\r\n dimensions[field].filterAll()\r\n\r\n const filter = newFilters.get(field)\r\n newFilters = newFilters.set(field, filter ? filter.clear() : Set())\r\n })\r\n\r\n newState = state.merge({\r\n // convert Array from crossfilter back to an immutable List\r\n data: List(crossfilter.allFiltered()),\r\n dimensionCounts: countByDimension(dimensions),\r\n filteredCount: countFiltered(crossfilter),\r\n filters: newFilters,\r\n })\r\n break\r\n }\r\n\r\n default: {\r\n console.error('unhandled action type', type)\r\n break\r\n }\r\n }\r\n\r\n if (isDebug) {\r\n console.log('Next state', newState.toJS())\r\n }\r\n\r\n return newState\r\n }\r\n\r\n // Initialize crossfilter and dimensions when useReducer is first setup\r\n const initialize = () => {\r\n // crossfilter depends on Array methods at the top level\r\n // so we shallowly convert the List to an Array.\r\n const crossfilter = Crossfilter(data.toArray())\r\n\r\n const dimensions = {}\r\n filters.forEach(filter => {\r\n const { field, isArray, getValue } = filter\r\n // default `getValue` function is identify function for field\r\n // const dimensionFunction = getValue || (d => d[field])\r\n const dimensionFunction =\r\n getValue ||\r\n (record => {\r\n const value = record.get(field)\r\n // if incoming value is an immutableJS object, convert it to JS first\r\n if (value && value.toJS !== undefined) {\r\n return value.toJS()\r\n }\r\n return value\r\n })\r\n const dimension = crossfilter.dimension(dimensionFunction, !!isArray)\r\n dimension.config = filter\r\n dimensions[field] = dimension\r\n })\r\n\r\n crossfilterRef.current = crossfilter\r\n dimensionsRef.current = dimensions\r\n\r\n if (isDebug) {\r\n window.crossfilter = crossfilter\r\n window.dimensions = dimensions\r\n }\r\n\r\n // initial state\r\n return Map({\r\n data,\r\n filters: Map(),\r\n dimensionCounts: countByDimension(dimensions),\r\n filteredCount: countFiltered(crossfilter),\r\n total: data.size,\r\n })\r\n }\r\n\r\n return useReducer(reducer, undefined, initialize)\r\n}\r\n","import React, { createContext } from 'react'\r\nimport ImmutablePropTypes from 'react-immutable-proptypes'\r\nimport PropTypes from 'prop-types'\r\n\r\nimport { useCrossfilter } from './Crossfilter'\r\n\r\n/**\r\n * Provide Crossfilter as a context so that components deeper in the\r\n * component tree can access crossfilter state or dispatch.\r\n */\r\nexport const Context = createContext()\r\nexport const Provider = ({ data, filters, children }) => {\r\n const [state, dispatch] = useCrossfilter(data, filters)\r\n return (\r\n {children}\r\n )\r\n}\r\n\r\nProvider.propTypes = {\r\n data: ImmutablePropTypes.list.isRequired,\r\n filters: PropTypes.array.isRequired,\r\n children: PropTypes.oneOfType([\r\n PropTypes.node,\r\n PropTypes.element,\r\n PropTypes.array,\r\n ]).isRequired,\r\n}\r\n","import React, { useState } from 'react'\r\nimport PropTypes from 'prop-types'\r\nimport { Text } from 'rebass'\r\n\r\nimport { Flex, Box, Columns, Column as BaseColumn } from 'components/Grid'\r\n\r\nimport styled, { themeGet } from 'util/style'\r\n\r\nconst Wrapper = styled.div`\r\n cursor: pointer;\r\n position: absolute;\r\n right: 10px;\r\n bottom: 24px;\r\n z-index: 10000;\r\n background-color: #fff;\r\n border-radius: 0.5rem;\r\n border: 1px solid ${themeGet('colors.grey.400')};\r\n box-shadow: 1px 1px 4px #666;\r\n padding: 0.25rem 0.5rem 0.5rem;\r\n max-height: 90%;\r\n overflow-y: auto;\r\n overflow-x: hidden;\r\n`\r\n\r\nconst Column = styled(BaseColumn)`\r\n max-width: 200px;\r\n\r\n &:not(:first-child) {\r\n margin-left: 1rem;\r\n }\r\n`\r\n\r\nconst Title = styled(Text).attrs({\r\n fontSize: ['0.8rem', '0.8rem', '1rem'],\r\n})``\r\n\r\nconst Patch = styled(Box).attrs({\r\n flex: 0,\r\n})`\r\n flex: 0 0 1.25rem;\r\n width: 1.25rem;\r\n height: 1.25rem;\r\n background-color: ${({ color }) => color || 'transparent'};\r\n border-style: solid;\r\n border-width: ${({ borderWidth }) => borderWidth || 0}px;\r\n border-color: ${({ borderColor }) => borderColor || 'transparent'};\r\n border-radius: 0.25rem;\r\n`\r\n\r\nconst Label = styled(Box).attrs({})`\r\n font-size: 0.7rem;\r\n color: ${themeGet('colors.grey.800')};\r\n margin-left: 0.5rem;\r\n`\r\n\r\nconst Circle = ({ radius, color, borderColor, borderWidth, scale }) => {\r\n const width = 2 * borderWidth + 2 * radius * scale\r\n const center = width / 2\r\n\r\n return (\r\n \r\n \r\n \r\n )\r\n}\r\n\r\nCircle.propTypes = {\r\n radius: PropTypes.number.isRequired,\r\n color: PropTypes.string,\r\n borderColor: PropTypes.string,\r\n borderWidth: PropTypes.number,\r\n scale: PropTypes.number,\r\n}\r\n\r\nCircle.defaultProps = {\r\n borderWidth: 0,\r\n color: null,\r\n borderColor: null,\r\n scale: 1,\r\n}\r\n\r\nconst EntryWrapper = styled(Flex).attrs({\r\n alignItems: 'center',\r\n})`\r\n &:not(:first-child) {\r\n margin-top: 0.25rem;\r\n }\r\n`\r\n\r\nconst Entry = ({ type, label, ...entry }) => (\r\n \r\n {type === 'circle' ? (\r\n \r\n ) : (\r\n \r\n )}\r\n \r\n \r\n)\r\n\r\nEntry.propTypes = {\r\n type: PropTypes.string.isRequired,\r\n label: PropTypes.string.isRequired,\r\n}\r\n\r\nconst Legend = ({ title, entries }) => {\r\n if (!entries.length) return null\r\n\r\n const [isClosed, setIsClosed] = useState(false)\r\n const toggle = () => setIsClosed(prevIsClosed => !prevIsClosed)\r\n\r\n const cols = []\r\n // if (entries.length > 6) {\r\n // const numCols = entries.length / 4\r\n // for (let i = 0; i < numCols; i += 1) {\r\n // cols.push(entries.slice(i * 4, i * 4 + 4))\r\n // }\r\n // console.log(entries, cols)\r\n // }\r\n\r\n return (\r\n \r\n {isClosed ? (\r\n {title}\r\n ) : (\r\n \r\n {cols.length ? (\r\n <>\r\n {cols.map((colEntries, i) => (\r\n \r\n {colEntries.map(entry => (\r\n \r\n ))}\r\n \r\n ))}\r\n {/* \r\n {entries.slice(0, Math.round(entries.length / 2)).map(entry => (\r\n \r\n ))}\r\n \r\n \r\n {entries\r\n .slice(Math.round(entries.length / 2), entries.length)\r\n .map(entry => (\r\n \r\n ))}\r\n */}\r\n \r\n ) : (\r\n \r\n {entries.map(entry => (\r\n \r\n ))}\r\n \r\n )}\r\n \r\n )}\r\n \r\n )\r\n}\r\n\r\nLegend.propTypes = {\r\n title: PropTypes.string,\r\n entries: PropTypes.arrayOf(\r\n PropTypes.shape({\r\n label: PropTypes.string.isRequired,\r\n color: PropTypes.string,\r\n borderColor: PropTypes.string,\r\n borderWidth: PropTypes.number,\r\n radius: PropTypes.number,\r\n })\r\n ),\r\n}\r\n\r\nLegend.defaultProps = {\r\n title: 'Legend',\r\n entries: [],\r\n}\r\n\r\nexport default Legend\r\n","import React, { useState, memo } from 'react'\r\nimport PropTypes from 'prop-types'\r\n\r\nimport styled, { css, themeGet } from 'util/style'\r\n\r\nimport LightIcon from 'images/light-v9.png'\r\nimport StreetsIcon from 'images/streets-v11.png'\r\nimport SatelliteIcon from 'images/satellite-streets-v11.jpg'\r\n\r\nconst Wrapper = styled.div`\r\n cursor: pointer;\r\n position: absolute;\r\n left: 10px;\r\n bottom: 24px;\r\n z-index: 999;\r\n`\r\n\r\nconst Basemap = styled.img`\r\n box-sizing: border-box;\r\n border: 2px solid\r\n ${({ isActive }) => (isActive ? themeGet('colors.highlight.500') : '#fff')};\r\n box-shadow: 0 1px 5px rgba(0, 0, 0, 0.65);\r\n margin: 0;\r\n\r\n width: 64px;\r\n height: 64px;\r\n border-radius: 64px;\r\n\r\n &:not(:first-child) {\r\n margin-left: 0.25rem;\r\n }\r\n`\r\n\r\nconst icons = {\r\n 'light-v9': LightIcon,\r\n 'satellite-streets-v11': SatelliteIcon,\r\n 'streets-v11': StreetsIcon,\r\n}\r\n\r\nconst StyleSelector = ({ styles, onChange }) => {\r\n const [basemap, setBasemap] = useState(styles[0])\r\n const [isOpen, setIsOpen] = useState(false)\r\n\r\n const handleBasemapClick = newBasemap => {\r\n setIsOpen(false)\r\n\r\n if (newBasemap === basemap) return\r\n\r\n setBasemap(newBasemap)\r\n onChange(newBasemap)\r\n }\r\n\r\n const toggleOpen = () => {\r\n setIsOpen(true)\r\n }\r\n\r\n const toggleClosed = () => {\r\n setIsOpen(false)\r\n }\r\n\r\n // if there are only 2 options, render as a toggle\r\n if (styles.length === 2) {\r\n const nextBasemap = basemap === styles[0] ? styles[1] : styles[0]\r\n\r\n return (\r\n \r\n handleBasemapClick(nextBasemap)}\r\n />\r\n \r\n )\r\n }\r\n\r\n const nextBasemap = styles.filter(style => style !== basemap)[0]\r\n\r\n return (\r\n \r\n {isOpen ? (\r\n <>\r\n handleBasemapClick(nextBasemap)}\r\n />\r\n {styles\r\n .filter(style => style !== nextBasemap)\r\n .map(styleID => (\r\n handleBasemapClick(styleID)}\r\n />\r\n ))}\r\n \r\n ) : (\r\n \r\n )}\r\n \r\n )\r\n}\r\n\r\nStyleSelector.propTypes = {\r\n // list of mapbox style IDs - corresponding images must be loaded here\r\n styles: PropTypes.arrayOf(PropTypes.string).isRequired,\r\n onChange: PropTypes.func.isRequired,\r\n}\r\n\r\n// don't rerender based on container\r\nexport default memo(StyleSelector, () => true)\r\n","import React from 'react'\r\nimport PropTypes from 'prop-types'\r\n\r\nimport { Flex } from 'components/Grid'\r\nimport { ToggleButton } from 'components/Button'\r\n\r\nimport styled from 'util/style'\r\n\r\nconst Wrapper = styled(Flex).attrs({ alignItems: 'center', p: '0.5rem' })`\r\n position: absolute;\r\n top: 0;\r\n left: 10px;\r\n z-index: 1000;\r\n background: #fff;\r\n border-radius: 0 0 0.25rem 0.25rem;\r\n box-shadow: 1px 1px 8px #333;\r\n`\r\n\r\nconst TopBarToggle = styled(ToggleButton)`\r\n margin: 0 1rem;\r\n\r\n button {\r\n text-transform: lowercase;\r\n padding: 0.25rem 0.5rem;\r\n font-size: 0.9rem;\r\n }\r\n`\r\n\r\nconst LayerToggle = ({ value, options, onChange }) => (\r\n \r\n Show:\r\n \r\n \r\n)\r\n\r\nLayerToggle.propTypes = {\r\n value: PropTypes.string.isRequired,\r\n options: PropTypes.arrayOf(\r\n PropTypes.shape({\r\n value: PropTypes.string.isRequired,\r\n label: PropTypes.string.isRequired,\r\n })\r\n ).isRequired,\r\n onChange: PropTypes.func.isRequired,\r\n}\r\n\r\nexport default LayerToggle\r\n","import React from 'react'\r\nimport PropTypes from 'prop-types'\r\nimport { FaExternalLinkAlt } from 'react-icons/fa'\r\n\r\nimport { Flex } from 'components/Grid'\r\nimport styled from 'util/style'\r\n\r\nconst Wrapper = styled(Flex).attrs({\r\n alignItems: 'center',\r\n justifyContent: 'center',\r\n})`\r\n cursor: pointer;\r\n position: absolute;\r\n right: 8px;\r\n top: 110px;\r\n width: 34px;\r\n height: 34px;\r\n z-index: 999;\r\n background-color: #fff;\r\n border-radius: 5px;\r\n border: 2px solid rgb(216, 216, 216);\r\n`\r\n\r\nconst Icon = styled(FaExternalLinkAlt)`\r\n width: 1em;\r\n height: 1em;\r\n`\r\n\r\nconst FullExtentButton = ({ onClick }) => (\r\n \r\n \r\n \r\n)\r\n\r\nFullExtentButton.propTypes = {\r\n onClick: PropTypes.func.isRequired,\r\n}\r\n\r\nexport default FullExtentButton\r\n","import { createSteps } from 'util/map'\r\nimport { flatten } from 'util/data'\r\nimport { bioticInfo, twInfo, PNWBounds } from './constants'\r\nimport { siteMetadata } from '../gatsby-config'\r\n\r\nexport const transparentColor = 'rgba(0,0,0,0)'\r\nexport const boundaryColor = '#a18ac9'\r\nexport const highlightColor = '#ee7d14'\r\nexport const defaultRadius = 12\r\n\r\n/* --------- Vector tile source information --------- */\r\nexport const boundaryLayer = {\r\n tileURL:\r\n 'https://tiles.arcgis.com/tiles/kpMKjjLr8H1rZ4XO/arcgis/rest/services/PMEP_Estuary_Extent_Vector_Tiles_flat_20190517/VectorTileServer/tile/{z}/{y}/{x}.pbf',\r\n sourceLayer: 'West Coast USA Current and Historical Estuary Extent',\r\n idProperty: 'PMEP_EstuaryID',\r\n}\r\n\r\n// CMECS biotics vector tile source information\r\nexport const bioticLayer = {\r\n tileURL:\r\n 'https://tiles.arcgis.com/tiles/kpMKjjLr8H1rZ4XO/arcgis/rest/services/PMEP_Biotic_Component_VectorTilePackage_V1_2_dissolved/VectorTileServer/tile/{z}/{y}/{x}.pbf',\r\n sourceLayer: 'West Coast USA Estuarine Biotic Habitat',\r\n idProperty: 'CMECS_BC_Code',\r\n}\r\n\r\n// Tidal wetland loss and restoration source information\r\nexport const twLayer = {\r\n tileURL:\r\n 'https://honu.psmfc.org/server/rest/services/Hosted/PMEP_Tidal_Wetlands_Loss_Summary_V2/VectorTileServer/tile/{z}/{y}/{x}.pbf',\r\n sourceLayer: 'PMEP_Tidal_Wetlands_Loss_Summary_V2',\r\n idProperty: 'TWL_Type',\r\n}\r\n\r\n/* --------- Cluster information --------- */\r\nconst clusters = [\r\n {\r\n threshold: 10,\r\n label: '< 10 estuaries',\r\n color: '#74a9cf',\r\n borderColor: '#2b8cbe',\r\n radius: defaultRadius,\r\n },\r\n {\r\n threshold: 100,\r\n label: '10 - 100 estuaries',\r\n color: '#2b8cbe',\r\n borderColor: '#045a8d',\r\n radius: 20,\r\n },\r\n {\r\n threshold: Infinity,\r\n label: '> 100 estuaries',\r\n color: '#045a8d',\r\n borderColor: '#000',\r\n radius: 25,\r\n },\r\n]\r\nconst clusterRadii = createSteps(clusters, 'radius')\r\n\r\n// extract biotic code and color info into Mapbox style expression\r\n// so that we can style the layer based on code\r\n// structure is: [code, color, code2, color2, ...]\r\n// final entry must be the default color\r\nconst bioticStyle = flatten(\r\n Object.entries(bioticInfo).map(([key, { color }]) => [key, color])\r\n).concat(transparentColor)\r\n\r\nconst twStyle = flatten(\r\n Object.entries(twInfo).map(([key, { color }]) => [key, color])\r\n).concat(transparentColor)\r\n\r\n/**\r\n * Map configuration information used to construct map and populate layers\r\n */\r\nexport const config = {\r\n accessToken: siteMetadata.mapboxToken,\r\n bounds: PNWBounds,\r\n minZoom: 1.75,\r\n styles: ['light-v9', 'satellite-streets-v11', 'streets-v11'],\r\n padding: 0.1, // padding around bounds as a proportion\r\n}\r\n\r\nexport const sources = {\r\n boundaries: {\r\n type: 'vector',\r\n tiles: [boundaryLayer.tileURL],\r\n minzoom: 4,\r\n maxzoom: 15,\r\n tileSize: 512,\r\n },\r\n biotics: {\r\n type: 'vector',\r\n tiles: [bioticLayer.tileURL],\r\n minzoom: 5,\r\n maxzoom: 15,\r\n tileSize: 512,\r\n },\r\n tidalWetlands: {\r\n type: 'vector',\r\n tiles: [twLayer.tileURL],\r\n minzoom: 5,\r\n maxzoom: 15,\r\n tileSize: 512,\r\n },\r\n points: {\r\n type: 'geojson',\r\n data: {},\r\n cluster: true,\r\n clusterMaxZoom: 14,\r\n clusterRadius: 45,\r\n },\r\n}\r\n\r\nexport const layers = [\r\n {\r\n id: 'boundaries-fill',\r\n source: 'boundaries',\r\n 'source-layer': boundaryLayer.sourceLayer,\r\n minzoom: 4,\r\n maxzoom: 22,\r\n type: 'fill',\r\n paint: {\r\n 'fill-opacity': {\r\n stops: [[5, 1], [7, 0.5], [10, 0.1]],\r\n },\r\n 'fill-color': boundaryColor,\r\n },\r\n },\r\n\r\n {\r\n id: 'biotics-fill',\r\n source: 'biotics',\r\n 'source-layer': bioticLayer.sourceLayer,\r\n minzoom: 7.5,\r\n maxzoom: 22,\r\n type: 'fill',\r\n\r\n paint: {\r\n 'fill-opacity': {\r\n base: 1,\r\n stops: [[7.5, 0.1], [9, 0.5]],\r\n },\r\n 'fill-color': ['match', ['get', bioticLayer.idProperty], ...bioticStyle],\r\n },\r\n },\r\n {\r\n id: 'biotics-boundary',\r\n source: 'biotics',\r\n 'source-layer': bioticLayer.sourceLayer,\r\n minzoom: 7.5,\r\n maxzoom: 22,\r\n type: 'line',\r\n paint: {\r\n 'line-width': {\r\n base: 0.1,\r\n stops: [[5, 0.1], [8, 0.5], [10, 1]],\r\n },\r\n 'line-opacity': {\r\n stops: [[5, 0.1], [7, 0.5], [10, 1]],\r\n },\r\n 'line-color': '#AAA',\r\n },\r\n },\r\n {\r\n id: 'tw-fill',\r\n source: 'tidalWetlands',\r\n 'source-layer': twLayer.sourceLayer,\r\n minzoom: 7.5,\r\n maxzoom: 22,\r\n type: 'fill',\r\n filter: ['!=', ['get', twLayer.idProperty], 'N/A'],\r\n layout: {\r\n visibility: 'none',\r\n },\r\n paint: {\r\n 'fill-opacity': {\r\n base: 1,\r\n stops: [[7.5, 0.1], [9, 0.5]],\r\n },\r\n 'fill-color': ['match', ['get', twLayer.idProperty], ...twStyle],\r\n },\r\n },\r\n {\r\n id: 'boundaries-outline',\r\n source: 'boundaries',\r\n 'source-layer': boundaryLayer.sourceLayer,\r\n minzoom: 4,\r\n maxzoom: 22,\r\n type: 'line',\r\n paint: {\r\n 'line-width': {\r\n base: 0.1,\r\n stops: [[5, 0.1], [8, 0.5], [10, 1], [12, 1.5]],\r\n },\r\n 'line-opacity': {\r\n stops: [[5, 0.1], [7, 0.5], [10, 1]],\r\n },\r\n 'line-color': boundaryColor,\r\n },\r\n },\r\n {\r\n id: 'boundaries-outline-highlight',\r\n source: 'boundaries',\r\n 'source-layer': boundaryLayer.sourceLayer,\r\n minzoom: 4,\r\n maxzoom: 22,\r\n type: 'line',\r\n filter: ['==', ['get', boundaryLayer.idProperty], Infinity],\r\n paint: {\r\n 'line-width': {\r\n base: 1,\r\n stops: [[5, 1], [12, 3]],\r\n },\r\n 'line-opacity': {\r\n stops: [[5, 0.5], [8, 1]],\r\n },\r\n 'line-color': highlightColor,\r\n },\r\n },\r\n {\r\n id: 'clusters',\r\n type: 'circle',\r\n source: 'points',\r\n filter: ['has', 'point_count'], // point_count field added by mapbox GL\r\n paint: {\r\n 'circle-color': [\r\n 'step',\r\n ['get', 'point_count'],\r\n ...createSteps(clusters, 'color'),\r\n ],\r\n 'circle-stroke-color': [\r\n 'step',\r\n ['get', 'point_count'],\r\n ...createSteps(clusters, 'borderColor'),\r\n ],\r\n 'circle-stroke-width': 1,\r\n 'circle-radius': ['step', ['get', 'point_count'], ...clusterRadii],\r\n },\r\n },\r\n\r\n {\r\n id: 'points', // unclustered points\r\n type: 'circle',\r\n source: 'points',\r\n maxzoom: 15,\r\n filter: ['!', ['has', 'point_count']],\r\n paint: {\r\n 'circle-color': boundaryColor,\r\n 'circle-radius': {\r\n base: 12,\r\n stops: [[5, defaultRadius], [14, 10]],\r\n },\r\n 'circle-stroke-width': 1,\r\n 'circle-stroke-color': '#fff',\r\n },\r\n },\r\n\r\n {\r\n id: 'points-hover',\r\n type: 'circle',\r\n source: 'points',\r\n maxzoom: 15,\r\n filter: ['==', 'id', Infinity],\r\n paint: {\r\n 'circle-color': highlightColor,\r\n 'circle-stroke-color': highlightColor,\r\n 'circle-stroke-width': 4,\r\n // if a cluster, use cluster sizes above, else use the point size above\r\n 'circle-radius': [\r\n 'case',\r\n ['has', 'point_count'],\r\n ['step', ['get', 'point_count'], ...clusterRadii],\r\n defaultRadius,\r\n ],\r\n },\r\n },\r\n {\r\n id: 'clusters-label',\r\n type: 'symbol',\r\n source: 'points',\r\n filter: ['has', 'point_count'],\r\n layout: {\r\n 'text-field': '{point_count_abbreviated}',\r\n 'text-size': 12,\r\n 'text-font': ['Open Sans Bold', 'Arial Unicode MS Bold'],\r\n },\r\n paint: {\r\n 'text-color': '#FFFFFF',\r\n 'text-opacity': 1,\r\n 'text-halo-color': '#000',\r\n 'text-halo-blur': 1,\r\n 'text-halo-width': 0.5,\r\n },\r\n },\r\n]\r\n\r\nexport const legends = {\r\n clusters: {\r\n getLegend: features => {\r\n const clusterThresholds = clusters.map(({ threshold }) => threshold)\r\n\r\n // extract unique sizes and sort from largest to smallest\r\n const sizes = Array.from(\r\n new Set(\r\n features.map(({ properties: { point_count: count } }) => {\r\n // find the matching cluster threshold\r\n let i = 0\r\n for (; i < clusterThresholds.length; i += 1) {\r\n if (count < clusterThresholds[i]) break\r\n }\r\n return i\r\n })\r\n )\r\n )\r\n .sort()\r\n .reverse()\r\n\r\n return sizes.map(size => {\r\n const { label, color, borderColor, radius } = clusters[size]\r\n return {\r\n type: 'circle',\r\n radius, // scale down so that it fits in 20px container\r\n color,\r\n borderColor,\r\n borderWidth: 1,\r\n label,\r\n }\r\n })\r\n },\r\n },\r\n points: {\r\n getLegend: () => [\r\n {\r\n type: 'circle',\r\n radius: defaultRadius,\r\n label: 'Estuary',\r\n color: boundaryColor,\r\n borderColor: '#FFF',\r\n borderWidth: 1,\r\n },\r\n ],\r\n },\r\n 'boundaries-fill': {\r\n getLegend: () => [\r\n {\r\n type: 'fill',\r\n label: 'Estuary boundary',\r\n color: `${boundaryColor}55`, // make partly transparent\r\n borderColor: boundaryColor,\r\n borderWidth: 2,\r\n },\r\n ],\r\n },\r\n 'boundaries-outline-highlight': {\r\n getLegend: () => [\r\n {\r\n type: 'fill',\r\n label: 'Selected estuary',\r\n borderColor: highlightColor,\r\n borderWidth: 2,\r\n },\r\n ],\r\n },\r\n 'biotics-fill': {\r\n getLegend: features => {\r\n // extract unique biotic codes and sort in ascending order\r\n const codes = Array.from(\r\n new Set(\r\n features.map(({ properties }) => properties[bioticLayer.idProperty])\r\n )\r\n ).sort()\r\n\r\n return codes.map(code => {\r\n const { label, color } = bioticInfo[code]\r\n return {\r\n type: 'fill',\r\n label,\r\n color: `${color}99`,\r\n }\r\n })\r\n },\r\n },\r\n 'tw-fill': {\r\n getLegend: () =>\r\n Object.entries(twInfo)\r\n .sort(([, { label: left }], [, { label: right }]) =>\r\n left < right ? -1 : 1\r\n )\r\n .map(([key, { label, color }]) => ({\r\n type: 'fill',\r\n label: `Tidal wetlands ${label}`,\r\n color: `${color}99`, // add a bit of transparency to mute color\r\n })),\r\n },\r\n}\r\n","/* eslint-disable max-len, no-underscore-dangle */\r\nimport React, { useEffect, useRef, useState } from 'react'\r\nimport PropTypes from 'prop-types'\r\nimport { List, fromJS } from 'immutable'\r\nimport ImmutablePropTypes from 'react-immutable-proptypes'\r\nimport mapboxgl from 'mapbox-gl'\r\nimport 'mapbox-gl/dist/mapbox-gl.css'\r\n\r\nimport styled from 'util/style'\r\nimport { hasWindow } from 'util/dom'\r\nimport { indexBy } from 'util/data'\r\nimport { getCenterAndZoom, toGeoJSONPoints, groupByLayer } from 'util/map'\r\n\r\nimport Legend from './Legend'\r\nimport StyleSelector from './StyleSelector'\r\nimport LayerToggle from './LayerToggle'\r\nimport FullExtentButton from './FullExtentButton'\r\nimport {\r\n config,\r\n sources,\r\n layers,\r\n legends,\r\n boundaryLayer,\r\n twLayer,\r\n} from '../../../config/map'\r\nimport { bioticInfo, twInfo } from '../../../config/constants'\r\n\r\nconst Relative = styled.div`\r\n position: relative;\r\n flex: 1 0 auto;\r\n z-index: 1;\r\n`\r\n\r\nconst renderTooltipContent = (title, color, label) =>\r\n `\r\n ${title}
    \r\n
     
    \r\n
    ${label}
    \r\n `\r\n\r\nconst Map = ({\r\n data,\r\n selectedFeature,\r\n bounds,\r\n location,\r\n onSelectFeature,\r\n onBoundsChange,\r\n}) => {\r\n // if there is no window, we cannot render this component\r\n if (!hasWindow) {\r\n return null\r\n }\r\n\r\n const { accessToken, styles } = config\r\n\r\n const mapNode = useRef(null)\r\n const mapRef = useRef(null)\r\n const baseStyleRef = useRef(null)\r\n const indexRef = useRef(null)\r\n const fullDataCount = useRef(null) // set to full size of data array on first mount, this is a shortcut to know if data are filtered\r\n const selectedFeatureRef = useRef(selectedFeature)\r\n const locationMarkerRef = useRef(null)\r\n const [legendEntries, setLegendEntries] = useState([])\r\n const [activeLayer, setActiveLayer] = useState('biotics') // options are biotics and tw\r\n\r\n useEffect(() => {\r\n const { padding, bounds: initBounds } = config\r\n\r\n let { center, zoom } = config\r\n\r\n const targetBounds = bounds.isEmpty() ? initBounds : bounds.toJS()\r\n\r\n // If bounds are available, use these to establish center and zoom when map first loads\r\n if (targetBounds && targetBounds.length === 4) {\r\n const {\r\n current: { offsetWidth, offsetHeight },\r\n } = mapNode\r\n\r\n const { center: boundsCenter, zoom: boundsZoom } = getCenterAndZoom(\r\n targetBounds,\r\n offsetWidth,\r\n offsetHeight,\r\n padding\r\n )\r\n center = boundsCenter\r\n zoom = boundsZoom\r\n }\r\n\r\n mapboxgl.accessToken = accessToken\r\n\r\n const map = new mapboxgl.Map({\r\n container: mapNode.current,\r\n style: `mapbox://styles/mapbox/${styles[0]}`,\r\n center: center || [0, 0],\r\n zoom: zoom || 0,\r\n minZoom: config.minZoom || 0,\r\n })\r\n mapRef.current = map\r\n window.map = map\r\n\r\n map.addControl(new mapboxgl.NavigationControl(), 'top-right')\r\n\r\n // Construct GeoJSON points from data\r\n sources.points.data = data ? toGeoJSONPoints(data.toJS()) : []\r\n indexRef.current = data ? indexBy(data.toJS(), 'id') : null\r\n fullDataCount.current = data ? data.count() : 0\r\n\r\n map.on('load', () => {\r\n // snapshot existing map config\r\n baseStyleRef.current = fromJS(map.getStyle())\r\n window.baseStyle = baseStyleRef.current\r\n\r\n // add sources\r\n Object.entries(sources).forEach(([id, source]) => {\r\n map.addSource(id, source)\r\n })\r\n\r\n // add layers\r\n layers.forEach(layer => {\r\n map.addLayer(layer)\r\n })\r\n })\r\n\r\n map.on('click', e => {\r\n const [feature] = map.queryRenderedFeatures(e.point, {\r\n layers: ['points', 'boundaries-fill'],\r\n })\r\n\r\n if (!feature) return\r\n const {\r\n layer: { id: layerId },\r\n properties,\r\n } = feature\r\n\r\n if (layerId === 'points') {\r\n onSelectFeature(properties.id)\r\n } else {\r\n onSelectFeature(properties[boundaryLayer.idProperty])\r\n }\r\n })\r\n\r\n // clicking on clusters zooms in\r\n map.on('click', 'clusters', e => {\r\n const [feature] = map.queryRenderedFeatures(e.point, {\r\n layers: ['clusters'],\r\n })\r\n map\r\n .getSource('points')\r\n .getClusterExpansionZoom(\r\n feature.properties.cluster_id,\r\n (err, targetZoom) => {\r\n if (err) return\r\n\r\n map.easeTo({\r\n center: feature.geometry.coordinates,\r\n zoom: targetZoom + 1,\r\n })\r\n }\r\n )\r\n })\r\n\r\n // show tooltip for clusters\r\n const tooltip = new mapboxgl.Popup({\r\n closeButton: false,\r\n closeOnClick: false,\r\n anchor: 'left',\r\n offset: 20,\r\n })\r\n map.on('mouseenter', 'clusters', ({ features: [feature] }) => {\r\n map.getCanvas().style.cursor = 'pointer'\r\n\r\n const clusterId = feature.properties.cluster_id\r\n\r\n // highlight\r\n map.setFilter('points-hover', ['==', ['get', 'cluster_id'], clusterId])\r\n\r\n map\r\n .getSource('points')\r\n .getClusterLeaves(clusterId, Infinity, 0, (err, children) => {\r\n if (err) return\r\n\r\n let names = children\r\n .slice(0, 5)\r\n .map(({ properties: { name } }) => name)\r\n .join('
    ')\r\n if (children.length > 5) {\r\n names += `
    and ${children.length - 5} more...`\r\n }\r\n\r\n tooltip\r\n .setLngLat(feature.geometry.coordinates)\r\n .setHTML(names)\r\n .addTo(map)\r\n })\r\n })\r\n map.on('mouseleave', 'clusters', () => {\r\n map.getCanvas().style.cursor = ''\r\n map.setFilter('points-hover', ['==', 'id', Infinity])\r\n tooltip.remove()\r\n })\r\n\r\n // show tooltip for single points\r\n map.on('mouseenter', 'points', ({ features: [feature] }) => {\r\n map.getCanvas().style.cursor = 'pointer'\r\n\r\n map.setFilter('points-hover', ['==', 'id', feature.properties.id])\r\n\r\n tooltip\r\n .setLngLat(feature.geometry.coordinates)\r\n .setHTML(`${feature.properties.name}`)\r\n .addTo(map)\r\n })\r\n map.on('mouseleave', 'points', () => {\r\n map.getCanvas().style.cursor = ''\r\n map.setFilter('points-hover', ['==', 'id', Infinity])\r\n tooltip.remove()\r\n })\r\n\r\n // show tooltip for boundaries\r\n map.on('mousemove', 'boundaries-fill', ({ point, features: [feature] }) => {\r\n if (map.getZoom() < 10) return\r\n\r\n map.getCanvas().style.cursor = 'pointer'\r\n\r\n const {\r\n properties: { PMEP_EstuaryID },\r\n } = feature\r\n\r\n if (!indexRef.current[PMEP_EstuaryID]) {\r\n console.error('Could not fetch data for estuary', PMEP_EstuaryID)\r\n return\r\n }\r\n\r\n tooltip\r\n .setLngLat(map.unproject(point))\r\n .setHTML(`${indexRef.current[PMEP_EstuaryID].name}`)\r\n .addTo(map)\r\n })\r\n\r\n map.on('mouseleave', 'boundaries-fill', () => {\r\n map.getCanvas().style.cursor = ''\r\n tooltip.remove()\r\n })\r\n\r\n // setup tooltip for biotic data\r\n map.on('mousemove', 'biotics-fill', ({ point, features: [feature] }) => {\r\n if (map.getZoom() < 10) return\r\n\r\n map.getCanvas().style.cursor = 'pointer'\r\n\r\n const {\r\n properties: { CMECS_BC_Code, PMEP_EstuaryID },\r\n } = feature\r\n\r\n if (!CMECS_BC_Code) return\r\n\r\n if (!indexRef.current[PMEP_EstuaryID]) {\r\n console.error('Could not fetch data for estuary', PMEP_EstuaryID)\r\n return\r\n }\r\n\r\n const { color, label } = bioticInfo[CMECS_BC_Code]\r\n\r\n tooltip\r\n .setLngLat(map.unproject(point))\r\n .setHTML(\r\n renderTooltipContent(\r\n indexRef.current[PMEP_EstuaryID].name,\r\n color,\r\n label\r\n )\r\n )\r\n .addTo(map)\r\n })\r\n\r\n map.on('mouseleave', 'biotics-fill', () => {\r\n map.getCanvas().style.cursor = ''\r\n tooltip.remove()\r\n })\r\n\r\n // setup tooltip for tidal wetland loss data\r\n map.on('mousemove', 'tw-fill', ({ point, features: [feature] }) => {\r\n map.getCanvas().style.cursor = 'pointer'\r\n\r\n const {\r\n properties: { TWL_Type, PMEP_EstuaryID },\r\n } = feature\r\n\r\n if (!indexRef.current[PMEP_EstuaryID]) {\r\n console.error('Could not fetch data for estuary', PMEP_EstuaryID)\r\n return\r\n }\r\n\r\n tooltip\r\n .setLngLat(map.unproject(point))\r\n .setHTML(\r\n renderTooltipContent(\r\n indexRef.current[PMEP_EstuaryID].name,\r\n twInfo[TWL_Type].color,\r\n `Tidal wetlands ${TWL_Type}`\r\n )\r\n )\r\n .addTo(map)\r\n })\r\n\r\n map.on('mouseleave', 'tw-fill', () => {\r\n map.getCanvas().style.cursor = ''\r\n tooltip.remove()\r\n })\r\n\r\n map.on('moveend', () => {\r\n const [lowerLeft, upperRight] = map.getBounds().toArray()\r\n onBoundsChange(lowerLeft.concat(upperRight))\r\n })\r\n\r\n map.on('idle', () => {\r\n // update legend after drawing layers\r\n setLegendEntries(getLegendEntries())\r\n })\r\n\r\n return () => {\r\n removeLocationMarker()\r\n map.remove()\r\n }\r\n }, [])\r\n\r\n // Update map when the filtered data change\r\n // also note that this fires when the map first mounts\r\n useEffect(() => {\r\n const { current: map } = mapRef\r\n if (!(map && map.isStyleLoaded())) return\r\n\r\n const records = data.toJS()\r\n\r\n // update clusters / points\r\n // note: we have to update the data to force rebuilding of clusters\r\n const geoJSON = data ? toGeoJSONPoints(records) : []\r\n map.getSource('points').setData(geoJSON)\r\n\r\n // update map layers based on state of filters\r\n // note: TWL is a special case because we need to filter out N/A as well\r\n const filterLayers = [\r\n 'boundaries-fill',\r\n 'boundaries-outline',\r\n 'biotics-fill',\r\n 'biotics-boundary',\r\n ]\r\n\r\n if (records.length < fullDataCount.current) {\r\n const ids = records.map(({ id }) => id)\r\n const filterExpr = ['in', ['get', 'PMEP_EstuaryID'], ['literal', ids]]\r\n\r\n filterLayers.forEach(id => {\r\n map.setFilter(id, filterExpr)\r\n })\r\n\r\n map.setFilter('tw-fill', [\r\n 'all',\r\n ['!=', ['get', twLayer.idProperty], 'N/A'],\r\n filterExpr,\r\n ])\r\n } else {\r\n // reset filters\r\n filterLayers.forEach(id => {\r\n map.setFilter(id, null)\r\n })\r\n\r\n map.setFilter('tw-fill', ['!=', ['get', twLayer.idProperty], 'N/A'])\r\n }\r\n }, [data])\r\n\r\n // Update selected point / polygon\r\n useEffect(() => {\r\n selectedFeatureRef.current = selectedFeature\r\n\r\n const { current: map } = mapRef\r\n if (!(map && map.isStyleLoaded())) return\r\n\r\n if (selectedFeature === null) {\r\n removeLocationMarker()\r\n map.setFilter('points', ['!', ['has', 'point_count']])\r\n } else {\r\n if (!indexRef.current[selectedFeature]) return\r\n\r\n const { lon, lat } = indexRef.current[selectedFeature]\r\n\r\n if (locationMarkerRef.current === null) {\r\n locationMarkerRef.current = new mapboxgl.Marker({\r\n color: '#ee7d14'\r\n })\r\n .setLngLat([lon, lat])\r\n .addTo(map)\r\n } else {\r\n locationMarkerRef.current.setLngLat([lon, lat])\r\n }\r\n\r\n map.setFilter('points', ['all', ['!', ['has', 'point_count']], ['!=', ['get', 'id'], selectedFeature]])\r\n }\r\n\r\n map.setFilter('boundaries-outline-highlight', [\r\n '==',\r\n ['get', boundaryLayer.idProperty],\r\n selectedFeature || Infinity,\r\n ])\r\n }, [selectedFeature])\r\n\r\n // Update bounds to match incoming bounds\r\n useEffect(() => {\r\n if (!bounds.isEmpty()) {\r\n const { current: map } = mapRef\r\n\r\n if (!map) return\r\n\r\n map.fitBounds(bounds.toJS(), { padding: 20, maxZoom: 14, duration: 2000 })\r\n }\r\n }, [bounds])\r\n\r\n useEffect(() => {\r\n if (!location) return\r\n const { current: map } = mapRef\r\n\r\n if (!map) return\r\n\r\n map.panTo(location)\r\n\r\n }, [location])\r\n\r\n // memoize this?\r\n const getLegendEntries = () => {\r\n const { current: map } = mapRef\r\n if (!(map && map.isStyleLoaded())) return []\r\n\r\n const queryLayers = [\r\n 'biotics-fill',\r\n 'tw-fill',\r\n 'boundaries-fill',\r\n 'boundaries-outline-highlight',\r\n 'clusters',\r\n 'points',\r\n ]\r\n\r\n // Create an index that preserves the above order for sorting\r\n const layerIndex = { ...queryLayers }\r\n\r\n // Group layers with visible features\r\n const visibleFeatures = map.queryRenderedFeatures({ layers: queryLayers })\r\n const grouped = groupByLayer(visibleFeatures)\r\n\r\n // only show point or boundary for estuaries when in view, not both\r\n // if fill is visible, show that\r\n if (grouped.points && grouped['boundaries-fill']) {\r\n delete grouped.points\r\n }\r\n\r\n let entries = []\r\n Object.entries(grouped)\r\n .sort(([leftLayer], [rightLayer]) =>\r\n layerIndex[leftLayer] > layerIndex[rightLayer] ? -1 : 1\r\n )\r\n .forEach(([layer, features]) => {\r\n if (legends[layer]) {\r\n entries = entries.concat(legends[layer].getLegend(features))\r\n }\r\n })\r\n\r\n return entries\r\n }\r\n\r\n const handleLayerToggle = newLayer => {\r\n const { current: map } = mapRef\r\n\r\n if (!(map && map.isStyleLoaded)) return\r\n\r\n setActiveLayer(newLayer)\r\n\r\n const isBiotics = newLayer === 'biotics'\r\n map.setLayoutProperty(\r\n 'biotics-fill',\r\n 'visibility',\r\n isBiotics ? 'visible' : 'none'\r\n )\r\n map.setLayoutProperty(\r\n 'tw-fill',\r\n 'visibility',\r\n isBiotics ? 'none' : 'visible'\r\n )\r\n }\r\n\r\n const handleBasemapChange = styleID => {\r\n const { current: map } = mapRef\r\n const { current: baseStyle } = baseStyleRef\r\n\r\n const snapshot = fromJS(map.getStyle())\r\n const baseSources = baseStyle.get('sources')\r\n const baseLayers = baseStyle.get('layers')\r\n\r\n // diff the sources and layers to find those added by the user\r\n const userSources = snapshot\r\n .get('sources')\r\n .filter((_, key) => !baseSources.has(key))\r\n const userLayers = snapshot\r\n .get('layers')\r\n .filter(layer => !baseLayers.includes(layer))\r\n\r\n map.setStyle(`mapbox://styles/mapbox/${styleID}`)\r\n\r\n map.once('style.load', () => {\r\n // after new style has loaded\r\n // save it so that we can diff with it on next change\r\n // and re-add the sources / layers back on it\r\n\r\n // save base for new style\r\n baseStyleRef.current = fromJS(map.getStyle())\r\n\r\n userSources.forEach((source, id) => {\r\n map.addSource(id, source.toJS())\r\n })\r\n\r\n userLayers.forEach(layer => {\r\n map.addLayer(layer.toJS())\r\n })\r\n })\r\n }\r\n\r\n const goToFullExtent = () => {\r\n const { current: map } = mapRef\r\n\r\n if (!(map && map.isStyleLoaded)) return\r\n\r\n map.fitBounds(config.bounds, { padding: 20, duration: 1000 })\r\n }\r\n\r\n const removeLocationMarker = () => {\r\n if (locationMarkerRef.current !== null) {\r\n locationMarkerRef.current.remove()\r\n locationMarkerRef.current = null\r\n }\r\n }\r\n\r\n\r\n return (\r\n \r\n
    \r\n\r\n \r\n {mapRef.current && mapRef.current.isStyleLoaded && (\r\n <>\r\n \r\n \r\n \r\n \r\n )}\r\n \r\n )\r\n}\r\n\r\nMap.propTypes = {\r\n data: ImmutablePropTypes.listOf(\r\n ImmutablePropTypes.mapContains({\r\n id: PropTypes.number.isRequired,\r\n lat: PropTypes.number.isRequired,\r\n lon: PropTypes.number.isRequired,\r\n })\r\n ).isRequired,\r\n bounds: ImmutablePropTypes.listOf(PropTypes.number),\r\n location: PropTypes.arrayOf(PropTypes.number),\r\n selectedFeature: PropTypes.number,\r\n onSelectFeature: PropTypes.func,\r\n onBoundsChange: PropTypes.func,\r\n}\r\n\r\nMap.defaultProps = {\r\n bounds: List(),\r\n selectedFeature: null,\r\n onSelectFeature: () => {},\r\n onBoundsChange: () => {},\r\n}\r\n\r\nexport default Map\r\n","/** A wrapper for the map to inject context from crossfilter so that the map doesn't need to know anything about crossfilter */\r\n\r\nimport React, { useContext } from 'react'\r\nimport PropTypes from 'prop-types'\r\n\r\nimport Map from 'components/Map'\r\nimport { SET_FILTER } from './Crossfilter'\r\nimport { Context } from './Context'\r\n\r\nconst FilteredMap = ({ onBoundsChange, ...props }) => {\r\n const { state, dispatch } = useContext(Context)\r\n\r\n const handleBoundsChange = bounds => {\r\n // TODO: persist bounds and convert to immutable throughout stack\r\n dispatch({\r\n type: SET_FILTER,\r\n payload: {\r\n field: 'bounds',\r\n filterValue: bounds,\r\n },\r\n })\r\n onBoundsChange(bounds)\r\n }\r\n\r\n return (\r\n \r\n )\r\n}\r\n\r\nFilteredMap.propTypes = {\r\n onBoundsChange: PropTypes.func,\r\n}\r\n\r\nFilteredMap.defaultProps = {\r\n onBoundsChange: () => {},\r\n}\r\n\r\nexport default FilteredMap\r\n","module.exports = __webpack_public_path__ + \"static/2098-2eccf6cf632faf4278233a5f67c13db1.jpg\";","module.exports = __webpack_public_path__ + \"static/3093-306046ed33157ca03000dc529412fe0f.jpg\";","module.exports = __webpack_public_path__ + \"static/4047-90d06c444ce5d067175fba188f1c42ac.jpg\";","module.exports = __webpack_public_path__ + \"static/1003-65711dc1e48c35ce56be4e43919e658b.jpg\";","import React from 'react'\r\nimport PropTypes from 'prop-types'\r\nimport { Text } from 'rebass'\r\n\r\nimport { Flex } from 'components/Grid'\r\nimport FaIcon from 'components/elements/FaIcon'\r\nimport styled, { themeGet } from 'util/style'\r\n\r\nconst Wrapper = styled(Flex).attrs({\r\n alignItems: 'center',\r\n flexWrap: 'nowrap',\r\n})`\r\n line-height: 1;\r\n padding: 1rem 1rem 0.25rem;\r\n`\r\n\r\nconst Icon = styled(FaIcon).attrs({})`\r\n margin-right: 0.25em;\r\n color: ${themeGet('colors.grey.900')};\r\n opacity: 0.6;\r\n`\r\n\r\nconst Title = styled(Text).attrs({\r\n fontSize: ['1.5rem', '1.75rem'],\r\n as: 'h2',\r\n})`\r\n margin: 0;\r\n font-weight: normal;\r\n color: ${themeGet('colors.grey.900')};\r\n`\r\n\r\nconst Header = ({ icon, title }) => (\r\n \r\n \r\n \r\n \r\n {title}\r\n \r\n)\r\n\r\nHeader.propTypes = {\r\n icon: PropTypes.string.isRequired,\r\n title: PropTypes.string.isRequired,\r\n}\r\n\r\nexport default Header\r\n","import React from 'react'\r\nimport PropTypes from 'prop-types'\r\n\r\nimport { Box, Flex } from 'components/Grid'\r\nimport HelpText from 'components/elements/HelpText'\r\nimport styled, { themeGet } from 'util/style'\r\nimport Header from './Header'\r\n\r\nexport { Header as SidebarHeader }\r\n\r\nconst Wrapper = styled(Box).attrs({\r\n width: ['100%', '350px', '470px'],\r\n flex: '0 0 auto',\r\n})`\r\n border-right: 1px solid ${themeGet('colors.grey.800')};\r\n height: 100%;\r\n`\r\n\r\nconst InnerWrapper = styled(Flex).attrs({\r\n flexDirection: 'column',\r\n flex: '1 1 auto',\r\n})`\r\n overflow-x: hidden;\r\n overflow-y: ${({ allowScroll }) => (allowScroll ? 'auto' : 'hidden')};\r\n height: 100%;\r\n`\r\n\r\nconst Sidebar = ({ children, allowScroll }) => (\r\n \r\n {children}\r\n \r\n)\r\n\r\nSidebar.propTypes = {\r\n children: PropTypes.node.isRequired,\r\n allowScroll: PropTypes.bool,\r\n}\r\n\r\nSidebar.defaultProps = {\r\n allowScroll: true,\r\n}\r\n\r\nexport default Sidebar\r\n","module.exports = __webpack_public_path__ + \"static/1062-74cccf5a1c26d6eed45c457b9f4dd036.jpg\";","module.exports = __webpack_public_path__ + \"static/2103-542a3e1796d5d7caee890d29a62de6e7.jpg\";","module.exports = __webpack_public_path__ + \"static/3047-077f620ce44d77a39fe4326f6e0568c6.jpg\";","module.exports = __webpack_public_path__ + \"static/1021-ac8efff9054ed8b9879f5417101ba4dd.jpg\";","module.exports = __webpack_public_path__ + \"static/2034-795fdc45b91f3b9878f17ea5a3ad4610.jpg\";","module.exports = __webpack_public_path__ + \"static/2040-7ba8a96ea755ac4a2b1b0c821ef3e10e.jpg\";","module.exports = __webpack_public_path__ + \"static/2007-cfddac1f165ad66f1e1f631b32a140e0.jpg\";","module.exports = __webpack_public_path__ + \"static/1072-60c24db4d324ff9cdfadc989afe4cd20.jpg\";","var $ = require('../internals/export');\n\nvar $hypot = Math.hypot;\nvar abs = Math.abs;\nvar sqrt = Math.sqrt;\n\n// Chrome 77 bug\n// https://bugs.chromium.org/p/v8/issues/detail?id=9546\nvar BUGGY = !!$hypot && $hypot(Infinity, NaN) !== Infinity;\n\n// `Math.hypot` method\n// https://tc39.github.io/ecma262/#sec-math.hypot\n$({ target: 'Math', stat: true, forced: BUGGY }, {\n hypot: function hypot(value1, value2) { // eslint-disable-line no-unused-vars\n var sum = 0;\n var i = 0;\n var aLen = arguments.length;\n var larg = 0;\n var arg, div;\n while (i < aLen) {\n arg = abs(arguments[i++]);\n if (larg < arg) {\n div = larg / arg;\n sum = sum * div * div + 1;\n larg = arg;\n } else if (arg > 0) {\n div = arg / larg;\n sum += div * div;\n } else sum += arg;\n }\n return larg === Infinity ? Infinity : larg * sqrt(sum);\n }\n});\n","module.exports = __webpack_public_path__ + \"static/1098-fa0723e5f0421b7516e1d5324e96c326.jpg\";","module.exports = __webpack_public_path__ + \"static/2057-17b4f0223f3255bc41943c0a0bc4f033.jpg\";","module.exports = __webpack_public_path__ + \"static/3014-5e50c92a85a1cd9c785205c4a1cfdd58.jpg\";","module.exports = __webpack_public_path__ + \"static/4024-50075d25772e7164a10afa80f3cc6b77.jpg\";","module.exports = __webpack_public_path__ + \"static/3028-e6c4b166f620df5a684ea99b3d900e19.jpg\";","module.exports = __webpack_public_path__ + \"static/2099-f57549b58c7681b0839c385bedfc08ac.jpg\";","module.exports = __webpack_public_path__ + \"static/1120-2ee7247a36c0cab6b9a4d372d6831af9.jpg\";","module.exports = __webpack_public_path__ + \"static/1048-f4c45ef6293e741666aed976a63793a0.jpg\";","module.exports = __webpack_public_path__ + \"static/1069-54a3a22a5c717d81882b03a9db0d391e.jpg\";","module.exports = __webpack_public_path__ + \"static/4060-c10b18f0be655696def0ee5ed23edc1b.jpg\";","module.exports = __webpack_public_path__ + \"static/4053-47f73f25035e1fa7bebe34052ac392cc.jpg\";","module.exports = __webpack_public_path__ + \"static/3000-abcc951c26fa3ff606ce513f4c211e1e.jpg\";","// Classify a value into an index depending on what range it falls into\r\n// ranges: [[rangeMin, rangeMax], ..., ]\r\nexport const classify = (value, ranges) => {\r\n let i = 0\r\n for (i; i < ranges.length; i += 1) {\r\n if (value >= ranges[i][0] && value < ranges[i][1]) {\r\n break\r\n }\r\n }\r\n return i\r\n}\r\n\r\n/**\r\n * Converts an array of ['key:value', ...] to {key: value, }\r\n * @param {Array of strings} entries - array of ['key:value', ...]\r\n * @param {function} modifier - modifier function called for each value (optional)\r\n */\r\nexport const packedToObject = (entries, modifier) =>\r\n entries.reduce((result, part) => {\r\n const [key, value] = part.split(':')\r\n /* eslint-disable no-param-reassign */\r\n result[key] = modifier ? modifier(value) : value\r\n return result\r\n }, {})\r\n\r\n/** Flatten an array of arrays into a single array\r\n * @param {Array of Arrays} - arrays\r\n */\r\nexport const flatten = arrays =>\r\n arrays.reduce((result, entry) => result.concat(...entry), [])\r\n\r\n/**\r\n * Index an array on index field, and return an object with\r\n * values of index field as keys.\r\n * @param {Array} data\r\n * @param {String} indexField\r\n * @param {function} getValue - if present, values are passed into\r\n * this function for further processing to extract values of interest\r\n */\r\nexport const indexBy = (data, indexField, getValue = null) =>\r\n data.reduce(\r\n (prev, { [indexField]: id, ...rest }) =>\r\n Object.assign(prev, { [id]: getValue ? getValue(rest) : rest }),\r\n {}\r\n )\r\n","module.exports = __webpack_public_path__ + \"static/3042-25fc78753861e627674c704ef584333a.jpg\";","module.exports = __webpack_public_path__ + \"static/1002-157a854256090807ec513c58943cfe3d.jpg\";","module.exports = __webpack_public_path__ + \"static/2062-ce89df1ce8c7d22a98c8aa5d6a762b32.jpg\";","module.exports = __webpack_public_path__ + \"static/3016-8004f883c11804b523383f49edc015b9.jpg\";","module.exports = __webpack_public_path__ + \"static/2056-9b775b064901cc2cc715c5cafca0121b.jpg\";","module.exports = __webpack_public_path__ + \"static/3078-92f97be39f34a7458901de30d99962f3.jpg\";","module.exports = __webpack_public_path__ + \"static/4030-d91d70af3c06316a2a1cb28c643a1308.jpg\";","module.exports = __webpack_public_path__ + \"static/1012-b1bd3387c167ec7ec389b9680e100efb.jpg\";","module.exports = __webpack_public_path__ + \"static/2071-7ea8449e3f667f6aba861a1570246f8a.jpg\";","module.exports = __webpack_public_path__ + \"static/2072-b76bac8339953dbbe1072f21cee72219.jpg\";","module.exports = __webpack_public_path__ + \"static/2046-fc2e441422457927ba5eb1791ea0e974.jpg\";","module.exports = __webpack_public_path__ + \"static/3003-93a88edaee610e014eaae5cb5aa94389.jpg\";","module.exports = __webpack_public_path__ + \"static/1134-a8d7b4daf44a88ad9f0f9a4b6288c46b.jpg\";","module.exports = __webpack_public_path__ + \"static/4010-6e63f1d5b8029b9a8de88bbc2ed9ecde.jpg\";","module.exports = __webpack_public_path__ + \"static/1139-85c0b14ccf593969181cbf3cd9b7eac1.jpg\";","module.exports = __webpack_public_path__ + \"static/4017-b4b928440dba4d06f4e8289898e043ad.jpg\";","module.exports = __webpack_public_path__ + \"static/1032-9d68352923ddef2d328393d573d1adc9.jpg\";","module.exports = __webpack_public_path__ + \"static/1095-ebff1f510687a38ef6e1ca806b6d4168.jpg\";","module.exports = __webpack_public_path__ + \"static/1044-4acb267123711094688689bab3d6429c.jpg\";","module.exports = __webpack_public_path__ + \"static/2003-62158bea0a8da73673581f72f654dba9.jpg\";","module.exports = __webpack_public_path__ + \"static/4031-3a45ba8c8b9c42e5330e71c0b187e92e.jpg\";","module.exports = __webpack_public_path__ + \"static/3062-3fc0b45d9be547286d35422a1b6ec638.jpg\";","module.exports = __webpack_public_path__ + \"static/4001-8b60129f5d17dc15ab7a4941635cd1d3.jpg\";","module.exports = __webpack_public_path__ + \"static/3091-31f383eaad045359697e7283c489988d.jpg\";","module.exports = __webpack_public_path__ + \"static/4052-9c8be564d3a6d23242318bb5f290378d.jpg\";","module.exports = __webpack_public_path__ + \"static/riverine-984379f55561054be3fde94b5e2fc4d2.svg\";","module.exports = __webpack_public_path__ + \"static/1092-8f2573a544d7059f4b1514284d4f28e8.jpg\";","module.exports = __webpack_public_path__ + \"static/1146-22e012e6375f19397e524166a282d062.jpg\";","module.exports = __webpack_public_path__ + \"static/2045-1776c0b48e17718aebd8500bff72080a.jpg\";","module.exports = __webpack_public_path__ + \"static/3031-cf35899e5b53c379a89bb1a9ba9b436f.jpg\";","module.exports = __webpack_public_path__ + \"static/2055-492a5f3b2a68404bed625f11599e7e6c.jpg\";","var SphericalMercator = require('@mapbox/sphericalmercator'); // The SphericalMercator library only accepts a variable\n// tileSize on instantiation, which it uses to pre-cache\n// calculations by zoom level.\n// We cache each instantiation, keyed by tile size, to avoid\n// repeating this cost when working with a single tile size\n// (assumed to be the most-common use case).\n\n\nvar smCache = {};\nmodule.exports.viewport = viewport;\nmodule.exports.bounds = bounds;\n\nfunction fetchMerc(tileSize) {\n tileSize = tileSize || 256;\n\n if (!smCache[tileSize]) {\n smCache[tileSize] = new SphericalMercator({\n size: tileSize\n });\n }\n\n return smCache[tileSize];\n}\n\nfunction getAdjusted(base, ratios, allowFloat) {\n var adjusted = Math.min(base - Math.log(ratios[0]) / Math.log(2), base - Math.log(ratios[1]) / Math.log(2));\n return allowFloat ? adjusted : Math.floor(adjusted);\n}\n\nfunction viewport(bounds, dimensions, minzoom, maxzoom, tileSize, allowFloat) {\n minzoom = minzoom === undefined ? 0 : minzoom;\n maxzoom = maxzoom === undefined ? 20 : maxzoom;\n var merc = fetchMerc(tileSize);\n var base = maxzoom;\n var bl = merc.px([bounds[0], bounds[1]], base);\n var tr = merc.px([bounds[2], bounds[3]], base);\n var width = tr[0] - bl[0];\n var height = bl[1] - tr[1];\n var centerPixelX = bl[0] + width / 2;\n var centerPixelY = tr[1] + height / 2;\n var ratios = [width / dimensions[0], height / dimensions[1]];\n var adjusted = getAdjusted(base, ratios, allowFloat);\n var center = merc.ll([centerPixelX, centerPixelY], base);\n var zoom = Math.max(minzoom, Math.min(maxzoom, adjusted));\n return {\n center: center,\n zoom: zoom\n };\n}\n\nfunction bounds(viewport, zoom, dimensions, tileSize) {\n if (viewport.lon !== undefined) {\n viewport = [viewport.lon, viewport.lat];\n }\n\n var merc = fetchMerc(tileSize);\n var px = merc.px(viewport, zoom);\n var tl = merc.ll([px[0] - dimensions[0] / 2, px[1] - dimensions[1] / 2], zoom);\n var br = merc.ll([px[0] + dimensions[0] / 2, px[1] + dimensions[1] / 2], zoom);\n return [tl[0], br[1], br[0], tl[1]];\n}","var wellKnownSymbol = require('../internals/well-known-symbol');\nvar create = require('../internals/object-create');\nvar definePropertyModule = require('../internals/object-define-property');\n\nvar UNSCOPABLES = wellKnownSymbol('unscopables');\nvar ArrayPrototype = Array.prototype;\n\n// Array.prototype[@@unscopables]\n// https://tc39.github.io/ecma262/#sec-array.prototype-@@unscopables\nif (ArrayPrototype[UNSCOPABLES] == undefined) {\n definePropertyModule.f(ArrayPrototype, UNSCOPABLES, {\n configurable: true,\n value: create(null)\n });\n}\n\n// add a key to Array.prototype[@@unscopables]\nmodule.exports = function (key) {\n ArrayPrototype[UNSCOPABLES][key] = true;\n};\n","module.exports = __webpack_public_path__ + \"static/1101-29f52e25eb398c7eea31b20a80de4c10.jpg\";","module.exports = __webpack_public_path__ + \"static/1161-bc91c29172f583bc1298274a9e1e3c9e.jpg\";","module.exports = __webpack_public_path__ + \"static/4043-607c690ffa744ae953e4bfc5ec4de11e.jpg\";","module.exports = __webpack_public_path__ + \"static/1102-6679668890cd7e48336e2a8da9f88a31.jpg\";","module.exports = __webpack_public_path__ + \"static/2085-d6059d513148436ca0f9d1418010855d.jpg\";","module.exports = __webpack_public_path__ + \"static/1127-74af4cdf4c56ff8286c22bf118bb1bcc.jpg\";","import { theme } from 'util/style'\r\n\r\nexport const PNWBounds = [-124.7, 32.5, -117.1, 49]\r\n\r\nexport const states = ['WA', 'OR', 'CA']\r\n\r\nexport const stateNames = {\r\n WA: 'Washington',\r\n OR: 'Oregon',\r\n ORWA: 'Oregon / Washington', // these are split for filtering\r\n CA: 'California',\r\n}\r\n\r\nexport const regions = [\r\n 'Salish Sea',\r\n 'Washington, Oregon, Northern California Coast',\r\n 'Central California',\r\n 'Southern California Bight',\r\n]\r\n\r\nexport const estuaryTypes = {\r\n 0: {\r\n label: 'Embayment/Bay',\r\n snippet:\r\n 'This type of estuary is primarily composed of a water body with some level of enclosure by land at different spatial scales...',\r\n description:\r\n 'This type of estuary is primarily composed of a water body with some level of enclosure by land at different spatial scales. These can be wide, curving indentations in the coast, arms of the sea, or bodies of water almost surrounded by land. These features can be small—with considerable freshwater and terrestrial influence—or large and generally oceanic in character.',\r\n },\r\n 1: {\r\n label: 'Major River Delta',\r\n snippet:\r\n 'This type of estuary is primarily composed of the nearly flat, alluvial tract of land at the mouth of a river...',\r\n description:\r\n 'This type of estuary is primarily composed of the nearly flat, alluvial tract of land at the mouth of a river, which commonly forms a triangular or fan-shaped plain. It is crossed by many distributaries, and the delta is the result of sediment accumulation from the river. Deltas are distinguished from alluvial fans by their flatter slope. All deltas are dynamic areas of mixed-water flow and salinity.',\r\n },\r\n 2: {\r\n label: 'Riverine Estuary',\r\n snippet: 'This type of estuary tends to be linear and seasonally turbid...',\r\n description:\r\n 'This type of estuary tends to be linear and seasonally turbid (especially in upper reaches), and may have higher current speeds. These estuaries are sedimentary and depositional, so they may be associated with a delta, bar, barrier island, and other depositional features. These estuaries also tend to be highly flushed (with a wide and variable salinity range) and seasonally stratified. ',\r\n },\r\n 3: {\r\n label: 'Lagoonal Estuary',\r\n snippet:\r\n 'This type of estuary tends to be shallow, highly enclosed, and have reduced exchange with the ocean...',\r\n description:\r\n 'This type of estuary tends to be shallow, highly enclosed, and have reduced exchange with the ocean. They often experience high evaporation, and they tend to be quiescent in terms of wind, current, and wave energy. The flushing times tend to be long relative to riverine estuaries and embayments because of the restricted exchange with the marine-end member and the reduced river input. Exchange with surrounding landscapes tends to be enhanced and more highly coupled than in other types of estuaries.',\r\n },\r\n}\r\n\r\nexport const species = [\r\n 'BatRay',\r\n 'BayShrimp',\r\n 'BrownRockfish',\r\n 'CaliforniaHalibut',\r\n 'ChinookSalmon',\r\n 'CohoSalmon',\r\n 'DungenessCrab',\r\n 'EnglishSole',\r\n 'GreenSturgeon',\r\n 'LeopardShark',\r\n 'PacificHerring',\r\n 'ShinerPerch',\r\n 'StaghornSculpin',\r\n 'StarryFlounder',\r\n 'Steelhead',\r\n]\r\n\r\nexport const sppEOLIDs = {\r\n BatRay: '46561010',\r\n BayShrimp: '1021223',\r\n BrownRockfish: '46568119',\r\n CaliforniaHalibut: '46570506',\r\n ChinookSalmon: '46563139',\r\n CohoSalmon: '46563137',\r\n DungenessCrab: '46505946',\r\n EnglishSole: '46570134',\r\n GreenSturgeon: '46561178',\r\n LeopardShark: '46560018',\r\n PacificHerring: '1156440',\r\n ShinerPerch: '46572845',\r\n StaghornSculpin: '46569026',\r\n StarryFlounder: '46570116',\r\n Steelhead: '46563138',\r\n}\r\n\r\nexport const lifeStageLabels = {\r\n P: 'present',\r\n JP: 'juvenile present',\r\n}\r\n\r\n// used to find the bin for which twl < bin\r\n// 999 indicates not assessed\r\nexport const twlBins = [10, 50, 90, 101, 1000]\r\nexport const twlBinLabels = [\r\n '< 10%',\r\n '10 - 49%',\r\n '50 - 89%',\r\n '≥ 90%',\r\n 'Not assessed',\r\n]\r\n\r\nexport const twrLabels = [\r\n 'Some restoration',\r\n 'No known restoration',\r\n 'Not assessed',\r\n]\r\n\r\nexport const nfhpCodes = [0, 1, 2, 3, 4, 5]\r\nexport const nfhpLabels = [\r\n 'Very High',\r\n 'High',\r\n 'Moderate',\r\n 'Low',\r\n 'Very Low',\r\n // these get screened out based on NFHPJoin==999\r\n 'Not assessed', // includes nodata, not scored by NFHAP, etc\r\n]\r\nexport const nfhpColors = {\r\n 5: theme.colors.grey[200],\r\n 4: theme.colors.primary[500],\r\n 3: theme.colors.primary[100],\r\n 2: theme.colors.secondary[300],\r\n 1: theme.colors.secondary[600],\r\n 0: theme.colors.secondary[900],\r\n}\r\n\r\n// Size classes adapted from page 127 in SoK, converted to acres\r\nexport const sizeClasses = [[0, 25], [25, 250], [250, 2500], [2500, Infinity]]\r\nexport const sizeClassLabels = [\r\n '0 - 25 acres',\r\n '25 - 250 acres',\r\n '250 acres - 2,500 acres',\r\n '> 2,500 acres',\r\n]\r\n\r\nexport const sppCountClasses = [10, 6, 1, 0, -1] // classifying is handled in filters.js\r\nexport const sppCountClassLabels = [\r\n '10-15 species present',\r\n '5-9 species present',\r\n '1-5 species present',\r\n 'no species found',\r\n 'not inventoried for species',\r\n]\r\n\r\nexport const bioticTypes = [\r\n '2',\r\n '2.2',\r\n '2.5',\r\n '2.5.1',\r\n '2.5.2',\r\n '2.5.2.1',\r\n '2.5.2.1.18',\r\n '2.6',\r\n '2.6.1',\r\n '2.6.1.1',\r\n '2.7',\r\n '2.7.1',\r\n '2.7.1.1',\r\n '2.8',\r\n '2.8.1',\r\n '2.8.1.1',\r\n]\r\n\r\n// Links to NatureServe's CMECs site, descriptions were extracted from there\r\nexport const bioticInfo = {\r\n '2': {\r\n label: 'Benthic/Attached Biota',\r\n description:\r\n 'Areas where biota lives on, in, or in close association with the seafloor or other substrates (e.g., pilings, buoys), extending down into the sediment to include the sub-surface layers of substrate that contain multi-cellular life.',\r\n color: '#CDAA66',\r\n link: 'https://www.cmecscatalog.org/cmecs/classification/unit/389.html',\r\n },\r\n '2.2': {\r\n label: 'Faunal Bed',\r\n description:\r\n 'Seabeds dominated or characterized by a cover of animals that are closely associated with the bottom, including attached, clinging, sessile, infaunal, burrowing, laying, interstitial, and slow-moving animals, but not animals that have created substrate (Reef Biota).',\r\n color: '#A68F62',\r\n link: 'https://www.cmecscatalog.org/cmecs/classification/unit/391.html',\r\n },\r\n '2.5': {\r\n label: 'Aquatic Vegetation Bed',\r\n description:\r\n 'Subtidal or intertidal bottoms and other areas dominated by rooted vascular plants, attached macroalgae, or mosses, which are usually submersed in the water column or floating on the surface. They may be exposed during low tides.',\r\n color: '#66CDAB',\r\n link: 'https://www.cmecscatalog.org/cmecs/classification/unit/394.html',\r\n },\r\n '2.5.1': {\r\n label: 'Benthic Macroalgae',\r\n description:\r\n 'Aquatic beds dominated by macroalgae attached to the substrate, such as kelp, intertidal fucoids, and calcareous algae. Macroalgal communities can exist at all depths within the photic zone, on diverse substrates, and across a range of energy and water chemistry regimes.',\r\n color: '#00A884',\r\n link: 'https://www.cmecscatalog.org/cmecs/classification/unit/433.html',\r\n },\r\n '2.5.2': {\r\n label: 'Aquatic Vascular Vegetation',\r\n description:\r\n 'Aquatic vascular vegetation beds dominated by submerged, rooted, vascular species (such as seagrasses, Figure 8.15) or submerged or rooted floating freshwater tidal vascular vegetation.',\r\n color: '#448970',\r\n link: 'https://www.cmecscatalog.org/cmecs/classification/unit/434.html',\r\n },\r\n '2.5.2.1': {\r\n label: 'Seagrass Bed',\r\n description:\r\n 'Tidal aquatic vegetation beds dominated by any number of seagrass or eelgrass species, including Cymocedea sp., Halodule sp., Thalassia sp., Halophilla sp., Vallisnera sp., Ruppia sp., Phyllospadix sp., and Zostera sp.',\r\n color: '#38A800',\r\n link: 'https://www.cmecscatalog.org/cmecs/classification/unit/567.html',\r\n },\r\n '2.5.2.1.18': {\r\n label: 'Eelgrass',\r\n description:\r\n 'Eelgrass (Zostera spp.) is a marine flowering plant that is found in temperature zones in soft-bottom habitats in estuaries and coastal environments worldwide. Eelgrass is the most common seagrass taxon along the U.S. West Coast and occurs from Alaska to Baja California.',\r\n color: '#A3FF73',\r\n // link: '' // not available from CMECS site yet\r\n },\r\n '2.6': {\r\n label: 'Emergent Wetland',\r\n description:\r\n 'Areas in this class are characterized by erect, rooted, herbaceous hydrophytes—excluding emergent mosses and lichens. This vegetation is present for most of the growing season in most years. These wetlands are usually dominated by perennial plants. These areas may be diked or disconnected from tidal influence, but are within the historical extent of the estuary.',\r\n color: '#73B2FF',\r\n link: 'https://www.cmecscatalog.org/cmecs/classification/unit/395.html',\r\n },\r\n '2.6.1': {\r\n label: 'Emergent Tidal Marsh',\r\n description:\r\n 'Communities dominated by emergent, halophytic, herbaceous vegetation (with occasional woody forbs or shrubs) along low-wave-energy, intertidal areas of estuaries and rivers.',\r\n color: '#004DA8',\r\n link: 'https://www.cmecscatalog.org/cmecs/classification/unit/435.html',\r\n },\r\n '2.6.1.1': {\r\n label: 'Brackish Emergent Tidal Marsh',\r\n description:\r\n 'Marshes dominated by species with a wide range of salinity tolerance. Depending on the salinity levels (0.5-30), more or less salt-intolerant species may be present. ',\r\n color: '#000F5A',\r\n link: 'https://www.cmecscatalog.org/cmecs/classification/unit/568.html',\r\n },\r\n '2.7': {\r\n label: 'Scrub-Shrub Wetland',\r\n description:\r\n 'Areas in this class are dominated by woody vegetation that is generally less than 6 meters tall. Characteristic species include true shrubs, young trees, and trees or shrubs that are small or stunted due to environmental conditions. These areas may be diked or disconnected from tidal influence, but are within the historical extent of the estuary.',\r\n color: '#D7D79E',\r\n link: 'https://www.cmecscatalog.org/cmecs/classification/unit/396.html',\r\n },\r\n '2.7.1': {\r\n label: 'Tidal Scrub-Shrub Wetland',\r\n description:\r\n 'Estuarine or tidal riverine areas dominated by shrub vegetation that has less than 10% tree cover.',\r\n color: '#E6E600',\r\n link: 'https://www.cmecscatalog.org/cmecs/classification/unit/437.html',\r\n },\r\n '2.7.1.1': {\r\n label: 'Brackish Tidal Scrub-Shrub Wetland',\r\n description:\r\n 'Tidal areas dominated by shrub or immature tree species that are less than 6 meters tall and have a range of salt tolerance.',\r\n color: '#737300',\r\n link: 'https://www.cmecscatalog.org/cmecs/classification/unit/574.html',\r\n },\r\n '2.8': {\r\n label: 'Forested Wetland',\r\n description:\r\n 'Areas in this class are characterized by woody vegetation that is generally 6 meters or taller. These areas may be diked or disconnected from tidal influence, but are within the historical extent of the estuary.',\r\n color: '#ABCD66',\r\n link: 'https://www.cmecscatalog.org/cmecs/classification/unit/397.html',\r\n },\r\n '2.8.1': {\r\n label: 'Tidal Forested Wetland',\r\n description:\r\n 'Estuarine or tidal riverine areas with greater than 10% tree cover',\r\n color: '#4C7300',\r\n link: 'https://www.cmecscatalog.org/cmecs/classification/unit/438.html',\r\n },\r\n '2.8.1.1': {\r\n label: 'Brackish Tidal Forest/Woodland',\r\n description:\r\n 'Tidal areas dominated by tree species that are greater than 6 meters tall and have a range of salt tolerance. Salinities may range from 0.5-30.',\r\n color: '#233200',\r\n link: 'https://www.cmecscatalog.org/cmecs/classification/unit/578.html',\r\n },\r\n}\r\n\r\nexport const twInfo = {\r\n lost: {\r\n label: 'lost',\r\n color: '#E69800',\r\n },\r\n restored: {\r\n label: 'restored',\r\n color: '#98E600',\r\n },\r\n retained: { label: 'retained', color: '#66CDAB' },\r\n // Not displayed in legend or map, but exists in source and is filtered out\r\n // 'N/A': {\r\n // label: 'not assessed',\r\n // color: '#FFFFFF',\r\n // },\r\n}\r\n\r\nexport const imageCredits = {\r\n WA: {\r\n credits: '© Washington State Department of Ecology',\r\n url: 'https://fortress.wa.gov/ecy/shorephotoviewer/',\r\n },\r\n OR: {\r\n credits: 'Oregon ShoreZone, CC-BY-SA',\r\n url: 'https://www.oregonshorezone.info/images.html',\r\n },\r\n CA: {\r\n credits:\r\n '© 2002-2019 Kenneth & Gabrielle Adelman, California Coastal Records Project',\r\n url: 'https://www.californiacoastline.org/',\r\n },\r\n GE: {\r\n credits: 'Google Earth',\r\n },\r\n}\r\n\r\nexport const imageRoot =\r\n 'https://maps.psmfc.org/imagelibrary/PMEP/Images/Estuary_Images/'\r\n","module.exports = __webpack_public_path__ + \"static/4029-bfab6e7e459b131904df43ca69bf5254.jpg\";","module.exports = __webpack_public_path__ + \"static/1028-15e405e33bc2b86bf42d3e45c2110bb7.jpg\";","module.exports = __webpack_public_path__ + \"static/3044-21834274309b3daac954d33ae808d90e.jpg\";","module.exports = __webpack_public_path__ + \"static/1083-f352bc0d8d19f137071ba52e6f983fb5.jpg\";","module.exports = __webpack_public_path__ + \"static/3073-a29c34f9887a5d8e6ac86898381fec7c.jpg\";","module.exports = __webpack_public_path__ + \"static/1046-337862be98182b7fec17d4e513be2a6a.jpg\";","module.exports = __webpack_public_path__ + \"static/3018-491a0d815603bd0fab38a705d0c49dec.jpg\";","module.exports = __webpack_public_path__ + \"static/1007-b715442bdf5d3d6c6a1526668cc198ef.jpg\";","module.exports = __webpack_public_path__ + \"static/4003-d94c2072f73043226a056c627e95f89c.jpg\";","module.exports = __webpack_public_path__ + \"static/2077-750f1ed815cf8676f85891e5eb540462.jpg\";","module.exports = __webpack_public_path__ + \"static/2075-6faf19ccd2ac8b9058d2884c3d1aeb4e.jpg\";","module.exports = __webpack_public_path__ + \"static/3092-0191655ca5644cae680934ae3f6702b7.jpg\";","module.exports = __webpack_public_path__ + \"static/1151-943650d463d43275cd49a3f87dceb992.jpg\";","module.exports = __webpack_public_path__ + \"static/4022-ac6436a82dcc2b08bbf25683590a9728.jpg\";","module.exports = __webpack_public_path__ + \"static/3025-d9d08f445c271f3831f6eaa94d480271.jpg\";","module.exports = __webpack_public_path__ + \"static/4005-72cf9fe5f04780ecac5505b6b2c41500.jpg\";","module.exports = __webpack_public_path__ + \"static/3103-0aec30cca2122e641f35ac09c652efef.jpg\";","module.exports = __webpack_public_path__ + \"static/2043-d27af0ab5a6a89324d55f9aba49f5274.jpg\";","/**\n * This is a straight rip-off of the React.js ReactPropTypes.js proptype validators,\n * modified to make it possible to validate Immutable.js data.\n * ImmutableTypes.listOf is patterned after React.PropTypes.arrayOf, but for Immutable.List\n * ImmutableTypes.shape is based on React.PropTypes.shape, but for any Immutable.Iterable\n */\n\"use strict\";\n\nvar Immutable = require(\"immutable\");\n\nvar ANONYMOUS = \"<>\";\nvar ImmutablePropTypes;\n\nif (process.env.NODE_ENV !== \"production\") {\n ImmutablePropTypes = {\n listOf: createListOfTypeChecker,\n mapOf: createMapOfTypeChecker,\n orderedMapOf: createOrderedMapOfTypeChecker,\n setOf: createSetOfTypeChecker,\n orderedSetOf: createOrderedSetOfTypeChecker,\n stackOf: createStackOfTypeChecker,\n iterableOf: createIterableOfTypeChecker,\n recordOf: createRecordOfTypeChecker,\n shape: createShapeChecker,\n contains: createShapeChecker,\n mapContains: createMapContainsChecker,\n orderedMapContains: createOrderedMapContainsChecker,\n // Primitive Types\n list: createImmutableTypeChecker(\"List\", Immutable.List.isList),\n map: createImmutableTypeChecker(\"Map\", Immutable.Map.isMap),\n orderedMap: createImmutableTypeChecker(\"OrderedMap\", Immutable.OrderedMap.isOrderedMap),\n set: createImmutableTypeChecker(\"Set\", Immutable.Set.isSet),\n orderedSet: createImmutableTypeChecker(\"OrderedSet\", Immutable.OrderedSet.isOrderedSet),\n stack: createImmutableTypeChecker(\"Stack\", Immutable.Stack.isStack),\n seq: createImmutableTypeChecker(\"Seq\", Immutable.Seq.isSeq),\n record: createImmutableTypeChecker(\"Record\", function (isRecord) {\n return isRecord instanceof Immutable.Record;\n }),\n iterable: createImmutableTypeChecker(\"Iterable\", Immutable.Iterable.isIterable)\n };\n} else {\n var productionTypeChecker = function productionTypeChecker() {\n invariant(false, \"ImmutablePropTypes type checking code is stripped in production.\");\n };\n\n productionTypeChecker.isRequired = productionTypeChecker;\n\n var getProductionTypeChecker = function getProductionTypeChecker() {\n return productionTypeChecker;\n };\n\n ImmutablePropTypes = {\n listOf: getProductionTypeChecker,\n mapOf: getProductionTypeChecker,\n orderedMapOf: getProductionTypeChecker,\n setOf: getProductionTypeChecker,\n orderedSetOf: getProductionTypeChecker,\n stackOf: getProductionTypeChecker,\n iterableOf: getProductionTypeChecker,\n recordOf: getProductionTypeChecker,\n shape: getProductionTypeChecker,\n contains: getProductionTypeChecker,\n mapContains: getProductionTypeChecker,\n orderedMapContains: getProductionTypeChecker,\n // Primitive Types\n list: productionTypeChecker,\n map: productionTypeChecker,\n orderedMap: productionTypeChecker,\n set: productionTypeChecker,\n orderedSet: productionTypeChecker,\n stack: productionTypeChecker,\n seq: productionTypeChecker,\n record: productionTypeChecker,\n iterable: productionTypeChecker\n };\n}\n\nImmutablePropTypes.iterable.indexed = createIterableSubclassTypeChecker(\"Indexed\", Immutable.Iterable.isIndexed);\nImmutablePropTypes.iterable.keyed = createIterableSubclassTypeChecker(\"Keyed\", Immutable.Iterable.isKeyed);\n\nfunction getPropType(propValue) {\n var propType = typeof propValue;\n\n if (Array.isArray(propValue)) {\n return \"array\";\n }\n\n if (propValue instanceof RegExp) {\n // Old webkits (at least until Android 4.0) return 'function' rather than\n // 'object' for typeof a RegExp. We'll normalize this here so that /bla/\n // passes PropTypes.object.\n return \"object\";\n }\n\n if (propValue instanceof Immutable.Iterable) {\n return \"Immutable.\" + propValue.toSource().split(\" \")[0];\n }\n\n return propType;\n}\n\nfunction createChainableTypeChecker(validate) {\n function checkType(isRequired, props, propName, componentName, location, propFullName) {\n for (var _len = arguments.length, rest = Array(_len > 6 ? _len - 6 : 0), _key = 6; _key < _len; _key++) {\n rest[_key - 6] = arguments[_key];\n }\n\n propFullName = propFullName || propName;\n componentName = componentName || ANONYMOUS;\n\n if (props[propName] == null) {\n var locationName = location;\n\n if (isRequired) {\n return new Error(\"Required \" + locationName + \" `\" + propFullName + \"` was not specified in \" + (\"`\" + componentName + \"`.\"));\n }\n } else {\n return validate.apply(undefined, [props, propName, componentName, location, propFullName].concat(rest));\n }\n }\n\n var chainedCheckType = checkType.bind(null, false);\n chainedCheckType.isRequired = checkType.bind(null, true);\n return chainedCheckType;\n}\n\nfunction createImmutableTypeChecker(immutableClassName, immutableClassTypeValidator) {\n function validate(props, propName, componentName, location, propFullName) {\n var propValue = props[propName];\n\n if (!immutableClassTypeValidator(propValue)) {\n var propType = getPropType(propValue);\n return new Error(\"Invalid \" + location + \" `\" + propFullName + \"` of type `\" + propType + \"` \" + (\"supplied to `\" + componentName + \"`, expected `\" + immutableClassName + \"`.\"));\n }\n\n return null;\n }\n\n return createChainableTypeChecker(validate);\n}\n\nfunction createIterableSubclassTypeChecker(subclassName, validator) {\n return createImmutableTypeChecker(\"Iterable.\" + subclassName, function (propValue) {\n return Immutable.Iterable.isIterable(propValue) && validator(propValue);\n });\n}\n\nfunction createIterableTypeChecker(typeChecker, immutableClassName, immutableClassTypeValidator) {\n function validate(props, propName, componentName, location, propFullName) {\n for (var _len = arguments.length, rest = Array(_len > 5 ? _len - 5 : 0), _key = 5; _key < _len; _key++) {\n rest[_key - 5] = arguments[_key];\n }\n\n var propValue = props[propName];\n\n if (!immutableClassTypeValidator(propValue)) {\n var locationName = location;\n var propType = getPropType(propValue);\n return new Error(\"Invalid \" + locationName + \" `\" + propFullName + \"` of type \" + (\"`\" + propType + \"` supplied to `\" + componentName + \"`, expected an Immutable.js \" + immutableClassName + \".\"));\n }\n\n if (typeof typeChecker !== \"function\") {\n return new Error(\"Invalid typeChecker supplied to `\" + componentName + \"` \" + (\"for propType `\" + propFullName + \"`, expected a function.\"));\n }\n\n var propValues = propValue.valueSeq().toArray();\n\n for (var i = 0, len = propValues.length; i < len; i++) {\n var error = typeChecker.apply(undefined, [propValues, i, componentName, location, \"\" + propFullName + \"[\" + i + \"]\"].concat(rest));\n\n if (error instanceof Error) {\n return error;\n }\n }\n }\n\n return createChainableTypeChecker(validate);\n}\n\nfunction createKeysTypeChecker(typeChecker) {\n function validate(props, propName, componentName, location, propFullName) {\n for (var _len = arguments.length, rest = Array(_len > 5 ? _len - 5 : 0), _key = 5; _key < _len; _key++) {\n rest[_key - 5] = arguments[_key];\n }\n\n var propValue = props[propName];\n\n if (typeof typeChecker !== \"function\") {\n return new Error(\"Invalid keysTypeChecker (optional second argument) supplied to `\" + componentName + \"` \" + (\"for propType `\" + propFullName + \"`, expected a function.\"));\n }\n\n var keys = propValue.keySeq().toArray();\n\n for (var i = 0, len = keys.length; i < len; i++) {\n var error = typeChecker.apply(undefined, [keys, i, componentName, location, \"\" + propFullName + \" -> key(\" + keys[i] + \")\"].concat(rest));\n\n if (error instanceof Error) {\n return error;\n }\n }\n }\n\n return createChainableTypeChecker(validate);\n}\n\nfunction createListOfTypeChecker(typeChecker) {\n return createIterableTypeChecker(typeChecker, \"List\", Immutable.List.isList);\n}\n\nfunction createMapOfTypeCheckerFactory(valuesTypeChecker, keysTypeChecker, immutableClassName, immutableClassTypeValidator) {\n function validate() {\n for (var _len = arguments.length, args = Array(_len), _key = 0; _key < _len; _key++) {\n args[_key] = arguments[_key];\n }\n\n return createIterableTypeChecker(valuesTypeChecker, immutableClassName, immutableClassTypeValidator).apply(undefined, args) || keysTypeChecker && createKeysTypeChecker(keysTypeChecker).apply(undefined, args);\n }\n\n return createChainableTypeChecker(validate);\n}\n\nfunction createMapOfTypeChecker(valuesTypeChecker, keysTypeChecker) {\n return createMapOfTypeCheckerFactory(valuesTypeChecker, keysTypeChecker, \"Map\", Immutable.Map.isMap);\n}\n\nfunction createOrderedMapOfTypeChecker(valuesTypeChecker, keysTypeChecker) {\n return createMapOfTypeCheckerFactory(valuesTypeChecker, keysTypeChecker, \"OrderedMap\", Immutable.OrderedMap.isOrderedMap);\n}\n\nfunction createSetOfTypeChecker(typeChecker) {\n return createIterableTypeChecker(typeChecker, \"Set\", Immutable.Set.isSet);\n}\n\nfunction createOrderedSetOfTypeChecker(typeChecker) {\n return createIterableTypeChecker(typeChecker, \"OrderedSet\", Immutable.OrderedSet.isOrderedSet);\n}\n\nfunction createStackOfTypeChecker(typeChecker) {\n return createIterableTypeChecker(typeChecker, \"Stack\", Immutable.Stack.isStack);\n}\n\nfunction createIterableOfTypeChecker(typeChecker) {\n return createIterableTypeChecker(typeChecker, \"Iterable\", Immutable.Iterable.isIterable);\n}\n\nfunction createRecordOfTypeChecker(recordKeys) {\n function validate(props, propName, componentName, location, propFullName) {\n for (var _len = arguments.length, rest = Array(_len > 5 ? _len - 5 : 0), _key = 5; _key < _len; _key++) {\n rest[_key - 5] = arguments[_key];\n }\n\n var propValue = props[propName];\n\n if (!(propValue instanceof Immutable.Record)) {\n var propType = getPropType(propValue);\n var locationName = location;\n return new Error(\"Invalid \" + locationName + \" `\" + propFullName + \"` of type `\" + propType + \"` \" + (\"supplied to `\" + componentName + \"`, expected an Immutable.js Record.\"));\n }\n\n for (var key in recordKeys) {\n var checker = recordKeys[key];\n\n if (!checker) {\n continue;\n }\n\n var mutablePropValue = propValue.toObject();\n var error = checker.apply(undefined, [mutablePropValue, key, componentName, location, \"\" + propFullName + \".\" + key].concat(rest));\n\n if (error) {\n return error;\n }\n }\n }\n\n return createChainableTypeChecker(validate);\n} // there is some irony in the fact that shapeTypes is a standard hash and not an immutable collection\n\n\nfunction createShapeTypeChecker(shapeTypes) {\n var immutableClassName = arguments[1] === undefined ? \"Iterable\" : arguments[1];\n var immutableClassTypeValidator = arguments[2] === undefined ? Immutable.Iterable.isIterable : arguments[2];\n\n function validate(props, propName, componentName, location, propFullName) {\n for (var _len = arguments.length, rest = Array(_len > 5 ? _len - 5 : 0), _key = 5; _key < _len; _key++) {\n rest[_key - 5] = arguments[_key];\n }\n\n var propValue = props[propName];\n\n if (!immutableClassTypeValidator(propValue)) {\n var propType = getPropType(propValue);\n var locationName = location;\n return new Error(\"Invalid \" + locationName + \" `\" + propFullName + \"` of type `\" + propType + \"` \" + (\"supplied to `\" + componentName + \"`, expected an Immutable.js \" + immutableClassName + \".\"));\n }\n\n var mutablePropValue = propValue.toObject();\n\n for (var key in shapeTypes) {\n var checker = shapeTypes[key];\n\n if (!checker) {\n continue;\n }\n\n var error = checker.apply(undefined, [mutablePropValue, key, componentName, location, \"\" + propFullName + \".\" + key].concat(rest));\n\n if (error) {\n return error;\n }\n }\n }\n\n return createChainableTypeChecker(validate);\n}\n\nfunction createShapeChecker(shapeTypes) {\n return createShapeTypeChecker(shapeTypes);\n}\n\nfunction createMapContainsChecker(shapeTypes) {\n return createShapeTypeChecker(shapeTypes, \"Map\", Immutable.Map.isMap);\n}\n\nfunction createOrderedMapContainsChecker(shapeTypes) {\n return createShapeTypeChecker(shapeTypes, \"OrderedMap\", Immutable.OrderedMap.isOrderedMap);\n}\n\nmodule.exports = ImmutablePropTypes;","module.exports = __webpack_public_path__ + \"static/1155-4ad0ff3508999d817d2ffe949de8e340.jpg\";","module.exports = __webpack_public_path__ + \"static/3060-0e4659fa83ff3443b435c04482421c40.jpg\";","module.exports = __webpack_public_path__ + \"static/1059-e09fb2933bf2d23c525696e48976ae7e.jpg\";","module.exports = __webpack_public_path__ + \"static/4013-d8682fee1cdabc5aaa7a4d15fa96b8d5.jpg\";","module.exports = __webpack_public_path__ + \"static/1143-da09cc9cc8f02abf324074f647d58653.jpg\";","module.exports = __webpack_public_path__ + \"static/3013-20e2977c5b4e844ae54d94ca084cdfb0.jpg\";","module.exports = __webpack_public_path__ + \"static/4004-9be7b6ba7872a10725824ea52f102f92.jpg\";","module.exports = __webpack_public_path__ + \"static/3095-17eddd8154134af2e317b4a77253d72f.jpg\";","module.exports = __webpack_public_path__ + \"static/1133-8fe363ca48e63f64fe776ae0d53c5c71.jpg\";","module.exports = __webpack_public_path__ + \"static/1157-4debb692be0b197b681466805c2a1dfc.jpg\";","module.exports = __webpack_public_path__ + \"static/3005-d5730b3785df008fcfd24153753515b1.jpg\";","module.exports = __webpack_public_path__ + \"static/1068-00755404326934a75e719bcd2fe0b64c.jpg\";"],"sourceRoot":""}