@buildcanada/charts 0.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (404) hide show
  1. package/LICENSE.md +8 -0
  2. package/README.md +113 -0
  3. package/package.json +137 -0
  4. package/src/components/BodyPortal/BodyPortal.tsx +40 -0
  5. package/src/components/Button/Button.scss +110 -0
  6. package/src/components/Button/Button.tsx +101 -0
  7. package/src/components/Checkbox.scss +93 -0
  8. package/src/components/Checkbox.tsx +47 -0
  9. package/src/components/ExpandableToggle/ExpandableToggle.scss +123 -0
  10. package/src/components/ExpandableToggle/ExpandableToggle.tsx +60 -0
  11. package/src/components/GrapherTabIcon.tsx +156 -0
  12. package/src/components/GrapherTrendArrow.scss +16 -0
  13. package/src/components/GrapherTrendArrow.tsx +30 -0
  14. package/src/components/Halo/Halo.tsx +44 -0
  15. package/src/components/LabeledSwitch/LabeledSwitch.scss +109 -0
  16. package/src/components/LabeledSwitch/LabeledSwitch.tsx +62 -0
  17. package/src/components/MarkdownTextWrap/MarkdownTextWrap.tsx +1173 -0
  18. package/src/components/OverlayHeader.scss +18 -0
  19. package/src/components/OverlayHeader.tsx +29 -0
  20. package/src/components/RadioButton.scss +69 -0
  21. package/src/components/RadioButton.tsx +42 -0
  22. package/src/components/SimpleMarkdownText.tsx +89 -0
  23. package/src/components/TextInput.scss +17 -0
  24. package/src/components/TextInput.tsx +19 -0
  25. package/src/components/TextWrap/TextWrap.tsx +361 -0
  26. package/src/components/TextWrap/TextWrapUtils.ts +32 -0
  27. package/src/components/closeButton/CloseButton.scss +40 -0
  28. package/src/components/closeButton/CloseButton.tsx +27 -0
  29. package/src/components/index.ts +70 -0
  30. package/src/components/loadingIndicator/LoadingIndicator.scss +40 -0
  31. package/src/components/loadingIndicator/LoadingIndicator.tsx +28 -0
  32. package/src/components/markdown/remarkPlainLinks.ts +36 -0
  33. package/src/components/reactUtil.ts +20 -0
  34. package/src/components/stubs/CodeSnippet.tsx +19 -0
  35. package/src/components/stubs/DataCitation.tsx +16 -0
  36. package/src/components/stubs/IndicatorKeyData.tsx +45 -0
  37. package/src/components/stubs/IndicatorProcessing.tsx +15 -0
  38. package/src/components/stubs/IndicatorSources.tsx +15 -0
  39. package/src/components/styles/colors.scss +113 -0
  40. package/src/components/styles/mixins.scss +630 -0
  41. package/src/components/styles/typography.scss +579 -0
  42. package/src/components/styles/util.scss +89 -0
  43. package/src/components/styles/variables.scss +208 -0
  44. package/src/config/ChartsConfig.ts +163 -0
  45. package/src/config/ChartsProvider.tsx +157 -0
  46. package/src/config/index.ts +20 -0
  47. package/src/core-table/CoreTable.ts +1355 -0
  48. package/src/core-table/CoreTableColumns.ts +973 -0
  49. package/src/core-table/CoreTableUtils.ts +793 -0
  50. package/src/core-table/ErrorValues.ts +73 -0
  51. package/src/core-table/OwidTable.ts +1175 -0
  52. package/src/core-table/OwidTableSynthesizers.ts +272 -0
  53. package/src/core-table/OwidTableUtil.ts +76 -0
  54. package/src/core-table/Transforms.ts +484 -0
  55. package/src/core-table/index.ts +82 -0
  56. package/src/explorer/ColumnGrammar.ts +217 -0
  57. package/src/explorer/Explorer.sample.ts +212 -0
  58. package/src/explorer/Explorer.scss +148 -0
  59. package/src/explorer/Explorer.tsx +1283 -0
  60. package/src/explorer/ExplorerConstants.ts +85 -0
  61. package/src/explorer/ExplorerControls.scss +156 -0
  62. package/src/explorer/ExplorerControls.tsx +210 -0
  63. package/src/explorer/ExplorerDecisionMatrix.ts +471 -0
  64. package/src/explorer/ExplorerGrammar.ts +161 -0
  65. package/src/explorer/ExplorerProgram.ts +568 -0
  66. package/src/explorer/ExplorerUtils.ts +59 -0
  67. package/src/explorer/GrapherGrammar.ts +387 -0
  68. package/src/explorer/gridLang/GrammarUtils.ts +121 -0
  69. package/src/explorer/gridLang/GridCell.ts +298 -0
  70. package/src/explorer/gridLang/GridLangConstants.ts +255 -0
  71. package/src/explorer/gridLang/GridProgram.ts +311 -0
  72. package/src/explorer/gridLang/readme.md +17 -0
  73. package/src/explorer/index.ts +69 -0
  74. package/src/explorer/readme.md +19 -0
  75. package/src/explorer/urlMigrations/CO2UrlMigration.ts +46 -0
  76. package/src/explorer/urlMigrations/CovidUrlMigration.ts +37 -0
  77. package/src/explorer/urlMigrations/EnergyUrlMigration.ts +41 -0
  78. package/src/explorer/urlMigrations/ExplorerPageUrlMigrationSpec.ts +12 -0
  79. package/src/explorer/urlMigrations/ExplorerUrlMigrationUtils.ts +45 -0
  80. package/src/explorer/urlMigrations/ExplorerUrlMigrations.ts +33 -0
  81. package/src/explorer/urlMigrations/LegacyCovidUrlMigration.ts +144 -0
  82. package/src/explorer/urlMigrations/readme.md +39 -0
  83. package/src/grapher/axis/Axis.ts +973 -0
  84. package/src/grapher/axis/AxisConfig.ts +179 -0
  85. package/src/grapher/axis/AxisViews.tsx +597 -0
  86. package/src/grapher/barCharts/DiscreteBarChart.tsx +728 -0
  87. package/src/grapher/barCharts/DiscreteBarChartConstants.ts +60 -0
  88. package/src/grapher/barCharts/DiscreteBarChartHelpers.ts +338 -0
  89. package/src/grapher/barCharts/DiscreteBarChartState.ts +354 -0
  90. package/src/grapher/barCharts/DiscreteBarChartThumbnail.tsx +34 -0
  91. package/src/grapher/captionedChart/CaptionedChart.scss +61 -0
  92. package/src/grapher/captionedChart/CaptionedChart.tsx +523 -0
  93. package/src/grapher/captionedChart/Logos.tsx +141 -0
  94. package/src/grapher/captionedChart/LogosSVG.tsx +16 -0
  95. package/src/grapher/captionedChart/StaticChartRasterizer.tsx +178 -0
  96. package/src/grapher/captionedChart/assets/buildcanada-logo-square.svg +15 -0
  97. package/src/grapher/captionedChart/assets/buildcanada-logo.svg +15 -0
  98. package/src/grapher/captionedChart/assets/canadaspends.svg +7 -0
  99. package/src/grapher/captionedChart/readme.md +14 -0
  100. package/src/grapher/chart/Chart.tsx +62 -0
  101. package/src/grapher/chart/ChartAreaContent.tsx +172 -0
  102. package/src/grapher/chart/ChartDimension.ts +121 -0
  103. package/src/grapher/chart/ChartInterface.ts +83 -0
  104. package/src/grapher/chart/ChartManager.ts +113 -0
  105. package/src/grapher/chart/ChartTabs.ts +178 -0
  106. package/src/grapher/chart/ChartTypeMap.tsx +158 -0
  107. package/src/grapher/chart/ChartTypeSwitcher.tsx +26 -0
  108. package/src/grapher/chart/ChartUtils.tsx +364 -0
  109. package/src/grapher/chart/DimensionSlot.ts +45 -0
  110. package/src/grapher/chart/StaticChartWrapper.tsx +94 -0
  111. package/src/grapher/chart/guidedChartUtils.ts +82 -0
  112. package/src/grapher/color/BinningStrategies.ts +484 -0
  113. package/src/grapher/color/BinningStrategyEqualSizeBins.ts +132 -0
  114. package/src/grapher/color/BinningStrategyLogarithmic.ts +121 -0
  115. package/src/grapher/color/CategoricalColorAssigner.ts +97 -0
  116. package/src/grapher/color/ColorBrewerSchemes.ts +80 -0
  117. package/src/grapher/color/ColorConstants.ts +20 -0
  118. package/src/grapher/color/ColorScale.ts +339 -0
  119. package/src/grapher/color/ColorScaleBin.ts +147 -0
  120. package/src/grapher/color/ColorScaleConfig.ts +204 -0
  121. package/src/grapher/color/ColorScheme.ts +137 -0
  122. package/src/grapher/color/ColorSchemes.ts +149 -0
  123. package/src/grapher/color/ColorUtils.ts +86 -0
  124. package/src/grapher/color/CustomSchemes.ts +1772 -0
  125. package/src/grapher/color/readme.md +84 -0
  126. package/src/grapher/comparisonLine/ComparisonLine.tsx +31 -0
  127. package/src/grapher/comparisonLine/ComparisonLineConstants.ts +11 -0
  128. package/src/grapher/comparisonLine/ComparisonLineGenerator.ts +60 -0
  129. package/src/grapher/comparisonLine/ComparisonLineHelpers.ts +10 -0
  130. package/src/grapher/comparisonLine/CustomComparisonLine.tsx +159 -0
  131. package/src/grapher/comparisonLine/VerticalComparisonLine.tsx +208 -0
  132. package/src/grapher/controls/ActionButtons.scss +97 -0
  133. package/src/grapher/controls/ActionButtons.tsx +453 -0
  134. package/src/grapher/controls/CommandPalette.scss +50 -0
  135. package/src/grapher/controls/CommandPalette.tsx +74 -0
  136. package/src/grapher/controls/ContentSwitchers.scss +93 -0
  137. package/src/grapher/controls/ContentSwitchers.tsx +238 -0
  138. package/src/grapher/controls/Controls.scss +158 -0
  139. package/src/grapher/controls/DataTableFilterDropdown.scss +7 -0
  140. package/src/grapher/controls/DataTableFilterDropdown.tsx +168 -0
  141. package/src/grapher/controls/DataTableSearchField.scss +3 -0
  142. package/src/grapher/controls/DataTableSearchField.tsx +76 -0
  143. package/src/grapher/controls/Dropdown.scss +252 -0
  144. package/src/grapher/controls/Dropdown.tsx +235 -0
  145. package/src/grapher/controls/EntitySelectionToggle.tsx +135 -0
  146. package/src/grapher/controls/MapRegionDropdown.scss +3 -0
  147. package/src/grapher/controls/MapRegionDropdown.tsx +104 -0
  148. package/src/grapher/controls/MapResetButton.tsx +115 -0
  149. package/src/grapher/controls/MapZoomDropdown.scss +9 -0
  150. package/src/grapher/controls/MapZoomDropdown.tsx +270 -0
  151. package/src/grapher/controls/MapZoomToSelectionButton.tsx +87 -0
  152. package/src/grapher/controls/SearchField.scss +78 -0
  153. package/src/grapher/controls/SearchField.tsx +63 -0
  154. package/src/grapher/controls/SettingsMenu.scss +191 -0
  155. package/src/grapher/controls/SettingsMenu.tsx +399 -0
  156. package/src/grapher/controls/ShareMenu.scss +58 -0
  157. package/src/grapher/controls/ShareMenu.tsx +304 -0
  158. package/src/grapher/controls/SortIcon.tsx +39 -0
  159. package/src/grapher/controls/VerticalScrollContainer.tsx +263 -0
  160. package/src/grapher/controls/controlsRow/ControlsRow.tsx +168 -0
  161. package/src/grapher/controls/dropdown-icons.scss +4 -0
  162. package/src/grapher/controls/entityPicker/EntityPicker.scss +255 -0
  163. package/src/grapher/controls/entityPicker/EntityPicker.tsx +816 -0
  164. package/src/grapher/controls/entityPicker/EntityPickerConstants.ts +23 -0
  165. package/src/grapher/controls/globalEntitySelector/GlobalEntitySelector.scss +129 -0
  166. package/src/grapher/controls/globalEntitySelector/GlobalEntitySelector.tsx +463 -0
  167. package/src/grapher/controls/globalEntitySelector/GlobalEntitySelectorConstants.ts +3 -0
  168. package/src/grapher/controls/globalEntitySelector/readme.md +17 -0
  169. package/src/grapher/controls/settings/AbsRelToggle.tsx +64 -0
  170. package/src/grapher/controls/settings/AxisScaleToggle.tsx +53 -0
  171. package/src/grapher/controls/settings/FacetStrategySelector.tsx +110 -0
  172. package/src/grapher/controls/settings/FacetYDomainToggle.tsx +51 -0
  173. package/src/grapher/controls/settings/NoDataAreaToggle.tsx +38 -0
  174. package/src/grapher/controls/settings/ZoomToggle.tsx +36 -0
  175. package/src/grapher/core/EntitiesByRegionType.ts +174 -0
  176. package/src/grapher/core/EntityCodes.ts +19 -0
  177. package/src/grapher/core/EntityUrlBuilder.ts +200 -0
  178. package/src/grapher/core/FetchingGrapher.tsx +156 -0
  179. package/src/grapher/core/Grapher.tsx +760 -0
  180. package/src/grapher/core/GrapherAnalytics.ts +229 -0
  181. package/src/grapher/core/GrapherConstants.ts +173 -0
  182. package/src/grapher/core/GrapherState.tsx +3659 -0
  183. package/src/grapher/core/GrapherUrl.ts +184 -0
  184. package/src/grapher/core/GrapherUrlMigrations.ts +29 -0
  185. package/src/grapher/core/GrapherUseHelpers.tsx +147 -0
  186. package/src/grapher/core/LegacyToOwidTable.ts +841 -0
  187. package/src/grapher/core/grapher.entry.ts +5 -0
  188. package/src/grapher/core/grapher.scss +257 -0
  189. package/src/grapher/core/loadGrapherTableHelpers.ts +116 -0
  190. package/src/grapher/core/loadVariable.ts +104 -0
  191. package/src/grapher/core/relatedQuestion.ts +12 -0
  192. package/src/grapher/core/typography.scss +206 -0
  193. package/src/grapher/dataTable/DataTable.sample.ts +206 -0
  194. package/src/grapher/dataTable/DataTable.scss +249 -0
  195. package/src/grapher/dataTable/DataTable.tsx +1332 -0
  196. package/src/grapher/dataTable/DataTableConstants.ts +186 -0
  197. package/src/grapher/entitySelector/EntitySelector.scss +255 -0
  198. package/src/grapher/entitySelector/EntitySelector.tsx +1838 -0
  199. package/src/grapher/facet/FacetChart.tsx +943 -0
  200. package/src/grapher/facet/FacetChartConstants.ts +24 -0
  201. package/src/grapher/facet/FacetChartUtils.ts +51 -0
  202. package/src/grapher/facet/FacetMap.tsx +604 -0
  203. package/src/grapher/facet/FacetMapConstants.ts +23 -0
  204. package/src/grapher/facet/readme.md +13 -0
  205. package/src/grapher/focus/FocusArray.ts +79 -0
  206. package/src/grapher/footer/Footer.scss +63 -0
  207. package/src/grapher/footer/Footer.tsx +809 -0
  208. package/src/grapher/footer/FooterManager.ts +44 -0
  209. package/src/grapher/fullScreen/FullScreen.scss +11 -0
  210. package/src/grapher/fullScreen/FullScreen.tsx +61 -0
  211. package/src/grapher/header/Header.scss +35 -0
  212. package/src/grapher/header/Header.tsx +372 -0
  213. package/src/grapher/header/HeaderManager.ts +28 -0
  214. package/src/grapher/index.ts +157 -0
  215. package/src/grapher/interaction/InteractionState.ts +60 -0
  216. package/src/grapher/legend/HorizontalColorLegends.tsx +923 -0
  217. package/src/grapher/legend/LegendInteractionState.ts +40 -0
  218. package/src/grapher/legend/VerticalColorLegend.tsx +295 -0
  219. package/src/grapher/lineCharts/LineChart.tsx +968 -0
  220. package/src/grapher/lineCharts/LineChartConstants.ts +89 -0
  221. package/src/grapher/lineCharts/LineChartHelpers.ts +184 -0
  222. package/src/grapher/lineCharts/LineChartState.ts +394 -0
  223. package/src/grapher/lineCharts/LineChartThumbnail.tsx +437 -0
  224. package/src/grapher/lineCharts/Lines.tsx +258 -0
  225. package/src/grapher/lineLegend/LineLegend.tsx +723 -0
  226. package/src/grapher/lineLegend/LineLegendConstants.ts +9 -0
  227. package/src/grapher/lineLegend/LineLegendFilterAlgorithms.ts +143 -0
  228. package/src/grapher/lineLegend/LineLegendHelpers.ts +253 -0
  229. package/src/grapher/lineLegend/LineLegendTypes.ts +32 -0
  230. package/src/grapher/mapCharts/CanadaTopology.ts +17922 -0
  231. package/src/grapher/mapCharts/ChoroplethGlobe.tsx +949 -0
  232. package/src/grapher/mapCharts/ChoroplethMap.tsx +662 -0
  233. package/src/grapher/mapCharts/GeoFeatures.ts +184 -0
  234. package/src/grapher/mapCharts/GlobeController.ts +496 -0
  235. package/src/grapher/mapCharts/MapAnnotationPlacements.json +1040 -0
  236. package/src/grapher/mapCharts/MapAnnotationPlacements.ts +31 -0
  237. package/src/grapher/mapCharts/MapAnnotations.ts +723 -0
  238. package/src/grapher/mapCharts/MapChart.sample.ts +59 -0
  239. package/src/grapher/mapCharts/MapChart.scss +5 -0
  240. package/src/grapher/mapCharts/MapChart.tsx +720 -0
  241. package/src/grapher/mapCharts/MapChartConstants.ts +260 -0
  242. package/src/grapher/mapCharts/MapChartState.ts +416 -0
  243. package/src/grapher/mapCharts/MapChartThumbnail.tsx +25 -0
  244. package/src/grapher/mapCharts/MapComponents.tsx +338 -0
  245. package/src/grapher/mapCharts/MapConfig.ts +156 -0
  246. package/src/grapher/mapCharts/MapHelpers.ts +181 -0
  247. package/src/grapher/mapCharts/MapProjections.ts +49 -0
  248. package/src/grapher/mapCharts/MapSparkline.tsx +257 -0
  249. package/src/grapher/mapCharts/MapTooltip.scss +49 -0
  250. package/src/grapher/mapCharts/MapTooltip.tsx +409 -0
  251. package/src/grapher/mapCharts/MapTopology.ts +1766 -0
  252. package/src/grapher/mapCharts/d3-bboxCollide.js +204 -0
  253. package/src/grapher/mapCharts/d3-geo-projection.ts +198 -0
  254. package/src/grapher/modal/DownloadIcons.tsx +39 -0
  255. package/src/grapher/modal/DownloadModal.scss +300 -0
  256. package/src/grapher/modal/DownloadModal.tsx +1226 -0
  257. package/src/grapher/modal/EmbedModal.scss +40 -0
  258. package/src/grapher/modal/EmbedModal.tsx +160 -0
  259. package/src/grapher/modal/EntitySelectorModal.tsx +59 -0
  260. package/src/grapher/modal/Modal.scss +31 -0
  261. package/src/grapher/modal/Modal.tsx +90 -0
  262. package/src/grapher/modal/ModalHeader.scss +12 -0
  263. package/src/grapher/modal/ModalHeader.tsx +16 -0
  264. package/src/grapher/modal/SourcesDescriptions.scss +87 -0
  265. package/src/grapher/modal/SourcesDescriptions.tsx +89 -0
  266. package/src/grapher/modal/SourcesKeyDataTable.scss +49 -0
  267. package/src/grapher/modal/SourcesKeyDataTable.tsx +87 -0
  268. package/src/grapher/modal/SourcesModal.scss +301 -0
  269. package/src/grapher/modal/SourcesModal.tsx +568 -0
  270. package/src/grapher/noDataModal/NoDataModal.tsx +125 -0
  271. package/src/grapher/scatterCharts/ConnectedScatterLegend.tsx +143 -0
  272. package/src/grapher/scatterCharts/MultiColorPolyline.tsx +129 -0
  273. package/src/grapher/scatterCharts/NoDataSection.scss +14 -0
  274. package/src/grapher/scatterCharts/NoDataSection.tsx +56 -0
  275. package/src/grapher/scatterCharts/ScatterPlotChart.tsx +792 -0
  276. package/src/grapher/scatterCharts/ScatterPlotChartConstants.ts +157 -0
  277. package/src/grapher/scatterCharts/ScatterPlotChartState.ts +678 -0
  278. package/src/grapher/scatterCharts/ScatterPlotChartThumbnail.tsx +155 -0
  279. package/src/grapher/scatterCharts/ScatterPlotTooltip.tsx +560 -0
  280. package/src/grapher/scatterCharts/ScatterPoints.tsx +153 -0
  281. package/src/grapher/scatterCharts/ScatterPointsWithLabels.tsx +708 -0
  282. package/src/grapher/scatterCharts/ScatterSizeLegend.tsx +327 -0
  283. package/src/grapher/scatterCharts/ScatterUtils.ts +265 -0
  284. package/src/grapher/scatterCharts/Triangle.tsx +41 -0
  285. package/src/grapher/schema/README.md +33 -0
  286. package/src/grapher/schema/defaultGrapherConfig.ts +100 -0
  287. package/src/grapher/schema/grapher-schema.009.yaml +781 -0
  288. package/src/grapher/schema/migrations/helpers.ts +58 -0
  289. package/src/grapher/schema/migrations/migrate.ts +75 -0
  290. package/src/grapher/schema/migrations/migrations.ts +158 -0
  291. package/src/grapher/selection/MapSelectionArray.ts +99 -0
  292. package/src/grapher/selection/SelectionArray.ts +71 -0
  293. package/src/grapher/selection/readme.md +16 -0
  294. package/src/grapher/sidePanel/SidePanel.scss +10 -0
  295. package/src/grapher/sidePanel/SidePanel.tsx +23 -0
  296. package/src/grapher/slideInDrawer/SlideInDrawer.scss +57 -0
  297. package/src/grapher/slideInDrawer/SlideInDrawer.tsx +125 -0
  298. package/src/grapher/slideshowController/SlideShowController.tsx +43 -0
  299. package/src/grapher/slideshowController/readme.md +7 -0
  300. package/src/grapher/slopeCharts/MarkX.tsx +45 -0
  301. package/src/grapher/slopeCharts/Slope.tsx +102 -0
  302. package/src/grapher/slopeCharts/SlopeChart.tsx +1152 -0
  303. package/src/grapher/slopeCharts/SlopeChartConstants.ts +33 -0
  304. package/src/grapher/slopeCharts/SlopeChartHelpers.ts +73 -0
  305. package/src/grapher/slopeCharts/SlopeChartState.ts +392 -0
  306. package/src/grapher/slopeCharts/SlopeChartThumbnail.tsx +368 -0
  307. package/src/grapher/stackedCharts/AbstractStackedChartState.ts +370 -0
  308. package/src/grapher/stackedCharts/MarimekkoBars.tsx +190 -0
  309. package/src/grapher/stackedCharts/MarimekkoBarsForOneEntity.tsx +168 -0
  310. package/src/grapher/stackedCharts/MarimekkoChart.tsx +1144 -0
  311. package/src/grapher/stackedCharts/MarimekkoChartConstants.ts +112 -0
  312. package/src/grapher/stackedCharts/MarimekkoChartHelpers.ts +21 -0
  313. package/src/grapher/stackedCharts/MarimekkoChartState.ts +465 -0
  314. package/src/grapher/stackedCharts/MarimekkoChartThumbnail.tsx +168 -0
  315. package/src/grapher/stackedCharts/MarimekkoInternalLabels.tsx +124 -0
  316. package/src/grapher/stackedCharts/StackedAreaChart.tsx +678 -0
  317. package/src/grapher/stackedCharts/StackedAreaChartState.ts +34 -0
  318. package/src/grapher/stackedCharts/StackedAreaChartThumbnail.tsx +215 -0
  319. package/src/grapher/stackedCharts/StackedAreas.tsx +223 -0
  320. package/src/grapher/stackedCharts/StackedBarChart.tsx +619 -0
  321. package/src/grapher/stackedCharts/StackedBarChartState.ts +80 -0
  322. package/src/grapher/stackedCharts/StackedBarChartThumbnail.tsx +220 -0
  323. package/src/grapher/stackedCharts/StackedBarSegment.tsx +87 -0
  324. package/src/grapher/stackedCharts/StackedBars.tsx +102 -0
  325. package/src/grapher/stackedCharts/StackedConstants.ts +109 -0
  326. package/src/grapher/stackedCharts/StackedDiscreteBarChart.tsx +270 -0
  327. package/src/grapher/stackedCharts/StackedDiscreteBarChartState.ts +296 -0
  328. package/src/grapher/stackedCharts/StackedDiscreteBarChartThumbnail.tsx +27 -0
  329. package/src/grapher/stackedCharts/StackedDiscreteBars.tsx +648 -0
  330. package/src/grapher/stackedCharts/StackedUtils.ts +142 -0
  331. package/src/grapher/tabs/Tabs.scss +169 -0
  332. package/src/grapher/tabs/Tabs.tsx +54 -0
  333. package/src/grapher/tabs/TabsWithDropdown.scss +62 -0
  334. package/src/grapher/tabs/TabsWithDropdown.tsx +114 -0
  335. package/src/grapher/testData/OwidTestData.sample.ts +273 -0
  336. package/src/grapher/testData/OwidTestData.ts +64 -0
  337. package/src/grapher/timeline/TimelineComponent.scss +139 -0
  338. package/src/grapher/timeline/TimelineComponent.tsx +658 -0
  339. package/src/grapher/timeline/TimelineController.ts +368 -0
  340. package/src/grapher/timeline/readme.md +7 -0
  341. package/src/grapher/tooltip/Tooltip.scss +510 -0
  342. package/src/grapher/tooltip/Tooltip.tsx +294 -0
  343. package/src/grapher/tooltip/TooltipContents.tsx +383 -0
  344. package/src/grapher/tooltip/TooltipProps.ts +123 -0
  345. package/src/grapher/tooltip/TooltipState.ts +81 -0
  346. package/src/grapher/verticalLabels/VerticalLabels.tsx +31 -0
  347. package/src/grapher/verticalLabels/VerticalLabelsState.ts +154 -0
  348. package/src/index.ts +226 -0
  349. package/src/styles/charts.scss +15 -0
  350. package/src/types/NominalType.ts +30 -0
  351. package/src/types/OwidOrigin.ts +18 -0
  352. package/src/types/OwidSource.ts +9 -0
  353. package/src/types/OwidVariable.ts +133 -0
  354. package/src/types/OwidVariableDisplayConfigInterface.ts +49 -0
  355. package/src/types/analyticsTypes.ts +54 -0
  356. package/src/types/dbTypes/Tags.ts +11 -0
  357. package/src/types/domainTypes/Archive.ts +139 -0
  358. package/src/types/domainTypes/Author.ts +28 -0
  359. package/src/types/domainTypes/ContentGraph.ts +76 -0
  360. package/src/types/domainTypes/CoreTableTypes.ts +305 -0
  361. package/src/types/domainTypes/DeployStatus.ts +23 -0
  362. package/src/types/domainTypes/Layout.ts +34 -0
  363. package/src/types/domainTypes/Posts.ts +34 -0
  364. package/src/types/domainTypes/Search.ts +299 -0
  365. package/src/types/domainTypes/Site.ts +8 -0
  366. package/src/types/domainTypes/StaticViz.ts +64 -0
  367. package/src/types/domainTypes/Toc.ts +11 -0
  368. package/src/types/domainTypes/Tombstone.ts +19 -0
  369. package/src/types/domainTypes/Various.ts +79 -0
  370. package/src/types/gdocTypes/Gdoc.ts +280 -0
  371. package/src/types/grapherTypes/BinningStrategyTypes.ts +46 -0
  372. package/src/types/grapherTypes/GrapherConstants.ts +53 -0
  373. package/src/types/grapherTypes/GrapherTypes.ts +743 -0
  374. package/src/types/index.ts +316 -0
  375. package/src/types/wordpressTypes/WordpressTypes.ts +9 -0
  376. package/src/utils/Bounds.ts +439 -0
  377. package/src/utils/BrowserUtils.ts +12 -0
  378. package/src/utils/FuzzySearch.ts +74 -0
  379. package/src/utils/MultiDimDataPageConfig.ts +31 -0
  380. package/src/utils/OwidVariable.ts +82 -0
  381. package/src/utils/PointVector.ts +97 -0
  382. package/src/utils/PromiseCache.ts +36 -0
  383. package/src/utils/PromiseSwitcher.ts +52 -0
  384. package/src/utils/TimeBounds.ts +130 -0
  385. package/src/utils/Tippy.tsx +57 -0
  386. package/src/utils/Util.ts +2369 -0
  387. package/src/utils/archival/archivalDate.ts +48 -0
  388. package/src/utils/dayjs.ts +32 -0
  389. package/src/utils/formatValue.ts +242 -0
  390. package/src/utils/grapherConfigUtils.ts +81 -0
  391. package/src/utils/image.ts +225 -0
  392. package/src/utils/index.ts +318 -0
  393. package/src/utils/isPresent.ts +5 -0
  394. package/src/utils/metadataHelpers.ts +329 -0
  395. package/src/utils/persistable/Persistable.ts +82 -0
  396. package/src/utils/persistable/readme.md +50 -0
  397. package/src/utils/regions.json +5635 -0
  398. package/src/utils/regions.ts +463 -0
  399. package/src/utils/serializers.ts +16 -0
  400. package/src/utils/string.ts +42 -0
  401. package/src/utils/urls/Url.ts +195 -0
  402. package/src/utils/urls/UrlMigration.ts +10 -0
  403. package/src/utils/urls/UrlUtils.ts +54 -0
  404. package/src/utils/urls/readme.md +90 -0
@@ -0,0 +1,252 @@
1
+ @import "dropdown-icons";
2
+
3
+ $grapher-dropdown-hover-fill: $gray-10;
4
+ $grapher-dropdown-active-fill: $blue-20;
5
+ $grapher-dropdown-selected-fill: #c7ced7;
6
+
7
+ .grapher-dropdown {
8
+ position: relative;
9
+ font: 400 13px/16px $sans-serif-font-stack;
10
+
11
+ // fixes a bug in Firefox where long labels would cause the dropdown to resize,
12
+ // see https://github.com/JedWatson/react-select/issues/5170
13
+ display: grid;
14
+ grid-template-columns: minmax(0, 1fr);
15
+
16
+ .clear-indicator {
17
+ padding-right: 10px;
18
+ position: absolute;
19
+ right: 29px; // Leave space for the dropdown caret
20
+ top: 50%;
21
+ transform: translateY(-50%);
22
+ cursor: pointer;
23
+ border-right: 1px solid #dadada;
24
+ background: none;
25
+ display: flex;
26
+ align-items: center;
27
+ z-index: 1;
28
+ height: calc(100% - 12px);
29
+
30
+ &::after {
31
+ content: " ";
32
+ background: url($clear) no-repeat center;
33
+ width: 12px;
34
+ height: 12px;
35
+ }
36
+
37
+ &:hover::after {
38
+ background-image: url($clear-hover);
39
+ }
40
+ }
41
+
42
+ .control {
43
+ min-height: auto;
44
+ font: 400 13px/16px $sans-serif-font-stack;
45
+ letter-spacing: 0.01em;
46
+ text-align: left;
47
+ display: flex;
48
+ align-items: center;
49
+ border: 1px solid $gray-20;
50
+ border-radius: 4px;
51
+ padding: 7px;
52
+ color: $gray-90;
53
+ background: white;
54
+ cursor: pointer;
55
+ position: relative;
56
+ width: 100%;
57
+
58
+ &:focus-visible {
59
+ // Override global focus-visible style.
60
+ outline: 1px solid $blue-30;
61
+ outline-offset: -1px;
62
+ }
63
+
64
+ &:hover {
65
+ background: $grapher-dropdown-hover-fill;
66
+ }
67
+
68
+ &[data-disabled] {
69
+ opacity: 0.75;
70
+ cursor: default;
71
+ background: $gray-10;
72
+ }
73
+
74
+ &:after {
75
+ content: " ";
76
+ background: url($menu-caret-down) no-repeat center;
77
+ width: 16px;
78
+ height: 16px;
79
+ margin-left: auto;
80
+ }
81
+
82
+ &.loading:after {
83
+ opacity: 0.5;
84
+ }
85
+
86
+ &[data-pressed] {
87
+ border-color: $blue-30;
88
+ &:after {
89
+ background: url($menu-caret-up) no-repeat center;
90
+ }
91
+ }
92
+
93
+ .label {
94
+ color: $gray-70;
95
+
96
+ svg {
97
+ margin-left: 1px;
98
+ margin-right: 5px;
99
+ }
100
+ }
101
+ }
102
+
103
+ .select-value {
104
+ overflow: hidden;
105
+ text-overflow: ellipsis;
106
+ white-space: nowrap;
107
+ width: 100%;
108
+
109
+ &[data-placeholder] {
110
+ color: $gray-60;
111
+ white-space: nowrap;
112
+ }
113
+ }
114
+ }
115
+
116
+ .grapher-dropdown-listbox {
117
+ max-height: 400px;
118
+ overflow-y: auto;
119
+
120
+ &:focus-visible {
121
+ // Override global focus-visible style.
122
+ outline: none;
123
+ }
124
+ }
125
+
126
+ .grapher-dropdown-menu {
127
+ $option-checkmark: "data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iMTIiIGhlaWdodD0iOSIgdmlld0JveD0iMCAwIDEyIDkiIGZpbGw9Im5vbmUiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyI+CjxwYXRoIGQ9Ik0xMS4wMTU2IDAuOTg0Mzc1QzExLjMyMDMgMS4yNjU2MiAxMS4zMjAzIDEuNzU3ODEgMTEuMDE1NiAyLjAzOTA2TDUuMDE1NjIgOC4wMzkwNkM0LjczNDM4IDguMzQzNzUgNC4yNDIxOSA4LjM0Mzc1IDMuOTYwOTQgOC4wMzkwNkwwLjk2MDkzOCA1LjAzOTA2QzAuNjU2MjUgNC43NTc4MSAwLjY1NjI1IDQuMjY1NjIgMC45NjA5MzggMy45ODQzOEMxLjI0MjE5IDMuNjc5NjkgMS43MzQzOCAzLjY3OTY5IDIuMDE1NjIgMy45ODQzOEw0LjQ3NjU2IDYuNDQ1MzFMOS45NjA5NCAwLjk4NDM3NUMxMC4yNDIyIDAuNjc5Njg4IDEwLjczNDQgMC42Nzk2ODggMTEuMDE1NiAwLjk4NDM3NVoiIGZpbGw9IiMxRDNENjMiLz4KPC9zdmc+";
128
+ $option-checkmark-width: 12px;
129
+ font: 400 13px/16px $sans-serif-font-stack;
130
+
131
+ margin-top: 3px;
132
+ border-radius: 4px;
133
+ background: white;
134
+ box-shadow: 0px 4px 40px 0px rgba(0, 0, 0, 0.15);
135
+ z-index: $zindex-controls-popup;
136
+ color: $gray-90;
137
+ width: var(--trigger-width);
138
+ overflow-y: hidden;
139
+
140
+ .group-heading {
141
+ @include grapher_h5-black-caps;
142
+ font-size: 11px;
143
+ color: $light-text;
144
+ margin: 12px 8px 2px 8px;
145
+ font-weight: 700;
146
+ }
147
+
148
+ .group + .group .group-heading {
149
+ margin-top: 8px;
150
+ padding: 12px 0 2px 0;
151
+ border-top: 1px solid #f2f2f2;
152
+ }
153
+
154
+ .option {
155
+ padding: 10px calc(16px + $option-checkmark-width + 2px) 10px 16px;
156
+ cursor: pointer;
157
+
158
+ &[data-hovered],
159
+ &[data-focused] {
160
+ background: $grapher-dropdown-hover-fill;
161
+ }
162
+
163
+ &:focus-visible {
164
+ // Override global focus-visible style.
165
+ outline: none !important;
166
+ }
167
+
168
+ &[data-pressed] {
169
+ color: $active-text;
170
+ background: $grapher-dropdown-active-fill;
171
+ }
172
+
173
+ &[data-selected] {
174
+ position: relative;
175
+ color: $active-text;
176
+ background: $grapher-dropdown-active-fill;
177
+
178
+ &:hover {
179
+ background: $grapher-dropdown-selected-fill;
180
+ }
181
+
182
+ &:after {
183
+ content: " ";
184
+ background: url($option-checkmark) no-repeat;
185
+ width: $option-checkmark-width;
186
+ height: 9px;
187
+ position: absolute;
188
+ right: 18px;
189
+ top: 50%;
190
+ transform: translateY(-50%);
191
+ }
192
+ }
193
+
194
+ .detail {
195
+ color: $gray-70;
196
+ }
197
+
198
+ &[data-selected] .detail {
199
+ color: $blue-60;
200
+ }
201
+ }
202
+ }
203
+
204
+ .grapher-dropdown-search {
205
+ display: flex;
206
+ align-items: center;
207
+ margin: 4px;
208
+ border: 1px solid $gray-20;
209
+ border-radius: 4px;
210
+ height: 32px;
211
+ }
212
+
213
+ .grapher-dropdown-search-input {
214
+ flex: 1;
215
+ min-width: 0;
216
+ border: none;
217
+ outline: 0;
218
+ font: 400 13px/16px $sans-serif-font-stack;
219
+ color: $dark-text;
220
+ background: white;
221
+ padding: 4px 6px;
222
+
223
+ &:focus-visible {
224
+ // Override global focus-visible style.
225
+ outline: none;
226
+ }
227
+ }
228
+
229
+ .grapher-dropdown-search-icon {
230
+ $magnifying-glass: "data:image/svg+xml;base64,PHN2ZwogICAgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIgogICAgdmlld0JveD0iMCAwIDUxMiA1MTIiCj4KICA8cGF0aAogICAgZD0iTTQxNiAyMDhjMCA0NS45LTE0LjkgODguMy00MCAxMjIuN0w1MDIuNiA0NTcuNGMxMi41IDEyLjUgMTIuNSAzMi44IDAgNDUuM3MtMzIuOCAxMi41LTQ1LjMgMEwzMzAuNyAzNzZjLTM0LjQgMjUuMi03Ni44IDQwLTEyMi43IDQwQzkzLjEgNDE2IDAgMzIyLjkgMCAyMDhTOTMuMSAwIDIwOCAwUzQxNiA5My4xIDQxNiAyMDh6TTIwOCAzNTJhMTQ0IDE0NCAwIDEgMCAwLTI4OCAxNDQgMTQ0IDAgMSAwIDAgMjg4eiIKICAgIGZpbGw9IiM4NTg1ODUiCiAgLz4KPC9zdmc+Cg==";
231
+ margin-left: 8px;
232
+ width: 12px;
233
+ height: 12px;
234
+ background: url($magnifying-glass) no-repeat center;
235
+ }
236
+
237
+ .grapher-dropdown-search-reset {
238
+ margin-right: 8px;
239
+ border: none;
240
+ background: none;
241
+ padding: 0;
242
+ cursor: pointer;
243
+ color: $gray-60;
244
+
245
+ &:hover {
246
+ color: $dark-text;
247
+ }
248
+ }
249
+
250
+ .grapher-dropdown-search[data-empty] .grapher-dropdown-search-reset {
251
+ visibility: hidden;
252
+ }
@@ -0,0 +1,235 @@
1
+ import cx from "classnames"
2
+ import * as React from "react"
3
+ import { useMemo } from "react"
4
+ import {
5
+ Autocomplete,
6
+ Button,
7
+ Header,
8
+ Input,
9
+ Key,
10
+ ListBox,
11
+ ListBoxItem,
12
+ ListBoxSection,
13
+ Popover,
14
+ SearchField,
15
+ Select,
16
+ SelectValue,
17
+ useFilter,
18
+ } from "react-aria-components"
19
+ import { faTimesCircle } from "@fortawesome/free-solid-svg-icons"
20
+ import { FontAwesomeIcon } from "@fortawesome/react-fontawesome"
21
+ import { isTouchDevice } from "../../utils/index.js"
22
+
23
+ export interface BasicDropdownOption {
24
+ trackNote?: string
25
+ value: string
26
+ label: React.ReactNode
27
+ }
28
+
29
+ export interface DropdownOptionGroup<
30
+ DropdownOption extends BasicDropdownOption,
31
+ > {
32
+ label: React.ReactNode
33
+ options: DropdownOption[]
34
+ }
35
+
36
+ export type DropdownCollectionItem<DropdownOption extends BasicDropdownOption> =
37
+ DropdownOption | DropdownOptionGroup<DropdownOption>
38
+
39
+ export type DropdownCollection<DropdownOption extends BasicDropdownOption> =
40
+ DropdownCollectionItem<DropdownOption>[]
41
+
42
+ export interface DropdownProps<DropdownOption extends BasicDropdownOption> {
43
+ className?: string
44
+ menuClassName?: string
45
+ options: DropdownCollection<DropdownOption>
46
+ value?: DropdownOption | null
47
+ inputValue?: string
48
+ onChange?: (option: DropdownOption | null) => void
49
+ onInputChange?: (value: string) => void
50
+ placeholder?: string
51
+ isDisabled?: boolean
52
+ isClearable?: boolean
53
+ isLoading?: boolean
54
+ isSearchable?: boolean
55
+ renderTriggerValue?: (
56
+ option: DropdownOption | null
57
+ ) => React.ReactNode | undefined
58
+ renderMenuOption?: (option: DropdownOption) => React.ReactNode
59
+ portalContainer?: HTMLElement
60
+ "data-track-note"?: string
61
+ "aria-label"?: string
62
+ }
63
+
64
+ function isOptionGroup<DropdownOption extends BasicDropdownOption>(
65
+ item: DropdownCollectionItem<DropdownOption>
66
+ ): item is DropdownOptionGroup<DropdownOption> {
67
+ return (item as DropdownOptionGroup<DropdownOption>).options !== undefined
68
+ }
69
+
70
+ function flattenOptions<DropdownOption extends BasicDropdownOption>(
71
+ options: DropdownCollection<DropdownOption>
72
+ ): DropdownOption[] {
73
+ return options.flatMap((item) =>
74
+ isOptionGroup(item) ? item.options : [item]
75
+ )
76
+ }
77
+
78
+ export function Dropdown<DropdownOption extends BasicDropdownOption>({
79
+ className,
80
+ // We use a separate prop for the menu's className because the Popover
81
+ // (menu) doesn't render as a child of the select, so it's not trivial to
82
+ // style it using the main className.
83
+ menuClassName,
84
+ options,
85
+ value,
86
+ inputValue,
87
+ onChange,
88
+ onInputChange,
89
+ placeholder,
90
+ isDisabled,
91
+ isClearable,
92
+ isLoading,
93
+ isSearchable,
94
+ renderTriggerValue,
95
+ renderMenuOption,
96
+ portalContainer,
97
+ ...otherProps
98
+ }: DropdownProps<DropdownOption>): React.ReactElement {
99
+ const { contains } = useFilter({ sensitivity: "base" })
100
+ const flatOptions = useMemo(() => flattenOptions(options), [options])
101
+ const selectedValue = value ?? null
102
+
103
+ function handleSelectionChange(key: Key | null): void {
104
+ if (key === null) {
105
+ onChange?.(null)
106
+ return
107
+ }
108
+
109
+ if (typeof key === "number") return
110
+ const selected = flatOptions.find((option) => option.value === key)
111
+ if (selected) {
112
+ onChange?.(selected)
113
+ }
114
+ }
115
+
116
+ const listBox = (
117
+ <ListBox className="grapher-dropdown-listbox">
118
+ {options.map((item, index) =>
119
+ isOptionGroup(item) ? (
120
+ <ListBoxSection
121
+ key={`section-${index}`}
122
+ id={`section-${index}`}
123
+ className="group"
124
+ >
125
+ <Header className="group-heading">{item.label}</Header>
126
+ {item.options.map((option) => (
127
+ <ListBoxItem
128
+ className="option"
129
+ key={option.value}
130
+ id={option.value}
131
+ textValue={
132
+ typeof option.label === "string"
133
+ ? option.label
134
+ : String(option.value)
135
+ }
136
+ data-track-note={option.trackNote}
137
+ >
138
+ {renderMenuOption
139
+ ? renderMenuOption(option)
140
+ : option.label}
141
+ </ListBoxItem>
142
+ ))}
143
+ </ListBoxSection>
144
+ ) : (
145
+ <ListBoxItem
146
+ className="option"
147
+ key={item.value}
148
+ id={item.value}
149
+ textValue={
150
+ typeof item.label === "string"
151
+ ? item.label
152
+ : String(item.value)
153
+ }
154
+ data-track-note={item.trackNote}
155
+ >
156
+ {renderMenuOption ? renderMenuOption(item) : item.label}
157
+ </ListBoxItem>
158
+ )
159
+ )}
160
+ </ListBox>
161
+ )
162
+
163
+ return (
164
+ <Select
165
+ className={cx("grapher-dropdown", className)}
166
+ // null means no selection, undefined means the component is
167
+ // uncontrolled, so we need to set it explicitly.
168
+ selectedKey={value?.value ?? null}
169
+ onSelectionChange={handleSelectionChange}
170
+ placeholder={placeholder}
171
+ isDisabled={isDisabled}
172
+ {...otherProps}
173
+ >
174
+ <Button
175
+ className={cx("control", {
176
+ loading: isLoading,
177
+ })}
178
+ >
179
+ <SelectValue className="select-value">
180
+ {({ selectedItems, defaultChildren }) => {
181
+ if (renderTriggerValue && selectedItems.length === 1) {
182
+ return renderTriggerValue(selectedValue)
183
+ }
184
+ return defaultChildren
185
+ }}
186
+ </SelectValue>
187
+ </Button>
188
+ {isClearable && value && (
189
+ <Button
190
+ className="clear-indicator"
191
+ slot={null}
192
+ type="button"
193
+ onPress={() => onChange?.(null)}
194
+ aria-label="Clear selection"
195
+ />
196
+ )}
197
+ <Popover
198
+ className={cx("grapher-dropdown-menu", menuClassName)}
199
+ offset={4}
200
+ UNSTABLE_portalContainer={portalContainer}
201
+ >
202
+ {isSearchable ? (
203
+ // If inputValue is provided, the component is controlled
204
+ // and we expect the filtering to happen outside of it.
205
+ <Autocomplete filter={inputValue ? undefined : contains}>
206
+ <SearchField
207
+ className="grapher-dropdown-search"
208
+ aria-label="Search"
209
+ autoFocus
210
+ value={inputValue}
211
+ onChange={onInputChange}
212
+ >
213
+ <span className="grapher-dropdown-search-icon" />
214
+ <Input
215
+ className="grapher-dropdown-search-input"
216
+ style={{
217
+ fontSize: isTouchDevice() ? 16 : undefined,
218
+ }}
219
+ />
220
+ <Button className="grapher-dropdown-search-reset">
221
+ <FontAwesomeIcon
222
+ icon={faTimesCircle}
223
+ aria-hidden
224
+ />
225
+ </Button>
226
+ </SearchField>
227
+ {listBox}
228
+ </Autocomplete>
229
+ ) : (
230
+ listBox
231
+ )}
232
+ </Popover>
233
+ </Select>
234
+ )
235
+ }
@@ -0,0 +1,135 @@
1
+ import * as React from "react"
2
+ import { action, computed, makeObservable } from "mobx"
3
+ import { observer } from "mobx-react"
4
+ import { FontAwesomeIcon } from "@fortawesome/react-fontawesome"
5
+ import { faEye, faRightLeft, faPen } from "@fortawesome/free-solid-svg-icons"
6
+ import classnames from "classnames"
7
+ import { GrapherWindowType } from "../../types/index.js"
8
+
9
+ export interface EntitySelectionManager {
10
+ canHighlightEntities?: boolean
11
+ canChangeEntity?: boolean
12
+ canAddEntities?: boolean
13
+ canChangeAddOrHighlightEntities?: boolean
14
+ entityType?: string
15
+ entityTypePlural?: string
16
+ isEntitySelectorModalOrDrawerOpen?: boolean
17
+ isOnChartTab?: boolean
18
+ isOnMapTab?: boolean
19
+ hideEntityControls?: boolean
20
+ shouldShowEntitySelectorAs?: GrapherWindowType
21
+ }
22
+
23
+ interface EntitySelectionLabel {
24
+ icon: React.ReactElement
25
+ action: string
26
+ entity: string
27
+ }
28
+
29
+ @observer
30
+ export class EntitySelectionToggle extends React.Component<{
31
+ manager: EntitySelectionManager
32
+ }> {
33
+ constructor(props: { manager: EntitySelectionManager }) {
34
+ super(props)
35
+ makeObservable(this)
36
+ }
37
+
38
+ static shouldShow(manager: EntitySelectionManager): boolean {
39
+ const toggle = new EntitySelectionToggle({ manager })
40
+ return toggle.showToggle
41
+ }
42
+
43
+ @computed get showToggle(): boolean {
44
+ const {
45
+ isOnChartTab,
46
+ isOnMapTab,
47
+ hideEntityControls,
48
+ shouldShowEntitySelectorAs,
49
+ canChangeAddOrHighlightEntities,
50
+ } = this.props.manager
51
+
52
+ if (hideEntityControls) return false
53
+
54
+ const shouldShowDrawer =
55
+ shouldShowEntitySelectorAs === GrapherWindowType.drawer
56
+ const shouldShowModal =
57
+ shouldShowEntitySelectorAs === GrapherWindowType.modal
58
+
59
+ if (isOnMapTab) return shouldShowDrawer
60
+
61
+ return !!(
62
+ isOnChartTab &&
63
+ canChangeAddOrHighlightEntities &&
64
+ (shouldShowModal || shouldShowDrawer) &&
65
+ this.label
66
+ )
67
+ }
68
+
69
+ @computed get label(): EntitySelectionLabel | null {
70
+ const {
71
+ entityType = "",
72
+ entityTypePlural = "",
73
+ canHighlightEntities,
74
+ canChangeEntity,
75
+ canAddEntities,
76
+ isOnMapTab,
77
+ } = this.props.manager
78
+
79
+ if (isOnMapTab)
80
+ return {
81
+ action: "Select",
82
+ entity: "countries",
83
+ icon: <FontAwesomeIcon icon={faPen} />,
84
+ }
85
+
86
+ if (canHighlightEntities)
87
+ return {
88
+ action: "Select",
89
+ entity: entityTypePlural,
90
+ icon: <FontAwesomeIcon icon={faEye} />,
91
+ }
92
+
93
+ if (canChangeEntity)
94
+ return {
95
+ action: "Change",
96
+ entity: entityType,
97
+ icon: <FontAwesomeIcon icon={faRightLeft} />,
98
+ }
99
+
100
+ if (canAddEntities)
101
+ return {
102
+ action: "Edit",
103
+ entity: entityTypePlural,
104
+ icon: <FontAwesomeIcon icon={faPen} />,
105
+ }
106
+
107
+ return null
108
+ }
109
+
110
+ override render(): React.ReactElement | null {
111
+ const { showToggle, label } = this
112
+ const { isEntitySelectorModalOrDrawerOpen: active } = this.props.manager
113
+
114
+ return showToggle && label ? (
115
+ <div className="entity-selection-menu">
116
+ <button
117
+ className={classnames("menu-toggle", { active })}
118
+ onClick={action((e): void => {
119
+ this.props.manager.isEntitySelectorModalOrDrawerOpen =
120
+ !active
121
+ e.stopPropagation()
122
+ })}
123
+ type="button"
124
+ data-track-note="chart_add_entity"
125
+ aria-label={`${label.action} ${label.entity}`}
126
+ >
127
+ {label.icon}
128
+ <label>
129
+ {label.action} <span>{label.entity}</span>
130
+ </label>
131
+ </button>
132
+ </div>
133
+ ) : null
134
+ }
135
+ }
@@ -0,0 +1,3 @@
1
+ .map-region-dropdown {
2
+ flex: 0 1 155px;
3
+ }