@sis-cc/dotstatsuite-components 22.5.0 → 23.0.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 (477) hide show
  1. package/dist/_virtual/index.js +4 -5
  2. package/dist/_virtual/index.js.map +1 -1
  3. package/dist/_virtual/index2.js +4 -5
  4. package/dist/_virtual/index2.js.map +1 -1
  5. package/dist/_virtual/index3.js +4 -4
  6. package/dist/_virtual/index4.js +2 -6
  7. package/dist/_virtual/index4.js.map +1 -1
  8. package/dist/_virtual/index5.js +3 -5
  9. package/dist/_virtual/index5.js.map +1 -1
  10. package/dist/_virtual/index6.js +2 -6
  11. package/dist/_virtual/index6.js.map +1 -1
  12. package/dist/_virtual/index7.js +2 -6
  13. package/dist/_virtual/index7.js.map +1 -1
  14. package/dist/bridge-d3-react/src/index.js +1 -2
  15. package/dist/bridge-d3-react/src/index.js.map +1 -1
  16. package/dist/node_modules/@mui/styles/StylesProvider/StylesProvider.js +1 -1
  17. package/dist/node_modules/@mui/system/colorManipulator.js +2 -2
  18. package/dist/node_modules/@mui/system/esm/responsivePropType.js +1 -1
  19. package/dist/node_modules/@mui/utils/esm/getDisplayName/getDisplayName.js +1 -1
  20. package/dist/node_modules/@mui/utils/node_modules/react-is/index.js +1 -1
  21. package/dist/node_modules/date-fns/esm/_lib/defaultOptions/index.js +7 -0
  22. package/dist/node_modules/date-fns/esm/_lib/defaultOptions/index.js.map +1 -0
  23. package/dist/node_modules/date-fns/esm/_lib/isSameUTCWeek/index.js +12 -0
  24. package/dist/node_modules/date-fns/esm/_lib/isSameUTCWeek/index.js.map +1 -0
  25. package/dist/node_modules/date-fns/esm/_lib/requiredArgs/index.js +8 -0
  26. package/dist/node_modules/date-fns/esm/_lib/requiredArgs/index.js.map +1 -0
  27. package/dist/node_modules/date-fns/esm/_lib/startOfUTCWeek/index.js +25 -0
  28. package/dist/node_modules/date-fns/esm/_lib/startOfUTCWeek/index.js.map +1 -0
  29. package/dist/node_modules/date-fns/esm/_lib/toInteger/index.js +13 -0
  30. package/dist/node_modules/date-fns/esm/_lib/toInteger/index.js.map +1 -0
  31. package/dist/node_modules/date-fns/esm/getISOWeek/index.js +39 -0
  32. package/dist/node_modules/date-fns/esm/getISOWeek/index.js.map +1 -0
  33. package/dist/node_modules/date-fns/esm/getISOWeekYear/index.js +47 -0
  34. package/dist/node_modules/date-fns/esm/getISOWeekYear/index.js.map +1 -0
  35. package/dist/node_modules/date-fns/esm/getTime/index.js +29 -0
  36. package/dist/node_modules/date-fns/esm/getTime/index.js.map +1 -0
  37. package/dist/node_modules/date-fns/esm/isFriday/index.js +27 -0
  38. package/dist/node_modules/date-fns/esm/isFriday/index.js.map +1 -0
  39. package/dist/node_modules/date-fns/esm/isMonday/index.js +27 -0
  40. package/dist/node_modules/date-fns/esm/isMonday/index.js.map +1 -0
  41. package/dist/node_modules/date-fns/esm/isSaturday/index.js +27 -0
  42. package/dist/node_modules/date-fns/esm/isSaturday/index.js.map +1 -0
  43. package/dist/node_modules/date-fns/esm/isSunday/index.js +27 -0
  44. package/dist/node_modules/date-fns/esm/isSunday/index.js.map +1 -0
  45. package/dist/node_modules/date-fns/esm/isThursday/index.js +27 -0
  46. package/dist/node_modules/date-fns/esm/isThursday/index.js.map +1 -0
  47. package/dist/node_modules/date-fns/esm/isTuesday/index.js +27 -0
  48. package/dist/node_modules/date-fns/esm/isTuesday/index.js.map +1 -0
  49. package/dist/node_modules/date-fns/esm/isWednesday/index.js +27 -0
  50. package/dist/node_modules/date-fns/esm/isWednesday/index.js.map +1 -0
  51. package/dist/node_modules/date-fns/esm/locale/_lib/buildFormatLongFn/index.js +12 -0
  52. package/dist/node_modules/date-fns/esm/locale/_lib/buildFormatLongFn/index.js.map +1 -0
  53. package/dist/node_modules/date-fns/esm/locale/_lib/buildLocalizeFn/index.js +21 -0
  54. package/dist/node_modules/date-fns/esm/locale/_lib/buildLocalizeFn/index.js.map +1 -0
  55. package/dist/node_modules/date-fns/esm/locale/_lib/buildMatchFn/index.js +45 -0
  56. package/dist/node_modules/date-fns/esm/locale/_lib/buildMatchFn/index.js.map +1 -0
  57. package/dist/node_modules/date-fns/esm/locale/_lib/buildMatchPatternFn/index.js +20 -0
  58. package/dist/node_modules/date-fns/esm/locale/_lib/buildMatchPatternFn/index.js.map +1 -0
  59. package/dist/node_modules/date-fns/esm/locale/ar/_lib/formatDistance/index.js +119 -0
  60. package/dist/node_modules/date-fns/esm/locale/ar/_lib/formatDistance/index.js.map +1 -0
  61. package/dist/node_modules/date-fns/esm/locale/ar/_lib/formatLong/index.js +37 -0
  62. package/dist/node_modules/date-fns/esm/locale/ar/_lib/formatLong/index.js.map +1 -0
  63. package/dist/node_modules/date-fns/esm/locale/ar/_lib/formatRelative/index.js +14 -0
  64. package/dist/node_modules/date-fns/esm/locale/ar/_lib/formatRelative/index.js.map +1 -0
  65. package/dist/node_modules/date-fns/esm/locale/ar/_lib/localize/index.js +121 -0
  66. package/dist/node_modules/date-fns/esm/locale/ar/_lib/localize/index.js.map +1 -0
  67. package/dist/node_modules/date-fns/esm/locale/ar/_lib/match/index.js +102 -0
  68. package/dist/node_modules/date-fns/esm/locale/ar/_lib/match/index.js.map +1 -0
  69. package/dist/node_modules/date-fns/esm/locale/ar/index.js +30 -0
  70. package/dist/node_modules/date-fns/esm/locale/ar/index.js.map +1 -0
  71. package/dist/node_modules/date-fns/esm/locale/de/_lib/formatDistance/index.js +178 -0
  72. package/dist/node_modules/date-fns/esm/locale/de/_lib/formatDistance/index.js.map +1 -0
  73. package/dist/node_modules/date-fns/esm/locale/de/_lib/formatLong/index.js +42 -0
  74. package/dist/node_modules/date-fns/esm/locale/de/_lib/formatLong/index.js.map +1 -0
  75. package/dist/node_modules/date-fns/esm/locale/de/_lib/formatRelative/index.js +14 -0
  76. package/dist/node_modules/date-fns/esm/locale/de/_lib/formatRelative/index.js.map +1 -0
  77. package/dist/node_modules/date-fns/esm/locale/de/_lib/localize/index.js +137 -0
  78. package/dist/node_modules/date-fns/esm/locale/de/_lib/localize/index.js.map +1 -0
  79. package/dist/node_modules/date-fns/esm/locale/de/_lib/match/index.js +103 -0
  80. package/dist/node_modules/date-fns/esm/locale/de/_lib/match/index.js.map +1 -0
  81. package/dist/node_modules/date-fns/esm/locale/de/index.js +33 -0
  82. package/dist/node_modules/date-fns/esm/locale/de/index.js.map +1 -0
  83. package/dist/node_modules/date-fns/esm/locale/en-US/_lib/formatDistance/index.js +85 -0
  84. package/dist/node_modules/date-fns/esm/locale/en-US/_lib/formatDistance/index.js.map +1 -0
  85. package/dist/node_modules/date-fns/esm/locale/en-US/_lib/formatLong/index.js +37 -0
  86. package/dist/node_modules/date-fns/esm/locale/en-US/_lib/formatLong/index.js.map +1 -0
  87. package/dist/node_modules/date-fns/esm/locale/en-US/_lib/formatRelative/index.js +14 -0
  88. package/dist/node_modules/date-fns/esm/locale/en-US/_lib/formatRelative/index.js.map +1 -0
  89. package/dist/node_modules/date-fns/esm/locale/en-US/_lib/localize/index.js +146 -0
  90. package/dist/node_modules/date-fns/esm/locale/en-US/_lib/localize/index.js.map +1 -0
  91. package/dist/node_modules/date-fns/esm/locale/en-US/_lib/match/index.js +101 -0
  92. package/dist/node_modules/date-fns/esm/locale/en-US/_lib/match/index.js.map +1 -0
  93. package/dist/node_modules/date-fns/esm/locale/en-US/index.js +30 -0
  94. package/dist/node_modules/date-fns/esm/locale/en-US/index.js.map +1 -0
  95. package/dist/node_modules/date-fns/esm/locale/es/_lib/formatDistance/index.js +85 -0
  96. package/dist/node_modules/date-fns/esm/locale/es/_lib/formatDistance/index.js.map +1 -0
  97. package/dist/node_modules/date-fns/esm/locale/es/_lib/formatLong/index.js +37 -0
  98. package/dist/node_modules/date-fns/esm/locale/es/_lib/formatLong/index.js.map +1 -0
  99. package/dist/node_modules/date-fns/esm/locale/es/_lib/formatRelative/index.js +26 -0
  100. package/dist/node_modules/date-fns/esm/locale/es/_lib/formatRelative/index.js.map +1 -0
  101. package/dist/node_modules/date-fns/esm/locale/es/_lib/localize/index.js +122 -0
  102. package/dist/node_modules/date-fns/esm/locale/es/_lib/localize/index.js.map +1 -0
  103. package/dist/node_modules/date-fns/esm/locale/es/_lib/match/index.js +102 -0
  104. package/dist/node_modules/date-fns/esm/locale/es/_lib/match/index.js.map +1 -0
  105. package/dist/node_modules/date-fns/esm/locale/es/index.js +33 -0
  106. package/dist/node_modules/date-fns/esm/locale/es/index.js.map +1 -0
  107. package/dist/node_modules/date-fns/esm/locale/fr/_lib/formatDistance/index.js +85 -0
  108. package/dist/node_modules/date-fns/esm/locale/fr/_lib/formatDistance/index.js.map +1 -0
  109. package/dist/node_modules/date-fns/esm/locale/fr/_lib/formatLong/index.js +37 -0
  110. package/dist/node_modules/date-fns/esm/locale/fr/_lib/formatLong/index.js.map +1 -0
  111. package/dist/node_modules/date-fns/esm/locale/fr/_lib/formatRelative/index.js +14 -0
  112. package/dist/node_modules/date-fns/esm/locale/fr/_lib/formatRelative/index.js.map +1 -0
  113. package/dist/node_modules/date-fns/esm/locale/fr/_lib/localize/index.js +97 -0
  114. package/dist/node_modules/date-fns/esm/locale/fr/_lib/localize/index.js.map +1 -0
  115. package/dist/node_modules/date-fns/esm/locale/fr/_lib/match/index.js +101 -0
  116. package/dist/node_modules/date-fns/esm/locale/fr/_lib/match/index.js.map +1 -0
  117. package/dist/node_modules/date-fns/esm/locale/fr/index.js +30 -0
  118. package/dist/node_modules/date-fns/esm/locale/fr/index.js.map +1 -0
  119. package/dist/node_modules/date-fns/esm/locale/it/_lib/formatDistance/index.js +85 -0
  120. package/dist/node_modules/date-fns/esm/locale/it/_lib/formatDistance/index.js.map +1 -0
  121. package/dist/node_modules/date-fns/esm/locale/it/_lib/formatLong/index.js +37 -0
  122. package/dist/node_modules/date-fns/esm/locale/it/_lib/formatLong/index.js.map +1 -0
  123. package/dist/node_modules/date-fns/esm/locale/it/_lib/formatRelative/index.js +54 -0
  124. package/dist/node_modules/date-fns/esm/locale/it/_lib/formatRelative/index.js.map +1 -0
  125. package/dist/node_modules/date-fns/esm/locale/it/_lib/localize/index.js +122 -0
  126. package/dist/node_modules/date-fns/esm/locale/it/_lib/localize/index.js.map +1 -0
  127. package/dist/node_modules/date-fns/esm/locale/it/_lib/match/index.js +101 -0
  128. package/dist/node_modules/date-fns/esm/locale/it/_lib/match/index.js.map +1 -0
  129. package/dist/node_modules/date-fns/esm/locale/it/index.js +31 -0
  130. package/dist/node_modules/date-fns/esm/locale/it/index.js.map +1 -0
  131. package/dist/node_modules/date-fns/esm/locale/nl/_lib/formatDistance/index.js +85 -0
  132. package/dist/node_modules/date-fns/esm/locale/nl/_lib/formatDistance/index.js.map +1 -0
  133. package/dist/node_modules/date-fns/esm/locale/nl/_lib/formatLong/index.js +37 -0
  134. package/dist/node_modules/date-fns/esm/locale/nl/_lib/formatLong/index.js.map +1 -0
  135. package/dist/node_modules/date-fns/esm/locale/nl/_lib/formatRelative/index.js +14 -0
  136. package/dist/node_modules/date-fns/esm/locale/nl/_lib/formatRelative/index.js.map +1 -0
  137. package/dist/node_modules/date-fns/esm/locale/nl/_lib/localize/index.js +88 -0
  138. package/dist/node_modules/date-fns/esm/locale/nl/_lib/localize/index.js.map +1 -0
  139. package/dist/node_modules/date-fns/esm/locale/nl/_lib/match/index.js +100 -0
  140. package/dist/node_modules/date-fns/esm/locale/nl/_lib/match/index.js.map +1 -0
  141. package/dist/node_modules/date-fns/esm/locale/nl/index.js +34 -0
  142. package/dist/node_modules/date-fns/esm/locale/nl/index.js.map +1 -0
  143. package/dist/node_modules/date-fns/esm/locale/th/_lib/formatDistance/index.js +89 -0
  144. package/dist/node_modules/date-fns/esm/locale/th/_lib/formatDistance/index.js.map +1 -0
  145. package/dist/node_modules/date-fns/esm/locale/th/_lib/formatLong/index.js +37 -0
  146. package/dist/node_modules/date-fns/esm/locale/th/_lib/formatLong/index.js.map +1 -0
  147. package/dist/node_modules/date-fns/esm/locale/th/_lib/formatRelative/index.js +14 -0
  148. package/dist/node_modules/date-fns/esm/locale/th/_lib/formatRelative/index.js.map +1 -0
  149. package/dist/node_modules/date-fns/esm/locale/th/_lib/localize/index.js +121 -0
  150. package/dist/node_modules/date-fns/esm/locale/th/_lib/localize/index.js.map +1 -0
  151. package/dist/node_modules/date-fns/esm/locale/th/_lib/match/index.js +100 -0
  152. package/dist/node_modules/date-fns/esm/locale/th/_lib/match/index.js.map +1 -0
  153. package/dist/node_modules/date-fns/esm/locale/th/index.js +31 -0
  154. package/dist/node_modules/date-fns/esm/locale/th/index.js.map +1 -0
  155. package/dist/node_modules/date-fns/esm/startOfISOWeek/index.js +32 -0
  156. package/dist/node_modules/date-fns/esm/startOfISOWeek/index.js.map +1 -0
  157. package/dist/node_modules/date-fns/esm/startOfISOWeekYear/index.js +37 -0
  158. package/dist/node_modules/date-fns/esm/startOfISOWeekYear/index.js.map +1 -0
  159. package/dist/node_modules/date-fns/esm/startOfWeek/index.js +52 -0
  160. package/dist/node_modules/date-fns/esm/startOfWeek/index.js.map +1 -0
  161. package/dist/node_modules/date-fns/esm/toDate/index.js +56 -0
  162. package/dist/node_modules/date-fns/esm/toDate/index.js.map +1 -0
  163. package/dist/node_modules/prop-types/index.js +1 -1
  164. package/dist/node_modules/react-is/index.js +1 -1
  165. package/dist/rules/src/chart/getAxisOptions.js +22 -22
  166. package/dist/rules/src/chart/getAxisOptions.js.map +1 -1
  167. package/dist/rules/src/chart/getChartOptions.js +1 -1
  168. package/dist/rules/src/chart/getChartOptions.js.map +1 -1
  169. package/dist/rules/src/constants.js +1 -35
  170. package/dist/rules/src/constants.js.map +1 -1
  171. package/dist/rules/src/date.js +40 -40
  172. package/dist/rules/src/date.js.map +1 -1
  173. package/dist/rules/src/dimension-utils.js +26 -24
  174. package/dist/rules/src/dimension-utils.js.map +1 -1
  175. package/dist/rules/src/factories/choro-series.js +43 -32
  176. package/dist/rules/src/factories/choro-series.js.map +1 -1
  177. package/dist/rules/src/factories/focus.js +20 -0
  178. package/dist/rules/src/factories/focus.js.map +1 -0
  179. package/dist/rules/src/factories/getChartSeries.js +11 -0
  180. package/dist/rules/src/factories/getChartSeries.js.map +1 -0
  181. package/dist/rules/src/factories/sample-focus.js +14 -18
  182. package/dist/rules/src/factories/sample-focus.js.map +1 -1
  183. package/dist/rules/src/factories/sample-series.js +20 -20
  184. package/dist/rules/src/factories/sample-series.js.map +1 -1
  185. package/dist/rules/src/factories/scatter-focus.js +21 -35
  186. package/dist/rules/src/factories/scatter-focus.js.map +1 -1
  187. package/dist/rules/src/factories/scatter-series.js +5 -5
  188. package/dist/rules/src/factories/scatter-series.js.map +1 -1
  189. package/dist/rules/src/factories/series.js +48 -0
  190. package/dist/rules/src/factories/series.js.map +1 -0
  191. package/dist/rules/src/factories/stacked-series.js +6 -7
  192. package/dist/rules/src/factories/stacked-series.js.map +1 -1
  193. package/dist/rules/src/factories/symbol-series.js +39 -46
  194. package/dist/rules/src/factories/symbol-series.js.map +1 -1
  195. package/dist/rules/src/factories/timeline-focus.js +10 -14
  196. package/dist/rules/src/factories/timeline-focus.js.map +1 -1
  197. package/dist/rules/src/factories/timeline-series.js +37 -41
  198. package/dist/rules/src/factories/timeline-series.js.map +1 -1
  199. package/dist/rules/src/get-values-enhanced.js +8 -2
  200. package/dist/rules/src/get-values-enhanced.js.map +1 -1
  201. package/dist/rules/src/index.js +6 -371
  202. package/dist/rules/src/index.js.map +1 -1
  203. package/dist/rules/src/layout.js +4 -2
  204. package/dist/rules/src/layout.js.map +1 -1
  205. package/dist/rules/src/observation-formater.js +8 -14
  206. package/dist/rules/src/observation-formater.js.map +1 -1
  207. package/dist/rules/src/properties/focus.js +51 -3
  208. package/dist/rules/src/properties/focus.js.map +1 -1
  209. package/dist/rules/src/properties/getHeaderProps.js +2 -53
  210. package/dist/rules/src/properties/getHeaderProps.js.map +1 -1
  211. package/dist/rules/src/properties/index.js +3 -94
  212. package/dist/rules/src/properties/index.js.map +1 -1
  213. package/dist/rules/src/properties/linear.js +4 -4
  214. package/dist/rules/src/properties/linear.js.map +1 -1
  215. package/dist/rules/src/properties/scatter.js +4 -4
  216. package/dist/rules/src/properties/scatter.js.map +1 -1
  217. package/dist/rules/src/properties/stacked.js +5 -7
  218. package/dist/rules/src/properties/stacked.js.map +1 -1
  219. package/dist/rules/src/properties/symbol.js.map +1 -1
  220. package/dist/rules/src/properties/utils.js +11 -12
  221. package/dist/rules/src/properties/utils.js.map +1 -1
  222. package/dist/rules/src/sdmx-data/index.js +2 -27
  223. package/dist/rules/src/sdmx-data/index.js.map +1 -1
  224. package/dist/rules2/src/combinedValuesDisplay.js +2 -2
  225. package/dist/rules2/src/combinedValuesDisplay.js.map +1 -1
  226. package/dist/rules2/src/getAttributes.js +37 -0
  227. package/dist/rules2/src/getAttributes.js.map +1 -0
  228. package/dist/rules2/src/getDataflowTooltipAttributesIds.js +2 -2
  229. package/dist/rules2/src/getDataflowTooltipAttributesIds.js.map +1 -1
  230. package/dist/rules2/src/getHeaderCombinations.js +1 -1
  231. package/dist/rules2/src/getHeaderCombinations.js.map +1 -1
  232. package/dist/rules2/src/getHeaderSubtitle.js +1 -1
  233. package/dist/rules2/src/getHeaderSubtitle.js.map +1 -1
  234. package/dist/rules2/src/getHeaderTitle.js +1 -1
  235. package/dist/rules2/src/getHeaderTitle.js.map +1 -1
  236. package/dist/rules2/src/getMetadataCoordinates.js +1 -1
  237. package/dist/rules2/src/getMetadataCoordinates.js.map +1 -1
  238. package/dist/rules2/src/getNotDisplayedIds.js +1 -1
  239. package/dist/rules2/src/getNotDisplayedIds.js.map +1 -1
  240. package/dist/rules2/src/index.js +1 -0
  241. package/dist/rules2/src/index.js.map +1 -1
  242. package/dist/rules2/src/parseAttributes.js +2 -2
  243. package/dist/rules2/src/parseAttributes.js.map +1 -1
  244. package/dist/rules2/src/parseHierarchicalCodelist.js +1 -1
  245. package/dist/rules2/src/parseHierarchicalCodelist.js.map +1 -1
  246. package/dist/rules2/src/parseMetadataSeries.js +1 -1
  247. package/dist/rules2/src/parseMetadataSeries.js.map +1 -1
  248. package/dist/rules2/src/prepareData.js +10 -3
  249. package/dist/rules2/src/prepareData.js.map +1 -1
  250. package/dist/rules2/src/refineDimensions.js +53 -8
  251. package/dist/rules2/src/refineDimensions.js.map +1 -1
  252. package/dist/rules2/src/refineTimePeriod.js +12 -16
  253. package/dist/rules2/src/refineTimePeriod.js.map +1 -1
  254. package/dist/rules2/src/table/getCells.js +1 -1
  255. package/dist/rules2/src/table/getCells.js.map +1 -1
  256. package/dist/rules2/src/table/getLayout.js +1 -1
  257. package/dist/rules2/src/table/getLayout.js.map +1 -1
  258. package/dist/rules2/src/table/getTableLayoutIds.js +1 -1
  259. package/dist/rules2/src/table/getTableLayoutIds.js.map +1 -1
  260. package/dist/rules2/src/table/getTableProps.js +0 -1
  261. package/dist/rules2/src/table/getTableProps.js.map +1 -1
  262. package/dist/rules2/src/table/parseValueHierarchy.js.map +1 -1
  263. package/dist/rules2/src/table/refineLayoutSize2.js +1 -1
  264. package/dist/rules2/src/table/refineLayoutSize2.js.map +1 -1
  265. package/dist/rules2/src/utils.js.map +1 -1
  266. package/dist/viewer/src/chart.js +13 -2
  267. package/dist/viewer/src/chart.js.map +1 -1
  268. package/dist/viewer/src/legends/FocusLegend.js +1 -1
  269. package/dist/viewer/src/legends/FocusLegend.js.map +1 -1
  270. package/package.json +7 -6
  271. package/src/bridge-d3-react/src/index.js +0 -1
  272. package/src/rules/src/chart/getAxisOptions.js +33 -21
  273. package/src/rules/src/chart/getChartOptions.js +2 -2
  274. package/src/rules/src/constants.js +0 -35
  275. package/src/rules/src/date.js +6 -12
  276. package/src/rules/src/dimension-utils.js +25 -23
  277. package/src/rules/src/factories/choro-series.js +41 -30
  278. package/src/rules/src/factories/focus.js +17 -0
  279. package/src/rules/src/factories/getChartSeries.js +8 -0
  280. package/src/rules/src/factories/sample-focus.js +14 -18
  281. package/src/rules/src/factories/sample-series.js +20 -20
  282. package/src/rules/src/factories/scatter-focus.js +22 -36
  283. package/src/rules/src/factories/scatter-series.js +8 -8
  284. package/src/rules/src/factories/series.js +45 -0
  285. package/src/rules/src/factories/stacked-series.js +4 -5
  286. package/src/rules/src/factories/symbol-series.js +37 -44
  287. package/src/rules/src/factories/timeline-focus.js +10 -14
  288. package/src/rules/src/factories/timeline-series.js +35 -39
  289. package/src/rules/src/get-values-enhanced.js +8 -2
  290. package/src/rules/src/index.js +7 -384
  291. package/src/rules/src/layout.js +4 -2
  292. package/src/rules/src/observation-formater.js +14 -20
  293. package/src/rules/src/properties/focus.js +50 -2
  294. package/src/rules/src/properties/getHeaderProps.js +1 -53
  295. package/src/rules/src/properties/index.js +2 -93
  296. package/src/rules/src/properties/linear.js +2 -2
  297. package/src/rules/src/properties/scatter.js +4 -4
  298. package/src/rules/src/properties/stacked.js +4 -6
  299. package/src/rules/src/properties/symbol.js +0 -1
  300. package/src/rules/src/properties/utils.js +11 -22
  301. package/src/rules/src/sdmx-data/index.js +2 -31
  302. package/src/rules2/src/combinedValuesDisplay.js +2 -2
  303. package/src/rules2/src/getAttributes.js +34 -0
  304. package/src/rules2/src/getDataflowTooltipAttributesIds.js +2 -2
  305. package/src/rules2/src/getHeaderCombinations.js +1 -1
  306. package/src/rules2/src/getHeaderSubtitle.js +2 -2
  307. package/src/rules2/src/getHeaderTitle.js +1 -1
  308. package/src/rules2/src/getMetadataCoordinates.js +1 -1
  309. package/src/rules2/src/getNotDisplayedIds.js +1 -1
  310. package/src/rules2/src/index.js +1 -0
  311. package/src/rules2/src/parseAttributes.js +2 -2
  312. package/src/rules2/src/parseHierarchicalCodelist.js +1 -1
  313. package/src/rules2/src/parseMetadataSeries.js +1 -1
  314. package/src/rules2/src/prepareData.js +10 -3
  315. package/src/rules2/src/refineDimensions.js +53 -8
  316. package/src/rules2/src/refineTimePeriod.js +12 -16
  317. package/src/rules2/src/table/getCells.js +2 -2
  318. package/src/rules2/src/table/getLayout.js +2 -2
  319. package/src/rules2/src/table/getTableLayoutIds.js +9 -9
  320. package/src/rules2/src/table/getTableProps.js +0 -1
  321. package/src/rules2/src/table/parseValueHierarchy.js +0 -7
  322. package/src/rules2/src/table/refineLayoutSize2.js +5 -5
  323. package/src/rules2/src/utils.js +0 -11
  324. package/src/viewer/src/app/leg.js +0 -1
  325. package/src/viewer/src/chart.jsx +23 -1
  326. package/src/viewer/src/legends/FocusLegend.jsx +1 -1
  327. package/dist/_virtual/index10.js +0 -8
  328. package/dist/_virtual/index10.js.map +0 -1
  329. package/dist/_virtual/index11.js +0 -8
  330. package/dist/_virtual/index11.js.map +0 -1
  331. package/dist/_virtual/index12.js +0 -8
  332. package/dist/_virtual/index12.js.map +0 -1
  333. package/dist/_virtual/index13.js +0 -8
  334. package/dist/_virtual/index13.js.map +0 -1
  335. package/dist/_virtual/index14.js +0 -8
  336. package/dist/_virtual/index14.js.map +0 -1
  337. package/dist/_virtual/index15.js +0 -8
  338. package/dist/_virtual/index15.js.map +0 -1
  339. package/dist/_virtual/index16.js +0 -8
  340. package/dist/_virtual/index16.js.map +0 -1
  341. package/dist/_virtual/index17.js +0 -7
  342. package/dist/_virtual/index17.js.map +0 -1
  343. package/dist/_virtual/index18.js +0 -7
  344. package/dist/_virtual/index18.js.map +0 -1
  345. package/dist/_virtual/index19.js +0 -8
  346. package/dist/_virtual/index19.js.map +0 -1
  347. package/dist/_virtual/index20.js +0 -4
  348. package/dist/_virtual/index20.js.map +0 -1
  349. package/dist/_virtual/index21.js +0 -6
  350. package/dist/_virtual/index21.js.map +0 -1
  351. package/dist/_virtual/index22.js +0 -4
  352. package/dist/_virtual/index22.js.map +0 -1
  353. package/dist/_virtual/index23.js +0 -4
  354. package/dist/_virtual/index23.js.map +0 -1
  355. package/dist/_virtual/index8.js +0 -8
  356. package/dist/_virtual/index8.js.map +0 -1
  357. package/dist/_virtual/index9.js +0 -8
  358. package/dist/_virtual/index9.js.map +0 -1
  359. package/dist/node_modules/date-fns/_lib/getTimezoneOffsetInMilliseconds/index.js +0 -32
  360. package/dist/node_modules/date-fns/_lib/getTimezoneOffsetInMilliseconds/index.js.map +0 -1
  361. package/dist/node_modules/date-fns/get_iso_week/index.js +0 -49
  362. package/dist/node_modules/date-fns/get_iso_week/index.js.map +0 -1
  363. package/dist/node_modules/date-fns/get_iso_year/index.js +0 -59
  364. package/dist/node_modules/date-fns/get_iso_year/index.js.map +0 -1
  365. package/dist/node_modules/date-fns/is_date/index.js +0 -32
  366. package/dist/node_modules/date-fns/is_date/index.js.map +0 -1
  367. package/dist/node_modules/date-fns/is_friday/index.js +0 -35
  368. package/dist/node_modules/date-fns/is_friday/index.js.map +0 -1
  369. package/dist/node_modules/date-fns/is_monday/index.js +0 -35
  370. package/dist/node_modules/date-fns/is_monday/index.js.map +0 -1
  371. package/dist/node_modules/date-fns/is_saturday/index.js +0 -35
  372. package/dist/node_modules/date-fns/is_saturday/index.js.map +0 -1
  373. package/dist/node_modules/date-fns/is_sunday/index.js +0 -35
  374. package/dist/node_modules/date-fns/is_sunday/index.js.map +0 -1
  375. package/dist/node_modules/date-fns/is_thursday/index.js +0 -35
  376. package/dist/node_modules/date-fns/is_thursday/index.js.map +0 -1
  377. package/dist/node_modules/date-fns/is_tuesday/index.js +0 -35
  378. package/dist/node_modules/date-fns/is_tuesday/index.js.map +0 -1
  379. package/dist/node_modules/date-fns/is_wednesday/index.js +0 -35
  380. package/dist/node_modules/date-fns/is_wednesday/index.js.map +0 -1
  381. package/dist/node_modules/date-fns/locale/_lib/build_formatting_tokens_reg_exp/index.js +0 -39
  382. package/dist/node_modules/date-fns/locale/_lib/build_formatting_tokens_reg_exp/index.js.map +0 -1
  383. package/dist/node_modules/date-fns/locale/ar/build_distance_in_words_locale/index.js +0 -110
  384. package/dist/node_modules/date-fns/locale/ar/build_distance_in_words_locale/index.js.map +0 -1
  385. package/dist/node_modules/date-fns/locale/ar/build_format_locale/index.js +0 -86
  386. package/dist/node_modules/date-fns/locale/ar/build_format_locale/index.js.map +0 -1
  387. package/dist/node_modules/date-fns/locale/ar/index.js +0 -26
  388. package/dist/node_modules/date-fns/locale/ar/index.js.map +0 -1
  389. package/dist/node_modules/date-fns/locale/de/build_distance_in_words_locale/index.js +0 -196
  390. package/dist/node_modules/date-fns/locale/de/build_distance_in_words_locale/index.js.map +0 -1
  391. package/dist/node_modules/date-fns/locale/de/build_format_locale/index.js +0 -90
  392. package/dist/node_modules/date-fns/locale/de/build_format_locale/index.js.map +0 -1
  393. package/dist/node_modules/date-fns/locale/de/index.js +0 -27
  394. package/dist/node_modules/date-fns/locale/de/index.js.map +0 -1
  395. package/dist/node_modules/date-fns/locale/en/build_distance_in_words_locale/index.js +0 -110
  396. package/dist/node_modules/date-fns/locale/en/build_distance_in_words_locale/index.js.map +0 -1
  397. package/dist/node_modules/date-fns/locale/en/build_format_locale/index.js +0 -101
  398. package/dist/node_modules/date-fns/locale/en/build_format_locale/index.js.map +0 -1
  399. package/dist/node_modules/date-fns/locale/en/index.js +0 -25
  400. package/dist/node_modules/date-fns/locale/en/index.js.map +0 -1
  401. package/dist/node_modules/date-fns/locale/es/build_distance_in_words_locale/index.js +0 -110
  402. package/dist/node_modules/date-fns/locale/es/build_distance_in_words_locale/index.js.map +0 -1
  403. package/dist/node_modules/date-fns/locale/es/build_format_locale/index.js +0 -86
  404. package/dist/node_modules/date-fns/locale/es/build_format_locale/index.js.map +0 -1
  405. package/dist/node_modules/date-fns/locale/es/index.js +0 -28
  406. package/dist/node_modules/date-fns/locale/es/index.js.map +0 -1
  407. package/dist/node_modules/date-fns/locale/fr/build_distance_in_words_locale/index.js +0 -110
  408. package/dist/node_modules/date-fns/locale/fr/build_distance_in_words_locale/index.js.map +0 -1
  409. package/dist/node_modules/date-fns/locale/fr/build_format_locale/index.js +0 -135
  410. package/dist/node_modules/date-fns/locale/fr/build_format_locale/index.js.map +0 -1
  411. package/dist/node_modules/date-fns/locale/fr/index.js +0 -27
  412. package/dist/node_modules/date-fns/locale/fr/index.js.map +0 -1
  413. package/dist/node_modules/date-fns/locale/it/build_distance_in_words_locale/index.js +0 -110
  414. package/dist/node_modules/date-fns/locale/it/build_distance_in_words_locale/index.js.map +0 -1
  415. package/dist/node_modules/date-fns/locale/it/build_format_locale/index.js +0 -86
  416. package/dist/node_modules/date-fns/locale/it/build_format_locale/index.js.map +0 -1
  417. package/dist/node_modules/date-fns/locale/it/index.js +0 -26
  418. package/dist/node_modules/date-fns/locale/it/index.js.map +0 -1
  419. package/dist/node_modules/date-fns/locale/nl/build_distance_in_words_locale/index.js +0 -110
  420. package/dist/node_modules/date-fns/locale/nl/build_distance_in_words_locale/index.js.map +0 -1
  421. package/dist/node_modules/date-fns/locale/nl/build_format_locale/index.js +0 -86
  422. package/dist/node_modules/date-fns/locale/nl/build_format_locale/index.js.map +0 -1
  423. package/dist/node_modules/date-fns/locale/nl/index.js +0 -27
  424. package/dist/node_modules/date-fns/locale/nl/index.js.map +0 -1
  425. package/dist/node_modules/date-fns/locale/th/build_distance_in_words_locale/index.js +0 -114
  426. package/dist/node_modules/date-fns/locale/th/build_distance_in_words_locale/index.js.map +0 -1
  427. package/dist/node_modules/date-fns/locale/th/build_format_locale/index.js +0 -74
  428. package/dist/node_modules/date-fns/locale/th/build_format_locale/index.js.map +0 -1
  429. package/dist/node_modules/date-fns/locale/th/index.js +0 -26
  430. package/dist/node_modules/date-fns/locale/th/index.js.map +0 -1
  431. package/dist/node_modules/date-fns/parse/index.js +0 -346
  432. package/dist/node_modules/date-fns/parse/index.js.map +0 -1
  433. package/dist/node_modules/date-fns/start_of_iso_week/index.js +0 -38
  434. package/dist/node_modules/date-fns/start_of_iso_week/index.js.map +0 -1
  435. package/dist/node_modules/date-fns/start_of_iso_year/index.js +0 -46
  436. package/dist/node_modules/date-fns/start_of_iso_year/index.js.map +0 -1
  437. package/dist/node_modules/date-fns/start_of_week/index.js +0 -51
  438. package/dist/node_modules/date-fns/start_of_week/index.js.map +0 -1
  439. package/dist/rules/src/factories/scatter-dimension.js +0 -35
  440. package/dist/rules/src/factories/scatter-dimension.js.map +0 -1
  441. package/dist/rules/src/factories/stacked-dimension.js +0 -32
  442. package/dist/rules/src/factories/stacked-dimension.js.map +0 -1
  443. package/dist/rules/src/factories/symbol-dimension.js +0 -32
  444. package/dist/rules/src/factories/symbol-dimension.js.map +0 -1
  445. package/dist/rules/src/header/getDefaultSubtitle.js +0 -44
  446. package/dist/rules/src/header/getDefaultSubtitle.js.map +0 -1
  447. package/dist/rules/src/header/getHeaderUnits.js +0 -21
  448. package/dist/rules/src/header/getHeaderUnits.js.map +0 -1
  449. package/dist/rules/src/header/getSubtitleFlags.js +0 -47
  450. package/dist/rules/src/header/getSubtitleFlags.js.map +0 -1
  451. package/dist/rules/src/header/getTitleFlags.js +0 -12
  452. package/dist/rules/src/header/getTitleFlags.js.map +0 -1
  453. package/dist/rules/src/properties/errors.js +0 -22
  454. package/dist/rules/src/properties/errors.js.map +0 -1
  455. package/dist/rules/src/properties/getInformationsStateFromNewProps.js +0 -50
  456. package/dist/rules/src/properties/getInformationsStateFromNewProps.js.map +0 -1
  457. package/dist/rules/src/v8-transformer.js +0 -174
  458. package/dist/rules/src/v8-transformer.js.map +0 -1
  459. package/src/bridge-d3-react/src/app.js +0 -64
  460. package/src/bridge-d3-react/src/mock-choro.js +0 -394
  461. package/src/rules/src/factories/scatter-dimension.js +0 -32
  462. package/src/rules/src/factories/stacked-dimension.js +0 -29
  463. package/src/rules/src/factories/symbol-dimension.js +0 -29
  464. package/src/rules/src/header/getDefaultSubtitle.js +0 -40
  465. package/src/rules/src/header/getHeaderUnits.js +0 -17
  466. package/src/rules/src/header/getSubtitleFlags.js +0 -43
  467. package/src/rules/src/header/getTitleFlags.js +0 -8
  468. package/src/rules/src/header/index.js +0 -4
  469. package/src/rules/src/preparators/enhanceObservations.js +0 -152
  470. package/src/rules/src/properties/errors.js +0 -19
  471. package/src/rules/src/properties/getInformationsStateFromNewProps.js +0 -47
  472. package/src/rules/src/properties/information.js +0 -84
  473. package/src/rules/src/v8-transformer.js +0 -177
  474. package/src/rules2/src/getAdvAttrSeriesAtCoordinates.js +0 -29
  475. package/src/rules2/src/getMetadataStructureFromData.js +0 -17
  476. package/src/rules2/src/refineMetadataCoordinates.js +0 -28
  477. package/src/rules2/src/table/getCombinationDimensionsData.js +0 -39
@@ -1,55 +1,66 @@
1
- import { get, has, head, isUndefined, map, split, transform } from 'lodash';
1
+ import * as R from 'ramda';
2
2
  import { getRefAreaDimension } from '@sis-cc/dotstatsuite-sdmxjs';
3
3
  import { categoryDisplay, dimensionValueDisplay } from '../dimension-utils';
4
4
 
5
5
  const parseByAreas = (observations, refAreaDimension) => {
6
- if (isUndefined(refAreaDimension)) {
6
+ if (R.isNil(refAreaDimension)) {
7
7
  return null;
8
8
  }
9
- const refAreaDimIndex = get(refAreaDimension, 'index');
10
- const refAreaValues = refAreaDimension.values;
9
+ const { __index, values=[] } = refAreaDimension;
11
10
 
12
- return transform(
13
- observations,
14
- (acc, value, key) => {
15
- const splitedKey = split(key, ':');
16
- const areaValueIndex = get(splitedKey, `[${refAreaDimIndex}]`, null);
17
- const areaValue = get(refAreaValues, `[${areaValueIndex}]`, null);
18
- const areaId = get(areaValue, 'id', null);
19
- if (!has(acc, areaId)) {
20
- acc[areaId] = [];
21
- }
22
- acc[areaId].push({ splitedKey, value, areaValueIndex });
23
- },
24
- {}
25
- );
11
+ return R.pipe(
12
+ R.keys,
13
+ R.reduce((acc, key) => {
14
+ const value = observations[key];
15
+ const splitedKey = R.split(':', key);
16
+ const areaValueIndex = Number(R.nth(__index, splitedKey));
17
+ const areaValue = isNaN(areaValueIndex)
18
+ ? null : R.nth(areaValueIndex, values);
19
+ const areaId = R.prop('id', areaValue || {});
20
+ return R.over(
21
+ R.lensProp(areaId),
22
+ vals => R.append({ splitedKey, value, areaValueIndex }, vals || []),
23
+ acc
24
+ );
25
+ }, {})
26
+ )(observations);
26
27
  };
27
28
 
28
29
  export default ({ observations, dimensions }, dimensionsWithValuesIndexedById, topoMap, display) => {
29
30
  const refAreaDimension = getRefAreaDimension({ dimensions });
30
31
  const observationsByAreas = parseByAreas(observations, refAreaDimension);
31
- const topology = get(topoMap, 'topology', {});
32
- const areaSelection = get(topoMap, 'areaSelection', null);
33
- const topoAreas = get(topology, `objects.${areaSelection}`, null);
32
+ const topology = R.propOr({}, 'topology', topoMap);
33
+ const areaSelection = R.propOr(null, 'areaSelection', topoMap);
34
+ const topoAreas = R.pathOr(null, ['objects', areaSelection], topology);
34
35
  if (!observationsByAreas || !topoAreas) {
35
36
  return null;
36
37
  }
37
- const topoAreasWithData = map(
38
- topoAreas.geometries,
38
+ const topoAreasWithData = R.map(
39
39
  (areaGeometry) => {
40
- const areaObservation = head(get(observationsByAreas, get(areaGeometry, 'properties.id', null), []));
41
- const areaValueIndex = get(areaObservation, 'areaValueIndex', null);
42
- const areaValue = get(refAreaDimension, `values[${areaValueIndex}]`, null);
40
+ const areaObservation = R.pipe(
41
+ R.pathOr(null, ['properties', 'id']),
42
+ id => R.propOr([], id, observationsByAreas),
43
+ R.head
44
+ )(areaGeometry);
45
+ const areaValueIndex = R.propOr(null, 'areaValueIndex', areaObservation);
46
+ const areaValue = R.pathOr(null, ['values', areaValueIndex], refAreaDimension);
43
47
  return {
44
48
  ...areaGeometry,
45
49
  properties: {
46
- ...get(areaGeometry, 'properties', {}),
50
+ ...R.propOr({}, 'properties', areaGeometry),
47
51
  label: dimensionValueDisplay(display)(areaValue),
48
- value: head(get(areaObservation, 'value', [])),
49
- category: categoryDisplay(get(areaObservation, 'splitedKey', null), dimensions, dimensionsWithValuesIndexedById, refAreaDimension.id, display),
52
+ value: R.head(R.propOr([], 'value', areaObservation)),
53
+ category: categoryDisplay(
54
+ R.propOr([], 'splitedKey', areaObservation),
55
+ dimensions,
56
+ dimensionsWithValuesIndexedById,
57
+ refAreaDimension.id,
58
+ display
59
+ ),
50
60
  }
51
61
  };
52
- }
62
+ },
63
+ topoAreas.geometries,
53
64
  );
54
65
  return ({
55
66
  objects: {
@@ -0,0 +1,17 @@
1
+ import sampleFocus from './sample-focus';
2
+ import scatterFocus from './scatter-focus';
3
+ import timelineFocus from './timeline-focus';
4
+
5
+ export default ({ type, series, focusOptions }) => {
6
+ switch(type) {
7
+ case 'ScatterChart':
8
+ return scatterFocus(series, focusOptions);
9
+ case 'TimelineChart':
10
+ return timelineFocus(series, focusOptions);
11
+ case 'BarChart': case 'RowChart': case 'StackedBarChart':
12
+ case 'StackedRowChart': case 'HorizontalSymbolChart': case 'VerticalSymbolChart':
13
+ return sampleFocus(series, focusOptions);
14
+ default:
15
+ return series;
16
+ }
17
+ };
@@ -0,0 +1,8 @@
1
+ import getFocusedSeries from './focus';
2
+ import getSeries from './series';
3
+
4
+ export const getChartSeries = ({ type, data, options, singularity, focusOptions }) => {
5
+ const chartSeries = getSeries({ type, data, options, singularity });
6
+ const focusedSeries = getFocusedSeries({ type, series: chartSeries, focusOptions });
7
+ return focusedSeries;
8
+ };
@@ -1,22 +1,18 @@
1
- import { map, each, get, omit, isArray, keys, head } from 'lodash';
1
+ import * as R from 'ramda';
2
2
 
3
3
  export default function focus(series, focusSelections) {
4
- const serie = head(series);
5
- const datapoints = get(serie, 'datapoints', []);
4
+ const { highlight = [], baseline = [] } = focusSelections || {};
5
+ if (R.isEmpty(highlight) && R.isEmpty(baseline)) {
6
+ return series;
7
+ }
6
8
 
7
- const _datapoints = map(datapoints, (datapoint) => {
8
- let _datapoint = omit(datapoint, map(keys(focusSelections), focusKey => `${focusKey}Index`));
9
-
10
- each(focusSelections, (focusSelection, focusKey) => {
11
- const _focusKey = `${focusKey}Index`;
12
-
13
- each(isArray(focusSelection) ? focusSelection : [focusSelection], (focus, index) => {
14
- if (get(focus, 'value') === _datapoint.key) _datapoint[_focusKey] = index;
15
- });
16
- });
17
-
18
- return _datapoint;
19
- });
20
-
21
- return [{ ...serie, datapoints: _datapoints }];
9
+ return R.over(
10
+ R.lensPath([0, 'datapoints']),
11
+ R.map(dp => ({
12
+ ...dp,
13
+ highlightIndex: R.findIndex(R.propEq(dp.key, 'value'), highlight),
14
+ baselineIndex: R.path([0, 'value'], baseline) === dp.key ? 0 : -1
15
+ })),
16
+ series || []
17
+ );
22
18
  }
@@ -1,35 +1,35 @@
1
- import { map, sortBy, head, isEmpty, isNil, split } from 'lodash';
1
+ import * as R from 'ramda';
2
2
  import { categoryDisplay } from '../dimension-utils';
3
3
  import { getFormatedObservation } from '../observation-formater';
4
4
 
5
- export const getDatapoints = (
5
+ const getDatapoints = (
6
6
  keys, observations, dimensions, dimensionsWithValuesIndexedById, sortDirection, display, formaterAttrs
7
7
  ) => {
8
8
  const [categoryKey, valueKey] = keys;
9
9
  const sortFunc = dp => dp[valueKey] * sortDirection;
10
10
 
11
- return sortBy(
12
- map(
13
- observations,
14
- (observationValue, observationKey) => {
15
- const value = head(observationValue);
16
- const category = categoryDisplay(split(observationKey, ':'), dimensions, dimensionsWithValuesIndexedById, null, display);
17
- const categoryIds = categoryDisplay(split(observationKey, ':'), dimensions, dimensionsWithValuesIndexedById, null, 'code');
18
- const formatedValue = getFormatedObservation(observationValue, formaterAttrs);
11
+ return R.pipe(
12
+ R.keys,
13
+ R.map((observationKey) => {
14
+ const observationValue = R.prop(observationKey, observations);
15
+ const value = R.head(observationValue);
16
+ const splitKey = R.split(':', observationKey);
17
+ const category = categoryDisplay(splitKey, dimensions, dimensionsWithValuesIndexedById, null, display);
18
+ const categoryIds = categoryDisplay(splitKey, dimensions, dimensionsWithValuesIndexedById, null, 'code');
19
+ const formatedValue = getFormatedObservation(observationValue, formaterAttrs);
19
20
 
20
- let key = categoryIds;
21
- if (isNil(key) || isEmpty(key)) {
22
- key = 'uniq-dp';
23
- }
24
-
25
- return { value, category, [valueKey]: value, [categoryKey]: category, key, formatedValue };
21
+ let key = categoryIds;
22
+ if (R.isNil(key) || R.isEmpty(key)) {
23
+ key = 'uniq-dp';
26
24
  }
27
- ),
28
- sortFunc
29
- );
25
+
26
+ return { value, category, [valueKey]: value, [categoryKey]: category, key, formatedValue };
27
+ }),
28
+ R.sortBy(sortFunc)
29
+ )(observations);
30
30
  };
31
31
 
32
- export const series = (
32
+ const series = (
33
33
  keys, observations, dimensions, dimensionsWithValuesIndexedById, sortDirection, display, formaterAttrs
34
34
  ) => {
35
35
  return [{
@@ -1,39 +1,25 @@
1
- import { map, each, omit, get, split, reduce, isEmpty, keys } from 'lodash';
1
+ import * as R from 'ramda';
2
2
 
3
3
  export default function focus(series, focusSelections) {
4
- // scatter has only 1 serie
5
- const serie = get(series, '[0]', {});
6
-
7
- const _focusSelections = reduce(
8
- focusSelections,
9
- (memo, focusSelection, focusKey) => {
10
- if (!isEmpty(focusSelection)) memo[focusKey] = focusSelection;
11
- return memo;
12
- },
13
- {}
4
+ const { highlight = [], baseline = [] } = focusSelections || {};
5
+ if (R.isEmpty(highlight && R.isEmpty(baseline))) {
6
+ return series;
7
+ }
8
+
9
+ return R.over(
10
+ R.lensPath([0, 'datapoints']),
11
+ R.map(dp => {
12
+ const isFocusMatch = f => {
13
+ const focusedDim = R.path(['options', 'dimensionId'], f);
14
+ const dpValId = R.path(['dimensionValues', focusedDim, 'id'], dp);
15
+ return dpValId === R.path(['options', 'dimensionValueId'], f);
16
+ }
17
+ return ({
18
+ ...dp,
19
+ highlightIndex: R.findIndex(isFocusMatch, highlight),
20
+ baselineIndex: isFocusMatch(R.head(baseline)) ? 0 : -1
21
+ })
22
+ }),
23
+ series
14
24
  );
15
-
16
- if (isEmpty(_focusSelections)) return series;
17
-
18
- const datapoints = get(serie, 'datapoints', []);
19
-
20
- let _datapoints = map(datapoints, (datapoint) => (
21
- omit(datapoint, map(keys(focusSelections), focusKey => `${focusKey}Index`))
22
- ));
23
-
24
- const __datapoints = map(_datapoints, (datapoint) => {
25
- each(_focusSelections, (focusSelection, focusKey) => {
26
- const _focusKey = `${focusKey}Index`;
27
-
28
- each(focusSelection, (focus, i) => {
29
- const _focus = get(focus, 'options', {});
30
- const dimensionValueId = get(datapoint, `dimensionValues.${_focus.dimensionId}.id`);
31
- if (dimensionValueId === _focus.dimensionValueId) datapoint[_focusKey] = i;
32
- });
33
- });
34
-
35
- return datapoint;
36
- });
37
-
38
- return [{ ...serie, datapoints: __datapoints }];
39
- }
25
+ };
@@ -2,14 +2,14 @@ import * as R from 'ramda';
2
2
  import { dimensionValueDisplay } from '../dimension-utils';
3
3
  import { getFormatedObservation } from '../observation-formater';
4
4
 
5
- export function dimensionValueIsValid(dimensionValue, chartDimension) {
5
+ function dimensionValueIsValid(dimensionValue, chartDimension) {
6
6
  return R.includes(
7
7
  R.prop('id', dimensionValue),
8
8
  R.map(k => R.prop(`${k}Id`, chartDimension), ['x', 'y']),
9
9
  );
10
10
  };
11
11
 
12
- export function getDimensionValues(
12
+ function getDimensionValues(
13
13
  dimensionValuesIndexes, dimensions, dimensionsWithValuesIndexedById, chartDimensionId, display
14
14
  ) {
15
15
  const dimensionsWithValuesIds = R.keys(dimensionsWithValuesIndexedById);
@@ -32,13 +32,13 @@ export function getDimensionValues(
32
32
  );
33
33
  };
34
34
 
35
- export function getDimensionValueKey(chartDimension, dimensionValue) {
35
+ function getDimensionValueKey(chartDimension, dimensionValue) {
36
36
  return R.prop('xId', chartDimension,) === R.prop('id', dimensionValue) ? 'x' : 'y';
37
37
  };
38
38
 
39
- export function datapoints(observations, dimensions, dimensionsWithValuesIndexedById, chartDimension, display, formaterAttrs) {
39
+ function datapoints(observations, dimensions, dimensionsWithValuesIndexedById, chartDimension, display, formaterAttrs) {
40
40
  const chartDimensionId = R.prop('id', chartDimension);
41
- const chartDimensionIndex = R.findIndex(R.propEq('id', chartDimensionId), dimensions);
41
+ const chartDimensionIndex = R.findIndex(R.propEq(chartDimensionId, 'id'), dimensions);
42
42
  const datapoints = R.reduce(
43
43
  (acc, k) => {
44
44
  const o = R.prop(k, observations);
@@ -74,10 +74,10 @@ export function datapoints(observations, dimensions, dimensionsWithValuesIndexed
74
74
  )(datapoints);
75
75
  };
76
76
 
77
- export const series = (observations, dimensions, dimensionsWithValuesIndexedById, chartDimension, display, formaterAttrs) => {
77
+ const series = (observations, dimensions, dimensionsWithValuesIndexedById, chartDimension, display, formaterAttrs) => {
78
78
  const values = R.pipe(R.prop(R.prop('id', chartDimension || {})), R.propOr([], 'values'))(dimensionsWithValuesIndexedById);
79
- const xValue = R.find(R.propEq('id', R.prop('xId', chartDimension)), values);
80
- const yValue = R.find(R.propEq('id', R.prop('yId', chartDimension)), values);
79
+ const xValue = R.find(R.propEq(R.prop('xId', chartDimension),'id'), values);
80
+ const yValue = R.find(R.propEq(R.prop('yId', chartDimension), 'id'), values);
81
81
  return [{
82
82
  dimensionValues: {
83
83
  x: { ...xValue, name: dimensionValueDisplay(display)(xValue) },
@@ -0,0 +1,45 @@
1
+ import * as R from 'ramda';
2
+ import sampleSeries from './sample-series';
3
+ import scatterSeries from './scatter-series';
4
+ import timelineSeries from './timeline-series';
5
+ import symbolSeries from './symbol-series';
6
+ import stackedSeries from './stacked-series';
7
+ import choroSeries from './choro-series';
8
+ import { getObservationsFormaterAttributes } from '../observation-formater';
9
+
10
+ export default ({ type, data, options, singularity }) => {
11
+ const {
12
+ display,
13
+ formatterIds,
14
+ map,
15
+ } = options;
16
+
17
+ const { attributes = [] } = data;
18
+ const formaterAttributes = getObservationsFormaterAttributes(attributes, formatterIds);
19
+
20
+ const indexedDimensions = R.reduce((acc, dim) => {
21
+ if (dim.header) {
22
+ return acc;
23
+ }
24
+ return R.assoc(dim.id, dim, acc);
25
+ }, {}, data.dimensions || []);
26
+
27
+ switch(type) {
28
+ case 'BarChart': case 'RowChart':
29
+ return sampleSeries(type, data, indexedDimensions, display, formaterAttributes);
30
+ case 'ScatterChart':
31
+ return scatterSeries(data, indexedDimensions, singularity, display, formaterAttributes);
32
+ case 'TimelineChart':
33
+ return timelineSeries(data, indexedDimensions, display, formaterAttributes);
34
+ case 'HorizontalSymbolChart': case 'VerticalSymbolChart':
35
+ return symbolSeries(data, type, indexedDimensions, singularity, display, formaterAttributes);
36
+ case 'StackedBarChart':
37
+ return stackedSeries(data, indexedDimensions, singularity, display, formaterAttributes, ['y', 'x']);
38
+ case 'StackedRowChart':
39
+ return stackedSeries(data, indexedDimensions, singularity, display, formaterAttributes, ['x', 'y']);
40
+ case 'ChoroplethChart':
41
+ return choroSeries(data, indexedDimensions, map, display);
42
+ default:
43
+ return [];
44
+ }
45
+ };
@@ -65,12 +65,11 @@ const serie = (
65
65
  [stackKey, categoryKey]
66
66
  ) => {
67
67
  const serieDimensionId = R.propOr(null, 'id', singularity);
68
- const serieDimension = R.find(R.propEq('id', serieDimensionId), dimensions);
68
+ const serieDimension = R.find(R.propEq(serieDimensionId, 'id'), dimensions);
69
69
  if (R.isNil(serieDimension)) {
70
70
  return { datapoints: [], layerSeries: [] };
71
71
  }
72
72
  const _flatDatapoints = flatDatapoints(observations, dimensions, dimensionsWithValuesIndexedById, serieDimensionId, display, formaterAttrs, [stackKey, categoryKey]);
73
-
74
73
  const layeredDatapoints = R.groupBy(
75
74
  R.prop('layerKey'),
76
75
  _flatDatapoints
@@ -145,7 +144,7 @@ const percentSerie = (stackKey) => R.pipe(
145
144
  });
146
145
  })
147
146
  ),
148
- R.of
147
+ res => R.of(Array, res)
149
148
  );
150
149
 
151
150
  const serieSortedByTotal = (stackKey) => R.pipe(
@@ -153,7 +152,7 @@ const serieSortedByTotal = (stackKey) => R.pipe(
153
152
  R.lensProp('datapoints'),
154
153
  R.sortBy(R.pipe(R.prop(stackKey), R.map(v => v > 0 ? R.negate(v) : 0), R.sum))
155
154
  ),
156
- R.of
155
+ res => R.of(Array, res)
157
156
  );
158
157
 
159
158
  const serieSortedByDataOrder = R.pipe(
@@ -161,7 +160,7 @@ const serieSortedByDataOrder = R.pipe(
161
160
  R.lensProp('datapoints'),
162
161
  R.sortBy(R.prop('index'))
163
162
  ),
164
- R.of
163
+ res => R.of(Array, res)
165
164
  );
166
165
 
167
166
  export default (
@@ -1,52 +1,45 @@
1
- import { fill, findIndex, get, head, isEmpty, isNil, map, reduce, split, size, sortBy } from 'lodash';
1
+ import * as R from 'ramda';
2
2
  import { categoryDisplay, dimensionValueDisplay } from '../dimension-utils';
3
3
  import { getFormatedObservation } from '../observation-formater';
4
4
 
5
5
  const series = (observations, dimensions, dimensionsWithValuesIndexedById, symbolDimension, sortDirection, display, formaterAttrs) => {
6
- const symbolDimensionId = get(symbolDimension, 'id', null);
7
- if (symbolDimensionId === null) return [];
8
- const symbolDimensionIndex = findIndex(dimensions, d => d.id === symbolDimensionId);
9
- const datapoints = sortBy(
10
- reduce(
11
- observations,
12
- (memo, observationValue, observationKey) => {
13
- if (!(head(observationValue))) {
14
- // because yes it is possible to have null observations, why not ...
15
- return memo;
16
- }
17
- const oDimensionValuesIndexes = split(observationKey, ':');
18
- const oSymbolDimensionValueIndex = Number(oDimensionValuesIndexes[symbolDimensionIndex]);
19
- const oSymbolDimensionValueId = dimensions[symbolDimensionIndex].values[oSymbolDimensionValueIndex].id;
6
+ const symbolDimensionId = R.propOr(null, 'id', symbolDimension);
7
+ if (symbolDimensionId === null)
8
+ return [];
9
+ const symbolDimIndex = R.findIndex(d => d.id === symbolDimensionId, dimensions);
10
+ const datapoints = R.pipe(
11
+ R.keys,
12
+ R.reduce((acc, obsKey) => {
13
+ const obs = observations[obsKey];
14
+ if (R.isNil(R.head(obs)) || R.isEmpty(R.head(obs))) {
15
+ return acc;
16
+ }
17
+ const obsDimsValsIndexes = R.split(':', obsKey);
18
+ const symbolValIndex = Number(R.nth(symbolDimIndex, obsDimsValsIndexes));
19
+ const symbolValId = R.path([symbolDimIndex, 'values', symbolValIndex, 'id'], dimensions);
20
+ const symbolIndex = R.findIndex(R.propEq(symbolValId, 'id'), symbolDimension.serie);
21
+ if (symbolIndex === -1) {
22
+ return acc;
23
+ }
24
+ const category = categoryDisplay(obsDimsValsIndexes, dimensions, dimensionsWithValuesIndexedById, symbolDimensionId, display);
25
+ const ids = categoryDisplay(obsDimsValsIndexes, dimensions, dimensionsWithValuesIndexedById, symbolDimensionId, 'code');
26
+ const key = R.isNil(ids) || R.isEmpty(ids) ? 'uniq-dp' : ids;
27
+ const dpIndex = R.findIndex(R.propEq(key, 'key'), acc);
28
+ const dp = R.pipe(
29
+ dpIndex => dpIndex === -1
30
+ ? { category, formatedValues: new Array(R.length(symbolDimension.serie)), values: new Array(R.length(symbolDimension.serie)), key }
31
+ : R.nth(dpIndex, acc),
32
+ R.set(R.lensPath(['values', symbolValIndex]), R.head(obs)),
33
+ R.set(R.lensPath(['formatedValues', symbolValIndex]), getFormatedObservation(obs, formaterAttrs)),
34
+ )(dpIndex);
35
+ return dpIndex === -1
36
+ ? R.append(dp, acc)
37
+ : R.set(R.lensIndex(dpIndex), dp, acc);
38
+ }, []),
39
+ R.sortBy(d => R.head(d.values) * sortDirection)
40
+ )(observations);
20
41
 
21
- const symbolIndex = findIndex(symbolDimension.serie, v => v.id === oSymbolDimensionValueId);
22
- if (symbolIndex === -1) {
23
- return memo;
24
- }
25
- const category = categoryDisplay(oDimensionValuesIndexes, dimensions, dimensionsWithValuesIndexedById, symbolDimensionId, display);
26
- const ids = categoryDisplay(oDimensionValuesIndexes, dimensions, dimensionsWithValuesIndexedById, symbolDimensionId, 'code');
27
- let dpIndex = findIndex(memo, dp => dp.key === ids);
28
- let dpValues = (dpIndex === -1) ? fill(Array(size(symbolDimension.serie)), null) : memo[dpIndex].values;
29
- let dpFormatedValues = (dpIndex === -1) ? fill(Array(size(symbolDimension.serie)), null) : memo[dpIndex].formatedValues;
30
- dpValues[oSymbolDimensionValueIndex] = head(observationValue);
31
- dpFormatedValues[oSymbolDimensionValueIndex] = getFormatedObservation(observationValue, formaterAttrs);
32
- let key = ids;
33
- if (isNil(ids) || isEmpty(ids)) {
34
- key = 'uniq-dp';
35
- }
36
- if (dpIndex !== -1) {
37
- memo[dpIndex].values = dpValues;
38
- memo[dpIndex].formatedValues = dpFormatedValues;
39
- }
40
- else {
41
- memo.push({ category, formatedValues: dpFormatedValues, values: dpValues, key });
42
- }
43
- return memo;
44
- },
45
- []
46
- ),
47
- d => head(d.values) * sortDirection
48
- );
49
- const symbolValues = map(symbolDimension.serie, v => dimensionValueDisplay(display)(v));
42
+ const symbolValues = R.map(dimensionValueDisplay(display), symbolDimension.serie);
50
43
  return [{ datapoints , symbolValues }];
51
44
  }
52
45
 
@@ -1,18 +1,14 @@
1
- import { map, each, findIndex, get, omit, isArray, keys } from 'lodash';
1
+ import * as R from 'ramda';
2
2
 
3
3
  export default function focus(series, focusSelections) {
4
- return map(
5
- series,
6
- (serie, index) => {
7
- each(focusSelections, (focusSelection, focusKey) => {
8
- const _focusKey = `${focusKey}Index`;
9
- const res = findIndex(
10
- isArray(focusSelection) ? focusSelection : [focusSelection],
11
- focus => focus.value === serie.key
12
- );
13
- serie[`${_focusKey}`] = res;
14
- });
15
- return serie;
16
- }
4
+ const { highlight = [], baseline = [] } = focusSelections || {};
5
+
6
+ return R.map(
7
+ serie => ({
8
+ ...serie,
9
+ highlightIndex: R.findIndex(R.propEq(serie.key, 'value'), highlight),
10
+ baselineIndex: R.path([0, 'value'], baseline) === serie.key ? 0 : -1
11
+ }),
12
+ series
17
13
  );
18
14
  }